From 2675423ad7cff638b13675899dfe4535c458b9a3 Mon Sep 17 00:00:00 2001 From: Hunter Johnston <64506580+huntabyte@users.noreply.github.com> Date: Mon, 1 Jan 2024 15:04:37 -0700 Subject: [PATCH] Initial release (#6) --- .changeset/rich-chairs-watch.md | 5 ++ README.md | 90 ++++++++++++++++++++------------- vite.config.ts | 1 - 3 files changed, 60 insertions(+), 36 deletions(-) create mode 100644 .changeset/rich-chairs-watch.md diff --git a/.changeset/rich-chairs-watch.md b/.changeset/rich-chairs-watch.md new file mode 100644 index 0000000..d731eb4 --- /dev/null +++ b/.changeset/rich-chairs-watch.md @@ -0,0 +1,5 @@ +--- +'vaul-svelte': patch +--- + +initial release diff --git a/README.md b/README.md index 69f4875..0425253 100644 --- a/README.md +++ b/README.md @@ -1,58 +1,78 @@ -# create-svelte +Vaul-Svelte is an unstyled drawer component for Svelte that can be used as a Dialog replacement on tablet and mobile devices. It uses [Bits' Dialog primitive](https://www.bits-ui.com/docs/components/dialog) under the hood and is inspired by [this tweet](https://twitter.com/devongovett/status/1674470185783402496). -Everything you need to build a Svelte library, powered by [`create-svelte`](https://github.com/sveltejs/kit/tree/main/packages/create-svelte). +This is a port of [Vaul](https://github.com/emilkowalski/vaul) for React, which was created by [Emil Kowalski](https://twitter.com/emilkowalski_). -Read more about creating a library [in the docs](https://kit.svelte.dev/docs/packaging). +## Usage -## Creating a project - -If you're seeing this, you've probably already done this step. Congrats! +To start using the library, install it in your project: ```bash -# create a new project in the current directory -npm create svelte@latest +npm install vaul-svelte +``` -# create a new project in my-app -npm create svelte@latest my-app +Use the drawer in your app. + +```svelte + + + + Open + + +

Content

+
+ +
+
``` -## Developing +## Examples -Once you've created a project and installed dependencies with `npm install` (or `pnpm install` or `yarn`), start a development server: +(Coming soon) -```bash -npm run dev +## API Reference -# or start the server and open the app in a new browser tab -npm run dev -- --open -``` +### Root -Everything inside `src/lib` is part of your library, everything inside `src/routes` can be used as a showcase or preview app. +Contains all parts of a dialog. Use `shouldScaleBackground` to enable background scaling, it requires an element with `[data-vaul-drawer-wrapper]` data attribute to scale its background. +Can be controlled by binding to the `open` prop, or using the`onOpenChange` prop. -## Building +Additional props: -To build your library: +`closeThreshold`: Number between 0 and 1 that determines when the drawer should be closed. Example: threshold of 0.5 would close the drawer if the user swiped for 50% of the height of the drawer or more. -```bash -npm run package -``` +`scrollLockTimeout`: Duration for which the drawer is not draggable after scrolling content inside of the drawer. Defaults to 500ms -To create a production version of your showcase app: +`snapPoints`: Array of numbers from 0 to 100 that corresponds to % of the screen a given snap point should take up. Should go from least visible. Example `[0.2, 0.5, 0.8]`. You can also use px values, which doesn't take screen height into account. -```bash -npm run build -``` +`fadeFromIndex`: Index of a `snapPoint` from which the overlay fade should be applied. Defaults to the last snap point. -You can preview the production build with `npm run preview`. +### Trigger -> To deploy your app, you may need to install an [adapter](https://kit.svelte.dev/docs/adapters) for your target environment. +The button that opens the dialog. [Props](https://www.bits-ui.com/docs/components/dialog#trigger). -## Publishing +### Content -Go into the `package.json` and give your package the desired name through the `"name"` option. Also consider adding a `"license"` field and point it to a `LICENSE` file which you can create from a template (one popular option is the [MIT license](https://opensource.org/license/mit/)). +Content that should be rendered in the drawer. [Props](https://www.bits-ui.com/docs/components/dialog#content). -To publish your library to [npm](https://www.npmjs.com): +### Overlay -```bash -npm publish -``` +A layer that covers the inert portion of the view when the dialog is open. [Props](https://www.bits-ui.com/docs/components/dialog#overlay). + +### Title + +An accessible title to be announced when the dialog is opened. [Props](https://www.bits-ui.com/docs/components/dialog#title). + +### Description + +An optional accessible description to be announced when the dialog is opened. [Props](https://www.bits-ui.com/docs/components/dialog#description). + +### Close + +The button that closes the dialog. [Props](https://www.bits-ui.com/docs/components/dialog#close). + +### Portal + +Portals your drawer into the body. diff --git a/vite.config.ts b/vite.config.ts index b481b8b..ca016cb 100644 --- a/vite.config.ts +++ b/vite.config.ts @@ -10,7 +10,6 @@ export default defineConfig({ environment: 'jsdom', // in-source testing includeSource: ['src/**/*.{js,ts,svelte}'], - setupFiles: ['./src/tests/setupTest.ts'], coverage: { exclude: ['setupTest.ts'] },