Select Git revision
text_2.3.2.xml
text_2.3.2.xml 19.53 KiB
<widget xmlns="http://openajax.org/metadata" spec="1.0" id="http://microsoft.com/appmagic/text" name="text" jsClass="AppMagic.Controls.Text" version="2.3.2" styleable="true" runtimeCost="1" xmlns:appMagic="http://schemas.microsoft.com/appMagic">
<author name="Microsoft AppMagic" />
<license type="text/html"><![CDATA[<p>TODO: Need license text here.</p>]]></license>
<description><![CDATA[TEXT
Control description here.]]></description>
<requires>
<require type="css" src="css/text.css" excludeOnFeatureGate="controls.reactText" />
<require type="javascript" src="js/text.js" excludeOnFeatureGate="controls.reactText" />
<require type="javascript" src="js/textReactProxy.js" includeOnFeatureGate="controls.reactText" />
</requires>
<appMagic:capabilities contextualViewsEnabled="true" autoBorders="true" autoFocusedBorders="true" autoFill="true" autoPointerViewState="true" autoDisabledViewState="true" autoBorderRadius="true" isVersionFlexible="true" supportsSetFocus="true" />
<appMagic:accessibilityChecks controlIsInteractive="true" />
<content><![CDATA[
<div class="appmagic-textbox" touch-action="pan-x pan-y"
appmagic-control="__WID__">
<!-- ko if: (mode() === "multiline") -->
<textarea
appmagic-control="__WID__textarea"
class="appmagic-textarea mousetrap block-undo-redo"
data-control-part="text"
data-bind="
value: text,
css: {
underline: properties.Underline,
strikethrough: properties.Strikethrough,
readonly: viewState.displayMode() === AppMagic.Constants.DisplayMode.View
},
event: {
click: handleClick,
change: handleOnChange
},
attr: {
title: properties.Tooltip() || null,
'aria-label': properties.AccessibleLabel() || null,
placeholder: properties.HintText,
readonly: viewState.displayMode() === AppMagic.Constants.DisplayMode.View,
maxlength: properties.MaxLength() < 0 ? 0 : properties.MaxLength()
},
style: {
fontFamily: properties.Font,
fontSize: properties.Size,
color: autoProperties.Color,
fontWeight: properties.FontWeight,
fontStyle: properties.Italic,
textAlign: properties.Align,
lineHeight: properties.LineHeight,
paddingTop: properties.PaddingTop,
paddingRight: properties.PaddingRight,
paddingBottom: properties.PaddingBottom,
paddingLeft: properties.PaddingLeft
},
disable: viewState.displayMode() === AppMagic.Constants.DisplayMode.Disabled">
</textarea>
<!-- /ko -->
<!-- ko if: (mode() !== "multiline") -->
<input
appmagic-control="__WID__textbox"
class="appmagic-text mousetrap block-undo-redo"
maxlength="10000"
data-bind="
attr: {
type: mode() === 'password' ? 'password' : 'text',
title: properties.Tooltip() || null,
'aria-label': properties.AccessibleLabel() || null,
placeholder: properties.HintText,
readonly: viewState.displayMode() === AppMagic.Constants.DisplayMode.View,
'data-control-part': properties.Clear() ? 'text clearable' : 'text',
inputmode: keyboardMode,
maxlength: properties.MaxLength() < 0 ? 0 : properties.MaxLength()
},
css: {
underline: properties.Underline,
strikethrough: properties.Strikethrough,
readonly: viewState.displayMode() === AppMagic.Constants.DisplayMode.View
},
value: text,
event: {
click: handleClick,
change: handleOnChange
},
style: {
fontFamily: properties.Font,
fontSize: properties.Size,
color: autoProperties.Color,
fontWeight: properties.FontWeight,
fontStyle: properties.Italic,
textAlign: properties.Align,
lineHeight: properties.LineHeight,
paddingTop: properties.PaddingTop,
paddingRight: properties.PaddingRight,
paddingBottom: properties.PaddingBottom,
paddingLeft: properties.PaddingLeft
},
disable: viewState.displayMode() === AppMagic.Constants.DisplayMode.Disabled">
</input>
<div class='appmagic-text-clear-container'>
<button class='appmagic-text-clear-button'
data-control-part="clear"
data-bind="
visible: isFocused() && properties.Clear() && properties.Text() && mode() !== 'password' && viewState.displayMode() === AppMagic.Constants.DisplayMode.Edit,
event: {click: handleClearClick},
attr: {'aria-label': AppMagic.Strings.TextInputClearButtonLabel},
style: {color: autoProperties.Color}">
<svg
class='appmagic-text-clear-svg'
xmlns='http://www.w3.org/2000/svg'
viewbox='0 0 12 12'
aria-hidden='true'
focusable='false'>
<polygon points="12,1.1 10.9,0 6,4.9 1.1,0 0,1.1 4.9,6 0,10.9 1.1,12 6,7.1 10.9,12 12,10.9 7.1,6"></polygon>
</svg>
</button>
</div>
<!-- /ko -->
<!-- ko if: properties.Format() === 'number' && viewState.displayMode() === AppMagic.Constants.DisplayMode.Edit -->
<div class="a11y" aria-live="assertive" aria-atomic="true"></div>
<!-- /ko -->
</div>
]]></content>
<properties>
<property name="Default" localizedName="##text_Default##" datatype="String" defaultValue="##Text_DefaultValue_Default##" isExpr="true" editable="true" direction="in" isPrimaryInputProperty="true">
<title>Initial text</title>
<appMagic:category>data</appMagic:category>
<appMagic:displayName>##text_Default_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_Default_Tooltip##</appMagic:tooltip>
</property>
<property name="Text" localizedName="##text_Text##" datatype="String" direction="out" isPrimaryOutputProperty="true" supportsAutomation="true">
<title>Output Text</title>
<appMagic:category>data</appMagic:category>
</property>
<property name="Mode" localizedName="##text_Mode##" datatype="TextMode" defaultValue="%TextMode.RESERVED%.SingleLine" isExpr="true">
<title>Textbox Mode</title>
<appMagic:category>design</appMagic:category>
<appMagic:helperUI>TextMode</appMagic:helperUI>
<appMagic:displayName>##text_Mode_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_Mode_Tooltip##</appMagic:tooltip>
</property>
<property name="Format" localizedName="##text_Format##" datatype="TextFormat" defaultValue="%TextFormat.RESERVED%.Text" isExpr="true">
<title>Input textbox Format</title>
<appMagic:category>design</appMagic:category>
<appMagic:helperUI>TextFormat</appMagic:helperUI>
<appMagic:displayName>##text_Format_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_Format_Tooltip##</appMagic:tooltip>
</property>
<property name="VirtualKeyboardMode" localizedName="##text_VirtualKeyboardMode##" datatype="VirtualKeyboardMode" defaultValue="%VirtualKeyboardMode.RESERVED%.Auto" isExpr="true">
<title>Input Keyboard Type</title>
<appMagic:category>design</appMagic:category>
<appMagic:helperUI>VirtualKeyboardMode</appMagic:helperUI>
<appMagic:displayName>##text_VirtualKeyboardMode_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_VirtualKeyboardMode_Tooltip##</appMagic:tooltip>
</property>
<property name="Clear" localizedName="##text_Clear##" datatype="Boolean" defaultValue="false">
<title>Clear Button</title>
<appMagic:category>design</appMagic:category>
<appMagic:helperUI>boolean</appMagic:helperUI>
<appMagic:displayName>##text_Clear_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_Clear_Tooltip##</appMagic:tooltip>
</property>
<property name="EnableSpellCheck" localizedName="##text_EnableSpellCheck##" datatype="Boolean" defaultValue="false">
<title>Enable spell check</title>
<appMagic:category>design</appMagic:category>
<appMagic:helperUI>boolean</appMagic:helperUI>
<appMagic:displayName>##text_EnableSpellCheck_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_EnableSpellCheck_Tooltip##</appMagic:tooltip>
</property>
<property name="Reset" localizedName="##commonProperties_Reset##" datatype="Boolean" defaultValue="false" direction="in">
<title>Reset</title>
<appMagic:category>data</appMagic:category>
<appMagic:displayName>##commonProperties_Reset_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##commonProperties_Reset_Tooltip##</appMagic:tooltip>
</property>
<property name="LineHeight" localizedName="##text_LineHeight##" datatype="Number" defaultValue="1.2">
<title>Line Height</title>
<appMagic:category>design</appMagic:category>
<appMagic:displayName>##text_LineHeight_DisplayName##</appMagic:displayName>
<appMagic:helperUI>lineWidth</appMagic:helperUI>
<appMagic:tooltip>##label_LineHeight_Tooltip##</appMagic:tooltip>
</property>
<property name="HintText" localizedName="##text_HintText##" datatype="String">
<title>Hint text</title>
<appMagic:category>data</appMagic:category>
<appMagic:displayName>##text_HintText_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_HintText_Tooltip##</appMagic:tooltip>
</property>
<property name="MaxLength" localizedName="##commonProperties_MaxLength##" datatype="Number" default="" direction="in" isExpr="true">
<title>MaxLength</title>
<appMagic:category>data</appMagic:category>
<appMagic:displayName>##commonProperties_MaxLength_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##commonProperties_MaxLength_Tooltip##</appMagic:tooltip>
</property>
<property name="DelayOutput" localizedName="##text_DelayOutput##" datatype="Boolean" defaultValue="false" direction="in" isExpr="true">
<title>DelayOutput</title>
<appMagic:category>data</appMagic:category>
<appMagic:displayName>##text_DelayOutput_DisplayName##</appMagic:displayName>
<appMagic:tooltip>##text_DelayOutput_Tooltip##</appMagic:tooltip>
</property>
</properties>
<appMagic:includeProperties>
<!-- Data -->
<appMagic:includeProperty name="AccessibleLabel" />
<appMagic:includeProperty name="Tooltip">
<appMagic:commandBar>
<appMagic:visible>true</appMagic:visible>
</appMagic:commandBar>
</appMagic:includeProperty>
<appMagic:includeProperty name="ContentLanguage" />
<!-- Design -->
<appMagic:includeProperty name="BorderColor" />
<appMagic:includeProperty name="RadiusTopLeft" defaultValue="5" />
<appMagic:includeProperty name="RadiusTopRight" defaultValue="5" />
<appMagic:includeProperty name="RadiusBottomLeft" defaultValue="5" />
<appMagic:includeProperty name="RadiusBottomRight" defaultValue="5" />
<appMagic:includeProperty name="DisabledBorderColor" defaultValue="ColorFade(Self.BorderColor, 40%)" />
<appMagic:includeProperty name="PressedBorderColor" defaultValue="Self.HoverBorderColor" />
<appMagic:includeProperty name="HoverBorderColor" defaultValue="Self.Color" />
<appMagic:includeProperty name="BorderStyle" />
<appMagic:includeProperty name="BorderThickness" defaultValue="1" />
<appMagic:includeProperty name="FocusedBorderColor" defaultValue="Self.BorderColor" isExpr="true" />
<appMagic:includeProperty name="FocusedBorderThickness" defaultValue="3" />
<appMagic:includeProperty name="Color" defaultValue="RGBA(70, 68, 64, 1)" />
<appMagic:includeProperty name="DisabledColor" defaultValue="ColorFade(Self.Color, 40%)" />
<appMagic:includeProperty name="PressedColor" defaultValue="Self.Color" />
<appMagic:includeProperty name="HoverColor" defaultValue="Self.Color" />
<appMagic:includeProperty name="Fill" defaultValue="RGBA(255, 255, 255, 1)" />
<appMagic:includeProperty name="DisabledFill" defaultValue="Self.Fill" />
<appMagic:includeProperty name="PressedFill" defaultValue="Self.Fill" />
<appMagic:includeProperty name="HoverFill" defaultValue="Self.Fill" />
<appMagic:includeProperty name="Font" />
<appMagic:includeProperty name="Size" defaultValue="14" phoneDefaultValue="24" webDefaultValue="12" />
<appMagic:includeProperty name="FontWeight" />
<appMagic:includeProperty name="Italic" />
<appMagic:includeProperty name="Underline" />
<appMagic:includeProperty name="Strikethrough" />
<appMagic:includeProperty name="Align" />
<appMagic:includeProperty name="PaddingTop" defaultValue="5" />
<appMagic:includeProperty name="PaddingRight" defaultValue="5" />
<appMagic:includeProperty name="PaddingBottom" defaultValue="5" />
<appMagic:includeProperty name="PaddingLeft" defaultValue="12" />
<appMagic:includeProperty name="X" />
<appMagic:includeProperty name="Y" />
<appMagic:includeProperty name="Width" defaultValue="320" phoneDefaultValue="560" webDefaultValue="180" />
<appMagic:includeProperty name="Height" defaultValue="40" phoneDefaultValue="70" webDefaultValue="32" />
<appMagic:includeProperty name="Visible" />
<appMagic:includeProperty name="DisplayMode" />
<appMagic:includeProperty name="TabIndex" />
<!-- Behavior -->
<!-- TASK: 85476: Do Behavior properties make sense as input only? -->
<appMagic:includeProperty name="OnChange" direction="in" />
<appMagic:includeProperty name="OnSelect" direction="in" />
<!--Hidden properties -->
<appMagic:includeProperty name="maximumHeight" defaultValue="768" />
<appMagic:includeProperty name="maximumWidth" defaultValue="1366" />
<appMagic:includeProperty name="minimumHeight" defaultValue="30" />
<appMagic:includeProperty name="minimumWidth" defaultValue="10" />
</appMagic:includeProperties>
<!--Property Dependencies -->
<appMagic:propertyDependencies>
<appMagic:propertyDependency input="Default" output="Text" />
<appMagic:propertyDependency input="MaxLength" output="Text" />
<appMagic:propertyDependency input="Format" output="Text" />
<appMagic:propertyDependency input="Reset" output="Text" />
</appMagic:propertyDependencies>
<appMagic:insertMetadata>
<appMagic:category name="Popular" priority="30" />
<appMagic:category name="Input" priority="20" />
<appMagic:category name="ClassicControls" priority="20" />
</appMagic:insertMetadata>
<!-- Display metadata providing property visibility, order, sections, and grouping in UI (e.g. properties panel) -->
<appMagic:displayMetadata>
<appMagic:section>
<appMagic:property name="Default" />
<appMagic:property name="Format" />
<appMagic:property name="HintText" />
<appMagic:property name="Font" displayType="FontEnum" showInFloatie="true" showInCommandBar="true" />
<appMagic:property name="Size" labelOverride="##FontSize_Property##" showInFloatie="true" showInCommandBar="true" />
<appMagic:property name="FontWeight" displayType="EnumIcon" itemsOrder="Bold;Semibold;Normal;Lighter" showInCommandBar="true" />
<appMagic:propertyGroup name="Style">
<appMagic:property name="Italic" displayType="ToggleButton" />
<appMagic:property name="Underline" displayType="ToggleButton" />
<appMagic:property name="Strikethrough" displayType="ToggleButton" />
</appMagic:propertyGroup>
<appMagic:property name="Align" displayType="EnumButtons" itemsOrder="Left;Center;Right;Justify" labelOverride="##FontAlign_Property##" showInFloatie="true" showInCommandBar="true" floatieDisplayType="FaceplateIconEnum" />
<appMagic:property name="LineHeight" />
<appMagic:property name="Clear" />
<appMagic:property name="EnableSpellCheck" />
<appMagic:property name="MaxLength" />
<appMagic:property name="Mode" />
<appMagic:property name="DisplayMode" />
</appMagic:section>
<appMagic:section>
<appMagic:property name="Visible" />
<appMagic:propertyGroup name="Position">
<appMagic:property name="X" />
<appMagic:property name="Y" />
</appMagic:propertyGroup>
<appMagic:propertyGroup name="Size">
<appMagic:property name="Width" />
<appMagic:property name="Height" />
</appMagic:propertyGroup>
<appMagic:propertyGroup name="Padding">
<appMagic:property name="PaddingTop" labelOverride="##Padding_Top_Title##" />
<appMagic:property name="PaddingBottom" labelOverride="##Padding_Bottom_Title##" />
<appMagic:property name="PaddingLeft" labelOverride="##Padding_Left_Title##" />
<appMagic:property name="PaddingRight" labelOverride="##Padding_Right_Title##" />
</appMagic:propertyGroup>
</appMagic:section>
<appMagic:section>
<appMagic:propertyGroup name="Color">
<appMagic:property name="Color" showInFloatie="true" showInCommandBar="true" />
<appMagic:property name="Fill" showInFloatie="true" showInCommandBar="true" />
</appMagic:propertyGroup>
<appMagic:propertyGroup name="Border">
<appMagic:property name="BorderStyle" showInCommandBar="true" />
<appMagic:property name="BorderThickness" showInCommandBar="true" />
<appMagic:property name="BorderColor" showInCommandBar="true" />
</appMagic:propertyGroup>
<appMagic:propertyGroup name="Radius">
<appMagic:property name="RadiusTopLeft" />
<appMagic:property name="RadiusTopRight" />
<appMagic:property name="RadiusBottomLeft" />
<appMagic:property name="RadiusBottomRight" />
</appMagic:propertyGroup>
</appMagic:section>
<appMagic:section>
<appMagic:propertyGroup name="DisabledColor">
<appMagic:property name="DisabledColor" />
<appMagic:property name="DisabledFill" />
<appMagic:property name="DisabledBorderColor" />
</appMagic:propertyGroup>
<appMagic:propertyGroup name="HoverColor">
<appMagic:property name="HoverColor" />
<appMagic:property name="HoverFill" />
<appMagic:property name="HoverBorderColor" />
</appMagic:propertyGroup>
<appMagic:propertyGroup name="PressedColor">
<appMagic:property name="PressedColor" />
<appMagic:property name="PressedFill" />
<appMagic:property name="PressedBorderColor" />
</appMagic:propertyGroup>
<appMagic:property name="Tooltip" />
<appMagic:property name="TabIndex" />
</appMagic:section>
</appMagic:displayMetadata>
<appMagic:conversion from="2.0.0" to="2.0.1">
<!-- Removed defaultValue for BorderColor. BorderColor default now defined in theme. -->
</appMagic:conversion>
<appMagic:conversion from="2.0.1" to="2.1.0">
<!-- Added a new property VirtualKeyboardMode to hint what type of virtual keyboard for the OS to show-->
<appMagic:conversionAction type="add" name="VirtualKeyboardMode" />
</appMagic:conversion>
<appMagic:conversion from="2.1.0" to="2.2.0">
<!-- Added EnableSpellCheck property. -->
<appMagic:conversionAction type="add" name="EnableSpellCheck" />
</appMagic:conversion>
<appMagic:conversion from="2.2.0" to="2.2.1">
<!-- KO template change to use HTML maxlength attribute -->
</appMagic:conversion>
<appMagic:conversion from="2.2.1" to="2.3.0">
<appMagic:conversionAction type="add" name="ContentLanguage" />
</appMagic:conversion>
<appMagic:conversion from="2.3.0" to="2.3.1">
<!-- KO template changes for accessibility fixes -->
</appMagic:conversion>
<appMagic:conversion from="2.3.1" to="2.3.2">
<!-- KO template changes for accessibility fixes -->
</appMagic:conversion>
</widget>