Nuxt VCalendar
在 Nuxt 中整合 V Calendar
特色
- 零配置
- 前綴 VCalendar 元件
- 自動導入所有 VCalendar 元件或僅導入您需要的元件
快速設定
- 將
@samk-dev/nuxt-vcalendar
相依性新增至您的專案
npx nuxi@latest module add @samk-dev/nuxt-vcalendar
就這樣!您現在可以在您的 Nuxt 應用程式中使用 Nuxt VCalendar ✨
手動安裝
- 將 @samk-dev/nuxt-vcalendar 相依性新增至您的專案
# Using pnpm
pnpm add -D @samk-dev/nuxt-vcalendar
# Using yarn
yarn add --dev @samk-dev/nuxt-vcalendar
# Using npm
npm install --save-dev @samk-dev/nuxt-vcalendar
- 將
@samk-dev/nuxt-vcalendar
新增至nuxt.config.ts
的modules
區段
export default defineNuxtConfig({
modules: ['@samk-dev/nuxt-vcalendar']
})
Stackblitz 範例
https://stackblitz.com/edit/nuxt-starter-2zwgab?file=app.vue
使用範例
<script setup lang="ts">
import { ref } from '#imports'
const date = ref(new Date())
const attrs = ref([
{
key: 'today',
highlight: {
color: 'green',
fillMode: 'solid'
},
dates: new Date()
}
])
</script>
<template>
<div>
<client-only>
<h2>Calendar</h2>
<VCalendar v-model="date" />
<h2>Date Picker</h2>
<VDatePicker v-model="date" :attributes="attrs" />
</client-only>
</div>
</template>
模組選項
export type VCalendarComponents = {
DatePicker: boolean
Calendar: boolean
}
export interface ModuleOptions {
/**
* @description prefix instead of v-
* @default V
*/
prefix: string
/**
* @description load v-calendar styles
* @default true
*/
defaultCss: boolean
/**
* @description load custom stylesheet
* @default undefined
*/
cssPath?: string
/**
* @description v-calendar options
* @see https://vcalendar.io/calendar/api.html#defaults
*/
calendarOptions?: Defaults
/**
* @description auto import v-calendar components
* @default {DatePicker, true, Calendar: true}
*/
autoImports: VCalendarComponents
}
開發
# Install dependencies
npm install
# Generate type stubs
npm run dev:prepare
# Develop with the playground
npm run dev
# Build the playground
npm run dev:build
# Run ESLint
npm run lint
# Run Vitest
npm run test
npm run test:watch
# Release new version
npm run release