Components
Textfield
Used to enter spesific text input form
Usage
Textfield are used to defines a text input control.
Use Legion Textfield styles allow users to type text into an app, with support lots type and attribute to customize.
import LegionUI
Variant
Legion IOS Have 2 Variant of Textfield :
Outline
data:image/s3,"s3://crabby-images/db41a/db41a8259a7d1f190fe974210bea4c5c1be9c970" alt=""
data:image/s3,"s3://crabby-images/435f5/435f581b80d1810e1e8ce9bebc9fc59558e31d34" alt=""
data:image/s3,"s3://crabby-images/cf7ce/cf7cec3e6e6b8c9f0035d1c3e15401ab7d76aa48" alt=""
data:image/s3,"s3://crabby-images/1d661/1d6619f5f723aa56aeffebc44c1b217ba99d4d54" alt=""
Choose type textfield : LGNOutlineTxtField
and use this Function : @State var state: LGNStateField = .TextType
, where the .TextTypeconsists
of .success
, .error
and .focussed
This code sample demonstrates how to modify the type of the textfield :
A. Outline idle
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text)}
B. Outline success
@State var text: String = ""@State var state: LGNStateField = .successvar body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
C. Outline error
@State var text: String = ""@State var state: LGNStateField = .errorvar body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
D. Outline focussed
@State var text: String = ""@State var state: LGNStateField = .focussedvar body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
Inline
data:image/s3,"s3://crabby-images/df3a5/df3a5400953ccec73af915bc330c2cdafd047245" alt=""
data:image/s3,"s3://crabby-images/c0bf2/c0bf2be31aff5f6d4d7e3a835607446464ad7a16" alt=""
data:image/s3,"s3://crabby-images/4f052/4f052c272056af0a5187c568b1b4a008238b3cd6" alt=""
data:image/s3,"s3://crabby-images/9988b/9988bf1863bae61ae5df40ca3ab6c2294a790a4e" alt=""
Choose type textfield : LGNInlineTxtField
and use this Function : @State var state: LGNStateField = .TextType
, where the .TextTypeconsists
of .success
, .error
and .focussed
This code sample demonstrates how to modify the type of the textfield :
A. Inline idle
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text)}
B. Inline success
@State var text: String = ""@State var state: LGNStateField = .successvar body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
C. Inline error
@State var text: String = ""@State var state: LGNStateField = .errorvar body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
D. Inline focussed
@State var text: String = ""@State var state: LGNStateField = .focussedvar body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
Attribute
Legion Have 6 Attributes for Costumize Textfield :
Disable
This disable attribute for user to inactive the textfield.
data:image/s3,"s3://crabby-images/0df87/0df872e835afd57ab5f799e39c2d0f1c460dfde8" alt=""
data:image/s3,"s3://crabby-images/ef7d3/ef7d317cd4f645a2f54772b342ac1537e3351068" alt=""
Choose type textfield LGNOutlineTxtField
or LGNInlineTxtField
and add @State var state: LGNStateField
= with .disable
This code sample demonstrates how to modify the disable of the textfield :
A. Outline disable
@State var text: String = ""@State var state: LGNStateField = .disablevar body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
B. Inline disable
@State var text: String = ""@State var state: LGNStateField = .disablevar body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text).state(state)}
Icon
data:image/s3,"s3://crabby-images/7b47e/7b47e758bbe79e6615412083160e03148d312a33" alt=""
data:image/s3,"s3://crabby-images/fdd8c/fdd8c6a2dd9cad46050ec9c23ef4a95093923f3d" alt=""
This icon attribute for user to choose the icon position inside the textfield.
Choose Type Textfield LGNOutlineTxtField
or LGNInlineTxtField
and add leftIcon: Image(systemName: "")
where the systemName: “”
fill with the icon
This code sample demonstrates how to modify the icon of the textfield :
A. Outline Icon
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,leftIcon: Image(systemName: "info.circle"))}
B. Inline Icon
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,leftIcon: Image(systemName: "info.circle"))}
Label
data:image/s3,"s3://crabby-images/fc021/fc0218afff75bea4fade0820d4d93fd76da99d35" alt=""
data:image/s3,"s3://crabby-images/3eee4/3eee43cd619d22d1de570b5041f3557e87c6e5ed" alt=""
This label attribute for user to customize label of the textfield.
Choose Type Textfield LGNOutlineTxtField or LGNInlineTxtField and add label: with value of the label
This code sample demonstrates how to modify the label of the textview :
A. Outline Icon
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,label: "title")}
B. Inline Icon
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,label: "title")}
Caption
This caption attribute for user to customize caption under of the textfield:
data:image/s3,"s3://crabby-images/6f4ae/6f4ae606d5857db8c2c3e3386bd6fc6db5fd246e" alt=""
data:image/s3,"s3://crabby-images/bfb61/bfb61936cbe6d03b6ac5286050229500451b7801" alt=""
data:image/s3,"s3://crabby-images/9f1af/9f1af0898cc6bad1e5dd009655705c7f44048c16" alt=""
data:image/s3,"s3://crabby-images/c275d/c275dd78bf3975164ecbd26e60fe70cdb245c74d" alt=""
With Image
This code sample demonstrates how to modify the caption of the textview :
A. Outline Image
@State var text: String = ""@State var showCaption: Bool = truevar body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text).showCaption(caption: LGNContentModel(
B. Inline Image
@State var text: String = ""@State var showCaption: Bool = truevar body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text).showCaption(caption: LGNContentModel(
Without Image
This code sample demonstrates how to modify the caption of the text view :
A. Outline Without Image
@State var text: String = ""@State var showCaption: Bool = truevar body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,).showCaption(caption: LGNContentModel(text: "text"),
B. Inline Without Image
@State var text: String = ""@State var showCaption: Bool = truevar body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,).showCaption(caption: LGNContentModel(text: "text"),
Prefix
This Prefix attribute for user to customize value prefix of the textfield
data:image/s3,"s3://crabby-images/4b62f/4b62fd0b1f0310fc1f1ed72a74ae5faa9fde9fa4" alt=""
data:image/s3,"s3://crabby-images/9df5e/9df5e99c59976125e4192e4e409aaa686767dbff" alt=""
data:image/s3,"s3://crabby-images/fb061/fb061fb964783034c099bc103927fd9334045023" alt=""
data:image/s3,"s3://crabby-images/dd63f/dd63f9d579c69bf78ac0f5076920dcd6e978273d" alt=""
The prefix sets or returns the namespace prefix of an attribute.
This code sample demonstrates how to modify the prefix of the textview :
Prefix With Image
A. Outline Prefix Image
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,prefix: LGNContentModel(image: Image(systemName: "chevron.right"),text: "prefix")
B. Inline Preffix Image
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,prefix: LGNContentModel(image: Image(systemName: "chevron.right"),text: "prefix")
Prefix Without Image
A. Outline Preffix Without Image
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,prefix: LGNContentModel(text: "prefix"))}
B. Inline Preffix Without Image
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,prefix: LGNContentModel(text: "prefix"))}
Suffix
This Suffix attribute for user to customize value suffix of the textfield
data:image/s3,"s3://crabby-images/0dd6e/0dd6ed029979db506f33e88cf612821be6024c9f" alt=""
data:image/s3,"s3://crabby-images/bd0a3/bd0a3b724b41998e5f226f9dbeeadfc3b6b1fabb" alt=""
data:image/s3,"s3://crabby-images/b371c/b371c2bd70ab633dc2eda90e9e76e73d954abb5b" alt=""
data:image/s3,"s3://crabby-images/bd413/bd413bb868508b105991ff645ceadef3baaae220" alt=""
The suffix sets or returns the namespace suffix of an attribute.
This code sample demonstrates how to modify the suffix of the textview :
Suffix With Image
A. Outline Suffix Image
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,suffix: LGNContentModel(image: Image(systemName: "chevron.left"),text: "suffix")
B. Inline Suffix Image
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,suffix: LGNContentModel(image: Image(systemName: "chevron.left"),text: "suffix")
Suffix Without Image
A. Outline Suffix Without Image
@State var text: String = ""var body: some View {LGNOutlineTxtField(titleKey: "Placeholder",text: $text,suffix: LGNContentModel(text: "suffix"))}
B. Inline Suffix Without Image
@State var text: String = ""var body: some View {LGNInlineTxtField(titleKey: "Placeholder",text: $text,suffix: LGNContentModel(text: "suffix"))}
Properties
Properties | Description | Default Value |
---|---|---|
titleKey | The key for the localized title of the text field, describing its purpose, default value is empty string | empty string "" |
text | The key for the localized title of the text field, describing its purpose, default value is empty string | not have |
label | The label to represent the title of the text field, default value is nil | nil (literal null value for objective-C classes) |
leftIcon | The icon is on the left of the text | nil (literal null value for objective-C classes) |
prefix | The icon is on the left of the text | nil (literal null value for objective-C classes) |
sufix | To show suffix content with position right side in text field | nil (literal null value for objective-C classes) |
defaultBorderColor | The color will appear on the border of the text field, default value is Color tertiary300 | color.tertiary300 |
errorBorderColor | The color will appear on the border of the text field, default value is Color tertiary300 | color.error500 |
successBorderColor | The color will appear on the border of the text field on the success state, default value is Color success500 | color.error500 |
Do you have feedback?
Please let us know to make it better