Socket
Socket
Sign inDemoInstall

@nuxt-themes/elements

Package Overview
Dependencies
Maintainers
3
Versions
42
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@nuxt-themes/elements

[![Nuxt Elements](https://user-images.githubusercontent.com/904724/182881577-5c94cc0f-c8b9-4005-b204-4b4c2e801f49.png)](https://elements.nuxt.space)


Version published
Weekly downloads
1.5K
decreased by-4.87%
Maintainers
3
Weekly downloads
 
Created
Source

Nuxt Elements

Nuxt Elements

The Vue components library to build any kind of websites, built with design tokens and made to be used in Markdown Components.

Usage

In your Nuxt project, install the package:

pnpm add -D @nuxt-themes/elements

Then in your nuxt.config.ts, add it to the extends array:

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:

pnpm install

Start the playground:

pnpm dev

Start the documentation:

pnpm generate

Preview the built documentation:

pnpm preview

To use the elements in development in your project:

  • Run the pwd command in the elements project and copy it, example: /Users/atinux/Projects/nuxt-themes/elements
  • Add it to your nuxt.config.ts and suffix with /theme:
export default defineNuxtConfig({
  extends: ['/Users/atinux/Projects/nuxt-themes/elements/theme']
})

License

TBD

FAQs

Package last updated on 01 Dec 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc