fix: remove formily demo (#138)

This commit is contained in:
刘菊萍(絮黎) 2023-10-26 16:37:42 +08:00 committed by GitHub
parent 9497ae4970
commit 3759f381d6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
33 changed files with 17891 additions and 1355 deletions

View File

@ -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)
更多参考资料:

View File

@ -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",

View File

@ -1,7 +0,0 @@
module.exports = {
printWidth: 100,
tabWidth: 2,
semi: true,
singleQuote: true,
trailingComma: 'all',
};

View File

@ -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"
]
}

View File

@ -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');
});
};

View File

@ -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

View File

@ -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>

View File

@ -1 +0,0 @@
勿删,删了有奇妙的 bug😄~

View File

@ -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}]}

View File

@ -1,3 +0,0 @@
{
"info": "Hello AliLowCode!!"
}

View File

@ -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>

View File

@ -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`);
}
});

View File

@ -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;
}

View File

@ -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()
},
});
})();

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;
}
}

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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'));

View File

@ -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": {}
}

View File

@ -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;
};

View File

@ -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": ""
}

View File

@ -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"]
}

View File

@ -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",

17887
demo-general/yarn.lock Normal file

File diff suppressed because it is too large Load Diff

View File

@ -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",