详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
99 lines
2.8 KiB
JavaScript
99 lines
2.8 KiB
JavaScript
(function (Prism) {
|
|
|
|
// Many of the following regexes will contain negated lookaheads like `[ \t]+(?![ \t])`. This is a trick to ensure
|
|
// that quantifiers behave *atomically*. Atomic quantifiers are necessary to prevent exponential backtracking.
|
|
|
|
var spaceAfterBackSlash = /\\[\r\n](?:\s|\\[\r\n]|#.*(?!.))*(?![\s#]|\\[\r\n])/.source;
|
|
// At least one space, comment, or line break
|
|
var space = /(?:[ \t]+(?![ \t])(?:<SP_BS>)?|<SP_BS>)/.source
|
|
.replace(/<SP_BS>/g, function () { return spaceAfterBackSlash; });
|
|
|
|
var string = /"(?:[^"\\\r\n]|\\(?:\r\n|[\s\S]))*"|'(?:[^'\\\r\n]|\\(?:\r\n|[\s\S]))*'/.source;
|
|
var option = /--[\w-]+=(?:<STR>|(?!["'])(?:[^\s\\]|\\.)+)/.source.replace(/<STR>/g, function () { return string; });
|
|
|
|
var stringRule = {
|
|
pattern: RegExp(string),
|
|
greedy: true
|
|
};
|
|
var commentRule = {
|
|
pattern: /(^[ \t]*)#.*/m,
|
|
lookbehind: true,
|
|
greedy: true
|
|
};
|
|
|
|
/**
|
|
* @param {string} source
|
|
* @param {string} flags
|
|
* @returns {RegExp}
|
|
*/
|
|
function re(source, flags) {
|
|
source = source
|
|
.replace(/<OPT>/g, function () { return option; })
|
|
.replace(/<SP>/g, function () { return space; });
|
|
|
|
return RegExp(source, flags);
|
|
}
|
|
|
|
Prism.languages.docker = {
|
|
'instruction': {
|
|
pattern: /(^[ \t]*)(?:ADD|ARG|CMD|COPY|ENTRYPOINT|ENV|EXPOSE|FROM|HEALTHCHECK|LABEL|MAINTAINER|ONBUILD|RUN|SHELL|STOPSIGNAL|USER|VOLUME|WORKDIR)(?=\s)(?:\\.|[^\r\n\\])*(?:\\$(?:\s|#.*$)*(?![\s#])(?:\\.|[^\r\n\\])*)*/im,
|
|
lookbehind: true,
|
|
greedy: true,
|
|
inside: {
|
|
'options': {
|
|
pattern: re(/(^(?:ONBUILD<SP>)?\w+<SP>)<OPT>(?:<SP><OPT>)*/.source, 'i'),
|
|
lookbehind: true,
|
|
greedy: true,
|
|
inside: {
|
|
'property': {
|
|
pattern: /(^|\s)--[\w-]+/,
|
|
lookbehind: true
|
|
},
|
|
'string': [
|
|
stringRule,
|
|
{
|
|
pattern: /(=)(?!["'])(?:[^\s\\]|\\.)+/,
|
|
lookbehind: true
|
|
}
|
|
],
|
|
'operator': /\\$/m,
|
|
'punctuation': /=/
|
|
}
|
|
},
|
|
'keyword': [
|
|
{
|
|
// https://docs.docker.com/engine/reference/builder/#healthcheck
|
|
pattern: re(/(^(?:ONBUILD<SP>)?HEALTHCHECK<SP>(?:<OPT><SP>)*)(?:CMD|NONE)\b/.source, 'i'),
|
|
lookbehind: true,
|
|
greedy: true
|
|
},
|
|
{
|
|
// https://docs.docker.com/engine/reference/builder/#from
|
|
pattern: re(/(^(?:ONBUILD<SP>)?FROM<SP>(?:<OPT><SP>)*(?!--)[^ \t\\]+<SP>)AS/.source, 'i'),
|
|
lookbehind: true,
|
|
greedy: true
|
|
},
|
|
{
|
|
// https://docs.docker.com/engine/reference/builder/#onbuild
|
|
pattern: re(/(^ONBUILD<SP>)\w+/.source, 'i'),
|
|
lookbehind: true,
|
|
greedy: true
|
|
},
|
|
{
|
|
pattern: /^\w+/,
|
|
greedy: true
|
|
}
|
|
],
|
|
'comment': commentRule,
|
|
'string': stringRule,
|
|
'variable': /\$(?:\w+|\{[^{}"'\\]*\})/,
|
|
'operator': /\\$/m
|
|
}
|
|
},
|
|
'comment': commentRule
|
|
};
|
|
|
|
Prism.languages.dockerfile = Prism.languages.docker;
|
|
|
|
}(Prism));
|