@tableslayer/ui 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +105 -0
- package/README.md +45 -0
- package/dist/components/Avatar/Avatar.svelte +82 -0
- package/dist/components/Avatar/Avatar.svelte.d.ts +4 -0
- package/dist/components/Avatar/AvatarFileInput.svelte +85 -0
- package/dist/components/Avatar/AvatarFileInput.svelte.d.ts +4 -0
- package/dist/components/Avatar/AvatarPopover.svelte +34 -0
- package/dist/components/Avatar/AvatarPopover.svelte.d.ts +4 -0
- package/dist/components/Avatar/index.d.ts +4 -0
- package/dist/components/Avatar/index.js +4 -0
- package/dist/components/Avatar/types.d.ts +21 -0
- package/dist/components/Avatar/types.js +1 -0
- package/dist/components/BrushSizeSlider/BrushSizeSlider.svelte +174 -0
- package/dist/components/BrushSizeSlider/BrushSizeSlider.svelte.d.ts +11 -0
- package/dist/components/BrushSizeSlider/index.d.ts +1 -0
- package/dist/components/BrushSizeSlider/index.js +1 -0
- package/dist/components/Button/Button.svelte +182 -0
- package/dist/components/Button/Button.svelte.d.ts +26 -0
- package/dist/components/Button/ConfirmActionButton.svelte +98 -0
- package/dist/components/Button/ConfirmActionButton.svelte.d.ts +4 -0
- package/dist/components/Button/IconButton.svelte +121 -0
- package/dist/components/Button/IconButton.svelte.d.ts +4 -0
- package/dist/components/Button/RadioButton.svelte +93 -0
- package/dist/components/Button/RadioButton.svelte.d.ts +15 -0
- package/dist/components/Button/index.d.ts +5 -0
- package/dist/components/Button/index.js +5 -0
- package/dist/components/Button/types.d.ts +55 -0
- package/dist/components/Button/types.js +1 -0
- package/dist/components/CardFan/CardFan.svelte +165 -0
- package/dist/components/CardFan/CardFan.svelte.d.ts +4 -0
- package/dist/components/CardFan/index.d.ts +2 -0
- package/dist/components/CardFan/index.js +2 -0
- package/dist/components/CardFan/types.d.ts +5 -0
- package/dist/components/CardFan/types.js +1 -0
- package/dist/components/CodeBlock/Code.svelte +7 -0
- package/dist/components/CodeBlock/Code.svelte.d.ts +4 -0
- package/dist/components/CodeBlock/CodeBlock.svelte +102 -0
- package/dist/components/CodeBlock/CodeBlock.svelte.d.ts +4 -0
- package/dist/components/CodeBlock/index.d.ts +3 -0
- package/dist/components/CodeBlock/index.js +3 -0
- package/dist/components/CodeBlock/types.d.ts +9 -0
- package/dist/components/CodeBlock/types.js +1 -0
- package/dist/components/ColorMode/ColorMode.svelte +8 -0
- package/dist/components/ColorMode/ColorMode.svelte.d.ts +4 -0
- package/dist/components/ColorMode/index.d.ts +2 -0
- package/dist/components/ColorMode/index.js +1 -0
- package/dist/components/ColorMode/types.d.ts +10 -0
- package/dist/components/ColorMode/types.js +1 -0
- package/dist/components/ColorPicker/ColorPicker.svelte +838 -0
- package/dist/components/ColorPicker/ColorPicker.svelte.d.ts +4 -0
- package/dist/components/ColorPicker/ColorPickerSwatch.svelte +32 -0
- package/dist/components/ColorPicker/ColorPickerSwatch.svelte.d.ts +6 -0
- package/dist/components/ColorPicker/index.d.ts +3 -0
- package/dist/components/ColorPicker/index.js +3 -0
- package/dist/components/ColorPicker/types.d.ts +60 -0
- package/dist/components/ColorPicker/types.js +1 -0
- package/dist/components/ContextMenu/ContextMenu.svelte +86 -0
- package/dist/components/ContextMenu/ContextMenu.svelte.d.ts +4 -0
- package/dist/components/ContextMenu/index.d.ts +2 -0
- package/dist/components/ContextMenu/index.js +2 -0
- package/dist/components/ContextMenu/types.d.ts +13 -0
- package/dist/components/ContextMenu/types.js +1 -0
- package/dist/components/DrawingSliders/DrawingSliders.svelte +379 -0
- package/dist/components/DrawingSliders/DrawingSliders.svelte.d.ts +16 -0
- package/dist/components/DrawingSliders/index.d.ts +1 -0
- package/dist/components/DrawingSliders/index.js +1 -0
- package/dist/components/Editor/Editor.svelte +825 -0
- package/dist/components/Editor/Editor.svelte.d.ts +11 -0
- package/dist/components/Editor/index.d.ts +1 -0
- package/dist/components/Editor/index.js +1 -0
- package/dist/components/FogSliders/FogSliders.svelte +33 -0
- package/dist/components/FogSliders/FogSliders.svelte.d.ts +7 -0
- package/dist/components/FogSliders/index.d.ts +1 -0
- package/dist/components/FogSliders/index.js +1 -0
- package/dist/components/Hr/Hr.svelte +15 -0
- package/dist/components/Hr/Hr.svelte.d.ts +3 -0
- package/dist/components/Hr/index.d.ts +1 -0
- package/dist/components/Hr/index.js +1 -0
- package/dist/components/Icon/Icon.svelte +6 -0
- package/dist/components/Icon/Icon.svelte.d.ts +4 -0
- package/dist/components/Icon/index.d.ts +2 -0
- package/dist/components/Icon/index.js +1 -0
- package/dist/components/Icon/types.d.ts +18 -0
- package/dist/components/Icon/types.js +1 -0
- package/dist/components/Input/DualInputSlider.svelte +126 -0
- package/dist/components/Input/DualInputSlider.svelte.d.ts +4 -0
- package/dist/components/Input/FileInput.svelte +176 -0
- package/dist/components/Input/FileInput.svelte.d.ts +21 -0
- package/dist/components/Input/FormControl.svelte +150 -0
- package/dist/components/Input/FormControl.svelte.d.ts +41 -0
- package/dist/components/Input/FormError.svelte +37 -0
- package/dist/components/Input/FormError.svelte.d.ts +13 -0
- package/dist/components/Input/Input.svelte +56 -0
- package/dist/components/Input/Input.svelte.d.ts +4 -0
- package/dist/components/Input/InputCheckbox.svelte +99 -0
- package/dist/components/Input/InputCheckbox.svelte.d.ts +4 -0
- package/dist/components/Input/InputSlider.svelte +86 -0
- package/dist/components/Input/InputSlider.svelte.d.ts +4 -0
- package/dist/components/Input/Label.svelte +19 -0
- package/dist/components/Input/Label.svelte.d.ts +4 -0
- package/dist/components/Input/index.d.ts +9 -0
- package/dist/components/Input/index.js +9 -0
- package/dist/components/Input/types.d.ts +33 -0
- package/dist/components/Input/types.js +1 -0
- package/dist/components/Link/Link.svelte +41 -0
- package/dist/components/Link/Link.svelte.d.ts +4 -0
- package/dist/components/Link/LinkBox.svelte +20 -0
- package/dist/components/Link/LinkBox.svelte.d.ts +4 -0
- package/dist/components/Link/LinkOverlay.svelte +23 -0
- package/dist/components/Link/LinkOverlay.svelte.d.ts +4 -0
- package/dist/components/Link/index.d.ts +4 -0
- package/dist/components/Link/index.js +4 -0
- package/dist/components/Link/types.d.ts +15 -0
- package/dist/components/Link/types.js +1 -0
- package/dist/components/Loading/Loader.svelte +60 -0
- package/dist/components/Loading/Loader.svelte.d.ts +3 -0
- package/dist/components/Loading/Skeleton.svelte +9 -0
- package/dist/components/Loading/Skeleton.svelte.d.ts +26 -0
- package/dist/components/Loading/index.d.ts +2 -0
- package/dist/components/Loading/index.js +2 -0
- package/dist/components/Logo/Logo.svelte +16 -0
- package/dist/components/Logo/Logo.svelte.d.ts +7 -0
- package/dist/components/Logo/index.d.ts +1 -0
- package/dist/components/Logo/index.js +1 -0
- package/dist/components/MarkerTooltip/MarkerTooltip.svelte +435 -0
- package/dist/components/MarkerTooltip/MarkerTooltip.svelte.d.ts +35 -0
- package/dist/components/MarkerTooltip/index.d.ts +1 -0
- package/dist/components/MarkerTooltip/index.js +1 -0
- package/dist/components/Menu/SelectorMenu.svelte +280 -0
- package/dist/components/Menu/SelectorMenu.svelte.d.ts +4 -0
- package/dist/components/Menu/index.d.ts +2 -0
- package/dist/components/Menu/index.js +2 -0
- package/dist/components/Menu/types.d.ts +20 -0
- package/dist/components/Menu/types.js +1 -0
- package/dist/components/MyCounterButton.svelte +11 -0
- package/dist/components/MyCounterButton.svelte.d.ts +3 -0
- package/dist/components/Panel/index.d.ts +2 -0
- package/dist/components/Panel/index.js +2 -0
- package/dist/components/Panel/panel.svelte +18 -0
- package/dist/components/Panel/panel.svelte.d.ts +4 -0
- package/dist/components/Panel/types.d.ts +7 -0
- package/dist/components/Panel/types.js +1 -0
- package/dist/components/PersistButton/PersistButton.svelte +100 -0
- package/dist/components/PersistButton/PersistButton.svelte.d.ts +12 -0
- package/dist/components/PersistButton/index.d.ts +1 -0
- package/dist/components/PersistButton/index.js +1 -0
- package/dist/components/Popover/Popover.svelte +81 -0
- package/dist/components/Popover/Popover.svelte.d.ts +6 -0
- package/dist/components/Popover/index.d.ts +2 -0
- package/dist/components/Popover/index.js +2 -0
- package/dist/components/Popover/types.d.ts +17 -0
- package/dist/components/Popover/types.js +1 -0
- package/dist/components/PropsTable/PropsTable.svelte +107 -0
- package/dist/components/PropsTable/PropsTable.svelte.d.ts +26 -0
- package/dist/components/RadialMenu/EffectPreview.svelte +36 -0
- package/dist/components/RadialMenu/EffectPreview.svelte.d.ts +9 -0
- package/dist/components/RadialMenu/EffectPreviewScene.svelte +194 -0
- package/dist/components/RadialMenu/EffectPreviewScene.svelte.d.ts +8 -0
- package/dist/components/RadialMenu/RadialMenu.svelte +503 -0
- package/dist/components/RadialMenu/RadialMenu.svelte.d.ts +4 -0
- package/dist/components/RadialMenu/RadialMenuItem.svelte +176 -0
- package/dist/components/RadialMenu/RadialMenuItem.svelte.d.ts +11 -0
- package/dist/components/RadialMenu/index.d.ts +2 -0
- package/dist/components/RadialMenu/index.js +2 -0
- package/dist/components/RadialMenu/types.d.ts +35 -0
- package/dist/components/RadialMenu/types.js +1 -0
- package/dist/components/Select/Select.svelte +342 -0
- package/dist/components/Select/Select.svelte.d.ts +4 -0
- package/dist/components/Select/index.d.ts +2 -0
- package/dist/components/Select/index.js +2 -0
- package/dist/components/Select/types.d.ts +24 -0
- package/dist/components/Select/types.js +1 -0
- package/dist/components/Spacer/Spacer.svelte +14 -0
- package/dist/components/Spacer/Spacer.svelte.d.ts +4 -0
- package/dist/components/Spacer/index.d.ts +2 -0
- package/dist/components/Spacer/index.js +2 -0
- package/dist/components/Spacer/types.d.ts +4 -0
- package/dist/components/Spacer/types.js +1 -0
- package/dist/components/Stage/components/AnnotationLayer/AnnotationLayer.svelte +445 -0
- package/dist/components/Stage/components/AnnotationLayer/AnnotationLayer.svelte.d.ts +19 -0
- package/dist/components/Stage/components/AnnotationLayer/AnnotationMaterial.svelte +167 -0
- package/dist/components/Stage/components/AnnotationLayer/AnnotationMaterial.svelte.d.ts +20 -0
- package/dist/components/Stage/components/AnnotationLayer/types.d.ts +121 -0
- package/dist/components/Stage/components/AnnotationLayer/types.js +71 -0
- package/dist/components/Stage/components/CursorLayer/CursorLayer.svelte +148 -0
- package/dist/components/Stage/components/CursorLayer/CursorLayer.svelte.d.ts +7 -0
- package/dist/components/Stage/components/CursorLayer/cursor.svg +26 -0
- package/dist/components/Stage/components/CursorLayer/index.d.ts +2 -0
- package/dist/components/Stage/components/CursorLayer/index.js +1 -0
- package/dist/components/Stage/components/CursorLayer/types.d.ts +28 -0
- package/dist/components/Stage/components/CursorLayer/types.js +1 -0
- package/dist/components/Stage/components/DrawingLayer/DrawingMaterial.svelte +364 -0
- package/dist/components/Stage/components/DrawingLayer/DrawingMaterial.svelte.d.ts +24 -0
- package/dist/components/Stage/components/DrawingLayer/types.d.ts +56 -0
- package/dist/components/Stage/components/DrawingLayer/types.js +23 -0
- package/dist/components/Stage/components/EdgeOverlayLayer/EdgeOverlayLayer.svelte +72 -0
- package/dist/components/Stage/components/EdgeOverlayLayer/EdgeOverlayLayer.svelte.d.ts +11 -0
- package/dist/components/Stage/components/EdgeOverlayLayer/types.d.ts +29 -0
- package/dist/components/Stage/components/EdgeOverlayLayer/types.js +1 -0
- package/dist/components/Stage/components/FogLayer/FogLayer.svelte +75 -0
- package/dist/components/Stage/components/FogLayer/FogLayer.svelte.d.ts +11 -0
- package/dist/components/Stage/components/FogLayer/types.d.ts +42 -0
- package/dist/components/Stage/components/FogLayer/types.js +1 -0
- package/dist/components/Stage/components/FogOfWarLayer/FogOfWarLayer.svelte +249 -0
- package/dist/components/Stage/components/FogOfWarLayer/FogOfWarLayer.svelte.d.ts +19 -0
- package/dist/components/Stage/components/FogOfWarLayer/FogOfWarMaterial.svelte +200 -0
- package/dist/components/Stage/components/FogOfWarLayer/FogOfWarMaterial.svelte.d.ts +18 -0
- package/dist/components/Stage/components/FogOfWarLayer/types.d.ts +143 -0
- package/dist/components/Stage/components/FogOfWarLayer/types.js +1 -0
- package/dist/components/Stage/components/GridLayer/GridLayer.svelte +20 -0
- package/dist/components/Stage/components/GridLayer/GridLayer.svelte.d.ts +12 -0
- package/dist/components/Stage/components/GridLayer/GridMaterial.svelte +69 -0
- package/dist/components/Stage/components/GridLayer/GridMaterial.svelte.d.ts +10 -0
- package/dist/components/Stage/components/GridLayer/types.d.ts +65 -0
- package/dist/components/Stage/components/GridLayer/types.js +10 -0
- package/dist/components/Stage/components/LayerInput/LayerInput.svelte +300 -0
- package/dist/components/Stage/components/LayerInput/LayerInput.svelte.d.ts +20 -0
- package/dist/components/Stage/components/MapLayer/MapLayer.svelte +196 -0
- package/dist/components/Stage/components/MapLayer/MapLayer.svelte.d.ts +24 -0
- package/dist/components/Stage/components/MapLayer/dataSources/GifDataSource.d.ts +93 -0
- package/dist/components/Stage/components/MapLayer/dataSources/GifDataSource.js +229 -0
- package/dist/components/Stage/components/MapLayer/dataSources/IMapDataSource.d.ts +51 -0
- package/dist/components/Stage/components/MapLayer/dataSources/IMapDataSource.js +1 -0
- package/dist/components/Stage/components/MapLayer/dataSources/ImageDataSource.d.ts +49 -0
- package/dist/components/Stage/components/MapLayer/dataSources/ImageDataSource.js +87 -0
- package/dist/components/Stage/components/MapLayer/dataSources/VideoDataSource.d.ts +52 -0
- package/dist/components/Stage/components/MapLayer/dataSources/VideoDataSource.js +141 -0
- package/dist/components/Stage/components/MapLayer/dataSources/dataSourceFactory.d.ts +21 -0
- package/dist/components/Stage/components/MapLayer/dataSources/dataSourceFactory.js +44 -0
- package/dist/components/Stage/components/MapLayer/dataSources/index.d.ts +15 -0
- package/dist/components/Stage/components/MapLayer/dataSources/index.js +14 -0
- package/dist/components/Stage/components/MapLayer/types.d.ts +54 -0
- package/dist/components/Stage/components/MapLayer/types.js +9 -0
- package/dist/components/Stage/components/MarkerLayer/MarkerLayer.svelte +398 -0
- package/dist/components/Stage/components/MarkerLayer/MarkerLayer.svelte.d.ts +24 -0
- package/dist/components/Stage/components/MarkerLayer/MarkerToken.svelte +262 -0
- package/dist/components/Stage/components/MarkerLayer/MarkerToken.svelte.d.ts +27 -0
- package/dist/components/Stage/components/MarkerLayer/types.d.ts +109 -0
- package/dist/components/Stage/components/MarkerLayer/types.js +21 -0
- package/dist/components/Stage/components/MeasurementLayer/MeasurementLayer.svelte +364 -0
- package/dist/components/Stage/components/MeasurementLayer/MeasurementLayer.svelte.d.ts +49 -0
- package/dist/components/Stage/components/MeasurementLayer/MeasurementManager.svelte +473 -0
- package/dist/components/Stage/components/MeasurementLayer/MeasurementManager.svelte.d.ts +24 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/BaseMeasurement.d.ts +150 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/BaseMeasurement.js +274 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/BeamMeasurement.d.ts +10 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/BeamMeasurement.js +58 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/CircleMeasurement.d.ts +9 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/CircleMeasurement.js +66 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/ConeMeasurement.d.ts +10 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/ConeMeasurement.js +103 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/LineMeasurement.d.ts +9 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/LineMeasurement.js +75 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/RectangleMeasurement.d.ts +9 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/RectangleMeasurement.js +73 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/index.d.ts +2 -0
- package/dist/components/Stage/components/MeasurementLayer/measurements/index.js +7 -0
- package/dist/components/Stage/components/MeasurementLayer/types.d.ts +76 -0
- package/dist/components/Stage/components/MeasurementLayer/types.js +9 -0
- package/dist/components/Stage/components/MeasurementLayer/utils/canvasDrawing.d.ts +83 -0
- package/dist/components/Stage/components/MeasurementLayer/utils/canvasDrawing.js +267 -0
- package/dist/components/Stage/components/MeasurementLayer/utils/distanceCalculations.d.ts +74 -0
- package/dist/components/Stage/components/MeasurementLayer/utils/distanceCalculations.js +130 -0
- package/dist/components/Stage/components/ParticleSystem/ParticleSystem.svelte +220 -0
- package/dist/components/Stage/components/ParticleSystem/ParticleSystem.svelte.d.ts +9 -0
- package/dist/components/Stage/components/ParticleSystem/particles/atlases/ash.png +0 -0
- package/dist/components/Stage/components/ParticleSystem/particles/atlases/leaves.png +0 -0
- package/dist/components/Stage/components/ParticleSystem/particles/atlases/rain.png +0 -0
- package/dist/components/Stage/components/ParticleSystem/particles/atlases/snow.png +0 -0
- package/dist/components/Stage/components/ParticleSystem/rng.d.ts +7 -0
- package/dist/components/Stage/components/ParticleSystem/rng.js +20 -0
- package/dist/components/Stage/components/ParticleSystem/types.d.ts +88 -0
- package/dist/components/Stage/components/ParticleSystem/types.js +37 -0
- package/dist/components/Stage/components/PerformanceDebugger/PerformanceDebugger.svelte +144 -0
- package/dist/components/Stage/components/PerformanceDebugger/PerformanceDebugger.svelte.d.ts +19 -0
- package/dist/components/Stage/components/PerformanceDebugger/index.d.ts +1 -0
- package/dist/components/Stage/components/PerformanceDebugger/index.js +1 -0
- package/dist/components/Stage/components/PerformanceOverlay/PerformanceOverlay.svelte +208 -0
- package/dist/components/Stage/components/PerformanceOverlay/PerformanceOverlay.svelte.d.ts +7 -0
- package/dist/components/Stage/components/PerformanceOverlay/index.d.ts +1 -0
- package/dist/components/Stage/components/PerformanceOverlay/index.js +1 -0
- package/dist/components/Stage/components/PointerInputManager/PointerInputManager.svelte +201 -0
- package/dist/components/Stage/components/PointerInputManager/PointerInputManager.svelte.d.ts +17 -0
- package/dist/components/Stage/components/Scene/Scene.svelte +651 -0
- package/dist/components/Stage/components/Scene/Scene.svelte.d.ts +88 -0
- package/dist/components/Stage/components/Scene/luts.d.ts +7 -0
- package/dist/components/Stage/components/Scene/luts.js +33 -0
- package/dist/components/Stage/components/Scene/types.d.ts +207 -0
- package/dist/components/Stage/components/Scene/types.js +35 -0
- package/dist/components/Stage/components/Stage/Stage.svelte +332 -0
- package/dist/components/Stage/components/Stage/Stage.svelte.d.ts +86 -0
- package/dist/components/Stage/components/Stage/types.d.ts +163 -0
- package/dist/components/Stage/components/Stage/types.js +5 -0
- package/dist/components/Stage/components/WeatherLayer/WeatherLayer.svelte +135 -0
- package/dist/components/Stage/components/WeatherLayer/WeatherLayer.svelte.d.ts +13 -0
- package/dist/components/Stage/components/WeatherLayer/presets/AshPreset.d.ts +3 -0
- package/dist/components/Stage/components/WeatherLayer/presets/AshPreset.js +69 -0
- package/dist/components/Stage/components/WeatherLayer/presets/LeavesPreset.d.ts +3 -0
- package/dist/components/Stage/components/WeatherLayer/presets/LeavesPreset.js +68 -0
- package/dist/components/Stage/components/WeatherLayer/presets/RainPreset.d.ts +3 -0
- package/dist/components/Stage/components/WeatherLayer/presets/RainPreset.js +67 -0
- package/dist/components/Stage/components/WeatherLayer/presets/SnowPreset.d.ts +3 -0
- package/dist/components/Stage/components/WeatherLayer/presets/SnowPreset.js +68 -0
- package/dist/components/Stage/components/WeatherLayer/presets/index.d.ts +5 -0
- package/dist/components/Stage/components/WeatherLayer/presets/index.js +5 -0
- package/dist/components/Stage/components/WeatherLayer/types.d.ts +31 -0
- package/dist/components/Stage/components/WeatherLayer/types.js +9 -0
- package/dist/components/Stage/helpers/clippingPlaneStore.svelte.d.ts +7 -0
- package/dist/components/Stage/helpers/clippingPlaneStore.svelte.js +23 -0
- package/dist/components/Stage/helpers/debugState.svelte.d.ts +10 -0
- package/dist/components/Stage/helpers/debugState.svelte.js +13 -0
- package/dist/components/Stage/helpers/grid.d.ts +72 -0
- package/dist/components/Stage/helpers/grid.js +444 -0
- package/dist/components/Stage/helpers/lazyBrush.d.ts +63 -0
- package/dist/components/Stage/helpers/lazyBrush.js +137 -0
- package/dist/components/Stage/helpers/performanceMetrics.svelte.d.ts +62 -0
- package/dist/components/Stage/helpers/performanceMetrics.svelte.js +165 -0
- package/dist/components/Stage/helpers/utils.d.ts +3 -0
- package/dist/components/Stage/helpers/utils.js +18 -0
- package/dist/components/Stage/index.d.ts +21 -0
- package/dist/components/Stage/index.js +21 -0
- package/dist/components/Stage/shaders/AnnotationEffects.frag +1070 -0
- package/dist/components/Stage/shaders/Annotations.frag +29 -0
- package/dist/components/Stage/shaders/Drawing.frag +83 -0
- package/dist/components/Stage/shaders/Drawing.vert +5 -0
- package/dist/components/Stage/shaders/Fog.frag +147 -0
- package/dist/components/Stage/shaders/FractalNoise.frag +96 -0
- package/dist/components/Stage/shaders/GridShader.frag +174 -0
- package/dist/components/Stage/shaders/Overlay.frag +23 -0
- package/dist/components/Stage/shaders/Overlay.vert +0 -0
- package/dist/components/Stage/shaders/Particles.frag +27 -0
- package/dist/components/Stage/shaders/Particles.vert +51 -0
- package/dist/components/Stage/shaders/ToolOutline.frag +59 -0
- package/dist/components/Stage/shaders/default.vert +8 -0
- package/dist/components/Stage/types.d.ts +4 -0
- package/dist/components/Stage/types.js +1 -0
- package/dist/components/Table/Table.svelte +16 -0
- package/dist/components/Table/Table.svelte.d.ts +4 -0
- package/dist/components/Table/Td.svelte +17 -0
- package/dist/components/Table/Td.svelte.d.ts +4 -0
- package/dist/components/Table/Th.svelte +18 -0
- package/dist/components/Table/Th.svelte.d.ts +4 -0
- package/dist/components/Table/index.d.ts +4 -0
- package/dist/components/Table/index.js +4 -0
- package/dist/components/Table/types.d.ts +11 -0
- package/dist/components/Table/types.js +1 -0
- package/dist/components/Text/Text.svelte +23 -0
- package/dist/components/Text/Text.svelte.d.ts +4 -0
- package/dist/components/Text/index.d.ts +2 -0
- package/dist/components/Text/index.js +2 -0
- package/dist/components/Text/types.d.ts +11 -0
- package/dist/components/Text/types.js +1 -0
- package/dist/components/Title/Title.svelte +54 -0
- package/dist/components/Title/Title.svelte.d.ts +4 -0
- package/dist/components/Title/index.d.ts +2 -0
- package/dist/components/Title/index.js +2 -0
- package/dist/components/Title/types.d.ts +8 -0
- package/dist/components/Title/types.js +1 -0
- package/dist/components/Toast/Toast.svelte +155 -0
- package/dist/components/Toast/Toast.svelte.d.ts +5 -0
- package/dist/components/Toast/index.d.ts +3 -0
- package/dist/components/Toast/index.js +5 -0
- package/dist/components/Toast/toastCookie.d.ts +7 -0
- package/dist/components/Toast/toastCookie.js +17 -0
- package/dist/components/Toast/types.d.ts +6 -0
- package/dist/components/Toast/types.js +1 -0
- package/dist/components/ToolTip/ToolTip.svelte +70 -0
- package/dist/components/ToolTip/ToolTip.svelte.d.ts +4 -0
- package/dist/components/ToolTip/index.d.ts +2 -0
- package/dist/components/ToolTip/index.js +2 -0
- package/dist/components/ToolTip/types.d.ts +14 -0
- package/dist/components/ToolTip/types.js +1 -0
- package/dist/components/index.d.ts +32 -0
- package/dist/components/index.js +32 -0
- package/dist/components/types.d.ts +0 -0
- package/dist/components/types.js +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/styles/globals.css +108 -0
- package/dist/styles/normalize.css +9 -0
- package/dist/styles/reset.css +133 -0
- package/dist/styles/utilities.css +179 -0
- package/dist/styles/vars.css +1103 -0
- package/dist/types/awareness.d.ts +16 -0
- package/dist/types/awareness.js +1 -0
- package/dist/utils/rle.d.ts +41 -0
- package/dist/utils/rle.js +201 -0
- package/package.json +110 -0
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import { type Props as ThrelteProps } from '@threlte/core';
|
|
3
|
+
import { type GridLayerProps } from './types';
|
|
4
|
+
import { type DisplayProps } from '../Stage/types';
|
|
5
|
+
interface Props extends ThrelteProps<typeof THREE.Mesh> {
|
|
6
|
+
grid: GridLayerProps;
|
|
7
|
+
display: DisplayProps;
|
|
8
|
+
sceneZoom: number;
|
|
9
|
+
}
|
|
10
|
+
declare const GridLayer: import("svelte").Component<Props, {}, "">;
|
|
11
|
+
type GridLayer = ReturnType<typeof GridLayer>;
|
|
12
|
+
export default GridLayer;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import * as THREE from 'three';
|
|
3
|
+
import type { GridLayerProps } from './types';
|
|
4
|
+
import type { DisplayProps } from '../Stage/types';
|
|
5
|
+
import fragmentShader from '../../shaders/GridShader.frag?raw';
|
|
6
|
+
import vertexShader from '../../shaders/default.vert?raw';
|
|
7
|
+
import { T, useThrelte } from '@threlte/core';
|
|
8
|
+
|
|
9
|
+
interface Props {
|
|
10
|
+
grid: GridLayerProps;
|
|
11
|
+
display: DisplayProps;
|
|
12
|
+
sceneZoom: number;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
let { invalidate } = useThrelte();
|
|
16
|
+
const { grid, display, sceneZoom }: Props = $props();
|
|
17
|
+
|
|
18
|
+
let material = new THREE.ShaderMaterial({
|
|
19
|
+
uniforms: {
|
|
20
|
+
uOpacity: new THREE.Uniform(grid.opacity),
|
|
21
|
+
uGridType: new THREE.Uniform(grid.gridType),
|
|
22
|
+
uGridMode: new THREE.Uniform(grid.gridMode || 0),
|
|
23
|
+
uSpacing_in: new THREE.Uniform(grid.spacing),
|
|
24
|
+
uPadding_px: new THREE.Uniform(display.padding),
|
|
25
|
+
uLineThickness: new THREE.Uniform(grid.lineThickness),
|
|
26
|
+
uLineColor: new THREE.Uniform(new THREE.Color(grid.lineColor)),
|
|
27
|
+
uShadowOpacity: new THREE.Uniform(grid.shadowOpacity),
|
|
28
|
+
uShadowBlur: new THREE.Uniform(grid.shadowBlur),
|
|
29
|
+
uShadowSpread: new THREE.Uniform(grid.shadowSpread),
|
|
30
|
+
uShadowColor: new THREE.Uniform(new THREE.Color(grid.shadowColor)),
|
|
31
|
+
uSceneScale: new THREE.Uniform(1),
|
|
32
|
+
uResolution_px: new THREE.Uniform(new THREE.Vector2(0, 0)),
|
|
33
|
+
uDisplaySize_in: new THREE.Uniform(new THREE.Vector2(0, 0)),
|
|
34
|
+
uFixedGridCountX: new THREE.Uniform(grid.fixedGridCount?.x || 24),
|
|
35
|
+
uFixedGridCountY: new THREE.Uniform(grid.fixedGridCount?.y || 17)
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
$effect(() => {
|
|
40
|
+
material.uniforms.uOpacity.value = grid.opacity;
|
|
41
|
+
material.uniforms.uSceneScale.value = sceneZoom;
|
|
42
|
+
material.uniforms.uGridType.value = grid.gridType;
|
|
43
|
+
material.uniforms.uGridMode.value = grid.gridMode || 0;
|
|
44
|
+
material.uniforms.uSpacing_in.value = grid.spacing;
|
|
45
|
+
material.uniforms.uPadding_px.value = display.padding;
|
|
46
|
+
material.uniforms.uLineThickness.value = grid.lineThickness;
|
|
47
|
+
// Use .set() to avoid allocating new objects
|
|
48
|
+
material.uniforms.uLineColor.value.set(grid.lineColor);
|
|
49
|
+
material.uniforms.uShadowOpacity.value = grid.shadowOpacity;
|
|
50
|
+
material.uniforms.uShadowBlur.value = grid.shadowBlur;
|
|
51
|
+
material.uniforms.uShadowSpread.value = grid.shadowSpread;
|
|
52
|
+
material.uniforms.uShadowColor.value.set(grid.shadowColor);
|
|
53
|
+
material.uniforms.uResolution_px.value.set(display.resolution.x, display.resolution.y);
|
|
54
|
+
material.uniforms.uDisplaySize_in.value.set(display.size.x, display.size.y);
|
|
55
|
+
material.uniforms.uFixedGridCountX.value = grid.fixedGridCount?.x || 24;
|
|
56
|
+
material.uniforms.uFixedGridCountY.value = grid.fixedGridCount?.y || 17;
|
|
57
|
+
|
|
58
|
+
invalidate();
|
|
59
|
+
});
|
|
60
|
+
</script>
|
|
61
|
+
|
|
62
|
+
{#snippet attachMaterial()}
|
|
63
|
+
{material}
|
|
64
|
+
{/snippet}
|
|
65
|
+
|
|
66
|
+
<!-- Export the material to be used in the parent component -->
|
|
67
|
+
<T is={material} {fragmentShader} {vertexShader} transparent={true} depthTest={false}>
|
|
68
|
+
{@render attachMaterial()}
|
|
69
|
+
</T>
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { GridLayerProps } from './types';
|
|
2
|
+
import type { DisplayProps } from '../Stage/types';
|
|
3
|
+
interface Props {
|
|
4
|
+
grid: GridLayerProps;
|
|
5
|
+
display: DisplayProps;
|
|
6
|
+
sceneZoom: number;
|
|
7
|
+
}
|
|
8
|
+
declare const GridMaterial: import("svelte").Component<Props, {}, "">;
|
|
9
|
+
type GridMaterial = ReturnType<typeof GridMaterial>;
|
|
10
|
+
export default GridMaterial;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export declare enum GridType {
|
|
2
|
+
Square = 0,
|
|
3
|
+
Hex = 1
|
|
4
|
+
}
|
|
5
|
+
export declare enum GridMode {
|
|
6
|
+
FillSpace = 0,
|
|
7
|
+
MapDefined = 1
|
|
8
|
+
}
|
|
9
|
+
export interface GridLayerProps {
|
|
10
|
+
/**
|
|
11
|
+
* The type of grid. 0 for square, 1 for hex
|
|
12
|
+
*/
|
|
13
|
+
gridType: GridType;
|
|
14
|
+
/**
|
|
15
|
+
* The grid calculation mode. FillSpace fills display with 1-inch squares, MapDefined uses exact grid dimensions
|
|
16
|
+
*/
|
|
17
|
+
gridMode: GridMode;
|
|
18
|
+
/**
|
|
19
|
+
* Fixed grid dimensions when using MapDefined mode
|
|
20
|
+
*/
|
|
21
|
+
fixedGridCount: {
|
|
22
|
+
x: number;
|
|
23
|
+
y: number;
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* The opacity of the grid lines (0 to 1)
|
|
27
|
+
*/
|
|
28
|
+
opacity: number;
|
|
29
|
+
/**
|
|
30
|
+
* The grid spacing in inches
|
|
31
|
+
*/
|
|
32
|
+
spacing: number;
|
|
33
|
+
/**
|
|
34
|
+
* The real-world size of one grid square
|
|
35
|
+
*/
|
|
36
|
+
worldGridSize: number;
|
|
37
|
+
/**
|
|
38
|
+
* The units for the world grid size (e.g., 'ft', 'm', 'yd')
|
|
39
|
+
*/
|
|
40
|
+
worldGridUnits: string;
|
|
41
|
+
/**
|
|
42
|
+
* Line thickness
|
|
43
|
+
*/
|
|
44
|
+
lineThickness: number;
|
|
45
|
+
/**
|
|
46
|
+
* Line color represented as a hex string (e.g. 0x60A3FE)
|
|
47
|
+
*/
|
|
48
|
+
lineColor: string;
|
|
49
|
+
/**
|
|
50
|
+
* Opacity of the drop shadow
|
|
51
|
+
*/
|
|
52
|
+
shadowOpacity: number;
|
|
53
|
+
/**
|
|
54
|
+
* Blur factor for the drop shadow
|
|
55
|
+
*/
|
|
56
|
+
shadowBlur: number;
|
|
57
|
+
/**
|
|
58
|
+
* Spread amount for the drop shadow
|
|
59
|
+
*/
|
|
60
|
+
shadowSpread: number;
|
|
61
|
+
/**
|
|
62
|
+
* Shadow represented as a hex string (e.g. 0x60A3FE)
|
|
63
|
+
*/
|
|
64
|
+
shadowColor: string;
|
|
65
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export var GridType;
|
|
2
|
+
(function (GridType) {
|
|
3
|
+
GridType[GridType["Square"] = 0] = "Square";
|
|
4
|
+
GridType[GridType["Hex"] = 1] = "Hex";
|
|
5
|
+
})(GridType || (GridType = {}));
|
|
6
|
+
export var GridMode;
|
|
7
|
+
(function (GridMode) {
|
|
8
|
+
GridMode[GridMode["FillSpace"] = 0] = "FillSpace";
|
|
9
|
+
GridMode[GridMode["MapDefined"] = 1] = "MapDefined";
|
|
10
|
+
})(GridMode || (GridMode = {}));
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import * as THREE from 'three';
|
|
3
|
+
import { onDestroy, onMount } from 'svelte';
|
|
4
|
+
import { useThrelte } from '@threlte/core';
|
|
5
|
+
import type { Size } from '../../types';
|
|
6
|
+
import { SceneLayer } from '../Scene/types';
|
|
7
|
+
|
|
8
|
+
interface Props {
|
|
9
|
+
id?: string;
|
|
10
|
+
isActive: boolean;
|
|
11
|
+
target?: THREE.Mesh;
|
|
12
|
+
layerSize?: Size | null;
|
|
13
|
+
onMouseDown?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
14
|
+
onMouseUp?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
15
|
+
onMouseMove?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
16
|
+
onContextMenu?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
17
|
+
onMouseEnter?: () => void;
|
|
18
|
+
onMouseLeave?: () => void;
|
|
19
|
+
onWheel?: (e: WheelEvent) => void;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
let {
|
|
23
|
+
id,
|
|
24
|
+
layerSize,
|
|
25
|
+
isActive,
|
|
26
|
+
target,
|
|
27
|
+
onMouseDown,
|
|
28
|
+
onMouseUp,
|
|
29
|
+
onMouseMove,
|
|
30
|
+
onMouseEnter,
|
|
31
|
+
onMouseLeave,
|
|
32
|
+
onWheel,
|
|
33
|
+
onContextMenu
|
|
34
|
+
}: Props = $props();
|
|
35
|
+
|
|
36
|
+
const { camera, renderer, size } = useThrelte();
|
|
37
|
+
|
|
38
|
+
let raycaster = new THREE.Raycaster();
|
|
39
|
+
raycaster.layers.enable(SceneLayer.Overlay);
|
|
40
|
+
raycaster.layers.enable(SceneLayer.Main);
|
|
41
|
+
raycaster.layers.enable(SceneLayer.Input);
|
|
42
|
+
|
|
43
|
+
function isTouchDevice() {
|
|
44
|
+
return window.matchMedia('(any-pointer: coarse)').matches;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// Track pending touch to detect multi-touch gestures
|
|
48
|
+
let touchStartTimer: ReturnType<typeof setTimeout> | null = null;
|
|
49
|
+
let pendingTouchEvent: TouchEvent | null = null;
|
|
50
|
+
let pendingTouchCoords: THREE.Vector2 | null = null;
|
|
51
|
+
let isDrawing = false;
|
|
52
|
+
|
|
53
|
+
// Bind events to the renderer's canvas element
|
|
54
|
+
onMount(() => {
|
|
55
|
+
// Mouse events
|
|
56
|
+
if (onMouseDown) renderer.domElement.addEventListener('mousedown', handleMouseDown);
|
|
57
|
+
if (onMouseMove) renderer.domElement.addEventListener('mousemove', handleMouseMove);
|
|
58
|
+
if (onMouseUp) renderer.domElement.addEventListener('mouseup', handleMouseUp);
|
|
59
|
+
if (onMouseEnter) renderer.domElement.addEventListener('mouseenter', handleMouseEnter);
|
|
60
|
+
if (onMouseLeave) renderer.domElement.addEventListener('mouseleave', handleMouseLeave);
|
|
61
|
+
if (onContextMenu) renderer.domElement.addEventListener('contextmenu', handleContextMenu);
|
|
62
|
+
if (onWheel) renderer.domElement.addEventListener('wheel', handleWheel);
|
|
63
|
+
|
|
64
|
+
// Touch events
|
|
65
|
+
if (onMouseDown) renderer.domElement.addEventListener('touchstart', handleTouchStart);
|
|
66
|
+
if (onMouseMove) renderer.domElement.addEventListener('touchmove', handleTouchMove);
|
|
67
|
+
if (onMouseUp) renderer.domElement.addEventListener('touchend', handleTouchEnd);
|
|
68
|
+
if (onMouseLeave) renderer.domElement.addEventListener('touchcancel', handleTouchCancel);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
onDestroy(() => {
|
|
72
|
+
// Clean up any pending timers
|
|
73
|
+
if (touchStartTimer) {
|
|
74
|
+
clearTimeout(touchStartTimer);
|
|
75
|
+
touchStartTimer = null;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// Mouse events
|
|
79
|
+
if (onMouseDown) renderer.domElement.removeEventListener('mousedown', handleMouseDown);
|
|
80
|
+
if (onMouseMove) renderer.domElement.removeEventListener('mousemove', handleMouseMove);
|
|
81
|
+
if (onMouseUp) renderer.domElement.removeEventListener('mouseup', handleMouseUp);
|
|
82
|
+
if (onMouseEnter) renderer.domElement.removeEventListener('mouseenter', handleMouseEnter);
|
|
83
|
+
if (onMouseLeave) renderer.domElement.removeEventListener('mouseleave', handleMouseLeave);
|
|
84
|
+
if (onContextMenu) renderer.domElement.removeEventListener('contextmenu', handleContextMenu);
|
|
85
|
+
if (onWheel) renderer.domElement.removeEventListener('wheel', handleWheel);
|
|
86
|
+
|
|
87
|
+
// Touch events
|
|
88
|
+
if (onMouseDown) renderer.domElement.removeEventListener('touchstart', handleTouchStart);
|
|
89
|
+
if (onMouseMove) renderer.domElement.removeEventListener('touchmove', handleTouchMove);
|
|
90
|
+
if (onMouseUp) renderer.domElement.removeEventListener('touchend', handleTouchEnd);
|
|
91
|
+
if (onMouseLeave) renderer.domElement.removeEventListener('touchcancel', handleTouchCancel);
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
export function getId() {
|
|
95
|
+
return id;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
// Internal event handler methods for mouse
|
|
99
|
+
function handleMouseDown(event: MouseEvent) {
|
|
100
|
+
if (onMouseDown && isActive) {
|
|
101
|
+
onMouseDown(event, mouseToCanvasCoords(event));
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
function handleMouseUp(event: MouseEvent) {
|
|
106
|
+
if (onMouseUp && isActive) {
|
|
107
|
+
onMouseUp(event, mouseToCanvasCoords(event));
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
function handleMouseMove(event: MouseEvent) {
|
|
112
|
+
if (onMouseMove && isActive) {
|
|
113
|
+
onMouseMove(event, mouseToCanvasCoords(event));
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
function handleMouseEnter() {
|
|
118
|
+
if (onMouseEnter && isActive) {
|
|
119
|
+
onMouseEnter();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
function handleMouseLeave() {
|
|
124
|
+
if (onMouseLeave && isActive) {
|
|
125
|
+
onMouseLeave();
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
function handleContextMenu(event: MouseEvent) {
|
|
130
|
+
if (onContextMenu && isActive) {
|
|
131
|
+
onContextMenu(event, mouseToCanvasCoords(event));
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
function handleWheel(event: WheelEvent) {
|
|
136
|
+
if (onWheel && isActive) {
|
|
137
|
+
onWheel(event);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
function handleTouchStart(event: TouchEvent) {
|
|
142
|
+
if (onMouseDown && isActive) {
|
|
143
|
+
// If multiple touches detected immediately, cancel any pending touch
|
|
144
|
+
if (event.touches.length > 1) {
|
|
145
|
+
// Cancel pending touch if it exists
|
|
146
|
+
if (touchStartTimer) {
|
|
147
|
+
clearTimeout(touchStartTimer);
|
|
148
|
+
touchStartTimer = null;
|
|
149
|
+
pendingTouchEvent = null;
|
|
150
|
+
pendingTouchCoords = null;
|
|
151
|
+
}
|
|
152
|
+
// Stop any ongoing drawing
|
|
153
|
+
if (isDrawing && onMouseUp) {
|
|
154
|
+
onMouseUp(event, null);
|
|
155
|
+
isDrawing = false;
|
|
156
|
+
}
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
event.preventDefault(); // Prevent scrolling when interacting with the canvas
|
|
161
|
+
const touch = event.touches[0];
|
|
162
|
+
const coords = touchToCanvasCoords(touch);
|
|
163
|
+
|
|
164
|
+
// Store the touch event and wait to see if another finger touches
|
|
165
|
+
pendingTouchEvent = event;
|
|
166
|
+
pendingTouchCoords = coords;
|
|
167
|
+
|
|
168
|
+
// Clear any existing timer
|
|
169
|
+
if (touchStartTimer) {
|
|
170
|
+
clearTimeout(touchStartTimer);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
// Wait 50ms to see if this becomes a multi-touch gesture
|
|
174
|
+
touchStartTimer = setTimeout(() => {
|
|
175
|
+
// If we still only have one touch after the delay, start drawing
|
|
176
|
+
if (pendingTouchEvent && pendingTouchCoords && event.touches.length === 1) {
|
|
177
|
+
onMouseDown(pendingTouchEvent, pendingTouchCoords);
|
|
178
|
+
isDrawing = true;
|
|
179
|
+
}
|
|
180
|
+
touchStartTimer = null;
|
|
181
|
+
pendingTouchEvent = null;
|
|
182
|
+
pendingTouchCoords = null;
|
|
183
|
+
}, 50);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
function handleTouchEnd(event: TouchEvent) {
|
|
188
|
+
if (onMouseUp && isActive && isTouchDevice()) {
|
|
189
|
+
event.preventDefault();
|
|
190
|
+
|
|
191
|
+
// Cancel any pending touch start
|
|
192
|
+
if (touchStartTimer) {
|
|
193
|
+
clearTimeout(touchStartTimer);
|
|
194
|
+
touchStartTimer = null;
|
|
195
|
+
pendingTouchEvent = null;
|
|
196
|
+
pendingTouchCoords = null;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
// Only trigger mouse up if we were actually drawing
|
|
200
|
+
if (isDrawing) {
|
|
201
|
+
const touch = event.changedTouches[0];
|
|
202
|
+
onMouseUp(event, touch ? touchToCanvasCoords(touch) : null);
|
|
203
|
+
isDrawing = false;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
function handleTouchMove(event: TouchEvent) {
|
|
209
|
+
if (onMouseMove && isActive && isTouchDevice()) {
|
|
210
|
+
// Stop drawing if multiple touches detected (pinch/zoom gesture)
|
|
211
|
+
if (event.touches.length > 1) {
|
|
212
|
+
// Cancel any pending touch
|
|
213
|
+
if (touchStartTimer) {
|
|
214
|
+
clearTimeout(touchStartTimer);
|
|
215
|
+
touchStartTimer = null;
|
|
216
|
+
pendingTouchEvent = null;
|
|
217
|
+
pendingTouchCoords = null;
|
|
218
|
+
}
|
|
219
|
+
// Stop any ongoing drawing
|
|
220
|
+
if (isDrawing && onMouseUp) {
|
|
221
|
+
onMouseUp(event, null);
|
|
222
|
+
isDrawing = false;
|
|
223
|
+
}
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
// Only process move if we're actually drawing
|
|
228
|
+
if (isDrawing) {
|
|
229
|
+
event.preventDefault();
|
|
230
|
+
const touch = event.touches[0];
|
|
231
|
+
onMouseMove(event, touchToCanvasCoords(touch));
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
function handleTouchCancel() {
|
|
237
|
+
// Clean up any pending or ongoing touch operations
|
|
238
|
+
if (touchStartTimer) {
|
|
239
|
+
clearTimeout(touchStartTimer);
|
|
240
|
+
touchStartTimer = null;
|
|
241
|
+
pendingTouchEvent = null;
|
|
242
|
+
pendingTouchCoords = null;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
if (isDrawing) {
|
|
246
|
+
isDrawing = false;
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
if (onMouseLeave && isActive) {
|
|
250
|
+
onMouseLeave();
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
function mouseToCanvasCoords(e: MouseEvent): THREE.Vector2 | null {
|
|
255
|
+
if (!target || !layerSize) return null;
|
|
256
|
+
|
|
257
|
+
const mouse = new THREE.Vector2((e.offsetX / $size.width) * 2 - 1, -(e.offsetY / $size.height) * 2 + 1);
|
|
258
|
+
|
|
259
|
+
raycaster.setFromCamera(mouse, $camera);
|
|
260
|
+
const intersects = raycaster.intersectObject(target);
|
|
261
|
+
|
|
262
|
+
if (intersects.length > 0) {
|
|
263
|
+
const { point } = intersects[0];
|
|
264
|
+
const localPoint = target.worldToLocal(point);
|
|
265
|
+
const canvasPoint = new THREE.Vector2(
|
|
266
|
+
layerSize.width * (localPoint.x + 0.5),
|
|
267
|
+
layerSize.height * (localPoint.y + 0.5)
|
|
268
|
+
);
|
|
269
|
+
return canvasPoint;
|
|
270
|
+
} else {
|
|
271
|
+
return null;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
function touchToCanvasCoords(touch: Touch): THREE.Vector2 | null {
|
|
276
|
+
if (!target || !layerSize || !renderer.domElement) return null;
|
|
277
|
+
|
|
278
|
+
const rect = renderer.domElement.getBoundingClientRect();
|
|
279
|
+
|
|
280
|
+
const offsetX = touch.clientX - rect.left;
|
|
281
|
+
const offsetY = touch.clientY - rect.top;
|
|
282
|
+
|
|
283
|
+
const mouse = new THREE.Vector2((offsetX / $size.width) * 2 - 1, -(offsetY / $size.height) * 2 + 1);
|
|
284
|
+
|
|
285
|
+
raycaster.setFromCamera(mouse, $camera);
|
|
286
|
+
const intersects = raycaster.intersectObject(target);
|
|
287
|
+
|
|
288
|
+
if (intersects.length > 0) {
|
|
289
|
+
const { point } = intersects[0];
|
|
290
|
+
const localPoint = target.worldToLocal(point);
|
|
291
|
+
const canvasPoint = new THREE.Vector2(
|
|
292
|
+
layerSize.width * (localPoint.x + 0.5),
|
|
293
|
+
layerSize.height * (localPoint.y + 0.5)
|
|
294
|
+
);
|
|
295
|
+
return canvasPoint;
|
|
296
|
+
} else {
|
|
297
|
+
return null;
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
</script>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import type { Size } from '../../types';
|
|
3
|
+
interface Props {
|
|
4
|
+
id?: string;
|
|
5
|
+
isActive: boolean;
|
|
6
|
+
target?: THREE.Mesh;
|
|
7
|
+
layerSize?: Size | null;
|
|
8
|
+
onMouseDown?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
9
|
+
onMouseUp?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
10
|
+
onMouseMove?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
11
|
+
onContextMenu?: (e: MouseEvent | TouchEvent, coords: THREE.Vector2 | null) => void;
|
|
12
|
+
onMouseEnter?: () => void;
|
|
13
|
+
onMouseLeave?: () => void;
|
|
14
|
+
onWheel?: (e: WheelEvent) => void;
|
|
15
|
+
}
|
|
16
|
+
declare const LayerInput: import("svelte").Component<Props, {
|
|
17
|
+
getId: () => string | undefined;
|
|
18
|
+
}, "">;
|
|
19
|
+
type LayerInput = ReturnType<typeof LayerInput>;
|
|
20
|
+
export default LayerInput;
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import * as THREE from 'three';
|
|
3
|
+
import { T } from '@threlte/core';
|
|
4
|
+
import { MapLayerType } from './types';
|
|
5
|
+
import type { Size } from '../../types';
|
|
6
|
+
import FogOfWarLayer from '../FogOfWarLayer/FogOfWarLayer.svelte';
|
|
7
|
+
import type { FogOfWarExports } from '../FogOfWarLayer/types';
|
|
8
|
+
import type { Callbacks, StageProps } from '../Stage/types';
|
|
9
|
+
import { getContext } from 'svelte';
|
|
10
|
+
import { SceneLayer, SceneLayerOrder } from '../Scene/types';
|
|
11
|
+
import FogLayer from '../FogLayer/FogLayer.svelte';
|
|
12
|
+
import { createDataSource, type IMapDataSource } from './dataSources';
|
|
13
|
+
|
|
14
|
+
interface Props {
|
|
15
|
+
props: StageProps;
|
|
16
|
+
onMapLoading: () => void;
|
|
17
|
+
onMapLoaded: (mapUrl: string, mapSize: Size) => void;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const { props, onMapLoading, onMapLoaded }: Props = $props();
|
|
21
|
+
|
|
22
|
+
const callbacks = getContext<Callbacks>('callbacks');
|
|
23
|
+
const onMapUpdate = callbacks.onMapUpdate;
|
|
24
|
+
|
|
25
|
+
let currentMapUrl: string | null = $state(null);
|
|
26
|
+
let dataSource: IMapDataSource | null = null;
|
|
27
|
+
let mapImageMaterial = new THREE.MeshBasicMaterial();
|
|
28
|
+
let fogOfWarLayer: FogOfWarExports;
|
|
29
|
+
|
|
30
|
+
// The size of the map image
|
|
31
|
+
let mapSize: Size | null = $state(null);
|
|
32
|
+
|
|
33
|
+
// Track if the material needs a full update
|
|
34
|
+
let materialUpdateKey = $state(0);
|
|
35
|
+
|
|
36
|
+
$effect(() => {
|
|
37
|
+
if (!props.map.url) {
|
|
38
|
+
currentMapUrl = props.map.url;
|
|
39
|
+
// Dispose of data source when URL is null
|
|
40
|
+
if (dataSource) {
|
|
41
|
+
dataSource.dispose();
|
|
42
|
+
dataSource = null;
|
|
43
|
+
}
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// Check if the URL is changing (including query params for cache busting)
|
|
48
|
+
// For video files, we need to check the full URL including query params
|
|
49
|
+
const newMapUrlWithoutParams = getUrlWithoutParams(props.map.url);
|
|
50
|
+
const currentMapUrlWithoutParams = getUrlWithoutParams(currentMapUrl);
|
|
51
|
+
|
|
52
|
+
// Check if this is a video file
|
|
53
|
+
const isVideo = props.map.url.match(/\.(mp4|webm|mov|avi)/i);
|
|
54
|
+
|
|
55
|
+
// For videos, compare full URLs (including query params) to ensure cache busting
|
|
56
|
+
// For images, compare without params to avoid unnecessary reloads
|
|
57
|
+
if (isVideo) {
|
|
58
|
+
if (currentMapUrl === props.map.url) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
} else {
|
|
62
|
+
if (currentMapUrlWithoutParams === newMapUrlWithoutParams) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// Update the current URL immediately
|
|
68
|
+
currentMapUrl = props.map.url;
|
|
69
|
+
|
|
70
|
+
onMapLoading();
|
|
71
|
+
|
|
72
|
+
// Dispose of previous data source
|
|
73
|
+
if (dataSource) {
|
|
74
|
+
dataSource.dispose();
|
|
75
|
+
dataSource = null;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// Dispose of previous material map
|
|
79
|
+
if (mapImageMaterial.map) {
|
|
80
|
+
mapImageMaterial.map.dispose();
|
|
81
|
+
mapImageMaterial.map = null;
|
|
82
|
+
mapImageMaterial.needsUpdate = true;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// Create new data source based on file type
|
|
86
|
+
dataSource = createDataSource(props.map.url);
|
|
87
|
+
|
|
88
|
+
// Load the new data source
|
|
89
|
+
dataSource
|
|
90
|
+
.load(props.map.url)
|
|
91
|
+
.then(() => {
|
|
92
|
+
const texture = dataSource?.getTexture();
|
|
93
|
+
const size = dataSource?.getSize();
|
|
94
|
+
|
|
95
|
+
if (texture && size) {
|
|
96
|
+
mapImageMaterial.map = texture;
|
|
97
|
+
mapImageMaterial.needsUpdate = true;
|
|
98
|
+
mapSize = size;
|
|
99
|
+
// Force material key update to trigger re-render
|
|
100
|
+
materialUpdateKey++;
|
|
101
|
+
onMapLoaded(props.map.url, mapSize);
|
|
102
|
+
}
|
|
103
|
+
})
|
|
104
|
+
.catch((reason) => {
|
|
105
|
+
console.error('Failed to load map:', reason);
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
function getUrlWithoutParams(url: string | null): string {
|
|
110
|
+
if (!url) return '';
|
|
111
|
+
return url.split('?')[0];
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
export function getCompositeMapTexture(): THREE.Texture | null {
|
|
115
|
+
return mapImageMaterial.map;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export function fill() {
|
|
119
|
+
if (!mapSize) return;
|
|
120
|
+
|
|
121
|
+
const imageAspectRatio = mapSize.width / mapSize.height;
|
|
122
|
+
const sceneAspectRatio = props.display.resolution.x / props.display.resolution.y;
|
|
123
|
+
|
|
124
|
+
let newZoom: number;
|
|
125
|
+
if (imageAspectRatio > sceneAspectRatio) {
|
|
126
|
+
newZoom = props.display.resolution.y / mapSize.height;
|
|
127
|
+
} else {
|
|
128
|
+
newZoom = props.display.resolution.x / mapSize.width;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
onMapUpdate({ x: 0, y: 0 }, newZoom);
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
export function fit() {
|
|
135
|
+
if (!mapSize) return;
|
|
136
|
+
|
|
137
|
+
const imageAspectRatio = mapSize.width / mapSize.height;
|
|
138
|
+
const sceneAspectRatio = props.display.resolution.x / props.display.resolution.y;
|
|
139
|
+
|
|
140
|
+
let newZoom: number;
|
|
141
|
+
if (imageAspectRatio > sceneAspectRatio) {
|
|
142
|
+
newZoom = props.display.resolution.x / mapSize.width;
|
|
143
|
+
} else {
|
|
144
|
+
newZoom = props.display.resolution.y / mapSize.height;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
onMapUpdate({ x: 0, y: 0 }, newZoom);
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
// Export the map size for external components
|
|
151
|
+
export { mapSize };
|
|
152
|
+
|
|
153
|
+
// References to the layer doesn't exist until the component is mounted,
|
|
154
|
+
// so we need create these wrapper functions
|
|
155
|
+
export const fogOfWar = {
|
|
156
|
+
clear: () => fogOfWarLayer.clearFog(),
|
|
157
|
+
reset: () => fogOfWarLayer.resetFog(),
|
|
158
|
+
toPng: () => fogOfWarLayer.toPng(),
|
|
159
|
+
toRLE: () => fogOfWarLayer.toRLE(),
|
|
160
|
+
fromRLE: (rleData: Uint8Array, width: number, height: number) => fogOfWarLayer.fromRLE(rleData, width, height),
|
|
161
|
+
isDrawing: () => fogOfWarLayer?.isDrawing() ?? false
|
|
162
|
+
};
|
|
163
|
+
</script>
|
|
164
|
+
|
|
165
|
+
<!-- Map -->
|
|
166
|
+
<T.Object3D
|
|
167
|
+
name="mapLayer"
|
|
168
|
+
position={[props.map.offset.x, props.map.offset.y, 0]}
|
|
169
|
+
rotation.z={(props.map.rotation / 180.0) * Math.PI}
|
|
170
|
+
scale={[(mapSize?.width ?? 0) * props.map.zoom, (mapSize?.height ?? 0) * props.map.zoom, 1]}
|
|
171
|
+
>
|
|
172
|
+
<!-- Map image -->
|
|
173
|
+
{#key materialUpdateKey}
|
|
174
|
+
<T.Mesh name="mapImage" layers={[SceneLayer.Main]} renderOrder={SceneLayerOrder.Map} visible={true}>
|
|
175
|
+
<T.MeshBasicMaterial is={mapImageMaterial} />
|
|
176
|
+
<T.PlaneGeometry />
|
|
177
|
+
</T.Mesh>
|
|
178
|
+
{/key}
|
|
179
|
+
|
|
180
|
+
<FogLayer
|
|
181
|
+
props={props.fog}
|
|
182
|
+
{mapSize}
|
|
183
|
+
layers={[SceneLayer.Main]}
|
|
184
|
+
renderOrder={SceneLayerOrder.Fog}
|
|
185
|
+
visible={props.fog.enabled}
|
|
186
|
+
/>
|
|
187
|
+
|
|
188
|
+
<FogOfWarLayer
|
|
189
|
+
bind:this={fogOfWarLayer}
|
|
190
|
+
props={props.fogOfWar}
|
|
191
|
+
isActive={props.activeLayer === MapLayerType.FogOfWar}
|
|
192
|
+
{mapSize}
|
|
193
|
+
layers={[SceneLayer.Main]}
|
|
194
|
+
renderOrder={SceneLayerOrder.FogOfWar}
|
|
195
|
+
/>
|
|
196
|
+
</T.Object3D>
|