@vyr/cli 0.0.12 → 0.0.13
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/.entry/app.js +362 -362
- package/build/index.html +1 -1
- package/build/js/{index.b67bf9b8.js → index.e0eed6ab.js} +1 -1
- package/build/js/{preview.ad0b8290.js → preview.ff6115f6.js} +1 -1
- package/build/login.html +1 -1
- package/build/preview.html +1 -1
- package/output/auto-provider-plugin/index.js +38 -0
- package/output/auto-provider-plugin/loader.js +53 -0
- package/output/auto-provider-plugin/package.json +1 -0
- package/output/builtin/build/common/example.d.ts +5 -0
- package/output/builtin/build/common/index.d.ts +3 -0
- package/output/builtin/build/common/provider.d.ts +5 -0
- package/output/builtin/build/common/save.d.ts +4 -0
- package/output/builtin/build/component/CodeEditor.vue.d.ts +11 -0
- package/output/builtin/build/component/ColorItem.vue.d.ts +27 -0
- package/output/builtin/build/component/DatasetItem.vue.d.ts +14 -0
- package/output/builtin/build/component/Directory.vue.d.ts +33 -0
- package/output/builtin/build/component/ErrorComponent.vue.d.ts +13 -0
- package/output/builtin/build/component/Graph.vue.d.ts +20 -0
- package/output/builtin/build/component/InputItem.vue.d.ts +19 -0
- package/output/builtin/build/component/InteractionItem.vue.d.ts +19 -0
- package/output/builtin/build/component/LoadingComponent.vue.d.ts +13 -0
- package/output/builtin/build/component/RuleItem.vue.d.ts +12 -0
- package/output/builtin/build/component/Timeline.vue.d.ts +7 -0
- package/output/builtin/build/component/VariableItem.vue.d.ts +14 -0
- package/output/builtin/build/component/WindowSetting.vue.d.ts +3 -0
- package/output/builtin/build/component/index.d.ts +14 -0
- package/output/builtin/build/fragment/AnimationUnitFragment.vue.d.ts +6 -0
- package/output/builtin/build/fragment/BaseFragment.vue.d.ts +6 -0
- package/output/builtin/build/fragment/DatasetFragment.vue.d.ts +3 -0
- package/output/builtin/build/fragment/DatasetInspectorFragment.vue.d.ts +13 -0
- package/output/builtin/build/fragment/DynamicFragment.vue.d.ts +3 -0
- package/output/builtin/build/fragment/HTMLFragment.vue.d.ts +16 -0
- package/output/builtin/build/fragment/InteractionInspectorFragment.vue.d.ts +21 -0
- package/output/builtin/build/fragment/PrefabFragment.vue.d.ts +3 -0
- package/output/builtin/build/fragment/PrefabInstanceFragment.vue.d.ts +3 -0
- package/output/builtin/build/fragment/SchedulerFragment.vue.d.ts +3 -0
- package/output/builtin/build/fragment/StyleFragment.vue.d.ts +8 -0
- package/output/builtin/build/index.d.ts +10 -0
- package/output/builtin/build/locale/Language.d.ts +3 -0
- package/output/builtin/build/locale/LanguageProvider.d.ts +326 -0
- package/output/builtin/build/locale/index.d.ts +2 -0
- package/output/builtin/build/option/Animation.d.ts +25 -0
- package/output/builtin/build/option/Color.d.ts +5 -0
- package/output/builtin/build/option/Dynamic.d.ts +5 -0
- package/output/builtin/build/option/HTML.d.ts +41 -0
- package/output/builtin/build/option/Net.d.ts +6 -0
- package/output/builtin/build/option/Preset.d.ts +8 -0
- package/output/builtin/build/option/Style.d.ts +76 -0
- package/output/builtin/build/option/Variable.d.ts +5 -0
- package/output/builtin/build/option/index.d.ts +17 -0
- package/output/builtin/build/preset/dataset.d.ts +8 -0
- package/output/builtin/build/preset/graphics.d.ts +8 -0
- package/output/builtin/build/preset/index.d.ts +3 -0
- package/output/builtin/build/preset/scheduler.d.ts +8 -0
- package/output/builtin/build/service/footer/action/AddDirAction.d.ts +10 -0
- package/output/builtin/build/service/footer/action/AddMoreAction.d.ts +26 -0
- package/output/builtin/build/service/footer/action/BackupAction.d.ts +10 -0
- package/output/builtin/build/service/footer/action/ControllerAction.d.ts +39 -0
- package/output/builtin/build/service/footer/action/CopyAction.d.ts +13 -0
- package/output/builtin/build/service/footer/action/CutAction.d.ts +13 -0
- package/output/builtin/build/service/footer/action/DeleteAction.d.ts +14 -0
- package/output/builtin/build/service/footer/action/EditFileAction.d.ts +15 -0
- package/output/builtin/build/service/footer/action/RenameAction.d.ts +13 -0
- package/output/builtin/build/service/footer/action/SelectAllAction.d.ts +14 -0
- package/output/builtin/build/service/footer/action/StickupAction.d.ts +16 -0
- package/output/builtin/build/service/footer/action/index.d.ts +11 -0
- package/output/builtin/build/service/footer/draggable/Draggable.d.ts +10 -0
- package/output/builtin/build/service/footer/draggable/index.d.ts +1 -0
- package/output/builtin/build/service/footer/index.d.ts +2 -0
- package/output/builtin/build/service/global/action/FooterAction.d.ts +18 -0
- package/output/builtin/build/service/global/action/RedoAction.d.ts +9 -0
- package/output/builtin/build/service/global/action/SidebarAction.d.ts +14 -0
- package/output/builtin/build/service/global/action/UndoAction.d.ts +9 -0
- package/output/builtin/build/service/global/action/index.d.ts +4 -0
- package/output/builtin/build/service/global/index.d.ts +2 -0
- package/output/builtin/build/service/global/scripts/index.d.ts +3 -0
- package/output/builtin/build/service/header/action/ExportProjectAction.d.ts +9 -0
- package/output/builtin/build/service/header/action/ExportSceneAction.d.ts +9 -0
- package/output/builtin/build/service/header/action/PreviewSceneAction.d.ts +14 -0
- package/output/builtin/build/service/header/action/index.d.ts +3 -0
- package/output/builtin/build/service/header/index.d.ts +1 -0
- package/output/builtin/build/service/index.d.ts +6 -0
- package/output/builtin/build/service/inspector/AnimationUnitViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/DatasetInspector.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/DatasetViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/DivViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/DynamicViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/InteractionInspector.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/PrefabInstanceViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/PrefabViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/ServiceSchedulerViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/ServiceViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/StyleViewer.vue.d.ts +7 -0
- package/output/builtin/build/service/inspector/asset/AssetInspector.vue.d.ts +3 -0
- package/output/builtin/build/service/inspector/draggable/Draggable.d.ts +10 -0
- package/output/builtin/build/service/inspector/draggable/index.d.ts +1 -0
- package/output/builtin/build/service/inspector/index.d.ts +1 -0
- package/output/builtin/build/service/inspector/scene/SceneInspector.vue.d.ts +3 -0
- package/output/builtin/build/service/sidebar/asset/Asset.vue.d.ts +3 -0
- package/output/builtin/build/service/sidebar/asset/AssetItem.vue.d.ts +18 -0
- package/output/builtin/build/service/sidebar/asset/AssetNavigator.d.ts +28 -0
- package/output/builtin/build/service/sidebar/asset/action/AddNodeAction.d.ts +54 -0
- package/output/builtin/build/service/sidebar/asset/action/ControllerAction.d.ts +36 -0
- package/output/builtin/build/service/sidebar/asset/action/CopyAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/asset/action/CutAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/asset/action/DeleteAction.d.ts +15 -0
- package/output/builtin/build/service/sidebar/asset/action/RenameAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/asset/action/SaveAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/asset/action/StickupAction.d.ts +15 -0
- package/output/builtin/build/service/sidebar/asset/action/index.d.ts +8 -0
- package/output/builtin/build/service/sidebar/asset/draggable/Draggable.d.ts +14 -0
- package/output/builtin/build/service/sidebar/asset/draggable/index.d.ts +1 -0
- package/output/builtin/build/service/sidebar/asset/index.d.ts +3 -0
- package/output/builtin/build/service/sidebar/index.d.ts +2 -0
- package/output/builtin/build/service/sidebar/scene/Scene.vue.d.ts +3 -0
- package/output/builtin/build/service/sidebar/scene/SceneItem.vue.d.ts +18 -0
- package/output/builtin/build/service/sidebar/scene/SceneNavigator.d.ts +36 -0
- package/output/builtin/build/service/sidebar/scene/action/AddNodeAction.d.ts +54 -0
- package/output/builtin/build/service/sidebar/scene/action/AddServiceAction.d.ts +54 -0
- package/output/builtin/build/service/sidebar/scene/action/ControllerAction.d.ts +39 -0
- package/output/builtin/build/service/sidebar/scene/action/CopyAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/scene/action/CutAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/scene/action/DeleteAction.d.ts +15 -0
- package/output/builtin/build/service/sidebar/scene/action/RenameAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/scene/action/SaveAction.d.ts +14 -0
- package/output/builtin/build/service/sidebar/scene/action/StickupAction.d.ts +15 -0
- package/output/builtin/build/service/sidebar/scene/action/index.d.ts +9 -0
- package/output/builtin/build/service/sidebar/scene/draggable/Draggable.d.ts +14 -0
- package/output/builtin/build/service/sidebar/scene/draggable/index.d.ts +1 -0
- package/output/builtin/build/service/sidebar/scene/index.d.ts +3 -0
- package/output/builtin/build/singleton/index.d.ts +1 -0
- package/output/builtin/build/singleton/rightMenu.d.ts +10 -0
- package/output/builtin/package.json +16 -0
- package/output/builtin/src/shims-vue.d.ts +10 -0
- package/output/class-wrapper-plugin/index.js +42 -0
- package/output/class-wrapper-plugin/loaders/descriptor.js +89 -0
- package/output/class-wrapper-plugin/loaders/dynamic-interpreter.js +54 -0
- package/output/class-wrapper-plugin/loaders/index.js +30 -0
- package/output/class-wrapper-plugin/loaders/input-system.js +31 -0
- package/output/class-wrapper-plugin/loaders/object-pool.js +79 -0
- package/output/class-wrapper-plugin/package.json +1 -0
- package/output/class-wrapper-plugin/utils.js +79 -0
- package/output/declare/package.json +1 -0
- package/output/declare/src/Config.ts +19 -0
- package/output/declare/src/Draggable.ts +10 -0
- package/output/declare/src/Extension.ts +12 -0
- package/output/declare/src/index.ts +3 -0
- package/output/declare/tsconfig.json +31 -0
- package/output/design/package.json +14 -0
- package/output/design/src/components/Button.vue +64 -0
- package/output/design/src/components/Card.vue +203 -0
- package/output/design/src/components/Cascader.vue +171 -0
- package/output/design/src/components/Checked.vue +124 -0
- package/output/design/src/components/CheckedGroup.vue +51 -0
- package/output/design/src/components/Col.vue +52 -0
- package/output/design/src/components/ColorPicker.vue +331 -0
- package/output/design/src/components/Confirm.vue +86 -0
- package/output/design/src/components/Dialog.vue +220 -0
- package/output/design/src/components/Divider.vue +40 -0
- package/output/design/src/components/Draggable.vue +50 -0
- package/output/design/src/components/Dropdown.vue +175 -0
- package/output/design/src/components/DynamicDialog.vue +113 -0
- package/output/design/src/components/DynamicLayouter.vue +235 -0
- package/output/design/src/components/Form.vue +88 -0
- package/output/design/src/components/Input.vue +254 -0
- package/output/design/src/components/InputNumber.vue +96 -0
- package/output/design/src/components/Label.vue +116 -0
- package/output/design/src/components/Loading.vue +196 -0
- package/output/design/src/components/Mask.vue +47 -0
- package/output/design/src/components/Notify.vue +130 -0
- package/output/design/src/components/Option.vue +159 -0
- package/output/design/src/components/Options.vue +202 -0
- package/output/design/src/components/Popover.vue +271 -0
- package/output/design/src/components/Provider.vue +12 -0
- package/output/design/src/components/RightMenu.vue +127 -0
- package/output/design/src/components/Row.vue +50 -0
- package/output/design/src/components/Scroll.vue +99 -0
- package/output/design/src/components/Select.vue +223 -0
- package/output/design/src/components/Slot.vue +23 -0
- package/output/design/src/components/SubTree.vue +262 -0
- package/output/design/src/components/Tree.vue +129 -0
- package/output/design/src/components/common/DraggableController.ts +113 -0
- package/output/design/src/components/common/ResizeListener.ts +49 -0
- package/output/design/src/components/composables/useDefaultProps.ts +179 -0
- package/output/design/src/components/composables/useDraggable.ts +65 -0
- package/output/design/src/components/composables/useGetter.ts +15 -0
- package/output/design/src/components/composables/useMarginStyle.ts +45 -0
- package/output/design/src/components/composables/usePopover.ts +33 -0
- package/output/design/src/components/composables/useProvider.ts +186 -0
- package/output/design/src/components/composables/useScroll.ts +46 -0
- package/output/design/src/components/composables/useSearch.ts +95 -0
- package/output/design/src/components/composables/useTimer.ts +5 -0
- package/output/design/src/components/index.ts +1 -0
- package/output/design/src/components/singleton/confirm.ts +25 -0
- package/output/design/src/components/singleton/dialog.ts +25 -0
- package/output/design/src/components/singleton/index.ts +5 -0
- package/output/design/src/components/singleton/loading.ts +36 -0
- package/output/design/src/components/singleton/notify.ts +36 -0
- package/output/design/src/components/types/index.ts +82 -0
- package/output/design/src/components/utils/Cascader.ts +52 -0
- package/output/design/src/components/utils/Confirm.ts +41 -0
- package/output/design/src/components/utils/Dialog.ts +38 -0
- package/output/design/src/components/utils/DynamicDialog.ts +41 -0
- package/output/design/src/components/utils/DynamicLayouter.ts +5 -0
- package/output/design/src/components/utils/FloatLayer.ts +40 -0
- package/output/design/src/components/utils/InputNumber.ts +3 -0
- package/output/design/src/components/utils/Notify.ts +25 -0
- package/output/design/src/components/utils/Popover.ts +58 -0
- package/output/design/src/components/utils/RightMenu.ts +21 -0
- package/output/design/src/components/utils/Scroll.ts +4 -0
- package/output/design/src/components/utils/Slot.ts +73 -0
- package/output/design/src/components/utils/index.ts +12 -0
- package/output/design/src/font/demo.css +539 -0
- package/output/design/src/font/demo_index.html +1292 -0
- package/output/design/src/font/iconfont.css +207 -0
- package/output/design/src/font/iconfont.js +1 -0
- package/output/design/src/font/iconfont.json +345 -0
- package/output/design/src/font/iconfont.ttf +0 -0
- package/output/design/src/font/iconfont.woff +0 -0
- package/output/design/src/font/iconfont.woff2 +0 -0
- package/output/design/src/index.ts +68 -0
- package/output/design/src/locale/Language.ts +10 -0
- package/output/design/src/locale/LanguageProvider.ts +38 -0
- package/output/design/src/locale/index.ts +2 -0
- package/output/design/src/theme/global.less +91 -0
- package/output/design/src/theme/index.ts +155 -0
- package/output/design/src/tool/ArrayUtils.ts +38 -0
- package/output/design/src/tool/Color.ts +7 -0
- package/output/design/src/tool/Draggable.ts +36 -0
- package/output/design/src/tool/Listener.ts +59 -0
- package/output/design/src/tool/index.ts +4 -0
- package/output/design/tsconfig.json +37 -0
- package/output/engine/package.json +1 -0
- package/output/engine/src/ArrayUtils.ts +65 -0
- package/output/engine/src/AsyncTask.ts +72 -0
- package/output/engine/src/Category.ts +119 -0
- package/output/engine/src/Color.ts +111 -0
- package/output/engine/src/Engine.ts +115 -0
- package/output/engine/src/Generate.ts +40 -0
- package/output/engine/src/InputSystem.ts +108 -0
- package/output/engine/src/Listener.ts +59 -0
- package/output/engine/src/ObjectPool.ts +84 -0
- package/output/engine/src/ObjectUtils.ts +49 -0
- package/output/engine/src/Serialization.ts +49 -0
- package/output/engine/src/Traverser.ts +39 -0
- package/output/engine/src/actor/Actor.ts +28 -0
- package/output/engine/src/actor/AnimationUnitActor.ts +289 -0
- package/output/engine/src/actor/DivActor.ts +70 -0
- package/output/engine/src/actor/FragmentActor.ts +56 -0
- package/output/engine/src/actor/HTMActor.ts +169 -0
- package/output/engine/src/actor/HTMServiceActor.ts +57 -0
- package/output/engine/src/actor/HTMTransformControllerActor.ts +409 -0
- package/output/engine/src/actor/StyleActor.ts +96 -0
- package/output/engine/src/actor/index.ts +8 -0
- package/output/engine/src/asset/Asset.ts +282 -0
- package/output/engine/src/asset/AssetGraph.ts +246 -0
- package/output/engine/src/asset/index.ts +2 -0
- package/output/engine/src/descriptor/AnimationUnitDescriptor.ts +65 -0
- package/output/engine/src/descriptor/CameraDescriptor.ts +12 -0
- package/output/engine/src/descriptor/ControllerDescriptor.ts +16 -0
- package/output/engine/src/descriptor/DatasetDescriptor.ts +90 -0
- package/output/engine/src/descriptor/Descriptor.ts +388 -0
- package/output/engine/src/descriptor/DivDescriptor.ts +18 -0
- package/output/engine/src/descriptor/DynamicDescriptor.ts +27 -0
- package/output/engine/src/descriptor/HTMLDescriptor.ts +87 -0
- package/output/engine/src/descriptor/HTMLServiceDescriptor.ts +19 -0
- package/output/engine/src/descriptor/HTMLTransformControllerDescriptor.ts +34 -0
- package/output/engine/src/descriptor/NodeDescriptor.ts +32 -0
- package/output/engine/src/descriptor/PrefabDescriptor.ts +53 -0
- package/output/engine/src/descriptor/PrefabInstanceDescriptor.ts +32 -0
- package/output/engine/src/descriptor/ServiceDescriptor.ts +32 -0
- package/output/engine/src/descriptor/ServiceSchedulerDescriptor.ts +32 -0
- package/output/engine/src/descriptor/StyleDescriptor.ts +213 -0
- package/output/engine/src/descriptor/index.ts +16 -0
- package/output/engine/src/graphics/Collection.ts +25 -0
- package/output/engine/src/graphics/Compilation.ts +74 -0
- package/output/engine/src/graphics/Graphics.ts +487 -0
- package/output/engine/src/graphics/Observer.ts +36 -0
- package/output/engine/src/graphics/Unit.ts +83 -0
- package/output/engine/src/graphics/VariableProxy.ts +92 -0
- package/output/engine/src/graphics/index.ts +5 -0
- package/output/engine/src/index.ts +27 -0
- package/output/engine/src/interaction/InteractionDescriptor.ts +96 -0
- package/output/engine/src/interaction/InteractionExecutor.ts +84 -0
- package/output/engine/src/interaction/Scriptable.ts +40 -0
- package/output/engine/src/interaction/index.ts +3 -0
- package/output/engine/src/interpreter/AnimationUnitInterpreter.ts +53 -0
- package/output/engine/src/interpreter/DatasetInterpreter.ts +11 -0
- package/output/engine/src/interpreter/DivInterpreter.ts +44 -0
- package/output/engine/src/interpreter/DynamicInterpreter.ts +207 -0
- package/output/engine/src/interpreter/FragmentInterpreter.ts +34 -0
- package/output/engine/src/interpreter/HTMLServiceInterpreter.ts +47 -0
- package/output/engine/src/interpreter/HTMLTransformControllerInterpreter.ts +40 -0
- package/output/engine/src/interpreter/Interpreter.ts +69 -0
- package/output/engine/src/interpreter/PrefaInterpreter.ts +11 -0
- package/output/engine/src/interpreter/PrefabInstanceInterpreter.ts +12 -0
- package/output/engine/src/interpreter/ServiceInterpreter.ts +24 -0
- package/output/engine/src/interpreter/ServiceSchedulerInterpreter.ts +42 -0
- package/output/engine/src/interpreter/StyleInterpreter.ts +66 -0
- package/output/engine/src/interpreter/index.ts +13 -0
- package/output/engine/src/locale/Language.ts +10 -0
- package/output/engine/src/locale/LanguageProvider.ts +52 -0
- package/output/engine/src/locale/index.ts +2 -0
- package/output/engine/src/math/Euler.ts +303 -0
- package/output/engine/src/math/Matrix4.ts +1123 -0
- package/output/engine/src/math/Quaternion.ts +737 -0
- package/output/engine/src/math/Vector2.ts +680 -0
- package/output/engine/src/math/Vector3.ts +1062 -0
- package/output/engine/src/math/index.ts +5 -0
- package/output/engine/src/math/utils.ts +17 -0
- package/output/engine/src/preset/execute/dataset/compile.ts +99 -0
- package/output/engine/src/preset/execute/dataset/index.ts +2 -0
- package/output/engine/src/preset/execute/dataset/update.ts +51 -0
- package/output/engine/src/preset/execute/graphics/index.ts +1 -0
- package/output/engine/src/preset/execute/graphics/invoke.ts +48 -0
- package/output/engine/src/preset/execute/index.ts +4 -0
- package/output/engine/src/preset/execute/net/http.ts +95 -0
- package/output/engine/src/preset/execute/net/index.ts +1 -0
- package/output/engine/src/preset/execute/scheduler/index.ts +1 -0
- package/output/engine/src/preset/execute/scheduler/switch.ts +46 -0
- package/output/engine/src/preset/index.ts +7 -0
- package/output/engine/src/preset/interaction/dataset/compile.ts +27 -0
- package/output/engine/src/preset/interaction/dataset/index.ts +1 -0
- package/output/engine/src/preset/interaction/graphics/index.ts +1 -0
- package/output/engine/src/preset/interaction/graphics/invoke.ts +27 -0
- package/output/engine/src/preset/interaction/index.ts +3 -0
- package/output/engine/src/preset/interaction/scheduler/index.ts +1 -0
- package/output/engine/src/preset/interaction/scheduler/switch.ts +27 -0
- package/output/engine/src/setup/index.ts +17 -0
- package/output/engine/src/utils/AssetProvider.ts +73 -0
- package/output/engine/src/utils/constants.ts +10 -0
- package/output/engine/src/utils/index.ts +2 -0
- package/output/engine/tsconfig.json +31 -0
- package/output/locale/build/index.d.ts +18 -0
- package/output/locale/build/index.js +71 -0
- package/output/locale/package.json +1 -0
- package/output/locale/src/index.ts +79 -0
- package/output/locale/tsconfig.json +29 -0
- package/output/remote/package.json +1 -0
- package/output/remote/src/Bridge.ts +133 -0
- package/output/remote/src/ChangeScriptable.ts +22 -0
- package/output/remote/src/Collection.ts +36 -0
- package/output/remote/src/RemoteExecutor.ts +519 -0
- package/output/remote/src/RemoteInvoker.ts +72 -0
- package/output/remote/src/RemoteProcess.ts +87 -0
- package/output/remote/src/index.ts +7 -0
- package/output/remote/src/job/IJob.ts +6 -0
- package/output/remote/src/job/Job.ts +16 -0
- package/output/remote/src/job/asset/add.ts +23 -0
- package/output/remote/src/job/asset/dragdrap.ts +24 -0
- package/output/remote/src/job/asset/index.ts +6 -0
- package/output/remote/src/job/asset/load.ts +20 -0
- package/output/remote/src/job/asset/remove.ts +20 -0
- package/output/remote/src/job/asset/unload.ts +18 -0
- package/output/remote/src/job/asset/update.ts +22 -0
- package/output/remote/src/job/bridge/connection.ts +18 -0
- package/output/remote/src/job/bridge/disconnect.ts +29 -0
- package/output/remote/src/job/bridge/index.ts +2 -0
- package/output/remote/src/job/index.ts +1 -0
- package/output/remote/src/job/invoke/alert.ts +20 -0
- package/output/remote/src/job/invoke/animation.ts +45 -0
- package/output/remote/src/job/invoke/event.ts +40 -0
- package/output/remote/src/job/invoke/index.ts +8 -0
- package/output/remote/src/job/invoke/orbit.ts +20 -0
- package/output/remote/src/job/invoke/pick.ts +15 -0
- package/output/remote/src/job/invoke/properties.ts +43 -0
- package/output/remote/src/job/invoke/screenshot.ts +35 -0
- package/output/remote/src/job/invoke/transform.ts +36 -0
- package/output/remote/src/job/scene/add.ts +22 -0
- package/output/remote/src/job/scene/dragdrap.ts +23 -0
- package/output/remote/src/job/scene/index.ts +6 -0
- package/output/remote/src/job/scene/load.ts +19 -0
- package/output/remote/src/job/scene/remove.ts +19 -0
- package/output/remote/src/job/scene/unload.ts +17 -0
- package/output/remote/src/job/scene/update.ts +20 -0
- package/output/remote/src/locale/Language.ts +10 -0
- package/output/remote/src/locale/LanguageProvider.ts +15 -0
- package/output/remote/src/locale/index.ts +2 -0
- package/output/remote/src/utils/index.ts +85 -0
- package/output/remote/src/utils/screenshot.ts +20 -0
- package/output/remote/tsconfig.json +31 -0
- package/output/rollup-config-plugin/index.js +46 -0
- package/output/rollup-config-plugin/package.json +8 -0
- package/output/runtime/build/Action.d.ts +42 -0
- package/output/runtime/build/DataService.d.ts +22 -0
- package/output/runtime/build/DraggableService.d.ts +37 -0
- package/output/runtime/build/InspectorService.d.ts +18 -0
- package/output/runtime/build/PresetService.d.ts +32 -0
- package/output/runtime/build/RemoteService.d.ts +12 -0
- package/output/runtime/build/Runtime.d.ts +8 -0
- package/output/runtime/build/ShortcutkeyService.d.ts +23 -0
- package/output/runtime/build/data/body.d.ts +13 -0
- package/output/runtime/build/data/footer.d.ts +42 -0
- package/output/runtime/build/data/global.d.ts +15 -0
- package/output/runtime/build/data/header.d.ts +11 -0
- package/output/runtime/build/data/inspector.d.ts +10 -0
- package/output/runtime/build/data/sidebar.d.ts +11 -0
- package/output/runtime/build/data/status.d.ts +17 -0
- package/output/runtime/build/index.d.ts +10 -0
- package/output/runtime/build/locale/Language.d.ts +3 -0
- package/output/runtime/build/locale/LanguageProvider.d.ts +31 -0
- package/output/runtime/build/locale/index.d.ts +2 -0
- package/output/runtime/build/navigator/SidebarNavigator.d.ts +52 -0
- package/output/runtime/build/navigator/index.d.ts +1 -0
- package/output/runtime/package.json +16 -0
- package/output/service/package.json +1 -0
- package/output/service/src/Service.ts +44 -0
- package/output/service/src/index.ts +2 -0
- package/output/service/src/locale/Language.ts +10 -0
- package/output/service/src/locale/LanguageProvider.ts +15 -0
- package/output/service/src/locale/index.ts +2 -0
- package/output/service/tsconfig.json +31 -0
- package/output/service-asset/package.json +1 -0
- package/output/service-asset/src/AssetMethodProvider.ts +132 -0
- package/output/service-asset/src/AssetService.ts +102 -0
- package/output/service-asset/src/index.ts +2 -0
- package/output/service-asset/src/locale/Language.ts +10 -0
- package/output/service-asset/src/locale/LanguageProvider.ts +15 -0
- package/output/service-asset/src/locale/index.ts +2 -0
- package/output/service-asset/tsconfig.json +31 -0
- package/output/service-graph/package.json +1 -0
- package/output/service-graph/src/GraphDrawer.ts +309 -0
- package/output/service-graph/src/GraphService.ts +181 -0
- package/output/service-graph/src/asset/font/demo.css +539 -0
- package/output/service-graph/src/asset/font/demo_index.html +326 -0
- package/output/service-graph/src/asset/font/iconfont.css +39 -0
- package/output/service-graph/src/asset/font/iconfont.js +1 -0
- package/output/service-graph/src/asset/font/iconfont.json +51 -0
- package/output/service-graph/src/asset/font/iconfont.ttf +0 -0
- package/output/service-graph/src/asset/font/iconfont.woff +0 -0
- package/output/service-graph/src/asset/font/iconfont.woff2 +0 -0
- package/output/service-graph/src/asset/less/index.less +108 -0
- package/output/service-graph/src/common/InteractionUnit.ts +65 -0
- package/output/service-graph/src/common/Unit.ts +172 -0
- package/output/service-graph/src/index.ts +7 -0
- package/output/service-graph/src/locale/Language.ts +10 -0
- package/output/service-graph/src/locale/LanguageProvider.ts +16 -0
- package/output/service-graph/src/locale/index.ts +2 -0
- package/output/service-graph/tsconfig.json +34 -0
- package/output/service-rpc/package.json +1 -0
- package/output/service-rpc/src/IMessage.ts +14 -0
- package/output/service-rpc/src/Message.ts +17 -0
- package/output/service-rpc/src/Operation.ts +113 -0
- package/output/service-rpc/src/RpcService.ts +122 -0
- package/output/service-rpc/src/Scheme.ts +20 -0
- package/output/service-rpc/src/UseRecord.ts +50 -0
- package/output/service-rpc/src/User.ts +21 -0
- package/output/service-rpc/src/VirtualNode.ts +107 -0
- package/output/service-rpc/src/asset/add.ts +35 -0
- package/output/service-rpc/src/asset/close.ts +35 -0
- package/output/service-rpc/src/asset/copy.ts +23 -0
- package/output/service-rpc/src/asset/create.ts +39 -0
- package/output/service-rpc/src/asset/cut.ts +23 -0
- package/output/service-rpc/src/asset/delete.ts +28 -0
- package/output/service-rpc/src/asset/dragdrap.ts +36 -0
- package/output/service-rpc/src/asset/index.ts +13 -0
- package/output/service-rpc/src/asset/initialize.ts +24 -0
- package/output/service-rpc/src/asset/open.ts +35 -0
- package/output/service-rpc/src/asset/remove.ts +29 -0
- package/output/service-rpc/src/asset/rename.ts +21 -0
- package/output/service-rpc/src/asset/select.ts +19 -0
- package/output/service-rpc/src/asset/update.ts +39 -0
- package/output/service-rpc/src/dep/add.ts +22 -0
- package/output/service-rpc/src/dep/create.ts +23 -0
- package/output/service-rpc/src/dep/delete.ts +23 -0
- package/output/service-rpc/src/dep/index.ts +5 -0
- package/output/service-rpc/src/dep/remove.ts +23 -0
- package/output/service-rpc/src/dep/update.ts +22 -0
- package/output/service-rpc/src/index.ts +14 -0
- package/output/service-rpc/src/locale/Language.ts +10 -0
- package/output/service-rpc/src/locale/LanguageProvider.ts +15 -0
- package/output/service-rpc/src/locale/index.ts +2 -0
- package/output/service-rpc/src/rpc/confirm.ts +32 -0
- package/output/service-rpc/src/rpc/connection.ts +20 -0
- package/output/service-rpc/src/rpc/disconnect.ts +20 -0
- package/output/service-rpc/src/rpc/getUser.ts +37 -0
- package/output/service-rpc/src/rpc/index.ts +9 -0
- package/output/service-rpc/src/rpc/login.ts +35 -0
- package/output/service-rpc/src/rpc/logout.ts +20 -0
- package/output/service-rpc/src/rpc/redo.ts +18 -0
- package/output/service-rpc/src/rpc/undo.ts +18 -0
- package/output/service-rpc/src/scene/add.ts +35 -0
- package/output/service-rpc/src/scene/create.ts +28 -0
- package/output/service-rpc/src/scene/delete.ts +27 -0
- package/output/service-rpc/src/scene/download.ts +20 -0
- package/output/service-rpc/src/scene/dragdrap.ts +36 -0
- package/output/service-rpc/src/scene/index.ts +10 -0
- package/output/service-rpc/src/scene/initialize.ts +36 -0
- package/output/service-rpc/src/scene/record.ts +22 -0
- package/output/service-rpc/src/scene/remove.ts +28 -0
- package/output/service-rpc/src/scene/switch.ts +37 -0
- package/output/service-rpc/src/scene/update.ts +34 -0
- package/output/service-rpc/src/sidebar/index.ts +1 -0
- package/output/service-rpc/src/sidebar/switch.ts +35 -0
- package/output/service-rpc/tsconfig.json +31 -0
- package/output/service-scene/package.json +1 -0
- package/output/service-scene/src/SceneMethodProvider.ts +129 -0
- package/output/service-scene/src/SceneService.ts +78 -0
- package/output/service-scene/src/index.ts +2 -0
- package/output/service-scene/src/locale/Language.ts +10 -0
- package/output/service-scene/src/locale/LanguageProvider.ts +15 -0
- package/output/service-scene/src/locale/index.ts +2 -0
- package/output/service-scene/tsconfig.json +31 -0
- package/output/var-rename-plugin/index.js +74 -0
- package/output/var-rename-plugin/package.json +1 -0
- package/package.json +1 -1
- /package/build/js/{1111.d7fb9219.js → 1111.1f95eaf7.js} +0 -0
- /package/build/js/{chunk-vendors.fea3dfe0.js → chunk-vendors.f015a48a.js} +0 -0
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
import { Vector2 } from "../math"
|
|
2
|
+
import { Asset } from "../asset"
|
|
3
|
+
import { Descriptor, HTMLDescriptor, HTMLTransformControllerChangeArgs, HTMLTransformControllerDescriptor } from "../descriptor"
|
|
4
|
+
import { Scriptable } from "../interaction/Scriptable"
|
|
5
|
+
import { Actor } from "./Actor"
|
|
6
|
+
import { HTMLActor } from "./HTMActor"
|
|
7
|
+
|
|
8
|
+
class HTMLTransformState {
|
|
9
|
+
isDragging = false
|
|
10
|
+
isResizing = false
|
|
11
|
+
offset = new Vector2()
|
|
12
|
+
resizeData = {
|
|
13
|
+
direction: "",
|
|
14
|
+
startWidth: 0,
|
|
15
|
+
startHeight: 0,
|
|
16
|
+
calcHeight: 0,
|
|
17
|
+
calcWidth: 0,
|
|
18
|
+
startX: 0,
|
|
19
|
+
startY: 0,
|
|
20
|
+
}
|
|
21
|
+
target = {
|
|
22
|
+
element: document.createElement('div') as HTMLElement,
|
|
23
|
+
parent: null as HTMLElement | null,
|
|
24
|
+
initialRect: new DOMRect(),
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
class HTMLTransformControllerActor extends Actor {
|
|
29
|
+
state = new HTMLTransformState()
|
|
30
|
+
offset = new Vector2()
|
|
31
|
+
events: number[] = []
|
|
32
|
+
element: HTMLElement
|
|
33
|
+
circles: HTMLElement[]
|
|
34
|
+
target!: HTMLDescriptor
|
|
35
|
+
descriptor!: HTMLTransformControllerDescriptor
|
|
36
|
+
|
|
37
|
+
constructor() {
|
|
38
|
+
super()
|
|
39
|
+
this.element = this.createElement()
|
|
40
|
+
this.circles = this.createCircle()
|
|
41
|
+
for (const circle of this.circles) this.element.appendChild(circle)
|
|
42
|
+
document.body.appendChild(this.element)
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
createElement() {
|
|
46
|
+
const element = document.createElement('div')
|
|
47
|
+
element.style.width = '100px'
|
|
48
|
+
element.style.height = '100px'
|
|
49
|
+
element.style.position = 'fixed'
|
|
50
|
+
element.style.top = '0px'
|
|
51
|
+
element.style.left = '0px'
|
|
52
|
+
element.style.zIndex = '2147483647'
|
|
53
|
+
element.style.userSelect = 'none'
|
|
54
|
+
element.addEventListener('contextmenu', e => {
|
|
55
|
+
e.stopPropagation()
|
|
56
|
+
e.preventDefault()
|
|
57
|
+
this.change('contextmenu')
|
|
58
|
+
})
|
|
59
|
+
|
|
60
|
+
const border = document.createElement('div')
|
|
61
|
+
border.style.position = 'absolute'
|
|
62
|
+
border.style.top = '50%'
|
|
63
|
+
border.style.left = '50%'
|
|
64
|
+
border.style.transform = 'translate(-50%,-50%)'
|
|
65
|
+
border.style.width = '100%'
|
|
66
|
+
border.style.height = '100%'
|
|
67
|
+
border.style.border = '6px double #1b8fdfcc'
|
|
68
|
+
border.style.boxSizing = 'content-box'
|
|
69
|
+
border.style.pointerEvents = 'none'
|
|
70
|
+
element.appendChild(border)
|
|
71
|
+
return element
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
createCircle() {
|
|
75
|
+
const circles = []
|
|
76
|
+
const positions = [[0, 0], [100, 0], [100, 100], [0, 100]]
|
|
77
|
+
for (let i = 0; i < positions.length; i++) {
|
|
78
|
+
const circle = document.createElement('div')
|
|
79
|
+
this.setCircleStyle(circle, i, positions[i])
|
|
80
|
+
circles.push(circle)
|
|
81
|
+
}
|
|
82
|
+
return circles
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
setCircleStyle(circle: HTMLElement, index: number, position: number[]) {
|
|
86
|
+
circle.classList.add('resize-handle', index.toString())
|
|
87
|
+
circle.style.borderRadius = '50%'
|
|
88
|
+
circle.style.width = '12px'
|
|
89
|
+
circle.style.height = '12px'
|
|
90
|
+
circle.style.position = 'absolute'
|
|
91
|
+
circle.style.left = position[0] + '%'
|
|
92
|
+
circle.style.top = position[1] + '%'
|
|
93
|
+
circle.style.transform = 'translate(-50%,-50%)'
|
|
94
|
+
circle.style.border = '2px double #1b8fdfcc'
|
|
95
|
+
circle.style.background = '#ffffff'
|
|
96
|
+
circle.style.boxShadow = '0 0 4px #1b8fdfcc'
|
|
97
|
+
circle.style.zIndex = '99999'
|
|
98
|
+
circle.style.cursor = [1, 3].includes(index) ? 'nesw-resize' : 'nwse-resize'
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
listen(descriptor: HTMLTransformControllerDescriptor) {
|
|
102
|
+
this.reset()
|
|
103
|
+
const graphics = Actor.getGraphics(this)
|
|
104
|
+
const target = graphics.variableProxy.get<Descriptor>(descriptor.target, graphics)
|
|
105
|
+
if (target instanceof HTMLDescriptor) {
|
|
106
|
+
|
|
107
|
+
const targetActor = graphics.getActor<HTMLActor>(target)
|
|
108
|
+
if (targetActor === null) return
|
|
109
|
+
|
|
110
|
+
const wrapper = targetActor.getWrapper()
|
|
111
|
+
if (wrapper === null) return
|
|
112
|
+
|
|
113
|
+
this.descriptor = descriptor
|
|
114
|
+
this.target = target
|
|
115
|
+
|
|
116
|
+
this.selectTargetElement(wrapper)
|
|
117
|
+
|
|
118
|
+
this.events.push(graphics.engine.inputSystem.listen('mousedown', this.handleDragStart, { target: this.element }))
|
|
119
|
+
for (const circle of this.circles) {
|
|
120
|
+
this.events.push(graphics.engine.inputSystem.listen('mousedown', this.handleResizeStart, { target: circle }))
|
|
121
|
+
}
|
|
122
|
+
this.events.push(graphics.engine.inputSystem.listen('mousemove', this.handleMouseMove, { target: document }))
|
|
123
|
+
this.events.push(graphics.engine.inputSystem.listen('mouseup', this.handleMouseEnd, { target: document }))
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
unlisten() {
|
|
128
|
+
this.reset()
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
update(descriptor: HTMLTransformControllerDescriptor) {
|
|
132
|
+
this.listen(descriptor)
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
change = (type = 'change') => {
|
|
136
|
+
const scriptable = Asset.get<Scriptable<HTMLTransformControllerChangeArgs>>(this.descriptor.event)
|
|
137
|
+
if (scriptable === null) return
|
|
138
|
+
const graphics = Actor.getGraphics(this)
|
|
139
|
+
const _args: HTMLTransformControllerChangeArgs = {
|
|
140
|
+
event: { type, target: this.descriptor.target },
|
|
141
|
+
trigger: this.descriptor,
|
|
142
|
+
input: undefined,
|
|
143
|
+
result: undefined,
|
|
144
|
+
}
|
|
145
|
+
scriptable.execute(graphics, _args)
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
reset() {
|
|
149
|
+
const graphics = Actor.getGraphics(this)
|
|
150
|
+
for (const id of this.events) graphics.engine.inputSystem.unlisten(id)
|
|
151
|
+
this.events.length = 0
|
|
152
|
+
this.element.style.display = 'none'
|
|
153
|
+
this.state.target.element = document.createElement('div')
|
|
154
|
+
this.state.target.parent = null
|
|
155
|
+
//@ts-ignore
|
|
156
|
+
this.target = undefined
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
dispose() {
|
|
160
|
+
this.reset()
|
|
161
|
+
this.element.remove()
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// 选中目标元素
|
|
165
|
+
selectTargetElement = (element: HTMLElement) => {
|
|
166
|
+
this.state.target.element = element;
|
|
167
|
+
this.state.target.parent = element.parentElement;
|
|
168
|
+
this.state.target.initialRect = element.getBoundingClientRect();
|
|
169
|
+
|
|
170
|
+
this.updateOffset(this.state.target.initialRect)
|
|
171
|
+
// 显示并更新拖拽元素
|
|
172
|
+
this.updateDraggableElement();
|
|
173
|
+
this.element.style.display = 'block';
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
updateOffset(rect: DOMRect = this.state.target.initialRect) {
|
|
177
|
+
this.offset.set(
|
|
178
|
+
rect.width * (this.target.translate.x / 100),
|
|
179
|
+
rect.height * (this.target.translate.y / 100)
|
|
180
|
+
)
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
// 更新拖拽元素以匹配目标
|
|
184
|
+
updateDraggableElement = () => {
|
|
185
|
+
if (!this.state.target.element) return;
|
|
186
|
+
|
|
187
|
+
const targetRect = this.state.target.element.getBoundingClientRect();
|
|
188
|
+
|
|
189
|
+
this.element.style.left = `${targetRect.left}px`;
|
|
190
|
+
this.element.style.top = `${targetRect.top}px`;
|
|
191
|
+
this.element.style.width = `${targetRect.width}px`;
|
|
192
|
+
this.element.style.height = `${targetRect.height}px`;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
// 同步更新目标元素位置
|
|
196
|
+
syncTargetPosition = (resize = true) => {
|
|
197
|
+
if (!this.state.target.element) return;
|
|
198
|
+
if (!this.state.target.parent) return
|
|
199
|
+
|
|
200
|
+
const draggableRect = this.element.getBoundingClientRect();
|
|
201
|
+
const parentRect = this.state.target.parent.getBoundingClientRect();
|
|
202
|
+
|
|
203
|
+
// 设置尺寸
|
|
204
|
+
if (resize) {
|
|
205
|
+
this.setDimension('width', draggableRect.width - this.state.resizeData.calcWidth, parentRect.width, this.target.wUnit);
|
|
206
|
+
this.setDimension('height', draggableRect.height - this.state.resizeData.calcHeight, parentRect.height, this.target.hUnit);
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
// 设置位置
|
|
210
|
+
if (this.target.position === 'fixed') {
|
|
211
|
+
this.setFixedPosition(draggableRect)
|
|
212
|
+
} else {
|
|
213
|
+
this.setRelativePosition(draggableRect, parentRect);
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
this.target.setNeedsUpdate()
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
// 设置元素尺寸
|
|
220
|
+
setDimension = (prop: string, value: number, parentSize: number, unit: string) => {
|
|
221
|
+
//@ts-ignore
|
|
222
|
+
this.target[prop] = unit === '%' ? (value / parentSize) * 100 : value
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
// 设置固定定位
|
|
226
|
+
setFixedPosition = (rect: DOMRect) => {
|
|
227
|
+
if (this.target.xAxis === 'left') {
|
|
228
|
+
const leftPos = rect.left - this.offset.x
|
|
229
|
+
this.target.location.x = this.target.xUnit === '%' ? (leftPos / window.innerWidth) * 100
|
|
230
|
+
: leftPos
|
|
231
|
+
} else {
|
|
232
|
+
const rightPos = window.innerWidth - rect.right + this.offset.x
|
|
233
|
+
this.target.location.x = this.target.xUnit === '%'
|
|
234
|
+
? (rightPos / window.innerWidth) * 100
|
|
235
|
+
: rightPos
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
if (this.target.yAxis === 'top') {
|
|
239
|
+
const topPos = rect.top - this.offset.y
|
|
240
|
+
this.target.location.y = this.target.yUnit === '%'
|
|
241
|
+
? (topPos / window.innerHeight) * 100
|
|
242
|
+
: topPos
|
|
243
|
+
} else {
|
|
244
|
+
const bottomPos = window.innerHeight - rect.bottom + this.offset.y
|
|
245
|
+
this.target.location.y = this.target.yUnit === '%'
|
|
246
|
+
? (bottomPos / window.innerHeight) * 100
|
|
247
|
+
: bottomPos
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
// 设置相对/绝对定位
|
|
252
|
+
setRelativePosition = (draggableRect: DOMRect, parentRect: DOMRect) => {
|
|
253
|
+
if (this.target.xAxis === 'left') {
|
|
254
|
+
const leftPos = draggableRect.left - parentRect.left - this.offset.x;
|
|
255
|
+
this.target.location.x = this.target.xUnit === '%'
|
|
256
|
+
? (leftPos / parentRect.width) * 100
|
|
257
|
+
: leftPos
|
|
258
|
+
} else {
|
|
259
|
+
const rightPos = parentRect.right - draggableRect.right + this.offset.x;
|
|
260
|
+
this.target.location.x = this.target.xUnit === '%'
|
|
261
|
+
? (rightPos / parentRect.width) * 100
|
|
262
|
+
: rightPos
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
if (this.target.yAxis === 'top') {
|
|
266
|
+
const topPos = draggableRect.top - parentRect.top - this.offset.y;
|
|
267
|
+
this.target.location.y = this.target.yUnit === '%'
|
|
268
|
+
? (topPos / parentRect.height) * 100
|
|
269
|
+
: topPos
|
|
270
|
+
} else {
|
|
271
|
+
const bottomPos = parentRect.bottom - draggableRect.bottom + this.offset.y;
|
|
272
|
+
this.target.location.y = this.target.yUnit === '%'
|
|
273
|
+
? (bottomPos / parentRect.height) * 100
|
|
274
|
+
: bottomPos
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
// 拖拽开始
|
|
279
|
+
handleDragStart = (e: MouseEvent) => {
|
|
280
|
+
if (this.descriptor.enabled === false) return
|
|
281
|
+
if (!this.state.target.element) return
|
|
282
|
+
if (this.target.position === 'static' || this.target.position === 'relative') return
|
|
283
|
+
|
|
284
|
+
if (e.target instanceof HTMLElement && e.target.classList.contains('resize-handle') === false) {
|
|
285
|
+
|
|
286
|
+
this.state.isDragging = true;
|
|
287
|
+
|
|
288
|
+
const rect = this.element.getBoundingClientRect();
|
|
289
|
+
this.state.offset = new Vector2(e.clientX - rect.left, e.clientY - rect.top)
|
|
290
|
+
|
|
291
|
+
// 清除目标元素的过渡效果,实现更流畅的拖拽
|
|
292
|
+
this.state.target.element.style.transition = 'none';
|
|
293
|
+
|
|
294
|
+
e.preventDefault();
|
|
295
|
+
|
|
296
|
+
this.change('mousedown')
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
// 调整大小开始
|
|
302
|
+
handleResizeStart = (e: MouseEvent) => {
|
|
303
|
+
if (this.descriptor.enabled === false) return
|
|
304
|
+
if (!this.state.target.element) return;
|
|
305
|
+
if (this.target.position === 'static' || this.target.position === 'relative') return
|
|
306
|
+
if (e.target instanceof HTMLElement) {
|
|
307
|
+
|
|
308
|
+
this.state.isResizing = true;
|
|
309
|
+
this.state.resizeData.direction = e.target.classList[1];
|
|
310
|
+
|
|
311
|
+
const rect = this.element.getBoundingClientRect();
|
|
312
|
+
this.state.resizeData.calcWidth = this.target.calcWidth
|
|
313
|
+
this.state.resizeData.calcHeight = this.target.calcHeight
|
|
314
|
+
this.state.resizeData.startWidth = rect.width;
|
|
315
|
+
this.state.resizeData.startHeight = rect.height;
|
|
316
|
+
this.state.resizeData.startX = rect.left;
|
|
317
|
+
this.state.resizeData.startY = rect.top;
|
|
318
|
+
this.state.offset = new Vector2(e.clientX, e.clientY)
|
|
319
|
+
|
|
320
|
+
// 清除目标元素的过渡效果,实现更流畅的调整
|
|
321
|
+
this.state.target.element.style.transition = 'none';
|
|
322
|
+
|
|
323
|
+
e.preventDefault();
|
|
324
|
+
|
|
325
|
+
this.change('mousedown')
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
|
|
329
|
+
// 鼠标移动处理
|
|
330
|
+
handleMouseMove = (e: MouseEvent) => {
|
|
331
|
+
if (!this.state.target.element) return
|
|
332
|
+
|
|
333
|
+
if (this.state.isDragging) {
|
|
334
|
+
// 更新拖拽元素位置
|
|
335
|
+
this.element.style.left = `${e.clientX - this.state.offset.x}px`;
|
|
336
|
+
this.element.style.top = `${e.clientY - this.state.offset.y}px`;
|
|
337
|
+
|
|
338
|
+
// 同步更新目标元素
|
|
339
|
+
this.syncTargetPosition(false);
|
|
340
|
+
this.change()
|
|
341
|
+
} else if (this.state.isResizing) {
|
|
342
|
+
this.handleResizing(e);
|
|
343
|
+
this.change()
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
// 处理调整大小
|
|
348
|
+
handleResizing = (e: MouseEvent) => {
|
|
349
|
+
const deltaX = e.clientX - this.state.offset.x;
|
|
350
|
+
const deltaY = e.clientY - this.state.offset.y;
|
|
351
|
+
const { direction, startWidth, startHeight, startX, startY } = this.state.resizeData;
|
|
352
|
+
|
|
353
|
+
let newWidth = startWidth;
|
|
354
|
+
let newHeight = startHeight;
|
|
355
|
+
let newLeft = startX;
|
|
356
|
+
let newTop = startY;
|
|
357
|
+
|
|
358
|
+
// 根据调整方向计算新尺寸和位置
|
|
359
|
+
switch (direction) {
|
|
360
|
+
case '0':
|
|
361
|
+
newWidth = Math.max(20, startWidth - deltaX);
|
|
362
|
+
newHeight = Math.max(20, startHeight - deltaY);
|
|
363
|
+
newLeft = startX + (startWidth - newWidth);
|
|
364
|
+
newTop = startY + (startHeight - newHeight);
|
|
365
|
+
break;
|
|
366
|
+
case '1':
|
|
367
|
+
newWidth = Math.max(20, startWidth + deltaX);
|
|
368
|
+
newHeight = Math.max(20, startHeight - deltaY);
|
|
369
|
+
newTop = startY + (startHeight - newHeight);
|
|
370
|
+
break;
|
|
371
|
+
case '3':
|
|
372
|
+
newWidth = Math.max(20, startWidth - deltaX);
|
|
373
|
+
newHeight = Math.max(20, startHeight + deltaY);
|
|
374
|
+
newLeft = startX + (startWidth - newWidth);
|
|
375
|
+
break;
|
|
376
|
+
case '2':
|
|
377
|
+
newWidth = Math.max(20, startWidth + deltaX);
|
|
378
|
+
newHeight = Math.max(20, startHeight + deltaY);
|
|
379
|
+
break;
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
this.element.style.width = `${newWidth}px`;
|
|
383
|
+
this.element.style.height = `${newHeight}px`;
|
|
384
|
+
this.element.style.left = `${newLeft}px`;
|
|
385
|
+
this.element.style.top = `${newTop}px`;
|
|
386
|
+
|
|
387
|
+
this.updateOffset(this.element.getBoundingClientRect())
|
|
388
|
+
|
|
389
|
+
// 同步更新目标元素
|
|
390
|
+
this.syncTargetPosition();
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
// 鼠标释放处理
|
|
394
|
+
handleMouseEnd = () => {
|
|
395
|
+
if (!this.state.target.element) return
|
|
396
|
+
|
|
397
|
+
if (this.state.isDragging) {
|
|
398
|
+
this.state.isDragging = false;
|
|
399
|
+
} else if (this.state.isResizing) {
|
|
400
|
+
this.state.isResizing = false;
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
this.change('mouseup')
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
export {
|
|
408
|
+
HTMLTransformControllerActor
|
|
409
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { Asset } from "../asset"
|
|
2
|
+
import { Actor } from "./Actor"
|
|
3
|
+
import { StyleDescriptor } from "../descriptor"
|
|
4
|
+
import { StyleInterpreter } from "../interpreter"
|
|
5
|
+
|
|
6
|
+
interface RuleObjects extends Array<{ name: string, value: string }> { }
|
|
7
|
+
|
|
8
|
+
class StyleActor extends Actor {
|
|
9
|
+
private _styleCollection = new Map<string, RuleObjects>()
|
|
10
|
+
private _className: string[] = []
|
|
11
|
+
|
|
12
|
+
getStyleValue() {
|
|
13
|
+
const styles: string[] = []
|
|
14
|
+
|
|
15
|
+
const entries = this._styleCollection.entries()
|
|
16
|
+
for (const [selectorText, rules] of entries) {
|
|
17
|
+
const style: string[] = []
|
|
18
|
+
style.push(`${selectorText}{`)
|
|
19
|
+
if (rules.length === 0) {
|
|
20
|
+
style.push('/* 如果需要样式,在这里添加 */')
|
|
21
|
+
} else {
|
|
22
|
+
for (const rule of rules) {
|
|
23
|
+
style.push(`${rule.name}:${rule.value};`)
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
style.push(`}`)
|
|
27
|
+
styles.push(style.join('\n'))
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return styles
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
getClassName() {
|
|
34
|
+
return [...this._className]
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
updateRule(sheet: CSSStyleSheet) {
|
|
38
|
+
let count = 0
|
|
39
|
+
for (const rule of sheet.cssRules) {
|
|
40
|
+
if (rule instanceof CSSStyleRule) {
|
|
41
|
+
const styleObjects = this._styleCollection.get(rule.selectorText)
|
|
42
|
+
if (styleObjects === undefined) continue
|
|
43
|
+
|
|
44
|
+
count++
|
|
45
|
+
rule.style.cssText = ''
|
|
46
|
+
for (const styleObject of styleObjects) {
|
|
47
|
+
rule.style.setProperty(styleObject.name, styleObject.value)
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
if (count === 2) return true
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return false
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
update(descriptor: StyleDescriptor, className: string) {
|
|
57
|
+
this._className.length = 0
|
|
58
|
+
this._styleCollection.clear()
|
|
59
|
+
|
|
60
|
+
let inherit = Asset.get<StyleDescriptor>(descriptor.inherit)
|
|
61
|
+
if (inherit) {
|
|
62
|
+
const graphics = Actor.getGraphics(this)
|
|
63
|
+
const interpreter = graphics.getInterpreter<StyleInterpreter>(inherit)
|
|
64
|
+
this._className.push(interpreter.className)
|
|
65
|
+
}
|
|
66
|
+
this._className.push(className)
|
|
67
|
+
|
|
68
|
+
const rules: RuleObjects = []
|
|
69
|
+
for (const rule of descriptor.rules) {
|
|
70
|
+
if (rule.inherit === true) continue
|
|
71
|
+
const value = rule.getValue()
|
|
72
|
+
rules.push({ name: rule.name, value })
|
|
73
|
+
}
|
|
74
|
+
this._styleCollection.set(`.${className}`, rules)
|
|
75
|
+
|
|
76
|
+
const hover: RuleObjects = []
|
|
77
|
+
for (const rule of descriptor.hoverRules) {
|
|
78
|
+
if (rule.inherit === true) continue
|
|
79
|
+
const value = rule.getValue()
|
|
80
|
+
hover.push({ name: rule.name, value })
|
|
81
|
+
}
|
|
82
|
+
this._styleCollection.set(`.${className}:hover`, hover)
|
|
83
|
+
|
|
84
|
+
const active: RuleObjects = []
|
|
85
|
+
for (const rule of descriptor.activeRules) {
|
|
86
|
+
if (rule.inherit === true) continue
|
|
87
|
+
const value = rule.getValue()
|
|
88
|
+
active.push({ name: rule.name, value })
|
|
89
|
+
}
|
|
90
|
+
this._styleCollection.set(`.${className}.${StyleDescriptor.activeName}`, active)
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export {
|
|
95
|
+
StyleActor
|
|
96
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './Actor'
|
|
2
|
+
export * from './StyleActor'
|
|
3
|
+
export * from './AnimationUnitActor'
|
|
4
|
+
export * from './FragmentActor'
|
|
5
|
+
export * from './HTMActor'
|
|
6
|
+
export * from './DivActor'
|
|
7
|
+
export * from './HTMServiceActor'
|
|
8
|
+
export * from './HTMTransformControllerActor'
|