Compare commits
	
		
			239 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c9516d90e9 | |||
| 3cbe4617eb | |||
| de69fe6b6f | |||
| e53101dacb | |||
| d3ec749848 | |||
| 410b7d3dd6 | |||
| e87b233713 | |||
| ca38ecb1cf | |||
| 5dfa70dc10 | |||
| ff3daff15a | |||
| 7b7f235354 | |||
| 779c6247cd | |||
| fcaffa8c5f | |||
| d2ffcc903a | |||
| 1d12c97e30 | |||
| 3bcaeb214e | |||
| 85995040a8 | |||
| 826d06b532 | |||
| 3328e35cf4 | |||
| 091c56ec34 | |||
| 31e9910242 | |||
| f6e3c72e9c | |||
| 3f618bc970 | |||
| 1c766e568c | |||
| 8ed9bfbfcb | |||
| f1d66fc446 | |||
| 50977b367f | |||
| 45312d0564 | |||
| 3261d63b19 | |||
| 2894899ad4 | |||
| dd5c709709 | |||
| 618247f4d5 | |||
| abcf035143 | |||
| 0b015233a9 | |||
| 44d85b842c | |||
| 470f4a770b | |||
| 808a1ba0ea | |||
| 04cef606fc | |||
| 1ef6a1d0e4 | |||
| b163a3a7b9 | |||
| e7f7f28ff1 | |||
| b9c17fd360 | |||
| c7534a985a | |||
| 081373fc0d | |||
| 9130604fa6 | |||
| e8b32c4ed3 | |||
| 72ca259771 | |||
| d175c4b564 | |||
| fb2aeb8192 | |||
| 24c25ab26c | |||
| 9da91e460f | |||
| 2634cf7de9 | |||
| 7417091f3f | |||
| f9aad50f46 | |||
| 535cd5af2e | |||
| 4a8e469736 | |||
| 7d89f711fe | |||
| 7555a0389b | |||
| 1ac6e4b1a0 | |||
| d2fc4c6134 | |||
| 73cad308aa | |||
| c9f4c33ba1 | |||
| 3f0bdc593c | |||
| 0da2d38bd8 | |||
| 3a6ce52ead | |||
| eb0582ae69 | |||
| 3143d094e8 | |||
| f265a23f97 | |||
| dceeb410c6 | |||
| 30be08fe4d | |||
| 20247d0bc2 | |||
| c0ac325911 | |||
| c02ab116cd | |||
| 7ec4f2a61e | |||
| 16129ba742 | |||
| 61853fb71f | |||
| 58f13eb1dc | |||
| b999f17445 | |||
| c8047854f6 | |||
| 91ee23287a | |||
| 85b08b8c65 | |||
| c81079a876 | |||
| 8abe57552c | |||
| 3bf24b838b | |||
| e37928bf89 | |||
| 525173bc9f | |||
| aa6dacf0c5 | |||
| 69cc71ab3b | |||
| fe52d31168 | |||
| 3ea4307716 | |||
| 5650df1a9f | |||
| 8f154ebf48 | |||
| 47a4c62e92 | |||
| 539ad769d0 | |||
| 5fa90d9eab | |||
| ba9d56811c | |||
| 8eb8a328d1 | |||
| e8327316dd | |||
| 3bd7001106 | |||
| 2e5ad53c6a | |||
| ca0ae279e0 | |||
| adf1120436 | |||
| 7879391de0 | |||
| 11ba9ea418 | |||
| 0fe84ca17c | |||
| 1009ca5111 | |||
| 2c973fb0be | |||
| dba1f4e71c | |||
| 46fe124fe1 | |||
| 50688d7d8a | |||
| a7396e3c4a | |||
| 41e969f79e | |||
| 7b3f78f745 | |||
| 14bc171246 | |||
| a584c0751e | |||
| 3d7528e069 | |||
| 58cc75ef71 | |||
| b5a9462e95 | |||
| 1bc421ac6d | |||
| ad0d091b49 | |||
| 22de686a44 | |||
| 3e7eb09758 | |||
| e2a276085b | |||
| d561c579e0 | |||
| 371d117746 | |||
| 28c681a562 | |||
| 2131efb522 | |||
| 6e20774edf | |||
| a7c7744ff3 | |||
| 019aefbc61 | |||
| 81a23305ba | |||
| 4001abff02 | |||
| 25bfbeb8d6 | |||
| 44025c3978 | |||
| a3aa9747b8 | |||
| 009243b091 | |||
| e31e0b6680 | |||
| 449bb2522b | |||
| 453dce9520 | |||
| 655592186b | |||
| 1ebf67233b | |||
| 1588dabcbe | |||
| 09d3995e6c | |||
| db20385a6d | |||
| d701935ddf | |||
| d3888e3c32 | |||
| 94f0795247 | |||
| 4def73d738 | |||
| 99445406fc | |||
| 8c32d18aec | |||
| 20c31153de | |||
| 025fa57e24 | |||
| 6f04d0bf07 | |||
| ecb9a805e5 | |||
| 0577acad93 | |||
| d7f83fa4d4 | |||
| 4c4f4d52d2 | |||
| 0bf9025c0d | |||
| 7a0f56cad8 | |||
| 2784b57a05 | |||
| b9fc9748c7 | |||
| c98299d916 | |||
| f6e25fd966 | |||
| 557b9429bf | |||
| 139f7bbd0a | |||
| ec25f6426a | |||
| 00283b4f28 | |||
| e08b5cde69 | |||
| ec8e4c36a4 | |||
| 07c7718320 | |||
| 2953e977ef | |||
| 92522b1229 | |||
| 9ef9dcd7b9 | |||
| 5fd8096ef0 | |||
| 5f59543a14 | |||
| d44593d6d4 | |||
| 38744ff8e8 | |||
| 83e935a3f4 | |||
| 4d96e73866 | |||
| a55ce75e2e | |||
| c45dbf1dac | |||
| 2d08629608 | |||
| 49bc67a64f | |||
| abec4d9281 | |||
| 149bc601e2 | |||
| 66deede936 | |||
| 0df5511bf7 | |||
| 2e68218cfe | |||
| 80f3568dbd | |||
| 5fd0ff9e71 | |||
| 4dcfa05157 | |||
| 42648f31a5 | |||
| e0b628dce9 | |||
| 6e9c7e28e6 | |||
| ac091a7d26 | |||
| 8f31532917 | |||
| 612e7955cf | |||
| ce92031ff7 | |||
| 5a7e63871d | |||
| 7ade7f6e24 | |||
| e470ef0553 | |||
| fb01a4f8df | |||
| eacdca8669 | |||
| df97a6dd01 | |||
| 0259d4ff1d | |||
| f71e9938bb | |||
| 69f8e3f4fc | |||
| f49c888307 | |||
| 04a2da4371 | |||
| 59372b23e4 | |||
| 2970c0d7d4 | |||
| 392f1b09b2 | |||
| 79f66e9641 | |||
| e90fceca86 | |||
| 24d5cee8b4 | |||
| 31f608a9ec | |||
| 1ba4c4f343 | |||
| 700d9656b2 | |||
| 0c17d9abc2 | |||
| 2c1476b74c | |||
| 0fa71727ac | |||
| 20cacf26ae | |||
| 1d406b0c7e | |||
| a099d27b86 | |||
| 3e53ec9191 | |||
| 637cbd9954 | |||
| 717251ca5e | |||
| 5d3bb41275 | |||
| e5211fee00 | |||
| e9e934cfb1 | |||
| a417ddda85 | |||
| f273a8839a | |||
| 62ae81c7b3 | |||
| 6db9567eb9 | |||
| 8ef08c53b3 | |||
| 9fdbdb05f4 | |||
| d392131005 | |||
| 389b9e382b | |||
| 6fd84e2f2a | 
| @@ -5,7 +5,7 @@ | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -44,6 +44,7 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
| @@ -53,13 +54,14 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <OutputPath>bin\Debug\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -32,9 +32,9 @@ namespace AdjustBuildRevision | ||||
| 						{ | ||||
| 							// Allow for setting build revision on either proms or the roeditor: | ||||
| 							if (Directory.GetCurrentDirectory().ToUpper().Contains("REFOBJ")) | ||||
| 								outline = Regex.Replace(line, @"([0-9]*)\.([0-9]*)\.([0-9]*)\.([0-9]*)""\)", DateTime.Now.ToString("2.3.yyMM.dHH") + "\")"); | ||||
| 								outline = Regex.Replace(line, @"([0-9]*)\.([0-9]*)\.([0-9]*)\.([0-9]*)""\)", DateTime.Now.ToString("2.4.yyMM.dHH") + "\")"); | ||||
| 							else | ||||
| 								outline = Regex.Replace(line, @"([0-9]*)\.([0-9]*)\.([0-9]*)\.([0-9]*)""\)", DateTime.Now.ToString("2.2.yyMM.dHH") + "\")"); | ||||
| 								outline = Regex.Replace(line, @"([0-9]*)\.([0-9]*)\.([0-9]*)\.([0-9]*)""\)", DateTime.Now.ToString("2.3.yyMM.dHH") + "\")"); | ||||
| 					//		if (outline != line) | ||||
| 					//		{ | ||||
| 					//			Console.WriteLine("Before: '{0}'", line); | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
|     <TargetFrameworkProfile /> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> | ||||
|     <PlatformTarget>AnyCPU</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <DebugType>full</DebugType> | ||||
|     <Optimize>false</Optimize> | ||||
| @@ -30,15 +30,17 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <PlatformTarget>AnyCPU</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <Optimize>true</Optimize> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <ItemGroup> | ||||
|     <Reference Include="System" /> | ||||
|   | ||||
| @@ -28,7 +28,9 @@ namespace AT.STO.UI.Win | ||||
|  | ||||
| 			_dropDownHelper = new DropDownWindowHelper(); | ||||
|  | ||||
| 			_dropDownHelper.DropDownClosed -= new DropDownClosedEventHandler(DropDownHelper_DropDownClosed); | ||||
| 			_dropDownHelper.DropDownClosed += new DropDownClosedEventHandler(DropDownHelper_DropDownClosed); | ||||
| 			_dropDownHelper.DropDownCancel -= new DropDownCancelEventHandler(DropDownHelper_DropDownCancel); | ||||
| 			_dropDownHelper.DropDownCancel += new DropDownCancelEventHandler(DropDownHelper_DropDownCancel); | ||||
| 			 | ||||
| 			combo.DisplayMember = "Text"; | ||||
| @@ -82,7 +84,9 @@ namespace AT.STO.UI.Win | ||||
| 				DropDownForm dropDown = new DropDownForm(_dropDownControl); | ||||
| 				 | ||||
| 				 | ||||
| 				dropDown.FinishEditing -= new DropDownValueChangedEventHandler(DropDown_FinishEditing); | ||||
| 				dropDown.FinishEditing += new DropDownValueChangedEventHandler(DropDown_FinishEditing); | ||||
| 				dropDown.ValueChanged -= new DropDownValueChangedEventHandler(DropDown_ValueChanged); | ||||
| 				dropDown.ValueChanged += new DropDownValueChangedEventHandler(DropDown_ValueChanged); | ||||
| 				 | ||||
| 				combo.DroppedDown = false; | ||||
|   | ||||
| @@ -34,7 +34,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
| @@ -45,13 +45,14 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Demo|AnyCPU' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <OutputPath>bin\Demo\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -60,7 +61,7 @@ | ||||
|     <OutputPath>bin\Debug\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -69,7 +70,7 @@ | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -78,7 +79,7 @@ | ||||
|     <OutputPath>bin\Demo\</OutputPath> | ||||
|     <DefineConstants>TRACE;DEMO</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -49,7 +49,9 @@ namespace AT.STO.UI.Win | ||||
| 		{ | ||||
| 			base.OnShown(e); | ||||
| 			 | ||||
| 			_control.FinishEditing -= new DropDownValueChangedEventHandler(Ctrl_FinishEditing); | ||||
| 			_control.FinishEditing += new DropDownValueChangedEventHandler(Ctrl_FinishEditing); | ||||
| 			_control.ValueChanged -= new DropDownValueChangedEventHandler(Ctrl_ValueChanged); | ||||
| 			_control.ValueChanged += new DropDownValueChangedEventHandler(Ctrl_ValueChanged); | ||||
| 		} | ||||
| 	#endregion | ||||
|   | ||||
| @@ -39,6 +39,7 @@ namespace AT.STO.UI.Win | ||||
| 		public DropDownWindowHelper() | ||||
| 		{ | ||||
| 			_filter = new DropDownMessageFilter(this); | ||||
| 			_filter.DropDownCancel -= new DropDownCancelEventHandler(Popup_Cancel); | ||||
| 			_filter.DropDownCancel += new DropDownCancelEventHandler(Popup_Cancel); | ||||
| 		} | ||||
| 	#endregion | ||||
|   | ||||
| @@ -29,7 +29,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
| @@ -40,13 +40,14 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'"> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <OutputPath>bin\Debug\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
| @@ -56,7 +57,7 @@ | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   | ||||
| @@ -35,6 +35,7 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
| @@ -44,6 +45,7 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <ItemGroup> | ||||
|     <Reference Include="DevComponents.DotNetBar2, Version=14.1.0.37, Culture=neutral, PublicKeyToken=7eb7c3a35b91de04, processorArchitecture=MSIL"> | ||||
| @@ -92,6 +94,10 @@ | ||||
|     </Compile> | ||||
|   </ItemGroup> | ||||
|   <ItemGroup> | ||||
|     <Content Include="epall\EPFormatTST1.xml" /> | ||||
|     <Content Include="epall\EPFormatTST2.xml" /> | ||||
|     <Content Include="epall\EPFormatTST3.xml" /> | ||||
|     <Content Include="epall\EPFormatTST4.xml" /> | ||||
|     <Content Include="fmtall\AEPall.xml"> | ||||
|       <SubType>Designer</SubType> | ||||
|     </Content> | ||||
| @@ -176,6 +182,8 @@ | ||||
|     <Content Include="fmtall\CPL_03all.xml" /> | ||||
|     <Content Include="fmtall\CPSAMGDataall.xml" /> | ||||
|     <Content Include="fmtall\CPSAMGDEVall.xml" /> | ||||
|     <Content Include="fmtall\EPTSTBCK1all.xml" /> | ||||
|     <Content Include="fmtall\EPTST1all.xml" /> | ||||
|     <Content Include="fmtall\CWEall.xml" /> | ||||
|     <Content Include="fmtall\CWEDEVall.xml" /> | ||||
|     <Content Include="fmtall\CWERall.xml" /> | ||||
| @@ -187,6 +195,7 @@ | ||||
|     <Content Include="fmtall\EFSGBCKall.xml" /> | ||||
|     <Content Include="fmtall\ELFDEVall.xml" /> | ||||
|     <Content Include="fmtall\ENall.xml" /> | ||||
|     <Content Include="fmtall\EPTST2all.xml" /> | ||||
|     <Content Include="fmtall\ESFDEVall.xml" /> | ||||
|     <Content Include="fmtall\EXCLNall.xml" /> | ||||
|     <Content Include="fmtall\EXCLN_00all.xml" /> | ||||
| @@ -282,6 +291,10 @@ | ||||
|     <Content Include="fmtall\NSPWGall.xml" /> | ||||
|     <Content Include="fmtall\NSP_00all.xml" /> | ||||
|     <Content Include="fmtall\OHLPall.xml" /> | ||||
|     <Content Include="fmtall\PROMSDemo1all.xml" /> | ||||
|     <Content Include="fmtall\PROMSDemo2all.xml" /> | ||||
|     <Content Include="fmtall\PROMSDemoALRall.xml" /> | ||||
|     <Content Include="fmtall\PROMSDemoBCKall.xml" /> | ||||
|     <Content Include="fmtall\PROMSMan1all.xml" /> | ||||
|     <Content Include="fmtall\PROMSMan2all.xml" /> | ||||
|     <Content Include="fmtall\RGEall.xml" /> | ||||
| @@ -499,6 +512,10 @@ | ||||
|     <Content Include="genmacall\nspsam.svg" /> | ||||
|     <Content Include="genmacall\nspsamdev.svg" /> | ||||
|     <Content Include="genmacall\ohlp.svg" /> | ||||
|     <Content Include="genmacall\PROMSDemo1.svg" /> | ||||
|     <Content Include="genmacall\PROMSDemo2.svg" /> | ||||
|     <Content Include="genmacall\PROMSDemoALR.svg" /> | ||||
|     <Content Include="genmacall\PROMSDemoBCK.svg" /> | ||||
|     <Content Include="genmacall\PROMSMan1.svg" /> | ||||
|     <Content Include="genmacall\PROMSMan2.svg" /> | ||||
|     <Content Include="genmacall\rge.svg" /> | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST1.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST1.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST2.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST2.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST3.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST3.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST4.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/epall/EPFormatTST4.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/EPTST1all.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/EPTST1all.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/EPTST2all.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/EPTST2all.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/EPTSTBCK1all.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/EPTSTBCK1all.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemo1all.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemo1all.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemo2all.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemo2all.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemoALRall.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemoALRall.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemoBCKall.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/fmtall/PROMSDemoBCKall.xml
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										17
									
								
								PROMS/Formats/frmFormatCopy.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										17
									
								
								PROMS/Formats/frmFormatCopy.Designer.cs
									
									
									
										generated
									
									
									
								
							| @@ -35,6 +35,7 @@ namespace Formats | ||||
| 			this.buttonX2 = new DevComponents.DotNetBar.ButtonX(); | ||||
| 			this.labelX2 = new DevComponents.DotNetBar.LabelX(); | ||||
| 			this.LstBxExcludeFiles = new DevComponents.DotNetBar.ListBoxAdv(); | ||||
| 			this.cbIncludeDemoFormats = new DevComponents.DotNetBar.Controls.CheckBoxX(); | ||||
| 			this.SuspendLayout(); | ||||
| 			//  | ||||
| 			// txbxPROMSFormatsPath | ||||
| @@ -131,11 +132,26 @@ namespace Formats | ||||
| 			this.LstBxExcludeFiles.TabIndex = 6; | ||||
| 			this.LstBxExcludeFiles.Text = "listBoxAdv1"; | ||||
| 			//  | ||||
| 			// cbIncludeDemoFormats | ||||
| 			//  | ||||
| 			//  | ||||
| 			//  | ||||
| 			//  | ||||
| 			this.cbIncludeDemoFormats.BackgroundStyle.CornerType = DevComponents.DotNetBar.eCornerType.Square; | ||||
| 			this.cbIncludeDemoFormats.Font = new System.Drawing.Font("Microsoft Sans Serif", 9.75F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
| 			this.cbIncludeDemoFormats.Location = new System.Drawing.Point(43, 156); | ||||
| 			this.cbIncludeDemoFormats.Name = "cbIncludeDemoFormats"; | ||||
| 			this.cbIncludeDemoFormats.Size = new System.Drawing.Size(160, 23); | ||||
| 			this.cbIncludeDemoFormats.Style = DevComponents.DotNetBar.eDotNetBarStyle.Office2010; | ||||
| 			this.cbIncludeDemoFormats.TabIndex = 7; | ||||
| 			this.cbIncludeDemoFormats.Text = "Include Demo Formats"; | ||||
| 			//  | ||||
| 			// frmFormatCopy | ||||
| 			//  | ||||
| 			this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); | ||||
| 			this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | ||||
| 			this.ClientSize = new System.Drawing.Size(496, 191); | ||||
| 			this.Controls.Add(this.cbIncludeDemoFormats); | ||||
| 			this.Controls.Add(this.LstBxExcludeFiles); | ||||
| 			this.Controls.Add(this.labelX2); | ||||
| 			this.Controls.Add(this.buttonX2); | ||||
| @@ -158,6 +174,7 @@ namespace Formats | ||||
| 		private DevComponents.DotNetBar.ButtonX buttonX2; | ||||
| 		private DevComponents.DotNetBar.LabelX labelX2; | ||||
| 		private DevComponents.DotNetBar.ListBoxAdv LstBxExcludeFiles; | ||||
| 		private DevComponents.DotNetBar.Controls.CheckBoxX cbIncludeDemoFormats; | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -96,13 +96,17 @@ namespace Formats | ||||
| 			if (!txbxPROMSFormatsPath.Text.EndsWith(@"\")) txbxPROMSFormatsPath.Text += @"\"; | ||||
| 		} | ||||
|  | ||||
| 		public string[] excludeThese = { "WPS", "WPB", "VCBEPP" }; | ||||
| 		// Added a PROMSDemo to the list of excluded format files | ||||
| 		public string[] excludeThese = { "WPS", "WPB", "VCBEPP", "PROMSDemo" }; | ||||
| 		 | ||||
| 		// Added logic to support in inclusion of the PROMSDemo formats if the checkbox on the | ||||
| 		// dialog is check | ||||
| 		private bool ExcludeFromCopy(string fn) | ||||
| 		{ | ||||
| 			// don't copy formats whos file name starts with.. | ||||
| 			foreach (string excludeThis in excludeThese) | ||||
| 				if (fn.ToUpper().StartsWith(excludeThis)) return true; | ||||
| 				if (fn.ToUpper().StartsWith(excludeThis)  | ||||
| 					&& !(cbIncludeDemoFormats.Checked && fn.ToUpper().StartsWith("PROMSDEMO"))) return true; | ||||
| 			return false; | ||||
| 		} | ||||
|  | ||||
| @@ -161,5 +165,5 @@ namespace Formats | ||||
| 			Application.Exit(); | ||||
| 		} | ||||
|  | ||||
| } | ||||
| 	} | ||||
| } | ||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemo1.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemo1.svg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemo2.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemo2.svg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemoALR.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemoALR.svg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemoBCK.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/Formats/genmacall/PROMSDemoBCK.svg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -34,7 +34,7 @@ | ||||
|     <DefineConstants>TRACE;DEBUG</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
| @@ -45,13 +45,14 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'"> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <OutputPath>bin\Debug\</OutputPath> | ||||
|     <DefineConstants>TRACE;DEBUG</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
| @@ -61,7 +62,7 @@ | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   | ||||
| @@ -59,7 +59,7 @@ | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
| @@ -85,6 +85,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -92,7 +93,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -103,7 +104,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -71,7 +71,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -96,6 +96,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -103,7 +104,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -62,6 +62,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -86,6 +87,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -93,7 +95,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -35,6 +35,7 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
| @@ -44,13 +45,14 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <OutputPath>bin\Debug\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -59,7 +61,7 @@ | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -409,7 +409,7 @@ namespace RODBInterface | ||||
| 			GetDbServerInfo(ropath); | ||||
| 			if (!dbProviderType.Equals((int)DB_PROVIDER.SQL_SERVER)) | ||||
| 			{ | ||||
| 				strDatabaseConnectionCommand = "Provider=Microsoft.Jet.OLEDB.4.0;Password=\"\";User ID=Admin;Data Source=" + DataConnectionPath + "\\ROMaster.mdb;Mode=Share Deny None;Extended Properties=\"\";Jet OLEDB:System database=\"\";Jet OLEDB:Registry Path=\"\";Jet OLEDB:Database Password=\"\";Jet OLEDB:Engine Type=5;Jet OLEDB:Database Locking Mode=1;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password=\"\";Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False"; | ||||
| 				strDatabaseConnectionCommand = "Provider=Microsoft.ACE.OLEDB.12.0;Password=\"\";User ID=Admin;Data Source=" + DataConnectionPath + "\\ROMaster.mdb;Mode=Share Deny None;Extended Properties=\"\";Jet OLEDB:System database=\"\";Jet OLEDB:Registry Path=\"\";Jet OLEDB:Database Password=\"\";Jet OLEDB:Engine Type=5;Jet OLEDB:Database Locking Mode=1;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password=\"\";Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False"; | ||||
| 			} | ||||
| 		} | ||||
| 		#endregion | ||||
|   | ||||
| @@ -62,6 +62,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -86,6 +87,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -93,7 +95,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -171,6 +173,17 @@ | ||||
|       <Name>VlnStatus</Name> | ||||
|     </ProjectReference> | ||||
|   </ItemGroup> | ||||
|   <ItemGroup> | ||||
|     <COMReference Include="Microsoft.Office.Interop.Access.Dao"> | ||||
|       <Guid>{4AC9E1DA-5BAD-4AC7-86E3-24F4CDCECA28}</Guid> | ||||
|       <VersionMajor>12</VersionMajor> | ||||
|       <VersionMinor>0</VersionMinor> | ||||
|       <Lcid>0</Lcid> | ||||
|       <WrapperTool>primary</WrapperTool> | ||||
|       <Isolated>False</Isolated> | ||||
|       <EmbedInteropTypes>True</EmbedInteropTypes> | ||||
|     </COMReference> | ||||
|   </ItemGroup> | ||||
|   <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> | ||||
|   <PropertyGroup> | ||||
|     <PreBuildEvent> | ||||
|   | ||||
| @@ -735,10 +735,13 @@ namespace RODBInterface | ||||
| 				else | ||||
| 					parentValue = nd.InnerText; | ||||
|  | ||||
| 				if (parentName != "#whitespace") | ||||
| 				{ | ||||
| 					//applicValues = ""; | ||||
| 					applicValues = string.Format("<APL DefaultVal={0}", parentValue); | ||||
| 					int pcChildIdx = 0; | ||||
| 					//C2022-001 only save the child ro value in the RO.FST if it is different than the parent (default) value | ||||
|  | ||||
| 					foreach (string c in pcChildern) | ||||
| 					{ | ||||
| 						//string csufx = CvtUserFldToFld(c); | ||||
| @@ -754,6 +757,7 @@ namespace RODBInterface | ||||
| 								applicValues += string.Format(",UnitIdx={0} Value={1}", pcChildIdx, cn.InnerText); | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 				applicValues += " /APL>"; | ||||
| 			} | ||||
| 			return applicValues; | ||||
|   | ||||
| @@ -62,6 +62,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -86,6 +87,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -93,7 +95,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE;Upgrade2005;</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -62,6 +62,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -86,6 +87,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -93,7 +95,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -77,6 +77,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -101,6 +102,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -108,7 +110,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -119,7 +121,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -73,6 +73,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -97,6 +98,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -62,6 +62,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -86,6 +87,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -93,7 +95,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -276,8 +276,10 @@ namespace ctlXMLEditLib | ||||
| 			bool imagechild;	//whether this field is a subchild of an image | ||||
| 			string imagename;	//if subchild of image, name of image parent (for save) | ||||
| 			string imagedate;   //if this was filename, save the date/time stamp | ||||
| 			string name;        //name of element | ||||
| 			string parenthtid;  //name of parent element in hashtable for PC items | ||||
| 			public TextBoxAttrTag(bool reqd, string ptn, RadioButton rd, bool img,  | ||||
| 				string imgname, string imgdate)  | ||||
| 				string imgname, string imgdate, string elemname)  | ||||
| 			{ | ||||
| 				this.req_msg = null; | ||||
| 				this.required = reqd; | ||||
| @@ -286,6 +288,12 @@ namespace ctlXMLEditLib | ||||
| 				this.imagechild = img; | ||||
| 				this.imagename = imgname; | ||||
| 				this.imagedate = imgdate; | ||||
| 				this.name = elemname; | ||||
|  | ||||
| 				if (name.Contains("_PCCHILD")) | ||||
| 					this.parenthtid = name.Substring(0, name.IndexOf("_PCCHILD")); | ||||
| 				else | ||||
| 					this.parenthtid = null; | ||||
| 			} | ||||
| 			public void SetPattern(string pattern) {this.pattern = pattern;} | ||||
| 			public void SetRequired(bool req) {this.required = req;} | ||||
| @@ -298,6 +306,10 @@ namespace ctlXMLEditLib | ||||
| 			public string GetImageName { get {return imagename;}} | ||||
| 			public string GetImageDate { get {return imagedate;}} | ||||
| 			public void SetImageDate(string imgdate) {this.imagedate = imgdate;} | ||||
| 			public string GetName { get { return name; } } | ||||
| 			public void SetName(string elemname) { this.name = elemname; } | ||||
| 			public string GetParentHTId { get { return parenthtid; } } | ||||
| 			public void SetParentHTId(string id) { this.parenthtid = id; } | ||||
| 		} | ||||
|  | ||||
| 		public ctlXMLEdit(VlnXmlElement myelem, XmlSchema myschema, ArrayList reqfields, ArrayList fldsWithApplic, string [] pckids) | ||||
| @@ -928,7 +940,7 @@ namespace ctlXMLEditLib | ||||
| 			// initialization. | ||||
| 			if (mytextbox.Tag == null) | ||||
| 			{ | ||||
| 				TextBoxAttrTag tag = new TextBoxAttrTag(false, pattern, radio, img, (img?imgname:null), null); | ||||
| 				TextBoxAttrTag tag = new TextBoxAttrTag(false, pattern, radio, img, (img?imgname:null), null, mytextbox.Name); | ||||
| 				mytextbox.Tag = (object) tag; | ||||
| 			} | ||||
| 			return getannot; | ||||
| @@ -1136,6 +1148,7 @@ namespace ctlXMLEditLib | ||||
| 				mytextbox = new TextBox(); | ||||
| 				mytextbox.Location = new Point(screenx+indent, screeny); | ||||
| 				string tFieldName = (pcChildIdx == 0) ? CvtUserFldToFld(element.Name) : CvtUserFldToFld(pcChildFldName); | ||||
| 				mytextbox.Name = tFieldName; | ||||
| 				myHT.Add(tFieldName, mytextbox); | ||||
| 				tabindx++; | ||||
| 				Controls.Add(mytextbox); | ||||
| @@ -1192,14 +1205,39 @@ namespace ctlXMLEditLib | ||||
| 		// C2021-026 Event handler for Parent/Child child textbox | ||||
| 		//           if the textbox text is same as parent, then or nothing is entered in the textbox | ||||
| 		//           then use the parent value and set the text color to gray | ||||
| 		// B2025-028 RO Editor - Parent Child Applicability - Default Values | ||||
| 		//           Were always setting to the Group parent value instead of individual parent values | ||||
| 		//           When leaving the textbox | ||||
| 		private void txtBox_Leave(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			TextBox tb = sender as TextBox; | ||||
| 			string dfTxt = ""; | ||||
| 			try | ||||
| 			{ | ||||
| 				string parentid = ((TextBoxAttrTag)tb.Tag).GetParentHTId; | ||||
| 				if (!string.IsNullOrEmpty(parentid)) | ||||
| 				{ | ||||
| 					object o = myHT[parentid]; | ||||
| 					if (o != null) | ||||
| 						dfTxt = (o as TextBox).Text; // set to use the parent's value (default)				 | ||||
| 				} | ||||
| 				else | ||||
|                 { | ||||
|  | ||||
| 					string parName = pcGrpBox.Name.Substring(5); | ||||
| 					object o = myHT[parName]; | ||||
| 					if (o != null) | ||||
| 						dfTxt = (o as TextBox).Text; // set to use the parent's value (default) | ||||
| 				} | ||||
| 			} | ||||
|             catch  | ||||
| 			{ | ||||
| 				string parName = pcGrpBox.Name.Substring(5); | ||||
| 				object o = myHT[parName]; | ||||
| 				if (o != null) | ||||
| 					dfTxt = (o as TextBox).Text; // set to use the parent's value (default) | ||||
| 			} | ||||
|  | ||||
| 			if (dosaveflag) mysavexml = true; | ||||
| 			if (tb.Text.Length == 0 || tb.Text == dfTxt) | ||||
| 			{ | ||||
|   | ||||
| @@ -62,6 +62,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -86,6 +87,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -93,7 +95,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -104,7 +106,7 @@ | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType> | ||||
|     </DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   | ||||
| @@ -229,7 +229,7 @@ namespace RoAccessToSql | ||||
| 					if (sqlConnection.State == ConnectionState.Open) | ||||
| 					{ | ||||
| 						// now try to open access db: | ||||
| 						string strDatabaseConnectionCommand = "Provider=Microsoft.Jet.OLEDB.4.0;Password=\"\";User ID=Admin;Data Source=" + MSAccessPath + "\\ROMaster.mdb;Mode=Share Deny None;Extended Properties=\"\";Jet OLEDB:System database=\"\";Jet OLEDB:Registry Path=\"\";Jet OLEDB:Database Password=\"\";Jet OLEDB:Engine Type=5;Jet OLEDB:Database Locking Mode=1;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password=\"\";Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False"; | ||||
| 						string strDatabaseConnectionCommand = "Provider=Microsoft.ACE.OLEDB.12.0;Password=\"\";User ID=Admin;Data Source=" + MSAccessPath + "\\ROMaster.mdb;Mode=Share Deny None;Extended Properties=\"\";Jet OLEDB:System database=\"\";Jet OLEDB:Registry Path=\"\";Jet OLEDB:Database Password=\"\";Jet OLEDB:Engine Type=5;Jet OLEDB:Database Locking Mode=1;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password=\"\";Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False"; | ||||
| 						using (OleDbConnection accessConnection = new OleDbConnection(strDatabaseConnectionCommand)) | ||||
| 						{ | ||||
| 							try | ||||
|   | ||||
| @@ -22,7 +22,7 @@ | ||||
|     </SccProvider> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> | ||||
|     <PlatformTarget>AnyCPU</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <DebugType>full</DebugType> | ||||
|     <Optimize>false</Optimize> | ||||
| @@ -30,15 +30,17 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <PlatformTarget>AnyCPU</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <Optimize>true</Optimize> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <ItemGroup> | ||||
|     <Reference Include="DevComponents.DotNetBar2, Version=14.1.0.37, Culture=neutral, PublicKeyToken=7eb7c3a35b91de04, processorArchitecture=MSIL"> | ||||
| @@ -98,6 +100,17 @@ | ||||
|   <ItemGroup> | ||||
|     <None Include="App.config" /> | ||||
|   </ItemGroup> | ||||
|   <ItemGroup> | ||||
|     <COMReference Include="Microsoft.Office.Interop.Access.Dao"> | ||||
|       <Guid>{4AC9E1DA-5BAD-4AC7-86E3-24F4CDCECA28}</Guid> | ||||
|       <VersionMajor>12</VersionMajor> | ||||
|       <VersionMinor>0</VersionMinor> | ||||
|       <Lcid>0</Lcid> | ||||
|       <WrapperTool>primary</WrapperTool> | ||||
|       <Isolated>False</Isolated> | ||||
|       <EmbedInteropTypes>True</EmbedInteropTypes> | ||||
|     </COMReference> | ||||
|   </ItemGroup> | ||||
|   <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> | ||||
|   <!-- To modify your build process, add your task inside one of the targets below and uncomment it.  | ||||
|        Other similar extension points exist, see Microsoft.Common.targets. | ||||
|   | ||||
| @@ -60,6 +60,7 @@ | ||||
|     <DebugType>full</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -84,6 +85,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release_PreRegistered|AnyCPU' "> | ||||
|     <OutputPath>bin\Release\</OutputPath> | ||||
| @@ -108,6 +110,7 @@ | ||||
|     <DebugType>none</DebugType> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)' == 'Debug|x86'"> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
| @@ -116,7 +119,7 @@ | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <FileAlignment>4096</FileAlignment> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
| @@ -127,7 +130,7 @@ | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <Optimize>true</Optimize> | ||||
|     <FileAlignment>4096</FileAlignment> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
| @@ -138,7 +141,7 @@ | ||||
|     <BaseAddress>285212672</BaseAddress> | ||||
|     <Optimize>true</Optimize> | ||||
|     <FileAlignment>4096</FileAlignment> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <CodeAnalysisRuleSet>MinimumRecommendedRules.ruleset</CodeAnalysisRuleSet> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   | ||||
							
								
								
									
										203
									
								
								PROMS/VEPROMS User Interface/DlgAnnotationsSelect.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										203
									
								
								PROMS/VEPROMS User Interface/DlgAnnotationsSelect.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,203 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.ComponentModel; | ||||
| using System.Data; | ||||
| using System.Drawing; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
| using System.Windows.Forms; | ||||
| using VEPROMS.CSLA.Library; | ||||
|  | ||||
| namespace VEPROMS | ||||
| { | ||||
|     // C2025-027 Annotation Type Filtering | ||||
|     public partial class dlgAnnotationsSelect : Form | ||||
|     { | ||||
|         public dlgAnnotationsSelect() | ||||
|         { | ||||
|             InitializeComponent(); | ||||
|         } | ||||
|  | ||||
|         public dlgAnnotationsSelect(string userid) | ||||
|         { | ||||
|             InitializeComponent(); | ||||
|             UserID = userid; | ||||
|         } | ||||
|  | ||||
|         private int _MyItemID; | ||||
|         public int MyItemID | ||||
|         { | ||||
|             get { return _MyItemID; } | ||||
|             set { _MyItemID = value; } | ||||
|         } | ||||
|  | ||||
|         private string _UserID; | ||||
|         public string UserID | ||||
|         { | ||||
|             get { return _UserID; } | ||||
|             set { _UserID = value; } | ||||
|         } | ||||
|  | ||||
|         private void btnSelect_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             MoveSelectedItems(lstUnselected, lstSelected); | ||||
|         } | ||||
|  | ||||
|         // Move selected items to lstUnselected. | ||||
|         private void btnDeselect_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             MoveSelectedItems(lstSelected, lstUnselected); | ||||
|         } | ||||
|  | ||||
|         // Move selected items from one ListBox to another. | ||||
|         private void MoveSelectedItems(ListBox lstFrom, ListBox lstTo) | ||||
|         { | ||||
|             while (lstFrom.SelectedItems.Count > 0) | ||||
|             { | ||||
|                 lstSelected.DisplayMember = "NameStr"; | ||||
|                 lstSelected.ValueMember = "TypeID"; | ||||
|  | ||||
|                 AnnotataionItem item = (AnnotataionItem)lstFrom.SelectedItems[0]; | ||||
|                 lstTo.Items.Add(new AnnotataionItem(item.NameStr, item.TypeID)); | ||||
|                 lstFrom.Items.Remove(item); | ||||
|             } | ||||
|             SetButtonsEditable(); | ||||
|             btnUpdate.Enabled = true; | ||||
|         } | ||||
|  | ||||
|         // Move all items to lstSelected. | ||||
|         private void btnSelectAll_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             MoveAllItems(lstUnselected, lstSelected); | ||||
|             btnUpdate.Enabled = true; | ||||
|         } | ||||
|  | ||||
|         // Move all items to lstUnselected. | ||||
|         private void btnDeselectAll_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             MoveAllItems(lstSelected, lstUnselected); | ||||
|             btnUpdate.Enabled = true; | ||||
|         } | ||||
|  | ||||
|         // Move all items from one ListBox to another. | ||||
|         private void MoveAllItems(ListBox lstFrom, ListBox lstTo) | ||||
|         { | ||||
|             lstTo.Items.AddRange(lstFrom.Items); | ||||
|             lstFrom.Items.Clear(); | ||||
|             SetButtonsEditable(); | ||||
|             btnUpdate.Enabled = true; | ||||
|         } | ||||
|  | ||||
|         // Enable and disable buttons. | ||||
|         private void lst_SelectedIndexChanged(object sender, EventArgs e) | ||||
|         { | ||||
|             SetButtonsEditable(); | ||||
|         } | ||||
|         // Save selected list to DB. | ||||
|         private void btnUpdate_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             saveChanges(); | ||||
|         } | ||||
|         public class AnnotataionItem | ||||
|         { | ||||
|             private string _NameStr; | ||||
|             private int _TypeID; | ||||
|  | ||||
|             public AnnotataionItem(string NameStr, int TypeID) | ||||
|             { | ||||
|                 this._NameStr = NameStr; | ||||
|                 this._TypeID = TypeID; | ||||
|             } | ||||
|             public string NameStr | ||||
|             { | ||||
|                 get | ||||
|                 { | ||||
|                     return _NameStr; | ||||
|                 } | ||||
|             } | ||||
|             public int TypeID | ||||
|             { | ||||
|                 get | ||||
|                 { | ||||
|                     return _TypeID; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // Enable and disable buttons. | ||||
|         private void SetButtonsEditable() | ||||
|         { | ||||
|             btnSelect.Enabled = (lstUnselected.SelectedItems.Count > 0); | ||||
|             btnSelectAll.Enabled = (lstUnselected.Items.Count > 0); | ||||
|             btnDeselect.Enabled = (lstSelected.SelectedItems.Count > 0); | ||||
|             btnDeselectAll.Enabled = (lstSelected.Items.Count > 0); | ||||
|         } | ||||
|  | ||||
|         private void DlgAnnotationsSelect_Load(object sender, EventArgs e) | ||||
|         { | ||||
|             lstUnselected.DisplayMember = "NameStr"; | ||||
|             lstUnselected.ValueMember = "TypeID"; | ||||
|             SetButtonsEditable(); | ||||
|             DataTable AnnoType = AnnotationstypeSelections.GetAnnoTypes(UserID); | ||||
|             foreach (DataRow dr in AnnoType.Rows) | ||||
|             { | ||||
|                 lstUnselected.Items.Add(new AnnotataionItem(dr["Name"].ToString(), (int)dr["TypeID"])); | ||||
|             } | ||||
|  | ||||
|             lstSelected.DisplayMember = "NameStr"; | ||||
|             lstSelected.ValueMember = "TypeID"; | ||||
|             DataTable lstSelectedTbl = VEPROMS.CSLA.Library.AnnotationstypeSelections.Retrieve(UserID); | ||||
|  | ||||
|             foreach (DataRow lstSelectedRow in lstSelectedTbl.Rows) | ||||
|             { | ||||
|                 lstSelected.Items.Add(new AnnotataionItem(lstSelectedRow["Name"].ToString(), (int)lstSelectedRow["TypeID"])); | ||||
|             } | ||||
|             btnUpdate.Enabled = false; | ||||
|         } | ||||
|  | ||||
|         private void btnCancel_Click_1(object sender, EventArgs e) | ||||
|         { | ||||
|             if (btnUpdate.Enabled == true) | ||||
|             { | ||||
|                 string message = "Changes have not yet been saved.  Do you want to save the changes prior to closing?"; | ||||
|                 string title = "Save Annotation Selections"; | ||||
|                 MessageBoxButtons buttons = MessageBoxButtons.YesNo; | ||||
|                 DialogResult result = MessageBox.Show(message, title, buttons); | ||||
|                 if (result == DialogResult.Yes) | ||||
|                 { | ||||
|                     saveChanges(); | ||||
|                     this.Close(); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     this.Close(); | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 this.Close(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private DataTable coverToTable() | ||||
|         { | ||||
|             DataTable dt = new DataTable(); | ||||
|             dt.Columns.Add("TypeID", typeof(Int32)); | ||||
|  | ||||
|  | ||||
|             foreach (AnnotataionItem item in lstSelected.Items.OfType<AnnotataionItem>()) | ||||
|             { | ||||
|                 dt.Rows.Add(item.TypeID); | ||||
|             } | ||||
|             return dt; | ||||
|         } | ||||
|         private void saveChanges() | ||||
|         { | ||||
|             DataTable dt2 = coverToTable(); | ||||
|             VEPROMS.CSLA.Library.AnnotationstypeSelections.Update(dt2, UserID); | ||||
|             btnUpdate.Enabled = false; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -112,9 +112,9 @@ | ||||
|     <value>2.0</value> | ||||
|   </resheader> | ||||
|   <resheader name="reader"> | ||||
|     <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|     <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|   </resheader> | ||||
|   <resheader name="writer"> | ||||
|     <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|     <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|   </resheader> | ||||
| </root> | ||||
| @@ -66,6 +66,12 @@ namespace VEPROMS | ||||
| 			set { _prtSectID = value; } | ||||
| 		} | ||||
|  | ||||
| 		private bool _OverwritePDF; | ||||
| 		public bool OverwritePDF | ||||
| 		{ | ||||
| 			get { return cbxOverwritePDF2.Checked; } | ||||
| 			set { cbxOverwritePDF2.Checked = value; } | ||||
| 		} | ||||
|  | ||||
| 		// C2018-033 Used to turn off using the date/time PDF file prefix and suffix when doing batch file autmatic baseline print testing (frmVEPROMS.cs RunAutomatic()) | ||||
| 		//           This is needed so the the automatic baselines can compare results from different runs of PROMS | ||||
| @@ -393,6 +399,7 @@ namespace VEPROMS | ||||
| 		{ | ||||
| 			SetupForProcedure(); | ||||
| 			_MyTimer = new Timer(); | ||||
| 			_MyTimer.Tick -= new EventHandler(_MyTimer_Tick); | ||||
| 			_MyTimer.Tick += new EventHandler(_MyTimer_Tick); | ||||
| 			_MyTimer.Interval = 100; | ||||
| 			_MyTimer.Enabled = true; | ||||
| @@ -418,7 +425,12 @@ namespace VEPROMS | ||||
| 			//txbPDFLocation.Text = _PDFPath; | ||||
| 			BuildPDFFileName(); | ||||
| 			ProcedureConfig pc = _MyProcedure.MyConfig as ProcedureConfig; | ||||
| 			if(SelectedSlave > 0) pc.SelectedSlave = SelectedSlave; | ||||
| 			// C2025-033 set which Child procedure is being printed used for PageStyle items | ||||
| 			VlnSvgPageHelper.PrintingChild = SelectedSlave; | ||||
| 			if (SelectedSlave > 0) | ||||
| 			{ | ||||
| 				pc.SelectedSlave = SelectedSlave; | ||||
| 			} | ||||
| 			if (pc != null) | ||||
| 			{ | ||||
| 				//C2021-062 use the save rev number for all procedures if set, or just use the rev number in the current procedure config | ||||
| @@ -1087,7 +1099,9 @@ namespace VEPROMS | ||||
| 					(int)changeBarData.FixedChangeColumn : | ||||
| 					System.Convert.ToInt32(changeBarData.DefaultCBLoc.Split(" ,".ToCharArray())[System.Convert.ToInt32(cbd.MyChangeBarLoc)]); | ||||
| 				//cbd.MyChangeBarColumn = (int)changeBarData.FixedChangeColumn; | ||||
| 				if (cbd.MyChangeBarText == PrintChangeBarText.UserDef) | ||||
| 				if (cbd.MyChangeBarText == PrintChangeBarText.UserDef && !string.IsNullOrEmpty(ppTxbxChangeBarUserMsgOne.Text)) | ||||
| 					cbd.MyChangeBarMessage = ppTxbxChangeBarUserMsgOne.Text + @"\n" + ppTxbxChangeBarUserMsgTwo.Text; | ||||
| 				else if (cbd.MyChangeBarText == PrintChangeBarText.UserDef) | ||||
| 					cbd.MyChangeBarMessage = _DocVersionConfig.Print_UserCBMess1 + @"\n" + _DocVersionConfig.Print_UserCBMess2; | ||||
|  | ||||
| 			} | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
|  | ||||
|  | ||||
| Set NoCount On; | ||||
|  | ||||
| If (db_name() in('master','model','msdn','tempdb')) | ||||
| @@ -13637,8 +13635,8 @@ WITH EXECUTE AS OWNER | ||||
| AS | ||||
| BEGIN TRY -- Try Block | ||||
| 	BEGIN TRANSACTION | ||||
| 	Update Contents set Text = Replace(Replace(Replace(Replace(Replace(Replace(Replace(Text,'\emdash','\u8209?'),'\endash','\u8209?'),'\u8213?','\u8209?'),'\u8212?','\u8209?'),'\u8211?','\u8209?'),'\u8210?','\u8209?'),'\u8208?','\u8209?') | ||||
| 	where Text Like '%\u8208?%' or Text Like '%\u8210?%' or Text Like '%\u8211?%' or Text Like '%\u8212?%' or Text Like '%\u8213?%' or Text Like '%\endash%' or Text Like '%\emdash%' | ||||
|     Update Contents set Text = Replace(Replace(Replace(Replace(Replace(Replace(Replace(Replace(Text,'\emdash','\u8209?'),'\endash','\u8209?'),'\u8213?','\u8209?'),'\u8212?','\u8209?'),'\u8211?','\u8209?'),'\u8210?','\u8209?'),'\u8208?','\u8209?'),NCHAR(8209),'\u8209?') | ||||
|     where Text Like '%\u8208?%' or Text Like '%\u8210?%' or Text Like '%\u8211?%' or Text Like '%\u8212?%' or Text Like '%\u8213?%' or Text Like '%\endash%' or Text Like '%\emdash%'or Text Like '%' + NCHAR(8209) + '%'	IF( @@TRANCOUNT > 0 ) COMMIT | ||||
| 	IF( @@TRANCOUNT > 0 ) COMMIT | ||||
| END TRY | ||||
| BEGIN CATCH -- Catch Block | ||||
| @@ -14767,40 +14765,11 @@ IF (@@Error = 0) PRINT 'StoredProcedure [getJustFormat] Succeeded' | ||||
| ELSE PRINT 'StoredProcedure [getJustFormat] Error on Creation' | ||||
| go | ||||
|  | ||||
|  | ||||
| -- Remove getFormatNoUCF from DB (UCF) no longer used. | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getFormatNoUCF]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getFormatNoUCF]; | ||||
| GO | ||||
| CREATE PROCEDURE [dbo].[getFormatNoUCF] | ||||
| ( | ||||
| 	@FormatID int | ||||
| ) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
| 	SELECT | ||||
| 		[FormatID], | ||||
| 		[ParentID], | ||||
| 		[Name], | ||||
| 		[Description], | ||||
| 		[Data], | ||||
| 		[Config], | ||||
| 		[GenMac], | ||||
| 		[DTS], | ||||
| 		[UserID], | ||||
| 		[LastChanged], | ||||
| 		(SELECT COUNT(*) FROM [Contents] WHERE [Contents].[FormatID]=[Formats].[FormatID]) [ContentCount], | ||||
| 		(SELECT COUNT(*) FROM [DocVersions] WHERE [DocVersions].[FormatID]=[Formats].[FormatID]) [DocVersionCount], | ||||
| 		(SELECT COUNT(*) FROM [Folders] WHERE [Folders].[FormatID]=[Formats].[FormatID]) [FolderCount], | ||||
| 		(SELECT COUNT(*) FROM [Formats] [Children] WHERE [Children].[ParentID]=[Formats].[FormatID]) [ChildCount] | ||||
| 	FROM [Formats] | ||||
| 	WHERE [FormatID]=@FormatID | ||||
|  | ||||
| 	RETURN | ||||
| GO | ||||
| -- Display the status of Proc creation | ||||
| IF (@@Error = 0) PRINT 'StoredProcedure [getFormatNoUCF] Succeeded' | ||||
| ELSE PRINT 'StoredProcedure [getFormatNoUCF] Error on Creation' | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vefn_GetItemsMatchingFormatItems]') AND OBJECTPROPERTY(id,N'IsTableFunction') = 1) | ||||
| 	DROP FUNCTION [vefn_GetItemsMatchingFormatItems]; | ||||
| @@ -14983,100 +14952,10 @@ IF (@@Error = 0) PRINT 'StoredProcedure [vefn_GetFolderMatchingFormatItems] Succ | ||||
| ELSE PRINT 'StoredProcedure [vefn_GetFolderMatchingFormatItems] Error on Creation' | ||||
| go | ||||
|  | ||||
| -- Remove vesp_ClearOverrideFormatsByFolder (UCF) from DB.  No longer used. | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_ClearOverrideFormatsByFolder]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_ClearOverrideFormatsByFolder]; | ||||
| GO | ||||
| CREATE PROCEDURE [dbo].[vesp_ClearOverrideFormatsByFolder](@FolderID int, @FormatID int, @NewFormatID int) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
| BEGIN | ||||
| DECLARE @ClearedContents TABLE | ||||
| ( | ||||
| 	ContentID int | ||||
| ) | ||||
| DECLARE @ClearedFolders TABLE | ||||
| ( | ||||
| 	FolderID int | ||||
| ) | ||||
| DECLARE @ClearedDocVersions TABLE | ||||
| ( | ||||
| 	VersionID int | ||||
| ) | ||||
|  | ||||
| insert into @ClearedContents | ||||
| select cc.ContentID from (select contentid from contents where formatid is not null) cc | ||||
| join vefn_GetFolderMatchingFormatItems(@FolderID, @FormatID, @NewFormatID) vi on vi.ContentID = cc.ContentID | ||||
|  | ||||
| -- update any folders & docversions that are using that formatid to clear them, i.e. so they inherit.  To do this | ||||
| -- get lists of folders & docversions that have non-null format ids that should be null. | ||||
|  | ||||
| BEGIN | ||||
| With Folderz([FolderID], [FormatID]) as | ||||
| 		( | ||||
| 			select FF.FolderID, FF.FormatID from Folders FF | ||||
| 			Where FF.FolderID = @FolderID | ||||
| 			UNION ALL | ||||
| 			select FF.FolderID, FF.FormatID from Folders FF | ||||
| 			Join Folderz ZZ on FF.ParentID = ZZ.FolderID | ||||
| 			Where FF.FolderID != @FolderID and (FF.FormatID is null or FF.FormatID = @FormatID or FF.FormatID = @NewFormatID) | ||||
| 		) | ||||
| 		insert into @ClearedFolders | ||||
| 		select ZZ.FolderID  | ||||
| 		from Folderz ZZ | ||||
| 		where ZZ.FormatID is not null and ZZ.FolderID != @FolderID  -- don't include folder passed in, only do children (folder is done in code) | ||||
| 		OPTION (MAXRECURSION 10000) | ||||
| END | ||||
|  | ||||
| BEGIN | ||||
| With Folderz([FolderID]) as | ||||
| 		( | ||||
| 			select FF.FolderID from Folders FF | ||||
| 			Where FF.FolderID = @FolderID | ||||
| 			UNION ALL | ||||
| 			select FF.FolderID from Folders FF | ||||
| 			Join Folderz ZZ on FF.ParentID = ZZ.FolderID | ||||
| 			Where FF.FolderID != @FolderID and (FF.FormatID is null or FF.FormatID = @FormatID or FF.FormatID = @NewFormatID) | ||||
| 		) | ||||
| 		insert into @ClearedDocVersions | ||||
| 		select DV.VersionID | ||||
| 			from Folderz ZZ | ||||
| 			Left Join DocVersions DV ON DV.FolderID = ZZ.FolderID | ||||
| 			where VersionID is not null and DV.FormatID is not null and (DV.FormatID = @FormatID or DV.FormatID = @NewFormatID) | ||||
| 		OPTION (MAXRECURSION 10000) | ||||
| END | ||||
| update Folders set formatid = null where FolderID in (select FolderID from @ClearedFolders) | ||||
| update DocVersions set formatid = null where VersionID in (select VersionID from @ClearedDocVersions) | ||||
|  | ||||
| -- now update all of the contents that were found | ||||
| update contents set formatid = null where contentID in (select contentid from @ClearedContents) | ||||
|  | ||||
| select [ContentID], | ||||
| 		[Number], | ||||
| 		[Text], | ||||
| 		[Type], | ||||
| 		[FormatID], | ||||
| 		[Config], | ||||
| 		[DTS], | ||||
| 		[UserID], | ||||
| 		[LastChanged], | ||||
| 		(SELECT COUNT(*) FROM [Details] WHERE [Details].[ContentID]=[Contents].[ContentID]) [DetailCount], | ||||
| 		(SELECT COUNT(*) FROM [Entries] WHERE [Entries].[ContentID]=[Contents].[ContentID]) [EntryCount], | ||||
| 		(SELECT COUNT(*) FROM [Grids] WHERE [Grids].[ContentID]=[Contents].[ContentID]) [GridCount], | ||||
| 		(SELECT COUNT(*) FROM [Images] WHERE [Images].[ContentID]=[Contents].[ContentID]) [ImageCount], | ||||
| 		(SELECT COUNT(*) FROM [Items] WHERE [Items].[ContentID]=[Contents].[ContentID]) [ItemCount], | ||||
| 		(SELECT COUNT(*) FROM [Parts] WHERE [Parts].[ContentID]=[Contents].[ContentID]) [PartCount], | ||||
| 		(SELECT COUNT(*) FROM [RoUsages] WHERE [RoUsages].[ContentID]=[Contents].[ContentID]) [RoUsageCount], | ||||
| 		(SELECT COUNT(*) FROM [Transitions] WHERE [Transitions].[FromID]=[Contents].[ContentID]) [TransitionCount], | ||||
| 		(SELECT COUNT(*) FROM [ZContents] WHERE [ZContents].[ContentID]=[Contents].[ContentID]) [ZContentCount] | ||||
| 	FROM contents where contentid in (select ContentID from @ClearedContents) | ||||
| RETURN | ||||
| END | ||||
|  | ||||
| GO | ||||
| -- Display the status of Proc creation | ||||
| IF (@@Error = 0) PRINT 'Procedure Creation: vesp_ClearOverrideFormatsByFolder Succeeded' | ||||
| ELSE PRINT 'Procedure Creation: vesp_ClearOverrideFormatsByFolder Error on Creation' | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_ClearOverrideFormatsByDocVersion]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_ClearOverrideFormatsByDocVersion]; | ||||
| @@ -17322,7 +17201,7 @@ GO | ||||
| 			[RofstID] [int] NOT NULL, | ||||
| 			[roid] [varchar](50) NOT NULL, | ||||
| 			[value] [varchar](max) NOT NULL, | ||||
| 			[AccPageID] [varchar](max) NULL, | ||||
| 			[AccPageID] [varchar](100) NULL, | ||||
| 		 CONSTRAINT [PK_RofstDefaultValue] PRIMARY KEY CLUSTERED  | ||||
| 		( | ||||
| 			[RofstID] ASC, | ||||
| @@ -18920,8 +18799,9 @@ GO | ||||
| 	*****************************************************************************/ | ||||
| 	/* | ||||
| 		========================================================================================================== | ||||
| 		Author:			Jake Ropar | ||||
| 		Author:			Jake Ropar / Matthew Schill | ||||
| 		Create Date:	06/23/2022 | ||||
| 		Modify Date:    08/18/2025 | ||||
| 		Description:	Finalizes Rofst Header Record / Updates LoadedDate if Success | ||||
| 	========================================================================================================== | ||||
| 	*/ | ||||
| @@ -18938,13 +18818,18 @@ GO | ||||
| 		Set LoadedDate = GetDate() | ||||
| 		Where RofstID = @RofstID; | ||||
|  | ||||
|  | ||||
| 		--always rebuild the rofst child and default indexes | ||||
| 		DBCC DBREINDEX ('RofstChild'); | ||||
| 		DBCC DBREINDEX ('RofstDefaultValue');	 | ||||
|  | ||||
| 		-- Rebuild/Reorganize Indexes | ||||
| 		Exec [dbo].[vesp_UtilityCheckIndexes] 20.0, 5.0, 0, 1; | ||||
|  | ||||
|  | ||||
| 		Return; | ||||
| 	End | ||||
| 	Go | ||||
| 	GO | ||||
|  | ||||
| 	IF (@@Error = 0) PRINT 'Procedure Creation: [vesp_RofstHeaderFinalizeLoad] Succeeded' | ||||
| 	ELSE PRINT 'Procedure Creation: [vesp_RofstHeaderFinalizeLoad] Error on Creation' | ||||
| @@ -20703,11 +20588,6 @@ GO | ||||
| 	GO | ||||
|  | ||||
|  | ||||
|  | ||||
| 	-- Delete All Existing Rofst Table Data | ||||
| 	Delete From RofstHeader; | ||||
|  | ||||
|  | ||||
| /* | ||||
| ========================================================================================================== | ||||
|  End: B2022-083: Support Conditional RO Values (v2.1) | ||||
| @@ -23811,6 +23691,747 @@ IF (@@Error = 0) PRINT 'Running vesp_UpdateUserSettings Succeeded' | ||||
| ELSE PRINT 'Running vesp_UpdateUserSettings Failed to Execute' | ||||
| GO | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 5/19/2025 | ||||
| -- Description:	Allow option to not prompt user with MS Word messages | ||||
| --   when generating Summaries | ||||
| -- ============================================= | ||||
| --- MSWordSummaryPrompt = ahouls user be prompted with message? | ||||
| --    default = yes (true) | ||||
| IF NOT EXISTS(SELECT * | ||||
|           FROM   INFORMATION_SCHEMA.COLUMNS | ||||
|           WHERE  TABLE_NAME = 'Users' | ||||
|                  AND COLUMN_NAME = 'MSWordSummaryPrompt')  | ||||
| ALTER TABLE Users ADD MSWordSummaryPrompt bit NOT NULL DEFAULT(1); | ||||
| go | ||||
| -- Display the status | ||||
| IF (@@Error = 0) PRINT 'Altered table [Users] Succeeded for MSWordSummaryPrompt' | ||||
| ELSE PRINT 'Altered table [Users] Error on Alter for MSWordSummaryPrompt' | ||||
| go | ||||
|  | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_UpdateUserSettingMSWordSummaryPrompt]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_UpdateUserSettingMSWordSummaryPrompt]; | ||||
| GO | ||||
|  | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 5/19/2025 | ||||
| -- Description:	Allow option to not prompt user with MS Word messages | ||||
| --   when generating Summaries | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[vesp_UpdateUserSettingMSWordSummaryPrompt] | ||||
|  | ||||
| ( | ||||
| 	@UID varchar(100), | ||||
| 	@Prompt bit = null | ||||
| ) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
|    UPDATE Users SET  | ||||
|      MSWordSummaryPrompt = ISNULL(@Prompt, MSWordSummaryPrompt) | ||||
| 	WHERE UserID =@UID | ||||
|  | ||||
| 	RETURN | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Running vesp_UpdateUserSettingMSWordSummaryPrompt Succeeded' | ||||
| ELSE PRINT 'Running vesp_UpdateUserSettingMSWordSummaryPrompt Failed to Execute' | ||||
| GO | ||||
|  | ||||
| ---  begin changes for: | ||||
| ---C2025-023 - Electronic Procedures - Modifications to PROMS | ||||
| --- The following IsEPAnnotationType column was added for EP Annotations. | ||||
| --- IsEPAnnotationType = Is for EPs | ||||
| IF NOT EXISTS(SELECT * | ||||
|           FROM   INFORMATION_SCHEMA.COLUMNS | ||||
|           WHERE  TABLE_NAME = 'AnnotationTypes' | ||||
|                  AND COLUMN_NAME = 'IsEPAnnotationType')  | ||||
| ALTER TABLE AnnotationTypes ADD IsEPAnnotationType bit NOT NULL DEFAULT(0); | ||||
| go | ||||
| -- Display the status | ||||
| IF (@@Error = 0) PRINT 'Altered table [AnnotationTypes] Succeeded for IsEPAnnotationType' | ||||
| ELSE PRINT 'Altered table [AnnotationTypes] Error on Alter for IsEPAnnotationType' | ||||
| go | ||||
|  | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getAnnotationType]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getAnnotationType]; | ||||
| GO | ||||
|  | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 3/21/2025 | ||||
| -- Description:	Add EP to AnnotationTypes | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[getAnnotationType] | ||||
| ( | ||||
| 	@TypeID int | ||||
| ) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
| 	SELECT | ||||
| 		[TypeID], | ||||
| 		[Name], | ||||
| 		[Config], | ||||
| 		[DTS], | ||||
| 		[UserID], | ||||
| 		[LastChanged], | ||||
| 		(SELECT COUNT(*) FROM [Annotations] WHERE [Annotations].[TypeID]=[AnnotationTypes].[TypeID]) [AnnotationCount], | ||||
| 		[IsEPAnnotationType] | ||||
| 	FROM [AnnotationTypes] | ||||
| 	WHERE [TypeID]=@TypeID | ||||
|  | ||||
| 	SELECT | ||||
| 		[Annotations].[AnnotationID], | ||||
| 		[Annotations].[ItemID], | ||||
| 		[Annotations].[TypeID], | ||||
| 		[Annotations].[RtfText], | ||||
| 		[Annotations].[SearchText], | ||||
| 		[Annotations].[Config], | ||||
| 		[Annotations].[DTS], | ||||
| 		[Annotations].[UserID], | ||||
| 		[Annotations].[LastChanged], | ||||
| 		[Items].[PreviousID] [Item_PreviousID], | ||||
| 		[Items].[ContentID] [Item_ContentID], | ||||
| 		[Items].[DTS] [Item_DTS], | ||||
| 		[Items].[UserID] [Item_UserID] | ||||
| 	FROM [Annotations] | ||||
| 		JOIN [Items]  ON | ||||
| 			[Items].[ItemID]=[Annotations].[ItemID] | ||||
| 	WHERE | ||||
| 		[Annotations].[TypeID]=@TypeID | ||||
|  | ||||
| 	RETURN | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Running getAnnotationType Succeeded' | ||||
| ELSE PRINT 'Running getAnnotationType Failed to Execute' | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getAnnotationTypeByName]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getAnnotationTypeByName]; | ||||
| GO | ||||
|  | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 3/21/2025 | ||||
| -- Description:	Add EP to AnnotationTypes | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[getAnnotationTypeByName] | ||||
| ( | ||||
| 	@Name nvarchar(100) | ||||
| ) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
| 	SELECT | ||||
| 		[TypeID], | ||||
| 		[Name], | ||||
| 		[Config], | ||||
| 		[DTS], | ||||
| 		[UserID], | ||||
| 		[LastChanged], | ||||
| 		(SELECT COUNT(*) FROM [Annotations] WHERE [Annotations].[TypeID]=[AnnotationTypes].[TypeID]) [AnnotationCount], | ||||
| 		[IsEPAnnotationType] | ||||
| 	FROM [AnnotationTypes] | ||||
| 	WHERE [Name]=@Name | ||||
| 	RETURN | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Running getAnnotationTypeByName Succeeded' | ||||
| ELSE PRINT 'Running getAnnotationTypeByName Failed to Execute' | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getAnnotationTypes]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getAnnotationTypes]; | ||||
| GO | ||||
|  | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 3/21/2025 | ||||
| -- Description:	Add EP to AnnotationTypes | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[getAnnotationTypes] | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
| 	SELECT | ||||
| 		[TypeID], | ||||
| 		[Name], | ||||
| 		[Config], | ||||
| 		[DTS], | ||||
| 		[UserID], | ||||
| 		[LastChanged], | ||||
| 		(SELECT COUNT(*) FROM [Annotations] WHERE [Annotations].[TypeID]=[AnnotationTypes].[TypeID]) [AnnotationCount], | ||||
| 		[IsEPAnnotationType] | ||||
| 	FROM [AnnotationTypes] | ||||
| 	RETURN | ||||
|  | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Running getAnnotationTypes Succeeded' | ||||
| ELSE PRINT 'Running getAnnotationTypes Failed to Execute' | ||||
| GO | ||||
|  | ||||
| IF Not Exists(SELECT * FROM sys.objects Where name = 'EPFormats' AND type in (N'U')) | ||||
| Begin -- Rofst Tables | ||||
|  | ||||
| 	SET ANSI_NULLS ON | ||||
| 	SET QUOTED_IDENTIFIER ON | ||||
|  | ||||
| 	CREATE TABLE [dbo].[EPFormats]( | ||||
| 		[FormatID] [int] IDENTITY(1,1) NOT NULL, | ||||
| 		[Name] [nvarchar](100) NOT NULL, | ||||
| 		[Data] [xml] NULL, | ||||
| 		[Created] [datetime] NOT NULL DEFAULT (getdate()), | ||||
| 		[CreatedBy] [nvarchar](100) NOT NULL DEFAULT (upper(suser_sname())), | ||||
| 		[Updated] [datetime] NOT NULL DEFAULT (getdate()), | ||||
| 		[UpdatedBy] [nvarchar](100) NOT NULL DEFAULT (upper(suser_sname())) | ||||
| 	 CONSTRAINT [PK_EPFormats] PRIMARY KEY CLUSTERED  | ||||
| 	( | ||||
| 		[FormatID] ASC | ||||
| 	)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] | ||||
| 	) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] | ||||
|  | ||||
| 	IF (@@Error = 0) PRINT 'Table Creation: [EPFormats] Succeeded' | ||||
| 	ELSE PRINT 'Table Creation: [EPFormats] Error on Creation' | ||||
|  | ||||
| End | ||||
| Go | ||||
|  | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_UpdateEPFormat]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_UpdateEPFormat]; | ||||
| GO | ||||
|  | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 3/26/2025 | ||||
| -- Description:	Update / Insert EP Format | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[vesp_UpdateEPFormat] | ||||
| ( | ||||
| 	@name nvarchar(100), | ||||
| 	@data nvarchar(max), | ||||
| 	@userID nvarchar(15) | ||||
| ) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
|  | ||||
| IF EXISTS(Select 1 FROM EPFormats where Name = @name ) | ||||
|  BEGIN | ||||
| 	UpDate EPFormats | ||||
| 	 SET Name = @name, | ||||
| 		 Data = @data, | ||||
| 		 Updated = getdate(), | ||||
| 		 UpdatedBy = upper(@userID) | ||||
| 	 WHERE Name = @name | ||||
|  END | ||||
| ELSE | ||||
|  BEGIN | ||||
|    INSERT INTO EPFormats (Name, Data, CreatedBy, UpdatedBy) | ||||
|     values (@name, @data, 'Migration', 'Migration') | ||||
|  | ||||
|  END | ||||
|  | ||||
| GO | ||||
|  | ||||
| -- C2025-027 Annotation Type Filtering | ||||
| /****** Object:  Table [dbo].[AnnotationTypeSelections]    Script Date: 7/10/2025 2:38:23 PM ******/ | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
|  | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Paul Larsen | ||||
| -- Create date: 07/10/2025 | ||||
| -- Description:	Store user Annotation selections for annotation filter. | ||||
| -- ============================================= | ||||
| IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[AnnotationTypeSelections]') AND type in (N'U')) | ||||
| BEGIN | ||||
|  | ||||
| 	CREATE TABLE [dbo].[AnnotationTypeSelections]( | ||||
| 		[ASTypeID] [int] IDENTITY(1,1) NOT NULL, | ||||
| 		[TypeID] [int] NULL, | ||||
| 		[UserID] [varchar](50) NULL, | ||||
| 		[LastChanged] [datetime] NULL, | ||||
| 		CONSTRAINT [PK_AnnotationTypeSelections] PRIMARY KEY CLUSTERED  | ||||
| 		([ASTypeID] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] | ||||
| 			) ON [PRIMARY] | ||||
| END | ||||
|  | ||||
| IF OBJECT_ID('DF_AnnotationTypeSelections_LastChanged', 'D') IS NULL | ||||
| 	ALTER TABLE AnnotationTypeSelections ADD CONSTRAINT [DF_AnnotationTypeSelections_LastChanged]  DEFAULT (getdate()) for [LastChanged]; | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT *  FROM sys.indexes  WHERE name='idx_AnnotationTypeSelections_UserIDTypeID'  | ||||
| AND object_id = OBJECT_ID('[dbo].[AnnotationTypeSelections]')) | ||||
| begin | ||||
| DROP INDEX [idx_AnnotationTypeSelections_UserIDTypeID] ON [dbo].[AnnotationTypeSelections]; | ||||
| end | ||||
|  | ||||
| CREATE UNIQUE INDEX [idx_AnnotationTypeSelections_UserIDTypeID] ON [dbo].[AnnotationTypeSelections] | ||||
| ( | ||||
| [UserID] ASC, | ||||
| [TypeID] ASC | ||||
| ) | ||||
| INCLUDE (ASTypeID) | ||||
| WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] | ||||
| GO | ||||
|  | ||||
| -- C2025-027 Annotation Type Filtering | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getAnnotationSelectListTypes]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getAnnotationSelectListTypes]; | ||||
| GO | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Paul Larsen | ||||
| -- Create date: 7/10/2025 | ||||
| -- Description:	Retrieve Annotation Types not added to Annotation type filtering by user. | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[getAnnotationSelectListTypes] | ||||
| ( | ||||
| 	@UserID varchar(50) | ||||
| ) | ||||
| WITH EXECUTE AS OWNER | ||||
| AS | ||||
| 	SELECT | ||||
| 		AT.[TypeID], | ||||
| 		AT.[Name], | ||||
| 		AT.[Config], | ||||
| 		AT.[DTS], | ||||
| 		AT.[UserID], | ||||
| 		AT.[LastChanged], | ||||
| 		(SELECT COUNT(*) FROM [Annotations] WHERE [Annotations].[TypeID]= AT.[TypeID]) [AnnotationCount], | ||||
| 		AT.[IsEPAnnotationType] | ||||
| 	FROM [AnnotationTypes] AT | ||||
| 	LEFT OUTER JOIN AnnotationTypeSelections ATS  | ||||
| 	ON ATS.TypeID = AT.TypeID AND ATS.UserID = @UserID	     | ||||
| 	WHERE ATS.ASTypeID IS NULL | ||||
| GO | ||||
|  | ||||
| -- C2025-027 Annotation Type Filtering | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getAnnotationstypeSelections]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getAnnotationstypeSelections]; | ||||
| GO | ||||
|  | ||||
| SET ANSI_NULLS ON | ||||
| GO | ||||
| SET QUOTED_IDENTIFIER ON | ||||
| GO | ||||
| -- ============================================= | ||||
| -- Author:		Paul Larsen | ||||
| -- Create date: 07/10/2025 | ||||
| -- Description:	Retrieve Current Annotation Types  | ||||
| -- ============================================= | ||||
|  | ||||
| CREATE PROC [dbo].[getAnnotationstypeSelections] | ||||
| ( | ||||
| 	@UsrID varchar(50) | ||||
| ) | ||||
| AS | ||||
| 	BEGIN | ||||
| 		SELECT [ASTypeID] | ||||
| 			  ,ATS.[TypeID] | ||||
| 			  ,ATS.[UserID] | ||||
| 			  ,AT.[Name] | ||||
| 			  ,AT.[Config] | ||||
| 			  ,ATS.[LastChanged] | ||||
| 			  ,AT.[UserID] | ||||
| 			  ,AT.[IsEPAnnotationType] | ||||
| 		FROM [dbo].[AnnotationTypeSelections] ATS | ||||
| 		INNER JOIN AnnotationTypes AT ON AT.TypeID = ATS.TypeID | ||||
| 		WHERE ATS.UserID = @UsrID | ||||
| 	END | ||||
|  | ||||
| GO | ||||
|  | ||||
| -- C2025-027 Annotation Type Filtering | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getAnnotationstypeFiltered]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getAnnotationstypeFiltered]; | ||||
| GO | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Paul Larsen | ||||
| -- Create date: 07/10/2025 | ||||
| -- Description:	Retrieve Current Annotation Types  | ||||
| -- ============================================= | ||||
|  | ||||
| CREATE PROC [dbo].[getAnnotationstypeFiltered] | ||||
| ( | ||||
| 	@UsrID varchar(50) | ||||
| ) | ||||
| AS | ||||
| BEGIN | ||||
| 	IF((SELECT count(TypeID) FROM AnnotationTypeSelections WHERE UserID = @UsrID) > 0) | ||||
| 	BEGIN | ||||
| 		SELECT [ASTypeID] | ||||
| 			  ,ATS.[TypeID] | ||||
| 			  ,ATS.[UserID] | ||||
| 			  ,AT.[Name] | ||||
| 			  ,AT.[Config] | ||||
| 			  ,ATS.[LastChanged] | ||||
| 			  ,AT.[UserID] | ||||
| 			  ,AT.[IsEPAnnotationType] | ||||
| 		FROM [dbo].[AnnotationTypeSelections] ATS | ||||
| 		INNER JOIN AnnotationTypes AT ON AT.TypeID = ATS.TypeID | ||||
| 		WHERE ATS.UserID = @UsrID | ||||
| 	END | ||||
| 	ELSE | ||||
| 	BEGIN | ||||
| 		SELECT | ||||
| 			[TypeID], | ||||
| 			[Name], | ||||
| 			[Config], | ||||
| 			[DTS], | ||||
| 			[UserID], | ||||
| 			[LastChanged], | ||||
| 			(SELECT COUNT(*) FROM [Annotations] WHERE [Annotations].[TypeID]=[AnnotationTypes].[TypeID]) [AnnotationCount], | ||||
| 			[IsEPAnnotationType] | ||||
| 		FROM [AnnotationTypes] | ||||
| 	END | ||||
| END | ||||
|  | ||||
| GO | ||||
|  | ||||
| -- C2025-027 Annotation Type Filtering | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[UpdateAnnotationstypeSelections]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [UpdateAnnotationstypeSelections]; | ||||
|  | ||||
| -- Need to drop UpdateAnnotationstypeSelections SP first so script can drop and recreate the TableValAnnotTypeSelections table type  | ||||
|  | ||||
| IF EXISTS( SELECT * FROM INFORMATION_SCHEMA.DOMAINS WHERE Domain_Name = 'TableValAnnotTypeSelections' ) | ||||
|     DROP TYPE [dbo].[TableValAnnotTypeSelections] | ||||
|  | ||||
| CREATE TYPE [dbo].[TableValAnnotTypeSelections] AS TABLE( | ||||
| 	[TypeID] [int] NOT NULL | ||||
| 							 | ||||
| ) | ||||
| GO | ||||
|  | ||||
| /****** Object:  StoredProcedure [dbo].[UpdateAnnotationstypeSelections]    Script Date: 7/21/2025 8:51:42 PM ******/ | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Paul Larsen | ||||
| -- Create date: 07/21/2025 | ||||
| -- Description:	Manage user choice annotation types | ||||
| -- ============================================= | ||||
| CREATE PROC [dbo].[UpdateAnnotationstypeSelections] | ||||
| ( | ||||
| 	@TempTable AS dbo.TableValAnnotTypeSelections READONLY, | ||||
| 	@UserID [varchar](50) NULL | ||||
| ) | ||||
| AS | ||||
| BEGIN | ||||
| 																	  | ||||
| 															 | ||||
|  | ||||
| 	DELETE FROM AnnotationTypeSelections where UserID = @UserID | ||||
| 	AND | ||||
| 	TypeID not in | ||||
| 	(Select TypeID From @TempTable tmp) | ||||
|  | ||||
| 	--this would insert all the ones that are in the uploaded table and not already in AnnotationTypeSelections | ||||
| 	Insert INTO AnnotationTypeSelections (TypeID, UserID) | ||||
| 	Select tmp.TypeID, @UserID | ||||
| 	FROM | ||||
| 	@TempTable tmp | ||||
| 	LEFT OUTER JOIN | ||||
| 	AnnotationTypeSelections ATS on ATS.TypeID = tmp.TypeID | ||||
| 	AND ATS.UserID = @UserID | ||||
| 	where | ||||
| 	ATS.ASTypeID IS NULL | ||||
|  | ||||
| END | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Running vesp_UpdateEPFormat Succeeded' | ||||
| ELSE PRINT 'Running vesp_UpdateEPFormat Failed to Execute' | ||||
| GO | ||||
| UPDATE Formats SET ApplicablePlant = 1000 WHERE [Name] LIKE 'EPTST%'; | ||||
| Go | ||||
| ---  end changes for: | ||||
| ---C2025-023 - Electronic Procedures - Modifications to PROMS | ||||
|  | ||||
| /* | ||||
| ========================================================================================================== | ||||
|  Begin: C2025-045: Improve Performance loading procedures with Alarms | ||||
| ========================================================================================================== | ||||
| */ | ||||
|  | ||||
| IF Exists(SELECT 1 from information_schema.columns where character_maximum_length=-1 and column_name = 'AccPageID' and table_name = 'RofstDefaultValue') | ||||
| Begin | ||||
| ALTER TABLE RofstDefaultValue ALTER COLUMN AccPageID varchar(100) | ||||
| END | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Updating size of RofstDefaultValue.AccPageID Succeeded' | ||||
| ELSE PRINT 'Updating size of RofstDefaultValue.AccPageID Failed to Execute' | ||||
| GO | ||||
|  | ||||
| EXEC sp_refreshview [dbo.vwRofstData_RofstDefaultValues] | ||||
| EXEC sp_refreshview [dbo.vwRofstData_RofstBaseRoids] | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Refreshing views: (vwRofstData_RofstDefaultValues,vwRofstData_RofstBaseRoids) Succeeded' | ||||
| ELSE PRINT 'Refreshing views: (vwRofstData_RofstDefaultValues,vwRofstData_RofstBaseRoids) Failed to Execute' | ||||
| GO | ||||
|  | ||||
| IF NOT EXISTS (SELECT * FROM dbo.sysindexes WHERE name = 'IX_RofstDefaultValue_RofstID_AccPageID') | ||||
| BEGIN | ||||
| CREATE NONCLUSTERED INDEX [IX_RofstDefaultValue_RofstID_AccPageID] ON [dbo].[RofstDefaultValue] | ||||
| ( | ||||
|     [RofstID] ASC, | ||||
| 	[AccPageID] ASC | ||||
| ) | ||||
| INCLUDE | ||||
| ( | ||||
|        [roid] | ||||
|       ,[value] | ||||
| ) | ||||
| WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] | ||||
|  | ||||
| END | ||||
| GO | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Adding Index IX_RofstDefaultValue_RofstID_AccPageID Succeeded' | ||||
| ELSE PRINT 'Adding Index IX_RofstDefaultValue_RofstID_AccPageID Failed to Execute' | ||||
| GO | ||||
|  | ||||
| /* | ||||
| ========================================================================================================== | ||||
|  End: C2025-045: Improve Performance loading procedures with Alarms | ||||
| ========================================================================================================== | ||||
| */ | ||||
|  | ||||
| -- C2025-009 Report for tracking PROMS Users / Security | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[getUserAcessControl]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [getUserAcessControl]; | ||||
|  | ||||
| GO | ||||
|  | ||||
| /****** Object:  StoredProcedure [dbo].[getUserAcessControl]    Script Date: 9/5/2025 6:51:42 AM ******/ | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 09/05/2025 | ||||
| -- Description:	Get Data on When Users were added to PROMS and when they were added to Security Groups | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[getUserAcessControl] | ||||
| AS | ||||
| BEGIN | ||||
| 	SELECT Users.UserID,  | ||||
| 		   WhenUserAddedToPROMS = Users.[DTS], | ||||
| 					   GroupName = Groups.GroupName, | ||||
| 					   WhenUserAddedToGroup = Memberships.[DTS], | ||||
| 					   WhoAddedUserToGroup = CASE WHEN  | ||||
| 									Memberships.UsrID = Users.UsrID | ||||
| 									AND Users.UsrID = Users.UserID | ||||
| 									THEN 'INITIAL_SETUP' | ||||
| 									ELSE Memberships.UsrID END, | ||||
| 					   DateUserRemovedFromGroup = Memberships.EndDate | ||||
| 	  FROM Memberships | ||||
| 	  inner join Groups on Memberships.GID = Groups.GID | ||||
| 	  right outer join Users on Users.UID = Memberships.UID | ||||
| 	  order by UserID, Memberships.[DTS] | ||||
| 	RETURN | ||||
| END | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Procedure Creation: [getUserAcessControl] Succeeded' | ||||
| ELSE PRINT 'Procedure Creation: [getUserAcessControl] Error on Creation' | ||||
| GO | ||||
|  | ||||
| -- C2021-058 Admin Tool Purge Change History / C2025-052 Admin Tool Index Maintenance | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_PurgeChangeHistory]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_PurgeChangeHistory]; | ||||
|  | ||||
| GO | ||||
|  | ||||
| /****** Object:  StoredProcedure [dbo].[vesp_PurgeChangeHistory]    Script Date: 9/9/2025 6:51:42 AM ******/ | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 09/09/2025 | ||||
| -- Description:	Admin Tool Purge Change History. Add the ability to remove audit records from Admin Tools.   | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[vesp_PurgeChangeHistory] | ||||
| ( | ||||
| 	@dte AS datetime | ||||
| ) | ||||
| AS | ||||
| BEGIN | ||||
| 		Delete from Versions where DTS < @dte | ||||
| 		Delete from DocumentAudits where DTS < @dte | ||||
| 		delete from Figures  where ROFSTID not in(select rofstid from Associations) and DTS < @dte | ||||
| 		Delete from ROFSTs where ROFSTID not in(select rofstid from Associations) and DTS < @dte | ||||
| 		delete from roimages where rodbid not in(select rodbid from rofsts) and DTS < @dte | ||||
| 		delete from documents where docid not in(select docid from entries) and DTS < @dte | ||||
| 	PRINT 'Temporarally storing Items to delete' | ||||
| 	    declare @Items table (ItemID bigint PRIMARY KEY, deletestatus int) | ||||
| 		INSERT INTO @Items | ||||
| 			Select Child.ItemID, Child.deletestatus | ||||
| 				FROM tblItems AS Child | ||||
| 				INNER JOIN tblContents AS parent | ||||
| 				ON Parent.ContentID = Child.ContentID | ||||
| 					AND Parent.deletestatus = Child.deletestatus | ||||
| 				Where | ||||
| 				parent.deletestatus != 0 and parent.ActionDTS < @dte | ||||
| 	PRINT 'Phase 1' | ||||
| 		delete from tblAnnotations where deletestatus != 0 and DTS < @dte | ||||
| 		delete tblAnnotations  | ||||
| 		  from tblAnnotations | ||||
| 		   INNER JOIN @Items Itms | ||||
| 		     ON Itms.ItemID = tblAnnotations.ItemID AND tblAnnotations.deletestatus != 0 | ||||
|  | ||||
| 		delete from drousages where docid in(select docid from tbldocuments where deletestatus != 0) and DTS < @dte | ||||
| 		delete from tblEntries where deletestatus != 0 and DTS < @dte | ||||
| 		delete from tblDocuments where deletestatus != 0 and DTS < @dte | ||||
| 		delete from tblGrids where deletestatus != 0 and DTS < @dte | ||||
| 		delete from tblImages where deletestatus != 0 and DTS < @dte | ||||
| 	PRINT 'Phase 2' | ||||
| 		delete from tblROUsages where deletestatus != 0 and DTS < @dte | ||||
| 		delete tblROUsages  | ||||
| 		   from tblROUsages | ||||
| 		   INNER JOIN tblContents ON tblContents.ContentID = tblROUsages.ContentID | ||||
| 		     AND tblContents.deletestatus = tblROUsages.deletestatus | ||||
| 		    where tblContents.deletestatus != 0 and tblContents.ActionDTS < @dte | ||||
| 	PRINT 'Deleting Transitions' | ||||
| 		delete from tblTransitions where deletestatus != 0 and  | ||||
| 		  (DTS < @dte | ||||
| 		   OR RangeID in (Select ItemID FROM @Items) | ||||
| 		   OR ToID in (Select ItemID FROM @Items) | ||||
| 		   OR FromID in (Select ContentID from tblContents where deletestatus != 0 and ActionDTS < @dte) | ||||
| 		  ) | ||||
| 	PRINT 'Deleting Items and Parts' | ||||
| 		delete from tblItems where deletestatus != 0 and DTS < @dte | ||||
| 		delete from tblParts where deletestatus != 0 and ItemID Not IN (Select ItemID from Items) and DTS < @dte | ||||
| 	PRINT 'Purging Parts with deleted Contents' | ||||
| 		DELETE from Child | ||||
| 		 FROM tblParts AS Child | ||||
| 		 INNER JOIN tblItems | ||||
| 		   ON tblItems.ItemID = Child.ItemID | ||||
| 		    AND tblItems.deletestatus = Child.deletestatus | ||||
| 		 INNER JOIN tblContents AS parent | ||||
| 		   ON parent.ContentID = tblItems.ContentID | ||||
| 		    AND parent.deletestatus = tblItems.deletestatus | ||||
| 		   Where | ||||
| 		    parent.deletestatus != 0 and parent.ActionDTS < @dte | ||||
| 		DELETE FROM tblParts  | ||||
| 		where deletestatus != 0 AND | ||||
| 		ContentID in | ||||
|          (Select ContentID from tblContents where deletestatus != 0 and ActionDTS < @dte) | ||||
|  | ||||
| 	PRINT 'Purging Items with deleted Contents' | ||||
| 	   alter table tblItems nocheck constraint FK_Items_Items | ||||
| 		DELETE tblItems | ||||
| 		 FROM tblItems | ||||
| 		 INNER JOIN @Items Itms | ||||
| 		   ON Itms.ItemID = tblItems.ItemID AND Itms.deletestatus = tblItems.deletestatus | ||||
| 	   alter table tblItems check constraint FK_Items_Items | ||||
| 	PRINT 'Purging Contents' | ||||
| 		delete from tblContents where deletestatus != 0 and ActionDTS < @dte  | ||||
| 	PRINT 'Phase 3'  | ||||
| 		delete from AnnotationAudits where DTS < @dte | ||||
| 		delete from ContentAudits where DTS < @dte | ||||
| 		delete from EntryAudits where DTS < @dte | ||||
| 		delete from DocumentAudits where DTS < @dte | ||||
| 		delete from GridAudits where DTS < @dte | ||||
| 		delete from ImageAudits where DTS < @dte | ||||
| 	PRINT 'Phase 4'  | ||||
| 		delete from ItemAudits where DTS < @dte | ||||
| 		delete from PartAudits where DTS < @dte | ||||
| 		delete from ROUsageAudits where DTS < @dte | ||||
| 		delete from TransitionAudits where DTS < @dte | ||||
|  | ||||
| 	RETURN | ||||
| END | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Procedure Creation: [vesp_PurgeChangeHistory] Succeeded' | ||||
| ELSE PRINT 'Procedure Creation: [vesp_PurgeChangeHistory] Error on Creation' | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_IndexMaintenance]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_IndexMaintenance]; | ||||
|  | ||||
| GO | ||||
|  | ||||
| /****** Object:  StoredProcedure [dbo].[vesp_IndexMaintenance]    Script Date: 9/9/2025 7:54:42 AM ******/ | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 09/09/2025 | ||||
| -- Description:	Rebuild all indexes in the db | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[vesp_IndexMaintenance] | ||||
| With Execute as Owner | ||||
| AS | ||||
| BEGIN | ||||
|  | ||||
| 	Exec sp_msforeachtable 'SET QUOTED_IDENTIFIER ON; ALTER INDEX ALL ON ? REBUILD' | ||||
|  | ||||
| 	RETURN | ||||
| END | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Procedure Creation: [vesp_IndexMaintenance] Succeeded' | ||||
| ELSE PRINT 'Procedure Creation: [vesp_IndexMaintenance] Error on Creation' | ||||
| GO | ||||
|  | ||||
| IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[vesp_GetOtherActiveSessions]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1) | ||||
| 	DROP PROCEDURE [vesp_GetOtherActiveSessions]; | ||||
|  | ||||
| GO | ||||
|  | ||||
| /****** Object:  StoredProcedure [dbo].[vesp_GetOtherActiveSessions]    Script Date: 9/10/2025 7:54:42 AM ******/ | ||||
|  | ||||
| -- ============================================= | ||||
| -- Author:		Matthew Schill | ||||
| -- Create date: 09/10/2025 | ||||
| -- Description:	Get active sessions by users other than the current user | ||||
| -- ============================================= | ||||
| CREATE PROCEDURE [dbo].[vesp_GetOtherActiveSessions] | ||||
| ( | ||||
| 	@UsrID AS varchar(100) | ||||
| ) | ||||
| AS | ||||
| BEGIN | ||||
|  | ||||
| 		SELECT | ||||
| 			[UserID], | ||||
| 			[DTSDtart], | ||||
| 			[MachineName] | ||||
| 		FROM [Sessions] | ||||
| 		WHERE DTSEnd IS NULL AND UserID != @UsrID | ||||
|  | ||||
| 	RETURN | ||||
| END | ||||
|  | ||||
| IF (@@Error = 0) PRINT 'Procedure Creation: [vesp_GetOtherActiveSessions] Succeeded' | ||||
| ELSE PRINT 'Procedure Creation: [vesp_GetOtherActiveSessions] Error on Creation' | ||||
| GO | ||||
|  | ||||
|  | ||||
| /* | ||||
|   --------------------------------------------------------------------------- | ||||
|   |                       ADD New Code Before this Block                    | | ||||
| @@ -23844,8 +24465,8 @@ BEGIN TRY -- Try Block | ||||
| 	DECLARE @RevDate varchar(255) | ||||
| 	DECLARE @RevDescription varchar(255) | ||||
|  | ||||
| 	set @RevDate = '4/03/2025 6:14 PM' | ||||
| 	set @RevDescription = 'B2022-031 Add filtering for Proc and Section name from Global Search' | ||||
| 	set @RevDate = '09/16/2025 7:00 AM' | ||||
| 	set @RevDescription = 'Added Purge Change History and Index Maintenance functions to Admin Tools' | ||||
|  | ||||
| 	Select  cast(@RevDate as datetime) RevDate, @RevDescription  RevDescription | ||||
| 	PRINT 'SQL Code Revision ' + @RevDate + ' - ' + @RevDescription | ||||
|   | ||||
| @@ -250,6 +250,16 @@ namespace VEPROMS.Properties { | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         /// <summary> | ||||
|         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||
|         /// </summary> | ||||
|         internal static System.Drawing.Bitmap toolbox { | ||||
|             get { | ||||
|                 object obj = ResourceManager.GetObject("toolbox", resourceCulture); | ||||
|                 return ((System.Drawing.Bitmap)(obj)); | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         /// <summary> | ||||
|         ///   Looks up a localized resource of type System.Drawing.Bitmap. | ||||
|         /// </summary> | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -410,17 +410,5 @@ namespace VEPROMS.Properties { | ||||
|                 this["VisioPath"] = value; | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         [global::System.Configuration.UserScopedSettingAttribute()] | ||||
|         [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] | ||||
|         [global::System.Configuration.DefaultSettingValueAttribute("0")] | ||||
|         public int UCFImportOpt { | ||||
|             get { | ||||
|                 return ((int)(this["UCFImportOpt"])); | ||||
|             } | ||||
|             set { | ||||
|                 this["UCFImportOpt"] = value; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -80,11 +80,9 @@ | ||||
|     <Setting Name="UpdateSettings" Type="System.Boolean" Scope="User"> | ||||
|       <Value Profile="(Default)">True</Value> | ||||
|     </Setting> | ||||
|  | ||||
|     <Setting Name="cbShwRplWrdsColor" Type="System.Boolean" Scope="User"> | ||||
|       <Value Profile="(Default)">False</Value> | ||||
|     </Setting> | ||||
|      | ||||
|     <Setting Name="PasteNoReturns" Type="System.Boolean" Scope="User"> | ||||
|       <Value Profile="(Default)">False</Value> | ||||
|     </Setting> | ||||
| @@ -103,8 +101,5 @@ | ||||
|     <Setting Name="VisioPath" Type="System.String" Scope="User"> | ||||
|       <Value Profile="(Default)" /> | ||||
|     </Setting> | ||||
|     <Setting Name="UCFImportOpt" Type="System.Int32" Scope="User"> | ||||
|       <Value Profile="(Default)">0</Value> | ||||
|     </Setting> | ||||
|   </Settings> | ||||
| </SettingsFile> | ||||
							
								
								
									
										
											BIN
										
									
								
								PROMS/VEPROMS User Interface/Resources/toolbox.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								PROMS/VEPROMS User Interface/Resources/toolbox.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 3.3 KiB | 
| @@ -50,7 +50,7 @@ | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||||
| @@ -61,13 +61,14 @@ | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <WarningLevel>4</WarningLevel> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Demo|AnyCPU' "> | ||||
|     <DebugSymbols>true</DebugSymbols> | ||||
|     <OutputPath>bin\Demo\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -76,7 +77,7 @@ | ||||
|     <OutputPath>bin\Debug\</OutputPath> | ||||
|     <DefineConstants>DEBUG;TRACE</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -85,7 +86,7 @@ | ||||
|     <DefineConstants>TRACE</DefineConstants> | ||||
|     <Optimize>true</Optimize> | ||||
|     <DebugType>pdbonly</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -94,7 +95,7 @@ | ||||
|     <OutputPath>bin\Demo\</OutputPath> | ||||
|     <DefineConstants>TRACE;DEMO</DefineConstants> | ||||
|     <DebugType>full</DebugType> | ||||
|     <PlatformTarget>x86</PlatformTarget> | ||||
|     <PlatformTarget>x64</PlatformTarget> | ||||
|     <ErrorReport>prompt</ErrorReport> | ||||
|     <Prefer32Bit>false</Prefer32Bit> | ||||
|   </PropertyGroup> | ||||
| @@ -111,10 +112,6 @@ | ||||
|       <SpecificVersion>False</SpecificVersion> | ||||
|       <HintPath>..\..\..\..\3rdPartyLibraries\DotNetBar\DotNetBar4.6Build\DevComponents.DotNetBar2.dll</HintPath> | ||||
|     </Reference> | ||||
|     <Reference Include="Ionic.Zip, Version=1.9.1.8, Culture=neutral, PublicKeyToken=edbe51ad942a3f5c, processorArchitecture=MSIL"> | ||||
|       <SpecificVersion>False</SpecificVersion> | ||||
|       <HintPath>..\..\..\..\3rdPartyLibraries\Ionic\Ionic.Zip.dll</HintPath> | ||||
|     </Reference> | ||||
|     <Reference Include="Itenso.Rtf.Interpreter"> | ||||
|       <HintPath>..\..\..\..\3rdPartyLibraries\RtfConverter\bin\Debug\Itenso.Rtf.Interpreter.dll</HintPath> | ||||
|     </Reference> | ||||
| @@ -125,6 +122,10 @@ | ||||
|       <SpecificVersion>False</SpecificVersion> | ||||
|       <HintPath>..\..\..\..\3rdPartyLibraries\Log4Net\log4net.dll</HintPath> | ||||
|     </Reference> | ||||
|     <Reference Include="Microsoft.CSharp" /> | ||||
|     <Reference Include="Microsoft.Office.Interop.Excel, Version=15.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c, processorArchitecture=MSIL"> | ||||
|       <EmbedInteropTypes>True</EmbedInteropTypes> | ||||
|     </Reference> | ||||
|     <Reference Include="System" /> | ||||
|     <Reference Include="System.configuration" /> | ||||
|     <Reference Include="System.Data"> | ||||
| @@ -133,6 +134,8 @@ | ||||
|     <Reference Include="System.Deployment" /> | ||||
|     <Reference Include="System.Design" /> | ||||
|     <Reference Include="System.Drawing" /> | ||||
|     <Reference Include="System.IO.Compression" /> | ||||
|     <Reference Include="System.IO.Compression.FileSystem" /> | ||||
|     <Reference Include="System.Runtime.Remoting" /> | ||||
|     <Reference Include="System.Web" /> | ||||
|     <Reference Include="System.Web.Extensions" /> | ||||
| @@ -152,6 +155,17 @@ | ||||
|       <DependentUpon>AboutVEPROMS.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="BookMarks.cs" /> | ||||
|     <Compile Include="dlgAnnotationsSelect.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgAnnotationsSelect.Designer.cs"> | ||||
|       <DependentUpon>dlgAnnotationsSelect.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgAnnotationsSelect.Designer.cs"> | ||||
|       <AutoGen>True</AutoGen> | ||||
|       <DesignTime>True</DesignTime> | ||||
|       <DependentUpon>dlgAnnotationsSelect.resx</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgApproveProcedure.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
| @@ -164,6 +178,15 @@ | ||||
|     <Compile Include="dlgCheckedOutProcedure.designer.cs"> | ||||
|       <DependentUpon>dlgCheckedOutProcedure.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgExportImportEP.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgMSWordMessage.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgMSWordMessage.Designer.cs"> | ||||
|       <DependentUpon>dlgMSWordMessage.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgCheckOpenTabs.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
| @@ -206,6 +229,12 @@ | ||||
|     <Compile Include="dlgPickROFolder.designer.cs"> | ||||
|       <DependentUpon>dlgPickROFolder.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgPrintAllApprovedProcedures.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgPrintAllApprovedProcedures.Designer.cs"> | ||||
|       <DependentUpon>dlgPrintAllApprovedProcedures.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="DlgPrintProcedure.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
| @@ -224,12 +253,6 @@ | ||||
|     <Compile Include="dlgTransitionReport.designer.cs"> | ||||
|       <DependentUpon>dlgTransitionReport.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgUCFDetail.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="dlgUCFDetail.Designer.cs"> | ||||
|       <DependentUpon>dlgUCFDetail.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="frmAnnotationsCleanup.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
| @@ -248,6 +271,12 @@ | ||||
|     <Compile Include="frmBatchRefreshCheckedOut.designer.cs"> | ||||
|       <DependentUpon>frmBatchRefreshCheckedOut.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="frmGenTools.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="frmGenTools.designer.cs"> | ||||
|       <DependentUpon>frmGenTools.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="frmManageUser.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
| @@ -278,12 +307,6 @@ | ||||
|     <Compile Include="frmSI.Designer.cs"> | ||||
|       <DependentUpon>frmSI.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="frmUCF.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="frmUCF.designer.cs"> | ||||
|       <DependentUpon>frmUCF.cs</DependentUpon> | ||||
|     </Compile> | ||||
|     <Compile Include="frmVEPROMS.cs"> | ||||
|       <SubType>Form</SubType> | ||||
|     </Compile> | ||||
| @@ -331,6 +354,13 @@ | ||||
|       <SubType>Designer</SubType> | ||||
|       <DependentUpon>AboutVEPROMS.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="dlgAnnotationsSelect.resx"> | ||||
|       <DependentUpon>dlgAnnotationsSelect.cs</DependentUpon> | ||||
|       <Generator>ResXFileCodeGenerator</Generator> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="dlgMSWordMessage.resx"> | ||||
|       <DependentUpon>dlgMSWordMessage.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="dlgCheckOpenTabs.resx"> | ||||
|       <DependentUpon>dlgCheckOpenTabs.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
| @@ -340,6 +370,9 @@ | ||||
|     <EmbeddedResource Include="dlgImpHowToHandleROs.resx"> | ||||
|       <DependentUpon>dlgImpHowToHandleROs.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="dlgPrintAllApprovedProcedures.resx"> | ||||
|       <DependentUpon>dlgPrintAllApprovedProcedures.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="DlgPrintProcedure.resx"> | ||||
|       <DependentUpon>DlgPrintProcedure.cs</DependentUpon> | ||||
|       <SubType>Designer</SubType> | ||||
| @@ -347,12 +380,12 @@ | ||||
|     <EmbeddedResource Include="dlgSetChangeBarStartDate.resx"> | ||||
|       <DependentUpon>dlgSetChangeBarStartDate.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="dlgUCFDetail.resx"> | ||||
|       <DependentUpon>dlgUCFDetail.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="frmAnnotationsCleanup.resx"> | ||||
|       <DependentUpon>frmAnnotationsCleanup.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="frmGenTools.resx"> | ||||
|       <DependentUpon>frmGenTools.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="frmPDFStatusForm.resx"> | ||||
|       <DependentUpon>frmPDFStatusForm.cs</DependentUpon> | ||||
|       <SubType>Designer</SubType> | ||||
| @@ -368,9 +401,6 @@ | ||||
|     <EmbeddedResource Include="frmSI.resx"> | ||||
|       <DependentUpon>frmSI.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="frmUCF.resx"> | ||||
|       <DependentUpon>frmUCF.cs</DependentUpon> | ||||
|     </EmbeddedResource> | ||||
|     <EmbeddedResource Include="frmVEPROMS.resx"> | ||||
|       <SubType>Designer</SubType> | ||||
|       <DependentUpon>frmVEPROMS.cs</DependentUpon> | ||||
| @@ -478,6 +508,7 @@ | ||||
|     <Content Include="PROMSRollback %28v2.0%29.Sql"> | ||||
|       <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> | ||||
|     </Content> | ||||
|     <Content Include="Resources\toolbox.png" /> | ||||
|     <Content Include="ROBuild.Sql"> | ||||
|       <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> | ||||
|     </Content> | ||||
| @@ -568,8 +599,6 @@ | ||||
|     <Content Include="Resources\Save.png" /> | ||||
|     <Content Include="Resources\SaveAllHS.png" /> | ||||
|     <Content Include="Resources\SaveAs.png" /> | ||||
|     <Content Include="UCFDetails.xsl" /> | ||||
|     <Content Include="UCFSummary.xsl" /> | ||||
|     <Content Include="VEicon.ico" /> | ||||
|     <Content Include="veproms.ico" /> | ||||
|     <Content Include="Vicon.ico" /> | ||||
|   | ||||
							
								
								
									
										229
									
								
								PROMS/VEPROMS User Interface/dlgAnnotationsSelect.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										229
									
								
								PROMS/VEPROMS User Interface/dlgAnnotationsSelect.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,229 @@ | ||||
|  | ||||
| namespace VEPROMS | ||||
| { | ||||
| 	partial class dlgAnnotationsSelect | ||||
| 	{ | ||||
| 		/// <summary> | ||||
| 		/// Required designer variable. | ||||
| 		/// </summary> | ||||
| 		private System.ComponentModel.IContainer components = null; | ||||
|  | ||||
| 		/// <summary> | ||||
| 		/// Clean up any resources being used. | ||||
| 		/// </summary> | ||||
| 		/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param> | ||||
| 		protected override void Dispose(bool disposing) | ||||
| 		{ | ||||
| 			if (disposing && (components != null)) | ||||
| 			{ | ||||
| 				components.Dispose(); | ||||
| 			} | ||||
| 			base.Dispose(disposing); | ||||
| 		} | ||||
|  | ||||
| 		#region Windows Form Designer generated code | ||||
|  | ||||
| 		/// <summary> | ||||
| 		/// Required method for Designer support - do not modify | ||||
| 		/// the contents of this method with the code editor. | ||||
| 		/// </summary> | ||||
| 		private void InitializeComponent() | ||||
| 		{ | ||||
| 			this.lstUnselected = new System.Windows.Forms.ListBox(); | ||||
| 			this.lstSelected = new System.Windows.Forms.ListBox(); | ||||
| 			this.btnSelect = new System.Windows.Forms.Button(); | ||||
| 			this.btnSelectAll = new System.Windows.Forms.Button(); | ||||
| 			this.btnDeselectAll = new System.Windows.Forms.Button(); | ||||
| 			this.btnDeselect = new System.Windows.Forms.Button(); | ||||
| 			this.btnUpdate = new System.Windows.Forms.Button(); | ||||
| 			this.tableLayoutPanel1 = new System.Windows.Forms.TableLayoutPanel(); | ||||
| 			this.btnCancel = new System.Windows.Forms.Button(); | ||||
| 			this.lblMessage = new System.Windows.Forms.Label(); | ||||
| 			this.lblAvailableTypes = new System.Windows.Forms.Label(); | ||||
| 			this.lblSelected = new System.Windows.Forms.Label(); | ||||
| 			this.tableLayoutPanel1.SuspendLayout(); | ||||
| 			this.SuspendLayout(); | ||||
| 			//  | ||||
| 			// lstUnselected | ||||
| 			//  | ||||
| 			this.lstUnselected.Dock = System.Windows.Forms.DockStyle.Fill; | ||||
| 			this.lstUnselected.FormattingEnabled = true; | ||||
| 			this.lstUnselected.IntegralHeight = false; | ||||
| 			this.lstUnselected.ItemHeight = 16; | ||||
| 			this.lstUnselected.Location = new System.Drawing.Point(3, 3); | ||||
| 			this.lstUnselected.Name = "lstUnselected"; | ||||
| 			this.tableLayoutPanel1.SetRowSpan(this.lstUnselected, 4); | ||||
| 			this.lstUnselected.SelectionMode = System.Windows.Forms.SelectionMode.MultiExtended; | ||||
| 			this.lstUnselected.Size = new System.Drawing.Size(287, 347); | ||||
| 			this.lstUnselected.TabIndex = 0; | ||||
| 			this.lstUnselected.SelectedIndexChanged += new System.EventHandler(this.lst_SelectedIndexChanged); | ||||
| 			//  | ||||
| 			// lstSelected | ||||
| 			//  | ||||
| 			this.lstSelected.Dock = System.Windows.Forms.DockStyle.Fill; | ||||
| 			this.lstSelected.FormattingEnabled = true; | ||||
| 			this.lstSelected.IntegralHeight = false; | ||||
| 			this.lstSelected.ItemHeight = 16; | ||||
| 			this.lstSelected.Location = new System.Drawing.Point(334, 3); | ||||
| 			this.lstSelected.Name = "lstSelected"; | ||||
| 			this.tableLayoutPanel1.SetRowSpan(this.lstSelected, 4); | ||||
| 			this.lstSelected.SelectionMode = System.Windows.Forms.SelectionMode.MultiExtended; | ||||
| 			this.lstSelected.Size = new System.Drawing.Size(288, 347); | ||||
| 			this.lstSelected.TabIndex = 1; | ||||
| 			this.lstSelected.SelectedIndexChanged += new System.EventHandler(this.lst_SelectedIndexChanged); | ||||
| 			//  | ||||
| 			// btnSelect | ||||
| 			//  | ||||
| 			this.btnSelect.Anchor = System.Windows.Forms.AnchorStyles.None; | ||||
| 			this.btnSelect.Location = new System.Drawing.Point(298, 32); | ||||
| 			this.btnSelect.Name = "btnSelect"; | ||||
| 			this.btnSelect.Size = new System.Drawing.Size(28, 23); | ||||
| 			this.btnSelect.TabIndex = 2; | ||||
| 			this.btnSelect.Text = ">"; | ||||
| 			this.btnSelect.UseVisualStyleBackColor = true; | ||||
| 			this.btnSelect.Click += new System.EventHandler(this.btnSelect_Click); | ||||
| 			//  | ||||
| 			// btnSelectAll | ||||
| 			//  | ||||
| 			this.btnSelectAll.Anchor = System.Windows.Forms.AnchorStyles.None; | ||||
| 			this.btnSelectAll.Location = new System.Drawing.Point(296, 120); | ||||
| 			this.btnSelectAll.Name = "btnSelectAll"; | ||||
| 			this.btnSelectAll.Size = new System.Drawing.Size(32, 23); | ||||
| 			this.btnSelectAll.TabIndex = 3; | ||||
| 			this.btnSelectAll.Text = ">>"; | ||||
| 			this.btnSelectAll.UseVisualStyleBackColor = true; | ||||
| 			this.btnSelectAll.Click += new System.EventHandler(this.btnSelectAll_Click); | ||||
| 			//  | ||||
| 			// btnDeselectAll | ||||
| 			//  | ||||
| 			this.btnDeselectAll.Anchor = System.Windows.Forms.AnchorStyles.None; | ||||
| 			this.btnDeselectAll.Location = new System.Drawing.Point(297, 207); | ||||
| 			this.btnDeselectAll.Name = "btnDeselectAll"; | ||||
| 			this.btnDeselectAll.Size = new System.Drawing.Size(30, 26); | ||||
| 			this.btnDeselectAll.TabIndex = 5; | ||||
| 			this.btnDeselectAll.Text = "<<"; | ||||
| 			this.btnDeselectAll.UseVisualStyleBackColor = true; | ||||
| 			this.btnDeselectAll.Click += new System.EventHandler(this.btnDeselectAll_Click); | ||||
| 			//  | ||||
| 			// btnDeselect | ||||
| 			//  | ||||
| 			this.btnDeselect.Anchor = System.Windows.Forms.AnchorStyles.None; | ||||
| 			this.btnDeselect.Location = new System.Drawing.Point(298, 297); | ||||
| 			this.btnDeselect.Name = "btnDeselect"; | ||||
| 			this.btnDeselect.Size = new System.Drawing.Size(28, 23); | ||||
| 			this.btnDeselect.TabIndex = 4; | ||||
| 			this.btnDeselect.Text = "<"; | ||||
| 			this.btnDeselect.UseVisualStyleBackColor = true; | ||||
| 			this.btnDeselect.Click += new System.EventHandler(this.btnDeselect_Click); | ||||
| 			//  | ||||
| 			// btnUpdate | ||||
| 			//  | ||||
| 			this.btnUpdate.Anchor = System.Windows.Forms.AnchorStyles.None; | ||||
| 			this.btnUpdate.Location = new System.Drawing.Point(536, 422); | ||||
| 			this.btnUpdate.Name = "btnUpdate"; | ||||
| 			this.btnUpdate.Size = new System.Drawing.Size(100, 35); | ||||
| 			this.btnUpdate.TabIndex = 8; | ||||
| 			this.btnUpdate.Text = "Save"; | ||||
| 			this.btnUpdate.UseVisualStyleBackColor = true; | ||||
| 			this.btnUpdate.Click += new System.EventHandler(this.btnUpdate_Click); | ||||
| 			//  | ||||
| 			// tableLayoutPanel1 | ||||
| 			//  | ||||
| 			this.tableLayoutPanel1.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)  | ||||
|             | System.Windows.Forms.AnchorStyles.Left)  | ||||
|             | System.Windows.Forms.AnchorStyles.Right))); | ||||
| 			this.tableLayoutPanel1.ColumnCount = 3; | ||||
| 			this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F)); | ||||
| 			this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Absolute, 38F)); | ||||
| 			this.tableLayoutPanel1.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 50F)); | ||||
| 			this.tableLayoutPanel1.Controls.Add(this.lstUnselected, 0, 0); | ||||
| 			this.tableLayoutPanel1.Controls.Add(this.lstSelected, 2, 0); | ||||
| 			this.tableLayoutPanel1.Controls.Add(this.btnDeselect, 1, 3); | ||||
| 			this.tableLayoutPanel1.Controls.Add(this.btnDeselectAll, 1, 2); | ||||
| 			this.tableLayoutPanel1.Controls.Add(this.btnSelect, 1, 0); | ||||
| 			this.tableLayoutPanel1.Controls.Add(this.btnSelectAll, 1, 1); | ||||
| 			this.tableLayoutPanel1.Location = new System.Drawing.Point(12, 62); | ||||
| 			this.tableLayoutPanel1.Name = "tableLayoutPanel1"; | ||||
| 			this.tableLayoutPanel1.RowCount = 4; | ||||
| 			this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 25F)); | ||||
| 			this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 25F)); | ||||
| 			this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 25F)); | ||||
| 			this.tableLayoutPanel1.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Percent, 25F)); | ||||
| 			this.tableLayoutPanel1.Size = new System.Drawing.Size(625, 353); | ||||
| 			this.tableLayoutPanel1.TabIndex = 6; | ||||
| 			//  | ||||
| 			// btnCancel | ||||
| 			//  | ||||
| 			this.btnCancel.Location = new System.Drawing.Point(411, 422); | ||||
| 			this.btnCancel.Name = "btnCancel"; | ||||
| 			this.btnCancel.Size = new System.Drawing.Size(100, 35); | ||||
| 			this.btnCancel.TabIndex = 9; | ||||
| 			this.btnCancel.Text = "Close"; | ||||
| 			this.btnCancel.UseVisualStyleBackColor = true; | ||||
| 			this.btnCancel.Click += new System.EventHandler(this.btnCancel_Click_1); | ||||
| 			//  | ||||
| 			// lblMessage | ||||
| 			//  | ||||
| 			this.lblMessage.Font = new System.Drawing.Font("Microsoft Sans Serif", 9.75F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
| 			this.lblMessage.Location = new System.Drawing.Point(43, 12); | ||||
| 			this.lblMessage.Name = "lblMessage"; | ||||
| 			this.lblMessage.Size = new System.Drawing.Size(317, 16); | ||||
| 			this.lblMessage.TabIndex = 10; | ||||
| 			this.lblMessage.Text = "Updates will appear when PROMS is restarted."; | ||||
| 			//  | ||||
| 			// lblAvailableTypes | ||||
| 			//  | ||||
| 			this.lblAvailableTypes.AutoSize = true; | ||||
| 			this.lblAvailableTypes.Location = new System.Drawing.Point(12, 43); | ||||
| 			this.lblAvailableTypes.Name = "lblAvailableTypes"; | ||||
| 			this.lblAvailableTypes.Size = new System.Drawing.Size(110, 16); | ||||
| 			this.lblAvailableTypes.TabIndex = 11; | ||||
| 			this.lblAvailableTypes.Text = "Types Available "; | ||||
| 			//  | ||||
| 			// lblSelected | ||||
| 			//  | ||||
| 			this.lblSelected.AutoSize = true; | ||||
| 			this.lblSelected.Location = new System.Drawing.Point(343, 43); | ||||
| 			this.lblSelected.Name = "lblSelected"; | ||||
| 			this.lblSelected.Size = new System.Drawing.Size(104, 16); | ||||
| 			this.lblSelected.TabIndex = 12; | ||||
| 			this.lblSelected.Text = "Types Selected"; | ||||
| 			//  | ||||
| 			// dlgAnnotationsSelect | ||||
| 			//  | ||||
| 			this.AutoScaleDimensions = new System.Drawing.SizeF(8F, 16F); | ||||
| 			this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | ||||
| 			this.ClientSize = new System.Drawing.Size(653, 466); | ||||
| 			this.Controls.Add(this.lblSelected); | ||||
| 			this.Controls.Add(this.lblAvailableTypes); | ||||
| 			this.Controls.Add(this.btnCancel); | ||||
| 			this.Controls.Add(this.tableLayoutPanel1); | ||||
| 			this.Controls.Add(this.btnUpdate); | ||||
| 			this.Controls.Add(this.lblMessage); | ||||
| 			this.Font = new System.Drawing.Font("Microsoft Sans Serif", 9.75F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
| 			this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog; | ||||
| 			this.Name = "dlgAnnotationsSelect"; | ||||
| 			this.Text = "Filter Annotation Types"; | ||||
| 			this.Load += new System.EventHandler(this.DlgAnnotationsSelect_Load); | ||||
| 			this.tableLayoutPanel1.ResumeLayout(false); | ||||
| 			this.ResumeLayout(false); | ||||
| 			this.PerformLayout(); | ||||
|  | ||||
| 		} | ||||
|  | ||||
| 		#endregion | ||||
| 		private System.Windows.Forms.ListBox lstUnselected; | ||||
| 		private System.Windows.Forms.ListBox lstSelected; | ||||
| 		private System.Windows.Forms.Button btnSelect; | ||||
| 		private System.Windows.Forms.Button btnSelectAll; | ||||
| 		private System.Windows.Forms.Button btnDeselectAll; | ||||
| 		private System.Windows.Forms.Button btnDeselect; | ||||
| 		private System.Windows.Forms.Button btnUpdate; | ||||
|  | ||||
| 		private System.Windows.Forms.TableLayoutPanel tableLayoutPanel1; | ||||
| 		private System.Windows.Forms.Button btnCancel; | ||||
| 		private System.Windows.Forms.Label lblMessage; | ||||
| 		private System.Windows.Forms.Label lblAvailableTypes; | ||||
| 		private System.Windows.Forms.Label lblSelected; | ||||
| 	} | ||||
| } | ||||
| @@ -65,11 +65,13 @@ namespace VEPROMS | ||||
| 			MyFrmVEPROMS = myFrmVEPROMS;// Save frmVEPROMS for Import to shutoff SessionPing | ||||
| 			_MyApproval = new ApprovalInfo(myFrmVEPROMS);// Save frmVEPROMS for Import to shutoff SessionPing | ||||
| 			ApplicabilityIndex = myDocVersion.DocVersionConfig.SelectedSlave; | ||||
| 			this.ConsistencyPrintRequest -= new DisplayConsistencyReportEvent(dlgApproveProcedure_ConsistencyPrintRequest); | ||||
| 			this.ConsistencyPrintRequest += new DisplayConsistencyReportEvent(dlgApproveProcedure_ConsistencyPrintRequest); | ||||
| 			_MyDocVersion = myDocVersion; | ||||
| 			_MyDocVersion.ResetProcedures();    // B2021-035: Pasted, modified number and deleted procedures not refreshed so missing from list | ||||
| 			InitializeComponent(); | ||||
| 			FlexGridAddEvents(); | ||||
| 			_MyApproval.StatusUpdated -= new ApprovalStatusChangeEvent(_MyApproval_StatusUpdated); | ||||
| 			_MyApproval.StatusUpdated += new ApprovalStatusChangeEvent(_MyApproval_StatusUpdated); | ||||
| 			SetupComboBoxes(); | ||||
| 			foreach (ProcedureInfo pi in myDocVersion.Procedures) | ||||
| @@ -101,6 +103,7 @@ namespace VEPROMS | ||||
| 			//fgProcs.SetupEditor += new C1.Win.C1FlexGrid.RowColEventHandler(fgProcs_SetupEditor); | ||||
| 			//fgProcs.StartEdit += new C1.Win.C1FlexGrid.RowColEventHandler(fgProcs_StartEdit); | ||||
| 			//fgProcs.ValidateEdit += new C1.Win.C1FlexGrid.ValidateEditEventHandler(fgProcs_ValidateEdit); | ||||
| 			fgProcs.ComboCloseUp -= new C1.Win.C1FlexGrid.RowColEventHandler(fgProcs_ComboCloseUp); | ||||
| 			fgProcs.ComboCloseUp += new C1.Win.C1FlexGrid.RowColEventHandler(fgProcs_ComboCloseUp); | ||||
| 			//fgProcs.MouseDown += new MouseEventHandler(fgProcs_MouseDown); | ||||
| 			//fgProcs.MouseUp += new MouseEventHandler(fgProcs_MouseUp);  | ||||
| @@ -275,6 +278,7 @@ namespace VEPROMS | ||||
| 		{ | ||||
| 			MyFrmVEPROMS = myFrmVEPROMS;// Save frmVEPROMS for Import to shutoff SessionPing | ||||
| 			_MyApproval = new ApprovalInfo(myFrmVEPROMS);// Save frmVEPROMS for Import to shutoff SessionPing | ||||
| 			this.ConsistencyPrintRequest -= new DisplayConsistencyReportEvent(dlgApproveProcedure_ConsistencyPrintRequest); | ||||
| 			this.ConsistencyPrintRequest += new DisplayConsistencyReportEvent(dlgApproveProcedure_ConsistencyPrintRequest); | ||||
| 			_MyDocVersion = myDocVersion; | ||||
| 			_MyDocVersion.ResetProcedures();    // B2021-035: Pasted, modified number and deleted procedures not refreshed so missing from list | ||||
| @@ -295,6 +299,7 @@ namespace VEPROMS | ||||
| 		{ | ||||
| 			MyFrmVEPROMS = myFrmVEPROMS;// Save frmVEPROMS for Import to shutoff SessionPing | ||||
| 			_MyApproval = new ApprovalInfo(myFrmVEPROMS);// Save frmVEPROMS for Import to shutoff SessionPing | ||||
| 			this.ConsistencyPrintRequest -= new DisplayConsistencyReportEvent(dlgApproveProcedure_ConsistencyPrintRequest); | ||||
| 			this.ConsistencyPrintRequest += new DisplayConsistencyReportEvent(dlgApproveProcedure_ConsistencyPrintRequest); | ||||
| 			_MyDocVersion = myProcedure.MyDocVersion; | ||||
| 			_MyDocVersion.ResetProcedures();    // B2021-035: Pasted, modified number and deleted procedures not refreshed so missing from list | ||||
| @@ -450,6 +455,7 @@ namespace VEPROMS | ||||
| 			int checkedCount = clbMore.CheckedItems.Count; | ||||
| 			string oldLabel = lblMore.Text; | ||||
| 			pbMore.Visible = true; | ||||
| 			ItemInfoList.ConsistencyCheckUpdated -= new ItemInfoListCCEvent(ItemInfoList_ConsistencyCheckUpdated); | ||||
| 			ItemInfoList.ConsistencyCheckUpdated += new ItemInfoListCCEvent(ItemInfoList_ConsistencyCheckUpdated); | ||||
| 			List<ProcedureInfo> myProcs = new List<ProcedureInfo>(); | ||||
| 			// B2018-136 use the list of procedures that have checkboxes and are checked (right panel) instead of the list to be approved (left panel) | ||||
| @@ -1303,7 +1309,7 @@ namespace VEPROMS | ||||
| 				pi.MyDocVersion.DocVersionConfig.SelectedSlave = 0; | ||||
| 				if (si.IsApproved == 1) | ||||
| 				{ | ||||
| 					dlgExportImport dlg = new dlgExportImport("Export", pi, MyFrmVEPROMS, (E_UCFImportOptions)0); // "true tell export to convert ROs and Transitions to text | ||||
| 					dlgExportImport dlg = new dlgExportImport("Export", pi, MyFrmVEPROMS, (selectedSlave)); // "true tell export to convert ROs and Transitions to text | ||||
| 					dlg.DocReplace = frm.DocReplace;  // this tells approval to prepare an export file with resolved transitions and ROs, word sections are saved with resolved ROs during approval PDF creation and saved in DocReplace | ||||
| 					System.Xml.XmlDocument xd = new System.Xml.XmlDocument(); | ||||
| 					dlg.ExportItem(xd, pi, "procedure"); | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										347
									
								
								PROMS/VEPROMS User Interface/dlgExportImportEP.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										347
									
								
								PROMS/VEPROMS User Interface/dlgExportImportEP.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,347 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.IO; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Text.RegularExpressions; | ||||
| using System.Xml; | ||||
| using VEPROMS.CSLA.Library; | ||||
|  | ||||
| namespace VEPROMS | ||||
| { | ||||
|     //C2025-024 Electronic Procedures - Phase 2 (PROMS XML output) | ||||
|     //class inherits from normal import/export form | ||||
|     //then adds additional functionality | ||||
| #pragma warning disable S101 // Types should be named in PascalCase | ||||
|     public partial class dlgExportImportEP : dlgExportImport | ||||
| #pragma warning restore S101 // Types should be named in PascalCase | ||||
| 	{ | ||||
| 		private readonly AnnotationTypeInfo _AnnotationType; | ||||
|         private readonly string multiseparator = ","; | ||||
|  | ||||
| 		private static Regex _ROAccPageTokenPattern = new Regex("[<][^<>-]+-[^<>]+[>]"); | ||||
|  | ||||
|         public dlgExportImportEP(string mode, FolderInfo folderInfo, frmVEPROMS myFrmVEPROMS, int annotationTypeId, int unitIndex = 0) : base(mode, folderInfo, myFrmVEPROMS, ( unitIndex)) | ||||
|         { | ||||
|             _AnnotationType = AnnotationTypeInfo.Get(annotationTypeId); | ||||
|             _ExportBothConvertedandNot = true; | ||||
|             DocReplace = new Dictionary<int, byte[]>(); | ||||
|             FormClosed += OnClose; | ||||
|             Text = $"{mode} Electronic Procedure ({_AnnotationType.Name}) Dialog for {folderInfo.Name}"; | ||||
| 		} | ||||
|         public dlgExportImportEP(string mode, DocVersionInfo docVersionInfo, frmVEPROMS myFrmVEPROMS, int annotationTypeId, int unitIndex = 0) : base(mode, docVersionInfo, myFrmVEPROMS, (unitIndex)) | ||||
|         { | ||||
|             _AnnotationType = AnnotationTypeInfo.Get(annotationTypeId); | ||||
|             _ExportBothConvertedandNot = true; | ||||
|             DocReplace = new Dictionary<int, byte[]>(); | ||||
|             FormClosed += OnClose; | ||||
|             Text = $"{mode} Electronic Procedure ({_AnnotationType.Name}) Dialog for {docVersionInfo.Name} of {docVersionInfo.MyFolder.Name}"; | ||||
| 		} | ||||
|         public dlgExportImportEP(string mode, ProcedureInfo procedureInfo, frmVEPROMS myFrmVEPROMS, int annotationTypeId, int unitIndex = 0) : base(mode, procedureInfo, myFrmVEPROMS, (unitIndex)) | ||||
| 		{ | ||||
| 			_AnnotationType = AnnotationTypeInfo.Get(annotationTypeId); | ||||
| 			_ExportBothConvertedandNot = true; | ||||
| 			DocReplace = new Dictionary<int, byte[]>(); | ||||
| 			FormClosed += OnClose; | ||||
| 			Text = $"{mode} Electronic Procedure ({_AnnotationType.Name}) Dialog for {procedureInfo.DisplayNumber}"; | ||||
| 		} | ||||
|  | ||||
| 		//Overridden function to handle export of EP data | ||||
| 		protected override void ExportEPAnnotationInfo(XmlElement xe, ItemInfo ii) | ||||
| 		{ | ||||
| 			if (_UnitIndex > 0) | ||||
|             { | ||||
| 				ii.MyDocVersion.DocVersionConfig.SelectedSlave = _UnitIndex; | ||||
| 				ii.MyProcedure.MyDocVersion.DocVersionConfig.SelectedSlave = _UnitIndex; | ||||
|             } | ||||
|  | ||||
|             //switch to handle customizations for different formats | ||||
|             switch (ii.ActiveFormat.PlantFormat.EPFormatFiles.Find(x => x.AnnotationTypeID == _AnnotationType.TypeID)?.Name) | ||||
| 			{ | ||||
| 				default: | ||||
| 					ExportEPAnnotationInfo_Default(xe, ii); | ||||
| 					break; | ||||
| 			} | ||||
|  | ||||
| 			ii.MyDocVersion.DocVersionConfig.SelectedSlave = 0; | ||||
| 			ii.MyProcedure.MyDocVersion.DocVersionConfig.SelectedSlave = 0; | ||||
|  | ||||
| 		} | ||||
|  | ||||
| 		//default export of EP Data | ||||
| 		private void ExportEPAnnotationInfo_Default(XmlElement xe, ItemInfo ii) | ||||
| 		{ | ||||
| 			//Add tab text to item | ||||
| 			string steptab = Volian.Print.Library.PDFReport.BuildStepTab(ii); | ||||
| 			xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "StepTab", steptab)); | ||||
|  | ||||
| 			//Add db sequence to item | ||||
| 			string dbsequence = dbSeq(ii); | ||||
| 			xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "dbsequence", dbsequence)); | ||||
|  | ||||
| 			//get first transition in item and add it as an xml element | ||||
| 			if (ii.MyContent.ContentTransitionCount > 0) | ||||
| 			{ | ||||
| 				TransitionInfo ct = ii.MyContent.ContentTransitions[0]; | ||||
| 				xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "TransitionToItemID", ct.ToID.ToString())); | ||||
| 				xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "TransitionTodbsequence", dbSeq(ct.ToID))); | ||||
| 			} | ||||
|  | ||||
| 			//export EP annotation details under an EPInfo node | ||||
| 			if (ii.ItemAnnotations != null) | ||||
| 			{ | ||||
| 				XmlElement xepinfo = xe.OwnerDocument.CreateElement("EPInfo"); | ||||
|  | ||||
| 				EPFields myEPFields = ii.GetValidEPFields(_AnnotationType.TypeID); | ||||
| 				ROFSTLookup lookup = ii.MyDocVersion.DocVersionAssociations[0].MyROFst.GetROFSTLookup(ii.MyDocVersion); | ||||
| 				bool epexportblank = ii.EPexportblank(_AnnotationType.TypeID); //should blank xml elements export? | ||||
|  | ||||
| 				//grab the current RO db so will know location of RO files and default graphics ext. | ||||
|                 using (RODbInfo myRODB = (RODbInfoList.Get()).FirstOrDefault(x => x.RODbID == ii.MyDocVersion.DocVersionAssociations[0].MyROFst.RODbID)) | ||||
|                 { | ||||
| 					//For each annotation in the item that is of the current EP Annotation type | ||||
| 					foreach (var EPAnnotation in ii.ItemAnnotations.Where(x => x.TypeID == _AnnotationType.TypeID)) | ||||
| 					{ | ||||
| 						var EPAnnotationConfig = new AnnotationConfig(EPAnnotation.Config); | ||||
|  | ||||
| 						XmlElement xepdetails = xe.OwnerDocument.CreateElement("Details"); | ||||
| 						//include the annotation ID for reference | ||||
| 						xepdetails.Attributes.SetNamedItem(AddAttribute(xepdetails.OwnerDocument, "AnnotationID", EPAnnotation.AnnotationID.ToString())); | ||||
|  | ||||
| 						//loop through each EP Field - name the xml elements the EP.name | ||||
| 						foreach (EPField EP in myEPFields) | ||||
| 						{ | ||||
| 							string val = EPAnnotationConfig.GetValue("EP", EP.name); | ||||
|  | ||||
| 							if (epexportblank || !string.IsNullOrEmpty(val)) | ||||
| 							{ | ||||
|  | ||||
| 								if (_UnitIndex != 0) | ||||
| 								{ | ||||
| 									val = DisplayText.ResolveUnitSpecific(ii.MyDocVersion, val); | ||||
| 								} | ||||
|  | ||||
| 								XmlElement xindivid = xe.OwnerDocument.CreateElement(EP.name); | ||||
|  | ||||
| 								//need to resolve ROs ROSingle, ROMulti, in text | ||||
| 								//get values | ||||
| 								switch (EP.type.ToLower()) | ||||
| 								{ | ||||
| 									case "text": | ||||
|  | ||||
| 										//for text, check if any embedded ROs | ||||
| 										//if none, set the xml element to the text | ||||
| 										//otherwise resolve the ROs | ||||
| 										MatchCollection matches = _ROAccPageTokenPattern.Matches(val); | ||||
| 										if (matches.Count == 0) | ||||
| 										{ | ||||
| 											xindivid.InnerText = val; | ||||
| 										} | ||||
| 										else | ||||
| 										{ | ||||
| 											//resolve ROs | ||||
| 											//text ROs will replace the AccID key in the text | ||||
| 											//for binary objects like images, | ||||
| 											//we will keep the AccID in the text and output the binary as a separate child | ||||
| 											//XML element with the same xml name as the AccID | ||||
| 											foreach (Match m in matches) | ||||
| 											{ | ||||
| 												ROFSTLookup.rochild roc = lookup.GetROChildByAccPageID(m.Groups[0].Value); | ||||
|  | ||||
| 												// Exclude replacing Images since are binary - for those, add a sub item | ||||
| 												if (Enumerable.Range(8, 15).Contains(roc.type)) | ||||
| 												{ | ||||
| 													xindivid.InnerText = val; | ||||
|  | ||||
| 													XmlElement xroid = AddGraphic(xindivid, m.Groups[0].Value, roc, myRODB, roc.type != 8); | ||||
|  | ||||
| 													xindivid.AppendChild(xroid); | ||||
| 												} | ||||
| 												else if (!string.IsNullOrEmpty(roc.value)) | ||||
| 												{ | ||||
| 													bool convertCaretToDeltaSymbol = (ii.ActiveSection != null) && ii.ActiveSection.ActiveFormat.PlantFormat.FormatData.SectData.ConvertCaretToDelta; | ||||
|  | ||||
| 													string rocvalue = roc.value.Replace("`", "\xB0"); | ||||
| 													rocvalue = rocvalue.Replace("\xF8", "\xB0"); | ||||
| 													rocvalue = rocvalue.Replace("\x7F", "\x394"); //delta | ||||
| 													if (convertCaretToDeltaSymbol) rocvalue = rocvalue.Replace("^", "\x394"); // delta | ||||
| 													val = val.Replace($"{m.Groups[0].Value}", rocvalue); | ||||
| 													xindivid.InnerText = val; | ||||
| 												} | ||||
| 											} | ||||
| 										} | ||||
| 										break; | ||||
| 									case "rosingle": | ||||
| 										//Get the output columns from the EPFormatFile | ||||
| 										//set the "Item" nodes value = to those resolved items | ||||
| 										//separated by multiseparator | ||||
| 										XmlElement xindivid_rosingle = xindivid.OwnerDocument.CreateElement("Item"); | ||||
| 										xindivid_rosingle.Attributes.SetNamedItem(AddAttribute(xindivid_rosingle.OwnerDocument, "ROID", val)); | ||||
|  | ||||
| 										//add values specified in EP input list | ||||
| 										List<string> ro_single_tmp = EP.getROValuesList(EPAnnotation, val); | ||||
| 										xindivid_rosingle.InnerText = String.Join(multiseparator, ro_single_tmp.ToArray()); | ||||
|  | ||||
| 										//if image, add location and binary of image | ||||
| 										// - images are type 8 | ||||
| 										//   but if multiple return values could combine | ||||
| 										//   for example an text (1) + image (8) would be 9 | ||||
| 										ROFSTLookup.rochild roc_single = lookup.GetRoChild(val); | ||||
| 										if (Enumerable.Range(8, 15).Contains(roc_single.type)) | ||||
| 										{ | ||||
| 											XmlElement xroid = AddGraphic(xindivid, val, roc_single, myRODB, roc_single.type != 8); | ||||
| 											xindivid_rosingle.AppendChild(xroid); | ||||
| 										} | ||||
|  | ||||
| 										xindivid.AppendChild(xindivid_rosingle); | ||||
| 										break; | ||||
| 									case "romulti": | ||||
| 										//Get the output columns from the EPFormatFile | ||||
| 										//create an "Item" subnode for each selected RO | ||||
| 										//set the nodes value = to those resolved items | ||||
| 										//separated by multiseparator | ||||
| 										foreach (string ival in val.Split(multiseparator.ToCharArray())) | ||||
| 										{ | ||||
| 											XmlElement xindivid_romulti = xindivid.OwnerDocument.CreateElement("Item"); | ||||
| 											xindivid_romulti.Attributes.SetNamedItem(AddAttribute(xindivid_romulti.OwnerDocument, "ROID", ival)); | ||||
|  | ||||
| 											//add values specified in EP input list | ||||
| 											List<string> ro_multi_tmp = EP.getROValuesList(EPAnnotation, ival); | ||||
| 											xindivid_romulti.InnerText = String.Join(multiseparator, ro_multi_tmp.ToArray()); | ||||
|  | ||||
| 											//if image, add location and binary of image | ||||
| 											// - images are type 8 | ||||
| 											//   but if multiple return values could combine | ||||
| 											//   for example an text (1) + image (8) would be 9 | ||||
| 											ROFSTLookup.rochild roc_multi = lookup.GetRoChild(ival); | ||||
| 											if (Enumerable.Range(8, 15).Contains(roc_multi.type)) | ||||
| 											{ | ||||
| 												XmlElement xroid = AddGraphic(xindivid, ival, roc_multi, myRODB, roc_multi.type != 8); | ||||
| 												xindivid_romulti.AppendChild(xroid); | ||||
| 											} | ||||
|  | ||||
| 											xindivid.AppendChild(xindivid_romulti); | ||||
| 										} | ||||
| 										break; | ||||
| 									case "tableinput": | ||||
| 										xindivid.InnerText = val; | ||||
| 										break; | ||||
| 									default: | ||||
| 										xindivid.InnerText = val; | ||||
| 										break; | ||||
| 								} | ||||
| 								xepdetails.AppendChild(xindivid); | ||||
| 							} | ||||
| 						} | ||||
| 						xepinfo.AppendChild(xepdetails); | ||||
| 					} | ||||
|  | ||||
| 				} | ||||
|  | ||||
| 				xe.AppendChild(xepinfo); | ||||
| 			} | ||||
|  | ||||
| 		} | ||||
|  | ||||
| 		//return a db sequence string from an Item ID | ||||
| 		private string dbSeq(int itemID) | ||||
| 		{ | ||||
| 			using (ItemInfo ii = ItemInfo.Get(itemID)) | ||||
|             { | ||||
| 				return dbSeq(ii); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
|         //return a db sequence string from an ItemInfo | ||||
|         private string dbSeq(ItemInfo ii) => $"{((FolderInfo)ii.MyDocVersion.ActiveParent).Name}:{ii.MyProcedure.DisplayNumber} {ii.MyProcedure.DisplayText}:{ii.DBSequence}"; | ||||
|  | ||||
|         //For Exporting an RO that is an image | ||||
|         //returns the Location and FileName of the RO Image | ||||
|         private string GetROImageFileLocation(ROFSTLookup.rochild roc, RODbInfo rodb, bool isMulti) | ||||
| 		{ | ||||
| 			string rodbpath = rodb.FolderPath; | ||||
|  | ||||
| 			string rocval = roc.value; | ||||
| 			if (rocval == null) rocval = Array.Find(roc.children, x => x.value.Contains('.')).value; | ||||
|  | ||||
| 			if (rocval == null) return ""; | ||||
| 			string imgname; | ||||
| 			if (isMulti) | ||||
| 			{ | ||||
| 				imgname = rocval.Substring(rocval.IndexOf(' ') + 1, rocval.IndexOf("\r\n") - rocval.IndexOf(' ') - 1); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				imgname = rocval.Substring(0, rocval.IndexOf('\n')); | ||||
| 			} | ||||
| 			int thedot = imgname.LastIndexOf('.'); | ||||
| 			string fname = imgname; | ||||
| 			if (thedot == -1 || (thedot != (imgname.Length - 4))) | ||||
| 			{ | ||||
| 				RODbConfig roDbCfg = new RODbConfig(rodb.Config); | ||||
| 				fname += string.Format(".{0}", roDbCfg.GetDefaultGraphicExtension()); | ||||
| 			} | ||||
|  | ||||
| 			string imgfile = Path.Combine(rodbpath, fname); | ||||
| 			return imgfile; | ||||
| 		} | ||||
|  | ||||
| 		//For Exporting an RO that is an image | ||||
| 		//returns an xmlElement | ||||
| 		// - that is a child to xindivid | ||||
| 		// - that has a name of Name | ||||
| 		// - that has a value of the binary representation of the image | ||||
| 		// - that has an attribute designating the location of the image file | ||||
| 		private XmlElement AddGraphic(XmlElement xindivid, string Name, ROFSTLookup.rochild roc, RODbInfo rodb, bool isMulti) | ||||
| 		{ | ||||
|             Name = Name.Replace("<", "").Replace(">", ""); | ||||
|  | ||||
| 			XmlElement xroid = xindivid.OwnerDocument.CreateElement(Name); | ||||
|  | ||||
| 			string imgfile = GetROImageFileLocation(roc, rodb, isMulti); | ||||
| 			if (string.IsNullOrEmpty(imgfile)) return xroid; | ||||
| 			xroid.Attributes.SetNamedItem(AddAttribute(xroid.OwnerDocument, "Location", imgfile)); | ||||
|  | ||||
| 			if (File.Exists(imgfile)) | ||||
| 			{ | ||||
| 				using (FileStream fsIn = new FileStream(imgfile, FileMode.Open, FileAccess.Read, FileShare.Read)) | ||||
| 				{ | ||||
| 					// Create an instance of StreamReader that can read characters from the FileStream. | ||||
| 					using (BinaryReader r = new BinaryReader(fsIn)) | ||||
| 						xroid.InnerText = Encoding.Default.GetString(r.ReadBytes((int)fsIn.Length)); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			return xroid; | ||||
| 		} | ||||
|  | ||||
| 		//overridden - used to set the RO location for RO Images that are not in annotations | ||||
| 		protected override void SetROLocation(ref XmlElement xindivid, ROFSTLookup.rochild roc, RODbInfo rodb, bool isMulti) | ||||
| 		{ | ||||
| 			string imgfile = GetROImageFileLocation(roc, rodb, isMulti); | ||||
| 			if (!string.IsNullOrEmpty(imgfile)) xindivid.Attributes.SetNamedItem(AddAttribute(xindivid.OwnerDocument, "Location", imgfile)); | ||||
| 		} | ||||
|  | ||||
| 		//overridden - used to set specific enhanced doc info | ||||
| 		protected override void SetEPEnhancedDocLinks(ref XmlElement xe, ItemInfo ii) | ||||
| 		{ | ||||
| 			EnhancedDocuments eds = ii.GetMyEnhancedDocuments(); | ||||
|  | ||||
| 			if (eds != null && eds.Count == 1) | ||||
| 			{ | ||||
| 				xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "EnhancedDocType", eds[0].Type.ToString())); | ||||
| 				xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "EnhancedDocToItemID", eds[0].ItemID.ToString())); | ||||
| 				xe.Attributes.SetNamedItem(AddAttribute(xe.OwnerDocument, "EnhancedDocToDbSeq", dbSeq(eds[0].ItemID))); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		//clear objects to release memory | ||||
| 		private void OnClose(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			DocReplace.Clear(); | ||||
| 			DocReplace = null; | ||||
| 		} | ||||
|  | ||||
|  | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										100
									
								
								PROMS/VEPROMS User Interface/dlgMSWordMessage.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								PROMS/VEPROMS User Interface/dlgMSWordMessage.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
|  | ||||
| namespace VEPROMS | ||||
| { | ||||
|     partial class dlgMSWordMessage | ||||
|     { | ||||
|         /// <summary> | ||||
|         /// Required designer variable. | ||||
|         /// </summary> | ||||
|         private System.ComponentModel.IContainer components = null; | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Clean up any resources being used. | ||||
|         /// </summary> | ||||
|         /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param> | ||||
|         protected override void Dispose(bool disposing) | ||||
|         { | ||||
|             if (disposing && (components != null)) | ||||
|             { | ||||
|                 components.Dispose(); | ||||
|             } | ||||
|             base.Dispose(disposing); | ||||
|         } | ||||
|  | ||||
|         #region Windows Form Designer generated code | ||||
|  | ||||
|         /// <summary> | ||||
|         /// Required method for Designer support - do not modify | ||||
|         /// the contents of this method with the code editor. | ||||
|         /// </summary> | ||||
|         private void InitializeComponent() | ||||
|         { | ||||
|             this.labelX1 = new DevComponents.DotNetBar.LabelX(); | ||||
|             this.cbRemember = new DevComponents.DotNetBar.Controls.CheckBoxX(); | ||||
|             this.btnOpenTabs = new DevComponents.DotNetBar.ButtonX(); | ||||
|             this.SuspendLayout(); | ||||
|             //  | ||||
|             // labelX1 | ||||
|             //  | ||||
|             //  | ||||
|             //  | ||||
|             //  | ||||
|             this.labelX1.BackgroundStyle.CornerType = DevComponents.DotNetBar.eCornerType.Square; | ||||
|             this.labelX1.Font = new System.Drawing.Font("Microsoft Sans Serif", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
|             this.labelX1.Location = new System.Drawing.Point(20, 12); | ||||
|             this.labelX1.Name = "labelX1"; | ||||
|             this.labelX1.Size = new System.Drawing.Size(520, 78); | ||||
|             this.labelX1.TabIndex = 0; | ||||
|             this.labelX1.Text = "The _______________ will be opened in MS Word.\r\n\r\nYou can make modifications and " + | ||||
|     "copy it into a PROMS Word section."; | ||||
|             this.labelX1.WordWrap = true; | ||||
|             //  | ||||
|             // cbRemember | ||||
|             //  | ||||
|             //  | ||||
|             //  | ||||
|             //  | ||||
|             this.cbRemember.BackgroundStyle.CornerType = DevComponents.DotNetBar.eCornerType.Square; | ||||
|             this.cbRemember.Location = new System.Drawing.Point(12, 96); | ||||
|             this.cbRemember.Name = "cbRemember"; | ||||
|             this.cbRemember.Size = new System.Drawing.Size(566, 55); | ||||
|             this.cbRemember.Style = DevComponents.DotNetBar.eDotNetBarStyle.StyleManagerControlled; | ||||
|             this.cbRemember.TabIndex = 1; | ||||
|             this.cbRemember.Text = "Check this box to not be prompted in the future when generating summaries that wi" + | ||||
|     "ll be opened in MS Word. \r\n\nNote that these settings can be adjusted at any time" + | ||||
|     " from the OPTIONS menu for PROMS."; | ||||
|             //  | ||||
|             // btnOpenTabs | ||||
|             //  | ||||
|             this.btnOpenTabs.AccessibleRole = System.Windows.Forms.AccessibleRole.PushButton; | ||||
|             this.btnOpenTabs.ColorTable = DevComponents.DotNetBar.eButtonColor.OrangeWithBackground; | ||||
|             this.btnOpenTabs.DialogResult = System.Windows.Forms.DialogResult.Yes; | ||||
|             this.btnOpenTabs.Location = new System.Drawing.Point(490, 126); | ||||
|             this.btnOpenTabs.Name = "btnOpenTabs"; | ||||
|             this.btnOpenTabs.Size = new System.Drawing.Size(64, 25); | ||||
|             this.btnOpenTabs.Style = DevComponents.DotNetBar.eDotNetBarStyle.StyleManagerControlled; | ||||
|             this.btnOpenTabs.TabIndex = 2; | ||||
|             this.btnOpenTabs.Text = "OK"; | ||||
|             this.btnOpenTabs.Click += new System.EventHandler(this.btnTabs_Click); | ||||
|             //  | ||||
|             // dlgMSWordMessage | ||||
|             //  | ||||
|             this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); | ||||
|             this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; | ||||
|             this.ClientSize = new System.Drawing.Size(567, 163); | ||||
|             this.ControlBox = false; | ||||
|             this.Controls.Add(this.btnOpenTabs); | ||||
|             this.Controls.Add(this.cbRemember); | ||||
|             this.Controls.Add(this.labelX1); | ||||
|             this.Name = "dlgMSWordMessage"; | ||||
|             this.ResumeLayout(false); | ||||
|  | ||||
|         } | ||||
|  | ||||
|         #endregion | ||||
|  | ||||
|         private DevComponents.DotNetBar.LabelX labelX1; | ||||
|         private DevComponents.DotNetBar.Controls.CheckBoxX cbRemember; | ||||
|         private DevComponents.DotNetBar.ButtonX btnOpenTabs; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										45
									
								
								PROMS/VEPROMS User Interface/dlgMSWordMessage.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								PROMS/VEPROMS User Interface/dlgMSWordMessage.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.ComponentModel; | ||||
| using System.Data; | ||||
| using System.Drawing; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
| using System.Windows.Forms; | ||||
| using VEPROMS.CSLA.Library; | ||||
| using Volian.Base.Library; | ||||
|  | ||||
| namespace VEPROMS | ||||
| { | ||||
|     public partial class dlgMSWordMessage : Form | ||||
|     { | ||||
|         //C2025-013 - Allow not continuously generate message that opening Summaries in MS Word | ||||
|         //typeofitem will be: Continuous Action/Time Critical Action | ||||
|         public dlgMSWordMessage(string typeofitem) | ||||
|         { | ||||
|             InitializeComponent(); | ||||
|             Text = $"{typeofitem} Summary"; | ||||
|             labelX1.Text = $"The {typeofitem} Summary will be opened in MS Word.\n\nYou can make modifications and copy it into a PROMS Word section."; | ||||
|         } | ||||
|  | ||||
|         public bool ShouldDisplay() | ||||
|         { | ||||
|             UserSettings usersettings = new UserSettings(VlnSettings.UserID); | ||||
|             return usersettings.UserSetting_MSWord_Summary_Prompt; | ||||
|         } | ||||
|  | ||||
|         private void btnTabs_Click(object sender, EventArgs e) | ||||
|         { | ||||
|             //if checkbox was checked in form, then update User Settings in database | ||||
|             if (cbRemember.Checked) | ||||
|             { | ||||
|                 UserSettings usersettings = new UserSettings(VlnSettings.UserID); | ||||
|                 usersettings.SetUserSetting_MSWord_Summary_Prompt(false); | ||||
|             } | ||||
|  | ||||
|             this.Close(); | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -112,9 +112,9 @@ | ||||
|     <value>2.0</value> | ||||
|   </resheader> | ||||
|   <resheader name="reader"> | ||||
|     <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|     <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|   </resheader> | ||||
|   <resheader name="writer"> | ||||
|     <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|     <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value> | ||||
|   </resheader> | ||||
| </root> | ||||
| @@ -30,10 +30,7 @@ namespace VEPROMS | ||||
| 		{ | ||||
|             this.components = new System.ComponentModel.Container(); | ||||
|             this.tcSecurity = new System.Windows.Forms.TabControl(); | ||||
| 			this.tpGroupUsers = new System.Windows.Forms.TabPage(); | ||||
| 			this.pnlMembers = new System.Windows.Forms.Panel(); | ||||
| 			this.lstMembers = new System.Windows.Forms.ListBox(); | ||||
| 			this.lblMembers = new System.Windows.Forms.Label(); | ||||
|             this.tpManageFolders = new System.Windows.Forms.TabPage(); | ||||
|             this.label6 = new System.Windows.Forms.Label(); | ||||
|             this.tvFolders = new System.Windows.Forms.TreeView(); | ||||
|             this.cmFolders = new System.Windows.Forms.ContextMenuStrip(this.components); | ||||
| @@ -41,10 +38,23 @@ namespace VEPROMS | ||||
|             this.createWriterGroupToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
|             this.createROEToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
|             this.createReviewerGroupToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
| 			this.lstUsers = new System.Windows.Forms.ListBox(); | ||||
| 			this.label5 = new System.Windows.Forms.Label(); | ||||
|             this.tpManageGroups = new System.Windows.Forms.TabPage(); | ||||
|             this.btnAddMember = new System.Windows.Forms.Button(); | ||||
|             this.btnRemoveMember = new System.Windows.Forms.Button(); | ||||
|             this.label1 = new System.Windows.Forms.Label(); | ||||
|             this.lbNonMembers = new System.Windows.Forms.Label(); | ||||
|             this.btnDeleteGroup = new System.Windows.Forms.Button(); | ||||
|             this.cbGroupSelection = new System.Windows.Forms.ComboBox(); | ||||
|             this.lstNonMembers = new System.Windows.Forms.ListBox(); | ||||
|             this.pnlMembers = new System.Windows.Forms.Panel(); | ||||
|             this.lstMembers = new System.Windows.Forms.ListBox(); | ||||
|             this.lblMembers = new System.Windows.Forms.Label(); | ||||
|             this.label3 = new System.Windows.Forms.Label(); | ||||
|             this.tpManageUsers = new System.Windows.Forms.TabPage(); | ||||
|             this.lblUserGroups = new System.Windows.Forms.Label(); | ||||
|             this.lstGroups = new System.Windows.Forms.ListBox(); | ||||
|             this.lstUsers = new System.Windows.Forms.ListBox(); | ||||
|             this.lblUsers = new System.Windows.Forms.Label(); | ||||
|             this.tpDefault = new System.Windows.Forms.TabPage(); | ||||
|             this.label8 = new System.Windows.Forms.Label(); | ||||
|             this.pnlGroups = new System.Windows.Forms.Panel(); | ||||
| @@ -54,23 +64,22 @@ namespace VEPROMS | ||||
|             this.addUserToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
|             this.editUserToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
|             this.deleteUserToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
| 			this.addMemberToolStripMenuItemUser = new System.Windows.Forms.ToolStripMenuItem(); | ||||
| 			this.cmGroups = new System.Windows.Forms.ContextMenuStrip(this.components); | ||||
| 			this.deleteGroupToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); | ||||
| 			this.addMemberToolStripMenuItemGroup = new System.Windows.Forms.ToolStripMenuItem(); | ||||
|             this.tt = new System.Windows.Forms.ToolTip(this.components); | ||||
|             this.tcSecurity.SuspendLayout(); | ||||
| 			this.tpGroupUsers.SuspendLayout(); | ||||
| 			this.pnlMembers.SuspendLayout(); | ||||
|             this.tpManageFolders.SuspendLayout(); | ||||
|             this.cmFolders.SuspendLayout(); | ||||
|             this.tpManageGroups.SuspendLayout(); | ||||
|             this.pnlMembers.SuspendLayout(); | ||||
|             this.tpManageUsers.SuspendLayout(); | ||||
|             this.tpDefault.SuspendLayout(); | ||||
| 			this.cmMembers.SuspendLayout(); | ||||
|             this.cmUsers.SuspendLayout(); | ||||
| 			this.cmGroups.SuspendLayout(); | ||||
|             this.SuspendLayout(); | ||||
|             //  | ||||
|             // tcSecurity | ||||
|             //  | ||||
| 			this.tcSecurity.Controls.Add(this.tpGroupUsers); | ||||
|             this.tcSecurity.Controls.Add(this.tpManageFolders); | ||||
|             this.tcSecurity.Controls.Add(this.tpManageGroups); | ||||
|             this.tcSecurity.Controls.Add(this.tpManageUsers); | ||||
|             this.tcSecurity.Controls.Add(this.tpDefault); | ||||
|             this.tcSecurity.Dock = System.Windows.Forms.DockStyle.Fill; | ||||
|             this.tcSecurity.Location = new System.Drawing.Point(0, 0); | ||||
| @@ -78,69 +87,38 @@ namespace VEPROMS | ||||
|             this.tcSecurity.SelectedIndex = 0; | ||||
|             this.tcSecurity.Size = new System.Drawing.Size(784, 564); | ||||
|             this.tcSecurity.TabIndex = 0; | ||||
|             this.tcSecurity.SelectedIndexChanged += new System.EventHandler(this.changedTab); | ||||
|             //  | ||||
| 			// tpGroupUsers | ||||
|             // tpManageFolders | ||||
|             //  | ||||
| 			this.tpGroupUsers.BackColor = System.Drawing.SystemColors.ButtonFace; | ||||
| 			this.tpGroupUsers.Controls.Add(this.pnlMembers); | ||||
| 			this.tpGroupUsers.Controls.Add(this.label6); | ||||
| 			this.tpGroupUsers.Controls.Add(this.tvFolders); | ||||
| 			this.tpGroupUsers.Controls.Add(this.lstUsers); | ||||
| 			this.tpGroupUsers.Controls.Add(this.label5); | ||||
| 			this.tpGroupUsers.Controls.Add(this.label3); | ||||
| 			this.tpGroupUsers.Controls.Add(this.lstGroups); | ||||
| 			this.tpGroupUsers.Location = new System.Drawing.Point(4, 22); | ||||
| 			this.tpGroupUsers.Name = "tpGroupUsers"; | ||||
| 			this.tpGroupUsers.Padding = new System.Windows.Forms.Padding(3); | ||||
| 			this.tpGroupUsers.Size = new System.Drawing.Size(776, 538); | ||||
| 			this.tpGroupUsers.TabIndex = 2; | ||||
| 			this.tpGroupUsers.Text = "Folders, Groups and Users"; | ||||
| 			//  | ||||
| 			// pnlMembers | ||||
| 			//  | ||||
| 			this.pnlMembers.Controls.Add(this.lstMembers); | ||||
| 			this.pnlMembers.Controls.Add(this.lblMembers); | ||||
| 			this.pnlMembers.Location = new System.Drawing.Point(384, 304); | ||||
| 			this.pnlMembers.Name = "pnlMembers"; | ||||
| 			this.pnlMembers.Size = new System.Drawing.Size(386, 232); | ||||
| 			this.pnlMembers.TabIndex = 12; | ||||
| 			//  | ||||
| 			// lstMembers | ||||
| 			//  | ||||
| 			this.lstMembers.Dock = System.Windows.Forms.DockStyle.Fill; | ||||
| 			this.lstMembers.FormattingEnabled = true; | ||||
| 			this.lstMembers.Location = new System.Drawing.Point(0, 19); | ||||
| 			this.lstMembers.Name = "lstMembers"; | ||||
| 			this.lstMembers.SelectionMode = System.Windows.Forms.SelectionMode.MultiExtended; | ||||
| 			this.lstMembers.Size = new System.Drawing.Size(386, 212); | ||||
| 			this.lstMembers.TabIndex = 10; | ||||
| 			this.lstMembers.MouseUp += new System.Windows.Forms.MouseEventHandler(this.lstMembers_MouseUp); | ||||
| 			//  | ||||
| 			// lblMembers | ||||
| 			//  | ||||
| 			this.lblMembers.Dock = System.Windows.Forms.DockStyle.Top; | ||||
| 			this.lblMembers.Location = new System.Drawing.Point(0, 0); | ||||
| 			this.lblMembers.Name = "lblMembers"; | ||||
| 			this.lblMembers.Size = new System.Drawing.Size(386, 19); | ||||
| 			this.lblMembers.TabIndex = 2; | ||||
| 			this.lblMembers.Text = "Members"; | ||||
|             this.tpManageFolders.BackColor = System.Drawing.SystemColors.ButtonFace; | ||||
|             this.tpManageFolders.Controls.Add(this.label6); | ||||
|             this.tpManageFolders.Controls.Add(this.tvFolders); | ||||
|             this.tpManageFolders.Location = new System.Drawing.Point(4, 22); | ||||
|             this.tpManageFolders.Name = "tpManageFolders"; | ||||
|             this.tpManageFolders.Padding = new System.Windows.Forms.Padding(3); | ||||
|             this.tpManageFolders.Size = new System.Drawing.Size(776, 538); | ||||
|             this.tpManageFolders.TabIndex = 2; | ||||
|             this.tpManageFolders.Text = "Manage Folders / Add Groups"; | ||||
|             //  | ||||
|             // label6 | ||||
|             //  | ||||
|             this.label6.AutoSize = true; | ||||
|             this.label6.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.75F, ((System.Drawing.FontStyle)((System.Drawing.FontStyle.Bold | System.Drawing.FontStyle.Underline))), System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
|             this.label6.Location = new System.Drawing.Point(8, 5); | ||||
|             this.label6.Name = "label6"; | ||||
| 			this.label6.Size = new System.Drawing.Size(41, 13); | ||||
|             this.label6.Size = new System.Drawing.Size(55, 15); | ||||
|             this.label6.TabIndex = 7; | ||||
|             this.label6.Text = "Folders"; | ||||
|             //  | ||||
|             // tvFolders | ||||
|             //  | ||||
|             this.tvFolders.ContextMenuStrip = this.cmFolders; | ||||
|             this.tvFolders.Dock = System.Windows.Forms.DockStyle.Bottom; | ||||
|             this.tvFolders.HideSelection = false; | ||||
| 			this.tvFolders.Location = new System.Drawing.Point(8, 21); | ||||
|             this.tvFolders.Location = new System.Drawing.Point(3, 32); | ||||
|             this.tvFolders.Name = "tvFolders"; | ||||
| 			this.tvFolders.Size = new System.Drawing.Size(370, 511); | ||||
|             this.tvFolders.Size = new System.Drawing.Size(770, 503); | ||||
|             this.tvFolders.TabIndex = 6; | ||||
|             this.tvFolders.NodeMouseClick += new System.Windows.Forms.TreeNodeMouseClickEventHandler(this.tvFolders_NodeMouseClick); | ||||
|             //  | ||||
| @@ -182,49 +160,189 @@ namespace VEPROMS | ||||
|             this.createReviewerGroupToolStripMenuItem.Text = "Create a Reviewer Group"; | ||||
|             this.createReviewerGroupToolStripMenuItem.Click += new System.EventHandler(this.createGroupMenuItem); | ||||
|             //  | ||||
| 			// lstUsers | ||||
|             // tpManageGroups | ||||
|             //  | ||||
| 			this.lstUsers.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) | ||||
| 									| System.Windows.Forms.AnchorStyles.Left))); | ||||
| 			this.lstUsers.FormattingEnabled = true; | ||||
| 			this.lstUsers.Location = new System.Drawing.Point(630, 21); | ||||
| 			this.lstUsers.Name = "lstUsers"; | ||||
| 			this.lstUsers.SelectionMode = System.Windows.Forms.SelectionMode.MultiExtended; | ||||
| 			this.lstUsers.Size = new System.Drawing.Size(140, 277); | ||||
| 			this.lstUsers.TabIndex = 5; | ||||
| 			this.lstUsers.MouseUp += new System.Windows.Forms.MouseEventHandler(this.lstUsers_MouseUp); | ||||
| 			this.lstUsers.SelectedIndexChanged += new System.EventHandler(this.lstUsers_SelectedIndexChanged); | ||||
|             this.tpManageGroups.Controls.Add(this.btnAddMember); | ||||
|             this.tpManageGroups.Controls.Add(this.btnRemoveMember); | ||||
|             this.tpManageGroups.Controls.Add(this.label1); | ||||
|             this.tpManageGroups.Controls.Add(this.lbNonMembers); | ||||
|             this.tpManageGroups.Controls.Add(this.btnDeleteGroup); | ||||
|             this.tpManageGroups.Controls.Add(this.cbGroupSelection); | ||||
|             this.tpManageGroups.Controls.Add(this.lstNonMembers); | ||||
|             this.tpManageGroups.Controls.Add(this.pnlMembers); | ||||
|             this.tpManageGroups.Controls.Add(this.label3); | ||||
|             this.tpManageGroups.Location = new System.Drawing.Point(4, 22); | ||||
|             this.tpManageGroups.Name = "tpManageGroups"; | ||||
|             this.tpManageGroups.Padding = new System.Windows.Forms.Padding(3); | ||||
|             this.tpManageGroups.Size = new System.Drawing.Size(776, 538); | ||||
|             this.tpManageGroups.TabIndex = 3; | ||||
|             this.tpManageGroups.Text = "Manage Groups"; | ||||
|             this.tpManageGroups.UseVisualStyleBackColor = true; | ||||
|             //  | ||||
| 			// label5 | ||||
|             // btnAddMember | ||||
|             //  | ||||
| 			this.label5.AutoSize = true; | ||||
| 			this.label5.Location = new System.Drawing.Point(630, 6); | ||||
| 			this.label5.Name = "label5"; | ||||
| 			this.label5.Size = new System.Drawing.Size(34, 13); | ||||
| 			this.label5.TabIndex = 4; | ||||
| 			this.label5.Text = "Users"; | ||||
|             this.btnAddMember.Location = new System.Drawing.Point(337, 190); | ||||
|             this.btnAddMember.Name = "btnAddMember"; | ||||
|             this.btnAddMember.Size = new System.Drawing.Size(36, 29); | ||||
|             this.btnAddMember.TabIndex = 19; | ||||
|             this.btnAddMember.Text = "<<"; | ||||
|             this.tt.SetToolTip(this.btnAddMember, "Add User as Members of Group"); | ||||
|             this.btnAddMember.UseVisualStyleBackColor = true; | ||||
|             this.btnAddMember.Click += new System.EventHandler(this.addMember_Click); | ||||
|             //  | ||||
|             // btnRemoveMember | ||||
|             //  | ||||
|             this.btnRemoveMember.Location = new System.Drawing.Point(337, 254); | ||||
|             this.btnRemoveMember.Name = "btnRemoveMember"; | ||||
|             this.btnRemoveMember.Size = new System.Drawing.Size(36, 29); | ||||
|             this.btnRemoveMember.TabIndex = 18; | ||||
|             this.btnRemoveMember.Text = ">>"; | ||||
|             this.tt.SetToolTip(this.btnRemoveMember, "Remove User From Group"); | ||||
|             this.btnRemoveMember.UseVisualStyleBackColor = true; | ||||
|             this.btnRemoveMember.Click += new System.EventHandler(this.removeMember_Click); | ||||
|             //  | ||||
|             // label1 | ||||
|             //  | ||||
|             this.label1.AutoSize = true; | ||||
|             this.label1.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.75F, ((System.Drawing.FontStyle)((System.Drawing.FontStyle.Bold | System.Drawing.FontStyle.Underline))), System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
|             this.label1.Location = new System.Drawing.Point(386, 42); | ||||
|             this.label1.Name = "label1"; | ||||
|             this.label1.Size = new System.Drawing.Size(97, 15); | ||||
|             this.label1.TabIndex = 17; | ||||
|             this.label1.Text = "Non Members"; | ||||
|             //  | ||||
|             // lbNonMembers | ||||
|             //  | ||||
|             this.lbNonMembers.AutoSize = true; | ||||
|             this.lbNonMembers.Location = new System.Drawing.Point(386, 42); | ||||
|             this.lbNonMembers.Name = "lbNonMembers"; | ||||
|             this.lbNonMembers.Size = new System.Drawing.Size(73, 13); | ||||
|             this.lbNonMembers.TabIndex = 17; | ||||
|             this.lbNonMembers.Text = "Non Members"; | ||||
|             //  | ||||
|             // btnDeleteGroup | ||||
|             //  | ||||
|             this.btnDeleteGroup.ForeColor = System.Drawing.Color.Red; | ||||
|             this.btnDeleteGroup.Location = new System.Drawing.Point(668, 12); | ||||
|             this.btnDeleteGroup.Name = "btnDeleteGroup"; | ||||
|             this.btnDeleteGroup.Size = new System.Drawing.Size(89, 23); | ||||
|             this.btnDeleteGroup.TabIndex = 16; | ||||
|             this.btnDeleteGroup.Text = "Delete Group"; | ||||
|             this.btnDeleteGroup.UseVisualStyleBackColor = true; | ||||
|             this.btnDeleteGroup.Click += new System.EventHandler(this.deleteGroup_Click); | ||||
|             //  | ||||
|             // cbGroupSelection | ||||
|             //  | ||||
|             this.cbGroupSelection.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; | ||||
|             this.cbGroupSelection.FormattingEnabled = true; | ||||
|             this.cbGroupSelection.Location = new System.Drawing.Point(50, 9); | ||||
|             this.cbGroupSelection.Name = "cbGroupSelection"; | ||||
|             this.cbGroupSelection.Size = new System.Drawing.Size(272, 21); | ||||
|             this.cbGroupSelection.TabIndex = 15; | ||||
|             this.cbGroupSelection.SelectedIndexChanged += new System.EventHandler(this.cbGroupSelection_SelectedIndexChanged); | ||||
|             //  | ||||
|             // lstNonMembers | ||||
|             //  | ||||
|             this.lstNonMembers.FormattingEnabled = true; | ||||
|             this.lstNonMembers.Location = new System.Drawing.Point(389, 61); | ||||
|             this.lstNonMembers.Name = "lstNonMembers"; | ||||
|             this.lstNonMembers.Size = new System.Drawing.Size(316, 472); | ||||
|             this.lstNonMembers.TabIndex = 14; | ||||
|             //  | ||||
|             // pnlMembers | ||||
|             //  | ||||
|             this.pnlMembers.Controls.Add(this.lstMembers); | ||||
|             this.pnlMembers.Controls.Add(this.lblMembers); | ||||
|             this.pnlMembers.Location = new System.Drawing.Point(6, 42); | ||||
|             this.pnlMembers.Name = "pnlMembers"; | ||||
|             this.pnlMembers.Size = new System.Drawing.Size(316, 493); | ||||
|             this.pnlMembers.TabIndex = 13; | ||||
|             //  | ||||
|             // lstMembers | ||||
|             //  | ||||
|             this.lstMembers.Dock = System.Windows.Forms.DockStyle.Fill; | ||||
|             this.lstMembers.FormattingEnabled = true; | ||||
|             this.lstMembers.Location = new System.Drawing.Point(0, 19); | ||||
|             this.lstMembers.Name = "lstMembers"; | ||||
|             this.lstMembers.Size = new System.Drawing.Size(316, 474); | ||||
|             this.lstMembers.TabIndex = 10; | ||||
|             //  | ||||
|             // lblMembers | ||||
|             //  | ||||
|             this.lblMembers.Dock = System.Windows.Forms.DockStyle.Top; | ||||
|             this.lblMembers.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.75F, ((System.Drawing.FontStyle)((System.Drawing.FontStyle.Bold | System.Drawing.FontStyle.Underline))), System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
|             this.lblMembers.Location = new System.Drawing.Point(0, 0); | ||||
|             this.lblMembers.Name = "lblMembers"; | ||||
|             this.lblMembers.Size = new System.Drawing.Size(316, 19); | ||||
|             this.lblMembers.TabIndex = 2; | ||||
|             this.lblMembers.Text = "Selected Group Users"; | ||||
|             //  | ||||
|             // label3 | ||||
|             //  | ||||
|             this.label3.AutoSize = true; | ||||
| 			this.label3.Location = new System.Drawing.Point(381, 6); | ||||
|             this.label3.Location = new System.Drawing.Point(3, 12); | ||||
|             this.label3.Name = "label3"; | ||||
| 			this.label3.Size = new System.Drawing.Size(41, 13); | ||||
| 			this.label3.TabIndex = 1; | ||||
| 			this.label3.Text = "Groups"; | ||||
|             this.label3.Size = new System.Drawing.Size(39, 13); | ||||
|             this.label3.TabIndex = 3; | ||||
|             this.label3.Text = "Group:"; | ||||
|             //  | ||||
|             // tpManageUsers | ||||
|             //  | ||||
|             this.tpManageUsers.Controls.Add(this.lblUserGroups); | ||||
|             this.tpManageUsers.Controls.Add(this.lstGroups); | ||||
|             this.tpManageUsers.Controls.Add(this.lstUsers); | ||||
|             this.tpManageUsers.Controls.Add(this.lblUsers); | ||||
|             this.tpManageUsers.Location = new System.Drawing.Point(4, 22); | ||||
|             this.tpManageUsers.Name = "tpManageUsers"; | ||||
|             this.tpManageUsers.Size = new System.Drawing.Size(776, 538); | ||||
|             this.tpManageUsers.TabIndex = 4; | ||||
|             this.tpManageUsers.Text = "Manage Users"; | ||||
|             this.tpManageUsers.UseVisualStyleBackColor = true; | ||||
|             //  | ||||
|             // lblUserGroups | ||||
|             //  | ||||
|             this.lblUserGroups.AutoSize = true; | ||||
|             this.lblUserGroups.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.75F, ((System.Drawing.FontStyle)((System.Drawing.FontStyle.Bold | System.Drawing.FontStyle.Underline))), System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
|             this.lblUserGroups.Location = new System.Drawing.Point(268, 11); | ||||
|             this.lblUserGroups.Name = "lblUserGroups"; | ||||
|             this.lblUserGroups.Size = new System.Drawing.Size(225, 15); | ||||
|             this.lblUserGroups.TabIndex = 9; | ||||
|             this.lblUserGroups.Text = "Groups That User Is a Member Of:"; | ||||
|             //  | ||||
|             // lstGroups | ||||
|             //  | ||||
|             this.lstGroups.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)  | ||||
|             | System.Windows.Forms.AnchorStyles.Left))); | ||||
|             this.lstGroups.FormattingEnabled = true; | ||||
| 			this.lstGroups.Location = new System.Drawing.Point(384, 21); | ||||
|             this.lstGroups.Location = new System.Drawing.Point(271, 36); | ||||
|             this.lstGroups.Name = "lstGroups"; | ||||
|             this.lstGroups.SelectionMode = System.Windows.Forms.SelectionMode.MultiExtended; | ||||
| 			this.lstGroups.Size = new System.Drawing.Size(240, 277); | ||||
| 			this.lstGroups.TabIndex = 0; | ||||
|             this.lstGroups.Size = new System.Drawing.Size(502, 498); | ||||
|             this.lstGroups.TabIndex = 8; | ||||
|             this.lstGroups.MouseUp += new System.Windows.Forms.MouseEventHandler(this.lstGroups_MouseUp); | ||||
| 			this.lstGroups.SelectedIndexChanged += new System.EventHandler(this.lstGroups_SelectedIndexChanged); | ||||
|             //  | ||||
|             // lstUsers | ||||
|             //  | ||||
|             this.lstUsers.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)  | ||||
|             | System.Windows.Forms.AnchorStyles.Left))); | ||||
|             this.lstUsers.FormattingEnabled = true; | ||||
|             this.lstUsers.Location = new System.Drawing.Point(8, 36); | ||||
|             this.lstUsers.Name = "lstUsers"; | ||||
|             this.lstUsers.SelectionMode = System.Windows.Forms.SelectionMode.MultiExtended; | ||||
|             this.lstUsers.Size = new System.Drawing.Size(217, 498); | ||||
|             this.lstUsers.TabIndex = 7; | ||||
|             this.lstUsers.SelectedIndexChanged += new System.EventHandler(this.lstUsers_SelectedIndexChanged); | ||||
|             this.lstUsers.MouseUp += new System.Windows.Forms.MouseEventHandler(this.lstUsers_MouseUp); | ||||
|             //  | ||||
|             // lblUsers | ||||
|             //  | ||||
|             this.lblUsers.AutoSize = true; | ||||
|             this.lblUsers.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.75F, ((System.Drawing.FontStyle)((System.Drawing.FontStyle.Bold | System.Drawing.FontStyle.Underline))), System.Drawing.GraphicsUnit.Point, ((byte)(0))); | ||||
|             this.lblUsers.Location = new System.Drawing.Point(8, 11); | ||||
|             this.lblUsers.Name = "lblUsers"; | ||||
|             this.lblUsers.Size = new System.Drawing.Size(44, 15); | ||||
|             this.lblUsers.TabIndex = 6; | ||||
|             this.lblUsers.Text = "Users"; | ||||
|             //  | ||||
|             // tpDefault | ||||
|             //  | ||||
| @@ -256,10 +374,8 @@ namespace VEPROMS | ||||
|             //  | ||||
|             // cmMembers | ||||
|             //  | ||||
| 			this.cmMembers.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { | ||||
|             this.removeMemberToolStripMenuItem}); | ||||
|             this.cmMembers.Name = "cmGroupMembers"; | ||||
| 			this.cmMembers.Size = new System.Drawing.Size(166, 26); | ||||
|             this.cmMembers.Size = new System.Drawing.Size(61, 4); | ||||
|             //  | ||||
|             // removeMemberToolStripMenuItem | ||||
|             //  | ||||
| @@ -273,61 +389,31 @@ namespace VEPROMS | ||||
|             this.cmUsers.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { | ||||
|             this.addUserToolStripMenuItem, | ||||
|             this.editUserToolStripMenuItem, | ||||
|             this.deleteUserToolStripMenuItem, | ||||
|             this.addMemberToolStripMenuItemUser}); | ||||
|             this.deleteUserToolStripMenuItem}); | ||||
|             this.cmUsers.Name = "cmUsers"; | ||||
| 			this.cmUsers.Size = new System.Drawing.Size(153, 114); | ||||
|             this.cmUsers.Size = new System.Drawing.Size(145, 92); | ||||
|             //  | ||||
|             // addUserToolStripMenuItem | ||||
|             //  | ||||
|             this.addUserToolStripMenuItem.Name = "addUserToolStripMenuItem"; | ||||
| 			this.addUserToolStripMenuItem.Size = new System.Drawing.Size(152, 22); | ||||
|             this.addUserToolStripMenuItem.Size = new System.Drawing.Size(144, 22); | ||||
|             this.addUserToolStripMenuItem.Text = "Add User"; | ||||
|             this.addUserToolStripMenuItem.Click += new System.EventHandler(this.addUserToolStripMenuItem_Click); | ||||
|             //  | ||||
|             // editUserToolStripMenuItem | ||||
|             //  | ||||
|             this.editUserToolStripMenuItem.Name = "editUserToolStripMenuItem"; | ||||
| 			this.editUserToolStripMenuItem.Size = new System.Drawing.Size(152, 22); | ||||
|             this.editUserToolStripMenuItem.Size = new System.Drawing.Size(144, 22); | ||||
|             this.editUserToolStripMenuItem.Text = "Edit User"; | ||||
|             this.editUserToolStripMenuItem.Click += new System.EventHandler(this.editUserToolStripMenuItem_Click); | ||||
|             //  | ||||
|             // deleteUserToolStripMenuItem | ||||
|             //  | ||||
|             this.deleteUserToolStripMenuItem.Name = "deleteUserToolStripMenuItem"; | ||||
| 			this.deleteUserToolStripMenuItem.Size = new System.Drawing.Size(152, 22); | ||||
|             this.deleteUserToolStripMenuItem.Size = new System.Drawing.Size(144, 22); | ||||
|             this.deleteUserToolStripMenuItem.Text = "Delete User"; | ||||
|             this.deleteUserToolStripMenuItem.Click += new System.EventHandler(this.deleteUserToolStripMenuItem_Click); | ||||
|             //  | ||||
| 			// addMemberToolStripMenuItemUser | ||||
| 			//  | ||||
| 			this.addMemberToolStripMenuItemUser.Name = "addMemberToolStripMenuItemUser"; | ||||
| 			this.addMemberToolStripMenuItemUser.Size = new System.Drawing.Size(152, 22); | ||||
| 			this.addMemberToolStripMenuItemUser.Text = "Add Member"; | ||||
| 			this.addMemberToolStripMenuItemUser.Click += new System.EventHandler(this.addMemberToolStripMenuItem_Click); | ||||
| 			//  | ||||
| 			// cmGroups | ||||
| 			//  | ||||
| 			this.cmGroups.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { | ||||
|             this.deleteGroupToolStripMenuItem, | ||||
|             this.addMemberToolStripMenuItemGroup}); | ||||
| 			this.cmGroups.Name = "cmGroups"; | ||||
| 			this.cmGroups.Size = new System.Drawing.Size(145, 48); | ||||
| 			//  | ||||
| 			// deleteGroupToolStripMenuItem | ||||
| 			//  | ||||
| 			this.deleteGroupToolStripMenuItem.Name = "deleteGroupToolStripMenuItem"; | ||||
| 			this.deleteGroupToolStripMenuItem.Size = new System.Drawing.Size(144, 22); | ||||
| 			this.deleteGroupToolStripMenuItem.Text = "Delete Group"; | ||||
| 			this.deleteGroupToolStripMenuItem.Click += new System.EventHandler(this.deleteGroupToolStripMenuItem_Click); | ||||
| 			//  | ||||
| 			// addMemberToolStripMenuItemGroup | ||||
| 			//  | ||||
| 			this.addMemberToolStripMenuItemGroup.Name = "addMemberToolStripMenuItemGroup"; | ||||
| 			this.addMemberToolStripMenuItemGroup.Size = new System.Drawing.Size(144, 22); | ||||
| 			this.addMemberToolStripMenuItemGroup.Text = "Add Member"; | ||||
| 			this.addMemberToolStripMenuItemGroup.Click += new System.EventHandler(this.addMemberToolStripMenuItem_Click); | ||||
| 			//  | ||||
|             // dlgManageSecurity | ||||
|             //  | ||||
|             this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.None; | ||||
| @@ -341,14 +427,16 @@ namespace VEPROMS | ||||
|             this.Text = "Manage Security"; | ||||
|             this.Load += new System.EventHandler(this.dlgManageSecurity_Load); | ||||
|             this.tcSecurity.ResumeLayout(false); | ||||
| 			this.tpGroupUsers.ResumeLayout(false); | ||||
| 			this.tpGroupUsers.PerformLayout(); | ||||
| 			this.pnlMembers.ResumeLayout(false); | ||||
|             this.tpManageFolders.ResumeLayout(false); | ||||
|             this.tpManageFolders.PerformLayout(); | ||||
|             this.cmFolders.ResumeLayout(false); | ||||
|             this.tpManageGroups.ResumeLayout(false); | ||||
|             this.tpManageGroups.PerformLayout(); | ||||
|             this.pnlMembers.ResumeLayout(false); | ||||
|             this.tpManageUsers.ResumeLayout(false); | ||||
|             this.tpManageUsers.PerformLayout(); | ||||
|             this.tpDefault.ResumeLayout(false); | ||||
| 			this.cmMembers.ResumeLayout(false); | ||||
|             this.cmUsers.ResumeLayout(false); | ||||
| 			this.cmGroups.ResumeLayout(false); | ||||
|             this.ResumeLayout(false); | ||||
|  | ||||
| 		} | ||||
| @@ -357,13 +445,7 @@ namespace VEPROMS | ||||
|  | ||||
| 		private System.Windows.Forms.TabControl tcSecurity; | ||||
| 		private System.Windows.Forms.TabPage tpDefault; | ||||
| 		private System.Windows.Forms.TabPage tpGroupUsers; | ||||
| 		private System.Windows.Forms.ListBox lstGroups; | ||||
| 		private System.Windows.Forms.Label lblMembers; | ||||
| 		private System.Windows.Forms.Label label3; | ||||
| 		private System.Windows.Forms.ContextMenuStrip cmGroups; | ||||
| 		private System.Windows.Forms.ListBox lstUsers; | ||||
| 		private System.Windows.Forms.Label label5; | ||||
| 		private System.Windows.Forms.TabPage tpManageFolders; | ||||
| 		private System.Windows.Forms.ContextMenuStrip cmUsers; | ||||
| 		private System.Windows.Forms.ToolStripMenuItem addUserToolStripMenuItem; | ||||
| 		private System.Windows.Forms.ToolStripMenuItem editUserToolStripMenuItem; | ||||
| @@ -379,10 +461,23 @@ namespace VEPROMS | ||||
| 		private System.Windows.Forms.ToolStripMenuItem createReviewerGroupToolStripMenuItem; | ||||
| 		private System.Windows.Forms.Panel pnlGroups; | ||||
| 		private System.Windows.Forms.Label label8; | ||||
| 		private System.Windows.Forms.ToolStripMenuItem deleteGroupToolStripMenuItem; | ||||
|         private System.Windows.Forms.TabPage tpManageGroups; | ||||
|         private System.Windows.Forms.TabPage tpManageUsers; | ||||
|         private System.Windows.Forms.Panel pnlMembers; | ||||
|         private System.Windows.Forms.ListBox lstMembers; | ||||
| 		private System.Windows.Forms.ToolStripMenuItem addMemberToolStripMenuItemUser; | ||||
| 		private System.Windows.Forms.ToolStripMenuItem addMemberToolStripMenuItemGroup; | ||||
|         private System.Windows.Forms.Label lblMembers; | ||||
|         private System.Windows.Forms.ListBox lstUsers; | ||||
|         private System.Windows.Forms.Label lblUsers; | ||||
|         private System.Windows.Forms.Label label3; | ||||
|         private System.Windows.Forms.ComboBox cbGroupSelection; | ||||
|         private System.Windows.Forms.ListBox lstNonMembers; | ||||
|         private System.Windows.Forms.Button btnDeleteGroup; | ||||
|         private System.Windows.Forms.Label lbNonMembers; | ||||
|         private System.Windows.Forms.ListBox lstGroups; | ||||
|         private System.Windows.Forms.Button btnAddMember; | ||||
|         private System.Windows.Forms.Button btnRemoveMember; | ||||
|         private System.Windows.Forms.ToolTip tt; | ||||
|         private System.Windows.Forms.Label label1; | ||||
|         private System.Windows.Forms.Label lblUserGroups; | ||||
|     } | ||||
| } | ||||
| @@ -7,84 +7,85 @@ using System.Text; | ||||
| using System.Windows.Forms; | ||||
| using VEPROMS.CSLA.Library; | ||||
| using Volian.Base.Library; | ||||
| using Volian.Controls.Library; | ||||
| using System.Linq; | ||||
|  | ||||
|  | ||||
| namespace VEPROMS | ||||
| { | ||||
| 	//C2024-047 Redesign PROMS Security Dialog | ||||
| 	public partial class dlgManageSecurity : Form | ||||
| 	{ | ||||
| 		#region Log4Net | ||||
| 		private static readonly log4net.ILog _MyLog = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); | ||||
| 		#endregion | ||||
|  | ||||
| 		#region Main Form / Shared Code | ||||
| 		private GroupInfoList myGroupInfoList; | ||||
| 		private UserInfoList myUserInfoList; | ||||
| 		private List<MembershipInfo> myMembershipInfoList; | ||||
| 		private Folder myFolder; | ||||
|  | ||||
| 		public dlgManageSecurity() | ||||
| 		{ | ||||
| 			InitializeComponent(); | ||||
| 		} | ||||
| 		private void dlgManageSecurity_Load(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			//load all folders | ||||
| 			myFolder = Folder.Get(1); | ||||
| 			SetupSecurity(); | ||||
|  | ||||
| 			//Default to Users Tab | ||||
| 			tcSecurity.SelectedIndex = 2; | ||||
| 		} | ||||
|  | ||||
| 		//This is called when the Index Changes for main tab Control | ||||
| 		//it loads info for the current tab | ||||
| 		private void changedTab(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			LoadRefreshGroupUsers(); | ||||
|  | ||||
| 			switch (tcSecurity.SelectedIndex) | ||||
| 			{ | ||||
| 				//Manage Folders | ||||
| 				case 0: | ||||
| 					SetupFolderOptions(); | ||||
| 					break; | ||||
| 				//Manage Groups | ||||
| 				case 1: | ||||
| 					SetupGroups(); | ||||
| 					break; | ||||
| 				//Manage Users (note that this is the default) | ||||
| 				case 2: | ||||
| 					SetupUserOptions(); | ||||
| 					break; | ||||
|                 //Default Options tab | ||||
| 				case 3: | ||||
| 					SetupDefaultGroupOptions(); | ||||
| 					break; | ||||
| 			} | ||||
| 		private void SetupGroups() | ||||
| 		} | ||||
| 		//Loads a refreshed list of Groups and Users | ||||
| 		private void LoadRefreshGroupUsers() | ||||
| 		{ | ||||
| 			pnlGroups.Controls.Clear(); | ||||
| 			foreach (GroupInfo gi in myGroupInfoList) | ||||
| 			{ | ||||
| 				RadioButton rb = new RadioButton(); | ||||
| 				rb.Text = gi.GroupName; | ||||
| 				rb.Parent = pnlGroups; | ||||
| 				rb.Dock = DockStyle.Top; | ||||
| 				rb.Tag = gi; | ||||
| 				rb.CheckedChanged += new EventHandler(rb_CheckedChanged); | ||||
| 				pnlGroups.Controls.Add(rb); | ||||
| 				rb.BringToFront(); | ||||
| 				if (myFolder.FolderConfig.Security_Group == 0 && gi.GID == 1) | ||||
| 				{ | ||||
| 					myFolder.FolderConfig.Security_Group = gi.GID; | ||||
| 					rb.Checked = true; | ||||
| 					myFolder.Save(); | ||||
| 			GroupInfoList.Reset(); | ||||
| 			myGroupInfoList = GroupInfoList.Get(); | ||||
| 			UserInfoList.Reset(); | ||||
| 			myUserInfoList = UserInfoList.Get(); | ||||
| 		} | ||||
| 				else if (myFolder.FolderConfig.Security_Group == gi.GID) | ||||
| 				{ | ||||
| 					rb.Checked = true; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		private void rb_CheckedChanged(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			RadioButton rb = sender as RadioButton; | ||||
| 			GroupInfo gi = rb.Tag as GroupInfo; | ||||
| 			label8.Text = gi.GroupAssignments[0].MyRole.Title + " for " + gi.GroupAssignments[0].MyFolder.Name; | ||||
| 			myFolder.FolderConfig.Security_Group = gi.GID; | ||||
| 			myFolder.Save(); | ||||
| 		} | ||||
| 		private void SetupSecurity() | ||||
| 		#endregion | ||||
|  | ||||
| 		#region Manage Folders | ||||
| 		//Sets up Folders | ||||
| 		private void SetupFolderOptions() | ||||
| 		{ | ||||
| 			if (tvFolders.Nodes.Count == 0) | ||||
| 			{ | ||||
| 				FolderInfo fi = FolderInfo.Get(1); | ||||
| 				LoadChildFolders(fi, null); | ||||
| 			} | ||||
| 			lstMembers.Items.Clear(); | ||||
| 			lstUsers.Items.Clear(); | ||||
| 			lstGroups.Items.Clear(); | ||||
| 			GroupInfoList.Reset(); | ||||
| 			UserInfoList.Reset(); | ||||
| 			myGroupInfoList = GroupInfoList.Get(); | ||||
| 			myUserInfoList = UserInfoList.Get(); | ||||
| 			foreach (GroupInfo gi in myGroupInfoList) | ||||
| 				lstGroups.Items.Add(gi.GroupName); | ||||
| 			lstGroups.SelectedIndex = 0; | ||||
| 			foreach (UserInfo ui in myUserInfoList) | ||||
| 				lstUsers.Items.Add(ui.UserID); | ||||
| 			lstGroups.SelectedIndex = -1; | ||||
| 			lstUsers.SelectedIndex = -1; | ||||
| 		} | ||||
| 		//loads child folders in tree view | ||||
| 		private void LoadChildFolders(FolderInfo fi, TreeNode tn) | ||||
| 		{ | ||||
| 			if (tn == null) | ||||
| @@ -105,172 +106,7 @@ namespace VEPROMS | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		private void lstGroups_SelectedIndexChanged(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			lblMembers.Text = "Selected Group Users"; | ||||
| 			myMembershipInfoList = new List<MembershipInfo>(); | ||||
| 			lstMembers.Items.Clear(); | ||||
| 			if (lstGroups.SelectedIndex > -1) | ||||
| 			{ | ||||
| 				GroupInfo gi = myGroupInfoList[lstGroups.SelectedIndex]; | ||||
| 				if (gi.GroupMembershipCount > 0) | ||||
| 					foreach (MembershipInfo mi in gi.GroupMemberships) | ||||
| 					{ | ||||
| 						if (mi.EndDate == null || mi.EndDate == string.Empty) | ||||
| 						{ | ||||
| 							myMembershipInfoList.Add(mi); | ||||
| 							lstMembers.Items.Add(mi.MyUser.UserID); | ||||
| 						} | ||||
| 					} | ||||
| 			} | ||||
| 		} | ||||
| 		private void addMemberToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			int groupIndex = lstGroups.SelectedIndex; | ||||
| 			int userIndex = lstUsers.SelectedIndex; | ||||
| 			GroupInfo gi = myGroupInfoList[groupIndex]; | ||||
| 			UserInfo ui = myUserInfoList[userIndex]; | ||||
| 			Membership.MakeMembership(User.Get(ui.UID), Group.Get(gi.GID), null, ""); | ||||
| 			SetupSecurity(); | ||||
| 			if ((sender as ToolStripMenuItem).Name.EndsWith("Group")) | ||||
| 			{ | ||||
| 				lstUsers.SelectedIndex = userIndex; | ||||
| 				lstGroups.SelectedIndex = groupIndex; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				lstGroups.SelectedIndex = groupIndex; | ||||
| 				lstUsers.SelectedIndex = userIndex; | ||||
| 			} | ||||
| 		} | ||||
| 		private void removeMemberToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			MembershipInfo mi = myMembershipInfoList[lstMembers.SelectedIndex]; | ||||
| 			string msg = "Are you sure you want to remove this Group Member?"; | ||||
| 			if (MessageBox.Show(this, msg, "Confirm Group Member Removal", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == DialogResult.Yes) | ||||
| 			{ | ||||
| 				int groupIndex = lstGroups.SelectedIndex; | ||||
| 				int userIndex = lstUsers.SelectedIndex; | ||||
| 				if (mi.MyGroup.GroupName == "Administrators") | ||||
| 				{ | ||||
| 					int k = 0; | ||||
| 					foreach(MembershipInfo mm in mi.MyGroup.GroupMemberships) | ||||
| 						if(mm.EndDate == null || mm.EndDate == string.Empty) | ||||
| 							k++; | ||||
| 					if (k == 1) | ||||
| 					{ | ||||
| 						MessageBox.Show("You must have at least 1 user assigned to the Adminstrators group", "One Administrator Required", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 						return; | ||||
| 					} | ||||
| 				} | ||||
| 				Membership m = Membership.Get(mi.UGID); | ||||
| 				m.EndDate = DateTime.Now.ToShortDateString(); | ||||
| 				m.Save(); | ||||
| 				SetupSecurity(); | ||||
| 				lstGroups.SelectedIndex = groupIndex; | ||||
| 				lstUsers.SelectedIndex = userIndex; | ||||
| 			} | ||||
| 			//  foreach (int gg in lstGroups.SelectedIndices) | ||||
| 			//  { | ||||
| 			//    GroupInfo gi = myGroupInfoList[gg]; | ||||
| 			//    if (gi.GroupName == "Administrators" && gi.GroupMembershipCount == 1) | ||||
| 			//    { | ||||
| 			//      MessageBox.Show("You must have at least 1 user assigned to the Adminstrators group", "Can Not Delete User", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 			//      return; | ||||
| 			//    } | ||||
| 			//    foreach (MembershipInfo mi in gi.GroupMemberships) | ||||
| 			//    { | ||||
| 			//      foreach (int mm in lstGroupUsers.SelectedIndices) | ||||
| 			//      { | ||||
| 			//        MembershipInfo mig = myMembershipInfoList[mm]; | ||||
| 			//        if (mi.MyUser.UID == mig.MyUser.UID) | ||||
| 			//        { | ||||
| 			//          Membership m = Membership.Get(mi.UGID); | ||||
| 			//          m.EndDate = DateTime.Now.ToShortDateString(); | ||||
| 			//          m.Save(); | ||||
| 			//        } | ||||
| 			//      } | ||||
| 			//    } | ||||
| 			//  } | ||||
| 			//  SetupSecurity(); | ||||
| 			//} | ||||
| 		} | ||||
| 		private void addUserToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			User u = User.MakeUser("[Enter New UserID]","", "", "", "", "", "", "", "", "", "",DateTime.Now,""); | ||||
| 			frmManageUser frm = new frmManageUser("add"); | ||||
| 			frm.MyUser = u; | ||||
| 			if (frm.ShowDialog(this) == DialogResult.OK) | ||||
| 			{ | ||||
| 				u = frm.MyUser; | ||||
| 				u.Save(); | ||||
| 				Membership.MakeMembership(u, Group.Get(myFolder.FolderConfig.Security_Group), "", ""); | ||||
| 				SetupSecurity(); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				u.Delete(); | ||||
| 			} | ||||
| 		} | ||||
| 		private void editUserToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			if (lstUsers.SelectedIndex == -1) | ||||
| 			{ | ||||
| 				MessageBox.Show("You must select a user to edit", "No User Selected", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			UserInfo ui = myUserInfoList[lstUsers.SelectedIndex]; | ||||
| 			using (User u = User.Get(ui.UID)) | ||||
| 			{ | ||||
| 				frmManageUser frm = new frmManageUser("edit"); | ||||
| 				frm.MyUser = u; | ||||
| 				if (frm.ShowDialog(this) == DialogResult.OK) | ||||
| 				{ | ||||
| 					frm.MyUser.Save(); | ||||
|           SetupSecurity(); | ||||
|         } | ||||
| 			} | ||||
| 		} | ||||
| 		private void deleteUserToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			if (lstUsers.SelectedIndex == -1) | ||||
| 			{ | ||||
| 				MessageBox.Show("You must select a user to delete", "No User Selected", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			UserInfo ui = myUserInfoList[lstUsers.SelectedIndex]; | ||||
| 			SessionInfoList sil = SessionInfoList.Get(); | ||||
| 			foreach (SessionInfo si in sil) | ||||
| 			{ | ||||
| 				if (si.UserID == ui.UserID && (si.DTSEnd == null)) | ||||
| 				{ | ||||
| 					MessageBox.Show("The user selected has an active session.  You may not delete the user at this time.", "User Active Session", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 					return; | ||||
| 				} | ||||
| 			} | ||||
| 			int k = 0; | ||||
| 			if (ui.UserMembershipCount > 0) | ||||
| 			{ | ||||
| 				foreach (MembershipInfo mi in ui.UserMemberships) | ||||
| 				{ | ||||
| 					if (mi.EndDate == null || mi.EndDate == string.Empty) | ||||
| 						k++; | ||||
| 				} | ||||
| 			} | ||||
| 			if (k > 0) | ||||
| 			{ | ||||
| 				MessageBox.Show("You must remove user from all groups that user is a member of in order to delete user", "User Has Memberships", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			if (MessageBox.Show("Are you sure you want to delete this user?", "Confirm Deleting User", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == DialogResult.Yes) | ||||
| 			{ | ||||
| 				User.Delete(ui.UID); | ||||
| 				SetupSecurity(); | ||||
| 			} | ||||
| 			//to do delete user | ||||
| 			//end date user memberships | ||||
| 			//delete user | ||||
| 		} | ||||
| 		//Handles Creating a New Group | ||||
| 		private void createGroupMenuItem(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			try | ||||
| @@ -279,7 +115,6 @@ namespace VEPROMS | ||||
| 				TreeNode tn = tvFolders.SelectedNode; | ||||
| 				FolderInfo fi = tn.Tag as FolderInfo; | ||||
| 				AddNewGroup(tsddi.Text, fi); | ||||
| 				SetupSecurity(); | ||||
| 			} | ||||
| 			catch (Exception ex) | ||||
| 			{ | ||||
| @@ -298,81 +133,116 @@ namespace VEPROMS | ||||
| 				MessageBox.Show("Roles table is missing entries.\r\nPlease contact Volian to create other groups.", "Cannot create groups", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			foreach(RoleInfo ri in ril) | ||||
| 			{ | ||||
| 				if (ri.Name == txt) | ||||
|  | ||||
|             foreach (var ri in ril.Where(ri => ri.Name == txt)) | ||||
|             { | ||||
|                 string gin = string.Format("{0}s - {1}", ri.Name, fi.Name); | ||||
| 					bool addOK = true; | ||||
| 					foreach (GroupInfo gi in myGroupInfoList) | ||||
| 					{ | ||||
| 						if (gin == gi.GroupName) | ||||
| 						{ | ||||
| 							addOK = false; | ||||
| 							break; | ||||
| 						} | ||||
| 					} | ||||
| 					if (addOK) | ||||
|                 if (!myGroupInfoList.Any(gi => gi.GroupName == gin)) | ||||
|                 { | ||||
|                     Group group = Group.MakeGroup(gin, null, null); | ||||
|                     Assignment.MakeAssignment(group, Role.Get(ri.RID), Folder.Get(fi.FolderID), null); | ||||
|                 } | ||||
|             } | ||||
| 			} | ||||
| 			GroupInfoList.Reset(); | ||||
| 			myGroupInfoList = GroupInfoList.Get(); | ||||
| 			SetupGroups(); | ||||
| 		} | ||||
| 		private void lstUsers_SelectedIndexChanged(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			lblMembers.Text = "Selected User Groups"; | ||||
| 			myMembershipInfoList = new List<MembershipInfo>(); | ||||
| 			lstMembers.Items.Clear(); | ||||
| 			if (lstUsers.SelectedIndex > -1) | ||||
| 			{ | ||||
| 				UserInfo ui = myUserInfoList[lstUsers.SelectedIndex]; | ||||
| 				if (ui.UserMembershipCount > 0) | ||||
| 				{ | ||||
| 					foreach (MembershipInfo mi in ui.UserMemberships) | ||||
| 					{ | ||||
| 						if (mi.EndDate == null || mi.EndDate == string.Empty) | ||||
| 						{ | ||||
| 							myMembershipInfoList.Add(mi); | ||||
| 							lstMembers.Items.Add(mi.MyGroup.GroupName); | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
|             LoadRefreshGroupUsers(); | ||||
| 		} | ||||
| 		private void tvFolders_NodeMouseClick(object sender, TreeNodeMouseClickEventArgs e) | ||||
| 		{ | ||||
| 			tvFolders.SelectedNode = e.Node; | ||||
| 		} | ||||
| 		private void deleteGroupToolStripMenuItem_Click(object sender, EventArgs e) | ||||
|  | ||||
| 		#endregion | ||||
|  | ||||
| 		#region Manage Groups | ||||
| 		//Sets up Group Options | ||||
| 		private void SetupGroups() | ||||
| 		{ | ||||
| 			if (lstGroups.SelectedIndex < 0) | ||||
| 			cbGroupSelection.Items.Clear(); | ||||
| 			foreach (GroupInfo gi in myGroupInfoList) | ||||
| 				cbGroupSelection.Items.Add(gi.GroupName); | ||||
| 			cbGroupSelection.SelectedIndex = 0; | ||||
| 		} | ||||
|  | ||||
| 		private void cbGroupSelection_SelectedIndexChanged(object sender, EventArgs e) => updateMembershipLists(); | ||||
|  | ||||
| 		//Updates the lists of members / nonMembers | ||||
| 		private void updateMembershipLists() | ||||
| 		{ | ||||
| 			myMembershipInfoList = new List<MembershipInfo>(); | ||||
| 			if (cbGroupSelection.SelectedIndex > -1) | ||||
| 			{ | ||||
| 				GroupInfo gi = myGroupInfoList[cbGroupSelection.SelectedIndex]; | ||||
| 				gi.RefreshGroupMemberships(); | ||||
| 				if (gi.GroupMembershipCount > 0) | ||||
| 					myMembershipInfoList.AddRange(gi.GroupMemberships.Where(mi => mi.EndDate == null || mi.EndDate == string.Empty).OrderBy(x => x.MyUserUserID)); | ||||
| 			} | ||||
| 			lstMembers.DataSource = myMembershipInfoList; | ||||
| 			lstMembers.ValueMember = "UID"; | ||||
| 			lstMembers.DisplayMember = "MyUserUserID"; | ||||
|  | ||||
| 			//set NonMembers to Users that are not in Members | ||||
| 			lstNonMembers.DataSource = myUserInfoList.Select(x => x.UserID).Except(myMembershipInfoList.Select(x => x.MyUser.UserID)).ToList(); | ||||
| 		} | ||||
|  | ||||
| 		//Add a Member to a Group | ||||
| 		private void addMember_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			int groupIndex = cbGroupSelection.SelectedIndex; | ||||
| 			string selectedUserID = lstNonMembers.SelectedValue.ToString(); | ||||
| 			int selectedUID = UserInfo.GetByUserID(selectedUserID).UID; | ||||
| 			GroupInfo gi = myGroupInfoList[groupIndex]; | ||||
| 			User selectedUser = User.Get(selectedUID); | ||||
|  | ||||
| 			Membership.MakeMembership(selectedUser, Group.Get(gi.GID), null, ""); | ||||
| 			updateMembershipLists(); | ||||
| 			lstNonMembers.SelectedIndex = -1; | ||||
|  | ||||
| 			int index = lstMembers.FindString(selectedUserID); | ||||
| 			lstMembers.SetSelected(index, true); | ||||
| 		} | ||||
|  | ||||
| 		//Remove a Member From a Group | ||||
| 		private void removeMember_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			if (lstMembers.SelectedIndex > -1) | ||||
| 			{ | ||||
| 				MembershipInfo mi = (MembershipInfo)lstMembers.SelectedItem; | ||||
| 				string selectedUserID = mi.MyUserUserID; | ||||
| 				string msg = "Are you sure you want to remove this Group Member?"; | ||||
| 				if (MessageBox.Show(this, msg, "Confirm Group Member Removal", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == DialogResult.Yes) | ||||
| 				{ | ||||
| 					if (mi.MyGroup.GroupName == "Administrators" && mi.MyGroup.GroupMemberships.Count(mm => mm.EndDate == null || mm.EndDate == string.Empty) == 1) | ||||
| 					{ | ||||
| 						MessageBox.Show("You must have at least 1 user assigned to the Administrators group", "One Administrator Required", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 						return; | ||||
| 					} | ||||
| 					Membership m = Membership.Get(mi.UGID); | ||||
| 					m.EndDate = DateTime.Now.ToShortDateString(); | ||||
| 					m.Save(); | ||||
| 					updateMembershipLists(); | ||||
| 					lstMembers.SelectedIndex = -1; | ||||
| 					lstNonMembers.SelectedItem = selectedUserID; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		//Deletes the Currently Selected Group | ||||
| 		private void deleteGroup_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			if (cbGroupSelection.SelectedIndex < 0) | ||||
| 			{ | ||||
| 				MessageBox.Show("You must select a group to delete", "No Group Selected", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			GroupInfo gi = myGroupInfoList[lstGroups.SelectedIndex]; | ||||
| 			GroupInfo gi = myGroupInfoList[cbGroupSelection.SelectedIndex]; | ||||
| 			if(myFolder.FolderConfig.Security_Group == gi.GID) | ||||
| 			{ | ||||
| 				MessageBox.Show("Cannot Delete Default Group", "Attempt to Delete Default", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			bool deleteOK = true; | ||||
| 			if(gi.GroupMembershipCount > 0) | ||||
| 			{ | ||||
| 				foreach (MembershipInfo mi in gi.GroupMemberships) | ||||
| 				{ | ||||
| 					if (mi.EndDate == null || mi.EndDate == string.Empty) | ||||
| 					{ | ||||
|             if (gi.GroupMembershipCount > 0 && gi.GroupMemberships.Any(mi => mi.EndDate == null || mi.EndDate == string.Empty)) | ||||
|                 deleteOK = false; | ||||
| 						break; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
|             if (!deleteOK) | ||||
| 			{ | ||||
| 				MessageBox.Show("There are still users who are members of this group.  You need to delete all members in order to delete this group.", "Group Has Members", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| @@ -381,90 +251,64 @@ namespace VEPROMS | ||||
| 			if (MessageBox.Show("Are you sure you want to delete this group?", "Confirm Deleting Group", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == DialogResult.Yes) | ||||
| 			{ | ||||
| 				Group.Delete(gi.GID); | ||||
| 				GroupInfoList.Reset(); | ||||
| 				myGroupInfoList = GroupInfoList.Get(); | ||||
| 				LoadRefreshGroupUsers(); | ||||
| 				SetupGroups(); | ||||
| 				SetupSecurity(); | ||||
| 			} | ||||
| 		} | ||||
| 		private void lstGroups_MouseUp(object sender, MouseEventArgs e) | ||||
|  | ||||
| 		#endregion | ||||
|  | ||||
| 		#region Manage Users | ||||
|  | ||||
| 		//Sets up UserOptions | ||||
| 		private void SetupUserOptions() | ||||
| 		{ | ||||
| 			lstGroups.SelectedIndex = -1; | ||||
| 			if (e.Button == MouseButtons.Right) | ||||
| 			lstUsers.Items.Clear(); | ||||
| 			foreach (UserInfo ui in myUserInfoList) | ||||
| 				lstUsers.Items.Add(ui.UserID); | ||||
| 			lstUsers.SelectedIndex = -1; | ||||
| 			lstGroups.DataSource = null; | ||||
| 		} | ||||
|  | ||||
| 		#region Manage Users - User Options | ||||
|  | ||||
| 		//Build Membership list based on selected user | ||||
| 		private void lstUsers_SelectedIndexChanged(object sender, EventArgs e) | ||||
| 		{ | ||||
| 				int k = lstGroups.IndexFromPoint(e.Location); | ||||
| 				if (k >= 0) | ||||
| 			myMembershipInfoList = new List<MembershipInfo>(); | ||||
| 			if (lstUsers.SelectedIndex > -1) | ||||
| 			{ | ||||
| 					lstGroups.SelectedIndex = k; | ||||
| 					if (lstUsers.SelectedIndex >= 0) | ||||
| 					{ | ||||
| 						GroupInfo gi = myGroupInfoList[k]; | ||||
| 						if (gi.GroupMembershipCount > 0) | ||||
| 						{ | ||||
| 							addMemberToolStripMenuItemGroup.Visible = true; | ||||
| 				UserInfo ui = myUserInfoList[lstUsers.SelectedIndex]; | ||||
| 							foreach (MembershipInfo mi in gi.GroupMemberships) | ||||
| 				if (ui.UserMembershipCount > 0) | ||||
| 				{ | ||||
| 								if (mi.MyUser.UserID == ui.UserID && (mi.EndDate == null || mi.EndDate == string.Empty)) | ||||
| 								{ | ||||
| 									addMemberToolStripMenuItemGroup.Visible = false; | ||||
| 									break; | ||||
| 								} | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 					else | ||||
| 						addMemberToolStripMenuItemGroup.Visible = false; | ||||
| 					cmGroups.Show(lstGroups, e.Location); | ||||
| 				} | ||||
| 			} | ||||
| 			else if (e.Button == MouseButtons.Left) | ||||
| 			{ | ||||
| 				int k = lstGroups.IndexFromPoint(e.Location); | ||||
| 				if (k >= 0) | ||||
| 				{ | ||||
| 					lstGroups.SelectedIndex = k; | ||||
| 					myMembershipInfoList.AddRange(ui.UserMemberships.Where(mi => mi.EndDate == null || mi.EndDate == string.Empty)); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			lstGroups.DataSource = myMembershipInfoList; | ||||
| 			lstGroups.ValueMember = "UGID"; | ||||
| 			lstGroups.DisplayMember = "MyGroupName"; | ||||
| 		} | ||||
|  | ||||
| 		//Select User and set up Mouse Click Menus based on | ||||
| 		//where click in User Box | ||||
| 		private void lstUsers_MouseUp(object sender, MouseEventArgs e) | ||||
| 		{ | ||||
| 			lstUsers.SelectedIndex = -1; | ||||
| 			if (e.Button == MouseButtons.Right) | ||||
| 			{ | ||||
| 				int k = lstUsers.IndexFromPoint(e.Location); | ||||
| 				if (k >= 0) | ||||
| 				{ | ||||
| 					lstUsers.SelectedIndex = k; | ||||
|           //addUserToolStripMenuItem.Visible = false; | ||||
| 					editUserToolStripMenuItem.Visible = deleteUserToolStripMenuItem.Visible = true; | ||||
| 					if (lstGroups.SelectedIndex >= 0) | ||||
| 					{ | ||||
| 						UserInfo ui = myUserInfoList[k]; | ||||
| 						if(ui.UserMembershipCount > 0) | ||||
| 						{ | ||||
| 							addMemberToolStripMenuItemUser.Visible = true; | ||||
| 							GroupInfo gi = myGroupInfoList[lstGroups.SelectedIndex]; | ||||
| 							foreach(MembershipInfo mi in ui.UserMemberships) | ||||
| 							{ | ||||
| 								if (mi.MyGroup.GroupName == gi.GroupName && (mi.EndDate == null || mi.EndDate == string.Empty)) | ||||
| 								{ | ||||
| 									addMemberToolStripMenuItemUser.Visible = false; | ||||
| 									break; | ||||
| 								} | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 					else | ||||
| 						addMemberToolStripMenuItemUser.Visible = false; | ||||
| 					cmUsers.Show(lstUsers, e.Location); | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					addUserToolStripMenuItem.Visible = true; | ||||
| 					editUserToolStripMenuItem.Visible = deleteUserToolStripMenuItem.Visible = addMemberToolStripMenuItemUser.Visible = false; | ||||
| 					cmUsers.Show(lstUsers, e.Location); | ||||
| 					editUserToolStripMenuItem.Visible = deleteUserToolStripMenuItem.Visible = false; | ||||
| 				} | ||||
|  | ||||
| 				cmUsers.Show(lstUsers, e.Location); | ||||
| 			} | ||||
| 			else if (e.Button == MouseButtons.Left) | ||||
| 			{ | ||||
| @@ -475,34 +319,215 @@ namespace VEPROMS | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		private void lstMembers_MouseUp(object sender, MouseEventArgs e) | ||||
|  | ||||
| 		//Adds a new User | ||||
| 		private void addUserToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			lstMembers.SelectedIndex = -1; | ||||
| 			if (e.Button == MouseButtons.Right) | ||||
| 			User u = User.MakeUser("[Enter New UserID]", "", "", "", "", "", "", "", "", "", "", DateTime.Now, ""); | ||||
| 			frmManageUser frm = new frmManageUser("add"); | ||||
| 			frm.MyUser = u; | ||||
| 			if (frm.ShowDialog(this) == DialogResult.OK) | ||||
| 			{ | ||||
| 				int k = lstMembers.IndexFromPoint(e.Location); | ||||
| 				if (k >= 0) | ||||
| 				{ | ||||
| 					lstMembers.SelectedIndex = k; | ||||
| 					addMemberToolStripMenuItemUser.Visible = false; | ||||
| 					removeMemberToolStripMenuItem.Visible = true; | ||||
| 					cmMembers.Show(lstMembers, e.Location); | ||||
| 				u = frm.MyUser; | ||||
| 				u.Save(); | ||||
| 				Membership.MakeMembership(u, Group.Get(myFolder.FolderConfig.Security_Group), "", ""); | ||||
|  | ||||
| 				//Update the User list to reflect the added user | ||||
| 				LoadRefreshGroupUsers(); | ||||
| 				SetupUserOptions(); | ||||
| 				lstUsers.SelectedItem = u.UserID; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 					addMemberToolStripMenuItemUser.Visible = true; | ||||
| 					removeMemberToolStripMenuItem.Visible = false; | ||||
| 					cmMembers.Show(lstMembers, e.Location); | ||||
| 				u.Delete(); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		//Edit a User's details | ||||
| 		private void editUserToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			if (lstUsers.SelectedIndex == -1) | ||||
| 			{ | ||||
| 				MessageBox.Show("You must select a user to edit", "No User Selected", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			UserInfo ui = myUserInfoList[lstUsers.SelectedIndex]; | ||||
| 			using (User u = User.Get(ui.UID)) | ||||
| 			{ | ||||
| 				frmManageUser frm = new frmManageUser("edit"); | ||||
| 				frm.MyUser = u; | ||||
| 				if (frm.ShowDialog(this) == DialogResult.OK) | ||||
| 				{ | ||||
| 					frm.MyUser.Save(); | ||||
|  | ||||
| 					//Update the User list to reflect the edited user | ||||
| 					//this is done in case the UserID is updated so the list updates to reflect that | ||||
| 					LoadRefreshGroupUsers(); | ||||
| 					SetupUserOptions(); | ||||
| 					lstUsers.SelectedItem = u.UserID; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		//Delete a User | ||||
| 		private void deleteUserToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			if (lstUsers.SelectedIndex == -1) | ||||
| 			{ | ||||
| 				MessageBox.Show("You must select a user to delete", "No User Selected", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 				return; | ||||
| 			} | ||||
| 			UserInfo ui = myUserInfoList[lstUsers.SelectedIndex]; | ||||
| 			SessionInfoList sil = SessionInfoList.Get(); | ||||
| 			foreach (SessionInfo si in sil) | ||||
| 			{ | ||||
| 				if (si.UserID == ui.UserID && (si.DTSEnd == null)) | ||||
| 				{ | ||||
| 					MessageBox.Show("The user selected has an active session.  You may not delete the user at this time.", "User Active Session", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
| 					return; | ||||
| 				} | ||||
| 			} | ||||
| 			int nummemberships = ui.UserMemberships.Count(mi => mi.EndDate == null || mi.EndDate == string.Empty); | ||||
| 			string mem_text = nummemberships > 0 ? "\r\nNote that this will remove all memberships that this user has." : ""; | ||||
| 			if (MessageBox.Show($"Are you sure you want to delete this user?{mem_text}", "Confirm Deleting User", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == DialogResult.Yes) | ||||
| 			{ | ||||
| 				foreach (MembershipInfo minfo in ui.UserMemberships.Where(mi => mi.EndDate == null || mi.EndDate == string.Empty)) | ||||
|                 { | ||||
| 					Membership m = Membership.Get(minfo.UGID); | ||||
| 					m.EndDate = DateTime.Now.ToShortDateString(); | ||||
| 					m.Save(); | ||||
| 				} | ||||
|  | ||||
| 				User.Delete(ui.UID); | ||||
|  | ||||
| 				//Update the User list to reflect the deleted user | ||||
| 				LoadRefreshGroupUsers(); | ||||
| 				SetupUserOptions(); | ||||
| 				lstUsers.SelectedIndex = -1; | ||||
| 				lstGroups.DataSource = null; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		#endregion | ||||
|  | ||||
| 		#region Manage Users - Member Options | ||||
|  | ||||
| 		//Adds Context Menu for when a Group is selected | ||||
| 		private void lstGroups_MouseUp(object sender, MouseEventArgs e) | ||||
| 		{ | ||||
| 			cmMembers.Items.Clear(); | ||||
| 			lstGroups.SelectedIndex = -1; | ||||
|  | ||||
| 			//shouldn<64>t be bringing up a menu in the Group box unless a user is 1st selected in the Users box. | ||||
| 			if (e.Button == MouseButtons.Right && lstUsers.SelectedIndex > -1) | ||||
| 			{ | ||||
| 				int k = lstGroups.IndexFromPoint(e.Location); | ||||
| 				if (k >= 0) | ||||
| 				{ | ||||
| 					lstGroups.SelectedIndex = k; | ||||
| 					cmMembers.Items.Add(this.removeMemberToolStripMenuItem); | ||||
|  | ||||
| 				} | ||||
|  | ||||
| 				var groupsCanAddTo = myGroupInfoList.Select(x => new { x.GroupName, x.GID }).Except(myMembershipInfoList.Select(x => new { x.MyGroup.GroupName, x.GID })); | ||||
| 				foreach (var possiblegroup in groupsCanAddTo) | ||||
| 				{ | ||||
| 					ToolStripMenuItemwithValue AddToMenuItem = new ToolStripMenuItemwithValue($"Add as Member to Group: {possiblegroup.GroupName}", possiblegroup.GID); | ||||
| 					AddToMenuItem.Click += addMemberToolStripMenuItem_Click; | ||||
| 					cmMembers.Items.Add(AddToMenuItem); | ||||
| 				} | ||||
|  | ||||
| 				cmMembers.Show(lstGroups, e.Location); | ||||
|  | ||||
| 			} | ||||
| 			else if (e.Button == MouseButtons.Left) | ||||
| 			{ | ||||
| 				int k = lstMembers.IndexFromPoint(e.Location); | ||||
| 				int k = lstGroups.IndexFromPoint(e.Location); | ||||
| 				if (k >= 0) | ||||
| 				{ | ||||
| 					lstMembers.SelectedIndex = k; | ||||
| 					lstGroups.SelectedIndex = k; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		//Adds a User to a Group | ||||
| 		private void addMemberToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			ToolStripMenuItemwithValue item = (ToolStripMenuItemwithValue)sender; | ||||
| 			int userIndex = lstUsers.SelectedIndex; | ||||
| 			UserInfo ui = myUserInfoList[userIndex]; | ||||
|  | ||||
| 			Membership.MakeMembership(User.Get(ui.UID), Group.Get((int) item.Value), null, ""); | ||||
|  | ||||
| 			//Update the Group list to reflect the added group | ||||
| 			LoadRefreshGroupUsers(); | ||||
| 			lstUsers_SelectedIndexChanged(sender, e); | ||||
| 		} | ||||
|  | ||||
| 		//Removes a User from a Group | ||||
| 		private void removeMemberToolStripMenuItem_Click(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			MembershipInfo mi = (MembershipInfo)lstGroups.SelectedItem; | ||||
| 			string msg = "Are you sure you want to remove this Group Member?"; | ||||
| 			if (MessageBox.Show(this, msg, "Confirm Group Member Removal", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question) == DialogResult.Yes) | ||||
| 			{ | ||||
|                 if (mi.MyGroup.GroupName == "Administrators" && mi.MyGroup.GroupMemberships.Count(mm => mm.EndDate == null || mm.EndDate == string.Empty) == 1) | ||||
|                 { | ||||
|                     MessageBox.Show("You must have at least 1 user assigned to the Administrators group", "One Administrator Required", MessageBoxButtons.OK, MessageBoxIcon.Warning); | ||||
|                     return; | ||||
|                 } | ||||
|                 Membership m = Membership.Get(mi.UGID); | ||||
| 				m.EndDate = DateTime.Now.ToShortDateString(); | ||||
| 				m.Save(); | ||||
|  | ||||
| 				//Update the Group list to reflect the removed group | ||||
| 				LoadRefreshGroupUsers(); | ||||
| 				lstUsers_SelectedIndexChanged(sender, e); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		#endregion | ||||
|  | ||||
| 		#endregion | ||||
|  | ||||
| 		#region Default Options | ||||
| 		//Sets up Default Group options for Default Tab | ||||
| 		private void SetupDefaultGroupOptions() | ||||
| 		{ | ||||
| 			pnlGroups.Controls.Clear(); | ||||
| 			foreach (GroupInfo gi in myGroupInfoList) | ||||
| 			{ | ||||
| 				RadioButton rb = new RadioButton(); | ||||
| 				rb.Text = gi.GroupName; | ||||
| 				rb.Parent = pnlGroups; | ||||
| 				rb.Dock = DockStyle.Top; | ||||
| 				rb.Tag = gi; | ||||
| 				rb.CheckedChanged -= new EventHandler(rb_CheckedChanged); | ||||
| 				rb.CheckedChanged += new EventHandler(rb_CheckedChanged); | ||||
| 				pnlGroups.Controls.Add(rb); | ||||
| 				rb.BringToFront(); | ||||
| 				if (myFolder.FolderConfig.Security_Group == 0 && gi.GID == 1) | ||||
| 				{ | ||||
| 					myFolder.FolderConfig.Security_Group = gi.GID; | ||||
| 					rb.Checked = true; | ||||
| 					myFolder.Save(); | ||||
| 				} | ||||
| 				else if (myFolder.FolderConfig.Security_Group == gi.GID) | ||||
| 				{ | ||||
| 					rb.Checked = true; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		//Handles changing the default group | ||||
| 		private void rb_CheckedChanged(object sender, EventArgs e) | ||||
| 		{ | ||||
| 			RadioButton rb = sender as RadioButton; | ||||
| 			GroupInfo gi = rb.Tag as GroupInfo; | ||||
| 			label8.Text = gi.GroupAssignments[0].MyRole.Title + " for " + gi.GroupAssignments[0].MyFolder.Name; | ||||
| 			myFolder.FolderConfig.Security_Group = gi.GID; | ||||
| 			myFolder.Save(); | ||||
| 		} | ||||
| 		#endregion | ||||
|  | ||||
| 	} | ||||
| } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user