linear-react-components-ui 1.1.20-beta.8 → 1.1.20-rc.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/lib/alerts/BaseAlert.js +1 -1
- package/lib/alerts/Message.js +1 -1
- package/lib/assets/styles/effects.scss +0 -2
- package/lib/assets/styles/input.scss +2 -2
- package/lib/assets/styles/popover.scss +3 -0
- package/lib/assets/styles/select.scss +2 -1
- package/lib/assets/styles/treetable.scss +2 -2
- package/lib/assets/styles/treeview.scss +24 -8
- package/lib/assets/styles/wizard.scss +127 -0
- package/lib/avatar/index.js +9 -8
- package/lib/badge/index.js +4 -4
- package/lib/buttons/DangerButton.js +1 -1
- package/lib/buttons/DefaultButton.js +24 -4
- package/lib/buttons/InfoButton.js +1 -1
- package/lib/buttons/PrimaryButton.js +1 -1
- package/lib/buttons/SuccessButton.js +1 -1
- package/lib/buttons/WarningButton.js +1 -1
- package/lib/buttons/button_container/index.js +1 -1
- package/lib/buttons/split_button/index.js +1 -1
- package/lib/calendar/base/Day.js +1 -1
- package/lib/calendar/base/Month.js +1 -1
- package/lib/calendar/base/helpers.js +2 -2
- package/lib/calendar/base/index.js +1 -1
- package/lib/checkbox/index.js +46 -19
- package/lib/checkbox/types.d.ts +4 -0
- package/lib/dialog/Alert.js +6 -2
- package/lib/dialog/Custom.js +4 -2
- package/lib/dialog/Error.js +6 -2
- package/lib/dialog/Information.js +6 -2
- package/lib/dialog/Question.js +23 -5
- package/lib/dialog/Warning.js +6 -2
- package/lib/dialog/base/Content.d.ts +1 -1
- package/lib/dialog/base/Content.js +3 -2
- package/lib/dialog/base/Header.js +2 -2
- package/lib/dialog/base/index.js +12 -9
- package/lib/dialog/form/index.js +8 -3
- package/lib/dialog/types.d.ts +44 -4
- package/lib/dialog/wizard/index.d.ts +13 -0
- package/lib/dialog/wizard/index.js +78 -0
- package/lib/dialog/wizard/progressbar.d.ts +13 -0
- package/lib/dialog/wizard/progressbar.js +36 -0
- package/lib/dialog/wizard/step.d.ts +9 -0
- package/lib/dialog/wizard/step.js +22 -0
- package/lib/dialog/wizard/useWizard.d.ts +9 -0
- package/lib/dialog/wizard/useWizard.js +48 -0
- package/lib/drawer/Drawer.js +3 -3
- package/lib/drawer/Header.js +1 -1
- package/lib/dropdown/Popup.js +6 -6
- package/lib/dropdown/helper.js +1 -1
- package/lib/dropdown/withDropdown.js +2 -2
- package/lib/fieldset/index.js +7 -7
- package/lib/form/FieldArray.js +1 -1
- package/lib/form/FieldNumber.js +7 -10
- package/lib/form/FieldPeriod.js +2 -2
- package/lib/form/index.js +20 -15
- package/lib/form/types.d.ts +14 -1
- package/lib/gridlayout/GridCol.js +5 -5
- package/lib/gridlayout/GridRow.js +4 -1
- package/lib/hint/index.js +7 -1
- package/lib/icons/helper.d.ts +20 -0
- package/lib/icons/helper.js +20 -0
- package/lib/icons/index.js +24 -27
- package/lib/inputs/base/InputTextBase.js +39 -15
- package/lib/inputs/base/Label.js +1 -1
- package/lib/inputs/base/helpers.js +7 -3
- package/lib/inputs/base/types.d.ts +3 -0
- package/lib/inputs/color/types.d.ts +5 -0
- package/lib/inputs/date/helpers.js +4 -1
- package/lib/inputs/date/index.js +9 -15
- package/lib/inputs/date/types.d.ts +4 -0
- package/lib/inputs/errorMessage/index.js +1 -1
- package/lib/inputs/file/DefaultFile.js +5 -6
- package/lib/inputs/file/DragDropFile.js +17 -18
- package/lib/inputs/file/File.js +3 -4
- package/lib/inputs/file/types.d.ts +3 -0
- package/lib/inputs/mask/BaseMask.js +4 -1
- package/lib/inputs/mask/helpers.d.ts +4 -0
- package/lib/inputs/mask/types.d.ts +4 -0
- package/lib/inputs/multiSelect/Dropdown.js +9 -10
- package/lib/inputs/multiSelect/helper.js +1 -2
- package/lib/inputs/multiSelect/index.js +7 -9
- package/lib/inputs/multiSelect/types.d.ts +4 -0
- package/lib/inputs/number/BaseNumber.d.ts +1 -1
- package/lib/inputs/number/Currency.d.ts +1 -1
- package/lib/inputs/number/Decimal.d.ts +1 -1
- package/lib/inputs/number/index.d.ts +1 -1
- package/lib/inputs/number/index.js +8 -4
- package/lib/inputs/number/types.d.ts +14 -2
- package/lib/inputs/period/PeriodList.js +1 -1
- package/lib/inputs/period/helper.js +3 -1
- package/lib/inputs/period/index.js +40 -18
- package/lib/inputs/period/types.d.ts +3 -0
- package/lib/inputs/search/index.js +1 -1
- package/lib/inputs/select/Dropdown.js +1 -1
- package/lib/inputs/select/helper.js +10 -13
- package/lib/inputs/select/multiple/Selecteds.js +1 -1
- package/lib/inputs/select/multiple/index.js +22 -18
- package/lib/inputs/select/simple/index.js +15 -20
- package/lib/inputs/select/types.d.ts +7 -0
- package/lib/inputs/textarea/index.js +1 -1
- package/lib/internals/withTooltip.js +9 -9
- package/lib/labelMessages/index.js +4 -3
- package/lib/labels/DefaultLabel.js +4 -1
- package/lib/labels/label_container/index.js +1 -1
- package/lib/list/Header.d.ts +1 -0
- package/lib/list/Header.js +1 -1
- package/lib/list/Item.d.ts +6 -2
- package/lib/list/Item.js +36 -14
- package/lib/list/helpers.d.ts +1 -0
- package/lib/list/index.d.ts +1 -0
- package/lib/list/index.js +3 -2
- package/lib/list/types.d.ts +8 -1
- package/lib/menus/float/MenuItem.js +2 -2
- package/lib/menus/float/SubMenuContainer.js +1 -1
- package/lib/menus/float/index.js +1 -1
- package/lib/menus/sidenav/ExpandMenu.js +1 -1
- package/lib/menus/sidenav/NavMenuGroup.js +1 -1
- package/lib/menus/sidenav/NavMenuItem.js +27 -25
- package/lib/menus/sidenav/NavSubMenuItem.js +1 -1
- package/lib/menus/sidenav/helpers.js +1 -1
- package/lib/menus/sidenav/index.js +39 -31
- package/lib/menus/sidenav/types.d.ts +1 -0
- package/lib/panel/Content.js +5 -7
- package/lib/panel/Default.js +2 -2
- package/lib/panel/Header.js +3 -3
- package/lib/permissionValidations.js +1 -1
- package/lib/popover/index.js +4 -6
- package/lib/popover/types.d.ts +2 -1
- package/lib/progress/Bar.js +6 -6
- package/lib/radio/index.d.ts +1 -1
- package/lib/radio/index.js +36 -5
- package/lib/radio/types.d.ts +8 -1
- package/lib/shortcuts/index.js +1 -1
- package/lib/skeleton/SkeletonContainer.js +2 -1
- package/lib/skeleton/index.js +4 -1
- package/lib/spinner/index.js +2 -2
- package/lib/split/Split.js +1 -1
- package/lib/split/SplitSide.js +3 -3
- package/lib/table/Body.js +3 -3
- package/lib/table/Header.js +8 -11
- package/lib/table/HeaderColumn.js +7 -7
- package/lib/table/Row.js +3 -3
- package/lib/table/RowColumn.js +1 -1
- package/lib/table/index.js +6 -1
- package/lib/table/types.d.ts +0 -2
- package/lib/tabs/DropdownTabs.js +1 -1
- package/lib/tabs/Menu.js +1 -1
- package/lib/tabs/MenuTabs.js +2 -2
- package/lib/tabs/Panel.js +5 -7
- package/lib/tabs/context.js +3 -6
- package/lib/textContent/index.d.ts +18 -4
- package/lib/textContent/index.js +18 -6
- package/lib/toolbar/ButtonBar.js +1 -1
- package/lib/toolbar/index.js +1 -1
- package/lib/tooltip/index.js +7 -7
- package/lib/treetable/Body.js +1 -1
- package/lib/treetable/Header.js +2 -2
- package/lib/treetable/Row.d.ts +1 -1
- package/lib/treetable/Row.js +50 -25
- package/lib/treetable/helpers.d.ts +1 -1
- package/lib/treetable/index.d.ts +2 -2
- package/lib/treeview/Header.js +1 -1
- package/lib/treeview/Node.js +5 -5
- package/lib/treeview/index.js +4 -4
- package/lib/{types.d-73cece43.d.ts → types.d-b477e076.d.ts} +1 -0
- package/lib/uitour/index.js +6 -8
- package/package.json +2 -2
- package/lib/checkbox/Label.d.ts +0 -11
- package/lib/checkbox/Label.js +0 -31
- package/lib/inputs/mask/imaskHOC.js +0 -203
- package/lib/menus/sidenav/popup_menu_help/index.js +0 -85
- package/lib/tabs/DropdownItems.js +0 -62
- package/lib/tabs/MenuItems.js +0 -70
- package/lib/treeview_old/Header.js +0 -29
- package/lib/treeview_old/Node.js +0 -68
- package/lib/treeview_old/index.js +0 -43
package/lib/dialog/Alert.js
CHANGED
|
@@ -11,10 +11,14 @@ var _icons = _interopRequireDefault(require("../icons"));
|
|
|
11
11
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
12
|
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); }
|
|
13
13
|
const Alert = props => {
|
|
14
|
+
const {
|
|
15
|
+
onConfirmClick,
|
|
16
|
+
confirmLabel = 'Confirmar'
|
|
17
|
+
} = props;
|
|
14
18
|
const buttons = [/*#__PURE__*/_react.default.createElement(_buttons.PrimaryButton, {
|
|
15
19
|
key: "confirm-buttom",
|
|
16
|
-
onClick:
|
|
17
|
-
label:
|
|
20
|
+
onClick: onConfirmClick,
|
|
21
|
+
label: confirmLabel
|
|
18
22
|
})];
|
|
19
23
|
return /*#__PURE__*/_react.default.createElement(_Custom.default, _extends({}, props, {
|
|
20
24
|
buttons: buttons,
|
package/lib/dialog/Custom.js
CHANGED
|
@@ -30,9 +30,11 @@ const Custom = props => {
|
|
|
30
30
|
const {
|
|
31
31
|
width = '35%',
|
|
32
32
|
height = 'auto',
|
|
33
|
-
iconName = null
|
|
33
|
+
iconName = null,
|
|
34
|
+
open
|
|
34
35
|
} = props;
|
|
35
36
|
return /*#__PURE__*/_react.default.createElement(_base.default, _extends({
|
|
37
|
+
open: open,
|
|
36
38
|
width: width,
|
|
37
39
|
height: height
|
|
38
40
|
}, props, {
|
|
@@ -48,7 +50,7 @@ const Custom = props => {
|
|
|
48
50
|
}, props.text)), props.buttons && props.buttons.length > 0 && /*#__PURE__*/_react.default.createElement(_Footer.default, props, /*#__PURE__*/_react.default.createElement(_buttons.ButtonContainer, {
|
|
49
51
|
position: "right"
|
|
50
52
|
}, props.buttons.map(button => /*#__PURE__*/_react.default.cloneElement(button, {
|
|
51
|
-
key:
|
|
53
|
+
key: `button-${uuid.v1()}`
|
|
52
54
|
})))));
|
|
53
55
|
};
|
|
54
56
|
var _default = exports.default = Custom;
|
package/lib/dialog/Error.js
CHANGED
|
@@ -11,10 +11,14 @@ var _icons = _interopRequireDefault(require("../../lib/icons"));
|
|
|
11
11
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
12
|
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); }
|
|
13
13
|
const Error = props => {
|
|
14
|
+
const {
|
|
15
|
+
onConfirmClick,
|
|
16
|
+
confirmLabel = 'Confirmar'
|
|
17
|
+
} = props;
|
|
14
18
|
const buttons = [/*#__PURE__*/_react.default.createElement(_buttons.PrimaryButton, {
|
|
15
19
|
key: "confirm-buttom",
|
|
16
|
-
onClick:
|
|
17
|
-
label:
|
|
20
|
+
onClick: onConfirmClick,
|
|
21
|
+
label: confirmLabel
|
|
18
22
|
})];
|
|
19
23
|
return /*#__PURE__*/_react.default.createElement(_Custom.default, _extends({}, props, {
|
|
20
24
|
buttons: buttons,
|
|
@@ -11,10 +11,14 @@ var _icons = _interopRequireDefault(require("../../lib/icons"));
|
|
|
11
11
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
12
|
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); }
|
|
13
13
|
const Information = props => {
|
|
14
|
+
const {
|
|
15
|
+
onConfirmClick,
|
|
16
|
+
confirmLabel = 'Confirmar'
|
|
17
|
+
} = props;
|
|
14
18
|
const buttons = [/*#__PURE__*/_react.default.createElement(_buttons.PrimaryButton, {
|
|
15
19
|
key: "confirm-buttom",
|
|
16
|
-
onClick:
|
|
17
|
-
label:
|
|
20
|
+
onClick: onConfirmClick,
|
|
21
|
+
label: confirmLabel
|
|
18
22
|
})];
|
|
19
23
|
return /*#__PURE__*/_react.default.createElement(_Custom.default, _extends({}, props, {
|
|
20
24
|
buttons: buttons,
|
package/lib/dialog/Question.js
CHANGED
|
@@ -4,36 +4,54 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
var _react =
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
8
|
var _buttons = _interopRequireWildcard(require("../buttons"));
|
|
9
9
|
var _Custom = _interopRequireDefault(require("./Custom"));
|
|
10
10
|
var _icons = _interopRequireDefault(require("../icons"));
|
|
11
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
12
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
12
13
|
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 _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
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
15
|
const Question = props => {
|
|
16
16
|
const {
|
|
17
17
|
visible = true,
|
|
18
|
+
closeOnEsc = false,
|
|
18
19
|
isWaiting,
|
|
19
20
|
onConfirmClick,
|
|
20
|
-
onUnconfirmClick
|
|
21
|
+
onUnconfirmClick,
|
|
22
|
+
confirmLabel = 'Sim',
|
|
23
|
+
declineLabel = 'Não'
|
|
21
24
|
} = props;
|
|
25
|
+
const idUnconfirm = 'botao-unconfirm-click';
|
|
22
26
|
const buttons = [/*#__PURE__*/_react.default.createElement(_buttons.DangerButton, {
|
|
23
27
|
key: "yes-buttom",
|
|
24
28
|
disabled: isWaiting,
|
|
25
29
|
onClick: onConfirmClick,
|
|
26
30
|
isLoading: isWaiting,
|
|
27
|
-
label:
|
|
31
|
+
label: confirmLabel
|
|
28
32
|
}), /*#__PURE__*/_react.default.createElement(_buttons.default, {
|
|
33
|
+
id: idUnconfirm,
|
|
29
34
|
key: "no-buttom",
|
|
30
35
|
disabled: isWaiting,
|
|
31
36
|
onClick: onUnconfirmClick,
|
|
32
|
-
label:
|
|
37
|
+
label: declineLabel
|
|
33
38
|
})];
|
|
39
|
+
(0, _react.useLayoutEffect)(() => {
|
|
40
|
+
const lastElementActive = document.activeElement;
|
|
41
|
+
return () => {
|
|
42
|
+
lastElementActive?.focus?.();
|
|
43
|
+
};
|
|
44
|
+
}, [visible]);
|
|
45
|
+
(0, _react.useEffect)(() => {
|
|
46
|
+
const buttonUnconfirm = document.getElementById(idUnconfirm);
|
|
47
|
+
buttonUnconfirm?.focus?.();
|
|
48
|
+
}, [visible, document.activeElement]);
|
|
34
49
|
if (!visible) return null;
|
|
35
50
|
return /*#__PURE__*/_react.default.createElement(_Custom.default, _extends({}, props, {
|
|
51
|
+
open: visible,
|
|
36
52
|
buttons: buttons,
|
|
53
|
+
closeOnEsc: closeOnEsc,
|
|
54
|
+
handlerClose: onUnconfirmClick,
|
|
37
55
|
icon: /*#__PURE__*/_react.default.createElement(_icons.default, {
|
|
38
56
|
name: "question",
|
|
39
57
|
color: "#3498db",
|
package/lib/dialog/Warning.js
CHANGED
|
@@ -11,9 +11,13 @@ var _icons = _interopRequireDefault(require("../../lib/icons"));
|
|
|
11
11
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
12
|
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); }
|
|
13
13
|
const Warning = props => {
|
|
14
|
+
const {
|
|
15
|
+
onConfirmClick,
|
|
16
|
+
confirmLabel = 'Confirmar'
|
|
17
|
+
} = props;
|
|
14
18
|
const buttons = [/*#__PURE__*/_react.default.createElement(_buttons.PrimaryButton, {
|
|
15
|
-
onClick:
|
|
16
|
-
label:
|
|
19
|
+
onClick: onConfirmClick,
|
|
20
|
+
label: confirmLabel,
|
|
17
21
|
key: 1
|
|
18
22
|
})];
|
|
19
23
|
return /*#__PURE__*/_react.default.createElement(_Custom.default, _extends({}, props, {
|
|
@@ -4,6 +4,6 @@ import '../../@types/Align.js';
|
|
|
4
4
|
import '../../@types/Icon.js';
|
|
5
5
|
import '../../icons/helper.js';
|
|
6
6
|
|
|
7
|
-
declare const Content: ({ children, styleForContent }: IContentProps) => JSX.Element;
|
|
7
|
+
declare const Content: ({ children, styleForContent, className }: IContentProps) => JSX.Element;
|
|
8
8
|
|
|
9
9
|
export { Content as default };
|
|
@@ -10,11 +10,12 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
|
|
|
10
10
|
const Content = _ref => {
|
|
11
11
|
let {
|
|
12
12
|
children,
|
|
13
|
-
styleForContent
|
|
13
|
+
styleForContent,
|
|
14
|
+
className = ''
|
|
14
15
|
} = _ref;
|
|
15
16
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
16
17
|
id: "modal-dialog-content",
|
|
17
|
-
className:
|
|
18
|
+
className: `dialog-content ${className}`,
|
|
18
19
|
style: styleForContent
|
|
19
20
|
}, children);
|
|
20
21
|
};
|
|
@@ -46,10 +46,10 @@ const Header = _ref => {
|
|
|
46
46
|
tabIndex: -1,
|
|
47
47
|
onFocus: () => {},
|
|
48
48
|
onBlur: () => {},
|
|
49
|
-
ref: formDialogContext
|
|
49
|
+
ref: formDialogContext?.headerRef,
|
|
50
50
|
className: "dialog-header"
|
|
51
51
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
52
|
-
className:
|
|
52
|
+
className: `${icon !== null || titleIcon !== null ? 'left' : ''}`
|
|
53
53
|
}, getIcon(titleIcon, icon)), /*#__PURE__*/_react.default.createElement("div", {
|
|
54
54
|
className: "right"
|
|
55
55
|
}, /*#__PURE__*/_react.default.createElement("h5", {
|
package/lib/dialog/base/index.js
CHANGED
|
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.default = exports.DialogContext = void 0;
|
|
7
7
|
var _react = _interopRequireWildcard(require("react"));
|
|
8
8
|
var _reactDom = _interopRequireDefault(require("react-dom"));
|
|
9
|
+
var uuid = _interopRequireWildcard(require("uuid"));
|
|
9
10
|
var _style = _interopRequireDefault(require("./style"));
|
|
10
11
|
require("../../assets/styles/dialog.scss");
|
|
11
12
|
var _form = require("../form");
|
|
@@ -17,11 +18,14 @@ const {
|
|
|
17
18
|
body
|
|
18
19
|
} = document;
|
|
19
20
|
const BaseDialog = props => {
|
|
21
|
+
const baseDialogId = uuid.v4();
|
|
20
22
|
const {
|
|
23
|
+
id = baseDialogId,
|
|
21
24
|
overlay = true,
|
|
22
25
|
closeOnEsc,
|
|
23
26
|
closeOnOutsideClick,
|
|
24
|
-
wrapperClassName,
|
|
27
|
+
wrapperClassName = '',
|
|
28
|
+
className = '',
|
|
25
29
|
children,
|
|
26
30
|
open: openProp,
|
|
27
31
|
onOpenChange,
|
|
@@ -42,9 +46,7 @@ const BaseDialog = props => {
|
|
|
42
46
|
onOpenChange(false);
|
|
43
47
|
} else {
|
|
44
48
|
if (handlerClose) handlerClose();
|
|
45
|
-
if (onOpenChange)
|
|
46
|
-
onOpenChange(false);
|
|
47
|
-
}
|
|
49
|
+
if (onOpenChange) onOpenChange(false);
|
|
48
50
|
}
|
|
49
51
|
};
|
|
50
52
|
const handleClickOutside = event => {
|
|
@@ -56,7 +58,8 @@ const BaseDialog = props => {
|
|
|
56
58
|
}
|
|
57
59
|
};
|
|
58
60
|
const handleCloseOnEsc = event => {
|
|
59
|
-
if (event
|
|
61
|
+
if (event?.key === 'Escape') {
|
|
62
|
+
event.stopPropagation();
|
|
60
63
|
handleClose();
|
|
61
64
|
}
|
|
62
65
|
};
|
|
@@ -74,7 +77,7 @@ const BaseDialog = props => {
|
|
|
74
77
|
let y = positionY <= 0 ? 0 : positionY;
|
|
75
78
|
if (x + width >= window.innerWidth) x = window.innerWidth - width;
|
|
76
79
|
if (y + height >= window.innerHeight) y = window.innerHeight - height;
|
|
77
|
-
wrapperEl.current.style.transform =
|
|
80
|
+
wrapperEl.current.style.transform = `translate(${x}px, ${y}px)`;
|
|
78
81
|
wrapperEl.current.style.transition = 'none';
|
|
79
82
|
wrapperEl.current.style.left = '0';
|
|
80
83
|
wrapperEl.current.style.top = '0';
|
|
@@ -94,15 +97,15 @@ const BaseDialog = props => {
|
|
|
94
97
|
}
|
|
95
98
|
};
|
|
96
99
|
const onMouseDown = event => {
|
|
97
|
-
var _headerRef$current;
|
|
98
100
|
const element = event.target;
|
|
99
|
-
const isHeader = headerRef
|
|
101
|
+
const isHeader = headerRef?.current?.contains(element);
|
|
100
102
|
if (wrapperEl.current && isHeader) setIsDragging(true);
|
|
101
103
|
};
|
|
102
104
|
const onMouseUp = () => {
|
|
103
105
|
if (wrapperEl.current) setIsDragging(false);
|
|
104
106
|
};
|
|
105
107
|
const createdModal = /*#__PURE__*/_react.default.createElement("div", {
|
|
108
|
+
id: id,
|
|
106
109
|
className: "modalcontainer",
|
|
107
110
|
onMouseDown: handleClickOutside,
|
|
108
111
|
style: {
|
|
@@ -112,7 +115,7 @@ const BaseDialog = props => {
|
|
|
112
115
|
className: "modal-overlay",
|
|
113
116
|
"data-testid": "modal-overlay"
|
|
114
117
|
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
115
|
-
className:
|
|
118
|
+
className: `dialog ${className}`,
|
|
116
119
|
"data-testid": "dialog-component"
|
|
117
120
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
118
121
|
className: wrapperClassName,
|
package/lib/dialog/form/index.js
CHANGED
|
@@ -29,7 +29,10 @@ const ModalForm = props => {
|
|
|
29
29
|
width = '50%',
|
|
30
30
|
height = '50%',
|
|
31
31
|
content,
|
|
32
|
-
children
|
|
32
|
+
children,
|
|
33
|
+
className = '',
|
|
34
|
+
wrapperClassName = '',
|
|
35
|
+
contentClassName = ''
|
|
33
36
|
} = props;
|
|
34
37
|
const headerRef = (0, _react.useRef)(null);
|
|
35
38
|
const context = (0, _react.useContext)(_withFormSecurity.FormSecurityContext);
|
|
@@ -56,7 +59,8 @@ const ModalForm = props => {
|
|
|
56
59
|
width: width,
|
|
57
60
|
height: height
|
|
58
61
|
}, props, {
|
|
59
|
-
|
|
62
|
+
className: className,
|
|
63
|
+
wrapperClassName: `dialog-form-wrapper ${wrapperClassName}`
|
|
60
64
|
}), props.title && /*#__PURE__*/_react.default.createElement("div", {
|
|
61
65
|
className: "header-form"
|
|
62
66
|
}, /*#__PURE__*/_react.default.createElement(_Header.default, {
|
|
@@ -64,7 +68,8 @@ const ModalForm = props => {
|
|
|
64
68
|
handlerClose: props.handlerClose,
|
|
65
69
|
icon: props.icon
|
|
66
70
|
})), /*#__PURE__*/_react.default.createElement(_Content.default, {
|
|
67
|
-
styleForContent: _objectSpread(_objectSpread({}, props.styleForContent), overlayStyle)
|
|
71
|
+
styleForContent: _objectSpread(_objectSpread({}, props.styleForContent), overlayStyle),
|
|
72
|
+
className: contentClassName
|
|
68
73
|
}, content || children), getSpinner(), showFooter && props.buttons && /*#__PURE__*/_react.default.createElement(_Footer.default, null, /*#__PURE__*/_react.default.createElement(_index.ButtonContainer, _extends({}, props, {
|
|
69
74
|
style: _objectSpread({}, overlayStyle)
|
|
70
75
|
}), _react.default.Children.toArray(props.buttons.map(button => {
|
package/lib/dialog/types.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ReactNode, CSSProperties, ReactElement } from 'react';
|
|
1
|
+
import { ReactNode, CSSProperties, ReactElement, Dispatch } from 'react';
|
|
2
2
|
import { TextAlign } from '../@types/Align.js';
|
|
3
3
|
import { IconNames } from '../@types/Icon.js';
|
|
4
4
|
import '../icons/helper.js';
|
|
@@ -6,6 +6,7 @@ import '../icons/helper.js';
|
|
|
6
6
|
interface IContentProps {
|
|
7
7
|
children: ReactNode | ReactNode[];
|
|
8
8
|
styleForContent?: CSSProperties;
|
|
9
|
+
className?: string;
|
|
9
10
|
}
|
|
10
11
|
interface IFooterProps {
|
|
11
12
|
children: ReactElement | ReactElement[];
|
|
@@ -18,10 +19,11 @@ interface IHeaderProps {
|
|
|
18
19
|
titleIcon?: IconNames;
|
|
19
20
|
}
|
|
20
21
|
interface IBaseProps {
|
|
21
|
-
wrapperClassName
|
|
22
|
+
wrapperClassName?: string;
|
|
22
23
|
width?: string;
|
|
23
24
|
height?: string;
|
|
24
25
|
children: ReactNode | ReactNode[];
|
|
26
|
+
className?: string;
|
|
25
27
|
closeOnEsc?: boolean;
|
|
26
28
|
closeOnOutsideClick?: boolean;
|
|
27
29
|
overlay?: boolean;
|
|
@@ -30,8 +32,9 @@ interface IBaseProps {
|
|
|
30
32
|
open?: boolean;
|
|
31
33
|
onOpenChange?: (open: boolean) => void;
|
|
32
34
|
handlerClose?: () => void;
|
|
35
|
+
id?: string;
|
|
33
36
|
}
|
|
34
|
-
interface IFormProps extends Omit<IBaseProps, 'textAlign' | 'zIndex'
|
|
37
|
+
interface IFormProps extends Omit<IBaseProps, 'textAlign' | 'zIndex'> {
|
|
35
38
|
buttons?: JSX.Element[];
|
|
36
39
|
styleForContent?: CSSProperties;
|
|
37
40
|
title?: string;
|
|
@@ -39,11 +42,13 @@ interface IFormProps extends Omit<IBaseProps, 'textAlign' | 'zIndex' | 'wrapperC
|
|
|
39
42
|
isWaiting?: boolean;
|
|
40
43
|
icon?: JSX.Element;
|
|
41
44
|
content?: ReactNode;
|
|
45
|
+
contentClassName?: string;
|
|
42
46
|
}
|
|
43
47
|
interface ICommonDialogProps {
|
|
44
48
|
onConfirmClick?: () => void;
|
|
45
49
|
text?: string;
|
|
46
50
|
title?: string;
|
|
51
|
+
confirmLabel?: string;
|
|
47
52
|
}
|
|
48
53
|
interface IQuestionProps {
|
|
49
54
|
onUnconfirmClick: () => void;
|
|
@@ -53,6 +58,9 @@ interface IQuestionProps {
|
|
|
53
58
|
text?: string;
|
|
54
59
|
title?: string;
|
|
55
60
|
zIndex?: number | string;
|
|
61
|
+
closeOnEsc?: boolean;
|
|
62
|
+
confirmLabel?: string;
|
|
63
|
+
declineLabel?: string;
|
|
56
64
|
}
|
|
57
65
|
interface ICustomProps {
|
|
58
66
|
icon: ReactElement;
|
|
@@ -62,9 +70,41 @@ interface ICustomProps {
|
|
|
62
70
|
height?: string;
|
|
63
71
|
width?: string;
|
|
64
72
|
iconName?: IconNames | null;
|
|
73
|
+
open?: boolean;
|
|
74
|
+
closeOnEsc?: boolean;
|
|
75
|
+
handlerClose?: () => void;
|
|
65
76
|
}
|
|
66
77
|
interface IFormDialogContext {
|
|
67
78
|
headerRef?: React.RefObject<HTMLDivElement>;
|
|
68
79
|
}
|
|
80
|
+
interface WizardComponentProps extends Omit<IFormProps, 'content'> {
|
|
81
|
+
children: React.ReactNode;
|
|
82
|
+
buttons?: JSX.Element[];
|
|
83
|
+
showProgressbar?: boolean;
|
|
84
|
+
title?: string;
|
|
85
|
+
handlerClose?: () => void;
|
|
86
|
+
controls: WizardControls;
|
|
87
|
+
customStyleForProgressBar?: CSSProperties;
|
|
88
|
+
customStyleForBody?: CSSProperties;
|
|
89
|
+
}
|
|
90
|
+
interface WizardStepComponentProps {
|
|
91
|
+
children: React.ReactNode;
|
|
92
|
+
title: string;
|
|
93
|
+
customClass?: string;
|
|
94
|
+
customStyle?: CSSProperties;
|
|
95
|
+
}
|
|
96
|
+
interface WizardControls extends Omit<UseWizardReturn, 'controls'> {
|
|
97
|
+
setTotalSteps: Dispatch<React.SetStateAction<number>>;
|
|
98
|
+
}
|
|
99
|
+
interface UseWizardReturn {
|
|
100
|
+
changeStep: (nextStep: number) => void;
|
|
101
|
+
nextStep: () => void;
|
|
102
|
+
hasNextStep: boolean;
|
|
103
|
+
previousStep: () => void;
|
|
104
|
+
hasPreviousStep: boolean;
|
|
105
|
+
currentStep: number;
|
|
106
|
+
totalSteps: number;
|
|
107
|
+
controls: WizardControls;
|
|
108
|
+
}
|
|
69
109
|
|
|
70
|
-
export { IBaseProps, ICommonDialogProps, IContentProps, ICustomProps, IFooterProps, IFormDialogContext, IFormProps, IHeaderProps, IQuestionProps };
|
|
110
|
+
export { IBaseProps, ICommonDialogProps, IContentProps, ICustomProps, IFooterProps, IFormDialogContext, IFormProps, IHeaderProps, IQuestionProps, UseWizardReturn, WizardComponentProps, WizardControls, WizardStepComponentProps };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React__default from 'react';
|
|
2
|
+
import { WizardControls, WizardComponentProps } from '../types.js';
|
|
3
|
+
export { WizardStep as Step } from './step.js';
|
|
4
|
+
export { useWizard } from './useWizard.js';
|
|
5
|
+
import '../../@types/Align.js';
|
|
6
|
+
import '../../@types/Icon.js';
|
|
7
|
+
import '../../icons/helper.js';
|
|
8
|
+
|
|
9
|
+
declare const WizardContext: React__default.Context<WizardControls | null>;
|
|
10
|
+
declare const useWizardContext: () => WizardControls | null;
|
|
11
|
+
declare function Wizard({ children, controls, showProgressbar, customStyleForProgressBar, customStyleForBody, ...dialogProps }: Readonly<WizardComponentProps>): JSX.Element;
|
|
12
|
+
|
|
13
|
+
export { Wizard as Container, WizardContext, Wizard as default, useWizardContext };
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Container = Wizard;
|
|
7
|
+
Object.defineProperty(exports, "Step", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _step.WizardStep;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
exports.default = exports.WizardContext = void 0;
|
|
14
|
+
Object.defineProperty(exports, "useWizard", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
get: function () {
|
|
17
|
+
return _useWizard.useWizard;
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
exports.useWizardContext = void 0;
|
|
21
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
22
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
23
|
+
var _form = _interopRequireDefault(require("../form/"));
|
|
24
|
+
var _progressbar = require("./progressbar");
|
|
25
|
+
require("../../assets/styles/wizard.scss");
|
|
26
|
+
var _step = require("./step");
|
|
27
|
+
var _useWizard = require("./useWizard");
|
|
28
|
+
const _excluded = ["children", "controls", "showProgressbar", "customStyleForProgressBar", "customStyleForBody"];
|
|
29
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
30
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
31
|
+
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; }
|
|
32
|
+
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); }
|
|
33
|
+
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; }
|
|
34
|
+
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; }
|
|
35
|
+
const WizardContext = exports.WizardContext = /*#__PURE__*/_react.default.createContext(null);
|
|
36
|
+
const useWizardContext = () => _react.default.useContext(WizardContext);
|
|
37
|
+
exports.useWizardContext = useWizardContext;
|
|
38
|
+
function Wizard(_ref) {
|
|
39
|
+
let {
|
|
40
|
+
children,
|
|
41
|
+
controls,
|
|
42
|
+
showProgressbar = true,
|
|
43
|
+
customStyleForProgressBar,
|
|
44
|
+
customStyleForBody
|
|
45
|
+
} = _ref,
|
|
46
|
+
dialogProps = _objectWithoutProperties(_ref, _excluded);
|
|
47
|
+
const {
|
|
48
|
+
currentStep,
|
|
49
|
+
setTotalSteps
|
|
50
|
+
} = controls;
|
|
51
|
+
const steps = _react.default.Children.toArray(children);
|
|
52
|
+
const stepsTitle = steps.map((step, index) => {
|
|
53
|
+
return {
|
|
54
|
+
title: String(step.props.title),
|
|
55
|
+
number: index + 1,
|
|
56
|
+
completed: index < currentStep - 1 && index !== currentStep
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
const currentStepElement = steps[currentStep - 1];
|
|
60
|
+
if (!controls || _lodash.default.isEmpty(controls)) throw new Error('Wizard must be have controls by using useWizard hook or creating manually.');
|
|
61
|
+
(0, _react.useEffect)(() => {
|
|
62
|
+
setTotalSteps(steps.length);
|
|
63
|
+
}, [steps.length]);
|
|
64
|
+
return /*#__PURE__*/_react.default.createElement(WizardContext.Provider, {
|
|
65
|
+
value: controls
|
|
66
|
+
}, /*#__PURE__*/_react.default.createElement(_form.default, _extends({
|
|
67
|
+
className: "wizard-dialog",
|
|
68
|
+
wrapperClassName: "wizard-wrapper",
|
|
69
|
+
contentClassName: "wizard-content"
|
|
70
|
+
}, dialogProps), showProgressbar && /*#__PURE__*/_react.default.createElement(_progressbar.Progressbar, {
|
|
71
|
+
stepsTitle: stepsTitle,
|
|
72
|
+
customStyle: customStyleForProgressBar
|
|
73
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
74
|
+
className: "wizard-body",
|
|
75
|
+
style: customStyleForBody
|
|
76
|
+
}, currentStepElement)));
|
|
77
|
+
}
|
|
78
|
+
var _default = exports.default = Wizard;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { CSSProperties } from 'react';
|
|
2
|
+
|
|
3
|
+
declare function Progressbar({ customClass, customStyle, stepsTitle }: Readonly<{
|
|
4
|
+
customClass?: string;
|
|
5
|
+
stepsTitle: {
|
|
6
|
+
title: string;
|
|
7
|
+
number: number;
|
|
8
|
+
completed: boolean;
|
|
9
|
+
}[];
|
|
10
|
+
customStyle?: CSSProperties;
|
|
11
|
+
}>): JSX.Element;
|
|
12
|
+
|
|
13
|
+
export { Progressbar };
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Progressbar = Progressbar;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _ = require(".");
|
|
9
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
|
+
function Progressbar(_ref) {
|
|
11
|
+
let {
|
|
12
|
+
customClass,
|
|
13
|
+
customStyle,
|
|
14
|
+
stepsTitle
|
|
15
|
+
} = _ref;
|
|
16
|
+
const context = (0, _.useWizardContext)();
|
|
17
|
+
if (!context) throw new Error('WizardProgressbar must be used within a Wizard component');
|
|
18
|
+
const {
|
|
19
|
+
currentStep
|
|
20
|
+
} = context;
|
|
21
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
22
|
+
className: `wizard-progresbar ${customClass}`,
|
|
23
|
+
style: customStyle
|
|
24
|
+
}, stepsTitle.map(step => /*#__PURE__*/_react.default.createElement("div", {
|
|
25
|
+
key: step.number,
|
|
26
|
+
className: "title",
|
|
27
|
+
"data-completed": step.completed,
|
|
28
|
+
"data-disabled": step.number > currentStep
|
|
29
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
30
|
+
className: "step"
|
|
31
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
32
|
+
className: "number"
|
|
33
|
+
}, step.number)), /*#__PURE__*/_react.default.createElement("span", {
|
|
34
|
+
className: "step-title"
|
|
35
|
+
}, step.title))));
|
|
36
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { WizardStepComponentProps } from '../types.js';
|
|
2
|
+
import 'react';
|
|
3
|
+
import '../../@types/Align.js';
|
|
4
|
+
import '../../@types/Icon.js';
|
|
5
|
+
import '../../icons/helper.js';
|
|
6
|
+
|
|
7
|
+
declare function WizardStep({ children, customClass, customStyle }: Readonly<WizardStepComponentProps>): JSX.Element;
|
|
8
|
+
|
|
9
|
+
export { WizardStep };
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.WizardStep = WizardStep;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _ = require(".");
|
|
9
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
|
+
function WizardStep(_ref) {
|
|
11
|
+
let {
|
|
12
|
+
children,
|
|
13
|
+
customClass = '',
|
|
14
|
+
customStyle
|
|
15
|
+
} = _ref;
|
|
16
|
+
const context = (0, _.useWizardContext)();
|
|
17
|
+
if (!context) throw new Error('WizardStep must be used within a Wizard component');
|
|
18
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
19
|
+
className: `wizard-step-component ${customClass}`,
|
|
20
|
+
style: customStyle
|
|
21
|
+
}, children);
|
|
22
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.useWizard = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
9
|
+
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; }
|
|
10
|
+
const useWizard = () => {
|
|
11
|
+
const [totalSteps, setTotalSteps] = (0, _react.useState)(0);
|
|
12
|
+
const [currentStep, setCurrentStep] = _react.default.useState(1);
|
|
13
|
+
const hasNextStep = currentStep < totalSteps;
|
|
14
|
+
const hasPreviousStep = currentStep > 1;
|
|
15
|
+
const changeStep = nextStep => {
|
|
16
|
+
setCurrentStep(state => state + nextStep);
|
|
17
|
+
};
|
|
18
|
+
const nextStep = () => {
|
|
19
|
+
if (hasNextStep) {
|
|
20
|
+
changeStep(1);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
const previousStep = () => {
|
|
24
|
+
if (hasPreviousStep) {
|
|
25
|
+
changeStep(-1);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
return {
|
|
29
|
+
changeStep,
|
|
30
|
+
nextStep,
|
|
31
|
+
hasNextStep,
|
|
32
|
+
previousStep,
|
|
33
|
+
hasPreviousStep,
|
|
34
|
+
currentStep,
|
|
35
|
+
totalSteps,
|
|
36
|
+
controls: {
|
|
37
|
+
changeStep,
|
|
38
|
+
nextStep,
|
|
39
|
+
hasNextStep,
|
|
40
|
+
previousStep,
|
|
41
|
+
hasPreviousStep,
|
|
42
|
+
currentStep,
|
|
43
|
+
totalSteps,
|
|
44
|
+
setTotalSteps
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
exports.useWizard = useWizard;
|