@cloudparker/moldex.js 4.1.7 → 4.1.8

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 (220) hide show
  1. package/dist/actions/badge.d.ts +12 -0
  2. package/dist/actions/badge.js +22 -0
  3. package/dist/actions/index.d.ts +3 -0
  4. package/dist/actions/index.js +3 -0
  5. package/dist/actions/no-context-menu.d.ts +3 -0
  6. package/dist/actions/no-context-menu.js +11 -0
  7. package/dist/actions/ripple.css +29 -0
  8. package/dist/actions/ripple.d.ts +7 -0
  9. package/dist/actions/ripple.js +74 -0
  10. package/dist/index.d.ts +3 -0
  11. package/dist/index.js +3 -0
  12. package/dist/services/date/date-service.d.ts +52 -0
  13. package/dist/services/date/date-service.js +206 -0
  14. package/dist/services/dialog/dialog-service.d.ts +96 -0
  15. package/dist/services/dialog/dialog-service.js +350 -0
  16. package/dist/services/index.d.ts +12 -0
  17. package/dist/services/index.js +12 -0
  18. package/dist/services/navigation/navigation-service.d.ts +39 -0
  19. package/dist/services/navigation/navigation-service.js +100 -0
  20. package/dist/services/screen/screen-service.d.ts +17 -0
  21. package/dist/services/screen/screen-service.js +39 -0
  22. package/dist/services/toast/toast-service.d.ts +5 -0
  23. package/dist/services/toast/toast-service.js +26 -0
  24. package/dist/services/utils/color-service.d.ts +46 -0
  25. package/dist/services/utils/color-service.js +73 -0
  26. package/dist/services/utils/currency-service.d.ts +91 -0
  27. package/dist/services/utils/currency-service.js +140 -0
  28. package/dist/services/utils/download-service.d.ts +91 -0
  29. package/dist/services/utils/download-service.js +159 -0
  30. package/dist/services/utils/file-service.d.ts +140 -0
  31. package/dist/services/utils/file-service.js +301 -0
  32. package/dist/services/utils/http-service.d.ts +77 -0
  33. package/dist/services/utils/http-service.js +158 -0
  34. package/dist/services/utils/image-service.d.ts +107 -0
  35. package/dist/services/utils/image-service.js +260 -0
  36. package/dist/services/utils/melody-service.d.ts +5 -0
  37. package/dist/services/utils/melody-service.js +41 -0
  38. package/dist/services/utils/utils-service.d.ts +260 -0
  39. package/dist/services/utils/utils-service.js +413 -0
  40. package/dist/stores/referrer-store/referrer-store.svelte.d.ts +3 -0
  41. package/dist/stores/referrer-store/referrer-store.svelte.js +11 -0
  42. package/dist/stores/screen-size/screen-size-store.svelte.d.ts +18 -0
  43. package/dist/stores/screen-size/screen-size-store.svelte.js +41 -0
  44. package/dist/types.d.ts +6 -0
  45. package/dist/types.js +7 -0
  46. package/dist/views/core/button/components/button/button.svelte +161 -0
  47. package/dist/views/core/button/components/button/button.svelte.d.ts +4 -0
  48. package/dist/views/core/button/components/button-back/button-back.svelte +46 -0
  49. package/dist/views/core/button/components/button-back/button-back.svelte.d.ts +11 -0
  50. package/dist/views/core/button/components/button-close/button-close.svelte +8 -0
  51. package/dist/views/core/button/components/button-close/button-close.svelte.d.ts +4 -0
  52. package/dist/views/core/button/components/button-close-icon/button-close-icon.svelte +47 -0
  53. package/dist/views/core/button/components/button-close-icon/button-close-icon.svelte.d.ts +11 -0
  54. package/dist/views/core/button/components/button-dropdown/button-dropdown.svelte +149 -0
  55. package/dist/views/core/button/components/button-dropdown/button-dropdown.svelte.d.ts +24 -0
  56. package/dist/views/core/button/components/button-list-item/button-list-item.svelte +136 -0
  57. package/dist/views/core/button/components/button-list-item/button-list-item.svelte.d.ts +4 -0
  58. package/dist/views/core/button/components/button-menu/button-menu.svelte +105 -0
  59. package/dist/views/core/button/components/button-menu/button-menu.svelte.d.ts +21 -0
  60. package/dist/views/core/button/components/button-ok/button-ok.svelte +9 -0
  61. package/dist/views/core/button/components/button-ok/button-ok.svelte.d.ts +4 -0
  62. package/dist/views/core/button/components/button-search/button-search.svelte +72 -0
  63. package/dist/views/core/button/components/button-search/button-search.svelte.d.ts +21 -0
  64. package/dist/views/core/button/components/switch/switch.svelte +62 -0
  65. package/dist/views/core/button/components/switch/switch.svelte.d.ts +4 -0
  66. package/dist/views/core/button/index.d.ts +12 -0
  67. package/dist/views/core/button/index.js +12 -0
  68. package/dist/views/core/button/types.d.ts +100 -0
  69. package/dist/views/core/button/types.js +1 -0
  70. package/dist/views/core/common/components/content-area/content-area.svelte +47 -0
  71. package/dist/views/core/common/components/content-area/content-area.svelte.d.ts +12 -0
  72. package/dist/views/core/common/components/loading/loading.svelte +14 -0
  73. package/dist/views/core/common/components/loading/loading.svelte.d.ts +7 -0
  74. package/dist/views/core/common/components/virtual-scrolling/virtual-scrolling-list.svelte +60 -0
  75. package/dist/views/core/common/components/virtual-scrolling/virtual-scrolling-list.svelte.d.ts +11 -0
  76. package/dist/views/core/common/index.js +9 -0
  77. package/dist/views/core/dialog/components/cropper-dialog/cropper-dialog.svelte +51 -0
  78. package/dist/views/core/dialog/components/cropper-dialog/cropper-dialog.svelte.d.ts +5 -0
  79. package/dist/views/core/dialog/components/dialog/dialog.svelte +370 -0
  80. package/dist/views/core/dialog/components/dialog/dialog.svelte.d.ts +19 -0
  81. package/dist/views/core/dialog/components/loading-dialog/loading-dialog.svelte +42 -0
  82. package/dist/views/core/dialog/components/loading-dialog/loading-dialog.svelte.d.ts +12 -0
  83. package/dist/views/core/dialog/components/msg-dialog/msg-dialog.svelte +22 -0
  84. package/dist/views/core/dialog/components/msg-dialog/msg-dialog.svelte.d.ts +9 -0
  85. package/dist/views/core/dialog/components/number-field-dialog/number-field-dialog.svelte +57 -0
  86. package/dist/views/core/dialog/components/number-field-dialog/number-field-dialog.svelte.d.ts +14 -0
  87. package/dist/views/core/dialog/components/picker-dialog/picker-dialog.svelte +181 -0
  88. package/dist/views/core/dialog/components/picker-dialog/picker-dialog.svelte.d.ts +5 -0
  89. package/dist/views/core/dialog/components/text-field-dialog/text-field-dialog.svelte +56 -0
  90. package/dist/views/core/dialog/components/text-field-dialog/text-field-dialog.svelte.d.ts +15 -0
  91. package/dist/views/core/dialog/components/textarea-field-dialog/textarea-field-dialog.svelte +56 -0
  92. package/dist/views/core/dialog/components/textarea-field-dialog/textarea-field-dialog.svelte.d.ts +15 -0
  93. package/dist/views/core/dialog/index.d.ts +9 -0
  94. package/dist/views/core/dialog/index.js +9 -0
  95. package/dist/views/core/dialog/types.d.ts +105 -0
  96. package/dist/views/core/dialog/types.js +1 -0
  97. package/dist/views/core/drawer/components/drawer/drawer.svelte +110 -0
  98. package/dist/views/core/drawer/components/drawer/drawer.svelte.d.ts +19 -0
  99. package/dist/views/core/drawer/index.d.ts +2 -0
  100. package/dist/views/core/drawer/index.js +2 -0
  101. package/dist/views/core/icon/components/icon/icon.svelte +27 -0
  102. package/dist/views/core/icon/components/icon/icon.svelte.d.ts +12 -0
  103. package/dist/views/core/icon/components/icon-circle/icon-circle.svelte +17 -0
  104. package/dist/views/core/icon/components/icon-circle/icon-circle.svelte.d.ts +8 -0
  105. package/dist/views/core/icon/index.d.ts +4 -0
  106. package/dist/views/core/icon/index.js +4 -0
  107. package/dist/views/core/icon/services/icon-path-service.d.ts +23 -0
  108. package/dist/views/core/icon/services/icon-path-service.js +24 -0
  109. package/dist/views/core/index.d.ts +16 -0
  110. package/dist/views/core/index.js +16 -0
  111. package/dist/views/core/input/components/checkbox-field/checkbox-field.svelte +83 -0
  112. package/dist/views/core/input/components/checkbox-field/checkbox-field.svelte.d.ts +19 -0
  113. package/dist/views/core/input/components/color-field/color-field.svelte +135 -0
  114. package/dist/views/core/input/components/color-field/color-field.svelte.d.ts +11 -0
  115. package/dist/views/core/input/components/combobox-field/combobox-field.svelte +492 -0
  116. package/dist/views/core/input/components/combobox-field/combobox-field.svelte.d.ts +7 -0
  117. package/dist/views/core/input/components/date-field/date-field.svelte +40 -0
  118. package/dist/views/core/input/components/date-field/date-field.svelte.d.ts +11 -0
  119. package/dist/views/core/input/components/datetime-field/datetime-field.svelte +22 -0
  120. package/dist/views/core/input/components/datetime-field/datetime-field.svelte.d.ts +8 -0
  121. package/dist/views/core/input/components/email-field/email-field.svelte +27 -0
  122. package/dist/views/core/input/components/email-field/email-field.svelte.d.ts +8 -0
  123. package/dist/views/core/input/components/file-field/file-field.svelte +106 -0
  124. package/dist/views/core/input/components/file-field/file-field.svelte.d.ts +13 -0
  125. package/dist/views/core/input/components/input-field/input-field.svelte +336 -0
  126. package/dist/views/core/input/components/input-field/input-field.svelte.d.ts +9 -0
  127. package/dist/views/core/input/components/label/label.svelte +48 -0
  128. package/dist/views/core/input/components/label/label.svelte.d.ts +14 -0
  129. package/dist/views/core/input/components/number-field/number-field.svelte +22 -0
  130. package/dist/views/core/input/components/number-field/number-field.svelte.d.ts +8 -0
  131. package/dist/views/core/input/components/password-field/password-field.svelte +100 -0
  132. package/dist/views/core/input/components/password-field/password-field.svelte.d.ts +12 -0
  133. package/dist/views/core/input/components/phone-field/phone-field.svelte +187 -0
  134. package/dist/views/core/input/components/phone-field/phone-field.svelte.d.ts +12 -0
  135. package/dist/views/core/input/components/radio-field/radio-field.svelte +127 -0
  136. package/dist/views/core/input/components/radio-field/radio-field.svelte.d.ts +4 -0
  137. package/dist/views/core/input/components/range-field/range-field.svelte +120 -0
  138. package/dist/views/core/input/components/range-field/range-field.svelte.d.ts +23 -0
  139. package/dist/views/core/input/components/search-field/search-field.svelte +80 -0
  140. package/dist/views/core/input/components/search-field/search-field.svelte.d.ts +12 -0
  141. package/dist/views/core/input/components/text-field/text-field.svelte +31 -0
  142. package/dist/views/core/input/components/text-field/text-field.svelte.d.ts +11 -0
  143. package/dist/views/core/input/components/textarea-field/textarea-field.svelte +27 -0
  144. package/dist/views/core/input/components/textarea-field/textarea-field.svelte.d.ts +8 -0
  145. package/dist/views/core/input/components/time-field/time-field.svelte +21 -0
  146. package/dist/views/core/input/components/time-field/time-field.svelte.d.ts +8 -0
  147. package/dist/views/core/input/index.d.ts +20 -0
  148. package/dist/views/core/input/index.js +20 -0
  149. package/dist/views/core/input/types.d.ts +159 -0
  150. package/dist/views/core/input/types.js +1 -0
  151. package/dist/views/core/navbar/components/navbar/navbar.svelte +133 -0
  152. package/dist/views/core/navbar/components/navbar/navbar.svelte.d.ts +4 -0
  153. package/dist/views/core/navbar/index.d.ts +2 -0
  154. package/dist/views/core/navbar/index.js +2 -0
  155. package/dist/views/core/navbar/types.d.ts +35 -0
  156. package/dist/views/core/navbar/types.js +1 -0
  157. package/dist/views/core/no-data/components/no-data/no-data.svelte +47 -0
  158. package/dist/views/core/no-data/components/no-data/no-data.svelte.d.ts +13 -0
  159. package/dist/views/core/no-data/index.d.ts +2 -0
  160. package/dist/views/core/no-data/index.js +2 -0
  161. package/dist/views/core/pagination/components/pagination/pagination.svelte +151 -0
  162. package/dist/views/core/pagination/components/pagination/pagination.svelte.d.ts +16 -0
  163. package/dist/views/core/pagination/index.d.ts +2 -0
  164. package/dist/views/core/pagination/index.js +2 -0
  165. package/dist/views/core/progressbar/components/progressbar/progressbar.svelte +55 -0
  166. package/dist/views/core/progressbar/components/progressbar/progressbar.svelte.d.ts +11 -0
  167. package/dist/views/core/progressbar/index.d.ts +2 -0
  168. package/dist/views/core/progressbar/index.js +2 -0
  169. package/dist/views/core/ruler/components/vertical-ruler/verticcal-ruler.svelte +8 -0
  170. package/dist/views/core/ruler/components/vertical-ruler/verticcal-ruler.svelte.d.ts +6 -0
  171. package/dist/views/core/ruler/index.d.ts +2 -0
  172. package/dist/views/core/ruler/index.js +2 -0
  173. package/dist/views/core/screen-detector/components/screen-detector.svelte +17 -0
  174. package/dist/views/core/screen-detector/components/screen-detector.svelte.d.ts +3 -0
  175. package/dist/views/core/screen-detector/index.d.ts +2 -0
  176. package/dist/views/core/screen-detector/index.js +2 -0
  177. package/dist/views/core/sidebar/components/sidebar.svelte +49 -0
  178. package/dist/views/core/sidebar/components/sidebar.svelte.d.ts +12 -0
  179. package/dist/views/core/sidebar/index.js +5 -0
  180. package/dist/views/core/spinner/components/spinner/spinner.svelte +21 -0
  181. package/dist/views/core/spinner/components/spinner/spinner.svelte.d.ts +6 -0
  182. package/dist/views/core/spinner/index.d.ts +2 -0
  183. package/dist/views/core/spinner/index.js +2 -0
  184. package/dist/views/core/text/components/text-await/text-await.svelte +23 -0
  185. package/dist/views/core/text/components/text-await/text-await.svelte.d.ts +10 -0
  186. package/dist/views/core/text/components/text-copy/text-copy.svelte +40 -0
  187. package/dist/views/core/text/components/text-copy/text-copy.svelte.d.ts +10 -0
  188. package/dist/views/core/text/components/text-currency/text-currency.svelte +24 -0
  189. package/dist/views/core/text/components/text-currency/text-currency.svelte.d.ts +11 -0
  190. package/dist/views/core/text/components/text-date/text-date.svelte +40 -0
  191. package/dist/views/core/text/components/text-date/text-date.svelte.d.ts +10 -0
  192. package/dist/views/core/text/components/text-email/text-email.svelte +22 -0
  193. package/dist/views/core/text/components/text-email/text-email.svelte.d.ts +9 -0
  194. package/dist/views/core/text/components/text-html/text-html.svelte +7 -0
  195. package/dist/views/core/text/components/text-html/text-html.svelte.d.ts +6 -0
  196. package/dist/views/core/text/components/text-phone/text-phone.svelte +25 -0
  197. package/dist/views/core/text/components/text-phone/text-phone.svelte.d.ts +9 -0
  198. package/dist/views/core/text/index.d.ts +8 -0
  199. package/dist/views/core/text/index.js +8 -0
  200. package/dist/views/core/toast/components/toast/toast.svelte +46 -0
  201. package/dist/views/core/toast/components/toast/toast.svelte.d.ts +7 -0
  202. package/dist/views/core/toast/index.d.ts +3 -0
  203. package/dist/views/core/toast/index.js +3 -0
  204. package/dist/views/core/toast/types.d.ts +8 -0
  205. package/dist/views/core/toast/types.js +1 -0
  206. package/dist/views/extra/fields/country-combobox-field.svelte +42 -0
  207. package/dist/views/extra/fields/country-combobox-field.svelte.d.ts +8 -0
  208. package/dist/views/extra/index.d.ts +6 -0
  209. package/dist/views/extra/index.js +6 -0
  210. package/dist/views/extra/loaders/country-loader.svelte +38 -0
  211. package/dist/views/extra/loaders/country-loader.svelte.d.ts +12 -0
  212. package/dist/views/extra/texts/text-country-state.svelte +48 -0
  213. package/dist/views/extra/texts/text-country-state.svelte.d.ts +6 -0
  214. package/dist/views/extra/texts/text-country.svelte +22 -0
  215. package/dist/views/extra/texts/text-country.svelte.d.ts +6 -0
  216. package/dist/views/extra/types.d.ts +5 -0
  217. package/dist/views/extra/types.js +1 -0
  218. package/dist/views/index.d.ts +2 -0
  219. package/dist/views/index.js +2 -0
  220. package/package.json +2 -1
@@ -0,0 +1,140 @@
1
+ export declare const FILE_EXTENTIONS: string[];
2
+ export declare const FILE_VIEWER_HOST = "https://viewer.cloudparker.com";
3
+ /**
4
+ * Reads a file as a data URL.
5
+ * @param file - The file to read.
6
+ * @returns A promise that resolves to a data URL string.
7
+ */
8
+ export declare function readFileAsDataURL(file: File): Promise<string>;
9
+ /**
10
+ * Reads the contents of a given File object as a text string.
11
+ *
12
+ * This function uses the FileReader API to read the file content and returns it as a string.
13
+ *
14
+ * @param file - The File object to be read.
15
+ * @returns A promise that resolves to the text content of the file as a string.
16
+ *
17
+ * @throws An error if the file could not be read.
18
+ *
19
+ * @example
20
+ * // Create a file and read its content as text
21
+ * const myFile = new File(['Hello, world!'], 'example.txt', { type: 'text/plain' });
22
+ * readFileAsText(myFile).then((text) => {
23
+ * console.log(text); // Output: "Hello, world!"
24
+ * });
25
+ */
26
+ export declare function readFileAsText(file: File): Promise<string>;
27
+ /**
28
+ * Reads the contents of a given File object as an ArrayBuffer.
29
+ *
30
+ * This function uses the FileReader API to read the file content as a binary ArrayBuffer.
31
+ *
32
+ * @param file - The File object to be read.
33
+ * @returns A promise that resolves to the binary content of the file as an ArrayBuffer.
34
+ *
35
+ * @throws An error if the file could not be read.
36
+ *
37
+ * @example
38
+ * // Create a file and read its content as an ArrayBuffer
39
+ * const myFile = new File(['Hello, world!'], 'example.txt', { type: 'text/plain' });
40
+ * readFileAsBuffer(myFile).then((buffer) => {
41
+ * console.log(buffer); // Output: ArrayBuffer { ... }
42
+ * });
43
+ */
44
+ export declare function readFileAsBuffer(file: File): Promise<ArrayBuffer>;
45
+ /**
46
+ * Converts a given URL to a File object by downloading the content from the URL.
47
+ *
48
+ * This function fetches the file content from the provided URL and converts it into a File object.
49
+ * It attempts to extract the filename and MIME type from the HTTP headers. If these are not available,
50
+ * it falls back to using the provided filename and MIME type or extracts the filename from the URL.
51
+ *
52
+ * @param url - The URL to download the file from.
53
+ * @param givenFileName - Optional. The fallback name for the file if no name can be extracted from the URL or headers.
54
+ * @param givenMimeType - Optional. The fallback MIME type for the file if no MIME type is available in the headers.
55
+ * @returns A promise that resolves to a File object containing the downloaded content.
56
+ *
57
+ * @throws An error if the download fails or the file cannot be converted.
58
+ *
59
+ * @example
60
+ * // Convert an image URL to a File object and log its properties
61
+ * readUrlAsFile('https://example.com/image.png', 'downloaded-image.png', 'image/png')
62
+ * .then((file) => {
63
+ * console.log(file.name); // Output: "downloaded-image.png"
64
+ * console.log(file.type); // Output: "image/png"
65
+ * })
66
+ * .catch((error) => console.error('Error converting URL to file:', error.message));
67
+ */
68
+ export declare function readUrlAsFile(url: string, givenFileName?: string, givenMimeType?: string): Promise<File>;
69
+ /**
70
+ * Converts a given Data URL (Base64 or Data URL format) to a File object.
71
+ *
72
+ * @param dataUrl - The Data URL string to convert into a File object.
73
+ * @param fileName - Optional. The name for the created file.
74
+ * @param mimeType - Optional. The MIME type of the file. If not provided, it will be extracted from the Data URL.
75
+ * @returns A promise that resolves to a File object containing the content of the Data URL.
76
+ *
77
+ * @example
78
+ * // Convert a Base64 string to a File object
79
+ * const base64String = '...';
80
+ * readDataUrlAsFile(base64String, 'example.png', 'image/png')
81
+ * .then((file) => {
82
+ * console.log(file.name); // Output: "example.png"
83
+ * console.log(file.type); // Output: "image/png"
84
+ * });
85
+ */
86
+ export declare function readDataUrlAsFile(dataUrl: string, fileName?: string, mimeType?: string): Promise<File>;
87
+ /**
88
+ * Converts a given ArrayBuffer to a File object.
89
+ *
90
+ * This function wraps an ArrayBuffer in a File object with the provided filename and MIME type.
91
+ *
92
+ * @param buffer - The ArrayBuffer containing the file data.
93
+ * @param fileName - The name for the created file.
94
+ * @param mimeType - The MIME type for the created file.
95
+ * @returns A promise that resolves to a File object created from the ArrayBuffer.
96
+ *
97
+ * @example
98
+ * // Convert an ArrayBuffer to a File object
99
+ * const buffer = new ArrayBuffer(8);
100
+ * convertBufferToFile(buffer, 'example.bin', 'application/octet-stream').then((file) => {
101
+ * console.log(file.name); // Output: "example.bin"
102
+ * console.log(file.type); // Output: "application/octet-stream"
103
+ * });
104
+ */
105
+ export declare function convertBufferToFile(buffer: ArrayBuffer, fileName: string, mimeType: string): Promise<File>;
106
+ /**
107
+ * Extracts the filename and extension from a given filename string.
108
+ *
109
+ * This function splits a filename into its base name and extension parts.
110
+ * If no extension is present, the extension will be `undefined`.
111
+ *
112
+ * @param filename - The filename string to be processed.
113
+ * @returns An object containing the base name and extension of the filename.
114
+ *
115
+ * @example
116
+ * // Extract filename and extension
117
+ * const { name, ext } = getFilenameExtension('example.txt');
118
+ * console.log(name); // Output: "example"
119
+ * console.log(ext); // Output: "txt"
120
+ */
121
+ export declare function getFilenameExtension(filename: string): {
122
+ name: string;
123
+ ext: string | undefined;
124
+ };
125
+ /**
126
+ * Converts a file size in bytes to a human-readable string.
127
+ *
128
+ * This function converts a file size in bytes to a string representation with appropriate units
129
+ * (e.g., B, kB, MB, GB, TB) based on the size.
130
+ *
131
+ * @param size - The file size in bytes.
132
+ * @returns A human-readable string representing the file size.
133
+ *
134
+ * @example
135
+ * const sizeString = fileSizeString(1024);
136
+ * console.log(sizeString); // Output: "1 kB"
137
+ */
138
+ export declare function formatFileSize(bytes?: number): string;
139
+ export declare function getExtFromFileType(type: string): string | null;
140
+ export declare function ellipsisFileNameAtCenter(name: string, sizeLimit?: number, startLength?: number, endLength?: number): string;
@@ -0,0 +1,301 @@
1
+ export const FILE_EXTENTIONS = [
2
+ "java", "js", "ts", "json", "c", "cpp", "cs", "py", "ts", "php", "rb", "swift", "go",
3
+ "rs", "kt", "scala", "pl", "lua", "hs", "sh", "ps1", "dart", "jl", "m", "f90", "txt",
4
+ "r", "groovy", "asm", "pas", "ada", "sql", "md", "html", "css", "xml", "yaml", "xml",
5
+ "bat",
6
+ ];
7
+ export const FILE_VIEWER_HOST = 'https://viewer.cloudparker.com';
8
+ /**
9
+ * Reads a file as a data URL.
10
+ * @param file - The file to read.
11
+ * @returns A promise that resolves to a data URL string.
12
+ */
13
+ export function readFileAsDataURL(file) {
14
+ return new Promise((resolve, reject) => {
15
+ const reader = new FileReader();
16
+ reader.onload = () => resolve(reader.result);
17
+ reader.onerror = () => reject(reader.error);
18
+ reader.readAsDataURL(file);
19
+ });
20
+ }
21
+ /**
22
+ * Reads the contents of a given File object as a text string.
23
+ *
24
+ * This function uses the FileReader API to read the file content and returns it as a string.
25
+ *
26
+ * @param file - The File object to be read.
27
+ * @returns A promise that resolves to the text content of the file as a string.
28
+ *
29
+ * @throws An error if the file could not be read.
30
+ *
31
+ * @example
32
+ * // Create a file and read its content as text
33
+ * const myFile = new File(['Hello, world!'], 'example.txt', { type: 'text/plain' });
34
+ * readFileAsText(myFile).then((text) => {
35
+ * console.log(text); // Output: "Hello, world!"
36
+ * });
37
+ */
38
+ export async function readFileAsText(file) {
39
+ return new Promise((resolve, reject) => {
40
+ const reader = new FileReader();
41
+ // Event handler executed when the file reading operation is completed
42
+ reader.onloadend = function () {
43
+ // Check if the file was read successfully
44
+ if (reader.readyState === FileReader.DONE) {
45
+ resolve(reader.result);
46
+ }
47
+ else {
48
+ reject(new Error('Failed to read file as text.'));
49
+ }
50
+ };
51
+ // Event handler executed when an error occurs while reading the file
52
+ reader.onerror = function () {
53
+ reject(new Error(`Error reading file: ${reader.error?.message || 'Unknown error'}`));
54
+ };
55
+ // Read the file content as a text string
56
+ reader.readAsText(file);
57
+ });
58
+ }
59
+ /**
60
+ * Reads the contents of a given File object as an ArrayBuffer.
61
+ *
62
+ * This function uses the FileReader API to read the file content as a binary ArrayBuffer.
63
+ *
64
+ * @param file - The File object to be read.
65
+ * @returns A promise that resolves to the binary content of the file as an ArrayBuffer.
66
+ *
67
+ * @throws An error if the file could not be read.
68
+ *
69
+ * @example
70
+ * // Create a file and read its content as an ArrayBuffer
71
+ * const myFile = new File(['Hello, world!'], 'example.txt', { type: 'text/plain' });
72
+ * readFileAsBuffer(myFile).then((buffer) => {
73
+ * console.log(buffer); // Output: ArrayBuffer { ... }
74
+ * });
75
+ */
76
+ export async function readFileAsBuffer(file) {
77
+ return new Promise((resolve, reject) => {
78
+ const reader = new FileReader();
79
+ // Event handler executed when the file reading operation is completed
80
+ reader.onloadend = () => {
81
+ if (reader.readyState === FileReader.DONE) {
82
+ resolve(reader.result);
83
+ }
84
+ else {
85
+ reject(new Error('Failed to read file as ArrayBuffer.'));
86
+ }
87
+ };
88
+ // Event handler executed when an error occurs while reading the file
89
+ reader.onerror = () => {
90
+ reject(new Error(`Error reading file as ArrayBuffer: ${reader.error?.message || 'Unknown error'}`));
91
+ };
92
+ // Read the file content as a binary ArrayBuffer
93
+ reader.readAsArrayBuffer(file);
94
+ });
95
+ }
96
+ /**
97
+ * Converts a given URL to a File object by downloading the content from the URL.
98
+ *
99
+ * This function fetches the file content from the provided URL and converts it into a File object.
100
+ * It attempts to extract the filename and MIME type from the HTTP headers. If these are not available,
101
+ * it falls back to using the provided filename and MIME type or extracts the filename from the URL.
102
+ *
103
+ * @param url - The URL to download the file from.
104
+ * @param givenFileName - Optional. The fallback name for the file if no name can be extracted from the URL or headers.
105
+ * @param givenMimeType - Optional. The fallback MIME type for the file if no MIME type is available in the headers.
106
+ * @returns A promise that resolves to a File object containing the downloaded content.
107
+ *
108
+ * @throws An error if the download fails or the file cannot be converted.
109
+ *
110
+ * @example
111
+ * // Convert an image URL to a File object and log its properties
112
+ * readUrlAsFile('https://example.com/image.png', 'downloaded-image.png', 'image/png')
113
+ * .then((file) => {
114
+ * console.log(file.name); // Output: "downloaded-image.png"
115
+ * console.log(file.type); // Output: "image/png"
116
+ * })
117
+ * .catch((error) => console.error('Error converting URL to file:', error.message));
118
+ */
119
+ export async function readUrlAsFile(url, givenFileName, givenMimeType) {
120
+ try {
121
+ const response = await fetch(url);
122
+ // Check if the fetch request was successful
123
+ if (!response.ok) {
124
+ throw new Error(`Failed to fetch file from URL: ${response.statusText}`);
125
+ }
126
+ // Extract filename from the Content-Disposition header if available
127
+ const contentDisposition = response.headers.get('Content-Disposition');
128
+ let fileName = "";
129
+ if (contentDisposition) {
130
+ const filenameMatch = contentDisposition.match(/filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/);
131
+ if (filenameMatch && filenameMatch[1]) {
132
+ fileName = filenameMatch[1].replace(/['"]/g, '');
133
+ }
134
+ }
135
+ // Fallback to using the URL's last segment as the filename if Content-Disposition is not available
136
+ if (!fileName) {
137
+ const urlSegments = url.split('/');
138
+ fileName = urlSegments[urlSegments.length - 1] || 'downloaded-file';
139
+ }
140
+ // Get MIME type from the Content-Type header, if available
141
+ const mimeType = response.headers.get('Content-Type') || givenMimeType || 'application/octet-stream';
142
+ // Read the file content as an ArrayBuffer
143
+ const buffer = await response.arrayBuffer();
144
+ // Create a File object with the buffer, filename, and MIME type
145
+ return new File([buffer], givenFileName || fileName, { type: mimeType });
146
+ }
147
+ catch (error) {
148
+ throw new Error(`Error converting URL to file: ${error.message}`);
149
+ }
150
+ }
151
+ /**
152
+ * Converts a given Data URL (Base64 or Data URL format) to a File object.
153
+ *
154
+ * @param dataUrl - The Data URL string to convert into a File object.
155
+ * @param fileName - Optional. The name for the created file.
156
+ * @param mimeType - Optional. The MIME type of the file. If not provided, it will be extracted from the Data URL.
157
+ * @returns A promise that resolves to a File object containing the content of the Data URL.
158
+ *
159
+ * @example
160
+ * // Convert a Base64 string to a File object
161
+ * const base64String = '...';
162
+ * readDataUrlAsFile(base64String, 'example.png', 'image/png')
163
+ * .then((file) => {
164
+ * console.log(file.name); // Output: "example.png"
165
+ * console.log(file.type); // Output: "image/png"
166
+ * });
167
+ */
168
+ export async function readDataUrlAsFile(dataUrl, fileName = 'file', mimeType) {
169
+ try {
170
+ // Extract the MIME type from the Data URL if not provided
171
+ const mimeTypeMatch = dataUrl.match(/^data:([^;]+);/);
172
+ const extractedMimeType = mimeTypeMatch ? mimeTypeMatch[1] : mimeType;
173
+ // Convert the Base64 portion of the Data URL to a binary string
174
+ const binaryString = atob(dataUrl.split(',')[1]);
175
+ // Convert the binary string to an ArrayBuffer
176
+ const length = binaryString.length;
177
+ const buffer = new Uint8Array(length);
178
+ for (let i = 0; i < length; i++) {
179
+ buffer[i] = binaryString.charCodeAt(i);
180
+ }
181
+ // Create and return a File object
182
+ return new File([buffer], fileName, { type: extractedMimeType || 'application/octet-stream' });
183
+ }
184
+ catch (error) {
185
+ throw new Error(`Error converting Data URL to file: ${error.message}`);
186
+ }
187
+ }
188
+ /**
189
+ * Converts a given ArrayBuffer to a File object.
190
+ *
191
+ * This function wraps an ArrayBuffer in a File object with the provided filename and MIME type.
192
+ *
193
+ * @param buffer - The ArrayBuffer containing the file data.
194
+ * @param fileName - The name for the created file.
195
+ * @param mimeType - The MIME type for the created file.
196
+ * @returns A promise that resolves to a File object created from the ArrayBuffer.
197
+ *
198
+ * @example
199
+ * // Convert an ArrayBuffer to a File object
200
+ * const buffer = new ArrayBuffer(8);
201
+ * convertBufferToFile(buffer, 'example.bin', 'application/octet-stream').then((file) => {
202
+ * console.log(file.name); // Output: "example.bin"
203
+ * console.log(file.type); // Output: "application/octet-stream"
204
+ * });
205
+ */
206
+ export async function convertBufferToFile(buffer, fileName, mimeType) {
207
+ try {
208
+ // Create and return a File object from the ArrayBuffer
209
+ return new File([buffer], fileName, { type: mimeType });
210
+ }
211
+ catch (error) {
212
+ throw new Error(`Error converting ArrayBuffer to file: ${error.message}`);
213
+ }
214
+ }
215
+ /**
216
+ * Extracts the filename and extension from a given filename string.
217
+ *
218
+ * This function splits a filename into its base name and extension parts.
219
+ * If no extension is present, the extension will be `undefined`.
220
+ *
221
+ * @param filename - The filename string to be processed.
222
+ * @returns An object containing the base name and extension of the filename.
223
+ *
224
+ * @example
225
+ * // Extract filename and extension
226
+ * const { name, ext } = getFilenameExtension('example.txt');
227
+ * console.log(name); // Output: "example"
228
+ * console.log(ext); // Output: "txt"
229
+ */
230
+ export function getFilenameExtension(filename) {
231
+ if (!filename)
232
+ return { name: '', ext: undefined };
233
+ const parts = filename.split('.');
234
+ const ext = parts.length > 1 ? parts.pop() : undefined;
235
+ const name = parts.join('.');
236
+ return { name, ext };
237
+ }
238
+ /**
239
+ * Converts a file size in bytes to a human-readable string.
240
+ *
241
+ * This function converts a file size in bytes to a string representation with appropriate units
242
+ * (e.g., B, kB, MB, GB, TB) based on the size.
243
+ *
244
+ * @param size - The file size in bytes.
245
+ * @returns A human-readable string representing the file size.
246
+ *
247
+ * @example
248
+ * const sizeString = fileSizeString(1024);
249
+ * console.log(sizeString); // Output: "1 kB"
250
+ */
251
+ export function formatFileSize(bytes = 0) {
252
+ if (bytes < 1024) {
253
+ return bytes + ' Bytes';
254
+ }
255
+ else if (bytes < 1024 * 1024) {
256
+ return (bytes / 1024).toFixed(2) + ' KB';
257
+ }
258
+ else if (bytes < 1024 * 1024 * 1024) {
259
+ return (bytes / (1024 * 1024)).toFixed(2) + ' MB';
260
+ }
261
+ else {
262
+ return (bytes / (1024 * 1024 * 1024)).toFixed(2) + ' GB';
263
+ }
264
+ }
265
+ export function getExtFromFileType(type) {
266
+ const mimeTypes = {
267
+ "image/jpeg": "jpg",
268
+ "image/png": "png",
269
+ "image/gif": "gif",
270
+ "image/webp": "webp",
271
+ "image/svg+xml": "svg",
272
+ "video/mp4": "mp4",
273
+ "video/webm": "webm",
274
+ "video/ogg": "ogv",
275
+ "audio/mpeg": "mp3",
276
+ "audio/ogg": "ogg",
277
+ "audio/wav": "wav",
278
+ "application/pdf": "pdf",
279
+ "application/json": "json",
280
+ "application/javascript": "js",
281
+ "text/html": "html",
282
+ "text/css": "css",
283
+ "text/plain": "txt",
284
+ "application/zip": "zip",
285
+ "application/x-rar-compressed": "rar",
286
+ "application/xml": "xml"
287
+ };
288
+ return mimeTypes[type] || null;
289
+ }
290
+ export function ellipsisFileNameAtCenter(name, sizeLimit = 15, startLength = 5, endLength = 3) {
291
+ name = name || '';
292
+ if (name.length > sizeLimit) {
293
+ name = [
294
+ name.substring(0, startLength),
295
+ '…',
296
+ name.substring(name.lastIndexOf('.') - endLength, name.length)
297
+ ].join('');
298
+ return name;
299
+ }
300
+ return name;
301
+ }
@@ -0,0 +1,77 @@
1
+ /**
2
+ * Sends a GET request to the specified URL.
3
+ *
4
+ * @param url - The URL to send the GET request to.
5
+ * @param headers - Optional headers to include in the request.
6
+ * @returns A promise that resolves to the JSON response from the server.
7
+ *
8
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
9
+ *
10
+ * @example
11
+ * httpGet('https://api.example.com/data')
12
+ * .then((response) => console.log(response))
13
+ * .catch((error) => console.error('Error fetching data:', error));
14
+ */
15
+ export declare function httpGet(url: string, headers?: HeadersInit): Promise<any>;
16
+ /**
17
+ * Sends a POST request with JSON data to the specified URL.
18
+ *
19
+ * @param url - The endpoint URL to send the POST request to.
20
+ * @param data - The data object to be sent as the request body.
21
+ * @param headers - Optional headers to include in the request.
22
+ * @returns A promise that resolves to the JSON response from the server.
23
+ *
24
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
25
+ */
26
+ export declare function httpPost(url: string, data?: Record<string, any>, headers?: HeadersInit): Promise<any>;
27
+ /**
28
+ * Sends a PUT request with JSON data to the specified URL.
29
+ *
30
+ * @param url - The endpoint URL to send the PUT request to.
31
+ * @param data - The data object to be sent as the request body.
32
+ * @param headers - Optional headers to include in the request.
33
+ * @returns A promise that resolves to the JSON response from the server.
34
+ *
35
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
36
+ */
37
+ export declare function httpPut(url: string, data?: Record<string, any>, headers?: HeadersInit): Promise<any>;
38
+ /**
39
+ * Sends a PATCH request with JSON data to the specified URL.
40
+ *
41
+ * @param url - The endpoint URL to send the PATCH request to.
42
+ * @param data - The data object to be sent as the request body.
43
+ * @param headers - Optional headers to include in the request.
44
+ * @returns A promise that resolves to the JSON response from the server.
45
+ *
46
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
47
+ */
48
+ export declare function httpPatch(url: string, data?: Record<string, any>, headers?: HeadersInit): Promise<any>;
49
+ /**
50
+ * Sends a DELETE request to the specified URL.
51
+ *
52
+ * @param url - The endpoint URL to send the DELETE request to.
53
+ * @param headers - Optional headers to include in the request.
54
+ * @returns A promise that resolves to the JSON response from the server.
55
+ *
56
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
57
+ */
58
+ export declare function httpDelete(url: string, headers?: HeadersInit): Promise<any>;
59
+ /**
60
+ * Fetches text content from a given URL with a default timeout of 60 seconds.
61
+ *
62
+ * This function sends a GET request to the provided URL and returns the response as text.
63
+ * It throws an error if the request fails or the response cannot be read as text.
64
+ * The request will be aborted if it exceeds the default timeout of 60 seconds.
65
+ *
66
+ * @param url - The URL to fetch the text content from.
67
+ * @param timeout - Optional. The timeout duration in milliseconds. Default is 60 seconds (60000ms).
68
+ * @returns A promise that resolves to the text content of the URL.
69
+ *
70
+ * @throws An error if the fetch request fails or if the request times out.
71
+ *
72
+ * @example
73
+ * fetchText('https://example.com/data.txt').then((text) => {
74
+ * console.log(text); // Outputs the text content of the file.
75
+ * }).catch((error) => console.error('Failed to fetch text:', error));
76
+ */
77
+ export declare function fetchText(url: string, timeout?: number): Promise<string>;
@@ -0,0 +1,158 @@
1
+ // Default timeout duration in milliseconds (60 seconds)
2
+ const DEFAULT_TIMEOUT = 60000;
3
+ /**
4
+ * Sends a GET request to the specified URL.
5
+ *
6
+ * @param url - The URL to send the GET request to.
7
+ * @param headers - Optional headers to include in the request.
8
+ * @returns A promise that resolves to the JSON response from the server.
9
+ *
10
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
11
+ *
12
+ * @example
13
+ * httpGet('https://api.example.com/data')
14
+ * .then((response) => console.log(response))
15
+ * .catch((error) => console.error('Error fetching data:', error));
16
+ */
17
+ export async function httpGet(url, headers = {}) {
18
+ return httpRequest(url, { method: 'GET', headers });
19
+ }
20
+ /**
21
+ * Sends a POST request with JSON data to the specified URL.
22
+ *
23
+ * @param url - The endpoint URL to send the POST request to.
24
+ * @param data - The data object to be sent as the request body.
25
+ * @param headers - Optional headers to include in the request.
26
+ * @returns A promise that resolves to the JSON response from the server.
27
+ *
28
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
29
+ */
30
+ export async function httpPost(url, data = {}, headers = {}) {
31
+ return httpRequest(url, {
32
+ method: 'POST',
33
+ headers: { 'Content-Type': 'application/json', ...headers },
34
+ body: JSON.stringify(data),
35
+ });
36
+ }
37
+ /**
38
+ * Sends a PUT request with JSON data to the specified URL.
39
+ *
40
+ * @param url - The endpoint URL to send the PUT request to.
41
+ * @param data - The data object to be sent as the request body.
42
+ * @param headers - Optional headers to include in the request.
43
+ * @returns A promise that resolves to the JSON response from the server.
44
+ *
45
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
46
+ */
47
+ export async function httpPut(url, data = {}, headers = {}) {
48
+ return httpRequest(url, {
49
+ method: 'PUT',
50
+ headers: { 'Content-Type': 'application/json', ...headers },
51
+ body: JSON.stringify(data),
52
+ });
53
+ }
54
+ /**
55
+ * Sends a PATCH request with JSON data to the specified URL.
56
+ *
57
+ * @param url - The endpoint URL to send the PATCH request to.
58
+ * @param data - The data object to be sent as the request body.
59
+ * @param headers - Optional headers to include in the request.
60
+ * @returns A promise that resolves to the JSON response from the server.
61
+ *
62
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
63
+ */
64
+ export async function httpPatch(url, data = {}, headers = {}) {
65
+ return httpRequest(url, {
66
+ method: 'PATCH',
67
+ headers: { 'Content-Type': 'application/json', ...headers },
68
+ body: JSON.stringify(data),
69
+ });
70
+ }
71
+ /**
72
+ * Sends a DELETE request to the specified URL.
73
+ *
74
+ * @param url - The endpoint URL to send the DELETE request to.
75
+ * @param headers - Optional headers to include in the request.
76
+ * @returns A promise that resolves to the JSON response from the server.
77
+ *
78
+ * @throws An error if the request fails or the response cannot be parsed as JSON.
79
+ */
80
+ export async function httpDelete(url, headers = {}) {
81
+ return httpRequest(url, { method: 'DELETE', headers });
82
+ }
83
+ /**
84
+ * Generic function to handle HTTP requests with a timeout.
85
+ *
86
+ * @param url - The URL to send the request to.
87
+ * @param options - The request options (method, headers, body, etc.).
88
+ * @param timeout - Optional timeout duration in milliseconds. Default is 60 seconds.
89
+ * @returns A promise that resolves to the JSON response from the server.
90
+ *
91
+ * @throws An error if the request times out or if the response cannot be parsed as JSON.
92
+ */
93
+ async function httpRequest(url, options, timeout = DEFAULT_TIMEOUT) {
94
+ // Create an AbortController to handle request timeout
95
+ const controller = new AbortController();
96
+ const timeoutId = setTimeout(() => controller.abort(), timeout);
97
+ options.signal = controller.signal;
98
+ try {
99
+ const response = await fetch(url, options);
100
+ // Check if the response is successful (status in the range 200–299)
101
+ if (!response.ok) {
102
+ throw new Error(`HTTP error! Status: ${response.status} ${response.statusText}`);
103
+ }
104
+ // Parse and return the response as JSON
105
+ return await response.json();
106
+ }
107
+ catch (error) {
108
+ if (error.name === 'AbortError') {
109
+ throw new Error(`Request to ${url} timed out after ${timeout / 1000} seconds.`);
110
+ }
111
+ throw new Error(`Failed to fetch ${url}: ${error.message}`);
112
+ }
113
+ finally {
114
+ clearTimeout(timeoutId); // Clear the timeout to prevent memory leaks
115
+ }
116
+ }
117
+ /**
118
+ * Fetches text content from a given URL with a default timeout of 60 seconds.
119
+ *
120
+ * This function sends a GET request to the provided URL and returns the response as text.
121
+ * It throws an error if the request fails or the response cannot be read as text.
122
+ * The request will be aborted if it exceeds the default timeout of 60 seconds.
123
+ *
124
+ * @param url - The URL to fetch the text content from.
125
+ * @param timeout - Optional. The timeout duration in milliseconds. Default is 60 seconds (60000ms).
126
+ * @returns A promise that resolves to the text content of the URL.
127
+ *
128
+ * @throws An error if the fetch request fails or if the request times out.
129
+ *
130
+ * @example
131
+ * fetchText('https://example.com/data.txt').then((text) => {
132
+ * console.log(text); // Outputs the text content of the file.
133
+ * }).catch((error) => console.error('Failed to fetch text:', error));
134
+ */
135
+ export async function fetchText(url, timeout = DEFAULT_TIMEOUT) {
136
+ // Create an AbortController to handle request timeout
137
+ const controller = new AbortController();
138
+ const timeoutId = setTimeout(() => controller.abort(), timeout);
139
+ try {
140
+ const response = await fetch(url, { signal: controller.signal });
141
+ // Check if the response is successful (status in the range 200–299)
142
+ if (!response.ok) {
143
+ throw new Error(`Failed to fetch text. Status: ${response.status} ${response.statusText}`);
144
+ }
145
+ // Return the response as text
146
+ return await response.text();
147
+ }
148
+ catch (error) {
149
+ if (error.name === 'AbortError') {
150
+ throw new Error(`Request to ${url} timed out after ${timeout / 1000} seconds.`);
151
+ }
152
+ console.error('Error fetching text from URL:', error);
153
+ throw new Error(`Failed to fetch text from ${url}: ${error.message}`);
154
+ }
155
+ finally {
156
+ clearTimeout(timeoutId); // Clear the timeout to prevent memory leaks
157
+ }
158
+ }