Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gacallea/elm_vite_tailwind_template
Opinionated template for building Elm web apps using Vite, TailwindCSS and daisyUI.
https://github.com/gacallea/elm_vite_tailwind_template
daisyui elm elm-lang front-end frontend tailwind tailwindcss vite vitejs web-app web-application web-dev web-development webapp webdev webdevelopment
Last synced: 4 months ago
JSON representation
Opinionated template for building Elm web apps using Vite, TailwindCSS and daisyUI.
- Host: GitHub
- URL: https://github.com/gacallea/elm_vite_tailwind_template
- Owner: gacallea
- License: gpl-3.0
- Created: 2022-05-11T09:26:25.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-12T16:36:02.000Z (9 months ago)
- Last Synced: 2024-04-12T23:07:46.433Z (9 months ago)
- Topics: daisyui, elm, elm-lang, front-end, frontend, tailwind, tailwindcss, vite, vitejs, web-app, web-application, web-dev, web-development, webapp, webdev, webdevelopment
- Language: Elm
- Homepage: https://elm-vite-tailwind-template.netlify.app/
- Size: 1.1 MB
- Stars: 34
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - gacallea/elm_vite_tailwind_template - Opinionated template for building Elm web apps using Vite, TailwindCSS and daisyUI. (Elm)
- fucking-awesome-vite - elm_vite_tailwind_template - Opinionated template for building Elm web apps using Tailwind CSS and Daisy UI. (Get Started / Tauri)
- awesome-vite - elm_vite_tailwind_template - Opinionated template for building Elm web apps using Tailwind CSS and Daisy UI. (Get Started / Tauri)
README
# Vite, Elm, Tailwind CSS, and daisyUI
Opinionated template for building [Elm](https://elm-lang.org/) web applications
using [Vite](https://vitejs.dev/), [Tailwind CSS](https://tailwindcss.com/),
and [daisyUI](https://daisyui.com/).- To learn more about Elm, check out [Elm's official
homepage](https://elm-lang.org/).
- For more information about Vite JS, check out [Vite JS's official
documentation](https://vitejs.dev/).
- For more information about Tailwind CSS, check out [Tailwind CSS's official
documentation](https://tailwindcss.com/docs/installation).
- For more information about daisyUI, check out [daisyUI's official
documentation](https://daisyui.com/docs/use/).## Tooling
### Vite
- [vite-plugin-elm](https://github.com/hmsk/vite-plugin-elm): compile an Elm
module with hot-module reload.
- [vite-plugin-webfont-dl](https://github.com/feat-agency/vite-plugin-webfont-dl):
inject [Google Fonts](https://fonts.google.com/) to improve website's
performance.
- [vite-plugin-compression](https://github.com/vbenjs/vite-plugin-compression):
compress resources to improve website's performance.
- [vite-plugin-imagemin](https://github.com/vbenjs/vite-plugin-imagemin):
compress image assets to improve website's performance.### Elm
- [elm-tooling](https://elm-tooling.github.io/elm-tooling-cli/): command line
program that manages your Elm tools.
- [elm-format](https://github.com/avh4/elm-format): format Elm source code
according to the official [Elm Style
Guide](https://elm-lang.org/docs/style-guide).
- [elm-test](https://package.elm-lang.org/packages/elm-explorations/test/latest/):
write [unit](https://en.wikipedia.org/wiki/Unit_testing) and
[fuzz](https://en.wikipedia.org/wiki/Fuzzing) tests for Elm code.
- [elm-review](https://package.elm-lang.org/packages/jfmengels/elm-review/latest/):
analyze Elm projects and find mistakes before your users find them.#### Packages
Shortlist of Elm packages that could be beneficial. Included as suggestions:
- [hmsk/elm-vite-plugin-helper](https://package.elm-lang.org/packages/hmsk/elm-vite-plugin-helper/latest):
provides helpers for using vite-plugin-elm.
- [tesk9/accessible-html](https://package.elm-lang.org/packages/tesk9/accessible-html/latest/):
makes writing accessible websites easier.
- [lattyware/elm-fontawesome](https://package.elm-lang.org/packages/lattyware/elm-fontawesome/latest/):
native [Font Awesome](https://fontawesome.com/) integration and support.To remove them feel free:
1. not to use them
2. run `npm run review`### Tailwind CSS
The [official plugins](https://tailwindcss.com/docs/plugins#official-plugins)
are installed by default:- [@tailwindcss/typography](https://tailwindcss.com/docs/typography-plugin)
- [@tailwindcss/forms](https://github.com/tailwindlabs/tailwindcss-forms)
- [@tailwindcss/container-queries](https://github.com/tailwindlabs/tailwindcss-container-queries)
- [@tailwindcss/aspect-ratio](https://github.com/tailwindlabs/tailwindcss-aspect-ratio)#### daisyUI
_"The most popular, free and open-source Tailwind CSS component library"_.
[daisyUI](https://daisyui.com/): a Tailwind CSS classes component library,
aiming to work on all frameworks. The CSS nature of daisyUI makes Elm
integration possible and a breeze to use. Examples included:- the whole page is a daisyUI [hero](https://daisyui.com/components/hero/)
section
- the counter buttons are daisyUI
[buttons](https://daisyui.com/components/button/)
- basic daisyUI 'light' and 'dark'
[theming](https://daisyui.com/docs/themes/)/[coloring](https://daisyui.com/docs/colors/)
(via [Elm ports](https://guide.elm-lang.org/interop/ports.html))### Node
- [fnm](https://github.com/Schniz/fnm): easily and consistently manage Node.
- `.nvimrc` set to use latest `lts/iron`.### VS Code
- This template provides both [recommended
extensions](https://code.visualstudio.com/docs/editor/extension-marketplace#_recommended-extensions)
and [workspace
settings](https://code.visualstudio.com/docs/getstarted/settings#_workspace-settings).
- [VS Code](https://code.visualstudio.com/) will prompt you to install them
when you open the workspace for the first time.#### Lint/Format
- [Elm Format](https://github.com/avh4/elm-format)
- [StandardJS](https://standardjs.com/)
- [Prettier](https://prettier.io/)
- [Markdown Lint](https://github.com/DavidAnson/markdownlint)
- [Red Hat YAML](https://github.com/redhat-developer/vscode-yaml) (LSP)
- [Even Better TOML](https://taplo.tamasfe.dev/)#### Elm + Tailwind CSS
- [@max_hoffmann](https://twitter.com/max_hoffmann) amazing [Tailwind CSS in
Elm for VSCode](https://max.hn/thoughts/using-tailwind-css-in-elm-and-vscode)
changes are implemented.## Get Started
### Install tiged
To clone this repository, devoid of `.git`, you can either use `npx
degit` or install `tiged` locally and run `degit` without `npx`.
YMMV.[Tiged is a fork that addresses a number of
issues](https://github.com/tiged/tiged#why-fork=), and should be preferred. To
install it, run:```bash
npm uninstall -g degit
npm install -g tiged
```Most likely, `npx degit` would invoke `degit`. A locally installed
binary makes sure you are running `tiged` instead.### Peruse the template
1. Clone the template:
1. using npx: `npx degit gacallea/elm_vite_tailwind_template my-elm-app`
2. local binary: `degit gacallea/elm_vite_tailwind_template my-elm-app`
2. Enter the project: `cd my-elm-app`
3. Install dependencies: `npm install`
4. Start developing: `npm run dev`### Available Commands
| script | action |
| ----------- | ------------------------------------ |
| postinstall | elm-tooling install |
| dev | vite |
| prebuild | elm-tooling install |
| build | vite build |
| preview | npm run build; vite preview |
| standard | standard --fix src/\*_/_.js |
| markdown | standard-markdown --fix src/\*_/_.md |
| review | elm-review --fix-all |
| test | elm-test-rs |## Contributing
Contributions and constructive criticism are welcome. If you think I'm
overdoing it, feel free to discuss. I'm still experimenting with this, as a
learning opportunity, and I strive to improve the template as much as possible.### pre-commit hooks (WIP)
This repo relies on [pre-commit-ci](https://pre-commit.ci) to make sure all
suggested coding standards are enforced with [git
hooks](https://githooks.com/). You could also install
[pre-commit](https://pre-commit.com/#install) locally to apply the same
[configuration](./.pre-commit-config.yaml) locally.## Acknowledgements
This templated was inspired by [Lindsay K
Wardell](https://github.com/lindsaykwardell/vite-elm-template)'s template.