FIL-4 Completed refactoring of Sections to ItemFilterCommentBlocks
This commit is contained in:
		
							parent
							
								
									43c6149832
								
							
						
					
					
						commit
						b65fad0679
					
				| @ -117,7 +117,6 @@ | |||||||
|     <None Include="packages.config" /> |     <None Include="packages.config" /> | ||||||
|     <None Include="Resources\MuldiniFilterScript.txt" /> |     <None Include="Resources\MuldiniFilterScript.txt" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <Import Project="$(VSToolsPath)\TeamTest\Microsoft.TestTools.targets" Condition="Exists('$(VSToolsPath)\TeamTest\Microsoft.TestTools.targets')" /> |  | ||||||
|   <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> |   <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> | ||||||
|   <!-- To modify your build process, add your task inside one of the targets below and uncomment it.  |   <!-- 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. |        Other similar extension points exist, see Microsoft.Common.targets. | ||||||
|  | |||||||
| @ -6,7 +6,6 @@ using System.Xml.Serialization; | |||||||
| using Filtration.ObjectModel; | using Filtration.ObjectModel; | ||||||
| using Filtration.ObjectModel.Enums; | using Filtration.ObjectModel.Enums; | ||||||
| using NUnit.Framework; | using NUnit.Framework; | ||||||
| using YamlDotNet.Serialization; |  | ||||||
| 
 | 
 | ||||||
| namespace Filtration.ItemFilterPreview.Tests.Services | namespace Filtration.ItemFilterPreview.Tests.Services | ||||||
| { | { | ||||||
| @ -39,8 +38,7 @@ namespace Filtration.ItemFilterPreview.Tests.Services | |||||||
|                 serializer.Serialize(textWriter, item); |                 serializer.Serialize(textWriter, item); | ||||||
|                  output = textWriter.ToString(); |                  output = textWriter.ToString(); | ||||||
|             } |             } | ||||||
| 
 |              | ||||||
|             var x = 2; |  | ||||||
|             //Assert |             //Assert | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -31,9 +31,8 @@ namespace Filtration.ItemFilterPreview.Services | |||||||
|                 sw.Restart(); |                 sw.Restart(); | ||||||
| 
 | 
 | ||||||
|                 var matchedBlock = itemFilterScript.ItemFilterBlocks |                 var matchedBlock = itemFilterScript.ItemFilterBlocks | ||||||
|                                     .OfType<IItemFilterBlock>() |                                                    .OfType<IItemFilterBlock>() | ||||||
|                                     .Where(b => !(b is ItemFilterSection)) |                                                    .FirstOrDefault(block => _blockItemMatcher.ItemBlockMatch(block, item)); | ||||||
|                                     .FirstOrDefault(block => _blockItemMatcher.ItemBlockMatch(block, item)); |  | ||||||
| 
 | 
 | ||||||
