Commit f2921cb8 authored by 张烨's avatar 张烨

perf: 优化图片库加载

parent 7245db0b
...@@ -18,6 +18,7 @@ import configureStore from './configureStore'; ...@@ -18,6 +18,7 @@ import configureStore from './configureStore';
import App from './containers/App'; import App from './containers/App';
import history from './utils/history'; import history from './utils/history';
import config from './routes/config'; import config from './routes/config';
import { PictureWallProvider } from '@/components/Upload/context';
const initialState = Immutable.Map(); const initialState = Immutable.Map();
const store = configureStore(initialState, history); const store = configureStore(initialState, history);
const MOUNT_NODE = document.getElementById('app'); const MOUNT_NODE = document.getElementById('app');
...@@ -27,7 +28,9 @@ const render = () => { ...@@ -27,7 +28,9 @@ const render = () => {
<Provider store={store}> <Provider store={store}>
<ConnectedRouter history={history}> <ConnectedRouter history={history}>
<ConfigProvider locale={zhCN}> <ConfigProvider locale={zhCN}>
<PictureWallProvider>
<App routesConfig={config} /> <App routesConfig={config} />
</PictureWallProvider>
</ConfigProvider> </ConfigProvider>
</ConnectedRouter> </ConnectedRouter>
</Provider>, </Provider>,
......
import { getImageBases } from '@/services/common/api';
import React, { useEffect, useState } from 'react';
const UploadContext = React.createContext();
const PictureWallProvider = props => {
const { children, ...rest } = props;
const [imgBed, setImgBed] = useState([]);
const update = () => {
getImageBases('').then(res => {
if (res.code === 0) {
setImgBed(res.data);
}
});
};
useEffect(() => {
update();
}, []);
return (
<UploadContext.Provider value={{ imgBed, update }}>
{children}
</UploadContext.Provider>
);
};
export { UploadContext as default, PictureWallProvider };
...@@ -8,6 +8,7 @@ import { uuid } from '@/utils/tools'; ...@@ -8,6 +8,7 @@ import { uuid } from '@/utils/tools';
import { get, PUBLISH_SERVICE } from '@/services'; import { get, PUBLISH_SERVICE } from '@/services';
import styles from './index.less'; import styles from './index.less';
import { getImageBases } from '@/services/common/api'; import { getImageBases } from '@/services/common/api';
import UploadContext from './context.js'
const { TabPane } = Tabs; const { TabPane } = Tabs;
...@@ -17,6 +18,12 @@ const wallCateName: any = { ...@@ -17,6 +18,12 @@ const wallCateName: any = {
bg: '背景', bg: '背景',
uploaded: '上传', uploaded: '上传',
}; };
const tabNames:any = {
CityTemp: '用户上传',
icon: '图标',
androidMenu: '安卓图标',
menuNew: '应用图标'
}
function getBase64(file: File | Blob) { function getBase64(file: File | Blob) {
return new Promise<string>((resolve, reject) => { return new Promise<string>((resolve, reject) => {
...@@ -38,6 +45,7 @@ interface PicturesWallType { ...@@ -38,6 +45,7 @@ interface PicturesWallType {
isCrop?: boolean; isCrop?: boolean;
type?: 'CityTemp'|'icon'|'androidMenu'|'menuNew', type?: 'CityTemp'|'icon'|'androidMenu'|'menuNew',
value?: string | string[], value?: string | string[],
uploadContext: any,
} }
class PicturesWall extends React.Component<PicturesWallType> { class PicturesWall extends React.Component<PicturesWallType> {
...@@ -46,7 +54,7 @@ class PicturesWall extends React.Component<PicturesWallType> { ...@@ -46,7 +54,7 @@ class PicturesWall extends React.Component<PicturesWallType> {
previewImage: '', previewImage: '',
wallModalVisible: false, wallModalVisible: false,
previewTitle: '', previewTitle: '',
imgBed: [], imgBed: this.props.uploadContext?.imgBed || [],
curSelectedImg: '', curSelectedImg: '',
prevProps:{}, prevProps:{},
fileList: this.props.value ? Array.isArray(this.props.value) ? this.props.value.map((v) => ({ fileList: this.props.value ? Array.isArray(this.props.value) ? this.props.value.map((v) => ({
...@@ -63,24 +71,32 @@ class PicturesWall extends React.Component<PicturesWallType> { ...@@ -63,24 +71,32 @@ class PicturesWall extends React.Component<PicturesWallType> {
}; };
static getDerivedStateFromProps = (props, state) => { static getDerivedStateFromProps = (props, state) => {
const {value, uploadContext = {}} = props;
const { imgBed, update } = uploadContext;
const fileList = state.fileList; const fileList = state.fileList;
const shouldUpdate = props.value && fileList.every(f => Array.isArray(props.value) ? !props.value.some(v => f.url === v) : f.url !== props.value) const shouldUpdate = value && fileList.every(f => Array.isArray(value) ? !value.some(v => f.url === v) : f.url !== value)
if(props.value !== state.prevProps.value && shouldUpdate){ if(value !== state.prevProps.value && shouldUpdate){
return { return {
provProps: props, prevProps: props,
fileList: Array.isArray(props.value) ? props.value.map((v) => ({ fileList: Array.isArray(value) ? value.map((v) => ({
url: v, url: v,
uid: uuid(8, 16), uid: uuid(8, 16),
name: '熊猫运维中台系统', name: '熊猫运维中台系统',
status: 'done', status: 'done',
})) as UploadFile<any>[]: [{ })) as UploadFile<any>[]: [{
url: props.value, url: value,
uid: uuid(8, 16), uid: uuid(8, 16),
name: '熊猫运维中台系统', name: '熊猫运维中台系统',
status: 'done', status: 'done',
}] as UploadFile<any>[] }] as UploadFile<any>[]
} }
} }
if(imgBed != state.prevProps.uploadContext?.imgBed){
return {
prevProps: props,
imgBed
}
}
return { return {
prevProps: props prevProps: props
}; };
...@@ -153,16 +169,17 @@ class PicturesWall extends React.Component<PicturesWallType> { ...@@ -153,16 +169,17 @@ class PicturesWall extends React.Component<PicturesWallType> {
}; };
handleChange = ({ file, fileList }: UploadChangeParam<UploadFile<any>>) => { handleChange = ({ file, fileList }: UploadChangeParam<UploadFile<any>>) => {
const { maxLen = 1 } = this.props; const { maxLen = 1, uploadContext } = this.props;
this.setState({ fileList }); this.setState({ fileList });
if (file.status === 'done') { if (file.status === 'done') {
const files = fileList.map(item => { const files = fileList.map(item => {
const { status, data, name, thumbUrl } = item; const { status, name, thumbUrl } = item;
const url = item.response && item.response.data || thumbUrl ; const url = item.response && item.response.data || thumbUrl ;
return { uid: uuid(8, 16), name, status, url }; return { uid: uuid(8, 16), name, status, url };
}); });
this.setState({fileList: files}) this.setState({fileList: files})
this.props.onChange && this.props.onChange( maxLen === 1 ? files[0].url : files.map(f => f.url)); this.props.onChange && this.props.onChange( maxLen === 1 ? files[0].url : files.map(f => f.url));
uploadContext?.update && uploadContext.update()
} }
}; };
...@@ -182,14 +199,14 @@ class PicturesWall extends React.Component<PicturesWallType> { ...@@ -182,14 +199,14 @@ class PicturesWall extends React.Component<PicturesWallType> {
return isJpgOrPng && isLt2M; return isJpgOrPng && isLt2M;
}; };
componentDidMount() { // componentDidMount() {
const { type = ''} = this.props; // const { type = ''} = this.props;
getImageBases(type).then(res => { // getImageBases(type).then(res => {
if(res.code === 0){ // if(res.code === 0){
this.setState({imgBed: res.data}) // this.setState({imgBed: res.data})
} // }
}) // })
} // }
getImageUrl(path){ getImageUrl(path){
if(path&&path.indexOf('http') === 0){ if(path&&path.indexOf('http') === 0){
...@@ -302,7 +319,7 @@ class PicturesWall extends React.Component<PicturesWallType> { ...@@ -302,7 +319,7 @@ class PicturesWall extends React.Component<PicturesWallType> {
<Tabs defaultActiveKey={imgBed[0]?.moduleName} tabPosition="left" style={{ height: 520 }}> <Tabs defaultActiveKey={imgBed[0]?.moduleName} tabPosition="left" style={{ height: 520 }}>
{imgBed.map((item, i) => { {imgBed.map((item, i) => {
return ( return (
<TabPane tab={item.moduleName} key={item.moduleName}> <TabPane tab={tabNames[item.moduleName]} key={item.moduleName}>
<div className={styles.imgBox}> <div className={styles.imgBox}>
{item.child?.map(m => m.fileUrls).flat(Infinity).map((item: string, i: number) => { {item.child?.map(m => m.fileUrls).flat(Infinity).map((item: string, i: number) => {
return ( return (
...@@ -335,4 +352,9 @@ class PicturesWall extends React.Component<PicturesWallType> { ...@@ -335,4 +352,9 @@ class PicturesWall extends React.Component<PicturesWallType> {
} }
} }
export default PicturesWall; const PicturesWallWrapper = (props: any) => {
return <UploadContext.Consumer>
{(uploadContext) => <PicturesWall {...props} uploadContext={uploadContext}/>}
</UploadContext.Consumer>
}
export default PicturesWallWrapper;
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