Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lxsmnsyc/tailwind-layouts
Collection of Tailwind Layouts
https://github.com/lxsmnsyc/tailwind-layouts
alpinejs cdn-imports esbuild esm lit-html playground preact react skypack solidjs tailwind tailwindcss typescript vite vue3
Last synced: 3 months ago
JSON representation
Collection of Tailwind Layouts
- Host: GitHub
- URL: https://github.com/lxsmnsyc/tailwind-layouts
- Owner: lxsmnsyc
- License: mit
- Created: 2021-06-03T11:52:27.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-09-05T05:32:29.000Z (over 3 years ago)
- Last Synced: 2024-10-06T11:16:50.577Z (4 months ago)
- Topics: alpinejs, cdn-imports, esbuild, esm, lit-html, playground, preact, react, skypack, solidjs, tailwind, tailwindcss, typescript, vite, vue3
- Language: TypeScript
- Homepage: https://tailwind-layouts.vercel.app
- Size: 1.27 MB
- Stars: 63
- Watchers: 4
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# tailwind-layouts
![image](https://user-images.githubusercontent.com/4783372/121133049-74fdb180-c864-11eb-86d9-dcb2a932a174.png)
> A collection of [Tailwind](https://tailwindcss.com) Layouts
## Playground
The website includes a client-side playground which allows components to be rendered and tweaked in real-time. The playground uses [Split.js](https://split.js.org/) to allow resizable editor and live code output.
### Editor
`tailwind-layouts` uses [Microsoft's Monaco Editor](https://microsoft.github.io/monaco-editor/) (more specifically, [@monaco-editor/react](https://monaco-react.surenatoyan.com/)) to view and edit the component's code.
### Live Code
`tailwind-layouts` uses [ESBuild](https://esbuild.github.io/) to transform and render the component in real-time. JSX and TypeScript is supported, but the compiled code is transformed into ES2017 for browser compatibility. The compiled code format is also in ESM. The code is then transported to an in-document iframe that performs an [ESM HMR](https://github.com/snowpackjs/esm-hmr)-like mechanism.
Since Tailwind only generates classes during build-time, `tailwind-layouts` instead uses [`twind`](https://twind.dev/) to generate classes on runtime, as well as add support for JIT.
#### CDN Imports
Since the compiled code's format is in ESM, `tailwind-layouts` allows CDN imports. You can check out [Skypack](http://skypack.dev/).
#### Live TypeScript definitions
When importing packages from [Skypack](http://skypack.dev/) or [UNPKG](https://unpkg.com/), `tailwind-layouts` will attempt to load the TypeScript declarations of the imported package in real-time, allowing you to have a type-safe environment in the playground.
#### Source Map
Since `ESBuild` transforms the input code, it may lose context of what the original source may look like, so it exports a source map information of the source content. However, errors would have a hard time showing what the original source's stack looks like, therefor `tailwind-layouts` uses [`source-map-support`](https://github.com/evanw/node-source-map-support) to shim source map stack traces.
### Environments
`tailwind-layouts` currently supports the following implementations:
- [Vanilla + HTML](http://vanilla-js.com/)
- [React](https://reactjs.org/)
- [Preact](https://preactjs.com/)
- [Vue 3](https://v3.vuejs.org/)
- [`lit-html`](http://lit-html.polymer-project.org/)
- [uhtml](https://github.com/WebReflection/uhtml)
- [Alpine.js](https://alpinejs.dev/)
- [SolidJS](https://www.solidjs.com/)Upcoming implemenations:
- Inferno
- Vue 2
- Vue 3 SFC
- Svelte## License
MIT © [lxsmnsyc](https://github.com/lxsmnsyc)