create-microact-app 1.0.1

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 (213) hide show
  1. package/index.js +95 -0
  2. package/package.json +21 -0
  3. package/templates/vanilla/.github/workflows/deploy.yml +38 -0
  4. package/templates/vanilla/index.html +13 -0
  5. package/templates/vanilla/node_modules/.package-lock.json +207 -0
  6. package/templates/vanilla/node_modules/@esbuild/darwin-x64/README.md +3 -0
  7. package/templates/vanilla/node_modules/@esbuild/darwin-x64/bin/esbuild +0 -0
  8. package/templates/vanilla/node_modules/@esbuild/darwin-x64/package.json +17 -0
  9. package/templates/vanilla/node_modules/@monygroupcorp/microact/README.md +154 -0
  10. package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.cjs.js +1749 -0
  11. package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.cjs.js.map +1 -0
  12. package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.esm.js +1743 -0
  13. package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.esm.js.map +1 -0
  14. package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.umd.js +2 -0
  15. package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.umd.js.map +1 -0
  16. package/templates/vanilla/node_modules/@monygroupcorp/microact/example/index.html +13 -0
  17. package/templates/vanilla/node_modules/@monygroupcorp/microact/example/index.js +63 -0
  18. package/templates/vanilla/node_modules/@monygroupcorp/microact/package.json +38 -0
  19. package/templates/vanilla/node_modules/@monygroupcorp/microact/rollup.config.cjs +30 -0
  20. package/templates/vanilla/node_modules/@monygroupcorp/microact/src/Component.js +831 -0
  21. package/templates/vanilla/node_modules/@monygroupcorp/microact/src/DOMUpdater.js +320 -0
  22. package/templates/vanilla/node_modules/@monygroupcorp/microact/src/EventBus.js +123 -0
  23. package/templates/vanilla/node_modules/@monygroupcorp/microact/src/Router.js +253 -0
  24. package/templates/vanilla/node_modules/@monygroupcorp/microact/src/UpdateScheduler.js +218 -0
  25. package/templates/vanilla/node_modules/@monygroupcorp/microact/src/index.js +6 -0
  26. package/templates/vanilla/node_modules/esbuild/LICENSE.md +21 -0
  27. package/templates/vanilla/node_modules/esbuild/README.md +3 -0
  28. package/templates/vanilla/node_modules/esbuild/bin/esbuild +0 -0
  29. package/templates/vanilla/node_modules/esbuild/install.js +287 -0
  30. package/templates/vanilla/node_modules/esbuild/lib/main.d.ts +660 -0
  31. package/templates/vanilla/node_modules/esbuild/lib/main.js +2393 -0
  32. package/templates/vanilla/node_modules/esbuild/package.json +42 -0
  33. package/templates/vanilla/node_modules/nanoid/LICENSE +20 -0
  34. package/templates/vanilla/node_modules/nanoid/README.md +39 -0
  35. package/templates/vanilla/node_modules/nanoid/async/index.browser.cjs +69 -0
  36. package/templates/vanilla/node_modules/nanoid/async/index.browser.js +34 -0
  37. package/templates/vanilla/node_modules/nanoid/async/index.cjs +71 -0
  38. package/templates/vanilla/node_modules/nanoid/async/index.d.ts +56 -0
  39. package/templates/vanilla/node_modules/nanoid/async/index.js +35 -0
  40. package/templates/vanilla/node_modules/nanoid/async/index.native.js +26 -0
  41. package/templates/vanilla/node_modules/nanoid/async/package.json +12 -0
  42. package/templates/vanilla/node_modules/nanoid/bin/nanoid.cjs +55 -0
  43. package/templates/vanilla/node_modules/nanoid/index.browser.cjs +72 -0
  44. package/templates/vanilla/node_modules/nanoid/index.browser.js +34 -0
  45. package/templates/vanilla/node_modules/nanoid/index.cjs +85 -0
  46. package/templates/vanilla/node_modules/nanoid/index.d.cts +91 -0
  47. package/templates/vanilla/node_modules/nanoid/index.d.ts +91 -0
  48. package/templates/vanilla/node_modules/nanoid/index.js +45 -0
  49. package/templates/vanilla/node_modules/nanoid/nanoid.js +1 -0
  50. package/templates/vanilla/node_modules/nanoid/non-secure/index.cjs +34 -0
  51. package/templates/vanilla/node_modules/nanoid/non-secure/index.d.ts +33 -0
  52. package/templates/vanilla/node_modules/nanoid/non-secure/index.js +21 -0
  53. package/templates/vanilla/node_modules/nanoid/non-secure/package.json +6 -0
  54. package/templates/vanilla/node_modules/nanoid/package.json +89 -0
  55. package/templates/vanilla/node_modules/nanoid/url-alphabet/index.cjs +7 -0
  56. package/templates/vanilla/node_modules/nanoid/url-alphabet/index.js +3 -0
  57. package/templates/vanilla/node_modules/nanoid/url-alphabet/package.json +6 -0
  58. package/templates/vanilla/node_modules/picocolors/LICENSE +15 -0
  59. package/templates/vanilla/node_modules/picocolors/README.md +21 -0
  60. package/templates/vanilla/node_modules/picocolors/package.json +25 -0
  61. package/templates/vanilla/node_modules/picocolors/picocolors.browser.js +4 -0
  62. package/templates/vanilla/node_modules/picocolors/picocolors.d.ts +5 -0
  63. package/templates/vanilla/node_modules/picocolors/picocolors.js +75 -0
  64. package/templates/vanilla/node_modules/picocolors/types.d.ts +51 -0
  65. package/templates/vanilla/node_modules/postcss/LICENSE +20 -0
  66. package/templates/vanilla/node_modules/postcss/README.md +29 -0
  67. package/templates/vanilla/node_modules/postcss/lib/at-rule.d.ts +140 -0
  68. package/templates/vanilla/node_modules/postcss/lib/at-rule.js +25 -0
  69. package/templates/vanilla/node_modules/postcss/lib/comment.d.ts +68 -0
  70. package/templates/vanilla/node_modules/postcss/lib/comment.js +13 -0
  71. package/templates/vanilla/node_modules/postcss/lib/container.d.ts +483 -0
  72. package/templates/vanilla/node_modules/postcss/lib/container.js +447 -0
  73. package/templates/vanilla/node_modules/postcss/lib/css-syntax-error.d.ts +248 -0
  74. package/templates/vanilla/node_modules/postcss/lib/css-syntax-error.js +133 -0
  75. package/templates/vanilla/node_modules/postcss/lib/declaration.d.ts +151 -0
  76. package/templates/vanilla/node_modules/postcss/lib/declaration.js +24 -0
  77. package/templates/vanilla/node_modules/postcss/lib/document.d.ts +69 -0
  78. package/templates/vanilla/node_modules/postcss/lib/document.js +33 -0
  79. package/templates/vanilla/node_modules/postcss/lib/fromJSON.d.ts +9 -0
  80. package/templates/vanilla/node_modules/postcss/lib/fromJSON.js +54 -0
  81. package/templates/vanilla/node_modules/postcss/lib/input.d.ts +227 -0
  82. package/templates/vanilla/node_modules/postcss/lib/input.js +265 -0
  83. package/templates/vanilla/node_modules/postcss/lib/lazy-result.d.ts +190 -0
  84. package/templates/vanilla/node_modules/postcss/lib/lazy-result.js +550 -0
  85. package/templates/vanilla/node_modules/postcss/lib/list.d.ts +60 -0
  86. package/templates/vanilla/node_modules/postcss/lib/list.js +58 -0
  87. package/templates/vanilla/node_modules/postcss/lib/map-generator.js +368 -0
  88. package/templates/vanilla/node_modules/postcss/lib/no-work-result.d.ts +46 -0
  89. package/templates/vanilla/node_modules/postcss/lib/no-work-result.js +138 -0
  90. package/templates/vanilla/node_modules/postcss/lib/node.d.ts +556 -0
  91. package/templates/vanilla/node_modules/postcss/lib/node.js +449 -0
  92. package/templates/vanilla/node_modules/postcss/lib/parse.d.ts +9 -0
  93. package/templates/vanilla/node_modules/postcss/lib/parse.js +42 -0
  94. package/templates/vanilla/node_modules/postcss/lib/parser.js +611 -0
  95. package/templates/vanilla/node_modules/postcss/lib/postcss.d.mts +69 -0
  96. package/templates/vanilla/node_modules/postcss/lib/postcss.d.ts +458 -0
  97. package/templates/vanilla/node_modules/postcss/lib/postcss.js +101 -0
  98. package/templates/vanilla/node_modules/postcss/lib/postcss.mjs +30 -0
  99. package/templates/vanilla/node_modules/postcss/lib/previous-map.d.ts +81 -0
  100. package/templates/vanilla/node_modules/postcss/lib/previous-map.js +144 -0
  101. package/templates/vanilla/node_modules/postcss/lib/processor.d.ts +115 -0
  102. package/templates/vanilla/node_modules/postcss/lib/processor.js +67 -0
  103. package/templates/vanilla/node_modules/postcss/lib/result.d.ts +205 -0
  104. package/templates/vanilla/node_modules/postcss/lib/result.js +42 -0
  105. package/templates/vanilla/node_modules/postcss/lib/root.d.ts +87 -0
  106. package/templates/vanilla/node_modules/postcss/lib/root.js +61 -0
  107. package/templates/vanilla/node_modules/postcss/lib/rule.d.ts +126 -0
  108. package/templates/vanilla/node_modules/postcss/lib/rule.js +27 -0
  109. package/templates/vanilla/node_modules/postcss/lib/stringifier.d.ts +46 -0
  110. package/templates/vanilla/node_modules/postcss/lib/stringifier.js +353 -0
  111. package/templates/vanilla/node_modules/postcss/lib/stringify.d.ts +9 -0
  112. package/templates/vanilla/node_modules/postcss/lib/stringify.js +11 -0
  113. package/templates/vanilla/node_modules/postcss/lib/symbols.js +5 -0
  114. package/templates/vanilla/node_modules/postcss/lib/terminal-highlight.js +70 -0
  115. package/templates/vanilla/node_modules/postcss/lib/tokenize.js +266 -0
  116. package/templates/vanilla/node_modules/postcss/lib/warn-once.js +13 -0
  117. package/templates/vanilla/node_modules/postcss/lib/warning.d.ts +147 -0
  118. package/templates/vanilla/node_modules/postcss/lib/warning.js +37 -0
  119. package/templates/vanilla/node_modules/postcss/package.json +88 -0
  120. package/templates/vanilla/node_modules/rollup/LICENSE.md +695 -0
  121. package/templates/vanilla/node_modules/rollup/README.md +125 -0
  122. package/templates/vanilla/node_modules/rollup/dist/bin/rollup +1715 -0
  123. package/templates/vanilla/node_modules/rollup/dist/es/getLogFilter.js +64 -0
  124. package/templates/vanilla/node_modules/rollup/dist/es/package.json +1 -0
  125. package/templates/vanilla/node_modules/rollup/dist/es/rollup.js +17 -0
  126. package/templates/vanilla/node_modules/rollup/dist/es/shared/node-entry.js +27273 -0
  127. package/templates/vanilla/node_modules/rollup/dist/es/shared/watch.js +4857 -0
  128. package/templates/vanilla/node_modules/rollup/dist/getLogFilter.d.ts +5 -0
  129. package/templates/vanilla/node_modules/rollup/dist/getLogFilter.js +69 -0
  130. package/templates/vanilla/node_modules/rollup/dist/loadConfigFile.d.ts +20 -0
  131. package/templates/vanilla/node_modules/rollup/dist/loadConfigFile.js +29 -0
  132. package/templates/vanilla/node_modules/rollup/dist/rollup.d.ts +1012 -0
  133. package/templates/vanilla/node_modules/rollup/dist/rollup.js +31 -0
  134. package/templates/vanilla/node_modules/rollup/dist/shared/fsevents-importer.js +37 -0
  135. package/templates/vanilla/node_modules/rollup/dist/shared/index.js +4571 -0
  136. package/templates/vanilla/node_modules/rollup/dist/shared/loadConfigFile.js +546 -0
  137. package/templates/vanilla/node_modules/rollup/dist/shared/rollup.js +27351 -0
  138. package/templates/vanilla/node_modules/rollup/dist/shared/watch-cli.js +561 -0
  139. package/templates/vanilla/node_modules/rollup/dist/shared/watch-proxy.js +87 -0
  140. package/templates/vanilla/node_modules/rollup/dist/shared/watch.js +316 -0
  141. package/templates/vanilla/node_modules/rollup/package.json +181 -0
  142. package/templates/vanilla/node_modules/source-map-js/LICENSE +28 -0
  143. package/templates/vanilla/node_modules/source-map-js/README.md +765 -0
  144. package/templates/vanilla/node_modules/source-map-js/lib/array-set.js +121 -0
  145. package/templates/vanilla/node_modules/source-map-js/lib/base64-vlq.js +140 -0
  146. package/templates/vanilla/node_modules/source-map-js/lib/base64.js +67 -0
  147. package/templates/vanilla/node_modules/source-map-js/lib/binary-search.js +111 -0
  148. package/templates/vanilla/node_modules/source-map-js/lib/mapping-list.js +79 -0
  149. package/templates/vanilla/node_modules/source-map-js/lib/quick-sort.js +132 -0
  150. package/templates/vanilla/node_modules/source-map-js/lib/source-map-consumer.d.ts +1 -0
  151. package/templates/vanilla/node_modules/source-map-js/lib/source-map-consumer.js +1188 -0
  152. package/templates/vanilla/node_modules/source-map-js/lib/source-map-generator.d.ts +1 -0
  153. package/templates/vanilla/node_modules/source-map-js/lib/source-map-generator.js +444 -0
  154. package/templates/vanilla/node_modules/source-map-js/lib/source-node.d.ts +1 -0
  155. package/templates/vanilla/node_modules/source-map-js/lib/source-node.js +413 -0
  156. package/templates/vanilla/node_modules/source-map-js/lib/util.js +594 -0
  157. package/templates/vanilla/node_modules/source-map-js/package.json +71 -0
  158. package/templates/vanilla/node_modules/source-map-js/source-map.d.ts +104 -0
  159. package/templates/vanilla/node_modules/source-map-js/source-map.js +8 -0
  160. package/templates/vanilla/node_modules/vite/LICENSE.md +3396 -0
  161. package/templates/vanilla/node_modules/vite/README.md +20 -0
  162. package/templates/vanilla/node_modules/vite/bin/openChrome.applescript +95 -0
  163. package/templates/vanilla/node_modules/vite/bin/vite.js +61 -0
  164. package/templates/vanilla/node_modules/vite/client.d.ts +281 -0
  165. package/templates/vanilla/node_modules/vite/dist/client/client.mjs +725 -0
  166. package/templates/vanilla/node_modules/vite/dist/client/client.mjs.map +1 -0
  167. package/templates/vanilla/node_modules/vite/dist/client/env.mjs +30 -0
  168. package/templates/vanilla/node_modules/vite/dist/client/env.mjs.map +1 -0
  169. package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-7ec6f216.js +914 -0
  170. package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-827b23df.js +66713 -0
  171. package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-c423598f.js +561 -0
  172. package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-f0c7dae0.js +7930 -0
  173. package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-f1e8587f.js +7646 -0
  174. package/templates/vanilla/node_modules/vite/dist/node/cli.js +929 -0
  175. package/templates/vanilla/node_modules/vite/dist/node/constants.js +130 -0
  176. package/templates/vanilla/node_modules/vite/dist/node/index.d.ts +3548 -0
  177. package/templates/vanilla/node_modules/vite/dist/node/index.js +158 -0
  178. package/templates/vanilla/node_modules/vite/dist/node-cjs/publicUtils.cjs +4555 -0
  179. package/templates/vanilla/node_modules/vite/index.cjs +34 -0
  180. package/templates/vanilla/node_modules/vite/package.json +173 -0
  181. package/templates/vanilla/node_modules/vite/types/customEvent.d.ts +35 -0
  182. package/templates/vanilla/node_modules/vite/types/hmrPayload.d.ts +61 -0
  183. package/templates/vanilla/node_modules/vite/types/hot.d.ts +32 -0
  184. package/templates/vanilla/node_modules/vite/types/importGlob.d.ts +97 -0
  185. package/templates/vanilla/node_modules/vite/types/importMeta.d.ts +26 -0
  186. package/templates/vanilla/node_modules/vite/types/metadata.d.ts +10 -0
  187. package/templates/vanilla/node_modules/vite/types/package.json +4 -0
  188. package/templates/vanilla/package-lock.json +589 -0
  189. package/templates/vanilla/package.json +17 -0
  190. package/templates/vanilla/src/components/App.js +60 -0
  191. package/templates/vanilla/src/components/Card.js +21 -0
  192. package/templates/vanilla/src/components/Hero.js +15 -0
  193. package/templates/vanilla/src/components/InteractiveDemo.js +59 -0
  194. package/templates/vanilla/src/main.js +9 -0
  195. package/templates/vanilla/src/style/main.css +172 -0
  196. package/templates/vanilla/vite.config.js +8 -0
  197. package/templates/web3/.env.example +15 -0
  198. package/templates/web3/.github/workflows/deploy.yml +38 -0
  199. package/templates/web3/README.md +33 -0
  200. package/templates/web3/contracts/foundry.toml +11 -0
  201. package/templates/web3/contracts/script/Deploy.s.sol +13 -0
  202. package/templates/web3/contracts/src/Counter.sol +21 -0
  203. package/templates/web3/index.html +13 -0
  204. package/templates/web3/package.json +25 -0
  205. package/templates/web3/scripts/chain-start.mjs +305 -0
  206. package/templates/web3/scripts/chain-stop.mjs +34 -0
  207. package/templates/web3/scripts/deploy.mjs +155 -0
  208. package/templates/web3/scripts/setup.mjs +42 -0
  209. package/templates/web3/src/components/App.js +49 -0
  210. package/templates/web3/src/components/CounterCard.js +111 -0
  211. package/templates/web3/src/main.js +54 -0
  212. package/templates/web3/src/style/main.css +345 -0
  213. package/templates/web3/vite.config.js +29 -0
