@apia/util 1.0.4 → 2.0.1

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 (274) hide show
  1. package/dist/animate/index.d.ts +4 -0
  2. package/dist/animate/index.d.ts.map +1 -0
  3. package/dist/animate/index.js +24 -0
  4. package/dist/animate/index.js.map +1 -0
  5. package/dist/array/arrayOrArray.d.ts +4 -0
  6. package/dist/array/arrayOrArray.d.ts.map +1 -0
  7. package/dist/array/arrayOrArray.js +8 -0
  8. package/dist/array/arrayOrArray.js.map +1 -0
  9. package/dist/array/getIndex.d.ts +14 -0
  10. package/dist/array/getIndex.d.ts.map +1 -0
  11. package/dist/array/getIndex.js +12 -0
  12. package/dist/array/getIndex.js.map +1 -0
  13. package/dist/crypto/decrypt.d.ts +4 -0
  14. package/dist/crypto/decrypt.d.ts.map +1 -0
  15. package/dist/crypto/decrypt.js +16 -0
  16. package/dist/crypto/decrypt.js.map +1 -0
  17. package/dist/crypto/encrypt.d.ts +4 -0
  18. package/dist/crypto/encrypt.d.ts.map +1 -0
  19. package/dist/crypto/encrypt.js +13 -0
  20. package/dist/crypto/encrypt.js.map +1 -0
  21. package/dist/crypto/generateKey.js +11 -0
  22. package/dist/crypto/generateKey.js.map +1 -0
  23. package/dist/date/apiaDateToStandarFormat.d.ts +4 -0
  24. package/dist/date/apiaDateToStandarFormat.d.ts.map +1 -0
  25. package/dist/date/apiaDateToStandarFormat.js +12 -0
  26. package/dist/date/apiaDateToStandarFormat.js.map +1 -0
  27. package/dist/date/dateToApiaFormat.d.ts +4 -0
  28. package/dist/date/dateToApiaFormat.d.ts.map +1 -0
  29. package/dist/date/dateToApiaFormat.js +9 -0
  30. package/dist/date/dateToApiaFormat.js.map +1 -0
  31. package/dist/date/getDateFormat.d.ts +11 -0
  32. package/dist/date/getDateFormat.d.ts.map +1 -0
  33. package/dist/date/getDateFormat.js +20 -0
  34. package/dist/date/getDateFormat.js.map +1 -0
  35. package/dist/debug/debugDispatcher.d.ts +32 -0
  36. package/dist/debug/debugDispatcher.d.ts.map +1 -0
  37. package/dist/debug/debugDispatcher.js +72 -0
  38. package/dist/debug/debugDispatcher.js.map +1 -0
  39. package/dist/debug/shortcutController.d.ts +57 -0
  40. package/dist/debug/shortcutController.d.ts.map +1 -0
  41. package/dist/debug/shortcutController.js +152 -0
  42. package/dist/debug/shortcutController.js.map +1 -0
  43. package/dist/documents/downloadStringAsDoc.d.ts +8 -0
  44. package/dist/documents/downloadStringAsDoc.d.ts.map +1 -0
  45. package/dist/documents/downloadStringAsDoc.js +12 -0
  46. package/dist/documents/downloadStringAsDoc.js.map +1 -0
  47. package/dist/documents/downloadUrl.d.ts +20 -0
  48. package/dist/documents/downloadUrl.d.ts.map +1 -0
  49. package/dist/documents/downloadUrl.js +18 -0
  50. package/dist/documents/downloadUrl.js.map +1 -0
  51. package/dist/documents/openAndReadFile.d.ts +4 -0
  52. package/dist/documents/openAndReadFile.d.ts.map +1 -0
  53. package/dist/documents/openAndReadFile.js +29 -0
  54. package/dist/documents/openAndReadFile.js.map +1 -0
  55. package/dist/dom/autoDisconnectMutationObserver.d.ts +17 -0
  56. package/dist/dom/autoDisconnectMutationObserver.d.ts.map +1 -0
  57. package/dist/dom/autoDisconnectMutationObserver.js +35 -0
  58. package/dist/dom/autoDisconnectMutationObserver.js.map +1 -0
  59. package/dist/dom/customEvents.d.ts +40 -0
  60. package/dist/dom/customEvents.d.ts.map +1 -0
  61. package/dist/dom/customEvents.js +34 -0
  62. package/dist/dom/customEvents.js.map +1 -0
  63. package/dist/dom/enableChildrenFocus.d.ts +18 -0
  64. package/dist/dom/enableChildrenFocus.d.ts.map +1 -0
  65. package/dist/dom/enableChildrenFocus.js +26 -0
  66. package/dist/dom/enableChildrenFocus.js.map +1 -0
  67. package/dist/dom/findOffsetRelativeToScrollParent.d.ts +7 -0
  68. package/dist/dom/findOffsetRelativeToScrollParent.d.ts.map +1 -0
  69. package/dist/dom/findOffsetRelativeToScrollParent.js +19 -0
  70. package/dist/dom/findOffsetRelativeToScrollParent.js.map +1 -0
  71. package/dist/dom/findScrollContainer.d.ts +8 -0
  72. package/dist/dom/findScrollContainer.d.ts.map +1 -0
  73. package/dist/dom/findScrollContainer.js +9 -0
  74. package/dist/dom/findScrollContainer.js.map +1 -0
  75. package/dist/dom/getFocusSelector.d.ts +25 -0
  76. package/dist/dom/getFocusSelector.d.ts.map +1 -0
  77. package/dist/dom/getFocusSelector.js +30 -0
  78. package/dist/dom/getFocusSelector.js.map +1 -0
  79. package/dist/dom/getSpecificParent.d.ts +23 -0
  80. package/dist/dom/getSpecificParent.d.ts.map +1 -0
  81. package/dist/dom/getSpecificParent.js +19 -0
  82. package/dist/dom/getSpecificParent.js.map +1 -0
  83. package/dist/dom/isChild.d.ts +13 -0
  84. package/dist/dom/isChild.d.ts.map +1 -0
  85. package/dist/dom/isChild.js +8 -0
  86. package/dist/dom/isChild.js.map +1 -0
  87. package/dist/dom/scrollParentIntoElement.d.ts +9 -0
  88. package/dist/dom/scrollParentIntoElement.d.ts.map +1 -0
  89. package/dist/dom/scrollParentIntoElement.js +24 -0
  90. package/dist/dom/scrollParentIntoElement.js.map +1 -0
  91. package/dist/dom/url.d.ts +18 -0
  92. package/dist/dom/url.d.ts.map +1 -0
  93. package/dist/dom/url.js +52 -0
  94. package/dist/dom/url.js.map +1 -0
  95. package/dist/dom/usePanAndZoom.d.ts +14 -0
  96. package/dist/dom/usePanAndZoom.d.ts.map +1 -0
  97. package/dist/dom/usePanAndZoom.js +111 -0
  98. package/dist/dom/usePanAndZoom.js.map +1 -0
  99. package/dist/encoding/index.d.ts +8 -0
  100. package/dist/encoding/index.d.ts.map +1 -0
  101. package/dist/encoding/index.js +12 -0
  102. package/dist/encoding/index.js.map +1 -0
  103. package/dist/events/BouncingEmitter.d.ts +67 -0
  104. package/dist/events/BouncingEmitter.d.ts.map +1 -0
  105. package/dist/events/BouncingEmitter.js +72 -0
  106. package/dist/events/BouncingEmitter.js.map +1 -0
  107. package/dist/events/EventEmitter.d.ts +47 -0
  108. package/dist/events/EventEmitter.d.ts.map +1 -0
  109. package/dist/events/EventEmitter.js +75 -0
  110. package/dist/events/EventEmitter.js.map +1 -0
  111. package/dist/events/StatefulEmitter.d.ts +44 -0
  112. package/dist/events/StatefulEmitter.d.ts.map +1 -0
  113. package/dist/events/StatefulEmitter.js +57 -0
  114. package/dist/events/StatefulEmitter.js.map +1 -0
  115. package/dist/events/types.d.ts +29 -0
  116. package/dist/events/types.d.ts.map +1 -0
  117. package/dist/focus/focusController.d.ts +108 -0
  118. package/dist/focus/focusController.d.ts.map +1 -0
  119. package/dist/focus/focusController.js +295 -0
  120. package/dist/focus/focusController.js.map +1 -0
  121. package/dist/focus/globalFocus.d.ts +24 -0
  122. package/dist/focus/globalFocus.d.ts.map +1 -0
  123. package/dist/focus/globalFocus.js +87 -0
  124. package/dist/focus/globalFocus.js.map +1 -0
  125. package/dist/history/History.d.ts +81 -0
  126. package/dist/history/History.d.ts.map +1 -0
  127. package/dist/history/History.js +122 -0
  128. package/dist/history/History.js.map +1 -0
  129. package/dist/hooks/useCombinedRefs.d.ts +18 -0
  130. package/dist/hooks/useCombinedRefs.d.ts.map +1 -0
  131. package/dist/hooks/useCombinedRefs.js +20 -0
  132. package/dist/hooks/useCombinedRefs.js.map +1 -0
  133. package/dist/hooks/useDebouncedCallback.d.ts +7 -0
  134. package/dist/hooks/useDebouncedCallback.d.ts.map +1 -0
  135. package/dist/hooks/useDebouncedCallback.js +21 -0
  136. package/dist/hooks/useDebouncedCallback.js.map +1 -0
  137. package/dist/hooks/useLatest.d.ts +13 -0
  138. package/dist/hooks/useLatest.d.ts.map +1 -0
  139. package/dist/hooks/useLatest.js +10 -0
  140. package/dist/hooks/useLatest.js.map +1 -0
  141. package/dist/hooks/useMount.d.ts +6 -0
  142. package/dist/hooks/useMount.d.ts.map +1 -0
  143. package/dist/hooks/useMount.js +14 -0
  144. package/dist/hooks/useMount.js.map +1 -0
  145. package/dist/hooks/usePrevious.d.ts +6 -0
  146. package/dist/hooks/usePrevious.d.ts.map +1 -0
  147. package/dist/hooks/usePrevious.js +12 -0
  148. package/dist/hooks/usePrevious.js.map +1 -0
  149. package/dist/hooks/useShallowMemo.d.ts +9 -0
  150. package/dist/hooks/useShallowMemo.d.ts.map +1 -0
  151. package/dist/hooks/useShallowMemo.js +42 -0
  152. package/dist/hooks/useShallowMemo.js.map +1 -0
  153. package/dist/hooks/useStateRef.d.ts +10 -0
  154. package/dist/hooks/useStateRef.d.ts.map +1 -0
  155. package/dist/hooks/useStateRef.js +11 -0
  156. package/dist/hooks/useStateRef.js.map +1 -0
  157. package/dist/hooks/useSubscription.d.ts +31 -0
  158. package/dist/hooks/useSubscription.d.ts.map +1 -0
  159. package/dist/hooks/useSubscription.js +21 -0
  160. package/dist/hooks/useSubscription.js.map +1 -0
  161. package/dist/hooks/useUnmount.d.ts +4 -0
  162. package/dist/hooks/useUnmount.d.ts.map +1 -0
  163. package/dist/hooks/useUnmount.js +10 -0
  164. package/dist/hooks/useUnmount.js.map +1 -0
  165. package/dist/hooks/useUpdateEffect.d.ts +10 -0
  166. package/dist/hooks/useUpdateEffect.d.ts.map +1 -0
  167. package/dist/hooks/useUpdateEffect.js +16 -0
  168. package/dist/hooks/useUpdateEffect.js.map +1 -0
  169. package/dist/imperative/makeImperativeComponent.d.ts +56 -0
  170. package/dist/imperative/makeImperativeComponent.d.ts.map +1 -0
  171. package/dist/imperative/makeImperativeComponent.js +48 -0
  172. package/dist/imperative/makeImperativeComponent.js.map +1 -0
  173. package/dist/imperative/makeSingleImperativeComponent.d.ts +15 -0
  174. package/dist/imperative/makeSingleImperativeComponent.d.ts.map +1 -0
  175. package/dist/imperative/makeSingleImperativeComponent.js +31 -0
  176. package/dist/imperative/makeSingleImperativeComponent.js.map +1 -0
  177. package/dist/imperative/types.d.ts +22 -0
  178. package/dist/imperative/types.d.ts.map +1 -0
  179. package/dist/imperative/types.js +8 -0
  180. package/dist/imperative/types.js.map +1 -0
  181. package/dist/imperative/useImperativeComponentEvents.d.ts +6 -0
  182. package/dist/imperative/useImperativeComponentEvents.d.ts.map +1 -0
  183. package/dist/imperative/useImperativeComponentEvents.js +35 -0
  184. package/dist/imperative/useImperativeComponentEvents.js.map +1 -0
  185. package/dist/imperative/useImperativeIdentifierContext.d.ts +14 -0
  186. package/dist/imperative/useImperativeIdentifierContext.d.ts.map +1 -0
  187. package/dist/imperative/useImperativeIdentifierContext.js +10 -0
  188. package/dist/imperative/useImperativeIdentifierContext.js.map +1 -0
  189. package/dist/index.d.ts +69 -1777
  190. package/dist/index.js +63 -2659
  191. package/dist/index.js.map +1 -1
  192. package/dist/labels/formatMessage.d.ts +19 -0
  193. package/dist/labels/formatMessage.d.ts.map +1 -0
  194. package/dist/labels/formatMessage.js +13 -0
  195. package/dist/labels/formatMessage.js.map +1 -0
  196. package/dist/labels/getLabel.d.ts +34 -0
  197. package/dist/labels/getLabel.d.ts.map +1 -0
  198. package/dist/labels/getLabel.js +18 -0
  199. package/dist/labels/getLabel.js.map +1 -0
  200. package/dist/number/index.d.ts +29 -0
  201. package/dist/number/index.d.ts.map +1 -0
  202. package/dist/number/index.js +43 -0
  203. package/dist/number/index.js.map +1 -0
  204. package/dist/objects/getValueByPath.d.ts +23 -0
  205. package/dist/objects/getValueByPath.d.ts.map +1 -0
  206. package/dist/objects/getValueByPath.js +19 -0
  207. package/dist/objects/getValueByPath.js.map +1 -0
  208. package/dist/objects/setValueByPath.d.ts +33 -0
  209. package/dist/objects/setValueByPath.d.ts.map +1 -0
  210. package/dist/objects/setValueByPath.js +35 -0
  211. package/dist/objects/setValueByPath.js.map +1 -0
  212. package/dist/propsStore/propsStore.d.ts +42 -0
  213. package/dist/propsStore/propsStore.d.ts.map +1 -0
  214. package/dist/propsStore/propsStore.js +157 -0
  215. package/dist/propsStore/propsStore.js.map +1 -0
  216. package/dist/propsStore/types.d.ts +24 -0
  217. package/dist/propsStore/types.d.ts.map +1 -0
  218. package/dist/propsStore/usePropsSelector.d.ts +67 -0
  219. package/dist/propsStore/usePropsSelector.d.ts.map +1 -0
  220. package/dist/propsStore/usePropsSelector.js +92 -0
  221. package/dist/propsStore/usePropsSelector.js.map +1 -0
  222. package/dist/screenLock/screenLocker.d.ts +60 -0
  223. package/dist/screenLock/screenLocker.d.ts.map +1 -0
  224. package/dist/screenLock/screenLocker.js +95 -0
  225. package/dist/screenLock/screenLocker.js.map +1 -0
  226. package/dist/states/useDebouncedState.d.ts +10 -0
  227. package/dist/states/useDebouncedState.d.ts.map +1 -0
  228. package/dist/states/useDebouncedState.js +22 -0
  229. package/dist/states/useDebouncedState.js.map +1 -0
  230. package/dist/states/useDomState.d.ts +86 -0
  231. package/dist/states/useDomState.d.ts.map +1 -0
  232. package/dist/states/useDomState.js +35 -0
  233. package/dist/states/useDomState.js.map +1 -0
  234. package/dist/storage/StatefulStore.d.ts +205 -0
  235. package/dist/storage/StatefulStore.d.ts.map +1 -0
  236. package/dist/storage/StatefulStore.js +301 -0
  237. package/dist/storage/StatefulStore.js.map +1 -0
  238. package/dist/storage/persistentStorage.d.ts +12 -0
  239. package/dist/storage/persistentStorage.d.ts.map +1 -0
  240. package/dist/storage/persistentStorage.js +28 -0
  241. package/dist/storage/persistentStorage.js.map +1 -0
  242. package/dist/storage/useLocalStorage.d.ts +7 -0
  243. package/dist/storage/useLocalStorage.d.ts.map +1 -0
  244. package/dist/storage/useLocalStorage.js +40 -0
  245. package/dist/storage/useLocalStorage.js.map +1 -0
  246. package/dist/string/alignment.d.ts +25 -0
  247. package/dist/string/alignment.d.ts.map +1 -0
  248. package/dist/string/alignment.js +26 -0
  249. package/dist/string/alignment.js.map +1 -0
  250. package/dist/string/ucfirst.d.ts +4 -0
  251. package/dist/string/ucfirst.d.ts.map +1 -0
  252. package/dist/string/ucfirst.js +6 -0
  253. package/dist/string/ucfirst.js.map +1 -0
  254. package/dist/typeGuards/toBoolean.d.ts +26 -0
  255. package/dist/typeGuards/toBoolean.d.ts.map +1 -0
  256. package/dist/typeGuards/toBoolean.js +11 -0
  257. package/dist/typeGuards/toBoolean.js.map +1 -0
  258. package/dist/types/apia/common.d.ts +114 -0
  259. package/dist/types/apia/common.d.ts.map +1 -0
  260. package/dist/types/apia/date.d.ts +4 -0
  261. package/dist/types/apia/date.d.ts.map +1 -0
  262. package/dist/types/apia/forms.d.ts +221 -0
  263. package/dist/types/apia/forms.d.ts.map +1 -0
  264. package/dist/types/misc.d.ts +9 -0
  265. package/dist/types/misc.d.ts.map +1 -0
  266. package/dist/xml/parseXmlAsync.d.ts +4 -0
  267. package/dist/xml/parseXmlAsync.d.ts.map +1 -0
  268. package/dist/xml/parseXmlAsync.js +58 -0
  269. package/dist/xml/parseXmlAsync.js.map +1 -0
  270. package/package.json +24 -35
  271. package/LICENSE.md +0 -21
  272. package/README.md +0 -18
  273. package/cleanDist.json +0 -3
  274. package/entries.json +0 -1
