matrix-react-sdk
Version:
SDK for matrix.org using React
121 lines (117 loc) • 19.1 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PollHistoryList = void 0;
var _react = _interopRequireDefault(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _languageHandler = require("../../../../languageHandler");
var _FilterTabGroup = require("../../elements/FilterTabGroup");
var _InlineSpinner = _interopRequireDefault(require("../../elements/InlineSpinner"));
var _PollListItem = require("./PollListItem");
var _PollListItemEnded = require("./PollListItemEnded");
var _AccessibleButton = _interopRequireDefault(require("../../elements/AccessibleButton"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2023 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.
*/
const LoadingPolls = ({
noResultsYet
}) => /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)("mx_PollHistoryList_loading", {
mx_PollHistoryList_noResultsYet: noResultsYet
})
}, /*#__PURE__*/_react.default.createElement(_InlineSpinner.default, null), (0, _languageHandler._t)("right_panel|poll|loading"));
const LoadMorePolls = ({
isLoading,
loadMorePolls
}) => loadMorePolls ? /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_PollHistoryList_loadMorePolls",
kind: "link_inline",
onClick: () => loadMorePolls()
}, (0, _languageHandler._t)("right_panel|poll|load_more"), isLoading && /*#__PURE__*/_react.default.createElement(_InlineSpinner.default, null)) : null;
const ONE_DAY_MS = 60000 * 60 * 24;
const getNoResultsMessage = (filter, oldestEventTimestamp, loadMorePolls) => {
if (!loadMorePolls) {
return filter === "ACTIVE" ? (0, _languageHandler._t)("right_panel|poll|empty_active") : (0, _languageHandler._t)("right_panel|poll|empty_past");
}
// we don't know how much history has been fetched
if (!oldestEventTimestamp) {
return filter === "ACTIVE" ? (0, _languageHandler._t)("right_panel|poll|empty_active_load_more") : (0, _languageHandler._t)("right_panel|poll|empty_past_load_more");
}
const fetchedHistoryDaysCount = Math.ceil((Date.now() - oldestEventTimestamp) / ONE_DAY_MS);
return filter === "ACTIVE" ? (0, _languageHandler._t)("right_panel|poll|empty_active_load_more_n_days", {
count: fetchedHistoryDaysCount
}) : (0, _languageHandler._t)("right_panel|poll|empty_past_load_more_n_days", {
count: fetchedHistoryDaysCount
});
};
const NoResults = ({
filter,
isLoading,
oldestFetchedEventTimestamp,
loadMorePolls
}) => {
// we can't page the timeline anymore
// just use plain loader
if (!loadMorePolls && isLoading) {
return /*#__PURE__*/_react.default.createElement(LoadingPolls, {
noResultsYet: true
});
}
return /*#__PURE__*/_react.default.createElement("span", {
className: "mx_PollHistoryList_noResults"
}, getNoResultsMessage(filter, oldestFetchedEventTimestamp, loadMorePolls), !!loadMorePolls && /*#__PURE__*/_react.default.createElement(LoadMorePolls, {
loadMorePolls: loadMorePolls,
isLoading: isLoading
}));
};
const PollHistoryList = ({
pollStartEvents,
polls,
filter,
isLoading,
oldestFetchedEventTimestamp,
onFilterChange,
loadMorePolls,
onItemClick
}) => {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollHistoryList"
}, /*#__PURE__*/_react.default.createElement(_FilterTabGroup.FilterTabGroup, {
name: "PollHistory_filter",
value: filter,
onFilterChange: onFilterChange,
tabs: [{
id: "ACTIVE",
label: "Active polls"
}, {
id: "ENDED",
label: "Past polls"
}]
}), !!pollStartEvents.length && /*#__PURE__*/_react.default.createElement("ol", {
className: (0, _classnames.default)("mx_PollHistoryList_list", `mx_PollHistoryList_list_${filter}`)
}, pollStartEvents.map(pollStartEvent => filter === "ACTIVE" ? /*#__PURE__*/_react.default.createElement(_PollListItem.PollListItem, {
key: pollStartEvent.getId(),
event: pollStartEvent,
onClick: () => onItemClick(pollStartEvent.getId())
}) : /*#__PURE__*/_react.default.createElement(_PollListItemEnded.PollListItemEnded, {
key: pollStartEvent.getId(),
event: pollStartEvent,
poll: polls.get(pollStartEvent.getId()),
onClick: () => onItemClick(pollStartEvent.getId())
})), isLoading && !loadMorePolls && /*#__PURE__*/_react.default.createElement(LoadingPolls, null), !!loadMorePolls && /*#__PURE__*/_react.default.createElement(LoadMorePolls, {
loadMorePolls: loadMorePolls,
isLoading: isLoading
})), !pollStartEvents.length && /*#__PURE__*/_react.default.createElement(NoResults, {
oldestFetchedEventTimestamp: oldestFetchedEventTimestamp,
isLoading: isLoading,
filter: filter,
loadMorePolls: loadMorePolls
}));
};
exports.PollHistoryList = PollHistoryList;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_languageHandler","_FilterTabGroup","_InlineSpinner","_PollListItem","_PollListItemEnded","_AccessibleButton","LoadingPolls","noResultsYet","default","createElement","className","classNames","mx_PollHistoryList_noResultsYet","_t","LoadMorePolls","isLoading","loadMorePolls","kind","onClick","ONE_DAY_MS","getNoResultsMessage","filter","oldestEventTimestamp","fetchedHistoryDaysCount","Math","ceil","Date","now","count","NoResults","oldestFetchedEventTimestamp","PollHistoryList","pollStartEvents","polls","onFilterChange","onItemClick","FilterTabGroup","name","value","tabs","id","label","length","map","pollStartEvent","PollListItem","key","getId","event","PollListItemEnded","poll","get","exports"],"sources":["../../../../../src/components/views/polls/pollHistory/PollHistoryList.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2023 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 from \"react\";\nimport classNames from \"classnames\";\nimport { MatrixEvent, Poll } from \"matrix-js-sdk/src/matrix\";\n\nimport { _t } from \"../../../../languageHandler\";\nimport { FilterTabGroup } from \"../../elements/FilterTabGroup\";\nimport InlineSpinner from \"../../elements/InlineSpinner\";\nimport { PollHistoryFilter } from \"./types\";\nimport { PollListItem } from \"./PollListItem\";\nimport { PollListItemEnded } from \"./PollListItemEnded\";\nimport AccessibleButton from \"../../elements/AccessibleButton\";\n\nconst LoadingPolls: React.FC<{ noResultsYet?: boolean }> = ({ noResultsYet }) => (\n    <div\n        className={classNames(\"mx_PollHistoryList_loading\", {\n            mx_PollHistoryList_noResultsYet: noResultsYet,\n        })}\n    >\n        <InlineSpinner />\n        {_t(\"right_panel|poll|loading\")}\n    </div>\n);\n\nconst LoadMorePolls: React.FC<{ loadMorePolls?: () => void; isLoading?: boolean }> = ({ isLoading, loadMorePolls }) =>\n    loadMorePolls ? (\n        <AccessibleButton\n            className=\"mx_PollHistoryList_loadMorePolls\"\n            kind=\"link_inline\"\n            onClick={() => loadMorePolls()}\n        >\n            {_t(\"right_panel|poll|load_more\")}\n            {isLoading && <InlineSpinner />}\n        </AccessibleButton>\n    ) : null;\n\nconst ONE_DAY_MS = 60000 * 60 * 24;\nconst getNoResultsMessage = (\n    filter: PollHistoryFilter,\n    oldestEventTimestamp?: number,\n    loadMorePolls?: () => void,\n): string => {\n    if (!loadMorePolls) {\n        return filter === \"ACTIVE\" ? _t(\"right_panel|poll|empty_active\") : _t(\"right_panel|poll|empty_past\");\n    }\n\n    // we don't know how much history has been fetched\n    if (!oldestEventTimestamp) {\n        return filter === \"ACTIVE\"\n            ? _t(\"right_panel|poll|empty_active_load_more\")\n            : _t(\"right_panel|poll|empty_past_load_more\");\n    }\n\n    const fetchedHistoryDaysCount = Math.ceil((Date.now() - oldestEventTimestamp) / ONE_DAY_MS);\n    return filter === \"ACTIVE\"\n        ? _t(\"right_panel|poll|empty_active_load_more_n_days\", { count: fetchedHistoryDaysCount })\n        : _t(\"right_panel|poll|empty_past_load_more_n_days\", {\n              count: fetchedHistoryDaysCount,\n          });\n};\n\nconst NoResults: React.FC<{\n    filter: PollHistoryFilter;\n    oldestFetchedEventTimestamp?: number;\n    loadMorePolls?: () => void;\n    isLoading?: boolean;\n}> = ({ filter, isLoading, oldestFetchedEventTimestamp, loadMorePolls }) => {\n    // we can't page the timeline anymore\n    // just use plain loader\n    if (!loadMorePolls && isLoading) {\n        return <LoadingPolls noResultsYet />;\n    }\n\n    return (\n        <span className=\"mx_PollHistoryList_noResults\">\n            {getNoResultsMessage(filter, oldestFetchedEventTimestamp, loadMorePolls)}\n\n            {!!loadMorePolls && <LoadMorePolls loadMorePolls={loadMorePolls} isLoading={isLoading} />}\n        </span>\n    );\n};\n\ntype PollHistoryListProps = {\n    pollStartEvents: MatrixEvent[];\n    polls: Map<string, Poll>;\n    filter: PollHistoryFilter;\n    /**\n     * server ts of the oldest fetched poll\n     * ignoring filter\n     * used to render no results in last x days message\n     * undefined when no polls are found\n     */\n    oldestFetchedEventTimestamp?: number;\n    onFilterChange: (filter: PollHistoryFilter) => void;\n    onItemClick: (pollId: string) => void;\n    loadMorePolls?: () => void;\n    isLoading?: boolean;\n};\nexport const PollHistoryList: React.FC<PollHistoryListProps> = ({\n    pollStartEvents,\n    polls,\n    filter,\n    isLoading,\n    oldestFetchedEventTimestamp,\n    onFilterChange,\n    loadMorePolls,\n    onItemClick,\n}) => {\n    return (\n        <div className=\"mx_PollHistoryList\">\n            <FilterTabGroup<PollHistoryFilter>\n                name=\"PollHistory_filter\"\n                value={filter}\n                onFilterChange={onFilterChange}\n                tabs={[\n                    { id: \"ACTIVE\", label: \"Active polls\" },\n                    { id: \"ENDED\", label: \"Past polls\" },\n                ]}\n            />\n            {!!pollStartEvents.length && (\n                <ol className={classNames(\"mx_PollHistoryList_list\", `mx_PollHistoryList_list_${filter}`)}>\n                    {pollStartEvents.map((pollStartEvent) =>\n                        filter === \"ACTIVE\" ? (\n                            <PollListItem\n                                key={pollStartEvent.getId()!}\n                                event={pollStartEvent}\n                                onClick={() => onItemClick(pollStartEvent.getId()!)}\n                            />\n                        ) : (\n                            <PollListItemEnded\n                                key={pollStartEvent.getId()!}\n                                event={pollStartEvent}\n                                poll={polls.get(pollStartEvent.getId()!)!}\n                                onClick={() => onItemClick(pollStartEvent.getId()!)}\n                            />\n                        ),\n                    )}\n                    {isLoading && !loadMorePolls && <LoadingPolls />}\n                    {!!loadMorePolls && <LoadMorePolls loadMorePolls={loadMorePolls} isLoading={isLoading} />}\n                </ol>\n            )}\n            {!pollStartEvents.length && (\n                <NoResults\n                    oldestFetchedEventTimestamp={oldestFetchedEventTimestamp}\n                    isLoading={isLoading}\n                    filter={filter}\n                    loadMorePolls={loadMorePolls}\n                />\n            )}\n        </div>\n    );\n};\n"],"mappings":"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","ignoreList":[]}