|                 filteredItems.Add(new FilteredItem(item, matchedBlock)); |                 filteredItems.Add(new FilteredItem(item, matchedBlock)); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -85,7 +85,6 @@ | |||||||
|     <Compile Include="ItemFilterBlockGroup.cs" /> |     <Compile Include="ItemFilterBlockGroup.cs" /> | ||||||
|     <Compile Include="ItemFilterScript.cs" /> |     <Compile Include="ItemFilterScript.cs" /> | ||||||
|     <Compile Include="ItemFilterScriptSettings.cs" /> |     <Compile Include="ItemFilterScriptSettings.cs" /> | ||||||
|     <Compile Include="ItemFilterSection.cs" /> |  | ||||||
|     <Compile Include="ItemSet.cs" /> |     <Compile Include="ItemSet.cs" /> | ||||||
|     <Compile Include="NumericFilterPredicate.cs" /> |     <Compile Include="NumericFilterPredicate.cs" /> | ||||||
|     <Compile Include="PathOfExileNamedColors.cs" /> |     <Compile Include="PathOfExileNamedColors.cs" /> | ||||||
|  | |||||||
| @ -37,13 +37,11 @@ namespace Filtration.ObjectModel | |||||||
|     public interface IItemFilterCommentBlock : IItemFilterBlockBase |     public interface IItemFilterCommentBlock : IItemFilterBlockBase | ||||||
|     { |     { | ||||||
|         string Comment { get; set; } |         string Comment { get; set; } | ||||||
|         bool IsSection { get; set; } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public class ItemFilterCommentBlock : ItemFilterBlockBase, IItemFilterCommentBlock |     public class ItemFilterCommentBlock : ItemFilterBlockBase, IItemFilterCommentBlock | ||||||
|     { |     { | ||||||
|         public string Comment { get; set; } |         public string Comment { get; set; } | ||||||
|         public bool IsSection { get; set; } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public class ItemFilterBlock : ItemFilterBlockBase, IItemFilterBlock |     public class ItemFilterBlock : ItemFilterBlockBase, IItemFilterBlock | ||||||
|  | |||||||
| @ -81,15 +81,9 @@ namespace Filtration.ObjectModel | |||||||
| 
 | 
 | ||||||
|         private bool BlockIsColorReplacementCandidate(ReplaceColorsParameterSet replaceColorsParameterSet, IItemFilterBlock block) |         private bool BlockIsColorReplacementCandidate(ReplaceColorsParameterSet replaceColorsParameterSet, IItemFilterBlock block) | ||||||
|         { |         { | ||||||
|             var textColorItem = block.HasBlockItemOfType<TextColorBlockItem>() |             var textColorItem = block.BlockItems.OfType<TextColorBlockItem>().FirstOrDefault(); | ||||||
|                 ? block.BlockItems.OfType<TextColorBlockItem>().First() |             var backgroundColorItem = block.BlockItems.OfType<BackgroundColorBlockItem>().FirstOrDefault(); | ||||||
|                 : null; |             var borderColorItem = block.BlockItems.OfType<BorderColorBlockItem>().FirstOrDefault(); | ||||||
|             var backgroundColorItem = block.HasBlockItemOfType<BackgroundColorBlockItem>() |  | ||||||
|                 ? block.BlockItems.OfType<BackgroundColorBlockItem>().First() |  | ||||||
|                 : null; |  | ||||||
|             var borderColorItem = block.HasBlockItemOfType<BorderColorBlockItem>() |  | ||||||
|                 ? block.BlockItems.OfType<BorderColorBlockItem>().First() |  | ||||||
|                 : null; |  | ||||||
| 
 | 
 | ||||||
|             // If we don't have all of the things we want to replace, then we aren't a candidate for replacing those things. |             // If we don't have all of the things we want to replace, then we aren't a candidate for replacing those things. | ||||||
|             if ((textColorItem == null && replaceColorsParameterSet.ReplaceTextColor) || |             if ((textColorItem == null && replaceColorsParameterSet.ReplaceTextColor) || | ||||||
|  | |||||||
| @ -1,6 +0,0 @@ | |||||||
| namespace Filtration.ObjectModel |  | ||||||
| { |  | ||||||
|     public class ItemFilterSection : ItemFilterBlock |  | ||||||
|     { |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -9,5 +9,7 @@ namespace Filtration.Parser.Interface.Services | |||||||
|         string TranslateItemFilterBlockToString(IItemFilterBlock block); |         string TranslateItemFilterBlockToString(IItemFilterBlock block); | ||||||
|         void ReplaceAudioVisualBlockItemsFromString(ObservableCollection<IItemFilterBlockItem> blockItems, string inputString); |         void ReplaceAudioVisualBlockItemsFromString(ObservableCollection<IItemFilterBlockItem> blockItems, string inputString); | ||||||
|         IItemFilterCommentBlock TranslateStringToItemFilterCommentBlock(string inputString); |         IItemFilterCommentBlock TranslateStringToItemFilterCommentBlock(string inputString); | ||||||
|  |         string TranslateItemFilterCommentBlockToString(IItemFilterCommentBlock itemFilterCommentBlock); | ||||||
|  |         string TranslateItemFilterBlockBaseToString(IItemFilterBlockBase itemFilterBlockBase); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -442,16 +442,31 @@ namespace Filtration.Parser.Services | |||||||
|             return new Color(); |             return new Color(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public string TranslateItemFilterBlockBaseToString(IItemFilterBlockBase itemFilterBlockBase) | ||||||
|  |         { | ||||||
|  |             var itemFilterBlock = itemFilterBlockBase as IItemFilterBlock; | ||||||
|  |             if (itemFilterBlock != null) return TranslateItemFilterBlockToString(itemFilterBlock); | ||||||
|  | 
 | ||||||
|  |             var itemFilterCommentBlock = itemFilterBlockBase as IItemFilterCommentBlock; | ||||||
|  |             if (itemFilterCommentBlock != null) return TranslateItemFilterCommentBlockToString(itemFilterCommentBlock); | ||||||
|  | 
 | ||||||
|  |             throw new InvalidOperationException("Unable to translate unknown ItemFilterBlock type"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // TODO: Private | ||||||
|  |         public string TranslateItemFilterCommentBlockToString(IItemFilterCommentBlock itemFilterCommentBlock) | ||||||
|  |         { | ||||||
|  |             // TODO: Handle multi-line | ||||||
|  |             // TODO: Tests | ||||||
|  |             // TODO: # Section: text? | ||||||
|  |             return $"#{itemFilterCommentBlock.Comment}"; | ||||||
|  |         } | ||||||
|  |          | ||||||
|         // This method converts an ItemFilterBlock object into a string. This is used for copying a ItemFilterBlock |         // This method converts an ItemFilterBlock object into a string. This is used for copying a ItemFilterBlock | ||||||
|         // to the clipboard, and when saving a ItemFilterScript. |         // to the clipboard, and when saving a ItemFilterScript. | ||||||
|  |         // TODO: Private | ||||||
|         public string TranslateItemFilterBlockToString(IItemFilterBlock block) |         public string TranslateItemFilterBlockToString(IItemFilterBlock block) | ||||||
|         { |         { | ||||||
|             // TODO: fix |  | ||||||
|             if (block.GetType() == typeof (ItemFilterCommentBlock)) |  | ||||||
|             { |  | ||||||
|                 return "# Section: " + block.Description; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             var outputString = string.Empty; |             var outputString = string.Empty; | ||||||
| 
 | 
 | ||||||
|             if (!block.Enabled) |             if (!block.Enabled) | ||||||
|  | |||||||
| @ -45,6 +45,9 @@ | |||||||
|                     <converters:BooleanToBlockActionInverseConverter x:Key="BooleanToBlockActionInverseConverter" /> |                     <converters:BooleanToBlockActionInverseConverter x:Key="BooleanToBlockActionInverseConverter" /> | ||||||
|                     <converters:AvailableThemeComponentsConverter x:Key="AvailableThemeComponentsConverter" /> |                     <converters:AvailableThemeComponentsConverter x:Key="AvailableThemeComponentsConverter" /> | ||||||
|                 </ResourceDictionary> |                 </ResourceDictionary> | ||||||
|  |                 <ResourceDictionary> | ||||||
|  |                     <RoutedCommand x:Key="OpenScriptRoutedCommand" /> | ||||||
|  |                 </ResourceDictionary> | ||||||
|             </ResourceDictionary.MergedDictionaries> |             </ResourceDictionary.MergedDictionaries> | ||||||
|         </ResourceDictionary> |         </ResourceDictionary> | ||||||
|     </Application.Resources> |     </Application.Resources> | ||||||
|  | |||||||
| @ -181,7 +181,10 @@ | |||||||
|     <Compile Include="UserControls\ThemeComponentSelectionControl.xaml.cs"> |     <Compile Include="UserControls\ThemeComponentSelectionControl.xaml.cs"> | ||||||
|       <DependentUpon>ThemeComponentSelectionControl.xaml</DependentUpon> |       <DependentUpon>ThemeComponentSelectionControl.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
|  |     <Compile Include="Utility\RoutedCommandHandler.cs" /> | ||||||
|  |     <Compile Include="Utility\RoutedCommandHandlers.cs" /> | ||||||
|     <Compile Include="ViewModels\AvalonDockWorkspaceViewModel.cs" /> |     <Compile Include="ViewModels\AvalonDockWorkspaceViewModel.cs" /> | ||||||
|  |     <Compile Include="ViewModels\IItemFilterCommentBlockViewModelFactory.cs" /> | ||||||
|     <Compile Include="ViewModels\SettingsPageViewModel.cs" /> |     <Compile Include="ViewModels\SettingsPageViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\ToolPanes\BlockGroupBrowserViewModel.cs" /> |     <Compile Include="ViewModels\ToolPanes\BlockGroupBrowserViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\IItemFilterScriptViewModelFactory.cs" /> |     <Compile Include="ViewModels\IItemFilterScriptViewModelFactory.cs" /> | ||||||
| @ -191,7 +194,7 @@ | |||||||
|     <Compile Include="ViewModels\ItemFilterScriptViewModel.cs" /> |     <Compile Include="ViewModels\ItemFilterScriptViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\ToolPanes\BlockOutputPreviewViewModel.cs" /> |     <Compile Include="ViewModels\ToolPanes\BlockOutputPreviewViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\ReplaceColorsViewModel.cs" /> |     <Compile Include="ViewModels\ReplaceColorsViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\ToolPanes\SectionBrowserViewModel.cs" /> |     <Compile Include="ViewModels\ToolPanes\CommentBlockBrowserViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\StartPageViewModel.cs" /> |     <Compile Include="ViewModels\StartPageViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\ToolPanes\ToolViewModel.cs" /> |     <Compile Include="ViewModels\ToolPanes\ToolViewModel.cs" /> | ||||||
|     <Compile Include="ViewModels\UpdateAvailableViewModel.cs" /> |     <Compile Include="ViewModels\UpdateAvailableViewModel.cs" /> | ||||||
| @ -220,7 +223,6 @@ | |||||||
|     <Compile Include="Views\ToolPanes\BlockGroupBrowserView.xaml.cs"> |     <Compile Include="Views\ToolPanes\BlockGroupBrowserView.xaml.cs"> | ||||||
|       <DependentUpon>BlockGroupBrowserView.xaml</DependentUpon> |       <DependentUpon>BlockGroupBrowserView.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
|     <Compile Include="Views\BlockTemplateSelector.cs" /> |  | ||||||
|     <Compile Include="Views\ItemFilterScriptView.xaml.cs"> |     <Compile Include="Views\ItemFilterScriptView.xaml.cs"> | ||||||
|       <DependentUpon>ItemFilterScriptView.xaml</DependentUpon> |       <DependentUpon>ItemFilterScriptView.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
| @ -230,8 +232,8 @@ | |||||||
|     <Compile Include="UserControls\NumericFilterPredicateControl.xaml.cs"> |     <Compile Include="UserControls\NumericFilterPredicateControl.xaml.cs"> | ||||||
|       <DependentUpon>NumericFilterPredicateControl.xaml</DependentUpon> |       <DependentUpon>NumericFilterPredicateControl.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
|     <Compile Include="Views\ItemFilterSectionView.xaml.cs"> |     <Compile Include="Views\ItemFilterCommentBlockView.xaml.cs"> | ||||||
|       <DependentUpon>ItemFilterSectionView.xaml</DependentUpon> |       <DependentUpon>ItemFilterCommentBlockView.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
|     <Compile Include="Views\AboutWindow.xaml.cs"> |     <Compile Include="Views\AboutWindow.xaml.cs"> | ||||||
|       <DependentUpon>AboutWindow.xaml</DependentUpon> |       <DependentUpon>AboutWindow.xaml</DependentUpon> | ||||||
| @ -245,8 +247,8 @@ | |||||||
|     <Compile Include="Views\ToolPanes\BlockOutputPreviewView.xaml.cs"> |     <Compile Include="Views\ToolPanes\BlockOutputPreviewView.xaml.cs"> | ||||||
|       <DependentUpon>BlockOutputPreviewView.xaml</DependentUpon> |       <DependentUpon>BlockOutputPreviewView.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
|     <Compile Include="Views\ToolPanes\SectionBrowserView.xaml.cs"> |     <Compile Include="Views\ToolPanes\CommentBlockBrowserView.xaml.cs"> | ||||||
|       <DependentUpon>SectionBrowserView.xaml</DependentUpon> |       <DependentUpon>CommentBlockBrowserView.xaml</DependentUpon> | ||||||
|     </Compile> |     </Compile> | ||||||
|     <Compile Include="Views\StartPageView.xaml.cs"> |     <Compile Include="Views\StartPageView.xaml.cs"> | ||||||
|       <DependentUpon>StartPageView.xaml</DependentUpon> |       <DependentUpon>StartPageView.xaml</DependentUpon> | ||||||
| @ -310,7 +312,7 @@ | |||||||
|       <SubType>Designer</SubType> |       <SubType>Designer</SubType> | ||||||
|       <Generator>MSBuild:Compile</Generator> |       <Generator>MSBuild:Compile</Generator> | ||||||
|     </Page> |     </Page> | ||||||
|     <Page Include="Views\ToolPanes\SectionBrowserView.xaml"> |     <Page Include="Views\ToolPanes\CommentBlockBrowserView.xaml"> | ||||||
|       <SubType>Designer</SubType> |       <SubType>Designer</SubType> | ||||||
|       <Generator>MSBuild:Compile</Generator> |       <Generator>MSBuild:Compile</Generator> | ||||||
|     </Page> |     </Page> | ||||||
| @ -322,7 +324,7 @@ | |||||||
|       <SubType>Designer</SubType> |       <SubType>Designer</SubType> | ||||||
|       <Generator>MSBuild:Compile</Generator> |       <Generator>MSBuild:Compile</Generator> | ||||||
|     </Page> |     </Page> | ||||||
|     <Page Include="Views\ItemFilterSectionView.xaml"> |     <Page Include="Views\ItemFilterCommentBlockView.xaml"> | ||||||
|       <SubType>Designer</SubType> |       <SubType>Designer</SubType> | ||||||
|       <Generator>MSBuild:Compile</Generator> |       <Generator>MSBuild:Compile</Generator> | ||||||
|     </Page> |     </Page> | ||||||
| @ -510,9 +512,7 @@ | |||||||
|       <Name>Filtration.ThemeEditor</Name> |       <Name>Filtration.ThemeEditor</Name> | ||||||
|     </ProjectReference> |     </ProjectReference> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |   <ItemGroup /> | ||||||
|     <Folder Include="Translators\" /> |  | ||||||
|   </ItemGroup> |  | ||||||
|   <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> |   <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> | ||||||
|   <Import Project="$(XamlSpyInstallPath)MSBuild\FirstFloor.XamlSpy.WPF.targets" Condition="'$(XamlSpyInstallPath)' != '' and '$(Configuration)' == 'DEBUG'" /> |   <Import Project="$(XamlSpyInstallPath)MSBuild\FirstFloor.XamlSpy.WPF.targets" Condition="'$(XamlSpyInstallPath)' != '' and '$(Configuration)' == 'DEBUG'" /> | ||||||
|   <!-- To modify your build process, add your task inside one of the targets below and uncomment it.  |   <!-- To modify your build process, add your task inside one of the targets below and uncomment it.  | ||||||
|  | |||||||
							
								
								
									
										73
									
								
								Filtration/Utility/RoutedCommandHandler.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								Filtration/Utility/RoutedCommandHandler.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,73 @@ | |||||||
|  | using System.Windows; | ||||||
|  | using System.Windows.Input; | ||||||
|  | 
 | ||||||
|  | namespace Filtration.Utility | ||||||
|  | { | ||||||
|  |     /// <summary> | ||||||
|  |     ///  Allows associated a routed command with a non-routed command.  Used by | ||||||
|  |     ///  <see cref="RoutedCommandHandlers"/>. | ||||||
|  |     /// </summary> | ||||||
|  |     public class RoutedCommandHandler : Freezable | ||||||
|  |     { | ||||||
|  |         public static readonly DependencyProperty CommandProperty = DependencyProperty.Register( | ||||||
|  |             "Command", | ||||||
|  |             typeof(ICommand), | ||||||
|  |             typeof(RoutedCommandHandler), | ||||||
|  |             new PropertyMetadata(default(ICommand))); | ||||||
|  | 
 | ||||||
|  |         /// <summary> The command that should be executed when the RoutedCommand fires. </summary> | ||||||
|  |         public ICommand Command | ||||||
|  |         { | ||||||
|  |             get => (ICommand)GetValue(CommandProperty); | ||||||
|  |             set => SetValue(CommandProperty, value); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public static readonly DependencyProperty IsActiveProperty = DependencyProperty.Register( | ||||||
|  |             "IsActive", typeof(bool), typeof(RoutedCommandHandler), new PropertyMetadata(default(bool))); | ||||||
|  | 
 | ||||||
|  |         public bool IsActive | ||||||
|  |         { | ||||||
|  |             get { return (bool) GetValue(IsActiveProperty); } | ||||||
|  |             set { SetValue(IsActiveProperty, value); } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         /// <summary> The command that triggers <see cref="ICommand"/>. </summary> | ||||||
|  |         public ICommand RoutedCommand { get; set; } | ||||||
|  | 
 | ||||||
|  |         /// <inheritdoc /> | ||||||
|  |         protected override Freezable CreateInstanceCore() | ||||||
|  |         { | ||||||
|  |             return new RoutedCommandHandler(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         /// <summary> | ||||||
|  |         ///  Register this handler to respond to the registered RoutedCommand for the | ||||||
|  |         ///  given element. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="owner"> The element for which we should register the command | ||||||
|  |         ///  binding for the current routed command. </param> | ||||||
|  |         internal void Register(FrameworkElement owner) | ||||||
|  |         { | ||||||
|  |             var binding = new CommandBinding(RoutedCommand, HandleExecuted, HandleCanExecute); | ||||||
|  |             owner.CommandBindings.Add(binding); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         /// <summary> Proxy to the current Command.CanExecute(object). </summary> | ||||||
|  |         private void HandleCanExecute(object sender, CanExecuteRoutedEventArgs e) | ||||||
|  |         { | ||||||
|  |             if (!IsActive) return; | ||||||
|  | 
 | ||||||
|  |             e.CanExecute = Command?.CanExecute(e.Parameter) != null; | ||||||
|  |             e.Handled = true; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         /// <summary> Proxy to the current Command.Execute(object). </summary> | ||||||
|  |         private void HandleExecuted(object sender, ExecutedRoutedEventArgs e) | ||||||
|  |         { | ||||||
|  |             if (!IsActive) return; | ||||||
|  | 
 | ||||||
|  |             Command?.Execute(e.Parameter); | ||||||
|  |             e.Handled = true; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										79
									
								
								Filtration/Utility/RoutedCommandHandlers.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								Filtration/Utility/RoutedCommandHandlers.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,79 @@ | |||||||
|  | using System.Collections; | ||||||
|  | using System.Collections.Specialized; | ||||||
|  | using System.Windows; | ||||||
|  | 
 | ||||||
|  | namespace Filtration.Utility | ||||||
|  | { | ||||||
|  |     /// <summary> | ||||||
|  |     ///  Holds a collection of <see cref="RoutedCommandHandler"/> that should be | ||||||
|  |     ///  turned into CommandBindings. | ||||||
|  |     /// </summary> | ||||||
|  |     public class RoutedCommandHandlers : FreezableCollection<RoutedCommandHandler> | ||||||
|  |     { | ||||||
|  |         /// <summary> | ||||||
|  |         ///  Hide this from WPF so that it's forced to go through | ||||||
|  |         ///  <see cref="GetCommands"/> and we can auto-create the collection | ||||||
|  |         ///  if it doesn't already exist.  This isn't strictly necessary but it makes | ||||||
|  |         ///  the XAML much nicer. | ||||||
|  |         /// </summary> | ||||||
|  |         private static readonly DependencyProperty CommandsProperty = DependencyProperty.RegisterAttached( | ||||||
|  |             "CommandsPrivate", | ||||||
|  |             typeof(RoutedCommandHandlers), | ||||||
|  |             typeof(RoutedCommandHandlers), | ||||||
|  |             new PropertyMetadata(default(RoutedCommandHandlers))); | ||||||
|  | 
 | ||||||
|  |         /// <summary> | ||||||
|  |         ///  Gets the collection of RoutedCommandHandler for a given element, creating | ||||||
|  |         ///  it if it doesn't already exist. | ||||||
|  |         /// </summary> | ||||||
|  |         public static RoutedCommandHandlers GetCommands(FrameworkElement element) | ||||||
|  |         { | ||||||
|  |             RoutedCommandHandlers handlers = (RoutedCommandHandlers)element.GetValue(CommandsProperty); | ||||||
|  |             if (handlers == null) | ||||||
|  |             { | ||||||
|  |                 handlers = new RoutedCommandHandlers(element); | ||||||
|  |                 element.SetValue(CommandsProperty, handlers); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return handlers; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private readonly FrameworkElement _owner; | ||||||
|  | 
 | ||||||
|  |         /// <summary> Each collection is tied to a specific element. </summary> | ||||||
|  |         /// <param name="owner"> The element for which this collection is created. </param> | ||||||
|  |         public RoutedCommandHandlers(FrameworkElement owner) | ||||||
|  |         { | ||||||
|  |             _owner = owner; | ||||||
|  | 
 | ||||||
|  |             // because we auto-create the collection, we don't know when items will be | ||||||
|  |             // added.  So, we observe ourself for changes manually.  | ||||||
|  |             var self = (INotifyCollectionChanged)this; | ||||||
|  |             self.CollectionChanged += (sender, args) => | ||||||
|  |             { | ||||||
|  |                 // note this does not handle deletions, that's left as an exercise for the | ||||||
|  |                 // reader, but most of the time, that's not needed!  | ||||||
|  |                 ((RoutedCommandHandlers)sender).HandleAdditions(args.NewItems); | ||||||
|  |             }; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         /// <summary> Invoked when new items are added to the collection. </summary> | ||||||
|  |         /// <param name="newItems"> The new items that were added. </param> | ||||||
|  |         private void HandleAdditions(IList newItems) | ||||||
|  |         { | ||||||
|  |             if (newItems == null) | ||||||
|  |                 return; | ||||||
|  | 
 | ||||||
|  |             foreach (RoutedCommandHandler routedHandler in newItems) | ||||||
|  |             { | ||||||
|  |                 routedHandler.Register(_owner); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         /// <inheritdoc /> | ||||||
|  |         protected override Freezable CreateInstanceCore() | ||||||
|  |         { | ||||||
|  |             return new RoutedCommandHandlers(_owner); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -2,6 +2,7 @@ | |||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Collections.ObjectModel; | using System.Collections.ObjectModel; | ||||||
| using System.Linq; | using System.Linq; | ||||||
|  | using System.Windows; | ||||||
| using Filtration.Common.ViewModels; | using Filtration.Common.ViewModels; | ||||||
| using Filtration.Interface; | using Filtration.Interface; | ||||||
| using Filtration.ThemeEditor.ViewModels; | using Filtration.ThemeEditor.ViewModels; | ||||||
| @ -18,7 +19,7 @@ namespace Filtration.ViewModels | |||||||
|         ReadOnlyObservableCollection<IDocument> OpenDocuments { get; } |         ReadOnlyObservableCollection<IDocument> OpenDocuments { get; } | ||||||
|         IItemFilterScriptViewModel ActiveScriptViewModel { get; } |         IItemFilterScriptViewModel ActiveScriptViewModel { get; } | ||||||
|         IThemeEditorViewModel ActiveThemeViewModel { get; } |         IThemeEditorViewModel ActiveThemeViewModel { get; } | ||||||
|         ISectionBrowserViewModel SectionBrowserViewModel { get; } |         ICommentBlockBrowserViewModel CommentBlockBrowserViewModel { get; } | ||||||
|         IBlockGroupBrowserViewModel BlockGroupBrowserViewModel { get; } |         IBlockGroupBrowserViewModel BlockGroupBrowserViewModel { get; } | ||||||
|         IBlockOutputPreviewViewModel BlockOutputPreviewViewModel { get; } |         IBlockOutputPreviewViewModel BlockOutputPreviewViewModel { get; } | ||||||
|         void AddDocument(IDocument document); |         void AddDocument(IDocument document); | ||||||
| @ -29,7 +30,7 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|     internal class AvalonDockWorkspaceViewModel : ViewModelBase, IAvalonDockWorkspaceViewModel |     internal class AvalonDockWorkspaceViewModel : ViewModelBase, IAvalonDockWorkspaceViewModel | ||||||
|     { |     { | ||||||
|         private readonly ISectionBrowserViewModel _sectionBrowserViewModel; |         private readonly ICommentBlockBrowserViewModel _commentBlockBrowserViewModel; | ||||||
|         private readonly IBlockGroupBrowserViewModel _blockGroupBrowserViewModel; |         private readonly IBlockGroupBrowserViewModel _blockGroupBrowserViewModel; | ||||||
|         private readonly IBlockOutputPreviewViewModel _blockOutputPreviewViewModel; |         private readonly IBlockOutputPreviewViewModel _blockOutputPreviewViewModel; | ||||||
| 
 | 
 | ||||||
| @ -38,16 +39,16 @@ namespace Filtration.ViewModels | |||||||
|         private IThemeEditorViewModel _activeThemeViewModel; |         private IThemeEditorViewModel _activeThemeViewModel; | ||||||
|         private readonly ObservableCollection<IDocument> _openDocuments; |         private readonly ObservableCollection<IDocument> _openDocuments; | ||||||
| 
 | 
 | ||||||
|         public AvalonDockWorkspaceViewModel(ISectionBrowserViewModel sectionBrowserViewModel, |         public AvalonDockWorkspaceViewModel(ICommentBlockBrowserViewModel commentBlockBrowserViewModel, | ||||||
|             IBlockGroupBrowserViewModel blockGroupBrowserViewModel, |             IBlockGroupBrowserViewModel blockGroupBrowserViewModel, | ||||||
|             IStartPageViewModel startPageViewModel, |             IStartPageViewModel startPageViewModel, | ||||||
|             IBlockOutputPreviewViewModel blockOutputPreviewViewModel) |             IBlockOutputPreviewViewModel blockOutputPreviewViewModel) | ||||||
|         { |         { | ||||||
|             _sectionBrowserViewModel = sectionBrowserViewModel; |             _commentBlockBrowserViewModel = commentBlockBrowserViewModel; | ||||||
|             _blockGroupBrowserViewModel = blockGroupBrowserViewModel; |             _blockGroupBrowserViewModel = blockGroupBrowserViewModel; | ||||||
|             _blockOutputPreviewViewModel = blockOutputPreviewViewModel; |             _blockOutputPreviewViewModel = blockOutputPreviewViewModel; | ||||||
| 
 | 
 | ||||||
|             _sectionBrowserViewModel.Initialise(this); |             _commentBlockBrowserViewModel.Initialise(this); | ||||||
|             _blockGroupBrowserViewModel.Initialise(this); |             _blockGroupBrowserViewModel.Initialise(this); | ||||||
|             _blockOutputPreviewViewModel.Initialise(this); |             _blockOutputPreviewViewModel.Initialise(this); | ||||||
| 
 | 
 | ||||||
| @ -94,13 +95,13 @@ namespace Filtration.ViewModels | |||||||
|         public IThemeEditorViewModel ActiveThemeViewModel => _activeThemeViewModel; |         public IThemeEditorViewModel ActiveThemeViewModel => _activeThemeViewModel; | ||||||
|         public IBlockGroupBrowserViewModel BlockGroupBrowserViewModel => _blockGroupBrowserViewModel; |         public IBlockGroupBrowserViewModel BlockGroupBrowserViewModel => _blockGroupBrowserViewModel; | ||||||
|         public IBlockOutputPreviewViewModel BlockOutputPreviewViewModel => _blockOutputPreviewViewModel; |         public IBlockOutputPreviewViewModel BlockOutputPreviewViewModel => _blockOutputPreviewViewModel; | ||||||
|         public ISectionBrowserViewModel SectionBrowserViewModel => _sectionBrowserViewModel; |         public ICommentBlockBrowserViewModel CommentBlockBrowserViewModel => _commentBlockBrowserViewModel; | ||||||
| 
 | 
 | ||||||
|         private List<IToolViewModel> _tools; |         private List<IToolViewModel> _tools; | ||||||
| 
 | 
 | ||||||
|         public IEnumerable<IToolViewModel> Tools => _tools ?? (_tools = new List<IToolViewModel> |         public IEnumerable<IToolViewModel> Tools => _tools ?? (_tools = new List<IToolViewModel> | ||||||
|         { |         { | ||||||
|             _sectionBrowserViewModel, |             _commentBlockBrowserViewModel, | ||||||
|             _blockGroupBrowserViewModel, |             _blockGroupBrowserViewModel, | ||||||
|             _blockOutputPreviewViewModel |             _blockOutputPreviewViewModel | ||||||
|         }); |         }); | ||||||
| @ -116,7 +117,7 @@ namespace Filtration.ViewModels | |||||||
|                 _activeThemeViewModel = (IThemeEditorViewModel) document; |                 _activeThemeViewModel = (IThemeEditorViewModel) document; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             _openDocuments.Add(document); |             Application.Current.Dispatcher.Invoke(() => _openDocuments.Add(document)); | ||||||
|             ActiveDocument = document; |             ActiveDocument = document; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -129,7 +130,7 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|             if (document.IsScript && ActiveDocument == document) |             if (document.IsScript && ActiveDocument == document) | ||||||
|             { |             { | ||||||
|                 _sectionBrowserViewModel.ClearDown(); |                 _commentBlockBrowserViewModel.ClearDown(); | ||||||
|                 _blockGroupBrowserViewModel.ClearDown(); |                 _blockGroupBrowserViewModel.ClearDown(); | ||||||
|                 _blockOutputPreviewViewModel.ClearDown(); |                 _blockOutputPreviewViewModel.ClearDown(); | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -0,0 +1,8 @@ | |||||||
|  | namespace Filtration.ViewModels | ||||||
|  | { | ||||||
|  |     internal interface IItemFilterCommentBlockViewModelFactory | ||||||
|  |     { | ||||||
|  |         IItemFilterCommentBlockViewModel Create(); | ||||||
|  |         void Release(IItemFilterCommentBlockViewModel itemFilterCommentBlockViewModel); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -15,11 +15,9 @@ using Xceed.Wpf.Toolkit; | |||||||
| 
 | 
 | ||||||
| namespace Filtration.ViewModels | namespace Filtration.ViewModels | ||||||
| { | { | ||||||
|     internal interface IItemFilterBlockViewModel |     internal interface IItemFilterBlockViewModel : IItemFilterBlockViewModelBase | ||||||
|     { |     { | ||||||
|         event EventHandler BlockBecameDirty; |  | ||||||
|         void Initialise(IItemFilterBlock itemFilterBlock, ItemFilterScriptViewModel parentScriptViewModel); |         void Initialise(IItemFilterBlock itemFilterBlock, ItemFilterScriptViewModel parentScriptViewModel); | ||||||
|         bool IsDirty { get; set; } |  | ||||||
|         bool IsExpanded { get; set; } |         bool IsExpanded { get; set; } | ||||||
|         IItemFilterBlock Block { get; } |         IItemFilterBlock Block { get; } | ||||||
|         bool BlockEnabled { get; set; } |         bool BlockEnabled { get; set; } | ||||||
| @ -27,7 +25,67 @@ namespace Filtration.ViewModels | |||||||
|         void RefreshBlockPreview(); |         void RefreshBlockPreview(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     internal class ItemFilterBlockViewModel : ViewModelBase, IItemFilterBlockViewModel |     internal interface IItemFilterBlockViewModelBase | ||||||
|  |     { | ||||||
|  |         IItemFilterBlockBase BaseBlock { get; } | ||||||
|  |         bool IsDirty { get; set; } | ||||||
|  |         event EventHandler BlockBecameDirty; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     internal abstract class ItemFilterBlockViewModelBase : ViewModelBase, IItemFilterBlockViewModelBase | ||||||
|  |     { | ||||||
|  |         private bool _isDirty; | ||||||
|  | 
 | ||||||
|  |         protected void Initialise(IItemFilterBlockBase itemfilterBlock) | ||||||
|  |         { | ||||||
|  |             BaseBlock = itemfilterBlock; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         public event EventHandler BlockBecameDirty; | ||||||
|  | 
 | ||||||
|  |         public IItemFilterBlockBase BaseBlock { get; protected set; } | ||||||
|  |          | ||||||
|  |         public bool IsDirty | ||||||
|  |         { | ||||||
|  |             get => _isDirty; | ||||||
|  |             set | ||||||
|  |             { | ||||||
|  |                 if (value != _isDirty) | ||||||
|  |                 { | ||||||
|  |                     _isDirty = value; | ||||||
|  |                     RaisePropertyChanged(); | ||||||
|  |                     BlockBecameDirty?.Invoke(this, EventArgs.Empty); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     internal interface IItemFilterCommentBlockViewModel : IItemFilterBlockViewModelBase | ||||||
|  |     { | ||||||
|  |         void Initialise(IItemFilterCommentBlock itemFilterCommentBlock); | ||||||
|  |         IItemFilterCommentBlock ItemFilterCommentBlock { get; } | ||||||
|  |         string Comment { get; } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     internal class ItemFilterCommentBlockViewModel : ItemFilterBlockViewModelBase, IItemFilterCommentBlockViewModel | ||||||
|  |     { | ||||||
|  |         public ItemFilterCommentBlockViewModel() | ||||||
|  |         { | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public void Initialise(IItemFilterCommentBlock itemFilterCommentBlock) | ||||||
|  |         { | ||||||
|  |             ItemFilterCommentBlock = itemFilterCommentBlock; | ||||||
|  |             BaseBlock = itemFilterCommentBlock; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public IItemFilterCommentBlock ItemFilterCommentBlock { get; private set; } | ||||||
|  | 
 | ||||||
|  |         public string Comment => ItemFilterCommentBlock.Comment; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     internal class ItemFilterBlockViewModel : ItemFilterBlockViewModelBase, IItemFilterBlockViewModel | ||||||
|     { |     { | ||||||
|         private readonly IStaticDataService _staticDataService; |         private readonly IStaticDataService _staticDataService; | ||||||
|         private readonly IReplaceColorsViewModel _replaceColorsViewModel; |         private readonly IReplaceColorsViewModel _replaceColorsViewModel; | ||||||
| @ -37,7 +95,6 @@ namespace Filtration.ViewModels | |||||||
|         private bool _displaySettingsPopupOpen; |         private bool _displaySettingsPopupOpen; | ||||||
|         private bool _isExpanded; |         private bool _isExpanded; | ||||||
|         private bool _audioVisualBlockItemsGridVisible; |         private bool _audioVisualBlockItemsGridVisible; | ||||||
|         private bool _isDirty; |  | ||||||
| 
 | 
 | ||||||
|         public ItemFilterBlockViewModel(IStaticDataService staticDataService, IReplaceColorsViewModel replaceColorsViewModel) |         public ItemFilterBlockViewModel(IStaticDataService staticDataService, IReplaceColorsViewModel replaceColorsViewModel) | ||||||
|         { |         { | ||||||
| @ -63,8 +120,6 @@ namespace Filtration.ViewModels | |||||||
|             PlaySoundCommand = new RelayCommand(OnPlaySoundCommand, () => HasSound); |             PlaySoundCommand = new RelayCommand(OnPlaySoundCommand, () => HasSound); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public event EventHandler BlockBecameDirty; |  | ||||||
| 
 |  | ||||||
|         public void Initialise(IItemFilterBlock itemFilterBlock, ItemFilterScriptViewModel parentScriptViewModel) |         public void Initialise(IItemFilterBlock itemFilterBlock, ItemFilterScriptViewModel parentScriptViewModel) | ||||||
|         { |         { | ||||||
|             if (itemFilterBlock == null || parentScriptViewModel == null) |             if (itemFilterBlock == null || parentScriptViewModel == null) | ||||||
| @ -75,51 +130,42 @@ namespace Filtration.ViewModels | |||||||
|             _parentScriptViewModel = parentScriptViewModel; |             _parentScriptViewModel = parentScriptViewModel; | ||||||
| 
 | 
 | ||||||
|             Block = itemFilterBlock; |             Block = itemFilterBlock; | ||||||
|  | 
 | ||||||
|             itemFilterBlock.BlockItems.CollectionChanged += OnBlockItemsCollectionChanged; |             itemFilterBlock.BlockItems.CollectionChanged += OnBlockItemsCollectionChanged; | ||||||
| 
 | 
 | ||||||
|             foreach (var blockItem in itemFilterBlock.BlockItems) |             foreach (var blockItem in itemFilterBlock.BlockItems) | ||||||
|             { |             { | ||||||
|                 blockItem.PropertyChanged += OnBlockItemChanged; |                 blockItem.PropertyChanged += OnBlockItemChanged; | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             base.Initialise(itemFilterBlock); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public RelayCommand CopyBlockCommand { get; private set; } |         public RelayCommand CopyBlockCommand { get; } | ||||||
|         public RelayCommand PasteBlockCommand { get; private set; } |         public RelayCommand PasteBlockCommand { get; } | ||||||
|         public RelayCommand CopyBlockStyleCommand { get; private set; } |         public RelayCommand CopyBlockStyleCommand { get; } | ||||||
|         public RelayCommand PasteBlockStyleCommand { get; private set; } |         public RelayCommand PasteBlockStyleCommand { get; } | ||||||
|         public RelayCommand AddBlockCommand { get; private set; } |         public RelayCommand AddBlockCommand { get; } | ||||||
|         public RelayCommand AddSectionCommand { get; private set; } |         public RelayCommand AddSectionCommand { get; } | ||||||
|         public RelayCommand DeleteBlockCommand { get; private set; } |         public RelayCommand DeleteBlockCommand { get; } | ||||||
|         public RelayCommand MoveBlockUpCommand { get; private set; } |         public RelayCommand MoveBlockUpCommand { get; } | ||||||
|         public RelayCommand MoveBlockDownCommand { get; private set; } |         public RelayCommand MoveBlockDownCommand { get; } | ||||||
|         public RelayCommand MoveBlockToTopCommand { get; private set; } |         public RelayCommand MoveBlockToTopCommand { get; } | ||||||
|         public RelayCommand MoveBlockToBottomCommand { get; private set; } |         public RelayCommand MoveBlockToBottomCommand { get; } | ||||||
|         public RelayCommand ToggleBlockActionCommand { get; private set; } |         public RelayCommand ToggleBlockActionCommand { get; } | ||||||
|         public RelayCommand ReplaceColorsCommand { get; private set; } |         public RelayCommand ReplaceColorsCommand { get; } | ||||||
|         public RelayCommand<Type> AddFilterBlockItemCommand { get; private set; } |         public RelayCommand<Type> AddFilterBlockItemCommand { get; } | ||||||
|         public RelayCommand<IItemFilterBlockItem> RemoveFilterBlockItemCommand { get; private set; } |         public RelayCommand<IItemFilterBlockItem> RemoveFilterBlockItemCommand { get; } | ||||||
|         public RelayCommand PlaySoundCommand { get; private set; } |         public RelayCommand PlaySoundCommand { get; } | ||||||
|         public RelayCommand SwitchBlockItemsViewCommand { get; private set; } |         public RelayCommand SwitchBlockItemsViewCommand { get; } | ||||||
| 
 | 
 | ||||||
|         public IItemFilterBlock Block { get; private set; } |         public IItemFilterBlock Block { get; private set; } | ||||||
| 
 | 
 | ||||||
|         public bool IsDirty |  | ||||||
|         { |  | ||||||
|             get { return _isDirty; } |  | ||||||
|             set |  | ||||||
|             { |  | ||||||
|                 if (value != _isDirty) |  | ||||||
|                 { |  | ||||||
|                     _isDirty = value; |  | ||||||
|                     RaisePropertyChanged(); |  | ||||||
|                     BlockBecameDirty?.Invoke(this, EventArgs.Empty); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         public bool IsExpanded |         public bool IsExpanded | ||||||
|         { |         { | ||||||
|             get { return _isExpanded; } |             get => _isExpanded; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 _isExpanded = value; |                 _isExpanded = value; | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ | |||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Collections.ObjectModel; | using System.Collections.ObjectModel; | ||||||
| using System.ComponentModel; | using System.ComponentModel; | ||||||
|  | using System.Diagnostics; | ||||||
| using System.IO; | using System.IO; | ||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
| @ -25,9 +26,9 @@ namespace Filtration.ViewModels | |||||||
|     internal interface IItemFilterScriptViewModel : IEditableDocument |     internal interface IItemFilterScriptViewModel : IEditableDocument | ||||||
|     { |     { | ||||||
|         ItemFilterScript Script { get; } |         ItemFilterScript Script { get; } | ||||||
|         IItemFilterBlockViewModel SelectedBlockViewModel { get; set; } |         IItemFilterBlockViewModelBase SelectedBlockViewModel { get; set; } | ||||||
|         IItemFilterBlockViewModel SectionBrowserSelectedBlockViewModel { get; set; } |         IItemFilterCommentBlockViewModel CommentBlockBrowserBrowserSelectedBlockViewModel { get; set; } | ||||||
|         IEnumerable<IItemFilterBlockViewModel> ItemFilterSectionViewModels { get; } |         IEnumerable<IItemFilterCommentBlockViewModel> ItemFilterCommentBlockViewModels { get; } | ||||||
|         Predicate<IItemFilterBlockViewModel> BlockFilterPredicate { get; set; } |         Predicate<IItemFilterBlockViewModel> BlockFilterPredicate { get; set; } | ||||||
|          |          | ||||||
|         bool ShowAdvanced { get; } |         bool ShowAdvanced { get; } | ||||||
| @ -58,11 +59,11 @@ namespace Filtration.ViewModels | |||||||
|         RelayCommand<bool> ToggleShowAdvancedCommand { get; } |         RelayCommand<bool> ToggleShowAdvancedCommand { get; } | ||||||
|         RelayCommand ClearFilterCommand { get; } |         RelayCommand ClearFilterCommand { get; } | ||||||
| 
 | 
 | ||||||
|         void AddSection(IItemFilterBlockViewModel targetBlockViewModel); |         void AddSection(IItemFilterBlockViewModelBase targetBlockViewModel); | ||||||
|         void AddBlock(IItemFilterBlockViewModel targetBlockViewModel); |         void AddBlock(IItemFilterBlockViewModelBase targetBlockViewModel); | ||||||
|         void CopyBlock(IItemFilterBlockViewModel targetBlockViewModel); |         void CopyBlock(IItemFilterBlockViewModelBase targetBlockViewModel); | ||||||
|         void CopyBlockStyle(IItemFilterBlockViewModel targetBlockViewModel); |         void CopyBlockStyle(IItemFilterBlockViewModel targetBlockViewModel); | ||||||
|         void PasteBlock(IItemFilterBlockViewModel targetBlockViewModel); |         void PasteBlock(IItemFilterBlockViewModelBase targetBlockViewModel); | ||||||
|         void PasteBlockStyle(IItemFilterBlockViewModel targetBlockViewModel); |         void PasteBlockStyle(IItemFilterBlockViewModel targetBlockViewModel); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -72,6 +73,7 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         private readonly IItemFilterBlockViewModelFactory _itemFilterBlockViewModelFactory; |         private readonly IItemFilterBlockViewModelFactory _itemFilterBlockViewModelFactory; | ||||||
|         private readonly IItemFilterBlockTranslator _blockTranslator; |         private readonly IItemFilterBlockTranslator _blockTranslator; | ||||||
|  |         private readonly IItemFilterCommentBlockViewModelFactory _itemFilterCommentBlockViewModelFactory; | ||||||
|         private readonly IAvalonDockWorkspaceViewModel _avalonDockWorkspaceViewModel; |         private readonly IAvalonDockWorkspaceViewModel _avalonDockWorkspaceViewModel; | ||||||
|         private readonly IItemFilterPersistenceService _persistenceService; |         private readonly IItemFilterPersistenceService _persistenceService; | ||||||
|         private readonly IMessageBoxService _messageBoxService; |         private readonly IMessageBoxService _messageBoxService; | ||||||
| @ -79,14 +81,15 @@ namespace Filtration.ViewModels | |||||||
|         private readonly IBlockGroupHierarchyBuilder _blockGroupHierarchyBuilder; |         private readonly IBlockGroupHierarchyBuilder _blockGroupHierarchyBuilder; | ||||||
| 
 | 
 | ||||||
|         private bool _isDirty; |         private bool _isDirty; | ||||||
|         private IItemFilterBlockViewModel _selectedBlockViewModel; |         private IItemFilterBlockViewModelBase _selectedBlockViewModel; | ||||||
|         private IItemFilterBlockViewModel _sectionBrowserSelectedBlockViewModel; |         private IItemFilterCommentBlockViewModel _sectionBrowserSelectedBlockViewModel; | ||||||
|         private readonly ObservableCollection<IItemFilterBlockViewModel> _itemFilterBlockViewModels; |         private readonly ObservableCollection<IItemFilterBlockViewModelBase> _itemFilterBlockViewModels; | ||||||
|         private ICollectionView _itemFilterBlockViewModelsCollectionView; |         private ICollectionView _itemFilterBlockViewModelsCollectionView; | ||||||
|         private Predicate<IItemFilterBlockViewModel> _blockFilterPredicate; |         private Predicate<IItemFilterBlockViewModel> _blockFilterPredicate; | ||||||
| 
 | 
 | ||||||
|         public ItemFilterScriptViewModel(IItemFilterBlockViewModelFactory itemFilterBlockViewModelFactory, |         public ItemFilterScriptViewModel(IItemFilterBlockViewModelFactory itemFilterBlockViewModelFactory, | ||||||
|                                          IItemFilterBlockTranslator blockTranslator, |                                          IItemFilterBlockTranslator blockTranslator, | ||||||
|  |                                          IItemFilterCommentBlockViewModelFactory itemFilterCommentBlockViewModelFactory, | ||||||
|                                          IAvalonDockWorkspaceViewModel avalonDockWorkspaceViewModel, |                                          IAvalonDockWorkspaceViewModel avalonDockWorkspaceViewModel, | ||||||
|                                          IItemFilterPersistenceService persistenceService, |                                          IItemFilterPersistenceService persistenceService, | ||||||
|                                          IMessageBoxService messageBoxService, |                                          IMessageBoxService messageBoxService, | ||||||
| @ -95,14 +98,20 @@ namespace Filtration.ViewModels | |||||||
|         { |         { | ||||||
|             _itemFilterBlockViewModelFactory = itemFilterBlockViewModelFactory; |             _itemFilterBlockViewModelFactory = itemFilterBlockViewModelFactory; | ||||||
|             _blockTranslator = blockTranslator; |             _blockTranslator = blockTranslator; | ||||||
|  |             _itemFilterCommentBlockViewModelFactory = itemFilterCommentBlockViewModelFactory; | ||||||
|             _avalonDockWorkspaceViewModel = avalonDockWorkspaceViewModel; |             _avalonDockWorkspaceViewModel = avalonDockWorkspaceViewModel; | ||||||
|             _avalonDockWorkspaceViewModel.ActiveDocumentChanged += OnActiveDocumentChanged; |             _avalonDockWorkspaceViewModel.ActiveDocumentChanged += OnActiveDocumentChanged; | ||||||
|             _persistenceService = persistenceService; |             _persistenceService = persistenceService; | ||||||
|             _messageBoxService = messageBoxService; |             _messageBoxService = messageBoxService; | ||||||
|             _clipboardService = clipboardService; |             _clipboardService = clipboardService; | ||||||
|             _blockGroupHierarchyBuilder = blockGroupHierarchyBuilder; |             _blockGroupHierarchyBuilder = blockGroupHierarchyBuilder; | ||||||
|             _itemFilterBlockViewModels = new ObservableCollection<IItemFilterBlockViewModel>(); |             _itemFilterBlockViewModels = new ObservableCollection<IItemFilterBlockViewModelBase>(); | ||||||
|              | 
 | ||||||
|  |             _avalonDockWorkspaceViewModel.ActiveDocumentChanged += (s, e) => | ||||||
|  |             { | ||||||
|  |                 RaisePropertyChanged(nameof(IsActiveDocument)); | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|             ToggleShowAdvancedCommand = new RelayCommand<bool>(OnToggleShowAdvancedCommand); |             ToggleShowAdvancedCommand = new RelayCommand<bool>(OnToggleShowAdvancedCommand); | ||||||
|             ClearFilterCommand = new RelayCommand(OnClearFilterCommand, () => BlockFilterPredicate != null); |             ClearFilterCommand = new RelayCommand(OnClearFilterCommand, () => BlockFilterPredicate != null); | ||||||
|             CloseCommand = new RelayCommand(async () => await OnCloseCommand()); |             CloseCommand = new RelayCommand(async () => await OnCloseCommand()); | ||||||
| @ -148,7 +157,19 @@ namespace Filtration.ViewModels | |||||||
|         public RelayCommand ExpandAllBlocksCommand { get; } |         public RelayCommand ExpandAllBlocksCommand { get; } | ||||||
|         public RelayCommand CollapseAllBlocksCommand { get; } |         public RelayCommand CollapseAllBlocksCommand { get; } | ||||||
| 
 | 
 | ||||||
|         public ObservableCollection<IItemFilterBlockViewModel> ItemFilterBlockViewModels |         public bool IsActiveDocument | ||||||
|  |         { | ||||||
|  |             get | ||||||
|  |             { | ||||||
|  |                 var isActiveDocument = _avalonDockWorkspaceViewModel.ActiveScriptViewModel == this; | ||||||
|  |                 Debug.WriteLine($"IsActiveDocument: {isActiveDocument}"); | ||||||
|  | 
 | ||||||
|  |                 return isActiveDocument; | ||||||
|  | 
 | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public ObservableCollection<IItemFilterBlockViewModelBase> ItemFilterBlockViewModels | ||||||
|         { |         { | ||||||
|             get |             get | ||||||
|             { |             { | ||||||
| @ -162,6 +183,8 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         private bool BlockFilter(object item) |         private bool BlockFilter(object item) | ||||||
|         { |         { | ||||||
|  |             if (!(item is IItemFilterBlockViewModelBase)) return false; | ||||||
|  |             if (item is IItemFilterCommentBlockViewModel) return true; | ||||||
|             var blockViewModel = item as IItemFilterBlockViewModel; |             var blockViewModel = item as IItemFilterBlockViewModel; | ||||||
| 
 | 
 | ||||||
|             if (BlockFilterPredicate != null) |             if (BlockFilterPredicate != null) | ||||||
| @ -190,25 +213,22 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         public Predicate<IItemFilterBlockViewModel> BlockFilterPredicate |         public Predicate<IItemFilterBlockViewModel> BlockFilterPredicate | ||||||
|         { |         { | ||||||
|             get { return _blockFilterPredicate; } |             get => _blockFilterPredicate; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 _blockFilterPredicate = value; |                 _blockFilterPredicate = value; | ||||||
|                 RaisePropertyChanged("ItemFilterBlockViewModels"); |                 RaisePropertyChanged(nameof(ItemFilterBlockViewModels)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IEnumerable<IItemFilterBlockViewModel> ItemFilterSectionViewModels |         public IEnumerable<IItemFilterCommentBlockViewModel> ItemFilterCommentBlockViewModels => ItemFilterBlockViewModels.OfType<IItemFilterCommentBlockViewModel>(); | ||||||
|         { |  | ||||||
|             get { return ItemFilterBlockViewModels.Where(b => b.Block.GetType() == typeof (ItemFilterSection)); } |  | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         public bool IsScript => true; |         public bool IsScript => true; | ||||||
|         public bool IsTheme => false; |         public bool IsTheme => false; | ||||||
| 
 | 
 | ||||||
|         public string Description |         public string Description | ||||||
|         { |         { | ||||||
|             get { return Script.Description; } |             get => Script.Description; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 Script.Description = value; |                 Script.Description = value; | ||||||
| @ -219,33 +239,39 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         public bool ShowAdvanced |         public bool ShowAdvanced | ||||||
|         { |         { | ||||||
|             get { return _showAdvanced; } |             get => _showAdvanced; | ||||||
|             private set |             private set | ||||||
|             { |             { | ||||||
|                 _showAdvanced = value; |                 _showAdvanced = value; | ||||||
|                 RaisePropertyChanged(); |                 RaisePropertyChanged(); | ||||||
|                 RaisePropertyChanged("ItemFilterBlockViewModels"); |                 RaisePropertyChanged(nameof(ItemFilterBlockViewModels)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public bool HasSelectedBlock() |  | ||||||
|         { |  | ||||||
|             return SelectedBlockViewModel != null; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public bool HasSelectedEnabledBlock() |         public bool HasSelectedEnabledBlock() | ||||||
|         { |         { | ||||||
|             return HasSelectedBlock() && !(SelectedBlockViewModel.Block is ItemFilterSection) && SelectedBlockViewModel.BlockEnabled; |             var selectedBlockViewModel = SelectedBlockViewModel as IItemFilterBlockViewModel; | ||||||
|  |             if (selectedBlockViewModel == null) return false; | ||||||
|  | 
 | ||||||
|  |             return HasSelectedBlock() && selectedBlockViewModel.BlockEnabled; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public bool HasSelectedDisabledBlock() |         public bool HasSelectedDisabledBlock() | ||||||
|         { |         { | ||||||
|             return HasSelectedBlock() && !(SelectedBlockViewModel.Block is ItemFilterSection) && !SelectedBlockViewModel.BlockEnabled; |             var selectedBlockViewModel = SelectedBlockViewModel as IItemFilterBlockViewModel; | ||||||
|  |             if (selectedBlockViewModel == null) return false; | ||||||
|  | 
 | ||||||
|  |             return HasSelectedBlock() && !selectedBlockViewModel.BlockEnabled; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IItemFilterBlockViewModel SelectedBlockViewModel |         private bool HasSelectedBlock() | ||||||
|         { |         { | ||||||
|             get { return _selectedBlockViewModel; } |             return SelectedBlockViewModel != null; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public IItemFilterBlockViewModelBase SelectedBlockViewModel | ||||||
|  |         { | ||||||
|  |             get => _selectedBlockViewModel; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 if (value != _selectedBlockViewModel) |                 if (value != _selectedBlockViewModel) | ||||||
| @ -257,9 +283,9 @@ namespace Filtration.ViewModels | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IItemFilterBlockViewModel SectionBrowserSelectedBlockViewModel |         public IItemFilterCommentBlockViewModel CommentBlockBrowserBrowserSelectedBlockViewModel | ||||||
|         { |         { | ||||||
|             get { return _sectionBrowserSelectedBlockViewModel; } |             get => _sectionBrowserSelectedBlockViewModel; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 _sectionBrowserSelectedBlockViewModel = value; |                 _sectionBrowserSelectedBlockViewModel = value; | ||||||
| @ -272,7 +298,7 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         public bool IsDirty |         public bool IsDirty | ||||||
|         { |         { | ||||||
|             get { return _isDirty || HasDirtyChildren; } |             get => _isDirty || HasDirtyChildren; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 if (_isDirty != value) |                 if (_isDirty != value) | ||||||
| @ -295,15 +321,15 @@ namespace Filtration.ViewModels | |||||||
|         { |         { | ||||||
|             CleanChildren(); |             CleanChildren(); | ||||||
|             IsDirty = false; |             IsDirty = false; | ||||||
|             RaisePropertyChanged("Filename"); |             RaisePropertyChanged(nameof(Filename)); | ||||||
|             RaisePropertyChanged("DisplayName"); |             RaisePropertyChanged(nameof(DisplayName)); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void SetDirtyFlag() |         public void SetDirtyFlag() | ||||||
|         { |         { | ||||||
|             IsDirty = true; |             IsDirty = true; | ||||||
|             RaisePropertyChanged("Filename"); |             RaisePropertyChanged(nameof(Filename)); | ||||||
|             RaisePropertyChanged("DisplayName"); |             RaisePropertyChanged(nameof(DisplayName)); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public string DisplayName => !string.IsNullOrEmpty(Filename) ? Filename : Description; |         public string DisplayName => !string.IsNullOrEmpty(Filename) ? Filename : Description; | ||||||
| @ -320,14 +346,32 @@ namespace Filtration.ViewModels | |||||||
|             ItemFilterBlockViewModels.Clear(); |             ItemFilterBlockViewModels.Clear(); | ||||||
| 
 | 
 | ||||||
|             Script = itemFilterScript; |             Script = itemFilterScript; | ||||||
|             foreach (var block in Script.ItemFilterBlocks.OfType<ItemFilterBlock>()) | 
 | ||||||
|  |             foreach (var block in Script.ItemFilterBlocks) | ||||||
|             { |             { | ||||||
|                 var vm = _itemFilterBlockViewModelFactory.Create(); |                 var itemFilterBlock = block as IItemFilterBlock; | ||||||
|                 vm.Initialise(block, this); |                 if (itemFilterBlock != null) | ||||||
|                 vm.BlockBecameDirty += OnBlockBecameDirty; |                 { | ||||||
|                 ItemFilterBlockViewModels.Add(vm); |                     var itemFilterBlockViewModel = _itemFilterBlockViewModelFactory.Create(); | ||||||
|  |                     itemFilterBlockViewModel.Initialise(itemFilterBlock, this); | ||||||
|  |                     itemFilterBlockViewModel.BlockBecameDirty += OnBlockBecameDirty; | ||||||
|  |                     ItemFilterBlockViewModels.Add(itemFilterBlockViewModel); | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 var itemFilterCommentBlock = block as IItemFilterCommentBlock; | ||||||
|  |                 if (itemFilterCommentBlock == null) | ||||||
|  |                 { | ||||||
|  |                     throw new InvalidOperationException("Unknown item filter block type"); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |                 var itemFilterCommentBlockViewModel = _itemFilterCommentBlockViewModelFactory.Create(); | ||||||
|  |                 itemFilterCommentBlockViewModel.Initialise(itemFilterCommentBlock); | ||||||
|  |                 itemFilterCommentBlockViewModel.BlockBecameDirty += OnBlockBecameDirty; | ||||||
|  |                 ItemFilterBlockViewModels.Add(itemFilterCommentBlockViewModel); | ||||||
|             } |             } | ||||||
|             | 
 | ||||||
|             _filenameIsFake = newScript; |             _filenameIsFake = newScript; | ||||||
| 
 | 
 | ||||||
|             if (newScript) |             if (newScript) | ||||||
| @ -550,12 +594,11 @@ namespace Filtration.ViewModels | |||||||
|             CopyBlock(SelectedBlockViewModel); |             CopyBlock(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void CopyBlock(IItemFilterBlockViewModel targetBlockViewModel) |         public void CopyBlock(IItemFilterBlockViewModelBase targetBlockViewModel) | ||||||
|         { |         { | ||||||
|             try |             try | ||||||
|             { |             { | ||||||
|                 _clipboardService.SetClipboardText( |                 _clipboardService.SetClipboardText(_blockTranslator.TranslateItemFilterBlockBaseToString(SelectedBlockViewModel.BaseBlock)); | ||||||
|                     _blockTranslator.TranslateItemFilterBlockToString(SelectedBlockViewModel.Block)); |  | ||||||
|             } |             } | ||||||
|             catch |             catch | ||||||
|             { |             { | ||||||
| @ -566,7 +609,11 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         private void OnCopyBlockStyleCommand() |         private void OnCopyBlockStyleCommand() | ||||||
|         { |         { | ||||||
|             CopyBlockStyle(SelectedBlockViewModel); |             var selectedBlockViewModel = SelectedBlockViewModel as IItemFilterBlockViewModel; | ||||||
|  |             if (selectedBlockViewModel != null) | ||||||
|  |             { | ||||||
|  |                 CopyBlockStyle(selectedBlockViewModel); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void CopyBlockStyle(IItemFilterBlockViewModel targetBlockViewModel) |         public void CopyBlockStyle(IItemFilterBlockViewModel targetBlockViewModel) | ||||||
| @ -594,7 +641,11 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         private void OnPasteBlockStyleCommand() |         private void OnPasteBlockStyleCommand() | ||||||
|         { |         { | ||||||
|             PasteBlockStyle(SelectedBlockViewModel); |             var selectedBlockViewModel = SelectedBlockViewModel as IItemFilterBlockViewModel; | ||||||
|  |             if (selectedBlockViewModel != null) | ||||||
|  |             { | ||||||
|  |                 PasteBlockStyle(selectedBlockViewModel); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void PasteBlockStyle(IItemFilterBlockViewModel targetBlockViewModel) |         public void PasteBlockStyle(IItemFilterBlockViewModel targetBlockViewModel) | ||||||
| @ -614,7 +665,7 @@ namespace Filtration.ViewModels | |||||||
|             PasteBlock(SelectedBlockViewModel); |             PasteBlock(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void PasteBlock(IItemFilterBlockViewModel targetBlockViewModel) |         public void PasteBlock(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             try |             try | ||||||
|             { |             { | ||||||
| @ -630,9 +681,9 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|                 if (ItemFilterBlockViewModels.Count > 0) |                 if (ItemFilterBlockViewModels.Count > 0) | ||||||
|                 { |                 { | ||||||
|                     Script.ItemFilterBlocks.Insert(Script.ItemFilterBlocks.IndexOf(targetBlockViewModel.Block) + 1, |                     Script.ItemFilterBlocks.Insert(Script.ItemFilterBlocks.IndexOf(targetBlockViewModelBase.BaseBlock) + 1, | ||||||
|                         translatedBlock); |                         translatedBlock); | ||||||
|                     ItemFilterBlockViewModels.Insert(ItemFilterBlockViewModels.IndexOf(targetBlockViewModel) + 1, vm); |                     ItemFilterBlockViewModels.Insert(ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase) + 1, vm); | ||||||
|                 } |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
| @ -661,18 +712,18 @@ namespace Filtration.ViewModels | |||||||
|             MoveBlockToTop(SelectedBlockViewModel); |             MoveBlockToTop(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void MoveBlockToTop(IItemFilterBlockViewModel targetBlockViewModel) |         public void MoveBlockToTop(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModel); |             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase); | ||||||
| 
 | 
 | ||||||
|             if (currentIndex > 0) |             if (currentIndex > 0) | ||||||
|             { |             { | ||||||
|                 var block = targetBlockViewModel.Block; |                 var block = targetBlockViewModelBase.BaseBlock; | ||||||
|                 Script.ItemFilterBlocks.Remove(block); |                 Script.ItemFilterBlocks.Remove(block); | ||||||
|                 Script.ItemFilterBlocks.Insert(0, block); |                 Script.ItemFilterBlocks.Insert(0, block); | ||||||
|                 ItemFilterBlockViewModels.Move(currentIndex, 0); |                 ItemFilterBlockViewModels.Move(currentIndex, 0); | ||||||
|                 IsDirty = true; |                 IsDirty = true; | ||||||
|                 RaisePropertyChanged(nameof(ItemFilterSectionViewModels)); |                 RaisePropertyChanged(nameof(ItemFilterCommentBlockViewModels)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -681,19 +732,19 @@ namespace Filtration.ViewModels | |||||||
|             MoveBlockUp(SelectedBlockViewModel); |             MoveBlockUp(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void MoveBlockUp(IItemFilterBlockViewModel targetBlockViewModel) |         public void MoveBlockUp(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModel); |             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase); | ||||||
| 
 | 
 | ||||||
|             if (currentIndex > 0) |             if (currentIndex > 0) | ||||||
|             { |             { | ||||||
|                 var block = targetBlockViewModel.Block; |                 var block = targetBlockViewModelBase.BaseBlock; | ||||||
|                 var blockPos = Script.ItemFilterBlocks.IndexOf(block); |                 var blockPos = Script.ItemFilterBlocks.IndexOf(block); | ||||||
|                 Script.ItemFilterBlocks.RemoveAt(blockPos); |                 Script.ItemFilterBlocks.RemoveAt(blockPos); | ||||||
|                 Script.ItemFilterBlocks.Insert(blockPos - 1, block); |                 Script.ItemFilterBlocks.Insert(blockPos - 1, block); | ||||||
|                 ItemFilterBlockViewModels.Move(currentIndex, currentIndex - 1); |                 ItemFilterBlockViewModels.Move(currentIndex, currentIndex - 1); | ||||||
|                 IsDirty = true; |                 IsDirty = true; | ||||||
|                 RaisePropertyChanged(nameof(ItemFilterSectionViewModels)); |                 RaisePropertyChanged(nameof(ItemFilterCommentBlockViewModels)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -702,19 +753,19 @@ namespace Filtration.ViewModels | |||||||
|             MoveBlockDown(SelectedBlockViewModel); |             MoveBlockDown(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void MoveBlockDown(IItemFilterBlockViewModel targetBlockViewModel) |         public void MoveBlockDown(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModel); |             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase); | ||||||
| 
 | 
 | ||||||
|             if (currentIndex < ItemFilterBlockViewModels.Count - 1) |             if (currentIndex < ItemFilterBlockViewModels.Count - 1) | ||||||
|             { |             { | ||||||
|                 var block = targetBlockViewModel.Block; |                 var block = targetBlockViewModelBase.BaseBlock; | ||||||
|                 var blockPos = Script.ItemFilterBlocks.IndexOf(block); |                 var blockPos = Script.ItemFilterBlocks.IndexOf(block); | ||||||
|                 Script.ItemFilterBlocks.RemoveAt(blockPos); |                 Script.ItemFilterBlocks.RemoveAt(blockPos); | ||||||
|                 Script.ItemFilterBlocks.Insert(blockPos + 1, block); |                 Script.ItemFilterBlocks.Insert(blockPos + 1, block); | ||||||
|                 ItemFilterBlockViewModels.Move(currentIndex, currentIndex + 1); |                 ItemFilterBlockViewModels.Move(currentIndex, currentIndex + 1); | ||||||
|                 IsDirty = true; |                 IsDirty = true; | ||||||
|                 RaisePropertyChanged(nameof(ItemFilterSectionViewModels)); |                 RaisePropertyChanged(nameof(ItemFilterCommentBlockViewModels)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -723,18 +774,18 @@ namespace Filtration.ViewModels | |||||||
|             MoveBlockToBottom(SelectedBlockViewModel); |             MoveBlockToBottom(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void MoveBlockToBottom(IItemFilterBlockViewModel targetBlockViewModel) |         public void MoveBlockToBottom(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModel); |             var currentIndex = ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase); | ||||||
| 
 | 
 | ||||||
|             if (currentIndex < ItemFilterBlockViewModels.Count - 1) |             if (currentIndex < ItemFilterBlockViewModels.Count - 1) | ||||||
|             { |             { | ||||||
|                 var block = targetBlockViewModel.Block; |                 var block = targetBlockViewModelBase.BaseBlock; | ||||||
|                 Script.ItemFilterBlocks.Remove(block); |                 Script.ItemFilterBlocks.Remove(block); | ||||||
|                 Script.ItemFilterBlocks.Add(block); |                 Script.ItemFilterBlocks.Add(block); | ||||||
|                 ItemFilterBlockViewModels.Move(currentIndex, ItemFilterBlockViewModels.Count - 1); |                 ItemFilterBlockViewModels.Move(currentIndex, ItemFilterBlockViewModels.Count - 1); | ||||||
|                 IsDirty = true; |                 IsDirty = true; | ||||||
|                 RaisePropertyChanged(nameof(ItemFilterSectionViewModels)); |                 RaisePropertyChanged(nameof(ItemFilterCommentBlockViewModels)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -743,16 +794,16 @@ namespace Filtration.ViewModels | |||||||
|             AddBlock(SelectedBlockViewModel); |             AddBlock(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void AddBlock(IItemFilterBlockViewModel targetBlockViewModel) |         public void AddBlock(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var vm = _itemFilterBlockViewModelFactory.Create(); |             var vm = _itemFilterBlockViewModelFactory.Create(); | ||||||
|             var newBlock = new ItemFilterBlock(); |             var newBlock = new ItemFilterBlock(); | ||||||
|             vm.Initialise(newBlock, this); |             vm.Initialise(newBlock, this); | ||||||
| 
 | 
 | ||||||
|             if (targetBlockViewModel != null) |             if (targetBlockViewModelBase != null) | ||||||
|             { |             { | ||||||
|                 Script.ItemFilterBlocks.Insert(Script.ItemFilterBlocks.IndexOf(targetBlockViewModel.Block) + 1, newBlock); |                 Script.ItemFilterBlocks.Insert(Script.ItemFilterBlocks.IndexOf(targetBlockViewModelBase.BaseBlock) + 1, newBlock); | ||||||
|                 ItemFilterBlockViewModels.Insert(ItemFilterBlockViewModels.IndexOf(targetBlockViewModel) + 1, vm); |                 ItemFilterBlockViewModels.Insert(ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase) + 1, vm); | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
| @ -776,23 +827,23 @@ namespace Filtration.ViewModels | |||||||
|             AddSection(SelectedBlockViewModel); |             AddSection(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         public void AddSection(IItemFilterBlockViewModel targetBlockViewModel) |         public void AddSection(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var vm = _itemFilterBlockViewModelFactory.Create(); |             var vm = _itemFilterCommentBlockViewModelFactory.Create(); | ||||||
|             var newSection = new ItemFilterSection { Description = "New Section" }; |             var newSection = new ItemFilterCommentBlock { Comment = "New Comment Block" }; | ||||||
|             vm.Initialise(newSection, this); |             vm.Initialise(newSection); | ||||||
| 
 | 
 | ||||||
|             Script.ItemFilterBlocks.Insert(Script.ItemFilterBlocks.IndexOf(targetBlockViewModel.Block), newSection); |             Script.ItemFilterBlocks.Insert(Script.ItemFilterBlocks.IndexOf(targetBlockViewModelBase.BaseBlock), newSection); | ||||||
|             ItemFilterBlockViewModels.Insert(ItemFilterBlockViewModels.IndexOf(targetBlockViewModel), vm); |             ItemFilterBlockViewModels.Insert(ItemFilterBlockViewModels.IndexOf(targetBlockViewModelBase), vm); | ||||||
|             IsDirty = true; |             IsDirty = true; | ||||||
|             SelectedBlockViewModel = vm; |             SelectedBlockViewModel = vm; | ||||||
|             RaisePropertyChanged(nameof(ItemFilterSectionViewModels)); |             RaisePropertyChanged(nameof(ItemFilterCommentBlockViewModels)); | ||||||
|             Messenger.Default.Send(new NotificationMessage("SectionsChanged")); |             Messenger.Default.Send(new NotificationMessage("SectionsChanged")); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void OnExpandAllBlocksCommand() |         private void OnExpandAllBlocksCommand() | ||||||
|         { |         { | ||||||
|             foreach (var blockViewModel in ItemFilterBlockViewModels) |             foreach (var blockViewModel in ItemFilterBlockViewModels.OfType<IItemFilterBlockViewModel>()) | ||||||
|             { |             { | ||||||
|                 blockViewModel.IsExpanded = true; |                 blockViewModel.IsExpanded = true; | ||||||
|             } |             } | ||||||
| @ -800,7 +851,7 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         private void OnCollapseAllBlocksCommand() |         private void OnCollapseAllBlocksCommand() | ||||||
|         { |         { | ||||||
|             foreach (var blockViewModel in ItemFilterBlockViewModels) |             foreach (var blockViewModel in ItemFilterBlockViewModels.OfType<IItemFilterBlockViewModel>()) | ||||||
|             { |             { | ||||||
|                 blockViewModel.IsExpanded = false; |                 blockViewModel.IsExpanded = false; | ||||||
|             } |             } | ||||||
| @ -811,7 +862,7 @@ namespace Filtration.ViewModels | |||||||
|             DeleteBlock(SelectedBlockViewModel); |             DeleteBlock(SelectedBlockViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void DeleteBlock(IItemFilterBlockViewModel targetBlockViewModel) |         public void DeleteBlock(IItemFilterBlockViewModelBase targetBlockViewModelBase) | ||||||
|         { |         { | ||||||
|             var result = _messageBoxService.Show("Delete Confirmation", "Are you sure you wish to delete this block?", |             var result = _messageBoxService.Show("Delete Confirmation", "Are you sure you wish to delete this block?", | ||||||
|                 MessageBoxButton.YesNo, |                 MessageBoxButton.YesNo, | ||||||
| @ -819,13 +870,13 @@ namespace Filtration.ViewModels | |||||||
|              |              | ||||||
|             if (result == MessageBoxResult.Yes) |             if (result == MessageBoxResult.Yes) | ||||||
|             { |             { | ||||||
|                 var isSection = targetBlockViewModel.Block is ItemFilterSection; |                 var isSection = targetBlockViewModelBase.BaseBlock is ItemFilterCommentBlock; | ||||||
| 
 | 
 | ||||||
|                 Script.ItemFilterBlocks.Remove(targetBlockViewModel.Block); |                 Script.ItemFilterBlocks.Remove(targetBlockViewModelBase.BaseBlock); | ||||||
|                 ItemFilterBlockViewModels.Remove(targetBlockViewModel); |                 ItemFilterBlockViewModels.Remove(targetBlockViewModelBase); | ||||||
|                 IsDirty = true; |                 IsDirty = true; | ||||||
| 
 | 
 | ||||||
|                 targetBlockViewModel.BlockBecameDirty -= OnBlockBecameDirty; |                 targetBlockViewModelBase.BlockBecameDirty -= OnBlockBecameDirty; | ||||||
| 
 | 
 | ||||||
|                 if (isSection) |                 if (isSection) | ||||||
|                 { |                 { | ||||||
| @ -838,22 +889,20 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         private void OnDisableBlockCommand() |         private void OnDisableBlockCommand() | ||||||
|         { |         { | ||||||
|             DisableBlock(SelectedBlockViewModel); |             var selectedBlockViewModel = SelectedBlockViewModel as IItemFilterBlockViewModel; | ||||||
|         } |             if (selectedBlockViewModel != null) | ||||||
| 
 |             { | ||||||
|         private void DisableBlock(IItemFilterBlockViewModel targetBlockViewModel) |                 selectedBlockViewModel.BlockEnabled = false; | ||||||
|         { |             } | ||||||
|             targetBlockViewModel.BlockEnabled = false; |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void OnEnableBlockCommand() |         private void OnEnableBlockCommand() | ||||||
|         { |         { | ||||||
|             EnableBlock(SelectedBlockViewModel); |             var selectedBlockViewModel = SelectedBlockViewModel as IItemFilterBlockViewModel; | ||||||
|         } |             if (selectedBlockViewModel != null) | ||||||
| 
 |             { | ||||||
|         private void EnableBlock(IItemFilterBlockViewModel targetBlockViewModel) |                 selectedBlockViewModel.BlockEnabled = true; | ||||||
|         { |             } | ||||||
|             targetBlockViewModel.BlockEnabled = true; |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -159,7 +159,7 @@ namespace Filtration.ViewModels | |||||||
|                     case "OpenScript": |                     case "OpenScript": | ||||||
|                     { |                     { | ||||||
| #pragma warning disable 4014 | #pragma warning disable 4014 | ||||||
|                         OnOpenScriptCommand(); |                         Task.Run(OnOpenScriptCommand).GetAwaiter().GetResult(); | ||||||
| #pragma warning restore 4014 | #pragma warning restore 4014 | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
| @ -216,7 +216,7 @@ namespace Filtration.ViewModels | |||||||
| 
 | 
 | ||||||
|         public RelayCommand<bool> ToggleShowAdvancedCommand { get; } |         public RelayCommand<bool> ToggleShowAdvancedCommand { get; } | ||||||
|         public RelayCommand ClearFiltersCommand { get; } |         public RelayCommand ClearFiltersCommand { get; } | ||||||
|          | 
 | ||||||
|         public ImageSource Icon { get; private set; } |         public ImageSource Icon { get; private set; } | ||||||
| 
 | 
 | ||||||
|         public IAvalonDockWorkspaceViewModel AvalonDockWorkspaceViewModel => _avalonDockWorkspaceViewModel; |         public IAvalonDockWorkspaceViewModel AvalonDockWorkspaceViewModel => _avalonDockWorkspaceViewModel; | ||||||
| @ -334,7 +334,7 @@ namespace Filtration.ViewModels | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             await LoadScriptAsync(filePath); |             await LoadScriptAsync(filePath); // TODO: fix crash | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private async Task LoadScriptAsync(string scriptFilename) |         private async Task LoadScriptAsync(string scriptFilename) | ||||||
| @ -346,20 +346,19 @@ namespace Filtration.ViewModels | |||||||
|             { |             { | ||||||
|                 loadedViewModel = await _itemFilterScriptRepository.LoadScriptFromFileAsync(scriptFilename); |                 loadedViewModel = await _itemFilterScriptRepository.LoadScriptFromFileAsync(scriptFilename); | ||||||
|             } |             } | ||||||
|             catch (IOException e) |             catch (Exception e) | ||||||
|             { |             { | ||||||
|                 Messenger.Default.Send(new NotificationMessage("HideLoadingBanner")); |                 Logger.Error(e); | ||||||
|                 if (Logger.IsErrorEnabled) |  | ||||||
|                 { |  | ||||||
|                     Logger.Error(e); |  | ||||||
|                 } |  | ||||||
|                 _messageBoxService.Show("Script Load Error", "Error loading filter script - " + e.Message, |                 _messageBoxService.Show("Script Load Error", "Error loading filter script - " + e.Message, | ||||||
|                     MessageBoxButton.OK, |                     MessageBoxButton.OK, | ||||||
|                     MessageBoxImage.Error); |                     MessageBoxImage.Error); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |             finally | ||||||
|  |             { | ||||||
|  |                 Messenger.Default.Send(new NotificationMessage("HideLoadingBanner")); | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             Messenger.Default.Send(new NotificationMessage("HideLoadingBanner")); |  | ||||||
|             _avalonDockWorkspaceViewModel.AddDocument(loadedViewModel); |             _avalonDockWorkspaceViewModel.AddDocument(loadedViewModel); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -382,12 +381,9 @@ namespace Filtration.ViewModels | |||||||
|             { |             { | ||||||
|                 loadedViewModel = await _themeProvider.LoadThemeFromFile(themeFilename); |                 loadedViewModel = await _themeProvider.LoadThemeFromFile(themeFilename); | ||||||
|             } |             } | ||||||
|             catch (IOException e) |             catch (Exception e) | ||||||
|             { |             { | ||||||
|                 if (Logger.IsErrorEnabled) |                 Logger.Error(e); | ||||||
|                 { |  | ||||||
|                     Logger.Error(e); |  | ||||||
|                 } |  | ||||||
|                 _messageBoxService.Show("Theme Load Error", "Error loading filter theme - " + e.Message, |                 _messageBoxService.Show("Theme Load Error", "Error loading filter theme - " + e.Message, | ||||||
|                     MessageBoxButton.OK, |                     MessageBoxButton.OK, | ||||||
|                     MessageBoxImage.Error); |                     MessageBoxImage.Error); | ||||||
|  | |||||||
| @ -73,8 +73,8 @@ namespace Filtration.ViewModels.ToolPanes | |||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             PreviewText = |             PreviewText = | ||||||
|                 _itemFilterBlockTranslator.TranslateItemFilterBlockToString( |                 _itemFilterBlockTranslator.TranslateItemFilterBlockBaseToString( | ||||||
|                     AvalonDockWorkspaceViewModel.ActiveScriptViewModel.SelectedBlockViewModel.Block); |                     AvalonDockWorkspaceViewModel.ActiveScriptViewModel.SelectedBlockViewModel.BaseBlock); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -5,18 +5,18 @@ using GalaSoft.MvvmLight.Messaging; | |||||||
| 
 | 
 | ||||||
| namespace Filtration.ViewModels.ToolPanes | namespace Filtration.ViewModels.ToolPanes | ||||||
| { | { | ||||||
|     internal interface ISectionBrowserViewModel : IToolViewModel |     internal interface ICommentBlockBrowserViewModel : IToolViewModel | ||||||
|     { |     { | ||||||
|         void ClearDown(); |         void ClearDown(); | ||||||
|         bool IsVisible { get; set; } |         bool IsVisible { get; set; } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     internal class SectionBrowserViewModel : ToolViewModel, ISectionBrowserViewModel |     internal class CommentBlockBrowserViewModel : ToolViewModel, ICommentBlockBrowserViewModel | ||||||
|     { |     { | ||||||
|         private IEnumerable<IItemFilterBlockViewModel> _sectionBlockViewModels; |         private IEnumerable<IItemFilterCommentBlockViewModel> _itemFilterCommentBlockViewModels; | ||||||
|         private IItemFilterBlockViewModel _selectedSectionBlockViewModel; |         private IItemFilterCommentBlockViewModel _selectedItemFilterCommentBlockViewModel; | ||||||
| 
 | 
 | ||||||
|         public SectionBrowserViewModel() : base("Section Browser") |         public CommentBlockBrowserViewModel() : base("Section Browser") | ||||||
|         { |         { | ||||||
|             ContentId = ToolContentId; |             ContentId = ToolContentId; | ||||||
|             var icon = new BitmapImage(); |             var icon = new BitmapImage(); | ||||||
| @ -40,25 +40,25 @@ namespace Filtration.ViewModels.ToolPanes | |||||||
| 
 | 
 | ||||||
|         public const string ToolContentId = "SectionBrowserTool"; |         public const string ToolContentId = "SectionBrowserTool"; | ||||||
| 
 | 
 | ||||||
|         public IEnumerable<IItemFilterBlockViewModel> SectionBlockViewModels |         public IEnumerable<IItemFilterCommentBlockViewModel> ItemFilterCommentBlockViewModels | ||||||
|         { |         { | ||||||
|             get { return _sectionBlockViewModels; } |             get => _itemFilterCommentBlockViewModels; | ||||||
|             private set |             private set | ||||||
|             { |             { | ||||||
|                 _sectionBlockViewModels = value; |                 _itemFilterCommentBlockViewModels = value; | ||||||
|                 RaisePropertyChanged(); |                 RaisePropertyChanged(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IItemFilterBlockViewModel SelectedSectionBlockViewModel |         public IItemFilterCommentBlockViewModel SelectedItemFilterCommentBlockViewModel | ||||||
|         { |         { | ||||||
|             get { return _selectedSectionBlockViewModel; } |             get => _selectedItemFilterCommentBlockViewModel; | ||||||
|             set |             set | ||||||
|             { |             { | ||||||
|                 _selectedSectionBlockViewModel = value; |                 _selectedItemFilterCommentBlockViewModel = value; | ||||||
|                 if (AvalonDockWorkspaceViewModel.ActiveDocument.IsScript) |                 if (AvalonDockWorkspaceViewModel.ActiveDocument.IsScript) | ||||||
|                 { |                 { | ||||||
|                     AvalonDockWorkspaceViewModel.ActiveScriptViewModel.SectionBrowserSelectedBlockViewModel = value; |                     AvalonDockWorkspaceViewModel.ActiveScriptViewModel.CommentBlockBrowserBrowserSelectedBlockViewModel = value; | ||||||
|                 } |                 } | ||||||
|                 RaisePropertyChanged(); |                 RaisePropertyChanged(); | ||||||
|             } |             } | ||||||
| @ -68,7 +68,7 @@ namespace Filtration.ViewModels.ToolPanes | |||||||
|         { |         { | ||||||
|             if (AvalonDockWorkspaceViewModel.ActiveScriptViewModel != null && AvalonDockWorkspaceViewModel.ActiveDocument.IsScript) |             if (AvalonDockWorkspaceViewModel.ActiveScriptViewModel != null && AvalonDockWorkspaceViewModel.ActiveDocument.IsScript) | ||||||
|             { |             { | ||||||
|                 SectionBlockViewModels = AvalonDockWorkspaceViewModel.ActiveScriptViewModel.ItemFilterSectionViewModels; |                 ItemFilterCommentBlockViewModels = AvalonDockWorkspaceViewModel.ActiveScriptViewModel.ItemFilterCommentBlockViewModels; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
| @ -78,8 +78,8 @@ namespace Filtration.ViewModels.ToolPanes | |||||||
| 
 | 
 | ||||||
|         public void ClearDown() |         public void ClearDown() | ||||||
|         { |         { | ||||||
|             SectionBlockViewModels = null; |             ItemFilterCommentBlockViewModels = null; | ||||||
|             SelectedSectionBlockViewModel = null; |             SelectedItemFilterCommentBlockViewModel = null; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -43,7 +43,7 @@ | |||||||
|                     </viewsAvalonDock:PanesTemplateSelector.BlockGroupBrowserTemplate> |                     </viewsAvalonDock:PanesTemplateSelector.BlockGroupBrowserTemplate> | ||||||
|                     <viewsAvalonDock:PanesTemplateSelector.SectionBrowserTemplate> |                     <viewsAvalonDock:PanesTemplateSelector.SectionBrowserTemplate> | ||||||
|                         <DataTemplate> |                         <DataTemplate> | ||||||
|                             <toolPanes:SectionBrowserView DataContext="{Binding}" /> |                             <toolPanes:CommentBlockBrowserView DataContext="{Binding}" /> | ||||||
|                         </DataTemplate> |                         </DataTemplate> | ||||||
|                     </viewsAvalonDock:PanesTemplateSelector.SectionBrowserTemplate> |                     </viewsAvalonDock:PanesTemplateSelector.SectionBrowserTemplate> | ||||||
|                     <viewsAvalonDock:PanesTemplateSelector.BlockOutputPreviewTemplate> |                     <viewsAvalonDock:PanesTemplateSelector.BlockOutputPreviewTemplate> | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ namespace Filtration.Views.AvalonDock | |||||||
|             if (destinationContainer?.FindParent<LayoutFloatingWindow>() != null) |             if (destinationContainer?.FindParent<LayoutFloatingWindow>() != null) | ||||||
|                 return false; |                 return false; | ||||||
| 
 | 
 | ||||||
|             if (anchorableToShow.Content is SectionBrowserViewModel) |             if (anchorableToShow.Content is CommentBlockBrowserViewModel) | ||||||
|             { |             { | ||||||
|                 var toolsPane = layout.Descendents().OfType<LayoutAnchorablePane>().FirstOrDefault(d => d.Name == "SectionBrowserPane"); |                 var toolsPane = layout.Descendents().OfType<LayoutAnchorablePane>().FirstOrDefault(d => d.Name == "SectionBrowserPane"); | ||||||
|                 if (toolsPane != null) |                 if (toolsPane != null) | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ namespace Filtration.Views.AvalonDock | |||||||
|                 return ThemeTemplate; |                 return ThemeTemplate; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (item is SectionBrowserViewModel) |             if (item is CommentBlockBrowserViewModel) | ||||||
|             { |             { | ||||||
|                 return SectionBrowserTemplate; |                 return SectionBrowserTemplate; | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -1,26 +0,0 @@ | |||||||
| using System.Windows; |  | ||||||
| using System.Windows.Controls; |  | ||||||
| using Filtration.ObjectModel; |  | ||||||
| using Filtration.ViewModels; |  | ||||||
| 
 |  | ||||||
| namespace Filtration.Views |  | ||||||
| { |  | ||||||
|     public class BlockTemplateSelector : DataTemplateSelector |  | ||||||
|     { |  | ||||||
|         public override DataTemplate SelectTemplate(object item, DependencyObject container) |  | ||||||
|         { |  | ||||||
|             var viewModel = item as ItemFilterBlockViewModel; |  | ||||||
|             var element = container as FrameworkElement; |  | ||||||
| 
 |  | ||||||
|             if (viewModel == null || element == null) |  | ||||||
|                 return null; |  | ||||||
| 
 |  | ||||||
|             if (viewModel.Block is ItemFilterSection) |  | ||||||
|             { |  | ||||||
|                 return element.FindResource("ItemFilterSectionTemplate") as DataTemplate; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             return element.FindResource("ItemFilterBlockTemplate") as DataTemplate; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -1,10 +1,10 @@ | |||||||
| <UserControl x:Class="Filtration.Views.ItemFilterSectionView" | <UserControl x:Class="Filtration.Views.ItemFilterCommentBlockView" | ||||||
|              xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" |              xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" | ||||||
|              xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" |              xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" | ||||||
|              xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  |              xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  | ||||||
|              xmlns:d="http://schemas.microsoft.com/expression/blend/2008" |              xmlns:d="http://schemas.microsoft.com/expression/blend/2008" | ||||||
|              xmlns:viewModels="clr-namespace:Filtration.ViewModels" |              xmlns:viewModels="clr-namespace:Filtration.ViewModels" | ||||||
|              d:DataContext="{d:DesignInstance Type=viewModels:ItemFilterBlockViewModel}" |              d:DataContext="{d:DesignInstance Type=viewModels:ItemFilterCommentBlockViewModel}" | ||||||
|              mc:Ignorable="d"  |              mc:Ignorable="d"  | ||||||
|              d:DesignHeight="50" d:DesignWidth="300"> |              d:DesignHeight="50" d:DesignWidth="300"> | ||||||
|     <UserControl.Resources> |     <UserControl.Resources> | ||||||
| @ -45,7 +45,7 @@ | |||||||
|                     <ColumnDefinition Width="Auto" /> |                     <ColumnDefinition Width="Auto" /> | ||||||
|                     <ColumnDefinition Width="*" /> |                     <ColumnDefinition Width="*" /> | ||||||
|                 </Grid.ColumnDefinitions> |                 </Grid.ColumnDefinitions> | ||||||
|                 <TextBox Grid.Column ="0" Text="{Binding BlockDescription, UpdateSourceTrigger=PropertyChanged}" VerticalAlignment="Center" TextWrapping="Wrap" MinWidth="150"/> |                 <TextBox Grid.Column ="0" Text="{Binding Comment, UpdateSourceTrigger=PropertyChanged, Mode=OneWay}" VerticalAlignment="Center" TextWrapping="Wrap" MinWidth="150"/> | ||||||
|             </Grid> |             </Grid> | ||||||
|         </Border> |         </Border> | ||||||
|     </Grid> |     </Grid> | ||||||
| @ -1,8 +1,8 @@ | |||||||
| namespace Filtration.Views | namespace Filtration.Views | ||||||
| { | { | ||||||
|     public partial class ItemFilterSectionView |     public partial class ItemFilterCommentBlockView | ||||||
|     { |     { | ||||||
|         public ItemFilterSectionView() |         public ItemFilterCommentBlockView() | ||||||
|         { |         { | ||||||
|             InitializeComponent(); |             InitializeComponent(); | ||||||
|         } |         } | ||||||
| @ -7,6 +7,7 @@ | |||||||
|              xmlns:attachedProperties="clr-namespace:Filtration.Views.AttachedProperties" |              xmlns:attachedProperties="clr-namespace:Filtration.Views.AttachedProperties" | ||||||
|              xmlns:viewModels="clr-namespace:Filtration.ViewModels" |              xmlns:viewModels="clr-namespace:Filtration.ViewModels" | ||||||
|              xmlns:userControls="clr-namespace:Filtration.UserControls" |              xmlns:userControls="clr-namespace:Filtration.UserControls" | ||||||
|  |              xmlns:utility="clr-namespace:Filtration.Utility" | ||||||
|              mc:Ignorable="d"  |              mc:Ignorable="d"  | ||||||
|              d:DataContext="{d:DesignInstance Type=viewModels:ItemFilterScriptViewModel}" |              d:DataContext="{d:DesignInstance Type=viewModels:ItemFilterScriptViewModel}" | ||||||
|              d:DesignHeight="300" d:DesignWidth="600"> |              d:DesignHeight="300" d:DesignWidth="600"> | ||||||
| @ -16,19 +17,19 @@ | |||||||
|         <KeyBinding Command="{Binding CopyBlockStyleCommand}" Modifiers="Shift+Control" Key="C" /> |         <KeyBinding Command="{Binding CopyBlockStyleCommand}" Modifiers="Shift+Control" Key="C" /> | ||||||
|         <KeyBinding Command="{Binding PasteBlockStyleCommand}" Modifiers="Shift+Control" Key="V" /> |         <KeyBinding Command="{Binding PasteBlockStyleCommand}" Modifiers="Shift+Control" Key="V" /> | ||||||
|     </UserControl.InputBindings> |     </UserControl.InputBindings> | ||||||
|  |     <utility:RoutedCommandHandlers.Commands> | ||||||
|  |         <utility:RoutedCommandHandler RoutedCommand="{StaticResource MoveBlockUpRoutedCommand}" Command="{Binding MoveBlockUpCommand}" IsActive="{Binding IsActiveDocument}" /> | ||||||
|  |     </utility:RoutedCommandHandlers.Commands> | ||||||
|     <UserControl.Resources> |     <UserControl.Resources> | ||||||
|         <ResourceDictionary> |         <ResourceDictionary> | ||||||
|             <ResourceDictionary.MergedDictionaries> |             <ResourceDictionary.MergedDictionaries> | ||||||
|                 <ResourceDictionary> |                 <ResourceDictionary> | ||||||
|                     <!-- ReSharper disable once Xaml.RedundantResource --> |                     <DataTemplate DataType="{x:Type viewModels:ItemFilterBlockViewModel}"> | ||||||
|                     <DataTemplate x:Key="ItemFilterBlockTemplate"> |  | ||||||
|                         <views:ItemFilterBlockView Margin="1" /> |                         <views:ItemFilterBlockView Margin="1" /> | ||||||
|                     </DataTemplate> |                     </DataTemplate> | ||||||
|                     <!-- ReSharper disable once Xaml.RedundantResource --> |                     <DataTemplate DataType="{x:Type viewModels:ItemFilterCommentBlockViewModel}"> | ||||||
|                     <DataTemplate x:Key="ItemFilterSectionTemplate"> |                         <views:ItemFilterCommentBlockView Margin="1" /> | ||||||
|                         <views:ItemFilterSectionView Margin="1" /> |  | ||||||
|                     </DataTemplate> |                     </DataTemplate> | ||||||
|                     <views:BlockTemplateSelector x:Key="BlockTemplateSelector" /> |  | ||||||
|                 </ResourceDictionary> |                 </ResourceDictionary> | ||||||
|                 <ResourceDictionary Source="ExpanderStyle.xaml" /> |                 <ResourceDictionary Source="ExpanderStyle.xaml" /> | ||||||
|             </ResourceDictionary.MergedDictionaries> |             </ResourceDictionary.MergedDictionaries> | ||||||
| @ -36,14 +37,15 @@ | |||||||
|     </UserControl.Resources> |     </UserControl.Resources> | ||||||
|     <Grid> |     <Grid> | ||||||
|         <Grid.RowDefinitions> |         <Grid.RowDefinitions> | ||||||
|             <RowDefinition Height="Auto"/>  |             <RowDefinition Height="Auto"/> | ||||||
|             <RowDefinition Height="*" /> |             <RowDefinition Height="*" /> | ||||||
|         </Grid.RowDefinitions> |         </Grid.RowDefinitions> | ||||||
|         <Border Grid.Row="0" BorderThickness="1" BorderBrush="DarkGray"  Margin="5,5,5,0"> |         <Border Grid.Row="0" BorderThickness="1" BorderBrush="DarkGray"  Margin="5,5,5,0"> | ||||||
|             <StackPanel Margin="2,2,2,2"> |             <StackPanel Margin="2,2,2,2"> | ||||||
|  |                 <Button Command="{StaticResource MoveBlockUpRoutedCommand}">MOVE BLOCK UP TEST BUTTON</Button> | ||||||
|                 <Expander Style="{StaticResource ExpanderRightAlignStyle}"> |                 <Expander Style="{StaticResource ExpanderRightAlignStyle}"> | ||||||
|                     <Expander.Header> |                     <Expander.Header> | ||||||
|                         <TextBlock Text="Script Description" VerticalAlignment="Center" />  |                         <TextBlock Text="Script Description" VerticalAlignment="Center" /> | ||||||
|                     </Expander.Header> |                     </Expander.Header> | ||||||
|                     <Grid> |                     <Grid> | ||||||
|                         <TextBox Text="{Binding Description, UpdateSourceTrigger=PropertyChanged}" Margin="5" MaxLines="20" AcceptsReturn="True" VerticalScrollBarVisibility="Auto" /> |                         <TextBox Text="{Binding Description, UpdateSourceTrigger=PropertyChanged}" Margin="5" MaxLines="20" AcceptsReturn="True" VerticalScrollBarVisibility="Auto" /> | ||||||
| @ -59,9 +61,9 @@ | |||||||
|                                                    BorderThickness="0" |                                                    BorderThickness="0" | ||||||
|                                                    ScrollViewer.HorizontalScrollBarVisibility="Disabled" |                                                    ScrollViewer.HorizontalScrollBarVisibility="Disabled" | ||||||
|                                                    VirtualizingStackPanel.VirtualizationMode="Recycling" |                                                    VirtualizingStackPanel.VirtualizationMode="Recycling" | ||||||
|                                                    ItemTemplateSelector="{StaticResource BlockTemplateSelector}" |                                                    attachedProperties:SelectingItemAttachedProperty.SelectingItem="{Binding CommentBlockBrowserBrowserSelectedBlockViewModel}" | ||||||
|                                                    attachedProperties:SelectingItemAttachedProperty.SelectingItem="{Binding SectionBrowserSelectedBlockViewModel}" |                                                    SelectedItem="{Binding SelectedBlockViewModel}"> | ||||||
|                                                    SelectedItem="{Binding SelectedBlockViewModel}" x:Name="BlocksListBox"> |                     <!--ItemTemplateSelector="{StaticResource BlockTemplateSelector}"--> | ||||||
|                     <ListBox.InputBindings> |                     <ListBox.InputBindings> | ||||||
|                         <KeyBinding Key="Delete" Command="{Binding DeleteBlockCommand}" /> |                         <KeyBinding Key="Delete" Command="{Binding DeleteBlockCommand}" /> | ||||||
|                     </ListBox.InputBindings> |                     </ListBox.InputBindings> | ||||||
|  | |||||||
| @ -9,15 +9,20 @@ | |||||||
|         xmlns:viewsAvalonDock="clr-namespace:Filtration.Views.AvalonDock" |         xmlns:viewsAvalonDock="clr-namespace:Filtration.Views.AvalonDock" | ||||||
|         xmlns:views="clr-namespace:Filtration.Views" |         xmlns:views="clr-namespace:Filtration.Views" | ||||||
|         xmlns:gif="http://wpfanimatedgif.codeplex.com" |         xmlns:gif="http://wpfanimatedgif.codeplex.com" | ||||||
|  |         xmlns:utility="clr-namespace:Filtration.Utility" | ||||||
|         mc:Ignorable="d" |         mc:Ignorable="d" | ||||||
|         d:DataContext="{d:DesignInstance Type=viewModels:MainWindowViewModel}" |         d:DataContext="{d:DesignInstance Type=viewModels:MainWindowViewModel}" | ||||||
|         Title="{Binding WindowTitle}" Height="762" Width="1126" IsIconVisible="True" |         Title="{Binding WindowTitle}" Height="762" Width="1126" IsIconVisible="True" | ||||||
|         Closing="MainWindow_OnClosing" Drop="MainWindow_OnDrop" AllowDrop="True"> |         Closing="MainWindow_OnClosing" Drop="MainWindow_OnDrop" AllowDrop="True"> | ||||||
|  | 
 | ||||||
|     <fluent:RibbonWindow.InputBindings> |     <fluent:RibbonWindow.InputBindings> | ||||||
|         <KeyBinding Command="{Binding SaveCommand}" Modifiers="Control" Key="S" /> |         <KeyBinding Command="{Binding SaveCommand}" Modifiers="Control" Key="S" /> | ||||||
|         <KeyBinding Command="{Binding OpenScriptCommand}" Modifiers="Control" Key="O" /> |         <KeyBinding Command="{Binding OpenScriptCommand}" Modifiers="Control" Key="O" /> | ||||||
|         <KeyBinding Command="{Binding NewScriptCommand}" Modifiers="Control" Key="N" /> |         <KeyBinding Command="{Binding NewScriptCommand}" Modifiers="Control" Key="N" /> | ||||||
|     </fluent:RibbonWindow.InputBindings> |     </fluent:RibbonWindow.InputBindings> | ||||||
|  |     <utility:RoutedCommandHandlers.Commands> | ||||||
|  |         <utility:RoutedCommandHandler RoutedCommand="{StaticResource OpenScriptRoutedCommand}" Command="{Binding OpenScriptCommand}" /> | ||||||
|  |     </utility:RoutedCommandHandlers.Commands> | ||||||
|     <DockPanel x:Name="RootDockPanel"> |     <DockPanel x:Name="RootDockPanel"> | ||||||
|         <fluent:Ribbon DockPanel.Dock="Top" x:Name="RibbonRoot" IsEnabled="{Binding ShowLoadingBanner, Converter={StaticResource BoolInverterConverter}}"> |         <fluent:Ribbon DockPanel.Dock="Top" x:Name="RibbonRoot" IsEnabled="{Binding ShowLoadingBanner, Converter={StaticResource BoolInverterConverter}}"> | ||||||
|             <fluent:Ribbon.Menu> |             <fluent:Ribbon.Menu> | ||||||
| @ -67,7 +72,7 @@ | |||||||
|             </fluent:Ribbon.ContextualGroups> |             </fluent:Ribbon.ContextualGroups> | ||||||
|             <fluent:RibbonTabItem Header="View"> |             <fluent:RibbonTabItem Header="View"> | ||||||
|                 <fluent:RibbonGroupBox Header="Tools"> |                 <fluent:RibbonGroupBox Header="Tools"> | ||||||
|                     <fluent:ToggleButton Header="Section Browser" Width="150" Size="Middle" Icon="{StaticResource AddSectionIcon}" IsChecked="{Binding AvalonDockWorkspaceViewModel.SectionBrowserViewModel.IsVisible}"/> |                     <fluent:ToggleButton Header="Section Browser" Width="150" Size="Middle" Icon="{StaticResource AddSectionIcon}" IsChecked="{Binding AvalonDockWorkspaceViewModel.CommentBlockBrowserViewModel.IsVisible}"/> | ||||||
|                     <fluent:ToggleButton Header="Block Group Browser" SizeDefinition="Middle" Icon="{StaticResource BlockGroupBrowserIcon}" IsChecked="{Binding AvalonDockWorkspaceViewModel.BlockGroupBrowserViewModel.IsVisible}" /> |                     <fluent:ToggleButton Header="Block Group Browser" SizeDefinition="Middle" Icon="{StaticResource BlockGroupBrowserIcon}" IsChecked="{Binding AvalonDockWorkspaceViewModel.BlockGroupBrowserViewModel.IsVisible}" /> | ||||||
|                     <fluent:ToggleButton Header="Block Output Preview" SizeDefinition="Middle" Icon="{StaticResource BlockOutputPreviewIcon}" IsChecked="{Binding AvalonDockWorkspaceViewModel.BlockOutputPreviewViewModel.IsVisible}" /> |                     <fluent:ToggleButton Header="Block Output Preview" SizeDefinition="Middle" Icon="{StaticResource BlockOutputPreviewIcon}" IsChecked="{Binding AvalonDockWorkspaceViewModel.BlockOutputPreviewViewModel.IsVisible}" /> | ||||||
|                 </fluent:RibbonGroupBox> |                 </fluent:RibbonGroupBox> | ||||||
| @ -146,4 +151,5 @@ | |||||||
|         </Grid> |         </Grid> | ||||||
|     </DockPanel> |     </DockPanel> | ||||||
| </fluent:RibbonWindow> | </fluent:RibbonWindow> | ||||||
|  |   | ||||||
|   |   | ||||||
| @ -8,7 +8,7 @@ | |||||||
|     <Grid> |     <Grid> | ||||||
|         <TextBlock FontStyle="Italic" Margin="5" FontSize="13"> |         <TextBlock FontStyle="Italic" Margin="5" FontSize="13"> | ||||||
|             Welcome to Filtration, to get started either  |             Welcome to Filtration, to get started either  | ||||||
|             <Hyperlink Command="{Binding NewScriptCommand}">create a new script</Hyperlink> or <Hyperlink Command="{Binding OpenScriptCommand}">open an existing script</Hyperlink> |             <Hyperlink Command="{Binding NewScriptCommand}">create a new script</Hyperlink> or <Hyperlink Command="{StaticResource OpenScriptRoutedCommand}">open an existing script</Hyperlink> | ||||||
|         </TextBlock> |         </TextBlock> | ||||||
|     </Grid> |     </Grid> | ||||||
| </UserControl> | </UserControl> | ||||||
|  | |||||||
| @ -1,19 +1,19 @@ | |||||||
| <UserControl x:Class="Filtration.Views.ToolPanes.SectionBrowserView" | <UserControl x:Class="Filtration.Views.ToolPanes.CommentBlockBrowserView" | ||||||
|              xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" |              xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" | ||||||
|              xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" |              xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" | ||||||
|              xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  |              xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"  | ||||||
|              xmlns:d="http://schemas.microsoft.com/expression/blend/2008" |              xmlns:d="http://schemas.microsoft.com/expression/blend/2008" | ||||||
|              xmlns:converters="clr-namespace:Filtration.Converters" |              xmlns:converters="clr-namespace:Filtration.Converters" | ||||||
|              xmlns:toolPanes="clr-namespace:Filtration.ViewModels.ToolPanes" |              xmlns:toolPanes="clr-namespace:Filtration.ViewModels.ToolPanes" | ||||||
|              d:DataContext="{d:DesignInstance Type=toolPanes:SectionBrowserViewModel}" |              d:DataContext="{d:DesignInstance Type=toolPanes:CommentBlockBrowserViewModel}" | ||||||
|              mc:Ignorable="d"  |              mc:Ignorable="d"  | ||||||
|              d:DesignHeight="300" d:DesignWidth="300"> |              d:DesignHeight="300" d:DesignWidth="300"> | ||||||
|     <UserControl.Resources> |     <UserControl.Resources> | ||||||
|         <converters:HashSignRemovalConverter x:Key="HashSignRemovalConverter" /> |         <converters:HashSignRemovalConverter x:Key="HashSignRemovalConverter" /> | ||||||
|     </UserControl.Resources> |     </UserControl.Resources> | ||||||
|     <Grid> |     <Grid> | ||||||
|         <ListBox ItemsSource="{Binding SectionBlockViewModels}" |         <ListBox ItemsSource="{Binding ItemFilterCommentBlockViewModels}" | ||||||
|                              SelectedItem="{Binding SelectedSectionBlockViewModel}" |                              SelectedItem="{Binding SelectedItemFilterCommentBlockViewModel}" | ||||||
|                              x:Name="SectionBrowserListBox" |                              x:Name="SectionBrowserListBox" | ||||||
|                              ScrollViewer.HorizontalScrollBarVisibility="Hidden"><!--SelectionChanged="SectionBrowserListBox_OnSelectionChanged"--> |                              ScrollViewer.HorizontalScrollBarVisibility="Hidden"><!--SelectionChanged="SectionBrowserListBox_OnSelectionChanged"--> | ||||||
|             <ListBox.Resources> |             <ListBox.Resources> | ||||||
| @ -21,7 +21,7 @@ | |||||||
|             </ListBox.Resources> |             </ListBox.Resources> | ||||||
|             <ListBox.ItemTemplate> |             <ListBox.ItemTemplate> | ||||||
|                 <DataTemplate> |                 <DataTemplate> | ||||||
|                     <TextBlock Text="{Binding BlockDescription, Converter={StaticResource HashSignRemovalConverter}}" ToolTip="{Binding BlockDescription}" /> |                     <TextBlock Text="{Binding Comment, Converter={StaticResource HashSignRemovalConverter}}" ToolTip="{Binding Comment}" /> | ||||||
|                 </DataTemplate> |                 </DataTemplate> | ||||||
|             </ListBox.ItemTemplate> |             </ListBox.ItemTemplate> | ||||||
|         </ListBox> |         </ListBox> | ||||||
| @ -1,8 +1,8 @@ | |||||||
| namespace Filtration.Views.ToolPanes | namespace Filtration.Views.ToolPanes | ||||||
| { | { | ||||||
|     public partial class SectionBrowserView |     public partial class CommentBlockBrowserView | ||||||
|     { |     { | ||||||
|         public SectionBrowserView() |         public CommentBlockBrowserView() | ||||||
|         { |         { | ||||||
|             InitializeComponent(); |             InitializeComponent(); | ||||||
|         } |         } | ||||||
| @ -26,6 +26,11 @@ namespace Filtration.WindsorInstallers | |||||||
|                     .ImplementedBy<ItemFilterBlockViewModel>() |                     .ImplementedBy<ItemFilterBlockViewModel>() | ||||||
|                     .LifeStyle.Transient); |                     .LifeStyle.Transient); | ||||||
| 
 | 
 | ||||||
|  |             container.Register( | ||||||
|  |                 Component.For<IItemFilterCommentBlockViewModel>() | ||||||
|  |                     .ImplementedBy<ItemFilterCommentBlockViewModel>() | ||||||
|  |                     .LifeStyle.Transient); | ||||||
|  | 
 | ||||||
|             container.Register( |             container.Register( | ||||||
|                 Component.For<IItemFilterScriptViewModel>() |                 Component.For<IItemFilterScriptViewModel>() | ||||||
|                     .ImplementedBy<ItemFilterScriptViewModel>() |                     .ImplementedBy<ItemFilterScriptViewModel>() | ||||||
| @ -42,8 +47,8 @@ namespace Filtration.WindsorInstallers | |||||||
|                     .LifeStyle.Singleton); |                     .LifeStyle.Singleton); | ||||||
| 
 | 
 | ||||||
|             container.Register( |             container.Register( | ||||||
|                 Component.For<ISectionBrowserViewModel>() |                 Component.For<ICommentBlockBrowserViewModel>() | ||||||
|                     .ImplementedBy<SectionBrowserViewModel>() |                     .ImplementedBy<CommentBlockBrowserViewModel>() | ||||||
|                     .LifeStyle.Singleton); |                     .LifeStyle.Singleton); | ||||||
| 
 | 
 | ||||||
|             container.Register( |             container.Register( | ||||||
| @ -69,6 +74,9 @@ namespace Filtration.WindsorInstallers | |||||||
|             container.Register( |             container.Register( | ||||||
|                 Component.For<IItemFilterBlockViewModelFactory>().AsFactory()); |                 Component.For<IItemFilterBlockViewModelFactory>().AsFactory()); | ||||||
| 
 | 
 | ||||||
|  |             container.Register( | ||||||
|  |                 Component.For<IItemFilterCommentBlockViewModelFactory>().AsFactory()); | ||||||
|  | 
 | ||||||
|             container.Register( |             container.Register( | ||||||
|                 Component.For<IItemFilterScriptViewModelFactory>().AsFactory()); |                 Component.For<IItemFilterScriptViewModelFactory>().AsFactory()); | ||||||
|         } |         } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user