primeng 12.1.1 → 12.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (403) hide show
  1. package/autocomplete/autocomplete.d.ts +2 -1
  2. package/blockui/blockui.d.ts +3 -0
  3. package/breadcrumb/breadcrumb.d.ts +2 -1
  4. package/bundles/primeng-accordion.umd.js +4 -6
  5. package/bundles/primeng-accordion.umd.js.map +1 -1
  6. package/bundles/primeng-api.umd.js +5 -7
  7. package/bundles/primeng-api.umd.js.map +1 -1
  8. package/bundles/primeng-autocomplete.umd.js +9 -9
  9. package/bundles/primeng-autocomplete.umd.js.map +1 -1
  10. package/bundles/primeng-avatar.umd.js +4 -6
  11. package/bundles/primeng-avatar.umd.js.map +1 -1
  12. package/bundles/primeng-avatargroup.umd.js +4 -6
  13. package/bundles/primeng-avatargroup.umd.js.map +1 -1
  14. package/bundles/primeng-badge.umd.js +4 -6
  15. package/bundles/primeng-badge.umd.js.map +1 -1
  16. package/bundles/primeng-blockui.umd.js +30 -13
  17. package/bundles/primeng-blockui.umd.js.map +1 -1
  18. package/bundles/primeng-breadcrumb.umd.js +8 -8
  19. package/bundles/primeng-breadcrumb.umd.js.map +1 -1
  20. package/bundles/primeng-button.umd.js +11 -8
  21. package/bundles/primeng-button.umd.js.map +1 -1
  22. package/bundles/primeng-calendar.umd.js +39 -26
  23. package/bundles/primeng-calendar.umd.js.map +1 -1
  24. package/bundles/primeng-captcha.umd.js +4 -6
  25. package/bundles/primeng-captcha.umd.js.map +1 -1
  26. package/bundles/primeng-card.umd.js +4 -6
  27. package/bundles/primeng-card.umd.js.map +1 -1
  28. package/bundles/primeng-carousel.umd.js +5 -7
  29. package/bundles/primeng-carousel.umd.js.map +1 -1
  30. package/bundles/primeng-cascadeselect.umd.js +34 -15
  31. package/bundles/primeng-cascadeselect.umd.js.map +1 -1
  32. package/bundles/primeng-chart.umd.js +7 -8
  33. package/bundles/primeng-chart.umd.js.map +1 -1
  34. package/bundles/primeng-checkbox.umd.js +31 -39
  35. package/bundles/primeng-checkbox.umd.js.map +1 -1
  36. package/bundles/primeng-chip.umd.js +4 -6
  37. package/bundles/primeng-chip.umd.js.map +1 -1
  38. package/bundles/primeng-chips.umd.js +7 -8
  39. package/bundles/primeng-chips.umd.js.map +1 -1
  40. package/bundles/primeng-codehighlighter.umd.js +4 -6
  41. package/bundles/primeng-codehighlighter.umd.js.map +1 -1
  42. package/bundles/primeng-colorpicker.umd.js +4 -6
  43. package/bundles/primeng-colorpicker.umd.js.map +1 -1
  44. package/bundles/primeng-confirmdialog.umd.js +15 -14
  45. package/bundles/primeng-confirmdialog.umd.js.map +1 -1
  46. package/bundles/primeng-confirmpopup.umd.js +22 -7
  47. package/bundles/primeng-confirmpopup.umd.js.map +1 -1
  48. package/bundles/primeng-contextmenu.umd.js +5 -7
  49. package/bundles/primeng-contextmenu.umd.js.map +1 -1
  50. package/bundles/primeng-dataview.umd.js +5 -7
  51. package/bundles/primeng-dataview.umd.js.map +1 -1
  52. package/bundles/primeng-defer.umd.js +4 -6
  53. package/bundles/primeng-defer.umd.js.map +1 -1
  54. package/bundles/primeng-dialog.umd.js +14 -8
  55. package/bundles/primeng-dialog.umd.js.map +1 -1
  56. package/bundles/primeng-divider.umd.js +4 -6
  57. package/bundles/primeng-divider.umd.js.map +1 -1
  58. package/bundles/primeng-dock.umd.js +6 -8
  59. package/bundles/primeng-dock.umd.js.map +1 -1
  60. package/bundles/primeng-dom.umd.js +7 -4
  61. package/bundles/primeng-dom.umd.js.map +1 -1
  62. package/bundles/primeng-dragdrop.umd.js +4 -6
  63. package/bundles/primeng-dragdrop.umd.js.map +1 -1
  64. package/bundles/primeng-dropdown.umd.js +25 -20
  65. package/bundles/primeng-dropdown.umd.js.map +1 -1
  66. package/bundles/primeng-dynamicdialog.umd.js +10 -9
  67. package/bundles/primeng-dynamicdialog.umd.js.map +1 -1
  68. package/bundles/primeng-editor.umd.js +6 -8
  69. package/bundles/primeng-editor.umd.js.map +1 -1
  70. package/bundles/primeng-fieldset.umd.js +4 -6
  71. package/bundles/primeng-fieldset.umd.js.map +1 -1
  72. package/bundles/primeng-fileupload.umd.js +5 -7
  73. package/bundles/primeng-fileupload.umd.js.map +1 -1
  74. package/bundles/primeng-focustrap.umd.js +4 -6
  75. package/bundles/primeng-focustrap.umd.js.map +1 -1
  76. package/bundles/primeng-fullcalendar.umd.js +4 -6
  77. package/bundles/primeng-fullcalendar.umd.js.map +1 -1
  78. package/bundles/primeng-galleria.umd.js +74 -28
  79. package/bundles/primeng-galleria.umd.js.map +1 -1
  80. package/bundles/primeng-gmap.umd.js +5 -7
  81. package/bundles/primeng-gmap.umd.js.map +1 -1
  82. package/bundles/primeng-image.umd.js +241 -0
  83. package/bundles/primeng-image.umd.js.map +1 -0
  84. package/bundles/primeng-inplace.umd.js +4 -6
  85. package/bundles/primeng-inplace.umd.js.map +1 -1
  86. package/bundles/primeng-inputmask.umd.js +4 -6
  87. package/bundles/primeng-inputmask.umd.js.map +1 -1
  88. package/bundles/primeng-inputnumber.umd.js +5 -7
  89. package/bundles/primeng-inputnumber.umd.js.map +1 -1
  90. package/bundles/primeng-inputswitch.umd.js +22 -15
  91. package/bundles/primeng-inputswitch.umd.js.map +1 -1
  92. package/bundles/primeng-inputtext.umd.js +12 -9
  93. package/bundles/primeng-inputtext.umd.js.map +1 -1
  94. package/bundles/primeng-inputtextarea.umd.js +4 -6
  95. package/bundles/primeng-inputtextarea.umd.js.map +1 -1
  96. package/bundles/primeng-keyfilter.umd.js +5 -7
  97. package/bundles/primeng-keyfilter.umd.js.map +1 -1
  98. package/bundles/primeng-knob.umd.js +4 -6
  99. package/bundles/primeng-knob.umd.js.map +1 -1
  100. package/bundles/primeng-lightbox.umd.js +5 -7
  101. package/bundles/primeng-lightbox.umd.js.map +1 -1
  102. package/bundles/primeng-listbox.umd.js +7 -9
  103. package/bundles/primeng-listbox.umd.js.map +1 -1
  104. package/bundles/primeng-megamenu.umd.js +4 -6
  105. package/bundles/primeng-megamenu.umd.js.map +1 -1
  106. package/bundles/primeng-menu.umd.js +51 -11
  107. package/bundles/primeng-menu.umd.js.map +1 -1
  108. package/bundles/primeng-menubar.umd.js +4 -6
  109. package/bundles/primeng-menubar.umd.js.map +1 -1
  110. package/bundles/primeng-message.umd.js +4 -6
  111. package/bundles/primeng-message.umd.js.map +1 -1
  112. package/bundles/primeng-messages.umd.js +5 -7
  113. package/bundles/primeng-messages.umd.js.map +1 -1
  114. package/bundles/primeng-multiselect.umd.js +11 -10
  115. package/bundles/primeng-multiselect.umd.js.map +1 -1
  116. package/bundles/primeng-orderlist.umd.js +5 -7
  117. package/bundles/primeng-orderlist.umd.js.map +1 -1
  118. package/bundles/primeng-organizationchart.umd.js +5 -7
  119. package/bundles/primeng-organizationchart.umd.js.map +1 -1
  120. package/bundles/primeng-overlaypanel.umd.js +9 -8
  121. package/bundles/primeng-overlaypanel.umd.js.map +1 -1
  122. package/bundles/primeng-paginator.umd.js +28 -21
  123. package/bundles/primeng-paginator.umd.js.map +1 -1
  124. package/bundles/primeng-panel.umd.js +4 -6
  125. package/bundles/primeng-panel.umd.js.map +1 -1
  126. package/bundles/primeng-panelmenu.umd.js +42 -14
  127. package/bundles/primeng-panelmenu.umd.js.map +1 -1
  128. package/bundles/primeng-password.umd.js +16 -10
  129. package/bundles/primeng-password.umd.js.map +1 -1
  130. package/bundles/primeng-picklist.umd.js +22 -8
  131. package/bundles/primeng-picklist.umd.js.map +1 -1
  132. package/bundles/primeng-progressbar.umd.js +4 -6
  133. package/bundles/primeng-progressbar.umd.js.map +1 -1
  134. package/bundles/primeng-progressspinner.umd.js +4 -6
  135. package/bundles/primeng-progressspinner.umd.js.map +1 -1
  136. package/bundles/primeng-radiobutton.umd.js +4 -6
  137. package/bundles/primeng-radiobutton.umd.js.map +1 -1
  138. package/bundles/primeng-rating.umd.js +4 -6
  139. package/bundles/primeng-rating.umd.js.map +1 -1
  140. package/bundles/primeng-ripple.umd.js +4 -6
  141. package/bundles/primeng-ripple.umd.js.map +1 -1
  142. package/bundles/primeng-scrollpanel.umd.js +4 -6
  143. package/bundles/primeng-scrollpanel.umd.js.map +1 -1
  144. package/bundles/primeng-scrolltop.umd.js +4 -6
  145. package/bundles/primeng-scrolltop.umd.js.map +1 -1
  146. package/bundles/primeng-selectbutton.umd.js +5 -7
  147. package/bundles/primeng-selectbutton.umd.js.map +1 -1
  148. package/bundles/primeng-sidebar.umd.js +28 -19
  149. package/bundles/primeng-sidebar.umd.js.map +1 -1
  150. package/bundles/primeng-skeleton.umd.js +4 -6
  151. package/bundles/primeng-skeleton.umd.js.map +1 -1
  152. package/bundles/primeng-slidemenu.umd.js +63 -10
  153. package/bundles/primeng-slidemenu.umd.js.map +1 -1
  154. package/bundles/primeng-slider.umd.js +4 -6
  155. package/bundles/primeng-slider.umd.js.map +1 -1
  156. package/bundles/primeng-speeddial.umd.js +4 -6
  157. package/bundles/primeng-speeddial.umd.js.map +1 -1
  158. package/bundles/primeng-spinner.umd.js +4 -6
  159. package/bundles/primeng-spinner.umd.js.map +1 -1
  160. package/bundles/primeng-splitbutton.umd.js +4 -6
  161. package/bundles/primeng-splitbutton.umd.js.map +1 -1
  162. package/bundles/primeng-splitter.umd.js +5 -7
  163. package/bundles/primeng-splitter.umd.js.map +1 -1
  164. package/bundles/primeng-steps.umd.js +4 -6
  165. package/bundles/primeng-steps.umd.js.map +1 -1
  166. package/bundles/primeng-styleclass.umd.js +4 -6
  167. package/bundles/primeng-styleclass.umd.js.map +1 -1
  168. package/bundles/primeng-table.umd.js +75 -64
  169. package/bundles/primeng-table.umd.js.map +1 -1
  170. package/bundles/primeng-tabmenu.umd.js +5 -7
  171. package/bundles/primeng-tabmenu.umd.js.map +1 -1
  172. package/bundles/primeng-tabview.umd.js +4 -6
  173. package/bundles/primeng-tabview.umd.js.map +1 -1
  174. package/bundles/primeng-tag.umd.js +4 -6
  175. package/bundles/primeng-tag.umd.js.map +1 -1
  176. package/bundles/primeng-terminal.umd.js +4 -6
  177. package/bundles/primeng-terminal.umd.js.map +1 -1
  178. package/bundles/primeng-tieredmenu.umd.js +4 -6
  179. package/bundles/primeng-tieredmenu.umd.js.map +1 -1
  180. package/bundles/primeng-timeline.umd.js +4 -6
  181. package/bundles/primeng-timeline.umd.js.map +1 -1
  182. package/bundles/primeng-toast.umd.js +5 -7
  183. package/bundles/primeng-toast.umd.js.map +1 -1
  184. package/bundles/primeng-togglebutton.umd.js +4 -6
  185. package/bundles/primeng-togglebutton.umd.js.map +1 -1
  186. package/bundles/primeng-toolbar.umd.js +4 -6
  187. package/bundles/primeng-toolbar.umd.js.map +1 -1
  188. package/bundles/primeng-tooltip.umd.js +5 -7
  189. package/bundles/primeng-tooltip.umd.js.map +1 -1
  190. package/bundles/primeng-tree.umd.js +10 -10
  191. package/bundles/primeng-tree.umd.js.map +1 -1
  192. package/bundles/primeng-treeselect.umd.js +13 -8
  193. package/bundles/primeng-treeselect.umd.js.map +1 -1
  194. package/bundles/primeng-treetable.umd.js +6 -8
  195. package/bundles/primeng-treetable.umd.js.map +1 -1
  196. package/bundles/primeng-tristatecheckbox.umd.js +4 -6
  197. package/bundles/primeng-tristatecheckbox.umd.js.map +1 -1
  198. package/bundles/primeng-utils.umd.js +340 -2
  199. package/bundles/primeng-utils.umd.js.map +1 -1
  200. package/bundles/primeng-virtualscroller.umd.js +4 -6
  201. package/bundles/primeng-virtualscroller.umd.js.map +1 -1
  202. package/bundles/primeng.umd.js +2 -2
  203. package/calendar/calendar.d.ts +5 -1
  204. package/cascadeselect/cascadeselect.d.ts +2 -1
  205. package/checkbox/checkbox.d.ts +4 -5
  206. package/confirmpopup/confirmpopup.d.ts +3 -1
  207. package/dialog/dialog.d.ts +2 -1
  208. package/dom/domhandler.d.ts +1 -0
  209. package/dropdown/dropdown.d.ts +3 -1
  210. package/esm2015/autocomplete/autocomplete.js +6 -4
  211. package/esm2015/blockui/blockui.js +25 -5
  212. package/esm2015/breadcrumb/breadcrumb.js +9 -7
  213. package/esm2015/button/button.js +8 -3
  214. package/esm2015/calendar/calendar.js +36 -21
  215. package/esm2015/cascadeselect/cascadeselect.js +29 -10
  216. package/esm2015/chart/chart.js +3 -2
  217. package/esm2015/checkbox/checkbox.js +36 -41
  218. package/esm2015/chips/chips.js +3 -2
  219. package/esm2015/confirmdialog/confirmdialog.js +13 -10
  220. package/esm2015/confirmpopup/confirmpopup.js +19 -2
  221. package/esm2015/dataview/dataview.js +1 -1
  222. package/esm2015/dialog/dialog.js +15 -7
  223. package/esm2015/dock/dock.js +40 -36
  224. package/esm2015/dom/domhandler.js +5 -2
  225. package/esm2015/dropdown/dropdown.js +22 -15
  226. package/esm2015/dynamicdialog/dynamicdialog.js +8 -5
  227. package/esm2015/editor/editor.js +7 -7
  228. package/esm2015/galleria/galleria.js +74 -23
  229. package/esm2015/image/image.js +276 -0
  230. package/esm2015/image/primeng-image.js +5 -0
  231. package/esm2015/image/public_api.js +2 -0
  232. package/esm2015/inputswitch/inputswitch.js +24 -15
  233. package/esm2015/inputtext/inputtext.js +9 -4
  234. package/esm2015/lightbox/lightbox.js +1 -1
  235. package/esm2015/listbox/listbox.js +3 -3
  236. package/esm2015/menu/menu.js +61 -19
  237. package/esm2015/multiselect/multiselect.js +7 -4
  238. package/esm2015/overlaypanel/overlaypanel.js +6 -3
  239. package/esm2015/paginator/paginator.js +45 -33
  240. package/esm2015/panelmenu/panelmenu.js +49 -18
  241. package/esm2015/password/password.js +17 -9
  242. package/esm2015/picklist/picklist.js +42 -26
  243. package/esm2015/sidebar/sidebar.js +25 -14
  244. package/esm2015/slidemenu/slidemenu.js +68 -18
  245. package/esm2015/table/table.js +82 -68
  246. package/esm2015/tabmenu/tabmenu.js +1 -1
  247. package/esm2015/tooltip/tooltip.js +2 -2
  248. package/esm2015/tree/tree.js +8 -6
  249. package/esm2015/treeselect/treeselect.js +9 -2
  250. package/esm2015/treetable/treetable.js +2 -2
  251. package/esm2015/utils/objectutils.js +10 -1
  252. package/fesm2015/primeng-autocomplete.js +5 -3
  253. package/fesm2015/primeng-autocomplete.js.map +1 -1
  254. package/fesm2015/primeng-blockui.js +24 -4
  255. package/fesm2015/primeng-blockui.js.map +1 -1
  256. package/fesm2015/primeng-breadcrumb.js +8 -6
  257. package/fesm2015/primeng-breadcrumb.js.map +1 -1
  258. package/fesm2015/primeng-button.js +7 -2
  259. package/fesm2015/primeng-button.js.map +1 -1
  260. package/fesm2015/primeng-calendar.js +35 -20
  261. package/fesm2015/primeng-calendar.js.map +1 -1
  262. package/fesm2015/primeng-cascadeselect.js +28 -9
  263. package/fesm2015/primeng-cascadeselect.js.map +1 -1
  264. package/fesm2015/primeng-chart.js +2 -1
  265. package/fesm2015/primeng-chart.js.map +1 -1
  266. package/fesm2015/primeng-checkbox.js +35 -40
  267. package/fesm2015/primeng-checkbox.js.map +1 -1
  268. package/fesm2015/primeng-chips.js +2 -1
  269. package/fesm2015/primeng-chips.js.map +1 -1
  270. package/fesm2015/primeng-confirmdialog.js +12 -9
  271. package/fesm2015/primeng-confirmdialog.js.map +1 -1
  272. package/fesm2015/primeng-confirmpopup.js +18 -1
  273. package/fesm2015/primeng-confirmpopup.js.map +1 -1
  274. package/fesm2015/primeng-dataview.js +1 -1
  275. package/fesm2015/primeng-dialog.js +14 -6
  276. package/fesm2015/primeng-dialog.js.map +1 -1
  277. package/fesm2015/primeng-dock.js +39 -35
  278. package/fesm2015/primeng-dock.js.map +1 -1
  279. package/fesm2015/primeng-dom.js +4 -1
  280. package/fesm2015/primeng-dom.js.map +1 -1
  281. package/fesm2015/primeng-dropdown.js +21 -14
  282. package/fesm2015/primeng-dropdown.js.map +1 -1
  283. package/fesm2015/primeng-dynamicdialog.js +7 -4
  284. package/fesm2015/primeng-dynamicdialog.js.map +1 -1
  285. package/fesm2015/primeng-editor.js +6 -6
  286. package/fesm2015/primeng-editor.js.map +1 -1
  287. package/fesm2015/primeng-galleria.js +73 -22
  288. package/fesm2015/primeng-galleria.js.map +1 -1
  289. package/fesm2015/primeng-image.js +283 -0
  290. package/fesm2015/primeng-image.js.map +1 -0
  291. package/fesm2015/primeng-inputswitch.js +23 -14
  292. package/fesm2015/primeng-inputswitch.js.map +1 -1
  293. package/fesm2015/primeng-inputtext.js +8 -3
  294. package/fesm2015/primeng-inputtext.js.map +1 -1
  295. package/fesm2015/primeng-lightbox.js +1 -1
  296. package/fesm2015/primeng-listbox.js +2 -2
  297. package/fesm2015/primeng-listbox.js.map +1 -1
  298. package/fesm2015/primeng-menu.js +60 -18
  299. package/fesm2015/primeng-menu.js.map +1 -1
  300. package/fesm2015/primeng-multiselect.js +6 -3
  301. package/fesm2015/primeng-multiselect.js.map +1 -1
  302. package/fesm2015/primeng-overlaypanel.js +5 -2
  303. package/fesm2015/primeng-overlaypanel.js.map +1 -1
  304. package/fesm2015/primeng-paginator.js +44 -32
  305. package/fesm2015/primeng-paginator.js.map +1 -1
  306. package/fesm2015/primeng-panelmenu.js +48 -17
  307. package/fesm2015/primeng-panelmenu.js.map +1 -1
  308. package/fesm2015/primeng-password.js +16 -8
  309. package/fesm2015/primeng-password.js.map +1 -1
  310. package/fesm2015/primeng-picklist.js +41 -25
  311. package/fesm2015/primeng-picklist.js.map +1 -1
  312. package/fesm2015/primeng-sidebar.js +24 -13
  313. package/fesm2015/primeng-sidebar.js.map +1 -1
  314. package/fesm2015/primeng-slidemenu.js +68 -18
  315. package/fesm2015/primeng-slidemenu.js.map +1 -1
  316. package/fesm2015/primeng-table.js +81 -67
  317. package/fesm2015/primeng-table.js.map +1 -1
  318. package/fesm2015/primeng-tabmenu.js +1 -1
  319. package/fesm2015/primeng-tooltip.js +1 -1
  320. package/fesm2015/primeng-tooltip.js.map +1 -1
  321. package/fesm2015/primeng-tree.js +7 -5
  322. package/fesm2015/primeng-tree.js.map +1 -1
  323. package/fesm2015/primeng-treeselect.js +8 -1
  324. package/fesm2015/primeng-treeselect.js.map +1 -1
  325. package/fesm2015/primeng-treetable.js +1 -1
  326. package/fesm2015/primeng-treetable.js.map +1 -1
  327. package/fesm2015/primeng-utils.js +9 -0
  328. package/fesm2015/primeng-utils.js.map +1 -1
  329. package/galleria/galleria.d.ts +9 -1
  330. package/image/image.d.ts +62 -0
  331. package/image/package.json +10 -0
  332. package/image/primeng-image.d.ts +5 -0
  333. package/image/public_api.d.ts +1 -0
  334. package/inputswitch/inputswitch.d.ts +6 -3
  335. package/inputtext/inputtext.d.ts +6 -4
  336. package/menu/menu.d.ts +3 -0
  337. package/overlaypanel/overlaypanel.d.ts +1 -0
  338. package/package.json +1 -1
  339. package/paginator/paginator.d.ts +9 -5
  340. package/panelmenu/panelmenu.d.ts +4 -1
  341. package/password/password.d.ts +6 -4
  342. package/picklist/picklist.d.ts +9 -1
  343. package/resources/components/breadcrumb/breadcrumb.css +4 -0
  344. package/resources/components/checkbox/checkbox.css +2 -1
  345. package/resources/components/dialog/dialog.css +0 -7
  346. package/resources/components/dock/dock.css +5 -1
  347. package/resources/components/image/image.css +55 -0
  348. package/resources/components/radiobutton/radiobutton.css +2 -1
  349. package/resources/components/sidebar/sidebar.css +1 -10
  350. package/resources/components/table/table.css +1 -5
  351. package/resources/components/tabmenu/tabmenu.css +4 -0
  352. package/resources/components/tooltip/tooltip.css +2 -1
  353. package/resources/primeng.css +6 -1
  354. package/resources/primeng.min.css +1 -1
  355. package/resources/themes/arya-blue/theme.css +99 -17
  356. package/resources/themes/arya-green/theme.css +99 -17
  357. package/resources/themes/arya-orange/theme.css +99 -17
  358. package/resources/themes/arya-purple/theme.css +99 -17
  359. package/resources/themes/bootstrap4-dark-blue/theme.css +99 -17
  360. package/resources/themes/bootstrap4-dark-purple/theme.css +99 -17
  361. package/resources/themes/bootstrap4-light-blue/theme.css +99 -17
  362. package/resources/themes/bootstrap4-light-purple/theme.css +99 -17
  363. package/resources/themes/fluent-light/theme.css +99 -17
  364. package/resources/themes/luna-amber/theme.css +99 -17
  365. package/resources/themes/luna-blue/theme.css +99 -17
  366. package/resources/themes/luna-green/theme.css +99 -17
  367. package/resources/themes/luna-pink/theme.css +99 -17
  368. package/resources/themes/md-dark-deeppurple/theme.css +287 -46
  369. package/resources/themes/md-dark-indigo/theme.css +287 -46
  370. package/resources/themes/md-light-deeppurple/theme.css +287 -46
  371. package/resources/themes/md-light-indigo/theme.css +287 -46
  372. package/resources/themes/mdc-dark-deeppurple/theme.css +287 -46
  373. package/resources/themes/mdc-dark-indigo/theme.css +287 -46
  374. package/resources/themes/mdc-light-deeppurple/theme.css +287 -46
  375. package/resources/themes/mdc-light-indigo/theme.css +287 -46
  376. package/resources/themes/nova/theme.css +99 -17
  377. package/resources/themes/nova-accent/theme.css +99 -17
  378. package/resources/themes/nova-alt/theme.css +99 -17
  379. package/resources/themes/rhea/theme.css +99 -17
  380. package/resources/themes/saga-blue/theme.css +99 -17
  381. package/resources/themes/saga-green/theme.css +99 -17
  382. package/resources/themes/saga-orange/theme.css +99 -17
  383. package/resources/themes/saga-purple/theme.css +99 -17
  384. package/resources/themes/tailwind-light/fonts/Inter-Bold.woff +0 -0
  385. package/resources/themes/tailwind-light/fonts/Inter-Bold.woff2 +0 -0
  386. package/resources/themes/tailwind-light/fonts/Inter-Light.woff +0 -0
  387. package/resources/themes/tailwind-light/fonts/Inter-Light.woff2 +0 -0
  388. package/resources/themes/tailwind-light/fonts/Inter-Medium.woff +0 -0
  389. package/resources/themes/tailwind-light/fonts/Inter-Medium.woff2 +0 -0
  390. package/resources/themes/tailwind-light/fonts/Inter-Regular.woff +0 -0
  391. package/resources/themes/tailwind-light/fonts/Inter-Regular.woff2 +0 -0
  392. package/resources/themes/tailwind-light/fonts/Inter-SemiBold.woff +0 -0
  393. package/resources/themes/tailwind-light/fonts/Inter-SemiBold.woff2 +0 -0
  394. package/resources/themes/tailwind-light/theme.css +5743 -0
  395. package/resources/themes/vela-blue/theme.css +99 -17
  396. package/resources/themes/vela-green/theme.css +99 -17
  397. package/resources/themes/vela-orange/theme.css +99 -17
  398. package/resources/themes/vela-purple/theme.css +99 -17
  399. package/sidebar/sidebar.d.ts +3 -0
  400. package/slidemenu/slidemenu.d.ts +7 -0
  401. package/table/table.d.ts +8 -3
  402. package/tree/tree.d.ts +2 -1
  403. package/utils/objectutils.d.ts +1 -0
