@nice2dev/ui-graphics 1.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/CHANGELOG.md +84 -0
- package/LICENSE +21 -0
- package/README.md +339 -0
- package/dist/cjs/animation/AnimatedPerson.js +153 -0
- package/dist/cjs/animation/AnimatedPerson.js.map +1 -0
- package/dist/cjs/animation/AnimationEditor.js +106 -0
- package/dist/cjs/animation/AnimationEditor.js.map +1 -0
- package/dist/cjs/animation/Audience.js +59 -0
- package/dist/cjs/animation/Audience.js.map +1 -0
- package/dist/cjs/animation/BodyRenderer.js +33 -0
- package/dist/cjs/animation/BodyRenderer.js.map +1 -0
- package/dist/cjs/animation/animationHelper.js +272 -0
- package/dist/cjs/animation/animationHelper.js.map +1 -0
- package/dist/cjs/animation/characterTypes.js +75 -0
- package/dist/cjs/animation/characterTypes.js.map +1 -0
- package/dist/cjs/animation/choreoDSL.js +190 -0
- package/dist/cjs/animation/choreoDSL.js.map +1 -0
- package/dist/cjs/animation/choreography.js +41 -0
- package/dist/cjs/animation/choreography.js.map +1 -0
- package/dist/cjs/animation/karaokeIntegration.js +98 -0
- package/dist/cjs/animation/karaokeIntegration.js.map +1 -0
- package/dist/cjs/animation/lottieExport.js +128 -0
- package/dist/cjs/animation/lottieExport.js.map +1 -0
- package/dist/cjs/animation/motionPath.js +196 -0
- package/dist/cjs/animation/motionPath.js.map +1 -0
- package/dist/cjs/animation/physics.js +201 -0
- package/dist/cjs/animation/physics.js.map +1 -0
- package/dist/cjs/animation/rig/RigPlayer.js +63 -0
- package/dist/cjs/animation/rig/RigPlayer.js.map +1 -0
- package/dist/cjs/animation/rig/RiggedBody.js +30 -0
- package/dist/cjs/animation/rig/RiggedBody.js.map +1 -0
- package/dist/cjs/animation/rig/choreoRigBridge.js +63 -0
- package/dist/cjs/animation/rig/choreoRigBridge.js.map +1 -0
- package/dist/cjs/animation/rig/ik.js +22 -0
- package/dist/cjs/animation/rig/ik.js.map +1 -0
- package/dist/cjs/animation/rig/poseOps.js +49 -0
- package/dist/cjs/animation/rig/poseOps.js.map +1 -0
- package/dist/cjs/animation/rig/presets.js +60 -0
- package/dist/cjs/animation/rig/presets.js.map +1 -0
- package/dist/cjs/animation/rig/rigMath.js +41 -0
- package/dist/cjs/animation/rig/rigMath.js.map +1 -0
- package/dist/cjs/animation/rig/rigTypes.js +44 -0
- package/dist/cjs/animation/rig/rigTypes.js.map +1 -0
- package/dist/cjs/animation/shapes/arms.js +15 -0
- package/dist/cjs/animation/shapes/arms.js.map +1 -0
- package/dist/cjs/animation/shapes/eyes.js +52 -0
- package/dist/cjs/animation/shapes/eyes.js.map +1 -0
- package/dist/cjs/animation/shapes/hair.js +55 -0
- package/dist/cjs/animation/shapes/hair.js.map +1 -0
- package/dist/cjs/animation/shapes/heads.js +62 -0
- package/dist/cjs/animation/shapes/heads.js.map +1 -0
- package/dist/cjs/animation/shapes/headwear.js +44 -0
- package/dist/cjs/animation/shapes/headwear.js.map +1 -0
- package/dist/cjs/animation/shapes/legs.js +15 -0
- package/dist/cjs/animation/shapes/legs.js.map +1 -0
- package/dist/cjs/animation/shapes/mouths.js +53 -0
- package/dist/cjs/animation/shapes/mouths.js.map +1 -0
- package/dist/cjs/animation/shapes/noses.js +31 -0
- package/dist/cjs/animation/shapes/noses.js.map +1 -0
- package/dist/cjs/animation/shapes/outfits.js +43 -0
- package/dist/cjs/animation/shapes/outfits.js.map +1 -0
- package/dist/cjs/animation/shapes/torsos.js +13 -0
- package/dist/cjs/animation/shapes/torsos.js.map +1 -0
- package/dist/cjs/animation/spineExport.js +132 -0
- package/dist/cjs/animation/spineExport.js.map +1 -0
- package/dist/cjs/core/LocalUI.js +54 -0
- package/dist/cjs/core/LocalUI.js.map +1 -0
- package/dist/cjs/core/collaboration.js +259 -0
- package/dist/cjs/core/collaboration.js.map +1 -0
- package/dist/cjs/core/colorBlindness.js +97 -0
- package/dist/cjs/core/colorBlindness.js.map +1 -0
- package/dist/cjs/core/dragDrop.js +168 -0
- package/dist/cjs/core/dragDrop.js.map +1 -0
- package/dist/cjs/core/fixes.js +185 -0
- package/dist/cjs/core/fixes.js.map +1 -0
- package/dist/cjs/core/gridGuides.js +245 -0
- package/dist/cjs/core/gridGuides.js.map +1 -0
- package/dist/cjs/core/historyVisual.js +124 -0
- package/dist/cjs/core/historyVisual.js.map +1 -0
- package/dist/cjs/core/i18n.js +16 -0
- package/dist/cjs/core/i18n.js.map +1 -0
- package/dist/cjs/core/integrations.js +261 -0
- package/dist/cjs/core/integrations.js.map +1 -0
- package/dist/cjs/core/minimap.js +142 -0
- package/dist/cjs/core/minimap.js.map +1 -0
- package/dist/cjs/core/plugins.js +129 -0
- package/dist/cjs/core/plugins.js.map +1 -0
- package/dist/cjs/core/rtl.js +102 -0
- package/dist/cjs/core/rtl.js.map +1 -0
- package/dist/cjs/core/shortcuts.js +205 -0
- package/dist/cjs/core/shortcuts.js.map +1 -0
- package/dist/cjs/core/theme.js +171 -0
- package/dist/cjs/core/theme.js.map +1 -0
- package/dist/cjs/font/NiceFontEditor.js +193 -0
- package/dist/cjs/font/NiceFontEditor.js.map +1 -0
- package/dist/cjs/game/GameAsset2dEditor.js +371 -0
- package/dist/cjs/game/GameAsset2dEditor.js.map +1 -0
- package/dist/cjs/game/GameAsset2dEditor.module.css.js +6 -0
- package/dist/cjs/game/GameAsset2dEditor.module.css.js.map +1 -0
- package/dist/cjs/game/gameAssetTypes.js +20 -0
- package/dist/cjs/game/gameAssetTypes.js.map +1 -0
- package/dist/cjs/game/gameAssetUtils.js +475 -0
- package/dist/cjs/game/gameAssetUtils.js.map +1 -0
- package/dist/cjs/game/useGameAssetEditor.js +761 -0
- package/dist/cjs/game/useGameAssetEditor.js.map +1 -0
- package/dist/cjs/icon/NiceIconEditor.js +249 -0
- package/dist/cjs/icon/NiceIconEditor.js.map +1 -0
- package/dist/cjs/index.js +264 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/nice2dev-ui/dist/index.js +32070 -0
- package/dist/cjs/nice2dev-ui/dist/index.js.map +1 -0
- package/dist/cjs/nice2dev-ui-graphics.css +1 -0
- package/dist/cjs/photo/FilterThumb.js +29 -0
- package/dist/cjs/photo/FilterThumb.js.map +1 -0
- package/dist/cjs/photo/PhotoEditor.js +20 -0
- package/dist/cjs/photo/PhotoEditor.js.map +1 -0
- package/dist/cjs/photo/PhotoEditor.module.css.js +6 -0
- package/dist/cjs/photo/PhotoEditor.module.css.js.map +1 -0
- package/dist/cjs/photo/PhotoEditorCanvas.js +59 -0
- package/dist/cjs/photo/PhotoEditorCanvas.js.map +1 -0
- package/dist/cjs/photo/PhotoEditorLeftPanel.js +174 -0
- package/dist/cjs/photo/PhotoEditorLeftPanel.js.map +1 -0
- package/dist/cjs/photo/PhotoEditorToolbar.js +15 -0
- package/dist/cjs/photo/PhotoEditorToolbar.js.map +1 -0
- package/dist/cjs/photo/photoEditorActions.js +80 -0
- package/dist/cjs/photo/photoEditorActions.js.map +1 -0
- package/dist/cjs/photo/photoEditorTypes.js +40 -0
- package/dist/cjs/photo/photoEditorTypes.js.map +1 -0
- package/dist/cjs/photo/photoFilters.js +880 -0
- package/dist/cjs/photo/photoFilters.js.map +1 -0
- package/dist/cjs/photo/photoOverlays.js +651 -0
- package/dist/cjs/photo/photoOverlays.js.map +1 -0
- package/dist/cjs/photo/photoSelection.js +547 -0
- package/dist/cjs/photo/photoSelection.js.map +1 -0
- package/dist/cjs/photo/usePhotoEditor.js +640 -0
- package/dist/cjs/photo/usePhotoEditor.js.map +1 -0
- package/dist/cjs/pixel/HSVPicker.js +173 -0
- package/dist/cjs/pixel/HSVPicker.js.map +1 -0
- package/dist/cjs/pixel/PixelEditor.js +28 -0
- package/dist/cjs/pixel/PixelEditor.js.map +1 -0
- package/dist/cjs/pixel/PixelEditor.module.css.js +6 -0
- package/dist/cjs/pixel/PixelEditor.module.css.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorCanvas.js +15 -0
- package/dist/cjs/pixel/PixelEditorCanvas.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorMenuBar.js +11 -0
- package/dist/cjs/pixel/PixelEditorMenuBar.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorRightPanel.js +15 -0
- package/dist/cjs/pixel/PixelEditorRightPanel.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorStatusBar.js +15 -0
- package/dist/cjs/pixel/PixelEditorStatusBar.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorTimeline.js +11 -0
- package/dist/cjs/pixel/PixelEditorTimeline.js.map +1 -0
- package/dist/cjs/pixel/PixelEditorToolbar.js +16 -0
- package/dist/cjs/pixel/PixelEditorToolbar.js.map +1 -0
- package/dist/cjs/pixel/asepriteFormat.js +512 -0
- package/dist/cjs/pixel/asepriteFormat.js.map +1 -0
- package/dist/cjs/pixel/pixelEditorExports.js +471 -0
- package/dist/cjs/pixel/pixelEditorExports.js.map +1 -0
- package/dist/cjs/pixel/pixelEditorTypes.js +102 -0
- package/dist/cjs/pixel/pixelEditorTypes.js.map +1 -0
- package/dist/cjs/pixel/pixelEditorUtils.js +664 -0
- package/dist/cjs/pixel/pixelEditorUtils.js.map +1 -0
- package/dist/cjs/pixel/usePixelEditor.js +1112 -0
- package/dist/cjs/pixel/usePixelEditor.js.map +1 -0
- package/dist/cjs/texture/Nice3DTexturePainter.js +236 -0
- package/dist/cjs/texture/Nice3DTexturePainter.js.map +1 -0
- package/dist/cjs/ui/NiceUIDesigner.js +191 -0
- package/dist/cjs/ui/NiceUIDesigner.js.map +1 -0
- package/dist/cjs/vector/VectorEditor.js +31 -0
- package/dist/cjs/vector/VectorEditor.js.map +1 -0
- package/dist/cjs/vector/VectorEditor.module.css.js +6 -0
- package/dist/cjs/vector/VectorEditor.module.css.js.map +1 -0
- package/dist/cjs/vector/VectorEditorMenuBar.js +16 -0
- package/dist/cjs/vector/VectorEditorMenuBar.js.map +1 -0
- package/dist/cjs/vector/VectorEditorRightPanel.js +126 -0
- package/dist/cjs/vector/VectorEditorRightPanel.js.map +1 -0
- package/dist/cjs/vector/VectorEditorShapeRenderer.js +55 -0
- package/dist/cjs/vector/VectorEditorShapeRenderer.js.map +1 -0
- package/dist/cjs/vector/VectorEditorStatusBar.js +14 -0
- package/dist/cjs/vector/VectorEditorStatusBar.js.map +1 -0
- package/dist/cjs/vector/useVectorEditor.js +613 -0
- package/dist/cjs/vector/useVectorEditor.js.map +1 -0
- package/dist/cjs/vector/vectorBooleanOps.js +511 -0
- package/dist/cjs/vector/vectorBooleanOps.js.map +1 -0
- package/dist/cjs/vector/vectorEditorExport.js +159 -0
- package/dist/cjs/vector/vectorEditorExport.js.map +1 -0
- package/dist/cjs/vector/vectorEditorImport.js +150 -0
- package/dist/cjs/vector/vectorEditorImport.js.map +1 -0
- package/dist/cjs/vector/vectorEditorTypes.js +72 -0
- package/dist/cjs/vector/vectorEditorTypes.js.map +1 -0
- package/dist/cjs/vector/vectorGradients.js +201 -0
- package/dist/cjs/vector/vectorGradients.js.map +1 -0
- package/dist/esm/animation/AnimatedPerson.js +151 -0
- package/dist/esm/animation/AnimatedPerson.js.map +1 -0
- package/dist/esm/animation/AnimationEditor.js +104 -0
- package/dist/esm/animation/AnimationEditor.js.map +1 -0
- package/dist/esm/animation/Audience.js +57 -0
- package/dist/esm/animation/Audience.js.map +1 -0
- package/dist/esm/animation/BodyRenderer.js +28 -0
- package/dist/esm/animation/BodyRenderer.js.map +1 -0
- package/dist/esm/animation/animationHelper.js +268 -0
- package/dist/esm/animation/animationHelper.js.map +1 -0
- package/dist/esm/animation/characterTypes.js +70 -0
- package/dist/esm/animation/characterTypes.js.map +1 -0
- package/dist/esm/animation/choreoDSL.js +182 -0
- package/dist/esm/animation/choreoDSL.js.map +1 -0
- package/dist/esm/animation/choreography.js +36 -0
- package/dist/esm/animation/choreography.js.map +1 -0
- package/dist/esm/animation/karaokeIntegration.js +91 -0
- package/dist/esm/animation/karaokeIntegration.js.map +1 -0
- package/dist/esm/animation/lottieExport.js +123 -0
- package/dist/esm/animation/lottieExport.js.map +1 -0
- package/dist/esm/animation/motionPath.js +185 -0
- package/dist/esm/animation/motionPath.js.map +1 -0
- package/dist/esm/animation/physics.js +192 -0
- package/dist/esm/animation/physics.js.map +1 -0
- package/dist/esm/animation/rig/RigPlayer.js +61 -0
- package/dist/esm/animation/rig/RigPlayer.js.map +1 -0
- package/dist/esm/animation/rig/RiggedBody.js +28 -0
- package/dist/esm/animation/rig/RiggedBody.js.map +1 -0
- package/dist/esm/animation/rig/choreoRigBridge.js +60 -0
- package/dist/esm/animation/rig/choreoRigBridge.js.map +1 -0
- package/dist/esm/animation/rig/ik.js +20 -0
- package/dist/esm/animation/rig/ik.js.map +1 -0
- package/dist/esm/animation/rig/poseOps.js +45 -0
- package/dist/esm/animation/rig/poseOps.js.map +1 -0
- package/dist/esm/animation/rig/presets.js +53 -0
- package/dist/esm/animation/rig/presets.js.map +1 -0
- package/dist/esm/animation/rig/rigMath.js +37 -0
- package/dist/esm/animation/rig/rigMath.js.map +1 -0
- package/dist/esm/animation/rig/rigTypes.js +40 -0
- package/dist/esm/animation/rig/rigTypes.js.map +1 -0
- package/dist/esm/animation/shapes/arms.js +13 -0
- package/dist/esm/animation/shapes/arms.js.map +1 -0
- package/dist/esm/animation/shapes/eyes.js +45 -0
- package/dist/esm/animation/shapes/eyes.js.map +1 -0
- package/dist/esm/animation/shapes/hair.js +46 -0
- package/dist/esm/animation/shapes/hair.js.map +1 -0
- package/dist/esm/animation/shapes/heads.js +52 -0
- package/dist/esm/animation/shapes/heads.js.map +1 -0
- package/dist/esm/animation/shapes/headwear.js +36 -0
- package/dist/esm/animation/shapes/headwear.js.map +1 -0
- package/dist/esm/animation/shapes/legs.js +13 -0
- package/dist/esm/animation/shapes/legs.js.map +1 -0
- package/dist/esm/animation/shapes/mouths.js +45 -0
- package/dist/esm/animation/shapes/mouths.js.map +1 -0
- package/dist/esm/animation/shapes/noses.js +23 -0
- package/dist/esm/animation/shapes/noses.js.map +1 -0
- package/dist/esm/animation/shapes/outfits.js +37 -0
- package/dist/esm/animation/shapes/outfits.js.map +1 -0
- package/dist/esm/animation/shapes/torsos.js +11 -0
- package/dist/esm/animation/shapes/torsos.js.map +1 -0
- package/dist/esm/animation/spineExport.js +128 -0
- package/dist/esm/animation/spineExport.js.map +1 -0
- package/dist/esm/core/LocalUI.js +50 -0
- package/dist/esm/core/LocalUI.js.map +1 -0
- package/dist/esm/core/collaboration.js +252 -0
- package/dist/esm/core/collaboration.js.map +1 -0
- package/dist/esm/core/colorBlindness.js +90 -0
- package/dist/esm/core/colorBlindness.js.map +1 -0
- package/dist/esm/core/dragDrop.js +165 -0
- package/dist/esm/core/dragDrop.js.map +1 -0
- package/dist/esm/core/fixes.js +179 -0
- package/dist/esm/core/fixes.js.map +1 -0
- package/dist/esm/core/gridGuides.js +232 -0
- package/dist/esm/core/gridGuides.js.map +1 -0
- package/dist/esm/core/historyVisual.js +121 -0
- package/dist/esm/core/historyVisual.js.map +1 -0
- package/dist/esm/core/i18n.js +13 -0
- package/dist/esm/core/i18n.js.map +1 -0
- package/dist/esm/core/integrations.js +254 -0
- package/dist/esm/core/integrations.js.map +1 -0
- package/dist/esm/core/minimap.js +139 -0
- package/dist/esm/core/minimap.js.map +1 -0
- package/dist/esm/core/plugins.js +124 -0
- package/dist/esm/core/plugins.js.map +1 -0
- package/dist/esm/core/rtl.js +95 -0
- package/dist/esm/core/rtl.js.map +1 -0
- package/dist/esm/core/shortcuts.js +200 -0
- package/dist/esm/core/shortcuts.js.map +1 -0
- package/dist/esm/core/theme.js +162 -0
- package/dist/esm/core/theme.js.map +1 -0
- package/dist/esm/font/NiceFontEditor.js +189 -0
- package/dist/esm/font/NiceFontEditor.js.map +1 -0
- package/dist/esm/game/GameAsset2dEditor.js +369 -0
- package/dist/esm/game/GameAsset2dEditor.js.map +1 -0
- package/dist/esm/game/GameAsset2dEditor.module.css.js +4 -0
- package/dist/esm/game/GameAsset2dEditor.module.css.js.map +1 -0
- package/dist/esm/game/gameAssetTypes.js +18 -0
- package/dist/esm/game/gameAssetTypes.js.map +1 -0
- package/dist/esm/game/gameAssetUtils.js +456 -0
- package/dist/esm/game/gameAssetUtils.js.map +1 -0
- package/dist/esm/game/useGameAssetEditor.js +759 -0
- package/dist/esm/game/useGameAssetEditor.js.map +1 -0
- package/dist/esm/icon/NiceIconEditor.js +246 -0
- package/dist/esm/icon/NiceIconEditor.js.map +1 -0
- package/dist/esm/index.js +59 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/nice2dev-ui/dist/index.js +31720 -0
- package/dist/esm/nice2dev-ui/dist/index.js.map +1 -0
- package/dist/esm/nice2dev-ui-graphics.css +1 -0
- package/dist/esm/photo/FilterThumb.js +27 -0
- package/dist/esm/photo/FilterThumb.js.map +1 -0
- package/dist/esm/photo/PhotoEditor.js +18 -0
- package/dist/esm/photo/PhotoEditor.js.map +1 -0
- package/dist/esm/photo/PhotoEditor.module.css.js +4 -0
- package/dist/esm/photo/PhotoEditor.module.css.js.map +1 -0
- package/dist/esm/photo/PhotoEditorCanvas.js +57 -0
- package/dist/esm/photo/PhotoEditorCanvas.js.map +1 -0
- package/dist/esm/photo/PhotoEditorLeftPanel.js +172 -0
- package/dist/esm/photo/PhotoEditorLeftPanel.js.map +1 -0
- package/dist/esm/photo/PhotoEditorToolbar.js +13 -0
- package/dist/esm/photo/PhotoEditorToolbar.js.map +1 -0
- package/dist/esm/photo/photoEditorActions.js +75 -0
- package/dist/esm/photo/photoEditorActions.js.map +1 -0
- package/dist/esm/photo/photoEditorTypes.js +36 -0
- package/dist/esm/photo/photoEditorTypes.js.map +1 -0
- package/dist/esm/photo/photoFilters.js +871 -0
- package/dist/esm/photo/photoFilters.js.map +1 -0
- package/dist/esm/photo/photoOverlays.js +636 -0
- package/dist/esm/photo/photoOverlays.js.map +1 -0
- package/dist/esm/photo/photoSelection.js +535 -0
- package/dist/esm/photo/photoSelection.js.map +1 -0
- package/dist/esm/photo/usePhotoEditor.js +638 -0
- package/dist/esm/photo/usePhotoEditor.js.map +1 -0
- package/dist/esm/pixel/HSVPicker.js +171 -0
- package/dist/esm/pixel/HSVPicker.js.map +1 -0
- package/dist/esm/pixel/PixelEditor.js +26 -0
- package/dist/esm/pixel/PixelEditor.js.map +1 -0
- package/dist/esm/pixel/PixelEditor.module.css.js +4 -0
- package/dist/esm/pixel/PixelEditor.module.css.js.map +1 -0
- package/dist/esm/pixel/PixelEditorCanvas.js +13 -0
- package/dist/esm/pixel/PixelEditorCanvas.js.map +1 -0
- package/dist/esm/pixel/PixelEditorMenuBar.js +9 -0
- package/dist/esm/pixel/PixelEditorMenuBar.js.map +1 -0
- package/dist/esm/pixel/PixelEditorRightPanel.js +13 -0
- package/dist/esm/pixel/PixelEditorRightPanel.js.map +1 -0
- package/dist/esm/pixel/PixelEditorStatusBar.js +13 -0
- package/dist/esm/pixel/PixelEditorStatusBar.js.map +1 -0
- package/dist/esm/pixel/PixelEditorTimeline.js +9 -0
- package/dist/esm/pixel/PixelEditorTimeline.js.map +1 -0
- package/dist/esm/pixel/PixelEditorToolbar.js +14 -0
- package/dist/esm/pixel/PixelEditorToolbar.js.map +1 -0
- package/dist/esm/pixel/asepriteFormat.js +505 -0
- package/dist/esm/pixel/asepriteFormat.js.map +1 -0
- package/dist/esm/pixel/pixelEditorExports.js +461 -0
- package/dist/esm/pixel/pixelEditorExports.js.map +1 -0
- package/dist/esm/pixel/pixelEditorTypes.js +90 -0
- package/dist/esm/pixel/pixelEditorTypes.js.map +1 -0
- package/dist/esm/pixel/pixelEditorUtils.js +631 -0
- package/dist/esm/pixel/pixelEditorUtils.js.map +1 -0
- package/dist/esm/pixel/usePixelEditor.js +1110 -0
- package/dist/esm/pixel/usePixelEditor.js.map +1 -0
- package/dist/esm/texture/Nice3DTexturePainter.js +233 -0
- package/dist/esm/texture/Nice3DTexturePainter.js.map +1 -0
- package/dist/esm/ui/NiceUIDesigner.js +187 -0
- package/dist/esm/ui/NiceUIDesigner.js.map +1 -0
- package/dist/esm/vector/VectorEditor.js +29 -0
- package/dist/esm/vector/VectorEditor.js.map +1 -0
- package/dist/esm/vector/VectorEditor.module.css.js +4 -0
- package/dist/esm/vector/VectorEditor.module.css.js.map +1 -0
- package/dist/esm/vector/VectorEditorMenuBar.js +14 -0
- package/dist/esm/vector/VectorEditorMenuBar.js.map +1 -0
- package/dist/esm/vector/VectorEditorRightPanel.js +124 -0
- package/dist/esm/vector/VectorEditorRightPanel.js.map +1 -0
- package/dist/esm/vector/VectorEditorShapeRenderer.js +53 -0
- package/dist/esm/vector/VectorEditorShapeRenderer.js.map +1 -0
- package/dist/esm/vector/VectorEditorStatusBar.js +12 -0
- package/dist/esm/vector/VectorEditorStatusBar.js.map +1 -0
- package/dist/esm/vector/useVectorEditor.js +611 -0
- package/dist/esm/vector/useVectorEditor.js.map +1 -0
- package/dist/esm/vector/vectorBooleanOps.js +507 -0
- package/dist/esm/vector/vectorBooleanOps.js.map +1 -0
- package/dist/esm/vector/vectorEditorExport.js +152 -0
- package/dist/esm/vector/vectorEditorExport.js.map +1 -0
- package/dist/esm/vector/vectorEditorImport.js +148 -0
- package/dist/esm/vector/vectorEditorImport.js.map +1 -0
- package/dist/esm/vector/vectorEditorTypes.js +63 -0
- package/dist/esm/vector/vectorEditorTypes.js.map +1 -0
- package/dist/esm/vector/vectorGradients.js +193 -0
- package/dist/esm/vector/vectorGradients.js.map +1 -0
- package/dist/types/__benchmarks__/bench.d.ts +13 -0
- package/dist/types/__tests__/setup.d.ts +4 -0
- package/dist/types/animation/AnimatedPerson.d.ts +14 -0
- package/dist/types/animation/AnimationEditor.d.ts +20 -0
- package/dist/types/animation/Audience.d.ts +11 -0
- package/dist/types/animation/BodyRenderer.d.ts +12 -0
- package/dist/types/animation/animationHelper.d.ts +28 -0
- package/dist/types/animation/characterTypes.d.ts +37 -0
- package/dist/types/animation/choreoDSL.d.ts +88 -0
- package/dist/types/animation/choreography.d.ts +8 -0
- package/dist/types/animation/karaokeIntegration.d.ts +31 -0
- package/dist/types/animation/lottieExport.d.ts +77 -0
- package/dist/types/animation/motionPath.d.ts +60 -0
- package/dist/types/animation/physics.d.ts +73 -0
- package/dist/types/animation/rig/RigPlayer.d.ts +32 -0
- package/dist/types/animation/rig/RiggedBody.d.ts +19 -0
- package/dist/types/animation/rig/choreoRigBridge.d.ts +9 -0
- package/dist/types/animation/rig/ik.d.ts +8 -0
- package/dist/types/animation/rig/poseOps.d.ts +14 -0
- package/dist/types/animation/rig/presets.d.ts +13 -0
- package/dist/types/animation/rig/rigMath.d.ts +7 -0
- package/dist/types/animation/rig/rigTypes.d.ts +38 -0
- package/dist/types/animation/shapes/arms.d.ts +10 -0
- package/dist/types/animation/shapes/eyes.d.ts +17 -0
- package/dist/types/animation/shapes/hair.d.ts +17 -0
- package/dist/types/animation/shapes/heads.d.ts +18 -0
- package/dist/types/animation/shapes/headwear.d.ts +16 -0
- package/dist/types/animation/shapes/legs.d.ts +10 -0
- package/dist/types/animation/shapes/mouths.d.ts +17 -0
- package/dist/types/animation/shapes/noses.d.ts +17 -0
- package/dist/types/animation/shapes/outfits.d.ts +14 -0
- package/dist/types/animation/shapes/torsos.d.ts +9 -0
- package/dist/types/animation/spineExport.d.ts +66 -0
- package/dist/types/core/LocalUI.d.ts +21 -0
- package/dist/types/core/collaboration.d.ts +164 -0
- package/dist/types/core/colorBlindness.d.ts +24 -0
- package/dist/types/core/dragDrop.d.ts +46 -0
- package/dist/types/core/fixes.d.ts +80 -0
- package/dist/types/core/gridGuides.d.ts +70 -0
- package/dist/types/core/historyVisual.d.ts +915 -0
- package/dist/types/core/i18n.d.ts +27 -0
- package/dist/types/core/integrations.d.ts +103 -0
- package/dist/types/core/minimap.d.ts +49 -0
- package/dist/types/core/plugins.d.ts +111 -0
- package/dist/types/core/rtl.d.ts +32 -0
- package/dist/types/core/shortcuts.d.ts +150 -0
- package/dist/types/core/theme.d.ts +78 -0
- package/dist/types/core/useGamepad.d.ts +64 -0
- package/dist/types/core/usePointerPressure.d.ts +88 -0
- package/dist/types/font/NiceFontEditor.d.ts +62 -0
- package/dist/types/game/AnimationPreviewPlayer.d.ts +29 -0
- package/dist/types/game/CollisionEditor.d.ts +101 -0
- package/dist/types/game/GameAsset2dEditor.d.ts +17 -0
- package/dist/types/game/GameAssetExportPanel.d.ts +20 -0
- package/dist/types/game/IsometricEditor.d.ts +22 -0
- package/dist/types/game/IsometricTilePanel.d.ts +18 -0
- package/dist/types/game/gameAssetExport.d.ts +160 -0
- package/dist/types/game/gameAssetTypes.d.ts +238 -0
- package/dist/types/game/gameAssetUtils.d.ts +23 -0
- package/dist/types/game/index.d.ts +8 -0
- package/dist/types/game/isometricTiles.d.ts +250 -0
- package/dist/types/game/useAnimationPreview.d.ts +63 -0
- package/dist/types/game/useCollisionEditor.d.ts +96 -0
- package/dist/types/game/useGameAssetEditor.d.ts +79 -0
- package/dist/types/game/useGameAssetExport.d.ts +82 -0
- package/dist/types/icon/NiceIconEditor.d.ts +79 -0
- package/dist/types/index.d.ts +85 -0
- package/dist/types/photo/BatchProcessingPanel.d.ts +13 -0
- package/dist/types/photo/FaceDetectionPanel.d.ts +18 -0
- package/dist/types/photo/FilterThumb.d.ts +14 -0
- package/dist/types/photo/PerspectiveCorrectionPanel.d.ts +17 -0
- package/dist/types/photo/PhotoEditor.d.ts +2 -0
- package/dist/types/photo/PhotoEditorCanvas.d.ts +14 -0
- package/dist/types/photo/PhotoEditorLeftPanel.d.ts +13 -0
- package/dist/types/photo/PhotoEditorToolbar.d.ts +13 -0
- package/dist/types/photo/RawFilePanel.d.ts +14 -0
- package/dist/types/photo/StyleTransferPanel.d.ts +15 -0
- package/dist/types/photo/aiStyleTransfer.d.ts +58 -0
- package/dist/types/photo/batchProcessing.d.ts +95 -0
- package/dist/types/photo/faceDetection.d.ts +103 -0
- package/dist/types/photo/index.d.ts +17 -0
- package/dist/types/photo/perspectiveCorrection.d.ts +134 -0
- package/dist/types/photo/photoEditorActions.d.ts +40 -0
- package/dist/types/photo/photoEditorTypes.d.ts +34 -0
- package/dist/types/photo/photoFilters.d.ts +55 -0
- package/dist/types/photo/photoOverlays.d.ts +126 -0
- package/dist/types/photo/photoSelection.d.ts +56 -0
- package/dist/types/photo/rawFileSupport.d.ts +124 -0
- package/dist/types/photo/usePhotoEditor.d.ts +123 -0
- package/dist/types/pixel/HSVPicker.d.ts +11 -0
- package/dist/types/pixel/PaletteExtractorPanel.d.ts +16 -0
- package/dist/types/pixel/PixelEditor.d.ts +17 -0
- package/dist/types/pixel/PixelEditorCanvas.d.ts +10 -0
- package/dist/types/pixel/PixelEditorMenuBar.d.ts +11 -0
- package/dist/types/pixel/PixelEditorRightPanel.d.ts +11 -0
- package/dist/types/pixel/PixelEditorStatusBar.d.ts +11 -0
- package/dist/types/pixel/PixelEditorTimeline.d.ts +11 -0
- package/dist/types/pixel/PixelEditorToolbar.d.ts +11 -0
- package/dist/types/pixel/TileMapPanel.d.ts +14 -0
- package/dist/types/pixel/asepriteFormat.d.ts +62 -0
- package/dist/types/pixel/paletteExtractor.d.ts +73 -0
- package/dist/types/pixel/pixelEditorExports.d.ts +31 -0
- package/dist/types/pixel/pixelEditorTypes.d.ts +51 -0
- package/dist/types/pixel/pixelEditorUtils.d.ts +136 -0
- package/dist/types/pixel/tileMapMode.d.ts +122 -0
- package/dist/types/pixel/usePixelEditor.d.ts +114 -0
- package/dist/types/texture/Nice3DTexturePainter.d.ts +55 -0
- package/dist/types/ui/NiceUIDesigner.d.ts +43 -0
- package/dist/types/vector/PathSimplificationPanel.d.ts +15 -0
- package/dist/types/vector/PdfExportPanel.d.ts +20 -0
- package/dist/types/vector/TextOnPathPanel.d.ts +26 -0
- package/dist/types/vector/VectorEditor.d.ts +32 -0
- package/dist/types/vector/VectorEditorMenuBar.d.ts +8 -0
- package/dist/types/vector/VectorEditorRightPanel.d.ts +7 -0
- package/dist/types/vector/VectorEditorShapeRenderer.d.ts +9 -0
- package/dist/types/vector/VectorEditorStatusBar.d.ts +9 -0
- package/dist/types/vector/VectorFilterPanel.d.ts +19 -0
- package/dist/types/vector/VectorPatternPanel.d.ts +21 -0
- package/dist/types/vector/pathSimplification.d.ts +135 -0
- package/dist/types/vector/pdfExport.d.ts +65 -0
- package/dist/types/vector/textOnPath.d.ts +145 -0
- package/dist/types/vector/useVectorEditor.d.ts +90 -0
- package/dist/types/vector/vectorBooleanOps.d.ts +22 -0
- package/dist/types/vector/vectorEditorExport.d.ts +8 -0
- package/dist/types/vector/vectorEditorImport.d.ts +7 -0
- package/dist/types/vector/vectorEditorTypes.d.ts +47 -0
- package/dist/types/vector/vectorGradients.d.ts +64 -0
- package/dist/types/vector/vectorPatternFills.d.ts +101 -0
- package/dist/types/vector/vectorSvgFilters.d.ts +134 -0
- package/package.json +93 -0
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* fixes.ts — Bug fixes and performance patches for editors.
|
|
3
|
+
*
|
|
4
|
+
* - PhotoEditor: Retina/HiDPI canvas devicePixelRatio handling
|
|
5
|
+
* - VectorEditor: Shape virtualization for >100 shapes
|
|
6
|
+
* - AnimationEditor: Memory leak prevention (raf/timer cleanup)
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* Configure a canvas for Retina/HiDPI displays.
|
|
10
|
+
* Scales the backing store while keeping CSS dimensions intact.
|
|
11
|
+
*/
|
|
12
|
+
function setupRetinaCanvas(canvas, options) {
|
|
13
|
+
var _a;
|
|
14
|
+
const dpr = (_a = options.dpr) !== null && _a !== void 0 ? _a : (typeof window !== "undefined" ? window.devicePixelRatio : 1);
|
|
15
|
+
canvas.width = Math.round(options.width * dpr);
|
|
16
|
+
canvas.height = Math.round(options.height * dpr);
|
|
17
|
+
canvas.style.width = `${options.width}px`;
|
|
18
|
+
canvas.style.height = `${options.height}px`;
|
|
19
|
+
const ctx = canvas.getContext("2d");
|
|
20
|
+
ctx.scale(dpr, dpr);
|
|
21
|
+
return ctx;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Get the correct mouse position on a Retina canvas.
|
|
25
|
+
*/
|
|
26
|
+
function retinaMousePosition(e, canvas) {
|
|
27
|
+
const rect = canvas.getBoundingClientRect();
|
|
28
|
+
return {
|
|
29
|
+
x: e.clientX - rect.left,
|
|
30
|
+
y: e.clientY - rect.top,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Given a list of shapes with bounding boxes and a visible viewport,
|
|
35
|
+
* returns only the shapes intersecting the viewport.
|
|
36
|
+
*/
|
|
37
|
+
function virtualizeShapes(shapes, viewport, margin = 50) {
|
|
38
|
+
const vx = viewport.x - margin;
|
|
39
|
+
const vy = viewport.y - margin;
|
|
40
|
+
const vr = viewport.x + viewport.width + margin;
|
|
41
|
+
const vb = viewport.y + viewport.height + margin;
|
|
42
|
+
return shapes
|
|
43
|
+
.filter(({ bounds: b }) => {
|
|
44
|
+
const bx2 = b.x + b.width;
|
|
45
|
+
const by2 = b.y + b.height;
|
|
46
|
+
return bx2 >= vx && b.x <= vr && by2 >= vy && b.y <= vb;
|
|
47
|
+
})
|
|
48
|
+
.map(({ shape }) => shape);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Spatial hash grid for fast shape lookup.
|
|
52
|
+
* Greatly speeds up rendering and hit-testing with many shapes.
|
|
53
|
+
*/
|
|
54
|
+
class SpatialHashGrid {
|
|
55
|
+
constructor(cellSize = 200) {
|
|
56
|
+
this.cellSize = cellSize;
|
|
57
|
+
this.cells = new Map();
|
|
58
|
+
}
|
|
59
|
+
cellKey(cx, cy) {
|
|
60
|
+
return `${cx},${cy}`;
|
|
61
|
+
}
|
|
62
|
+
/** Insert a shape into the grid. */
|
|
63
|
+
insert(shape, bounds) {
|
|
64
|
+
const x0 = Math.floor(bounds.x / this.cellSize);
|
|
65
|
+
const y0 = Math.floor(bounds.y / this.cellSize);
|
|
66
|
+
const x1 = Math.floor((bounds.x + bounds.width) / this.cellSize);
|
|
67
|
+
const y1 = Math.floor((bounds.y + bounds.height) / this.cellSize);
|
|
68
|
+
const vs = { shape, bounds };
|
|
69
|
+
for (let cx = x0; cx <= x1; cx++) {
|
|
70
|
+
for (let cy = y0; cy <= y1; cy++) {
|
|
71
|
+
const key = this.cellKey(cx, cy);
|
|
72
|
+
const cell = this.cells.get(key);
|
|
73
|
+
if (cell)
|
|
74
|
+
cell.push(vs);
|
|
75
|
+
else
|
|
76
|
+
this.cells.set(key, [vs]);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/** Query shapes overlapping the given viewport. */
|
|
81
|
+
query(viewport) {
|
|
82
|
+
const x0 = Math.floor(viewport.x / this.cellSize);
|
|
83
|
+
const y0 = Math.floor(viewport.y / this.cellSize);
|
|
84
|
+
const x1 = Math.floor((viewport.x + viewport.width) / this.cellSize);
|
|
85
|
+
const y1 = Math.floor((viewport.y + viewport.height) / this.cellSize);
|
|
86
|
+
const seen = new Set();
|
|
87
|
+
const result = [];
|
|
88
|
+
for (let cx = x0; cx <= x1; cx++) {
|
|
89
|
+
for (let cy = y0; cy <= y1; cy++) {
|
|
90
|
+
const cell = this.cells.get(this.cellKey(cx, cy));
|
|
91
|
+
if (!cell)
|
|
92
|
+
continue;
|
|
93
|
+
for (const vs of cell) {
|
|
94
|
+
if (!seen.has(vs.shape)) {
|
|
95
|
+
seen.add(vs.shape);
|
|
96
|
+
result.push(vs.shape);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return result;
|
|
102
|
+
}
|
|
103
|
+
/** Remove all shapes from the grid. */
|
|
104
|
+
clear() {
|
|
105
|
+
this.cells.clear();
|
|
106
|
+
}
|
|
107
|
+
/** Rebuild the grid from a list of shapes. */
|
|
108
|
+
rebuild(shapes) {
|
|
109
|
+
this.clear();
|
|
110
|
+
for (const vs of shapes)
|
|
111
|
+
this.insert(vs.shape, vs.bounds);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
// ── Animation Memory Leak Prevention ────────────────────────────
|
|
115
|
+
/**
|
|
116
|
+
* Track requestAnimationFrame IDs and timers for proper cleanup.
|
|
117
|
+
*/
|
|
118
|
+
class AnimationCleanup {
|
|
119
|
+
constructor() {
|
|
120
|
+
this.rafIds = new Set();
|
|
121
|
+
this.timerIds = new Set();
|
|
122
|
+
this.intervalIds = new Set();
|
|
123
|
+
this.disposed = false;
|
|
124
|
+
}
|
|
125
|
+
/** Wraps requestAnimationFrame with tracking. */
|
|
126
|
+
requestAnimationFrame(cb) {
|
|
127
|
+
if (this.disposed)
|
|
128
|
+
return -1;
|
|
129
|
+
const id = window.requestAnimationFrame((time) => {
|
|
130
|
+
this.rafIds.delete(id);
|
|
131
|
+
if (!this.disposed)
|
|
132
|
+
cb(time);
|
|
133
|
+
});
|
|
134
|
+
this.rafIds.add(id);
|
|
135
|
+
return id;
|
|
136
|
+
}
|
|
137
|
+
/** Wraps setTimeout with tracking. */
|
|
138
|
+
setTimeout(cb, ms) {
|
|
139
|
+
if (this.disposed)
|
|
140
|
+
return null;
|
|
141
|
+
const id = setTimeout(() => {
|
|
142
|
+
this.timerIds.delete(id);
|
|
143
|
+
if (!this.disposed)
|
|
144
|
+
cb();
|
|
145
|
+
}, ms);
|
|
146
|
+
this.timerIds.add(id);
|
|
147
|
+
return id;
|
|
148
|
+
}
|
|
149
|
+
/** Wraps setInterval with tracking. */
|
|
150
|
+
setInterval(cb, ms) {
|
|
151
|
+
if (this.disposed)
|
|
152
|
+
return null;
|
|
153
|
+
const id = setInterval(() => {
|
|
154
|
+
if (this.disposed) {
|
|
155
|
+
clearInterval(id);
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
cb();
|
|
159
|
+
}, ms);
|
|
160
|
+
this.intervalIds.add(id);
|
|
161
|
+
return id;
|
|
162
|
+
}
|
|
163
|
+
/** Cancel all tracked timers and animation frames. */
|
|
164
|
+
dispose() {
|
|
165
|
+
this.disposed = true;
|
|
166
|
+
for (const id of this.rafIds)
|
|
167
|
+
window.cancelAnimationFrame(id);
|
|
168
|
+
for (const id of this.timerIds)
|
|
169
|
+
clearTimeout(id);
|
|
170
|
+
for (const id of this.intervalIds)
|
|
171
|
+
clearInterval(id);
|
|
172
|
+
this.rafIds.clear();
|
|
173
|
+
this.timerIds.clear();
|
|
174
|
+
this.intervalIds.clear();
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
export { AnimationCleanup, SpatialHashGrid, retinaMousePosition, setupRetinaCanvas, virtualizeShapes };
|
|
179
|
+
//# sourceMappingURL=fixes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fixes.js","sources":["../../../src/core/fixes.ts"],"sourcesContent":[null],"names":[],"mappings":"AAAA;;;;;;AAMG;AAaH;;;AAGG;AACG,SAAU,iBAAiB,CAC/B,MAAyB,EACzB,OAA4B,EAAA;;IAE5B,MAAM,GAAG,GAAG,CAAA,EAAA,GAAA,OAAO,CAAC,GAAG,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,IAAK,OAAO,MAAM,KAAK,WAAW,GAAG,MAAM,CAAC,gBAAgB,GAAG,CAAC,CAAC;AACxF,IAAA,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,GAAG,CAAC;AAC9C,IAAA,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,CAAC;IAChD,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,OAAO,CAAC,KAAK,CAAA,EAAA,CAAI;IACzC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAA,EAAA,CAAI;IAE3C,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAE;AACpC,IAAA,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AACnB,IAAA,OAAO,GAAG;AACZ;AAEA;;AAEG;AACG,SAAU,mBAAmB,CACjC,CAAoD,EACpD,MAAyB,EAAA;AAEzB,IAAA,MAAM,IAAI,GAAG,MAAM,CAAC,qBAAqB,EAAE;IAC3C,OAAO;AACL,QAAA,CAAC,EAAE,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI;AACxB,QAAA,CAAC,EAAE,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG;KACxB;AACH;AAgBA;;;AAGG;AACG,SAAU,gBAAgB,CAC9B,MAA6B,EAC7B,QAAuB,EACvB,MAAM,GAAG,EAAE,EAAA;AAEX,IAAA,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,MAAM;AAC9B,IAAA,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,MAAM;IAC9B,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,GAAG,MAAM;IAC/C,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,MAAM;AAEhD,IAAA,OAAO;SACJ,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,KAAI;QACxB,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK;QACzB,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM;AAC1B,QAAA,OAAO,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE;AACzD,IAAA,CAAC;SACA,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,KAAK,CAAC;AAC9B;AAEA;;;AAGG;MACU,eAAe,CAAA;AAG1B,IAAA,WAAA,CAAoB,WAAW,GAAG,EAAA;QAAd,IAAA,CAAA,QAAQ,GAAR,QAAQ;AAFpB,QAAA,IAAA,CAAA,KAAK,GAAG,IAAI,GAAG,EAAiC;IAEnB;IAE7B,OAAO,CAAC,EAAU,EAAE,EAAU,EAAA;AACpC,QAAA,OAAO,CAAA,EAAG,EAAE,CAAA,CAAA,EAAI,EAAE,EAAE;IACtB;;IAGA,MAAM,CAAC,KAAQ,EAAE,MAAqB,EAAA;AACpC,QAAA,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;AAC/C,QAAA,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/C,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC;QAChE,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC;AAEjE,QAAA,MAAM,EAAE,GAAwB,EAAE,KAAK,EAAE,MAAM,EAAE;AACjD,QAAA,KAAK,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE;AAChC,YAAA,KAAK,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE;gBAChC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC;gBAChC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC;AAChC,gBAAA,IAAI,IAAI;AAAE,oBAAA,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;;oBAClB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;YAChC;QACF;IACF;;AAGA,IAAA,KAAK,CAAC,QAAuB,EAAA;AAC3B,QAAA,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;AACjD,QAAA,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;QACjD,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC;QACpE,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC;AAErE,QAAA,MAAM,IAAI,GAAG,IAAI,GAAG,EAAK;QACzB,MAAM,MAAM,GAAQ,EAAE;AAEtB,QAAA,KAAK,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE;AAChC,YAAA,KAAK,IAAI,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE;AAChC,gBAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;AACjD,gBAAA,IAAI,CAAC,IAAI;oBAAE;AACX,gBAAA,KAAK,MAAM,EAAE,IAAI,IAAI,EAAE;oBACrB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE;AACvB,wBAAA,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC;AAClB,wBAAA,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;oBACvB;gBACF;YACF;QACF;AACA,QAAA,OAAO,MAAM;IACf;;IAGA,KAAK,GAAA;AACH,QAAA,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;IACpB;;AAGA,IAAA,OAAO,CAAC,MAA6B,EAAA;QACnC,IAAI,CAAC,KAAK,EAAE;QACZ,KAAK,MAAM,EAAE,IAAI,MAAM;YAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC;IAC3D;AACD;AAED;AAEA;;AAEG;MACU,gBAAgB,CAAA;AAA7B,IAAA,WAAA,GAAA;AACU,QAAA,IAAA,CAAA,MAAM,GAAG,IAAI,GAAG,EAAU;AAC1B,QAAA,IAAA,CAAA,QAAQ,GAAG,IAAI,GAAG,EAAiC;AACnD,QAAA,IAAA,CAAA,WAAW,GAAG,IAAI,GAAG,EAAkC;QACvD,IAAA,CAAA,QAAQ,GAAG,KAAK;IAgD1B;;AA7CE,IAAA,qBAAqB,CAAC,EAAwB,EAAA;QAC5C,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO,EAAE;QAC5B,MAAM,EAAE,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC,IAAI,KAAI;AAC/C,YAAA,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;YACtB,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAAE,EAAE,CAAC,IAAI,CAAC;AAC9B,QAAA,CAAC,CAAC;AACF,QAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;AACnB,QAAA,OAAO,EAAE;IACX;;IAGA,UAAU,CAAC,EAAc,EAAE,EAAU,EAAA;QACnC,IAAI,IAAI,CAAC,QAAQ;AAAE,YAAA,OAAO,IAAgD;AAC1E,QAAA,MAAM,EAAE,GAAG,UAAU,CAAC,MAAK;AACzB,YAAA,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,QAAQ;AAAE,gBAAA,EAAE,EAAE;QAC1B,CAAC,EAAE,EAAE,CAAC;AACN,QAAA,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;AACrB,QAAA,OAAO,EAAE;IACX;;IAGA,WAAW,CAAC,EAAc,EAAE,EAAU,EAAA;QACpC,IAAI,IAAI,CAAC,QAAQ;AAAE,YAAA,OAAO,IAAiD;AAC3E,QAAA,MAAM,EAAE,GAAG,WAAW,CAAC,MAAK;AAC1B,YAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,aAAa,CAAC,EAAE,CAAC;gBACjB;YACF;AACA,YAAA,EAAE,EAAE;QACN,CAAC,EAAE,EAAE,CAAC;AACN,QAAA,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;AACxB,QAAA,OAAO,EAAE;IACX;;IAGA,OAAO,GAAA;AACL,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI;AACpB,QAAA,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,MAAM;AAAE,YAAA,MAAM,CAAC,oBAAoB,CAAC,EAAE,CAAC;AAC7D,QAAA,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,QAAQ;YAAE,YAAY,CAAC,EAAE,CAAC;AAChD,QAAA,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,WAAW;YAAE,aAAa,CAAC,EAAE,CAAC;AACpD,QAAA,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;AACnB,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE;AACrB,QAAA,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;IAC1B;AACD;;;;"}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* gridGuides.ts — Grid, guides, rulers, and snap-to-grid/pixel for editors.
|
|
3
|
+
*
|
|
4
|
+
* Unified system for drawing grids, ruler bars, snapping to grid,
|
|
5
|
+
* and managing user-defined guide lines.
|
|
6
|
+
*/
|
|
7
|
+
// ── Default Config ──────────────────────────────────────────────
|
|
8
|
+
// ── Grid Rendering ──────────────────────────────────────────────
|
|
9
|
+
/** Draw a grid on a canvas context. */
|
|
10
|
+
function drawGrid(ctx, width, height, config, offsetX = 0, offsetY = 0, zoom = 1) {
|
|
11
|
+
if (!config.enabled)
|
|
12
|
+
return;
|
|
13
|
+
const gridSize = config.size * zoom;
|
|
14
|
+
const subSize = gridSize / config.subdivisions;
|
|
15
|
+
ctx.save();
|
|
16
|
+
ctx.globalAlpha = config.opacity;
|
|
17
|
+
// Sub-grid
|
|
18
|
+
if (config.subdivisions > 1 && subSize >= 3) {
|
|
19
|
+
ctx.strokeStyle = config.subColor;
|
|
20
|
+
ctx.lineWidth = 0.5;
|
|
21
|
+
ctx.beginPath();
|
|
22
|
+
const startX = -(offsetX % subSize);
|
|
23
|
+
const startY = -(offsetY % subSize);
|
|
24
|
+
for (let x = startX; x <= width; x += subSize) {
|
|
25
|
+
ctx.moveTo(Math.round(x) + 0.5, 0);
|
|
26
|
+
ctx.lineTo(Math.round(x) + 0.5, height);
|
|
27
|
+
}
|
|
28
|
+
for (let y = startY; y <= height; y += subSize) {
|
|
29
|
+
ctx.moveTo(0, Math.round(y) + 0.5);
|
|
30
|
+
ctx.lineTo(width, Math.round(y) + 0.5);
|
|
31
|
+
}
|
|
32
|
+
ctx.stroke();
|
|
33
|
+
}
|
|
34
|
+
// Main grid
|
|
35
|
+
ctx.strokeStyle = config.color;
|
|
36
|
+
ctx.lineWidth = 1;
|
|
37
|
+
ctx.beginPath();
|
|
38
|
+
const mainStartX = -(offsetX % gridSize);
|
|
39
|
+
const mainStartY = -(offsetY % gridSize);
|
|
40
|
+
for (let x = mainStartX; x <= width; x += gridSize) {
|
|
41
|
+
ctx.moveTo(Math.round(x) + 0.5, 0);
|
|
42
|
+
ctx.lineTo(Math.round(x) + 0.5, height);
|
|
43
|
+
}
|
|
44
|
+
for (let y = mainStartY; y <= height; y += gridSize) {
|
|
45
|
+
ctx.moveTo(0, Math.round(y) + 0.5);
|
|
46
|
+
ctx.lineTo(width, Math.round(y) + 0.5);
|
|
47
|
+
}
|
|
48
|
+
ctx.stroke();
|
|
49
|
+
ctx.restore();
|
|
50
|
+
}
|
|
51
|
+
// ── Ruler Rendering ─────────────────────────────────────────────
|
|
52
|
+
/** Draw horizontal ruler bar. */
|
|
53
|
+
function drawHorizontalRuler(ctx, width, config, offsetX = 0, zoom = 1) {
|
|
54
|
+
if (!config.enabled)
|
|
55
|
+
return;
|
|
56
|
+
ctx.save();
|
|
57
|
+
ctx.fillStyle = config.backgroundColor;
|
|
58
|
+
ctx.fillRect(0, 0, width, config.size);
|
|
59
|
+
const step = calculateRulerStep(zoom);
|
|
60
|
+
ctx.strokeStyle = config.color;
|
|
61
|
+
ctx.fillStyle = config.textColor;
|
|
62
|
+
ctx.font = "9px monospace";
|
|
63
|
+
ctx.textAlign = "center";
|
|
64
|
+
const startX = Math.floor(-offsetX / (step * zoom)) * step;
|
|
65
|
+
const endX = startX + width / zoom + step;
|
|
66
|
+
for (let val = startX; val <= endX; val += step) {
|
|
67
|
+
const x = (val + offsetX / zoom) * zoom;
|
|
68
|
+
if (x < 0 || x > width)
|
|
69
|
+
continue;
|
|
70
|
+
// Major tick
|
|
71
|
+
ctx.beginPath();
|
|
72
|
+
ctx.moveTo(Math.round(x) + 0.5, config.size);
|
|
73
|
+
ctx.lineTo(Math.round(x) + 0.5, config.size - config.tickSize * 2);
|
|
74
|
+
ctx.stroke();
|
|
75
|
+
ctx.fillText(String(Math.round(val)), x, config.size - config.tickSize * 2 - 2);
|
|
76
|
+
// Minor ticks
|
|
77
|
+
for (let m = 1; m < 5; m++) {
|
|
78
|
+
const mx = ((val + (step * m) / 5) + offsetX / zoom) * zoom;
|
|
79
|
+
if (mx < 0 || mx > width)
|
|
80
|
+
continue;
|
|
81
|
+
ctx.beginPath();
|
|
82
|
+
ctx.moveTo(Math.round(mx) + 0.5, config.size);
|
|
83
|
+
ctx.lineTo(Math.round(mx) + 0.5, config.size - config.tickSize);
|
|
84
|
+
ctx.stroke();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
ctx.restore();
|
|
88
|
+
}
|
|
89
|
+
/** Draw vertical ruler bar. */
|
|
90
|
+
function drawVerticalRuler(ctx, height, config, offsetY = 0, zoom = 1) {
|
|
91
|
+
if (!config.enabled)
|
|
92
|
+
return;
|
|
93
|
+
ctx.save();
|
|
94
|
+
ctx.fillStyle = config.backgroundColor;
|
|
95
|
+
ctx.fillRect(0, 0, config.size, height);
|
|
96
|
+
const step = calculateRulerStep(zoom);
|
|
97
|
+
ctx.strokeStyle = config.color;
|
|
98
|
+
ctx.fillStyle = config.textColor;
|
|
99
|
+
ctx.font = "9px monospace";
|
|
100
|
+
const startY = Math.floor(-offsetY / (step * zoom)) * step;
|
|
101
|
+
const endY = startY + height / zoom + step;
|
|
102
|
+
for (let val = startY; val <= endY; val += step) {
|
|
103
|
+
const y = (val + offsetY / zoom) * zoom;
|
|
104
|
+
if (y < 0 || y > height)
|
|
105
|
+
continue;
|
|
106
|
+
ctx.beginPath();
|
|
107
|
+
ctx.moveTo(config.size, Math.round(y) + 0.5);
|
|
108
|
+
ctx.lineTo(config.size - config.tickSize * 2, Math.round(y) + 0.5);
|
|
109
|
+
ctx.stroke();
|
|
110
|
+
// Rotated text
|
|
111
|
+
ctx.save();
|
|
112
|
+
ctx.translate(config.size - config.tickSize * 2 - 2, y);
|
|
113
|
+
ctx.rotate(-Math.PI / 2);
|
|
114
|
+
ctx.textAlign = "center";
|
|
115
|
+
ctx.fillText(String(Math.round(val)), 0, 0);
|
|
116
|
+
ctx.restore();
|
|
117
|
+
}
|
|
118
|
+
ctx.restore();
|
|
119
|
+
}
|
|
120
|
+
function calculateRulerStep(zoom) {
|
|
121
|
+
var _a;
|
|
122
|
+
const idealStep = 50 / zoom;
|
|
123
|
+
const magnitude = Math.pow(10, Math.floor(Math.log10(idealStep)));
|
|
124
|
+
const candidates = [1, 2, 5, 10].map((m) => m * magnitude);
|
|
125
|
+
return (_a = candidates.find((c) => c >= idealStep)) !== null && _a !== void 0 ? _a : idealStep;
|
|
126
|
+
}
|
|
127
|
+
// ── Guide Rendering ─────────────────────────────────────────────
|
|
128
|
+
/** Draw guides on a canvas context. */
|
|
129
|
+
function drawGuides(ctx, width, height, config, offsetX = 0, offsetY = 0, zoom = 1) {
|
|
130
|
+
if (!config.enabled)
|
|
131
|
+
return;
|
|
132
|
+
ctx.save();
|
|
133
|
+
ctx.setLineDash([6, 3]);
|
|
134
|
+
ctx.lineWidth = 1;
|
|
135
|
+
for (const guide of config.guides) {
|
|
136
|
+
ctx.strokeStyle = guide.color || config.color;
|
|
137
|
+
ctx.beginPath();
|
|
138
|
+
if (guide.orientation === "horizontal") {
|
|
139
|
+
const y = (guide.position + offsetY / zoom) * zoom;
|
|
140
|
+
ctx.moveTo(0, Math.round(y) + 0.5);
|
|
141
|
+
ctx.lineTo(width, Math.round(y) + 0.5);
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
const x = (guide.position + offsetX / zoom) * zoom;
|
|
145
|
+
ctx.moveTo(Math.round(x) + 0.5, 0);
|
|
146
|
+
ctx.lineTo(Math.round(x) + 0.5, height);
|
|
147
|
+
}
|
|
148
|
+
ctx.stroke();
|
|
149
|
+
}
|
|
150
|
+
ctx.setLineDash([]);
|
|
151
|
+
ctx.restore();
|
|
152
|
+
}
|
|
153
|
+
// ── Snapping ────────────────────────────────────────────────────
|
|
154
|
+
/** Snap a point to the grid. */
|
|
155
|
+
function snapToGrid(x, y, gridSize) {
|
|
156
|
+
return {
|
|
157
|
+
x: Math.round(x / gridSize) * gridSize,
|
|
158
|
+
y: Math.round(y / gridSize) * gridSize,
|
|
159
|
+
snappedX: true,
|
|
160
|
+
snappedY: true,
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
/** Snap a point to nearby guides. */
|
|
164
|
+
function snapToGuides(x, y, guides, snapDistance) {
|
|
165
|
+
let sx = x, sy = y;
|
|
166
|
+
let snappedX = false, snappedY = false;
|
|
167
|
+
for (const guide of guides) {
|
|
168
|
+
if (guide.orientation === "vertical") {
|
|
169
|
+
if (Math.abs(x - guide.position) <= snapDistance) {
|
|
170
|
+
sx = guide.position;
|
|
171
|
+
snappedX = true;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
if (Math.abs(y - guide.position) <= snapDistance) {
|
|
176
|
+
sy = guide.position;
|
|
177
|
+
snappedY = true;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
return { x: sx, y: sy, snappedX, snappedY };
|
|
182
|
+
}
|
|
183
|
+
/** Snap to pixel (floor to nearest integer). */
|
|
184
|
+
function snapToPixel(x, y) {
|
|
185
|
+
return {
|
|
186
|
+
x: Math.round(x),
|
|
187
|
+
y: Math.round(y),
|
|
188
|
+
snappedX: true,
|
|
189
|
+
snappedY: true,
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
/** Combined snap: try guides first, then grid, then pixel. */
|
|
193
|
+
function snapPoint(x, y, gridConfig, guidesConfig) {
|
|
194
|
+
// Try guides first
|
|
195
|
+
if (guidesConfig.enabled && guidesConfig.snapToGuides) {
|
|
196
|
+
const guideResult = snapToGuides(x, y, guidesConfig.guides, guidesConfig.snapDistance);
|
|
197
|
+
if (guideResult.snappedX || guideResult.snappedY)
|
|
198
|
+
return guideResult;
|
|
199
|
+
}
|
|
200
|
+
// Then grid
|
|
201
|
+
if (gridConfig.enabled && gridConfig.snapToGrid) {
|
|
202
|
+
return snapToGrid(x, y, gridConfig.size);
|
|
203
|
+
}
|
|
204
|
+
return { x, y, snappedX: false, snappedY: false };
|
|
205
|
+
}
|
|
206
|
+
// ── Guide Management ────────────────────────────────────────────
|
|
207
|
+
let nextGuideId = 1;
|
|
208
|
+
/** Create a new guide. */
|
|
209
|
+
function createGuide(orientation, position, color) {
|
|
210
|
+
return {
|
|
211
|
+
id: `guide-${nextGuideId++}`,
|
|
212
|
+
orientation,
|
|
213
|
+
position,
|
|
214
|
+
color: color !== null && color !== void 0 ? color : "rgba(59, 130, 246, 0.6)",
|
|
215
|
+
locked: false,
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
/** Add a guide to the config. */
|
|
219
|
+
function addGuide(config, guide) {
|
|
220
|
+
return { ...config, guides: [...config.guides, guide] };
|
|
221
|
+
}
|
|
222
|
+
/** Remove a guide by ID. */
|
|
223
|
+
function removeGuide(config, guideId) {
|
|
224
|
+
return { ...config, guides: config.guides.filter((g) => g.id !== guideId) };
|
|
225
|
+
}
|
|
226
|
+
/** Clear all guides. */
|
|
227
|
+
function clearGuides(config) {
|
|
228
|
+
return { ...config, guides: [] };
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
export { addGuide, clearGuides, createGuide, drawGrid, drawGuides, drawHorizontalRuler, drawVerticalRuler, removeGuide, snapPoint, snapToGrid, snapToGuides, snapToPixel };
|
|
232
|
+
//# sourceMappingURL=gridGuides.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gridGuides.js","sources":["../../../src/core/gridGuides.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* historyVisual.ts — Visual undo/redo history for editors.
|
|
5
|
+
*
|
|
6
|
+
* Provides a visual timeline showing thumbnails/labels for each history entry,
|
|
7
|
+
* allowing users to click on any point to jump to that state.
|
|
8
|
+
*/
|
|
9
|
+
// ── Hook ────────────────────────────────────────────────────────
|
|
10
|
+
let nextHistoryId = 1;
|
|
11
|
+
/** React hook for visual undo/redo history management. */
|
|
12
|
+
function useVisualHistory(maxEntries = 100) {
|
|
13
|
+
const [state, setState] = React.useState({
|
|
14
|
+
entries: [],
|
|
15
|
+
currentIndex: -1,
|
|
16
|
+
});
|
|
17
|
+
const push = React.useCallback((label, snapshot, thumbnail) => {
|
|
18
|
+
setState((prev) => {
|
|
19
|
+
// Trim redo stack
|
|
20
|
+
const entries = prev.entries.slice(0, prev.currentIndex + 1);
|
|
21
|
+
const entry = {
|
|
22
|
+
id: nextHistoryId++,
|
|
23
|
+
label,
|
|
24
|
+
timestamp: Date.now(),
|
|
25
|
+
thumbnail,
|
|
26
|
+
state: snapshot,
|
|
27
|
+
};
|
|
28
|
+
entries.push(entry);
|
|
29
|
+
// Enforce max
|
|
30
|
+
while (entries.length > maxEntries)
|
|
31
|
+
entries.shift();
|
|
32
|
+
return { entries, currentIndex: entries.length - 1 };
|
|
33
|
+
});
|
|
34
|
+
}, [maxEntries]);
|
|
35
|
+
const undo = React.useCallback(() => {
|
|
36
|
+
let result = null;
|
|
37
|
+
setState((prev) => {
|
|
38
|
+
if (prev.currentIndex <= 0)
|
|
39
|
+
return prev;
|
|
40
|
+
const newIndex = prev.currentIndex - 1;
|
|
41
|
+
result = prev.entries[newIndex].state;
|
|
42
|
+
return { ...prev, currentIndex: newIndex };
|
|
43
|
+
});
|
|
44
|
+
return result;
|
|
45
|
+
}, []);
|
|
46
|
+
const redo = React.useCallback(() => {
|
|
47
|
+
let result = null;
|
|
48
|
+
setState((prev) => {
|
|
49
|
+
if (prev.currentIndex >= prev.entries.length - 1)
|
|
50
|
+
return prev;
|
|
51
|
+
const newIndex = prev.currentIndex + 1;
|
|
52
|
+
result = prev.entries[newIndex].state;
|
|
53
|
+
return { ...prev, currentIndex: newIndex };
|
|
54
|
+
});
|
|
55
|
+
return result;
|
|
56
|
+
}, []);
|
|
57
|
+
const jumpTo = React.useCallback((index) => {
|
|
58
|
+
let result = null;
|
|
59
|
+
setState((prev) => {
|
|
60
|
+
if (index < 0 || index >= prev.entries.length)
|
|
61
|
+
return prev;
|
|
62
|
+
result = prev.entries[index].state;
|
|
63
|
+
return { ...prev, currentIndex: index };
|
|
64
|
+
});
|
|
65
|
+
return result;
|
|
66
|
+
}, []);
|
|
67
|
+
const clear = React.useCallback(() => {
|
|
68
|
+
setState({ entries: [], currentIndex: -1 });
|
|
69
|
+
}, []);
|
|
70
|
+
return {
|
|
71
|
+
push,
|
|
72
|
+
undo,
|
|
73
|
+
redo,
|
|
74
|
+
jumpTo,
|
|
75
|
+
getState: () => state,
|
|
76
|
+
canUndo: state.currentIndex > 0,
|
|
77
|
+
canRedo: state.currentIndex < state.entries.length - 1,
|
|
78
|
+
count: state.entries.length,
|
|
79
|
+
currentIndex: state.currentIndex,
|
|
80
|
+
entries: state.entries,
|
|
81
|
+
clear,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
/** Visual history timeline panel showing entries with thumbnails. */
|
|
85
|
+
function VisualHistoryPanel({ history, onJump, className = "", style, }) {
|
|
86
|
+
const handleClick = (index) => {
|
|
87
|
+
const state = history.jumpTo(index);
|
|
88
|
+
if (state !== null && onJump)
|
|
89
|
+
onJump(state);
|
|
90
|
+
};
|
|
91
|
+
return React.createElement("div", {
|
|
92
|
+
className: `nice-visual-history ${className}`,
|
|
93
|
+
style: { display: "flex", flexDirection: "column", gap: 2, padding: 4, ...style },
|
|
94
|
+
}, React.createElement("div", {
|
|
95
|
+
style: { display: "flex", justifyContent: "space-between", marginBottom: 4, fontSize: 11 },
|
|
96
|
+
}, React.createElement("strong", null, "History"), React.createElement("span", { style: { opacity: 0.6 } }, `${history.currentIndex + 1} / ${history.count}`)), React.createElement("div", {
|
|
97
|
+
style: { display: "flex", flexDirection: "column", gap: 1, overflowY: "auto", maxHeight: 300 },
|
|
98
|
+
}, history.entries.map((entry, idx) => React.createElement("div", {
|
|
99
|
+
key: entry.id,
|
|
100
|
+
onClick: () => handleClick(idx),
|
|
101
|
+
style: {
|
|
102
|
+
display: "flex",
|
|
103
|
+
alignItems: "center",
|
|
104
|
+
gap: 4,
|
|
105
|
+
padding: "3px 6px",
|
|
106
|
+
cursor: "pointer",
|
|
107
|
+
fontSize: 11,
|
|
108
|
+
borderRadius: 3,
|
|
109
|
+
background: idx === history.currentIndex ? "rgba(59,130,246,0.15)" : "transparent",
|
|
110
|
+
fontWeight: idx === history.currentIndex ? 600 : 400,
|
|
111
|
+
opacity: idx > history.currentIndex ? 0.4 : 1,
|
|
112
|
+
},
|
|
113
|
+
}, entry.thumbnail && React.createElement("img", {
|
|
114
|
+
src: entry.thumbnail,
|
|
115
|
+
alt: "",
|
|
116
|
+
style: { width: 24, height: 24, borderRadius: 2, objectFit: "cover" },
|
|
117
|
+
}), React.createElement("span", { style: { flex: 1, overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" } }, entry.label)))));
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
export { VisualHistoryPanel, useVisualHistory };
|
|
121
|
+
//# sourceMappingURL=historyVisual.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"historyVisual.js","sources":["../../../src/core/historyVisual.ts"],"sourcesContent":[null],"names":[],"mappings":";;AAAA;;;;;AAKG;AA6CH;AAEA,IAAI,aAAa,GAAG,CAAC;AAErB;AACM,SAAU,gBAAgB,CAAI,UAAU,GAAG,GAAG,EAAA;IAClD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAwB;AAC9D,QAAA,OAAO,EAAE,EAAE;QACX,YAAY,EAAE,EAAE;AACjB,KAAA,CAAC;AAEF,IAAA,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,KAAa,EAAE,QAAW,EAAE,SAAkB,KAAI;AAChF,QAAA,QAAQ,CAAC,CAAC,IAAI,KAAI;;AAEhB,YAAA,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;AAC5D,YAAA,MAAM,KAAK,GAAoB;gBAC7B,EAAE,EAAE,aAAa,EAAE;gBACnB,KAAK;AACL,gBAAA,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;gBACrB,SAAS;AACT,gBAAA,KAAK,EAAE,QAAQ;aAChB;AACD,YAAA,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;;AAEnB,YAAA,OAAO,OAAO,CAAC,MAAM,GAAG,UAAU;gBAAE,OAAO,CAAC,KAAK,EAAE;YACnD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;AACtD,QAAA,CAAC,CAAC;AACJ,IAAA,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC;AAEhB,IAAA,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC,MAAe;QAC5C,IAAI,MAAM,GAAa,IAAI;AAC3B,QAAA,QAAQ,CAAC,CAAC,IAAI,KAAI;AAChB,YAAA,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC;AAAE,gBAAA,OAAO,IAAI;AACvC,YAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,GAAG,CAAC;YACtC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK;YACrC,OAAO,EAAE,GAAG,IAAI,EAAE,YAAY,EAAE,QAAQ,EAAE;AAC5C,QAAA,CAAC,CAAC;AACF,QAAA,OAAO,MAAM;IACf,CAAC,EAAE,EAAE,CAAC;AAEN,IAAA,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC,MAAe;QAC5C,IAAI,MAAM,GAAa,IAAI;AAC3B,QAAA,QAAQ,CAAC,CAAC,IAAI,KAAI;YAChB,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC;AAAE,gBAAA,OAAO,IAAI;AAC7D,YAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,GAAG,CAAC;YACtC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK;YACrC,OAAO,EAAE,GAAG,IAAI,EAAE,YAAY,EAAE,QAAQ,EAAE;AAC5C,QAAA,CAAC,CAAC;AACF,QAAA,OAAO,MAAM;IACf,CAAC,EAAE,EAAE,CAAC;IAEN,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,KAAa,KAAc;QAC3D,IAAI,MAAM,GAAa,IAAI;AAC3B,QAAA,QAAQ,CAAC,CAAC,IAAI,KAAI;YAChB,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM;AAAE,gBAAA,OAAO,IAAI;YAC1D,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK;YAClC,OAAO,EAAE,GAAG,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE;AACzC,QAAA,CAAC,CAAC;AACF,QAAA,OAAO,MAAM;IACf,CAAC,EAAE,EAAE,CAAC;AAEN,IAAA,MAAM,KAAK,GAAG,KAAK,CAAC,WAAW,CAAC,MAAK;AACnC,QAAA,QAAQ,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC;IAC7C,CAAC,EAAE,EAAE,CAAC;IAEN,OAAO;QACL,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,MAAM;AACN,QAAA,QAAQ,EAAE,MAAM,KAAK;AACrB,QAAA,OAAO,EAAE,KAAK,CAAC,YAAY,GAAG,CAAC;QAC/B,OAAO,EAAE,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC;AACtD,QAAA,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM;QAC3B,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,KAAK;KACN;AACH;AAWA;AACM,SAAU,kBAAkB,CAAI,EACpC,OAAO,EACP,MAAM,EACN,SAAS,GAAG,EAAE,EACd,KAAK,GACsB,EAAA;AAC3B,IAAA,MAAM,WAAW,GAAG,CAAC,KAAa,KAAI;QACpC,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;AACnC,QAAA,IAAI,KAAK,KAAK,IAAI,IAAI,MAAM;YAAE,MAAM,CAAC,KAAK,CAAC;AAC7C,IAAA,CAAC;AAED,IAAA,OAAO,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QAChC,SAAS,EAAE,CAAA,oBAAA,EAAuB,SAAS,CAAA,CAAE;QAC7C,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,KAAK,EAAE;AAClF,KAAA,EACC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AACzB,QAAA,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,eAAe,EAAE,YAAY,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;KAC3F,EACC,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,EAAE,SAAS,CAAC,EAC9C,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE,EACrD,CAAA,EAAG,OAAO,CAAC,YAAY,GAAG,CAAC,CAAA,GAAA,EAAM,OAAO,CAAC,KAAK,CAAA,CAAE,CACjD,CACF,EACD,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QACzB,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,EAAE;AAC/F,KAAA,EACC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,KAC7B,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QACzB,GAAG,EAAE,KAAK,CAAC,EAAE;AACb,QAAA,OAAO,EAAE,MAAM,WAAW,CAAC,GAAG,CAAC;AAC/B,QAAA,KAAK,EAAE;AACL,YAAA,OAAO,EAAE,MAAM;AACf,YAAA,UAAU,EAAE,QAAQ;AACpB,YAAA,GAAG,EAAE,CAAC;AACN,YAAA,OAAO,EAAE,SAAS;AAClB,YAAA,MAAM,EAAE,SAAS;AACjB,YAAA,QAAQ,EAAE,EAAE;AACZ,YAAA,YAAY,EAAE,CAAC;AACf,YAAA,UAAU,EAAE,GAAG,KAAK,OAAO,CAAC,YAAY,GAAG,uBAAuB,GAAG,aAAa;AAClF,YAAA,UAAU,EAAE,GAAG,KAAK,OAAO,CAAC,YAAY,GAAG,GAAG,GAAG,GAAG;AACpD,YAAA,OAAO,EAAE,GAAG,GAAG,OAAO,CAAC,YAAY,GAAG,GAAG,GAAG,CAAC;AAC9C,SAAA;KACF,EACC,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QAC5C,GAAG,EAAE,KAAK,CAAC,SAAS;AACpB,QAAA,GAAG,EAAE,EAAE;AACP,QAAA,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE;AACtE,KAAA,CAAC,EACF,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,EAAE,EACpH,KAAK,CAAC,KAAK,CACZ,CACF,CACF,CACF,CACF;AACH;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { createContext, useContext } from 'react';
|
|
3
|
+
|
|
4
|
+
const fallback = (_key, defaultValue) => defaultValue;
|
|
5
|
+
const NiceI18nContext = createContext(fallback);
|
|
6
|
+
const NiceI18nProvider = ({ t, children }) => (jsx(NiceI18nContext.Provider, { value: t, children: children }));
|
|
7
|
+
function useNiceTranslation() {
|
|
8
|
+
const t = useContext(NiceI18nContext);
|
|
9
|
+
return { t };
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export { NiceI18nProvider, useNiceTranslation };
|
|
13
|
+
//# sourceMappingURL=i18n.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"i18n.js","sources":["../../../src/core/i18n.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;AAqBA,MAAM,QAAQ,GAAoB,CAAC,IAAY,EAAE,YAAoB,KAAK,YAAY;AAEtF,MAAM,eAAe,GAAG,aAAa,CAAkB,QAAQ,CAAC;AAOzD,MAAM,gBAAgB,GAAoC,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,MAC/EA,GAAA,CAAC,eAAe,CAAC,QAAQ,EAAA,EAAC,KAAK,EAAE,CAAC,EAAA,QAAA,EAAG,QAAQ,EAAA,CAA4B;SAG3D,kBAAkB,GAAA;AAChC,IAAA,MAAM,CAAC,GAAG,UAAU,CAAC,eAAe,CAAC;IACrC,OAAO,EAAE,CAAC,EAAE;AACd;;;;"}
|