@@ -0,0 +1,218 @@
1
+ /**
2
+ * UpdateScheduler - Coordinates component updates using requestAnimationFrame batching
3
+ *
4
+ * Prevents UI blocking by batching multiple component updates into a single frame.
5
+ * Components can opt-in to batching for non-critical updates, while critical updates
6
+ * (user input, errors) can execute immediately.
7
+ *
8
+ * Usage:
9
+ * // In Component.js
10
+ * this.scheduleUpdate(); // Batched (default)
11
+ * this.scheduleUpdate({ immediate: true }); // Immediate
12
+ */
13
+ export class UpdateScheduler {
14
+ constructor() {
15
+ // Queue of components waiting to be updated
16
+ this._queue = new Set();
17
+
18
+ // Flag to track if requestAnimationFrame is already scheduled
19
+ this._scheduled = false;
20
+
21
+ // Performance metrics (only tracked in dev mode)
22
+ this._metrics = {
23
+ frames: 0,
24
+ updates: 0,
25
+ maxFrameTime: 0,
26
+ totalFrameTime: 0,
27
+ maxUpdatesPerFrame: 0
28
+ };
29
+
30
+ // Dev mode flag (can be enabled for performance monitoring)
31
+ this._devMode = false;
32
+
33
+ // Track if scheduler is enabled (can be disabled for debugging)
34
+ this._enabled = true;
35
+ }
36
+
37
+ /**
38
+ * Get singleton instance
39
+ * @returns {UpdateScheduler}
40
+ */
41
+ static getInstance() {
42
+ if (!UpdateScheduler._instance) {
43
+ UpdateScheduler._instance = new UpdateScheduler();
44
+ }
45
+ return UpdateScheduler._instance;
46
+ }
47
+
48
+ /**
49
+ * Enable or disable dev mode (performance tracking)
50
+ * @param {boolean} enabled
51
+ */
52
+ setDevMode(enabled) {
53
+ this._devMode = enabled;
54
+ }
55
+
56
+ /**
57
+ * Enable or disable the scheduler (for debugging)
58
+ * @param {boolean} enabled
59
+ */
60
+ setEnabled(enabled) {
61
+ this._enabled = enabled;
62
+ if (!enabled && this._scheduled) {
63
+ // Cancel pending frame if disabling
64
+ this._queue.clear();
65
+ this._scheduled = false;
66
+ }
67
+ }
68
+
69
+ /**
70
+ * Queue a component for batched update
71
+ * @param {Component} component - Component instance to update
72
+ */
73
+ queue(component) {
74
+ if (!this._enabled) {
75
+ // If scheduler is disabled, execute immediately
76
+ try {
77
+ component.update();
78
+ } catch (error) {
79
+ console.error('[UpdateScheduler] Error updating component (immediate):', error);
80
+ }
81
+ return;
82
+ }
83
+
84
+ if (!component || typeof component.update !== 'function') {
85
+ console.warn('[UpdateScheduler] Invalid component queued:', component);
86
+ return;
87
+ }
88
+
89
+ // Add to queue (Set automatically deduplicates)
90
+ this._queue.add(component);
91
+
92
+ // Schedule flush if not already scheduled
93
+ if (!this._scheduled) {
94
+ this._scheduled = true;
95
+ requestAnimationFrame(() => this._flush());
96
+ }
97
+ }
98
+
99
+ /**
100
+ * Execute all queued updates in a single frame
101
+ * @private
102
+ */
103
+ _flush() {
104
+ if (this._queue.size === 0) {
105
+ this._scheduled = false;
106
+ return;
107
+ }
108
+
109
+ const start = performance.now();
110
+ const updates = Array.from(this._queue);
111
+ const updateCount = updates.length;
112
+
113
+ // Clear queue and reset scheduled flag
114
+ this._queue.clear();
115
+ this._scheduled = false;
116
+
117
+ // Execute all updates
118
+ updates.forEach(component => {
119
+ try {
120
+ // Check if component is still mounted/valid before updating
121
+ if (component && component.element && typeof component.update === 'function') {
122
+ component.update();
123
+ }
124
+ } catch (error) {
125
+ // Log error but continue with other updates
126
+ console.error('[UpdateScheduler] Error updating component:', error);
127
+ console.error('[UpdateScheduler] Component:', component);
128
+ }
129
+ });
130
+
131
+ const duration = performance.now() - start;
132
+
133
+ // Track metrics in dev mode
134
+ if (this._devMode) {
135
+ this._metrics.frames++;
136
+ this._metrics.updates += updateCount;
137
+ this._metrics.totalFrameTime += duration;
138
+ this._metrics.maxFrameTime = Math.max(this._metrics.maxFrameTime, duration);
139
+ this._metrics.maxUpdatesPerFrame = Math.max(this._metrics.maxUpdatesPerFrame, updateCount);
140
+
141
+ // Warn if frame took too long (>16ms for 60fps)
142
+ if (duration > 16) {
143
+ console.warn(
144
+ `[UpdateScheduler] Frame took ${duration.toFixed(2)}ms (>16ms target). ` +
145
+ `Updated ${updateCount} component(s).`
146
+ );
147
+ }
148
+ }
149
+
150
+ // Handle nested updates (components that schedule updates during their update)
151
+ // If new updates were queued during this flush, schedule another frame
152
+ if (this._queue.size > 0) {
153
+ this._scheduled = true;
154
+ requestAnimationFrame(() => this._flush());
155
+ }
156
+ }
157
+
158
+ /**
159
+ * Get performance metrics
160
+ * @returns {Object} Metrics object
161
+ */
162
+ getMetrics() {
163
+ if (!this._devMode) {
164
+ return { enabled: false };
165
+ }
166
+
167
+ const avgFrameTime = this._metrics.frames > 0
168
+ ? this._metrics.totalFrameTime / this._metrics.frames
169
+ : 0;
170
+
171
+ const avgUpdatesPerFrame = this._metrics.frames > 0
172
+ ? this._metrics.updates / this._metrics.frames
173
+ : 0;
174
+
175
+ return {
176
+ enabled: true,
177
+ frames: this._metrics.frames,
178
+ totalUpdates: this._metrics.updates,
179
+ maxFrameTime: this._metrics.maxFrameTime,
180
+ avgFrameTime: avgFrameTime,
181
+ maxUpdatesPerFrame: this._metrics.maxUpdatesPerFrame,
182
+ avgUpdatesPerFrame: avgUpdatesPerFrame
183
+ };
184
+ }
185
+
186
+ /**
187
+ * Reset performance metrics
188
+ */
189
+ resetMetrics() {
190
+ this._metrics = {
191
+ frames: 0,
192
+ updates: 0,
193
+ maxFrameTime: 0,
194
+ totalFrameTime: 0,
195
+ maxUpdatesPerFrame: 0
196
+ };
197
+ }
198
+
199
+ /**
200
+ * Clear the update queue (useful for cleanup or testing)
201
+ */
202
+ clear() {
203
+ this._queue.clear();
204
+ this._scheduled = false;
205
+ }
206
+
207
+ /**
208
+ * Get current queue size (for debugging)
209
+ * @returns {number}
210
+ */
211
+ getQueueSize() {
212
+ return this._queue.size;
213
+ }
214
+ }
215
+
216
+ // Export singleton instance getter
217
+ export const getUpdateScheduler = () => UpdateScheduler.getInstance();
218
+
@@ -0,0 +1,6 @@
1
+ // microact/src/index.js
2
+ export { Component } from './Component.js';
3
+ export { eventBus } from './EventBus.js';
4
+ export { default as Router } from './Router.js'; // Router is default export
5
+ export { getUpdateScheduler } from './UpdateScheduler.js';
6
+ export { DOMUpdater } from './DOMUpdater.js';
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2020 Evan Wallace
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,3 @@
1
+ # esbuild
2
+
3
+ This is a JavaScript bundler and minifier. See https://github.com/evanw/esbuild and the [JavaScript API documentation](https://esbuild.github.io/api/) for details.
@@ -0,0 +1,287 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from === "object" || typeof from === "function") {
10
+ for (let key of __getOwnPropNames(from))
11
+ if (!__hasOwnProp.call(to, key) && key !== except)
12
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
13
+ }
14
+ return to;
15
+ };
16
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
17
+ // If the importer is in node compatibility mode or this is not an ESM
18
+ // file that has been converted to a CommonJS file using a Babel-
19
+ // compatible transform (i.e. "__esModule" has not been set), then set
20
+ // "default" to the CommonJS "module.exports" for node compatibility.
21
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
22
+ mod
23
+ ));
24
+
25
+ // lib/npm/node-platform.ts
26
+ var fs = require("fs");
27
+ var os = require("os");
28
+ var path = require("path");
29
+ var ESBUILD_BINARY_PATH = process.env.ESBUILD_BINARY_PATH || ESBUILD_BINARY_PATH;
30
+ var isValidBinaryPath = (x) => !!x && x !== "/usr/bin/esbuild";
31
+ var knownWindowsPackages = {
32
+ "win32 arm64 LE": "@esbuild/win32-arm64",
33
+ "win32 ia32 LE": "@esbuild/win32-ia32",
34
+ "win32 x64 LE": "@esbuild/win32-x64"
35
+ };
36
+ var knownUnixlikePackages = {
37
+ "android arm64 LE": "@esbuild/android-arm64",
38
+ "darwin arm64 LE": "@esbuild/darwin-arm64",
39
+ "darwin x64 LE": "@esbuild/darwin-x64",
40
+ "freebsd arm64 LE": "@esbuild/freebsd-arm64",
41
+ "freebsd x64 LE": "@esbuild/freebsd-x64",
42
+ "linux arm LE": "@esbuild/linux-arm",
43
+ "linux arm64 LE": "@esbuild/linux-arm64",
44
+ "linux ia32 LE": "@esbuild/linux-ia32",
45
+ "linux mips64el LE": "@esbuild/linux-mips64el",
46
+ "linux ppc64 LE": "@esbuild/linux-ppc64",
47
+ "linux riscv64 LE": "@esbuild/linux-riscv64",
48
+ "linux s390x BE": "@esbuild/linux-s390x",
49
+ "linux x64 LE": "@esbuild/linux-x64",
50
+ "linux loong64 LE": "@esbuild/linux-loong64",
51
+ "netbsd x64 LE": "@esbuild/netbsd-x64",
52
+ "openbsd x64 LE": "@esbuild/openbsd-x64",
53
+ "sunos x64 LE": "@esbuild/sunos-x64"
54
+ };
55
+ var knownWebAssemblyFallbackPackages = {
56
+ "android arm LE": "@esbuild/android-arm",
57
+ "android x64 LE": "@esbuild/android-x64"
58
+ };
59
+ function pkgAndSubpathForCurrentPlatform() {
60
+ let pkg;
61
+ let subpath;
62
+ let isWASM = false;
63
+ let platformKey = `${process.platform} ${os.arch()} ${os.endianness()}`;
64
+ if (platformKey in knownWindowsPackages) {
65
+ pkg = knownWindowsPackages[platformKey];
66
+ subpath = "esbuild.exe";
67
+ } else if (platformKey in knownUnixlikePackages) {
68
+ pkg = knownUnixlikePackages[platformKey];
69
+ subpath = "bin/esbuild";
70
+ } else if (platformKey in knownWebAssemblyFallbackPackages) {
71
+ pkg = knownWebAssemblyFallbackPackages[platformKey];
72
+ subpath = "bin/esbuild";
73
+ isWASM = true;
74
+ } else {
75
+ throw new Error(`Unsupported platform: ${platformKey}`);
76
+ }
77
+ return { pkg, subpath, isWASM };
78
+ }
79
+ function downloadedBinPath(pkg, subpath) {
80
+ const esbuildLibDir = path.dirname(require.resolve("esbuild"));
81
+ return path.join(esbuildLibDir, `downloaded-${pkg.replace("/", "-")}-${path.basename(subpath)}`);
82
+ }
83
+
84
+ // lib/npm/node-install.ts
85
+ var fs2 = require("fs");
86
+ var os2 = require("os");
87
+ var path2 = require("path");
88
+ var zlib = require("zlib");
89
+ var https = require("https");
90
+ var child_process = require("child_process");
91
+ var versionFromPackageJSON = require(path2.join(__dirname, "package.json")).version;
92
+ var toPath = path2.join(__dirname, "bin", "esbuild");
93
+ var isToPathJS = true;
94
+ function validateBinaryVersion(...command) {
95
+ command.push("--version");
96
+ let stdout;
97
+ try {
98
+ stdout = child_process.execFileSync(command.shift(), command, {
99
+ // Without this, this install script strangely crashes with the error
100
+ // "EACCES: permission denied, write" but only on Ubuntu Linux when node is
101
+ // installed from the Snap Store. This is not a problem when you download
102
+ // the official version of node. The problem appears to be that stderr
103
+ // (i.e. file descriptor 2) isn't writable?
104
+ //
105
+ // More info:
106
+ // - https://snapcraft.io/ (what the Snap Store is)
107
+ // - https://nodejs.org/dist/ (download the official version of node)
108
+ // - https://github.com/evanw/esbuild/issues/1711#issuecomment-1027554035
109
+ //
110
+ stdio: "pipe"
111
+ }).toString().trim();
112
+ } catch (err) {
113
+ if (os2.platform() === "darwin" && /_SecTrustEvaluateWithError/.test(err + "")) {
114
+ let os3 = "this version of macOS";
115
+ try {
116
+ os3 = "macOS " + child_process.execFileSync("sw_vers", ["-productVersion"]).toString().trim();
117
+ } catch {
118
+ }
119
+ throw new Error(`The "esbuild" package cannot be installed because ${os3} is too outdated.
120
+
121
+ The Go compiler (which esbuild relies on) no longer supports ${os3},
122
+ which means the "esbuild" binary executable can't be run. You can either:
123
+
124
+ * Update your version of macOS to one that the Go compiler supports
125
+ * Use the "esbuild-wasm" package instead of the "esbuild" package
126
+ * Build esbuild yourself using an older version of the Go compiler
127
+ `);
128
+ }
129
+ throw err;
130
+ }
131
+ if (stdout !== versionFromPackageJSON) {
132
+ throw new Error(`Expected ${JSON.stringify(versionFromPackageJSON)} but got ${JSON.stringify(stdout)}`);
133
+ }
134
+ }
135
+ function isYarn() {
136
+ const { npm_config_user_agent } = process.env;
137
+ if (npm_config_user_agent) {
138
+ return /\byarn\//.test(npm_config_user_agent);
139
+ }
140
+ return false;
141
+ }
142
+ function fetch(url) {
143
+ return new Promise((resolve, reject) => {
144
+ https.get(url, (res) => {
145
+ if ((res.statusCode === 301 || res.statusCode === 302) && res.headers.location)
146
+ return fetch(res.headers.location).then(resolve, reject);
147
+ if (res.statusCode !== 200)
148
+ return reject(new Error(`Server responded with ${res.statusCode}`));
149
+ let chunks = [];
150
+ res.on("data", (chunk) => chunks.push(chunk));
151
+ res.on("end", () => resolve(Buffer.concat(chunks)));
152
+ }).on("error", reject);
153
+ });
154
+ }
155
+ function extractFileFromTarGzip(buffer, subpath) {
156
+ try {
157
+ buffer = zlib.unzipSync(buffer);
158
+ } catch (err) {
159
+ throw new Error(`Invalid gzip data in archive: ${err && err.message || err}`);
160
+ }
161
+ let str = (i, n) => String.fromCharCode(...buffer.subarray(i, i + n)).replace(/\0.*$/, "");
162
+ let offset = 0;
163
+ subpath = `package/${subpath}`;
164
+ while (offset < buffer.length) {
165
+ let name = str(offset, 100);
166
+ let size = parseInt(str(offset + 124, 12), 8);
167
+ offset += 512;
168
+ if (!isNaN(size)) {
169
+ if (name === subpath)
170
+ return buffer.subarray(offset, offset + size);
171
+ offset += size + 511 & ~511;
172
+ }
173
+ }
174
+ throw new Error(`Could not find ${JSON.stringify(subpath)} in archive`);
175
+ }
176
+ function installUsingNPM(pkg, subpath, binPath) {
177
+ const env = { ...process.env, npm_config_global: void 0 };
178
+ const esbuildLibDir = path2.dirname(require.resolve("esbuild"));
179
+ const installDir = path2.join(esbuildLibDir, "npm-install");
180
+ fs2.mkdirSync(installDir);
181
+ try {
182
+ fs2.writeFileSync(path2.join(installDir, "package.json"), "{}");
183
+ child_process.execSync(
184
+ `npm install --loglevel=error --prefer-offline --no-audit --progress=false ${pkg}@${versionFromPackageJSON}`,
185
+ { cwd: installDir, stdio: "pipe", env }
186
+ );
187
+ const installedBinPath = path2.join(installDir, "node_modules", pkg, subpath);
188
+ fs2.renameSync(installedBinPath, binPath);
189
+ } finally {
190
+ try {
191
+ removeRecursive(installDir);
192
+ } catch {
193
+ }
194
+ }
195
+ }
196
+ function removeRecursive(dir) {
197
+ for (const entry of fs2.readdirSync(dir)) {
198
+ const entryPath = path2.join(dir, entry);
199
+ let stats;
200
+ try {
201
+ stats = fs2.lstatSync(entryPath);
202
+ } catch {
203
+ continue;
204
+ }
205
+ if (stats.isDirectory())
206
+ removeRecursive(entryPath);
207
+ else
208
+ fs2.unlinkSync(entryPath);
209
+ }
210
+ fs2.rmdirSync(dir);
211
+ }
212
+ function applyManualBinaryPathOverride(overridePath) {
213
+ const pathString = JSON.stringify(overridePath);
214
+ fs2.writeFileSync(toPath, `#!/usr/bin/env node
215
+ require('child_process').execFileSync(${pathString}, process.argv.slice(2), { stdio: 'inherit' });
216
+ `);
217
+ const libMain = path2.join(__dirname, "lib", "main.js");
218
+ const code = fs2.readFileSync(libMain, "utf8");
219
+ fs2.writeFileSync(libMain, `var ESBUILD_BINARY_PATH = ${pathString};
220
+ ${code}`);
221
+ }
222
+ function maybeOptimizePackage(binPath) {
223
+ if (os2.platform() !== "win32" && !isYarn()) {
224
+ const tempPath = path2.join(__dirname, "bin-esbuild");
225
+ try {
226
+ fs2.linkSync(binPath, tempPath);
227
+ fs2.renameSync(tempPath, toPath);
228
+ isToPathJS = false;
229
+ fs2.unlinkSync(tempPath);
230
+ } catch {
231
+ }
232
+ }
233
+ }
234
+ async function downloadDirectlyFromNPM(pkg, subpath, binPath) {
235
+ const url = `https://registry.npmjs.org/${pkg}/-/${pkg.replace("@esbuild/", "")}-${versionFromPackageJSON}.tgz`;
236
+ console.error(`[esbuild] Trying to download ${JSON.stringify(url)}`);
237
+ try {
238
+ fs2.writeFileSync(binPath, extractFileFromTarGzip(await fetch(url), subpath));
239
+ fs2.chmodSync(binPath, 493);
240
+ } catch (e) {
241
+ console.error(`[esbuild] Failed to download ${JSON.stringify(url)}: ${e && e.message || e}`);
242
+ throw e;
243
+ }
244
+ }
245
+ async function checkAndPreparePackage() {
246
+ if (isValidBinaryPath(ESBUILD_BINARY_PATH)) {
247
+ if (!fs2.existsSync(ESBUILD_BINARY_PATH)) {
248
+ console.warn(`[esbuild] Ignoring bad configuration: ESBUILD_BINARY_PATH=${ESBUILD_BINARY_PATH}`);
249
+ } else {
250
+ applyManualBinaryPathOverride(ESBUILD_BINARY_PATH);
251
+ return;
252
+ }
253
+ }
254
+ const { pkg, subpath } = pkgAndSubpathForCurrentPlatform();
255
+ let binPath;
256
+ try {
257
+ binPath = require.resolve(`${pkg}/${subpath}`);
258
+ } catch (e) {
259
+ console.error(`[esbuild] Failed to find package "${pkg}" on the file system
260
+
261
+ This can happen if you use the "--no-optional" flag. The "optionalDependencies"
262
+ package.json feature is used by esbuild to install the correct binary executable
263
+ for your current platform. This install script will now attempt to work around
264
+ this. If that fails, you need to remove the "--no-optional" flag to use esbuild.
265
+ `);
266
+ binPath = downloadedBinPath(pkg, subpath);
267
+ try {
268
+ console.error(`[esbuild] Trying to install package "${pkg}" using npm`);
269
+ installUsingNPM(pkg, subpath, binPath);
270
+ } catch (e2) {
271
+ console.error(`[esbuild] Failed to install package "${pkg}" using npm: ${e2 && e2.message || e2}`);
272
+ try {
273
+ await downloadDirectlyFromNPM(pkg, subpath, binPath);
274
+ } catch (e3) {
275
+ throw new Error(`Failed to install package "${pkg}"`);
276
+ }
277
+ }
278
+ }
279
+ maybeOptimizePackage(binPath);
280
+ }
281
+ checkAndPreparePackage().then(() => {
282
+ if (isToPathJS) {
283
+ validateBinaryVersion(process.execPath, toPath);
284
+ } else {
285
+ validateBinaryVersion(toPath);
286
+ }
287
+ });