Add possibility for hosting provider IFrame

Add config option hosting_signup_iframe that
will render an action in the UserMenu and ProfileSettings
for setting up a host with some hosting provider
that provides an HTML to do that.

Add iframe for hosting provider signup content
This commit is contained in:
Jason Robinson 2020-10-21 15:22:35 +03:00
parent edd5bf5842
commit c7706ac3d5
6 changed files with 138 additions and 0 deletions

View File

@ -72,6 +72,7 @@
@import "./views/dialogs/_EditCommunityPrototypeDialog.scss";
@import "./views/dialogs/_FeedbackDialog.scss";
@import "./views/dialogs/_GroupAddressPicker.scss";
@import "./views/dialogs/_HostingProviderDialog.scss";
@import "./views/dialogs/_IncomingSasDialog.scss";
@import "./views/dialogs/_InviteDialog.scss";
@import "./views/dialogs/_KeyboardShortcutsDialog.scss";

View File

@ -0,0 +1,44 @@
/*
Copyright 2020 Element
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
.mx_HostingProviderDialog .mx_Dialog {
width: 60%;
height: 70%;
overflow: hidden;
padding: 0;
max-width: initial;
max-height: initial;
position: relative;
}
.mx_HostingProviderDialog_container {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
iframe {
width: 100%;
height: 100%;
border: none;
background-color: #fff;
}
}
.mx_HostingProviderTrigger {
cursor: pointer;
}

View File

@ -0,0 +1,33 @@
/*
Copyright 2020 Element
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
import * as React from "react";
import SdkConfig from "../../SdkConfig";
interface IProps {}
interface IState {}
export default class HostingProviderDialog extends React.PureComponent<IProps, IState> {
public render(): React.ReactNode {
const hostingSignupUrl = SdkConfig.get().hosting_signup_iframe;
return (
<div className="mx_HostingProviderDialog_container">
<iframe src={hostingSignupUrl} />
</div>
);
}
}

View File

@ -0,0 +1,39 @@
/*
Copyright 2020 Element
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
import * as React from "react";
import Modal from "../../Modal";
import HostingProviderDialog from "./HostingProviderDialog";
interface IProps {}
interface IState {}
export default class HostingProviderTrigger extends React.PureComponent<IProps, IState> {
private static openDialog() {
Modal.createDialog(
HostingProviderDialog, {}, "mx_HostingProviderDialog",
);
}
public render(): React.ReactNode {
return (
<div onClick={HostingProviderTrigger.openDialog} className="mx_HostingProviderTrigger">
Get your own personal Element!
</div>
);
}
}

View File

@ -51,6 +51,7 @@ import { RightPanelPhases } from "../../stores/RightPanelStorePhases";
import ErrorDialog from "../views/dialogs/ErrorDialog";
import EditCommunityPrototypeDialog from "../views/dialogs/EditCommunityPrototypeDialog";
import {UIFeature} from "../../settings/UIFeature";
import HostingProviderTrigger from "./HostingProviderTrigger";
interface IProps {
isMinimized: boolean;
@ -311,6 +312,16 @@ export default class UserMenu extends React.Component<IProps, IState> {
</div>
);
}
const hostingSignupIFrame = SdkConfig.get().hosting_signup_iframe;
let hostingIFrame;
if (hostingSignupIFrame) {
hostingIFrame = <div
className="mx_UserMenu_contextMenu_header mx_UserMenu_contextMenu_hostingLink"
onClick={this.onCloseMenu}
>
<HostingProviderTrigger />
</div>;
}
let homeButton = null;
if (this.hasHomePage) {
@ -495,6 +506,7 @@ export default class UserMenu extends React.Component<IProps, IState> {
</AccessibleTooltipButton>
</div>
{topSection}
{hostingIFrame}
{primaryOptionList}
{secondarySection}
</IconizedContextMenu>;

View File

@ -23,6 +23,7 @@ import * as sdk from "../../../index";
import {OwnProfileStore} from "../../../stores/OwnProfileStore";
import Modal from "../../../Modal";
import ErrorDialog from "../dialogs/ErrorDialog";
import SdkConfig from "../../../SdkConfig";
export default class ProfileSettings extends React.Component {
constructor() {
@ -151,6 +152,13 @@ export default class ProfileSettings extends React.Component {
</a>
</span>;
}
const hostingSignupIFrame = SdkConfig.get().hosting_signup_iframe;
let hostingIFrame;
if (hostingSignupIFrame) {
hostingIFrame = <span className="mx_ProfileSettings_hostingIFrame">
Get your own personal Element!
</span>;
}
const AccessibleButton = sdk.getComponent('elements.AccessibleButton');
const AvatarSetting = sdk.getComponent('settings.AvatarSetting');
@ -175,6 +183,7 @@ export default class ProfileSettings extends React.Component {
<p>
{this.state.userId}
{hostingSignup}
{hostingIFrame}
</p>
</div>
<AvatarSetting