@stevejtrettel/shader-sandbox 0.1.2 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. package/README.md +259 -235
  2. package/bin/cli.js +106 -14
  3. package/dist-lib/app/App.d.ts +143 -15
  4. package/dist-lib/app/App.d.ts.map +1 -1
  5. package/dist-lib/app/App.js +1343 -108
  6. package/dist-lib/app/app.css +349 -24
  7. package/dist-lib/app/types.d.ts +48 -5
  8. package/dist-lib/app/types.d.ts.map +1 -1
  9. package/dist-lib/editor/EditorPanel.d.ts +2 -2
  10. package/dist-lib/editor/EditorPanel.d.ts.map +1 -1
  11. package/dist-lib/editor/EditorPanel.js +1 -1
  12. package/dist-lib/editor/editor-panel.css +55 -32
  13. package/dist-lib/editor/prism-editor.css +16 -16
  14. package/dist-lib/embed.js +1 -1
  15. package/dist-lib/engine/{ShadertoyEngine.d.ts → ShaderEngine.d.ts} +134 -10
  16. package/dist-lib/engine/ShaderEngine.d.ts.map +1 -0
  17. package/dist-lib/engine/ShaderEngine.js +1523 -0
  18. package/dist-lib/engine/glHelpers.d.ts +24 -0
  19. package/dist-lib/engine/glHelpers.d.ts.map +1 -1
  20. package/dist-lib/engine/glHelpers.js +88 -0
  21. package/dist-lib/engine/std140.d.ts +47 -0
  22. package/dist-lib/engine/std140.d.ts.map +1 -0
  23. package/dist-lib/engine/std140.js +119 -0
  24. package/dist-lib/engine/types.d.ts +55 -5
  25. package/dist-lib/engine/types.d.ts.map +1 -1
  26. package/dist-lib/engine/types.js +1 -1
  27. package/dist-lib/index.d.ts +4 -3
  28. package/dist-lib/index.d.ts.map +1 -1
  29. package/dist-lib/index.js +2 -1
  30. package/dist-lib/layouts/SplitLayout.d.ts +2 -1
  31. package/dist-lib/layouts/SplitLayout.d.ts.map +1 -1
  32. package/dist-lib/layouts/SplitLayout.js +3 -0
  33. package/dist-lib/layouts/TabbedLayout.d.ts.map +1 -1
  34. package/dist-lib/layouts/UILayout.d.ts +55 -0
  35. package/dist-lib/layouts/UILayout.d.ts.map +1 -0
  36. package/dist-lib/layouts/UILayout.js +147 -0
  37. package/dist-lib/layouts/default.css +2 -2
  38. package/dist-lib/layouts/index.d.ts +11 -1
  39. package/dist-lib/layouts/index.d.ts.map +1 -1
  40. package/dist-lib/layouts/index.js +17 -1
  41. package/dist-lib/layouts/split.css +33 -31
  42. package/dist-lib/layouts/tabbed.css +127 -74
  43. package/dist-lib/layouts/types.d.ts +14 -3
  44. package/dist-lib/layouts/types.d.ts.map +1 -1
  45. package/dist-lib/main.js +33 -0
  46. package/dist-lib/project/configHelpers.d.ts +45 -0
  47. package/dist-lib/project/configHelpers.d.ts.map +1 -0
  48. package/dist-lib/project/configHelpers.js +196 -0
  49. package/dist-lib/project/generatedLoader.d.ts +2 -2
  50. package/dist-lib/project/generatedLoader.d.ts.map +1 -1
  51. package/dist-lib/project/generatedLoader.js +23 -5
  52. package/dist-lib/project/loadProject.d.ts +6 -6
  53. package/dist-lib/project/loadProject.d.ts.map +1 -1
  54. package/dist-lib/project/loadProject.js +396 -144
  55. package/dist-lib/project/loaderHelper.d.ts +4 -4
  56. package/dist-lib/project/loaderHelper.d.ts.map +1 -1
  57. package/dist-lib/project/loaderHelper.js +278 -116
  58. package/dist-lib/project/types.d.ts +292 -13
  59. package/dist-lib/project/types.d.ts.map +1 -1
  60. package/dist-lib/project/types.js +13 -1
  61. package/dist-lib/styles/base.css +5 -1
  62. package/dist-lib/uniforms/UniformControls.d.ts +60 -0
  63. package/dist-lib/uniforms/UniformControls.d.ts.map +1 -0
  64. package/dist-lib/uniforms/UniformControls.js +518 -0
  65. package/dist-lib/uniforms/UniformStore.d.ts +74 -0
  66. package/dist-lib/uniforms/UniformStore.d.ts.map +1 -0
  67. package/dist-lib/uniforms/UniformStore.js +145 -0
  68. package/dist-lib/uniforms/UniformsPanel.d.ts +53 -0
  69. package/dist-lib/uniforms/UniformsPanel.d.ts.map +1 -0
  70. package/dist-lib/uniforms/UniformsPanel.js +124 -0
  71. package/dist-lib/uniforms/index.d.ts +11 -0
  72. package/dist-lib/uniforms/index.d.ts.map +1 -0
  73. package/dist-lib/uniforms/index.js +8 -0
  74. package/package.json +16 -1
  75. package/src/app/App.ts +1469 -126
  76. package/src/app/app.css +349 -24
  77. package/src/app/types.ts +53 -5
  78. package/src/editor/EditorPanel.ts +5 -5
  79. package/src/editor/editor-panel.css +55 -32
  80. package/src/editor/prism-editor.css +16 -16
  81. package/src/embed.ts +1 -1
  82. package/src/engine/ShaderEngine.ts +1934 -0
  83. package/src/engine/glHelpers.ts +117 -0
  84. package/src/engine/std140.ts +136 -0
  85. package/src/engine/types.ts +69 -5
  86. package/src/index.ts +4 -3
  87. package/src/layouts/SplitLayout.ts +8 -3
  88. package/src/layouts/TabbedLayout.ts +3 -3
  89. package/src/layouts/UILayout.ts +185 -0
  90. package/src/layouts/default.css +2 -2
  91. package/src/layouts/index.ts +20 -1
  92. package/src/layouts/split.css +33 -31
  93. package/src/layouts/tabbed.css +127 -74
  94. package/src/layouts/types.ts +19 -3
  95. package/src/layouts/ui.css +289 -0
  96. package/src/main.ts +39 -1
  97. package/src/project/configHelpers.ts +225 -0
  98. package/src/project/generatedLoader.ts +27 -6
  99. package/src/project/loadProject.ts +459 -173
  100. package/src/project/loaderHelper.ts +377 -130
  101. package/src/project/types.ts +360 -14
  102. package/src/styles/base.css +5 -1
  103. package/src/styles/theme.css +292 -0
  104. package/src/uniforms/UniformControls.ts +660 -0
  105. package/src/uniforms/UniformStore.ts +166 -0
  106. package/src/uniforms/UniformsPanel.ts +163 -0
  107. package/src/uniforms/index.ts +13 -0
  108. package/src/uniforms/uniform-controls.css +342 -0
  109. package/src/uniforms/uniforms-panel.css +277 -0
  110. package/templates/shaders/example-buffer/config.json +1 -0
  111. package/dist-lib/engine/ShadertoyEngine.d.ts.map +0 -1
  112. package/dist-lib/engine/ShadertoyEngine.js +0 -704
  113. package/src/engine/ShadertoyEngine.ts +0 -929
