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.
- package/index.js +95 -0
- package/package.json +21 -0
- package/templates/vanilla/.github/workflows/deploy.yml +38 -0
- package/templates/vanilla/index.html +13 -0
- package/templates/vanilla/node_modules/.package-lock.json +207 -0
- package/templates/vanilla/node_modules/@esbuild/darwin-x64/README.md +3 -0
- package/templates/vanilla/node_modules/@esbuild/darwin-x64/bin/esbuild +0 -0
- package/templates/vanilla/node_modules/@esbuild/darwin-x64/package.json +17 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/README.md +154 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.cjs.js +1749 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.cjs.js.map +1 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.esm.js +1743 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.esm.js.map +1 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.umd.js +2 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/dist/microact.umd.js.map +1 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/example/index.html +13 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/example/index.js +63 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/package.json +38 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/rollup.config.cjs +30 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/src/Component.js +831 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/src/DOMUpdater.js +320 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/src/EventBus.js +123 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/src/Router.js +253 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/src/UpdateScheduler.js +218 -0
- package/templates/vanilla/node_modules/@monygroupcorp/microact/src/index.js +6 -0
- package/templates/vanilla/node_modules/esbuild/LICENSE.md +21 -0
- package/templates/vanilla/node_modules/esbuild/README.md +3 -0
- package/templates/vanilla/node_modules/esbuild/bin/esbuild +0 -0
- package/templates/vanilla/node_modules/esbuild/install.js +287 -0
- package/templates/vanilla/node_modules/esbuild/lib/main.d.ts +660 -0
- package/templates/vanilla/node_modules/esbuild/lib/main.js +2393 -0
- package/templates/vanilla/node_modules/esbuild/package.json +42 -0
- package/templates/vanilla/node_modules/nanoid/LICENSE +20 -0
- package/templates/vanilla/node_modules/nanoid/README.md +39 -0
- package/templates/vanilla/node_modules/nanoid/async/index.browser.cjs +69 -0
- package/templates/vanilla/node_modules/nanoid/async/index.browser.js +34 -0
- package/templates/vanilla/node_modules/nanoid/async/index.cjs +71 -0
- package/templates/vanilla/node_modules/nanoid/async/index.d.ts +56 -0
- package/templates/vanilla/node_modules/nanoid/async/index.js +35 -0
- package/templates/vanilla/node_modules/nanoid/async/index.native.js +26 -0
- package/templates/vanilla/node_modules/nanoid/async/package.json +12 -0
- package/templates/vanilla/node_modules/nanoid/bin/nanoid.cjs +55 -0
- package/templates/vanilla/node_modules/nanoid/index.browser.cjs +72 -0
- package/templates/vanilla/node_modules/nanoid/index.browser.js +34 -0
- package/templates/vanilla/node_modules/nanoid/index.cjs +85 -0
- package/templates/vanilla/node_modules/nanoid/index.d.cts +91 -0
- package/templates/vanilla/node_modules/nanoid/index.d.ts +91 -0
- package/templates/vanilla/node_modules/nanoid/index.js +45 -0
- package/templates/vanilla/node_modules/nanoid/nanoid.js +1 -0
- package/templates/vanilla/node_modules/nanoid/non-secure/index.cjs +34 -0
- package/templates/vanilla/node_modules/nanoid/non-secure/index.d.ts +33 -0
- package/templates/vanilla/node_modules/nanoid/non-secure/index.js +21 -0
- package/templates/vanilla/node_modules/nanoid/non-secure/package.json +6 -0
- package/templates/vanilla/node_modules/nanoid/package.json +89 -0
- package/templates/vanilla/node_modules/nanoid/url-alphabet/index.cjs +7 -0
- package/templates/vanilla/node_modules/nanoid/url-alphabet/index.js +3 -0
- package/templates/vanilla/node_modules/nanoid/url-alphabet/package.json +6 -0
- package/templates/vanilla/node_modules/picocolors/LICENSE +15 -0
- package/templates/vanilla/node_modules/picocolors/README.md +21 -0
- package/templates/vanilla/node_modules/picocolors/package.json +25 -0
- package/templates/vanilla/node_modules/picocolors/picocolors.browser.js +4 -0
- package/templates/vanilla/node_modules/picocolors/picocolors.d.ts +5 -0
- package/templates/vanilla/node_modules/picocolors/picocolors.js +75 -0
- package/templates/vanilla/node_modules/picocolors/types.d.ts +51 -0
- package/templates/vanilla/node_modules/postcss/LICENSE +20 -0
- package/templates/vanilla/node_modules/postcss/README.md +29 -0
- package/templates/vanilla/node_modules/postcss/lib/at-rule.d.ts +140 -0
- package/templates/vanilla/node_modules/postcss/lib/at-rule.js +25 -0
- package/templates/vanilla/node_modules/postcss/lib/comment.d.ts +68 -0
- package/templates/vanilla/node_modules/postcss/lib/comment.js +13 -0
- package/templates/vanilla/node_modules/postcss/lib/container.d.ts +483 -0
- package/templates/vanilla/node_modules/postcss/lib/container.js +447 -0
- package/templates/vanilla/node_modules/postcss/lib/css-syntax-error.d.ts +248 -0
- package/templates/vanilla/node_modules/postcss/lib/css-syntax-error.js +133 -0
- package/templates/vanilla/node_modules/postcss/lib/declaration.d.ts +151 -0
- package/templates/vanilla/node_modules/postcss/lib/declaration.js +24 -0
- package/templates/vanilla/node_modules/postcss/lib/document.d.ts +69 -0
- package/templates/vanilla/node_modules/postcss/lib/document.js +33 -0
- package/templates/vanilla/node_modules/postcss/lib/fromJSON.d.ts +9 -0
- package/templates/vanilla/node_modules/postcss/lib/fromJSON.js +54 -0
- package/templates/vanilla/node_modules/postcss/lib/input.d.ts +227 -0
- package/templates/vanilla/node_modules/postcss/lib/input.js +265 -0
- package/templates/vanilla/node_modules/postcss/lib/lazy-result.d.ts +190 -0
- package/templates/vanilla/node_modules/postcss/lib/lazy-result.js +550 -0
- package/templates/vanilla/node_modules/postcss/lib/list.d.ts +60 -0
- package/templates/vanilla/node_modules/postcss/lib/list.js +58 -0
- package/templates/vanilla/node_modules/postcss/lib/map-generator.js +368 -0
- package/templates/vanilla/node_modules/postcss/lib/no-work-result.d.ts +46 -0
- package/templates/vanilla/node_modules/postcss/lib/no-work-result.js +138 -0
- package/templates/vanilla/node_modules/postcss/lib/node.d.ts +556 -0
- package/templates/vanilla/node_modules/postcss/lib/node.js +449 -0
- package/templates/vanilla/node_modules/postcss/lib/parse.d.ts +9 -0
- package/templates/vanilla/node_modules/postcss/lib/parse.js +42 -0
- package/templates/vanilla/node_modules/postcss/lib/parser.js +611 -0
- package/templates/vanilla/node_modules/postcss/lib/postcss.d.mts +69 -0
- package/templates/vanilla/node_modules/postcss/lib/postcss.d.ts +458 -0
- package/templates/vanilla/node_modules/postcss/lib/postcss.js +101 -0
- package/templates/vanilla/node_modules/postcss/lib/postcss.mjs +30 -0
- package/templates/vanilla/node_modules/postcss/lib/previous-map.d.ts +81 -0
- package/templates/vanilla/node_modules/postcss/lib/previous-map.js +144 -0
- package/templates/vanilla/node_modules/postcss/lib/processor.d.ts +115 -0
- package/templates/vanilla/node_modules/postcss/lib/processor.js +67 -0
- package/templates/vanilla/node_modules/postcss/lib/result.d.ts +205 -0
- package/templates/vanilla/node_modules/postcss/lib/result.js +42 -0
- package/templates/vanilla/node_modules/postcss/lib/root.d.ts +87 -0
- package/templates/vanilla/node_modules/postcss/lib/root.js +61 -0
- package/templates/vanilla/node_modules/postcss/lib/rule.d.ts +126 -0
- package/templates/vanilla/node_modules/postcss/lib/rule.js +27 -0
- package/templates/vanilla/node_modules/postcss/lib/stringifier.d.ts +46 -0
- package/templates/vanilla/node_modules/postcss/lib/stringifier.js +353 -0
- package/templates/vanilla/node_modules/postcss/lib/stringify.d.ts +9 -0
- package/templates/vanilla/node_modules/postcss/lib/stringify.js +11 -0
- package/templates/vanilla/node_modules/postcss/lib/symbols.js +5 -0
- package/templates/vanilla/node_modules/postcss/lib/terminal-highlight.js +70 -0
- package/templates/vanilla/node_modules/postcss/lib/tokenize.js +266 -0
- package/templates/vanilla/node_modules/postcss/lib/warn-once.js +13 -0
- package/templates/vanilla/node_modules/postcss/lib/warning.d.ts +147 -0
- package/templates/vanilla/node_modules/postcss/lib/warning.js +37 -0
- package/templates/vanilla/node_modules/postcss/package.json +88 -0
- package/templates/vanilla/node_modules/rollup/LICENSE.md +695 -0
- package/templates/vanilla/node_modules/rollup/README.md +125 -0
- package/templates/vanilla/node_modules/rollup/dist/bin/rollup +1715 -0
- package/templates/vanilla/node_modules/rollup/dist/es/getLogFilter.js +64 -0
- package/templates/vanilla/node_modules/rollup/dist/es/package.json +1 -0
- package/templates/vanilla/node_modules/rollup/dist/es/rollup.js +17 -0
- package/templates/vanilla/node_modules/rollup/dist/es/shared/node-entry.js +27273 -0
- package/templates/vanilla/node_modules/rollup/dist/es/shared/watch.js +4857 -0
- package/templates/vanilla/node_modules/rollup/dist/getLogFilter.d.ts +5 -0
- package/templates/vanilla/node_modules/rollup/dist/getLogFilter.js +69 -0
- package/templates/vanilla/node_modules/rollup/dist/loadConfigFile.d.ts +20 -0
- package/templates/vanilla/node_modules/rollup/dist/loadConfigFile.js +29 -0
- package/templates/vanilla/node_modules/rollup/dist/rollup.d.ts +1012 -0
- package/templates/vanilla/node_modules/rollup/dist/rollup.js +31 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/fsevents-importer.js +37 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/index.js +4571 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/loadConfigFile.js +546 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/rollup.js +27351 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/watch-cli.js +561 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/watch-proxy.js +87 -0
- package/templates/vanilla/node_modules/rollup/dist/shared/watch.js +316 -0
- package/templates/vanilla/node_modules/rollup/package.json +181 -0
- package/templates/vanilla/node_modules/source-map-js/LICENSE +28 -0
- package/templates/vanilla/node_modules/source-map-js/README.md +765 -0
- package/templates/vanilla/node_modules/source-map-js/lib/array-set.js +121 -0
- package/templates/vanilla/node_modules/source-map-js/lib/base64-vlq.js +140 -0
- package/templates/vanilla/node_modules/source-map-js/lib/base64.js +67 -0
- package/templates/vanilla/node_modules/source-map-js/lib/binary-search.js +111 -0
- package/templates/vanilla/node_modules/source-map-js/lib/mapping-list.js +79 -0
- package/templates/vanilla/node_modules/source-map-js/lib/quick-sort.js +132 -0
- package/templates/vanilla/node_modules/source-map-js/lib/source-map-consumer.d.ts +1 -0
- package/templates/vanilla/node_modules/source-map-js/lib/source-map-consumer.js +1188 -0
- package/templates/vanilla/node_modules/source-map-js/lib/source-map-generator.d.ts +1 -0
- package/templates/vanilla/node_modules/source-map-js/lib/source-map-generator.js +444 -0
- package/templates/vanilla/node_modules/source-map-js/lib/source-node.d.ts +1 -0
- package/templates/vanilla/node_modules/source-map-js/lib/source-node.js +413 -0
- package/templates/vanilla/node_modules/source-map-js/lib/util.js +594 -0
- package/templates/vanilla/node_modules/source-map-js/package.json +71 -0
- package/templates/vanilla/node_modules/source-map-js/source-map.d.ts +104 -0
- package/templates/vanilla/node_modules/source-map-js/source-map.js +8 -0
- package/templates/vanilla/node_modules/vite/LICENSE.md +3396 -0
- package/templates/vanilla/node_modules/vite/README.md +20 -0
- package/templates/vanilla/node_modules/vite/bin/openChrome.applescript +95 -0
- package/templates/vanilla/node_modules/vite/bin/vite.js +61 -0
- package/templates/vanilla/node_modules/vite/client.d.ts +281 -0
- package/templates/vanilla/node_modules/vite/dist/client/client.mjs +725 -0
- package/templates/vanilla/node_modules/vite/dist/client/client.mjs.map +1 -0
- package/templates/vanilla/node_modules/vite/dist/client/env.mjs +30 -0
- package/templates/vanilla/node_modules/vite/dist/client/env.mjs.map +1 -0
- package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-7ec6f216.js +914 -0
- package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-827b23df.js +66713 -0
- package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-c423598f.js +561 -0
- package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-f0c7dae0.js +7930 -0
- package/templates/vanilla/node_modules/vite/dist/node/chunks/dep-f1e8587f.js +7646 -0
- package/templates/vanilla/node_modules/vite/dist/node/cli.js +929 -0
- package/templates/vanilla/node_modules/vite/dist/node/constants.js +130 -0
- package/templates/vanilla/node_modules/vite/dist/node/index.d.ts +3548 -0
- package/templates/vanilla/node_modules/vite/dist/node/index.js +158 -0
- package/templates/vanilla/node_modules/vite/dist/node-cjs/publicUtils.cjs +4555 -0
- package/templates/vanilla/node_modules/vite/index.cjs +34 -0
- package/templates/vanilla/node_modules/vite/package.json +173 -0
- package/templates/vanilla/node_modules/vite/types/customEvent.d.ts +35 -0
- package/templates/vanilla/node_modules/vite/types/hmrPayload.d.ts +61 -0
- package/templates/vanilla/node_modules/vite/types/hot.d.ts +32 -0
- package/templates/vanilla/node_modules/vite/types/importGlob.d.ts +97 -0
- package/templates/vanilla/node_modules/vite/types/importMeta.d.ts +26 -0
- package/templates/vanilla/node_modules/vite/types/metadata.d.ts +10 -0
- package/templates/vanilla/node_modules/vite/types/package.json +4 -0
- package/templates/vanilla/package-lock.json +589 -0
- package/templates/vanilla/package.json +17 -0
- package/templates/vanilla/src/components/App.js +60 -0
- package/templates/vanilla/src/components/Card.js +21 -0
- package/templates/vanilla/src/components/Hero.js +15 -0
- package/templates/vanilla/src/components/InteractiveDemo.js +59 -0
- package/templates/vanilla/src/main.js +9 -0
- package/templates/vanilla/src/style/main.css +172 -0
- package/templates/vanilla/vite.config.js +8 -0
- package/templates/web3/.env.example +15 -0
- package/templates/web3/.github/workflows/deploy.yml +38 -0
- package/templates/web3/README.md +33 -0
- package/templates/web3/contracts/foundry.toml +11 -0
- package/templates/web3/contracts/script/Deploy.s.sol +13 -0
- package/templates/web3/contracts/src/Counter.sol +21 -0
- package/templates/web3/index.html +13 -0
- package/templates/web3/package.json +25 -0
- package/templates/web3/scripts/chain-start.mjs +305 -0
- package/templates/web3/scripts/chain-stop.mjs +34 -0
- package/templates/web3/scripts/deploy.mjs +155 -0
- package/templates/web3/scripts/setup.mjs +42 -0
- package/templates/web3/src/components/App.js +49 -0
- package/templates/web3/src/components/CounterCard.js +111 -0
- package/templates/web3/src/main.js +54 -0
- package/templates/web3/src/style/main.css +345 -0
- 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.
|
|
Binary file
|
|
@@ -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
|
+
});
|