UNPKG

5.07 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
5var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports.default = void 0;
11
12var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
14var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
15
16var React = _interopRequireWildcard(require("react"));
17
18var _propTypes = _interopRequireDefault(require("prop-types"));
19
20var _HiddenJs = _interopRequireDefault(require("./HiddenJs"));
21
22var _HiddenCss = _interopRequireDefault(require("./HiddenCss"));
23
24/**
25 * Responsively hides children based on the selected implementation.
26 */
27function Hidden(props) {
28 var _props$implementation = props.implementation,
29 implementation = _props$implementation === void 0 ? 'js' : _props$implementation,
30 _props$lgDown = props.lgDown,
31 lgDown = _props$lgDown === void 0 ? false : _props$lgDown,
32 _props$lgUp = props.lgUp,
33 lgUp = _props$lgUp === void 0 ? false : _props$lgUp,
34 _props$mdDown = props.mdDown,
35 mdDown = _props$mdDown === void 0 ? false : _props$mdDown,
36 _props$mdUp = props.mdUp,
37 mdUp = _props$mdUp === void 0 ? false : _props$mdUp,
38 _props$smDown = props.smDown,
39 smDown = _props$smDown === void 0 ? false : _props$smDown,
40 _props$smUp = props.smUp,
41 smUp = _props$smUp === void 0 ? false : _props$smUp,
42 _props$xlDown = props.xlDown,
43 xlDown = _props$xlDown === void 0 ? false : _props$xlDown,
44 _props$xlUp = props.xlUp,
45 xlUp = _props$xlUp === void 0 ? false : _props$xlUp,
46 _props$xsDown = props.xsDown,
47 xsDown = _props$xsDown === void 0 ? false : _props$xsDown,
48 _props$xsUp = props.xsUp,
49 xsUp = _props$xsUp === void 0 ? false : _props$xsUp,
50 other = (0, _objectWithoutProperties2.default)(props, ["implementation", "lgDown", "lgUp", "mdDown", "mdUp", "smDown", "smUp", "xlDown", "xlUp", "xsDown", "xsUp"]);
51
52 if (implementation === 'js') {
53 return /*#__PURE__*/React.createElement(_HiddenJs.default, (0, _extends2.default)({
54 lgDown: lgDown,
55 lgUp: lgUp,
56 mdDown: mdDown,
57 mdUp: mdUp,
58 smDown: smDown,
59 smUp: smUp,
60 xlDown: xlDown,
61 xlUp: xlUp,
62 xsDown: xsDown,
63 xsUp: xsUp
64 }, other));
65 }
66
67 return /*#__PURE__*/React.createElement(_HiddenCss.default, (0, _extends2.default)({
68 lgDown: lgDown,
69 lgUp: lgUp,
70 mdDown: mdDown,
71 mdUp: mdUp,
72 smDown: smDown,
73 smUp: smUp,
74 xlDown: xlDown,
75 xlUp: xlUp,
76 xsDown: xsDown,
77 xsUp: xsUp
78 }, other));
79}
80
81process.env.NODE_ENV !== "production" ? Hidden.propTypes = {
82 /**
83 * The content of the component.
84 */
85 children: _propTypes.default.node,
86
87 /**
88 * @ignore
89 */
90 className: _propTypes.default.string,
91
92 /**
93 * Specify which implementation to use. 'js' is the default, 'css' works better for
94 * server-side rendering.
95 */
96 implementation: _propTypes.default.oneOf(['js', 'css']),
97
98 /**
99 * You can use this prop when choosing the `js` implementation with server-side rendering.
100 *
101 * As `window.innerWidth` is unavailable on the server,
102 * we default to rendering an empty component during the first mount.
103 * You might want to use an heuristic to approximate
104 * the screen width of the client browser screen width.
105 *
106 * For instance, you could be using the user-agent or the client-hints.
107 * https://caniuse.com/#search=client%20hint
108 */
109 initialWidth: _propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']),
110
111 /**
112 * If `true`, screens this size and down will be hidden.
113 */
114 lgDown: _propTypes.default.bool,
115
116 /**
117 * If `true`, screens this size and up will be hidden.
118 */
119 lgUp: _propTypes.default.bool,
120
121 /**
122 * If `true`, screens this size and down will be hidden.
123 */
124 mdDown: _propTypes.default.bool,
125
126 /**
127 * If `true`, screens this size and up will be hidden.
128 */
129 mdUp: _propTypes.default.bool,
130
131 /**
132 * Hide the given breakpoint(s).
133 */
134 only: _propTypes.default.oneOfType([_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']), _propTypes.default.arrayOf(_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']))]),
135
136 /**
137 * If `true`, screens this size and down will be hidden.
138 */
139 smDown: _propTypes.default.bool,
140
141 /**
142 * If `true`, screens this size and up will be hidden.
143 */
144 smUp: _propTypes.default.bool,
145
146 /**
147 * If `true`, screens this size and down will be hidden.
148 */
149 xlDown: _propTypes.default.bool,
150
151 /**
152 * If `true`, screens this size and up will be hidden.
153 */
154 xlUp: _propTypes.default.bool,
155
156 /**
157 * If `true`, screens this size and down will be hidden.
158 */
159 xsDown: _propTypes.default.bool,
160
161 /**
162 * If `true`, screens this size and up will be hidden.
163 */
164 xsUp: _propTypes.default.bool
165} : void 0;
166var _default = Hidden;
167exports.default = _default;
\No newline at end of file