UIfiedMaterialWPFBase.ps1
| using namespace System.Collections.Generic using namespace System.Windows using namespace System.Windows.Controls using namespace MaterialDesignThemes.Wpf class MaterialWPFHost : UIHost { [HashTable] $SyncHash $UIRunspace [void] ShowFrame([ScriptBlock] $frameScriptBlock) { $window = Invoke-Command -ScriptBlock $frameScriptBlock $window.ShowDialog() } } class MaterialWPFWindow : WindowBase { [Application] $Application = [System.Windows.Application]::new() MaterialWPFWindow() { $this.StyleApplication() $windowNativeUI = [Window]::new() $windowNativeUI.SizeToContent = 'WidthAndHeight' $windowNativeUI.Margin = 10 $windowNativeUI.FontFamily = "MaterialDesignFont" $windowNativeUI.SetResourceReference([Control]::BackgroundProperty, "MaterialDesignPaper") $this.Application.MainWindow = $windowNativeUI $this.SetNativeUI($windowNativeUI) $this.WrapProperty("Caption", "Title") $this.AddScriptBlockProperty("Loaded") $this.AddNativeUIChild = { param ( [WPFElement] $element ) $this.NativeUI.Content = $element.NativeUI } } hidden [void] StyleApplication() { $uris = "/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Light.xaml", "/MaterialDesignThemes.Wpf;component/Themes/MaterialDesignTheme.Defaults.xaml", "/MaterialDesignColors;component/Themes/Recommended/Primary/MaterialDesignColor.DeepPurple.xaml", "/MaterialDesignColors;component/Themes/Recommended/Accent/MaterialDesignColor.Lime.xaml" $uris | ForEach-Object { $resourceDictionary = [System.Windows.ResourceDictionary] [System.Windows.Application]::LoadComponent([Uri]::new($_, [System.UriKind]::Relative)) $this.Application.Resources.MergedDictionaries.Add($resourceDictionary) } } [void] ShowDialog() { $this.NativeUI.ShowDialog() #$this.Application.Run() } [void] OnLoaded() { Invoke-Command -ScriptBlock $this._Loaded -ArgumentList $this } } class MaterialWPFStackPanel : WPFStackPanel { } class MaterialWPFIcon : WPFElement { hidden [String] $KindName hidden $TextInfo MaterialWPFIcon() { $this.TextInfo = ([System.Globalization.CultureInfo]::new("en-US",$false)).TextInfo $this.NativeUI = [MaterialDesignThemes.Wpf.PackIcon]::new() Add-Member -InputObject $this -Name Kind -MemberType ScriptProperty -Value { $this.KindName } -SecondValue { $this.KindName = $args[0] $this.NativeUI.Kind = $this.TextInfo.ToTitleCase($this.KindName).Replace("_", [String]::Empty) } } } class MaterialWPFLabel : WPFLabel {} class MaterialWPFButton : WPFElement { hidden [stackpanel] $StackPanel = [StackPanel]::new() hidden [MaterialWPFIcon] $CurrentIcon = $null hidden [String] $CaptionText = "" MaterialWPFButton() { $this.SetNativeUI([Button]::new()) $this.NativeUI.SetResourceReference([Control]::StyleProperty, "MaterialDesignRaisedButton") $this.StackPanel.Orientation = [Orientation]::Horizontal $this.NativeUI.Content = $this.StackPanel Add-Member -InputObject $this -Name Caption -MemberType ScriptProperty -Value { $this.CaptionText } -SecondValue { $this.CaptionText = $args[0] $this.RefreshCaption() } Add-Member -InputObject $this -Name Icon -MemberType ScriptProperty -Value { $this.CurrentIcon } -SecondValue { $this.CurrentIcon = $args[0] $this.RefreshCaption() } $this.AddScriptBlockProperty("Action") $this.NativeUI.Add_Click({ $this.Control.OnAction() }) } [void] RefreshCaption() { $this.StackPanel.Children.Clear() if ($this.CurrentIcon -ne $null) { $this.StackPanel.AddChild($this.CurrentIcon.NativeUI) } if ($this.CaptionText -ne "") { $label = [TextBlock]::new() $label.Text = $this.CaptionText $this.StackPanel.AddChild($label) } } [void] OnAction() { $this.InvokeTrappableCommand($this._Action, $this) } } class MaterialWPFTextBox : WPFTextBox { } class MaterialWPFCheckBox : WPFCheckBox { MaterialWPFCheckBox() { $this.NativeUI.SetResourceReference([Control]::StyleProperty, "MaterialDesignCheckBox") } } class MaterialWPFRadioButton : WPFRadioButton { MaterialWPFCheckBox() { $this.NativeUI.SetResourceReference([Control]::StyleProperty, "MaterialDesignRadioButton") } } class MaterialWPFRadioGroup : WPFRadioGroup { } class MaterialWPFList : WPFList { } class MaterialWPFListColumn : WPFListColumn { } class MaterialWPFTabItem : MaterialWPFStackPanel { [MaterialWPFRadioButton] $HeaderRadioButton = ([MaterialWPFRadioButton] @{ Caption = "" }) MaterialWPFTabItem() { Add-Member -InputObject $this.HeaderRadioButton -Name Tab -Value $this -MemberType NoteProperty $this.WrapProperty("Caption", "Caption", "HeaderRadioButton") $this.HeaderRadioButton.NativeUI.SetResourceReference([Control]::StyleProperty, "MaterialDesignTabRadioButton") $this.Visible = $false $this.HeaderRadioButton.Click = { $this.Control.Tab.Parent.HideTabs() $this.Control.Tab.Visible = $this.Control.IsChecked } } } class MaterialWPFTabControl : MaterialWPFStackPanel { hidden [MaterialWPFStackPanel] $HeadersStackPanel = ([MaterialWPFStackPanel] @{ Orientation = [Orientation]::Horizontal }) hidden [MaterialWPFStackPanel] $TabsStackPanel = ([MaterialWPFStackPanel] @{ Orientation = [Orientation]::Horizontal }) hidden $TabItems = [List[MaterialWPFTabItem]]::new() MaterialWPFTabControl() { $this.Orientation = [Orientation]::Vertical $this.AddChild($this.HeadersStackPanel) $this.AddChild($this.TabsStackPanel) $this.AddNativeUIChild = { param ( [MaterialWPFTabItem] $element ) $this.TabItems.Add($element) $this.HeadersStackPanel.AddChild($element.HeaderRadioButton) | Out-Null $this.TabsStackPanel.NativeUI.AddChild($element.NativeUI) | Out-Null } $this.RemoveNativeUIChild = { param ( [MaterialWPFTabItem] $element ) $this.TabItems.Remove($element) $this.HeadersStackPanel.RemoveChild($element.HeaderRadioButton) | Out-Null $this.TabsStackPanel.NativeUI.Children.Remove($element.NativeUI) | Out-Null } } [void] HideTabs() { $this.TabItems | ForEach-Object { $_.Visible = $false } } } class MaterialWPFModal : WPFElement { [StackPanel] $Stack [Window] $ModalWindow MaterialWPFModal() { $this.Stack = [StackPanel]::new() $this.SetNativeUI($this.Stack) $this.ModalWindow = [Window]::new() $this.ModalWindow.WindowStyle = [WindowStyle]::SingleBorderWindow $this.ModalWindow.SizeToContent = 'WidthAndHeight' $this.ModalWindow.Margin = 10 $this.ModalWindow.Content = [StackPanel]::new() $this.WrapProperty("Title", "Title", "ModalWindow") $this.AddNativeUIChild = { param ( [WPFElement] $element ) $this.ModalWindow.Content.AddChild($element.NativeUI) | Out-Null } } [void] Show() { $this.ModalWindow.WindowStartupLocation = "CenterOwner" $this.ModalWindow.ShowDialog() } [void] Hide() { $this.ModalWindow.Hide() } } class MaterialWPFTimer : WPFTimer { } class MaterialWPFDatePicker : WPFElement { MaterialWPFDatePicker() { $datePicker = [DatePicker]::new() $datePicker.Width = 100 $datePicker.SetResourceReference([Control]::StyleProperty, "MaterialDesignFloatingHintDatePicker") $datePicker.SetValue([HintAssist]::HintProperty, "Hola") $this.SetNativeUI($datePicker) $this.AddScriptBlockProperty("Change") $this.NativeUI.Add_SelectedDateChanged({ $this.Control.OnChange() }) $this.AddScriptBlockProperty("LostFocus") $this.NativeUI.Add_LostFocus({ $this.Control.OnLostFocus() }) $this.WrapProperty("Value", "SelectedDate") } [void] OnChange() { $this.InvokeTrappableCommand($this._Change, $this) } [void] OnLostFocus() { $this.InvokeTrappableCommand($this._LostFocus, $this) } } class MaterialWPFTimePicker : WPFElement { MaterialWPFTimePicker() { $timePicker = [TimePicker]::new() $timePicker.Width = 100 $timePicker.SetResourceReference([Control]::StyleProperty, "MaterialDesignFloatingHintTimePicker") $timePicker.SetValue([HintAssist]::HintProperty, "Hola") $timePicker.Is24Hours = $true $this.SetNativeUI($timePicker) $this.AddScriptBlockProperty("Change") $this.NativeUI.Add_SelectedTimeChanged({ $this.Control.OnChange() }) $this.AddScriptBlockProperty("LostFocus") $this.NativeUI.Add_LostFocus({ $this.Control.OnLostFocus() }) $this.WrapProperty("Value", "SelectedTime") } [void] OnChange() { $this.InvokeTrappableCommand($this._Change, $this) } [void] OnLostFocus() { $this.InvokeTrappableCommand($this._LostFocus, $this) } } class MaterialWPFBrowser : WPFBrowser { [void] StyleComponents() { $this.StyleButton($this.FirstButton, "FirstPage", "MaterialDesignIconButton") $this.StyleButton($this.PreviousButton, "ChevronLeft", "MaterialDesignIconButton") $this.StyleButton($this.NextButton, "ChevronRight", "MaterialDesignIconButton") $this.StyleButton($this.LastButton, "LastPage", "MaterialDesignIconButton") $this.StyleButton($this.AddNewButton, "Add", "MaterialDesignFloatingActionAccentButton") $this.FirstButton.Parent.NativeUI.Margin = "0 -10 0 10" $this.AddNewButton.NativeUI.Margin = "100 10 10 10" } [void] StyleButton($button, $iconKind, $styleName) { $button.NativeUI.Content = New-Object PackIcon -Property @{ Kind = $iconKind } $button.NativeUI.Margin = 0 $button.NativeUI.SetResourceReference([Control]::StyleProperty, $styleName) } [void] StyleEditionButtons([WPFButton] $editButton, [WPFButton] $deleteButton, [int] $rowIndex) { $editButton.Parent.NativeUI.Background = $this.GetRowBackground($rowIndex) $this.StyleButton($editButton, "ModeEdit", "MaterialDesignIconMiniButton") $this.StyleButton($deleteButton, "WindowClose", "MaterialDesignIconMiniButton") $editButton.NativeUI.Background = [System.Windows.Media.Brushes]::Transparent $deleteButton.NativeUI.Background = [System.Windows.Media.Brushes]::Transparent $editButton.NativeUI.Foreground = [System.Windows.Media.Brushes]::Green $deleteButton.NativeUI.Foreground = [System.Windows.Media.Brushes]::Red $editButton.NativeUI.BorderThickness = 0 $deleteButton.NativeUI.BorderThickness = 0 } } class MaterialWPFMenuItem : WPFMenuItem { } class MaterialWPFDropDownMenu : WPFDropDownMenu { } class MaterialWPFAutoComplete : WPFAutoComplete { } class MaterialWPFCard : WPFCard { hidden $CurrentIcon = [MaterialWPFIcon]::new() [void] StyleComponents() { ([WPFCard] $this).StyleComponents() $this.NativeUI.SetResourceReference([Control]::StyleProperty, "MaterialDesignCardGroupBox") $this.HeaderTextBlock.Foreground = [System.Windows.Media.Brushes]::White $this.CurrentIcon.NativeUI.Foreground = [System.Windows.Media.Brushes]::White $this.HeaderTextBlock.SetResourceReference([Control]::StyleProperty, "MaterialDesignSubHeadingTextBlock") } } class MaterialWPFImage : WPFImage { } |