@dnncommunity/dnn-elements 0.14.1 → 0.15.0-beta.3

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 (422) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +24 -24
  3. package/dist/.storybook/utilities.js +16 -0
  4. package/dist/.storybook/utilities.js.map +1 -0
  5. package/dist/cjs/{css-shim-3bfdba4f.js → css-shim-aaf4fec9.js} +3 -3
  6. package/dist/cjs/css-shim-aaf4fec9.js.map +1 -0
  7. package/dist/cjs/{debounce-1de79bc7.js → debounce-901e1f0c.js} +18 -18
  8. package/dist/cjs/{debounce-1de79bc7.js.map → debounce-901e1f0c.js.map} +1 -1
  9. package/dist/cjs/dnn-button.cjs.entry.js +80 -76
  10. package/dist/cjs/dnn-button.cjs.entry.js.map +1 -1
  11. package/dist/cjs/{dnn-button_16.cjs.entry.js → dnn-button_17.cjs.entry.js} +2024 -1710
  12. package/dist/cjs/dnn-button_17.cjs.entry.js.map +1 -0
  13. package/dist/cjs/dnn-checkbox.cjs.entry.js +47 -47
  14. package/dist/cjs/dnn-checkbox.cjs.entry.js.map +1 -1
  15. package/dist/cjs/dnn-chevron.cjs.entry.js +22 -22
  16. package/dist/cjs/dnn-chevron.cjs.entry.js.map +1 -1
  17. package/dist/cjs/dnn-collapsible.cjs.entry.js +57 -54
  18. package/dist/cjs/dnn-collapsible.cjs.entry.js.map +1 -1
  19. package/dist/cjs/dnn-color-picker.cjs.entry.js +494 -494
  20. package/dist/cjs/dnn-color-picker.cjs.entry.js.map +1 -1
  21. package/dist/cjs/dnn-dropzone.cjs.entry.js +141 -141
  22. package/dist/cjs/dnn-dropzone.cjs.entry.js.map +1 -1
  23. package/dist/cjs/dnn-image-cropper.cjs.entry.js +394 -394
  24. package/dist/cjs/dnn-image-cropper.cjs.entry.js.map +1 -1
  25. package/dist/cjs/dnn-modal.cjs.entry.js +53 -50
  26. package/dist/cjs/dnn-modal.cjs.entry.js.map +1 -1
  27. package/dist/cjs/dnn-permissions-grid.cjs.entry.js +320 -0
  28. package/dist/cjs/dnn-permissions-grid.cjs.entry.js.map +1 -0
  29. package/dist/cjs/dnn-searchbox.cjs.entry.js +54 -54
  30. package/dist/cjs/dnn-searchbox.cjs.entry.js.map +1 -1
  31. package/dist/cjs/dnn-sort-icon.cjs.entry.js +32 -32
  32. package/dist/cjs/dnn-sort-icon.cjs.entry.js.map +1 -1
  33. package/dist/cjs/dnn-tab.cjs.entry.js +19 -19
  34. package/dist/cjs/dnn-tab.cjs.entry.js.map +1 -1
  35. package/dist/cjs/dnn-tabs.cjs.entry.js +40 -40
  36. package/dist/cjs/dnn-tabs.cjs.entry.js.map +1 -1
  37. package/dist/cjs/dnn-toggle.cjs.entry.js +26 -26
  38. package/dist/cjs/dnn-toggle.cjs.entry.js.map +1 -1
  39. package/dist/cjs/dnn-treeview-item.cjs.entry.js +56 -56
  40. package/dist/cjs/dnn-treeview-item.cjs.entry.js.map +1 -1
  41. package/dist/cjs/dnn-vertical-overflow-menu.cjs.entry.js +113 -111
  42. package/dist/cjs/dnn-vertical-overflow-menu.cjs.entry.js.map +1 -1
  43. package/dist/cjs/dnn-vertical-splitview.cjs.entry.js +121 -121
  44. package/dist/cjs/dnn-vertical-splitview.cjs.entry.js.map +1 -1
  45. package/dist/cjs/dnn.cjs.js +8 -4
  46. package/dist/cjs/dnn.cjs.js.map +1 -1
  47. package/dist/cjs/{dom-8ac1ad03.js → dom-14886762.js} +2 -2
  48. package/dist/cjs/{dom-8ac1ad03.js.map → dom-14886762.js.map} +1 -1
  49. package/dist/cjs/{index-7505bd72.js → index-514ef6dd.js} +32 -2
  50. package/dist/cjs/index-514ef6dd.js.map +1 -0
  51. package/dist/cjs/{index-aff4d89a.js → index-d53702a3.js} +30 -4
  52. package/dist/cjs/index-d53702a3.js.map +1 -0
  53. package/dist/cjs/index.cjs.js +41 -41
  54. package/dist/cjs/loader.cjs.js +4 -4
  55. package/dist/cjs/loader.cjs.js.map +1 -1
  56. package/dist/cjs/{mouseUtilities-75be531a.js → mouseUtilities-ecd5ecf7.js} +19 -19
  57. package/dist/cjs/{mouseUtilities-75be531a.js.map → mouseUtilities-ecd5ecf7.js.map} +1 -1
  58. package/dist/cjs/{shadow-css-41d9783d.js → shadow-css-c44ea13a.js} +2 -2
  59. package/dist/cjs/{shadow-css-41d9783d.js.map → shadow-css-c44ea13a.js.map} +1 -1
  60. package/dist/collection/collection-manifest.json +3 -2
  61. package/dist/collection/components/dnn-button/dnn-button.js +275 -271
  62. package/dist/collection/components/dnn-button/dnn-button.js.map +1 -1
  63. package/dist/collection/components/dnn-button/dnn-button.stories.js +72 -0
  64. package/dist/collection/components/dnn-button/dnn-button.stories.js.map +1 -0
  65. package/dist/collection/components/dnn-checkbox/dnn-checkbox.css +6 -0
  66. package/dist/collection/components/dnn-checkbox/dnn-checkbox.js +151 -139
  67. package/dist/collection/components/dnn-checkbox/dnn-checkbox.js.map +1 -1
  68. package/dist/collection/components/dnn-checkbox/dnn-checkbox.stories.js +39 -0
  69. package/dist/collection/components/dnn-checkbox/dnn-checkbox.stories.js.map +1 -0
  70. package/dist/collection/components/dnn-chevron/dnn-chevron.js +106 -106
  71. package/dist/collection/components/dnn-chevron/dnn-chevron.js.map +1 -1
  72. package/dist/collection/components/dnn-chevron/dnn-chevron.stories.js +38 -0
  73. package/dist/collection/components/dnn-chevron/dnn-chevron.stories.js.map +1 -0
  74. package/dist/collection/components/dnn-collapsible/dnn-collapsible.js +145 -142
  75. package/dist/collection/components/dnn-collapsible/dnn-collapsible.js.map +1 -1
  76. package/dist/collection/components/dnn-collapsible/dnn-collapsible.stories.js +39 -0
  77. package/dist/collection/components/dnn-collapsible/dnn-collapsible.stories.js.map +1 -0
  78. package/dist/collection/components/dnn-color-picker/dnn-color-picker.js +433 -433
  79. package/dist/collection/components/dnn-color-picker/dnn-color-picker.js.map +1 -1
  80. package/dist/collection/components/dnn-color-picker/dnn-color-picker.stories.js +33 -0
  81. package/dist/collection/components/dnn-color-picker/dnn-color-picker.stories.js.map +1 -0
  82. package/dist/collection/components/dnn-dropzone/dnn-dropzone.js +265 -265
  83. package/dist/collection/components/dnn-dropzone/dnn-dropzone.js.map +1 -1
  84. package/dist/collection/components/dnn-dropzone/dnn-dropzone.stories.js +48 -0
  85. package/dist/collection/components/dnn-dropzone/dnn-dropzone.stories.js.map +1 -0
  86. package/dist/collection/components/dnn-image-cropper/CornerType.js +8 -8
  87. package/dist/collection/components/dnn-image-cropper/CornerType.js.map +1 -1
  88. package/dist/collection/components/dnn-image-cropper/dnn-image-cropper.js +522 -522
  89. package/dist/collection/components/dnn-image-cropper/dnn-image-cropper.js.map +1 -1
  90. package/dist/collection/components/dnn-image-cropper/dnn-image-cropper.stories.js +60 -0
  91. package/dist/collection/components/dnn-image-cropper/dnn-image-cropper.stories.js.map +1 -0
  92. package/dist/collection/components/dnn-modal/dnn-modal.js +190 -172
  93. package/dist/collection/components/dnn-modal/dnn-modal.js.map +1 -1
  94. package/dist/collection/components/dnn-modal/dnn-modal.stories.js +47 -0
  95. package/dist/collection/components/dnn-modal/dnn-modal.stories.js.map +1 -0
  96. package/dist/collection/components/dnn-permissions-grid/dnn-permissions-grid.css +83 -0
  97. package/dist/collection/components/dnn-permissions-grid/dnn-permissions-grid.js +531 -0
  98. package/dist/collection/components/dnn-permissions-grid/dnn-permissions-grid.js.map +1 -0
  99. package/dist/collection/components/dnn-permissions-grid/dnn-permissions-grid.stories.js +273 -0
  100. package/dist/collection/components/dnn-permissions-grid/dnn-permissions-grid.stories.js.map +1 -0
  101. package/dist/collection/components/dnn-permissions-grid/localization-interface.js +3 -0
  102. package/dist/collection/components/dnn-permissions-grid/localization-interface.js.map +1 -0
  103. package/dist/collection/components/dnn-permissions-grid/permissions-interface.js +3 -0
  104. package/dist/collection/components/dnn-permissions-grid/permissions-interface.js.map +1 -0
  105. package/dist/collection/components/dnn-permissions-grid/role-group-interface.js +2 -0
  106. package/dist/collection/components/dnn-permissions-grid/role-group-interface.js.map +1 -0
  107. package/dist/collection/components/dnn-permissions-grid/role-interface.js +2 -0
  108. package/dist/collection/components/dnn-permissions-grid/role-interface.js.map +1 -0
  109. package/dist/collection/components/dnn-permissions-grid/searched-user-interface.js +2 -0
  110. package/dist/collection/components/dnn-permissions-grid/searched-user-interface.js.map +1 -0
  111. package/dist/collection/components/dnn-searchbox/dnn-searchbox.js +136 -136
  112. package/dist/collection/components/dnn-searchbox/dnn-searchbox.js.map +1 -1
  113. package/dist/collection/components/dnn-searchbox/dnn-searchbox.stories.js +26 -0
  114. package/dist/collection/components/dnn-searchbox/dnn-searchbox.stories.js.map +1 -0
  115. package/dist/collection/components/dnn-sort-icon/dnn-sort-icon.css +6 -3
  116. package/dist/collection/components/dnn-sort-icon/dnn-sort-icon.js +80 -80
  117. package/dist/collection/components/dnn-sort-icon/dnn-sort-icon.js.map +1 -1
  118. package/dist/collection/components/dnn-sort-icon/dnn-sort-icon.stories.js +58 -0
  119. package/dist/collection/components/dnn-sort-icon/dnn-sort-icon.stories.js.map +1 -0
  120. package/dist/collection/components/dnn-tab/dnn-tab.js +83 -83
  121. package/dist/collection/components/dnn-tab/dnn-tab.js.map +1 -1
  122. package/dist/collection/components/dnn-tab/dnn-tab.stories.js +25 -0
  123. package/dist/collection/components/dnn-tab/dnn-tab.stories.js.map +1 -0
  124. package/dist/collection/components/dnn-tabs/dnn-tabs.js +54 -54
  125. package/dist/collection/components/dnn-tabs/dnn-tabs.js.map +1 -1
  126. package/dist/collection/components/dnn-tabs/dnn-tabs.stories.js +48 -0
  127. package/dist/collection/components/dnn-tabs/dnn-tabs.stories.js.map +1 -0
  128. package/dist/collection/components/dnn-toggle/dnn-toggle.css +1 -1
  129. package/dist/collection/components/dnn-toggle/dnn-toggle.js +93 -93
  130. package/dist/collection/components/dnn-toggle/dnn-toggle.js.map +1 -1
  131. package/dist/collection/components/dnn-toggle/dnn-toggle.stories.js +53 -0
  132. package/dist/collection/components/dnn-toggle/dnn-toggle.stories.js.map +1 -0
  133. package/dist/collection/components/dnn-toggle/toggle-interface.js +1 -1
  134. package/dist/collection/components/dnn-toggle/toggle-interface.js.map +1 -1
  135. package/dist/collection/components/dnn-treeview-item/dnn-treeview-item.js +130 -126
  136. package/dist/collection/components/dnn-treeview-item/dnn-treeview-item.js.map +1 -1
  137. package/dist/collection/components/dnn-treeview-item/dnn-treeview-item.stories.js +36 -0
  138. package/dist/collection/components/dnn-treeview-item/dnn-treeview-item.stories.js.map +1 -0
  139. package/dist/collection/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.css +6 -7
  140. package/dist/collection/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.js +133 -131
  141. package/dist/collection/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.js.map +1 -1
  142. package/dist/collection/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.stories.js +60 -0
  143. package/dist/collection/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.stories.js.map +1 -0
  144. package/dist/collection/components/dnn-vertical-splitview/dnn-vertical-splitview.css +4 -2
  145. package/dist/collection/components/dnn-vertical-splitview/dnn-vertical-splitview.js +233 -233
  146. package/dist/collection/components/dnn-vertical-splitview/dnn-vertical-splitview.js.map +1 -1
  147. package/dist/collection/components/dnn-vertical-splitview/dnn-vertical-splitview.stories.js +75 -0
  148. package/dist/collection/components/dnn-vertical-splitview/dnn-vertical-splitview.stories.js.map +1 -0
  149. package/dist/collection/index.js +2 -2
  150. package/dist/collection/index.js.map +1 -1
  151. package/dist/collection/utilities/colorInfo.js +190 -190
  152. package/dist/collection/utilities/colorInfo.js.map +1 -1
  153. package/dist/collection/utilities/debounce.js +18 -18
  154. package/dist/collection/utilities/debounce.js.map +1 -1
  155. package/dist/collection/utilities/dnnServicesFramework.js +41 -41
  156. package/dist/collection/utilities/dnnServicesFramework.js.map +1 -1
  157. package/dist/collection/utilities/mouseUtilities.js +19 -19
  158. package/dist/collection/utilities/mouseUtilities.js.map +1 -1
  159. package/dist/{esm/css-shim-20dbffa5.js → dnn/css-shim-091f949f.js} +3 -3
  160. package/dist/dnn/css-shim-091f949f.js.map +1 -0
  161. package/dist/dnn/{css-shim-856c55de.system.js → css-shim-c5bffe6b.system.js} +2 -2
  162. package/dist/dnn/css-shim-c5bffe6b.system.js.map +1 -0
  163. package/dist/{esm/debounce-06f55268.js → dnn/debounce-6be67abd.js} +18 -18
  164. package/dist/dnn/{debounce-06f55268.js.map → debounce-6be67abd.js.map} +1 -1
  165. package/dist/dnn/{debounce-eef81bf7.system.js → debounce-db438a09.system.js} +1 -1
  166. package/dist/dnn/{debounce-eef81bf7.system.js.map → debounce-db438a09.system.js.map} +0 -0
  167. package/dist/dnn/dnn-button.entry.js +80 -76
  168. package/dist/dnn/dnn-button.entry.js.map +1 -1
  169. package/dist/dnn/dnn-button.system.entry.js +1 -1
  170. package/dist/dnn/dnn-button.system.entry.js.map +1 -1
  171. package/dist/dnn/dnn-checkbox.entry.js +47 -47
  172. package/dist/dnn/dnn-checkbox.entry.js.map +1 -1
  173. package/dist/dnn/dnn-checkbox.system.entry.js +1 -1
  174. package/dist/dnn/dnn-checkbox.system.entry.js.map +1 -1
  175. package/dist/dnn/dnn-chevron.entry.js +22 -22
  176. package/dist/dnn/dnn-chevron.entry.js.map +1 -1
  177. package/dist/dnn/dnn-chevron.system.entry.js +1 -1
  178. package/dist/dnn/dnn-chevron.system.entry.js.map +1 -1
  179. package/dist/dnn/dnn-collapsible.entry.js +57 -54
  180. package/dist/dnn/dnn-collapsible.entry.js.map +1 -1
  181. package/dist/dnn/dnn-collapsible.system.entry.js +1 -1
  182. package/dist/dnn/dnn-collapsible.system.entry.js.map +1 -1
  183. package/dist/dnn/dnn-color-picker.entry.js +494 -494
  184. package/dist/dnn/dnn-color-picker.entry.js.map +1 -1
  185. package/dist/dnn/dnn-color-picker.system.entry.js +2 -2
  186. package/dist/dnn/dnn-color-picker.system.entry.js.map +1 -1
  187. package/dist/dnn/dnn-dropzone.entry.js +141 -141
  188. package/dist/dnn/dnn-dropzone.entry.js.map +1 -1
  189. package/dist/dnn/dnn-dropzone.system.entry.js +1 -1
  190. package/dist/dnn/dnn-dropzone.system.entry.js.map +1 -1
  191. package/dist/dnn/dnn-image-cropper.entry.js +394 -394
  192. package/dist/dnn/dnn-image-cropper.entry.js.map +1 -1
  193. package/dist/dnn/dnn-image-cropper.system.entry.js +1 -1
  194. package/dist/dnn/dnn-image-cropper.system.entry.js.map +1 -1
  195. package/dist/dnn/dnn-modal.entry.js +53 -50
  196. package/dist/dnn/dnn-modal.entry.js.map +1 -1
  197. package/dist/dnn/dnn-modal.system.entry.js +1 -1
  198. package/dist/dnn/dnn-modal.system.entry.js.map +1 -1
  199. package/dist/dnn/dnn-permissions-grid.entry.js +316 -0
  200. package/dist/dnn/dnn-permissions-grid.entry.js.map +1 -0
  201. package/dist/dnn/dnn-permissions-grid.system.entry.js +2 -0
  202. package/dist/dnn/dnn-permissions-grid.system.entry.js.map +1 -0
  203. package/dist/dnn/dnn-searchbox.entry.js +54 -54
  204. package/dist/dnn/dnn-searchbox.entry.js.map +1 -1
  205. package/dist/dnn/dnn-searchbox.system.entry.js +1 -1
  206. package/dist/dnn/dnn-searchbox.system.entry.js.map +1 -1
  207. package/dist/dnn/dnn-sort-icon.entry.js +32 -32
  208. package/dist/dnn/dnn-sort-icon.entry.js.map +1 -1
  209. package/dist/dnn/dnn-sort-icon.system.entry.js +1 -1
  210. package/dist/dnn/dnn-sort-icon.system.entry.js.map +1 -1
  211. package/dist/dnn/dnn-tab.entry.js +19 -19
  212. package/dist/dnn/dnn-tab.entry.js.map +1 -1
  213. package/dist/dnn/dnn-tab.system.entry.js +1 -1
  214. package/dist/dnn/dnn-tabs.entry.js +40 -40
  215. package/dist/dnn/dnn-tabs.entry.js.map +1 -1
  216. package/dist/dnn/dnn-tabs.system.entry.js +1 -1
  217. package/dist/dnn/dnn-tabs.system.entry.js.map +1 -1
  218. package/dist/dnn/dnn-toggle.entry.js +26 -26
  219. package/dist/dnn/dnn-toggle.entry.js.map +1 -1
  220. package/dist/dnn/dnn-toggle.system.entry.js +1 -1
  221. package/dist/dnn/dnn-toggle.system.entry.js.map +1 -1
  222. package/dist/dnn/dnn-treeview-item.entry.js +56 -56
  223. package/dist/dnn/dnn-treeview-item.entry.js.map +1 -1
  224. package/dist/dnn/dnn-treeview-item.system.entry.js +1 -1
  225. package/dist/dnn/dnn-treeview-item.system.entry.js.map +1 -1
  226. package/dist/dnn/dnn-vertical-overflow-menu.entry.js +113 -111
  227. package/dist/dnn/dnn-vertical-overflow-menu.entry.js.map +1 -1
  228. package/dist/dnn/dnn-vertical-overflow-menu.system.entry.js +1 -1
  229. package/dist/dnn/dnn-vertical-overflow-menu.system.entry.js.map +1 -1
  230. package/dist/dnn/dnn-vertical-splitview.entry.js +121 -121
  231. package/dist/dnn/dnn-vertical-splitview.entry.js.map +1 -1
  232. package/dist/dnn/dnn-vertical-splitview.system.entry.js +1 -1
  233. package/dist/dnn/dnn-vertical-splitview.system.entry.js.map +1 -1
  234. package/dist/dnn/dnn.esm.js +8 -4
  235. package/dist/dnn/dnn.esm.js.map +1 -1
  236. package/dist/dnn/dnn.system.js +1 -1
  237. package/dist/dnn/dnn.system.js.map +1 -1
  238. package/dist/dnn/{dom-938307ec.system.js → dom-99eb7b76.system.js} +1 -1
  239. package/dist/dnn/{dom-938307ec.system.js.map → dom-99eb7b76.system.js.map} +1 -1
  240. package/dist/dnn/{dom-c5ed0ba5.js → dom-a385e381.js} +2 -2
  241. package/dist/{esm/dom-c5ed0ba5.js.map → dnn/dom-a385e381.js.map} +1 -1
  242. package/dist/dnn/{index-b5a28c1d.js → index-20e42ad7.js} +30 -4
  243. package/dist/dnn/index-20e42ad7.js.map +1 -0
  244. package/dist/dnn/index-c3cc3b5b.system.js +2 -0
  245. package/dist/dnn/index-c3cc3b5b.system.js.map +1 -0
  246. package/dist/dnn/index.esm.js +41 -41
  247. package/dist/dnn/index.system.js +1 -1
  248. package/dist/dnn/{mouseUtilities-e7e4e78f.system.js → mouseUtilities-233ad7e3.system.js} +1 -1
  249. package/dist/dnn/{mouseUtilities-e7e4e78f.system.js.map → mouseUtilities-233ad7e3.system.js.map} +0 -0
  250. package/dist/{esm/mouseUtilities-817973b4.js → dnn/mouseUtilities-b261ca4f.js} +19 -19
  251. package/dist/dnn/{mouseUtilities-817973b4.js.map → mouseUtilities-b261ca4f.js.map} +1 -1
  252. package/dist/dnn/{p-646cfb1b.system.js → p-1e26a4e1.system.js} +1 -1
  253. package/dist/dnn/{p-646cfb1b.system.js.map → p-1e26a4e1.system.js.map} +0 -0
  254. package/dist/dnn/p-31dc68a7.system.entry.js +11 -0
  255. package/dist/dnn/p-31dc68a7.system.entry.js.map +1 -0
  256. package/dist/dnn/p-5bcf3629.system.js +2 -0
  257. package/dist/dnn/p-5bcf3629.system.js.map +1 -0
  258. package/dist/dnn/{p-fb637662.system.js → p-78561bb1.system.js} +2 -2
  259. package/dist/dnn/{p-fb637662.system.js.map → p-78561bb1.system.js.map} +0 -0
  260. package/dist/dnn/p-7ffdbed1.js +2 -0
  261. package/dist/dnn/p-7ffdbed1.js.map +1 -0
  262. package/dist/dnn/{p-0e94f5ee.js → p-9b8731a9.js} +1 -1
  263. package/dist/dnn/{p-0e94f5ee.js.map → p-9b8731a9.js.map} +0 -0
  264. package/dist/dnn/p-b8064287.system.js +2 -0
  265. package/dist/dnn/p-b8064287.system.js.map +1 -0
  266. package/dist/dnn/p-c222c8b7.entry.js +11 -0
  267. package/dist/dnn/p-c222c8b7.entry.js.map +1 -0
  268. package/dist/dnn/shadow-css-27708fdd.system.js +14 -0
  269. package/dist/dnn/shadow-css-27708fdd.system.js.map +1 -0
  270. package/dist/dnn/{shadow-css-8c625855.js → shadow-css-ef431969.js} +2 -2
  271. package/dist/{esm/shadow-css-8c625855.js.map → dnn/shadow-css-ef431969.js.map} +1 -1
  272. package/dist/{dnn/css-shim-20dbffa5.js → esm/css-shim-091f949f.js} +3 -3
  273. package/dist/esm/css-shim-091f949f.js.map +1 -0
  274. package/dist/{dnn/debounce-06f55268.js → esm/debounce-6be67abd.js} +18 -18
  275. package/dist/esm/{debounce-06f55268.js.map → debounce-6be67abd.js.map} +1 -1
  276. package/dist/esm/dnn-button.entry.js +80 -76
  277. package/dist/esm/dnn-button.entry.js.map +1 -1
  278. package/dist/esm/{dnn-button_16.entry.js → dnn-button_17.entry.js} +2024 -1711
  279. package/dist/esm/dnn-button_17.entry.js.map +1 -0
  280. package/dist/esm/dnn-checkbox.entry.js +47 -47
  281. package/dist/esm/dnn-checkbox.entry.js.map +1 -1
  282. package/dist/esm/dnn-chevron.entry.js +22 -22
  283. package/dist/esm/dnn-chevron.entry.js.map +1 -1
  284. package/dist/esm/dnn-collapsible.entry.js +57 -54
  285. package/dist/esm/dnn-collapsible.entry.js.map +1 -1
  286. package/dist/esm/dnn-color-picker.entry.js +494 -494
  287. package/dist/esm/dnn-color-picker.entry.js.map +1 -1
  288. package/dist/esm/dnn-dropzone.entry.js +141 -141
  289. package/dist/esm/dnn-dropzone.entry.js.map +1 -1
  290. package/dist/esm/dnn-image-cropper.entry.js +394 -394
  291. package/dist/esm/dnn-image-cropper.entry.js.map +1 -1
  292. package/dist/esm/dnn-modal.entry.js +53 -50
  293. package/dist/esm/dnn-modal.entry.js.map +1 -1
  294. package/dist/esm/dnn-permissions-grid.entry.js +316 -0
  295. package/dist/esm/dnn-permissions-grid.entry.js.map +1 -0
  296. package/dist/esm/dnn-searchbox.entry.js +54 -54
  297. package/dist/esm/dnn-searchbox.entry.js.map +1 -1
  298. package/dist/esm/dnn-sort-icon.entry.js +32 -32
  299. package/dist/esm/dnn-sort-icon.entry.js.map +1 -1
  300. package/dist/esm/dnn-tab.entry.js +19 -19
  301. package/dist/esm/dnn-tab.entry.js.map +1 -1
  302. package/dist/esm/dnn-tabs.entry.js +40 -40
  303. package/dist/esm/dnn-tabs.entry.js.map +1 -1
  304. package/dist/esm/dnn-toggle.entry.js +26 -26
  305. package/dist/esm/dnn-toggle.entry.js.map +1 -1
  306. package/dist/esm/dnn-treeview-item.entry.js +56 -56
  307. package/dist/esm/dnn-treeview-item.entry.js.map +1 -1
  308. package/dist/esm/dnn-vertical-overflow-menu.entry.js +113 -111
  309. package/dist/esm/dnn-vertical-overflow-menu.entry.js.map +1 -1
  310. package/dist/esm/dnn-vertical-splitview.entry.js +121 -121
  311. package/dist/esm/dnn-vertical-splitview.entry.js.map +1 -1
  312. package/dist/esm/dnn.js +8 -4
  313. package/dist/esm/dnn.js.map +1 -1
  314. package/dist/esm/{dom-c5ed0ba5.js → dom-a385e381.js} +2 -2
  315. package/dist/{dnn/dom-c5ed0ba5.js.map → esm/dom-a385e381.js.map} +1 -1
  316. package/dist/esm/{index-b5a28c1d.js → index-20e42ad7.js} +30 -4
  317. package/dist/esm/index-20e42ad7.js.map +1 -0
  318. package/dist/esm/{index-cdbad319.js → index-59e0950f.js} +32 -2
  319. package/dist/esm/index-59e0950f.js.map +1 -0
  320. package/dist/esm/index.js +41 -41
  321. package/dist/esm/loader.js +4 -4
  322. package/dist/esm/loader.js.map +1 -1
  323. package/dist/{dnn/mouseUtilities-817973b4.js → esm/mouseUtilities-b261ca4f.js} +19 -19
  324. package/dist/esm/{mouseUtilities-817973b4.js.map → mouseUtilities-b261ca4f.js.map} +1 -1
  325. package/dist/esm/polyfills/core-js.js +0 -0
  326. package/dist/esm/polyfills/css-shim.js +1 -1
  327. package/dist/esm/polyfills/dom.js +0 -0
  328. package/dist/esm/polyfills/es5-html-element.js +0 -0
  329. package/dist/esm/polyfills/index.js +0 -0
  330. package/dist/esm/polyfills/system.js +0 -0
  331. package/dist/esm/{shadow-css-8c625855.js → shadow-css-ef431969.js} +2 -2
  332. package/dist/{dnn/shadow-css-8c625855.js.map → esm/shadow-css-ef431969.js.map} +1 -1
  333. package/dist/esm-es5/{debounce-06f55268.js → debounce-6be67abd.js} +1 -1
  334. package/dist/esm-es5/{debounce-06f55268.js.map → debounce-6be67abd.js.map} +0 -0
  335. package/dist/esm-es5/dnn-button_17.entry.js +11 -0
  336. package/dist/esm-es5/dnn-button_17.entry.js.map +1 -0
  337. package/dist/esm-es5/dnn.js +1 -1
  338. package/dist/esm-es5/dnn.js.map +1 -1
  339. package/dist/esm-es5/index-59e0950f.js +2 -0
  340. package/dist/esm-es5/index-59e0950f.js.map +1 -0
  341. package/dist/esm-es5/index.js +1 -1
  342. package/dist/esm-es5/loader.js +1 -1
  343. package/dist/esm-es5/loader.js.map +1 -1
  344. package/dist/types/components/dnn-button/dnn-button.d.ts +56 -55
  345. package/dist/types/components/dnn-button/dnn-button.stories.d.ts +4 -0
  346. package/dist/types/components/dnn-checkbox/dnn-checkbox.d.ts +20 -16
  347. package/dist/types/components/dnn-checkbox/dnn-checkbox.stories.d.ts +4 -0
  348. package/dist/types/components/dnn-chevron/dnn-chevron.d.ts +13 -13
  349. package/dist/types/components/dnn-chevron/dnn-chevron.stories.d.ts +4 -0
  350. package/dist/types/components/dnn-collapsible/dnn-collapsible.d.ts +19 -18
  351. package/dist/types/components/dnn-collapsible/dnn-collapsible.stories.d.ts +4 -0
  352. package/dist/types/components/dnn-color-picker/dnn-color-picker.d.ts +46 -46
  353. package/dist/types/components/dnn-color-picker/dnn-color-picker.stories.d.ts +4 -0
  354. package/dist/types/components/dnn-dropzone/dnn-dropzone.d.ts +45 -45
  355. package/dist/types/components/dnn-dropzone/dnn-dropzone.stories.d.ts +4 -0
  356. package/dist/types/components/dnn-image-cropper/CornerType.d.ts +6 -6
  357. package/dist/types/components/dnn-image-cropper/dnn-image-cropper.d.ts +61 -61
  358. package/dist/types/components/dnn-image-cropper/dnn-image-cropper.stories.d.ts +4 -0
  359. package/dist/types/components/dnn-modal/dnn-modal.d.ts +38 -35
  360. package/dist/types/components/dnn-modal/dnn-modal.stories.d.ts +4 -0
  361. package/dist/types/components/dnn-permissions-grid/dnn-permissions-grid.d.ts +47 -0
  362. package/dist/types/components/dnn-permissions-grid/dnn-permissions-grid.stories.d.ts +4 -0
  363. package/dist/types/components/dnn-permissions-grid/localization-interface.d.ts +11 -0
  364. package/dist/types/components/dnn-permissions-grid/permissions-interface.d.ts +26 -0
  365. package/dist/types/components/dnn-permissions-grid/role-group-interface.d.ts +6 -0
  366. package/dist/types/components/dnn-permissions-grid/role-interface.d.ts +6 -0
  367. package/dist/types/components/dnn-permissions-grid/searched-user-interface.d.ts +4 -0
  368. package/dist/types/components/dnn-searchbox/dnn-searchbox.d.ts +22 -22
  369. package/dist/types/components/dnn-searchbox/dnn-searchbox.stories.d.ts +4 -0
  370. package/dist/types/components/dnn-sort-icon/dnn-sort-icon.d.ts +9 -9
  371. package/dist/types/components/dnn-sort-icon/dnn-sort-icon.stories.d.ts +4 -0
  372. package/dist/types/components/dnn-tab/dnn-tab.d.ts +11 -11
  373. package/dist/types/components/dnn-tab/dnn-tab.stories.d.ts +4 -0
  374. package/dist/types/components/dnn-tabs/dnn-tabs.d.ts +11 -11
  375. package/dist/types/components/dnn-tabs/dnn-tabs.stories.d.ts +4 -0
  376. package/dist/types/components/dnn-toggle/dnn-toggle.d.ts +13 -13
  377. package/dist/types/components/dnn-toggle/dnn-toggle.stories.d.ts +4 -0
  378. package/dist/types/components/dnn-toggle/toggle-interface.d.ts +3 -3
  379. package/dist/types/components/dnn-treeview-item/dnn-treeview-item.d.ts +28 -24
  380. package/dist/types/components/dnn-treeview-item/dnn-treeview-item.stories.d.ts +4 -0
  381. package/dist/types/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.d.ts +16 -16
  382. package/dist/types/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.stories.d.ts +4 -0
  383. package/dist/types/components/dnn-vertical-splitview/dnn-vertical-splitview.d.ts +28 -28
  384. package/dist/types/components/dnn-vertical-splitview/dnn-vertical-splitview.stories.d.ts +4 -0
  385. package/dist/types/components.d.ts +108 -34
  386. package/dist/types/global.d.ts +1 -0
  387. package/dist/types/home/runner/work/dnn-elements/dnn-elements/.stencil/.storybook/utilities.d.ts +1 -0
  388. package/dist/types/index.d.ts +3 -3
  389. package/dist/types/utilities/colorInfo.d.ts +52 -52
  390. package/dist/types/utilities/debounce.d.ts +5 -5
  391. package/dist/types/utilities/dnnServicesFramework.d.ts +19 -19
  392. package/dist/types/utilities/mouseUtilities.d.ts +4 -4
  393. package/package.json +63 -48
  394. package/dist/cjs/css-shim-3bfdba4f.js.map +0 -1
  395. package/dist/cjs/dnn-button_16.cjs.entry.js.map +0 -1
  396. package/dist/cjs/index-7505bd72.js.map +0 -1
  397. package/dist/cjs/index-aff4d89a.js.map +0 -1
  398. package/dist/dnn/css-shim-20dbffa5.js.map +0 -1
  399. package/dist/dnn/css-shim-856c55de.system.js.map +0 -1
  400. package/dist/dnn/index-a3a55419.system.js +0 -2
  401. package/dist/dnn/index-a3a55419.system.js.map +0 -1
  402. package/dist/dnn/index-b5a28c1d.js.map +0 -1
  403. package/dist/dnn/p-058ba146.system.js +0 -2
  404. package/dist/dnn/p-058ba146.system.js.map +0 -1
  405. package/dist/dnn/p-45ce2139.js +0 -2
  406. package/dist/dnn/p-45ce2139.js.map +0 -1
  407. package/dist/dnn/p-755d047d.system.entry.js +0 -11
  408. package/dist/dnn/p-755d047d.system.entry.js.map +0 -1
  409. package/dist/dnn/p-8ec1f3a8.entry.js +0 -11
  410. package/dist/dnn/p-8ec1f3a8.entry.js.map +0 -1
  411. package/dist/dnn/p-f91193e2.system.js +0 -2
  412. package/dist/dnn/p-f91193e2.system.js.map +0 -1
  413. package/dist/dnn/shadow-css-d573707f.system.js +0 -14
  414. package/dist/dnn/shadow-css-d573707f.system.js.map +0 -1
  415. package/dist/esm/css-shim-20dbffa5.js.map +0 -1
  416. package/dist/esm/dnn-button_16.entry.js.map +0 -1
  417. package/dist/esm/index-b5a28c1d.js.map +0 -1
  418. package/dist/esm/index-cdbad319.js.map +0 -1
  419. package/dist/esm-es5/dnn-button_16.entry.js +0 -11
  420. package/dist/esm-es5/dnn-button_16.entry.js.map +0 -1
  421. package/dist/esm-es5/index-cdbad319.js +0 -2
  422. package/dist/esm-es5/index-cdbad319.js.map +0 -1
