matrix-react-sdk
Version:
SDK for matrix.org using React
148 lines (128 loc) • 13.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.IconizedContextMenuOptionList = exports.IconizedContextMenuOption = exports.IconizedContextMenuCheckbox = exports.IconizedContextMenuRadio = 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 = require("../../structures/ContextMenu");
/*
Copyright 2020 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
const IconizedContextMenuRadio
/*: React.FC<IRadioProps>*/
= (_ref) => {
let {
label,
iconClassName,
active,
className
} = _ref,
props = (0, _objectWithoutProperties2.default)(_ref, ["label", "iconClassName", "active", "className"]);
return /*#__PURE__*/_react.default.createElement(_ContextMenu.MenuItemRadio, (0, _extends2.default)({}, props, {
className: (0, _classnames.default)(className, {
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), active && /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_icon mx_IconizedContextMenu_checked"
}));
};
exports.IconizedContextMenuRadio = IconizedContextMenuRadio;
const IconizedContextMenuCheckbox
/*: React.FC<ICheckboxProps>*/
= (_ref2) => {
let {
label,
iconClassName,
active,
className
} = _ref2,
props = (0, _objectWithoutProperties2.default)(_ref2, ["label", "iconClassName", "active", "className"]);
return /*#__PURE__*/_react.default.createElement(_ContextMenu.MenuItemCheckbox, (0, _extends2.default)({}, props, {
className: (0, _classnames.default)(className, {
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), active && /*#__PURE__*/_react.default.createElement("span", {
className: "mx_IconizedContextMenu_icon mx_IconizedContextMenu_checked"
}));
};
exports.IconizedContextMenuCheckbox = IconizedContextMenuCheckbox;
const IconizedContextMenuOption
/*: React.FC<IOptionProps>*/
= (_ref3) => {
let {
label,
iconClassName
} = _ref3,
props = (0, _objectWithoutProperties2.default)(_ref3, ["label", "iconClassName"]);
return /*#__PURE__*/_react.default.createElement(_ContextMenu.MenuItem, (0, _extends2.default)({}, props, {
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));
};
exports.IconizedContextMenuOption = IconizedContextMenuOption;
const IconizedContextMenuOptionList
/*: React.FC<IOptionListProps>*/
= ({
first,
red,
className,
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
}, children);
};
exports.IconizedContextMenuOptionList = IconizedContextMenuOptionList;
const IconizedContextMenu
/*: React.FC<IProps>*/
= (_ref4) => {
let {
className,
children,
compact
} = _ref4,
props = (0, _objectWithoutProperties2.default)(_ref4, ["className", "children", "compact"]);
const classes = (0, _classnames.default)("mx_IconizedContextMenu", className, {
mx_IconizedContextMenu_compact: compact
});
return /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenu, (0, _extends2.default)({
chevronFace: _ContextMenu.ChevronFace.None
}, props), /*#__PURE__*/_react.default.createElement("div", {
className: classes
}, children));
};
var _default = IconizedContextMenu;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/context_menus/IconizedContextMenu.tsx"],"names":["IconizedContextMenuRadio","label","iconClassName","active","className","props","mx_IconizedContextMenu_active","IconizedContextMenuCheckbox","IconizedContextMenuOption","IconizedContextMenuOptionList","first","red","children","classes","mx_IconizedContextMenu_optionList_notFirst","mx_IconizedContextMenu_optionList_red","IconizedContextMenu","compact","mx_IconizedContextMenu_compact","ChevronFace","None"],"mappings":"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","sourcesContent":["/*\nCopyright 2020 The Matrix.org Foundation C.I.C.\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 classNames from \"classnames\";\n\nimport {\n    ChevronFace,\n    ContextMenu,\n    IProps as IContextMenuProps,\n    MenuItem,\n    MenuItemCheckbox, MenuItemRadio,\n} from \"../../structures/ContextMenu\";\n\ninterface IProps extends IContextMenuProps {\n    className?: string;\n    compact?: boolean;\n}\n\ninterface IOptionListProps {\n    first?: boolean;\n    red?: boolean;\n    className?: string;\n}\n\ninterface IOptionProps extends React.ComponentProps<typeof MenuItem> {\n    iconClassName?: string;\n}\n\ninterface ICheckboxProps extends React.ComponentProps<typeof MenuItemCheckbox> {\n    iconClassName: string;\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 <MenuItemRadio\n        {...props}\n        className={classNames(className, {\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        {active && <span className=\"mx_IconizedContextMenu_icon mx_IconizedContextMenu_checked\" />}\n    </MenuItemRadio>;\n};\n\nexport const IconizedContextMenuCheckbox: React.FC<ICheckboxProps> = ({\n    label,\n    iconClassName,\n    active,\n    className,\n    ...props\n}) => {\n    return <MenuItemCheckbox\n        {...props}\n        className={classNames(className, {\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        {active && <span className=\"mx_IconizedContextMenu_icon mx_IconizedContextMenu_checked\" />}\n    </MenuItemCheckbox>;\n};\n\nexport const IconizedContextMenuOption: React.FC<IOptionProps> = ({label, iconClassName, ...props}) => {\n    return <MenuItem {...props} label={label}>\n        { iconClassName && <span className={classNames(\"mx_IconizedContextMenu_icon\", iconClassName)} /> }\n        <span className=\"mx_IconizedContextMenu_label\">{label}</span>\n    </MenuItem>;\n};\n\nexport const IconizedContextMenuOptionList: React.FC<IOptionListProps> = ({first, red, className, children}) => {\n    const classes = classNames(\"mx_IconizedContextMenu_optionList\", className, {\n        mx_IconizedContextMenu_optionList_notFirst: !first,\n        mx_IconizedContextMenu_optionList_red: red,\n    });\n\n    return <div className={classes}>\n        {children}\n    </div>;\n};\n\nconst IconizedContextMenu: React.FC<IProps> = ({className, children, compact, ...props}) => {\n    const classes = classNames(\"mx_IconizedContextMenu\", className, {\n        mx_IconizedContextMenu_compact: compact,\n    });\n\n    return <ContextMenu chevronFace={ChevronFace.None} {...props}>\n        <div className={classes}>\n            { children }\n        </div>\n    </ContextMenu>;\n};\n\nexport default IconizedContextMenu;\n\n"]}