@aquera/nile-elements 0.1.37 → 0.1.38-beta-1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (244) hide show
  1. package/README.md +9 -0
  2. package/demo/index.html +9 -9
  3. package/dist/{fixture-372df3b0.esm.js → fixture-add72f26.esm.js} +1 -1
  4. package/dist/{fixture-161dee0b.cjs.js → fixture-cb376a7f.cjs.js} +3 -3
  5. package/dist/fixture-cb376a7f.cjs.js.map +1 -0
  6. package/dist/index.cjs.js +1 -1
  7. package/dist/index.esm.js +1 -1
  8. package/dist/lit-html-39a6718c.esm.js +6 -0
  9. package/dist/lit-html-9b3af046.cjs.js +6 -0
  10. package/dist/lit-html-9b3af046.cjs.js.map +1 -0
  11. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  12. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  13. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +1 -1
  14. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js.map +1 -1
  15. package/dist/nile-auto-complete/nile-auto-complete.test.esm.js +1 -1
  16. package/dist/nile-avatar/nile-avatar.test.cjs.js +1 -1
  17. package/dist/nile-avatar/nile-avatar.test.esm.js +1 -1
  18. package/dist/nile-badge/nile-badge.test.cjs.js +1 -1
  19. package/dist/nile-badge/nile-badge.test.esm.js +1 -1
  20. package/dist/nile-button/nile-button.test.cjs.js +1 -1
  21. package/dist/nile-button/nile-button.test.esm.js +1 -1
  22. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.cjs.js +1 -1
  23. package/dist/nile-button-toggle-group/nile-button-toggle-group.test.esm.js +1 -1
  24. package/dist/nile-calendar/nile-calendar.test.cjs.js +1 -1
  25. package/dist/nile-calendar/nile-calendar.test.esm.js +1 -1
  26. package/dist/nile-card/nile-card.test.cjs.js +1 -1
  27. package/dist/nile-card/nile-card.test.esm.js +1 -1
  28. package/dist/nile-checkbox/nile-checkbox.test.cjs.js +1 -1
  29. package/dist/nile-checkbox/nile-checkbox.test.esm.js +1 -1
  30. package/dist/nile-chip/nile-chip.test.cjs.js +1 -1
  31. package/dist/nile-chip/nile-chip.test.esm.js +1 -1
  32. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  33. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  34. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  35. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  36. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  37. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  38. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  39. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  40. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  41. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  42. package/dist/nile-file-preview/index.cjs.js +2 -0
  43. package/dist/nile-file-preview/index.cjs.js.map +1 -0
  44. package/dist/nile-file-preview/index.esm.js +1 -0
  45. package/dist/nile-file-preview/nile-file-preview.cjs.js +2 -0
  46. package/dist/nile-file-preview/nile-file-preview.cjs.js.map +1 -0
  47. package/dist/nile-file-preview/nile-file-preview.css.cjs.js +2 -0
  48. package/dist/nile-file-preview/nile-file-preview.css.cjs.js.map +1 -0
  49. package/dist/nile-file-preview/nile-file-preview.css.esm.js +510 -0
  50. package/dist/nile-file-preview/nile-file-preview.esm.js +3 -0
  51. package/dist/nile-file-preview/nile-file-preview.template.cjs.js +2 -0
  52. package/dist/nile-file-preview/nile-file-preview.template.cjs.js.map +1 -0
  53. package/dist/nile-file-preview/nile-file-preview.template.esm.js +179 -0
  54. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +2 -0
  55. package/dist/nile-file-preview/nile-file-preview.test.cjs.js.map +1 -0
  56. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -0
  57. package/dist/nile-file-preview/types/index.cjs.js +2 -0
  58. package/dist/nile-file-preview/types/index.cjs.js.map +1 -0
  59. package/dist/nile-file-preview/types/index.esm.js +1 -0
  60. package/dist/nile-file-preview/types/nile-file-preview.enums.cjs.js +2 -0
  61. package/dist/nile-file-preview/types/nile-file-preview.enums.cjs.js.map +1 -0
  62. package/dist/nile-file-preview/types/nile-file-preview.enums.esm.js +1 -0
  63. package/dist/nile-file-preview/types/nile-file-preview.interface.cjs.js +2 -0
  64. package/dist/nile-file-preview/types/nile-file-preview.interface.cjs.js.map +1 -0
  65. package/dist/nile-file-preview/types/nile-file-preview.interface.esm.js +1 -0
  66. package/dist/nile-file-preview/utils/index.cjs.js +2 -0
  67. package/dist/nile-file-preview/utils/index.cjs.js.map +1 -0
  68. package/dist/nile-file-preview/utils/index.esm.js +1 -0
  69. package/dist/nile-file-preview/utils/nile-file-preview.util.cjs.js +2 -0
  70. package/dist/nile-file-preview/utils/nile-file-preview.util.cjs.js.map +1 -0
  71. package/dist/nile-file-preview/utils/nile-file-preview.util.esm.js +1 -0
  72. package/dist/nile-file-upload/index.cjs.js +2 -0
  73. package/dist/nile-file-upload/index.cjs.js.map +1 -0
  74. package/dist/nile-file-upload/index.esm.js +1 -0
  75. package/dist/nile-file-upload/nile-file-upload.cjs.js +2 -0
  76. package/dist/nile-file-upload/nile-file-upload.cjs.js.map +1 -0
  77. package/dist/nile-file-upload/nile-file-upload.css.cjs.js +2 -0
  78. package/dist/nile-file-upload/nile-file-upload.css.cjs.js.map +1 -0
  79. package/dist/nile-file-upload/nile-file-upload.css.esm.js +536 -0
  80. package/dist/nile-file-upload/nile-file-upload.esm.js +3 -0
  81. package/dist/nile-file-upload/nile-file-upload.template.cjs.js +10 -0
  82. package/dist/nile-file-upload/nile-file-upload.template.cjs.js.map +1 -0
  83. package/dist/nile-file-upload/nile-file-upload.template.esm.js +163 -0
  84. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +2 -0
  85. package/dist/nile-file-upload/nile-file-upload.test.cjs.js.map +1 -0
  86. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -0
  87. package/dist/nile-file-upload/types/file-upload.enums.cjs.js +2 -0
  88. package/dist/nile-file-upload/types/file-upload.enums.cjs.js.map +1 -0
  89. package/dist/nile-file-upload/types/file-upload.enums.esm.js +1 -0
  90. package/dist/nile-file-upload/types/file-upload.type.cjs.js +2 -0
  91. package/dist/nile-file-upload/types/file-upload.type.cjs.js.map +1 -0
  92. package/dist/nile-file-upload/types/file-upload.type.esm.js +1 -0
  93. package/dist/nile-file-upload/types/index.cjs.js +2 -0
  94. package/dist/nile-file-upload/types/index.cjs.js.map +1 -0
  95. package/dist/nile-file-upload/types/index.esm.js +1 -0
  96. package/dist/nile-file-upload/utils/drag-drop.util.cjs.js +2 -0
  97. package/dist/nile-file-upload/utils/drag-drop.util.cjs.js.map +1 -0
  98. package/dist/nile-file-upload/utils/drag-drop.util.esm.js +1 -0
  99. package/dist/nile-file-upload/utils/file-validation.util.cjs.js +2 -0
  100. package/dist/nile-file-upload/utils/file-validation.util.cjs.js.map +1 -0
  101. package/dist/nile-file-upload/utils/file-validation.util.esm.js +1 -0
  102. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  103. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  104. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  105. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  106. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  107. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  108. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  109. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  110. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  111. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  112. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  113. package/dist/nile-input/nile-input.test.esm.js +1 -1
  114. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  115. package/dist/nile-link/nile-link.test.esm.js +1 -1
  116. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  117. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  118. package/dist/nile-popover/index.cjs.js +1 -1
  119. package/dist/nile-popover/index.esm.js +1 -1
  120. package/dist/nile-popover/nile-popover.cjs.js +3 -11
  121. package/dist/nile-popover/nile-popover.cjs.js.map +1 -1
  122. package/dist/nile-popover/nile-popover.esm.js +7 -13
  123. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  124. package/dist/nile-popover/nile-popover.test.cjs.js.map +1 -1
  125. package/dist/nile-popover/nile-popover.test.esm.js +3 -3
  126. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  127. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  128. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  129. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  130. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  131. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  132. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  133. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  134. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  135. package/dist/nile-select/nile-select.test.esm.js +1 -1
  136. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  137. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  138. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  139. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  140. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  141. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  142. package/dist/src/index.d.ts +2 -0
  143. package/dist/src/index.js +2 -0
  144. package/dist/src/index.js.map +1 -1
  145. package/dist/src/nile-file-preview/index.d.ts +1 -0
  146. package/dist/src/nile-file-preview/index.js +2 -0
  147. package/dist/src/nile-file-preview/index.js.map +1 -0
  148. package/dist/src/nile-file-preview/nile-file-preview.css.d.ts +12 -0
  149. package/dist/src/nile-file-preview/nile-file-preview.css.js +522 -0
  150. package/dist/src/nile-file-preview/nile-file-preview.css.js.map +1 -0
  151. package/dist/src/nile-file-preview/nile-file-preview.d.ts +50 -0
  152. package/dist/src/nile-file-preview/nile-file-preview.js +171 -0
  153. package/dist/src/nile-file-preview/nile-file-preview.js.map +1 -0
  154. package/dist/src/nile-file-preview/nile-file-preview.template.d.ts +13 -0
  155. package/dist/src/nile-file-preview/nile-file-preview.template.js +210 -0
  156. package/dist/src/nile-file-preview/nile-file-preview.template.js.map +1 -0
  157. package/dist/src/nile-file-preview/nile-file-preview.test.d.ts +7 -0
  158. package/dist/src/nile-file-preview/nile-file-preview.test.js +30 -0
  159. package/dist/src/nile-file-preview/nile-file-preview.test.js.map +1 -0
  160. package/dist/src/nile-file-preview/types/file-preview.enums.d.ts +23 -0
  161. package/dist/src/nile-file-preview/types/file-preview.enums.js +28 -0
  162. package/dist/src/nile-file-preview/types/file-preview.enums.js.map +1 -0
  163. package/dist/src/nile-file-preview/types/file-preview.interface.d.ts +4 -0
  164. package/dist/src/nile-file-preview/types/file-preview.interface.js +2 -0
  165. package/dist/src/nile-file-preview/types/file-preview.interface.js.map +1 -0
  166. package/dist/src/nile-file-preview/types/index.d.ts +2 -0
  167. package/dist/src/nile-file-preview/types/index.js +3 -0
  168. package/dist/src/nile-file-preview/types/index.js.map +1 -0
  169. package/dist/src/nile-file-preview/types/nile-file-preview.enums.d.ts +28 -0
  170. package/dist/src/nile-file-preview/types/nile-file-preview.enums.js +33 -0
  171. package/dist/src/nile-file-preview/types/nile-file-preview.enums.js.map +1 -0
  172. package/dist/src/nile-file-preview/types/nile-file-preview.interface.d.ts +4 -0
  173. package/dist/src/nile-file-preview/types/nile-file-preview.interface.js +2 -0
  174. package/dist/src/nile-file-preview/types/nile-file-preview.interface.js.map +1 -0
  175. package/dist/src/nile-file-preview/utils/file-preview.util.d.ts +3 -0
  176. package/dist/src/nile-file-preview/utils/file-preview.util.js +29 -0
  177. package/dist/src/nile-file-preview/utils/file-preview.util.js.map +1 -0
  178. package/dist/src/nile-file-preview/utils/index.d.ts +1 -0
  179. package/dist/src/nile-file-preview/utils/index.js +2 -0
  180. package/dist/src/nile-file-preview/utils/index.js.map +1 -0
  181. package/dist/src/nile-file-preview/utils/nile-file-preview.util.d.ts +4 -0
  182. package/dist/src/nile-file-preview/utils/nile-file-preview.util.js +38 -0
  183. package/dist/src/nile-file-preview/utils/nile-file-preview.util.js.map +1 -0
  184. package/dist/src/nile-file-upload/index.d.ts +1 -0
  185. package/dist/src/nile-file-upload/index.js +2 -0
  186. package/dist/src/nile-file-upload/index.js.map +1 -0
  187. package/dist/src/nile-file-upload/nile-file-upload.css.d.ts +12 -0
  188. package/dist/src/nile-file-upload/nile-file-upload.css.js +548 -0
  189. package/dist/src/nile-file-upload/nile-file-upload.css.js.map +1 -0
  190. package/dist/src/nile-file-upload/nile-file-upload.d.ts +48 -0
  191. package/dist/src/nile-file-upload/nile-file-upload.js +165 -0
  192. package/dist/src/nile-file-upload/nile-file-upload.js.map +1 -0
  193. package/dist/src/nile-file-upload/nile-file-upload.template.d.ts +11 -0
  194. package/dist/src/nile-file-upload/nile-file-upload.template.js +171 -0
  195. package/dist/src/nile-file-upload/nile-file-upload.template.js.map +1 -0
  196. package/dist/src/nile-file-upload/nile-file-upload.test.d.ts +7 -0
  197. package/dist/src/nile-file-upload/nile-file-upload.test.js +30 -0
  198. package/dist/src/nile-file-upload/nile-file-upload.test.js.map +1 -0
  199. package/dist/src/nile-file-upload/types/file-upload.enums.d.ts +35 -0
  200. package/dist/src/nile-file-upload/types/file-upload.enums.js +42 -0
  201. package/dist/src/nile-file-upload/types/file-upload.enums.js.map +1 -0
  202. package/dist/src/nile-file-upload/types/file-upload.type.d.ts +4 -0
  203. package/dist/src/nile-file-upload/types/file-upload.type.js +2 -0
  204. package/dist/src/nile-file-upload/types/file-upload.type.js.map +1 -0
  205. package/dist/src/nile-file-upload/types/index.d.ts +2 -0
  206. package/dist/src/nile-file-upload/types/index.js +3 -0
  207. package/dist/src/nile-file-upload/types/index.js.map +1 -0
  208. package/dist/src/nile-file-upload/utils/drag-drop.util.d.ts +23 -0
  209. package/dist/src/nile-file-upload/utils/drag-drop.util.js +85 -0
  210. package/dist/src/nile-file-upload/utils/drag-drop.util.js.map +1 -0
  211. package/dist/src/nile-file-upload/utils/file-validation.util.d.ts +11 -0
  212. package/dist/src/nile-file-upload/utils/file-validation.util.js +120 -0
  213. package/dist/src/nile-file-upload/utils/file-validation.util.js.map +1 -0
  214. package/dist/src/nile-tooltip/nile-tooltip-utils.d.ts +18 -0
  215. package/dist/src/nile-tooltip/nile-tooltip-utils.js +216 -0
  216. package/dist/src/nile-tooltip/nile-tooltip-utils.js.map +1 -0
  217. package/dist/src/nile-tooltip/nile-tooltip.test.d.ts +1 -0
  218. package/dist/src/nile-tooltip/nile-tooltip.test.js +148 -0
  219. package/dist/src/nile-tooltip/nile-tooltip.test.js.map +1 -0
  220. package/dist/tsconfig.tsbuildinfo +1 -1
  221. package/package.json +1 -1
  222. package/src/index.ts +3 -1
  223. package/src/nile-file-preview/index.ts +1 -0
  224. package/src/nile-file-preview/nile-file-preview.css.ts +524 -0
  225. package/src/nile-file-preview/nile-file-preview.template.ts +248 -0
  226. package/src/nile-file-preview/nile-file-preview.test.ts +38 -0
  227. package/src/nile-file-preview/nile-file-preview.ts +173 -0
  228. package/src/nile-file-preview/types/index.ts +2 -0
  229. package/src/nile-file-preview/types/nile-file-preview.enums.ts +31 -0
  230. package/src/nile-file-preview/types/nile-file-preview.interface.ts +4 -0
  231. package/src/nile-file-preview/utils/index.ts +1 -0
  232. package/src/nile-file-preview/utils/nile-file-preview.util.ts +47 -0
  233. package/src/nile-file-upload/index.ts +1 -0
  234. package/src/nile-file-upload/nile-file-upload.css.ts +550 -0
  235. package/src/nile-file-upload/nile-file-upload.template.ts +201 -0
  236. package/src/nile-file-upload/nile-file-upload.test.ts +38 -0
  237. package/src/nile-file-upload/nile-file-upload.ts +149 -0
  238. package/src/nile-file-upload/types/file-upload.enums.ts +39 -0
  239. package/src/nile-file-upload/types/file-upload.type.ts +5 -0
  240. package/src/nile-file-upload/types/index.ts +2 -0
  241. package/src/nile-file-upload/utils/drag-drop.util.ts +106 -0
  242. package/src/nile-file-upload/utils/file-validation.util.ts +163 -0
  243. package/vscode-html-custom-data.json +143 -0
  244. package/dist/fixture-161dee0b.cjs.js.map +0 -1
