choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
246 lines (196 loc) • 8.5 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.SelectionsPosition = exports.TIMESTAMP = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _tslib = require("tslib");
var _react = _interopRequireWildcard(require("react"));
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
var _isUndefined = _interopRequireDefault(require("lodash/isUndefined"));
var _sortBy = _interopRequireDefault(require("lodash/sortBy"));
var _mobx = require("mobx");
var _mobxReact = require("mobx-react");
var _utils = require("../../../lib/configure/utils");
var _tag = _interopRequireDefault(require("../../../lib/tag"));
var _animate = _interopRequireDefault(require("../animate"));
var _icon = _interopRequireDefault(require("../icon"));
var _localeContext = require("../locale-context");
function _createSuper(Derived) {
function isNativeReflectConstruct() {
if (typeof Reflect === "undefined" || !Reflect.construct) return false;
if (Reflect.construct.sham) return false;
if (typeof Proxy === "function") return true;
try {
Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));
return true;
} catch (e) {
return false;
}
}
return function () {
var Super = (0, _getPrototypeOf2["default"])(Derived),
result;
if (isNativeReflectConstruct()) {
var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor;
result = Reflect.construct(Super, arguments, NewTarget);
} else {
result = Super.apply(this, arguments);
}
return (0, _possibleConstructorReturn2["default"])(this, result);
};
}
var TIMESTAMP = '__TIMESTAMP__';
exports.TIMESTAMP = TIMESTAMP;
var SelectionsPosition;
exports.SelectionsPosition = SelectionsPosition;
(function (SelectionsPosition) {
SelectionsPosition["side"] = "side";
SelectionsPosition["below"] = "below";
})(SelectionsPosition || (exports.SelectionsPosition = SelectionsPosition = {}));
var SelectionList =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(SelectionList, _Component);
var _super = _createSuper(SelectionList);
function SelectionList() {
var _this;
(0, _classCallCheck2["default"])(this, SelectionList);
_this = _super.apply(this, arguments);
_this.prefixCls = (0, _utils.getProPrefixCls)('modal');
_this.unSelect = function (record) {
var _this$props = _this.props,
dataSet = _this$props.dataSet,
treeFlag = _this$props.treeFlag;
record.setState(TIMESTAMP, 0);
if (treeFlag === 'Y') {
dataSet.treeUnSelect(record);
} else {
dataSet.unSelect(record);
}
if (!(0, _isUndefined["default"])(record.parent)) {
dataSet.unSelect(record.parent);
}
};
_this.renderBelow = function () {
var _this$props2 = _this.props,
dataSet = _this$props2.dataSet,
treeFlag = _this$props2.treeFlag,
_this$props2$valueFie = _this$props2.valueField,
valueField = _this$props2$valueFie === void 0 ? '' : _this$props2$valueFie,
_this$props2$textFiel = _this$props2.textField,
textField = _this$props2$textFiel === void 0 ? '' : _this$props2$textFiel;
var records = treeFlag === 'Y' ? dataSet.treeSelected : dataSet.selected;
if ((0, _isEmpty["default"])(records)) {
return null;
}
var classString = "".concat(_this.prefixCls, "-selection-list-below");
var animateChildren = _this.getRecords(records).map(function (record) {
return _react["default"].createElement("li", {
key: record.get(valueField),
className: "".concat(classString, "-item")
}, _react["default"].createElement(_tag["default"], {
closable: true,
onClose: function onClose() {
_this.unSelect(record);
}
}, _react["default"].createElement("span", null, record.get(textField))));
});
return _react["default"].createElement("div", {
className: classString
}, _react["default"].createElement("p", {
className: "".concat(classString, "-intro")
}, (0, _localeContext.$l)('Lov', 'selection_tips', {
count: _react["default"].createElement("b", {
key: "count"
}, records.length)
})), _react["default"].createElement(_animate["default"], {
className: "".concat(classString, "-list"),
transitionAppear: true,
transitionName: "fade",
component: "ul"
}, animateChildren));
};
return _this;
}
(0, _createClass2["default"])(SelectionList, [{
key: "getRecords",
value: function getRecords(records) {
return (0, _sortBy["default"])(records, function (item) {
var _item$getState;
return (_item$getState = item.getState(TIMESTAMP)) !== null && _item$getState !== void 0 ? _item$getState : -1;
});
}
}, {
key: "renderSide",
value: function renderSide() {
var _this2 = this;
var _this$props3 = this.props,
dataSet = _this$props3.dataSet,
treeFlag = _this$props3.treeFlag,
_this$props3$valueFie = _this$props3.valueField,
valueField = _this$props3$valueFie === void 0 ? '' : _this$props3$valueFie,
_this$props3$textFiel = _this$props3.textField,
textField = _this$props3$textFiel === void 0 ? '' : _this$props3$textFiel,
_this$props3$selectio = _this$props3.selectionProps,
selectionProps = _this$props3$selectio === void 0 ? {} : _this$props3$selectio;
var nodeRenderer = selectionProps.nodeRenderer,
placeholder = selectionProps.placeholder;
var records = treeFlag === 'Y' ? dataSet.treeSelected : dataSet.selected;
var isEmptyList = (0, _isEmpty["default"])(records);
if (isEmptyList && !placeholder) {
return null;
}
var classString = "".concat(this.prefixCls, "-selection-list");
var animateChildren = this.getRecords(records).map(function (record) {
return _react["default"].createElement("li", {
key: record.get(valueField),
className: "".concat(classString, "-item")
}, nodeRenderer ? (0, _mobx.toJS)(nodeRenderer(record)) : _react["default"].createElement("span", null, record.get(textField)), _react["default"].createElement(_icon["default"], {
type: "cancel",
onClick: function onClick() {
_this2.unSelect(record);
}
}));
});
return _react["default"].createElement("div", {
className: "".concat(classString, "-container")
}, _react["default"].createElement("p", {
className: "".concat(classString, "-intro")
}, isEmptyList ? placeholder : (0, _localeContext.$l)('Lov', 'selection_tips', {
count: _react["default"].createElement("b", {
key: "count"
}, records.length)
})), _react["default"].createElement(_animate["default"], {
className: "".concat(classString, "-list"),
transitionAppear: true,
transitionName: "slide-right",
component: "ul"
}, animateChildren));
}
}, {
key: "render",
value: function render() {
var selectionsPosition = this.props.selectionsPosition;
if (selectionsPosition === SelectionsPosition.side) {
return this.renderSide();
}
if (selectionsPosition === SelectionsPosition.below) {
return this.renderBelow();
}
return null;
}
}]);
return SelectionList;
}(_react.Component);
(0, _tslib.__decorate)([_mobx.action], SelectionList.prototype, "unSelect", void 0);
SelectionList = (0, _tslib.__decorate)([_mobxReact.observer], SelectionList);
var _default = SelectionList;
exports["default"] = _default;
//# sourceMappingURL=SelectionList.js.map