@weser/hook 1.0.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/LICENSE +21 -0
- package/README.md +3 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +13 -0
- package/dist/index.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/useBreakpoint.d.ts +2 -0
- package/dist/useBreakpoint.d.ts.map +1 -0
- package/dist/useBreakpoint.js +20 -0
- package/dist/useBreakpoint.js.map +1 -0
- package/dist/useClickAway.d.ts +3 -0
- package/dist/useClickAway.d.ts.map +1 -0
- package/dist/useClickAway.js +20 -0
- package/dist/useClickAway.js.map +1 -0
- package/dist/useClientOnly.d.ts +2 -0
- package/dist/useClientOnly.d.ts.map +1 -0
- package/dist/useClientOnly.js +7 -0
- package/dist/useClientOnly.js.map +1 -0
- package/dist/useDisclosure.d.ts +17 -0
- package/dist/useDisclosure.d.ts.map +1 -0
- package/dist/useDisclosure.js +26 -0
- package/dist/useDisclosure.js.map +1 -0
- package/dist/useFirstRender.d.ts +2 -0
- package/dist/useFirstRender.d.ts.map +1 -0
- package/dist/useFirstRender.js +10 -0
- package/dist/useFirstRender.js.map +1 -0
- package/dist/useFocusTrap.d.ts +8 -0
- package/dist/useFocusTrap.d.ts.map +1 -0
- package/dist/useFocusTrap.js +78 -0
- package/dist/useFocusTrap.js.map +1 -0
- package/dist/useKeyDown.d.ts +14 -0
- package/dist/useKeyDown.d.ts.map +1 -0
- package/dist/useKeyDown.js +34 -0
- package/dist/useKeyDown.js.map +1 -0
- package/dist/useList.d.ts +9 -0
- package/dist/useList.d.ts.map +1 -0
- package/dist/useList.js +32 -0
- package/dist/useList.js.map +1 -0
- package/dist/useRerender.d.ts +2 -0
- package/dist/useRerender.d.ts.map +1 -0
- package/dist/useRerender.js +12 -0
- package/dist/useRerender.js.map +1 -0
- package/dist/useRouteChange.d.ts +2 -0
- package/dist/useRouteChange.d.ts.map +1 -0
- package/dist/useRouteChange.js +33 -0
- package/dist/useRouteChange.js.map +1 -0
- package/dist/useScrollBlocking.d.ts +2 -0
- package/dist/useScrollBlocking.d.ts.map +1 -0
- package/dist/useScrollBlocking.js +32 -0
- package/dist/useScrollBlocking.js.map +1 -0
- package/dist/useTree.d.ts +19 -0
- package/dist/useTree.d.ts.map +1 -0
- package/dist/useTree.js +25 -0
- package/dist/useTree.js.map +1 -0
- package/dist/useTrigger.d.ts +8 -0
- package/dist/useTrigger.d.ts.map +1 -0
- package/dist/useTrigger.js +25 -0
- package/dist/useTrigger.js.map +1 -0
- package/package.json +59 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2022-present Robin Weser
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export { default as useBreakpoint } from './useBreakpoint';
|
|
2
|
+
export { default as useClickAway } from './useClickAway';
|
|
3
|
+
export { default as useClientOnly } from './useClientOnly';
|
|
4
|
+
export { default as useDisclosure } from './useDisclosure';
|
|
5
|
+
export { default as useFirstRender } from './useFirstRender';
|
|
6
|
+
export { default as useFocusTrap } from './useFocusTrap';
|
|
7
|
+
export { default as useKeyDown } from './useKeyDown';
|
|
8
|
+
export { default as useList } from './useList';
|
|
9
|
+
export { default as useRerender } from './useRerender';
|
|
10
|
+
export { default as useRouteChange } from './useRouteChange';
|
|
11
|
+
export { default as useScrollBlocking } from './useScrollBlocking';
|
|
12
|
+
export { default as useTrigger } from './useTrigger';
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAA;AACxD,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAA;AACxD,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAA;AAC9C,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA;AACtD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAClE,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export { default as useBreakpoint } from './useBreakpoint';
|
|
2
|
+
export { default as useClickAway } from './useClickAway';
|
|
3
|
+
export { default as useClientOnly } from './useClientOnly';
|
|
4
|
+
export { default as useDisclosure } from './useDisclosure';
|
|
5
|
+
export { default as useFirstRender } from './useFirstRender';
|
|
6
|
+
export { default as useFocusTrap } from './useFocusTrap';
|
|
7
|
+
export { default as useKeyDown } from './useKeyDown';
|
|
8
|
+
export { default as useList } from './useList';
|
|
9
|
+
export { default as useRerender } from './useRerender';
|
|
10
|
+
export { default as useRouteChange } from './useRouteChange';
|
|
11
|
+
export { default as useScrollBlocking } from './useScrollBlocking';
|
|
12
|
+
export { default as useTrigger } from './useTrigger';
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAA;AACxD,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC1D,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAA;AACxD,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAA;AAC9C,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA;AACtD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAClE,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"fileNames":["../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es5.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.dom.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.dom.iterable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.dom.asynciterable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.webworker.importscripts.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.scripthost.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.core.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.collection.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.generator.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.iterable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.proxy.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.reflect.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2015.symbol.wellknown.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.array.include.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2016.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.arraybuffer.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.date.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.sharedmemory.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2017.typedarrays.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asyncgenerator.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.asynciterable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2018.regexp.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.array.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.symbol.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2019.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.bigint.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.date.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.sharedmemory.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.symbol.wellknown.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2020.number.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.weakref.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2021.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.array.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.error.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2022.regexp.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.array.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.collection.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2023.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.arraybuffer.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.collection.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.object.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.regexp.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.sharedmemory.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.es2024.string.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.array.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.collection.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.intl.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.disposable.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.promise.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.decorators.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.iterator.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.float16.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.error.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.sharedmemory.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.decorators.legacy.d.ts","../../../node_modules/.pnpm/typescript@5.9.3/node_modules/typescript/lib/lib.esnext.full.d.ts","../../../node_modules/.pnpm/@types+react@18.3.27/node_modules/@types/react/global.d.ts","../../../node_modules/.pnpm/csstype@3.2.3/node_modules/csstype/index.d.ts","../../../node_modules/.pnpm/@types+prop-types@15.7.15/node_modules/@types/prop-types/index.d.ts","../../../node_modules/.pnpm/@types+react@18.3.27/node_modules/@types/react/index.d.ts","../src/usebreakpoint.ts","../src/useclickaway.ts","../src/useclientonly.ts","../src/usedisclosure.ts","../src/usefirstrender.ts","../src/usekeydown.ts","../src/usefocustrap.ts","../src/uselist.ts","../src/usererender.ts","../src/useroutechange.ts","../src/usescrollblocking.ts","../src/usetrigger.ts","../src/index.ts","../../tree/dist/types.d.ts","../../tree/dist/add.d.ts","../../tree/dist/clone.d.ts","../../tree/dist/create.d.ts","../../tree/dist/find.d.ts","../../tree/dist/findall.d.ts","../../tree/dist/get.d.ts","../../tree/dist/getparent.d.ts","../../tree/dist/insert.d.ts","../../tree/dist/move.d.ts","../../tree/dist/remove.d.ts","../../tree/dist/replace.d.ts","../../tree/dist/traverse.d.ts","../../tree/dist/update.d.ts","../../tree/dist/index.d.ts","../src/usetree.ts"],"fileIdsList":[[87,88,89],[91,92,93,94,95,96,97,98,99,100,101,102],[90],[90,96],[90,118],[104],[104,105,106,107,108,109,110,111,112,113,114,115,116,117]],"fileInfos":[{"version":"c430d44666289dae81f30fa7b2edebf186ecc91a2d4c71266ea6ae76388792e1","affectsGlobalScope":true,"impliedFormat":1},{"version":"45b7ab580deca34ae9729e97c13cfd999df04416a79116c3bfb483804f85ded4","impliedFormat":1},{"version":"3facaf05f0c5fc569c5649dd359892c98a85557e3e0c847964caeb67076f4d75","impliedFormat":1},{"version":"e44bb8bbac7f10ecc786703fe0a6a4b952189f908707980ba8f3c8975a760962","impliedFormat":1},{"version":"5e1c4c362065a6b95ff952c0eab010f04dcd2c3494e813b493ecfd4fcb9fc0d8","impliedFormat":1},{"version":"68d73b4a11549f9c0b7d352d10e91e5dca8faa3322bfb77b661839c42b1ddec7","impliedFormat":1},{"version":"5efce4fc3c29ea84e8928f97adec086e3dc876365e0982cc8479a07954a3efd4","impliedFormat":1},{"version":"feecb1be483ed332fad555aff858affd90a48ab19ba7272ee084704eb7167569","impliedFormat":1},{"version":"ee7bad0c15b58988daa84371e0b89d313b762ab83cb5b31b8a2d1162e8eb41c2","impliedFormat":1},{"version":"27bdc30a0e32783366a5abeda841bc22757c1797de8681bbe81fbc735eeb1c10","impliedFormat":1},{"version":"8fd575e12870e9944c7e1d62e1f5a73fcf23dd8d3a321f2a2c74c20d022283fe","impliedFormat":1},{"version":"2ab096661c711e4a81cc464fa1e6feb929a54f5340b46b0a07ac6bbf857471f0","impliedFormat":1},{"version":"080941d9f9ff9307f7e27a83bcd888b7c8270716c39af943532438932ec1d0b9","affectsGlobalScope":true,"impliedFormat":1},{"version":"2e80ee7a49e8ac312cc11b77f1475804bee36b3b2bc896bead8b6e1266befb43","affectsGlobalScope":true,"impliedFormat":1},{"version":"d7a3c8b952931daebdfc7a2897c53c0a1c73624593fa070e46bd537e64dcd20a","affectsGlobalScope":true,"impliedFormat":1},{"version":"80e18897e5884b6723488d4f5652167e7bb5024f946743134ecc4aa4ee731f89","affectsGlobalScope":true,"impliedFormat":1},{"version":"cd034f499c6cdca722b60c04b5b1b78e058487a7085a8e0d6fb50809947ee573","affectsGlobalScope":true,"impliedFormat":1},{"version":"c57796738e7f83dbc4b8e65132f11a377649c00dd3eee333f672b8f0a6bea671","affectsGlobalScope":true,"impliedFormat":1},{"version":"dc2df20b1bcdc8c2d34af4926e2c3ab15ffe1160a63e58b7e09833f616efff44","affectsGlobalScope":true,"impliedFormat":1},{"version":"515d0b7b9bea2e31ea4ec968e9edd2c39d3eebf4a2d5cbd04e88639819ae3b71","affectsGlobalScope":true,"impliedFormat":1},{"version":"0559b1f683ac7505ae451f9a96ce4c3c92bdc71411651ca6ddb0e88baaaad6a3","affectsGlobalScope":true,"impliedFormat":1},{"version":"0dc1e7ceda9b8b9b455c3a2d67b0412feab00bd2f66656cd8850e8831b08b537","affectsGlobalScope":true,"impliedFormat":1},{"version":"ce691fb9e5c64efb9547083e4a34091bcbe5bdb41027e310ebba8f7d96a98671","affectsGlobalScope":true,"impliedFormat":1},{"version":"8d697a2a929a5fcb38b7a65594020fcef05ec1630804a33748829c5ff53640d0","affectsGlobalScope":true,"impliedFormat":1},{"version":"4ff2a353abf8a80ee399af572debb8faab2d33ad38c4b4474cff7f26e7653b8d","affectsGlobalScope":true,"impliedFormat":1},{"version":"fb0f136d372979348d59b3f5020b4cdb81b5504192b1cacff5d1fbba29378aa1","affectsGlobalScope":true,"impliedFormat":1},{"version":"d15bea3d62cbbdb9797079416b8ac375ae99162a7fba5de2c6c505446486ac0a","affectsGlobalScope":true,"impliedFormat":1},{"version":"68d18b664c9d32a7336a70235958b8997ebc1c3b8505f4f1ae2b7e7753b87618","affectsGlobalScope":true,"impliedFormat":1},{"version":"eb3d66c8327153d8fa7dd03f9c58d351107fe824c79e9b56b462935176cdf12a","affectsGlobalScope":true,"impliedFormat":1},{"version":"38f0219c9e23c915ef9790ab1d680440d95419ad264816fa15009a8851e79119","affectsGlobalScope":true,"impliedFormat":1},{"version":"69ab18c3b76cd9b1be3d188eaf8bba06112ebbe2f47f6c322b5105a6fbc45a2e","affectsGlobalScope":true,"impliedFormat":1},{"version":"a680117f487a4d2f30ea46f1b4b7f58bef1480456e18ba53ee85c2746eeca012","affectsGlobalScope":true,"impliedFormat":1},{"version":"2f11ff796926e0832f9ae148008138ad583bd181899ab7dd768a2666700b1893","affectsGlobalScope":true,"impliedFormat":1},{"version":"4de680d5bb41c17f7f68e0419412ca23c98d5749dcaaea1896172f06435891fc","affectsGlobalScope":true,"impliedFormat":1},{"version":"954296b30da6d508a104a3a0b5d96b76495c709785c1d11610908e63481ee667","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac9538681b19688c8eae65811b329d3744af679e0bdfa5d842d0e32524c73e1c","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a969edff4bd52585473d24995c5ef223f6652d6ef46193309b3921d65dd4376","affectsGlobalScope":true,"impliedFormat":1},{"version":"9e9fbd7030c440b33d021da145d3232984c8bb7916f277e8ffd3dc2e3eae2bdb","affectsGlobalScope":true,"impliedFormat":1},{"version":"811ec78f7fefcabbda4bfa93b3eb67d9ae166ef95f9bff989d964061cbf81a0c","affectsGlobalScope":true,"impliedFormat":1},{"version":"717937616a17072082152a2ef351cb51f98802fb4b2fdabd32399843875974ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"d7e7d9b7b50e5f22c915b525acc5a49a7a6584cf8f62d0569e557c5cfc4b2ac2","affectsGlobalScope":true,"impliedFormat":1},{"version":"71c37f4c9543f31dfced6c7840e068c5a5aacb7b89111a4364b1d5276b852557","affectsGlobalScope":true,"impliedFormat":1},{"version":"576711e016cf4f1804676043e6a0a5414252560eb57de9faceee34d79798c850","affectsGlobalScope":true,"impliedFormat":1},{"version":"89c1b1281ba7b8a96efc676b11b264de7a8374c5ea1e6617f11880a13fc56dc6","affectsGlobalScope":true,"impliedFormat":1},{"version":"74f7fa2d027d5b33eb0471c8e82a6c87216223181ec31247c357a3e8e2fddc5b","affectsGlobalScope":true,"impliedFormat":1},{"version":"d6d7ae4d1f1f3772e2a3cde568ed08991a8ae34a080ff1151af28b7f798e22ca","affectsGlobalScope":true,"impliedFormat":1},{"version":"063600664504610fe3e99b717a1223f8b1900087fab0b4cad1496a114744f8df","affectsGlobalScope":true,"impliedFormat":1},{"version":"934019d7e3c81950f9a8426d093458b65d5aff2c7c1511233c0fd5b941e608ab","affectsGlobalScope":true,"impliedFormat":1},{"version":"52ada8e0b6e0482b728070b7639ee42e83a9b1c22d205992756fe020fd9f4a47","affectsGlobalScope":true,"impliedFormat":1},{"version":"3bdefe1bfd4d6dee0e26f928f93ccc128f1b64d5d501ff4a8cf3c6371200e5e6","affectsGlobalScope":true,"impliedFormat":1},{"version":"59fb2c069260b4ba00b5643b907ef5d5341b167e7d1dbf58dfd895658bda2867","affectsGlobalScope":true,"impliedFormat":1},{"version":"639e512c0dfc3fad96a84caad71b8834d66329a1f28dc95e3946c9b58176c73a","affectsGlobalScope":true,"impliedFormat":1},{"version":"368af93f74c9c932edd84c58883e736c9e3d53cec1fe24c0b0ff451f529ceab1","affectsGlobalScope":true,"impliedFormat":1},{"version":"af3dd424cf267428f30ccfc376f47a2c0114546b55c44d8c0f1d57d841e28d74","affectsGlobalScope":true,"impliedFormat":1},{"version":"995c005ab91a498455ea8dfb63aa9f83fa2ea793c3d8aa344be4a1678d06d399","affectsGlobalScope":true,"impliedFormat":1},{"version":"959d36cddf5e7d572a65045b876f2956c973a586da58e5d26cde519184fd9b8a","affectsGlobalScope":true,"impliedFormat":1},{"version":"965f36eae237dd74e6cca203a43e9ca801ce38824ead814728a2807b1910117d","affectsGlobalScope":true,"impliedFormat":1},{"version":"3925a6c820dcb1a06506c90b1577db1fdbf7705d65b62b99dce4be75c637e26b","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a3d63ef2b853447ec4f749d3f368ce642264246e02911fcb1590d8c161b8005","affectsGlobalScope":true,"impliedFormat":1},{"version":"8cdf8847677ac7d20486e54dd3fcf09eda95812ac8ace44b4418da1bbbab6eb8","affectsGlobalScope":true,"impliedFormat":1},{"version":"8444af78980e3b20b49324f4a16ba35024fef3ee069a0eb67616ea6ca821c47a","affectsGlobalScope":true,"impliedFormat":1},{"version":"3287d9d085fbd618c3971944b65b4be57859f5415f495b33a6adc994edd2f004","affectsGlobalScope":true,"impliedFormat":1},{"version":"b4b67b1a91182421f5df999988c690f14d813b9850b40acd06ed44691f6727ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"df83c2a6c73228b625b0beb6669c7ee2a09c914637e2d35170723ad49c0f5cd4","affectsGlobalScope":true,"impliedFormat":1},{"version":"436aaf437562f276ec2ddbee2f2cdedac7664c1e4c1d2c36839ddd582eeb3d0a","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e3c06ea092138bf9fa5e874a1fdbc9d54805d074bee1de31b99a11e2fec239d","affectsGlobalScope":true,"impliedFormat":1},{"version":"87dc0f382502f5bbce5129bdc0aea21e19a3abbc19259e0b43ae038a9fc4e326","affectsGlobalScope":true,"impliedFormat":1},{"version":"b1cb28af0c891c8c96b2d6b7be76bd394fddcfdb4709a20ba05a7c1605eea0f9","affectsGlobalScope":true,"impliedFormat":1},{"version":"2fef54945a13095fdb9b84f705f2b5994597640c46afeb2ce78352fab4cb3279","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac77cb3e8c6d3565793eb90a8373ee8033146315a3dbead3bde8db5eaf5e5ec6","affectsGlobalScope":true,"impliedFormat":1},{"version":"56e4ed5aab5f5920980066a9409bfaf53e6d21d3f8d020c17e4de584d29600ad","affectsGlobalScope":true,"impliedFormat":1},{"version":"4ece9f17b3866cc077099c73f4983bddbcb1dc7ddb943227f1ec070f529dedd1","affectsGlobalScope":true,"impliedFormat":1},{"version":"0a6282c8827e4b9a95f4bf4f5c205673ada31b982f50572d27103df8ceb8013c","affectsGlobalScope":true,"impliedFormat":1},{"version":"1c9319a09485199c1f7b0498f2988d6d2249793ef67edda49d1e584746be9032","affectsGlobalScope":true,"impliedFormat":1},{"version":"e3a2a0cee0f03ffdde24d89660eba2685bfbdeae955a6c67e8c4c9fd28928eeb","affectsGlobalScope":true,"impliedFormat":1},{"version":"811c71eee4aa0ac5f7adf713323a5c41b0cf6c4e17367a34fbce379e12bbf0a4","affectsGlobalScope":true,"impliedFormat":1},{"version":"51ad4c928303041605b4d7ae32e0c1ee387d43a24cd6f1ebf4a2699e1076d4fa","affectsGlobalScope":true,"impliedFormat":1},{"version":"60037901da1a425516449b9a20073aa03386cce92f7a1fd902d7602be3a7c2e9","affectsGlobalScope":true,"impliedFormat":1},{"version":"d4b1d2c51d058fc21ec2629fff7a76249dec2e36e12960ea056e3ef89174080f","affectsGlobalScope":true,"impliedFormat":1},{"version":"22adec94ef7047a6c9d1af3cb96be87a335908bf9ef386ae9fd50eeb37f44c47","affectsGlobalScope":true,"impliedFormat":1},{"version":"196cb558a13d4533a5163286f30b0509ce0210e4b316c56c38d4c0fd2fb38405","affectsGlobalScope":true,"impliedFormat":1},{"version":"73f78680d4c08509933daf80947902f6ff41b6230f94dd002ae372620adb0f60","affectsGlobalScope":true,"impliedFormat":1},{"version":"c5239f5c01bcfa9cd32f37c496cf19c61d69d37e48be9de612b541aac915805b","affectsGlobalScope":true,"impliedFormat":1},{"version":"8e7f8264d0fb4c5339605a15daadb037bf238c10b654bb3eee14208f860a32ea","affectsGlobalScope":true,"impliedFormat":1},{"version":"782dec38049b92d4e85c1585fbea5474a219c6984a35b004963b00beb1aab538","affectsGlobalScope":true,"impliedFormat":1},{"version":"bde31fd423cd93b0eff97197a3f66df7c93e8c0c335cbeb113b7ff1ac35c23f4","impliedFormat":1},{"version":"eb5b19b86227ace1d29ea4cf81387279d04bb34051e944bc53df69f58914b788","affectsGlobalScope":true,"impliedFormat":1},{"version":"ac51dd7d31333793807a6abaa5ae168512b6131bd41d9c5b98477fc3b7800f9f","impliedFormat":1},{"version":"87d9d29dbc745f182683f63187bf3d53fd8673e5fca38ad5eaab69798ed29fbc","impliedFormat":1},{"version":"7a3aa194cfd5919c4da251ef04ea051077e22702638d4edcb9579e9101653519","affectsGlobalScope":true,"impliedFormat":1},{"version":"39884c1ad44a5406c4f092428b33ce28ecd355d7ecc288a9b951ffe725ba9419","signature":"7686aabceb07b67a0b3e577f44a1800589d1a4c4053a3d4689aaee9951091f64"},{"version":"97a10724d4cae64ee14ac88dcda58a6a4a3915e3aff9a1280f1383853972dcd0","signature":"beb3d0c4b0c3eff72633a026d47d422c1708f75f84153e7803eaa7257d0705b1"},{"version":"0066bf28d57c18426fe1189539d880782b255ae38447c0d30d2198d6e0f2f3c5","signature":"abed499a26c243a3504bbb167c1e3d7170f100a1c727aa8462968acc0121d7ce"},{"version":"802e850acae844d9f80faded7516a1cae90546f94c233e4a5b2fdcfac74cb8cb","signature":"77ee3b4c9adac79477b02fc4a87f2b5e23f273e80feb0b95d283e8f4a7ac35ea"},{"version":"e00615fec10e9f635d230626b46ce30a5582585b3689cb755e94b1aa41beddc6","signature":"61b1b4e864096ffac61d139d47d8eebd3603aa14a34ab4976a6b90a9d60c0204"},{"version":"3992a60d08a27a1b7ef8ba5a60c71ec582c8b4415270178d544278cb675b8dc1","signature":"a2212e471cf532733a9e6514fee245e5da87a950c6c3c90872bc12f8c2770790"},{"version":"4676bccb17e868a204ccffc050c54ad3e25eb4957b85564f1ea7d2aaad50903f","signature":"0dc700b285437ac76b1866a35aa8337719845425d5e11a6e9d9f653068fcbacc"},{"version":"69daf08e52f31ef4eb9da14c9d11b9efb44fc0942202cb3a98776837bac0f2e0","signature":"212a800ed68442fd17245f3f8a4ec1d7777f636abf8e6aa9246135ffd2beb835"},{"version":"f0edd2e50853f601563ac7990425b0b1e064db7fc094677dd430ee6f280b7bb7","signature":"2b5fc36878137346c46e91f64dcbba639a22ae9f9414d41bb5859f5585ccd42a"},{"version":"fcf7fffeee4192ba711c9ee64561d1ecc7cd94bfa1479b5b3f048be1139be5ff","signature":"bfbcd47065df6a8a35a01acaf4486d73a5dd1653ce979660c32ad441ec6864ee"},{"version":"42c092eb42da873807e2d14cbffb8779a52a7e7e5bd7bbcde1703f3c085ee95a","signature":"dca2986dfe59777973feb6966e17bb937f8413aecb60310efc4a1674dce7391b"},{"version":"e2a6d186fdd9920b4c812deaecbaa5684ac7a630750e6c7d56f646e8fbeb0d53","signature":"25679ab9911bf2e77e02ca5179d511a684e6571c2f614e3f61d392ce6481162d"},{"version":"8d441c45f8020f5ca5ebe5cfdd6e7cd1ecd212a06c7e492ad85b053ac6c2b99f","signature":"411eb6886d42cea20c1ffe3e6ecd0f5b4d4b1ca32ff2b5d480e8781c8e2cb903"},"9ef1ec185876e151fbcc81866cb4563fc5cfdb270e744c05a4b9d6fe1b4ab014","8a96087e21dfc526658c54218f81cc5ff9e1dc30a4b1889b9c473d3921a2830e","b4000e32e997b4952775eeff474a7a2a203af0dc1fd95e1aa5cf6f36d44c5030","e60e17e449c33facbc9ca2995f3cbda4be1399bbdd4ba2bbe719cb3748f66d06","eb868f49640ecdfc1de9c5507939a7875f6531225fbf410ee8baf0eed182d382","e9f0013a4984965eae064d8d8326bc102d72354994e883162b8e6f275f870158","e55dd2148c33f9df34ddf90a3f3b2bb7f611b808f531d027a480b1d941fef855","ff5d195cc26dc6ada0100cc23f5765c66fa4d02edd1269dc4891c00f74b8f864","53ce1a341e6f98cc8b222682f1ff84e398a9d1fc6f8289030d524d5ca17e5d8c","e450a32e8f7870053b4fb01856f175e9d4d5d455957fa8f199992d196b182afe","3fc6a026389a7a9567fb63ff18469d7fd45bb9dc237992f679e5c28bc5139613","f39dbf1cc9d4369860097e8526e6446980e33b300af3b148c3ea5cffcdf7a465","86f371ee8788c2b428b5f48a5de3c1a996c5723f0956dac2f2a450dd13bd759c","f883086e6f3f988e06de60b5fa9efef186a65d21223c8251876456e5410622dc","a9e9af7634fac88f081a991d89ee424823961cbaf05720511446af87881cfb28",{"version":"b6debaaedf33adf9c18192b0240f74a5568ed6a3a2c0b579ae2ddaa08a812dc5","signature":"069ad359acbab7baad74d6a83eb4f97ac26b7ac41a8783ab6fe0dd62f48c653a"}],"root":[[91,103],119],"options":{"declaration":true,"declarationMap":true,"esModuleInterop":true,"jsx":1,"module":99,"outDir":"./","skipLibCheck":true,"sourceMap":true,"strict":true,"target":99},"referencedMap":[[90,1],[103,2],[91,3],[92,3],[93,3],[94,3],[95,3],[97,4],[96,3],[98,3],[99,3],[100,3],[101,3],[119,5],[102,3],[105,6],[106,6],[107,6],[108,6],[109,6],[110,6],[111,6],[118,7],[112,6],[113,6],[114,6],[115,6],[116,6],[117,6]],"version":"5.9.3"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBreakpoint.d.ts","sourceRoot":"","sources":["../src/useBreakpoint.ts"],"names":[],"mappings":"AAWA,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,GAAE,MAAY,WAiB5E"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { useState, useEffect } from 'react';
|
|
2
|
+
function debounce(handler, delay) {
|
|
3
|
+
let timeout;
|
|
4
|
+
return () => {
|
|
5
|
+
clearTimeout(timeout);
|
|
6
|
+
timeout = setTimeout(handler, delay);
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
export default function useBreakpoint(breakpoint, delay = 250) {
|
|
10
|
+
const [isMatching, setMatching] = useState(false);
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
const handleResize = debounce(() => setMatching(window.matchMedia(breakpoint).matches), delay);
|
|
13
|
+
// initial check
|
|
14
|
+
handleResize();
|
|
15
|
+
window.addEventListener('resize', handleResize);
|
|
16
|
+
return () => window.removeEventListener('resize', handleResize);
|
|
17
|
+
}, []);
|
|
18
|
+
return isMatching;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=useBreakpoint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBreakpoint.js","sourceRoot":"","sources":["../src/useBreakpoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAE3C,SAAS,QAAQ,CAAC,OAAmB,EAAE,KAAa;IAClD,IAAI,OAAY,CAAA;IAEhB,OAAO,GAAG,EAAE;QACV,YAAY,CAAC,OAAO,CAAC,CAAA;QACrB,OAAO,GAAG,UAAU,CAAC,OAAO,EAAE,KAAK,CAAC,CAAA;IACtC,CAAC,CAAA;AACH,CAAC;AAED,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,UAAkB,EAAE,QAAgB,GAAG;IAC3E,MAAM,CAAC,UAAU,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAEjD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,YAAY,GAAG,QAAQ,CAC3B,GAAG,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,EACxD,KAAK,CACN,CAAA;QAED,gBAAgB;QAChB,YAAY,EAAE,CAAA;QAEd,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QAC/C,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;IACjE,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,UAAU,CAAA;AACnB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useClickAway.d.ts","sourceRoot":"","sources":["../src/useClickAway.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAa,MAAM,OAAO,CAAA;AAE5C,MAAM,CAAC,OAAO,UAAU,YAAY,CAClC,GAAG,EAAE,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,EAClC,QAAQ,EAAE,MAAM,IAAI,EACpB,MAAM,GAAE,OAAc,QAqBvB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
export default function useClickAway(ref, callback, active = true) {
|
|
3
|
+
useEffect(() => {
|
|
4
|
+
const onClickAway = (e) => {
|
|
5
|
+
if (active && ref.current) {
|
|
6
|
+
const isClickOnInner = ref.current.contains(e.target);
|
|
7
|
+
if (!isClickOnInner) {
|
|
8
|
+
setTimeout(callback, 0);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
document.addEventListener('mousedown', onClickAway);
|
|
13
|
+
document.addEventListener('touchstart', onClickAway);
|
|
14
|
+
return () => {
|
|
15
|
+
document.removeEventListener('mousedown', onClickAway);
|
|
16
|
+
document.removeEventListener('touchstart', onClickAway);
|
|
17
|
+
};
|
|
18
|
+
}, [ref, active, callback]);
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=useClickAway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useClickAway.js","sourceRoot":"","sources":["../src/useClickAway.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,MAAM,OAAO,CAAA;AAE5C,MAAM,CAAC,OAAO,UAAU,YAAY,CAClC,GAAkC,EAClC,QAAoB,EACpB,SAAkB,IAAI;IAEtB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,WAAW,GAAG,CAAC,CAAQ,EAAE,EAAE;YAC/B,IAAI,MAAM,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;gBAC1B,MAAM,cAAc,GAAG,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAc,CAAC,CAAA;gBAE7D,IAAI,CAAC,cAAc,EAAE,CAAC;oBACpB,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA;gBACzB,CAAC;YACH,CAAC;QACH,CAAC,CAAA;QAED,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAA;QACnD,QAAQ,CAAC,gBAAgB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAA;QAEpD,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAA;YACtD,QAAQ,CAAC,mBAAmB,CAAC,YAAY,EAAE,WAAW,CAAC,CAAA;QACzD,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAA;AAC7B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useClientOnly.d.ts","sourceRoot":"","sources":["../src/useClientOnly.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,aAAa,YAMpC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useClientOnly.js","sourceRoot":"","sources":["../src/useClientOnly.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE3C,MAAM,CAAC,OAAO,UAAU,aAAa;IACnC,MAAM,CAAC,YAAY,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAErD,SAAS,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;IAExC,OAAO,YAAY,CAAA;AACrB,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export default function useDisclosure(defaultExpanded?: boolean): {
|
|
2
|
+
toggleProps: {
|
|
3
|
+
readonly id: string;
|
|
4
|
+
readonly onClick: () => void;
|
|
5
|
+
readonly type: "button";
|
|
6
|
+
readonly 'aria-expanded': boolean;
|
|
7
|
+
readonly 'aria-controls': string;
|
|
8
|
+
};
|
|
9
|
+
contentProps: {
|
|
10
|
+
readonly id: string;
|
|
11
|
+
readonly 'aria-hidden': boolean;
|
|
12
|
+
readonly 'aria-labelledby': string;
|
|
13
|
+
};
|
|
14
|
+
isExpanded: boolean;
|
|
15
|
+
toggle: () => void;
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=useDisclosure.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDisclosure.d.ts","sourceRoot":"","sources":["../src/useDisclosure.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,eAAe,GAAE,OAAe;;;;;;;;;;;;;;;EA4BrE"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useState, useEffect, useId } from 'react';
|
|
2
|
+
export default function useDisclosure(defaultExpanded = false) {
|
|
3
|
+
const [isExpanded, setExpanded] = useState(defaultExpanded);
|
|
4
|
+
const id = useId();
|
|
5
|
+
useEffect(() => setExpanded(defaultExpanded), [defaultExpanded]);
|
|
6
|
+
const toggle = () => setExpanded((isExpanded) => !isExpanded);
|
|
7
|
+
const toggleProps = {
|
|
8
|
+
id: id + '-toggle',
|
|
9
|
+
onClick: toggle,
|
|
10
|
+
type: 'button',
|
|
11
|
+
'aria-expanded': isExpanded,
|
|
12
|
+
'aria-controls': id + '-content',
|
|
13
|
+
};
|
|
14
|
+
const contentProps = {
|
|
15
|
+
id: id + '-content',
|
|
16
|
+
'aria-hidden': !isExpanded,
|
|
17
|
+
'aria-labelledby': id + '-toggle',
|
|
18
|
+
};
|
|
19
|
+
return {
|
|
20
|
+
toggleProps,
|
|
21
|
+
contentProps,
|
|
22
|
+
isExpanded,
|
|
23
|
+
toggle,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=useDisclosure.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useDisclosure.js","sourceRoot":"","sources":["../src/useDisclosure.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,OAAO,CAAA;AAElD,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,kBAA2B,KAAK;IACpE,MAAM,CAAC,UAAU,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,eAAe,CAAC,CAAA;IAC3D,MAAM,EAAE,GAAG,KAAK,EAAE,CAAA;IAElB,SAAS,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,eAAe,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC,CAAA;IAEhE,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,CAAA;IAE7D,MAAM,WAAW,GAAG;QAClB,EAAE,EAAE,EAAE,GAAG,SAAS;QAClB,OAAO,EAAE,MAAM;QACf,IAAI,EAAE,QAAQ;QACd,eAAe,EAAE,UAAU;QAC3B,eAAe,EAAE,EAAE,GAAG,UAAU;KACxB,CAAA;IAEV,MAAM,YAAY,GAAG;QACnB,EAAE,EAAE,EAAE,GAAG,UAAU;QACnB,aAAa,EAAE,CAAC,UAAU;QAC1B,iBAAiB,EAAE,EAAE,GAAG,SAAS;KACzB,CAAA;IAEV,OAAO;QACL,WAAW;QACX,YAAY;QACZ,UAAU;QACV,MAAM;KACP,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFirstRender.d.ts","sourceRoot":"","sources":["../src/useFirstRender.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,cAAc,YASrC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFirstRender.js","sourceRoot":"","sources":["../src/useFirstRender.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAE9B,MAAM,CAAC,OAAO,UAAU,cAAc;IACpC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;IAExB,IAAI,GAAG,CAAC,OAAO,KAAK,IAAI,EAAE,CAAC;QACzB,GAAG,CAAC,OAAO,GAAG,KAAK,CAAA;QACnB,OAAO,IAAI,CAAA;IACb,CAAC;IAED,OAAO,GAAG,CAAC,OAAO,CAAA;AACpB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { RefObject } from 'react';
|
|
2
|
+
type Config = {
|
|
3
|
+
visible?: boolean;
|
|
4
|
+
autoFocus?: boolean;
|
|
5
|
+
};
|
|
6
|
+
export default function useFocusTrap(ref: RefObject<HTMLElement | null>, active: boolean, config?: Config): void;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=useFocusTrap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFocusTrap.d.ts","sourceRoot":"","sources":["../src/useFocusTrap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAa,MAAM,OAAO,CAAA;AAe5C,KAAK,MAAM,GAAG;IACZ,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AACD,MAAM,CAAC,OAAO,UAAU,YAAY,CAClC,GAAG,EAAE,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,EAClC,MAAM,EAAE,OAAO,EACf,MAAM,GAAE,MAAW,QAsFpB"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
import useKeyDown from './useKeyDown';
|
|
3
|
+
const focusableSelector = `:is(
|
|
4
|
+
a[href],
|
|
5
|
+
area[href],
|
|
6
|
+
input:not([disabled]),
|
|
7
|
+
select:not([disabled]),
|
|
8
|
+
textarea:not([disabled]),
|
|
9
|
+
button:not([disabled]),
|
|
10
|
+
[tabindex]:not([tabindex="-1"]),
|
|
11
|
+
[contenteditable]
|
|
12
|
+
)`;
|
|
13
|
+
export default function useFocusTrap(ref, active, config = {}) {
|
|
14
|
+
const { visible, autoFocus = true } = config;
|
|
15
|
+
useKeyDown('Tab', (e) => {
|
|
16
|
+
const element = ref.current;
|
|
17
|
+
if (!active || !element) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const focusables = [
|
|
21
|
+
...element.querySelectorAll(focusableSelector),
|
|
22
|
+
].filter((el) => el.hasAttribute('tabindex')
|
|
23
|
+
? el.getAttribute('tabindex') !== '-1'
|
|
24
|
+
: true);
|
|
25
|
+
const firstFocusable = focusables[0];
|
|
26
|
+
const lastFocusable = focusables[focusables.length - 1];
|
|
27
|
+
const activeElement = document.activeElement;
|
|
28
|
+
let nextElement;
|
|
29
|
+
if (activeElement && focusables.includes(activeElement)) {
|
|
30
|
+
const index = focusables.indexOf(activeElement);
|
|
31
|
+
if (e.shiftKey) {
|
|
32
|
+
if (index === 0) {
|
|
33
|
+
nextElement = lastFocusable;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
if (index === focusables.length - 1) {
|
|
38
|
+
nextElement = firstFocusable;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
if (e.shiftKey) {
|
|
44
|
+
nextElement = lastFocusable;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
nextElement = firstFocusable;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
if (nextElement) {
|
|
51
|
+
;
|
|
52
|
+
nextElement.focus();
|
|
53
|
+
e.preventDefault();
|
|
54
|
+
}
|
|
55
|
+
}, {
|
|
56
|
+
active,
|
|
57
|
+
});
|
|
58
|
+
useEffect(() => {
|
|
59
|
+
const element = ref.current;
|
|
60
|
+
if (!autoFocus || !visible || !element) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const autoFocusElement = element.querySelector('[data-autofocus="true"]' + focusableSelector);
|
|
64
|
+
if (autoFocusElement) {
|
|
65
|
+
// @ts-ignore
|
|
66
|
+
autoFocusElement.focus();
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const nodeList = element.querySelectorAll(focusableSelector);
|
|
70
|
+
const elements = Array.from(nodeList);
|
|
71
|
+
const focusableElements = elements.filter((element) => !element.hasAttribute('tabindex') ||
|
|
72
|
+
element.getAttribute('tabindex') === '0');
|
|
73
|
+
// 1. focus the first focusable
|
|
74
|
+
// @ts-ignore, TODO: fix typing
|
|
75
|
+
focusableElements[0]?.focus();
|
|
76
|
+
}, [visible, ref.current, autoFocus]);
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=useFocusTrap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFocusTrap.js","sourceRoot":"","sources":["../src/useFocusTrap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,MAAM,OAAO,CAAA;AAE5C,OAAO,UAAU,MAAM,cAAc,CAAA;AAErC,MAAM,iBAAiB,GAAG;;;;;;;;;EASxB,CAAA;AAMF,MAAM,CAAC,OAAO,UAAU,YAAY,CAClC,GAAkC,EAClC,MAAe,EACf,SAAiB,EAAE;IAEnB,MAAM,EAAE,OAAO,EAAE,SAAS,GAAG,IAAI,EAAE,GAAG,MAAM,CAAA;IAE5C,UAAU,CACR,KAAK,EACL,CAAC,CAAC,EAAE,EAAE;QACJ,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,CAAA;QAE3B,IAAI,CAAC,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;YACxB,OAAM;QACR,CAAC;QAED,MAAM,UAAU,GAAG;YACjB,GAAG,OAAO,CAAC,gBAAgB,CAAC,iBAAiB,CAAC;SAC/C,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CACd,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC;YACzB,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,IAAI;YACtC,CAAC,CAAC,IAAI,CACT,CAAA;QAED,MAAM,cAAc,GAAG,UAAU,CAAC,CAAC,CAAC,CAAA;QACpC,MAAM,aAAa,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAEvD,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAA;QAE5C,IAAI,WAAW,CAAA;QACf,IAAI,aAAa,IAAI,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;YACxD,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,CAAA;YAE/C,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACf,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;oBAChB,WAAW,GAAG,aAAa,CAAA;gBAC7B,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,KAAK,KAAK,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACpC,WAAW,GAAG,cAAc,CAAA;gBAC9B,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACf,WAAW,GAAG,aAAa,CAAA;YAC7B,CAAC;iBAAM,CAAC;gBACN,WAAW,GAAG,cAAc,CAAA;YAC9B,CAAC;QACH,CAAC;QACD,IAAI,WAAW,EAAE,CAAC;YAChB,CAAC;YAAC,WAA2B,CAAC,KAAK,EAAE,CAAA;YACrC,CAAC,CAAC,cAAc,EAAE,CAAA;QACpB,CAAC;IACH,CAAC,EACD;QACE,MAAM;KACP,CACF,CAAA;IAED,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,CAAA;QAE3B,IAAI,CAAC,SAAS,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;YACvC,OAAM;QACR,CAAC;QAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,aAAa,CAC5C,yBAAyB,GAAG,iBAAiB,CAC9C,CAAA;QAED,IAAI,gBAAgB,EAAE,CAAC;YACrB,aAAa;YACb,gBAAgB,CAAC,KAAK,EAAE,CAAA;YACxB,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,OAAO,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAA;QAC5D,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAErC,MAAM,iBAAiB,GAAG,QAAQ,CAAC,MAAM,CACvC,CAAC,OAAO,EAAE,EAAE,CACV,CAAC,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC;YACjC,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,GAAG,CAC3C,CAAA;QAED,+BAA+B;QAC/B,+BAA+B;QAC/B,iBAAiB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAA;IAC/B,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAA;AACvC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { RefObject } from 'react';
|
|
2
|
+
type Options = {
|
|
3
|
+
modifiers?: {
|
|
4
|
+
ctrl?: boolean;
|
|
5
|
+
meta?: boolean;
|
|
6
|
+
alt?: boolean;
|
|
7
|
+
shift?: boolean;
|
|
8
|
+
};
|
|
9
|
+
target?: RefObject<HTMLElement>;
|
|
10
|
+
active?: boolean;
|
|
11
|
+
};
|
|
12
|
+
export default function useKeyDown(keyCode: string | Array<string>, callback: (e: KeyboardEvent) => void, options?: Options): void;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=useKeyDown.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useKeyDown.d.ts","sourceRoot":"","sources":["../src/useKeyDown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAa,MAAM,OAAO,CAAA;AAE5C,KAAK,OAAO,GAAG;IACb,SAAS,CAAC,EAAE;QACV,IAAI,CAAC,EAAE,OAAO,CAAA;QACd,IAAI,CAAC,EAAE,OAAO,CAAA;QACd,GAAG,CAAC,EAAE,OAAO,CAAA;QACb,KAAK,CAAC,EAAE,OAAO,CAAA;KAChB,CAAA;IACD,MAAM,CAAC,EAAE,SAAS,CAAC,WAAW,CAAC,CAAA;IAC/B,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AACD,MAAM,CAAC,OAAO,UAAU,UAAU,CAChC,OAAO,EAAE,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,EAC/B,QAAQ,EAAE,CAAC,CAAC,EAAE,aAAa,KAAK,IAAI,EACpC,OAAO,GAAE,OAAY,QAkCtB"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
export default function useKeyDown(keyCode, callback, options = {}) {
|
|
3
|
+
const { active = true, target, modifiers = {} } = options;
|
|
4
|
+
const { ctrl = false, meta = false, alt = false, shift = false } = modifiers;
|
|
5
|
+
const keyCodes = [].concat(keyCode);
|
|
6
|
+
useEffect(() => {
|
|
7
|
+
if (!active || target === null || target?.current === null) {
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
const hasRef = target && target.current;
|
|
11
|
+
const element = target?.current ?? document;
|
|
12
|
+
if (element) {
|
|
13
|
+
const handleKeyDown = (event) => {
|
|
14
|
+
const e = event;
|
|
15
|
+
if (!keyCodes.includes(e.code))
|
|
16
|
+
return;
|
|
17
|
+
if (hasRef && document.activeElement !== element)
|
|
18
|
+
return;
|
|
19
|
+
if (ctrl && !e.ctrlKey)
|
|
20
|
+
return;
|
|
21
|
+
if (meta && !e.metaKey)
|
|
22
|
+
return;
|
|
23
|
+
if (alt && !e.altKey)
|
|
24
|
+
return;
|
|
25
|
+
if (shift && !e.shiftKey)
|
|
26
|
+
return;
|
|
27
|
+
callback(e);
|
|
28
|
+
};
|
|
29
|
+
element.addEventListener('keydown', handleKeyDown);
|
|
30
|
+
return () => element.removeEventListener('keydown', handleKeyDown);
|
|
31
|
+
}
|
|
32
|
+
}, [options, callback, active]);
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=useKeyDown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useKeyDown.js","sourceRoot":"","sources":["../src/useKeyDown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,MAAM,OAAO,CAAA;AAY5C,MAAM,CAAC,OAAO,UAAU,UAAU,CAChC,OAA+B,EAC/B,QAAoC,EACpC,UAAmB,EAAE;IAErB,MAAM,EAAE,MAAM,GAAG,IAAI,EAAE,MAAM,EAAE,SAAS,GAAG,EAAE,EAAE,GAAG,OAAO,CAAA;IACzD,MAAM,EAAE,IAAI,GAAG,KAAK,EAAE,IAAI,GAAG,KAAK,EAAE,GAAG,GAAG,KAAK,EAAE,KAAK,GAAG,KAAK,EAAE,GAAG,SAAS,CAAA;IAE5E,MAAM,QAAQ,GAAI,EAAoB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IAEtD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,MAAM,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,EAAE,OAAO,KAAK,IAAI,EAAE,CAAC;YAC3D,OAAM;QACR,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,IAAI,MAAM,CAAC,OAAO,CAAA;QACvC,MAAM,OAAO,GAA2B,MAAM,EAAE,OAAO,IAAI,QAAQ,CAAA;QAEnE,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,aAAa,GAAkB,CAAC,KAAK,EAAE,EAAE;gBAC7C,MAAM,CAAC,GAAG,KAAsB,CAAA;gBAEhC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;oBAAE,OAAM;gBACtC,IAAI,MAAM,IAAI,QAAQ,CAAC,aAAa,KAAK,OAAO;oBAAE,OAAM;gBAExD,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO;oBAAE,OAAM;gBAC9B,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,OAAO;oBAAE,OAAM;gBAC9B,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM;oBAAE,OAAM;gBAC5B,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,QAAQ;oBAAE,OAAM;gBAEhC,QAAQ,CAAC,CAAC,CAAC,CAAA;YACb,CAAC,CAAA;YAED,OAAO,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;YAClD,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAA;QACpE,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAA;AACjC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export default function useList<T>(initialList?: Array<T>): readonly [T[], {
|
|
2
|
+
set: (list: Array<T>) => void;
|
|
3
|
+
add: (item: T) => void;
|
|
4
|
+
removeAt: (index: number) => void;
|
|
5
|
+
updateAt: (index: number, item: T) => void;
|
|
6
|
+
insertAt: (index: number, item: T) => void;
|
|
7
|
+
clear: () => void;
|
|
8
|
+
}];
|
|
9
|
+
//# sourceMappingURL=useList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useList.d.ts","sourceRoot":"","sources":["../src/useList.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,CAAC,EAAE,WAAW,GAAE,KAAK,CAAC,CAAC,CAAM;gBAGxC,KAAK,CAAC,CAAC,CAAC;gBAGR,CAAC;sBAGK,MAAM;sBAGN,MAAM,QAAQ,CAAC;sBAGf,MAAM,QAAQ,CAAC;;GAiBzC"}
|
package/dist/useList.js
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useState } from 'react';
|
|
2
|
+
export default function useList(initialList = []) {
|
|
3
|
+
const [list, setList] = useState(initialList);
|
|
4
|
+
function set(list) {
|
|
5
|
+
setList(list);
|
|
6
|
+
}
|
|
7
|
+
function add(item) {
|
|
8
|
+
setList([...list, item]);
|
|
9
|
+
}
|
|
10
|
+
function removeAt(index) {
|
|
11
|
+
setList(list.filter((_, i) => i !== index));
|
|
12
|
+
}
|
|
13
|
+
function updateAt(index, item) {
|
|
14
|
+
setList(list.map((entry, i) => (i === index ? item : entry)));
|
|
15
|
+
}
|
|
16
|
+
function insertAt(index, item) {
|
|
17
|
+
setList([...list.slice(0, index), item, ...list.slice(index)]);
|
|
18
|
+
}
|
|
19
|
+
function clear() {
|
|
20
|
+
setList([]);
|
|
21
|
+
}
|
|
22
|
+
const actions = {
|
|
23
|
+
set,
|
|
24
|
+
add,
|
|
25
|
+
removeAt,
|
|
26
|
+
updateAt,
|
|
27
|
+
insertAt,
|
|
28
|
+
clear,
|
|
29
|
+
};
|
|
30
|
+
return [list, actions];
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=useList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useList.js","sourceRoot":"","sources":["../src/useList.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhC,MAAM,CAAC,OAAO,UAAU,OAAO,CAAI,cAAwB,EAAE;IAC3D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAW,WAAW,CAAC,CAAA;IAEvD,SAAS,GAAG,CAAC,IAAc;QACzB,OAAO,CAAC,IAAI,CAAC,CAAA;IACf,CAAC;IACD,SAAS,GAAG,CAAC,IAAO;QAClB,OAAO,CAAC,CAAC,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC,CAAA;IAC1B,CAAC;IACD,SAAS,QAAQ,CAAC,KAAa;QAC7B,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAA;IAC7C,CAAC;IACD,SAAS,QAAQ,CAAC,KAAa,EAAE,IAAO;QACtC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IAC/D,CAAC;IACD,SAAS,QAAQ,CAAC,KAAa,EAAE,IAAO;QACtC,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IAChE,CAAC;IACD,SAAS,KAAK;QACZ,OAAO,CAAC,EAAE,CAAC,CAAA;IACb,CAAC;IAED,MAAM,OAAO,GAAG;QACd,GAAG;QACH,GAAG;QACH,QAAQ;QACR,QAAQ;QACR,QAAQ;QACR,KAAK;KACN,CAAA;IAED,OAAO,CAAC,IAAI,EAAE,OAAO,CAAU,CAAA;AACjC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRerender.d.ts","sourceRoot":"","sources":["../src/useRerender.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,WAAW,CAAC,cAAc,GAAE,MAAkB,QAYrE"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
export default function useRerender(updateInterval = 60 * 1000) {
|
|
3
|
+
const [time, setTime] = useState(new Date());
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
const interval = setInterval(() => {
|
|
6
|
+
setTime(new Date());
|
|
7
|
+
}, updateInterval);
|
|
8
|
+
return () => clearInterval(interval);
|
|
9
|
+
}, []);
|
|
10
|
+
return time;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=useRerender.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRerender.js","sourceRoot":"","sources":["../src/useRerender.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE3C,MAAM,CAAC,OAAO,UAAU,WAAW,CAAC,iBAAyB,EAAE,GAAG,IAAI;IACpE,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;IAE5C,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;QACrB,CAAC,EAAE,cAAc,CAAC,CAAA;QAElB,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;IACtC,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,IAAI,CAAA;AACb,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRouteChange.d.ts","sourceRoot":"","sources":["../src/useRouteChange.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,cAAc,CACpC,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,EACrC,QAAQ,CAAC,EAAE,MAAM,EACjB,YAAY,GAAE,GAAG,EAAO,QAyBzB"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
export default function useRouteChange(onRouteChange, pathname, dependencies = []) {
|
|
3
|
+
useEffect(() => {
|
|
4
|
+
if (pathname) {
|
|
5
|
+
onRouteChange(pathname);
|
|
6
|
+
}
|
|
7
|
+
}, [pathname, ...dependencies]);
|
|
8
|
+
// track clicks on links with the current path
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
const onClick = (e) => {
|
|
11
|
+
const target = e.target;
|
|
12
|
+
const anchor = getContainingAnchor(e.target);
|
|
13
|
+
if ((target.tagName === 'A' && target.href === pathname) ||
|
|
14
|
+
(anchor !== null && anchor?.pathname === pathname)) {
|
|
15
|
+
onRouteChange(pathname);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
window.addEventListener('click', onClick);
|
|
19
|
+
return () => window.removeEventListener('click', onClick);
|
|
20
|
+
}, [pathname, ...dependencies]);
|
|
21
|
+
}
|
|
22
|
+
function getContainingAnchor(node) {
|
|
23
|
+
if (!node || !(node instanceof Node))
|
|
24
|
+
return null;
|
|
25
|
+
if (node.nodeType === Node.ELEMENT_NODE) {
|
|
26
|
+
return node.closest('a');
|
|
27
|
+
}
|
|
28
|
+
// For text/other nodes, start at the nearest Element ancestor
|
|
29
|
+
const parent = node.parentElement ||
|
|
30
|
+
node.parentNode;
|
|
31
|
+
return parent?.closest('a');
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=useRouteChange.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRouteChange.js","sourceRoot":"","sources":["../src/useRouteChange.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEjC,MAAM,CAAC,OAAO,UAAU,cAAc,CACpC,aAAqC,EACrC,QAAiB,EACjB,eAAsB,EAAE;IAExB,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,CAAC,QAAQ,CAAC,CAAA;QACzB,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,YAAY,CAAC,CAAC,CAAA;IAE/B,8CAA8C;IAC9C,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,OAAO,GAAG,CAAC,CAAa,EAAE,EAAE;YAChC,MAAM,MAAM,GAAG,CAAC,CAAC,MAA2B,CAAA;YAC5C,MAAM,MAAM,GAAG,mBAAmB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAA;YAE5C,IACE,CAAC,MAAM,CAAC,OAAO,KAAK,GAAG,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,CAAC;gBACpD,CAAC,MAAM,KAAK,IAAI,IAAI,MAAM,EAAE,QAAQ,KAAK,QAAQ,CAAC,EAClD,CAAC;gBACD,aAAa,CAAC,QAAQ,CAAC,CAAA;YACzB,CAAC;QACH,CAAC,CAAA;QAED,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;QACzC,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;IAC3D,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,YAAY,CAAC,CAAC,CAAA;AACjC,CAAC;AAED,SAAS,mBAAmB,CAC1B,IAA+B;IAE/B,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,YAAY,IAAI,CAAC;QAAE,OAAO,IAAI,CAAA;IAEjD,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;QACxC,OAAQ,IAAgB,CAAC,OAAO,CAAC,GAAG,CAA6B,CAAA;IACnE,CAAC;IAED,8DAA8D;IAC9D,MAAM,MAAM,GACT,IAAI,CAAC,aAAgC;QACrC,IAAI,CAAC,UAA6B,CAAA;IAErC,OAAO,MAAM,EAAE,OAAO,CAAC,GAAG,CAA6B,CAAA;AACzD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useScrollBlocking.d.ts","sourceRoot":"","sources":["../src/useScrollBlocking.ts"],"names":[],"mappings":"AAmCA,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,MAAM,EAAE,OAAO,QAExD"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
let scrollTop;
|
|
3
|
+
function blockScrolling(scrollElement) {
|
|
4
|
+
scrollTop = window.scrollY;
|
|
5
|
+
scrollElement.style.overflow = 'hidden';
|
|
6
|
+
scrollElement.style.position = 'fixed';
|
|
7
|
+
scrollElement.style.width = '100%';
|
|
8
|
+
scrollElement.style.top = -scrollTop + 'px';
|
|
9
|
+
}
|
|
10
|
+
function enableScrolling(scrollElement) {
|
|
11
|
+
if (scrollElement.style.position !== 'fixed') {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
scrollElement.style.removeProperty('position');
|
|
15
|
+
scrollElement.style.removeProperty('overflow');
|
|
16
|
+
scrollElement.style.removeProperty('top');
|
|
17
|
+
scrollElement.style.removeProperty('width');
|
|
18
|
+
window.scrollTo(0, scrollTop);
|
|
19
|
+
}
|
|
20
|
+
function toggleScrolling(isBlocked) {
|
|
21
|
+
const scrollElement = document.scrollingElement;
|
|
22
|
+
if (isBlocked) {
|
|
23
|
+
blockScrolling(scrollElement);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
enableScrolling(scrollElement);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
export default function useScrollBlocking(active) {
|
|
30
|
+
useEffect(() => toggleScrolling(active), [active]);
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=useScrollBlocking.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useScrollBlocking.js","sourceRoot":"","sources":["../src/useScrollBlocking.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEjC,IAAI,SAAiB,CAAA;AACrB,SAAS,cAAc,CAAC,aAA0B;IAChD,SAAS,GAAG,MAAM,CAAC,OAAO,CAAA;IAE1B,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAA;IACvC,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAA;IACtC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAA;IAClC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,SAAS,GAAG,IAAI,CAAA;AAC7C,CAAC;AAED,SAAS,eAAe,CAAC,aAA0B;IACjD,IAAI,aAAa,CAAC,KAAK,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC;QAC7C,OAAM;IACR,CAAC;IAED,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,CAAA;IAC9C,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,CAAA;IAC9C,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;IACzC,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAA;IAE3C,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,SAAS,CAAC,CAAA;AAC/B,CAAC;AAED,SAAS,eAAe,CAAC,SAAkB;IACzC,MAAM,aAAa,GAAG,QAAQ,CAAC,gBAA+B,CAAA;IAE9D,IAAI,SAAS,EAAE,CAAC;QACd,cAAc,CAAC,aAAa,CAAC,CAAA;IAC/B,CAAC;SAAM,CAAC;QACN,eAAe,CAAC,aAAa,CAAC,CAAA;IAChC,CAAC;AACH,CAAC;AAED,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,MAAe;IACvD,SAAS,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;AACpD,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { type BaseNode, type BaseNodeInput } from '@weser/tree';
|
|
2
|
+
export default function useTree<T extends BaseNode<T>>(initialTree: T): {
|
|
3
|
+
tree: T;
|
|
4
|
+
setTree: import("react").Dispatch<import("react").SetStateAction<T>>;
|
|
5
|
+
traverse: (callback: (node: T) => void) => void;
|
|
6
|
+
create: (node: T extends any ? Omit<T, "id"> : never) => T;
|
|
7
|
+
get: (id: string, rootNode?: T) => T | null;
|
|
8
|
+
clone: (id: string) => T | null;
|
|
9
|
+
getParent: (id: string) => T | null;
|
|
10
|
+
find: (condition: (node: T) => boolean) => T | null;
|
|
11
|
+
findAll: (condition: (node: T) => boolean) => T[];
|
|
12
|
+
update: (id: string, newNode: Partial<BaseNodeInput<T>>) => void;
|
|
13
|
+
replace: (id: string, newNode: T) => void;
|
|
14
|
+
remove: (id: string) => void;
|
|
15
|
+
add: (id: string, newNode: T) => void;
|
|
16
|
+
insert: (id: string, index: number, newNode: T) => void;
|
|
17
|
+
move: (id: string, parentId: string, index?: number) => void;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=useTree.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTree.d.ts","sourceRoot":"","sources":["../src/useTree.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,QAAQ,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAA;AAG/D,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,CAAC,SAAS,QAAQ,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC;;;yBAS5C,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI;;cAE5B,MAAM,aAAY,CAAC;gBACjB,MAAM;oBACF,MAAM;sBACJ,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO;yBACjB,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO;iBAG5B,MAAM,WAAW,OAAO,kBAAW;kBAElC,MAAM,WAAW,CAAC;iBAEnB,MAAM;cACT,MAAM,WAAW,CAAC;iBAEf,MAAM,SAAS,MAAM,WAAW,CAAC;eAEnC,MAAM,YAAY,MAAM,UAAU,MAAM;EAGtD"}
|
package/dist/useTree.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { useState } from 'react';
|
|
2
|
+
import * as utils from '@weser/tree';
|
|
3
|
+
export default function useTree(initialTree) {
|
|
4
|
+
const [tree, setTree] = useState(initialTree);
|
|
5
|
+
return {
|
|
6
|
+
tree,
|
|
7
|
+
setTree,
|
|
8
|
+
// helpers
|
|
9
|
+
traverse: (callback) => utils.traverse(tree, callback),
|
|
10
|
+
create: (utils.create),
|
|
11
|
+
get: (id, rootNode = tree) => utils.get(rootNode, id),
|
|
12
|
+
clone: (id) => utils.clone(tree, id),
|
|
13
|
+
getParent: (id) => utils.getParent(tree, id),
|
|
14
|
+
find: (condition) => utils.find(tree, condition),
|
|
15
|
+
findAll: (condition) => utils.findAll(tree, condition),
|
|
16
|
+
// actions
|
|
17
|
+
update: (id, newNode) => setTree((tree) => utils.update(tree, id, newNode)),
|
|
18
|
+
replace: (id, newNode) => setTree((tree) => utils.replace(tree, id, newNode)),
|
|
19
|
+
remove: (id) => setTree((tree) => utils.remove(tree, id)),
|
|
20
|
+
add: (id, newNode) => setTree((tree) => utils.add(tree, id, newNode)),
|
|
21
|
+
insert: (id, index, newNode) => setTree((tree) => utils.insert(tree, id, index, newNode)),
|
|
22
|
+
move: (id, parentId, index) => setTree((tree) => utils.move(tree, id, parentId, index)),
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=useTree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTree.js","sourceRoot":"","sources":["../src/useTree.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhC,OAAO,KAAK,KAAK,MAAM,aAAa,CAAA;AAEpC,MAAM,CAAC,OAAO,UAAU,OAAO,CAAwB,WAAc;IAGnE,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAI,WAAW,CAAC,CAAA;IAEhD,OAAO;QACL,IAAI;QACJ,OAAO;QACP,UAAU;QACV,QAAQ,EAAE,CAAC,QAA2B,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC;QACzE,MAAM,EAAE,CAAA,KAAK,CAAC,MAAS,CAAA;QACvB,GAAG,EAAE,CAAC,EAAU,EAAE,WAAc,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC;QAChE,KAAK,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;QAC5C,SAAS,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC;QACpD,IAAI,EAAE,CAAC,SAA+B,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC;QACtE,OAAO,EAAE,CAAC,SAA+B,EAAE,EAAE,CAC3C,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC;QAChC,UAAU;QACV,MAAM,EAAE,CAAC,EAAU,EAAE,OAA2B,EAAE,EAAE,CAClD,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC;QACpD,OAAO,EAAE,CAAC,EAAU,EAAE,OAAU,EAAE,EAAE,CAClC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC;QACrD,MAAM,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACjE,GAAG,EAAE,CAAC,EAAU,EAAE,OAAU,EAAE,EAAE,CAC9B,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC;QACjD,MAAM,EAAE,CAAC,EAAU,EAAE,KAAa,EAAE,OAAU,EAAE,EAAE,CAChD,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QAC3D,IAAI,EAAE,CAAC,EAAU,EAAE,QAAgB,EAAE,KAAc,EAAE,EAAE,CACrD,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;KAC3D,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { RefObject } from 'react';
|
|
2
|
+
type Props<T> = {
|
|
3
|
+
defaultVisible?: boolean;
|
|
4
|
+
getTrigger?: () => T | null;
|
|
5
|
+
};
|
|
6
|
+
export default function useTrigger<T extends HTMLElement = HTMLButtonElement>({ defaultVisible, getTrigger, }?: Props<T>): [boolean, (visible: boolean) => void, RefObject<T>];
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=useTrigger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTrigger.d.ts","sourceRoot":"","sources":["../src/useTrigger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA+B,MAAM,OAAO,CAAA;AAE9D,KAAK,KAAK,CAAC,CAAC,IAAI;IACd,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC,GAAG,IAAI,CAAA;CAC5B,CAAA;AACD,MAAM,CAAC,OAAO,UAAU,UAAU,CAAC,CAAC,SAAS,WAAW,GAAG,iBAAiB,EAAE,EAC5E,cAAsB,EACtB,UAAU,GACX,GAAE,KAAK,CAAC,CAAC,CAAM,GAAG,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CA6BrE"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { useEffect, useRef, useState } from 'react';
|
|
2
|
+
export default function useTrigger({ defaultVisible = false, getTrigger, } = {}) {
|
|
3
|
+
const triggerRef = useRef(null);
|
|
4
|
+
const [isVisible, _setVisible] = useState(false);
|
|
5
|
+
function getTriggerElement() {
|
|
6
|
+
if (getTrigger) {
|
|
7
|
+
return getTrigger();
|
|
8
|
+
}
|
|
9
|
+
return triggerRef.current;
|
|
10
|
+
}
|
|
11
|
+
function setVisible(visible) {
|
|
12
|
+
if (isVisible !== visible) {
|
|
13
|
+
_setVisible(visible);
|
|
14
|
+
if (!visible) {
|
|
15
|
+
const trigger = getTriggerElement();
|
|
16
|
+
if (trigger) {
|
|
17
|
+
trigger.focus({ preventScroll: true });
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
useEffect(() => _setVisible(defaultVisible), [defaultVisible]);
|
|
23
|
+
return [isVisible, setVisible, triggerRef];
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=useTrigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTrigger.js","sourceRoot":"","sources":["../src/useTrigger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAM9D,MAAM,CAAC,OAAO,UAAU,UAAU,CAA4C,EAC5E,cAAc,GAAG,KAAK,EACtB,UAAU,MACE,EAAE;IACd,MAAM,UAAU,GAAG,MAAM,CAAI,IAAI,CAAC,CAAA;IAClC,MAAM,CAAC,SAAS,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAA;IAEzD,SAAS,iBAAiB;QACxB,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,UAAU,EAAE,CAAA;QACrB,CAAC;QAED,OAAO,UAAU,CAAC,OAAO,CAAA;IAC3B,CAAC;IAED,SAAS,UAAU,CAAC,OAAgB;QAClC,IAAI,SAAS,KAAK,OAAO,EAAE,CAAC;YAC1B,WAAW,CAAC,OAAO,CAAC,CAAA;YAEpB,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAA;gBAEnC,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,CAAC,KAAK,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAA;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,SAAS,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAA;IAE9D,OAAO,CAAC,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC,CAAA;AAC5C,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@weser/hook",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "React hooks for building apps",
|
|
5
|
+
"author": "Robin Weser <robin@weser.io>",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"homepage": "https://github.com/robinweser/weserstack.git",
|
|
8
|
+
"repository": "https://github.com/robinweser/weserstack.git",
|
|
9
|
+
"type": "module",
|
|
10
|
+
"main": "dist/index.js",
|
|
11
|
+
"module": "dist/index.js",
|
|
12
|
+
"types": "dist/index.d.ts",
|
|
13
|
+
"sideEffects": false,
|
|
14
|
+
"publishConfig": {
|
|
15
|
+
"access": "public"
|
|
16
|
+
},
|
|
17
|
+
"files": [
|
|
18
|
+
"LICENSE",
|
|
19
|
+
"README.md",
|
|
20
|
+
"dist/**"
|
|
21
|
+
],
|
|
22
|
+
"browserslist": [
|
|
23
|
+
"IE >= 11",
|
|
24
|
+
"Firefox >= 60",
|
|
25
|
+
"Safari >= 11.1",
|
|
26
|
+
"Chrome >= 66",
|
|
27
|
+
"ChromeAndroid >= 66",
|
|
28
|
+
"iOS >= 11.3",
|
|
29
|
+
"Edge >= 15"
|
|
30
|
+
],
|
|
31
|
+
"scripts": {
|
|
32
|
+
"setup": "pnpm build",
|
|
33
|
+
"clean": "rimraf dist",
|
|
34
|
+
"build": "tsc -b",
|
|
35
|
+
"dev": "pnpm build -w",
|
|
36
|
+
"test": "echo 1"
|
|
37
|
+
},
|
|
38
|
+
"keywords": [
|
|
39
|
+
"react",
|
|
40
|
+
"react-hook",
|
|
41
|
+
"react hooks",
|
|
42
|
+
"hooks",
|
|
43
|
+
"utils"
|
|
44
|
+
],
|
|
45
|
+
"dependencies": {
|
|
46
|
+
"@weser/tree": "2.0.0"
|
|
47
|
+
},
|
|
48
|
+
"peerDependencies": {
|
|
49
|
+
"react": ">16.3.0"
|
|
50
|
+
},
|
|
51
|
+
"devDependencies": {
|
|
52
|
+
"@types/react": "^18.3.3",
|
|
53
|
+
"ava": "^6.1.3",
|
|
54
|
+
"react": "canary",
|
|
55
|
+
"rimraf": "^3.0.2",
|
|
56
|
+
"typescript": "^5.4.5"
|
|
57
|
+
},
|
|
58
|
+
"gitHead": "45f425a5a38595dcf1553593c97ea5ffc9fd0c25"
|
|
59
|
+
}
|