@szzbmy/lowcode-cli
Version:
🐇 lowcode-cli is an efficient cli tool for Rabbitpre plugin component secondary development. ❤️
70 lines (69 loc) • 3 kB
JavaScript
;
/**
* @describe 创建二开组件
* @author qinzhenya
* @since 20210818
*/
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const ink_1 = require("ink");
const react_1 = __importStar(require("react"));
const components_1 = require("../../components");
const create_cmp_1 = __importDefault(require("./mode/create-cmp"));
const create_cmplib_1 = __importDefault(require("./mode/create-cmplib"));
var CREATE_MODE;
(function (CREATE_MODE) {
CREATE_MODE[CREATE_MODE["UN_SELECT"] = 0] = "UN_SELECT";
CREATE_MODE[CREATE_MODE["CMP"] = 1] = "CMP";
CREATE_MODE[CREATE_MODE["CMPLIB"] = 2] = "CMPLIB";
})(CREATE_MODE || (CREATE_MODE = {}));
function Create() {
const [createMode, setCreateMode] = (0, react_1.useState)(CREATE_MODE.UN_SELECT);
// 选择拉取组件or组件库
const onHandleSelectMode = (0, react_1.useCallback)(({ value }) => {
setCreateMode(value);
}, []);
let renderer = null;
switch (createMode) {
case CREATE_MODE.UN_SELECT:
renderer = (react_1.default.createElement(react_1.default.Fragment, null,
react_1.default.createElement(ink_1.Text, { color: "green" }, "\u9009\u62E9\u62C9\u53D6:"),
react_1.default.createElement(ink_1.Box, { borderStyle: "single" },
react_1.default.createElement(components_1.SelectInput, { items: [
{ label: '二开组件', value: CREATE_MODE.CMP },
{ label: '自定义玩法', value: CREATE_MODE.CMPLIB },
], onSelect: onHandleSelectMode }))));
break;
case CREATE_MODE.CMP:
renderer = react_1.default.createElement(create_cmp_1.default, null);
break;
case CREATE_MODE.CMPLIB:
renderer = react_1.default.createElement(create_cmplib_1.default, null);
break;
default:
renderer = null;
}
return renderer;
}
exports.default = Create;