@@ -1,15 +1,17 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { EventEmitter, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, Output, NgModule } from '@angular/core';
3
- import * as i2 from '@angular/common';
3
+ import * as i3 from '@angular/common';
4
4
  import { CommonModule } from '@angular/common';
5
- import * as i4 from '@angular/forms';
5
+ import * as i5 from '@angular/forms';
6
6
  import { FormsModule } from '@angular/forms';
7
7
  import * as i1 from 'primeng/dropdown';
8
8
  import { DropdownModule } from 'primeng/dropdown';
9
- import * as i3 from 'primeng/ripple';
9
+ import * as i4 from 'primeng/ripple';
10
10
  import { RippleModule } from 'primeng/ripple';
11
- import * as i5 from 'primeng/api';
11
+ import * as i6 from 'primeng/api';
12
12
  import { SharedModule } from 'primeng/api';
13
+ import * as i2 from 'primeng/inputnumber';
14
+ import { InputNumberModule } from 'primeng/inputnumber';
13
15
 
14
16
  class Paginator {
15
17
  constructor(cd) {
@@ -75,7 +77,7 @@ class Paginator {
75
77
  return this.getPage() === this.getPageCount() - 1;
76
78
  }
77
79
  getPageCount() {
78
- return Math.ceil(this.totalRecords / this.rows) || 1;
80
+ return Math.ceil(this.totalRecords / this.rows);
79
81
  }
80
82
  calculatePageLinkBoundaries() {
81
83
  let numberOfPages = this.getPageCount(), visiblePages = Math.min(this.pageLinkSize, numberOfPages);
@@ -162,9 +164,15 @@ class Paginator {
162
164
  totalRecords: this.totalRecords
163
165
  };
164
166
  }
167
+ empty() {
168
+ return this.getPageCount() === 0;
169
+ }
170
+ currentPage() {
171
+ return this.getPageCount() > 0 ? this.getPage() + 1 : 0;
172
+ }
165
173
  get currentPageReport() {
166
174
  return this.currentPageReportTemplate
167
- .replace("{currentPage}", String(this.getPage() + 1))
175
+ .replace("{currentPage}", String(this.currentPage()))
168
176
  .replace("{totalPages}", String(this.getPageCount()))
169
177
  .replace("{first}", String((this.totalRecords > 0) ? this._first + 1 : 0))
170
178
  .replace("{last}", String(Math.min(this._first + this.rows, this.totalRecords)))
@@ -173,37 +181,38 @@ class Paginator {
173
181
  }
174
182
  }
175
183
  Paginator.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: Paginator, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
176
- Paginator.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: Paginator, selector: "p-paginator", inputs: { pageLinkSize: "pageLinkSize", style: "style", styleClass: "styleClass", alwaysShow: "alwaysShow", templateLeft: "templateLeft", templateRight: "templateRight", dropdownAppendTo: "dropdownAppendTo", dropdownScrollHeight: "dropdownScrollHeight", currentPageReportTemplate: "currentPageReportTemplate", showCurrentPageReport: "showCurrentPageReport", showFirstLastIcon: "showFirstLastIcon", totalRecords: "totalRecords", rows: "rows", rowsPerPageOptions: "rowsPerPageOptions", showJumpToPageDropdown: "showJumpToPageDropdown", showPageLinks: "showPageLinks", dropdownItemTemplate: "dropdownItemTemplate", first: "first" }, outputs: { onPageChange: "onPageChange" }, host: { classAttribute: "p-element" }, usesOnChanges: true, ngImport: i0, template: `
184
+ Paginator.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: Paginator, selector: "p-paginator", inputs: { pageLinkSize: "pageLinkSize", style: "style", styleClass: "styleClass", alwaysShow: "alwaysShow", templateLeft: "templateLeft", templateRight: "templateRight", dropdownAppendTo: "dropdownAppendTo", dropdownScrollHeight: "dropdownScrollHeight", currentPageReportTemplate: "currentPageReportTemplate", showCurrentPageReport: "showCurrentPageReport", showFirstLastIcon: "showFirstLastIcon", totalRecords: "totalRecords", rows: "rows", rowsPerPageOptions: "rowsPerPageOptions", showJumpToPageDropdown: "showJumpToPageDropdown", showJumpToPageInput: "showJumpToPageInput", showPageLinks: "showPageLinks", dropdownItemTemplate: "dropdownItemTemplate", first: "first" }, outputs: { onPageChange: "onPageChange" }, host: { classAttribute: "p-element" }, usesOnChanges: true, ngImport: i0, template: `
177
185
  <div [class]="styleClass" [ngStyle]="style" [ngClass]="'p-paginator p-component'" *ngIf="alwaysShow ? true : (pageLinks && pageLinks.length > 1)">
178
186
  <div class="p-paginator-left-content" *ngIf="templateLeft">
179
187
  <ng-container *ngTemplateOutlet="templateLeft; context: {$implicit: paginatorState}"></ng-container>
180
188
  </div>
181
189
  <span class="p-paginator-current" *ngIf="showCurrentPageReport">{{currentPageReport}}</span>
182
- <button *ngIf="showFirstLastIcon" type="button" [disabled]="isFirstPage()" (click)="changePageToFirst($event)" pRipple
183
- class="p-paginator-first p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage()}">
190
+ <button *ngIf="showFirstLastIcon" type="button" [disabled]="isFirstPage() || empty()" (click)="changePageToFirst($event)" pRipple
191
+ class="p-paginator-first p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage() || empty()}">
184
192
  <span class="p-paginator-icon pi pi-angle-double-left"></span>
185
193
  </button>
186
- <button type="button" [disabled]="isFirstPage()" (click)="changePageToPrev($event)" pRipple
187
- class="p-paginator-prev p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage()}">
194
+ <button type="button" [disabled]="isFirstPage() || empty()" (click)="changePageToPrev($event)" pRipple
195
+ class="p-paginator-prev p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage() || empty()}">
188
196
  <span class="p-paginator-icon pi pi-angle-left"></span>
189
197
  </button>
190
198
  <span class="p-paginator-pages" *ngIf="showPageLinks">
191
199
  <button type="button" *ngFor="let pageLink of pageLinks" class="p-paginator-page p-paginator-element p-link" [ngClass]="{'p-highlight': (pageLink-1 == getPage())}"
192
200
  (click)="onPageLinkClick($event, pageLink - 1)" pRipple>{{pageLink}}</button>
193
201
  </span>
194
- <p-dropdown [options]="pageItems" [ngModel]="getPage()" *ngIf="showJumpToPageDropdown" styleClass="p-paginator-page-options"
202
+ <p-dropdown [options]="pageItems" [ngModel]="getPage()" *ngIf="showJumpToPageDropdown" [disabled]="empty()" styleClass="p-paginator-page-options"
195
203
  (onChange)="onPageDropdownChange($event)" [appendTo]="dropdownAppendTo" [scrollHeight]="dropdownScrollHeight">
196
204
  <ng-template pTemplate="selectedItem">{{currentPageReport}}</ng-template>
197
205
  </p-dropdown>
198
- <button type="button" [disabled]="isLastPage()" (click)="changePageToNext($event)" pRipple
199
- class="p-paginator-next p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage()}">
206
+ <button type="button" [disabled]="isLastPage() || empty()" (click)="changePageToNext($event)" pRipple
207
+ class="p-paginator-next p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage() || empty()}">
200
208
  <span class="p-paginator-icon pi pi-angle-right"></span>
201
209
  </button>
202
- <button *ngIf="showFirstLastIcon" type="button" [disabled]="isLastPage()" (click)="changePageToLast($event)" pRipple
203
- class="p-paginator-last p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage()}">
210
+ <button *ngIf="showFirstLastIcon" type="button" [disabled]="isLastPage() || empty()" (click)="changePageToLast($event)" pRipple
211
+ class="p-paginator-last p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage() || empty()}">
204
212
  <span class="p-paginator-icon pi pi-angle-double-right"></span>
205
213
  </button>
206
- <p-dropdown [options]="rowsPerPageItems" [(ngModel)]="rows" *ngIf="rowsPerPageOptions" styleClass="p-paginator-rpp-options"
214
+ <p-inputNumber *ngIf="showJumpToPageInput" [ngModel]="currentPage()" class="p-paginator-page-input" [disabled]="empty()" (ngModelChange)="changePage($event - 1)"></p-inputNumber>
215
+ <p-dropdown [options]="rowsPerPageItems" [(ngModel)]="rows" *ngIf="rowsPerPageOptions" styleClass="p-paginator-rpp-options" [disabled]="empty()"
207
216
  (onChange)="onRppChange($event)" [appendTo]="dropdownAppendTo" [scrollHeight]="dropdownScrollHeight">
208
217
  <ng-container *ngIf="dropdownItemTemplate">
209
218
  <ng-template let-item pTemplate="item">
@@ -216,7 +225,7 @@ Paginator.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12
216
225
  <ng-container *ngTemplateOutlet="templateRight; context: {$implicit: paginatorState}"></ng-container>
217
226
  </div>
218
227
  </div>
219
- `, isInline: true, styles: [".p-paginator{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}.p-paginator-left-content{margin-right:auto}.p-paginator-right-content{margin-left:auto}.p-paginator-current,.p-paginator-first,.p-paginator-last,.p-paginator-next,.p-paginator-page,.p-paginator-prev{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;-webkit-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;position:relative}.p-paginator-element:focus{z-index:1;position:relative}"], components: [{ type: i1.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.Ripple, selector: "[pRipple]" }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
228
+ `, isInline: true, styles: [".p-paginator{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}.p-paginator-left-content{margin-right:auto}.p-paginator-right-content{margin-left:auto}.p-paginator-current,.p-paginator-first,.p-paginator-last,.p-paginator-next,.p-paginator-page,.p-paginator-prev{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:1;-webkit-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;position:relative}.p-paginator-element:focus{z-index:1;position:relative}"], components: [{ type: i1.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }, { type: i2.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.Ripple, selector: "[pRipple]" }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
220
229
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: Paginator, decorators: [{
221
230
  type: Component,
222
231
  args: [{
@@ -227,31 +236,32 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
227
236
  <ng-container *ngTemplateOutlet="templateLeft; context: {$implicit: paginatorState}"></ng-container>
228
237
  </div>
229
238
  <span class="p-paginator-current" *ngIf="showCurrentPageReport">{{currentPageReport}}</span>
230
- <button *ngIf="showFirstLastIcon" type="button" [disabled]="isFirstPage()" (click)="changePageToFirst($event)" pRipple
231
- class="p-paginator-first p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage()}">
239
+ <button *ngIf="showFirstLastIcon" type="button" [disabled]="isFirstPage() || empty()" (click)="changePageToFirst($event)" pRipple
240
+ class="p-paginator-first p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage() || empty()}">
232
241
  <span class="p-paginator-icon pi pi-angle-double-left"></span>
233
242
  </button>
234
- <button type="button" [disabled]="isFirstPage()" (click)="changePageToPrev($event)" pRipple
235
- class="p-paginator-prev p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage()}">
243
+ <button type="button" [disabled]="isFirstPage() || empty()" (click)="changePageToPrev($event)" pRipple
244
+ class="p-paginator-prev p-paginator-element p-link" [ngClass]="{'p-disabled':isFirstPage() || empty()}">
236
245
  <span class="p-paginator-icon pi pi-angle-left"></span>
237
246
  </button>
238
247
  <span class="p-paginator-pages" *ngIf="showPageLinks">
239
248
  <button type="button" *ngFor="let pageLink of pageLinks" class="p-paginator-page p-paginator-element p-link" [ngClass]="{'p-highlight': (pageLink-1 == getPage())}"
240
249
  (click)="onPageLinkClick($event, pageLink - 1)" pRipple>{{pageLink}}</button>
241
250
  </span>
242
- <p-dropdown [options]="pageItems" [ngModel]="getPage()" *ngIf="showJumpToPageDropdown" styleClass="p-paginator-page-options"
251
+ <p-dropdown [options]="pageItems" [ngModel]="getPage()" *ngIf="showJumpToPageDropdown" [disabled]="empty()" styleClass="p-paginator-page-options"
243
252
  (onChange)="onPageDropdownChange($event)" [appendTo]="dropdownAppendTo" [scrollHeight]="dropdownScrollHeight">
244
253
  <ng-template pTemplate="selectedItem">{{currentPageReport}}</ng-template>
245
254
  </p-dropdown>
246
- <button type="button" [disabled]="isLastPage()" (click)="changePageToNext($event)" pRipple
247
- class="p-paginator-next p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage()}">
255
+ <button type="button" [disabled]="isLastPage() || empty()" (click)="changePageToNext($event)" pRipple
256
+ class="p-paginator-next p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage() || empty()}">
248
257
  <span class="p-paginator-icon pi pi-angle-right"></span>
249
258
  </button>
250
- <button *ngIf="showFirstLastIcon" type="button" [disabled]="isLastPage()" (click)="changePageToLast($event)" pRipple
251
- class="p-paginator-last p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage()}">
259
+ <button *ngIf="showFirstLastIcon" type="button" [disabled]="isLastPage() || empty()" (click)="changePageToLast($event)" pRipple
260
+ class="p-paginator-last p-paginator-element p-link" [ngClass]="{'p-disabled':isLastPage() || empty()}">
252
261
  <span class="p-paginator-icon pi pi-angle-double-right"></span>
253
262
  </button>
254
- <p-dropdown [options]="rowsPerPageItems" [(ngModel)]="rows" *ngIf="rowsPerPageOptions" styleClass="p-paginator-rpp-options"
263
+ <p-inputNumber *ngIf="showJumpToPageInput" [ngModel]="currentPage()" class="p-paginator-page-input" [disabled]="empty()" (ngModelChange)="changePage($event - 1)"></p-inputNumber>
264
+ <p-dropdown [options]="rowsPerPageItems" [(ngModel)]="rows" *ngIf="rowsPerPageOptions" styleClass="p-paginator-rpp-options" [disabled]="empty()"
255
265
  (onChange)="onRppChange($event)" [appendTo]="dropdownAppendTo" [scrollHeight]="dropdownScrollHeight">
256
266
  <ng-container *ngIf="dropdownItemTemplate">
257
267
  <ng-template let-item pTemplate="item">
@@ -304,6 +314,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
304
314
  type: Input
305
315
  }], showJumpToPageDropdown: [{
306
316
  type: Input
317
+ }], showJumpToPageInput: [{
318
+ type: Input
307
319
  }], showPageLinks: [{
308
320
  type: Input
309
321
  }], dropdownItemTemplate: [{
@@ -314,13 +326,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
314
326
  class PaginatorModule {
315
327
  }
316
328
  PaginatorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginatorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
317
- PaginatorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginatorModule, declarations: [Paginator], imports: [CommonModule, DropdownModule, FormsModule, SharedModule, RippleModule], exports: [Paginator, DropdownModule, FormsModule, SharedModule] });
318
- PaginatorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginatorModule, imports: [[CommonModule, DropdownModule, FormsModule, SharedModule, RippleModule], DropdownModule, FormsModule, SharedModule] });
329
+ PaginatorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginatorModule, declarations: [Paginator], imports: [CommonModule, DropdownModule, InputNumberModule, FormsModule, SharedModule, RippleModule], exports: [Paginator, DropdownModule, InputNumberModule, FormsModule, SharedModule] });
330
+ PaginatorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginatorModule, imports: [[CommonModule, DropdownModule, InputNumberModule, FormsModule, SharedModule, RippleModule], DropdownModule, InputNumberModule, FormsModule, SharedModule] });
319
331
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PaginatorModule, decorators: [{
320
332
  type: NgModule,
321
333
  args: [{
322
- imports: [CommonModule, DropdownModule, FormsModule, SharedModule, RippleModule],
323
- exports: [Paginator, DropdownModule, FormsModule, SharedModule],
334
+ imports: [CommonModule, DropdownModule, InputNumberModule, FormsModule, SharedModule, RippleModule],
335
+ exports: [Paginator, DropdownModule, InputNumberModule, FormsModule, SharedModule],
324
336
  declarations: [Paginator]
325
337
  }]
326
338
  }] });
@@ -1 +1 @@
1
- {"version":3,"file":"primeng-paginator.js","sources":["../../src/app/components/paginator/paginator.ts","../../src/app/components/paginator/primeng-paginator.ts"],"sourcesContent":["import {NgModule,Component,OnInit,Input,Output,ChangeDetectorRef,EventEmitter,TemplateRef,OnChanges,SimpleChanges,ChangeDetectionStrategy, ViewEncapsulation} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {FormsModule} from '@angular/forms';\nimport {DropdownModule} from 'primeng/dropdown';\nimport {SelectItem} from 'primeng/api';\nimport {RippleModule} from 'primeng/ripple';\nimport {SharedModule} from 'primeng/api';\n\n@Component({\n selector: 'p-paginator',\n template: `\n <div [class]=\"styleClass\" [ngStyle]=\"style\" [ngClass]=\"'p-paginator p-component'\" *ngIf=\"alwaysShow ? true : (pageLinks && pageLinks.length > 1)\">\n <div class=\"p-paginator-left-content\" *ngIf=\"templateLeft\">\n <ng-container *ngTemplateOutlet=\"templateLeft; context: {$implicit: paginatorState}\"></ng-container>\n </div>\n <span class=\"p-paginator-current\" *ngIf=\"showCurrentPageReport\">{{currentPageReport}}</span>\n <button *ngIf=\"showFirstLastIcon\" type=\"button\" [disabled]=\"isFirstPage()\" (click)=\"changePageToFirst($event)\" pRipple\n class=\"p-paginator-first p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isFirstPage()}\">\n <span class=\"p-paginator-icon pi pi-angle-double-left\"></span>\n </button>\n <button type=\"button\" [disabled]=\"isFirstPage()\" (click)=\"changePageToPrev($event)\" pRipple\n class=\"p-paginator-prev p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isFirstPage()}\">\n <span class=\"p-paginator-icon pi pi-angle-left\"></span>\n </button>\n <span class=\"p-paginator-pages\" *ngIf=\"showPageLinks\">\n <button type=\"button\" *ngFor=\"let pageLink of pageLinks\" class=\"p-paginator-page p-paginator-element p-link\" [ngClass]=\"{'p-highlight': (pageLink-1 == getPage())}\"\n (click)=\"onPageLinkClick($event, pageLink - 1)\" pRipple>{{pageLink}}</button>\n </span>\n <p-dropdown [options]=\"pageItems\" [ngModel]=\"getPage()\" *ngIf=\"showJumpToPageDropdown\" styleClass=\"p-paginator-page-options\"\n (onChange)=\"onPageDropdownChange($event)\" [appendTo]=\"dropdownAppendTo\" [scrollHeight]=\"dropdownScrollHeight\">\n <ng-template pTemplate=\"selectedItem\">{{currentPageReport}}</ng-template>\n </p-dropdown>\n <button type=\"button\" [disabled]=\"isLastPage()\" (click)=\"changePageToNext($event)\" pRipple\n class=\"p-paginator-next p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isLastPage()}\">\n <span class=\"p-paginator-icon pi pi-angle-right\"></span>\n </button>\n <button *ngIf=\"showFirstLastIcon\" type=\"button\" [disabled]=\"isLastPage()\" (click)=\"changePageToLast($event)\" pRipple\n class=\"p-paginator-last p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isLastPage()}\">\n <span class=\"p-paginator-icon pi pi-angle-double-right\"></span>\n </button>\n <p-dropdown [options]=\"rowsPerPageItems\" [(ngModel)]=\"rows\" *ngIf=\"rowsPerPageOptions\" styleClass=\"p-paginator-rpp-options\"\n (onChange)=\"onRppChange($event)\" [appendTo]=\"dropdownAppendTo\" [scrollHeight]=\"dropdownScrollHeight\">\n <ng-container *ngIf=\"dropdownItemTemplate\">\n <ng-template let-item pTemplate=\"item\">\n <ng-container *ngTemplateOutlet=\"dropdownItemTemplate; context: {$implicit: item}\">\n </ng-container>\n </ng-template>\n </ng-container>\n </p-dropdown>\n <div class=\"p-paginator-right-content\" *ngIf=\"templateRight\">\n <ng-container *ngTemplateOutlet=\"templateRight; context: {$implicit: paginatorState}\"></ng-container>\n </div>\n </div>\n `,\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n styleUrls: ['./paginator.css'],\n host: {\n 'class': 'p-element'\n }\n})\nexport class Paginator implements OnInit, OnChanges {\n\n @Input() pageLinkSize: number = 5;\n\n @Output() onPageChange: EventEmitter<any> = new EventEmitter();\n\n @Input() style: any;\n\n @Input() styleClass: string;\n\n @Input() alwaysShow: boolean = true;\n\n @Input() templateLeft: TemplateRef<any>;\n\n @Input() templateRight: TemplateRef<any>;\n\n @Input() dropdownAppendTo: any;\n\n @Input() dropdownScrollHeight: string = '200px';\n\n @Input() currentPageReportTemplate: string = '{currentPage} of {totalPages}';\n\n @Input() showCurrentPageReport: boolean;\n\n @Input() showFirstLastIcon: boolean = true;\n\n @Input() totalRecords: number = 0;\n\n @Input() rows: number = 0;\n\n @Input() rowsPerPageOptions: any[];\n\n @Input() showJumpToPageDropdown: boolean;\n\n @Input() showPageLinks: boolean = true;\n\n @Input() dropdownItemTemplate: TemplateRef<any>;\n\n pageLinks: number[];\n\n pageItems: SelectItem[];\n\n rowsPerPageItems: SelectItem[];\n\n paginatorState: any;\n\n _first: number = 0;\n\n _page: number = 0;\n\n constructor(private cd: ChangeDetectorRef) {}\n\n ngOnInit() {\n this.updatePaginatorState();\n }\n\n ngOnChanges(simpleChange: SimpleChanges) {\n if (simpleChange.totalRecords) {\n this.updatePageLinks();\n this.updatePaginatorState();\n this.updateFirst();\n this.updateRowsPerPageOptions();\n }\n\n if (simpleChange.first) {\n this._first = simpleChange.first.currentValue;\n this.updatePageLinks();\n this.updatePaginatorState();\n }\n\n if (simpleChange.rows) {\n this.updatePageLinks();\n this.updatePaginatorState();\n }\n\n if (simpleChange.rowsPerPageOptions) {\n this.updateRowsPerPageOptions();\n }\n }\n\n @Input() get first(): number {\n return this._first;\n }\n set first(val:number) {\n this._first = val;\n }\n\n updateRowsPerPageOptions() {\n if (this.rowsPerPageOptions) {\n this.rowsPerPageItems = [];\n for (let opt of this.rowsPerPageOptions) {\n if (typeof opt == 'object' && opt['showAll']) {\n this.rowsPerPageItems.unshift({label: opt['showAll'], value: this.totalRecords});\n }\n else {\n this.rowsPerPageItems.push({label: String(opt), value: opt});\n }\n }\n }\n }\n\n isFirstPage() {\n return this.getPage() === 0;\n }\n\n isLastPage() {\n return this.getPage() === this.getPageCount() - 1;\n }\n\n getPageCount() {\n return Math.ceil(this.totalRecords/this.rows)||1;\n }\n\n calculatePageLinkBoundaries() {\n let numberOfPages = this.getPageCount(),\n visiblePages = Math.min(this.pageLinkSize, numberOfPages);\n\n //calculate range, keep current in middle if necessary\n let start = Math.max(0, Math.ceil(this.getPage() - ((visiblePages) / 2))),\n end = Math.min(numberOfPages - 1, start + visiblePages - 1);\n\n //check when approaching to last page\n var delta = this.pageLinkSize - (end - start + 1);\n start = Math.max(0, start - delta);\n\n return [start, end];\n }\n\n updatePageLinks() {\n this.pageLinks = [];\n let boundaries = this.calculatePageLinkBoundaries(),\n start = boundaries[0],\n end = boundaries[1];\n\n for(let i = start; i <= end; i++) {\n this.pageLinks.push(i + 1);\n }\n\n if (this.showJumpToPageDropdown) {\n this.pageItems = [];\n for (let i = 0; i < this.getPageCount(); i++) {\n this.pageItems.push({label: String(i + 1), value: i});\n }\n }\n }\n\n changePage(p :number) {\n var pc = this.getPageCount();\n\n if (p >= 0 && p < pc) {\n this._first = this.rows * p;\n var state = {\n page: p,\n first: this.first,\n rows: this.rows,\n pageCount: pc\n };\n this.updatePageLinks();\n\n this.onPageChange.emit(state);\n this.updatePaginatorState();\n }\n }\n\n updateFirst() {\n const page = this.getPage();\n if (page > 0 && this.totalRecords && (this.first >= this.totalRecords)) {\n Promise.resolve(null).then(() => this.changePage(page - 1));\n }\n }\n\n getPage(): number {\n return Math.floor(this.first / this.rows);\n }\n\n changePageToFirst(event) {\n if (!this.isFirstPage()){\n this.changePage(0);\n }\n\n event.preventDefault();\n }\n\n changePageToPrev(event) {\n this.changePage(this.getPage() - 1);\n event.preventDefault();\n }\n\n changePageToNext(event) {\n this.changePage(this.getPage() + 1);\n event.preventDefault();\n }\n\n changePageToLast(event) {\n if (!this.isLastPage()){\n this.changePage(this.getPageCount() - 1);\n }\n\n event.preventDefault();\n }\n\n onPageLinkClick(event, page) {\n this.changePage(page);\n event.preventDefault();\n }\n\n onRppChange(event) {\n this.changePage(this.getPage());\n }\n\n onPageDropdownChange(event) {\n this.changePage(event.value);\n }\n\n updatePaginatorState() {\n this.paginatorState = {\n page: this.getPage(),\n pageCount: this.getPageCount(),\n rows: this.rows,\n first: this.first,\n totalRecords: this.totalRecords\n }\n }\n\n get currentPageReport() {\n return this.currentPageReportTemplate\n .replace(\"{currentPage}\", String(this.getPage() + 1))\n .replace(\"{totalPages}\", String(this.getPageCount()))\n .replace(\"{first}\", String((this.totalRecords > 0) ? this._first + 1 : 0))\n .replace(\"{last}\", String(Math.min(this._first + this.rows, this.totalRecords)))\n .replace(\"{rows}\", String(this.rows))\n .replace(\"{totalRecords}\", String(this.totalRecords));\n }\n}\n\n@NgModule({\n imports: [CommonModule,DropdownModule,FormsModule,SharedModule,RippleModule],\n exports: [Paginator,DropdownModule,FormsModule,SharedModule],\n declarations: [Paginator]\n})\nexport class PaginatorModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"primeng-paginator.js","sources":["../../src/app/components/paginator/paginator.ts","../../src/app/components/paginator/primeng-paginator.ts"],"sourcesContent":["import {NgModule,Component,OnInit,Input,Output,ChangeDetectorRef,EventEmitter,TemplateRef,OnChanges,SimpleChanges,ChangeDetectionStrategy, ViewEncapsulation} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {FormsModule} from '@angular/forms';\nimport {DropdownModule} from 'primeng/dropdown';\nimport {SelectItem} from 'primeng/api';\nimport {RippleModule} from 'primeng/ripple';\nimport {SharedModule} from 'primeng/api';\nimport {InputNumberModule} from 'primeng/inputnumber';\n\n@Component({\n selector: 'p-paginator',\n template: `\n <div [class]=\"styleClass\" [ngStyle]=\"style\" [ngClass]=\"'p-paginator p-component'\" *ngIf=\"alwaysShow ? true : (pageLinks && pageLinks.length > 1)\">\n <div class=\"p-paginator-left-content\" *ngIf=\"templateLeft\">\n <ng-container *ngTemplateOutlet=\"templateLeft; context: {$implicit: paginatorState}\"></ng-container>\n </div>\n <span class=\"p-paginator-current\" *ngIf=\"showCurrentPageReport\">{{currentPageReport}}</span>\n <button *ngIf=\"showFirstLastIcon\" type=\"button\" [disabled]=\"isFirstPage() || empty()\" (click)=\"changePageToFirst($event)\" pRipple\n class=\"p-paginator-first p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isFirstPage() || empty()}\">\n <span class=\"p-paginator-icon pi pi-angle-double-left\"></span>\n </button>\n <button type=\"button\" [disabled]=\"isFirstPage() || empty()\" (click)=\"changePageToPrev($event)\" pRipple\n class=\"p-paginator-prev p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isFirstPage() || empty()}\">\n <span class=\"p-paginator-icon pi pi-angle-left\"></span>\n </button>\n <span class=\"p-paginator-pages\" *ngIf=\"showPageLinks\">\n <button type=\"button\" *ngFor=\"let pageLink of pageLinks\" class=\"p-paginator-page p-paginator-element p-link\" [ngClass]=\"{'p-highlight': (pageLink-1 == getPage())}\"\n (click)=\"onPageLinkClick($event, pageLink - 1)\" pRipple>{{pageLink}}</button>\n </span>\n <p-dropdown [options]=\"pageItems\" [ngModel]=\"getPage()\" *ngIf=\"showJumpToPageDropdown\" [disabled]=\"empty()\" styleClass=\"p-paginator-page-options\"\n (onChange)=\"onPageDropdownChange($event)\" [appendTo]=\"dropdownAppendTo\" [scrollHeight]=\"dropdownScrollHeight\">\n <ng-template pTemplate=\"selectedItem\">{{currentPageReport}}</ng-template>\n </p-dropdown>\n <button type=\"button\" [disabled]=\"isLastPage() || empty()\" (click)=\"changePageToNext($event)\" pRipple\n class=\"p-paginator-next p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isLastPage() || empty()}\">\n <span class=\"p-paginator-icon pi pi-angle-right\"></span>\n </button>\n <button *ngIf=\"showFirstLastIcon\" type=\"button\" [disabled]=\"isLastPage() || empty()\" (click)=\"changePageToLast($event)\" pRipple\n class=\"p-paginator-last p-paginator-element p-link\" [ngClass]=\"{'p-disabled':isLastPage() || empty()}\">\n <span class=\"p-paginator-icon pi pi-angle-double-right\"></span>\n </button>\n <p-inputNumber *ngIf=\"showJumpToPageInput\" [ngModel]=\"currentPage()\" class=\"p-paginator-page-input\" [disabled]=\"empty()\" (ngModelChange)=\"changePage($event - 1)\"></p-inputNumber>\n <p-dropdown [options]=\"rowsPerPageItems\" [(ngModel)]=\"rows\" *ngIf=\"rowsPerPageOptions\" styleClass=\"p-paginator-rpp-options\" [disabled]=\"empty()\"\n (onChange)=\"onRppChange($event)\" [appendTo]=\"dropdownAppendTo\" [scrollHeight]=\"dropdownScrollHeight\">\n <ng-container *ngIf=\"dropdownItemTemplate\">\n <ng-template let-item pTemplate=\"item\">\n <ng-container *ngTemplateOutlet=\"dropdownItemTemplate; context: {$implicit: item}\">\n </ng-container>\n </ng-template>\n </ng-container>\n </p-dropdown>\n <div class=\"p-paginator-right-content\" *ngIf=\"templateRight\">\n <ng-container *ngTemplateOutlet=\"templateRight; context: {$implicit: paginatorState}\"></ng-container>\n </div>\n </div>\n `,\n changeDetection: ChangeDetectionStrategy.OnPush,\n encapsulation: ViewEncapsulation.None,\n styleUrls: ['./paginator.css'],\n host: {\n 'class': 'p-element'\n }\n})\nexport class Paginator implements OnInit, OnChanges {\n\n @Input() pageLinkSize: number = 5;\n\n @Output() onPageChange: EventEmitter<any> = new EventEmitter();\n\n @Input() style: any;\n\n @Input() styleClass: string;\n\n @Input() alwaysShow: boolean = true;\n\n @Input() templateLeft: TemplateRef<any>;\n\n @Input() templateRight: TemplateRef<any>;\n\n @Input() dropdownAppendTo: any;\n\n @Input() dropdownScrollHeight: string = '200px';\n\n @Input() currentPageReportTemplate: string = '{currentPage} of {totalPages}';\n\n @Input() showCurrentPageReport: boolean;\n\n @Input() showFirstLastIcon: boolean = true;\n\n @Input() totalRecords: number = 0;\n\n @Input() rows: number = 0;\n\n @Input() rowsPerPageOptions: any[];\n\n @Input() showJumpToPageDropdown: boolean;\n\n @Input() showJumpToPageInput: boolean;\n\n @Input() showPageLinks: boolean = true;\n\n @Input() dropdownItemTemplate: TemplateRef<any>;\n\n pageLinks: number[];\n\n pageItems: SelectItem[];\n\n rowsPerPageItems: SelectItem[];\n\n paginatorState: any;\n\n _first: number = 0;\n\n _page: number = 0;\n\n constructor(private cd: ChangeDetectorRef) {}\n\n ngOnInit() {\n this.updatePaginatorState();\n }\n\n ngOnChanges(simpleChange: SimpleChanges) {\n if (simpleChange.totalRecords) {\n this.updatePageLinks();\n this.updatePaginatorState();\n this.updateFirst();\n this.updateRowsPerPageOptions();\n }\n\n if (simpleChange.first) {\n this._first = simpleChange.first.currentValue;\n this.updatePageLinks();\n this.updatePaginatorState();\n }\n\n if (simpleChange.rows) {\n this.updatePageLinks();\n this.updatePaginatorState();\n }\n\n if (simpleChange.rowsPerPageOptions) {\n this.updateRowsPerPageOptions();\n }\n }\n\n @Input() get first(): number {\n return this._first;\n }\n set first(val:number) {\n this._first = val;\n }\n\n updateRowsPerPageOptions() {\n if (this.rowsPerPageOptions) {\n this.rowsPerPageItems = [];\n for (let opt of this.rowsPerPageOptions) {\n if (typeof opt == 'object' && opt['showAll']) {\n this.rowsPerPageItems.unshift({label: opt['showAll'], value: this.totalRecords});\n }\n else {\n this.rowsPerPageItems.push({label: String(opt), value: opt});\n }\n }\n }\n }\n\n isFirstPage() {\n return this.getPage() === 0;\n }\n\n isLastPage() {\n return this.getPage() === this.getPageCount() - 1;\n }\n\n getPageCount() {\n return Math.ceil(this.totalRecords/this.rows);\n }\n\n calculatePageLinkBoundaries() {\n let numberOfPages = this.getPageCount(),\n visiblePages = Math.min(this.pageLinkSize, numberOfPages);\n\n //calculate range, keep current in middle if necessary\n let start = Math.max(0, Math.ceil(this.getPage() - ((visiblePages) / 2))),\n end = Math.min(numberOfPages - 1, start + visiblePages - 1);\n\n //check when approaching to last page\n var delta = this.pageLinkSize - (end - start + 1);\n start = Math.max(0, start - delta);\n\n return [start, end];\n }\n\n updatePageLinks() {\n this.pageLinks = [];\n let boundaries = this.calculatePageLinkBoundaries(),\n start = boundaries[0],\n end = boundaries[1];\n\n for(let i = start; i <= end; i++) {\n this.pageLinks.push(i + 1);\n }\n\n if (this.showJumpToPageDropdown) {\n this.pageItems = [];\n for (let i = 0; i < this.getPageCount(); i++) {\n this.pageItems.push({label: String(i + 1), value: i});\n }\n }\n }\n\n changePage(p :number) {\n var pc = this.getPageCount();\n\n if (p >= 0 && p < pc) {\n this._first = this.rows * p;\n var state = {\n page: p,\n first: this.first,\n rows: this.rows,\n pageCount: pc\n };\n this.updatePageLinks();\n\n this.onPageChange.emit(state);\n this.updatePaginatorState();\n }\n }\n\n updateFirst() {\n const page = this.getPage();\n if (page > 0 && this.totalRecords && (this.first >= this.totalRecords)) {\n Promise.resolve(null).then(() => this.changePage(page - 1));\n }\n }\n\n getPage(): number {\n return Math.floor(this.first / this.rows);\n }\n\n changePageToFirst(event) {\n if (!this.isFirstPage()){\n this.changePage(0);\n }\n\n event.preventDefault();\n }\n\n changePageToPrev(event) {\n this.changePage(this.getPage() - 1);\n event.preventDefault();\n }\n\n changePageToNext(event) {\n this.changePage(this.getPage() + 1);\n event.preventDefault();\n }\n\n changePageToLast(event) {\n if (!this.isLastPage()){\n this.changePage(this.getPageCount() - 1);\n }\n\n event.preventDefault();\n }\n\n onPageLinkClick(event, page) {\n this.changePage(page);\n event.preventDefault();\n }\n\n onRppChange(event) {\n this.changePage(this.getPage());\n }\n\n onPageDropdownChange(event) {\n this.changePage(event.value);\n }\n\n updatePaginatorState() {\n this.paginatorState = {\n page: this.getPage(),\n pageCount: this.getPageCount(),\n rows: this.rows,\n first: this.first,\n totalRecords: this.totalRecords\n }\n }\n\n empty() {\n return this.getPageCount() === 0;\n }\n\n currentPage() {\n return this.getPageCount() > 0 ? this.getPage() + 1 : 0;\n }\n\n get currentPageReport() {\n return this.currentPageReportTemplate\n .replace(\"{currentPage}\", String(this.currentPage()))\n .replace(\"{totalPages}\", String(this.getPageCount()))\n .replace(\"{first}\", String((this.totalRecords > 0) ? this._first + 1 : 0))\n .replace(\"{last}\", String(Math.min(this._first + this.rows, this.totalRecords)))\n .replace(\"{rows}\", String(this.rows))\n .replace(\"{totalRecords}\", String(this.totalRecords));\n }\n}\n\n@NgModule({\n imports: [CommonModule,DropdownModule,InputNumberModule,FormsModule,SharedModule,RippleModule],\n exports: [Paginator,DropdownModule,InputNumberModule,FormsModule,SharedModule],\n declarations: [Paginator]\n})\nexport class PaginatorModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
@@ -7,6 +7,7 @@ import * as i3 from '@angular/router';
7
7
  import { RouterModule } from '@angular/router';
8
8
  import * as i2 from 'primeng/tooltip';
9
9
  import { TooltipModule } from 'primeng/tooltip';
10
+ import { DomHandler } from 'primeng/dom';
10
11
 
11
12
  class BasePanelMenuItem {
12
13
  constructor(ref) {
@@ -34,14 +35,28 @@ class PanelMenuSub extends BasePanelMenuItem {
34
35
  constructor(ref) {
35
36
  super(ref);
36
37
  }
38
+ onItemKeyDown(event) {
39
+ let listItem = event.currentTarget;
40
+ switch (event.code) {
41
+ case 'Space':
42
+ case 'Enter':
43
+ if (listItem && !DomHandler.hasClass(listItem, 'p-disabled')) {
44
+ listItem.click();
45
+ }
46
+ event.preventDefault();
47
+ break;
48
+ default:
49
+ break;
50
+ }
51
+ }
37
52
  }
38
53
  PanelMenuSub.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PanelMenuSub, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
39
- PanelMenuSub.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: PanelMenuSub, selector: "p-panelMenuSub", inputs: { item: "item", expanded: "expanded", transitionOptions: "transitionOptions", root: "root" }, host: { classAttribute: "p-element" }, usesInheritance: true, ngImport: i0, template: `
54
+ PanelMenuSub.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: PanelMenuSub, selector: "p-panelMenuSub", inputs: { item: "item", expanded: "expanded", parentExpanded: "parentExpanded", transitionOptions: "transitionOptions", root: "root" }, host: { classAttribute: "p-element" }, usesInheritance: true, ngImport: i0, template: `
40
55
  <ul [ngClass]="{'p-submenu-list': true, 'p-panelmenu-root-submenu': root}" [@submenu]="expanded ? {value: 'visible', params: {transitionParams: transitionOptions, height: '*'}} : {value: 'hidden', params: {transitionParams: transitionOptions, height: '0'}}" role="tree">
41
56
  <ng-template ngFor let-child [ngForOf]="item.items">
42
57
  <li *ngIf="child.separator" class="p-menu-separator" role="separator">
43
58
  <li *ngIf="!child.separator" class="p-menuitem" [ngClass]="child.styleClass" [class.p-hidden]="child.visible === false" [ngStyle]="child.style" pTooltip [tooltipOptions]="child.tooltipOptions">
44
- <a *ngIf="!child.routerLink" [attr.href]="child.url" class="p-menuitem-link" [attr.tabindex]="!item.expanded ? null : child.disabled ? null : '0'" [attr.id]="child.id"
59
+ <a *ngIf="!child.routerLink" (keydown)="onItemKeyDown($event)" [attr.href]="child.url" class="p-menuitem-link" [attr.tabindex]="!item.expanded || !parentExpanded ? null : child.disabled ? null : '0'" [attr.id]="child.id"
45
60
  [ngClass]="{'p-disabled':child.disabled}" role="treeitem" [attr.aria-expanded]="child.expanded"
46
61
  (click)="handleClick($event,child)" [attr.target]="child.target" [attr.title]="child.title">
47
62
  <span class="p-panelmenu-icon pi pi-fw" [ngClass]="{'pi-angle-right':!child.expanded,'pi-angle-down':child.expanded}" *ngIf="child.items"></span>
@@ -49,8 +64,8 @@ PanelMenuSub.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version:
49
64
  <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlLabel">{{child.label}}</span>
50
65
  <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
51
66
  </a>
52
- <a *ngIf="child.routerLink" [routerLink]="child.routerLink" [queryParams]="child.queryParams" [routerLinkActive]="'p-menuitem-link-active'" [routerLinkActiveOptions]="child.routerLinkActiveOptions||{exact:false}" class="p-menuitem-link"
53
- [ngClass]="{'p-disabled':child.disabled}" [attr.tabindex]="!item.expanded ? null : child.disabled ? null : '0'" [attr.id]="child.id" role="treeitem" [attr.aria-expanded]="child.expanded"
67
+ <a *ngIf="child.routerLink" (keydown)="onItemKeyDown($event)" [routerLink]="child.routerLink" [queryParams]="child.queryParams" [routerLinkActive]="'p-menuitem-link-active'" [routerLinkActiveOptions]="child.routerLinkActiveOptions||{exact:false}" class="p-menuitem-link"
68
+ [ngClass]="{'p-disabled':child.disabled}" [attr.tabindex]="!item.expanded || !parentExpanded ? null : child.disabled ? null : '0'" [attr.id]="child.id" role="treeitem" [attr.aria-expanded]="child.expanded"
54
69
  (click)="handleClick($event,child)" [attr.target]="child.target" [attr.title]="child.title"
55
70
  [fragment]="child.fragment" [queryParamsHandling]="child.queryParamsHandling" [preserveFragment]="child.preserveFragment" [skipLocationChange]="child.skipLocationChange" [replaceUrl]="child.replaceUrl" [state]="child.state">
56
71
  <span class="p-panelmenu-icon pi pi-fw" [ngClass]="{'pi-angle-right':!child.expanded,'pi-angle-down':child.expanded}" *ngIf="child.items"></span>
@@ -58,11 +73,11 @@ PanelMenuSub.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version:
58
73
  <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlRouteLabel">{{child.label}}</span>
59
74
  <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
60
75
  </a>
61
- <p-panelMenuSub [item]="child" [expanded]="child.expanded" [transitionOptions]="transitionOptions" *ngIf="child.items"></p-panelMenuSub>
76
+ <p-panelMenuSub [item]="child" [parentExpanded]="expanded && parentExpanded" [expanded]="child.expanded" [transitionOptions]="transitionOptions" *ngIf="child.items"></p-panelMenuSub>
62
77
  </li>
63
78
  </ng-template>
64
79
  </ul>
65
- `, isInline: true, components: [{ type: PanelMenuSub, selector: "p-panelMenuSub", inputs: ["item", "expanded", "transitionOptions", "root"] }], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], exportAs: ["routerLinkActive"] }], animations: [
80
+ `, isInline: true, components: [{ type: PanelMenuSub, selector: "p-panelMenuSub", inputs: ["item", "expanded", "parentExpanded", "transitionOptions", "root"] }], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], exportAs: ["routerLinkActive"] }], animations: [
66
81
  trigger('submenu', [
67
82
  state('hidden', style({
68
83
  height: '0',
@@ -84,7 +99,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
84
99
  <ng-template ngFor let-child [ngForOf]="item.items">
85
100
  <li *ngIf="child.separator" class="p-menu-separator" role="separator">
86
101
  <li *ngIf="!child.separator" class="p-menuitem" [ngClass]="child.styleClass" [class.p-hidden]="child.visible === false" [ngStyle]="child.style" pTooltip [tooltipOptions]="child.tooltipOptions">
87
- <a *ngIf="!child.routerLink" [attr.href]="child.url" class="p-menuitem-link" [attr.tabindex]="!item.expanded ? null : child.disabled ? null : '0'" [attr.id]="child.id"
102
+ <a *ngIf="!child.routerLink" (keydown)="onItemKeyDown($event)" [attr.href]="child.url" class="p-menuitem-link" [attr.tabindex]="!item.expanded || !parentExpanded ? null : child.disabled ? null : '0'" [attr.id]="child.id"
88
103
  [ngClass]="{'p-disabled':child.disabled}" role="treeitem" [attr.aria-expanded]="child.expanded"
89
104
  (click)="handleClick($event,child)" [attr.target]="child.target" [attr.title]="child.title">
90
105
  <span class="p-panelmenu-icon pi pi-fw" [ngClass]="{'pi-angle-right':!child.expanded,'pi-angle-down':child.expanded}" *ngIf="child.items"></span>
@@ -92,8 +107,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
92
107
  <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlLabel">{{child.label}}</span>
93
108
  <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
94
109
  </a>
95
- <a *ngIf="child.routerLink" [routerLink]="child.routerLink" [queryParams]="child.queryParams" [routerLinkActive]="'p-menuitem-link-active'" [routerLinkActiveOptions]="child.routerLinkActiveOptions||{exact:false}" class="p-menuitem-link"
96
- [ngClass]="{'p-disabled':child.disabled}" [attr.tabindex]="!item.expanded ? null : child.disabled ? null : '0'" [attr.id]="child.id" role="treeitem" [attr.aria-expanded]="child.expanded"
110
+ <a *ngIf="child.routerLink" (keydown)="onItemKeyDown($event)" [routerLink]="child.routerLink" [queryParams]="child.queryParams" [routerLinkActive]="'p-menuitem-link-active'" [routerLinkActiveOptions]="child.routerLinkActiveOptions||{exact:false}" class="p-menuitem-link"
111
+ [ngClass]="{'p-disabled':child.disabled}" [attr.tabindex]="!item.expanded || !parentExpanded ? null : child.disabled ? null : '0'" [attr.id]="child.id" role="treeitem" [attr.aria-expanded]="child.expanded"
97
112
  (click)="handleClick($event,child)" [attr.target]="child.target" [attr.title]="child.title"
98
113
  [fragment]="child.fragment" [queryParamsHandling]="child.queryParamsHandling" [preserveFragment]="child.preserveFragment" [skipLocationChange]="child.skipLocationChange" [replaceUrl]="child.replaceUrl" [state]="child.state">
99
114
  <span class="p-panelmenu-icon pi pi-fw" [ngClass]="{'pi-angle-right':!child.expanded,'pi-angle-down':child.expanded}" *ngIf="child.items"></span>
@@ -101,7 +116,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
101
116
  <span class="p-menuitem-text" *ngIf="child.escape !== false; else htmlRouteLabel">{{child.label}}</span>
102
117
  <ng-template #htmlRouteLabel><span class="p-menuitem-text" [innerHTML]="child.label"></span></ng-template>
103
118
  </a>
104
- <p-panelMenuSub [item]="child" [expanded]="child.expanded" [transitionOptions]="transitionOptions" *ngIf="child.items"></p-panelMenuSub>
119
+ <p-panelMenuSub [item]="child" [parentExpanded]="expanded && parentExpanded" [expanded]="child.expanded" [transitionOptions]="transitionOptions" *ngIf="child.items"></p-panelMenuSub>
105
120
  </li>
106
121
  </ng-template>
107
122
  </ul>
@@ -128,6 +143,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
128
143
  type: Input
129
144
  }], expanded: [{
130
145
  type: Input
146
+ }], parentExpanded: [{
147
+ type: Input
131
148
  }], transitionOptions: [{
132
149
  type: Input
133
150
  }], root: [{
@@ -160,6 +177,20 @@ class PanelMenu extends BasePanelMenuItem {
160
177
  onToggleDone() {
161
178
  this.animating = false;
162
179
  }
180
+ onItemKeyDown(event) {
181
+ let listItem = event.currentTarget;
182
+ switch (event.code) {
183
+ case 'Space':
184
+ case 'Enter':
185
+ if (listItem && !DomHandler.hasClass(listItem, 'p-disabled')) {
186
+ listItem.click();
187
+ }
188
+ event.preventDefault();
189
+ break;
190
+ default:
191
+ break;
192
+ }
193
+ }
163
194
  }
164
195
  PanelMenu.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: PanelMenu, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
165
196
  PanelMenu.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: PanelMenu, selector: "p-panelMenu", inputs: { model: "model", style: "style", styleClass: "styleClass", multiple: "multiple", transitionOptions: "transitionOptions" }, host: { classAttribute: "p-element" }, usesInheritance: true, ngImport: i0, template: `
@@ -167,7 +198,7 @@ PanelMenu.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12
167
198
  <ng-container *ngFor="let item of model;let f=first;let l=last;">
168
199
  <div class="p-panelmenu-panel" [ngClass]="{'p-hidden': item.visible === false}">
169
200
  <div [ngClass]="{'p-component p-panelmenu-header':true, 'p-highlight':item.expanded,'p-disabled':item.disabled}" [class]="item.styleClass" [ngStyle]="item.style" pTooltip [tooltipOptions]="item.tooltipOptions">
170
- <a *ngIf="!item.routerLink" [attr.href]="item.url" (click)="handleClick($event,item)" [attr.tabindex]="item.disabled ? null : '0'" [attr.id]="item.id"
201
+ <a *ngIf="!item.routerLink" [attr.href]="item.url" (click)="handleClick($event,item)" (keydown)="onItemKeyDown($event)" [attr.tabindex]="item.disabled ? null : '0'" [attr.id]="item.id"
171
202
  [attr.target]="item.target" [attr.title]="item.title" class="p-panelmenu-header-link" [attr.aria-expanded]="item.expanded" [attr.id]="item.id + '_header'" [attr.aria-controls]="item.id +'_content'">
172
203
  <span *ngIf="item.items" class="p-panelmenu-icon pi" [ngClass]="{'pi-chevron-right':!item.expanded,'pi-chevron-down':item.expanded}"></span>
173
204
  <span class="p-menuitem-icon" [ngClass]="item.icon" *ngIf="item.icon"></span>
@@ -175,7 +206,7 @@ PanelMenu.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12
175
206
  <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="item.label"></span></ng-template>
176
207
  </a>
177
208
  <a *ngIf="item.routerLink" [routerLink]="item.routerLink" [queryParams]="item.queryParams" [routerLinkActive]="'p-menuitem-link-active'" [routerLinkActiveOptions]="item.routerLinkActiveOptions||{exact:false}"
178
- (click)="handleClick($event,item)" [attr.target]="item.target" [attr.title]="item.title" class="p-panelmenu-header-link" [attr.id]="item.id" [attr.tabindex]="item.disabled ? null : '0'"
209
+ (click)="handleClick($event,item)" (keydown)="onItemKeyDown($event)" [attr.target]="item.target" [attr.title]="item.title" class="p-panelmenu-header-link" [attr.id]="item.id" [attr.tabindex]="item.disabled ? null : '0'"
179
210
  [fragment]="item.fragment" [queryParamsHandling]="item.queryParamsHandling" [preserveFragment]="item.preserveFragment" [skipLocationChange]="item.skipLocationChange" [replaceUrl]="item.replaceUrl" [state]="item.state">
180
211
  <span *ngIf="item.items" class="p-panelmenu-icon pi" [ngClass]="{'pi-chevron-right':!item.expanded,'pi-chevron-down':item.expanded}"></span>
181
212
  <span class="p-menuitem-icon" [ngClass]="item.icon" *ngIf="item.icon"></span>
@@ -185,13 +216,13 @@ PanelMenu.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12
185
216
  </div>
186
217
  <div *ngIf="item.items" class="p-toggleable-content" [@rootItem]="item.expanded ? {value: 'visible', params: {transitionParams: animating ? transitionOptions : '0ms', height: '*'}} : {value: 'hidden', params: {transitionParams: transitionOptions, height: '0'}}" (@rootItem.done)="onToggleDone()">
187
218
  <div class="p-panelmenu-content" role="region" [attr.id]="item.id +'_content' " [attr.aria-labelledby]="item.id +'_header'">
188
- <p-panelMenuSub [item]="item" [expanded]="true" [transitionOptions]="transitionOptions" [root]="true"></p-panelMenuSub>
219
+ <p-panelMenuSub [item]="item" [parentExpanded]="item.expanded" [expanded]="true" [transitionOptions]="transitionOptions" [root]="true"></p-panelMenuSub>
189
220
  </div>
190
221
  </div>
191
222
  </div>
192
223
  </ng-container>
193
224
  </div>
194
- `, isInline: true, styles: [".p-panelmenu .p-panelmenu-header-link{display:flex;align-items:center;-webkit-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;position:relative;text-decoration:none}.p-panelmenu .p-panelmenu-header-link:focus{z-index:1}.p-panelmenu .p-submenu-list{margin:0;padding:0;list-style:none}.p-panelmenu .p-menuitem-link{display:flex;align-items:center;-webkit-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;text-decoration:none}.p-panelmenu .p-menuitem-text{line-height:1}"], components: [{ type: PanelMenuSub, selector: "p-panelMenuSub", inputs: ["item", "expanded", "transitionOptions", "root"] }], directives: [{ type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], exportAs: ["routerLinkActive"] }], animations: [
225
+ `, isInline: true, styles: [".p-panelmenu .p-panelmenu-header-link{display:flex;align-items:center;-webkit-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;position:relative;text-decoration:none}.p-panelmenu .p-panelmenu-header-link:focus{z-index:1}.p-panelmenu .p-submenu-list{margin:0;padding:0;list-style:none}.p-panelmenu .p-menuitem-link{display:flex;align-items:center;-webkit-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;text-decoration:none}.p-panelmenu .p-menuitem-text{line-height:1}"], components: [{ type: PanelMenuSub, selector: "p-panelMenuSub", inputs: ["item", "expanded", "parentExpanded", "transitionOptions", "root"] }], directives: [{ type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], exportAs: ["routerLinkActive"] }], animations: [
195
226
  trigger('rootItem', [
196
227
  state('hidden', style({
197
228
  height: '0',
@@ -213,7 +244,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
213
244
  <ng-container *ngFor="let item of model;let f=first;let l=last;">
214
245
  <div class="p-panelmenu-panel" [ngClass]="{'p-hidden': item.visible === false}">
215
246
  <div [ngClass]="{'p-component p-panelmenu-header':true, 'p-highlight':item.expanded,'p-disabled':item.disabled}" [class]="item.styleClass" [ngStyle]="item.style" pTooltip [tooltipOptions]="item.tooltipOptions">
216
- <a *ngIf="!item.routerLink" [attr.href]="item.url" (click)="handleClick($event,item)" [attr.tabindex]="item.disabled ? null : '0'" [attr.id]="item.id"
247
+ <a *ngIf="!item.routerLink" [attr.href]="item.url" (click)="handleClick($event,item)" (keydown)="onItemKeyDown($event)" [attr.tabindex]="item.disabled ? null : '0'" [attr.id]="item.id"
217
248
  [attr.target]="item.target" [attr.title]="item.title" class="p-panelmenu-header-link" [attr.aria-expanded]="item.expanded" [attr.id]="item.id + '_header'" [attr.aria-controls]="item.id +'_content'">
218
249
  <span *ngIf="item.items" class="p-panelmenu-icon pi" [ngClass]="{'pi-chevron-right':!item.expanded,'pi-chevron-down':item.expanded}"></span>
219
250
  <span class="p-menuitem-icon" [ngClass]="item.icon" *ngIf="item.icon"></span>
@@ -221,7 +252,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
221
252
  <ng-template #htmlLabel><span class="p-menuitem-text" [innerHTML]="item.label"></span></ng-template>
222
253
  </a>
223
254
  <a *ngIf="item.routerLink" [routerLink]="item.routerLink" [queryParams]="item.queryParams" [routerLinkActive]="'p-menuitem-link-active'" [routerLinkActiveOptions]="item.routerLinkActiveOptions||{exact:false}"
224
- (click)="handleClick($event,item)" [attr.target]="item.target" [attr.title]="item.title" class="p-panelmenu-header-link" [attr.id]="item.id" [attr.tabindex]="item.disabled ? null : '0'"
255
+ (click)="handleClick($event,item)" (keydown)="onItemKeyDown($event)" [attr.target]="item.target" [attr.title]="item.title" class="p-panelmenu-header-link" [attr.id]="item.id" [attr.tabindex]="item.disabled ? null : '0'"
225
256
  [fragment]="item.fragment" [queryParamsHandling]="item.queryParamsHandling" [preserveFragment]="item.preserveFragment" [skipLocationChange]="item.skipLocationChange" [replaceUrl]="item.replaceUrl" [state]="item.state">
226
257
  <span *ngIf="item.items" class="p-panelmenu-icon pi" [ngClass]="{'pi-chevron-right':!item.expanded,'pi-chevron-down':item.expanded}"></span>
227
258
  <span class="p-menuitem-icon" [ngClass]="item.icon" *ngIf="item.icon"></span>
@@ -231,7 +262,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
231
262
  </div>
232
263
  <div *ngIf="item.items" class="p-toggleable-content" [@rootItem]="item.expanded ? {value: 'visible', params: {transitionParams: animating ? transitionOptions : '0ms', height: '*'}} : {value: 'hidden', params: {transitionParams: transitionOptions, height: '0'}}" (@rootItem.done)="onToggleDone()">
233
264
  <div class="p-panelmenu-content" role="region" [attr.id]="item.id +'_content' " [attr.aria-labelledby]="item.id +'_header'">
234
- <p-panelMenuSub [item]="item" [expanded]="true" [transitionOptions]="transitionOptions" [root]="true"></p-panelMenuSub>
265
+ <p-panelMenuSub [item]="item" [parentExpanded]="item.expanded" [expanded]="true" [transitionOptions]="transitionOptions" [root]="true"></p-panelMenuSub>
235
266
  </div>
236
267
  </div>
237
268
  </div>