@quintoandar-tokko/modal 1.2.379

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/lib/index.js +198 -0
  2. package/package.json +24 -0
package/lib/index.js ADDED
@@ -0,0 +1,198 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.Modal = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _box = require("@quintoandar-tokko/box");
10
+ var _theme = _interopRequireDefault(require("@quintoandar-tokko/theme"));
11
+ var _text = require("@quintoandar-tokko/text");
12
+ var _icons = require("@quintoandar-tokko/icons");
13
+ var _excluded = ["children", "variant", "modalBG", "blockScroll", "closeModal", "scrollHeight", "fixedCLoseBtn", "paddings"],
14
+ _excluded2 = ["closeIcon", "variant", "text", "textSize"],
15
+ _excluded3 = ["variant"];
16
+ /* eslint-disable multiline-ternary */
17
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
20
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
21
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
22
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
23
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
24
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
25
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
26
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
27
+ function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
28
+ function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; }
29
+ var Modal = exports.Modal = function Modal(_ref) {
30
+ var children = _ref.children,
31
+ variant = _ref.variant,
32
+ modalBG = _ref.modalBG,
33
+ _ref$blockScroll = _ref.blockScroll,
34
+ blockScroll = _ref$blockScroll === void 0 ? false : _ref$blockScroll,
35
+ _ref$closeModal = _ref.closeModal,
36
+ closeModal = _ref$closeModal === void 0 ? false : _ref$closeModal,
37
+ _ref$scrollHeight = _ref.scrollHeight,
38
+ scrollHeight = _ref$scrollHeight === void 0 ? '600px' : _ref$scrollHeight,
39
+ _ref$fixedCLoseBtn = _ref.fixedCLoseBtn,
40
+ fixedCLoseBtn = _ref$fixedCLoseBtn === void 0 ? false : _ref$fixedCLoseBtn,
41
+ _ref$paddings = _ref.paddings,
42
+ paddings = _ref$paddings === void 0 ? '24px' : _ref$paddings,
43
+ props = _objectWithoutProperties(_ref, _excluded);
44
+ var modalRef = (0, _react.useRef)(null);
45
+ (0, _react.useEffect)(function () {
46
+ if (blockScroll) {
47
+ document.body.style.overflow = 'hidden';
48
+ return function () {
49
+ return document.body.style.overflow = 'auto';
50
+ };
51
+ }
52
+ }, []);
53
+ var handleKeyDown = function handleKeyDown(event) {
54
+ if (event.key === 'Escape' && document.activeElement === modalRef.current) {
55
+ event.stopPropagation();
56
+ closeModal();
57
+ }
58
+ };
59
+ (0, _react.useEffect)(function () {
60
+ if (closeModal) {
61
+ document.addEventListener('keydown', handleKeyDown);
62
+ }
63
+ return function () {
64
+ document.removeEventListener('keydown', handleKeyDown);
65
+ };
66
+ }, []);
67
+ (0, _react.useEffect)(function () {
68
+ if (closeModal && modalRef.current) {
69
+ modalRef.current.focus();
70
+ }
71
+ }, []);
72
+ return /*#__PURE__*/_react["default"].createElement(_box.Box, {
73
+ tabIndex: -1,
74
+ ref: modalRef,
75
+ __css: {
76
+ position: 'fixed',
77
+ zIndex: '1000',
78
+ width: '100%',
79
+ height: '100%',
80
+ top: '0',
81
+ left: '0',
82
+ display: 'flex',
83
+ justifyContent: 'center',
84
+ alignItems: 'center'
85
+ }
86
+ }, modalBG && /*#__PURE__*/_react["default"].createElement(_box.Box, {
87
+ onClick: closeModal || undefined,
88
+ __css: {
89
+ backgroundColor: '#485C66',
90
+ opacity: '0.7',
91
+ width: '100%',
92
+ height: '100%',
93
+ position: 'absolute',
94
+ zIndex: '-1'
95
+ }
96
+ }), /*#__PURE__*/_react["default"].createElement(_box.Box, _extends({
97
+ as: "div",
98
+ tx: "modals"
99
+ }, props, {
100
+ __css: {
101
+ position: 'relative',
102
+ maxWidth: '900px',
103
+ minWidth: '380px !important',
104
+ height: "".concat(scrollHeight),
105
+ background: _theme["default"].colors.white,
106
+ borderRadius: '16px',
107
+ boxSizing: 'border-box',
108
+ boxShadow: '8px 8px 16px rgba(77, 91, 100, 0.15)'
109
+ },
110
+ variant: variant
111
+ }), fixedCLoseBtn && /*#__PURE__*/_react["default"].createElement(_box.Box, {
112
+ onClick: closeModal,
113
+ __css: {
114
+ width: '24px',
115
+ height: '24px',
116
+ backgroundColor: '#FFF',
117
+ position: 'absolute',
118
+ borderRadius: '50%',
119
+ top: '-7px',
120
+ right: '-7px',
121
+ display: 'grid',
122
+ placeItems: 'center',
123
+ cursor: 'pointer',
124
+ boxShadow: '4px 4px 12px 0px rgba(87, 95, 99, 0.25)',
125
+ zIndex: '1000'
126
+ }
127
+ }, /*#__PURE__*/_react["default"].createElement(_icons.Icon, {
128
+ icon: "icon-cerrar",
129
+ fontSize: "12px",
130
+ color: _theme["default"].colors.neutralGray1
131
+ })), /*#__PURE__*/_react["default"].createElement(_box.Box, {
132
+ __css: {
133
+ padding: paddings,
134
+ display: 'flex',
135
+ flexDirection: 'column',
136
+ gap: '24px',
137
+ height: "".concat(scrollHeight)
138
+ }
139
+ }, children)));
140
+ };
141
+ var ModalHeader = function ModalHeader(_ref2) {
142
+ var closeIcon = _ref2.closeIcon,
143
+ variant = _ref2.variant,
144
+ text = _ref2.text,
145
+ textSize = _ref2.textSize,
146
+ props = _objectWithoutProperties(_ref2, _excluded2);
147
+ var _useState = (0, _react.useState)(),
148
+ _useState2 = _slicedToArray(_useState, 2),
149
+ justifyContent = _useState2[0],
150
+ setJustifyContent = _useState2[1];
151
+ var headerRef = (0, _react.useRef)(null);
152
+ (0, _react.useEffect)(function () {
153
+ setJustifyContent(headerRef.current.childElementCount > 1 ? 'space-between' : variant[0]);
154
+ }, []);
155
+ return /*#__PURE__*/_react["default"].createElement(_box.Flex, _extends({
156
+ as: "div",
157
+ tx: "modals",
158
+ ref: headerRef,
159
+ variant: variant[1],
160
+ __css: {
161
+ justifyContent: justifyContent,
162
+ alignItems: 'center'
163
+ }
164
+ }, props), /*#__PURE__*/_react["default"].createElement(_text.Text, {
165
+ style: {
166
+ fontWeight: '700',
167
+ color: _theme["default"].colors.neutralGray1
168
+ }
169
+ }, text), closeIcon && /*#__PURE__*/_react["default"].createElement(_icons.Icon, {
170
+ style: {
171
+ cursor: 'pointer'
172
+ },
173
+ icon: "icon-cerrar",
174
+ fontSize: "18px",
175
+ color: _theme["default"].colors.neutralGray5,
176
+ onClick: closeIcon
177
+ }));
178
+ };
179
+ var ModalBody = function ModalBody(props) {
180
+ return /*#__PURE__*/_react["default"].createElement(_box.Box, props);
181
+ };
182
+ var ModalFooter = function ModalFooter(_ref3) {
183
+ var _ref3$variant = _ref3.variant,
184
+ variant = _ref3$variant === void 0 ? 'start' : _ref3$variant,
185
+ props = _objectWithoutProperties(_ref3, _excluded3);
186
+ return /*#__PURE__*/_react["default"].createElement(_box.Flex, _extends({
187
+ as: "div",
188
+ tx: "modals",
189
+ __css: {
190
+ justifyContent: variant,
191
+ alignItems: 'center',
192
+ gap: '24px'
193
+ }
194
+ }, props));
195
+ };
196
+ Modal.Header = ModalHeader;
197
+ Modal.Body = ModalBody;
198
+ Modal.Footer = ModalFooter;
package/package.json ADDED
@@ -0,0 +1,24 @@
1
+ {
2
+ "name": "@quintoandar-tokko/modal",
3
+ "version": "1.2.379",
4
+ "main": "lib/index.js",
5
+ "module": "src/index.js",
6
+ "files": [
7
+ "lib"
8
+ ],
9
+ "dependencies": {
10
+ "@quintoandar-tokko/box": "^1.2.286",
11
+ "@quintoandar-tokko/button": "^1.2.371",
12
+ "@quintoandar-tokko/hooks": "^1.2.308",
13
+ "@quintoandar-tokko/text": "^1.2.287",
14
+ "prop-types": "^15.7.2"
15
+ },
16
+ "peerDependencies": {
17
+ "react": "^16.8.0",
18
+ "react-dom": "^16.8.0"
19
+ },
20
+ "publishConfig": {
21
+ "access": "public"
22
+ },
23
+ "gitHead": "3c5995a3482c9cd1b428a69e135c934c37bce2ae"
24
+ }