@motion-script/player 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/README.md +46 -0
  2. package/dist/App.d.ts +7 -0
  3. package/dist/App.d.ts.map +1 -0
  4. package/dist/components/decoration/dino-loading.d.ts +7 -0
  5. package/dist/components/decoration/dino-loading.d.ts.map +1 -0
  6. package/dist/components/decoration/stripe.d.ts +18 -0
  7. package/dist/components/decoration/stripe.d.ts.map +1 -0
  8. package/dist/components/errors/errors-button.d.ts +2 -0
  9. package/dist/components/errors/errors-button.d.ts.map +1 -0
  10. package/dist/components/errors/errors-dialog.d.ts +9 -0
  11. package/dist/components/errors/errors-dialog.d.ts.map +1 -0
  12. package/dist/components/export/export-button.d.ts +8 -0
  13. package/dist/components/export/export-button.d.ts.map +1 -0
  14. package/dist/components/export/export-dialog.d.ts +9 -0
  15. package/dist/components/export/export-dialog.d.ts.map +1 -0
  16. package/dist/components/export/use-export.d.ts +23 -0
  17. package/dist/components/export/use-export.d.ts.map +1 -0
  18. package/dist/components/layout/editor-layout.d.ts +2 -0
  19. package/dist/components/layout/editor-layout.d.ts.map +1 -0
  20. package/dist/components/layout/preview-zoom-controls.d.ts +2 -0
  21. package/dist/components/layout/preview-zoom-controls.d.ts.map +1 -0
  22. package/dist/components/layout/scene-panel.d.ts +2 -0
  23. package/dist/components/layout/scene-panel.d.ts.map +1 -0
  24. package/dist/components/layout/video-preview.d.ts +5 -0
  25. package/dist/components/layout/video-preview.d.ts.map +1 -0
  26. package/dist/components/theme/logo.d.ts +7 -0
  27. package/dist/components/theme/logo.d.ts.map +1 -0
  28. package/dist/components/theme/theme-toggle.d.ts +2 -0
  29. package/dist/components/theme/theme-toggle.d.ts.map +1 -0
  30. package/dist/components/timeline/audio-waveform-bar.d.ts +7 -0
  31. package/dist/components/timeline/audio-waveform-bar.d.ts.map +1 -0
  32. package/dist/components/timeline/constants.d.ts +14 -0
  33. package/dist/components/timeline/constants.d.ts.map +1 -0
  34. package/dist/components/timeline/flatten.d.ts +15 -0
  35. package/dist/components/timeline/flatten.d.ts.map +1 -0
  36. package/dist/components/timeline/node-icon.d.ts +4 -0
  37. package/dist/components/timeline/node-icon.d.ts.map +1 -0
  38. package/dist/components/timeline/node-names-column.d.ts +16 -0
  39. package/dist/components/timeline/node-names-column.d.ts.map +1 -0
  40. package/dist/components/timeline/ruler-utils.d.ts +3 -0
  41. package/dist/components/timeline/ruler-utils.d.ts.map +1 -0
  42. package/dist/components/timeline/timeline.d.ts +7 -0
  43. package/dist/components/timeline/timeline.d.ts.map +1 -0
  44. package/dist/components/timeline/toolbar.d.ts +4 -0
  45. package/dist/components/timeline/toolbar.d.ts.map +1 -0
  46. package/dist/components/timeline/track-rows.d.ts +20 -0
  47. package/dist/components/timeline/track-rows.d.ts.map +1 -0
  48. package/dist/components/timeline/use-row-virtualizer.d.ts +21 -0
  49. package/dist/components/timeline/use-row-virtualizer.d.ts.map +1 -0
  50. package/dist/components/ui/alert.d.ts +11 -0
  51. package/dist/components/ui/alert.d.ts.map +1 -0
  52. package/dist/components/ui/button.d.ts +9 -0
  53. package/dist/components/ui/button.d.ts.map +1 -0
  54. package/dist/components/ui/card.d.ts +12 -0
  55. package/dist/components/ui/card.d.ts.map +1 -0
  56. package/dist/components/ui/checkbox.d.ts +4 -0
  57. package/dist/components/ui/checkbox.d.ts.map +1 -0
  58. package/dist/components/ui/dialog.d.ts +18 -0
  59. package/dist/components/ui/dialog.d.ts.map +1 -0
  60. package/dist/components/ui/empty.d.ts +12 -0
  61. package/dist/components/ui/empty.d.ts.map +1 -0
  62. package/dist/components/ui/field.d.ts +25 -0
  63. package/dist/components/ui/field.d.ts.map +1 -0
  64. package/dist/components/ui/label.d.ts +4 -0
  65. package/dist/components/ui/label.d.ts.map +1 -0
  66. package/dist/components/ui/popover.d.ts +10 -0
  67. package/dist/components/ui/popover.d.ts.map +1 -0
  68. package/dist/components/ui/progress.d.ts +8 -0
  69. package/dist/components/ui/progress.d.ts.map +1 -0
  70. package/dist/components/ui/resizable.d.ts +8 -0
  71. package/dist/components/ui/resizable.d.ts.map +1 -0
  72. package/dist/components/ui/select.d.ts +16 -0
  73. package/dist/components/ui/select.d.ts.map +1 -0
  74. package/dist/components/ui/separator.d.ts +4 -0
  75. package/dist/components/ui/separator.d.ts.map +1 -0
  76. package/dist/components/ui/skeleton.d.ts +3 -0
  77. package/dist/components/ui/skeleton.d.ts.map +1 -0
  78. package/dist/components/ui/slider.d.ts +14 -0
  79. package/dist/components/ui/slider.d.ts.map +1 -0
  80. package/dist/components/ui/sonner.d.ts +4 -0
  81. package/dist/components/ui/sonner.d.ts.map +1 -0
  82. package/dist/components/ui/table.d.ts +11 -0
  83. package/dist/components/ui/table.d.ts.map +1 -0
  84. package/dist/components/ui/toggle.d.ts +9 -0
  85. package/dist/components/ui/toggle.d.ts.map +1 -0
  86. package/dist/components/ui/tooltip.d.ts +7 -0
  87. package/dist/components/ui/tooltip.d.ts.map +1 -0
  88. package/dist/hooks/use-mobile.d.ts +2 -0
  89. package/dist/hooks/use-mobile.d.ts.map +1 -0
  90. package/dist/hooks/use-search-params.d.ts +6 -0
  91. package/dist/hooks/use-search-params.d.ts.map +1 -0
  92. package/dist/index.d.ts +3 -0
  93. package/dist/index.d.ts.map +1 -0
  94. package/dist/lib/utils.d.ts +3 -0
  95. package/dist/lib/utils.d.ts.map +1 -0
  96. package/dist/motion-script-player.css +3955 -0
  97. package/dist/motion-script-player.js +41824 -0
  98. package/dist/motion-script-player.js.map +1 -0
  99. package/dist/providers/editor-provider.d.ts +16 -0
  100. package/dist/providers/editor-provider.d.ts.map +1 -0
  101. package/dist/providers/theme-provider.d.ts +14 -0
  102. package/dist/providers/theme-provider.d.ts.map +1 -0
  103. package/dist/stores/editor-store.d.ts +71 -0
  104. package/dist/stores/editor-store.d.ts.map +1 -0
  105. package/package.json +76 -0