@@ -0,0 +1,23 @@
1
+ import { FileUploadState } from "../types";
2
+ export declare class DragHandler {
3
+ private currentState;
4
+ private size;
5
+ private uploadedFiles;
6
+ private stateChangeCallback?;
7
+ private fileDropCallback?;
8
+ private errorMessageCallback?;
9
+ constructor();
10
+ setErrorMessage(callback: (errorMessage: string) => void): void;
11
+ setValuesInDragHandler(state: FileUploadState, size: number, uploadedFiles: File[]): void;
12
+ onFileDrop(callback: (files: File[]) => void): void;
13
+ onStateChange(callback: (state: FileUploadState) => void): void;
14
+ private setState;
15
+ dragEnter(e: DragEvent): void;
16
+ dragLeave(e: DragEvent): void;
17
+ dragOver(e: DragEvent): void;
18
+ drop(e: DragEvent): void;
19
+ handleDocumentDrop(e: DragEvent): void;
20
+ preventDragOver(e: DragEvent): void;
21
+ preventDrop(e: DragEvent): void;
22
+ handleFiles(event: Event | DragEvent): void;
23
+ }
@@ -0,0 +1,85 @@
1
+ import { FileUploadState } from "../types";
2
+ export class DragHandler {
3
+ constructor() {
4
+ this.currentState = FileUploadState.DEFAULT;
5
+ this.size = 0;
6
+ this.uploadedFiles = [];
7
+ }
8
+ setErrorMessage(callback) {
9
+ this.errorMessageCallback = callback;
10
+ }
11
+ setValuesInDragHandler(state, size, uploadedFiles) {
12
+ this.currentState = state;
13
+ this.size = size;
14
+ this.uploadedFiles = uploadedFiles;
15
+ }
16
+ onFileDrop(callback) {
17
+ this.fileDropCallback = callback;
18
+ }
19
+ onStateChange(callback) {
20
+ this.stateChangeCallback = callback;
21
+ }
22
+ setState(state) {
23
+ if (this.currentState === FileUploadState.DISABLED)
24
+ return;
25
+ this.currentState = state;
26
+ this.stateChangeCallback?.(state);
27
+ }
28
+ dragEnter(e) {
29
+ if (this.currentState === FileUploadState.DISABLED)
30
+ return;
31
+ e.preventDefault();
32
+ this.errorMessageCallback?.("");
33
+ this.setState(FileUploadState.DRAG);
34
+ }
35
+ dragLeave(e) {
36
+ if (this.currentState === FileUploadState.DISABLED)
37
+ return;
38
+ e.preventDefault();
39
+ this.setState(FileUploadState.DEFAULT);
40
+ }
41
+ dragOver(e) {
42
+ if (this.currentState === FileUploadState.DISABLED)
43
+ return;
44
+ e.preventDefault();
45
+ }
46
+ drop(e) {
47
+ if (this.currentState === FileUploadState.DISABLED)
48
+ return;
49
+ e.preventDefault();
50
+ e.stopPropagation();
51
+ this.setState(FileUploadState.DEFAULT);
52
+ this.handleFiles(e);
53
+ }
54
+ handleDocumentDrop(e) {
55
+ if (this.currentState === FileUploadState.DISABLED)
56
+ return;
57
+ e.preventDefault();
58
+ e.stopPropagation();
59
+ this.setState(FileUploadState.DEFAULT);
60
+ }
61
+ preventDragOver(e) {
62
+ e.preventDefault();
63
+ }
64
+ preventDrop(e) {
65
+ e.preventDefault();
66
+ e.stopPropagation();
67
+ }
68
+ handleFiles(event) {
69
+ if (this.currentState === FileUploadState.DISABLED)
70
+ return;
71
+ event.preventDefault?.();
72
+ let files = null;
73
+ if ('dataTransfer' in event && event.dataTransfer) {
74
+ files = event.dataTransfer.files;
75
+ }
76
+ if (!files && event.target instanceof HTMLInputElement) {
77
+ files = event.target.files;
78
+ }
79
+ if (files && files.length > 0) {
80
+ const newFiles = Array.from(files);
81
+ this.fileDropCallback?.(newFiles);
82
+ }
83
+ }
84
+ }
85
+ //# sourceMappingURL=drag-drop.util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drag-drop.util.js","sourceRoot":"","sources":["../../../../src/nile-file-upload/utils/drag-drop.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { FileUploadError, FileUploadState } from \"../types\";\n\nexport class DragHandler {\n private currentState: FileUploadState = FileUploadState.DEFAULT;\n private size: number = 0;\n private uploadedFiles: File[] = [];\n\n private stateChangeCallback?: (state: FileUploadState) => void;\n private fileDropCallback?: (files: File[]) => void;\n private errorMessageCallback?: (errorMessage: string) => void;\n\n constructor() {}\n\n public setErrorMessage(callback: (errorMessage: string) => void): void {\n this.errorMessageCallback = callback;\n }\n\n public setValuesInDragHandler(state: FileUploadState, size: number, uploadedFiles: File[]): void {\n this.currentState = state;\n this.size = size;\n this.uploadedFiles = uploadedFiles;\n }\n\n public onFileDrop(callback: (files: File[]) => void): void {\n this.fileDropCallback = callback;\n }\n\n public onStateChange(callback: (state: FileUploadState) => void): void {\n this.stateChangeCallback = callback;\n }\n\n private setState(state: FileUploadState): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n this.currentState = state;\n this.stateChangeCallback?.(state);\n }\n\n public dragEnter(e: DragEvent): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n e.preventDefault();\n this.errorMessageCallback?.(\"\");\n this.setState(FileUploadState.DRAG);\n }\n\n public dragLeave(e: DragEvent): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n e.preventDefault();\n this.setState(FileUploadState.DEFAULT);\n }\n\n public dragOver(e: DragEvent): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n e.preventDefault();\n }\n\n public drop(e: DragEvent): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n e.preventDefault();\n e.stopPropagation();\n this.setState(FileUploadState.DEFAULT);\n this.handleFiles(e);\n }\n\n public handleDocumentDrop(e: DragEvent): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n e.preventDefault();\n e.stopPropagation();\n this.setState(FileUploadState.DEFAULT);\n }\n\n public preventDragOver(e: DragEvent): void {\n e.preventDefault();\n }\n\n public preventDrop(e: DragEvent): void {\n e.preventDefault();\n e.stopPropagation();\n }\n\n public handleFiles(event: Event | DragEvent): void {\n if (this.currentState === FileUploadState.DISABLED) return;\n\n event.preventDefault?.();\n let files: FileList | null = null;\n\n if ('dataTransfer' in event && event.dataTransfer) {\n files = event.dataTransfer.files;\n }\n\n if (!files && event.target instanceof HTMLInputElement) {\n files = event.target.files;\n }\n\n if (files && files.length > 0) {\n const newFiles = Array.from(files);\n\n this.fileDropCallback?.(newFiles);\n }\n }\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import { DragHandler } from "./drag-drop.util";
2
+ import { FileUploadState } from "../types";
3
+ import { NileFileUpload } from "../nile-file-upload";
4
+ export declare const areDuplicates: (files: File[], uploadedFiles: File[]) => boolean;
5
+ export declare const setUpDragHandler: (nileFileUpload: NileFileUpload, dragHandler: DragHandler) => void;
6
+ export declare const addGlobalListeners: (dragHandler: DragHandler) => void;
7
+ export declare const addInternalListeners: (nileFileUpload: NileFileUpload, dragHandler: DragHandler, uploadRequests: any) => void;
8
+ export declare function handleHoverIn(setState: (state: FileUploadState) => void, currentState: FileUploadState): void;
9
+ export declare function handleHoverOut(setState: (state: FileUploadState) => void, currentState: FileUploadState): void;
10
+ export declare function uploadFiles(nileFileUpload: NileFileUpload): void;
11
+ export declare const cancelFileUpload: (nileFileUpload: NileFileUpload, uploadRequests: Map<File, XMLHttpRequest>) => void;
@@ -0,0 +1,120 @@
1
+ import { FileUploadState, FileUploadError, FileUploadEvent } from "../types";
2
+ // write a function to check for duplicatse in the files name it as areDuplicates
3
+ export const areDuplicates = (files, uploadedFiles) => {
4
+ return files.some(file => uploadedFiles.some(existing => file.name === existing.name &&
5
+ file.size === existing.size &&
6
+ file.lastModified === existing.lastModified));
7
+ };
8
+ // set up the drag handler
9
+ export const setUpDragHandler = (nileFileUpload, dragHandler) => {
10
+ dragHandler.onStateChange((newState) => {
11
+ nileFileUpload.state = newState;
12
+ });
13
+ dragHandler.onFileDrop((files) => {
14
+ let { allowMultiple, uploadedFiles, errorMessage, requestUpdate } = nileFileUpload;
15
+ if (!allowMultiple) {
16
+ const total = uploadedFiles.length + files.length;
17
+ if (total > 1) {
18
+ errorMessage = FileUploadError.MULTIPLE_NOT_ALLOWED;
19
+ requestUpdate();
20
+ return;
21
+ }
22
+ }
23
+ let newFiles = files;
24
+ if (!nileFileUpload.allowDuplicates) {
25
+ newFiles = files.filter(file => !nileFileUpload.uploadedFiles.some(uploaded => uploaded.name === file.name &&
26
+ uploaded.size === file.size &&
27
+ uploaded.type === file.type));
28
+ if (newFiles.length === 0) {
29
+ nileFileUpload.errorMessage = FileUploadError.DUPLICATES_NOT_ALLOWED;
30
+ nileFileUpload.requestUpdate();
31
+ return;
32
+ }
33
+ }
34
+ nileFileUpload.uploadedFiles = [...nileFileUpload.uploadedFiles, ...newFiles];
35
+ nileFileUpload.requestUpdate();
36
+ });
37
+ dragHandler.setErrorMessage((errorMessage) => {
38
+ nileFileUpload.errorMessage = errorMessage;
39
+ });
40
+ };
41
+ // global listenrers
42
+ export const addGlobalListeners = (dragHandler) => {
43
+ document.addEventListener('dragover', dragHandler.preventDragOver, { passive: false });
44
+ document.addEventListener('drop', dragHandler.preventDrop, { passive: false });
45
+ };
46
+ // for hover & dragging functionality
47
+ export const addInternalListeners = (nileFileUpload, dragHandler, uploadRequests) => {
48
+ nileFileUpload.addEventListener('mouseenter', (e) => handleHoverIn(nileFileUpload.setState, nileFileUpload.state));
49
+ nileFileUpload.addEventListener('mouseleave', (e) => handleHoverOut(nileFileUpload.setState, nileFileUpload.state));
50
+ nileFileUpload.addEventListener('dragenter', (e) => dragHandler.dragEnter(e));
51
+ nileFileUpload.addEventListener('dragleave', (e) => dragHandler.dragLeave(e));
52
+ nileFileUpload.addEventListener('dragover', (e) => dragHandler.dragOver(e));
53
+ nileFileUpload.addEventListener('drop', (e) => dragHandler.drop(e));
54
+ cancelFileUpload(nileFileUpload, uploadRequests);
55
+ };
56
+ export function handleHoverIn(setState, currentState) {
57
+ if (currentState === FileUploadState.DEFAULT) {
58
+ setState(FileUploadState.HOVER);
59
+ }
60
+ }
61
+ export function handleHoverOut(setState, currentState) {
62
+ if (currentState === FileUploadState.HOVER) {
63
+ setState(FileUploadState.DEFAULT);
64
+ }
65
+ }
66
+ export function uploadFiles(nileFileUpload) {
67
+ const { uploadedFiles, fileUploadUrl, uploadRequests } = nileFileUpload;
68
+ if (!fileUploadUrl || !uploadedFiles?.length)
69
+ return;
70
+ for (const file of uploadedFiles) {
71
+ const formData = new FormData();
72
+ formData.append('file', file);
73
+ const xhr = new XMLHttpRequest();
74
+ uploadRequests.set(file, xhr);
75
+ xhr.upload.onprogress = (e) => {
76
+ const percent = Math.floor((e.loaded / e.total) * 100);
77
+ nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_PROGRESS, {
78
+ detail: { file, progress: percent }
79
+ }));
80
+ };
81
+ xhr.onload = () => {
82
+ uploadRequests.delete(file);
83
+ if (xhr.status === 201) {
84
+ // Remove the successfully uploaded file
85
+ nileFileUpload.uploadedFiles = nileFileUpload.uploadedFiles.filter(f => f !== file);
86
+ nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_SUCCESS, {
87
+ detail: { file, response: xhr.response }
88
+ }));
89
+ }
90
+ else {
91
+ nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.SERVER_SIDE_ERROR, {
92
+ detail: { file, status: xhr.status, response: xhr.response }
93
+ }));
94
+ }
95
+ };
96
+ xhr.onerror = () => {
97
+ uploadRequests.delete(file);
98
+ nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_NETWORK_ERROR, {
99
+ detail: { file, status: xhr.status, response: xhr.response }
100
+ }));
101
+ };
102
+ xhr.open('POST', fileUploadUrl);
103
+ xhr.send(formData);
104
+ }
105
+ }
106
+ export const cancelFileUpload = (nileFileUpload, uploadRequests) => {
107
+ document.addEventListener(FileUploadEvent.NILE_CANCEL_UPLOAD, (e) => {
108
+ const fileToCancel = e.detail.file;
109
+ const xhr = uploadRequests.get(fileToCancel);
110
+ if (xhr) {
111
+ xhr.abort();
112
+ }
113
+ uploadRequests.delete(fileToCancel);
114
+ nileFileUpload.uploadedFiles = nileFileUpload.uploadedFiles.filter(file => file !== fileToCancel);
115
+ nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_CANCELLED, {
116
+ detail: { file: fileToCancel }
117
+ }));
118
+ });
119
+ };
120
+ //# sourceMappingURL=file-validation.util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-validation.util.js","sourceRoot":"","sources":["../../../../src/nile-file-upload/utils/file-validation.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { DragHandler } from \"./drag-drop.util\";\nimport { FileUploadState, FileUploadError, FileUploadEvent } from \"../types\";\nimport { NileFileUpload } from \"../nile-file-upload\";\n\n// write a function to check for duplicatse in the files name it as areDuplicates\nexport const areDuplicates = (files: File[], uploadedFiles: File[]): boolean => {\n return files.some(file =>\n uploadedFiles.some(existing =>\n file.name === existing.name &&\n file.size === existing.size &&\n file.lastModified === existing.lastModified\n )\n );\n};\n\n// set up the drag handler\nexport const setUpDragHandler = (\n nileFileUpload: NileFileUpload,\n dragHandler: DragHandler\n): void => {\n dragHandler.onStateChange((newState: FileUploadState) => {\n nileFileUpload.state = newState;\n });\n\n dragHandler.onFileDrop((files: File[]) => {\n let { allowMultiple, uploadedFiles, errorMessage, requestUpdate } = nileFileUpload;\n\n if (!allowMultiple) {\n const total = uploadedFiles.length + files.length;\n if (total > 1) {\n errorMessage = FileUploadError.MULTIPLE_NOT_ALLOWED;\n requestUpdate();\n return;\n }\n }\n\n let newFiles = files;\n\n if (!nileFileUpload.allowDuplicates) {\n newFiles = files.filter(file =>\n !nileFileUpload.uploadedFiles.some(\n uploaded =>\n uploaded.name === file.name &&\n uploaded.size === file.size &&\n uploaded.type === file.type\n )\n );\n\n if (newFiles.length === 0) {\n nileFileUpload.errorMessage = FileUploadError.DUPLICATES_NOT_ALLOWED;\n nileFileUpload.requestUpdate();\n return;\n }\n }\n\n nileFileUpload.uploadedFiles = [...nileFileUpload.uploadedFiles, ...newFiles];\n nileFileUpload.requestUpdate();\n });\n\n dragHandler.setErrorMessage((errorMessage: string) => {\n nileFileUpload.errorMessage = errorMessage;\n });\n};\n\n\n// global listenrers\nexport const addGlobalListeners = (dragHandler: DragHandler): void => {\n document.addEventListener('dragover', dragHandler.preventDragOver, { passive: false });\n document.addEventListener('drop', dragHandler.preventDrop, { passive: false });\n}\n\n// for hover & dragging functionality\nexport const addInternalListeners = (nileFileUpload: NileFileUpload, dragHandler: DragHandler, uploadRequests: any): void => {\n nileFileUpload.addEventListener('mouseenter', (e) => handleHoverIn(nileFileUpload.setState, nileFileUpload.state));\n nileFileUpload.addEventListener('mouseleave', (e) => handleHoverOut(nileFileUpload.setState, nileFileUpload.state));\n nileFileUpload.addEventListener('dragenter', (e) => dragHandler.dragEnter(e));\n nileFileUpload.addEventListener('dragleave', (e) => dragHandler.dragLeave(e));\n nileFileUpload.addEventListener('dragover', (e) => dragHandler.dragOver(e));\n nileFileUpload.addEventListener('drop', (e) => dragHandler.drop(e)); \n\n cancelFileUpload(nileFileUpload, uploadRequests);\n}\n\nexport function handleHoverIn(\n setState: (state: FileUploadState) => void,\n currentState: FileUploadState\n): void {\n if (currentState === FileUploadState.DEFAULT) {\n setState(FileUploadState.HOVER);\n }\n}\n\nexport function handleHoverOut(\n setState: (state: FileUploadState) => void,\n currentState: FileUploadState\n): void {\n if (currentState === FileUploadState.HOVER) {\n setState(FileUploadState.DEFAULT);\n }\n}\n\nexport function uploadFiles(nileFileUpload: NileFileUpload) {\n const { uploadedFiles, fileUploadUrl, uploadRequests } = nileFileUpload;\n if (!fileUploadUrl || !uploadedFiles?.length) return;\n\n for (const file of uploadedFiles) {\n const formData = new FormData();\n formData.append('file', file);\n\n const xhr = new XMLHttpRequest();\n uploadRequests.set(file, xhr);\n\n xhr.upload.onprogress = (e) => {\n const percent = Math.floor((e.loaded / e.total) * 100);\n nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_PROGRESS, {\n detail: { file, progress: percent }\n }));\n };\n\n xhr.onload = () => {\n uploadRequests.delete(file);\n if (xhr.status === 201) {\n // Remove the successfully uploaded file\n nileFileUpload.uploadedFiles = nileFileUpload.uploadedFiles.filter(f => f !== file);\n\n nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_SUCCESS, {\n detail: { file, response: xhr.response }\n }));\n } else {\n nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.SERVER_SIDE_ERROR, {\n detail: { file, status: xhr.status, response: xhr.response }\n }));\n }\n };\n\n xhr.onerror = () => {\n uploadRequests.delete(file);\n nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_NETWORK_ERROR, {\n detail: { file, status: xhr.status, response: xhr.response }\n }));\n };\n\n xhr.open('POST', fileUploadUrl);\n xhr.send(formData);\n }\n}\n\nexport const cancelFileUpload = (nileFileUpload: NileFileUpload, uploadRequests: Map<File, XMLHttpRequest>) => {\n document.addEventListener(FileUploadEvent.NILE_CANCEL_UPLOAD, (e: CustomEvent) => {\n const fileToCancel = e.detail.file;\n const xhr = uploadRequests.get(fileToCancel);\n\n if (xhr) {\n xhr.abort();\n }\n uploadRequests.delete(fileToCancel);\n nileFileUpload.uploadedFiles = nileFileUpload.uploadedFiles.filter(file => file !== fileToCancel);\n\n nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_CANCELLED, {\n detail: { file: fileToCancel }\n }));\n });\n};\n"]}
@@ -0,0 +1,18 @@
1
+ export declare function isInViewport(element: HTMLElement): boolean;
2
+ export declare function getValidTooltipPosition(triggerRect: DOMRect, tooltipRect: DOMRect, originalPlacement: string, distance: number, skidding: number, caretSize: number, viewportWidth: number, viewportHeight: number): {
3
+ top: number;
4
+ left: number;
5
+ placement: string;
6
+ };
7
+ export interface CaretPositionInput {
8
+ placement: string;
9
+ tooltipRect: DOMRect;
10
+ triggerRect: DOMRect;
11
+ caretSize: number;
12
+ left: number;
13
+ top: number;
14
+ }
15
+ export declare function getCaretPosition({ placement, tooltipRect, triggerRect, caretSize, left, top }: CaretPositionInput): {
16
+ caretLeft: number;
17
+ caretTop: number;
18
+ };
@@ -0,0 +1,216 @@
1
+ export function isInViewport(element) {
2
+ const rect = element.getBoundingClientRect();
3
+ return (rect.top >= 0 &&
4
+ rect.left >= 0 &&
5
+ rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&
6
+ rect.right <= (window.innerWidth || document.documentElement.clientWidth));
7
+ }
8
+ export function getValidTooltipPosition(triggerRect, tooltipRect, originalPlacement, distance, skidding, caretSize, viewportWidth, viewportHeight) {
9
+ const triggerCenterX = triggerRect.left + triggerRect.width / 2;
10
+ const getCandidatePosition = (placement) => {
11
+ let top = 0;
12
+ let left = 0;
13
+ switch (placement) {
14
+ case 'top':
15
+ top = triggerRect.top - tooltipRect.height - distance;
16
+ left = triggerRect.left + (triggerRect.width - tooltipRect.width) / 2 + skidding;
17
+ break;
18
+ case 'top-start': {
19
+ top = triggerRect.top - tooltipRect.height - distance;
20
+ const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;
21
+ left = Math.max(triggerRect.left + skidding, centeredLeft);
22
+ break;
23
+ }
24
+ case 'top-end': {
25
+ top = triggerRect.top - tooltipRect.height - distance;
26
+ const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;
27
+ const maxLeft = triggerRect.right - tooltipRect.width + skidding;
28
+ left = Math.min(centeredLeft, maxLeft);
29
+ break;
30
+ }
31
+ case 'bottom':
32
+ top = triggerRect.bottom + distance;
33
+ left = triggerRect.left + (triggerRect.width - tooltipRect.width) / 2 + skidding;
34
+ break;
35
+ case 'bottom-start': {
36
+ top = triggerRect.bottom + distance;
37
+ const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;
38
+ left = Math.max(triggerRect.left + skidding, centeredLeft);
39
+ break;
40
+ }
41
+ case 'bottom-end': {
42
+ top = triggerRect.bottom + distance;
43
+ const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;
44
+ const maxLeft = triggerRect.right - tooltipRect.width + skidding;
45
+ left = Math.min(centeredLeft, maxLeft);
46
+ break;
47
+ }
48
+ case 'left':
49
+ top = triggerRect.top + (triggerRect.height - tooltipRect.height) / 2 + skidding;
50
+ left = triggerRect.left - tooltipRect.width - distance;
51
+ break;
52
+ case 'left-start': {
53
+ const triggerCenterY = triggerRect.top + triggerRect.height / 2;
54
+ top = triggerCenterY - tooltipRect.height / 2;
55
+ left = triggerRect.left - tooltipRect.width - distance;
56
+ if (top < triggerRect.top) {
57
+ top = triggerRect.top;
58
+ }
59
+ break;
60
+ }
61
+ case 'left-end': {
62
+ const triggerCenterY = triggerRect.top + triggerRect.height / 2;
63
+ top = triggerCenterY - tooltipRect.height / 2;
64
+ left = triggerRect.left - tooltipRect.width - distance;
65
+ if (top + tooltipRect.height > triggerRect.bottom) {
66
+ top = triggerRect.bottom - tooltipRect.height;
67
+ }
68
+ break;
69
+ }
70
+ case 'right':
71
+ top = triggerRect.top + (triggerRect.height - tooltipRect.height) / 2 + skidding;
72
+ left = triggerRect.right + distance;
73
+ break;
74
+ case 'right-start': {
75
+ const triggerCenterY = triggerRect.top + triggerRect.height / 2;
76
+ top = triggerCenterY - tooltipRect.height / 2;
77
+ left = triggerRect.right + distance;
78
+ if (top < triggerRect.top) {
79
+ top = triggerRect.top;
80
+ }
81
+ break;
82
+ }
83
+ case 'right-end': {
84
+ const triggerCenterY = triggerRect.top + triggerRect.height / 2;
85
+ top = triggerCenterY - tooltipRect.height / 2;
86
+ left = triggerRect.right + distance;
87
+ if (top + tooltipRect.height > triggerRect.bottom) {
88
+ top = triggerRect.bottom - tooltipRect.height;
89
+ }
90
+ break;
91
+ }
92
+ default:
93
+ top = triggerRect.top - tooltipRect.height - distance;
94
+ left = triggerRect.left + (triggerRect.width - tooltipRect.width) / 2 + skidding;
95
+ }
96
+ return { top, left };
97
+ };
98
+ const candidateFits = (top, left) => top >= 0 &&
99
+ left >= 0 &&
100
+ top + tooltipRect.height <= viewportHeight &&
101
+ left + tooltipRect.width <= viewportWidth;
102
+ let placement = originalPlacement;
103
+ let candidate = getCandidatePosition(placement);
104
+ if (!candidateFits(candidate.top, candidate.left)) {
105
+ if (['top', 'top-start', 'top-end'].includes(originalPlacement)) {
106
+ placement = 'bottom';
107
+ }
108
+ else if (['bottom', 'bottom-start', 'bottom-end'].includes(originalPlacement)) {
109
+ placement = 'top';
110
+ }
111
+ else if (['right', 'right-start', 'right-end'].includes(originalPlacement)) {
112
+ placement = 'left';
113
+ }
114
+ else if (['left', 'left-start', 'left-end'].includes(originalPlacement)) {
115
+ placement = 'right';
116
+ }
117
+ candidate = getCandidatePosition(placement);
118
+ const leftCandidate = getCandidatePosition('left');
119
+ const bottomCandidate = getCandidatePosition('bottom');
120
+ const topCandidate = getCandidatePosition('top');
121
+ if (!candidateFits(leftCandidate.top, leftCandidate.left) &&
122
+ !candidateFits(bottomCandidate.top, bottomCandidate.left) &&
123
+ !candidateFits(topCandidate.top, topCandidate.left)) {
124
+ placement = 'right';
125
+ candidate = getCandidatePosition(placement);
126
+ }
127
+ else {
128
+ const rightCandidate = getCandidatePosition('right');
129
+ if (!candidateFits(rightCandidate.top, rightCandidate.left) &&
130
+ !candidateFits(bottomCandidate.top, bottomCandidate.left) &&
131
+ !candidateFits(topCandidate.top, topCandidate.left)) {
132
+ placement = 'left';
133
+ candidate = getCandidatePosition(placement);
134
+ }
135
+ }
136
+ }
137
+ if (candidate.left < 0) {
138
+ candidate.left = 5;
139
+ }
140
+ else if (candidate.left + tooltipRect.width > viewportWidth) {
141
+ candidate.left = viewportWidth - tooltipRect.width - 5;
142
+ }
143
+ if (candidate.top < 0) {
144
+ candidate.top = 5;
145
+ }
146
+ else if (candidate.top + tooltipRect.height > viewportHeight) {
147
+ candidate.top = viewportHeight - tooltipRect.height - 5;
148
+ }
149
+ return { ...candidate, placement };
150
+ }
151
+ export function getCaretPosition({ placement, tooltipRect, triggerRect, caretSize, left, top }) {
152
+ const triggerCenterX = triggerRect.left + triggerRect.width / 2;
153
+ const triggerCenterY = triggerRect.top + triggerRect.height / 2;
154
+ const [primaryPlacement, secondaryPlacement] = placement.split('-');
155
+ let caretLeft = 0;
156
+ let caretTop = 0;
157
+ switch (primaryPlacement) {
158
+ case 'top':
159
+ caretTop = tooltipRect.height - caretSize;
160
+ caretLeft = triggerCenterX - left - caretSize;
161
+ if (placement === 'top-end') {
162
+ caretLeft = triggerCenterX - left - caretSize;
163
+ }
164
+ else if (secondaryPlacement === 'start') {
165
+ caretLeft = triggerCenterX - left - caretSize;
166
+ }
167
+ else if (secondaryPlacement === 'end') {
168
+ caretLeft = tooltipRect.width - 2 * caretSize + 8;
169
+ }
170
+ caretLeft = Math.max(caretSize, Math.min(caretLeft, tooltipRect.width - 2 * caretSize));
171
+ break;
172
+ case 'bottom':
173
+ caretTop = -caretSize;
174
+ caretLeft = triggerCenterX - left - caretSize;
175
+ break;
176
+ case 'left':
177
+ caretLeft = tooltipRect.width - caretSize;
178
+ if (secondaryPlacement === 'start') {
179
+ const computedCaretTop = triggerCenterY - top - caretSize;
180
+ const minCaretTop = triggerRect.top - top;
181
+ caretTop = Math.max(computedCaretTop, minCaretTop);
182
+ }
183
+ else if (secondaryPlacement === 'end') {
184
+ const computedCaretTop = triggerCenterY - top - caretSize;
185
+ const maxCaretTop = triggerRect.bottom - top - 2 * caretSize;
186
+ caretTop = Math.min(computedCaretTop, maxCaretTop);
187
+ }
188
+ else {
189
+ caretTop = triggerCenterY - top - caretSize;
190
+ }
191
+ caretTop = Math.max(caretSize, Math.min(caretTop, tooltipRect.height - 2 * caretSize));
192
+ break;
193
+ case 'right':
194
+ caretLeft = -caretSize;
195
+ if (secondaryPlacement === 'start') {
196
+ const computedCaretTop = triggerCenterY - top - caretSize;
197
+ const minCaretTop = triggerRect.top - top;
198
+ caretTop = Math.max(computedCaretTop, minCaretTop);
199
+ }
200
+ else if (secondaryPlacement === 'end') {
201
+ const computedCaretTop = triggerCenterY - top - caretSize;
202
+ const maxCaretTop = triggerRect.bottom - top - 2 * caretSize;
203
+ caretTop = Math.min(computedCaretTop, maxCaretTop);
204
+ }
205
+ else {
206
+ caretTop = triggerCenterY - top - caretSize;
207
+ }
208
+ caretTop = Math.max(caretSize, Math.min(caretTop, tooltipRect.height - 2 * caretSize));
209
+ break;
210
+ default:
211
+ caretLeft = tooltipRect.width / 2 - caretSize;
212
+ caretTop = tooltipRect.height / 2 - caretSize;
213
+ }
214
+ return { caretLeft, caretTop };
215
+ }
216
+ //# sourceMappingURL=nile-tooltip-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nile-tooltip-utils.js","sourceRoot":"","sources":["../../../src/nile-tooltip/nile-tooltip-utils.ts"],"names":[],"mappings":"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","sourcesContent":["export function isInViewport(element: HTMLElement): boolean {\n const rect = element.getBoundingClientRect();\n return (\n rect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n rect.right <= (window.innerWidth || document.documentElement.clientWidth)\n );\n}\n\n\nexport function getValidTooltipPosition(\n triggerRect: DOMRect,\n tooltipRect: DOMRect,\n originalPlacement: string,\n distance: number,\n skidding: number,\n caretSize: number,\n viewportWidth: number,\n viewportHeight: number\n): { top: number; left: number; placement: string } {\n const triggerCenterX = triggerRect.left + triggerRect.width / 2;\n\n const getCandidatePosition = (placement: string) => {\n let top = 0;\n let left = 0;\n\n switch (placement) {\n case 'top':\n top = triggerRect.top - tooltipRect.height - distance;\n left = triggerRect.left + (triggerRect.width - tooltipRect.width) / 2 + skidding;\n break;\n case 'top-start': {\n top = triggerRect.top - tooltipRect.height - distance;\n const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;\n left = Math.max(triggerRect.left + skidding, centeredLeft);\n break;\n }\n case 'top-end': {\n top = triggerRect.top - tooltipRect.height - distance;\n const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;\n const maxLeft = triggerRect.right - tooltipRect.width + skidding;\n left = Math.min(centeredLeft, maxLeft);\n break;\n }\n\n case 'bottom':\n top = triggerRect.bottom + distance;\n left = triggerRect.left + (triggerRect.width - tooltipRect.width) / 2 + skidding;\n break;\n case 'bottom-start': {\n top = triggerRect.bottom + distance;\n const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;\n left = Math.max(triggerRect.left + skidding, centeredLeft);\n\n break;\n }\n\n case 'bottom-end': {\n top = triggerRect.bottom + distance;\n const centeredLeft = triggerRect.left + (triggerRect.width / 2) - (tooltipRect.width / 2) + skidding;\n const maxLeft = triggerRect.right - tooltipRect.width + skidding;\n left = Math.min(centeredLeft, maxLeft);\n break;\n }\n\n case 'left':\n top = triggerRect.top + (triggerRect.height - tooltipRect.height) / 2 + skidding;\n left = triggerRect.left - tooltipRect.width - distance;\n break;\n case 'left-start': {\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n top = triggerCenterY - tooltipRect.height / 2;\n left = triggerRect.left - tooltipRect.width - distance;\n if (top < triggerRect.top) {\n top = triggerRect.top;\n }\n break;\n }\n\n case 'left-end': {\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n top = triggerCenterY - tooltipRect.height / 2;\n left = triggerRect.left - tooltipRect.width - distance;\n if (top + tooltipRect.height > triggerRect.bottom) {\n top = triggerRect.bottom - tooltipRect.height;\n }\n\n break;\n }\n\n case 'right':\n top = triggerRect.top + (triggerRect.height - tooltipRect.height) / 2 + skidding;\n left = triggerRect.right + distance;\n break;\n case 'right-start': {\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n top = triggerCenterY - tooltipRect.height / 2;\n left = triggerRect.right + distance;\n if (top < triggerRect.top) {\n top = triggerRect.top;\n }\n\n break;\n }\n\n case 'right-end': {\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n top = triggerCenterY - tooltipRect.height / 2;\n left = triggerRect.right + distance;\n if (top + tooltipRect.height > triggerRect.bottom) {\n top = triggerRect.bottom - tooltipRect.height;\n }\n\n break;\n }\n\n default:\n top = triggerRect.top - tooltipRect.height - distance;\n left = triggerRect.left + (triggerRect.width - tooltipRect.width) / 2 + skidding;\n }\n\n return { top, left };\n };\n\n const candidateFits = (top: number, left: number) =>\n top >= 0 &&\n left >= 0 &&\n top + tooltipRect.height <= viewportHeight &&\n left + tooltipRect.width <= viewportWidth;\n\n let placement = originalPlacement;\n let candidate = getCandidatePosition(placement);\n\n if (!candidateFits(candidate.top, candidate.left)) {\n if (['top', 'top-start', 'top-end'].includes(originalPlacement)) {\n placement = 'bottom';\n } else if (['bottom', 'bottom-start', 'bottom-end'].includes(originalPlacement)) {\n placement = 'top';\n } else if (['right', 'right-start', 'right-end'].includes(originalPlacement)) {\n placement = 'left';\n } else if (['left', 'left-start', 'left-end'].includes(originalPlacement)) {\n placement = 'right';\n }\n candidate = getCandidatePosition(placement);\n const leftCandidate = getCandidatePosition('left');\n const bottomCandidate = getCandidatePosition('bottom');\n const topCandidate = getCandidatePosition('top');\n if (\n !candidateFits(leftCandidate.top, leftCandidate.left) &&\n !candidateFits(bottomCandidate.top, bottomCandidate.left) &&\n !candidateFits(topCandidate.top, topCandidate.left)\n ) {\n placement = 'right';\n candidate = getCandidatePosition(placement);\n }\n else {\n const rightCandidate = getCandidatePosition('right');\n if (\n !candidateFits(rightCandidate.top, rightCandidate.left) &&\n !candidateFits(bottomCandidate.top, bottomCandidate.left) &&\n !candidateFits(topCandidate.top, topCandidate.left)\n ) {\n placement = 'left';\n candidate = getCandidatePosition(placement);\n }\n }\n }\n\n if (candidate.left < 0) {\n candidate.left = 5;\n } else if (candidate.left + tooltipRect.width > viewportWidth) {\n candidate.left = viewportWidth - tooltipRect.width - 5;\n }\n\n if (candidate.top < 0) {\n candidate.top = 5;\n } else if (candidate.top + tooltipRect.height > viewportHeight) {\n candidate.top = viewportHeight - tooltipRect.height - 5;\n }\n\n return { ...candidate, placement };\n}\n\n\n\nexport interface CaretPositionInput {\n placement: string;\n tooltipRect: DOMRect;\n triggerRect: DOMRect;\n caretSize: number;\n left: number;\n top: number;\n}\n\nexport function getCaretPosition({\n placement,\n tooltipRect,\n triggerRect,\n caretSize,\n left,\n top\n}: CaretPositionInput): { caretLeft: number; caretTop: number } {\n const triggerCenterX = triggerRect.left + triggerRect.width / 2;\n const triggerCenterY = triggerRect.top + triggerRect.height / 2;\n\n const [primaryPlacement, secondaryPlacement] = placement.split('-');\n\n let caretLeft = 0;\n let caretTop = 0;\n\n switch (primaryPlacement) {\n case 'top':\n caretTop = tooltipRect.height - caretSize;\n caretLeft = triggerCenterX - left - caretSize;\n if (placement === 'top-end') {\n caretLeft = triggerCenterX - left - caretSize;\n } else if (secondaryPlacement === 'start') {\n caretLeft = triggerCenterX - left - caretSize;\n } else if (secondaryPlacement === 'end') {\n caretLeft = tooltipRect.width - 2 * caretSize + 8;\n }\n caretLeft = Math.max(caretSize, Math.min(caretLeft, tooltipRect.width - 2 * caretSize));\n break;\n\n case 'bottom':\n caretTop = -caretSize;\n caretLeft = triggerCenterX - left - caretSize;\n break;\n\n case 'left':\n caretLeft = tooltipRect.width - caretSize;\n if (secondaryPlacement === 'start') {\n const computedCaretTop = triggerCenterY - top - caretSize;\n const minCaretTop = triggerRect.top - top;\n caretTop = Math.max(computedCaretTop, minCaretTop);\n } else if (secondaryPlacement === 'end') {\n const computedCaretTop = triggerCenterY - top - caretSize;\n const maxCaretTop = triggerRect.bottom - top - 2 * caretSize;\n caretTop = Math.min(computedCaretTop, maxCaretTop);\n } else {\n caretTop = triggerCenterY - top - caretSize;\n }\n caretTop = Math.max(caretSize, Math.min(caretTop, tooltipRect.height - 2 * caretSize));\n break;\n\n\n case 'right':\n caretLeft = -caretSize;\n if (secondaryPlacement === 'start') {\n const computedCaretTop = triggerCenterY - top - caretSize;\n const minCaretTop = triggerRect.top - top;\n caretTop = Math.max(computedCaretTop, minCaretTop);\n } else if (secondaryPlacement === 'end') {\n const computedCaretTop = triggerCenterY - top - caretSize;\n const maxCaretTop = triggerRect.bottom - top - 2 * caretSize;\n caretTop = Math.min(computedCaretTop, maxCaretTop);\n } else {\n caretTop = triggerCenterY - top - caretSize;\n }\n caretTop = Math.max(caretSize, Math.min(caretTop, tooltipRect.height - 2 * caretSize));\n break;\n\n\n default:\n caretLeft = tooltipRect.width / 2 - caretSize;\n caretTop = tooltipRect.height / 2 - caretSize;\n }\n\n return { caretLeft, caretTop };\n}\n"]}
@@ -0,0 +1 @@
1
+ import './nile-tooltip';