Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/mdauner/sveltejs-forms

Declarative forms for Svelte
https://github.com/mdauner/sveltejs-forms

form form-validation hacktoberfest svelte svelte-components svelte3 sveltejs yup

Last synced: about 17 hours ago
JSON representation

Declarative forms for Svelte

Awesome Lists containing this project

README

        

# sveltejs-forms

![npm](https://img.shields.io/npm/v/sveltejs-forms)
![npm bundle size](https://img.shields.io/bundlephobia/minzip/sveltejs-forms)
![npm](https://img.shields.io/npm/dm/sveltejs-forms)

![GitHub](https://img.shields.io/github/license/mdauner/sveltejs-forms)
![Actions Status](https://github.com/mdauner/sveltejs-forms/workflows/CI/badge.svg)
[![codecov](https://codecov.io/gh/mdauner/sveltejs-forms/branch/master/graph/badge.svg)](https://codecov.io/gh/mdauner/sveltejs-forms)

Declarative forms for [Svelte](https://svelte.dev/).

[DEMO](https://svelte.dev/repl/8e7deaa261364b4f8b2c0caff1982eeb?version=3.23.0)

## Features

- optional schema-based validation through [Yup](https://github.com/jquense/yup)
- access to nested properties using paths
- supports custom components
- provides `Input`, `Select`, `Choice` components to reduce boilerplate

## Install

```shell
$ npm i sveltejs-forms
```

or

```shell
$ yarn add sveltejs-forms
```

## How to use

### With provided `Input`, `Select`, `Choice` helper components

```html

import { Form, Input, Select, Choice } from 'sveltejs-forms';
import yup from '[email protected]';

function handleSubmit({ detail: { values, setSubmitting, resetForm } }) {
setTimeout(() => {
console.log(values);
setSubmitting(false);
resetForm({
user: { email: '[email protected]' }, // optional
});
}, 2000);

/**
* {
* user: {
* email: '[email protected]'
* },
* password: '123456',
* language: 'svelte',
* os: 'osx,linux'
* }
*/
}

function handleReset() {
console.log('form has been reset');
}

const schema = yup.object().shape({
user: yup.object().shape({
email: yup
.string()
.required()
.email(),
}),
password: yup.string().min(4),
language: yup.string().required(),
os: yup.string(),
});

const langOptions = [
{ id: 'svelte', title: 'Svelte' },
{ id: 'react', title: 'React' },
{ id: 'angular', title: 'Angular' },
];

const osOptions = [
{ id: 'macos', title: 'macOS' },
{ id: 'linux', title: 'Linux 🐧' },
{ id: 'windows', title: 'Windows' },
];

const initialValues = {
language: 'svelte',
};

:global(.sveltejs-forms) {
background-color: #f8f8f8;
display: inline-block;
padding: 1rem;
border: 1px solid #ccc;
border-radius: 5px;
}

:global(label) {
font-size: 0.8rem;
color: #888;
margin-bottom: 0.2rem;
}

:global(.message) {
font-size: 0.8rem;
color: #888;
margin: 0.2rem 0;
color: #f56565;
}

:global(input[type='text']),
:global(textarea),
:global(select) {
width: 100%;
background-color: white;
margin: 0;
}

:global(input[type='checkbox'] + label) {
display: inline-block;
margin-right: 2rem;
}

:global(.field) {
margin-bottom: 1rem;
}

button {
border-radius: 5px;
padding: 0.5rem 1rem;
margin-right: 1rem;
color: white;
}

button[type='reset'] {
background-color: #f56565;
}

button[type='submit'] {
background-color: #48bb78;
width: 80px;
}

{initialValues}
validateOnBlur={false}
validateOnChange={false}
on:submit={handleSubmit}
on:reset={handleReset}
let:isSubmitting
let:isValid
>

label="Email Address"
value="[email protected]"
placeholder="e.g. [email protected]" />



Reset
Sign in

The form is valid: {isValid}

```

### With custom component:

```html

import { Form } from 'sveltejs-forms';
import Select from 'svelte-select';
import yup from '[email protected]';

let svelteSelect;

function handleSubmit({ detail: { values, setSubmitting, resetForm } }) {
setTimeout(() => {
console.log(values);
setSubmitting(false);
svelteSelect.handleClear();
resetForm();
}, 2000);
}

const schema = yup.object().shape({
food: yup.string().required()
});

let items = [
{ value: 'chocolate', label: 'Chocolate' },
{ value: 'pizza', label: 'Pizza' },
{ value: 'cake', label: 'Cake' },
{ value: 'chips', label: 'Chips' },
{ value: 'ice-cream', label: 'Ice Cream' },
];

Submit

```

## Slot props

| Name | Type |
|------|------|
| isSubmitting | `boolean`
| isValid | `boolean`
| setValue(path, value) | `function`
| touchField(path) | `function`
| validate() | `function`
| values | `object`
| errors | `object`
| touched | `object`

## Contributions

**All contributions are welcome.**