详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
144 lines
3.2 KiB
JavaScript
144 lines
3.2 KiB
JavaScript
/**
|
|
* @import {
|
|
* Extension,
|
|
* Handles,
|
|
* HtmlExtension,
|
|
* NormalizedExtension
|
|
* } from 'micromark-util-types'
|
|
*/
|
|
|
|
import {splice} from 'micromark-util-chunked'
|
|
|
|
const hasOwnProperty = {}.hasOwnProperty
|
|
|
|
/**
|
|
* Combine multiple syntax extensions into one.
|
|
*
|
|
* @param {ReadonlyArray<Extension>} extensions
|
|
* List of syntax extensions.
|
|
* @returns {NormalizedExtension}
|
|
* A single combined extension.
|
|
*/
|
|
export function combineExtensions(extensions) {
|
|
/** @type {NormalizedExtension} */
|
|
const all = {}
|
|
let index = -1
|
|
|
|
while (++index < extensions.length) {
|
|
syntaxExtension(all, extensions[index])
|
|
}
|
|
|
|
return all
|
|
}
|
|
|
|
/**
|
|
* Merge `extension` into `all`.
|
|
*
|
|
* @param {NormalizedExtension} all
|
|
* Extension to merge into.
|
|
* @param {Extension} extension
|
|
* Extension to merge.
|
|
* @returns {undefined}
|
|
* Nothing.
|
|
*/
|
|
function syntaxExtension(all, extension) {
|
|
/** @type {keyof Extension} */
|
|
let hook
|
|
|
|
for (hook in extension) {
|
|
const maybe = hasOwnProperty.call(all, hook) ? all[hook] : undefined
|
|
/** @type {Record<string, unknown>} */
|
|
const left = maybe || (all[hook] = {})
|
|
/** @type {Record<string, unknown> | undefined} */
|
|
const right = extension[hook]
|
|
/** @type {string} */
|
|
let code
|
|
|
|
if (right) {
|
|
for (code in right) {
|
|
if (!hasOwnProperty.call(left, code)) left[code] = []
|
|
const value = right[code]
|
|
constructs(
|
|
// @ts-expect-error Looks like a list.
|
|
left[code],
|
|
Array.isArray(value) ? value : value ? [value] : []
|
|
)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Merge `list` into `existing` (both lists of constructs).
|
|
* Mutates `existing`.
|
|
*
|
|
* @param {Array<unknown>} existing
|
|
* List of constructs to merge into.
|
|
* @param {Array<unknown>} list
|
|
* List of constructs to merge.
|
|
* @returns {undefined}
|
|
* Nothing.
|
|
*/
|
|
function constructs(existing, list) {
|
|
let index = -1
|
|
/** @type {Array<unknown>} */
|
|
const before = []
|
|
|
|
while (++index < list.length) {
|
|
// @ts-expect-error Looks like an object.
|
|
;(list[index].add === 'after' ? existing : before).push(list[index])
|
|
}
|
|
|
|
splice(existing, 0, 0, before)
|
|
}
|
|
|
|
/**
|
|
* Combine multiple HTML extensions into one.
|
|
*
|
|
* @param {ReadonlyArray<HtmlExtension>} htmlExtensions
|
|
* List of HTML extensions.
|
|
* @returns {HtmlExtension}
|
|
* Single combined HTML extension.
|
|
*/
|
|
export function combineHtmlExtensions(htmlExtensions) {
|
|
/** @type {HtmlExtension} */
|
|
const handlers = {}
|
|
let index = -1
|
|
|
|
while (++index < htmlExtensions.length) {
|
|
htmlExtension(handlers, htmlExtensions[index])
|
|
}
|
|
|
|
return handlers
|
|
}
|
|
|
|
/**
|
|
* Merge `extension` into `all`.
|
|
*
|
|
* @param {HtmlExtension} all
|
|
* Extension to merge into.
|
|
* @param {HtmlExtension} extension
|
|
* Extension to merge.
|
|
* @returns {undefined}
|
|
* Nothing.
|
|
*/
|
|
function htmlExtension(all, extension) {
|
|
/** @type {keyof HtmlExtension} */
|
|
let hook
|
|
|
|
for (hook in extension) {
|
|
const maybe = hasOwnProperty.call(all, hook) ? all[hook] : undefined
|
|
const left = maybe || (all[hook] = {})
|
|
const right = extension[hook]
|
|
/** @type {keyof Handles} */
|
|
let type
|
|
|
|
if (right) {
|
|
for (type in right) {
|
|
// @ts-expect-error assume document vs regular handler are managed correctly.
|
|
left[type] = right[type]
|
|
}
|
|
}
|
|
}
|
|
}
|