@aquera/nile-elements 0.1.55-beta-1.1 → 0.1.55-beta-1.2

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 (418) hide show
  1. package/demo/index.html +389 -25
  2. package/dist/fixture-28d63bc4.cjs.js +395 -0
  3. package/dist/fixture-28d63bc4.cjs.js.map +1 -0
  4. package/dist/{fixture-3330277d.cjs.js → fixture-324a7ef9.cjs.js} +2 -2
  5. package/dist/{fixture-3330277d.cjs.js.map → fixture-324a7ef9.cjs.js.map} +1 -1
  6. package/dist/fixture-78a015b8.esm.js +569 -0
  7. package/dist/{fixture-588a3119.esm.js → fixture-ba65eb22.esm.js} +1 -1
  8. package/dist/index.js +117 -7
  9. package/dist/lit-html-39a6718c.esm.js +6 -0
  10. package/dist/lit-html-9b3af046.cjs.js +6 -0
  11. package/dist/lit-html-9b3af046.cjs.js.map +1 -0
  12. package/dist/nile-accordion/nile-accordian.test.cjs.js +1 -1
  13. package/dist/nile-accordion/nile-accordian.test.esm.js +1 -1
  14. package/dist/nile-auto-complete/nile-auto-complete.test.cjs.js +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-code-editor/theme.cjs.js +1 -1
  33. package/dist/nile-code-editor/theme.cjs.js.map +1 -1
  34. package/dist/nile-code-editor/theme.esm.js +1 -1
  35. package/dist/nile-dialog/nile-dialog.test.cjs.js +1 -1
  36. package/dist/nile-dialog/nile-dialog.test.esm.js +1 -1
  37. package/dist/nile-drawer/nile-drawer.test.cjs.js +1 -1
  38. package/dist/nile-drawer/nile-drawer.test.esm.js +1 -1
  39. package/dist/nile-dropdown/nile-dropdown.test.cjs.js +1 -1
  40. package/dist/nile-dropdown/nile-dropdown.test.esm.js +1 -1
  41. package/dist/nile-empty-state/nile-empty-state.test.cjs.js +1 -1
  42. package/dist/nile-empty-state/nile-empty-state.test.esm.js +1 -1
  43. package/dist/nile-error-message/nile-error-message.test.cjs.js +1 -1
  44. package/dist/nile-error-message/nile-error-message.test.esm.js +1 -1
  45. package/dist/nile-file-preview/index.cjs.js +2 -0
  46. package/dist/nile-file-preview/index.cjs.js.map +1 -0
  47. package/dist/nile-file-preview/index.esm.js +1 -0
  48. package/dist/nile-file-preview/nile-file-preview.cjs.js +2 -0
  49. package/dist/nile-file-preview/nile-file-preview.cjs.js.map +1 -0
  50. package/dist/nile-file-preview/nile-file-preview.css.cjs.js +2 -0
  51. package/dist/nile-file-preview/nile-file-preview.css.cjs.js.map +1 -0
  52. package/dist/nile-file-preview/nile-file-preview.css.esm.js +556 -0
  53. package/dist/nile-file-preview/nile-file-preview.esm.js +3 -0
  54. package/dist/nile-file-preview/nile-file-preview.template.cjs.js +2 -0
  55. package/dist/nile-file-preview/nile-file-preview.template.cjs.js.map +1 -0
  56. package/dist/nile-file-preview/nile-file-preview.template.esm.js +179 -0
  57. package/dist/nile-file-preview/nile-file-preview.test.cjs.js +2 -0
  58. package/dist/nile-file-preview/nile-file-preview.test.cjs.js.map +1 -0
  59. package/dist/nile-file-preview/nile-file-preview.test.esm.js +1 -0
  60. package/dist/nile-file-preview/types/index.cjs.js +2 -0
  61. package/dist/nile-file-preview/types/index.cjs.js.map +1 -0
  62. package/dist/nile-file-preview/types/index.esm.js +1 -0
  63. package/dist/nile-file-preview/types/nile-file-preview.enums.cjs.js +2 -0
  64. package/dist/nile-file-preview/types/nile-file-preview.enums.cjs.js.map +1 -0
  65. package/dist/nile-file-preview/types/nile-file-preview.enums.esm.js +1 -0
  66. package/dist/nile-file-preview/types/nile-file-preview.interface.cjs.js +2 -0
  67. package/dist/nile-file-preview/types/nile-file-preview.interface.cjs.js.map +1 -0
  68. package/dist/nile-file-preview/types/nile-file-preview.interface.esm.js +1 -0
  69. package/dist/nile-file-preview/utils/index.cjs.js +2 -0
  70. package/dist/nile-file-preview/utils/index.cjs.js.map +1 -0
  71. package/dist/nile-file-preview/utils/index.esm.js +1 -0
  72. package/dist/nile-file-preview/utils/nile-file-preview.util.cjs.js +2 -0
  73. package/dist/nile-file-preview/utils/nile-file-preview.util.cjs.js.map +1 -0
  74. package/dist/nile-file-preview/utils/nile-file-preview.util.esm.js +1 -0
  75. package/dist/nile-file-upload/index.cjs.js +2 -0
  76. package/dist/nile-file-upload/index.cjs.js.map +1 -0
  77. package/dist/nile-file-upload/index.esm.js +1 -0
  78. package/dist/nile-file-upload/nile-file-upload.cjs.js +2 -0
  79. package/dist/nile-file-upload/nile-file-upload.cjs.js.map +1 -0
  80. package/dist/nile-file-upload/nile-file-upload.css.cjs.js +2 -0
  81. package/dist/nile-file-upload/nile-file-upload.css.cjs.js.map +1 -0
  82. package/dist/nile-file-upload/nile-file-upload.css.esm.js +557 -0
  83. package/dist/nile-file-upload/nile-file-upload.esm.js +3 -0
  84. package/dist/nile-file-upload/nile-file-upload.template.cjs.js +10 -0
  85. package/dist/nile-file-upload/nile-file-upload.template.cjs.js.map +1 -0
  86. package/dist/nile-file-upload/nile-file-upload.template.esm.js +163 -0
  87. package/dist/nile-file-upload/nile-file-upload.test.cjs.js +2 -0
  88. package/dist/nile-file-upload/nile-file-upload.test.cjs.js.map +1 -0
  89. package/dist/nile-file-upload/nile-file-upload.test.esm.js +1 -0
  90. package/dist/nile-file-upload/types/file-upload.enums.cjs.js +2 -0
  91. package/dist/nile-file-upload/types/file-upload.enums.cjs.js.map +1 -0
  92. package/dist/nile-file-upload/types/file-upload.enums.esm.js +1 -0
  93. package/dist/nile-file-upload/types/file-upload.type.cjs.js +2 -0
  94. package/dist/nile-file-upload/types/file-upload.type.cjs.js.map +1 -0
  95. package/dist/nile-file-upload/types/file-upload.type.esm.js +1 -0
  96. package/dist/nile-file-upload/types/index.cjs.js +2 -0
  97. package/dist/nile-file-upload/types/index.cjs.js.map +1 -0
  98. package/dist/nile-file-upload/types/index.esm.js +1 -0
  99. package/dist/nile-file-upload/utils/drag-drop.util.cjs.js +2 -0
  100. package/dist/nile-file-upload/utils/drag-drop.util.cjs.js.map +1 -0
  101. package/dist/nile-file-upload/utils/drag-drop.util.esm.js +1 -0
  102. package/dist/nile-file-upload/utils/file-validation.util.cjs.js +2 -0
  103. package/dist/nile-file-upload/utils/file-validation.util.cjs.js.map +1 -0
  104. package/dist/nile-file-upload/utils/file-validation.util.esm.js +1 -0
  105. package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +1 -1
  106. package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +1 -1
  107. package/dist/nile-form-group/nile-form-group.test.cjs.js +1 -1
  108. package/dist/nile-form-group/nile-form-group.test.esm.js +1 -1
  109. package/dist/nile-form-help-text/nile-form-help-text.test.cjs.js +1 -1
  110. package/dist/nile-form-help-text/nile-form-help-text.test.esm.js +1 -1
  111. package/dist/nile-hero/nile-hero.test.cjs.js +1 -1
  112. package/dist/nile-hero/nile-hero.test.esm.js +1 -1
  113. package/dist/nile-icon/icons/svg/ng-activity.cjs.js +2 -0
  114. package/dist/nile-icon/icons/svg/ng-activity.cjs.js.map +1 -0
  115. package/dist/nile-icon/icons/svg/ng-activity.esm.js +1 -0
  116. package/dist/nile-icon/icons/svg/ng-align-center.cjs.js +2 -0
  117. package/dist/nile-icon/icons/svg/ng-align-center.cjs.js.map +1 -0
  118. package/dist/nile-icon/icons/svg/ng-align-center.esm.js +1 -0
  119. package/dist/nile-icon/icons/svg/ng-annotation-x.cjs.js +2 -0
  120. package/dist/nile-icon/icons/svg/ng-annotation-x.cjs.js.map +1 -0
  121. package/dist/nile-icon/icons/svg/ng-annotation-x.esm.js +1 -0
  122. package/dist/nile-icon/icons/svg/ng-arrow-down.cjs.js +2 -0
  123. package/dist/nile-icon/icons/svg/ng-arrow-down.cjs.js.map +1 -0
  124. package/dist/nile-icon/icons/svg/ng-arrow-down.esm.js +1 -0
  125. package/dist/nile-icon/icons/svg/ng-arrow-narrow-down.cjs.js +2 -0
  126. package/dist/nile-icon/icons/svg/ng-arrow-narrow-down.cjs.js.map +1 -0
  127. package/dist/nile-icon/icons/svg/ng-arrow-narrow-down.esm.js +1 -0
  128. package/dist/nile-icon/icons/svg/ng-arrow-narrow-left.cjs.js +2 -0
  129. package/dist/nile-icon/icons/svg/ng-arrow-narrow-left.cjs.js.map +1 -0
  130. package/dist/nile-icon/icons/svg/ng-arrow-narrow-left.esm.js +1 -0
  131. package/dist/nile-icon/icons/svg/ng-arrow-up.cjs.js +2 -0
  132. package/dist/nile-icon/icons/svg/ng-arrow-up.cjs.js.map +1 -0
  133. package/dist/nile-icon/icons/svg/ng-arrow-up.esm.js +1 -0
  134. package/dist/nile-icon/icons/svg/ng-bar-chart-12.cjs.js +2 -0
  135. package/dist/nile-icon/icons/svg/ng-bar-chart-12.cjs.js.map +1 -0
  136. package/dist/nile-icon/icons/svg/ng-bar-chart-12.esm.js +1 -0
  137. package/dist/nile-icon/icons/svg/ng-bell-01.cjs.js +2 -0
  138. package/dist/nile-icon/icons/svg/ng-bell-01.cjs.js.map +1 -0
  139. package/dist/nile-icon/icons/svg/ng-bell-01.esm.js +1 -0
  140. package/dist/nile-icon/icons/svg/ng-bell-ringing-04.cjs.js +2 -0
  141. package/dist/nile-icon/icons/svg/ng-bell-ringing-04.cjs.js.map +1 -0
  142. package/dist/nile-icon/icons/svg/ng-bell-ringing-04.esm.js +1 -0
  143. package/dist/nile-icon/icons/svg/ng-bold-01.cjs.js +2 -0
  144. package/dist/nile-icon/icons/svg/ng-bold-01.cjs.js.map +1 -0
  145. package/dist/nile-icon/icons/svg/ng-bold-01.esm.js +1 -0
  146. package/dist/nile-icon/icons/svg/ng-calendar-plus-02.cjs.js +2 -0
  147. package/dist/nile-icon/icons/svg/ng-calendar-plus-02.cjs.js.map +1 -0
  148. package/dist/nile-icon/icons/svg/ng-calendar-plus-02.esm.js +1 -0
  149. package/dist/nile-icon/icons/svg/ng-calendar.cjs.js +2 -0
  150. package/dist/nile-icon/icons/svg/ng-calendar.cjs.js.map +1 -0
  151. package/dist/nile-icon/icons/svg/ng-calendar.esm.js +1 -0
  152. package/dist/nile-icon/icons/svg/ng-check-circle.cjs.js +2 -0
  153. package/dist/nile-icon/icons/svg/ng-check-circle.cjs.js.map +1 -0
  154. package/dist/nile-icon/icons/svg/ng-check-circle.esm.js +1 -0
  155. package/dist/nile-icon/icons/svg/ng-check-square-broken.cjs.js +2 -0
  156. package/dist/nile-icon/icons/svg/ng-check-square-broken.cjs.js.map +1 -0
  157. package/dist/nile-icon/icons/svg/ng-check-square-broken.esm.js +1 -0
  158. package/dist/nile-icon/icons/svg/ng-chevron-down.cjs.js +2 -0
  159. package/dist/nile-icon/icons/svg/ng-chevron-down.cjs.js.map +1 -0
  160. package/dist/nile-icon/icons/svg/ng-chevron-down.esm.js +1 -0
  161. package/dist/nile-icon/icons/svg/ng-chevron-left.cjs.js +2 -0
  162. package/dist/nile-icon/icons/svg/ng-chevron-left.cjs.js.map +1 -0
  163. package/dist/nile-icon/icons/svg/ng-chevron-left.esm.js +1 -0
  164. package/dist/nile-icon/icons/svg/ng-chevron-right.cjs.js +2 -0
  165. package/dist/nile-icon/icons/svg/ng-chevron-right.cjs.js.map +1 -0
  166. package/dist/nile-icon/icons/svg/ng-chevron-right.esm.js +1 -0
  167. package/dist/nile-icon/icons/svg/ng-chevron-selector-vertical.cjs.js +2 -0
  168. package/dist/nile-icon/icons/svg/ng-chevron-selector-vertical.cjs.js.map +1 -0
  169. package/dist/nile-icon/icons/svg/ng-chevron-selector-vertical.esm.js +1 -0
  170. package/dist/nile-icon/icons/svg/ng-chevron-up-double.cjs.js +2 -0
  171. package/dist/nile-icon/icons/svg/ng-chevron-up-double.cjs.js.map +1 -0
  172. package/dist/nile-icon/icons/svg/ng-chevron-up-double.esm.js +1 -0
  173. package/dist/nile-icon/icons/svg/ng-chevron-up.cjs.js +2 -0
  174. package/dist/nile-icon/icons/svg/ng-chevron-up.cjs.js.map +1 -0
  175. package/dist/nile-icon/icons/svg/ng-chevron-up.esm.js +1 -0
  176. package/dist/nile-icon/icons/svg/ng-copy-03.cjs.js +2 -0
  177. package/dist/nile-icon/icons/svg/ng-copy-03.cjs.js.map +1 -0
  178. package/dist/nile-icon/icons/svg/ng-copy-03.esm.js +1 -0
  179. package/dist/nile-icon/icons/svg/ng-dots-grid.cjs.js +2 -0
  180. package/dist/nile-icon/icons/svg/ng-dots-grid.cjs.js.map +1 -0
  181. package/dist/nile-icon/icons/svg/ng-dots-grid.esm.js +1 -0
  182. package/dist/nile-icon/icons/svg/ng-dots-vertical.cjs.js +2 -0
  183. package/dist/nile-icon/icons/svg/ng-dots-vertical.cjs.js.map +1 -0
  184. package/dist/nile-icon/icons/svg/ng-dots-vertical.esm.js +1 -0
  185. package/dist/nile-icon/icons/svg/ng-download-01.cjs.js +2 -0
  186. package/dist/nile-icon/icons/svg/ng-download-01.cjs.js.map +1 -0
  187. package/dist/nile-icon/icons/svg/ng-download-01.esm.js +1 -0
  188. package/dist/nile-icon/icons/svg/ng-dropdown.cjs.js +2 -0
  189. package/dist/nile-icon/icons/svg/ng-dropdown.cjs.js.map +1 -0
  190. package/dist/nile-icon/icons/svg/ng-dropdown.esm.js +1 -0
  191. package/dist/nile-icon/icons/svg/ng-edit-02.cjs.js +2 -0
  192. package/dist/nile-icon/icons/svg/ng-edit-02.cjs.js.map +1 -0
  193. package/dist/nile-icon/icons/svg/ng-edit-02.esm.js +1 -0
  194. package/dist/nile-icon/icons/svg/ng-edit-05.cjs.js +2 -0
  195. package/dist/nile-icon/icons/svg/ng-edit-05.cjs.js.map +1 -0
  196. package/dist/nile-icon/icons/svg/ng-edit-05.esm.js +1 -0
  197. package/dist/nile-icon/icons/svg/ng-expand-06.cjs.js +2 -0
  198. package/dist/nile-icon/icons/svg/ng-expand-06.cjs.js.map +1 -0
  199. package/dist/nile-icon/icons/svg/ng-expand-06.esm.js +1 -0
  200. package/dist/nile-icon/icons/svg/ng-file-02.cjs.js +2 -0
  201. package/dist/nile-icon/icons/svg/ng-file-02.cjs.js.map +1 -0
  202. package/dist/nile-icon/icons/svg/ng-file-02.esm.js +1 -0
  203. package/dist/nile-icon/icons/svg/ng-file-check-02.cjs.js +2 -0
  204. package/dist/nile-icon/icons/svg/ng-file-check-02.cjs.js.map +1 -0
  205. package/dist/nile-icon/icons/svg/ng-file-check-02.esm.js +1 -0
  206. package/dist/nile-icon/icons/svg/ng-file-question-03.cjs.js +2 -0
  207. package/dist/nile-icon/icons/svg/ng-file-question-03.cjs.js.map +1 -0
  208. package/dist/nile-icon/icons/svg/ng-file-question-03.esm.js +1 -0
  209. package/dist/nile-icon/icons/svg/ng-filter-lines.cjs.js +2 -0
  210. package/dist/nile-icon/icons/svg/ng-filter-lines.cjs.js.map +1 -0
  211. package/dist/nile-icon/icons/svg/ng-filter-lines.esm.js +1 -0
  212. package/dist/nile-icon/icons/svg/ng-grid-01.cjs.js +2 -0
  213. package/dist/nile-icon/icons/svg/ng-grid-01.cjs.js.map +1 -0
  214. package/dist/nile-icon/icons/svg/ng-grid-01.esm.js +1 -0
  215. package/dist/nile-icon/icons/svg/ng-help-circle.cjs.js +2 -0
  216. package/dist/nile-icon/icons/svg/ng-help-circle.cjs.js.map +1 -0
  217. package/dist/nile-icon/icons/svg/ng-help-circle.esm.js +1 -0
  218. package/dist/nile-icon/icons/svg/ng-image-user-left.cjs.js +2 -0
  219. package/dist/nile-icon/icons/svg/ng-image-user-left.cjs.js.map +1 -0
  220. package/dist/nile-icon/icons/svg/ng-image-user-left.esm.js +1 -0
  221. package/dist/nile-icon/icons/svg/ng-info-circle.cjs.js +2 -0
  222. package/dist/nile-icon/icons/svg/ng-info-circle.cjs.js.map +1 -0
  223. package/dist/nile-icon/icons/svg/ng-info-circle.esm.js +1 -0
  224. package/dist/nile-icon/icons/svg/ng-italic-01.cjs.js +2 -0
  225. package/dist/nile-icon/icons/svg/ng-italic-01.cjs.js.map +1 -0
  226. package/dist/nile-icon/icons/svg/ng-italic-01.esm.js +1 -0
  227. package/dist/nile-icon/icons/svg/ng-layers-three-01.cjs.js +2 -0
  228. package/dist/nile-icon/icons/svg/ng-layers-three-01.cjs.js.map +1 -0
  229. package/dist/nile-icon/icons/svg/ng-layers-three-01.esm.js +1 -0
  230. package/dist/nile-icon/icons/svg/ng-list.cjs.js +2 -0
  231. package/dist/nile-icon/icons/svg/ng-list.cjs.js.map +1 -0
  232. package/dist/nile-icon/icons/svg/ng-list.esm.js +1 -0
  233. package/dist/nile-icon/icons/svg/ng-log-out-01.cjs.js +2 -0
  234. package/dist/nile-icon/icons/svg/ng-log-out-01.cjs.js.map +1 -0
  235. package/dist/nile-icon/icons/svg/ng-log-out-01.esm.js +1 -0
  236. package/dist/nile-icon/icons/svg/ng-mail-01.cjs.js +2 -0
  237. package/dist/nile-icon/icons/svg/ng-mail-01.cjs.js.map +1 -0
  238. package/dist/nile-icon/icons/svg/ng-mail-01.esm.js +1 -0
  239. package/dist/nile-icon/icons/svg/ng-mail-04.cjs.js +2 -0
  240. package/dist/nile-icon/icons/svg/ng-mail-04.cjs.js.map +1 -0
  241. package/dist/nile-icon/icons/svg/ng-mail-04.esm.js +1 -0
  242. package/dist/nile-icon/icons/svg/ng-menu-05.cjs.js +2 -0
  243. package/dist/nile-icon/icons/svg/ng-menu-05.cjs.js.map +1 -0
  244. package/dist/nile-icon/icons/svg/ng-menu-05.esm.js +1 -0
  245. package/dist/nile-icon/icons/svg/ng-message-text-square-01.cjs.js +2 -0
  246. package/dist/nile-icon/icons/svg/ng-message-text-square-01.cjs.js.map +1 -0
  247. package/dist/nile-icon/icons/svg/ng-message-text-square-01.esm.js +1 -0
  248. package/dist/nile-icon/icons/svg/ng-minimize-02.cjs.js +2 -0
  249. package/dist/nile-icon/icons/svg/ng-minimize-02.cjs.js.map +1 -0
  250. package/dist/nile-icon/icons/svg/ng-minimize-02.esm.js +1 -0
  251. package/dist/nile-icon/icons/svg/ng-plus.cjs.js +2 -0
  252. package/dist/nile-icon/icons/svg/ng-plus.cjs.js.map +1 -0
  253. package/dist/nile-icon/icons/svg/ng-plus.esm.js +1 -0
  254. package/dist/nile-icon/icons/svg/ng-refresh-cw-02.cjs.js +2 -0
  255. package/dist/nile-icon/icons/svg/ng-refresh-cw-02.cjs.js.map +1 -0
  256. package/dist/nile-icon/icons/svg/ng-refresh-cw-02.esm.js +1 -0
  257. package/dist/nile-icon/icons/svg/ng-rocket-02.cjs.js +2 -0
  258. package/dist/nile-icon/icons/svg/ng-rocket-02.cjs.js.map +1 -0
  259. package/dist/nile-icon/icons/svg/ng-rocket-02.esm.js +1 -0
  260. package/dist/nile-icon/icons/svg/ng-search-lg.cjs.js +2 -0
  261. package/dist/nile-icon/icons/svg/ng-search-lg.cjs.js.map +1 -0
  262. package/dist/nile-icon/icons/svg/ng-search-lg.esm.js +1 -0
  263. package/dist/nile-icon/icons/svg/ng-send-01.cjs.js +2 -0
  264. package/dist/nile-icon/icons/svg/ng-send-01.cjs.js.map +1 -0
  265. package/dist/nile-icon/icons/svg/ng-send-01.esm.js +1 -0
  266. package/dist/nile-icon/icons/svg/ng-settings-01.cjs.js +2 -0
  267. package/dist/nile-icon/icons/svg/ng-settings-01.cjs.js.map +1 -0
  268. package/dist/nile-icon/icons/svg/ng-settings-01.esm.js +1 -0
  269. package/dist/nile-icon/icons/svg/ng-share-04.cjs.js +2 -0
  270. package/dist/nile-icon/icons/svg/ng-share-04.cjs.js.map +1 -0
  271. package/dist/nile-icon/icons/svg/ng-share-04.esm.js +1 -0
  272. package/dist/nile-icon/icons/svg/ng-share-06.cjs.js +2 -0
  273. package/dist/nile-icon/icons/svg/ng-share-06.cjs.js.map +1 -0
  274. package/dist/nile-icon/icons/svg/ng-share-06.esm.js +1 -0
  275. package/dist/nile-icon/icons/svg/ng-stars-02.cjs.js +2 -0
  276. package/dist/nile-icon/icons/svg/ng-stars-02.cjs.js.map +1 -0
  277. package/dist/nile-icon/icons/svg/ng-stars-02.esm.js +1 -0
  278. package/dist/nile-icon/icons/svg/ng-trash-01.cjs.js +2 -0
  279. package/dist/nile-icon/icons/svg/ng-trash-01.cjs.js.map +1 -0
  280. package/dist/nile-icon/icons/svg/ng-trash-01.esm.js +1 -0
  281. package/dist/nile-icon/icons/svg/ng-trash-03.cjs.js +2 -0
  282. package/dist/nile-icon/icons/svg/ng-trash-03.cjs.js.map +1 -0
  283. package/dist/nile-icon/icons/svg/ng-trash-03.esm.js +1 -0
  284. package/dist/nile-icon/icons/svg/ng-trend-up-01.cjs.js +2 -0
  285. package/dist/nile-icon/icons/svg/ng-trend-up-01.cjs.js.map +1 -0
  286. package/dist/nile-icon/icons/svg/ng-trend-up-01.esm.js +1 -0
  287. package/dist/nile-icon/icons/svg/ng-underline-01.cjs.js +2 -0
  288. package/dist/nile-icon/icons/svg/ng-underline-01.cjs.js.map +1 -0
  289. package/dist/nile-icon/icons/svg/ng-underline-01.esm.js +1 -0
  290. package/dist/nile-icon/icons/svg/ng-upload-01.cjs.js +2 -0
  291. package/dist/nile-icon/icons/svg/ng-upload-01.cjs.js.map +1 -0
  292. package/dist/nile-icon/icons/svg/ng-upload-01.esm.js +1 -0
  293. package/dist/nile-icon/icons/svg/ng-upload-cloud-02.cjs.js +2 -0
  294. package/dist/nile-icon/icons/svg/ng-upload-cloud-02.cjs.js.map +1 -0
  295. package/dist/nile-icon/icons/svg/ng-upload-cloud-02.esm.js +1 -0
  296. package/dist/nile-icon/icons/svg/ng-user-01.cjs.js +2 -0
  297. package/dist/nile-icon/icons/svg/ng-user-01.cjs.js.map +1 -0
  298. package/dist/nile-icon/icons/svg/ng-user-01.esm.js +1 -0
  299. package/dist/nile-icon/icons/svg/ng-user-check-02-1.cjs.js +2 -0
  300. package/dist/nile-icon/icons/svg/ng-user-check-02-1.cjs.js.map +1 -0
  301. package/dist/nile-icon/icons/svg/ng-user-check-02-1.esm.js +1 -0
  302. package/dist/nile-icon/icons/svg/ng-user-check-02.cjs.js +2 -0
  303. package/dist/nile-icon/icons/svg/ng-user-check-02.cjs.js.map +1 -0
  304. package/dist/nile-icon/icons/svg/ng-user-check-02.esm.js +1 -0
  305. package/dist/nile-icon/icons/svg/ng-user-plus-02.cjs.js +2 -0
  306. package/dist/nile-icon/icons/svg/ng-user-plus-02.cjs.js.map +1 -0
  307. package/dist/nile-icon/icons/svg/ng-user-plus-02.esm.js +1 -0
  308. package/dist/nile-icon/icons/svg/ng-user-right-01.cjs.js +2 -0
  309. package/dist/nile-icon/icons/svg/ng-user-right-01.cjs.js.map +1 -0
  310. package/dist/nile-icon/icons/svg/ng-user-right-01.esm.js +1 -0
  311. package/dist/nile-icon/icons/svg/ng-users-01.cjs.js +2 -0
  312. package/dist/nile-icon/icons/svg/ng-users-01.cjs.js.map +1 -0
  313. package/dist/nile-icon/icons/svg/ng-users-01.esm.js +1 -0
  314. package/dist/nile-icon/icons/svg/ng-x-close.cjs.js +2 -0
  315. package/dist/nile-icon/icons/svg/ng-x-close.cjs.js.map +1 -0
  316. package/dist/nile-icon/icons/svg/ng-x-close.esm.js +1 -0
  317. package/dist/nile-icon/icons/svg/ng-x-square.cjs.js +2 -0
  318. package/dist/nile-icon/icons/svg/ng-x-square.cjs.js.map +1 -0
  319. package/dist/nile-icon/icons/svg/ng-x-square.esm.js +1 -0
  320. package/dist/nile-icon/nile-icon.test.cjs.js +1 -1
  321. package/dist/nile-icon/nile-icon.test.esm.js +1 -1
  322. package/dist/nile-input/nile-input.test.cjs.js +1 -1
  323. package/dist/nile-input/nile-input.test.esm.js +1 -1
  324. package/dist/nile-link/nile-link.test.cjs.js +1 -1
  325. package/dist/nile-link/nile-link.test.esm.js +1 -1
  326. package/dist/nile-loader/nile-loader.test.cjs.js +1 -1
  327. package/dist/nile-loader/nile-loader.test.esm.js +1 -1
  328. package/dist/nile-popover/nile-popover.test.cjs.js +1 -1
  329. package/dist/nile-popover/nile-popover.test.esm.js +1 -1
  330. package/dist/nile-popup/nile-popup.test.cjs.js +1 -1
  331. package/dist/nile-popup/nile-popup.test.esm.js +1 -1
  332. package/dist/nile-progress-bar/nile-progress-bar.test.cjs.js +1 -1
  333. package/dist/nile-progress-bar/nile-progress-bar.test.esm.js +1 -1
  334. package/dist/nile-radio/nile-radio.test.cjs.js +1 -1
  335. package/dist/nile-radio/nile-radio.test.esm.js +1 -1
  336. package/dist/nile-radio-group/nile-radio-group.test.cjs.js +1 -1
  337. package/dist/nile-radio-group/nile-radio-group.test.esm.js +1 -1
  338. package/dist/nile-select/nile-select.test.cjs.js +1 -1
  339. package/dist/nile-select/nile-select.test.esm.js +1 -1
  340. package/dist/nile-slide-toggle/nile-slide-toggle.test.cjs.js +1 -1
  341. package/dist/nile-slide-toggle/nile-slide-toggle.test.esm.js +1 -1
  342. package/dist/nile-tab-group/nile-tab-group.test.cjs.js +1 -1
  343. package/dist/nile-tab-group/nile-tab-group.test.esm.js +1 -1
  344. package/dist/nile-table-row/nile-table-row.cjs.js +1 -1
  345. package/dist/nile-table-row/nile-table-row.cjs.js.map +1 -1
  346. package/dist/nile-table-row/nile-table-row.css.cjs.js +1 -1
  347. package/dist/nile-table-row/nile-table-row.css.cjs.js.map +1 -1
  348. package/dist/nile-table-row/nile-table-row.css.esm.js +91 -0
  349. package/dist/nile-table-row/nile-table-row.esm.js +25 -6
  350. package/dist/nile-textarea/nile-textarea.test.cjs.js +1 -1
  351. package/dist/nile-textarea/nile-textarea.test.esm.js +1 -1
  352. package/dist/src/nile-calendar/test.d.ts +0 -0
  353. package/dist/src/nile-calendar/test.js +2 -0
  354. package/dist/src/nile-calendar/test.js.map +1 -0
  355. package/dist/src/nile-code-editor/theme.d.ts +2 -41
  356. package/dist/src/nile-code-editor/theme.js +12 -51
  357. package/dist/src/nile-code-editor/theme.js.map +1 -1
  358. package/dist/src/nile-file-preview/nile-file-preview.css.js +156 -112
  359. package/dist/src/nile-file-preview/nile-file-preview.css.js.map +1 -1
  360. package/dist/src/nile-file-preview/nile-file-preview.js +1 -1
  361. package/dist/src/nile-file-preview/nile-file-preview.js.map +1 -1
  362. package/dist/src/nile-file-preview/nile-file-preview.template.js +21 -16
  363. package/dist/src/nile-file-preview/nile-file-preview.template.js.map +1 -1
  364. package/dist/src/nile-file-preview/types/nile-file-preview.enums.d.ts +1 -0
  365. package/dist/src/nile-file-preview/types/nile-file-preview.enums.js +1 -0
  366. package/dist/src/nile-file-preview/types/nile-file-preview.enums.js.map +1 -1
  367. package/dist/src/nile-file-preview/utils/nile-file-preview.util.d.ts +0 -1
  368. package/dist/src/nile-file-preview/utils/nile-file-preview.util.js +0 -12
  369. package/dist/src/nile-file-preview/utils/nile-file-preview.util.js.map +1 -1
  370. package/dist/src/nile-file-upload/nile-file-upload.css.js +74 -55
  371. package/dist/src/nile-file-upload/nile-file-upload.css.js.map +1 -1
  372. package/dist/src/nile-file-upload/nile-file-upload.d.ts +1 -1
  373. package/dist/src/nile-file-upload/nile-file-upload.js +19 -16
  374. package/dist/src/nile-file-upload/nile-file-upload.js.map +1 -1
  375. package/dist/src/nile-file-upload/nile-file-upload.template.d.ts +5 -4
  376. package/dist/src/nile-file-upload/nile-file-upload.template.js +70 -16
  377. package/dist/src/nile-file-upload/nile-file-upload.template.js.map +1 -1
  378. package/dist/src/nile-file-upload/types/file-upload.enums.d.ts +2 -3
  379. package/dist/src/nile-file-upload/types/file-upload.enums.js +2 -3
  380. package/dist/src/nile-file-upload/types/file-upload.enums.js.map +1 -1
  381. package/dist/src/nile-file-upload/utils/drag-drop.util.d.ts +4 -2
  382. package/dist/src/nile-file-upload/utils/drag-drop.util.js +21 -18
  383. package/dist/src/nile-file-upload/utils/drag-drop.util.js.map +1 -1
  384. package/dist/src/nile-file-upload/utils/file-validation.util.d.ts +1 -3
  385. package/dist/src/nile-file-upload/utils/file-validation.util.js +16 -44
  386. package/dist/src/nile-file-upload/utils/file-validation.util.js.map +1 -1
  387. package/dist/src/nile-table-row/nile-table-row.css.js +91 -0
  388. package/dist/src/nile-table-row/nile-table-row.css.js.map +1 -1
  389. package/dist/src/nile-table-row/nile-table-row.d.ts +17 -17
  390. package/dist/src/nile-table-row/nile-table-row.js +68 -32
  391. package/dist/src/nile-table-row/nile-table-row.js.map +1 -1
  392. package/dist/tsconfig.tsbuildinfo +1 -1
  393. package/package.json +1 -1
  394. package/src/nile-code-editor/theme.ts +12 -51
  395. package/src/nile-table-row/nile-table-row.css.ts +91 -0
  396. package/src/nile-table-row/nile-table-row.ts +59 -37
  397. package/vscode-html-custom-data.json +17 -2
  398. package/dist/src/nile-slider/index.d.ts +0 -1
  399. package/dist/src/nile-slider/index.js +0 -2
  400. package/dist/src/nile-slider/index.js.map +0 -1
  401. package/dist/src/nile-slider/nile-slider.css.d.ts +0 -12
  402. package/dist/src/nile-slider/nile-slider.css.js +0 -110
  403. package/dist/src/nile-slider/nile-slider.css.js.map +0 -1
  404. package/dist/src/nile-slider/nile-slider.d.ts +0 -47
  405. package/dist/src/nile-slider/nile-slider.js +0 -181
  406. package/dist/src/nile-slider/nile-slider.js.map +0 -1
  407. package/dist/src/nile-slider/nile-slider.template.d.ts +0 -5
  408. package/dist/src/nile-slider/nile-slider.template.js +0 -44
  409. package/dist/src/nile-slider/nile-slider.template.js.map +0 -1
  410. package/dist/src/nile-slider/types/nile-slider.enums.d.ts +0 -10
  411. package/dist/src/nile-slider/types/nile-slider.enums.js +0 -2
  412. package/dist/src/nile-slider/types/nile-slider.enums.js.map +0 -1
  413. package/dist/src/nile-slider/types/nile-slider.types.d.ts +0 -1
  414. package/dist/src/nile-slider/types/nile-slider.types.js +0 -2
  415. package/dist/src/nile-slider/types/nile-slider.types.js.map +0 -1
  416. package/dist/src/nile-slider/utils/nile-slider.utils.d.ts +0 -11
  417. package/dist/src/nile-slider/utils/nile-slider.utils.js +0 -86
  418. package/dist/src/nile-slider/utils/nile-slider.utils.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"nile-file-upload.template.js","sourceRoot":"","sources":["../../../src/nile-file-upload/nile-file-upload.template.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, TemplateResult } from 'lit';\nimport './nile-file-upload.css';\nimport { DragHandler } from './utils/drag-drop.util';\nimport { classMap } from 'lit-html/directives/class-map.js';\nimport { FileUploadState } from './types/file-upload.enums';\n\nconst baseHorizontalState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n disabled: boolean,\n dragHandler: DragHandler,\n state: FileUploadState,\n errorMessage: string\n): TemplateResult => html`\n <div>\n <div class=${classMap({ 'hover-border': state === \"hover\", 'horizontal-div': true, 'disable': disabled })}>\n <div class=\"inner-div\">\n <slot name=\"uploadIcon\">\n <nile-icon name=\"upload\" size=\"24\"></nile-icon>\n </slot>\n <div class=\"content\">\n <slot name=\"title\">\n <h4>${title}</h4>\n </slot>\n <slot name=\"subtitle\">\n <p>${subtitle}</p>\n </slot>\n </div>\n </div>\n <input\n type=\"file\"\n ?disabled=${disabled}\n @change=${(e: Event | DragEvent) => { dragHandler.handleFiles(e) }}\n multiple\n />\n <slot @click=${disabled ? undefined : browseFiles} name=\"browseFileButton\">\n <nile-button variant=\"tertiary\" ?disabled=${disabled}>\n Browse File\n </nile-button>\n </slot>\n </div>\n ${errorMessage ?\n html`<div class=\"upload-error\">\n <nile-icon name=\"warning\" size=\"12\" color=\"red\"></nile-icon>\n <span>${errorMessage}</span>\n </div>` :\n html``\n }\n </div>\n`;\n\nexport const getHorizontalDefaultState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n dragHandler: DragHandler,\n state: FileUploadState,\n errorMessage: string\n): TemplateResult => baseHorizontalState(browseFiles, title, subtitle, false, dragHandler, state, errorMessage);\n\nexport const getHorizontalDisabledState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n dragHandler: DragHandler,\n state: FileUploadState,\n errorMessage: string\n): TemplateResult => baseHorizontalState(browseFiles, title, subtitle, true, dragHandler, state, errorMessage);\n\nexport const getHorizontalDragState = (): TemplateResult => html`\n <div class=\"horizontal-div dragging\">\n <div class=\"icons-container\">\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"general\"\n size=\"20\"\n class=\"general-icon\"\n ></nile-icon>\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"image\"\n size=\"24\"\n class=\"image-icon\"\n ></nile-icon>\n </div>\n <p>Drop files here to upload</p>\n </div>\n`;\n\n// Vertical States\nconst baseVerticalState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n disabled: boolean,\n dragHandler: DragHandler,\n errorMessage: string\n): TemplateResult => html`\n <div>\n <div class=\"vertical-default vertical-div ${disabled ? 'disable' : ''}\">\n <slot name=\"uploadIcon\">\n <nile-icon name=\"upload\" size=\"24\"></nile-icon>\n </slot>\n <div class=\"content-container\">\n <slot name=\"title\">\n <h4>${title}</h4>\n </slot>\n <slot name=\"subtitle\">\n <p>${subtitle}</p>\n </slot>\n </div>\n <input\n type=\"file\"\n ?disabled=${disabled}\n @change=${(e: Event | DragEvent) => dragHandler.handleFiles(e)}\n multiple\n />\n <slot @click=${disabled ? undefined : browseFiles} name=\"browseFileButton\">\n <nile-button variant=\"tertiary\" ?disabled=${disabled}>\n Browse File\n </nile-button>\n </slot>\n </div>\n ${errorMessage ?\n html`<div class=\"upload-error\">\n <nile-icon name=\"warning\" size=\"12\" color=\"red\"></nile-icon>\n <span>${errorMessage}</span>\n </div>` :\n html``\n }\n </div>\n`;\n\nexport const getVerticalDefaultState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n dragHandler: DragHandler,\n errorMessage: string\n): TemplateResult => baseVerticalState(browseFiles, title, subtitle, false, dragHandler, errorMessage);\n\nexport const getVerticalDisabledState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n dragHandler: DragHandler,\n errorMessage: string\n): TemplateResult => baseVerticalState(browseFiles, title, subtitle, true, dragHandler, errorMessage);\n\n\nexport const getVerticalDragState = (): TemplateResult => html`\n <div class=\"vertical-div vertical-drag\">\n <div class=\"icons-container\">\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"general\"\n size=\"20\"\n class=\"general-icon\"\n ></nile-icon>\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"image\"\n size=\"24\"\n class=\"image-icon\"\n ></nile-icon>\n </div>\n <p>Drop files here to upload</p>\n </div>\n`;"]}
1
+ {"version":3,"file":"nile-file-upload.template.js","sourceRoot":"","sources":["../../../src/nile-file-upload/nile-file-upload.template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAkB,MAAM,KAAK,CAAC;AAC3C,OAAO,wBAAwB,CAAC;AAEhC,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAC;AAG5D,IAAI,mBAAgC,CAAC;AACrC,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,WAAwB,EAAQ,EAAE;IAC/D,mBAAmB,GAAG,WAAW,CAAC;AACpC,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,yBAAyB,GAAG,CACvC,WAAqB,EACrB,KAAa,EACb,QAAgB,EAChB,YAAoB,EACpB,KAAsB,EACN,EAAE,CAAC,IAAI,CAAA;;iBAER,QAAQ,CAAC,EAAE,cAAc,EAAE,KAAK,KAAK,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC;;;;;;;kBAOtE,KAAK;;;iBAGN,QAAQ;;;;;;kBAMP,CAAC,CAAoB,EAAE,EAAE,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC;;;qBAGzD,WAAW;;;;;;MAM1B,YAAY,CAAC,CAAC;IACd,IAAI,CAAA;;gBAEM,YAAY;aACf,CAAC,CAAC;IACT,IAAI,CAAA,EACN;;CAEH,CAAC;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAG,CACzC,WAAqB,EACrB,KAAa,EACb,QAAgB,EACA,EAAE,CAAC,IAAI,CAAA;;;;;;;;;;gBAUT,KAAK;;;eAGN,QAAQ;;;;;;gBAMP,CAAC,CAAoB,EAAE,EAAE,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC;;;mBAGzD,WAAW;;;;;;CAM7B,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,GAAmB,EAAE,CAAC,IAAI,CAAA;;;;;;;;;;;;;;;;;;CAkB/D,CAAC;AAEF,mBAAmB;AACnB,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACrC,WAAqB,EACrB,KAAa,EACb,QAAgB,EAChB,YAAoB,EACpB,KAAsB,EACN,EAAE,CAAC,IAAI,CAAA;;iBAER,QAAQ,CAAC,EAAE,cAAc,EAAE,KAAK,KAAK,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC;;;;;;gBAMtE,KAAK;;;eAGN,QAAQ;;;;;kBAKL,CAAC,CAAoB,EAAE,EAAE,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC;;;qBAGzD,WAAW;;;;;;MAM1B,YAAY,CAAC,CAAC;IACd,IAAI,CAAA;;gBAEM,YAAY;aACf,CAAC,CAAC;IACT,IAAI,CAAA,EACN;;CAEH,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,WAAqB,EACrB,KAAa,EACb,QAAgB,EACA,EAAE,CAAC,IAAI,CAAA;;;;;;;;;cASX,KAAK;;;aAGN,QAAQ;;;;;gBAKL,CAAC,CAAoB,EAAE,EAAE,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC;;;mBAGzD,WAAW;;;;;;CAM7B,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAmB,EAAE,CAAC,IAAI,CAAA;;;;;;;;;;;;;;;;;;CAkB7D,CAAC","sourcesContent":["import { html, TemplateResult } from 'lit';\nimport './nile-file-upload.css';\nimport { DragHandler } from './utils/drag-drop.util';\nimport { classMap } from 'lit-html/directives/class-map.js';\nimport { FileUploadState } from './types/file-upload.enums';\n\nlet dragHandlerInstance: DragHandler;\nexport const getDragHandler = (dragHandler: DragHandler): void => {\n dragHandlerInstance = dragHandler;\n}\n\nexport const getHorizontalDefaultState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n errorMessage: string,\n state: FileUploadState\n): TemplateResult => html`\n <div>\n <div class=${classMap({ 'hover-border': state === \"hover\", 'horizontal-div': true })}>\n <div class=\"inner-div\">\n <slot name=\"uploadIcon\">\n <nile-icon name=\"upload\" size=\"24\"></nile-icon>\n </slot>\n <div class=\"content\">\n <slot name=\"title\">\n <h4>${title}</h4>\n </slot>\n <slot name=\"subtitle\">\n <p>${subtitle}</p>\n </slot>\n </div>\n </div>\n <input\n type=\"file\"\n @change=${(e: Event | DragEvent) => dragHandlerInstance.handleFiles(e)}\n multiple\n />\n <slot @click=${browseFiles} name=\"browseFileButton\">\n <nile-button variant=\"tertiary\">\n Browse File\n </nile-button>\n </slot>\n </div>\n ${errorMessage ?\n html`<div class=\"upload-error\">\n <nile-icon name=\"warning\" size=\"12\" color=\"red\"></nile-icon>\n <span>${errorMessage}</span>\n </div>` :\n html``\n }\n </div>\n`;\n\nexport const getHorizontalDisabledtState = (\n browseFiles: Function,\n title: string,\n subtitle: string\n): TemplateResult => html`\n <div\n class=\"horizontal-div disable\"\n >\n <div class=\"inner-div\">\n <slot name=\"uploadIcon\">\n <nile-icon name=\"upload\" size=\"24\"></nile-icon>\n </slot>\n <div class=\"content\">\n <slot name=\"title\">\n <h4>${title}</h4>\n </slot>\n <slot name=\"subtitle\">\n <p>${subtitle}</p>\n </slot>\n </div>\n </div>\n <input\n type=\"file\"\n @change=${(e: Event | DragEvent) => dragHandlerInstance.handleFiles(e)}\n multiple\n />\n <slot @click=${browseFiles} name=\"browseFileButton\">\n <nile-button variant=\"tertiary\">\n Browse File\n </nile-button>\n </slot>\n </div>\n`;\n\nexport const getHorizontalDragState = (): TemplateResult => html`\n <div class=\"horizontal-div dragging\">\n <div class=\"icons-container\">\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"general\"\n size=\"20\"\n class=\"general-icon\"\n ></nile-icon>\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"image\"\n size=\"24\"\n class=\"image-icon\"\n ></nile-icon>\n </div>\n <p>Drop files here to upload</p>\n </div>\n`;\n\n// Vertical States\nexport const getVerticalDefaultState = (\n browseFiles: Function,\n title: string,\n subtitle: string,\n errorMessage: string,\n state: FileUploadState\n): TemplateResult => html`\n <div>\n <div class=${classMap({ 'hover-border': state === \"hover\", 'vertical-div': true })}>\n <slot name=\"uploadIcon\">\n <nile-icon name=\"upload\" size=\"24\"></nile-icon>\n </slot>\n <div class=\"content-container\">\n <slot name=\"title\">\n <h4>${title}</h4>\n </slot>\n <slot name=\"subtitle\">\n <p>${subtitle}</p>\n </slot>\n </div>\n <input\n type=\"file\"\n @change=${(e: Event | DragEvent) => dragHandlerInstance.handleFiles(e)}\n multiple\n />\n <slot @click=${browseFiles} name=\"browseFileButton\">\n <nile-button variant=\"tertiary\">\n Browse File\n </nile-button>\n </slot>\n </div>\n ${errorMessage ?\n html`<div class=\"upload-error\">\n <nile-icon name=\"warning\" size=\"12\" color=\"red\"></nile-icon>\n <span>${errorMessage}</span>\n </div>` :\n html``\n }\n </div>\n`;\n\nexport const getVerticalDisabledState = (\n browseFiles: Function,\n title: string,\n subtitle: string\n): TemplateResult => html`\n <div\n class=\"vertical-deafult vertical-div disable\"\n >\n <slot name=\"uploadIcon\">\n <nile-icon name=\"upload\" size=\"24\"></nile-icon>\n </slot>\n <div class=\"content-container\">\n <slot name=\"title\">\n <h4>${title}</h4>\n </slot>\n <slot name=\"title\">\n <p>${subtitle}</p>\n </slot>\n </div>\n <input\n type=\"file\"\n @change=${(e: Event | DragEvent) => dragHandlerInstance.handleFiles(e)}\n multiple\n />\n <slot @click=${browseFiles} name=\"browseFileButton\">\n <nile-button variant=\"tertiary\">\n Browse File\n </nile-button>\n </slot>\n </div>\n`;\n\nexport const getVerticalDragState = (): TemplateResult => html`\n <div class=\"vertical-div vertical-drag\">\n <div class=\"icons-container\">\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"general\"\n size=\"20\"\n class=\"general-icon\"\n ></nile-icon>\n <nile-icon\n color=\"var(--nile-colors-blue-500)\"\n name=\"image\"\n size=\"24\"\n class=\"image-icon\"\n ></nile-icon>\n </div>\n <p>Drop files here to upload</p>\n </div>\n`;"]}
@@ -10,7 +10,7 @@ export declare enum FileUploadVariant {
10
10
  }
11
11
  export declare enum FileUploadError {
12
12
  INVALID_FORMAT = "Invalid file format! Upload valid file.",
13
- SIZE_LIMIT_EXCEEDED = "File exceeds size limit! Upload smaller file.",
13
+ SIZE_EXCEEDED = "File exceeds size limit! Upload smaller file.",
14
14
  MULTIPLE_NOT_ALLOWED = "Please Upload Single File!",
15
15
  DUPLICATES_NOT_ALLOWED = "Duplicate Files Are Not Allowed!",
16
16
  UPLOAD_URL_REQUIRED = "Upload URL is required!"
@@ -20,7 +20,6 @@ export declare enum FileUploadEvent {
20
20
  NILE_BROWSE = "nile-browse",
21
21
  NILE_DRAG = "nile-drag",
22
22
  NILE_CHANGE = "nile-change",
23
- NILE_UPLOADING = "nile-uploading",
24
23
  NILE_UPLOAD_PROGRESS = "nile-upload-progress",
25
24
  NILE_UPLOAD_SUCCESS = "nile-upload-success",
26
25
  NILE_UPLOAD_CANCELLED = "nile-upload-cancelled",
@@ -31,6 +30,6 @@ export declare enum FileUploadEvent {
31
30
  }
32
31
  export declare enum FileUploadDefaults {
33
32
  TITLE = "Drag and drop to upload",
34
- SUBTITLE = "Please upload a file",
33
+ SUBTITLE = "PNG, JPG or SVG (upto 1MB) | 1:1 ratio",
35
34
  ERROR_MESSAGE = "Invalid File Format."
36
35
  }
@@ -13,7 +13,7 @@ export var FileUploadVariant;
13
13
  export var FileUploadError;
14
14
  (function (FileUploadError) {
15
15
  FileUploadError["INVALID_FORMAT"] = "Invalid file format! Upload valid file.";
16
- FileUploadError["SIZE_LIMIT_EXCEEDED"] = "File exceeds size limit! Upload smaller file.";
16
+ FileUploadError["SIZE_EXCEEDED"] = "File exceeds size limit! Upload smaller file.";
17
17
  FileUploadError["MULTIPLE_NOT_ALLOWED"] = "Please Upload Single File!";
18
18
  FileUploadError["DUPLICATES_NOT_ALLOWED"] = "Duplicate Files Are Not Allowed!";
19
19
  FileUploadError["UPLOAD_URL_REQUIRED"] = "Upload URL is required!";
@@ -24,7 +24,6 @@ export var FileUploadEvent;
24
24
  FileUploadEvent["NILE_BROWSE"] = "nile-browse";
25
25
  FileUploadEvent["NILE_DRAG"] = "nile-drag";
26
26
  FileUploadEvent["NILE_CHANGE"] = "nile-change";
27
- FileUploadEvent["NILE_UPLOADING"] = "nile-uploading";
28
27
  FileUploadEvent["NILE_UPLOAD_PROGRESS"] = "nile-upload-progress";
29
28
  FileUploadEvent["NILE_UPLOAD_SUCCESS"] = "nile-upload-success";
30
29
  FileUploadEvent["NILE_UPLOAD_CANCELLED"] = "nile-upload-cancelled";
@@ -36,7 +35,7 @@ export var FileUploadEvent;
36
35
  export var FileUploadDefaults;
37
36
  (function (FileUploadDefaults) {
38
37
  FileUploadDefaults["TITLE"] = "Drag and drop to upload";
39
- FileUploadDefaults["SUBTITLE"] = "Please upload a file";
38
+ FileUploadDefaults["SUBTITLE"] = "PNG, JPG or SVG (upto 1MB) | 1:1 ratio";
40
39
  FileUploadDefaults["ERROR_MESSAGE"] = "Invalid File Format.";
41
40
  })(FileUploadDefaults || (FileUploadDefaults = {}));
42
41
  ;
@@ -1 +1 @@
1
- {"version":3,"file":"file-upload.enums.js","sourceRoot":"","sources":["../../../../src/nile-file-upload/types/file-upload.enums.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,sCAAmB,CAAA;IACnB,wCAAqB,CAAA;IACrB,kCAAe,CAAA;IACf,gCAAa,CAAA;AACf,CAAC,EALW,eAAe,KAAf,eAAe,QAK1B;AAED,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IAC3B,8CAAyB,CAAA;IACzB,0CAAqB,CAAA;AACvB,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B;AAED,MAAM,CAAN,IAAY,eAMX;AAND,WAAY,eAAe;IACzB,6EAA0D,CAAA;IAC1D,wFAAqE,CAAA;IACrE,sEAAmD,CAAA;IACnD,8EAA2D,CAAA;IAC3D,kEAA+C,CAAA;AACjD,CAAC,EANW,eAAe,KAAf,eAAe,QAM1B;AAED,MAAM,CAAN,IAAY,eAaX;AAbD,WAAY,eAAe;IACzB,0CAAuB,CAAA;IACvB,8CAA2B,CAAA;IAC3B,0CAAuB,CAAA;IACvB,8CAA2B,CAAA;IAC3B,oDAAiC,CAAA;IACjC,gEAA6C,CAAA;IAC7C,8DAA2C,CAAA;IAC3C,kEAA+C,CAAA;IAC/C,4DAAyC,CAAA;IACzC,4DAAyC,CAAA;IACzC,0DAAuC,CAAA;IACvC,gDAA6B,CAAA;AAC/B,CAAC,EAbW,eAAe,KAAf,eAAe,QAa1B;AAED,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,uDAAiC,CAAA;IACjC,uDAAiC,CAAA;IACjC,4DAAsC,CAAA;AACxC,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAAA,CAAC","sourcesContent":["export enum FileUploadState {\n DEFAULT = 'default',\n DISABLED = 'disabled',\n HOVER = 'hover',\n DRAG = 'drag'\n}\n\nexport enum FileUploadVariant {\n HORIZONTAL = 'horizontal',\n VERTICAL = 'vertical'\n}\n\nexport enum FileUploadError {\n INVALID_FORMAT = \"Invalid file format! Upload valid file.\",\n SIZE_LIMIT_EXCEEDED = \"File exceeds size limit! Upload smaller file.\",\n MULTIPLE_NOT_ALLOWED = \"Please Upload Single File!\",\n DUPLICATES_NOT_ALLOWED = \"Duplicate Files Are Not Allowed!\",\n UPLOAD_URL_REQUIRED = \"Upload URL is required!\",\n}\n\nexport enum FileUploadEvent {\n NILE_INIT = \"nile-init\",\n NILE_BROWSE = \"nile-browse\",\n NILE_DRAG = \"nile-drag\",\n NILE_CHANGE = \"nile-change\",\n NILE_UPLOADING = \"nile-uploading\",\n NILE_UPLOAD_PROGRESS = \"nile-upload-progress\",\n NILE_UPLOAD_SUCCESS = \"nile-upload-success\",\n NILE_UPLOAD_CANCELLED = \"nile-upload-cancelled\",\n NILE_CANCEL_UPLOAD = \"nile-cancel-upload\",\n NILE_NETWORK_ERROR = \"nile-network-error\",\n SERVER_SIDE_ERROR = \"nile-server-error\",\n NILE_DESTROY = \"nile-destroy\"\n}\n\nexport enum FileUploadDefaults {\n TITLE = 'Drag and drop to upload',\n SUBTITLE = 'Please upload a file',\n ERROR_MESSAGE = 'Invalid File Format.',\n};"]}
1
+ {"version":3,"file":"file-upload.enums.js","sourceRoot":"","sources":["../../../../src/nile-file-upload/types/file-upload.enums.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,sCAAmB,CAAA;IACnB,wCAAqB,CAAA;IACrB,kCAAe,CAAA;IACf,gCAAa,CAAA;AACf,CAAC,EALW,eAAe,KAAf,eAAe,QAK1B;AAED,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IAC3B,8CAAyB,CAAA;IACzB,0CAAqB,CAAA;AACvB,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B;AAED,MAAM,CAAN,IAAY,eAMX;AAND,WAAY,eAAe;IACzB,6EAA0D,CAAA;IAC1D,kFAA+D,CAAA;IAC/D,sEAAmD,CAAA;IACnD,8EAA2D,CAAA;IAC3D,kEAA+C,CAAA;AACjD,CAAC,EANW,eAAe,KAAf,eAAe,QAM1B;AAED,MAAM,CAAN,IAAY,eAYX;AAZD,WAAY,eAAe;IACzB,0CAAuB,CAAA;IACvB,8CAA2B,CAAA;IAC3B,0CAAuB,CAAA;IACvB,8CAA2B,CAAA;IAC3B,gEAA6C,CAAA;IAC7C,8DAA2C,CAAA;IAC3C,kEAA+C,CAAA;IAC/C,4DAAyC,CAAA;IACzC,4DAAyC,CAAA;IACzC,0DAAuC,CAAA;IACvC,gDAA6B,CAAA;AAC/B,CAAC,EAZW,eAAe,KAAf,eAAe,QAY1B;AAED,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,uDAAiC,CAAA;IACjC,yEAAmD,CAAA;IACnD,4DAAsC,CAAA;AACxC,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAAA,CAAC","sourcesContent":["export enum FileUploadState {\n DEFAULT = 'default',\n DISABLED = 'disabled',\n HOVER = 'hover',\n DRAG = 'drag'\n}\n\nexport enum FileUploadVariant {\n HORIZONTAL = 'horizontal',\n VERTICAL = 'vertical'\n}\n\nexport enum FileUploadError {\n INVALID_FORMAT = \"Invalid file format! Upload valid file.\",\n SIZE_EXCEEDED = \"File exceeds size limit! Upload smaller file.\",\n MULTIPLE_NOT_ALLOWED = \"Please Upload Single File!\",\n DUPLICATES_NOT_ALLOWED = \"Duplicate Files Are Not Allowed!\",\n UPLOAD_URL_REQUIRED = \"Upload URL is required!\",\n}\n\nexport enum FileUploadEvent {\n NILE_INIT = \"nile-init\",\n NILE_BROWSE = \"nile-browse\",\n NILE_DRAG = \"nile-drag\",\n NILE_CHANGE = \"nile-change\",\n NILE_UPLOAD_PROGRESS = \"nile-upload-progress\",\n NILE_UPLOAD_SUCCESS = \"nile-upload-success\",\n NILE_UPLOAD_CANCELLED = \"nile-upload-cancelled\",\n NILE_CANCEL_UPLOAD = \"nile-cancel-upload\",\n NILE_NETWORK_ERROR = \"nile-network-error\",\n SERVER_SIDE_ERROR = \"nile-server-error\",\n NILE_DESTROY = \"nile-destroy\"\n}\n\nexport enum FileUploadDefaults {\n TITLE = 'Drag and drop to upload',\n SUBTITLE = 'PNG, JPG or SVG (upto 1MB) | 1:1 ratio',\n ERROR_MESSAGE = 'Invalid File Format.',\n};"]}
@@ -1,12 +1,14 @@
1
1
  import { FileUploadState } from "../types";
2
2
  export declare class DragHandler {
3
3
  private currentState;
4
+ private size;
5
+ private uploadedFiles;
4
6
  private stateChangeCallback?;
5
7
  private fileDropCallback?;
6
8
  private errorMessageCallback?;
7
9
  constructor();
8
10
  setErrorMessage(callback: (errorMessage: string) => void): void;
9
- setValuesInDragHandler(state: FileUploadState): void;
11
+ setValuesInDragHandler(state: FileUploadState, size: number, uploadedFiles: File[]): void;
10
12
  onFileDrop(callback: (files: File[]) => void): void;
11
13
  onStateChange(callback: (state: FileUploadState) => void): void;
12
14
  private setState;
@@ -17,5 +19,5 @@ export declare class DragHandler {
17
19
  handleDocumentDrop(e: DragEvent): void;
18
20
  preventDragOver(e: DragEvent): void;
19
21
  preventDrop(e: DragEvent): void;
20
- handleFiles(e: Event | DragEvent): void;
22
+ handleFiles(event: Event | DragEvent): void;
21
23
  }
@@ -1,14 +1,17 @@
1
- import { preventDefaultAndStopPropagation } from "./file-validation.util";
2
1
  import { FileUploadState } from "../types";
3
2
  export class DragHandler {
4
3
  constructor() {
5
4
  this.currentState = FileUploadState.DEFAULT;
5
+ this.size = 0;
6
+ this.uploadedFiles = [];
6
7
  }
7
8
  setErrorMessage(callback) {
8
9
  this.errorMessageCallback = callback;
9
10
  }
10
- setValuesInDragHandler(state) {
11
+ setValuesInDragHandler(state, size, uploadedFiles) {
11
12
  this.currentState = state;
13
+ this.size = size;
14
+ this.uploadedFiles = uploadedFiles;
12
15
  }
13
16
  onFileDrop(callback) {
14
17
  this.fileDropCallback = callback;
@@ -23,60 +26,60 @@ export class DragHandler {
23
26
  this.stateChangeCallback?.(state);
24
27
  }
25
28
  dragEnter(e) {
26
- preventDefaultAndStopPropagation(e);
27
29
  if (this.currentState === FileUploadState.DISABLED)
28
30
  return;
31
+ e.preventDefault();
29
32
  this.errorMessageCallback?.("");
30
33
  this.setState(FileUploadState.DRAG);
31
34
  }
32
35
  dragLeave(e) {
33
- preventDefaultAndStopPropagation(e);
34
36
  if (this.currentState === FileUploadState.DISABLED)
35
37
  return;
38
+ e.preventDefault();
36
39
  this.setState(FileUploadState.DEFAULT);
37
40
  }
38
41
  dragOver(e) {
39
- preventDefaultAndStopPropagation(e);
40
42
  if (this.currentState === FileUploadState.DISABLED)
41
43
  return;
44
+ e.preventDefault();
42
45
  }
43
46
  drop(e) {
44
- preventDefaultAndStopPropagation(e);
45
47
  if (this.currentState === FileUploadState.DISABLED)
46
48
  return;
49
+ e.preventDefault();
50
+ e.stopPropagation();
47
51
  this.setState(FileUploadState.DEFAULT);
48
52
  this.handleFiles(e);
49
53
  }
50
54
  handleDocumentDrop(e) {
51
55
  if (this.currentState === FileUploadState.DISABLED)
52
56
  return;
53
- preventDefaultAndStopPropagation(e);
57
+ e.preventDefault();
58
+ e.stopPropagation();
54
59
  this.setState(FileUploadState.DEFAULT);
55
60
  }
56
61
  preventDragOver(e) {
57
- preventDefaultAndStopPropagation(e);
62
+ e.preventDefault();
58
63
  }
59
64
  preventDrop(e) {
60
- preventDefaultAndStopPropagation(e);
65
+ e.preventDefault();
66
+ e.stopPropagation();
61
67
  }
62
- handleFiles(e) {
63
- preventDefaultAndStopPropagation(e);
68
+ handleFiles(event) {
64
69
  if (this.currentState === FileUploadState.DISABLED)
65
70
  return;
71
+ event.preventDefault?.();
66
72
  let files = null;
67
- if ('dataTransfer' in e && e.dataTransfer) {
68
- files = e.dataTransfer.files;
73
+ if ('dataTransfer' in event && event.dataTransfer) {
74
+ files = event.dataTransfer.files;
69
75
  }
70
- if (!files && e.target instanceof HTMLInputElement) {
71
- files = e.target.files;
76
+ if (!files && event.target instanceof HTMLInputElement) {
77
+ files = event.target.files;
72
78
  }
73
79
  if (files && files.length > 0) {
74
80
  const newFiles = Array.from(files);
75
81
  this.fileDropCallback?.(newFiles);
76
82
  }
77
- if (e.target instanceof HTMLInputElement) {
78
- e.target.value = "";
79
- }
80
83
  }
81
84
  }
82
85
  //# sourceMappingURL=drag-drop.util.js.map
@@ -1 +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 { preventDefaultAndStopPropagation } from \"./file-validation.util\";\nimport { FileUploadState } from \"../types\";\n\nexport class DragHandler {\n private currentState: FileUploadState = FileUploadState.DEFAULT;\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): void {\n this.currentState = state;\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 preventDefaultAndStopPropagation(e);\n\n if (this.currentState === FileUploadState.DISABLED) return;\n this.errorMessageCallback?.(\"\");\n this.setState(FileUploadState.DRAG);\n }\n\n public dragLeave(e: DragEvent): void {\n preventDefaultAndStopPropagation(e);\n \n if (this.currentState === FileUploadState.DISABLED) return;\n\n this.setState(FileUploadState.DEFAULT);\n }\n\n public dragOver(e: DragEvent): void {\n preventDefaultAndStopPropagation(e);\n \n if (this.currentState === FileUploadState.DISABLED) return;\n }\n\n public drop(e: DragEvent): void {\n preventDefaultAndStopPropagation(e);\n \n if (this.currentState === FileUploadState.DISABLED) return;\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 preventDefaultAndStopPropagation(e);\n \n this.setState(FileUploadState.DEFAULT);\n }\n\n public preventDragOver(e: DragEvent): void {\n preventDefaultAndStopPropagation(e); \n }\n\n public preventDrop(e: DragEvent): void {\n preventDefaultAndStopPropagation(e); \n }\n\n public handleFiles(e: Event | DragEvent): void {\n preventDefaultAndStopPropagation(e);\n if (this.currentState === FileUploadState.DISABLED) return;\n\n let files: FileList | null = null;\n\n if ('dataTransfer' in e && e.dataTransfer) {\n files = e.dataTransfer.files;\n }\n\n if (!files && e.target instanceof HTMLInputElement) {\n files = e.target.files;\n }\n\n if (files && files.length > 0) {\n const newFiles = Array.from(files);\n\n this.fileDropCallback?.(newFiles);\n }\n\n if(e.target instanceof HTMLInputElement) {\n e.target.value = \"\";\n }\n }\n}\n"]}
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"]}
@@ -2,12 +2,10 @@ import { DragHandler } from "./drag-drop.util";
2
2
  import { FileUploadState } from "../types";
3
3
  import { NileFileUpload } from "../nile-file-upload";
4
4
  export declare const areDuplicates: (files: File[], uploadedFiles: File[]) => boolean;
5
- export declare const setUpDragHandler: (nileFileUpload: NileFileUpload, dragHandler: DragHandler, allowMultiple: boolean, uploadedFiles: File[], errorMessage: string, size: string, allowDuplicates: boolean) => void;
5
+ export declare const setUpDragHandler: (nileFileUpload: NileFileUpload, dragHandler: DragHandler) => void;
6
6
  export declare const addGlobalListeners: (dragHandler: DragHandler) => void;
7
7
  export declare const addInternalListeners: (nileFileUpload: NileFileUpload, dragHandler: DragHandler, uploadRequests: any) => void;
8
8
  export declare function handleHoverIn(setState: (state: FileUploadState) => void, currentState: FileUploadState): void;
9
9
  export declare function handleHoverOut(setState: (state: FileUploadState) => void, currentState: FileUploadState): void;
10
10
  export declare function uploadFiles(nileFileUpload: NileFileUpload): void;
11
11
  export declare const cancelFileUpload: (nileFileUpload: NileFileUpload, uploadRequests: Map<File, XMLHttpRequest>) => void;
12
- export declare const preventDefaultAndStopPropagation: (event: Event | DragEvent) => void;
13
- export declare const removeFile: (uploadedFiles: File[], nileFileUpload: NileFileUpload) => void;
@@ -1,41 +1,32 @@
1
1
  import { FileUploadState, FileUploadError, FileUploadEvent } from "../types";
2
- // optimise this function
2
+ // write a function to check for duplicatse in the files name it as areDuplicates
3
3
  export const areDuplicates = (files, uploadedFiles) => {
4
4
  return files.some(file => uploadedFiles.some(existing => file.name === existing.name &&
5
5
  file.size === existing.size &&
6
6
  file.lastModified === existing.lastModified));
7
7
  };
8
- export const setUpDragHandler = (nileFileUpload, dragHandler, allowMultiple, uploadedFiles, errorMessage, size, allowDuplicates) => {
8
+ // set up the drag handler
9
+ export const setUpDragHandler = (nileFileUpload, dragHandler) => {
9
10
  dragHandler.onStateChange((newState) => {
10
11
  nileFileUpload.state = newState;
11
12
  });
12
13
  dragHandler.onFileDrop((files) => {
13
- let maxSize = parseSize(size);
14
- if (!nileFileUpload.allowMultiple) {
15
- const total = nileFileUpload.uploadedFiles.length + files.length;
14
+ let { allowMultiple, uploadedFiles, errorMessage, requestUpdate } = nileFileUpload;
15
+ if (!allowMultiple) {
16
+ const total = uploadedFiles.length + files.length;
16
17
  if (total > 1) {
17
- nileFileUpload.errorMessage = FileUploadError.MULTIPLE_NOT_ALLOWED;
18
- console.error(errorMessage);
19
- nileFileUpload.requestUpdate();
20
- return;
21
- }
22
- }
23
- for (const file of files) {
24
- if (file.size > maxSize) {
25
- nileFileUpload.errorMessage = FileUploadError.SIZE_LIMIT_EXCEEDED;
26
- console.error(errorMessage);
27
- nileFileUpload.requestUpdate();
18
+ errorMessage = FileUploadError.MULTIPLE_NOT_ALLOWED;
19
+ requestUpdate();
28
20
  return;
29
21
  }
30
22
  }
31
23
  let newFiles = files;
32
24
  if (!nileFileUpload.allowDuplicates) {
33
- newFiles = files.filter(file => !uploadedFiles.some(uploaded => uploaded.name === file.name &&
25
+ newFiles = files.filter(file => !nileFileUpload.uploadedFiles.some(uploaded => uploaded.name === file.name &&
34
26
  uploaded.size === file.size &&
35
27
  uploaded.type === file.type));
36
28
  if (newFiles.length === 0) {
37
- errorMessage = FileUploadError.DUPLICATES_NOT_ALLOWED;
38
- console.error(errorMessage);
29
+ nileFileUpload.errorMessage = FileUploadError.DUPLICATES_NOT_ALLOWED;
39
30
  nileFileUpload.requestUpdate();
40
31
  return;
41
32
  }
@@ -44,14 +35,15 @@ export const setUpDragHandler = (nileFileUpload, dragHandler, allowMultiple, upl
44
35
  nileFileUpload.requestUpdate();
45
36
  });
46
37
  dragHandler.setErrorMessage((errorMessage) => {
47
- console.error(errorMessage);
48
38
  nileFileUpload.errorMessage = errorMessage;
49
39
  });
50
40
  };
41
+ // global listenrers
51
42
  export const addGlobalListeners = (dragHandler) => {
52
43
  document.addEventListener('dragover', dragHandler.preventDragOver, { passive: false });
53
44
  document.addEventListener('drop', dragHandler.preventDrop, { passive: false });
54
45
  };
46
+ // for hover & dragging functionality
55
47
  export const addInternalListeners = (nileFileUpload, dragHandler, uploadRequests) => {
56
48
  nileFileUpload.addEventListener('mouseenter', (e) => handleHoverIn(nileFileUpload.setState, nileFileUpload.state));
57
49
  nileFileUpload.addEventListener('mouseleave', (e) => handleHoverOut(nileFileUpload.setState, nileFileUpload.state));
@@ -60,7 +52,6 @@ export const addInternalListeners = (nileFileUpload, dragHandler, uploadRequests
60
52
  nileFileUpload.addEventListener('dragover', (e) => dragHandler.dragOver(e));
61
53
  nileFileUpload.addEventListener('drop', (e) => dragHandler.drop(e));
62
54
  cancelFileUpload(nileFileUpload, uploadRequests);
63
- removeFile(nileFileUpload.uploadedFiles, nileFileUpload);
64
55
  };
65
56
  export function handleHoverIn(setState, currentState) {
66
57
  if (currentState === FileUploadState.DEFAULT) {
@@ -77,21 +68,21 @@ export function uploadFiles(nileFileUpload) {
77
68
  if (!fileUploadUrl || !uploadedFiles?.length)
78
69
  return;
79
70
  for (const file of uploadedFiles) {
80
- if (uploadRequests.has(file))
81
- continue;
82
71
  const formData = new FormData();
83
72
  formData.append('file', file);
84
73
  const xhr = new XMLHttpRequest();
85
74
  uploadRequests.set(file, xhr);
86
- nileFileUpload.emit(FileUploadEvent.NILE_UPLOADING);
87
75
  xhr.upload.onprogress = (e) => {
88
76
  const percent = Math.floor((e.loaded / e.total) * 100);
89
77
  nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_PROGRESS, {
90
78
  detail: { file, progress: percent }
91
79
  }));
92
80
  };
93
- xhr.onload = (e) => {
81
+ xhr.onload = () => {
82
+ uploadRequests.delete(file);
94
83
  if (xhr.status === 201) {
84
+ // Remove the successfully uploaded file
85
+ nileFileUpload.uploadedFiles = nileFileUpload.uploadedFiles.filter(f => f !== file);
95
86
  nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_SUCCESS, {
96
87
  detail: { file, response: xhr.response }
97
88
  }));
@@ -126,23 +117,4 @@ export const cancelFileUpload = (nileFileUpload, uploadRequests) => {
126
117
  }));
127
118
  });
128
119
  };
129
- function parseSize(sizeStr) {
130
- const units = { B: 1, KB: 1024, MB: 1024 ** 2, GB: 1024 ** 3 };
131
- const num = parseFloat(sizeStr);
132
- const unit = sizeStr.replace(/[0-9.\s]/g, '').toUpperCase();
133
- const multiplier = units[unit] || 1;
134
- return num * multiplier;
135
- }
136
- export const preventDefaultAndStopPropagation = (event) => {
137
- event.preventDefault?.();
138
- event.stopPropagation();
139
- };
140
- export const removeFile = (uploadedFiles, nileFileUpload) => {
141
- document.addEventListener('nile-remove', (e) => {
142
- const { value } = e.detail;
143
- uploadedFiles = uploadedFiles.filter(file => file !== value);
144
- nileFileUpload.uploadedFiles = uploadedFiles;
145
- nileFileUpload.requestUpdate();
146
- });
147
- };
148
120
  //# sourceMappingURL=file-validation.util.js.map
@@ -1 +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\";\nimport { RemoveFileDetail } from \"../../nile-file-preview/types\";\n\n// optimise this function\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\nexport const setUpDragHandler = (\n nileFileUpload: NileFileUpload,\n dragHandler: DragHandler,\n allowMultiple: boolean,\n uploadedFiles: File[],\n errorMessage: string,\n size: string,\n allowDuplicates: boolean\n): void => {\n dragHandler.onStateChange((newState: FileUploadState) => {\n nileFileUpload.state = newState;\n });\n\n dragHandler.onFileDrop((files: File[]) => {\n let maxSize = parseSize(size);\n\n if (!nileFileUpload.allowMultiple) {\n const total = nileFileUpload.uploadedFiles.length + files.length;\n if (total > 1) {\n nileFileUpload.errorMessage = FileUploadError.MULTIPLE_NOT_ALLOWED;\n console.error(errorMessage);\n nileFileUpload.requestUpdate();\n return;\n }\n }\n\n for (const file of files) {\n if (file.size > maxSize) {\n nileFileUpload.errorMessage = FileUploadError.SIZE_LIMIT_EXCEEDED;\n console.error(errorMessage);\n nileFileUpload.requestUpdate();\n return;\n }\n }\n\n let newFiles = files;\n if (!nileFileUpload.allowDuplicates) {\n newFiles = files.filter(file =>\n !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 errorMessage = FileUploadError.DUPLICATES_NOT_ALLOWED;\n console.error(errorMessage);\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 console.error(errorMessage)\n nileFileUpload.errorMessage = errorMessage;\n });\n};\n\nexport const addGlobalListeners = (dragHandler: DragHandler): void => {\n document.addEventListener('dragover', dragHandler.preventDragOver, { passive: false });\n document.addEventListener('drop', dragHandler.preventDrop, { passive: false });\n}\n\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 removeFile(nileFileUpload.uploadedFiles, nileFileUpload);\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 if (uploadRequests.has(file)) continue;\n \n const formData = new FormData();\n formData.append('file', file);\n\n const xhr = new XMLHttpRequest();\n uploadRequests.set(file, xhr);\n\n nileFileUpload.emit(FileUploadEvent.NILE_UPLOADING);\n\n xhr.upload.onprogress = (e) => {\n const percent = Math.floor((e.loaded / e.total) * 100);\n \n nileFileUpload.dispatchEvent(new CustomEvent(FileUploadEvent.NILE_UPLOAD_PROGRESS, {\n detail: { file, progress: percent }\n }));\n };\n\n xhr.onload = (e) => {\n if (xhr.status === 201) {\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\nfunction parseSize(sizeStr: string): number {\n const units = { B: 1, KB: 1024, MB: 1024 ** 2, GB: 1024 ** 3 };\n const num = parseFloat(sizeStr);\n const unit = sizeStr.replace(/[0-9.\\s]/g, '').toUpperCase();\n const multiplier = units[unit as keyof typeof units] || 1;\n return num * multiplier;\n}\n\nexport const preventDefaultAndStopPropagation = (event: Event | DragEvent): void => {\n event.preventDefault?.();\n event.stopPropagation();\n}\n\nexport const removeFile = (uploadedFiles: File[], nileFileUpload: NileFileUpload) => {\n document.addEventListener('nile-remove', (e: CustomEvent<RemoveFileDetail>) => {\n const { value } = e.detail;\n uploadedFiles = uploadedFiles.filter(file => file !== value);\n nileFileUpload.uploadedFiles = uploadedFiles;\n nileFileUpload.requestUpdate();\n });\n}"]}
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"]}
@@ -25,6 +25,97 @@ export const styles = css `
25
25
  nile-table-row > slot::slotted(nile-table-cell-item:first-child) {
26
26
  color: red;
27
27
  }
28
+
29
+ .row-container {
30
+ display: flex;
31
+ flex-direction: column;
32
+ }
33
+
34
+ .row {
35
+ cursor: pointer;
36
+ }
37
+
38
+ .expanded-content {
39
+ overflow: hidden;
40
+ /* Optional: smooth height transition */
41
+ transition: max-height 0.3s ease;
42
+ max-height: 1000px; /* or set via a CSS variable */
43
+ }
44
+
45
+ .row-container {
46
+ display: flex;
47
+ flex-direction: column; /* keeps expansion content below */
48
+ }
49
+
50
+ .row {
51
+ display: flex; /* turn each row into a flex row */
52
+ cursor: pointer; /* keep your expand cursor */
53
+ }
54
+
55
+ .row.expandable .expand-icon {
56
+ margin-right: 4px;
57
+ }
58
+
59
+ /* All direct children of .row (i.e. your cell items & the icon) flex equally */
60
+ .row ::slotted(nile-table-cell-item),
61
+ .row ::slotted(nile-table-header-item) {
62
+ flex: 1 1 0; /* grow + shrink equally, zero base-width */
63
+ box-sizing: border-box; /* so padding/borders stay inside */
64
+ }
65
+
66
+ /* Make sure the expand-icon doesn’t stretch like a cell: */
67
+ .row ::slotted(.expand-icon) {
68
+ flex: 0 0 auto;
69
+ }
70
+
71
+ /* Expansion pane—already in your code: */
72
+ .expanded-content {
73
+ overflow: hidden;
74
+ transition: ease-in-out all 10s;
75
+ max-height: 1000px; /* or a CSS variable */
76
+ }
77
+
78
+
79
+
80
+
81
+ .row-container {
82
+ display: flex;
83
+ flex-direction: column;
84
+ }
85
+
86
+
87
+ .row {
88
+ position: relative; /* so the icon can be absolutely positioned */
89
+ display: flex;
90
+ align-items: center;
91
+ border-bottom: 1px solid var(--nile-table-row-border-color, #e0e0e0);
92
+ cursor: default; /* row itself is inert */
93
+ background: var(--nile-table-row-background, #fff);
94
+ }
95
+
96
+ /* Expand/collapse icon */
97
+ .expand-icon {
98
+ position: absolute;
99
+ left: 0.40em;
100
+ top: 50%;
101
+ transform: translateY(-50%);
102
+ cursor: pointer;
103
+ font-size: 1em;
104
+ line-height: 1;
105
+ user-select: none;
106
+ z-index: 1;
107
+ }
108
+
109
+
110
+
111
+
112
+
113
+
114
+ .expanded-content {
115
+ overflow: hidden;
116
+ transition: ease-in-out all 10s;
117
+ }
118
+
28
119
  `;
29
120
  export default [styles];
30
121
  //# sourceMappingURL=nile-table-row.css.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"nile-table-row.css.js","sourceRoot":"","sources":["../../../src/nile-table-row/nile-table-row.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;CAiBxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2023\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { css } from 'lit';\n\n/**\n * TableRow CSS\n */\nexport const styles = css`\n :host {\n display: table-row;\n width: 100%;\n height: 100%;\n height: max-content;\n --nile-header-background: var(--nile-table-header-background-color);\n border-bottom: 1px solid var(--nile-table-row-border-color);\n }\n\n slot::slotted(nile-table-header-item) {\n background-color: var(--nile-header-background);\n }\n\n nile-table-row > slot::slotted(nile-table-cell-item:first-child) {\n color: red;\n }\n`;\n\nexport default [styles];\n"]}
1
+ {"version":3,"file":"nile-table-row.css.js","sourceRoot":"","sources":["../../../src/nile-table-row/nile-table-row.css.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4GxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n * Copyright Aquera Inc 2023\n *\n * This source code is licensed under the BSD-3-Clause license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { css } from 'lit';\n\n/**\n * TableRow CSS\n */\nexport const styles = css`\n :host {\n display: table-row;\n width: 100%;\n height: 100%;\n height: max-content;\n --nile-header-background: var(--nile-table-header-background-color);\n border-bottom: 1px solid var(--nile-table-row-border-color);\n }\n\n slot::slotted(nile-table-header-item) {\n background-color: var(--nile-header-background);\n }\n\n nile-table-row > slot::slotted(nile-table-cell-item:first-child) {\n color: red;\n }\n\n .row-container {\n display: flex;\n flex-direction: column;\n}\n\n.row {\n cursor: pointer;\n}\n\n.expanded-content {\n overflow: hidden;\n /* Optional: smooth height transition */\n transition: max-height 0.3s ease;\n max-height: 1000px; /* or set via a CSS variable */\n}\n\n.row-container {\n display: flex;\n flex-direction: column; /* keeps expansion content below */\n}\n\n.row {\n display: flex; /* turn each row into a flex row */\n cursor: pointer; /* keep your expand cursor */\n}\n\n.row.expandable .expand-icon {\n margin-right: 4px;\n}\n\n/* All direct children of .row (i.e. your cell items & the icon) flex equally */\n.row ::slotted(nile-table-cell-item),\n.row ::slotted(nile-table-header-item) {\n flex: 1 1 0; /* grow + shrink equally, zero base-width */\n box-sizing: border-box; /* so padding/borders stay inside */\n}\n\n/* Make sure the expand-icon doesn’t stretch like a cell: */\n.row ::slotted(.expand-icon) {\n flex: 0 0 auto;\n}\n\n/* Expansion pane—already in your code: */\n.expanded-content {\n overflow: hidden;\n transition: ease-in-out all 10s;\n max-height: 1000px; /* or a CSS variable */\n}\n\n \n\n \n.row-container {\n display: flex;\n flex-direction: column;\n}\n\n \n.row {\n position: relative; /* so the icon can be absolutely positioned */\n display: flex;\n align-items: center;\n border-bottom: 1px solid var(--nile-table-row-border-color, #e0e0e0);\n cursor: default; /* row itself is inert */\n background: var(--nile-table-row-background, #fff);\n}\n\n/* Expand/collapse icon */\n.expand-icon {\n position: absolute;\n left: 0.40em; \n top: 50%;\n transform: translateY(-50%);\n cursor: pointer;\n font-size: 1em;\n line-height: 1;\n user-select: none;\n z-index: 1;\n}\n\n\n \n \n\n\n.expanded-content {\n overflow: hidden;\ntransition: ease-in-out all 10s;\n}\n\n`;\n\nexport default [styles];\n"]}
@@ -1,31 +1,31 @@
1
- /**
2
- * Copyright Aquera Inc 2023
3
- *
4
- * This source code is licensed under the BSD-3-Clause license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- */
7
1
  import { CSSResultArray, TemplateResult } from 'lit';
8
2
  import NileElement from '../internal/nile-element';
9
3
  /**
10
- *nile-table-row component.
4
+ * `<nile-table-row>` component.
11
5
  *
12
- * @tag nile-table-row
6
+ * Renders one table row; if `expandable` is true, shows
7
+ * a toggle icon at top-left that expands/collapses
8
+ * the `<slot name="expanded">` content.
13
9
  *
10
+ * @slot Default slot for cell items
11
+ * @slot expanded Content to reveal on expand
12
+ * @attr {boolean} expandable enable expansion behavior
13
+ * @attr {boolean} expanded reflect current expanded state
14
14
  */
15
15
  export declare class NileTableRow extends NileElement {
16
- /**
17
- * The styles for TableRow
18
- * @remarks If you are extending this class you can extend the base styles with super. Eg `return [super(), myCustomStyles]`
19
- */
16
+ /** Include our CSS */
20
17
  static get styles(): CSSResultArray;
21
- /**
22
- * Render method
23
- * @slot This is a slot test
24
- */
18
+ /** Enable expansion (shows icon) */
19
+ expandable: boolean;
20
+ /** Current expanded/collapsed state */
21
+ expanded: boolean;
22
+ private _expandedSlot;
23
+ /** Icon click toggles expand/collapse */
24
+ private toggleExpand;
25
+ /** Sorting event pass-through (unchanged) */
25
26
  private handleSortingAlter;
26
27
  render(): TemplateResult;
27
28
  }
28
- export default NileTableRow;
29
29
  declare global {
30
30
  interface HTMLElementTagNameMap {
31
31
  'nile-table-row': NileTableRow;