neo-cmp-cli 1.10.2 → 1.10.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index2.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./_virtual/index.js"),s=require("figlet"),o=require("yargs"),n=require("chalk"),a=require("inquirer"),t=require("ora"),i=require("./main2.js"),p=require("./neo/env.js"),c=require("./package.json.js");var m;exports.__require=function(){if(m)return e.__exports;m=1;const r=s,l=o,u=n,d=a,g=t,{neoInit:h,neoInitByCopy:y,inspect:b,neoConfigInit:v,validateProjectName:C,getCmpTypeByDir:f,NeoService:x,NeoLoginService:$,hasNeoProject:T,consoleTag:U,errorLog:j,successLog:_}=i.__require(),w=i.__require(),{getNeoCrmAPI:q}=p.__require(),N=c.default,M=r.textSync("neo",{font:"Lean"}),S=w.projectConfig,D=function(e){return u.green(u.bold(e))},R={"config init":"初始化配置文件",dev:"开启本地调试模式",build:"构建生产环境代码",build2lib:"构建 UMD 模块",build2esm:"构建 ESM 模块",publish2oss:"发布到 OSS",inspect:"输出配置文件",open:"打开项目"},k={...R,init:"初始化自定义组件项目",login:"登录 NeoCRM 平台",logout:"登出 NeoCRM 平台","create project":"创建自定义组件项目","create cmp":"创建自定义组件",linkDebug:"开启外链调试模式","pull cmp":"拉取线上自定义组件","delete cmp":"删除线上自定义组件",preview:"预览自定义组件","push cmp":"发布自定义组件到平台"};return l.middleware(function(e){if(e.help||e.version)return;const s=function(e){if(!e._||0===e._.length)return"";const s=e._.join(" ");if(k[s])return s;const o=e._[0];return k[o]?o:s||o}(e);if(!s)return;const o=k[s]||s;R[s]&&(console.log(u.green(M)),console.log(u.green(`当前版本:v${N.version}.\n`))),console.log(""),console.log(u.cyan(`执行命令: ${o}`)),console.log("")}).command("init [options]","根据模板创建一个自定义组件",e=>{e.reset().usage(D("Usage")+": $0 init [options]").option("type",{alias:"t",describe:"自定义组件类型(react ts 技术栈/ vue2.0 技术栈/ react 技术栈)"}).option("name",{alias:"n",describe:"自定义组件项目名称"}).alias("h","help")},e=>{if(e.type&&e.name)T()&&(j(`${U}创建自定义组件失败,当前目录(${process.cwd()})已经是一个自定义组件项目,请勿重复创建。`),process.exit(1)),"github"===e.mode?h(e.type,e.name):y(e.type,e.name);else{const s=[],o=[{name:"react&ts 自定义组件",value:"react-ts",short:"react-ts"},{name:"Neo 自定义组件(使用平台实体数据源)",value:"neo",short:"neo"},{name:"antd 自定义组件",value:"antd",short:"antd"},{name:"echarts 自定义组件",value:"echarts",short:"echarts"},{name:"vue2 自定义组件",value:"vue2",short:"vue2"}];e.type||s.push({name:"type",type:"list",message:"请选择您要创建的自定义组件类型: ",default:"react-ts",choices:o}),e.name||s.push({name:"name",type:"input",message:"请设置自定义组件项目名称(默认 neoCustomCmp):",default:"neoCustomCmp"}),d.prompt(s).then(s=>{const{isValid:o,errors:n}=C(s.name);o||(j(n.join("\n")),process.exit(1)),"github"===e.mode?h(s.type,s.name):y(s.type,s.name)})}}).command("config init","创建 neo.config.js 配置文件",e=>{e.reset().usage(D("Usage")+": $0 config init").alias("h","help")},()=>{v("neo.config.js")}).command("login","登录 NeoCRM 平台(OAuth2 授权)",e=>{e.reset().usage(D("Usage")+": $0 login").alias("h","help")},()=>{const e=[{name:"env",type:"list",message:"请选择您要登录的环境:",default:"cd",choices:[{name:"线上生产环境(crm.xiaoshouyi.com)",value:"production"},{name:"灰度环境(crm-gray.xiaoshouyi.com)",value:"gray"},{name:"沙盒环境(crm-sandbox.xiaoshouyi.com)",value:"sandbox"},{name:"开发环境(crm-cd.xiaoshouyi.com)",value:"cd"},{name:"自定义环境(在neo.config.js / neoConfig 中自行配置)",value:"custom"}]}];d.prompt(e).then(async e=>{const s=q(e.env,S.neoConfig);try{const e=new $(s);await e.login(),process.exit(0)}catch(e){j(`\n登录失败: ${e.message||e.msg}`),process.exit(1)}})}).command("logout","登出 NeoCRM 平台",e=>{e.reset().usage(D("Usage")+": $0 logout").alias("h","help")},async()=>{try{const e=new $;await e.logout(),process.exit(0)}catch(e){j(`\n登出失败: ${e.message||e.msg}`),process.exit(1)}}).command("create","创建项目或者组件",e=>e.command("project [options]","创建自定义组件项目(含工程代码)",e=>{e.reset().usage(D("Usage")+": $0 project [options]").option("name",{alias:"n",describe:"自定义组件项目名称"}).alias("h","help")},e=>{if(e.name)w.createCmpProjectByTemplate(e.name);else{const e=[{name:"name",type:"input",message:"请设置自定义组件项目名称:"}];d.prompt(e).then(e=>{const{isValid:s,errors:o}=C(e.name);s||(j(o.join("\n")),process.exit(1)),e.name?w.createCmpProjectByTemplate(e.name):(j("自定义组件项目名称不能为空。"),process.exit(1))})}}).command("cmp [options]","创建自定义组件",e=>{e.reset().usage(D("Usage")+": $0 cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.createCmpByTemplate(e.name);else{const e=[{name:"name",type:"input",message:"请设置自定义组件名称:"}];d.prompt(e).then(e=>{e.name?w.createCmpByTemplate(e.name):(j("自定义组件名称不能为空。"),process.exit(1))})}})).command("pull cmp [options]","拉取线上自定义组件",e=>{e.reset().usage(D("Usage")+": $0 pull cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},async e=>{if(e.name)w.pullCmp(e.name);else{const e=new x,s=g("正在拉取线上自定义组件列表...").start(),o=await e.getCustomCmpList();0===o.length&&(j("当前租户暂无任何自定义组件。"),process.exit(1)),s.stop("线上自定义组件列表拉取成功。");const n=[{name:"cmpType",type:"list",message:"请选择要拉取的自定义组件:",choices:o.map(e=>({name:`${e.label}(${e.cmpType})`,value:e.cmpType}))}];d.prompt(n).then(s=>{s.cmpType?w.pullCmp(s.cmpType,e):(j("自定义组件名称不能为空。"),process.exit(1))})}}).command("delete cmp [options]","删除线上自定义组件",e=>{e.reset().usage(D("Usage")+": $0 delete cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},async e=>{if(e.name)w.deleteCmp(e.name);else{const e=new x,s=g("正在获取线上自定义组件列表...").start(),o=await e.getCustomCmpList();0===o.length&&(j("当前租户暂无任何自定义组件。"),process.exit(1)),s.stop("线上自定义组件列表获取成功。");const n=[{name:"cmpType",type:"list",message:"请选择要删除的自定义组件:",choices:o.map(e=>({name:`${e.label}(${e.cmpType})`,value:e.cmpType}))}];d.prompt(n).then(s=>{s.cmpType?w.deleteCmp(s.cmpType,e):(j("自定义组件名称不能为空。"),process.exit(1))})}}).command("preview [options]","预览指定自定义组件(仅预览组件本身内容)",e=>{e.reset().usage(D("Usage")+": $0 preview [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.previewCmp(e.name);else{const e=f();0===e.length&&(j("当前自定义组件目录中未找到自定义组件。(./src/components 目录下)"),process.exit(1));const s=[{name:"cmpType",type:"list",message:"请选择要预览的自定义组件:",choices:e.map(e=>({name:e,value:e}))}];d.prompt(s).then(e=>{e.cmpType||(j("未选择要预览的自定义组件。"),process.exit(1)),w.previewCmp(e.cmpType)})}}).command("dev","开启本地调试模式",e=>{e.reset().usage(D("Usage")+": $0 dev").alias("h","help")},()=>{w.dev()}).command("linkDebug","开启外链调试模式(在线上页面设计器端调试)",e=>{e.reset().usage(D("Usage")+": $0 linkDebug").alias("h","help")},e=>{w.linkDebug()}).command("build","构建生产环境代码",e=>{e.reset().usage(D("Usage")+": $0 build").alias("h","help")},e=>{w.build()}).command("build2lib","构建 UMD 模块",e=>{e.reset().usage(D("Usage")+": $0 build2lib").alias("h","help")},e=>{w.build2lib()}).command("publish2oss [options]","发布到oss",e=>{e.reset().usage(D("Usage")+": $0 publish2oss [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.publish2oss(e.name);else{const e=f();0===e.length&&(j("当前自定义组件目录中未找到自定义组件。(./src/components 目录下)"),process.exit(1));const s=[{name:"cmpType",type:"list",message:"请选择要发布的自定义组件:",choices:e.map(e=>({name:e,value:e}))}];d.prompt(s).then(e=>{e.cmpType||(j("未选择要发布的自定义组件。"),process.exit(1)),w.publish2oss(e.cmpType)})}}).command("push cmp [options]","构建并发布自定义组件到 NeoCRM 平台",e=>{e.reset().usage(D("Usage")+": $0 push cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.pushCmp(e.name);else{const e=f();0===e.length&&(j("当前自定义组件目录中未找到自定义组件。(./src/components 目录下)"),process.exit(1));const s=[{name:"cmpType",type:"list",message:"请选择要发布的自定义组件:",choices:e.map(e=>({name:e,value:e}))}];d.prompt(s).then(e=>{e.cmpType||(j("未选择要发布的自定义组件。"),process.exit(1)),w.pushCmp(e.cmpType)})}}).command("build2esm","构建 ESM 模块",e=>{e.reset().usage(D("Usage")+": $0 build2esm").alias("h","help")},()=>{w.build2esm()}).command("inspect","输出当前配置文件",e=>{e.reset().usage(D("Usage")+": $0 inspect").option("type",{alias:"t",describe:"环境类型(本地调试环境/生产环境/library构建环境)",default:"build"}).alias("h","help")},e=>{b(e.type)}).command("open [options]","使用 Cursor 或 VSCode 打开项目",e=>{e.reset().usage(D("Usage")+": $0 open [options]").option("editor",{alias:"e",describe:"编辑器类型(cursor/vscode/auto),默认为 auto(自动检测)",default:"auto",choices:["cursor","vscode","code","auto"]}).option("name",{alias:"n",describe:"要打开的项目名称,默认为当前目录"}).alias("h","help")},e=>{w.openEditor(e.editor,e.name)}).alias("h","help").alias("v","version").strict().fail((e,s,o)=>{j(`\n运行命令时发生错误: ${e}。\n`),console.log(D("当前可用命令列表:")),console.log("");[{cmd:"init [options]",desc:"根据模板创建一个自定义组件"},{cmd:"create project [options]",desc:"创建自定义组件项目(含工程代码)"},{cmd:"create cmp [options]",desc:"创建自定义组件"},{cmd:"preview [options]",desc:"预览指定自定义组件(仅预览组件本身内容)"},{cmd:"linkDebug",desc:"开启外链调试模式(在线上页面设计器端调试)"},{cmd:"login",desc:"登录 NeoCRM 平台(OAuth2 授权)"},{cmd:"logout",desc:"登出 NeoCRM 平台"},{cmd:"pull cmp [options]",desc:"拉取线上自定义组件"},{cmd:"delete cmp [options]",desc:"删除线上自定义组件"},{cmd:"push cmp [options]",desc:"构建并发布自定义组件到 NeoCRM 平台"},{cmd:"open [options]",desc:"使用 Cursor 或 VSCode 打开项目"}].forEach(({cmd:e,desc:s})=>{console.log(` ${u.cyan(e.padEnd(25))} ${s}`)}),console.log(""),console.log(`使用 ${u.cyan("neo <command> --help")} 查看具体命令的帮助信息。`),console.log(""),process.exit(1)}).help().updateStrings({"Usage:":D("Usage:"),"Commands:":D("Commands:"),"Options:":D("Options:")}).argv,e.__exports};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./_virtual/index.js"),s=require("figlet"),o=require("yargs"),n=require("chalk"),a=require("inquirer"),t=require("ora"),i=require("./main2.js"),p=require("./neo/env.js"),c=require("./package.json.js");var m;exports.__require=function(){if(m)return e.__exports;m=1;const r=s,l=o,u=n,d=a,g=t,{neoInit:h,neoInitByCopy:y,inspect:b,neoConfigInit:v,validateProjectName:C,getCmpTypeByDir:f,NeoService:x,NeoLoginService:$,hasNeoProject:T,consoleTag:U,errorLog:j,successLog:_}=i.__require(),w=i.__require(),{getNeoCrmAPI:q}=p.__require(),N=c.default,M=r.textSync("neo",{font:"Lean"}),S=w.projectConfig,D=function(e){return u.green(u.bold(e))},R={"config init":"初始化配置文件",dev:"开启本地调试模式",build:"构建生产环境代码",build2lib:"构建 UMD 模块",build2esm:"构建 ESM 模块",publish2oss:"发布到 OSS",inspect:"输出配置文件",open:"打开项目"},k={...R,init:"初始化自定义组件项目",login:"登录 NeoCRM 平台",logout:"登出 NeoCRM 平台","create project":"创建自定义组件项目","create cmp":"创建自定义组件",linkDebug:"开启外链调试模式","pull cmp":"拉取线上自定义组件","delete cmp":"删除线上自定义组件",preview:"预览自定义组件","push cmp":"发布自定义组件到平台"};return l.middleware(function(e){if(e.help||e.version)return;const s=function(e){if(!e._||0===e._.length)return"";const s=e._.join(" ");if(k[s])return s;const o=e._[0];return k[o]?o:s||o}(e);if(!s)return;const o=k[s]||s;R[s]&&(console.log(u.green(M)),console.log(u.green(`当前版本:v${N.version}.\n`))),console.log(""),console.log(u.cyan(`执行命令: ${o}`)),console.log("")}).command("init [options]","根据模板创建一个自定义组件",e=>{e.reset().usage(D("Usage")+": $0 init [options]").option("type",{alias:"t",describe:"自定义组件类型(react ts 技术栈/ vue2.0 技术栈/ react 技术栈)"}).option("name",{alias:"n",describe:"自定义组件项目名称"}).alias("h","help")},e=>{if(e.type&&e.name)T()&&(j(`${U}创建自定义组件失败,当前目录(${process.cwd()})已经是一个自定义组件项目,请勿重复创建。`),process.exit(1)),"github"===e.mode?h(e.type,e.name):y(e.type,e.name);else{const s=[],o=[{name:"react&ts 自定义组件",value:"react-ts",short:"react-ts"},{name:"Neo 自定义组件(使用平台实体数据源)",value:"neo",short:"neo"},{name:"antd 自定义组件",value:"antd",short:"antd"},{name:"echarts 自定义组件",value:"echarts",short:"echarts"},{name:"vue2 自定义组件",value:"vue2",short:"vue2"}];e.type||s.push({name:"type",type:"list",message:"请选择您要创建的自定义组件类型: ",default:"react-ts",choices:o}),e.name||s.push({name:"name",type:"input",message:"请设置自定义组件项目名称(默认 neoCustomCmp):",default:"neoCustomCmp"}),d.prompt(s).then(s=>{const{isValid:o,errors:n}=C(s.name);o||(j(n.join("\n")),process.exit(1)),"github"===e.mode?h(s.type,s.name):y(s.type,s.name)})}}).command("config init","创建 neo.config.js 配置文件",e=>{e.reset().usage(D("Usage")+": $0 config init").alias("h","help")},()=>{v("neo.config.js")}).command("login","登录 NeoCRM 平台(OAuth2 授权)",e=>{e.reset().usage(D("Usage")+": $0 login").alias("h","help")},()=>{const e=[{name:"env",type:"list",message:"请选择您要登录的环境:",default:"cd",choices:[{name:"线上生产环境(crm.xiaoshouyi.com)",value:"production"},{name:"灰度环境(crm-gray.xiaoshouyi.com)",value:"gray"},{name:"沙盒环境(crm-sandbox.xiaoshouyi.com)",value:"sandbox"},{name:"开发环境(crm-cd.xiaoshouyi.com)",value:"cd"},{name:"自定义环境(在neo.config.js / neoConfig 中自行配置)",value:"custom"}]}];d.prompt(e).then(async e=>{const s=q(e.env,S.neoConfig);try{const e=new $(s);await e.login(),process.exit(0)}catch(e){j(`\n登录失败: ${e.message||e.msg}`),process.exit(1)}})}).command("logout","登出 NeoCRM 平台",e=>{e.reset().usage(D("Usage")+": $0 logout").alias("h","help")},async()=>{try{const e=new $;await e.logout(),process.exit(0)}catch(e){j(`\n登出失败: ${e.message||e.msg}`),process.exit(1)}}).command("create","创建项目或者组件",e=>e.command("project [options]","创建自定义组件项目(含工程代码)",e=>{e.reset().usage(D("Usage")+": $0 project [options]").option("name",{alias:"n",describe:"自定义组件项目名称"}).alias("h","help")},e=>{if(e.name)w.createCmpProjectByTemplate(e.name);else{const e=[{name:"name",type:"input",message:"请设置自定义组件项目名称:"}];d.prompt(e).then(e=>{const{isValid:s,errors:o}=C(e.name);s||(j(o.join("\n")),process.exit(1)),e.name?w.createCmpProjectByTemplate(e.name):(j("自定义组件项目名称不能为空。"),process.exit(1))})}}).command("cmp [options]","创建自定义组件",e=>{e.reset().usage(D("Usage")+": $0 cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.createCmpByTemplate(e.name);else{const e=[{name:"name",type:"input",message:"请设置自定义组件名称:"}];d.prompt(e).then(e=>{e.name?w.createCmpByTemplate(e.name):(j("自定义组件名称不能为空。"),process.exit(1))})}})).command("pull cmp [options]","拉取线上自定义组件",e=>{e.reset().usage(D("Usage")+": $0 pull cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},async e=>{if(e.name)w.pullCmp(e.name);else{const e=new x,s=g("正在拉取线上自定义组件列表...").start(),o=await e.getCustomCmpList();0===o.length&&(j("当前租户暂无任何自定义组件。"),process.exit(1)),s.stop("线上自定义组件列表拉取成功。");const n=[{name:"cmpType",type:"list",message:"请选择要拉取的自定义组件:",choices:o.map(e=>({name:`${e.label}(${e.cmpType})`,value:e.cmpType}))}];d.prompt(n).then(s=>{s.cmpType?w.pullCmp(s.cmpType,e):(j("自定义组件名称不能为空。"),process.exit(1))})}}).command("delete cmp [options]","删除线上自定义组件",e=>{e.reset().usage(D("Usage")+": $0 delete cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},async e=>{if(e.name)w.deleteCmp(e.name);else{const e=new x,s=g("正在获取线上自定义组件列表...").start(),o=await e.getCustomCmpList();0===o.length&&(j("当前租户暂无任何自定义组件。"),process.exit(1)),s.stop("线上自定义组件列表获取成功。");const n=[{name:"cmpType",type:"list",message:"请选择要删除的自定义组件:",choices:o.map(e=>({name:`${e.label}(${e.cmpType})`,value:e.cmpType}))}];d.prompt(n).then(s=>{s.cmpType?w.deleteCmp(s.cmpType,e):(j("自定义组件名称不能为空。"),process.exit(1))})}}).command("preview [options]","预览指定自定义组件(仅预览组件本身内容)",e=>{e.reset().usage(D("Usage")+": $0 preview [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.previewCmp(e.name);else{const e=f(S.componentsDir);0===e.length&&(j("当前自定义组件目录中未找到自定义组件。(./src/components 目录下)"),process.exit(1));const s=[{name:"cmpType",type:"list",message:"请选择要预览的自定义组件:",choices:e.map(e=>({name:e,value:e}))}];d.prompt(s).then(e=>{e.cmpType||(j("未选择要预览的自定义组件。"),process.exit(1)),w.previewCmp(e.cmpType)})}}).command("dev","开启本地调试模式",e=>{e.reset().usage(D("Usage")+": $0 dev").alias("h","help")},()=>{w.dev()}).command("linkDebug","开启外链调试模式(在线上页面设计器端调试)",e=>{e.reset().usage(D("Usage")+": $0 linkDebug").alias("h","help")},e=>{w.linkDebug()}).command("build","构建生产环境代码",e=>{e.reset().usage(D("Usage")+": $0 build").alias("h","help")},e=>{w.build()}).command("build2lib","构建 UMD 模块",e=>{e.reset().usage(D("Usage")+": $0 build2lib").alias("h","help")},e=>{w.build2lib()}).command("publish2oss [options]","发布到oss",e=>{e.reset().usage(D("Usage")+": $0 publish2oss [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.publish2oss(e.name);else{const e=f(S.componentsDir);0===e.length&&(j("当前自定义组件目录中未找到自定义组件。(./src/components 目录下)"),process.exit(1));const s=[{name:"cmpType",type:"list",message:"请选择要发布的自定义组件:",choices:e.map(e=>({name:e,value:e}))}];d.prompt(s).then(e=>{e.cmpType||(j("未选择要发布的自定义组件。"),process.exit(1)),w.publish2oss(e.cmpType)})}}).command("push cmp [options]","构建并发布自定义组件到 NeoCRM 平台",e=>{e.reset().usage(D("Usage")+": $0 push cmp [options]").option("name",{alias:"n",describe:"自定义组件名称"}).alias("h","help")},e=>{if(e.name)w.pushCmp(e.name);else{const e=f(S.componentsDir);0===e.length&&(j("当前自定义组件目录中未找到自定义组件。(./src/components 目录下)"),process.exit(1));const s=[{name:"cmpType",type:"list",message:"请选择要发布的自定义组件:",choices:e.map(e=>({name:e,value:e}))}];d.prompt(s).then(e=>{e.cmpType||(j("未选择要发布的自定义组件。"),process.exit(1)),w.pushCmp(e.cmpType)})}}).command("build2esm","构建 ESM 模块",e=>{e.reset().usage(D("Usage")+": $0 build2esm").alias("h","help")},()=>{w.build2esm()}).command("inspect","输出当前配置文件",e=>{e.reset().usage(D("Usage")+": $0 inspect").option("type",{alias:"t",describe:"环境类型(本地调试环境/生产环境/library构建环境)",default:"build"}).alias("h","help")},e=>{b(e.type)}).command("open [options]","使用 Cursor 或 VSCode 打开项目",e=>{e.reset().usage(D("Usage")+": $0 open [options]").option("editor",{alias:"e",describe:"编辑器类型(cursor/vscode/auto),默认为 auto(自动检测)",default:"auto",choices:["cursor","vscode","code","auto"]}).option("name",{alias:"n",describe:"要打开的项目名称,默认为当前目录"}).alias("h","help")},e=>{w.openEditor(e.editor,e.name)}).alias("h","help").alias("v","version").strict().fail((e,s,o)=>{j(`\n运行命令时发生错误: ${e}。\n`),console.log(D("当前可用命令列表:")),console.log("");[{cmd:"init [options]",desc:"根据模板创建一个自定义组件"},{cmd:"create project [options]",desc:"创建自定义组件项目(含工程代码)"},{cmd:"create cmp [options]",desc:"创建自定义组件"},{cmd:"preview [options]",desc:"预览指定自定义组件(仅预览组件本身内容)"},{cmd:"linkDebug",desc:"开启外链调试模式(在线上页面设计器端调试)"},{cmd:"login",desc:"登录 NeoCRM 平台(OAuth2 授权)"},{cmd:"logout",desc:"登出 NeoCRM 平台"},{cmd:"pull cmp [options]",desc:"拉取线上自定义组件"},{cmd:"delete cmp [options]",desc:"删除线上自定义组件"},{cmd:"push cmp [options]",desc:"构建并发布自定义组件到 NeoCRM 平台"},{cmd:"open [options]",desc:"使用 Cursor 或 VSCode 打开项目"}].forEach(({cmd:e,desc:s})=>{console.log(` ${u.cyan(e.padEnd(25))} ${s}`)}),console.log(""),console.log(`使用 ${u.cyan("neo <command> --help")} 查看具体命令的帮助信息。`),console.log(""),process.exit(1)}).help().updateStrings({"Usage:":D("Usage:"),"Commands:":D("Commands:"),"Options:":D("Options:")}).argv,e.__exports};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("lodash");var e,n;exports.__require=function(){if(n)return e;n=1;const s=o,d={react:"^16.13.1","react-dom":"^16.13.1",mobx:"^6.3.0","mobx-react":"^7.0.0","mobx-state-tree":"^5.4.0",echarts:"5.4.2",antd:"4.9.4","antd-mobile":"2.3.4","@ant-design/icons":"^4.8.0","video-react":"0.14.1",axios:"^0.27.2",classnames:"^2.3.2",qs:"^6.11.0",lodash:"^4.17.21","neo-ui-component-web":"^1.0.0","neo-ui-common":"^1.0.0","neo-open-api":"^1.1.9",amis:"^1.1.5"};return e={initNeoRequire:()=>{window.neoRequire||(window.neoRequire=o=>window.__NeoCommonModules[o]||window[o])},addNeoCommonModules:o=>{if(window.__NeoCommonModules||(window.__NeoCommonModules={}),isPlainObject(o)){Object.keys(o).forEach(e=>{const n=o[e],s=window.__NeoCommonModules[e];s&&Object.keys(s).length<3?(window.__NeoCommonModules[e]=Object.assign(window.__NeoCommonModules[e],n),void 0!==n.__esModule&&(window.__NeoCommonModules[e].__esModule=n.__esModule),void 0!==n.default&&(window.__NeoCommonModules[e].default=n.default)):window.__NeoCommonModules[e]=n})}},addNeoRemoteDeps:o=>{window.__NeoCommonModules||(window.__NeoCommonModules={}),window.__NeoCommonModules.__neoRemoteDeps||(window.__NeoCommonModules.__neoRemoteDeps={}),s.isPlainObject(o)&&(window.__NeoCommonModules.__neoRemoteDeps=Object.assign(window.__NeoCommonModules.__neoRemoteDeps,o))},getExternalsByNeoCommonModules:o=>{const e={};return Object.keys(d).forEach(o=>{e[o]=`commonjs ${o}`}),o&&o.length>0&&o.forEach(o=>{e[o]=`commonjs ${o}`}),e}}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("lodash");var e,n;exports.__require=function(){if(n)return e;n=1;const s=o,d={react:"^16.13.1","react-dom":"^16.13.1",mobx:"^6.3.0","mobx-react":"^7.0.0","mobx-state-tree":"^5.4.0",echarts:"5.4.2",antd:"4.9.4","antd-mobile":"2.3.4","@ant-design/icons":"^4.8.0","video-react":"0.14.1",axios:"^0.27.2",classnames:"^2.3.2",qs:"^6.11.0",lodash:"^4.17.21","neo-ui-component-web":"^1.0.0","neo-ui-common":"^1.0.0","neo-open-api":"^1.1.9",amis:"^1.1.5"};return e={initNeoRequire:()=>{window.neoRequire||(window.neoRequire=o=>window.__NeoCommonModules[o]||window[o])},addNeoCommonModules:o=>{if(window.__NeoCommonModules||(window.__NeoCommonModules={}),isPlainObject(o)){Object.keys(o).forEach(e=>{const n=o[e],s=window.__NeoCommonModules[e];if(!Object.isFrozen(s)&&s&&Object.keys(s).length<3)try{window.__NeoCommonModules[e]=Object.assign(s,n),void 0!==n.__esModule&&(window.__NeoCommonModules[e].__esModule=n.__esModule),void 0!==n.default&&(window.__NeoCommonModules[e].default=n.default)}catch(o){console.warn(`window.__NeoCommonModules[${e}] Object.assign error:`,o),window.__NeoCommonModules[e]=n}else window.__NeoCommonModules[e]=n})}},addNeoRemoteDeps:o=>{window.__NeoCommonModules||(window.__NeoCommonModules={}),window.__NeoCommonModules.__neoRemoteDeps||(window.__NeoCommonModules.__neoRemoteDeps={}),s.isPlainObject(o)&&(window.__NeoCommonModules.__neoRemoteDeps=Object.assign(window.__NeoCommonModules.__neoRemoteDeps,o))},getExternalsByNeoCommonModules:o=>{const e={};return Object.keys(d).forEach(o=>{e[o]=`commonjs ${o}`}),o&&o.length>0&&o.forEach(o=>{e[o]=`commonjs ${o}`}),e}}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("axios"),t=require("form-data"),s=require("node:fs"),o=require("node:path"),i=require("ora"),r=require("lodash"),n=require("akfun"),a=require("./neoLogin.js"),c=require("../utils/projectUtils/updatePublishLog.js"),l=require("../utils/common.js"),h=require("./neoEnvManager.js"),u=require("../utils/tableLog.js");var d,p;exports.__require=function(){if(p)return d;p=1;const m=e,f=t,y=s,g=o,w=i,k=r,{resolve:A}=n,$=a.__require(),C=c.__require(),{getFramework:x,errorLog:T,successLog:F}=l.__require(),L=h.__require(),{tableLog:P}=u.__require(),b=["cmpType","label","componentCategory","description","framework","icon","iconUrl","orderNo","version","propsSchema","defaultProps","previewProps","events","functions","asset","modelAsset","cssAsset","codeLib"];return d=class{constructor(){const e=L.getEnvConfig(),{assetsRoot:t,auth:s,authType:o}=e||{};this.authType=o||"oauth2",this.NeoCrmAPI=e,"password"!==this.authType||s||(T("密码授权模式时,neo.config.js / neoConfig / auth 配置不能为空"),process.exit(1)),"password"===this.authType?s.client_id&&s.client_secret&&s.username&&s.password||(T("neo.config.js / neoConfig / auth 配置不完整(password 模式),需要包含 client_id、client_secret、username、password"),process.exit(1)):"oauth2"!=this.authType&&(T(`不支持的授权类型: ${this.authType},可选值:oauth2、password`),process.exit(1)),this.assetsRoot=t||A("dist"),this.auth=s,this.cmpList=[],this.cmpInfoMap={},this.tokenCache={token:null,expiresAt:null}}buildFullUrl(e){return e.startsWith("http://")||e.startsWith("https://")?e:`${this.NeoCrmAPI.neoBaseURL}${e}`}uploadAPI(){return this.buildFullUrl(this.NeoCrmAPI.uploadAPI)}saveAPI(){return this.buildFullUrl(this.NeoCrmAPI.saveAPI)}isTokenExpired(){return!this.tokenCache.token||!this.tokenCache.expiresAt||Date.now()>=this.tokenCache.expiresAt}async getToken(){return this.isTokenExpired()?"oauth2"===this.authType?await this.getTokenByOAuth2():await this.getTokenByPassword():this.tokenCache.token}async getTokenByPassword(){const e=w("获取 token(密码模式)...").start();if(!this.isTokenExpired())return F("使用缓存的 token。",e),this.tokenCache.token;const t=new URLSearchParams;t.append("grant_type","password"),t.append("client_id",this.auth.client_id),t.append("client_secret",this.auth.client_secret),t.append("username",this.auth.username),t.append("password",this.auth.password);const s=this.buildFullUrl(this.NeoCrmAPI.tokenURL);try{const o=await m.post(s,t.toString(),{headers:{"Content-Type":"application/x-www-form-urlencoded"}}),i=o.data||{},{access_token:r,expires_in:n}=i;r||(T("获取 token 失败(授权配置错误):响应中未包含 access_token,"+JSON.stringify(o.data),e),process.exit(1));const a=parseInt(n)||3600;return this.tokenCache={...i,token:r,expiresAt:Date.now()+1e3*(a-60)},e.clear(),e.stop(),r}catch(o){T("获取 token 失败",e),T(`\n获取 token 失败: ${o.message||o.msg}`),T(`\ntoken 授权地址: ${s}`),T(`\ntoken 请求参数: ${t}`),o.response&&T(`响应数据: ${JSON.stringify(o.response.data)}`),process.exit(1)}}async getTokenByOAuth2(){const e=w("获取 token(OAuth2 模式)...").start();try{const t={loginURL:this.NeoCrmAPI.loginURL,tokenURL:this.NeoCrmAPI.tokenURL},s=new $(t),o=await s.getAccessToken(),i=o.access_token;return this.tokenCache={...o,token:i,expiresAt:Date.now()+72e5},e.clear(),e.stop(),i}catch(t){T("获取 token 失败(OAuth2 模式)",e),T(`\n获取 token 失败: ${t.message||t.msg}`),t.response&&T(`响应数据: ${JSON.stringify(t.response.data)}`),process.exit(1)}}async refreshToken(){return this.tokenCache={token:null,expiresAt:null},await this.getToken()}async ensureValidToken(){if(!this.tokenCache.token)return await this.getToken();if(this.isTokenExpired()){const e=w("token 已过期,正在刷新...").start();try{const t=await this.refreshToken();return F("token 刷新成功。",e),t}catch(t){throw T("token 刷新失败。",e),t}}return this.tokenCache.token}async uploadFile(e,t={}){const s=await this.ensureValidToken();if(!e||"string"!=typeof e)throw new Error(`文件路径无效: ${e}`);if(!y.existsSync(e))throw new Error(`文件不存在: ${e}`);const o=y.statSync(e);if(!o.isFile())throw new Error(`路径不是文件: ${e}`);const i=t.maxSize||5242880;if(o.size>i){const e=(o.size/1024/1024).toFixed(2),t=(i/1024/1024).toFixed(2);throw new Error(`文件大小超过限制: ${e}MB > ${t}MB`)}if(0===o.size)throw new Error(`文件为空: ${e}`);const r=g.basename(e),n=(o.size/1024).toFixed(2),a=w(`正在上传文件: ${r} (${n}KB)...`).start();try{const o=new f,i=t.fieldName||"customComponentCode",n=y.createReadStream(e);o.append(i,n,r);const c=this.uploadAPI(),l=t.timeout||6e4,h={headers:{Authorization:`Bearer ${s}`,"xsy-inner-source":"bff",...o.getHeaders()},timeout:l,maxContentLength:1/0,maxBodyLength:1/0},u=await m.post(c,o,h);let d;const p=u.data;if(200!==u.status&&201!==u.status)throw new Error(`上传失败: HTTP ${u.status}`);if("string"==typeof p)d=p.trim();else{if(!p||"object"!=typeof p)throw new Error("响应数据格式不正确: "+typeof p);if(void 0!==p.code&&200!==p.code&&0!==p.code){const e=p.message||p.msg||"未知错误";throw new Error(`上传失败: ${e} (code: ${p.code})`)}d=void 0!==p.data?p.data:void 0!==p.url?p.url:void 0!==p.fileUrl?p.fileUrl:p}if(!d)throw new Error("返回的文件地址为空");let g;return"string"==typeof d?g=d:d&&"object"==typeof d&&d.url&&(g=d.url),F(`文件上传成功: ${r} -> ${g}`,a),g}catch(t){if(T(`上传文件失败: ${t.message||t.msg}, 文件路径: ${e}`,a),t.response){const e=t.response.status,s=t.response.statusText,o=t.response.data,i=t.config?.url||this.uploadAPI();if(T("\n========== 上传请求详情 =========="),T(`请求 URL: ${i}`),T(`HTTP 状态码: ${e} ${s}`),T(`响应数据: ${JSON.stringify(o)}`),T("==================================\n"),404===e)throw new Error(`上传 API 不存在 (404): ${i}\n请检查 neo.config.js 中的 neoBaseURL 配置是否正确,或者 API 路径是否存在。\n当前配置的 API 路径: ${this.NeoCrmAPI.uploadAPI}`)}else t.request&&T("请求已发送但未收到响应,请检查网络连接或代理配置。");throw t}}async publish2oss(e,t=[".js",".css",".zip"]){if(!e)return void T(`自定义组件名称不能为空: ${e}`);if(!y.existsSync(this.assetsRoot))return void T(`未找到自定义组件资源目录: ${this.assetsRoot}`);const s={cmpType:e},o=y.readdirSync(this.assetsRoot).map(async o=>{const i=g.join(this.assetsRoot,o),r=y.statSync(i),n=g.parse(i);if(r.isFile()&&t.includes(n.ext)){let t=k.camelCase(e);if(o.indexOf(t)<0)return;try{const e=await this.uploadFile(i);o.indexOf("Model")>-1?s.modelAsset=e:o.endsWith(".css")?s.cssAsset=e:o.endsWith(".zip")?s.codeLib=e:s.asset=e}catch(e){T(`文件上传失败(${o}):\n`),process.exit(1)}}});return await Promise.all(o),s&&s.cmpType&&(console.info("上传至 OSS 的文件信息:\n",s),C(s)),s}async getCmpAssets(e,t=[".js",".css",".zip"]){if(!e)return void T(`自定义组件名称不能为空: ${e}`);if(!y.existsSync(this.assetsRoot))return void T(`未找到自定义组件资源目录: ${this.assetsRoot}`);const s={cmpType:e};return y.readdirSync(this.assetsRoot).forEach(o=>{const i=g.join(this.assetsRoot,o),r=y.statSync(i),n=g.parse(i);if(r.isFile()&&t.includes(n.ext)){let t=k.camelCase(e);if(o.indexOf(t)<0)return;const n=5242880;if(r.size>n){const e=(r.size/1024/1024).toFixed(2),t=(n/1024/1024).toFixed(2);throw new Error(`${o} 文件大小超过限制: ${e}MB > ${t}MB`)}const a={fileContent:y.createReadStream(i),fileName:o,fileSize:r.size};o.indexOf("Model")>-1?s.modelAssetFile=a:o.endsWith(".css")?s.cssAssetFile=a:o.endsWith(".zip")?s.codeLibFile=a:s.assetFile=a}}),s}async updateCustomComponent(e){const t=await this.ensureValidToken();if(!e)throw new Error("componentData 不能为空");const s=w("正在保存自定义组件信息...").start();try{const o=this.saveAPI(),i=new f;e.assetFile&&i.append("assetFile",e.assetFile.fileContent,e.assetFile.fileName),e.modelAssetFile&&i.append("modelAssetFile",e.modelAssetFile.fileContent,e.modelAssetFile.fileName),e.cssAssetFile&&i.append("cssAssetFile",e.cssAssetFile.fileContent,e.cssAssetFile.fileName),e.codeLibFile&&i.append("codeLibFile",e.codeLibFile.fileContent,e.codeLibFile.fileName),i.append("component",JSON.stringify(k.omit(e,["assetFile","modelAssetFile","cssAssetFile","codeLibFile"])));const r=await m.post(o,i,{headers:{Authorization:`Bearer ${t}`,"xsy-inner-source":"bff",...i.getHeaders()},timeout:12e4,maxContentLength:1/0,maxBodyLength:1/0}),{code:n,message:a,msg:c}=r.data||{};n&&200!==n&&(T(`保存自定义组件信息失败: ${a||c||"未知错误"}`),process.exit(1)),s.clear(),s.stop()}catch(e){const t=e.message||e.msg;T(t?`保存自定义组件信息失败: ${t}`:`保存自定义组件信息失败: ${JSON.stringify(e)}`,s),process.exit(1)}}async getCustomCmpList(){const e=await this.ensureValidToken();try{let t=this.buildFullUrl(this.NeoCrmAPI.queryAll);t+=`&fields=${b.join(",")}`;const s=await m.get(t,{headers:{Authorization:`Bearer ${e}`,"xsy-inner-source":"bff","Content-Type":"application/json"}}),{code:o,message:i,msg:r}=s.data||{};o&&200!==o&&(T(`获取自定义组件列表失败: ${i||r||"未知错误"}`),process.exit(1)),this.updateCustomCmpList(s.data.data||[])}catch(e){const t=e.message||e.msg;T(t?`获取自定义组件列表失败: ${t}`:`响应数据: ${JSON.stringify(e)}`),process.exit(1)}return this.cmpList||[]}getCodeLibByCmpType(e){return e?this.buildFullUrl(this.NeoCrmAPI.getCodeLibAPI(e)):null}async deleteCmp(e){const t=await this.ensureValidToken();e||(T("自定义组件名称不能为空。"),process.exit(1));let s=this.buildFullUrl(this.NeoCrmAPI.delete);s+=`/${e}`;const o=await m.delete(s,{headers:{Authorization:`Bearer ${t}`,"xsy-inner-source":"bff","Content-Type":"application/json"}}),{code:i,message:r,msg:n,errorInfo:a}=o.data||{};return i&&200!==i&&(a&&a.length>0?P(a,{title:"删除自定义组件失败",columns:["reason","instance"],headers:{reason:"原因",instance:"实例"},align:{reason:"center",instance:"center"},padding:2,showBorder:!0}):T(`删除自定义组件失败: ${r||n||"未知错误"}`),process.exit(1)),o.data}getCmpListByFramework(e){if(!e)return this.cmpList;const t=x(e);return this.cmpList.filter(e=>e.framework===t)}getCmpInfoByCmpType(e){return e&&this.cmpInfoMap[e]||null}updateCustomCmpList(e){e&&Array.isArray(e)&&(this.cmpList=e,e.forEach(e=>{this.cmpInfoMap[e.cmpType]=e}))}async request(e,t,s={}){const o=await this.ensureValidToken(),{data:i,headers:r={},params:n}=s,a=this.buildFullUrl(t);try{const t=await m({method:e,url:a,data:i,params:n,headers:{Authorization:`Bearer ${o}`,"xsy-inner-source":"bff",...r}});if(t.data&&t.data.code&&200!==t.data.code)throw new Error(`请求失败: ${t.data.message||t.data.msg||"未知错误"}`);return t.data}catch(s){throw T(`请求失败 [${e} ${t}]: ${s.message||s.msg}`),s.response&&T(`响应数据: ${JSON.stringify(s.response.data)}`),s}}async get(e,t={}){return await this.request("GET",e,t)}async post(e,t={}){return await this.request("POST",e,t)}async put(e,t={}){return await this.request("PUT",e,t)}async delete(e,t={}){return await this.request("DELETE",e,t)}}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("axios"),t=require("form-data"),s=require("node:fs"),o=require("node:path"),i=require("ora"),r=require("lodash"),n=require("akfun"),a=require("./neoLogin.js"),c=require("../utils/projectUtils/updatePublishLog.js"),l=require("../utils/common.js"),h=require("./neoEnvManager.js"),u=require("../utils/tableLog.js");var d,p;exports.__require=function(){if(p)return d;p=1;const m=e,f=t,y=s,g=o,w=i,k=r,{resolve:A}=n,C=a.__require(),$=c.__require(),{getFramework:x,errorLog:T,successLog:F}=l.__require(),L=h.__require(),{tableLog:P}=u.__require(),b=["cmpType","label","componentCategory","description","framework","icon","iconUrl","orderNo","version","propsSchema","defaultProps","previewProps","events","functions","asset","modelAsset","cssAsset","codeLib"];return d=class{constructor(){const e=L.getEnvConfig(),{assetsRoot:t,auth:s,authType:o}=e||{};this.authType=o||"oauth2",this.NeoCrmAPI=e,"password"!==this.authType||s||(T("密码授权模式时,neo.config.js / neoConfig / auth 配置不能为空"),process.exit(1)),"password"===this.authType?s.client_id&&s.client_secret&&s.username&&s.password||(T("neo.config.js / neoConfig / auth 配置不完整(password 模式),需要包含 client_id、client_secret、username、password"),process.exit(1)):"oauth2"!=this.authType&&(T(`不支持的授权类型: ${this.authType},可选值:oauth2、password`),process.exit(1)),this.assetsRoot=t||A("dist"),this.auth=s,this.cmpList=[],this.cmpInfoMap={},this.tokenCache={token:null,expiresAt:null}}buildFullUrl(e){return e.startsWith("http://")||e.startsWith("https://")?e:`${this.NeoCrmAPI.neoBaseURL}${e}`}uploadAPI(){return this.buildFullUrl(this.NeoCrmAPI.uploadAPI)}saveAPI(){return this.buildFullUrl(this.NeoCrmAPI.saveAPI)}isTokenExpired(){return!this.tokenCache.token||!this.tokenCache.expiresAt||Date.now()>=this.tokenCache.expiresAt}async getToken(){return this.isTokenExpired()?"oauth2"===this.authType?await this.getTokenByOAuth2():await this.getTokenByPassword():this.tokenCache.token}async getTokenByPassword(){const e=w("获取 token(密码模式)...").start();if(!this.isTokenExpired())return F("使用缓存的 token。",e),this.tokenCache.token;const t=new URLSearchParams;t.append("grant_type","password"),t.append("client_id",this.auth.client_id),t.append("client_secret",this.auth.client_secret),t.append("username",this.auth.username),t.append("password",this.auth.password);const s=this.buildFullUrl(this.NeoCrmAPI.tokenURL);try{const o=await m.post(s,t.toString(),{headers:{"Content-Type":"application/x-www-form-urlencoded"}}),i=o.data||{},{access_token:r,expires_in:n}=i;r||(T("获取 token 失败(授权配置错误):响应中未包含 access_token,"+JSON.stringify(o.data),e),process.exit(1));const a=parseInt(n)||3600;return this.tokenCache={...i,token:r,expiresAt:Date.now()+1e3*(a-60)},e.clear(),e.stop(),r}catch(o){T("获取 token 失败",e),T(`\n获取 token 失败: ${o.message||o.msg}`),T(`\ntoken 授权地址: ${s}`),T(`\ntoken 请求参数: ${t}`),o.response&&T(`响应数据: ${JSON.stringify(o.response.data)}`),process.exit(1)}}async getTokenByOAuth2(){const e=w("获取 token(OAuth2 模式)...").start();try{const t={neoBaseURL:this.NeoCrmAPI.neoBaseURL,loginURL:this.NeoCrmAPI.loginURL,tokenURL:this.NeoCrmAPI.tokenURL},s=new C(t),o=await s.getAccessToken(),i=o.access_token;return this.tokenCache={...o,token:i,expiresAt:Date.now()+72e5},e.clear(),e.stop(),i}catch(t){T("获取 token 失败(OAuth2 模式)",e),T(`\n获取 token 失败: ${t.message||t.msg}`),t.response&&T(`响应数据: ${JSON.stringify(t.response.data)}`),process.exit(1)}}async refreshToken(){return this.tokenCache={token:null,expiresAt:null},await this.getToken()}async ensureValidToken(){if(!this.tokenCache.token)return await this.getToken();if(this.isTokenExpired()){const e=w("token 已过期,正在刷新...").start();try{const t=await this.refreshToken();return F("token 刷新成功。",e),t}catch(t){throw T("token 刷新失败。",e),t}}return this.tokenCache.token}async uploadFile(e,t={}){const s=await this.ensureValidToken();if(!e||"string"!=typeof e)throw new Error(`文件路径无效: ${e}`);if(!y.existsSync(e))throw new Error(`文件不存在: ${e}`);const o=y.statSync(e);if(!o.isFile())throw new Error(`路径不是文件: ${e}`);const i=t.maxSize||5242880;if(o.size>i){const e=(o.size/1024/1024).toFixed(2),t=(i/1024/1024).toFixed(2);throw new Error(`文件大小超过限制: ${e}MB > ${t}MB`)}if(0===o.size)throw new Error(`文件为空: ${e}`);const r=g.basename(e),n=(o.size/1024).toFixed(2),a=w(`正在上传文件: ${r} (${n}KB)...`).start();try{const o=new f,i=t.fieldName||"customComponentCode",n=y.createReadStream(e);o.append(i,n,r);const c=this.uploadAPI(),l=t.timeout||6e4,h={headers:{Authorization:`Bearer ${s}`,"xsy-inner-source":"bff",...o.getHeaders()},timeout:l,maxContentLength:1/0,maxBodyLength:1/0},u=await m.post(c,o,h);let d;const p=u.data;if(200!==u.status&&201!==u.status)throw new Error(`上传失败: HTTP ${u.status}`);if("string"==typeof p)d=p.trim();else{if(!p||"object"!=typeof p)throw new Error("响应数据格式不正确: "+typeof p);if(void 0!==p.code&&200!==p.code&&0!==p.code){const e=p.message||p.msg||"未知错误";throw new Error(`上传失败: ${e} (code: ${p.code})`)}d=void 0!==p.data?p.data:void 0!==p.url?p.url:void 0!==p.fileUrl?p.fileUrl:p}if(!d)throw new Error("返回的文件地址为空");let g;return"string"==typeof d?g=d:d&&"object"==typeof d&&d.url&&(g=d.url),F(`文件上传成功: ${r} -> ${g}`,a),g}catch(t){if(T(`上传文件失败: ${t.message||t.msg}, 文件路径: ${e}`,a),t.response){const e=t.response.status,s=t.response.statusText,o=t.response.data,i=t.config?.url||this.uploadAPI();if(T("\n========== 上传请求详情 =========="),T(`请求 URL: ${i}`),T(`HTTP 状态码: ${e} ${s}`),T(`响应数据: ${JSON.stringify(o)}`),T("==================================\n"),404===e)throw new Error(`上传 API 不存在 (404): ${i}\n请检查 neo.config.js 中的 neoBaseURL 配置是否正确,或者 API 路径是否存在。\n当前配置的 API 路径: ${this.NeoCrmAPI.uploadAPI}`)}else t.request&&T("请求已发送但未收到响应,请检查网络连接或代理配置。");throw t}}async publish2oss(e,t=[".js",".css",".zip"]){if(!e)return void T(`自定义组件名称不能为空: ${e}`);if(!y.existsSync(this.assetsRoot))return void T(`未找到自定义组件资源目录: ${this.assetsRoot}`);const s={cmpType:e},o=y.readdirSync(this.assetsRoot).map(async o=>{const i=g.join(this.assetsRoot,o),r=y.statSync(i),n=g.parse(i);if(r.isFile()&&t.includes(n.ext)){let t=k.camelCase(e);if(o.indexOf(t)<0)return;try{const e=await this.uploadFile(i);o.indexOf("Model")>-1?s.modelAsset=e:o.endsWith(".css")?s.cssAsset=e:o.endsWith(".zip")?s.codeLib=e:s.asset=e}catch(e){T(`文件上传失败(${o}):\n`),process.exit(1)}}});return await Promise.all(o),s&&s.cmpType&&(console.info("上传至 OSS 的文件信息:\n",s),$(s)),s}async getCmpAssets(e,t=[".js",".css",".zip"]){if(!e)return void T(`自定义组件名称不能为空: ${e}`);if(!y.existsSync(this.assetsRoot))return void T(`未找到自定义组件资源目录: ${this.assetsRoot}`);const s={cmpType:e};return y.readdirSync(this.assetsRoot).forEach(o=>{const i=g.join(this.assetsRoot,o),r=y.statSync(i),n=g.parse(i);if(r.isFile()&&t.includes(n.ext)){let t=k.camelCase(e);if(o.indexOf(t)<0)return;const n=5242880;if(r.size>n){const e=(r.size/1024/1024).toFixed(2),t=(n/1024/1024).toFixed(2);throw new Error(`${o} 文件大小超过限制: ${e}MB > ${t}MB`)}const a={fileContent:y.createReadStream(i),fileName:o,fileSize:r.size};o.indexOf("Model")>-1?s.modelAssetFile=a:o.endsWith(".css")?s.cssAssetFile=a:o.endsWith(".zip")?s.codeLibFile=a:s.assetFile=a}}),s}async updateCustomComponent(e){const t=await this.ensureValidToken();if(!e)throw new Error("componentData 不能为空");const s=w("正在保存自定义组件信息...").start();try{const o=this.saveAPI(),i=new f;e.assetFile&&i.append("assetFile",e.assetFile.fileContent,e.assetFile.fileName),e.modelAssetFile&&i.append("modelAssetFile",e.modelAssetFile.fileContent,e.modelAssetFile.fileName),e.cssAssetFile&&i.append("cssAssetFile",e.cssAssetFile.fileContent,e.cssAssetFile.fileName),e.codeLibFile&&i.append("codeLibFile",e.codeLibFile.fileContent,e.codeLibFile.fileName),i.append("component",JSON.stringify(k.omit(e,["assetFile","modelAssetFile","cssAssetFile","codeLibFile"])));const r=await m.post(o,i,{headers:{Authorization:`Bearer ${t}`,"xsy-inner-source":"bff",...i.getHeaders()},timeout:12e4,maxContentLength:1/0,maxBodyLength:1/0}),{code:n,message:a,msg:c}=r.data||{};n&&200!==n&&(T(`保存自定义组件信息失败: ${a||c||"未知错误"}`),process.exit(1)),s.clear(),s.stop()}catch(e){const t=e.message||e.msg;T(t?`保存自定义组件信息失败: ${t}`:`保存自定义组件信息失败: ${JSON.stringify(e)}`,s),process.exit(1)}}async getCustomCmpList(){const e=await this.ensureValidToken();try{let t=this.buildFullUrl(this.NeoCrmAPI.queryAll);t+=`&fields=${b.join(",")}`;const s=await m.get(t,{headers:{Authorization:`Bearer ${e}`,"xsy-inner-source":"bff","Content-Type":"application/json"}}),{code:o,message:i,msg:r}=s.data||{};o&&200!==o&&(T(`获取自定义组件列表失败: ${i||r||"未知错误"}`),process.exit(1)),this.updateCustomCmpList(s.data.data||[])}catch(e){const t=e.message||e.msg;T(t?`获取自定义组件列表失败: ${t}`:`响应数据: ${JSON.stringify(e)}`),process.exit(1)}return this.cmpList||[]}getCodeLibByCmpType(e){return e?this.buildFullUrl(this.NeoCrmAPI.getCodeLibAPI(e)):null}async deleteCmp(e){const t=await this.ensureValidToken();e||(T("自定义组件名称不能为空。"),process.exit(1));let s=this.buildFullUrl(this.NeoCrmAPI.delete);s+=`/${e}`;const o=await m.delete(s,{headers:{Authorization:`Bearer ${t}`,"xsy-inner-source":"bff","Content-Type":"application/json"}}),{code:i,message:r,msg:n,errorInfo:a}=o.data||{};return i&&200!==i&&(a&&a.length>0?P(a,{title:"删除自定义组件失败",columns:["reason","instance"],headers:{reason:"原因",instance:"实例"},align:{reason:"center",instance:"center"},padding:2,showBorder:!0}):T(`删除自定义组件失败: ${r||n||"未知错误"}`),process.exit(1)),o.data}getCmpListByFramework(e){if(!e)return this.cmpList;const t=x(e);return this.cmpList.filter(e=>e.framework===t)}getCmpInfoByCmpType(e){return e&&this.cmpInfoMap[e]||null}updateCustomCmpList(e){e&&Array.isArray(e)&&(this.cmpList=e,e.forEach(e=>{this.cmpInfoMap[e.cmpType]=e}))}async request(e,t,s={}){const o=await this.ensureValidToken(),{data:i,headers:r={},params:n}=s,a=this.buildFullUrl(t);try{const t=await m({method:e,url:a,data:i,params:n,headers:{Authorization:`Bearer ${o}`,"xsy-inner-source":"bff",...r}});if(t.data&&t.data.code&&200!==t.data.code)throw new Error(`请求失败: ${t.data.message||t.data.msg||"未知错误"}`);return t.data}catch(s){throw T(`请求失败 [${e} ${t}]: ${s.message||s.msg}`),s.response&&T(`响应数据: ${JSON.stringify(s.response.data)}`),s}}async get(e,t={}){return await this.request("GET",e,t)}async post(e,t={}){return await this.request("POST",e,t)}async put(e,t={}){return await this.request("PUT",e,t)}async delete(e,t={}){return await this.request("DELETE",e,t)}}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"}),require("lodash");const e=require("akfun"),r=require("ora"),t=require("./neoService.js"),s=require("../utils/common.js"),i=require("../utils/pathUtils.js"),o=require("../utils/cmpUtils/getCmpTypeByDir.js"),c=require("../utils/cmpUtils/createCmpByZip.js");var n,a;exports.__require=function(){if(a)return n;a=1;const{getConfigObj:p}=e,u=r,m=t.__require(),{getFramework:l,errorLog:g,successLog:q}=s.__require(),{catchCurPackageJson:f}=i.__require(),_=o.__require(),y=c.__require(),C=l(p(f()).framework);return n=async(e,r)=>{_().indexOf(e)>-1&&(g(`当前项目目录中已存在${e}自定义组件。(./src/components 目录下)`),process.exit(1));const t=u("正在拉取组件...").start();try{let s=r,i=[],o={},c=null;r?(i=r.cmpList||[],o=r.cmpInfoMap||{}):(s=new m,t.info("正在获取自定义组件列表..."),i=await s.getCustomCmpList(),o=s.cmpInfoMap||{}),0===i.length&&(g("拉取失败,当前租户暂无任何自定义组件。",t),process.exit(1)),c=s.getCmpInfoByCmpType(e),c||(g(`拉取失败,当前租户不存在${e}自定义组件。`,t),process.exit(1)),c.framework&&c.framework!==C&&(g(`拉取失败,${e}自定义组件与当前项目技术栈不一致。`,t),process.exit(1));const n=s.getCodeLibByCmpType(e),a=await s.ensureValidToken();await y(n,{token:a,cmpName:e,componentBaseDir:"./src/components"})||(g(`拉取失败,${e}自定义组件源码解析失败,请检查源码文件是否正确。`,t),process.exit(1)),q(`已成功拉取${e}自定义组件!\n`,t)}catch(e){throw g(`拉取自定义组件失败: ${e.message||e.msg}`,t),e}},n};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"}),require("lodash");const e=require("akfun"),r=require("ora"),t=require("./neoService.js"),i=require("../utils/common.js"),s=require("../utils/pathUtils.js"),o=require("../utils/cmpUtils/getCmpTypeByDir.js"),n=require("../utils/cmpUtils/createCmpByZip.js"),c=require("../config/index.js");var u,p;exports.__require=function(){if(p)return u;p=1;const{getConfigObj:a}=e,m=r,g=t.__require(),{getFramework:l,errorLog:q,successLog:f}=i.__require(),{catchCurPackageJson:_}=s.__require(),y=o.__require(),C=n.__require(),w=c.__require(),x=l(a(_()).framework);return u=async(e,r)=>{y(w.componentsDir).indexOf(e)>-1&&(q(`当前项目目录中已存在${e}自定义组件。(./src/components 目录下)`),process.exit(1));const t=m("正在拉取组件...").start();try{let i=r,s=[],o={},n=null;r?(s=r.cmpList||[],o=r.cmpInfoMap||{}):(i=new g,t.info("正在获取自定义组件列表..."),s=await i.getCustomCmpList(),o=i.cmpInfoMap||{}),0===s.length&&(q("拉取失败,当前租户暂无任何自定义组件。",t),process.exit(1)),n=i.getCmpInfoByCmpType(e),n||(q(`拉取失败,当前租户不存在${e}自定义组件。`,t),process.exit(1)),n.framework&&n.framework!==x&&(q(`拉取失败,${e}自定义组件与当前项目技术栈不一致。`,t),process.exit(1));const c=i.getCodeLibByCmpType(e),u=await i.ensureValidToken();await C(c,{token:u,cmpName:e,componentBaseDir:w.componentsDir})||(q(`拉取失败,${e}自定义组件源码解析失败,请检查源码文件是否正确。`,t),process.exit(1)),f(`已成功拉取${e}自定义组件!\n`,t)}catch(e){throw q(`拉取自定义组件失败: ${e.message||e.msg}`,t),e}},u};
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var e="1.10.1";const o={version:e};exports.default=o,exports.version=e;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});var e="1.10.5";const o={version:e};exports.default=o,exports.version=e;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("node:fs"),e=require("lodash"),n=require("../common.js"),s=require("../pathUtils.js");var d,m;exports.__require=function(){if(m)return d;m=1;const u=o,{isPlainObject:t}=e,{getRelativePathForWebpack:r}=n.__require(),{resolveToCurrentRoot:l}=s.__require();return d=(o,e)=>{const{exports:n,remoteDeps:s}=o;if(!n&&!s)return"";const d={},m={};Array.isArray(n)&&n.length>0?n.forEach(o=>{d[o]=require(o)}):t(n)&&Object.keys(n).length>0?Object.keys(n).forEach(o=>{const e=r(n[o]);d[o]=`require('${e}')`}):n&&(console.error("exports 格式不正确,请检查 neo.config.js 文件中的 neoCommonModule / exports 配置"),process.exit(1)),Array.isArray(s)&&s.length>0&&e.forEach(o=>{m[o]=s});let i="{\n";const c=Object.entries(d);c.forEach(([o,e],n)=>{const s=n===c.length-1;i+=` "${o}": ${e}${s?"":","}\n`}),i+="}";const _=`\n/**\n * 自定义组件 共享出来的依赖模块\n * 备注:可在其他模块中通过 neoRequire 中使用\n */\nimport { isPlainObject } from 'lodash';\nconst CustomCmpCommonModules = ${i};\nconst CustomCmpRemoteDeps = ${JSON.stringify(m)};\n\n// 用于添加共享的依赖模块\nconst addNeoCommonModules = (modules) => {\n if (!window.__NeoCommonModules) {\n window.__NeoCommonModules = {}\n }\n if (isPlainObject(modules)) {\n const moduleIds = Object.keys(modules)\n moduleIds.forEach((moduleId) => {\n const curModule = modules[moduleId];\n const curCommonModule = window.__NeoCommonModules[moduleId];\n \n if (curCommonModule && Object.keys(curCommonModule).length < 3) {\n window.__NeoCommonModules[moduleId] = Object.assign(window.__NeoCommonModules[moduleId], curModule);\n\n // 处理模块中的特殊属性\n if (curModule.__esModule !== undefined) {\n window.__NeoCommonModules[moduleId].__esModule = curModule.__esModule;\n }\n if (curModule.default !== undefined) {\n window.__NeoCommonModules[moduleId].default = curModule.default;\n }\n } else {\n window.__NeoCommonModules[moduleId] = curModule;\n }\n })\n }\n}\n\n// 用于添加自定义组件的远程依赖组件(关联使用)\nconst addNeoRemoteDeps = (remoteDeps) => {\n if (!window.__NeoCommonModules) {\n window.__NeoCommonModules = {}\n }\n if (!window.__NeoCommonModules.__neoRemoteDeps) {\n window.__NeoCommonModules.__neoRemoteDeps = {}\n }\n if (isPlainObject(remoteDeps)) {\n window.__NeoCommonModules.__neoRemoteDeps = Object.assign(window.__NeoCommonModules.__neoRemoteDeps, remoteDeps)\n }\n}\n\naddNeoCommonModules(CustomCmpCommonModules);\naddNeoRemoteDeps(CustomCmpRemoteDeps);\n `,M=l("./.neo-cli");u.existsSync(M)||u.mkdirSync(M);const a=`${M}/commonModules.js`;return u.writeFileSync(a,_),a}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("node:fs"),e=require("lodash"),n=require("../common.js"),s=require("../pathUtils.js");var d,m;exports.__require=function(){if(m)return d;m=1;const r=o,{isPlainObject:u}=e,{getRelativePathForWebpack:t}=n.__require(),{resolveToCurrentRoot:l}=s.__require();return d=(o,e)=>{const{exports:n,remoteDeps:s}=o;if(!n&&!s)return"";const d={},m={};Array.isArray(n)&&n.length>0?n.forEach(o=>{d[o]=require(o)}):u(n)&&Object.keys(n).length>0?Object.keys(n).forEach(o=>{const e=t(n[o]);d[o]=`require('${e}')`}):n&&(console.error("exports 格式不正确,请检查 neo.config.js 文件中的 neoCommonModule / exports 配置"),process.exit(1)),Array.isArray(s)&&s.length>0&&e.forEach(o=>{m[o]=s});let i="{\n";const c=Object.entries(d);c.forEach(([o,e],n)=>{const s=n===c.length-1;i+=` "${o}": ${e}${s?"":","}\n`}),i+="}";const _=`\n/**\n * 自定义组件 共享出来的依赖模块\n * 备注:可在其他模块中通过 neoRequire 中使用\n */\nimport { isPlainObject } from 'lodash';\nconst CustomCmpCommonModules = ${i};\nconst CustomCmpRemoteDeps = ${JSON.stringify(m)};\n\n// 用于添加共享的依赖模块\nconst addNeoCommonModules = (modules) => {\n if (!window.__NeoCommonModules) {\n window.__NeoCommonModules = {}\n }\n if (isPlainObject(modules)) {\n const moduleIds = Object.keys(modules)\n moduleIds.forEach((moduleId) => {\n const curModule = modules[moduleId];\n const curCommonModule = window.__NeoCommonModules[moduleId];\n \n if (!Object.isFrozen(curCommonModule) && curCommonModule && Object.keys(curCommonModule).length < 3) {\n try {\n // 如果是默认模块对象,则覆盖式合并(保持引用关联)\n window.__NeoCommonModules[moduleId] = Object.assign(curCommonModule, curModule);\n\n // 处理模块中的特殊属性\n if (curModule.__esModule !== undefined) {\n window.__NeoCommonModules[moduleId].__esModule = curModule.__esModule;\n }\n if (curModule.default !== undefined) {\n window.__NeoCommonModules[moduleId].default = curModule.default;\n }\n } catch (error) {\n console.warn('window.__NeoCommonModules[moduleId] Object.assign error:', error);\n window.__NeoCommonModules[moduleId] = curModule;\n }\n } else {\n window.__NeoCommonModules[moduleId] = curModule;\n }\n })\n }\n}\n\n// 用于添加自定义组件的远程依赖组件(关联使用)\nconst addNeoRemoteDeps = (remoteDeps) => {\n if (!window.__NeoCommonModules) {\n window.__NeoCommonModules = {}\n }\n if (!window.__NeoCommonModules.__neoRemoteDeps) {\n window.__NeoCommonModules.__neoRemoteDeps = {}\n }\n if (isPlainObject(remoteDeps)) {\n window.__NeoCommonModules.__neoRemoteDeps = Object.assign(window.__NeoCommonModules.__neoRemoteDeps, remoteDeps)\n }\n}\n\naddNeoCommonModules(CustomCmpCommonModules);\naddNeoRemoteDeps(CustomCmpRemoteDeps);\n `,M=l("./.neo-cli");r.existsSync(M)||r.mkdirSync(M);const a=`${M}/commonModules.js`;return r.writeFileSync(a,_),a}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"}),require("node:fs");const e=require("../pathUtils.js"),r=require("../common.js");var o,t;exports.__require=function(){if(t)return o;t=1;const{resolveToCurrentRoot:i}=e.__require(),{getRelativePathForWebpack:n}=r.__require();return o=(e,r,o)=>{const t=i(`${e}/${r}/model`);return`\n// @ts-ignore\nimport { registerNeoEditorModel } from 'neo-register';\nimport CustomCmpModel from '${n(t,o)}';\n\nregisterNeoEditorModel(CustomCmpModel, '${r}');\n `}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"}),require("node:fs");const e=require("../pathUtils.js"),r=require("../common.js");var o,t;exports.__require=function(){if(t)return o;t=1;const{resolveToCurrentRoot:i}=e.__require(),{getRelativePathForWebpack:n}=r.__require();return o=(e,r,o,t)=>{const s=i(`${e}/${r}/model`),m="linkDebug"===t?`${r}_temp`:r,u=n(s,o);return"linkDebug"===t?`\n// @ts-ignore\nimport { registerNeoEditorModel } from 'neo-register';\nimport CustomCmpModel from '${u}';\n\nregisterNeoEditorModel(CustomCmpModel, '${m}', { tags: ['自定义组件(本地)'] });\n `:`\n// @ts-ignore\nimport { registerNeoEditorModel } from 'neo-register';\nimport CustomCmpModel from '${u}';\n\nregisterNeoEditorModel(CustomCmpModel, '${m}');\n `}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"}),require("node:fs");const e=require("../pathUtils.js"),r=require("../common.js");var t,o;exports.__require=function(){if(o)return t;o=1;const{resolveToCurrentRoot:n}=e.__require(),{getRelativePathForWebpack:i}=r.__require();return t=(e,r,t)=>{const o=n(`${e}/${r}/index`);return`\n// @ts-ignore\nimport { registerNeoCmp } from 'neo-register';\nimport CustomCmp from '${i(o,t)}';\n\nregisterNeoCmp(CustomCmp, '${r}');\n `}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"}),require("node:fs");const e=require("../pathUtils.js"),r=require("../common.js");var t,o;exports.__require=function(){if(o)return t;o=1;const{resolveToCurrentRoot:n}=e.__require(),{getRelativePathForWebpack:i}=r.__require();return t=(e,r,t,o)=>{const s=n(`${e}/${r}/index`),u="linkDebug"===o?`${r}_temp`:r;return`\n// @ts-ignore\nimport { registerNeoCmp } from 'neo-register';\nimport CustomCmp from '${i(s,t)}';\n\nregisterNeoCmp(CustomCmp, '${u}');\n `}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./getCmpTypeByDir.js");var r,t;exports.__require=function(){if(t)return r;t=1;const i=e.__require();return r=e=>i().includes(e)};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./getCmpTypeByDir.js"),r=require("../../config/index.js");var i,t;exports.__require=function(){if(t)return i;t=1;const n=e.__require(),o=r.__require();return i=e=>n(o.componentsDir).includes(e)};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./projectUtils/getEntries.js"),t=require("./projectUtils/getEntriesWithAutoRegister.js");var r,i;exports.__require=function(){if(i)return r;i=1;const n=e.__require(),s=t.__require();return r=function({configEntry:e,disableAutoRegister:t,componentsDir:r,entryType:i="widget",cmpType:o}){if(e&&Object.keys(e).length>0)return{entries:e,cmpTypes:[]};let u,c;u=t?n(r,o):s(r,o),c="linkDebug"===i?u.linkDebugEntries||{}:u.widgetEntries||{};const p=u.cmpTypes||[];if(!c||0===Object.keys(c).length){throw new Error(`未识别到自定义组件,请检查 ${r||"./src/components"} 目录下是否存在自定义组件。`)}return{entries:c||e||{},cmpTypes:p,defaultExports:u.defaultExports||{}}}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./projectUtils/getEntries.js"),t=require("./projectUtils/getEntriesWithAutoRegister.js");var r,i;exports.__require=function(){if(i)return r;i=1;const n=e.__require(),s=t.__require();return r=function({configEntry:e,disableAutoRegister:t,componentsDir:r,entryType:i="widget",cmpType:o}){if(e&&Object.keys(e).length>0)return{entries:e,cmpTypes:[]};let u,c;u=t?n(r,o):s(r,o,i),c="linkDebug"===i?u.linkDebugEntries||{}:u.widgetEntries||{};const p=u.cmpTypes||[];if(!c||0===Object.keys(c).length){throw new Error(`未识别到自定义组件,请检查 ${r||"./src/components"} 目录下是否存在自定义组件。`)}return{entries:c||e||{},cmpTypes:p,defaultExports:u.defaultExports||{}}}};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("node:fs"),r=require("node:path"),t=require("lodash"),s=require("../pathUtils.js"),i=require("../cmpUtils/getCmpRegisterCode.js"),o=require("../cmpUtils/getCmpModelRegisterCode.js");var n,c;exports.__require=function(){if(c)return n;c=1;const d=e,u=r,l=t,{resolveToCurrentRoot:a}=s.__require(),p=i.__require(),m=o.__require();return n=(e="./src/components",r)=>{const t={},s={index:[]},i=[],o={},n=a(e);d.existsSync(n)||(console.error(`未找到组件目录,请检查 ${e} 目录是否存在`),process.exit(1));const c=a("./.neo-cli");d.existsSync(c)||d.mkdirSync(c);try{let a=[];a=r?[r]:d.readdirSync(n),a.forEach(r=>{const a=u.join(n,r);if(d.statSync(a).isDirectory()&&!r.startsWith(".")&&"node_modules"!==r){const x=r,y=l.camelCase(x);i.push(x);const h=`${c}/${x}`;d.existsSync(h)||d.mkdirSync(h),d.readdirSync(a).filter(e=>e.match(/(index|model)\.(tsx?|jsx?|vue)$/)).map(r=>u.join(e,x,r)).forEach(e=>{if(e.match(/index\.(tsx?|jsx?|vue)$/)){o[y]=u.resolve(e);const r=`${h}/register.js`,i=p(n,x,r);d.writeFileSync(r,i),t[y]=r,s.index.push(r)}else if(e.match(/model\.[tj]sx?$/)){const e=`${h}/model.js`,r=m(n,x,e);d.writeFileSync(e,r),t[`${y}Model`]=e,s.index.push(e)}})}})}catch(e){console.error("获取自定义组件入口文件失败(getEntriesWithAutoRegister):",e),process.exit(1)}return{widgetEntries:t,linkDebugEntries:s,cmpTypes:i,defaultExports:o}}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("node:fs"),r=require("node:path"),t=require("lodash"),s=require("../pathUtils.js"),i=require("../cmpUtils/getCmpRegisterCode.js"),o=require("../cmpUtils/getCmpModelRegisterCode.js");var n,c;exports.__require=function(){if(c)return n;c=1;const d=e,u=r,l=t,{resolveToCurrentRoot:a}=s.__require(),p=i.__require(),m=o.__require();return n=(e="./src/components",r,t="widget")=>{const s={},i={index:[]},o=[],n={},c=a(e);d.existsSync(c)||(console.error(`未找到组件目录,请检查 ${e} 目录是否存在`),process.exit(1));const x=a("./.neo-cli");d.existsSync(x)||d.mkdirSync(x);try{let a=[];a=r?[r]:d.readdirSync(c),a.forEach(r=>{const a=u.join(c,r);if(d.statSync(a).isDirectory()&&!r.startsWith(".")&&"node_modules"!==r){const y=r,h=l.camelCase(y);o.push(y);const g=`${x}/${y}`;d.existsSync(g)||d.mkdirSync(g),d.readdirSync(a).filter(e=>e.match(/(index|model)\.(tsx?|jsx?|vue)$/)).map(r=>u.join(e,y,r)).forEach(e=>{if(e.match(/index\.(tsx?|jsx?|vue)$/)){n[h]=u.resolve(e);const r=`${g}/register.js`,o=p(c,y,r,t);d.writeFileSync(r,o),s[h]=r,i.index.push(r)}else if(e.match(/model\.[tj]sx?$/)){const e=`${g}/model.js`,r=m(c,y,e,t);d.writeFileSync(e,r),s[`${h}Model`]=e,i.index.push(e)}})}})}catch(e){console.error("获取自定义组件入口文件失败(getEntriesWithAutoRegister):",e),process.exit(1)}return{widgetEntries:s,linkDebugEntries:i,cmpTypes:o,defaultExports:n}}};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "neo-cmp-cli",
3
- "version": "1.10.2",
3
+ "version": "1.10.5",
4
4
  "description": "Neo 自定义组件开发工具,支持react 和 vue2.0技术栈。",
5
5
  "keywords": [
6
6
  "neo-cli",
@@ -19,8 +19,7 @@
19
19
  "files": [
20
20
  "bin/*",
21
21
  "dist/*",
22
- "template/*",
23
- "test/*"
22
+ "template/*"
24
23
  ],
25
24
  "husky": {
26
25
  "hooks": {
@@ -103,6 +103,13 @@ module.exports = {
103
103
  }
104
104
  */
105
105
  },
106
+ // 选择「自定义环境」时需要添加 NeoCRM 平台配置,可自定义对接的任何环境
107
+ neoConfig: {
108
+ // authType: 'oauth2', // 默认授权模式:OAuth2 授权码模式
109
+ neoBaseURL: 'https://crm-test.xiaoshouyi.com', // 平台根地址(默认:https://crm.xiaoshouyi.com)
110
+ loginURL: 'https://login-test.xiaoshouyi.com/auc/oauth2/auth', // 登录授权 URL(默认:https://login.xiaoshouyi.com/auc/oauth2/auth)
111
+ tokenURL: 'https://login-test.xiaoshouyi.com/auc/oauth2/token', // Token 获取接口地址(默认:https://login.xiaoshouyi.com/auc/oauth2/token)
112
+ },
106
113
  pushCmp: {
107
114
  // 用于构建并发布至 NeoCRM 的相关配置
108
115
  /*
@@ -38,7 +38,7 @@
38
38
  "url": "https://github.com/wibetter/antd-custom-cmp-template/issues"
39
39
  },
40
40
  "dependencies": {
41
- "neo-register": "^1.1.2",
41
+ "neo-register": "^1.1.3",
42
42
  "antd": "4.9.4",
43
43
  "react": "^16.9.0",
44
44
  "react-dom": "^16.9.0"
@@ -48,7 +48,7 @@
48
48
  "@commitlint/config-conventional": "^9.1.1",
49
49
  "@types/react": "^16.9.11",
50
50
  "@types/react-dom": "^16.9.15",
51
- "neo-cmp-cli": "^1.9.28",
51
+ "neo-cmp-cli": "^1.10.5",
52
52
  "husky": "^4.2.5",
53
53
  "lint-staged": "^10.2.9",
54
54
  "prettier": "^2.0.5"
@@ -38,7 +38,7 @@
38
38
  "url": "https://github.com/wibetter/echarts-custom-cmp-template/issues"
39
39
  },
40
40
  "dependencies": {
41
- "neo-register": "^1.1.2",
41
+ "neo-register": "^1.1.3",
42
42
  "react": "^16.9.0",
43
43
  "react-dom": "^16.9.0",
44
44
  "echarts": "^5.5.1"
@@ -48,7 +48,7 @@
48
48
  "@commitlint/config-conventional": "^9.1.1",
49
49
  "@types/react": "^16.9.11",
50
50
  "@types/react-dom": "^16.9.15",
51
- "neo-cmp-cli": "^1.9.28",
51
+ "neo-cmp-cli": "^1.10.5",
52
52
  "husky": "^4.2.5",
53
53
  "lint-staged": "^10.2.9",
54
54
  "prettier": "^2.0.5",
@@ -37,7 +37,7 @@
37
37
  "url": "https://github.com/wibetter/empty-custom-cmp-template/issues"
38
38
  },
39
39
  "dependencies": {
40
- "neo-register": "^1.1.2",
40
+ "neo-register": "^1.1.3",
41
41
  "react": "^16.9.0",
42
42
  "react-dom": "^16.9.0",
43
43
  "antd": "4.9.4",
@@ -41,7 +41,7 @@
41
41
  "url": "https://github.com/wibetter/neo-custom-cmp-template/issues"
42
42
  },
43
43
  "dependencies": {
44
- "neo-register": "^1.1.2",
44
+ "neo-register": "^1.1.3",
45
45
  "react": "^16.9.0",
46
46
  "react-dom": "^16.9.0",
47
47
  "axios": "^0.27.2",
@@ -55,7 +55,7 @@
55
55
  "@types/react": "^16.9.11",
56
56
  "@types/react-dom": "^16.9.15",
57
57
  "@types/axios": "^0.14.0",
58
- "neo-cmp-cli": "^1.9.28",
58
+ "neo-cmp-cli": "^1.10.5",
59
59
  "husky": "^4.2.5",
60
60
  "lint-staged": "^10.2.9",
61
61
  "prettier": "^2.0.5"
@@ -31,6 +31,9 @@ export class EntityFormModel {
31
31
  */
32
32
  targetPage: string[] = ['all'];
33
33
 
34
+ // 适配终端类型
35
+ targetDevice: string = 'all';
36
+
34
37
  enableDuplicate: boolean = true;
35
38
 
36
39
  /** 组件图标,用于设置在编辑器左侧组件面板中展示的图标 */
@@ -38,14 +38,14 @@
38
38
  "url": "https://github.com/wibetter/react-custom-cmp-template/issues"
39
39
  },
40
40
  "dependencies": {
41
- "neo-register": "^1.1.2",
41
+ "neo-register": "^1.1.3",
42
42
  "react": "^16.9.0",
43
43
  "react-dom": "^16.9.0"
44
44
  },
45
45
  "devDependencies": {
46
46
  "@commitlint/cli": "^8.3.5",
47
47
  "@commitlint/config-conventional": "^9.1.1",
48
- "neo-cmp-cli": "^1.9.28",
48
+ "neo-cmp-cli": "^1.10.5",
49
49
  "husky": "^4.2.5",
50
50
  "lint-staged": "^10.2.9",
51
51
  "prettier": "^2.0.5"
@@ -38,7 +38,7 @@
38
38
  "url": "https://github.com/wibetter/react-ts-custom-cmp-template/issues"
39
39
  },
40
40
  "dependencies": {
41
- "neo-register": "^1.1.2",
41
+ "neo-register": "^1.1.3",
42
42
  "react": "^16.9.0",
43
43
  "react-dom": "^16.9.0"
44
44
  },
@@ -47,7 +47,7 @@
47
47
  "@commitlint/config-conventional": "^9.1.1",
48
48
  "@types/react": "^16.9.11",
49
49
  "@types/react-dom": "^16.9.15",
50
- "neo-cmp-cli": "^1.9.28",
50
+ "neo-cmp-cli": "^1.10.5",
51
51
  "husky": "^4.2.5",
52
52
  "lint-staged": "^10.2.9",
53
53
  "prettier": "^2.0.5"
@@ -38,14 +38,14 @@
38
38
  "url": "https://github.com/wibetter/vue2-custom-cmp-template/issues"
39
39
  },
40
40
  "dependencies": {
41
- "neo-register": "^1.1.2",
41
+ "neo-register": "^1.1.3",
42
42
  "vue": "^2.6.14",
43
43
  "element-ui": "^2.15.12"
44
44
  },
45
45
  "devDependencies": {
46
46
  "@commitlint/cli": "^8.3.5",
47
47
  "@commitlint/config-conventional": "^9.1.1",
48
- "neo-cmp-cli": "^1.9.28",
48
+ "neo-cmp-cli": "^1.10.5",
49
49
  "husky": "^4.2.5",
50
50
  "lint-staged": "^10.2.9",
51
51
  "prettier": "^2.0.5",
package/test/demo.js DELETED
@@ -1,8 +0,0 @@
1
- const {neoInit, neoConfigInit, inspect, debug, build2lib, build2esm, neoInitByCopy, previewCmp, createCmpByTemplate } = require('../src/main');
2
- createCmpByTemplate('react_ts');
3
- // neoInitByCopy('react-ts', 'test123');
4
-
5
- // previewCmp('info-card');
6
-
7
- // const entries = getEntriesWithAutoRegister('linkDebug');
8
- // console.log(entries);
package/test/demo2.js DELETED
@@ -1,3 +0,0 @@
1
- const createCmpByZip = require('../src/utils/cmpUtils/createCmpByZip');
2
-
3
- createCmpByZip('https://publicfront-1253467224.cos.ap-beijing.myqcloud.com/customComponent/crm-cd/tenant/3256219432312412/1762331900697/entityDetailSource.zip', 'entity-detail');
package/test/demo3.js DELETED
@@ -1,3 +0,0 @@
1
- const openEditor = require('../dist/main.js').openEditor;
2
-
3
- openEditor('auto', 'src');
package/test/demo6.js DELETED
@@ -1,95 +0,0 @@
1
- /**
2
- * 基于XMLHttpRequest的通用请求方法
3
- * @param {string} url - 请求地址
4
- * @param {object} options - 请求配置
5
- * @param {string} [options.method='GET'] - 请求方法
6
- * @param {object} [options.params={}] - URL查询参数(GET/DELETE)
7
- * @param {object} [options.data={}] - 请求体数据(POST/PUT)
8
- * @param {object} [options.headers={}] - 请求头
9
- * @param {number} [options.timeout=5000] - 超时时间(毫秒)
10
- * @returns {Promise} - 返回Promise对象
11
- */
12
- function requestXHR(url, options) {
13
- options = options || {};
14
- var method = options.method || 'GET';
15
- var data = options.data || {};
16
- var headers = options.headers || {};
17
- var timeout = options.timeout || 5000;
18
-
19
- return new Promise(function(resolve, reject) {
20
- // 1. 创建XHR对象
21
- var xhr = new XMLHttpRequest();
22
-
23
- // 2. 处理GET参数,拼接到URL
24
- var queryParts = [];
25
- var queryString = queryParts.join('&');
26
- var fullUrl = queryString ? url + '?' + queryString : url;
27
-
28
- // 3. 初始化请求
29
- xhr.open(method.toUpperCase(), fullUrl, true);
30
-
31
- // 4. 设置请求头
32
- // 默认JSON请求头(POST/PUT)
33
- var methodUpper = method.toUpperCase();
34
- if (methodUpper === 'POST' || methodUpper === 'PUT') {
35
- xhr.setRequestHeader('Content-Type', 'application/json;charset=utf-8');
36
- }
37
- // 自定义请求头
38
- var headerKeys = Object.keys(headers);
39
- for (var j = 0; j < headerKeys.length; j++) {
40
- var headerKey = headerKeys[j];
41
- var headerValue = headers[headerKey];
42
- xhr.setRequestHeader(headerKey, headerValue);
43
- }
44
-
45
- // 5. 设置超时
46
- xhr.timeout = timeout;
47
-
48
- // 6. 处理响应
49
- xhr.onload = function () {
50
- if (xhr.status >= 200 && xhr.status < 300) {
51
- // 解析响应数据(优先JSON,其次文本)
52
- var responseData;
53
- try {
54
- responseData = JSON.parse(xhr.responseText);
55
- } catch (e) {
56
- responseData = xhr.responseText;
57
- }
58
- resolve({
59
- data: responseData,
60
- status: xhr.status,
61
- statusText: xhr.statusText
62
- });
63
- } else {
64
- reject(new Error('请求失败:' + xhr.status + ' ' + xhr.statusText));
65
- }
66
- };
67
-
68
- // 7. 处理网络错误、超时
69
- xhr.onerror = function () {
70
- reject(new Error('网络错误,请检查网络连接'));
71
- };
72
- xhr.ontimeout = function () {
73
- reject(new Error('请求超时(' + timeout + 'ms)'));
74
- };
75
-
76
- // 8. 发送请求(POST/PUT需传请求体)
77
- var methodUpperSend = method.toUpperCase();
78
- if (methodUpperSend === 'POST' || methodUpperSend === 'PUT') {
79
- xhr.send(JSON.stringify(data));
80
- } else {
81
- xhr.send(null);
82
- }
83
- });
84
- }
85
-
86
- // GET请求
87
- requestXHR('https://jsonplaceholder.typicode.com/posts', {
88
- timeout: 10000
89
- })
90
- .then(function(res) {
91
-
92
- })
93
- .catch(function(err) {
94
-
95
- });
@@ -1,30 +0,0 @@
1
- const { execSync } = require('child_process');
2
-
3
- // 所有需要废弃的版本
4
- const versionsToDeprecate = ["1.9.12", "1.9.13", "1.9.15", "1.9.16", "1.9.17", "1.9.18", "1.9.19", "1.9.20", "1.9.21", "1.9.22"];
5
-
6
- const packageName = 'neo-cmp-cli';
7
- const deprecateMessage = '此版本为开发中版本(存在 bug),请升级到最新版本。';
8
-
9
- console.log(`开始标记 ${versionsToDeprecate.length} 个版本为废弃状态...\n`);
10
-
11
- let successCount = 0;
12
- let failCount = 0;
13
-
14
- versionsToDeprecate.forEach((version, index) => {
15
- try {
16
- const command = `npm deprecate ${packageName}@${version} "${deprecateMessage}"`;
17
- console.log(`[${index + 1}/${versionsToDeprecate.length}] 正在标记 ${version}...`);
18
- execSync(command, { stdio: 'inherit' });
19
- successCount++;
20
- console.log(`✓ ${version} 已成功标记\n`);
21
- } catch (error) {
22
- failCount++;
23
- console.error(`✗ ${version} 标记失败: ${error.message}\n`);
24
- }
25
- });
26
-
27
- console.log('\n========================================');
28
- console.log(`完成!成功: ${successCount}, 失败: ${failCount}`);
29
- console.log('========================================');
30
-