详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
84 lines
3.1 KiB
JavaScript
84 lines
3.1 KiB
JavaScript
(function (Prism) {
|
|
|
|
// https://yaml.org/spec/1.2/spec.html#c-ns-anchor-property
|
|
// https://yaml.org/spec/1.2/spec.html#c-ns-alias-node
|
|
var anchorOrAlias = /[*&][^\s[\]{},]+/;
|
|
// https://yaml.org/spec/1.2/spec.html#c-ns-tag-property
|
|
var tag = /!(?:<[\w\-%#;/?:@&=+$,.!~*'()[\]]+>|(?:[a-zA-Z\d-]*!)?[\w\-%#;/?:@&=+$.~*'()]+)?/;
|
|
// https://yaml.org/spec/1.2/spec.html#c-ns-properties(n,c)
|
|
var properties = '(?:' + tag.source + '(?:[ \t]+' + anchorOrAlias.source + ')?|'
|
|
+ anchorOrAlias.source + '(?:[ \t]+' + tag.source + ')?)';
|
|
// https://yaml.org/spec/1.2/spec.html#ns-plain(n,c)
|
|
// This is a simplified version that doesn't support "#" and multiline keys
|
|
// All these long scarry character classes are simplified versions of YAML's characters
|
|
var plainKey = /(?:[^\s\x00-\x08\x0e-\x1f!"#%&'*,\-:>?@[\]`{|}\x7f-\x84\x86-\x9f\ud800-\udfff\ufffe\uffff]|[?:-]<PLAIN>)(?:[ \t]*(?:(?![#:])<PLAIN>|:<PLAIN>))*/.source
|
|
.replace(/<PLAIN>/g, function () { return /[^\s\x00-\x08\x0e-\x1f,[\]{}\x7f-\x84\x86-\x9f\ud800-\udfff\ufffe\uffff]/.source; });
|
|
var string = /"(?:[^"\\\r\n]|\\.)*"|'(?:[^'\\\r\n]|\\.)*'/.source;
|
|
|
|
/**
|
|
*
|
|
* @param {string} value
|
|
* @param {string} [flags]
|
|
* @returns {RegExp}
|
|
*/
|
|
function createValuePattern(value, flags) {
|
|
flags = (flags || '').replace(/m/g, '') + 'm'; // add m flag
|
|
var pattern = /([:\-,[{]\s*(?:\s<<prop>>[ \t]+)?)(?:<<value>>)(?=[ \t]*(?:$|,|\]|\}|(?:[\r\n]\s*)?#))/.source
|
|
.replace(/<<prop>>/g, function () { return properties; }).replace(/<<value>>/g, function () { return value; });
|
|
return RegExp(pattern, flags);
|
|
}
|
|
|
|
Prism.languages.yaml = {
|
|
'scalar': {
|
|
pattern: RegExp(/([\-:]\s*(?:\s<<prop>>[ \t]+)?[|>])[ \t]*(?:((?:\r?\n|\r)[ \t]+)\S[^\r\n]*(?:\2[^\r\n]+)*)/.source
|
|
.replace(/<<prop>>/g, function () { return properties; })),
|
|
lookbehind: true,
|
|
alias: 'string'
|
|
},
|
|
'comment': /#.*/,
|
|
'key': {
|
|
pattern: RegExp(/((?:^|[:\-,[{\r\n?])[ \t]*(?:<<prop>>[ \t]+)?)<<key>>(?=\s*:\s)/.source
|
|
.replace(/<<prop>>/g, function () { return properties; })
|
|
.replace(/<<key>>/g, function () { return '(?:' + plainKey + '|' + string + ')'; })),
|
|
lookbehind: true,
|
|
greedy: true,
|
|
alias: 'atrule'
|
|
},
|
|
'directive': {
|
|
pattern: /(^[ \t]*)%.+/m,
|
|
lookbehind: true,
|
|
alias: 'important'
|
|
},
|
|
'datetime': {
|
|
pattern: createValuePattern(/\d{4}-\d\d?-\d\d?(?:[tT]|[ \t]+)\d\d?:\d{2}:\d{2}(?:\.\d*)?(?:[ \t]*(?:Z|[-+]\d\d?(?::\d{2})?))?|\d{4}-\d{2}-\d{2}|\d\d?:\d{2}(?::\d{2}(?:\.\d*)?)?/.source),
|
|
lookbehind: true,
|
|
alias: 'number'
|
|
},
|
|
'boolean': {
|
|
pattern: createValuePattern(/false|true/.source, 'i'),
|
|
lookbehind: true,
|
|
alias: 'important'
|
|
},
|
|
'null': {
|
|
pattern: createValuePattern(/null|~/.source, 'i'),
|
|
lookbehind: true,
|
|
alias: 'important'
|
|
},
|
|
'string': {
|
|
pattern: createValuePattern(string),
|
|
lookbehind: true,
|
|
greedy: true
|
|
},
|
|
'number': {
|
|
pattern: createValuePattern(/[+-]?(?:0x[\da-f]+|0o[0-7]+|(?:\d+(?:\.\d*)?|\.\d+)(?:e[+-]?\d+)?|\.inf|\.nan)/.source, 'i'),
|
|
lookbehind: true
|
|
},
|
|
'tag': tag,
|
|
'important': anchorOrAlias,
|
|
'punctuation': /---|[:[\]{}\-,|>?]|\.\.\./
|
|
};
|
|
|
|
Prism.languages.yml = Prism.languages.yaml;
|
|
|
|
}(Prism));
|