Merge pull request #500 from filecoin-project/@aminejvm/video-autoplay-option

@aminejvm/added support for video's autoplay attr
This commit is contained in:
CAKE 2021-02-01 10:53:10 -08:00 committed by GitHub
commit eac95dfc71
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 33 additions and 4 deletions

View File

@ -105,7 +105,7 @@ const STYLES_TAG = css`
border: 1px solid ${Constants.system.darkGray};
`;
const STYLES_VISIBILITY_SECTION = css`
const STYLES_OPTIONS_SECTION = css`
display: flex;
flex-direction: row;
align-items: center;
@ -180,7 +180,7 @@ const STYLES_FILE_HIDDEN = css`
`;
const STYLES_TEXT = css`
color: ${Constants.system.darkGray}
color: ${Constants.system.darkGray};
line-height: 1.5;
`;
@ -291,6 +291,13 @@ export default class CarouselSidebarData extends React.Component {
}, 4000);
};
_handleToggleAutoPlay = async (e) => {
await this.props.onSave(
{ settings: { ...this.props.data?.settings, autoPlay: e.target.value } },
this.props.index
);
};
_handleUpload = async (e) => {
e.persist();
this.setState({ changingPreview: true });
@ -551,12 +558,12 @@ export default class CarouselSidebarData extends React.Component {
</div>
</div>
)}
{this.props.isOwner ? (
{this.props.isOwner && type?.startsWith("video/") ? (
<React.Fragment>
<div css={STYLES_SECTION_HEADER} style={{ margin: "48px 0px 8px 0px" }}>
Visibility
</div>
<div css={STYLES_VISIBILITY_SECTION}>
<div css={STYLES_OPTIONS_SECTION}>
<div css={STYLES_TEXT}>{isVisible ? "Everyone" : "Link only"}</div>
<Toggle dark active={isVisible} onChange={this._handleToggleVisibility} />
</div>
@ -567,6 +574,26 @@ export default class CarouselSidebarData extends React.Component {
</div>
</React.Fragment>
) : null}
{this.props.isOwner ? (
<React.Fragment>
<div css={STYLES_SECTION_HEADER} style={{ margin: "48px 0px 8px 0px" }}>
Settings
</div>
<div css={STYLES_OPTIONS_SECTION}>
<div css={STYLES_TEXT}>AutoPlay</div>
<Toggle
dark
active={this.props?.data?.settings?.autoPlay}
onChange={this._handleToggleAutoPlay}
/>
</div>
<div style={{ color: Constants.system.darkGray, marginTop: 8 }}>
{this.props?.data?.settings?.autoPlay
? "This video will be autoplayed when opened by others."
: "This video will be paused when opened by others."}
</div>
</React.Fragment>
) : null}
<input
css={STYLES_HIDDEN}
ref={(c) => {

View File

@ -78,10 +78,12 @@ export default class SlateMediaObject extends React.Component {
}
if (type.startsWith("video/")) {
const autoPlay = this.props?.data?.settings?.autoPlay || false;
return (
<video
playsInline
controls
autoPlay={autoPlay}
name="media"
type={playType}
css={STYLES_OBJECT}