matrix-react-sdk
Version:
SDK for matrix.org using React
78 lines (75 loc) • 14.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PollHistory = void 0;
var _react = _interopRequireWildcard(require("react"));
var _languageHandler = require("../../../../languageHandler");
var _PollHistoryList = require("./PollHistoryList");
var _PollDetailHeader = require("./PollDetailHeader");
var _PollDetail = require("./PollDetail");
var _usePollHistory = require("./usePollHistory");
var _fetchPastPolls = require("./fetchPastPolls");
var _Heading = _interopRequireDefault(require("../../typography/Heading"));
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 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 sortEventsByLatest = (left, right) => right.getTs() - left.getTs();
const filterPolls = filter => poll =>
// exclude polls while they are still loading
// to avoid jitter in list
!poll.isFetchingResponses && filter === "ACTIVE" !== poll.isEnded;
const filterAndSortPolls = (polls, filter) => {
return [...polls.values()].filter(filterPolls(filter)).map(poll => poll.rootEvent).sort(sortEventsByLatest);
};
const PollHistory = ({
room,
matrixClient,
permalinkCreator,
onFinished
}) => {
const {
polls
} = (0, _usePollHistory.usePollsWithRelations)(room.roomId, matrixClient);
const {
isLoading,
loadMorePolls,
oldestEventTimestamp
} = (0, _fetchPastPolls.useFetchPastPolls)(room, matrixClient);
const [filter, setFilter] = (0, _react.useState)("ACTIVE");
const [focusedPollId, setFocusedPollId] = (0, _react.useState)(null);
const pollStartEvents = filterAndSortPolls(polls, filter);
const isLoadingPollResponses = [...polls.values()].some(poll => poll.isFetchingResponses);
const focusedPoll = focusedPollId ? polls.get(focusedPollId) : undefined;
const title = focusedPoll ? /*#__PURE__*/_react.default.createElement(_PollDetailHeader.PollDetailHeader, {
filter: filter,
onNavigateBack: () => setFocusedPollId(null)
}) : (0, _languageHandler._t)("right_panel|polls_button");
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollHistory_content"
}, /*#__PURE__*/_react.default.createElement(_Heading.default, {
className: "mx_PollHistory_header",
size: "2"
}, title), focusedPoll ? /*#__PURE__*/_react.default.createElement(_PollDetail.PollDetail, {
poll: focusedPoll,
permalinkCreator: permalinkCreator,
requestModalClose: onFinished
}) : /*#__PURE__*/_react.default.createElement(_PollHistoryList.PollHistoryList, {
onItemClick: setFocusedPollId,
pollStartEvents: pollStartEvents,
isLoading: isLoading || isLoadingPollResponses,
oldestFetchedEventTimestamp: oldestEventTimestamp,
polls: polls,
filter: filter,
onFilterChange: setFilter,
loadMorePolls: loadMorePolls
}));
};
exports.PollHistory = PollHistory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_languageHandler","_PollHistoryList","_PollDetailHeader","_PollDetail","_usePollHistory","_fetchPastPolls","_Heading","_interopRequireDefault","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","sortEventsByLatest","left","right","getTs","filterPolls","filter","poll","isFetchingResponses","isEnded","filterAndSortPolls","polls","values","map","rootEvent","sort","PollHistory","room","matrixClient","permalinkCreator","onFinished","usePollsWithRelations","roomId","isLoading","loadMorePolls","oldestEventTimestamp","useFetchPastPolls","setFilter","useState","focusedPollId","setFocusedPollId","pollStartEvents","isLoadingPollResponses","some","focusedPoll","undefined","title","createElement","PollDetailHeader","onNavigateBack","_t","className","size","PollDetail","requestModalClose","PollHistoryList","onItemClick","oldestFetchedEventTimestamp","onFilterChange","exports"],"sources":["../../../../../src/components/views/polls/pollHistory/PollHistory.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, { useState } from \"react\";\nimport { MatrixClient, MatrixEvent, Poll, Room } from \"matrix-js-sdk/src/matrix\";\n\nimport { _t } from \"../../../../languageHandler\";\nimport { PollHistoryList } from \"./PollHistoryList\";\nimport { PollHistoryFilter } from \"./types\";\nimport { PollDetailHeader } from \"./PollDetailHeader\";\nimport { PollDetail } from \"./PollDetail\";\nimport { RoomPermalinkCreator } from \"../../../../utils/permalinks/Permalinks\";\nimport { usePollsWithRelations } from \"./usePollHistory\";\nimport { useFetchPastPolls } from \"./fetchPastPolls\";\nimport Heading from \"../../typography/Heading\";\n\ntype PollHistoryProps = {\n    room: Room;\n    matrixClient: MatrixClient;\n    permalinkCreator: RoomPermalinkCreator;\n    onFinished(): void;\n};\n\nconst sortEventsByLatest = (left: MatrixEvent, right: MatrixEvent): number => right.getTs() - left.getTs();\nconst filterPolls =\n    (filter: PollHistoryFilter) =>\n    (poll: Poll): boolean =>\n        // exclude polls while they are still loading\n        // to avoid jitter in list\n        !poll.isFetchingResponses && (filter === \"ACTIVE\") !== poll.isEnded;\n\nconst filterAndSortPolls = (polls: Map<string, Poll>, filter: PollHistoryFilter): MatrixEvent[] => {\n    return [...polls.values()]\n        .filter(filterPolls(filter))\n        .map((poll) => poll.rootEvent)\n        .sort(sortEventsByLatest);\n};\n\nexport const PollHistory: React.FC<PollHistoryProps> = ({ room, matrixClient, permalinkCreator, onFinished }) => {\n    const { polls } = usePollsWithRelations(room.roomId, matrixClient);\n    const { isLoading, loadMorePolls, oldestEventTimestamp } = useFetchPastPolls(room, matrixClient);\n    const [filter, setFilter] = useState<PollHistoryFilter>(\"ACTIVE\");\n    const [focusedPollId, setFocusedPollId] = useState<string | null>(null);\n\n    const pollStartEvents = filterAndSortPolls(polls, filter);\n    const isLoadingPollResponses = [...polls.values()].some((poll) => poll.isFetchingResponses);\n\n    const focusedPoll = focusedPollId ? polls.get(focusedPollId) : undefined;\n    const title = focusedPoll ? (\n        <PollDetailHeader filter={filter} onNavigateBack={() => setFocusedPollId(null)} />\n    ) : (\n        _t(\"right_panel|polls_button\")\n    );\n\n    return (\n        <div className=\"mx_PollHistory_content\">\n            {/* @TODO this probably needs some style */}\n            <Heading className=\"mx_PollHistory_header\" size=\"2\">\n                {title}\n            </Heading>\n            {focusedPoll ? (\n                <PollDetail poll={focusedPoll} permalinkCreator={permalinkCreator} requestModalClose={onFinished} />\n            ) : (\n                <PollHistoryList\n                    onItemClick={setFocusedPollId}\n                    pollStartEvents={pollStartEvents}\n                    isLoading={isLoading || isLoadingPollResponses}\n                    oldestFetchedEventTimestamp={oldestEventTimestamp}\n                    polls={polls}\n                    filter={filter}\n                    onFilterChange={setFilter}\n                    loadMorePolls={loadMorePolls}\n                />\n            )}\n        </div>\n    );\n};\n"],"mappings":"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","ignoreList":[]}