2019-08-07 10:57:54 +00:00
|
|
|
import React from "react";
|
|
|
|
import PropTypes from "prop-types";
|
2020-05-29 06:25:28 +00:00
|
|
|
import styled, { css } from "styled-components";
|
2021-03-29 07:24:56 +00:00
|
|
|
//import equal from "fast-deep-equal/react";
|
|
|
|
//import { LayoutContextConsumer } from "studio/Layout/context";
|
2021-01-20 18:04:00 +00:00
|
|
|
import { isMobile } from "react-device-detect";
|
2021-02-20 14:31:58 +00:00
|
|
|
import { inject, observer } from "mobx-react";
|
2020-08-11 12:35:24 +00:00
|
|
|
|
2021-02-24 17:11:23 +00:00
|
|
|
import Scrollbar from "@appserver/components/scrollbar";
|
|
|
|
import DragAndDrop from "@appserver/components/drag-and-drop";
|
|
|
|
import { tablet } from "@appserver/components/utils/device";
|
2019-07-20 09:48:29 +00:00
|
|
|
|
2020-05-29 06:25:28 +00:00
|
|
|
const commonStyles = css`
|
2019-07-20 09:48:29 +00:00
|
|
|
flex-grow: 1;
|
2019-09-10 12:41:52 +00:00
|
|
|
height: 100%;
|
2020-03-11 14:18:47 +00:00
|
|
|
|
2020-05-29 06:25:28 +00:00
|
|
|
.section-wrapper-content {
|
2020-03-11 14:18:47 +00:00
|
|
|
flex: 1 0 auto;
|
2020-10-26 11:24:09 +00:00
|
|
|
padding: 17px 7px 16px 24px;
|
2020-03-11 14:18:47 +00:00
|
|
|
outline: none;
|
2020-10-16 12:38:04 +00:00
|
|
|
${(props) => props.viewAs == "tile" && "padding-right:0;"}
|
2020-03-11 14:18:47 +00:00
|
|
|
|
|
|
|
@media ${tablet} {
|
|
|
|
padding: 16px 0 16px 24px;
|
|
|
|
}
|
2020-05-29 06:25:28 +00:00
|
|
|
|
|
|
|
.section-wrapper {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
min-height: 100%;
|
|
|
|
}
|
2020-12-03 15:03:05 +00:00
|
|
|
|
|
|
|
.people-row-container,
|
|
|
|
.files-row-container {
|
|
|
|
margin-top: -22px;
|
2021-02-24 17:11:23 +00:00
|
|
|
}
|
2020-03-11 14:18:47 +00:00
|
|
|
}
|
2019-12-25 14:51:38 +00:00
|
|
|
`;
|
|
|
|
|
2020-05-29 06:25:28 +00:00
|
|
|
const StyledSectionBody = styled.div`
|
|
|
|
${commonStyles}
|
2020-10-16 12:38:04 +00:00
|
|
|
|
|
|
|
${(props) =>
|
|
|
|
props.withScroll &&
|
|
|
|
`
|
2021-01-13 12:21:06 +00:00
|
|
|
|
2020-05-29 06:25:28 +00:00
|
|
|
margin-left: -24px;
|
|
|
|
`}
|
|
|
|
`;
|
|
|
|
|
|
|
|
const StyledDropZoneBody = styled(DragAndDrop)`
|
|
|
|
${commonStyles}
|
|
|
|
|
|
|
|
.drag-and-drop {
|
2020-08-11 12:53:39 +00:00
|
|
|
user-select: none;
|
2020-05-29 06:25:28 +00:00
|
|
|
height: 100%;
|
|
|
|
}
|
2020-10-16 12:38:04 +00:00
|
|
|
|
|
|
|
${(props) =>
|
|
|
|
props.withScroll &&
|
|
|
|
`
|
2020-05-29 06:25:28 +00:00
|
|
|
margin-left: -24px;
|
|
|
|
`}
|
2019-07-20 09:48:29 +00:00
|
|
|
`;
|
|
|
|
|
2019-11-14 12:13:54 +00:00
|
|
|
const StyledSpacer = styled.div`
|
|
|
|
display: none;
|
|
|
|
min-height: 64px;
|
|
|
|
|
|
|
|
@media ${tablet} {
|
2020-10-16 12:38:04 +00:00
|
|
|
display: ${(props) => (props.pinned ? "none" : "block")};
|
2019-11-14 12:13:54 +00:00
|
|
|
}
|
|
|
|
`;
|
|
|
|
|
2020-01-24 08:23:12 +00:00
|
|
|
class SectionBody extends React.Component {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
2019-07-20 09:48:29 +00:00
|
|
|
|
2020-01-24 08:23:12 +00:00
|
|
|
this.focusRef = React.createRef();
|
2020-06-11 06:54:33 +00:00
|
|
|
this.scrollRef = React.createRef();
|
2020-01-24 08:23:12 +00:00
|
|
|
}
|
2020-08-11 12:35:24 +00:00
|
|
|
|
2021-02-20 14:31:58 +00:00
|
|
|
// shouldComponentUpdate(nextProps) {
|
|
|
|
// return !equal(this.props, nextProps);
|
|
|
|
// }
|
2020-08-11 12:35:24 +00:00
|
|
|
|
2020-01-24 08:23:12 +00:00
|
|
|
componentDidMount() {
|
|
|
|
if (!this.props.autoFocus) return;
|
|
|
|
this.focusRef.current.focus();
|
|
|
|
}
|
|
|
|
|
2020-12-04 11:21:51 +00:00
|
|
|
componentWillUnmount() {
|
|
|
|
this.focusRef = null;
|
|
|
|
this.scrollRef = null;
|
|
|
|
}
|
|
|
|
|
2020-01-24 08:23:12 +00:00
|
|
|
render() {
|
2020-11-30 13:09:53 +00:00
|
|
|
//console.log("PageLayout SectionBody render" );
|
2020-10-16 12:38:04 +00:00
|
|
|
const {
|
2020-08-11 12:35:24 +00:00
|
|
|
autoFocus,
|
|
|
|
children,
|
|
|
|
onDrop,
|
|
|
|
pinned,
|
|
|
|
setSelections,
|
|
|
|
uploadFiles,
|
|
|
|
viewAs,
|
2020-10-16 12:38:04 +00:00
|
|
|
withScroll,
|
2020-11-19 13:34:34 +00:00
|
|
|
isLoaded,
|
2020-08-11 12:35:24 +00:00
|
|
|
} = this.props;
|
2020-01-24 08:23:12 +00:00
|
|
|
|
2020-10-16 12:38:04 +00:00
|
|
|
const focusProps = autoFocus
|
|
|
|
? {
|
|
|
|
ref: this.focusRef,
|
2021-04-30 11:02:58 +00:00
|
|
|
tabIndex: -1,
|
2020-10-16 12:38:04 +00:00
|
|
|
}
|
|
|
|
: {};
|
2020-01-24 08:23:12 +00:00
|
|
|
|
2020-07-24 07:34:53 +00:00
|
|
|
const scrollProp = uploadFiles ? { ref: this.scrollRef } : {};
|
|
|
|
|
|
|
|
return uploadFiles ? (
|
|
|
|
<StyledDropZoneBody
|
|
|
|
isDropZone
|
|
|
|
onDrop={onDrop}
|
|
|
|
withScroll={withScroll}
|
|
|
|
viewAs={viewAs}
|
2020-11-17 08:36:49 +00:00
|
|
|
pinned={pinned}
|
2020-11-19 13:34:34 +00:00
|
|
|
isLoaded={isLoaded}
|
2020-07-24 07:34:53 +00:00
|
|
|
>
|
|
|
|
{withScroll ? (
|
2021-01-20 18:04:00 +00:00
|
|
|
!isMobile ? (
|
|
|
|
<Scrollbar {...scrollProp} stype="mediumBlack">
|
2021-04-13 06:35:07 +00:00
|
|
|
<div className="section-wrapper">
|
|
|
|
<div className="section-wrapper-content" {...focusProps}>
|
|
|
|
{children}
|
|
|
|
<StyledSpacer pinned={pinned} />
|
2020-07-24 07:34:53 +00:00
|
|
|
</div>
|
2021-04-13 06:35:07 +00:00
|
|
|
</div>
|
2021-01-20 18:04:00 +00:00
|
|
|
</Scrollbar>
|
|
|
|
) : (
|
2021-03-29 07:24:56 +00:00
|
|
|
<div className="section-wrapper">
|
|
|
|
<div className="section-wrapper-content" {...focusProps}>
|
|
|
|
{children}
|
|
|
|
<StyledSpacer pinned={pinned} />
|
2021-03-29 07:08:50 +00:00
|
|
|
</div>
|
2021-03-29 07:24:56 +00:00
|
|
|
</div>
|
2021-01-20 18:04:00 +00:00
|
|
|
)
|
2020-07-24 07:34:53 +00:00
|
|
|
) : (
|
2021-04-13 06:35:07 +00:00
|
|
|
<div className="section-wrapper">
|
|
|
|
{children}
|
|
|
|
<StyledSpacer pinned={pinned} />
|
|
|
|
</div>
|
2020-10-16 12:38:04 +00:00
|
|
|
)}
|
2020-07-24 07:34:53 +00:00
|
|
|
</StyledDropZoneBody>
|
|
|
|
) : (
|
2020-11-17 08:36:49 +00:00
|
|
|
<StyledSectionBody
|
|
|
|
viewAs={viewAs}
|
|
|
|
withScroll={withScroll}
|
|
|
|
pinned={pinned}
|
2020-11-19 13:34:34 +00:00
|
|
|
isLoaded={isLoaded}
|
2020-11-17 08:36:49 +00:00
|
|
|
>
|
2020-10-16 12:38:04 +00:00
|
|
|
{withScroll ? (
|
2021-01-20 18:04:00 +00:00
|
|
|
!isMobile ? (
|
|
|
|
<Scrollbar {...scrollProp} stype="mediumBlack">
|
|
|
|
<div className="section-wrapper">
|
|
|
|
<div className="section-wrapper-content" {...focusProps}>
|
|
|
|
{children}
|
|
|
|
<StyledSpacer pinned={pinned} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</Scrollbar>
|
|
|
|
) : (
|
2020-10-16 12:38:04 +00:00
|
|
|
<div className="section-wrapper">
|
|
|
|
<div className="section-wrapper-content" {...focusProps}>
|
2020-03-11 14:18:47 +00:00
|
|
|
{children}
|
2020-05-29 06:25:28 +00:00
|
|
|
<StyledSpacer pinned={pinned} />
|
2020-03-11 14:18:47 +00:00
|
|
|
</div>
|
2020-10-16 12:38:04 +00:00
|
|
|
</div>
|
2021-01-20 18:04:00 +00:00
|
|
|
)
|
2020-10-16 12:38:04 +00:00
|
|
|
) : (
|
|
|
|
<div className="section-wrapper">
|
|
|
|
{children}
|
|
|
|
<StyledSpacer pinned={pinned} />
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</StyledSectionBody>
|
|
|
|
);
|
2020-01-24 08:23:12 +00:00
|
|
|
}
|
|
|
|
}
|
2019-07-20 09:48:29 +00:00
|
|
|
|
2019-09-10 12:41:52 +00:00
|
|
|
SectionBody.displayName = "SectionBody";
|
|
|
|
|
2019-08-07 10:57:54 +00:00
|
|
|
SectionBody.propTypes = {
|
2019-09-10 12:41:52 +00:00
|
|
|
withScroll: PropTypes.bool,
|
2020-01-24 08:23:12 +00:00
|
|
|
autoFocus: PropTypes.bool,
|
2019-11-14 12:13:54 +00:00
|
|
|
pinned: PropTypes.bool,
|
2020-05-29 06:25:28 +00:00
|
|
|
onDrop: PropTypes.func,
|
2020-06-09 07:02:13 +00:00
|
|
|
setSelections: PropTypes.func,
|
2020-05-29 06:25:28 +00:00
|
|
|
uploadFiles: PropTypes.bool,
|
2019-09-10 12:41:52 +00:00
|
|
|
children: PropTypes.oneOfType([
|
|
|
|
PropTypes.arrayOf(PropTypes.node),
|
2019-09-12 12:15:22 +00:00
|
|
|
PropTypes.node,
|
2020-10-16 12:38:04 +00:00
|
|
|
PropTypes.any,
|
2020-07-15 04:30:59 +00:00
|
|
|
]),
|
2020-10-16 12:38:04 +00:00
|
|
|
viewAs: PropTypes.string,
|
2020-11-19 14:53:12 +00:00
|
|
|
isLoaded: PropTypes.bool,
|
2019-08-07 10:57:54 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
SectionBody.defaultProps = {
|
2020-01-24 08:23:12 +00:00
|
|
|
autoFocus: false,
|
2020-05-29 06:25:28 +00:00
|
|
|
pinned: false,
|
2020-07-15 04:30:59 +00:00
|
|
|
uploadFiles: false,
|
2020-10-16 12:38:04 +00:00
|
|
|
withScroll: true,
|
2019-08-07 10:57:54 +00:00
|
|
|
};
|
|
|
|
|
2021-02-20 14:31:58 +00:00
|
|
|
export default inject(({ auth }) => {
|
2020-11-19 14:53:12 +00:00
|
|
|
return {
|
2021-02-20 14:31:58 +00:00
|
|
|
isLoaded: auth.isLoaded,
|
2020-11-19 14:53:12 +00:00
|
|
|
};
|
2021-02-20 14:31:58 +00:00
|
|
|
})(observer(SectionBody));
|