@ptsecurity/mosaic 12.1.0 → 12.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (302) hide show
  1. package/_theming.scss +38 -157
  2. package/_visual.scss +0 -1
  3. package/bundles/ptsecurity-mosaic-autocomplete.umd.js +18 -20
  4. package/bundles/ptsecurity-mosaic-autocomplete.umd.js.map +1 -1
  5. package/bundles/ptsecurity-mosaic-button-toggle.umd.js +15 -17
  6. package/bundles/ptsecurity-mosaic-button-toggle.umd.js.map +1 -1
  7. package/bundles/ptsecurity-mosaic-button.umd.js +17 -19
  8. package/bundles/ptsecurity-mosaic-button.umd.js.map +1 -1
  9. package/bundles/ptsecurity-mosaic-card.umd.js +11 -13
  10. package/bundles/ptsecurity-mosaic-card.umd.js.map +1 -1
  11. package/bundles/ptsecurity-mosaic-checkbox.umd.js +14 -16
  12. package/bundles/ptsecurity-mosaic-checkbox.umd.js.map +1 -1
  13. package/bundles/ptsecurity-mosaic-core.umd.js +122 -168
  14. package/bundles/ptsecurity-mosaic-core.umd.js.map +1 -1
  15. package/bundles/ptsecurity-mosaic-datepicker.umd.js +53 -48
  16. package/bundles/ptsecurity-mosaic-datepicker.umd.js.map +1 -1
  17. package/bundles/ptsecurity-mosaic-design-tokens.umd.js +3 -4
  18. package/bundles/ptsecurity-mosaic-design-tokens.umd.js.map +1 -1
  19. package/bundles/ptsecurity-mosaic-divider.umd.js +11 -13
  20. package/bundles/ptsecurity-mosaic-divider.umd.js.map +1 -1
  21. package/bundles/ptsecurity-mosaic-dropdown.umd.js +36 -23
  22. package/bundles/ptsecurity-mosaic-dropdown.umd.js.map +1 -1
  23. package/bundles/ptsecurity-mosaic-form-field.umd.js +737 -738
  24. package/bundles/ptsecurity-mosaic-form-field.umd.js.map +1 -1
  25. package/bundles/ptsecurity-mosaic-icon.umd.js +14 -16
  26. package/bundles/ptsecurity-mosaic-icon.umd.js.map +1 -1
  27. package/bundles/ptsecurity-mosaic-input.umd.js +45 -33
  28. package/bundles/ptsecurity-mosaic-input.umd.js.map +1 -1
  29. package/bundles/ptsecurity-mosaic-link.umd.js +11 -13
  30. package/bundles/ptsecurity-mosaic-link.umd.js.map +1 -1
  31. package/bundles/ptsecurity-mosaic-list.umd.js +37 -36
  32. package/bundles/ptsecurity-mosaic-list.umd.js.map +1 -1
  33. package/bundles/ptsecurity-mosaic-modal.umd.js +52 -44
  34. package/bundles/ptsecurity-mosaic-modal.umd.js.map +1 -1
  35. package/bundles/ptsecurity-mosaic-navbar.umd.js +40 -42
  36. package/bundles/ptsecurity-mosaic-navbar.umd.js.map +1 -1
  37. package/bundles/ptsecurity-mosaic-popover.umd.js +215 -34
  38. package/bundles/ptsecurity-mosaic-popover.umd.js.map +1 -1
  39. package/bundles/ptsecurity-mosaic-progress-bar.umd.js +12 -14
  40. package/bundles/ptsecurity-mosaic-progress-bar.umd.js.map +1 -1
  41. package/bundles/ptsecurity-mosaic-progress-spinner.umd.js +12 -14
  42. package/bundles/ptsecurity-mosaic-progress-spinner.umd.js.map +1 -1
  43. package/bundles/ptsecurity-mosaic-radio.umd.js +14 -16
  44. package/bundles/ptsecurity-mosaic-radio.umd.js.map +1 -1
  45. package/bundles/ptsecurity-mosaic-select.umd.js +22 -24
  46. package/bundles/ptsecurity-mosaic-select.umd.js.map +1 -1
  47. package/bundles/ptsecurity-mosaic-sidebar.umd.js +17 -19
  48. package/bundles/ptsecurity-mosaic-sidebar.umd.js.map +1 -1
  49. package/bundles/ptsecurity-mosaic-sidepanel.umd.js +62 -58
  50. package/bundles/ptsecurity-mosaic-sidepanel.umd.js.map +1 -1
  51. package/bundles/ptsecurity-mosaic-splitter.umd.js +245 -48
  52. package/bundles/ptsecurity-mosaic-splitter.umd.js.map +1 -1
  53. package/bundles/ptsecurity-mosaic-table.umd.js +11 -13
  54. package/bundles/ptsecurity-mosaic-table.umd.js.map +1 -1
  55. package/bundles/ptsecurity-mosaic-tabs.umd.js +56 -58
  56. package/bundles/ptsecurity-mosaic-tabs.umd.js.map +1 -1
  57. package/bundles/ptsecurity-mosaic-tags.umd.js +77 -73
  58. package/bundles/ptsecurity-mosaic-tags.umd.js.map +1 -1
  59. package/bundles/ptsecurity-mosaic-textarea.umd.js +12 -14
  60. package/bundles/ptsecurity-mosaic-textarea.umd.js.map +1 -1
  61. package/bundles/ptsecurity-mosaic-timepicker.umd.js +15 -16
  62. package/bundles/ptsecurity-mosaic-timepicker.umd.js.map +1 -1
  63. package/bundles/ptsecurity-mosaic-toggle.umd.js +11 -13
  64. package/bundles/ptsecurity-mosaic-toggle.umd.js.map +1 -1
  65. package/bundles/ptsecurity-mosaic-tooltip.umd.js +72 -23
  66. package/bundles/ptsecurity-mosaic-tooltip.umd.js.map +1 -1
  67. package/bundles/ptsecurity-mosaic-tree-select.umd.js +17 -18
  68. package/bundles/ptsecurity-mosaic-tree-select.umd.js.map +1 -1
  69. package/bundles/ptsecurity-mosaic-tree.umd.js +45 -53
  70. package/bundles/ptsecurity-mosaic-tree.umd.js.map +1 -1
  71. package/bundles/ptsecurity-mosaic.umd.js +2 -2
  72. package/core/pop-up/pop-up-trigger.d.ts +9 -12
  73. package/design-tokens/style-dictionary/build.js +6 -0
  74. package/design-tokens/style-dictionary/configs/index.js +2 -1
  75. package/design-tokens/tokens.d.ts +0 -1
  76. package/dropdown/dropdown-item.component.d.ts +1 -0
  77. package/esm2015/autocomplete/autocomplete-origin.directive.js +4 -4
  78. package/esm2015/autocomplete/autocomplete-trigger.directive.js +4 -4
  79. package/esm2015/autocomplete/autocomplete.component.js +4 -4
  80. package/esm2015/autocomplete/autocomplete.module.js +5 -5
  81. package/esm2015/button/button.component.js +10 -10
  82. package/esm2015/button/button.module.js +5 -5
  83. package/esm2015/button-toggle/button-toggle.component.js +7 -7
  84. package/esm2015/button-toggle/button-toggle.module.js +5 -5
  85. package/esm2015/card/card.component.js +4 -4
  86. package/esm2015/card/card.module.js +5 -5
  87. package/esm2015/checkbox/checkbox-module.js +5 -5
  88. package/esm2015/checkbox/checkbox-required-validator.js +4 -4
  89. package/esm2015/checkbox/checkbox.js +4 -4
  90. package/esm2015/core/common-behaviors/common-module.js +5 -5
  91. package/esm2015/core/error/error-options.js +7 -7
  92. package/esm2015/core/formatters/date/formatter.js +6 -5
  93. package/esm2015/core/formatters/index.js +5 -5
  94. package/esm2015/core/formatters/number/formatter.js +5 -5
  95. package/esm2015/core/forms/forms-module.js +5 -5
  96. package/esm2015/core/forms/forms.directive.js +7 -7
  97. package/esm2015/core/highlight/highlight.pipe.js +4 -4
  98. package/esm2015/core/highlight/index.js +5 -5
  99. package/esm2015/core/line/line.js +8 -8
  100. package/esm2015/core/option/action.js +4 -4
  101. package/esm2015/core/option/optgroup.js +4 -4
  102. package/esm2015/core/option/option-module.js +5 -5
  103. package/esm2015/core/option/option.js +4 -4
  104. package/esm2015/core/pop-up/pop-up-trigger.js +32 -66
  105. package/esm2015/core/pop-up/pop-up.js +4 -4
  106. package/esm2015/core/selection/pseudo-checkbox/pseudo-checkbox.js +4 -4
  107. package/esm2015/core/selection/pseudo-checkbox/pseudo-checkbox.module.js +5 -5
  108. package/esm2015/core/services/measure-scrollbar.service.js +4 -4
  109. package/esm2015/datepicker/calendar-body.component.js +4 -4
  110. package/esm2015/datepicker/calendar.component.js +7 -7
  111. package/esm2015/datepicker/datepicker-input.directive.js +12 -5
  112. package/esm2015/datepicker/datepicker-intl.js +4 -4
  113. package/esm2015/datepicker/datepicker-module.js +5 -5
  114. package/esm2015/datepicker/datepicker-toggle.component.js +7 -7
  115. package/esm2015/datepicker/datepicker.component.js +7 -7
  116. package/esm2015/datepicker/month-view.component.js +4 -4
  117. package/esm2015/datepicker/multi-year-view.component.js +4 -4
  118. package/esm2015/datepicker/year-view.component.js +4 -4
  119. package/esm2015/design-tokens/tokens.js +1 -2
  120. package/esm2015/divider/divider.component.js +4 -4
  121. package/esm2015/divider/divider.module.js +5 -5
  122. package/esm2015/dropdown/dropdown-content.directive.js +4 -4
  123. package/esm2015/dropdown/dropdown-item.component.js +11 -4
  124. package/esm2015/dropdown/dropdown-trigger.directive.js +13 -5
  125. package/esm2015/dropdown/dropdown.component.js +4 -4
  126. package/esm2015/dropdown/dropdown.module.js +5 -5
  127. package/esm2015/form-field/cleaner.js +9 -5
  128. package/esm2015/form-field/form-field.js +7 -7
  129. package/esm2015/form-field/form-field.module.js +5 -5
  130. package/esm2015/form-field/hint.js +4 -4
  131. package/esm2015/form-field/prefix.js +4 -4
  132. package/esm2015/form-field/stepper.js +4 -4
  133. package/esm2015/form-field/suffix.js +4 -4
  134. package/esm2015/icon/icon.component.js +7 -7
  135. package/esm2015/icon/icon.module.js +5 -5
  136. package/esm2015/input/input-number-validators.js +28 -14
  137. package/esm2015/input/input-number.js +4 -4
  138. package/esm2015/input/input.js +7 -7
  139. package/esm2015/input/input.module.js +5 -5
  140. package/esm2015/link/link.component.js +4 -4
  141. package/esm2015/link/link.module.js +5 -5
  142. package/esm2015/list/list-selection.component.js +24 -21
  143. package/esm2015/list/list.component.js +7 -7
  144. package/esm2015/list/list.module.js +5 -5
  145. package/esm2015/modal/css-unit.pipe.js +4 -4
  146. package/esm2015/modal/modal-control.service.js +4 -4
  147. package/esm2015/modal/modal.component.js +6 -4
  148. package/esm2015/modal/modal.directive.js +13 -13
  149. package/esm2015/modal/modal.module.js +9 -7
  150. package/esm2015/modal/modal.service.js +16 -9
  151. package/esm2015/navbar/navbar-item.component.js +21 -21
  152. package/esm2015/navbar/navbar.component.js +7 -7
  153. package/esm2015/navbar/navbar.module.js +5 -5
  154. package/esm2015/navbar/vertical-navbar.component.js +7 -7
  155. package/esm2015/popover/popover-confirm.component.js +116 -0
  156. package/esm2015/popover/popover.component.js +63 -20
  157. package/esm2015/popover/popover.module.js +13 -10
  158. package/esm2015/popover/public-api.js +2 -1
  159. package/esm2015/progress-bar/progress-bar.component.js +4 -4
  160. package/esm2015/progress-bar/progress-bar.module.js +5 -5
  161. package/esm2015/progress-spinner/progress-spinner.component.js +4 -4
  162. package/esm2015/progress-spinner/progress-spinner.module.js +5 -5
  163. package/esm2015/radio/radio.component.js +7 -7
  164. package/esm2015/radio/radio.module.js +5 -5
  165. package/esm2015/select/select.component.js +14 -14
  166. package/esm2015/select/select.module.js +5 -5
  167. package/esm2015/sidebar/sidebar.component.js +10 -10
  168. package/esm2015/sidebar/sidebar.module.js +5 -5
  169. package/esm2015/sidepanel/sidepanel-container.component.js +14 -13
  170. package/esm2015/sidepanel/sidepanel-directives.js +22 -18
  171. package/esm2015/sidepanel/sidepanel.module.js +12 -8
  172. package/esm2015/sidepanel/sidepanel.service.js +6 -5
  173. package/esm2015/splitter/splitter.component.js +198 -40
  174. package/esm2015/splitter/splitter.module.js +8 -6
  175. package/esm2015/table/table.component.js +4 -4
  176. package/esm2015/table/table.module.js +5 -5
  177. package/esm2015/tabs/paginated-tab-header.js +4 -4
  178. package/esm2015/tabs/tab-body.component.js +7 -7
  179. package/esm2015/tabs/tab-content.directive.js +4 -4
  180. package/esm2015/tabs/tab-group.component.js +19 -19
  181. package/esm2015/tabs/tab-header.component.js +4 -4
  182. package/esm2015/tabs/tab-label-wrapper.directive.js +4 -4
  183. package/esm2015/tabs/tab-label.directive.js +4 -4
  184. package/esm2015/tabs/tab-nav-bar/tab-nav-bar.js +7 -7
  185. package/esm2015/tabs/tab.component.js +4 -4
  186. package/esm2015/tabs/tabs.module.js +5 -5
  187. package/esm2015/tags/tag-input.js +4 -4
  188. package/esm2015/tags/tag-list.component.js +4 -4
  189. package/esm2015/tags/tag.component.js +61 -57
  190. package/esm2015/tags/tag.module.js +5 -5
  191. package/esm2015/textarea/textarea.component.js +4 -4
  192. package/esm2015/textarea/textarea.module.js +5 -5
  193. package/esm2015/timepicker/timepicker.directive.js +8 -7
  194. package/esm2015/timepicker/timepicker.module.js +5 -5
  195. package/esm2015/toggle/toggle.component.js +4 -4
  196. package/esm2015/toggle/toggle.module.js +5 -5
  197. package/esm2015/tooltip/tooltip.component.js +55 -16
  198. package/esm2015/tooltip/tooltip.module.js +5 -5
  199. package/esm2015/tree/node.js +4 -4
  200. package/esm2015/tree/outlet.js +4 -4
  201. package/esm2015/tree/padding.directive.js +5 -8
  202. package/esm2015/tree/toggle.js +11 -11
  203. package/esm2015/tree/tree-base.js +7 -7
  204. package/esm2015/tree/tree-option.component.js +5 -5
  205. package/esm2015/tree/tree-selection.component.js +4 -4
  206. package/esm2015/tree/tree.js +4 -4
  207. package/esm2015/tree/tree.module.js +5 -8
  208. package/esm2015/tree-select/tree-select.component.js +9 -8
  209. package/esm2015/tree-select/tree-select.module.js +5 -5
  210. package/fesm2015/ptsecurity-mosaic-autocomplete.js +13 -13
  211. package/fesm2015/ptsecurity-mosaic-autocomplete.js.map +1 -1
  212. package/fesm2015/ptsecurity-mosaic-button-toggle.js +10 -10
  213. package/fesm2015/ptsecurity-mosaic-button-toggle.js.map +1 -1
  214. package/fesm2015/ptsecurity-mosaic-button.js +13 -13
  215. package/fesm2015/ptsecurity-mosaic-button.js.map +1 -1
  216. package/fesm2015/ptsecurity-mosaic-card.js +7 -7
  217. package/fesm2015/ptsecurity-mosaic-card.js.map +1 -1
  218. package/fesm2015/ptsecurity-mosaic-checkbox.js +10 -10
  219. package/fesm2015/ptsecurity-mosaic-checkbox.js.map +1 -1
  220. package/fesm2015/ptsecurity-mosaic-core.js +102 -136
  221. package/fesm2015/ptsecurity-mosaic-core.js.map +1 -1
  222. package/fesm2015/ptsecurity-mosaic-datepicker.js +48 -41
  223. package/fesm2015/ptsecurity-mosaic-datepicker.js.map +1 -1
  224. package/fesm2015/ptsecurity-mosaic-design-tokens.js +0 -1
  225. package/fesm2015/ptsecurity-mosaic-design-tokens.js.map +1 -1
  226. package/fesm2015/ptsecurity-mosaic-divider.js +7 -7
  227. package/fesm2015/ptsecurity-mosaic-divider.js.map +1 -1
  228. package/fesm2015/ptsecurity-mosaic-dropdown.js +32 -17
  229. package/fesm2015/ptsecurity-mosaic-dropdown.js.map +1 -1
  230. package/fesm2015/ptsecurity-mosaic-form-field.js +30 -27
  231. package/fesm2015/ptsecurity-mosaic-form-field.js.map +1 -1
  232. package/fesm2015/ptsecurity-mosaic-icon.js +10 -10
  233. package/fesm2015/ptsecurity-mosaic-icon.js.map +1 -1
  234. package/fesm2015/ptsecurity-mosaic-input.js +40 -26
  235. package/fesm2015/ptsecurity-mosaic-input.js.map +1 -1
  236. package/fesm2015/ptsecurity-mosaic-link.js +7 -7
  237. package/fesm2015/ptsecurity-mosaic-link.js.map +1 -1
  238. package/fesm2015/ptsecurity-mosaic-list.js +33 -30
  239. package/fesm2015/ptsecurity-mosaic-list.js.map +1 -1
  240. package/fesm2015/ptsecurity-mosaic-modal.js +46 -35
  241. package/fesm2015/ptsecurity-mosaic-modal.js.map +1 -1
  242. package/fesm2015/ptsecurity-mosaic-navbar.js +36 -36
  243. package/fesm2015/ptsecurity-mosaic-navbar.js.map +1 -1
  244. package/fesm2015/ptsecurity-mosaic-popover.js +179 -30
  245. package/fesm2015/ptsecurity-mosaic-popover.js.map +1 -1
  246. package/fesm2015/ptsecurity-mosaic-progress-bar.js +7 -7
  247. package/fesm2015/ptsecurity-mosaic-progress-bar.js.map +1 -1
  248. package/fesm2015/ptsecurity-mosaic-progress-spinner.js +7 -7
  249. package/fesm2015/ptsecurity-mosaic-progress-spinner.js.map +1 -1
  250. package/fesm2015/ptsecurity-mosaic-radio.js +10 -10
  251. package/fesm2015/ptsecurity-mosaic-radio.js.map +1 -1
  252. package/fesm2015/ptsecurity-mosaic-select.js +17 -17
  253. package/fesm2015/ptsecurity-mosaic-select.js.map +1 -1
  254. package/fesm2015/ptsecurity-mosaic-sidebar.js +13 -13
  255. package/fesm2015/ptsecurity-mosaic-sidebar.js.map +1 -1
  256. package/fesm2015/ptsecurity-mosaic-sidepanel.js +50 -41
  257. package/fesm2015/ptsecurity-mosaic-sidepanel.js.map +1 -1
  258. package/fesm2015/ptsecurity-mosaic-splitter.js +204 -44
  259. package/fesm2015/ptsecurity-mosaic-splitter.js.map +1 -1
  260. package/fesm2015/ptsecurity-mosaic-table.js +7 -7
  261. package/fesm2015/ptsecurity-mosaic-table.js.map +1 -1
  262. package/fesm2015/ptsecurity-mosaic-tabs.js +52 -52
  263. package/fesm2015/ptsecurity-mosaic-tabs.js.map +1 -1
  264. package/fesm2015/ptsecurity-mosaic-tags.js +70 -66
  265. package/fesm2015/ptsecurity-mosaic-tags.js.map +1 -1
  266. package/fesm2015/ptsecurity-mosaic-textarea.js +7 -7
  267. package/fesm2015/ptsecurity-mosaic-textarea.js.map +1 -1
  268. package/fesm2015/ptsecurity-mosaic-timepicker.js +11 -10
  269. package/fesm2015/ptsecurity-mosaic-timepicker.js.map +1 -1
  270. package/fesm2015/ptsecurity-mosaic-toggle.js +7 -7
  271. package/fesm2015/ptsecurity-mosaic-toggle.js.map +1 -1
  272. package/fesm2015/ptsecurity-mosaic-tooltip.js +57 -18
  273. package/fesm2015/ptsecurity-mosaic-tooltip.js.map +1 -1
  274. package/fesm2015/ptsecurity-mosaic-tree-select.js +12 -11
  275. package/fesm2015/ptsecurity-mosaic-tree-select.js.map +1 -1
  276. package/fesm2015/ptsecurity-mosaic-tree.js +40 -46
  277. package/fesm2015/ptsecurity-mosaic-tree.js.map +1 -1
  278. package/form-field/cleaner.d.ts +2 -0
  279. package/input/input-number-validators.d.ts +2 -2
  280. package/modal/modal.component.d.ts +2 -0
  281. package/modal/modal.module.d.ts +1 -1
  282. package/package.json +5 -5
  283. package/popover/popover-confirm.component.d.ts +33 -0
  284. package/popover/popover.component.d.ts +14 -4
  285. package/popover/popover.module.d.ts +6 -3
  286. package/popover/public-api.d.ts +1 -0
  287. package/prebuilt-themes/dark-theme.css +1 -1
  288. package/prebuilt-themes/default-theme.css +1 -1
  289. package/prebuilt-visual/default-visual.css +1 -1
  290. package/select/select.component.d.ts +2 -7
  291. package/sidepanel/sidepanel-directives.d.ts +2 -0
  292. package/sidepanel/sidepanel.module.d.ts +2 -1
  293. package/splitter/splitter.component.d.ts +46 -5
  294. package/splitter/splitter.module.d.ts +1 -1
  295. package/tags/tag.component.d.ts +20 -20
  296. package/tooltip/tooltip.component.d.ts +12 -3
  297. package/tree/padding.directive.d.ts +1 -1
  298. package/tree/toggle.d.ts +1 -1
  299. package/tree/tree-option.component.d.ts +1 -1
  300. package/tree/tree-selection.component.d.ts +2 -2
  301. package/tree/tree.module.d.ts +1 -1
  302. package/tree-select/tree-select.component.d.ts +2 -7
