primereact 10.5.1 → 10.5.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 (430) hide show
  1. package/api/api.cjs.js +94 -92
  2. package/api/api.cjs.min.js +1 -1
  3. package/api/api.d.ts +229 -11
  4. package/api/api.esm.js +94 -92
  5. package/api/api.esm.min.js +1 -1
  6. package/api/api.js +94 -92
  7. package/api/api.min.js +1 -1
  8. package/autocomplete/autocomplete.cjs.js +89 -45
  9. package/autocomplete/autocomplete.cjs.min.js +1 -1
  10. package/autocomplete/autocomplete.d.ts +6 -1
  11. package/autocomplete/autocomplete.esm.js +89 -45
  12. package/autocomplete/autocomplete.esm.min.js +1 -1
  13. package/autocomplete/autocomplete.js +89 -45
  14. package/autocomplete/autocomplete.min.js +1 -1
  15. package/blockui/blockui.cjs.js +13 -13
  16. package/blockui/blockui.cjs.min.js +1 -1
  17. package/blockui/blockui.esm.js +13 -13
  18. package/blockui/blockui.esm.min.js +1 -1
  19. package/blockui/blockui.js +13 -13
  20. package/blockui/blockui.min.js +1 -1
  21. package/calendar/calendar.cjs.js +30 -11
  22. package/calendar/calendar.cjs.min.js +1 -1
  23. package/calendar/calendar.d.ts +9 -0
  24. package/calendar/calendar.esm.js +30 -11
  25. package/calendar/calendar.esm.min.js +1 -1
  26. package/calendar/calendar.js +30 -11
  27. package/calendar/calendar.min.js +1 -1
  28. package/carousel/carousel.cjs.js +17 -15
  29. package/carousel/carousel.cjs.min.js +1 -1
  30. package/carousel/carousel.esm.js +4 -2
  31. package/carousel/carousel.esm.min.js +1 -1
  32. package/carousel/carousel.js +17 -15
  33. package/carousel/carousel.min.js +1 -1
  34. package/cascadeselect/cascadeselect.cjs.js +28 -14
  35. package/cascadeselect/cascadeselect.cjs.min.js +1 -1
  36. package/cascadeselect/cascadeselect.d.ts +5 -0
  37. package/cascadeselect/cascadeselect.esm.js +28 -14
  38. package/cascadeselect/cascadeselect.esm.min.js +1 -1
  39. package/cascadeselect/cascadeselect.js +28 -14
  40. package/cascadeselect/cascadeselect.min.js +1 -1
  41. package/checkbox/checkbox.cjs.js +70 -153
  42. package/checkbox/checkbox.cjs.min.js +1 -1
  43. package/checkbox/checkbox.d.ts +10 -34
  44. package/checkbox/checkbox.esm.js +70 -153
  45. package/checkbox/checkbox.esm.min.js +1 -1
  46. package/checkbox/checkbox.js +70 -153
  47. package/checkbox/checkbox.min.js +1 -1
  48. package/chips/chips.cjs.js +23 -9
  49. package/chips/chips.cjs.min.js +1 -1
  50. package/chips/chips.d.ts +6 -1
  51. package/chips/chips.esm.js +23 -9
  52. package/chips/chips.esm.min.js +1 -1
  53. package/chips/chips.js +23 -9
  54. package/chips/chips.min.js +1 -1
  55. package/colorpicker/colorpicker.cjs.js +3 -2
  56. package/colorpicker/colorpicker.cjs.min.js +1 -1
  57. package/colorpicker/colorpicker.esm.js +2 -1
  58. package/colorpicker/colorpicker.esm.min.js +1 -1
  59. package/colorpicker/colorpicker.js +3 -2
  60. package/colorpicker/colorpicker.min.js +1 -1
  61. package/componentbase/componentbase.cjs.js +4 -6
  62. package/componentbase/componentbase.cjs.min.js +1 -1
  63. package/componentbase/componentbase.esm.js +5 -7
  64. package/componentbase/componentbase.esm.min.js +1 -1
  65. package/componentbase/componentbase.js +4 -6
  66. package/componentbase/componentbase.min.js +1 -1
  67. package/confirmdialog/confirmdialog.cjs.js +1 -0
  68. package/confirmdialog/confirmdialog.cjs.min.js +1 -1
  69. package/confirmdialog/confirmdialog.esm.js +1 -0
  70. package/confirmdialog/confirmdialog.esm.min.js +1 -1
  71. package/confirmdialog/confirmdialog.js +1 -0
  72. package/confirmdialog/confirmdialog.min.js +1 -1
  73. package/confirmpopup/confirmpopup.cjs.js +5 -5
  74. package/confirmpopup/confirmpopup.cjs.min.js +1 -1
  75. package/confirmpopup/confirmpopup.esm.js +5 -5
  76. package/confirmpopup/confirmpopup.esm.min.js +1 -1
  77. package/confirmpopup/confirmpopup.js +5 -5
  78. package/confirmpopup/confirmpopup.min.js +1 -1
  79. package/core/core.js +639 -603
  80. package/core/core.min.js +13 -13
  81. package/datatable/datatable.cjs.js +128 -110
  82. package/datatable/datatable.cjs.min.js +1 -1
  83. package/datatable/datatable.d.ts +1 -1
  84. package/datatable/datatable.esm.js +128 -110
  85. package/datatable/datatable.esm.min.js +1 -1
  86. package/datatable/datatable.js +128 -110
  87. package/datatable/datatable.min.js +1 -1
  88. package/dataview/dataview.cjs.js +16 -13
  89. package/dataview/dataview.cjs.min.js +1 -1
  90. package/dataview/dataview.esm.js +4 -1
  91. package/dataview/dataview.esm.min.js +1 -1
  92. package/dataview/dataview.js +17 -15
  93. package/dataview/dataview.min.js +1 -1
  94. package/dialog/dialog.cjs.js +6 -6
  95. package/dialog/dialog.cjs.min.js +1 -1
  96. package/dialog/dialog.esm.js +6 -6
  97. package/dialog/dialog.esm.min.js +1 -1
  98. package/dialog/dialog.js +6 -6
  99. package/dialog/dialog.min.js +1 -1
  100. package/dropdown/dropdown.cjs.js +98 -29
  101. package/dropdown/dropdown.cjs.min.js +1 -1
  102. package/dropdown/dropdown.d.ts +41 -0
  103. package/dropdown/dropdown.esm.js +98 -29
  104. package/dropdown/dropdown.esm.min.js +1 -1
  105. package/dropdown/dropdown.js +98 -31
  106. package/dropdown/dropdown.min.js +1 -1
  107. package/editor/editor.cjs.js +125 -54
  108. package/editor/editor.cjs.min.js +1 -1
  109. package/editor/editor.esm.js +125 -54
  110. package/editor/editor.esm.min.js +1 -1
  111. package/editor/editor.js +125 -54
  112. package/editor/editor.min.js +1 -1
  113. package/galleria/galleria.cjs.js +22 -19
  114. package/galleria/galleria.cjs.min.js +1 -1
  115. package/galleria/galleria.esm.js +4 -1
  116. package/galleria/galleria.esm.min.js +1 -1
  117. package/galleria/galleria.js +23 -20
  118. package/galleria/galleria.min.js +1 -1
  119. package/hooks/hooks.cjs.js +115 -72
  120. package/hooks/hooks.cjs.min.js +1 -1
  121. package/hooks/hooks.esm.js +116 -73
  122. package/hooks/hooks.esm.min.js +1 -1
  123. package/hooks/hooks.js +115 -72
  124. package/hooks/hooks.min.js +1 -1
  125. package/image/image.cjs.js +11 -9
  126. package/image/image.cjs.min.js +1 -1
  127. package/image/image.esm.js +11 -9
  128. package/image/image.esm.min.js +1 -1
  129. package/image/image.js +11 -9
  130. package/image/image.min.js +1 -1
  131. package/inputnumber/inputnumber.cjs.js +20 -36
  132. package/inputnumber/inputnumber.cjs.min.js +1 -1
  133. package/inputnumber/inputnumber.d.ts +5 -5
  134. package/inputnumber/inputnumber.esm.js +20 -36
  135. package/inputnumber/inputnumber.esm.min.js +1 -1
  136. package/inputnumber/inputnumber.js +20 -36
  137. package/inputnumber/inputnumber.min.js +1 -1
  138. package/inputswitch/inputswitch.cjs.js +18 -93
  139. package/inputswitch/inputswitch.cjs.min.js +1 -1
  140. package/inputswitch/inputswitch.d.ts +9 -20
  141. package/inputswitch/inputswitch.esm.js +18 -93
  142. package/inputswitch/inputswitch.esm.min.js +1 -1
  143. package/inputswitch/inputswitch.js +18 -93
  144. package/inputswitch/inputswitch.min.js +1 -1
  145. package/inputtext/inputtext.cjs.js +5 -3
  146. package/inputtext/inputtext.cjs.min.js +1 -1
  147. package/inputtext/inputtext.d.ts +5 -0
  148. package/inputtext/inputtext.esm.js +5 -3
  149. package/inputtext/inputtext.esm.min.js +1 -1
  150. package/inputtext/inputtext.js +5 -3
  151. package/inputtext/inputtext.min.js +1 -1
  152. package/inputtextarea/inputtextarea.cjs.js +3 -1
  153. package/inputtextarea/inputtextarea.cjs.min.js +1 -1
  154. package/inputtextarea/inputtextarea.d.ts +5 -0
  155. package/inputtextarea/inputtextarea.esm.js +3 -1
  156. package/inputtextarea/inputtextarea.esm.min.js +1 -1
  157. package/inputtextarea/inputtextarea.js +3 -1
  158. package/inputtextarea/inputtextarea.min.js +1 -1
  159. package/listbox/listbox.cjs.js +14 -10
  160. package/listbox/listbox.cjs.min.js +1 -1
  161. package/listbox/listbox.d.ts +15 -0
  162. package/listbox/listbox.esm.js +15 -11
  163. package/listbox/listbox.esm.min.js +1 -1
  164. package/listbox/listbox.js +14 -10
  165. package/listbox/listbox.min.js +1 -1
  166. package/mention/mention.cjs.js +3 -1
  167. package/mention/mention.cjs.min.js +1 -1
  168. package/mention/mention.esm.js +3 -1
  169. package/mention/mention.esm.min.js +1 -1
  170. package/mention/mention.js +3 -1
  171. package/mention/mention.min.js +1 -1
  172. package/menu/menu.cjs.js +3 -2
  173. package/menu/menu.cjs.min.js +1 -1
  174. package/menu/menu.esm.js +3 -2
  175. package/menu/menu.esm.min.js +1 -1
  176. package/menu/menu.js +3 -2
  177. package/menu/menu.min.js +1 -1
  178. package/menubar/menubar.cjs.js +1 -1
  179. package/menubar/menubar.cjs.min.js +1 -1
  180. package/menubar/menubar.esm.js +1 -1
  181. package/menubar/menubar.esm.min.js +1 -1
  182. package/menubar/menubar.js +1 -1
  183. package/menubar/menubar.min.js +1 -1
  184. package/message/message.cjs.js +2 -8
  185. package/message/message.cjs.min.js +1 -1
  186. package/message/message.d.ts +1 -1
  187. package/message/message.esm.js +2 -8
  188. package/message/message.esm.min.js +1 -1
  189. package/message/message.js +2 -8
  190. package/message/message.min.js +1 -1
  191. package/messages/messages.cjs.js +1 -1
  192. package/messages/messages.cjs.min.js +1 -1
  193. package/messages/messages.d.ts +1 -1
  194. package/messages/messages.esm.js +1 -1
  195. package/messages/messages.esm.min.js +1 -1
  196. package/messages/messages.js +1 -1
  197. package/messages/messages.min.js +1 -1
  198. package/metergroup/metergroup.cjs.js +237 -0
  199. package/metergroup/metergroup.cjs.min.js +1 -0
  200. package/metergroup/metergroup.d.ts +183 -0
  201. package/metergroup/metergroup.esm.js +233 -0
  202. package/metergroup/metergroup.esm.min.js +1 -0
  203. package/metergroup/metergroup.js +236 -0
  204. package/metergroup/metergroup.min.js +1 -0
  205. package/multiselect/multiselect.cjs.js +94 -123
  206. package/multiselect/multiselect.cjs.min.js +1 -1
  207. package/multiselect/multiselect.d.ts +25 -1
  208. package/multiselect/multiselect.esm.js +94 -123
  209. package/multiselect/multiselect.esm.min.js +1 -1
  210. package/multiselect/multiselect.js +94 -123
  211. package/multiselect/multiselect.min.js +1 -1
  212. package/multistatecheckbox/multistatecheckbox.cjs.js +1 -1
  213. package/multistatecheckbox/multistatecheckbox.cjs.min.js +1 -1
  214. package/multistatecheckbox/multistatecheckbox.esm.js +1 -1
  215. package/multistatecheckbox/multistatecheckbox.esm.min.js +1 -1
  216. package/multistatecheckbox/multistatecheckbox.js +1 -1
  217. package/multistatecheckbox/multistatecheckbox.min.js +1 -1
  218. package/orderlist/orderlist.cjs.js +35 -11
  219. package/orderlist/orderlist.cjs.min.js +1 -1
  220. package/orderlist/orderlist.d.ts +5 -0
  221. package/orderlist/orderlist.esm.js +35 -11
  222. package/orderlist/orderlist.esm.min.js +1 -1
  223. package/orderlist/orderlist.js +35 -11
  224. package/orderlist/orderlist.min.js +1 -1
  225. package/overlaypanel/overlaypanel.cjs.js +3 -2
  226. package/overlaypanel/overlaypanel.cjs.min.js +1 -1
  227. package/overlaypanel/overlaypanel.esm.js +3 -2
  228. package/overlaypanel/overlaypanel.esm.min.js +1 -1
  229. package/overlaypanel/overlaypanel.js +3 -2
  230. package/overlaypanel/overlaypanel.min.js +1 -1
  231. package/package.json +1 -1
  232. package/paginator/paginator.cjs.js +125 -108
  233. package/paginator/paginator.cjs.min.js +1 -1
  234. package/paginator/paginator.d.ts +88 -0
  235. package/paginator/paginator.esm.js +125 -108
  236. package/paginator/paginator.esm.min.js +1 -1
  237. package/paginator/paginator.js +125 -108
  238. package/paginator/paginator.min.js +1 -1
  239. package/panelmenu/panelmenu.cjs.js +13 -5
  240. package/panelmenu/panelmenu.cjs.min.js +1 -1
  241. package/panelmenu/panelmenu.esm.js +13 -5
  242. package/panelmenu/panelmenu.esm.min.js +1 -1
  243. package/panelmenu/panelmenu.js +13 -5
  244. package/panelmenu/panelmenu.min.js +1 -1
  245. package/passthrough/index.d.ts +12 -0
  246. package/passthrough/tailwind/index.cjs.js +268 -172
  247. package/passthrough/tailwind/index.cjs.min.js +1 -1
  248. package/passthrough/tailwind/index.esm.js +268 -172
  249. package/passthrough/tailwind/index.esm.min.js +1 -1
  250. package/passthrough/tailwind/index.js +268 -172
  251. package/passthrough/tailwind/index.min.js +1 -1
  252. package/password/password.cjs.js +70 -39
  253. package/password/password.cjs.min.js +1 -1
  254. package/password/password.d.ts +5 -0
  255. package/password/password.esm.js +72 -41
  256. package/password/password.esm.min.js +1 -1
  257. package/password/password.js +70 -39
  258. package/password/password.min.js +1 -1
  259. package/picklist/picklist.cjs.js +126 -101
  260. package/picklist/picklist.cjs.min.js +1 -1
  261. package/picklist/picklist.d.ts +5 -0
  262. package/picklist/picklist.esm.js +126 -101
  263. package/picklist/picklist.esm.min.js +1 -1
  264. package/picklist/picklist.js +126 -101
  265. package/picklist/picklist.min.js +1 -1
  266. package/primereact.all.cjs.js +1774 -1431
  267. package/primereact.all.cjs.min.js +1 -1
  268. package/primereact.all.esm.js +1775 -1431
  269. package/primereact.all.esm.min.js +1 -1
  270. package/primereact.all.js +1774 -1431
  271. package/primereact.all.min.js +1 -1
  272. package/radiobutton/radiobutton.cjs.js +67 -142
  273. package/radiobutton/radiobutton.cjs.min.js +1 -1
  274. package/radiobutton/radiobutton.d.ts +17 -35
  275. package/radiobutton/radiobutton.esm.js +68 -143
  276. package/radiobutton/radiobutton.esm.min.js +1 -1
  277. package/radiobutton/radiobutton.js +67 -142
  278. package/radiobutton/radiobutton.min.js +1 -1
  279. package/resources/themes/arya-blue/theme.css +344 -67
  280. package/resources/themes/arya-green/theme.css +344 -67
  281. package/resources/themes/arya-orange/theme.css +344 -67
  282. package/resources/themes/bootstrap4-dark-blue/theme.css +389 -64
  283. package/resources/themes/bootstrap4-light-blue/theme.css +389 -64
  284. package/resources/themes/fluent-light/theme.css +341 -64
  285. package/resources/themes/lara-dark-amber/theme.css +470 -67
  286. package/resources/themes/lara-dark-blue/theme.css +470 -67
  287. package/resources/themes/lara-dark-cyan/theme.css +470 -67
  288. package/resources/themes/lara-dark-green/theme.css +470 -67
  289. package/resources/themes/lara-dark-indigo/theme.css +470 -67
  290. package/resources/themes/lara-dark-pink/theme.css +470 -67
  291. package/resources/themes/lara-dark-teal/theme.css +470 -67
  292. package/resources/themes/lara-light-amber/theme.css +470 -67
  293. package/resources/themes/lara-light-blue/theme.css +470 -67
  294. package/resources/themes/lara-light-cyan/theme.css +470 -67
  295. package/resources/themes/lara-light-green/theme.css +470 -67
  296. package/resources/themes/lara-light-indigo/theme.css +470 -67
  297. package/resources/themes/lara-light-pink/theme.css +470 -67
  298. package/resources/themes/lara-light-teal/theme.css +470 -67
  299. package/resources/themes/luna-amber/theme.css +344 -67
  300. package/resources/themes/luna-blue/theme.css +344 -67
  301. package/resources/themes/luna-green/theme.css +344 -67
  302. package/resources/themes/luna-pink/theme.css +344 -67
  303. package/resources/themes/md-dark-deeppurple/theme.css +995 -289
  304. package/resources/themes/md-dark-indigo/theme.css +684 -232
  305. package/resources/themes/md-light-deeppurple/theme.css +868 -162
  306. package/resources/themes/md-light-indigo/theme.css +566 -101
  307. package/resources/themes/mdc-dark-deeppurple/theme.css +995 -289
  308. package/resources/themes/mdc-dark-indigo/theme.css +697 -232
  309. package/resources/themes/mdc-light-deeppurple/theme.css +868 -162
  310. package/resources/themes/mdc-light-indigo/theme.css +566 -101
  311. package/resources/themes/mira/theme.css +344 -67
  312. package/resources/themes/nano/theme.css +344 -67
  313. package/resources/themes/nova/theme.css +344 -67
  314. package/resources/themes/nova-accent/theme.css +344 -67
  315. package/resources/themes/nova-alt/theme.css +344 -67
  316. package/resources/themes/rhea/theme.css +343 -66
  317. package/resources/themes/saga-blue/theme.css +344 -67
  318. package/resources/themes/saga-green/theme.css +344 -67
  319. package/resources/themes/saga-orange/theme.css +344 -67
  320. package/resources/themes/soho-dark/theme.css +413 -88
  321. package/resources/themes/soho-light/theme.css +392 -67
  322. package/resources/themes/tailwind-light/theme.css +344 -67
  323. package/resources/themes/vela-blue/theme.css +344 -67
  324. package/resources/themes/vela-green/theme.css +344 -67
  325. package/resources/themes/vela-orange/theme.css +344 -67
  326. package/resources/themes/viva-dark/theme.css +392 -67
  327. package/resources/themes/viva-light/theme.css +392 -67
  328. package/selectbutton/selectbutton.cjs.js +12 -4
  329. package/selectbutton/selectbutton.cjs.min.js +1 -1
  330. package/selectbutton/selectbutton.d.ts +5 -0
  331. package/selectbutton/selectbutton.esm.js +12 -4
  332. package/selectbutton/selectbutton.esm.min.js +1 -1
  333. package/selectbutton/selectbutton.js +13 -5
  334. package/selectbutton/selectbutton.min.js +1 -1
  335. package/sidebar/sidebar.cjs.js +4 -3
  336. package/sidebar/sidebar.cjs.min.js +1 -1
  337. package/sidebar/sidebar.d.ts +4 -4
  338. package/sidebar/sidebar.esm.js +4 -3
  339. package/sidebar/sidebar.esm.min.js +1 -1
  340. package/sidebar/sidebar.js +4 -3
  341. package/sidebar/sidebar.min.js +1 -1
  342. package/slidemenu/slidemenu.cjs.js +3 -2
  343. package/slidemenu/slidemenu.cjs.min.js +1 -1
  344. package/slidemenu/slidemenu.esm.js +3 -2
  345. package/slidemenu/slidemenu.esm.min.js +1 -1
  346. package/slidemenu/slidemenu.js +3 -2
  347. package/slidemenu/slidemenu.min.js +1 -1
  348. package/slider/slider.cjs.js +18 -2
  349. package/slider/slider.cjs.min.js +1 -1
  350. package/slider/slider.esm.js +18 -2
  351. package/slider/slider.esm.min.js +1 -1
  352. package/slider/slider.js +18 -2
  353. package/slider/slider.min.js +1 -1
  354. package/splitbutton/splitbutton.d.ts +2 -2
  355. package/splitter/splitter.cjs.js +7 -7
  356. package/splitter/splitter.cjs.min.js +1 -1
  357. package/splitter/splitter.d.ts +5 -5
  358. package/splitter/splitter.esm.js +7 -7
  359. package/splitter/splitter.esm.min.js +1 -1
  360. package/splitter/splitter.js +7 -7
  361. package/splitter/splitter.min.js +1 -1
  362. package/styleclass/styleclass.cjs.js +21 -1
  363. package/styleclass/styleclass.cjs.min.js +1 -1
  364. package/styleclass/styleclass.d.ts +10 -0
  365. package/styleclass/styleclass.esm.js +21 -1
  366. package/styleclass/styleclass.esm.min.js +1 -1
  367. package/styleclass/styleclass.js +22 -2
  368. package/styleclass/styleclass.min.js +1 -1
  369. package/tabmenu/tabmenu.cjs.js +1 -1
  370. package/tabmenu/tabmenu.cjs.min.js +1 -1
  371. package/tabmenu/tabmenu.esm.js +1 -1
  372. package/tabmenu/tabmenu.esm.min.js +1 -1
  373. package/tabmenu/tabmenu.js +1 -1
  374. package/tabmenu/tabmenu.min.js +1 -1
  375. package/toast/toast.cjs.js +93 -92
  376. package/toast/toast.cjs.min.js +1 -1
  377. package/toast/toast.d.ts +1 -1
  378. package/toast/toast.esm.js +93 -92
  379. package/toast/toast.esm.min.js +1 -1
  380. package/toast/toast.js +93 -92
  381. package/toast/toast.min.js +1 -1
  382. package/togglebutton/togglebutton.cjs.js +54 -92
  383. package/togglebutton/togglebutton.cjs.min.js +1 -1
  384. package/togglebutton/togglebutton.d.ts +24 -0
  385. package/togglebutton/togglebutton.esm.js +53 -91
  386. package/togglebutton/togglebutton.esm.min.js +1 -1
  387. package/togglebutton/togglebutton.js +54 -92
  388. package/togglebutton/togglebutton.min.js +1 -1
  389. package/tooltip/tooltip.d.ts +3 -3
  390. package/tooltip/tooltipoptions.d.ts +5 -0
  391. package/tree/tree.cjs.js +20 -8
  392. package/tree/tree.cjs.min.js +1 -1
  393. package/tree/tree.esm.js +20 -8
  394. package/tree/tree.esm.min.js +1 -1
  395. package/tree/tree.js +20 -8
  396. package/tree/tree.min.js +1 -1
  397. package/treeselect/treeselect.cjs.js +2 -0
  398. package/treeselect/treeselect.cjs.min.js +1 -1
  399. package/treeselect/treeselect.d.ts +5 -0
  400. package/treeselect/treeselect.esm.js +2 -0
  401. package/treeselect/treeselect.esm.min.js +1 -1
  402. package/treeselect/treeselect.js +2 -0
  403. package/treeselect/treeselect.min.js +1 -1
  404. package/treetable/treetable.cjs.js +17 -14
  405. package/treetable/treetable.cjs.min.js +1 -1
  406. package/treetable/treetable.esm.js +17 -14
  407. package/treetable/treetable.esm.min.js +1 -1
  408. package/treetable/treetable.js +17 -14
  409. package/treetable/treetable.min.js +1 -1
  410. package/tristatecheckbox/tristatecheckbox.cjs.js +33 -90
  411. package/tristatecheckbox/tristatecheckbox.cjs.min.js +1 -1
  412. package/tristatecheckbox/tristatecheckbox.d.ts +12 -13
  413. package/tristatecheckbox/tristatecheckbox.esm.js +34 -91
  414. package/tristatecheckbox/tristatecheckbox.esm.min.js +1 -1
  415. package/tristatecheckbox/tristatecheckbox.js +33 -90
  416. package/tristatecheckbox/tristatecheckbox.min.js +1 -1
  417. package/utils/utils.cjs.js +64 -72
  418. package/utils/utils.cjs.min.js +1 -1
  419. package/utils/utils.d.ts +11 -2
  420. package/utils/utils.esm.js +65 -72
  421. package/utils/utils.esm.min.js +1 -1
  422. package/utils/utils.js +64 -72
  423. package/utils/utils.min.js +1 -1
  424. package/virtualscroller/virtualscroller.cjs.js +17 -15
  425. package/virtualscroller/virtualscroller.cjs.min.js +1 -1
  426. package/virtualscroller/virtualscroller.esm.js +14 -12
  427. package/virtualscroller/virtualscroller.esm.min.js +1 -1
  428. package/virtualscroller/virtualscroller.js +17 -15
  429. package/virtualscroller/virtualscroller.min.js +1 -1
  430. package/web-types.json +455 -39
