slate/components/sidebars/SidebarAddFileToSlate.js
2020-09-24 20:17:36 -07:00

223 lines
5.7 KiB
JavaScript

import * as React from "react";
import * as Strings from "~/common/strings";
import * as Constants from "~/common/constants";
import * as System from "~/components/system";
import * as Validations from "~/common/validations";
import * as SVG from "~/common/svg";
import * as Actions from "~/common/actions";
import { dispatchCustomEvent } from "~/common/custom-events";
import { css } from "@emotion/react";
import {
ButtonPrimary,
ButtonDisabled,
} from "~/components/system/components/Buttons";
const STYLES_SLATE_NAME = css`
overflow: hidden;
text-overflow: ellipsis;
font-family: ${Constants.font.medium};
`;
const STYLES_HEADER = css`
font-family: ${Constants.font.semiBold};
font-size: 18px;
margin-top: 32px;
margin-bottom: 16px;
`;
const STYLES_SLATE_LIST = css`
max-height: 400px;
overflow-y: scroll;
`;
const STYLES_SLATE_LINE = css`
display: flex;
align-items: center;
width: 100%;
padding: 12px 16px;
background-color: ${Constants.system.white};
margin-bottom: 1px;
cursor: pointer;
`;
const STYLES_ICON_BOX = css`
display: flex;
align-items: center;
`;
export default class SidebarAddFileToSlate extends React.Component {
state = {
selected: {},
};
componentDidMount = () => {
if (!this.props.sidebarData || !this.props.sidebarData.files) {
this.props.onCancel();
}
};
_handleCreateSlate = async () => {
if (
Object.values(this.state.selected).some((value) => {
return !!value;
})
) {
await this._handleSubmit();
}
await this.props.onCancel();
this.props.onAction({
type: "SIDEBAR",
value: "SIDEBAR_CREATE_SLATE",
data: this.props.sidebarData,
});
};
_handleAdd = (slate) => {
if (this.state.selected[slate.id]) {
this.setState({
selected: { ...this.state.selected, [slate.id]: false },
});
} else {
this.setState({
selected: { ...this.state.selected, [slate.id]: slate },
});
}
};
_handleSubmit = async () => {
let data = this.props.sidebarData.files.map((file) => {
return { title: file.name, ...file };
});
for (let slate of Object.values(this.state.selected)) {
if (!slate) continue;
const addResponse = await Actions.addFileToSlate({ slate, data });
if (!addResponse) {
dispatchCustomEvent({
name: "create-alert",
detail: {
alert: {
message:
"We're having trouble connecting right now. Please try again later",
},
},
});
return;
}
if (addResponse.error) {
dispatchCustomEvent({
name: "create-alert",
detail: { alert: { decorator: addResponse.decorator } },
});
return;
}
const { added, skipped } = addResponse;
let message = `${added || 0} file${added !== 1 ? "s" : ""} uploaded. `;
if (skipped) {
message += `${skipped || 0} duplicate / existing file${
added !== 1 ? "s were" : " was"
} skipped.`;
}
dispatchCustomEvent({
name: "create-alert",
detail: {
alert: { message, status: !added ? null : "INFO" },
},
});
}
await this.props.onRehydrate();
dispatchCustomEvent({
name: "remote-update-carousel",
detail: null,
});
this.props.onCancel();
};
render() {
return (
<div>
<System.P
style={{
fontFamily: Constants.font.semiBold,
fontSize: Constants.typescale.lvl3,
marginBottom: "64px",
}}
>
Add files to slate
</System.P>
<System.P css={STYLES_HEADER}>Slates</System.P>
<div
css={STYLES_SLATE_LINE}
style={{ marginBottom: 32 }}
onClick={this._handleCreateSlate}
>
<SVG.Plus
height="24px"
style={{
color: Constants.system.brand,
marginRight: 8,
pointerEvents: "none",
}}
/>
<div
css={STYLES_SLATE_NAME}
style={{ color: Constants.system.brand }}
>
Create new slate
</div>
</div>
<div css={STYLES_SLATE_LIST}>
{this.props.viewer.slates.map((slate) => (
<div css={STYLES_SLATE_LINE} onClick={() => this._handleAdd(slate)}>
<div css={STYLES_ICON_BOX}>
{this.state.selected[slate.id] ? (
<SVG.Slate
height="24px"
style={{ marginRight: 8, pointerEvents: "none" }}
/>
) : (
<SVG.PlusCircle
height="24px"
style={{
color: Constants.system.darkGray,
marginRight: 8,
pointerEvents: "none",
}}
/>
)}
</div>
<div
css={STYLES_SLATE_NAME}
style={
this.state.selected[slate.id]
? null
: { color: Constants.system.darkGray }
}
>
{slate.data.name || slate.slatename}
</div>
</div>
))}
</div>
{Object.keys(this.state.selected).length ? (
<ButtonPrimary
full
onClick={this._handleSubmit}
style={{ marginTop: 32 }}
>
Add to slates
</ButtonPrimary>
) : (
<ButtonDisabled full style={{ marginTop: 32 }}>
Add to slates
</ButtonDisabled>
)}
</div>
);
}
}