@@ -1,5 +1,5 @@
1
1
  import { coerceBooleanProperty, coerceCssPixelValue, coerceNumberProperty } from '@angular/cdk/coercion';
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, Input, NgZone, QueryList, Renderer2, ViewChildren, ViewEncapsulation } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, EventEmitter, Input, NgZone, Output, QueryList, Renderer2, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
5
  export var Direction;
@@ -34,32 +34,38 @@ export class McGutterDirective {
34
34
  set size(size) {
35
35
  this._size = coerceNumberProperty(size);
36
36
  }
37
+ get isVertical() {
38
+ return this._direction === Direction.Vertical;
39
+ }
37
40
  ngOnInit() {
38
41
  this.setStyle("flex-basis" /* FlexBasis */, coerceCssPixelValue(this.size));
39
- this.setStyle(this.isVertical() ? "height" /* Height */ : "width" /* Width */, coerceCssPixelValue(this.size));
42
+ this.setStyle(this.isVertical ? "height" /* Height */ : "width" /* Width */, coerceCssPixelValue(this.size));
40
43
  this.setStyle("order" /* Order */, this.order);
41
- if (!this.isVertical()) {
44
+ if (!this.isVertical) {
42
45
  this.setStyle("height" /* Height */, '100%');
43
46
  }
44
47
  // fix IE issue with gutter icon. flex-direction is requied for flex alignment options
45
- this.setStyle("flex-direction" /* FlexDirection */, this.isVertical() ? 'row' : 'column');
48
+ this.setStyle("flex-direction" /* FlexDirection */, this.isVertical ? 'row' : 'column');
46
49
  }
47
- isVertical() {
48
- return this.direction === Direction.Vertical;
50
+ getPosition() {
51
+ return {
52
+ x: this.elementRef.nativeElement.offsetLeft,
53
+ y: this.elementRef.nativeElement.offsetTop
54
+ };
49
55
  }
50
56
  setStyle(property, value) {
51
57
  this.renderer.setStyle(this.elementRef.nativeElement, property, value);
52
58
  }
53
59
  }
54
- /** @nocollapse */ McGutterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McGutterDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
55
- /** @nocollapse */ McGutterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: McGutterDirective, selector: "mc-gutter", inputs: { direction: "direction", order: "order", size: "size" }, host: { listeners: { "mousedown": "dragged = true" }, properties: { "class.mc-gutter_vertical": "isVertical()", "class.mc-gutter_dragged": "dragged" }, classAttribute: "mc-gutter" }, ngImport: i0 });
56
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McGutterDirective, decorators: [{
60
+ /** @nocollapse */ McGutterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McGutterDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
61
+ /** @nocollapse */ McGutterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.13", type: McGutterDirective, selector: "mc-gutter", inputs: { direction: "direction", order: "order", size: "size" }, host: { listeners: { "mousedown": "dragged = true" }, properties: { "class.mc-gutter_vertical": "isVertical", "class.mc-gutter_dragged": "dragged" }, classAttribute: "mc-gutter" }, ngImport: i0 });
62
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McGutterDirective, decorators: [{
57
63
  type: Directive,
58
64
  args: [{
59
65
  selector: 'mc-gutter',
60
66
  host: {
61
67
  class: 'mc-gutter',
62
- '[class.mc-gutter_vertical]': 'isVertical()',
68
+ '[class.mc-gutter_vertical]': 'isVertical',
63
69
  '[class.mc-gutter_dragged]': 'dragged',
64
70
  '(mousedown)': 'dragged = true'
65
71
  }
@@ -71,19 +77,96 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
71
77
  }], size: [{
72
78
  type: Input
73
79
  }] } });
80
+ export class McGutterGhostDirective {
81
+ constructor(elementRef, renderer) {
82
+ this.elementRef = elementRef;
83
+ this.renderer = renderer;
84
+ this._x = 0;
85
+ this._y = 0;
86
+ this._direction = Direction.Vertical;
87
+ this._size = 6;
88
+ }
89
+ get x() {
90
+ return this._x;
91
+ }
92
+ set x(x) {
93
+ this._x = x;
94
+ this.setStyle("left" /* Left */, coerceCssPixelValue(x));
95
+ }
96
+ get y() {
97
+ return this._y;
98
+ }
99
+ set y(y) {
100
+ this._y = y;
101
+ this.setStyle("top" /* Top */, coerceCssPixelValue(y));
102
+ }
103
+ get direction() {
104
+ return this._direction;
105
+ }
106
+ set direction(direction) {
107
+ this._direction = direction;
108
+ this.updateDimensions();
109
+ }
110
+ get size() {
111
+ return this._size;
112
+ }
113
+ set size(size) {
114
+ this._size = coerceNumberProperty(size);
115
+ this.updateDimensions();
116
+ }
117
+ get isVertical() {
118
+ return this.direction === Direction.Vertical;
119
+ }
120
+ updateDimensions() {
121
+ this.setStyle(this.isVertical ? "width" /* Width */ : "height" /* Height */, '100%');
122
+ this.setStyle(this.isVertical ? "height" /* Height */ : "width" /* Width */, coerceCssPixelValue(this.size));
123
+ }
124
+ setStyle(property, value) {
125
+ this.renderer.setStyle(this.elementRef.nativeElement, property, value);
126
+ }
127
+ }
128
+ /** @nocollapse */ McGutterGhostDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McGutterGhostDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
129
+ /** @nocollapse */ McGutterGhostDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.13", type: McGutterGhostDirective, selector: "mc-gutter-ghost", inputs: { visible: "visible", x: "x", y: "y", direction: "direction", size: "size" }, host: { properties: { "class.mc-gutter-ghost_vertical": "isVertical", "class.mc-gutter-ghost_visible": "visible" }, classAttribute: "mc-gutter-ghost" }, ngImport: i0 });
130
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McGutterGhostDirective, decorators: [{
131
+ type: Directive,
132
+ args: [{
133
+ selector: 'mc-gutter-ghost',
134
+ host: {
135
+ class: 'mc-gutter-ghost',
136
+ '[class.mc-gutter-ghost_vertical]': 'isVertical',
137
+ '[class.mc-gutter-ghost_visible]': 'visible'
138
+ }
139
+ }]
140
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { visible: [{
141
+ type: Input
142
+ }], x: [{
143
+ type: Input
144
+ }], y: [{
145
+ type: Input
146
+ }], direction: [{
147
+ type: Input
148
+ }], size: [{
149
+ type: Input
150
+ }] } });
74
151
  export class McSplitterComponent {
75
152
  constructor(elementRef, changeDetectorRef, ngZone, renderer) {
76
153
  this.elementRef = elementRef;
77
154
  this.changeDetectorRef = changeDetectorRef;
78
155
  this.ngZone = ngZone;
79
156
  this.renderer = renderer;
157
+ this.gutterPositionChange = new EventEmitter();
80
158
  this.areas = [];
81
- this.isDragging = false;
159
+ this._isDragging = false;
82
160
  this.areaPositionDivider = 2;
83
161
  this.listeners = [];
84
162
  this._hideGutters = false;
85
163
  this._disabled = false;
164
+ this._useGhost = false;
86
165
  this._gutterSize = 6;
166
+ this._resizing = false;
167
+ }
168
+ get isDragging() {
169
+ return this._isDragging;
87
170
  }
88
171
  get hideGutters() {
89
172
  return this._hideGutters;
@@ -103,6 +186,12 @@ export class McSplitterComponent {
103
186
  set disabled(disabled) {
104
187
  this._disabled = coerceBooleanProperty(disabled);
105
188
  }
189
+ get useGhost() {
190
+ return this._useGhost;
191
+ }
192
+ set useGhost(useGhost) {
193
+ this._useGhost = coerceBooleanProperty(useGhost);
194
+ }
106
195
  get gutterSize() {
107
196
  return this._gutterSize;
108
197
  }
@@ -110,6 +199,9 @@ export class McSplitterComponent {
110
199
  const size = coerceNumberProperty(gutterSize);
111
200
  this._gutterSize = size > 0 ? size : this.gutterSize;
112
201
  }
202
+ get resizing() {
203
+ return this._resizing;
204
+ }
113
205
  addArea(area) {
114
206
  const index = this.areas.length;
115
207
  const order = index * this.areaPositionDivider;
@@ -133,26 +225,41 @@ export class McSplitterComponent {
133
225
  return;
134
226
  }
135
227
  event.preventDefault();
136
- const leftArea = this.areas[leftAreaIndex];
137
- const rightArea = this.areas[rightAreaIndex];
138
228
  const startPoint = {
139
229
  x: event.screenX,
140
230
  y: event.screenY
141
231
  };
232
+ const leftArea = this.areas[leftAreaIndex];
233
+ const rightArea = this.areas[rightAreaIndex];
142
234
  leftArea.initialSize = leftArea.area.getSize();
143
235
  rightArea.initialSize = rightArea.area.getSize();
144
- this.areas.forEach((item) => {
145
- const size = item.area.getSize();
146
- item.area.disableFlex();
147
- item.area.setSize(size);
148
- });
149
- this.ngZone.runOutsideAngular(() => {
150
- this.listeners.push(this.renderer.listen('document', 'mouseup', () => this.onMouseUp()));
151
- });
236
+ let currentGutter;
237
+ if (this.useGhost) {
238
+ // tslint:disable-next-line:no-magic-numbers
239
+ const gutterOrder = leftAreaIndex * 2 + 1;
240
+ currentGutter = this.gutters.find((gutter) => gutter.order === gutterOrder);
241
+ if (currentGutter) {
242
+ const gutterPosition = currentGutter.getPosition();
243
+ this.ghost.direction = currentGutter.direction;
244
+ this.ghost.size = currentGutter.size;
245
+ this.ghost.x = gutterPosition.x;
246
+ this.ghost.y = gutterPosition.y;
247
+ this.ghost.visible = true;
248
+ this.setStyle("cursor" /* Cursor */, currentGutter.direction === Direction.Vertical ? 'row-resize' : 'col-resize');
249
+ }
250
+ }
251
+ else {
252
+ this.areas.forEach((item) => {
253
+ const size = item.area.getSize();
254
+ item.area.disableFlex();
255
+ item.area.setSize(size);
256
+ });
257
+ }
258
+ this.listeners.push(this.renderer.listen('document', 'mouseup', () => this.onMouseUp(leftArea, rightArea, currentGutter)));
152
259
  this.ngZone.runOutsideAngular(() => {
153
- this.listeners.push(this.renderer.listen('document', 'mousemove', (e) => this.onMouseMove(e, startPoint, leftArea, rightArea)));
260
+ this.listeners.push(this.renderer.listen('document', 'mousemove', (e) => this.onMouseMove(e, startPoint, leftArea, rightArea, currentGutter)));
154
261
  });
155
- this.isDragging = true;
262
+ this._isDragging = true;
156
263
  }
157
264
  removeArea(area) {
158
265
  let indexToRemove = -1;
@@ -179,7 +286,7 @@ export class McSplitterComponent {
179
286
  }
180
287
  });
181
288
  }
182
- onMouseMove(event, startPoint, leftArea, rightArea) {
289
+ onMouseMove(event, startPoint, leftArea, rightArea, currentGutter) {
183
290
  if (!this.isDragging || this.disabled) {
184
291
  return;
185
292
  }
@@ -190,11 +297,28 @@ export class McSplitterComponent {
190
297
  const offset = this.isVertical()
191
298
  ? startPoint.y - endPoint.y
192
299
  : startPoint.x - endPoint.x;
193
- const newLeftAreaSize = leftArea.initialSize - offset;
194
- const newRightAreaSize = rightArea.initialSize + offset;
300
+ if (this.useGhost && currentGutter) {
301
+ const gutterPosition = currentGutter.getPosition();
302
+ const leftPos = leftArea.area.getPosition();
303
+ const rightPos = rightArea.area.getPosition();
304
+ const rightMin = rightArea.area.getMinSize() || 0;
305
+ const leftMin = leftArea.area.getMinSize() || 0;
306
+ const key = this.isVertical() ? 'y' : 'x';
307
+ const minPos = leftPos[key] - leftMin;
308
+ const maxPos = rightPos[key] + (rightArea.area.getSize() || 0) - rightMin - currentGutter.size;
309
+ const newPos = gutterPosition[key] - offset;
310
+ this.ghost[key] = newPos < minPos ? minPos : Math.min(newPos, maxPos);
311
+ }
312
+ else {
313
+ this.resizeAreas(leftArea, rightArea, offset);
314
+ }
315
+ }
316
+ resizeAreas(leftArea, rightArea, sizeOffset) {
317
+ const newLeftAreaSize = leftArea.initialSize - sizeOffset;
318
+ const newRightAreaSize = rightArea.initialSize + sizeOffset;
195
319
  const minLeftAreaSize = leftArea.area.getMinSize();
196
320
  const minRightAreaSize = rightArea.area.getMinSize();
197
- if (newLeftAreaSize <= minLeftAreaSize || newRightAreaSize <= minRightAreaSize) {
321
+ if (newLeftAreaSize < minLeftAreaSize || newRightAreaSize < minRightAreaSize) {
198
322
  return;
199
323
  }
200
324
  else if (newLeftAreaSize <= 0) {
@@ -210,23 +334,33 @@ export class McSplitterComponent {
210
334
  rightArea.area.setSize(newRightAreaSize);
211
335
  }
212
336
  }
213
- onMouseUp() {
337
+ onMouseUp(leftArea, rightArea, currentGutter) {
214
338
  while (this.listeners.length > 0) {
215
339
  const unsubscribe = this.listeners.pop();
216
340
  if (unsubscribe) {
217
341
  unsubscribe();
218
342
  }
219
343
  }
220
- this.isDragging = false;
344
+ if (this.useGhost && currentGutter) {
345
+ const gutterPosition = currentGutter.getPosition();
346
+ const offset = this.ghost.direction === Direction.Vertical ?
347
+ gutterPosition.y - this.ghost.y :
348
+ gutterPosition.x - this.ghost.x;
349
+ this.resizeAreas(leftArea, rightArea, offset);
350
+ this.ghost.visible = false;
351
+ this.setStyle("cursor" /* Cursor */, 'unset');
352
+ }
353
+ this._isDragging = false;
221
354
  this.updateGutter();
355
+ this.gutterPositionChange.emit();
222
356
  }
223
357
  setStyle(property, value) {
224
358
  this.renderer.setStyle(this.elementRef.nativeElement, property, value);
225
359
  }
226
360
  }
227
- /** @nocollapse */ McSplitterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
228
- /** @nocollapse */ McSplitterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: McSplitterComponent, selector: "mc-splitter", inputs: { hideGutters: "hideGutters", direction: "direction", disabled: "disabled", gutterSize: "gutterSize" }, host: { classAttribute: "mc-splitter" }, viewQueries: [{ propertyName: "gutters", predicate: McGutterDirective, descendants: true }], exportAs: ["mcSplitter"], ngImport: i0, template: "<ng-content></ng-content>\n\n<ng-template ngFor let-area [ngForOf]=\"areas\" let-index=\"index\" let-last=\"last\">\n <mc-gutter *ngIf=\"last === false\"\n [direction]=\"direction\"\n [attr.disabled]=\"disabled || null\"\n [style.display]=\"hideGutters ? 'none' : 'flex'\"\n [size]=\"gutterSize\"\n [order]=\"index * 2 + 1\"\n (mousedown)=\"onMouseDown($event, index, index + 1)\">\n </mc-gutter>\n</ng-template>\n", styles: [".mc-splitter{display:flex;flex-wrap:nowrap;align-items:stretch;overflow:hidden}.mc-splitter .mc-splitter-area{overflow:hidden}.mc-gutter{display:flex;flex-grow:0;flex-shrink:0;justify-content:center;align-items:center;overflow:hidden}.mc-gutter.mc-gutter_vertical>.mc-icon{transform:rotate(90deg)}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: McGutterDirective, selector: "mc-gutter", inputs: ["direction", "order", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
229
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterComponent, decorators: [{
361
+ /** @nocollapse */ McSplitterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
362
+ /** @nocollapse */ McSplitterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: McSplitterComponent, selector: "mc-splitter", inputs: { hideGutters: "hideGutters", direction: "direction", disabled: "disabled", useGhost: "useGhost", gutterSize: "gutterSize" }, outputs: { gutterPositionChange: "gutterPositionChange" }, host: { classAttribute: "mc-splitter" }, viewQueries: [{ propertyName: "ghost", first: true, predicate: McGutterGhostDirective, descendants: true }, { propertyName: "gutters", predicate: McGutterDirective, descendants: true }], exportAs: ["mcSplitter"], ngImport: i0, template: "<ng-content></ng-content>\n\n<ng-template ngFor let-area [ngForOf]=\"areas\" let-index=\"index\" let-last=\"last\">\n <mc-gutter *ngIf=\"last === false\"\n [direction]=\"direction\"\n [attr.disabled]=\"disabled || null\"\n [style.display]=\"hideGutters ? 'none' : 'flex'\"\n [size]=\"gutterSize\"\n [order]=\"index * 2 + 1\"\n (mousedown)=\"onMouseDown($event, index, index + 1)\">\n </mc-gutter>\n</ng-template>\n\n<mc-gutter-ghost *ngIf=\"useGhost\"></mc-gutter-ghost>\n", styles: [".mc-splitter{display:flex;position:relative;flex-wrap:nowrap;align-items:stretch;overflow:hidden}.mc-splitter .mc-splitter-area{overflow:hidden}.mc-splitter .mc-splitter-area_resizing{pointer-events:none}.mc-gutter{display:flex;flex-grow:0;flex-shrink:0;justify-content:center;align-items:center;overflow:hidden}.mc-gutter.mc-gutter_vertical>.mc-icon{transform:rotate(90deg)}.mc-gutter-ghost{position:absolute;z-index:999;display:none;overflow:hidden}.mc-gutter-ghost.mc-gutter-ghost_vertical>.mc-icon{transform:rotate(90deg)}.mc-gutter-ghost.mc-gutter-ghost_visible{display:block}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: McGutterDirective, selector: "mc-gutter", inputs: ["direction", "order", "size"] }, { type: McGutterGhostDirective, selector: "mc-gutter-ghost", inputs: ["visible", "x", "y", "direction", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
363
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterComponent, decorators: [{
230
364
  type: Component,
231
365
  args: [{
232
366
  selector: 'mc-splitter',
@@ -240,15 +374,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
240
374
  encapsulation: ViewEncapsulation.None,
241
375
  changeDetection: ChangeDetectionStrategy.OnPush
242
376
  }]
243
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i0.Renderer2 }]; }, propDecorators: { gutters: [{
377
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i0.Renderer2 }]; }, propDecorators: { gutterPositionChange: [{
378
+ type: Output
379
+ }], gutters: [{
244
380
  type: ViewChildren,
245
381
  args: [McGutterDirective]
382
+ }], ghost: [{
383
+ type: ViewChild,
384
+ args: [McGutterGhostDirective]
246
385
  }], hideGutters: [{
247
386
  type: Input
248
387
  }], direction: [{
249
388
  type: Input
250
389
  }], disabled: [{
251
390
  type: Input
391
+ }], useGhost: [{
392
+ type: Input
252
393
  }], gutterSize: [{
253
394
  type: Input
254
395
  }] } });
@@ -257,6 +398,10 @@ export class McSplitterAreaDirective {
257
398
  this.elementRef = elementRef;
258
399
  this.renderer = renderer;
259
400
  this.splitter = splitter;
401
+ this.sizeChange = new EventEmitter();
402
+ }
403
+ isResizing() {
404
+ return this.splitter.isDragging;
260
405
  }
261
406
  disableFlex() {
262
407
  this.renderer.removeStyle(this.elementRef.nativeElement, 'flex');
@@ -272,6 +417,7 @@ export class McSplitterAreaDirective {
272
417
  this.setStyle("height" /* Height */, '100%');
273
418
  this.removeStyle("width" /* Width */);
274
419
  }
420
+ this.splitter.gutterPositionChange.subscribe(() => this.emitSizeChange());
275
421
  }
276
422
  ngOnDestroy() {
277
423
  this.splitter.removeArea(this);
@@ -280,7 +426,7 @@ export class McSplitterAreaDirective {
280
426
  this.setStyle("order" /* Order */, order);
281
427
  }
282
428
  setSize(size) {
283
- if (size) {
429
+ if (!isNaN(size)) {
284
430
  const sz = coerceNumberProperty(size);
285
431
  this.setStyle(this.getSizeProperty(), coerceCssPixelValue(sz));
286
432
  }
@@ -288,6 +434,12 @@ export class McSplitterAreaDirective {
288
434
  getSize() {
289
435
  return this.elementRef.nativeElement[this.getOffsetSizeProperty()];
290
436
  }
437
+ getPosition() {
438
+ return {
439
+ x: this.elementRef.nativeElement.offsetLeft,
440
+ y: this.elementRef.nativeElement.offsetTop
441
+ };
442
+ }
291
443
  getMinSize() {
292
444
  const styles = getComputedStyle(this.elementRef.nativeElement);
293
445
  return parseFloat(styles[this.getMinSizeProperty()]);
@@ -316,16 +468,22 @@ export class McSplitterAreaDirective {
316
468
  removeStyle(style) {
317
469
  this.renderer.removeStyle(this.elementRef.nativeElement, style);
318
470
  }
471
+ emitSizeChange() {
472
+ this.sizeChange.emit(this.getSize());
473
+ }
319
474
  }
320
- /** @nocollapse */ McSplitterAreaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterAreaDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: McSplitterComponent }], target: i0.ɵɵFactoryTarget.Directive });
321
- /** @nocollapse */ McSplitterAreaDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: McSplitterAreaDirective, selector: "[mc-splitter-area]", host: { classAttribute: "mc-splitter-area" }, ngImport: i0 });
322
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterAreaDirective, decorators: [{
475
+ /** @nocollapse */ McSplitterAreaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterAreaDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: McSplitterComponent }], target: i0.ɵɵFactoryTarget.Directive });
476
+ /** @nocollapse */ McSplitterAreaDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.13", type: McSplitterAreaDirective, selector: "[mc-splitter-area]", outputs: { sizeChange: "sizeChange" }, host: { properties: { "class.mc-splitter-area_resizing": "isResizing()" }, classAttribute: "mc-splitter-area" }, ngImport: i0 });
477
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterAreaDirective, decorators: [{
323
478
  type: Directive,
324
479
  args: [{
325
480
  selector: '[mc-splitter-area]',
326
481
  host: {
327
- class: 'mc-splitter-area'
482
+ class: 'mc-splitter-area',
483
+ '[class.mc-splitter-area_resizing]': 'isResizing()'
328
484
  }
329
485
  }]
330
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: McSplitterComponent }]; } });
331
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/splitter/splitter.component.ts","../../../../packages/mosaic/splitter/splitter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty, coerceCssPixelValue, coerceNumberProperty } from '@angular/cdk/coercion';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Directive,\n    ElementRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    Renderer2,\n    ViewChildren,\n    ViewEncapsulation\n} from '@angular/core';\n\n\ninterface IArea {\n    area: McSplitterAreaDirective;\n    index: number;\n    order: number;\n    initialSize: number;\n}\n\ninterface IPoint {\n    x: number;\n    y: number;\n}\n\nconst enum StyleProperty {\n    Flex = 'flex',\n    FlexBasis = 'flex-basis',\n    FlexDirection = 'flex-direction',\n    Height = 'height',\n    MaxWidth = 'max-width',\n    MinHeight = 'min-height',\n    MinWidth = 'minWidth',\n    OffsetHeight = 'offsetHeight',\n    OffsetWidth = 'offsetWidth',\n    Order = 'order',\n    Width = 'width'\n}\n\nexport enum Direction {\n    Horizontal = 'horizontal',\n    Vertical = 'vertical'\n}\n\n\n@Directive({\n    selector: 'mc-gutter',\n    host: {\n        class: 'mc-gutter',\n        '[class.mc-gutter_vertical]': 'isVertical()',\n        '[class.mc-gutter_dragged]': 'dragged',\n        '(mousedown)': 'dragged = true'\n    }\n})\nexport class McGutterDirective implements OnInit {\n    get direction(): Direction {\n        return this._direction;\n    }\n\n    @Input()\n    set direction(direction: Direction) {\n        this._direction = direction;\n    }\n\n    private _direction: Direction = Direction.Vertical;\n\n    get order(): number {\n        return this._order;\n    }\n\n    @Input()\n    set order(order: number) {\n        this._order = coerceNumberProperty(order);\n    }\n\n    private _order: number = 0;\n\n    get size(): number {\n        return this._size;\n    }\n\n    @Input()\n    set size(size: number) {\n        this._size = coerceNumberProperty(size);\n    }\n\n    private _size: number = 6;\n\n    dragged: boolean = false;\n\n    constructor(\n        private elementRef: ElementRef,\n        private renderer: Renderer2\n    ) {}\n\n    ngOnInit(): void {\n        this.setStyle(StyleProperty.FlexBasis, coerceCssPixelValue(this.size));\n        this.setStyle(this.isVertical() ? StyleProperty.Height : StyleProperty.Width, coerceCssPixelValue(this.size));\n        this.setStyle(StyleProperty.Order, this.order);\n\n        if (!this.isVertical()) {\n            this.setStyle(StyleProperty.Height, '100%');\n        }\n\n        // fix IE issue with gutter icon. flex-direction is requied for flex alignment options\n        this.setStyle(StyleProperty.FlexDirection, this.isVertical() ? 'row' : 'column');\n    }\n\n    isVertical(): boolean {\n        return this.direction === Direction.Vertical;\n    }\n\n    private setStyle(property: StyleProperty, value: string | number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, property, value);\n    }\n}\n\n\n@Component({\n    selector: 'mc-splitter',\n    exportAs: 'mcSplitter',\n    host: {\n        class: 'mc-splitter'\n    },\n    preserveWhitespaces: false,\n    styleUrls: ['splitter.scss'],\n    templateUrl: './splitter.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class McSplitterComponent implements OnInit {\n    readonly areas: IArea[] = [];\n\n    @ViewChildren(McGutterDirective) gutters: QueryList<McGutterDirective>;\n\n    private isDragging: boolean = false;\n\n    private readonly areaPositionDivider: number = 2;\n    private readonly listeners: (() => void)[] = [];\n\n    get hideGutters(): boolean {\n        return this._hideGutters;\n    }\n\n    @Input()\n    set hideGutters(value: boolean) {\n        this._hideGutters = coerceBooleanProperty(value);\n    }\n\n    private _hideGutters: boolean = false;\n\n    get direction(): Direction {\n        return this._direction;\n    }\n\n    @Input()\n    set direction(direction: Direction) {\n        this._direction = direction;\n    }\n\n    private _direction: Direction;\n\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    @Input()\n    set disabled(disabled: boolean) {\n        this._disabled = coerceBooleanProperty(disabled);\n    }\n\n    private _disabled: boolean = false;\n\n    get gutterSize(): number {\n        return this._gutterSize;\n    }\n\n    @Input()\n    set gutterSize(gutterSize: number) {\n        const size = coerceNumberProperty(gutterSize);\n        this._gutterSize = size > 0 ? size : this.gutterSize;\n    }\n\n    private _gutterSize: number = 6;\n\n    constructor(\n        public elementRef: ElementRef,\n        public changeDetectorRef: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private renderer: Renderer2\n    ) {}\n\n    addArea(area: McSplitterAreaDirective): void {\n        const index: number = this.areas.length;\n        const order: number = index * this.areaPositionDivider;\n        const size: number = area.getSize();\n\n        area.setOrder(order);\n\n        this.areas.push({\n            area,\n            index,\n            order,\n            initialSize: size\n        });\n    }\n\n    ngOnInit(): void {\n        if (!this.direction) {\n            this.direction = Direction.Horizontal;\n        }\n\n        this.setStyle(StyleProperty.FlexDirection, this.isVertical() ? 'column' : 'row');\n    }\n\n    onMouseDown(event: MouseEvent, leftAreaIndex: number, rightAreaIndex: number) {\n        if (this.disabled) { return; }\n\n        event.preventDefault();\n\n        const leftArea = this.areas[leftAreaIndex];\n        const rightArea = this.areas[rightAreaIndex];\n\n        const startPoint: IPoint = {\n            x: event.screenX,\n            y: event.screenY\n        };\n\n        leftArea.initialSize = leftArea.area.getSize();\n        rightArea.initialSize = rightArea.area.getSize();\n\n        this.areas.forEach((item) => {\n            const size = item.area.getSize();\n            item.area.disableFlex();\n            item.area.setSize(size);\n        });\n\n        this.ngZone.runOutsideAngular(() => {\n            this.listeners.push(\n                this.renderer.listen(\n                    'document',\n                    'mouseup',\n                    () => this.onMouseUp()\n                )\n            );\n        });\n\n        this.ngZone.runOutsideAngular(() => {\n            this.listeners.push(\n                this.renderer.listen(\n                    'document',\n                    'mousemove',\n                    (e: MouseEvent) => this.onMouseMove(e, startPoint, leftArea, rightArea)\n                )\n            );\n        });\n\n        this.isDragging = true;\n    }\n\n    removeArea(area: McSplitterAreaDirective): void {\n        let indexToRemove: number = -1;\n\n        this.areas.some((item, index) => {\n            if (item.area === area) {\n                indexToRemove = index;\n\n                return true;\n            }\n\n            return false;\n        });\n\n        if (indexToRemove === -1) {\n            return;\n        }\n\n        this.areas.splice(indexToRemove, 1);\n    }\n\n    isVertical(): boolean {\n        return this.direction === Direction.Vertical;\n    }\n\n    private updateGutter(): void {\n        this.gutters.forEach((gutter) => {\n            if (gutter.dragged) {\n                gutter.dragged = false;\n\n                this.changeDetectorRef.detectChanges();\n            }\n        });\n\n    }\n\n    private onMouseMove(event: MouseEvent, startPoint: IPoint, leftArea: IArea, rightArea: IArea) {\n        if (!this.isDragging || this.disabled) { return; }\n\n        const endPoint: IPoint = {\n            x: event.screenX,\n            y: event.screenY\n        };\n\n        const offset = this.isVertical()\n            ? startPoint.y - endPoint.y\n            : startPoint.x - endPoint.x;\n\n        const newLeftAreaSize = leftArea.initialSize - offset;\n        const newRightAreaSize = rightArea.initialSize + offset;\n\n        const minLeftAreaSize = leftArea.area.getMinSize();\n        const minRightAreaSize = rightArea.area.getMinSize();\n\n        if (newLeftAreaSize <= minLeftAreaSize || newRightAreaSize <= minRightAreaSize) {\n            return;\n        } else if (newLeftAreaSize <= 0) {\n            leftArea.area.setSize(0);\n            rightArea.area.setSize(rightArea.initialSize + leftArea.initialSize);\n        } else if (newRightAreaSize <= 0) {\n            leftArea.area.setSize(rightArea.initialSize + leftArea.initialSize);\n            rightArea.area.setSize(0);\n        } else {\n            leftArea.area.setSize(newLeftAreaSize);\n            rightArea.area.setSize(newRightAreaSize);\n        }\n    }\n\n    private onMouseUp() {\n        while (this.listeners.length > 0) {\n            const unsubscribe = this.listeners.pop();\n\n            if (unsubscribe) {\n                unsubscribe();\n            }\n        }\n\n        this.isDragging = false;\n\n        this.updateGutter();\n    }\n\n    private setStyle(property: StyleProperty, value: string | number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, property, value);\n    }\n}\n\n@Directive({\n    selector: '[mc-splitter-area]',\n    host: {\n        class: 'mc-splitter-area'\n    }\n})\nexport class McSplitterAreaDirective implements OnInit, OnDestroy {\n    constructor(\n        private elementRef: ElementRef,\n        private renderer: Renderer2,\n        private splitter: McSplitterComponent\n    ) {}\n\n    disableFlex(): void {\n        this.renderer.removeStyle(this.elementRef.nativeElement, 'flex');\n    }\n\n    ngOnInit(): void {\n        this.splitter.addArea(this);\n\n        this.removeStyle(StyleProperty.MaxWidth);\n\n        if (this.splitter.direction === Direction.Vertical) {\n            this.setStyle(StyleProperty.Width, '100%');\n            this.removeStyle(StyleProperty.Height);\n        } else {\n            this.setStyle(StyleProperty.Height, '100%');\n            this.removeStyle(StyleProperty.Width);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.splitter.removeArea(this);\n    }\n\n    setOrder(order: number): void {\n        this.setStyle(StyleProperty.Order, order);\n    }\n\n    setSize(size: number): void {\n        if (size) {\n            const sz = coerceNumberProperty(size);\n            this.setStyle(this.getSizeProperty(), coerceCssPixelValue(sz));\n        }\n    }\n\n    getSize(): number {\n        return this.elementRef.nativeElement[this.getOffsetSizeProperty()];\n    }\n\n    getMinSize(): number {\n        const styles = getComputedStyle(this.elementRef.nativeElement);\n\n        return parseFloat(styles[this.getMinSizeProperty()]);\n    }\n\n    private isVertical(): boolean {\n        return this.splitter.direction === Direction.Vertical;\n    }\n\n    private getMinSizeProperty(): StyleProperty {\n        return this.isVertical()\n            ? StyleProperty.MinHeight\n            : StyleProperty.MinWidth;\n    }\n\n    private getOffsetSizeProperty(): StyleProperty {\n        return this.isVertical()\n            ? StyleProperty.OffsetHeight\n            : StyleProperty.OffsetWidth;\n    }\n\n    private getSizeProperty(): StyleProperty {\n        return this.isVertical()\n            ? StyleProperty.Height\n            : StyleProperty.Width;\n    }\n\n    private setStyle(style: StyleProperty, value: string | number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, style, value);\n    }\n\n    private removeStyle(style: StyleProperty) {\n        this.renderer.removeStyle(this.elementRef.nativeElement, style);\n    }\n}\n","<ng-content></ng-content>\n\n<ng-template ngFor let-area [ngForOf]=\"areas\" let-index=\"index\" let-last=\"last\">\n    <mc-gutter *ngIf=\"last === false\"\n               [direction]=\"direction\"\n               [attr.disabled]=\"disabled || null\"\n               [style.display]=\"hideGutters ? 'none' : 'flex'\"\n               [size]=\"gutterSize\"\n               [order]=\"index * 2 + 1\"\n               (mousedown)=\"onMouseDown($event, index, index + 1)\">\n    </mc-gutter>\n</ng-template>\n"]}
486
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: McSplitterComponent }]; }, propDecorators: { sizeChange: [{
487
+ type: Output
488
+ }] } });
489
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splitter.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/splitter/splitter.component.ts","../../../../packages/mosaic/splitter/splitter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty, coerceCssPixelValue, coerceNumberProperty } from '@angular/cdk/coercion';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    Renderer2,\n    ViewChild,\n    ViewChildren,\n    ViewEncapsulation\n} from '@angular/core';\n\n\ninterface IArea {\n    area: McSplitterAreaDirective;\n    index: number;\n    order: number;\n    initialSize: number;\n}\n\ninterface IPoint {\n    x: number;\n    y: number;\n}\n\nconst enum StyleProperty {\n    Flex = 'flex',\n    FlexBasis = 'flex-basis',\n    FlexDirection = 'flex-direction',\n    Height = 'height',\n    MaxWidth = 'max-width',\n    MinHeight = 'min-height',\n    MinWidth = 'minWidth',\n    OffsetHeight = 'offsetHeight',\n    OffsetWidth = 'offsetWidth',\n    Order = 'order',\n    Width = 'width',\n    Top = 'top',\n    Left = 'left',\n    Cursor = 'cursor'\n}\n\nexport enum Direction {\n    Horizontal = 'horizontal',\n    Vertical = 'vertical'\n}\n\n@Directive({\n    selector: 'mc-gutter',\n    host: {\n        class: 'mc-gutter',\n        '[class.mc-gutter_vertical]': 'isVertical',\n        '[class.mc-gutter_dragged]': 'dragged',\n        '(mousedown)': 'dragged = true'\n    }\n})\nexport class McGutterDirective implements OnInit {\n    get direction(): Direction {\n        return this._direction;\n    }\n\n    @Input()\n    set direction(direction: Direction) {\n        this._direction = direction;\n    }\n\n    private _direction: Direction = Direction.Vertical;\n\n    get order(): number {\n        return this._order;\n    }\n\n    @Input()\n    set order(order: number) {\n        this._order = coerceNumberProperty(order);\n    }\n\n    private _order: number = 0;\n\n    get size(): number {\n        return this._size;\n    }\n\n    @Input()\n    set size(size: number) {\n        this._size = coerceNumberProperty(size);\n    }\n\n    private _size: number = 6;\n\n    get isVertical(): boolean {\n        return this._direction === Direction.Vertical;\n    }\n\n    dragged: boolean = false;\n\n    constructor(\n        private elementRef: ElementRef,\n        private renderer: Renderer2\n    ) {}\n\n    ngOnInit(): void {\n        this.setStyle(StyleProperty.FlexBasis, coerceCssPixelValue(this.size));\n        this.setStyle(this.isVertical ? StyleProperty.Height : StyleProperty.Width, coerceCssPixelValue(this.size));\n        this.setStyle(StyleProperty.Order, this.order);\n\n        if (!this.isVertical) {\n            this.setStyle(StyleProperty.Height, '100%');\n        }\n\n        // fix IE issue with gutter icon. flex-direction is requied for flex alignment options\n        this.setStyle(StyleProperty.FlexDirection, this.isVertical ? 'row' : 'column');\n    }\n\n    getPosition(): IPoint {\n        return {\n            x: this.elementRef.nativeElement.offsetLeft,\n            y: this.elementRef.nativeElement.offsetTop\n        };\n    }\n\n    private setStyle(property: StyleProperty, value: string | number): void {\n        this.renderer.setStyle(this.elementRef.nativeElement, property, value);\n    }\n}\n\n@Directive({\n    selector: 'mc-gutter-ghost',\n    host: {\n        class: 'mc-gutter-ghost',\n        '[class.mc-gutter-ghost_vertical]': 'isVertical',\n        '[class.mc-gutter-ghost_visible]': 'visible'\n    }\n})\nexport class McGutterGhostDirective {\n    @Input() visible: boolean;\n\n    get x(): number {\n        return this._x;\n    }\n\n    @Input()\n    set x(x: number) {\n        this._x = x;\n        this.setStyle(StyleProperty.Left, coerceCssPixelValue(x));\n    }\n\n    private _x: number = 0;\n\n    get y(): number {\n        return this._y;\n    }\n\n    @Input()\n    set y(y: number) {\n        this._y = y;\n        this.setStyle(StyleProperty.Top, coerceCssPixelValue(y));\n    }\n\n    private _y: number = 0;\n\n\n    get direction(): Direction {\n        return this._direction;\n    }\n\n    @Input()\n    set direction(direction: Direction) {\n        this._direction = direction;\n        this.updateDimensions();\n    }\n\n    private _direction: Direction = Direction.Vertical;\n\n    get size(): number {\n        return this._size;\n    }\n\n    @Input()\n    set size(size: number) {\n        this._size = coerceNumberProperty(size);\n        this.updateDimensions();\n    }\n\n    private _size: number = 6;\n\n    get isVertical(): boolean {\n        return this.direction === Direction.Vertical;\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        private renderer: Renderer2\n    ) {}\n\n    private updateDimensions(): void {\n        this.setStyle(this.isVertical ? StyleProperty.Width : StyleProperty.Height, '100%');\n        this.setStyle(this.isVertical ? StyleProperty.Height : StyleProperty.Width, coerceCssPixelValue(this.size));\n    }\n\n    private setStyle(property: StyleProperty, value: string | number): void {\n        this.renderer.setStyle(this.elementRef.nativeElement, property, value);\n    }\n}\n\n\n@Component({\n    selector: 'mc-splitter',\n    exportAs: 'mcSplitter',\n    host: {\n        class: 'mc-splitter'\n    },\n    preserveWhitespaces: false,\n    styleUrls: ['splitter.scss'],\n    templateUrl: './splitter.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class McSplitterComponent implements OnInit {\n    @Output() gutterPositionChange: EventEmitter<void> = new EventEmitter<void>();\n\n    readonly areas: IArea[] = [];\n\n    @ViewChildren(McGutterDirective) gutters: QueryList<McGutterDirective>;\n    @ViewChild(McGutterGhostDirective) ghost: McGutterGhostDirective;\n\n    get isDragging(): boolean {\n        return this._isDragging;\n    }\n    private _isDragging: boolean = false;\n\n    private readonly areaPositionDivider: number = 2;\n    private readonly listeners: (() => void)[] = [];\n\n    get hideGutters(): boolean {\n        return this._hideGutters;\n    }\n\n    @Input()\n    set hideGutters(value: boolean) {\n        this._hideGutters = coerceBooleanProperty(value);\n    }\n\n    private _hideGutters: boolean = false;\n\n    get direction(): Direction {\n        return this._direction;\n    }\n\n    @Input()\n    set direction(direction: Direction) {\n        this._direction = direction;\n    }\n\n    private _direction: Direction;\n\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    @Input()\n    set disabled(disabled: boolean) {\n        this._disabled = coerceBooleanProperty(disabled);\n    }\n\n    private _disabled: boolean = false;\n\n    get useGhost(): boolean {\n        return this._useGhost;\n    }\n\n    @Input()\n    set useGhost(useGhost: boolean) {\n        this._useGhost = coerceBooleanProperty(useGhost);\n    }\n\n    private _useGhost: boolean = false;\n\n    get gutterSize(): number {\n        return this._gutterSize;\n    }\n\n    @Input()\n    set gutterSize(gutterSize: number) {\n        const size = coerceNumberProperty(gutterSize);\n        this._gutterSize = size > 0 ? size : this.gutterSize;\n    }\n\n    private _gutterSize: number = 6;\n\n    get resizing(): boolean {\n        return this._resizing;\n    }\n\n    private _resizing: boolean = false;\n\n    constructor(\n        public elementRef: ElementRef,\n        public changeDetectorRef: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private renderer: Renderer2\n    ) {}\n\n    addArea(area: McSplitterAreaDirective): void {\n        const index: number = this.areas.length;\n        const order: number = index * this.areaPositionDivider;\n        const size: number = area.getSize();\n\n        area.setOrder(order);\n\n        this.areas.push({\n            area,\n            index,\n            order,\n            initialSize: size\n        });\n    }\n\n    ngOnInit(): void {\n        if (!this.direction) {\n            this.direction = Direction.Horizontal;\n        }\n\n        this.setStyle(StyleProperty.FlexDirection, this.isVertical() ? 'column' : 'row');\n    }\n\n    onMouseDown(event: MouseEvent, leftAreaIndex: number, rightAreaIndex: number) {\n        if (this.disabled) { return; }\n\n        event.preventDefault();\n\n        const startPoint: IPoint = {\n            x: event.screenX,\n            y: event.screenY\n        };\n\n        const leftArea = this.areas[leftAreaIndex];\n        const rightArea = this.areas[rightAreaIndex];\n        leftArea.initialSize = leftArea.area.getSize();\n        rightArea.initialSize = rightArea.area.getSize();\n        let currentGutter: McGutterDirective | undefined;\n\n        if (this.useGhost) {\n            // tslint:disable-next-line:no-magic-numbers\n            const gutterOrder = leftAreaIndex * 2 + 1;\n            currentGutter = this.gutters.find((gutter: McGutterDirective) => gutter.order === gutterOrder);\n\n            if (currentGutter) {\n                const gutterPosition = currentGutter.getPosition();\n\n                this.ghost.direction = currentGutter.direction;\n                this.ghost.size = currentGutter.size;\n                this.ghost.x = gutterPosition.x;\n                this.ghost.y = gutterPosition.y;\n\n                this.ghost.visible = true;\n                this.setStyle(StyleProperty.Cursor, currentGutter.direction === Direction.Vertical ? 'row-resize' : 'col-resize');\n            }\n        } else {\n            this.areas.forEach((item) => {\n                const size = item.area.getSize();\n                item.area.disableFlex();\n                item.area.setSize(size);\n            });\n        }\n\n\n        this.listeners.push(\n            this.renderer.listen(\n                'document',\n                'mouseup',\n                () => this.onMouseUp(leftArea, rightArea, currentGutter)\n            )\n        );\n\n        this.ngZone.runOutsideAngular(() => {\n            this.listeners.push(\n                this.renderer.listen(\n                    'document',\n                    'mousemove',\n                    (e: MouseEvent) => this.onMouseMove(e, startPoint, leftArea, rightArea, currentGutter)\n                )\n            );\n        });\n\n        this._isDragging = true;\n    }\n\n    removeArea(area: McSplitterAreaDirective): void {\n        let indexToRemove: number = -1;\n\n        this.areas.some((item, index) => {\n            if (item.area === area) {\n                indexToRemove = index;\n\n                return true;\n            }\n\n            return false;\n        });\n\n        if (indexToRemove === -1) {\n            return;\n        }\n\n        this.areas.splice(indexToRemove, 1);\n    }\n\n    isVertical(): boolean {\n        return this.direction === Direction.Vertical;\n    }\n\n    private updateGutter(): void {\n        this.gutters.forEach((gutter) => {\n            if (gutter.dragged) {\n                gutter.dragged = false;\n\n                this.changeDetectorRef.detectChanges();\n            }\n        });\n    }\n\n    private onMouseMove(event: MouseEvent,\n                        startPoint: IPoint,\n                        leftArea: IArea,\n                        rightArea: IArea,\n                        currentGutter: McGutterDirective | undefined) {\n        if (!this.isDragging || this.disabled) { return; }\n\n        const endPoint: IPoint = {\n            x: event.screenX,\n            y: event.screenY\n        };\n\n        const offset = this.isVertical()\n            ? startPoint.y - endPoint.y\n            : startPoint.x - endPoint.x;\n\n        if (this.useGhost && currentGutter) {\n            const gutterPosition = currentGutter.getPosition();\n            const leftPos = leftArea.area.getPosition();\n            const rightPos = rightArea.area.getPosition();\n            const rightMin = rightArea.area.getMinSize() || 0;\n            const leftMin = leftArea.area.getMinSize() || 0;\n\n            const key = this.isVertical() ? 'y' : 'x';\n\n            const minPos = leftPos[key] - leftMin;\n\n            const maxPos = rightPos[key] + (rightArea.area.getSize() || 0) - rightMin - currentGutter.size;\n\n            const newPos = gutterPosition[key] - offset;\n\n            this.ghost[key] = newPos < minPos ? minPos : Math.min(newPos, maxPos);\n\n        } else {\n           this.resizeAreas(leftArea, rightArea, offset);\n        }\n    }\n\n    private resizeAreas(leftArea: IArea, rightArea: IArea, sizeOffset: number): void {\n        const newLeftAreaSize = leftArea.initialSize - sizeOffset;\n        const newRightAreaSize = rightArea.initialSize + sizeOffset;\n\n        const minLeftAreaSize = leftArea.area.getMinSize();\n        const minRightAreaSize = rightArea.area.getMinSize();\n\n        if (newLeftAreaSize < minLeftAreaSize || newRightAreaSize < minRightAreaSize) {\n            return;\n        } else if (newLeftAreaSize <= 0) {\n            leftArea.area.setSize(0);\n            rightArea.area.setSize(rightArea.initialSize + leftArea.initialSize);\n        } else if (newRightAreaSize <= 0) {\n            leftArea.area.setSize(rightArea.initialSize + leftArea.initialSize);\n            rightArea.area.setSize(0);\n        } else {\n            leftArea.area.setSize(newLeftAreaSize);\n            rightArea.area.setSize(newRightAreaSize);\n        }\n    }\n\n    private onMouseUp(leftArea: IArea,\n                      rightArea: IArea,\n                      currentGutter: McGutterDirective | undefined) {\n        while (this.listeners.length > 0) {\n            const unsubscribe = this.listeners.pop();\n\n            if (unsubscribe) {\n                unsubscribe();\n            }\n        }\n        if (this.useGhost && currentGutter) {\n            const gutterPosition = currentGutter.getPosition();\n            const offset = this.ghost.direction === Direction.Vertical ?\n                gutterPosition.y - this.ghost.y :\n                gutterPosition.x - this.ghost.x;\n            this.resizeAreas(leftArea, rightArea, offset);\n            this.ghost.visible = false;\n            this.setStyle(StyleProperty.Cursor, 'unset');\n        }\n        this._isDragging = false;\n\n        this.updateGutter();\n\n        this.gutterPositionChange.emit();\n    }\n\n    private setStyle(property: StyleProperty, value: string | number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, property, value);\n    }\n}\n\n@Directive({\n    selector: '[mc-splitter-area]',\n    host: {\n        class: 'mc-splitter-area',\n        '[class.mc-splitter-area_resizing]': 'isResizing()'\n    }\n})\nexport class McSplitterAreaDirective implements OnInit, OnDestroy {\n    @Output() sizeChange: EventEmitter<number> = new EventEmitter<number>();\n\n    constructor(\n        private elementRef: ElementRef,\n        private renderer: Renderer2,\n        private splitter: McSplitterComponent\n    ) { }\n\n    isResizing(): boolean {\n        return this.splitter.isDragging;\n    }\n\n    disableFlex(): void {\n        this.renderer.removeStyle(this.elementRef.nativeElement, 'flex');\n    }\n\n    ngOnInit(): void {\n        this.splitter.addArea(this);\n\n        this.removeStyle(StyleProperty.MaxWidth);\n\n        if (this.splitter.direction === Direction.Vertical) {\n            this.setStyle(StyleProperty.Width, '100%');\n            this.removeStyle(StyleProperty.Height);\n        } else {\n            this.setStyle(StyleProperty.Height, '100%');\n            this.removeStyle(StyleProperty.Width);\n        }\n\n        this.splitter.gutterPositionChange.subscribe(() => this.emitSizeChange());\n    }\n\n    ngOnDestroy(): void {\n        this.splitter.removeArea(this);\n    }\n\n    setOrder(order: number): void {\n        this.setStyle(StyleProperty.Order, order);\n    }\n\n    setSize(size: number): void {\n        if (!isNaN(size)) {\n            const sz = coerceNumberProperty(size);\n            this.setStyle(this.getSizeProperty(), coerceCssPixelValue(sz));\n        }\n    }\n\n    getSize(): number {\n        return this.elementRef.nativeElement[this.getOffsetSizeProperty()];\n    }\n\n    getPosition(): IPoint {\n        return {\n            x: this.elementRef.nativeElement.offsetLeft,\n            y: this.elementRef.nativeElement.offsetTop\n        };\n    }\n\n    getMinSize(): number {\n        const styles = getComputedStyle(this.elementRef.nativeElement);\n\n        return parseFloat(styles[this.getMinSizeProperty()]);\n    }\n\n    private isVertical(): boolean {\n        return this.splitter.direction === Direction.Vertical;\n    }\n\n    private getMinSizeProperty(): StyleProperty {\n        return this.isVertical()\n            ? StyleProperty.MinHeight\n            : StyleProperty.MinWidth;\n    }\n\n    private getOffsetSizeProperty(): StyleProperty {\n        return this.isVertical()\n            ? StyleProperty.OffsetHeight\n            : StyleProperty.OffsetWidth;\n    }\n\n    private getSizeProperty(): StyleProperty {\n        return this.isVertical()\n            ? StyleProperty.Height\n            : StyleProperty.Width;\n    }\n\n    private setStyle(style: StyleProperty, value: string | number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, style, value);\n    }\n\n    private removeStyle(style: StyleProperty) {\n        this.renderer.removeStyle(this.elementRef.nativeElement, style);\n    }\n\n    private emitSizeChange(): void {\n        this.sizeChange.emit(this.getSize());\n    }\n}\n","<ng-content></ng-content>\n\n<ng-template ngFor let-area [ngForOf]=\"areas\" let-index=\"index\" let-last=\"last\">\n    <mc-gutter *ngIf=\"last === false\"\n               [direction]=\"direction\"\n               [attr.disabled]=\"disabled || null\"\n               [style.display]=\"hideGutters ? 'none' : 'flex'\"\n               [size]=\"gutterSize\"\n               [order]=\"index * 2 + 1\"\n               (mousedown)=\"onMouseDown($event, index, index + 1)\">\n    </mc-gutter>\n</ng-template>\n\n<mc-gutter-ghost *ngIf=\"useGhost\"></mc-gutter-ghost>\n"]}
@@ -1,22 +1,23 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
3
  import { McIconModule } from '@ptsecurity/mosaic/icon';
4
- import { McGutterDirective, McSplitterAreaDirective, McSplitterComponent } from './splitter.component';
4
+ import { McGutterDirective, McGutterGhostDirective, McSplitterAreaDirective, McSplitterComponent } from './splitter.component';
5
5
  import * as i0 from "@angular/core";
6
6
  export class McSplitterModule {
7
7
  }
8
- /** @nocollapse */ McSplitterModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- /** @nocollapse */ McSplitterModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterModule, declarations: [McGutterDirective,
8
+ /** @nocollapse */ McSplitterModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ /** @nocollapse */ McSplitterModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterModule, declarations: [McGutterDirective,
10
+ McGutterGhostDirective,
10
11
  McSplitterAreaDirective,
11
12
  McSplitterComponent], imports: [CommonModule,
12
13
  McIconModule], exports: [McGutterDirective,
13
14
  McSplitterAreaDirective,
14
15
  McSplitterComponent] });
15
- /** @nocollapse */ McSplitterModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterModule, imports: [[
16
+ /** @nocollapse */ McSplitterModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterModule, imports: [[
16
17
  CommonModule,
17
18
  McIconModule
18
19
  ]] });
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: McSplitterModule, decorators: [{
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: McSplitterModule, decorators: [{
20
21
  type: NgModule,
21
22
  args: [{
22
23
  imports: [
@@ -30,9 +31,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
30
31
  ],
31
32
  declarations: [
32
33
  McGutterDirective,
34
+ McGutterGhostDirective,
33
35
  McSplitterAreaDirective,
34
36
  McSplitterComponent
35
37
  ]
36
38
  }]
37
39
  }] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BsaXR0ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbW9zYWljL3NwbGl0dGVyL3NwbGl0dGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFdkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLHVCQUF1QixFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBbUJ2RyxNQUFNLE9BQU8sZ0JBQWdCOztnSUFBaEIsZ0JBQWdCO2lJQUFoQixnQkFBZ0IsaUJBTHJCLGlCQUFpQjtRQUNqQix1QkFBdUI7UUFDdkIsbUJBQW1CLGFBWG5CLFlBQVk7UUFDWixZQUFZLGFBR1osaUJBQWlCO1FBQ2pCLHVCQUF1QjtRQUN2QixtQkFBbUI7aUlBUWQsZ0JBQWdCLFlBZmhCO1lBQ0wsWUFBWTtZQUNaLFlBQVk7U0FDZjsyRkFZUSxnQkFBZ0I7a0JBaEI1QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLFlBQVk7cUJBQ2Y7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLGlCQUFpQjt3QkFDakIsdUJBQXVCO3dCQUN2QixtQkFBbUI7cUJBQ3RCO29CQUNELFlBQVksRUFBRTt3QkFDVixpQkFBaUI7d0JBQ2pCLHVCQUF1Qjt3QkFDdkIsbUJBQW1CO3FCQUN0QjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWNJY29uTW9kdWxlIH0gZnJvbSAnQHB0c2VjdXJpdHkvbW9zYWljL2ljb24nO1xuXG5pbXBvcnQgeyBNY0d1dHRlckRpcmVjdGl2ZSwgTWNTcGxpdHRlckFyZWFEaXJlY3RpdmUsIE1jU3BsaXR0ZXJDb21wb25lbnQgfSBmcm9tICcuL3NwbGl0dGVyLmNvbXBvbmVudCc7XG5cblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTWNJY29uTW9kdWxlXG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIE1jR3V0dGVyRGlyZWN0aXZlLFxuICAgICAgICBNY1NwbGl0dGVyQXJlYURpcmVjdGl2ZSxcbiAgICAgICAgTWNTcGxpdHRlckNvbXBvbmVudFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIE1jR3V0dGVyRGlyZWN0aXZlLFxuICAgICAgICBNY1NwbGl0dGVyQXJlYURpcmVjdGl2ZSxcbiAgICAgICAgTWNTcGxpdHRlckNvbXBvbmVudFxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgTWNTcGxpdHRlck1vZHVsZSB7XG59XG4iXX0=
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BsaXR0ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbW9zYWljL3NwbGl0dGVyL3NwbGl0dGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFdkQsT0FBTyxFQUNILGlCQUFpQixFQUNqQixzQkFBc0IsRUFDdEIsdUJBQXVCLEVBQ3ZCLG1CQUFtQixFQUN0QixNQUFNLHNCQUFzQixDQUFDOztBQW9COUIsTUFBTSxPQUFPLGdCQUFnQjs7aUlBQWhCLGdCQUFnQjtrSUFBaEIsZ0JBQWdCLGlCQU5yQixpQkFBaUI7UUFDakIsc0JBQXNCO1FBQ3RCLHVCQUF1QjtRQUN2QixtQkFBbUIsYUFabkIsWUFBWTtRQUNaLFlBQVksYUFHWixpQkFBaUI7UUFDakIsdUJBQXVCO1FBQ3ZCLG1CQUFtQjtrSUFTZCxnQkFBZ0IsWUFoQmhCO1lBQ0wsWUFBWTtZQUNaLFlBQVk7U0FDZjs0RkFhUSxnQkFBZ0I7a0JBakI1QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLFlBQVk7cUJBQ2Y7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLGlCQUFpQjt3QkFDakIsdUJBQXVCO3dCQUN2QixtQkFBbUI7cUJBQ3RCO29CQUNELFlBQVksRUFBRTt3QkFDVixpQkFBaUI7d0JBQ2pCLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2QixtQkFBbUI7cUJBQ3RCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNY0ljb25Nb2R1bGUgfSBmcm9tICdAcHRzZWN1cml0eS9tb3NhaWMvaWNvbic7XG5cbmltcG9ydCB7XG4gICAgTWNHdXR0ZXJEaXJlY3RpdmUsXG4gICAgTWNHdXR0ZXJHaG9zdERpcmVjdGl2ZSxcbiAgICBNY1NwbGl0dGVyQXJlYURpcmVjdGl2ZSxcbiAgICBNY1NwbGl0dGVyQ29tcG9uZW50XG59IGZyb20gJy4vc3BsaXR0ZXIuY29tcG9uZW50JztcblxuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBNY0ljb25Nb2R1bGVcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgTWNHdXR0ZXJEaXJlY3RpdmUsXG4gICAgICAgIE1jU3BsaXR0ZXJBcmVhRGlyZWN0aXZlLFxuICAgICAgICBNY1NwbGl0dGVyQ29tcG9uZW50XG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtcbiAgICAgICAgTWNHdXR0ZXJEaXJlY3RpdmUsXG4gICAgICAgIE1jR3V0dGVyR2hvc3REaXJlY3RpdmUsXG4gICAgICAgIE1jU3BsaXR0ZXJBcmVhRGlyZWN0aXZlLFxuICAgICAgICBNY1NwbGl0dGVyQ29tcG9uZW50XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBNY1NwbGl0dGVyTW9kdWxlIHtcbn1cbiJdfQ==