matrix-react-sdk
Version:
SDK for matrix.org using React
172 lines (144 loc) • 19 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _IntegrationManagers = require("../../../integrations/IntegrationManagers");
var _room = require("matrix-js-sdk/src/models/room");
var sdk = _interopRequireWildcard(require("../../../index"));
var _Terms = require("../../../Terms");
var _classnames = _interopRequireDefault(require("classnames"));
var ScalarMessaging = _interopRequireWildcard(require("../../../ScalarMessaging"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _class2, _temp;
let TabbedIntegrationManagerDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.TabbedIntegrationManagerDialog"), _dec(_class = (_temp = _class2 = class TabbedIntegrationManagerDialog extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "openManager", async (i
/*: number*/
, force = false) => {
if (i === this.state.currentIndex && !force) return;
const manager = this.state.managers[i];
const client = manager.getScalarClient();
this.setState({
busy: true,
currentIndex: i,
currentLoading: true,
currentConnected: false,
currentScalarClient: client
});
ScalarMessaging.setOpenManagerUrl(manager.uiUrl);
client.setTermsInteractionCallback((policyInfo, agreedUrls) => {
// To avoid visual glitching of two modals stacking briefly, we customise the
// terms dialog sizing when it will appear for the integration manager so that
// it gets the same basic size as the IM's own modal.
return (0, _Terms.dialogTermsInteractionCallback)(policyInfo, agreedUrls, 'mx_TermsDialog_forIntegrationManager');
});
try {
await client.connect();
if (!client.hasCredentials()) {
this.setState({
busy: false,
currentLoading: false,
currentConnected: false
});
} else {
this.setState({
busy: false,
currentLoading: false,
currentConnected: true
});
}
} catch (e) {
if (e instanceof _Terms.TermsNotSignedError) {
return;
}
console.error(e);
this.setState({
busy: false,
currentLoading: false,
currentConnected: false
});
}
});
this.state = {
managers: _IntegrationManagers.IntegrationManagers.sharedInstance().getOrderedManagers(),
busy: true,
currentIndex: 0,
currentConnected: false,
currentLoading: true,
currentScalarClient: null
};
}
componentDidMount()
/*: void*/
{
this.openManager(0, true);
}
_renderTabs() {
const AccessibleButton = sdk.getComponent("views.elements.AccessibleButton");
return this.state.managers.map((m, i) => {
const classes = (0, _classnames.default)({
'mx_TabbedIntegrationManagerDialog_tab': true,
'mx_TabbedIntegrationManagerDialog_currentTab': this.state.currentIndex === i
});
return /*#__PURE__*/_react.default.createElement(AccessibleButton, {
className: classes,
onClick: () => this.openManager(i),
key: `tab_${i}`,
disabled: this.state.busy
}, m.name);
});
}
_renderTab() {
const IntegrationManager = sdk.getComponent("views.settings.IntegrationManager");
let uiUrl = null;
if (this.state.currentScalarClient) {
uiUrl = this.state.currentScalarClient.getScalarInterfaceUrlForRoom(this.props.room, this.props.screen, this.props.integrationId);
}
return /*#__PURE__*/_react.default.createElement(IntegrationManager, {
configured: true,
loading: this.state.currentLoading,
connected: this.state.currentConnected,
url: uiUrl,
onFinished: () => {
/* no-op */
}
});
}
render() {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TabbedIntegrationManagerDialog_container"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TabbedIntegrationManagerDialog_tabs"
}, this._renderTabs()), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TabbedIntegrationManagerDialog_currentManager"
}, this._renderTab()));
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
/**
* Called with:
* * success {bool} True if the user accepted any douments, false if cancelled
* * agreedUrls {string[]} List of agreed URLs
*/
onFinished: _propTypes.default.func.isRequired,
/**
* Optional room where the integration manager should be open to
*/
room: _propTypes.default.instanceOf(_room.Room),
/**
* Optional screen to open on the integration manager
*/
screen: _propTypes.default.string,
/**
* Optional integration ID to open in the integration manager
*/
integrationId: _propTypes.default.string
}), _temp)) || _class);
exports.default = TabbedIntegrationManagerDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/TabbedIntegrationManagerDialog.js"],"names":["TabbedIntegrationManagerDialog","React","Component","constructor","props","i","force","state","currentIndex","manager","managers","client","getScalarClient","setState","busy","currentLoading","currentConnected","currentScalarClient","ScalarMessaging","setOpenManagerUrl","uiUrl","setTermsInteractionCallback","policyInfo","agreedUrls","connect","hasCredentials","e","TermsNotSignedError","console","error","IntegrationManagers","sharedInstance","getOrderedManagers","componentDidMount","openManager","_renderTabs","AccessibleButton","sdk","getComponent","map","m","classes","name","_renderTab","IntegrationManager","getScalarInterfaceUrlForRoom","room","screen","integrationId","render","onFinished","PropTypes","func","isRequired","instanceOf","Room","string"],"mappings":"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","sourcesContent":["/*\nCopyright 2019 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 PropTypes from 'prop-types';\nimport {IntegrationManagers} from \"../../../integrations/IntegrationManagers\";\nimport {Room} from \"matrix-js-sdk/src/models/room\";\nimport * as sdk from '../../../index';\nimport {dialogTermsInteractionCallback, TermsNotSignedError} from \"../../../Terms\";\nimport classNames from 'classnames';\nimport * as ScalarMessaging from \"../../../ScalarMessaging\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.dialogs.TabbedIntegrationManagerDialog\")\nexport default class TabbedIntegrationManagerDialog extends React.Component {\n    static propTypes = {\n        /**\n         * Called with:\n         *     * success {bool} True if the user accepted any douments, false if cancelled\n         *     * agreedUrls {string[]} List of agreed URLs\n         */\n        onFinished: PropTypes.func.isRequired,\n\n        /**\n         * Optional room where the integration manager should be open to\n         */\n        room: PropTypes.instanceOf(Room),\n\n        /**\n         * Optional screen to open on the integration manager\n         */\n        screen: PropTypes.string,\n\n        /**\n         * Optional integration ID to open in the integration manager\n         */\n        integrationId: PropTypes.string,\n    };\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            managers: IntegrationManagers.sharedInstance().getOrderedManagers(),\n            busy: true,\n            currentIndex: 0,\n            currentConnected: false,\n            currentLoading: true,\n            currentScalarClient: null,\n        };\n    }\n\n    componentDidMount(): void {\n        this.openManager(0, true);\n    }\n\n    openManager = async (i: number, force = false) => {\n        if (i === this.state.currentIndex && !force) return;\n\n        const manager = this.state.managers[i];\n        const client = manager.getScalarClient();\n        this.setState({\n            busy: true,\n            currentIndex: i,\n            currentLoading: true,\n            currentConnected: false,\n            currentScalarClient: client,\n        });\n\n        ScalarMessaging.setOpenManagerUrl(manager.uiUrl);\n\n        client.setTermsInteractionCallback((policyInfo, agreedUrls) => {\n            // To avoid visual glitching of two modals stacking briefly, we customise the\n            // terms dialog sizing when it will appear for the integration manager so that\n            // it gets the same basic size as the IM's own modal.\n            return dialogTermsInteractionCallback(\n                policyInfo, agreedUrls, 'mx_TermsDialog_forIntegrationManager',\n            );\n        });\n\n        try {\n            await client.connect();\n            if (!client.hasCredentials()) {\n                this.setState({\n                    busy: false,\n                    currentLoading: false,\n                    currentConnected: false,\n                });\n            } else {\n                this.setState({\n                    busy: false,\n                    currentLoading: false,\n                    currentConnected: true,\n                });\n            }\n        } catch (e) {\n            if (e instanceof TermsNotSignedError) {\n                return;\n            }\n\n            console.error(e);\n            this.setState({\n                busy: false,\n                currentLoading: false,\n                currentConnected: false,\n            });\n        }\n    };\n\n    _renderTabs() {\n        const AccessibleButton = sdk.getComponent(\"views.elements.AccessibleButton\");\n        return this.state.managers.map((m, i) => {\n            const classes = classNames({\n                'mx_TabbedIntegrationManagerDialog_tab': true,\n                'mx_TabbedIntegrationManagerDialog_currentTab': this.state.currentIndex === i,\n            });\n            return (\n                <AccessibleButton\n                    className={classes}\n                    onClick={() => this.openManager(i)}\n                    key={`tab_${i}`}\n                    disabled={this.state.busy}\n                >\n                    {m.name}\n                </AccessibleButton>\n            );\n        });\n    }\n\n    _renderTab() {\n        const IntegrationManager = sdk.getComponent(\"views.settings.IntegrationManager\");\n        let uiUrl = null;\n        if (this.state.currentScalarClient) {\n            uiUrl = this.state.currentScalarClient.getScalarInterfaceUrlForRoom(\n                this.props.room,\n                this.props.screen,\n                this.props.integrationId,\n            );\n        }\n        return <IntegrationManager\n            configured={true}\n            loading={this.state.currentLoading}\n            connected={this.state.currentConnected}\n            url={uiUrl}\n            onFinished={() => {/* no-op */}}\n        />;\n    }\n\n    render() {\n        return (\n            <div className='mx_TabbedIntegrationManagerDialog_container'>\n                <div className='mx_TabbedIntegrationManagerDialog_tabs'>\n                    {this._renderTabs()}\n                </div>\n                <div className='mx_TabbedIntegrationManagerDialog_currentManager'>\n                    {this._renderTab()}\n                </div>\n            </div>\n        );\n    }\n}\n"]}