Replace AutoCompleteBox demo data with ControlData

Co-authored-by: rabbitism <14807942+rabbitism@users.noreply.github.com>
This commit is contained in:
copilot-swe-agent[bot]
2025-09-19 10:23:11 +00:00
parent 130c4f7f14
commit 75d5e86877
5 changed files with 85 additions and 88 deletions

View File

@@ -0,0 +1,7 @@
namespace Ursa.Demo.Models;
public class ControlData
{
public required string MenuHeader { get; init; }
public required string Chinese { get; init; }
}

View File

@@ -3,6 +3,7 @@
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:viewModels="clr-namespace:Ursa.Demo.ViewModels" xmlns:viewModels="clr-namespace:Ursa.Demo.ViewModels"
xmlns:models="clr-namespace:Ursa.Demo.Models"
xmlns:u="https://irihi.tech/ursa" xmlns:u="https://irihi.tech/ursa"
x:DataType="viewModels:AutoCompleteBoxDemoViewModel" x:DataType="viewModels:AutoCompleteBoxDemoViewModel"
mc:Ignorable="d" d:DesignWidth="800" mc:Ignorable="d" d:DesignWidth="800"
@@ -13,40 +14,43 @@
<Style Selector="u|AutoCompleteBox"> <Style Selector="u|AutoCompleteBox">
<Setter Property="Width" Value="300" /> <Setter Property="Width" Value="300" />
<Setter Property="ItemsSource"> <Setter Property="ItemsSource">
<Binding Path="States" /> <Binding Path="Controls" />
</Setter> </Setter>
<Setter Property="ItemTemplate"> <Setter Property="ItemTemplate">
<DataTemplate DataType="viewModels:StateData"> <DataTemplate DataType="models:ControlData">
<TextBlock Text="{Binding Name}" /> <StackPanel Orientation="Horizontal">
<TextBlock Text="{Binding MenuHeader}" VerticalAlignment="Center"/>
<TextBlock Text="{Binding Chinese}" Classes="Secondary" FontSize="12" Margin="8 0 0 0" VerticalAlignment="Center"/>
</StackPanel>
</DataTemplate> </DataTemplate>
</Setter> </Setter>
</Style> </Style>
</StackPanel.Styles> </StackPanel.Styles>
<TextBlock Text="{Binding #box.((viewModels:StateData)SelectedItem).Name}" /> <TextBlock Text="{Binding #box.((models:ControlData)SelectedItem).MenuHeader}" />
<u:AutoCompleteBox <u:AutoCompleteBox
Name="box" Name="box"
Watermark="Please select a State" Watermark="Please select a Control"
Classes="ClearButton" Classes="ClearButton"
ValueMemberBinding="{ReflectionBinding Name}" /> ValueMemberBinding="{ReflectionBinding MenuHeader}" />
<u:AutoCompleteBox <u:AutoCompleteBox
Classes="Large" Classes="Large"
ValueMemberBinding="{ReflectionBinding Name}" /> ValueMemberBinding="{ReflectionBinding MenuHeader}" />
<u:AutoCompleteBox <u:AutoCompleteBox
Classes="Small" Classes="Small"
ValueMemberBinding="{ReflectionBinding Name}" /> ValueMemberBinding="{ReflectionBinding MenuHeader}" />
<u:AutoCompleteBox <u:AutoCompleteBox
Classes="Bordered" Classes="Bordered"
ValueMemberBinding="{ReflectionBinding Name}" /> ValueMemberBinding="{ReflectionBinding MenuHeader}" />
<u:AutoCompleteBox <u:AutoCompleteBox
IsEnabled="False" IsEnabled="False"
Watermark="Disabled" Watermark="Disabled"
ValueMemberBinding="{ReflectionBinding Name}" /> ValueMemberBinding="{ReflectionBinding MenuHeader}" />
<u:AutoCompleteBox <u:AutoCompleteBox
InnerLeftContent="https://" InnerLeftContent="https://"
InnerRightContent=".com" InnerRightContent=".com"
ValueMemberBinding="{ReflectionBinding Name}" /> ValueMemberBinding="{ReflectionBinding MenuHeader}" />
</StackPanel> </StackPanel>
</UserControl> </UserControl>

View File