@@ -1,402 +1,402 @@
1
- import { r as registerInstance, e as createEvent, h, f as Host } from './index-b5a28c1d.js';
2
- import { g as getMovementFromEvent } from './mouseUtilities-817973b4.js';
1
+ import { r as registerInstance, e as createEvent, h, f as Host } from './index-20e42ad7.js';
2
+ import { g as getMovementFromEvent } from './mouseUtilities-b261ca4f.js';
3
3
 
4
- var CornerType;
5
- (function (CornerType) {
6
- CornerType[CornerType["nw"] = 0] = "nw";
7
- CornerType[CornerType["ne"] = 1] = "ne";
8
- CornerType[CornerType["se"] = 2] = "se";
9
- CornerType[CornerType["sw"] = 3] = "sw";
10
- })(CornerType || (CornerType = {}));
4
+ var CornerType;
5
+ (function (CornerType) {
6
+ CornerType[CornerType["nw"] = 0] = "nw";
7
+ CornerType[CornerType["ne"] = 1] = "ne";
8
+ CornerType[CornerType["se"] = 2] = "se";
9
+ CornerType[CornerType["sw"] = 3] = "sw";
10
+ })(CornerType || (CornerType = {}));
11
11
  ;
12
12
 
13
13
  const dnnImageCropperCss = ":host{display:block}canvas{display:none}.view{visibility:hidden;opacity:0;height:0;overflow:hidden;-webkit-transition:all 300ms ease-in-out;transition:all 300ms ease-in-out}.view.visible{visibility:visible;opacity:1;height:initial;overflow:visible}.view .cropper{position:relative;width:100%}.view .cropper img{width:100%;display:block;margin:0 auto}.view .cropper .backdrop{-webkit-backdrop-filter:saturate(0.5);backdrop-filter:saturate(0.5);-webkit-backdrop-filter:brightness(0.5);backdrop-filter:brightness(0.5);position:absolute;left:0;top:0;width:100%;height:100%}.view .cropper .crop{position:absolute;top:0;left:0;width:100%;height:100%;outline:2px dashed white;-webkit-box-shadow:black 0 0 0px 2px;box-shadow:black 0 0 0px 2px;-webkit-backdrop-filter:saturate(2);backdrop-filter:saturate(2);-webkit-backdrop-filter:brightness(2);backdrop-filter:brightness(2);cursor:move}.view .cropper .crop>div{width:20px;height:20px;background-color:white;border:2px solid rgba(0, 0, 0, 0.5);position:absolute}.view .cropper .crop>div.nw,.view .cropper .crop>div.ne{top:-17px}.view .cropper .crop>div.ne,.view .cropper .crop>div.se{right:-17px}.view .cropper .crop>div.se,.view .cropper .crop>div.sw{bottom:-17px}.view .cropper .crop>div.sw,.view .cropper .crop>div.nw{left:-17px}.view .cropper .crop>div.nw,.view .cropper .crop>div.se{cursor:nwse-resize}.view .cropper .crop>div.ne,.view .cropper .crop>div.sw{cursor:nesw-resize}dnn-modal{--max-width:512px}";
