Files
Agent-n8n/backups/exhibition-demo-backup-20250928-210916/node_modules/react-syntax-highlighter/src/create-element.js
Yep_Q 67f5dfbe50 feat: 实现多订单班支持系统
主要功能:
- 修改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>
2025-09-29 10:02:15 +08:00

213 lines
6.3 KiB
JavaScript

import React from 'react';
// Get all possible permutations of all power sets
//
// Super simple, non-algorithmic solution since the
// number of class names will not be greater than 4
function powerSetPermutations(arr) {
const arrLength = arr.length;
if (arrLength === 0 || arrLength === 1) return arr;
if (arrLength === 2) {
// prettier-ignore
return [
arr[0],
arr[1],
`${arr[0]}.${arr[1]}`,
`${arr[1]}.${arr[0]}`
];
}
if (arrLength === 3) {
return [
arr[0],
arr[1],
arr[2],
`${arr[0]}.${arr[1]}`,
`${arr[0]}.${arr[2]}`,
`${arr[1]}.${arr[0]}`,
`${arr[1]}.${arr[2]}`,
`${arr[2]}.${arr[0]}`,
`${arr[2]}.${arr[1]}`,
`${arr[0]}.${arr[1]}.${arr[2]}`,
`${arr[0]}.${arr[2]}.${arr[1]}`,
`${arr[1]}.${arr[0]}.${arr[2]}`,
`${arr[1]}.${arr[2]}.${arr[0]}`,
`${arr[2]}.${arr[0]}.${arr[1]}`,
`${arr[2]}.${arr[1]}.${arr[0]}`
];
}
if (arrLength >= 4) {
// Currently does not support more than 4 extra
// class names (after `.token` has been removed)
return [
arr[0],
arr[1],
arr[2],
arr[3],
`${arr[0]}.${arr[1]}`,
`${arr[0]}.${arr[2]}`,
`${arr[0]}.${arr[3]}`,
`${arr[1]}.${arr[0]}`,
`${arr[1]}.${arr[2]}`,
`${arr[1]}.${arr[3]}`,
`${arr[2]}.${arr[0]}`,
`${arr[2]}.${arr[1]}`,
`${arr[2]}.${arr[3]}`,
`${arr[3]}.${arr[0]}`,
`${arr[3]}.${arr[1]}`,
`${arr[3]}.${arr[2]}`,
`${arr[0]}.${arr[1]}.${arr[2]}`,
`${arr[0]}.${arr[1]}.${arr[3]}`,
`${arr[0]}.${arr[2]}.${arr[1]}`,
`${arr[0]}.${arr[2]}.${arr[3]}`,
`${arr[0]}.${arr[3]}.${arr[1]}`,
`${arr[0]}.${arr[3]}.${arr[2]}`,
`${arr[1]}.${arr[0]}.${arr[2]}`,
`${arr[1]}.${arr[0]}.${arr[3]}`,
`${arr[1]}.${arr[2]}.${arr[0]}`,
`${arr[1]}.${arr[2]}.${arr[3]}`,
`${arr[1]}.${arr[3]}.${arr[0]}`,
`${arr[1]}.${arr[3]}.${arr[2]}`,
`${arr[2]}.${arr[0]}.${arr[1]}`,
`${arr[2]}.${arr[0]}.${arr[3]}`,
`${arr[2]}.${arr[1]}.${arr[0]}`,
`${arr[2]}.${arr[1]}.${arr[3]}`,
`${arr[2]}.${arr[3]}.${arr[0]}`,
`${arr[2]}.${arr[3]}.${arr[1]}`,
`${arr[3]}.${arr[0]}.${arr[1]}`,
`${arr[3]}.${arr[0]}.${arr[2]}`,
`${arr[3]}.${arr[1]}.${arr[0]}`,
`${arr[3]}.${arr[1]}.${arr[2]}`,
`${arr[3]}.${arr[2]}.${arr[0]}`,
`${arr[3]}.${arr[2]}.${arr[1]}`,
`${arr[0]}.${arr[1]}.${arr[2]}.${arr[3]}`,
`${arr[0]}.${arr[1]}.${arr[3]}.${arr[2]}`,
`${arr[0]}.${arr[2]}.${arr[1]}.${arr[3]}`,
`${arr[0]}.${arr[2]}.${arr[3]}.${arr[1]}`,
`${arr[0]}.${arr[3]}.${arr[1]}.${arr[2]}`,
`${arr[0]}.${arr[3]}.${arr[2]}.${arr[1]}`,
`${arr[1]}.${arr[0]}.${arr[2]}.${arr[3]}`,
`${arr[1]}.${arr[0]}.${arr[3]}.${arr[2]}`,
`${arr[1]}.${arr[2]}.${arr[0]}.${arr[3]}`,
`${arr[1]}.${arr[2]}.${arr[3]}.${arr[0]}`,
`${arr[1]}.${arr[3]}.${arr[0]}.${arr[2]}`,
`${arr[1]}.${arr[3]}.${arr[2]}.${arr[0]}`,
`${arr[2]}.${arr[0]}.${arr[1]}.${arr[3]}`,
`${arr[2]}.${arr[0]}.${arr[3]}.${arr[1]}`,
`${arr[2]}.${arr[1]}.${arr[0]}.${arr[3]}`,
`${arr[2]}.${arr[1]}.${arr[3]}.${arr[0]}`,
`${arr[2]}.${arr[3]}.${arr[0]}.${arr[1]}`,
`${arr[2]}.${arr[3]}.${arr[1]}.${arr[0]}`,
`${arr[3]}.${arr[0]}.${arr[1]}.${arr[2]}`,
`${arr[3]}.${arr[0]}.${arr[2]}.${arr[1]}`,
`${arr[3]}.${arr[1]}.${arr[0]}.${arr[2]}`,
`${arr[3]}.${arr[1]}.${arr[2]}.${arr[0]}`,
`${arr[3]}.${arr[2]}.${arr[0]}.${arr[1]}`,
`${arr[3]}.${arr[2]}.${arr[1]}.${arr[0]}`
];
}
}
const classNameCombinations = {};
function getClassNameCombinations(classNames) {
if (classNames.length === 0 || classNames.length === 1) return classNames;
const key = classNames.join('.');
if (!classNameCombinations[key]) {
classNameCombinations[key] = powerSetPermutations(classNames);
}
return classNameCombinations[key];
}
export function createStyleObject(classNames, elementStyle = {}, stylesheet) {
const nonTokenClassNames = classNames.filter(
className => className !== 'token'
);
const classNamesCombinations = getClassNameCombinations(nonTokenClassNames);
return classNamesCombinations.reduce((styleObject, className) => {
return { ...styleObject, ...stylesheet[className] };
}, elementStyle);
}
export function createClassNameString(classNames) {
return classNames.join(' ');
}
export function createChildren(stylesheet, useInlineStyles) {
let childrenCount = 0;
return children => {
childrenCount += 1;
return children.map((child, i) =>
createElement({
node: child,
stylesheet,
useInlineStyles,
key: `code-segment-${childrenCount}-${i}`
})
);
};
}
export default function createElement({
node,
stylesheet,
style = {},
useInlineStyles,
key
}) {
const { properties, type, tagName: TagName, value } = node;
if (type === 'text') {
return value;
} else if (TagName) {
const childrenCreator = createChildren(stylesheet, useInlineStyles);
let props;
if (!useInlineStyles) {
props = {
...properties,
className: createClassNameString(properties.className)
};
} else {
const allStylesheetSelectors = Object.keys(stylesheet).reduce(
(classes, selector) => {
selector.split('.').forEach(className => {
if (!classes.includes(className)) classes.push(className);
});
return classes;
},
[]
);
// For compatibility with older versions of react-syntax-highlighter
const startingClassName =
properties.className && properties.className.includes('token')
? ['token']
: [];
const className =
properties.className &&
startingClassName.concat(
properties.className.filter(
className => !allStylesheetSelectors.includes(className)
)
);
props = {
...properties,
className: createClassNameString(className) || undefined,
style: createStyleObject(
properties.className,
Object.assign({}, properties.style, style),
stylesheet
)
};
}
const children = childrenCreator(node.children);
return (
<TagName key={key} {...props}>
{children}
</TagName>
);
}
}