@@ -4,6 +4,7 @@
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:u="https://irihi.tech/ursa" xmlns:u="https://irihi.tech/ursa"
xmlns:vm="clr-namespace:Ursa.Demo.ViewModels" xmlns:vm="clr-namespace:Ursa.Demo.ViewModels"
xmlns:models="clr-namespace:Ursa.Demo.Models"
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450" mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
x:DataType="vm:MultiAutoCompleteBoxDemoViewModel" x:DataType="vm:MultiAutoCompleteBoxDemoViewModel"
x:Class="Ursa.Demo.Pages.MultiAutoCompleteBoxDemo"> x:Class="Ursa.Demo.Pages.MultiAutoCompleteBoxDemo">
@@ -16,7 +17,7 @@
ItemFilter="{Binding FilterPredicate}" ItemFilter="{Binding FilterPredicate}"
FilterMode="Custom"> FilterMode="Custom">
<u:MultiAutoCompleteBox.ItemTemplate> <u:MultiAutoCompleteBox.ItemTemplate>
<DataTemplate DataType="vm:ControlData"> <DataTemplate DataType="models:ControlData">
<StackPanel Orientation="Horizontal"> <StackPanel Orientation="Horizontal">
<TextBlock Text="{Binding MenuHeader}" VerticalAlignment="Center"/> <TextBlock Text="{Binding MenuHeader}" VerticalAlignment="Center"/>
<TextBlock Text="{Binding Chinese}" Classes="Secondary" FontSize="12" Margin="8 0 0 0" VerticalAlignment="Center"/> <TextBlock Text="{Binding Chinese}" Classes="Secondary" FontSize="12" Margin="8 0 0 0" VerticalAlignment="Center"/>
@@ -24,7 +25,7 @@
</DataTemplate> </DataTemplate>
</u:MultiAutoCompleteBox.ItemTemplate> </u:MultiAutoCompleteBox.ItemTemplate>
<u:MultiAutoCompleteBox.SelectedItemTemplate> <u:MultiAutoCompleteBox.SelectedItemTemplate>
<DataTemplate DataType="vm:ControlData"> <DataTemplate DataType="models:ControlData">
<TextBlock Text="{Binding MenuHeader}" /> <TextBlock Text="{Binding MenuHeader}" />
</DataTemplate> </DataTemplate>
</u:MultiAutoCompleteBox.SelectedItemTemplate> </u:MultiAutoCompleteBox.SelectedItemTemplate>

View File

