@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.
Files changed (34) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/cjs/components/Modal/Modal.js +2 -0
  3. package/dist/cjs/components/Modal/Modal.js.map +1 -1
  4. package/dist/cjs/hooks/index.d.ts +1 -0
  5. package/dist/cjs/hooks/index.js +1 -0
  6. package/dist/cjs/hooks/index.js.map +1 -1
  7. package/dist/cjs/hooks/useBodyScrollLock/index.d.ts +1 -0
  8. package/dist/cjs/hooks/useBodyScrollLock/index.js +18 -0
  9. package/dist/cjs/hooks/useBodyScrollLock/index.js.map +1 -0
  10. package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.d.ts +3 -0
  11. package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.js +25 -0
  12. package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.js.map +1 -0
  13. package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.test.d.ts +1 -0
  14. package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.test.js +31 -0
  15. package/dist/cjs/hooks/useBodyScrollLock/useBodyScrollLock.test.js.map +1 -0
  16. package/dist/cjs/tsconfig.tsbuildinfo +1 -1
  17. package/dist/esm/components/Modal/Modal.js +2 -0
  18. package/dist/esm/components/Modal/Modal.js.map +1 -1
  19. package/dist/esm/hooks/index.js +1 -0
  20. package/dist/esm/hooks/index.js.map +1 -1
  21. package/dist/esm/hooks/useBodyScrollLock/index.js +2 -0
  22. package/dist/esm/hooks/useBodyScrollLock/index.js.map +1 -0
  23. package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.js +21 -0
  24. package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.js.map +1 -0
  25. package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.test.js +29 -0
  26. package/dist/esm/hooks/useBodyScrollLock/useBodyScrollLock.test.js.map +1 -0
  27. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  28. package/dist/mobius.d.ts +4 -0
  29. package/package.json +1 -1
  30. package/src/components/Modal/Modal.tsx +2 -0
  31. package/src/hooks/index.tsx +1 -0
  32. package/src/hooks/useBodyScrollLock/index.ts +1 -0
  33. package/src/hooks/useBodyScrollLock/useBodyScrollLock.test.ts +34 -0
  34. 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;AAmBtD,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;IAE1D,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"}
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"}
@@ -1,3 +1,4 @@
1
1
  export * from "./useBreakpoint";
2
2
  export * from "./useHideColumns";
3
3
  export * from "./useButton";
4
+ export * from "./useBodyScrollLock";
@@ -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,3 @@
1
+ export declare function useBodyScrollLock({ enabled, }?: {
2
+ enabled?: boolean;
3
+ }): void;
@@ -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,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"}