shop-components 0.0.25 → 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,109 @@
|
|
|
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, html, LitElement } from 'lit';
|
|
8
|
+
import { customElement, property, query } from 'lit/decorators.js';
|
|
9
|
+
const url = 'http://192.168.0.31:3000';
|
|
10
|
+
let StepViewer = class StepViewer extends LitElement {
|
|
11
|
+
constructor() {
|
|
12
|
+
super();
|
|
13
|
+
this.files = [];
|
|
14
|
+
this._upload = async (filePath) => {
|
|
15
|
+
const formData = new FormData();
|
|
16
|
+
const file = await this.blobURLToFile(filePath);
|
|
17
|
+
URL.revokeObjectURL(filePath);
|
|
18
|
+
console.log(file);
|
|
19
|
+
if (!file)
|
|
20
|
+
return;
|
|
21
|
+
formData.append('file', file);
|
|
22
|
+
const response = await fetch(`${url}/api/v1/resource/upload`, {
|
|
23
|
+
method: 'POST',
|
|
24
|
+
body: formData
|
|
25
|
+
});
|
|
26
|
+
const { id } = await response.json();
|
|
27
|
+
if (id) {
|
|
28
|
+
const r = await this._startTask(id);
|
|
29
|
+
console.log(r);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
firstUpdated(_changedProperties) {
|
|
34
|
+
super.firstUpdated(_changedProperties);
|
|
35
|
+
if (!this.container)
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
updated(_changedProperties) {
|
|
39
|
+
super.updated(_changedProperties);
|
|
40
|
+
if (this.files.length > 0) {
|
|
41
|
+
const file = this.files[0];
|
|
42
|
+
this._upload(file)
|
|
43
|
+
.then();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
async blobURLToFile(blobURL, fileName) {
|
|
47
|
+
try {
|
|
48
|
+
const response = await fetch(blobURL);
|
|
49
|
+
const blob = await response.blob();
|
|
50
|
+
if (!fileName) {
|
|
51
|
+
fileName = blobURL.slice(blobURL.lastIndexOf('/')) + '.stp';
|
|
52
|
+
}
|
|
53
|
+
return new File([blob], fileName, { type: blob.type });
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
console.error('Error:', error);
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async _startTask(id) {
|
|
61
|
+
const response = await fetch(`${url}/api/`, {
|
|
62
|
+
method: 'POST',
|
|
63
|
+
headers: {
|
|
64
|
+
'Content-Type': 'application/json'
|
|
65
|
+
},
|
|
66
|
+
body: JSON.stringify({
|
|
67
|
+
metadata: {
|
|
68
|
+
resID: id,
|
|
69
|
+
targetExt: 'fbx'
|
|
70
|
+
}
|
|
71
|
+
})
|
|
72
|
+
});
|
|
73
|
+
if (response.ok) {
|
|
74
|
+
return await response.json();
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
render() {
|
|
78
|
+
return html `
|
|
79
|
+
${this.files?.map(r => {
|
|
80
|
+
return html `
|
|
81
|
+
<div>
|
|
82
|
+
<img src="${r}" alt=""/>
|
|
83
|
+
</div>`;
|
|
84
|
+
})}
|
|
85
|
+
<div class="container"></div>`;
|
|
86
|
+
}
|
|
87
|
+
static { this.styles = css `
|
|
88
|
+
:host {
|
|
89
|
+
display: block;
|
|
90
|
+
width: 100%;
|
|
91
|
+
height: 100%;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
img {
|
|
95
|
+
width: 40px;
|
|
96
|
+
}
|
|
97
|
+
`; }
|
|
98
|
+
};
|
|
99
|
+
__decorate([
|
|
100
|
+
query('.container')
|
|
101
|
+
], StepViewer.prototype, "container", void 0);
|
|
102
|
+
__decorate([
|
|
103
|
+
property()
|
|
104
|
+
], StepViewer.prototype, "files", void 0);
|
|
105
|
+
StepViewer = __decorate([
|
|
106
|
+
customElement('step-viewer')
|
|
107
|
+
], StepViewer);
|
|
108
|
+
export default StepViewer;
|
|
109
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../stories/step-viewer/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import StepViewer, { Props } from './index';
|
|
2
|
+
declare const _default: {
|
|
3
|
+
title: string;
|
|
4
|
+
tags: string[];
|
|
5
|
+
render: (args: Props) => StepViewer;
|
|
6
|
+
argTypes: {
|
|
7
|
+
files: {
|
|
8
|
+
control: {
|
|
9
|
+
type: string;
|
|
10
|
+
accept: string;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
export default _default;
|
|
16
|
+
export declare const Primary: {
|
|
17
|
+
args: {
|
|
18
|
+
files: never[];
|
|
19
|
+
};
|
|
20
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import StepViewer from './index';
|
|
2
|
+
export default {
|
|
3
|
+
title: 'Shop/StepViewer',
|
|
4
|
+
tags: ['autodocs'],
|
|
5
|
+
render: (args) => {
|
|
6
|
+
const viewer = new StepViewer();
|
|
7
|
+
viewer.files = args.files;
|
|
8
|
+
return viewer;
|
|
9
|
+
},
|
|
10
|
+
argTypes: {
|
|
11
|
+
files: {
|
|
12
|
+
control: {
|
|
13
|
+
type: 'file',
|
|
14
|
+
accept: '.stp,.step'
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
export const Primary = {
|
|
20
|
+
args: {
|
|
21
|
+
files: []
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=index.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.stories.js","sourceRoot":"","sources":["../../../stories/step-viewer/index.stories.ts"],"names":[],"mappings":"AAAA,OAAO,UAAqB,MAAM,SAAS,CAAA;AAE3C,eAAe;IACb,KAAK,EAAE,iBAAiB;IACxB,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,MAAM,EAAE,CAAC,IAAW,EAAE,EAAE;QACtB,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAA;QAC/B,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;QACzB,OAAO,MAAM,CAAA;IACf,CAAC;IACD,QAAQ,EAAE;QACR,KAAK,EAAE;YACL,OAAO,EAAE;gBACP,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,YAAY;aACrB;SACF;KACF;CACF,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,IAAI,EAAE;QACJ,KAAK,EAAE,EAAE;KACV;CACF,CAAA"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { LitElement, PropertyValues } from 'lit';
|
|
2
|
+
import { Scene3D } from './scene';
|
|
3
|
+
export interface Props {
|
|
4
|
+
test: string;
|
|
5
|
+
count: number;
|
|
6
|
+
onChange: () => {};
|
|
7
|
+
}
|
|
8
|
+
export declare class TestViewer extends LitElement {
|
|
9
|
+
scene: Scene3D;
|
|
10
|
+
container: HTMLDivElement | undefined;
|
|
11
|
+
drag: HTMLButtonElement | undefined;
|
|
12
|
+
constructor();
|
|
13
|
+
protected firstUpdated(_changedProperties: PropertyValues): void;
|
|
14
|
+
protected updated(_changedProperties: PropertyValues): void;
|
|
15
|
+
disconnectedCallback(): void;
|
|
16
|
+
test: string;
|
|
17
|
+
count: number;
|
|
18
|
+
theme: undefined | string;
|
|
19
|
+
onChange: undefined | Function;
|
|
20
|
+
usePathTracing: boolean;
|
|
21
|
+
progressBar: HTMLDivElement | undefined;
|
|
22
|
+
cancel: () => void;
|
|
23
|
+
protected render(): unknown;
|
|
24
|
+
static styles: import("lit").CSSResult;
|
|
25
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
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, html, LitElement } from 'lit';
|
|
8
|
+
import { customElement, property, query, state } from 'lit/decorators.js';
|
|
9
|
+
import { Scene3D } from './scene';
|
|
10
|
+
let TestViewer = class TestViewer extends LitElement {
|
|
11
|
+
constructor() {
|
|
12
|
+
super();
|
|
13
|
+
this.scene = new Scene3D();
|
|
14
|
+
this.test = '';
|
|
15
|
+
this.count = 4;
|
|
16
|
+
this.usePathTracing = false;
|
|
17
|
+
this.cancel = () => {
|
|
18
|
+
this.usePathTracing = false;
|
|
19
|
+
this.scene.usePathTracing = false;
|
|
20
|
+
};
|
|
21
|
+
const style = document.createElement('style');
|
|
22
|
+
document.head.append(style);
|
|
23
|
+
this.scene.renderer.domElement.addEventListener('ticker', () => {
|
|
24
|
+
const percent = this.scene.sampleCount / this.scene.maxSample;
|
|
25
|
+
if (this.progressBar) {
|
|
26
|
+
this.progressBar.style.width = percent * 100 + '%';
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
firstUpdated(_changedProperties) {
|
|
31
|
+
super.firstUpdated(_changedProperties);
|
|
32
|
+
if (!this.container)
|
|
33
|
+
return;
|
|
34
|
+
this.scene.appendTo(this.container);
|
|
35
|
+
}
|
|
36
|
+
updated(_changedProperties) {
|
|
37
|
+
super.updated(_changedProperties);
|
|
38
|
+
}
|
|
39
|
+
disconnectedCallback() {
|
|
40
|
+
super.disconnectedCallback();
|
|
41
|
+
this.scene.destroy();
|
|
42
|
+
}
|
|
43
|
+
render() {
|
|
44
|
+
return html `
|
|
45
|
+
<div class="container">
|
|
46
|
+
<div class="progress-bar"></div>
|
|
47
|
+
<div class="actions">
|
|
48
|
+
${this.usePathTracing
|
|
49
|
+
? html `
|
|
50
|
+
<button @click=${this.cancel}>取消渲染</button>`
|
|
51
|
+
: html `
|
|
52
|
+
<button @click=${this.generateBVH}>渲染</button>`}
|
|
53
|
+
</div>
|
|
54
|
+
</div>`;
|
|
55
|
+
}
|
|
56
|
+
static { this.styles = css `
|
|
57
|
+
|
|
58
|
+
.actions {
|
|
59
|
+
position:relative;
|
|
60
|
+
z-index:100;
|
|
61
|
+
}
|
|
62
|
+
canvas {
|
|
63
|
+
position:absolute;
|
|
64
|
+
left:0;
|
|
65
|
+
top:0;
|
|
66
|
+
width:100%;
|
|
67
|
+
height: 100%;
|
|
68
|
+
}
|
|
69
|
+
`; }
|
|
70
|
+
};
|
|
71
|
+
__decorate([
|
|
72
|
+
query('.container')
|
|
73
|
+
], TestViewer.prototype, "container", void 0);
|
|
74
|
+
__decorate([
|
|
75
|
+
query('#drag')
|
|
76
|
+
], TestViewer.prototype, "drag", void 0);
|
|
77
|
+
__decorate([
|
|
78
|
+
property()
|
|
79
|
+
], TestViewer.prototype, "test", void 0);
|
|
80
|
+
__decorate([
|
|
81
|
+
property()
|
|
82
|
+
], TestViewer.prototype, "count", void 0);
|
|
83
|
+
__decorate([
|
|
84
|
+
property()
|
|
85
|
+
], TestViewer.prototype, "theme", void 0);
|
|
86
|
+
__decorate([
|
|
87
|
+
property()
|
|
88
|
+
], TestViewer.prototype, "onChange", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
state()
|
|
91
|
+
], TestViewer.prototype, "usePathTracing", void 0);
|
|
92
|
+
__decorate([
|
|
93
|
+
query('.progress-bar')
|
|
94
|
+
], TestViewer.prototype, "progressBar", void 0);
|
|
95
|
+
TestViewer = __decorate([
|
|
96
|
+
customElement('test-viewer')
|
|
97
|
+
], TestViewer);
|
|
98
|
+
export { TestViewer };
|
|
99
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../stories/test/index.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAkB,MAAM,KAAK,CAAA;AAC3D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AACzE,OAAO,EAAE,OAAO,EAAE,MAAoC,SAAS,CAAA;AASxD,IAAM,UAAU,GAAhB,MAAM,UAAW,SAAQ,UAAU;IAcxC;QACE,KAAK,EAAE,CAAA;QAbT,UAAK,GAAG,IAAI,OAAO,EAAE,CAAA;QAyCrB,SAAI,GAAG,EAAE,CAAA;QAGT,UAAK,GAAG,CAAC,CAAA;QAST,mBAAc,GAAG,KAAK,CAAA;QAKtB,WAAM,GAAG,GAAG,EAAE;YACZ,IAAI,CAAC,cAAc,GAAG,KAAK,CAAA;YAC3B,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,KAAK,CAAA;QACnC,CAAC,CAAA;QA/CC,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAA;QAC7C,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAE3B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;YAC7D,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAA;YAC7D,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACrB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,GAAG,GAAG,GAAG,GAAG,CAAA;YACpD,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAES,YAAY,CAAC,kBAAkC;QACvD,KAAK,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAA;QACtC,IAAI,CAAC,IAAI,CAAC,SAAS;YAAE,OAAM;QAC3B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACrC,CAAC;IAES,OAAO,CAAC,kBAAkC;QAClD,KAAK,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAA;IACnC,CAAC;IAED,oBAAoB;QAClB,KAAK,CAAC,oBAAoB,EAAE,CAAA;QAC5B,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAA;IACtB,CAAC;IAyBS,MAAM;QACd,OAAO,IAAI,CAAA;;;;YAKH,IAAI,CAAC,cAAc;YACjB,CAAC,CAAC,IAAI,CAAA;iCACa,IAAI,CAAC,MAAM,gBAAgB;YAC9C,CAAC,CAAC,IAAI,CAAA;iCACa,IAAI,CAAC,WAAW,cACvC;;aAEG,CAAA;IACX,CAAC;aAEM,WAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;GAalB,AAbY,CAaZ;;AAzFD;IADC,KAAK,CAAC,YAAY,CAAC;6CACiB;AAGrC;IADC,KAAK,CAAC,OAAO,CAAC;wCACoB;AAmCnC;IADC,QAAQ,EAAE;wCACF;AAGT;IADC,QAAQ,EAAE;yCACF;AAGT;IADC,QAAQ,EAAE;yCACc;AAGzB;IADC,QAAQ,EAAE;4CACmB;AAG9B;IADC,KAAK,EAAE;kDACc;AAGtB;IADC,KAAK,CAAC,eAAe,CAAC;+CACgB;AA1D5B,UAAU;IADtB,aAAa,CAAC,aAAa,CAAC;GAChB,UAAU,CA+FtB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { TestViewer, Props } from './index';
|
|
2
|
+
declare const _default: {
|
|
3
|
+
title: string;
|
|
4
|
+
tags: string[];
|
|
5
|
+
render: (args: Props) => TestViewer;
|
|
6
|
+
argTypes: {};
|
|
7
|
+
};
|
|
8
|
+
export default _default;
|
|
9
|
+
export declare const Primary: {
|
|
10
|
+
args: {
|
|
11
|
+
test: string;
|
|
12
|
+
count: number;
|
|
13
|
+
};
|
|
14
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { TestViewer } from './index';
|
|
2
|
+
export default {
|
|
3
|
+
title: 'Shop/TestViewer',
|
|
4
|
+
tags: ['autodocs'],
|
|
5
|
+
render: (args) => {
|
|
6
|
+
return new TestViewer();
|
|
7
|
+
},
|
|
8
|
+
argTypes: {}
|
|
9
|
+
};
|
|
10
|
+
export const Primary = {
|
|
11
|
+
args: {
|
|
12
|
+
test: 'test',
|
|
13
|
+
count: 4
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=index.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.stories.js","sourceRoot":"","sources":["../../../stories/test/index.stories.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAS,MAAM,SAAS,CAAA;AAE3C,eAAe;IACb,KAAK,EAAE,iBAAiB;IACxB,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,MAAM,EAAE,CAAC,IAAW,EAAE,EAAE;QACtB,OAAO,IAAI,UAAU,EAAE,CAAA;IACzB,CAAC;IACD,QAAQ,EAAE,EACT;CACF,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM;QACZ,KAAK,EAAE,CAAC;KACT;CACF,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { PerspectiveCamera, Scene, WebGLRenderer } from 'three';
|
|
2
|
+
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';
|
|
3
|
+
import { WebGLPathTracer } from 'three-gpu-pathtracer';
|
|
4
|
+
export declare class Scene3D {
|
|
5
|
+
readonly maxSample = 1024;
|
|
6
|
+
sampleCount: number;
|
|
7
|
+
renderer: WebGLRenderer;
|
|
8
|
+
camera: PerspectiveCamera;
|
|
9
|
+
scene: Scene;
|
|
10
|
+
controls: OrbitControls;
|
|
11
|
+
_usePathTracing: boolean;
|
|
12
|
+
pathTracer: WebGLPathTracer;
|
|
13
|
+
usePathTracing: boolean;
|
|
14
|
+
constructor();
|
|
15
|
+
resize: () => void;
|
|
16
|
+
private _loadEnv;
|
|
17
|
+
generateBVH(): void;
|
|
18
|
+
appendTo(parent: any): void;
|
|
19
|
+
ticker: () => void;
|
|
20
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { BoxGeometry, EquirectangularReflectionMapping, LinearFilter, LoadingManager, Mesh, PerspectiveCamera, Scene, SRGBColorSpace, Vector3, WebGLRenderer } from 'three';
|
|
2
|
+
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';
|
|
3
|
+
import { RGBELoader } from 'three/examples/jsm/loaders/RGBELoader';
|
|
4
|
+
import HDR from '../device-viewer/asserts/lightroom_14b_512.hdr?url';
|
|
5
|
+
import { WebGLPathTracer } from 'three-gpu-pathtracer';
|
|
6
|
+
const initialDamp = 0.2;
|
|
7
|
+
export class Scene3D {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.maxSample = 1024;
|
|
10
|
+
this.sampleCount = 0;
|
|
11
|
+
this.renderer = new WebGLRenderer({
|
|
12
|
+
antialias: true,
|
|
13
|
+
alpha: true,
|
|
14
|
+
logarithmicDepthBuffer: true,
|
|
15
|
+
powerPreference: 'high-performance',
|
|
16
|
+
preserveDrawingBuffer: true
|
|
17
|
+
});
|
|
18
|
+
this.camera = new PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.01, 10000);
|
|
19
|
+
this.scene = new Scene();
|
|
20
|
+
this._usePathTracing = false;
|
|
21
|
+
this.usePathTracing = false;
|
|
22
|
+
this.resize = () => {
|
|
23
|
+
const parent = this.renderer.domElement.parentElement;
|
|
24
|
+
if (!parent)
|
|
25
|
+
return;
|
|
26
|
+
parent.style.display = 'flex';
|
|
27
|
+
this.renderer.domElement.style.width = '100%';
|
|
28
|
+
this.renderer.domElement.style.height = '100%';
|
|
29
|
+
this.renderer.domElement.style.flexGrow = '1';
|
|
30
|
+
const width = parent.clientWidth;
|
|
31
|
+
const height = parent.clientHeight;
|
|
32
|
+
this.camera.aspect = width / height;
|
|
33
|
+
this.camera.updateProjectionMatrix();
|
|
34
|
+
const pixelRatio = this.renderer.getPixelRatio();
|
|
35
|
+
this.sampleCount = 0;
|
|
36
|
+
this.renderer.setSize(width, height);
|
|
37
|
+
};
|
|
38
|
+
this.ticker = () => {
|
|
39
|
+
requestAnimationFrame(this.ticker);
|
|
40
|
+
this.renderer.domElement.dispatchEvent(new CustomEvent('ticker'));
|
|
41
|
+
this.pathTracer?.renderSample();
|
|
42
|
+
};
|
|
43
|
+
this.controls = new OrbitControls(this.camera, this.renderer.domElement);
|
|
44
|
+
this.controls.enablePan = false;
|
|
45
|
+
this.controls.rotateSpeed = 0.3;
|
|
46
|
+
this.controls.dampingFactor = initialDamp;
|
|
47
|
+
this.controls.enableDamping = true;
|
|
48
|
+
this.controls.maxDistance = 50;
|
|
49
|
+
this.controls.minDistance = 0.3;
|
|
50
|
+
this._loadEnv();
|
|
51
|
+
const box = new Mesh(new BoxGeometry(1, 1, 1));
|
|
52
|
+
this.scene.add(box);
|
|
53
|
+
this.ticker();
|
|
54
|
+
this.camera.position.set(10, 0, -10);
|
|
55
|
+
this.camera.lookAt(new Vector3());
|
|
56
|
+
this.pathTracer = new WebGLPathTracer(this.renderer);
|
|
57
|
+
this.pathTracer.setScene(this.scene, this.camera);
|
|
58
|
+
this.resize();
|
|
59
|
+
}
|
|
60
|
+
_loadEnv() {
|
|
61
|
+
const loader = new RGBELoader(new LoadingManager());
|
|
62
|
+
loader.load(HDR, (texture) => {
|
|
63
|
+
texture.mapping = EquirectangularReflectionMapping;
|
|
64
|
+
texture.minFilter = LinearFilter;
|
|
65
|
+
texture.magFilter = LinearFilter;
|
|
66
|
+
texture.colorSpace = SRGBColorSpace;
|
|
67
|
+
texture.needsUpdate = true;
|
|
68
|
+
if (this._usePathTracing) {
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
this.scene.environment = texture;
|
|
72
|
+
}
|
|
73
|
+
this.scene.background = texture;
|
|
74
|
+
this.scene.backgroundIntensity = 1;
|
|
75
|
+
this.scene.backgroundBlurriness = 0;
|
|
76
|
+
}, () => {
|
|
77
|
+
}, () => {
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
generateBVH() {
|
|
81
|
+
}
|
|
82
|
+
appendTo(parent) {
|
|
83
|
+
parent.append(this.renderer.domElement);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=scene.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scene.js","sourceRoot":"","sources":["../../../stories/test/scene.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function downloadBlob(blob: Blob, filename: string): void;
|
|
2
|
+
export declare function calculateArrayAverage(array: number[]): number;
|
|
3
|
+
export declare function arrayBufferToUrl(arrayBuffer: ArrayBuffer, mimeType: string): string;
|
|
4
|
+
export declare function isAppleDevice(): boolean;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export function downloadBlob(blob, filename) {
|
|
2
|
+
const url = URL.createObjectURL(blob);
|
|
3
|
+
const a = document.createElement('a');
|
|
4
|
+
a.href = url;
|
|
5
|
+
a.download = filename;
|
|
6
|
+
document.body.appendChild(a);
|
|
7
|
+
a.click();
|
|
8
|
+
document.body.removeChild(a);
|
|
9
|
+
URL.revokeObjectURL(url);
|
|
10
|
+
}
|
|
11
|
+
export function calculateArrayAverage(array) {
|
|
12
|
+
if (array.length === 0) {
|
|
13
|
+
return 0;
|
|
14
|
+
}
|
|
15
|
+
const sum = array.reduce((accumulator, currentValue) => {
|
|
16
|
+
return accumulator + currentValue;
|
|
17
|
+
}, 0);
|
|
18
|
+
return sum / array.length;
|
|
19
|
+
}
|
|
20
|
+
export function arrayBufferToUrl(arrayBuffer, mimeType) {
|
|
21
|
+
const blob = new Blob([arrayBuffer], { type: mimeType });
|
|
22
|
+
return URL.createObjectURL(blob);
|
|
23
|
+
}
|
|
24
|
+
export function isAppleDevice() {
|
|
25
|
+
return /Mac|iPod|iPhone|iPad/.test(navigator.platform) ||
|
|
26
|
+
/Mac OS|iOS/.test(navigator.userAgent);
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../stories/utils/index.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,YAAY,CAAC,IAAU,EAAE,QAAgB;IAEvD,MAAM,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAA;IAGrC,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAA;IACrC,CAAC,CAAC,IAAI,GAAG,GAAG,CAAA;IACZ,CAAC,CAAC,QAAQ,GAAG,QAAQ,CAAA;IAGrB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAA;IAC5B,CAAC,CAAC,KAAK,EAAE,CAAA;IAGT,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAA;IAC5B,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,CAAA;AAC1B,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,KAAe;IAEnD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvB,OAAO,CAAC,CAAA;IACV,CAAC;IAGD,MAAM,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;QACrD,OAAO,WAAW,GAAG,YAAY,CAAA;IACnC,CAAC,EAAE,CAAC,CAAC,CAAA;IAGL,OAAO,GAAG,GAAG,KAAK,CAAC,MAAM,CAAA;AAC3B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,WAAwB,EAAE,QAAgB;IACzE,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,WAAW,CAAC,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAA;IACxD,OAAO,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAA;AAClC,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,sBAAsB,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QACpD,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;AAC3C,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { LitElement, PropertyValues } from 'lit';
|
|
2
|
+
import { Scene3D } from './scene';
|
|
3
|
+
export interface Props {
|
|
4
|
+
test: string;
|
|
5
|
+
count: number;
|
|
6
|
+
onChange: () => {};
|
|
7
|
+
}
|
|
8
|
+
export declare class TestViewer extends LitElement {
|
|
9
|
+
scene: Scene3D;
|
|
10
|
+
container: HTMLDivElement | undefined;
|
|
11
|
+
drag: HTMLButtonElement | undefined;
|
|
12
|
+
constructor();
|
|
13
|
+
protected firstUpdated(_changedProperties: PropertyValues): void;
|
|
14
|
+
protected updated(_changedProperties: PropertyValues): void;
|
|
15
|
+
disconnectedCallback(): void;
|
|
16
|
+
test: string;
|
|
17
|
+
count: number;
|
|
18
|
+
theme: undefined | string;
|
|
19
|
+
onChange: undefined | Function;
|
|
20
|
+
usePathTracing: boolean;
|
|
21
|
+
progressBar: HTMLDivElement | undefined;
|
|
22
|
+
cancel: () => void;
|
|
23
|
+
protected render(): unknown;
|
|
24
|
+
static styles: import("lit").CSSResult;
|
|
25
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { TestViewer, Props } from './index';
|
|
2
|
+
declare const _default: {
|
|
3
|
+
title: string;
|
|
4
|
+
tags: string[];
|
|
5
|
+
render: (args: Props) => TestViewer;
|
|
6
|
+
argTypes: {};
|
|
7
|
+
};
|
|
8
|
+
export default _default;
|
|
9
|
+
export declare const Primary: {
|
|
10
|
+
args: {
|
|
11
|
+
test: string;
|
|
12
|
+
count: number;
|
|
13
|
+
};
|
|
14
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { PerspectiveCamera, Scene, WebGLRenderer } from 'three';
|
|
2
|
+
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';
|
|
3
|
+
import { WebGLPathTracer } from 'three-gpu-pathtracer';
|
|
4
|
+
export declare class Scene3D {
|
|
5
|
+
readonly maxSample = 1024;
|
|
6
|
+
sampleCount: number;
|
|
7
|
+
renderer: WebGLRenderer;
|
|
8
|
+
camera: PerspectiveCamera;
|
|
9
|
+
scene: Scene;
|
|
10
|
+
controls: OrbitControls;
|
|
11
|
+
_usePathTracing: boolean;
|
|
12
|
+
pathTracer: WebGLPathTracer;
|
|
13
|
+
usePathTracing: boolean;
|
|
14
|
+
constructor();
|
|
15
|
+
resize: () => void;
|
|
16
|
+
private _loadEnv;
|
|
17
|
+
generateBVH(): void;
|
|
18
|
+
appendTo(parent: any): void;
|
|
19
|
+
ticker: () => void;
|
|
20
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "shop-components",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.26",
|
|
4
4
|
"description": "Shop components",
|
|
5
5
|
"main": "dist/shop-components.umd.js",
|
|
6
6
|
"module": "dist/shop-components.mjs",
|
|
@@ -31,25 +31,28 @@
|
|
|
31
31
|
"react": "^18.2.0",
|
|
32
32
|
"react-dom": "^18.2.0",
|
|
33
33
|
"storybook": "^8.0.6",
|
|
34
|
-
"three": "^0.
|
|
34
|
+
"three": "^0.164.0"
|
|
35
35
|
},
|
|
36
36
|
"resolutions": {
|
|
37
37
|
"string-width": "4.2.3"
|
|
38
38
|
},
|
|
39
39
|
"dependencies": {
|
|
40
|
-
"@types/three": "^0.160.0",
|
|
41
40
|
"@storybook/addon-themes": "^8.0.6",
|
|
42
41
|
"@tweakpane/core": "^2.0.3",
|
|
43
|
-
"@tweenjs/tween.js": "^
|
|
42
|
+
"@tweenjs/tween.js": "^23.1.2",
|
|
43
|
+
"@types/bezier-js": "^4.1.1",
|
|
44
44
|
"@types/howler": "^2.2.11",
|
|
45
|
+
"@types/three": "^0.164.0",
|
|
46
|
+
"bezier-js": "^6.1.4",
|
|
45
47
|
"eventemitter3": "^5.0.1",
|
|
46
48
|
"howler": "^2.2.4",
|
|
47
49
|
"pixi-viewport": "^5.0.2",
|
|
48
50
|
"pixi.js": "^7.4.0",
|
|
49
51
|
"stats-fps.js": "0.0.6",
|
|
50
52
|
"stylus": "^0.63.0",
|
|
51
|
-
"three-gpu-pathtracer": "
|
|
52
|
-
"three-mesh-bvh": "^0.7.
|
|
53
|
+
"three-gpu-pathtracer": "0.0.23",
|
|
54
|
+
"three-mesh-bvh": "^0.7.5",
|
|
55
|
+
"troika-three-text": "^0.49.1",
|
|
53
56
|
"tweakpane": "^4.0.3",
|
|
54
57
|
"vite": "^5.1.6",
|
|
55
58
|
"vite-plugin-dts": "^3.7.3"
|