matrix-react-sdk
Version:
SDK for matrix.org using React
77 lines (74 loc) • 13.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.UserOnboardingButton = UserOnboardingButton;
var _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireWildcard(require("react"));
var _actions = require("../../../dispatcher/actions");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _useSettings = require("../../../hooks/useSettings");
var _languageHandler = require("../../../languageHandler");
var _PosthogTrackers = _interopRequireDefault(require("../../../PosthogTrackers"));
var _SettingLevel = require("../../../settings/SettingLevel");
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _AccessibleButton = _interopRequireDefault(require("../../views/elements/AccessibleButton"));
var _Heading = _interopRequireDefault(require("../../views/typography/Heading"));
var _UserOnboardingPage = require("./UserOnboardingPage");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2022 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
function UserOnboardingButton({
selected,
minimized
}) {
const useCase = (0, _useSettings.useSettingValue)("FTUE.useCaseSelection");
const visible = (0, _useSettings.useSettingValue)("FTUE.userOnboardingButton");
if (!visible || minimized || !(0, _UserOnboardingPage.showUserOnboardingPage)(useCase)) {
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
}
return /*#__PURE__*/_react.default.createElement(UserOnboardingButtonInternal, {
selected: selected,
minimized: minimized
});
}
function UserOnboardingButtonInternal({
selected,
minimized
}) {
const onDismiss = (0, _react.useCallback)(ev => {
ev.preventDefault();
ev.stopPropagation();
_PosthogTrackers.default.trackInteraction("WebRoomListUserOnboardingIgnoreButton", ev);
_SettingsStore.default.setValue("FTUE.userOnboardingButton", null, _SettingLevel.SettingLevel.ACCOUNT, false);
}, []);
const onClick = (0, _react.useCallback)(ev => {
ev.preventDefault();
ev.stopPropagation();
_PosthogTrackers.default.trackInteraction("WebRoomListUserOnboardingButton", ev);
_dispatcher.default.fire(_actions.Action.ViewHomePage);
}, []);
return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: (0, _classnames.default)("mx_UserOnboardingButton", {
mx_UserOnboardingButton_selected: selected,
mx_UserOnboardingButton_minimized: minimized
}),
onClick: onClick
}, !minimized && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_UserOnboardingButton_content"
}, /*#__PURE__*/_react.default.createElement(_Heading.default, {
size: "4",
className: "mx_Heading_h4"
}, (0, _languageHandler._t)("common|welcome")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_UserOnboardingButton_close",
onClick: onDismiss,
"aria-label": (0, _languageHandler._t)("action|dismiss")
}))));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_classnames","_interopRequireDefault","require","_react","_interopRequireWildcard","_actions","_dispatcher","_useSettings","_languageHandler","_PosthogTrackers","_SettingLevel","_SettingsStore","_AccessibleButton","_Heading","_UserOnboardingPage","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","UserOnboardingButton","selected","minimized","useCase","useSettingValue","visible","showUserOnboardingPage","createElement","Fragment","UserOnboardingButtonInternal","onDismiss","useCallback","ev","preventDefault","stopPropagation","PosthogTrackers","trackInteraction","SettingsStore","setValue","SettingLevel","ACCOUNT","onClick","defaultDispatcher","fire","Action","ViewHomePage","className","classNames","mx_UserOnboardingButton_selected","mx_UserOnboardingButton_minimized","size","_t"],"sources":["../../../../src/components/views/user-onboarding/UserOnboardingButton.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport classNames from \"classnames\";\nimport React, { useCallback } from \"react\";\n\nimport { Action } from \"../../../dispatcher/actions\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport { useSettingValue } from \"../../../hooks/useSettings\";\nimport { _t } from \"../../../languageHandler\";\nimport PosthogTrackers from \"../../../PosthogTrackers\";\nimport { UseCase } from \"../../../settings/enums/UseCase\";\nimport { SettingLevel } from \"../../../settings/SettingLevel\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport AccessibleButton, { ButtonEvent } from \"../../views/elements/AccessibleButton\";\nimport Heading from \"../../views/typography/Heading\";\nimport { showUserOnboardingPage } from \"./UserOnboardingPage\";\n\ninterface Props {\n    selected: boolean;\n    minimized: boolean;\n}\n\nexport function UserOnboardingButton({ selected, minimized }: Props): JSX.Element {\n    const useCase = useSettingValue<UseCase | null>(\"FTUE.useCaseSelection\");\n    const visible = useSettingValue<boolean>(\"FTUE.userOnboardingButton\");\n\n    if (!visible || minimized || !showUserOnboardingPage(useCase)) {\n        return <></>;\n    }\n\n    return <UserOnboardingButtonInternal selected={selected} minimized={minimized} />;\n}\n\nfunction UserOnboardingButtonInternal({ selected, minimized }: Props): JSX.Element {\n    const onDismiss = useCallback((ev: ButtonEvent) => {\n        ev.preventDefault();\n        ev.stopPropagation();\n\n        PosthogTrackers.trackInteraction(\"WebRoomListUserOnboardingIgnoreButton\", ev);\n        SettingsStore.setValue(\"FTUE.userOnboardingButton\", null, SettingLevel.ACCOUNT, false);\n    }, []);\n\n    const onClick = useCallback((ev: ButtonEvent) => {\n        ev.preventDefault();\n        ev.stopPropagation();\n\n        PosthogTrackers.trackInteraction(\"WebRoomListUserOnboardingButton\", ev);\n        defaultDispatcher.fire(Action.ViewHomePage);\n    }, []);\n\n    return (\n        <AccessibleButton\n            className={classNames(\"mx_UserOnboardingButton\", {\n                mx_UserOnboardingButton_selected: selected,\n                mx_UserOnboardingButton_minimized: minimized,\n            })}\n            onClick={onClick}\n        >\n            {!minimized && (\n                <>\n                    <div className=\"mx_UserOnboardingButton_content\">\n                        <Heading size=\"4\" className=\"mx_Heading_h4\">\n                            {_t(\"common|welcome\")}\n                        </Heading>\n                        <AccessibleButton\n                            className=\"mx_UserOnboardingButton_close\"\n                            onClick={onDismiss}\n                            aria-label={_t(\"action|dismiss\")}\n                        />\n                    </div>\n                </>\n            )}\n        </AccessibleButton>\n    );\n}\n"],"mappings":"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","ignoreList":[]}