@simplybusiness/mobius 3.7.1 → 3.8.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/CHANGELOG.md +7 -0
- package/dist/cjs/components/Modal/Modal.js +2 -0
- package/dist/cjs/components/Modal/Modal.js.map +1 -1
- package/dist/cjs/hooks/index.d.ts +1 -0
- package/dist/cjs/hooks/index.js +1 -0
- package/dist/cjs/hooks/index.js.map +1 -1
- package/dist/cjs/hooks/useBodyScrollLock/index.d.ts +1 -0
- package/dist/cjs/hooks/useBodyScrollLock/index.js +18 -0
- package/dist/cjs/hooks/useBodyScrollLock/index.js.map +1 -0
- package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.d.ts +3 -0
- package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.js +25 -0
- package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.js.map +1 -0
- package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.test.d.ts +1 -0
- package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.test.js +31 -0
- package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.test.js.map +1 -0
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/components/Modal/Modal.js +2 -0
- package/dist/esm/components/Modal/Modal.js.map +1 -1
- package/dist/esm/hooks/index.js +1 -0
- package/dist/esm/hooks/index.js.map +1 -1
- package/dist/esm/hooks/useBodyScrollLock/index.js +2 -0
- package/dist/esm/hooks/useBodyScrollLock/index.js.map +1 -0
- package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.js +21 -0
- package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.js.map +1 -0
- package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.test.js +29 -0
- package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.test.js.map +1 -0
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/dist/mobius.d.ts +4 -0
- package/package.json +1 -1
- package/src/components/Modal/Modal.tsx +2 -0
- package/src/hooks/index.tsx +1 -0
- package/src/hooks/useBodyScrollLock/index.ts +1 -0
- package/src/hooks/useBodyScrollLock/useBodyScrollLock.test.ts +34 -0
- package/src/hooks/useBodyScrollLock/useBodyScrollLock.ts +25 -0
package/CHANGELOG.md
CHANGED
|
@@ -5,6 +5,12 @@ All notable changes to this project will be documented in this file, or link in
|
|
|
5
5
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
|
6
6
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
7
7
|
|
|
8
|
+
## [3.8.0] - 2023-08-01
|
|
9
|
+
|
|
10
|
+
### Added
|
|
11
|
+
|
|
12
|
+
- Added custom `useBodyScrollLock` hook to prevent scrolling of body when modal is open
|
|
13
|
+
|
|
8
14
|
## [3.7.0] - 2023-07-31
|
|
9
15
|
|
|
10
16
|
### Added
|
|
@@ -278,6 +284,7 @@ Additionally, mobius and themes are available on the public NPM registry and can
|
|
|
278
284
|
|
|
279
285
|
## Github Links
|
|
280
286
|
|
|
287
|
+
[3.8.0]: https://github.com/simplybusiness/mobius/releases/tag/v3.8.0
|
|
281
288
|
[3.7.1]: https://github.com/simplybusiness/mobius/releases/tag/v3.7.1
|
|
282
289
|
[3.7.0]: https://github.com/simplybusiness/mobius/releases/tag/v3.7.0
|
|
283
290
|
[3.6.2]: https://github.com/simplybusiness/mobius/releases/tag/v3.6.2
|
|
@@ -10,9 +10,11 @@ const react_1 = require("react");
|
|
|
10
10
|
const react_modal_1 = __importDefault(require("react-modal"));
|
|
11
11
|
const clsx_1 = __importDefault(require("clsx"));
|
|
12
12
|
const sizeClasses_1 = require("../../utils/sizeClasses");
|
|
13
|
+
const useBodyScrollLock_1 = require("../../hooks/useBodyScrollLock");
|
|
13
14
|
const Modal = ({ isOpen, onClose, children, className, closeLabel, size = "md", appElement = "body", preventCloseOnEsc, animation, shouldFocusAfterRender = true, parentSelector, }) => {
|
|
14
15
|
const noPreference = window.matchMedia("(prefers-reduced-motion: no-preference)");
|
|
15
16
|
const shouldAnimate = noPreference.matches && !!animation;
|
|
17
|
+
(0, useBodyScrollLock_1.useBodyScrollLock)({ enabled: isOpen });
|
|
16
18
|
const modalClasses = (0, clsx_1.default)("mobius", "mobius/Modal", Object.assign({ "--slide-up": animation === "slideUp", "--fade": animation === "fade", "--has-reduced-motion": !noPreference.matches, "--is-fullscreen": size === "fullscreen" }, (size !== "fullscreen" && (0, sizeClasses_1.sizeClasses)(size))), className);
|
|
17
19
|
const overlayClasses = (0, clsx_1.default)("mobius/ModalOverlay", {
|
|
18
20
|
"--fade": shouldAnimate,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../../src/components/Modal/Modal.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;AAEb,iCAMe;AACf,8DAAqC;AACrC,gDAAwB;AAExB,yDAAsD;
|
|
1
|
+
{"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../../src/components/Modal/Modal.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;AAEb,iCAMe;AACf,8DAAqC;AACrC,gDAAwB;AAExB,yDAAsD;AACtD,qEAAkE;AAmBlE,MAAM,KAAK,GAAG,CAAC,EACb,MAAM,EACN,OAAO,EACP,QAAQ,EACR,SAAS,EACT,UAAU,EACV,IAAI,GAAG,IAAI,EACX,UAAU,GAAG,MAAM,EACnB,iBAAiB,EACjB,SAAS,EACT,sBAAsB,GAAG,IAAI,EAC7B,cAAc,GACH,EAAE,EAAE;IACf,MAAM,YAAY,GAAG,MAAM,CAAC,UAAU,CACpC,yCAAyC,CAC1C,CAAC;IACF,MAAM,aAAa,GAAG,YAAY,CAAC,OAAO,IAAI,CAAC,CAAC,SAAS,CAAC;IAC1D,IAAA,qCAAiB,EAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IAEvC,MAAM,YAAY,GAAG,IAAA,cAAI,EACvB,QAAQ,EACR,cAAc,kBAEZ,YAAY,EAAE,SAAS,KAAK,SAAS,EACrC,QAAQ,EAAE,SAAS,KAAK,MAAM,EAC9B,sBAAsB,EAAE,CAAC,YAAY,CAAC,OAAO,EAC7C,iBAAiB,EAAE,IAAI,KAAK,YAAY,IACrC,CAAC,IAAI,KAAK,YAAY,IAAI,IAAA,yBAAW,EAAC,IAAI,CAAC,CAAC,GAEjD,SAAS,CACV,CAAC;IAEF,MAAM,cAAc,GAAG,IAAA,cAAI,EAAC,qBAAqB,EAAE;QACjD,QAAQ,EAAE,aAAa;KACxB,CAAC,CAAC;IAEH,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,wDAAwD;QACxD,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM,EAAE;YACnC,qBAAU,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;SACtC;IACH,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjB,OAAO,CACL,uBAAC,qBAAU,kBACT,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,OAAO,EACvB,SAAS,EAAE;YACT,IAAI,EAAE,YAAY;YAClB,SAAS,EAAE,EAAE;YACb,WAAW,EAAE,cAAc;SAC5B,EACD,eAAe,EAAC,oBAAoB,EACpC,gBAAgB,EAAE;YAChB,IAAI,EAAE,cAAc;YACpB,SAAS,EAAE,EAAE;YACb,WAAW,EAAE,cAAc;SAC5B,EACD,iBAAiB,EAAC,uBAAuB,EACzC,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM,EAC5C,gBAAgB,EAAE,CAAC,iBAAiB,EACpC,cAAc,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EACvC,sBAAsB,EAAE,sBAAsB,EAC9C,cAAc,EAAE,cAAc,gBAE7B,gBAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE;YAC9B,IAAI,IAAA,sBAAc,EAAC,KAAK,CAAC,EAAE;gBACzB,OAAO,IAAA,oBAAY,EAAC,KAAK,EAAE;oBACzB,OAAO;oBACP,UAAU;iBACJ,CAAC,CAAC;aACX;YAED,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,IACS,CACd,CAAC;AACJ,CAAC,CAAC;AAGO,sBAAK;AADd,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC"}
|
package/dist/cjs/hooks/index.js
CHANGED
|
@@ -17,4 +17,5 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./useBreakpoint"), exports);
|
|
18
18
|
__exportStar(require("./useHideColumns"), exports);
|
|
19
19
|
__exportStar(require("./useButton"), exports);
|
|
20
|
+
__exportStar(require("./useBodyScrollLock"), exports);
|
|
20
21
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,mDAAiC;AACjC,8CAA4B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,mDAAiC;AACjC,8CAA4B;AAC5B,sDAAoC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./useBodyScrollLock";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./useBodyScrollLock"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/hooks/useBodyScrollLock/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useBodyScrollLock = void 0;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
function useBodyScrollLock({ enabled = true, } = {}) {
|
|
6
|
+
function disableScrollLock() {
|
|
7
|
+
document.body.style.removeProperty("overflow");
|
|
8
|
+
}
|
|
9
|
+
function enableScrollLock() {
|
|
10
|
+
document.body.style.overflow = "hidden";
|
|
11
|
+
}
|
|
12
|
+
(0, react_1.useEffect)(() => {
|
|
13
|
+
if (enabled) {
|
|
14
|
+
enableScrollLock();
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
disableScrollLock();
|
|
18
|
+
}
|
|
19
|
+
return () => {
|
|
20
|
+
disableScrollLock();
|
|
21
|
+
};
|
|
22
|
+
}, [enabled]);
|
|
23
|
+
}
|
|
24
|
+
exports.useBodyScrollLock = useBodyScrollLock;
|
|
25
|
+
//# sourceMappingURL=useBodyScrollLock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBodyScrollLock.js","sourceRoot":"","sources":["../../../../src/hooks/useBodyScrollLock/useBodyScrollLock.ts"],"names":[],"mappings":";;;AAAA,iCAAkC;AAElC,SAAgB,iBAAiB,CAAC,EAChC,OAAO,GAAG,IAAI,MACW,EAAE;IAC3B,SAAS,iBAAiB;QACxB,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACjD,CAAC;IAED,SAAS,gBAAgB;QACvB,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC1C,CAAC;IAED,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE;YACX,gBAAgB,EAAE,CAAC;SACpB;aAAM;YACL,iBAAiB,EAAE,CAAC;SACrB;QAED,OAAO,GAAG,EAAE;YACV,iBAAiB,EAAE,CAAC;QACtB,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;AAChB,CAAC;AAtBD,8CAsBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const react_1 = require("@testing-library/react");
|
|
4
|
+
const useBodyScrollLock_1 = require("./useBodyScrollLock");
|
|
5
|
+
describe("useBodyScrollLock", () => {
|
|
6
|
+
it("should be defined", () => {
|
|
7
|
+
expect(useBodyScrollLock_1.useBodyScrollLock).toBeDefined();
|
|
8
|
+
});
|
|
9
|
+
it("should not throw", () => {
|
|
10
|
+
expect(() => (0, react_1.renderHook)(() => (0, useBodyScrollLock_1.useBodyScrollLock)())).not.toThrow();
|
|
11
|
+
});
|
|
12
|
+
it("should disable scroll by default", () => {
|
|
13
|
+
(0, react_1.renderHook)(() => (0, useBodyScrollLock_1.useBodyScrollLock)());
|
|
14
|
+
expect(document.body.style.overflow).toBe("hidden");
|
|
15
|
+
});
|
|
16
|
+
it("should disable scroll when enabled is true", () => {
|
|
17
|
+
(0, react_1.renderHook)(() => (0, useBodyScrollLock_1.useBodyScrollLock)({ enabled: true }));
|
|
18
|
+
expect(document.body.style.overflow).toBe("hidden");
|
|
19
|
+
});
|
|
20
|
+
it("should enable scroll when enabled is false", () => {
|
|
21
|
+
(0, react_1.renderHook)(() => (0, useBodyScrollLock_1.useBodyScrollLock)({ enabled: false }));
|
|
22
|
+
expect(document.body.style.overflow).toBe("");
|
|
23
|
+
});
|
|
24
|
+
it("should enable scroll on unmount", () => {
|
|
25
|
+
const { unmount } = (0, react_1.renderHook)(() => (0, useBodyScrollLock_1.useBodyScrollLock)());
|
|
26
|
+
expect(document.body.style.overflow).toBe("hidden");
|
|
27
|
+
unmount();
|
|
28
|
+
expect(document.body.style.overflow).toBe("");
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=useBodyScrollLock.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBodyScrollLock.test.js","sourceRoot":"","sources":["../../../../src/hooks/useBodyScrollLock/useBodyScrollLock.test.ts"],"names":[],"mappings":";;AAAA,kDAAoD;AACpD,2DAAwD;AAExD,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,mBAAmB,EAAE,GAAG,EAAE;QAC3B,MAAM,CAAC,qCAAiB,CAAC,CAAC,WAAW,EAAE,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAC1B,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,kBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAiB,GAAE,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,IAAA,kBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAiB,GAAE,CAAC,CAAC;QACtC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,IAAA,kBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAiB,EAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QACvD,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,IAAA,kBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAiB,EAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACxD,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,EAAE,OAAO,EAAE,GAAG,IAAA,kBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,qCAAiB,GAAE,CAAC,CAAC;QAC1D,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpD,OAAO,EAAE,CAAC;QACV,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|