主要功能: - 修改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>
86 lines
1.8 KiB
JavaScript
86 lines
1.8 KiB
JavaScript
'use strict'
|
|
|
|
const req = require('./req.js')
|
|
|
|
/**
|
|
* Plugin Loader
|
|
*
|
|
* @private
|
|
* @method load
|
|
*
|
|
* @param {String} plugin PostCSS Plugin Name
|
|
* @param {Object} options PostCSS Plugin Options
|
|
*
|
|
* @return {Function} PostCSS Plugin
|
|
*/
|
|
const load = (plugin, options, file) => {
|
|
try {
|
|
if (
|
|
options === null ||
|
|
options === undefined ||
|
|
Object.keys(options).length === 0
|
|
) {
|
|
return req(plugin, file)
|
|
} else {
|
|
return req(plugin, file)(options)
|
|
}
|
|
} catch (err) {
|
|
throw new Error(`Loading PostCSS Plugin failed: ${err.message}\n\n(@${file})`)
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Load Plugins
|
|
*
|
|
* @private
|
|
* @method plugins
|
|
*
|
|
* @param {Object} config PostCSS Config Plugins
|
|
*
|
|
* @return {Array} plugins PostCSS Plugins
|
|
*/
|
|
const plugins = (config, file) => {
|
|
let plugins = []
|
|
|
|
if (Array.isArray(config.plugins)) {
|
|
plugins = config.plugins.filter(Boolean)
|
|
} else {
|
|
plugins = Object.keys(config.plugins)
|
|
.filter((plugin) => {
|
|
return config.plugins[plugin] !== false ? plugin : ''
|
|
})
|
|
.map((plugin) => {
|
|
return load(plugin, config.plugins[plugin], file)
|
|
})
|
|
}
|
|
|
|
if (plugins.length && plugins.length > 0) {
|
|
plugins.forEach((plugin, i) => {
|
|
if (plugin.default) {
|
|
plugin = plugin.default
|
|
}
|
|
|
|
if (plugin.postcss === true) {
|
|
plugin = plugin()
|
|
} else if (plugin.postcss) {
|
|
plugin = plugin.postcss
|
|
}
|
|
|
|
if (
|
|
// eslint-disable-next-line
|
|
!(
|
|
(typeof plugin === 'object' && Array.isArray(plugin.plugins)) ||
|
|
(typeof plugin === 'object' && plugin.postcssPlugin) ||
|
|
(typeof plugin === 'function')
|
|
)
|
|
) {
|
|
throw new TypeError(`Invalid PostCSS Plugin found at: plugins[${i}]\n\n(@${file})`)
|
|
}
|
|
})
|
|
}
|
|
|
|
return plugins
|
|
}
|
|
|
|
module.exports = plugins
|