@@ -1,6 +1,6 @@
using System.Collections.Generic;
using System.Collections.ObjectModel; using System.Collections.ObjectModel;
using CommunityToolkit.Mvvm.ComponentModel; using CommunityToolkit.Mvvm.ComponentModel;
using Ursa.Demo.Models;
namespace Ursa.Demo.ViewModels; namespace Ursa.Demo.ViewModels;
@@ -8,79 +8,69 @@ public class AutoCompleteBoxDemoViewModel : ObservableObject
{ {
public AutoCompleteBoxDemoViewModel() public AutoCompleteBoxDemoViewModel()
{ {
States = new ObservableCollection<StateData>(GetStates()); Controls = new ObservableCollection<ControlData>(GetControlData());
} }
public ObservableCollection<StateData> States { get; set; } public ObservableCollection<ControlData> Controls { get; set; }
private static List<StateData> GetStates() private static ControlData[] GetControlData()
{ {
return new List<StateData> return new ControlData[]
{ {
new("Alabama", "AL", "Montgomery"), new() { MenuHeader = "Button Group", Chinese = "按钮组" },
new("Alaska", "AK", "Juneau"), new() { MenuHeader = "Icon Button", Chinese = "图标按钮" },
new("Arizona", "AZ", "Phoenix"), new() { MenuHeader = "AutoCompleteBox", Chinese = "自动完成框" },
new("Arkansas", "AR", "Little Rock"), new() { MenuHeader = "Class Input", Chinese = "类输入框" },
new("California", "CA", "Sacramento"), new() { MenuHeader = "Enum Selector", Chinese = "枚举选择器" },
new("Colorado", "CO", "Denver"), new() { MenuHeader = "Form", Chinese = "表单" },
new("Connecticut", "CT", "Hartford"), new() { MenuHeader = "KeyGestureInput", Chinese = "快捷键输入" },
new("Delaware", "DE", "Dover"), new() { MenuHeader = "IPv4Box", Chinese = "IPv4输入框" },
new("Florida", "FL", "Tallahassee"), new() { MenuHeader = "MultiComboBox", Chinese = "多选组合框" },
new("Georgia", "GA", "Atlanta"), new() { MenuHeader = "Multi AutoCompleteBox", Chinese = "多项自动完成框" },
new("Hawaii", "HI", "Honolulu"), new() { MenuHeader = "Numeric UpDown", Chinese = "数字上下调节" },
new("Idaho", "ID", "Boise"), new() { MenuHeader = "NumPad", Chinese = "数字键盘" },
new("Illinois", "IL", "Springfield"), new() { MenuHeader = "PathPicker", Chinese = "路径选择器" },
new("Indiana", "IN", "Indianapolis"), new() { MenuHeader = "PinCode", Chinese = "密码输入" },
new("Iowa", "IA", "Des Moines"), new() { MenuHeader = "RangeSlider", Chinese = "范围滑块" },
new("Kansas", "KS", "Topeka"), new() { MenuHeader = "Rating", Chinese = "评分" },
new("Kentucky", "KY", "Frankfort"), new() { MenuHeader = "Selection List", Chinese = "选择列表" },
new("Louisiana", "LA", "Baton Rouge"), new() { MenuHeader = "TagInput", Chinese = "标签输入" },
new("Maine", "ME", "Augusta"), new() { MenuHeader = "Theme Toggler", Chinese = "主题切换" },
new("Maryland", "MD", "Annapolis"), new() { MenuHeader = "TreeComboBox", Chinese = "树形组合框" },
new("Massachusetts", "MA", "Boston"), new() { MenuHeader = "Dialog", Chinese = "对话框" },
new("Michigan", "MI", "Lansing"), new() { MenuHeader = "Drawer", Chinese = "抽屉" },
new("Minnesota", "MN", "St. Paul"), new() { MenuHeader = "Loading", Chinese = "加载" },
new("Mississippi", "MS", "Jackson"), new() { MenuHeader = "Message Box", Chinese = "消息框" },
new("Missouri", "MO", "Jefferson City"), new() { MenuHeader = "Notification", Chinese = "通知" },
new("Montana", "MT", "Helena"), new() { MenuHeader = "PopConfirm", Chinese = "气泡确认" },
new("Nebraska", "NE", "Lincoln"), new() { MenuHeader = "Toast", Chinese = "吐司" },
new("Nevada", "NV", "Carson City"), new() { MenuHeader = "Skeleton", Chinese = "骨架屏" },
new("New Hampshire", "NH", "Concord"), new() { MenuHeader = "Date Picker", Chinese = "日期选择器" },
new("New Jersey", "NJ", "Trenton"), new() { MenuHeader = "Date Range Picker", Chinese = "日期范围选择器" },
new("New Mexico", "NM", "Santa Fe"), new() { MenuHeader = "Date Time Picker", Chinese = "日期时间选择器" },
new("New York", "NY", "Albany"), new() { MenuHeader = "Time Box", Chinese = "时间输入框" },
new("North Carolina", "NC", "Raleigh"), new() { MenuHeader = "Time Picker", Chinese = "时间选择器" },
new("North Dakota", "ND", "Bismarck"), new() { MenuHeader = "Time Range Picker", Chinese = "时间范围选择器" },
new("Ohio", "OH", "Columbus"), new() { MenuHeader = "Clock", Chinese = "时钟" },
new("Oklahoma", "OK", "Oklahoma City"), new() { MenuHeader = "Anchor", Chinese = "锚点" },
new("Oregon", "OR", "Salem"), new() { MenuHeader = "Breadcrumb", Chinese = "面包屑" },
new("Pennsylvania", "PA", "Harrisburg"), new() { MenuHeader = "Nav Menu", Chinese = "导航菜单" },
new("Rhode Island", "RI", "Providence"), new() { MenuHeader = "Pagination", Chinese = "分页" },
new("South Carolina", "SC", "Columbia"), new() { MenuHeader = "ToolBar", Chinese = "工具栏" },
new("South Dakota", "SD", "Pierre"), new() { MenuHeader = "AspectRatioLayout", Chinese = "宽高比布局" },
new("Tennessee", "TN", "Nashville"), new() { MenuHeader = "Avatar", Chinese = "头像" },
new("Texas", "TX", "Austin"), new() { MenuHeader = "Badge", Chinese = "徽章" },
new("Utah", "UT", "Salt Lake City"), new() { MenuHeader = "Banner", Chinese = "横幅" },
new("Vermont", "VT", "Montpelier"), new() { MenuHeader = "Disable Container", Chinese = "禁用容器" },
new("Virginia", "VA", "Richmond"), new() { MenuHeader = "Divider", Chinese = "分割线" },
new("Washington", "WA", "Olympia"), new() { MenuHeader = "DualBadge", Chinese = "双徽章" },
new("West Virginia", "WV", "Charleston"), new() { MenuHeader = "ImageViewer", Chinese = "图片查看器" },
new("Wisconsin", "WI", "Madison"), new() { MenuHeader = "ElasticWrapPanel", Chinese = "弹性换行面板" },
new("Wyoming", "WY", "Cheyenne") new() { MenuHeader = "Marquee", Chinese = "跑马灯" },
new() { MenuHeader = "Number Displayer", Chinese = "数字显示器" },
new() { MenuHeader = "Scroll To", Chinese = "滚动到按钮" },
new() { MenuHeader = "Timeline", Chinese = "时间轴" },
new() { MenuHeader = "TwoTonePathIcon", Chinese = "双色路径图标" }
}; };
} }
} }
public class StateData
{
public StateData(string name, string abbreviation, string capital)
{
Name = name;
Abbreviation = abbreviation;
Capital = capital;
}
public string Name { get; private set; }
public string Abbreviation { get; private set; }
public string Capital { get; private set; }
}

View File

@@ -3,6 +3,7 @@ using System.Collections.Generic;
using System.Collections.ObjectModel; using System.Collections.ObjectModel;
using Avalonia.Controls; using Avalonia.Controls;
using CommunityToolkit.Mvvm.ComponentModel; using CommunityToolkit.Mvvm.ComponentModel;
using Ursa.Demo.Models;
namespace Ursa.Demo.ViewModels; namespace Ursa.Demo.ViewModels;
@@ -87,9 +88,3 @@ public class MultiAutoCompleteBoxDemoViewModel : ObservableObject
control.Chinese.Contains(text, StringComparison.InvariantCultureIgnoreCase); control.Chinese.Contains(text, StringComparison.InvariantCultureIgnoreCase);
} }
} }
public class ControlData
{
public required string MenuHeader { get; init; }
public required string Chinese { get; init; }
}