@@ -0,0 +1,16 @@
1
+ import { default as React } from 'react';
2
+ import { AssetManifest, ProjectConfig } from '@motion-script/core';
3
+ import { FrameHandle } from '@motion-script/react';
4
+ import { EditorState } from '../stores/editor-store';
5
+ export declare function EditorStoreProvider({ config, assets, children, }: {
6
+ config: ProjectConfig;
7
+ assets?: AssetManifest;
8
+ children: React.ReactNode;
9
+ }): React.JSX.Element;
10
+ export declare function useEditorStore<T>(selector: (state: EditorState) => T): T;
11
+ export declare function FrameHandleProvider({ frameRef, children, }: {
12
+ frameRef: React.RefObject<FrameHandle | null>;
13
+ children: React.ReactNode;
14
+ }): React.JSX.Element;
15
+ export declare function useFrameHandleRef(): React.RefObject<FrameHandle | null> | null;
16
+ //# sourceMappingURL=editor-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"editor-provider.d.ts","sourceRoot":"","sources":["../../src/providers/editor-provider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAqB,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAIvE,wBAAgB,mBAAmB,CAAC,EAChC,MAAM,EACN,MAAM,EACN,QAAQ,GACX,EAAE;IACC,MAAM,EAAE,aAAa,CAAC;IACtB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B,qBAsBA;AAED,wBAAgB,cAAc,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,CAAC,GAAG,CAAC,CAMxE;AAID,wBAAgB,mBAAmB,CAAC,EAChC,QAAQ,EACR,QAAQ,GACX,EAAE;IACC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IAC9C,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC7B,qBAMA;AAED,wBAAgB,iBAAiB,IAAI,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,IAAI,CAE9E"}
@@ -0,0 +1,14 @@
1
+ type Theme = "dark" | "light" | "system";
2
+ type ThemeProviderProps = {
3
+ children: React.ReactNode;
4
+ defaultTheme?: Theme;
5
+ storageKey?: string;
6
+ };
7
+ type ThemeProviderState = {
8
+ theme: Theme;
9
+ setTheme: (theme: Theme) => void;
10
+ };
11
+ export declare function ThemeProvider({ children, defaultTheme, storageKey, ...props }: ThemeProviderProps): import("react").JSX.Element;
12
+ export declare const useTheme: () => ThemeProviderState;
13
+ export {};
14
+ //# sourceMappingURL=theme-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme-provider.d.ts","sourceRoot":"","sources":["../../src/providers/theme-provider.tsx"],"names":[],"mappings":"AAEA,KAAK,KAAK,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAA;AAExC,KAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,YAAY,CAAC,EAAE,KAAK,CAAA;IACpB,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,CAAA;AAED,KAAK,kBAAkB,GAAG;IACxB,KAAK,EAAE,KAAK,CAAA;IACZ,QAAQ,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAA;CACjC,CAAA;AASD,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,YAAuB,EACvB,UAA4B,EAC5B,GAAG,KAAK,EACT,EAAE,kBAAkB,+BAoCpB;AAED,eAAO,MAAM,QAAQ,0BAOpB,CAAA"}
@@ -0,0 +1,71 @@
1
+ import { AssetManifest, Scene, Color, NodeState, TreeState, ProjectConfig, Size2D } from '@motion-script/core';
2
+ export type BuildError = {
3
+ sceneName: string;
4
+ sceneIndex: number;
5
+ message: string;
6
+ stack?: string;
7
+ };
8
+ export type EditorState = {
9
+ scenes: Scene[];
10
+ projectName: string;
11
+ theme: Record<string, Color>;
12
+ viewport: Size2D;
13
+ fps: number;
14
+ assets: AssetManifest;
15
+ currentFrame: number;
16
+ currentTime: number;
17
+ setCurrentFrame: (frame: number) => void;
18
+ setCurrentTime: (time: number) => void;
19
+ duration: number;
20
+ setDuration: (duration: number) => void;
21
+ sceneStartFrames: number[];
22
+ setSceneDurations: (durationFrames: number[]) => void;
23
+ isPlaying: boolean;
24
+ setIsPlaying: (playing: boolean) => void;
25
+ togglePlay: () => void;
26
+ isLoading: boolean;
27
+ setIsLoading: (loading: boolean) => void;
28
+ snapshotRequested: boolean;
29
+ requestSnapshot: () => void;
30
+ completeSnapshot: () => void;
31
+ exportProgress: number | null;
32
+ setExportProgress: (progress: number | null) => void;
33
+ timelineZoom: number;
34
+ setTimelineZoom: (zoom: number) => void;
35
+ zoomTimelineBy: (delta: number, opts?: {
36
+ min?: number;
37
+ max?: number;
38
+ }) => void;
39
+ timelineCollapsed: boolean;
40
+ setTimelineCollapsed: (collapsed: boolean) => void;
41
+ toggleTimelineCollapsed: () => void;
42
+ previewZoom: number;
43
+ previewPan: {
44
+ x: number;
45
+ y: number;
46
+ };
47
+ setPreviewZoom: (zoom: number) => void;
48
+ setPreviewPan: (pan: {
49
+ x: number;
50
+ y: number;
51
+ }) => void;
52
+ resetPreviewView: () => void;
53
+ playbackSpeed: number;
54
+ setPlaybackSpeed: (speed: number) => void;
55
+ buildErrors: BuildError[];
56
+ setBuildErrors: (errors: BuildError[]) => void;
57
+ rootNode: TreeState | null;
58
+ setRootNode: (node: TreeState | null) => void;
59
+ selectedNode: NodeState | null;
60
+ setSelectedNode: (node: NodeState | null) => void;
61
+ isLooping: boolean;
62
+ setIsLooping: (looping: boolean) => void;
63
+ isMuted: boolean;
64
+ setIsMuted: (muted: boolean) => void;
65
+ toggleMuted: () => void;
66
+ replay: () => void;
67
+ resetConfig: (config: ProjectConfig) => void;
68
+ _pendingSceneIndex: number | null;
69
+ };
70
+ export declare const createEditorStore: (config: ProjectConfig, assets?: AssetManifest) => import('zustand').UseBoundStore<import('zustand').StoreApi<EditorState>>;
71
+ //# sourceMappingURL=editor-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"editor-store.d.ts","sourceRoot":"","sources":["../../src/stores/editor-store.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,76 @@
1
+ {
2
+ "name": "@motion-script/player",
3
+ "description": "Visual editor and preview app for Motion Script projects, with timeline scrubbing, scene inspection, and video export.",
4
+ "version": "0.1.0",
5
+ "type": "module",
6
+ "author": "Motion Script",
7
+ "license": "Apache-2.0",
8
+ "publishConfig": {
9
+ "access": "public"
10
+ },
11
+ "scripts": {
12
+ "postinstall": "node ../../scripts/copy-wasm.js",
13
+ "dev": "vite",
14
+ "clean": "rimraf dist .turbo && tsc -b --clean",
15
+ "predev": "node ../../scripts/copy-wasm.js",
16
+ "build": "tsc -b && vite build",
17
+ "build:app": "vite build --config vite.config.app.ts",
18
+ "lint": "eslint .",
19
+ "preview": "vite preview"
20
+ },
21
+ "files": [
22
+ "dist"
23
+ ],
24
+ "module": "./dist/motion-script-player.js",
25
+ "types": "./dist/motion-script-player.d.ts",
26
+ "exports": {
27
+ ".": {
28
+ "types": "./dist/motion-script-player.d.ts",
29
+ "import": "./dist/motion-script-player.js"
30
+ },
31
+ "./style.css": "./dist/motion-script-player.css"
32
+ },
33
+ "peerDependencies": {
34
+ "react": "^19.2.0",
35
+ "react-dom": "^19.2.0"
36
+ },
37
+ "dependencies": {
38
+ "@base-ui/react": "^1.4.1",
39
+ "@fontsource-variable/geist": "^5.2.9",
40
+ "@motion-script/core": "workspace:*",
41
+ "@motion-script/react": "workspace:*",
42
+ "@motion-script/web": "workspace:*",
43
+ "@tailwindcss/forms": "^0.5.11",
44
+ "@tailwindcss/typography": "^0.5.19",
45
+ "class-variance-authority": "^0.7.1",
46
+ "clsx": "^2.1.1",
47
+ "lucide-react": "^1.14.0",
48
+ "react-resizable-panels": "^4.11.2",
49
+ "shadcn": "^4.10.0",
50
+ "sonner": "^2.0.7",
51
+ "tailwind-merge": "^3.5.0",
52
+ "tailwindcss": "^4.2.4",
53
+ "tw-animate-css": "^1.4.0",
54
+ "use-sync-external-store": "^1.6.0",
55
+ "wavesurfer.js": "^7.12.6",
56
+ "zustand": "^5.0.12"
57
+ },
58
+ "devDependencies": {
59
+ "@eslint/js": "^9.39.1",
60
+ "@tailwindcss/vite": "^4.3.0",
61
+ "@types/node": "catalog:",
62
+ "@types/react": "^19.2.0",
63
+ "@types/react-dom": "^19.2.0",
64
+ "@vitejs/plugin-react": "catalog:",
65
+ "eslint": "^9.39.1",
66
+ "eslint-plugin-react-hooks": "^7.0.1",
67
+ "eslint-plugin-react-refresh": "^0.4.24",
68
+ "globals": "^16.5.0",
69
+ "react": "catalog:",
70
+ "react-dom": "catalog:",
71
+ "typescript": "catalog:",
72
+ "typescript-eslint": "^8.48.0",
73
+ "vite": "catalog:",
74
+ "vite-plugin-dts": "catalog:"
75
+ }
76
+ }