- Foldable left panel (user profile) and right panel (task details) - Clicking a task in the list or graph node selects it and shows details - Both views (task list + graph) always mounted via absolute inset-0 for correct canvas dimensions; tabs toggle visibility with opacity - Graph node selection animation: other nodes repel outward (charge -600), then selected node smoothly slides to center (500ms cubic ease-out), then charge restores to -120 and graph stabilizes - Graph re-fits on tab switch and panel resize via ResizeObserver - Fix UUID string IDs throughout (backend returns UUIDs, not integers) - Add TaskDetailPanel, UserPanel components - Add CLAUDE.md project documentation Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
47 lines
1.7 KiB
JavaScript
47 lines
1.7 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.buildDynamicImport = buildDynamicImport;
|
|
var _core = require("@babel/core");
|
|
exports.getDynamicImportSource = function getDynamicImportSource(node) {
|
|
const [source] = node.arguments;
|
|
return _core.types.isStringLiteral(source) || _core.types.isTemplateLiteral(source) ? source : _core.template.expression.ast`\`\${${source}}\``;
|
|
};
|
|
function buildDynamicImport(node, deferToThen, wrapWithPromise, builder) {
|
|
const specifier = _core.types.isCallExpression(node) ? node.arguments[0] : node.source;
|
|
if (_core.types.isStringLiteral(specifier) || _core.types.isTemplateLiteral(specifier) && specifier.quasis.length === 0) {
|
|
if (deferToThen) {
|
|
return _core.template.expression.ast`
|
|
Promise.resolve().then(() => ${builder(specifier)})
|
|
`;
|
|
} else return builder(specifier);
|
|
}
|
|
const specifierToString = _core.types.isTemplateLiteral(specifier) ? _core.types.identifier("specifier") : _core.types.templateLiteral([_core.types.templateElement({
|
|
raw: ""
|
|
}), _core.types.templateElement({
|
|
raw: ""
|
|
})], [_core.types.identifier("specifier")]);
|
|
if (deferToThen) {
|
|
return _core.template.expression.ast`
|
|
(specifier =>
|
|
new Promise(r => r(${specifierToString}))
|
|
.then(s => ${builder(_core.types.identifier("s"))})
|
|
)(${specifier})
|
|
`;
|
|
} else if (wrapWithPromise) {
|
|
return _core.template.expression.ast`
|
|
(specifier =>
|
|
new Promise(r => r(${builder(specifierToString)}))
|
|
)(${specifier})
|
|
`;
|
|
} else {
|
|
return _core.template.expression.ast`
|
|
(specifier => ${builder(specifierToString)})(${specifier})
|
|
`;
|
|
}
|
|
}
|
|
|
|
//# sourceMappingURL=dynamic-import.js.map
|