tabler-react-2 0.1.97 → 0.1.99

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/dist/index.js CHANGED
@@ -192,5 +192,17 @@ Object.keys(_index18).forEach(function (key) {
192
192
  }
193
193
  });
194
194
  });
195
+ var _index19 = require("./offcanvas/index");
196
+ Object.keys(_index19).forEach(function (key) {
197
+ if (key === "default" || key === "__esModule") return;
198
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
199
+ if (key in exports && exports[key] === _index19[key]) return;
200
+ Object.defineProperty(exports, key, {
201
+ enumerable: true,
202
+ get: function get() {
203
+ return _index19[key];
204
+ }
205
+ });
206
+ });
195
207
  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); }
196
208
  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; }
@@ -0,0 +1,173 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useOffcanvas = exports.Offcanvas = void 0;
7
+ var _react = _interopRequireWildcard(require("react"));
8
+ var _propTypes = _interopRequireDefault(require("prop-types"));
9
+ var _button = require("../button");
10
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
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 && {}.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 _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); }
14
+ 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); }
15
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
16
+ 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."); }
17
+ 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; } }
18
+ 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; }
19
+ 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; } }
20
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
21
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
22
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
23
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
24
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
25
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
26
+ var Offcanvas = exports.Offcanvas = /*#__PURE__*/_react["default"].memo(function (_ref) {
27
+ var show = _ref.show,
28
+ onHide = _ref.onHide,
29
+ position = _ref.position,
30
+ children = _ref.children,
31
+ _ref$size = _ref.size,
32
+ size = _ref$size === void 0 ? 300 : _ref$size;
33
+ // backdrop style
34
+ var backdropStyle = (0, _react.useMemo)(function () {
35
+ return {
36
+ position: "fixed",
37
+ top: 0,
38
+ left: 0,
39
+ width: "100vw",
40
+ height: "100vh",
41
+ backgroundColor: "rgba(0,0,0,0.1)",
42
+ zIndex: 999
43
+ };
44
+ }, []);
45
+
46
+ // offcanvas container style
47
+ var containerStyle = (0, _react.useMemo)(function () {
48
+ var base = {
49
+ position: "fixed",
50
+ backgroundColor: "#fff",
51
+ boxShadow: "0 0.5rem 1rem rgba(0,0,0,0.15)",
52
+ transition: "transform 0.3s ease-out",
53
+ zIndex: 1000,
54
+ padding: 20,
55
+ overflow: "auto"
56
+ };
57
+ switch (position) {
58
+ case "end":
59
+ return _objectSpread(_objectSpread({}, base), {}, {
60
+ top: 0,
61
+ bottom: 0,
62
+ right: 0,
63
+ width: size,
64
+ transform: show ? "translateX(0)" : "translateX(100%)"
65
+ });
66
+ case "top":
67
+ return _objectSpread(_objectSpread({}, base), {}, {
68
+ left: 0,
69
+ right: 0,
70
+ top: 0,
71
+ height: size,
72
+ transform: show ? "translateY(0)" : "translateY(-100%)"
73
+ });
74
+ case "bottom":
75
+ return _objectSpread(_objectSpread({}, base), {}, {
76
+ left: 0,
77
+ right: 0,
78
+ bottom: 0,
79
+ height: size,
80
+ transform: show ? "translateY(0)" : "translateY(100%)"
81
+ });
82
+ case "start":
83
+ default:
84
+ return _objectSpread(_objectSpread({}, base), {}, {
85
+ top: 0,
86
+ bottom: 0,
87
+ left: 0,
88
+ width: size,
89
+ transform: show ? "translateX(0)" : "translateX(-100%)"
90
+ });
91
+ }
92
+ }, [position, show]);
93
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, show && /*#__PURE__*/_react["default"].createElement("div", {
94
+ style: backdropStyle,
95
+ onClick: onHide
96
+ }), /*#__PURE__*/_react["default"].createElement("div", {
97
+ style: containerStyle,
98
+ role: "dialog",
99
+ "aria-hidden": !show
100
+ }, children));
101
+ });
102
+ Offcanvas.displayName = "Offcanvas";
103
+ Offcanvas.propTypes = {
104
+ /** Show or hide the offcanvas */
105
+ show: _propTypes["default"].bool.isRequired,
106
+ /** Callback when the backdrop is clicked */
107
+ onHide: _propTypes["default"].func.isRequired,
108
+ /** Position: 'start' (left), 'end' (right), 'top', or 'bottom' */
109
+ position: _propTypes["default"].oneOf(["start", "end", "top", "bottom"]),
110
+ /** Content inside the offcanvas */
111
+ children: _propTypes["default"].node
112
+ };
113
+ Offcanvas.defaultProps = {
114
+ position: "start",
115
+ children: null
116
+ };
117
+ var useOffcanvas = exports.useOffcanvas = function useOffcanvas() {
118
+ var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
119
+ var _useState = (0, _react.useState)({
120
+ show: false,
121
+ resolve: null,
122
+ content: options.content || null,
123
+ position: options.position || "start"
124
+ }),
125
+ _useState2 = _slicedToArray(_useState, 2),
126
+ state = _useState2[0],
127
+ setState = _useState2[1];
128
+ var offcanvas = (0, _react.useCallback)(function () {
129
+ var newOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
130
+ return new Promise(function (resolve) {
131
+ setState(function (prev) {
132
+ var _newOptions$content, _newOptions$position;
133
+ return _objectSpread(_objectSpread({}, prev), {}, {
134
+ show: true,
135
+ resolve: resolve,
136
+ content: (_newOptions$content = newOptions.content) !== null && _newOptions$content !== void 0 ? _newOptions$content : prev.content,
137
+ position: (_newOptions$position = newOptions.position) !== null && _newOptions$position !== void 0 ? _newOptions$position : prev.position
138
+ });
139
+ });
140
+ });
141
+ }, []);
142
+ var close = (0, _react.useCallback)(function () {
143
+ if (state.resolve) {
144
+ state.resolve();
145
+ }
146
+ setState(function (prev) {
147
+ return _objectSpread(_objectSpread({}, prev), {}, {
148
+ show: false,
149
+ resolve: null
150
+ });
151
+ });
152
+ }, [state.resolve]);
153
+ var OffcanvasElement = /*#__PURE__*/_react["default"].createElement(Offcanvas, _extends({
154
+ show: state.show,
155
+ onHide: close,
156
+ position: state.position
157
+ }, options.offcanvasProps || {}), /*#__PURE__*/_react["default"].createElement(_button.Button, {
158
+ type: "button",
159
+ className: "btn-close",
160
+ "aria-label": "Close",
161
+ onClick: close,
162
+ style: {
163
+ position: "absolute",
164
+ top: 10,
165
+ right: 10
166
+ }
167
+ }), state.content);
168
+ return {
169
+ offcanvas: offcanvas,
170
+ OffcanvasElement: OffcanvasElement,
171
+ close: close
172
+ };
173
+ };
package/docs/package.json CHANGED
@@ -22,7 +22,7 @@
22
22
  "react": "^18.2.0",
