Commit a04ec4e0 authored by 张烨's avatar 张烨

feat: website config start

parent 122aeff1
...@@ -20,8 +20,8 @@ export const renderButtonGroup = props => { ...@@ -20,8 +20,8 @@ export const renderButtonGroup = props => {
}; };
export const BaseFormItem = itemOption => { export const BaseFormItem = itemOption => {
const { type, ...rest } = itemOption; const { formType, ...rest } = itemOption;
switch (type) { switch (formType) {
case 'input': case 'input':
// eslint-disable-next-line no-undef // eslint-disable-next-line no-undef
return <Input allowClear {...rest} />; return <Input allowClear {...rest} />;
......
import React from 'react';
import { Button, Drawer } from 'antd';
import styles from './siteConfigDrawer.less';
import BaseForm from '@/components/BaseForm';
let form = null;
const defaultKeyMap = {
title: {
label: '标题',
formType: 'input',
allowClear: true,
placeholder: '请输入标题',
rules: [
{
required: true,
message: '标题为必填项',
},
],
},
subtitle: {
label: '副标题',
formType: 'input',
allowClear: true,
},
shortcutIcon: {
label: '图标icon',
formType: 'image',
rules: [
{
required: true,
message: '请选择图标icon',
},
],
},
logo: {
label: '登录logo',
formType: 'image',
rules: [
{
required: true,
message: '请选择登录logo',
},
],
},
bannerlogo: {
label: '标题logo',
formType: 'image',
rules: [
{
required: true,
message: '请选择标题logo',
},
],
},
client: {
label: '虚拟目录',
formType: 'input',
allowClear: true,
size: 'small',
rules: [
{
required: true,
message: '虚拟目录不能为空',
},
],
},
homePage: {
label: '主页',
formType: 'input',
allowClear: true,
},
loginTemplate: {
label: '登录模板',
formType: 'select',
placeholder: '请选择登录模板',
filterOption: (input, option) =>
option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0,
rules: [
{
required: true,
message: '登录模板必填',
},
],
},
theme: {
label: '系统皮肤',
formType: 'singleRadio',
rules: [
{
required: true,
message: '请选择系统皮肤',
},
],
},
style: '系统风格',
menu: '菜单类型',
mode: '功能标签',
qrcode: '二维码地址',
mapPlan: '地图方案',
waterMark: '地图水印',
};
export default props => {
const { visible, onClose, config } = props;
const getForm = f => {
form = f;
};
const adaptConfig = conf => {};
const formConfig = {
getForm,
items: [
{
label: '标题',
dataIndex: 'title',
initialValue: '',
rules: [],
},
],
};
return (
<div className={styles.siteConfigContainer}>
<Drawer
title="Multi-level drawer"
width={520}
closable
onClose={onClose}
visible={visible}
>
<BaseForm {...formConfig} />
</Drawer>
</div>
);
};
import React from 'react';
import { Button } from 'antd';
import styles from './siteConfig.less';
import PreviewConfigDrawer from '@/components/PreviewConfigDrawer';
import BaseForm from '@/components/BaseForm';
export default props => {
const { visible, setVisible } = props;
return (
<div className={styles.siteConfigContainer}>
<PreviewConfigDrawer
visible={visible}
setVisible={setVisible}
drawerProps={
{
// maskStyle: { opacity: 0.6 },
}
}
previewContent={
<Button onClick={() => setVisible(true)}>打开配置</Button>
}
>
<BaseForm />
</PreviewConfigDrawer>
</div>
);
};
import React, { useState } from 'react'; import React, { useEffect, useState } from 'react';
import { PageContainer } from '@ant-design/pro-layout'; import { PageContainer } from '@ant-design/pro-layout';
import { Tabs } from 'antd'; import { Tabs } from 'antd';
import menuTree from '@/services/mocks/web4site'; import menuTreeMock from '@/services/mocks/web4site';
import styles from './index.less'; import styles from './index.less';
import SiteConfig from './componets/siteConfig'; import SiteConfig from './components/siteConfigDrawer';
const { TabPane } = Tabs; const { TabPane } = Tabs;
const getMenuTree = () =>
new Promise((r, j) => {
setTimeout(() => {
r(menuTreeMock);
}, 1000);
});
const WebConfigPage = props => { const WebConfigPage = props => {
const [configVisible, setConfigVisible] = useState(false); const [configVisible, setConfigVisible] = useState(false);
const [loading, setLoading] = useState(false);
const [menuTree, setMeneTree] = useState({ children: [] });
const [configObj, setConfigObj] = useState({});
const renderPage = () => {}; const renderPage = () => {};
useEffect(() => {
getMenuTree().then(res => {
setMeneTree(res);
setLoading(false);
});
}, []);
const renderTabPane = tabPaneItem => ( const renderTabPane = tabPaneItem => (
<TabPane key={tabPaneItem.id} tab={tabPaneItem.text}> <TabPane key={tabPaneItem.id} tab={tabPaneItem.text} />
<SiteConfig visible={configVisible} setVisible={setConfigVisible} />
</TabPane>
); );
const onEdit = (targetKey, action) => { const onEdit = (targetKey, action) => {
// console.log(targetKey, action); // action: add|remove // console.log(targetKey, action); // action: add|remove
switch (action) {
case 'add':
setConfigVisible(true);
break;
case 'remove':
break;
default:
}
}; };
const onDrawerClose = form => {};
return ( return (
<PageContainer> <PageContainer loading={loading}>
<div className={styles.webConfigContainer}> <div className={styles.webConfigContainer}>
<Tabs type="editable-card" onEdit={onEdit}> <Tabs type="editable-card" onEdit={onEdit}>
{menuTree.children.map(renderTabPane)} {menuTree.children.map(renderTabPane)}
</Tabs> </Tabs>
<SiteConfig
visible={configVisible}
onClose={onDrawerClose}
config={configObj}
/>
</div> </div>
</PageContainer> </PageContainer>
); );
......
export default { export default {
"id": "Web4SingleStation", id: 'Web4SingleStation',
"text": "一般网站", 'text': '一般网站',
"visible": null, 'visible': null,
"iconCls": "civ-flag-blue", 'iconCls': 'civ-flag-blue',
"children": [ 'children': [
{ {
"id": "singlecity", 'id': 'singlecity',
"text": "熊猫智慧水务GCK平台", 'text': '熊猫智慧水务GCK平台',
"visible": null, 'visible': null,
"iconCls": "civ-flag-green", 'iconCls': 'civ-flag-green',
"children": [ 'children': [
{ {
"id": "Web4StationRootcity", 'id': 'Web4StationRootcity',
"text": "网站配置", 'text': '网站配置',
"visible": null, 'visible': null,
"iconCls": "civ-cog", 'iconCls': 'civ-cog',
"children": [], 'children': [],
"expanded": false, 'expanded': false,
"leaf": true, 'leaf': true,
"description": null, 'description': null,
"allowDrag": false, 'allowDrag': false,
"allowDrop": false, 'allowDrop': false,
"draggable": false, 'draggable': false,
"isTarget": false, 'isTarget': false,
"dragAttribute": null, 'dragAttribute': null,
"stationID": null, 'stationID': null,
"roleID": null, 'roleID': null,
"menuID": null, 'menuID': null,
"offlineHead": null, 'offlineHead': null,
"headType": null, 'headType': null,
"group": null, 'group': null,
"groupName": null, 'groupName': null,
"menuType": "Web4WebsiteRoot", 'menuType': 'Web4WebsiteRoot',
"clickType": "Web4WebsiteRoot" 'clickType': 'Web4WebsiteRoot'
}, },
{ {
"id": "Web4PageUIRootcity", 'id': 'Web4PageUIRootcity',
"text": "地图组件", 'text': '地图组件',
"visible": null, 'visible': null,
"iconCls": "civ-world-link", 'iconCls': 'civ-world-link',
"children": [ 'children': [
{ {
"id": "pageUI-487", 'id': 'pageUI-487',
"text": "缩放", 'text': '缩放',
"visible": null, 'visible': null,
"iconCls": "civ-world", 'iconCls': 'civ-world',
"children": [], 'children': [],
"expanded": false, 'expanded': false,
"leaf": true, 'leaf': true,
"description": null, 'description': null,
"allowDrag": true, 'allowDrag': true,
"allowDrop": true, 'allowDrop': true,
"draggable": true, 'draggable': true,
"isTarget": true, 'isTarget': true,
"dragAttribute": "Web4PageUI", 'dragAttribute': 'Web4PageUI',
"stationID": null, 'stationID': null,
"roleID": null, 'roleID': null,
"menuID": "487", 'menuID': '487',
"offlineHead": null, 'offlineHead': null,
"headType": null, 'headType': null,
"group": null, 'group': null,
"groupName": null, 'groupName': null,
"menuType": "Web4PageUI", 'menuType': 'Web4PageUI',
"clickType": "Web4PageUI" 'clickType': 'Web4PageUI'
}, },
{ {
"id": "pageUI-488", 'id': 'pageUI-488',
"text": "图层控制", 'text': '图层控制',
"visible": null, 'visible': null,
"iconCls": "civ-world", 'iconCls': 'civ-world',
"children": [], 'children': [],
"expanded": false, 'expanded': false,
"leaf": true, 'leaf': true,
"description": null, 'description': null,
"allowDrag": true, 'allowDrag': true,
"allowDrop": true, 'allowDrop': true,
"draggable": true, 'draggable': true,
"isTarget": true, 'isTarget': true,
"dragAttribute": "Web4PageUI", 'dragAttribute': 'Web4PageUI',
"stationID": null, 'stationID': null,
"roleID": null, 'roleID': null,
"menuID": "488", 'menuID': '488',
"offlineHead": null, "offlineHead": null,
"headType": null, "headType": null,
"group": null, "group": null,
...@@ -10667,5 +10666,5 @@ export default { ...@@ -10667,5 +10666,5 @@ export default {
"group": null, "group": null,
"groupName": null, "groupName": null,
"menuType": "Web4SingleStationRoot", "menuType": "Web4SingleStationRoot",
"clickType": "Web4SingleStationRoot" clickType: "Web4SingleStationRoot"
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment