@progress/kendo-angular-buttons 7.0.0-next.202111120840 → 7.0.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 (283) hide show
  1. package/LICENSE.md +1 -1
  2. package/NOTICE.txt +119 -79
  3. package/README.md +1 -1
  4. package/dist/cdn/js/kendo-angular-buttons.js +20 -0
  5. package/dist/cdn/main.js +5 -0
  6. package/dist/es/button/button.directive.js +771 -0
  7. package/{esm2015 → dist/es}/button/button.module.js +13 -13
  8. package/dist/es/button/button.service.js +24 -0
  9. package/{esm2015 → dist/es}/button/selection-settings.js +0 -1
  10. package/dist/es/buttongroup/buttongroup.component.js +353 -0
  11. package/dist/es/buttongroup/buttongroup.module.js +30 -0
  12. package/{esm2015 → dist/es}/buttons.module.js +12 -12
  13. package/{esm2015 → dist/es}/chip/chip-content-click-event-args.interface.js +0 -1
  14. package/{esm2015 → dist/es}/chip/chip-list-remove-event-args.interface.js +0 -1
  15. package/dist/es/chip/chip-list.component.js +214 -0
  16. package/{esm2015 → dist/es}/chip/chip-remove-event-args.interface.js +0 -1
  17. package/dist/es/chip/chip.component.js +449 -0
  18. package/dist/es/chip/chip.module.js +55 -0
  19. package/{esm2015 → dist/es}/chip/models/selection.js +0 -1
  20. package/dist/es/common/models/fillmode.js +4 -0
  21. package/dist/es/common/models/rounded.js +4 -0
  22. package/{esm2015 → dist/es}/common/models/shape.js +0 -1
  23. package/{esm2015 → dist/es}/common/models/size.js +0 -1
  24. package/dist/es/common/models/styling-classes.js +4 -0
  25. package/{esm2015 → dist/es}/common/models/theme-color.js +0 -1
  26. package/{esm2015/button-look.js → dist/es/common/models.js} +0 -1
  27. package/{esm2015 → dist/es}/direction.js +0 -1
  28. package/dist/es/dropdownbutton/dropdownbutton.component.js +705 -0
  29. package/dist/es/dropdownbutton/dropdownbutton.module.js +32 -0
  30. package/dist/es/floatingactionbutton/animations/animations.js +33 -0
  31. package/dist/es/floatingactionbutton/dial-item.component.js +143 -0
  32. package/dist/es/floatingactionbutton/dial-list.component.js +76 -0
  33. package/dist/es/floatingactionbutton/floatingactionbutton.component.js +903 -0
  34. package/dist/es/floatingactionbutton/floatingactionbutton.module.js +65 -0
  35. package/{esm2015 → dist/es}/floatingactionbutton/models/align.js +0 -1
  36. package/{esm2015 → dist/es}/floatingactionbutton/models/item-animation.interface.js +0 -1
  37. package/{esm2015 → dist/es}/floatingactionbutton/models/item-click.event.js +0 -1
  38. package/{esm2015 → dist/es}/floatingactionbutton/models/item.interface.js +0 -1
  39. package/{esm2015 → dist/es}/floatingactionbutton/models/offset.js +0 -1
  40. package/{esm2015 → dist/es}/floatingactionbutton/models/position-mode.js +0 -1
  41. package/dist/es/floatingactionbutton/templates/dial-item-template.directive.js +26 -0
  42. package/dist/es/floatingactionbutton/templates/fab-template.directive.js +26 -0
  43. package/dist/es/floatingactionbutton/utils.js +38 -0
  44. package/dist/es/focusable/focus.service.js +43 -0
  45. package/dist/es/focusable/focusable.directive.js +68 -0
  46. package/dist/es/index.js +22 -0
  47. package/dist/es/listbutton/button-item-template.directive.js +68 -0
  48. package/dist/es/listbutton/list-button.js +243 -0
  49. package/{esm2015 → dist/es}/listbutton/list-item-model.js +0 -1
  50. package/dist/es/listbutton/list.component.js +85 -0
  51. package/dist/es/listbutton/list.module.js +33 -0
  52. package/{esm2015 → dist/es}/listbutton/popup-settings.js +0 -1
  53. package/dist/es/listbutton/template-context.directive.js +40 -0
  54. package/{esm2015 → dist/es}/main.js +1 -5
  55. package/{esm2015 → dist/es}/navigation/key-events.js +0 -0
  56. package/{esm2015 → dist/es}/navigation/navigation-action.js +0 -0
  57. package/dist/es/navigation/navigation-config.js +9 -0
  58. package/dist/es/navigation/navigation.service.js +114 -0
  59. package/dist/es/package-metadata.js +15 -0
  60. package/dist/es/preventable-event.js +29 -0
  61. package/dist/es/splitbutton/localization/custom-messages.component.js +44 -0
  62. package/dist/es/splitbutton/localization/localized-messages.directive.js +35 -0
  63. package/dist/es/splitbutton/localization/messages.js +22 -0
  64. package/dist/es/splitbutton/splitbutton.component.js +831 -0
  65. package/dist/es/splitbutton/splitbutton.module.js +34 -0
  66. package/dist/es/util.js +97 -0
  67. package/{button → dist/es2015/button}/button.directive.d.ts +100 -46
  68. package/dist/es2015/button/button.directive.js +674 -0
  69. package/{button → dist/es2015/button}/button.module.d.ts +0 -5
  70. package/dist/es2015/button/button.module.js +47 -0
  71. package/{button → dist/es2015/button}/button.service.d.ts +1 -7
  72. package/dist/es2015/button/button.service.js +26 -0
  73. package/{button → dist/es2015/button}/selection-settings.d.ts +0 -0
  74. package/dist/es2015/button/selection-settings.js +4 -0
  75. package/{buttongroup → dist/es2015/buttongroup}/buttongroup.component.d.ts +9 -28
  76. package/{esm2015 → dist/es2015}/buttongroup/buttongroup.component.js +116 -121
  77. package/dist/es2015/buttongroup/buttongroup.module.d.ts +14 -0
  78. package/dist/es2015/buttongroup/buttongroup.module.js +27 -0
  79. package/{buttons.module.d.ts → dist/es2015/buttons.module.d.ts} +0 -10
  80. package/dist/es2015/buttons.module.js +51 -0
  81. package/{chip → dist/es2015/chip}/chip-content-click-event-args.interface.d.ts +0 -0
  82. package/dist/es2015/chip/chip-content-click-event-args.interface.js +4 -0
  83. package/{chip → dist/es2015/chip}/chip-list-remove-event-args.interface.d.ts +0 -0
  84. package/dist/es2015/chip/chip-list-remove-event-args.interface.js +4 -0
  85. package/{chip → dist/es2015/chip}/chip-list.component.d.ts +21 -8
  86. package/dist/es2015/chip/chip-list.component.js +197 -0
  87. package/{chip → dist/es2015/chip}/chip-remove-event-args.interface.d.ts +0 -0
  88. package/dist/es2015/chip/chip-remove-event-args.interface.js +4 -0
  89. package/{chip → dist/es2015/chip}/chip.component.d.ts +72 -38
  90. package/dist/es2015/chip/chip.component.js +431 -0
  91. package/{chip → dist/es2015/chip}/chip.module.d.ts +0 -7
  92. package/{esm2015 → dist/es2015}/chip/chip.module.js +11 -16
  93. package/{chip → dist/es2015/chip}/models/selection.d.ts +0 -0
  94. package/dist/es2015/chip/models/selection.js +4 -0
  95. package/{util.d.ts → dist/es2015/common/models/fillmode.d.ts} +4 -8
  96. package/dist/es2015/common/models/fillmode.js +4 -0
  97. package/dist/es2015/common/models/rounded.d.ts +12 -0
  98. package/dist/es2015/common/models/rounded.js +4 -0
  99. package/dist/es2015/common/models/shape.d.ts +9 -0
  100. package/dist/es2015/common/models/shape.js +4 -0
  101. package/dist/es2015/common/models/size.d.ts +17 -0
  102. package/dist/es2015/common/models/size.js +4 -0
  103. package/{esm2015/kendo-angular-buttons.js → dist/es2015/common/models/styling-classes.d.ts} +5 -2
  104. package/dist/es2015/common/models/styling-classes.js +4 -0
  105. package/{common → dist/es2015/common}/models/theme-color.d.ts +15 -4
  106. package/dist/es2015/common/models/theme-color.js +4 -0
  107. package/{common/models/size.d.ts → dist/es2015/common/models.d.ts} +6 -10
  108. package/dist/es2015/common/models.js +4 -0
  109. package/{direction.d.ts → dist/es2015/direction.d.ts} +0 -0
  110. package/dist/es2015/direction.js +4 -0
  111. package/{dropdownbutton → dist/es2015/dropdownbutton}/dropdownbutton.component.d.ts +74 -29
  112. package/{esm2015 → dist/es2015}/dropdownbutton/dropdownbutton.component.js +258 -179
  113. package/dist/es2015/dropdownbutton/dropdownbutton.module.d.ts +14 -0
  114. package/dist/es2015/dropdownbutton/dropdownbutton.module.js +29 -0
  115. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/animations/animations.d.ts +0 -0
  116. package/{esm2015 → dist/es2015}/floatingactionbutton/animations/animations.js +0 -0
  117. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/dial-item.component.d.ts +5 -8
  118. package/dist/es2015/floatingactionbutton/dial-item.component.js +133 -0
  119. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/dial-list.component.d.ts +2 -5
  120. package/dist/es2015/floatingactionbutton/dial-list.component.js +81 -0
  121. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/floatingactionbutton.component.d.ts +47 -49
  122. package/{esm2015 → dist/es2015}/floatingactionbutton/floatingactionbutton.component.js +212 -192
  123. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/floatingactionbutton.module.d.ts +0 -13
  124. package/{esm2015 → dist/es2015}/floatingactionbutton/floatingactionbutton.module.js +11 -19
  125. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/models/align.d.ts +0 -0
  126. package/dist/es2015/floatingactionbutton/models/align.js +4 -0
  127. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/models/item-animation.interface.d.ts +0 -0
  128. package/dist/es2015/floatingactionbutton/models/item-animation.interface.js +4 -0
  129. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/models/item-click.event.d.ts +0 -0
  130. package/dist/es2015/floatingactionbutton/models/item-click.event.js +4 -0
  131. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/models/item.interface.d.ts +0 -0
  132. package/dist/es2015/floatingactionbutton/models/item.interface.js +4 -0
  133. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/models/offset.d.ts +0 -0
  134. package/dist/es2015/floatingactionbutton/models/offset.js +4 -0
  135. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/models/position-mode.d.ts +0 -0
  136. package/dist/es2015/floatingactionbutton/models/position-mode.js +4 -0
  137. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/templates/dial-item-template.directive.d.ts +0 -3
  138. package/dist/es2015/floatingactionbutton/templates/dial-item-template.directive.js +25 -0
  139. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/templates/fab-template.directive.d.ts +0 -3
  140. package/dist/es2015/floatingactionbutton/templates/fab-template.directive.js +25 -0
  141. package/{floatingactionbutton → dist/es2015/floatingactionbutton}/utils.d.ts +0 -0
  142. package/{esm2015 → dist/es2015}/floatingactionbutton/utils.js +0 -0
  143. package/{focusable → dist/es2015/focusable}/focus.service.d.ts +1 -5
  144. package/{esm2015 → dist/es2015}/focusable/focus.service.js +10 -8
  145. package/{focusable → dist/es2015/focusable}/focusable.directive.d.ts +0 -3
  146. package/{esm2015 → dist/es2015}/focusable/focusable.directive.js +20 -19
  147. package/dist/es2015/index.d.ts +22 -0
  148. package/dist/es2015/index.js +22 -0
  149. package/dist/es2015/index.metadata.json +1 -0
  150. package/{listbutton → dist/es2015/listbutton}/button-item-template.directive.d.ts +0 -3
  151. package/{esm2015 → dist/es2015}/listbutton/button-item-template.directive.js +12 -13
  152. package/{listbutton → dist/es2015/listbutton}/list-button.d.ts +2 -6
  153. package/{esm2015 → dist/es2015}/listbutton/list-button.js +6 -16
  154. package/{listbutton → dist/es2015/listbutton}/list-item-model.d.ts +0 -0
  155. package/dist/es2015/listbutton/list-item-model.js +4 -0
  156. package/{listbutton → dist/es2015/listbutton}/list.component.d.ts +3 -3
  157. package/dist/es2015/listbutton/list.component.js +113 -0
  158. package/dist/es2015/listbutton/list.module.d.ts +9 -0
  159. package/dist/es2015/listbutton/list.module.js +30 -0
  160. package/{listbutton → dist/es2015/listbutton}/popup-settings.d.ts +0 -0
  161. package/dist/es2015/listbutton/popup-settings.js +4 -0
  162. package/{listbutton → dist/es2015/listbutton}/template-context.directive.d.ts +1 -4
  163. package/dist/es2015/listbutton/template-context.directive.js +35 -0
  164. package/{main.d.ts → dist/es2015/main.d.ts} +5 -9
  165. package/dist/es2015/main.js +22 -0
  166. package/{navigation → dist/es2015/navigation}/key-events.d.ts +0 -0
  167. package/dist/es2015/navigation/key-events.js +13 -0
  168. package/{navigation → dist/es2015/navigation}/navigation-action.d.ts +0 -0
  169. package/dist/es2015/navigation/navigation-action.js +19 -0
  170. package/{navigation → dist/es2015/navigation}/navigation-config.d.ts +0 -0
  171. package/{esm2015 → dist/es2015}/navigation/navigation-config.js +0 -0
  172. package/{navigation → dist/es2015/navigation}/navigation.service.d.ts +0 -3
  173. package/{esm2015 → dist/es2015}/navigation/navigation.service.js +9 -11
  174. package/{package-metadata.d.ts → dist/es2015/package-metadata.d.ts} +0 -0
  175. package/{esm2015 → dist/es2015}/package-metadata.js +1 -1
  176. package/{preventable-event.d.ts → dist/es2015/preventable-event.d.ts} +0 -0
  177. package/{esm2015 → dist/es2015}/preventable-event.js +0 -0
  178. package/dist/es2015/splitbutton/localization/custom-messages.component.d.ts +15 -0
  179. package/dist/es2015/splitbutton/localization/custom-messages.component.js +36 -0
  180. package/dist/es2015/splitbutton/localization/localized-messages.directive.d.ts +13 -0
  181. package/dist/es2015/splitbutton/localization/localized-messages.directive.js +31 -0
  182. package/dist/es2015/splitbutton/localization/messages.d.ts +32 -0
  183. package/dist/es2015/splitbutton/localization/messages.js +16 -0
  184. package/{splitbutton → dist/es2015/splitbutton}/splitbutton.component.d.ts +74 -34
  185. package/{esm2015 → dist/es2015}/splitbutton/splitbutton.component.js +289 -203
  186. package/dist/es2015/splitbutton/splitbutton.module.d.ts +14 -0
  187. package/dist/es2015/splitbutton/splitbutton.module.js +31 -0
  188. package/dist/es2015/util.d.ts +41 -0
  189. package/dist/es2015/util.js +95 -0
  190. package/{fesm2015/kendo-angular-buttons.js → dist/fesm2015/index.js} +2375 -1814
  191. package/dist/fesm5/index.js +5565 -0
  192. package/dist/npm/button/button.directive.js +773 -0
  193. package/dist/npm/button/button.module.js +52 -0
  194. package/dist/npm/button/button.service.js +26 -0
  195. package/dist/npm/button/selection-settings.js +6 -0
  196. package/dist/npm/buttongroup/buttongroup.component.js +355 -0
  197. package/dist/npm/buttongroup/buttongroup.module.js +32 -0
  198. package/dist/npm/buttons.module.js +56 -0
  199. package/dist/npm/chip/chip-content-click-event-args.interface.js +6 -0
  200. package/dist/npm/chip/chip-list-remove-event-args.interface.js +6 -0
  201. package/dist/npm/chip/chip-list.component.js +216 -0
  202. package/dist/npm/chip/chip-remove-event-args.interface.js +6 -0
  203. package/dist/npm/chip/chip.component.js +451 -0
  204. package/dist/npm/chip/chip.module.js +57 -0
  205. package/dist/npm/chip/models/selection.js +6 -0
  206. package/dist/npm/common/models/fillmode.js +6 -0
  207. package/dist/npm/common/models/rounded.js +6 -0
  208. package/dist/npm/common/models/shape.js +6 -0
  209. package/dist/npm/common/models/size.js +6 -0
  210. package/dist/npm/common/models/styling-classes.js +6 -0
  211. package/dist/npm/common/models/theme-color.js +6 -0
  212. package/dist/npm/common/models.js +6 -0
  213. package/dist/npm/direction.js +6 -0
  214. package/dist/npm/dropdownbutton/dropdownbutton.component.js +707 -0
  215. package/dist/npm/dropdownbutton/dropdownbutton.module.js +34 -0
  216. package/dist/npm/floatingactionbutton/animations/animations.js +37 -0
  217. package/dist/npm/floatingactionbutton/dial-item.component.js +145 -0
  218. package/dist/npm/floatingactionbutton/dial-list.component.js +78 -0
  219. package/dist/npm/floatingactionbutton/floatingactionbutton.component.js +905 -0
  220. package/dist/npm/floatingactionbutton/floatingactionbutton.module.js +67 -0
  221. package/dist/npm/floatingactionbutton/models/align.js +6 -0
  222. package/dist/npm/floatingactionbutton/models/item-animation.interface.js +6 -0
  223. package/dist/npm/floatingactionbutton/models/item-click.event.js +6 -0
  224. package/dist/npm/floatingactionbutton/models/item.interface.js +6 -0
  225. package/dist/npm/floatingactionbutton/models/offset.js +6 -0
  226. package/dist/npm/floatingactionbutton/models/position-mode.js +6 -0
  227. package/dist/npm/floatingactionbutton/templates/dial-item-template.directive.js +28 -0
  228. package/dist/npm/floatingactionbutton/templates/fab-template.directive.js +28 -0
  229. package/dist/npm/floatingactionbutton/utils.js +42 -0
  230. package/dist/npm/focusable/focus.service.js +45 -0
  231. package/dist/npm/focusable/focusable.directive.js +70 -0
  232. package/dist/npm/index.js +39 -0
  233. package/dist/npm/listbutton/button-item-template.directive.js +70 -0
  234. package/dist/npm/listbutton/list-button.js +245 -0
  235. package/dist/npm/listbutton/list-item-model.js +6 -0
  236. package/dist/npm/listbutton/list.component.js +87 -0
  237. package/dist/npm/listbutton/list.module.js +35 -0
  238. package/dist/npm/listbutton/popup-settings.js +6 -0
  239. package/dist/npm/listbutton/template-context.directive.js +42 -0
  240. package/dist/npm/main.js +45 -0
  241. package/dist/npm/navigation/key-events.js +15 -0
  242. package/dist/npm/navigation/navigation-action.js +21 -0
  243. package/dist/npm/navigation/navigation-config.js +11 -0
  244. package/dist/npm/navigation/navigation.service.js +116 -0
  245. package/dist/npm/package-metadata.js +17 -0
  246. package/dist/npm/preventable-event.js +31 -0
  247. package/dist/npm/splitbutton/localization/custom-messages.component.js +46 -0
  248. package/dist/npm/splitbutton/localization/localized-messages.directive.js +37 -0
  249. package/dist/npm/splitbutton/localization/messages.js +24 -0
  250. package/dist/npm/splitbutton/splitbutton.component.js +833 -0
  251. package/dist/npm/splitbutton/splitbutton.module.js +36 -0
  252. package/dist/npm/util.js +100 -0
  253. package/dist/systemjs/kendo-angular-buttons.js +5 -0
  254. package/package.json +110 -35
  255. package/schematics/ngAdd/index.js +2 -5
  256. package/schematics/ngAdd/index.js.map +1 -1
  257. package/bundles/kendo-angular-buttons.umd.js +0 -5
  258. package/button-look.d.ts +0 -21
  259. package/buttongroup/buttongroup.module.d.ts +0 -21
  260. package/chip/models/chip-look.d.ts +0 -18
  261. package/chip/models/type.d.ts +0 -21
  262. package/common/models/shape.d.ts +0 -16
  263. package/dropdownbutton/dropdownbutton.module.d.ts +0 -23
  264. package/esm2015/button/button.directive.js +0 -488
  265. package/esm2015/button/button.service.js +0 -28
  266. package/esm2015/buttongroup/buttongroup.module.js +0 -30
  267. package/esm2015/chip/chip-list.component.js +0 -145
  268. package/esm2015/chip/chip.component.js +0 -335
  269. package/esm2015/chip/models/chip-look.js +0 -5
  270. package/esm2015/chip/models/type.js +0 -5
  271. package/esm2015/dropdownbutton/dropdownbutton.module.js +0 -32
  272. package/esm2015/floatingactionbutton/dial-item.component.js +0 -126
  273. package/esm2015/floatingactionbutton/dial-list.component.js +0 -89
  274. package/esm2015/floatingactionbutton/templates/dial-item-template.directive.js +0 -27
  275. package/esm2015/floatingactionbutton/templates/fab-template.directive.js +0 -27
  276. package/esm2015/listbutton/list.component.js +0 -120
  277. package/esm2015/listbutton/list.module.js +0 -39
  278. package/esm2015/listbutton/template-context.directive.js +0 -33
  279. package/esm2015/splitbutton/splitbutton.module.js +0 -32
  280. package/esm2015/util.js +0 -39
  281. package/kendo-angular-buttons.d.ts +0 -9
  282. package/listbutton/list.module.d.ts +0 -18
  283. package/splitbutton/splitbutton.module.d.ts +0 -23
@@ -0,0 +1,705 @@
1
+ /**-----------------------------------------------------------------------------------------
2
+ * Copyright © 2021 Progress Software Corporation. All rights reserved.
3
+ * Licensed under commercial license. See LICENSE.md in the project root for more information
4
+ *-------------------------------------------------------------------------------------------*/
5
+ import * as tslib_1 from "tslib";
6
+ /* tslint:disable:no-access-missing-member */
7
+ import { Component, ContentChild, TemplateRef, ViewChild, ViewContainerRef, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, NgZone, ChangeDetectorRef } from '@angular/core';
8
+ import { LocalizationService, L10N_PREFIX } from '@progress/kendo-angular-l10n';
9
+ import { PopupService } from '@progress/kendo-angular-popup';
10
+ import { isDocumentAvailable, guid, Keys, isChanged } from '@progress/kendo-angular-common';
11
+ import { ButtonItemTemplateDirective } from '../listbutton/button-item-template.directive';
12
+ import { isPresent, tick } from '../util';
13
+ import { ListButton } from '../listbutton/list-button';
14
+ import { ListComponent } from '../listbutton/list.component';
15
+ import { FocusService } from '../focusable/focus.service';
16
+ import { NavigationService } from '../navigation/navigation.service';
17
+ import { NAVIGATION_CONFIG } from '../navigation/navigation-config';
18
+ import { PreventableEvent } from '../preventable-event';
19
+ import { merge } from 'rxjs';
20
+ var NAVIGATION_SETTINGS = {
21
+ useLeftRightArrows: true
22
+ };
23
+ var ɵ0 = NAVIGATION_SETTINGS;
24
+ var NAVIGATION_SETTINGS_PROVIDER = {
25
+ provide: NAVIGATION_CONFIG,
26
+ useValue: ɵ0
27
+ };
28
+ /**
29
+ * Represents the Kendo UI DropDownButton component for Angular.
30
+ *
31
+ * @example
32
+ * ```ts
33
+ * _@Component({
34
+ * selector: 'my-app',
35
+ * template: `
36
+ * <kendo-dropdownbutton [data]="data">
37
+ * User Settings
38
+ * </kendo-dropdownbutton>
39
+ * `
40
+ * })
41
+ * class AppComponent {
42
+ * public data: Array<any> = [{
43
+ * text: 'My Profile'
44
+ * }, {
45
+ * text: 'Friend Requests'
46
+ * }, {
47
+ * text: 'Account Settings'
48
+ * }, {
49
+ * text: 'Support'
50
+ * }, {
51
+ * text: 'Log Out'
52
+ * }];
53
+ * }
54
+ * ```
55
+ */
56
+ var DropDownButtonComponent = /** @class */ (function (_super) {
57
+ tslib_1.__extends(DropDownButtonComponent, _super);
58
+ function DropDownButtonComponent(focusService, navigationService, wrapperRef, zone, popupService, elRef, localization, cdr) {
59
+ var _this = _super.call(this, focusService, navigationService, wrapperRef, zone, localization, cdr) || this;
60
+ _this.popupService = popupService;
61
+ _this.elRef = elRef;
62
+ /**
63
+ * Defines the name of an existing icon in a Kendo UI theme.
64
+ */
65
+ _this.icon = '';
66
+ /**
67
+ * Defines the list of CSS classes which are used for styling the Button with custom icons.
68
+ */
69
+ _this.iconClass = '';
70
+ /**
71
+ * Defines a URL for styling the button with a custom image.
72
+ */
73
+ _this.imageUrl = '';
74
+ /**
75
+ * The size property specifies the padding of the DropDownButton
76
+ * ([see example]({% slug api_buttons_dropdownbuttoncomponent %}#toc-size)).
77
+ *
78
+ * The possible values are:
79
+ * * `'small'`
80
+ * * `'medium'` (default)
81
+ * * `'large'`
82
+ * * `null`
83
+ */
84
+ _this.size = 'medium';
85
+ /**
86
+ * The shape property specifies if the DropDownButton will be a square or rectangle.
87
+ * ([see example]({% slug api_buttons_dropdownbuttoncomponent %}#toc-shape)).
88
+ *
89
+ * The possible values are:
90
+ * * `'rectangle'` (default)
91
+ * * `'square'`
92
+ * * `null`
93
+ */
94
+ _this.shape = 'rectangle';
95
+ /**
96
+ * The rounded property specifies the border radius of the DropDownButton
97
+ * ([see example]({% slug api_buttons_dropdownbuttoncomponent %}#toc-rounded)).
98
+ *
99
+ * The possible values are:
100
+ * * `'small'`
101
+ * * `'medium'` (default)
102
+ * * `'large'`
103
+ * * `'full'`
104
+ * * `null`
105
+ */
106
+ _this.rounded = 'medium';
107
+ /**
108
+ * The DropDownButton allows you to specify predefined theme colors.
109
+ * The theme color will be applied as a background and border color while also amending the text color accordingly
110
+ * ([see example]({% slug api_buttons_dropdownbuttoncomponent %}#toc-themeColor)).
111
+ *
112
+ * The possible values are:
113
+ * * `base` &mdash;Applies coloring based on the `base` theme color. (default)
114
+ * * `primary` &mdash;Applies coloring based on the `primary` theme color.
115
+ * * `secondary`&mdash;Applies coloring based on the `secondary` theme color.
116
+ * * `tertiary`&mdash; Applies coloring based on the `tertiary` theme color.
117
+ * * `info`&mdash;Applies coloring based on the `info` theme color.
118
+ * * `success`&mdash; Applies coloring based on the `success` theme color.
119
+ * * `warning`&mdash; Applies coloring based on the `warning` theme color.
120
+ * * `error`&mdash; Applies coloring based on the `error` theme color.
121
+ * * `dark`&mdash; Applies coloring based on the `dark` theme color.
122
+ * * `light`&mdash; Applies coloring based on the `light` theme color.
123
+ * * `inverse`&mdash; Applies coloring based on the `inverse` theme color.
124
+ * * `null` &mdash;Removes the default CSS class (no class would be rendered).
125
+ */
126
+ _this.themeColor = 'base';
127
+ /**
128
+ * Specifies the [`tabIndex`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) of the component.
129
+ */
130
+ _this.tabIndex = 0;
131
+ /**
132
+ * Fires each time the user clicks on a drop-down list item. The event data contains the data item bound to the clicked list item.
133
+ */
134
+ _this.itemClick = new EventEmitter();
135
+ /**
136
+ * Fires each time the popup is about to open.
137
+ * This event is preventable. If you cancel the event, the popup will remain closed.
138
+ */
139
+ _this.open = new EventEmitter();
140
+ /**
141
+ * Fires each time the popup is about to close.
142
+ * This event is preventable. If you cancel the event, the popup will remain open.
143
+ */
144
+ _this.close = new EventEmitter();
145
+ /**
146
+ * Fires each time the DropDownButton gets focused.
147
+ */
148
+ _this.onFocus = new EventEmitter(); //tslint:disable-line:no-output-rename
149
+ /**
150
+ * Fires each time the DropDownButton gets blurred.
151
+ */
152
+ _this.onBlur = new EventEmitter(); //tslint:disable-line:no-output-rename
153
+ _this.listId = guid();
154
+ _this._fillMode = 'solid';
155
+ _this._itemClick = _this.itemClick;
156
+ _this._blur = _this.onBlur;
157
+ return _this;
158
+ }
159
+ Object.defineProperty(DropDownButtonComponent.prototype, "popupSettings", {
160
+ get: function () {
161
+ return this._popupSettings;
162
+ },
163
+ /**
164
+ * Configures the popup of the DropDownButton.
165
+ *
166
+ * The available options are:
167
+ * - `animate: Boolean`&mdash;Controls the popup animation. By default, the open and close animations are enabled.
168
+ * - `popupClass: String`&mdash;Specifies a list of CSS classes that are used to style the popup.
169
+ * - `appendTo: "root" | "component" | ViewContainerRef`&mdash;Specifies the component to which the popup will be appended.
170
+ * - `align: "left" | "center" | "right"`&mdash;Specifies the alignment of the popup.
171
+ */
172
+ set: function (settings) {
173
+ this._popupSettings = Object.assign({ animate: true, popupClass: '' }, settings);
174
+ },
175
+ enumerable: true,
176
+ configurable: true
177
+ });
178
+ Object.defineProperty(DropDownButtonComponent.prototype, "disabled", {
179
+ get: function () {
180
+ return this._disabled;
181
+ },
182
+ /**
183
+ * Sets the disabled state of the DropDownButton.
184
+ */
185
+ set: function (value) {
186
+ if (value && this.openState) {
187
+ this.openState = false;
188
+ }
189
+ this._disabled = value;
190
+ },
191
+ enumerable: true,
192
+ configurable: true
193
+ });
194
+ Object.defineProperty(DropDownButtonComponent.prototype, "data", {
195
+ get: function () {
196
+ return this._data;
197
+ },
198
+ /**
199
+ * Sets or gets the data of the DropDownButton.
200
+ *
201
+ * > The data has to be provided in an array-like list.
202
+ */
203
+ set: function (data) {
204
+ this._data = data || [];
205
+ },
206
+ enumerable: true,
207
+ configurable: true
208
+ });
209
+ Object.defineProperty(DropDownButtonComponent.prototype, "fillMode", {
210
+ get: function () {
211
+ return this._fillMode;
212
+ },
213
+ /**
214
+ * The fillMode property specifies the background and border styles of the DropDownButton
215
+ * ([see example]({% slug api_buttons_dropdownbuttoncomponent %}#toc-fillMode)).
216
+ *
217
+ * The available values are:
218
+ * * `solid` (default)
219
+ * * `flat`
220
+ * * `outline`
221
+ * * `link`
222
+ * * `null`
223
+ */
224
+ set: function (fillMode) {
225
+ // Temporary workaround for missing 'clear' styles
226
+ this._fillMode = fillMode === 'clear' ? 'flat' : fillMode;
227
+ },
228
+ enumerable: true,
229
+ configurable: true
230
+ });
231
+ Object.defineProperty(DropDownButtonComponent.prototype, "openState", {
232
+ /**
233
+ * @hidden
234
+ */
235
+ get: function () {
236
+ return this._open;
237
+ },
238
+ /**
239
+ * @hidden
240
+ */
241
+ set: function (open) {
242
+ if (this.disabled) {
243
+ return;
244
+ }
245
+ var eventArgs = new PreventableEvent();
246
+ if (open) {
247
+ this.open.emit(eventArgs);
248
+ }
249
+ else {
250
+ this.close.emit(eventArgs);
251
+ }
252
+ if (eventArgs.isDefaultPrevented()) {
253
+ return;
254
+ }
255
+ this._toggle(open);
256
+ },
257
+ enumerable: true,
258
+ configurable: true
259
+ });
260
+ Object.defineProperty(DropDownButtonComponent.prototype, "componentTabIndex", {
261
+ /**
262
+ * @hidden
263
+ */
264
+ get: function () {
265
+ return this.disabled ? (-1) : this.tabIndex;
266
+ },
267
+ enumerable: true,
268
+ configurable: true
269
+ });
270
+ Object.defineProperty(DropDownButtonComponent.prototype, "appendTo", {
271
+ get: function () {
272
+ var appendTo = this.popupSettings.appendTo;
273
+ if (!appendTo || appendTo === 'root') {
274
+ return undefined;
275
+ }
276
+ return appendTo === 'component' ? this.container : appendTo;
277
+ },
278
+ enumerable: true,
279
+ configurable: true
280
+ });
281
+ Object.defineProperty(DropDownButtonComponent.prototype, "focused", {
282
+ get: function () {
283
+ return this._isFocused && !this._disabled;
284
+ },
285
+ enumerable: true,
286
+ configurable: true
287
+ });
288
+ Object.defineProperty(DropDownButtonComponent.prototype, "widgetClasses", {
289
+ get: function () {
290
+ return true;
291
+ },
292
+ enumerable: true,
293
+ configurable: true
294
+ });
295
+ Object.defineProperty(DropDownButtonComponent.prototype, "dir", {
296
+ get: function () {
297
+ return this.direction;
298
+ },
299
+ enumerable: true,
300
+ configurable: true
301
+ });
302
+ Object.defineProperty(DropDownButtonComponent.prototype, "active", {
303
+ /**
304
+ * @hidden
305
+ */
306
+ get: function () {
307
+ return this._active;
308
+ },
309
+ enumerable: true,
310
+ configurable: true
311
+ });
312
+ /**
313
+ * @hidden
314
+ */
315
+ DropDownButtonComponent.prototype.keydown = function (event) {
316
+ this.keyDownHandler(event);
317
+ if (event.keyCode === Keys.Space) {
318
+ this._active = true;
319
+ }
320
+ };
321
+ /**
322
+ * @hidden
323
+ */
324
+ DropDownButtonComponent.prototype.keypress = function (event) {
325
+ this.keyPressHandler(event);
326
+ };
327
+ /**
328
+ * @hidden
329
+ */
330
+ DropDownButtonComponent.prototype.keyup = function (event) {
331
+ this.keyUpHandler(event);
332
+ this._active = false;
333
+ };
334
+ /**
335
+ * @hidden
336
+ */
337
+ DropDownButtonComponent.prototype.mousedown = function (event) {
338
+ if (this._disabled) {
339
+ event.preventDefault();
340
+ }
341
+ this._active = true;
342
+ };
343
+ /**
344
+ * @hidden
345
+ */
346
+ DropDownButtonComponent.prototype.mouseup = function (event) {
347
+ if (this._disabled) {
348
+ event.preventDefault();
349
+ }
350
+ this._active = false;
351
+ };
352
+ /**
353
+ * @hidden
354
+ */
355
+ DropDownButtonComponent.prototype.openPopup = function () {
356
+ this.togglePopupVisibility();
357
+ };
358
+ /**
359
+ * @hidden
360
+ */
361
+ DropDownButtonComponent.prototype.onButtonBlur = function () {
362
+ if (!this.isOpen) {
363
+ this.blurWrapper();
364
+ }
365
+ };
366
+ Object.defineProperty(DropDownButtonComponent.prototype, "anchorAlign", {
367
+ /**
368
+ * @hidden
369
+ */
370
+ get: function () {
371
+ var align = { horizontal: this.popupSettings.align || 'left', vertical: 'bottom' };
372
+ if (this.direction === 'rtl' && !isPresent(this.popupSettings.align)) {
373
+ align.horizontal = 'right';
374
+ }
375
+ return align;
376
+ },
377
+ enumerable: true,
378
+ configurable: true
379
+ });
380
+ Object.defineProperty(DropDownButtonComponent.prototype, "popupAlign", {
381
+ /**
382
+ * @hidden
383
+ */
384
+ get: function () {
385
+ var align = { horizontal: this.popupSettings.align || 'left', vertical: 'top' };
386
+ if (this.direction === 'rtl' && !isPresent(this.popupSettings.align)) {
387
+ align.horizontal = 'right';
388
+ }
389
+ return align;
390
+ },
391
+ enumerable: true,
392
+ configurable: true
393
+ });
394
+ /**
395
+ * Focuses the DropDownButton component.
396
+ */
397
+ DropDownButtonComponent.prototype.focus = function () {
398
+ if (isDocumentAvailable()) {
399
+ this.button.nativeElement.focus();
400
+ }
401
+ };
402
+ /**
403
+ * Blurs the DropDownButton component.
404
+ */
405
+ DropDownButtonComponent.prototype.blur = function () {
406
+ if (isDocumentAvailable()) {
407
+ this.button.nativeElement.blur();
408
+ this.blurWrapper();
409
+ }
410
+ };
411
+ DropDownButtonComponent.prototype.ngOnChanges = function (changes) {
412
+ if (isChanged("popupSettings", changes) && isPresent(this.popupRef)) {
413
+ var popup = this.popupRef.popup.instance;
414
+ var newSettings = changes.popupSettings.currentValue;
415
+ popup.popupClass = newSettings.popupClass;
416
+ popup.animate = newSettings.animate;
417
+ popup.popupAlign = this.popupAlign;
418
+ }
419
+ };
420
+ DropDownButtonComponent.prototype.ngOnDestroy = function () {
421
+ _super.prototype.ngOnDestroy.call(this);
422
+ this.destroyPopup();
423
+ };
424
+ /**
425
+ * Toggles the visibility of the popup.
426
+ * If the `toggle` method is used to open or close the popup, the `open` and `close` events will not be fired.
427
+ *
428
+ * @param open - The state of the popup.
429
+ */
430
+ DropDownButtonComponent.prototype.toggle = function (open) {
431
+ var _this = this;
432
+ if (this.disabled) {
433
+ return;
434
+ }
435
+ tick(function () { return (_this._toggle((open === undefined) ? !_this._open : open)); });
436
+ };
437
+ Object.defineProperty(DropDownButtonComponent.prototype, "isOpen", {
438
+ /**
439
+ * Returns the current open state of the popup.
440
+ */
441
+ get: function () {
442
+ return this.openState;
443
+ },
444
+ enumerable: true,
445
+ configurable: true
446
+ });
447
+ /**
448
+ * @hidden
449
+ */
450
+ DropDownButtonComponent.prototype.handleFocus = function () {
451
+ if (!this._disabled && !this._isFocused) {
452
+ this._isFocused = true;
453
+ this.onFocus.emit();
454
+ }
455
+ };
456
+ /**
457
+ * @hidden
458
+ */
459
+ DropDownButtonComponent.prototype.wrapperContains = function (element) {
460
+ return this.wrapper === element
461
+ || this.wrapper.contains(element)
462
+ || (this.popupRef && this.popupRef.popupElement.contains(element));
463
+ };
464
+ DropDownButtonComponent.prototype.subscribeNavigationEvents = function () {
465
+ this.navigationSubscription = this.navigationService.navigate
466
+ .subscribe(this.onArrowKeyNavigate.bind(this));
467
+ this.enterUpSubscription = this.navigationService.enterup.subscribe(this.onNavigationEnterUp.bind(this));
468
+ this.openSubscription = this.navigationService.open.subscribe(this.onNavigationOpen.bind(this));
469
+ this.closeSubscription = merge(this.navigationService.close, this.navigationService.esc).subscribe(this.onNavigationClose.bind(this));
470
+ };
471
+ DropDownButtonComponent.prototype.onNavigationEnterUp = function () {
472
+ if (!this._disabled && !this.openState) {
473
+ this._active = false;
474
+ }
475
+ if (this.openState) {
476
+ var focused = this.focusService.focused;
477
+ if (isPresent(focused) && focused !== -1) {
478
+ this.emitItemClickHandler(focused);
479
+ }
480
+ }
481
+ this.togglePopupVisibility();
482
+ if (!this.openState && isDocumentAvailable()) {
483
+ this.button.nativeElement.focus();
484
+ }
485
+ };
486
+ DropDownButtonComponent.prototype.onNavigationOpen = function () {
487
+ if (!this._disabled && !this.openState) {
488
+ this.togglePopupVisibility();
489
+ }
490
+ };
491
+ DropDownButtonComponent.prototype.onNavigationClose = function () {
492
+ if (this.openState) {
493
+ this.togglePopupVisibility();
494
+ if (isDocumentAvailable()) {
495
+ this.button.nativeElement.focus();
496
+ }
497
+ }
498
+ };
499
+ DropDownButtonComponent.prototype.onArrowKeyNavigate = function (index) {
500
+ this.focusService.focus(index);
501
+ };
502
+ DropDownButtonComponent.prototype._toggle = function (open) {
503
+ if (this._open === open) {
504
+ return;
505
+ }
506
+ this._open = open;
507
+ this.destroyPopup();
508
+ if (this._open) {
509
+ this.createPopup();
510
+ }
511
+ };
512
+ DropDownButtonComponent.prototype.createPopup = function () {
513
+ var _this = this;
514
+ this.popupRef = this.popupService.open({
515
+ anchor: this.elRef,
516
+ anchorAlign: this.anchorAlign,
517
+ animate: this.popupSettings.animate,
518
+ appendTo: this.appendTo,
519
+ content: this.popupTemplate,
520
+ popupAlign: this.popupAlign,
521
+ popupClass: this.popupClasses
522
+ });
523
+ this.popupRef.popupAnchorViewportLeave.subscribe(function () { return _this.openState = false; });
524
+ this.popupRef.popupOpen.subscribe(this.focusFirstItem.bind(this));
525
+ };
526
+ DropDownButtonComponent.prototype.destroyPopup = function () {
527
+ if (this.popupRef) {
528
+ this.popupRef.close();
529
+ this.popupRef = null;
530
+ }
531
+ };
532
+ tslib_1.__decorate([
533
+ Input(),
534
+ tslib_1.__metadata("design:type", String)
535
+ ], DropDownButtonComponent.prototype, "icon", void 0);
536
+ tslib_1.__decorate([
537
+ Input(),
538
+ tslib_1.__metadata("design:type", String)
539
+ ], DropDownButtonComponent.prototype, "iconClass", void 0);
540
+ tslib_1.__decorate([
541
+ Input(),
542
+ tslib_1.__metadata("design:type", String)
543
+ ], DropDownButtonComponent.prototype, "imageUrl", void 0);
544
+ tslib_1.__decorate([
545
+ Input(),
546
+ tslib_1.__metadata("design:type", Object),
547
+ tslib_1.__metadata("design:paramtypes", [Object])
548
+ ], DropDownButtonComponent.prototype, "popupSettings", null);
549
+ tslib_1.__decorate([
550
+ Input(),
551
+ tslib_1.__metadata("design:type", String)
552
+ ], DropDownButtonComponent.prototype, "textField", void 0);
553
+ tslib_1.__decorate([
554
+ Input(),
555
+ tslib_1.__metadata("design:type", Boolean),
556
+ tslib_1.__metadata("design:paramtypes", [Boolean])
557
+ ], DropDownButtonComponent.prototype, "disabled", null);
558
+ tslib_1.__decorate([
559
+ Input(),
560
+ tslib_1.__metadata("design:type", Object),
561
+ tslib_1.__metadata("design:paramtypes", [Object])
562
+ ], DropDownButtonComponent.prototype, "data", null);
563
+ tslib_1.__decorate([
564
+ Input(),
565
+ tslib_1.__metadata("design:type", String)
566
+ ], DropDownButtonComponent.prototype, "size", void 0);
567
+ tslib_1.__decorate([
568
+ Input(),
569
+ tslib_1.__metadata("design:type", String)
570
+ ], DropDownButtonComponent.prototype, "shape", void 0);
571
+ tslib_1.__decorate([
572
+ Input(),
573
+ tslib_1.__metadata("design:type", String)
574
+ ], DropDownButtonComponent.prototype, "rounded", void 0);
575
+ tslib_1.__decorate([
576
+ Input(),
577
+ tslib_1.__metadata("design:type", String),
578
+ tslib_1.__metadata("design:paramtypes", [String])
579
+ ], DropDownButtonComponent.prototype, "fillMode", null);
580
+ tslib_1.__decorate([
581
+ Input(),
582
+ tslib_1.__metadata("design:type", String)
583
+ ], DropDownButtonComponent.prototype, "themeColor", void 0);
584
+ tslib_1.__decorate([
585
+ Input(),
586
+ tslib_1.__metadata("design:type", Object)
587
+ ], DropDownButtonComponent.prototype, "buttonClass", void 0);
588
+ tslib_1.__decorate([
589
+ Input(),
590
+ tslib_1.__metadata("design:type", Number)
591
+ ], DropDownButtonComponent.prototype, "tabIndex", void 0);
592
+ tslib_1.__decorate([
593
+ Output(),
594
+ tslib_1.__metadata("design:type", EventEmitter)
595
+ ], DropDownButtonComponent.prototype, "itemClick", void 0);
596
+ tslib_1.__decorate([
597
+ Output(),
598
+ tslib_1.__metadata("design:type", EventEmitter)
599
+ ], DropDownButtonComponent.prototype, "open", void 0);
600
+ tslib_1.__decorate([
601
+ Output(),
602
+ tslib_1.__metadata("design:type", EventEmitter)
603
+ ], DropDownButtonComponent.prototype, "close", void 0);
604
+ tslib_1.__decorate([
605
+ Output('focus'),
606
+ tslib_1.__metadata("design:type", EventEmitter)
607
+ ], DropDownButtonComponent.prototype, "onFocus", void 0);
608
+ tslib_1.__decorate([
609
+ Output('blur'),
610
+ tslib_1.__metadata("design:type", EventEmitter)
611
+ ], DropDownButtonComponent.prototype, "onBlur", void 0);
612
+ tslib_1.__decorate([
613
+ HostBinding('class.k-focus'),
614
+ tslib_1.__metadata("design:type", Boolean),
615
+ tslib_1.__metadata("design:paramtypes", [])
616
+ ], DropDownButtonComponent.prototype, "focused", null);
617
+ tslib_1.__decorate([
618
+ HostBinding('class.k-dropdown-button'),
619
+ tslib_1.__metadata("design:type", Boolean),
620
+ tslib_1.__metadata("design:paramtypes", [])
621
+ ], DropDownButtonComponent.prototype, "widgetClasses", null);
622
+ tslib_1.__decorate([
623
+ HostBinding('attr.dir'),
624
+ tslib_1.__metadata("design:type", String),
625
+ tslib_1.__metadata("design:paramtypes", [])
626
+ ], DropDownButtonComponent.prototype, "dir", null);
627
+ tslib_1.__decorate([
628
+ ContentChild(ButtonItemTemplateDirective, { static: false }),
629
+ tslib_1.__metadata("design:type", ButtonItemTemplateDirective)
630
+ ], DropDownButtonComponent.prototype, "itemTemplate", void 0);
631
+ tslib_1.__decorate([
632
+ ViewChild('button', { static: true }),
633
+ tslib_1.__metadata("design:type", ElementRef)
634
+ ], DropDownButtonComponent.prototype, "button", void 0);
635
+ tslib_1.__decorate([
636
+ ViewChild('buttonList', { static: false }),
637
+ tslib_1.__metadata("design:type", ListComponent)
638
+ ], DropDownButtonComponent.prototype, "buttonList", void 0);
639
+ tslib_1.__decorate([
640
+ ViewChild('popupTemplate', { static: true }),
641
+ tslib_1.__metadata("design:type", TemplateRef)
642
+ ], DropDownButtonComponent.prototype, "popupTemplate", void 0);
643
+ tslib_1.__decorate([
644
+ ViewChild('container', { read: ViewContainerRef, static: true }),
645
+ tslib_1.__metadata("design:type", ViewContainerRef)
646
+ ], DropDownButtonComponent.prototype, "container", void 0);
647
+ tslib_1.__decorate([
648
+ HostListener('keydown', ['$event']),
649
+ tslib_1.__metadata("design:type", Function),
650
+ tslib_1.__metadata("design:paramtypes", [Object]),
651
+ tslib_1.__metadata("design:returntype", void 0)
652
+ ], DropDownButtonComponent.prototype, "keydown", null);
653
+ tslib_1.__decorate([
654
+ HostListener('keypress', ['$event']),
655
+ tslib_1.__metadata("design:type", Function),
656
+ tslib_1.__metadata("design:paramtypes", [Object]),
657
+ tslib_1.__metadata("design:returntype", void 0)
658
+ ], DropDownButtonComponent.prototype, "keypress", null);
659
+ tslib_1.__decorate([
660
+ HostListener('keyup', ['$event']),
661
+ tslib_1.__metadata("design:type", Function),
662
+ tslib_1.__metadata("design:paramtypes", [Object]),
663
+ tslib_1.__metadata("design:returntype", void 0)
664
+ ], DropDownButtonComponent.prototype, "keyup", null);
665
+ tslib_1.__decorate([
666
+ HostListener('mousedown', ['$event']),
667
+ tslib_1.__metadata("design:type", Function),
668
+ tslib_1.__metadata("design:paramtypes", [Object]),
669
+ tslib_1.__metadata("design:returntype", void 0)
670
+ ], DropDownButtonComponent.prototype, "mousedown", null);
671
+ tslib_1.__decorate([
672
+ HostListener('mouseup', ['$event']),
673
+ tslib_1.__metadata("design:type", Function),
674
+ tslib_1.__metadata("design:paramtypes", [Object]),
675
+ tslib_1.__metadata("design:returntype", void 0)
676
+ ], DropDownButtonComponent.prototype, "mouseup", null);
677
+ DropDownButtonComponent = tslib_1.__decorate([
678
+ Component({
679
+ exportAs: 'kendoDropDownButton',
680
+ providers: [
681
+ FocusService,
682
+ NavigationService,
683
+ NAVIGATION_SETTINGS_PROVIDER,
684
+ LocalizationService,
685
+ {
686
+ provide: L10N_PREFIX,
687
+ useValue: 'kendo.dropdownbutton'
688
+ }
689
+ ],
690
+ selector: 'kendo-dropdownbutton',
691
+ template: "\n <button kendoButton #button\n role=\"menu\"\n type=\"button\"\n [tabindex]=\"componentTabIndex\"\n [class.k-active]=\"active\"\n [disabled]=\"disabled\"\n [icon]=\"icon\"\n [iconClass]=\"iconClass\"\n [imageUrl]=\"imageUrl\"\n [ngClass]=\"buttonClass\"\n [size]=\"size\"\n [shape]=\"shape\"\n [rounded]=\"rounded\"\n [fillMode]=\"fillMode\"\n [themeColor]=\"fillMode ? themeColor : null\"\n (click)=\"openPopup()\"\n (focus)=\"handleFocus()\"\n (blur)=\"onButtonBlur()\"\n [attr.aria-disabled]=\"disabled\"\n [attr.aria-expanded]=\"openState\"\n [attr.aria-haspopup]=\"true\"\n [attr.aria-owns]=\"listId\"\n >\n <ng-content></ng-content>\n </button>\n <ng-template #popupTemplate>\n <kendo-button-list\n #buttonList\n [id]=\"listId\"\n [data]=\"data\"\n [textField]=\"textField\"\n [itemTemplate]=\"itemTemplate\"\n (onItemClick)=\"onItemClick($event)\"\n (keydown)=\"keyDownHandler($event)\"\n (keypress)=\"keyPressHandler($event)\"\n (keyup)=\"keyUpHandler($event)\"\n [attr.dir]=\"dir\"\n [size]=\"size\"\n >\n </kendo-button-list>\n </ng-template>\n <ng-container #container></ng-container>\n "
692
+ }),
693
+ tslib_1.__metadata("design:paramtypes", [FocusService,
694
+ NavigationService,
695
+ ElementRef,
696
+ NgZone,
697
+ PopupService,
698
+ ElementRef,
699
+ LocalizationService,
700
+ ChangeDetectorRef])
701
+ ], DropDownButtonComponent);
702
+ return DropDownButtonComponent;
703
+ }(ListButton));
704
+ export { DropDownButtonComponent };
705
+ export { ɵ0 };