详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
100 lines
2.4 KiB
JavaScript
100 lines
2.4 KiB
JavaScript
// Thanks to: https://github.com/prometheus-community/monaco-promql/blob/master/src/promql/promql.ts
|
|
// As well as: https://kausal.co/blog/slate-prism-add-new-syntax-promql/
|
|
|
|
(function (Prism) {
|
|
// PromQL Aggregation Operators
|
|
// (https://prometheus.io/docs/prometheus/latest/querying/operators/#aggregation-operators)
|
|
var aggregations = [
|
|
'sum',
|
|
'min',
|
|
'max',
|
|
'avg',
|
|
'group',
|
|
'stddev',
|
|
'stdvar',
|
|
'count',
|
|
'count_values',
|
|
'bottomk',
|
|
'topk',
|
|
'quantile'
|
|
];
|
|
|
|
// PromQL vector matching + the by and without clauses
|
|
// (https://prometheus.io/docs/prometheus/latest/querying/operators/#vector-matching)
|
|
var vectorMatching = [
|
|
'on',
|
|
'ignoring',
|
|
'group_right',
|
|
'group_left',
|
|
'by',
|
|
'without',
|
|
];
|
|
|
|
// PromQL offset modifier
|
|
// (https://prometheus.io/docs/prometheus/latest/querying/basics/#offset-modifier)
|
|
var offsetModifier = ['offset'];
|
|
|
|
var keywords = aggregations.concat(vectorMatching, offsetModifier);
|
|
|
|
Prism.languages.promql = {
|
|
'comment': {
|
|
pattern: /(^[ \t]*)#.*/m,
|
|
lookbehind: true
|
|
},
|
|
'vector-match': {
|
|
// Match the comma-separated label lists inside vector matching:
|
|
pattern: new RegExp('((?:' + vectorMatching.join('|') + ')\\s*)\\([^)]*\\)'),
|
|
lookbehind: true,
|
|
inside: {
|
|
'label-key': {
|
|
pattern: /\b[^,]+\b/,
|
|
alias: 'attr-name',
|
|
},
|
|
'punctuation': /[(),]/
|
|
},
|
|
},
|
|
'context-labels': {
|
|
pattern: /\{[^{}]*\}/,
|
|
inside: {
|
|
'label-key': {
|
|
pattern: /\b[a-z_]\w*(?=\s*(?:=|![=~]))/,
|
|
alias: 'attr-name',
|
|
},
|
|
'label-value': {
|
|
pattern: /(["'`])(?:\\[\s\S]|(?!\1)[^\\])*\1/,
|
|
greedy: true,
|
|
alias: 'attr-value',
|
|
},
|
|
'punctuation': /\{|\}|=~?|![=~]|,/,
|
|
},
|
|
},
|
|
'context-range': [
|
|
{
|
|
pattern: /\[[\w\s:]+\]/, // [1m]
|
|
inside: {
|
|
'punctuation': /\[|\]|:/,
|
|
'range-duration': {
|
|
pattern: /\b(?:\d+(?:[smhdwy]|ms))+\b/i,
|
|
alias: 'number',
|
|
},
|
|
},
|
|
},
|
|
{
|
|
pattern: /(\boffset\s+)\w+/, // offset 1m
|
|
lookbehind: true,
|
|
inside: {
|
|
'range-duration': {
|
|
pattern: /\b(?:\d+(?:[smhdwy]|ms))+\b/i,
|
|
alias: 'number',
|
|
},
|
|
},
|
|
},
|
|
],
|
|
'keyword': new RegExp('\\b(?:' + keywords.join('|') + ')\\b', 'i'),
|
|
'function': /\b[a-z_]\w*(?=\s*\()/i,
|
|
'number': /[-+]?(?:(?:\b\d+(?:\.\d+)?|\B\.\d+)(?:e[-+]?\d+)?\b|\b(?:0x[0-9a-f]+|nan|inf)\b)/i,
|
|
'operator': /[\^*/%+-]|==|!=|<=|<|>=|>|\b(?:and|or|unless)\b/i,
|
|
'punctuation': /[{};()`,.[\]]/,
|
|
};
|
|
}(Prism));
|