matrix-react-sdk
Version:
SDK for matrix.org using React
96 lines (93 loc) • 14.9 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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _compoundWeb = require("@vector-im/compound-web");
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _NotificationState = require("../../../stores/notifications/NotificationState");
var _languageHandler = require("../../../languageHandler");
var _NotificationLevel = require("../../../stores/notifications/NotificationLevel");
var _StatelessNotificationBadge = require("./NotificationBadge/StatelessNotificationBadge");
/*
Copyright 2024 New Vector Ltd.
Copyright 2020 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.
*/
class NotificationBadge extends _react.default.PureComponent {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "countWatcherRef", void 0);
(0, _defineProperty2.default)(this, "countPreferenceChanged", () => {
this.setState({
showCounts: _SettingsStore.default.getValue("Notifications.alwaysShowBadgeCounts", this.roomId)
});
});
(0, _defineProperty2.default)(this, "onNotificationUpdate", () => {
this.forceUpdate(); // notification state changed - update
});
this.props.notification.on(_NotificationState.NotificationStateEvents.Update, this.onNotificationUpdate);
this.state = {
showCounts: _SettingsStore.default.getValue("Notifications.alwaysShowBadgeCounts", this.roomId)
};
this.countWatcherRef = _SettingsStore.default.watchSetting("Notifications.alwaysShowBadgeCounts", this.roomId, this.countPreferenceChanged);
}
get roomId() {
// We should convert this to null for safety with the SettingsStore
return this.props.roomId || null;
}
componentWillUnmount() {
_SettingsStore.default.unwatchSetting(this.countWatcherRef);
this.props.notification.off(_NotificationState.NotificationStateEvents.Update, this.onNotificationUpdate);
}
componentDidUpdate(prevProps) {
if (prevProps.notification) {
prevProps.notification.off(_NotificationState.NotificationStateEvents.Update, this.onNotificationUpdate);
}
this.props.notification.on(_NotificationState.NotificationStateEvents.Update, this.onNotificationUpdate);
}
render() {
/* eslint @typescript-eslint/no-unused-vars: ["error", { "ignoreRestSiblings": true }] */
const {
notification,
showUnsentTooltip,
hideIfDot,
onClick,
tabIndex
} = this.props;
if (notification.isIdle && !notification.knocked) return null;
if (hideIfDot && notification.level < _NotificationLevel.NotificationLevel.Notification) {
// This would just be a dot and we've been told not to show dots, so don't show it
return null;
}
const commonProps = {
symbol: notification.symbol,
count: notification.count,
level: notification.level,
knocked: notification.knocked
};
let badge;
if (onClick) {
badge = /*#__PURE__*/_react.default.createElement(_StatelessNotificationBadge.StatelessNotificationBadge, (0, _extends2.default)({}, commonProps, {
onClick: onClick,
tabIndex: tabIndex
}));
} else {
badge = /*#__PURE__*/_react.default.createElement(_StatelessNotificationBadge.StatelessNotificationBadge, commonProps);
}
if (showUnsentTooltip && notification.level === _NotificationLevel.NotificationLevel.Unsent) {
return /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, {
label: (0, _languageHandler._t)("notifications|message_didnt_send"),
placement: "right"
}, badge);
}
return badge;
}
}
exports.default = NotificationBadge;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_compoundWeb","_SettingsStore","_NotificationState","_languageHandler","_NotificationLevel","_StatelessNotificationBadge","NotificationBadge","React","PureComponent","constructor","props","_defineProperty2","default","setState","showCounts","SettingsStore","getValue","roomId","forceUpdate","notification","on","NotificationStateEvents","Update","onNotificationUpdate","state","countWatcherRef","watchSetting","countPreferenceChanged","componentWillUnmount","unwatchSetting","off","componentDidUpdate","prevProps","render","showUnsentTooltip","hideIfDot","onClick","tabIndex","isIdle","knocked","level","NotificationLevel","Notification","commonProps","symbol","count","badge","createElement","StatelessNotificationBadge","_extends2","Unsent","Tooltip","label","_t","placement","exports"],"sources":["../../../../src/components/views/rooms/NotificationBadge.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 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 React, { ReactNode } from \"react\";\nimport { Tooltip } from \"@vector-im/compound-web\";\n\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { XOR } from \"../../../@types/common\";\nimport { NotificationState, NotificationStateEvents } from \"../../../stores/notifications/NotificationState\";\nimport { _t } from \"../../../languageHandler\";\nimport { NotificationLevel } from \"../../../stores/notifications/NotificationLevel\";\nimport { StatelessNotificationBadge } from \"./NotificationBadge/StatelessNotificationBadge\";\n\ninterface IProps {\n    notification: NotificationState;\n\n    /**\n     * If true, show nothing if the notification would only cause a dot to be shown rather than\n     * a badge. That is: only display badges and not dots. Default: false.\n     */\n    hideIfDot?: boolean;\n\n    /**\n     * The room ID, if any, the badge represents.\n     */\n    roomId?: string;\n}\n\ninterface IClickableProps extends IProps, React.InputHTMLAttributes<Element> {\n    showUnsentTooltip?: boolean;\n    /**\n     * If specified will return an AccessibleButton instead of a div.\n     */\n    onClick(ev: React.MouseEvent): void;\n}\n\ninterface IState {\n    showCounts: boolean; // whether to show counts.\n}\n\nexport default class NotificationBadge extends React.PureComponent<XOR<IProps, IClickableProps>, IState> {\n    private countWatcherRef: string;\n\n    public constructor(props: IProps) {\n        super(props);\n        this.props.notification.on(NotificationStateEvents.Update, this.onNotificationUpdate);\n\n        this.state = {\n            showCounts: SettingsStore.getValue(\"Notifications.alwaysShowBadgeCounts\", this.roomId),\n        };\n\n        this.countWatcherRef = SettingsStore.watchSetting(\n            \"Notifications.alwaysShowBadgeCounts\",\n            this.roomId,\n            this.countPreferenceChanged,\n        );\n    }\n\n    private get roomId(): string | null {\n        // We should convert this to null for safety with the SettingsStore\n        return this.props.roomId || null;\n    }\n\n    public componentWillUnmount(): void {\n        SettingsStore.unwatchSetting(this.countWatcherRef);\n        this.props.notification.off(NotificationStateEvents.Update, this.onNotificationUpdate);\n    }\n\n    public componentDidUpdate(prevProps: Readonly<IProps>): void {\n        if (prevProps.notification) {\n            prevProps.notification.off(NotificationStateEvents.Update, this.onNotificationUpdate);\n        }\n\n        this.props.notification.on(NotificationStateEvents.Update, this.onNotificationUpdate);\n    }\n\n    private countPreferenceChanged = (): void => {\n        this.setState({ showCounts: SettingsStore.getValue(\"Notifications.alwaysShowBadgeCounts\", this.roomId) });\n    };\n\n    private onNotificationUpdate = (): void => {\n        this.forceUpdate(); // notification state changed - update\n    };\n\n    public render(): ReactNode {\n        /* eslint @typescript-eslint/no-unused-vars: [\"error\", { \"ignoreRestSiblings\": true }] */\n        const { notification, showUnsentTooltip, hideIfDot, onClick, tabIndex } = this.props;\n\n        if (notification.isIdle && !notification.knocked) return null;\n        if (hideIfDot && notification.level < NotificationLevel.Notification) {\n            // This would just be a dot and we've been told not to show dots, so don't show it\n            return null;\n        }\n\n        const commonProps: React.ComponentProps<typeof StatelessNotificationBadge> = {\n            symbol: notification.symbol,\n            count: notification.count,\n            level: notification.level,\n            knocked: notification.knocked,\n        };\n\n        let badge: JSX.Element;\n        if (onClick) {\n            badge = <StatelessNotificationBadge {...commonProps} onClick={onClick} tabIndex={tabIndex} />;\n        } else {\n            badge = <StatelessNotificationBadge {...commonProps} />;\n        }\n\n        if (showUnsentTooltip && notification.level === NotificationLevel.Unsent) {\n            return (\n                <Tooltip label={_t(\"notifications|message_didnt_send\")} placement=\"right\">\n                    {badge}\n                </Tooltip>\n            );\n        }\n\n        return badge;\n    }\n}\n"],"mappings":";;;;;;;;;AAQA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AAEA,IAAAE,cAAA,GAAAH,sBAAA,CAAAC,OAAA;AAEA,IAAAG,kBAAA,GAAAH,OAAA;AACA,IAAAI,gBAAA,GAAAJ,OAAA;AACA,IAAAK,kBAAA,GAAAL,OAAA;AACA,IAAAM,2BAAA,GAAAN,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;;AAuCe,MAAMO,iBAAiB,SAASC,cAAK,CAACC,aAAa,CAAuC;EAG9FC,WAAWA,CAACC,KAAa,EAAE;IAC9B,KAAK,CAACA,KAAK,CAAC;IAAC,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,kCAgCgB,MAAY;MACzC,IAAI,CAACC,QAAQ,CAAC;QAAEC,UAAU,EAAEC,sBAAa,CAACC,QAAQ,CAAC,qCAAqC,EAAE,IAAI,CAACC,MAAM;MAAE,CAAC,CAAC;IAC7G,CAAC;IAAA,IAAAN,gBAAA,CAAAC,OAAA,gCAE8B,MAAY;MACvC,IAAI,CAACM,WAAW,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IArCG,IAAI,CAACR,KAAK,CAACS,YAAY,CAACC,EAAE,CAACC,0CAAuB,CAACC,MAAM,EAAE,IAAI,CAACC,oBAAoB,CAAC;IAErF,IAAI,CAACC,KAAK,GAAG;MACTV,UAAU,EAAEC,sBAAa,CAACC,QAAQ,CAAC,qCAAqC,EAAE,IAAI,CAACC,MAAM;IACzF,CAAC;IAED,IAAI,CAACQ,eAAe,GAAGV,sBAAa,CAACW,YAAY,CAC7C,qCAAqC,EACrC,IAAI,CAACT,MAAM,EACX,IAAI,CAACU,sBACT,CAAC;EACL;EAEA,IAAYV,MAAMA,CAAA,EAAkB;IAChC;IACA,OAAO,IAAI,CAACP,KAAK,CAACO,MAAM,IAAI,IAAI;EACpC;EAEOW,oBAAoBA,CAAA,EAAS;IAChCb,sBAAa,CAACc,cAAc,CAAC,IAAI,CAACJ,eAAe,CAAC;IAClD,IAAI,CAACf,KAAK,CAACS,YAAY,CAACW,GAAG,CAACT,0CAAuB,CAACC,MAAM,EAAE,IAAI,CAACC,oBAAoB,CAAC;EAC1F;EAEOQ,kBAAkBA,CAACC,SAA2B,EAAQ;IACzD,IAAIA,SAAS,CAACb,YAAY,EAAE;MACxBa,SAAS,CAACb,YAAY,CAACW,GAAG,CAACT,0CAAuB,CAACC,MAAM,EAAE,IAAI,CAACC,oBAAoB,CAAC;IACzF;IAEA,IAAI,CAACb,KAAK,CAACS,YAAY,CAACC,EAAE,CAACC,0CAAuB,CAACC,MAAM,EAAE,IAAI,CAACC,oBAAoB,CAAC;EACzF;EAUOU,MAAMA,CAAA,EAAc;IACvB;IACA,MAAM;MAAEd,YAAY;MAAEe,iBAAiB;MAAEC,SAAS;MAAEC,OAAO;MAAEC;IAAS,CAAC,GAAG,IAAI,CAAC3B,KAAK;IAEpF,IAAIS,YAAY,CAACmB,MAAM,IAAI,CAACnB,YAAY,CAACoB,OAAO,EAAE,OAAO,IAAI;IAC7D,IAAIJ,SAAS,IAAIhB,YAAY,CAACqB,KAAK,GAAGC,oCAAiB,CAACC,YAAY,EAAE;MAClE;MACA,OAAO,IAAI;IACf;IAEA,MAAMC,WAAoE,GAAG;MACzEC,MAAM,EAAEzB,YAAY,CAACyB,MAAM;MAC3BC,KAAK,EAAE1B,YAAY,CAAC0B,KAAK;MACzBL,KAAK,EAAErB,YAAY,CAACqB,KAAK;MACzBD,OAAO,EAAEpB,YAAY,CAACoB;IAC1B,CAAC;IAED,IAAIO,KAAkB;IACtB,IAAIV,OAAO,EAAE;MACTU,KAAK,gBAAGjD,MAAA,CAAAe,OAAA,CAAAmC,aAAA,CAAC1C,2BAAA,CAAA2C,0BAA0B,MAAAC,SAAA,CAAArC,OAAA,MAAK+B,WAAW;QAAEP,OAAO,EAAEA,OAAQ;QAACC,QAAQ,EAAEA;MAAS,EAAE,CAAC;IACjG,CAAC,MAAM;MACHS,KAAK,gBAAGjD,MAAA,CAAAe,OAAA,CAAAmC,aAAA,CAAC1C,2BAAA,CAAA2C,0BAA0B,EAAKL,WAAc,CAAC;IAC3D;IAEA,IAAIT,iBAAiB,IAAIf,YAAY,CAACqB,KAAK,KAAKC,oCAAiB,CAACS,MAAM,EAAE;MACtE,oBACIrD,MAAA,CAAAe,OAAA,CAAAmC,aAAA,CAAC/C,YAAA,CAAAmD,OAAO;QAACC,KAAK,EAAE,IAAAC,mBAAE,EAAC,kCAAkC,CAAE;QAACC,SAAS,EAAC;MAAO,GACpER,KACI,CAAC;IAElB;IAEA,OAAOA,KAAK;EAChB;AACJ;AAACS,OAAA,CAAA3C,OAAA,GAAAN,iBAAA","ignoreList":[]}