MainView.axaml 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <UserControl xmlns="https://github.com/avaloniaui"
  2. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  3. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  4. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  5. xmlns:vm="clr-namespace:VeloeMonitorApp.ViewModels"
  6. xmlns:avalonia="clr-namespace:Material.Icons.Avalonia;assembly=Material.Icons.Avalonia"
  7. xmlns:controls="clr-namespace:Material.Styles.Controls;assembly=Material.Styles"
  8. xmlns:dialogHostAvalonia="clr-namespace:DialogHostAvalonia;assembly=DialogHost.Avalonia"
  9. mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
  10. x:Class="VeloeMonitorApp.Views.MainView"
  11. x:DataType="vm:MainViewModel">
  12. <Design.DataContext>
  13. <!-- This only sets the DataContext for the previewer in an IDE,
  14. to set the actual DataContext for runtime, set the DataContext property in code (look at App.axaml.cs) -->
  15. <vm:MainViewModel />
  16. </Design.DataContext>
  17. <UserControl.Styles>
  18. <Style Selector="TextBlock.Subheadline">
  19. <Setter Property="Margin" Value="0, 16" />
  20. </Style>
  21. <Style Selector="TextBlock.Subheadline2">
  22. <Setter Property="Margin" Value="0, 8" />
  23. </Style>
  24. <Style Selector="TextBlock.Content">
  25. <Setter Property="Margin" Value="0, 4" />
  26. <Setter Property="HorizontalAlignment" Value="Left" />
  27. </Style>
  28. </UserControl.Styles>
  29. <controls:SnackbarHost HostName="Root">
  30. <controls:NavigationDrawer Name="LeftDrawer" Classes="permanent"
  31. LeftDrawerOpened="{Binding ElementName=NavDrawerSwitch, Path=IsChecked, Mode=TwoWay}">
  32. <controls:NavigationDrawer.LeftDrawerContent>
  33. <ScrollViewer>
  34. <StackPanel>
  35. <controls:ColorZone Mode="Accent" Height="180">
  36. <StackPanel>
  37. <Image Width="96" Height="120"
  38. HorizontalAlignment="Center" VerticalAlignment="Center"
  39. Margin="0,0,0,-8"
  40. />
  41. <TextBlock Classes="Headline6" Text="Material Design" HorizontalAlignment="Center" />
  42. <TextBlock Classes="Subtitle1" Text="with AvaloniaUI" HorizontalAlignment="Center" />
  43. </StackPanel>
  44. </controls:ColorZone>
  45. <ListBox Classes="NoScroll" Name="DrawerList"
  46. Focusable="{Binding ElementName=LeftDrawer, Path=LeftDrawerOpened}">
  47. <ListBox.Styles>
  48. <Style Selector="ListBoxItem">
  49. <Setter Property="Height" Value="48" />
  50. <Setter Property="Padding" Value="16,0" />
  51. <Setter Property="VerticalContentAlignment" Value="Center" />
  52. </Style>
  53. </ListBox.Styles>
  54. <ListBoxItem Tag="Index">Home</ListBoxItem>
  55. <ListBoxItem>Buttons</ListBoxItem>
  56. <ListBoxItem>Card</ListBoxItem>
  57. <ListBoxItem>ColorZones</ListBoxItem>
  58. <ListBoxItem>Colors</ListBoxItem>
  59. <ListBoxItem>ComboBoxes</ListBoxItem>
  60. <ListBoxItem>Date/Time pickers</ListBoxItem>
  61. <ListBoxItem>Dialogs</ListBoxItem>
  62. <ListBoxItem>Expanders</ListBoxItem>
  63. <ListBoxItem>Fields</ListBoxItem>
  64. <ListBoxItem>Lists</ListBoxItem>
  65. <ListBoxItem>Material Icons</ListBoxItem>
  66. <ListBoxItem>Progress indicators</ListBoxItem>
  67. <ListBoxItem>ScrollViewer</ListBoxItem>
  68. <!-- <ListBoxItem>Shadows</ListBoxItem> -->
  69. <ListBoxItem>SideSheet</ListBoxItem>
  70. <ListBoxItem>Sliders</ListBoxItem>
  71. <ListBoxItem>Snackbar</ListBoxItem>
  72. <ListBoxItem>TabControls</ListBoxItem>
  73. <ListBoxItem>Toggles</ListBoxItem>
  74. <ListBoxItem>TreeViews</ListBoxItem>
  75. <ListBoxItem>Typography</ListBoxItem>
  76. </ListBox>
  77. </StackPanel>
  78. </ScrollViewer>
  79. </controls:NavigationDrawer.LeftDrawerContent>
  80. <DockPanel LastChildFill="true">
  81. <controls:ColorZone Name="PART_AppBarContainer" VerticalAlignment="Top" HorizontalAlignment="Stretch"
  82. DockPanel.Dock="Top"
  83. Height="56" Mode="PrimaryMid" ZIndex="1">
  84. <Grid Margin="16">
  85. <Grid.ColumnDefinitions>
  86. <ColumnDefinition Width="24" />
  87. <ColumnDefinition Width="32" />
  88. <ColumnDefinition Width="*" />
  89. <ColumnDefinition Width="32" />
  90. <ColumnDefinition Width="Auto" />
  91. </Grid.ColumnDefinitions>
  92. <ToggleButton Name="NavDrawerSwitch"
  93. Theme="{StaticResource MaterialFlatButton}"
  94. Width="32" Height="32" Padding="4">
  95. <avalonia:MaterialIcon Kind="Menu" Width="24" Height="24" />
  96. </ToggleButton>
  97. <TextBlock Grid.Column="2" Classes="Headline6" Text="Veloe Monitor"
  98. VerticalAlignment="Center" />
  99. <Menu Grid.Column="4" Height="32" Padding="0" Margin="0">
  100. <MenuItem Height="32" Width="32" Header="{avalonia:MaterialIconExt DotsVertical, Size=24}">
  101. <MenuItem Header="Hello!">
  102. <MenuItem.Icon>
  103. <avalonia:MaterialIcon Kind="Hand" Width="24" Height="24" />
  104. </MenuItem.Icon>
  105. </MenuItem>
  106. <MenuItem Header="Connect to network">
  107. <MenuItem.Icon>
  108. <avalonia:MaterialIcon Kind="RocketLaunch" Width="24" Height="24" />
  109. </MenuItem.Icon>
  110. </MenuItem>
  111. <Separator />
  112. <MenuItem Header="Action 1" />
  113. <MenuItem Header="Action 2" />
  114. <MenuItem Header="Action 3" />
  115. <Separator />
  116. <MenuItem Header="Goodbye">
  117. <MenuItem.Icon>
  118. <avalonia:MaterialIcon Kind="ExitRun" Width="24" Height="24" />
  119. </MenuItem.Icon>
  120. </MenuItem>
  121. </MenuItem>
  122. </Menu>
  123. </Grid>
  124. </controls:ColorZone>
  125. <ScrollViewer Name="mainScroller"
  126. DockPanel.Dock="Top"
  127. HorizontalContentAlignment="Stretch"
  128. HorizontalAlignment="Stretch"
  129. HorizontalScrollBarVisibility="Disabled">
  130. <Border HorizontalAlignment="Stretch"
  131. VerticalAlignment="Stretch">
  132. <ContentControl Content="{Binding SelectedPage}"
  133. HorizontalAlignment="Stretch"/>
  134. </Border>
  135. </ScrollViewer>
  136. </DockPanel>
  137. </controls:NavigationDrawer>
  138. </controls:SnackbarHost>
  139. </UserControl>