From a9a5211f48607fa7ac5bae91233f3a5e6df43587 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期四, 20 一月 2022 14:09:04 +0800 Subject: [PATCH] 2022-01-20 --- src/views/mobdesign/index.jsx | 148 ++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 134 insertions(+), 14 deletions(-) diff --git a/src/views/mobdesign/index.jsx b/src/views/mobdesign/index.jsx index 76a8309..0862e1d 100644 --- a/src/views/mobdesign/index.jsx +++ b/src/views/mobdesign/index.jsx @@ -17,6 +17,7 @@ import MKEmitter from '@/utils/events.js' import MenuUtils from '@/utils/utils-custom.js' import asyncComponent from '@/utils/asyncComponent' +import backurl from '@/assets/img/back.jpg' import './index.scss' @@ -72,7 +73,8 @@ settingshow: true, controlshow: true, comloading: false, - adapters: [] + adapters: [], + viewType: 'menu' } UNSAFE_componentWillMount() { @@ -89,6 +91,8 @@ sessionStorage.setItem('typename', param.typename || 'mob') sessionStorage.setItem('adapter', param.adapter || '') sessionStorage.setItem('sysBgColor', param.sysBgColor || '#ffffff') + sessionStorage.setItem('userbind', param.userbind || '') + sessionStorage.setItem('instantMessage', param.instantMessage || '') this.setState({ localedict: sessionStorage.getItem('lang') !== 'en-US' ? antdZhCN : antdEnUS, @@ -117,7 +121,8 @@ this.setState({ adapters, - MenuId: param.MenuID + MenuId: param.MenuID, + viewType: /^userbind/.test(param.MenuID) ? 'userbind' : 'menu' }, () => { this.getMenuParam(param) }) @@ -444,10 +449,7 @@ if (!config) { window.close() - return - } - - if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) { + } else if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) { confirm({ title: '閰嶇疆淇℃伅鏈繚瀛橈紝纭畾鍏抽棴鍚楋紵', content: '', @@ -458,6 +460,25 @@ }) } else { window.close() + } + } + + backView = () => { + const { oriConfig, config } = this.state + + if (!config) { + window.history.back() + } else if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) { + confirm({ + title: '閰嶇疆淇℃伅鏈繚瀛橈紝纭畾鍚庨��鍚楋紵', + content: '', + onOk() { + window.history.back() + }, + onCancel() {} + }) + } else { + window.history.back() } } @@ -491,6 +512,11 @@ } catch (e) { console.warn('Parse Failure') config = null + } + + if (/^userbind/.test(MenuId)) { + this.setUserBindMenu(config, result) + return } if (!config) { @@ -541,6 +567,88 @@ this.getAppMenus() } + setUserBindMenu = (config, result) => { + const { MenuId } = this.state + let isCreate = !config + + if (!config) { + config = { + version: 1.0, + uuid: MenuId, + MenuID: MenuId, + Template: 'webPage', + enabled: false, + MenuName: '鐢ㄦ埛缁戝畾', + MenuNo: 'user_bind', + tables: [], + components: [], + viewType: 'userbind', + statusBarbgColor: sessionStorage.getItem('sysBgColor') || '#ffffff', + style: { + backgroundColor: sessionStorage.getItem('sysBgColor') || '#ffffff', backgroundImage: '' + } + } + + config.components.push({ + subcards:[ + { + uuid: Utils.getuuid(), setting: {width:24, primaryId: '', click: ''}, style: {}, backStyle: {}, + elements: [{maxWidth: 135, datatype: 'static', width: 24, marks: null, url: 'http://cloud.mk9h.cn/Content/images/20220120/cb5cd13a-2ef4-41cc-ab6a-a202f1c04da5.png', style: {borderRadius: '50%'}, eleType: 'picture', link: '', uuid: Utils.getuuid(), lenWidRadio: '1:1', $type: ''}], + backElements: [] + } + ], + headerStyle: {}, parentId: '', width: 24, scripts: [], btnlog: [], pageable: false, + wrap: {name: 'logo', width: 24, datatype: 'static', cardType: '', blacklist: []}, + name: 'logo', floor: 1, switchable: true, + setting:{interType: 'system'}, tabId: '', style:{paddingTop: '10vh', paddingBottom: '10vh'}, dataName: Utils.getuuid(), format: 'object', subtype: 'propcard', type: 'card', uuid: Utils.getuuid(), columns: [] + }) + + config.components.push({ + uuid: Utils.getuuid(), + type: 'login', + floor: 1, + tabId: '', + parentId: '', + dataName: '', + width: 24, + name: '鐢ㄦ埛缁戝畾', + subtype: 'bindlogin', + wrap: { name: '鐢ㄦ埛缁戝畾', width: 24, loginWays: ['uname_pwd'], shortcut: 'none', height: '45vh' }, + style: {}, + loginWays: [ + {type: 'uname_pwd', label: '璐﹀彿鐧诲綍', shortcut: 'none'}, + {type: 'sms_vcode', label: '鐭俊鐧诲綍'}, + ] + }) + + config.components.push({ + subcards:[ + { + uuid: Utils.getuuid(), setting: {width:24, primaryId: '', click: ''}, style: {}, backStyle: {}, + elements: [{datatype: 'static', width: 24, marks: null, height: null, value: 'Power by Minkesoft', style: { fontSize: '13px', textAlign: 'center'}, eleType: 'text', link: '', uuid: Utils.getuuid(), $type: ''}], + backElements: [] + } + ], + headerStyle: {}, parentId: '', width: 24, scripts: [], btnlog: [], pageable: false, + wrap: {name: 'Power', width: 24, datatype: 'static', cardType: '', blacklist: []}, + name: 'Power', floor: 1, switchable: true, + setting:{interType: 'system'}, tabId: '', style:{}, dataName: Utils.getuuid(), format: 'object', subtype: 'propcard', type: 'card', uuid: Utils.getuuid(), columns: [] + }) + } + + config.uuid = MenuId + config.MenuID = MenuId + config.open_edition = result.open_edition || '' + + this.setState({ + oriConfig: isCreate ? null : config, + config: fromJS(config).toJS(), + activeKey: isCreate ? 'basedata' : 'component', + loading: false + }) + window.GLOB.customMenu = config + } + getAppMenus = () => { let _param = { func: 's_get_app_menus', @@ -565,6 +673,13 @@ let appIndeList = sessionStorage.getItem('appViewList') appIndeList = JSON.parse(appIndeList) appIndeList = appIndeList.map(item => (item.keys_type !== 'index' ? item.keys_id : '')).join(',') + + if (sessionStorage.getItem('userbind')) { + appIndeList = appIndeList + ',' + sessionStorage.getItem('userbind') + } + if (sessionStorage.getItem('instantMessage')) { + appIndeList = appIndeList + ',' + sessionStorage.getItem('instantMessage') + } let menus = res.menus.filter(item => appIndeList.indexOf(item.MenuID) === -1) menus = menus.map(item => { @@ -1247,7 +1362,7 @@ } verifyConfig = (show) => { - const { config } = this.state + const { config, viewType } = this.state let error = '' let searchSum = 0 let swipes = [] @@ -1313,6 +1428,10 @@ } check(config.components) + + if (!error && viewType === 'userbind' && config.components.filter(item => item.type === 'login').length === 0) { + error = '鐢ㄦ埛缁戝畾椤甸潰蹇呴』娣诲姞鐧诲綍銆�' + } if (!error && searchSum > 1) { error = '鎼滅储缁勪欢涓庡鑸爮鐨勬悳绱㈠姛鑳戒笉鍙悓鏃朵娇鐢ㄣ��' @@ -1540,11 +1659,11 @@ render () { - const { localedict, comloading, loading, settingshow, controlshow, activeKey, dict, MenuId, config, menuloading, customComponents, adapters } = this.state + const { viewType, localedict, comloading, loading, settingshow, controlshow, activeKey, dict, MenuId, config, menuloading, customComponents, adapters } = this.state return ( <ConfigProvider locale={localedict}> - <div className="mk-mob-view" id="mk-mob-design-view"> + <div className={'mk-mob-view ' + viewType} id="mk-mob-design-view"> <Header changeView={this.changeView}/> {loading ? <Spin className="view-spin" size="large" /> : null} <DndProvider backend={HTML5Backend}> @@ -1556,7 +1675,7 @@ <div className="pc-setting-tools"> <Collapse accordion activeKey={activeKey} bordered={false} onChange={(key) => this.setState({activeKey: key})}> {/* 鍩烘湰淇℃伅 */} - <Panel header={dict['mob.basemsg']} forceRender key="basedata"> + <Panel header={dict['mob.basemsg']} forceRender className="basedata" key="basedata"> {/* 鑿滃崟淇℃伅 */} {config ? <MenuForm dict={dict} @@ -1571,10 +1690,10 @@ {config ? <Paragraph style={{padding: '15px 0px 0px 18px'}} copyable={{ text: MenuId }}>鑿滃崟ID</Paragraph> : null} </Panel> {/* 缁勪欢娣诲姞 */} - <Panel header={dict['mob.component']} key="component"> + <Panel header={dict['mob.component']} className="component" key="component"> <SourceWrap /> </Panel> - {customComponents && customComponents.length ? <Panel header="鑷畾涔夌粍浠�" key="cuscomponent"> + {customComponents && customComponents.length ? <Panel header="鑷畾涔夌粍浠�" className="cuscomponent" key="cuscomponent"> <SourceWrap components={customComponents} /> </Panel> : null} <Panel header={'椤甸潰鏍峰紡'} key="background"> @@ -1591,14 +1710,15 @@ <div className="wrap"> <Button type="primary" onClick={this.submitConfig} id="save-config" loading={menuloading}>{dict['mob.save']}</Button> <Switch className="big" checkedChildren={dict['mob.enable']} unCheckedChildren={dict['mob.disable']} checked={config && config.enabled} onChange={this.onEnabledChange} /> + <img title="鍚庨��" className="back-view" onClick={this.backView} src={backurl} alt=""/> <CreateView resetmenu={this.getAppMenus} /> <PasteController insert={this.insert} /> <StyleCombControlButton menu={config} /> <SysInterface config={config} updateConfig={this.updateConfig}/> <PictureController/> <Quotecomponent config={config} updateConfig={this.updateConfig}/> - <Button className="mk-border-green" onClick={this.setHomeView}><HomeOutlined /> 璁句负棣栭〉</Button> - <Button className="mk-border-purple" onClick={this.setLoginView}><LoginOutlined /> 璁句负鐧诲綍椤�</Button> + <Button className="mk-border-green set-home" onClick={this.setHomeView}><HomeOutlined /> 璁句负棣栭〉</Button> + <Button className="mk-border-purple set-login" onClick={this.setLoginView}><LoginOutlined /> 璁句负鐧诲綍椤�</Button> <ReplaceField type="custom" config={config} updateConfig={this.resetConfig}/> <Transfer MenuID={MenuId} /> <Versions MenuId={MenuId} open_edition={config ? config.open_edition : ''}/> -- Gitblit v1.8.0