@@ -0,0 +1,277 @@
1
+ /**
2
+ * Uniforms Panel - Floating overlay styles
3
+ */
4
+
5
+ /* Wrapper positions both toggle button and panel in same location */
6
+ .uniforms-panel-wrapper {
7
+ position: absolute;
8
+ top: 16px;
9
+ right: 16px;
10
+ z-index: 100;
11
+ display: flex;
12
+ flex-direction: column;
13
+ align-items: flex-end;
14
+ }
15
+
16
+ /* Toggle button - uses shared glass variables from app.css */
17
+ .uniforms-toggle-button {
18
+ width: 32px;
19
+ height: 32px;
20
+ padding: 6px;
21
+ background: var(--glass-bg);
22
+ border: var(--glass-border);
23
+ border-radius: var(--glass-radius-sm);
24
+ color: var(--glass-text);
25
+ cursor: pointer;
26
+ backdrop-filter: var(--glass-blur);
27
+ -webkit-backdrop-filter: var(--glass-blur);
28
+ box-shadow: var(--glass-shadow-sm);
29
+ transition: all 0.2s ease, opacity 0.15s ease;
30
+ display: flex;
31
+ align-items: center;
32
+ justify-content: center;
33
+ }
34
+
35
+ .uniforms-toggle-button:hover {
36
+ background: var(--glass-bg-hover);
37
+ transform: scale(1.05);
38
+ }
39
+
40
+ .uniforms-toggle-button:active {
41
+ transform: scale(0.95);
42
+ }
43
+
44
+ .uniforms-toggle-button svg {
45
+ width: 16px;
46
+ height: 16px;
47
+ }
48
+
49
+ /* Hidden state for toggle button when panel is open */
50
+ .uniforms-toggle-button.hidden {
51
+ opacity: 0;
52
+ transform: scale(0.8);
53
+ pointer-events: none;
54
+ position: absolute;
55
+ }
56
+
57
+ /* Panel - uses shared glass variables */
58
+ .uniforms-panel {
59
+ width: 175px;
60
+ max-height: calc(100vh - 100px);
61
+ background: var(--glass-bg);
62
+ backdrop-filter: var(--glass-blur);
63
+ -webkit-backdrop-filter: var(--glass-blur);
64
+ border-radius: var(--glass-radius);
65
+ border: var(--glass-border);
66
+ box-shadow: var(--glass-shadow);
67
+ overflow: hidden;
68
+ display: flex;
69
+ flex-direction: column;
70
+ transform-origin: top right;
71
+ transition: opacity 0.2s ease, transform 0.2s ease, max-height 0.2s ease;
72
+ }
73
+
74
+ /* Closed state - scales down to toggle button size from top-right */
75
+ .uniforms-panel.closed {
76
+ opacity: 0;
77
+ transform: scale(0.18) translateX(0);
78
+ transform-origin: top right;
79
+ pointer-events: none;
80
+ max-height: 0;
81
+ padding: 0;
82
+ }
83
+
84
+ /* Header */
85
+ .uniforms-panel-header {
86
+ padding: 10px 14px;
87
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
88
+ font-size: 11px;
89
+ font-weight: 600;
90
+ text-transform: uppercase;
91
+ letter-spacing: 0.5px;
92
+ color: var(--glass-text-muted);
93
+ background: rgba(255, 255, 255, 0.03);
94
+ border-bottom: 1px solid rgba(255, 255, 255, 0.06);
95
+ flex-shrink: 0;
96
+ display: flex;
97
+ justify-content: space-between;
98
+ align-items: center;
99
+ }
100
+
101
+ /* Close button in header */
102
+ .uniforms-panel-close {
103
+ background: transparent;
104
+ border: none;
105
+ color: var(--glass-text-muted);
106
+ font-size: 18px;
107
+ line-height: 1;
108
+ cursor: pointer;
109
+ padding: 0;
110
+ width: 20px;
111
+ height: 20px;
112
+ display: flex;
113
+ align-items: center;
114
+ justify-content: center;
115
+ border-radius: 4px;
116
+ transition: all 0.15s ease;
117
+ }
118
+
119
+ .uniforms-panel-close:hover {
120
+ background: rgba(255, 255, 255, 0.1);
121
+ color: var(--glass-text);
122
+ }
123
+
124
+ /* Content area */
125
+ .uniforms-panel-content {
126
+ flex: 1;
127
+ overflow-y: auto;
128
+ overflow-x: hidden;
129
+ }
130
+
131
+ /* Override uniform controls styles for compact glass panel */
132
+ .uniforms-panel .uniform-controls {
133
+ padding: 12px;
134
+ gap: 12px;
135
+ background: transparent;
136
+ }
137
+
138
+ .uniforms-panel .uniform-controls-header {
139
+ display: none; /* Hide the reset button header in compact mode */
140
+ }
141
+
142
+ .uniforms-panel .uniform-controls-list {
143
+ gap: 14px;
144
+ }
145
+
146
+ .uniforms-panel .uniform-control {
147
+ gap: 6px;
148
+ }
149
+
150
+ .uniforms-panel .uniform-control-label {
151
+ font-size: 11px;
152
+ color: var(--glass-text);
153
+ }
154
+
155
+ .uniforms-panel .uniform-control-value {
156
+ font-size: 10px;
157
+ padding: 1px 4px;
158
+ min-width: 40px;
159
+ color: var(--glass-text-muted);
160
+ background: rgba(0, 0, 0, 0.2);
161
+ border-radius: 3px;
162
+ }
163
+
164
+ /* Compact slider - glass style */
165
+ .uniforms-panel .uniform-control-slider {
166
+ height: 4px;
167
+ background: rgba(255, 255, 255, 0.15);
168
+ }
169
+
170
+ .uniforms-panel .uniform-control-slider::-webkit-slider-runnable-track {
171
+ height: 4px;
172
+ background: rgba(255, 255, 255, 0.15);
173
+ }
174
+
175
+ .uniforms-panel .uniform-control-slider::-webkit-slider-thumb {
176
+ width: 12px;
177
+ height: 12px;
178
+ margin-top: -4px;
179
+ background: rgba(255, 255, 255, 0.9);
180
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
181
+ }
182
+
183
+ .uniforms-panel .uniform-control-slider::-moz-range-track {
184
+ height: 4px;
185
+ background: rgba(255, 255, 255, 0.15);
186
+ }
187
+
188
+ .uniforms-panel .uniform-control-slider::-moz-range-thumb {
189
+ width: 12px;
190
+ height: 12px;
191
+ background: rgba(255, 255, 255, 0.9);
192
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
193
+ }
194
+
195
+ /* Compact toggle */
196
+ .uniforms-panel .uniform-control-toggle {
197
+ width: 34px;
198
+ height: 18px;
199
+ }
200
+
201
+ .uniforms-panel .uniform-control-toggle-slider {
202
+ border-radius: 18px;
203
+ }
204
+
205
+ .uniforms-panel .uniform-control-toggle-slider::before {
206
+ width: 12px;
207
+ height: 12px;
208
+ left: 3px;
209
+ bottom: 3px;
210
+ }
211
+
212
+ .uniforms-panel .uniform-control-toggle input:checked + .uniform-control-toggle-slider::before {
213
+ transform: translateX(16px);
214
+ }
215
+
216
+ /* Compact XY pad */
217
+ .uniforms-panel .uniform-control-xy-pad {
218
+ height: 100px;
219
+ }
220
+
221
+ .uniforms-panel .uniform-control-xy-handle {
222
+ width: 12px;
223
+ height: 12px;
224
+ }
225
+
226
+ /* Compact color swatch */
227
+ .uniforms-panel .uniform-control-color-swatch {
228
+ height: 28px;
229
+ }
230
+
231
+ /* Compact vec3 sliders - glass style */
232
+ .uniforms-panel .uniform-control-vec-slider-row {
233
+ gap: 6px;
234
+ }
235
+
236
+ .uniforms-panel .uniform-control-vec-component {
237
+ font-size: 9px;
238
+ width: 12px;
239
+ color: var(--glass-text-muted);
240
+ }
241
+
242
+ .uniforms-panel .uniform-control-vec-value {
243
+ font-size: 9px;
244
+ min-width: 32px;
245
+ color: var(--glass-text-muted);
246
+ background: rgba(0, 0, 0, 0.2);
247
+ border-radius: 3px;
248
+ }
249
+
250
+ /* XY pad glass style */
251
+ .uniforms-panel .uniform-control-xy-pad {
252
+ background: rgba(0, 0, 0, 0.25);
253
+ border: 1px solid rgba(255, 255, 255, 0.1);
254
+ }
255
+
256
+ .uniforms-panel .uniform-control-xy-handle {
257
+ background: rgba(255, 255, 255, 0.9);
258
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
259
+ }
260
+
261
+ /* Scrollbar styling for glass panel */
262
+ .uniforms-panel-content::-webkit-scrollbar {
263
+ width: 6px;
264
+ }
265
+
266
+ .uniforms-panel-content::-webkit-scrollbar-track {
267
+ background: transparent;
268
+ }
269
+
270
+ .uniforms-panel-content::-webkit-scrollbar-thumb {
271
+ background: rgba(255, 255, 255, 0.2);
272
+ border-radius: 3px;
273
+ }
274
+
275
+ .uniforms-panel-content::-webkit-scrollbar-thumb:hover {
276
+ background: rgba(255, 255, 255, 0.35);
277
+ }
@@ -1,4 +1,5 @@
1
1
  {
2
+ "mode": "shadertoy",
2
3
  "layout": "default",
3
4
  "controls": true,
4
5
  "Image": {
@@ -1 +0,0 @@
1
- {"version":3,"file":"ShadertoyEngine.d.ts","sourceRoot":"","sources":["../../src/engine/ShadertoyEngine.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EACL,gBAAgB,EAEhB,QAAQ,EACT,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EACL,aAAa,EAIb,WAAW,EAEZ,MAAM,SAAS,CAAC;AAkDjB,qBAAa,eAAe;IAC1B,QAAQ,CAAC,OAAO,EAAE,gBAAgB,CAAC;IACnC,QAAQ,CAAC,EAAE,EAAE,sBAAsB,CAAC;IAEpC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;IAExB,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,KAAK,CAAa;IAC1B,OAAO,CAAC,aAAa,CAAuB;IAE5C,OAAO,CAAC,OAAO,CAAqB;IACpC,OAAO,CAAC,SAAS,CAA0B;IAC3C,OAAO,CAAC,gBAAgB,CAAuC;IAE/D,OAAO,CAAC,aAAa,CAA6B;IAGlD,OAAO,CAAC,UAAU,CAAmC;IACrD,OAAO,CAAC,aAAa,CAAkC;IAGvD,OAAO,CAAC,kBAAkB,CAMlB;gBAEI,IAAI,EAAE,aAAa;IAmC/B,IAAI,KAAK,IAAI,MAAM,CAElB;IAED,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,IAAI,KAAK,IAAI,WAAW,CASvB;IAED;;;OAGG;IACH,oBAAoB,IAAI,KAAK,CAAC;QAC5B,QAAQ,EAAE,QAAQ,CAAC;QACnB,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,MAAM,CAAC;QACf,YAAY,EAAE,OAAO,CAAC;QACtB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;KAC7B,CAAC;IAIF;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,mBAAmB,IAAI,gBAAgB,GAAG,IAAI;IAK9C;;;;;OAKG;IACH,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI;IAyCxE;;;OAGG;IACH,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAsB3C;;;OAGG;IACH,KAAK,IAAI,IAAI;IAkCb;;;;;OAKG;IACH,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,IAAI;IAatD;;;OAGG;IACH,qBAAqB,IAAI,IAAI;IAa7B;;;;;;;OAOG;IACH,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE;IAyD1F;;;;;;OAMG;IACH,eAAe,CAAC,eAAe,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,KAAK,CAAC;YAAE,QAAQ,EAAE,QAAQ,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,CAAC,CAAA;KAAE;IA0CpH;;OAEG;IACH,OAAO,IAAI,IAAI;IAsCf,OAAO,CAAC,cAAc;IAgBtB;;;;;;OAMG;IACH,OAAO,CAAC,mBAAmB;IA4D3B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IA0FzB;;;OAGG;IACH,OAAO,CAAC,cAAc;IAWtB;;;;;OAKG;IACH,OAAO,CAAC,mBAAmB;IA0C3B;;;;;;;;;OASG;IACH,OAAO,CAAC,yBAAyB;IA+BjC,OAAO,CAAC,WAAW;IAoCnB,OAAO,CAAC,mBAAmB;IAiC3B,OAAO,CAAC,mBAAmB;IAmB3B;;OAEG;IACH,OAAO,CAAC,qBAAqB;IA4C7B;;;OAGG;IACH,OAAO,CAAC,gBAAgB;CAmBzB"}