详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
79 lines
2.0 KiB
JavaScript
79 lines
2.0 KiB
JavaScript
Prism.languages.haxe = Prism.languages.extend('clike', {
|
|
'string': {
|
|
// Strings can be multi-line
|
|
pattern: /"(?:[^"\\]|\\[\s\S])*"/,
|
|
greedy: true
|
|
},
|
|
'class-name': [
|
|
{
|
|
pattern: /(\b(?:abstract|class|enum|extends|implements|interface|new|typedef)\s+)[A-Z_]\w*/,
|
|
lookbehind: true,
|
|
},
|
|
// based on naming convention
|
|
/\b[A-Z]\w*/
|
|
],
|
|
// The final look-ahead prevents highlighting of keywords if expressions such as "haxe.macro.Expr"
|
|
'keyword': /\bthis\b|\b(?:abstract|as|break|case|cast|catch|class|continue|default|do|dynamic|else|enum|extends|extern|final|for|from|function|if|implements|import|in|inline|interface|macro|new|null|operator|overload|override|package|private|public|return|static|super|switch|throw|to|try|typedef|untyped|using|var|while)(?!\.)\b/,
|
|
'function': {
|
|
pattern: /\b[a-z_]\w*(?=\s*(?:<[^<>]*>\s*)?\()/i,
|
|
greedy: true
|
|
},
|
|
'operator': /\.{3}|\+\+|--|&&|\|\||->|=>|(?:<<?|>{1,3}|[-+*/%!=&|^])=?|[?:~]/
|
|
});
|
|
|
|
Prism.languages.insertBefore('haxe', 'string', {
|
|
'string-interpolation': {
|
|
pattern: /'(?:[^'\\]|\\[\s\S])*'/,
|
|
greedy: true,
|
|
inside: {
|
|
'interpolation': {
|
|
pattern: /(^|[^\\])\$(?:\w+|\{[^{}]+\})/,
|
|
lookbehind: true,
|
|
inside: {
|
|
'interpolation-punctuation': {
|
|
pattern: /^\$\{?|\}$/,
|
|
alias: 'punctuation'
|
|
},
|
|
'expression': {
|
|
pattern: /[\s\S]+/,
|
|
inside: Prism.languages.haxe
|
|
},
|
|
}
|
|
},
|
|
'string': /[\s\S]+/
|
|
}
|
|
}
|
|
});
|
|
|
|
Prism.languages.insertBefore('haxe', 'class-name', {
|
|
'regex': {
|
|
pattern: /~\/(?:[^\/\\\r\n]|\\.)+\/[a-z]*/,
|
|
greedy: true,
|
|
inside: {
|
|
'regex-flags': /\b[a-z]+$/,
|
|
'regex-source': {
|
|
pattern: /^(~\/)[\s\S]+(?=\/$)/,
|
|
lookbehind: true,
|
|
alias: 'language-regex',
|
|
inside: Prism.languages.regex
|
|
},
|
|
'regex-delimiter': /^~\/|\/$/,
|
|
}
|
|
}
|
|
});
|
|
|
|
Prism.languages.insertBefore('haxe', 'keyword', {
|
|
'preprocessor': {
|
|
pattern: /#(?:else|elseif|end|if)\b.*/,
|
|
alias: 'property'
|
|
},
|
|
'metadata': {
|
|
pattern: /@:?[\w.]+/,
|
|
alias: 'symbol'
|
|
},
|
|
'reification': {
|
|
pattern: /\$(?:\w+|(?=\{))/,
|
|
alias: 'important'
|
|
}
|
|
});
|