Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/stuymedova/segmented-control-svelte

Segmented Control component implemented in Svelte
https://github.com/stuymedova/segmented-control-svelte

segmented-control svelte svelte-components sveltejs ui-components

Last synced: 2 months ago
JSON representation

Segmented Control component implemented in Svelte

Awesome Lists containing this project

README

        

# Segmented Control

Segmented Control is a set of two or more Segments, each of which functions as a mutually exclusive button. It features a background, which can be animated with a sliding effect.

segmented-control-svelte

## Installation and Usage

**Installation**

To add a component to a Svelte/SvelteKit project, run:
```shell
npm i segmented-control-svelte
```

**Usage**

Include component on a webpage by adding
```js
import 'segmented-control-svelte/main.css' // Optional, alternatively use darkMode.css or a custom stylesheet
import { SegmentedControl, Segment } from 'segmented-control-svelte'
```
within the `script` tag of a Svelte file. You can further use the component as such:

```html

First
Second

```

The generated HTML will be as such:

```html


First
Second


```

## API

You can specify additional options for Segmented Control and each separate Segment.

**Segmented Control**

***selectedIndex***

Use this option to specify an index of an element to be selected by default, starting with 0.

```html

First
Second

```

You can bind to this value to have changes to the selected index be reflected both in the Segmented Control component and any other part of the interface that uses it.

```html

import 'segmented-control-svelte/main.css'
import { SegmentedControl, Segment } from 'segmented-control-svelte'

let segmentedControlSelectedIndex = 1

First
Second

Index of a selected element: {segmentedControlSelectedIndex}


```

***orientation***

Use this option to specify orientation of the Segmented Control. Accepted options are "horizontal" and "vertical". Default orientation is "horizontal".

```html

First
Second

```

**Segment**

***label***

Use this option to specify a Segment's label.

```html


```

Alternatively, a label can be specified between component tags:

```html

First
Second

```

***isDisabled***

Use this option to disable selection of a Segment.

```html

First
Second

```

## Demo

Launch a demo by running in the terminal:

```shell
git clone --depth=1 https://github.com/stuymedova/segmented-control-svelte . # Clone the latest commit from this repository to your current directory
npm install
npm run dev
```

The demo will be available at http://localhost:3000. Navigate to `src/routes/index.svelte` to make any changes.