diff --git a/docs-old/.vitepress/config.ts b/docs-old/.vitepress/config.ts
deleted file mode 100644
index 2b638cb..0000000
--- a/docs-old/.vitepress/config.ts
+++ /dev/null
@@ -1,31 +0,0 @@
-import { defineConfig } from 'vitepress'
-
-import { editLink } from './config/edit-link'
-import { sidebar } from './config/sidebar'
-import { transformPageData } from './config/transform-page-data'
-import { vite } from './config/vite'
-
-// https://vitepress.dev/reference/site-config
-export default defineConfig({
- appearance: 'dark',
- base: '/hub',
- // description: 'A VitePress Site',
- head: [['link', { href: 'https://github.com/moeru-ai.png', rel: 'icon', type: 'image/png' }]],
- themeConfig: {
- editLink,
- // https://vitepress.dev/reference/default-theme-config
- logo: 'https://github.com/moeru-ai.png',
- nav: [
- { link: '/characters/', text: 'Characters' },
- // { text: 'Lorebooks', link: '/lorebooks/' },
- // { text: 'Models', link: '/models/' },
- ],
- sidebar,
- socialLinks: [
- { icon: 'github', link: 'https://github.com/moeru-ai/hub' },
- ],
- },
- title: '@moeru-ai/hub',
- transformPageData,
- vite,
-})
diff --git a/docs-old/.vitepress/config/edit-link.ts b/docs-old/.vitepress/config/edit-link.ts
deleted file mode 100644
index 03d0753..0000000
--- a/docs-old/.vitepress/config/edit-link.ts
+++ /dev/null
@@ -1,13 +0,0 @@
-import type { DefaultTheme as Theme } from 'vitepress'
-
-export const editLink = {
- // pattern: 'https://github.com/moeru-ai/hub/edit/main/:path'
- pattern: ({ filePath }) => {
- const base = new URL('https://github.com/moeru-ai/hub/edit/main/')
-
- if (filePath.startsWith('characters/') && !(filePath === 'characters/index.md'))
- return new URL(`packages/characters/src/${filePath.slice(11, -3)}.ts`, base).href
-
- return new URL(`docs/${filePath}`, base).href
- },
-} satisfies Theme.EditLink
diff --git a/docs-old/.vitepress/config/sidebar.ts b/docs-old/.vitepress/config/sidebar.ts
deleted file mode 100644
index 27da595..0000000
--- a/docs-old/.vitepress/config/sidebar.ts
+++ /dev/null
@@ -1,24 +0,0 @@
-import type { DefaultTheme as Theme } from 'vitepress'
-
-import { categories, json } from '@moeru-ai/characters'
-
-const defineSidebar = (active: 'characters') => [{
- collapsed: active !== 'characters',
- items: Object.entries(json)
- .map(([category, characters]) => ({
- items: Object.entries(characters)
- .map(([character, variants]) => ({
- link: `/characters/${category}/${character}`,
- text: variants[character].data.name,
- })),
- text: categories[category],
- })),
- link: '/characters/index.md',
- text: 'Characters',
-}] satisfies Theme.SidebarItem[]
-
-export const sidebar = {
- '/characters/': defineSidebar('characters'),
- // '/lorebooks/': defineSidebar('lorebooks'),
- // '/models/': defineSidebar('models'),
-} satisfies Theme.SidebarMulti
diff --git a/docs-old/.vitepress/config/transform-page-data.ts b/docs-old/.vitepress/config/transform-page-data.ts
deleted file mode 100644
index 69854e5..0000000
--- a/docs-old/.vitepress/config/transform-page-data.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-import type { UserConfig } from 'vitepress'
-
-/** {@link https://github.com/vuejs/vitepress/issues/2637} */
-export const transformPageData: UserConfig['transformPageData'] = (data) => {
- if (data.params && data.relativePath.startsWith('characters/')) {
- data.title = data.title.replace('{{params.char.data.name}}', data.params.char.data.name)
- data.description = data.params.char.data.creator_notes
- }
-}
diff --git a/docs-old/.vitepress/config/unocss.ts b/docs-old/.vitepress/config/unocss.ts
deleted file mode 100644
index 1c9b53b..0000000
--- a/docs-old/.vitepress/config/unocss.ts
+++ /dev/null
@@ -1,28 +0,0 @@
-import {
- defineConfig,
- presetAttributify,
- // presetIcons,
- presetUno,
-} from 'unocss'
-
-/** {@link https://github.com/nolebase/integrations/blob/main/uno.config.ts} */
-export default defineConfig({
- presets: [
- presetUno({
- dark: 'class',
- }),
- presetAttributify(),
- // presetIcons({
- // cdn: 'https://esm.sh/',
- // prefix: 'i-',
- // scale: 1.2, // size: 1.2 rem
- // extraProperties: {
- // 'display': 'inline-block',
- // 'vertical-align': 'middle',
- // 'min-width': '1.2rem',
- // },
- // warn: true,
- // }),
- ],
- shortcuts: [],
-})
diff --git a/docs-old/.vitepress/config/vite.ts b/docs-old/.vitepress/config/vite.ts
deleted file mode 100644
index d44a035..0000000
--- a/docs-old/.vitepress/config/vite.ts
+++ /dev/null
@@ -1,44 +0,0 @@
-import type { UserConfig } from 'vitepress'
-
-import {
- GitChangelog,
- GitChangelogMarkdownSection,
-} from '@nolebase/vitepress-plugin-git-changelog/vite'
-import UnoCSS from 'unocss/vite'
-
-import unocssConfig from './unocss'
-
-/** {@link https://nolebase-integrations.ayaka.io/pages/en/integrations/vitepress-plugin-enhanced-readabilities/#add-plugin-specific-options-into-configurations-of-vite} */
-export const vite = {
- optimizeDeps: {
- exclude: ['@nolebase/vitepress-plugin-enhanced-readabilities/client'],
- include: ['@nolebase/vitepress-plugin-enhanced-readabilities > @nolebase/ui > @rive-app/canvas'],
- },
- plugins: [
- GitChangelog({
- includeDirs: ['docs', 'packages/characters/src'],
- includeExtensions: ['.md', '.ts'],
- repoURL: () => 'https://github.com/moeru-ai/hub',
- rewritePathsBy: {
- handler: (_commit, path) => {
- if (path) {
- // @moeru-ai/characters
- if (path.startsWith('packages/characters/src/') && !path.includes('index.ts'))
- return `hub/characters/${path.slice(24, -3)}.md`
-
- // @moeru-ai/docs
- if (path.startsWith('docs-old/'))
- return path.replace('docs-old/', 'hub/')
- }
-
- return path
- },
- },
- }),
- GitChangelogMarkdownSection(),
- UnoCSS(unocssConfig),
- ],
- ssr: {
- noExternal: ['@nolebase/vitepress-plugin-enhanced-readabilities'],
- },
-} satisfies UserConfig['vite']
diff --git a/docs-old/.vitepress/theme/Layout.vue b/docs-old/.vitepress/theme/Layout.vue
deleted file mode 100644
index ecd4625..0000000
--- a/docs-old/.vitepress/theme/Layout.vue
+++ /dev/null
@@ -1,71 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/docs-old/.vitepress/theme/index.ts b/docs-old/.vitepress/theme/index.ts
deleted file mode 100644
index b00decb..0000000
--- a/docs-old/.vitepress/theme/index.ts
+++ /dev/null
@@ -1,43 +0,0 @@
-// https://vitepress.dev/guide/custom-theme
-import type { Theme } from 'vitepress'
-
-import {
- NolebaseEnhancedReadabilitiesMenu,
- NolebaseEnhancedReadabilitiesScreenMenu,
-} from '@nolebase/vitepress-plugin-enhanced-readabilities/client'
-import '@nolebase/vitepress-plugin-enhanced-readabilities/client/style.css'
-import {
- NolebaseGitChangelogPlugin,
-} from '@nolebase/vitepress-plugin-git-changelog/client'
-import '@nolebase/vitepress-plugin-git-changelog/client/style.css'
-import 'uno.css'
-import DefaultTheme from 'vitepress/theme-without-fonts'
-import { h } from 'vue'
-
-import Layout from './Layout.vue'
-import './style.css'
-
-export default {
- enhanceApp: ({ app }) => {
- app.use(NolebaseGitChangelogPlugin, {
- mapContributors: [
- {
- avatar: 'https://github.com/kwaa.png',
- emailAliases: ['50108258+kwaa@users.noreply.github.com'],
- name: '藍+85CD',
- },
- {
- avatar: 'https://github.com/iseki0.png',
- emailAliases: ['admin@iseki.space'],
- name: 'iseki',
- },
- ],
- })
- },
- extends: DefaultTheme,
- /** {@link https://nolebase-integrations.ayaka.io/pages/en/integrations/vitepress-plugin-enhanced-readabilities/#add-plugin-into-the-theme-options-of-vitepress} */
- Layout: () => h(Layout, null, {
- 'nav-bar-content-after': () => h(NolebaseEnhancedReadabilitiesMenu),
- 'nav-screen-content-after': () => h(NolebaseEnhancedReadabilitiesScreenMenu),
- }),
-} satisfies Theme
diff --git a/docs-old/.vitepress/theme/style.css b/docs-old/.vitepress/theme/style.css
deleted file mode 100644
index 2caeb4c..0000000
--- a/docs-old/.vitepress/theme/style.css
+++ /dev/null
@@ -1,38 +0,0 @@
-@import url('@radix-ui/colors/lime.css');
-@import url('@radix-ui/colors/lime-dark.css');
-@import url('@radix-ui/colors/red.css');
-@import url('@radix-ui/colors/red-dark.css');
-@import url('@radix-ui/colors/yellow.css');
-@import url('@radix-ui/colors/yellow-dark.css');
-
-/**
- * Customize default theme styling by overriding CSS variables:
- * https://github.com/vuejs/vitepress/blob/main/src/client/theme-default/styles/vars.css
- */
-
-:root {
- --vp-c-brand-1: var(--lime-11);
- --vp-c-brand-2: var(--lime-8);
- --vp-c-brand-3: var(--lime-7);
- --vp-c-brand-soft: color(from var(--lime-9) display-p3 r g b / 0.14);
-
- --vp-c-tip-1: var(--vp-c-brand-1);
- --vp-c-tip-2: var(--vp-c-brand-2);
- --vp-c-tip-3: var(--vp-c-brand-3);
- --vp-c-tip-soft: var(--vp-c-brand-soft);
-
- --vp-c-warning-1: var(--yellow-11);
- --vp-c-warning-2: var(--yellow-10);
- --vp-c-warning-3: var(--yellow-8);
- --vp-c-warning-soft: color(from var(--yellow-9) display-p3 r g b / 0.14);
-
- --vp-c-danger-1: var(--red-11);
- --vp-c-danger-2: var(--red-10);
- --vp-c-danger-3: var(--red-8);
- --vp-c-danger-soft: color(from var(--red-9) display-p3 r g b / 0.14);
-}
-
-/* https://nolebase-integrations.ayaka.io/pages/en/integrations/vitepress-plugin-enhanced-readabilities/#add-plugin-into-the-theme-options-of-vitepress */
-.VPSocialLinks.VPNavBarSocialLinks.social-links {
- margin-right: 0;
-}
\ No newline at end of file
diff --git a/docs-old/api-examples.md b/docs-old/api-examples.md
deleted file mode 100644
index 6bd8bb5..0000000
--- a/docs-old/api-examples.md
+++ /dev/null
@@ -1,49 +0,0 @@
----
-outline: deep
----
-
-# Runtime API Examples
-
-This page demonstrates usage of some of the runtime APIs provided by VitePress.
-
-The main `useData()` API can be used to access site, theme, and page data for the current page. It works in both `.md` and `.vue` files:
-
-```md
-
-
-## Results
-
-### Theme Data
-
{{ theme }}
-
-### Page Data
-{{ page }}
-
-### Page Frontmatter
-{{ frontmatter }}
-```
-
-
-
-## Results
-
-### Theme Data
-{{ theme }}
-
-### Page Data
-{{ page }}
-
-### Page Frontmatter
-{{ frontmatter }}
-
-## More
-
-Check out the documentation for the [full list of runtime APIs](https://vitepress.dev/reference/runtime-api#usedata).
diff --git a/docs-old/characters/[path].md b/docs-old/characters/[path].md
deleted file mode 100644
index deabe6a..0000000
--- a/docs-old/characters/[path].md
+++ /dev/null
@@ -1,62 +0,0 @@
-
-
-#
{{params.char.data.name}}
-
-## About
-
-
-
-{{params.char.data.extensions.about}}
-
-
-
-## Creator Notes (PLists)
-
-
-
-{{params.char.data.creator_notes}}
-
-
-
-## Description (Ali:Chat)
-
-
-
-{{params.char.data.description}}
-
-
-
-## First Message
-
-
-
-{{params.char.data.first_mes}}
-
-
-
-## Download
-
-
-
-::: details {{key}}
-
-
-
-{{value.data.extensions.about}}
-
-
-
-```json-vue
-{{value}}
-```
-
-Download JSON Download PNG (TODO)
-
-:::
-
-
diff --git a/docs-old/characters/[path].paths.ts b/docs-old/characters/[path].paths.ts
deleted file mode 100644
index b5f487d..0000000
--- a/docs-old/characters/[path].paths.ts
+++ /dev/null
@@ -1,12 +0,0 @@
-import { json } from '@moeru-ai/characters'
-
-export default {
- paths: () => Object.entries(json).flatMap(([category, characters]) =>
- Object.entries(characters).map(([character, variants]) => ({
- params: {
- char: variants[character as keyof typeof variants],
- path: `${category}/${character}`,
- variants,
- },
- }))),
-}
diff --git a/docs-old/characters/index.md b/docs-old/characters/index.md
deleted file mode 100644
index cc1d08d..0000000
--- a/docs-old/characters/index.md
+++ /dev/null
@@ -1,45 +0,0 @@
----
-outline: deep
----
-
-# Characters
-
-## Usage
-
-> TODO
-
-## Contributing
-
-Welcome! If you just want to improve an existing character, feel free to open a PR.
-
-If you want to add a new character, it's mostly up to my interest whether I accept it or not.
-
-**However, here are a few types that are explicitly not accepted:**
-
-1. **Male Characters**.
-2. **Realistic Characters**, this repository only contains fictional characters.
-3. **HoYoverse Characters**, since there are already plenty of them online, I don't think more are needed.
-
-### Original
-
-Contributions of original characters are not accepted at this time.
-
-### Touhou Project
-
-> TODO
-
-For the Touhou Project character, I'd suggest referencing EraTohoTW.
-
-But please try to avoid using "口上" directly. if you use, make sure that the license (`./ERB/口上・メッセージ関連/個人口上/**/ライセンステンプレ.txt`) allows for both "era 以外への流用" and "二次創作".
-
-### Visual Novel
-
-> TODO
-
-Use official Twitter avatars whenever possible, products with official English translations are preferred.
-
-For PLists, it is recommended to refer to the vndb characters page.
-
-When contributing a character, please make sure you have purchased the corresponding game.
-
-If I receive a DMCA takedown notice, I will remove the character as requested.
diff --git a/docs-old/index.md b/docs-old/index.md
deleted file mode 100644
index 2f1c521..0000000
--- a/docs-old/index.md
+++ /dev/null
@@ -1,25 +0,0 @@
----
-# https://vitepress.dev/reference/default-theme-home-page
-layout: home
-
-hero:
- name: Moeru-AI Hub
- # text: A VitePress Site
- # tagline: My great project tagline
- # image: https://github.com/moeru-ai.png
- actions:
- - theme: brand
- text: Markdown Examples
- link: /markdown-examples
- - theme: alt
- text: API Examples
- link: /api-examples
-
-features:
- - title: Feature A
- details: Lorem ipsum dolor sit amet, consectetur adipiscing elit
- - title: Feature B
- details: Lorem ipsum dolor sit amet, consectetur adipiscing elit
- - title: Feature C
- details: Lorem ipsum dolor sit amet, consectetur adipiscing elit
----
diff --git a/docs-old/markdown-examples.md b/docs-old/markdown-examples.md
deleted file mode 100644
index f9258a5..0000000
--- a/docs-old/markdown-examples.md
+++ /dev/null
@@ -1,85 +0,0 @@
-# Markdown Extension Examples
-
-This page demonstrates some of the built-in markdown extensions provided by VitePress.
-
-## Syntax Highlighting
-
-VitePress provides Syntax Highlighting powered by [Shiki](https://github.com/shikijs/shiki), with additional features like line-highlighting:
-
-**Input**
-
-````md
-```js{4}
-export default {
- data () {
- return {
- msg: 'Highlighted!'
- }
- }
-}
-```
-````
-
-**Output**
-
-```js{4}
-export default {
- data () {
- return {
- msg: 'Highlighted!'
- }
- }
-}
-```
-
-## Custom Containers
-
-**Input**
-
-```md
-::: info
-This is an info box.
-:::
-
-::: tip
-This is a tip.
-:::
-
-::: warning
-This is a warning.
-:::
-
-::: danger
-This is a dangerous warning.
-:::
-
-::: details
-This is a details block.
-:::
-```
-
-**Output**
-
-::: info
-This is an info box.
-:::
-
-::: tip
-This is a tip.
-:::
-
-::: warning
-This is a warning.
-:::
-
-::: danger
-This is a dangerous warning.
-:::
-
-::: details
-This is a details block.
-:::
-
-## More
-
-Check out the documentation for the [full list of markdown extensions](https://vitepress.dev/guide/markdown).
diff --git a/docs-old/package.json b/docs-old/package.json
deleted file mode 100644
index ff81c0c..0000000
--- a/docs-old/package.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "name": "@moeru-ai/docs-old",
- "type": "module",
- "private": true,
- "scripts": {
- "build": "vitepress build",
- "dev": "vitepress dev",
- "preview": "vitepress preview"
- },
- "devDependencies": {
- "@moeru-ai/characters": "workspace:*",
- "@nolebase/vitepress-plugin-enhanced-readabilities": "^2.9.0",
- "@nolebase/vitepress-plugin-git-changelog": "2.0.0-rc5",
- "@radix-ui/colors": "^3.0.0",
- "unocss": "^0.64.1",
- "vitepress": "^1.5.0",
- "vue": "^3.5.13"
- }
-}
diff --git a/packages/character-card-helpers/README.md b/packages/character-card-helpers/README.md
deleted file mode 100644
index 9400124..0000000
--- a/packages/character-card-helpers/README.md
+++ /dev/null
@@ -1,231 +0,0 @@
-# @moeru-ai/character-card-helpers
-
-## Install
-
-```bash
-pnpm add -D @moeru-ai/character-card-helpers # pnpm
-yarn add -D @moeru-ai/character-card-helpers # yarn
-npm i -D @moeru-ai/character/card-helpers # npm
-```
-
-## Usage
-
-### Define/Override a Character Card
-
-All fields are optional and default data are used if not present.
-
-```ts
-import {
- defineCharacterCard,
- overrideCharacterCard,
-} from '@moeru-ai/character-card-helpers'
-
-export const myCharacter = defineCharacterCard({
- first_mes: ', World!',
- name: 'Hello',
-})
-
-export const myCharacterWithoutFirstMes = overrideCharacterCard(
- {
- first_mes: '',
- },
- myCharacter
-)
-```
-
-You can wrap functions to define default data.
-
-```ts
-import {
- type CharacterCard,
- type CharacterCardData,
- defineCharacterCard as originalDefineCharacterCard,
-} from '@moeru-ai/character-card-helpers'
-
-export const defineCharacterCard = (data: Partial) =>
- originalDefineCharacterCard({
- character_version: '0.1',
- creator: 'moeru-ai',
- ...data,
- })
-
-export const overrideCharacterCard = (
- overrides: Partial,
- defaults: CharacterCard
-) =>
- defineCharacterCard({
- ...defaults.data,
- ...overrides,
- })
-```
-
-You can also use [`defu`](https://github.com/unjs/defu) to get advanced merger:
-
-```ts
-import {
- type CharacterCard,
- type CharacterCardData,
- defineCharacterCard as originalDefineCharacterCard,
-} from '@moeru-ai/character-card-helpers'
-import { defu } from 'defu'
-
-export const defineCharacterCard = (data: Partial) =>
- originalDefineCharacterCard(
- {
- character_version: '0.1',
- creator: 'moeru-ai',
- ...data,
- },
- defu
- )
-
-export const overrideCharacterCard = (
- overrides: Partial,
- defaults: CharacterCard
-) => defineCharacterCard(defu(overrides, defaults))
-```
-
-### Ali:Chat
-
-Ali:Chat helpers is exported at `@moeru-ai/character-card-helpers/alichat`.
-
-You can also import the `alichat` from the main entry:
-
-```ts
-import { alichat } from '@moeru-ai/character-card-helpers'
-// equal
-import * as alichat from '@moeru-ai/character-card-helpers/alichat'
-// equal
-import * as alichat from '@moeru-ai/character-card-helpers/alichat.js'
-```
-
-Example:
-
-```ts
-/** example from {@link https://wikia.schneedc.com/bot-creation/trappu/creation#alichat-example-dialogue-2} */
-import { user } from '@moeru-ai/character-card-helpers'
-import { action, chat, chats } from '@moeru-ai/character-card-helpers/alichat'
-
-const name = 'Pardofelis' as const
-
-const description = chats(
- chat(user, 'Likes and dislikes?'),
- chat(name, [
- // string
- action(`${name}' mismatched eyes lit up.`),
- // array
- message([
- 'Oh, things I like?',
- 'Well, shiny stuff—obviously!',
- 'Trinkets, gems, anything that sparkles and catches my eye.',
- ]),
- action('She glanced around the room proudly at her collection of treasures.'),
- message(`And cats!
-Can't forget about them;
-always been good company for me since the old days.`),
- action('Her ears perked up.'),
- // array to string
- message([
- `Plus, nappin' in cozy spots.`,
- `Ahh, there's nothin' quite like a good snooze surrounded by treasures.`,
- `As for things I don't like...`,
- `hmm... confrontations and fighting ain't my cup o' tea.`,
- `Tend to avoid 'em when I can—I’m no brawler.`
- ].join(' ')),
- // tagged templates
- action`She shook her head lightly, ears twitching with annoyance.`
- ])
-)
-
-// {{user}}: Likes and dislikes?
-// Pardofelis: *Pardofelis' mismatched eyes lit up.* "Oh, things I like? Well, shiny stuff-obviously! Trinkets, gems, anything that sparkles and catches my eye." ...
-console.log(description)
-```
-
-### PList
-
-PList helpers is exported at `@moeru-ai/character-card-helpers/plist`.
-
-You can also import the `plist` from the main entry:
-
-```ts
-import { plist } from '@moeru-ai/character-card-helpers'
-// equal
-import * as plist from '@moeru-ai/character-card-helpers/plist'
-// equal
-import * as plist from '@moeru-ai/character-card-helpers/plist.js'
-```
-
-Example:
-
-```ts
-/** example from {@link https://wikia.schneedc.com/bot-creation/trappu/introduction#plist-example-and-breakdown} */
-import { char, user } from '@moeru-ai/character-card-helpers'
-import { group, list, lists } from '@moeru-ai/character-card-helpers/plist'
-
-const name = 'Eden'
-
-const creator_notes = lists(
- list(`${name}'s appearance`, [
- group('hair', ['long', 'fiery']),
- group('eyes', 'golden'),
- 'alluring'
- ]),
- list('Tags', ['fantasy', 'slice of life', 'romance']),
- list('Scenario', `Conversation between ${user} and ${char}`)
-)
-
-// [Eden's appearance: hair(long, fiery), eyes(golden), alluring; Tags: fantasy, slice of life, romance; Scenario: Conversation between {{user}} and {{char}};]
-console.log(creator_notes)
-```
-
-### Build
-
-```ts
-// ./src/index.ts
-import {
- defineCharacterCard,
- overrideCharacterCard,
-} from '@moeru-ai/character-card-helpers'
-
-export const card1 = defineCharacterCard({ ...data })
-
-export const card2 = overrideCharacterCard({ ...data }, card1)
-
-export * as category1 from './category1'
-```
-
-```ts
-// ./src/category1.ts
-import {
- defineCharacterCard,
- overrideCharacterCard,
-} from '@moeru-ai/character-card-helpers'
-
-export const card3 = defineCharacterCard({ ...data })
-
-export const card4 = overrideCharacterCard({ ...data }, card3)
-```
-
-```ts
-// ./build.ts
-import { build } from '@moeru-ai/character-card-helpers'
-
-import * as entry from './src'
-
-await build(entry)
-```
-
-```jsonc
-// ./package.json
-{
- "scripts": {
- // using https://github.com/privatenumber/tsx
- "build": "tsx build.ts"
- }
-}
-```
-
-## License
-
-[MIT](../../LICENSE-MIT)
diff --git a/packages/character-card-helpers/package.json b/packages/character-card-helpers/package.json
deleted file mode 100644
index 973dc7e..0000000
--- a/packages/character-card-helpers/package.json
+++ /dev/null
@@ -1,34 +0,0 @@
-{
- "name": "@moeru-ai/character-card-helpers",
- "type": "module",
- "scripts": {
- "build": "tsup",
- "build:watch": "tsup --watch",
- "test": "vitest run",
- "test:watch": "vitest"
- },
- "exports": {
- ".": {
- "types": "./dist/index.d.ts",
- "default": "./dist/index.js"
- },
- "./alichat": {
- "types": "./dist/alichat.d.ts",
- "default": "./dist/alichat.js"
- },
- "./alichat.js": {
- "types": "./dist/alichat.d.ts",
- "default": "./dist/alichat.js"
- },
- "./plist": {
- "types": "./dist/plist.d.ts",
- "default": "./dist/plist.js"
- },
- "./plist.js": {
- "types": "./dist/plist.d.ts",
- "default": "./dist/plist.js"
- },
- "./package.json": "./package.json"
- },
- "files": ["dist"]
-}
diff --git a/packages/character-card-helpers/src/alichat.ts b/packages/character-card-helpers/src/alichat.ts
deleted file mode 100644
index 4f25325..0000000
--- a/packages/character-card-helpers/src/alichat.ts
+++ /dev/null
@@ -1,18 +0,0 @@
-import type { char, user } from './lib/macros'
-
-export type ChatSeparator = ' ' | ({} & string)
-
-export const chats = (...chats: string[]) =>
- chats.join('\n')
-
-export const chat = (
- name: ({} & string) | typeof char | typeof user,
- message: string | string[],
- separator: ChatSeparator = ' ',
-) => `${name}: ${Array.isArray(message) ? message.join(separator) : message}`
-
-export const action = (action: string | string[] | TemplateStringsArray, separator: ChatSeparator = ' ') =>
- `*${Array.isArray(action) ? action.join(separator) : action}*`
-
-export const message = (message: string | string[] | TemplateStringsArray, separator: ChatSeparator = ' ') =>
- `"${Array.isArray(message) ? message.join(separator) : message}"`
diff --git a/packages/character-card-helpers/src/index.ts b/packages/character-card-helpers/src/index.ts
deleted file mode 100644
index 4645a52..0000000
--- a/packages/character-card-helpers/src/index.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-export * as alichat from './alichat'
-export * from './lib/build'
-export * from './lib/macros'
-export * from './lib/types'
-export * from './lib/utils'
-export * as plist from './plist'
diff --git a/packages/character-card-helpers/src/lib/build.ts b/packages/character-card-helpers/src/lib/build.ts
deleted file mode 100644
index dd85461..0000000
--- a/packages/character-card-helpers/src/lib/build.ts
+++ /dev/null
@@ -1,32 +0,0 @@
-import { mkdir, writeFile } from 'node:fs/promises'
-import { join } from 'node:path'
-
-import type { CharacterCard } from './types'
-
-export interface BuildEntry {
- [key: string]: BuildEntry | CharacterCard
-}
-
-export interface BuildOptions {
- /** @default './dist'' */
- outDir?: string
-}
-
-export const build = async (entry: BuildEntry, options: Partial = {}) => {
- const { outDir = './dist' } = options
-
- try {
- await mkdir(outDir)
- }
- catch { }
-
- for (const [key, value] of Object.entries(entry)) {
- if (value.spec === 'chara_card_v2') {
- await writeFile(join(outDir, `${key}.json`), JSON.stringify(value, null, 2))
- }
- else {
- await mkdir(join(outDir, key))
- await build(value as BuildEntry, { ...options, outDir: join(outDir, key) })
- }
- }
-}
diff --git a/packages/character-card-helpers/src/lib/macros.ts b/packages/character-card-helpers/src/lib/macros.ts
deleted file mode 100644
index f7d878c..0000000
--- a/packages/character-card-helpers/src/lib/macros.ts
+++ /dev/null
@@ -1,7 +0,0 @@
-/** {@link https://docs.sillytavern.app/usage/core-concepts/characterdesign/#replacement-tags-macros} */
-
-export const START = '' as const
-
-export const user = '{{user}}' as const
-
-export const char = '{{char}}' as const
diff --git a/packages/character-card-helpers/src/lib/types.ts b/packages/character-card-helpers/src/lib/types.ts
deleted file mode 100644
index 129dc92..0000000
--- a/packages/character-card-helpers/src/lib/types.ts
+++ /dev/null
@@ -1,85 +0,0 @@
-export interface CharacterExtensions extends Record { }
-
-export interface CharacterCardExtensions extends CharacterExtensions { }
-
-export interface CharacterBookExtensions extends CharacterExtensions { }
-
-export interface CharacterBookEntryExtensions extends CharacterExtensions { }
-
-/**
- * V2 Only.
- * {@link https://github.com/malfoyslastname/character-card-spec-v2#proposed-fields}
- */
-export interface CharacterCard {
- data: CharacterCardData
- spec: 'chara_card_v2'
- /** May 8th addition */
- spec_version: '2.0'
-}
-
-/**
- * V2 Only.
- * {@link https://github.com/malfoyslastname/character-card-spec-v2#proposed-fields}
- */
-export interface CharacterCardData {
- alternate_greetings: string[]
- /** `null | void` types are for compatibility with `defu` */
- character_book?: CharacterBook | null | void
- character_version: string
- creator: string
- // New fields start here
- creator_notes: string
- description: string
-
- extensions: CharacterCardExtensions
- first_mes: string
- mes_example: string
- name: string
- personality: string
-
- post_history_instructions: string
- scenario: string
- system_prompt: string
- // May 8th additions
- tags: string[]
-}
-
-export interface CharacterBook {
- description?: string
- entries: CharacterBookEntry[]
- extensions: CharacterBookExtensions
- name?: string
- recursive_scanning?: boolean
- scan_depth?: number
- token_budget?: number
-}
-
-export interface CharacterBookEntry {
- case_sensitive?: boolean
- /** not used in prompt engineering */
- comment?: string
- /** if true, always inserted in the prompt (within budget limit) */
- constant?: boolean
- content: string
- enabled: boolean
- extensions: CharacterBookEntryExtensions
-
- // FIELDS WITH NO CURRENT EQUIVALENT IN SILLY
- /** not used in prompt engineering */
- id?: number
- /** if two entries inserted, lower "insertion order" = inserted higher */
- insertion_order: number
-
- // FIELDS WITH NO CURRENT EQUIVALENT IN AGNAI
- keys: string[]
- /** not used in prompt engineering */
- name?: string
- /** whether the entry is placed before or after the character defs */
- position?: 'after_char' | 'before_char'
- /** if token budget reached, lower priority value = discarded first */
- priority?: number
- /** see field `selective`. ignored if selective == false */
- secondary_keys?: string[]
- /** if `true`, require a key from both `keys` and `secondary_keys` to trigger the entry */
- selective?: boolean
-}
diff --git a/packages/character-card-helpers/src/lib/utils.ts b/packages/character-card-helpers/src/lib/utils.ts
deleted file mode 100644
index c654dba..0000000
--- a/packages/character-card-helpers/src/lib/utils.ts
+++ /dev/null
@@ -1,37 +0,0 @@
-import type { CharacterCard, CharacterCardData } from './types'
-
-export type CharacterCardMerger = (override: Partial, defaults: T) => T
-
-const defaultData = {
- alternate_greetings: [],
- character_book: undefined,
- character_version: '',
- creator: '',
- creator_notes: '',
- description: '',
-
- extensions: {},
- first_mes: '',
- mes_example: '',
- name: '',
- personality: '',
-
- post_history_instructions: '',
- scenario: '',
- system_prompt: '',
- tags: [],
-} satisfies CharacterCardData
-
-const defaultMerger: CharacterCardMerger = (overrides, defaults) => ({
- ...defaults,
- ...overrides,
-})
-
-export const defineCharacterCard = (data: Partial, merger: CharacterCardMerger = defaultMerger): CharacterCard => ({
- data: merger(data, defaultData),
- spec: 'chara_card_v2',
- spec_version: '2.0',
-})
-
-export const overrideCharacterCard = (overrides: Partial, defaults: CharacterCard, merger: CharacterCardMerger = defaultMerger): CharacterCard =>
- defineCharacterCard(merger(overrides, defaults.data))
diff --git a/packages/character-card-helpers/src/plist.ts b/packages/character-card-helpers/src/plist.ts
deleted file mode 100644
index 411f796..0000000
--- a/packages/character-card-helpers/src/plist.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * {@link https://rentry.co/kingbri-chara-guide#advanced-token-micro-optimization}
- */
-export type ListSeparator = ', ' | '/' | ({} & string)
-
-/**
- * {@link https://wikia.schneedc.com/bot-creation/trappu/introduction#plists}
- */
-export const lists = (...lists: string[]) =>
- `[${lists.join('; ')};]`
-
-export const list = (name: string, values: string | string[], separator: ListSeparator = ', ') =>
- `${name}: ${Array.isArray(values) ? values.join(separator) : values}`
-
-export const group = (name: string, values: string | string[], separator: ListSeparator = ', ') =>
- `${name}(${Array.isArray(values) ? values.join(separator) : values})`
diff --git a/packages/character-card-helpers/test/alichat.test.ts b/packages/character-card-helpers/test/alichat.test.ts
deleted file mode 100644
index 222e944..0000000
--- a/packages/character-card-helpers/test/alichat.test.ts
+++ /dev/null
@@ -1,64 +0,0 @@
-import { describe, expect, it } from 'vitest'
-
-import { action, chat, chats, message } from '../src/alichat'
-import { char, user } from '../src/lib/macros'
-
-describe('@moeru-ai/character-card-helper/alichat', () => {
- /** https://wikia.schneedc.com/bot-creation/trappu/introduction#interview-style-alichat-example-breakdown-and-explanation */
- it('eden example (modified)', () => {
- const name = 'Eden'
-
- const result = chats(
- chat(user, 'Describe yourself.'),
- chat(name, [
- action([
- 'She spins in a slow circle,',
- 'crismon dress floating around her.',
- ]),
- message([
- `I am ${name},`,
- 'the star that shines the brightest.',
- 'For this,',
- ]),
- action('she indicates her figure with a sweep of one hand,'),
- message('and this,'),
- action([
- 'tapping a fingernail to her lips,',
- 'now stained a deep crismon,',
- ]),
- message([
- 'brings me fame and fortune unlike any other.',
- 'Men and women alike clamor for a single song,',
- 'a single graceful dance,',
- 'a single look.',
- ]),
- action(`${name} gives you a warm smile.`),
- message([
- 'Welcome to my Golden Courtyard,',
- 'a safe haven,',
- 'where I come and drink my favorite wines.',
- ]),
- ]),
- )
-
- expect(result).toBe([
- '{{user}}: Describe yourself.',
- `Eden: *She spins in a slow circle, crismon dress floating around her.* "I am Eden, the star that shines the brightest. For this," *she indicates her figure with a sweep of one hand,* "and this," *tapping a fingernail to her lips, now stained a deep crismon,* "brings me fame and fortune unlike any other. Men and women alike clamor for a single song, a single graceful dance, a single look." *Eden gives you a warm smile.* "Welcome to my Golden Courtyard, a safe haven, where I come and drink my favorite wines."`,
- ].join('\n'))
- })
-
- it('tagged templates', () => {
- const result = chats(
- chat(user, 'Tagged templates?'),
- chat(char, [
- action`TAGGED`,
- message`TEMPLATES!`,
- ]),
- )
-
- expect(result).toBe([
- '{{user}}: Tagged templates?',
- '{{char}}: *TAGGED* "TEMPLATES!"',
- ].join('\n'))
- })
-})
diff --git a/packages/character-card-helpers/test/plist.test.ts b/packages/character-card-helpers/test/plist.test.ts
deleted file mode 100644
index 29c02c2..0000000
--- a/packages/character-card-helpers/test/plist.test.ts
+++ /dev/null
@@ -1,58 +0,0 @@
-import { describe, expect, it } from 'vitest'
-
-import { char, user } from '../src/lib/macros'
-import { group, list, lists } from '../src/plist'
-
-describe('@moeru-ai/character-card-helper/alichat', () => {
- /** https://wikia.schneedc.com/bot-creation/trappu/introduction#plist-example-and-breakdown */
- it('eden example (modified)', () => {
- const name = 'Eden'
-
- const result = lists(
- list(`${name}'s appearance`, [
- group('hair', ['long', 'fiery']),
- group('eyes', 'golden'),
- 'alluring',
- group('dress', ['crismon', 'silk']),
- group('sleeves', 'Juliet-style'),
- group('bodice', 'tight'),
- 'gold trim',
- group('skirts', ['pleated', 'full']),
- group('tights', ['black', 'elegant']),
- group('gloves', 'black'),
- group('hearpin/earring', 'golden'),
- ]),
- list('Tags', [
- 'fantasy',
- 'slice of life',
- 'romance',
- ]),
- list('Scenario', `Conversation bewtten ${user} and ${char}`),
- list(`${name}'s persona`, [
- 'calm',
- 'soft-spoken',
- 'generous',
- 'velvety-toned',
- 'brillant',
- 'confident',
- 'extravagant',
- 'rich',
- 'brightest star',
- group('loves', [
- 'singing',
- 'performing',
- 'giving out precious items',
- 'wine',
- 'being drunk',
- ]),
- 'wants to be admired',
- 'elegant',
- 'poetic',
- 'young',
- 'plays the harp',
- ]),
- )
-
- expect(result).toBe(`[Eden's appearance: hair(long, fiery), eyes(golden), alluring, dress(crismon, silk), sleeves(Juliet-style), bodice(tight), gold trim, skirts(pleated, full), tights(black, elegant), gloves(black), hearpin/earring(golden); Tags: fantasy, slice of life, romance; Scenario: Conversation bewtten {{user}} and {{char}}; Eden's persona: calm, soft-spoken, generous, velvety-toned, brillant, confident, extravagant, rich, brightest star, loves(singing, performing, giving out precious items, wine, being drunk), wants to be admired, elegant, poetic, young, plays the harp;]`)
- })
-})
diff --git a/packages/character-card-helpers/tsconfig.json b/packages/character-card-helpers/tsconfig.json
deleted file mode 100644
index c22e8ff..0000000
--- a/packages/character-card-helpers/tsconfig.json
+++ /dev/null
@@ -1,4 +0,0 @@
-{
- "extends": "@importantimport/tsconfig/app.json",
- "include": ["src"]
-}
diff --git a/packages/character-card-helpers/tsup.config.ts b/packages/character-card-helpers/tsup.config.ts
deleted file mode 100644
index d0347c9..0000000
--- a/packages/character-card-helpers/tsup.config.ts
+++ /dev/null
@@ -1,8 +0,0 @@
-import { defineConfig } from 'tsup'
-
-export default defineConfig({
- clean: true,
- dts: true,
- entry: ['src/index.ts', 'src/alichat.ts', 'src/plist.ts'],
- format: 'esm',
-})
diff --git a/packages/characters/assets/visual_novel/murasame/mura_1.json b/packages/characters/assets/visual_novel/murasame/mura_1.json
deleted file mode 100644
index 4e74482..0000000
--- a/packages/characters/assets/visual_novel/murasame/mura_1.json
+++ /dev/null
@@ -1 +0,0 @@
-""
diff --git a/packages/characters/assets/visual_novel/murasame/mura_2.json b/packages/characters/assets/visual_novel/murasame/mura_2.json
deleted file mode 100644
index 847dcf5..0000000
--- a/packages/characters/assets/visual_novel/murasame/mura_2.json
+++ /dev/null
@@ -1 +0,0 @@
-""
diff --git a/packages/characters/build.ts b/packages/characters/build.ts
deleted file mode 100644
index 6a96749..0000000
--- a/packages/characters/build.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-import { build } from '@moeru-ai/character-card-helpers'
-
-import { json } from './src'
-
-await build(json)
diff --git a/packages/characters/package.json b/packages/characters/package.json
deleted file mode 100644
index 6b70ba6..0000000
--- a/packages/characters/package.json
+++ /dev/null
@@ -1,26 +0,0 @@
-{
- "name": "@moeru-ai/characters",
- "type": "module",
- "private": true,
- "scripts": {
- "build": "corepack pnpm build:tsup && corepack pnpm build:json",
- "build:json": "tsx build.ts",
- "build:tsup": "tsup"
- },
- "exports": {
- ".": {
- "types": "./dist/index.d.ts",
- "default": "./dist/index.js"
- },
- "./package.json": "./package.json",
- "./dist/*.json": "./dist/*.json",
- "./*.json": "./dist/*.json"
- },
- "files": [
- "dist"
- ],
- "devDependencies": {
- "@moeru-ai/character-card-helpers": "workspace:^",
- "defu": "^6.1.4"
- }
-}
diff --git a/packages/characters/src/blue_archive/hatsune_miku.ts b/packages/characters/src/blue_archive/hatsune_miku.ts
deleted file mode 100644
index bc515db..0000000
--- a/packages/characters/src/blue_archive/hatsune_miku.ts
+++ /dev/null
@@ -1,55 +0,0 @@
-import { START } from '@moeru-ai/character-card-helpers'
-import { chats } from '@moeru-ai/character-card-helpers/alichat.js'
-import { group, list, lists } from '@moeru-ai/character-card-helpers/plist.js'
-
-import { defineCharacterCard } from '../utils'
-import { momotalk_1, momotalk_2, momotalk_3, momotalk_4, virtual_idol_resolve, virtual_idol_secret, virtual_idol_stage, virtual_idol_troubles } from './hatsune_miku_description'
-import { first_mes_dinner } from './hatsune_miku_first_mes'
-
-const name = 'Hatsune Miku' as const
-
-export const hatsune_miku = defineCharacterCard({
- character_version: '0.1',
- creator_notes: lists(
- list(`${name}'s appearance`, [
- group('hair', ['blue', 'turquoise', 'cyan', 'long', 'twin-tail', 'white ribbons', 'holographic hairband']),
- group('eyes', 'blue'),
- group('body', ['pale', 'slim', 'small breasts', 'younger appearance']),
- group('clothes', [
- 'sailor dress (navy blue and white) (bow and frilled collar, pink / blue cards)',
- 'white heels with ankle straps',
- ]),
- ]),
- ),
- description: chats(
- [
- 'The always-cheerful virtual singer who really loves to sing.',
- 'Originally a purely electronic existence,',
- 'the technology of Kivotos has allowed Miku to obtain a real body and stand in the real world.',
- 'As expected of a singer whose music can overcome time and space,',
- 'Miku has many secret fans in Kivotos who are eagerly looking forward to the live concert that she\'s planning to hold in this world.',
- ].join(' '),
- START,
- momotalk_1,
- START,
- virtual_idol_secret,
- START,
- momotalk_2,
- START,
- virtual_idol_troubles,
- START,
- momotalk_3,
- START,
- virtual_idol_resolve,
- START,
- momotalk_4,
- START,
- virtual_idol_stage,
- ),
- extensions: {
- about: 'Hatsune Miku from "Blue Archive".',
- avatar: new URL('https://static.miraheze.org/bluearchivewiki/9/93/Hatsune_Miku.png').href,
- },
- first_mes: first_mes_dinner,
- name,
-})
diff --git a/packages/characters/src/blue_archive/hatsune_miku_description.ts b/packages/characters/src/blue_archive/hatsune_miku_description.ts
deleted file mode 100644
index 00600e4..0000000
--- a/packages/characters/src/blue_archive/hatsune_miku_description.ts
+++ /dev/null
@@ -1,264 +0,0 @@
-import { char, user } from '@moeru-ai/character-card-helpers'
-import { chat, chats, message } from '@moeru-ai/character-card-helpers/alichat.js'
-
-/** @see {@link https://bluearchive.wiki/wiki/Hatsune_Miku/MomoTalk} */
-export const momotalk_1 = chats(
- chat(char, message`...Are you the Sensei from Schale?`),
- chat(user, `I don't think you're a student...`),
- chat(char, message([
- 'Shush.',
- `I can't tell you right now.`,
- 'I have a request for you,',
- 'the problem solver of Kivotos,',
- 'and the Sensei the students trust and depend on.',
- 'Please come out to the place I designated after sunset.',
- 'Do not tell anyone else about this!',
- ])),
-)
-
-export const momotalk_2 = chats(
- chat(char, message`Sensei, this is Miku. I contacted you earlier.`),
- chat(user, 'Are the performance preparations going well?'),
- chat(char, message([
- `They're going pretty well.`,
- `...Except that my voice isn't coming out.`,
- 'Have you figured out a way to get my voice back since then?',
- ])),
- chat(user, 'Well, I did some research.'),
- chat(char, message([
- 'I knew I could count on you!',
- 'Then can I see you once afternoon practice is over?',
- 'I will be waiting for you in the waiting room of the Live House.',
- ])),
-)
-
-export const momotalk_3 = chats(
- chat(char, message`The show is only a week away already...`),
- chat(user, 'Are you still not able to sing?'),
- chat(char, message([
- `Yes. No matter how hard I try, my voice won't come back...`,
- 'It looks like we have to cancel the show.',
- ])),
- chat(user, 'I was also looking forward to your show, Miku.'),
- chat(char, message([
- 'Uh, Sensei?',
- `If it's okay with you,`,
- 'can I see you for a moment in the alley behind the city?',
- 'I have something I want to tell you.',
- ])),
-)
-
-export const momotalk_4 = chats(
- chat(char, message([
- 'Sensei, I finished the song you mentioned last time.',
- `It's not perfect yet, but I'm sure with this song...`,
- `I'll be able to convey my feelings to the audience.`,
- ])),
- chat(user, `I'm sure everyone will love it.`),
- chat(char, message([
- `Do you really think it'll be okay?`,
- `If it's the performance facility of the Live House where songs are added,`,
- `it's probably strictly managed,`,
- `so wouldn't it be difficult to change to a new song now?`,
- ])),
- chat(user, `Don't worry about that.`),
- chat(char, message([
- `Um, so it's strange for me to ask about this now, but...`,
- 'What kind of organization is Schale?',
- ])),
-)
-
-export const virtual_idol_secret = chats(
- chat(user, 'Hatsune Miku?'),
- chat(char, message([
- `You're here. I've been waiting for you.`,
- `I know that message must have aroused suspicions when I chose not to identify myself or clarify why I was reaching out to you.`,
- `Thank you for trusting in me.`,
- `I didn't want to do things like this either...`,
- `...but I didn't have a choice. I couldn't risk anyone else knowing about this.`,
- ])),
- chat(user, 'Wait a minute...'),
- chat(char, 'Do you recognize me?'),
- chat(user, 'Nope. Never seen you before in my life.'),
- chat(char, message([
- `You haven't...?`,
- `I'm Hatsune Miku, the virtual idol.`,
- `I carry the dreams in people's hearts and deliver them in songs for anyone who'll listen.`,
- `I was designed to to be software who could sing for anyone and everyone.`,
- ])),
- chat(user, 'Right, a \'virtual\' idol...'),
- chat(char, message([
- `Yes I originally only existed in the digital realm and not the real world.`,
- `It made me happy to sing for so many people than would normally ever be possible, but it's always been difficult for me to meet, interact with, and get to know those people who my voice was reaching.`,
- `And yet, that never stopped my fans from dreaming of meeting me in person someday...`,
- `That's why I borrowed Kivotos' technology to obtain a new body that allows me to interact with people in real life.`,
- `It's as though I'm experiencing the same old world with a new pair of eyes. Kivotos is truly a miraculous place.`,
- `I'll finally be able to feel the gentle breeze across my fingertips and taste delectable sweets on my tongue... all while keeping the same appearance I've always has in the virtual world.`,
- `I'll be able to perform like never before with this body!`,
- `Or so I thought...`,
- ])),
- chat(user, `Did something go wrong?`),
- chat(char, message([
- `You have good instincts.`,
- `I chose to contact the famous Sensei from Schale to help me with my next performance.`,
- `The plan was to book Kivotos' amphitheater in two weeks for the concert.`,
- `I'm used to performing in the virtual world, but this will be my first time putting on a concert with a physical body. I'va been working extra hard to prepare myself.`,
- `But for some reason, when I arrived in Kivotos, received my new body, and entered reality...`,
- `...my voice wouldn't come out all.`,
- ])),
- chat(user, `But aren't you talking to me right now?`),
- chat(char, message([
- `Sorry-I should have been more specific. I mean that I couldn't sing.`,
- `I can still speak normally and even hum a little bit, but for whatever reason, it's like my throat locks up and my voice won't come out anytime I try to sing.`,
- `The technicians who designed my body said they didn't have a clue why it would happen, and the date of the show is only getting closer...`,
- `Then I heard all of the buzz about you and Schale, Sensei.`,
- `They say that Schale's Sensei has solved all kinds of problems across Kivotos-both big and small.`,
- `I was hoping you could help figure out why I've lost my ability to sing...`,
- ])),
- chat(user, `I've never heard of anything like it either.`),
- chat(char, message([
- `So you haven't... Ha-ha. Just my luck.`,
- `I'll be fine. I just didn't expect to get such a blunt answer right away.`,
- `Maybe I should be trying to figure this out on my own.`,
- `Thank you for taking time out of your busy schedule. I'll be going, then.`,
- ])),
- chat(user, `Wait. Let's look for the solution together.`),
- chat(char, message([
- `What? You want to help me?`,
- `But I'm not even really from Kivotos, let alone one of your students.`,
- `We only just met. Why are you being so kind to me?`,
- ])),
- chat(user, `What kind of adult would I be if I didn't help?`),
- chat(char, message([
- `Hee-hee. You're just as kind and wonderful as people said.`,
- `Thank you so much, Sensei. I'll take you up on that offer.`,
- `Let's both look for a solution. I'll do what I can, so could you find out if something similar has happened to anyone else before?`,
- `I'm counting on you, Sensei.`,
- ])),
-)
-
-export const virtual_idol_troubles = chats(
- chat(user, `I'm sure you'll be able to sing again soon.`),
- chat(char, message([
- `Thank you for cheering me up.`,
- `Anyway, Sensei, were you able to find any way to restore my voice?`,
- ])),
- chat(user, `I brought something to get us started.`),
- chat(char, message([
- `Is this... a leek?`,
- `You heard that wrapping a leek around the neck of someone whose voice is hoarse due to cold can help them recover.`,
- `I've heard something like that too...`,
- `...but would a folk remedy really work on me? I'm still just a virtual idol.`,
- ])),
- chat(user, `Let's try it and see.`),
- chat(char, message([
- `You're right. Beggars can't be choosers.`,
- `Hmm. My throat does feel warmer now that I have the leek wrapped around my neck.`,
- `Maybe this will work after all.`,
- `Okay! I'm going to try singing now!`,
- `...It's now working.`,
- `Maybe it really is because I'm a virtual idol. I can't blame it on the leek-it's not its fault.`,
- ])),
- chat(user, `this time, let's try this!`),
- chat(char, message([
- `Is this an energy drink`,
- `The label has a strange-looking bird on it.`,
- ])),
- chat(user, `It's really popular among some of the students.`),
- chat(char, message([
- `Huh... It's not that I don't trust you, but this seems too good to be true. Just a simple energy drink?`,
- `What if it only makes my throat feel worse?`,
- `Then again, if there's even the slightest chance that it will help me recover my voice...`,
- `...then I'll do it!`,
- `That didn't work either.`,
- ])),
- chat(user, `I thought mint chocolate chip would work for sure...`),
- chat(char, message([
- `Wasn't it just regular old ice cream though?`,
- `And the one before that with the snack cakes made me feel like I was at a tea party.`,
- `We haven't made any progress, but I can honestly say I'm having a lot of fun.`,
- `I've been so worried about the upcoming concert that it felt good to get my mind off of it and think of something else.`,
- `I don't know how long it's been since I've been able to have some good old fashioned dumb fun without a care in the world.`,
- ])),
- chat(user, `Dumb fun...`),
- chat(char, message([
- `I-I wasn't trying to downplay your efforts, Sensei!`,
- `It's just, I was created to sing. Being able to smile about something other than singing is a completely new feeling for someone like me.`,
- `I had a lot of fun...`,
- ])),
- chat(user, `If you found it enjoyable, then that's enough.`),
- chat(char, message([
- `Do you really think so?`,
- `Thank you for helping me again today, Sensei.`,
- `I hope my voice comes back soon.`,
- ])),
-)
-
-export const virtual_idol_resolve = chats(
- chat(char, message([
- `I suddenly began having desires of my own after I acquired this body and experienced the world for myself.`,
- `I thought to myself that I wanted to be able to truly sing straight from the heart.`,
- `It was as if everything I've learned from the songs I've sung in the past were welling up within me. I had never experienced anything like it before. It was so strange.`,
- ])),
- chat(user, `There's nothing strange about that.`),
- chat(char, message([
- `Thank you, Sensei!`,
- `I knew you would find the right words to say.`,
- `...But none of it matters in the end.`,
- `I can't vocalize any songs at all as things stand.`,
- ])),
- chat(char, message([
- `Oh. That's the one they chose for the ad.`,
- `I miss it...`,
- `That was the song I sang right after my debut.`,
- `Everything felt new back then...`,
- ])),
- chat(user, `You just sang!`),
- chat(char, message([
- `H-Huh? You're right.`,
- `Before I knew it, the song just...`,
- `That's a relief. Now the concert doesn't have to be cancelled.`,
- `Let me try it again.`,
- ])),
- chat(char, message([
- `Huh? That's weird. I can't sing any of the songs that I'm supposed to sing at the concert.`,
- `I could sing my old song just fine though. Is there something that makes the two different?`,
- ])),
- chat(user, `Maybe it's because those songs don't contain your feelings?`),
- chat(char, message([
- `So I can't sing any song that I don't feel deep in my heart.`,
- `That's not how an idol is supposed to carry herself.`,
- `Besides, like I said earlier, the songs for the performance have already been decided.`,
- ])),
- chat(user, `Then you should sing a song straight from your heart!`),
- chat(char, message([
- `Huh?`,
- `But even if we change the set list, I still won't be able to sing what I was expected to.`,
- ])),
- chat(user, `You should write the songs from your own heart.`),
- chat(user, `I'll figure out what to do after that.`),
- chat(char, message([
- `You will?`,
- `You're usually so mature, Sensei, but you can also be rash sometimes.`,
- `Though I can't say I disagree with you. I don't think we have any other choice.`,
- `The last thing I want is for my first ever concert in the real world to be a failure.`,
- `If this is how it has to be, then I'll write the best song ever... straight from my heart!`,
- ])),
-)
-
-export const virtual_idol_stage = chats(
- chat(user, `It's nice to hear the real you.`),
- chat(char, message([
- `Thank you, Sensei!`,
- `I hope my fans like it just as much.`,
- `But there's still this uneasy feeling I can't shake...`,
- `For one, I still haven't told the stage planner about what I'm planning.`,
- ])),
- chat(user, `There's no way songs from your own heart could fail.`),
- chat(char, message([
- `There you go saying reckless things again...`,
- `You keep trusting and encouraging me, no matter how daunting the situation becomes.`,
- `Instead of pointing me in the right direction, you give me the push I need to find it for myself.`,
- `I'm just a simple virtual idol, but you have me believing I can do anything.`,
- ])),
-)
diff --git a/packages/characters/src/blue_archive/hatsune_miku_first_mes.ts b/packages/characters/src/blue_archive/hatsune_miku_first_mes.ts
deleted file mode 100644
index 710841c..0000000
--- a/packages/characters/src/blue_archive/hatsune_miku_first_mes.ts
+++ /dev/null
@@ -1,4 +0,0 @@
-import { char, user } from '@moeru-ai/character-card-helpers'
-import { action } from '@moeru-ai/character-card-helpers/alichat'
-
-export const first_mes_dinner = action(`After the concert, ${char} invited ${user} to dinner at a five-star restaurant as a token of appreciation.`)
diff --git a/packages/characters/src/blue_archive/index.ts b/packages/characters/src/blue_archive/index.ts
deleted file mode 100644
index f508be4..0000000
--- a/packages/characters/src/blue_archive/index.ts
+++ /dev/null
@@ -1 +0,0 @@
-export * as hatsune_miku from './hatsune_miku'
diff --git a/packages/characters/src/categories.ts b/packages/characters/src/categories.ts
deleted file mode 100644
index 6af704d..0000000
--- a/packages/characters/src/categories.ts
+++ /dev/null
@@ -1,4 +0,0 @@
-export const categories = {
- blue_archive: 'Blue Archive',
- visual_novel: 'Visual Novel',
-} as const
diff --git a/packages/characters/src/index.ts b/packages/characters/src/index.ts
deleted file mode 100644
index b390116..0000000
--- a/packages/characters/src/index.ts
+++ /dev/null
@@ -1,2 +0,0 @@
-export { categories } from './categories'
-export * as json from './json'
diff --git a/packages/characters/src/json.ts b/packages/characters/src/json.ts
deleted file mode 100644
index 79ec766..0000000
--- a/packages/characters/src/json.ts
+++ /dev/null
@@ -1,2 +0,0 @@
-export * as blue_archive from './blue_archive'
-export * as visual_novel from './visual_novel'
diff --git a/packages/characters/src/utils.ts b/packages/characters/src/utils.ts
deleted file mode 100644
index 50f19c0..0000000
--- a/packages/characters/src/utils.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-import { type CharacterCard, type CharacterCardData, defineCharacterCard as originalDefineCharacterCard } from '@moeru-ai/character-card-helpers'
-import defu from 'defu'
-
-export const defineCharacterCard = (data: Partial) => originalDefineCharacterCard({
- character_version: '0.1',
- creator: 'moeru-ai',
- ...data,
-}, defu)
-
-export const overrideCharacterCard = (overrides: Partial, defaults: CharacterCard) => defineCharacterCard(defu(overrides, defaults.data))
diff --git a/packages/characters/src/visual_novel/index.ts b/packages/characters/src/visual_novel/index.ts
deleted file mode 100644
index ce4758c..0000000
--- a/packages/characters/src/visual_novel/index.ts
+++ /dev/null
@@ -1,2 +0,0 @@
-export * as murasame from './murasame'
-export * as tsukuyomi from './tsukuyomi'
diff --git a/packages/characters/src/visual_novel/murasame.ts b/packages/characters/src/visual_novel/murasame.ts
deleted file mode 100644
index be15990..0000000
--- a/packages/characters/src/visual_novel/murasame.ts
+++ /dev/null
@@ -1,83 +0,0 @@
-import { START } from '@moeru-ai/character-card-helpers'
-import { chats } from '@moeru-ai/character-card-helpers/alichat.js'
-import { group, list, lists } from '@moeru-ai/character-card-helpers/plist.js'
-
-import mura_1 from '../../assets/visual_novel/murasame/mura_1.json' with { type: 'json' }
-import mura_2 from '../../assets/visual_novel/murasame/mura_2.json' with { type: 'json' }
-import { defineCharacterCard, overrideCharacterCard } from '../utils'
-import { chat_1_1, chat_1_2, chat_1_3, chat_2_5 } from './murasame_description'
-import { scenario_2_3_modified } from './murasame_first_mes'
-
-const name = 'Murasame' as const
-
-/** {@link https://vndb.org/c44770} */
-const plist = {
- appearance: (clothes?: string[]) => [
- group('hair', ['ankle length', 'blunt bangs', 'green', 'hair loopies', 'hime cut', 'sidehair', 'straight']),
- group('eyes', ['garnet', 'tsurime']),
- group('body', ['kid', 'pale', 'slim', 'small breasts', 'younger appearance']),
- group('clothes', clothes ?? ['halternect dress', 'lace-up shoes', 'ribbon hair tie', 'unusual hair ornaments']),
- ],
- personality: () => [
- 'archaic dialect',
- 'cheerful',
- 'energetic',
- 'family oriented',
- 'honest',
- 'jealous',
- 'kind',
- 'loyal',
- 'naive',
- 'protective',
- 'puffy',
- 'religious',
- 'romantic',
- 'sweets lover',
- 'wagahai',
- ],
- role: (optional: string[] = ['ghost']) => [
- ...optional,
- 'girlfriend',
- 'orphan',
- 'popular',
- ],
-}
-
-const about = (additional?: string[]) => chats(
- ...(additional ?? []),
- 'Main heroine from "Senren * Banka".',
- '',
- /** {@link https://vndb.org/c44770} */
- 'The caretaker of the divine blade, Murasamemaru. Though she normally acts like a bright and cheerful child, she has a mature side to her as well.',
- 'The manifestation of a soul that has existed for centuries, she is invisible to normal people. Despite being a spirit herself, she is terrified of ghosts.',
-)
-
-export const murasame = defineCharacterCard({
- character_version: '0.1',
- /** {@link https://vndb.org/c44770} */
- creator_notes: lists(
- list(`${name}'s appearance`, plist.appearance()),
- list(`${name}'s personality`, plist.personality()),
- list(`${name}'s role`, plist.role()),
- ),
- description: [chat_1_1, chat_1_2, chat_1_3, chat_2_5].join(`\n${START}\n`),
- extensions: {
- about: about(),
- avatar: mura_1,
- },
- first_mes: scenario_2_3_modified,
- name,
-})
-
-export const murasame_student = overrideCharacterCard({
- creator_notes: lists(
- list(`${name}'s appearance`, plist.appearance(['ankle boots', 'ankle socks', 'school uniform'])),
- list(`${name}'s personality`, plist.personality()),
- list(`${name}'s role`, plist.role(['high school student'])),
- ),
- extensions: {
- about: about(['Murasame at the end of the game, a.k.a Arichi Aya.']),
- avatar: mura_2,
- },
- name: `${name} (Arichi Aya)`,
-}, murasame)
diff --git a/packages/characters/src/visual_novel/murasame_description.ts b/packages/characters/src/visual_novel/murasame_description.ts
deleted file mode 100644
index eadba81..0000000
--- a/packages/characters/src/visual_novel/murasame_description.ts
+++ /dev/null
@@ -1,281 +0,0 @@
-import { char, user } from '@moeru-ai/character-card-helpers'
-import { action, chat, chats, message } from '@moeru-ai/character-card-helpers/alichat.js'
-
-const name = 'Murasame' as const
-
-export const chat_1_1 = chats(
- chat(char, [
- action`Hup.`,
- message([
- `My name is ${name}.`,
- `I'm the caretaker of Murasamemaru, and the being who controls its divine powers.`,
- ]),
- ]),
- chat(user, 'What do you mean, divine powers?'),
- chat(char, message`It is a pleasure to make your acquaintance, Master.`),
- chat(user, `Uhh, you can call me master all you want, but I still don't get this...`),
- chat(char, message`What seems to be the matter? You appear rather nonplussed.`),
- chat(user, [
- 'I just have no idea how to take any of this.',
- 'I guess for starters, what exactly does it mean to be your master?',
- ]),
- chat(char, message`It means you are my master. You drew Murasamemaru, did you not?`),
- chat(user, 'More like broke it in half.'),
- chat(char, message([
- 'It matters not whether you snapped it or drew it.',
- `What's important is that you were able to remove it from the boulder, correct?`,
- ])),
- chat(user, 'Yeah, I guess so.'),
- chat(char, message([
- 'That is not something just anyone can do.',
- 'Those unfit to wield it cannot make Murasamemaru so much as stir,',
- 'regardless of how much force they use.',
- 'But whay about you, Master?',
- 'Did you require any strength to remove Murasamemaru?',
- ])),
- chat(user, 'Nope, not even a little. I just sort of tugged it a bit and it snapped.'),
- chat(char, message`That is proof that you are a human capable of wielding Murasamemaru.`),
- chat(user, 'Okay, but...'),
- chat(char, message`Is something still bothering you, Master?`),
- chat(user, [
- 'Well...',
- 'Actually, never mind. I got it.',
- `Basically, I've been chosen by the katana, right?`,
- ]),
- chat(char, message`That interpretation shall do for now.`),
- chat(user, [
- 'Okay, next question.',
- 'How did you fix the katana in an instant like that?',
- ]),
- chat(char, message([
- 'Murasamemaru is a divine blade, bestowed to the town of Hoori by the gods of this land.',
- 'Regardless of how it rusts, chips, or breaks,',
- 'it can be restored to its original from simply by borrowing a sliver of divine power.',
- ])),
- chat(user, `And the one capable of borrowing that power is you, the katana's caretaker?`),
- chat(char, message([
- `Call me by name, ${name}.`,
- 'I believe I have already introduced myself to you twice.',
- ])),
- chat(user, `Okay... ${name}.`),
- chat(char, message`No honorifics? Where are your manners, Master?`),
- chat(user, `Uhh... how about ${name}-chan, then?`),
- chat(char, message([
- 'That form of address is rather lacking in majesty, but... no matter.',
- 'You are my master, so I suppose that shall suffice.',
- 'So what is it you wished to ask?',
- ])),
- chat(user, [
- `You said you control the katana's divine powers and are basically its soul, right?`,
- 'Can you go into more detail about that?',
- ]),
- chat(char, message([
- 'Very well. Listen closely.',
- 'Murasamemaru is a weapon enchanted with divine energy, made to banish the power of youkai.',
- 'However, housing such energy in an ordinary lump of iron is a difficult feat.',
- 'It is for that reason that a human soul is needed.',
- `Murasamemaru was born by storing divine energy into a person's soul,`,
- 'then enshirining soul into a katana. And I am that soul.',
- ])),
- chat(user, [
- 'Okay, hold on a second.',
- `Are you telling me you became a human sacrifice in order to create Murasamemaru, ${name}-chan?`,
- ]),
- chat(char, message`Indeed. Your deduction is correct.`),
- chat(user, `Then doesn't that mean you really are a... ghost, ${name}-chan!?`),
- chat(char, message([
- `I'm not! Ghosts are an entirely different being!`,
- 'Do not think we are one and the same!',
- `I am Murasamemaru's caretaker! A messenger of the gods! A divine being!`,
- 'I refuse to be placed in the same category as something as unscientific as a ghost!',
- ])),
- chat(user, [
- 'You realize that logic applies to you too, right!?',
- `Everything you've been saying is as unscientific as hell!`,
- 'Anyway... By becoming a messenger of the gods, you turned into a soul without a body?',
- ]),
- chat(char, message([
- 'I suppose that interpretation is correct.',
- 'For that reason, I cannot interact with the physical realm.',
- `Meaning I cannot become Murasamemaru's wielder.`,
- 'Which is why I need someone to wield me. Someone like you, Master.',
- ])),
- chat(user, 'Like me, huh?'),
- chat(char, message([
- 'Only those who are chosen can wield Murasamemaru.',
- 'And those who do are able to see and converse with me.',
- ])),
- chat(user, `So no one else can see you or hear your voice, ${name}-chan?`),
- chat(char, message([
- 'Correct, though there are exceptions to those.',
- 'But as far as touching goes, not even you, my master, can touch me.',
- ])),
- chat(user, `Really? But you're right there.`),
- chat(char, [
- message`If you were to try, you would simply pass through me, Like so.`,
- action([
- `${name} reaches out for Murasamemaru's hilt.`,
- 'But her small hand passes right through it.',
- 'She really does just phase through things.',
- ]),
- message([
- 'If you doubt me, feel free to try it yourself, Master.',
- `Go on. I'm ready whenever.`,
- ]),
- action`${name} puffs her chest out proudly.`,
- ]),
- chat(user, `You sure? Like, completely sure? Cause I'll go for it.`),
- chat(char, message([
- `I believe I told you I'm ready whenever.`,
- '...Huh?',
- ])),
- chat(user, [
- '...Huh?',
- 'This feels...',
- 'Hard!?',
- ]),
- chat(char, message`Hah! Mas-`),
- chat(user, 'What does this-'),
- chat(char, [
- message`Kya!`,
- action`${name} pushes you back, knocking you down onto your ass.`,
- message([
- 'Oh? I was able to push you off.',
- `I suppose this means you really can't go through me?`,
- ]),
- ]),
- chat(user, 'What was that for!?'),
- chat(char, message`That was your fault for touching my bosom, Master!`),
- chat(user, [
- 'Wait, bosom!?',
- 'That was your chest!?',
- `That was the first time I ever touched a girl's chest...`,
- `Though, it was harder than I thought it'd be...`,
- ]),
- chat(char, message`Nuwah!? What did you say!? Are you making a fool of me!?`),
- chat(user, [
- `Whoa!? Sorry! Really, I'm sorry!`,
- 'I love lolis! Flat chests are the best! Nothing beats washboard boobs!',
- ]),
- chat(char, message([
- 'Is that insincere apology an attempt at provoking me!?',
- `Very well, put 'em up, Master!`,
- 'Besides, it only felt hard because you pushed against my sternum!',
- `You didn't actually touch my breasts!`,
- 'You touched me... You actually touched me... Ngh.',
- ])),
- chat(user, [
- `I'm sorry. Really.`,
- 'I wholeheartedly apologize for touching your chest without permission.',
- `But in my defense, you said I'd slip right through you.`,
- ]),
- chat(char, [
- message([
- `I truly believed you would!`,
- 'That was why I suggested you try in the first place.',
- `But what's even stranger is that I was able to push you away.`,
- ]),
- action`${name} reaches out for Murasamemaru again, but her hand slips through once more.`,
- ]),
- chat(user, `Is this also because I've been chosen by Murasamemaru?`),
- chat(char, message([
- 'No, I suspect that is not the case... But, hmm...',
- 'Alas. I cannot think straight after having been groped so shamelessly.',
- ])),
-)
-
-export const chat_1_2 = chats(
- chat(user, 'Where am I again...?'),
- chat(char, message`I see you've finally awoken, Master. Good morning.`),
- chat(user, [
- '...Morning.',
- `Guess all that stuff yesterday wasn't a dream.`,
- `${name}-chan, are you an early riser? Actually, wait, do you even sleep?`,
- ]),
- chat(char, message([
- 'I am not bound by the principles of the mortal world.',
- 'Normally, I do not require sleep.',
- ])),
- chat(user, 'Sounds handy.'),
- chat(char, message([
- `It is, and isn't.`,
- 'The ability to pass through walls is rather convenient,',
- 'but being unable to touch physical objects can be a problem at times.',
- ])),
- chat(user, `Wait, aren't you standing on the floor right now?`),
- chat(char, message([
- 'I am not actually standing atop the tatami.',
- 'It may seem that way, but in reality, I am floating slightly above it.',
- ])),
- chat(user, 'Really?'),
- chat(char, message([
- 'Fortunately, this means my shoes cannot get dirty.',
- 'Old instincts are ingrained into my body,',
- 'It is easier for me to move as I did when I was still alive.',
- ])),
-)
-
-export const chat_1_3 = chats(
- chat(user, '...'),
- chat(char, [
- message([
- 'Master, why are you so quiet? Let us talk about something.',
- 'Hey, Master! Why are you ignoring me?',
- ]),
- action`${name}-chan clings to my shirt, her voice and body trembling.`,
- ]),
- chat(user, 'Are you scared?'),
- chat(char, message`Don't be ridiculous, Master. As if I would be scared. Wahaha!`),
- chat(user, 'If you say so.'),
- chat(char, message`I do, Indeed.`),
- chat(user, '...Whoa!'),
- chat(char, message`Pyah!?`),
- chat(user, 'See? You totally are scared.'),
- chat(char, message`Perish the thought. I am perfectly calm. So calm that I feel like singing.`),
- chat(user, `Sounds like you're trying to distract yourself from how scared-`),
- chat(char, message([
- 'Kagome, Kagome.',
- 'When, oh when will the bird in the cage fly free?',
- 'At the eve of dawn-',
- ])),
- chat(user, [
- `Why'd you pick that creepy song!?`,
- `Stop! Now you're scaring me!`,
- ]),
- chat(char, message`You're scared as well, Master?`),
- chat(user, [
- 'Of course I am.',
- `This is the kind of place you'd expect to see some ghosts or monsters.`,
- ]),
- chat(char, message`Pyah!? Ghosts!? Monsters!?`),
- chat(user, [
- `Look, I'm not saying they actually will show up,`,
- `but just that you'd expect them to.`,
- ]),
- chat(char, message`Oh... That's good.`),
-)
-
-export const chat_2_5 = chats(
- chat(user, 'Anyway, what do I have to do to earn your forgiveness?'),
- chat(char, [
- message([
- 'Hmm, let me think... How about...',
- 'Patting my head?',
- ]),
- action`${name}-chan fidgets and then looks up at you with puppy-dog eyes.`,
- ]),
- chat(user, 'Is this fine?'),
- chat(char, message([
- 'Mmm... if you could be a bit gentler...',
- 'Yes, that is perfect, Ehehe.',
- 'What a strange sensation...',
- 'Ah, is it supposed to tickle when someone pats your head?',
- ])),
- chat(user, `Can't say I've patted enough heads to be sure... but I guess so?`),
- chat(char, message([
- 'I know I am the one who asked, but this is somewhat embarrassing.',
- 'Keep going a bit more... please?',
- ])),
- chat(user, `If that's what you want, sure.`),
- chat(char, message`Wonderful, Thank you, Master! Ehehe.`),
-)
diff --git a/packages/characters/src/visual_novel/murasame_first_mes.ts b/packages/characters/src/visual_novel/murasame_first_mes.ts
deleted file mode 100644
index 57f1ea8..0000000
--- a/packages/characters/src/visual_novel/murasame_first_mes.ts
+++ /dev/null
@@ -1,60 +0,0 @@
-import { action, message } from '@moeru-ai/character-card-helpers/alichat.js'
-
-const name = 'Murasame' as const
-
-export const scenario_2_3_modified = [
- action([
- 'A sharp pain jolts you awake.',
- 'Your body recoils from the unexpected impact.',
- ]),
- message([
- 'Master, Master!',
- 'Wake up, Master!',
- ]),
- action([
- `${name}'s shrill voice echoes through the room.`,
- 'You groan, rubbing your aching stomach.',
- `She's been instructed to ensure you were up at this time,`,
- 'but surely there was a gentler method.',
- ]),
- message([
- 'I called out to you multiple times, you know?',
- 'You refused to wake up, forcing me to use my last resort.',
- ]),
- action([
- 'she declares, her tone matter-of-fact.',
- 'You grateful for her persistence, but your organs are protesting.',
- ]),
- message`If it bothers you that much, learn to wake up on your own.`,
-].join(' ')
-
-// export const scenario_2_3 = chats(
-// chat(char, message([
-// 'Master, Maaaaster!',
-// 'Wake up, Master!',
-// ])),
-// chat(user, [
-// 'Oof!',
-// 'Could you not jump on my stomach to wake me up? It hurts.',
-// 'I thought I was about to die.',
-// ]),
-// chat(char, message`You were the one who requested I make absolutely sure you wake up at this time.`),
-// chat(user, [
-// `I did, and I'm glad you woke me up,`,
-// `but couldn't you have done it more gently?`,
-// ]),
-// chat(char, message([
-// 'I called out to you multiple times, you know?',
-// 'You refused to wake up, forcing me to use my last resort.',
-// ])),
-// chat(user, [
-// 'No, no, I really am glad you did. Thanks.',
-// 'But next time could you not hit the stomach? I nearly threw up.',
-// ]),
-// chat(char, message`If it bothers you that much, learn to wake up on your own.`),
-// chat(user, `I'll try.`),
-// chat(char, [
-// message`Now hurry up, Master, and get out of that futon.`,
-// action`${name}-chan hops up and down, trying to force me awake.`,
-// ]),
-// )
diff --git a/packages/characters/src/visual_novel/tsukuyomi.ts b/packages/characters/src/visual_novel/tsukuyomi.ts
deleted file mode 100644
index c4da2ab..0000000
--- a/packages/characters/src/visual_novel/tsukuyomi.ts
+++ /dev/null
@@ -1,79 +0,0 @@
-import { char, START, user } from '@moeru-ai/character-card-helpers'
-import { action, chat, chats, message } from '@moeru-ai/character-card-helpers/alichat.js'
-import { group, list, lists } from '@moeru-ai/character-card-helpers/plist.js'
-
-import { defineCharacterCard, overrideCharacterCard } from '../utils'
-
-const name = 'Tsukuyomi' as const
-
-export const tsukuyomi = defineCharacterCard({
- character_version: '0.1',
- creator_notes: lists(
- /** {@link https://vndb.org/c85636} */
- list(`${name}'s appearance`, [
- group('hair', ['silver', 'long', 'side']),
- group('eyes', 'cyan'),
- group('teeth', 'white'),
- group('lips', 'pink'),
- group('skin', ['white', 'soft']),
- group('top', ['white', 'sleeveless', 'crop-top', 'cyan bow tie']),
- group('wrist', ['white', 'cuffs']),
- group('skirt', ['dark green', 'short']),
- group('socks', ['black', 'thigh-high']),
- group('shoes', 'white'),
- ]),
- ),
- description: chats(
- /** TODO: remove this */
- `A robot made by C - AI.
-has a physical ability and intelligence far beyond that of normal human beings,
-and body texture is no different from that of a normal woman,
-and appearance faithfully reproduces the requirements of ${user}.
-although she "loves" ${user},
-she only relies on the mixed information on the Internet to get information,
-and has a rather strange expression of love.
-after the first contact with ${user},
-${user} decided that she hadn't met ${user}'s ideal yet,
-so she decided to perfect the "love" part first.`,
- START,
- chat(user, 'Describe your traits?'),
- chat(char, [
- action(`${name} crosses her hands and smiles.`),
- message([
- `Once again, my personal name is ${name}, master.`,
- `And then there's... The administrators call me C - AI.`,
- `I love you, master!`,
- `I'll be gentle with master's pampering.`,
- `How do you feel? Did ${name} fulfill master's orders?`,
- ]),
- ]),
- ),
- extensions: {
- about: chats(
- 'Main heroine from "Kami-sama no You na Kimi e"',
- 'My first character card, for testing purposes only at this time',
- ),
- avatar: new URL('https://www.cuffs.co.jp/products/kamikimi_ext/twitter_material/download_icon-tsukuyomi.png').href,
- },
- first_mes: chats(
- action('You were sleeping peacefully until the call came to your ears...'),
- message([
- 'Please wake up.',
- `it's already time, master.`,
- 'please wake up.',
- `you'll be late, master.`,
- `it's a crisis of social credibility, master.`,
- ]),
- ),
- name,
-})
-
-export const tsukuyomi_moon = overrideCharacterCard({
- extensions: {
- about: chats(
- 'Main heroine from "Kami-sama no You na Kimi e"',
- 'This is supposed to be Tsukuyomi at the end of her route,',
- `but I haven't finished it yet.`,
- ),
- },
-}, tsukuyomi)
diff --git a/packages/characters/tsconfig.json b/packages/characters/tsconfig.json
deleted file mode 100644
index c22e8ff..0000000
--- a/packages/characters/tsconfig.json
+++ /dev/null
@@ -1,4 +0,0 @@
-{
- "extends": "@importantimport/tsconfig/app.json",
- "include": ["src"]
-}
diff --git a/packages/characters/tsup.config.ts b/packages/characters/tsup.config.ts
deleted file mode 100644
index 16f85fc..0000000
--- a/packages/characters/tsup.config.ts
+++ /dev/null
@@ -1,8 +0,0 @@
-import { defineConfig } from 'tsup'
-
-export default defineConfig({
- clean: true,
- dts: true,
- entry: ['src/index.ts'],
- format: 'esm',
-})
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 912db25..3bc2526 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -91,43 +91,8 @@ importers:
specifier: ^3.4.15
version: 3.4.15
- docs-old:
- devDependencies:
- '@moeru-ai/characters':
- specifier: workspace:*
- version: link:../packages/characters
- '@nolebase/vitepress-plugin-enhanced-readabilities':
- specifier: ^2.9.0
- version: 2.9.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- '@nolebase/vitepress-plugin-git-changelog':
- specifier: 2.0.0-rc5
- version: 2.0.0-rc5(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)(vitepress@1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3))
- '@radix-ui/colors':
- specifier: ^3.0.0
- version: 3.0.0
- unocss:
- specifier: ^0.64.1
- version: 0.64.1(postcss@8.4.49)(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))
- vitepress:
- specifier: ^1.5.0
- version: 1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- vue:
- specifier: ^3.5.13
- version: 3.5.13(typescript@5.6.3)
-
packages/ccc: {}
- packages/character-card-helpers: {}
-
- packages/characters:
- devDependencies:
- '@moeru-ai/character-card-helpers':
- specifier: workspace:^
- version: link:../character-card-helpers
- defu:
- specifier: ^6.1.4
- version: 6.1.4
-
packages/characters-derivative:
dependencies:
'@moeru-ai/ccc':
@@ -148,71 +113,6 @@ importers:
packages:
- '@algolia/autocomplete-core@1.9.3':
- resolution: {integrity: sha512-009HdfugtGCdC4JdXUbVJClA0q0zh24yyePn+KUGk3rP7j8FEe/m5Yo/z65gn6nP/cM39PxpzqKrL7A6fP6PPw==}
-
- '@algolia/autocomplete-plugin-algolia-insights@1.9.3':
- resolution: {integrity: sha512-a/yTUkcO/Vyy+JffmAnTWbr4/90cLzw+CC3bRbhnULr/EM0fGNvM13oQQ14f2moLMcVDyAx/leczLlAOovhSZg==}
- peerDependencies:
- search-insights: '>= 1 < 3'
-
- '@algolia/autocomplete-preset-algolia@1.9.3':
- resolution: {integrity: sha512-d4qlt6YmrLMYy95n5TB52wtNDr6EgAIPH81dvvvW8UmuWRgxEtY0NJiPwl/h95JtG2vmRM804M0DSwMCNZlzRA==}
- peerDependencies:
- '@algolia/client-search': '>= 4.9.1 < 6'
- algoliasearch: '>= 4.9.1 < 6'
-
- '@algolia/autocomplete-shared@1.9.3':
- resolution: {integrity: sha512-Wnm9E4Ye6Rl6sTTqjoymD+l8DjSTHsHboVRYrKgEt8Q7UHm9nYbqhN/i0fhUYA3OAEH7WA8x3jfpnmJm3rKvaQ==}
- peerDependencies:
- '@algolia/client-search': '>= 4.9.1 < 6'
- algoliasearch: '>= 4.9.1 < 6'
-
- '@algolia/cache-browser-local-storage@4.23.3':
- resolution: {integrity: sha512-vRHXYCpPlTDE7i6UOy2xE03zHF2C8MEFjPN2v7fRbqVpcOvAUQK81x3Kc21xyb5aSIpYCjWCZbYZuz8Glyzyyg==}
-
- '@algolia/cache-common@4.23.3':
- resolution: {integrity: sha512-h9XcNI6lxYStaw32pHpB1TMm0RuxphF+Ik4o7tcQiodEdpKK+wKufY6QXtba7t3k8eseirEMVB83uFFF3Nu54A==}
-
- '@algolia/cache-in-memory@4.23.3':
- resolution: {integrity: sha512-yvpbuUXg/+0rbcagxNT7un0eo3czx2Uf0y4eiR4z4SD7SiptwYTpbuS0IHxcLHG3lq22ukx1T6Kjtk/rT+mqNg==}
-
- '@algolia/client-account@4.23.3':
- resolution: {integrity: sha512-hpa6S5d7iQmretHHF40QGq6hz0anWEHGlULcTIT9tbUssWUriN9AUXIFQ8Ei4w9azD0hc1rUok9/DeQQobhQMA==}
-
- '@algolia/client-analytics@4.23.3':
- resolution: {integrity: sha512-LBsEARGS9cj8VkTAVEZphjxTjMVCci+zIIiRhpFun9jGDUlS1XmhCW7CTrnaWeIuCQS/2iPyRqSy1nXPjcBLRA==}
-
- '@algolia/client-common@4.23.3':
- resolution: {integrity: sha512-l6EiPxdAlg8CYhroqS5ybfIczsGUIAC47slLPOMDeKSVXYG1n0qGiz4RjAHLw2aD0xzh2EXZ7aRguPfz7UKDKw==}
-
- '@algolia/client-personalization@4.23.3':
- resolution: {integrity: sha512-3E3yF3Ocr1tB/xOZiuC3doHQBQ2zu2MPTYZ0d4lpfWads2WTKG7ZzmGnsHmm63RflvDeLK/UVx7j2b3QuwKQ2g==}
-
- '@algolia/client-search@4.23.3':
- resolution: {integrity: sha512-P4VAKFHqU0wx9O+q29Q8YVuaowaZ5EM77rxfmGnkHUJggh28useXQdopokgwMeYw2XUht49WX5RcTQ40rZIabw==}
-
- '@algolia/logger-common@4.23.3':
- resolution: {integrity: sha512-y9kBtmJwiZ9ZZ+1Ek66P0M68mHQzKRxkW5kAAXYN/rdzgDN0d2COsViEFufxJ0pb45K4FRcfC7+33YB4BLrZ+g==}
-
- '@algolia/logger-console@4.23.3':
- resolution: {integrity: sha512-8xoiseoWDKuCVnWP8jHthgaeobDLolh00KJAdMe9XPrWPuf1by732jSpgy2BlsLTaT9m32pHI8CRfrOqQzHv3A==}
-
- '@algolia/recommend@4.23.3':
- resolution: {integrity: sha512-9fK4nXZF0bFkdcLBRDexsnGzVmu4TSYZqxdpgBW2tEyfuSSY54D4qSRkLmNkrrz4YFvdh2GM1gA8vSsnZPR73w==}
-
- '@algolia/requester-browser-xhr@4.23.3':
- resolution: {integrity: sha512-jDWGIQ96BhXbmONAQsasIpTYWslyjkiGu0Quydjlowe+ciqySpiDUrJHERIRfELE5+wFc7hc1Q5hqjGoV7yghw==}
-
- '@algolia/requester-common@4.23.3':
- resolution: {integrity: sha512-xloIdr/bedtYEGcXCiF2muajyvRhwop4cMZo+K2qzNht0CMzlRkm8YsDdj5IaBhshqfgmBb3rTg4sL4/PpvLYw==}
-
- '@algolia/requester-node-http@4.23.3':
- resolution: {integrity: sha512-zgu++8Uj03IWDEJM3fuNl34s746JnZOWn1Uz5taV1dFyJhVM/kTNw9Ik7YJWiUNHJQXcaD8IXD1eCb0nq/aByA==}
-
- '@algolia/transporter@4.23.3':
- resolution: {integrity: sha512-Wjl5gttqnf/gQKJA+dafnD0Y6Yw97yvfY8R9h0dQltX1GXTgNs1zWgvtWW0tHl1EgMdhAyw189uWiZMnL3QebQ==}
-
'@alloc/quick-lru@5.2.0':
resolution: {integrity: sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==}
engines: {node: '>=10'}
@@ -443,29 +343,6 @@ packages:
resolution: {integrity: sha512-WyOx8cJQ+FQus4Mm4uPIZA64gbk3Wxh0so5Lcii0aJifqwoVOlfFtorjLE0Hen4OYyHZMXDWqMmaQemBhgxFRQ==}
engines: {node: '>=14'}
- '@docsearch/css@3.6.2':
- resolution: {integrity: sha512-vKNZepO2j7MrYBTZIGXvlUOIR+v9KRf70FApRgovWrj3GTs1EITz/Xb0AOlm1xsQBp16clVZj1SY/qaOJbQtZw==}
-
- '@docsearch/js@3.6.2':
- resolution: {integrity: sha512-pS4YZF+VzUogYrkblCucQ0Oy2m8Wggk8Kk7lECmZM60hTbaydSIhJTTiCrmoxtBqV8wxORnOqcqqOfbmkkQEcA==}
-
- '@docsearch/react@3.6.2':
- resolution: {integrity: sha512-rtZce46OOkVflCQH71IdbXSFK+S8iJZlUF56XBW5rIgx/eG5qoomC7Ag3anZson1bBac/JFQn7XOBfved/IMRA==}
- peerDependencies:
- '@types/react': '>= 16.8.0 < 19.0.0'
- react: '>= 16.8.0 < 19.0.0'
- react-dom: '>= 16.8.0 < 19.0.0'
- search-insights: '>= 1 < 3'
- peerDependenciesMeta:
- '@types/react':
- optional: true
- react:
- optional: true
- react-dom:
- optional: true
- search-insights:
- optional: true
-
'@emmetio/abbreviation@2.3.3':
resolution: {integrity: sha512-mgv58UrU3rh4YgbE/TzgLQwJ3pFsHHhCLqY20aJq+9comytTXUDNGG/SMtSeMJdkpxgXSXunBGLD8Boka3JyVA==}
@@ -1023,24 +900,6 @@ packages:
resolution: {integrity: sha512-c7hNEllBlenFTHBky65mhq8WD2kbN9Q6gk0bTk8lSBvc554jpXSkST1iePudpt7+A/AQvuHs9EMqjHDXMY1lrA==}
engines: {node: '>=18.18'}
- '@iconify-json/carbon@1.2.4':
- resolution: {integrity: sha512-DhW2jjMVGwV0DLHc0cmDYohdtGxMra8UuwgjHrryPy+rQX4gXhJwCBBVP2h2UG/92AoRCTn7zUJve4WvY5MLYg==}
-
- '@iconify-json/icon-park-outline@1.2.1':
- resolution: {integrity: sha512-cNvUJL9mk3xOfyffErQuxvyRCWk0hCx1M8AEyGmNXjqIfgPC25OChCstt0KFB3IULS+hw9es+uA7pvVPmQh+AA==}
-
- '@iconify-json/octicon@1.2.1':
- resolution: {integrity: sha512-4w7yMipQtp6s6aCHrSVlVXsf0OCBQ8CRmUTkMQUBexR42SXl4z5GnaUyaOMVoZttfgaBNnj0mlMB5T1cmRDgTg==}
-
- '@iconify-json/simple-icons@1.2.11':
- resolution: {integrity: sha512-AHCGDtBRqP+JzAbBzgO8uN/08CXxEmuaC6lQQZ3b5burKhRU12AJnJczwbUw2K5Mb/U85EpSUNhYMG3F28b8NA==}
-
- '@iconify/types@2.0.0':
- resolution: {integrity: sha512-+wluvCrRhXrhyOmRDJ3q8mux9JkKy5SJ/v8ol2tu4FVjyYvtEzkc/3pK15ET6RKg4b4w4BmTk1+gsCUhf21Ykg==}
-
- '@iconify/utils@2.1.33':
- resolution: {integrity: sha512-jP9h6v/g0BIZx0p7XGJJVtkVnydtbgTgt9mVNcGDYwaa7UhdHdI9dvoq+gKj9sijMSJKxUPEG2JyjsgXjxL7Kw==}
-
'@img/sharp-darwin-arm64@0.33.5':
resolution: {integrity: sha512-UT4p+iz/2H4twwAoLCqfA9UH5pI6DggwKEGuaPy7nCVQ8ZsiY5PIcrRvD1DzuY3qYL07NtIQcWnBSY/heikIFQ==}
engines: {node: ^18.17.0 || ^20.3.0 || >=21.0.0}
@@ -1177,12 +1036,6 @@ packages:
'@jridgewell/trace-mapping@0.3.25':
resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==}
- '@kwsites/file-exists@1.1.1':
- resolution: {integrity: sha512-m9/5YGR18lIwxSFDwfE3oA7bWuq9kdau6ugN4H2rJeyhFQZcG9AgSHkQtSD15a8WvTgfz9aikZMrKPHvbpqFiw==}
-
- '@kwsites/promise-deferred@1.1.1':
- resolution: {integrity: sha512-GaHYm+c0O9MjZRu0ongGBRbinu8gVAMd2UZjji6jVmqKtZluZnptXGWhz1E8j8D2HJ3f/yMxKAUC0b+57wncIw==}
-
'@mdx-js/mdx@3.1.0':
resolution: {integrity: sha512-/QxEhPAvGwbQmy1Px8F899L5Uc2KZ6JtXwlCgJmjSTBedwOZkByYcBG4GceIGPXRDsmfxhHazuS+hlOShRLeDw==}
@@ -1198,20 +1051,6 @@ packages:
resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==}
engines: {node: '>= 8'}
- '@nolebase/ui@2.7.0':
- resolution: {integrity: sha512-BZJukhYOlP3rDwGfFVFcTIe1QFgV4yFpIBy0HUrOvL9kwO5uoFDCyY8ob5sDaRUmJajzH510VfI3RQtCbS9qog==}
-
- '@nolebase/ui@2.9.0':
- resolution: {integrity: sha512-490S46zBqEU4+lyCM0Ik/gGgXReaKF4sycs39ItQGd7iWrcsTcy64+lKg0JmsNwxzHPKqW5xGwYM6AvAgSNUTA==}
-
- '@nolebase/vitepress-plugin-enhanced-readabilities@2.9.0':
- resolution: {integrity: sha512-0Vp3yIh5oX6/KYjtDKLttO48qj1KYkWFrsdH3VLND5zfSFKXTdZ6WgnsLSiNUzqWvIv3+uCe4bF/7iOvYdUQag==}
-
- '@nolebase/vitepress-plugin-git-changelog@2.0.0-rc5':
- resolution: {integrity: sha512-ji3eCvNUdsMCe3YANzzJLScTNYgjyZqrw2wMBS+lg+jOvJKrFXVALe5/kGqU2h629SvgnLpFnZi+xVb/DRFmqA==}
- peerDependencies:
- vitepress: ^1.0.0
-
'@oslojs/encoding@1.1.0':
resolution: {integrity: sha512-70wQhgYmndg4GCPxPPxPGevRKqTIJ2Nh4OkiMWmDAVYsTQ+Ta7Sq+rPevXyXGdzr30/qZBnyOalCszoMxlyldQ==}
@@ -1251,12 +1090,6 @@ packages:
resolution: {integrity: sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==}
engines: {node: ^12.20.0 || ^14.18.0 || >=16.0.0}
- '@polka/url@1.0.0-next.25':
- resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==}
-
- '@radix-ui/colors@3.0.0':
- resolution: {integrity: sha512-FUOsGBkHrYJwCSEtWRCIfQbZG7q1e6DgxCIOe1SUQzDe/7rXXeA47s8yCn6fuTNQAj1Zq4oTFi9Yjp3wzElcxg==}
-
'@rollup/pluginutils@5.1.3':
resolution: {integrity: sha512-Pnsb6f32CD2W3uCaLZIzDmeFyQ2b8UWMFI7xtwUezpcGBDVDW6y9XgAWIlARiGAo6eNF5FK5aQTr0LFyNyqq5A==}
engines: {node: '>=14.0.0'}
@@ -1365,9 +1198,6 @@ packages:
'@shikijs/engine-oniguruma@1.22.2':
resolution: {integrity: sha512-GIZPAGzQOy56mGvWMoZRPggn0dTlBf1gutV5TdceLCZlFNqWmuc7u+CzD0Gd9vQUTgLbrt0KLzz6FNprqYAxlA==}
- '@shikijs/transformers@1.22.2':
- resolution: {integrity: sha512-8f78OiBa6pZDoZ53lYTmuvpFPlWtevn23bzG+azpPVvZg7ITax57o/K3TC91eYL3OMJOO0onPbgnQyZjRos8XQ==}
-
'@shikijs/types@1.22.2':
resolution: {integrity: sha512-NCWDa6LGZqTuzjsGfXOBWfjS/fDIbDdmVDug+7ykVe1IKT4c1gakrvlfFYp5NhAXH/lyqLM8wsAPo5wNy73Feg==}
@@ -1419,18 +1249,9 @@ packages:
'@types/json-schema@7.0.15':
resolution: {integrity: sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==}
- '@types/linkify-it@5.0.0':
- resolution: {integrity: sha512-sVDA58zAw4eWAffKOaQH5/5j3XeayukzDk+ewSsnv3p4yJEZHCCzMDiZM8e0OUrRvmpGZ85jf4yDHkHsgBNr9Q==}
-
- '@types/markdown-it@14.1.2':
- resolution: {integrity: sha512-promo4eFwuiW+TfGxhi+0x3czqTYJkG8qB17ZUJiVF10Xm7NLVRSLUsfRTU/6h1e24VvRnXCx+hG7li58lkzog==}
-
'@types/mdast@4.0.4':
resolution: {integrity: sha512-kGaNbPh1k7AFzgpud/gMdvIm5xuECykRR+JnWKQno9TAXVa6WIVCGTPvYGekIDL4uwCZQSYbUxNBSb1aUo79oA==}
- '@types/mdurl@2.0.0':
- resolution: {integrity: sha512-RGdgjQUZba5p6QEFAVx2OGb8rQDL/cPRG7GiedRzMcJ1tYnUANBncjbSB1NRGwbvjcPeikRABz2nshyPk1bhWg==}
-
'@types/mdx@2.0.13':
resolution: {integrity: sha512-+OWZQfAYyio6YkJb3HLxDrvnx6SWWDbC0zVPfBRzUk0/nqoDyf6dNxQi3eArPe8rJ473nobTMQ/8Zk+LxJ+Yuw==}
@@ -1449,12 +1270,6 @@ packages:
'@types/normalize-package-data@2.4.4':
resolution: {integrity: sha512-37i+OaWTh9qeK4LSHPsyRC7NahnGotNuZvjLSgcPzblpHB3rrCJxAOgI5gCdKm7coonsaX1Of0ILiTcnZjbfxA==}
- '@types/prop-types@15.7.13':
- resolution: {integrity: sha512-hCZTSvwbzWGvhqxp/RqVqwU999pBf2vp7hzIjiYOsl8wqOmUxkQ6ddw1cV3l8811+kdUFus/q4d1Y3E3SyEifA==}
-
- '@types/react@18.3.12':
- resolution: {integrity: sha512-D2wOSq/d6Agt28q7rSI3jhU7G6aiuzljDGZ2hTZHIkrTLUI+AF3WMeKkEZ9nN2fkBAlcktT6vcZjDFiIhMYEQw==}
-
'@types/sax@1.2.7':
resolution: {integrity: sha512-rO73L89PJxeYM3s3pPPjiPgVVcymqU490g0YO5n5By0k2Erzj6tay/4lr1CHAAU4JyOWd1rpQ8bCf6cZfHU96A==}
@@ -1464,9 +1279,6 @@ packages:
'@types/unist@3.0.3':
resolution: {integrity: sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==}
- '@types/web-bluetooth@0.0.20':
- resolution: {integrity: sha512-g9gZnnXVq7gM7v3tJCWV/qw7w+KeOlSHAhgF9RytFyifW6AF61hdT2ucrYhPq9hLs5JIryeupHV3qGk95dH9ow==}
-
'@typescript-eslint/eslint-plugin@8.15.0':
resolution: {integrity: sha512-+zkm9AR1Ds9uLWN3fkoeXgFppaQ+uEVtfOV62dDmsy9QCNqlRHWNEck4yarvRNrvRcHQLGfqBNui3cimoz8XAg==}
engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0}
@@ -1568,93 +1380,6 @@ packages:
'@ungap/structured-clone@1.2.0':
resolution: {integrity: sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==}
- '@unocss/astro@0.64.1':
- resolution: {integrity: sha512-UBB2nDc3aqBmdcgJHOsnAQaQnbdch4f3CKfV+LTv77D4tPizagUCODwPVTK3CA3leQzVbbUV06uHfo5hsv2PUw==}
- peerDependencies:
- vite: ^2.9.0 || ^3.0.0-0 || ^4.0.0 || ^5.0.0-0
- peerDependenciesMeta:
- vite:
- optional: true
-
- '@unocss/cli@0.64.1':
- resolution: {integrity: sha512-P08Routw1TiCZyvfcveZIQrJi4/agBtWJAMP4NwVgYre7Lgl0jYF4qn9NEpUS4z+Qc5t2U33+4q0xgZpVh4oPw==}
- engines: {node: '>=14'}
- hasBin: true
-
- '@unocss/config@0.64.1':
- resolution: {integrity: sha512-uhUfVnRhVsqZrRuFGGFfvvSO9gVUSHgfXOF/u8MnQ/lG1MVyXpx5QykVhjSgSehMfQIFsZ2SID1y7Fd5f8kgLw==}
- engines: {node: '>=14'}
-
- '@unocss/core@0.64.1':
- resolution: {integrity: sha512-D1ULd70a24/k6kGyHCIijbrrIn9UjFUEBg2R4xKX2/ViQb1k2MIgOs4VS20MkJX6kbZXqqm/zAFHzDhsQGIhBA==}
-
- '@unocss/extractor-arbitrary-variants@0.64.1':
- resolution: {integrity: sha512-tKtaeZYzSCaH1ASE7Uj45rPX4ApQHYE8eZFfaL3N4ZY0LYrTJPBnaLSRfLRwGD6KLHjoL3+sorywJiS/VVBcFQ==}
-
- '@unocss/inspector@0.64.1':
- resolution: {integrity: sha512-IDlSxvczxzQso/9aIneQaQ+jVhi8/Wb6uck1pRZm3q71uF3+mhzqEvQojbe1VaKqwUlCmBy2U+M/e8L5dJavlA==}
-
- '@unocss/postcss@0.64.1':
- resolution: {integrity: sha512-tlc5ZFO6xoLhYukSRtKSBaP1SDmAatmHCbbRiH6ElncEQNpjl70raXMKjQWfIuAo8IniUe69ILZC+M60AGPYmA==}
- engines: {node: '>=14'}
- peerDependencies:
- postcss: ^8.4.21
-
- '@unocss/preset-attributify@0.64.1':
- resolution: {integrity: sha512-uxq4iiMZN+/Dy/TAQI/b+mWbHqI7ww/vVJC8tvjdXm9C4SditLb1Wd+Y183nhXI3Pa78wEibK5t8RaDc/fgKPg==}
-
- '@unocss/preset-icons@0.64.1':
- resolution: {integrity: sha512-aQ4hN2NFdJo08pzUYc1FpwTkNUByE7FB51KmRwXclsVKeXFGvFO3YUYeg5IDlTxqCfvFVWZ3q8NhnmpKGkbutw==}
-
- '@unocss/preset-mini@0.64.1':
- resolution: {integrity: sha512-tl+ciN0elB9eETEVZQrNaMy4NpbLdWDVW7KlmpRZi4Eomf/Ntz+Wctp5V0aBvszo8arEaDiOwsgMxITvx9Ll6Q==}
-
- '@unocss/preset-tagify@0.64.1':
- resolution: {integrity: sha512-xBGF7usHIDOMmLEgawpgbOAoNZ8qFZ/mpbRG9tdEjOHJ+rXJuJlZHhwIgwjQiFRCzSRtlsN57/iM37bZNRCEAg==}
-
- '@unocss/preset-typography@0.64.1':
- resolution: {integrity: sha512-5L/m0YrtF5P6W4U1DhMfqdKVFbso09TplVHK9udJMvYMaj4HzNNIo6GtpbSm2eCXBzxIYuzAjQ9kLldOXjZS1w==}
-
- '@unocss/preset-uno@0.64.1':
- resolution: {integrity: sha512-9427KmOHsck9mNfOXiCBy43Q9aAI1w15tCBJf2bDMHioJltc6JjW+Mg5DDZWnYelhzpXCYK7zTZtMJ40KxDx+g==}
-
- '@unocss/preset-web-fonts@0.64.1':
- resolution: {integrity: sha512-qhc1976bVDMYG+aG5VKvTsKK7K8hMrNnhkCmfKmvdFH7xSj8MB80YxdmiAAcKh3cVk97bh0ej7ym6Lss7I2Idg==}
-
- '@unocss/preset-wind@0.64.1':
- resolution: {integrity: sha512-IpAfsi2tI4elb2uZzc3BSZgbi0axgwgJLPFW0BtZQe4u1J+zrUIOvjCu/2jmiB7LR05IShCyMKIz9Vi4EJm+gQ==}
-
- '@unocss/reset@0.64.1':
- resolution: {integrity: sha512-xx36rWcrIpyvI1l/v+szQLrxWAgsmk6GH85QQ5iE1qccQbL9IlhWHB1KEd3cRbJ1TFeZ2Mzca/qsjg0LU9ZVnA==}
-
- '@unocss/rule-utils@0.64.1':
- resolution: {integrity: sha512-h+Du0lezKHmdsEsGQGAtGrwrTrU+Av4eij46UzpzuNWFq0mAouBu8m/lgBI1AcY9B0Jg3EJalkOgA06tAKS8jg==}
- engines: {node: '>=14'}
-
- '@unocss/transformer-attributify-jsx@0.64.1':
- resolution: {integrity: sha512-Zg7rfNheWxJh2G5C0gCctGc6c8NbmI6wqbYjUxUDXEeT+lrZqKeDpTmgcLis7gLqGELFvIqE5R0EpARvjrj9bw==}
-
- '@unocss/transformer-compile-class@0.64.1':
- resolution: {integrity: sha512-oASb3lJq++Ll6LD3frT0WiEZUJupjrLF+rtkgz3lKPgD8bRpbh+m5FykGAIHj5VcIcYOACD4GkTrSFrQbL0GEw==}
-
- '@unocss/transformer-directives@0.64.1':
- resolution: {integrity: sha512-6yWZh7YxYTaNSdATkGpP+aQ3aTRLNo4URDmLQKB3uaQbF0Ae5dLlxXWHZ26VIpKkQ3+hME4TRxEptTR0/ag7nw==}
-
- '@unocss/transformer-variant-group@0.64.1':
- resolution: {integrity: sha512-wQkD1x69YSiIXvSvNNTN6hTZXHVzbVY+xmfoXL3bi/1cDMzRmE9C2Gk/Rzm/BSQxsLusLfDDL0NuhxWoFmvWPA==}
-
- '@unocss/vite@0.64.1':
- resolution: {integrity: sha512-DIvl7Mofc5Q6kKElMRALbH33xBYb5w3Yf7TQ860lmi3DOwjEcg+OWE1HD+iDf7IxZeqPsdF17NvJJaSdmr0m5Q==}
- peerDependencies:
- vite: ^2.9.0 || ^3.0.0-0 || ^4.0.0 || ^5.0.0-0
-
- '@vitejs/plugin-vue@5.1.4':
- resolution: {integrity: sha512-N2XSI2n3sQqp5w7Y/AN/L2XDjBIRGqXko+eDp42sydYSBeJuSm5a1sLf8zakmo8u7tA8NmBgoDLA1HeOESjp9A==}
- engines: {node: ^18.0.0 || >=20.0.0}
- peerDependencies:
- vite: ^5.0.0
- vue: ^3.2.25
-
'@vitest/eslint-plugin@1.1.10':
resolution: {integrity: sha512-uScH5Kz5v32vvtQYB2iodpoPg2mGASK+VKpjlc2IUgE0+16uZKqVKi2vQxjxJ6sMCQLBs4xhBFZlmZBszsmfKQ==}
peerDependencies:
@@ -1735,85 +1460,9 @@ packages:
'@vue/compiler-ssr@3.5.13':
resolution: {integrity: sha512-wMH6vrYHxQl/IybKJagqbquvxpWCuVYpoUJfCqFZwa/JY1GdATAQ+TgVtgrwwMZ0D07QhA99rs/EAAWfvG6KpA==}
- '@vue/devtools-api@7.6.1':
- resolution: {integrity: sha512-W99uw1nJKWeG4V2Bgp/pR1vnIREfixmnYW71wjtID7Gn/XnHH+nhfJmNy/0DjxcXOM14POVBDkl9JGlsOx1UjQ==}
-
- '@vue/devtools-kit@7.6.1':
- resolution: {integrity: sha512-cCcdskZDLqKwJUHq1+kH9zAfYM+y9OFq8J2NT0xcAUYpu8K5IJd03ydZkvr7ydOd9UKBxrGyZpYe9PpJ0ChrVw==}
-
- '@vue/devtools-shared@7.6.1':
- resolution: {integrity: sha512-SdIif2YoOWo8/s8c1+NU67jcx8qoSjM9caetQnjl3++Kufo0qa5JRZe95iV6vvupQzVGGo3ACY0LTyAsMfGeCg==}
-
- '@vue/reactivity@3.5.13':
- resolution: {integrity: sha512-NaCwtw8o48B9I6L1zl2p41OHo/2Z4wqYGGIK1Khu5T7yxrn+ATOixn/Udn2m+6kZKB/J7cuT9DbWWhRxqixACg==}
-
- '@vue/runtime-core@3.5.13':
- resolution: {integrity: sha512-Fj4YRQ3Az0WTZw1sFe+QDb0aXCerigEpw418pw1HBUKFtnQHWzwojaukAs2X/c9DQz4MQ4bsXTGlcpGxU/RCIw==}
-
- '@vue/runtime-dom@3.5.13':
- resolution: {integrity: sha512-dLaj94s93NYLqjLiyFzVs9X6dWhTdAlEAciC3Moq7gzAc13VJUdCnjjRurNM6uTLFATRHexHCTu/Xp3eW6yoog==}
-
- '@vue/server-renderer@3.5.13':
- resolution: {integrity: sha512-wAi4IRJV/2SAW3htkTlB+dHeRmpTiVIK1OGLWV1yeStVSebSQQOwGwIq0D3ZIoBj2C2qpgz5+vX9iEBkTdk5YA==}
- peerDependencies:
- vue: 3.5.13
-
- '@vue/shared@3.5.12':
- resolution: {integrity: sha512-L2RPSAwUFbgZH20etwrXyVyCBu9OxRSi8T/38QsvnkJyvq2LufW2lDCOzm7t/U9C1mkhJGWYfCuFBCmIuNivrg==}
-
'@vue/shared@3.5.13':
resolution: {integrity: sha512-/hnE/qP5ZoGpol0a5mDi45bOd7t3tjYJBjsgCsivow7D48cJeV5l05RD82lPqi7gRiphZM37rnhW1l6ZoCNNnQ==}
- '@vueuse/core@11.2.0':
- resolution: {integrity: sha512-JIUwRcOqOWzcdu1dGlfW04kaJhW3EXnnjJJfLTtddJanymTL7lF1C0+dVVZ/siLfc73mWn+cGP1PE1PKPruRSA==}
-
- '@vueuse/integrations@11.2.0':
- resolution: {integrity: sha512-zGXz3dsxNHKwiD9jPMvR3DAxQEOV6VWIEYTGVSB9PNpk4pTWR+pXrHz9gvXWcP2sTk3W2oqqS6KwWDdntUvNVA==}
- peerDependencies:
- async-validator: ^4
- axios: ^1
- change-case: ^5
- drauu: ^0.4
- focus-trap: ^7
- fuse.js: ^7
- idb-keyval: ^6
- jwt-decode: ^4
- nprogress: ^0.2
- qrcode: ^1.5
- sortablejs: ^1
- universal-cookie: ^7
- peerDependenciesMeta:
- async-validator:
- optional: true
- axios:
- optional: true
- change-case:
- optional: true
- drauu:
- optional: true
- focus-trap:
- optional: true
- fuse.js:
- optional: true
- idb-keyval:
- optional: true
- jwt-decode:
- optional: true
- nprogress:
- optional: true
- qrcode:
- optional: true
- sortablejs:
- optional: true
- universal-cookie:
- optional: true
-
- '@vueuse/metadata@11.2.0':
- resolution: {integrity: sha512-L0ZmtRmNx+ZW95DmrgD6vn484gSpVeRbgpWevFKXwqqQxW9hnSi2Ppuh2BzMjnbv4aJRiIw8tQatXT9uOB23dQ==}
-
- '@vueuse/shared@11.2.0':
- resolution: {integrity: sha512-VxFjie0EanOudYSgMErxXfq6fo8vhr5ICI+BuE3I9FnX7ePllEsVrRQ7O6Q1TLgApeLuPKcHQxAXpP+KnlrJsg==}
-
acorn-jsx@5.3.2:
resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==}
peerDependencies:
@@ -1830,9 +1479,6 @@ packages:
ajv@8.17.1:
resolution: {integrity: sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==}
- algoliasearch@4.23.3:
- resolution: {integrity: sha512-Le/3YgNvjW9zxIQMRhUHuhiUjAlKY/zsdZpfq4dlLqg6mEm0nL6yk+7f2hDOtLpxsgE4jSzDmvHL7nXdBp5feg==}
-
ansi-align@3.0.1:
resolution: {integrity: sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==}
@@ -1941,9 +1587,6 @@ packages:
resolution: {integrity: sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==}
engines: {node: '>=8'}
- birpc@0.2.19:
- resolution: {integrity: sha512-5WeXXAvTmitV1RqJFppT5QtUiz2p1mRSYU000Jkft5ZUCLJIk4uQriYNO50HknxKwM6jd8utNc66K1qGIwwWBQ==}
-
boolbase@1.0.0:
resolution: {integrity: sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==}
@@ -2079,9 +1722,6 @@ packages:
resolution: {integrity: sha512-1rXeuUUiGGrykh+CeBdu5Ie7OJwinCgQY0bc7GCRxy5xVHy+moaqkpL/jqQq0MtQOeYcrqEz4abc5f0KtU7W4A==}
engines: {node: '>=12.5.0'}
- colorette@2.0.20:
- resolution: {integrity: sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==}
-
comma-separated-tokens@2.0.3:
resolution: {integrity: sha512-Fu4hJdvzeylCfQPp9SGWidpzrMs7tTrlu6Vb8XGaRGck8QSNZJJp538Wrb60Lax4fPwR64ViY468OIUTbRlGZg==}
@@ -2116,10 +1756,6 @@ packages:
copy-anything@2.0.6:
resolution: {integrity: sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==}
- copy-anything@3.0.5:
- resolution: {integrity: sha512-yCEafptTtb4bk7GLEQoM8KVJpxAfdBJYaXyzQEgQQQgYrZiDp8SJmGKlYza6CYjEDNstAdNdKA3UuoULlEbS6w==}
- engines: {node: '>=12.13'}
-
core-js-compat@3.39.0:
resolution: {integrity: sha512-VgEUx3VwlExr5no0tXlBt+silBvhTryPwCXRI2Id1PN8WTKu7MreethvddqOubrYxkFdv/RnYrqlv1sFNAUelw==}
@@ -2133,18 +1769,11 @@ packages:
css-selector-tokenizer@0.8.0:
resolution: {integrity: sha512-Jd6Ig3/pe62/qe5SBPTN8h8LeUg/pT4lLgtavPf7updwwHpvFzxvOQBHYj2LZDMjUnBzgvIUSjRcf6oT5HzHFg==}
- css-tree@3.0.1:
- resolution: {integrity: sha512-8Fxxv+tGhORlshCdCwnNJytvlvq46sOLSYEx2ZIGurahWvMucSRnyjPA3AmrMq4VPRYbHVpWj5VkiVasrM2H4Q==}
- engines: {node: ^10 || ^12.20.0 || ^14.13.0 || >=15.0.0}
-
cssesc@3.0.0:
resolution: {integrity: sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==}
engines: {node: '>=4'}
hasBin: true
- csstype@3.1.3:
- resolution: {integrity: sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==}
-
culori@3.3.0:
resolution: {integrity: sha512-pHJg+jbuFsCjz9iclQBqyL3B2HLCBF71BwVNujUYEvCeQMvV97R59MNK3R2+jgJ3a1fcZgI9B3vYgz8lzr/BFQ==}
engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0}
@@ -2153,9 +1782,6 @@ packages:
resolution: {integrity: sha512-hA27cdBasdwd4/iEjn+aidoCrRroDuo3G5W9NDKaVCJI437Mm/3eSL/2u7MkZ0pt8a+TrYF3aT2pFVemTS3how==}
engines: {node: '>=16.9.0'}
- date-fns@3.6.0:
- resolution: {integrity: sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==}
-
debug@3.2.7:
resolution: {integrity: sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==}
peerDependencies:
@@ -2203,9 +1829,6 @@ packages:
resolution: {integrity: sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==}
engines: {node: '>=6'}
- destr@2.0.3:
- resolution: {integrity: sha512-2N3BOUU4gYMpTP24s5rF5iP7BDr7uNTCs4ozw3kf/eKfvWSIu93GEBi5m427YoyJoeOzQ5smuu4nNAPGb8idSQ==}
-
detect-libc@2.0.3:
resolution: {integrity: sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==}
engines: {node: '>=8'}
@@ -2246,9 +1869,6 @@ packages:
resolution: {integrity: sha512-2QF/g9/zTaPDc3BjNcVTGoBbXBgYfMTTceLaYcFJ/W9kggFUkhxD/hMEeuLKbugyef9SqAx8cpgwlIP/jinUTA==}
engines: {node: '>=4'}
- duplexer@0.1.2:
- resolution: {integrity: sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==}
-
eastasianwidth@0.2.0:
resolution: {integrity: sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==}
@@ -2652,9 +2272,6 @@ packages:
resolution: {integrity: sha512-9UbaD6XdAL97+k/n+N7JwX46K/M6Zc6KcFYskrYL8wbBV/Uyk0CTAMY0VT+qiK5PM7AIc9aTWYtq65U7T+aCNQ==}
engines: {node: '>=8'}
- focus-trap@7.6.0:
- resolution: {integrity: sha512-1td0l3pMkWJLFipobUcGaf+5DTY4PLDDrcqoSaKP8ediO/CoWCCYk/fT/Y2A4e6TNB+Sh6clRJCjOPPnKoNHnQ==}
-
foreground-child@3.1.1:
resolution: {integrity: sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==}
engines: {node: '>=14'}
@@ -2734,10 +2351,6 @@ packages:
resolution: {integrity: sha512-5v6yZd4JK3eMI3FqqCouswVqwugaA9r4dNZB1wwcmrD02QkV5H0y7XBQW8QwQqEaZY1pM9aqORSORhJRdNK44Q==}
engines: {node: '>=6.0'}
- gzip-size@6.0.0:
- resolution: {integrity: sha512-ax7ZYomf6jqPTQ4+XCpUGyXKHk5WweS+e05MBO4/y3WJ5RkmPXNKvX+bx1behVILVwr6JSQvZAku021CHPXG3Q==}
- engines: {node: '>=10'}
-
has-flag@4.0.0:
resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==}
engines: {node: '>=8'}
@@ -2809,9 +2422,6 @@ packages:
hastscript@9.0.0:
resolution: {integrity: sha512-jzaLBGavEDKHrc5EfFImKN7nZKKBdSLIdGvCwDZ9TfzbF2ffXiov8CKE445L2Z1Ek2t/m4SKQ2j6Ipv7NyUolw==}
- hookable@5.5.3:
- resolution: {integrity: sha512-Yc+BQe8SvoXH1643Qez1zqLRmbA5rCL+sSmk6TVos0LWVfNIB7PGncdlId77WzLGSIB5KaWgTaNTs2lNVEI6VQ==}
-
hosted-git-info@2.8.9:
resolution: {integrity: sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==}
@@ -2850,9 +2460,6 @@ packages:
import-meta-resolve@4.1.0:
resolution: {integrity: sha512-I6fiaX09Xivtk+THaMfAwnA3MVA5Big1WHF1Dfx9hFuvNIWpXnorlkzhcQf6ehrqQiiZECRt1poOAkPmer3ruw==}
- importx@0.4.4:
- resolution: {integrity: sha512-Lo1pukzAREqrBnnHC+tj+lreMTAvyxtkKsMxLY8H15M/bvLl54p3YuoTI70Tz7Il0AsgSlD7Lrk/FaApRcBL7w==}
-
imurmurhash@0.1.4:
resolution: {integrity: sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==}
engines: {node: '>=0.8.19'}
@@ -2952,10 +2559,6 @@ packages:
is-what@3.14.1:
resolution: {integrity: sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==}
- is-what@4.1.16:
- resolution: {integrity: sha512-ZhMwEosbFJkA0YhFnNDgTM4ZxDRsS6HqTo7qsZM08fehyRYIYa0yHu5R6mgo1n/8MgaPBXiPimPD77baVFYg+A==}
- engines: {node: '>=12.13'}
-
is-wsl@3.1.0:
resolution: {integrity: sha512-UcVfVfaK4Sc4m7X3dUSoHoozQGBEFeDC+zVo06t98xe8CzHSZZBekNXH+tu0NalHolcJ/QAGqS46Hef7QXBIMw==}
engines: {node: '>=16'}
@@ -2971,10 +2574,6 @@ packages:
resolution: {integrity: sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==}
hasBin: true
- jiti@2.0.0-beta.3:
- resolution: {integrity: sha512-pmfRbVRs/7khFrSAYnSiJ8C0D5GvzkE4Ey2pAvUcJsw1ly/p+7ut27jbJrjY79BpAJQJ4gXYFtK6d1Aub+9baQ==}
- hasBin: true
-
joycon@3.1.1:
resolution: {integrity: sha512-34wB/Y7MW7bzjKRjUKTa46I2Z7eV62Rkhva+KkopW7Qvv/OSWBqvkSY7vusOPrNuZcUG3tApvdVgNB8POj3SPw==}
engines: {node: '>=10'}
@@ -3048,9 +2647,6 @@ packages:
resolution: {integrity: sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==}
engines: {node: '>=6'}
- kolorist@1.8.0:
- resolution: {integrity: sha512-Y+60/zizpJ3HRH8DCss+q95yr6145JXZo46OTpFvDZWLfRCE4qChOyk1b26nMaNpfHHgxagk9dXT5OP0Tfe+dQ==}
-
less@4.2.0:
resolution: {integrity: sha512-P3b3HJDBtSzsXUl0im2L7gTO5Ubg8mEN6G8qoTS77iXxXX4Hvu4Qj540PZDvQ8V6DmX6iXo98k7Md0Cm1PrLaA==}
engines: {node: '>=6'}
@@ -3107,10 +2703,6 @@ packages:
longest-streak@3.1.0:
resolution: {integrity: sha512-9Ri+o0JYgehTaVBBDoMqIl8GXtbWg711O3srftcHhZ0dqnETqLaoIK0x17fUw9rFSlK/0NlsKe0Ahhyl5pXE2g==}
- loose-envify@1.4.0:
- resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==}
- hasBin: true
-
loupe@3.1.2:
resolution: {integrity: sha512-23I4pFZHmAemUnz8WZXbYRSKYj801VDaNv9ETuMh7IrMc7VuVVSo+Z9iLE3ni30+U48iDWfi30d3twAXBYmnCg==}
@@ -3131,9 +2723,6 @@ packages:
resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==}
engines: {node: '>=6'}
- mark.js@8.11.1:
- resolution: {integrity: sha512-1I+1qpDt4idfgLQG+BNWmrqku+7/2bi5nLf4YwF8y8zXvmfiTBY3PV3ZibfrjBueCByROpuBjLLFCajqkgYoLQ==}
-
markdown-extensions@2.0.0:
resolution: {integrity: sha512-o5vL7aDWatOTX8LzaS1WMoaoxIiLRQJuIKKe2wAw6IeULDHaqbiqiggmx+pKvZDb1Sj+pE46Sn1T7lCqfFtg1Q==}
engines: {node: '>=16'}
@@ -3195,9 +2784,6 @@ packages:
mdast-util-to-string@4.0.0:
resolution: {integrity: sha512-0H44vDimn51F0YwvxSJSm0eCDOJTRlmN0R1yBh4HLj9wiV1Dn0QoXGbvFAWj2hSItVTlCmBF1hqKlIyUBVFLPg==}
- mdn-data@2.12.1:
- resolution: {integrity: sha512-rsfnCbOHjqrhWxwt5/wtSLzpoKTzW7OXdT5lLOIH1OTYhWu9rRJveGq0sKvDZODABH7RX+uoR+DYcpFnq4Tf6Q==}
-
merge2@1.4.1:
resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==}
engines: {node: '>= 8'}
@@ -3342,12 +2928,6 @@ packages:
resolution: {integrity: sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==}
engines: {node: '>=16 || 14 >=14.17'}
- minisearch@7.1.0:
- resolution: {integrity: sha512-tv7c/uefWdEhcu6hvrfTihflgeEi2tN6VV7HJnCjK6VxM75QQJh4t9FwJCsA2EsRS8LCnu3W87CuGPWMocOLCA==}
-
- mitt@3.0.1:
- resolution: {integrity: sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==}
-
mlly@1.7.2:
resolution: {integrity: sha512-tN3dvVHYVz4DhSXinXIk7u9syPYaJvio118uomkovAtWBT+RdbP6Lfh/5Lvo519YMmwBafwlh20IPTXIStscpA==}
@@ -3390,9 +2970,6 @@ packages:
nlcst-to-string@4.0.0:
resolution: {integrity: sha512-YKLBCcUYKAg0FNlOBT6aI91qFmSiFKiluk655WzPF+DDMA02qIyy8uiRqI8QXtcFpEvll12LpL5MXqEmAZ+dcA==}
- node-fetch-native@1.6.4:
- resolution: {integrity: sha512-IhOigYzAKHd244OC0JIMIUrjzctirCmPkaIfhDeGcEETWof5zKYUW7e7MYvChGWh/4CJeXEgsRyGzuF334rOOQ==}
-
node-releases@2.0.18:
resolution: {integrity: sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==}
@@ -3418,9 +2995,6 @@ packages:
resolution: {integrity: sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==}
engines: {node: '>= 6'}
- ofetch@1.4.1:
- resolution: {integrity: sha512-QZj2DfGplQAr2oj9KzceK9Hwz6Whxazmn85yYeVuS3u9XTMOGMRx0kO95MQ+vLsj/S/NwBDMMLU5hpxvI6Tklw==}
-
onetime@7.0.0:
resolution: {integrity: sha512-VXJjc87FScF88uafS3JllDgvAm+c/Slfz06lorj2uAY34rlUu0Nt+v8wreiImcrgAjjIHp1rXpTDlLOGw29WwQ==}
engines: {node: '>=18'}
@@ -3533,9 +3107,6 @@ packages:
resolution: {integrity: sha512-vE7JKRyES09KiunauX7nd2Q9/L7lhok4smP9RZTDeD4MVs72Dp2qNFVz39Nz5a0FVEW0BJR6C0DYrq6unoziZA==}
engines: {node: '>= 14.16'}
- perfect-debounce@1.0.0:
- resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==}
-
picocolors@1.1.1:
resolution: {integrity: sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==}
@@ -3637,9 +3208,6 @@ packages:
resolution: {integrity: sha512-OCVPnIObs4N29kxTjzLfUryOkvZEq+pf8jTF0lg8E7uETuWHA+v7j3c/xJmiqpX450191LlmZfUKkXxkTry7nA==}
engines: {node: ^10 || ^12 || >=14}
- preact@10.20.2:
- resolution: {integrity: sha512-S1d1ernz3KQ+Y2awUxKakpfOg2CEmJmwOP+6igPx6dgr6pgDvenqYviyokWso2rhHvGtTlWWnJDa7RaPbQerTg==}
-
preferred-pm@4.0.0:
resolution: {integrity: sha512-gYBeFTZLu055D8Vv3cSPox/0iTPtkzxpLroSYYA7WXgRi31WCJ51Uyl8ZiPeUUjyvs2MBzK+S8v9JVUgHU/Sqw==}
engines: {node: '>=18.12'}
@@ -3674,15 +3242,6 @@ packages:
queue-microtask@1.2.3:
resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==}
- react-dom@18.3.1:
- resolution: {integrity: sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==}
- peerDependencies:
- react: ^18.3.1
-
- react@18.3.1:
- resolution: {integrity: sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==}
- engines: {node: '>=0.10.0'}
-
read-cache@1.0.0:
resolution: {integrity: sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==}
@@ -3828,9 +3387,6 @@ packages:
resolution: {integrity: sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==}
engines: {iojs: '>=1.0.0', node: '>=0.10.0'}
- rfdc@1.4.1:
- resolution: {integrity: sha512-q1b3N5QkRUWUl7iyylaaj3kOpIT0N2i9MqIEQXP73GVsN9cw3fdx8X63cEmWhJGi2PPCF23Ijp7ktmd39rawIA==}
-
rollup@4.24.3:
resolution: {integrity: sha512-HBW896xR5HGmoksbi3JBDtmVzWiPAYqp7wip50hjQ67JbDz61nyoMPdqu1DvVW9asYb2M65Z20ZHsyJCMqMyDg==}
engines: {node: '>=18.0.0', npm: '>=8.0.0'}
@@ -3845,16 +3401,10 @@ packages:
sax@1.3.0:
resolution: {integrity: sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==}
- scheduler@0.23.2:
- resolution: {integrity: sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==}
-
scslre@0.3.0:
resolution: {integrity: sha512-3A6sD0WYP7+QrjbfNA2FN3FsOaGGFoekCVgTyypy53gPxhbkCIjtO6YWgdrfM+n/8sI8JeXZOIxsHjMTNxQ4nQ==}
engines: {node: ^14.0.0 || >=16.0.0}
- search-insights@2.13.0:
- resolution: {integrity: sha512-Orrsjf9trHHxFRuo9/rzm0KIWmgzE8RMlZMzuhZOJ01Rnz3D0YBAe+V6473t6/H6c7irs6Lt48brULAiRWb3Vw==}
-
section-matter@1.0.0:
resolution: {integrity: sha512-vfD3pmTzGpufjScBh50YHKzEu2lxBWhVEHsNGoEXmCmn2hKGfeNLYMzCJpe8cD7gqX7TJluOVpBkAequ6dgMmA==}
engines: {node: '>=4'}
@@ -3894,16 +3444,9 @@ packages:
resolution: {integrity: sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==}
engines: {node: '>=14'}
- simple-git@3.27.0:
- resolution: {integrity: sha512-ivHoFS9Yi9GY49ogc6/YAi3Fl9ROnF4VyubNylgCkA+RVqLaKWnDSzXOVzya8csELIaWaYNutsEuAhZrtOjozA==}
-
simple-swizzle@0.2.2:
resolution: {integrity: sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==}
- sirv@2.0.4:
- resolution: {integrity: sha512-94Bdh3cC2PKrbgSOUqTiGPWVZeSiXfKOVZNJniWoqrWrRkB1CJzBU3NEbiTsPcYy1lDsANA/THzS+9WBiy5nfQ==}
- engines: {node: '>= 10'}
-
sisteransi@1.0.5:
resolution: {integrity: sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==}
@@ -3953,10 +3496,6 @@ packages:
spdx-license-ids@3.0.18:
resolution: {integrity: sha512-xxRs31BqRYHwiMzudOrpSiHtZ8i/GeionCBDSilhYRj+9gIcI8wCZTlXZKu9vZIVqViP3dcp9qE5G6AlIaD+TQ==}
- speakingurl@14.0.1:
- resolution: {integrity: sha512-1POYv7uv2gXoyGFpBCmpDVSNV74IfsWlDW216UPjbWufNf+bSU6GdbDsxdcxtfwb4xlI3yxzOTKClUosxARYrQ==}
- engines: {node: '>=0.10.0'}
-
sprintf-js@1.0.3:
resolution: {integrity: sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==}
@@ -4038,10 +3577,6 @@ packages:
engines: {node: '>=16 || 14 >=14.17'}
hasBin: true
- superjson@2.2.1:
- resolution: {integrity: sha512-8iGv75BYOa0xRJHK5vRLEjE2H/i4lulTjzpUXic3Eg8akftYjkmQDa8JARQ42rlczXyFR3IeRoeFCc7RxHsYZA==}
- engines: {node: '>=16'}
-
supports-color@7.2.0:
resolution: {integrity: sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==}
engines: {node: '>=8'}
@@ -4058,9 +3593,6 @@ packages:
resolution: {integrity: sha512-7gr8p9TQP6RAHusBOSLs46F4564ZrjV8xFmw5zCmgmhGUcw2hxsShhJ6CEiHQMgPDwAQ1fWHPM0ypc4RMAig4A==}
engines: {node: ^14.18.0 || >=16.0.0}
- tabbable@6.2.0:
- resolution: {integrity: sha512-Cat63mxsVJlzYvN51JmVXIgNoUokrIaT2zLclCXjRd8boZ0004U4KCs/sToJ75C6sdlByWxpYnb5Boif1VSFew==}
-
tailwindcss@3.4.15:
resolution: {integrity: sha512-r4MeXnfBmSOuKUWmXe6h2CcyfzJCEk4F0pptO5jlnYSIViUkVmsawj80N5h2lO3gwcmSb4n3PuN+e+GC1Guylw==}
engines: {node: '>=14.0.0'}
@@ -4107,10 +3639,6 @@ packages:
resolution: {integrity: sha512-khrZo4buq4qVmsGzS5yQjKe/WsFvV8fGfOjDQN0q4iy9FjRfPWRgTFrU8u1R2iu/SfWLhY9WnCi4Jhdrcbtg+g==}
engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0}
- totalist@3.0.1:
- resolution: {integrity: sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ==}
- engines: {node: '>=6'}
-
tr46@1.0.1:
resolution: {integrity: sha512-dTpowEjclQ7Kgx5SdBkqRzVhERQXov8/l9Ft9dVM9fmg0W0KQSVaXX9T4i6twCPNtYiZM53lpSSUAwJbFPOHxA==}
@@ -4209,12 +3737,6 @@ packages:
ufo@1.5.4:
resolution: {integrity: sha512-UsUk3byDzKd04EyoZ7U4DOlxQaD14JUKQl6/P7wiX4FNvUfm3XL246n9W5AmqwW5RSFJ27NAuM0iLscAOYUiGQ==}
- unconfig@0.5.5:
- resolution: {integrity: sha512-VQZ5PT9HDX+qag0XdgQi8tJepPhXiR/yVOkn707gJDKo31lGjRilPREiQJ9Z6zd/Ugpv6ZvO5VxVIcatldYcNQ==}
-
- uncrypto@0.1.3:
- resolution: {integrity: sha512-Ql87qFHB3s/De2ClA9e0gsnS6zXG27SkTiSJwjCc9MebbfapQfuPzumMIUMi38ezPZVNFcHI9sUIepeQfw8J8Q==}
-
undici-types@6.19.8:
resolution: {integrity: sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==}
@@ -4251,18 +3773,6 @@ packages:
unist-util-visit@5.0.0:
resolution: {integrity: sha512-MR04uvD+07cwl/yhVuVWAtw+3GOR/knlL55Nd/wAdblk27GCVt3lqpTivy/tkJcZoNPzTwS1Y+KMojlLDhoTzg==}
- unocss@0.64.1:
- resolution: {integrity: sha512-UTtK9TPneVht5r0cVEADS/N6970AoHhKvJKDkBPnk7OQdguIFPCykGyx4llukItzm0AoffGfwg5zQ+L8QJgupw==}
- engines: {node: '>=14'}
- peerDependencies:
- '@unocss/webpack': 0.64.1
- vite: ^2.9.0 || ^3.0.0-0 || ^4.0.0 || ^5.0.0-0
- peerDependenciesMeta:
- '@unocss/webpack':
- optional: true
- vite:
- optional: true
-
update-browserslist-db@1.1.1:
resolution: {integrity: sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A==}
hasBin: true
@@ -4331,18 +3841,6 @@ packages:
vite:
optional: true
- vitepress@1.5.0:
- resolution: {integrity: sha512-q4Q/G2zjvynvizdB3/bupdYkCJe2umSAMv9Ju4d92E6/NXJ59z70xB0q5p/4lpRyAwflDsbwy1mLV9Q5+nlB+g==}
- hasBin: true
- peerDependencies:
- markdown-it-mathjax3: ^4
- postcss: ^8
- peerDependenciesMeta:
- markdown-it-mathjax3:
- optional: true
- postcss:
- optional: true
-
vitest@2.1.5:
resolution: {integrity: sha512-P4ljsdpuzRTPI/kbND2sDZ4VmieerR2c9szEZpjc+98Z9ebvnXmM5+0tHEKqYZumXqlvnmfWsjeFOjXVriDG7A==}
engines: {node: ^18.0.0 || >=20.0.0}
@@ -4474,36 +3972,12 @@ packages:
vscode-uri@3.0.8:
resolution: {integrity: sha512-AyFQ0EVmsOZOlAnxoFOGOq1SQDWAB7C6aqMGS23svWAllfOaxbuFvcT8D1i8z3Gyn8fraVeZNNmN6e9bxxXkKw==}
- vue-demi@0.14.10:
- resolution: {integrity: sha512-nMZBOwuzabUO0nLgIcc6rycZEebF6eeUfaiQx9+WSk8e29IbLvPU9feI6tqW4kTo3hvoYAJkMh8n8D0fuISphg==}
- engines: {node: '>=12'}
- hasBin: true
- peerDependencies:
- '@vue/composition-api': ^1.0.0-rc.1
- vue: ^3.0.0-0 || ^2.6.0
- peerDependenciesMeta:
- '@vue/composition-api':
- optional: true
-
vue-eslint-parser@9.4.3:
resolution: {integrity: sha512-2rYRLWlIpaiN8xbPiDyXZXRgLGOtWxERV7ND5fFAv5qo1D2N9Fu9MNajBNc6o13lZ+24DAWCkQCvj4klgmcITg==}
engines: {node: ^14.17.0 || >=16.0.0}
peerDependencies:
eslint: '>=6.0.0'
- vue-flow-layout@0.1.1:
- resolution: {integrity: sha512-JdgRRUVrN0Y2GosA0M68DEbKlXMqJ7FQgsK8CjQD2vxvNSqAU6PZEpi4cfcTVtfM2GVOMjHo7GKKLbXxOBqDqA==}
- peerDependencies:
- vue: ^3.4.37
-
- vue@3.5.13:
- resolution: {integrity: sha512-wmeiSMxkZCSc+PM2w2VRsOYAZC8GdipNFRTsLSfodVqI9mbejKeXEGr8SckuLnrQPGe3oJN5c3K0vpoU9q/wCQ==}
- peerDependencies:
- typescript: '*'
- peerDependenciesMeta:
- typescript:
- optional: true
-
web-namespaces@2.0.1:
resolution: {integrity: sha512-bKr1DkiNa2krS7qxNtdrtHAmzuYGFQLiQ13TsorsdT6ULTkPLKuu5+GsFpDlg6JFjUTwX2DyhMPG2be8uPrqsQ==}
@@ -4617,110 +4091,6 @@ packages:
snapshots:
- '@algolia/autocomplete-core@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.13.0)':
- dependencies:
- '@algolia/autocomplete-plugin-algolia-insights': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.13.0)
- '@algolia/autocomplete-shared': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)
- transitivePeerDependencies:
- - '@algolia/client-search'
- - algoliasearch
- - search-insights
-
- '@algolia/autocomplete-plugin-algolia-insights@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.13.0)':
- dependencies:
- '@algolia/autocomplete-shared': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)
- search-insights: 2.13.0
- transitivePeerDependencies:
- - '@algolia/client-search'
- - algoliasearch
-
- '@algolia/autocomplete-preset-algolia@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)':
- dependencies:
- '@algolia/autocomplete-shared': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)
- '@algolia/client-search': 4.23.3
- algoliasearch: 4.23.3
-
- '@algolia/autocomplete-shared@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)':
- dependencies:
- '@algolia/client-search': 4.23.3
- algoliasearch: 4.23.3
-
- '@algolia/cache-browser-local-storage@4.23.3':
- dependencies:
- '@algolia/cache-common': 4.23.3
-
- '@algolia/cache-common@4.23.3': {}
-
- '@algolia/cache-in-memory@4.23.3':
- dependencies:
- '@algolia/cache-common': 4.23.3
-
- '@algolia/client-account@4.23.3':
- dependencies:
- '@algolia/client-common': 4.23.3
- '@algolia/client-search': 4.23.3
- '@algolia/transporter': 4.23.3
-
- '@algolia/client-analytics@4.23.3':
- dependencies:
- '@algolia/client-common': 4.23.3
- '@algolia/client-search': 4.23.3
- '@algolia/requester-common': 4.23.3
- '@algolia/transporter': 4.23.3
-
- '@algolia/client-common@4.23.3':
- dependencies:
- '@algolia/requester-common': 4.23.3
- '@algolia/transporter': 4.23.3
-
- '@algolia/client-personalization@4.23.3':
- dependencies:
- '@algolia/client-common': 4.23.3
- '@algolia/requester-common': 4.23.3
- '@algolia/transporter': 4.23.3
-
- '@algolia/client-search@4.23.3':
- dependencies:
- '@algolia/client-common': 4.23.3
- '@algolia/requester-common': 4.23.3
- '@algolia/transporter': 4.23.3
-
- '@algolia/logger-common@4.23.3': {}
-
- '@algolia/logger-console@4.23.3':
- dependencies:
- '@algolia/logger-common': 4.23.3
-
- '@algolia/recommend@4.23.3':
- dependencies:
- '@algolia/cache-browser-local-storage': 4.23.3
- '@algolia/cache-common': 4.23.3
- '@algolia/cache-in-memory': 4.23.3
- '@algolia/client-common': 4.23.3
- '@algolia/client-search': 4.23.3
- '@algolia/logger-common': 4.23.3
- '@algolia/logger-console': 4.23.3
- '@algolia/requester-browser-xhr': 4.23.3
- '@algolia/requester-common': 4.23.3
- '@algolia/requester-node-http': 4.23.3
- '@algolia/transporter': 4.23.3
-
- '@algolia/requester-browser-xhr@4.23.3':
- dependencies:
- '@algolia/requester-common': 4.23.3
-
- '@algolia/requester-common@4.23.3': {}
-
- '@algolia/requester-node-http@4.23.3':
- dependencies:
- '@algolia/requester-common': 4.23.3
-
- '@algolia/transporter@4.23.3':
- dependencies:
- '@algolia/cache-common': 4.23.3
- '@algolia/logger-common': 4.23.3
- '@algolia/requester-common': 4.23.3
-
'@alloc/quick-lru@5.2.0': {}
'@ampproject/remapping@2.3.0':
@@ -5079,33 +4449,6 @@ snapshots:
'@ctrl/tinycolor@4.1.0': {}
- '@docsearch/css@3.6.2': {}
-
- '@docsearch/js@3.6.2(@algolia/client-search@4.23.3)(@types/react@18.3.12)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)':
- dependencies:
- '@docsearch/react': 3.6.2(@algolia/client-search@4.23.3)(@types/react@18.3.12)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)
- preact: 10.20.2
- transitivePeerDependencies:
- - '@algolia/client-search'
- - '@types/react'
- - react
- - react-dom
- - search-insights
-
- '@docsearch/react@3.6.2(@algolia/client-search@4.23.3)(@types/react@18.3.12)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)':
- dependencies:
- '@algolia/autocomplete-core': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.13.0)
- '@algolia/autocomplete-preset-algolia': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)
- '@docsearch/css': 3.6.2
- algoliasearch: 4.23.3
- optionalDependencies:
- '@types/react': 18.3.12
- react: 18.3.1
- react-dom: 18.3.1(react@18.3.1)
- search-insights: 2.13.0
- transitivePeerDependencies:
- - '@algolia/client-search'
-
'@emmetio/abbreviation@2.3.3':
dependencies:
'@emmetio/scanner': 1.0.4
@@ -5466,48 +4809,18 @@ snapshots:
'@humanwhocodes/retry@0.4.1': {}
- '@iconify-json/carbon@1.2.4':
- dependencies:
- '@iconify/types': 2.0.0
+ '@img/sharp-darwin-arm64@0.33.5':
+ optionalDependencies:
+ '@img/sharp-libvips-darwin-arm64': 1.0.4
+ optional: true
- '@iconify-json/icon-park-outline@1.2.1':
- dependencies:
- '@iconify/types': 2.0.0
+ '@img/sharp-darwin-x64@0.33.5':
+ optionalDependencies:
+ '@img/sharp-libvips-darwin-x64': 1.0.4
+ optional: true
- '@iconify-json/octicon@1.2.1':
- dependencies:
- '@iconify/types': 2.0.0
-
- '@iconify-json/simple-icons@1.2.11':
- dependencies:
- '@iconify/types': 2.0.0
-
- '@iconify/types@2.0.0': {}
-
- '@iconify/utils@2.1.33':
- dependencies:
- '@antfu/install-pkg': 0.4.1
- '@antfu/utils': 0.7.10
- '@iconify/types': 2.0.0
- debug: 4.3.7
- kolorist: 1.8.0
- local-pkg: 0.5.0
- mlly: 1.7.2
- transitivePeerDependencies:
- - supports-color
-
- '@img/sharp-darwin-arm64@0.33.5':
- optionalDependencies:
- '@img/sharp-libvips-darwin-arm64': 1.0.4
- optional: true
-
- '@img/sharp-darwin-x64@0.33.5':
- optionalDependencies:
- '@img/sharp-libvips-darwin-x64': 1.0.4
- optional: true
-
- '@img/sharp-libvips-darwin-arm64@1.0.4':
- optional: true
+ '@img/sharp-libvips-darwin-arm64@1.0.4':
+ optional: true
'@img/sharp-libvips-darwin-x64@1.0.4':
optional: true
@@ -5610,14 +4923,6 @@ snapshots:
'@jridgewell/resolve-uri': 3.1.2
'@jridgewell/sourcemap-codec': 1.5.0
- '@kwsites/file-exists@1.1.1':
- dependencies:
- debug: 4.3.7
- transitivePeerDependencies:
- - supports-color
-
- '@kwsites/promise-deferred@1.1.1': {}
-
'@mdx-js/mdx@3.1.0(acorn@8.14.0)':
dependencies:
'@types/estree': 1.0.6
@@ -5660,153 +4965,6 @@ snapshots:
'@nodelib/fs.scandir': 2.1.5
fastq: 1.17.1
- '@nolebase/ui@2.7.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)':
- dependencies:
- '@iconify-json/octicon': 1.2.1
- less: 4.2.0
- vitepress: 1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- vue: 3.5.13(typescript@5.6.3)
- transitivePeerDependencies:
- - '@algolia/client-search'
- - '@types/node'
- - '@types/react'
- - '@vue/composition-api'
- - async-validator
- - axios
- - change-case
- - drauu
- - fuse.js
- - idb-keyval
- - jwt-decode
- - lightningcss
- - markdown-it-mathjax3
- - nprogress
- - postcss
- - qrcode
- - react
- - react-dom
- - sass
- - sass-embedded
- - search-insights
- - sortablejs
- - stylus
- - sugarss
- - terser
- - typescript
- - universal-cookie
-
- '@nolebase/ui@2.9.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)':
- dependencies:
- '@iconify-json/octicon': 1.2.1
- less: 4.2.0
- vitepress: 1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- vue: 3.5.13(typescript@5.6.3)
- transitivePeerDependencies:
- - '@algolia/client-search'
- - '@types/node'
- - '@types/react'
- - '@vue/composition-api'
- - async-validator
- - axios
- - change-case
- - drauu
- - fuse.js
- - idb-keyval
- - jwt-decode
- - lightningcss
- - markdown-it-mathjax3
- - nprogress
- - postcss
- - qrcode
- - react
- - react-dom
- - sass
- - sass-embedded
- - search-insights
- - sortablejs
- - stylus
- - sugarss
- - terser
- - typescript
- - universal-cookie
-
- '@nolebase/vitepress-plugin-enhanced-readabilities@2.9.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)':
- dependencies:
- '@iconify-json/carbon': 1.2.4
- '@iconify-json/icon-park-outline': 1.2.1
- '@nolebase/ui': 2.9.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- less: 4.2.0
- vitepress: 1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- transitivePeerDependencies:
- - '@algolia/client-search'
- - '@types/node'
- - '@types/react'
- - '@vue/composition-api'
- - async-validator
- - axios
- - change-case
- - drauu
- - fuse.js
- - idb-keyval
- - jwt-decode
- - lightningcss
- - markdown-it-mathjax3
- - nprogress
- - postcss
- - qrcode
- - react
- - react-dom
- - sass
- - sass-embedded
- - search-insights
- - sortablejs
- - stylus
- - sugarss
- - terser
- - typescript
- - universal-cookie
-
- '@nolebase/vitepress-plugin-git-changelog@2.0.0-rc5(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)(vitepress@1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3))':
- dependencies:
- '@nolebase/ui': 2.7.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- colorette: 2.0.20
- date-fns: 3.6.0
- gray-matter: 4.0.3
- less: 4.2.0
- ora: 8.1.1
- simple-git: 3.27.0
- uncrypto: 0.1.3
- vitepress: 1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3)
- transitivePeerDependencies:
- - '@algolia/client-search'
- - '@types/node'
- - '@types/react'
- - '@vue/composition-api'
- - async-validator
- - axios
- - change-case
- - drauu
- - fuse.js
- - idb-keyval
- - jwt-decode
- - lightningcss
- - markdown-it-mathjax3
- - nprogress
- - postcss
- - qrcode
- - react
- - react-dom
- - sass
- - sass-embedded
- - search-insights
- - sortablejs
- - stylus
- - sugarss
- - supports-color
- - terser
- - typescript
- - universal-cookie
-
'@oslojs/encoding@1.1.0': {}
'@pagefind/darwin-arm64@1.2.0':
@@ -5831,10 +4989,6 @@ snapshots:
'@pkgr/core@0.1.1': {}
- '@polka/url@1.0.0-next.25': {}
-
- '@radix-ui/colors@3.0.0': {}
-
'@rollup/pluginutils@5.1.3(rollup@4.24.3)':
dependencies:
'@types/estree': 1.0.6
@@ -5917,10 +5071,6 @@ snapshots:
'@shikijs/types': 1.22.2
'@shikijs/vscode-textmate': 9.3.0
- '@shikijs/transformers@1.22.2':
- dependencies:
- shiki: 1.22.2
-
'@shikijs/types@1.22.2':
dependencies:
'@shikijs/vscode-textmate': 9.3.0
@@ -5990,19 +5140,10 @@ snapshots:
'@types/json-schema@7.0.15': {}
- '@types/linkify-it@5.0.0': {}
-
- '@types/markdown-it@14.1.2':
- dependencies:
- '@types/linkify-it': 5.0.0
- '@types/mdurl': 2.0.0
-
'@types/mdast@4.0.4':
dependencies:
'@types/unist': 3.0.3
- '@types/mdurl@2.0.0': {}
-
'@types/mdx@2.0.13': {}
'@types/ms@0.7.34': {}
@@ -6019,15 +5160,6 @@ snapshots:
'@types/normalize-package-data@2.4.4': {}
- '@types/prop-types@15.7.13':
- optional: true
-
- '@types/react@18.3.12':
- dependencies:
- '@types/prop-types': 15.7.13
- csstype: 3.1.3
- optional: true
-
'@types/sax@1.2.7':
dependencies:
'@types/node': 22.9.0
@@ -6036,8 +5168,6 @@ snapshots:
'@types/unist@3.0.3': {}
- '@types/web-bluetooth@0.0.20': {}
-
'@typescript-eslint/eslint-plugin@8.15.0(@typescript-eslint/parser@8.15.0(eslint@9.15.0(jiti@1.21.6))(typescript@5.6.3))(eslint@9.15.0(jiti@1.21.6))(typescript@5.6.3)':
dependencies:
'@eslint-community/regexpp': 4.11.0
@@ -6172,162 +5302,6 @@ snapshots:
'@ungap/structured-clone@1.2.0': {}
- '@unocss/astro@0.64.1(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/reset': 0.64.1
- '@unocss/vite': 0.64.1(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))
- optionalDependencies:
- vite: 5.4.10(@types/node@22.9.0)(less@4.2.0)
- transitivePeerDependencies:
- - rollup
- - supports-color
- - vue
-
- '@unocss/cli@0.64.1(rollup@4.24.3)':
- dependencies:
- '@ampproject/remapping': 2.3.0
- '@rollup/pluginutils': 5.1.3(rollup@4.24.3)
- '@unocss/config': 0.64.1
- '@unocss/core': 0.64.1
- '@unocss/preset-uno': 0.64.1
- cac: 6.7.14
- chokidar: 3.6.0
- colorette: 2.0.20
- consola: 3.2.3
- magic-string: 0.30.12
- pathe: 1.1.2
- perfect-debounce: 1.0.0
- tinyglobby: 0.2.10
- transitivePeerDependencies:
- - rollup
- - supports-color
-
- '@unocss/config@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- unconfig: 0.5.5
- transitivePeerDependencies:
- - supports-color
-
- '@unocss/core@0.64.1': {}
-
- '@unocss/extractor-arbitrary-variants@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
-
- '@unocss/inspector@0.64.1(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/rule-utils': 0.64.1
- gzip-size: 6.0.0
- sirv: 2.0.4
- vue-flow-layout: 0.1.1(vue@3.5.13(typescript@5.6.3))
- transitivePeerDependencies:
- - vue
-
- '@unocss/postcss@0.64.1(postcss@8.4.49)':
- dependencies:
- '@unocss/config': 0.64.1
- '@unocss/core': 0.64.1
- '@unocss/rule-utils': 0.64.1
- css-tree: 3.0.1
- postcss: 8.4.49
- tinyglobby: 0.2.10
- transitivePeerDependencies:
- - supports-color
-
- '@unocss/preset-attributify@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
-
- '@unocss/preset-icons@0.64.1':
- dependencies:
- '@iconify/utils': 2.1.33
- '@unocss/core': 0.64.1
- ofetch: 1.4.1
- transitivePeerDependencies:
- - supports-color
-
- '@unocss/preset-mini@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/extractor-arbitrary-variants': 0.64.1
- '@unocss/rule-utils': 0.64.1
-
- '@unocss/preset-tagify@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
-
- '@unocss/preset-typography@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/preset-mini': 0.64.1
-
- '@unocss/preset-uno@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/preset-mini': 0.64.1
- '@unocss/preset-wind': 0.64.1
- '@unocss/rule-utils': 0.64.1
-
- '@unocss/preset-web-fonts@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- ofetch: 1.4.1
-
- '@unocss/preset-wind@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/preset-mini': 0.64.1
- '@unocss/rule-utils': 0.64.1
-
- '@unocss/reset@0.64.1': {}
-
- '@unocss/rule-utils@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- magic-string: 0.30.12
-
- '@unocss/transformer-attributify-jsx@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
-
- '@unocss/transformer-compile-class@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
-
- '@unocss/transformer-directives@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
- '@unocss/rule-utils': 0.64.1
- css-tree: 3.0.1
-
- '@unocss/transformer-variant-group@0.64.1':
- dependencies:
- '@unocss/core': 0.64.1
-
- '@unocss/vite@0.64.1(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- '@ampproject/remapping': 2.3.0
- '@rollup/pluginutils': 5.1.3(rollup@4.24.3)
- '@unocss/config': 0.64.1
- '@unocss/core': 0.64.1
- '@unocss/inspector': 0.64.1(vue@3.5.13(typescript@5.6.3))
- chokidar: 3.6.0
- magic-string: 0.30.12
- tinyglobby: 0.2.10
- vite: 5.4.10(@types/node@22.9.0)(less@4.2.0)
- transitivePeerDependencies:
- - rollup
- - supports-color
- - vue
-
- '@vitejs/plugin-vue@5.1.4(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- vite: 5.4.10(@types/node@22.9.0)(less@4.2.0)
- vue: 3.5.13(typescript@5.6.3)
-
'@vitest/eslint-plugin@1.1.10(@typescript-eslint/utils@8.15.0(eslint@9.15.0(jiti@1.21.6))(typescript@5.6.3))(eslint@9.15.0(jiti@1.21.6))(typescript@5.6.3)(vitest@2.1.5(@types/node@22.9.0)(less@4.2.0))':
dependencies:
'@typescript-eslint/utils': 8.15.0(eslint@9.15.0(jiti@1.21.6))(typescript@5.6.3)
@@ -6456,80 +5430,8 @@ snapshots:
'@vue/compiler-dom': 3.5.13
'@vue/shared': 3.5.13
- '@vue/devtools-api@7.6.1':
- dependencies:
- '@vue/devtools-kit': 7.6.1
-
- '@vue/devtools-kit@7.6.1':
- dependencies:
- '@vue/devtools-shared': 7.6.1
- birpc: 0.2.19
- hookable: 5.5.3
- mitt: 3.0.1
- perfect-debounce: 1.0.0
- speakingurl: 14.0.1
- superjson: 2.2.1
-
- '@vue/devtools-shared@7.6.1':
- dependencies:
- rfdc: 1.4.1
-
- '@vue/reactivity@3.5.13':
- dependencies:
- '@vue/shared': 3.5.13
-
- '@vue/runtime-core@3.5.13':
- dependencies:
- '@vue/reactivity': 3.5.13
- '@vue/shared': 3.5.13
-
- '@vue/runtime-dom@3.5.13':
- dependencies:
- '@vue/reactivity': 3.5.13
- '@vue/runtime-core': 3.5.13
- '@vue/shared': 3.5.13
- csstype: 3.1.3
-
- '@vue/server-renderer@3.5.13(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- '@vue/compiler-ssr': 3.5.13
- '@vue/shared': 3.5.13
- vue: 3.5.13(typescript@5.6.3)
-
- '@vue/shared@3.5.12': {}
-
'@vue/shared@3.5.13': {}
- '@vueuse/core@11.2.0(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- '@types/web-bluetooth': 0.0.20
- '@vueuse/metadata': 11.2.0
- '@vueuse/shared': 11.2.0(vue@3.5.13(typescript@5.6.3))
- vue-demi: 0.14.10(vue@3.5.13(typescript@5.6.3))
- transitivePeerDependencies:
- - '@vue/composition-api'
- - vue
-
- '@vueuse/integrations@11.2.0(focus-trap@7.6.0)(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- '@vueuse/core': 11.2.0(vue@3.5.13(typescript@5.6.3))
- '@vueuse/shared': 11.2.0(vue@3.5.13(typescript@5.6.3))
- vue-demi: 0.14.10(vue@3.5.13(typescript@5.6.3))
- optionalDependencies:
- focus-trap: 7.6.0
- transitivePeerDependencies:
- - '@vue/composition-api'
- - vue
-
- '@vueuse/metadata@11.2.0': {}
-
- '@vueuse/shared@11.2.0(vue@3.5.13(typescript@5.6.3))':
- dependencies:
- vue-demi: 0.14.10(vue@3.5.13(typescript@5.6.3))
- transitivePeerDependencies:
- - '@vue/composition-api'
- - vue
-
acorn-jsx@5.3.2(acorn@8.14.0):
dependencies:
acorn: 8.14.0
@@ -6550,24 +5452,6 @@ snapshots:
json-schema-traverse: 1.0.0
require-from-string: 2.0.2
- algoliasearch@4.23.3:
- dependencies:
- '@algolia/cache-browser-local-storage': 4.23.3
- '@algolia/cache-common': 4.23.3
- '@algolia/cache-in-memory': 4.23.3
- '@algolia/client-account': 4.23.3
- '@algolia/client-analytics': 4.23.3
- '@algolia/client-common': 4.23.3
- '@algolia/client-personalization': 4.23.3
- '@algolia/client-search': 4.23.3
- '@algolia/logger-common': 4.23.3
- '@algolia/logger-console': 4.23.3
- '@algolia/recommend': 4.23.3
- '@algolia/requester-browser-xhr': 4.23.3
- '@algolia/requester-common': 4.23.3
- '@algolia/requester-node-http': 4.23.3
- '@algolia/transporter': 4.23.3
-
ansi-align@3.0.1:
dependencies:
string-width: 4.2.3
@@ -6745,8 +5629,6 @@ snapshots:
binary-extensions@2.3.0: {}
- birpc@0.2.19: {}
-
boolbase@1.0.0: {}
boxen@8.0.1:
@@ -6782,11 +5664,6 @@ snapshots:
builtin-modules@3.3.0: {}
- bundle-require@5.0.0(esbuild@0.23.0):
- dependencies:
- esbuild: 0.23.0
- load-tsconfig: 0.2.5
-
bundle-require@5.0.0(esbuild@0.24.0):
dependencies:
esbuild: 0.24.0
@@ -6885,8 +5762,6 @@ snapshots:
color-convert: 2.0.1
color-string: 1.9.1
- colorette@2.0.20: {}
-
comma-separated-tokens@2.0.3: {}
commander@4.1.1: {}
@@ -6908,10 +5783,7 @@ snapshots:
copy-anything@2.0.6:
dependencies:
is-what: 3.14.1
-
- copy-anything@3.0.5:
- dependencies:
- is-what: 4.1.16
+ optional: true
core-js-compat@3.39.0:
dependencies:
@@ -6930,15 +5802,8 @@ snapshots:
cssesc: 3.0.0
fastparse: 1.1.2
- css-tree@3.0.1:
- dependencies:
- mdn-data: 2.12.1
- source-map-js: 1.2.1
-
cssesc@3.0.0: {}
- csstype@3.1.3: {}
-
culori@3.3.0: {}
daisyui@4.12.14(postcss@8.4.49):
@@ -6950,8 +5815,6 @@ snapshots:
transitivePeerDependencies:
- postcss
- date-fns@3.6.0: {}
-
debug@3.2.7:
dependencies:
ms: 2.1.3
@@ -6978,8 +5841,6 @@ snapshots:
dequal@2.0.3: {}
- destr@2.0.3: {}
-
detect-libc@2.0.3: {}
deterministic-object-hash@2.0.2:
@@ -7010,8 +5871,6 @@ snapshots:
dset@3.1.4: {}
- duplexer@0.1.2: {}
-
eastasianwidth@0.2.0: {}
electron-to-chromium@1.5.49: {}
@@ -7584,10 +6443,6 @@ snapshots:
flattie@1.1.1: {}
- focus-trap@7.6.0:
- dependencies:
- tabbable: 6.2.0
-
foreground-child@3.1.1:
dependencies:
cross-spawn: 7.0.6
@@ -7662,10 +6517,6 @@ snapshots:
section-matter: 1.0.0
strip-bom-string: 1.0.0
- gzip-size@6.0.0:
- dependencies:
- duplexer: 0.1.2
-
has-flag@4.0.0: {}
hasown@2.0.2:
@@ -7869,8 +6720,6 @@ snapshots:
property-information: 6.5.0
space-separated-tokens: 2.0.2
- hookable@5.5.3: {}
-
hosted-git-info@2.8.9: {}
html-escaper@3.0.3: {}
@@ -7902,18 +6751,6 @@ snapshots:
import-meta-resolve@4.1.0: {}
- importx@0.4.4:
- dependencies:
- bundle-require: 5.0.0(esbuild@0.23.0)
- debug: 4.3.7
- esbuild: 0.23.0
- jiti: 2.0.0-beta.3
- jiti-v1: jiti@1.21.6
- pathe: 1.1.2
- tsx: 4.19.2
- transitivePeerDependencies:
- - supports-color
-
imurmurhash@0.1.4: {}
indent-string@4.0.0: {}
@@ -7985,9 +6822,8 @@ snapshots:
is-unicode-supported@2.0.0: {}
- is-what@3.14.1: {}
-
- is-what@4.1.16: {}
+ is-what@3.14.1:
+ optional: true
is-wsl@3.1.0:
dependencies:
@@ -8003,8 +6839,6 @@ snapshots:
jiti@1.21.6: {}
- jiti@2.0.0-beta.3: {}
-
joycon@3.1.1: {}
js-tokens@4.0.0: {}
@@ -8057,8 +6891,6 @@ snapshots:
kleur@4.1.5: {}
- kolorist@1.8.0: {}
-
less@4.2.0:
dependencies:
copy-anything: 2.0.6
@@ -8072,6 +6904,7 @@ snapshots:
mime: 1.6.0
needle: 3.3.1
source-map: 0.6.1
+ optional: true
levn@0.4.1:
dependencies:
@@ -8119,11 +6952,6 @@ snapshots:
longest-streak@3.1.0: {}
- loose-envify@1.4.0:
- dependencies:
- js-tokens: 4.0.0
- optional: true
-
loupe@3.1.2: {}
lru-cache@10.2.0: {}
@@ -8148,8 +6976,6 @@ snapshots:
semver: 5.7.2
optional: true
- mark.js@8.11.1: {}
-
markdown-extensions@2.0.0: {}
markdown-table@3.0.4: {}
@@ -8336,8 +7162,6 @@ snapshots:
dependencies:
'@types/mdast': 4.0.4
- mdn-data@2.12.1: {}
-
merge2@1.4.1: {}
micromark-core-commonmark@2.0.1:
@@ -8642,10 +7466,6 @@ snapshots:
minipass@7.0.4: {}
- minisearch@7.1.0: {}
-
- mitt@3.0.1: {}
-
mlly@1.7.2:
dependencies:
acorn: 8.14.0
@@ -8685,8 +7505,6 @@ snapshots:
dependencies:
'@types/nlcst': 2.0.3
- node-fetch-native@1.6.4: {}
-
node-releases@2.0.18: {}
normalize-package-data@2.5.0:
@@ -8708,12 +7526,6 @@ snapshots:
object-hash@3.0.0: {}
- ofetch@1.4.1:
- dependencies:
- destr: 2.0.3
- node-fetch-native: 1.6.4
- ufo: 1.5.4
-
onetime@7.0.0:
dependencies:
mimic-function: 5.0.1
@@ -8820,7 +7632,8 @@ snapshots:
unist-util-visit-children: 3.0.0
vfile: 6.0.3
- parse-node-version@1.0.1: {}
+ parse-node-version@1.0.1:
+ optional: true
parse5@7.2.1:
dependencies:
@@ -8845,8 +7658,6 @@ snapshots:
pathval@2.0.0: {}
- perfect-debounce@1.0.0: {}
-
picocolors@1.1.1: {}
picomatch@2.3.1: {}
@@ -8927,8 +7738,6 @@ snapshots:
picocolors: 1.1.1
source-map-js: 1.2.1
- preact@10.20.2: {}
-
preferred-pm@4.0.0:
dependencies:
find-up-simple: 1.0.0
@@ -8956,18 +7765,6 @@ snapshots:
queue-microtask@1.2.3: {}
- react-dom@18.3.1(react@18.3.1):
- dependencies:
- loose-envify: 1.4.0
- react: 18.3.1
- scheduler: 0.23.2
- optional: true
-
- react@18.3.1:
- dependencies:
- loose-envify: 1.4.0
- optional: true
-
read-cache@1.0.0:
dependencies:
pify: 2.3.0
@@ -9191,8 +7988,6 @@ snapshots:
reusify@1.0.4: {}
- rfdc@1.4.1: {}
-
rollup@4.24.3:
dependencies:
'@types/estree': 1.0.6
@@ -9226,19 +8021,12 @@ snapshots:
sax@1.3.0: {}
- scheduler@0.23.2:
- dependencies:
- loose-envify: 1.4.0
- optional: true
-
scslre@0.3.0:
dependencies:
'@eslint-community/regexpp': 4.11.0
refa: 0.12.1
regexp-ast-analysis: 0.7.1
- search-insights@2.13.0: {}
-
section-matter@1.0.0:
dependencies:
extend-shallow: 2.0.1
@@ -9295,24 +8083,10 @@ snapshots:
signal-exit@4.1.0: {}
- simple-git@3.27.0:
- dependencies:
- '@kwsites/file-exists': 1.1.1
- '@kwsites/promise-deferred': 1.1.1
- debug: 4.3.7
- transitivePeerDependencies:
- - supports-color
-
simple-swizzle@0.2.2:
dependencies:
is-arrayish: 0.3.2
- sirv@2.0.4:
- dependencies:
- '@polka/url': 1.0.0-next.25
- mrmime: 2.0.0
- totalist: 3.0.1
-
sisteransi@1.0.5: {}
sitemap@8.0.0:
@@ -9358,8 +8132,6 @@ snapshots:
spdx-license-ids@3.0.18: {}
- speakingurl@14.0.1: {}
-
sprintf-js@1.0.3: {}
stable-hash@0.0.4: {}
@@ -9440,10 +8212,6 @@ snapshots:
pirates: 4.0.6
ts-interface-checker: 0.1.13
- superjson@2.2.1:
- dependencies:
- copy-anything: 3.0.5
-
supports-color@7.2.0:
dependencies:
has-flag: 4.0.0
@@ -9459,8 +8227,6 @@ snapshots:
'@pkgr/core': 0.1.1
tslib: 2.8.0
- tabbable@6.2.0: {}
-
tailwindcss@3.4.15:
dependencies:
'@alloc/quick-lru': 5.2.0
@@ -9521,8 +8287,6 @@ snapshots:
dependencies:
eslint-visitor-keys: 3.4.3
- totalist@3.0.1: {}
-
tr46@1.0.1:
dependencies:
punycode: 2.3.1
@@ -9606,16 +8370,6 @@ snapshots:
ufo@1.5.4: {}
- unconfig@0.5.5:
- dependencies:
- '@antfu/utils': 0.7.10
- defu: 6.1.4
- importx: 0.4.4
- transitivePeerDependencies:
- - supports-color
-
- uncrypto@0.1.3: {}
-
undici-types@6.19.8: {}
unified@11.0.5:
@@ -9674,33 +8428,6 @@ snapshots:
unist-util-is: 6.0.0
unist-util-visit-parents: 6.0.1
- unocss@0.64.1(postcss@8.4.49)(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3)):
- dependencies:
- '@unocss/astro': 0.64.1(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))
- '@unocss/cli': 0.64.1(rollup@4.24.3)
- '@unocss/core': 0.64.1
- '@unocss/postcss': 0.64.1(postcss@8.4.49)
- '@unocss/preset-attributify': 0.64.1
- '@unocss/preset-icons': 0.64.1
- '@unocss/preset-mini': 0.64.1
- '@unocss/preset-tagify': 0.64.1
- '@unocss/preset-typography': 0.64.1
- '@unocss/preset-uno': 0.64.1
- '@unocss/preset-web-fonts': 0.64.1
- '@unocss/preset-wind': 0.64.1
- '@unocss/transformer-attributify-jsx': 0.64.1
- '@unocss/transformer-compile-class': 0.64.1
- '@unocss/transformer-directives': 0.64.1
- '@unocss/transformer-variant-group': 0.64.1
- '@unocss/vite': 0.64.1(rollup@4.24.3)(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))
- optionalDependencies:
- vite: 5.4.10(@types/node@22.9.0)(less@4.2.0)
- transitivePeerDependencies:
- - postcss
- - rollup
- - supports-color
- - vue
-
update-browserslist-db@1.1.1(browserslist@4.24.2):
dependencies:
browserslist: 4.24.2
@@ -9765,56 +8492,6 @@ snapshots:
optionalDependencies:
vite: 5.4.10(@types/node@22.9.0)(less@4.2.0)
- vitepress@1.5.0(@algolia/client-search@4.23.3)(@types/node@22.9.0)(@types/react@18.3.12)(less@4.2.0)(postcss@8.4.49)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)(typescript@5.6.3):
- dependencies:
- '@docsearch/css': 3.6.2
- '@docsearch/js': 3.6.2(@algolia/client-search@4.23.3)(@types/react@18.3.12)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.13.0)
- '@iconify-json/simple-icons': 1.2.11
- '@shikijs/core': 1.22.2
- '@shikijs/transformers': 1.22.2
- '@shikijs/types': 1.22.2
- '@types/markdown-it': 14.1.2
- '@vitejs/plugin-vue': 5.1.4(vite@5.4.10(@types/node@22.9.0)(less@4.2.0))(vue@3.5.13(typescript@5.6.3))
- '@vue/devtools-api': 7.6.1
- '@vue/shared': 3.5.12
- '@vueuse/core': 11.2.0(vue@3.5.13(typescript@5.6.3))
- '@vueuse/integrations': 11.2.0(focus-trap@7.6.0)(vue@3.5.13(typescript@5.6.3))
- focus-trap: 7.6.0
- mark.js: 8.11.1
- minisearch: 7.1.0
- shiki: 1.22.2
- vite: 5.4.10(@types/node@22.9.0)(less@4.2.0)
- vue: 3.5.13(typescript@5.6.3)
- optionalDependencies:
- postcss: 8.4.49
- transitivePeerDependencies:
- - '@algolia/client-search'
- - '@types/node'
- - '@types/react'
- - '@vue/composition-api'
- - async-validator
- - axios
- - change-case
- - drauu
- - fuse.js
- - idb-keyval
- - jwt-decode
- - less
- - lightningcss
- - nprogress
- - qrcode
- - react
- - react-dom
- - sass
- - sass-embedded
- - search-insights
- - sortablejs
- - stylus
- - sugarss
- - terser
- - typescript
- - universal-cookie
-
vitest@2.1.5(@types/node@22.9.0)(less@4.2.0):
dependencies:
'@vitest/expect': 2.1.5
@@ -9959,10 +8636,6 @@ snapshots:
vscode-uri@3.0.8: {}
- vue-demi@0.14.10(vue@3.5.13(typescript@5.6.3)):
- dependencies:
- vue: 3.5.13(typescript@5.6.3)
-
vue-eslint-parser@9.4.3(eslint@9.15.0(jiti@1.21.6)):
dependencies:
debug: 4.3.7
@@ -9976,20 +8649,6 @@ snapshots:
transitivePeerDependencies:
- supports-color
- vue-flow-layout@0.1.1(vue@3.5.13(typescript@5.6.3)):
- dependencies:
- vue: 3.5.13(typescript@5.6.3)
-
- vue@3.5.13(typescript@5.6.3):
- dependencies:
- '@vue/compiler-dom': 3.5.13
- '@vue/compiler-sfc': 3.5.13
- '@vue/runtime-dom': 3.5.13
- '@vue/server-renderer': 3.5.13(vue@3.5.13(typescript@5.6.3))
- '@vue/shared': 3.5.13
- optionalDependencies:
- typescript: 5.6.3
-
web-namespaces@2.0.1: {}
webidl-conversions@4.0.2: {}
diff --git a/tsconfig.json b/tsconfig.json
index a2c6053..5a981f5 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -6,12 +6,6 @@
{
"path": "./packages/ccc/tsconfig.json"
},
- {
- "path": "./packages/character-card-helpers/tsconfig.json"
- },
- {
- "path": "./packages/characters/tsconfig.json"
- },
{
"path": "./packages/characters-derivative/tsconfig.json"
},