gdx-ui 1.1.0
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.
- package/base.css +1 -0
- package/components/autocomplete/Autocomplete.js +128 -0
- package/components/autocomplete/index.js +16 -0
- package/components/badge/Badge.js +33 -0
- package/components/badge/index.js +16 -0
- package/components/box/Box.js +137 -0
- package/components/box/index.js +16 -0
- package/components/button/Button.js +41 -0
- package/components/button/CircleButton.js +33 -0
- package/components/button/index.js +27 -0
- package/components/cards/Card.js +22 -0
- package/components/cards/CardScroller.js +114 -0
- package/components/dialog/ConfirmationDialog.js +43 -0
- package/components/dialog/Dialog.js +141 -0
- package/components/dialog/index.js +27 -0
- package/components/editable/Editable.js +113 -0
- package/components/editable/EditableArea.js +94 -0
- package/components/editable/index.js +27 -0
- package/components/expandable/Expandable.js +73 -0
- package/components/expandable/index.js +16 -0
- package/components/forms/Autocomplete.js +126 -0
- package/components/forms/Form.js +46 -0
- package/components/forms/Input copy.js +133 -0
- package/components/forms/Input.js +108 -0
- package/components/forms/Select.js +54 -0
- package/components/forms/SelectInput.js +74 -0
- package/components/forms/Switch.js +32 -0
- package/components/forms/index.js +71 -0
- package/components/images/Picture.js +61 -0
- package/components/images/Thumb.js +55 -0
- package/components/images/index.js +27 -0
- package/components/index.js +192 -0
- package/components/navbar/Navbar.js +127 -0
- package/components/navbar/index.js +16 -0
- package/components/pagination/Pagination.js +96 -0
- package/components/pagination/index.js +16 -0
- package/components/row/Row.js +77 -0
- package/components/row/index.js +16 -0
- package/components/snackbar/Snackbar.js +35 -0
- package/components/snackbar/index.js +16 -0
- package/components/table/Table.js +132 -0
- package/components/table/index.js +16 -0
- package/components/tabs/Tabs.js +82 -0
- package/components/tabs/index.js +16 -0
- package/components/tree/Tree.js +64 -0
- package/components/util/Alert.js +35 -0
- package/components/util/List.js +28 -0
- package/components/util/Loader.js +13 -0
- package/components/util/Locker.js +13 -0
- package/components/util/Note.js +20 -0
- package/components/util/Separator.js +17 -0
- package/components/util/Skeleton.js +26 -0
- package/components/util/Text.js +28 -0
- package/components/util/Title.js +19 -0
- package/components/util/index.js +104 -0
- package/components/widget/Widget.js +23 -0
- package/components/widget/index.js +16 -0
- package/hooks/index.js +16 -0
- package/hooks/useForm.js +145 -0
- package/hooks/useOutsideClick.js +28 -0
- package/hooks/useScreenDimentions.js +41 -0
- package/index.js +38 -0
- package/layout/AppLayout.js +43 -0
- package/layout/Layout.js +28 -0
- package/layout/Wrapper.js +23 -0
- package/layout/index.js +27 -0
- package/package.json +29 -0
- package/utils/utils.js +69 -0
- package/utils/validations.js +86 -0
|
@@ -0,0 +1,77 @@
|
|
|
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.RowItem = exports.Row = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
+
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); }
|
|
12
|
+
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 && Object.prototype.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; }
|
|
13
|
+
var RowContext = /*#__PURE__*/(0, _react.createContext)(null);
|
|
14
|
+
var Row = exports.Row = function Row(_ref) {
|
|
15
|
+
var children = _ref.children,
|
|
16
|
+
className = _ref.className,
|
|
17
|
+
_ref$columns = _ref.columns,
|
|
18
|
+
columns = _ref$columns === void 0 ? 1 : _ref$columns,
|
|
19
|
+
_ref$align = _ref.align,
|
|
20
|
+
align = _ref$align === void 0 ? 'left' : _ref$align,
|
|
21
|
+
_ref$valign = _ref.valign,
|
|
22
|
+
valign = _ref$valign === void 0 ? 'top' : _ref$valign,
|
|
23
|
+
_ref$collapsed = _ref.collapsed,
|
|
24
|
+
collapsed = _ref$collapsed === void 0 ? false : _ref$collapsed,
|
|
25
|
+
_ref$responsive = _ref.responsive,
|
|
26
|
+
responsive = _ref$responsive === void 0 ? true : _ref$responsive;
|
|
27
|
+
var transVAling = function transVAling(valign) {
|
|
28
|
+
if (valign === 'top') return 'flex-start';
|
|
29
|
+
// else if (valign === 'center') return 'center';
|
|
30
|
+
else if (valign === 'bottom') return 'flex-end';else valign;
|
|
31
|
+
};
|
|
32
|
+
var settings = {
|
|
33
|
+
columns: columns
|
|
34
|
+
};
|
|
35
|
+
var justifyContent = align === 'left' ? 'flex-start' : align === 'right' ? 'flex-end' : align;
|
|
36
|
+
var alignItems = transVAling(valign);
|
|
37
|
+
return /*#__PURE__*/_react["default"].createElement(RowContext.Provider, {
|
|
38
|
+
value: {
|
|
39
|
+
settings: settings
|
|
40
|
+
}
|
|
41
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
42
|
+
className: "row ".concat(collapsed ? 'collapesed-bottom' : '', " ").concat(responsive ? 'row-responsive' : '', " ").concat(className ? className : ''),
|
|
43
|
+
style: {
|
|
44
|
+
justifyContent: justifyContent,
|
|
45
|
+
alignItems: alignItems
|
|
46
|
+
}
|
|
47
|
+
}, children));
|
|
48
|
+
};
|
|
49
|
+
var RowItem = exports.RowItem = function RowItem(_ref2) {
|
|
50
|
+
var children = _ref2.children,
|
|
51
|
+
className = _ref2.className,
|
|
52
|
+
_ref2$grow = _ref2.grow,
|
|
53
|
+
grow = _ref2$grow === void 0 ? 0 : _ref2$grow,
|
|
54
|
+
_ref2$hover = _ref2.hover,
|
|
55
|
+
hover = _ref2$hover === void 0 ? false : _ref2$hover;
|
|
56
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
57
|
+
className: "row-item ".concat(hover ? 'hover' : '', " ").concat(className ? className : ''),
|
|
58
|
+
style: {
|
|
59
|
+
flexGrow: grow
|
|
60
|
+
}
|
|
61
|
+
}, children);
|
|
62
|
+
};
|
|
63
|
+
Row.propTypes = {
|
|
64
|
+
children: _propTypes["default"].any,
|
|
65
|
+
className: _propTypes["default"].string,
|
|
66
|
+
columns: _propTypes["default"].number,
|
|
67
|
+
align: _propTypes["default"].oneOf(['left', 'center', 'right']),
|
|
68
|
+
valign: _propTypes["default"].oneOf(['top', 'center', 'bottom', 'strech', 'baseline']),
|
|
69
|
+
collapsed: _propTypes["default"].bool,
|
|
70
|
+
responsive: _propTypes["default"].bool
|
|
71
|
+
};
|
|
72
|
+
RowItem.propTypes = {
|
|
73
|
+
children: _propTypes["default"].any,
|
|
74
|
+
className: _propTypes["default"].string,
|
|
75
|
+
grow: _propTypes["default"].number,
|
|
76
|
+
hover: _propTypes["default"].bool
|
|
77
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _Row = require("./Row");
|
|
7
|
+
Object.keys(_Row).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _Row[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function get() {
|
|
13
|
+
return _Row[key];
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Snackbar = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
var _freeSolidSvgIcons = require("@fortawesome/free-solid-svg-icons");
|
|
10
|
+
var _reactFontawesome = require("@fortawesome/react-fontawesome");
|
|
11
|
+
var _CircleButton = require("../button/CircleButton");
|
|
12
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
13
|
+
var Snackbar = exports.Snackbar = function Snackbar(_ref) {
|
|
14
|
+
var children = _ref.children,
|
|
15
|
+
_ref$color = _ref.color,
|
|
16
|
+
color = _ref$color === void 0 ? 'primary' : _ref$color,
|
|
17
|
+
onClose = _ref.onClose;
|
|
18
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("div", {
|
|
19
|
+
className: "snackbar-wrapper"
|
|
20
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
21
|
+
className: "snackbar snackbar-".concat(color)
|
|
22
|
+
}, children, /*#__PURE__*/_react["default"].createElement("div", {
|
|
23
|
+
className: "snackbar-close"
|
|
24
|
+
}, /*#__PURE__*/_react["default"].createElement(_CircleButton.CircleButton, {
|
|
25
|
+
color: "white",
|
|
26
|
+
onClick: onClose
|
|
27
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactFontawesome.FontAwesomeIcon, {
|
|
28
|
+
icon: _freeSolidSvgIcons.faTimes
|
|
29
|
+
}))))));
|
|
30
|
+
};
|
|
31
|
+
Snackbar.propTypes = {
|
|
32
|
+
children: _propTypes["default"].any,
|
|
33
|
+
color: _propTypes["default"].oneOf(['info', 'primary', 'alert', 'success']),
|
|
34
|
+
onClose: _propTypes["default"].func
|
|
35
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _Snackbar = require("./Snackbar");
|
|
7
|
+
Object.keys(_Snackbar).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _Snackbar[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function get() {
|
|
13
|
+
return _Snackbar[key];
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.TableRowSkeleton = exports.TableRow = exports.TableHeader = exports.TableFooter = exports.TableData = exports.TableBody = exports.Table = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
var _reactFontawesome = require("@fortawesome/react-fontawesome");
|
|
10
|
+
var _freeSolidSvgIcons = require("@fortawesome/free-solid-svg-icons");
|
|
11
|
+
var _utils = require("../../utils/utils");
|
|
12
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
13
|
+
var Table = exports.Table = function Table(_ref) {
|
|
14
|
+
var children = _ref.children,
|
|
15
|
+
className = _ref.className,
|
|
16
|
+
_ref$bordered = _ref.bordered,
|
|
17
|
+
bordered = _ref$bordered === void 0 ? false : _ref$bordered,
|
|
18
|
+
_ref$expanded = _ref.expanded,
|
|
19
|
+
expanded = _ref$expanded === void 0 ? true : _ref$expanded,
|
|
20
|
+
_ref$striped = _ref.striped,
|
|
21
|
+
striped = _ref$striped === void 0 ? false : _ref$striped,
|
|
22
|
+
_ref$hover = _ref.hover,
|
|
23
|
+
hover = _ref$hover === void 0 ? false : _ref$hover;
|
|
24
|
+
return /*#__PURE__*/_react["default"].createElement("table", {
|
|
25
|
+
className: "table ".concat(expanded ? "expanded" : '', " \n ").concat(hover ? "table-hover" : '', "\n ").concat(bordered ? "bordered" : '', "\n ").concat(striped ? "table-striped" : '', "\n ").concat(className ? className : '')
|
|
26
|
+
}, children);
|
|
27
|
+
};
|
|
28
|
+
/**
|
|
29
|
+
*
|
|
30
|
+
* @param {headers} data [{id, sortable, order, text, width}]
|
|
31
|
+
* @returns
|
|
32
|
+
*/
|
|
33
|
+
var TableHeader = exports.TableHeader = function TableHeader(_ref2) {
|
|
34
|
+
var headers = _ref2.headers;
|
|
35
|
+
if (!headers) {
|
|
36
|
+
throw new Error('Headers are required');
|
|
37
|
+
}
|
|
38
|
+
var maxWidth = headers[0].width && !isNaN(headers[0].width) && headers.reduce(function (s, h) {
|
|
39
|
+
return s + h.width;
|
|
40
|
+
}, 0);
|
|
41
|
+
return /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", {
|
|
42
|
+
key: (0, _utils.generateId)()
|
|
43
|
+
}, headers.map(function (_ref3) {
|
|
44
|
+
var id = _ref3.id,
|
|
45
|
+
text = _ref3.text,
|
|
46
|
+
sortable = _ref3.sortable,
|
|
47
|
+
order = _ref3.order,
|
|
48
|
+
width = _ref3.width,
|
|
49
|
+
align = _ref3.align;
|
|
50
|
+
return /*#__PURE__*/_react["default"].createElement("th", {
|
|
51
|
+
key: id ? id : (0, _utils.generateId)(),
|
|
52
|
+
className: align,
|
|
53
|
+
width: isNaN(width) ? width : "".concat(100 * width / maxWidth, "%")
|
|
54
|
+
}, sortable && (!order ? /*#__PURE__*/_react["default"].createElement(_reactFontawesome.FontAwesomeIcon, {
|
|
55
|
+
icon: _freeSolidSvgIcons.faArrowsUpDown
|
|
56
|
+
}) : /*#__PURE__*/_react["default"].createElement(_reactFontawesome.FontAwesomeIcon, {
|
|
57
|
+
icon: order === 'ASC' ? _freeSolidSvgIcons.faArrowUp : _freeSolidSvgIcons.faArrowDown
|
|
58
|
+
})), " ", text);
|
|
59
|
+
})));
|
|
60
|
+
};
|
|
61
|
+
var TableFooter = exports.TableFooter = function TableFooter(_ref4) {
|
|
62
|
+
var children = _ref4.children;
|
|
63
|
+
return /*#__PURE__*/_react["default"].createElement("tfoot", null, children);
|
|
64
|
+
};
|
|
65
|
+
var TableBody = exports.TableBody = function TableBody(_ref5) {
|
|
66
|
+
var children = _ref5.children;
|
|
67
|
+
return /*#__PURE__*/_react["default"].createElement("tbody", null, children);
|
|
68
|
+
};
|
|
69
|
+
var TableRow = exports.TableRow = function TableRow(_ref6) {
|
|
70
|
+
var children = _ref6.children,
|
|
71
|
+
id = _ref6.id,
|
|
72
|
+
color = _ref6.color;
|
|
73
|
+
return /*#__PURE__*/_react["default"].createElement("tr", {
|
|
74
|
+
key: id ? id : (0, _utils.generateId)(),
|
|
75
|
+
className: "".concat(color && "highlight-".concat(color))
|
|
76
|
+
}, children);
|
|
77
|
+
};
|
|
78
|
+
var TableData = exports.TableData = function TableData(_ref7) {
|
|
79
|
+
var children = _ref7.children,
|
|
80
|
+
id = _ref7.id,
|
|
81
|
+
className = _ref7.className,
|
|
82
|
+
_ref7$align = _ref7.align,
|
|
83
|
+
align = _ref7$align === void 0 ? 'left' : _ref7$align;
|
|
84
|
+
return /*#__PURE__*/_react["default"].createElement("td", {
|
|
85
|
+
key: id ? id : (0, _utils.generateId)(),
|
|
86
|
+
className: "".concat(align, " ").concat(className ? className : '')
|
|
87
|
+
}, children);
|
|
88
|
+
};
|
|
89
|
+
var TableRowSkeleton = exports.TableRowSkeleton = function TableRowSkeleton(_ref8) {
|
|
90
|
+
var id = _ref8.id,
|
|
91
|
+
_ref8$colspan = _ref8.colspan,
|
|
92
|
+
colspan = _ref8$colspan === void 0 ? 100 : _ref8$colspan;
|
|
93
|
+
return /*#__PURE__*/_react["default"].createElement("tr", {
|
|
94
|
+
key: id ? id : (0, _utils.generateId)()
|
|
95
|
+
}, /*#__PURE__*/_react["default"].createElement("td", {
|
|
96
|
+
colSpan: colspan
|
|
97
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
98
|
+
className: "skeleton blink-soft"
|
|
99
|
+
})));
|
|
100
|
+
};
|
|
101
|
+
Table.propTypes = {
|
|
102
|
+
children: _propTypes["default"].any,
|
|
103
|
+
className: _propTypes["default"].string,
|
|
104
|
+
bordered: _propTypes["default"].bool,
|
|
105
|
+
expanded: _propTypes["default"].bool,
|
|
106
|
+
striped: _propTypes["default"].bool,
|
|
107
|
+
hover: _propTypes["default"].bool
|
|
108
|
+
};
|
|
109
|
+
TableHeader.propTypes = {
|
|
110
|
+
headers: _propTypes["default"].array
|
|
111
|
+
};
|
|
112
|
+
TableBody.propTypes = {
|
|
113
|
+
children: _propTypes["default"].any
|
|
114
|
+
};
|
|
115
|
+
TableFooter.propTypes = {
|
|
116
|
+
children: _propTypes["default"].any
|
|
117
|
+
};
|
|
118
|
+
TableRow.propTypes = {
|
|
119
|
+
children: _propTypes["default"].any,
|
|
120
|
+
id: _propTypes["default"].string,
|
|
121
|
+
color: _propTypes["default"].oneOf([false, 'alert', 'success'])
|
|
122
|
+
};
|
|
123
|
+
TableData.propTypes = {
|
|
124
|
+
children: _propTypes["default"].any,
|
|
125
|
+
id: _propTypes["default"].string,
|
|
126
|
+
className: _propTypes["default"].string,
|
|
127
|
+
align: _propTypes["default"].oneOf(['left', 'center', 'right'])
|
|
128
|
+
};
|
|
129
|
+
TableRowSkeleton.propTypes = {
|
|
130
|
+
id: _propTypes["default"].string,
|
|
131
|
+
colspan: _propTypes["default"].number
|
|
132
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _Table = require("./Table");
|
|
7
|
+
Object.keys(_Table).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _Table[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function get() {
|
|
13
|
+
return _Table[key];
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1,82 @@
|
|
|
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.TabsWrapper = exports.Tabs = exports.TabContent = exports.Tab = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
+
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); }
|
|
12
|
+
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 && Object.prototype.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; }
|
|
13
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
14
|
+
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."); }
|
|
15
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
16
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
17
|
+
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; } }
|
|
18
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
19
|
+
var TabsContext = /*#__PURE__*/(0, _react.createContext)(null);
|
|
20
|
+
var TabsWrapper = exports.TabsWrapper = function TabsWrapper(_ref) {
|
|
21
|
+
var children = _ref.children;
|
|
22
|
+
var _useState = (0, _react.useState)(null),
|
|
23
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
24
|
+
active = _useState2[0],
|
|
25
|
+
setActive = _useState2[1];
|
|
26
|
+
return /*#__PURE__*/_react["default"].createElement(TabsContext.Provider, {
|
|
27
|
+
value: {
|
|
28
|
+
active: active,
|
|
29
|
+
setActive: setActive
|
|
30
|
+
}
|
|
31
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
32
|
+
className: "tabs-widget"
|
|
33
|
+
}, children));
|
|
34
|
+
};
|
|
35
|
+
var Tabs = exports.Tabs = function Tabs(_ref2) {
|
|
36
|
+
var children = _ref2.children,
|
|
37
|
+
active = _ref2.active;
|
|
38
|
+
var _useContext = (0, _react.useContext)(TabsContext),
|
|
39
|
+
setActive = _useContext.setActive;
|
|
40
|
+
(0, _react.useEffect)(function () {
|
|
41
|
+
active && setActive(active);
|
|
42
|
+
}, []);
|
|
43
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
44
|
+
className: "tabs"
|
|
45
|
+
}, children);
|
|
46
|
+
};
|
|
47
|
+
var Tab = exports.Tab = function Tab(_ref3) {
|
|
48
|
+
var children = _ref3.children,
|
|
49
|
+
control = _ref3.control,
|
|
50
|
+
current = _ref3.active,
|
|
51
|
+
_ref3$disabled = _ref3.disabled,
|
|
52
|
+
disabled = _ref3$disabled === void 0 ? false : _ref3$disabled;
|
|
53
|
+
var _useContext2 = (0, _react.useContext)(TabsContext),
|
|
54
|
+
active = _useContext2.active,
|
|
55
|
+
setActive = _useContext2.setActive;
|
|
56
|
+
var onClickTab = function onClickTab(control) {
|
|
57
|
+
setActive(control);
|
|
58
|
+
};
|
|
59
|
+
return /*#__PURE__*/_react["default"].createElement("button", {
|
|
60
|
+
disabled: disabled,
|
|
61
|
+
className: "tab ".concat(active === control ? 'active' : ''),
|
|
62
|
+
onClick: function onClick() {
|
|
63
|
+
return onClickTab(control);
|
|
64
|
+
}
|
|
65
|
+
}, children);
|
|
66
|
+
};
|
|
67
|
+
var TabContent = exports.TabContent = function TabContent(_ref4) {
|
|
68
|
+
var children = _ref4.children,
|
|
69
|
+
id = _ref4.id;
|
|
70
|
+
var _useContext3 = (0, _react.useContext)(TabsContext),
|
|
71
|
+
active = _useContext3.active;
|
|
72
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
73
|
+
id: id,
|
|
74
|
+
className: "tab-content ".concat(active == id ? '' : 'hidden')
|
|
75
|
+
}, children);
|
|
76
|
+
};
|
|
77
|
+
Tab.propTypes = {
|
|
78
|
+
children: _propTypes["default"].any
|
|
79
|
+
};
|
|
80
|
+
Tabs.propTypes = {
|
|
81
|
+
children: _propTypes["default"].any
|
|
82
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _Tabs = require("./Tabs");
|
|
7
|
+
Object.keys(_Tabs).forEach(function (key) {
|
|
8
|
+
if (key === "default" || key === "__esModule") return;
|
|
9
|
+
if (key in exports && exports[key] === _Tabs[key]) return;
|
|
10
|
+
Object.defineProperty(exports, key, {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function get() {
|
|
13
|
+
return _Tabs[key];
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1,64 @@
|
|
|
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.TreeItem = exports.Tree = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
var _reactFontawesome = require("@fortawesome/react-fontawesome");
|
|
11
|
+
var _freeRegularSvgIcons = require("@fortawesome/free-regular-svg-icons");
|
|
12
|
+
var _button = require("../button");
|
|
13
|
+
var _utils = require("../../utils/utils");
|
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
15
|
+
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); }
|
|
16
|
+
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 && Object.prototype.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; }
|
|
17
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
18
|
+
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."); }
|
|
19
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
20
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
21
|
+
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; } }
|
|
22
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
23
|
+
var Tree = exports.Tree = function Tree(_ref) {
|
|
24
|
+
var children = _ref.children,
|
|
25
|
+
className = _ref.className;
|
|
26
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("ul", {
|
|
27
|
+
className: "tree ".concat(className ? className : '')
|
|
28
|
+
}, children));
|
|
29
|
+
};
|
|
30
|
+
var TreeItem = exports.TreeItem = function TreeItem(_ref2) {
|
|
31
|
+
var children = _ref2.children,
|
|
32
|
+
child = _ref2.child,
|
|
33
|
+
onClick = _ref2.onClick;
|
|
34
|
+
var _useState = (0, _react.useState)(false),
|
|
35
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
36
|
+
clicked = _useState2[0],
|
|
37
|
+
setClicked = _useState2[1];
|
|
38
|
+
var onClickButton = function onClickButton(e) {
|
|
39
|
+
onClick && onClick(e);
|
|
40
|
+
setClicked(!clicked);
|
|
41
|
+
};
|
|
42
|
+
return /*#__PURE__*/_react["default"].createElement("li", {
|
|
43
|
+
key: (0, _utils.generateId)(),
|
|
44
|
+
className: "tree-item"
|
|
45
|
+
}, children && /*#__PURE__*/_react["default"].createElement("div", {
|
|
46
|
+
className: "tree-button"
|
|
47
|
+
}, /*#__PURE__*/_react["default"].createElement(_button.CircleButton, {
|
|
48
|
+
color: "solid",
|
|
49
|
+
onClick: onClickButton
|
|
50
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactFontawesome.FontAwesomeIcon, {
|
|
51
|
+
icon: clicked ? _freeRegularSvgIcons.faMinusSquare : _freeRegularSvgIcons.faPlusSquare
|
|
52
|
+
}))), /*#__PURE__*/_react["default"].createElement("div", {
|
|
53
|
+
className: "tree-children"
|
|
54
|
+
}, child), children && clicked && children);
|
|
55
|
+
};
|
|
56
|
+
Tree.propTypes = {
|
|
57
|
+
children: _propTypes["default"].any,
|
|
58
|
+
className: _propTypes["default"].string
|
|
59
|
+
};
|
|
60
|
+
TreeItem.propTypes = {
|
|
61
|
+
children: _propTypes["default"].any,
|
|
62
|
+
child: _propTypes["default"].any,
|
|
63
|
+
onClick: _propTypes["default"].func
|
|
64
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Alert = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
var _dialog = require("../dialog");
|
|
10
|
+
var _row = require("../row");
|
|
11
|
+
var _button = require("../button");
|
|
12
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
13
|
+
var Alert = exports.Alert = function Alert(_ref) {
|
|
14
|
+
var children = _ref.children,
|
|
15
|
+
_ref$title = _ref.title,
|
|
16
|
+
title = _ref$title === void 0 ? 'Alerta' : _ref$title,
|
|
17
|
+
_ref$color = _ref.color,
|
|
18
|
+
color = _ref$color === void 0 ? 'alert' : _ref$color,
|
|
19
|
+
onClose = _ref.onClose;
|
|
20
|
+
return /*#__PURE__*/_react["default"].createElement(_dialog.Dialog, {
|
|
21
|
+
color: color,
|
|
22
|
+
onClose: onClose
|
|
23
|
+
}, /*#__PURE__*/_react["default"].createElement(_dialog.DialogTitle, null, title), /*#__PURE__*/_react["default"].createElement(_dialog.DialogContent, null, children), /*#__PURE__*/_react["default"].createElement(_dialog.DialogActions, null, /*#__PURE__*/_react["default"].createElement(_row.Row, {
|
|
24
|
+
align: "right"
|
|
25
|
+
}, /*#__PURE__*/_react["default"].createElement(_row.RowItem, null, /*#__PURE__*/_react["default"].createElement(_button.Button, {
|
|
26
|
+
onClick: onClose,
|
|
27
|
+
color: color ? color : 'primary'
|
|
28
|
+
}, "Close")))));
|
|
29
|
+
};
|
|
30
|
+
Alert.propTypes = {
|
|
31
|
+
children: _propTypes["default"].any,
|
|
32
|
+
title: _propTypes["default"].string,
|
|
33
|
+
color: _propTypes["default"].oneOf(['default', 'primary', 'alert', 'success']),
|
|
34
|
+
onClose: _propTypes["default"].func
|
|
35
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ListItem = exports.List = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
var List = exports.List = function List(_ref) {
|
|
11
|
+
var children = _ref.children,
|
|
12
|
+
_ref$inline = _ref.inline,
|
|
13
|
+
inline = _ref$inline === void 0 ? false : _ref$inline;
|
|
14
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
15
|
+
className: "clear-list ".concat(inline ? 'inline-list' : '')
|
|
16
|
+
}, /*#__PURE__*/_react["default"].createElement("ul", null, children));
|
|
17
|
+
};
|
|
18
|
+
var ListItem = exports.ListItem = function ListItem(_ref2) {
|
|
19
|
+
var children = _ref2.children;
|
|
20
|
+
return /*#__PURE__*/_react["default"].createElement("li", null, children);
|
|
21
|
+
};
|
|
22
|
+
List.propTypes = {
|
|
23
|
+
children: _propTypes["default"].any.isRequired,
|
|
24
|
+
inline: _propTypes["default"].bool
|
|
25
|
+
};
|
|
26
|
+
ListItem.propTypes = {
|
|
27
|
+
children: _propTypes["default"].any.isRequired
|
|
28
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Loader = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
9
|
+
var Loader = exports.Loader = function Loader() {
|
|
10
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
11
|
+
className: "loader"
|
|
12
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null), /*#__PURE__*/_react["default"].createElement("div", null), /*#__PURE__*/_react["default"].createElement("div", null), /*#__PURE__*/_react["default"].createElement("div", null), /*#__PURE__*/_react["default"].createElement("div", null));
|
|
13
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Locker = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
9
|
+
var Locker = exports.Locker = function Locker() {
|
|
10
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
11
|
+
className: "component-locker"
|
|
12
|
+
});
|
|
13
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Note = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
var Note = exports.Note = function Note(_ref) {
|
|
11
|
+
var children = _ref.children,
|
|
12
|
+
className = _ref.className;
|
|
13
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
14
|
+
className: "gray small ".concat(className ? className : '')
|
|
15
|
+
}, children);
|
|
16
|
+
};
|
|
17
|
+
Note.propTypes = {
|
|
18
|
+
children: _propTypes["default"].any,
|
|
19
|
+
className: _propTypes["default"].string
|
|
20
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Separator = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
var Separator = exports.Separator = function Separator() {
|
|
11
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
12
|
+
className: "margin-bottom border-bottom"
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
Separator.propTypes = {
|
|
16
|
+
children: _propTypes["default"].any
|
|
17
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Skeleton = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
var Skeleton = exports.Skeleton = function Skeleton(_ref) {
|
|
11
|
+
var _ref$width = _ref.width,
|
|
12
|
+
width = _ref$width === void 0 ? 'unset' : _ref$width,
|
|
13
|
+
_ref$height = _ref.height,
|
|
14
|
+
height = _ref$height === void 0 ? 'unset' : _ref$height;
|
|
15
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
16
|
+
className: "skeleton blink-soft",
|
|
17
|
+
style: {
|
|
18
|
+
width: width,
|
|
19
|
+
height: height
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
Skeleton.propTypes = {
|
|
24
|
+
width: _propTypes["default"].number,
|
|
25
|
+
height: _propTypes["default"].number
|
|
26
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Text = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
10
|
+
/**
|
|
11
|
+
* @param {type} text type define the className
|
|
12
|
+
* @returns
|
|
13
|
+
*/
|
|
14
|
+
var Text = exports.Text = function Text(_ref) {
|
|
15
|
+
var variant = _ref.variant,
|
|
16
|
+
_ref$size = _ref.size,
|
|
17
|
+
size = _ref$size === void 0 ? 'normal' : _ref$size,
|
|
18
|
+
children = _ref.children;
|
|
19
|
+
var Tag = variant || 'p';
|
|
20
|
+
return /*#__PURE__*/_react["default"].createElement(Tag, {
|
|
21
|
+
className: size
|
|
22
|
+
}, children);
|
|
23
|
+
};
|
|
24
|
+
Text.propTypes = {
|
|
25
|
+
variant: _propTypes["default"].string,
|
|
26
|
+
size: _propTypes["default"].oneOf(['small', 'normal', 'large']),
|
|
27
|
+
children: _propTypes["default"].any
|
|
28
|
+
};
|