14
14
 
15
- let DnnImageCropper = class {
16
- constructor(hostRef) {
17
- registerInstance(this, hostRef);
18
- this.imageCropChanged = createEvent(this, "imageCropChanged", 7);
19
- /** Sets the desired final image width. */
20
- this.width = 600;
21
- /** Sets the desired final image height. */
22
- this.height = 600;
23
- /** Can be used to customize controls text.
24
- * Some values support tokens, see default values for examples.
25
- */
26
- this.resx = {
27
- capture: "Capture",
28
- dragAndDropFile: "Drag and drop an image",
29
- or: "or",
30
- takePicture: "Take a picture",
31
- uploadFile: "Upload an image",
32
- imageTooSmall: "The image you are attempting to upload does not meet the minimum size requirement of {width} pixels by {height} pixels. Please upload a larger image.",
33
- modalCloseText: "Close",
34
- };
35
- /** Sets the output quality of the corpped image (number between 0 and 1). */
36
- this.quality = 0.8;
37
- /** When set to true, prevents cropping an image smaller than the required size, which would blow pixel and make the final picture look blurry. */
38
- this.preventUndersized = false;
39
- this.handleCropMouseDown = (event) => {
40
- event.stopPropagation();
41
- event.preventDefault();
42
- const element = event.target;
43
- const className = element.classList[0];
44
- document.addEventListener("mouseup", this.handleImageCropFinished, false);
45
- document.addEventListener("touchend", this.handleImageCropFinished, false);
46
- switch (className) {
47
- case "crop":
48
- document.addEventListener("mousemove", this.handleCropDrag, false);
49
- document.addEventListener("touchmove", this.handleCropDrag, false);
50
- document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleCropDrag));
51
- document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleCropDrag));
52
- break;
53
- case "nw":
54
- document.addEventListener("mousemove", this.handleNwMouseMove, false);
55
- document.addEventListener("touchmove", this.handleNwMouseMove, false);
56
- document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleNwMouseMove));
57
- document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleNwMouseMove));
58
- break;
59
- case "ne":
60
- document.addEventListener("mousemove", this.handleNeMouseMove, false);
61
- document.addEventListener("touchmove", this.handleNeMouseMove, false);
62
- document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleNeMouseMove));
63
- document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleNeMouseMove));
64
- break;
65
- case "se":
66
- document.addEventListener("mousemove", this.handleSeMouseMove, false);
67
- document.addEventListener("touchmove", this.handleSeMouseMove, false);
68
- document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleSeMouseMove));
69
- document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleSeMouseMove));
70
- break;
71
- case "sw":
72
- document.addEventListener("mousemove", this.handleSwMouseMove, false);
73
- document.addEventListener("touchmove", this.handleSwMouseMove, false);
74
- document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleSwMouseMove));
75
- document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleSwMouseMove));
76
- break;
77
- default:
78
- break;
79
- }
80
- };
81
- this.handleImageCropFinished = (_ev) => {
82
- this.emitImage();
83
- document.removeEventListener("mouseup", this.handleImageCropFinished);
84
- this.previousTouch = undefined;
85
- };
86
- this.handleNwMouseMove = (event) => {
87
- this.handleCornerDrag(event, CornerType.nw);
88
- };
89
- this.handleNeMouseMove = (event) => {
90
- this.handleCornerDrag(event, CornerType.ne);
91
- };
92
- this.handleSeMouseMove = (event) => {
93
- this.handleCornerDrag(event, CornerType.se);
94
- };
95
- this.handleSwMouseMove = (event) => {
96
- this.handleCornerDrag(event, CornerType.sw);
97
- };
98
- this.handleCornerDrag = (event, corner) => {
99
- if (!this.isMouseStillInTarget(event)) {
100
- return;
101
- }
102
- let { left, top } = this.getCornerLeftTop(corner);
103
- let newWidth = 0;
104
- let newHeight = 0;
105
- let orientation = "horizontal";
106
- const wantedRatio = this.width / this.height;
107
- const cropRect = this.crop.getBoundingClientRect();
108
- const imageRect = this.image.getBoundingClientRect();
109
- let { movementX, movementY } = getMovementFromEvent(event, this.previousTouch);
110
- if (Math.abs(movementX) < Math.abs(movementY)) {
111
- orientation = "vertical";
112
- }
113
- if (orientation == "horizontal") {
114
- switch (corner) {
115
- case CornerType.nw:
116
- case CornerType.sw:
117
- newWidth = cropRect.width - movementX;
118
- newHeight = newWidth / wantedRatio;
119
- break;
120
- case CornerType.ne:
121
- case CornerType.se:
122
- newWidth = cropRect.width + movementX;
123
- newHeight = newWidth / wantedRatio;
124
- break;
125
- default:
126
- break;
127
- }
128
- }
129
- else {
130
- switch (corner) {
131
- case CornerType.nw:
132
- case CornerType.ne:
133
- newHeight = cropRect.height - movementY;
134
- newWidth = newHeight * wantedRatio;
135
- break;
136
- case CornerType.se:
137
- case CornerType.sw:
138
- newHeight = cropRect.height + movementY;
139
- newWidth = newHeight * wantedRatio;
140
- break;
141
- default:
142
- break;
143
- }
144
- }
145
- switch (corner) {
146
- case CornerType.ne:
147
- case CornerType.nw:
148
- const topOffset = cropRect.height - newHeight;
149
- top = this.crop.offsetTop + topOffset;
150
- default:
151
- break;
152
- }
153
- switch (corner) {
154
- case CornerType.nw:
155
- case CornerType.sw:
156
- const leftOffset = cropRect.width - newWidth;
157
- left = this.crop.offsetLeft + leftOffset;
158
- if (left < 0)
159
- left = 0;
160
- if (left > imageRect.width)
161
- left = imageRect.width;
162
- if (top < 0)
163
- top = 0;
164
- if (top > imageRect.height)
165
- top = imageRect.height;
166
- if (left + newWidth > imageRect.width)
167
- newWidth = imageRect.width - left;
168
- if (top + newHeight > imageRect.height)
169
- newHeight = imageRect.height - top;
170
- break;
171
- case CornerType.ne:
172
- case CornerType.se:
173
- if (top < 0)
174
- top = 0;
175
- if (top > imageRect.height)
176
- top = imageRect.height;
177
- if (left + newWidth > imageRect.width)
178
- newWidth = imageRect.width - left;
179
- if (top + newHeight > imageRect.height)
180
- newHeight = imageRect.height - top;
181
- break;
182
- default:
183
- break;
184
- }
185
- if (newWidth / newHeight != wantedRatio) {
186
- return;
187
- }
188
- if (this.preventUndersized) {
189
- const zoomRatio = this.image.width / this.image.naturalWidth;
190
- if (newWidth / zoomRatio < this.width || newHeight / zoomRatio < this.height) {
191
- return;
192
- }
193
- }
194
- switch (corner) {
195
- case CornerType.ne:
196
- this.crop.style.top = `${top}px`;
197
- this.crop.style.width = `${newWidth}px`;
198
- this.crop.style.height = `${newHeight}px`;
199
- break;
200
- case CornerType.nw:
201
- this.crop.style.left = `${left}px`;
202
- this.crop.style.top = `${top}px`;
203
- this.crop.style.width = `${newWidth}px`;
204
- this.crop.style.height = `${newHeight}px`;
205
- break;
206
- case CornerType.se:
207
- this.crop.style.width = `${newWidth}px`;
208
- this.crop.style.height = `${newHeight}px`;
209
- break;
210
- case CornerType.sw:
211
- this.crop.style.left = `${left}px`;
212
- this.crop.style.width = `${newWidth}px`;
213
- this.crop.style.height = `${newHeight}px`;
214
- break;
215
- default:
216
- break;
217
- }
218
- };
219
- this.handleCropDrag = (ev) => {
220
- if (!this.isMouseStillInTarget(ev)) {
221
- return;
222
- }
223
- let { movementX, movementY } = getMovementFromEvent(ev, this.previousTouch);
224
- let newLeft = this.crop.offsetLeft + movementX;
225
- let newTop = this.crop.offsetTop + movementY;
226
- var imageRect = this.image.getBoundingClientRect();
227
- var cropRect = this.crop.getBoundingClientRect();
228
- if (newLeft < 0) {
229
- newLeft = 0;
230
- }
231
- if (newTop < 0) {
232
- newTop = 0;
233
- }
234
- if (newLeft + cropRect.width > imageRect.width) {
235
- newLeft = this.crop.offsetLeft;
236
- }
237
- if (newTop + cropRect.height > imageRect.height) {
238
- newTop = this.crop.offsetTop;
239
- }
240
- this.crop.style.left = newLeft + "px";
241
- this.crop.style.top = newTop + "px";
242
- };
243
- }
244
- componentDidLoad() {
245
- requestAnimationFrame(() => {
246
- this.setView("noPictureView");
247
- });
248
- }
249
- setView(newView) {
250
- const views = this.host.shadowRoot.querySelectorAll(".view");
251
- views.forEach(v => v.classList.remove("visible"));
252
- switch (newView) {
253
- case "noPictureView":
254
- this.noPictureView.classList.add("visible");
255
- break;
256
- case "hasPictureView":
257
- this.hasPictureView.classList.add("visible");
258
- break;
259
- default:
260
- break;
261
- }
262
- this.view = newView;
263
- }
264
- initCrop() {
265
- var wantedRatio = this.width / this.height;
266
- var imageRect = this.image.getBoundingClientRect();
267
- var imageRatio = imageRect.width / imageRect.height;
268
- if (wantedRatio > imageRatio) {
269
- var wantedHeight = imageRect.width / wantedRatio;
270
- var diff = imageRect.height - wantedHeight;
271
- this.crop.style.top = Math.round(diff / 2).toString() + "px";
272
- this.crop.style.height = Math.round(wantedHeight).toString() + "px";
273
- }
274
- else {
275
- var wantedWidth = imageRect.height * wantedRatio;
276
- var diff = imageRect.width - wantedWidth;
277
- this.crop.style.left = Math.round(diff / 2).toString() + "px";
278
- this.crop.style.width = Math.round(wantedWidth).toString() + "px";
279
- }
280
- }
281
- setImage() {
282
- this.image.addEventListener('load', () => {
283
- this.initCrop();
284
- this.emitImage();
285
- });
286
- this.image.src = this.canvas.toDataURL();
287
- }
288
- handleNewFile(file) {
289
- if (file.type.split('/')[0] != "image") {
290
- return;
291
- }
292
- var reader = new FileReader();
293
- reader.onload = readerLoadEvent => {
294
- var img = new Image();
295
- img.onload = () => {
296
- this.canvas.width = img.width;
297
- this.canvas.height = img.height;
298
- if (this.preventUndersized && (img.width < this.width || img.height < this.height)) {
299
- this.imageTooSmallModal.show();
300
- return;
301
- }
302
- var ctx = this.canvas.getContext("2d");
303
- ctx.drawImage(img, 0, 0);
304
- this.setView("hasPictureView");
305
- this.setImage();
306
- };
307
- img.src = readerLoadEvent.target.result.toString();
308
- };
309
- reader.readAsDataURL(file);
310
- }
311
- emitImage() {
312
- var x = this.crop.offsetLeft / this.image.width * this.image.naturalWidth;
313
- var y = this.crop.offsetTop / this.image.height * this.image.naturalHeight;
314
- var cropRect = this.crop.getBoundingClientRect();
315
- var width = cropRect.width / this.image.width * this.image.naturalWidth;
316
- var height = cropRect.height / this.image.height * this.image.naturalHeight;
317
- if (x < 0)
318
- x = 0;
319
- if (x > this.image.naturalWidth)
320
- x = this.image.naturalWidth;
321
- if (y < 0)
322
- y = 0;
323
- if (y > this.image.naturalWidth)
324
- y = this.image.naturalWidth;
325
- if (width > this.image.naturalWidth)
326
- width = this.image.naturalWidth;
327
- if (height > this.image.naturalHeight)
328
- height = this.image.naturalHeight;
329
- var dataUrl = this.generateCroppedImage(x, y, width, height, this.width, this.height);
330
- this.imageCropChanged.emit(dataUrl);
331
- }
332
- generateCroppedImage(x, y, width, height, desiredWidth, desiredHeight) {
333
- this.canvas.width = desiredWidth;
334
- this.canvas.height = desiredHeight;
335
- const context = this.canvas.getContext("2d");
336
- context.clearRect(0, 0, desiredWidth, desiredHeight);
337
- context.drawImage(this.image, x, y, width, height, 0, 0, desiredWidth, desiredHeight);
338
- return this.canvas.toDataURL("image/jpeg", this.quality);
339
- }
340
- getCornerLeftTop(corner) {
341
- let left = 0;
342
- let top = 0;
343
- switch (corner) {
344
- case CornerType.se:
345
- left = this.crop.offsetLeft;
346
- top = this.crop.offsetTop;
347
- break;
348
- case CornerType.sw:
349
- top = this.crop.offsetTop;
350
- break;
351
- default:
352
- break;
353
- }
354
- return { top, left };
355
- }
356
- isMouseStillInTarget(event) {
357
- var inside = false;
358
- let mouseX;
359
- let mouseY;
360
- const imageRect = this.image.getBoundingClientRect();
361
- if (event instanceof MouseEvent) {
362
- mouseX = event.clientX;
363
- mouseY = event.clientY;
364
- }
365
- if (typeof TouchEvent !== "undefined") {
366
- if (event instanceof TouchEvent) {
367
- var touch = event.touches[0];
368
- mouseX = touch.clientX;
369
- mouseY = touch.clientY;
370
- }
371
- }
372
- if (mouseX >= imageRect.x &&
373
- mouseY >= imageRect.y &&
374
- mouseX <= imageRect.left + imageRect.width &&
375
- mouseY <= imageRect.top + imageRect.height) {
376
- inside = true;
377
- }
378
- var corners = this.crop.querySelectorAll("div");
379
- corners.forEach(corner => {
380
- var cornerRect = corner.getBoundingClientRect();
381
- if (mouseX >= cornerRect.x &&
382
- mouseY >= cornerRect.y &&
383
- mouseX <= cornerRect.left + cornerRect.width &&
384
- mouseY <= cornerRect.top + cornerRect.height) {
385
- inside = true;
386
- }
387
- });
388
- return inside;
389
- }
390
- render() {
391
- return (h(Host, { ref: el => this.host = el }, h("canvas", { ref: el => this.canvas = el }), h("div", { class: "view", ref: el => this.hasPictureView = el }, h("div", { class: "cropper" }, h("img", { ref: el => this.image = el }), h("div", { class: "backdrop" }), h("div", { class: "crop", ref: e => this.crop = e, onMouseDown: this.handleCropMouseDown, onTouchStart: this.handleCropMouseDown }, h("div", { class: "nw" }), h("div", { class: "ne" }), h("div", { class: "se" }), h("div", { class: "sw" })))), h("div", { class: "view", ref: el => this.noPictureView = el }, h("dnn-dropzone", { allowCameraMode: true, onFilesSelected: e => this.handleNewFile(e.detail[0]), resx: {
392
- capture: this.resx.capture,
393
- dragAndDropFile: this.resx.dragAndDropFile,
394
- or: this.resx.or,
395
- takePicture: this.resx.takePicture,
396
- uploadFile: this.resx.uploadFile,
397
- } })), h("dnn-modal", { ref: el => this.imageTooSmallModal = el, "close-text": this.resx.modalCloseText }, h("p", null, this.resx.imageTooSmall.replace("{width}", this.width.toString()).replace("{height}", this.height.toString())))));
398
- }
399
- };
15
+ const DnnImageCropper = class {
16
+ constructor(hostRef) {
17
+ registerInstance(this, hostRef);
18
+ this.imageCropChanged = createEvent(this, "imageCropChanged", 7);
19
+ /** Sets the desired final image width. */
20
+ this.width = 600;
21
+ /** Sets the desired final image height. */
22
+ this.height = 600;
23
+ /** Can be used to customize controls text.
24
+ * Some values support tokens, see default values for examples.
25
+ */
26
+ this.resx = {
27
+ capture: "Capture",
28
+ dragAndDropFile: "Drag and drop an image",
29
+ or: "or",
30
+ takePicture: "Take a picture",
31
+ uploadFile: "Upload an image",
32
+ imageTooSmall: "The image you are attempting to upload does not meet the minimum size requirement of {width} pixels by {height} pixels. Please upload a larger image.",
33
+ modalCloseText: "Close",
34
+ };
35
+ /** Sets the output quality of the corpped image (number between 0 and 1). */
36
+ this.quality = 0.8;
37
+ /** When set to true, prevents cropping an image smaller than the required size, which would blow pixel and make the final picture look blurry. */
38
+ this.preventUndersized = false;
39
+ this.handleCropMouseDown = (event) => {
40
+ event.stopPropagation();
41
+ event.preventDefault();
42
+ const element = event.target;
43
+ const className = element.classList[0];
44
+ document.addEventListener("mouseup", this.handleImageCropFinished, false);
45
+ document.addEventListener("touchend", this.handleImageCropFinished, false);
46
+ switch (className) {
47
+ case "crop":
48
+ document.addEventListener("mousemove", this.handleCropDrag, false);
49
+ document.addEventListener("touchmove", this.handleCropDrag, false);
50
+ document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleCropDrag));
51
+ document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleCropDrag));
52
+ break;
53
+ case "nw":
54
+ document.addEventListener("mousemove", this.handleNwMouseMove, false);
55
+ document.addEventListener("touchmove", this.handleNwMouseMove, false);
56
+ document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleNwMouseMove));
57
+ document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleNwMouseMove));
58
+ break;
59
+ case "ne":
60
+ document.addEventListener("mousemove", this.handleNeMouseMove, false);
61
+ document.addEventListener("touchmove", this.handleNeMouseMove, false);
62
+ document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleNeMouseMove));
63
+ document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleNeMouseMove));
64
+ break;
65
+ case "se":
66
+ document.addEventListener("mousemove", this.handleSeMouseMove, false);
67
+ document.addEventListener("touchmove", this.handleSeMouseMove, false);
68
+ document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleSeMouseMove));
69
+ document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleSeMouseMove));
70
+ break;
71
+ case "sw":
72
+ document.addEventListener("mousemove", this.handleSwMouseMove, false);
73
+ document.addEventListener("touchmove", this.handleSwMouseMove, false);
74
+ document.addEventListener("mouseup", () => document.removeEventListener("mousemove", this.handleSwMouseMove));
75
+ document.addEventListener("touchend", () => document.removeEventListener("touchmove", this.handleSwMouseMove));
76
+ break;
77
+ default:
78
+ break;
79
+ }
80
+ };
81
+ this.handleImageCropFinished = (_ev) => {
82
+ this.emitImage();
83
+ document.removeEventListener("mouseup", this.handleImageCropFinished);
84
+ this.previousTouch = undefined;
85
+ };
86
+ this.handleNwMouseMove = (event) => {
87
+ this.handleCornerDrag(event, CornerType.nw);
88
+ };
89
+ this.handleNeMouseMove = (event) => {
90
+ this.handleCornerDrag(event, CornerType.ne);
91
+ };
92
+ this.handleSeMouseMove = (event) => {
93
+ this.handleCornerDrag(event, CornerType.se);
94
+ };
95
+ this.handleSwMouseMove = (event) => {
96
+ this.handleCornerDrag(event, CornerType.sw);
97
+ };
98
+ this.handleCornerDrag = (event, corner) => {
99
+ if (!this.isMouseStillInTarget(event)) {
100
+ return;
101
+ }
102
+ let { left, top } = this.getCornerLeftTop(corner);
103
+ let newWidth = 0;
104
+ let newHeight = 0;
105
+ let orientation = "horizontal";
106
+ const wantedRatio = this.width / this.height;
107
+ const cropRect = this.crop.getBoundingClientRect();
108
+ const imageRect = this.image.getBoundingClientRect();
109
+ let { movementX, movementY } = getMovementFromEvent(event, this.previousTouch);
110
+ if (Math.abs(movementX) < Math.abs(movementY)) {
111
+ orientation = "vertical";
112
+ }
113
+ if (orientation == "horizontal") {
114
+ switch (corner) {
115
+ case CornerType.nw:
116
+ case CornerType.sw:
117
+ newWidth = cropRect.width - movementX;
118
+ newHeight = newWidth / wantedRatio;
119
+ break;
120
+ case CornerType.ne:
121
+ case CornerType.se:
122
+ newWidth = cropRect.width + movementX;
123
+ newHeight = newWidth / wantedRatio;
124
+ break;
125
+ default:
126
+ break;
127
+ }
128
+ }
129
+ else {
130
+ switch (corner) {
131
+ case CornerType.nw:
132
+ case CornerType.ne:
133
+ newHeight = cropRect.height - movementY;
134
+ newWidth = newHeight * wantedRatio;
135
+ break;
136
+ case CornerType.se:
137
+ case CornerType.sw:
138
+ newHeight = cropRect.height + movementY;
139
+ newWidth = newHeight * wantedRatio;
140
+ break;
141
+ default:
142
+ break;
143
+ }
144
+ }
145
+ switch (corner) {
146
+ case CornerType.ne:
147
+ case CornerType.nw:
148
+ const topOffset = cropRect.height - newHeight;
149
+ top = this.crop.offsetTop + topOffset;
150
+ default:
151
+ break;
152
+ }
153
+ switch (corner) {
154
+ case CornerType.nw:
155
+ case CornerType.sw:
156
+ const leftOffset = cropRect.width - newWidth;
157
+ left = this.crop.offsetLeft + leftOffset;
158
+ if (left < 0)
159
+ left = 0;
160
+ if (left > imageRect.width)
161
+ left = imageRect.width;
162
+ if (top < 0)
163
+ top = 0;
164
+ if (top > imageRect.height)
165
+ top = imageRect.height;
166
+ if (left + newWidth > imageRect.width)
167
+ newWidth = imageRect.width - left;
168
+ if (top + newHeight > imageRect.height)
169
+ newHeight = imageRect.height - top;
170
+ break;
171
+ case CornerType.ne:
172
+ case CornerType.se:
173
+ if (top < 0)
174
+ top = 0;
175
+ if (top > imageRect.height)
176
+ top = imageRect.height;
177
+ if (left + newWidth > imageRect.width)
178
+ newWidth = imageRect.width - left;
179
+ if (top + newHeight > imageRect.height)
180
+ newHeight = imageRect.height - top;
181
+ break;
182
+ default:
183
+ break;
184
+ }
185
+ if (newWidth / newHeight != wantedRatio) {
186
+ return;
187
+ }
188
+ if (this.preventUndersized) {
189
+ const zoomRatio = this.image.width / this.image.naturalWidth;
190
+ if (newWidth / zoomRatio < this.width || newHeight / zoomRatio < this.height) {
191
+ return;
192
+ }
193
+ }
194
+ switch (corner) {
195
+ case CornerType.ne:
196
+ this.crop.style.top = `${top}px`;
197
+ this.crop.style.width = `${newWidth}px`;
198
+ this.crop.style.height = `${newHeight}px`;
199
+ break;
200
+ case CornerType.nw:
201
+ this.crop.style.left = `${left}px`;
202
+ this.crop.style.top = `${top}px`;
203
+ this.crop.style.width = `${newWidth}px`;
204
+ this.crop.style.height = `${newHeight}px`;
205
+ break;
206
+ case CornerType.se:
207
+ this.crop.style.width = `${newWidth}px`;
208
+ this.crop.style.height = `${newHeight}px`;
209
+ break;
210
+ case CornerType.sw:
211
+ this.crop.style.left = `${left}px`;
212
+ this.crop.style.width = `${newWidth}px`;
213
+ this.crop.style.height = `${newHeight}px`;
214
+ break;
215
+ default:
216
+ break;
217
+ }
218
+ };
219
+ this.handleCropDrag = (ev) => {
220
+ if (!this.isMouseStillInTarget(ev)) {
221
+ return;
222
+ }
223
+ let { movementX, movementY } = getMovementFromEvent(ev, this.previousTouch);
224
+ let newLeft = this.crop.offsetLeft + movementX;
225
+ let newTop = this.crop.offsetTop + movementY;
226
+ var imageRect = this.image.getBoundingClientRect();
227
+ var cropRect = this.crop.getBoundingClientRect();
228
+ if (newLeft < 0) {
229
+ newLeft = 0;
230
+ }
231
+ if (newTop < 0) {
232
+ newTop = 0;
233
+ }
234
+ if (newLeft + cropRect.width > imageRect.width) {
235
+ newLeft = this.crop.offsetLeft;
236
+ }
237
+ if (newTop + cropRect.height > imageRect.height) {
238
+ newTop = this.crop.offsetTop;
239
+ }
240
+ this.crop.style.left = newLeft + "px";
241
+ this.crop.style.top = newTop + "px";
242
+ };
243
+ }
244
+ componentDidLoad() {
245
+ requestAnimationFrame(() => {
246
+ this.setView("noPictureView");
247
+ });
248
+ }
249
+ setView(newView) {
250
+ const views = this.host.shadowRoot.querySelectorAll(".view");
251
+ views.forEach(v => v.classList.remove("visible"));
252
+ switch (newView) {
253
+ case "noPictureView":
254
+ this.noPictureView.classList.add("visible");
255
+ break;
256
+ case "hasPictureView":
257
+ this.hasPictureView.classList.add("visible");
258
+ break;
259
+ default:
260
+ break;
261
+ }
262
+ this.view = newView;
263
+ }
264
+ initCrop() {
265
+ var wantedRatio = this.width / this.height;
266
+ var imageRect = this.image.getBoundingClientRect();
267
+ var imageRatio = imageRect.width / imageRect.height;
268
+ if (wantedRatio > imageRatio) {
269
+ var wantedHeight = imageRect.width / wantedRatio;
270
+ var diff = imageRect.height - wantedHeight;
271
+ this.crop.style.top = Math.round(diff / 2).toString() + "px";
272
+ this.crop.style.height = Math.round(wantedHeight).toString() + "px";
273
+ }
274
+ else {
275
+ var wantedWidth = imageRect.height * wantedRatio;
276
+ var diff = imageRect.width - wantedWidth;
277
+ this.crop.style.left = Math.round(diff / 2).toString() + "px";
278
+ this.crop.style.width = Math.round(wantedWidth).toString() + "px";
279
+ }
280
+ }
281
+ setImage() {
282
+ this.image.addEventListener('load', () => {
283
+ this.initCrop();
284
+ this.emitImage();
285
+ });
286
+ this.image.src = this.canvas.toDataURL();
287
+ }
288
+ handleNewFile(file) {
289
+ if (file.type.split('/')[0] != "image") {
290
+ return;
291
+ }
292
+ var reader = new FileReader();
293
+ reader.onload = readerLoadEvent => {
294
+ var img = new Image();
295
+ img.onload = () => {
296
+ this.canvas.width = img.width;
297
+ this.canvas.height = img.height;
298
+ if (this.preventUndersized && (img.width < this.width || img.height < this.height)) {
299
+ this.imageTooSmallModal.show();
300
+ return;
301
+ }
302
+ var ctx = this.canvas.getContext("2d");
303
+ ctx.drawImage(img, 0, 0);
304
+ this.setView("hasPictureView");
305
+ this.setImage();
306
+ };
307
+ img.src = readerLoadEvent.target.result.toString();
308
+ };
309
+ reader.readAsDataURL(file);
310
+ }
311
+ emitImage() {
312
+ var x = this.crop.offsetLeft / this.image.width * this.image.naturalWidth;
313
+ var y = this.crop.offsetTop / this.image.height * this.image.naturalHeight;
314
+ var cropRect = this.crop.getBoundingClientRect();
315
+ var width = cropRect.width / this.image.width * this.image.naturalWidth;
316
+ var height = cropRect.height / this.image.height * this.image.naturalHeight;
317
+ if (x < 0)
318
+ x = 0;
319
+ if (x > this.image.naturalWidth)
320
+ x = this.image.naturalWidth;
321
+ if (y < 0)
322
+ y = 0;
323
+ if (y > this.image.naturalWidth)
324
+ y = this.image.naturalWidth;
325
+ if (width > this.image.naturalWidth)
326
+ width = this.image.naturalWidth;
327
+ if (height > this.image.naturalHeight)
328
+ height = this.image.naturalHeight;
329
+ var dataUrl = this.generateCroppedImage(x, y, width, height, this.width, this.height);
330
+ this.imageCropChanged.emit(dataUrl);
331
+ }
332
+ generateCroppedImage(x, y, width, height, desiredWidth, desiredHeight) {
333
+ this.canvas.width = desiredWidth;
334
+ this.canvas.height = desiredHeight;
335
+ const context = this.canvas.getContext("2d");
336
+ context.clearRect(0, 0, desiredWidth, desiredHeight);
337
+ context.drawImage(this.image, x, y, width, height, 0, 0, desiredWidth, desiredHeight);
338
+ return this.canvas.toDataURL("image/jpeg", this.quality);
339
+ }
340
+ getCornerLeftTop(corner) {
341
+ let left = 0;
342
+ let top = 0;
343
+ switch (corner) {
344
+ case CornerType.se:
345
+ left = this.crop.offsetLeft;
346
+ top = this.crop.offsetTop;
347
+ break;
348
+ case CornerType.sw:
349
+ top = this.crop.offsetTop;
350
+ break;
351
+ default:
352
+ break;
353
+ }
354
+ return { top, left };
355
+ }
356
+ isMouseStillInTarget(event) {
357
+ var inside = false;
358
+ let mouseX;
359
+ let mouseY;
360
+ const imageRect = this.image.getBoundingClientRect();
361
+ if (event instanceof MouseEvent) {
362
+ mouseX = event.clientX;
363
+ mouseY = event.clientY;
364
+ }
365
+ if (typeof TouchEvent !== "undefined") {
366
+ if (event instanceof TouchEvent) {
367
+ var touch = event.touches[0];
368
+ mouseX = touch.clientX;
369
+ mouseY = touch.clientY;
370
+ }
371
+ }
372
+ if (mouseX >= imageRect.x &&
373
+ mouseY >= imageRect.y &&
374
+ mouseX <= imageRect.left + imageRect.width &&
375
+ mouseY <= imageRect.top + imageRect.height) {
376
+ inside = true;
377
+ }
378
+ var corners = this.crop.querySelectorAll("div");
379
+ corners.forEach(corner => {
380
+ var cornerRect = corner.getBoundingClientRect();
381
+ if (mouseX >= cornerRect.x &&
382
+ mouseY >= cornerRect.y &&
383
+ mouseX <= cornerRect.left + cornerRect.width &&
384
+ mouseY <= cornerRect.top + cornerRect.height) {
385
+ inside = true;
386
+ }
387
+ });
388
+ return inside;
389
+ }
390
+ render() {
391
+ return (h(Host, { ref: el => this.host = el }, h("canvas", { ref: el => this.canvas = el }), h("div", { class: "view", ref: el => this.hasPictureView = el }, h("div", { class: "cropper" }, h("img", { ref: el => this.image = el }), h("div", { class: "backdrop" }), h("div", { class: "crop", ref: e => this.crop = e, onMouseDown: this.handleCropMouseDown, onTouchStart: this.handleCropMouseDown }, h("div", { class: "nw" }), h("div", { class: "ne" }), h("div", { class: "se" }), h("div", { class: "sw" })))), h("div", { class: "view", ref: el => this.noPictureView = el }, h("dnn-dropzone", { allowCameraMode: true, onFilesSelected: e => this.handleNewFile(e.detail[0]), resx: {
392
+ capture: this.resx.capture,
393
+ dragAndDropFile: this.resx.dragAndDropFile,
394
+ or: this.resx.or,
395
+ takePicture: this.resx.takePicture,
396
+ uploadFile: this.resx.uploadFile,
397
+ } })), h("dnn-modal", { ref: el => this.imageTooSmallModal = el, "close-text": this.resx.modalCloseText }, h("p", null, this.resx.imageTooSmall.replace("{width}", this.width.toString()).replace("{height}", this.height.toString())))));
398
+ }
399
+ };
400
400
  DnnImageCropper.style = dnnImageCropperCss;
401
401
 
402
402
  export { DnnImageCropper as dnn_image_cropper };