@nuxt-themes/elements-edge v0.0.1-d8bff8c

Nuxt Elements
The Vue components library to build any kind of websites, built with design tokens and made to be used in Markdown Components.
- Documentation: elements.nuxt.dev (password:
nuxtifytheworld) - Online playground: stackblitz.com/edit/nuxt-elements-play
Usage
In your Nuxt project, install the package:
yarn add --dev @nuxt-themes/elementsThen in your nuxt.config.ts, add it to the extends array:
import { defineNuxtConfig } from 'nuxt'
export default defineNuxtConfig({
extends: ['@nuxt-themes/elements']
})Start using the elements to build your website, checkout the list of elements on elements.nuxt.dev.
Edge channel
After each commit is merged into the dev branch and passing all tests, we trigger an automated npm release using Github Actions publishing on @nuxt-themes/elements-edge.
You can opt-in to it by installing and using @nuxt-themes/elements-edge instead of @nuxt-themes/elements.
Elements
An element is a Vue component made to be used inside the content/ directory with the MDC syntax.
The component can have:
- Props to receive data from the editor (generated form)
- Slots using the
<ContentSlot>component to pass MDC to the component
Example:
<script setup lang="ts">
defineProps({
image: {
type: String,
default: null
}
})
</script>
<template>
<section>
<h1 class="text-3xl font-bold text-primary-900 dark:text-primary-100">
<ContentSlot :use="$slots.title" unwrap="p">Default title</ContentSlot>
</h1>
<!-- description slot is optional -->
<p class="mt-3" v-if="$slots.description">
<ContentSlot :use="$slots.description" unwrap="p" />
</p>
</div>
<img v-if="image" :src="image" />
</div>
</section>
</template>Note that the <ContentSlot> component cannot have class attribute because they are headless components.
Development
Make sure to install the dependencies:
yarn installStart the playground and documentation on http://localhost:3000
npm run devGenerate the documentation:
npm run generateLocally preview the generated documentation:
npm run previewTo use the elements in development in your project:
- Run the
pwdcommand in the elements project and copy it, example:/Users/atinux/Projects/nuxt-themes/elements - Add it to your
nuxt.config.tsand suffix with/theme:
import { defineNuxtConfig } from 'nuxt'
export default defineNuxtConfig({
extends: ['/Users/atinux/Projects/nuxt-themes/elements/theme']
})License
TBD
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago