read-excel-file 6.0.3 → 7.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 (222) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/README.md +26 -15
  3. package/browser/index.cjs +7 -0
  4. package/{index.d.ts → browser/index.d.ts} +4 -3
  5. package/browser/index.js +6 -0
  6. package/browser/package.json +17 -0
  7. package/bundle/read-excel-file.min.js +1 -1
  8. package/bundle/read-excel-file.min.js.map +1 -1
  9. package/commonjs/export/convertInputToNodeStream.js +45 -0
  10. package/commonjs/export/convertInputToNodeStream.js.map +1 -0
  11. package/commonjs/export/convertValuesFromUint8ArraysToStrings.js +20 -0
  12. package/commonjs/export/convertValuesFromUint8ArraysToStrings.js.map +1 -0
  13. package/commonjs/export/filterZipArchiveEntry.js +18 -0
  14. package/commonjs/export/filterZipArchiveEntry.js.map +1 -0
  15. package/commonjs/{read → export}/readSheetNamesBrowser.js +4 -4
  16. package/commonjs/export/readSheetNamesBrowser.js.map +1 -0
  17. package/commonjs/export/readSheetNamesNode.js.map +1 -0
  18. package/commonjs/export/readSheetNamesUniversal.js +23 -0
  19. package/commonjs/export/readSheetNamesUniversal.js.map +1 -0
  20. package/commonjs/{read → export}/readSheetNamesWebWorker.js +2 -2
  21. package/commonjs/export/readSheetNamesWebWorker.js.map +1 -0
  22. package/commonjs/{read → export}/readXlsxFileBrowser.js +6 -6
  23. package/commonjs/export/readXlsxFileBrowser.js.map +1 -0
  24. package/commonjs/{read → export}/readXlsxFileNode.js +5 -5
  25. package/commonjs/export/readXlsxFileNode.js.map +1 -0
  26. package/commonjs/export/readXlsxFileUniversal.js +24 -0
  27. package/commonjs/export/readXlsxFileUniversal.js.map +1 -0
  28. package/commonjs/{read → export}/readXlsxFileWebWorker.js +5 -5
  29. package/commonjs/export/readXlsxFileWebWorker.js.map +1 -0
  30. package/commonjs/export/unpackXlsxFileBrowser.js +38 -0
  31. package/commonjs/export/unpackXlsxFileBrowser.js.map +1 -0
  32. package/commonjs/export/unpackXlsxFileNode.js +23 -0
  33. package/commonjs/export/unpackXlsxFileNode.js.map +1 -0
  34. package/commonjs/export/unpackXlsxFileUniversal.js +23 -0
  35. package/commonjs/export/unpackXlsxFileUniversal.js.map +1 -0
  36. package/commonjs/types/Date.js +1 -1
  37. package/commonjs/types/Date.js.map +1 -1
  38. package/commonjs/types/Email.test.js.map +1 -1
  39. package/commonjs/types/Integer.test.js.map +1 -1
  40. package/commonjs/types/URL.test.js.map +1 -1
  41. package/commonjs/{read → xlsx}/coordinates.js.map +1 -1
  42. package/commonjs/{read → xlsx}/dropEmptyColumns.js.map +1 -1
  43. package/commonjs/xlsx/dropEmptyColumns.test.js.map +1 -0
  44. package/commonjs/{read → xlsx}/dropEmptyRows.js.map +1 -1
  45. package/commonjs/xlsx/dropEmptyRows.test.js.map +1 -0
  46. package/commonjs/{read → xlsx}/getData.js.map +1 -1
  47. package/commonjs/{read → xlsx}/isDateTimestamp.js.map +1 -1
  48. package/commonjs/{read → xlsx}/parseCell.js.map +1 -1
  49. package/commonjs/{read → xlsx}/parseCellValue.js.map +1 -1
  50. package/commonjs/{read → xlsx}/parseCells.js.map +1 -1
  51. package/commonjs/{read → xlsx}/parseDate.js.map +1 -1
  52. package/commonjs/xlsx/parseDate.test.js.map +1 -0
  53. package/commonjs/{read → xlsx}/parseDimensions.js.map +1 -1
  54. package/commonjs/{read → xlsx}/parseFilePaths.js.map +1 -1
  55. package/commonjs/{read → xlsx}/parseProperties.js.map +1 -1
  56. package/commonjs/{read → xlsx}/parseSharedStrings.js.map +1 -1
  57. package/commonjs/{read → xlsx}/parseSheet.js.map +1 -1
  58. package/commonjs/{read → xlsx}/parseStyles.js.map +1 -1
  59. package/commonjs/{read/readXlsx.js → xlsx/parseXlsxFileContents.js} +10 -9
  60. package/commonjs/xlsx/parseXlsxFileContents.js.map +1 -0
  61. package/commonjs/{read/readXlsxFileContents.js → xlsx/parseXlsxFileContentsWithOptionalSchema.js} +13 -6
  62. package/commonjs/xlsx/parseXlsxFileContentsWithOptionalSchema.js.map +1 -0
  63. package/commonjs/{read → xlsx}/schema/mapToObjects.js +0 -4
  64. package/commonjs/xlsx/schema/mapToObjects.js.map +1 -0
  65. package/commonjs/xlsx/schema/mapToObjects.test.js.map +1 -0
  66. package/commonjs/zip/unzipFromArrayBuffer.js +74 -0
  67. package/commonjs/zip/unzipFromArrayBuffer.js.map +1 -0
  68. package/commonjs/zip/unzipFromArrayBufferSync.js +33 -0
  69. package/commonjs/zip/unzipFromArrayBufferSync.js.map +1 -0
  70. package/commonjs/zip/unzipFromStream.js +123 -0
  71. package/commonjs/zip/unzipFromStream.js.map +1 -0
  72. package/modules/export/convertInputToNodeStream.js +36 -0
  73. package/modules/export/convertInputToNodeStream.js.map +1 -0
  74. package/modules/export/convertValuesFromUint8ArraysToStrings.js +15 -0
  75. package/modules/export/convertValuesFromUint8ArraysToStrings.js.map +1 -0
  76. package/modules/export/filterZipArchiveEntry.js +12 -0
  77. package/modules/export/filterZipArchiveEntry.js.map +1 -0
  78. package/modules/{read → export}/readSheetNamesBrowser.js +4 -4
  79. package/modules/export/readSheetNamesBrowser.js.map +1 -0
  80. package/modules/export/readSheetNamesNode.js.map +1 -0
  81. package/modules/export/readSheetNamesUniversal.js +17 -0
  82. package/modules/export/readSheetNamesUniversal.js.map +1 -0
  83. package/modules/{read → export}/readSheetNamesWebWorker.js +2 -2
  84. package/modules/export/readSheetNamesWebWorker.js.map +1 -0
  85. package/modules/{read → export}/readXlsxFileBrowser.js +6 -6
  86. package/modules/export/readXlsxFileBrowser.js.map +1 -0
  87. package/modules/{read → export}/readXlsxFileNode.js +5 -5
  88. package/modules/export/readXlsxFileNode.js.map +1 -0
  89. package/modules/export/readXlsxFileUniversal.js +18 -0
  90. package/modules/export/readXlsxFileUniversal.js.map +1 -0
  91. package/modules/{read → export}/readXlsxFileWebWorker.js +5 -5
  92. package/modules/export/readXlsxFileWebWorker.js.map +1 -0
  93. package/modules/export/unpackXlsxFileBrowser.js +30 -0
  94. package/modules/export/unpackXlsxFileBrowser.js.map +1 -0
  95. package/modules/export/unpackXlsxFileNode.js +17 -0
  96. package/modules/export/unpackXlsxFileNode.js.map +1 -0
  97. package/modules/export/unpackXlsxFileUniversal.js +17 -0
  98. package/modules/export/unpackXlsxFileUniversal.js.map +1 -0
  99. package/modules/types/Date.js +1 -1
  100. package/modules/types/Date.js.map +1 -1
  101. package/modules/types/Email.test.js.map +1 -1
  102. package/modules/types/Integer.test.js.map +1 -1
  103. package/modules/types/URL.test.js.map +1 -1
  104. package/modules/{read → xlsx}/coordinates.js.map +1 -1
  105. package/modules/{read → xlsx}/dropEmptyColumns.js.map +1 -1
  106. package/modules/xlsx/dropEmptyColumns.test.js.map +1 -0
  107. package/modules/{read → xlsx}/dropEmptyRows.js.map +1 -1
  108. package/modules/xlsx/dropEmptyRows.test.js.map +1 -0
  109. package/modules/{read → xlsx}/getData.js.map +1 -1
  110. package/modules/{read → xlsx}/isDateTimestamp.js.map +1 -1
  111. package/modules/{read → xlsx}/parseCell.js.map +1 -1
  112. package/modules/{read → xlsx}/parseCellValue.js.map +1 -1
  113. package/modules/{read → xlsx}/parseCells.js.map +1 -1
  114. package/modules/{read → xlsx}/parseDate.js.map +1 -1
  115. package/modules/xlsx/parseDate.test.js.map +1 -0
  116. package/modules/{read → xlsx}/parseDimensions.js.map +1 -1
  117. package/modules/{read → xlsx}/parseFilePaths.js.map +1 -1
  118. package/modules/{read → xlsx}/parseProperties.js.map +1 -1
  119. package/modules/{read → xlsx}/parseSharedStrings.js.map +1 -1
  120. package/modules/{read → xlsx}/parseSheet.js.map +1 -1
  121. package/modules/{read → xlsx}/parseStyles.js.map +1 -1
  122. package/modules/{read/readXlsx.js → xlsx/parseXlsxFileContents.js} +9 -8
  123. package/modules/xlsx/parseXlsxFileContents.js.map +1 -0
  124. package/modules/{read/readXlsxFileContents.js → xlsx/parseXlsxFileContentsWithOptionalSchema.js} +13 -5
  125. package/modules/xlsx/parseXlsxFileContentsWithOptionalSchema.js.map +1 -0
  126. package/modules/{read → xlsx}/schema/mapToObjects.js +0 -4
  127. package/modules/xlsx/schema/mapToObjects.js.map +1 -0
  128. package/modules/xlsx/schema/mapToObjects.test.js.map +1 -0
  129. package/modules/zip/unzipFromArrayBuffer.js +67 -0
  130. package/modules/zip/unzipFromArrayBuffer.js.map +1 -0
  131. package/modules/zip/unzipFromArrayBufferSync.js +27 -0
  132. package/modules/zip/unzipFromArrayBufferSync.js.map +1 -0
  133. package/modules/zip/unzipFromStream.js +119 -0
  134. package/modules/zip/unzipFromStream.js.map +1 -0
  135. package/node/index.cjs +4 -4
  136. package/node/index.d.ts +4 -2
  137. package/node/index.js +3 -3
  138. package/package.json +16 -10
  139. package/rollup.config.mjs +1 -1
  140. package/types.d.ts +32 -16
  141. package/universal/index.cjs +7 -0
  142. package/universal/index.d.ts +29 -0
  143. package/universal/index.js +6 -0
  144. package/universal/package.json +17 -0
  145. package/web-worker/index.cjs +4 -4
  146. package/web-worker/index.d.ts +2 -1
  147. package/web-worker/index.js +3 -3
  148. package/commonjs/read/dropEmptyColumns.test.js.map +0 -1
  149. package/commonjs/read/dropEmptyRows.test.js.map +0 -1
  150. package/commonjs/read/parseDate.test.js.map +0 -1
  151. package/commonjs/read/readSheetNamesBrowser.js.map +0 -1
  152. package/commonjs/read/readSheetNamesNode.js.map +0 -1
  153. package/commonjs/read/readSheetNamesNode.test.js.map +0 -1
  154. package/commonjs/read/readSheetNamesWebWorker.js.map +0 -1
  155. package/commonjs/read/readXlsx.js.map +0 -1
  156. package/commonjs/read/readXlsxFileBrowser.js.map +0 -1
  157. package/commonjs/read/readXlsxFileContents.js.map +0 -1
  158. package/commonjs/read/readXlsxFileNode.js.map +0 -1
  159. package/commonjs/read/readXlsxFileNode.test.js.map +0 -1
  160. package/commonjs/read/readXlsxFileWebWorker.js.map +0 -1
  161. package/commonjs/read/schema/mapToObjects.js.map +0 -1
  162. package/commonjs/read/schema/mapToObjects.test.js.map +0 -1
  163. package/commonjs/read/unpackXlsxFileBrowser.js +0 -50
  164. package/commonjs/read/unpackXlsxFileBrowser.js.map +0 -1
  165. package/commonjs/read/unpackXlsxFileNode.js +0 -86
  166. package/commonjs/read/unpackXlsxFileNode.js.map +0 -1
  167. package/index.cjs +0 -7
  168. package/index.cjs.js +0 -12
  169. package/index.js +0 -6
  170. package/modules/read/dropEmptyColumns.test.js.map +0 -1
  171. package/modules/read/dropEmptyRows.test.js.map +0 -1
  172. package/modules/read/parseDate.test.js.map +0 -1
  173. package/modules/read/readSheetNamesBrowser.js.map +0 -1
  174. package/modules/read/readSheetNamesNode.js.map +0 -1
  175. package/modules/read/readSheetNamesNode.test.js.map +0 -1
  176. package/modules/read/readSheetNamesWebWorker.js.map +0 -1
  177. package/modules/read/readXlsx.js.map +0 -1
  178. package/modules/read/readXlsxFileBrowser.js.map +0 -1
  179. package/modules/read/readXlsxFileContents.js.map +0 -1
  180. package/modules/read/readXlsxFileNode.js.map +0 -1
  181. package/modules/read/readXlsxFileNode.test.js.map +0 -1
  182. package/modules/read/readXlsxFileWebWorker.js.map +0 -1
  183. package/modules/read/schema/mapToObjects.js.map +0 -1
  184. package/modules/read/schema/mapToObjects.test.js.map +0 -1
  185. package/modules/read/unpackXlsxFileBrowser.js +0 -45
  186. package/modules/read/unpackXlsxFileBrowser.js.map +0 -1
  187. package/modules/read/unpackXlsxFileNode.js +0 -78
  188. package/modules/read/unpackXlsxFileNode.js.map +0 -1
  189. package/node/index.cjs.js +0 -12
  190. package/web-worker/index.cjs.js +0 -12
  191. /package/commonjs/{read → export}/readSheetNamesNode.js +0 -0
  192. /package/commonjs/{read → xlsx}/coordinates.js +0 -0
  193. /package/commonjs/{read → xlsx}/dropEmptyColumns.js +0 -0
  194. /package/commonjs/{read → xlsx}/dropEmptyRows.js +0 -0
  195. /package/commonjs/{read → xlsx}/getData.js +0 -0
  196. /package/commonjs/{read → xlsx}/isDateTimestamp.js +0 -0
  197. /package/commonjs/{read → xlsx}/parseCell.js +0 -0
  198. /package/commonjs/{read → xlsx}/parseCellValue.js +0 -0
  199. /package/commonjs/{read → xlsx}/parseCells.js +0 -0
  200. /package/commonjs/{read → xlsx}/parseDate.js +0 -0
  201. /package/commonjs/{read → xlsx}/parseDimensions.js +0 -0
  202. /package/commonjs/{read → xlsx}/parseFilePaths.js +0 -0
  203. /package/commonjs/{read → xlsx}/parseProperties.js +0 -0
  204. /package/commonjs/{read → xlsx}/parseSharedStrings.js +0 -0
  205. /package/commonjs/{read → xlsx}/parseSheet.js +0 -0
  206. /package/commonjs/{read → xlsx}/parseStyles.js +0 -0
  207. /package/modules/{read → export}/readSheetNamesNode.js +0 -0
  208. /package/modules/{read → xlsx}/coordinates.js +0 -0
  209. /package/modules/{read → xlsx}/dropEmptyColumns.js +0 -0
  210. /package/modules/{read → xlsx}/dropEmptyRows.js +0 -0
  211. /package/modules/{read → xlsx}/getData.js +0 -0
  212. /package/modules/{read → xlsx}/isDateTimestamp.js +0 -0
  213. /package/modules/{read → xlsx}/parseCell.js +0 -0
  214. /package/modules/{read → xlsx}/parseCellValue.js +0 -0
  215. /package/modules/{read → xlsx}/parseCells.js +0 -0
  216. /package/modules/{read → xlsx}/parseDate.js +0 -0
  217. /package/modules/{read → xlsx}/parseDimensions.js +0 -0
  218. /package/modules/{read → xlsx}/parseFilePaths.js +0 -0
  219. /package/modules/{read → xlsx}/parseProperties.js +0 -0
  220. /package/modules/{read → xlsx}/parseSharedStrings.js +0 -0
  221. /package/modules/{read → xlsx}/parseSheet.js +0 -0
  222. /package/modules/{read → xlsx}/parseStyles.js +0 -0
