matrix-react-sdk
Version:
SDK for matrix.org using React
184 lines (149 loc) • 18.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = _interopRequireDefault(require("react"));
var _lodash = require("lodash");
var _classnames = _interopRequireDefault(require("classnames"));
var _PlatformPeg = _interopRequireDefault(require("../../../PlatformPeg"));
var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton"));
var _languageHandler = require("../../../languageHandler");
var _Login = require("../../../Login");
var _AccessibleTooltipButton = _interopRequireDefault(require("./AccessibleTooltipButton"));
var _Media = require("../../../customisations/Media");
/*
Copyright 2020 The Matrix.org Foundation C.I.C.
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.
*/
const getIcon = (brand
/*: IdentityProviderBrand | string*/
) => {
switch (brand) {
case _Login.IdentityProviderBrand.Apple:
return require(`../../../../res/img/element-icons/brands/apple.svg`);
case _Login.IdentityProviderBrand.Facebook:
return require(`../../../../res/img/element-icons/brands/facebook.svg`);
case _Login.IdentityProviderBrand.Github:
return require(`../../../../res/img/element-icons/brands/github.svg`);
case _Login.IdentityProviderBrand.Gitlab:
return require(`../../../../res/img/element-icons/brands/gitlab.svg`);
case _Login.IdentityProviderBrand.Google:
return require(`../../../../res/img/element-icons/brands/google.svg`);
case _Login.IdentityProviderBrand.Twitter:
return require(`../../../../res/img/element-icons/brands/twitter.svg`);
default:
return null;
}
};
const SSOButton
/*: React.FC<ISSOButtonProps>*/
= (_ref) => {
let {
matrixClient,
loginType,
fragmentAfterLogin,
idp,
primary,
mini
} = _ref,
props = (0, _objectWithoutProperties2.default)(_ref, ["matrixClient", "loginType", "fragmentAfterLogin", "idp", "primary", "mini"]);
const label = idp ? (0, _languageHandler._t)("Continue with %(provider)s", {
provider: idp.name
}) : (0, _languageHandler._t)("Sign in with single sign-on");
const onClick = () => {
_PlatformPeg.default.get().startSingleSignOn(matrixClient, loginType, fragmentAfterLogin, idp?.id);
};
let icon;
let brandClass;
const brandIcon = idp ? getIcon(idp.brand) : null;
if (brandIcon) {
const brandName = idp.brand.split(".").pop();
brandClass = `mx_SSOButton_brand_${brandName}`;
icon = /*#__PURE__*/_react.default.createElement("img", {
src: brandIcon,
height: "24",
width: "24",
alt: brandName
});
} else if (typeof idp?.icon === "string" && idp.icon.startsWith("mxc://")) {
const src = (0, _Media.mediaFromMxc)(idp.icon, matrixClient).getSquareThumbnailHttp(24);
icon = /*#__PURE__*/_react.default.createElement("img", {
src: src,
height: "24",
width: "24",
alt: idp.name
});
}
const classes = (0, _classnames.default)("mx_SSOButton", {
[brandClass]: brandClass,
mx_SSOButton_mini: mini,
mx_SSOButton_default: !idp,
mx_SSOButton_primary: primary
});
if (mini) {
// TODO fallback icon
return /*#__PURE__*/_react.default.createElement(_AccessibleTooltipButton.default, (0, _extends2.default)({}, props, {
title: label,
className: classes,
onClick: onClick
}), icon);
}
return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, (0, _extends2.default)({}, props, {
className: classes,
onClick: onClick
}), icon, label);
};
const MAX_PER_ROW = 6;
const SSOButtons
/*: React.FC<IProps>*/
= ({
matrixClient,
flow,
loginType,
fragmentAfterLogin,
primary
}) => {
const providers = flow["org.matrix.msc2858.identity_providers"] || [];
if (providers.length < 2) {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SSOButtons"
}, /*#__PURE__*/_react.default.createElement(SSOButton, {
matrixClient: matrixClient,
loginType: loginType,
fragmentAfterLogin: fragmentAfterLogin,
idp: providers[0],
primary: primary
}));
}
const rows = Math.ceil(providers.length / MAX_PER_ROW);
const size = Math.ceil(providers.length / rows);
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SSOButtons"
}, (0, _lodash.chunk)(providers, size).map(chunk => /*#__PURE__*/_react.default.createElement("div", {
key: chunk[0].id,
className: "mx_SSOButtons_row"
}, chunk.map(idp => /*#__PURE__*/_react.default.createElement(SSOButton, {
key: idp.id,
matrixClient: matrixClient,
loginType: loginType,
fragmentAfterLogin: fragmentAfterLogin,
idp: idp,
mini: true,
primary: primary
})))));
};
var _default = SSOButtons;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/elements/SSOButtons.tsx"],"names":["getIcon","brand","IdentityProviderBrand","Apple","require","Facebook","Github","Gitlab","Google","Twitter","SSOButton","matrixClient","loginType","fragmentAfterLogin","idp","primary","mini","props","label","provider","name","onClick","PlatformPeg","get","startSingleSignOn","id","icon","brandClass","brandIcon","brandName","split","pop","startsWith","src","getSquareThumbnailHttp","classes","mx_SSOButton_mini","mx_SSOButton_default","mx_SSOButton_primary","MAX_PER_ROW","SSOButtons","flow","providers","length","rows","Math","ceil","size","map","chunk"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React from \"react\";\nimport { chunk } from \"lodash\";\nimport classNames from \"classnames\";\nimport {MatrixClient} from \"matrix-js-sdk/src/client\";\n\nimport PlatformPeg from \"../../../PlatformPeg\";\nimport AccessibleButton from \"./AccessibleButton\";\nimport {_t} from \"../../../languageHandler\";\nimport {IdentityProviderBrand, IIdentityProvider, ISSOFlow} from \"../../../Login\";\nimport AccessibleTooltipButton from \"./AccessibleTooltipButton\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\ninterface ISSOButtonProps extends Omit<IProps, \"flow\"> {\n    idp: IIdentityProvider;\n    mini?: boolean;\n}\n\nconst getIcon = (brand: IdentityProviderBrand | string) => {\n    switch (brand) {\n        case IdentityProviderBrand.Apple:\n            return require(`../../../../res/img/element-icons/brands/apple.svg`);\n        case IdentityProviderBrand.Facebook:\n            return require(`../../../../res/img/element-icons/brands/facebook.svg`);\n        case IdentityProviderBrand.Github:\n            return require(`../../../../res/img/element-icons/brands/github.svg`);\n        case IdentityProviderBrand.Gitlab:\n            return require(`../../../../res/img/element-icons/brands/gitlab.svg`);\n        case IdentityProviderBrand.Google:\n            return require(`../../../../res/img/element-icons/brands/google.svg`);\n        case IdentityProviderBrand.Twitter:\n            return require(`../../../../res/img/element-icons/brands/twitter.svg`);\n        default:\n            return null;\n    }\n}\n\nconst SSOButton: React.FC<ISSOButtonProps> = ({\n    matrixClient,\n    loginType,\n    fragmentAfterLogin,\n    idp,\n    primary,\n    mini,\n    ...props\n}) => {\n    const label = idp ? _t(\"Continue with %(provider)s\", { provider: idp.name }) : _t(\"Sign in with single sign-on\");\n\n    const onClick = () => {\n        PlatformPeg.get().startSingleSignOn(matrixClient, loginType, fragmentAfterLogin, idp?.id);\n    };\n\n    let icon;\n    let brandClass;\n    const brandIcon = idp ? getIcon(idp.brand) : null;\n    if (brandIcon) {\n        const brandName = idp.brand.split(\".\").pop();\n        brandClass = `mx_SSOButton_brand_${brandName}`;\n        icon = <img src={brandIcon} height=\"24\" width=\"24\" alt={brandName} />;\n    } else if (typeof idp?.icon === \"string\" && idp.icon.startsWith(\"mxc://\")) {\n        const src = mediaFromMxc(idp.icon, matrixClient).getSquareThumbnailHttp(24);\n        icon = <img src={src} height=\"24\" width=\"24\" alt={idp.name} />;\n    }\n\n    const classes = classNames(\"mx_SSOButton\", {\n        [brandClass]: brandClass,\n        mx_SSOButton_mini: mini,\n        mx_SSOButton_default: !idp,\n        mx_SSOButton_primary: primary,\n    });\n\n    if (mini) {\n        // TODO fallback icon\n        return (\n            <AccessibleTooltipButton {...props} title={label} className={classes} onClick={onClick}>\n                { icon }\n            </AccessibleTooltipButton>\n        );\n    }\n\n    return (\n        <AccessibleButton {...props} className={classes} onClick={onClick}>\n            { icon }\n            { label }\n        </AccessibleButton>\n    );\n};\n\ninterface IProps {\n    matrixClient: MatrixClient;\n    flow: ISSOFlow;\n    loginType?: \"sso\" | \"cas\";\n    fragmentAfterLogin?: string;\n    primary?: boolean;\n}\n\nconst MAX_PER_ROW = 6;\n\nconst SSOButtons: React.FC<IProps> = ({matrixClient, flow, loginType, fragmentAfterLogin, primary}) => {\n    const providers = flow[\"org.matrix.msc2858.identity_providers\"] || [];\n    if (providers.length < 2) {\n        return <div className=\"mx_SSOButtons\">\n            <SSOButton\n                matrixClient={matrixClient}\n                loginType={loginType}\n                fragmentAfterLogin={fragmentAfterLogin}\n                idp={providers[0]}\n                primary={primary}\n            />\n        </div>;\n    }\n\n    const rows = Math.ceil(providers.length / MAX_PER_ROW);\n    const size = Math.ceil(providers.length / rows);\n\n    return <div className=\"mx_SSOButtons\">\n        { chunk(providers, size).map(chunk => (\n            <div key={chunk[0].id} className=\"mx_SSOButtons_row\">\n                { chunk.map(idp => (\n                    <SSOButton\n                        key={idp.id}\n                        matrixClient={matrixClient}\n                        loginType={loginType}\n                        fragmentAfterLogin={fragmentAfterLogin}\n                        idp={idp}\n                        mini={true}\n                        primary={primary}\n                    />\n                )) }\n            </div>\n        )) }\n    </div>;\n};\n\nexport default SSOButtons;\n"]}