choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
265 lines (212 loc) • 7.79 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.hasBreakPointMap = hasBreakPointMap;
exports["default"] = void 0;
var _objectSpread4 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = require("react");
var _isObject = _interopRequireDefault(require("lodash/isObject"));
var _debounce = _interopRequireDefault(require("lodash/debounce"));
var _mobx = require("mobx");
var _mediaQueryListPolyfill = require("../_util/mediaQueryListPolyfill");
var _enum = require("./enum");
var _responsiveMap;
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 enquire;
if (typeof window !== 'undefined') {
window.matchMedia = window.matchMedia || _mediaQueryListPolyfill.matchMediaPolifill; // eslint-disable-next-line global-require
enquire = require('enquire.js');
}
var responsiveMap = (_responsiveMap = {}, (0, _defineProperty2["default"])(_responsiveMap, _enum.Breakpoint.xxl, '(min-width: 1600px)'), (0, _defineProperty2["default"])(_responsiveMap, _enum.Breakpoint.xl, '(min-width: 1200px)'), (0, _defineProperty2["default"])(_responsiveMap, _enum.Breakpoint.lg, '(min-width: 992px)'), (0, _defineProperty2["default"])(_responsiveMap, _enum.Breakpoint.md, '(min-width: 768px)'), (0, _defineProperty2["default"])(_responsiveMap, _enum.Breakpoint.sm, '(min-width: 576px)'), (0, _defineProperty2["default"])(_responsiveMap, _enum.Breakpoint.xs, '(max-width: 575px)'), _responsiveMap);
var responsiveArray = Object.keys(responsiveMap);
function isBreakPointMap(item) {
if ((0, _isObject["default"])(item)) {
var keys = Object.keys(item);
if (keys.length) {
return keys.every(function (key) {
return key in responsiveMap;
});
}
}
return false;
}
function hasBreakPointMap(items) {
// eslint-disable-next-line no-use-before-define
return items.some(isOrHasBreakPointMap);
}
function isOrHasBreakPointMap(item) {
return (0, _mobx.isArrayLike)(item) ? hasBreakPointMap(item) : isBreakPointMap(item);
}
var Responsive =
/*#__PURE__*/
function (_PureComponent) {
(0, _inherits2["default"])(Responsive, _PureComponent);
var _super = _createSuper(Responsive);
function Responsive() {
var _this;
(0, _classCallCheck2["default"])(this, Responsive);
_this = _super.apply(this, arguments);
_this.state = {
breakpoints: {}
};
_this.handlers = new Map();
_this.fireUpdate = (0, _debounce["default"])(function () {
var onChange = _this.props.onChange;
if (onChange) {
onChange(_this.getValues());
}
}, 10);
return _this;
}
(0, _createClass2["default"])(Responsive, [{
key: "isDisabled",
value: function isDisabled(props) {
var disabled = props.disabled,
items = props.items;
if (!disabled && items) {
return !hasBreakPointMap(items);
}
return true;
}
}, {
key: "componentDidMount",
value: function componentDidMount() {
if (!this.isDisabled(this.props)) {
this.register();
}
}
}, {
key: "componentDidUpdate",
value: function componentDidUpdate(prevProps) {
var props = this.props;
if (!this.isDisabled(prevProps) && this.isDisabled(props)) {
this.unregister();
}
if (this.isDisabled(prevProps) && !this.isDisabled(props)) {
this.register();
}
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
if (!this.isDisabled(this.props)) {
this.unregister();
}
}
}, {
key: "register",
value: function register() {
var _this2 = this;
if (enquire) {
var handlers = this.handlers;
responsiveArray.forEach(function (breakpoint) {
var query = responsiveMap[breakpoint];
var handler = {
match: function match() {
_this2.setState(function (prevState) {
return {
breakpoints: (0, _objectSpread4["default"])({}, prevState.breakpoints, (0, _defineProperty2["default"])({}, breakpoint, true))
};
}, _this2.fireUpdate);
},
unmatch: function unmatch() {
_this2.setState(function (prevState) {
return {
breakpoints: (0, _objectSpread4["default"])({}, prevState.breakpoints, (0, _defineProperty2["default"])({}, breakpoint, false))
};
}, _this2.fireUpdate);
},
// Keep a empty destory to avoid triggering unmatch when unregister
destroy: function destroy() {}
};
enquire.register(query, handler);
handlers.set(query, handler);
});
}
}
}, {
key: "unregister",
value: function unregister() {
var handlers = this.handlers;
Object.keys(responsiveMap).forEach(function (breakpoint) {
var query = responsiveMap[breakpoint];
var handler = handlers.get(query);
if (handler) {
enquire.unregister(query, handler);
}
});
}
}, {
key: "processValue",
value: function processValue(value) {
var breakpoints = this.state.breakpoints;
if ((0, _mobx.isArrayLike)(value) && hasBreakPointMap(value)) {
return value.map(this.processValue, this);
}
if (isBreakPointMap(value)) {
for (var i = 0; i < responsiveArray.length; i++) {
var breakpoint = responsiveArray[i];
if (breakpoints[breakpoint] && value[breakpoint] !== undefined) {
return value[breakpoint];
}
}
return undefined;
}
return value;
}
}, {
key: "getValues",
value: function getValues() {
var items = this.props.items;
if (items) {
return items.map(this.processValue, this);
}
return [];
}
}, {
key: "render",
value: function render() {
var props = this.props;
var children = props.children;
if (typeof children === 'function') {
return children(this.getValues(), this.isDisabled(props));
}
return children;
}
}]);
return Responsive;
}(_react.PureComponent);
exports["default"] = Responsive;
Responsive.displayName = 'Responsive';
//# sourceMappingURL=Responsive.js.map