Components
Button
Used to initiate an action or trigger the users
Status component contains a list of checks and completeness that has been tested and owned by each component
Usage
Buttons are used to initiate an action or trigger the user to open a link.
Use Legion Button styles for actions in forms, dialogs, and more with support lots type and attribute for costumize. Legion Button have 4 variants component: Solid, Outline, Soft, Transparent
Usage With Theme
Available themes: ThemeAGR, ThemeMyTEnS, ThemeIHS & ThemeEazy
Solid
LGNSolidButton(title: "Button") {// Action Handler}
Outline
LGNOutlineButton(title: "Button") {// Action Handler}
Soft
LGNSoftButton(title: "Button") {// Action Handler}
Tranparent
LGNTransparentButton(title: "Button") {// Action Handler}
Usage Without Theme
Solid
SolidBtn(title: "Button") {// Action Handler}
Outline
OutlineBtn(title: "Button") {// Action Handler}
Soft
SoftBtn(title: "Button") {// Action Handler}
Transparent
TransparentBtn(title: "Button") {// Action Handler}
Solid
Solid Responsiveness
This responsive button or boolean attribute for user to choose the button responsively to the screen / layout or not.
Responsive
data:image/s3,"s3://crabby-images/16509/1650938bb4ef4b654b55705dff83f0e52dd88db2" alt=""
LGNSolidButton(title: "Button").variant(size: .medium, responsive: true)
Not Responsive
data:image/s3,"s3://crabby-images/0d990/0d99093ed37c211de29cb2436368e4e8cabf8f08" alt=""
LGNSolidButton(title: "Button").variant(size: .medium, responsive: false)
Solid Size
This size text button attribute for user to choose size text inside the button.
Large
data:image/s3,"s3://crabby-images/f8990/f8990deaed8e8707cea67a9bbc5d1fe363ce4e36" alt=""
LGNSolidButton(title: "Button").variant(size: .large, responsive: true)
Medium
data:image/s3,"s3://crabby-images/16509/1650938bb4ef4b654b55705dff83f0e52dd88db2" alt=""
LGNSolidButton(title: "Button").variant(size: .medium, responsive: true)
Small
data:image/s3,"s3://crabby-images/4ce31/4ce3117779a1325ffab7364f231767bce3fc9fd5" alt=""
LGNSolidButton(title: "Button").variant(size: .small, responsive: true)
Solid Icon
This icon attribute for user to choose the icon position inside the button.
Left Icon
data:image/s3,"s3://crabby-images/1c740/1c7401de94ad696a9200b78f6e612ac48a600eec" alt=""
LGNSolidButton(title: "Button",leftImage: Image(systemName: "square.and.arrow.down"))
Right Icon
data:image/s3,"s3://crabby-images/151d3/151d396ebcaafa200ada04840d23d35c5eb76aef" alt=""
LGNSolidButton(title: "Button",rightImage: Image(systemName: "square.and.arrow.down"))
Icon Only
data:image/s3,"s3://crabby-images/b7369/b7369de41102301ac6bfe677f85abd8d26c3c067" alt=""
LGNSolidButton(title: "",centerImage: Image(systemName: "square.and.arrow.down"))
Solid Disabled
This code sample demonstrates how to modify disable of the button :
data:image/s3,"s3://crabby-images/dd4c9/dd4c9824bd7a13142b8917f2c61edd0b5e7a8a1f" alt=""
LGNSolidButton(title: "Button",).disableInteraction(true)
Solid Show Activity
This code sample demonstrates how to modify show activity of the button :
data:image/s3,"s3://crabby-images/22a5a/22a5a26d7d3246e3b940f4edb6af4df16237089e" alt=""
LGNSolidButton(title: "Button",).showProgressView(true)
Outline
Outline Responsiveness
This responsive button or boolean attribute for user to choose the button responsively to the screen / layout or not.
Responsive
data:image/s3,"s3://crabby-images/8440b/8440b38550b1da9a4e5f5b382fa2b02783f1b350" alt=""
LGNOutlineButton(title: "Button").variant(size: .medium, responsive: true)
Not Responsive
data:image/s3,"s3://crabby-images/86b89/86b893cc66a7dfbbf5372f3a65ab2efa23a6bc9e" alt=""
LGNOutlineButton(title: "Button").variant(size: .medium, responsive: false)
Outline Size
This size text button attribute for user to choose size text inside the button.
Large
data:image/s3,"s3://crabby-images/bc469/bc469dea6055fe395b649c97489ee806d2913fdd" alt=""
LGNOutlineButton(title: "Button").variant(size: .large, responsive: true)
Medium
data:image/s3,"s3://crabby-images/8440b/8440b38550b1da9a4e5f5b382fa2b02783f1b350" alt=""
LGNOutlineButton(title: "Button").variant(size: .medium, responsive: true)
Small
data:image/s3,"s3://crabby-images/d9630/d9630823d27f37f52e83e3ab6194f25a76732859" alt=""
LGNOutlineButton(title: "Button").variant(size: .small, responsive: true)
Outline Icon
This icon attribute for user to choose the icon position inside the button.
Left Icon
data:image/s3,"s3://crabby-images/4a4dd/4a4ddddd68f57e3a9898ce577bb89b2deb9a55be" alt=""
LGNOutlineButton(title: "Button",leftImage: Image(systemName: "square.and.arrow.down"))
Right Icon
data:image/s3,"s3://crabby-images/b1942/b1942cf985560dd5e789563d43f5419398489f70" alt=""
LGNOutlineButton(title: "Button",rightImage: Image(systemName: "square.and.arrow.down"))
Icon Only
data:image/s3,"s3://crabby-images/ad097/ad09737a26f6626667eab263b56f4910e2659e2f" alt=""
LGNOutlineButton(title: "",centerImage: Image(systemName: "square.and.arrow.down"))
Outline Disabled
This code sample demonstrates how to modify disable of the button :
data:image/s3,"s3://crabby-images/dabb6/dabb66adc1382937f0ae9995ab868464014dea2e" alt=""
LGNOutlineButton(title: "Button",).disableInteraction(true)
Outline Show Activity
This code sample demonstrates how to modify show activity of the button :
data:image/s3,"s3://crabby-images/f9037/f9037188306188ee2b7daf54ecf3c40f6726f005" alt=""
LGNOutlineButton(title: "Button",).showProgressView(true)
Soft
Soft Responsiveness
This responsive button or boolean attribute for user to choose the button responsively to the screen / layout or not.
Responsive
data:image/s3,"s3://crabby-images/98fd4/98fd482ca7798d0389f7f453cf717d132ab0d3cb" alt=""
LGNSoftButton(title: "Button").variant(size: .medium, responsive: true)
Not Responsive
data:image/s3,"s3://crabby-images/4b4b9/4b4b987966ebd587317e354a61cecaa80ae3b180" alt=""
LGNSoftButton(title: "Button").variant(size: .medium, responsive: false)
Soft Size
This size text button attribute for user to choose size text inside the button.
Large
data:image/s3,"s3://crabby-images/b0f4a/b0f4a4e204914f63bd360d9ff059fd95bd1a194f" alt=""
LGNSoftButton(title: "Button").variant(size: .large, responsive: true)
Medium
data:image/s3,"s3://crabby-images/98fd4/98fd482ca7798d0389f7f453cf717d132ab0d3cb" alt=""
LGNSoftButton(title: "Button").variant(size: .medium, responsive: true)
Small
data:image/s3,"s3://crabby-images/1869a/1869ae300fbac8822b70cd32faa8015c60ca7bd3" alt=""
LGNSoftButton(title: "Button").variant(size: .small, responsive: true)
Soft Icon
This icon attribute for user to choose the icon position inside the button.
Left Icon
data:image/s3,"s3://crabby-images/c0e2b/c0e2b0e2f09617556c3d2bf84604f1fdcdddeb2f" alt=""
LGNSoftButton(title: "Button",leftImage: Image(systemName: "square.and.arrow.down"))
Right Icon
data:image/s3,"s3://crabby-images/f2856/f28560916b9e58f0f93878ebe52f4f431a52c5a4" alt=""
LGNSoftButton(title: "Button",rightImage: Image(systemName: "square.and.arrow.down"))
Icon Only
data:image/s3,"s3://crabby-images/cf730/cf730a79ea31dd279ea6002b2effa41101a1b9f3" alt=""
LGNSoftButton(title: "",centerImage: Image(systemName: "square.and.arrow.down"))
Soft Disabled
This code sample demonstrates how to modify disable of the button :
data:image/s3,"s3://crabby-images/6f443/6f443a5d642a2592a737224ba44b35bdbb12468b" alt=""
LGNSoftButton(title: "Button",).disableInteraction(true)
Soft Show Activity
This code sample demonstrates how to modify show activity of the button :
data:image/s3,"s3://crabby-images/1f95c/1f95c8f7ac249371c70c89ab4eb0dab0c49fdb8b" alt=""
LGNSoftButton(title: "Button",).showProgressView(true)
Transparent
Transparent Responsiveness
This responsive button or boolean attribute for user to choose the button responsively to the screen / layout or not.
Responsive
data:image/s3,"s3://crabby-images/b44b2/b44b23ef77aeb64cc8fd4c4a7fa5deb8dadd5ef7" alt=""
LGNTransparentButton(title: "Button").variant(size: .medium, responsive: true)
Not Responsive
data:image/s3,"s3://crabby-images/8f030/8f0309384a531a57e950a5c45793503573ea86d0" alt=""
LGNTransparentButton(title: "Button").variant(size: .medium, responsive: false)
Transparent Size
This size text button attribute for user to choose size text inside the button.
Large
data:image/s3,"s3://crabby-images/49ce0/49ce02f04f3e47849f693e4d76dbff44a0107356" alt=""
LGNTransparentButton(title: "Button").variant(size: .large, responsive: true)
Medium
data:image/s3,"s3://crabby-images/b44b2/b44b23ef77aeb64cc8fd4c4a7fa5deb8dadd5ef7" alt=""
LGNTransparentButton(title: "Button").variant(size: .medium, responsive: true)
Small
data:image/s3,"s3://crabby-images/c8653/c865314a75985378ddca0a59f6ec05875232862c" alt=""
LGNTransparentButton(title: "Button").variant(size: .small, responsive: true)
Transparent Icon
This icon attribute for user to choose the icon position inside the button.
Left Icon
data:image/s3,"s3://crabby-images/8abe2/8abe2b2caf20036979020219f0812775871dad3a" alt=""
LGNTransparentButton(title: "Button",leftImage: Image(systemName: "square.and.arrow.down"))
Right Icon
data:image/s3,"s3://crabby-images/b079a/b079abc40a82d52d69d5fe390ab43d7e5b407366" alt=""
LGNTransparentButton(title: "Button",rightImage: Image(systemName: "square.and.arrow.down"))
Icon Only
data:image/s3,"s3://crabby-images/1a6c5/1a6c50f86f4fffa3c925929481403ff4d6a87c32" alt=""
LGNTransparentButton(title: "",centerImage: Image(systemName: "square.and.arrow.down"))
Transparent Disabled
This code sample demonstrates how to modify disable of the button :
data:image/s3,"s3://crabby-images/b1044/b104428f123d47c0ec227175e5b7d6efd20ab8ed" alt=""
LGNTransparentButton(title: "Button",).disableInteraction(true)
Transparent Show Activity
This code sample demonstrates how to modify show activity of the button :
data:image/s3,"s3://crabby-images/0faab/0faab83b683f1062ff248244945a5eba94e2495b" alt=""
LGNTransparentButton(title: "Button",).showProgressView(true)
Properties
Properties | Description | Default Value |
---|---|---|
action | The action to perform when the user triggers the button. | {} |
title | The title for the button’s title, that describes the purpose of the button’s action . | - |
leftImage | Put the image in the left position in the button. | nil |
rightImage | Put the image in the right position in the button. | nil |
centerImage | Put the image in the center position of the button. | nil |
largeTextFont | Change the font on the title button is in large size. | bodyLargeSemibold |
mediumTextFont | Change the font on the title button is in medium size. | bodySmallSemibold |
smallTextFont | Change the font on the title button is in small size. | captionLargeSemibold |
tintBtnColor | To change the tint color of button. | depending on the variant |
tintPressedBtnColor | Change the tint color on the button when pressed state. | depending on the theme |
defaultBtnColor | To change the tint color of button. | depending on the variant |
pressedBtnColor | Change the background color of the button when the button is in pressed state. | depending on the variant |
cornerRadius | Change corner radius value. | 12 |
List of viewModifier
viewModifier | Description | Parameters |
---|---|---|
variant | Button can be modified the size (large, medium, or small) of the title label and also responsive or not. | size and responsive |
disableInteraction | A view that controls whether users can interact with this view. | disabled |
showProgressView | Adds a condition if there is interaction from the user and want to change the button to a loading state. | isShow |