diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index d5507ed49..466c65778 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -19,15 +19,15 @@ jobs: with: node-version: '>=24.13.0' cache: yarn - - name: Install dependencies and build website + - name: Install dependencies + run: yarn install + - name: Build Site env: APP_URL: ${{ secrets.APP_URL }} BACKEND_URL: ${{ secrets.BACKEND_URL }} GH_OAUTH_CLIENT_ID: ${{ vars.GH_OAUTH_CLIENT_ID}} SITE_CONFIG_PATH: ${{ vars.SITE_CONFIG_PATH }} - run: | - yarn install - yarn build + run: yarn build working-directory: . - name: Upload Build Artifact uses: actions/upload-pages-artifact@v3 diff --git a/docusaurus.config.ts b/docusaurus.config.ts index 85aa880a9..29c9c051b 100644 --- a/docusaurus.config.ts +++ b/docusaurus.config.ts @@ -32,6 +32,7 @@ import { socketIoNoDepWarningsPluginConfig, aliasConfigurationPlugin } from './src/siteConfig/pluginConfigs'; +import pageIndexPlugin from './packages/tdev/page-index/plugin'; import { useTdevContentPath } from './src/siteConfig/helpers'; import path from 'path'; import { @@ -383,7 +384,8 @@ const docusaurusConfig = withSiteConfig().then(async (siteConfig) => { ...(siteConfig.pages || {}) } ], - ...((siteConfig.plugins as Config['plugins']) || []) + ...((siteConfig.plugins as Config['plugins']) || []), + pageIndexPlugin ], themes: [ '@docusaurus/theme-mermaid', @@ -405,4 +407,4 @@ const docusaurusConfig = withSiteConfig().then(async (siteConfig) => { return config; }); -export default docusaurusConfig; +export default docusaurusConfig; \ No newline at end of file diff --git a/package.json b/package.json index 35ed55ab6..0bb7a6d2a 100644 --- a/package.json +++ b/package.json @@ -115,9 +115,6 @@ "vfile": "^6.0.3", "vitest": "^2.0.5" }, - "resolutions": { - "@rspack/core": "1.6.5" - }, "peerDependencies": { "react-hook-form": "*" }, diff --git a/packages/tdev/brython-code/README.mdx b/packages/tdev/brython-code/README.mdx index 790c0e0df..d78517320 100644 --- a/packages/tdev/brython-code/README.mdx +++ b/packages/tdev/brython-code/README.mdx @@ -1,5 +1,5 @@ --- -page_id: e7bde0ab-c0fe-4225-8325-e4ebc22d414b +page_id: 0f9fe018-9c46-4ec0-be50-c2ae69a6a005 tags: - '@tdev/' - python diff --git a/packages/tdev/page-index/README.mdx b/packages/tdev/page-index/README.mdx new file mode 100644 index 000000000..7f6c93007 --- /dev/null +++ b/packages/tdev/page-index/README.mdx @@ -0,0 +1,204 @@ +--- +page_id: cfbd9607-c2d5-4c2a-82e0-9f39c5756747 +tags: + - '@tdev/' +--- + +import { useStore } from '@tdev-hooks/useStore' +import { observer } from 'mobx-react-lite'; +import CodeBlock from '@theme/CodeBlock'; +import JsObjectViewer from '@tdev-components/shared/JsObject/Viewer'; + +# page-index + +Dieses Plugin ermöglicht eine Übersicht über alle speicherbaren Dokumente. So kann bspw. der Bearbeitungsstand in der Seitenleiste angezeigt werden. + +Standardmässig wird in der Seitenleiste der Bearbeitungsstand in zwei Fällen angezeigt: +1. Auf einer Seite sind *Statusdokument* vorhanden, deren Fortschritt bestimmt werden kann (sog. `TaskableDocuments`, bspw. `task_state` oder `progress_state`). +2. In einer Kategorie befinden sich direkt untergeordnete Seiten mit *Statusdokumenten*. + +![--width=800px](./images/taskable-sidebar.png) + +Dieses Verhalten kann über das *Frontmatter* der Seite angepasst werden: + +:::cards{flexBasis="300px"} +```yaml +--- +sidebar_custom_props: + taskable_state: 'show' +--- +``` +Bearbeitungsstand anzeigen, auch wenn keine Statusdokumente in den direkt untergeordneten Seiten vorhanden sind. +::br +```yaml +--- +sidebar_custom_props: + taskable_state: 'hide' +--- +``` +Bearbeitungsstand nicht anzeigen, auch wenn Statusdokumente vorhanden sind. +::: + +## Page index + +Der Seitenindex ist ein Baum aller speicherbaren Dokumente in der aktuellen Seite. + +Im `dev`-Modus wird er automatisch aktualisiert, wenn sich die Seite ändert. + +:::details[Page Index] + +export const Comp = observer(() => { + const pageStore = useStore('pageStore') + + return ( +
+ {JSON.stringify(pageStore._pageIndex, null, 2)} +
+ ); +}); + + +::: + +## Für Plugin-Autoren + +Wenn ein Plugin ein weiteres *Statusdokument* implementiert, das im Seitenindex erfasst werden soll, müssen folgende Schritte durchgeführt werden: +1. In der `siteConfig` die neue Komponente für das `remark`-Plugin registrieren: + ```ts title="siteConfig.ts" + import { PageIndexPluginDefaultOptions } from './src/siteConfig/markdownPluginConfigs'; + const indexPluginOptions = { + ...PageIndexPluginDefaultOptions, + components: [ + ...PageIndexPluginDefaultOptions.components, + { + name: 'MyNewTaskableDocument', + docTypeExtractor: (node: MdxJsxFlowElement) => 'my_new_taskable_document' + } + ] + }; + export const pageIndexPluginConfig = [pageIndexPlugin, indexPluginOptions]; + ``` +2. Im `index.ts` des neuen Plugins den neuen Dokumenttyp importieren: + ```ts title="packages///index.ts" + declare module '@tdev-api/document' { + export interface TaskableDocumentMapping { + ['my_new_taskable_document']: MyNewTaskableData; + } + export interface TypeModelMapping { + ['my_new_taskable_document']: MyNewTaskableDocument; + } + } + ``` + :::warning[iTaskableDocument] + Das neue `MyNewTaskableDocument`-Modell muss das Interface `iTaskableDocument<'my_new_taskable_document'>` implementieren, damit es im Seitenindex als *Statusdokument* erkannt wird. + ::: +3. Im `apiDocumentProviders` den neuen Dokumenttyp registrieren: + ```ts title="siteConfig.ts" + const getSiteConfig = () => { + apiDocumentProviders: { + ..., + require.resolve('@scope/new-plugin/register') + } + } + ``` + und den neuen Dokumenttyp im `ComponentStore` registrieren: + ```ts title="packages///register.ts" + const register = () => { + rootStore.componentStore.registerTaskableDocumentType('my_new_taskable_document'); + }; + ``` + +## Installation + +:::info[`docusaurus.config.ts`] +```ts +import pageIndexPlugin from './packages/tdev/page-index/plugin'; + +export default { + // ... + plugins: [ + // ... + pageIndexPlugin + ] +}; + +``` +::: + +:::info[swizzle `theme/DocSidebarItem/index.tsx`] +See the swizzled component of this page. This should be synced with the `updateTdev.config.yaml` by default. +::: + + +:::details[remark config] +```ts +import pageProgressStatePlugin from '@tdev/page-index/remark-plugin'; + +export const PageIndexPluginDefaultOptions: PageIndexPluginOptions = { + components: [ + { + name: 'Answer', + docTypeExtractor: (node) => { + return ( + getAnswerDocumentType( + node.attributes.find((a) => a.type === 'mdxJsxAttribute' && a.name === 'type') + ?.value as string + ) || 'unknown' + ); + } + }, + { + name: 'ProgressState', + docTypeExtractor: () => 'progress_state' + }, + { + name: 'TaskState', + docTypeExtractor: () => 'task_state' + }, + { + name: 'QuillV2', + docTypeExtractor: () => 'quill_v2' + }, + { + name: 'String', + docTypeExtractor: () => 'string' + }, + { + name: 'CmsText', + docTypeExtractor: () => 'cms_text' + }, + { + name: 'CmsCode', + docTypeExtractor: () => 'cms_text' + }, + { + name: 'Restricted', + docTypeExtractor: () => 'restricted' + }, + { + name: 'DynamicDocumentRoots', + docTypeExtractor: () => 'dynamic_document_roots' + } + ], + persistedCodeType: (node: Code) => { + if (node.lang === 'html') { + return 'script'; + } + const liveLangMatch = /(live_[a-zA-Z0-9-_]+)/.exec(node.meta || ''); + const liveCode = liveLangMatch ? liveLangMatch[1] : null; + + switch (liveCode) { + case 'live_py': + case 'live_bry': + // legacy name, TODO. should be 'brython_code'? + return 'script'; + case 'live_pyo': + return 'pyodide_code'; + default: + return 'code'; + } + } +}; +export const pageIndexPluginConfig = [pageIndexPlugin, PageIndexPluginDefaultOptions]; +``` +::: \ No newline at end of file diff --git a/packages/tdev/page-index/components/TaskableState/index.tsx b/packages/tdev/page-index/components/TaskableState/index.tsx new file mode 100644 index 000000000..3133b4d04 --- /dev/null +++ b/packages/tdev/page-index/components/TaskableState/index.tsx @@ -0,0 +1,51 @@ +import React from 'react'; +import clsx from 'clsx'; +import styles from './styles.module.scss'; +import { observer } from 'mobx-react-lite'; +import Page from '@tdev-models/Page'; +import Icon from '@mdi/react'; +import useIsBrowser from '@docusaurus/useIsBrowser'; + +interface Props { + page?: Page; + className?: string; + forcedAction?: 'show' | 'hide'; +} + +const TaskableState = observer((props: Props) => { + const { page } = props; + const isBrowser = useIsBrowser(); + const forceHide = props.forcedAction === 'hide'; + if (forceHide) { + return null; + } + + if (!isBrowser || !page) { + return null; + } + const forceShow = props.forcedAction === 'show'; + + if (!forceShow && page.stepsOnPage === 0 && page.stepsOnDirectSubPages === 0) { + return null; + } + + return ( +
{ + const thisElement = e.currentTarget; + thisElement.parentElement?.querySelector('a')?.click(); + }} + > + +
+ ); +}); + +export default TaskableState; diff --git a/packages/tdev/page-index/components/TaskableState/styles.module.scss b/packages/tdev/page-index/components/TaskableState/styles.module.scss new file mode 100644 index 000000000..8bd004f2f --- /dev/null +++ b/packages/tdev/page-index/components/TaskableState/styles.module.scss @@ -0,0 +1,12 @@ +.taskableState { + display: flex; + align-items: center; + justify-content: center; + height: 2em; + width: 2em; + cursor: pointer; + border-radius: 1em; + &:hover { + background-color: var(--ifm-hover-overlay); + } +} diff --git a/packages/tdev/page-index/images/taskable-sidebar.png b/packages/tdev/page-index/images/taskable-sidebar.png new file mode 100644 index 000000000..c04c2bd0f Binary files /dev/null and b/packages/tdev/page-index/images/taskable-sidebar.png differ diff --git a/packages/tdev/page-index/images/taskable-sidebar.png.excalidraw b/packages/tdev/page-index/images/taskable-sidebar.png.excalidraw new file mode 100644 index 000000000..6b3d53eb2 --- /dev/null +++ b/packages/tdev/page-index/images/taskable-sidebar.png.excalidraw @@ -0,0 +1,611 @@ +{ + "type": "excalidraw", + "version": 2, + "elements": [ + { + "id": "TDEV-BACKGROUND-IMAGE", + "type": "image", + "x": 0, + "y": 0, + "width": 445, + "height": 559, + "roughness": 0, + "opacity": 100, + "isDeleted": false, + "fileId": "TDEV-BACKGROUND--FILE", + "scale": [ + 1, + 1 + ], + "locked": true, + "customData": { + "exportFormatMimeType": "image/png", + "exportPadding": 4 + }, + "version": 2, + "versionNonce": 573287145, + "index": "a0", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "solid", + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "seed": 1, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1770247548661, + "link": null, + "status": "pending", + "crop": null + }, + { + "id": "TDEV-IMAGE--RECTANGLE", + "type": "rectangle", + "x": 0, + "y": 0, + "width": 445, + "height": 559, + "strokeColor": "#1e1e1e", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "locked": true, + "version": 2, + "versionNonce": 573287144, + "index": "a1", + "isDeleted": false, + "angle": 0, + "seed": 1, + "groupIds": [], + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1770247548661, + "link": null + }, + { + "id": "8-8yrCtx4PU0QPmyP2kGs", + "type": "text", + "x": 623.0766065968326, + "y": 357.47268348297536, + "width": 496.22381591796875, + "height": 48.6, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a2", + "roundness": null, + "seed": 814616999, + "version": 154, + "versionNonce": 714376617, + "isDeleted": false, + "boundElements": [], + "updated": 1770247741661, + "link": null, + "locked": false, + "text": "Enthalten TaskableDocuments", + "fontSize": 36, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Enthalten TaskableDocuments", + "autoResize": true, + "lineHeight": 1.35 + }, + { + "id": "FgnNFsNzNRYBXy_J8pJXS", + "type": "line", + "x": 608.32582, + "y": 357.47268302254025, + "width": 0, + "height": 55.16401372086386, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a3", + "roundness": { + "type": 2 + }, + "seed": 1020752199, + "version": 92, + "versionNonce": 2059866985, + "isDeleted": false, + "boundElements": [], + "updated": 1770247593910, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 55.16401372086386 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null + }, + { + "id": "GGdpT5dFNrLKK0yKAY-Rc", + "type": "arrow", + "x": 608.3258196765732, + "y": 356.04437637292256, + "width": 163.28548039029647, + "height": 130.18707220307417, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a4", + "roundness": { + "type": 2 + }, + "seed": 1268936137, + "version": 77, + "versionNonce": 741454343, + "isDeleted": false, + "boundElements": [], + "updated": 1770247604539, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -163.28548039029647, + -130.18707220307417 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "DVSREq4Ef0ofOh63yTXLL", + "type": "arrow", + "x": 608.3258196765732, + "y": 413.4149505641078, + "width": 163.28548039029647, + "height": 105.17936357087831, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a5", + "roundness": { + "type": 2 + }, + "seed": 727439655, + "version": 39, + "versionNonce": 707815273, + "isDeleted": false, + "boundElements": [], + "updated": 1770247612246, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -163.28548039029647, + 105.17936357087831 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "p1ooWVetebSkJ2n7rnlaf", + "type": "arrow", + "x": 606.8548690978753, + "y": 395.7624661975892, + "width": 161.8145298115985, + "height": 26.478726549777775, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a6", + "roundness": { + "type": 2 + }, + "seed": 1818333769, + "version": 40, + "versionNonce": 1865184201, + "isDeleted": false, + "boundElements": [], + "updated": 1770247615149, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -161.8145298115985, + 26.478726549777775 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "0PzJFjvP0z7ovn-ZlJn_6", + "type": "arrow", + "x": 607.5903443872244, + "y": 374.43233602879013, + "width": 163.28548039029647, + "height": 93.41101821357131, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a7", + "roundness": { + "type": 2 + }, + "seed": 1658655401, + "version": 47, + "versionNonce": 1527276615, + "isDeleted": false, + "boundElements": [], + "updated": 1770247619837, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -163.28548039029647, + -93.41101821357131 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "Uq3G12utv_3iauKXWmGEQ", + "type": "arrow", + "x": 607.5903440978752, + "y": 168.48672863056774, + "width": 162.55000481159846, + "height": 0, + "angle": 0, + "strokeColor": "#f08c00", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a8", + "roundness": { + "type": 2 + }, + "seed": 597904009, + "version": 98, + "versionNonce": 1875424937, + "isDeleted": false, + "boundElements": [], + "updated": 1770247754982, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -162.55000481159846, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "8NlUihPEosJeJVHpTNSNb", + "focus": -0.12298231980817184, + "gap": 15.486262678253752 + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "nXpLQrCOAwx4mauafchMY", + "type": "line", + "x": 608.3258198598327, + "y": 105.23193257222115, + "width": 0, + "height": 114.74118205181236, + "angle": 0, + "strokeColor": "#f08c00", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "a9", + "roundness": { + "type": 2 + }, + "seed": 1710221159, + "version": 103, + "versionNonce": 1439527625, + "isDeleted": false, + "boundElements": [], + "updated": 1770247723177, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 114.74118205181236 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null + }, + { + "id": "8NlUihPEosJeJVHpTNSNb", + "type": "text", + "x": 623.076606776129, + "y": 86.62131751655198, + "width": 602.02783203125, + "height": 145.8, + "angle": 0, + "strokeColor": "#f08c00", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "aA", + "roundness": null, + "seed": 1935552041, + "version": 186, + "versionNonce": 1353578889, + "isDeleted": false, + "boundElements": [ + { + "id": "Uq3G12utv_3iauKXWmGEQ", + "type": "arrow" + } + ], + "updated": 1770247754982, + "link": null, + "locked": false, + "text": "Kategorie mit direkt untergeordneten\nSeiten, die TaskableDocuments \nenthalten", + "fontSize": 36, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Kategorie mit direkt untergeordneten\nSeiten, die TaskableDocuments \nenthalten", + "autoResize": true, + "lineHeight": 1.35 + }, + { + "id": "FxcdmPEaKJ4_IWQDA4lKc", + "type": "arrow", + "x": 608.3258196765732, + "y": 16.969560995299833, + "width": 163.28548095057124, + "height": 0, + "angle": 0, + "strokeColor": "#e03131", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "aB", + "roundness": { + "type": 2 + }, + "seed": 1963716457, + "version": 73, + "versionNonce": 878699401, + "isDeleted": false, + "boundElements": [], + "updated": 1770247765552, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -163.28548095057124, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "oYKPgOpkt7MKfcGRduSD2", + "type": "line", + "x": 608.3258198414095, + "y": -19.806459043829165, + "width": 0, + "height": 69.87439483784124, + "angle": 0, + "strokeColor": "#e03131", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "aC", + "roundness": { + "type": 2 + }, + "seed": 1234400935, + "version": 59, + "versionNonce": 1490561863, + "isDeleted": false, + "boundElements": [], + "updated": 1770247805410, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 69.87439483784124 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null + }, + { + "id": "U5nrzQGZ2JNHrhPZK_EfS", + "type": "text", + "x": 623.0766072283326, + "y": -31.63043921391389, + "width": 642.52783203125, + "height": 97.2, + "angle": 0, + "strokeColor": "#e03131", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "aD", + "roundness": null, + "seed": 522207175, + "version": 91, + "versionNonce": 609424231, + "isDeleted": false, + "boundElements": [], + "updated": 1770247826306, + "link": null, + "locked": false, + "text": "Übergeordnete Kategorie ohne Anzeige\ndes Bearbeitungsstandes", + "fontSize": 36, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Übergeordnete Kategorie ohne Anzeige\ndes Bearbeitungsstandes", + "autoResize": true, + "lineHeight": 1.35 + } + ], + "files": { + "TDEV-BACKGROUND--FILE": { + "id": "TDEV-BACKGROUND--FILE", + "mimeType": "image/png", + "dataURL": "" + } + } +} \ No newline at end of file diff --git a/packages/tdev/page-index/index.ts b/packages/tdev/page-index/index.ts new file mode 100644 index 000000000..143bd11a8 --- /dev/null +++ b/packages/tdev/page-index/index.ts @@ -0,0 +1,21 @@ +import { DocumentType } from '@tdev-api/document'; + +export interface PageIndex { + /** + * the document root id + */ + id: string; + type: DocumentType; + /** + * the page_id in the frontmatter of each md/mdx file + */ + page_id: string; + /** + * The resolved path to the file - should be the same + * as docusaurus `path` field in the sidebar index. + */ + path: string; + position: number; +} + +export const PluginName = 'page-progress-state'; diff --git a/packages/tdev/page-index/package.json b/packages/tdev/page-index/package.json new file mode 100644 index 000000000..7f66b6b3c --- /dev/null +++ b/packages/tdev/page-index/package.json @@ -0,0 +1,16 @@ +{ + "name": "@tdev/page-index", + "version": "1.0.0", + "main": "index.ts", + "types": "index.ts", + "dependencies": {}, + "devDependencies": { + "@docusaurus/core": "*", + "@docusaurus/module-type-aliases": "*", + "@types/better-sqlite3": "^7.6.13", + "better-sqlite3": "^12.6.2" + }, + "peerDependencies": { + "@tdev/core": "1.0.0" + } +} diff --git a/packages/tdev/page-index/plugin.ts b/packages/tdev/page-index/plugin.ts new file mode 100644 index 000000000..6715a7a26 --- /dev/null +++ b/packages/tdev/page-index/plugin.ts @@ -0,0 +1,35 @@ +import { LoadContext, Plugin, PluginModule } from '@docusaurus/types'; +import { exportDB } from './utils/exportDb'; +import path from 'path'; +import { promises as fs } from 'fs'; +import { PluginName } from '.'; +import { pageIndexPath } from './utils/options'; + +const isDev = process.env.NODE_ENV !== 'production'; + +const pageIndexPlugin: PluginModule = (context: LoadContext) => { + const config: Plugin<{}> = { + name: PluginName, + async allContentLoaded() { + if (isDev) { + try { + await fs.access(path.dirname(pageIndexPath)); + } catch { + await fs.mkdir(path.dirname(pageIndexPath), { recursive: true }); + } + } + }, + async postBuild() { + try { + await fs.access(path.dirname(pageIndexPath)); + } catch { + await fs.mkdir(path.dirname(pageIndexPath), { recursive: true }); + } + + await exportDB(); + } + }; + return config as Plugin; +}; + +export default pageIndexPlugin; diff --git a/packages/tdev/page-index/remark-plugin/index.ts b/packages/tdev/page-index/remark-plugin/index.ts new file mode 100644 index 000000000..8dea02649 --- /dev/null +++ b/packages/tdev/page-index/remark-plugin/index.ts @@ -0,0 +1,147 @@ +import type { Plugin, Transformer } from 'unified'; +import type { Code, Root } from 'mdast'; +import type { MdxJsxFlowElement, MdxJsxTextElement } from 'mdast-util-mdx'; +import path from 'path'; +import db from '../utils/db'; +import { exportDB } from '../utils/exportDb'; +import { debounce } from 'es-toolkit/function'; +import { tdevRoot } from '../utils/options'; +import { TypeModelMapping } from '@tdev-api/document'; + +const TdevRoot = `${tdevRoot === '' ? '' : '/'}${tdevRoot}`; +const TdevRootRegex = new RegExp(`^${TdevRoot}`); +const projectRoot = process.cwd(); +const isDev = process.env.NODE_ENV !== 'production'; + +const insertDocRoot = db.prepare( + `INSERT INTO document_roots ( + id, + type, + page_id, + path, + position + ) VALUES ( + @id, + @type, + @page_id, + @path, + @position + ) ON CONFLICT(id, path) DO NOTHING` +); + +const cleanupPage = db.prepare( + `DELETE FROM document_roots + WHERE path = ? AND page_id = ?;` +); + +interface JsxConfig { + /** + * Component Name + */ + name: string; + /** + * @default id + */ + attributeName?: string; + docTypeExtractor: (node: MdxJsxFlowElement | MdxJsxTextElement) => keyof TypeModelMapping | string; +} + +export interface PluginOptions { + components: JsxConfig[]; + persistedCodeType?: (code: Code) => string; +} + +const slugCountMap = new Map(); + +const scheduleExportDb = debounce( + async () => { + await exportDB(); + }, + 250, + { edges: ['trailing'] } +); + +/** + * This plugin transforms inline code and code blocks in MDX files to use + * custom MDX components by converting the code content into attributes. + */ +const remarkPlugin: Plugin = function plugin( + options = { components: [], persistedCodeType: () => 'code' } +): Transformer { + const { components } = options; + const mdxJsxComponents = new Map(components.map((c) => [c.name, c])); + return async (root, file) => { + const { page_id } = (file.data?.frontMatter || {}) as { page_id?: string }; + if (components.length < 1 || !page_id) { + return; + } + const { visit, CONTINUE } = await import('unist-util-visit'); + const filePath = `/${path.relative(projectRoot, file.path)}` + .replace(/\/(index|README)\.mdx?$/i, '/') + .replace(/\.mdx?$/i, '/') + .replace(TdevRootRegex, '') + .replace(/^\/versioned_docs\/version-/, '/'); + slugCountMap.set(filePath, 1); + + insertDocRoot.run({ + id: page_id, + type: '', + page_id: page_id, + path: filePath, + position: 0 + }); + cleanupPage.run(filePath, page_id); + visit(root, (node, index, parent) => { + if (node.type === 'code') { + const idMatch = /id=([a-zA-Z0-9-_]+)/.exec(node.meta || ''); + if (!idMatch) { + return CONTINUE; + } + const docId = idMatch[1]; + const docType = options.persistedCodeType?.(node) ?? 'code'; + const res = insertDocRoot.run({ + id: docId, + type: docType, + page_id: page_id, + path: filePath, + position: slugCountMap.get(filePath)! + }); + if (res.changes > 0) { + slugCountMap.set(filePath, slugCountMap.get(filePath)! + 1); + } + return CONTINUE; + } + if ( + (node.type !== 'mdxJsxFlowElement' && node.type !== 'mdxJsxTextElement') || + !mdxJsxComponents.has(node.name as string) + ) { + return CONTINUE; + } + const config = mdxJsxComponents.get(node.name!)!; + const attr = node.attributes.find( + (a) => a.type === 'mdxJsxAttribute' && a.name === (config.attributeName || 'id') + ); + if (!attr || attr.type !== 'mdxJsxAttribute' || typeof attr.value !== 'string') { + return CONTINUE; + } + const docId = attr.value; + const docType = config.docTypeExtractor(node); + const res = insertDocRoot.run({ + id: docId, + type: docType, + page_id: page_id, + path: filePath, + position: slugCountMap.get(filePath)! + }); + if (res.changes > 0) { + slugCountMap.set(filePath, slugCountMap.get(filePath)! + 1); + } + return CONTINUE; + }); + if (isDev) { + scheduleExportDb(); + } + }; +}; + +export default remarkPlugin; diff --git a/packages/tdev/page-index/tsconfig.json b/packages/tdev/page-index/tsconfig.json new file mode 100644 index 000000000..ea56794f8 --- /dev/null +++ b/packages/tdev/page-index/tsconfig.json @@ -0,0 +1,3 @@ +{ + "extends": "../../../tsconfig.json" +} diff --git a/packages/tdev/page-index/utils/db.ts b/packages/tdev/page-index/utils/db.ts new file mode 100644 index 000000000..e5c7d6da8 --- /dev/null +++ b/packages/tdev/page-index/utils/db.ts @@ -0,0 +1,27 @@ +import path from 'path'; +import Database from 'better-sqlite3'; +import { accessSync, mkdirSync } from 'fs'; +import { dbPath } from './options'; + +try { + accessSync(path.dirname(dbPath)); +} catch { + mkdirSync(path.dirname(dbPath), { recursive: true }); +} + +const db = new Database(dbPath, { fileMustExist: false }); +db.pragma('journal_mode = WAL'); + +const createDocRoots = db.prepare( + `CREATE TABLE IF NOT EXISTS document_roots ( + id TEXT NOT NULL, + type TEXT NOT NULL, + page_id TEXT NOT NULL, + path TEXT NOT NULL, + position INTEGER NOT NULL, + UNIQUE(id, path) + )` +); +createDocRoots.run(); + +export default db; diff --git a/packages/tdev/page-index/utils/exportDb.ts b/packages/tdev/page-index/utils/exportDb.ts new file mode 100644 index 000000000..985c41aec --- /dev/null +++ b/packages/tdev/page-index/utils/exportDb.ts @@ -0,0 +1,15 @@ +import db from './db'; +import { promises as fs } from 'fs'; +import { pageIndexPath } from './options'; +import { PageIndex } from '..'; + +const getDocumentRoots = db.prepare('SELECT * FROM document_roots ORDER BY path ASC, position ASC'); + +export const getContent = () => { + const documentRoots = getDocumentRoots.all() as PageIndex[]; + return { documentRoots }; +}; + +export const exportDB = async () => { + await fs.writeFile(pageIndexPath, JSON.stringify(getContent(), null, 2)); +}; diff --git a/packages/tdev/page-index/utils/options.ts b/packages/tdev/page-index/utils/options.ts new file mode 100644 index 000000000..61acd8b13 --- /dev/null +++ b/packages/tdev/page-index/utils/options.ts @@ -0,0 +1,25 @@ +require('dotenv').config(); +import path from 'path'; +import { PluginName } from '..'; +const cwd = process.cwd(); +export const tdevRoot = path + .relative(cwd, process.env.SITE_CONFIG_PATH ?? './siteConfig') + .split(path.sep) + .slice(0, -1) + .join(path.sep); + +// current file's directory: +export const pluginRootDir = path.dirname(new URL(import.meta.url).pathname); +export const assetDir = path.join(pluginRootDir, 'assets'); + +const projectRoot = process.cwd(); +const isDev = process.env.NODE_ENV !== 'production'; + +export const generatedDbDir = path.join(projectRoot, '.docusaurus', PluginName, 'default'); + +export const generatedDataDir = isDev + ? path.join(projectRoot, 'static/tdev-artifacts', PluginName) + : path.join(projectRoot, 'build/tdev-artifacts', PluginName); + +export const dbPath = path.join(generatedDbDir, 'index.db'); +export const pageIndexPath = path.join(generatedDataDir, 'pageIndex.json'); diff --git a/packages/tdev/pyodide-code/index.ts b/packages/tdev/pyodide-code/index.ts index 21a02e9ff..880670449 100644 --- a/packages/tdev/pyodide-code/index.ts +++ b/packages/tdev/pyodide-code/index.ts @@ -1,4 +1,3 @@ -import type { CurrentBundler, PluginConfig, PluginModule } from '@docusaurus/types'; import type PyodideStore from './stores/PyodideStore'; import PyodideCode from './models/PyodideCode'; export interface PyodideData { @@ -13,6 +12,6 @@ declare module '@tdev-api/document' { ['pyodide_code']: PyodideCode; } export interface ViewStoreTypeMapping { - ['pyodideStore']: PyodideStore; // placeholder to avoid empty interface error + ['pyodideStore']: PyodideStore; } } diff --git a/src/api/OfflineApi/index.ts b/src/api/OfflineApi/index.ts index d9690c8b0..1c743fe54 100644 --- a/src/api/OfflineApi/index.ts +++ b/src/api/OfflineApi/index.ts @@ -239,6 +239,7 @@ export default class OfflineApi { ) || [] }; }) as unknown as T; + log('-> get', url, documenRoots); return resolveResponse(documenRoots); } return resolveResponse([OfflineUser] as unknown as T); diff --git a/src/api/document.ts b/src/api/document.ts index b38a01558..5172792f6 100644 --- a/src/api/document.ts +++ b/src/api/document.ts @@ -18,6 +18,7 @@ import type DocumentStore from '@tdev-stores/DocumentStore'; import iDocumentContainer from '@tdev-models/iDocumentContainer'; import iViewStore from '@tdev-stores/ViewStores/iViewStore'; import Code from '@tdev-models/documents/Code'; +import { iTaskableDocument } from '@tdev-models/iTaskableDocument'; export enum Access { RO_DocumentRoot = 'RO_DocumentRoot', @@ -85,6 +86,7 @@ export interface TaskStateData { } export interface ProgressStateData { progress: number; + totalSteps: number; } export interface MdxCommentData { @@ -112,9 +114,12 @@ export interface ContainerTypeDataMapping { ['_container_placeholder_']: { name: string }; // placeholder to avoid empty interface error } -export interface TypeDataMapping extends ContainerTypeDataMapping { +export interface TaskableDocumentMapping { ['task_state']: TaskStateData; ['progress_state']: ProgressStateData; +} + +export interface TypeDataMapping extends TaskableDocumentMapping, ContainerTypeDataMapping { ['code']: CodeData; // TODO: rename to `code_version`? ['script_version']: ScriptVersionData; @@ -130,6 +135,7 @@ export interface TypeDataMapping extends ContainerTypeDataMapping { // Add more mappings as needed } export type ContainerType = keyof ContainerTypeDataMapping; +export type TaskableType = keyof TaskableDocumentMapping; type KeysWithCode = { [K in keyof T]: 'code' extends keyof T[K] ? K : never; @@ -141,9 +147,15 @@ export interface ContainerTypeModelMapping { ['_container_placeholder_']: iDocumentContainer; // placeholder to avoid empty interface error } -export interface TypeModelMapping extends ContainerTypeModelMapping { +export interface TaskableTypeModelMapping { ['task_state']: TaskState; ['progress_state']: ProgressState; +} +// enforce all TaskableTypeMpdels to extend iTaskableDocument: +type EnsureAllTaskable }> = T; +null as unknown as EnsureAllTaskable; + +export interface TypeModelMapping extends TaskableTypeModelMapping, ContainerTypeModelMapping { ['code']: Code; // TODO: rename to `code_version`? ['script_version']: ScriptVersion; @@ -165,6 +177,7 @@ export interface TypeModelMapping extends ContainerTypeModelMapping { } export type ContainerModelType = ContainerTypeModelMapping[ContainerType]; +export type TaskableModelType = TaskableTypeModelMapping[TaskableType]; export type DocumentType = keyof TypeModelMapping; export type DocumentModelType = TypeModelMapping[DocumentType]; diff --git a/src/components/Admin/EditUser/index.tsx b/src/components/Admin/EditUser/index.tsx index 34b072411..361d772ca 100644 --- a/src/components/Admin/EditUser/index.tsx +++ b/src/components/Admin/EditUser/index.tsx @@ -285,7 +285,7 @@ const EditUser = observer((props: Props) => { setSpinState('deleting'); authClient.admin.removeUser({ userId: user.id }).then( action((res) => { - if (res.data?.success) { + if (res?.data?.success) { userStore.removeFromStore(user.id); props.close(); } diff --git a/src/components/Answer/helper.answer.ts b/src/components/Answer/helper.answer.ts new file mode 100644 index 000000000..e1f66dd5c --- /dev/null +++ b/src/components/Answer/helper.answer.ts @@ -0,0 +1,16 @@ +import { DocumentType } from '@tdev-api/document'; + +export const getAnswerDocumentType = (type: string): DocumentType => { + switch (type) { + case 'text': + return 'quill_v2'; + case 'string': + return 'string'; + case 'state': + return 'task_state'; + case 'progress': + return 'progress_state'; + default: + return type as DocumentType; + } +}; diff --git a/src/components/Answer/index.tsx b/src/components/Answer/index.tsx index db1c4bdf7..bc05d3d7a 100644 --- a/src/components/Answer/index.tsx +++ b/src/components/Answer/index.tsx @@ -5,6 +5,7 @@ import String from '@tdev-components/documents/String'; import TaskState from '@tdev-components/documents/TaskState'; import ProgressState from '@tdev-components/documents/ProgressState'; import { DocumentType } from '@tdev-api/document'; +import { getAnswerDocumentType } from './helper.answer'; interface Props { id: string; @@ -21,8 +22,7 @@ type AnswerProps = Props & ); const Answer = observer((props: AnswerProps) => { - switch (props.type) { - case 'text': + switch (getAnswerDocumentType(props.type)) { case 'quill_v2': return )} />; case 'string': @@ -34,10 +34,8 @@ const Answer = observer((props: AnswerProps) => { } /> ); - case 'progress': case 'progress_state': return )} />; - case 'state': case 'task_state': return ; } diff --git a/src/components/DynamicValues/TemplateCode/index.tsx b/src/components/DynamicValues/TemplateCode/index.tsx index 0cee3e95d..7a188ee31 100644 --- a/src/components/DynamicValues/TemplateCode/index.tsx +++ b/src/components/DynamicValues/TemplateCode/index.tsx @@ -17,8 +17,8 @@ const TemplateCode = observer((props: Props) => { if (!current) { return null; } - const code = templateReplacer(props.code, pageStore.current?.dynamicValues); - const metastring = templateReplacer(props.codeAttributes?.meta, pageStore.current?.dynamicValues); + const code = templateReplacer(props.code, current.dynamicValues); + const metastring = templateReplacer(props.codeAttributes?.meta, current.dynamicValues); return ( {code} diff --git a/src/components/DynamicValues/Val/index.tsx b/src/components/DynamicValues/Val/index.tsx index ee0bdbbdd..77d769026 100644 --- a/src/components/DynamicValues/Val/index.tsx +++ b/src/components/DynamicValues/Val/index.tsx @@ -23,7 +23,7 @@ const Val = observer((props: Props) => { } let value = ''; if ('code' in props) { - value = templateReplacer(props.code, pageStore.current?.dynamicValues); + value = templateReplacer(props.code, current.dynamicValues); } else if ('name' in props) { value = current.dynamicValues.get(props.name) || `<${props.name}>`; } diff --git a/src/components/EditingOverview/EditingStateList.tsx b/src/components/EditingOverview/EditingStateList.tsx index 8ce024e16..1d1135dd6 100644 --- a/src/components/EditingOverview/EditingStateList.tsx +++ b/src/components/EditingOverview/EditingStateList.tsx @@ -6,9 +6,10 @@ import { useStore } from '@tdev-hooks/useStore'; import Icon from '@mdi/react'; import TaskState from '@tdev-models/documents/TaskState'; import ProgressState from '@tdev-models/documents/ProgressState'; +import type { iTaskableDocument } from '@tdev-models/iTaskableDocument'; interface Props { - editingStatus: (TaskState | ProgressState)[]; + editingStatus: iTaskableDocument[]; } const EditingStateList = observer((props: Props) => { diff --git a/src/components/EditingOverview/index.tsx b/src/components/EditingOverview/index.tsx index 71c20f324..bfdfff1b5 100644 --- a/src/components/EditingOverview/index.tsx +++ b/src/components/EditingOverview/index.tsx @@ -62,7 +62,7 @@ const EditingOverview = observer(() => { if (!isBrowser || !currentUser || !currentPage) { return null; } - const taskStates = currentPage.editingState.filter((ts) => RWAccess.has(ts.root?.permission)) || []; + const taskStates = currentPage.taskableDocuments.filter((ts) => RWAccess.has(ts.root?.permission)) || []; if (taskStates.length === 0) { return null; } @@ -78,7 +78,7 @@ const EditingOverview = observer(() => { } onOpen={() => { - currentPage.loadLinkedDocumentRoots(); + currentPage.loadLinkedDocumentRoots(true); }} contentStyle={{ position: 'fixed' diff --git a/src/components/MdxPage/index.tsx b/src/components/MdxPage/index.tsx index 80442f9f8..76051be13 100644 --- a/src/components/MdxPage/index.tsx +++ b/src/components/MdxPage/index.tsx @@ -40,7 +40,7 @@ const MdxPage = observer((props: Props) => { if (!current || !userStore.current?.hasElevatedAccess) { return; } - if (userStore.viewedUserId && userStore.viewedUserId !== userStore.current?.id) { + if (userStore.isUserSwitched) { current.loadLinkedDocumentRoots(); } }, [pageStore.current, userStore.viewedUserId]); diff --git a/src/components/documents/ProgressState/index.tsx b/src/components/documents/ProgressState/index.tsx index babbd11b1..40f724ffb 100644 --- a/src/components/documents/ProgressState/index.tsx +++ b/src/components/documents/ProgressState/index.tsx @@ -74,7 +74,7 @@ const ProgressState = observer((props: Props) => { React.useEffect(() => { if (doc?.root && pageStore.current && !doc.root.isDummy) { - pageStore.current.addDocumentRoot(doc); + pageStore.current.assertDocumentRoot(doc); } }, [doc, pageStore.current]); diff --git a/src/components/documents/TaskState/index.tsx b/src/components/documents/TaskState/index.tsx index 3db082718..1f53dcb3f 100644 --- a/src/components/documents/TaskState/index.tsx +++ b/src/components/documents/TaskState/index.tsx @@ -94,7 +94,7 @@ export const TaskStateComponent = observer((props: ComponentProps) => { React.useEffect(() => { if (doc.root && pageStore.current && !doc.root.isDummy) { - pageStore.current.addDocumentRoot(doc); + pageStore.current.assertDocumentRoot(doc); } }, [doc, pageStore.current]); diff --git a/src/hooks/useDocumentRoot.ts b/src/hooks/useDocumentRoot.ts index 4fedb5830..bbc534076 100644 --- a/src/hooks/useDocumentRoot.ts +++ b/src/hooks/useDocumentRoot.ts @@ -87,7 +87,7 @@ export const useDocumentRoot = ( } if (userStore.isUserSwitched) { documentRootStore.loadInNextBatch(id, meta, { - documentRoot: false, + documentRoot: 'addIfMissing', skipCreate: true }); } else { diff --git a/src/models/DocumentRoot.ts b/src/models/DocumentRoot.ts index 27f1f67ad..60630ff41 100644 --- a/src/models/DocumentRoot.ts +++ b/src/models/DocumentRoot.ts @@ -4,6 +4,7 @@ import { DocumentRootStore } from '@tdev-stores/DocumentRootStore'; import { Access, DocumentType, TypeDataMapping, TypeModelMapping } from '@tdev-api/document'; import { highestAccess, NoneAccess, ROAccess, RWAccess } from './helpers/accessPolicy'; import { isDummyId } from '@tdev-hooks/useDummyId'; +import { orderBy } from 'es-toolkit/array'; export abstract class TypeMeta { readonly pagePosition: number; @@ -101,6 +102,21 @@ class DocumentRoot { return this.store.root.permissionStore.groupPermissionsByDocumentRoot(this.id); } + @computed + get pages() { + return this.store.root.pageStore.pages.filter((p) => p.documentRootConfigs.has(this.id)); + } + + /** + * Map of page paths to their position in this document root + */ + @computed + get pagePositions() { + return new Map( + this.pages.map((p) => [p.path, p.documentRootConfigs.get(this.id)!.position]) + ); + } + @computed get permissions() { return [...this.store.currentUsersPermissions(this.id)]; @@ -165,9 +181,11 @@ class DocumentRoot { */ @computed get mainDocuments(): TypeModelMapping[T][] { - const docs = this.documents - .filter((d) => d.isMain) - .sort((a, b) => a.createdAt.getTime() - b.createdAt.getTime()) as TypeModelMapping[T][]; + const docs = orderBy( + this.documents.filter((d) => d.isMain), + ['createdAt', 'id'], + ['asc', 'asc'] + ) as TypeModelMapping[T][]; if (this.isDummy) { return docs; } diff --git a/src/models/Page.ts b/src/models/Page.ts index 0bf48ce1e..c72527a3d 100644 --- a/src/models/Page.ts +++ b/src/models/Page.ts @@ -2,29 +2,72 @@ * A Markdown or MDX Page */ -import { action, computed, observable, ObservableSet } from 'mobx'; -import { PageStore } from '@tdev-stores/PageStore'; -import TaskState from '@tdev-models/documents/TaskState'; +import { action, computed, observable, ObservableMap } from 'mobx'; +import { AUTO_GENERATED_PAGE_PREFIX, PageStore } from '@tdev-stores/PageStore'; import _ from 'es-toolkit/compat'; import iDocument from '@tdev-models/iDocument'; import StudentGroup from '@tdev-models/StudentGroup'; -import ProgressState from './documents/ProgressState'; +import { DocumentType } from '@tdev-api/document'; +import { iTaskableDocument } from './iTaskableDocument'; +import { mdiCheckCircleOutline, mdiSpeedometer, mdiSpeedometerMedium, mdiSpeedometerSlow } from '@mdi/js'; +import { IfmColors } from '@tdev-components/shared/Colors'; +interface PageConfig { + type: DocumentType; + position: number; +} export default class Page { readonly store: PageStore; readonly id: string; - refetchTimestamps: number[] = []; + readonly path: string; + initialLoadComplete = false; @observable.ref accessor _primaryStudentGroupName: string | undefined = undefined; @observable.ref accessor _activeStudentGroup: StudentGroup | undefined = undefined; - documentRootIds: ObservableSet; + documentRootConfigs: ObservableMap; dynamicValues = observable.map(); - constructor(id: string, store: PageStore) { + constructor(id: string, path: string, store: PageStore) { this.id = id; + this.path = path; this.store = store; - this.documentRootIds = observable.set([id]); + this.documentRootConfigs = observable.map( + this.isAutoGenerated ? [] : [[id, { type: 'mdx_comment', position: 0 }]], + { deep: false } + ); + } + + @computed + get isAutoGenerated() { + return this.id.startsWith(AUTO_GENERATED_PAGE_PREFIX); + } + + @computed + get isLandingpage() { + return this.store.sidebarVersions.some((version) => version.rootPaths.includes(this.path)); + } + + @computed + get parentPath() { + const parts = this.path.split('/').slice(0, -2); + while (parts.length > 1) { + const parentPath = `${parts.join('/')}/`; + const parentPage = this.store.pages.find((p) => p.path === parentPath); + if (parentPage) { + return parentPage.path; + } + if (this.store.sidebarVersions.some((v) => v.versionPath === parentPath)) { + return parentPath; + } + parts.splice(-1, 1); + } + return '/'; + } + + @computed + get subPages() { + return this.store.pages.filter((page) => page.parentPath === this.path); } @action @@ -37,32 +80,35 @@ export default class Page { } @action - addDocumentRoot(doc: iDocument) { - this.documentRootIds.add(doc.documentRootId); + assertDocumentRoot(doc: iDocument) { + if (process.env.NODE_ENV === 'production') { + return; + } + if (!this.documentRootConfigs.has(doc.documentRootId)) { + this.store.loadPageIndex(true); + } } - @computed - get documentRoots() { - return this.store.root.documentRootStore.documentRoots.filter( - (doc) => this.documentRootIds.has(doc.id) && !doc.isDummy - ); + @action + addDocumentRootConfig(id: string, config: PageConfig) { + this.documentRootConfigs.set(id, { type: config.type, position: config.position }); } @computed - get documents() { - return this.documentRoots - .flatMap((doc) => doc.firstMainDocument) - .filter((d) => d?.root?.meta.pagePosition) - .sort((a, b) => a!.root!.meta!.pagePosition - b!.root!.meta.pagePosition); + get documentRoots() { + return this.store.root.documentRootStore.documentRoots + .filter((doc) => this.documentRootConfigs.has(doc.id) && !doc.isDummy) + .sort((a, b) => { + const pA = this.documentRootConfigs.get(a.id)!.position; + const pB = this.documentRootConfigs.get(b.id)!.position; + return pA - pB; + }); } @computed - get editingState(): (TaskState | ProgressState)[] { + get documents() { return this.documentRoots .flatMap((doc) => doc.firstMainDocument) - .filter( - (d): d is TaskState | ProgressState => d instanceof TaskState || d instanceof ProgressState - ) .filter((d) => d?.root?.meta.pagePosition) .sort((a, b) => a!.root!.meta!.pagePosition - b!.root!.meta.pagePosition); } @@ -100,18 +146,95 @@ export default class Page { * loads all linked document roots (added by #addDocumentRoot) */ @action - loadLinkedDocumentRoots() { - this.refetchTimestamps.push(Date.now()); - return this.store.loadAllDocuments(this).catch((err) => { - const now = Date.now(); - const ts = this.refetchTimestamps.filter((ts) => now - ts < 10_000); - if (ts.length < 5) { - setTimeout(() => this.loadLinkedDocumentRoots(), 500); - } - console.warn('Failed to load linked document roots for page', this, err); + loadLinkedDocumentRoots(force = false) { + if (!force && !this.store.root.userStore.isUserSwitched) { + return; + } + if (!force && this.initialLoadComplete) { + return; + } + this.initialLoadComplete = true; + return this.store.loadAllDocuments(this); + } + + get TaskableDocuments() { + return this.store.root.componentStore.taskableDocuments; + } + + @computed + get taskableDocumentRootIds() { + return [...this.documentRootConfigs.keys()].filter((id) => { + const config = this.documentRootConfigs.get(id)!; + return this.TaskableDocuments.has(config.type); + }); + } + + @computed + get taskableDocuments(): iTaskableDocument[] { + const uid = this.store.root.userStore.viewedUserId; + if (!uid) { + return []; + } + return this.taskableDocumentRootIds.flatMap((rid) => { + return this.store.root.documentStore + .findByDocumentRoot(rid) + .filter( + (doc) => doc.authorId === uid && this.TaskableDocuments.has(doc.type) + ) as iTaskableDocument[]; }); } + @computed + get stepsOnPage(): number { + return this.taskableDocuments.length; + } + + @computed + get stepsOnDirectSubPages(): number { + return this.subPages.reduce((sum, page) => sum + page.stepsOnPage, 0); + } + + @computed + get totalSteps(): number { + return this.stepsOnPage + this.subPages.reduce((sum, page) => sum + page.totalSteps, 0); + } + + @computed + get progress(): number { + return ( + this.taskableDocuments.filter((d) => d.isDone).length + + this.subPages.reduce((sum, page) => sum + page.progress, 0) + ); + } + + @computed + get isDone(): boolean { + return this.progress > 0 && this.progress >= this.totalSteps; + } + + @computed + get editingIconState() { + if (this.isDone) { + return { path: mdiCheckCircleOutline, color: IfmColors.green }; + } + const level = this.progress / this.totalSteps; + if (this.progress === 0) { + return { path: mdiSpeedometerSlow, color: IfmColors.gray }; + } + if (level < 1 / 3) { + return { path: mdiSpeedometerSlow, color: IfmColors.red }; + } + if (level < 2 / 3) { + return { path: mdiSpeedometerMedium, color: IfmColors.orange }; + } + return { path: mdiSpeedometer, color: IfmColors.lightGreen }; + } + + @computed + get editingState(): iTaskableDocument[] { + return this.taskableDocuments; + } + @action toggleActiveStudentGroup(studentGroup: StudentGroup) { if (this._activeStudentGroup && this._activeStudentGroup.id === studentGroup.id) { @@ -141,17 +264,15 @@ export default class Page { @computed get editingStateByUsers() { return _.groupBy( - this.documentRoots - .flatMap((dr) => dr.allDocuments) - .filter( - (d): d is TaskState | ProgressState => - d instanceof TaskState || d instanceof ProgressState - ) - .filter((doc) => doc.isMain && doc.root?.meta.pagePosition) + this.taskableDocumentRootIds + .flatMap((rid) => { + return this.store.root.documentStore + .findByDocumentRoot(rid) + .filter((doc) => this.TaskableDocuments.has(doc.type)) as iTaskableDocument[]; + }) .filter((doc) => this.activeStudentGroup ? this.activeStudentGroup.userIds.has(doc.authorId) : true - ) - .sort((a, b) => a.root!.meta.pagePosition - b.root!.meta.pagePosition), + ), (doc) => doc.authorId ); } diff --git a/src/models/documents/DynamicDocumentRoots/index.ts b/src/models/documents/DynamicDocumentRoots/index.ts index a56cee11f..da808568c 100644 --- a/src/models/documents/DynamicDocumentRoots/index.ts +++ b/src/models/documents/DynamicDocumentRoots/index.ts @@ -70,7 +70,7 @@ class DynamicDocumentRoots extends iDocument<'dynami addedIds.forEach((id) => { this.store.root.documentRootStore.loadInNextBatch(id, this.defaultContainerMeta, { documentType: this.containerType, - documentRoot: true + documentRoot: 'replace' }); }); } @@ -191,7 +191,7 @@ class DynamicDocumentRoots extends iDocument<'dynami return [...this.documentRootIds].map((id) => { this.store.root.documentRootStore.loadInNextBatch(id, this.defaultContainerMeta, { documentType: this.containerType, - documentRoot: true + documentRoot: 'replace' }); }); } diff --git a/src/models/documents/ProgressState/index.ts b/src/models/documents/ProgressState/index.ts index 00c8ec12e..294713c9b 100644 --- a/src/models/documents/ProgressState/index.ts +++ b/src/models/documents/ProgressState/index.ts @@ -7,6 +7,7 @@ import { RWAccess } from '@tdev-models/helpers/accessPolicy'; import { mdiCheckCircleOutline, mdiSpeedometer, mdiSpeedometerMedium, mdiSpeedometerSlow } from '@mdi/js'; import { IfmColors } from '@tdev-components/shared/Colors'; import Step from './Step'; +import type { iTaskableDocument } from '@tdev-models/iTaskableDocument'; export interface MetaInit { readonly?: boolean; @@ -52,13 +53,15 @@ export class ModelMeta extends TypeMeta<'progress_state'> { get defaultData(): TypeDataMapping['progress_state'] { return { - progress: this.default + progress: this.default, + totalSteps: Math.max(this.default, 1) }; } } -class ProgressState extends iDocument<'progress_state'> { +class ProgressState extends iDocument<'progress_state'> implements iTaskableDocument<'progress_state'> { @observable accessor _progress: number = 0; + @observable accessor _totalSteps: number = 0; @observable accessor _viewedIndex: number | undefined = undefined; @observable accessor scrollTo: boolean = false; @observable accessor hoveredIndex: number | undefined = undefined; @@ -69,6 +72,7 @@ class ProgressState extends iDocument<'progress_state'> { constructor(props: DocumentProps<'progress_state'>, store: DocumentStore) { super(props, store); this._progress = props.data?.progress ?? 0; + this.setTotalSteps(Math.max(props.data?.totalSteps ?? 1, props.data?.progress ?? 0, 1), true); } get canStepBack(): boolean { @@ -91,19 +95,19 @@ class ProgressState extends iDocument<'progress_state'> { } @action - setData(data: TypeDataMapping['progress_state'], from: Source, updatedAt?: Date): void { + setData(data: Partial, from: Source, updatedAt?: Date): void { if (!RWAccess.has(this.root?.permission)) { return; } - const { progress } = data; + const { progress, totalSteps } = data; if (progress && !this.steps[progress]?.canToggleContent && this.progress + 1 !== progress) { return; } - if (!this.canStepBack && progress < this.progress) { - return; + if (progress !== undefined && (this.canStepBack || progress > this.progress)) { + this._progress = progress; } - if (data.progress !== undefined) { - this._progress = data.progress; + if (totalSteps !== undefined) { + this.setTotalSteps(totalSteps, true); } if (from === Source.LOCAL) { @@ -116,7 +120,8 @@ class ProgressState extends iDocument<'progress_state'> { get data(): TypeDataMapping['progress_state'] { return { - progress: this._progress + progress: this._progress, + totalSteps: this._totalSteps }; } @@ -150,21 +155,19 @@ class ProgressState extends iDocument<'progress_state'> { @computed get totalSteps(): number { - return ( - this.steps.length || - ( - (this.root?.documents || []).find( - (ps) => ps.type === 'progress_state' && ps?.steps.length > 0 - ) as ProgressState | undefined - )?.steps?.length || - 0 - ); + return Math.max(this._totalSteps, 1, this.progress); } @action - setTotalSteps(totalSteps: number) { - if (this.totalSteps !== totalSteps && totalSteps > 0) { - this.steps.replace(Array.from({ length: totalSteps }, (_, i) => new Step(i, this))); + setTotalSteps(totalSteps: number, skipSave: boolean = false) { + const skip = this._totalSteps !== 0 && this.totalSteps === totalSteps; + if (totalSteps < 1 || skip) { + return; + } + this._totalSteps = totalSteps; + this.steps.replace(Array.from({ length: totalSteps }, (_, i) => new Step(i, this))); + if (!skipSave) { + this.saveNow(); } } @@ -175,6 +178,9 @@ class ProgressState extends iDocument<'progress_state'> { @computed get isDone(): boolean { + if (!this.totalSteps) { + return false; + } return this.progress > 0 && this.progress >= this.totalSteps; } @@ -219,7 +225,7 @@ class ProgressState extends iDocument<'progress_state'> { @computed get progress(): number { - return this.derivedData.progress ?? this.meta.default; + return this._progress ?? this.meta.default; } @computed diff --git a/src/models/documents/TaskState.ts b/src/models/documents/TaskState.ts index c2a306e9f..ed3530112 100644 --- a/src/models/documents/TaskState.ts +++ b/src/models/documents/TaskState.ts @@ -12,6 +12,7 @@ import { TypeMeta } from '@tdev-models/DocumentRoot'; import { RWAccess } from '@tdev-models/helpers/accessPolicy'; import { mdiIcon } from '@tdev-components/documents/TaskState'; import { mdiColor } from '@tdev-components/EditingOverview'; +import type { iTaskableDocument } from '@tdev-models/iTaskableDocument'; export interface MetaInit { readonly?: boolean; @@ -39,7 +40,7 @@ export class TaskMeta extends TypeMeta<'task_state'> { } } -class TaskState extends iDocument<'task_state'> { +class TaskState extends iDocument<'task_state'> implements iTaskableDocument<'task_state'> { @observable accessor _taskState: StateType; @observable accessor scrollTo: boolean = false; constructor(props: DocumentProps<'task_state'>, store: DocumentStore) { @@ -78,6 +79,16 @@ class TaskState extends iDocument<'task_state'> { return this.taskState === 'checked'; } + @computed + get progress(): number { + return this.isDone ? 1 : 0; + } + + @computed + get totalSteps(): number { + return 1; + } + @computed get editingIconState() { return { diff --git a/src/models/iDocumentContainer.ts b/src/models/iDocumentContainer.ts index 8e3d2a3fd..bbb4c3dbc 100644 --- a/src/models/iDocumentContainer.ts +++ b/src/models/iDocumentContainer.ts @@ -80,9 +80,9 @@ abstract class iDocumentContainer extends iDocument< this.documentRootId, undefined /* meta is only needed when you want to create a "default" document */, { - userPermissions: false /* already present from this container */, - groupPermissions: false /* already present from this container */, - documentRoot: false /* already present from this container */, + userPermissions: false /* already present for this container */, + groupPermissions: false /* already present for this container */, + documentRoot: false /* already present for this container */, skipCreate: true, documents: true } diff --git a/src/models/iTaskableDocument.ts b/src/models/iTaskableDocument.ts new file mode 100644 index 000000000..189e56a77 --- /dev/null +++ b/src/models/iTaskableDocument.ts @@ -0,0 +1,10 @@ +import type { TaskableType } from '@tdev-api/document'; +import iDocument from './iDocument'; + +export interface iTaskableDocument extends iDocument { + isDone: boolean; + editingIconState: { path: string; color: string }; + progress: number; + totalSteps: number; + setScrollTo(scroll: boolean): void; +} diff --git a/src/plugins/remark-page/plugin.ts b/src/plugins/remark-page/plugin.ts index 709756319..18d797035 100644 --- a/src/plugins/remark-page/plugin.ts +++ b/src/plugins/remark-page/plugin.ts @@ -15,7 +15,7 @@ const plugin: Plugin = function plugin(): Transformer { if (!page_id) { return; } - visit(root, (node, index, parent) => { + visit(root, (node, idx, parent) => { /** add the MdxPage exactly once at the top of the document and exit */ if (root === node && !parent) { const loaderNode: MdxJsxFlowElement = { diff --git a/src/siteConfig/markdownPluginConfigs.ts b/src/siteConfig/markdownPluginConfigs.ts index 2c62430f8..f219e8a39 100644 --- a/src/siteConfig/markdownPluginConfigs.ts +++ b/src/siteConfig/markdownPluginConfigs.ts @@ -1,5 +1,6 @@ -import type { Node } from 'mdast'; +import type { Code, Node } from 'mdast'; import type { LeafDirective } from 'mdast-util-directive'; +import type { MdxJsxFlowElement } from 'mdast-util-mdx'; import strongPlugin, { transformer as captionVisitor } from '../plugins/remark-strong/plugin'; import deflistPlugin from '../plugins/remark-deflist/plugin'; import mdiPlugin from '../plugins/remark-mdi/plugin'; @@ -13,11 +14,15 @@ import linkAnnotationPlugin from '../plugins/remark-link-annotation/plugin'; import mediaPlugin from '../plugins/remark-media/plugin'; import detailsPlugin from '../plugins/remark-details/plugin'; import pagePlugin from '../plugins/remark-page/plugin'; +import pageIndexPlugin, { + type PluginOptions as PageIndexPluginOptions +} from '@tdev/page-index/remark-plugin'; import graphvizPlugin from '@tdev/remark-graphviz/remark-plugin'; import pdfPlugin from '@tdev/remark-pdf/remark-plugin'; import codeAsAttributePlugin from '../plugins/remark-code-as-attribute/plugin'; import commentPlugin from '../plugins/remark-comments/plugin'; import enumerateAnswersPlugin from '../plugins/remark-enumerate-components/plugin'; +import { getAnswerDocumentType } from '../components/Answer/helper.answer'; export const flexCardsPluginConfig = [ flexCardsPlugin, @@ -133,7 +138,75 @@ export const enumerateAnswersPluginConfig = [ export const pdfPluginConfig = pdfPlugin; -export const pagePluginConfig = pagePlugin; +export const pagePluginConfig = [pagePlugin, {}]; + +export const PageIndexPluginDefaultOptions: PageIndexPluginOptions = { + components: [ + { + name: 'Answer', + docTypeExtractor: (node) => { + return ( + getAnswerDocumentType( + node.attributes.find((a) => a.type === 'mdxJsxAttribute' && a.name === 'type') + ?.value as string + ) || 'unknown' + ); + } + }, + { + name: 'ProgressState', + docTypeExtractor: () => 'progress_state' + }, + { + name: 'TaskState', + docTypeExtractor: () => 'task_state' + }, + { + name: 'QuillV2', + docTypeExtractor: () => 'quill_v2' + }, + { + name: 'String', + docTypeExtractor: () => 'string' + }, + { + name: 'CmsText', + docTypeExtractor: () => 'cms_text' + }, + { + name: 'CmsCode', + docTypeExtractor: () => 'cms_text' + }, + { + name: 'Restricted', + docTypeExtractor: () => 'restricted' + }, + { + name: 'DynamicDocumentRoots', + docTypeExtractor: () => 'dynamic_document_roots' + } + ], + persistedCodeType: (node: Code) => { + if (node.lang === 'html') { + return 'script'; + } + const liveLangMatch = /(live_[a-zA-Z0-9-_]+)/.exec(node.meta || ''); + const liveCode = liveLangMatch ? liveLangMatch[1] : null; + + switch (liveCode) { + case 'live_py': + case 'live_bry': + // legacy name, TODO. should be 'brython_code'? + return 'script'; + case 'live_pyo': + return 'pyodide_code'; + default: + return 'code'; + } + } +}; +export const pageIndexPluginConfig = [pageIndexPlugin, PageIndexPluginDefaultOptions]; + export const graphvizPluginConfig = graphvizPlugin; export const commentPluginConfig = [ @@ -173,6 +246,7 @@ export const recommendedRemarkPlugins = [ enumerateAnswersPluginConfig, pdfPluginConfig, pagePluginConfig, + pageIndexPluginConfig, commentPluginConfig, linkAnnotationPluginConfig, codeAsAttributePluginConfig diff --git a/src/stores/ComponentStore.ts b/src/stores/ComponentStore.ts index 590702442..8a4729b88 100644 --- a/src/stores/ComponentStore.ts +++ b/src/stores/ComponentStore.ts @@ -2,9 +2,11 @@ import { CodeMeta } from '@tdev-models/documents/Code'; import { RootStore } from './rootStore'; import { type CodeType, + type DocumentType, TypeModelMapping, type ContainerType, - type ContainerTypeModelMapping + type ContainerTypeModelMapping, + TaskableType } from '@tdev-api/document'; import { ContainerMeta } from '@tdev-models/documents/DynamicDocumentRoots/ContainerMeta'; import iCodeMeta, { MetaInit } from '@tdev-models/documents/iCode/iCodeMeta'; @@ -49,6 +51,7 @@ class ComponentStore { readonly root: RootStore; components = new Map(); editorComponents = new Map(); + taskableDocuments = new Set(['task_state', 'progress_state']); constructor(root: RootStore) { this.root = root; @@ -62,6 +65,18 @@ class ComponentStore { this.components.set(type, component as ContainerComponent); } + registerTaskableDocumentType(type: TaskableType) { + this.taskableDocuments.add(type); + } + + @computed + get defaultMeta() { + return [ + ...[...this.components.values()].map((comp) => comp.defaultMeta), + ...[...this.editorComponents.values()].map((comp) => comp.createModelMeta({})) + ]; + } + @computed get registeredContainerTypes(): ContainerType[] { return [...this.components.keys()]; diff --git a/src/stores/DocumentRootStore.ts b/src/stores/DocumentRootStore.ts index 1dca366b4..1c5a38daa 100644 --- a/src/stores/DocumentRootStore.ts +++ b/src/stores/DocumentRootStore.ts @@ -18,6 +18,15 @@ import { DocumentType } from '@tdev-api/document'; import _ from 'es-toolkit/compat'; import User from '@tdev-models/User'; import { NoneAccess } from '@tdev-models/helpers/accessPolicy'; +import { ModelMeta as ProgressStateMeta } from '@tdev-models/documents/ProgressState'; +import { CodeMeta } from '@tdev-models/documents/Code'; +import { ModelMeta as MdxCommentMeta } from '@tdev-models/documents/MdxComment'; +import { ModelMeta as RestrictedMeta } from '@tdev-models/documents/Restricted'; +import { ModelMeta as SolutionMeta } from '@tdev-models/documents/Solution'; +import { ModelMeta as StringMeta } from '@tdev-models/documents/String'; +import { TaskMeta as TaskStateMeta } from '@tdev-models/documents/TaskState'; + +import { CmsTextMeta } from '@tdev-models/documents/CmsText'; type LoadConfig = { /** if true, user permissions will be loaded @@ -30,11 +39,14 @@ type LoadConfig = { */ groupPermissions?: boolean; /** - * if true, the document root will be created and when already exists, - * it will replace the existing one - * @default true + * @option 'replace': the document root will be created and when already exists, + * it will replace the existing one. + * @option 'addIfMissing': when the document root does not exist in the mobx store, it will + * be added. But no new document root will be created on the api. + * @option false: the document root will not be loaded. + * @default 'replace' */ - documentRoot?: boolean; + documentRoot?: 'replace' | 'addIfMissing' | boolean; /** * if a document root should not be created when it is not found, * set `skipCreate` to true @@ -59,6 +71,17 @@ type BatchedMeta = { access: Partial; }; +const DefaultMeta: TypeMeta[] = [ + new CodeMeta({}), + new MdxCommentMeta({}), + new RestrictedMeta({}), + new SolutionMeta({}), + new StringMeta({}), + new TaskStateMeta({}), + new ProgressStateMeta({}), + new CmsTextMeta({}) +]; + export class DocumentRootStore extends iStore { readonly root: RootStore; documentRoots = observable.array>([]); @@ -75,6 +98,11 @@ export class DocumentRootStore extends iStore { return this.root.sessionStore.isLoggedIn; } + @computed + get defaultMetas(): TypeMeta[] { + return [...DefaultMeta, ...this.root.componentStore.defaultMeta]; + } + @action addDocumentRoot( documentRoot: DocumentRoot, @@ -123,7 +151,7 @@ export class DocumentRootStore extends iStore { this.queued.set(id, { meta: meta, load: { - documentRoot: true, + documentRoot: 'replace', groupPermissions: true, userPermissions: true, skipCreate: false, @@ -170,13 +198,13 @@ export class DocumentRootStore extends iStore { this.loadQueued(); console.log('Postponing', postponed.length, 'document roots for next batch'); } - const current = new Map(batch); + const currentBatch = new Map(batch); /** * if the user is not logged in, we can't load the documents * so we just mark all queued documents as loaded */ if (!this.root.sessionStore.isLoggedIn) { - [...current.keys()].forEach((id) => { + [...currentBatch.keys()].forEach((id) => { const dummyModel = this.find(id); if (dummyModel && dummyModel.isDummy) { dummyModel.setLoaded(); @@ -188,16 +216,16 @@ export class DocumentRootStore extends iStore { /** * load all queued documents */ - const rootIds = [...current.keys()].sort(); + const rootIds = [...currentBatch.keys()].sort(); const idConfigs: [DocumentType | undefined, string[]][] = []; - const rootIdsWithDocs = rootIds.filter((id) => !current.get(id)!.load.documentType); + const rootIdsWithDocs = rootIds.filter((id) => !currentBatch.get(id)!.load.documentType); if (rootIdsWithDocs.length > 0) { idConfigs.push([undefined, rootIdsWithDocs]); } rootIds - .filter((id) => current.get(id)!.load.documentType) + .filter((id) => currentBatch.get(id)!.load.documentType) .reduce((acc, id) => { - const type = current.get(id)!.load.documentType; + const type = currentBatch.get(id)!.load.documentType; const idx = acc.findIndex((item) => item[0] === type); if (idx < 0) { acc.push([type, [id]]); @@ -220,21 +248,21 @@ export class DocumentRootStore extends iStore { ).then((results) => results.flatMap((r) => r.data)); runInAction(() => { models.forEach((data) => { - const config = current.get(data.id); + const config = currentBatch.get(data.id); if (!config) { return; } this.addApiResultToStore(data, config); - current.delete(data.id); + currentBatch.delete(data.id); }); }); if (!isUserSwitched) { // create all missing root documents const created = await Promise.all( - [...current.keys()] - .filter((id) => !this.find(id)?.isLoaded && !current.get(id)!.load.skipCreate) + [...currentBatch.keys()] + .filter((id) => !this.find(id)?.isLoaded && !currentBatch.get(id)!.load.skipCreate) .map((id) => { - const config = current.get(id); + const config = currentBatch.get(id); if (config && config.meta) { return this.create(id, config.meta, config.access).catch(() => { // queue it up for loading later - the model was probably generated in the mean time? @@ -258,12 +286,12 @@ export class DocumentRootStore extends iStore { created .filter((docRoot) => !!docRoot) .forEach((docRoot) => { - current.delete(docRoot.id); + currentBatch.delete(docRoot.id); }); } // mark all remaining roots as loaded runInAction(() => { - [...current.keys()].forEach((id) => { + [...currentBatch.keys()].forEach((id) => { const dummyModel = this.find(id); if (dummyModel && dummyModel.isDummy) { dummyModel.setLoaded(); @@ -275,17 +303,27 @@ export class DocumentRootStore extends iStore { @action addApiResultToStore(data: ApiDocumentRoot, config: Omit) { - if (config.load.documentRoot && !config.meta) { + if (config.load.documentRoot === 'replace' && !config.meta) { return; } - const documentRoot = config.load.documentRoot - ? new DocumentRoot(data, config.meta!, this) - : this.find(data.id); + const defaultType = data.documents[0]?.type; + const meta = + config.meta || + (this.find(data.id)?.meta as TypeMeta) || + (defaultType ? this.defaultMetas.find((m) => m.type === defaultType) : undefined); + const documentRoot = + config.load.documentRoot && meta ? new DocumentRoot(data, meta, this) : this.find(data.id); if (!documentRoot) { return; } if (config.load.documentRoot) { - this.addDocumentRoot(documentRoot, { cleanup: true, deep: false }); + if (config.load.documentRoot === 'addIfMissing') { + if (!this.find(data.id)) { + this.addDocumentRoot(documentRoot); + } + } else { + this.addDocumentRoot(documentRoot, { cleanup: true, deep: false }); + } } if (config.load.groupPermissions) { data.groupPermissions.forEach((gp) => { @@ -391,7 +429,7 @@ export class DocumentRootStore extends iStore { @action reload(documentRoot: DocumentRoot) { this.loadInNextBatch(documentRoot.id, documentRoot.meta, { - documentRoot: true, + documentRoot: 'replace', documents: true, groupPermissions: true, userPermissions: true diff --git a/src/stores/PageStore.ts b/src/stores/PageStore.ts index 9ea2e63c5..18e50e2ab 100644 --- a/src/stores/PageStore.ts +++ b/src/stores/PageStore.ts @@ -4,6 +4,41 @@ import { RootStore } from '@tdev-stores/rootStore'; import Page from '@tdev-models/Page'; import { computedFn } from 'mobx-utils'; import { allDocuments as apiAllDocuments, DocumentType } from '@tdev-api/document'; +import type { GlobalPluginData } from '@docusaurus/plugin-content-docs/client'; +import siteConfig from '@generated/docusaurus.config'; +import { PageIndex } from '@tdev/page-index'; +import { groupBy } from 'es-toolkit/array'; +import globalData from '@generated/globalData'; +const ensureTrailingSlash = (str: string) => { + return str.endsWith('/') ? str : `${str}/`; +}; +export const AUTO_GENERATED_PAGE_PREFIX = '__auto_generated__'; +export const SidebarVersions = ( + globalData['docusaurus-plugin-content-docs'].default as GlobalPluginData +).versions.map((version) => { + const versionPath = ensureTrailingSlash(version.path); + const slashCount = version.path.split('/').length + 1; + const rdocs = version.docs.filter( + (doc) => + doc.path.startsWith(version.path) && doc.path.replace(/\/$/, '').split('/').length === slashCount + ); + return { + name: version.name, + rootPaths: rdocs.map((doc) => ensureTrailingSlash(doc.path)), + versionPath: versionPath + }; +}); + +const getPathTree = (pagePath: string) => { + const parts = pagePath.split('/').filter((p) => p.length > 0); + return parts.map((_, idx) => { + return `/${parts.slice(0, idx + 1).join('/')}/`; + }); +}; + +interface PagesIndex { + documentRoots: PageIndex[]; +} export class PageStore extends iStore { readonly root: RootStore; @@ -13,11 +48,73 @@ export class PageStore extends iStore { @observable accessor currentPageId: string | undefined = undefined; @observable accessor runningTurtleScriptId: string | undefined = undefined; + @observable.ref accessor _pageIndex: PageIndex[] = []; + constructor(store: RootStore) { super(); this.root = store; } + get sidebarVersions() { + return SidebarVersions; + } + + @computed + get landingPages() { + return this.pages.filter((page) => page.isLandingpage); + } + + @action + loadPageIndex(force: boolean = false) { + if (!force && this._pageIndex.length > 0) { + return Promise.resolve(); + } + return fetch(`${siteConfig.baseUrl}tdev-artifacts/page-progress-state/pageIndex.json`) + .then((res) => { + return res.json() as Promise; + }) + .then( + action((data) => { + const grouped = groupBy(data.documentRoots, (dr) => `${dr.path}::${dr.page_id}`); + const pages = Object.values(grouped).map((docRootDescriptors) => { + const doc = docRootDescriptors[0]!; + const page = new Page(doc.page_id, doc.path, this); + docRootDescriptors + .filter((doc) => doc.position > 0) + .forEach((d) => page.addDocumentRootConfig(d.id, d)); + return page; + }); + const addedPaths = new Set(pages.map((p) => p.path)); + const fullTree = new Set(pages.flatMap((p) => getPathTree(p.path))); + const missingPaths = Array.from(fullTree).filter((p) => !addedPaths.has(p)); + missingPaths.forEach((path) => { + const page = new Page(`${AUTO_GENERATED_PAGE_PREFIX}${path}`, path, this); + pages.push(page); + }); + this.pages.replace(pages); + this._pageIndex = data.documentRoots; + }) + ) + .then(() => { + this.loadTaskableDocuments(); + }) + .catch((err) => { + console.error('Failed to load page index', err); + }); + } + + @action + loadTaskableDocuments() { + this.pages.forEach((page) => { + page.taskableDocumentRootIds.forEach((id) => { + this.root.documentRootStore.loadInNextBatch(id, undefined, { + skipCreate: true, + documentRoot: 'addIfMissing' + }); + }); + }); + } + find = computedFn( function (this: PageStore, id?: string): Page | undefined { if (!id) { @@ -33,19 +130,13 @@ export class PageStore extends iStore { return this.find(this.currentPageId); } - @action - addToStore(page: Page) { - const old = this.find(page.id); - if (old) { - this.pages.remove(old); - } - this.pages.push(page); - } - @action addIfNotPresent(id: string, makeCurrent?: boolean) { if (!this.find(id)) { - const page = new Page(id, this); + if (process.env.NODE_ENV !== 'production') { + this.loadPageIndex(true); + } + const page = new Page(id, window.location.pathname, this); this.pages.push(page); } if (makeCurrent) { @@ -61,7 +152,7 @@ export class PageStore extends iStore { @action loadAllDocuments(page: Page) { return this.withAbortController(`load-all-${page.id}`, (sig) => { - return apiAllDocuments([...page.documentRootIds], sig.signal).then(({ data }) => { + return apiAllDocuments([...page.documentRootConfigs.keys()], sig.signal).then(({ data }) => { return transaction(() => { return data.map((doc) => { return this.root.documentStore.addToStore(doc); diff --git a/src/stores/SocketDataStore.ts b/src/stores/SocketDataStore.ts index dd61f4ea6..f7371789b 100644 --- a/src/stores/SocketDataStore.ts +++ b/src/stores/SocketDataStore.ts @@ -260,7 +260,7 @@ export class SocketDataStore extends iStore<'ping'> { this.root.documentRootStore.addApiResultToStore(docRoot, { meta: current.meta, load: { - documentRoot: true, + documentRoot: 'replace', documents: NoneAccess.has( current.permission ) /** only load the documents, when the current permission is None */, diff --git a/src/stores/rootStore.ts b/src/stores/rootStore.ts index c44cf01c7..821a873f9 100644 --- a/src/stores/rootStore.ts +++ b/src/stores/rootStore.ts @@ -51,6 +51,7 @@ export class RootStore { @action load(userId: string) { + this.pageStore.loadPageIndex(); this.sessionStore.setCurrentUserId(userId); this.sessionStore.setIsLoggedIn(!!userId); this.userStore.loadCurrent().then((user) => { @@ -60,6 +61,7 @@ export class RootStore { /** * load stores */ + this.userStore.load(); this.studentGroupStore.load(); this.cmsStore.initialize(); diff --git a/src/theme/DocItem/Content/index.tsx b/src/theme/DocItem/Content/index.tsx index 12295d8d1..b8cb753cb 100644 --- a/src/theme/DocItem/Content/index.tsx +++ b/src/theme/DocItem/Content/index.tsx @@ -21,11 +21,7 @@ const ContentWrapper = observer((props: Props): React.ReactNode => { }; }, [pageStore.current, location.pathname]); - return ( - <> - - - ); + return ; }); export default ContentWrapper; diff --git a/src/theme/DocSidebarItem/index.tsx b/src/theme/DocSidebarItem/index.tsx new file mode 100644 index 000000000..29c85cbe5 --- /dev/null +++ b/src/theme/DocSidebarItem/index.tsx @@ -0,0 +1,34 @@ +import React, { type ReactNode } from 'react'; +import DocSidebarItem from '@theme-original/DocSidebarItem'; +import type DocSidebarItemType from '@theme/DocSidebarItem'; +import type { WrapperProps } from '@docusaurus/types'; +import { observer } from 'mobx-react-lite'; +import { useStore } from '@tdev-hooks/useStore'; +import clsx from 'clsx'; +import styles from './styles.module.scss'; +import TaskableState from '@tdev/page-index/components/TaskableState'; +const ensureTrailingSlash = (path?: string) => { + if (!path) { + return ''; + } + return path.endsWith('/') ? path : path + '/'; +}; + +type Props = WrapperProps; +const DocSidebarItemWrapper = observer((props: Props): ReactNode => { + const pageStore = useStore('pageStore'); + const path = props.item.type !== 'html' ? ensureTrailingSlash(props.item.href) : undefined; + const page = pageStore.pages.find((p) => p.path === path); + return ( +
+ + +
+ ); +}); + +export default DocSidebarItemWrapper; diff --git a/src/theme/DocSidebarItem/styles.module.scss b/src/theme/DocSidebarItem/styles.module.scss new file mode 100644 index 000000000..2df830a7a --- /dev/null +++ b/src/theme/DocSidebarItem/styles.module.scss @@ -0,0 +1,20 @@ +.item { + position: relative; + .icon { + position: absolute; + right: 0.5em; + top: 0; + z-index: 0; + &.category { + right: 3em; + } + } + &:has(> .icon:hover) { + > li:has(+ .icon:hover) { + > a, + > div { + background: var(--ifm-menu-color-background-hover); + } + } + } +} diff --git a/src/theme/Root.tsx b/src/theme/Root.tsx index c7be59b4f..3fba443d5 100644 --- a/src/theme/Root.tsx +++ b/src/theme/Root.tsx @@ -11,6 +11,10 @@ import LoggedOutOverlay from '@tdev-components/LoggedOutOverlay'; import { authClient } from '@tdev/auth-client'; import { getOfflineUser } from '@tdev-api/OfflineApi'; import ExecutionEnvironment from '@docusaurus/ExecutionEnvironment'; +import type { GlobalPluginData } from '@docusaurus/plugin-content-docs/client'; +import { usePluginData } from '@docusaurus/useGlobalData'; +import { Hashery } from 'hashery'; +const hasher = new Hashery(); const { OFFLINE_API, SENTRY_DSN } = siteConfig.customFields as { SENTRY_DSN?: string; OFFLINE_API?: boolean | 'memory' | 'indexedDB'; @@ -175,6 +179,45 @@ const FullscreenHandler = observer(() => { }, []); return null; }); +let devHash: string | null = null; +const DevGlobalDataTracker = observer(() => { + if (process.env.NODE_ENV === 'production') { + return null; + } + const pageStore = useStore('pageStore'); + const global = usePluginData('docusaurus-plugin-content-docs', 'default') as GlobalPluginData; + React.useEffect(() => { + const controller = new AbortController(); + const check = async () => { + const pIndex = await fetch( + `${siteConfig.baseUrl}tdev-artifacts/page-progress-state/pageIndex.json`, + { signal: controller.signal } + ) + .then((res) => res.json()) + .catch(() => null); + if (controller.signal.aborted || !pIndex) { + return; + } + const hash = await hasher.toHash(pIndex); + if (controller.signal.aborted) { + return; + } + if (!devHash) { + devHash = hash; + return; + } + if (devHash !== hash) { + devHash = hash; + pageStore.loadPageIndex(true); + } + }; + check(); + return () => { + controller.abort(); + }; + }, [global]); + return null; +}); function Root({ children }: { children: React.ReactNode }) { const { siteConfig } = useDocusaurusContext(); @@ -202,6 +245,7 @@ function Root({ children }: { children: React.ReactNode }) { )} {SENTRY_DSN && } + {children} diff --git a/static/tdev-artifacts/.gitignore b/static/tdev-artifacts/.gitignore new file mode 100644 index 000000000..94a2dd146 --- /dev/null +++ b/static/tdev-artifacts/.gitignore @@ -0,0 +1 @@ +*.json \ No newline at end of file diff --git a/tdev-website/docs/gallery/persistable-documents/answer/progress-state/index.mdx b/tdev-website/docs/gallery/persistable-documents/answer/progress-state/index.mdx index 6b4d7091a..0d66574c1 100644 --- a/tdev-website/docs/gallery/persistable-documents/answer/progress-state/index.mdx +++ b/tdev-website/docs/gallery/persistable-documents/answer/progress-state/index.mdx @@ -51,7 +51,7 @@ Mit der Option `confirm` müssen die einzelnen Schritte bestätigt werden. ````md import ProgressState from '@tdev-components/documents/ProgressState'; - + 1. Hello Bello and Bella 2. World **bla** __foo__ @@ -63,7 +63,7 @@ import ProgressState from '@tdev-components/documents/ProgressState'; ```` - + 1. Hello Bello and Bella 2. World **bla** __foo__ @@ -83,7 +83,7 @@ Mit `float='right'` fährt der Bestätigungs-Button nach Rechts aus. Praktisch, ````md import ProgressState from '@tdev-components/documents/ProgressState'; - + 1. Hello Bello and Bella 2. World **bla** __foo__ @@ -95,7 +95,7 @@ import ProgressState from '@tdev-components/documents/ProgressState'; ```` - + 1. Hello Bello and Bella 2. World **bla** __foo__ diff --git a/tdev-website/docs/gallery/persistable-documents/answer/task-state/index.mdx b/tdev-website/docs/gallery/persistable-documents/answer/task-state/index.mdx index 87a07e9d3..32bcab97f 100644 --- a/tdev-website/docs/gallery/persistable-documents/answer/task-state/index.mdx +++ b/tdev-website/docs/gallery/persistable-documents/answer/task-state/index.mdx @@ -69,7 +69,8 @@ TaskState kann nicht verändert werden, wenn `readonly` gesetzt wurde. ```md ``` - - + + diff --git a/updateSync/packageDocsSync/actions.ts b/updateSync/packageDocsSync/actions.ts index b477d973c..e0c1182e0 100644 --- a/updateSync/packageDocsSync/actions.ts +++ b/updateSync/packageDocsSync/actions.ts @@ -27,6 +27,9 @@ const DEFAULT_README_CONFIG: Omit 'README.mdx', '_category_.yml', '_category_.json', + 'assets/', + 'images/', + 'img/', 'assets/**', 'images/**', 'img/**' diff --git a/yarn.lock b/yarn.lock index 372f5d1db..b4e17c3cd 100644 --- a/yarn.lock +++ b/yarn.lock @@ -157,34 +157,34 @@ "@babel/highlight" "^7.25.7" picocolors "^1.0.0" -"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.28.6.tgz#72499312ec58b1e2245ba4a4f550c132be4982f7" - integrity sha512-JYgintcMjRiCvS8mMECzaEn+m3PfoQiyqukOMCCVQtoJGYJw8j/8LBJEiqkHLkfwCcs74E3pbAUFNg7d9VNJ+Q== +"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.28.6", "@babel/code-frame@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.29.0.tgz#7cd7a59f15b3cc0dcd803038f7792712a7d0b15c" + integrity sha512-9NhCeYjq9+3uxgdtp20LSiJXJvN0FeCtNGpJxuMFZ1Kv3cWUNb6DOhJwUvcVCzKGR66cw4njwM6hrJLqgOwbcw== dependencies: "@babel/helper-validator-identifier" "^7.28.5" js-tokens "^4.0.0" picocolors "^1.1.1" -"@babel/compat-data@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.28.6.tgz#103f466803fa0f059e82ccac271475470570d74c" - integrity sha512-2lfu57JtzctfIrcGMz992hyLlByuzgIk58+hhGCxjKZ3rWI82NnVLjXcaTqkI2NvlcvOskZaiZ5kjUALo3Lpxg== +"@babel/compat-data@^7.28.6", "@babel/compat-data@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.29.0.tgz#00d03e8c0ac24dd9be942c5370990cbe1f17d88d" + integrity sha512-T1NCJqT/j9+cn8fvkt7jtwbLBfLC/1y1c7NtCeXFRgzGTsafi68MRv8yzkYSapBnFA6L3U2VSc02ciDzoAJhJg== "@babel/core@^7.18.5", "@babel/core@^7.21.3", "@babel/core@^7.25.9": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.28.6.tgz#531bf883a1126e53501ba46eb3bb414047af507f" - integrity sha512-H3mcG6ZDLTlYfaSNi0iOKkigqMFvkTKlGUYlD8GW7nNOYRrevuA46iTypPyv+06V3fEmvvazfntkBU34L0azAw== + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.29.0.tgz#5286ad785df7f79d656e88ce86e650d16ca5f322" + integrity sha512-CGOfOJqWjg2qW/Mb6zNsDm+u5vFQ8DxXfbM09z69p5Z6+mE1ikP2jUXw+j42Pf1XTYED2Rni5f95npYeuwMDQA== dependencies: - "@babel/code-frame" "^7.28.6" - "@babel/generator" "^7.28.6" + "@babel/code-frame" "^7.29.0" + "@babel/generator" "^7.29.0" "@babel/helper-compilation-targets" "^7.28.6" "@babel/helper-module-transforms" "^7.28.6" "@babel/helpers" "^7.28.6" - "@babel/parser" "^7.28.6" + "@babel/parser" "^7.29.0" "@babel/template" "^7.28.6" - "@babel/traverse" "^7.28.6" - "@babel/types" "^7.28.6" + "@babel/traverse" "^7.29.0" + "@babel/types" "^7.29.0" "@jridgewell/remapping" "^2.3.5" convert-source-map "^2.0.0" debug "^4.1.0" @@ -192,13 +192,13 @@ json5 "^2.2.3" semver "^6.3.1" -"@babel/generator@^7.25.9", "@babel/generator@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.28.6.tgz#48dcc65d98fcc8626a48f72b62e263d25fc3c3f1" - integrity sha512-lOoVRwADj8hjf7al89tvQ2a1lf53Z+7tiXMgpZJL3maQPDxh0DgLMN62B2MKUOFcoodBHLMbDM6WAbKgNy5Suw== +"@babel/generator@^7.25.9", "@babel/generator@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.29.0.tgz#4cba5a76b3c71d8be31761b03329d5dc7768447f" + integrity sha512-vSH118/wwM/pLR38g/Sgk05sNtro6TlTJKuiMXDaZqPUfjTFcudpCOt00IhOfj+1BFAX+UFAlzCU+6WXr3GLFQ== dependencies: - "@babel/parser" "^7.28.6" - "@babel/types" "^7.28.6" + "@babel/parser" "^7.29.0" + "@babel/types" "^7.29.0" "@jridgewell/gen-mapping" "^0.3.12" "@jridgewell/trace-mapping" "^0.3.28" jsesc "^3.0.2" @@ -267,7 +267,7 @@ "@babel/traverse" "^7.28.5" "@babel/types" "^7.28.5" -"@babel/helper-module-imports@^7.16.7", "@babel/helper-module-imports@^7.27.1", "@babel/helper-module-imports@^7.28.6": +"@babel/helper-module-imports@^7.16.7", "@babel/helper-module-imports@^7.28.6": version "7.28.6" resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.28.6.tgz#60632cbd6ffb70b22823187201116762a03e2d5c" integrity sha512-l5XkZK7r7wa9LucGw9LwZyyCUscb4x37JWTPz7swwFE/0FMQAGpiWUZn8u9DzkSBWEcK25jmvubfpw2dnAMdbw== @@ -275,7 +275,7 @@ "@babel/traverse" "^7.28.6" "@babel/types" "^7.28.6" -"@babel/helper-module-transforms@^7.27.1", "@babel/helper-module-transforms@^7.28.3", "@babel/helper-module-transforms@^7.28.6": +"@babel/helper-module-transforms@^7.27.1", "@babel/helper-module-transforms@^7.28.6": version "7.28.6" resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.28.6.tgz#9312d9d9e56edc35aeb6e95c25d4106b50b9eb1e" integrity sha512-67oXFAYr2cDLDVGLXTEABjdBJZ6drElUSI7WKp70NrpyISso3plG9SAGEF6y7zbha/wOzUByWWTJvEDVNIUGcA== @@ -364,12 +364,12 @@ js-tokens "^4.0.0" picocolors "^1.0.0" -"@babel/parser@^7.25.4", "@babel/parser@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.28.6.tgz#f01a8885b7fa1e56dd8a155130226cd698ef13fd" - integrity sha512-TeR9zWR18BvbfPmGbLampPMW+uW1NZnJlRuuHso8i87QZNq2JRF9i6RgxRqtEq+wQGsS19NNTWr2duhnE49mfQ== +"@babel/parser@^7.25.4", "@babel/parser@^7.28.6", "@babel/parser@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.29.0.tgz#669ef345add7d057e92b7ed15f0bac07611831b6" + integrity sha512-IyDgFV5GeDUVX4YdF/3CPULtVGSXXMLh1xVIgdCgxApktqnQV0r7/8Nqthg+8YLGaAtdyIlo2qIdZrbCv4+7ww== dependencies: - "@babel/types" "^7.28.6" + "@babel/types" "^7.29.0" "@babel/plugin-bugfix-firefox-class-in-computed-class-key@^7.28.5": version "7.28.5" @@ -465,14 +465,14 @@ dependencies: "@babel/helper-plugin-utils" "^7.27.1" -"@babel/plugin-transform-async-generator-functions@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.28.6.tgz#80cb86d3eaa2102e18ae90dd05ab87bdcad3877d" - integrity sha512-9knsChgsMzBV5Yh3kkhrZNxH3oCYAfMBkNNaVN4cP2RVlFPe8wYdwwcnOsAbkdDoV9UjFtOXWrWB52M8W4jNeA== +"@babel/plugin-transform-async-generator-functions@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.29.0.tgz#63ed829820298f0bf143d5a4a68fb8c06ffd742f" + integrity sha512-va0VdWro4zlBr2JsXC+ofCPB2iG12wPtVGTWFx2WLDOM3nYQZZIGP82qku2eW/JR83sD+k2k+CsNtyEbUqhU6w== dependencies: "@babel/helper-plugin-utils" "^7.28.6" "@babel/helper-remap-async-to-generator" "^7.27.1" - "@babel/traverse" "^7.28.6" + "@babel/traverse" "^7.29.0" "@babel/plugin-transform-async-to-generator@^7.28.6": version "7.28.6" @@ -556,10 +556,10 @@ dependencies: "@babel/helper-plugin-utils" "^7.27.1" -"@babel/plugin-transform-duplicate-named-capturing-groups-regex@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-named-capturing-groups-regex/-/plugin-transform-duplicate-named-capturing-groups-regex-7.28.6.tgz#e0c59ba54f1655dd682f2edf5f101b5910a8f6f3" - integrity sha512-5suVoXjC14lUN6ZL9OLKIHCNVWCrqGqlmEp/ixdXjvgnEl/kauLvvMO/Xw9NyMc95Joj1AeLVPVMvibBgSoFlA== +"@babel/plugin-transform-duplicate-named-capturing-groups-regex@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-named-capturing-groups-regex/-/plugin-transform-duplicate-named-capturing-groups-regex-7.29.0.tgz#8014b8a6cfd0e7b92762724443bf0d2400f26df1" + integrity sha512-zBPcW2lFGxdiD8PUnPwJjag2J9otbcLQzvbiOzDxpYXyCuYX9agOwMPGn1prVH0a4qzhCKu24rlH4c1f7yA8rw== dependencies: "@babel/helper-create-regexp-features-plugin" "^7.28.5" "@babel/helper-plugin-utils" "^7.28.6" @@ -654,15 +654,15 @@ "@babel/helper-module-transforms" "^7.28.6" "@babel/helper-plugin-utils" "^7.28.6" -"@babel/plugin-transform-modules-systemjs@^7.28.5": - version "7.28.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.28.5.tgz#7439e592a92d7670dfcb95d0cbc04bd3e64801d2" - integrity sha512-vn5Jma98LCOeBy/KpeQhXcV2WZgaRUtjwQmjoBuLNlOmkg0fB5pdvYVeWRYI69wWKwK2cD1QbMiUQnoujWvrew== +"@babel/plugin-transform-modules-systemjs@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.29.0.tgz#e458a95a17807c415924106a3ff188a3b8dee964" + integrity sha512-PrujnVFbOdUpw4UHiVwKvKRLMMic8+eC0CuNlxjsyZUiBjhFdPsewdXCkveh2KqBA9/waD0W1b4hXSOBQJezpQ== dependencies: - "@babel/helper-module-transforms" "^7.28.3" - "@babel/helper-plugin-utils" "^7.27.1" + "@babel/helper-module-transforms" "^7.28.6" + "@babel/helper-plugin-utils" "^7.28.6" "@babel/helper-validator-identifier" "^7.28.5" - "@babel/traverse" "^7.28.5" + "@babel/traverse" "^7.29.0" "@babel/plugin-transform-modules-umd@^7.27.1": version "7.27.1" @@ -672,13 +672,13 @@ "@babel/helper-module-transforms" "^7.27.1" "@babel/helper-plugin-utils" "^7.27.1" -"@babel/plugin-transform-named-capturing-groups-regex@^7.27.1": - version "7.27.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.27.1.tgz#f32b8f7818d8fc0cc46ee20a8ef75f071af976e1" - integrity sha512-SstR5JYy8ddZvD6MhV0tM/j16Qds4mIpJTOd1Yu9J9pJjH93bxHECF7pgtc28XvkzTD6Pxcm/0Z73Hvk7kb3Ng== +"@babel/plugin-transform-named-capturing-groups-regex@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.29.0.tgz#a26cd51e09c4718588fc4cce1c5d1c0152102d6a" + integrity sha512-1CZQA5KNAD6ZYQLPw7oi5ewtDNxH/2vuCh+6SmvgDfhumForvs8a1o9n0UrEoBD8HU4djO2yWngTQlXl1NDVEQ== dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.27.1" - "@babel/helper-plugin-utils" "^7.27.1" + "@babel/helper-create-regexp-features-plugin" "^7.28.5" + "@babel/helper-plugin-utils" "^7.28.6" "@babel/plugin-transform-new-target@^7.27.1": version "7.27.1" @@ -806,10 +806,10 @@ "@babel/helper-annotate-as-pure" "^7.27.1" "@babel/helper-plugin-utils" "^7.27.1" -"@babel/plugin-transform-regenerator@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.28.6.tgz#6ca2ed5b76cff87980f96eaacfc2ce833e8e7a1b" - integrity sha512-eZhoEZHYQLL5uc1gS5e9/oTknS0sSSAtd5TkKMUp3J+S/CaUjagc0kOUPsEbDmMeva0nC3WWl4SxVY6+OBuxfw== +"@babel/plugin-transform-regenerator@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.29.0.tgz#dec237cec1b93330876d6da9992c4abd42c9d18b" + integrity sha512-FijqlqMA7DmRdg/aINBSs04y8XNTYw/lr1gJ2WsmBnnaNw1iS43EPkJW+zK7z65auG3AWRFXWj+NcTQwYptUog== dependencies: "@babel/helper-plugin-utils" "^7.28.6" @@ -829,12 +829,12 @@ "@babel/helper-plugin-utils" "^7.27.1" "@babel/plugin-transform-runtime@^7.25.9": - version "7.28.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.28.5.tgz#ae3e21fbefe2831ebac04dfa6b463691696afe17" - integrity sha512-20NUVgOrinudkIBzQ2bNxP08YpKprUkRTiRSd2/Z5GOdPImJGkoN4Z7IQe1T5AdyKI1i5L6RBmluqdSzvaq9/w== + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.29.0.tgz#a5fded13cc656700804bfd6e5ebd7fffd5266803" + integrity sha512-jlaRT5dJtMaMCV6fAuLbsQMSwz/QkvaHOHOSXRitGGwSpR1blCY4KUKoyP2tYO8vJcqYe8cEj96cqSztv3uF9w== dependencies: - "@babel/helper-module-imports" "^7.27.1" - "@babel/helper-plugin-utils" "^7.27.1" + "@babel/helper-module-imports" "^7.28.6" + "@babel/helper-plugin-utils" "^7.28.6" babel-plugin-polyfill-corejs2 "^0.4.14" babel-plugin-polyfill-corejs3 "^0.13.0" babel-plugin-polyfill-regenerator "^0.6.5" @@ -919,11 +919,11 @@ "@babel/helper-plugin-utils" "^7.28.6" "@babel/preset-env@^7.20.2", "@babel/preset-env@^7.25.9": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.28.6.tgz#b4586bb59d8c61be6c58997f4912e7ea6bd17178" - integrity sha512-GaTI4nXDrs7l0qaJ6Rg06dtOXTBCG6TMDB44zbqofCIC4PqC7SEvmFFtpxzCDw9W5aJ7RKVshgXTLvLdBFV/qw== + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.29.0.tgz#c55db400c515a303662faaefd2d87e796efa08d0" + integrity sha512-fNEdfc0yi16lt6IZo2Qxk3knHVdfMYX33czNb4v8yWhemoBhibCpQK/uYHtSKIiO+p/zd3+8fYVXhQdOVV608w== dependencies: - "@babel/compat-data" "^7.28.6" + "@babel/compat-data" "^7.29.0" "@babel/helper-compilation-targets" "^7.28.6" "@babel/helper-plugin-utils" "^7.28.6" "@babel/helper-validator-option" "^7.27.1" @@ -937,7 +937,7 @@ "@babel/plugin-syntax-import-attributes" "^7.28.6" "@babel/plugin-syntax-unicode-sets-regex" "^7.18.6" "@babel/plugin-transform-arrow-functions" "^7.27.1" - "@babel/plugin-transform-async-generator-functions" "^7.28.6" + "@babel/plugin-transform-async-generator-functions" "^7.29.0" "@babel/plugin-transform-async-to-generator" "^7.28.6" "@babel/plugin-transform-block-scoped-functions" "^7.27.1" "@babel/plugin-transform-block-scoping" "^7.28.6" @@ -948,7 +948,7 @@ "@babel/plugin-transform-destructuring" "^7.28.5" "@babel/plugin-transform-dotall-regex" "^7.28.6" "@babel/plugin-transform-duplicate-keys" "^7.27.1" - "@babel/plugin-transform-duplicate-named-capturing-groups-regex" "^7.28.6" + "@babel/plugin-transform-duplicate-named-capturing-groups-regex" "^7.29.0" "@babel/plugin-transform-dynamic-import" "^7.27.1" "@babel/plugin-transform-explicit-resource-management" "^7.28.6" "@babel/plugin-transform-exponentiation-operator" "^7.28.6" @@ -961,9 +961,9 @@ "@babel/plugin-transform-member-expression-literals" "^7.27.1" "@babel/plugin-transform-modules-amd" "^7.27.1" "@babel/plugin-transform-modules-commonjs" "^7.28.6" - "@babel/plugin-transform-modules-systemjs" "^7.28.5" + "@babel/plugin-transform-modules-systemjs" "^7.29.0" "@babel/plugin-transform-modules-umd" "^7.27.1" - "@babel/plugin-transform-named-capturing-groups-regex" "^7.27.1" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.29.0" "@babel/plugin-transform-new-target" "^7.27.1" "@babel/plugin-transform-nullish-coalescing-operator" "^7.28.6" "@babel/plugin-transform-numeric-separator" "^7.28.6" @@ -975,7 +975,7 @@ "@babel/plugin-transform-private-methods" "^7.28.6" "@babel/plugin-transform-private-property-in-object" "^7.28.6" "@babel/plugin-transform-property-literals" "^7.27.1" - "@babel/plugin-transform-regenerator" "^7.28.6" + "@babel/plugin-transform-regenerator" "^7.29.0" "@babel/plugin-transform-regexp-modifiers" "^7.28.6" "@babel/plugin-transform-reserved-words" "^7.27.1" "@babel/plugin-transform-shorthand-properties" "^7.27.1" @@ -988,10 +988,10 @@ "@babel/plugin-transform-unicode-regex" "^7.27.1" "@babel/plugin-transform-unicode-sets-regex" "^7.28.6" "@babel/preset-modules" "0.1.6-no-external-plugins" - babel-plugin-polyfill-corejs2 "^0.4.14" - babel-plugin-polyfill-corejs3 "^0.13.0" - babel-plugin-polyfill-regenerator "^0.6.5" - core-js-compat "^3.43.0" + babel-plugin-polyfill-corejs2 "^0.4.15" + babel-plugin-polyfill-corejs3 "^0.14.0" + babel-plugin-polyfill-regenerator "^0.6.6" + core-js-compat "^3.48.0" semver "^6.3.1" "@babel/preset-modules@0.1.6-no-external-plugins": @@ -1027,11 +1027,11 @@ "@babel/plugin-transform-typescript" "^7.28.5" "@babel/runtime-corejs3@^7.25.9": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.28.6.tgz#f1e4a0da50f4856ceec1bb51c83f8ed0b202ed12" - integrity sha512-kz2fAQ5UzjV7X7D3ySxmj3vRq89dTpqOZWv76Z6pNPztkwb/0Yj1Mtx1xFrYj6mbIHysxtBot8J4o0JLCblcFw== + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.29.0.tgz#56cd28ec515364482afeb880b476936a702461b9" + integrity sha512-TgUkdp71C9pIbBcHudc+gXZnihEDOjUAmXO1VO4HHGES7QLZcShR0stfKIxLSNIYx2fqhmJChOjm/wkF8wv4gA== dependencies: - core-js-pure "^3.43.0" + core-js-pure "^3.48.0" "@babel/runtime@^7.1.2", "@babel/runtime@^7.10.1", "@babel/runtime@^7.10.3", "@babel/runtime@^7.12.0", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.13.10", "@babel/runtime@^7.14.8", "@babel/runtime@^7.18.3", "@babel/runtime@^7.25.9", "@babel/runtime@^7.5.5", "@babel/runtime@^7.8.7": version "7.28.6" @@ -1047,23 +1047,23 @@ "@babel/parser" "^7.28.6" "@babel/types" "^7.28.6" -"@babel/traverse@^7.25.9", "@babel/traverse@^7.27.1", "@babel/traverse@^7.28.5", "@babel/traverse@^7.28.6": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.28.6.tgz#871ddc79a80599a5030c53b1cc48cbe3a5583c2e" - integrity sha512-fgWX62k02qtjqdSNTAGxmKYY/7FSL9WAS1o2Hu5+I5m9T0yxZzr4cnrfXQ/MX0rIifthCSs6FKTlzYbJcPtMNg== +"@babel/traverse@^7.25.9", "@babel/traverse@^7.27.1", "@babel/traverse@^7.28.5", "@babel/traverse@^7.28.6", "@babel/traverse@^7.29.0": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.29.0.tgz#f323d05001440253eead3c9c858adbe00b90310a" + integrity sha512-4HPiQr0X7+waHfyXPZpWPfWL/J7dcN1mx9gL6WdQVMbPnF3+ZhSMs8tCxN7oHddJE9fhNE7+lxdnlyemKfJRuA== dependencies: - "@babel/code-frame" "^7.28.6" - "@babel/generator" "^7.28.6" + "@babel/code-frame" "^7.29.0" + "@babel/generator" "^7.29.0" "@babel/helper-globals" "^7.28.0" - "@babel/parser" "^7.28.6" + "@babel/parser" "^7.29.0" "@babel/template" "^7.28.6" - "@babel/types" "^7.28.6" + "@babel/types" "^7.29.0" debug "^4.3.1" -"@babel/types@^7.21.3", "@babel/types@^7.25.4", "@babel/types@^7.27.1", "@babel/types@^7.27.3", "@babel/types@^7.28.5", "@babel/types@^7.28.6", "@babel/types@^7.4.4": - version "7.28.6" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.28.6.tgz#c3e9377f1b155005bcc4c46020e7e394e13089df" - integrity sha512-0ZrskXVEHSWIqZM/sQZ4EV3jZJXRkio/WCxaqKZP1g//CEWEPSfeZFcms4XeKBCHU0ZKnIkdJeU/kF+eRp5lBg== +"@babel/types@^7.21.3", "@babel/types@^7.25.4", "@babel/types@^7.27.1", "@babel/types@^7.27.3", "@babel/types@^7.28.5", "@babel/types@^7.28.6", "@babel/types@^7.29.0", "@babel/types@^7.4.4": + version "7.29.0" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.29.0.tgz#9f5b1e838c446e72cf3cd4b918152b8c605e37c7" + integrity sha512-LwdZHpScM4Qz8Xw2iKSzS+cfglZzJGvofQICy7W7v4caru4EaAmyUuO6BGrbyQ2mYV11W0U8j5mBhd14dd3B0A== dependencies: "@babel/helper-string-parser" "^7.27.1" "@babel/helper-validator-identifier" "^7.28.5" @@ -1073,27 +1073,32 @@ resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39" integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== -"@better-auth/core@1.4.17": - version "1.4.17" - resolved "https://registry.yarnpkg.com/@better-auth/core/-/core-1.4.17.tgz#975fd8cb2029835f50958cde28154d8fa62dc367" - integrity sha512-WSaEQDdUO6B1CzAmissN6j0lx9fM9lcslEYzlApB5UzFaBeAOHNUONTdglSyUs6/idiZBoRvt0t/qMXCgIU8ug== +"@better-auth/core@1.4.18": + version "1.4.18" + resolved "https://registry.yarnpkg.com/@better-auth/core/-/core-1.4.18.tgz#d424ccbf2e7754b7a7581c841dd64811b2700dd4" + integrity sha512-q+awYgC7nkLEBdx2sW0iJjkzgSHlIxGnOpsN1r/O1+a4m7osJNHtfK2mKJSL1I+GfNyIlxJF8WvD/NLuYMpmcg== dependencies: "@standard-schema/spec" "^1.0.0" zod "^4.3.5" -"@better-auth/telemetry@1.4.17": - version "1.4.17" - resolved "https://registry.yarnpkg.com/@better-auth/telemetry/-/telemetry-1.4.17.tgz#1929f103807fb9010342cbcaf32e73a45a267830" - integrity sha512-R1BC4e/bNjQbXu7lG6ubpgmsPj7IMqky5DvMlzAtnAJWJhh99pMh/n6w5gOHa0cqDZgEAuj75IPTxv+q3YiInA== +"@better-auth/telemetry@1.4.18": + version "1.4.18" + resolved "https://registry.yarnpkg.com/@better-auth/telemetry/-/telemetry-1.4.18.tgz#9290df1b20c5376cb6820ae6704f682d7c676a4e" + integrity sha512-e5rDF8S4j3Um/0LIVATL2in9dL4lfO2fr2v1Wio4qTMRbfxqnUDTa+6SZtwdeJrbc4O+a3c+IyIpjG9Q/6GpfQ== dependencies: "@better-auth/utils" "0.3.0" "@better-fetch/fetch" "1.1.21" -"@better-auth/utils@0.3.0", "@better-auth/utils@^0.3.0": +"@better-auth/utils@0.3.0": version "0.3.0" resolved "https://registry.yarnpkg.com/@better-auth/utils/-/utils-0.3.0.tgz#066c5ce82bf393421547dd887b14a6899310003d" integrity sha512-W+Adw6ZA6mgvnSnhOki270rwJ42t4XzSK6YWGF//BbVXL6SwCLWfyzBc1lN2m/4RM28KubdBKQ4X5VMoLRNPQw== +"@better-auth/utils@^0.3.0": + version "0.3.1" + resolved "https://registry.yarnpkg.com/@better-auth/utils/-/utils-0.3.1.tgz#ffa4de03b9aef33df536fd19f36a24fa9c9942c0" + integrity sha512-+CGp4UmZSUrHHnpHhLPYu6cV+wSUSvVbZbNykxhUDocpVNTo9uFFxw/NqJlh1iC4wQ9HKKWGCKuZ5wUgS0v6Kg== + "@better-fetch/fetch@1.1.21", "@better-fetch/fetch@^1.1.4": version "1.1.21" resolved "https://registry.yarnpkg.com/@better-fetch/fetch/-/fetch-1.1.21.tgz#2b4990e73c46b0ae5e66b247083610ff8c37bddc" @@ -1110,9 +1115,9 @@ integrity sha512-s3jaWicZd0pkP0jf5ysyHUI/RE7MHos6qlToFcGWXVp+ykHOy77OUMrfbgJ9it2C5bow7OIQwYYaHjk9XlBQ2A== "@braintree/sanitize-url@^7.1.1": - version "7.1.1" - resolved "https://registry.yarnpkg.com/@braintree/sanitize-url/-/sanitize-url-7.1.1.tgz#15e19737d946559289b915e5dad3b4c28407735e" - integrity sha512-i1L7noDNxtFyL5DmZafWy1wRVhGehQmzZaz1HiN5e7iylJMSZR7ekOV7NsIqa5qBldlLrsKv4HbgFUVlQrz8Mw== + version "7.1.2" + resolved "https://registry.yarnpkg.com/@braintree/sanitize-url/-/sanitize-url-7.1.2.tgz#ca2035b0fefe956a8676ff0c69af73e605fcd81f" + integrity sha512-jigsZK+sMF/cuiB7sERuo9V7N9jx+dhmHHnQyDSVdpZwVutaBu7WvNYqMDLSgFgfB30n452TP3vjDAvFC973mA== "@chevrotain/cst-dts-gen@11.0.3": version "11.0.3" @@ -1450,9 +1455,9 @@ "@codemirror/language" "^6.0.0" "@codemirror/lint@^6.0.0": - version "6.9.2" - resolved "https://registry.yarnpkg.com/@codemirror/lint/-/lint-6.9.2.tgz#09ed0aedec13381c9e36e1ac5d126027740c3ef4" - integrity sha512-sv3DylBiIyi+xKwRCJAAsBZZZWo82shJ/RTMymLabAdtbkV5cSKwWDeCgtUq3v8flTaXS2y1kKkICuRYtUswyQ== + version "6.9.3" + resolved "https://registry.yarnpkg.com/@codemirror/lint/-/lint-6.9.3.tgz#eee48c9d60ea63582eee1ebd6b4ae65102eb8782" + integrity sha512-y3YkYhdnhjDBAe0VIA0c4wVoFOvnp8CnAvfLqi0TqotIv92wIlAAP7HELOpLBsKwjAX6W92rSflA6an/2zBvXw== dependencies: "@codemirror/state" "^6.0.0" "@codemirror/view" "^6.35.0" @@ -1486,9 +1491,9 @@ "@marijn/find-cluster-break" "^1.0.0" "@codemirror/view@^6.0.0", "@codemirror/view@^6.17.0", "@codemirror/view@^6.23.0", "@codemirror/view@^6.27.0", "@codemirror/view@^6.35.0", "@codemirror/view@^6.37.0", "@codemirror/view@^6.7.1": - version "6.39.11" - resolved "https://registry.yarnpkg.com/@codemirror/view/-/view-6.39.11.tgz#200aebef2074bfbbb7a3d5f0644c1b560d876b39" - integrity sha512-bWdeR8gWM87l4DB/kYSF9A+dVackzDb/V56Tq7QVrQ7rn86W0rgZFtlL3g3pem6AeGcb9NQNoy3ao4WpW4h5tQ== + version "6.39.12" + resolved "https://registry.yarnpkg.com/@codemirror/view/-/view-6.39.12.tgz#c61961d7107b44bd233647fc9e33d96309d627c9" + integrity sha512-f+/VsHVn/kOA9lltk/GFzuYwVVAKmOnNjxbrhkk3tPHntFqjWeI2TbIXx006YkBkqC10wZ4NsnWXCQiFPeAISQ== dependencies: "@codemirror/state" "^6.5.0" crelt "^1.0.6" @@ -2936,34 +2941,34 @@ lodash.isundefined "^3.0.1" lodash.uniq "^4.5.0" -"@floating-ui/core@^1.7.3": - version "1.7.3" - resolved "https://registry.yarnpkg.com/@floating-ui/core/-/core-1.7.3.tgz#462d722f001e23e46d86fd2bd0d21b7693ccb8b7" - integrity sha512-sGnvb5dmrJaKEZ+LDIpguvdX3bDlEllmv4/ClQ9awcmCZrlx5jQyyMWFM5kBI+EyNOCDDiKk8il0zeuX3Zlg/w== +"@floating-ui/core@^1.7.4": + version "1.7.4" + resolved "https://registry.yarnpkg.com/@floating-ui/core/-/core-1.7.4.tgz#4a006a6e01565c0f87ba222c317b056a2cffd2f4" + integrity sha512-C3HlIdsBxszvm5McXlB8PeOEWfBhcGBTZGkGlWc2U0KFY5IwG5OQEuQ8rq52DZmcHDlPLd+YFBK+cZcytwIFWg== dependencies: "@floating-ui/utils" "^0.2.10" -"@floating-ui/dom@^1.0.1", "@floating-ui/dom@^1.7.4": - version "1.7.4" - resolved "https://registry.yarnpkg.com/@floating-ui/dom/-/dom-1.7.4.tgz#ee667549998745c9c3e3e84683b909c31d6c9a77" - integrity sha512-OOchDgh4F2CchOX94cRVqhvy7b3AFb+/rQXyswmzmGakRfkMgoWVjfnLWkRirfLEfuD4ysVW16eXzwt3jHIzKA== +"@floating-ui/dom@^1.0.1", "@floating-ui/dom@^1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@floating-ui/dom/-/dom-1.7.5.tgz#60bfc83a4d1275b2a90db76bf42ca2a5f2c231c2" + integrity sha512-N0bD2kIPInNHUHehXhMke1rBGs1dwqvC9O9KYMyyjK7iXt7GAhnro7UlcuYcGdS/yYOlq0MAVgrow8IbWJwyqg== dependencies: - "@floating-ui/core" "^1.7.3" + "@floating-ui/core" "^1.7.4" "@floating-ui/utils" "^0.2.10" -"@floating-ui/react-dom@^2.0.0", "@floating-ui/react-dom@^2.1.6": - version "2.1.6" - resolved "https://registry.yarnpkg.com/@floating-ui/react-dom/-/react-dom-2.1.6.tgz#189f681043c1400561f62972f461b93f01bf2231" - integrity sha512-4JX6rEatQEvlmgU80wZyq9RT96HZJa88q8hp0pBd+LrczeDI4o6uA2M+uvxngVHo4Ihr8uibXxH6+70zhAFrVw== +"@floating-ui/react-dom@^2.0.0", "@floating-ui/react-dom@^2.1.7": + version "2.1.7" + resolved "https://registry.yarnpkg.com/@floating-ui/react-dom/-/react-dom-2.1.7.tgz#529475cc16ee4976ba3387968117e773d9aa703e" + integrity sha512-0tLRojf/1Go2JgEVm+3Frg9A3IW8bJgKgdO0BN5RkF//ufuz2joZM63Npau2ff3J6lUVYgDSNzNkR+aH3IVfjg== dependencies: - "@floating-ui/dom" "^1.7.4" + "@floating-ui/dom" "^1.7.5" "@floating-ui/react@^0.27.8": - version "0.27.16" - resolved "https://registry.yarnpkg.com/@floating-ui/react/-/react-0.27.16.tgz#6e485b5270b7a3296fdc4d0faf2ac9abf955a2f7" - integrity sha512-9O8N4SeG2z++TSM8QA/KTeKFBVCNEz/AGS7gWPJf6KFRzmRWixFRnCnkPHRDwSVZW6QPDO6uT0P2SpWNKCc9/g== + version "0.27.17" + resolved "https://registry.yarnpkg.com/@floating-ui/react/-/react-0.27.17.tgz#f1d74e01cf10016825a4167b3b0139a4d5af118a" + integrity sha512-LGVZKHwmWGg6MRHjLLgsfyaX2y2aCNgnD1zT/E6B+/h+vxg+nIJUqHPAlTzsHDyqdgEpJ1Np5kxWuFEErXzoGg== dependencies: - "@floating-ui/react-dom" "^2.1.6" + "@floating-ui/react-dom" "^2.1.7" "@floating-ui/utils" "^0.2.10" tabbable "^6.0.0" @@ -2985,9 +2990,9 @@ "@hapi/hoek" "^9.0.0" "@hpcc-js/wasm-graphviz@^1.7.0": - version "1.20.0" - resolved "https://registry.yarnpkg.com/@hpcc-js/wasm-graphviz/-/wasm-graphviz-1.20.0.tgz#26fcdc5742ef9331b81caa3c59df7a8c02bd2294" - integrity sha512-29nwKSkoKoXBHPqvimS2OmWUTojU148CFMszANgWvVOh76jbRFh1ZxXAiSzVWbtQcYFcb39T8tDEAXtUjyVlMA== + version "1.21.0" + resolved "https://registry.yarnpkg.com/@hpcc-js/wasm-graphviz/-/wasm-graphviz-1.21.0.tgz#1b7dd35aae704cf063a0b2089ea5b63efc5b798a" + integrity sha512-BQ06v/foSTxtwUyIdJYRz+S++/fHQuPVsFmX+pI3G66cANi1mQvsgToaN5deZ6ALEDUHsfHVMYlowNiimoET5g== "@iconify/types@^2.0.0": version "2.0.0" @@ -3457,9 +3462,9 @@ lexical "0.35.0" "@lezer/common@^1.0.0", "@lezer/common@^1.0.2", "@lezer/common@^1.1.0", "@lezer/common@^1.2.0", "@lezer/common@^1.2.1", "@lezer/common@^1.3.0", "@lezer/common@^1.5.0": - version "1.5.0" - resolved "https://registry.yarnpkg.com/@lezer/common/-/common-1.5.0.tgz#db227b596260189b67ba286387d9dc81fb07c70b" - integrity sha512-PNGcolp9hr4PJdXR4ix7XtixDrClScvtSCYW3rQG106oVMOOI+jFb+0+J3mbeL/53g1Zd6s0kJzaw6Ri68GmAA== + version "1.5.1" + resolved "https://registry.yarnpkg.com/@lezer/common/-/common-1.5.1.tgz#6e8c114ff5d36a41148e146a253734d3bb8807d3" + integrity sha512-6YRVG9vBkaY7p1IVxL4s44n5nUnaNnGM2/AckNgYOnxTG2kWh1vR8BMxPseWPjRNpb5VtXnMpeYAEAADoRV1Iw== "@lezer/cpp@^1.0.0": version "1.1.5" @@ -3532,9 +3537,9 @@ "@lezer/lr" "^1.0.0" "@lezer/lr@^1.0.0", "@lezer/lr@^1.1.0", "@lezer/lr@^1.3.0", "@lezer/lr@^1.3.1", "@lezer/lr@^1.3.3", "@lezer/lr@^1.4.0": - version "1.4.7" - resolved "https://registry.yarnpkg.com/@lezer/lr/-/lr-1.4.7.tgz#01a38556652bf73ffbf3af4a88b91e4c056cc6ee" - integrity sha512-wNIFWdSUfX9Jc6ePMzxSPVgTVB4EOfDIwLQLWASyiUdHKaMsiilj9bYiGkGQCKVodd0x6bgQCV207PILGFCF9Q== + version "1.4.8" + resolved "https://registry.yarnpkg.com/@lezer/lr/-/lr-1.4.8.tgz#333de9bc9346057323ff09beb4cda47ccc38a498" + integrity sha512-bPWa0Pgx69ylNlMlPvBPryqeLYQjyJjqPx+Aupm5zydLIF3NE+6MMLT8Yi23Bd9cif9VS00aUebn+6fDIGBcDA== dependencies: "@lezer/common" "^1.0.0" @@ -3592,9 +3597,9 @@ "@lezer/lr" "^1.0.0" "@lezer/yaml@^1.0.0": - version "1.0.3" - resolved "https://registry.yarnpkg.com/@lezer/yaml/-/yaml-1.0.3.tgz#b23770ab42b390056da6b187d861b998fd60b1ff" - integrity sha512-GuBLekbw9jDBDhGur82nuwkxKQ+a3W5H0GfaAthDXcAu+XdpS43VlnxA9E9hllkpSP5ellRDKjLLj7Lu9Wr6xA== + version "1.0.4" + resolved "https://registry.yarnpkg.com/@lezer/yaml/-/yaml-1.0.4.tgz#66a622188f1984a71d34506759b5807699043589" + integrity sha512-2lrrHqxalACEbxIbsjhqGpSW8kWpUKuY6RHgnSAFZa6qK62wvnPxA8hGOwOoDbwHcOFs5M4o27mjGu+P7TvBmw== dependencies: "@lezer/common" "^1.2.0" "@lezer/highlight" "^1.0.0" @@ -3737,48 +3742,48 @@ dependencies: langium "3.3.1" -"@module-federation/error-codes@0.21.4": - version "0.21.4" - resolved "https://registry.yarnpkg.com/@module-federation/error-codes/-/error-codes-0.21.4.tgz#037c15c641e67c2c5465d2d3f442724395691f55" - integrity sha512-ClpL5MereWNXh+EgDjz7w4RrC1JlisQTvXDa1gLxpviHafzNDfdViVmuhi9xXVuj+EYo8KU70Y999KHhk9424Q== +"@module-federation/error-codes@0.22.0": + version "0.22.0" + resolved "https://registry.yarnpkg.com/@module-federation/error-codes/-/error-codes-0.22.0.tgz#31ccc990dc240d73912ba7bd001f7e35ac751992" + integrity sha512-xF9SjnEy7vTdx+xekjPCV5cIHOGCkdn3pIxo9vU7gEZMIw0SvAEdsy6Uh17xaCpm8V0FWvR0SZoK9Ik6jGOaug== -"@module-federation/runtime-core@0.21.4": - version "0.21.4" - resolved "https://registry.yarnpkg.com/@module-federation/runtime-core/-/runtime-core-0.21.4.tgz#3254ee1be28255f9b115fe02d462672ae0f66584" - integrity sha512-SGpmoOLGNxZofpTOk6Lxb2ewaoz5wMi93AFYuuJB04HTVcngEK+baNeUZ2D/xewrqNIJoMY6f5maUjVfIIBPUA== +"@module-federation/runtime-core@0.22.0": + version "0.22.0" + resolved "https://registry.yarnpkg.com/@module-federation/runtime-core/-/runtime-core-0.22.0.tgz#7321ec792bb7d1d22bee6162ec43564b769d2a3c" + integrity sha512-GR1TcD6/s7zqItfhC87zAp30PqzvceoeDGYTgF3Vx2TXvsfDrhP6Qw9T4vudDQL3uJRne6t7CzdT29YyVxlgIA== dependencies: - "@module-federation/error-codes" "0.21.4" - "@module-federation/sdk" "0.21.4" + "@module-federation/error-codes" "0.22.0" + "@module-federation/sdk" "0.22.0" -"@module-federation/runtime-tools@0.21.4": - version "0.21.4" - resolved "https://registry.yarnpkg.com/@module-federation/runtime-tools/-/runtime-tools-0.21.4.tgz#dbaf6d0a21ee72fc343f0d9dc50eeabb5fd9f5ba" - integrity sha512-RzFKaL0DIjSmkn76KZRfzfB6dD07cvID84950jlNQgdyoQFUGkqD80L6rIpVCJTY/R7LzR3aQjHnoqmq4JPo3w== +"@module-federation/runtime-tools@0.22.0": + version "0.22.0" + resolved "https://registry.yarnpkg.com/@module-federation/runtime-tools/-/runtime-tools-0.22.0.tgz#36f2a7cb267af208a9d1a237fe9a71b4bf31431e" + integrity sha512-4ScUJ/aUfEernb+4PbLdhM/c60VHl698Gn1gY21m9vyC1Ucn69fPCA1y2EwcCB7IItseRMoNhdcWQnzt/OPCNA== dependencies: - "@module-federation/runtime" "0.21.4" - "@module-federation/webpack-bundler-runtime" "0.21.4" + "@module-federation/runtime" "0.22.0" + "@module-federation/webpack-bundler-runtime" "0.22.0" -"@module-federation/runtime@0.21.4": - version "0.21.4" - resolved "https://registry.yarnpkg.com/@module-federation/runtime/-/runtime-0.21.4.tgz#f07cc2dd9786b26d3af5440793693b953a818b97" - integrity sha512-wgvGqryurVEvkicufJmTG0ZehynCeNLklv8kIk5BLIsWYSddZAE+xe4xov1kgH5fIJQAoQNkRauFFjVNlHoAkA== +"@module-federation/runtime@0.22.0": + version "0.22.0" + resolved "https://registry.yarnpkg.com/@module-federation/runtime/-/runtime-0.22.0.tgz#f789c9ef40d846d110711c8221ecc0ad938d43d8" + integrity sha512-38g5iPju2tPC3KHMPxRKmy4k4onNp6ypFPS1eKGsNLUkXgHsPMBFqAjDw96iEcjri91BrahG4XcdyKi97xZzlA== dependencies: - "@module-federation/error-codes" "0.21.4" - "@module-federation/runtime-core" "0.21.4" - "@module-federation/sdk" "0.21.4" + "@module-federation/error-codes" "0.22.0" + "@module-federation/runtime-core" "0.22.0" + "@module-federation/sdk" "0.22.0" -"@module-federation/sdk@0.21.4": - version "0.21.4" - resolved "https://registry.yarnpkg.com/@module-federation/sdk/-/sdk-0.21.4.tgz#4b4757b527d9a2758d01c5aadec7963348f43385" - integrity sha512-tzvhOh/oAfX++6zCDDxuvioHY4Jurf8vcfoCbKFxusjmyKr32GPbwFDazUP+OPhYCc3dvaa9oWU6X/qpUBLfJw== +"@module-federation/sdk@0.22.0": + version "0.22.0" + resolved "https://registry.yarnpkg.com/@module-federation/sdk/-/sdk-0.22.0.tgz#6ad4c1de85a900c3c80ff26cb87cce253e3a2770" + integrity sha512-x4aFNBKn2KVQRuNVC5A7SnrSCSqyfIWmm1DvubjbO9iKFe7ith5niw8dqSFBekYBg2Fwy+eMg4sEFNVvCAdo6g== -"@module-federation/webpack-bundler-runtime@0.21.4": - version "0.21.4" - resolved "https://registry.yarnpkg.com/@module-federation/webpack-bundler-runtime/-/webpack-bundler-runtime-0.21.4.tgz#d8651c5bb8e7bc999300f32f0e11358a6acd0501" - integrity sha512-dusmR3uPnQh9u9ChQo3M+GLOuGFthfvnh7WitF/a1eoeTfRmXqnMFsXtZCUK+f/uXf+64874Zj/bhAgbBcVHZA== +"@module-federation/webpack-bundler-runtime@0.22.0": + version "0.22.0" + resolved "https://registry.yarnpkg.com/@module-federation/webpack-bundler-runtime/-/webpack-bundler-runtime-0.22.0.tgz#dcbe8f972d722fe278e6a7c21988d4bee53d401d" + integrity sha512-aM8gCqXu+/4wBmJtVeMeeMN5guw3chf+2i6HajKtQv7SJfxV/f4IyNQJUeUQu9HfiAZHjqtMV5Lvq/Lvh8LdyA== dependencies: - "@module-federation/runtime" "0.21.4" - "@module-federation/sdk" "0.21.4" + "@module-federation/runtime" "0.22.0" + "@module-federation/sdk" "0.22.0" "@napi-rs/wasm-runtime@1.0.7": version "1.0.7" @@ -4817,130 +4822,130 @@ resolved "https://registry.yarnpkg.com/@react-hook/passive-layout-effect/-/passive-layout-effect-1.2.1.tgz#c06dac2d011f36d61259aa1c6df4f0d5e28bc55e" integrity sha512-IwEphTD75liO8g+6taS+4oqz+nnroocNfWVHWz7j+N+ZO2vYrc6PV1q7GQhuahL0IOR7JccFTsFKQ/mb6iZWAg== -"@rollup/rollup-android-arm-eabi@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.56.0.tgz#067cfcd81f1c1bfd92aefe3ad5ef1523549d5052" - integrity sha512-LNKIPA5k8PF1+jAFomGe3qN3bbIgJe/IlpDBwuVjrDKrJhVWywgnJvflMt/zkbVNLFtF1+94SljYQS6e99klnw== - -"@rollup/rollup-android-arm64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.56.0.tgz#85e39a44034d7d4e4fee2a1616f0bddb85a80517" - integrity sha512-lfbVUbelYqXlYiU/HApNMJzT1E87UPGvzveGg2h0ktUNlOCxKlWuJ9jtfvs1sKHdwU4fzY7Pl8sAl49/XaEk6Q== - -"@rollup/rollup-darwin-arm64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.56.0.tgz#17d92fe98f2cc277b91101eb1528b7c0b6c00c54" - integrity sha512-EgxD1ocWfhoD6xSOeEEwyE7tDvwTgZc8Bss7wCWe+uc7wO8G34HHCUH+Q6cHqJubxIAnQzAsyUsClt0yFLu06w== - -"@rollup/rollup-darwin-x64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.56.0.tgz#89ae6c66b1451609bd1f297da9384463f628437d" - integrity sha512-1vXe1vcMOssb/hOF8iv52A7feWW2xnu+c8BV4t1F//m9QVLTfNVpEdja5ia762j/UEJe2Z1jAmEqZAK42tVW3g== - -"@rollup/rollup-freebsd-arm64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.56.0.tgz#cdbdb9947b26e76c188a31238c10639347413628" - integrity sha512-bof7fbIlvqsyv/DtaXSck4VYQ9lPtoWNFCB/JY4snlFuJREXfZnm+Ej6yaCHfQvofJDXLDMTVxWscVSuQvVWUQ== - -"@rollup/rollup-freebsd-x64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.56.0.tgz#9b1458d07b6e040be16ee36d308a2c9520f7f7cc" - integrity sha512-KNa6lYHloW+7lTEkYGa37fpvPq+NKG/EHKM8+G/g9WDU7ls4sMqbVRV78J6LdNuVaeeK5WB9/9VAFbKxcbXKYg== - -"@rollup/rollup-linux-arm-gnueabihf@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.56.0.tgz#1d50ded7c965d5f125f5832c971ad5b287befef7" - integrity sha512-E8jKK87uOvLrrLN28jnAAAChNq5LeCd2mGgZF+fGF5D507WlG/Noct3lP/QzQ6MrqJ5BCKNwI9ipADB6jyiq2A== - -"@rollup/rollup-linux-arm-musleabihf@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.56.0.tgz#53597e319b7e65990d3bc2a5048097384814c179" - integrity sha512-jQosa5FMYF5Z6prEpTCCmzCXz6eKr/tCBssSmQGEeozA9tkRUty/5Vx06ibaOP9RCrW1Pvb8yp3gvZhHwTDsJw== - -"@rollup/rollup-linux-arm64-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.56.0.tgz#597002909dec198ca4bdccb25f043d32db3d6283" - integrity sha512-uQVoKkrC1KGEV6udrdVahASIsaF8h7iLG0U0W+Xn14ucFwi6uS539PsAr24IEF9/FoDtzMeeJXJIBo5RkbNWvQ== - -"@rollup/rollup-linux-arm64-musl@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.56.0.tgz#286f0e0f799545ce288bdc5a7c777261fcba3d54" - integrity sha512-vLZ1yJKLxhQLFKTs42RwTwa6zkGln+bnXc8ueFGMYmBTLfNu58sl5/eXyxRa2RarTkJbXl8TKPgfS6V5ijNqEA== - -"@rollup/rollup-linux-loong64-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-loong64-gnu/-/rollup-linux-loong64-gnu-4.56.0.tgz#1fab07fa1a4f8d3697735b996517f1bae0ba101b" - integrity sha512-FWfHOCub564kSE3xJQLLIC/hbKqHSVxy8vY75/YHHzWvbJL7aYJkdgwD/xGfUlL5UV2SB7otapLrcCj2xnF1dg== - -"@rollup/rollup-linux-loong64-musl@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-loong64-musl/-/rollup-linux-loong64-musl-4.56.0.tgz#efc2cb143d6c067f95205482afb177f78ed9ea3d" - integrity sha512-z1EkujxIh7nbrKL1lmIpqFTc/sr0u8Uk0zK/qIEFldbt6EDKWFk/pxFq3gYj4Bjn3aa9eEhYRlL3H8ZbPT1xvA== - -"@rollup/rollup-linux-ppc64-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.56.0.tgz#e8de8bd3463f96b92b7dfb7f151fd80ffe8a937c" - integrity sha512-iNFTluqgdoQC7AIE8Q34R3AuPrJGJirj5wMUErxj22deOcY7XwZRaqYmB6ZKFHoVGqRcRd0mqO+845jAibKCkw== - -"@rollup/rollup-linux-ppc64-musl@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-ppc64-musl/-/rollup-linux-ppc64-musl-4.56.0.tgz#8c508fe28a239da83b3a9da75bcf093186e064b4" - integrity sha512-MtMeFVlD2LIKjp2sE2xM2slq3Zxf9zwVuw0jemsxvh1QOpHSsSzfNOTH9uYW9i1MXFxUSMmLpeVeUzoNOKBaWg== - -"@rollup/rollup-linux-riscv64-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.56.0.tgz#ff6d51976e0830732880770a9e18553136b8d92b" - integrity sha512-in+v6wiHdzzVhYKXIk5U74dEZHdKN9KH0Q4ANHOTvyXPG41bajYRsy7a8TPKbYPl34hU7PP7hMVHRvv/5aCSew== - -"@rollup/rollup-linux-riscv64-musl@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.56.0.tgz#325fb35eefc7e81d75478318f0deee1e4a111493" - integrity sha512-yni2raKHB8m9NQpI9fPVwN754mn6dHQSbDTwxdr9SE0ks38DTjLMMBjrwvB5+mXrX+C0npX0CVeCUcvvvD8CNQ== - -"@rollup/rollup-linux-s390x-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.56.0.tgz#37410fabb5d3ba4ad34abcfbe9ba9b6288413f30" - integrity sha512-zhLLJx9nQPu7wezbxt2ut+CI4YlXi68ndEve16tPc/iwoylWS9B3FxpLS2PkmfYgDQtosah07Mj9E0khc3Y+vQ== - -"@rollup/rollup-linux-x64-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.56.0.tgz#8ef907a53b2042068fc03fcc6a641e2b02276eca" - integrity sha512-MVC6UDp16ZSH7x4rtuJPAEoE1RwS8N4oK9DLHy3FTEdFoUTCFVzMfJl/BVJ330C+hx8FfprA5Wqx4FhZXkj2Kw== - -"@rollup/rollup-linux-x64-musl@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.56.0.tgz#61b9ba09ea219e0174b3f35a6ad2afc94bdd5662" - integrity sha512-ZhGH1eA4Qv0lxaV00azCIS1ChedK0V32952Md3FtnxSqZTBTd6tgil4nZT5cU8B+SIw3PFYkvyR4FKo2oyZIHA== - -"@rollup/rollup-openbsd-x64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-openbsd-x64/-/rollup-openbsd-x64-4.56.0.tgz#fc4e54133134c1787d0b016ffdd5aeb22a5effd3" - integrity sha512-O16XcmyDeFI9879pEcmtWvD/2nyxR9mF7Gs44lf1vGGx8Vg2DRNx11aVXBEqOQhWb92WN4z7fW/q4+2NYzCbBA== - -"@rollup/rollup-openharmony-arm64@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.56.0.tgz#959ae225b1eeea0cc5b7c9f88e4834330fb6cd09" - integrity sha512-LhN/Reh+7F3RCgQIRbgw8ZMwUwyqJM+8pXNT6IIJAqm2IdKkzpCh/V9EdgOMBKuebIrzswqy4ATlrDgiOwbRcQ== - -"@rollup/rollup-win32-arm64-msvc@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.56.0.tgz#842acd38869fa1cbdbc240c76c67a86f93444c27" - integrity sha512-kbFsOObXp3LBULg1d3JIUQMa9Kv4UitDmpS+k0tinPBz3watcUiV2/LUDMMucA6pZO3WGE27P7DsfaN54l9ing== - -"@rollup/rollup-win32-ia32-msvc@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.56.0.tgz#7ab654def4042df44cb29f8ed9d5044e850c66d5" - integrity sha512-vSSgny54D6P4vf2izbtFm/TcWYedw7f8eBrOiGGecyHyQB9q4Kqentjaj8hToe+995nob/Wv48pDqL5a62EWtg== - -"@rollup/rollup-win32-x64-gnu@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-gnu/-/rollup-win32-x64-gnu-4.56.0.tgz#7426cdec1b01d2382ffd5cda83cbdd1c8efb3ca6" - integrity sha512-FeCnkPCTHQJFbiGG49KjV5YGW/8b9rrXAM2Mz2kiIoktq2qsJxRD5giEMEOD2lPdgs72upzefaUvS+nc8E3UzQ== - -"@rollup/rollup-win32-x64-msvc@4.56.0": - version "4.56.0" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.56.0.tgz#9eec0212732a432c71bde0350bc40b673d15b2db" - integrity sha512-H8AE9Ur/t0+1VXujj90w0HrSOuv0Nq9r1vSZF2t5km20NTfosQsGGUXDaKdQZzwuLts7IyL1fYT4hM95TI9c4g== +"@rollup/rollup-android-arm-eabi@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.57.1.tgz#add5e608d4e7be55bc3ca3d962490b8b1890e088" + integrity sha512-A6ehUVSiSaaliTxai040ZpZ2zTevHYbvu/lDoeAteHI8QnaosIzm4qwtezfRg1jOYaUmnzLX1AOD6Z+UJjtifg== + +"@rollup/rollup-android-arm64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.57.1.tgz#10bd0382b73592beee6e9800a69401a29da625c4" + integrity sha512-dQaAddCY9YgkFHZcFNS/606Exo8vcLHwArFZ7vxXq4rigo2bb494/xKMMwRRQW6ug7Js6yXmBZhSBRuBvCCQ3w== + +"@rollup/rollup-darwin-arm64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.57.1.tgz#1e99ab04c0b8c619dd7bbde725ba2b87b55bfd81" + integrity sha512-crNPrwJOrRxagUYeMn/DZwqN88SDmwaJ8Cvi/TN1HnWBU7GwknckyosC2gd0IqYRsHDEnXf328o9/HC6OkPgOg== + +"@rollup/rollup-darwin-x64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.57.1.tgz#69e741aeb2839d2e8f0da2ce7a33d8bd23632423" + integrity sha512-Ji8g8ChVbKrhFtig5QBV7iMaJrGtpHelkB3lsaKzadFBe58gmjfGXAOfI5FV0lYMH8wiqsxKQ1C9B0YTRXVy4w== + +"@rollup/rollup-freebsd-arm64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.57.1.tgz#3736c232a999c7bef7131355d83ebdf9651a0839" + integrity sha512-R+/WwhsjmwodAcz65guCGFRkMb4gKWTcIeLy60JJQbXrJ97BOXHxnkPFrP+YwFlaS0m+uWJTstrUA9o+UchFug== + +"@rollup/rollup-freebsd-x64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.57.1.tgz#227dcb8f466684070169942bd3998901c9bfc065" + integrity sha512-IEQTCHeiTOnAUC3IDQdzRAGj3jOAYNr9kBguI7MQAAZK3caezRrg0GxAb6Hchg4lxdZEI5Oq3iov/w/hnFWY9Q== + +"@rollup/rollup-linux-arm-gnueabihf@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.57.1.tgz#ba004b30df31b724f99ce66e7128248bea17cb0c" + integrity sha512-F8sWbhZ7tyuEfsmOxwc2giKDQzN3+kuBLPwwZGyVkLlKGdV1nvnNwYD0fKQ8+XS6hp9nY7B+ZeK01EBUE7aHaw== + +"@rollup/rollup-linux-arm-musleabihf@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.57.1.tgz#6929f3e07be6b6da5991f63c6b68b3e473d0a65a" + integrity sha512-rGfNUfn0GIeXtBP1wL5MnzSj98+PZe/AXaGBCRmT0ts80lU5CATYGxXukeTX39XBKsxzFpEeK+Mrp9faXOlmrw== + +"@rollup/rollup-linux-arm64-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.57.1.tgz#06e89fd4a25d21fe5575d60b6f913c0e65297bfa" + integrity sha512-MMtej3YHWeg/0klK2Qodf3yrNzz6CGjo2UntLvk2RSPlhzgLvYEB3frRvbEF2wRKh1Z2fDIg9KRPe1fawv7C+g== + +"@rollup/rollup-linux-arm64-musl@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.57.1.tgz#fddabf395b90990d5194038e6cd8c00156ed8ac0" + integrity sha512-1a/qhaaOXhqXGpMFMET9VqwZakkljWHLmZOX48R0I/YLbhdxr1m4gtG1Hq7++VhVUmf+L3sTAf9op4JlhQ5u1Q== + +"@rollup/rollup-linux-loong64-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-loong64-gnu/-/rollup-linux-loong64-gnu-4.57.1.tgz#04c10bb764bbf09a3c1bd90432e92f58d6603c36" + integrity sha512-QWO6RQTZ/cqYtJMtxhkRkidoNGXc7ERPbZN7dVW5SdURuLeVU7lwKMpo18XdcmpWYd0qsP1bwKPf7DNSUinhvA== + +"@rollup/rollup-linux-loong64-musl@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-loong64-musl/-/rollup-linux-loong64-musl-4.57.1.tgz#f2450361790de80581d8687ea19142d8a4de5c0f" + integrity sha512-xpObYIf+8gprgWaPP32xiN5RVTi/s5FCR+XMXSKmhfoJjrpRAjCuuqQXyxUa/eJTdAE6eJ+KDKaoEqjZQxh3Gw== + +"@rollup/rollup-linux-ppc64-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.57.1.tgz#0474f4667259e407eee1a6d38e29041b708f6a30" + integrity sha512-4BrCgrpZo4hvzMDKRqEaW1zeecScDCR+2nZ86ATLhAoJ5FQ+lbHVD3ttKe74/c7tNT9c6F2viwB3ufwp01Oh2w== + +"@rollup/rollup-linux-ppc64-musl@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-ppc64-musl/-/rollup-linux-ppc64-musl-4.57.1.tgz#9f32074819eeb1ddbe51f50ea9dcd61a6745ec33" + integrity sha512-NOlUuzesGauESAyEYFSe3QTUguL+lvrN1HtwEEsU2rOwdUDeTMJdO5dUYl/2hKf9jWydJrO9OL/XSSf65R5+Xw== + +"@rollup/rollup-linux-riscv64-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.57.1.tgz#3fdb9d4b1e29fb6b6a6da9f15654d42eb77b99b2" + integrity sha512-ptA88htVp0AwUUqhVghwDIKlvJMD/fmL/wrQj99PRHFRAG6Z5nbWoWG4o81Nt9FT+IuqUQi+L31ZKAFeJ5Is+A== + +"@rollup/rollup-linux-riscv64-musl@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.57.1.tgz#1de780d64e6be0e3e8762035c22e0d8ea68df8ed" + integrity sha512-S51t7aMMTNdmAMPpBg7OOsTdn4tySRQvklmL3RpDRyknk87+Sp3xaumlatU+ppQ+5raY7sSTcC2beGgvhENfuw== + +"@rollup/rollup-linux-s390x-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.57.1.tgz#1da022ffd2d9e9f0fd8344ea49e113001fbcac64" + integrity sha512-Bl00OFnVFkL82FHbEqy3k5CUCKH6OEJL54KCyx2oqsmZnFTR8IoNqBF+mjQVcRCT5sB6yOvK8A37LNm/kPJiZg== + +"@rollup/rollup-linux-x64-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.57.1.tgz#78c16eef9520bd10e1ea7a112593bb58e2842622" + integrity sha512-ABca4ceT4N+Tv/GtotnWAeXZUZuM/9AQyCyKYyKnpk4yoA7QIAuBt6Hkgpw8kActYlew2mvckXkvx0FfoInnLg== + +"@rollup/rollup-linux-x64-musl@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.57.1.tgz#a7598591b4d9af96cb3167b50a5bf1e02dfea06c" + integrity sha512-HFps0JeGtuOR2convgRRkHCekD7j+gdAuXM+/i6kGzQtFhlCtQkpwtNzkNj6QhCDp7DRJ7+qC/1Vg2jt5iSOFw== + +"@rollup/rollup-openbsd-x64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-openbsd-x64/-/rollup-openbsd-x64-4.57.1.tgz#c51d48c07cd6c466560e5bed934aec688ce02614" + integrity sha512-H+hXEv9gdVQuDTgnqD+SQffoWoc0Of59AStSzTEj/feWTBAnSfSD3+Dql1ZruJQxmykT/JVY0dE8Ka7z0DH1hw== + +"@rollup/rollup-openharmony-arm64@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.57.1.tgz#f09921d0b2a0b60afbf3586d2a7a7f208ba6df17" + integrity sha512-4wYoDpNg6o/oPximyc/NG+mYUejZrCU2q+2w6YZqrAs2UcNUChIZXjtafAiiZSUc7On8v5NyNj34Kzj/Ltk6dQ== + +"@rollup/rollup-win32-arm64-msvc@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.57.1.tgz#08d491717135376e4a99529821c94ecd433d5b36" + integrity sha512-O54mtsV/6LW3P8qdTcamQmuC990HDfR71lo44oZMZlXU4tzLrbvTii87Ni9opq60ds0YzuAlEr/GNwuNluZyMQ== + +"@rollup/rollup-win32-ia32-msvc@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.57.1.tgz#b0c12aac1104a8b8f26a5e0098e5facbb3e3964a" + integrity sha512-P3dLS+IerxCT/7D2q2FYcRdWRl22dNbrbBEtxdWhXrfIMPP9lQhb5h4Du04mdl5Woq05jVCDPCMF7Ub0NAjIew== + +"@rollup/rollup-win32-x64-gnu@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-gnu/-/rollup-win32-x64-gnu-4.57.1.tgz#b9cccef26f5e6fdc013bf3c0911a3c77428509d0" + integrity sha512-VMBH2eOOaKGtIJYleXsi2B8CPVADrh+TyNxJ4mWPnKfLB/DBUmzW+5m1xUrcwWoMfSLagIRpjUFeW5CO5hyciQ== + +"@rollup/rollup-win32-x64-msvc@4.57.1": + version "4.57.1" + resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.57.1.tgz#a03348e7b559c792b6277cc58874b89ef46e1e72" + integrity sha512-mxRFDdHIWRxg3UfIIAwCm6NzvxG0jDX/wBN6KsQFTvKFqqg9vTrWUE68qEjHt19A5wwx5X5aUi2zuZT7YR0jrA== "@rsdoctor/client@0.4.13": version "0.4.13" @@ -5057,81 +5062,81 @@ fs-extra "^11.1.1" lodash "^4.17.21" -"@rspack/binding-darwin-arm64@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-darwin-arm64/-/binding-darwin-arm64-1.6.5.tgz#c038886401ec0ef3128e3b4a9ddb7efee063c469" - integrity sha512-DaAJTlaenqZIqFqIYcitn0SzjJ7WpC9234JpiSDZdRyXii9qJJiToVwxSPY/CmkrP0201+aC4pzN4tI9T0Ummw== - -"@rspack/binding-darwin-x64@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-darwin-x64/-/binding-darwin-x64-1.6.5.tgz#a1527e656ac9cdace2f42bbec40a70d266e40d27" - integrity sha512-fPVfp7W/GMbHayb5hbefiMI30JxlsqPexOItHGtufHmTCrNne1aHmApspyUZIUUxG36oDRHuGPnfh+IQbHR6+g== - -"@rspack/binding-linux-arm64-gnu@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-1.6.5.tgz#c0fb16502861ec85d8faac5a9a44e5e738d294a9" - integrity sha512-K68YDoV2e4s+nlrKZxgF0HehiiRwOAGgZFUwJNRMZ7MUrTGMNlPTJlM+bNdaCjDb6GFxBVFcNwIa1sU+0tF1zg== - -"@rspack/binding-linux-arm64-musl@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-linux-arm64-musl/-/binding-linux-arm64-musl-1.6.5.tgz#3d0104855c63be4092e39c523f008c94533411f9" - integrity sha512-JPtxFBOq7RRmBIwpdGIStf8iyCILehDsjQtEB0Kkhtm7TsAkVGwtC41GLcNuPxcQBKqNDmD8cy3yLYhXadH2CQ== - -"@rspack/binding-linux-x64-gnu@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-linux-x64-gnu/-/binding-linux-x64-gnu-1.6.5.tgz#635f6fb87d3aa79dbe356a3fb33f6e046e7e25ed" - integrity sha512-oh4ZNo2HtizZ/E6UK3BEONu20h8VVBw9GAXuWmo1u22cJSihzg+WfRNCMjRDil82LqSsyAgBwnU+dEjEYGKyAA== - -"@rspack/binding-linux-x64-musl@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-linux-x64-musl/-/binding-linux-x64-musl-1.6.5.tgz#fa085de6b6446866f151944c8082b23dbcf178c8" - integrity sha512-8Xebp5bvPJqjifpkFEAX5nUvoU2JvbMU3gwAkEovRRuvooCXnVT2tqkUBjkR3AhivAGgAxAr9hRzUUz/6QWt3Q== - -"@rspack/binding-wasm32-wasi@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-wasm32-wasi/-/binding-wasm32-wasi-1.6.5.tgz#501ce81b09de2720c725fc87c3a87edfa0e370ad" - integrity sha512-oINZNqzTxM+9dSUOjAORodHXYoJYzXvpaHI2U6ecEmoWaBCs+x3V3Po8DhpNFBwotB+jGlcoVhEHjpg5uaO6pw== +"@rspack/binding-darwin-arm64@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-darwin-arm64/-/binding-darwin-arm64-1.7.5.tgz#5adad9b17d4a29c62d239bfac653b71e7d755b61" + integrity sha512-dg2/IrF+g498NUt654N8LFWfIiUsHlTankWieE1S3GWEQM6jweeRbNuu1Py1nWIUsjR2yQtv7ziia7c9Q8UTaQ== + +"@rspack/binding-darwin-x64@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-darwin-x64/-/binding-darwin-x64-1.7.5.tgz#bfa31b9bdcea5238babf0914289ad4227a4eabdb" + integrity sha512-RQJX4boQJUu3lo1yiN344+y8W6iSO08ARXIZqFPg66coOgfX1lhsXQSRJGQEQG4PAcYuC0GmrYFzErliifbc1Q== + +"@rspack/binding-linux-arm64-gnu@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-1.7.5.tgz#2f3705a444911602619f48c2aac7a92205b9de8a" + integrity sha512-R7CO1crkJQLIQpJQzf+6DMHjvcvH/VxsatS5CG897IIT2aAfBeQuQAO+ERJko/UwSZam2K8Rxjuopcu5A2jsTQ== + +"@rspack/binding-linux-arm64-musl@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-linux-arm64-musl/-/binding-linux-arm64-musl-1.7.5.tgz#ac94268f78ffd818465a2ee1d626f5d349190f39" + integrity sha512-moDVFD06ISZi+wCIjJLzQSr8WO8paViacSHk+rOKQxwKI96cPoC4JFkz0+ibT2uks4i2ecs4Op48orsoguiXxw== + +"@rspack/binding-linux-x64-gnu@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-linux-x64-gnu/-/binding-linux-x64-gnu-1.7.5.tgz#69414ac99b79240d0148331bfd6579c3c669b85e" + integrity sha512-LGtdsdhtA5IxdMptj2NDVEbuZF4aqM99BVn3saHp92A4Fn20mW9UtQ+19PtaOFdbQBUN1GcP+cosrJ1wY56hOg== + +"@rspack/binding-linux-x64-musl@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-linux-x64-musl/-/binding-linux-x64-musl-1.7.5.tgz#a5b14a9a90e2400b85b2d13e83f379974356bd83" + integrity sha512-V1HTvuj0XF/e4Xnixqf7FrxdCtTkYqn26EKwH7ExUFuVBh4SsLGr29EK5SOXBG0xdy5TSEUokMup7cuONPb3Hw== + +"@rspack/binding-wasm32-wasi@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-wasm32-wasi/-/binding-wasm32-wasi-1.7.5.tgz#4addba33fbc8ba100cf7c963e804c9659dd87618" + integrity sha512-rGNHrk2QuLFfwOTib91skuLh2aMYeTP4lgM4zanDhtt95DLDlwioETFY7FzY1WmS+Z3qnEyrgQIRp8osy0NKTw== dependencies: "@napi-rs/wasm-runtime" "1.0.7" -"@rspack/binding-win32-arm64-msvc@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-1.6.5.tgz#f78c90691d5da8628da02de6e972cc8de517ae60" - integrity sha512-UUmep2ayuZxWPdrzkrzAFxVgYUWTB82pa9bkAGyeDO9SNkz8vTpdtbDaTvAzjFb8Pn+ErktDEDBKT57FLjxwxQ== - -"@rspack/binding-win32-ia32-msvc@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-win32-ia32-msvc/-/binding-win32-ia32-msvc-1.6.5.tgz#4666a868eca3d24d00405e64baa708f2c8a556b2" - integrity sha512-7nx+mMimpmCMstcW7nsyToXy5TK7N+YGPu2W/oioX7qv9ZCuJGTddjzLS84wN8DVrNIirg4mcxpBsmOQMZeHQA== - -"@rspack/binding-win32-x64-msvc@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding-win32-x64-msvc/-/binding-win32-x64-msvc-1.6.5.tgz#98a4196c38e9d220cde9a5047f99cf503ca46d6e" - integrity sha512-pzO7rYFu6f6stgSccolZHiXGTTwKrIGHHNV1ALY1xPRmQEdbHcbMwadeaG99JL2lRLve9iNI+Z9Pr3oDVRN46g== - -"@rspack/binding@1.6.5": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/binding/-/binding-1.6.5.tgz#78afbe3c9303edc39d96b57d32f33dca6a3fd75a" - integrity sha512-FzYsr5vdjaVQIlDTxZFlISOQGxl/4grpF2BeiNy60Fpw9eeADeXk55DVacbXPqpiz7Doj6cyhEyMszQOvihrqQ== +"@rspack/binding-win32-arm64-msvc@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-1.7.5.tgz#a2bac95fa670738dd2850bac0f56fc490a2b6aad" + integrity sha512-eLyD9URS9M2pYa7sPICu9S0OuDAMnnGfuqrZYlrtgnEOEgimaG39gX6ENLwHvlNulaVMMFTNbDnS/2MELZ7r7g== + +"@rspack/binding-win32-ia32-msvc@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-win32-ia32-msvc/-/binding-win32-ia32-msvc-1.7.5.tgz#7256001750794aa3b14815cc460c43d621ac4bdb" + integrity sha512-ZT4eC8hHWzweA6S4Tl2c/z/fvhbU7Wnh+l76z+qmDy8wuA8uNrHgIb1mHLPli/wsqcjmIy8rDO9gkIBitg5I+w== + +"@rspack/binding-win32-x64-msvc@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding-win32-x64-msvc/-/binding-win32-x64-msvc-1.7.5.tgz#eb8bafd9011139478ce79bd4924e3c0e481a2faa" + integrity sha512-a2j10QS3dZvW+gdu+FXteAkChxsK2g9BRUOmpt13w22LkiGrdmOkMQyDWRgJNxUGJTlqIUqtXxs72nTTlzo2Sw== + +"@rspack/binding@1.7.5": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/binding/-/binding-1.7.5.tgz#33efebda1596936193a6a9a8cdfb289b03c4cbba" + integrity sha512-tlZfDHfGu765FBL3hIyjrr8slJZztv7rCM+KIczZS7UlJQDl1+WsDKUe/+E1Fw9SlmorLWK40+y3rLTHmMrN2A== optionalDependencies: - "@rspack/binding-darwin-arm64" "1.6.5" - "@rspack/binding-darwin-x64" "1.6.5" - "@rspack/binding-linux-arm64-gnu" "1.6.5" - "@rspack/binding-linux-arm64-musl" "1.6.5" - "@rspack/binding-linux-x64-gnu" "1.6.5" - "@rspack/binding-linux-x64-musl" "1.6.5" - "@rspack/binding-wasm32-wasi" "1.6.5" - "@rspack/binding-win32-arm64-msvc" "1.6.5" - "@rspack/binding-win32-ia32-msvc" "1.6.5" - "@rspack/binding-win32-x64-msvc" "1.6.5" - -"@rspack/core@1.6.5", "@rspack/core@^1.5.0": - version "1.6.5" - resolved "https://registry.yarnpkg.com/@rspack/core/-/core-1.6.5.tgz#8e06a917dfbc556156d5c544cbf985b4da89dbd7" - integrity sha512-AqaOMA6MTNhqMYYwrhvPA+2uS662SkAi8Rb7B/IFOzh/Z5ooyczL4lUX+qyhAO3ymn50iwM4jikQCf9XfBiaQA== - dependencies: - "@module-federation/runtime-tools" "0.21.4" - "@rspack/binding" "1.6.5" + "@rspack/binding-darwin-arm64" "1.7.5" + "@rspack/binding-darwin-x64" "1.7.5" + "@rspack/binding-linux-arm64-gnu" "1.7.5" + "@rspack/binding-linux-arm64-musl" "1.7.5" + "@rspack/binding-linux-x64-gnu" "1.7.5" + "@rspack/binding-linux-x64-musl" "1.7.5" + "@rspack/binding-wasm32-wasi" "1.7.5" + "@rspack/binding-win32-arm64-msvc" "1.7.5" + "@rspack/binding-win32-ia32-msvc" "1.7.5" + "@rspack/binding-win32-x64-msvc" "1.7.5" + +"@rspack/core@^1.5.0": + version "1.7.5" + resolved "https://registry.yarnpkg.com/@rspack/core/-/core-1.7.5.tgz#d19295b5c2f137d4458701cf6dc3cbd3f73708b7" + integrity sha512-W1ChLhjBxGg6y4AHjEVjhcww/FZJ2O9obR0EOlYcfrfQGojCAUMeQjbmaF2sse5g5m0vSCaPtNYkycZ0qVRk1A== + dependencies: + "@module-federation/runtime-tools" "0.22.0" + "@rspack/binding" "1.7.5" "@rspack/lite-tapable" "1.1.0" "@rspack/lite-tapable@1.1.0": @@ -5300,9 +5305,9 @@ integrity sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ== "@sinclair/typebox@^0.27.8": - version "0.27.8" - resolved "https://registry.yarnpkg.com/@sinclair/typebox/-/typebox-0.27.8.tgz#6667fac16c436b5434a387a34dedb013198f6e6e" - integrity sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA== + version "0.27.10" + resolved "https://registry.yarnpkg.com/@sinclair/typebox/-/typebox-0.27.10.tgz#beefe675f1853f73676aecc915b2bd2ac98c4fc6" + integrity sha512-MTBk/3jGLNB2tVxv6uLlFh1iu64iYOQ2PbdOSK3NW8JZsmlaOh2q6sdtKowBhfw8QFLmYNzTW4/oK4uATIi6ZA== "@sindresorhus/is@^4.6.0": version "4.6.0" @@ -5444,147 +5449,147 @@ "@svgr/plugin-jsx" "8.1.0" "@svgr/plugin-svgo" "8.1.0" -"@swc/core-darwin-arm64@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-darwin-arm64/-/core-darwin-arm64-1.15.10.tgz#fb76ac44fa1d30696299d45c84f35b62f9ea2bac" - integrity sha512-U72pGqmJYbjrLhMndIemZ7u9Q9owcJczGxwtfJlz/WwMaGYAV/g4nkGiUVk/+QSX8sFCAjanovcU1IUsP2YulA== +"@swc/core-darwin-arm64@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-darwin-arm64/-/core-darwin-arm64-1.15.11.tgz#6f177125831b765e5dacdd1d8c07de576962ad16" + integrity sha512-QoIupRWVH8AF1TgxYyeA5nS18dtqMuxNwchjBIwJo3RdwLEFiJq6onOx9JAxHtuPwUkIVuU2Xbp+jCJ7Vzmgtg== -"@swc/core-darwin-x64@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-darwin-x64/-/core-darwin-x64-1.15.10.tgz#b00fdc59022152cc4998e8478a9250ca8382a7d7" - integrity sha512-NZpDXtwHH083L40xdyj1sY31MIwLgOxKfZEAGCI8xHXdHa+GWvEiVdGiu4qhkJctoHFzAEc7ZX3GN5phuJcPuQ== +"@swc/core-darwin-x64@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-darwin-x64/-/core-darwin-x64-1.15.11.tgz#31381b6560bbd8b8ca6a0755262df321e28c039d" + integrity sha512-S52Gu1QtPSfBYDiejlcfp9GlN+NjTZBRRNsz8PNwBgSE626/FUf2PcllVUix7jqkoMC+t0rS8t+2/aSWlMuQtA== -"@swc/core-linux-arm-gnueabihf@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-linux-arm-gnueabihf/-/core-linux-arm-gnueabihf-1.15.10.tgz#d39405a2ddcf6604db684fcbbcc9c807810b5d41" - integrity sha512-ioieF5iuRziUF1HkH1gg1r93e055dAdeBAPGAk40VjqpL5/igPJ/WxFHGvc6WMLhUubSJI4S0AiZAAhEAp1jDg== +"@swc/core-linux-arm-gnueabihf@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-linux-arm-gnueabihf/-/core-linux-arm-gnueabihf-1.15.11.tgz#ea7831776f7d8a548db4a8a5f38ef37faf5c0c66" + integrity sha512-lXJs8oXo6Z4yCpimpQ8vPeCjkgoHu5NoMvmJZ8qxDyU99KVdg6KwU9H79vzrmB+HfH+dCZ7JGMqMF//f8Cfvdg== -"@swc/core-linux-arm64-gnu@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-linux-arm64-gnu/-/core-linux-arm64-gnu-1.15.10.tgz#5f59553f7d1d3e0af02eb9544b6f88c05a7bb372" - integrity sha512-tD6BClOrxSsNus9cJL7Gxdv7z7Y2hlyvZd9l0NQz+YXzmTWqnfzLpg16ovEI7gknH2AgDBB5ywOsqu8hUgSeEQ== +"@swc/core-linux-arm64-gnu@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-linux-arm64-gnu/-/core-linux-arm64-gnu-1.15.11.tgz#c99a5843115ef57cbefd40b93c99cb130d6db12f" + integrity sha512-chRsz1K52/vj8Mfq/QOugVphlKPWlMh10V99qfH41hbGvwAU6xSPd681upO4bKiOr9+mRIZZW+EfJqY42ZzRyA== -"@swc/core-linux-arm64-musl@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-linux-arm64-musl/-/core-linux-arm64-musl-1.15.10.tgz#eb833e49df2a706d2ccf8e4474c111e7a1b784a5" - integrity sha512-4uAHO3nbfbrTcmO/9YcVweTQdx5fN3l7ewwl5AEK4yoC4wXmoBTEPHAVdKNe4r9+xrTgd4BgyPsy0409OjjlMw== +"@swc/core-linux-arm64-musl@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-linux-arm64-musl/-/core-linux-arm64-musl-1.15.11.tgz#9a7831f558b2ff504d3d6eaaf6a4c84e5232284b" + integrity sha512-PYftgsTaGnfDK4m6/dty9ryK1FbLk+LosDJ/RJR2nkXGc8rd+WenXIlvHjWULiBVnS1RsjHHOXmTS4nDhe0v0w== -"@swc/core-linux-x64-gnu@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-linux-x64-gnu/-/core-linux-x64-gnu-1.15.10.tgz#5d0b6f36e9d9d49fc0a2170fec2b6de2c9c0e76a" - integrity sha512-W0h9ONNw1pVIA0cN7wtboOSTl4Jk3tHq+w2cMPQudu9/+3xoCxpFb9ZdehwCAk29IsvdWzGzY6P7dDVTyFwoqg== +"@swc/core-linux-x64-gnu@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-linux-x64-gnu/-/core-linux-x64-gnu-1.15.11.tgz#4a1fce9b9abedde04459fefe5da9dd9e405a2ae8" + integrity sha512-DKtnJKIHiZdARyTKiX7zdRjiDS1KihkQWatQiCHMv+zc2sfwb4Glrodx2VLOX4rsa92NLR0Sw8WLcPEMFY1szQ== -"@swc/core-linux-x64-musl@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-linux-x64-musl/-/core-linux-x64-musl-1.15.10.tgz#0788cf24330f8efec0379cce594c727f3bc0a7c8" - integrity sha512-XQNZlLZB62S8nAbw7pqoqwy91Ldy2RpaMRqdRN3T+tAg6Xg6FywXRKCsLh6IQOadr4p1+lGnqM/Wn35z5a/0Vw== +"@swc/core-linux-x64-musl@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-linux-x64-musl/-/core-linux-x64-musl-1.15.11.tgz#0865f23b1cc532d9d77e743a83279e074edbee25" + integrity sha512-mUjjntHj4+8WBaiDe5UwRNHuEzLjIWBTSGTw0JT9+C9/Yyuh4KQqlcEQ3ro6GkHmBGXBFpGIj/o5VMyRWfVfWw== -"@swc/core-win32-arm64-msvc@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-win32-arm64-msvc/-/core-win32-arm64-msvc-1.15.10.tgz#1555dc561606268ff84805568cd9a60b5de42543" - integrity sha512-qnAGrRv5Nj/DATxAmCnJQRXXQqnJwR0trxLndhoHoxGci9MuguNIjWahS0gw8YZFjgTinbTxOwzatkoySihnmw== +"@swc/core-win32-arm64-msvc@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-win32-arm64-msvc/-/core-win32-arm64-msvc-1.15.11.tgz#73eda8b54c94046728f5983e5516223ad1009c59" + integrity sha512-ZkNNG5zL49YpaFzfl6fskNOSxtcZ5uOYmWBkY4wVAvgbSAQzLRVBp+xArGWh2oXlY/WgL99zQSGTv7RI5E6nzA== -"@swc/core-win32-ia32-msvc@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-win32-ia32-msvc/-/core-win32-ia32-msvc-1.15.10.tgz#e51f79e4e257f9b1a8c90437b20fc5a9b5b13119" - integrity sha512-i4X/q8QSvzVlaRtv1xfnfl+hVKpCfiJ+9th484rh937fiEZKxZGf51C+uO0lfKDP1FfnT6C1yBYwHy7FLBVXFw== +"@swc/core-win32-ia32-msvc@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-win32-ia32-msvc/-/core-win32-ia32-msvc-1.15.11.tgz#0df41547974ba9f26ba3e903e803ff523c15650b" + integrity sha512-6XnzORkZCQzvTQ6cPrU7iaT9+i145oLwnin8JrfsLG41wl26+5cNQ2XV3zcbrnFEV6esjOceom9YO1w9mGJByw== -"@swc/core-win32-x64-msvc@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core-win32-x64-msvc/-/core-win32-x64-msvc-1.15.10.tgz#9c2a11ac3321ebea8fc24940a1cd4b4cc9249fe2" - integrity sha512-HvY8XUFuoTXn6lSccDLYFlXv1SU/PzYi4PyUqGT++WfTnbw/68N/7BdUZqglGRwiSqr0qhYt/EhmBpULj0J9rA== +"@swc/core-win32-x64-msvc@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core-win32-x64-msvc/-/core-win32-x64-msvc-1.15.11.tgz#f6f97500472c0ea4ab756c383c5d97896075f95c" + integrity sha512-IQ2n6af7XKLL6P1gIeZACskSxK8jWtoKpJWLZmdXTDj1MGzktUy4i+FvpdtxFmJWNavRWH1VmTr6kAubRDHeKw== "@swc/core@^1.7.39": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/core/-/core-1.15.10.tgz#8487c006be73f4b4bee52d431f2b29881ae70ea4" - integrity sha512-udNofxftduMUEv7nqahl2nvodCiCDQ4Ge0ebzsEm6P8s0RC2tBM0Hqx0nNF5J/6t9uagFJyWIDjXy3IIWMHDJw== + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/core/-/core-1.15.11.tgz#8f52ab37b4d874b9cc1b1ae809778620b42dbf9f" + integrity sha512-iLmLTodbYxU39HhMPaMUooPwO/zqJWvsqkrXv1ZI38rMb048p6N7qtAtTp37sw9NzSrvH6oli8EdDygo09IZ/w== dependencies: "@swc/counter" "^0.1.3" "@swc/types" "^0.1.25" optionalDependencies: - "@swc/core-darwin-arm64" "1.15.10" - "@swc/core-darwin-x64" "1.15.10" - "@swc/core-linux-arm-gnueabihf" "1.15.10" - "@swc/core-linux-arm64-gnu" "1.15.10" - "@swc/core-linux-arm64-musl" "1.15.10" - "@swc/core-linux-x64-gnu" "1.15.10" - "@swc/core-linux-x64-musl" "1.15.10" - "@swc/core-win32-arm64-msvc" "1.15.10" - "@swc/core-win32-ia32-msvc" "1.15.10" - "@swc/core-win32-x64-msvc" "1.15.10" + "@swc/core-darwin-arm64" "1.15.11" + "@swc/core-darwin-x64" "1.15.11" + "@swc/core-linux-arm-gnueabihf" "1.15.11" + "@swc/core-linux-arm64-gnu" "1.15.11" + "@swc/core-linux-arm64-musl" "1.15.11" + "@swc/core-linux-x64-gnu" "1.15.11" + "@swc/core-linux-x64-musl" "1.15.11" + "@swc/core-win32-arm64-msvc" "1.15.11" + "@swc/core-win32-ia32-msvc" "1.15.11" + "@swc/core-win32-x64-msvc" "1.15.11" "@swc/counter@^0.1.3": version "0.1.3" resolved "https://registry.yarnpkg.com/@swc/counter/-/counter-0.1.3.tgz#cc7463bd02949611c6329596fccd2b0ec782b0e9" integrity sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ== -"@swc/html-darwin-arm64@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-darwin-arm64/-/html-darwin-arm64-1.15.10.tgz#98c95d79b6713906fadb0618a9fc18ef4068231e" - integrity sha512-WmQiAZe3TSbIvdPKljsFUwGqj3j53CSNxNcJcLhbTPVCU8Z0QQ9cEpeyktkqGNrQWOGp5r5EorWi+nvFu4HfqQ== +"@swc/html-darwin-arm64@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-darwin-arm64/-/html-darwin-arm64-1.15.11.tgz#209c1591bb8c3cff87f104ae44ec75c8e9c9ecfc" + integrity sha512-FTa0ypbMbUXiwXIIT76HMFQYewEdTsPKOQGDqI6/kUTzU+lCIqIJequdoh6gqQvMq2BtBu/15dkTYYIlp4JoJw== -"@swc/html-darwin-x64@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-darwin-x64/-/html-darwin-x64-1.15.10.tgz#f93e63c582b93598ffdb79b2ccc1f318a52ecdc7" - integrity sha512-EQaa43uKUn48dOaXyY7JpA2DChFYTwdfyfFvqz+sN3LoEM1OV1QxocWoF+qHPTKEzvLUzIYH5Tm09GzJz9hWIA== +"@swc/html-darwin-x64@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-darwin-x64/-/html-darwin-x64-1.15.11.tgz#411b53362105385132ffdf9bf556217d71283cfd" + integrity sha512-U+WFUFqbqS2WsLVCt40MuBGJ7mxDJi/T8RocBvQkoRwU3juOmeM2V/Od/QLBZxTFZTLQ3RCHJTkLXSDnxUWUuw== -"@swc/html-linux-arm-gnueabihf@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-linux-arm-gnueabihf/-/html-linux-arm-gnueabihf-1.15.10.tgz#dcad09c8e9bea3fe6d2d230700c786695d723c40" - integrity sha512-UymYHc37ejcKubESPGP5LlGqmx6vJnVs5CYCUbdpblar1XN1oW0SkxKOZVjURYCVAaB3XxfCTCptEol04uvhiw== +"@swc/html-linux-arm-gnueabihf@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-linux-arm-gnueabihf/-/html-linux-arm-gnueabihf-1.15.11.tgz#12a9e6a0fbb62f68fe0f003f2c43a9232c66d1ea" + integrity sha512-Cid64465sEkAiTh8KLFCbQbsIbgDzPeGdA5ZYB8w5AXmYAGPJ0xbeRHEFq3iq469Dj2rxYvExrLCXNhn8rHbww== -"@swc/html-linux-arm64-gnu@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-linux-arm64-gnu/-/html-linux-arm64-gnu-1.15.10.tgz#db770640cd8e14837209cb3f3fbeddd8977b0460" - integrity sha512-o9FzVmnpyD0Z4fzUbIrFz+1JZ72ZFaij+tZ4ZPtIWgA0ymyqlplPOHAbRsbt5/YoLoAx0wo2FN/sYsMdPv3mcA== +"@swc/html-linux-arm64-gnu@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-linux-arm64-gnu/-/html-linux-arm64-gnu-1.15.11.tgz#35b7395c3db2c702a4e2db7bac9e2805d3d0453f" + integrity sha512-sxKdt0QJIR2x/6pAmDPK0tjfGVwsSZsfeY1BM8ODTm7h18ApE7KVNN+ZtsDbl4n5ejfXG7fOWNmMPUvj8qSMSA== -"@swc/html-linux-arm64-musl@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-linux-arm64-musl/-/html-linux-arm64-musl-1.15.10.tgz#08e7a223944006121d94b6883f0189f396723f3a" - integrity sha512-3bBKC6VbOCFH4zJECWmp6jpuoOTcRIaC33zXLJta/GL9bT4AL3PAP0TdSvjNJ4fCAnOJFmbhawlCIOJJ5mTl/g== +"@swc/html-linux-arm64-musl@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-linux-arm64-musl/-/html-linux-arm64-musl-1.15.11.tgz#c21b62f3027720aeac30039fcc85487893d1523c" + integrity sha512-aNACh2/HPy52VbKPqHieVRDeKzkO66DQdlhiVUi+fggdn8khvllni6Xr52INeAMjYFASrTTth/3vKXMv215t3A== -"@swc/html-linux-x64-gnu@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-linux-x64-gnu/-/html-linux-x64-gnu-1.15.10.tgz#6811a3f9de97a1377715d3176163931462fec63e" - integrity sha512-4Bb77cpu8fZ38+PqfctHzO3JuJ74B8HKG3/NaqGUlJbwQOiHy0RSAowAp9njyMZ1EzbEkpC9XXju75RLI1KdLA== +"@swc/html-linux-x64-gnu@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-linux-x64-gnu/-/html-linux-x64-gnu-1.15.11.tgz#c0bb4430a406f5fdd171b4ba1d6157320dbbe3c7" + integrity sha512-8YOar0XeRLBzA+UMMW5smGpsQamoZLtaQ5RKGfap21FxOUUXqkPhkDTRr+kBVCYb47yz3NokjTPaDGTWOYNyww== -"@swc/html-linux-x64-musl@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-linux-x64-musl/-/html-linux-x64-musl-1.15.10.tgz#170a25071cc42c02740eb3a5f6d9b51faab50cfc" - integrity sha512-amYNWp667VbuV+4cAJB0RWYwsBPyh+7WtV0CDpD0ATgB4UvkOWuencFqUYXKC9xczFriani6OqdMa1d2Bffbog== +"@swc/html-linux-x64-musl@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-linux-x64-musl/-/html-linux-x64-musl-1.15.11.tgz#2b3ea8fb8937966fac39bf5d36c07dd99b6d34c0" + integrity sha512-em2Ur0uGFA/nw2JbMclXu9mLuUC7q/1J06i8FZTRHqZzNGt9Q0UMdgH9T8HkGLT5e7dZ6ROJoq1H4st6B8N3uw== -"@swc/html-win32-arm64-msvc@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-win32-arm64-msvc/-/html-win32-arm64-msvc-1.15.10.tgz#2c67ce17b84c7bf5bdf82e80bc0ca12ce95dc4d6" - integrity sha512-FRtTz1akAUfS1PH1WsILwBuRAgy/4E/d++il+dZAGkaAP5UaNUXPduNfLaJhT/mR3rVJaIqfAmAJEc1ts0u0lA== +"@swc/html-win32-arm64-msvc@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-win32-arm64-msvc/-/html-win32-arm64-msvc-1.15.11.tgz#3503c7ecddb773bd90ee09f31fb30e230edcecda" + integrity sha512-Xf9Vd4UsYTs4ejBwS+j9zShkyp3KQ+qfn/ZKVMKDygWjuOjU6FFXWYm93/PdTmS5qD0c58FhmoqTv+uFEZ4nxQ== -"@swc/html-win32-ia32-msvc@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-win32-ia32-msvc/-/html-win32-ia32-msvc-1.15.10.tgz#6b320b474bb42a590bb38ac584ff19b2e53df78e" - integrity sha512-eRscB+1U3WvxKyKrbh7aBioxNB/G3t+NP/RoTEAfSmKfIMuRTR3YX6FrPSU/7SFjv2lgswjRt5MGX7Ygjh5xuw== +"@swc/html-win32-ia32-msvc@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-win32-ia32-msvc/-/html-win32-ia32-msvc-1.15.11.tgz#41ce66ac169bb7d4b3fa061f0a5be1cc834a5ddb" + integrity sha512-+YNzKR81UqH+xOZPU8XEIy5L6E63UUGSSEu1Wv3D85GVMQkZ8X9LZkZ5hq4vvqmCTV1zeHIPfzNrrVElqK198g== -"@swc/html-win32-x64-msvc@1.15.10": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html-win32-x64-msvc/-/html-win32-x64-msvc-1.15.10.tgz#a7300047fd90710907ba7d4f52a882eb33047efc" - integrity sha512-UnKP25R8n3rxl3o0/04FK0iezi9m3Yp8Qrc9nzzrjFpso/TPbJwfgE+2bGUYaX482EsBU7TBorLY2t8fWcD7/Q== +"@swc/html-win32-x64-msvc@1.15.11": + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html-win32-x64-msvc/-/html-win32-x64-msvc-1.15.11.tgz#98793d32a81457c33248c3bf50711379025104d2" + integrity sha512-Y3Xj62eA+pjadhgiVNFUBgIN9Wa1gYrB3N1l6NmSLeApVE2qkBww3WrVXhRDfqUXiWz7eRHPDakZSRQREyMv5A== "@swc/html@^1.13.5": - version "1.15.10" - resolved "https://registry.yarnpkg.com/@swc/html/-/html-1.15.10.tgz#5d20c1b04a11cb1134e4af6de8d9fd8bf1516226" - integrity sha512-nlsp1DcT84fQPLcdOO8InIApoD6pI2gWmZCqyCfdu9WRIXZyKv43xIFEymtFrkZgR1iE0YlQV5mrsMnY2D2kxA== + version "1.15.11" + resolved "https://registry.yarnpkg.com/@swc/html/-/html-1.15.11.tgz#f8dcdc099eaffdc2d40b0a818b13ec6198d75b50" + integrity sha512-JOO48SCxyR3KbH9iiLMSWRDm7+Xl6lgvOBe5di54W8PsumdeP0Imatq8cunkRAUR7br8xAjlpB16bX6iJeyeMw== dependencies: "@swc/counter" "^0.1.3" optionalDependencies: - "@swc/html-darwin-arm64" "1.15.10" - "@swc/html-darwin-x64" "1.15.10" - "@swc/html-linux-arm-gnueabihf" "1.15.10" - "@swc/html-linux-arm64-gnu" "1.15.10" - "@swc/html-linux-arm64-musl" "1.15.10" - "@swc/html-linux-x64-gnu" "1.15.10" - "@swc/html-linux-x64-musl" "1.15.10" - "@swc/html-win32-arm64-msvc" "1.15.10" - "@swc/html-win32-ia32-msvc" "1.15.10" - "@swc/html-win32-x64-msvc" "1.15.10" + "@swc/html-darwin-arm64" "1.15.11" + "@swc/html-darwin-x64" "1.15.11" + "@swc/html-linux-arm-gnueabihf" "1.15.11" + "@swc/html-linux-arm64-gnu" "1.15.11" + "@swc/html-linux-arm64-musl" "1.15.11" + "@swc/html-linux-x64-gnu" "1.15.11" + "@swc/html-linux-x64-musl" "1.15.11" + "@swc/html-win32-arm64-msvc" "1.15.11" + "@swc/html-win32-ia32-msvc" "1.15.11" + "@swc/html-win32-x64-msvc" "1.15.11" "@swc/types@^0.1.25": version "0.1.25" @@ -5632,6 +5637,13 @@ dependencies: tslib "^2.4.0" +"@types/better-sqlite3@^7.6.13": + version "7.6.13" + resolved "https://registry.yarnpkg.com/@types/better-sqlite3/-/better-sqlite3-7.6.13.tgz#a72387f00d2f53cab699e63f2e2c05453cf953f0" + integrity sha512-NMv9ASNARoKksWtsq/SHakpYAYnhBrQgGD8zkLYk/jaK8jUGn08CfEdTRgYhMypUQAfzSP8W6gNLe0q19/t4VA== + dependencies: + "@types/node" "*" + "@types/body-parser@*": version "1.19.6" resolved "https://registry.yarnpkg.com/@types/body-parser/-/body-parser-1.19.6.tgz#1859bebb8fd7dac9918a45d54c1971ab8b5af474" @@ -6024,9 +6036,9 @@ integrity sha512-oh/6byDPnL1zeNXFrDXFLyZjkr1MsBG667IM792caf1L2UPOOMf65NFzjUH/ltyfwjAGfs1rsX1eftK0jC/KIg== "@types/http-cache-semantics@^4.0.2": - version "4.0.4" - resolved "https://registry.yarnpkg.com/@types/http-cache-semantics/-/http-cache-semantics-4.0.4.tgz#b979ebad3919799c979b17c72621c0bc0a31c6c4" - integrity sha512-1m0bIFVc7eJWyve9S0RnuRgcQqF/Xd5QsUZAZeQFr1Q3/p9JWoQQEqmVy+DPTNpGXwhgIetAoYF8JSc33q29QA== + version "4.2.0" + resolved "https://registry.yarnpkg.com/@types/http-cache-semantics/-/http-cache-semantics-4.2.0.tgz#f6a7788f438cbfde15f29acad46512b4c01913b3" + integrity sha512-L3LgimLHXtGkWikKnsPg0/VFx9OGZaC+eN1u4r+OB1XRqH3meBIAVC2zr1WdMH+RHmnRkqliQAOHNJ/E0j/e0Q== "@types/http-errors@*": version "2.0.5" @@ -6123,9 +6135,9 @@ integrity sha512-GsCCIZDE/p3i96vtEqx+7dBUGXrc7zeSK3wwPHIaRThS+9OhWIXRqzs4d6k1SVU8g91DrNRWxWUGhp5KXQb2VA== "@types/node@*", "@types/node@>=10.0.0": - version "25.0.10" - resolved "https://registry.yarnpkg.com/@types/node/-/node-25.0.10.tgz#4864459c3c9459376b8b75fd051315071c8213e7" - integrity sha512-zWW5KPngR/yvakJgGOmZ5vTBemDoSqF3AcV/LrO5u5wTWyEAVVh+IT39G4gtyAkh3CtTZs8aX/yRM82OfzHJRg== + version "25.2.0" + resolved "https://registry.yarnpkg.com/@types/node/-/node-25.2.0.tgz#015b7d228470c1dcbfc17fe9c63039d216b4d782" + integrity sha512-DZ8VwRFUNzuqJ5khrvwMXHmvPe+zGayJhr2CDNiKB1WBE1ST8Djl00D0IC4vvNmHMdj6DlbYRIaFE7WHjlDl5w== dependencies: undici-types "~7.16.0" @@ -6203,9 +6215,9 @@ integrity sha512-8TV6R3h2j7a91c+1DXdJi3Syo69zzIZbz7Lg5tORM5LEJG7X/E6a1V3drRyBRZq7/utz7A+c4OgYLiLcYGHG6w== "@types/react@*": - version "19.2.9" - resolved "https://registry.yarnpkg.com/@types/react/-/react-19.2.9.tgz#84ec7669742bb3e7e2e8d6a5258d95ead7764200" - integrity sha512-Lpo8kgb/igvMIPeNV2rsYKTgaORYdO1XGVZ4Qz3akwOj0ySGYMPlQWa8BaLn0G63D1aSaAQ5ldR06wCpChQCjA== + version "19.2.11" + resolved "https://registry.yarnpkg.com/@types/react/-/react-19.2.11.tgz#301b615ec33df67f6b0ba63f2b6aedce46cca0de" + integrity sha512-tORuanb01iEzWvMGVGv2ZDhYZVeRMrw453DCSAIn/5yvcSVnMoUMTyf33nQJLahYEnv9xqrTNbgz4qY5EfSh0g== dependencies: csstype "^3.2.2" @@ -6895,20 +6907,20 @@ asynckit@^0.4.0: integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== autoprefixer@^10.4.19, autoprefixer@^10.4.23: - version "10.4.23" - resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-10.4.23.tgz#c6aa6db8e7376fcd900f9fd79d143ceebad8c4e6" - integrity sha512-YYTXSFulfwytnjAPlw8QHncHJmlvFKtczb8InXaAx9Q0LbfDnfEYDE55omerIJKihhmU61Ft+cAOSzQVaBUmeA== + version "10.4.24" + resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-10.4.24.tgz#2c29595f3abd820a79976a609d0bf40eecf212fb" + integrity sha512-uHZg7N9ULTVbutaIsDRoUkoS8/h3bdsmVJYZ5l3wv8Cp/6UIIoRDm90hZ+BwxUj/hGBEzLxdHNSKuFpn8WOyZw== dependencies: browserslist "^4.28.1" - caniuse-lite "^1.0.30001760" + caniuse-lite "^1.0.30001766" fraction.js "^5.3.4" picocolors "^1.1.1" postcss-value-parser "^4.2.0" axios@^1.7.9, axios@^1.9.0: - version "1.13.2" - resolved "https://registry.yarnpkg.com/axios/-/axios-1.13.2.tgz#9ada120b7b5ab24509553ec3e40123521117f687" - integrity sha512-VPk9ebNqPcy5lRGuSlKx752IlDatOjT9paPlm8A7yOuW2Fbvp4X3JznJtT4f0GzGLLiWE9W8onz51SqLYwzGaA== + version "1.13.4" + resolved "https://registry.yarnpkg.com/axios/-/axios-1.13.4.tgz#15d109a4817fb82f73aea910d41a2c85606076bc" + integrity sha512-1wVkUaAO6WyaYtCkcYCOx12ZgpGf9Zif+qXa4n+oYzK558YryKqiL6UWwd5DqiH3VRW0GYhTZQ/vlgJrCoNQlg== dependencies: follow-redirects "^1.15.6" form-data "^4.0.4" @@ -6938,7 +6950,7 @@ babel-plugin-macros@^3.1.0: cosmiconfig "^7.0.0" resolve "^1.19.0" -babel-plugin-polyfill-corejs2@^0.4.14: +babel-plugin-polyfill-corejs2@^0.4.14, babel-plugin-polyfill-corejs2@^0.4.15: version "0.4.15" resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.15.tgz#808fa349686eea4741807cfaaa2aa3aa57ce120a" integrity sha512-hR3GwrRwHUfYwGfrisXPIDP3JcYfBrW7wKE7+Au6wDYl7fm/ka1NEII6kORzxNU556JjfidZeBsO10kYvtV1aw== @@ -6955,7 +6967,15 @@ babel-plugin-polyfill-corejs3@^0.13.0: "@babel/helper-define-polyfill-provider" "^0.6.5" core-js-compat "^3.43.0" -babel-plugin-polyfill-regenerator@^0.6.5: +babel-plugin-polyfill-corejs3@^0.14.0: + version "0.14.0" + resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.14.0.tgz#65b06cda48d6e447e1e926681f5a247c6ae2b9cf" + integrity sha512-AvDcMxJ34W4Wgy4KBIIePQTAOP1Ie2WFwkQp3dB7FQ/f0lI5+nM96zUnYEOE1P9sEg0es5VCP0HxiWu5fUHZAQ== + dependencies: + "@babel/helper-define-polyfill-provider" "^0.6.6" + core-js-compat "^3.48.0" + +babel-plugin-polyfill-regenerator@^0.6.5, babel-plugin-polyfill-regenerator@^0.6.6: version "0.6.6" resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.6.tgz#69f5dd263cab933c42fe5ea05e83443b374bd4bf" integrity sha512-hYm+XLYRMvupxiQzrvXUj7YyvFFVfv5gI0R71AJzudg1g2AI2vyCPPIFEBjk162/wFzti3inBHo7isWFuEVS/A== @@ -6983,9 +7003,9 @@ base64id@2.0.0, base64id@~2.0.0: integrity sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog== baseline-browser-mapping@^2.9.0: - version "2.9.17" - resolved "https://registry.yarnpkg.com/baseline-browser-mapping/-/baseline-browser-mapping-2.9.17.tgz#9d6019766cd7eba738cb5f32c84b9f937cc87780" - integrity sha512-agD0MgJFUP/4nvjqzIB29zRPUuCF7Ge6mEv9s8dHrtYD7QWXRcx75rOADE/d5ah1NI+0vkDl0yorDd5U852IQQ== + version "2.9.19" + resolved "https://registry.yarnpkg.com/baseline-browser-mapping/-/baseline-browser-mapping-2.9.19.tgz#3e508c43c46d961eb4d7d2e5b8d1dd0f9ee4f488" + integrity sha512-ipDqC8FrAl/76p2SSWKSI+H9tFwm7vYqXQrItCuiVPt26Km0jS+NzSsBWAaBusvSbQcfJG+JitdMm+wZAgTYqg== batch@0.6.1: version "0.6.1" @@ -6998,12 +7018,12 @@ before-after-hook@^3.0.2: integrity sha512-Nik3Sc0ncrMK4UUdXQmAnRtzmNQTAAXmXIopizwZ1W1t8QmfJj+zL4OA2I7XPTPW5z5TDqv4hRo/JzouDJnX3A== better-auth@^1.4.9: - version "1.4.17" - resolved "https://registry.yarnpkg.com/better-auth/-/better-auth-1.4.17.tgz#a6f6176042900690df880ed349ca27ec0620291c" - integrity sha512-VmHGQyKsEahkEs37qguROKg/6ypYpNF13D7v/lkbO7w7Aivz0Bv2h+VyUkH4NzrGY0QBKXi1577mGhDCVwp0ew== + version "1.4.18" + resolved "https://registry.yarnpkg.com/better-auth/-/better-auth-1.4.18.tgz#460cfa3f71d2da9ffcbfc1ad4d87977a4d51b5d5" + integrity sha512-bnyifLWBPcYVltH3RhS7CM62MoelEqC6Q+GnZwfiDWNfepXoQZBjEvn4urcERC7NTKgKq5zNBM8rvPvRBa6xcg== dependencies: - "@better-auth/core" "1.4.17" - "@better-auth/telemetry" "1.4.17" + "@better-auth/core" "1.4.18" + "@better-auth/telemetry" "1.4.18" "@better-auth/utils" "0.3.0" "@better-fetch/fetch" "1.1.21" "@noble/ciphers" "^2.0.0" @@ -7025,6 +7045,14 @@ better-call@1.1.8: rou3 "^0.7.10" set-cookie-parser "^2.7.1" +better-sqlite3@^12.6.2: + version "12.6.2" + resolved "https://registry.yarnpkg.com/better-sqlite3/-/better-sqlite3-12.6.2.tgz#770649f28a62e543a360f3dfa1afe4cc944b1937" + integrity sha512-8VYKM3MjCa9WcaSAI3hzwhmyHVlH8tiGFwf0RlTsZPWJ1I5MkzjiudCo4KC4DxOaL/53A5B1sI/IbldNFDbsKA== + dependencies: + bindings "^1.5.0" + prebuild-install "^7.1.1" + big-integer@^1.6.17: version "1.6.52" resolved "https://registry.yarnpkg.com/big-integer/-/big-integer-1.6.52.tgz#60a887f3047614a8e1bffe5d7173490a97dc8c85" @@ -7048,6 +7076,13 @@ binary@~0.3.0: buffers "~0.1.1" chainsaw "~0.1.0" +bindings@^1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/bindings/-/bindings-1.5.0.tgz#10353c9e945334bc0511a6d90b38fbc7c9c504df" + integrity sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ== + dependencies: + file-uri-to-path "1.0.0" + bl@^4.0.3: version "4.1.0" resolved "https://registry.yarnpkg.com/bl/-/bl-4.1.0.tgz#451535264182bec2fbbc83a62ab98cf11d9f7b3a" @@ -7324,10 +7359,10 @@ caniuse-api@^3.0.0: lodash.memoize "^4.1.2" lodash.uniq "^4.5.0" -caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001759, caniuse-lite@^1.0.30001760: - version "1.0.30001766" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001766.tgz#b6f6b55cb25a2d888d9393104d14751c6a7d6f7a" - integrity sha512-4C0lfJ0/YPjJQHagaE9x2Elb69CIqEPZeG0anQt9SIvIoOH4a4uaRl73IavyO+0qZh6MDLH//DrXThEYKHkmYA== +caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001759, caniuse-lite@^1.0.30001766: + version "1.0.30001767" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001767.tgz#0279c498e862efb067938bba0a0aabafe8d0b730" + integrity sha512-34+zUAMhSH+r+9eKmYG+k2Rpt8XttfE4yXAjoZvkAPs15xcYQhyBYdalJ65BzivAvGRMViEjy6oKr/S91loekQ== canvas-roundrect-polyfill@0.0.1: version "0.0.1" @@ -7821,14 +7856,14 @@ copy-webpack-plugin@^11.0.0: schema-utils "^4.0.0" serialize-javascript "^6.0.0" -core-js-compat@^3.43.0: +core-js-compat@^3.43.0, core-js-compat@^3.48.0: version "3.48.0" resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.48.0.tgz#7efbe1fc1cbad44008190462217cc5558adaeaa6" integrity sha512-OM4cAF3D6VtH/WkLtWvyNC56EZVXsZdU3iqaMG2B4WvYrlqU831pc4UtG5yp0sE9z8Y02wVN7PjW5Zf9Gt0f1Q== dependencies: browserslist "^4.28.1" -core-js-pure@^3.43.0: +core-js-pure@^3.48.0: version "3.48.0" resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.48.0.tgz#7d5a3fe1ec3631b9aa76a81c843ac2ce918e5023" integrity sha512-1slJgk89tWC51HQ1AEqG+s2VuwpTRr8ocu4n20QUcH1v9lAN0RXen0Q0AABa/DK1I7RrNWLucplOHMx8hfTGTw== @@ -8041,9 +8076,9 @@ css-what@^6.0.1, css-what@^6.1.0: integrity sha512-u/O3vwbptzhMs3L1fQE82ZSLHQQfto5gyZzwteVIEyeaY5Fc7R4dapF/BvRoSYFeqfBk4m0V1Vafq5Pjv25wvA== cssdb@^8.6.0: - version "8.7.0" - resolved "https://registry.yarnpkg.com/cssdb/-/cssdb-8.7.0.tgz#5a0846fabf863a4d397d980d8d29eb3eb26dfde1" - integrity sha512-UxiWVpV953ENHqAKjKRPZHNDfRo3uOymvO5Ef7MFCWlenaohkYj7PTO7WCBdjZm8z/aDZd6rXyUIlwZ0AjyFSg== + version "8.7.1" + resolved "https://registry.yarnpkg.com/cssdb/-/cssdb-8.7.1.tgz#f296bbedc39ace9edf0ed8fbbec57c3e117747cd" + integrity sha512-+F6LKx48RrdGOtE4DT5jz7Uo+VeyKXpK797FAevIkzjV8bMHz6xTO5F7gNDcRCHmPgD5jj2g6QCsY9zmVrh38A== cssesc@^3.0.0: version "3.0.0" @@ -8516,9 +8551,9 @@ default-browser-id@^5.0.0: integrity sha512-x1VCxdX4t+8wVfd1so/9w+vQ4vx7lKd2Qp5tDRutErwmR85OgmfX7RlLRMWafRMY7hbEiXIbudNrjOAPa/hL8Q== default-browser@^5.2.1: - version "5.4.0" - resolved "https://registry.yarnpkg.com/default-browser/-/default-browser-5.4.0.tgz#b55cf335bb0b465dd7c961a02cd24246aa434287" - integrity sha512-XDuvSq38Hr1MdN47EDvYtx3U0MTqpCEn+F6ft8z2vYDzMrvQhVp0ui9oQdqW3MvK3vqUETglt1tVGgjLuJ5izg== + version "5.5.0" + resolved "https://registry.yarnpkg.com/default-browser/-/default-browser-5.5.0.tgz#2792e886f2422894545947cc80e1a444496c5976" + integrity sha512-H9LMLr5zwIbSxrmvikGuI/5KGhZ8E2zH3stkMgM5LpOWDutGM2JZaj460Udnf1a+946zc7YBgrqEWwbk7zHvGw== dependencies: bundle-name "^4.1.0" default-browser-id "^5.0.0" @@ -8804,9 +8839,9 @@ ee-first@1.1.1: integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== electron-to-chromium@^1.5.263: - version "1.5.278" - resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.278.tgz#807a5e321f012a41bfd64e653f35993c9af95493" - integrity sha512-dQ0tM1svDRQOwxnXxm+twlGTjr9Upvt8UFWAgmLsxEzFQxhbti4VwxmMjsDxVC51Zo84swW7FVCXEV+VAkhuPw== + version "1.5.286" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.286.tgz#142be1ab5e1cd5044954db0e5898f60a4960384e" + integrity sha512-9tfDXhJ4RKFNerfjdCcZfufu49vg620741MNs26a9+bhLThdB+plgMeou98CAaHu/WATj2iHOOHTp1hWtABj2A== elkjs@^0.9.0, elkjs@^0.9.3: version "0.9.3" @@ -8894,13 +8929,13 @@ enhanced-resolve@5.12.0: graceful-fs "^4.2.4" tapable "^2.2.0" -enhanced-resolve@^5.17.4: - version "5.18.4" - resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.18.4.tgz#c22d33055f3952035ce6a144ce092447c525f828" - integrity sha512-LgQMM4WXU3QI+SYgEc2liRgznaD5ojbmY3sb8LxyguVkIg5FxdpTkvk72te2R38/TGKxH634oLxXRGY6d7AP+Q== +enhanced-resolve@^5.19.0: + version "5.19.0" + resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.19.0.tgz#6687446a15e969eaa63c2fa2694510e17ae6d97c" + integrity sha512-phv3E1Xl4tQOShqSte26C7Fl84EwUdZsyOuSSk9qtAGyyQs2s3jJzComh+Abf4g187lUUAvH+H26omrqia2aGg== dependencies: graceful-fs "^4.2.4" - tapable "^2.2.0" + tapable "^2.3.0" entities@^2.0.0: version "2.2.0" @@ -9454,6 +9489,11 @@ file-loader@^6.2.0: loader-utils "^2.0.0" schema-utils "^3.0.0" +file-uri-to-path@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" + integrity sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw== + filesize@^10.1.6: version "10.1.6" resolved "https://registry.yarnpkg.com/filesize/-/filesize-10.1.6.tgz#31194da825ac58689c0bce3948f33ce83aabd361" @@ -10080,9 +10120,9 @@ hoist-non-react-statics@^3.1.0, hoist-non-react-statics@^3.3.1, hoist-non-react- react-is "^16.7.0" hookified@^1.14.0: - version "1.15.0" - resolved "https://registry.yarnpkg.com/hookified/-/hookified-1.15.0.tgz#d51db9fe134b8bd19c1aa88f9fcd7878995e4b66" - integrity sha512-51w+ZZGt7Zw5q7rM3nC4t3aLn/xvKDETsXqMczndvwyVQhAHfUmUuFBRFcos8Iyebtk7OAE9dL26wFNzZVVOkw== + version "1.15.1" + resolved "https://registry.yarnpkg.com/hookified/-/hookified-1.15.1.tgz#b1fafeaa5489cdc29cb85546a8f837ed4ffbbcb6" + integrity sha512-MvG/clsADq1GPM2KGo2nyfaWVyn9naPiXrqIe4jYjXNZQt238kWyOGrsyc/DmRAQ+Re6yeo6yX/yoNCG5KAEVg== hpack.js@^2.1.6: version "2.1.6" @@ -10788,9 +10828,9 @@ jszip@^3.10.1: setimmediate "^1.0.5" katex@^0.16.0, katex@^0.16.22, katex@^0.16.9: - version "0.16.27" - resolved "https://registry.yarnpkg.com/katex/-/katex-0.16.27.tgz#4ecf6f620e0ca1c1a5de722e85fcdcec49086a48" - integrity sha512-aeQoDkuRWSqQN6nSvVCEFvfXdqo1OQiCmmW1kc9xSdjutPv7BGO7pqY9sQRJpMOGrEdfDgF2TfRXe5eUAD2Waw== + version "0.16.28" + resolved "https://registry.yarnpkg.com/katex/-/katex-0.16.28.tgz#64068425b5a29b41b136aae0d51cbb2c71d64c39" + integrity sha512-YHzO7721WbmAL6Ov1uzN/l5mY5WWWhJBSW+jq4tkfZfsxmo1hu6frS0EOswvjBUnWE6NtjEs48SFn5CQESRLZg== dependencies: commander "^8.3.0" @@ -10827,9 +10867,9 @@ known-css-properties@^0.36.0: integrity sha512-A+9jP+IUmuQsNdsLdcg6Yt7voiMF/D4K83ew0OpJtpu+l34ef7LaohWV0Rc6KNvzw6ZDizkqfyB5JznZnzuKQA== kysely@^0.28.5: - version "0.28.10" - resolved "https://registry.yarnpkg.com/kysely/-/kysely-0.28.10.tgz#d2441080cd6c633a3c6a927c2a364c69bbb829a7" - integrity sha512-ksNxfzIW77OcZ+QWSAPC7yDqUSaIVwkTWnTPNiIy//vifNbwsSgQ57OkkncHxxpcBHM3LRfLAZVEh7kjq5twVA== + version "0.28.11" + resolved "https://registry.yarnpkg.com/kysely/-/kysely-0.28.11.tgz#23b0d027cf59401e66d516eb23ed5e8e945fd4fd" + integrity sha512-zpGIFg0HuoC893rIjYX1BETkVWdDnzTzF5e0kWXJFg5lE0k1/LfNWBejrcnOFu8Q2Rfq/hTDTU7XLUM8QOrpzg== langium@3.3.1: version "3.3.1" @@ -13610,7 +13650,7 @@ postcss@^8.4.21, postcss@^8.4.24, postcss@^8.4.33, postcss@^8.4.43, postcss@^8.5 picocolors "^1.1.1" source-map-js "^1.2.1" -prebuild-install@^7.1.3: +prebuild-install@^7.1.1, prebuild-install@^7.1.3: version "7.1.3" resolved "https://registry.yarnpkg.com/prebuild-install/-/prebuild-install-7.1.3.tgz#d630abad2b147443f20a212917beae68b8092eec" integrity sha512-8Mf2cbV7x1cXPUILADGI3wuhfqWvtiLA1iclTDbFRZkgRQS0NqsPZphna9V+HyTEadheuPmjaJMsbzKQFOzLug== @@ -13747,9 +13787,9 @@ pwacompat@2.0.17: integrity sha512-6Du7IZdIy7cHiv7AhtDy4X2QRM8IAD5DII69mt5qWibC2d15ZU8DmBG1WdZKekG11cChSu4zkSUGPF9sweOl6w== pyodide@^0.29.1: - version "0.29.2" - resolved "https://registry.yarnpkg.com/pyodide/-/pyodide-0.29.2.tgz#cab544903fe202b765da2e6046e7d55c064ec34e" - integrity sha512-q/Fnbmiwlw80GfaG74gTbZ6hXOYHwZ1wCDZzE03+tzQYDP1wKEqrSqmIuLQRSYixFFdNdlGEinoGYcDnulwp5g== + version "0.29.3" + resolved "https://registry.yarnpkg.com/pyodide/-/pyodide-0.29.3.tgz#555ec43c09983a3cf3794c778e40084de24cfb95" + integrity sha512-22UBuhOJawj7vKUnS7/F3xK+515LJdjiMAHoCfuS6/PbHiOrSQVnYwDe+2sbVwiOZ3sMMexdXICew6NqOMQGgA== dependencies: "@types/emscripten" "^1.41.4" ws "^8.5.0" @@ -13904,9 +13944,9 @@ react-diff-viewer-continued@^3.4.0: prop-types "^15.8.1" react-dom@^19.2.0: - version "19.2.3" - resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-19.2.3.tgz#f0b61d7e5c4a86773889fcc1853af3ed5f215b17" - integrity sha512-yELu4WmLPw5Mr/lmeEpox5rw3RETacE++JgHqQzd2dg+YbJuat3jH4ingc+WPZhxaoFzdv9y33G+F7Nl5O0GBg== + version "19.2.4" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-19.2.4.tgz#6fac6bd96f7db477d966c7ec17c1a2b1ad8e6591" + integrity sha512-AXJdLo8kgMbimY95O2aKQqsz2iWi9jMgKJhRBAxECE4IFxfcazB2LmzloIoibJI3C12IlY20+KFaLv+71bUJeQ== dependencies: scheduler "^0.27.0" @@ -14094,9 +14134,9 @@ react-transition-group@^4.3.0: prop-types "^15.6.2" react@^19.2.0: - version "19.2.3" - resolved "https://registry.yarnpkg.com/react/-/react-19.2.3.tgz#d83e5e8e7a258cf6b4fe28640515f99b87cd19b8" - integrity sha512-Ku/hhYbVjOQnXDZFv2+RibmLFGwFdeeKHFcOTlrt7xplBnya5OGn/hIRDsqDiSUcfORsDC7MPxwork8jBwsIWA== + version "19.2.4" + resolved "https://registry.yarnpkg.com/react/-/react-19.2.4.tgz#438e57baa19b77cb23aab516cf635cd0579ee09a" + integrity sha512-9nfp2hYpCwOjAN+8TZFGhtWEwgvWHXqESH8qT89AT/lWklpLON22Lc8pEtnpsZz7VmawabSU0gCjnj8aC0euHQ== reactjs-popup@^2.0.6: version "2.0.6" @@ -14476,37 +14516,37 @@ robust-predicates@^3.0.2: integrity sha512-IXgzBWvWQwE6PrDI05OvmXUIruQTcoMDzRsOd5CDvHCVLcLHMTSYvOK5Cm46kWqlV3yAbuSpBZdJ5oP5OUoStg== rollup@^4.20.0, rollup@^4.43.0: - version "4.56.0" - resolved "https://registry.yarnpkg.com/rollup/-/rollup-4.56.0.tgz#65959d13cfbd7e48b8868c05165b1738f0143862" - integrity sha512-9FwVqlgUHzbXtDg9RCMgodF3Ua4Na6Gau+Sdt9vyCN4RhHfVKX2DCHy3BjMLTDd47ITDhYAnTwGulWTblJSDLg== + version "4.57.1" + resolved "https://registry.yarnpkg.com/rollup/-/rollup-4.57.1.tgz#947f70baca32db2b9c594267fe9150aa316e5a88" + integrity sha512-oQL6lgK3e2QZeQ7gcgIkS2YZPg5slw37hYufJ3edKlfQSGGm8ICoxswK15ntSzF/a8+h7ekRy7k7oWc3BQ7y8A== dependencies: "@types/estree" "1.0.8" optionalDependencies: - "@rollup/rollup-android-arm-eabi" "4.56.0" - "@rollup/rollup-android-arm64" "4.56.0" - "@rollup/rollup-darwin-arm64" "4.56.0" - "@rollup/rollup-darwin-x64" "4.56.0" - "@rollup/rollup-freebsd-arm64" "4.56.0" - "@rollup/rollup-freebsd-x64" "4.56.0" - "@rollup/rollup-linux-arm-gnueabihf" "4.56.0" - "@rollup/rollup-linux-arm-musleabihf" "4.56.0" - "@rollup/rollup-linux-arm64-gnu" "4.56.0" - "@rollup/rollup-linux-arm64-musl" "4.56.0" - "@rollup/rollup-linux-loong64-gnu" "4.56.0" - "@rollup/rollup-linux-loong64-musl" "4.56.0" - "@rollup/rollup-linux-ppc64-gnu" "4.56.0" - "@rollup/rollup-linux-ppc64-musl" "4.56.0" - "@rollup/rollup-linux-riscv64-gnu" "4.56.0" - "@rollup/rollup-linux-riscv64-musl" "4.56.0" - "@rollup/rollup-linux-s390x-gnu" "4.56.0" - "@rollup/rollup-linux-x64-gnu" "4.56.0" - "@rollup/rollup-linux-x64-musl" "4.56.0" - "@rollup/rollup-openbsd-x64" "4.56.0" - "@rollup/rollup-openharmony-arm64" "4.56.0" - "@rollup/rollup-win32-arm64-msvc" "4.56.0" - "@rollup/rollup-win32-ia32-msvc" "4.56.0" - "@rollup/rollup-win32-x64-gnu" "4.56.0" - "@rollup/rollup-win32-x64-msvc" "4.56.0" + "@rollup/rollup-android-arm-eabi" "4.57.1" + "@rollup/rollup-android-arm64" "4.57.1" + "@rollup/rollup-darwin-arm64" "4.57.1" + "@rollup/rollup-darwin-x64" "4.57.1" + "@rollup/rollup-freebsd-arm64" "4.57.1" + "@rollup/rollup-freebsd-x64" "4.57.1" + "@rollup/rollup-linux-arm-gnueabihf" "4.57.1" + "@rollup/rollup-linux-arm-musleabihf" "4.57.1" + "@rollup/rollup-linux-arm64-gnu" "4.57.1" + "@rollup/rollup-linux-arm64-musl" "4.57.1" + "@rollup/rollup-linux-loong64-gnu" "4.57.1" + "@rollup/rollup-linux-loong64-musl" "4.57.1" + "@rollup/rollup-linux-ppc64-gnu" "4.57.1" + "@rollup/rollup-linux-ppc64-musl" "4.57.1" + "@rollup/rollup-linux-riscv64-gnu" "4.57.1" + "@rollup/rollup-linux-riscv64-musl" "4.57.1" + "@rollup/rollup-linux-s390x-gnu" "4.57.1" + "@rollup/rollup-linux-x64-gnu" "4.57.1" + "@rollup/rollup-linux-x64-musl" "4.57.1" + "@rollup/rollup-openbsd-x64" "4.57.1" + "@rollup/rollup-openharmony-arm64" "4.57.1" + "@rollup/rollup-win32-arm64-msvc" "4.57.1" + "@rollup/rollup-win32-ia32-msvc" "4.57.1" + "@rollup/rollup-win32-x64-gnu" "4.57.1" + "@rollup/rollup-win32-x64-msvc" "4.57.1" fsevents "~2.3.2" rou3@^0.7.10: @@ -16070,7 +16110,7 @@ warning@^4.0.0: dependencies: loose-envify "^1.0.0" -watchpack@^2.4.4: +watchpack@^2.5.1: version "2.5.1" resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-2.5.1.tgz#dd38b601f669e0cbf567cb802e75cead82cde102" integrity sha512-Zn5uXdcFNIA1+1Ei5McRd+iRzfhENPCe7LeABkJtNulSxjma+l7ltNx55BWZkRlwRnpOgHqxnjyaDgJnNXnqzg== @@ -16193,9 +16233,9 @@ webpack-virtual-modules@^0.5.0: integrity sha512-kyDivFZ7ZM0BVOUteVbDFhlRt7Ah/CSPwJdi8hBpkK7QLumUqdLtVfm/PX/hkcnrvr0i77fO5+TjZ94Pe+C9iw== webpack@^5.88.1, webpack@^5.95.0: - version "5.104.1" - resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.104.1.tgz#94bd41eb5dbf06e93be165ba8be41b8260d4fb1a" - integrity sha512-Qphch25abbMNtekmEGJmeRUhLDbe+QfiWTiqpKYkpCOWY64v9eyl+KRRLmqOFA2AvKPpc9DC6+u2n76tQLBoaA== + version "5.105.0" + resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.105.0.tgz#38b5e6c5db8cbe81debbd16e089335ada05ea23a" + integrity sha512-gX/dMkRQc7QOMzgTe6KsYFM7DxeIONQSui1s0n/0xht36HvrgbxtM1xBlgx596NbpHuQU8P7QpKwrZYwUX48nw== dependencies: "@types/eslint-scope" "^3.7.7" "@types/estree" "^1.0.8" @@ -16207,7 +16247,7 @@ webpack@^5.88.1, webpack@^5.95.0: acorn-import-phases "^1.0.3" browserslist "^4.28.1" chrome-trace-event "^1.0.2" - enhanced-resolve "^5.17.4" + enhanced-resolve "^5.19.0" es-module-lexer "^2.0.0" eslint-scope "5.1.1" events "^3.2.0" @@ -16220,7 +16260,7 @@ webpack@^5.88.1, webpack@^5.95.0: schema-utils "^4.3.3" tapable "^2.3.0" terser-webpack-plugin "^5.3.16" - watchpack "^2.4.4" + watchpack "^2.5.1" webpack-sources "^3.3.3" webpackbar@^6.0.1: