This library provides a collection of reusable UI components built with Svelte.
This library is publish on npm & can be installed via any npm client. Use the following command to install the library.
npm install @juspay/svelte-ui-components
The library contains a collection of components that can be imported & used in your svelte project.
- Accordion
- Badge
- Banner
- Brand Loader (aka Splash Screen )
- Button
- Carousel
- Checkbox / Checklist Item
- Icon
- Input
- Input with attached Button
- List Item
- Loader
- Modal
- Select
- Status Screen
- Table
- Toggle
- Toolbar
All of the components can be easily imported from the 'svelte-ui-components' package.
<script>
import { Button } from '@juspay/svelte-ui-components';
</script>
<Button>Click me</Button>
Each component comes with a set of configuration options that can be used to customize the component. There are two ways to customize the component.
-
Using css variables:
- All the components have exposed css variables for all the properties available.
- The css variables can be used to customize the component.
-
Using props:
- All the components have exposed props for dynamic values/variables.
- The props can be used to customize the component.
<script lang="ts">
import {
Button,
type ButtonProperties,
defaultButtonProperties
} from '@juspay/svelte-ui-components';
const buttonProperties: ButtonProperties = {
...defaultButtonProperties,
text: 'Submit'
};
function handleSubmitClick() {
// handle click
}
</script>
```svelte
<div class="form">
<Button properties={buttonProperties} on:click={handleSubmitClick} />
</div>
<style>
.form {
--button-color: black;
--button-text-color: white;
// and many more
}
</style>
- Clone the repository
- Install dependencies using
pnpm install
- Make changes to the components
- Run tests using
pnpm run test
- Commit the changes
- Push the changes
- Create a pull request
- Add demo support
- Add documentation for all components
- Add more components
- Add tests