详细说明: - 基于文旅订单班框架复制创建food-order-demo项目 - 修改端口配置为4174避免冲突 - 更新LandingPage为青莳轻食主题(绿色健康风格) - 重新定义7个食品行业专业Agent: * 市场研究专家:轻食市场分析、客群画像 * 营养配方师:营养成分配比、低卡高蛋白设计 * 供应链管理专家:有机食材供应、溯源体系 * 品牌策划师:品牌定位、店铺空间布局 * 财务分析师:投资预算、ROI分析 * 运营管理专家:运营流程、品控标准 * 食品创业导师:中央协调、方案整合 - 创建专用启动脚本start.sh - 验证系统可正常运行在端口4174 - 实现代码复用率90%,符合预期目标 影响文件: web_frontend/food-order-demo/ 技术栈: React 18 + TypeScript + Tailwind CSS + Zustand
88 lines
2.1 KiB
JavaScript
88 lines
2.1 KiB
JavaScript
/**
|
|
* @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext
|
|
* @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension
|
|
* @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle
|
|
*
|
|
* @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle
|
|
* @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension
|
|
*
|
|
* @typedef {import('../index.js').MdxjsEsm} MdxjsEsm
|
|
*/
|
|
|
|
// To do: next major: expose functions.
|
|
import {ok as assert} from 'devlop'
|
|
|
|
/**
|
|
* Create an extension for `mdast-util-from-markdown` to enable MDX.js ESM in
|
|
* markdown.
|
|
*
|
|
* When using the micromark syntax extension with `addResult`, nodes will have
|
|
* a `data.estree` field set to an ESTree [`Program`][program] node.
|
|
*
|
|
* @returns {FromMarkdownExtension}
|
|
* Extension for `mdast-util-from-markdown` to enable MDX.js ESM.
|
|
*/
|
|
export function mdxjsEsmFromMarkdown() {
|
|
return {
|
|
enter: {mdxjsEsm: enterMdxjsEsm},
|
|
exit: {mdxjsEsm: exitMdxjsEsm, mdxjsEsmData: exitMdxjsEsmData}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Create an extension for `mdast-util-to-markdown` to enable MDX.js ESM in
|
|
* markdown.
|
|
*
|
|
* @returns {ToMarkdownExtension}
|
|
* Extension for `mdast-util-to-markdown` to enable MDX.js ESM.
|
|
*/
|
|
export function mdxjsEsmToMarkdown() {
|
|
return {handlers: {mdxjsEsm: handleMdxjsEsm}}
|
|
}
|
|
|
|
/**
|
|
* @this {CompileContext}
|
|
* @type {FromMarkdownHandle}
|
|
*/
|
|
function enterMdxjsEsm(token) {
|
|
this.enter({type: 'mdxjsEsm', value: ''}, token)
|
|
this.buffer() // Capture EOLs
|
|
}
|
|
|
|
/**
|
|
* @this {CompileContext}
|
|
* @type {FromMarkdownHandle}
|
|
*/
|
|
function exitMdxjsEsm(token) {
|
|
const value = this.resume()
|
|
const node = this.stack[this.stack.length - 1]
|
|
assert(node.type === 'mdxjsEsm')
|
|
|
|
this.exit(token)
|
|
|
|
const estree = token.estree
|
|
|
|
node.value = value
|
|
|
|
if (estree) {
|
|
node.data = {estree}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @this {CompileContext}
|
|
* @type {FromMarkdownHandle}
|
|
*/
|
|
function exitMdxjsEsmData(token) {
|
|
this.config.enter.data.call(this, token)
|
|
this.config.exit.data.call(this, token)
|
|
}
|
|
|
|
/**
|
|
* @type {ToMarkdownHandle}
|
|
* @param {MdxjsEsm} node
|
|
*/
|
|
function handleMdxjsEsm(node) {
|
|
return node.value || ''
|
|
}
|