package/CHANGELOG.md CHANGED
@@ -1,3 +1,23 @@
1
+ 7.0.1 / 04.03.2026
2
+ ==================
3
+
4
+ * [Fixed](https://github.com/catamphetamine/read-excel-file/issues/120) `CellValue` TypeScript type (it didn't include `null` value).
5
+
6
+ * (TypeScript minor breaking change) Renamed exported `Error` TypeScript interface to `SchemaParseCellValueError`, and removed `CellValue` generic from it.
7
+
8
+ 7.0.0 / 23.02.2026
9
+ ==================
10
+
11
+ * Refactored the code.
12
+ * (breaking change) The minimum required Node.js version is now >= 18.
13
+ * Nothing really changed in that regard, it's just that the minimum required Node.js version wasn't specified previously, and I just randomly assumed that now it's gonna be >= 18.
14
+ * (breaking change) The default export has been removed in order to not confuse people.
15
+ * (breaking change) `/browser` export uses [Web Workers](https://developer.mozilla.org/docs/Web/API/Web_Workers_API/Using_web_workers) now to avoid blocking the main thread. I dunno if Internet Explorer is supported now.
16
+ * Added new exports: `/browser` and `/universal`.
17
+ * `/universal` works both in a web browser and Node.js. Only accepts a [`Blob`](https://developer.mozilla.org/docs/Web/API/Blob) as an input.
18
+ * `/browser` works in a web browser. It replaced what used to be the default export.
19
+ * `/node` export now accepts a [`Blob`](https://developer.mozilla.org/docs/Web/API/Blob) as an input.
20
+
1
21
  6.0.0 / 12.09.2025
2
22
  ==================
3
23
 
package/README.md CHANGED
@@ -27,7 +27,7 @@ Example 1: User chooses a file and the web application reads it.
27
27
  ```
28
28
 
29
29
  ```js
30
- import readXlsxFile from 'read-excel-file'
30
+ import readXlsxFile from 'read-excel-file/browser'
31
31
 
32
32
  const input = document.getElementById('input')
33
33
 
@@ -63,7 +63,7 @@ Example 1: Read data from a file at file path.
63
63
 
64
64
  ```js
65
65
  // Import from '/node' subpackage.
66
- const readXlsxFile = require('read-excel-file/node')
66
+ import readXlsxFile from 'read-excel-file/node'
67
67
 
68
68
  // Read data from a file by file path.
69
69
  readXlsxFile('/path/to/file').then((rows) => {
@@ -84,19 +84,26 @@ readXlsxFile(fs.createReadStream('/path/to/file')).then((rows) => {
84
84
  })
85
85
  ```
86
86
 
87
- Example 3: Read data from a [`Buffer`](https://nodejs.org/api/buffer.html).
87
+ It could also read data from a [`Buffer`](https://nodejs.org/api/buffer.html) or a [`Blob`](https://developer.mozilla.org/docs/Web/API/Blob).
88
+
89
+ In summary, it can read data from a file path, a [`Stream`](https://nodejs.org/api/stream.html), a [`Buffer`](https://nodejs.org/api/buffer.html) or a [`Blob`](https://developer.mozilla.org/docs/Web/API/Blob).
90
+
91
+ ### Universal
92
+
93
+ The one that works both in a web browser and Node.js. Only supports a [`Blob`](https://developer.mozilla.org/en-US/docs/Web/API/Blob) for input, which could be a bit less convenient for some.
88
94
 
89
95
  ```js
90
- // Read data from a `Buffer`.
91
- readXlsxFile(Buffer.from(fs.readFileSync('/path/to/file'))).then((rows) => {
96
+ // Import from '/universal' subpackage.
97
+ import readXlsxFile from 'read-excel-file/universal'
98
+
99
+ // Read data from a `Blob` with `*.xlsx` file contents.
100
+ readXlsxFile(blob).then((rows) => {
92
101
  // `rows` is an array of "rows".
93
102
  // Each "row" is an array of "cells".
94
103
  // Each "cell" is a value: string, number, Date, boolean.
95
104
  })
96
105
  ```
97
106
 
98
- In summary, it can read data from a file path, a [`Stream`](https://nodejs.org/api/stream.html) or a [`Buffer`](https://nodejs.org/api/buffer.html).
99
-
100
107
  ### Web Worker
101
108
 
102
109
  Example 1: User chooses a file and the web application reads it in a [Web Worker](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Using_web_workers) to avoid freezing the UI on large files.
@@ -163,9 +170,9 @@ readXlsxFile(file, { sheet: 'Sheet1' }).then((data) => {
163
170
  To get the names of all available sheets, use `readSheetNames()` function:
164
171
 
165
172
  ```js
166
- // Depending on where your code runs, import it from
167
- // 'read-excel-file' or 'read-exel-file/node' or 'read-excel-file/web-worker'.
168
- import { readSheetNames } from 'read-excel-file'
173
+ // The function could be imported from any sub-package:
174
+ // 'read-excel-file/browser', 'read-exel-file/node', 'read-excel-file/web-worker', etc.
175
+ import { readSheetNames } from 'read-excel-file/browser'
169
176
 
170
177
  readSheetNames(file).then((sheetNames) => {
171
178
  // sheetNames === ['Sheet1', 'Sheet2']
@@ -244,10 +251,10 @@ A key of a `schema` entry represents the name of the property. The value of the
244
251
  * `required: (object) => boolean` — A function returning `true` or `false` depending on the other properties of the object.
245
252
  * It could be configured to skip `required` validation for missing columns by passing `schemaPropertyShouldSkipRequiredValidationForMissingColumn` function as an option. By default it's `(column, { object }) => false` meaning that when `column` is missing from the spreadsheet, it will not skip `required` validation for it.
246
253
  * `validate(value)` — (optional) Validates the value. Is only called for non-empty cells. If the value is invalid, this function should throw an error.
247
- * `schema` — (optional) If the value is an object, `schema` should describe its properties.
248
- * If all of its property values happen to be empty (`undefined` or `null`), the object itself will be `null` too.
254
+ * `schema` — (optional) If the value is going to be a nested object, `schema` should describe all of its properties.
255
+ * If all of its property values happen to be empty (`undefined` or `null`), the nested object will be replaced with `null`.
249
256
  * This can be overridden by passing `getEmptyObjectValue(object, { path? })` function as an option. By default, it returns `null`.
250
- * `type` — (optional) If the value is not an object, `type` should describe the type of the value. It defines how the cell value will be converted to the property value. If no `type` is specified then the cell value is returned "as is": as a string, number, date or boolean.
257
+ * `type` — (optional) If the value is not going to be a nested object, `type` should define the type of the value. It will determine how the cell value will be converted to the property value. If no `type` is specified then the cell value is returned "as is": as a string, number, date or boolean.
251
258
  * Valid `type`s:
252
259
  * Standard types:
253
260
  * `String`
@@ -259,7 +266,7 @@ A key of a `schema` entry represents the name of the property. The value of the
259
266
  * `Email`
260
267
  * `URL`
261
268
  * Custom type:
262
- * A function that receives a cell value and returns a parsed value. If the value is invalid, it should throw an error.
269
+ * A function that receives a cell value and returns a parsed value. Returning `undefined` will have same effect as returning `null`. If the value is invalid, it should throw an error.
263
270
  * If the cell value consists of comma-separated values (example: `"a, b, c"`) then `type` could be specified as `[type]` for any of the valid `type`s described above.
264
271
  * Example: `{ type: [String] }` or `{ type: [(value) => parseValue(value)] }`
265
272
  * If the cell value is empty, or if every element of the array is `null` or `undefined`, then the array property value is gonna be `null` by default.
@@ -407,7 +414,7 @@ readXlsxFile(file, {
407
414
  #####
408
415
 
409
416
  ```js
410
- import { parseExcelDate } from 'read-excel-file'
417
+ import { parseExcelDate } from 'read-excel-file/browser'
411
418
 
412
419
  function ParseExcelFileErrors({ errors }) {
413
420
  return (
@@ -468,6 +475,10 @@ readXlsxFile(file, {
468
475
  ```
469
476
  </details>
470
477
 
478
+ ## Browser Support
479
+
480
+ An `*.xlsx` file is just a `*.zip` archive with an `*.xslx` file extension. This package uses [`fflate`](https://www.npmjs.com/package/fflate) for `*.zip` decompression. See `fflate`'s [browser support](https://www.npmjs.com/package/fflate#browser-support) for further details.
481
+
471
482
  ## CDN
472
483
 
473
484
  To include this library directly via a `<script/>` tag on a page, one can use any npm CDN service, e.g. [unpkg.com](https://unpkg.com) or [jsdelivr.com](https://jsdelivr.com)
@@ -0,0 +1,7 @@
1
+ exports = module.exports = require('../commonjs/export/readXlsxFileBrowser.js').default
2
+ exports['default'] = require('../commonjs/export/readXlsxFileBrowser.js').default
3
+ exports.readSheetNames = require('../commonjs/export/readSheetNamesBrowser.js').default
4
+ exports.parseExcelDate = require('../commonjs/xlsx/parseDate.js').default
5
+ exports.Integer = require('../commonjs/types/Integer.js').default
6
+ exports.Email = require('../commonjs/types/Email.js').default
7
+ exports.URL = require('../commonjs/types/URL.js').default
@@ -3,18 +3,19 @@ import {
3
3
  ParseWithoutSchemaOptions,
4
4
  ParsedObjectsResult,
5
5
  Row
6
- } from './types.d.js';
6
+ } from '../types.d.js';
7
7
 
8
8
  export {
9
9
  Schema,
10
10
  ParsedObjectsResult,
11
- Error,
11
+ SchemaParseCellValueError,
12
+ CellValueRequiredError,
12
13
  CellValue,
13
14
  Row,
14
15
  Integer,
15
16
  Email,
16
17
  URL
17
- } from './types.d.js';
18
+ } from '../types.d.js';
18
19
 
19
20
  export function parseExcelDate(excelSerialDate: number) : typeof Date;
20
21
 
@@ -0,0 +1,6 @@
1
+ export { default as default } from '../modules/export/readXlsxFileBrowser.js'
2
+ export { default as readSheetNames } from '../modules/export/readSheetNamesBrowser.js'
3
+ export { default as parseExcelDate } from '../modules/xlsx/parseDate.js'
4
+ export { default as Integer } from '../modules/types/Integer.js'
5
+ export { default as Email } from '../modules/types/Email.js'
6
+ export { default as URL } from '../modules/types/URL.js'
@@ -0,0 +1,17 @@
1
+ {
2
+ "private": true,
3
+ "name": "read-excel-file/browser",
4
+ "version": "1.0.0",
5
+ "main": "index.cjs",
6
+ "module": "index.js",
7
+ "types": "./index.d.ts",
8
+ "type": "module",
9
+ "exports": {
10
+ ".": {
11
+ "types": "./index.d.ts",
12
+ "import": "./index.js",
13
+ "require": "./index.cjs"
14
+ }
15
+ },
16
+ "sideEffects": false
17
+ }
@@ -1,2 +1,2 @@
1
- !function(r,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(r="undefined"!=typeof globalThis?globalThis:r||self).readXlsxFile=e()}(this,(function(){"use strict";var r={createDocument:function(r){return(new DOMParser).parseFromString(r.trim(),"text/xml")}},e=Uint8Array,t=Uint16Array,n=Int32Array,o=new e([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),i=new e([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),a=new e([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),u=function(r,e){for(var o=new t(31),i=0;i<31;++i)o[i]=e+=1<<r[i-1];var a=new n(o[30]);for(i=1;i<30;++i)for(var u=o[i];u<o[i+1];++u)a[u]=u-o[i]<<5|i;return{b:o,r:a}},f=u(o,2),c=f.b,l=f.r;c[28]=258,l[258]=28;for(var s=u(i,0).b,p=new t(32768),y=0;y<32768;++y){var m=(43690&y)>>1|(21845&y)<<1;m=(61680&(m=(52428&m)>>2|(13107&m)<<2))>>4|(3855&m)<<4,p[y]=((65280&m)>>8|(255&m)<<8)>>1}var b=function(r,e,n){for(var o=r.length,i=0,a=new t(e);i<o;++i)r[i]&&++a[r[i]-1];var u,f=new t(e);for(i=1;i<e;++i)f[i]=f[i-1]+a[i-1]<<1;if(n){u=new t(1<<e);var c=15-e;for(i=0;i<o;++i)if(r[i])for(var l=i<<4|r[i],s=e-r[i],y=f[r[i]-1]++<<s,m=y|(1<<s)-1;y<=m;++y)u[p[y]>>c]=l}else for(u=new t(o),i=0;i<o;++i)r[i]&&(u[i]=p[f[r[i]-1]++]>>15-r[i]);return u},v=new e(288);for(y=0;y<144;++y)v[y]=8;for(y=144;y<256;++y)v[y]=9;for(y=256;y<280;++y)v[y]=7;for(y=280;y<288;++y)v[y]=8;var d=new e(32);for(y=0;y<32;++y)d[y]=5;var h=b(v,9,1),g=b(d,5,1),w=function(r){for(var e=r[0],t=1;t<r.length;++t)r[t]>e&&(e=r[t]);return e},O=function(r,e,t){var n=e/8|0;return(r[n]|r[n+1]<<8)>>(7&e)&t},S=function(r,e){var t=e/8|0;return(r[t]|r[t+1]<<8|r[t+2]<<16)>>(7&e)},j=function(r,t,n){return(null==t||t<0)&&(t=0),(null==n||n>r.length)&&(n=r.length),new e(r.subarray(t,n))},A=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],E=function(r,e,t){var n=new Error(e||A[r]);if(n.code=r,Error.captureStackTrace&&Error.captureStackTrace(n,E),!t)throw n;return n},P=function(r,t,n,u){var f=r.length,l=u?u.length:0;if(!f||t.f&&!t.l)return n||new e(0);var p=!n,y=p||2!=t.i,m=t.i;p&&(n=new e(3*f));var v=function(r){var t=n.length;if(r>t){var o=new e(Math.max(2*t,r));o.set(n),n=o}},d=t.f||0,A=t.p||0,P=t.b||0,x=t.l,I=t.d,k=t.m,N=t.n,T=8*f;do{if(!x){d=O(r,A,1);var D=O(r,A+1,3);if(A+=3,!D){var C=r[(z=4+((A+7)/8|0))-4]|r[z-3]<<8,F=z+C;if(F>f){m&&E(0);break}y&&v(P+C),n.set(r.subarray(z,F),P),t.b=P+=C,t.p=A=8*F,t.f=d;continue}if(1==D)x=h,I=g,k=9,N=5;else if(2==D){var M=O(r,A,31)+257,_=O(r,A+10,15)+4,V=M+O(r,A+5,31)+1;A+=14;for(var U=new e(V),R=new e(19),$=0;$<_;++$)R[a[$]]=O(r,A+3*$,7);A+=3*_;var B=w(R),X=(1<<B)-1,q=b(R,B,1);for($=0;$<V;){var z,L=q[O(r,A,X)];if(A+=15&L,(z=L>>4)<16)U[$++]=z;else{var G=0,W=0;for(16==z?(W=3+O(r,A,3),A+=2,G=U[$-1]):17==z?(W=3+O(r,A,7),A+=3):18==z&&(W=11+O(r,A,127),A+=7);W--;)U[$++]=G}}var H=U.subarray(0,M),J=U.subarray(M);k=w(H),N=w(J),x=b(H,k,1),I=b(J,N,1)}else E(1);if(A>T){m&&E(0);break}}y&&v(P+131072);for(var K=(1<<k)-1,Q=(1<<N)-1,Y=A;;Y=A){var Z=(G=x[S(r,A)&K])>>4;if((A+=15&G)>T){m&&E(0);break}if(G||E(2),Z<256)n[P++]=Z;else{if(256==Z){Y=A,x=null;break}var rr=Z-254;if(Z>264){var er=o[$=Z-257];rr=O(r,A,(1<<er)-1)+c[$],A+=er}var tr=I[S(r,A)&Q],nr=tr>>4;tr||E(3),A+=15&tr;J=s[nr];if(nr>3){er=i[nr];J+=S(r,A)&(1<<er)-1,A+=er}if(A>T){m&&E(0);break}y&&v(P+131072);var or=P+rr;if(P<J){var ir=l-J,ar=Math.min(J,or);for(ir+P<0&&E(3);P<ar;++P)n[P]=u[ir+P]}for(;P<or;++P)n[P]=n[P-J]}}t.l=x,t.p=Y,t.b=P,t.f=d,x&&(d=1,t.m=k,t.d=I,t.n=N)}while(!d);return P!=n.length&&p?j(n,0,P):n.subarray(0,P)},x=new e(0),I=function(r,e){return r[e]|r[e+1]<<8},k=function(r,e){return(r[e]|r[e+1]<<8|r[e+2]<<16|r[e+3]<<24)>>>0},N=function(r,e){return k(r,e)+4294967296*k(r,e+4)};function T(r,e){return P(r,{i:2},e&&e.out,e&&e.dictionary)}var D="undefined"!=typeof TextDecoder&&new TextDecoder;try{D.decode(x,{stream:!0}),1}catch(r){}var C=function(r){for(var e="",t=0;;){var n=r[t++],o=(n>127)+(n>223)+(n>239);if(t+o>r.length)return{s:e,r:j(r,t-1)};o?3==o?(n=((15&n)<<18|(63&r[t++])<<12|(63&r[t++])<<6|63&r[t++])-65536,e+=String.fromCharCode(55296|n>>10,56320|1023&n)):e+=1&o?String.fromCharCode((31&n)<<6|63&r[t++]):String.fromCharCode((15&n)<<12|(63&r[t++])<<6|63&r[t++]):e+=String.fromCharCode(n)}};function F(r,e){if(e){for(var t="",n=0;n<r.length;n+=16384)t+=String.fromCharCode.apply(null,r.subarray(n,n+16384));return t}if(D)return D.decode(r);var o=C(r),i=o.s;return(t=o.r).length&&E(8),i}var M=function(r,e){return e+30+I(r,e+26)+I(r,e+28)},_=function(r,e,t){var n=I(r,e+28),o=F(r.subarray(e+46,e+46+n),!(2048&I(r,e+8))),i=e+46+n,a=k(r,e+20),u=t&&4294967295==a?V(r,i):[a,k(r,e+24),k(r,e+42)],f=u[0],c=u[1],l=u[2];return[I(r,e+10),f,c,o,i+I(r,e+30)+I(r,e+32),l]},V=function(r,e){for(;1!=I(r,e);e+=4+I(r,e+2));return[N(r,e+12),N(r,e+4),N(r,e+20)]};function U(r){var t=function(r,t){for(var n={},o=r.length-22;101010256!=k(r,o);--o)(!o||r.length-o>65558)&&E(13);var i=I(r,o+8);if(!i)return{};var a=k(r,o+16),u=4294967295==a||65535==i;if(u){var f=k(r,o-12);(u=101075792==k(r,f))&&(i=k(r,f+32),a=k(r,f+48))}for(var c=t&&t.filter,l=0;l<i;++l){var s=_(r,a,u),p=s[0],y=s[1],m=s[2],b=s[3],v=s[4],d=s[5],h=M(r,d);a=v,c&&!c({name:b,size:y,originalSize:m,compression:p})||(p?8==p?n[b]=T(r.subarray(h,h+y),{out:new e(m)}):E(14,"unknown compression type "+p):n[b]=j(r,h,h+y))}return n}(new Uint8Array(r));return Promise.resolve(function(r){for(var e=[],t=0,n=Object.keys(r);t<n.length;t++){var o=n[t];e[o]=F(r[o])}return e}(t))}function R(r,e){for(var t=0;t<r.childNodes.length;){var n=r.childNodes[t];if(1===n.nodeType&&q(n)===e)return n;t++}}function $(r,e){for(var t=[],n=0;n<r.childNodes.length;){var o=r.childNodes[n];1===o.nodeType&&q(o)===e&&t.push(o),n++}return t}function B(r,e,t){for(var n=0;n<r.childNodes.length;){var o=r.childNodes[n];e?1===o.nodeType&&q(o)===e&&t(o,n):t(o,n),n++}}var X=/.+\:/;function q(r){return r.tagName.replace(X,"")}function z(r){for(var e=0;e<r.childNodes.length;){if(1===r.childNodes[e].nodeType)return r.childNodes[e];e++}}function L(r){if(1!==r.nodeType)return r.textContent;for(var e="<"+q(r),t=0;t<r.attributes.length;)e+=" "+r.attributes[t].name+'="'+r.attributes[t].value+'"',t++;e+=">";for(var n=0;n<r.childNodes.length;)e+=L(r.childNodes[n]),n++;return e+="</"+q(r)+">"}function G(r){var e,t,n=r.documentElement;return e=function(r){var e=R(r,"t");if(e)return e.textContent;var t="";return B(r,"r",(function(r){t+=R(r,"t").textContent})),t},t=[],B(n,"si",(function(r,n){t.push(e(r,n))})),t}function W(r,e){var t=e.createDocument(r),n={},o=R(t.documentElement,"workbookPr");o&&"1"===o.getAttribute("date1904")&&(n.epoch1904=!0),n.sheets=[];return function(r){return $(R(r.documentElement,"sheets"),"sheet")}(t).forEach((function(r){r.getAttribute("name")&&n.sheets.push({id:r.getAttribute("sheetId"),name:r.getAttribute("name"),relationId:r.getAttribute("r:id")})})),n}function H(r,e){var t=e.createDocument(r),n={sheets:{},sharedStrings:void 0,styles:void 0};return function(r){return $(r.documentElement,"Relationship")}(t).forEach((function(r){var e=r.getAttribute("Target");switch(r.getAttribute("Type")){case"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles":n.styles=J(e);break;case"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings":n.sharedStrings=J(e);break;case"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet":n.sheets[r.getAttribute("Id")]=J(e)}})),n}function J(r){return"/"===r[0]?r.slice(1):"xl/"+r}function K(r){return K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},K(r)}function Q(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function Y(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?Q(Object(t),!0).forEach((function(e){Z(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):Q(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function Z(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==K(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==K(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===K(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function rr(r,e){if(!r)return{};var t,n,o=e.createDocument(r),i=(t=o,n=R(t.documentElement,"cellStyleXfs"),n?$(n,"xf"):[]).map(tr),a=function(r){var e=R(r.documentElement,"numFmts");return e?$(e,"numFmt"):[]}(o).map(er).reduce((function(r,e){return r[e.id]=e,r}),[]);return function(r){var e=R(r.documentElement,"cellXfs");return e?$(e,"xf"):[]}(o).map((function(r){return r.hasAttribute("xfId")?Y(Y({},i[r.xfId]),tr(r,a)):tr(r,a)}))}function er(r){return{id:r.getAttribute("numFmtId"),template:r.getAttribute("formatCode")}}function tr(r,e){var t={};if(r.hasAttribute("numFmtId")){var n=r.getAttribute("numFmtId");e[n]?t.numberFormat=e[n]:t.numberFormat={id:n}}return t}function nr(r,e){e&&e.epoch1904&&(r+=1462);return new Date(Math.round(24*(r-25569)*36e5))}function or(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return ir(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return ir(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function ir(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function ar(r,e,t){if(r){var n=e[r];if(!n)throw new Error("Cell style not found: ".concat(r));if(!n.numberFormat)return!1;if(ur.indexOf(Number(n.numberFormat.id))>=0||t.dateFormat&&n.numberFormat.template===t.dateFormat||!1!==t.smartDateParser&&n.numberFormat.template&&function(r){for(var e,t=or((r=(r=(r=r.toLowerCase()).replace(fr,"")).replace(cr,"")).split(/\W+/));!(e=t()).done;){var n=e.value;if(lr.indexOf(n)<0)return!1}return!0}(n.numberFormat.template))return!0}}var ur=[14,15,16,17,18,19,20,21,22,27,30,36,45,46,47,50,57],fr=/^\[\$-414\]/,cr=/;@$/;var lr=["ss","mm","h","hh","am","pm","d","dd","m","mm","mmm","mmmm","yy","yyyy","e"];function sr(r,e,t){var n=t.getInlineStringValue,o=t.getInlineStringXml,i=t.getStyleId,a=t.styles,u=t.values,f=t.properties,c=t.options;switch(e||(e="n"),e){case"str":r=pr(r,c);break;case"inlineStr":if(void 0===(r=n()))throw new Error('Unsupported "inline string" cell value structure: '.concat(o()));r=pr(r,c);break;case"s":var l=Number(r);if(isNaN(l))throw new Error('Invalid "shared" string index: '.concat(r));if(l>=u.length)throw new Error('An out-of-bounds "shared" string index: '.concat(r));r=pr(r=u[l],c);break;case"b":if("1"===r)r=!0;else{if("0"!==r)throw new Error('Unsupported "boolean" cell value: '.concat(r));r=!1}break;case"z":r=void 0;break;case"e":r=function(r){switch(r){case 0:return"#NULL!";case 7:return"#DIV/0!";case 15:return"#VALUE!";case 23:return"#REF!";case 29:return"#NAME?";case 36:return"#NUM!";case 42:return"#N/A";case 43:return"#GETTING_DATA";default:return"#ERROR_".concat(r)}}(r);break;case"d":if(void 0===r)break;var s=new Date(r);if(isNaN(s.valueOf()))throw new Error('Unsupported "date" cell value: '.concat(r));r=s;break;case"n":if(void 0===r)break;r=ar(i(),a,c)?nr(r=yr(r),f):(c.parseNumber||yr)(r);break;default:throw new TypeError("Cell type not supported: ".concat(e))}return void 0===r&&(r=null),r}function pr(r,e){return!1!==e.trim&&(r=r.trim()),""===r&&(r=void 0),r}function yr(r){var e=Number(r);if(isNaN(e))throw new Error('Invalid "numeric" cell value: '.concat(r));return e}var mr=["","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"];function br(r){for(var e=0,t=0;t<r.length;)e*=26,e+=mr.indexOf(r[t]),t++;return e}function vr(r){return r=r.split(/(\d+)/),[parseInt(r[1]),br(r[0].trim())]}function dr(r,e,t,n,o,i,a){var u,f=vr(r.getAttribute("r")),c=function(r,e){return R(e,"v")}(0,r),l=c&&c.textContent;return r.hasAttribute("t")&&(u=r.getAttribute("t")),{row:f[0],column:f[1],value:sr(l,u,{getInlineStringValue:function(){return function(r,e){var t=z(e);if(t&&"is"===q(t)){var n=z(t);if(n&&"t"===q(n))return n.textContent}}(0,r)},getInlineStringXml:function(){return L(r)},getStyleId:function(){return r.getAttribute("s")},styles:o,values:n,properties:i,options:a})}}function hr(r,e,t,n,o,i){var a=function(r){var e=R(r.documentElement,"sheetData"),t=[];return B(e,"row",(function(r){B(r,"c",(function(r){t.push(r)}))})),t}(r);return 0===a.length?[]:a.map((function(r){return dr(r,0,0,t,n,o,i)}))}function gr(r,e){return function(r){if(Array.isArray(r))return r}(r)||function(r,e){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var n,o,i,a,u=[],f=!0,c=!1;try{if(i=(t=t.call(r)).next,0===e){if(Object(t)!==t)return;f=!1}else for(;!(f=(n=i.call(t)).done)&&(u.push(n.value),u.length!==e);f=!0);}catch(r){c=!0,o=r}finally{try{if(!f&&null!=t.return&&(a=t.return(),Object(a)!==a))return}finally{if(c)throw o}}return u}}(r,e)||function(r,e){if(!r)return;if("string"==typeof r)return wr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return wr(r,e)}(r,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function wr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Or(r){var e=function(r){var e=R(r.documentElement,"dimension");if(e)return e.getAttribute("ref")}(r);if(e)return 1===(e=e.split(":").map(vr).map((function(r){var e=gr(r,2);return{row:e[0],column:e[1]}}))).length&&(e=[e[0],e[0]]),e}function Sr(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return jr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return jr(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function jr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Ar(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return Er(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return Er(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Er(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Pr(r,e){return function(r){if(Array.isArray(r))return r}(r)||function(r,e){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var n,o,i,a,u=[],f=!0,c=!1;try{if(i=(t=t.call(r)).next,0===e){if(Object(t)!==t)return;f=!1}else for(;!(f=(n=i.call(t)).done)&&(u.push(n.value),u.length!==e);f=!0);}catch(r){c=!0,o=r}finally{try{if(!f&&null!=t.return&&(a=t.return(),Object(a)!==a))return}finally{if(c)throw o}}return u}}(r,e)||xr(r,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function xr(r,e){if(r){if("string"==typeof r)return Ir(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?Ir(r,e):void 0}}function Ir(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function kr(r,e){var t=r.dimensions,n=r.cells;if(0===n.length)return[];var o=Pr(t,2);o[0];for(var i=o[1],a=i.column,u=i.row,f=new Array(u),c=0;c<u;){f[c]=new Array(a);for(var l=0;l<a;)f[c][l]=null,l++;c++}for(var s,p=function(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=xr(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(n);!(s=p()).done;){var y=s.value,m=y.row-1,b=y.column-1;b<a&&m<u&&(f[m][b]=y.value)}var v=e.rowIndexSourceMap;if(v)for(var d=0;d<f.length;)v[d]=d,d++;return f=function(r){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},t=e.rowIndexSourceMap,n=e.accessor,o=void 0===n?function(r){return r}:n,i=e.onlyTrimAtTheEnd,a=r.length-1;a>=0;){for(var u,f=!0,c=Sr(r[a]);!(u=c()).done;)if(null!==o(u.value)){f=!1;break}if(f)r.splice(a,1),t&&t.splice(a,1);else if(i)break;a--}return r}(function(r){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},t=e.accessor,n=void 0===t?function(r){return r}:t,o=e.onlyTrimAtTheEnd,i=r[0].length-1;i>=0;){for(var a,u=!0,f=Ar(r);!(a=f()).done;)if(null!==n(a.value[i])){u=!1;break}if(u)for(var c=0;c<r.length;)r[c].splice(i,1),c++;else if(o)break;i--}return r}(f,{onlyTrimAtTheEnd:!0}),{onlyTrimAtTheEnd:!0,rowIndexSourceMap:v}),e.transformData&&(f=e.transformData(f)),f}function Nr(r){return Nr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},Nr(r)}function Tr(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return Dr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return Dr(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Dr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Cr(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function Fr(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?Cr(Object(t),!0).forEach((function(e){Mr(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):Cr(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function Mr(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==Nr(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==Nr(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===Nr(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function _r(r,e){var t=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};t.sheet||(t=Fr({sheet:1},t));var n=function(e){if(!r[e])throw new Error('"'.concat(e,'" file not found inside the *.xlsx file zip archive'));return r[e]},o=H(n("xl/_rels/workbook.xml.rels"),e),i=o.sharedStrings?function(r,e){return r?G(e.createDocument(r)):[]}(n(o.sharedStrings),e):[],a=o.styles?rr(n(o.styles),e):{},u=W(n("xl/workbook.xml"),e);if(t.getSheets)return u.sheets.map((function(r){return{name:r.name}}));var f=function(r,e){if("number"==typeof r){var t=e[r-1];return t&&t.relationId}for(var n,o=Tr(e);!(n=o()).done;){var i=n.value;if(i.name===r)return i.relationId}}(t.sheet,u.sheets);if(!f||!o.sheets[f])throw function(r,e){var t=e&&e.map((function(r,e){return'"'.concat(r.name,'" (#').concat(e+1,")")})).join(", ");return new Error("Sheet ".concat("number"==typeof r?"#"+r:'"'+r+'"'," not found in the *.xlsx file.").concat(e?" Available sheets: "+t+".":""))}(t.sheet,u.sheets);var c=function(r,e,t,n,o,i){var a=e.createDocument(r),u=hr(a,0,t,n,o,i),f=Or(a)||function(r){var e=function(r,e){return r-e},t=r.map((function(r){return r.row})).sort(e),n=r.map((function(r){return r.column})).sort(e),o=t[0],i=t[t.length-1];return[{row:o,column:n[0]},{row:i,column:n[n.length-1]}]}(u);return{cells:u,dimensions:f}}(n(o.sheets[f]),e,i,a,u,t),l=kr(c,t=Fr({rowIndexSourceMap:[]},t));return t.properties?{data:l,properties:u}:l}function Vr(r){return Vr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},Vr(r)}function Ur(r,e){for(var t=0;t<e.length;t++){var n=e[t];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(r,(o=n.key,i=void 0,i=function(r,e){if("object"!==Vr(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==Vr(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(o,"string"),"symbol"===Vr(i)?i:String(i)),n)}var o,i}function Rr(r){var e=Xr();return function(){var t,n=zr(r);if(e){var o=zr(this).constructor;t=Reflect.construct(n,arguments,o)}else t=n.apply(this,arguments);return function(r,e){if(e&&("object"===Vr(e)||"function"==typeof e))return e;if(void 0!==e)throw new TypeError("Derived constructors may only return object or undefined");return function(r){if(void 0===r)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return r}(r)}(this,t)}}function $r(r){var e="function"==typeof Map?new Map:void 0;return $r=function(r){if(null===r||(t=r,-1===Function.toString.call(t).indexOf("[native code]")))return r;var t;if("function"!=typeof r)throw new TypeError("Super expression must either be null or a function");if(void 0!==e){if(e.has(r))return e.get(r);e.set(r,n)}function n(){return Br(r,arguments,zr(this).constructor)}return n.prototype=Object.create(r.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),qr(n,r)},$r(r)}function Br(r,e,t){return Br=Xr()?Reflect.construct.bind():function(r,e,t){var n=[null];n.push.apply(n,e);var o=new(Function.bind.apply(r,n));return t&&qr(o,t.prototype),o},Br.apply(null,arguments)}function Xr(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(r){return!1}}function qr(r,e){return qr=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(r,e){return r.__proto__=e,r},qr(r,e)}function zr(r){return zr=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(r){return r.__proto__||Object.getPrototypeOf(r)},zr(r)}var Lr=function(r){!function(r,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");r.prototype=Object.create(e&&e.prototype,{constructor:{value:r,writable:!0,configurable:!0}}),Object.defineProperty(r,"prototype",{writable:!1}),e&&qr(r,e)}(i,r);var e,t,n,o=Rr(i);function i(r){var e;return function(r,e){if(!(r instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),(e=o.call(this,"invalid")).reason=r,e}return e=i,t&&Ur(e.prototype,t),n&&Ur(e,n),Object.defineProperty(e,"prototype",{writable:!1}),e}($r(Error));function Gr(r){if("string"==typeof r){var e=r;if(r=Number(r),String(r)!==e)throw new Lr("not_a_number")}if("number"!=typeof r)throw new Lr("not_a_number");if(isNaN(r))throw new Lr("invalid_number");if(!isFinite(r))throw new Lr("out_of_bounds");return r}function Wr(r){if("string"==typeof r)return r;if("number"==typeof r){if(isNaN(r))throw new Lr("invalid_number");if(!isFinite(r))throw new Lr("out_of_bounds");return String(r)}throw new Lr("not_a_string")}function Hr(r){if("boolean"==typeof r)return r;throw new Lr("not_a_boolean")}var Jr=["isColumnOriented","ignoreEmptyRows","rowIndexSourceMap"];function Kr(r){return Kr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},Kr(r)}function Qr(r,e){return function(r){if(Array.isArray(r))return r}(r)||function(r,e){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var n,o,i,a,u=[],f=!0,c=!1;try{if(i=(t=t.call(r)).next,0===e){if(Object(t)!==t)return;f=!1}else for(;!(f=(n=i.call(t)).done)&&(u.push(n.value),u.length!==e);f=!0);}catch(r){c=!0,o=r}finally{try{if(!f&&null!=t.return&&(a=t.return(),Object(a)!==a))return}finally{if(c)throw o}}return u}}(r,e)||Yr(r,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function Yr(r,e){if(r){if("string"==typeof r)return Zr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?Zr(r,e):void 0}}function Zr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function re(r,e){if(null==r)return{};var t,n,o=function(r,e){if(null==r)return{};var t,n,o={},i=Object.keys(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||(o[t]=r[t]);return o}(r,e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||Object.prototype.propertyIsEnumerable.call(r,t)&&(o[t]=r[t])}return o}function ee(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function te(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?ee(Object(t),!0).forEach((function(e){ne(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):ee(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function ne(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==Kr(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==Kr(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===Kr(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}var oe={schemaPropertyValueForMissingColumn:void 0,schemaPropertyValueForMissingValue:null,schemaPropertyShouldSkipRequiredValidationForMissingColumn:function(){return!1},getEmptyObjectValue:function(){return null},getEmptyArrayValue:function(){return null},isColumnOriented:!1,ignoreEmptyRows:!0,arrayValueSeparator:","};function ie(r,e,t){var n=t=t?te(te({},oe),t):oe,o=n.isColumnOriented,i=n.ignoreEmptyRows,a=n.rowIndexSourceMap,u=re(n,Jr),f=a&&a.slice();!function(r){for(var e=0,t=Object.keys(r);e<t.length;e++){var n=t[e],o=r[n];if("object"===Kr(o.type)&&!Array.isArray(o.type))throw new Error("When defining a nested schema, use a `schema` property instead of a `type` property");if(!o.schema&&!o.column)throw new Error('"column" not defined for schema entry "'.concat(n,'".'))}}(e),o&&(r=le(r)),i&&(r=r.filter((function(r,e){return!r.every((function(r){return null===r}))||(f&&f.splice(e,1),!1)})));for(var c=r[0],l=[],s=[],p=1;p<r.length;p++){var y=ae(e,r[p],p,void 0,c,s,u);l.push(y)}if(f)for(var m,b=function(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=Yr(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(s);!(m=b()).done;){var v=m.value;v.row=f[v.row-1]+1}return{rows:l,errors:s}}function ae(r,e,t,n,o,i,a){for(var u={},f=!0,c=function(r){var e=r.schemaEntry,n=r.value,o=r.error,i=r.reason,a={error:o,row:t+1,column:e.column,value:n};return i&&(a.reason=i),e.type&&(a.type=e.type),a},l=[],s=function(){var s,m,b,v,d=y[p],h=r[d],g=d,w=h.column,O="".concat(n||"",".").concat(g),S=o.indexOf(w),j=S<0;if(j||(s=e[S]),h.schema)m=ae(h.schema,e,t,O,o,i,a);else if(j)"schemaPropertyValueForMissingColumn"in a&&(m=a.schemaPropertyValueForMissingColumn);else if(void 0===s)"schemaPropertyValueForMissingValue"in a&&(m=a.schemaPropertyValueForMissingValue);else if(null===s)"schemaPropertyValueForMissingValue"in a&&(m=a.schemaPropertyValueForMissingValue);else if(Array.isArray(h.type)){var A=function(r,e){var t=[],n=0;for(;n<r.length;){var o=Qr(ce(r,e,n),2),i=o[0];n+=o[1]+e.length,t.push(i.trim())}return t}(s,a.arrayValueSeparator).map((function(r){if(!b){var e=ue(r,h,a);return e.error&&(m=r,b=e.error,v=e.reason),e.value}}));if(!b){var E=A.every(se);m=E?a.getEmptyArrayValue(A,{path:O}):A}}else{var P=ue(s,h,a);b=P.error,v=P.reason,m=b?s:P.value}!b&&se(m)&&h.required&&l.push({schemaEntry:h,value:m,isMissingColumn:j}),b?i.push(c({schemaEntry:h,value:m,error:b,reason:v})):(f&&!se(m)&&(f=!1),void 0!==m&&(u[g]=m))},p=0,y=Object.keys(r);p<y.length;p++)s();if(f)return a.getEmptyObjectValue(u,{path:n});for(var m=0,b=l;m<b.length;m++){var v=b[m],d=v.schemaEntry,h=v.value;if(!(v.isMissingColumn&&a.schemaPropertyShouldSkipRequiredValidationForMissingColumn(d.column,{object:u}))){var g=d.required;("boolean"==typeof g?g:g(u))&&i.push(c({schemaEntry:d,value:h,error:"required"}))}}return u}function ue(r,e,t){if(null===r)return{value:null};var n;if(e.parse)throw new Error("`schemaEntry.parse` property was renamed to `schemaEntry.type`");if(n=e.type?function(r,e,t){switch(e){case String:return fe(r,Wr);case Number:return fe(r,Gr);case Date:return fe(r,(function(r){return function(r,e){var t=e.properties;if(r instanceof Date){if(isNaN(r.valueOf()))throw new Lr("out_of_bounds");return r}if("number"==typeof r){if(isNaN(r))throw new Lr("invalid_number");if(!isFinite(r))throw new Lr("out_of_bounds");var n=nr(r,t);if(isNaN(n.valueOf()))throw new Lr("out_of_bounds");return n}throw new Lr("not_a_date")}(r,{properties:t.properties})}));case Boolean:return fe(r,Hr);default:if("function"==typeof e)return fe(r,e);throw new Error("Unsupported schema type: ".concat(e&&e.name||e))}}(r,Array.isArray(e.type)?e.type[0]:e.type,t):{value:r},n.error)return n;if(null!==n.value){if(e.oneOf&&e.oneOf.indexOf(n.value)<0)return{error:"invalid",reason:"unknown"};if(e.validate)try{e.validate(n.value)}catch(r){return{error:r.message}}}return n}function fe(r,e){try{var t=e(r);return void 0===t?{value:null}:{value:t}}catch(r){var n={error:r.message};return r.reason&&(n.reason=r.reason),n}}function ce(r,e,t){for(var n=0,o="";t+n<r.length;){var i=r[t+n];if(i===e)return[o,n];if('"'===i){var a=ce(r,'"',t+n+1);o+=a[0],n+=1+a[1]+1}else o+=i,n++}return[o,n]}var le=function(r){return r[0].map((function(e,t){return r.map((function(r){return r[t]}))}))};function se(r){return null==r}function pe(r){return pe="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},pe(r)}var ye=["schema"];function me(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function be(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?me(Object(t),!0).forEach((function(e){ve(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):me(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function ve(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==pe(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==pe(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===pe(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function de(r,e){if(null==r)return{};var t,n,o=function(r,e){if(null==r)return{};var t,n,o={},i=Object.keys(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||(o[t]=r[t]);return o}(r,e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||Object.prototype.propertyIsEnumerable.call(r,t)&&(o[t]=r[t])}return o}return function(e){var t,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return(t=e,t instanceof File||t instanceof Blob?t.arrayBuffer().then(U):U(t)).then((function(e){return function(r,e,t){var n=t.schema,o=de(t,ye);if(o.map)throw new Error("`map` option was removed. Pass a `schema` option instead.");var i=_r(r,e,be(be({},o),{},{properties:n||o.properties}));return n?ie(i.data,n,be(be({},o),{},{properties:i.properties})):i}(e,r,n)}))}}));
1
+ !function(r,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(r="undefined"!=typeof globalThis?globalThis:r||self).readXlsxFile=e()}(this,(function(){"use strict";var r={createDocument:function(r){return(new DOMParser).parseFromString(r.trim(),"text/xml")}},e={},t=Uint8Array,n=Uint16Array,o=Int32Array,i=new t([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),u=new t([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),a=new t([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),f=function(r,e){for(var t=new n(31),i=0;i<31;++i)t[i]=e+=1<<r[i-1];var u=new o(t[30]);for(i=1;i<30;++i)for(var a=t[i];a<t[i+1];++a)u[a]=a-t[i]<<5|i;return{b:t,r:u}},c=f(i,2),l=c.b,s=c.r;l[28]=258,s[258]=28;for(var p=f(u,0).b,y=new n(32768),m=0;m<32768;++m){var v=(43690&m)>>1|(21845&m)<<1;v=(61680&(v=(52428&v)>>2|(13107&v)<<2))>>4|(3855&v)<<4,y[m]=((65280&v)>>8|(255&v)<<8)>>1}var b=function(r,e,t){for(var o=r.length,i=0,u=new n(e);i<o;++i)r[i]&&++u[r[i]-1];var a,f=new n(e);for(i=1;i<e;++i)f[i]=f[i-1]+u[i-1]<<1;if(t){a=new n(1<<e);var c=15-e;for(i=0;i<o;++i)if(r[i])for(var l=i<<4|r[i],s=e-r[i],p=f[r[i]-1]++<<s,m=p|(1<<s)-1;p<=m;++p)a[y[p]>>c]=l}else for(a=new n(o),i=0;i<o;++i)r[i]&&(a[i]=y[f[r[i]-1]++]>>15-r[i]);return a},d=new t(288);for(m=0;m<144;++m)d[m]=8;for(m=144;m<256;++m)d[m]=9;for(m=256;m<280;++m)d[m]=7;for(m=280;m<288;++m)d[m]=8;var h=new t(32);for(m=0;m<32;++m)h[m]=5;var g=b(d,9,1),w=b(h,5,1),O=function(r){for(var e=r[0],t=1;t<r.length;++t)r[t]>e&&(e=r[t]);return e},S=function(r,e,t){var n=e/8|0;return(r[n]|r[n+1]<<8)>>(7&e)&t},j=function(r,e){var t=e/8|0;return(r[t]|r[t+1]<<8|r[t+2]<<16)>>(7&e)},A=function(r){return(r+7)/8|0},E=function(r,e,n){return(null==e||e<0)&&(e=0),(null==n||n>r.length)&&(n=r.length),new t(r.subarray(e,n))},P=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],x=function(r,e,t){var n=new Error(e||P[r]);if(n.code=r,Error.captureStackTrace&&Error.captureStackTrace(n,x),!t)throw n;return n},I=function(r,e,n,o){var f=r.length,c=o?o.length:0;if(!f||e.f&&!e.l)return n||new t(0);var s=!n,y=s||2!=e.i,m=e.i;s&&(n=new t(3*f));var v=function(r){var e=n.length;if(r>e){var o=new t(Math.max(2*e,r));o.set(n),n=o}},d=e.f||0,h=e.p||0,P=e.b||0,I=e.l,k=e.d,T=e.m,N=e.n,D=8*f;do{if(!I){d=S(r,h,1);var M=S(r,h+1,3);if(h+=3,!M){var C=r[(W=A(h)+4)-4]|r[W-3]<<8,F=W+C;if(F>f){m&&x(0);break}y&&v(P+C),n.set(r.subarray(W,F),P),e.b=P+=C,e.p=h=8*F,e.f=d;continue}if(1==M)I=g,k=w,T=9,N=5;else if(2==M){var _=S(r,h,31)+257,V=S(r,h+10,15)+4,U=_+S(r,h+5,31)+1;h+=14;for(var R=new t(U),$=new t(19),z=0;z<V;++z)$[a[z]]=S(r,h+3*z,7);h+=3*V;var L=O($),q=(1<<L)-1,B=b($,L,1);for(z=0;z<U;){var W,X=B[S(r,h,q)];if(h+=15&X,(W=X>>4)<16)R[z++]=W;else{var G=0,H=0;for(16==W?(H=3+S(r,h,3),h+=2,G=R[z-1]):17==W?(H=3+S(r,h,7),h+=3):18==W&&(H=11+S(r,h,127),h+=7);H--;)R[z++]=G}}var J=R.subarray(0,_),K=R.subarray(_);T=O(J),N=O(K),I=b(J,T,1),k=b(K,N,1)}else x(1);if(h>D){m&&x(0);break}}y&&v(P+131072);for(var Q=(1<<T)-1,Y=(1<<N)-1,Z=h;;Z=h){var rr=(G=I[j(r,h)&Q])>>4;if((h+=15&G)>D){m&&x(0);break}if(G||x(2),rr<256)n[P++]=rr;else{if(256==rr){Z=h,I=null;break}var er=rr-254;if(rr>264){var tr=i[z=rr-257];er=S(r,h,(1<<tr)-1)+l[z],h+=tr}var nr=k[j(r,h)&Y],or=nr>>4;nr||x(3),h+=15&nr;K=p[or];if(or>3){tr=u[or];K+=j(r,h)&(1<<tr)-1,h+=tr}if(h>D){m&&x(0);break}y&&v(P+131072);var ir=P+er;if(P<K){var ur=c-K,ar=Math.min(K,ir);for(ur+P<0&&x(3);P<ar;++P)n[P]=o[ur+P]}for(;P<ir;++P)n[P]=n[P-K]}}e.l=I,e.p=Z,e.b=P,e.f=d,I&&(d=1,e.m=T,e.d=k,e.n=N)}while(!d);return P!=n.length&&s?E(n,0,P):n.subarray(0,P)},k=new t(0),T=function(r,e,t){for(var n=r(),o=r.toString(),i=o.slice(o.indexOf("[")+1,o.lastIndexOf("]")).replace(/\s+/g,"").split(","),u=0;u<n.length;++u){var a=n[u],f=i[u];if("function"==typeof a){e+=";"+f+"=";var c=a.toString();if(a.prototype)if(-1!=c.indexOf("[native code]")){var l=c.indexOf(" ",8)+1;e+=c.slice(l,c.indexOf("(",l))}else for(var s in e+=c,a.prototype)e+=";"+f+".prototype."+s+"="+a.prototype[s].toString();else e+=c}else t[f]=a}return e},N=[],D=function(r,t,n,o){if(!N[n]){for(var i="",u={},a=r.length-1,f=0;f<a;++f)i=T(r[f],i,u);N[n]={c:T(r[a],i,u),e:u}}var c=function(r,e){var t={};for(var n in r)t[n]=r[n];for(var n in e)t[n]=e[n];return t}({},N[n].e);return function(r,t,n,o,i){var u=new Worker(e[t]||(e[t]=URL.createObjectURL(new Blob([r+';addEventListener("error",function(e){e=e.error;postMessage({$e$:[e.message,e.code,e.stack]})})'],{type:"text/javascript"}))));return u.onmessage=function(r){var e=r.data,t=e.$e$;if(t){var n=new Error(t[0]);n.code=t[1],n.stack=t[2],i(n,null)}else i(null,e)},u.postMessage(n,o),u}(N[n].c+";onmessage=function(e){for(var k in e.data)self[k]=e.data[k];onmessage="+t.toString()+"}",n,c,function(r){var e=[];for(var t in r)r[t].buffer&&e.push((r[t]=new r[t].constructor(r[t])).buffer);return e}(c),o)},M=function(){return[t,n,o,i,u,a,l,p,g,w,y,P,b,O,S,j,A,E,x,I,$,C,F]},C=function(r){return postMessage(r,[r.buffer])},F=function(r){return r&&{out:r.size&&new t(r.size),dictionary:r.dictionary}},_=function(r,e,t,n,o,i){var u=D(t,n,o,(function(r,e){u.terminate(),i(r,e)}));return u.postMessage([r,e],e.consume?[r.buffer]:[]),function(){u.terminate()}},V=function(r,e){return r[e]|r[e+1]<<8},U=function(r,e){return(r[e]|r[e+1]<<8|r[e+2]<<16|r[e+3]<<24)>>>0},R=function(r,e){return U(r,e)+4294967296*U(r,e+4)};function $(r,e){return I(r,{i:2},e&&e.out,e&&e.dictionary)}var z="undefined"!=typeof TextDecoder&&new TextDecoder;try{z.decode(k,{stream:!0}),1}catch(r){}var L=function(r){for(var e="",t=0;;){var n=r[t++],o=(n>127)+(n>223)+(n>239);if(t+o>r.length)return{s:e,r:E(r,t-1)};o?3==o?(n=((15&n)<<18|(63&r[t++])<<12|(63&r[t++])<<6|63&r[t++])-65536,e+=String.fromCharCode(55296|n>>10,56320|1023&n)):e+=1&o?String.fromCharCode((31&n)<<6|63&r[t++]):String.fromCharCode((15&n)<<12|(63&r[t++])<<6|63&r[t++]):e+=String.fromCharCode(n)}};function q(r,e){if(e){for(var t="",n=0;n<r.length;n+=16384)t+=String.fromCharCode.apply(null,r.subarray(n,n+16384));return t}if(z)return z.decode(r);var o=L(r),i=o.s;return(t=o.r).length&&x(8),i}var B=function(r,e){return e+30+V(r,e+26)+V(r,e+28)},W=function(r,e,t){var n=V(r,e+28),o=q(r.subarray(e+46,e+46+n),!(2048&V(r,e+8))),i=e+46+n,u=U(r,e+20),a=t&&4294967295==u?X(r,i):[u,U(r,e+24),U(r,e+42)],f=a[0],c=a[1],l=a[2];return[V(r,e+10),f,c,o,i+V(r,e+30)+V(r,e+32),l]},X=function(r,e){for(;1!=V(r,e);e+=4+V(r,e+2));return[R(r,e+12),R(r,e+4),R(r,e+20)]},G="function"==typeof queueMicrotask?queueMicrotask:"function"==typeof setTimeout?setTimeout:function(r){r()};function H(r,e,n){n||(n=e,e={}),"function"!=typeof n&&x(7);var o=[],i=function(){for(var r=0;r<o.length;++r)o[r]()},u={},a=function(r,e){G((function(){n(r,e)}))};G((function(){a=n}));for(var f=r.length-22;101010256!=U(r,f);--f)if(!f||r.length-f>65558)return a(x(13,0,1),null),i;var c=V(r,f+8);if(c){var l=c,s=U(r,f+16),p=4294967295==s||65535==l;if(p){var y=U(r,f-12);(p=101075792==U(r,y))&&(l=c=U(r,y+32),s=U(r,y+48))}for(var m=e&&e.filter,v=function(e){var n=W(r,s,p),f=n[0],l=n[1],y=n[2],v=n[3],b=n[4],d=n[5],h=B(r,d);s=b;var g=function(r,e){r?(i(),a(r,null)):(e&&(u[v]=e),--c||a(null,u))};if(!m||m({name:v,size:l,originalSize:y,compression:f}))if(f)if(8==f){var w=r.subarray(h,h+l);if(y<524288||l>.8*y)try{g(null,$(w,{out:new t(y)}))}catch(r){g(r,null)}else o.push(function(r,e,t){return t||(t=e,e={}),"function"!=typeof t&&x(7),_(r,e,[M],(function(r){return C($(r.data[0],F(r.data[1])))}),1,t)}(w,{size:y},g))}else g(x(14,"unknown compression type "+f,1),null);else g(null,E(r,h,h+l));else g(null,null)},b=0;b<l;++b)v()}else a(null,{});return i}function J(r,e){return function(r){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},t=e.filter,n=arguments.length>2?arguments[2]:void 0;return n(new Uint8Array(r),{filter:function(r){return!t||t({path:r.name})}})}(r,e,K,!0)}function K(r){return new Promise((function(e,t){H(r,(function(r,n){r?t(r):e(n)}))}))}function Q(r){for(var e={},t=0,n=Object.keys(r);t<n.length;t++){var o=n[t];e[o]=q(r[o])}return e}function Y(r){var e=r.path;return e.endsWith(".xml")||e.endsWith(".xml.rels")}function Z(r){return J(r,{filter:Y}).then(Q)}function rr(r,e){for(var t=0;t<r.childNodes.length;){var n=r.childNodes[t];if(1===n.nodeType&&or(n)===e)return n;t++}}function er(r,e){for(var t=[],n=0;n<r.childNodes.length;){var o=r.childNodes[n];1===o.nodeType&&or(o)===e&&t.push(o),n++}return t}function tr(r,e,t){for(var n=0;n<r.childNodes.length;){var o=r.childNodes[n];e?1===o.nodeType&&or(o)===e&&t(o,n):t(o,n),n++}}var nr=/.+\:/;function or(r){return r.tagName.replace(nr,"")}function ir(r){for(var e=0;e<r.childNodes.length;){if(1===r.childNodes[e].nodeType)return r.childNodes[e];e++}}function ur(r){if(1!==r.nodeType)return r.textContent;for(var e="<"+or(r),t=0;t<r.attributes.length;)e+=" "+r.attributes[t].name+'="'+r.attributes[t].value+'"',t++;e+=">";for(var n=0;n<r.childNodes.length;)e+=ur(r.childNodes[n]),n++;return e+="</"+or(r)+">"}function ar(r){var e,t,n=r.documentElement;return e=function(r){var e=rr(r,"t");if(e)return e.textContent;var t="";return tr(r,"r",(function(r){t+=rr(r,"t").textContent})),t},t=[],tr(n,"si",(function(r,n){t.push(e(r,n))})),t}function fr(r,e){var t=e.createDocument(r),n={},o=rr(t.documentElement,"workbookPr");o&&"1"===o.getAttribute("date1904")&&(n.epoch1904=!0),n.sheets=[];return function(r){return er(rr(r.documentElement,"sheets"),"sheet")}(t).forEach((function(r){r.getAttribute("name")&&n.sheets.push({id:r.getAttribute("sheetId"),name:r.getAttribute("name"),relationId:r.getAttribute("r:id")})})),n}function cr(r,e){var t=e.createDocument(r),n={sheets:{},sharedStrings:void 0,styles:void 0};return function(r){return er(r.documentElement,"Relationship")}(t).forEach((function(r){var e=r.getAttribute("Target");switch(r.getAttribute("Type")){case"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles":n.styles=lr(e);break;case"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings":n.sharedStrings=lr(e);break;case"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet":n.sheets[r.getAttribute("Id")]=lr(e)}})),n}function lr(r){return"/"===r[0]?r.slice(1):"xl/"+r}function sr(r){return sr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},sr(r)}function pr(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function yr(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?pr(Object(t),!0).forEach((function(e){mr(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):pr(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function mr(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==sr(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==sr(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===sr(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function vr(r,e){if(!r)return{};var t,n,o=e.createDocument(r),i=(t=o,n=rr(t.documentElement,"cellStyleXfs"),n?er(n,"xf"):[]).map(dr),u=function(r){var e=rr(r.documentElement,"numFmts");return e?er(e,"numFmt"):[]}(o).map(br).reduce((function(r,e){return r[e.id]=e,r}),[]);return function(r){var e=rr(r.documentElement,"cellXfs");return e?er(e,"xf"):[]}(o).map((function(r){return r.hasAttribute("xfId")?yr(yr({},i[r.xfId]),dr(r,u)):dr(r,u)}))}function br(r){return{id:r.getAttribute("numFmtId"),template:r.getAttribute("formatCode")}}function dr(r,e){var t={};if(r.hasAttribute("numFmtId")){var n=r.getAttribute("numFmtId");e[n]?t.numberFormat=e[n]:t.numberFormat={id:n}}return t}function hr(r,e){e&&e.epoch1904&&(r+=1462);return new Date(Math.round(24*(r-25569)*36e5))}function gr(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return wr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return wr(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function wr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Or(r,e,t){if(r){var n=e[r];if(!n)throw new Error("Cell style not found: ".concat(r));if(!n.numberFormat)return!1;if(Sr.indexOf(Number(n.numberFormat.id))>=0||t.dateFormat&&n.numberFormat.template===t.dateFormat||!1!==t.smartDateParser&&n.numberFormat.template&&function(r){for(var e,t=gr((r=(r=(r=r.toLowerCase()).replace(jr,"")).replace(Ar,"")).split(/\W+/));!(e=t()).done;){var n=e.value;if(Er.indexOf(n)<0)return!1}return!0}(n.numberFormat.template))return!0}}var Sr=[14,15,16,17,18,19,20,21,22,27,30,36,45,46,47,50,57],jr=/^\[\$-414\]/,Ar=/;@$/;var Er=["ss","mm","h","hh","am","pm","d","dd","m","mm","mmm","mmmm","yy","yyyy","e"];function Pr(r,e,t){var n=t.getInlineStringValue,o=t.getInlineStringXml,i=t.getStyleId,u=t.styles,a=t.values,f=t.properties,c=t.options;switch(e||(e="n"),e){case"str":r=xr(r,c);break;case"inlineStr":if(void 0===(r=n()))throw new Error('Unsupported "inline string" cell value structure: '.concat(o()));r=xr(r,c);break;case"s":var l=Number(r);if(isNaN(l))throw new Error('Invalid "shared" string index: '.concat(r));if(l>=a.length)throw new Error('An out-of-bounds "shared" string index: '.concat(r));r=xr(r=a[l],c);break;case"b":if("1"===r)r=!0;else{if("0"!==r)throw new Error('Unsupported "boolean" cell value: '.concat(r));r=!1}break;case"z":r=void 0;break;case"e":r=function(r){switch(r){case 0:return"#NULL!";case 7:return"#DIV/0!";case 15:return"#VALUE!";case 23:return"#REF!";case 29:return"#NAME?";case 36:return"#NUM!";case 42:return"#N/A";case 43:return"#GETTING_DATA";default:return"#ERROR_".concat(r)}}(r);break;case"d":if(void 0===r)break;var s=new Date(r);if(isNaN(s.valueOf()))throw new Error('Unsupported "date" cell value: '.concat(r));r=s;break;case"n":if(void 0===r)break;r=Or(i(),u,c)?hr(r=Ir(r),f):(c.parseNumber||Ir)(r);break;default:throw new TypeError("Cell type not supported: ".concat(e))}return void 0===r&&(r=null),r}function xr(r,e){return!1!==e.trim&&(r=r.trim()),""===r&&(r=void 0),r}function Ir(r){var e=Number(r);if(isNaN(e))throw new Error('Invalid "numeric" cell value: '.concat(r));return e}var kr=["","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"];function Tr(r){for(var e=0,t=0;t<r.length;)e*=26,e+=kr.indexOf(r[t]),t++;return e}function Nr(r){return r=r.split(/(\d+)/),[parseInt(r[1]),Tr(r[0].trim())]}function Dr(r,e,t,n,o,i,u){var a,f=Nr(r.getAttribute("r")),c=function(r,e){return rr(e,"v")}(0,r),l=c&&c.textContent;return r.hasAttribute("t")&&(a=r.getAttribute("t")),{row:f[0],column:f[1],value:Pr(l,a,{getInlineStringValue:function(){return function(r,e){var t=ir(e);if(t&&"is"===or(t)){var n=ir(t);if(n&&"t"===or(n))return n.textContent}}(0,r)},getInlineStringXml:function(){return ur(r)},getStyleId:function(){return r.getAttribute("s")},styles:o,values:n,properties:i,options:u})}}function Mr(r,e,t,n,o,i){var u=function(r){var e=rr(r.documentElement,"sheetData"),t=[];return tr(e,"row",(function(r){tr(r,"c",(function(r){t.push(r)}))})),t}(r);return 0===u.length?[]:u.map((function(r){return Dr(r,0,0,t,n,o,i)}))}function Cr(r,e){return function(r){if(Array.isArray(r))return r}(r)||function(r,e){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var n,o,i,u,a=[],f=!0,c=!1;try{if(i=(t=t.call(r)).next,0===e){if(Object(t)!==t)return;f=!1}else for(;!(f=(n=i.call(t)).done)&&(a.push(n.value),a.length!==e);f=!0);}catch(r){c=!0,o=r}finally{try{if(!f&&null!=t.return&&(u=t.return(),Object(u)!==u))return}finally{if(c)throw o}}return a}}(r,e)||function(r,e){if(!r)return;if("string"==typeof r)return Fr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return Fr(r,e)}(r,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function Fr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function _r(r){var e=function(r){var e=rr(r.documentElement,"dimension");if(e)return e.getAttribute("ref")}(r);if(e)return 1===(e=e.split(":").map(Nr).map((function(r){var e=Cr(r,2);return{row:e[0],column:e[1]}}))).length&&(e=[e[0],e[0]]),e}function Vr(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return Ur(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return Ur(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Ur(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Rr(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return $r(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return $r(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function $r(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function zr(r,e){return function(r){if(Array.isArray(r))return r}(r)||function(r,e){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var n,o,i,u,a=[],f=!0,c=!1;try{if(i=(t=t.call(r)).next,0===e){if(Object(t)!==t)return;f=!1}else for(;!(f=(n=i.call(t)).done)&&(a.push(n.value),a.length!==e);f=!0);}catch(r){c=!0,o=r}finally{try{if(!f&&null!=t.return&&(u=t.return(),Object(u)!==u))return}finally{if(c)throw o}}return a}}(r,e)||Lr(r,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function Lr(r,e){if(r){if("string"==typeof r)return qr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?qr(r,e):void 0}}function qr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Br(r,e){var t=r.dimensions,n=r.cells;if(0===n.length)return[];var o=zr(t,2);o[0];for(var i=o[1],u=i.column,a=i.row,f=new Array(a),c=0;c<a;){f[c]=new Array(u);for(var l=0;l<u;)f[c][l]=null,l++;c++}for(var s,p=function(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=Lr(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(n);!(s=p()).done;){var y=s.value,m=y.row-1,v=y.column-1;v<u&&m<a&&(f[m][v]=y.value)}var b=e.rowIndexSourceMap;if(b)for(var d=0;d<f.length;)b[d]=d,d++;return f=function(r){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},t=e.rowIndexSourceMap,n=e.accessor,o=void 0===n?function(r){return r}:n,i=e.onlyTrimAtTheEnd,u=r.length-1;u>=0;){for(var a,f=!0,c=Vr(r[u]);!(a=c()).done;)if(null!==o(a.value)){f=!1;break}if(f)r.splice(u,1),t&&t.splice(u,1);else if(i)break;u--}return r}(function(r){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},t=e.accessor,n=void 0===t?function(r){return r}:t,o=e.onlyTrimAtTheEnd,i=r[0].length-1;i>=0;){for(var u,a=!0,f=Rr(r);!(u=f()).done;)if(null!==n(u.value[i])){a=!1;break}if(a)for(var c=0;c<r.length;)r[c].splice(i,1),c++;else if(o)break;i--}return r}(f,{onlyTrimAtTheEnd:!0}),{onlyTrimAtTheEnd:!0,rowIndexSourceMap:b}),e.transformData&&(f=e.transformData(f)),f}function Wr(r){return Wr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},Wr(r)}function Xr(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=function(r,e){if(!r)return;if("string"==typeof r)return Gr(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);"Object"===t&&r.constructor&&(t=r.constructor.name);if("Map"===t||"Set"===t)return Array.from(r);if("Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return Gr(r,e)}(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function Gr(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function Hr(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function Jr(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?Hr(Object(t),!0).forEach((function(e){Kr(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):Hr(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function Kr(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==Wr(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==Wr(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===Wr(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function Qr(r,e){var t=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};t.sheet||(t=Jr({sheet:1},t));var n=function(e){if(!r[e])throw new Error('"'.concat(e,'" file not found inside the *.xlsx file zip archive'));return r[e]},o=cr(n("xl/_rels/workbook.xml.rels"),e),i=o.sharedStrings?function(r,e){return r?ar(e.createDocument(r)):[]}(n(o.sharedStrings),e):[],u=o.styles?vr(n(o.styles),e):{},a=fr(n("xl/workbook.xml"),e);if(t.getSheets)return a.sheets.map((function(r){return{name:r.name}}));var f=function(r,e){if("number"==typeof r){var t=e[r-1];return t&&t.relationId}for(var n,o=Xr(e);!(n=o()).done;){var i=n.value;if(i.name===r)return i.relationId}}(t.sheet,a.sheets);if(!f||!o.sheets[f])throw function(r,e){var t=e&&e.map((function(r,e){return'"'.concat(r.name,'" (#').concat(e+1,")")})).join(", ");return new Error("Sheet ".concat("number"==typeof r?"#"+r:'"'+r+'"'," not found in the *.xlsx file.").concat(e?" Available sheets: "+t+".":""))}(t.sheet,a.sheets);var c=function(r,e,t,n,o,i){var u=e.createDocument(r),a=Mr(u,0,t,n,o,i),f=_r(u)||function(r){var e=function(r,e){return r-e},t=r.map((function(r){return r.row})).sort(e),n=r.map((function(r){return r.column})).sort(e),o=t[0],i=t[t.length-1];return[{row:o,column:n[0]},{row:i,column:n[n.length-1]}]}(a);return{cells:a,dimensions:f}}(n(o.sheets[f]),e,i,u,a,t),l=Br(c,t=Jr({rowIndexSourceMap:[]},t));return t.properties?{data:l,properties:a}:l}function Yr(r){return Yr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},Yr(r)}function Zr(r,e){for(var t=0;t<e.length;t++){var n=e[t];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(r,(o=n.key,i=void 0,i=function(r,e){if("object"!==Yr(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==Yr(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(o,"string"),"symbol"===Yr(i)?i:String(i)),n)}var o,i}function re(r){var e=ne();return function(){var t,n=ie(r);if(e){var o=ie(this).constructor;t=Reflect.construct(n,arguments,o)}else t=n.apply(this,arguments);return function(r,e){if(e&&("object"===Yr(e)||"function"==typeof e))return e;if(void 0!==e)throw new TypeError("Derived constructors may only return object or undefined");return function(r){if(void 0===r)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return r}(r)}(this,t)}}function ee(r){var e="function"==typeof Map?new Map:void 0;return ee=function(r){if(null===r||(t=r,-1===Function.toString.call(t).indexOf("[native code]")))return r;var t;if("function"!=typeof r)throw new TypeError("Super expression must either be null or a function");if(void 0!==e){if(e.has(r))return e.get(r);e.set(r,n)}function n(){return te(r,arguments,ie(this).constructor)}return n.prototype=Object.create(r.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),oe(n,r)},ee(r)}function te(r,e,t){return te=ne()?Reflect.construct.bind():function(r,e,t){var n=[null];n.push.apply(n,e);var o=new(Function.bind.apply(r,n));return t&&oe(o,t.prototype),o},te.apply(null,arguments)}function ne(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(r){return!1}}function oe(r,e){return oe=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(r,e){return r.__proto__=e,r},oe(r,e)}function ie(r){return ie=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(r){return r.__proto__||Object.getPrototypeOf(r)},ie(r)}var ue=function(r){!function(r,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");r.prototype=Object.create(e&&e.prototype,{constructor:{value:r,writable:!0,configurable:!0}}),Object.defineProperty(r,"prototype",{writable:!1}),e&&oe(r,e)}(i,r);var e,t,n,o=re(i);function i(r){var e;return function(r,e){if(!(r instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),(e=o.call(this,"invalid")).reason=r,e}return e=i,t&&Zr(e.prototype,t),n&&Zr(e,n),Object.defineProperty(e,"prototype",{writable:!1}),e}(ee(Error));function ae(r){if("string"==typeof r){var e=r;if(r=Number(r),String(r)!==e)throw new ue("not_a_number")}if("number"!=typeof r)throw new ue("not_a_number");if(isNaN(r))throw new ue("invalid_number");if(!isFinite(r))throw new ue("out_of_bounds");return r}function fe(r){if("string"==typeof r)return r;if("number"==typeof r){if(isNaN(r))throw new ue("invalid_number");if(!isFinite(r))throw new ue("out_of_bounds");return String(r)}throw new ue("not_a_string")}function ce(r){if("boolean"==typeof r)return r;throw new ue("not_a_boolean")}var le=["isColumnOriented","ignoreEmptyRows","rowIndexSourceMap"];function se(r){return se="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},se(r)}function pe(r,e){return function(r){if(Array.isArray(r))return r}(r)||function(r,e){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var n,o,i,u,a=[],f=!0,c=!1;try{if(i=(t=t.call(r)).next,0===e){if(Object(t)!==t)return;f=!1}else for(;!(f=(n=i.call(t)).done)&&(a.push(n.value),a.length!==e);f=!0);}catch(r){c=!0,o=r}finally{try{if(!f&&null!=t.return&&(u=t.return(),Object(u)!==u))return}finally{if(c)throw o}}return a}}(r,e)||ye(r,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function ye(r,e){if(r){if("string"==typeof r)return me(r,e);var t=Object.prototype.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?me(r,e):void 0}}function me(r,e){(null==e||e>r.length)&&(e=r.length);for(var t=0,n=new Array(e);t<e;t++)n[t]=r[t];return n}function ve(r,e){if(null==r)return{};var t,n,o=function(r,e){if(null==r)return{};var t,n,o={},i=Object.keys(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||(o[t]=r[t]);return o}(r,e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||Object.prototype.propertyIsEnumerable.call(r,t)&&(o[t]=r[t])}return o}function be(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function de(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?be(Object(t),!0).forEach((function(e){he(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):be(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function he(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==se(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==se(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===se(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}var ge={schemaPropertyValueForMissingColumn:void 0,schemaPropertyValueForMissingValue:null,schemaPropertyShouldSkipRequiredValidationForMissingColumn:function(){return!1},getEmptyObjectValue:function(){return null},getEmptyArrayValue:function(){return null},isColumnOriented:!1,ignoreEmptyRows:!0,arrayValueSeparator:","};function we(r,e,t){var n=t=t?de(de({},ge),t):ge,o=n.isColumnOriented,i=n.ignoreEmptyRows,u=n.rowIndexSourceMap,a=ve(n,le),f=u&&u.slice();!function(r){for(var e=0,t=Object.keys(r);e<t.length;e++){var n=t[e],o=r[n];if("object"===se(o.type)&&!Array.isArray(o.type))throw new Error("When defining a nested schema, use a `schema` property instead of a `type` property");if(!o.schema&&!o.column)throw new Error('"column" not defined for schema entry "'.concat(n,'".'))}}(e),o&&(r=Ee(r)),i&&(r=r.filter((function(r,e){return!r.every((function(r){return null===r}))||(f&&f.splice(e,1),!1)})));for(var c=r[0],l=[],s=[],p=1;p<r.length;p++){var y=Oe(e,r[p],p,void 0,c,s,a);l.push(y)}if(f)for(var m,v=function(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(t)return(t=t.call(r)).next.bind(t);if(Array.isArray(r)||(t=ye(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var n=0;return function(){return n>=r.length?{done:!0}:{done:!1,value:r[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(s);!(m=v()).done;){var b=m.value;b.row=f[b.row-1]+1}return{rows:l,errors:s}}function Oe(r,e,t,n,o,i,u){for(var a={},f=!0,c=function(r){var e=r.schemaEntry,n=r.value,o=r.error,i=r.reason,u={error:o,row:t+1,column:e.column,value:n};return i&&(u.reason=i),e.type&&(u.type=e.type),u},l=[],s=function(){var s,m,v,b,d=y[p],h=r[d],g=d,w=h.column,O="".concat(n||"",".").concat(g),S=o.indexOf(w),j=S<0;if(j||(s=e[S]),h.schema)m=Oe(h.schema,e,t,O,o,i,u);else if(j)"schemaPropertyValueForMissingColumn"in u&&(m=u.schemaPropertyValueForMissingColumn);else if(void 0===s)"schemaPropertyValueForMissingValue"in u&&(m=u.schemaPropertyValueForMissingValue);else if(null===s)"schemaPropertyValueForMissingValue"in u&&(m=u.schemaPropertyValueForMissingValue);else if(Array.isArray(h.type)){var A=function(r,e){var t=[],n=0;for(;n<r.length;){var o=pe(Ae(r,e,n),2),i=o[0];n+=o[1]+e.length,t.push(i.trim())}return t}(s,u.arrayValueSeparator).map((function(r){if(!v){var e=Se(r,h,u);return e.error&&(m=r,v=e.error,b=e.reason),e.value}}));if(!v){var E=A.every(Pe);m=E?u.getEmptyArrayValue(A,{path:O}):A}}else{var P=Se(s,h,u);v=P.error,b=P.reason,m=v?s:P.value}!v&&Pe(m)&&h.required&&l.push({schemaEntry:h,value:m,isMissingColumn:j}),v?i.push(c({schemaEntry:h,value:m,error:v,reason:b})):(f&&!Pe(m)&&(f=!1),void 0!==m&&(a[g]=m))},p=0,y=Object.keys(r);p<y.length;p++)s();if(f)return u.getEmptyObjectValue(a,{path:n});for(var m=0,v=l;m<v.length;m++){var b=v[m],d=b.schemaEntry,h=b.value;if(!(b.isMissingColumn&&u.schemaPropertyShouldSkipRequiredValidationForMissingColumn(d.column,{object:a}))){var g=d.required;("boolean"==typeof g?g:g(a))&&i.push(c({schemaEntry:d,value:h,error:"required"}))}}return a}function Se(r,e,t){if(null===r)return{value:null};var n;if(e.parse)throw new Error("`schemaEntry.parse` property was renamed to `schemaEntry.type`");if(n=e.type?function(r,e,t){switch(e){case String:return je(r,fe);case Number:return je(r,ae);case Date:return je(r,(function(r){return function(r,e){var t=e.properties;if(r instanceof Date){if(isNaN(r.valueOf()))throw new ue("out_of_bounds");return r}if("number"==typeof r){if(isNaN(r))throw new ue("invalid_number");if(!isFinite(r))throw new ue("out_of_bounds");var n=hr(r,t);if(isNaN(n.valueOf()))throw new ue("out_of_bounds");return n}throw new ue("not_a_date")}(r,{properties:t.properties})}));case Boolean:return je(r,ce);default:if("function"==typeof e)return je(r,e);throw new Error("Unsupported schema type: ".concat(e&&e.name||e))}}(r,Array.isArray(e.type)?e.type[0]:e.type,t):{value:r},n.error)return n;if(null!==n.value){if(e.oneOf&&e.oneOf.indexOf(n.value)<0)return{error:"invalid",reason:"unknown"};if(e.validate)try{e.validate(n.value)}catch(r){return{error:r.message}}}return n}function je(r,e){try{var t=e(r);return void 0===t?{value:null}:{value:t}}catch(r){var n={error:r.message};return r.reason&&(n.reason=r.reason),n}}function Ae(r,e,t){for(var n=0,o="";t+n<r.length;){var i=r[t+n];if(i===e)return[o,n];if('"'===i){var u=Ae(r,'"',t+n+1);o+=u[0],n+=1+u[1]+1}else o+=i,n++}return[o,n]}var Ee=function(r){return r[0].map((function(e,t){return r.map((function(r){return r[t]}))}))};function Pe(r){return null==r}function xe(r){return xe="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(r){return typeof r}:function(r){return r&&"function"==typeof Symbol&&r.constructor===Symbol&&r!==Symbol.prototype?"symbol":typeof r},xe(r)}var Ie=["schema"];function ke(r,e){var t=Object.keys(r);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(r);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),t.push.apply(t,n)}return t}function Te(r){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{};e%2?ke(Object(t),!0).forEach((function(e){Ne(r,e,t[e])})):Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(t)):ke(Object(t)).forEach((function(e){Object.defineProperty(r,e,Object.getOwnPropertyDescriptor(t,e))}))}return r}function Ne(r,e,t){return(e=function(r){var e=function(r,e){if("object"!==xe(r)||null===r)return r;var t=r[Symbol.toPrimitive];if(void 0!==t){var n=t.call(r,e||"default");if("object"!==xe(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(r)}(r,"string");return"symbol"===xe(e)?e:String(e)}(e))in r?Object.defineProperty(r,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):r[e]=t,r}function De(r,e){if(null==r)return{};var t,n,o=function(r,e){if(null==r)return{};var t,n,o={},i=Object.keys(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||(o[t]=r[t]);return o}(r,e);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(r);for(n=0;n<i.length;n++)t=i[n],e.indexOf(t)>=0||Object.prototype.propertyIsEnumerable.call(r,t)&&(o[t]=r[t])}return o}return function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return function(r){return r instanceof File||r instanceof Blob?r.arrayBuffer().then(Z):Promise.resolve(r).then(Z)}(e).then((function(e){return function(r,e,t){var n=t.schema,o=De(t,Ie);if(o.map)throw new Error("`map` option was removed. Pass a `schema` option instead.");var i=Qr(r,e,Te(Te({},o),{},{properties:n||o.properties}));return n?we(i.data,n,Te(Te({},o),{},{properties:i.properties})):i}(e,r,t)}))}}));
2
2
  //# sourceMappingURL=read-excel-file.min.js.map