@threlte/theatre 3.0.0-next.6 → 3.0.0-next.8
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/dist/project/Project.svelte.d.ts +10 -22
- package/dist/sequence/Sequence.svelte.d.ts +72 -66
- package/dist/sheet/Sheet.svelte.d.ts +39 -27
- package/dist/sheetObject/SheetObject.svelte +6 -3
- package/dist/sheetObject/SheetObject.svelte.d.ts +19 -31
- package/dist/sheetObject/declare/Declare.svelte +4 -1
- package/dist/sheetObject/declare/Declare.svelte.d.ts +19 -11
- package/dist/sheetObject/declare/types.d.ts +9 -0
- package/dist/sheetObject/declare/types.js +1 -0
- package/dist/sheetObject/sync/Sync.svelte +10 -4
- package/dist/sheetObject/sync/Sync.svelte.d.ts +21 -63
- package/dist/sheetObject/sync/types.d.ts +30 -0
- package/dist/sheetObject/sync/types.js +1 -0
- package/dist/sheetObject/sync/utils/isComplexProp.d.ts +1 -1
- package/dist/sheetObject/sync/utils/isStringProp.d.ts +1 -1
- package/dist/sheetObject/sync/utils/parsePropLabel.d.ts +1 -1
- package/dist/sheetObject/transform/Transform.svelte +5 -2
- package/dist/sheetObject/transform/Transform.svelte.d.ts +19 -22
- package/dist/sheetObject/transform/types.d.ts +14 -0
- package/dist/sheetObject/transform/types.js +1 -0
- package/dist/sheetObject/types.d.ts +24 -0
- package/dist/sheetObject/types.js +1 -0
- package/dist/sheetObject/useSheet.d.ts +4 -4
- package/dist/studio/InnerStudio.svelte.d.ts +28 -17
- package/dist/studio/Studio.svelte.d.ts +29 -18
- package/dist/theatre/Theatre.svelte.d.ts +32 -21
- package/package.json +6 -6
|
@@ -1,24 +1,12 @@
|
|
|
1
|
-
import { SvelteComponent } from "svelte";
|
|
2
1
|
import { type Snippet } from 'svelte';
|
|
3
2
|
import type { IProject, IProjectConfig } from '@theatre/core';
|
|
4
|
-
declare const
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
events: {
|
|
15
|
-
[evt: string]: CustomEvent<any>;
|
|
16
|
-
};
|
|
17
|
-
slots: {};
|
|
18
|
-
};
|
|
19
|
-
export type ProjectProps = typeof __propDef.props;
|
|
20
|
-
export type ProjectEvents = typeof __propDef.events;
|
|
21
|
-
export type ProjectSlots = typeof __propDef.slots;
|
|
22
|
-
export default class Project extends SvelteComponent<ProjectProps, ProjectEvents, ProjectSlots> {
|
|
23
|
-
}
|
|
24
|
-
export {};
|
|
3
|
+
declare const Project: import("svelte").Component<{
|
|
4
|
+
name: string;
|
|
5
|
+
config?: IProjectConfig | undefined;
|
|
6
|
+
project?: IProject | undefined;
|
|
7
|
+
isReady?: boolean | undefined;
|
|
8
|
+
children?: Snippet<[{
|
|
9
|
+
project: IProject;
|
|
10
|
+
}]> | undefined;
|
|
11
|
+
}, {}, "project" | "isReady">;
|
|
12
|
+
export default Project;
|
|
@@ -1,76 +1,82 @@
|
|
|
1
|
-
|
|
2
|
-
import type { IRafDriver } from '@theatre/core';
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
import type { IRafDriver, ISequence } from '@theatre/core';
|
|
3
3
|
import type { Autoreset, IterationCount, PlaybackDirection, PlaybackRange, SequenceAudioOptions } from './types';
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
5
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
6
|
+
$$bindings?: Bindings;
|
|
7
|
+
} & Exports;
|
|
8
|
+
(internal: unknown, props: Props & {
|
|
9
|
+
$$events?: Events;
|
|
10
|
+
$$slots?: Slots;
|
|
11
|
+
}): Exports & {
|
|
12
|
+
$set?: any;
|
|
13
|
+
$on?: any;
|
|
14
|
+
};
|
|
15
|
+
z_$$bindings?: Bindings;
|
|
16
|
+
}
|
|
17
|
+
type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
|
|
18
|
+
default: any;
|
|
19
|
+
} ? Props extends Record<string, never> ? any : {
|
|
20
|
+
children?: any;
|
|
21
|
+
} : {});
|
|
22
|
+
declare const Sequence: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
|
|
23
|
+
rate?: number | undefined;
|
|
24
|
+
range?: PlaybackRange;
|
|
25
|
+
iterationCount?: IterationCount;
|
|
26
|
+
direction?: PlaybackDirection;
|
|
27
|
+
rafDriver?: IRafDriver | undefined;
|
|
28
|
+
audio?: SequenceAudioOptions | undefined;
|
|
29
|
+
autoplay?: boolean | undefined;
|
|
30
|
+
autoreset?: Autoreset;
|
|
31
|
+
autopause?: boolean | undefined;
|
|
32
|
+
delay?: number | undefined;
|
|
33
|
+
sequence?: import("./SequenceController").SequenceController | undefined;
|
|
34
|
+
position?: number | undefined;
|
|
35
|
+
playing?: boolean | undefined;
|
|
36
|
+
length?: number | undefined;
|
|
37
|
+
play?: ((conf?: {
|
|
38
|
+
iterationCount?: number | undefined;
|
|
39
|
+
range?: [from: number, to: number] | undefined;
|
|
6
40
|
rate?: number | undefined;
|
|
7
|
-
|
|
8
|
-
iterationCount?: IterationCount;
|
|
9
|
-
direction?: PlaybackDirection;
|
|
41
|
+
direction?: ("reverse" | "alternate" | "normal" | "alternateReverse") | undefined;
|
|
10
42
|
rafDriver?: IRafDriver | undefined;
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
length?: number | undefined;
|
|
20
|
-
play?: ((conf?: {
|
|
43
|
+
} | undefined) => Promise<boolean>) | undefined;
|
|
44
|
+
pause?: (() => void) | undefined;
|
|
45
|
+
}, {
|
|
46
|
+
default: {
|
|
47
|
+
sequence: import("./SequenceController").SequenceController;
|
|
48
|
+
position: number;
|
|
49
|
+
playing: boolean;
|
|
50
|
+
play: (conf?: {
|
|
21
51
|
iterationCount?: number | undefined;
|
|
22
52
|
range?: [from: number, to: number] | undefined;
|
|
23
53
|
rate?: number | undefined;
|
|
24
54
|
direction?: ("reverse" | "alternate" | "normal" | "alternateReverse") | undefined;
|
|
25
55
|
rafDriver?: IRafDriver | undefined;
|
|
26
|
-
} | undefined) => Promise<boolean
|
|
27
|
-
pause
|
|
28
|
-
children?: import("svelte").Snippet<[{
|
|
29
|
-
sequence: import("./SequenceController").SequenceController;
|
|
30
|
-
position: number;
|
|
31
|
-
playing: boolean;
|
|
32
|
-
play: (conf?: {
|
|
33
|
-
iterationCount?: number | undefined;
|
|
34
|
-
range?: [from: number, to: number] | undefined;
|
|
35
|
-
rate?: number | undefined;
|
|
36
|
-
direction?: ("reverse" | "alternate" | "normal" | "alternateReverse") | undefined;
|
|
37
|
-
rafDriver?: IRafDriver | undefined;
|
|
38
|
-
} | undefined) => Promise<boolean>;
|
|
39
|
-
pause: () => void;
|
|
40
|
-
}]> | undefined;
|
|
56
|
+
} | undefined) => Promise<boolean>;
|
|
57
|
+
pause: () => void;
|
|
41
58
|
};
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
pause: () => void;
|
|
58
|
-
};
|
|
59
|
+
}>, {
|
|
60
|
+
[evt: string]: CustomEvent<any>;
|
|
61
|
+
}, {
|
|
62
|
+
default: {
|
|
63
|
+
sequence: import("./SequenceController").SequenceController;
|
|
64
|
+
position: number;
|
|
65
|
+
playing: boolean;
|
|
66
|
+
play: (conf?: {
|
|
67
|
+
iterationCount?: number | undefined;
|
|
68
|
+
range?: [from: number, to: number] | undefined;
|
|
69
|
+
rate?: number | undefined;
|
|
70
|
+
direction?: ("reverse" | "alternate" | "normal" | "alternateReverse") | undefined;
|
|
71
|
+
rafDriver?: IRafDriver | undefined;
|
|
72
|
+
} | undefined) => Promise<boolean>;
|
|
73
|
+
pause: () => void;
|
|
59
74
|
};
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
iterationCount?: number | undefined;
|
|
69
|
-
range?: [from: number, to: number] | undefined;
|
|
70
|
-
rate?: number | undefined;
|
|
71
|
-
direction?: ("reverse" | "alternate" | "normal" | "alternateReverse") | undefined;
|
|
72
|
-
rafDriver?: IRafDriver | undefined;
|
|
73
|
-
} | undefined) => Promise<boolean>;
|
|
74
|
-
get pause(): () => void;
|
|
75
|
-
}
|
|
76
|
-
export {};
|
|
75
|
+
}, {
|
|
76
|
+
sequence: import("./SequenceController").SequenceController;
|
|
77
|
+
length: number;
|
|
78
|
+
play: ISequence['play'];
|
|
79
|
+
pause: ISequence['pause'];
|
|
80
|
+
}, string>;
|
|
81
|
+
type Sequence = InstanceType<typeof Sequence>;
|
|
82
|
+
export default Sequence;
|
|
@@ -1,32 +1,44 @@
|
|
|
1
|
-
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
2
|
import type { IProject } from '@theatre/core';
|
|
3
3
|
import { SequenceController } from '../sequence/SequenceController';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
4
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
5
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
6
|
+
$$bindings?: Bindings;
|
|
7
|
+
} & Exports;
|
|
8
|
+
(internal: unknown, props: Props & {
|
|
9
|
+
$$events?: Events;
|
|
10
|
+
$$slots?: Slots;
|
|
11
|
+
}): Exports & {
|
|
12
|
+
$set?: any;
|
|
13
|
+
$on?: any;
|
|
14
14
|
};
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
z_$$bindings?: Bindings;
|
|
16
|
+
}
|
|
17
|
+
type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
|
|
18
|
+
default: any;
|
|
19
|
+
} ? Props extends Record<string, never> ? any : {
|
|
20
|
+
children?: any;
|
|
21
|
+
} : {});
|
|
22
|
+
declare const Sheet: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
|
|
23
|
+
project?: IProject | undefined;
|
|
24
|
+
name?: string | undefined;
|
|
25
|
+
instance?: string | undefined;
|
|
26
|
+
sheet?: import("@theatre/core").ISheet | undefined;
|
|
27
|
+
sequence?: SequenceController | undefined;
|
|
28
|
+
}, {
|
|
29
|
+
default: {
|
|
30
|
+
sheet: import("@theatre/core").ISheet;
|
|
17
31
|
};
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
32
|
+
}>, {
|
|
33
|
+
[evt: string]: CustomEvent<any>;
|
|
34
|
+
}, {
|
|
35
|
+
default: {
|
|
36
|
+
sheet: import("@theatre/core").ISheet;
|
|
22
37
|
};
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
get sequence(): SequenceController;
|
|
31
|
-
}
|
|
32
|
-
export {};
|
|
38
|
+
}, {
|
|
39
|
+
project: IProject;
|
|
40
|
+
sheet: import("@theatre/core").ISheet;
|
|
41
|
+
sequence: SequenceController;
|
|
42
|
+
}, string>;
|
|
43
|
+
type Sheet = InstanceType<typeof Sheet>;
|
|
44
|
+
export default Sheet;
|
|
@@ -3,9 +3,12 @@
|
|
|
3
3
|
- Creating namespaces
|
|
4
4
|
- Potentially Providing a sheet object
|
|
5
5
|
-->
|
|
6
|
-
<script
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
<script
|
|
7
|
+
lang="ts"
|
|
8
|
+
generics="Props extends UnknownShorthandCompoundProps"
|
|
9
|
+
>import { useStudio } from '../studio/useStudio';
|
|
10
|
+
import { currentWritable, useThrelte, watch } from '@threlte/core';
|
|
11
|
+
import { getContext, onDestroy, onMount } from 'svelte';
|
|
9
12
|
import Declare from './declare/Declare.svelte';
|
|
10
13
|
import Sync from './sync/Sync.svelte';
|
|
11
14
|
import Transform from './transform/Transform.svelte';
|
|
@@ -1,32 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import type
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
selected?: boolean
|
|
11
|
-
props?: T
|
|
12
|
-
|
|
13
|
-
children?: Snippet<
|
|
14
|
-
[
|
|
15
|
-
{
|
|
16
|
-
values: ISheetObject['value']
|
|
17
|
-
selected: boolean
|
|
18
|
-
select: () => void
|
|
19
|
-
deselect: () => void
|
|
20
|
-
sheetObject: ISheetObject
|
|
21
|
-
Sync: typeof Sync
|
|
22
|
-
Transform: typeof Transform
|
|
23
|
-
Declare: typeof Declare
|
|
24
|
-
}
|
|
25
|
-
]
|
|
26
|
-
>
|
|
27
|
-
|
|
28
|
-
onchange?: (sheet: ISheetObject['value']) => void
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
import type { UnknownShorthandCompoundProps } from '@theatre/core';
|
|
3
|
+
import type { SheetObjectProps } from './types';
|
|
4
|
+
declare class __sveltets_Render<Props extends UnknownShorthandCompoundProps> {
|
|
5
|
+
props(): SheetObjectProps<Props>;
|
|
6
|
+
events(): {};
|
|
7
|
+
slots(): {};
|
|
8
|
+
bindings(): "selected";
|
|
9
|
+
exports(): {};
|
|
29
10
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
>
|
|
11
|
+
interface $$IsomorphicComponent {
|
|
12
|
+
new <Props extends UnknownShorthandCompoundProps>(options: import('svelte').ComponentConstructorOptions<ReturnType<__sveltets_Render<Props>['props']>>): import('svelte').SvelteComponent<ReturnType<__sveltets_Render<Props>['props']>, ReturnType<__sveltets_Render<Props>['events']>, ReturnType<__sveltets_Render<Props>['slots']>> & {
|
|
13
|
+
$$bindings?: ReturnType<__sveltets_Render<Props>['bindings']>;
|
|
14
|
+
} & ReturnType<__sveltets_Render<Props>['exports']>;
|
|
15
|
+
<Props extends UnknownShorthandCompoundProps>(internal: unknown, props: ReturnType<__sveltets_Render<Props>['props']> & {}): ReturnType<__sveltets_Render<Props>['exports']>;
|
|
16
|
+
z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
|
|
17
|
+
}
|
|
18
|
+
declare const SheetObject: $$IsomorphicComponent;
|
|
19
|
+
type SheetObject<Props extends UnknownShorthandCompoundProps> = InstanceType<typeof SheetObject<Props>>;
|
|
20
|
+
export default SheetObject;
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
<script
|
|
1
|
+
<script
|
|
2
|
+
lang="ts"
|
|
3
|
+
generics="P extends UnknownShorthandCompoundProps"
|
|
4
|
+
>import { watch } from '@threlte/core';
|
|
2
5
|
import { onDestroy } from 'svelte';
|
|
3
6
|
import { useSheet } from '../useSheet';
|
|
4
7
|
let { props, children } = $props();
|
|
@@ -1,12 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
import type {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
import type { UnknownShorthandCompoundProps } from '@theatre/core';
|
|
3
|
+
import type { DeclareProps } from './types';
|
|
4
|
+
declare class __sveltets_Render<P extends UnknownShorthandCompoundProps> {
|
|
5
|
+
props(): DeclareProps<P>;
|
|
6
|
+
events(): {};
|
|
7
|
+
slots(): {};
|
|
8
|
+
bindings(): "";
|
|
9
|
+
exports(): {};
|
|
8
10
|
}
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
>
|
|
11
|
+
interface $$IsomorphicComponent {
|
|
12
|
+
new <P extends UnknownShorthandCompoundProps>(options: import('svelte').ComponentConstructorOptions<ReturnType<__sveltets_Render<P>['props']>>): import('svelte').SvelteComponent<ReturnType<__sveltets_Render<P>['props']>, ReturnType<__sveltets_Render<P>['events']>, ReturnType<__sveltets_Render<P>['slots']>> & {
|
|
13
|
+
$$bindings?: ReturnType<__sveltets_Render<P>['bindings']>;
|
|
14
|
+
} & ReturnType<__sveltets_Render<P>['exports']>;
|
|
15
|
+
<P extends UnknownShorthandCompoundProps>(internal: unknown, props: ReturnType<__sveltets_Render<P>['props']> & {}): ReturnType<__sveltets_Render<P>['exports']>;
|
|
16
|
+
z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
|
|
17
|
+
}
|
|
18
|
+
declare const Declare: $$IsomorphicComponent;
|
|
19
|
+
type Declare<P extends UnknownShorthandCompoundProps> = InstanceType<typeof Declare<P>>;
|
|
20
|
+
export default Declare;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ISheetObject, UnknownShorthandCompoundProps } from '@theatre/core';
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
export type DeclareProps<T extends UnknownShorthandCompoundProps> = {
|
|
4
|
+
props: T;
|
|
5
|
+
children?: Snippet<[{
|
|
6
|
+
values: ISheetObject<T>['value'];
|
|
7
|
+
}]>;
|
|
8
|
+
};
|
|
9
|
+
export type Values<T> = T extends UnknownShorthandCompoundProps ? ISheetObject<T>['value'] : never;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
-
<script
|
|
1
|
+
<script
|
|
2
|
+
lang="ts"
|
|
3
|
+
generics="Type"
|
|
4
|
+
>import { resolvePropertyPath, useParent, watch } from '@threlte/core';
|
|
2
5
|
import { onDestroy } from 'svelte';
|
|
6
|
+
import { useStudio } from '../../studio/useStudio';
|
|
7
|
+
import { useSheet } from '../useSheet';
|
|
3
8
|
import { getInitialValue } from './utils/getInitialValue';
|
|
4
9
|
import { isComplexProp } from './utils/isComplexProp';
|
|
10
|
+
import { isStringProp } from './utils/isStringProp';
|
|
5
11
|
import { makeAlphanumeric } from './utils/makeAlphanumeric';
|
|
6
12
|
import { parsePropLabel } from './utils/parsePropLabel';
|
|
7
|
-
import { isStringProp } from './utils/isStringProp';
|
|
8
|
-
import { useStudio } from '../../studio/useStudio';
|
|
9
|
-
import { useSheet } from '../useSheet';
|
|
10
13
|
let { type, children, ...rest } = $props();
|
|
11
14
|
const { sheetObject, addProps, removeProps } = useSheet();
|
|
12
15
|
const parent = useParent();
|
|
@@ -73,6 +76,9 @@ watch([parent, sheetObject], ([parent, sheetObject]) => {
|
|
|
73
76
|
});
|
|
74
77
|
initProps();
|
|
75
78
|
const studio = useStudio();
|
|
79
|
+
/**
|
|
80
|
+
* Capture the current values of the props
|
|
81
|
+
*/
|
|
76
82
|
export const capture = () => {
|
|
77
83
|
if (!$studio)
|
|
78
84
|
return;
|
|
@@ -1,65 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
import type {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
| 'children'
|
|
14
|
-
| `is${string}` // isMesh, isObject3D, etc
|
|
15
|
-
| 'parent'
|
|
16
|
-
| 'uuid'
|
|
17
|
-
| 'name'
|
|
18
|
-
type AnyClass = new (...args: any) => any
|
|
19
|
-
type AnyFn = (...args: any) => any
|
|
20
|
-
type MaybeInstance<Type extends any> = Type extends AnyClass ? InstanceType<Type> : Type
|
|
21
|
-
type InstanceProps<Type extends any> = Partial<
|
|
22
|
-
Omit<
|
|
23
|
-
MaybeInstance<Type> extends Primitive
|
|
24
|
-
? Record<string, unknown>
|
|
25
|
-
: {
|
|
26
|
-
[K in keyof MaybeInstance<Type>]?: MaybeInstance<Type>[K] extends {
|
|
27
|
-
set: (...args: any[]) => any
|
|
28
|
-
}
|
|
29
|
-
?
|
|
30
|
-
| Parameters<MaybeInstance<Type>[K]['set']>
|
|
31
|
-
| Parameters<MaybeInstance<Type>[K]['set']>[0]
|
|
32
|
-
: MaybeInstance<Type>[K] extends AnyFn
|
|
33
|
-
? never
|
|
34
|
-
: MaybeInstance<Type>[K]
|
|
35
|
-
},
|
|
36
|
-
ConditionalKeys<MaybeInstance<Type>, AnyFn> | OmittedPropKeys
|
|
37
|
-
>
|
|
38
|
-
>
|
|
39
|
-
/* COPIED FROM @threlte/core END */
|
|
40
|
-
|
|
41
|
-
type ObjectProp<T> = {
|
|
42
|
-
type?: T
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
import type { SyncProps } from './types';
|
|
3
|
+
declare class __sveltets_Render<Type> {
|
|
4
|
+
props(): SyncProps<Type>;
|
|
5
|
+
events(): {};
|
|
6
|
+
slots(): {};
|
|
7
|
+
bindings(): "";
|
|
8
|
+
exports(): {
|
|
9
|
+
/**
|
|
10
|
+
* Capture the current values of the props
|
|
11
|
+
*/ capture: () => void;
|
|
12
|
+
};
|
|
43
13
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
14
|
+
interface $$IsomorphicComponent {
|
|
15
|
+
new <Type>(options: import('svelte').ComponentConstructorOptions<ReturnType<__sveltets_Render<Type>['props']>>): import('svelte').SvelteComponent<ReturnType<__sveltets_Render<Type>['props']>, ReturnType<__sveltets_Render<Type>['events']>, ReturnType<__sveltets_Render<Type>['slots']>> & {
|
|
16
|
+
$$bindings?: ReturnType<__sveltets_Render<Type>['bindings']>;
|
|
17
|
+
} & ReturnType<__sveltets_Render<Type>['exports']>;
|
|
18
|
+
<Type>(internal: unknown, props: ReturnType<__sveltets_Render<Type>['props']> & {}): ReturnType<__sveltets_Render<Type>['exports']>;
|
|
19
|
+
z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
|
|
49
20
|
}
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
type AnyProps<T> = {
|
|
54
|
-
[P in keyof InstanceProps<T>]?: AnyProp
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export type SyncProps<T> = AnyProps<T> &
|
|
58
|
-
ObjectProp<T> &
|
|
59
|
-
Record<string, AnyProp | T> & {
|
|
60
|
-
capture?: () => void
|
|
61
|
-
} & {
|
|
62
|
-
children?: Snippet<[{ capture: () => void }]>
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
export default class Sync<T> extends SvelteComponent<SyncProps<T>> {}
|
|
21
|
+
declare const Sync: $$IsomorphicComponent;
|
|
22
|
+
type Sync<Type> = InstanceType<typeof Sync<Type>>;
|
|
23
|
+
export default Sync;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
import type { ConditionalKeys, Primitive } from 'type-fest';
|
|
3
|
+
import type { Transformer } from '../transfomers/types';
|
|
4
|
+
type OmittedPropKeys = 'type' | 'args' | 'attach' | 'manual' | 'makeDefault' | 'id' | 'children' | `is${string}` | 'parent' | 'uuid' | 'name';
|
|
5
|
+
type AnyClass = new (...args: any) => any;
|
|
6
|
+
type AnyFn = (...args: any) => any;
|
|
7
|
+
type MaybeInstance<Type extends any> = Type extends AnyClass ? InstanceType<Type> : Type;
|
|
8
|
+
type InstanceProps<Type extends any> = Partial<Omit<MaybeInstance<Type> extends Primitive ? Record<string, unknown> : {
|
|
9
|
+
[K in keyof MaybeInstance<Type>]?: MaybeInstance<Type>[K] extends {
|
|
10
|
+
set: (...args: any[]) => any;
|
|
11
|
+
} ? Parameters<MaybeInstance<Type>[K]['set']> | Parameters<MaybeInstance<Type>[K]['set']>[0] : MaybeInstance<Type>[K] extends AnyFn ? never : MaybeInstance<Type>[K];
|
|
12
|
+
}, ConditionalKeys<MaybeInstance<Type>, AnyFn> | OmittedPropKeys>>;
|
|
13
|
+
type ObjectProp<T> = {
|
|
14
|
+
type?: T;
|
|
15
|
+
};
|
|
16
|
+
export type ComplexProp = {
|
|
17
|
+
transformer?: Transformer;
|
|
18
|
+
label?: string;
|
|
19
|
+
key?: string;
|
|
20
|
+
};
|
|
21
|
+
export type AnyProp = string | boolean | ComplexProp;
|
|
22
|
+
type AnyProps<T> = {
|
|
23
|
+
[P in keyof InstanceProps<T>]?: AnyProp;
|
|
24
|
+
};
|
|
25
|
+
export type SyncProps<T> = AnyProps<T> & ObjectProp<T> & Record<string, AnyProp | T> & {
|
|
26
|
+
children?: Snippet<[{
|
|
27
|
+
capture: () => void;
|
|
28
|
+
}]>;
|
|
29
|
+
};
|
|
30
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import type { AnyProp, ComplexProp } from '../
|
|
1
|
+
import type { AnyProp, ComplexProp } from '../types';
|
|
2
2
|
export declare const isComplexProp: (prop: AnyProp) => prop is ComplexProp;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import type { AnyProp } from '../
|
|
1
|
+
import type { AnyProp } from '../types';
|
|
2
2
|
export declare const isStringProp: (prop: AnyProp) => prop is string;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import type { AnyProp } from '../
|
|
1
|
+
import type { AnyProp } from '../types';
|
|
2
2
|
export declare const parsePropLabel: (alphaNumericKey: string, propValue: AnyProp) => string;
|
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
<script
|
|
2
|
-
|
|
1
|
+
<script
|
|
2
|
+
lang="ts"
|
|
3
|
+
generics="Label extends string | undefined"
|
|
4
|
+
>import { T, watch } from '@threlte/core';
|
|
3
5
|
import { TransformControls } from '@threlte/extras';
|
|
4
6
|
import { onMount } from 'svelte';
|
|
5
7
|
import { Group } from 'three';
|
|
6
8
|
import { RAD2DEG } from 'three/src/math/MathUtils.js';
|
|
7
9
|
import { useStudio } from '../../studio/useStudio';
|
|
10
|
+
import { types } from '../../theatre';
|
|
8
11
|
import { getDefaultTransformer } from '../transfomers/getDefaultTransformer';
|
|
9
12
|
import { useSheet } from '../useSheet';
|
|
10
13
|
let { label, key, mode = 'translate', space, translationSnap, rotationSnap, scaleSnap, children } = $props();
|
|
@@ -1,22 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
export default class Transform<Label extends string | undefined> extends SvelteComponent<
|
|
21
|
-
TransformProps<Label>
|
|
22
|
-
> {}
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
import type { TransformProps } from './types';
|
|
3
|
+
declare class __sveltets_Render<Label extends string | undefined> {
|
|
4
|
+
props(): TransformProps<Label>;
|
|
5
|
+
events(): {};
|
|
6
|
+
slots(): {};
|
|
7
|
+
bindings(): "";
|
|
8
|
+
exports(): {};
|
|
9
|
+
}
|
|
10
|
+
interface $$IsomorphicComponent {
|
|
11
|
+
new <Label extends string | undefined>(options: import('svelte').ComponentConstructorOptions<ReturnType<__sveltets_Render<Label>['props']>>): import('svelte').SvelteComponent<ReturnType<__sveltets_Render<Label>['props']>, ReturnType<__sveltets_Render<Label>['events']>, ReturnType<__sveltets_Render<Label>['slots']>> & {
|
|
12
|
+
$$bindings?: ReturnType<__sveltets_Render<Label>['bindings']>;
|
|
13
|
+
} & ReturnType<__sveltets_Render<Label>['exports']>;
|
|
14
|
+
<Label extends string | undefined>(internal: unknown, props: ReturnType<__sveltets_Render<Label>['props']> & {}): ReturnType<__sveltets_Render<Label>['exports']>;
|
|
15
|
+
z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
|
|
16
|
+
}
|
|
17
|
+
declare const Transform: $$IsomorphicComponent;
|
|
18
|
+
type Transform<Label extends string | undefined> = InstanceType<typeof Transform<Label>>;
|
|
19
|
+
export default Transform;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
export type TransformProps<T extends string | undefined> = {
|
|
3
|
+
label?: T;
|
|
4
|
+
mode?: 'translate' | 'rotate' | 'scale';
|
|
5
|
+
translationSnap?: number;
|
|
6
|
+
rotationSnap?: number;
|
|
7
|
+
scaleSnap?: number;
|
|
8
|
+
space?: 'world' | 'local';
|
|
9
|
+
children?: Snippet;
|
|
10
|
+
} & (T extends string ? {
|
|
11
|
+
key: string;
|
|
12
|
+
} : {
|
|
13
|
+
key?: string;
|
|
14
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { ISheetObject, UnknownShorthandCompoundProps } from '@theatre/core';
|
|
2
|
+
import { type Snippet } from 'svelte';
|
|
3
|
+
import type Declare from './declare/Declare.svelte';
|
|
4
|
+
import type Sync from './sync/Sync.svelte';
|
|
5
|
+
import type Transform from './transform/Transform.svelte';
|
|
6
|
+
export type SheetObjectProps<T extends UnknownShorthandCompoundProps> = {
|
|
7
|
+
key: string;
|
|
8
|
+
detach?: boolean;
|
|
9
|
+
selected?: boolean;
|
|
10
|
+
props?: T;
|
|
11
|
+
children?: Snippet<[
|
|
12
|
+
{
|
|
13
|
+
values: ISheetObject['value'];
|
|
14
|
+
selected: boolean;
|
|
15
|
+
select: () => void;
|
|
16
|
+
deselect: () => void;
|
|
17
|
+
sheetObject: ISheetObject<T>;
|
|
18
|
+
Sync: typeof Sync;
|
|
19
|
+
Transform: typeof Transform;
|
|
20
|
+
Declare: typeof Declare;
|
|
21
|
+
}
|
|
22
|
+
]>;
|
|
23
|
+
onchange?: (sheet: ISheetObject<T>['value']) => void;
|
|
24
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import type { ISheetObject, UnknownShorthandCompoundProps } from '@theatre/core';
|
|
2
2
|
import type { CurrentWritable } from '@threlte/core';
|
|
3
|
-
|
|
4
|
-
sheetObject: CurrentWritable<ISheetObject<
|
|
3
|
+
type Context<T extends UnknownShorthandCompoundProps = {}> = {
|
|
4
|
+
sheetObject: CurrentWritable<ISheetObject<T>>;
|
|
5
5
|
addProps: (props: UnknownShorthandCompoundProps) => void;
|
|
6
6
|
removeProps: (names: string[]) => void;
|
|
7
|
-
}
|
|
7
|
+
};
|
|
8
8
|
export declare const createSheetContext: (context: Context) => void;
|
|
9
|
-
export declare const useSheet: () => Context
|
|
9
|
+
export declare const useSheet: <T extends UnknownShorthandCompoundProps = {}>() => Context<T>;
|
|
10
10
|
export {};
|
|
@@ -1,19 +1,30 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
3
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
4
|
+
$$bindings?: Bindings;
|
|
5
|
+
} & Exports;
|
|
6
|
+
(internal: unknown, props: Props & {
|
|
7
|
+
$$events?: Events;
|
|
8
|
+
$$slots?: Slots;
|
|
9
|
+
}): Exports & {
|
|
10
|
+
$set?: any;
|
|
11
|
+
$on?: any;
|
|
6
12
|
};
|
|
7
|
-
|
|
8
|
-
[evt: string]: CustomEvent<any>;
|
|
9
|
-
};
|
|
10
|
-
slots: {
|
|
11
|
-
default: {};
|
|
12
|
-
};
|
|
13
|
-
};
|
|
14
|
-
export type InnerStudioProps = typeof __propDef.props;
|
|
15
|
-
export type InnerStudioEvents = typeof __propDef.events;
|
|
16
|
-
export type InnerStudioSlots = typeof __propDef.slots;
|
|
17
|
-
export default class InnerStudio extends SvelteComponent<InnerStudioProps, InnerStudioEvents, InnerStudioSlots> {
|
|
13
|
+
z_$$bindings?: Bindings;
|
|
18
14
|
}
|
|
19
|
-
|
|
15
|
+
type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
|
|
16
|
+
default: any;
|
|
17
|
+
} ? Props extends Record<string, never> ? any : {
|
|
18
|
+
children?: any;
|
|
19
|
+
} : {});
|
|
20
|
+
declare const InnerStudio: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
|
|
21
|
+
hide: boolean;
|
|
22
|
+
}, {
|
|
23
|
+
default: {};
|
|
24
|
+
}>, {
|
|
25
|
+
[evt: string]: CustomEvent<any>;
|
|
26
|
+
}, {
|
|
27
|
+
default: {};
|
|
28
|
+
}, {}, string>;
|
|
29
|
+
type InnerStudio = InstanceType<typeof InnerStudio>;
|
|
30
|
+
export default InnerStudio;
|
|
@@ -1,20 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
3
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
4
|
+
$$bindings?: Bindings;
|
|
5
|
+
} & Exports;
|
|
6
|
+
(internal: unknown, props: Props & {
|
|
7
|
+
$$events?: Events;
|
|
8
|
+
$$slots?: Slots;
|
|
9
|
+
}): Exports & {
|
|
10
|
+
$set?: any;
|
|
11
|
+
$on?: any;
|
|
7
12
|
};
|
|
8
|
-
|
|
9
|
-
[evt: string]: CustomEvent<any>;
|
|
10
|
-
};
|
|
11
|
-
slots: {
|
|
12
|
-
default: {};
|
|
13
|
-
};
|
|
14
|
-
};
|
|
15
|
-
export type StudioProps = typeof __propDef.props;
|
|
16
|
-
export type StudioEvents = typeof __propDef.events;
|
|
17
|
-
export type StudioSlots = typeof __propDef.slots;
|
|
18
|
-
export default class Studio extends SvelteComponent<StudioProps, StudioEvents, StudioSlots> {
|
|
13
|
+
z_$$bindings?: Bindings;
|
|
19
14
|
}
|
|
20
|
-
|
|
15
|
+
type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
|
|
16
|
+
default: any;
|
|
17
|
+
} ? Props extends Record<string, never> ? any : {
|
|
18
|
+
children?: any;
|
|
19
|
+
} : {});
|
|
20
|
+
declare const Studio: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
|
|
21
|
+
enabled?: boolean | undefined;
|
|
22
|
+
hide?: boolean | undefined;
|
|
23
|
+
}, {
|
|
24
|
+
default: {};
|
|
25
|
+
}>, {
|
|
26
|
+
[evt: string]: CustomEvent<any>;
|
|
27
|
+
}, {
|
|
28
|
+
default: {};
|
|
29
|
+
}, {}, string>;
|
|
30
|
+
type Studio = InstanceType<typeof Studio>;
|
|
31
|
+
export default Studio;
|
|
@@ -1,24 +1,35 @@
|
|
|
1
|
-
|
|
1
|
+
/// <reference types="svelte" />
|
|
2
2
|
import type { IProjectConfig } from '@theatre/core';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
3
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
4
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
5
|
+
$$bindings?: Bindings;
|
|
6
|
+
} & Exports;
|
|
7
|
+
(internal: unknown, props: Props & {
|
|
8
|
+
$$events?: Events;
|
|
9
|
+
$$slots?: Slots;
|
|
10
|
+
}): Exports & {
|
|
11
|
+
$set?: any;
|
|
12
|
+
$on?: any;
|
|
11
13
|
};
|
|
12
|
-
|
|
13
|
-
[evt: string]: CustomEvent<any>;
|
|
14
|
-
};
|
|
15
|
-
slots: {
|
|
16
|
-
default: {};
|
|
17
|
-
};
|
|
18
|
-
};
|
|
19
|
-
export type TheatreProps = typeof __propDef.props;
|
|
20
|
-
export type TheatreEvents = typeof __propDef.events;
|
|
21
|
-
export type TheatreSlots = typeof __propDef.slots;
|
|
22
|
-
export default class Theatre extends SvelteComponent<TheatreProps, TheatreEvents, TheatreSlots> {
|
|
14
|
+
z_$$bindings?: Bindings;
|
|
23
15
|
}
|
|
24
|
-
|
|
16
|
+
type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
|
|
17
|
+
default: any;
|
|
18
|
+
} ? Props extends Record<string, never> ? any : {
|
|
19
|
+
children?: any;
|
|
20
|
+
} : {});
|
|
21
|
+
declare const Theatre: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
|
|
22
|
+
studio?: {
|
|
23
|
+
enabled?: boolean | undefined;
|
|
24
|
+
hide?: boolean | undefined;
|
|
25
|
+
} | undefined;
|
|
26
|
+
config?: IProjectConfig | undefined;
|
|
27
|
+
}, {
|
|
28
|
+
default: {};
|
|
29
|
+
}>, {
|
|
30
|
+
[evt: string]: CustomEvent<any>;
|
|
31
|
+
}, {
|
|
32
|
+
default: {};
|
|
33
|
+
}, {}, string>;
|
|
34
|
+
type Theatre = InstanceType<typeof Theatre>;
|
|
35
|
+
export default Theatre;
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@threlte/theatre",
|
|
3
|
-
"version": "3.0.0-next.
|
|
3
|
+
"version": "3.0.0-next.8",
|
|
4
4
|
"author": "Grischa Erbe <hello@legrisch.com> (https://legrisch.com)",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"description": "Threlte Components for Theatre, an animation library with a professional motion design toolset",
|
|
7
7
|
"devDependencies": {
|
|
8
8
|
"@sveltejs/adapter-auto": "^3.2.0",
|
|
9
9
|
"@sveltejs/kit": "^2.7.2",
|
|
10
|
-
"@sveltejs/package": "^2.3.
|
|
10
|
+
"@sveltejs/package": "^2.3.7",
|
|
11
11
|
"@sveltejs/vite-plugin-svelte": "^3.1.0",
|
|
12
12
|
"@types/node": "^20.12.7",
|
|
13
13
|
"@types/three": "^0.169.0",
|
|
@@ -21,17 +21,17 @@
|
|
|
21
21
|
"prettier-plugin-svelte": "^3.2.2",
|
|
22
22
|
"publint": "^0.2.7",
|
|
23
23
|
"rimraf": "^5.0.5",
|
|
24
|
-
"svelte": "^5.
|
|
24
|
+
"svelte": "^5.1.6",
|
|
25
25
|
"svelte-check": "^3.6.9",
|
|
26
26
|
"svelte-preprocess": "^5.1.3",
|
|
27
27
|
"svelte2tsx": "^0.7.6",
|
|
28
|
-
"three": "^0.
|
|
28
|
+
"three": "^0.170.0",
|
|
29
29
|
"tslib": "^2.6.2",
|
|
30
30
|
"type-fest": "^4.15.0",
|
|
31
31
|
"typescript": "^5.4.5",
|
|
32
32
|
"vite": "^5.2.8",
|
|
33
|
-
"@threlte/core": "8.0.0-next.
|
|
34
|
-
"@threlte/extras": "9.0.0-next.
|
|
33
|
+
"@threlte/core": "8.0.0-next.24",
|
|
34
|
+
"@threlte/extras": "9.0.0-next.35"
|
|
35
35
|
},
|
|
36
36
|
"peerDependencies": {
|
|
37
37
|
"svelte": ">=4",
|