@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,200 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* shortcuts.ts — Customizable keyboard shortcuts for all editors.
|
|
5
|
+
*
|
|
6
|
+
* Allows users to remap keyboard shortcuts and provides a central
|
|
7
|
+
* registry for keybindings across all graphic editors.
|
|
8
|
+
*/
|
|
9
|
+
function parseKeyCombo(combo) {
|
|
10
|
+
var _a;
|
|
11
|
+
const parts = combo.toLowerCase().split("+").map((s) => s.trim());
|
|
12
|
+
return {
|
|
13
|
+
ctrl: parts.includes("ctrl"),
|
|
14
|
+
shift: parts.includes("shift"),
|
|
15
|
+
alt: parts.includes("alt"),
|
|
16
|
+
meta: parts.includes("meta") || parts.includes("cmd"),
|
|
17
|
+
key: (_a = parts.filter((p) => !["ctrl", "shift", "alt", "meta", "cmd"].includes(p))[0]) !== null && _a !== void 0 ? _a : "",
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
function matchesEvent(parsed, e) {
|
|
21
|
+
return (e.ctrlKey === parsed.ctrl &&
|
|
22
|
+
e.shiftKey === parsed.shift &&
|
|
23
|
+
e.altKey === parsed.alt &&
|
|
24
|
+
e.metaKey === parsed.meta &&
|
|
25
|
+
e.key.toLowerCase() === parsed.key);
|
|
26
|
+
}
|
|
27
|
+
/** Convert a keyboard event to a key combo string. */
|
|
28
|
+
function eventToKeyCombo(e) {
|
|
29
|
+
const parts = [];
|
|
30
|
+
if (e.ctrlKey)
|
|
31
|
+
parts.push("Ctrl");
|
|
32
|
+
if (e.shiftKey)
|
|
33
|
+
parts.push("Shift");
|
|
34
|
+
if (e.altKey)
|
|
35
|
+
parts.push("Alt");
|
|
36
|
+
if (e.metaKey)
|
|
37
|
+
parts.push("Meta");
|
|
38
|
+
const key = e.key.length === 1 ? e.key.toUpperCase() : e.key;
|
|
39
|
+
if (!["Control", "Shift", "Alt", "Meta"].includes(e.key)) {
|
|
40
|
+
parts.push(key);
|
|
41
|
+
}
|
|
42
|
+
return parts.join("+");
|
|
43
|
+
}
|
|
44
|
+
// ── Shortcut Registry ───────────────────────────────────────────
|
|
45
|
+
class ShortcutRegistryImpl {
|
|
46
|
+
constructor() {
|
|
47
|
+
this.shortcuts = new Map();
|
|
48
|
+
this.overrides = {};
|
|
49
|
+
this.listeners = new Set();
|
|
50
|
+
}
|
|
51
|
+
/** Register a shortcut. */
|
|
52
|
+
register(def) {
|
|
53
|
+
var _a;
|
|
54
|
+
const currentKey = (_a = this.overrides[def.id]) !== null && _a !== void 0 ? _a : def.defaultKey;
|
|
55
|
+
this.shortcuts.set(def.id, { ...def, currentKey });
|
|
56
|
+
this.notify();
|
|
57
|
+
}
|
|
58
|
+
/** Register multiple shortcuts at once. */
|
|
59
|
+
registerAll(defs) {
|
|
60
|
+
var _a;
|
|
61
|
+
for (const def of defs) {
|
|
62
|
+
const currentKey = (_a = this.overrides[def.id]) !== null && _a !== void 0 ? _a : def.defaultKey;
|
|
63
|
+
this.shortcuts.set(def.id, { ...def, currentKey });
|
|
64
|
+
}
|
|
65
|
+
this.notify();
|
|
66
|
+
}
|
|
67
|
+
/** Unregister a shortcut. */
|
|
68
|
+
unregister(id) {
|
|
69
|
+
this.shortcuts.delete(id);
|
|
70
|
+
this.notify();
|
|
71
|
+
}
|
|
72
|
+
/** Remap a shortcut to a new key combo. */
|
|
73
|
+
remap(id, newKey) {
|
|
74
|
+
const def = this.shortcuts.get(id);
|
|
75
|
+
if (def) {
|
|
76
|
+
def.currentKey = newKey;
|
|
77
|
+
this.overrides[id] = newKey;
|
|
78
|
+
this.notify();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
/** Reset a shortcut to its default. */
|
|
82
|
+
resetToDefault(id) {
|
|
83
|
+
const def = this.shortcuts.get(id);
|
|
84
|
+
if (def) {
|
|
85
|
+
def.currentKey = def.defaultKey;
|
|
86
|
+
delete this.overrides[id];
|
|
87
|
+
this.notify();
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
/** Reset all shortcuts to defaults. */
|
|
91
|
+
resetAll() {
|
|
92
|
+
this.overrides = {};
|
|
93
|
+
for (const def of this.shortcuts.values()) {
|
|
94
|
+
def.currentKey = def.defaultKey;
|
|
95
|
+
}
|
|
96
|
+
this.notify();
|
|
97
|
+
}
|
|
98
|
+
/** Handle a keyboard event, triggering matching shortcuts. */
|
|
99
|
+
handleKeyEvent(e) {
|
|
100
|
+
for (const def of this.shortcuts.values()) {
|
|
101
|
+
const parsed = parseKeyCombo(def.currentKey);
|
|
102
|
+
if (matchesEvent(parsed, e)) {
|
|
103
|
+
e.preventDefault();
|
|
104
|
+
def.action();
|
|
105
|
+
return true;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
/** Get all registered shortcuts. */
|
|
111
|
+
getAll() {
|
|
112
|
+
return Array.from(this.shortcuts.values());
|
|
113
|
+
}
|
|
114
|
+
/** Get shortcuts by category. */
|
|
115
|
+
getByCategory(category) {
|
|
116
|
+
return this.getAll().filter((s) => s.category === category);
|
|
117
|
+
}
|
|
118
|
+
/** Get all categories. */
|
|
119
|
+
getCategories() {
|
|
120
|
+
return [...new Set(this.getAll().map((s) => s.category))];
|
|
121
|
+
}
|
|
122
|
+
/** Export custom overrides as JSON. */
|
|
123
|
+
exportConfig() {
|
|
124
|
+
return { overrides: { ...this.overrides } };
|
|
125
|
+
}
|
|
126
|
+
/** Import custom overrides from JSON. */
|
|
127
|
+
importConfig(config) {
|
|
128
|
+
var _a;
|
|
129
|
+
this.overrides = { ...config.overrides };
|
|
130
|
+
for (const def of this.shortcuts.values()) {
|
|
131
|
+
def.currentKey = (_a = this.overrides[def.id]) !== null && _a !== void 0 ? _a : def.defaultKey;
|
|
132
|
+
}
|
|
133
|
+
this.notify();
|
|
134
|
+
}
|
|
135
|
+
/** Save overrides to localStorage. */
|
|
136
|
+
save(storageKey = "nice2dev.graphics.shortcuts") {
|
|
137
|
+
try {
|
|
138
|
+
localStorage.setItem(storageKey, JSON.stringify(this.exportConfig()));
|
|
139
|
+
}
|
|
140
|
+
catch ( /* ignore */_a) { /* ignore */ }
|
|
141
|
+
}
|
|
142
|
+
/** Load overrides from localStorage. */
|
|
143
|
+
load(storageKey = "nice2dev.graphics.shortcuts") {
|
|
144
|
+
try {
|
|
145
|
+
const raw = localStorage.getItem(storageKey);
|
|
146
|
+
if (raw)
|
|
147
|
+
this.importConfig(JSON.parse(raw));
|
|
148
|
+
}
|
|
149
|
+
catch ( /* ignore */_a) { /* ignore */ }
|
|
150
|
+
}
|
|
151
|
+
/** Subscribe to changes. Returns unsubscribe function. */
|
|
152
|
+
subscribe(fn) {
|
|
153
|
+
this.listeners.add(fn);
|
|
154
|
+
return () => this.listeners.delete(fn);
|
|
155
|
+
}
|
|
156
|
+
notify() {
|
|
157
|
+
this.listeners.forEach((fn) => fn());
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
/** Global shortcuts registry singleton. */
|
|
161
|
+
const ShortcutRegistry = new ShortcutRegistryImpl();
|
|
162
|
+
// ── Default Shortcuts ───────────────────────────────────────────
|
|
163
|
+
const DEFAULT_SHORTCUTS = {
|
|
164
|
+
// General
|
|
165
|
+
undo: { id: "general.undo", label: "Undo", category: "General", defaultKey: "Ctrl+Z" },
|
|
166
|
+
redo: { id: "general.redo", label: "Redo", category: "General", defaultKey: "Ctrl+Y" },
|
|
167
|
+
copy: { id: "general.copy", label: "Copy", category: "General", defaultKey: "Ctrl+C" },
|
|
168
|
+
paste: { id: "general.paste", label: "Paste", category: "General", defaultKey: "Ctrl+V" },
|
|
169
|
+
cut: { id: "general.cut", label: "Cut", category: "General", defaultKey: "Ctrl+X" },
|
|
170
|
+
delete: { id: "general.delete", label: "Delete", category: "General", defaultKey: "Delete" },
|
|
171
|
+
selectAll: { id: "general.selectAll", label: "Select All", category: "General", defaultKey: "Ctrl+A" },
|
|
172
|
+
save: { id: "general.save", label: "Save", category: "General", defaultKey: "Ctrl+S" },
|
|
173
|
+
duplicate: { id: "general.duplicate", label: "Duplicate", category: "General", defaultKey: "Ctrl+D" },
|
|
174
|
+
// View
|
|
175
|
+
zoomIn: { id: "view.zoomIn", label: "Zoom In", category: "View", defaultKey: "Ctrl+=" },
|
|
176
|
+
zoomOut: { id: "view.zoomOut", label: "Zoom Out", category: "View", defaultKey: "Ctrl+-" },
|
|
177
|
+
zoomFit: { id: "view.zoomFit", label: "Zoom to Fit", category: "View", defaultKey: "Ctrl+0" },
|
|
178
|
+
toggleGrid: { id: "view.toggleGrid", label: "Toggle Grid", category: "View", defaultKey: "Ctrl+'" },
|
|
179
|
+
toggleRulers: { id: "view.toggleRulers", label: "Toggle Rulers", category: "View", defaultKey: "Ctrl+R" },
|
|
180
|
+
toggleMinimap: { id: "view.toggleMinimap", label: "Toggle Minimap", category: "View", defaultKey: "Ctrl+M" },
|
|
181
|
+
};
|
|
182
|
+
// ── React Hook ──────────────────────────────────────────────────
|
|
183
|
+
/** Hook to use shortcuts in a component. Attaches keyboard listener. */
|
|
184
|
+
function useShortcuts(active = true) {
|
|
185
|
+
const [shortcuts, setShortcuts] = React.useState(ShortcutRegistry.getAll());
|
|
186
|
+
React.useEffect(() => {
|
|
187
|
+
return ShortcutRegistry.subscribe(() => setShortcuts(ShortcutRegistry.getAll()));
|
|
188
|
+
}, []);
|
|
189
|
+
React.useEffect(() => {
|
|
190
|
+
if (!active)
|
|
191
|
+
return;
|
|
192
|
+
const handler = (e) => ShortcutRegistry.handleKeyEvent(e);
|
|
193
|
+
window.addEventListener("keydown", handler);
|
|
194
|
+
return () => window.removeEventListener("keydown", handler);
|
|
195
|
+
}, [active]);
|
|
196
|
+
return shortcuts;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
export { DEFAULT_SHORTCUTS, ShortcutRegistry, eventToKeyCombo, useShortcuts };
|
|
200
|
+
//# sourceMappingURL=shortcuts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shortcuts.js","sources":["../../../src/core/shortcuts.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* theme.ts — Dark/light theme system for @nice2dev/ui-graphics editors.
|
|
5
|
+
*
|
|
6
|
+
* Provides CSS custom properties, theme context, and auto-detection
|
|
7
|
+
* of system dark mode preference.
|
|
8
|
+
*/
|
|
9
|
+
// ── Themes ──────────────────────────────────────────────────────
|
|
10
|
+
const LIGHT_THEME = {
|
|
11
|
+
mode: "light",
|
|
12
|
+
colors: {
|
|
13
|
+
bg: "#ffffff",
|
|
14
|
+
bgAlt: "#f8f9fa",
|
|
15
|
+
surface: "#f1f3f5",
|
|
16
|
+
surfaceHover: "#e9ecef",
|
|
17
|
+
border: "#dee2e6",
|
|
18
|
+
text: "#212529",
|
|
19
|
+
textSecondary: "#495057",
|
|
20
|
+
textMuted: "#868e96",
|
|
21
|
+
accent: "#228be6",
|
|
22
|
+
accentHover: "#1c7ed6",
|
|
23
|
+
accentText: "#ffffff",
|
|
24
|
+
error: "#e03131",
|
|
25
|
+
warning: "#f59f00",
|
|
26
|
+
success: "#2f9e44",
|
|
27
|
+
canvasBg: "#e9ecef",
|
|
28
|
+
toolbarBg: "#f8f9fa",
|
|
29
|
+
panelBg: "#ffffff",
|
|
30
|
+
statusBarBg: "#f1f3f5",
|
|
31
|
+
selectionBg: "rgba(34, 139, 230, 0.1)",
|
|
32
|
+
selectionBorder: "rgba(34, 139, 230, 0.5)",
|
|
33
|
+
},
|
|
34
|
+
spacing: { xs: 2, sm: 4, md: 8, lg: 16, xl: 24 },
|
|
35
|
+
radius: { sm: 2, md: 4, lg: 8 },
|
|
36
|
+
fontSize: { xs: 10, sm: 12, md: 14, lg: 16 },
|
|
37
|
+
};
|
|
38
|
+
const DARK_THEME = {
|
|
39
|
+
mode: "dark",
|
|
40
|
+
colors: {
|
|
41
|
+
bg: "#1a1b1e",
|
|
42
|
+
bgAlt: "#25262b",
|
|
43
|
+
surface: "#2c2e33",
|
|
44
|
+
surfaceHover: "#373a40",
|
|
45
|
+
border: "#373a40",
|
|
46
|
+
text: "#c1c2c5",
|
|
47
|
+
textSecondary: "#909296",
|
|
48
|
+
textMuted: "#5c5f66",
|
|
49
|
+
accent: "#339af0",
|
|
50
|
+
accentHover: "#228be6",
|
|
51
|
+
accentText: "#ffffff",
|
|
52
|
+
error: "#ff6b6b",
|
|
53
|
+
warning: "#ffd43b",
|
|
54
|
+
success: "#69db7c",
|
|
55
|
+
canvasBg: "#141517",
|
|
56
|
+
toolbarBg: "#25262b",
|
|
57
|
+
panelBg: "#1a1b1e",
|
|
58
|
+
statusBarBg: "#25262b",
|
|
59
|
+
selectionBg: "rgba(51, 154, 240, 0.15)",
|
|
60
|
+
selectionBorder: "rgba(51, 154, 240, 0.5)",
|
|
61
|
+
},
|
|
62
|
+
spacing: { xs: 2, sm: 4, md: 8, lg: 16, xl: 24 },
|
|
63
|
+
radius: { sm: 2, md: 4, lg: 8 },
|
|
64
|
+
fontSize: { xs: 10, sm: 12, md: 14, lg: 16 },
|
|
65
|
+
};
|
|
66
|
+
// ── CSS Custom Properties ───────────────────────────────────────
|
|
67
|
+
/** Generate CSS custom properties from a theme. */
|
|
68
|
+
function themeToCssVars(theme) {
|
|
69
|
+
const vars = {};
|
|
70
|
+
for (const [key, value] of Object.entries(theme.colors)) {
|
|
71
|
+
vars[`--nice-editor-${camelToKebab(key)}`] = value;
|
|
72
|
+
}
|
|
73
|
+
for (const [key, value] of Object.entries(theme.spacing)) {
|
|
74
|
+
vars[`--nice-editor-spacing-${key}`] = `${value}px`;
|
|
75
|
+
}
|
|
76
|
+
for (const [key, value] of Object.entries(theme.radius)) {
|
|
77
|
+
vars[`--nice-editor-radius-${key}`] = `${value}px`;
|
|
78
|
+
}
|
|
79
|
+
for (const [key, value] of Object.entries(theme.fontSize)) {
|
|
80
|
+
vars[`--nice-editor-font-${key}`] = `${value}px`;
|
|
81
|
+
}
|
|
82
|
+
return vars;
|
|
83
|
+
}
|
|
84
|
+
/** Apply theme CSS variables to a DOM element. */
|
|
85
|
+
function applyThemeToElement(element, theme) {
|
|
86
|
+
const vars = themeToCssVars(theme);
|
|
87
|
+
for (const [prop, value] of Object.entries(vars)) {
|
|
88
|
+
element.style.setProperty(prop, value);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
function camelToKebab(str) {
|
|
92
|
+
return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`);
|
|
93
|
+
}
|
|
94
|
+
// ── System Dark Mode Detection ──────────────────────────────────
|
|
95
|
+
/** Detect if system prefers dark mode. */
|
|
96
|
+
function systemPrefersDark() {
|
|
97
|
+
var _a, _b;
|
|
98
|
+
if (typeof window === "undefined")
|
|
99
|
+
return false;
|
|
100
|
+
return (_b = (_a = window.matchMedia) === null || _a === void 0 ? void 0 : _a.call(window, "(prefers-color-scheme: dark)").matches) !== null && _b !== void 0 ? _b : false;
|
|
101
|
+
}
|
|
102
|
+
/** Resolve "auto" mode to "light" or "dark". */
|
|
103
|
+
function resolveThemeMode(mode) {
|
|
104
|
+
if (mode === "auto")
|
|
105
|
+
return systemPrefersDark() ? "dark" : "light";
|
|
106
|
+
return mode;
|
|
107
|
+
}
|
|
108
|
+
const ThemeContext = React.createContext({
|
|
109
|
+
theme: DARK_THEME,
|
|
110
|
+
mode: "dark",
|
|
111
|
+
setMode: () => { },
|
|
112
|
+
toggleMode: () => { },
|
|
113
|
+
});
|
|
114
|
+
/** Provider for editor theme. Supports "light", "dark", or "auto". */
|
|
115
|
+
const NiceEditorThemeProvider = ({ initialMode = "auto", storageKey = "nice2dev.graphics.theme", children }) => {
|
|
116
|
+
const [mode, setModeState] = React.useState(() => {
|
|
117
|
+
try {
|
|
118
|
+
const saved = localStorage.getItem(storageKey);
|
|
119
|
+
if (saved === "light" || saved === "dark" || saved === "auto")
|
|
120
|
+
return saved;
|
|
121
|
+
}
|
|
122
|
+
catch ( /* ignore */_a) { /* ignore */ }
|
|
123
|
+
return initialMode;
|
|
124
|
+
});
|
|
125
|
+
const [resolvedMode, setResolvedMode] = React.useState(resolveThemeMode(mode));
|
|
126
|
+
// Listen for system theme changes when in "auto" mode
|
|
127
|
+
React.useEffect(() => {
|
|
128
|
+
if (mode !== "auto") {
|
|
129
|
+
setResolvedMode(mode);
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
setResolvedMode(systemPrefersDark() ? "dark" : "light");
|
|
133
|
+
const mq = window.matchMedia("(prefers-color-scheme: dark)");
|
|
134
|
+
const handler = (e) => setResolvedMode(e.matches ? "dark" : "light");
|
|
135
|
+
mq.addEventListener("change", handler);
|
|
136
|
+
return () => mq.removeEventListener("change", handler);
|
|
137
|
+
}, [mode]);
|
|
138
|
+
const setMode = React.useCallback((m) => {
|
|
139
|
+
setModeState(m);
|
|
140
|
+
try {
|
|
141
|
+
localStorage.setItem(storageKey, m);
|
|
142
|
+
}
|
|
143
|
+
catch ( /* ignore */_a) { /* ignore */ }
|
|
144
|
+
}, [storageKey]);
|
|
145
|
+
const toggleMode = React.useCallback(() => {
|
|
146
|
+
setMode(resolvedMode === "dark" ? "light" : "dark");
|
|
147
|
+
}, [resolvedMode, setMode]);
|
|
148
|
+
const theme = resolvedMode === "dark" ? DARK_THEME : LIGHT_THEME;
|
|
149
|
+
const cssVars = React.useMemo(() => themeToCssVars(theme), [theme]);
|
|
150
|
+
const value = React.useMemo(() => ({ theme, mode, setMode, toggleMode }), [theme, mode, setMode, toggleMode]);
|
|
151
|
+
return React.createElement(ThemeContext.Provider, { value }, React.createElement("div", {
|
|
152
|
+
style: cssVars,
|
|
153
|
+
"data-theme": resolvedMode,
|
|
154
|
+
}, children));
|
|
155
|
+
};
|
|
156
|
+
/** Hook to access editor theme. */
|
|
157
|
+
function useEditorTheme() {
|
|
158
|
+
return React.useContext(ThemeContext);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
export { DARK_THEME, LIGHT_THEME, NiceEditorThemeProvider, applyThemeToElement, resolveThemeMode, systemPrefersDark, themeToCssVars, useEditorTheme };
|
|
162
|
+
//# sourceMappingURL=theme.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"theme.js","sources":["../../../src/core/theme.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* NiceFontEditor.tsx — Font creation and editing (glyph editor).
|
|
5
|
+
*
|
|
6
|
+
* Features:
|
|
7
|
+
* - Glyph grid with unicode character mapping
|
|
8
|
+
* - Per-glyph vector path editor
|
|
9
|
+
* - Metrics editing (advance width, bearing, ascent/descent)
|
|
10
|
+
* - Font preview with sample text
|
|
11
|
+
* - Export to OTF/TTF metadata (SVG font), WOFF subset
|
|
12
|
+
* - Import from existing font files
|
|
13
|
+
*/
|
|
14
|
+
// ── Defaults ────────────────────────────────────────────────────
|
|
15
|
+
const DEFAULT_METRICS = {
|
|
16
|
+
unitsPerEm: 1000,
|
|
17
|
+
ascent: 800,
|
|
18
|
+
descent: -200,
|
|
19
|
+
lineGap: 0,
|
|
20
|
+
xHeight: 500,
|
|
21
|
+
capHeight: 700,
|
|
22
|
+
};
|
|
23
|
+
const BASIC_CHARS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789 .,:;!?-'\"()[]{}@#$%&*+=/\\<>~`^|_";
|
|
24
|
+
function createDefaultGlyphs() {
|
|
25
|
+
return Array.from(BASIC_CHARS).map((char) => ({
|
|
26
|
+
unicode: char.codePointAt(0),
|
|
27
|
+
char,
|
|
28
|
+
name: char === " " ? "space" : `uni${char.codePointAt(0).toString(16).toUpperCase().padStart(4, "0")}`,
|
|
29
|
+
path: "",
|
|
30
|
+
advanceWidth: 500,
|
|
31
|
+
leftBearing: 50,
|
|
32
|
+
}));
|
|
33
|
+
}
|
|
34
|
+
// ── SVG Font Export ─────────────────────────────────────────────
|
|
35
|
+
function exportToSvgFont(data) {
|
|
36
|
+
const glyphElements = data.glyphs
|
|
37
|
+
.filter((g) => g.path)
|
|
38
|
+
.map((g) => ` <glyph unicode="&#x${g.unicode.toString(16)};" glyph-name="${g.name}" d="${g.path}" horiz-adv-x="${g.advanceWidth}" />`)
|
|
39
|
+
.join("\n");
|
|
40
|
+
return `<?xml version="1.0" standalone="no"?>
|
|
41
|
+
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
42
|
+
<svg xmlns="http://www.w3.org/2000/svg">
|
|
43
|
+
<defs>
|
|
44
|
+
<font id="${data.family}" horiz-adv-x="${data.metrics.unitsPerEm}">
|
|
45
|
+
<font-face
|
|
46
|
+
font-family="${data.family}"
|
|
47
|
+
font-weight="400"
|
|
48
|
+
font-style="normal"
|
|
49
|
+
units-per-em="${data.metrics.unitsPerEm}"
|
|
50
|
+
ascent="${data.metrics.ascent}"
|
|
51
|
+
descent="${data.metrics.descent}"
|
|
52
|
+
x-height="${data.metrics.xHeight}"
|
|
53
|
+
cap-height="${data.metrics.capHeight}"
|
|
54
|
+
/>
|
|
55
|
+
<missing-glyph horiz-adv-x="${data.metrics.unitsPerEm * 0.5}" />
|
|
56
|
+
${glyphElements}
|
|
57
|
+
</font>
|
|
58
|
+
</defs>
|
|
59
|
+
</svg>`;
|
|
60
|
+
}
|
|
61
|
+
// ── Hook ────────────────────────────────────────────────────────
|
|
62
|
+
function useFontEditor(initialName) {
|
|
63
|
+
const [fontName, setFontName] = React.useState(initialName);
|
|
64
|
+
const [metrics, setMetrics] = React.useState(DEFAULT_METRICS);
|
|
65
|
+
const [glyphs, setGlyphs] = React.useState(createDefaultGlyphs);
|
|
66
|
+
const [selectedGlyph, setSelectedGlyph] = React.useState(null);
|
|
67
|
+
const [previewText, setPreviewText] = React.useState("The quick brown fox jumps over the lazy dog");
|
|
68
|
+
const updateGlyph = React.useCallback((unicode, updates) => {
|
|
69
|
+
setGlyphs((prev) => prev.map((g) => g.unicode === unicode ? { ...g, ...updates } : g));
|
|
70
|
+
}, []);
|
|
71
|
+
const addGlyph = React.useCallback((char) => {
|
|
72
|
+
const unicode = char.codePointAt(0);
|
|
73
|
+
if (glyphs.some((g) => g.unicode === unicode))
|
|
74
|
+
return;
|
|
75
|
+
setGlyphs((prev) => [...prev, {
|
|
76
|
+
unicode,
|
|
77
|
+
char,
|
|
78
|
+
name: `uni${unicode.toString(16).toUpperCase().padStart(4, "0")}`,
|
|
79
|
+
path: "",
|
|
80
|
+
advanceWidth: 500,
|
|
81
|
+
leftBearing: 50,
|
|
82
|
+
}]);
|
|
83
|
+
}, [glyphs]);
|
|
84
|
+
const toFontData = React.useCallback(() => ({
|
|
85
|
+
name: fontName,
|
|
86
|
+
family: fontName.replace(/\s+/g, ""),
|
|
87
|
+
metrics,
|
|
88
|
+
glyphs,
|
|
89
|
+
}), [fontName, metrics, glyphs]);
|
|
90
|
+
return {
|
|
91
|
+
fontName, setFontName,
|
|
92
|
+
metrics, setMetrics,
|
|
93
|
+
glyphs, selectedGlyph, setSelectedGlyph,
|
|
94
|
+
updateGlyph, addGlyph,
|
|
95
|
+
previewText, setPreviewText,
|
|
96
|
+
toFontData,
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
// ── Component ───────────────────────────────────────────────────
|
|
100
|
+
/** Font glyph editor with metrics, path editing, and preview. */
|
|
101
|
+
const NiceFontEditor = ({ fontName = "MyFont", onSave, className = "", }) => {
|
|
102
|
+
var _a;
|
|
103
|
+
const editor = useFontEditor(fontName);
|
|
104
|
+
const handleSave = () => {
|
|
105
|
+
onSave === null || onSave === void 0 ? void 0 : onSave(editor.toFontData());
|
|
106
|
+
};
|
|
107
|
+
const handleExportSvg = () => {
|
|
108
|
+
const data = editor.toFontData();
|
|
109
|
+
const svg = exportToSvgFont(data);
|
|
110
|
+
const blob = new Blob([svg], { type: "image/svg+xml" });
|
|
111
|
+
const url = URL.createObjectURL(blob);
|
|
112
|
+
const a = document.createElement("a");
|
|
113
|
+
a.href = url;
|
|
114
|
+
a.download = `${data.family}.svg`;
|
|
115
|
+
a.click();
|
|
116
|
+
URL.revokeObjectURL(url);
|
|
117
|
+
};
|
|
118
|
+
const selectedG = editor.selectedGlyph !== null
|
|
119
|
+
? (_a = editor.glyphs.find((g) => g.unicode === editor.selectedGlyph)) !== null && _a !== void 0 ? _a : null
|
|
120
|
+
: null;
|
|
121
|
+
return React.createElement("div", {
|
|
122
|
+
className: `nice-font-editor ${className}`,
|
|
123
|
+
style: { display: "flex", flexDirection: "column", gap: 8, background: "#1a1b1e", color: "#c1c2c5", padding: 12, borderRadius: 8 },
|
|
124
|
+
},
|
|
125
|
+
// Header
|
|
126
|
+
React.createElement("div", { style: { display: "flex", alignItems: "center", gap: 8, fontSize: 12 } }, React.createElement("strong", { style: { fontSize: 14 } }, "Font Editor"), React.createElement("input", {
|
|
127
|
+
value: editor.fontName,
|
|
128
|
+
onChange: (e) => editor.setFontName(e.target.value),
|
|
129
|
+
placeholder: "Font name",
|
|
130
|
+
style: { flex: 1, maxWidth: 200, padding: "3px 6px", background: "#2c2e33", color: "#c1c2c5", border: "1px solid #373a40", borderRadius: 3, fontSize: 12 },
|
|
131
|
+
}), React.createElement("button", {
|
|
132
|
+
onClick: handleSave,
|
|
133
|
+
style: { padding: "4px 12px", background: "#2f9e44", color: "#fff", border: "none", borderRadius: 3, cursor: "pointer", fontSize: 11 },
|
|
134
|
+
}, "Save"), React.createElement("button", {
|
|
135
|
+
onClick: handleExportSvg,
|
|
136
|
+
style: { padding: "4px 12px", background: "#228be6", color: "#fff", border: "none", borderRadius: 3, cursor: "pointer", fontSize: 11 },
|
|
137
|
+
}, "Export SVG Font")), React.createElement("div", { style: { display: "flex", gap: 8 } },
|
|
138
|
+
// Glyph Grid
|
|
139
|
+
React.createElement("div", { style: { flex: 1 } }, React.createElement("div", { style: { fontSize: 11, marginBottom: 4, color: "#868e96" } }, `${editor.glyphs.length} glyphs`), React.createElement("div", {
|
|
140
|
+
style: { display: "grid", gridTemplateColumns: "repeat(auto-fill, 36px)", gap: 2, maxHeight: 300, overflowY: "auto" },
|
|
141
|
+
}, ...editor.glyphs.map((g) => React.createElement("div", {
|
|
142
|
+
key: g.unicode,
|
|
143
|
+
onClick: () => editor.setSelectedGlyph(g.unicode),
|
|
144
|
+
title: `U+${g.unicode.toString(16).toUpperCase().padStart(4, "0")} - ${g.name}`,
|
|
145
|
+
style: {
|
|
146
|
+
width: 36, height: 36, display: "flex", alignItems: "center", justifyContent: "center",
|
|
147
|
+
borderRadius: 3, cursor: "pointer", fontSize: 16,
|
|
148
|
+
background: editor.selectedGlyph === g.unicode ? "#339af0" : (g.path ? "#2c2e33" : "#25262b"),
|
|
149
|
+
color: editor.selectedGlyph === g.unicode ? "#fff" : (g.path ? "#c1c2c5" : "#5c5f66"),
|
|
150
|
+
border: g.path ? "1px solid #373a40" : "1px solid transparent",
|
|
151
|
+
},
|
|
152
|
+
}, g.char)))),
|
|
153
|
+
// Glyph Editor
|
|
154
|
+
React.createElement("div", { style: { width: 280, fontSize: 11 } }, selectedG ? React.createElement("div", { style: { display: "flex", flexDirection: "column", gap: 6 } }, React.createElement("strong", null, `Editing: "${selectedG.char}" (U+${selectedG.unicode.toString(16).toUpperCase().padStart(4, "0")})`),
|
|
155
|
+
// Path input
|
|
156
|
+
React.createElement("div", null, React.createElement("label", null, "SVG Path"), React.createElement("textarea", {
|
|
157
|
+
value: selectedG.path,
|
|
158
|
+
onChange: (e) => editor.updateGlyph(selectedG.unicode, { path: e.target.value }),
|
|
159
|
+
rows: 4,
|
|
160
|
+
style: { width: "100%", background: "#2c2e33", color: "#c1c2c5", border: "1px solid #373a40", borderRadius: 3, padding: 4, fontSize: 10, fontFamily: "monospace", resize: "vertical" },
|
|
161
|
+
})),
|
|
162
|
+
// Metrics
|
|
163
|
+
React.createElement("div", { style: { display: "grid", gridTemplateColumns: "1fr 1fr", gap: 4 } }, React.createElement("label", null, "Advance Width"), React.createElement("input", {
|
|
164
|
+
type: "number", value: selectedG.advanceWidth,
|
|
165
|
+
onChange: (e) => editor.updateGlyph(selectedG.unicode, { advanceWidth: Number(e.target.value) }),
|
|
166
|
+
style: { width: "100%", background: "#2c2e33", color: "#c1c2c5", border: "1px solid #373a40", borderRadius: 3, padding: 2, fontSize: 10 },
|
|
167
|
+
}), React.createElement("label", null, "Left Bearing"), React.createElement("input", {
|
|
168
|
+
type: "number", value: selectedG.leftBearing,
|
|
169
|
+
onChange: (e) => editor.updateGlyph(selectedG.unicode, { leftBearing: Number(e.target.value) }),
|
|
170
|
+
style: { width: "100%", background: "#2c2e33", color: "#c1c2c5", border: "1px solid #373a40", borderRadius: 3, padding: 2, fontSize: 10 },
|
|
171
|
+
})),
|
|
172
|
+
// Preview single glyph
|
|
173
|
+
selectedG.path && React.createElement("svg", {
|
|
174
|
+
width: 100, height: 100,
|
|
175
|
+
viewBox: `0 0 ${editor.metrics.unitsPerEm} ${editor.metrics.unitsPerEm}`,
|
|
176
|
+
style: { background: "#141517", borderRadius: 4 },
|
|
177
|
+
}, React.createElement("path", { d: selectedG.path, fill: "#c1c2c5" }))) : React.createElement("div", { style: { color: "#868e96", padding: 20, textAlign: "center" } }, "Select a glyph to edit"))),
|
|
178
|
+
// Preview
|
|
179
|
+
React.createElement("div", { style: { marginTop: 8 } }, React.createElement("div", { style: { fontSize: 11, color: "#868e96", marginBottom: 4 } }, "Preview"), React.createElement("input", {
|
|
180
|
+
value: editor.previewText,
|
|
181
|
+
onChange: (e) => editor.setPreviewText(e.target.value),
|
|
182
|
+
style: { width: "100%", padding: "6px 8px", background: "#2c2e33", color: "#c1c2c5", border: "1px solid #373a40", borderRadius: 4, fontSize: 12 },
|
|
183
|
+
}), React.createElement("div", {
|
|
184
|
+
style: { marginTop: 8, padding: 16, background: "#fff", color: "#212529", borderRadius: 6, fontSize: 24, fontFamily: "serif" },
|
|
185
|
+
}, editor.previewText)));
|
|
186
|
+
};
|
|
187
|
+
|
|
188
|
+
export { NiceFontEditor, exportToSvgFont, useFontEditor };
|
|
189
|
+
//# sourceMappingURL=NiceFontEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NiceFontEditor.js","sources":["../../../src/font/NiceFontEditor.tsx"],"sourcesContent":[null],"names":[],"mappings":";;AAAA;;;;;;;;;;AAUG;AAwDH;AAEA,MAAM,eAAe,GAAgB;AACnC,IAAA,UAAU,EAAE,IAAI;AAChB,IAAA,MAAM,EAAE,GAAG;IACX,OAAO,EAAE,IAAI;AACb,IAAA,OAAO,EAAE,CAAC;AACV,IAAA,OAAO,EAAE,GAAG;AACZ,IAAA,SAAS,EAAE,GAAG;CACf;AAED,MAAM,WAAW,GAAG,mGAAmG;AAEvH,SAAS,mBAAmB,GAAA;AAC1B,IAAA,OAAO,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,MAAM;AAC5C,QAAA,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAE;QAC7B,IAAI;AACJ,QAAA,IAAI,EAAE,IAAI,KAAK,GAAG,GAAG,OAAO,GAAG,CAAA,GAAA,EAAM,IAAI,CAAC,WAAW,CAAC,CAAC,CAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA,CAAE;AACvG,QAAA,IAAI,EAAE,EAAE;AACR,QAAA,YAAY,EAAE,GAAG;AACjB,QAAA,WAAW,EAAE,EAAE;AAChB,KAAA,CAAC,CAAC;AACL;AAEA;AAEM,SAAU,eAAe,CAAC,IAAc,EAAA;AAC5C,IAAA,MAAM,aAAa,GAAG,IAAI,CAAC;SACxB,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI;AACpB,SAAA,GAAG,CAAC,CAAC,CAAC,KAAK,CAAA,uBAAA,EAA0B,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA,eAAA,EAAkB,CAAC,CAAC,IAAI,CAAA,KAAA,EAAQ,CAAC,CAAC,IAAI,CAAA,eAAA,EAAkB,CAAC,CAAC,YAAY,CAAA,IAAA,CAAM;SACvI,IAAI,CAAC,IAAI,CAAC;IAEb,OAAO,CAAA;;;;AAIO,cAAA,EAAA,IAAI,CAAC,MAAM,CAAA,eAAA,EAAkB,IAAI,CAAC,OAAO,CAAC,UAAU,CAAA;;AAE7C,qBAAA,EAAA,IAAI,CAAC,MAAM,CAAA;;;wBAGV,IAAI,CAAC,OAAO,CAAC,UAAU,CAAA;kBAC7B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;mBAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAA;oBACnB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAA;sBAClB,IAAI,CAAC,OAAO,CAAC,SAAS,CAAA;;AAER,kCAAA,EAAA,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,GAAG,CAAA;EAC/D,aAAa,CAAA;;;OAGR;AACP;AAEA;AAEM,SAAU,aAAa,CAAC,WAAmB,EAAA;AAC/C,IAAA,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC;AAC3D,IAAA,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAc,eAAe,CAAC;AAC1E,IAAA,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAc,mBAAmB,CAAC;AAC5E,IAAA,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAgB,IAAI,CAAC;AAC7E,IAAA,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,6CAA6C,CAAC;IAEnG,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,OAAe,EAAE,OAA2B,KAAI;AACrF,QAAA,SAAS,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,KAAK,OAAO,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;IACxF,CAAC,EAAE,EAAE,CAAC;IAEN,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,IAAY,KAAI;QAClD,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAE;AACpC,QAAA,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC;YAAE;QAC/C,SAAS,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,IAAI,EAAE;gBAC5B,OAAO;gBACP,IAAI;AACJ,gBAAA,IAAI,EAAE,CAAA,GAAA,EAAM,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA,CAAE;AACjE,gBAAA,IAAI,EAAE,EAAE;AACR,gBAAA,YAAY,EAAE,GAAG;AACjB,gBAAA,WAAW,EAAE,EAAE;AAChB,aAAA,CAAC,CAAC;AACL,IAAA,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;IAEZ,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,CAAC,OAAiB;AACpD,QAAA,IAAI,EAAE,QAAQ;QACd,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;QACpC,OAAO;QACP,MAAM;KACP,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IAEhC,OAAO;AACL,QAAA,QAAQ,EAAE,WAAW;AACrB,QAAA,OAAO,EAAE,UAAU;QACnB,MAAM,EAAE,aAAa,EAAE,gBAAgB;AACvC,QAAA,WAAW,EAAE,QAAQ;AACrB,QAAA,WAAW,EAAE,cAAc;QAC3B,UAAU;KACX;AACH;AAEA;AAEA;AACO,MAAM,cAAc,GAA8B,CAAC,EACxD,QAAQ,GAAG,QAAQ,EACnB,MAAM,EACN,SAAS,GAAG,EAAE,GACf,KAAI;;AACH,IAAA,MAAM,MAAM,GAAG,aAAa,CAAC,QAAQ,CAAC;IAEtC,MAAM,UAAU,GAAG,MAAK;QACtB,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,MAAA,GAAA,MAAA,GAAN,MAAM,CAAG,MAAM,CAAC,UAAU,EAAE,CAAC;AAC/B,IAAA,CAAC;IAED,MAAM,eAAe,GAAG,MAAK;AAC3B,QAAA,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,EAAE;AAChC,QAAA,MAAM,GAAG,GAAG,eAAe,CAAC,IAAI,CAAC;AACjC,QAAA,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC;QACvD,MAAM,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC;QACrC,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC;AACrC,QAAA,CAAC,CAAC,IAAI,GAAG,GAAG;QACZ,CAAC,CAAC,QAAQ,GAAG,CAAA,EAAG,IAAI,CAAC,MAAM,MAAM;QACjC,CAAC,CAAC,KAAK,EAAE;AACT,QAAA,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC;AAC1B,IAAA,CAAC;AAED,IAAA,MAAM,SAAS,GAAG,MAAM,CAAC,aAAa,KAAK;UACvC,MAAA,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,KAAK,MAAM,CAAC,aAAa,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI;UACjE,IAAI;AAER,IAAA,OAAO,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QAChC,SAAS,EAAE,CAAA,iBAAA,EAAoB,SAAS,CAAA,CAAE;AAC1C,QAAA,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE;AACnI,KAAA;;IAEC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EACnG,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE,aAAa,CAAC,EACzE,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE;QAC3B,KAAK,EAAE,MAAM,CAAC,QAAQ;AACtB,QAAA,QAAQ,EAAE,CAAC,CAAsC,KAAK,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;AACxF,QAAA,WAAW,EAAE,WAAW;AACxB,QAAA,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,mBAAmB,EAAE,YAAY,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;AAC3J,KAAA,CAAC,EACF,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE;AAC5B,QAAA,OAAO,EAAE,UAAU;AACnB,QAAA,KAAK,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE;KACvI,EAAE,MAAM,CAAC,EACV,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE;AAC5B,QAAA,OAAO,EAAE,eAAe;AACxB,QAAA,KAAK,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE;KACvI,EAAE,iBAAiB,CAAC,CACtB,EAED,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;;IAE/D,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE,EAC/C,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,CAAA,EAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAA,OAAA,CAAS,CAAC,EAC5H,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QACzB,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,yBAAyB,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,EAAE;AACtH,KAAA,EACC,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,KACrB,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;QACzB,GAAG,EAAE,CAAC,CAAC,OAAO;QACd,OAAO,EAAE,MAAM,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,OAAO,CAAC;QACjD,KAAK,EAAE,CAAA,EAAA,EAAK,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA,GAAA,EAAM,CAAC,CAAC,IAAI,CAAA,CAAE;AAC/E,QAAA,KAAK,EAAE;AACL,YAAA,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,QAAQ;YACtF,YAAY,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE;YAChD,UAAU,EAAE,MAAM,CAAC,aAAa,KAAK,CAAC,CAAC,OAAO,GAAG,SAAS,IAAI,CAAC,CAAC,IAAI,GAAG,SAAS,GAAG,SAAS,CAAC;YAC7F,KAAK,EAAE,MAAM,CAAC,aAAa,KAAK,CAAC,CAAC,OAAO,GAAG,MAAM,IAAI,CAAC,CAAC,IAAI,GAAG,SAAS,GAAG,SAAS,CAAC;YACrF,MAAM,EAAE,CAAC,CAAC,IAAI,GAAG,mBAAmB,GAAG,uBAAuB;AAC/D,SAAA;AACF,KAAA,EAAE,CAAC,CAAC,IAAI,CAAC,CACX,CACF,CACF;;AAGD,IAAA,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAChE,SAAS,GAAG,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,EACpG,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAA,UAAA,EAAa,SAAS,CAAC,IAAI,CAAA,KAAA,EAAQ,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC;;IAExI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,EAC7B,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,CAAC,EAC9C,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE;QAC9B,KAAK,EAAE,SAAS,CAAC,IAAI;QACrB,QAAQ,EAAE,CAAC,CAAyC,KAAK,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;AACxH,QAAA,IAAI,EAAE,CAAC;AACP,QAAA,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,mBAAmB,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,UAAU,EAAE;AACvL,KAAA,CAAC,CACH;;AAED,IAAA,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,EAC/F,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE,IAAI,EAAE,eAAe,CAAC,EACnD,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE;AAC3B,QAAA,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,CAAC,YAAY;QAC7C,QAAQ,EAAE,CAAC,CAAsC,KAAK,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;AACrI,QAAA,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,mBAAmB,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;AAC1I,KAAA,CAAC,EACF,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE,IAAI,EAAE,cAAc,CAAC,EAClD,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE;AAC3B,QAAA,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,CAAC,WAAW;QAC5C,QAAQ,EAAE,CAAC,CAAsC,KAAK,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;AACpI,QAAA,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,mBAAmB,EAAE,YAAY,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;AAC1I,KAAA,CAAC,CACH;;IAED,SAAS,CAAC,IAAI,IAAI,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AAC3C,QAAA,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG;AACvB,QAAA,OAAO,EAAE,CAAA,IAAA,EAAO,MAAM,CAAC,OAAO,CAAC,UAAU,CAAA,CAAA,EAAI,MAAM,CAAC,OAAO,CAAC,UAAU,CAAA,CAAE;QACxE,KAAK,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,EAAE;KAClD,EACC,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CACpE,CACF,GAAG,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,wBAAwB,CAAC,CAC5H,CACF;;IAGD,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAAE,EACpD,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,EACrG,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE;QAC3B,KAAK,EAAE,MAAM,CAAC,WAAW;AACzB,QAAA,QAAQ,EAAE,CAAC,CAAsC,KAAK,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;AAC3F,QAAA,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,mBAAmB,EAAE,YAAY,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;AAClJ,KAAA,CAAC,EACF,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AACzB,QAAA,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE;AAC/H,KAAA,EAAE,MAAM,CAAC,WAAW,CAAC,CACvB,CACF;AACH;;;;"}
|