shop-components 0.0.24 → 0.0.26
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/assets/Color-RQJUDNI5-leAiB7jg.js +1 -0
- package/dist/assets/Configure-OUhXg2g0.js +173 -0
- package/dist/assets/DRACOLoader-FOpiHRUS.js +2 -0
- package/dist/assets/DocsRenderer-K4EAMTCU-wTc0yUaa.js +7 -0
- package/dist/assets/Header-Yyx952jD.css +1 -0
- package/dist/assets/Header.stories-8tnkOwSt.js +31 -0
- package/dist/assets/Page-fZ7a-HXz.css +1 -0
- package/dist/assets/Page.stories-53Crpe03.js +61 -0
- package/dist/assets/RGBELoader-re-MEsjP.js +5 -0
- package/dist/assets/SFL-CDD14-9UY62fbR.glb +0 -0
- package/dist/assets/WithTooltip-Y7J54OF7-e8Yh5ASp.js +1 -0
- package/dist/assets/_commonjsHelpers-4gQjN7DL.js +1 -0
- package/dist/assets/accessibility-Fv4dmnDm.png +0 -0
- package/dist/assets/addon-library-VlAgJsjc.png +0 -0
- package/dist/assets/bg-circle-d8WfpvaX.png +0 -0
- package/dist/assets/context-tKiKnkuP.png +0 -0
- package/dist/assets/docs-Pvr7BWzI.png +0 -0
- package/dist/assets/entry-preview-TptA_luc.js +8 -0
- package/dist/assets/entry-preview-docs-AhrJ3R4Z.js +2 -0
- package/dist/assets/figma-plugin-h9oRC4jr.png +0 -0
- package/dist/assets/formatter-B5HCVTEV-DKi3GmSv.js +58 -0
- package/dist/assets/generateMeshBVH.worker-NFSCTTDt.js +5 -0
- package/dist/assets/iframe-tlQuLR4E.js +7 -0
- package/dist/assets/img-radar-kufDNNXQ.png +0 -0
- package/dist/assets/img-radar2-1cPZO_cj.png +0 -0
- package/dist/assets/index-CXFn8OGe.js +513 -0
- package/dist/assets/index-C_uo8BdM.js +1 -0
- package/dist/assets/index-PPLHz8o0.js +6 -0
- package/dist/assets/index-jFdhmKfM.js +3 -0
- package/dist/assets/index-jtEywAqJ.js +1 -0
- package/dist/assets/index-ogXoivrg.js +1 -0
- package/dist/assets/index.stories-TVZrSYZv.js +20 -0
- package/dist/assets/index.stories-Uq0Yg-kp.js +896 -0
- package/dist/assets/index.stories-VJP6Jo4U.js +22 -0
- package/dist/assets/index.stories-VoNcNCFd.js +27 -0
- package/dist/assets/index.stories-YIFSciWI.js +1174 -0
- package/dist/assets/index.stories-iMKoZNyH.js +46 -0
- package/dist/assets/lightroom_14b-MJkJLVlP.hdr +0 -0
- package/dist/assets/lightroom_14b_512-e_XJNpR6.js +3981 -0
- package/dist/assets/lightroom_14b_512-nMVn659Q.hdr +0 -0
- package/dist/assets/lit-element-P_wTzRvl.js +19 -0
- package/dist/assets/parallelMeshBVH.worker-TP6qJGKX.js +5 -0
- package/dist/assets/preview-1q4RDNOi.js +1 -0
- package/dist/assets/preview-6iG64ELu.js +20 -0
- package/dist/assets/preview-7nNmfNVr.js +7 -0
- package/dist/assets/preview-9bpQVOkQ.js +1 -0
- package/dist/assets/preview-FnnPJHgu.js +1 -0
- package/dist/assets/preview-VI2eoWmp.js +1 -0
- package/dist/assets/preview-bEa2SesL.js +7 -0
- package/dist/assets/preview-u8M_OEO2.js +396 -0
- package/dist/assets/preview-zZA4w0lH.js +1 -0
- package/dist/assets/property-EQZXZ3dt.js +5 -0
- package/dist/assets/query-7eORIRsG.js +13 -0
- package/dist/assets/roller-8Vy8W3X_.glb +0 -0
- package/dist/assets/roller-hopper-Heae_wy5.glb +0 -0
- package/dist/assets/share-xgPlHEHy.png +0 -0
- package/dist/assets/styling-ZOs40c1G.png +0 -0
- package/dist/assets/syntaxhighlighter-JOJW2KGS-uBo08tOF.js +1 -0
- package/dist/assets/testing-HG80fZfa.png +0 -0
- package/dist/assets/theming--liSzaFj.png +0 -0
- package/dist/assets/three.module-9MfFqitO.js +3825 -0
- package/dist/assets/tiny-invariant-VyoA2Os1.js +1 -0
- package/dist/assets/worker-h5IcTUxB.js +1 -0
- package/dist/device-viewer/amr.d.ts +75 -0
- package/dist/device-viewer/assembly.d.ts +11 -0
- package/dist/device-viewer/dimension/index.d.ts +31 -0
- package/dist/device-viewer/dimension/line3.d.ts +21 -0
- package/dist/device-viewer/dimension/size-box.d.ts +39 -0
- package/dist/device-viewer/group-roller.d.ts +20 -0
- package/dist/device-viewer/index.d.ts +12 -0
- package/dist/device-viewer/mechanism/mechanism.d.ts +29 -0
- package/dist/device-viewer/outerline.d.ts +16 -0
- package/dist/device-viewer/roller.d.ts +31 -0
- package/dist/device-viewer/row.d.ts +18 -0
- package/dist/device-viewer/scene.d.ts +14 -28
- package/dist/device-viewer/slot.d.ts +10 -2
- package/dist/device-viewer/text2.d.ts +4 -0
- package/dist/device-viewer/text3.d.ts +4 -0
- package/dist/device-viewer/utils/index.d.ts +26 -1
- package/dist/favicon.svg +7 -0
- package/dist/iframe.html +495 -0
- package/dist/index.html +155 -0
- package/dist/index.json +1 -0
- package/dist/package.json +60 -0
- package/dist/project.json +1 -0
- package/dist/sb-addons/essentials-actions-3/manager-bundle.js +3 -0
- package/dist/sb-addons/essentials-actions-3/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/essentials-backgrounds-4/manager-bundle.js +12 -0
- package/dist/sb-addons/essentials-backgrounds-4/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/essentials-controls-2/manager-bundle.js +60 -0
- package/dist/sb-addons/essentials-controls-2/manager-bundle.js.LEGAL.txt +18 -0
- package/dist/sb-addons/essentials-measure-7/manager-bundle.js +3 -0
- package/dist/sb-addons/essentials-measure-7/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/essentials-outline-8/manager-bundle.js +3 -0
- package/dist/sb-addons/essentials-outline-8/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/essentials-toolbars-6/manager-bundle.js +3 -0
- package/dist/sb-addons/essentials-toolbars-6/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/essentials-viewport-5/manager-bundle.js +3 -0
- package/dist/sb-addons/essentials-viewport-5/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/links-1/manager-bundle.js +3 -0
- package/dist/sb-addons/links-1/manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-addons/storybook-core-server-presets-0/common-manager-bundle.js +3 -0
- package/dist/sb-addons/storybook-core-server-presets-0/common-manager-bundle.js.LEGAL.txt +0 -0
- package/dist/sb-common-assets/fonts.css +31 -0
- package/dist/sb-common-assets/nunito-sans-bold-italic.woff2 +0 -0
- package/dist/sb-common-assets/nunito-sans-bold.woff2 +0 -0
- package/dist/sb-common-assets/nunito-sans-italic.woff2 +0 -0
- package/dist/sb-common-assets/nunito-sans-regular.woff2 +0 -0
- package/dist/sb-manager/WithTooltip-Y7J54OF7-3AIPQNGM.js +1 -0
- package/dist/sb-manager/chunk-I53COLQ6.js +183 -0
- package/dist/sb-manager/chunk-L35575BZ.js +234 -0
- package/dist/sb-manager/chunk-TZAR34JC.js +6 -0
- package/dist/sb-manager/chunk-UOBNU442.js +347 -0
- package/dist/sb-manager/chunk-VMGB76WP.js +9 -0
- package/dist/sb-manager/chunk-XP3HGWTR.js +1 -0
- package/dist/sb-manager/formatter-B5HCVTEV-7DCBOGO6.js +58 -0
- package/dist/sb-manager/globals-module-info.js +1 -0
- package/dist/sb-manager/globals-runtime.js +1 -0
- package/dist/sb-manager/globals.js +1 -0
- package/dist/sb-manager/index.js +1 -0
- package/dist/sb-manager/runtime.js +1 -0
- package/dist/sb-manager/syntaxhighlighter-JOJW2KGS-7BF26SBB.js +1 -0
- package/dist/sb-preview/globals.js +1 -0
- package/dist/sb-preview/runtime.js +128 -0
- package/dist/stories/cropper/index.d.ts +18 -0
- package/dist/stories/cropper/index.js +118 -0
- package/dist/stories/cropper/index.js.map +1 -0
- package/dist/stories/cropper/index.stories.d.ts +11 -0
- package/dist/stories/cropper/index.stories.js +14 -0
- package/dist/stories/cropper/index.stories.js.map +1 -0
- package/dist/stories/device-viewer/amr.d.ts +75 -0
- package/dist/stories/device-viewer/amr.js +554 -0
- package/dist/stories/device-viewer/amr.js.map +1 -0
- package/dist/stories/device-viewer/assembly.d.ts +11 -0
- package/dist/stories/device-viewer/assembly.js +47 -0
- package/dist/stories/device-viewer/assembly.js.map +1 -0
- package/dist/stories/device-viewer/asserts/fonts/type.json +1281 -0
- package/dist/stories/device-viewer/dimension/index.d.ts +31 -0
- package/dist/stories/device-viewer/dimension/index.js +131 -0
- package/dist/stories/device-viewer/dimension/index.js.map +1 -0
- package/dist/stories/device-viewer/dimension/line3.d.ts +21 -0
- package/dist/stories/device-viewer/dimension/line3.js +98 -0
- package/dist/stories/device-viewer/dimension/line3.js.map +1 -0
- package/dist/stories/device-viewer/dimension/size-box.d.ts +39 -0
- package/dist/stories/device-viewer/dimension/size-box.js +176 -0
- package/dist/stories/device-viewer/dimension/size-box.js.map +1 -0
- package/dist/stories/device-viewer/group-roller.d.ts +20 -0
- package/dist/stories/device-viewer/group-roller.js +65 -0
- package/dist/stories/device-viewer/group-roller.js.map +1 -0
- package/dist/stories/device-viewer/index.d.ts +47 -0
- package/dist/stories/device-viewer/index.js +530 -0
- package/dist/stories/device-viewer/index.js.map +1 -0
- package/dist/stories/device-viewer/index.stories.d.ts +27 -0
- package/dist/stories/device-viewer/index.stories.js +37 -0
- package/dist/stories/device-viewer/index.stories.js.map +1 -0
- package/dist/stories/device-viewer/lines.d.ts +36 -0
- package/dist/stories/device-viewer/lines.js +171 -0
- package/dist/stories/device-viewer/lines.js.map +1 -0
- package/dist/stories/device-viewer/main.d.ts +1 -0
- package/dist/stories/device-viewer/main.js +2 -0
- package/dist/stories/device-viewer/main.js.map +1 -0
- package/dist/stories/device-viewer/mechanism/mechanism.d.ts +29 -0
- package/dist/stories/device-viewer/mechanism/mechanism.js +164 -0
- package/dist/stories/device-viewer/mechanism/mechanism.js.map +1 -0
- package/dist/stories/device-viewer/outerline.d.ts +16 -0
- package/dist/stories/device-viewer/outerline.js +63 -0
- package/dist/stories/device-viewer/outerline.js.map +1 -0
- package/dist/stories/device-viewer/roller.d.ts +31 -0
- package/dist/stories/device-viewer/roller.js +121 -0
- package/dist/stories/device-viewer/roller.js.map +1 -0
- package/dist/stories/device-viewer/row.d.ts +18 -0
- package/dist/stories/device-viewer/row.js +58 -0
- package/dist/stories/device-viewer/row.js.map +1 -0
- package/dist/stories/device-viewer/scene.d.ts +101 -0
- package/dist/stories/device-viewer/scene.js +535 -0
- package/dist/stories/device-viewer/scene.js.map +1 -0
- package/dist/stories/device-viewer/slot/slot-item.d.ts +20 -0
- package/dist/stories/device-viewer/slot/slot-item.js +82 -0
- package/dist/stories/device-viewer/slot/slot-item.js.map +1 -0
- package/dist/stories/device-viewer/slot.d.ts +71 -0
- package/dist/stories/device-viewer/slot.js +272 -0
- package/dist/stories/device-viewer/slot.js.map +1 -0
- package/dist/stories/device-viewer/sound.d.ts +5 -0
- package/dist/stories/device-viewer/sound.js +13 -0
- package/dist/stories/device-viewer/sound.js.map +1 -0
- package/dist/stories/device-viewer/text2.d.ts +4 -0
- package/dist/stories/device-viewer/text2.js +12 -0
- package/dist/stories/device-viewer/text2.js.map +1 -0
- package/dist/stories/device-viewer/text3.d.ts +4 -0
- package/dist/stories/device-viewer/text3.js +14 -0
- package/dist/stories/device-viewer/text3.js.map +1 -0
- package/dist/stories/device-viewer/utils/index.d.ts +36 -0
- package/dist/stories/device-viewer/utils/index.js +166 -0
- package/dist/stories/device-viewer/utils/index.js.map +1 -0
- package/dist/stories/device-viewer/worker/generate-mesh-bvh-worker.d.ts +8 -0
- package/dist/stories/device-viewer/worker/generate-mesh-bvh-worker.js +88 -0
- package/dist/stories/device-viewer/worker/generate-mesh-bvh-worker.js.map +1 -0
- package/dist/stories/device-viewer/worker/generateAsync.worker.d.ts +1 -0
- package/dist/stories/device-viewer/worker/generateAsync.worker.js +57 -0
- package/dist/stories/device-viewer/worker/generateAsync.worker.js.map +1 -0
- package/dist/stories/device-viewer/worker/path-tracing-scene-worker.d.ts +16 -0
- package/dist/stories/device-viewer/worker/path-tracing-scene-worker.js +29 -0
- package/dist/stories/device-viewer/worker/path-tracing-scene-worker.js.map +1 -0
- package/dist/stories/main/index.d.ts +1 -0
- package/dist/stories/main/index.js +2 -0
- package/dist/stories/main/index.js.map +1 -0
- package/dist/stories/main.d.ts +4 -0
- package/dist/stories/main.js +5 -0
- package/dist/stories/main.js.map +1 -0
- package/dist/stories/plugin.d.ts +5 -0
- package/dist/stories/plugin.js +6 -0
- package/dist/stories/plugin.js.map +1 -0
- package/dist/stories/plugins/change-slot/index.d.ts +0 -0
- package/dist/stories/plugins/change-slot/index.js +2 -0
- package/dist/stories/plugins/change-slot/index.js.map +1 -0
- package/dist/stories/sglb/index.d.ts +27 -0
- package/dist/stories/sglb/index.js +151 -0
- package/dist/stories/sglb/index.js.map +1 -0
- package/dist/stories/smap-viewer/index.d.ts +14 -0
- package/dist/stories/smap-viewer/index.js +59 -0
- package/dist/stories/smap-viewer/index.js.map +1 -0
- package/dist/stories/smap-viewer/index.stories.d.ts +22 -0
- package/dist/stories/smap-viewer/index.stories.js +27 -0
- package/dist/stories/smap-viewer/index.stories.js.map +1 -0
- package/dist/stories/step-viewer/index.d.ts +17 -0
- package/dist/stories/step-viewer/index.js +109 -0
- package/dist/stories/step-viewer/index.js.map +1 -0
- package/dist/stories/step-viewer/index.stories.d.ts +20 -0
- package/dist/stories/step-viewer/index.stories.js +24 -0
- package/dist/stories/step-viewer/index.stories.js.map +1 -0
- package/dist/stories/test/index.d.ts +25 -0
- package/dist/stories/test/index.js +99 -0
- package/dist/stories/test/index.js.map +1 -0
- package/dist/stories/test/index.stories.d.ts +14 -0
- package/dist/stories/test/index.stories.js +16 -0
- package/dist/stories/test/index.stories.js.map +1 -0
- package/dist/stories/test/scene.d.ts +20 -0
- package/dist/stories/test/scene.js +86 -0
- package/dist/stories/test/scene.js.map +1 -0
- package/dist/stories/utils/index.d.ts +4 -0
- package/dist/stories/utils/index.js +28 -0
- package/dist/stories/utils/index.js.map +1 -0
- package/dist/test/index.d.ts +25 -0
- package/dist/test/index.stories.d.ts +14 -0
- package/dist/test/scene.d.ts +20 -0
- package/package.json +9 -6
- package/dist/shop-components.mjs +0 -55938
- package/dist/shop-components.umd.js +0 -9232
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { LitElement } from 'lit';
|
|
2
|
+
import { Vector2 } from 'three';
|
|
3
|
+
export declare class Line {
|
|
4
|
+
name: string;
|
|
5
|
+
slot: string;
|
|
6
|
+
start: Vector2;
|
|
7
|
+
end: Vector2;
|
|
8
|
+
readonly split = "--";
|
|
9
|
+
uuid: string;
|
|
10
|
+
valid: boolean;
|
|
11
|
+
editable: boolean;
|
|
12
|
+
highlight: boolean;
|
|
13
|
+
constructor(name: string, slot: string, start: Vector2, end: Vector2);
|
|
14
|
+
update(start: Vector2, end: Vector2): void;
|
|
15
|
+
}
|
|
16
|
+
export declare class DeviceLines extends LitElement {
|
|
17
|
+
offset: Vector2;
|
|
18
|
+
heightOffset: number;
|
|
19
|
+
lines: Map<string, Line>;
|
|
20
|
+
container: HTMLDivElement | undefined;
|
|
21
|
+
constructor(offset: Vector2, heightOffset?: number);
|
|
22
|
+
setOffset(x: number, y: number): void;
|
|
23
|
+
setHeightOffset(height: number): void;
|
|
24
|
+
hide(): void;
|
|
25
|
+
show(): void;
|
|
26
|
+
addLine(line: Line): void;
|
|
27
|
+
clear(): void;
|
|
28
|
+
removeLine(line: Line): void;
|
|
29
|
+
getLineByName(name: string): Line[];
|
|
30
|
+
getLineBySlot(slot: string): Line[];
|
|
31
|
+
getPath(line: Line): string;
|
|
32
|
+
updateLine(line: Line): void;
|
|
33
|
+
forceUpdate(): void;
|
|
34
|
+
protected render(): unknown;
|
|
35
|
+
static styles: import("lit").CSSResult;
|
|
36
|
+
}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { css, LitElement, svg } from 'lit';
|
|
8
|
+
import { customElement, query, state } from 'lit/decorators.js';
|
|
9
|
+
export class Line {
|
|
10
|
+
constructor(name, slot, start, end) {
|
|
11
|
+
this.name = name;
|
|
12
|
+
this.slot = slot;
|
|
13
|
+
this.start = start;
|
|
14
|
+
this.end = end;
|
|
15
|
+
this.split = '--';
|
|
16
|
+
this.uuid = '';
|
|
17
|
+
this.valid = false;
|
|
18
|
+
this.editable = false;
|
|
19
|
+
this.highlight = false;
|
|
20
|
+
this.uuid = name + this.split + slot;
|
|
21
|
+
}
|
|
22
|
+
update(start, end) {
|
|
23
|
+
this.start = start.clone();
|
|
24
|
+
this.end = end.clone();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
let DeviceLines = class DeviceLines extends LitElement {
|
|
28
|
+
constructor(offset, heightOffset = 0) {
|
|
29
|
+
super();
|
|
30
|
+
this.offset = offset;
|
|
31
|
+
this.heightOffset = heightOffset;
|
|
32
|
+
this.lines = new Map();
|
|
33
|
+
this.setOffset(this.offset.x, this.offset.y);
|
|
34
|
+
}
|
|
35
|
+
setOffset(x, y) {
|
|
36
|
+
this.offset.set(x, y);
|
|
37
|
+
this.style.setProperty('--left', this.offset.x + 'px');
|
|
38
|
+
this.style.setProperty('--top', this.offset.y + 'px');
|
|
39
|
+
}
|
|
40
|
+
setHeightOffset(height) {
|
|
41
|
+
this.heightOffset = height;
|
|
42
|
+
this.style.setProperty('--heightOffset', this.heightOffset + 'px');
|
|
43
|
+
}
|
|
44
|
+
hide() {
|
|
45
|
+
this.container?.classList.add('hidden');
|
|
46
|
+
}
|
|
47
|
+
show() {
|
|
48
|
+
this.container?.classList.remove('hidden');
|
|
49
|
+
}
|
|
50
|
+
addLine(line) {
|
|
51
|
+
if (!this.lines.has(line.uuid)) {
|
|
52
|
+
this.lines.set(line.uuid, line);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
clear() {
|
|
56
|
+
this.lines.clear();
|
|
57
|
+
}
|
|
58
|
+
removeLine(line) {
|
|
59
|
+
this.lines.delete(line.uuid);
|
|
60
|
+
}
|
|
61
|
+
getLineByName(name) {
|
|
62
|
+
const results = [];
|
|
63
|
+
this.lines.forEach((r, key) => {
|
|
64
|
+
if (r.name === name) {
|
|
65
|
+
results.push(r);
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
return results;
|
|
69
|
+
}
|
|
70
|
+
getLineBySlot(slot) {
|
|
71
|
+
const results = [];
|
|
72
|
+
this.lines.forEach((r, key) => {
|
|
73
|
+
if (r.slot === slot) {
|
|
74
|
+
results.push(r);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
return results;
|
|
78
|
+
}
|
|
79
|
+
getPath(line) {
|
|
80
|
+
const end = line.end.clone();
|
|
81
|
+
end.set(end.x - this.offset.x, end.y - this.offset.y);
|
|
82
|
+
const left = line.start.clone().add(end).multiplyScalar(0.5);
|
|
83
|
+
const right = line.start.clone().add(end).multiplyScalar(0.7);
|
|
84
|
+
return `M${line.start.x} ${line.start.y}
|
|
85
|
+
C${left.x} ${line.start.y}
|
|
86
|
+
${right.x} ${line.end.y}
|
|
87
|
+
${end.x} ${end.y}
|
|
88
|
+
`;
|
|
89
|
+
}
|
|
90
|
+
updateLine(line) {
|
|
91
|
+
this.lines.set(line.uuid, line);
|
|
92
|
+
}
|
|
93
|
+
forceUpdate() {
|
|
94
|
+
this.requestUpdate();
|
|
95
|
+
}
|
|
96
|
+
render() {
|
|
97
|
+
return svg `
|
|
98
|
+
<svg class="container">
|
|
99
|
+
<g>
|
|
100
|
+
${[...this.lines.values()].map(r => {
|
|
101
|
+
return svg `<path
|
|
102
|
+
class="${r.valid ? 'valid' : ''} ${r.editable ? 'editable' : ''} ${r.highlight ? 'highlight' : ''}"
|
|
103
|
+
d="${this.getPath(r)}"></path>`;
|
|
104
|
+
})}
|
|
105
|
+
</g>
|
|
106
|
+
</svg>`;
|
|
107
|
+
}
|
|
108
|
+
static { this.styles = css `
|
|
109
|
+
:host {
|
|
110
|
+
--left: 0px;
|
|
111
|
+
--top: 0px;
|
|
112
|
+
position: absolute;
|
|
113
|
+
left: var(--left);
|
|
114
|
+
top: var(--top);
|
|
115
|
+
pointer-events: none;
|
|
116
|
+
width: calc(100% - var(--left));
|
|
117
|
+
height: calc(100% - var(--top));
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
svg {
|
|
121
|
+
width: 100%;
|
|
122
|
+
height: calc(100% + var(--heightOffset));
|
|
123
|
+
&.hidden {
|
|
124
|
+
display: none;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
path {
|
|
129
|
+
stroke: #787878;
|
|
130
|
+
fill: transparent;
|
|
131
|
+
stroke-width: 0.5px;
|
|
132
|
+
stroke-dasharray: 4 4;
|
|
133
|
+
|
|
134
|
+
&.valid {
|
|
135
|
+
stroke-width: 1px;
|
|
136
|
+
stroke: #00FF95;
|
|
137
|
+
stroke-dasharray: none;
|
|
138
|
+
&:hover {
|
|
139
|
+
cursor: pointer;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
&.highlight {
|
|
144
|
+
stroke: #0066FF;
|
|
145
|
+
cursor: pointer;
|
|
146
|
+
stroke-width: 2px;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
&.editable {
|
|
150
|
+
pointer-events: auto;
|
|
151
|
+
&:hover {
|
|
152
|
+
cursor: pointer;
|
|
153
|
+
stroke: #0066FF;
|
|
154
|
+
stroke-width: 2px;
|
|
155
|
+
stroke-dasharray: none;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
`; }
|
|
160
|
+
};
|
|
161
|
+
__decorate([
|
|
162
|
+
state()
|
|
163
|
+
], DeviceLines.prototype, "lines", void 0);
|
|
164
|
+
__decorate([
|
|
165
|
+
query('.container')
|
|
166
|
+
], DeviceLines.prototype, "container", void 0);
|
|
167
|
+
DeviceLines = __decorate([
|
|
168
|
+
customElement('device-lines')
|
|
169
|
+
], DeviceLines);
|
|
170
|
+
export { DeviceLines };
|
|
171
|
+
//# sourceMappingURL=lines.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lines.js","sourceRoot":"","sources":["../../../stories/device-viewer/lines.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./scene";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../stories/device-viewer/main.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAA"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Object3D } from 'three';
|
|
2
|
+
import { CSS2DObject } from 'three/examples/jsm/renderers/CSS2DRenderer';
|
|
3
|
+
export interface UserData {
|
|
4
|
+
[key: string]: any;
|
|
5
|
+
}
|
|
6
|
+
export interface MechanismProps {
|
|
7
|
+
name: '';
|
|
8
|
+
userData?: UserData;
|
|
9
|
+
target: string;
|
|
10
|
+
default: number;
|
|
11
|
+
min: number;
|
|
12
|
+
max: number;
|
|
13
|
+
}
|
|
14
|
+
export declare class Mechanism extends CSS2DObject {
|
|
15
|
+
props: MechanismProps;
|
|
16
|
+
amr: Object3D;
|
|
17
|
+
private _direction;
|
|
18
|
+
private _controllingRotate;
|
|
19
|
+
private _controlling;
|
|
20
|
+
private _startAt;
|
|
21
|
+
private _looper;
|
|
22
|
+
private _initial;
|
|
23
|
+
private _canRotate;
|
|
24
|
+
private _timer;
|
|
25
|
+
mechanism: Object3D | undefined;
|
|
26
|
+
constructor(props: MechanismProps, amr: Object3D);
|
|
27
|
+
private _update;
|
|
28
|
+
dispose(): void;
|
|
29
|
+
}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { CSS2DObject } from 'three/examples/jsm/renderers/CSS2DRenderer';
|
|
2
|
+
import { Tween } from '@tweenjs/tween.js';
|
|
3
|
+
import RotateRight from '../asserts/rotate-right.png';
|
|
4
|
+
import RotateRightHL from '../asserts/rotate-right-hl.png';
|
|
5
|
+
export class Mechanism extends CSS2DObject {
|
|
6
|
+
constructor(props, amr) {
|
|
7
|
+
const box = document.createElement('div');
|
|
8
|
+
super(box);
|
|
9
|
+
this.props = props;
|
|
10
|
+
this.amr = amr;
|
|
11
|
+
this._direction = 1;
|
|
12
|
+
this._controllingRotate = false;
|
|
13
|
+
this._controlling = false;
|
|
14
|
+
this._startAt = 0;
|
|
15
|
+
this._looper = 0;
|
|
16
|
+
this._initial = 0;
|
|
17
|
+
this._canRotate = false;
|
|
18
|
+
this._update = () => {
|
|
19
|
+
this._looper = requestAnimationFrame(this._update);
|
|
20
|
+
if (this._controlling) {
|
|
21
|
+
let duration = (Date.now() - this._startAt) / 200;
|
|
22
|
+
if (duration > 4) {
|
|
23
|
+
duration = 4;
|
|
24
|
+
}
|
|
25
|
+
let next = this._initial + 0.005 * duration * this._direction;
|
|
26
|
+
if (next > this.props.max || next < this.props.min) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
this._initial = next;
|
|
30
|
+
if (!this.mechanism)
|
|
31
|
+
return;
|
|
32
|
+
this.mechanism.position.setY(next);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
if (props.userData && props.userData.target) {
|
|
36
|
+
amr.traverse(m => {
|
|
37
|
+
if (m.name === props.userData.target.name) {
|
|
38
|
+
this.mechanism = m;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
box.style.fontSize = '30px';
|
|
43
|
+
box.style.color = '#0066FF';
|
|
44
|
+
box.style.cursor = 'pointer';
|
|
45
|
+
box.style.pointerEvents = 'auto';
|
|
46
|
+
const arrowUp = document.createElement('div');
|
|
47
|
+
arrowUp.innerText = '↑';
|
|
48
|
+
arrowUp.style.position = 'absolute';
|
|
49
|
+
arrowUp.style.left = '0';
|
|
50
|
+
arrowUp.style.transform = 'translateX(-50%)';
|
|
51
|
+
arrowUp.style.marginBottom = '5px';
|
|
52
|
+
arrowUp.setAttribute('data-direction', 'up');
|
|
53
|
+
const arrowDown = document.createElement('div');
|
|
54
|
+
arrowDown.style.position = 'absolute';
|
|
55
|
+
arrowDown.style.left = '0';
|
|
56
|
+
arrowDown.style.transform = 'translateX(-50%)';
|
|
57
|
+
arrowDown.innerText = '↓';
|
|
58
|
+
arrowUp.style.bottom = arrowDown.style.top = '8px';
|
|
59
|
+
arrowDown.setAttribute('data-direction', 'down');
|
|
60
|
+
Array.from([arrowUp, arrowDown]).forEach(item => {
|
|
61
|
+
item.addEventListener('mousemove', () => {
|
|
62
|
+
item.style.color = '#00FF95';
|
|
63
|
+
});
|
|
64
|
+
item.addEventListener('mouseleave', () => {
|
|
65
|
+
item.style.color = '#0066FF';
|
|
66
|
+
});
|
|
67
|
+
item.addEventListener('pointerdown', () => {
|
|
68
|
+
if (!this.mechanism)
|
|
69
|
+
return;
|
|
70
|
+
this._controlling = true;
|
|
71
|
+
this._startAt = Date.now();
|
|
72
|
+
this._initial = this.mechanism.position.y;
|
|
73
|
+
this._direction = item.getAttribute('data-direction') === 'up' ? 1 : -1;
|
|
74
|
+
});
|
|
75
|
+
item.addEventListener('pointerup', () => {
|
|
76
|
+
this._controlling = false;
|
|
77
|
+
});
|
|
78
|
+
item.addEventListener('pointerleave', () => {
|
|
79
|
+
this._controlling = false;
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
if (props.userData) {
|
|
83
|
+
this._canRotate = props.userData.canRotate;
|
|
84
|
+
if (this._canRotate) {
|
|
85
|
+
const { rotateTarget, rotateDuration, rotateStep, rotateMax, rotateMin } = props.userData;
|
|
86
|
+
let rotateTargetObject;
|
|
87
|
+
if (rotateTarget) {
|
|
88
|
+
amr.traverse(m => {
|
|
89
|
+
if (m.name === rotateTarget.name) {
|
|
90
|
+
rotateTargetObject = m;
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
if (rotateTargetObject) {
|
|
94
|
+
const arrowLeft = document.createElement('div');
|
|
95
|
+
arrowLeft.style.background = `url(${RotateRight}) center no-repeat`;
|
|
96
|
+
arrowLeft.style.backgroundSize = `100% auto`;
|
|
97
|
+
arrowLeft.style.width = arrowLeft.style.height = `35px`;
|
|
98
|
+
arrowLeft.style.position = 'absolute';
|
|
99
|
+
arrowLeft.style.top = '0';
|
|
100
|
+
arrowLeft.style.transform = 'translateY(-50%) scaleX(-100%) rotateZ(-30deg) rotateX(-40deg)';
|
|
101
|
+
arrowLeft.style.marginBottom = '5px';
|
|
102
|
+
arrowLeft.setAttribute('data-direction', 'left');
|
|
103
|
+
box.append(arrowLeft);
|
|
104
|
+
const arrowRight = document.createElement('div');
|
|
105
|
+
arrowRight.style.background = `url(${RotateRight}) center no-repeat`;
|
|
106
|
+
arrowRight.style.backgroundSize = `100% auto`;
|
|
107
|
+
arrowRight.style.width = arrowRight.style.height = `35px`;
|
|
108
|
+
arrowRight.style.position = 'absolute';
|
|
109
|
+
arrowLeft.style.right = arrowRight.style.left = '10px';
|
|
110
|
+
arrowRight.style.top = '0';
|
|
111
|
+
arrowRight.style.transform = 'translateY(-50%) rotateZ(-30deg) rotateX(-40deg)';
|
|
112
|
+
arrowRight.style.marginBottom = '5px';
|
|
113
|
+
arrowRight.setAttribute('data-direction', 'right');
|
|
114
|
+
box.append(arrowRight);
|
|
115
|
+
Array.from([arrowLeft, arrowRight]).forEach(item => {
|
|
116
|
+
item.addEventListener('mousemove', () => {
|
|
117
|
+
item.style.backgroundImage = `url(${RotateRightHL})`;
|
|
118
|
+
});
|
|
119
|
+
item.addEventListener('mouseleave', () => {
|
|
120
|
+
item.style.backgroundImage = `url(${RotateRight})`;
|
|
121
|
+
});
|
|
122
|
+
item.addEventListener('pointerdown', () => {
|
|
123
|
+
if (this._timer && this._timer.isPlaying())
|
|
124
|
+
return;
|
|
125
|
+
this._controllingRotate = true;
|
|
126
|
+
this._startAt = Date.now();
|
|
127
|
+
this._direction = item.getAttribute('data-direction') === 'left' ? -1 : 1;
|
|
128
|
+
let targetY = (rotateStep / 180) * Math.PI * this._direction + rotateTargetObject.rotation.y;
|
|
129
|
+
if (targetY > rotateMax / 180 * Math.PI) {
|
|
130
|
+
targetY = rotateMax / 180 * Math.PI;
|
|
131
|
+
}
|
|
132
|
+
else if (targetY < rotateMin / 180 * Math.PI) {
|
|
133
|
+
targetY = rotateMin / 180 * Math.PI;
|
|
134
|
+
}
|
|
135
|
+
this._timer = new Tween(rotateTargetObject.rotation)
|
|
136
|
+
.to({
|
|
137
|
+
y: targetY
|
|
138
|
+
})
|
|
139
|
+
.duration(rotateDuration)
|
|
140
|
+
.start();
|
|
141
|
+
});
|
|
142
|
+
item.addEventListener('pointerup', () => {
|
|
143
|
+
this._controllingRotate = false;
|
|
144
|
+
});
|
|
145
|
+
item.addEventListener('pointerleave', () => {
|
|
146
|
+
this._controllingRotate = false;
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
box.append(arrowUp, arrowDown);
|
|
154
|
+
this.scale.set(0.01, 0.01, 0.01);
|
|
155
|
+
this.matrixAutoUpdate = false;
|
|
156
|
+
this.updateMatrix();
|
|
157
|
+
this._update();
|
|
158
|
+
}
|
|
159
|
+
dispose() {
|
|
160
|
+
cancelAnimationFrame(this._looper);
|
|
161
|
+
this.element.remove();
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=mechanism.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mechanism.js","sourceRoot":"","sources":["../../../../stories/device-viewer/mechanism/mechanism.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,4CAA4C,CAAA;AACxE,OAAO,EAAE,KAAK,EAAE,MAAY,mBAAmB,CAAA;AAC/C,OAAO,WAAW,MAAU,6BAA6B,CAAA;AACzD,OAAO,aAAa,MAAU,gCAAgC,CAAA;AAe9D,MAAM,OAAO,SAAU,SAAQ,WAAW;IAexC,YAAmB,KAAqB,EAAS,GAAa;QAC5D,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QACzC,KAAK,CAAC,GAAG,CAAC,CAAA;QAFO,UAAK,GAAL,KAAK,CAAgB;QAAS,QAAG,GAAH,GAAG,CAAU;QAdtD,eAAU,GAAG,CAAC,CAAA;QACd,uBAAkB,GAAG,KAAK,CAAA;QAC1B,iBAAY,GAAG,KAAK,CAAA;QACpB,aAAQ,GAAG,CAAC,CAAA;QACZ,YAAO,GAAG,CAAC,CAAA;QAEX,aAAQ,GAAG,CAAC,CAAA;QAEZ,eAAU,GAAG,KAAK,CAAA;QAmJlB,YAAO,GAAG,GAAG,EAAE;YACrB,IAAI,CAAC,OAAO,GAAG,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YAClD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,IAAI,QAAQ,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAA;gBACjD,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;oBACjB,QAAQ,GAAG,CAAC,CAAA;gBACd,CAAC;gBACD,IAAI,IAAI,GAAG,IAAI,CAAC,QAAQ,GAAG,KAAK,GAAG,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAA;gBAC7D,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;oBACnD,OAAM;gBACR,CAAC;gBAOD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;gBACpB,IAAI,CAAC,IAAI,CAAC,SAAS;oBAAE,OAAM;gBAC3B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,CAAC;QACH,CAAC,CAAA;QA9JC,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YAC5C,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;gBACf,IAAI,CAAC,CAAC,IAAI,KAAK,KAAK,CAAC,QAAS,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;oBAC3C,IAAI,CAAC,SAAS,GAAG,CAAC,CAAA;gBACpB,CAAC;YACH,CAAC,CAAC,CAAA;QACJ,CAAC;QAED,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAA;QAC3B,GAAG,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAA;QAC3B,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAA;QAE5B,GAAG,CAAC,KAAK,CAAC,aAAa,GAAG,MAAM,CAAA;QAEhC,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QAC7C,OAAO,CAAC,SAAS,GAAG,GAAG,CAAA;QACvB,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAA;QACnC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAA;QACxB,OAAO,CAAC,KAAK,CAAC,SAAS,GAAG,kBAAkB,CAAA;QAC5C,OAAO,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAA;QAClC,OAAO,CAAC,YAAY,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAA;QAC5C,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QAC/C,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAA;QACrC,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,CAAA;QAC1B,SAAS,CAAC,KAAK,CAAC,SAAS,GAAG,kBAAkB,CAAA;QAC9C,SAAS,CAAC,SAAS,GAAG,GAAG,CAAA;QACzB,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,CAAA;QAElD,SAAS,CAAC,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAA;QAChD,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC9C,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,EAAE;gBACtC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAA;YAC9B,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE;gBACvC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAA;YAC9B,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,GAAG,EAAE;gBACxC,IAAI,CAAC,IAAI,CAAC,SAAS;oBAAE,OAAM;gBAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAA;gBACxB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;gBAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAA;gBACzC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACzE,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,EAAE;gBACtC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAA;YAC3B,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,GAAG,EAAE;gBACzC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAA;YAC3B,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAA;YAC1C,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBAEpB,MAAM,EAAE,YAAY,EAAE,cAAc,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC,QAAQ,CAAA;gBACzF,IAAI,kBAAwC,CAAA;gBAC5C,IAAI,YAAY,EAAE,CAAC;oBACjB,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;wBACf,IAAI,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,IAAI,EAAE,CAAC;4BACjC,kBAAkB,GAAG,CAAC,CAAA;wBACxB,CAAC;oBACH,CAAC,CAAC,CAAA;oBACF,IAAI,kBAAkB,EAAE,CAAC;wBACvB,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;wBAC/C,SAAS,CAAC,KAAK,CAAC,UAAU,GAAG,OAAO,WAAW,oBAAoB,CAAA;wBACnE,SAAS,CAAC,KAAK,CAAC,cAAc,GAAG,WAAW,CAAA;wBAC5C,SAAS,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAA;wBACvD,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAA;wBACrC,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,CAAA;wBACzB,SAAS,CAAC,KAAK,CAAC,SAAS,GAAG,gEAAgE,CAAA;wBAC5F,SAAS,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAA;wBACpC,SAAS,CAAC,YAAY,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAA;wBAChD,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;wBAErB,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;wBAChD,UAAU,CAAC,KAAK,CAAC,UAAU,GAAG,OAAO,WAAW,oBAAoB,CAAA;wBACpE,UAAU,CAAC,KAAK,CAAC,cAAc,GAAG,WAAW,CAAA;wBAC7C,UAAU,CAAC,KAAK,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAA;wBAEzD,UAAU,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAA;wBACtC,SAAS,CAAC,KAAK,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAA;wBACtD,UAAU,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,CAAA;wBAC1B,UAAU,CAAC,KAAK,CAAC,SAAS,GAAG,kDAAkD,CAAA;wBAC/E,UAAU,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAA;wBACrC,UAAU,CAAC,YAAY,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAA;wBAClD,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;wBAEtB,KAAK,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;4BACjD,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,EAAE;gCACtC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,OAAO,aAAa,GAAG,CAAA;4BACtD,CAAC,CAAC,CAAA;4BACF,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE;gCACvC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,OAAO,WAAW,GAAG,CAAA;4BACpD,CAAC,CAAC,CAAA;4BACF,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,GAAG,EAAE;gCACxC,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;oCAAE,OAAM;gCAClD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAA;gCAC9B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;gCAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;gCAEzE,IAAI,OAAO,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG,kBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAA;gCAC7F,IAAI,OAAO,GAAG,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;oCACxC,OAAO,GAAG,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,CAAA;gCACrC,CAAC;qCAAM,IAAI,OAAO,GAAG,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;oCAC/C,OAAO,GAAG,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,CAAA;gCACrC,CAAC;gCACD,IAAI,CAAC,MAAM,GAAG,IAAI,KAAK,CAAC,kBAAmB,CAAC,QAAQ,CAAC;qCAClD,EAAE,CAAC;oCACF,CAAC,EAAE,OAAO;iCACX,CAAC;qCACD,QAAQ,CAAC,cAAc,CAAC;qCACxB,KAAK,EAAE,CAAA;4BAEZ,CAAC,CAAC,CAAA;4BACF,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,EAAE;gCACtC,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAA;4BACjC,CAAC,CAAC,CAAA;4BACF,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,GAAG,EAAE;gCACzC,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAA;4BACjC,CAAC,CAAC,CAAA;wBACJ,CAAC,CAAC,CAAA;oBACJ,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;QAE9B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAA;QAEhC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAA;QAC7B,IAAI,CAAC,YAAY,EAAE,CAAA;QAEnB,IAAI,CAAC,OAAO,EAAE,CAAA;IAChB,CAAC;IAyBD,OAAO;QACL,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAClC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;IACvB,CAAC;CACF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Object3D, Vector3 } from 'three';
|
|
2
|
+
import { CSS2DObject } from 'three/examples/jsm/renderers/CSS2DRenderer';
|
|
3
|
+
export declare class Outerline extends Object3D {
|
|
4
|
+
radius: number;
|
|
5
|
+
private _text;
|
|
6
|
+
private _line;
|
|
7
|
+
private _box;
|
|
8
|
+
constructor(radius: number, height: number);
|
|
9
|
+
update(radius: number): void;
|
|
10
|
+
change(pos: Vector3): void;
|
|
11
|
+
}
|
|
12
|
+
export declare class RadiusText extends CSS2DObject {
|
|
13
|
+
private _wrapper;
|
|
14
|
+
constructor(radius: string);
|
|
15
|
+
update(radius: string): void;
|
|
16
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { BufferGeometry, DoubleSide, Line, LineBasicMaterial, Mesh, MeshBasicMaterial, Object3D, RingGeometry, Vector3 } from 'three';
|
|
2
|
+
import { CSS2DObject } from 'three/examples/jsm/renderers/CSS2DRenderer';
|
|
3
|
+
export class Outerline extends Object3D {
|
|
4
|
+
constructor(radius, height) {
|
|
5
|
+
super();
|
|
6
|
+
this.radius = radius;
|
|
7
|
+
this._text = new RadiusText('');
|
|
8
|
+
this._line = new Line(new BufferGeometry(), new LineBasicMaterial({
|
|
9
|
+
color: '#888'
|
|
10
|
+
}));
|
|
11
|
+
this._box = new Mesh();
|
|
12
|
+
this._box.geometry = new RingGeometry(radius, radius + 0.003, 128);
|
|
13
|
+
this._box.material = new MeshBasicMaterial({
|
|
14
|
+
color: '#898989',
|
|
15
|
+
side: DoubleSide
|
|
16
|
+
});
|
|
17
|
+
this.position.y = height;
|
|
18
|
+
this._box.rotateX(-Math.PI / 2);
|
|
19
|
+
this.add(this._box);
|
|
20
|
+
this.add(this._line);
|
|
21
|
+
this.add(this._text);
|
|
22
|
+
}
|
|
23
|
+
update(radius) {
|
|
24
|
+
this.radius = radius;
|
|
25
|
+
this._box.geometry?.dispose();
|
|
26
|
+
this._box.geometry = new RingGeometry(radius, radius + 0.003, 128);
|
|
27
|
+
this._text.update((radius * 1000).toFixed(0));
|
|
28
|
+
}
|
|
29
|
+
change(pos) {
|
|
30
|
+
const target = pos.clone();
|
|
31
|
+
target.setY(0);
|
|
32
|
+
target.normalize().multiplyScalar(this.radius);
|
|
33
|
+
this._text.position.set(target.x, target.y, target.z);
|
|
34
|
+
this._line.geometry.dispose();
|
|
35
|
+
this._line.geometry.setFromPoints([target, new Vector3()]);
|
|
36
|
+
this._line.computeLineDistances();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
export class RadiusText extends CSS2DObject {
|
|
40
|
+
constructor(radius) {
|
|
41
|
+
const box = document.createElement('div');
|
|
42
|
+
super(box);
|
|
43
|
+
this._wrapper = document.createElement('div');
|
|
44
|
+
this._wrapper.style.fontSize = '10px';
|
|
45
|
+
this._wrapper.style.color = '#898989';
|
|
46
|
+
this._wrapper.style.whiteSpace = 'nowrap';
|
|
47
|
+
this._wrapper.style.position = 'absolute';
|
|
48
|
+
this._wrapper.style.transform = 'translateX(-50%)';
|
|
49
|
+
this._wrapper.style.bottom = '4px';
|
|
50
|
+
const circle = document.createElement('div');
|
|
51
|
+
circle.style.position = 'relative';
|
|
52
|
+
circle.style.zIndex = '10';
|
|
53
|
+
circle.style.width = circle.style.height = '5px';
|
|
54
|
+
circle.style.borderRadius = '50%';
|
|
55
|
+
circle.style.background = '#ff6666';
|
|
56
|
+
box.append(this._wrapper, circle);
|
|
57
|
+
this.update(radius);
|
|
58
|
+
}
|
|
59
|
+
update(radius) {
|
|
60
|
+
this._wrapper.innerText = '旋转半径:' + radius + ' mm';
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=outerline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outerline.js","sourceRoot":"","sources":["../../../stories/device-viewer/outerline.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Object3D, Vector3 } from 'three';
|
|
2
|
+
import { AMRAssembly } from './assembly';
|
|
3
|
+
import EventEmitter from 'eventemitter3';
|
|
4
|
+
export interface RollerProps {
|
|
5
|
+
goodsSize: Vector3;
|
|
6
|
+
}
|
|
7
|
+
export declare class Roller extends AMRAssembly {
|
|
8
|
+
private _props;
|
|
9
|
+
private _goodsWidthGap;
|
|
10
|
+
private _goodsLengthGap;
|
|
11
|
+
private _emitter;
|
|
12
|
+
addEventListener: <T extends string | symbol>(event: T, fn: (...args: any[]) => void, context?: any) => EventEmitter<string | symbol, any>;
|
|
13
|
+
private _shaft;
|
|
14
|
+
private _shaftInstances;
|
|
15
|
+
private _length;
|
|
16
|
+
private _container;
|
|
17
|
+
private _goodsContainer;
|
|
18
|
+
private _goodsSize;
|
|
19
|
+
private _goods;
|
|
20
|
+
constructor(_props: RollerProps);
|
|
21
|
+
get length(): number;
|
|
22
|
+
loaded(glb: Object3D): void;
|
|
23
|
+
setGoodsSize({ length, width, height }: {
|
|
24
|
+
length: number;
|
|
25
|
+
width: number;
|
|
26
|
+
height: number;
|
|
27
|
+
}): void;
|
|
28
|
+
setShapeKey(key: string, value: number): void;
|
|
29
|
+
private _generateShaft;
|
|
30
|
+
destroy(): void;
|
|
31
|
+
}
|