react-responsive-redux
Version:
redux integration for react-responsive
74 lines (65 loc) • 2.84 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/defineProperty";
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; }
import { defaultSizes } from './defaults';
export var SET_MOBILE_DETECT = '@@react-responsive-redux/SET_MOBILE_DETECT';
export var setMobileDetect = function setMobileDetect() {
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
phone = _ref.phone,
tablet = _ref.tablet,
mobile = _ref.mobile,
desktop = _ref.desktop;
return {
type: SET_MOBILE_DETECT,
phone: phone,
tablet: tablet,
mobile: mobile,
desktop: desktop
};
};
export var defaultSize = defaultSizes.desktop;
export var initialState = {
phone: false,
tablet: false,
mobile: false,
desktop: false,
fakeWidth: defaultSize
};
export var reducer = function reducer() {
var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
var action = arguments.length > 1 ? arguments[1] : undefined;
switch (action.type) {
case SET_MOBILE_DETECT:
{
var _initialState$action = _objectSpread({}, initialState, {}, action),
mobile = _initialState$action.mobile,
tablet = _initialState$action.tablet,
phone = _initialState$action.phone,
desktop = _initialState$action.desktop;
var fakeWidth;
if (mobile) {
if (phone) {
fakeWidth = defaultSizes.phone;
} else if (tablet) {
fakeWidth = defaultSizes.tablet;
} else {
fakeWidth = defaultSizes.phone;
}
} else if (desktop) {
fakeWidth = defaultSizes.desktop;
} else {
fakeWidth = defaultSize;
}
return _objectSpread({}, state, {
mobile: mobile,
tablet: tablet,
phone: phone,
desktop: desktop,
fakeWidth: fakeWidth
});
}
default:
return state;
}
};
//# sourceMappingURL=redux.js.map