23
23
  "react-dom": "^18.2.0",
24
24
  "styled-components": "^6.1.15",
25
- "tabler-react-2": "^0.1.96"
25
+ "tabler-react-2": "^0.1.97"
26
26
  },
27
27
  "devDependencies": {},
28
28
  "keywords": [
@@ -6,6 +6,8 @@
6
6
  link: "/getting-started"
7
7
  - label: "Theme"
8
8
  link: "/theme"
9
+ - label: "Changelog"
10
+ link: "/changelog"
9
11
  - label: "Components"
10
12
  items:
11
13
  - label: "Typography"
@@ -0,0 +1,8 @@
1
+ ---
2
+ title: Changelog
3
+ ---
4
+
5
+ ## 0.1.97
6
+
7
+ - Added `helpText`, `helpTextPlacement`, `helpPrompt`, `required`, `hint`, and `labelDescription` props to the `Input` component.
8
+ - Updated the `TablerProvider` component to use the latest version of the Tabler core library. (migrated from `1.0.0-beta17` to `1.2.0`)
@@ -444,6 +444,7 @@ You can supply a `helpText` prop to the `Input` component to show a help text be
444
444
  label="Input"
445
445
  placeholder="Type here..."
446
446
  helpText="This is some help text"
447
+ helpPrompt="?"
447
448
  />
448
449
  </Excerpt>
449
450
 
@@ -454,3 +455,39 @@ You can supply a `helpText` prop to the `Input` component to show a help text be
454
455
  helpText="This is some help text"
455
456
  />
456
457
  ```
458
+
459
+ ## Required
460
+
461
+ You can supply a `required` prop to the `Input` component to show a red asterisk next to the label.
462
+
463
+ <Excerpt>
464
+ <Input label="Input" placeholder="Type here..." required />
465
+ </Excerpt>
466
+
467
+ ```jsx
468
+ <Input label="Input" placeholder="Type here..." required />
469
+ ```
470
+
471
+ ## Hint
472
+
473
+ You can supply a `hint` prop to the `Input` component to show a hint below the input.
474
+
475
+ <Excerpt>
476
+ <Input label="Input" placeholder="Type here..." hint="This is a hint" />
477
+ </Excerpt>
478
+
479
+ ```jsx
480
+ <Input label="Input" placeholder="Type here..." hint="This is a hint" />
481
+ ```
482
+
483
+ ## Label Description
484
+
485
+ You can supply a `labelDescription` prop to the `Input` component to show a description to the right of the label.
486
+
487
+ <Excerpt>
488
+ <Input label="Input" placeholder="Type here..." labelDescription="37/100" />
489
+ </Excerpt>
490
+
491
+ ```jsx
492
+ <Input label="Input" placeholder="Type here..." labelDescription="37/100" />
493
+ ```
@@ -5,8 +5,6 @@ title: Typography
5
5
  import { Typography, Card } from "../../components/LoadableTabler";
6
6
  import { Excerpt } from "../../components/Excerpt.jsx";
7
7
 
8
- # Typography
9
-
10
8
  ```jsx
11
9
  import { Typography } from "tabler-react-2";
12
10
  ```
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "tabler-react-2",
3
- "version": "0.1.97",
3
+ "version": "0.1.99",
4
4
  "description": "A react implementation of Tabler ui",
5
5
  "main": "dist/index.js",
6
6
  "scripts": {