From 97e18fa9b628357fa43013cfefc96eec078de25e Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期一, 16 一月 2023 15:58:12 +0800 Subject: [PATCH] 2023-01-16 --- src/tabviews/custom/components/carousel/data-card/index.jsx | 104 +++++++++++++++++++++++++++++++++++---------------- 1 files changed, 71 insertions(+), 33 deletions(-) diff --git a/src/tabviews/custom/components/carousel/data-card/index.jsx b/src/tabviews/custom/components/carousel/data-card/index.jsx index 723b495..90e9116 100644 --- a/src/tabviews/custom/components/carousel/data-card/index.jsx +++ b/src/tabviews/custom/components/carousel/data-card/index.jsx @@ -12,6 +12,7 @@ import './index.scss' const CardItem = asyncComponent(() => import('../cardItem')) +const NormalHeader = asyncComponent(() => import('@/tabviews/custom/components/share/normalheader')) class DataCard extends Component { static propTpyes = { @@ -30,6 +31,8 @@ BData: null, visible: false } + + loaded = false UNSAFE_componentWillMount () { const { data, initdata } = this.props @@ -61,6 +64,7 @@ } if (_data) { + this.loaded = true _data = _data.map((item, index) => { item.key = index item.$$uuid = item[_config.setting.primaryKey] || '' @@ -76,8 +80,6 @@ _cols.set(item.field, item) }) - _card.style.height = _config.style.height - if (_card.setting.click) { _card.style.cursor = 'pointer' } @@ -88,6 +90,13 @@ } return item }) + + if (!_config.wrap.height) { // 鍏煎 + _config.wrap.height = _config.style.height || '300px' + delete _config.style.height + } + + _card.style.height = _config.wrap.height _config.wrap.speed = (_config.wrap.speed || 3) * 1000 @@ -123,6 +132,21 @@ this.loadData('timer') }) } + + if (config.$cache && !this.loaded) { + Api.getLCacheConfig(config.uuid).then(res => { + if (!res || this.loaded) return + + let _data = res.map((item, index) => { + item.key = index + item.$$uuid = item[config.setting.primaryKey] || '' + item.$Index = index + 1 + '' + return item + }) + + this.setState({data: _data}) + }) + } } shouldComponentUpdate (nextProps, nextState) { @@ -146,6 +170,8 @@ item.$Index = index + 1 return item }) + + this.loaded = true this.setState({sync: false, data: _data}, () => { this.openModal() @@ -250,6 +276,8 @@ data: [], loading: false }) + + this.loaded = true return } @@ -270,6 +298,11 @@ let result = await Api.genericInterface(param) if (result.status) { + this.loaded = true + if (config.$cache) { + Api.writeCacheConfig(config.uuid, result.data || '') + } + this.setState({ data: result.data.map((item, index) => { item.key = index @@ -329,23 +362,26 @@ footer={null} destroyOnClose > - {data && data.length > 0 ? <div className="custom-data-carousel-box" style={config.style}> - {data.length > 1 && config.wrap.autoplay === 'false' ? <div className="prev" onClick={() => this.node && this.node.prev()}><LeftOutlined /></div> : null} - {data.length > 1 && config.wrap.autoplay === 'false' ? <div className="next" onClick={() => this.node && this.node.next()}><RightOutlined /></div> : null} - <Carousel - autoplay={config.wrap.autoplay !== 'false'} - dots={config.wrap.dots !== 'false'} - dotPosition={config.wrap.dotPosition || 'bottom'} - effect={config.wrap.effect || 'scrollx'} - autoplaySpeed={config.wrap.speed} - ref={ref => this.node = ref} - > - {data.map((item, index) => ( - <div key={index}> - <CardItem card={card} cards={config} data={item}/> - </div> - ))} - </Carousel> + {visible ? <div className="custom-data-carousel-box" style={config.style}> + <NormalHeader config={config}/> + <div className="carousel-wrap" style={{height: config.wrap.height}}> + {data.length > 1 && config.wrap.autoplay === 'false' ? <div className="prev" onClick={() => this.node && this.node.prev()}><LeftOutlined /></div> : null} + {data.length > 1 && config.wrap.autoplay === 'false' ? <div className="next" onClick={() => this.node && this.node.next()}><RightOutlined /></div> : null} + <Carousel + autoplay={config.wrap.autoplay !== 'false'} + dots={config.wrap.dots !== 'false'} + dotPosition={config.wrap.dotPosition || 'bottom'} + effect={config.wrap.effect || 'scrollx'} + autoplaySpeed={config.wrap.speed} + ref={ref => this.node = ref} + > + {data.map((item, index) => ( + <div key={index}> + <CardItem card={card} cards={config} data={item}/> + </div> + ))} + </Carousel> + </div> </div> : null} {config.wrap.modalContent !== 'update' ? <div className="mk-footer"> <Checkbox defaultChecked={false} onChange={this.onTipChange}>涓嶅湪鎻愰啋</Checkbox> @@ -364,20 +400,22 @@ <Spin /> </div> : null } - {data && data.length > 0 ? <Carousel - autoplay={config.wrap.autoplay !== 'false'} - dots={config.wrap.dots !== 'false'} - dotPosition={config.wrap.dotPosition || 'bottom'} - effect={config.wrap.effect || 'scrollx'} - autoplaySpeed={config.wrap.speed} - > - {data.map((item, index) => ( - <div key={index}> - <CardItem card={card} cards={config} data={item}/> - </div> - ))} - </Carousel> : null} - {!data || data.length === 0 ? <Empty description={false}/> : null} + <NormalHeader config={config}/> + <div className="carousel-wrap" style={{height: config.wrap.height}}> + {data && data.length > 0 ? <Carousel + autoplay={config.wrap.autoplay !== 'false'} + dots={config.wrap.dots !== 'false'} + dotPosition={config.wrap.dotPosition || 'bottom'} + effect={config.wrap.effect || 'scrollx'} + autoplaySpeed={config.wrap.speed} + > + {data.map((item, index) => ( + <div key={index}> + <CardItem card={card} cards={config} data={item}/> + </div> + ))} + </Carousel> : <Empty description={false}/>} + </div> </div> ) } -- Gitblit v1.8.0