From 274383fc005ba639353404a96209360d3970a7c1 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Wed, 27 Nov 2024 15:21:10 +0000 Subject: [PATCH] deploy: 7bb391ca6ccf5498bd9c06c068cb5da63dfc130d --- 404.html | 2 +- assets/js/9eb89d33.13f715e6.js | 1 - assets/js/9eb89d33.60f2f444.js | 1 + .../{runtime~main.8b52cb0e.js => runtime~main.0a7a9329.js} | 2 +- blog.html | 2 +- blog/archive.html | 2 +- blog/tags.html | 2 +- blog/tags/release.html | 2 +- blog/tags/v-24-00.html | 2 +- blog/tags/v-24-01.html | 2 +- blog/tags/v-24-02.html | 2 +- blog/tags/v-24-10.html | 2 +- blog/tags/v-24-11.html | 2 +- blog/tags/v-24-12.html | 2 +- blog/tags/v-24-20.html | 2 +- blog/tags/webfor-j.html | 2 +- blog/whats-new-24.00.html | 2 +- blog/whats-new-24.01.html | 2 +- blog/whats-new-24.02.html | 2 +- blog/whats-new-24.10.html | 2 +- blog/whats-new-v24.11.html | 2 +- blog/whats-new-v24.12.html | 2 +- blog/whats-new-v24.20.html | 2 +- docs/advanced/browser-console.html | 2 +- docs/advanced/browser-history.html | 2 +- docs/advanced/error-handling.html | 2 +- docs/advanced/interval.html | 2 +- docs/advanced/overview.html | 2 +- docs/advanced/terminate-and-error-actions.html | 2 +- docs/advanced/web-storage.html | 2 +- docs/architecture.html | 2 +- docs/architecture/controls-components.html | 2 +- docs/architecture/overview.html | 2 +- docs/building-ui/basics.html | 2 +- docs/building-ui/composite-components.html | 2 +- docs/building-ui/element.html | 2 +- docs/building-ui/element_composite.html | 2 +- docs/building-ui/events.html | 2 +- docs/building-ui/overview.html | 2 +- docs/building-ui/web-components/event-options.html | 2 +- docs/building-ui/web-components/html-elements.html | 2 +- docs/category/html-and-web-components.html | 2 +- docs/client-components/alert-popover.html | 2 +- docs/client-components/alert.html | 2 +- docs/client-components/app-layout.html | 2 +- docs/client-components/backdrop.html | 2 +- docs/client-components/button.html | 2 +- docs/client-components/checkbox.html | 2 +- docs/client-components/choicebox.html | 2 +- docs/client-components/color-chooser.html | 2 +- docs/client-components/columns-layout.html | 2 +- docs/client-components/combobox.html | 2 +- docs/client-components/datefield-spinner.html | 2 +- docs/client-components/datefield.html | 2 +- docs/client-components/dialog.html | 2 +- docs/client-components/drawer.html | 2 +- docs/client-components/dropdown.html | 2 +- docs/client-components/field-spinner.html | 2 +- docs/client-components/field.html | 2 +- docs/client-components/file-chooser.html | 2 +- docs/client-components/file-save.html | 2 +- docs/client-components/font-chooser.html | 2 +- docs/client-components/hotkey.html | 2 +- docs/client-components/icon-button.html | 2 +- docs/client-components/icon.html | 2 +- docs/client-components/infinite-scroll.html | 2 +- docs/client-components/listbox.html | 2 +- docs/client-components/loading.html | 2 +- docs/client-components/login.html | 2 +- docs/client-components/menu.html | 2 +- docs/client-components/menubar.html | 2 +- docs/client-components/menuitem.html | 2 +- docs/client-components/navigator.html | 2 +- docs/client-components/numberfield-spinner.html | 2 +- docs/client-components/numberfield.html | 2 +- docs/client-components/overview.html | 2 +- docs/client-components/popover.html | 2 +- docs/client-components/popupmenu.html | 2 +- docs/client-components/progressbar.html | 2 +- docs/client-components/radio.html | 2 +- docs/client-components/refresher.html | 2 +- docs/client-components/separator.html | 2 +- docs/client-components/slider.html | 2 +- docs/client-components/spinner.html | 2 +- docs/client-components/splitter.html | 2 +- docs/client-components/tab-panel.html | 2 +- docs/client-components/tab.html | 2 +- docs/client-components/tabbed-pane.html | 2 +- docs/client-components/table.html | 2 +- docs/client-components/terminal.html | 2 +- docs/client-components/textarea.html | 2 +- docs/client-components/textfield-spinner.html | 2 +- docs/client-components/textfield.html | 2 +- docs/client-components/timefield-spinner.html | 2 +- docs/client-components/timefield.html | 2 +- docs/client-components/toast.html | 2 +- docs/client-components/tree-node.html | 2 +- docs/client-components/tree.html | 2 +- docs/client-components/upload.html | 2 +- docs/components/app-layout.html | 2 +- docs/components/busyindicator.html | 2 +- docs/components/button.html | 6 +++--- docs/components/checkbox.html | 2 +- docs/components/columns-layout.html | 2 +- docs/components/dialog.html | 2 +- docs/components/drawer.html | 2 +- docs/components/fields.html | 2 +- docs/components/fields/colorfield.html | 2 +- docs/components/fields/datefield.html | 2 +- docs/components/fields/datetimefield.html | 2 +- docs/components/fields/numberfield.html | 2 +- docs/components/fields/passwordfield.html | 2 +- docs/components/fields/textfield.html | 2 +- docs/components/fields/timefield.html | 2 +- docs/components/flex-layout.html | 2 +- docs/components/google-charts.html | 2 +- docs/components/icon.html | 2 +- docs/components/lists.html | 2 +- docs/components/lists/choicebox.html | 2 +- docs/components/lists/combobox.html | 2 +- docs/components/lists/listbox.html | 2 +- docs/components/loading.html | 2 +- docs/components/login.html | 2 +- docs/components/navigator.html | 2 +- docs/components/option-dialogs.html | 2 +- docs/components/option-dialogs/confirm.html | 2 +- docs/components/option-dialogs/file-chooser.html | 2 +- docs/components/option-dialogs/file-upload.html | 2 +- docs/components/option-dialogs/input.html | 2 +- docs/components/option-dialogs/message.html | 2 +- docs/components/overview.html | 2 +- docs/components/progressbar.html | 2 +- docs/components/radiobutton.html | 2 +- docs/components/radiobuttongroup.html | 2 +- docs/components/slider.html | 2 +- docs/components/spinner.html | 2 +- docs/components/splitter.html | 2 +- docs/components/tabbedpane.html | 2 +- docs/components/table.html | 2 +- docs/components/table/Interactivity.html | 2 +- docs/components/table/columns.html | 2 +- docs/components/table/data.html | 2 +- docs/components/table/filtering.html | 2 +- docs/components/table/refreshing.html | 2 +- docs/components/table/rendering.html | 2 +- docs/components/table/selection.html | 2 +- docs/components/table/sorting.html | 2 +- docs/components/toast.html | 2 +- docs/configuration/bbj-installation/configuration.html | 2 +- docs/configuration/bbj-installation/docker.html | 2 +- docs/configuration/bbj-installation/github-codespaces.html | 2 +- docs/configuration/bbj-installation/local.html | 2 +- docs/configuration/bbj-installation/overview.html | 2 +- docs/configuration/deploy-reload/jrebel.html | 2 +- docs/configuration/deploy-reload/maven-jetty-plugin.html | 2 +- docs/configuration/deploy-reload/overview.html | 2 +- docs/configuration/licensing-and-watermark.html | 2 +- docs/configuration/overview.html | 2 +- docs/configuration/properties.html | 2 +- docs/data-binding/automatic-binding.html | 2 +- docs/data-binding/bindings.html | 2 +- docs/data-binding/overview.html | 2 +- docs/data-binding/transformation.html | 2 +- docs/data-binding/validation/context-results.html | 2 +- docs/data-binding/validation/jakarta-validation.html | 2 +- docs/data-binding/validation/overview.html | 2 +- docs/data-binding/validation/reporters.html | 2 +- docs/data-binding/validation/triggers.html | 2 +- docs/data-binding/validation/validators.html | 2 +- docs/glossary.html | 2 +- docs/introduction/basics.html | 2 +- docs/introduction/getting-started.html | 2 +- docs/introduction/overview.html | 2 +- docs/introduction/prerequisites.html | 2 +- docs/routing/defining-routes.html | 2 +- docs/routing/navigation-lifecycle/navigation-blocking.html | 2 +- docs/routing/navigation-lifecycle/navigation-events.html | 2 +- docs/routing/navigation-lifecycle/observers.html | 2 +- docs/routing/navigation-lifecycle/overview.html | 2 +- docs/routing/navigational-frame-titles.html | 2 +- docs/routing/overview.html | 2 +- docs/routing/query-parameters.html | 2 +- docs/routing/routable-apps.html | 2 +- docs/routing/route-hierarchy/nested-routes.html | 2 +- docs/routing/route-hierarchy/overview.html | 2 +- docs/routing/route-hierarchy/route-outlets.html | 2 +- docs/routing/route-hierarchy/route-types.html | 2 +- docs/routing/route-navigation.html | 2 +- docs/routing/route-patterns.html | 2 +- docs/routing/routes-registration.html | 2 +- docs/routing/state-management.html | 2 +- docs/styling/getting-started.html | 2 +- docs/styling/overview.html | 2 +- docs/styling/themes.html | 2 +- index.html | 2 +- live_demo.html | 2 +- markdown-page.html | 2 +- search.html | 2 +- 198 files changed, 199 insertions(+), 199 deletions(-) delete mode 100644 assets/js/9eb89d33.13f715e6.js create mode 100644 assets/js/9eb89d33.60f2f444.js rename assets/js/{runtime~main.8b52cb0e.js => runtime~main.0a7a9329.js} (99%) diff --git a/404.html b/404.html index 647294da3..99421e819 100644 --- a/404.html +++ b/404.html @@ -16,7 +16,7 @@ - +
diff --git a/assets/js/9eb89d33.13f715e6.js b/assets/js/9eb89d33.13f715e6.js deleted file mode 100644 index 5729e1eee..000000000 --- a/assets/js/9eb89d33.13f715e6.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkdwcj_documentation=self.webpackChunkdwcj_documentation||[]).push([[2870],{39191:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>r,default:()=>h,frontMatter:()=>a,metadata:()=>o,toc:()=>l});const o=JSON.parse('{"id":"components/button","title":"Button","description":"A Button component is a fundamental user interface element used in application development to create interactive elements that trigger actions or events when clicked or activated. It serves as a clickable element that users can interact with to perform various actions within an application or website.","source":"@site/docs/components/button.md","sourceDirName":"components","slug":"/components/button","permalink":"/docs/components/button","draft":false,"unlisted":false,"editUrl":"https://github.com/webforj/webforj-docs/tree/website/docs/components/button.md","tags":[],"version":"current","frontMatter":{"title":"Button"},"sidebar":"documentationSidebar","previous":{"title":"BusyIndicator","permalink":"/docs/components/busyindicator"},"next":{"title":"CheckBox","permalink":"/docs/components/checkbox"}}');var s=t(74848),i=t(28453);const a={title:"Button"},r=void 0,c={},l=[{value:"Usages",id:"usages",level:2},{value:"Adding icons to buttons",id:"adding-icons-to-buttons",level:2},{value:"Names",id:"names",level:3},{value:"Disabling a button",id:"disabling-a-button",level:2},{value:"Styling",id:"styling",level:2},{value:"Themes",id:"themes",level:3},{value:"Expanses",id:"expanses",level:3},{value:"Shadow parts",id:"shadow-parts",level:3},{value:"Slots",id:"slots",level:3},{value:"CSS properties",id:"css-properties",level:3},{value:"Reflected attributes",id:"reflected-attributes",level:3},{value:"Dependencies",id:"dependencies",level:3},{value:"Best practices",id:"best-practices",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components},{ComponentDemo:o,DocChip:a,JavadocLink:r,TableBuilder:c}=n;return o||u("ComponentDemo",!0),a||u("DocChip",!0),r||u("JavadocLink",!0),c||u("TableBuilder",!0),(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(a,{chip:"shadow"}),"\n",(0,s.jsx)(a,{chip:"name",label:"dwc-button"}),"\n",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/button/Button",top:"true"}),"\n",(0,s.jsxs)(n.p,{children:["A ",(0,s.jsx)(n.code,{children:"Button"})," component is a fundamental user interface element used in application development to create interactive elements that trigger actions or events when clicked or activated. It serves as a clickable element that users can interact with to perform various actions within an application or website."]}),"\n",(0,s.jsxs)(n.p,{children:["The primary purpose of the ",(0,s.jsx)(n.code,{children:"Button"})," component is to provide a clear and intuitive call-to-action for users, guiding them to perform specific tasks such as submitting a form, navigating to another page, triggering a function, or initiating a process. Buttons are essential for enhancing user interactions, improving accessibility, and creating a more engaging user experience."]}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttondemo?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonDemoView.java",cssURL:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/resources/css/button/buttonDemo.css",height:"300px"}),"\n",(0,s.jsx)(n.h2,{id:"usages",children:"Usages"}),"\n",(0,s.jsxs)(n.p,{children:["The ",(0,s.jsx)(n.code,{children:"Button"})," class is a versatile component that is commonly used in various situations where user interactions and actions need to be triggered. Here are some typical scenarios where you might need a button in your application:"]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Form Submission"}),": Buttons are often used to submit form data. For example, in an application, you can use:"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:'A "Submit" button to send data to the server'}),"\n",(0,s.jsx)(n.li,{children:'A "Clear" button to remove any information already present in the form'}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"2",children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"User Actions"}),": Buttons are used to allow users to perform specific actions within the application. For instance, you can have a button labeled:"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:'"Delete" to initiate the deletion of a selected item'}),"\n",(0,s.jsx)(n.li,{children:'"Save" to save changes made to a document or page.'}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"3",children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Confirmation Dialogs"}),": Buttons are often included in ",(0,s.jsx)(n.a,{href:"../components/dialog",children:(0,s.jsx)(n.code,{children:"Dialog"})})," components built for various purposes to provide options for users to confirm or cancel an action, or any other functionality that is built into the ",(0,s.jsx)(n.a,{href:"../components/dialog",children:(0,s.jsx)(n.code,{children:"Dialog"})})," you're using."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Interaction Triggers"}),": Buttons can serve as triggers for interactions or events within the application. By clicking a button, users can initiate complex actions or trigger animations, refreshing content, or updating the display."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Navigation"}),": Buttons can be used for navigation purposes, such as moving between different sections or pages within an application. Buttons for navigation could include:"]}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:'"Next" - Takes the user to the next page or section of the current application or page.'}),"\n",(0,s.jsx)(n.li,{children:'"Previous" - Returns the user to the previous page of the application or section they\'re in.'}),"\n",(0,s.jsx)(n.li,{children:'"Back" Returns the user to the first part of the application or page they\'re in.'}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"adding-icons-to-buttons",children:"Adding icons to buttons"}),"\n",(0,s.jsxs)(n.p,{children:["Incorporating an icon into a button can greatly improve your app's design, allowing users to quickly identify actionable items on the screen. The ",(0,s.jsx)(n.a,{href:"/docs/components/icon",children:(0,s.jsx)(n.code,{children:"Icon"})})," component provides a wide selection of icons to choose from."]}),"\n",(0,s.jsxs)(n.p,{children:["By utilizing the ",(0,s.jsx)(n.code,{children:"setPrefixComponent()"})," and ",(0,s.jsx)(n.code,{children:"setSuffixComponent()"})," methods, you have the flexibility to determine whether an ",(0,s.jsx)(n.code,{children:"Icon"})," should appear before or after the text on a button. Alternatively, the ",(0,s.jsx)(n.code,{children:"setIcon()"})," method can be used to add an ",(0,s.jsx)(n.code,{children:"Icon"})," after the text, but before the button's ",(0,s.jsx)(n.code,{children:"suffix"})," slot."]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsxs)(n.p,{children:["By default, an ",(0,s.jsx)(n.code,{children:"Icon"})," inherits the button's theme and expanse."]})}),"\n",(0,s.jsx)(n.p,{children:"Below are examples of buttons with text to the left and right, as well as a button with only an icon:"}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttonicon?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonIconView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Icon.txt",height:"200px"}),"\n",(0,s.jsx)(n.h3,{id:"names",children:"Names"}),"\n",(0,s.jsxs)(n.p,{children:["The ",(0,s.jsx)(n.code,{children:"Button"})," component utilizes naming, which is used for accessibility. When a name is not explicitly set, the label of the ",(0,s.jsx)(n.code,{children:"Button"})," will be used instead. However, some icons do not have labels, and only display non-text elements, such as icons. In this case, it is expedient to use the ",(0,s.jsx)(n.code,{children:"setName()"})," method to ensure that the ",(0,s.jsx)(n.code,{children:"Button"})," component created complies with accessibility standards."]}),"\n",(0,s.jsx)(n.h2,{id:"disabling-a-button",children:"Disabling a button"}),"\n",(0,s.jsx)(n.p,{children:"Button components, like many others, can be disabled to convey to a user that a certain action is not yet or is no longer available. A disabled button will decrease the opacity of the button, and is available for all button themes and expanses."}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttondisable?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonDisableView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Disable.txt"}),"\n",(0,s.jsx)("br",{}),"\n",(0,s.jsxs)(n.p,{children:["Disabling a button can be done at any time in the code by using the ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/HasEnable",code:"true",children:"setEnabled(boolean enabled)"})," function. For added convenience, a button can also be disabled when clicked using the built-in ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/button/Button",code:"true",suffix:"#setDisableOnClick(java.lang.Boolean)",children:"setDisabledOnClick(boolean enabled)"})," function."]}),"\n",(0,s.jsx)(n.p,{children:"In some applications, clicking a button triggers a long-running action. In most cases, the application might want to ensure that only a single click is processed. This can be an issue in high-latency environments when the user clicks the button multiple times before the application has had a chance to start processing the resulting action."}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsx)(n.p,{children:"Disabling on click not only helps optimize the processing of actions, but also prevents the developer from needing to implement this behavior on their own, as this method has been optimized to reduce round trip communications."})}),"\n",(0,s.jsx)(n.h2,{id:"styling",children:"Styling"}),"\n",(0,s.jsx)(n.h3,{id:"themes",children:"Themes"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.code,{children:"Button"})," components come with ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/button/ButtonTheme",children:"14 discrete themes "})," built in for quick styling without the use of CSS. These themes are pre-defined styles that can be applied to buttons to change their appearance and visual presentation. They offer a quick and consistent way to customize the look of buttons throughout an application."]}),"\n",(0,s.jsx)(n.p,{children:"While there are many use cases for each of the various themes, some examples uses are:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Danger"}),": Best for actions with severe consequences, such as clearing filled-out information or permanently deleting an account/data."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Default"}),": Appropriate for actions throughout an application that don't require special attention and are generic, such as toggling a setting."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Primary"}),': Appropriate as a main "call-to-action" on a page, such as signing up, saving changes, or continuing to another page.']}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Success"}),": Excellent for visualizing successful completion of an element in an application, such as the submission of a form or completion of a sign-up process. The success theme can by programmatically applied once a successful action has been completed."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Warning"}),": Useful to indicate that a user is about to perform a potentially risky action, such as navigating away from a page with unsaved changes. These actions are often less impactful than those that would use the Danger theme."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Gray"}),": Good for subtle actions, such as minor settings or actions that are more supplementary to a page, and not part of the main functionality."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Info"}),": Good for providing additional clarifying information to a user."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["Shown below are example buttons with each of the supported Themes applied: ",(0,s.jsx)("br",{})]}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttonthemes?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonThemesView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Theme.txt",cssURL:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/resources/button/buttonThemes.css",height:"175px"}),"\n",(0,s.jsx)(n.h3,{id:"expanses",children:"Expanses"}),"\n",(0,s.jsxs)(n.p,{children:["The following ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/Expanse",children:" Expanses values "})," allow for quick styling without using CSS. This allows for manipulation of the Button's dimensions without having to explicitly set it using any styling. In addition to simplifying styling, it also helps create and maintain a uniformity in your application. The default ",(0,s.jsx)(n.code,{children:"Button"})," expanse is ",(0,s.jsx)(n.code,{children:"Expanse.MEDIUM"}),"."]}),"\n",(0,s.jsx)(n.p,{children:"Different sizes are often appropriate for different uses:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Larger"})," expanse values are suited to buttons which should grab attention, emphasize functionality or are integral to the core functionality of an application or page."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Medium"}),' expanse buttons, the default size, should be utilized as a "standard size", when a button\'s behavior is no more or less important than other similar components.']}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Smaller"})," expanse values should be used for buttons that do not have integral behaviors in the application, and serve a more supplementary or utilitarian role, rather than play an important part in user interaction. This includes ",(0,s.jsx)(n.code,{children:"Button"})," components being used only with icons for utilitarian purposes."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["Below are the various expanses supported for the ",(0,s.jsx)(n.code,{children:"Button"})," component: ",(0,s.jsx)("br",{})]}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttonexpanses?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonExpansesView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Expanses.txt",cssURL:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/resources/css/button/buttonExpanses.css",height:"200px"}),"\n",(0,s.jsx)(n.h3,{id:"shadow-parts",children:"Shadow parts"}),"\n",(0,s.jsxs)(n.p,{children:["These are the various parts of the ",(0,s.jsx)(n.a,{href:"../glossary#shadow-dom",children:"shadow DOM"})," for the component, which will be required when styling via CSS is desired."]}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,table:"parts",exclusions:t(71084).x.rT}),"\n",(0,s.jsx)(n.h3,{id:"slots",children:"Slots"}),"\n",(0,s.jsxs)(n.p,{children:["Listed below are the slots available for utilization within the ",(0,s.jsx)(n.code,{children:"Button"})," component. These slots act as placeholders within the component that control where the children of a customized element should be inserted within the shadow tree."]}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,table:"slots",exclusions:t(71084).x.Q0}),"\n",(0,s.jsx)(n.h3,{id:"css-properties",children:"CSS properties"}),"\n",(0,s.jsx)(n.p,{children:"These are the various CSS properties that are used in the component, with a short description of their use."}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,exclusions:t(71084).x.qo,table:"properties"}),"\n",(0,s.jsx)(n.h3,{id:"reflected-attributes",children:"Reflected attributes"}),"\n",(0,s.jsx)(n.p,{children:"The reflected attributes of a component will be shown as attributes in the rendered HTML element for the component in the DOM. This means that styling can be applied using these attributes."}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,table:"reflects",exclusions:t(71084).x.Vt}),"\n",(0,s.jsx)(n.h3,{id:"dependencies",children:"Dependencies"}),"\n",(0,s.jsx)(n.p,{children:"This component relies on the following components - see the related article for more detailed styling information:"}),"\n",(0,s.jsx)(c,{tag:"dwc-button",table:"dependencies"}),"\n",(0,s.jsx)(n.h2,{id:"best-practices",children:"Best practices"}),"\n",(0,s.jsxs)(n.p,{children:["To ensure an optimal user experience when using the ",(0,s.jsx)(n.code,{children:"Button"})," component, consider the following best practices:"]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Proper Text"}),": Use clear and concise text for text within your ",(0,s.jsx)(n.code,{children:"Button"})," component to provide a clear indication of its purpose."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Appropriate Visual Styling"}),": Consider the visual styling and theme of the ",(0,s.jsx)(n.code,{children:"Button"})," to ensure consistency with your application's design. For example:"]}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:['A "Cancel" ',(0,s.jsx)(n.code,{children:"Button"})," component should be styled with the appropriate theme or CSS styling to ensure users are sure they want to cancel an action"]}),"\n",(0,s.jsxs)(n.li,{children:['A "Confirm" ',(0,s.jsx)(n.code,{children:"Button"}),' would have a different styling from a "Cancel" button, but would similarly stand out to ensure that users know this is a special action.']}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"3",children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Efficient Event Handling"}),": Handle ",(0,s.jsx)(n.code,{children:"Button"})," events efficiently and provide appropriate feedback to users. Refer to ",(0,s.jsx)(n.a,{href:"./button/#adding-events",children:(0,s.jsx)(n.strong,{children:"this section"})})," to review efficient event adding behaviors."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Testing and Accessibility"}),": Test the Button's behavior in different scenarios, such as when it is disabled or receives focus, to ensure a smooth user experience.\r\nFollow accessibility guidelines to make the ",(0,s.jsx)(n.code,{children:"Button"})," usable for all users, including those who rely on assistive technologies."]}),"\n"]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}function u(e,n){throw new Error("Expected "+(n?"component":"object")+" `"+e+"` to be defined: you likely forgot to import, pass, or provide it.")}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>r});var o=t(96540);const s={},i=o.createContext(s);function a(e){const n=o.useContext(i);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),o.createElement(i.Provider,{value:n},e.children)}},57813:e=>{e.exports=JSON.parse('{"e7":"dwc-app-layout","$n":"dwc-button","Sc":"dwc-checkbox","D0":"dwc-field","Ap":"dwc-slider","qF":"dwc-listbox","tX":"dwc-choicebox","a3":"dwc-combobox","mD":"dwc-navigator","z2":"dwc-progressbar","a":"dwc-radio","TN":"dwc-tabbed-pane","_s":"dwc-drawer","lG":"dwc-dialog","In":"dwc-icon","O3":"dwc-splitter","az":"dwc-login","y$":"dwc-spinner","Rh":"dwc-loading","bJ":"dwc-loading","y8":"dwc-toast"}')},71084:e=>{e.exports=JSON.parse('{"x":{"rT":["dropdown","dropdown-icon","dropdown-separator"],"Q0":[],"qo":["--dwc-button-selected-background","--dwc-button-selected-color","--dwc-button-separator-color"],"Vt":["toggleable","selected"]},"U":{"V":["theme"]}}')}}]); \ No newline at end of file diff --git a/assets/js/9eb89d33.60f2f444.js b/assets/js/9eb89d33.60f2f444.js new file mode 100644 index 000000000..161840569 --- /dev/null +++ b/assets/js/9eb89d33.60f2f444.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkdwcj_documentation=self.webpackChunkdwcj_documentation||[]).push([[2870],{39191:(e,n,t)=>{t.r(n),t.d(n,{assets:()=>c,contentTitle:()=>r,default:()=>h,frontMatter:()=>a,metadata:()=>o,toc:()=>l});const o=JSON.parse('{"id":"components/button","title":"Button","description":"A Button component is a fundamental user interface element used in application development to create interactive elements that trigger actions or events when clicked or activated. It serves as a clickable element that users can interact with to perform various actions within an application or website.","source":"@site/docs/components/button.md","sourceDirName":"components","slug":"/components/button","permalink":"/docs/components/button","draft":false,"unlisted":false,"editUrl":"https://github.com/webforj/webforj-docs/tree/website/docs/components/button.md","tags":[],"version":"current","frontMatter":{"title":"Button"},"sidebar":"documentationSidebar","previous":{"title":"BusyIndicator","permalink":"/docs/components/busyindicator"},"next":{"title":"CheckBox","permalink":"/docs/components/checkbox"}}');var s=t(74848),i=t(28453);const a={title:"Button"},r=void 0,c={},l=[{value:"Usages",id:"usages",level:2},{value:"Adding icons to buttons",id:"adding-icons-to-buttons",level:2},{value:"Names",id:"names",level:3},{value:"Disabling a button",id:"disabling-a-button",level:2},{value:"Styling",id:"styling",level:2},{value:"Themes",id:"themes",level:3},{value:"Expanses",id:"expanses",level:3},{value:"Shadow parts",id:"shadow-parts",level:3},{value:"Slots",id:"slots",level:3},{value:"CSS properties",id:"css-properties",level:3},{value:"Reflected attributes",id:"reflected-attributes",level:3},{value:"Dependencies",id:"dependencies",level:3},{value:"Best practices",id:"best-practices",level:2}];function d(e){const n={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",h2:"h2",h3:"h3",li:"li",ol:"ol",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components},{ComponentDemo:o,DocChip:a,JavadocLink:r,TableBuilder:c}=n;return o||p("ComponentDemo",!0),a||p("DocChip",!0),r||p("JavadocLink",!0),c||p("TableBuilder",!0),(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(a,{chip:"shadow"}),"\n",(0,s.jsx)(a,{chip:"name",label:"dwc-button"}),"\n",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/button/Button",top:"true"}),"\n",(0,s.jsxs)(n.p,{children:["A ",(0,s.jsx)(n.code,{children:"Button"})," component is a fundamental user interface element used in application development to create interactive elements that trigger actions or events when clicked or activated. It serves as a clickable element that users can interact with to perform various actions within an application or website."]}),"\n",(0,s.jsxs)(n.p,{children:["The primary purpose of the ",(0,s.jsx)(n.code,{children:"Button"})," component is to provide a clear and intuitive call-to-action for users, guiding them to perform specific tasks such as submitting a form, navigating to another page, triggering a function, or initiating a process. Buttons are essential for enhancing user interactions, improving accessibility, and creating a more engaging user experience."]}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/button?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonView.java",height:"300px"}),"\n",(0,s.jsx)(n.h2,{id:"usages",children:"Usages"}),"\n",(0,s.jsxs)(n.p,{children:["The ",(0,s.jsx)(n.code,{children:"Button"})," class is a versatile component that is commonly used in various situations where user interactions and actions need to be triggered. Here are some typical scenarios where you might need a button in your application:"]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Form Submission"}),": Buttons are often used to submit form data. For example, in an application, you can use:"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:'A "Submit" button to send data to the server'}),"\n",(0,s.jsx)(n.li,{children:'A "Clear" button to remove any information already present in the form'}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"2",children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"User Actions"}),": Buttons are used to allow users to perform specific actions within the application. For instance, you can have a button labeled:"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:'"Delete" to initiate the deletion of a selected item'}),"\n",(0,s.jsx)(n.li,{children:'"Save" to save changes made to a document or page.'}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"3",children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Confirmation Dialogs"}),": Buttons are often included in ",(0,s.jsx)(n.a,{href:"../components/dialog",children:(0,s.jsx)(n.code,{children:"Dialog"})})," components built for various purposes to provide options for users to confirm or cancel an action, or any other functionality that is built into the ",(0,s.jsx)(n.a,{href:"../components/dialog",children:(0,s.jsx)(n.code,{children:"Dialog"})})," you're using."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Interaction Triggers"}),": Buttons can serve as triggers for interactions or events within the application. By clicking a button, users can initiate complex actions or trigger animations, refreshing content, or updating the display."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Navigation"}),": Buttons can be used for navigation purposes, such as moving between different sections or pages within an application. Buttons for navigation could include:"]}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsx)(n.li,{children:'"Next" - Takes the user to the next page or section of the current application or page.'}),"\n",(0,s.jsx)(n.li,{children:'"Previous" - Returns the user to the previous page of the application or section they\'re in.'}),"\n",(0,s.jsx)(n.li,{children:'"Back" Returns the user to the first part of the application or page they\'re in.'}),"\n"]}),"\n"]}),"\n",(0,s.jsx)(n.h2,{id:"adding-icons-to-buttons",children:"Adding icons to buttons"}),"\n",(0,s.jsxs)(n.p,{children:["Incorporating an icon into a button can greatly improve your app's design, allowing users to quickly identify actionable items on the screen. The ",(0,s.jsx)(n.a,{href:"/docs/components/icon",children:(0,s.jsx)(n.code,{children:"Icon"})})," component provides a wide selection of icons to choose from."]}),"\n",(0,s.jsxs)(n.p,{children:["By utilizing the ",(0,s.jsx)(n.code,{children:"setPrefixComponent()"})," and ",(0,s.jsx)(n.code,{children:"setSuffixComponent()"})," methods, you have the flexibility to determine whether an ",(0,s.jsx)(n.code,{children:"Icon"})," should appear before or after the text on a button. Alternatively, the ",(0,s.jsx)(n.code,{children:"setIcon()"})," method can be used to add an ",(0,s.jsx)(n.code,{children:"Icon"})," after the text, but before the button's ",(0,s.jsx)(n.code,{children:"suffix"})," slot."]}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsxs)(n.p,{children:["By default, an ",(0,s.jsx)(n.code,{children:"Icon"})," inherits the button's theme and expanse."]})}),"\n",(0,s.jsx)(n.p,{children:"Below are examples of buttons with text to the left and right, as well as a button with only an icon:"}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttonicon?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonIconView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Icon.txt",height:"200px"}),"\n",(0,s.jsx)(n.h3,{id:"names",children:"Names"}),"\n",(0,s.jsxs)(n.p,{children:["The ",(0,s.jsx)(n.code,{children:"Button"})," component utilizes naming, which is used for accessibility. When a name is not explicitly set, the label of the ",(0,s.jsx)(n.code,{children:"Button"})," will be used instead. However, some icons do not have labels, and only display non-text elements, such as icons. In this case, it is expedient to use the ",(0,s.jsx)(n.code,{children:"setName()"})," method to ensure that the ",(0,s.jsx)(n.code,{children:"Button"})," component created complies with accessibility standards."]}),"\n",(0,s.jsx)(n.h2,{id:"disabling-a-button",children:"Disabling a button"}),"\n",(0,s.jsx)(n.p,{children:"Button components, like many others, can be disabled to convey to a user that a certain action is not yet or is no longer available. A disabled button will decrease the opacity of the button, and is available for all button themes and expanses."}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttondisable?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonDisableView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Disable.txt"}),"\n",(0,s.jsx)("br",{}),"\n",(0,s.jsxs)(n.p,{children:["Disabling a button can be done at any time in the code by using the ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/HasEnable",code:"true",children:"setEnabled(boolean enabled)"})," function. For added convenience, a button can also be disabled when clicked using the built-in ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/button/Button",code:"true",suffix:"#setDisableOnClick(java.lang.Boolean)",children:"setDisabledOnClick(boolean enabled)"})," function."]}),"\n",(0,s.jsx)(n.p,{children:"In some applications, clicking a button triggers a long-running action. In most cases, the application might want to ensure that only a single click is processed. This can be an issue in high-latency environments when the user clicks the button multiple times before the application has had a chance to start processing the resulting action."}),"\n",(0,s.jsx)(n.admonition,{type:"tip",children:(0,s.jsx)(n.p,{children:"Disabling on click not only helps optimize the processing of actions, but also prevents the developer from needing to implement this behavior on their own, as this method has been optimized to reduce round trip communications."})}),"\n",(0,s.jsx)(n.h2,{id:"styling",children:"Styling"}),"\n",(0,s.jsx)(n.h3,{id:"themes",children:"Themes"}),"\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.code,{children:"Button"})," components come with ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/button/ButtonTheme",children:"14 discrete themes "})," built in for quick styling without the use of CSS. These themes are pre-defined styles that can be applied to buttons to change their appearance and visual presentation. They offer a quick and consistent way to customize the look of buttons throughout an application."]}),"\n",(0,s.jsx)(n.p,{children:"While there are many use cases for each of the various themes, some examples uses are:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Danger"}),": Best for actions with severe consequences, such as clearing filled-out information or permanently deleting an account/data."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Default"}),": Appropriate for actions throughout an application that don't require special attention and are generic, such as toggling a setting."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Primary"}),': Appropriate as a main "call-to-action" on a page, such as signing up, saving changes, or continuing to another page.']}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Success"}),": Excellent for visualizing successful completion of an element in an application, such as the submission of a form or completion of a sign-up process. The success theme can by programmatically applied once a successful action has been completed."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Warning"}),": Useful to indicate that a user is about to perform a potentially risky action, such as navigating away from a page with unsaved changes. These actions are often less impactful than those that would use the Danger theme."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Gray"}),": Good for subtle actions, such as minor settings or actions that are more supplementary to a page, and not part of the main functionality."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Info"}),": Good for providing additional clarifying information to a user."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["Shown below are example buttons with each of the supported Themes applied: ",(0,s.jsx)("br",{})]}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttonthemes?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonThemesView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Theme.txt",cssURL:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/resources/button/buttonThemes.css",height:"175px"}),"\n",(0,s.jsx)(n.h3,{id:"expanses",children:"Expanses"}),"\n",(0,s.jsxs)(n.p,{children:["The following ",(0,s.jsx)(r,{type:"foundation",location:"com/webforj/component/Expanse",children:" Expanses values "})," allow for quick styling without using CSS. This allows for manipulation of the Button's dimensions without having to explicitly set it using any styling. In addition to simplifying styling, it also helps create and maintain a uniformity in your application. The default ",(0,s.jsx)(n.code,{children:"Button"})," expanse is ",(0,s.jsx)(n.code,{children:"Expanse.MEDIUM"}),"."]}),"\n",(0,s.jsx)(n.p,{children:"Different sizes are often appropriate for different uses:"}),"\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Larger"})," expanse values are suited to buttons which should grab attention, emphasize functionality or are integral to the core functionality of an application or page."]}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Medium"}),' expanse buttons, the default size, should be utilized as a "standard size", when a button\'s behavior is no more or less important than other similar components.']}),"\n",(0,s.jsxs)(n.li,{children:[(0,s.jsx)(n.strong,{children:"Smaller"})," expanse values should be used for buttons that do not have integral behaviors in the application, and serve a more supplementary or utilitarian role, rather than play an important part in user interaction. This includes ",(0,s.jsx)(n.code,{children:"Button"})," components being used only with icons for utilitarian purposes."]}),"\n"]}),"\n",(0,s.jsxs)(n.p,{children:["Below are the various expanses supported for the ",(0,s.jsx)(n.code,{children:"Button"})," component: ",(0,s.jsx)("br",{})]}),"\n",(0,s.jsx)(o,{path:"https://demo.webforj.com/webapp/controlsamples/buttonexpanses?",javaE:"https://raw.githubusercontent.com/webforj/webforj-docs-samples/refs/heads/main/src/main/java/com/webforj/samples/views/button/ButtonExpansesView.java",javaC:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/code_snippets/button/Expanses.txt",cssURL:"https://raw.githubusercontent.com/webforj/ControlSamples/main/src/main/resources/css/button/buttonExpanses.css",height:"200px"}),"\n",(0,s.jsx)(n.h3,{id:"shadow-parts",children:"Shadow parts"}),"\n",(0,s.jsxs)(n.p,{children:["These are the various parts of the ",(0,s.jsx)(n.a,{href:"../glossary#shadow-dom",children:"shadow DOM"})," for the component, which will be required when styling via CSS is desired."]}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,table:"parts",exclusions:t(71084).x.rT}),"\n",(0,s.jsx)(n.h3,{id:"slots",children:"Slots"}),"\n",(0,s.jsxs)(n.p,{children:["Listed below are the slots available for utilization within the ",(0,s.jsx)(n.code,{children:"Button"})," component. These slots act as placeholders within the component that control where the children of a customized element should be inserted within the shadow tree."]}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,table:"slots",exclusions:t(71084).x.Q0}),"\n",(0,s.jsx)(n.h3,{id:"css-properties",children:"CSS properties"}),"\n",(0,s.jsx)(n.p,{children:"These are the various CSS properties that are used in the component, with a short description of their use."}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,exclusions:t(71084).x.qo,table:"properties"}),"\n",(0,s.jsx)(n.h3,{id:"reflected-attributes",children:"Reflected attributes"}),"\n",(0,s.jsx)(n.p,{children:"The reflected attributes of a component will be shown as attributes in the rendered HTML element for the component in the DOM. This means that styling can be applied using these attributes."}),"\n",(0,s.jsx)(c,{tag:t(57813).$n,table:"reflects",exclusions:t(71084).x.Vt}),"\n",(0,s.jsx)(n.h3,{id:"dependencies",children:"Dependencies"}),"\n",(0,s.jsx)(n.p,{children:"This component relies on the following components - see the related article for more detailed styling information:"}),"\n",(0,s.jsx)(c,{tag:"dwc-button",table:"dependencies"}),"\n",(0,s.jsx)(n.h2,{id:"best-practices",children:"Best practices"}),"\n",(0,s.jsxs)(n.p,{children:["To ensure an optimal user experience when using the ",(0,s.jsx)(n.code,{children:"Button"})," component, consider the following best practices:"]}),"\n",(0,s.jsxs)(n.ol,{children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Proper Text"}),": Use clear and concise text for text within your ",(0,s.jsx)(n.code,{children:"Button"})," component to provide a clear indication of its purpose."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Appropriate Visual Styling"}),": Consider the visual styling and theme of the ",(0,s.jsx)(n.code,{children:"Button"})," to ensure consistency with your application's design. For example:"]}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.blockquote,{children:["\n",(0,s.jsxs)(n.ul,{children:["\n",(0,s.jsxs)(n.li,{children:['A "Cancel" ',(0,s.jsx)(n.code,{children:"Button"})," component should be styled with the appropriate theme or CSS styling to ensure users are sure they want to cancel an action"]}),"\n",(0,s.jsxs)(n.li,{children:['A "Confirm" ',(0,s.jsx)(n.code,{children:"Button"}),' would have a different styling from a "Cancel" button, but would similarly stand out to ensure that users know this is a special action.']}),"\n"]}),"\n"]}),"\n",(0,s.jsxs)(n.ol,{start:"3",children:["\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Efficient Event Handling"}),": Handle ",(0,s.jsx)(n.code,{children:"Button"})," events efficiently and provide appropriate feedback to users. Refer to ",(0,s.jsx)(n.a,{href:"./button/#adding-events",children:(0,s.jsx)(n.strong,{children:"this section"})})," to review efficient event adding behaviors."]}),"\n"]}),"\n",(0,s.jsxs)(n.li,{children:["\n",(0,s.jsxs)(n.p,{children:[(0,s.jsx)(n.strong,{children:"Testing and Accessibility"}),": Test the Button's behavior in different scenarios, such as when it is disabled or receives focus, to ensure a smooth user experience.\nFollow accessibility guidelines to make the ",(0,s.jsx)(n.code,{children:"Button"})," usable for all users, including those who rely on assistive technologies."]}),"\n"]}),"\n"]})]})}function h(e={}){const{wrapper:n}={...(0,i.R)(),...e.components};return n?(0,s.jsx)(n,{...e,children:(0,s.jsx)(d,{...e})}):d(e)}function p(e,n){throw new Error("Expected "+(n?"component":"object")+" `"+e+"` to be defined: you likely forgot to import, pass, or provide it.")}},28453:(e,n,t)=>{t.d(n,{R:()=>a,x:()=>r});var o=t(96540);const s={},i=o.createContext(s);function a(e){const n=o.useContext(i);return o.useMemo((function(){return"function"==typeof e?e(n):{...n,...e}}),[n,e])}function r(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(s):e.components||s:a(e.components),o.createElement(i.Provider,{value:n},e.children)}},57813:e=>{e.exports=JSON.parse('{"e7":"dwc-app-layout","$n":"dwc-button","Sc":"dwc-checkbox","D0":"dwc-field","Ap":"dwc-slider","qF":"dwc-listbox","tX":"dwc-choicebox","a3":"dwc-combobox","mD":"dwc-navigator","z2":"dwc-progressbar","a":"dwc-radio","TN":"dwc-tabbed-pane","_s":"dwc-drawer","lG":"dwc-dialog","In":"dwc-icon","O3":"dwc-splitter","az":"dwc-login","y$":"dwc-spinner","Rh":"dwc-loading","bJ":"dwc-loading","y8":"dwc-toast"}')},71084:e=>{e.exports=JSON.parse('{"x":{"rT":["dropdown","dropdown-icon","dropdown-separator"],"Q0":[],"qo":["--dwc-button-selected-background","--dwc-button-selected-color","--dwc-button-separator-color"],"Vt":["toggleable","selected"]},"U":{"V":["theme"]}}')}}]); \ No newline at end of file diff --git a/assets/js/runtime~main.8b52cb0e.js b/assets/js/runtime~main.0a7a9329.js similarity index 99% rename from assets/js/runtime~main.8b52cb0e.js rename to assets/js/runtime~main.0a7a9329.js index 4208e158e..32dd0cbda 100644 --- a/assets/js/runtime~main.8b52cb0e.js +++ b/assets/js/runtime~main.0a7a9329.js @@ -1 +1 @@ -(()=>{"use strict";var e,a,c,b,d,f={},t={};function r(e){var a=t[e];if(void 0!==a)return a.exports;var c=t[e]={exports:{}};return f[e].call(c.exports,c,c.exports,r),c.exports}r.m=f,e=[],r.O=(a,c,b,d)=>{if(!c){var f=1/0;for(i=0;iA Button
component is a fundamental user interface element used in application development to create interactive elements that trigger actions or events when clicked or activated. It serves as a clickable element that users can interact with to perform various actions within an application or website.
The primary purpose of the Button
component is to provide a clear and intuitive call-to-action for users, guiding them to perform specific tasks such as submitting a form, navigating to another page, triggering a function, or initiating a process. Buttons are essential for enhancing user interactions, improving accessibility, and creating a more engaging user experience.
The Button
class is a versatile component that is commonly used in various situations where user interactions and actions need to be triggered. Here are some typical scenarios where you might need a button in your application:
Efficient Event Handling: Handle Button
events efficiently and provide appropriate feedback to users. Refer to this section to review efficient event adding behaviors.
Testing and Accessibility: Test the Button's behavior in different scenarios, such as when it is disabled or receives focus, to ensure a smooth user experience. +
Testing and Accessibility: Test the Button's behavior in different scenarios, such as when it is disabled or receives focus, to ensure a smooth user experience.
Follow accessibility guidelines to make the Button
usable for all users, including those who rely on assistive technologies.