主要功能: - 修改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>
55 lines
1.4 KiB
JavaScript
55 lines
1.4 KiB
JavaScript
'use strict';
|
|
module.exports = {
|
|
wrap: wrapRange,
|
|
limit: limitRange,
|
|
validate: validateRange,
|
|
test: testRange,
|
|
curry: curry,
|
|
name: name
|
|
};
|
|
|
|
function wrapRange(min, max, value) {
|
|
var maxLessMin = max - min;
|
|
return ((value - min) % maxLessMin + maxLessMin) % maxLessMin + min;
|
|
}
|
|
|
|
function limitRange(min, max, value) {
|
|
return Math.max(min, Math.min(max, value));
|
|
}
|
|
|
|
function validateRange(min, max, value, minExclusive, maxExclusive) {
|
|
if (!testRange(min, max, value, minExclusive, maxExclusive)) {
|
|
throw new Error(value + ' is outside of range [' + min + ',' + max + ')');
|
|
}
|
|
return value;
|
|
}
|
|
|
|
function testRange(min, max, value, minExclusive, maxExclusive) {
|
|
return !(
|
|
value < min ||
|
|
value > max ||
|
|
(maxExclusive && (value === max)) ||
|
|
(minExclusive && (value === min))
|
|
);
|
|
}
|
|
|
|
function name(min, max, minExcl, maxExcl) {
|
|
return (minExcl ? '(' : '[') + min + ',' + max + (maxExcl ? ')' : ']');
|
|
}
|
|
|
|
function curry(min, max, minExclusive, maxExclusive) {
|
|
var boundNameFn = name.bind(null, min, max, minExclusive, maxExclusive);
|
|
return {
|
|
wrap: wrapRange.bind(null, min, max),
|
|
limit: limitRange.bind(null, min, max),
|
|
validate: function(value) {
|
|
return validateRange(min, max, value, minExclusive, maxExclusive);
|
|
},
|
|
test: function(value) {
|
|
return testRange(min, max, value, minExclusive, maxExclusive);
|
|
},
|
|
toString: boundNameFn,
|
|
name: boundNameFn
|
|
};
|
|
}
|