@@ -213,6 +213,7 @@ var PasswordBase = componentbase.ComponentBase.extend({
213
213
  className: null,
214
214
  inputStyle: null,
215
215
  inputClassName: null,
216
+ invalid: false,
216
217
  panelStyle: null,
217
218
  panelClassName: null,
218
219
  transitionOptions: null,
@@ -329,6 +330,43 @@ var Password = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
329
330
  }
330
331
  }
331
332
  };
333
+ var updateFeedback = function updateFeedback(value) {
334
+ if (!props.feedback) {
335
+ return false;
336
+ }
337
+ var label = null;
338
+ var meter = null;
339
+ switch (testStrength(value)) {
340
+ case 1:
341
+ label = weakLabel;
342
+ meter = {
343
+ strength: 'weak',
344
+ width: '33.33%'
345
+ };
346
+ break;
347
+ case 2:
348
+ label = mediumLabel;
349
+ meter = {
350
+ strength: 'medium',
351
+ width: '66.66%'
352
+ };
353
+ break;
354
+ case 3:
355
+ label = strongLabel;
356
+ meter = {
357
+ strength: 'strong',
358
+ width: '100%'
359
+ };
360
+ break;
361
+ default:
362
+ label = promptLabel;
363
+ meter = null;
364
+ break;
365
+ }
366
+ setMeterState(meter);
367
+ setInfoTextState(label);
368
+ return true;
369
+ };
332
370
  var onPanelClick = function onPanelClick(event) {
333
371
  if (props.feedback) {
334
372
  overlayservice.OverlayService.emit('overlay-click', {
@@ -391,38 +429,6 @@ var Password = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
391
429
  var onKeyup = function onKeyup(e) {
392
430
  var keyCode = e.code;
393
431
  if (props.feedback) {
394
- var value = e.target.value;
395
- var label = null;
396
- var meter = null;
397
- switch (testStrength(value)) {
398
- case 1:
399
- label = weakLabel;
400
- meter = {
401
- strength: 'weak',
402
- width: '33.33%'
403
- };
404
- break;
405
- case 2:
406
- label = mediumLabel;
407
- meter = {
408
- strength: 'medium',
409
- width: '66.66%'
410
- };
411
- break;
412
- case 3:
413
- label = strongLabel;
414
- meter = {
415
- strength: 'strong',
416
- width: '100%'
417
- };
418
- break;
419
- default:
420
- label = promptLabel;
421
- meter = null;
422
- break;
423
- }
424
- setMeterState(meter);
425
- setInfoTextState(label);
426
432
  if (!!keyCode && keyCode !== 'Escape' && !overlayVisibleState) {
427
433
  show();
428
434
  }
@@ -438,7 +444,16 @@ var Password = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
438
444
  }
439
445
  };
440
446
  var testStrength = function testStrength(str) {
441
- if (strongCheckRegExp.current.test(str)) return 3;else if (mediumCheckRegExp.current.test(str)) return 2;else if (str.length) return 1;
447
+ if (!str || str.length === 0) {
448
+ return 0;
449
+ }
450
+ if (strongCheckRegExp.current.test(str)) {
451
+ return 3;
452
+ } else if (mediumCheckRegExp.current.test(str)) {
453
+ return 2;
454
+ } else if (str.length > 0) {
455
+ return 1;
456
+ }
442
457
  return 0;
443
458
  };
444
459
  React__namespace.useImperativeHandle(ref, function () {
@@ -473,27 +488,42 @@ var Password = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
473
488
  utils.DomHandler.removeClass(elementRef.current, 'p-inputwrapper-filled');
474
489
  }
475
490
  }, [isFilled]);
491
+ hooks.useUpdateEffect(function () {
492
+ updateFeedback(props.value);
493
+ }, [props.value]);
476
494
  hooks.useMountEffect(function () {
477
495
  alignOverlay();
478
496
  });
479
497
  hooks.useUnmountEffect(function () {
480
498
  utils.ZIndexUtils.clear(overlayRef.current);
481
499
  });
500
+ var onToggleMaskKeyDown = function onToggleMaskKeyDown(event) {
501
+ if (event.key === 'Enter' || event.code === 'Space') {
502
+ toggleMask();
503
+ event.preventDefault();
504
+ }
505
+ };
482
506
  var createIcon = function createIcon() {
483
507
  var icon;
484
508
  var hideIconProps = mergeProps({
485
509
  key: 'hideIcon',
486
- role: 'button',
487
- tabIndex: props.tabIndex,
510
+ role: 'switch',
511
+ tabIndex: props.tabIndex || '0',
488
512
  className: cx('hideIcon'),
489
- onClick: toggleMask
513
+ onClick: toggleMask,
514
+ onKeyDown: onToggleMaskKeyDown,
515
+ 'aria-label': PrimeReact.ariaLabel('passwordHide') || 'Hide Password',
516
+ 'aria-checked': 'false'
490
517
  }, ptm('hideIcon'));
491
518
  var showIconProps = mergeProps({
492
519
  key: 'showIcon',
493
- role: 'button',
494
- tabIndex: props.tabIndex,
520
+ role: 'switch',
521
+ tabIndex: props.tabIndex || '0',
495
522
  className: cx('showIcon'),
496
- onClick: toggleMask
523
+ onClick: toggleMask,
524
+ onKeyDown: onToggleMaskKeyDown,
525
+ 'aria-label': PrimeReact.ariaLabel('passwordShow') || 'Show Password',
526
+ 'aria-checked': 'true'
497
527
  }, ptm('showIcon'));
498
528
  if (unmaskedState) {
499
529
  icon = props.hideIcon || /*#__PURE__*/React__namespace.createElement(eyeslash.EyeSlashIcon, hideIconProps);
@@ -601,6 +631,7 @@ var Password = /*#__PURE__*/React__namespace.memo( /*#__PURE__*/React__namespace
601
631
  onFocus: onFocus,
602
632
  onInput: onInput,
603
633
  onKeyUp: onKeyup,
634
+ invalid: props.invalid,
604
635
  style: props.inputStyle,
605
636
  tabIndex: props.tabIndex,
606
637
  tooltip: props.tooltip,
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),n=require("primereact/componentbase"),r=require("primereact/csstransition"),o=require("primereact/hooks"),a=require("primereact/icons/eye"),l=require("primereact/icons/eyeslash"),i=require("primereact/inputtext"),s=require("primereact/overlayservice"),u=require("primereact/portal"),c=require("primereact/utils");function p(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function f(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var d=f(e),m=p(t);function y(){return y=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},y.apply(this,arguments)}function b(e){return b="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},b(e)}function g(e,t){if("object"!==b(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==b(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function w(e){var t=g(e,"string");return"symbol"===b(t)?t:String(t)}function h(e){if(Array.isArray(e))return e}function v(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,l,i=[],s=!0,u=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;s=!1}else for(;!(s=(r=a.call(n)).done)&&(i.push(r.value),i.length!==t);s=!0);}catch(e){u=!0,o=e}finally{try{if(!s&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(u)throw o}}return i}}function O(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function E(e,t){if(e){if("string"==typeof e)return O(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?O(e,t):void 0}}function x(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function I(e,t){return h(e)||v(e,t)||E(e,t)||x()}var S=n.ComponentBase.extend({defaultProps:{__TYPE:"Password",id:null,inputId:null,inputRef:null,promptLabel:null,weakLabel:null,mediumLabel:null,strongLabel:null,mediumRegex:"^(((?=.*[a-z])(?=.*[A-Z]))|((?=.*[a-z])(?=.*[0-9]))|((?=.*[A-Z])(?=.*[0-9])))(?=.{6,})",strongRegex:"^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.{8,})",feedback:!0,toggleMask:!1,appendTo:null,header:null,content:null,footer:null,showIcon:null,hideIcon:null,icon:null,tooltip:null,tooltipOptions:null,style:null,className:null,inputStyle:null,inputClassName:null,panelStyle:null,panelClassName:null,transitionOptions:null,tabIndex:null,value:void 0,onInput:null,onShow:null,onHide:null,children:void 0},css:{classes:{root:function(e){var t=e.props;return c.classNames("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":e.isFilled,"p-inputwrapper-focus":e.focusedState,"p-input-icon-right":t.toggleMask},t.className)},input:function(e){return c.classNames("p-password-input",e.props.inputClassName)},panel:function(e){var t=e.context;return c.classNames("p-password-panel p-component",e.props.panelClassName,{"p-input-filled":t&&"filled"===t.inputStyle||"filled"===m.default.inputStyle,"p-ripple-disabled":t&&!1===t.ripple||!1===m.default.ripple})},meter:"p-password-meter",meterLabel:function(e){return c.classNames("p-password-strength",e.strength)},info:function(e){return c.classNames("p-password-info",e.strength)},showIcon:"p-password-show-icon",hideIcon:"p-password-hide-icon",transition:"p-connected-overlay"},styles:"\n@layer primereact {\n .p-password {\n position: relative;\n display: inline-flex;\n }\n \n .p-password-panel {\n position: absolute;\n top: 0;\n left: 0;\n }\n \n .p-password .p-password-panel {\n min-width: 100%;\n }\n \n .p-password-meter {\n height: 10px;\n }\n \n .p-password-strength {\n height: 100%;\n width: 0%;\n transition: width 1s ease-in-out;\n }\n \n .p-fluid .p-password {\n display: flex;\n }\n \n .p-password-input::-ms-reveal,\n .p-password-input::-ms-clear {\n display: none;\n }\n\n .p-password .p-password-show-icon,\n .p-password .p-password-hide-icon {\n line-height: 1.5;\n cursor: pointer;\n }\n}\n"}});function j(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function k(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?j(Object(n),!0).forEach((function(t){var r,o,a;r=e,a=n[t],(o=w(o=t))in r?Object.defineProperty(r,o,{value:a,enumerable:!0,configurable:!0,writable:!0}):r[o]=a})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):j(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var N=d.memo(d.forwardRef((function(e,p){var f=o.useMergeProps(),b=d.useContext(t.PrimeReactContext),g=S.getProps(e,b),w=g.promptLabel||t.localeOption("passwordPrompt"),h=g.weakLabel||t.localeOption("weak"),v=g.mediumLabel||t.localeOption("medium"),O=g.strongLabel||t.localeOption("strong"),E=I(d.useState(!1),2),x=E[0],j=E[1],N=I(d.useState(null),2),P=N[0],R=N[1],C=I(d.useState(w),2),U=C[0],D=C[1],H=I(d.useState(!1),2),L=H[0],M=H[1],T=I(d.useState(!1),2),q=T[0],A=T[1],_=d.useRef(null),Z=d.useRef(null),z=d.useRef(g.inputRef),F=d.useRef(new RegExp(g.mediumRegex)),J=d.useRef(new RegExp(g.strongRegex)),K=q?"text":"password",X={props:g,state:{overlayVisible:x,meter:P,infoText:U,focused:L,unmasked:q}},B=S.setMetaData(X),V=B.ptm,G=B.cx;n.useHandleStyle(S.css.styles,B.isUnstyled,{name:"password"});var Y=o.useDisplayOrder("password",x);o.useGlobalOnEscapeKey({callback:function(){le()},when:x&&g.feedback&&Y,priority:[o.ESC_KEY_HANDLING_PRIORITIES.PASSWORD,Y]});var W=I(o.useOverlayListener({target:_,overlay:Z,listener:function(e,t){t.valid&&le()},when:x}),2),$=W[0],Q=W[1],ee=z.current&&z.current.value,te=d.useMemo((function(){return c.ObjectUtils.isNotEmpty(g.value)||c.ObjectUtils.isNotEmpty(g.defaultValue)||c.ObjectUtils.isNotEmpty(ee)}),[g.value,g.defaultValue,ee]),ne=function(){if(P){var e=null;switch(P.strength){case"weak":e=h;break;case"medium":e=v;break;case"strong":e=O}e&&U!==e&&D(e)}else U!==w&&D(w)},re=function(e){g.feedback&&s.OverlayService.emit("overlay-click",{originalEvent:e,target:_.current})},oe=function(){A((function(e){return!e}))},ae=function(){ne(),j(!0)},le=function(){j(!1)},ie=function(){z.current&&c.DomHandler.alignOverlay(Z.current,z.current.parentElement,g.appendTo||b&&b.appendTo||m.default.appendTo)},se=function(){c.ZIndexUtils.set("overlay",Z.current,b&&b.autoZIndex||m.default.autoZIndex,b&&b.zIndex.overlay||m.default.zIndex.overlay),c.DomHandler.addStyles(Z.current,{position:"absolute",top:"0",left:"0"}),ie()},ue=function(){$(),g.onShow&&g.onShow()},ce=function(){Q()},pe=function(){c.ZIndexUtils.clear(Z.current),g.onHide&&g.onHide()},fe=function(e){return J.current.test(e)?3:F.current.test(e)?2:e.length?1:0};d.useImperativeHandle(p,(function(){return{props:g,toggleMask:oe,focus:function(){return c.DomHandler.focus(z.current)},getElement:function(){return _.current},getOverlay:function(){return Z.current},getInput:function(){return z.current}}})),d.useEffect((function(){c.ObjectUtils.combinedRefs(z,g.inputRef)}),[z,g.inputRef]),d.useEffect((function(){F.current=new RegExp(g.mediumRegex)}),[g.mediumRegex]),d.useEffect((function(){J.current=new RegExp(g.strongRegex)}),[g.strongRegex]),d.useEffect((function(){!te&&c.DomHandler.hasClass(_.current,"p-inputwrapper-filled")&&c.DomHandler.removeClass(_.current,"p-inputwrapper-filled")}),[te]),o.useMountEffect((function(){ie()})),o.useUnmountEffect((function(){c.ZIndexUtils.clear(Z.current)}));var de=c.classNames("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":te,"p-inputwrapper-focus":L,"p-input-icon-right":g.toggleMask},g.className),me=S.getOtherProps(g),ye=function(){var e=f({key:"hideIcon",role:"button",tabIndex:g.tabIndex,className:G("hideIcon"),onClick:oe},V("hideIcon")),t=f({key:"showIcon",role:"button",tabIndex:g.tabIndex,className:G("showIcon"),onClick:oe},V("showIcon")),n=c.IconUtils.getJSXIcon(q?g.hideIcon||d.createElement(l.EyeSlashIcon,e):g.showIcon||d.createElement(a.EyeIcon,t),k({},q?e:t),{props:g});if(g.toggleMask){var r=n;if(g.icon)r=c.ObjectUtils.getJSXElement(g.icon,{onClick:oe,className:de,element:r,props:g});return r}return null}(),be=function(){var e=P||{strength:"",width:"0%"},t=e.strength,n=e.width,o=c.ObjectUtils.getJSXElement(g.header,g),a=c.ObjectUtils.getJSXElement(g.footer,g),l=f({className:G("panel",{context:b}),style:g.panelStyle,onClick:re},V("panel")),i=f({className:G("meter")},V("meter")),s=f({className:G("meterLabel",{strength:t}),style:{width:n}},V("meterLabel")),p=f({className:G("info",{strength:t})},V("info")),m=g.content?c.ObjectUtils.getJSXElement(g.content,g):d.createElement(d.Fragment,null,d.createElement("div",i,d.createElement("div",s)),d.createElement("div",p,U)),w=f({classNames:G("transition"),in:x,timeout:{enter:120,exit:100},options:g.transitionOptions,unmountOnExit:!0,onEnter:se,onEntered:ue,onExit:ce,onExited:pe},V("transition")),h=d.createElement(r.CSSTransition,y({nodeRef:Z},w),d.createElement("div",y({ref:Z},l),o,m,a));return d.createElement(u.Portal,{element:h,appendTo:g.appendTo})}(),ge=f({ref:_,id:g.id,className:G("root",{isFilled:te,focusedState:L}),style:g.style},V("root")),we=f(k(k({ref:z,id:g.inputId},me),{},{className:c.classNames(g.inputClassName,G("input")),onBlur:function(e){M(!1),g.feedback&&le(),g.onBlur&&g.onBlur(e)},onFocus:function(e){M(!0),g.feedback&&ae(),g.onFocus&&g.onFocus(e)},onInput:function(e,t){g.onInput&&g.onInput(e,t),g.onChange||(c.ObjectUtils.isNotEmpty(e.target.value)?c.DomHandler.addClass(_.current,"p-inputwrapper-filled"):c.DomHandler.removeClass(_.current,"p-inputwrapper-filled"))},onKeyUp:function(e){var t=e.code;if(g.feedback){var n=null,r=null;switch(fe(e.target.value)){case 1:n=h,r={strength:"weak",width:"33.33%"};break;case 2:n=v,r={strength:"medium",width:"66.66%"};break;case 3:n=O,r={strength:"strong",width:"100%"};break;default:n=w,r=null}R(r),D(n),t&&"Escape"!==t&&!x&&ae()}g.onKeyUp&&g.onKeyUp(e)},style:g.inputStyle,tabIndex:g.tabIndex,tooltip:g.tooltip,tooltipOptions:g.tooltipOptions,type:K,value:g.value,__parentMetadata:{parent:X}}),V("input"));return d.createElement("div",ge,d.createElement(i.InputText,we),ye,be)})));N.displayName="Password",exports.Password=N;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),n=require("primereact/componentbase"),r=require("primereact/csstransition"),o=require("primereact/hooks"),a=require("primereact/icons/eye"),l=require("primereact/icons/eyeslash"),i=require("primereact/inputtext"),s=require("primereact/overlayservice"),u=require("primereact/portal"),c=require("primereact/utils");function p(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function d(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var f=d(e),m=p(t);function y(){return y=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},y.apply(this,arguments)}function b(e){return b="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},b(e)}function w(e,t){if("object"!==b(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==b(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function g(e){var t=w(e,"string");return"symbol"===b(t)?t:String(t)}function h(e){if(Array.isArray(e))return e}function v(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,l,i=[],s=!0,u=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;s=!1}else for(;!(s=(r=a.call(n)).done)&&(i.push(r.value),i.length!==t);s=!0);}catch(e){u=!0,o=e}finally{try{if(!s&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(u)throw o}}return i}}function O(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function E(e,t){if(e){if("string"==typeof e)return O(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?O(e,t):void 0}}function S(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function x(e,t){return h(e)||v(e,t)||E(e,t)||S()}var I=n.ComponentBase.extend({defaultProps:{__TYPE:"Password",id:null,inputId:null,inputRef:null,promptLabel:null,weakLabel:null,mediumLabel:null,strongLabel:null,mediumRegex:"^(((?=.*[a-z])(?=.*[A-Z]))|((?=.*[a-z])(?=.*[0-9]))|((?=.*[A-Z])(?=.*[0-9])))(?=.{6,})",strongRegex:"^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.{8,})",feedback:!0,toggleMask:!1,appendTo:null,header:null,content:null,footer:null,showIcon:null,hideIcon:null,icon:null,tooltip:null,tooltipOptions:null,style:null,className:null,inputStyle:null,inputClassName:null,invalid:!1,panelStyle:null,panelClassName:null,transitionOptions:null,tabIndex:null,value:void 0,onInput:null,onShow:null,onHide:null,children:void 0},css:{classes:{root:function(e){var t=e.props;return c.classNames("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":e.isFilled,"p-inputwrapper-focus":e.focusedState,"p-input-icon-right":t.toggleMask},t.className)},input:function(e){return c.classNames("p-password-input",e.props.inputClassName)},panel:function(e){var t=e.context;return c.classNames("p-password-panel p-component",e.props.panelClassName,{"p-input-filled":t&&"filled"===t.inputStyle||"filled"===m.default.inputStyle,"p-ripple-disabled":t&&!1===t.ripple||!1===m.default.ripple})},meter:"p-password-meter",meterLabel:function(e){return c.classNames("p-password-strength",e.strength)},info:function(e){return c.classNames("p-password-info",e.strength)},showIcon:"p-password-show-icon",hideIcon:"p-password-hide-icon",transition:"p-connected-overlay"},styles:"\n@layer primereact {\n .p-password {\n position: relative;\n display: inline-flex;\n }\n \n .p-password-panel {\n position: absolute;\n top: 0;\n left: 0;\n }\n \n .p-password .p-password-panel {\n min-width: 100%;\n }\n \n .p-password-meter {\n height: 10px;\n }\n \n .p-password-strength {\n height: 100%;\n width: 0%;\n transition: width 1s ease-in-out;\n }\n \n .p-fluid .p-password {\n display: flex;\n }\n \n .p-password-input::-ms-reveal,\n .p-password-input::-ms-clear {\n display: none;\n }\n\n .p-password .p-password-show-icon,\n .p-password .p-password-hide-icon {\n line-height: 1.5;\n cursor: pointer;\n }\n}\n"}});function j(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function k(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?j(Object(n),!0).forEach((function(t){var r,o,a;r=e,a=n[t],(o=g(o=t))in r?Object.defineProperty(r,o,{value:a,enumerable:!0,configurable:!0,writable:!0}):r[o]=a})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):j(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var N=f.memo(f.forwardRef((function(e,p){var d=o.useMergeProps(),b=f.useContext(t.PrimeReactContext),w=I.getProps(e,b),g=w.promptLabel||t.localeOption("passwordPrompt"),h=w.weakLabel||t.localeOption("weak"),v=w.mediumLabel||t.localeOption("medium"),O=w.strongLabel||t.localeOption("strong"),E=x(f.useState(!1),2),S=E[0],j=E[1],N=x(f.useState(null),2),P=N[0],R=N[1],C=x(f.useState(g),2),U=C[0],D=C[1],H=x(f.useState(!1),2),L=H[0],M=H[1],T=x(f.useState(!1),2),q=T[0],A=T[1],_=f.useRef(null),Z=f.useRef(null),K=f.useRef(w.inputRef),z=f.useRef(new RegExp(w.mediumRegex)),F=f.useRef(new RegExp(w.strongRegex)),J=q?"text":"password",X={props:w,state:{overlayVisible:S,meter:P,infoText:U,focused:L,unmasked:q}},B=I.setMetaData(X),V=B.ptm,G=B.cx;n.useHandleStyle(I.css.styles,B.isUnstyled,{name:"password"});var Y=o.useDisplayOrder("password",S);o.useGlobalOnEscapeKey({callback:function(){ie()},when:S&&w.feedback&&Y,priority:[o.ESC_KEY_HANDLING_PRIORITIES.PASSWORD,Y]});var W=x(o.useOverlayListener({target:_,overlay:Z,listener:function(e,t){t.valid&&ie()},when:S}),2),$=W[0],Q=W[1],ee=K.current&&K.current.value,te=f.useMemo((function(){return c.ObjectUtils.isNotEmpty(w.value)||c.ObjectUtils.isNotEmpty(w.defaultValue)||c.ObjectUtils.isNotEmpty(ee)}),[w.value,w.defaultValue,ee]),ne=function(){if(P){var e=null;switch(P.strength){case"weak":e=h;break;case"medium":e=v;break;case"strong":e=O}e&&U!==e&&D(e)}else U!==g&&D(g)},re=function(e){if(!w.feedback)return!1;var t=null,n=null;switch(fe(e)){case 1:t=h,n={strength:"weak",width:"33.33%"};break;case 2:t=v,n={strength:"medium",width:"66.66%"};break;case 3:t=O,n={strength:"strong",width:"100%"};break;default:t=g,n=null}return R(n),D(t),!0},oe=function(e){w.feedback&&s.OverlayService.emit("overlay-click",{originalEvent:e,target:_.current})},ae=function(){A((function(e){return!e}))},le=function(){ne(),j(!0)},ie=function(){j(!1)},se=function(){K.current&&c.DomHandler.alignOverlay(Z.current,K.current.parentElement,w.appendTo||b&&b.appendTo||m.default.appendTo)},ue=function(){c.ZIndexUtils.set("overlay",Z.current,b&&b.autoZIndex||m.default.autoZIndex,b&&b.zIndex.overlay||m.default.zIndex.overlay),c.DomHandler.addStyles(Z.current,{position:"absolute",top:"0",left:"0"}),se()},ce=function(){$(),w.onShow&&w.onShow()},pe=function(){Q()},de=function(){c.ZIndexUtils.clear(Z.current),w.onHide&&w.onHide()},fe=function(e){return e&&0!==e.length?F.current.test(e)?3:z.current.test(e)?2:e.length>0?1:0:0};f.useImperativeHandle(p,(function(){return{props:w,toggleMask:ae,focus:function(){return c.DomHandler.focus(K.current)},getElement:function(){return _.current},getOverlay:function(){return Z.current},getInput:function(){return K.current}}})),f.useEffect((function(){c.ObjectUtils.combinedRefs(K,w.inputRef)}),[K,w.inputRef]),f.useEffect((function(){z.current=new RegExp(w.mediumRegex)}),[w.mediumRegex]),f.useEffect((function(){F.current=new RegExp(w.strongRegex)}),[w.strongRegex]),f.useEffect((function(){!te&&c.DomHandler.hasClass(_.current,"p-inputwrapper-filled")&&c.DomHandler.removeClass(_.current,"p-inputwrapper-filled")}),[te]),o.useUpdateEffect((function(){re(w.value)}),[w.value]),o.useMountEffect((function(){se()})),o.useUnmountEffect((function(){c.ZIndexUtils.clear(Z.current)}));var me=function(e){"Enter"!==e.key&&"Space"!==e.code||(ae(),e.preventDefault())},ye=c.classNames("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":te,"p-inputwrapper-focus":L,"p-input-icon-right":w.toggleMask},w.className),be=I.getOtherProps(w),we=function(){var e=d({key:"hideIcon",role:"switch",tabIndex:w.tabIndex||"0",className:G("hideIcon"),onClick:ae,onKeyDown:me,"aria-label":t.ariaLabel("passwordHide")||"Hide Password","aria-checked":"false"},V("hideIcon")),n=d({key:"showIcon",role:"switch",tabIndex:w.tabIndex||"0",className:G("showIcon"),onClick:ae,onKeyDown:me,"aria-label":t.ariaLabel("passwordShow")||"Show Password","aria-checked":"true"},V("showIcon")),r=c.IconUtils.getJSXIcon(q?w.hideIcon||f.createElement(l.EyeSlashIcon,e):w.showIcon||f.createElement(a.EyeIcon,n),k({},q?e:n),{props:w});if(w.toggleMask){var o=r;if(w.icon)o=c.ObjectUtils.getJSXElement(w.icon,{onClick:ae,className:ye,element:o,props:w});return o}return null}(),ge=function(){var e=P||{strength:"",width:"0%"},t=e.strength,n=e.width,o=c.ObjectUtils.getJSXElement(w.header,w),a=c.ObjectUtils.getJSXElement(w.footer,w),l=d({className:G("panel",{context:b}),style:w.panelStyle,onClick:oe},V("panel")),i=d({className:G("meter")},V("meter")),s=d({className:G("meterLabel",{strength:t}),style:{width:n}},V("meterLabel")),p=d({className:G("info",{strength:t})},V("info")),m=w.content?c.ObjectUtils.getJSXElement(w.content,w):f.createElement(f.Fragment,null,f.createElement("div",i,f.createElement("div",s)),f.createElement("div",p,U)),g=d({classNames:G("transition"),in:S,timeout:{enter:120,exit:100},options:w.transitionOptions,unmountOnExit:!0,onEnter:ue,onEntered:ce,onExit:pe,onExited:de},V("transition")),h=f.createElement(r.CSSTransition,y({nodeRef:Z},g),f.createElement("div",y({ref:Z},l),o,m,a));return f.createElement(u.Portal,{element:h,appendTo:w.appendTo})}(),he=d({ref:_,id:w.id,className:G("root",{isFilled:te,focusedState:L}),style:w.style},V("root")),ve=d(k(k({ref:K,id:w.inputId},be),{},{className:c.classNames(w.inputClassName,G("input")),onBlur:function(e){M(!1),w.feedback&&ie(),w.onBlur&&w.onBlur(e)},onFocus:function(e){M(!0),w.feedback&&le(),w.onFocus&&w.onFocus(e)},onInput:function(e,t){w.onInput&&w.onInput(e,t),w.onChange||(c.ObjectUtils.isNotEmpty(e.target.value)?c.DomHandler.addClass(_.current,"p-inputwrapper-filled"):c.DomHandler.removeClass(_.current,"p-inputwrapper-filled"))},onKeyUp:function(e){var t=e.code;w.feedback&&t&&"Escape"!==t&&!S&&le(),w.onKeyUp&&w.onKeyUp(e)},invalid:w.invalid,style:w.inputStyle,tabIndex:w.tabIndex,tooltip:w.tooltip,tooltipOptions:w.tooltipOptions,type:J,value:w.value,__parentMetadata:{parent:X}}),V("input"));return f.createElement("div",he,f.createElement(i.InputText,ve),we,ge)})));N.displayName="Password",exports.Password=N;
@@ -50,6 +50,11 @@ export interface PasswordPassThroughOptions {
50
50
  * Uses to pass attributes to the show icon's DOM element.
51
51
  */
52
52
  showIcon?: PasswordPassThroughType<React.SVGProps<SVGSVGElement> | React.HTMLAttributes<HTMLSpanElement>>;
53
+ /**
54
+ * When present, it specifies that the component should have invalid state style.
55
+ * @defaultValue false
56
+ */
57
+ invalid?: boolean | undefined;
53
58
  /**
54
59
  * Uses to pass attributes to the panel's DOM element.
55
60
  */
@@ -1,9 +1,9 @@
1
1
  'use client';
2
2
  import * as React from 'react';
3
- import PrimeReact, { PrimeReactContext, localeOption } from 'primereact/api';
3
+ import PrimeReact, { PrimeReactContext, localeOption, ariaLabel } from 'primereact/api';
4
4
  import { ComponentBase, useHandleStyle } from 'primereact/componentbase';
5
5
  import { CSSTransition } from 'primereact/csstransition';
6
- import { useMergeProps, useDisplayOrder, useGlobalOnEscapeKey, ESC_KEY_HANDLING_PRIORITIES, useOverlayListener, useMountEffect, useUnmountEffect } from 'primereact/hooks';
6
+ import { useMergeProps, useDisplayOrder, useGlobalOnEscapeKey, ESC_KEY_HANDLING_PRIORITIES, useOverlayListener, useUpdateEffect, useMountEffect, useUnmountEffect } from 'primereact/hooks';
7
7
  import { EyeIcon } from 'primereact/icons/eye';
8
8
  import { EyeSlashIcon } from 'primereact/icons/eyeslash';
9
9
  import { InputText } from 'primereact/inputtext';
@@ -186,6 +186,7 @@ var PasswordBase = ComponentBase.extend({
186
186
  className: null,
187
187
  inputStyle: null,
188
188
  inputClassName: null,
189
+ invalid: false,
189
190
  panelStyle: null,
190
191
  panelClassName: null,
191
192
  transitionOptions: null,
@@ -302,6 +303,43 @@ var Password = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (
302
303
  }
303
304
  }
304
305
  };
306
+ var updateFeedback = function updateFeedback(value) {
307
+ if (!props.feedback) {
308
+ return false;
309
+ }
310
+ var label = null;
311
+ var meter = null;
312
+ switch (testStrength(value)) {
313
+ case 1:
314
+ label = weakLabel;
315
+ meter = {
316
+ strength: 'weak',
317
+ width: '33.33%'
318
+ };
319
+ break;
320
+ case 2:
321
+ label = mediumLabel;
322
+ meter = {
323
+ strength: 'medium',
324
+ width: '66.66%'
325
+ };
326
+ break;
327
+ case 3:
328
+ label = strongLabel;
329
+ meter = {
330
+ strength: 'strong',
331
+ width: '100%'
332
+ };
333
+ break;
334
+ default:
335
+ label = promptLabel;
336
+ meter = null;
337
+ break;
338
+ }
339
+ setMeterState(meter);
340
+ setInfoTextState(label);
341
+ return true;
342
+ };
305
343
  var onPanelClick = function onPanelClick(event) {
306
344
  if (props.feedback) {
307
345
  OverlayService.emit('overlay-click', {
@@ -364,38 +402,6 @@ var Password = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (
364
402
  var onKeyup = function onKeyup(e) {
365
403
  var keyCode = e.code;
366
404
  if (props.feedback) {
367
- var value = e.target.value;
368
- var label = null;
369
- var meter = null;
370
- switch (testStrength(value)) {
371
- case 1:
372
- label = weakLabel;
373
- meter = {
374
- strength: 'weak',
375
- width: '33.33%'
376
- };
377
- break;
378
- case 2:
379
- label = mediumLabel;
380
- meter = {
381
- strength: 'medium',
382
- width: '66.66%'
383
- };
384
- break;
385
- case 3:
386
- label = strongLabel;
387
- meter = {
388
- strength: 'strong',
389
- width: '100%'
390
- };
391
- break;
392
- default:
393
- label = promptLabel;
394
- meter = null;
395
- break;
396
- }
397
- setMeterState(meter);
398
- setInfoTextState(label);
399
405
  if (!!keyCode && keyCode !== 'Escape' && !overlayVisibleState) {
400
406
  show();
401
407
  }
@@ -411,7 +417,16 @@ var Password = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (
411
417
  }
412
418
  };
413
419
  var testStrength = function testStrength(str) {
414
- if (strongCheckRegExp.current.test(str)) return 3;else if (mediumCheckRegExp.current.test(str)) return 2;else if (str.length) return 1;
420
+ if (!str || str.length === 0) {
421
+ return 0;
422
+ }
423
+ if (strongCheckRegExp.current.test(str)) {
424
+ return 3;
425
+ } else if (mediumCheckRegExp.current.test(str)) {
426
+ return 2;
427
+ } else if (str.length > 0) {
428
+ return 1;
429
+ }
415
430
  return 0;
416
431
  };
417
432
  React.useImperativeHandle(ref, function () {
@@ -446,27 +461,42 @@ var Password = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (
446
461
  DomHandler.removeClass(elementRef.current, 'p-inputwrapper-filled');
447
462
  }
448
463
  }, [isFilled]);
464
+ useUpdateEffect(function () {
465
+ updateFeedback(props.value);
466
+ }, [props.value]);
449
467
  useMountEffect(function () {
450
468
  alignOverlay();
451
469
  });
452
470
  useUnmountEffect(function () {
453
471
  ZIndexUtils.clear(overlayRef.current);
454
472
  });
473
+ var onToggleMaskKeyDown = function onToggleMaskKeyDown(event) {
474
+ if (event.key === 'Enter' || event.code === 'Space') {
475
+ toggleMask();
476
+ event.preventDefault();
477
+ }
478
+ };
455
479
  var createIcon = function createIcon() {
456
480
  var icon;
457
481
  var hideIconProps = mergeProps({
458
482
  key: 'hideIcon',
459
- role: 'button',
460
- tabIndex: props.tabIndex,
483
+ role: 'switch',
484
+ tabIndex: props.tabIndex || '0',
461
485
  className: cx('hideIcon'),
462
- onClick: toggleMask
486
+ onClick: toggleMask,
487
+ onKeyDown: onToggleMaskKeyDown,
488
+ 'aria-label': ariaLabel('passwordHide') || 'Hide Password',
489
+ 'aria-checked': 'false'
463
490
  }, ptm('hideIcon'));
464
491
  var showIconProps = mergeProps({
465
492
  key: 'showIcon',
466
- role: 'button',
467
- tabIndex: props.tabIndex,
493
+ role: 'switch',
494
+ tabIndex: props.tabIndex || '0',
468
495
  className: cx('showIcon'),
469
- onClick: toggleMask
496
+ onClick: toggleMask,
497
+ onKeyDown: onToggleMaskKeyDown,
498
+ 'aria-label': ariaLabel('passwordShow') || 'Show Password',
499
+ 'aria-checked': 'true'
470
500
  }, ptm('showIcon'));
471
501
  if (unmaskedState) {
472
502
  icon = props.hideIcon || /*#__PURE__*/React.createElement(EyeSlashIcon, hideIconProps);
@@ -574,6 +604,7 @@ var Password = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(function (
574
604
  onFocus: onFocus,
575
605
  onInput: onInput,
576
606
  onKeyUp: onKeyup,
607
+ invalid: props.invalid,
577
608
  style: props.inputStyle,
578
609
  tabIndex: props.tabIndex,
579
610
  tooltip: props.tooltip,
@@ -1 +1 @@
1
- import*as e from"react";import t,{PrimeReactContext as n,localeOption as r}from"primereact/api";import{ComponentBase as o,useHandleStyle as i}from"primereact/componentbase";import{CSSTransition as a}from"primereact/csstransition";import{useMergeProps as l,useDisplayOrder as s,useGlobalOnEscapeKey as u,ESC_KEY_HANDLING_PRIORITIES as p,useOverlayListener as c,useMountEffect as f,useUnmountEffect as m}from"primereact/hooks";import{EyeIcon as d}from"primereact/icons/eye";import{EyeSlashIcon as y}from"primereact/icons/eyeslash";import{InputText as g}from"primereact/inputtext";import{OverlayService as w}from"primereact/overlayservice";import{Portal as b}from"primereact/portal";import{classNames as h,ObjectUtils as v,DomHandler as E,ZIndexUtils as x,IconUtils as S}from"primereact/utils";function O(){return O=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},O.apply(this,arguments)}function I(e){return I="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},I(e)}function k(e,t){if("object"!==I(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==I(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function R(e){var t=k(e,"string");return"symbol"===I(t)?t:String(t)}function N(e){if(Array.isArray(e))return e}function j(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,i,a,l=[],s=!0,u=!1;try{if(i=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;s=!1}else for(;!(s=(r=i.call(n)).done)&&(l.push(r.value),l.length!==t);s=!0);}catch(e){u=!0,o=e}finally{try{if(!s&&null!=n.return&&(a=n.return(),Object(a)!==a))return}finally{if(u)throw o}}return l}}function P(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function C(e,t){if(e){if("string"==typeof e)return P(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?P(e,t):void 0}}function L(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function A(e,t){return N(e)||j(e,t)||C(e,t)||L()}var T=o.extend({defaultProps:{__TYPE:"Password",id:null,inputId:null,inputRef:null,promptLabel:null,weakLabel:null,mediumLabel:null,strongLabel:null,mediumRegex:"^(((?=.*[a-z])(?=.*[A-Z]))|((?=.*[a-z])(?=.*[0-9]))|((?=.*[A-Z])(?=.*[0-9])))(?=.{6,})",strongRegex:"^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.{8,})",feedback:!0,toggleMask:!1,appendTo:null,header:null,content:null,footer:null,showIcon:null,hideIcon:null,icon:null,tooltip:null,tooltipOptions:null,style:null,className:null,inputStyle:null,inputClassName:null,panelStyle:null,panelClassName:null,transitionOptions:null,tabIndex:null,value:void 0,onInput:null,onShow:null,onHide:null,children:void 0},css:{classes:{root:function(e){var t=e.props;return h("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":e.isFilled,"p-inputwrapper-focus":e.focusedState,"p-input-icon-right":t.toggleMask},t.className)},input:function(e){return h("p-password-input",e.props.inputClassName)},panel:function(e){var n=e.context;return h("p-password-panel p-component",e.props.panelClassName,{"p-input-filled":n&&"filled"===n.inputStyle||"filled"===t.inputStyle,"p-ripple-disabled":n&&!1===n.ripple||!1===t.ripple})},meter:"p-password-meter",meterLabel:function(e){return h("p-password-strength",e.strength)},info:function(e){return h("p-password-info",e.strength)},showIcon:"p-password-show-icon",hideIcon:"p-password-hide-icon",transition:"p-connected-overlay"},styles:"\n@layer primereact {\n .p-password {\n position: relative;\n display: inline-flex;\n }\n \n .p-password-panel {\n position: absolute;\n top: 0;\n left: 0;\n }\n \n .p-password .p-password-panel {\n min-width: 100%;\n }\n \n .p-password-meter {\n height: 10px;\n }\n \n .p-password-strength {\n height: 100%;\n width: 0%;\n transition: width 1s ease-in-out;\n }\n \n .p-fluid .p-password {\n display: flex;\n }\n \n .p-password-input::-ms-reveal,\n .p-password-input::-ms-clear {\n display: none;\n }\n\n .p-password .p-password-show-icon,\n .p-password .p-password-hide-icon {\n line-height: 1.5;\n cursor: pointer;\n }\n}\n"}});function M(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function D(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?M(Object(n),!0).forEach((function(t){var r,o,i;r=e,i=n[t],(o=R(o=t))in r?Object.defineProperty(r,o,{value:i,enumerable:!0,configurable:!0,writable:!0}):r[o]=i})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):M(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var F=e.memo(e.forwardRef((function(o,I){var k=l(),R=e.useContext(n),N=T.getProps(o,R),j=N.promptLabel||r("passwordPrompt"),P=N.weakLabel||r("weak"),C=N.mediumLabel||r("medium"),L=N.strongLabel||r("strong"),M=A(e.useState(!1),2),F=M[0],z=M[1],J=A(e.useState(null),2),U=J[0],X=J[1],Z=A(e.useState(j),2),H=Z[0],_=Z[1],B=A(e.useState(!1),2),K=B[0],V=B[1],W=A(e.useState(!1),2),Y=W[0],$=W[1],q=e.useRef(null),G=e.useRef(null),Q=e.useRef(N.inputRef),ee=e.useRef(new RegExp(N.mediumRegex)),te=e.useRef(new RegExp(N.strongRegex)),ne=Y?"text":"password",re={props:N,state:{overlayVisible:F,meter:U,infoText:H,focused:K,unmasked:Y}},oe=T.setMetaData(re),ie=oe.ptm,ae=oe.cx;i(T.css.styles,oe.isUnstyled,{name:"password"});var le=s("password",F);u({callback:function(){we()},when:F&&N.feedback&&le,priority:[p.PASSWORD,le]});var se=A(c({target:q,overlay:G,listener:function(e,t){t.valid&&we()},when:F}),2),ue=se[0],pe=se[1],ce=Q.current&&Q.current.value,fe=e.useMemo((function(){return v.isNotEmpty(N.value)||v.isNotEmpty(N.defaultValue)||v.isNotEmpty(ce)}),[N.value,N.defaultValue,ce]),me=function(){if(U){var e=null;switch(U.strength){case"weak":e=P;break;case"medium":e=C;break;case"strong":e=L}e&&H!==e&&_(e)}else H!==j&&_(j)},de=function(e){N.feedback&&w.emit("overlay-click",{originalEvent:e,target:q.current})},ye=function(){$((function(e){return!e}))},ge=function(){me(),z(!0)},we=function(){z(!1)},be=function(){Q.current&&E.alignOverlay(G.current,Q.current.parentElement,N.appendTo||R&&R.appendTo||t.appendTo)},he=function(){x.set("overlay",G.current,R&&R.autoZIndex||t.autoZIndex,R&&R.zIndex.overlay||t.zIndex.overlay),E.addStyles(G.current,{position:"absolute",top:"0",left:"0"}),be()},ve=function(){ue(),N.onShow&&N.onShow()},Ee=function(){pe()},xe=function(){x.clear(G.current),N.onHide&&N.onHide()},Se=function(e){return te.current.test(e)?3:ee.current.test(e)?2:e.length?1:0};e.useImperativeHandle(I,(function(){return{props:N,toggleMask:ye,focus:function(){return E.focus(Q.current)},getElement:function(){return q.current},getOverlay:function(){return G.current},getInput:function(){return Q.current}}})),e.useEffect((function(){v.combinedRefs(Q,N.inputRef)}),[Q,N.inputRef]),e.useEffect((function(){ee.current=new RegExp(N.mediumRegex)}),[N.mediumRegex]),e.useEffect((function(){te.current=new RegExp(N.strongRegex)}),[N.strongRegex]),e.useEffect((function(){!fe&&E.hasClass(q.current,"p-inputwrapper-filled")&&E.removeClass(q.current,"p-inputwrapper-filled")}),[fe]),f((function(){be()})),m((function(){x.clear(G.current)}));var Oe=h("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":fe,"p-inputwrapper-focus":K,"p-input-icon-right":N.toggleMask},N.className),Ie=T.getOtherProps(N),ke=function(){var t=k({key:"hideIcon",role:"button",tabIndex:N.tabIndex,className:ae("hideIcon"),onClick:ye},ie("hideIcon")),n=k({key:"showIcon",role:"button",tabIndex:N.tabIndex,className:ae("showIcon"),onClick:ye},ie("showIcon")),r=S.getJSXIcon(Y?N.hideIcon||e.createElement(y,t):N.showIcon||e.createElement(d,n),D({},Y?t:n),{props:N});if(N.toggleMask){var o=r;if(N.icon)o=v.getJSXElement(N.icon,{onClick:ye,className:Oe,element:o,props:N});return o}return null}(),Re=function(){var t=U||{strength:"",width:"0%"},n=t.strength,r=t.width,o=v.getJSXElement(N.header,N),i=v.getJSXElement(N.footer,N),l=k({className:ae("panel",{context:R}),style:N.panelStyle,onClick:de},ie("panel")),s=k({className:ae("meter")},ie("meter")),u=k({className:ae("meterLabel",{strength:n}),style:{width:r}},ie("meterLabel")),p=k({className:ae("info",{strength:n})},ie("info")),c=N.content?v.getJSXElement(N.content,N):e.createElement(e.Fragment,null,e.createElement("div",s,e.createElement("div",u)),e.createElement("div",p,H)),f=k({classNames:ae("transition"),in:F,timeout:{enter:120,exit:100},options:N.transitionOptions,unmountOnExit:!0,onEnter:he,onEntered:ve,onExit:Ee,onExited:xe},ie("transition")),m=e.createElement(a,O({nodeRef:G},f),e.createElement("div",O({ref:G},l),o,c,i));return e.createElement(b,{element:m,appendTo:N.appendTo})}(),Ne=k({ref:q,id:N.id,className:ae("root",{isFilled:fe,focusedState:K}),style:N.style},ie("root")),je=k(D(D({ref:Q,id:N.inputId},Ie),{},{className:h(N.inputClassName,ae("input")),onBlur:function(e){V(!1),N.feedback&&we(),N.onBlur&&N.onBlur(e)},onFocus:function(e){V(!0),N.feedback&&ge(),N.onFocus&&N.onFocus(e)},onInput:function(e,t){N.onInput&&N.onInput(e,t),N.onChange||(v.isNotEmpty(e.target.value)?E.addClass(q.current,"p-inputwrapper-filled"):E.removeClass(q.current,"p-inputwrapper-filled"))},onKeyUp:function(e){var t=e.code;if(N.feedback){var n=null,r=null;switch(Se(e.target.value)){case 1:n=P,r={strength:"weak",width:"33.33%"};break;case 2:n=C,r={strength:"medium",width:"66.66%"};break;case 3:n=L,r={strength:"strong",width:"100%"};break;default:n=j,r=null}X(r),_(n),t&&"Escape"!==t&&!F&&ge()}N.onKeyUp&&N.onKeyUp(e)},style:N.inputStyle,tabIndex:N.tabIndex,tooltip:N.tooltip,tooltipOptions:N.tooltipOptions,type:ne,value:N.value,__parentMetadata:{parent:re}}),ie("input"));return e.createElement("div",Ne,e.createElement(g,je),ke,Re)})));F.displayName="Password";export{F as Password};
1
+ import*as e from"react";import t,{PrimeReactContext as n,localeOption as r,ariaLabel as o}from"primereact/api";import{ComponentBase as a,useHandleStyle as i}from"primereact/componentbase";import{CSSTransition as l}from"primereact/csstransition";import{useMergeProps as s,useDisplayOrder as u,useGlobalOnEscapeKey as p,ESC_KEY_HANDLING_PRIORITIES as c,useOverlayListener as f,useUpdateEffect as d,useMountEffect as m,useUnmountEffect as w}from"primereact/hooks";import{EyeIcon as y}from"primereact/icons/eye";import{EyeSlashIcon as g}from"primereact/icons/eyeslash";import{InputText as h}from"primereact/inputtext";import{OverlayService as b}from"primereact/overlayservice";import{Portal as v}from"primereact/portal";import{classNames as E,ObjectUtils as S,DomHandler as x,ZIndexUtils as k,IconUtils as O}from"primereact/utils";function I(){return I=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},I.apply(this,arguments)}function R(e){return R="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},R(e)}function N(e,t){if("object"!==R(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==R(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function j(e){var t=N(e,"string");return"symbol"===R(t)?t:String(t)}function P(e){if(Array.isArray(e))return e}function C(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,a,i,l=[],s=!0,u=!1;try{if(a=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;s=!1}else for(;!(s=(r=a.call(n)).done)&&(l.push(r.value),l.length!==t);s=!0);}catch(e){u=!0,o=e}finally{try{if(!s&&null!=n.return&&(i=n.return(),Object(i)!==i))return}finally{if(u)throw o}}return l}}function L(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function A(e,t){if(e){if("string"==typeof e)return L(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?L(e,t):void 0}}function T(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function D(e,t){return P(e)||C(e,t)||A(e,t)||T()}var M=a.extend({defaultProps:{__TYPE:"Password",id:null,inputId:null,inputRef:null,promptLabel:null,weakLabel:null,mediumLabel:null,strongLabel:null,mediumRegex:"^(((?=.*[a-z])(?=.*[A-Z]))|((?=.*[a-z])(?=.*[0-9]))|((?=.*[A-Z])(?=.*[0-9])))(?=.{6,})",strongRegex:"^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.{8,})",feedback:!0,toggleMask:!1,appendTo:null,header:null,content:null,footer:null,showIcon:null,hideIcon:null,icon:null,tooltip:null,tooltipOptions:null,style:null,className:null,inputStyle:null,inputClassName:null,invalid:!1,panelStyle:null,panelClassName:null,transitionOptions:null,tabIndex:null,value:void 0,onInput:null,onShow:null,onHide:null,children:void 0},css:{classes:{root:function(e){var t=e.props;return E("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":e.isFilled,"p-inputwrapper-focus":e.focusedState,"p-input-icon-right":t.toggleMask},t.className)},input:function(e){return E("p-password-input",e.props.inputClassName)},panel:function(e){var n=e.context;return E("p-password-panel p-component",e.props.panelClassName,{"p-input-filled":n&&"filled"===n.inputStyle||"filled"===t.inputStyle,"p-ripple-disabled":n&&!1===n.ripple||!1===t.ripple})},meter:"p-password-meter",meterLabel:function(e){return E("p-password-strength",e.strength)},info:function(e){return E("p-password-info",e.strength)},showIcon:"p-password-show-icon",hideIcon:"p-password-hide-icon",transition:"p-connected-overlay"},styles:"\n@layer primereact {\n .p-password {\n position: relative;\n display: inline-flex;\n }\n \n .p-password-panel {\n position: absolute;\n top: 0;\n left: 0;\n }\n \n .p-password .p-password-panel {\n min-width: 100%;\n }\n \n .p-password-meter {\n height: 10px;\n }\n \n .p-password-strength {\n height: 100%;\n width: 0%;\n transition: width 1s ease-in-out;\n }\n \n .p-fluid .p-password {\n display: flex;\n }\n \n .p-password-input::-ms-reveal,\n .p-password-input::-ms-clear {\n display: none;\n }\n\n .p-password .p-password-show-icon,\n .p-password .p-password-hide-icon {\n line-height: 1.5;\n cursor: pointer;\n }\n}\n"}});function F(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function H(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?F(Object(n),!0).forEach((function(t){var r,o,a;r=e,a=n[t],(o=j(o=t))in r?Object.defineProperty(r,o,{value:a,enumerable:!0,configurable:!0,writable:!0}):r[o]=a})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):F(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var z=e.memo(e.forwardRef((function(a,R){var N=s(),j=e.useContext(n),P=M.getProps(a,j),C=P.promptLabel||r("passwordPrompt"),L=P.weakLabel||r("weak"),A=P.mediumLabel||r("medium"),T=P.strongLabel||r("strong"),F=D(e.useState(!1),2),z=F[0],J=F[1],K=D(e.useState(null),2),U=K[0],X=K[1],Z=D(e.useState(C),2),_=Z[0],B=Z[1],V=D(e.useState(!1),2),W=V[0],Y=V[1],$=D(e.useState(!1),2),q=$[0],G=$[1],Q=e.useRef(null),ee=e.useRef(null),te=e.useRef(P.inputRef),ne=e.useRef(new RegExp(P.mediumRegex)),re=e.useRef(new RegExp(P.strongRegex)),oe=q?"text":"password",ae={props:P,state:{overlayVisible:z,meter:U,infoText:_,focused:W,unmasked:q}},ie=M.setMetaData(ae),le=ie.ptm,se=ie.cx;i(M.css.styles,ie.isUnstyled,{name:"password"});var ue=u("password",z);p({callback:function(){ve()},when:z&&P.feedback&&ue,priority:[c.PASSWORD,ue]});var pe=D(f({target:Q,overlay:ee,listener:function(e,t){t.valid&&ve()},when:z}),2),ce=pe[0],fe=pe[1],de=te.current&&te.current.value,me=e.useMemo((function(){return S.isNotEmpty(P.value)||S.isNotEmpty(P.defaultValue)||S.isNotEmpty(de)}),[P.value,P.defaultValue,de]),we=function(){if(U){var e=null;switch(U.strength){case"weak":e=L;break;case"medium":e=A;break;case"strong":e=T}e&&_!==e&&B(e)}else _!==C&&B(C)},ye=function(e){if(!P.feedback)return!1;var t=null,n=null;switch(Ie(e)){case 1:t=L,n={strength:"weak",width:"33.33%"};break;case 2:t=A,n={strength:"medium",width:"66.66%"};break;case 3:t=T,n={strength:"strong",width:"100%"};break;default:t=C,n=null}return X(n),B(t),!0},ge=function(e){P.feedback&&b.emit("overlay-click",{originalEvent:e,target:Q.current})},he=function(){G((function(e){return!e}))},be=function(){we(),J(!0)},ve=function(){J(!1)},Ee=function(){te.current&&x.alignOverlay(ee.current,te.current.parentElement,P.appendTo||j&&j.appendTo||t.appendTo)},Se=function(){k.set("overlay",ee.current,j&&j.autoZIndex||t.autoZIndex,j&&j.zIndex.overlay||t.zIndex.overlay),x.addStyles(ee.current,{position:"absolute",top:"0",left:"0"}),Ee()},xe=function(){ce(),P.onShow&&P.onShow()},ke=function(){fe()},Oe=function(){k.clear(ee.current),P.onHide&&P.onHide()},Ie=function(e){return e&&0!==e.length?re.current.test(e)?3:ne.current.test(e)?2:e.length>0?1:0:0};e.useImperativeHandle(R,(function(){return{props:P,toggleMask:he,focus:function(){return x.focus(te.current)},getElement:function(){return Q.current},getOverlay:function(){return ee.current},getInput:function(){return te.current}}})),e.useEffect((function(){S.combinedRefs(te,P.inputRef)}),[te,P.inputRef]),e.useEffect((function(){ne.current=new RegExp(P.mediumRegex)}),[P.mediumRegex]),e.useEffect((function(){re.current=new RegExp(P.strongRegex)}),[P.strongRegex]),e.useEffect((function(){!me&&x.hasClass(Q.current,"p-inputwrapper-filled")&&x.removeClass(Q.current,"p-inputwrapper-filled")}),[me]),d((function(){ye(P.value)}),[P.value]),m((function(){Ee()})),w((function(){k.clear(ee.current)}));var Re=function(e){"Enter"!==e.key&&"Space"!==e.code||(he(),e.preventDefault())},Ne=E("p-password p-component p-inputwrapper",{"p-inputwrapper-filled":me,"p-inputwrapper-focus":W,"p-input-icon-right":P.toggleMask},P.className),je=M.getOtherProps(P),Pe=function(){var t=N({key:"hideIcon",role:"switch",tabIndex:P.tabIndex||"0",className:se("hideIcon"),onClick:he,onKeyDown:Re,"aria-label":o("passwordHide")||"Hide Password","aria-checked":"false"},le("hideIcon")),n=N({key:"showIcon",role:"switch",tabIndex:P.tabIndex||"0",className:se("showIcon"),onClick:he,onKeyDown:Re,"aria-label":o("passwordShow")||"Show Password","aria-checked":"true"},le("showIcon")),r=O.getJSXIcon(q?P.hideIcon||e.createElement(g,t):P.showIcon||e.createElement(y,n),H({},q?t:n),{props:P});if(P.toggleMask){var a=r;if(P.icon)a=S.getJSXElement(P.icon,{onClick:he,className:Ne,element:a,props:P});return a}return null}(),Ce=function(){var t=U||{strength:"",width:"0%"},n=t.strength,r=t.width,o=S.getJSXElement(P.header,P),a=S.getJSXElement(P.footer,P),i=N({className:se("panel",{context:j}),style:P.panelStyle,onClick:ge},le("panel")),s=N({className:se("meter")},le("meter")),u=N({className:se("meterLabel",{strength:n}),style:{width:r}},le("meterLabel")),p=N({className:se("info",{strength:n})},le("info")),c=P.content?S.getJSXElement(P.content,P):e.createElement(e.Fragment,null,e.createElement("div",s,e.createElement("div",u)),e.createElement("div",p,_)),f=N({classNames:se("transition"),in:z,timeout:{enter:120,exit:100},options:P.transitionOptions,unmountOnExit:!0,onEnter:Se,onEntered:xe,onExit:ke,onExited:Oe},le("transition")),d=e.createElement(l,I({nodeRef:ee},f),e.createElement("div",I({ref:ee},i),o,c,a));return e.createElement(v,{element:d,appendTo:P.appendTo})}(),Le=N({ref:Q,id:P.id,className:se("root",{isFilled:me,focusedState:W}),style:P.style},le("root")),Ae=N(H(H({ref:te,id:P.inputId},je),{},{className:E(P.inputClassName,se("input")),onBlur:function(e){Y(!1),P.feedback&&ve(),P.onBlur&&P.onBlur(e)},onFocus:function(e){Y(!0),P.feedback&&be(),P.onFocus&&P.onFocus(e)},onInput:function(e,t){P.onInput&&P.onInput(e,t),P.onChange||(S.isNotEmpty(e.target.value)?x.addClass(Q.current,"p-inputwrapper-filled"):x.removeClass(Q.current,"p-inputwrapper-filled"))},onKeyUp:function(e){var t=e.code;P.feedback&&t&&"Escape"!==t&&!z&&be(),P.onKeyUp&&P.onKeyUp(e)},invalid:P.invalid,style:P.inputStyle,tabIndex:P.tabIndex,tooltip:P.tooltip,tooltipOptions:P.tooltipOptions,type:oe,value:P.value,__parentMetadata:{parent:ae}}),le("input"));return e.createElement("div",Le,e.createElement(h,Ae),Pe,Ce)})));z.displayName="Password";export{z as Password};
@@ -200,6 +200,7 @@ this.primereact.password = (function (exports, React, PrimeReact, componentbase,
200
200
  className: null,
201
201
  inputStyle: null,
202
202
  inputClassName: null,
203
+ invalid: false,
203
204
  panelStyle: null,
204
205
  panelClassName: null,
205
206
  transitionOptions: null,
@@ -316,6 +317,43 @@ this.primereact.password = (function (exports, React, PrimeReact, componentbase,
316
317
  }
317
318
  }
318
319
  };
320
+ var updateFeedback = function updateFeedback(value) {
321
+ if (!props.feedback) {
322
+ return false;
323
+ }
324
+ var label = null;
325
+ var meter = null;
326
+ switch (testStrength(value)) {
327
+ case 1:
328
+ label = weakLabel;
329
+ meter = {
330
+ strength: 'weak',
331
+ width: '33.33%'
332
+ };
333
+ break;
334
+ case 2:
335
+ label = mediumLabel;
336
+ meter = {
337
+ strength: 'medium',
338
+ width: '66.66%'
339
+ };
340
+ break;
341
+ case 3:
342
+ label = strongLabel;
343
+ meter = {
344
+ strength: 'strong',
345
+ width: '100%'
346
+ };
347
+ break;
348
+ default:
349
+ label = promptLabel;
350
+ meter = null;
351
+ break;
352
+ }
353
+ setMeterState(meter);
354
+ setInfoTextState(label);
355
+ return true;
356
+ };
319
357
  var onPanelClick = function onPanelClick(event) {
320
358
  if (props.feedback) {
321
359
  overlayservice.OverlayService.emit('overlay-click', {
@@ -378,38 +416,6 @@ this.primereact.password = (function (exports, React, PrimeReact, componentbase,
378
416
  var onKeyup = function onKeyup(e) {
379
417
  var keyCode = e.code;
380
418
  if (props.feedback) {
381
- var value = e.target.value;
382
- var label = null;
383
- var meter = null;
384
- switch (testStrength(value)) {
385
- case 1:
386
- label = weakLabel;
387
- meter = {
388
- strength: 'weak',
389
- width: '33.33%'
390
- };
391
- break;
392
- case 2:
393
- label = mediumLabel;
394
- meter = {
395
- strength: 'medium',
396
- width: '66.66%'
397
- };
398
- break;
399
- case 3:
400
- label = strongLabel;
401
- meter = {
402
- strength: 'strong',
403
- width: '100%'
404
- };
405
- break;
406
- default:
407
- label = promptLabel;
408
- meter = null;
409
- break;
410
- }
411
- setMeterState(meter);
412
- setInfoTextState(label);
413
419
  if (!!keyCode && keyCode !== 'Escape' && !overlayVisibleState) {
414
420
  show();
415
421
  }
@@ -425,7 +431,16 @@ this.primereact.password = (function (exports, React, PrimeReact, componentbase,
425
431
  }
426
432
  };
427
433
  var testStrength = function testStrength(str) {
428
- if (strongCheckRegExp.current.test(str)) return 3;else if (mediumCheckRegExp.current.test(str)) return 2;else if (str.length) return 1;
434
+ if (!str || str.length === 0) {
435
+ return 0;
436
+ }
437
+ if (strongCheckRegExp.current.test(str)) {
438
+ return 3;
439
+ } else if (mediumCheckRegExp.current.test(str)) {
440
+ return 2;
441
+ } else if (str.length > 0) {
442
+ return 1;
443
+ }
429
444
  return 0;
430
445
  };
431
446
  React__namespace.useImperativeHandle(ref, function () {
@@ -460,27 +475,42 @@ this.primereact.password = (function (exports, React, PrimeReact, componentbase,
460
475
  utils.DomHandler.removeClass(elementRef.current, 'p-inputwrapper-filled');
461
476
  }
462
477
  }, [isFilled]);
478
+ hooks.useUpdateEffect(function () {
479
+ updateFeedback(props.value);
480
+ }, [props.value]);
463
481
  hooks.useMountEffect(function () {
464
482
  alignOverlay();
465
483
  });
466
484
  hooks.useUnmountEffect(function () {
467
485
  utils.ZIndexUtils.clear(overlayRef.current);
468
486
  });
487
+ var onToggleMaskKeyDown = function onToggleMaskKeyDown(event) {
488
+ if (event.key === 'Enter' || event.code === 'Space') {
489
+ toggleMask();
490
+ event.preventDefault();
491
+ }
492
+ };
469
493
  var createIcon = function createIcon() {
470
494
  var icon;
471
495
  var hideIconProps = mergeProps({
472
496
  key: 'hideIcon',
473
- role: 'button',
474
- tabIndex: props.tabIndex,
497
+ role: 'switch',
498
+ tabIndex: props.tabIndex || '0',
475
499
  className: cx('hideIcon'),
476
- onClick: toggleMask
500
+ onClick: toggleMask,
501
+ onKeyDown: onToggleMaskKeyDown,
502
+ 'aria-label': PrimeReact.ariaLabel('passwordHide') || 'Hide Password',
503
+ 'aria-checked': 'false'
477
504
  }, ptm('hideIcon'));
478
505
  var showIconProps = mergeProps({
479
506
  key: 'showIcon',
480
- role: 'button',
481
- tabIndex: props.tabIndex,
507
+ role: 'switch',
508
+ tabIndex: props.tabIndex || '0',
482
509
  className: cx('showIcon'),
483
- onClick: toggleMask
510
+ onClick: toggleMask,
511
+ onKeyDown: onToggleMaskKeyDown,
512
+ 'aria-label': PrimeReact.ariaLabel('passwordShow') || 'Show Password',
513
+ 'aria-checked': 'true'
484
514
  }, ptm('showIcon'));
485
515
  if (unmaskedState) {
486
516
  icon = props.hideIcon || /*#__PURE__*/React__namespace.createElement(eyeslash.EyeSlashIcon, hideIconProps);
@@ -588,6 +618,7 @@ this.primereact.password = (function (exports, React, PrimeReact, componentbase,
588
618
  onFocus: onFocus,
589
619
  onInput: onInput,
590
620
  onKeyUp: onKeyup,
621
+ invalid: props.invalid,
591
622
  style: props.inputStyle,
592
623
  tabIndex: props.tabIndex,
593
624
  tooltip: props.tooltip,