ringcentral-widgets
Version:
RingCentral Integration Widget Library
150 lines (118 loc) • 6.74 kB
JavaScript
;
require("core-js/modules/es6.object.define-properties");
require("core-js/modules/es7.object.get-own-property-descriptors");
require("core-js/modules/es6.array.for-each");
require("core-js/modules/es6.array.filter");
require("core-js/modules/es6.object.define-property");
require("core-js/modules/es6.symbol");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
require("core-js/modules/es6.array.index-of");
require("core-js/modules/web.dom.iterable");
require("core-js/modules/es6.array.iterator");
require("core-js/modules/es6.object.to-string");
require("core-js/modules/es6.object.keys");
require("core-js/modules/es6.array.map");
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styles = _interopRequireDefault(require("./styles.scss"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
function CheckBox(_ref) {
var data = _ref.data,
selected = _ref.selected,
onSelect = _ref.onSelect,
valueField = _ref.valueField,
textField = _ref.textField,
className = _ref.className,
dataSign = _ref.dataSign,
type = _ref.type,
checked = _ref.checked,
disabled = _ref.disabled,
onChecked = _ref.onChecked,
children = _ref.children,
props = _objectWithoutProperties(_ref, ["data", "selected", "onSelect", "valueField", "textField", "className", "dataSign", "type", "checked", "disabled", "onChecked", "children"]);
var isListObject = !!(textField && valueField);
switch (type) {
case 'radio':
{
return /*#__PURE__*/_react["default"].createElement("div", {
className: className,
"data-sign": dataSign
}, data.map(function (item, key) {
var isSelected = selected === (isListObject ? item[valueField] : item);
var checkStyle = isSelected ? _styles["default"].selectedCheckButton : null;
var onClick = function onClick() {
return disabled ? undefined : onSelect(item);
};
var extraInfo = typeof item.renderExtraInfo === 'function' && isSelected ? item.renderExtraInfo(_objectSpread({}, props)) : null;
return /*#__PURE__*/_react["default"].createElement("div", {
key: key,
"data-sign": isSelected ? 'selectedItem' : undefined
}, /*#__PURE__*/_react["default"].createElement("div", {
onClick: onClick,
className: (0, _classnames["default"])(_styles["default"].item, disabled || item && item.disabled ? _styles["default"].disabled : null)
}, /*#__PURE__*/_react["default"].createElement("div", {
className: (0, _classnames["default"])(_styles["default"].checkButton, checkStyle)
}), /*#__PURE__*/_react["default"].createElement("div", {
className: _styles["default"].text,
"data-sign": "text"
}, isListObject ? item[textField] : item)), extraInfo);
}));
}
case 'checkbox':
{
var checkboxWrapperClassNames = (0, _classnames["default"])(_styles["default"].checkboxWrapper, disabled ? _styles["default"].wrapperDisabled : '', className);
var checkboxClassName = (0, _classnames["default"])(_styles["default"].checkbox, checked ? _styles["default"].checked : '', disabled ? _styles["default"].checkboxDisabled : '');
return /*#__PURE__*/_react["default"].createElement("div", {
className: checkboxWrapperClassNames,
"data-sign": dataSign,
onClick: function onClick() {
if (!disabled && onChecked) {
onChecked(!checked);
}
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: checkboxClassName
}, checked && '✓'), children);
}
default:
break;
}
}
CheckBox.propTypes = {
valueField: _propTypes["default"].string,
textField: _propTypes["default"].string,
selected: _propTypes["default"].any,
data: _propTypes["default"].array,
onSelect: _propTypes["default"].func,
className: _propTypes["default"].string,
dataSign: _propTypes["default"].string,
type: _propTypes["default"].string,
onChecked: _propTypes["default"].func,
checked: _propTypes["default"].bool,
disabled: _propTypes["default"].bool
};
CheckBox.defaultProps = {
textField: null,
valueField: null,
className: null,
dataSign: undefined,
type: 'radio',
onChecked: function onChecked() {},
onSelect: function onSelect() {},
data: [],
selected: null,
checked: false,
disabled: false
};
var _default = CheckBox;
exports["default"] = _default;
//# sourceMappingURL=index.js.map