Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@justeattakeaway/pie-button
Advanced tools
PIE design system button built using web components
pie-button
is a Web Component built using the Lit library. It offers a simple and accessible button component for web applications.
This component can be easily integrated into various frontend frameworks and customized through a set of properties.
To install pie-button
in your application, run the following on your command line:
# npm
$ npm i @justeattakeaway/pie-button
# yarn
$ yarn add @justeattakeaway/pie-button
For full information on using PIE components as part of an application, check out the Getting Started Guide.
// Default – for Native JS Applications, Vue, Angular, Svelte, etc.
import { PieButton } from '@justeattakeaway/pie-button';
// If you don't need to reference the imported object, you can simply
// import the module which registers the component as a custom element.
import '@justeattakeaway/pie-button';
// React
// For React, you will need to import our React-specific component build
// which wraps the web component using @lit/react
import { PieButton } from '@justeattakeaway/pie-button/dist/react';
[!NOTE] When using the React version of the component, please make sure to also include React as a peer dependency in your project.
[!IMPORTANT] When using
pie-button
, you will also need to include a couple of dependencies to ensure the component renders as expected. See the PIE Wiki for more information and how to include these in your application.
Property | Type | Default | Description |
---|---|---|---|
size | String | medium | Size of the button, one of sizes – xsmall , small-expressive , small-productive , medium , large |
type | String | submit | Type of the button, one of types – submit , button , reset . Read further on MDN |
variant | String | primary | Variant of the button, one of variants – primary , secondary , outline , ghost , destructive , destructive-ghost , inverse , ghost-inverse , outline-inverse |
disabled | Boolean | false | If true , disables the button. |
isFullWidth | Boolean | false | If true , sets the button width to 100% of its container. |
isLoading | Boolean | false | If true , displays a loading indicator inside the button. |
isResponsive | Boolean | false | If true , uses the next larger size on wide viewports. |
iconPlacement | String | leading | Icon placements of the icon slot, if provided, one of iconPlacements - leading , trailing |
name | String | undefined | The name of the button, to be submitted with form data. Read further on MDN |
value | String | undefined | The value of the button, to be submitted with form data. Read further on MDN |
formaction | String | undefined | Designates an alternative URL for form data submission. Read further on MDN |
formenctype | String | undefined | Specifies the form data encoding type. Read further on MDN |
formmethod | String | undefined | Sets the HTTP method for form data. Read further on MDN |
formnovalidate | Boolean | undefined | Ensures the form is submitted without native HTML validation. Read further on MDN |
formtarget | String | undefined | Dictates where to display the response after form submission. Read further on MDN |
responsiveSize | String | productive | Sets a specific size for xsmall button when rendered as responsive. It can be productive or expressive . |
In your markup or JSX, you can then use these to set the properties for the pie-button
component:
<!-- Native HTML -->
<pie-button size='medium' type='button' variant='primary'>Click me!</pie-button>
<!-- JSX -->
<PieButton size='medium' type='button' variant='primary'>Click me!</PieButton>
Slot | Description |
---|---|
Default slot | The default slot is used to pass text into the button component. |
icon | Used to pass in an icon to the button component. The icon placement can be controlled via the iconPlacement prop and we recommend using pie-icons-webc for defining this icon, but this can also accept an SVG icon. |
pie-icons-webc
with pie-button
icon slotWe recommend using pie-icons-webc
when using the icon
slot. Here is an example of how you would do this:
<!--
Note that pie-button and the icon that you want to use will need to be imported as components into your application.
See the `pie-icons-webc` README for more info on importing these icons.
-->
<pie-button>
<icon-plus-circle slot="icon"></icon-plus-circle>
Search
</pie-button>
This component does not use any custom event handlers. In order to add event listening to this component, you can treat it like a native HTML element in your application.
For example, to add a click handler in various templates:
<!-- Other attributes omitted for clarity -->
<pie-button onclick="e => console.log(e)">Click me!</pie-button>
<!-- Other attributes omitted for clarity -->
<pie-button @click="handleClick">Click me!</pie-button>
<!-- Other attributes omitted for clarity -->
<PieButton onClick={handleClick}>increment</PieButton>
The pie-button
web component is designed to integrate with standard HTML forms just like a native HTML button. When positioned inside a form, the component will automatically associate itself, enabling it to directly interact with the form context.
The pie-button
provides a set of attributes to customize its behavior within forms:
type
: Determines the button's function. Set to submit
for form submissions or reset
to clear form fields.formaction
: Designates an alternative URL for form data submission when this specific button is clicked.formenctype
: Specifies the form data encoding type during submission via this button.formmethod
: Sets the HTTP method (e.g., GET or POST) for form data when initiated by this button.formnovalidate
: If present, ensures the form is submitted without validation checks.formtarget
: Dictates where to display the response after form submission.Please see the MDN docs for more information on these attributes.
<form action="/default-endpoint" method="post">
<input type="text" name="username" required>
<pie-button
type="submit"
formaction="/alternate-endpoint"
formenctype="multipart/form-data"
formmethod="post"
formnovalidate
formtarget="_blank">
Submit
</pie-button>
</form>
In this example:
Check out our contributing guide for more information on local development and how to run specific component tests.
FAQs
PIE design system button built using web components
The npm package @justeattakeaway/pie-button receives a total of 480 weekly downloads. As such, @justeattakeaway/pie-button popularity was classified as not popular.
We found that @justeattakeaway/pie-button demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 13 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.