@lofcz/pptist 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +661 -0
- package/README.md +260 -0
- package/dist/embed/favicon.ico +0 -0
- package/dist/embed/fonts/AlibabaPuHuiTi.woff2 +0 -0
- package/dist/embed/fonts/CangerXiaowanzi.woff2 +0 -0
- package/dist/embed/fonts/DeYiHei.woff2 +0 -0
- package/dist/embed/fonts/FengguangMingrui.woff2 +0 -0
- package/dist/embed/fonts/Inter.woff2 +0 -0
- package/dist/embed/fonts/JetBrainsMono.woff2 +0 -0
- package/dist/embed/fonts/LXGWWenKai.woff2 +0 -0
- package/dist/embed/fonts/Literata.woff2 +0 -0
- package/dist/embed/fonts/Merriweather.woff2 +0 -0
- package/dist/embed/fonts/MiSans.woff2 +0 -0
- package/dist/embed/fonts/Montserrat.woff2 +0 -0
- package/dist/embed/fonts/OpenSans.woff2 +0 -0
- package/dist/embed/fonts/Roboto.woff2 +0 -0
- package/dist/embed/fonts/RuiziZhenyan.woff2 +0 -0
- package/dist/embed/fonts/ShetuModernSquare.woff2 +0 -0
- package/dist/embed/fonts/SourceHanSans.woff2 +0 -0
- package/dist/embed/fonts/SourceHanSerif.woff2 +0 -0
- package/dist/embed/fonts/SourceSansPro.woff2 +0 -0
- package/dist/embed/fonts/SourceSerif4.woff2 +0 -0
- package/dist/embed/fonts/SucaiJishiCoolSquare.woff2 +0 -0
- package/dist/embed/fonts/SucaiJishiKangkang.woff2 +0 -0
- package/dist/embed/fonts/TuniuRounded.woff2 +0 -0
- package/dist/embed/fonts/WenDingPLKaiTi.woff2 +0 -0
- package/dist/embed/fonts/WenDingPLSongTi.woff2 +0 -0
- package/dist/embed/fonts/YousheTitleBlack.woff2 +0 -0
- package/dist/embed/fonts/ZcoolHappy.woff2 +0 -0
- package/dist/embed/fonts/ZhuQueFangSong.woff2 +0 -0
- package/dist/embed/fonts/ZizhiQuXiMai.woff2 +0 -0
- package/dist/embed/imgs/template_1.webp +0 -0
- package/dist/embed/imgs/template_2.webp +0 -0
- package/dist/embed/imgs/template_3.webp +0 -0
- package/dist/embed/imgs/template_4.webp +0 -0
- package/dist/embed/imgs/template_5.webp +0 -0
- package/dist/embed/imgs/template_6.webp +0 -0
- package/dist/embed/imgs/template_7.webp +0 -0
- package/dist/embed/imgs/template_8.webp +0 -0
- package/dist/embed/logo.png +0 -0
- package/dist/embed/mocks/AIPPT.json +475 -0
- package/dist/embed/mocks/AIPPT_Outline.md +69 -0
- package/dist/embed/mocks/imgs.json +482 -0
- package/dist/embed/mocks/slides.json +184 -0
- package/dist/embed/mocks/template_1.json +1 -0
- package/dist/embed/mocks/template_2.json +1 -0
- package/dist/embed/mocks/template_3.json +1 -0
- package/dist/embed/mocks/template_4.json +1 -0
- package/dist/embed/mocks/template_5.json +1 -0
- package/dist/embed/mocks/template_6.json +1 -0
- package/dist/embed/mocks/template_7.json +1 -0
- package/dist/embed/mocks/template_8.json +1 -0
- package/dist/embed/pptist-embed.css +2 -0
- package/dist/embed/pptist-embed.js +112091 -0
- package/dist/types/App.vue.d.ts +3 -0
- package/dist/types/components/Button.vue.d.ts +32 -0
- package/dist/types/components/ButtonGroup.vue.d.ts +18 -0
- package/dist/types/components/ChartDataEditor.vue.d.ts +20 -0
- package/dist/types/components/Checkbox.vue.d.ts +23 -0
- package/dist/types/components/CheckboxButton.vue.d.ts +20 -0
- package/dist/types/components/ColorButton.vue.d.ts +6 -0
- package/dist/types/components/ColorListButton.vue.d.ts +6 -0
- package/dist/types/components/ColorPicker/Alpha.vue.d.ts +11 -0
- package/dist/types/components/ColorPicker/Checkboard.vue.d.ts +12 -0
- package/dist/types/components/ColorPicker/EditableInput.vue.d.ts +11 -0
- package/dist/types/components/ColorPicker/Hue.vue.d.ts +12 -0
- package/dist/types/components/ColorPicker/Saturation.vue.d.ts +12 -0
- package/dist/types/components/ColorPicker/index.vue.d.ts +12 -0
- package/dist/types/components/Contextmenu/MenuContent.vue.d.ts +8 -0
- package/dist/types/components/Contextmenu/index.vue.d.ts +10 -0
- package/dist/types/components/Contextmenu/types.d.ts +13 -0
- package/dist/types/components/Divider.vue.d.ts +10 -0
- package/dist/types/components/Drawer.vue.d.ts +29 -0
- package/dist/types/components/FileInput.vue.d.ts +22 -0
- package/dist/types/components/FullscreenSpin.vue.d.ts +12 -0
- package/dist/types/components/GradientBar.vue.d.ts +14 -0
- package/dist/types/components/ImageWaterfallViewer.vue.d.ts +36 -0
- package/dist/types/components/Input.vue.d.ts +44 -0
- package/dist/types/components/LaTeXEditor/FormulaContent.vue.d.ts +8 -0
- package/dist/types/components/LaTeXEditor/SymbolContent.vue.d.ts +6 -0
- package/dist/types/components/LaTeXEditor/hfmath.d.ts +2 -0
- package/dist/types/components/LaTeXEditor/index.vue.d.ts +20 -0
- package/dist/types/components/Message.vue.d.ts +24 -0
- package/dist/types/components/Modal.vue.d.ts +34 -0
- package/dist/types/components/MoveablePanel.vue.d.ts +44 -0
- package/dist/types/components/NumberInput.vue.d.ts +43 -0
- package/dist/types/components/OutlineEditor.vue.d.ts +10 -0
- package/dist/types/components/Popover.vue.d.ts +41 -0
- package/dist/types/components/PopoverMenuItem.vue.d.ts +22 -0
- package/dist/types/components/RadioButton.vue.d.ts +19 -0
- package/dist/types/components/RadioGroup.vue.d.ts +23 -0
- package/dist/types/components/Select.vue.d.ts +38 -0
- package/dist/types/components/SelectCustom.vue.d.ts +26 -0
- package/dist/types/components/SelectGroup.vue.d.ts +13 -0
- package/dist/types/components/Slider.vue.d.ts +21 -0
- package/dist/types/components/Switch.vue.d.ts +13 -0
- package/dist/types/components/Tabs.vue.d.ts +27 -0
- package/dist/types/components/TextArea.vue.d.ts +28 -0
- package/dist/types/components/TextColorButton.vue.d.ts +16 -0
- package/dist/types/components/WritingBoard.vue.d.ts +30 -0
- package/dist/types/configs/animation.d.ts +34 -0
- package/dist/types/configs/chart.d.ts +4 -0
- package/dist/types/configs/element.d.ts +2 -0
- package/dist/types/configs/font.d.ts +4 -0
- package/dist/types/configs/hotkey.d.ts +41 -0
- package/dist/types/configs/imageClip.d.ts +25 -0
- package/dist/types/configs/latex.d.ts +11 -0
- package/dist/types/configs/lines.d.ts +16 -0
- package/dist/types/configs/mime.d.ts +1 -0
- package/dist/types/configs/shapes.d.ts +27 -0
- package/dist/types/configs/storage.d.ts +1 -0
- package/dist/types/configs/symbol.d.ts +7 -0
- package/dist/types/configs/theme.d.ts +11 -0
- package/dist/types/directive/clickOutside.d.ts +3 -0
- package/dist/types/directive/contextmenu.d.ts +3 -0
- package/dist/types/directive/index.d.ts +5 -0
- package/dist/types/directive/loading.d.ts +4 -0
- package/dist/types/directive/tooltip.d.ts +4 -0
- package/dist/types/embed/EmbedRoot.vue.d.ts +7 -0
- package/dist/types/embed/agentic/createAgenticApi.d.ts +12 -0
- package/dist/types/embed/agentic/fixtures.d.ts +28 -0
- package/dist/types/embed/agentic/helpers.d.ts +99 -0
- package/dist/types/embed/agentic/types.d.ts +1786 -0
- package/dist/types/embed/agentic/validators.d.ts +20 -0
- package/dist/types/embed/createController.d.ts +7 -0
- package/dist/types/embed/index.d.ts +5 -0
- package/dist/types/embed/localeBridge.d.ts +4 -0
- package/dist/types/embed/mount.d.ts +12 -0
- package/dist/types/embed/types.d.ts +44 -0
- package/dist/types/hooks/useAIPPT.d.ts +14 -0
- package/dist/types/hooks/useAddSlidesOrElements.d.ts +6 -0
- package/dist/types/hooks/useAlignActiveElement.d.ts +5 -0
- package/dist/types/hooks/useAlignElementToCanvas.d.ts +5 -0
- package/dist/types/hooks/useCombineElement.d.ts +6 -0
- package/dist/types/hooks/useCopyAndPasteElement.d.ts +7 -0
- package/dist/types/hooks/useCreateElement.d.ts +36 -0
- package/dist/types/hooks/useDeleteElement.d.ts +5 -0
- package/dist/types/hooks/useExport.d.ts +10 -0
- package/dist/types/hooks/useGlobalHotkey.d.ts +2 -0
- package/dist/types/hooks/useHideElement.d.ts +6 -0
- package/dist/types/hooks/useHistorySnapshot.d.ts +6 -0
- package/dist/types/hooks/useImageHandler.d.ts +4 -0
- package/dist/types/hooks/useImport.d.ts +10 -0
- package/dist/types/hooks/useLink.d.ts +6 -0
- package/dist/types/hooks/useLoadSlides.d.ts +4 -0
- package/dist/types/hooks/useLockElement.d.ts +6 -0
- package/dist/types/hooks/useMoveElement.d.ts +4 -0
- package/dist/types/hooks/useOrderElement.d.ts +6 -0
- package/dist/types/hooks/usePasteDataTransfer.d.ts +7 -0
- package/dist/types/hooks/usePasteEvent.d.ts +2 -0
- package/dist/types/hooks/usePasteTextClipboardData.d.ts +8 -0
- package/dist/types/hooks/useScaleCanvas.d.ts +7 -0
- package/dist/types/hooks/useScreening.d.ts +6 -0
- package/dist/types/hooks/useSearch.d.ts +44 -0
- package/dist/types/hooks/useSectionHandler.d.ts +8 -0
- package/dist/types/hooks/useSelectElement.d.ts +5 -0
- package/dist/types/hooks/useShapeFormatPainter.d.ts +4 -0
- package/dist/types/hooks/useSlideBackgroundStyle.d.ts +21 -0
- package/dist/types/hooks/useSlideHandler.d.ts +16 -0
- package/dist/types/hooks/useSlideTheme.d.ts +14 -0
- package/dist/types/hooks/useTextFormatPainter.d.ts +4 -0
- package/dist/types/hooks/useUniformDisplayElement.d.ts +6 -0
- package/dist/types/i18n/cs/canvas/index.d.ts +3 -0
- package/dist/types/i18n/cs/common/index.d.ts +3 -0
- package/dist/types/i18n/cs/components/index.d.ts +3 -0
- package/dist/types/i18n/cs/configs/index.d.ts +3 -0
- package/dist/types/i18n/cs/editor/index.d.ts +3 -0
- package/dist/types/i18n/cs/export/index.d.ts +3 -0
- package/dist/types/i18n/cs/index.d.ts +3 -0
- package/dist/types/i18n/cs/mobile/index.d.ts +3 -0
- package/dist/types/i18n/cs/screen/index.d.ts +3 -0
- package/dist/types/i18n/en/canvas/index.d.ts +3 -0
- package/dist/types/i18n/en/common/index.d.ts +3 -0
- package/dist/types/i18n/en/components/index.d.ts +3 -0
- package/dist/types/i18n/en/configs/index.d.ts +3 -0
- package/dist/types/i18n/en/editor/index.d.ts +3 -0
- package/dist/types/i18n/en/export/index.d.ts +3 -0
- package/dist/types/i18n/en/index.d.ts +3 -0
- package/dist/types/i18n/en/mobile/index.d.ts +3 -0
- package/dist/types/i18n/en/screen/index.d.ts +3 -0
- package/dist/types/i18n/formatters.d.ts +6 -0
- package/dist/types/i18n/getLL.d.ts +8 -0
- package/dist/types/i18n/i18n-types.d.ts +8863 -0
- package/dist/types/i18n/i18n-util.async.d.ts +16 -0
- package/dist/types/i18n/i18n-util.d.ts +24 -0
- package/dist/types/i18n/i18n-util.sync.d.ts +4 -0
- package/dist/types/i18n/i18n-vue.d.ts +9 -0
- package/dist/types/i18n/locale.d.ts +12 -0
- package/dist/types/i18n/pl/canvas/index.d.ts +3 -0
- package/dist/types/i18n/pl/common/index.d.ts +3 -0
- package/dist/types/i18n/pl/components/index.d.ts +3 -0
- package/dist/types/i18n/pl/configs/index.d.ts +3 -0
- package/dist/types/i18n/pl/editor/index.d.ts +3 -0
- package/dist/types/i18n/pl/export/index.d.ts +3 -0
- package/dist/types/i18n/pl/index.d.ts +3 -0
- package/dist/types/i18n/pl/mobile/index.d.ts +3 -0
- package/dist/types/i18n/pl/screen/index.d.ts +3 -0
- package/dist/types/i18n/sk/canvas/index.d.ts +3 -0
- package/dist/types/i18n/sk/common/index.d.ts +3 -0
- package/dist/types/i18n/sk/components/index.d.ts +3 -0
- package/dist/types/i18n/sk/configs/index.d.ts +3 -0
- package/dist/types/i18n/sk/editor/index.d.ts +3 -0
- package/dist/types/i18n/sk/export/index.d.ts +3 -0
- package/dist/types/i18n/sk/index.d.ts +3 -0
- package/dist/types/i18n/sk/mobile/index.d.ts +3 -0
- package/dist/types/i18n/sk/screen/index.d.ts +3 -0
- package/dist/types/i18n/useI18nContext.d.ts +9 -0
- package/dist/types/langs/en.d.ts +854 -0
- package/dist/types/langs/zh-CN.d.ts +826 -0
- package/dist/types/main.d.ts +5 -0
- package/dist/types/services/axios.d.ts +2 -0
- package/dist/types/services/fetch.d.ts +2 -0
- package/dist/types/services/index.d.ts +34 -0
- package/dist/types/store/index.d.ts +6 -0
- package/dist/types/store/keyboard.d.ts +16 -0
- package/dist/types/store/main.d.ts +919 -0
- package/dist/types/store/screen.d.ts +6 -0
- package/dist/types/store/slides.d.ts +1576 -0
- package/dist/types/store/snapshot.d.ts +21 -0
- package/dist/types/types/AIPPT.d.ts +36 -0
- package/dist/types/types/edit.d.ts +111 -0
- package/dist/types/types/export.d.ts +1 -0
- package/dist/types/types/injectKey.d.ts +10 -0
- package/dist/types/types/mobile.d.ts +1 -0
- package/dist/types/types/slides.d.ts +744 -0
- package/dist/types/types/toolbar.d.ts +9 -0
- package/dist/types/utils/clipboard.d.ts +9 -0
- package/dist/types/utils/common.d.ts +22 -0
- package/dist/types/utils/crypto.d.ts +10 -0
- package/dist/types/utils/database.d.ts +17 -0
- package/dist/types/utils/element.d.ts +304 -0
- package/dist/types/utils/emitter.d.ts +23 -0
- package/dist/types/utils/font.d.ts +1 -0
- package/dist/types/utils/fullscreen.d.ts +3 -0
- package/dist/types/utils/htmlParser/format.d.ts +3 -0
- package/dist/types/utils/htmlParser/index.d.ts +4 -0
- package/dist/types/utils/htmlParser/lexer.d.ts +2 -0
- package/dist/types/utils/htmlParser/parser.d.ts +15 -0
- package/dist/types/utils/htmlParser/stringify.d.ts +3 -0
- package/dist/types/utils/htmlParser/tags.d.ts +4 -0
- package/dist/types/utils/htmlParser/types.d.ts +55 -0
- package/dist/types/utils/image.d.ts +25 -0
- package/dist/types/utils/message.d.ts +28 -0
- package/dist/types/utils/portal.d.ts +5 -0
- package/dist/types/utils/print.d.ts +7 -0
- package/dist/types/utils/prosemirror/commands/replaceText.d.ts +2 -0
- package/dist/types/utils/prosemirror/commands/setListStyle.d.ts +4 -0
- package/dist/types/utils/prosemirror/commands/setTextAlign.d.ts +5 -0
- package/dist/types/utils/prosemirror/commands/setTextIndent.d.ts +3 -0
- package/dist/types/utils/prosemirror/commands/toggleList.d.ts +8 -0
- package/dist/types/utils/prosemirror/index.d.ts +4 -0
- package/dist/types/utils/prosemirror/plugins/index.d.ts +10 -0
- package/dist/types/utils/prosemirror/plugins/inputrules.d.ts +7 -0
- package/dist/types/utils/prosemirror/plugins/keymap.d.ts +3 -0
- package/dist/types/utils/prosemirror/plugins/placeholder.d.ts +2 -0
- package/dist/types/utils/prosemirror/schema/index.d.ts +25 -0
- package/dist/types/utils/prosemirror/schema/marks.d.ts +18 -0
- package/dist/types/utils/prosemirror/schema/nodes.d.ts +11 -0
- package/dist/types/utils/prosemirror/utils.d.ts +69 -0
- package/dist/types/utils/selection.d.ts +1 -0
- package/dist/types/utils/svg2Base64.d.ts +1 -0
- package/dist/types/utils/svgPathParser.d.ts +39 -0
- package/dist/types/utils/textParser.d.ts +5 -0
- package/dist/types/views/Editor/AIPPTDialog.vue.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/AlignmentLine.vue.d.ts +10 -0
- package/dist/types/views/Editor/Canvas/EditableElement.vue.d.ts +11 -0
- package/dist/types/views/Editor/Canvas/ElementCreateSelection.vue.d.ts +8 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/AnimationIndex.vue.d.ts +10 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/BorderPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/ChartToolbar.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/ImageToolbar.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/LatexToolbar.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/LineToolbar.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/ShapeToolbar.vue.d.ts +11 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/TableToolbar.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/TextStyleControls.vue.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/TextToolbar.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/FloatingToolbar/index.vue.d.ts +12 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/LinkHandler.vue.d.ts +9 -0
- package/dist/types/views/Editor/Canvas/ElementFloatLayer/index.vue.d.ts +11 -0
- package/dist/types/views/Editor/Canvas/GridLines.vue.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/LinkDialog.vue.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/MouseSelection.vue.d.ts +10 -0
- package/dist/types/views/Editor/Canvas/Operate/BorderLine.vue.d.ts +10 -0
- package/dist/types/views/Editor/Canvas/Operate/CommonElementOperate.vue.d.ts +15 -0
- package/dist/types/views/Editor/Canvas/Operate/ImageElementOperate.vue.d.ts +15 -0
- package/dist/types/views/Editor/Canvas/Operate/LineElementOperate.vue.d.ts +13 -0
- package/dist/types/views/Editor/Canvas/Operate/MultiSelectOperate.vue.d.ts +10 -0
- package/dist/types/views/Editor/Canvas/Operate/ResizeHandler.vue.d.ts +10 -0
- package/dist/types/views/Editor/Canvas/Operate/RotateHandler.vue.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/Operate/ShapeElementOperate.vue.d.ts +17 -0
- package/dist/types/views/Editor/Canvas/Operate/TableElementOperate.vue.d.ts +15 -0
- package/dist/types/views/Editor/Canvas/Operate/TextElementOperate.vue.d.ts +15 -0
- package/dist/types/views/Editor/Canvas/Operate/index.vue.d.ts +16 -0
- package/dist/types/views/Editor/Canvas/Ruler.vue.d.ts +14 -0
- package/dist/types/views/Editor/Canvas/ShapeCreateCanvas.vue.d.ts +8 -0
- package/dist/types/views/Editor/Canvas/ViewportBackground.vue.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/hooks/useCommonOperate.d.ts +89 -0
- package/dist/types/views/Editor/Canvas/hooks/useDragElement.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/hooks/useDragLineElement.d.ts +7 -0
- package/dist/types/views/Editor/Canvas/hooks/useDrop.d.ts +3 -0
- package/dist/types/views/Editor/Canvas/hooks/useInsertFromCreateSelection.d.ts +12 -0
- package/dist/types/views/Editor/Canvas/hooks/useMouseSelection.d.ts +24 -0
- package/dist/types/views/Editor/Canvas/hooks/useMoveShapeKeypoint.d.ts +6 -0
- package/dist/types/views/Editor/Canvas/hooks/useRotateElement.d.ts +6 -0
- package/dist/types/views/Editor/Canvas/hooks/useRotateGroupElement.d.ts +6 -0
- package/dist/types/views/Editor/Canvas/hooks/useScaleElement.d.ts +8 -0
- package/dist/types/views/Editor/Canvas/hooks/useSelectElement.d.ts +6 -0
- package/dist/types/views/Editor/Canvas/hooks/useViewportSize.d.ts +11 -0
- package/dist/types/views/Editor/Canvas/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/CanvasTool/ChartPool.vue.d.ts +8 -0
- package/dist/types/views/Editor/CanvasTool/LinePool.vue.d.ts +8 -0
- package/dist/types/views/Editor/CanvasTool/MediaInput.vue.d.ts +23 -0
- package/dist/types/views/Editor/CanvasTool/ShapeItemThumbnail.vue.d.ts +7 -0
- package/dist/types/views/Editor/CanvasTool/ShapePool.vue.d.ts +8 -0
- package/dist/types/views/Editor/CanvasTool/TableGenerator.vue.d.ts +13 -0
- package/dist/types/views/Editor/CanvasTool/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/ChartDataEditorDialog.vue.d.ts +3 -0
- package/dist/types/views/Editor/EditorHeader/HotkeyDoc.vue.d.ts +3 -0
- package/dist/types/views/Editor/EditorHeader/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/ExportDialog/ExportImage.vue.d.ts +7 -0
- package/dist/types/views/Editor/ExportDialog/ExportJSON.vue.d.ts +7 -0
- package/dist/types/views/Editor/ExportDialog/ExportPDF.vue.d.ts +7 -0
- package/dist/types/views/Editor/ExportDialog/ExportPPTX.vue.d.ts +7 -0
- package/dist/types/views/Editor/ExportDialog/ExportSpecificFile.vue.d.ts +7 -0
- package/dist/types/views/Editor/ExportDialog/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/ImageLibPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/LatexEditorDialog.vue.d.ts +3 -0
- package/dist/types/views/Editor/MarkupPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/NotesPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Remark/Editor.vue.d.ts +10 -0
- package/dist/types/views/Editor/Remark/index.vue.d.ts +10 -0
- package/dist/types/views/Editor/SearchPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/SelectPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/SymbolPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Thumbnails/Templates.vue.d.ts +16 -0
- package/dist/types/views/Editor/Thumbnails/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementAnimationPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementPositionPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/AudioStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/ChartStylePanel/ThemeColorsSetting.vue.d.ts +10 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/ChartStylePanel/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/ImageStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/LatexStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/LineStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/ShapeStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/TableStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/TextStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/VideoStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/ElementStylePanel/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/MultiPositionPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/MultiStylePanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/SlideAnimationPanel.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/SlideDesignPanel/ThemeColorsSetting.vue.d.ts +7 -0
- package/dist/types/views/Editor/Toolbar/SlideDesignPanel/ThemeStylesExtract.vue.d.ts +7 -0
- package/dist/types/views/Editor/Toolbar/SlideDesignPanel/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/ElementColorMask.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/ElementFilter.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/ElementFlip.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/ElementOpacity.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/ElementOutline.vue.d.ts +8 -0
- package/dist/types/views/Editor/Toolbar/common/ElementShadow.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/RichTextBase.vue.d.ts +3 -0
- package/dist/types/views/Editor/Toolbar/common/SVGLine.vue.d.ts +15 -0
- package/dist/types/views/Editor/Toolbar/index.vue.d.ts +3 -0
- package/dist/types/views/Editor/index.vue.d.ts +3 -0
- package/dist/types/views/Mobile/MobileEditor/ElementToolbar.vue.d.ts +3 -0
- package/dist/types/views/Mobile/MobileEditor/Header.vue.d.ts +7 -0
- package/dist/types/views/Mobile/MobileEditor/MobileEditableElement.vue.d.ts +9 -0
- package/dist/types/views/Mobile/MobileEditor/MobileOperate.vue.d.ts +13 -0
- package/dist/types/views/Mobile/MobileEditor/SlideToolbar.vue.d.ts +3 -0
- package/dist/types/views/Mobile/MobileEditor/index.vue.d.ts +7 -0
- package/dist/types/views/Mobile/MobilePlayer.vue.d.ts +7 -0
- package/dist/types/views/Mobile/MobilePreview.vue.d.ts +7 -0
- package/dist/types/views/Mobile/MobileThumbnails.vue.d.ts +3 -0
- package/dist/types/views/Mobile/index.vue.d.ts +3 -0
- package/dist/types/views/Screen/AudienceView.vue.d.ts +3 -0
- package/dist/types/views/Screen/BaseView.vue.d.ts +6 -0
- package/dist/types/views/Screen/BottomThumbnails.vue.d.ts +3 -0
- package/dist/types/views/Screen/CountdownTimer.vue.d.ts +14 -0
- package/dist/types/views/Screen/PresenterView.vue.d.ts +6 -0
- package/dist/types/views/Screen/ScreenElement.vue.d.ts +11 -0
- package/dist/types/views/Screen/ScreenSlide.vue.d.ts +11 -0
- package/dist/types/views/Screen/ScreenSlideList.vue.d.ts +10 -0
- package/dist/types/views/Screen/SlideThumbnails.vue.d.ts +10 -0
- package/dist/types/views/Screen/WritingBoardTool.vue.d.ts +16 -0
- package/dist/types/views/Screen/hooks/useExecPlay.d.ts +23 -0
- package/dist/types/views/Screen/hooks/useFullscreen.d.ts +5 -0
- package/dist/types/views/Screen/hooks/useSlideSize.d.ts +6 -0
- package/dist/types/views/Screen/hooks/useSlidesWithTurningMode.d.ts +14 -0
- package/dist/types/views/Screen/index.vue.d.ts +3 -0
- package/dist/types/views/components/ThumbnailSlide/ThumbnailElement.vue.d.ts +8 -0
- package/dist/types/views/components/ThumbnailSlide/index.vue.d.ts +11 -0
- package/dist/types/views/components/element/AudioElement/AudioPlayer.vue.d.ts +14 -0
- package/dist/types/views/components/element/AudioElement/BaseAudioElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/AudioElement/ScreenAudioElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/AudioElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/ChartElement/BaseChartElement.vue.d.ts +8 -0
- package/dist/types/views/components/element/ChartElement/Chart.vue.d.ts +14 -0
- package/dist/types/views/components/element/ChartElement/chartOption.d.ts +15 -0
- package/dist/types/views/components/element/ChartElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/ElementOutline.vue.d.ts +9 -0
- package/dist/types/views/components/element/ImageElement/BaseImageElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/ImageElement/ImageClipHandler.vue.d.ts +19 -0
- package/dist/types/views/components/element/ImageElement/ImageOutline/ImageEllipseOutline.vue.d.ts +9 -0
- package/dist/types/views/components/element/ImageElement/ImageOutline/ImagePolygonOutline.vue.d.ts +10 -0
- package/dist/types/views/components/element/ImageElement/ImageOutline/ImageRectOutline.vue.d.ts +12 -0
- package/dist/types/views/components/element/ImageElement/ImageOutline/index.vue.d.ts +7 -0
- package/dist/types/views/components/element/ImageElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/ImageElement/useClipImage.d.ts +19 -0
- package/dist/types/views/components/element/ImageElement/useFilter.d.ts +6 -0
- package/dist/types/views/components/element/LatexElement/BaseLatexElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/LatexElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/LineElement/BaseLineElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/LineElement/LinePointMarker.vue.d.ts +13 -0
- package/dist/types/views/components/element/LineElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/ProsemirrorEditor.vue.d.ts +32 -0
- package/dist/types/views/components/element/ShapeElement/BaseShapeElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/ShapeElement/GradientDefs.vue.d.ts +12 -0
- package/dist/types/views/components/element/ShapeElement/PatternDefs.vue.d.ts +7 -0
- package/dist/types/views/components/element/ShapeElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/TableElement/BaseTableElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/TableElement/CustomTextarea.vue.d.ts +14 -0
- package/dist/types/views/components/element/TableElement/EditableTable.vue.d.ts +23 -0
- package/dist/types/views/components/element/TableElement/StaticTable.vue.d.ts +15 -0
- package/dist/types/views/components/element/TableElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/TableElement/useHideCells.d.ts +6 -0
- package/dist/types/views/components/element/TableElement/useSubThemeColor.d.ts +6 -0
- package/dist/types/views/components/element/TableElement/utils.d.ts +11 -0
- package/dist/types/views/components/element/TextElement/BaseTextElement.vue.d.ts +8 -0
- package/dist/types/views/components/element/TextElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/VideoElement/BaseVideoElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/VideoElement/ScreenVideoElement.vue.d.ts +7 -0
- package/dist/types/views/components/element/VideoElement/VideoPlayer/index.vue.d.ts +15 -0
- package/dist/types/views/components/element/VideoElement/VideoPlayer/useMSE.d.ts +3 -0
- package/dist/types/views/components/element/VideoElement/index.vue.d.ts +10 -0
- package/dist/types/views/components/element/hooks/useElementFill.d.ts +6 -0
- package/dist/types/views/components/element/hooks/useElementFlip.d.ts +5 -0
- package/dist/types/views/components/element/hooks/useElementOutline.d.ts +9 -0
- package/dist/types/views/components/element/hooks/useElementShadow.d.ts +6 -0
- package/docs/AGENTIC_BRIDGE.md +513 -0
- package/docs/EMBED.md +307 -0
- package/docs/RELEASE.md +47 -0
- package/package.json +127 -0
|
@@ -0,0 +1,513 @@
|
|
|
1
|
+
# PPTist Agentic Bridge
|
|
2
|
+
|
|
3
|
+
PPTist exposes a typed agentic bridge through `@lofcz/pptist/embed`. The bridge is for host agents that need deterministic CRUD over decks, slides, elements, animations, tables, charts, notes, search, and presentation state without reaching into Pinia internals.
|
|
4
|
+
|
|
5
|
+
This document is the style guide for the bridge contract. The canonical command types are the registered `execute()` commands in `src/embed/agentic/createAgenticApi.ts`; typed domain methods are convenience wrappers over the same command model when a wrapper exists.
|
|
6
|
+
|
|
7
|
+
## Public Surface
|
|
8
|
+
|
|
9
|
+
The public controller keeps the legacy imperative methods:
|
|
10
|
+
|
|
11
|
+
```ts
|
|
12
|
+
controller.getDocument()
|
|
13
|
+
controller.setDocument(document)
|
|
14
|
+
controller.setTitle(title)
|
|
15
|
+
controller.setLocale(locale)
|
|
16
|
+
controller.enterPresentation()
|
|
17
|
+
controller.exitPresentation()
|
|
18
|
+
controller.destroy()
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
The agentic surface adds command execution, state, events, and domain wrappers:
|
|
22
|
+
|
|
23
|
+
```ts
|
|
24
|
+
controller.getState()
|
|
25
|
+
controller.execute({ id: 'cmd_1', type: 'slides.create', payload: { slide } })
|
|
26
|
+
controller.executeBatch(commands, { atomic: true })
|
|
27
|
+
controller.canExecute(command)
|
|
28
|
+
controller.subscribe(event => {})
|
|
29
|
+
|
|
30
|
+
controller.deck.*
|
|
31
|
+
controller.slides.*
|
|
32
|
+
controller.elements.*
|
|
33
|
+
controller.element.*
|
|
34
|
+
controller.animations.*
|
|
35
|
+
controller.tables.*
|
|
36
|
+
controller.charts.*
|
|
37
|
+
controller.media.*
|
|
38
|
+
controller.links.*
|
|
39
|
+
controller.notes.*
|
|
40
|
+
controller.sections.*
|
|
41
|
+
controller.search.*
|
|
42
|
+
controller.history.*
|
|
43
|
+
controller.view.*
|
|
44
|
+
controller.import.*
|
|
45
|
+
controller.export.*
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
Use domain wrappers for common flows. Use `execute()` for command-only operations that are registered but do not yet have a wrapper method.
|
|
49
|
+
|
|
50
|
+
## API Naming
|
|
51
|
+
|
|
52
|
+
Command names use `domain.action` with lower-camel-case actions:
|
|
53
|
+
|
|
54
|
+
```ts
|
|
55
|
+
type PptistCommandType = `${string}.${string}`
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
Canonical domains are `deck`, `import`, `export`, `slides`, `elements`, `animations`, `tables`, `charts`, `notes`, `sections`, `search`, `history`, and `view`.
|
|
59
|
+
|
|
60
|
+
Naming rules:
|
|
61
|
+
|
|
62
|
+
- Use plural collection domains: `slides`, `elements`, `animations`, `tables`, `charts`, `notes`, `sections`.
|
|
63
|
+
- Use singular state domains when there is only one target: `deck`, `history`, `view`.
|
|
64
|
+
- Use `create`, `get`, `list`, `update`, `delete`, `duplicate`, `move`, `select`, and `reorder` for common CRUD and ordering operations.
|
|
65
|
+
- Use `setX` when replacing a named property, for example `deck.setTitle`, `slides.setBackground`, `charts.setType`.
|
|
66
|
+
- Use `applyX` when one payload is applied to multiple targets, for example `slides.applyBackground`.
|
|
67
|
+
- Use `patch` only for broad document-level patching, currently `deck.patch`.
|
|
68
|
+
- Use stable payload field names: `slideId`, `elementId`, `animationId`, `noteId`, `sectionId`, `toIndex`, `row`, `col`, `patch`, and `options`.
|
|
69
|
+
- Keep command types stable. Add new behavior under a new `domain.action` rather than changing the meaning of an existing action.
|
|
70
|
+
|
|
71
|
+
## Command Envelope
|
|
72
|
+
|
|
73
|
+
Every executable command uses this JSON-serializable envelope:
|
|
74
|
+
|
|
75
|
+
```ts
|
|
76
|
+
interface PptistAgentCommand<TPayload = unknown> {
|
|
77
|
+
id?: string
|
|
78
|
+
type: PptistCommandType
|
|
79
|
+
payload?: TPayload
|
|
80
|
+
meta?: {
|
|
81
|
+
commit?: boolean
|
|
82
|
+
dryRun?: boolean
|
|
83
|
+
source?: 'agent' | 'host' | 'ui'
|
|
84
|
+
label?: string
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
`id` is caller-owned and optional. Provide it when the host needs to correlate logs, events, retries, or a batch result. The bridge returns it as `commandId`; it does not use the command ID as a deck, slide, or element ID.
|
|
90
|
+
|
|
91
|
+
`meta.source` and `meta.label` are descriptive metadata for hosts and future event consumers. `meta.commit` and `meta.dryRun` affect execution:
|
|
92
|
+
|
|
93
|
+
- `commit: false` suppresses the per-command history snapshot.
|
|
94
|
+
- `dryRun: true` runs validation through the handler, restores the prior document, returns `changed: false`, and does not increment `documentVersion`.
|
|
95
|
+
- Batch-level `dryRun` overrides individual command dry runs for that batch.
|
|
96
|
+
|
|
97
|
+
## Result Contract
|
|
98
|
+
|
|
99
|
+
Every `execute()` command and domain wrapper that mutates through the command layer resolves to a JSON-serializable result:
|
|
100
|
+
|
|
101
|
+
```ts
|
|
102
|
+
interface PptistCommandResult<TData = unknown> {
|
|
103
|
+
ok: boolean
|
|
104
|
+
commandId?: string
|
|
105
|
+
type: PptistCommandType
|
|
106
|
+
changed: boolean
|
|
107
|
+
documentVersion: number
|
|
108
|
+
snapshotId?: number
|
|
109
|
+
data?: TData
|
|
110
|
+
errors?: Array<{
|
|
111
|
+
code: string
|
|
112
|
+
message: string
|
|
113
|
+
path?: string
|
|
114
|
+
recoverable?: boolean
|
|
115
|
+
}>
|
|
116
|
+
warnings?: Array<{
|
|
117
|
+
code: string
|
|
118
|
+
message: string
|
|
119
|
+
path?: string
|
|
120
|
+
recoverable?: boolean
|
|
121
|
+
}>
|
|
122
|
+
}
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
Result rules:
|
|
126
|
+
|
|
127
|
+
- `ok: true` means the command handler completed.
|
|
128
|
+
- `ok: false` means the command failed and document state was restored to its pre-command value.
|
|
129
|
+
- `commandId` mirrors the incoming command `id`.
|
|
130
|
+
- `type` always mirrors the incoming command `type`.
|
|
131
|
+
- `changed` is true only when the command changed document or view state and was not a dry run.
|
|
132
|
+
- `documentVersion` increments after successful, non-dry-run changed commands.
|
|
133
|
+
- `snapshotId` is present only when that command created its own history snapshot.
|
|
134
|
+
- `data` contains the command-specific return payload, usually the updated model object or current bridge state.
|
|
135
|
+
- `errors` and `warnings` use machine-readable `code` plus human-readable `message`. `path` should point to the invalid payload field when available.
|
|
136
|
+
|
|
137
|
+
Unsupported command types return `ok: false` with an error. `canExecute(command)` only checks whether the controller is alive and the command type is registered; use `dryRun` for payload-level validation.
|
|
138
|
+
|
|
139
|
+
## Validation Rules
|
|
140
|
+
|
|
141
|
+
Hosts should treat payloads as plain JSON. The bridge clones document data through JSON serialization in several paths, so functions, class instances, DOM nodes, and cyclic objects are invalid inputs.
|
|
142
|
+
|
|
143
|
+
Reference validation:
|
|
144
|
+
|
|
145
|
+
- `slideId`, `elementId`, `animationId`, and `noteId` must refer to existing objects unless the command creates that object.
|
|
146
|
+
- `elements.*` commands search across slides when `slideId` is omitted, and search within `slideId` when it is provided.
|
|
147
|
+
- Table commands require the target element to be `type: 'table'`.
|
|
148
|
+
- Chart commands require the target element to be `type: 'chart'`.
|
|
149
|
+
- Table cell commands require an existing `row` and `col`.
|
|
150
|
+
- Note replies require the target note to exist on the target slide.
|
|
151
|
+
|
|
152
|
+
Creation and ID rules:
|
|
153
|
+
|
|
154
|
+
- Agents may provide deterministic object IDs in create payloads.
|
|
155
|
+
- If an object ID is omitted, the bridge generates one with a type prefix such as `slide_`, `el_`, `anim_`, `note_`, `reply_`, `cell_`, or `group_`.
|
|
156
|
+
- Agents must use the ID returned in `data` for later commands.
|
|
157
|
+
- Do not reuse an ID for a different model object.
|
|
158
|
+
|
|
159
|
+
Index rules:
|
|
160
|
+
|
|
161
|
+
- Insert positions use `index`, `toIndex`, `rowIndex`, or `colIndex`.
|
|
162
|
+
- Non-finite insert indexes append to the end.
|
|
163
|
+
- Insert indexes are truncated to integers and clamped into the valid insertion range.
|
|
164
|
+
- Selection and delete indexes are clamped into the existing range where the underlying model operation supports it.
|
|
165
|
+
|
|
166
|
+
Content rules:
|
|
167
|
+
|
|
168
|
+
- Element create payloads must include `element.type`.
|
|
169
|
+
- Whole-document writes (`deck.set`, `deck.patch`, `import.json`, `import.pptist`, and `import.pptxSafe`) require a JSON-serializable payload with a string `title` and a `slides` array before store state is touched.
|
|
170
|
+
- Text-like content is stored as HTML where the model already expects HTML, for example text element `content`, shape `text.content`, slide `remark`, and note `content`.
|
|
171
|
+
- Slide links should be validated against `slides.list()` before use.
|
|
172
|
+
- DOM-dependent import/export paths remain outside the JSON bridge until they have been converted to a serializable document payload.
|
|
173
|
+
|
|
174
|
+
## Snapshot Policy
|
|
175
|
+
|
|
176
|
+
The bridge maintains a monotonic `documentVersion` and a separate `snapshotId`.
|
|
177
|
+
|
|
178
|
+
- Successful changed commands create one history snapshot by default.
|
|
179
|
+
- Pass `meta: { commit: false }` to suppress a command snapshot.
|
|
180
|
+
- `executeBatch()` runs child commands with `commit: false`, increments `documentVersion` once, and commits one batch snapshot at the end when any child changed state.
|
|
181
|
+
- Batch execution is atomic by default. Any failure restores the pre-batch runtime state, marks already-run changed results with a `BatchRolledBack` warning, and returns `BatchSkipped` errors for commands that were not run.
|
|
182
|
+
- Passing `{ atomic: false }` keeps successful child changes, rolls back only the failed command, continues later commands, and returns the mixed success/failure result list for the caller to inspect.
|
|
183
|
+
- Passing `{ commit: false }` to `executeBatch()` suppresses the final batch snapshot.
|
|
184
|
+
- Passing `{ dryRun: true }` lets commands validate against the staged batch state, then restores the pre-batch runtime state, returns `changed: false`, and creates no snapshot.
|
|
185
|
+
- `history.commit`, `history.undo`, and `history.redo` are command-layer operations and return bridge state.
|
|
186
|
+
|
|
187
|
+
Events emitted through `subscribe()` include `documentChanged`, `selectionChanged`, `commandApplied`, `commandFailed`, and `destroyed`. Command events include the command envelope and result when available.
|
|
188
|
+
|
|
189
|
+
## Examples
|
|
190
|
+
|
|
191
|
+
Create a slide and text element in one atomic snapshot using deterministic IDs:
|
|
192
|
+
|
|
193
|
+
```ts
|
|
194
|
+
const results = await controller.executeBatch([
|
|
195
|
+
{
|
|
196
|
+
id: 'cmd_create_intro_slide',
|
|
197
|
+
type: 'slides.create',
|
|
198
|
+
payload: {
|
|
199
|
+
slide: {
|
|
200
|
+
id: 'slide_intro',
|
|
201
|
+
elements: [],
|
|
202
|
+
background: { type: 'solid', color: '#fff' },
|
|
203
|
+
},
|
|
204
|
+
select: true,
|
|
205
|
+
},
|
|
206
|
+
},
|
|
207
|
+
{
|
|
208
|
+
id: 'cmd_create_intro_title',
|
|
209
|
+
type: 'elements.create',
|
|
210
|
+
payload: {
|
|
211
|
+
slideId: 'slide_intro',
|
|
212
|
+
element: {
|
|
213
|
+
id: 'el_intro_title',
|
|
214
|
+
type: 'text',
|
|
215
|
+
left: 80,
|
|
216
|
+
top: 80,
|
|
217
|
+
width: 500,
|
|
218
|
+
height: 80,
|
|
219
|
+
rotate: 0,
|
|
220
|
+
content: '<p>Hello from agent</p>',
|
|
221
|
+
defaultFontName: '',
|
|
222
|
+
defaultColor: '#111111',
|
|
223
|
+
},
|
|
224
|
+
select: true,
|
|
225
|
+
},
|
|
226
|
+
},
|
|
227
|
+
], { atomic: true })
|
|
228
|
+
|
|
229
|
+
if (!results.every(result => result.ok)) {
|
|
230
|
+
console.error(results.find(result => !result.ok)?.errors)
|
|
231
|
+
}
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
Validate a risky table edit without changing the deck:
|
|
235
|
+
|
|
236
|
+
```ts
|
|
237
|
+
const dryRun = await controller.execute({
|
|
238
|
+
id: 'cmd_validate_table_cell',
|
|
239
|
+
type: 'tables.setCell',
|
|
240
|
+
payload: {
|
|
241
|
+
elementId: 'table_fixture',
|
|
242
|
+
row: 0,
|
|
243
|
+
col: 1,
|
|
244
|
+
patch: { text: 'Updated' },
|
|
245
|
+
},
|
|
246
|
+
meta: { dryRun: true },
|
|
247
|
+
})
|
|
248
|
+
|
|
249
|
+
if (dryRun.ok) {
|
|
250
|
+
await controller.execute({
|
|
251
|
+
id: 'cmd_apply_table_cell',
|
|
252
|
+
type: 'tables.setCell',
|
|
253
|
+
payload: {
|
|
254
|
+
elementId: 'table_fixture',
|
|
255
|
+
row: 0,
|
|
256
|
+
col: 1,
|
|
257
|
+
patch: { text: 'Updated' },
|
|
258
|
+
},
|
|
259
|
+
})
|
|
260
|
+
}
|
|
261
|
+
```
|
|
262
|
+
|
|
263
|
+
Subscribe to command failures:
|
|
264
|
+
|
|
265
|
+
```ts
|
|
266
|
+
const unsubscribe = controller.subscribe(event => {
|
|
267
|
+
if (event.type === 'commandFailed') {
|
|
268
|
+
console.error(event.result?.commandId, event.result?.errors)
|
|
269
|
+
}
|
|
270
|
+
})
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
## Coverage Matrix
|
|
274
|
+
|
|
275
|
+
| Model area | Registered commands | Convenience surface | Notes |
|
|
276
|
+
| --- | --- | --- | --- |
|
|
277
|
+
| Deck/document | `deck.get`, `deck.set`, `deck.patch`, `deck.setTitle`, `deck.setTheme`, `deck.setViewport`, `deck.setTemplates`, `import.json`, `import.pptist`, `import.pptxSafe`, `export.json` | `deck.*`, `import.*`, `export.json()` | Import commands replace the deck from a data-safe document payload. |
|
|
278
|
+
| Slides | `slides.list`, `slides.get`, `slides.create`, `slides.update`, `slides.delete`, `slides.duplicate`, `slides.move`, `slides.select`, `slides.setBackground`, `slides.applyBackground`, `slides.setTransition`, `slides.setRemark` | `slides.*` | `slides.applyBackground` is command-only in the current runtime. |
|
|
279
|
+
| Elements | `elements.list`, `elements.get`, `elements.create`, `elements.update`, `elements.delete`, `elements.reorder`, `elements.select`, `elements.group`, `elements.ungroup`, `elements.lock`, `elements.hide`, `elements.setLink` | `elements.*`, `element.*`, `links.*` | Subtype and link helpers map to `elements.update` or `elements.setLink`. |
|
|
280
|
+
| Media assets | `media.resolveAsset`, `media.setImageSource`, `media.setVideoSource`, `media.setAudioSource` | `media.*` | Accepts JSON-safe media assets or raw `src` strings. Video and audio ext fields are inferred when possible. |
|
|
281
|
+
| Animations | `animations.list`, `animations.catalog`, `animations.create`, `animations.update`, `animations.delete`, `animations.reorder` | `animations.*` | `animations.catalog` is command-only in the current runtime. |
|
|
282
|
+
| Tables | `tables.update`, `tables.setCell`, `tables.setCellStyle`, `tables.insertRow`, `tables.deleteRow`, `tables.insertColumn`, `tables.deleteColumn`, `tables.mergeCells`, `tables.splitCell` | `tables.*` | `tables.mergeCells` and `tables.splitCell` are command-only in the current runtime. |
|
|
283
|
+
| Charts | `charts.update`, `charts.setType`, `charts.setData`, `charts.setLabels`, `charts.setLegends`, `charts.setSeries`, `charts.setOptions` | `charts.*` | Label, legend, and series helpers are command-only in the current runtime. |
|
|
284
|
+
| Notes/comments | `notes.create`, `notes.update`, `notes.delete`, `notes.reply` | `notes.*` | `notes.list` is a direct read helper, not a registered command. |
|
|
285
|
+
| Sections | `sections.set`, `sections.clear`, `sections.rename`, `sections.assignRange` | `sections.*` | `sections.list` is a direct read helper. `rename` and `assignRange` are command-only in the current runtime. |
|
|
286
|
+
| Search | `search.find`, `search.replace` | `search.*` | Finds and replaces text element content, shape text content, and table cell text. |
|
|
287
|
+
| View and selection | `view.setZoom`, `view.enterPresentation`, `view.exitPresentation`, `view.setLocale`, `slides.select`, `elements.select`, `elements.hide` | `view.*`, `slides.select`, `elements.select`, `elements.hide` | View commands return `PptistBridgeState`. |
|
|
288
|
+
| History | `history.commit`, `history.undo`, `history.redo` | `history.*` | Undo and redo update `documentVersion` and return bridge state. |
|
|
289
|
+
|
|
290
|
+
## Search And Replace
|
|
291
|
+
|
|
292
|
+
`controller.search.find(query, options)` scans `text.content`, `shape.text.content`, and table cell `text` fields. `controller.search.replace(query, replacement, options, meta)` updates the same fields and returns only the matches it replaced. Both methods support `{ caseSensitive, regex }`; replace also supports `{ replaceAll }`, which defaults to replacing the first match.
|
|
293
|
+
|
|
294
|
+
Both methods return `{ count, results }`, where each result includes `slideId`, `elementId`, `elementType`, `path`, `match`, `start`, `end`, and table cell `row`/`col` when applicable.
|
|
295
|
+
|
|
296
|
+
## Media Asset Contract
|
|
297
|
+
|
|
298
|
+
Media inputs must be JSON-safe. Hosts should resolve `File`, `Blob`, `ArrayBuffer`, upload handles, or private storage references before calling the bridge, then pass either a raw source string or a plain asset object:
|
|
299
|
+
|
|
300
|
+
```ts
|
|
301
|
+
type PptistMediaAssetInput = string | {
|
|
302
|
+
id?: string
|
|
303
|
+
kind?: 'image' | 'video' | 'audio'
|
|
304
|
+
src: string
|
|
305
|
+
ext?: string
|
|
306
|
+
mimeType?: string
|
|
307
|
+
filename?: string
|
|
308
|
+
title?: string
|
|
309
|
+
width?: number
|
|
310
|
+
height?: number
|
|
311
|
+
size?: number
|
|
312
|
+
poster?: string
|
|
313
|
+
metadata?: Record<string, unknown>
|
|
314
|
+
}
|
|
315
|
+
```
|
|
316
|
+
|
|
317
|
+
`src` is the playable/renderable URL or data URL. The bridge does not fetch or upload media; it only normalizes the contract and writes element fields. `controller.media.resolveAsset(asset, kind)` returns the normalized asset without mutating the deck.
|
|
318
|
+
|
|
319
|
+
The helper layer infers `mimeType` from data URLs and common file extensions, and infers `ext` from `mimeType` or URL/filename extensions. `media.setVideoSource` and `media.setAudioSource` copy the inferred `ext` into the PPTist element when the caller did not provide an explicit patch ext.
|
|
320
|
+
|
|
321
|
+
## Import Boundary
|
|
322
|
+
|
|
323
|
+
The agentic bridge imports documents only after data has been reduced to a JSON-safe deck payload:
|
|
324
|
+
|
|
325
|
+
```ts
|
|
326
|
+
await controller.import.json(document)
|
|
327
|
+
await controller.import.pptist(document)
|
|
328
|
+
await controller.import.pptxSafe(document)
|
|
329
|
+
|
|
330
|
+
await controller.execute({ type: 'import.json', payload: { document } })
|
|
331
|
+
await controller.execute({ type: 'import.pptist', payload: { document } })
|
|
332
|
+
await controller.execute({ type: 'import.pptxSafe', payload: { document } })
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
`import.json` is the canonical JSON bridge path. `import.pptist` is for an already-decoded native `.pptist` payload, and `import.pptxSafe` is for PPTX content that a trusted UI or host importer has already converted into a serializable deck payload.
|
|
336
|
+
|
|
337
|
+
Raw `.pptist` decryption, raw PPTX parsing, `File` / `ArrayBuffer` reads, DOM parsing, media blob extraction, and other DOM-heavy import work stay outside the agentic JSON bridge. Do not send those boundaries through `controller.execute()` unless the result is already data-safe.
|
|
338
|
+
|
|
339
|
+
## Host Safety Rules
|
|
340
|
+
|
|
341
|
+
- Use commands or domain methods, not Pinia stores.
|
|
342
|
+
- Prefer deterministic IDs for multi-command batches.
|
|
343
|
+
- Use returned IDs after every create command.
|
|
344
|
+
- Use `canExecute()` to reject unsupported command types early.
|
|
345
|
+
- Use `meta.dryRun` to validate payload shape and references before risky edits.
|
|
346
|
+
- Keep command batches small enough that a failed result can be inspected and retried by command ID.
|
|
347
|
+
- Use `deck.set`, `deck.patch`, `import.json`, `import.pptist`, or `import.pptxSafe` for whole-document writes so title/slides validation and JSON cloning happen before mutation.
|
|
348
|
+
- Convert raw `.pptist` and PPTX imports to a data-safe document before calling the agentic import APIs.
|
|
349
|
+
- Treat `controller.export.json()` as the stable serializable export path for host-side persistence.
|
|
350
|
+
|
|
351
|
+
## sciobot-next Usage Examples
|
|
352
|
+
|
|
353
|
+
Use `controller.execute()` when sciobot represents an agent action as JSON:
|
|
354
|
+
|
|
355
|
+
```ts
|
|
356
|
+
import type { PptistAgentCommand } from '@lofcz/pptist/embed'
|
|
357
|
+
|
|
358
|
+
const command: PptistAgentCommand = {
|
|
359
|
+
type: 'deck.setTitle',
|
|
360
|
+
payload: { title: 'Cell Biology Review' },
|
|
361
|
+
meta: { source: 'agent', label: 'Rename generated deck' },
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
const capability = controller.canExecute(command)
|
|
365
|
+
if (!capability.ok) throw new Error(capability.reason)
|
|
366
|
+
|
|
367
|
+
const result = await controller.execute(command)
|
|
368
|
+
if (!result.ok) {
|
|
369
|
+
reportAgentBridgeError(result.errors)
|
|
370
|
+
}
|
|
371
|
+
```
|
|
372
|
+
|
|
373
|
+
Use domain APIs when the React host already has a `PptistController` instance and wants typed helper methods:
|
|
374
|
+
|
|
375
|
+
```ts
|
|
376
|
+
const slide = await controller.slides.create({
|
|
377
|
+
select: true,
|
|
378
|
+
slide: {
|
|
379
|
+
elements: [],
|
|
380
|
+
background: { type: 'solid', color: '#fff' },
|
|
381
|
+
},
|
|
382
|
+
}, { source: 'agent', label: 'Create sciobot slide' })
|
|
383
|
+
|
|
384
|
+
if (!slide.ok || !slide.data) return
|
|
385
|
+
|
|
386
|
+
const text = await controller.elements.create({
|
|
387
|
+
slideId: slide.data.id,
|
|
388
|
+
element: {
|
|
389
|
+
type: 'text',
|
|
390
|
+
left: 72,
|
|
391
|
+
top: 72,
|
|
392
|
+
width: 640,
|
|
393
|
+
height: 120,
|
|
394
|
+
rotate: 0,
|
|
395
|
+
content: '<p>Learning objective</p>',
|
|
396
|
+
defaultFontName: '',
|
|
397
|
+
defaultColor: '#111',
|
|
398
|
+
},
|
|
399
|
+
})
|
|
400
|
+
|
|
401
|
+
if (text.ok && text.data) {
|
|
402
|
+
await controller.element.text(text.data.id, { content: '<p>Explain mitosis in five steps</p>' }, { slideId: slide.data.id })
|
|
403
|
+
await controller.links.set(text.data.id, { type: 'web', target: 'https://sciobot.app' }, { slideId: slide.data.id })
|
|
404
|
+
}
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
Domain helpers cover specialized model areas without requiring Pinia access:
|
|
408
|
+
|
|
409
|
+
```ts
|
|
410
|
+
await controller.tables.setCell(tableElementId, 0, 1, { text: 'Hypothesis' }, { slideId })
|
|
411
|
+
await controller.charts.setData(chartElementId, {
|
|
412
|
+
labels: ['Before', 'After'],
|
|
413
|
+
legends: ['Class average'],
|
|
414
|
+
series: [[62, 81]],
|
|
415
|
+
}, { slideId })
|
|
416
|
+
await controller.media.setImageSource(imageElementId, '/pptist-assets/imgs/example.png', { fixedRatio: true }, { slideId })
|
|
417
|
+
await controller.slides.setRemark(slideId, '<p>Ask students to compare both bars.</p>')
|
|
418
|
+
```
|
|
419
|
+
|
|
420
|
+
Use `subscribe()` to connect PPTist events to sciobot persistence, telemetry, or active selection state:
|
|
421
|
+
|
|
422
|
+
```ts
|
|
423
|
+
const unsubscribe = controller.subscribe(event => {
|
|
424
|
+
if (event.type === 'documentChanged') {
|
|
425
|
+
queueAutosave(controller.export.json())
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
if (event.type === 'selectionChanged') {
|
|
429
|
+
syncAgentSelection(event.data)
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
if (event.type === 'commandFailed') {
|
|
433
|
+
reportAgentBridgeError(event.result?.errors)
|
|
434
|
+
}
|
|
435
|
+
})
|
|
436
|
+
|
|
437
|
+
// Call before unmounting or replacing the controller.
|
|
438
|
+
unsubscribe()
|
|
439
|
+
```
|
|
440
|
+
|
|
441
|
+
Use `executeBatch()` when one agent instruction expands to multiple bridge commands and should produce one undo step:
|
|
442
|
+
|
|
443
|
+
```ts
|
|
444
|
+
const results = await controller.executeBatch([
|
|
445
|
+
{ type: 'slides.select', payload: { slideIdOrIndex: slideId } },
|
|
446
|
+
{ type: 'slides.setBackground', payload: { slideId, background: { type: 'solid', color: '#f8fafc' } } },
|
|
447
|
+
{
|
|
448
|
+
type: 'elements.update',
|
|
449
|
+
payload: {
|
|
450
|
+
slideId,
|
|
451
|
+
elementId: [titleElementId, bodyElementId],
|
|
452
|
+
patch: { defaultColor: '#0f172a' },
|
|
453
|
+
},
|
|
454
|
+
},
|
|
455
|
+
], { atomic: true })
|
|
456
|
+
|
|
457
|
+
const failed = results.find(result => !result.ok)
|
|
458
|
+
if (failed) reportAgentBridgeError(failed.errors)
|
|
459
|
+
```
|
|
460
|
+
|
|
461
|
+
The bridge does not load styles or static assets. The React host must load `pptist-embed.css` with a `<link>` from the same `assetBaseUrl` used for `mocks/` and `imgs/`; do not import the CSS into the sciobot Vite/PostCSS pipeline. See [`EMBED.md`](./EMBED.md) for the React loader example and production copy constraints.
|
|
462
|
+
|
|
463
|
+
## Migration Guide
|
|
464
|
+
|
|
465
|
+
Keep legacy document calls at persistence boundaries:
|
|
466
|
+
|
|
467
|
+
```ts
|
|
468
|
+
controller.setDocument(await loadPresentationDocument(id))
|
|
469
|
+
await savePresentationDocument(controller.getDocument())
|
|
470
|
+
```
|
|
471
|
+
|
|
472
|
+
Migrate in-editor agent edits from whole-document replacement to commands or domain APIs:
|
|
473
|
+
|
|
474
|
+
```ts
|
|
475
|
+
// Legacy: replace the complete document after changing one field.
|
|
476
|
+
const document = controller.getDocument()
|
|
477
|
+
controller.setDocument({
|
|
478
|
+
...document,
|
|
479
|
+
title: 'Generated lesson',
|
|
480
|
+
})
|
|
481
|
+
|
|
482
|
+
// Agentic: mutate only the intended field and get a result.
|
|
483
|
+
await controller.deck.setTitle('Generated lesson', { source: 'agent' })
|
|
484
|
+
```
|
|
485
|
+
|
|
486
|
+
```ts
|
|
487
|
+
// Legacy: create a slide by appending to document.slides.
|
|
488
|
+
const before = controller.getDocument()
|
|
489
|
+
controller.setDocument({
|
|
490
|
+
...before,
|
|
491
|
+
slides: [...before.slides, generatedSlide],
|
|
492
|
+
})
|
|
493
|
+
|
|
494
|
+
// Agentic: create through the bridge and use the returned ID.
|
|
495
|
+
const created = await controller.slides.create({
|
|
496
|
+
slide: { ...generatedSlide, id: undefined },
|
|
497
|
+
select: true,
|
|
498
|
+
})
|
|
499
|
+
if (created.ok && created.data) {
|
|
500
|
+
await controller.slides.setRemark(created.data.id, '<p>Generated by sciobot</p>')
|
|
501
|
+
}
|
|
502
|
+
```
|
|
503
|
+
|
|
504
|
+
```ts
|
|
505
|
+
// Legacy: save after every small mutation.
|
|
506
|
+
controller.setDocument(nextDocument)
|
|
507
|
+
await savePresentationDocument(controller.getDocument())
|
|
508
|
+
|
|
509
|
+
// Agentic: batch related mutations, then autosave from documentChanged.
|
|
510
|
+
await controller.executeBatch(commands, { atomic: true })
|
|
511
|
+
```
|
|
512
|
+
|
|
513
|
+
Use `controller.export.json()` for a synchronous serializable snapshot. Use `controller.import.json(document)`, `controller.execute({ type: 'import.json', payload: { document } })`, or `controller.execute({ type: 'export.json' })` when sciobot needs command results for whole-document import/export.
|