主要功能: - 修改RequirementModal支持12个订单班选择 - 添加OrderClassIconMap图标映射组件 - Store中添加selectedOrderClass状态管理 - WorkflowPage支持传递orderClass参数 - web_result添加URL参数切换功能 - 创建order-class-handler.js动态处理页面主题 技术改进: - 创建软链接关联订单班数据目录 - 生成wenlu.json和food.json数据结构 - 删除重复的web_result目录 - 添加测试页面test-order-class.html 影响范围: - 展会策划系统现支持12个订单班 - 结果展示页面自动适配不同订单班主题 - 用户可选择不同行业生成对应方案 🤖 Generated with Claude Code Co-Authored-By: Claude <noreply@anthropic.com>
68 lines
2.0 KiB
JavaScript
68 lines
2.0 KiB
JavaScript
import { noop } from 'motion-utils';
|
|
import { startViewAnimation } from './start.mjs';
|
|
|
|
/**
|
|
* TODO:
|
|
* - Create view transition on next tick
|
|
* - Replace animations with Motion animations
|
|
* - Return GroupAnimation on next tick
|
|
*/
|
|
class ViewTransitionBuilder {
|
|
constructor(update, options = {}) {
|
|
this.currentTarget = "root";
|
|
this.targets = new Map();
|
|
this.notifyReady = noop;
|
|
this.readyPromise = new Promise((resolve) => {
|
|
this.notifyReady = resolve;
|
|
});
|
|
queueMicrotask(() => {
|
|
startViewAnimation(update, options, this.targets).then((animation) => this.notifyReady(animation));
|
|
});
|
|
}
|
|
get(selector) {
|
|
this.currentTarget = selector;
|
|
return this;
|
|
}
|
|
layout(keyframes, options) {
|
|
this.updateTarget("layout", keyframes, options);
|
|
return this;
|
|
}
|
|
new(keyframes, options) {
|
|
this.updateTarget("new", keyframes, options);
|
|
return this;
|
|
}
|
|
old(keyframes, options) {
|
|
this.updateTarget("old", keyframes, options);
|
|
return this;
|
|
}
|
|
enter(keyframes, options) {
|
|
this.updateTarget("enter", keyframes, options);
|
|
return this;
|
|
}
|
|
exit(keyframes, options) {
|
|
this.updateTarget("exit", keyframes, options);
|
|
return this;
|
|
}
|
|
crossfade(options) {
|
|
this.updateTarget("enter", { opacity: 1 }, options);
|
|
this.updateTarget("exit", { opacity: 0 }, options);
|
|
return this;
|
|
}
|
|
updateTarget(target, keyframes, options = {}) {
|
|
const { currentTarget, targets } = this;
|
|
if (!targets.has(currentTarget)) {
|
|
targets.set(currentTarget, {});
|
|
}
|
|
const targetData = targets.get(currentTarget);
|
|
targetData[target] = { keyframes, options };
|
|
}
|
|
then(resolve, reject) {
|
|
return this.readyPromise.then(resolve, reject);
|
|
}
|
|
}
|
|
function view(update, defaultOptions = {}) {
|
|
return new ViewTransitionBuilder(update, defaultOptions);
|
|
}
|
|
|
|
export { ViewTransitionBuilder, view };
|