mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-02 23:48:47 +00:00
* fix wikis list style when side panel width is changing * change code format * fix wiki list item width when side panel is folded
86 lines
2.9 KiB
JavaScript
86 lines
2.9 KiB
JavaScript
import React, { Component } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import WikiCardItem from './wiki-card-item';
|
|
import WikiCardItemAdd from './wiki-card-item-add';
|
|
import { isMobile } from '../../utils/utils';
|
|
import { SIDE_PANEL_FOLDED_WIDTH } from '../../constants';
|
|
|
|
const propTypes = {
|
|
wikis: PropTypes.array.isRequired,
|
|
deleteWiki: PropTypes.func.isRequired,
|
|
title: PropTypes.string.isRequired,
|
|
isDepartment: PropTypes.bool.isRequired,
|
|
isShowAvatar: PropTypes.bool.isRequired,
|
|
renameWiki: PropTypes.func.isRequired,
|
|
toggelAddWikiDialog: PropTypes.func,
|
|
sidePanelRate: PropTypes.number,
|
|
isSidePanelFolded: PropTypes.bool,
|
|
};
|
|
|
|
class WikiCardGroup extends Component {
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
this.groupItemsRef = React.createRef();
|
|
}
|
|
|
|
componentDidMount() {
|
|
window.addEventListener('resize', this.onResize);
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
window.removeEventListener('resize', this.onResize);
|
|
}
|
|
|
|
getContainerWidth = () => {
|
|
const { sidePanelRate, isSidePanelFolded } = this.props;
|
|
return isSidePanelFolded ? window.innerWidth - SIDE_PANEL_FOLDED_WIDTH : window.innerWidth * (1 - sidePanelRate);
|
|
};
|
|
|
|
onResize = () => {
|
|
if (isMobile) return;
|
|
const containerWidth = this.getContainerWidth();
|
|
const numberOfWiki = Math.floor(containerWidth / 180);
|
|
const gridTemplateColumns = (Math.floor((containerWidth - (numberOfWiki + 1) * 16) / numberOfWiki) + 'px ').repeat(numberOfWiki);
|
|
if (this.groupItemsRef.current) {
|
|
this.groupItemsRef.current.style.gridTemplateColumns = gridTemplateColumns;
|
|
}
|
|
};
|
|
|
|
render() {
|
|
const { wikis, title, isDepartment, toggelAddWikiDialog } = this.props;
|
|
const containerWidth = this.getContainerWidth();
|
|
const numberOfWiki = Math.floor(containerWidth / 180);
|
|
const grids = (Math.floor((containerWidth - (numberOfWiki + 1) * 16) / numberOfWiki) + 'px ').repeat(numberOfWiki);
|
|
return (
|
|
<div className='wiki-card-group mb-4'>
|
|
<h4 className="sf-heading">
|
|
<span className={`sf3-font nav-icon sf3-font-${isDepartment ? 'department' : 'mine'}`} aria-hidden="true"></span>
|
|
{title}
|
|
</h4>
|
|
<div className='wiki-card-group-items' style={{ gridTemplateColumns: isMobile ? '48% 48%' : grids }} ref={this.groupItemsRef}>
|
|
{wikis.map((wiki, index) => {
|
|
return (
|
|
<WikiCardItem
|
|
key={index + wiki.id + wiki.name}
|
|
wiki={wiki}
|
|
deleteWiki={this.props.deleteWiki}
|
|
isDepartment={isDepartment}
|
|
isShowAvatar={this.props.isShowAvatar}
|
|
renameWiki={this.props.renameWiki}
|
|
/>
|
|
);
|
|
})}
|
|
{toggelAddWikiDialog &&
|
|
<WikiCardItemAdd toggelAddWikiDialog={toggelAddWikiDialog}/>
|
|
}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
WikiCardGroup.propTypes = propTypes;
|
|
|
|
export default WikiCardGroup;
|