@@ -0,0 +1,8 @@
1
+ type DownloadStringAsDocProps = {
2
+ fileName?: string;
3
+ blobProps?: BlobPropertyBag;
4
+ };
5
+ declare function downloadStringAsDoc(content: string, options?: DownloadStringAsDocProps): Promise<void>;
6
+
7
+ export { type DownloadStringAsDocProps, downloadStringAsDoc };
8
+ //# sourceMappingURL=downloadStringAsDoc.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"downloadStringAsDoc.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ async function downloadStringAsDoc(content, options) {
2
+ (await import('file-saver')).default.saveAs(
3
+ new Blob([content], {
4
+ type: "text/plain; charset=utf-8",
5
+ ...options?.blobProps
6
+ }),
7
+ options?.fileName
8
+ );
9
+ }
10
+
11
+ export { downloadStringAsDoc };
12
+ //# sourceMappingURL=downloadStringAsDoc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"downloadStringAsDoc.js","sources":["../../src/documents/downloadStringAsDoc.ts"],"sourcesContent":["export type DownloadStringAsDocProps = {\n fileName?: string;\n blobProps?: BlobPropertyBag;\n};\n\nexport async function downloadStringAsDoc(\n content: string,\n options?: DownloadStringAsDocProps,\n) {\n (await import('file-saver')).default.saveAs(\n new Blob([content], {\n type: 'text/plain; charset=utf-8',\n ...options?.blobProps,\n }),\n options?.fileName,\n );\n}\n"],"names":[],"mappings":"AAKsB,eAAA,mBAAA,CACpB,SACA,OACA,EAAA;AACA,EAAA,CAAC,MAAM,OAAO,YAAY,CAAA,EAAG,OAAQ,CAAA,MAAA;AAAA,IACnC,IAAI,IAAA,CAAK,CAAC,OAAO,CAAG,EAAA;AAAA,MAClB,IAAM,EAAA,2BAAA;AAAA,MACN,GAAG,OAAS,EAAA,SAAA;AAAA,KACb,CAAA;AAAA,IACD,OAAS,EAAA,QAAA;AAAA,GACX,CAAA;AACF;;;;"}
@@ -0,0 +1,20 @@
1
+ import { AxiosResponse } from 'axios';
2
+
3
+ declare function defaultGetNameFromResponse(blob: AxiosResponse): string;
4
+ /**
5
+ * This function gets an URL and a file name and performs a file download.
6
+ *
7
+ * @param url The url to fetch
8
+ * @param getNameFromResponse The name will be given by the 'content-disposition' prop in the headers
9
+ */
10
+ declare function downloadUrl(url: string, getNameFromResponse?: (blob: AxiosResponse) => string): Promise<void>;
11
+ /**
12
+ * This function gets an URL and a file name and performs a file download.
13
+ *
14
+ * @param url The url to fetch
15
+ * @param fileName The name the file will have as default in the save dialog
16
+ */
17
+ declare function downloadUrl(url: string, fileName: string): Promise<void>;
18
+
19
+ export { defaultGetNameFromResponse, downloadUrl };
20
+ //# sourceMappingURL=downloadUrl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"downloadUrl.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,18 @@
1
+ function defaultGetNameFromResponse(blob) {
2
+ return blob.headers["content-disposition"]?.match?.(
3
+ /filename=(?:\\?")?([\w,\s-() ]+(?:\.[A-Za-z]+)?)(?:\\?")?;?/
4
+ )?.[1] ?? "noFileName";
5
+ }
6
+ async function downloadUrl(url, secondParameter = defaultGetNameFromResponse) {
7
+ const blob = await (await import('axios')).default.get(url, {
8
+ responseType: "blob"
9
+ });
10
+ const actualFileName = typeof secondParameter === "string" ? secondParameter : secondParameter(blob);
11
+ (await import('file-saver')).default.saveAs(
12
+ new Blob([blob.data]),
13
+ actualFileName
14
+ );
15
+ }
16
+
17
+ export { defaultGetNameFromResponse, downloadUrl };
18
+ //# sourceMappingURL=downloadUrl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"downloadUrl.js","sources":["../../src/documents/downloadUrl.ts"],"sourcesContent":["import type { AxiosResponse } from 'axios';\n\nexport function defaultGetNameFromResponse(blob: AxiosResponse) {\n return (\n (blob.headers['content-disposition'] as string)?.match?.(\n /filename=(?:\\\\?\")?([\\w,\\s-() ]+(?:\\.[A-Za-z]+)?)(?:\\\\?\")?;?/,\n )?.[1] ?? 'noFileName'\n );\n}\n\n/**\n * This function gets an URL and a file name and performs a file download.\n *\n * @param url The url to fetch\n * @param getNameFromResponse The name will be given by the 'content-disposition' prop in the headers\n */\nexport async function downloadUrl(\n url: string,\n getNameFromResponse?: (blob: AxiosResponse) => string,\n): Promise<void>;\n/**\n * This function gets an URL and a file name and performs a file download.\n *\n * @param url The url to fetch\n * @param fileName The name the file will have as default in the save dialog\n */\nexport async function downloadUrl(url: string, fileName: string): Promise<void>;\nexport async function downloadUrl(\n url: string,\n secondParameter:\n | string\n | ((blob: AxiosResponse) => string) = defaultGetNameFromResponse,\n): Promise<void> {\n const blob = await (\n await import('axios')\n ).default.get(url, {\n responseType: 'blob',\n });\n\n const actualFileName =\n typeof secondParameter === 'string'\n ? secondParameter\n : secondParameter(blob);\n\n (await import('file-saver')).default.saveAs(\n new Blob([blob.data]),\n actualFileName,\n );\n}\n"],"names":[],"mappings":"AAEO,SAAS,2BAA2B,IAAqB,EAAA;AAC9D,EACG,OAAA,IAAA,CAAK,OAAQ,CAAA,qBAAqB,CAAc,EAAA,KAAA;AAAA,IAC/C,6DAAA;AAAA,GACF,GAAI,CAAC,CAAK,IAAA,YAAA,CAAA;AAEd,CAAA;AAmBsB,eAAA,WAAA,CACpB,GACA,EAAA,eAAA,GAEwC,0BACzB,EAAA;AACf,EAAM,MAAA,IAAA,GAAO,OACX,MAAM,OAAO,OAAO,CACpB,EAAA,OAAA,CAAQ,IAAI,GAAK,EAAA;AAAA,IACjB,YAAc,EAAA,MAAA;AAAA,GACf,CAAA,CAAA;AAED,EAAA,MAAM,iBACJ,OAAO,eAAA,KAAoB,QACvB,GAAA,eAAA,GACA,gBAAgB,IAAI,CAAA,CAAA;AAE1B,EAAA,CAAC,MAAM,OAAO,YAAY,CAAA,EAAG,OAAQ,CAAA,MAAA;AAAA,IACnC,IAAI,IAAA,CAAK,CAAC,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,IACpB,cAAA;AAAA,GACF,CAAA;AACF;;;;"}
@@ -0,0 +1,4 @@
1
+ declare function openAndReadFile(): Promise<string | ArrayBuffer | null>;
2
+
3
+ export { openAndReadFile };
4
+ //# sourceMappingURL=openAndReadFile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openAndReadFile.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,29 @@
1
+ function openAndReadFile() {
2
+ return new Promise((resolve) => {
3
+ const input = document.createElement("input");
4
+ input.type = "file";
5
+ input.style.display = "none";
6
+ document.body.append(input);
7
+ input.click();
8
+ input.addEventListener("change", (ev) => {
9
+ const fileInput = ev.target;
10
+ const file = fileInput?.files?.[0];
11
+ if (file) {
12
+ const reader = new FileReader();
13
+ reader.onload = (event) => {
14
+ fileInput.value = "";
15
+ const content = event.target?.result;
16
+ if (content) {
17
+ resolve(content);
18
+ }
19
+ };
20
+ reader.readAsText(file);
21
+ } else {
22
+ resolve(null);
23
+ }
24
+ });
25
+ });
26
+ }
27
+
28
+ export { openAndReadFile };
29
+ //# sourceMappingURL=openAndReadFile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openAndReadFile.js","sources":["../../src/documents/openAndReadFile.ts"],"sourcesContent":["export function openAndReadFile() {\n return new Promise<string | ArrayBuffer | null>((resolve) => {\n const input = document.createElement('input');\n input.type = 'file';\n input.style.display = 'none';\n document.body.append(input);\n input.click();\n input.addEventListener('change', (ev) => {\n const fileInput = ev.target as HTMLInputElement;\n const file = fileInput?.files?.[0];\n if (file) {\n const reader = new FileReader();\n reader.onload = (event) => {\n fileInput.value = '';\n const content = event.target?.result;\n if (content) {\n resolve(content);\n }\n };\n reader.readAsText(file);\n } else {\n resolve(null);\n }\n });\n });\n}\n"],"names":[],"mappings":"AAAO,SAAS,eAAkB,GAAA;AAChC,EAAO,OAAA,IAAI,OAAqC,CAAA,CAAC,OAAY,KAAA;AAC3D,IAAM,MAAA,KAAA,GAAQ,QAAS,CAAA,aAAA,CAAc,OAAO,CAAA,CAAA;AAC5C,IAAA,KAAA,CAAM,IAAO,GAAA,MAAA,CAAA;AACb,IAAA,KAAA,CAAM,MAAM,OAAU,GAAA,MAAA,CAAA;AACtB,IAAS,QAAA,CAAA,IAAA,CAAK,OAAO,KAAK,CAAA,CAAA;AAC1B,IAAA,KAAA,CAAM,KAAM,EAAA,CAAA;AACZ,IAAM,KAAA,CAAA,gBAAA,CAAiB,QAAU,EAAA,CAAC,EAAO,KAAA;AACvC,MAAA,MAAM,YAAY,EAAG,CAAA,MAAA,CAAA;AACrB,MAAM,MAAA,IAAA,GAAO,SAAW,EAAA,KAAA,GAAQ,CAAC,CAAA,CAAA;AACjC,MAAA,IAAI,IAAM,EAAA;AACR,QAAM,MAAA,MAAA,GAAS,IAAI,UAAW,EAAA,CAAA;AAC9B,QAAO,MAAA,CAAA,MAAA,GAAS,CAAC,KAAU,KAAA;AACzB,UAAA,SAAA,CAAU,KAAQ,GAAA,EAAA,CAAA;AAClB,UAAM,MAAA,OAAA,GAAU,MAAM,MAAQ,EAAA,MAAA,CAAA;AAC9B,UAAA,IAAI,OAAS,EAAA;AACX,YAAA,OAAA,CAAQ,OAAO,CAAA,CAAA;AAAA,WACjB;AAAA,SACF,CAAA;AACA,QAAA,MAAA,CAAO,WAAW,IAAI,CAAA,CAAA;AAAA,OACjB,MAAA;AACL,QAAA,OAAA,CAAQ,IAAI,CAAA,CAAA;AAAA,OACd;AAAA,KACD,CAAA,CAAA;AAAA,GACF,CAAA,CAAA;AACH;;;;"}
@@ -0,0 +1,17 @@
1
+ interface IAutoDisconnectMutationObserverConf {
2
+ /** Por defecto es true */
3
+ runCallbackOnInit?: boolean;
4
+ /** Por defecto es 100 (ms) */
5
+ timeout?: number;
6
+ }
7
+ /**
8
+ * Crea un observer que va a desconectarse automáticamente luego de que pase
9
+ * una determinada cantidad de tiempo sin actividad en el elemento.
10
+ *
11
+ * Se usa especialmente para esperar que un componente termine de renderizar y
12
+ * aplicar cálculos a nivel de layout sobre él.
13
+ */
14
+ declare function autoDisconnectMutationObserver(element: HTMLElement, callback: () => unknown, conf?: IAutoDisconnectMutationObserverConf): () => void;
15
+
16
+ export { type IAutoDisconnectMutationObserverConf, autoDisconnectMutationObserver };
17
+ //# sourceMappingURL=autoDisconnectMutationObserver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autoDisconnectMutationObserver.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,35 @@
1
+ function autoDisconnectMutationObserver(element, callback, conf) {
2
+ let timeoutRegister = -1;
3
+ let isConnected = false;
4
+ function disconnect() {
5
+ if (isConnected) {
6
+ isConnected = false;
7
+ observer.disconnect();
8
+ clearTimeout(timeoutRegister);
9
+ }
10
+ }
11
+ let shoutCallback;
12
+ const observer = new MutationObserver((...props) => {
13
+ if (props[0]?.[0] && (props[0][0].removedNodes || props[0][0].addedNodes)) {
14
+ clearTimeout(shoutCallback);
15
+ shoutCallback = setTimeout(callback, 100);
16
+ clearTimeout(timeoutRegister);
17
+ timeoutRegister = setTimeout(
18
+ disconnect,
19
+ conf?.timeout ?? 100
20
+ );
21
+ }
22
+ });
23
+ isConnected = true;
24
+ observer.observe(element, { subtree: true, childList: true });
25
+ timeoutRegister = setTimeout(
26
+ disconnect,
27
+ conf?.timeout ?? 100
28
+ );
29
+ if (conf?.runCallbackOnInit !== false)
30
+ shoutCallback = setTimeout(callback, 100);
31
+ return disconnect;
32
+ }
33
+
34
+ export { autoDisconnectMutationObserver };
35
+ //# sourceMappingURL=autoDisconnectMutationObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"autoDisconnectMutationObserver.js","sources":["../../src/dom/autoDisconnectMutationObserver.ts"],"sourcesContent":["export interface IAutoDisconnectMutationObserverConf {\n /** Por defecto es true */\n runCallbackOnInit?: boolean;\n /** Por defecto es 100 (ms) */\n timeout?: number;\n}\n\n/**\n * Crea un observer que va a desconectarse automáticamente luego de que pase\n * una determinada cantidad de tiempo sin actividad en el elemento.\n *\n * Se usa especialmente para esperar que un componente termine de renderizar y\n * aplicar cálculos a nivel de layout sobre él.\n */\nexport function autoDisconnectMutationObserver(\n element: HTMLElement,\n callback: () => unknown,\n conf?: IAutoDisconnectMutationObserverConf,\n) {\n let timeoutRegister = -1;\n let isConnected = false;\n function disconnect() {\n if (isConnected) {\n isConnected = false;\n observer.disconnect();\n clearTimeout(timeoutRegister);\n }\n }\n let shoutCallback: number;\n\n const observer = new MutationObserver((...props) => {\n if (props[0]?.[0] && (props[0][0].removedNodes || props[0][0].addedNodes)) {\n clearTimeout(shoutCallback);\n shoutCallback = setTimeout(callback, 100) as unknown as number;\n clearTimeout(timeoutRegister);\n timeoutRegister = setTimeout(\n disconnect,\n conf?.timeout ?? 100,\n ) as unknown as number;\n }\n });\n isConnected = true;\n observer.observe(element, { subtree: true, childList: true });\n timeoutRegister = setTimeout(\n disconnect,\n conf?.timeout ?? 100,\n ) as unknown as number;\n\n if (conf?.runCallbackOnInit !== false)\n shoutCallback = setTimeout(callback, 100) as unknown as number;\n\n return disconnect;\n}\n"],"names":[],"mappings":"AAcgB,SAAA,8BAAA,CACd,OACA,EAAA,QAAA,EACA,IACA,EAAA;AACA,EAAA,IAAI,eAAkB,GAAA,CAAA,CAAA,CAAA;AACtB,EAAA,IAAI,WAAc,GAAA,KAAA,CAAA;AAClB,EAAA,SAAS,UAAa,GAAA;AACpB,IAAA,IAAI,WAAa,EAAA;AACf,MAAc,WAAA,GAAA,KAAA,CAAA;AACd,MAAA,QAAA,CAAS,UAAW,EAAA,CAAA;AACpB,MAAA,YAAA,CAAa,eAAe,CAAA,CAAA;AAAA,KAC9B;AAAA,GACF;AACA,EAAI,IAAA,aAAA,CAAA;AAEJ,EAAA,MAAM,QAAW,GAAA,IAAI,gBAAiB,CAAA,CAAA,GAAI,KAAU,KAAA;AAClD,IAAA,IAAI,MAAM,CAAC,CAAA,GAAI,CAAC,CAAA,KAAM,MAAM,CAAC,CAAA,CAAE,CAAC,CAAA,CAAE,gBAAgB,KAAM,CAAA,CAAC,CAAE,CAAA,CAAC,EAAE,UAAa,CAAA,EAAA;AACzE,MAAA,YAAA,CAAa,aAAa,CAAA,CAAA;AAC1B,MAAgB,aAAA,GAAA,UAAA,CAAW,UAAU,GAAG,CAAA,CAAA;AACxC,MAAA,YAAA,CAAa,eAAe,CAAA,CAAA;AAC5B,MAAkB,eAAA,GAAA,UAAA;AAAA,QAChB,UAAA;AAAA,QACA,MAAM,OAAW,IAAA,GAAA;AAAA,OACnB,CAAA;AAAA,KACF;AAAA,GACD,CAAA,CAAA;AACD,EAAc,WAAA,GAAA,IAAA,CAAA;AACd,EAAA,QAAA,CAAS,QAAQ,OAAS,EAAA,EAAE,SAAS,IAAM,EAAA,SAAA,EAAW,MAAM,CAAA,CAAA;AAC5D,EAAkB,eAAA,GAAA,UAAA;AAAA,IAChB,UAAA;AAAA,IACA,MAAM,OAAW,IAAA,GAAA;AAAA,GACnB,CAAA;AAEA,EAAA,IAAI,MAAM,iBAAsB,KAAA,KAAA;AAC9B,IAAgB,aAAA,GAAA,UAAA,CAAW,UAAU,GAAG,CAAA,CAAA;AAE1C,EAAO,OAAA,UAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * Existen algunos eventos que se disparan en la
3
+ * aplicación con la finalidad de desencadenar
4
+ * un comportamiento específico. Por ello se declaran
5
+ * las siguientes constantes.
6
+ */
7
+ declare const customEvents: {
8
+ /**
9
+ * Indica que un elemento necesita recibir el foco,
10
+ * de esta forma, elementos que no se están mostrando
11
+ * en pantalla (por display:none por ejemplo), pueden
12
+ * indicar a sus ancestros que deben expandirse.
13
+ */
14
+ focus: string;
15
+ /**
16
+ * Indica que debe cambiarse el título del modal
17
+ */
18
+ iframeModalChangeTitle: string;
19
+ /**
20
+ * Indica que un iframe modal debe cerrarse
21
+ */
22
+ iframeModalClose: string;
23
+ /**
24
+ * Indica que un iframe modal debe cerrarse
25
+ */
26
+ iframeModalNotify: string;
27
+ /**
28
+ * Indica que un modal debe cerrarse
29
+ */
30
+ modalClose: string;
31
+ /**
32
+ * Indica que el panel contenedor debe cerrarse porque
33
+ * está vacío
34
+ */
35
+ hidePanel: string;
36
+ showPanel: string;
37
+ };
38
+
39
+ export { customEvents };
40
+ //# sourceMappingURL=customEvents.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"customEvents.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,34 @@
1
+ const customEvents = {
2
+ /**
3
+ * Indica que un elemento necesita recibir el foco,
4
+ * de esta forma, elementos que no se están mostrando
5
+ * en pantalla (por display:none por ejemplo), pueden
6
+ * indicar a sus ancestros que deben expandirse.
7
+ */
8
+ focus: "customFocus",
9
+ /**
10
+ * Indica que debe cambiarse el título del modal
11
+ */
12
+ iframeModalChangeTitle: "iframeModalChangeTitle",
13
+ /**
14
+ * Indica que un iframe modal debe cerrarse
15
+ */
16
+ iframeModalClose: "iframeModalClose",
17
+ /**
18
+ * Indica que un iframe modal debe cerrarse
19
+ */
20
+ iframeModalNotify: "iframeModalNotify",
21
+ /**
22
+ * Indica que un modal debe cerrarse
23
+ */
24
+ modalClose: "modalClose",
25
+ /**
26
+ * Indica que el panel contenedor debe cerrarse porque
27
+ * está vacío
28
+ */
29
+ hidePanel: "hidePanel",
30
+ showPanel: "showPanel"
31
+ };
32
+
33
+ export { customEvents };
34
+ //# sourceMappingURL=customEvents.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"customEvents.js","sources":["../../src/dom/customEvents.ts"],"sourcesContent":["/**\n * Existen algunos eventos que se disparan en la\n * aplicación con la finalidad de desencadenar\n * un comportamiento específico. Por ello se declaran\n * las siguientes constantes.\n */\nexport const customEvents = {\n /**\n * Indica que un elemento necesita recibir el foco,\n * de esta forma, elementos que no se están mostrando\n * en pantalla (por display:none por ejemplo), pueden\n * indicar a sus ancestros que deben expandirse.\n */\n focus: 'customFocus',\n /**\n * Indica que debe cambiarse el título del modal\n */\n iframeModalChangeTitle: 'iframeModalChangeTitle',\n /**\n * Indica que un iframe modal debe cerrarse\n */\n iframeModalClose: 'iframeModalClose',\n /**\n * Indica que un iframe modal debe cerrarse\n */\n iframeModalNotify: 'iframeModalNotify',\n /**\n * Indica que un modal debe cerrarse\n */\n modalClose: 'modalClose',\n /**\n * Indica que el panel contenedor debe cerrarse porque\n * está vacío\n */\n hidePanel: 'hidePanel',\n showPanel: 'showPanel',\n};\n"],"names":[],"mappings":"AAMO,MAAM,YAAe,GAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAO1B,KAAO,EAAA,aAAA;AAAA;AAAA;AAAA;AAAA,EAIP,sBAAwB,EAAA,wBAAA;AAAA;AAAA;AAAA;AAAA,EAIxB,gBAAkB,EAAA,kBAAA;AAAA;AAAA;AAAA;AAAA,EAIlB,iBAAmB,EAAA,mBAAA;AAAA;AAAA;AAAA;AAAA,EAInB,UAAY,EAAA,YAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAKZ,SAAW,EAAA,WAAA;AAAA,EACX,SAAW,EAAA,WAAA;AACb;;;;"}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Deshabilita la posibilidad de hacer foco en
3
+ * todos los descendientes de parent. Es
4
+ * especialmente útli cuando se ocultan elementos
5
+ * del DOM sin quitarlos, cuando por accesibilidad
6
+ * es importante que el foco no alcance a dichos
7
+ * métodos.
8
+ */
9
+ declare function disableChildrenFocus(parent: HTMLElement): void;
10
+ /**
11
+ * Restaura el foco de los hijos de parent a los
12
+ * que previamente se les había quitado el foco
13
+ * con disableChildrenFocus.
14
+ */
15
+ declare function enableChildrenFocus(parent: HTMLElement): void;
16
+
17
+ export { disableChildrenFocus, enableChildrenFocus };
18
+ //# sourceMappingURL=enableChildrenFocus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enableChildrenFocus.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,26 @@
1
+ import { focusSelector } from './getFocusSelector.js';
2
+
3
+ const previousTabIndexLabel = "data-previous-tabindex";
4
+ function disableChildrenFocus(parent) {
5
+ const focusElement = parent.querySelectorAll(focusSelector);
6
+ focusElement.forEach((element) => {
7
+ element.setAttribute(
8
+ previousTabIndexLabel,
9
+ element.getAttribute("tabindex") ?? ""
10
+ );
11
+ element.setAttribute("tabindex", "-1");
12
+ });
13
+ }
14
+ function enableChildrenFocus(parent) {
15
+ const focusElement = parent.querySelectorAll(`[${previousTabIndexLabel}]`);
16
+ focusElement.forEach((element) => {
17
+ element.setAttribute(
18
+ "tabindex",
19
+ element.getAttribute(previousTabIndexLabel) ?? "0"
20
+ );
21
+ element.removeAttribute(previousTabIndexLabel);
22
+ });
23
+ }
24
+
25
+ export { disableChildrenFocus, enableChildrenFocus };
26
+ //# sourceMappingURL=enableChildrenFocus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enableChildrenFocus.js","sources":["../../src/dom/enableChildrenFocus.ts"],"sourcesContent":["import { focusSelector } from './getFocusSelector';\n\nconst previousTabIndexLabel = 'data-previous-tabindex';\n\n/**\n * Deshabilita la posibilidad de hacer foco en\n * todos los descendientes de parent. Es\n * especialmente útli cuando se ocultan elementos\n * del DOM sin quitarlos, cuando por accesibilidad\n * es importante que el foco no alcance a dichos\n * métodos.\n */\nexport function disableChildrenFocus(parent: HTMLElement) {\n const focusElement = parent.querySelectorAll(focusSelector);\n focusElement.forEach((element) => {\n element.setAttribute(\n previousTabIndexLabel,\n element.getAttribute('tabindex') ?? '',\n );\n element.setAttribute('tabindex', '-1');\n });\n}\n\n/**\n * Restaura el foco de los hijos de parent a los\n * que previamente se les había quitado el foco\n * con disableChildrenFocus.\n */\nexport function enableChildrenFocus(parent: HTMLElement) {\n const focusElement = parent.querySelectorAll(`[${previousTabIndexLabel}]`);\n focusElement.forEach((element) => {\n element.setAttribute(\n 'tabindex',\n element.getAttribute(previousTabIndexLabel) ?? '0',\n );\n element.removeAttribute(previousTabIndexLabel);\n });\n}\n"],"names":[],"mappings":";;AAEA,MAAM,qBAAwB,GAAA,wBAAA,CAAA;AAUvB,SAAS,qBAAqB,MAAqB,EAAA;AACxD,EAAM,MAAA,YAAA,GAAe,MAAO,CAAA,gBAAA,CAAiB,aAAa,CAAA,CAAA;AAC1D,EAAa,YAAA,CAAA,OAAA,CAAQ,CAAC,OAAY,KAAA;AAChC,IAAQ,OAAA,CAAA,YAAA;AAAA,MACN,qBAAA;AAAA,MACA,OAAA,CAAQ,YAAa,CAAA,UAAU,CAAK,IAAA,EAAA;AAAA,KACtC,CAAA;AACA,IAAQ,OAAA,CAAA,YAAA,CAAa,YAAY,IAAI,CAAA,CAAA;AAAA,GACtC,CAAA,CAAA;AACH,CAAA;AAOO,SAAS,oBAAoB,MAAqB,EAAA;AACvD,EAAA,MAAM,YAAe,GAAA,MAAA,CAAO,gBAAiB,CAAA,CAAA,CAAA,EAAI,qBAAqB,CAAG,CAAA,CAAA,CAAA,CAAA;AACzE,EAAa,YAAA,CAAA,OAAA,CAAQ,CAAC,OAAY,KAAA;AAChC,IAAQ,OAAA,CAAA,YAAA;AAAA,MACN,UAAA;AAAA,MACA,OAAA,CAAQ,YAAa,CAAA,qBAAqB,CAAK,IAAA,GAAA;AAAA,KACjD,CAAA;AACA,IAAA,OAAA,CAAQ,gBAAgB,qBAAqB,CAAA,CAAA;AAAA,GAC9C,CAAA,CAAA;AACH;;;;"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Esta función calcula el offset que existe entre un elemento y su padre más inmediato que tenga scroll visible
3
+ */
4
+ declare function findOffsetRelativeToScrollParent(element: HTMLElement, which?: 'Left' | 'Top'): number;
5
+
6
+ export { findOffsetRelativeToScrollParent };
7
+ //# sourceMappingURL=findOffsetRelativeToScrollParent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findOffsetRelativeToScrollParent.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,19 @@
1
+ import { findScrollContainer } from './findScrollContainer.js';
2
+
3
+ function findOffsetRelativeToScrollParent(element, which = "Top") {
4
+ const scrollParent = findScrollContainer(element);
5
+ let currentElement = element;
6
+ let offset = 0;
7
+ let offsetParent = currentElement;
8
+ while (currentElement && currentElement !== scrollParent && currentElement !== document.body && offsetParent !== scrollParent) {
9
+ if (offsetParent !== currentElement.offsetParent) {
10
+ offset += currentElement[`offset${which}`];
11
+ offsetParent = currentElement.offsetParent;
12
+ }
13
+ currentElement = currentElement.parentElement;
14
+ }
15
+ return offset;
16
+ }
17
+
18
+ export { findOffsetRelativeToScrollParent };
19
+ //# sourceMappingURL=findOffsetRelativeToScrollParent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findOffsetRelativeToScrollParent.js","sources":["../../src/dom/findOffsetRelativeToScrollParent.ts"],"sourcesContent":["import { findScrollContainer } from \"./findScrollContainer\";\n\n/**\n * Esta función calcula el offset que existe entre un elemento y su padre más inmediato que tenga scroll visible\n */\nexport function findOffsetRelativeToScrollParent(\n element: HTMLElement,\n which: 'Left' | 'Top' = 'Top',\n) {\n const scrollParent = findScrollContainer(element);\n let currentElement = element;\n let offset = 0;\n let offsetParent = currentElement;\n while (\n currentElement &&\n currentElement !== scrollParent &&\n currentElement !== document.body &&\n offsetParent !== scrollParent\n ) {\n if (offsetParent !== currentElement.offsetParent) {\n offset += currentElement[`offset${which}`];\n offsetParent = currentElement.offsetParent as HTMLElement;\n }\n currentElement = currentElement.parentElement as HTMLElement;\n }\n return offset;\n}"],"names":[],"mappings":";;AAKgB,SAAA,gCAAA,CACd,OACA,EAAA,KAAA,GAAwB,KACxB,EAAA;AACA,EAAM,MAAA,YAAA,GAAe,oBAAoB,OAAO,CAAA,CAAA;AAChD,EAAA,IAAI,cAAiB,GAAA,OAAA,CAAA;AACrB,EAAA,IAAI,MAAS,GAAA,CAAA,CAAA;AACb,EAAA,IAAI,YAAe,GAAA,cAAA,CAAA;AACnB,EAAA,OACE,kBACA,cAAmB,KAAA,YAAA,IACnB,mBAAmB,QAAS,CAAA,IAAA,IAC5B,iBAAiB,YACjB,EAAA;AACA,IAAI,IAAA,YAAA,KAAiB,eAAe,YAAc,EAAA;AAChD,MAAU,MAAA,IAAA,cAAA,CAAe,CAAS,MAAA,EAAA,KAAK,CAAE,CAAA,CAAA,CAAA;AACzC,MAAA,YAAA,GAAe,cAAe,CAAA,YAAA,CAAA;AAAA,KAChC;AACA,IAAA,cAAA,GAAiB,cAAe,CAAA,aAAA,CAAA;AAAA,GAClC;AACA,EAAO,OAAA,MAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Encuentra el primer elemento padre del elemento provisto que tenga scroll
3
+ * activo.
4
+ */
5
+ declare function findScrollContainer(el: HTMLElement): HTMLElement | null;
6
+
7
+ export { findScrollContainer };
8
+ //# sourceMappingURL=findScrollContainer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findScrollContainer.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,9 @@
1
+ const REGEXP_SCROLL_PARENT = /^(visible|hidden)/;
2
+ function findScrollContainer(el) {
3
+ return !(el instanceof HTMLElement) || typeof window.getComputedStyle !== "function" ? null : el.scrollHeight >= el.clientHeight && !REGEXP_SCROLL_PARENT.test(
4
+ window.getComputedStyle(el).overflowY || "visible"
5
+ ) ? el : findScrollContainer(el.parentElement) || document.body;
6
+ }
7
+
8
+ export { findScrollContainer };
9
+ //# sourceMappingURL=findScrollContainer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findScrollContainer.js","sources":["../../src/dom/findScrollContainer.ts"],"sourcesContent":["const REGEXP_SCROLL_PARENT = /^(visible|hidden)/;\n/**\n * Encuentra el primer elemento padre del elemento provisto que tenga scroll\n * activo.\n */\nexport function findScrollContainer(el: HTMLElement): HTMLElement | null {\n // eslint-disable-next-line no-nested-ternary\n return !(el instanceof HTMLElement) ||\n typeof window.getComputedStyle !== 'function'\n ? null\n : el.scrollHeight >= el.clientHeight &&\n !REGEXP_SCROLL_PARENT.test(\n window.getComputedStyle(el).overflowY || 'visible',\n )\n ? el\n : findScrollContainer(el.parentElement as HTMLElement) || document.body;\n}\n"],"names":[],"mappings":"AAAA,MAAM,oBAAuB,GAAA,mBAAA,CAAA;AAKtB,SAAS,oBAAoB,EAAqC,EAAA;AAEvE,EAAA,OAAO,EAAE,EAAA,YAAc,WACrB,CAAA,IAAA,OAAO,MAAO,CAAA,gBAAA,KAAqB,UACjC,GAAA,IAAA,GACA,EAAG,CAAA,YAAA,IAAgB,EAAG,CAAA,YAAA,IACtB,CAAC,oBAAqB,CAAA,IAAA;AAAA,IACpB,MAAO,CAAA,gBAAA,CAAiB,EAAE,CAAA,CAAE,SAAa,IAAA,SAAA;AAAA,MAE3C,EACA,GAAA,mBAAA,CAAoB,EAAG,CAAA,aAA4B,KAAK,QAAS,CAAA,IAAA,CAAA;AACvE;;;;"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Este selector pretende abarcar todos modificadores que en caso de estar
3
+ * presentes hacen que un elemento no sea focusable
4
+ */
5
+ declare const cantFocusSelector: string;
6
+ /**
7
+ * Este selector pretende abarcar todos los elementos que sean focusables
8
+ */
9
+ declare const focusSelector: string;
10
+ /**
11
+ * Genera un selector que permitirá seleccionar
12
+ * todos los elementos candidatos a recibir foco,
13
+ * que no cumplan con la condición not pasada
14
+ * como parámetro.
15
+ *
16
+ * @param not Un selector not css, indicando cuáles
17
+ * condiciones deben evitar el foco en un elemento.
18
+ *
19
+ * @returns Una cadena que representa un selector
20
+ * css.
21
+ */
22
+ declare function getFocusSelector(not?: string): string;
23
+
24
+ export { cantFocusSelector, focusSelector, getFocusSelector };
25
+ //# sourceMappingURL=getFocusSelector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFocusSelector.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,30 @@
1
+ const cantFocusSelector = [
2
+ "[disabled]",
3
+ '[tabIndex="-1"]',
4
+ '[aria-hidden="true"]',
5
+ "[readonly]",
6
+ "[data-focus-guard]",
7
+ ".modal__closeButton"
8
+ ].map((current) => `:not(${current})`).join("");
9
+ const focusSelector = [
10
+ "input",
11
+ "textarea",
12
+ "select",
13
+ "a",
14
+ "button:not(.toggleAccordionElement)",
15
+ "[contenteditable]",
16
+ "[tabIndex]",
17
+ '[role="button"]'
18
+ ].map((current) => `${current}${cantFocusSelector}`).join(",");
19
+ function getFocusSelector(not) {
20
+ return `input${not ?? ""},
21
+ textarea${not ?? ""},
22
+ select${not ?? ""},
23
+ a${not ?? ""},
24
+ button:not(.toggleAccordionElement)${not ?? ""},
25
+ [contenteditable]${not ?? ""},
26
+ [tabIndex]${not ?? ""}`;
27
+ }
28
+
29
+ export { cantFocusSelector, focusSelector, getFocusSelector };
30
+ //# sourceMappingURL=getFocusSelector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFocusSelector.js","sources":["../../src/dom/getFocusSelector.ts"],"sourcesContent":["/**\n * Este selector pretende abarcar todos modificadores que en caso de estar\n * presentes hacen que un elemento no sea focusable\n */\nexport const cantFocusSelector = [\n '[disabled]',\n '[tabIndex=\"-1\"]',\n '[aria-hidden=\"true\"]',\n '[readonly]',\n '[data-focus-guard]',\n '.modal__closeButton',\n]\n .map((current) => `:not(${current})`)\n .join('');\n\n/**\n * Este selector pretende abarcar todos los elementos que sean focusables\n */\nexport const focusSelector = [\n 'input',\n 'textarea',\n 'select',\n 'a',\n 'button:not(.toggleAccordionElement)',\n '[contenteditable]',\n '[tabIndex]',\n '[role=\"button\"]',\n]\n .map((current) => `${current}${cantFocusSelector}`)\n .join(',');\n\n/**\n * Genera un selector que permitirá seleccionar\n * todos los elementos candidatos a recibir foco,\n * que no cumplan con la condición not pasada\n * como parámetro.\n *\n * @param not Un selector not css, indicando cuáles\n * condiciones deben evitar el foco en un elemento.\n *\n * @returns Una cadena que representa un selector\n * css.\n */\nexport function getFocusSelector(not?: string) {\n return `input${not ?? ''}, \n textarea${not ?? ''}, \n select${not ?? ''}, \n a${not ?? ''}, \n button:not(.toggleAccordionElement)${not ?? ''}, \n [contenteditable]${not ?? ''}, \n [tabIndex]${not ?? ''}`;\n}\n"],"names":[],"mappings":"AAIO,MAAM,iBAAoB,GAAA;AAAA,EAC/B,YAAA;AAAA,EACA,iBAAA;AAAA,EACA,sBAAA;AAAA,EACA,YAAA;AAAA,EACA,oBAAA;AAAA,EACA,qBAAA;AACF,CACG,CAAA,GAAA,CAAI,CAAC,OAAY,KAAA,CAAA,KAAA,EAAQ,OAAO,CAAG,CAAA,CAAA,CAAA,CACnC,KAAK,EAAE,EAAA;AAKH,MAAM,aAAgB,GAAA;AAAA,EAC3B,OAAA;AAAA,EACA,UAAA;AAAA,EACA,QAAA;AAAA,EACA,GAAA;AAAA,EACA,qCAAA;AAAA,EACA,mBAAA;AAAA,EACA,YAAA;AAAA,EACA,iBAAA;AACF,CACG,CAAA,GAAA,CAAI,CAAC,OAAA,KAAY,CAAG,EAAA,OAAO,GAAG,iBAAiB,CAAA,CAAE,CACjD,CAAA,IAAA,CAAK,GAAG,EAAA;AAcJ,SAAS,iBAAiB,GAAc,EAAA;AAC7C,EAAO,OAAA,CAAA,KAAA,EAAQ,OAAO,EAAE,CAAA;AAAA,YAAA,EACZ,OAAO,EAAE,CAAA;AAAA,UAAA,EACX,OAAO,EAAE,CAAA;AAAA,KAAA,EACd,OAAO,EAAE,CAAA;AAAA,uCAAA,EACyB,OAAO,EAAE,CAAA;AAAA,qBAAA,EAC3B,OAAO,EAAE,CAAA;AAAA,cAAA,EAChB,OAAO,EAAE,CAAA,CAAA,CAAA;AACzB;;;;"}
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Searches for a specific parent of a element,
3
+ * using a callback function as the source of
4
+ * truth in order to determine which is the correct
5
+ * parent.
6
+ *
7
+ * @param element The element where the process
8
+ * starts.
9
+ *
10
+ * @param checkParent A callback that will be
11
+ * called for each of the ancestors of the element
12
+ * until the desired parent is found.
13
+ * This function should return **true when found**
14
+ * the desired parend was found, **null to cancel**
15
+ * the search or **false to continue searching**.
16
+ *
17
+ * @returns The specific parent or null in case
18
+ * the root parent element is raised.
19
+ */
20
+ declare function getSpecificParent(element: HTMLElement | null, checkParent: (parent: HTMLElement) => boolean | null): HTMLElement | null;
21
+
22
+ export { getSpecificParent };
23
+ //# sourceMappingURL=getSpecificParent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSpecificParent.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,19 @@
1
+ function getSpecificParent(element, checkParent) {
2
+ let currentElement = element;
3
+ while (element !== document.documentElement && currentElement) {
4
+ const hasFoundTheParent = checkParent(currentElement);
5
+ if (hasFoundTheParent === null)
6
+ return null;
7
+ if (hasFoundTheParent)
8
+ return currentElement;
9
+ const parent = currentElement.parentElement;
10
+ if (parent)
11
+ currentElement = parent;
12
+ else
13
+ return null;
14
+ }
15
+ return null;
16
+ }
17
+
18
+ export { getSpecificParent };
19
+ //# sourceMappingURL=getSpecificParent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSpecificParent.js","sources":["../../src/dom/getSpecificParent.ts"],"sourcesContent":["/**\n * Searches for a specific parent of a element,\n * using a callback function as the source of\n * truth in order to determine which is the correct\n * parent.\n *\n * @param element The element where the process\n * starts.\n *\n * @param checkParent A callback that will be\n * called for each of the ancestors of the element\n * until the desired parent is found.\n * This function should return **true when found**\n * the desired parend was found, **null to cancel**\n * the search or **false to continue searching**.\n *\n * @returns The specific parent or null in case\n * the root parent element is raised.\n */\nexport function getSpecificParent(\n element: HTMLElement | null,\n checkParent: (parent: HTMLElement) => boolean | null,\n): HTMLElement | null {\n let currentElement = element;\n\n while (element !== document.documentElement && currentElement) {\n const hasFoundTheParent = checkParent(currentElement);\n if (hasFoundTheParent === null) return null;\n if (hasFoundTheParent) return currentElement;\n\n const parent = currentElement.parentElement;\n if (parent) currentElement = parent;\n else return null;\n }\n\n return null;\n}\n"],"names":[],"mappings":"AAmBgB,SAAA,iBAAA,CACd,SACA,WACoB,EAAA;AACpB,EAAA,IAAI,cAAiB,GAAA,OAAA,CAAA;AAErB,EAAO,OAAA,OAAA,KAAY,QAAS,CAAA,eAAA,IAAmB,cAAgB,EAAA;AAC7D,IAAM,MAAA,iBAAA,GAAoB,YAAY,cAAc,CAAA,CAAA;AACpD,IAAA,IAAI,iBAAsB,KAAA,IAAA;AAAM,MAAO,OAAA,IAAA,CAAA;AACvC,IAAI,IAAA,iBAAA;AAAmB,MAAO,OAAA,cAAA,CAAA;AAE9B,IAAA,MAAM,SAAS,cAAe,CAAA,aAAA,CAAA;AAC9B,IAAI,IAAA,MAAA;AAAQ,MAAiB,cAAA,GAAA,MAAA,CAAA;AAAA;AACxB,MAAO,OAAA,IAAA,CAAA;AAAA,GACd;AAEA,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Permite iterar desde un elemento hacia arriba en el
3
+ * DOM, utilizando una función de comparación para
4
+ * determinar si el elemento actual es el que estamos
5
+ * buscando.
6
+ *
7
+ * Si la función checkParent devuelve true, isChild
8
+ * devuelve true.
9
+ */
10
+ declare function isChild(element: HTMLElement | null, checkParent: (parent: HTMLElement) => boolean | null): boolean;
11
+
12
+ export { isChild };
13
+ //# sourceMappingURL=isChild.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isChild.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,8 @@
1
+ import { getSpecificParent } from './getSpecificParent.js';
2
+
3
+ function isChild(element, checkParent) {
4
+ return !!getSpecificParent(element, checkParent);
5
+ }
6
+
7
+ export { isChild };
8
+ //# sourceMappingURL=isChild.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isChild.js","sources":["../../src/dom/isChild.ts"],"sourcesContent":["import { getSpecificParent } from './getSpecificParent';\n\n/**\n * Permite iterar desde un elemento hacia arriba en el\n * DOM, utilizando una función de comparación para\n * determinar si el elemento actual es el que estamos\n * buscando.\n *\n * Si la función checkParent devuelve true, isChild\n * devuelve true.\n */\nexport function isChild(\n element: HTMLElement | null,\n checkParent: (parent: HTMLElement) => boolean | null,\n) {\n return !!getSpecificParent(element, checkParent);\n}\n"],"names":[],"mappings":";;AAWgB,SAAA,OAAA,CACd,SACA,WACA,EAAA;AACA,EAAA,OAAO,CAAC,CAAC,iBAAkB,CAAA,OAAA,EAAS,WAAW,CAAA,CAAA;AACjD;;;;"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Busca el padre con scroll visible y establece su scrollTop de acuerdo al offset del elemento pasado como argumento, de modo que éste aparezca visible dentro del padre mencionado.
3
+ *
4
+ * @param fixedOffsetTop Establece un mínimo de distancia que debe mantener con el borde superior del contenedor con scroll. Se usa para compensar en las situaciones donde existen cabezales fijos.
5
+ */
6
+ declare function scrollParentIntoElement(element: HTMLElement, fixedOffsetTop?: number, tries?: number, timeout?: number, scrollId?: string | undefined): void;
7
+
8
+ export { scrollParentIntoElement };
9
+ //# sourceMappingURL=scrollParentIntoElement.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scrollParentIntoElement.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,24 @@
1
+ import { findOffsetRelativeToScrollParent } from './findOffsetRelativeToScrollParent.js';
2
+ import { findScrollContainer } from './findScrollContainer.js';
3
+
4
+ const scrollIntervals = {};
5
+ function scrollParentIntoElement(element, fixedOffsetTop = 0, tries = 2, timeout = 100, scrollId = void 0) {
6
+ if (scrollId) {
7
+ clearTimeout(scrollIntervals[scrollId]);
8
+ }
9
+ const scrollParent = findScrollContainer(element);
10
+ const offsetTop = findOffsetRelativeToScrollParent(element);
11
+ if (scrollParent && (scrollParent.scrollTop + fixedOffsetTop > offsetTop || (scrollParent?.clientHeight ?? Infinity) - fixedOffsetTop < element.getBoundingClientRect().height)) {
12
+ scrollParent.scrollTop = offsetTop - fixedOffsetTop;
13
+ } else if (scrollParent && scrollParent.scrollTop + scrollParent.clientHeight < offsetTop + element.getBoundingClientRect().height) {
14
+ scrollParent.scrollTop = offsetTop;
15
+ }
16
+ if (tries > 0)
17
+ scrollIntervals[scrollId ?? "noId"] = setTimeout(
18
+ () => scrollParentIntoElement(element, fixedOffsetTop, tries - 1, timeout),
19
+ timeout
20
+ );
21
+ }
22
+
23
+ export { scrollParentIntoElement };
24
+ //# sourceMappingURL=scrollParentIntoElement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scrollParentIntoElement.js","sources":["../../src/dom/scrollParentIntoElement.ts"],"sourcesContent":["import { findOffsetRelativeToScrollParent } from \"./findOffsetRelativeToScrollParent\";\nimport { findScrollContainer } from \"./findScrollContainer\";\n\nconst scrollIntervals: Record<string, number> = {};\n/**\n * Busca el padre con scroll visible y establece su scrollTop de acuerdo al offset del elemento pasado como argumento, de modo que éste aparezca visible dentro del padre mencionado.\n *\n * @param fixedOffsetTop Establece un mínimo de distancia que debe mantener con el borde superior del contenedor con scroll. Se usa para compensar en las situaciones donde existen cabezales fijos.\n */\nexport function scrollParentIntoElement(\n element: HTMLElement,\n fixedOffsetTop = 0,\n tries = 2,\n timeout = 100,\n scrollId: string | undefined = undefined,\n) {\n if (scrollId) {\n clearTimeout(scrollIntervals[scrollId]);\n }\n\n const scrollParent = findScrollContainer(element);\n const offsetTop = findOffsetRelativeToScrollParent(element);\n\n if (\n scrollParent &&\n (scrollParent.scrollTop + fixedOffsetTop > offsetTop ||\n (scrollParent?.clientHeight ?? Infinity) - fixedOffsetTop <\n element.getBoundingClientRect().height)\n ) {\n scrollParent.scrollTop = offsetTop - fixedOffsetTop;\n } else if (\n scrollParent &&\n scrollParent.scrollTop + scrollParent.clientHeight <\n offsetTop + element.getBoundingClientRect().height\n ) {\n scrollParent.scrollTop = offsetTop;\n }\n\n if (tries > 0)\n scrollIntervals[scrollId ?? 'noId'] = setTimeout(\n () =>\n scrollParentIntoElement(element, fixedOffsetTop, tries - 1, timeout),\n timeout,\n ) as unknown as number;\n}"],"names":[],"mappings":";;;AAGA,MAAM,kBAA0C,EAAC,CAAA;AAMjC,SAAA,uBAAA,CACd,SACA,cAAiB,GAAA,CAAA,EACjB,QAAQ,CACR,EAAA,OAAA,GAAU,GACV,EAAA,QAAA,GAA+B,KAC/B,CAAA,EAAA;AACA,EAAA,IAAI,QAAU,EAAA;AACZ,IAAa,YAAA,CAAA,eAAA,CAAgB,QAAQ,CAAC,CAAA,CAAA;AAAA,GACxC;AAEA,EAAM,MAAA,YAAA,GAAe,oBAAoB,OAAO,CAAA,CAAA;AAChD,EAAM,MAAA,SAAA,GAAY,iCAAiC,OAAO,CAAA,CAAA;AAE1D,EAAA,IACE,YACC,KAAA,YAAA,CAAa,SAAY,GAAA,cAAA,GAAiB,SACxC,IAAA,CAAA,YAAA,EAAc,YAAgB,IAAA,QAAA,IAAY,cACzC,GAAA,OAAA,CAAQ,qBAAsB,EAAA,CAAE,MACpC,CAAA,EAAA;AACA,IAAA,YAAA,CAAa,YAAY,SAAY,GAAA,cAAA,CAAA;AAAA,GACvC,MAAA,IACE,YACA,IAAA,YAAA,CAAa,SAAY,GAAA,YAAA,CAAa,eACpC,SAAY,GAAA,OAAA,CAAQ,qBAAsB,EAAA,CAAE,MAC9C,EAAA;AACA,IAAA,YAAA,CAAa,SAAY,GAAA,SAAA,CAAA;AAAA,GAC3B;AAEA,EAAA,IAAI,KAAQ,GAAA,CAAA;AACV,IAAgB,eAAA,CAAA,QAAA,IAAY,MAAM,CAAI,GAAA,UAAA;AAAA,MACpC,MACE,uBAAwB,CAAA,OAAA,EAAS,cAAgB,EAAA,KAAA,GAAQ,GAAG,OAAO,CAAA;AAAA,MACrE,OAAA;AAAA,KACF,CAAA;AACJ;;;;"}