All the controls missing in WPF. Over 1 million downloads.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

118 lines
6.2 KiB

<!--*********************************************************************
Extended WPF Toolkit
Copyright (C) 2010-2012 Xceed Software Inc.
This program is provided to you under the terms of the Microsoft Public
License (Ms-PL) as published at http://wpftoolkit.codeplex.com/license
This program can be provided to you by Xceed Software Inc. under a
proprietary commercial license agreement for use in non-Open Source
projects. The commercial version of Extended WPF Toolkit also includes
priority technical support, commercial updates, and many additional
useful WPF controls if you license Xceed Business Suite for WPF.
Visit http://xceed.com and follow @datagrid on Twitter.
********************************************************************-->
<sample:DemoView x:Class="Samples.Modules.Text.Views.AutoSelectTextBoxView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:sample="clr-namespace:Samples.Infrastructure.Controls;assembly=Samples.Infrastructure"
xmlns:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
Title="AutoSelectTextBox"
Description="The AutoSelectTextBox allow to select the text content when the control get the focus. It also allow to affect the Focus navigation behavior winthin the control">
<StackPanel>
<StackPanel.Resources>
<Style TargetType="{x:Type xctk:AutoSelectTextBox}">
<Setter Property="Margin" Value="5"/>
<Setter Property="AutoSelectBehavior" Value="{Binding SelectedItem, ElementName=_autoSelectBehavior}"/>
<Setter Property="AutoMoveFocus" Value="{Binding IsChecked, ElementName=_autoMoveFocus}"/>
</Style>
</StackPanel.Resources>
<!-- FEATURES GROUP BOX -->
<GroupBox Header="Features" >
<Grid Margin="5">
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition />
</Grid.ColumnDefinitions>
<StackPanel Orientation="Horizontal" Grid.Column="0">
<TextBlock Grid.Row="0" Grid.Column="0" Text="AutoSelectBehavior: " VerticalAlignment="Center" />
<ComboBox Grid.Row="0" Grid.Column="1" x:Name="_autoSelectBehavior" SelectedIndex="1" Width="100" VerticalAlignment="Center">
<x:StaticExtension Member="xctk:AutoSelectBehavior.Never" />
<x:StaticExtension Member="xctk:AutoSelectBehavior.OnFocus" />
</ComboBox>
</StackPanel>
<StackPanel Orientation="Horizontal" Grid.Column="1">
<TextBlock Grid.Row="0" Grid.Column="2" Text="AutoMoveFocus: " VerticalAlignment="Center" />
<CheckBox Grid.Row="0" Grid.Column="3" x:Name="_autoMoveFocus" IsChecked="True" VerticalAlignment="Center"/>
</StackPanel>
</Grid>
</GroupBox>
<StackPanel>
<TextBlock Text="Usage:" Style="{StaticResource Header}"/>
<RichTextBox IsReadOnly="True" BorderThickness="0">
<FlowDocument>
<Paragraph>
<Bold>AutoSelectBehavior:</Bold>
<LineBreak/>
Controled by the "AutoSelectBehavior" property, the content of the AutoSelectTextBox will be selected or not when the control get the focus.
<LineBreak/>
<LineBreak/>
<Bold>AutoMoveFocus:</Bold>
<LineBreak/>
<Italic>Effect with "MaxLength" property:</Italic>
<LineBreak/>
<LineBreak/>
Setting the "MaxLenght" of the text box allow the focus to move from the AutoSelectTextBox once the max lenght has been reached.
In the following "Telephone Number" fields, the "MaxLenght" property of the control has been set to 3, 3 and 4, respectively
</Paragraph>
</FlowDocument>
</RichTextBox>
<!-- PHONE NUMBER FIELDS -->
<StackPanel Orientation="Horizontal" HorizontalAlignment="Center">
<TextBlock Text="(" VerticalAlignment="Center"/>
<xctk:AutoSelectTextBox MaxLength="3" Width="30" Text="555"/>
<TextBlock Text=")" VerticalAlignment="Center"/>
<xctk:AutoSelectTextBox MaxLength="3" Width="30" Text="555"/>
<TextBlock Text="-" VerticalAlignment="Center"/>
<xctk:AutoSelectTextBox MaxLength="4" Width="40" Text="5555"/>
</StackPanel>
<RichTextBox IsReadOnly="True" BorderThickness="0">
<FlowDocument>
<Paragraph>
<Italic>Effect with Arrow keys</Italic>
<LineBreak/>
<LineBreak/>
The "AutoMoveFocus" at true also allow to navigate the focus thru the controls using the arrow keys to move the focus up, down, left or right.
You are no longer limited to the "left-right" scenario of the "Tab, Shift-Tab" keys.
</Paragraph>
</FlowDocument>
</RichTextBox>
<!-- TEXTBOX MATRIX -->
<StackPanel Orientation="Vertical" HorizontalAlignment="Center">
<StackPanel Orientation="Horizontal">
<xctk:AutoSelectTextBox Text="Text1" Width="100" />
<xctk:AutoSelectTextBox Text="Text2" Width="100"/>
<xctk:AutoSelectTextBox Text="Text3" Width="100"/>
</StackPanel>
<StackPanel Orientation="Horizontal">
<xctk:AutoSelectTextBox Text="Text4" Width="100"/>
<xctk:AutoSelectTextBox Text="Text5" Width="100"/>
<xctk:AutoSelectTextBox Text="Text6" Width="100"/>
</StackPanel>
<StackPanel Orientation="Horizontal">
<xctk:AutoSelectTextBox Text="Text7" Width="100"/>
<xctk:AutoSelectTextBox Text="Text8" Width="100"/>
<xctk:AutoSelectTextBox Text="Text9" Width="100"/>
</StackPanel>
</StackPanel>
</StackPanel>
</StackPanel>
</sample:DemoView>