主要功能: - 修改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>
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
const CUSTOM_PROPERTY_REGEX = /^--[a-zA-Z0-9_-]+$/;
|
|
const HYPHEN_REGEX = /-([a-z])/g;
|
|
const NO_HYPHEN_REGEX = /^[^-]+$/;
|
|
const VENDOR_PREFIX_REGEX = /^-(webkit|moz|ms|o|khtml)-/;
|
|
const MS_VENDOR_PREFIX_REGEX = /^-(ms)-/;
|
|
|
|
/**
|
|
* Checks whether to skip camelCase.
|
|
*/
|
|
const skipCamelCase = (property: string) =>
|
|
!property ||
|
|
NO_HYPHEN_REGEX.test(property) ||
|
|
CUSTOM_PROPERTY_REGEX.test(property);
|
|
|
|
/**
|
|
* Replacer that capitalizes first character.
|
|
*/
|
|
const capitalize = (match: string, character: string) =>
|
|
character.toUpperCase();
|
|
|
|
/**
|
|
* Replacer that removes beginning hyphen of vendor prefix property.
|
|
*/
|
|
const trimHyphen = (match: string, prefix: string) => `${prefix}-`;
|
|
|
|
/**
|
|
* CamelCase options.
|
|
*/
|
|
export interface CamelCaseOptions {
|
|
reactCompat?: boolean;
|
|
}
|
|
|
|
/**
|
|
* CamelCases a CSS property.
|
|
*/
|
|
export const camelCase = (property: string, options: CamelCaseOptions = {}) => {
|
|
if (skipCamelCase(property)) {
|
|
return property;
|
|
}
|
|
|
|
property = property.toLowerCase();
|
|
|
|
if (options.reactCompat) {
|
|
// `-ms` vendor prefix should not be capitalized
|
|
property = property.replace(MS_VENDOR_PREFIX_REGEX, trimHyphen);
|
|
} else {
|
|
// for non-React, remove first hyphen so vendor prefix is not capitalized
|
|
property = property.replace(VENDOR_PREFIX_REGEX, trimHyphen);
|
|
}
|
|
|
|
return property.replace(HYPHEN_REGEX, capitalize);
|
|
};
|