https://github.com/renatoxm/nuxt3-starter
A Nuxt 3 starter template or boilerplate with a lot of useful features. and integrated with TailwindCSS 3 and DaisyUI.
https://github.com/renatoxm/nuxt3-starter
nuxt nuxtjs tailwindcss vue
Last synced: 2 months ago
JSON representation
A Nuxt 3 starter template or boilerplate with a lot of useful features. and integrated with TailwindCSS 3 and DaisyUI.
- Host: GitHub
- URL: https://github.com/renatoxm/nuxt3-starter
- Owner: renatoxm
- License: mit
- Created: 2023-02-24T21:06:36.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-03-01T08:35:02.000Z (over 2 years ago)
- Last Synced: 2025-04-09T18:12:04.195Z (2 months ago)
- Topics: nuxt, nuxtjs, tailwindcss, vue
- Language: Vue
- Homepage: https://nuxt3-starter-delta.vercel.app
- Size: 13.4 MB
- Stars: 4
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Nuxt 3 Starter
A Nuxt 3 starter template or boilerplate with a lot of useful features. and integrated with TailwindCSS 3.
## Features
- [x] ๐จ [Tailwind CSS v3](https://tailwindcss.com/) with [Windicss](https://windicss.org/)
- [x] โจ [Headless UI](https://headlessui.dev/)
- [x] ๐ [Icon Pack Component (unplugin-icons)](https://icones.js.org/)
- [x] ๐น [State & Store Management (Pinia)](https://pinia.vuejs.org/)
- [x] ๐ฉ [Localization (i18n) by @intlify](https://github.com/intlify/nuxt3) & Auto Generate Locales
- [x] ๐ฆ [Vue Composition Collection (Vueuse)](https://vueuse.org/)
- [x] ๐ [Content Management System (Nuxt Content)](https://content.nuxtjs.org/) [SSR]
- [x] ๐ Switch Theme (light, dark, system, realtime)
- [x] ๐ฎ๐ฉ Language Switcher
- [x] ๐ช Built-in Component & Layout
- [x] Eslint & Prettier
- [x] Husky & Commitlint
- [x] Custom Workspace Snippets
- [x] Built-in Unit Test
- [x] Configurable Theme
- [x] Primary Colors
- [x] Font## Preview
![]()
## Table of Contents
- [Nuxt 3 Starter](#nuxt-3-starter)
- [Features](#features)
- [To Do](#to-do)
- [Preview](#preview)
- [Table of Contents](#table-of-contents)
- [Quick Start](#quick-start)
- [Start with this template](#start-with-this-template)
- [Deploy as Static Site](#deploy-as-static-site)
- [Built-in Components](#built-in-components)
- [Notes](#notes)
- [Nuxt Content](#nuxt-content)
- [Custom Workspace Snippets](#custom-workspace-snippets)
- [Styles](#styles)
- [Theme (Dark Mode)](#theme-dark-mode)
- [Localization](#localization)
- [Generate Locales](#generate-locales)
- [Icons](#icons)
- [Precommit and Postmerge](#precommit-and-postmerge)
- [License](#license)## Quick Start
For detail information, go here [Getting Started](https://nuxt3-starter-renatoxm.vercel.app/)
### Start with this template
- This project using `pnpm` as package manager.
- Clone this project to your computer `git clone https://github.com/renatoxm/nuxt3-starter`
- Install dependencies `pnpm install --shamefully-hoist`
- Run `pnpm dev` to start development server and open `http://localhost:3000` in your browser### Deploy as Static Site
- Run `pnpm generate` to build the project
- Serve `dist/` folder
Checkout the [deployment documentation](https://v3.nuxtjs.org/docs/deployment).## Built-in Components
- [x] Footer
- [x] Button
- [x] Anchor (link)
- [x] Alert
- [x] Card
- [x] Action Sheet
- [x] Theme Toggle / Switcher
- [x] Navbar
- [x] Navbar Builder
- [x] Drawer (on mobile)
- [x] Options (on mobile)
- [x] Page Layout
- [x] Wrapper
- [x] Header
- [x] Title
- [x] Body
- [x] Section
- [x] Section Wrapper
- [x] Section Title
- [x] Dashboard Layout
- [x] Sidebar
- [ ] Modal## Notes
### Nuxt Content
With Nuxt Content, you can just create markdown file (recommended) inside `content` folder.
But this is only available for SSR (Server Side Rendering) mode. Static mode still not working, you can see the issue https://github.com/nuxt/content/issues/1202
For now, you can follow### Custom Workspace Snippets
This workspace including custom snippets for VSCode.
- **n3:content**
content template with markdown
- **n3:page**
page template### Styles
Tailwindcss import managed by windicss.
and you can add custom styles in :```
/path/to/assets/sass/app.scss
```### Theme (Dark Mode)
ThemeManager is a plugin that allows you to switch between themes. this lib in :
```
/path/to/utils/theme.ts
````Thememanager` is a function-class construct when app.vue before mounted. theme construct inside `AppSetup()` in `/path/to/app.vue` :
```vue
import { AppSetup } from '~/utils/app'
// app setup
AppSetup()```
To change theme, you can direct set theme from state `theme.setting`, example :
```vue
import { IThemeSettingOptions } from '~/utils/theme'
const themeSetting = useState<IThemeSettingOptions>('theme.setting')
themeSetting.value = 'dark'```
When you change state `theme.setting`, it will automatically change theme.
Theme Setting have 4 options :
- `light`
- `dark`
- `system` (operating system theme)
- `realtime` (realtime theme, if 05:00 - 17:00, it will change to light theme, otherwise dark)We have state `theme.current`, this state return `light` or `dark` theme. basically it's process from `theme.setting`.
dont change theme with this state.### Localization
Localization is a plugin that allows you to switch between languages. this lib in :
```
/path/to/utils/lang.ts
````LanguageManager` is a function-class construct when app.vue before mounted.
this lib depend on [@intlify/nuxt3](https://github.com/intlify/nuxt3)
lang construct inside `AppSetup()` in `/path/to/app.vue` :import { AppSetup } from '~/utils/app';
// app setup
AppSetup()To change language, you can direct set language from state `lang.setting`, example :
```vue
const langSetting = useState<string>('locale.setting')
langSetting.value = 'en'```
When you change state `locale.setting`, it will automatically change language.
### Generate Locales
I made an automatic tool to automatically translate to all languages โโthat have been prepared in the ./locales/ folder
So, you can just update "locales/en.yml" and run this tools, it will automatically translate to all languages.You can just run :
```
pnpm generate:locales# or :
node ./tools/translator.js ./locales en.yml
```### Icons
This project using unplugin-icons for auto generate and import icon as component.
You can see collection icon list in : [https://icones.js.org/](https://icones.js.org/)
you can use `` or ``.
in this project, configuration prefix as a "icon", you can see in `nuxt.config.ts` :
```js
export default defineNuxtConfig({
...vite: {
plugins: [
UnpluginComponentsVite({
dts: true,
resolvers: [
IconsResolver({
prefix: 'Icon',
}),
],
}),
],
},...
})
```Example :
```vue
// use icon from collection "Simple Icons" and name icon is "nuxtdotjs"// use icon from collection "Unicons" and name icon is "sun"
```
### Precommit and Postmerge
This project using husky and commitlint for precommit and postmerge.
when you commit, it will check your commit message and running "pnpm lint-staged" to check your staged files.
configuration in : `/path/to/.husky/pre-commit` and `/path/to/commitlint.config.js`And when Postmerge, it will run "pnpm" to automatically install new dependencies.
configuration in `/path/to/.husky/post-merge`## Credits
This project was based on the beautifully crafted [Nuxt 3 Awesome Starter](https://github.com/viandwi24/nuxt3-awesome-starter) by [Alfian Dwi Nugraha](https://github.com/viandwi24)
## License
This project is licensed under the MIT license, Copyright (c) 2023 Renato Nabinger. For more information see the [LICENSE](LICENSE.md) file.