mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-05 00:43:53 +00:00
Fix wikis list style when side panel width is changing (#6349)
* fix wikis list style when side panel width is changing * change code format * fix wiki list item width when side panel is folded
This commit is contained in:
@@ -308,7 +308,11 @@ class App extends Component {
|
|||||||
<ShareAdminShareLinks path={siteRoot + 'share-admin-share-links'} />
|
<ShareAdminShareLinks path={siteRoot + 'share-admin-share-links'} />
|
||||||
<ShareAdminUploadLinks path={siteRoot + 'share-admin-upload-links'} />
|
<ShareAdminUploadLinks path={siteRoot + 'share-admin-upload-links'} />
|
||||||
<PublicSharedView path={siteRoot + 'org/'} />
|
<PublicSharedView path={siteRoot + 'org/'} />
|
||||||
<Wikis path={siteRoot + 'published'} />
|
<Wikis
|
||||||
|
path={siteRoot + 'published'}
|
||||||
|
sidePanelRate={sidePanelRate}
|
||||||
|
isSidePanelFolded={isSidePanelFolded}
|
||||||
|
/>
|
||||||
<Starred path={siteRoot + 'starred'} />
|
<Starred path={siteRoot + 'starred'} />
|
||||||
<InvitationsView path={siteRoot + 'invitations/'} />
|
<InvitationsView path={siteRoot + 'invitations/'} />
|
||||||
<FilesActivities path={siteRoot + 'dashboard'} />
|
<FilesActivities path={siteRoot + 'dashboard'} />
|
||||||
|
@@ -3,6 +3,7 @@ import PropTypes from 'prop-types';
|
|||||||
import WikiCardItem from './wiki-card-item';
|
import WikiCardItem from './wiki-card-item';
|
||||||
import WikiCardItemAdd from './wiki-card-item-add';
|
import WikiCardItemAdd from './wiki-card-item-add';
|
||||||
import { isMobile } from '../../utils/utils';
|
import { isMobile } from '../../utils/utils';
|
||||||
|
import { SIDE_PANEL_FOLDED_WIDTH } from '../../constants';
|
||||||
|
|
||||||
const propTypes = {
|
const propTypes = {
|
||||||
wikis: PropTypes.array.isRequired,
|
wikis: PropTypes.array.isRequired,
|
||||||
@@ -12,6 +13,8 @@ const propTypes = {
|
|||||||
isShowAvatar: PropTypes.bool.isRequired,
|
isShowAvatar: PropTypes.bool.isRequired,
|
||||||
renameWiki: PropTypes.func.isRequired,
|
renameWiki: PropTypes.func.isRequired,
|
||||||
toggelAddWikiDialog: PropTypes.func,
|
toggelAddWikiDialog: PropTypes.func,
|
||||||
|
sidePanelRate: PropTypes.number,
|
||||||
|
isSidePanelFolded: PropTypes.bool,
|
||||||
};
|
};
|
||||||
|
|
||||||
class WikiCardGroup extends Component {
|
class WikiCardGroup extends Component {
|
||||||
@@ -29,10 +32,16 @@ class WikiCardGroup extends Component {
|
|||||||
window.removeEventListener('resize', this.onResize);
|
window.removeEventListener('resize', this.onResize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getContainerWidth = () => {
|
||||||
|
const { sidePanelRate, isSidePanelFolded } = this.props;
|
||||||
|
return isSidePanelFolded ? window.innerWidth - SIDE_PANEL_FOLDED_WIDTH : window.innerWidth * (1 - sidePanelRate);
|
||||||
|
};
|
||||||
|
|
||||||
onResize = () => {
|
onResize = () => {
|
||||||
if (isMobile) return;
|
if (isMobile) return;
|
||||||
const numberOfWiki = Math.floor((window.innerWidth * 0.78 / 180));
|
const containerWidth = this.getContainerWidth();
|
||||||
const gridTemplateColumns = (Math.floor((window.innerWidth * 0.78 - (numberOfWiki + 1) * 16) / numberOfWiki) + 'px ').repeat(numberOfWiki);
|
const numberOfWiki = Math.floor(containerWidth / 180);
|
||||||
|
const gridTemplateColumns = (Math.floor((containerWidth - (numberOfWiki + 1) * 16) / numberOfWiki) + 'px ').repeat(numberOfWiki);
|
||||||
if (this.groupItemsRef.current) {
|
if (this.groupItemsRef.current) {
|
||||||
this.groupItemsRef.current.style.gridTemplateColumns = gridTemplateColumns;
|
this.groupItemsRef.current.style.gridTemplateColumns = gridTemplateColumns;
|
||||||
}
|
}
|
||||||
@@ -40,8 +49,9 @@ class WikiCardGroup extends Component {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { wikis, title, isDepartment, toggelAddWikiDialog } = this.props;
|
const { wikis, title, isDepartment, toggelAddWikiDialog } = this.props;
|
||||||
const numberOfWiki = Math.floor((window.innerWidth * 0.78 / 180));
|
const containerWidth = this.getContainerWidth();
|
||||||
const grids = (Math.floor((window.innerWidth * 0.78 - (numberOfWiki + 1) * 16) / numberOfWiki) + 'px ').repeat(numberOfWiki);
|
const numberOfWiki = Math.floor(containerWidth / 180);
|
||||||
|
const grids = (Math.floor((containerWidth - (numberOfWiki + 1) * 16) / numberOfWiki) + 'px ').repeat(numberOfWiki);
|
||||||
return (
|
return (
|
||||||
<div className='wiki-card-group mb-4'>
|
<div className='wiki-card-group mb-4'>
|
||||||
<h4 className="sf-heading">
|
<h4 className="sf-heading">
|
||||||
|
@@ -13,6 +13,8 @@ const propTypes = {
|
|||||||
deleteWiki: PropTypes.func.isRequired,
|
deleteWiki: PropTypes.func.isRequired,
|
||||||
renameWiki: PropTypes.func.isRequired,
|
renameWiki: PropTypes.func.isRequired,
|
||||||
toggelAddWikiDialog: PropTypes.func,
|
toggelAddWikiDialog: PropTypes.func,
|
||||||
|
sidePanelRate: PropTypes.number,
|
||||||
|
isSidePanelFolded: PropTypes.bool,
|
||||||
};
|
};
|
||||||
|
|
||||||
class WikiCardView extends Component {
|
class WikiCardView extends Component {
|
||||||
@@ -57,7 +59,7 @@ class WikiCardView extends Component {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
let { loading, errorMsg, wikis } = this.props.data;
|
let { loading, errorMsg, wikis } = this.props.data;
|
||||||
const { toggelAddWikiDialog } = this.props;
|
const { toggelAddWikiDialog, sidePanelRate, isSidePanelFolded } = this.props;
|
||||||
|
|
||||||
if (loading) {
|
if (loading) {
|
||||||
return <span className="loading-icon loading-tip"></span>;
|
return <span className="loading-icon loading-tip"></span>;
|
||||||
@@ -72,6 +74,8 @@ class WikiCardView extends Component {
|
|||||||
key='my-Wikis'
|
key='my-Wikis'
|
||||||
deleteWiki={this.props.deleteWiki}
|
deleteWiki={this.props.deleteWiki}
|
||||||
renameWiki={this.props.renameWiki}
|
renameWiki={this.props.renameWiki}
|
||||||
|
sidePanelRate={sidePanelRate}
|
||||||
|
isSidePanelFolded={isSidePanelFolded}
|
||||||
wikis={myWikis}
|
wikis={myWikis}
|
||||||
title={gettext('My Wikis')}
|
title={gettext('My Wikis')}
|
||||||
isDepartment={false}
|
isDepartment={false}
|
||||||
@@ -85,6 +89,8 @@ class WikiCardView extends Component {
|
|||||||
key={'department-Wikis-' + deptID}
|
key={'department-Wikis-' + deptID}
|
||||||
deleteWiki={this.props.deleteWiki}
|
deleteWiki={this.props.deleteWiki}
|
||||||
renameWiki={this.props.renameWiki}
|
renameWiki={this.props.renameWiki}
|
||||||
|
sidePanelRate={sidePanelRate}
|
||||||
|
isSidePanelFolded={isSidePanelFolded}
|
||||||
wikis={department2WikisMap[deptID]}
|
wikis={department2WikisMap[deptID]}
|
||||||
title={department2WikisMap[deptID][0].owner_nickname}
|
title={department2WikisMap[deptID][0].owner_nickname}
|
||||||
isDepartment={true}
|
isDepartment={true}
|
||||||
@@ -98,6 +104,8 @@ class WikiCardView extends Component {
|
|||||||
key='old-Wikis'
|
key='old-Wikis'
|
||||||
deleteWiki={this.props.deleteWiki}
|
deleteWiki={this.props.deleteWiki}
|
||||||
renameWiki={this.props.renameWiki}
|
renameWiki={this.props.renameWiki}
|
||||||
|
isSidePanelFolded={isSidePanelFolded}
|
||||||
|
sidePanelRate={sidePanelRate}
|
||||||
wikis={v1Wikis}
|
wikis={v1Wikis}
|
||||||
title={gettext('Old Wikis')}
|
title={gettext('Old Wikis')}
|
||||||
isDepartment={false}
|
isDepartment={false}
|
||||||
|
@@ -1,4 +1,5 @@
|
|||||||
import React, { Component, Fragment } from 'react';
|
import React, { Component, Fragment } from 'react';
|
||||||
|
import PropTypes from 'prop-types';
|
||||||
import { Dropdown, DropdownToggle, DropdownMenu, DropdownItem } from 'reactstrap';
|
import { Dropdown, DropdownToggle, DropdownMenu, DropdownItem } from 'reactstrap';
|
||||||
import { gettext, canPublishRepo } from '../../utils/constants';
|
import { gettext, canPublishRepo } from '../../utils/constants';
|
||||||
import { Utils } from '../../utils/utils';
|
import { Utils } from '../../utils/utils';
|
||||||
@@ -9,6 +10,11 @@ import AddWikiDialog from '../../components/dialog/add-wiki-dialog';
|
|||||||
import wikiAPI from '../../utils/wiki-api';
|
import wikiAPI from '../../utils/wiki-api';
|
||||||
import WikiCardView from '../../components/wiki-card-view/wiki-card-view';
|
import WikiCardView from '../../components/wiki-card-view/wiki-card-view';
|
||||||
|
|
||||||
|
const propTypes = {
|
||||||
|
sidePanelRate: PropTypes.number,
|
||||||
|
isSidePanelFolded: PropTypes.bool,
|
||||||
|
};
|
||||||
|
|
||||||
class Wikis extends Component {
|
class Wikis extends Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
@@ -209,6 +215,8 @@ class Wikis extends Component {
|
|||||||
deleteWiki={this.deleteWiki}
|
deleteWiki={this.deleteWiki}
|
||||||
renameWiki={this.renameWiki}
|
renameWiki={this.renameWiki}
|
||||||
toggelAddWikiDialog={this.toggelAddWikiDialog}
|
toggelAddWikiDialog={this.toggelAddWikiDialog}
|
||||||
|
sidePanelRate={this.props.sidePanelRate}
|
||||||
|
isSidePanelFolded={this.props.isSidePanelFolded}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
@@ -229,4 +237,6 @@ class Wikis extends Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Wikis.propTypes = propTypes;
|
||||||
|
|
||||||
export default Wikis;
|
export default Wikis;
|
||||||
|
Reference in New Issue
Block a user