matrix-react-sdk
Version:
SDK for matrix.org using React
126 lines (102 loc) • 12.7 kB
JavaScript
;
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 _CustomRoomTagStore = _interopRequireDefault(require("../../stores/CustomRoomTagStore"));
var _AutoHideScrollbar = _interopRequireDefault(require("./AutoHideScrollbar"));
var sdk = _interopRequireWildcard(require("../../index"));
var _dispatcher = _interopRequireDefault(require("../../dispatcher/dispatcher"));
var _classnames = _interopRequireDefault(require("classnames"));
var FormattingUtils = _interopRequireWildcard(require("../../utils/FormattingUtils"));
var _replaceableComponent = require("../../utils/replaceableComponent");
var _dec, _class;
let CustomRoomTagPanel = (_dec = (0, _replaceableComponent.replaceableComponent)("structures.CustomRoomTagPanel"), _dec(_class = class CustomRoomTagPanel extends _react.default.Component {
constructor(props) {
super(props);
this.state = {
tags: _CustomRoomTagStore.default.getSortedTags()
};
}
componentDidMount() {
this._tagStoreToken = _CustomRoomTagStore.default.addListener(() => {
this.setState({
tags: _CustomRoomTagStore.default.getSortedTags()
});
});
}
componentWillUnmount() {
if (this._tagStoreToken) {
this._tagStoreToken.remove();
}
}
render() {
const tags = this.state.tags.map(tag => {
return /*#__PURE__*/_react.default.createElement(CustomRoomTagTile, {
tag: tag,
key: tag.name
});
});
const classes = (0, _classnames.default)('mx_CustomRoomTagPanel', {
mx_CustomRoomTagPanel_empty: this.state.tags.length === 0
});
return /*#__PURE__*/_react.default.createElement("div", {
className: classes
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CustomRoomTagPanel_divider"
}), /*#__PURE__*/_react.default.createElement(_AutoHideScrollbar.default, {
className: "mx_CustomRoomTagPanel_scroller"
}, tags));
}
}) || _class);
class CustomRoomTagTile extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onClick", () => {
_dispatcher.default.dispatch({
action: 'select_custom_room_tag',
tag: this.props.tag.name
});
});
}
render() {
const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');
const AccessibleTooltipButton = sdk.getComponent('elements.AccessibleTooltipButton');
const tag = this.props.tag;
const avatarHeight = 40;
const className = (0, _classnames.default)({
"CustomRoomTagPanel_tileSelected": tag.selected
});
const name = tag.name;
const badgeNotifState = tag.badgeNotifState;
let badgeElement;
if (badgeNotifState) {
const badgeClasses = (0, _classnames.default)({
"mx_TagTile_badge": true,
"mx_TagTile_badgeHighlight": badgeNotifState.hasMentions
});
badgeElement = /*#__PURE__*/_react.default.createElement("div", {
className: badgeClasses
}, FormattingUtils.formatCount(badgeNotifState.count));
}
return /*#__PURE__*/_react.default.createElement(AccessibleTooltipButton, {
className: className,
onClick: this.onClick,
title: name
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TagTile_avatar"
}, /*#__PURE__*/_react.default.createElement(BaseAvatar, {
name: tag.avatarLetter,
idName: name,
width: avatarHeight,
height: avatarHeight
}), badgeElement));
}
}
var _default = CustomRoomTagPanel;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/structures/CustomRoomTagPanel.js"],"names":["CustomRoomTagPanel","React","Component","constructor","props","state","tags","CustomRoomTagStore","getSortedTags","componentDidMount","_tagStoreToken","addListener","setState","componentWillUnmount","remove","render","map","tag","name","classes","mx_CustomRoomTagPanel_empty","length","CustomRoomTagTile","dis","dispatch","action","BaseAvatar","sdk","getComponent","AccessibleTooltipButton","avatarHeight","className","selected","badgeNotifState","badgeElement","badgeClasses","hasMentions","FormattingUtils","formatCount","count","onClick","avatarLetter"],"mappings":";;;;;;;;;;;;;AAgBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;IAGMA,kB,WADL,gDAAqB,+BAArB,C,gBAAD,MACMA,kBADN,SACiCC,eAAMC,SADvC,CACiD;AAC7CC,EAAAA,WAAW,CAACC,KAAD,EAAQ;AACf,UAAMA,KAAN;AACA,SAAKC,KAAL,GAAa;AACTC,MAAAA,IAAI,EAAEC,4BAAmBC,aAAnB;AADG,KAAb;AAGH;;AAEDC,EAAAA,iBAAiB,GAAG;AAChB,SAAKC,cAAL,GAAsBH,4BAAmBI,WAAnB,CAA+B,MAAM;AACvD,WAAKC,QAAL,CAAc;AAACN,QAAAA,IAAI,EAAEC,4BAAmBC,aAAnB;AAAP,OAAd;AACH,KAFqB,CAAtB;AAGH;;AAEDK,EAAAA,oBAAoB,GAAG;AACnB,QAAI,KAAKH,cAAT,EAAyB;AACrB,WAAKA,cAAL,CAAoBI,MAApB;AACH;AACJ;;AAEDC,EAAAA,MAAM,GAAG;AACL,UAAMT,IAAI,GAAG,KAAKD,KAAL,CAAWC,IAAX,CAAgBU,GAAhB,CAAqBC,GAAD,IAAS;AACtC,0BAAQ,6BAAC,iBAAD;AAAmB,QAAA,GAAG,EAAEA,GAAxB;AAA6B,QAAA,GAAG,EAAEA,GAAG,CAACC;AAAtC,QAAR;AACH,KAFY,CAAb;AAIA,UAAMC,OAAO,GAAG,yBAAW,uBAAX,EAAoC;AAChDC,MAAAA,2BAA2B,EAAE,KAAKf,KAAL,CAAWC,IAAX,CAAgBe,MAAhB,KAA2B;AADR,KAApC,CAAhB;AAIA,wBAAQ;AAAK,MAAA,SAAS,EAAEF;AAAhB,oBACJ;AAAK,MAAA,SAAS,EAAC;AAAf,MADI,eAEJ,6BAAC,0BAAD;AAAmB,MAAA,SAAS,EAAC;AAA7B,OACKb,IADL,CAFI,CAAR;AAMH;;AAnC4C,C;;AAsCjD,MAAMgB,iBAAN,SAAgCrB,eAAMC,SAAtC,CAAgD;AAAA;AAAA;AAAA,mDAClC,MAAM;AACZqB,0BAAIC,QAAJ,CAAa;AAACC,QAAAA,MAAM,EAAE,wBAAT;AAAmCR,QAAAA,GAAG,EAAE,KAAKb,KAAL,CAAWa,GAAX,CAAeC;AAAvD,OAAb;AACH,KAH2C;AAAA;;AAK5CH,EAAAA,MAAM,GAAG;AACL,UAAMW,UAAU,GAAGC,GAAG,CAACC,YAAJ,CAAiB,oBAAjB,CAAnB;AACA,UAAMC,uBAAuB,GAAGF,GAAG,CAACC,YAAJ,CAAiB,kCAAjB,CAAhC;AAEA,UAAMX,GAAG,GAAG,KAAKb,KAAL,CAAWa,GAAvB;AACA,UAAMa,YAAY,GAAG,EAArB;AACA,UAAMC,SAAS,GAAG,yBAAW;AACzB,yCAAmCd,GAAG,CAACe;AADd,KAAX,CAAlB;AAGA,UAAMd,IAAI,GAAGD,GAAG,CAACC,IAAjB;AACA,UAAMe,eAAe,GAAGhB,GAAG,CAACgB,eAA5B;AACA,QAAIC,YAAJ;;AACA,QAAID,eAAJ,EAAqB;AACjB,YAAME,YAAY,GAAG,yBAAW;AAC5B,4BAAoB,IADQ;AAE5B,qCAA6BF,eAAe,CAACG;AAFjB,OAAX,CAArB;AAIAF,MAAAA,YAAY,gBAAI;AAAK,QAAA,SAAS,EAAEC;AAAhB,SAA+BE,eAAe,CAACC,WAAhB,CAA4BL,eAAe,CAACM,KAA5C,CAA/B,CAAhB;AACH;;AAED,wBACI,6BAAC,uBAAD;AAAyB,MAAA,SAAS,EAAER,SAApC;AAA+C,MAAA,OAAO,EAAE,KAAKS,OAA7D;AAAsE,MAAA,KAAK,EAAEtB;AAA7E,oBACI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI,6BAAC,UAAD;AACI,MAAA,IAAI,EAAED,GAAG,CAACwB,YADd;AAEI,MAAA,MAAM,EAAEvB,IAFZ;AAGI,MAAA,KAAK,EAAEY,YAHX;AAII,MAAA,MAAM,EAAEA;AAJZ,MADJ,EAOMI,YAPN,CADJ,CADJ;AAaH;;AAtC2C;;eAyCjClC,kB","sourcesContent":["/*\nCopyright 2019 New Vector Ltd.\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 CustomRoomTagStore from '../../stores/CustomRoomTagStore';\nimport AutoHideScrollbar from './AutoHideScrollbar';\nimport * as sdk from '../../index';\nimport dis from '../../dispatcher/dispatcher';\nimport classNames from 'classnames';\nimport * as FormattingUtils from '../../utils/FormattingUtils';\nimport {replaceableComponent} from \"../../utils/replaceableComponent\";\n\n@replaceableComponent(\"structures.CustomRoomTagPanel\")\nclass CustomRoomTagPanel extends React.Component {\n    constructor(props) {\n        super(props);\n        this.state = {\n            tags: CustomRoomTagStore.getSortedTags(),\n        };\n    }\n\n    componentDidMount() {\n        this._tagStoreToken = CustomRoomTagStore.addListener(() => {\n            this.setState({tags: CustomRoomTagStore.getSortedTags()});\n        });\n    }\n\n    componentWillUnmount() {\n        if (this._tagStoreToken) {\n            this._tagStoreToken.remove();\n        }\n    }\n\n    render() {\n        const tags = this.state.tags.map((tag) => {\n            return (<CustomRoomTagTile tag={tag} key={tag.name} />);\n        });\n\n        const classes = classNames('mx_CustomRoomTagPanel', {\n            mx_CustomRoomTagPanel_empty: this.state.tags.length === 0,\n        });\n\n        return (<div className={classes}>\n            <div className=\"mx_CustomRoomTagPanel_divider\" />\n            <AutoHideScrollbar className=\"mx_CustomRoomTagPanel_scroller\">\n                {tags}\n            </AutoHideScrollbar>\n        </div>);\n    }\n}\n\nclass CustomRoomTagTile extends React.Component {\n    onClick = () => {\n        dis.dispatch({action: 'select_custom_room_tag', tag: this.props.tag.name});\n    };\n\n    render() {\n        const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');\n        const AccessibleTooltipButton = sdk.getComponent('elements.AccessibleTooltipButton');\n\n        const tag = this.props.tag;\n        const avatarHeight = 40;\n        const className = classNames({\n            \"CustomRoomTagPanel_tileSelected\": tag.selected,\n        });\n        const name = tag.name;\n        const badgeNotifState = tag.badgeNotifState;\n        let badgeElement;\n        if (badgeNotifState) {\n            const badgeClasses = classNames({\n                \"mx_TagTile_badge\": true,\n                \"mx_TagTile_badgeHighlight\": badgeNotifState.hasMentions,\n            });\n            badgeElement = (<div className={badgeClasses}>{FormattingUtils.formatCount(badgeNotifState.count)}</div>);\n        }\n\n        return (\n            <AccessibleTooltipButton className={className} onClick={this.onClick} title={name}>\n                <div className=\"mx_TagTile_avatar\">\n                    <BaseAvatar\n                        name={tag.avatarLetter}\n                        idName={name}\n                        width={avatarHeight}\n                        height={avatarHeight}\n                    />\n                    { badgeElement }\n                </div>\n            </AccessibleTooltipButton>\n        );\n    }\n}\n\nexport default CustomRoomTagPanel;\n"]}