fix: remove formily demo (#138)
This commit is contained in:
parent
9497ae4970
commit
3759f381d6
|
@ -30,8 +30,8 @@ npm run start
|
|||
- [custom-initialization](https://lowcode-engine.cn/demo/demo-custom-initialization/index.html)
|
||||
- [node-extended-actions](https://lowcode-engine.cn/demo/demo-node-extended-actions/index.html)
|
||||
- [next-pro](https://lowcode-engine.cn/demo/demo-next-pro/index.html)
|
||||
- [antd-pro-with-formily](https://lowcode-engine.cn/demo/demo-antd-pro-with-formily/index.html)
|
||||
- [lowcode-component](https://lowcode-engine.cn/demo/demo-lowcode-component/index.html)
|
||||
- [lowcode-workspace](https://lowcode-engine.cn/demo/demo-workspace/index.html)
|
||||
|
||||
更多参考资料:
|
||||
|
||||
|
|
|
@ -3,9 +3,6 @@
|
|||
"demo-general/index" : "./demo-general/src/index.ts",
|
||||
"demo-general/preview" : "./demo-general/src/preview.tsx",
|
||||
|
||||
"demo-antd-pro-with-formily/index" : "./demo-antd-pro-with-formily/src/index.ts",
|
||||
"demo-antd-pro-with-formily/preview" : "./demo-antd-pro-with-formily/src/preview.tsx",
|
||||
|
||||
"demo-basic-antd/index" : "./demo-basic-antd/src/index.ts",
|
||||
"demo-basic-antd/preview" : "./demo-basic-antd/src/preview.tsx",
|
||||
|
||||
|
|
|
@ -1,7 +0,0 @@
|
|||
module.exports = {
|
||||
printWidth: 100,
|
||||
tabWidth: 2,
|
||||
semi: true,
|
||||
singleQuote: true,
|
||||
trailingComma: 'all',
|
||||
};
|
|
@ -1,35 +0,0 @@
|
|||
{
|
||||
"entry": {
|
||||
"preview": "./src/preview.tsx",
|
||||
"index": "./src/index.ts"
|
||||
},
|
||||
"vendor": false,
|
||||
"devServer": {
|
||||
"hot": false
|
||||
},
|
||||
"publicPath": "/",
|
||||
"externals": {
|
||||
"react": "var window.React",
|
||||
"react-dom": "var window.ReactDOM",
|
||||
"prop-types": "var window.PropTypes",
|
||||
"@alifd/next": "var window.Next",
|
||||
"@alilc/lowcode-engine": "var window.AliLowCodeEngine",
|
||||
"@alilc/lowcode-engine-ext": "var window.AliLowCodeEngineExt",
|
||||
"moment": "var window.moment",
|
||||
"lodash": "var window._"
|
||||
},
|
||||
"plugins": [
|
||||
[
|
||||
"build-plugin-react-app"
|
||||
],
|
||||
[
|
||||
"build-plugin-moment-locales",
|
||||
{
|
||||
"locales": [
|
||||
"zh-cn"
|
||||
]
|
||||
}
|
||||
],
|
||||
"./build.plugin.js"
|
||||
]
|
||||
}
|
|
@ -1,57 +0,0 @@
|
|||
const fs = require('fs-extra');
|
||||
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin');
|
||||
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
||||
|
||||
const { version } = JSON.parse(fs.readFileSync('./package.json', 'utf8'));
|
||||
|
||||
module.exports = ({ onGetWebpackConfig }) => {
|
||||
onGetWebpackConfig((config) => {
|
||||
config.resolve.plugin('tsconfigpaths').use(TsconfigPathsPlugin, [
|
||||
{
|
||||
configFile: './tsconfig.json',
|
||||
},
|
||||
]);
|
||||
|
||||
config.merge({
|
||||
node: {
|
||||
fs: 'empty',
|
||||
},
|
||||
});
|
||||
|
||||
config
|
||||
.plugin('index')
|
||||
.use(HtmlWebpackPlugin, [
|
||||
{
|
||||
inject: false,
|
||||
minify: false,
|
||||
templateParameters: {
|
||||
version,
|
||||
},
|
||||
template: require.resolve('./public/index.ejs'),
|
||||
filename: 'index.html',
|
||||
},
|
||||
]);
|
||||
config
|
||||
.plugin('preview')
|
||||
.use(HtmlWebpackPlugin, [
|
||||
{
|
||||
inject: false,
|
||||
templateParameters: {
|
||||
},
|
||||
template: require.resolve('./public/preview.html'),
|
||||
filename: 'preview.html',
|
||||
},
|
||||
]);
|
||||
|
||||
config.plugins.delete('hot');
|
||||
config.devServer.hot(false);
|
||||
|
||||
config.module // fixes https://github.com/graphql/graphql-js/issues/1272
|
||||
.rule('mjs$')
|
||||
.test(/\.mjs$/)
|
||||
.include
|
||||
.add(/node_modules/)
|
||||
.end()
|
||||
.type('javascript/auto');
|
||||
});
|
||||
};
|
|
@ -1,67 +0,0 @@
|
|||
{
|
||||
"name": "@alilc/lowcode-demo-antd-pro-with-formily",
|
||||
"version": "1.0.28",
|
||||
"description": "Low-Code Engine 低代码搭建引擎 Demo 项目 - antd 高级组件 + formily 表单组件",
|
||||
"repository": "git@github.com:alibaba/lowcode-demo.git",
|
||||
"license": "MIT",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
"start": "build-scripts start --disable-reload --port 5556",
|
||||
"build": "build-scripts build",
|
||||
"prepublishOnly": "npm run build",
|
||||
"pub": "node ./scripts/watchdog.js && npm pub"
|
||||
},
|
||||
"files": [
|
||||
"build"
|
||||
],
|
||||
"config": {},
|
||||
"dependencies": {
|
||||
"@alilc/lowcode-datasource-fetch-handler": "^1.0.1",
|
||||
"@alilc/lowcode-plugin-code-editor": "^1.0.3",
|
||||
"@alilc/lowcode-plugin-code-generator": "^1.0.4",
|
||||
"@alilc/lowcode-plugin-components-pane": "^2.0.0",
|
||||
"@alilc/lowcode-plugin-datasource-pane": "^1.0.9",
|
||||
"@alilc/lowcode-plugin-inject": "^1.2.1",
|
||||
"@alilc/lowcode-plugin-manual": "^1.0.4",
|
||||
"@alilc/lowcode-plugin-schema": "^1.0.2",
|
||||
"@alilc/lowcode-plugin-simulator-select": "^1.0.2",
|
||||
"@alilc/lowcode-plugin-undo-redo": "^1.0.0",
|
||||
"@alilc/lowcode-plugin-zh-en": "^1.0.0",
|
||||
"@alilc/lowcode-plugin-set-ref-prop": "^1.0.1",
|
||||
"@alilc/lowcode-react-renderer": "^1.1.2",
|
||||
"@alilc/lowcode-setter-behavior": "^1.0.0",
|
||||
"@alilc/lowcode-setter-title": "^1.0.2",
|
||||
"@formily/antd": "2.2.15",
|
||||
"@formily/core": "2.2.15",
|
||||
"@formily/react": "2.2.15",
|
||||
"@seada/antd-plugins": "^1.0.0-rc.23",
|
||||
"@seada/lowcode-code-generator": "^1.0.4",
|
||||
"antd": "^4.21.4",
|
||||
"moment": "^2.29.3",
|
||||
"uuid": "^8.3.2"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@alib/build-scripts": "^0.1.18",
|
||||
"@alilc/lowcode-engine": "^1.1.2",
|
||||
"@alilc/lowcode-engine-ext": "^1.0.0",
|
||||
"@alilc/lowcode-types": "^1.1.1",
|
||||
"@types/events": "^3.0.0",
|
||||
"@types/react": "^16.8.3",
|
||||
"@types/react-dom": "^16.8.2",
|
||||
"@types/streamsaver": "^2.0.0",
|
||||
"@types/uuid": "^8.3.4",
|
||||
"build-plugin-fusion": "^0.1.0",
|
||||
"build-plugin-moment-locales": "^0.1.0",
|
||||
"build-plugin-react-app": "^1.1.2",
|
||||
"fs-extra": "^10.0.1",
|
||||
"tsconfig-paths-webpack-plugin": "^3.2.0"
|
||||
},
|
||||
"resolutions": {
|
||||
"@formily/antd": "2.2.15",
|
||||
"@formily/core": "2.2.15",
|
||||
"@formily/react": "2.2.15",
|
||||
"@formily/next": "2.2.15",
|
||||
"@babel/core": "7.20.12",
|
||||
"@monaco-editor/react": "4.4.6"
|
||||
}
|
||||
}
|
Binary file not shown.
Before Width: | Height: | Size: 3.5 KiB |
|
@ -1,48 +0,0 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||||
<title>阿里低代码引擎 Demo</title>
|
||||
<link rel="icon" href="//img.alicdn.com/imgextra/i2/O1CN01lNWGJi1xflgRfSgbk_!!6000000006471-55-tps-22-26.svg">
|
||||
<link href="./css/index.css" rel="stylesheet" />
|
||||
<!-- 低代码引擎的页面主题样式,可以替换为 theme-lowcode-dark -->
|
||||
<link href="https://alifd.alicdn.com/npm/@alifd/theme-lowcode-light@0.2.1/variables.css" rel="stylesheet" />
|
||||
<link href="https://alifd.alicdn.com/npm/@alifd/theme-lowcode-light@0.2.1/dist/next.var.min.css" rel="stylesheet" />
|
||||
<!-- 低代码引擎的页面框架样式 -->
|
||||
<link rel="stylesheet" href="https://uipaas-assets.com/prod/npm/@alilc/lowcode-engine/1.2.1-beta.0/dist/css/engine-core.css" />
|
||||
<!-- 低代码引擎官方扩展的样式 -->
|
||||
<link rel="stylesheet" href="https://uipaas-assets.com/prod/npm/@alilc/lowcode-engine-ext/1.0.6/dist/css/engine-ext.css" />
|
||||
|
||||
<!-- React,可替换为 production 包 -->
|
||||
<script src="https://g.alicdn.com/code/lib/react/16.14.0/umd/react.production.min.js"></script>
|
||||
<!-- React DOM,可替换为 production 包 -->
|
||||
<script src="https://g.alicdn.com/code/lib/react-dom/16.14.0/umd/react-dom.production.min.js"></script>
|
||||
<!-- React 向下兼容,预防物料层的依赖 -->
|
||||
<script src="https://g.alicdn.com/code/lib/prop-types/15.7.2/prop-types.js"></script>
|
||||
<script src="https://g.alicdn.com/platform/c/react15-polyfill/0.0.1/dist/index.js"></script>
|
||||
<!-- lodash,低代码编辑器的依赖 -->
|
||||
<script src="https://g.alicdn.com/platform/c/lodash/4.6.1/lodash.min.js"></script>
|
||||
<!-- 日期处理包,Fusion Next 的依赖 -->
|
||||
<script src="https://g.alicdn.com/mylib/moment/2.24.0/min/moment.min.js"></script>
|
||||
<!-- Fusion Next 的主包,低代码编辑器的依赖 -->
|
||||
<script src="https://g.alicdn.com/code/lib/alifd__next/1.24.18/next.min.js"></script>
|
||||
<!-- 低代码引擎的主包 -->
|
||||
<script crossorigin="anonymous" src="https://uipaas-assets.com/prod/npm/@alilc/lowcode-engine/1.2.1-beta.0/dist/js/engine-core.js"></script>
|
||||
<!-- 低代码引擎官方扩展的主包 -->
|
||||
<script crossorigin="anonymous" src="https://uipaas-assets.com/prod/npm/@alilc/lowcode-engine-ext/1.0.6/dist/js/engine-ext.js"></script>
|
||||
<script>
|
||||
console.log(
|
||||
'%c AliLowCodeEngineDemo %c v<%= version %> ',
|
||||
'padding: 2px 1px; border-radius: 3px 0 0 3px; color: #fff; background: #b37feb; font-weight: bold;',
|
||||
'padding: 2px 1px; border-radius: 0 3px 3px 0; color: #fff; background: #42c02e; font-weight: bold;',
|
||||
);
|
||||
</script>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="lce-container"></div>
|
||||
<script type="text/javascript" src="./js/index.js"></script>
|
||||
</body>
|
||||
</html>
|
|
@ -1 +0,0 @@
|
|||
勿删,删了有奇妙的 bug😄~
|
|
@ -1 +0,0 @@
|
|||
{"success":true,"content":[{"gmtModified":"2021-03-06 00:40:54","formUuid":"FORM-6X866SC1KM4O4BLF3U7879QB0EMT2Z3TGIWLKW","parentNavUuid":"NAV-SYSTEM-PARENT-UUID","hidden":"n","navUuid":"FORM-6X866SC1KM4O4BLF3U7879QB0EMT2Z3TGIWLKW","navType":"PAGE","isIndex":"n","isNew":"n","gmtCreate":"2021-03-06 00:27:26","title":{"en-US":"页面1","zh-CN":"页面1","type":"i18n"},"relateUuid":"FORM-6X866SC1KM4O4BLF3U7879QB0EMT2Z3TGIWLKW","parentId":0,"listOrder":0,"id":556103}]}
|
|
@ -1,3 +0,0 @@
|
|||
{
|
||||
"info": "Hello AliLowCode!!"
|
||||
}
|
|
@ -1,25 +0,0 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="UTF-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
|
||||
<title>阿里低代码引擎 Demo - 预览页</title>
|
||||
<link href="https://g.alicdn.com/code/lib/alifd__next/1.24.18/next.min.css" rel="stylesheet">
|
||||
<link href="./css/preview.css" rel="stylesheet">
|
||||
</head>
|
||||
<body>
|
||||
<div id="ice-container"></div>
|
||||
<script>
|
||||
window.g_config = {
|
||||
locale: 'zh-CN',
|
||||
};
|
||||
</script>
|
||||
<script src="https://g.alicdn.com/code/lib/react/16.14.0/umd/react.production.min.js"></script>
|
||||
<script src="https://g.alicdn.com/code/lib/react-dom/16.14.0/umd/react-dom.production.min.js"></script>
|
||||
<script src="https://g.alicdn.com/code/lib/prop-types/15.7.2/prop-types.js"></script>
|
||||
<script src="https://g.alicdn.com/platform/c/??react15-polyfill/0.0.1/dist/index.js,lodash/4.6.1/lodash.min.js"></script>
|
||||
<script src="https://g.alicdn.com/mylib/moment/2.24.0/min/moment.min.js"></script>
|
||||
<script src="https://g.alicdn.com/code/lib/alifd__next/1.24.18/next.min.js"></script>
|
||||
<script type="text/javascript" src="./js/preview.js"></script>
|
||||
</body>
|
||||
</html>
|
|
@ -1,15 +0,0 @@
|
|||
#!/usr/bin/env node
|
||||
const fs = require('fs');
|
||||
const { join } = require('path');
|
||||
|
||||
const workingDir = process.cwd();
|
||||
|
||||
const pkg = JSON.parse(fs.readFileSync(join(workingDir, 'package.json'), 'utf-8'));
|
||||
if (pkg.private) return;
|
||||
const { files } = pkg;
|
||||
files.forEach(file => {
|
||||
const fileDir = join(workingDir, file);
|
||||
if (!fs.existsSync(fileDir)) {
|
||||
throw new Error(`${fileDir} does not exist, plz run build`);
|
||||
}
|
||||
});
|
|
@ -1,55 +0,0 @@
|
|||
body {
|
||||
font-family: PingFangSC-Regular, Roboto, Helvetica Neue, Helvetica, Tahoma, Arial, PingFang SC-Light, Microsoft YaHei;
|
||||
font-size: 12px;
|
||||
* {
|
||||
box-sizing: border-box;
|
||||
}
|
||||
}
|
||||
|
||||
body, #lce-container {
|
||||
position: fixed;
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
top: 0;
|
||||
box-sizing: border-box;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
overflow: hidden;
|
||||
text-rendering: optimizeLegibility;
|
||||
-webkit-user-select: none;
|
||||
-webkit-user-drag: none;
|
||||
-webkit-text-size-adjust: none;
|
||||
-webkit-touch-callout: none;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
#engine {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
}
|
||||
}
|
||||
|
||||
html {
|
||||
min-width: 1024px;
|
||||
}
|
||||
|
||||
.save-sample {
|
||||
width: 80px;
|
||||
height: 30px;
|
||||
background-color: #5584FF;
|
||||
border: none;
|
||||
outline: none;
|
||||
border-radius: 4px;
|
||||
color: white;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.load-assets {
|
||||
width: 100px;
|
||||
height: 30px;
|
||||
background-color: #5584FF;
|
||||
border: none;
|
||||
outline: none;
|
||||
border-radius: 4px;
|
||||
color: white;
|
||||
cursor: pointer;
|
||||
}
|
|
@ -1,107 +0,0 @@
|
|||
import { init, plugins } from '@alilc/lowcode-engine';
|
||||
import { createFetchHandler } from '@alilc/lowcode-datasource-fetch-handler'
|
||||
import EditorInitPlugin from './plugins/plugin-editor-init';
|
||||
import UndoRedoPlugin from '@alilc/lowcode-plugin-undo-redo';
|
||||
import ZhEnPlugin from '@alilc/lowcode-plugin-zh-en';
|
||||
import CodeGenPlugin from '@alilc/lowcode-plugin-code-generator';
|
||||
import DataSourcePanePlugin from '@alilc/lowcode-plugin-datasource-pane';
|
||||
import SchemaPlugin from '@alilc/lowcode-plugin-schema';
|
||||
import CodeEditorPlugin from "@alilc/lowcode-plugin-code-editor";
|
||||
import ManualPlugin from "@alilc/lowcode-plugin-manual";
|
||||
import InjectPlugin from '@alilc/lowcode-plugin-inject';
|
||||
import SimulatorResizerPlugin from '@alilc/lowcode-plugin-simulator-select';
|
||||
import ComponentPanelPlugin from '@alilc/lowcode-plugin-components-pane';
|
||||
import DefaultSettersRegistryPlugin from './plugins/plugin-default-setters-registry';
|
||||
import LoadIncrementalAssetsWidgetPlugin from './plugins/plugin-load-incremental-assets-widget';
|
||||
import SaveSamplePlugin from './plugins/plugin-save-sample';
|
||||
import PreviewSamplePlugin from './plugins/plugin-preview-sample';
|
||||
import CustomSetterSamplePlugin from './plugins/plugin-custom-setter-sample';
|
||||
import SetRefPropPlugin from '@alilc/lowcode-plugin-set-ref-prop';
|
||||
import LogoSamplePlugin from './plugins/plugin-logo-sample';
|
||||
import { PluginFormily } from '@seada/antd-plugins'
|
||||
import 'antd/dist/antd.css'
|
||||
import './global.scss';
|
||||
|
||||
async function registerPlugins() {
|
||||
await plugins.register(InjectPlugin);
|
||||
|
||||
await plugins.register(EditorInitPlugin, {
|
||||
scenarioName: 'antd-pro-with-formily',
|
||||
displayName: 'antd 高级组件 + formily 表单组件',
|
||||
info: {
|
||||
urls: [
|
||||
{
|
||||
key: '设计器',
|
||||
value: 'https://github.com/alibaba/lowcode-demo/tree/main/demo-antd-pro-with-formily',
|
||||
},
|
||||
{
|
||||
"key": "formily 物料",
|
||||
"value": "https://github.com/seada-low-code/lowcode-ecology/tree/main/packages/formily-materials"
|
||||
}
|
||||
],
|
||||
},
|
||||
});
|
||||
|
||||
// 设置内置 setter 和事件绑定、插件绑定面板
|
||||
await plugins.register(DefaultSettersRegistryPlugin);
|
||||
|
||||
await plugins.register(LogoSamplePlugin);
|
||||
|
||||
await plugins.register(ComponentPanelPlugin);
|
||||
|
||||
await plugins.register(SchemaPlugin);
|
||||
|
||||
await plugins.register(ManualPlugin);
|
||||
// 注册回退/前进
|
||||
await plugins.register(UndoRedoPlugin);
|
||||
|
||||
// 注册中英文切换
|
||||
await plugins.register(ZhEnPlugin);
|
||||
|
||||
await plugins.register(SetRefPropPlugin);
|
||||
|
||||
await plugins.register(SimulatorResizerPlugin);
|
||||
|
||||
await plugins.register(LoadIncrementalAssetsWidgetPlugin);
|
||||
|
||||
await plugins.register(PluginFormily)
|
||||
|
||||
// 插件参数声明 & 传递,参考:https://lowcode-engine.cn/site/docs/api/plugins#设置插件参数版本示例
|
||||
await plugins.register(DataSourcePanePlugin, {
|
||||
importPlugins: [],
|
||||
dataSourceTypes: [
|
||||
{
|
||||
type: 'fetch',
|
||||
},
|
||||
{
|
||||
type: 'jsonp',
|
||||
}
|
||||
]
|
||||
});
|
||||
|
||||
await plugins.register(CodeEditorPlugin);
|
||||
|
||||
// 注册出码插件
|
||||
await plugins.register(CodeGenPlugin);
|
||||
|
||||
await plugins.register(SaveSamplePlugin);
|
||||
|
||||
await plugins.register(PreviewSamplePlugin);
|
||||
|
||||
await plugins.register(CustomSetterSamplePlugin);
|
||||
};
|
||||
|
||||
(async function main() {
|
||||
await registerPlugins();
|
||||
|
||||
init(document.getElementById('lce-container')!, {
|
||||
// locale: 'zh-CN',
|
||||
enableCondition: true,
|
||||
enableCanvasLock: true,
|
||||
// 默认绑定变量
|
||||
supportVariableGlobally: true,
|
||||
requestHandlersMap: {
|
||||
fetch: createFetchHandler()
|
||||
},
|
||||
});
|
||||
})();
|
|
@ -1,19 +0,0 @@
|
|||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import TitleSetter from '@alilc/lowcode-setter-title';
|
||||
import BehaviorSetter from './setters/behavior-setter';
|
||||
import CustomSetter from './setters/custom-setter';
|
||||
|
||||
// 保存功能示例
|
||||
const CustomSetterSamplePlugin = (ctx: IPublicModelPluginContext) => {
|
||||
return {
|
||||
async init() {
|
||||
const { setters } = ctx;
|
||||
|
||||
setters.registerSetter('TitleSetter', TitleSetter);
|
||||
setters.registerSetter('BehaviorSetter', BehaviorSetter);
|
||||
setters.registerSetter('CustomSetter', CustomSetter);
|
||||
},
|
||||
};
|
||||
}
|
||||
CustomSetterSamplePlugin.pluginName = 'CustomSetterSamplePlugin';
|
||||
export default CustomSetterSamplePlugin;
|
|
@ -1,27 +0,0 @@
|
|||
import * as React from 'react';
|
||||
import BehaviorSetter from '@alilc/lowcode-setter-behavior';
|
||||
|
||||
|
||||
const defaultExtraBehaviorActions: any[] = [];
|
||||
class LocalBehaviorSetter extends React.Component {
|
||||
render() {
|
||||
// ignore url && responseFormatter props, use default ones
|
||||
const { url: propsUrl, responseFormatter: propsFormatter, extraBehaviorActions: propsExtraBehaviorActions = [], ...otherProps } = this.props;
|
||||
const url = 'https://hn.algolia.com/api/v1/search?query';
|
||||
const responseFormatter = (response) => response.hits.map((item) => ({
|
||||
label: item.title,
|
||||
value: item.author
|
||||
}));
|
||||
const extraBehaviorActions = propsExtraBehaviorActions.concat(defaultExtraBehaviorActions);
|
||||
return (
|
||||
<BehaviorSetter
|
||||
{...otherProps}
|
||||
url={url}
|
||||
responseFormatter={responseFormatter}
|
||||
extraBehaviorActions={extraBehaviorActions}
|
||||
/>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
export default LocalBehaviorSetter;
|
|
@ -1,13 +0,0 @@
|
|||
import React, { Component } from 'react';
|
||||
// import classNames from 'classnames';
|
||||
|
||||
class CustomSetter extends Component<any, any> {
|
||||
render() {
|
||||
const { defaultValue, value, onChange } = this.props;
|
||||
const { editor } = this.props.field;
|
||||
|
||||
return <div>hello world</div>;
|
||||
}
|
||||
}
|
||||
|
||||
export default CustomSetter;
|
|
@ -1,34 +0,0 @@
|
|||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import AliLowCodeEngineExt from '@alilc/lowcode-engine-ext';
|
||||
|
||||
// 设置内置 setter 和事件绑定、插件绑定面板
|
||||
const DefaultSettersRegistryPlugin = (ctx: IPublicModelPluginContext) => {
|
||||
return {
|
||||
async init() {
|
||||
const { setterMap, pluginMap } = AliLowCodeEngineExt;
|
||||
const { setters, skeleton } = ctx;
|
||||
// 注册setterMap
|
||||
setters.registerSetter(setterMap);
|
||||
// 注册插件
|
||||
// 注册事件绑定面板
|
||||
skeleton.add({
|
||||
area: 'centerArea',
|
||||
type: 'Widget',
|
||||
content: pluginMap.EventBindDialog,
|
||||
name: 'eventBindDialog',
|
||||
props: {},
|
||||
});
|
||||
|
||||
// 注册变量绑定面板
|
||||
skeleton.add({
|
||||
area: 'centerArea',
|
||||
type: 'Widget',
|
||||
content: pluginMap.VariableBindDialog,
|
||||
name: 'variableBindDialog',
|
||||
props: {},
|
||||
});
|
||||
},
|
||||
};
|
||||
}
|
||||
DefaultSettersRegistryPlugin.pluginName = 'DefaultSettersRegistryPlugin';
|
||||
export default DefaultSettersRegistryPlugin;
|
|
@ -1,51 +0,0 @@
|
|||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import { injectAssets } from '@alilc/lowcode-plugin-inject';
|
||||
import assets from '../../services/assets.json';
|
||||
import { getPageSchema } from '../../services/mockService';
|
||||
const EditorInitPlugin = (ctx: IPublicModelPluginContext, options: any) => {
|
||||
return {
|
||||
async init() {
|
||||
const { material, project, config } = ctx;
|
||||
const scenarioName = options['scenarioName'];
|
||||
const scenarioDisplayName = options['displayName'] || scenarioName;
|
||||
const scenarioInfo = options['info'] || {};
|
||||
// 保存在config中用于引擎范围其他插件使用
|
||||
config.set('scenarioName', scenarioName);
|
||||
config.set('scenarioDisplayName', scenarioDisplayName);
|
||||
config.set('scenarioInfo', scenarioInfo);
|
||||
|
||||
// 设置物料描述
|
||||
|
||||
await material.setAssets(await injectAssets(assets));
|
||||
|
||||
const schema = await getPageSchema(scenarioName);
|
||||
|
||||
// 加载 schema
|
||||
project.openDocument(schema);
|
||||
},
|
||||
};
|
||||
}
|
||||
EditorInitPlugin.pluginName = 'EditorInitPlugin';
|
||||
EditorInitPlugin.meta = {
|
||||
preferenceDeclaration: {
|
||||
title: '保存插件配置',
|
||||
properties: [
|
||||
{
|
||||
key: 'scenarioName',
|
||||
type: 'string',
|
||||
description: '用于localstorage存储key',
|
||||
},
|
||||
{
|
||||
key: 'displayName',
|
||||
type: 'string',
|
||||
description: '用于显示的场景名',
|
||||
},
|
||||
{
|
||||
key: 'info',
|
||||
type: 'object',
|
||||
description: '用于扩展信息',
|
||||
}
|
||||
],
|
||||
},
|
||||
};
|
||||
export default EditorInitPlugin;
|
|
@ -1,170 +0,0 @@
|
|||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import { Button } from '@alifd/next';
|
||||
import { material } from '@alilc/lowcode-engine';
|
||||
import { Message } from '@alifd/next';
|
||||
|
||||
const loadIncrementalAssets = () => {
|
||||
material?.onChangeAssets(() => {
|
||||
Message.success('[MCBreadcrumb] 物料加载成功');
|
||||
});
|
||||
|
||||
material.loadIncrementalAssets({
|
||||
packages: [
|
||||
{
|
||||
title: 'MCBreadcrumb',
|
||||
package: 'mc-breadcrumb',
|
||||
version: '1.0.0',
|
||||
urls: [
|
||||
'https://unpkg.alibaba-inc.com/mc-breadcrumb@1.0.0/dist/MCBreadcrumb.js',
|
||||
'https://unpkg.alibaba-inc.com/mc-breadcrumb@1.0.0/dist/MCBreadcrumb.css',
|
||||
],
|
||||
library: 'MCBreadcrumb',
|
||||
},
|
||||
],
|
||||
components: [
|
||||
{
|
||||
componentName: 'MCBreadcrumb',
|
||||
title: 'MCBreadcrumb',
|
||||
docUrl: '',
|
||||
screenshot: '',
|
||||
npm: {
|
||||
package: 'mc-breadcrumb',
|
||||
version: '1.0.0',
|
||||
exportName: 'MCBreadcrumb',
|
||||
main: 'lib/index.js',
|
||||
destructuring: false,
|
||||
subName: '',
|
||||
},
|
||||
props: [
|
||||
{
|
||||
name: 'prefix',
|
||||
propType: 'string',
|
||||
description: '样式类名的品牌前缀',
|
||||
defaultValue: 'next-',
|
||||
},
|
||||
{
|
||||
name: 'title',
|
||||
propType: 'string',
|
||||
description: '标题',
|
||||
defaultValue: 'next-',
|
||||
},
|
||||
{
|
||||
name: 'rtl',
|
||||
propType: 'bool',
|
||||
},
|
||||
{
|
||||
name: 'children',
|
||||
propType: {
|
||||
type: 'instanceOf',
|
||||
value: 'node',
|
||||
},
|
||||
description: '面包屑子节点,需传入 Breadcrumb.Item',
|
||||
},
|
||||
{
|
||||
name: 'maxNode',
|
||||
propType: {
|
||||
type: 'oneOfType',
|
||||
value: [
|
||||
'number',
|
||||
{
|
||||
type: 'oneOf',
|
||||
value: ['auto'],
|
||||
},
|
||||
],
|
||||
},
|
||||
description:
|
||||
'面包屑最多显示个数,超出部分会被隐藏, 设置为 auto 会自动根据父元素的宽度适配。',
|
||||
defaultValue: 100,
|
||||
},
|
||||
{
|
||||
name: 'separator',
|
||||
propType: {
|
||||
type: 'instanceOf',
|
||||
value: 'node',
|
||||
},
|
||||
description: '分隔符,可以是文本或 Icon',
|
||||
},
|
||||
{
|
||||
name: 'component',
|
||||
propType: {
|
||||
type: 'oneOfType',
|
||||
value: ['string', 'func'],
|
||||
},
|
||||
description: '设置标签类型',
|
||||
defaultValue: 'nav',
|
||||
},
|
||||
{
|
||||
name: 'className',
|
||||
propType: 'any',
|
||||
},
|
||||
{
|
||||
name: 'style',
|
||||
propType: 'object',
|
||||
},
|
||||
],
|
||||
configure: {
|
||||
component: {
|
||||
isContainer: true,
|
||||
isModel: true,
|
||||
rootSelector: 'div.MCBreadcrumb',
|
||||
},
|
||||
},
|
||||
},
|
||||
],
|
||||
|
||||
componentList: [
|
||||
{
|
||||
title: '常用',
|
||||
icon: '',
|
||||
children: [
|
||||
{
|
||||
componentName: 'MCBreadcrumb',
|
||||
title: 'MC面包屑',
|
||||
icon: '',
|
||||
package: 'mc-breadcrumb',
|
||||
library: 'MCBreadcrumb',
|
||||
snippets: [
|
||||
{
|
||||
title: 'MC面包屑',
|
||||
screenshot:
|
||||
'https://alifd.oss-cn-hangzhou.aliyuncs.com/fusion-cool/icons/icon-light/ic_light_breadcrumb.png',
|
||||
schema: {
|
||||
componentName: 'MCBreadcrumb',
|
||||
props: {
|
||||
title: '物料中心',
|
||||
prefix: 'next-',
|
||||
maxNode: 100,
|
||||
},
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
});
|
||||
};
|
||||
const LoadIncrementalAssetsWidgetPlugin = (ctx: IPublicModelPluginContext) => {
|
||||
return {
|
||||
async init() {
|
||||
const { skeleton } = ctx;
|
||||
|
||||
skeleton.add({
|
||||
name: 'loadAssetsSample',
|
||||
area: 'topArea',
|
||||
type: 'Widget',
|
||||
props: {
|
||||
align: 'right',
|
||||
width: 80,
|
||||
},
|
||||
content: (
|
||||
<Button onClick={loadIncrementalAssets}>
|
||||
异步加载资源
|
||||
</Button>
|
||||
),
|
||||
});
|
||||
},
|
||||
};
|
||||
}
|
||||
LoadIncrementalAssetsWidgetPlugin.pluginName = 'LoadIncrementalAssetsWidgetPlugin';
|
||||
export default LoadIncrementalAssetsWidgetPlugin;
|
|
@ -1,25 +0,0 @@
|
|||
.lowcode-plugin-logo {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
justify-content: flex-start;
|
||||
align-items: flex-end;
|
||||
width: 400px;
|
||||
.logo {
|
||||
display: block;
|
||||
width: 139px;
|
||||
height: 26px;
|
||||
cursor: pointer;
|
||||
background-size: contain;
|
||||
background-position: center;
|
||||
background-repeat: no-repeat;
|
||||
}
|
||||
.scenario-name {
|
||||
display: block;
|
||||
margin-left: 20px;
|
||||
margin-right: 5px;
|
||||
font-size: 14px;
|
||||
}
|
||||
.info-dropdown {
|
||||
display: block;
|
||||
}
|
||||
}
|
|
@ -1,74 +0,0 @@
|
|||
import React from 'react';
|
||||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import { Dropdown, Menu } from '@alifd/next';
|
||||
import './index.scss';
|
||||
export interface IProps {
|
||||
logo?: string;
|
||||
href?: string;
|
||||
scenarioInfo?: any;
|
||||
scenarioDisplayName?: string;
|
||||
}
|
||||
|
||||
const Logo: React.FC<IProps> = (props): React.ReactElement => {
|
||||
const { scenarioDisplayName, scenarioInfo } = props;
|
||||
const urls = scenarioInfo?.urls || [];
|
||||
return (
|
||||
<div className="lowcode-plugin-logo">
|
||||
<a className="logo" target="blank" href={props.href || 'https://lowcode-engine.cn'} style={{ backgroundImage: `url(${props.logo})` }} />
|
||||
<div className="scenario-name">{scenarioDisplayName}</div>
|
||||
{
|
||||
urls && (
|
||||
<Dropdown
|
||||
className="info-dropdown"
|
||||
trigger={(
|
||||
<img
|
||||
style={{
|
||||
height: '18px',
|
||||
position: 'relative',
|
||||
top: '-2px',
|
||||
}}
|
||||
src="https://img.alicdn.com/imgextra/i4/O1CN013upU1R1yl5wVezP8k_!!6000000006618-2-tps-512-512.png"
|
||||
/>
|
||||
)}
|
||||
triggerType="click"
|
||||
>
|
||||
<Menu onItemClick={(key, item) => window.open(key, '_blank')}>
|
||||
{
|
||||
urls.map((url: any) => <Menu.Item key={url.value}>{url.key}</Menu.Item>)
|
||||
}
|
||||
</Menu>
|
||||
</Dropdown>
|
||||
)
|
||||
}
|
||||
</div>
|
||||
);
|
||||
};
|
||||
// 示例 Logo widget
|
||||
const LogoSamplePlugin = (ctx: IPublicModelPluginContext) => {
|
||||
return {
|
||||
async init() {
|
||||
const { skeleton, config } = ctx;
|
||||
const scenarioDisplayName = config.get('scenarioDisplayName');
|
||||
const scenarioInfo = config.get('scenarioInfo');
|
||||
// 注册 logo widget
|
||||
skeleton.add({
|
||||
area: 'topArea',
|
||||
type: 'Widget',
|
||||
name: 'logo',
|
||||
content: <Logo scenarioDisplayName={scenarioDisplayName} scenarioInfo={scenarioInfo} />,
|
||||
contentProps: {
|
||||
logo: 'https://img.alicdn.com/imgextra/i4/O1CN013w2bmQ25WAIha4Hx9_!!6000000007533-55-tps-137-26.svg',
|
||||
href: 'https://lowcode-engine.cn',
|
||||
},
|
||||
props: {
|
||||
align: 'left',
|
||||
},
|
||||
});
|
||||
},
|
||||
};
|
||||
}
|
||||
LogoSamplePlugin.pluginName = 'LogoSamplePlugin';
|
||||
LogoSamplePlugin.meta = {
|
||||
dependencies: ['EditorInitPlugin'],
|
||||
};
|
||||
export default LogoSamplePlugin;
|
|
@ -1,40 +0,0 @@
|
|||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import { Button } from '@alifd/next';
|
||||
import {
|
||||
saveSchema,
|
||||
} from '../../services/mockService';
|
||||
|
||||
// 保存功能示例
|
||||
const PreviewSamplePlugin = (ctx: IPublicModelPluginContext) => {
|
||||
return {
|
||||
async init() {
|
||||
const { skeleton, config } = ctx;
|
||||
const doPreview = () => {
|
||||
const scenarioName = config.get('scenarioName');
|
||||
saveSchema(scenarioName);
|
||||
setTimeout(() => {
|
||||
const search = location.search ? `${location.search}&scenarioName=${scenarioName}` : `?scenarioName=${scenarioName}`;
|
||||
window.open(`./preview.html${search}`);
|
||||
}, 500);
|
||||
};
|
||||
skeleton.add({
|
||||
name: 'previewSample',
|
||||
area: 'topArea',
|
||||
type: 'Widget',
|
||||
props: {
|
||||
align: 'right',
|
||||
},
|
||||
content: (
|
||||
<Button type="primary" onClick={() => doPreview()}>
|
||||
预览
|
||||
</Button>
|
||||
),
|
||||
});
|
||||
},
|
||||
};
|
||||
}
|
||||
PreviewSamplePlugin.pluginName = 'PreviewSamplePlugin';
|
||||
PreviewSamplePlugin.meta = {
|
||||
dependencies: ['EditorInitPlugin'],
|
||||
};
|
||||
export default PreviewSamplePlugin;
|
|
@ -1,52 +0,0 @@
|
|||
import { IPublicModelPluginContext } from '@alilc/lowcode-types';
|
||||
import { Button } from '@alifd/next';
|
||||
import {
|
||||
saveSchema,
|
||||
resetSchema,
|
||||
} from '../../services/mockService';
|
||||
|
||||
// 保存功能示例
|
||||
const SaveSamplePlugin = (ctx: IPublicModelPluginContext) => {
|
||||
return {
|
||||
async init() {
|
||||
const { skeleton, hotkey, config } = ctx;
|
||||
const scenarioName = config.get('scenarioName');
|
||||
|
||||
skeleton.add({
|
||||
name: 'saveSample',
|
||||
area: 'topArea',
|
||||
type: 'Widget',
|
||||
props: {
|
||||
align: 'right',
|
||||
},
|
||||
content: (
|
||||
<Button onClick={() => saveSchema(scenarioName)}>
|
||||
保存到本地
|
||||
</Button>
|
||||
),
|
||||
});
|
||||
skeleton.add({
|
||||
name: 'resetSchema',
|
||||
area: 'topArea',
|
||||
type: 'Widget',
|
||||
props: {
|
||||
align: 'right',
|
||||
},
|
||||
content: (
|
||||
<Button onClick={() => resetSchema(scenarioName)}>
|
||||
重置页面
|
||||
</Button>
|
||||
),
|
||||
});
|
||||
hotkey.bind('command+s', (e) => {
|
||||
e.preventDefault();
|
||||
saveSchema(scenarioName);
|
||||
});
|
||||
},
|
||||
};
|
||||
}
|
||||
SaveSamplePlugin.pluginName = 'SaveSamplePlugin';
|
||||
SaveSamplePlugin.meta = {
|
||||
dependencies: ['EditorInitPlugin'],
|
||||
};
|
||||
export default SaveSamplePlugin;
|
|
@ -1,79 +0,0 @@
|
|||
import ReactDOM from 'react-dom';
|
||||
import React, { useState } from 'react';
|
||||
import { Loading } from '@alifd/next';
|
||||
import { buildComponents, assetBundle, AssetLevel, AssetLoader } from '@alilc/lowcode-utils';
|
||||
import ReactRenderer from '@alilc/lowcode-react-renderer';
|
||||
import { injectComponents } from '@alilc/lowcode-plugin-inject';
|
||||
import { createFetchHandler } from '@alilc/lowcode-datasource-fetch-handler'
|
||||
|
||||
import { getProjectSchemaFromLocalStorage, getPackagesFromLocalStorage } from './services/mockService';
|
||||
|
||||
const getScenarioName = function () {
|
||||
if (location.search) {
|
||||
return new URLSearchParams(location.search.slice(1)).get('scenarioName') || 'index';
|
||||
}
|
||||
return 'index';
|
||||
}
|
||||
|
||||
const SamplePreview = () => {
|
||||
const [data, setData] = useState({});
|
||||
|
||||
async function init() {
|
||||
const scenarioName = getScenarioName();
|
||||
const packages = getPackagesFromLocalStorage(scenarioName);
|
||||
const projectSchema = getProjectSchemaFromLocalStorage(scenarioName);
|
||||
const { componentsMap: componentsMapArray, componentsTree } = projectSchema;
|
||||
const componentsMap: any = {};
|
||||
componentsMapArray.forEach((component: any) => {
|
||||
componentsMap[component.componentName] = component;
|
||||
});
|
||||
const schema = componentsTree[0];
|
||||
|
||||
const libraryMap = {};
|
||||
const libraryAsset = [];
|
||||
packages.forEach(({ package: _package, library, urls, renderUrls }) => {
|
||||
libraryMap[_package] = library;
|
||||
if (renderUrls) {
|
||||
libraryAsset.push(renderUrls);
|
||||
} else if (urls) {
|
||||
libraryAsset.push(urls);
|
||||
}
|
||||
});
|
||||
|
||||
const vendors = [assetBundle(libraryAsset, AssetLevel.Library)];
|
||||
|
||||
// TODO asset may cause pollution
|
||||
const assetLoader = new AssetLoader();
|
||||
await assetLoader.load(libraryAsset);
|
||||
const components = await injectComponents(buildComponents(libraryMap, componentsMap));
|
||||
|
||||
setData({
|
||||
schema,
|
||||
components,
|
||||
});
|
||||
}
|
||||
|
||||
const { schema, components } = data;
|
||||
|
||||
if (!schema || !components) {
|
||||
init();
|
||||
return <Loading fullScreen />;
|
||||
}
|
||||
|
||||
return (
|
||||
<div className="lowcode-plugin-sample-preview">
|
||||
<ReactRenderer
|
||||
className="lowcode-plugin-sample-preview-content"
|
||||
schema={schema}
|
||||
components={components}
|
||||
appHelper={{
|
||||
requestHandlersMap: {
|
||||
fetch: createFetchHandler()
|
||||
}
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
ReactDOM.render(<SamplePreview />, document.getElementById('ice-container'));
|
|
@ -1,137 +0,0 @@
|
|||
{
|
||||
"packages": [
|
||||
{
|
||||
"package": "moment",
|
||||
"version": "2.24.0",
|
||||
"urls": ["https://g.alicdn.com/mylib/moment/2.24.0/min/moment.min.js"],
|
||||
"library": "moment"
|
||||
},
|
||||
{
|
||||
"package": "lodash",
|
||||
"library": "_",
|
||||
"urls": ["https://g.alicdn.com/platform/c/lodash/4.6.1/lodash.min.js"]
|
||||
},
|
||||
{
|
||||
"package": "iconfont-icons",
|
||||
"urls": "//at.alicdn.com/t/font_2369445_ukrtsovd92r.js"
|
||||
},
|
||||
{
|
||||
"package": "@ant-design/icons",
|
||||
"version": "4.7.0",
|
||||
"urls": ["//g.alicdn.com/code/npm/@ali/ant-design-icons-cdn/4.5.0/index.umd.min.js"],
|
||||
"library": "icons"
|
||||
},
|
||||
{
|
||||
"package": "antd",
|
||||
"version": "4.23.0",
|
||||
"urls": [
|
||||
"//g.alicdn.com/code/lib/antd/4.23.0/antd.min.js",
|
||||
"//g.alicdn.com/code/lib/antd/4.23.0/antd.min.css"
|
||||
],
|
||||
"library": "antd"
|
||||
},
|
||||
{
|
||||
"title": "fusion组件库",
|
||||
"package": "@alifd/next",
|
||||
"version": "1.26.4",
|
||||
"urls": [
|
||||
"https://g.alicdn.com/code/lib/alifd__next/1.26.4/next.min.css",
|
||||
"https://g.alicdn.com/code/lib/alifd__next/1.26.4/next-with-locales.min.js"
|
||||
],
|
||||
"library": "Next"
|
||||
},
|
||||
{
|
||||
"package": "@alilc/antd-lowcode-materials",
|
||||
"version": "1.1.1",
|
||||
"library": "AntdLowcode",
|
||||
"urls": [
|
||||
"https://alifd.alicdn.com/npm/@alilc/antd-lowcode-materials@1.1.1/build/lowcode/view.js",
|
||||
"https://alifd.alicdn.com/npm/@alilc/antd-lowcode-materials@1.1.1/build/lowcode/view.css"
|
||||
],
|
||||
"editUrls": [
|
||||
"https://alifd.alicdn.com/npm/@alilc/antd-lowcode-materials@1.1.1/build/lowcode/view.js",
|
||||
"https://alifd.alicdn.com/npm/@alilc/antd-lowcode-materials@1.1.1/build/lowcode/view.css"
|
||||
]
|
||||
},
|
||||
{
|
||||
"package": "@seada/antd-materials",
|
||||
"version": "1.0.0-rc.27",
|
||||
"library": "SeadaAntdMaterials",
|
||||
"urls": [
|
||||
"https://unpkg.com/@seada/antd-materials@1.0.0-rc.27/build/lowcode/view.js",
|
||||
"https://unpkg.com/@seada/antd-materials@1.0.0-rc.27/build/lowcode/view.css"
|
||||
],
|
||||
"editUrls": [
|
||||
"https://unpkg.com/@seada/antd-materials@1.0.0-rc.27/build/lowcode/view.js",
|
||||
"https://unpkg.com/@seada/antd-materials@1.0.0-rc.27/build/lowcode/view.css"
|
||||
]
|
||||
},
|
||||
{
|
||||
"package": "@seada/formily-materials",
|
||||
"version": "1.0.0-rc.27",
|
||||
"library": "SeadaFormilyMaterials",
|
||||
"urls": [
|
||||
"https://unpkg.com/@seada/formily-materials@1.0.0-rc.27/build/lowcode/view.js",
|
||||
"https://unpkg.com/@seada/formily-materials@1.0.0-rc.27/build/lowcode/view.css"
|
||||
],
|
||||
"editUrls": [
|
||||
"https://unpkg.com/@seada/formily-materials@1.0.0-rc.27/build/lowcode/view.js",
|
||||
"https://unpkg.com/@seada/formily-materials@1.0.0-rc.27/build/lowcode/view.css"
|
||||
]
|
||||
}
|
||||
],
|
||||
"components": [
|
||||
{
|
||||
"exportName": "AlilcAntdLowcodeMaterialsMeta",
|
||||
"npm": {
|
||||
"package": "@alilc/antd-lowcode-materials",
|
||||
"version": "1.1.1"
|
||||
},
|
||||
"url": "https://alifd.alicdn.com/npm/@alilc/antd-lowcode-materials@1.1.1/build/lowcode/meta.js",
|
||||
"urls": {
|
||||
"default": "https://alifd.alicdn.com/npm/@alilc/antd-lowcode-materials@1.1.1/build/lowcode/meta.js"
|
||||
}
|
||||
},
|
||||
{
|
||||
"exportName": "SeadaAntdMaterialsMeta",
|
||||
"npm": {
|
||||
"package": "@seada/antd-materials",
|
||||
"version": "1.0.0-rc.27"
|
||||
},
|
||||
"url": "https://unpkg.com/@seada/antd-materials@1.0.0-rc.27/build/lowcode/meta.js",
|
||||
"urls": {
|
||||
"default": "https://unpkg.com/@seada/antd-materials@1.0.0-rc.27/build/lowcode/meta.js"
|
||||
}
|
||||
},
|
||||
{
|
||||
"exportName": "SeadaFormilyMaterialsMeta",
|
||||
"npm": {
|
||||
"package": "@seada/formily-materials",
|
||||
"version": "1.0.0-rc.27"
|
||||
},
|
||||
"url": "https://unpkg.com/@seada/formily-materials@1.0.0-rc.27/build/lowcode/meta.js",
|
||||
"urls": {
|
||||
"default": "https://unpkg.com/@seada/formily-materials@1.0.0-rc.27/build/lowcode/meta.js"
|
||||
}
|
||||
}
|
||||
],
|
||||
"sort": {
|
||||
"groupList": ["精选组件", "原子组件"],
|
||||
"categoryList": [
|
||||
"基础元素",
|
||||
"布局容器类",
|
||||
"表格类",
|
||||
"表单详情类",
|
||||
"帮助类",
|
||||
"对话框类",
|
||||
"业务类",
|
||||
"通用",
|
||||
"引导",
|
||||
"信息输入",
|
||||
"信息展示",
|
||||
"信息反馈"
|
||||
]
|
||||
},
|
||||
"groupList": ["精选组件", "原子组件"],
|
||||
"ignoreComponents": {}
|
||||
}
|
|
@ -1,94 +0,0 @@
|
|||
import { material, project } from '@alilc/lowcode-engine';
|
||||
import { filterPackages } from '@alilc/lowcode-plugin-inject'
|
||||
import { Message, Dialog } from '@alifd/next';
|
||||
import { IPublicEnumTransformStage } from '@alilc/lowcode-types';
|
||||
import schema from './schema.json';
|
||||
|
||||
export const saveSchema = async (scenarioName: string = 'unknown') => {
|
||||
setProjectSchemaToLocalStorage(scenarioName);
|
||||
await setPackagesToLocalStorage(scenarioName);
|
||||
Message.success('成功保存到本地');
|
||||
};
|
||||
|
||||
export const resetSchema = async (scenarioName: string = 'unknown') => {
|
||||
try {
|
||||
await new Promise<void>((resolve, reject) => {
|
||||
Dialog.confirm({
|
||||
content: '确定要重置吗?您所有的修改都将消失!',
|
||||
onOk: () => {
|
||||
resolve();
|
||||
},
|
||||
onCancel: () => {
|
||||
reject()
|
||||
},
|
||||
})
|
||||
})
|
||||
} catch(err) {
|
||||
return;
|
||||
}
|
||||
|
||||
let defaultSchema = schema || {
|
||||
componentsTree: [{ componentName: 'Page', fileName: 'sample' }],
|
||||
componentsMap: material.componentsMap,
|
||||
version: '1.0.0',
|
||||
i18n: {},
|
||||
};
|
||||
|
||||
project.getCurrentDocument()?.importSchema(defaultSchema as any);
|
||||
project.simulatorHost?.rerender();
|
||||
|
||||
setProjectSchemaToLocalStorage(scenarioName);
|
||||
await setPackagesToLocalStorage(scenarioName);
|
||||
Message.success('成功重置页面');
|
||||
}
|
||||
|
||||
const getLSName = (scenarioName: string, ns: string = 'projectSchema') => `${scenarioName}:${ns}`;
|
||||
|
||||
export const getProjectSchemaFromLocalStorage = (scenarioName: string) => {
|
||||
if (!scenarioName) {
|
||||
console.error('scenarioName is required!');
|
||||
return;
|
||||
}
|
||||
return JSON.parse(window.localStorage.getItem(getLSName(scenarioName)) || '{}');
|
||||
}
|
||||
|
||||
const setProjectSchemaToLocalStorage = (scenarioName: string) => {
|
||||
if (!scenarioName) {
|
||||
console.error('scenarioName is required!');
|
||||
return;
|
||||
}
|
||||
window.localStorage.setItem(
|
||||
getLSName(scenarioName),
|
||||
JSON.stringify(project.exportSchema(IPublicEnumTransformStage.Save))
|
||||
);
|
||||
}
|
||||
|
||||
const setPackagesToLocalStorage = async (scenarioName: string) => {
|
||||
if (!scenarioName) {
|
||||
console.error('scenarioName is required!');
|
||||
return;
|
||||
}
|
||||
const packages = await filterPackages(material.getAssets().packages);
|
||||
window.localStorage.setItem(
|
||||
getLSName(scenarioName, 'packages'),
|
||||
JSON.stringify(packages),
|
||||
);
|
||||
}
|
||||
|
||||
export const getPackagesFromLocalStorage = (scenarioName: string) => {
|
||||
if (!scenarioName) {
|
||||
console.error('scenarioName is required!');
|
||||
return;
|
||||
}
|
||||
return JSON.parse(window.localStorage.getItem(getLSName(scenarioName, 'packages')) || '{}');
|
||||
}
|
||||
|
||||
export const getPageSchema = async (scenarioName: string = 'unknown') => {
|
||||
const pageSchema = getProjectSchemaFromLocalStorage(scenarioName).componentsTree?.[0];
|
||||
|
||||
if (pageSchema) {
|
||||
return pageSchema;
|
||||
}
|
||||
|
||||
return schema;
|
||||
};
|
|
@ -1,69 +0,0 @@
|
|||
{
|
||||
"componentName": "Page",
|
||||
"id": "node_dockcviv8fo1",
|
||||
"props": {
|
||||
"ref": "outerView",
|
||||
"style": {
|
||||
"height": "100%"
|
||||
}
|
||||
},
|
||||
"fileName": "/",
|
||||
"dataSource": {
|
||||
"list": [
|
||||
{
|
||||
"type": "fetch",
|
||||
"isInit": true,
|
||||
"options": {
|
||||
"params": {},
|
||||
"method": "GET",
|
||||
"isCors": true,
|
||||
"timeout": 5000,
|
||||
"headers": {},
|
||||
"uri": "mock/info.json"
|
||||
},
|
||||
"id": "info"
|
||||
}
|
||||
]
|
||||
},
|
||||
"state": {
|
||||
"text": {
|
||||
"type": "JSExpression",
|
||||
"value": "\"outer\""
|
||||
},
|
||||
"isShowDialog": {
|
||||
"type": "JSExpression",
|
||||
"value": "false"
|
||||
}
|
||||
},
|
||||
"css": "body {\n font-size: 12px;\n}\n\n.button {\n width: 100px;\n color: #ff00ff\n}",
|
||||
"lifeCycles": {
|
||||
"componentDidMount": {
|
||||
"type": "JSFunction",
|
||||
"value": "function componentDidMount() {\n console.log('did mount');\n}"
|
||||
},
|
||||
"componentWillUnmount": {
|
||||
"type": "JSFunction",
|
||||
"value": "function componentWillUnmount() {\n console.log('will unmount');\n}"
|
||||
}
|
||||
},
|
||||
"methods": {
|
||||
"testFunc": {
|
||||
"type": "JSFunction",
|
||||
"value": "function testFunc() {\n console.log('test func');\n}"
|
||||
},
|
||||
"onClick": {
|
||||
"type": "JSFunction",
|
||||
"value": "function onClick() {\n this.setState({\n isShowDialog: true\n });\n}"
|
||||
},
|
||||
"closeDialog": {
|
||||
"type": "JSFunction",
|
||||
"value": "function closeDialog() {\n this.setState({\n isShowDialog: false\n });\n}"
|
||||
}
|
||||
},
|
||||
"originCode": "class LowcodeComponent extends Component {\n state = {\n \"text\": \"outer\",\n \"isShowDialog\": false\n }\n componentDidMount() {\n console.log('did mount');\n }\n componentWillUnmount() {\n console.log('will unmount');\n }\n testFunc() {\n console.log('test func');\n }\n onClick() {\n this.setState({\n isShowDialog: true\n })\n }\n closeDialog() {\n this.setState({\n isShowDialog: false\n })\n }\n}",
|
||||
"hidden": false,
|
||||
"title": "",
|
||||
"isLocked": false,
|
||||
"condition": true,
|
||||
"conditionGroup": ""
|
||||
}
|
|
@ -1,44 +0,0 @@
|
|||
{
|
||||
"compilerOptions": {
|
||||
"baseUrl": ".",
|
||||
"declaration": true,
|
||||
"lib": ["es2015", "dom"],
|
||||
// Target latest version of ECMAScript.
|
||||
"target": "esnext",
|
||||
// Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'.
|
||||
"module": "esnext",
|
||||
// Search under node_modules for non-relative imports.
|
||||
"moduleResolution": "node",
|
||||
// Process & infer types from .js files.
|
||||
"allowJs": true,
|
||||
// Report errors in .js files.
|
||||
"checkJs": false,
|
||||
// Don't emit; allow Babel to transform files.
|
||||
// "noEmit": true,
|
||||
// Enable strictest settings like strictNullChecks & noImplicitAny.
|
||||
"strict": true,
|
||||
// Allow default imports from modules with no default export. This does not affect code emit, just typechecking.
|
||||
"allowSyntheticDefaultImports": true,
|
||||
// Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'.
|
||||
"esModuleInterop": true,
|
||||
// Specify JSX code generation: 'preserve', 'react-native', or 'react'.
|
||||
"jsx": "preserve",
|
||||
// Import emit helpers (e.g. __extends, __rest, etc..) from tslib
|
||||
"importHelpers": true,
|
||||
// Enables experimental support for ES7 decorators.
|
||||
"experimentalDecorators": true,
|
||||
// Generates corresponding .map file.
|
||||
"sourceMap": true,
|
||||
// Disallow inconsistently-cased references to the same file.
|
||||
"forceConsistentCasingInFileNames": true,
|
||||
// Allow json import
|
||||
"resolveJsonModule": true,
|
||||
// skip type checking of declaration files
|
||||
"skipLibCheck": true,
|
||||
"outDir": "lib"
|
||||
},
|
||||
"include": [
|
||||
"./src/"
|
||||
],
|
||||
"exclude": ["**/test", "**/lib", "**/es", "node_modules"]
|
||||
}
|
|
@ -19,15 +19,15 @@
|
|||
"@alilc/lowcode-datasource-fetch-handler": "^1.0.1",
|
||||
"@alilc/lowcode-plugin-code-editor": "^1.0.3",
|
||||
"@alilc/lowcode-plugin-code-generator": "^1.0.4",
|
||||
"@alilc/lowcode-plugin-components-pane": "^2.0.0",
|
||||
"@alilc/lowcode-plugin-components-pane": "latest",
|
||||
"@alilc/lowcode-plugin-datasource-pane": "^1.0.9",
|
||||
"@alilc/lowcode-plugin-inject": "^1.2.1",
|
||||
"@alilc/lowcode-plugin-manual": "^1.0.4",
|
||||
"@alilc/lowcode-plugin-schema": "^1.0.2",
|
||||
"@alilc/lowcode-plugin-set-ref-prop": "^1.0.1",
|
||||
"@alilc/lowcode-plugin-simulator-select": "^1.0.2",
|
||||
"@alilc/lowcode-plugin-undo-redo": "^1.0.0",
|
||||
"@alilc/lowcode-plugin-zh-en": "^1.0.0",
|
||||
"@alilc/lowcode-plugin-set-ref-prop": "^1.0.1",
|
||||
"@alilc/lowcode-react-renderer": "^1.1.2",
|
||||
"@alilc/lowcode-setter-behavior": "^1.0.0",
|
||||
"@alilc/lowcode-setter-title": "^1.0.2",
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -21,6 +21,7 @@
|
|||
},
|
||||
"config": {},
|
||||
"dependencies": {
|
||||
"@alilc/build-plugin-lce": "^0.0.4-beta.3",
|
||||
"@alilc/lce-graph-core": "^1.0.6",
|
||||
"@alilc/lce-graph-materials-pane": "^1.0.10",
|
||||
"@alilc/lce-graph-tools": "^1.0.6",
|
||||
|
|
Loading…
Reference in New Issue