matrix-react-sdk
Version:
SDK for matrix.org using React
105 lines (102 loc) • 12.9 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PollOption = void 0;
var _react = _interopRequireDefault(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _languageHandler = require("../../../languageHandler");
var _trophy = require("../../../../res/img/element-icons/trophy.svg");
var _StyledRadioButton = _interopRequireDefault(require("../elements/StyledRadioButton"));
/*
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 PollOptionContent = ({
isWinner,
answer,
voteCount,
displayVoteCount
}) => {
const votesText = displayVoteCount ? (0, _languageHandler._t)("timeline|m.poll|count_of_votes", {
count: voteCount
}) : "";
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollOption_content"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollOption_optionText"
}, answer.text), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollOption_optionVoteCount"
}, isWinner && /*#__PURE__*/_react.default.createElement(_trophy.Icon, {
className: "mx_PollOption_winnerIcon"
}), votesText));
};
const EndedPollOption = ({
isChecked,
children,
answer
}) => /*#__PURE__*/_react.default.createElement("div", {
className: (0, _classnames.default)("mx_PollOption_endedOption", {
mx_PollOption_endedOptionWinner: isChecked
}),
"data-value": answer.id
}, children);
const ActivePollOption = ({
pollId,
isChecked,
children,
answer,
onOptionSelected
}) => /*#__PURE__*/_react.default.createElement(_StyledRadioButton.default, {
className: "mx_PollOption_live-option",
name: `poll_answer_select-${pollId}`,
value: answer.id,
checked: isChecked,
onChange: () => onOptionSelected?.(answer.id)
}, children);
const PollOption = ({
pollId,
answer,
voteCount,
totalVoteCount,
displayVoteCount,
isEnded,
isChecked,
onOptionSelected
}) => {
const cls = (0, _classnames.default)({
mx_PollOption: true,
mx_PollOption_checked: isChecked,
mx_PollOption_ended: isEnded
});
const isWinner = isEnded && isChecked;
const answerPercent = totalVoteCount === 0 ? 0 : Math.round(100.0 * voteCount / totalVoteCount);
const PollOptionWrapper = isEnded ? EndedPollOption : ActivePollOption;
return /*#__PURE__*/_react.default.createElement("div", {
"data-testid": `pollOption-${answer.id}`,
className: cls,
onClick: () => onOptionSelected?.(answer.id)
}, /*#__PURE__*/_react.default.createElement(PollOptionWrapper, {
pollId: pollId,
answer: answer,
isChecked: isChecked,
onOptionSelected: onOptionSelected
}, /*#__PURE__*/_react.default.createElement(PollOptionContent, {
isWinner: isWinner,
answer: answer,
voteCount: voteCount,
displayVoteCount: displayVoteCount
})), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollOption_popularityBackground"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_PollOption_popularityAmount",
style: {
width: `${answerPercent}%`
}
})));
};
exports.PollOption = PollOption;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_languageHandler","_trophy","_StyledRadioButton","PollOptionContent","isWinner","answer","voteCount","displayVoteCount","votesText","_t","count","default","createElement","className","text","Icon","EndedPollOption","isChecked","children","classNames","mx_PollOption_endedOptionWinner","id","ActivePollOption","pollId","onOptionSelected","name","value","checked","onChange","PollOption","totalVoteCount","isEnded","cls","mx_PollOption","mx_PollOption_checked","mx_PollOption_ended","answerPercent","Math","round","PollOptionWrapper","onClick","style","width","exports"],"sources":["../../../../src/components/views/polls/PollOption.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, { ReactNode } from \"react\";\nimport classNames from \"classnames\";\nimport { PollAnswerSubevent } from \"matrix-js-sdk/src/extensible_events_v1/PollStartEvent\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { Icon as TrophyIcon } from \"../../../../res/img/element-icons/trophy.svg\";\nimport StyledRadioButton from \"../elements/StyledRadioButton\";\n\ntype PollOptionContentProps = {\n    answer: PollAnswerSubevent;\n    voteCount: number;\n    displayVoteCount?: boolean;\n    isWinner?: boolean;\n};\nconst PollOptionContent: React.FC<PollOptionContentProps> = ({ isWinner, answer, voteCount, displayVoteCount }) => {\n    const votesText = displayVoteCount ? _t(\"timeline|m.poll|count_of_votes\", { count: voteCount }) : \"\";\n    return (\n        <div className=\"mx_PollOption_content\">\n            <div className=\"mx_PollOption_optionText\">{answer.text}</div>\n            <div className=\"mx_PollOption_optionVoteCount\">\n                {isWinner && <TrophyIcon className=\"mx_PollOption_winnerIcon\" />}\n                {votesText}\n            </div>\n        </div>\n    );\n};\n\ninterface PollOptionProps extends PollOptionContentProps {\n    pollId: string;\n    totalVoteCount: number;\n    isEnded?: boolean;\n    isChecked?: boolean;\n    onOptionSelected?: (id: string) => void;\n    children?: ReactNode;\n}\n\nconst EndedPollOption: React.FC<Omit<PollOptionProps, \"voteCount\" | \"totalVoteCount\">> = ({\n    isChecked,\n    children,\n    answer,\n}) => (\n    <div\n        className={classNames(\"mx_PollOption_endedOption\", {\n            mx_PollOption_endedOptionWinner: isChecked,\n        })}\n        data-value={answer.id}\n    >\n        {children}\n    </div>\n);\n\nconst ActivePollOption: React.FC<Omit<PollOptionProps, \"voteCount\" | \"totalVoteCount\">> = ({\n    pollId,\n    isChecked,\n    children,\n    answer,\n    onOptionSelected,\n}) => (\n    <StyledRadioButton\n        className=\"mx_PollOption_live-option\"\n        name={`poll_answer_select-${pollId}`}\n        value={answer.id}\n        checked={isChecked}\n        onChange={() => onOptionSelected?.(answer.id)}\n    >\n        {children}\n    </StyledRadioButton>\n);\n\nexport const PollOption: React.FC<PollOptionProps> = ({\n    pollId,\n    answer,\n    voteCount,\n    totalVoteCount,\n    displayVoteCount,\n    isEnded,\n    isChecked,\n    onOptionSelected,\n}) => {\n    const cls = classNames({\n        mx_PollOption: true,\n        mx_PollOption_checked: isChecked,\n        mx_PollOption_ended: isEnded,\n    });\n    const isWinner = isEnded && isChecked;\n    const answerPercent = totalVoteCount === 0 ? 0 : Math.round((100.0 * voteCount) / totalVoteCount);\n    const PollOptionWrapper = isEnded ? EndedPollOption : ActivePollOption;\n    return (\n        <div data-testid={`pollOption-${answer.id}`} className={cls} onClick={() => onOptionSelected?.(answer.id)}>\n            <PollOptionWrapper\n                pollId={pollId}\n                answer={answer}\n                isChecked={isChecked}\n                onOptionSelected={onOptionSelected}\n            >\n                <PollOptionContent\n                    isWinner={isWinner}\n                    answer={answer}\n                    voteCount={voteCount}\n                    displayVoteCount={displayVoteCount}\n                />\n            </PollOptionWrapper>\n            <div className=\"mx_PollOption_popularityBackground\">\n                <div className=\"mx_PollOption_popularityAmount\" style={{ width: `${answerPercent}%` }} />\n            </div>\n        </div>\n    );\n};\n"],"mappings":"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","ignoreList":[]}