matrix-react-sdk
Version:
SDK for matrix.org using React
147 lines (145 loc) • 21.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.IconizedContextMenuRadio = exports.IconizedContextMenuOptionList = exports.IconizedContextMenuOption = exports.IconizedContextMenuCheckbox = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = _interopRequireDefault(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _ContextMenu = _interopRequireWildcard(require("../../structures/ContextMenu"));
var _languageHandler = require("../../../languageHandler");
const _excluded = ["label", "iconClassName", "active", "className"],
_excluded2 = ["label", "iconClassName", "active", "className", "words"],
_excluded3 = ["label", "className", "iconClassName", "children", "isDestructive"],
_excluded4 = ["className", "children", "compact"];
/*
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.
*/
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; }
const IconizedContextMenuRadio = _ref => {
let {
label,
iconClassName,
active,
className
} = _ref,
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
return /*#__PURE__*/_react.default.createElement(_ContextMenu.MenuItemRadio, (0, _extends2.default)({}, props, {
className: (0, _classnames.default)(className, {
mx_IconizedContextMenu_item: true,
mx_IconizedContextMenu_active: active
}),
active: active,
label: label
}), iconClassName && /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)("mx_IconizedContextMenu_icon", iconClassName)
}), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_label"
}, label), active && /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_icon mx_IconizedContextMenu_checked"
}));
};
exports.IconizedContextMenuRadio = IconizedContextMenuRadio;
const IconizedContextMenuCheckbox = _ref2 => {
let {
label,
iconClassName,
active,
className,
words
} = _ref2,
props = (0, _objectWithoutProperties2.default)(_ref2, _excluded2);
let marker;
if (words) {
marker = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_activeText"
}, active ? (0, _languageHandler._t)("common|on") : (0, _languageHandler._t)("common|off"));
} else {
marker = /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)("mx_IconizedContextMenu_icon", {
mx_IconizedContextMenu_checked: active,
mx_IconizedContextMenu_unchecked: !active
})
});
}
return /*#__PURE__*/_react.default.createElement(_ContextMenu.MenuItemCheckbox, (0, _extends2.default)({}, props, {
className: (0, _classnames.default)(className, {
mx_IconizedContextMenu_item: true,
mx_IconizedContextMenu_active: active
}),
active: active,
label: label
}), /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)("mx_IconizedContextMenu_icon", iconClassName)
}), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_label"
}, label), marker);
};
exports.IconizedContextMenuCheckbox = IconizedContextMenuCheckbox;
const IconizedContextMenuOption = _ref3 => {
let {
label,
className,
iconClassName,
children,
isDestructive
} = _ref3,
props = (0, _objectWithoutProperties2.default)(_ref3, _excluded3);
return /*#__PURE__*/_react.default.createElement(_ContextMenu.MenuItem, (0, _extends2.default)({
element: "li"
}, props, {
className: (0, _classnames.default)(className, {
mx_IconizedContextMenu_item: true,
mx_IconizedContextMenu_itemDestructive: isDestructive
}),
label: label
}), iconClassName && /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)("mx_IconizedContextMenu_icon", iconClassName)
}), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_label"
}, label), children);
};
exports.IconizedContextMenuOption = IconizedContextMenuOption;
const IconizedContextMenuOptionList = ({
first,
red,
className,
label,
children
}) => {
const classes = (0, _classnames.default)("mx_IconizedContextMenu_optionList", className, {
mx_IconizedContextMenu_optionList_notFirst: !first,
mx_IconizedContextMenu_optionList_red: red
});
return /*#__PURE__*/_react.default.createElement("div", {
className: classes
}, label && /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_optionList_label"
}, label)), children);
};
exports.IconizedContextMenuOptionList = IconizedContextMenuOptionList;
const IconizedContextMenu = _ref4 => {
let {
className,
children,
compact
} = _ref4,
props = (0, _objectWithoutProperties2.default)(_ref4, _excluded4);
const classes = (0, _classnames.default)("mx_IconizedContextMenu", className, {
mx_IconizedContextMenu_compact: compact
});
return /*#__PURE__*/_react.default.createElement(_ContextMenu.default, (0, _extends2.default)({
chevronFace: _ContextMenu.ChevronFace.None
}, props), /*#__PURE__*/_react.default.createElement("ul", {
role: "none",
className: classes
}, children));
};
var _default = exports.default = IconizedContextMenu;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_ContextMenu","_interopRequireWildcard","_languageHandler","_excluded","_excluded2","_excluded3","_excluded4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","IconizedContextMenuRadio","_ref","label","iconClassName","active","className","props","_objectWithoutProperties2","createElement","MenuItemRadio","_extends2","classNames","mx_IconizedContextMenu_item","mx_IconizedContextMenu_active","exports","IconizedContextMenuCheckbox","_ref2","words","marker","_t","mx_IconizedContextMenu_checked","mx_IconizedContextMenu_unchecked","MenuItemCheckbox","IconizedContextMenuOption","_ref3","children","isDestructive","MenuItem","element","mx_IconizedContextMenu_itemDestructive","IconizedContextMenuOptionList","first","red","classes","mx_IconizedContextMenu_optionList_notFirst","mx_IconizedContextMenu_optionList_red","IconizedContextMenu","_ref4","compact","mx_IconizedContextMenu_compact","chevronFace","ChevronFace","None","role","_default"],"sources":["../../../../src/components/views/context_menus/IconizedContextMenu.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 classNames from \"classnames\";\n\nimport ContextMenu, {\n    ChevronFace,\n    IProps as IContextMenuProps,\n    MenuItem,\n    MenuItemCheckbox,\n    MenuItemRadio,\n} from \"../../structures/ContextMenu\";\nimport { _t } from \"../../../languageHandler\";\n\ninterface IProps extends IContextMenuProps {\n    className?: string;\n    compact?: boolean;\n}\n\ninterface IOptionListProps {\n    first?: boolean;\n    red?: boolean;\n    label?: string;\n    className?: string;\n    children: ReactNode;\n}\n\ninterface IOptionProps extends React.ComponentProps<typeof MenuItem> {\n    iconClassName?: string;\n    isDestructive?: boolean;\n}\n\ninterface ICheckboxProps extends React.ComponentProps<typeof MenuItemCheckbox> {\n    iconClassName: string;\n    words?: boolean;\n}\n\ninterface IRadioProps extends React.ComponentProps<typeof MenuItemRadio> {\n    iconClassName?: string;\n}\n\nexport const IconizedContextMenuRadio: React.FC<IRadioProps> = ({\n    label,\n    iconClassName,\n    active,\n    className,\n    ...props\n}) => {\n    return (\n        <MenuItemRadio\n            {...props}\n            className={classNames(className, {\n                mx_IconizedContextMenu_item: true,\n                mx_IconizedContextMenu_active: active,\n            })}\n            active={active}\n            label={label}\n        >\n            {iconClassName && <span className={classNames(\"mx_IconizedContextMenu_icon\", iconClassName)} />}\n            <span className=\"mx_IconizedContextMenu_label\">{label}</span>\n            {active && <span className=\"mx_IconizedContextMenu_icon mx_IconizedContextMenu_checked\" />}\n        </MenuItemRadio>\n    );\n};\n\nexport const IconizedContextMenuCheckbox: React.FC<ICheckboxProps> = ({\n    label,\n    iconClassName,\n    active,\n    className,\n    words,\n    ...props\n}) => {\n    let marker: JSX.Element;\n    if (words) {\n        marker = (\n            <span className=\"mx_IconizedContextMenu_activeText\">{active ? _t(\"common|on\") : _t(\"common|off\")}</span>\n        );\n    } else {\n        marker = (\n            <span\n                className={classNames(\"mx_IconizedContextMenu_icon\", {\n                    mx_IconizedContextMenu_checked: active,\n                    mx_IconizedContextMenu_unchecked: !active,\n                })}\n            />\n        );\n    }\n\n    return (\n        <MenuItemCheckbox\n            {...props}\n            className={classNames(className, {\n                mx_IconizedContextMenu_item: true,\n                mx_IconizedContextMenu_active: active,\n            })}\n            active={active}\n            label={label}\n        >\n            <span className={classNames(\"mx_IconizedContextMenu_icon\", iconClassName)} />\n            <span className=\"mx_IconizedContextMenu_label\">{label}</span>\n            {marker}\n        </MenuItemCheckbox>\n    );\n};\n\nexport const IconizedContextMenuOption: React.FC<IOptionProps> = ({\n    label,\n    className,\n    iconClassName,\n    children,\n    isDestructive,\n    ...props\n}) => {\n    return (\n        <MenuItem\n            element=\"li\"\n            {...props}\n            className={classNames(className, {\n                mx_IconizedContextMenu_item: true,\n                mx_IconizedContextMenu_itemDestructive: isDestructive,\n            })}\n            label={label}\n        >\n            {iconClassName && <span className={classNames(\"mx_IconizedContextMenu_icon\", iconClassName)} />}\n            <span className=\"mx_IconizedContextMenu_label\">{label}</span>\n            {children}\n        </MenuItem>\n    );\n};\n\nexport const IconizedContextMenuOptionList: React.FC<IOptionListProps> = ({\n    first,\n    red,\n    className,\n    label,\n    children,\n}) => {\n    const classes = classNames(\"mx_IconizedContextMenu_optionList\", className, {\n        mx_IconizedContextMenu_optionList_notFirst: !first,\n        mx_IconizedContextMenu_optionList_red: red,\n    });\n\n    return (\n        <div className={classes}>\n            {label && (\n                <div>\n                    <span className=\"mx_IconizedContextMenu_optionList_label\">{label}</span>\n                </div>\n            )}\n            {children}\n        </div>\n    );\n};\n\nconst IconizedContextMenu: React.FC<React.PropsWithChildren<IProps>> = ({ className, children, compact, ...props }) => {\n    const classes = classNames(\"mx_IconizedContextMenu\", className, {\n        mx_IconizedContextMenu_compact: compact,\n    });\n\n    return (\n        <ContextMenu chevronFace={ChevronFace.None} {...props}>\n            <ul role=\"none\" className={classes}>\n                {children}\n            </ul>\n        </ContextMenu>\n    );\n};\n\nexport default IconizedContextMenu;\n"],"mappings":"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","ignoreList":[]}