@tylertech/forge 3.0.0-next.1 → 3.0.0-next.11

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 (773) hide show
  1. package/custom-elements.json +18061 -12338
  2. package/dist/button/forge-button.css +1 -1
  3. package/dist/esm/accordion/index.js +1 -1
  4. package/dist/esm/app-bar/help-button/index.js +1 -1
  5. package/dist/esm/app-bar/index.js +1 -1
  6. package/dist/esm/app-bar/menu-button/index.js +1 -1
  7. package/dist/esm/app-bar/notification-button/index.js +1 -1
  8. package/dist/esm/app-bar/profile-button/index.js +1 -1
  9. package/dist/esm/app-bar/search/index.js +1 -1
  10. package/dist/esm/autocomplete/index.js +1 -1
  11. package/dist/esm/avatar/index.js +1 -1
  12. package/dist/esm/backdrop/index.js +1 -1
  13. package/dist/esm/badge/index.js +1 -1
  14. package/dist/esm/banner/index.js +1 -1
  15. package/dist/esm/bottom-sheet/index.js +1 -1
  16. package/dist/esm/busy-indicator/index.js +1 -1
  17. package/dist/esm/button/index.js +1 -1
  18. package/dist/esm/button-toggle/button-toggle/index.js +1 -1
  19. package/dist/esm/button-toggle/button-toggle-group/index.js +1 -1
  20. package/dist/esm/button-toggle/index.js +1 -1
  21. package/dist/esm/calendar/calendar-dropdown/index.js +1 -1
  22. package/dist/esm/calendar/calendar-menu/index.js +1 -1
  23. package/dist/esm/calendar/core/index.js +1 -1
  24. package/dist/esm/calendar/index.js +1 -1
  25. package/dist/esm/card/index.js +1 -1
  26. package/dist/esm/checkbox/index.js +1 -1
  27. package/dist/esm/chip-field/index.js +1 -1
  28. package/dist/esm/chips/chip/index.js +1 -1
  29. package/dist/esm/chips/chip-set/index.js +1 -1
  30. package/dist/esm/chips/index.js +1 -1
  31. package/dist/esm/chunks/chunk.2AJ7FFI6.js +7 -0
  32. package/dist/esm/chunks/chunk.2AJ7FFI6.js.map +7 -0
  33. package/dist/esm/chunks/{chunk.SSRQFKNH.js → chunk.2EWV2XBP.js} +2 -2
  34. package/dist/esm/chunks/{chunk.SSRQFKNH.js.map → chunk.2EWV2XBP.js.map} +1 -1
  35. package/dist/esm/chunks/chunk.2QHD3DCR.js +7 -0
  36. package/dist/esm/chunks/chunk.2QHD3DCR.js.map +7 -0
  37. package/dist/esm/chunks/{chunk.BJZ7RB5F.js → chunk.3CTKWBV2.js} +1 -1
  38. package/dist/esm/chunks/{chunk.BJZ7RB5F.js.map → chunk.3CTKWBV2.js.map} +1 -1
  39. package/dist/esm/chunks/chunk.3HB22HCX.js +7 -0
  40. package/dist/esm/chunks/chunk.44IUAOBP.js +7 -0
  41. package/dist/esm/chunks/{chunk.YPZNIYQL.js.map → chunk.44IUAOBP.js.map} +2 -2
  42. package/dist/esm/chunks/chunk.4C6KHYUO.js +7 -0
  43. package/dist/esm/chunks/{chunk.SXTTEIIH.js → chunk.4YFVG4KP.js} +2 -2
  44. package/dist/esm/chunks/{chunk.SXTTEIIH.js.map → chunk.4YFVG4KP.js.map} +1 -1
  45. package/dist/esm/chunks/chunk.4ZKX3SO5.js +7 -0
  46. package/dist/esm/chunks/{chunk.5WNKQTXX.js.map → chunk.4ZKX3SO5.js.map} +2 -2
  47. package/dist/esm/chunks/chunk.54OOOQ4R.js +7 -0
  48. package/dist/esm/chunks/chunk.54OOOQ4R.js.map +7 -0
  49. package/dist/esm/chunks/chunk.5565ZSTH.js +7 -0
  50. package/dist/esm/chunks/chunk.5565ZSTH.js.map +7 -0
  51. package/dist/esm/chunks/chunk.5MZ5SGMO.js +7 -0
  52. package/dist/esm/chunks/chunk.5MZ5SGMO.js.map +7 -0
  53. package/dist/esm/chunks/{chunk.7UKA4E5A.js → chunk.624UKZFU.js} +2 -2
  54. package/dist/esm/chunks/{chunk.7UKA4E5A.js.map → chunk.624UKZFU.js.map} +1 -1
  55. package/dist/esm/chunks/chunk.6GC5AJPE.js +7 -0
  56. package/dist/esm/chunks/chunk.6GC5AJPE.js.map +7 -0
  57. package/dist/esm/chunks/{chunk.CLM6MNKC.js → chunk.6OUJSOJY.js} +2 -2
  58. package/dist/esm/chunks/{chunk.CLM6MNKC.js.map → chunk.6OUJSOJY.js.map} +1 -1
  59. package/dist/esm/chunks/{chunk.TR5YMNJJ.js → chunk.6OW6Q3EW.js} +2 -2
  60. package/dist/esm/chunks/{chunk.TR5YMNJJ.js.map → chunk.6OW6Q3EW.js.map} +1 -1
  61. package/dist/esm/chunks/chunk.7CGKFRBK.js +7 -0
  62. package/dist/esm/chunks/chunk.7CGKFRBK.js.map +7 -0
  63. package/dist/esm/chunks/chunk.7DB3XVPI.js +7 -0
  64. package/dist/esm/chunks/chunk.7DB3XVPI.js.map +7 -0
  65. package/dist/esm/chunks/chunk.7TMLILLW.js +7 -0
  66. package/dist/esm/chunks/{chunk.ZFHPUAYX.js.map → chunk.7TMLILLW.js.map} +2 -2
  67. package/dist/esm/chunks/{chunk.KU5CXXGS.js → chunk.A62DE5PD.js} +2 -2
  68. package/dist/esm/chunks/chunk.AEKOP3XT.js +7 -0
  69. package/dist/esm/chunks/chunk.AEKOP3XT.js.map +7 -0
  70. package/dist/esm/chunks/chunk.ALIYGJXA.js +129 -0
  71. package/dist/esm/chunks/chunk.ALIYGJXA.js.map +7 -0
  72. package/dist/esm/chunks/chunk.B4T3R53C.js +7 -0
  73. package/dist/esm/chunks/{chunk.6OKJPSUE.js.map → chunk.B4T3R53C.js.map} +2 -2
  74. package/dist/esm/chunks/chunk.BH2TUG2V.js +7 -0
  75. package/dist/esm/chunks/chunk.BH2TUG2V.js.map +7 -0
  76. package/dist/esm/chunks/chunk.BKL2BAYW.js +7 -0
  77. package/dist/esm/chunks/{chunk.G5MGGEFP.js.map → chunk.BKL2BAYW.js.map} +1 -1
  78. package/dist/esm/chunks/chunk.BY25RT52.js +7 -0
  79. package/dist/esm/chunks/chunk.BY25RT52.js.map +7 -0
  80. package/dist/esm/chunks/chunk.CDGZYUQS.js +7 -0
  81. package/dist/esm/chunks/{chunk.RB5BTA5N.js.map → chunk.CDGZYUQS.js.map} +2 -2
  82. package/dist/esm/chunks/chunk.CKW7KKDW.js +7 -0
  83. package/dist/esm/chunks/{chunk.4NI63FGK.js.map → chunk.CKW7KKDW.js.map} +2 -2
  84. package/dist/esm/chunks/{chunk.RYMPSU4J.js → chunk.COVTBIQQ.js} +2 -2
  85. package/dist/esm/chunks/{chunk.RYMPSU4J.js.map → chunk.COVTBIQQ.js.map} +2 -2
  86. package/dist/esm/chunks/{chunk.G45OZEIS.js → chunk.CWTV3TB3.js} +2 -2
  87. package/dist/esm/chunks/chunk.CXY6K7EI.js +7 -0
  88. package/dist/esm/chunks/{chunk.ROR6JMAE.js.map → chunk.CXY6K7EI.js.map} +1 -1
  89. package/dist/esm/chunks/chunk.D5TAI6Q7.js +7 -0
  90. package/dist/esm/chunks/{chunk.BTBHIIGI.js.map → chunk.D5TAI6Q7.js.map} +1 -1
  91. package/dist/esm/chunks/chunk.DBNJHUYY.js +7 -0
  92. package/dist/esm/chunks/chunk.DBNJHUYY.js.map +7 -0
  93. package/dist/esm/chunks/{chunk.WP4QOOIS.js → chunk.DG4ZM3AW.js} +2 -2
  94. package/dist/esm/chunks/{chunk.U6WGJELL.js → chunk.DMCBAYQX.js} +1 -1
  95. package/dist/esm/chunks/{chunk.U6WGJELL.js.map → chunk.DMCBAYQX.js.map} +1 -1
  96. package/dist/esm/chunks/{chunk.BE7PZANN.js → chunk.DXN7ZOH3.js} +2 -2
  97. package/dist/esm/chunks/{chunk.BE7PZANN.js.map → chunk.DXN7ZOH3.js.map} +1 -1
  98. package/dist/esm/chunks/chunk.EK24Y56W.js +7 -0
  99. package/dist/esm/chunks/chunk.F4VXEE76.js +7 -0
  100. package/dist/esm/chunks/chunk.F4VXEE76.js.map +7 -0
  101. package/dist/esm/chunks/chunk.F5SY2D4B.js +7 -0
  102. package/dist/esm/chunks/{chunk.DT7MZR5Y.js.map → chunk.F5SY2D4B.js.map} +3 -3
  103. package/dist/esm/chunks/chunk.F74YURLV.js +7 -0
  104. package/dist/esm/chunks/chunk.F74YURLV.js.map +7 -0
  105. package/dist/esm/chunks/chunk.FCATJM34.js +7 -0
  106. package/dist/esm/chunks/chunk.FCATJM34.js.map +7 -0
  107. package/dist/esm/chunks/{chunk.3KQL7VAZ.js → chunk.FDZSLGIW.js} +2 -2
  108. package/dist/esm/chunks/{chunk.3KQL7VAZ.js.map → chunk.FDZSLGIW.js.map} +1 -1
  109. package/dist/esm/chunks/chunk.FG2GNAM2.js +7 -0
  110. package/dist/esm/chunks/chunk.FG2GNAM2.js.map +7 -0
  111. package/dist/esm/chunks/{chunk.UT7QUGAO.js → chunk.FWFOOQMA.js} +2 -2
  112. package/dist/esm/chunks/{chunk.MZLPUI6R.js → chunk.FYWPZFLJ.js} +2 -2
  113. package/dist/esm/chunks/{chunk.MZLPUI6R.js.map → chunk.FYWPZFLJ.js.map} +2 -2
  114. package/dist/esm/chunks/chunk.GNG64TXK.js +7 -0
  115. package/dist/esm/chunks/chunk.GNG64TXK.js.map +7 -0
  116. package/dist/esm/chunks/chunk.HHCO64F3.js +7 -0
  117. package/dist/esm/chunks/chunk.HHCO64F3.js.map +7 -0
  118. package/dist/esm/chunks/chunk.HRGTAVNA.js +7 -0
  119. package/dist/esm/chunks/{chunk.J6WCFQSS.js.map → chunk.HRGTAVNA.js.map} +2 -2
  120. package/dist/esm/chunks/chunk.ISC7SZSP.js +7 -0
  121. package/dist/esm/chunks/chunk.ISC7SZSP.js.map +7 -0
  122. package/dist/esm/chunks/{chunk.ZUNZKRRK.js → chunk.IX25DYIM.js} +2 -2
  123. package/dist/esm/chunks/chunk.JIKSKUDW.js +7 -0
  124. package/dist/esm/chunks/chunk.JIKSKUDW.js.map +7 -0
  125. package/dist/esm/chunks/{chunk.F2B24WLK.js → chunk.JLLHDJSO.js} +2 -2
  126. package/dist/esm/chunks/{chunk.F2B24WLK.js.map → chunk.JLLHDJSO.js.map} +1 -1
  127. package/dist/esm/chunks/chunk.JUJGROHA.js +7 -0
  128. package/dist/esm/chunks/{chunk.YBEBD4CN.js.map → chunk.JUJGROHA.js.map} +1 -1
  129. package/dist/esm/chunks/{chunk.UBD2DPQN.js → chunk.K3KAM2PL.js} +2 -2
  130. package/dist/esm/chunks/{chunk.UBD2DPQN.js.map → chunk.K3KAM2PL.js.map} +1 -1
  131. package/dist/esm/chunks/{chunk.PN26D52V.js → chunk.K7FPXAFS.js} +2 -2
  132. package/dist/esm/chunks/{chunk.PN26D52V.js.map → chunk.K7FPXAFS.js.map} +3 -3
  133. package/dist/esm/chunks/chunk.KJP2VA6Q.js +7 -0
  134. package/dist/esm/chunks/chunk.KJP2VA6Q.js.map +7 -0
  135. package/dist/esm/chunks/{chunk.ARJ3EVVO.js → chunk.KVCDAZ6B.js} +2 -2
  136. package/dist/esm/chunks/{chunk.4DAIIJ37.js → chunk.LEVFMI2Q.js} +1 -1
  137. package/dist/esm/chunks/{chunk.4DAIIJ37.js.map → chunk.LEVFMI2Q.js.map} +1 -1
  138. package/dist/esm/chunks/{chunk.77Y3EABF.js → chunk.LFODKHUO.js} +2 -2
  139. package/dist/esm/chunks/{chunk.77Y3EABF.js.map → chunk.LFODKHUO.js.map} +1 -1
  140. package/dist/esm/chunks/{chunk.XQ2EQIDS.js → chunk.LK4AAUOP.js} +2 -2
  141. package/dist/esm/chunks/{chunk.XQ2EQIDS.js.map → chunk.LK4AAUOP.js.map} +2 -2
  142. package/dist/esm/chunks/{chunk.H4Z4DHPA.js → chunk.LTT67HTW.js} +2 -2
  143. package/dist/esm/chunks/chunk.LXPFG7MW.js +7 -0
  144. package/dist/esm/chunks/chunk.LXPFG7MW.js.map +7 -0
  145. package/dist/esm/chunks/chunk.M3QDAYD2.js +7 -0
  146. package/dist/esm/chunks/chunk.M56LSSPW.js +7 -0
  147. package/dist/esm/chunks/{chunk.Y5A7RQ5M.js.map → chunk.M56LSSPW.js.map} +1 -1
  148. package/dist/esm/chunks/chunk.MACPUZC2.js +7 -0
  149. package/dist/esm/chunks/chunk.MACPUZC2.js.map +7 -0
  150. package/dist/esm/chunks/{chunk.O73S5LF3.js → chunk.MGLL67VO.js} +2 -2
  151. package/dist/esm/chunks/chunk.MGLWXAZO.js +18 -0
  152. package/dist/esm/chunks/{chunk.YI4JTY4T.js.map → chunk.MGLWXAZO.js.map} +2 -2
  153. package/dist/esm/chunks/{chunk.XZ4WI7VK.js → chunk.MHBBMC6O.js} +2 -2
  154. package/dist/esm/chunks/{chunk.XZ4WI7VK.js.map → chunk.MHBBMC6O.js.map} +1 -1
  155. package/dist/esm/chunks/{chunk.HBMNXZES.js → chunk.MTKSU2BV.js} +2 -2
  156. package/dist/esm/chunks/{chunk.HBMNXZES.js.map → chunk.MTKSU2BV.js.map} +1 -1
  157. package/dist/esm/chunks/chunk.MVTBJPO2.js +7 -0
  158. package/dist/esm/chunks/{chunk.Y4GKBJGI.js.map → chunk.MVTBJPO2.js.map} +3 -3
  159. package/dist/esm/chunks/chunk.MXEKIEJA.js +7 -0
  160. package/dist/esm/chunks/chunk.MXEKIEJA.js.map +7 -0
  161. package/dist/esm/chunks/chunk.N43BCJHN.js +7 -0
  162. package/dist/esm/chunks/chunk.N43BCJHN.js.map +7 -0
  163. package/dist/esm/chunks/{chunk.VC2BG2RS.js → chunk.NR3MLTXF.js} +2 -2
  164. package/dist/esm/chunks/{chunk.VC2BG2RS.js.map → chunk.NR3MLTXF.js.map} +1 -1
  165. package/dist/esm/chunks/{chunk.KTGSZEAG.js → chunk.NVUMRW44.js} +1 -1
  166. package/dist/esm/chunks/{chunk.KTGSZEAG.js.map → chunk.NVUMRW44.js.map} +1 -1
  167. package/dist/esm/chunks/{chunk.MLV25D2G.js → chunk.OWCYRSI3.js} +2 -2
  168. package/dist/esm/chunks/chunk.P2CW5MQO.js +12 -0
  169. package/dist/esm/chunks/chunk.P2CW5MQO.js.map +7 -0
  170. package/dist/esm/chunks/{chunk.N4PVZUJX.js → chunk.P2ZCNO63.js} +2 -2
  171. package/dist/esm/chunks/{chunk.N4PVZUJX.js.map → chunk.P2ZCNO63.js.map} +2 -2
  172. package/dist/esm/chunks/chunk.PADPL4L3.js +7 -0
  173. package/dist/esm/chunks/{chunk.47A2CN5U.js.map → chunk.PADPL4L3.js.map} +1 -1
  174. package/dist/esm/chunks/chunk.PEBT47AU.js +7 -0
  175. package/dist/esm/chunks/chunk.PEBT47AU.js.map +7 -0
  176. package/dist/esm/chunks/chunk.PH3HUFJJ.js +7 -0
  177. package/dist/esm/chunks/{chunk.JHBCYICS.js.map → chunk.PH3HUFJJ.js.map} +1 -1
  178. package/dist/esm/chunks/chunk.Q7JUJNYD.js +7 -0
  179. package/dist/esm/chunks/chunk.Q7JUJNYD.js.map +7 -0
  180. package/dist/esm/chunks/chunk.Q7Z3SJ5F.js +7 -0
  181. package/dist/esm/chunks/{chunk.4BEI55KI.js.map → chunk.Q7Z3SJ5F.js.map} +1 -1
  182. package/dist/esm/chunks/chunk.QCRRHGBA.js +7 -0
  183. package/dist/esm/chunks/chunk.QCRRHGBA.js.map +7 -0
  184. package/dist/esm/chunks/{chunk.IUOBRBDZ.js → chunk.QOJESHEV.js} +2 -2
  185. package/dist/esm/chunks/chunk.S3JMOOWC.js +7 -0
  186. package/dist/esm/chunks/{chunk.4WPFFNLH.js.map → chunk.S3JMOOWC.js.map} +1 -1
  187. package/dist/esm/chunks/{chunk.O4FB4BV5.js → chunk.SBYX7VZ4.js} +2 -2
  188. package/dist/esm/chunks/{chunk.O4FB4BV5.js.map → chunk.SBYX7VZ4.js.map} +2 -2
  189. package/dist/esm/chunks/{chunk.XUW3GG46.js → chunk.SFCGOCQK.js} +2 -2
  190. package/dist/esm/chunks/chunk.SJJS4LYN.js +7 -0
  191. package/dist/esm/chunks/chunk.SJJS4LYN.js.map +7 -0
  192. package/dist/esm/chunks/{chunk.P3IA2WTO.js → chunk.SMGXXR6K.js} +2 -2
  193. package/dist/esm/chunks/{chunk.P3IA2WTO.js.map → chunk.SMGXXR6K.js.map} +1 -1
  194. package/dist/esm/chunks/{chunk.PALRSBSY.js → chunk.SU4FU7GK.js} +2 -2
  195. package/dist/esm/chunks/{chunk.PALRSBSY.js.map → chunk.SU4FU7GK.js.map} +1 -1
  196. package/dist/esm/chunks/{chunk.XHV3GQ7L.js → chunk.TK5I4RHF.js} +2 -2
  197. package/dist/esm/chunks/{chunk.XHV3GQ7L.js.map → chunk.TK5I4RHF.js.map} +2 -2
  198. package/dist/esm/chunks/{chunk.BJE6O5ES.js → chunk.TYLOAD7R.js} +2 -2
  199. package/dist/esm/chunks/{chunk.BJE6O5ES.js.map → chunk.TYLOAD7R.js.map} +2 -2
  200. package/dist/esm/chunks/chunk.UJ2WQOLO.js +7 -0
  201. package/dist/esm/chunks/{chunk.E6CYXNS2.js.map → chunk.UJ2WQOLO.js.map} +2 -2
  202. package/dist/esm/chunks/{chunk.J2H5RXTX.js → chunk.ULY4H76N.js} +2 -2
  203. package/dist/esm/chunks/{chunk.J2H5RXTX.js.map → chunk.ULY4H76N.js.map} +1 -1
  204. package/dist/esm/chunks/{chunk.DONAMICM.js → chunk.UV3WIHCM.js} +1 -1
  205. package/dist/esm/chunks/{chunk.DONAMICM.js.map → chunk.UV3WIHCM.js.map} +1 -1
  206. package/dist/esm/chunks/{chunk.T76JYRPR.js → chunk.VSQOTSAO.js} +2 -2
  207. package/dist/esm/chunks/{chunk.T76JYRPR.js.map → chunk.VSQOTSAO.js.map} +2 -2
  208. package/dist/esm/chunks/chunk.VVXSELXX.js +7 -0
  209. package/dist/esm/chunks/chunk.VVXSELXX.js.map +7 -0
  210. package/dist/esm/chunks/chunk.VZWNNK7A.js +7 -0
  211. package/dist/esm/chunks/chunk.VZWNNK7A.js.map +7 -0
  212. package/dist/esm/chunks/chunk.W4247Q2P.js +7 -0
  213. package/dist/esm/chunks/{chunk.MHOS3IHQ.js.map → chunk.W4247Q2P.js.map} +1 -1
  214. package/dist/esm/chunks/chunk.WPG7NNQX.js +7 -0
  215. package/dist/esm/chunks/chunk.WPG7NNQX.js.map +7 -0
  216. package/dist/esm/chunks/{chunk.LYOQ2RGP.js → chunk.X3C3J5MH.js} +2 -2
  217. package/dist/esm/chunks/{chunk.LYOQ2RGP.js.map → chunk.X3C3J5MH.js.map} +1 -1
  218. package/dist/esm/chunks/{chunk.RBAVT3XQ.js → chunk.XGOAYMK2.js} +2 -2
  219. package/dist/esm/chunks/chunk.XI3MJSIS.js +7 -0
  220. package/dist/esm/chunks/chunk.XI3MJSIS.js.map +7 -0
  221. package/dist/esm/chunks/chunk.XIQFHO5R.js +7 -0
  222. package/dist/esm/chunks/{chunk.FVRSGKJD.js.map → chunk.XIQFHO5R.js.map} +2 -2
  223. package/dist/esm/chunks/chunk.XKI46BH2.js +7 -0
  224. package/dist/esm/chunks/{chunk.INCKI5IX.js.map → chunk.XKI46BH2.js.map} +1 -1
  225. package/dist/esm/chunks/{chunk.AFLH5HUG.js → chunk.YLG6ZC5K.js} +2 -2
  226. package/dist/esm/chunks/chunk.YRMR7IOS.js +7 -0
  227. package/dist/esm/chunks/chunk.YRMR7IOS.js.map +7 -0
  228. package/dist/esm/chunks/chunk.YWNCJ7XP.js +7 -0
  229. package/dist/esm/chunks/{chunk.242YUZKU.js.map → chunk.YWNCJ7XP.js.map} +2 -2
  230. package/dist/esm/chunks/{chunk.K2C4W3CO.js → chunk.YX7WLO5Y.js} +2 -2
  231. package/dist/esm/chunks/chunk.YZLASVCK.js +177 -0
  232. package/dist/esm/chunks/chunk.YZLASVCK.js.map +7 -0
  233. package/dist/esm/chunks/{chunk.5FPFRE4H.js → chunk.Z6FCL3G3.js} +2 -2
  234. package/dist/esm/chunks/{chunk.5FPFRE4H.js.map → chunk.Z6FCL3G3.js.map} +1 -1
  235. package/dist/esm/chunks/chunk.ZDD2NLGP.js +7 -0
  236. package/dist/esm/chunks/{chunk.FRYLJWYL.js → chunk.ZJC2DSNM.js} +2 -2
  237. package/dist/esm/chunks/{chunk.FRYLJWYL.js.map → chunk.ZJC2DSNM.js.map} +1 -1
  238. package/dist/esm/chunks/chunk.ZKGSQQGU.js +12 -0
  239. package/dist/esm/chunks/chunk.ZKGSQQGU.js.map +7 -0
  240. package/dist/esm/chunks/{chunk.JEN6YP2Q.js → chunk.ZVBZ3LGP.js} +2 -2
  241. package/dist/esm/circular-progress/index.js +1 -1
  242. package/dist/esm/color-picker/index.js +1 -1
  243. package/dist/esm/core/base/index.js +1 -1
  244. package/dist/esm/core/delegates/index.js +1 -1
  245. package/dist/esm/core/index.js +1 -1
  246. package/dist/esm/core/mask/index.js +1 -1
  247. package/dist/esm/core/utils/index.js +1 -1
  248. package/dist/esm/date-picker/index.js +1 -1
  249. package/dist/esm/date-range-picker/index.js +1 -1
  250. package/dist/esm/dialog/index.js +1 -1
  251. package/dist/esm/divider/index.js +1 -1
  252. package/dist/esm/drawer/base/index.js +1 -1
  253. package/dist/esm/drawer/drawer/index.js +1 -1
  254. package/dist/esm/drawer/index.js +1 -1
  255. package/dist/esm/drawer/mini-drawer/index.js +1 -1
  256. package/dist/esm/drawer/modal-drawer/index.js +1 -1
  257. package/dist/esm/expansion-panel/index.js +1 -1
  258. package/dist/esm/file-picker/index.js +1 -1
  259. package/dist/esm/floating-action-button/index.js +1 -1
  260. package/dist/esm/floating-label/index.js +1 -1
  261. package/dist/esm/focus-indicator/index.js +7 -0
  262. package/dist/esm/focus-indicator/index.js.map +7 -0
  263. package/dist/esm/icon/index.js +1 -1
  264. package/dist/esm/icon-button/index.js +1 -1
  265. package/dist/esm/index.js +1 -1
  266. package/dist/esm/inline-message/index.js +1 -1
  267. package/dist/esm/keyboard-shortcut/index.js +1 -1
  268. package/dist/esm/label-value/index.js +1 -1
  269. package/dist/esm/linear-progress/index.js +1 -1
  270. package/dist/esm/list/index.js +1 -1
  271. package/dist/esm/list/list/index.js +1 -1
  272. package/dist/esm/list/list-item/index.js +1 -1
  273. package/dist/esm/list-dropdown/index.js +1 -1
  274. package/dist/esm/menu/index.js +1 -1
  275. package/dist/esm/open-icon/index.js +1 -1
  276. package/dist/esm/page-state/index.js +1 -1
  277. package/dist/esm/paginator/index.js +1 -1
  278. package/dist/esm/popup/index.js +1 -1
  279. package/dist/esm/product-icon/index.js +1 -1
  280. package/dist/esm/profile-card/index.js +1 -1
  281. package/dist/esm/quantity-field/index.js +1 -1
  282. package/dist/esm/radio/index.js +1 -1
  283. package/dist/esm/ripple/index.js +1 -1
  284. package/dist/esm/scaffold/index.js +1 -1
  285. package/dist/esm/select/core/index.js +1 -1
  286. package/dist/esm/select/index.js +1 -1
  287. package/dist/esm/select/option/index.js +1 -1
  288. package/dist/esm/select/option-group/index.js +1 -1
  289. package/dist/esm/select/select/index.js +1 -1
  290. package/dist/esm/select/select-dropdown/index.js +1 -1
  291. package/dist/esm/skeleton/index.js +1 -1
  292. package/dist/esm/slider/index.js +1 -1
  293. package/dist/esm/split-view/index.js +1 -1
  294. package/dist/esm/split-view/split-view/index.js +1 -1
  295. package/dist/esm/split-view/split-view-panel/index.js +1 -1
  296. package/dist/esm/stack/index.js +1 -1
  297. package/dist/esm/state-layer/index.js +7 -0
  298. package/dist/esm/state-layer/index.js.map +7 -0
  299. package/dist/esm/stepper/index.js +1 -1
  300. package/dist/esm/stepper/step/index.js +1 -1
  301. package/dist/esm/stepper/stepper/index.js +1 -1
  302. package/dist/esm/switch/index.js +1 -1
  303. package/dist/esm/table/index.js +1 -1
  304. package/dist/esm/tabs/index.js +1 -1
  305. package/dist/esm/tabs/tab/index.js +1 -1
  306. package/dist/esm/tabs/tab-bar/index.js +1 -1
  307. package/dist/esm/text-field/index.js +1 -1
  308. package/dist/esm/theme/index.js +1 -1
  309. package/dist/esm/time-picker/index.js +1 -1
  310. package/dist/esm/toast/index.js +1 -1
  311. package/dist/esm/toolbar/index.js +1 -1
  312. package/dist/esm/tooltip/index.js +1 -1
  313. package/dist/esm/utils/index.js +1 -1
  314. package/dist/esm/view-switcher/index.js +1 -1
  315. package/dist/esm/view-switcher/view/index.js +1 -1
  316. package/dist/forge-dark.css +1 -1
  317. package/dist/forge.css +1 -1
  318. package/dist/icon-button/forge-icon-button.css +1 -1
  319. package/dist/table/forge-table.css +1 -1
  320. package/dist/theme/forge-theme.css +1 -1
  321. package/dist/typography/forge-typography-legacy.css +6 -0
  322. package/dist/typography/forge-typography.css +1 -1
  323. package/esm/accordion/accordion.js +4 -4
  324. package/esm/app-bar/app-bar.js +6 -6
  325. package/esm/app-bar/notification-button/app-bar-notification-button.js +5 -5
  326. package/esm/app-bar/profile-button/app-bar-profile-button-adapter.js +1 -1
  327. package/esm/app-bar/profile-button/app-bar-profile-button-constants.d.ts +1 -1
  328. package/esm/app-bar/profile-button/app-bar-profile-button.js +4 -4
  329. package/esm/app-bar/search/app-bar-search.js +6 -6
  330. package/esm/autocomplete/autocomplete-adapter.d.ts +0 -2
  331. package/esm/autocomplete/autocomplete-adapter.js +1 -5
  332. package/esm/autocomplete/autocomplete-component-delegate.d.ts +1 -1
  333. package/esm/autocomplete/autocomplete-constants.d.ts +5 -4
  334. package/esm/autocomplete/autocomplete-constants.js +1 -0
  335. package/esm/autocomplete/autocomplete-foundation.d.ts +5 -0
  336. package/esm/autocomplete/autocomplete-foundation.js +12 -12
  337. package/esm/autocomplete/autocomplete.d.ts +3 -0
  338. package/esm/autocomplete/autocomplete.js +13 -6
  339. package/esm/avatar/avatar-component-delegate.d.ts +1 -1
  340. package/esm/avatar/avatar.js +5 -5
  341. package/esm/backdrop/backdrop-constants.d.ts +1 -1
  342. package/esm/backdrop/backdrop.js +5 -5
  343. package/esm/badge/badge-component-delegate.d.ts +1 -1
  344. package/esm/badge/badge.js +5 -5
  345. package/esm/banner/banner.js +7 -7
  346. package/esm/bottom-sheet/bottom-sheet.js +6 -6
  347. package/esm/busy-indicator/busy-indicator-adapter.js +1 -1
  348. package/esm/busy-indicator/busy-indicator-constants.d.ts +1 -1
  349. package/esm/busy-indicator/busy-indicator.js +6 -6
  350. package/esm/button/button-component-delegate.d.ts +1 -1
  351. package/esm/button/button.d.ts +1 -0
  352. package/esm/button/button.js +11 -5
  353. package/esm/button-toggle/button-toggle/button-toggle.js +7 -7
  354. package/esm/button-toggle/button-toggle-group/button-toggle-group-constants.d.ts +2 -2
  355. package/esm/button-toggle/button-toggle-group/button-toggle-group.js +5 -5
  356. package/esm/calendar/calendar-component-delegate.d.ts +1 -1
  357. package/esm/calendar/calendar-constants.d.ts +10 -10
  358. package/esm/calendar/calendar-dropdown/calendar-dropdown.d.ts +3 -0
  359. package/esm/calendar/calendar-dropdown/calendar-dropdown.js +14 -5
  360. package/esm/calendar/calendar-menu/calendar-menu-constants.d.ts +2 -2
  361. package/esm/calendar/calendar-menu/calendar-menu.js +6 -6
  362. package/esm/calendar/calendar.js +7 -7
  363. package/esm/card/card-constants.d.ts +2 -2
  364. package/esm/card/card-constants.js +2 -2
  365. package/esm/card/card.d.ts +19 -8
  366. package/esm/card/card.js +34 -25
  367. package/esm/checkbox/checkbox-adapter.d.ts +1 -0
  368. package/esm/checkbox/checkbox-adapter.js +9 -2
  369. package/esm/checkbox/checkbox-component-delegate.d.ts +1 -1
  370. package/esm/checkbox/checkbox.js +4 -4
  371. package/esm/chip-field/chip-field-component-delegate.d.ts +1 -1
  372. package/esm/chip-field/chip-field-foundation.d.ts +1 -1
  373. package/esm/chip-field/chip-field-foundation.js +1 -1
  374. package/esm/chip-field/chip-field.js +1 -1
  375. package/esm/chips/chip/chip-adapter.js +2 -2
  376. package/esm/chips/chip/chip.js +7 -7
  377. package/esm/chips/chip-set/chip-set.js +5 -5
  378. package/esm/circular-progress/circular-progress-adapter.d.ts +7 -14
  379. package/esm/circular-progress/circular-progress-adapter.js +25 -25
  380. package/esm/circular-progress/circular-progress-constants.d.ts +6 -2
  381. package/esm/circular-progress/circular-progress-constants.js +8 -3
  382. package/esm/circular-progress/circular-progress-foundation.d.ts +0 -8
  383. package/esm/circular-progress/circular-progress-foundation.js +9 -27
  384. package/esm/circular-progress/circular-progress.d.ts +24 -5
  385. package/esm/circular-progress/circular-progress.js +33 -21
  386. package/esm/color-picker/color-picker-constants.d.ts +2 -2
  387. package/esm/color-picker/color-picker-foundation.d.ts +0 -1
  388. package/esm/color-picker/color-picker-foundation.js +2 -5
  389. package/esm/color-picker/color-picker.js +7 -7
  390. package/esm/core/base/base-component.d.ts +1 -2
  391. package/esm/core/delegates/base-component-delegate.d.ts +1 -1
  392. package/esm/core/delegates/base-component-delegate.js +3 -3
  393. package/esm/core/delegates/form-field-component-delegate.d.ts +1 -1
  394. package/esm/core/mask/time-segment-parser.d.ts +1 -1
  395. package/esm/core/testing/pointer.d.ts +13 -0
  396. package/esm/core/testing/pointer.js +42 -0
  397. package/esm/core/utils/utils.d.ts +33 -2
  398. package/esm/core/utils/utils.js +74 -6
  399. package/esm/date-picker/base/base-date-picker-adapter.d.ts +4 -2
  400. package/esm/date-picker/base/base-date-picker-adapter.js +6 -0
  401. package/esm/date-picker/base/base-date-picker-constants.d.ts +1 -0
  402. package/esm/date-picker/base/base-date-picker-constants.js +2 -1
  403. package/esm/date-picker/base/base-date-picker-foundation.d.ts +6 -2
  404. package/esm/date-picker/base/base-date-picker-foundation.js +21 -6
  405. package/esm/date-picker/base/base-date-picker.d.ts +3 -0
  406. package/esm/date-picker/base/base-date-picker.js +6 -0
  407. package/esm/date-picker/date-picker-adapter.js +6 -8
  408. package/esm/date-picker/date-picker-component-delegate.d.ts +1 -1
  409. package/esm/date-range-picker/date-range-picker-adapter.d.ts +4 -2
  410. package/esm/date-range-picker/date-range-picker-adapter.js +20 -18
  411. package/esm/date-range-picker/date-range-picker-component-delegate.d.ts +1 -1
  412. package/esm/date-range-picker/date-range-picker-foundation.d.ts +4 -1
  413. package/esm/date-range-picker/date-range-picker-foundation.js +48 -14
  414. package/esm/dialog/dialog-adapter.js +1 -1
  415. package/esm/dialog/dialog-constants.d.ts +2 -2
  416. package/esm/dialog/dialog.js +5 -5
  417. package/esm/drawer/base/base-drawer-constants.d.ts +1 -1
  418. package/esm/expansion-panel/expansion-panel-constants.d.ts +2 -0
  419. package/esm/expansion-panel/expansion-panel-constants.js +3 -1
  420. package/esm/expansion-panel/expansion-panel-foundation.js +4 -1
  421. package/esm/expansion-panel/expansion-panel.js +6 -6
  422. package/esm/field/field-adapter.d.ts +4 -2
  423. package/esm/field/field-adapter.js +5 -2
  424. package/esm/field/field-constants.d.ts +3 -3
  425. package/esm/field/field-foundation.d.ts +2 -2
  426. package/esm/field/field-foundation.js +12 -9
  427. package/esm/field/field.js +3 -3
  428. package/esm/file-picker/file-picker-component-delegate.d.ts +1 -1
  429. package/esm/file-picker/file-picker.js +6 -6
  430. package/esm/floating-action-button/floating-action-button-component-delegate.d.ts +1 -1
  431. package/esm/floating-action-button/floating-action-button.js +6 -6
  432. package/esm/focus-indicator/focus-indicator-adapter.d.ts +29 -0
  433. package/esm/focus-indicator/focus-indicator-adapter.js +39 -0
  434. package/esm/focus-indicator/focus-indicator-constants.d.ts +15 -0
  435. package/esm/focus-indicator/focus-indicator-constants.js +19 -0
  436. package/esm/focus-indicator/focus-indicator-foundation.d.ts +43 -0
  437. package/esm/focus-indicator/focus-indicator-foundation.js +110 -0
  438. package/esm/focus-indicator/focus-indicator.d.ts +67 -0
  439. package/esm/focus-indicator/focus-indicator.js +112 -0
  440. package/esm/focus-indicator/index.d.ts +10 -0
  441. package/esm/focus-indicator/index.js +14 -0
  442. package/esm/icon/icon.js +5 -5
  443. package/esm/icon-button/icon-button-component-delegate.d.ts +1 -1
  444. package/esm/icon-button/icon-button.d.ts +1 -0
  445. package/esm/icon-button/icon-button.js +16 -9
  446. package/esm/index.d.ts +2 -0
  447. package/esm/index.js +6 -0
  448. package/esm/keyboard-shortcut/keyboard-shortcut.js +4 -4
  449. package/esm/label-value/label-value-component-delegate.d.ts +1 -1
  450. package/esm/label-value/label-value-constants.d.ts +1 -1
  451. package/esm/label-value/label-value.js +5 -5
  452. package/esm/linear-progress/linear-progress-adapter.d.ts +23 -0
  453. package/esm/linear-progress/linear-progress-adapter.js +34 -0
  454. package/esm/linear-progress/linear-progress-constants.d.ts +6 -2
  455. package/esm/linear-progress/linear-progress-constants.js +8 -3
  456. package/esm/linear-progress/linear-progress-foundation.d.ts +26 -0
  457. package/esm/linear-progress/linear-progress-foundation.js +53 -0
  458. package/esm/linear-progress/linear-progress.d.ts +32 -25
  459. package/esm/linear-progress/linear-progress.js +49 -107
  460. package/esm/list/list/list-adapter.js +2 -2
  461. package/esm/list/list/list.js +5 -5
  462. package/esm/list/list-item/list-item-adapter.d.ts +3 -3
  463. package/esm/list/list-item/list-item-adapter.js +2 -2
  464. package/esm/list/list-item/list-item-foundation.d.ts +1 -0
  465. package/esm/list/list-item/list-item-foundation.js +8 -1
  466. package/esm/list/list-item/list-item.js +6 -6
  467. package/esm/list-dropdown/list-dropdown-adapter.js +4 -5
  468. package/esm/list-dropdown/list-dropdown-constants.d.ts +6 -6
  469. package/esm/list-dropdown/list-dropdown-utils.d.ts +1 -1
  470. package/esm/list-dropdown/list-dropdown-utils.js +7 -4
  471. package/esm/menu/menu-constants.d.ts +3 -3
  472. package/esm/menu/menu.js +6 -6
  473. package/esm/open-icon/open-icon.js +6 -6
  474. package/esm/paginator/paginator-constants.d.ts +1 -1
  475. package/esm/paginator/paginator-foundation.js +2 -0
  476. package/esm/paginator/paginator.js +12 -12
  477. package/esm/popup/popup-adapter.js +2 -2
  478. package/esm/popup/popup-constants.d.ts +2 -2
  479. package/esm/popup/popup.js +5 -5
  480. package/esm/product-icon/product-icon.js +5 -5
  481. package/esm/profile-card/profile-card.js +6 -6
  482. package/esm/quantity-field/quantity-field-component-delegate.d.ts +1 -1
  483. package/esm/quantity-field/quantity-field.js +6 -6
  484. package/esm/radio/radio-adapter.d.ts +1 -0
  485. package/esm/radio/radio-adapter.js +11 -3
  486. package/esm/radio/radio.js +5 -5
  487. package/esm/ripple/forge-ripple.d.ts +2 -0
  488. package/esm/ripple/forge-ripple.js +4 -0
  489. package/esm/ripple/ripple.js +4 -4
  490. package/esm/select/core/base-select-constants.d.ts +4 -4
  491. package/esm/select/option/option.js +4 -4
  492. package/esm/select/option-group/option-group.js +3 -3
  493. package/esm/select/select/select-adapter.d.ts +1 -1
  494. package/esm/select/select/select.js +1 -1
  495. package/esm/select/select-component-delegate.d.ts +1 -1
  496. package/esm/slider/slider-adapter.d.ts +79 -0
  497. package/esm/slider/slider-adapter.js +178 -0
  498. package/esm/slider/slider-component-delegate.d.ts +19 -3
  499. package/esm/slider/slider-component-delegate.js +48 -0
  500. package/esm/slider/slider-constants.d.ts +55 -19
  501. package/esm/slider/slider-constants.js +56 -14
  502. package/esm/slider/slider-foundation.d.ts +94 -0
  503. package/esm/slider/slider-foundation.js +313 -0
  504. package/esm/slider/slider-utils.d.ts +9 -0
  505. package/esm/slider/slider-utils.js +56 -0
  506. package/esm/slider/slider.d.ts +135 -66
  507. package/esm/slider/slider.js +241 -249
  508. package/esm/split-view/split-view/split-view-adapter.js +3 -1
  509. package/esm/split-view/split-view/split-view-constants.d.ts +1 -1
  510. package/esm/split-view/split-view/split-view.js +5 -5
  511. package/esm/split-view/split-view-panel/split-view-panel-constants.d.ts +2 -2
  512. package/esm/split-view/split-view-panel/split-view-panel-foundation.js +18 -18
  513. package/esm/split-view/split-view-panel/split-view-panel.js +7 -7
  514. package/esm/stack/stack-constants.d.ts +1 -1
  515. package/esm/stack/stack.js +5 -5
  516. package/esm/state-layer/index.d.ts +10 -0
  517. package/esm/state-layer/index.js +14 -0
  518. package/esm/state-layer/state-layer-adapter.d.ts +41 -0
  519. package/esm/state-layer/state-layer-adapter.js +101 -0
  520. package/esm/state-layer/state-layer-constants.d.ts +79 -0
  521. package/esm/state-layer/state-layer-constants.js +89 -0
  522. package/esm/state-layer/state-layer-foundation.d.ts +57 -0
  523. package/esm/state-layer/state-layer-foundation.js +237 -0
  524. package/esm/state-layer/state-layer-utils.d.ts +26 -0
  525. package/esm/state-layer/state-layer-utils.js +54 -0
  526. package/esm/state-layer/state-layer.d.ts +66 -0
  527. package/esm/state-layer/state-layer.js +96 -0
  528. package/esm/stepper/core/stepper-utils.js +2 -1
  529. package/esm/stepper/step/step-constants.d.ts +1 -1
  530. package/esm/stepper/step/step.js +13 -13
  531. package/esm/stepper/stepper/stepper-adapter.js +1 -1
  532. package/esm/stepper/stepper/stepper-constants.d.ts +2 -2
  533. package/esm/stepper/stepper/stepper-foundation.js +1 -0
  534. package/esm/stepper/stepper/stepper.js +5 -5
  535. package/esm/switch/switch-component-delegate.d.ts +1 -1
  536. package/esm/switch/switch-constants.d.ts +1 -1
  537. package/esm/switch/switch.js +19 -12
  538. package/esm/table/table.js +5 -5
  539. package/esm/table/types.d.ts +4 -4
  540. package/esm/tabs/tab/tab-adapter.d.ts +14 -40
  541. package/esm/tabs/tab/tab-adapter.js +57 -79
  542. package/esm/tabs/tab/tab-constants.d.ts +13 -14
  543. package/esm/tabs/tab/tab-constants.js +17 -10
  544. package/esm/tabs/tab/tab-foundation.d.ts +23 -23
  545. package/esm/tabs/tab/tab-foundation.js +66 -62
  546. package/esm/tabs/tab/tab.d.ts +56 -20
  547. package/esm/tabs/tab/tab.js +88 -39
  548. package/esm/tabs/tab-bar/tab-bar-adapter.d.ts +49 -87
  549. package/esm/tabs/tab-bar/tab-bar-adapter.js +114 -188
  550. package/esm/tabs/tab-bar/tab-bar-constants.d.ts +15 -45
  551. package/esm/tabs/tab-bar/tab-bar-constants.js +22 -56
  552. package/esm/tabs/tab-bar/tab-bar-foundation.d.ts +56 -65
  553. package/esm/tabs/tab-bar/tab-bar-foundation.js +241 -302
  554. package/esm/tabs/tab-bar/tab-bar.d.ts +51 -36
  555. package/esm/tabs/tab-bar/tab-bar.js +89 -57
  556. package/esm/text-field/text-field-adapter.d.ts +1 -1
  557. package/esm/text-field/text-field-adapter.js +5 -3
  558. package/esm/text-field/text-field-component-delegate.d.ts +1 -1
  559. package/esm/text-field/text-field.js +1 -1
  560. package/esm/theme/theme-utils.d.ts +2 -2
  561. package/esm/time-picker/time-picker-adapter.js +6 -8
  562. package/esm/time-picker/time-picker-component-delegate.d.ts +1 -1
  563. package/esm/time-picker/time-picker-constants.d.ts +6 -6
  564. package/esm/time-picker/time-picker-foundation.js +9 -6
  565. package/esm/time-picker/time-picker.js +6 -6
  566. package/esm/toast/toast-constants.d.ts +2 -2
  567. package/esm/toast/toast.js +7 -7
  568. package/esm/toolbar/toolbar.js +5 -5
  569. package/esm/tooltip/tooltip-constants.d.ts +1 -1
  570. package/esm/tooltip/tooltip.js +4 -4
  571. package/esm/utils/color-utils.js +1 -0
  572. package/esm/view-switcher/view-switcher.js +5 -5
  573. package/package.json +2 -4
  574. package/styles/app-bar/_mixins.scss +8 -1
  575. package/styles/card/_mixins.scss +8 -7
  576. package/styles/chips/chip/_mixins.scss +1 -0
  577. package/styles/circular-progress/_animation.scss +75 -0
  578. package/styles/circular-progress/_configuration.scss +23 -0
  579. package/styles/circular-progress/_core.scss +122 -0
  580. package/styles/circular-progress/circular-progress.scss +92 -3
  581. package/styles/circular-progress/index.scss +8 -0
  582. package/styles/core/styles/_utils.scss +63 -0
  583. package/styles/core/styles/animation/index.scss +16 -0
  584. package/styles/core/styles/border/index.scss +38 -0
  585. package/styles/core/styles/core/_config.scss +6 -0
  586. package/styles/core/styles/elevation/index.scss +61 -0
  587. package/styles/core/styles/shape/index.scss +31 -0
  588. package/styles/core/styles/spacing/index.scss +30 -0
  589. package/styles/core/styles/theme/index.scss +52 -0
  590. package/styles/core/styles/tokens/_color-palette.scss +299 -0
  591. package/styles/core/styles/tokens/animation/_tokens.scss +38 -0
  592. package/styles/core/styles/tokens/border/_tokens.scss +17 -0
  593. package/styles/core/styles/tokens/circular-progress/_tokens.scss +21 -0
  594. package/styles/core/styles/tokens/elevation/_tokens.scss +105 -0
  595. package/styles/core/styles/tokens/focus-indicator/_tokens.scss +34 -0
  596. package/styles/core/styles/tokens/index.scss +10 -0
  597. package/styles/core/styles/tokens/linear-progress/_tokens.scss +25 -0
  598. package/styles/core/styles/tokens/shape/_tokens.scss +42 -0
  599. package/styles/core/styles/tokens/slider/_tokens.scss +49 -0
  600. package/styles/core/styles/tokens/spacing/_tokens.scss +23 -0
  601. package/styles/core/styles/tokens/state-layer/_tokens.scss +23 -0
  602. package/styles/core/styles/tokens/tabs/tab/_tokens.scss +71 -0
  603. package/styles/core/styles/tokens/tabs/tab-bar/_tokens.scss +19 -0
  604. package/styles/core/styles/tokens/theme/_tokens.scss +133 -0
  605. package/styles/core/styles/tokens/typography/_tokens.scss +236 -0
  606. package/styles/core/styles/typography/index.scss +119 -0
  607. package/styles/focus-indicator/_animations.scss +36 -0
  608. package/styles/focus-indicator/_configuration.scss +23 -0
  609. package/styles/focus-indicator/_core.scss +52 -0
  610. package/styles/focus-indicator/focus-indicator.scss +55 -0
  611. package/styles/focus-indicator/index.scss +8 -0
  612. package/styles/linear-progress/_animations.scss +129 -0
  613. package/styles/linear-progress/_configuration.scss +29 -0
  614. package/styles/linear-progress/_core.scss +99 -0
  615. package/styles/linear-progress/index.scss +8 -0
  616. package/styles/linear-progress/linear-progress.scss +101 -18
  617. package/styles/list/list-item/_mixins.scss +11 -1
  618. package/styles/list/list-item/_variables.scss +9 -0
  619. package/styles/slider/_configuration.scss +61 -0
  620. package/styles/slider/_core.scss +344 -0
  621. package/styles/slider/index.scss +7 -0
  622. package/styles/slider/slider.scss +186 -14
  623. package/styles/state-layer/_configuration.scss +17 -0
  624. package/styles/state-layer/_core.scss +124 -0
  625. package/styles/state-layer/index.scss +7 -0
  626. package/styles/state-layer/state-layer.scss +38 -0
  627. package/styles/table/_mixins.scss +2 -2
  628. package/styles/tabs/tab/_configuration.scss +64 -0
  629. package/styles/tabs/tab/_core.scss +190 -0
  630. package/styles/tabs/tab/index.scss +7 -0
  631. package/styles/tabs/tab/tab.scss +182 -15
  632. package/styles/tabs/tab-bar/_configuration.scss +13 -0
  633. package/styles/tabs/tab-bar/_core.scss +60 -0
  634. package/styles/tabs/tab-bar/index.scss +7 -0
  635. package/styles/tabs/tab-bar/tab-bar.scss +66 -5
  636. package/styles/theme/_theme-dark.scss +4 -8
  637. package/styles/theme/_theme.scss +3 -36
  638. package/styles/typography/forge-typography-legacy.scss +8 -0
  639. package/styles/typography/forge-typography.scss +11 -3
  640. package/styles/utils/_mixins-core.scss +1 -1
  641. package/dist/esm/chunks/chunk.242YUZKU.js +0 -7
  642. package/dist/esm/chunks/chunk.2BNDXFI5.js +0 -7
  643. package/dist/esm/chunks/chunk.2BNDXFI5.js.map +0 -7
  644. package/dist/esm/chunks/chunk.2DXG2R3M.js +0 -73
  645. package/dist/esm/chunks/chunk.2DXG2R3M.js.map +0 -7
  646. package/dist/esm/chunks/chunk.44IJE5UL.js +0 -7
  647. package/dist/esm/chunks/chunk.44IJE5UL.js.map +0 -7
  648. package/dist/esm/chunks/chunk.47A2CN5U.js +0 -7
  649. package/dist/esm/chunks/chunk.4BEI55KI.js +0 -7
  650. package/dist/esm/chunks/chunk.4FSAAN6W.js +0 -29
  651. package/dist/esm/chunks/chunk.4FSAAN6W.js.map +0 -7
  652. package/dist/esm/chunks/chunk.4NI63FGK.js +0 -7
  653. package/dist/esm/chunks/chunk.4WPFFNLH.js +0 -7
  654. package/dist/esm/chunks/chunk.5WNKQTXX.js +0 -7
  655. package/dist/esm/chunks/chunk.6OKJPSUE.js +0 -7
  656. package/dist/esm/chunks/chunk.72AUOVCD.js +0 -7
  657. package/dist/esm/chunks/chunk.72AUOVCD.js.map +0 -7
  658. package/dist/esm/chunks/chunk.7A6MX6CS.js +0 -7
  659. package/dist/esm/chunks/chunk.7A6MX6CS.js.map +0 -7
  660. package/dist/esm/chunks/chunk.7BOXIJAM.js +0 -7
  661. package/dist/esm/chunks/chunk.7BOXIJAM.js.map +0 -7
  662. package/dist/esm/chunks/chunk.ABLKZXJ3.js +0 -12
  663. package/dist/esm/chunks/chunk.ABLKZXJ3.js.map +0 -7
  664. package/dist/esm/chunks/chunk.BTBHIIGI.js +0 -7
  665. package/dist/esm/chunks/chunk.C7AN6FMW.js +0 -7
  666. package/dist/esm/chunks/chunk.C7AN6FMW.js.map +0 -7
  667. package/dist/esm/chunks/chunk.CKYHP5MC.js +0 -7
  668. package/dist/esm/chunks/chunk.CKYHP5MC.js.map +0 -7
  669. package/dist/esm/chunks/chunk.DT7MZR5Y.js +0 -7
  670. package/dist/esm/chunks/chunk.DYNEJBYK.js +0 -7
  671. package/dist/esm/chunks/chunk.E6CYXNS2.js +0 -7
  672. package/dist/esm/chunks/chunk.EGRUD7S7.js +0 -7
  673. package/dist/esm/chunks/chunk.ESR2NHOS.js +0 -7
  674. package/dist/esm/chunks/chunk.ESR2NHOS.js.map +0 -7
  675. package/dist/esm/chunks/chunk.F3MP6AXF.js +0 -29
  676. package/dist/esm/chunks/chunk.F3MP6AXF.js.map +0 -7
  677. package/dist/esm/chunks/chunk.FVRSGKJD.js +0 -7
  678. package/dist/esm/chunks/chunk.G3ZTZ4AN.js +0 -7
  679. package/dist/esm/chunks/chunk.G3ZTZ4AN.js.map +0 -7
  680. package/dist/esm/chunks/chunk.G5MGGEFP.js +0 -7
  681. package/dist/esm/chunks/chunk.HPDBSBQJ.js +0 -29
  682. package/dist/esm/chunks/chunk.HPDBSBQJ.js.map +0 -7
  683. package/dist/esm/chunks/chunk.HV6SPRC4.js +0 -7
  684. package/dist/esm/chunks/chunk.HV6SPRC4.js.map +0 -7
  685. package/dist/esm/chunks/chunk.I5BAZWUF.js +0 -7
  686. package/dist/esm/chunks/chunk.I5BAZWUF.js.map +0 -7
  687. package/dist/esm/chunks/chunk.IGTXLDZS.js +0 -7
  688. package/dist/esm/chunks/chunk.ILRWZHH3.js +0 -29
  689. package/dist/esm/chunks/chunk.ILRWZHH3.js.map +0 -7
  690. package/dist/esm/chunks/chunk.INCKI5IX.js +0 -7
  691. package/dist/esm/chunks/chunk.J6WCFQSS.js +0 -7
  692. package/dist/esm/chunks/chunk.JHBCYICS.js +0 -7
  693. package/dist/esm/chunks/chunk.JHY2CKEH.js +0 -7
  694. package/dist/esm/chunks/chunk.K6AFP52A.js +0 -7
  695. package/dist/esm/chunks/chunk.K6AFP52A.js.map +0 -7
  696. package/dist/esm/chunks/chunk.KE6GOYAB.js +0 -7
  697. package/dist/esm/chunks/chunk.KE6GOYAB.js.map +0 -7
  698. package/dist/esm/chunks/chunk.LDN4HLF7.js +0 -7
  699. package/dist/esm/chunks/chunk.LDN4HLF7.js.map +0 -7
  700. package/dist/esm/chunks/chunk.M2QU3LUR.js +0 -7
  701. package/dist/esm/chunks/chunk.M2QU3LUR.js.map +0 -7
  702. package/dist/esm/chunks/chunk.MCIQXNKY.js +0 -7
  703. package/dist/esm/chunks/chunk.MHOS3IHQ.js +0 -7
  704. package/dist/esm/chunks/chunk.MSF55AA3.js +0 -7
  705. package/dist/esm/chunks/chunk.MSF55AA3.js.map +0 -7
  706. package/dist/esm/chunks/chunk.MXTDW27J.js +0 -7
  707. package/dist/esm/chunks/chunk.MXTDW27J.js.map +0 -7
  708. package/dist/esm/chunks/chunk.NW7NV2A2.js +0 -7
  709. package/dist/esm/chunks/chunk.NW7NV2A2.js.map +0 -7
  710. package/dist/esm/chunks/chunk.Q7LFOS2I.js +0 -7
  711. package/dist/esm/chunks/chunk.Q7LFOS2I.js.map +0 -7
  712. package/dist/esm/chunks/chunk.RB5BTA5N.js +0 -7
  713. package/dist/esm/chunks/chunk.RE5X26QT.js +0 -29
  714. package/dist/esm/chunks/chunk.RE5X26QT.js.map +0 -7
  715. package/dist/esm/chunks/chunk.RG6CDWEX.js +0 -7
  716. package/dist/esm/chunks/chunk.RG6CDWEX.js.map +0 -7
  717. package/dist/esm/chunks/chunk.ROR6JMAE.js +0 -7
  718. package/dist/esm/chunks/chunk.SAQVWOVK.js +0 -7
  719. package/dist/esm/chunks/chunk.SAQVWOVK.js.map +0 -7
  720. package/dist/esm/chunks/chunk.TWZXQQQO.js +0 -29
  721. package/dist/esm/chunks/chunk.TWZXQQQO.js.map +0 -7
  722. package/dist/esm/chunks/chunk.UF43SSFY.js +0 -7
  723. package/dist/esm/chunks/chunk.UF43SSFY.js.map +0 -7
  724. package/dist/esm/chunks/chunk.V4TCOZLK.js +0 -29
  725. package/dist/esm/chunks/chunk.V4TCOZLK.js.map +0 -7
  726. package/dist/esm/chunks/chunk.V7WKXEZC.js +0 -7
  727. package/dist/esm/chunks/chunk.V7WKXEZC.js.map +0 -7
  728. package/dist/esm/chunks/chunk.VAKNDCLP.js +0 -29
  729. package/dist/esm/chunks/chunk.VAKNDCLP.js.map +0 -7
  730. package/dist/esm/chunks/chunk.WY7DECJD.js +0 -7
  731. package/dist/esm/chunks/chunk.WY7DECJD.js.map +0 -7
  732. package/dist/esm/chunks/chunk.X5LGVZGO.js +0 -7
  733. package/dist/esm/chunks/chunk.X5LGVZGO.js.map +0 -7
  734. package/dist/esm/chunks/chunk.Y4GKBJGI.js +0 -7
  735. package/dist/esm/chunks/chunk.Y5A7RQ5M.js +0 -7
  736. package/dist/esm/chunks/chunk.Y66GSZJB.js +0 -7
  737. package/dist/esm/chunks/chunk.Y66GSZJB.js.map +0 -7
  738. package/dist/esm/chunks/chunk.Y72NANFX.js +0 -7
  739. package/dist/esm/chunks/chunk.Y72NANFX.js.map +0 -7
  740. package/dist/esm/chunks/chunk.YBEBD4CN.js +0 -7
  741. package/dist/esm/chunks/chunk.YI4JTY4T.js +0 -14
  742. package/dist/esm/chunks/chunk.YPZNIYQL.js +0 -7
  743. package/dist/esm/chunks/chunk.ZFHPUAYX.js +0 -7
  744. package/dist/typography/forge-form.css +0 -6
  745. package/styles/circular-progress/_keyframes.scss +0 -185
  746. package/styles/circular-progress/_mixins.scss +0 -320
  747. package/styles/circular-progress/_variables.scss +0 -50
  748. package/styles/linear-progress/_mixins.scss +0 -11
  749. package/styles/linear-progress/_variables.scss +0 -15
  750. package/styles/tabs/tab/_mixins.scss +0 -165
  751. package/styles/tabs/tab/_variables.scss +0 -9
  752. package/styles/tabs/tab-bar/_mixins.scss +0 -78
  753. package/styles/typography/forge-form.scss +0 -67
  754. /package/dist/esm/chunks/{chunk.JHY2CKEH.js.map → chunk.3HB22HCX.js.map} +0 -0
  755. /package/dist/esm/chunks/{chunk.IGTXLDZS.js.map → chunk.4C6KHYUO.js.map} +0 -0
  756. /package/dist/esm/chunks/{chunk.KU5CXXGS.js.map → chunk.A62DE5PD.js.map} +0 -0
  757. /package/dist/esm/chunks/{chunk.G45OZEIS.js.map → chunk.CWTV3TB3.js.map} +0 -0
  758. /package/dist/esm/chunks/{chunk.WP4QOOIS.js.map → chunk.DG4ZM3AW.js.map} +0 -0
  759. /package/dist/esm/chunks/{chunk.EGRUD7S7.js.map → chunk.EK24Y56W.js.map} +0 -0
  760. /package/dist/esm/chunks/{chunk.UT7QUGAO.js.map → chunk.FWFOOQMA.js.map} +0 -0
  761. /package/dist/esm/chunks/{chunk.ZUNZKRRK.js.map → chunk.IX25DYIM.js.map} +0 -0
  762. /package/dist/esm/chunks/{chunk.ARJ3EVVO.js.map → chunk.KVCDAZ6B.js.map} +0 -0
  763. /package/dist/esm/chunks/{chunk.H4Z4DHPA.js.map → chunk.LTT67HTW.js.map} +0 -0
  764. /package/dist/esm/chunks/{chunk.MCIQXNKY.js.map → chunk.M3QDAYD2.js.map} +0 -0
  765. /package/dist/esm/chunks/{chunk.O73S5LF3.js.map → chunk.MGLL67VO.js.map} +0 -0
  766. /package/dist/esm/chunks/{chunk.MLV25D2G.js.map → chunk.OWCYRSI3.js.map} +0 -0
  767. /package/dist/esm/chunks/{chunk.IUOBRBDZ.js.map → chunk.QOJESHEV.js.map} +0 -0
  768. /package/dist/esm/chunks/{chunk.XUW3GG46.js.map → chunk.SFCGOCQK.js.map} +0 -0
  769. /package/dist/esm/chunks/{chunk.RBAVT3XQ.js.map → chunk.XGOAYMK2.js.map} +0 -0
  770. /package/dist/esm/chunks/{chunk.AFLH5HUG.js.map → chunk.YLG6ZC5K.js.map} +0 -0
  771. /package/dist/esm/chunks/{chunk.K2C4W3CO.js.map → chunk.YX7WLO5Y.js.map} +0 -0
  772. /package/dist/esm/chunks/{chunk.DYNEJBYK.js.map → chunk.ZDD2NLGP.js.map} +0 -0
  773. /package/dist/esm/chunks/{chunk.JEN6YP2Q.js.map → chunk.ZVBZ3LGP.js.map} +0 -0
@@ -3,383 +3,322 @@
3
3
  * Copyright 2023 Tyler Technologies, Inc.
4
4
  * License: Apache-2.0
5
5
  */
6
- import { Platform, isNumber } from '@tylertech/forge-core';
7
- import { TAB_BAR_CONSTANTS, ACCEPTABLE_KEYS, KEYCODE_MAP } from './tab-bar-constants';
6
+ import { NAVIGATION_KEYS, TAB_BAR_CONSTANTS } from './tab-bar-constants';
8
7
  import { TAB_CONSTANTS } from '../tab/tab-constants';
9
8
  export class TabBarFoundation {
10
9
  constructor(_adapter) {
11
10
  this._adapter = _adapter;
11
+ // State
12
12
  this._isInitialized = false;
13
- this._activeTab = -1;
14
- this._layoutMode = 'fixed';
15
- this._layoutAlign = 'start';
16
- this._underline = false;
17
- this._autoActivate = false;
13
+ this._disabled = false;
14
+ this._vertical = false;
15
+ this._clustered = false;
18
16
  this._stacked = false;
19
- this._scrollButtons = true;
20
- this._forceScrollButtons = false;
21
- this._tabsChangedListener = evt => this._onTabsChanged(evt);
22
- this._tabInteractedListener = evt => this._onTabInteracted(evt);
23
- this._keydownListener = evt => this._onKeydown(evt);
24
- this._scrollPrevClickListener = evt => this._onScrollPrevious(evt);
25
- this._scrollPrevMousedownListener = evt => evt.preventDefault();
26
- this._scrollNextClickListener = evt => this._onScrollNext(evt);
27
- this._scrollNextMousedownListener = evt => evt.preventDefault();
28
- this._scrollListener = evt => this._onScroll(evt);
17
+ this._secondary = false;
18
+ this._inverted = false;
19
+ this._autoActivate = false;
20
+ this._scrollButtons = false;
21
+ this._tabs = [];
22
+ this._scrollButtonsVisible = false;
23
+ this._tabsChangedListener = () => this._onTabsChanged();
24
+ this._tabSelectedListener = (evt) => this._onTabSelected(evt);
25
+ this._keydownListener = (evt) => this._onKeydown(evt);
26
+ this._resizeListener = () => this._onResize();
27
+ this._scrollListener = () => this._onScroll();
28
+ this._scrollBackwardButtonListener = () => this._onScrollBackward();
29
+ this._scrollForwardButtonListener = () => this._onScrollForward();
29
30
  }
30
31
  initialize() {
31
- this._adapter.initializeTabs(this._activeTab, this._isFixed);
32
- this._adapter.initializeTabScroller();
33
- this._adapter.initializeAccessibility();
34
- this._adapter.addTabChangeListener(this._tabsChangedListener);
35
- this._adapter.addScrollPreviousListener('click', this._scrollPrevClickListener);
36
- this._adapter.addScrollPreviousListener('mousedown', this._scrollPrevMousedownListener);
37
- this._adapter.addScrollNextListener('click', this._scrollNextClickListener);
38
- this._adapter.addScrollNextListener('mousedown', this._scrollNextMousedownListener);
39
- this._adapter.addHostListener(TAB_CONSTANTS.events.INTERACTED, this._tabInteractedListener);
32
+ this._adapter.addSlotListener(this._tabsChangedListener);
33
+ this._adapter.addHostListener(TAB_CONSTANTS.events.SELECT, this._tabSelectedListener);
40
34
  this._adapter.addHostListener('keydown', this._keydownListener);
41
- this._adapter.addScrollListener(this._scrollListener);
42
- this._adapter.setUnderline(this._underline);
43
- this._adapter.setLayoutMode(this._layoutMode);
44
- this._adapter.setLayoutAlign(this._layoutAlign);
45
- window.requestAnimationFrame(() => {
46
- this._syncScrollButtons();
47
- this._adapter.ensureFocusableTab();
48
- });
35
+ this._adapter.setVertical(this._vertical);
36
+ if (this._scrollButtons) {
37
+ this._adapter.initializeContainerSizeObserver(this._resizeListener);
38
+ this._adapter.initializeScrollObserver(this._scrollListener);
39
+ this._updateScrollState();
40
+ }
41
+ this._tryScrollActiveTabIntoView();
49
42
  this._isInitialized = true;
50
43
  }
51
- disconnect() {
52
- this._adapter.destroyTabScroller();
53
- this._adapter.removeTabChangeListener(this._tabsChangedListener);
54
- this._adapter.removeHostListener(TAB_CONSTANTS.events.INTERACTED, this._tabInteractedListener);
55
- this._adapter.removeHostListener('keydown', this._keydownListener);
44
+ destroy() {
45
+ this._adapter.destroyContainerSizeObserver();
46
+ this._adapter.destroyScrollObserver(this._scrollListener);
56
47
  this._isInitialized = false;
57
48
  }
58
- _onTabsChanged(evt) {
59
- this._adapter.initializeTabs(this._activeTab, this._isFixed);
60
- this._adapter.ensureFocusableTab();
61
- // We need to wait a full cycle to scroll the active tab into view
62
- window.setTimeout(() => {
63
- window.requestAnimationFrame(() => {
64
- this.scrollIntoView(this._activeTab);
65
- this._syncScrollButtons();
66
- });
67
- });
49
+ async _onTabsChanged() {
50
+ this._tabs = this._adapter.getTabs();
51
+ this._syncTabState();
52
+ this._tryScrollActiveTabIntoView();
53
+ }
54
+ _onTabSelected(evt) {
55
+ this._selectTab(evt.target);
68
56
  }
69
- _onTabInteracted(evt) {
70
- const activatedTab = evt.target;
71
- const activatedTabIndex = this._adapter.getTabIndex(activatedTab);
72
- // Check if the event and requested tab index is valid
73
- const isTabEvent = activatedTab.tagName.toLowerCase() === TAB_CONSTANTS.elementName;
74
- const isValidTabIndex = activatedTabIndex !== this._activeTab && this._indexIsInRange(activatedTabIndex);
75
- if (!isTabEvent || !isValidTabIndex) {
57
+ async _onKeydown(evt) {
58
+ var _a, _b;
59
+ const orientation = this._vertical ? 'vertical' : 'horizontal';
60
+ const isNavigationKey = ((_a = NAVIGATION_KEYS.get('default')) === null || _a === void 0 ? void 0 : _a.has(evt.key)) ||
61
+ ((_b = NAVIGATION_KEYS.get(orientation)) === null || _b === void 0 ? void 0 : _b.has(evt.key));
62
+ if (!isNavigationKey) {
76
63
  return;
77
64
  }
78
- // Emit the activate event
79
- const activateEventData = { index: activatedTabIndex };
80
- const canActivate = this._adapter.emitHostEvent(TAB_BAR_CONSTANTS.events.ACTIVATE, activateEventData, true, true);
81
- // Check if listener prevented default on the activate event, and stop now if so
82
- if (!canActivate) {
83
- return;
65
+ evt.preventDefault();
66
+ let index = -1;
67
+ if (evt.key === 'Home') {
68
+ // Locate the first non-disabled tab
69
+ index = this._tabs.findIndex(tab => !tab.disabled);
84
70
  }
85
- this.activateTab(activatedTabIndex);
86
- this._adapter.focusTabAtIndex(activatedTabIndex);
87
- }
88
- _onKeydown(evt) {
89
- const key = this._getKeyFromEvent(evt);
90
- // Early exit if the event key isn't one of the keyboard navigation keys
91
- if (!key) {
92
- return;
71
+ else if (evt.key === 'End') {
72
+ // Locate the last non-disabled tab
73
+ index = this._tabs.reduceRight((acc, tab, i) => !tab.disabled && acc === -1 ? i : acc, -1);
74
+ }
75
+ else {
76
+ // Locate the next or previous tab based on the key that was pressed
77
+ const currentIndex = this._tabs.findIndex(tab => tab.matches(':focus'));
78
+ const isPrevKey = evt.key === 'ArrowLeft' || evt.key === 'ArrowUp';
79
+ const calcIndex = (startIndex) => {
80
+ var _a;
81
+ index = startIndex + (isPrevKey ? -1 : 1);
82
+ index = index < 0 ? this._tabs.length - 1 : index % this._tabs.length;
83
+ // Try to recurse until we find a non-disabled tab (unless all tabs are disabled already)
84
+ const isAllTabsDisabled = this._tabs.every(tab => tab.disabled);
85
+ if (!isAllTabsDisabled && ((_a = this._tabs[index]) === null || _a === void 0 ? void 0 : _a.disabled)) {
86
+ calcIndex(index);
87
+ }
88
+ };
89
+ calcIndex(currentIndex);
93
90
  }
94
- // Prevent default behavior for movement keys, but not for activation keys, since :active is used to apply ripple
95
- if (!this._isActivationKey(key)) {
96
- evt.preventDefault();
91
+ if (index === -1) {
92
+ return;
97
93
  }
98
94
  if (this._autoActivate) {
99
- if (this._isActivationKey(key)) {
100
- return;
101
- }
102
- const index = this._determineTargetFromKey(this._activeTab, key);
103
- if (this._activeTab === index) {
104
- return;
105
- }
106
- const activateEventData = { index };
107
- const canActivate = this._adapter.emitHostEvent(TAB_BAR_CONSTANTS.events.ACTIVATE, activateEventData, true, true);
108
- if (canActivate) {
109
- this.activateTab(index);
110
- this._adapter.focusTabAtIndex(index);
111
- }
95
+ this._selectTab(this._tabs[index]);
112
96
  }
113
97
  else {
114
- const focusedTabIndex = this._adapter.getFocusedTabIndex();
115
- if (focusedTabIndex === -1) {
116
- return;
117
- }
118
- if (this._isActivationKey(key)) {
119
- const activateEventData = { index: focusedTabIndex };
120
- const canActivate = this._adapter.emitHostEvent(TAB_BAR_CONSTANTS.events.ACTIVATE, activateEventData, true, true);
121
- if (canActivate) {
122
- this.activateTab(focusedTabIndex);
123
- }
124
- }
125
- else {
126
- const index = this._determineTargetFromKey(focusedTabIndex, key);
127
- if (focusedTabIndex === index) {
128
- return;
129
- }
130
- this._adapter.focusTabAtIndex(index);
131
- this.scrollIntoView(index);
132
- }
98
+ this._tabs[index].focus({ preventScroll: true });
99
+ await this._adapter.tryScrollTabIntoView(this._tabs[index]);
133
100
  }
134
101
  }
135
- _onScrollPrevious(evt) {
136
- const scrollAmount = -this._adapter.getOffsetWidth();
137
- this._adapter.incrementScroll(scrollAmount);
138
- this._syncScrollButtons();
139
- }
140
- _onScrollNext(evt) {
141
- const scrollAmount = this._adapter.getOffsetWidth();
142
- this._adapter.incrementScroll(scrollAmount);
143
- this._syncScrollButtons();
144
- }
145
- _onScroll(evt) {
146
- this._syncScrollButtons();
147
- }
148
- _syncScrollButtons() {
149
- const isScrollable = this._isScrollable();
150
- this._adapter.setPreviousButtonVisibility(isScrollable);
151
- this._adapter.setNextButtonVisibility(isScrollable);
152
- if (isScrollable) {
153
- this._adapter.setPreviousButtonEnabled(this._adapter.isScrolled());
154
- this._adapter.setNextButtonEnabled(!this._adapter.isScrolledEnd());
102
+ async _selectTab(tab, emitEvent = true) {
103
+ if (!tab || tab.disabled) {
104
+ return;
155
105
  }
156
- }
157
- /**
158
- * Determines the index of the adjacent tab closest to either edge of the Tab Bar
159
- * @param index The index of the tab
160
- * @param tabDimensions The dimensions of the tab
161
- * @param scrollPosition The current scroll position
162
- * @param barWidth The width of the tab bar
163
- */
164
- _findAdjacentTabIndexClosestToEdge(index, tabDimensions, scrollPosition, barWidth) {
165
- const relativeRootLeft = tabDimensions.rootLeft - scrollPosition;
166
- const relativeRootRight = tabDimensions.rootRight - scrollPosition - barWidth;
167
- const relativeRootDelta = relativeRootLeft + relativeRootRight;
168
- const leftEdgeIsCloser = relativeRootLeft < 0 || relativeRootDelta < 0;
169
- const rightEdgeIsCloser = relativeRootRight > 0 || relativeRootDelta > 0;
170
- if (leftEdgeIsCloser) {
171
- return index - 1;
106
+ const currentSelectedTab = this._tabs.find(t => t.selected);
107
+ if (currentSelectedTab === tab) {
108
+ return;
172
109
  }
173
- if (rightEdgeIsCloser) {
174
- return index + 1;
110
+ if (emitEvent) {
111
+ const index = this._tabs.indexOf(tab);
112
+ const cancelled = !this._adapter.emitHostEvent(TAB_BAR_CONSTANTS.events.CHANGE, index, true, true);
113
+ if (cancelled) {
114
+ return;
115
+ }
175
116
  }
176
- return -1;
177
- }
178
- /**
179
- * Calculates the scroll increment that will make the tab at the given index visible
180
- * @param index The index of the tab
181
- * @param nextIndex The index of the next tab
182
- * @param scrollPosition The current scroll position
183
- * @param barWidth The width of the tab-bar
184
- */
185
- _calculateScrollIncrement(index, nextIndex, scrollPosition, barWidth) {
186
- const nextTabDimensions = this._adapter.getTabDimensionsAtIndex(nextIndex);
187
- const relativeContentLeft = nextTabDimensions.contentLeft - scrollPosition - barWidth;
188
- const relativeContentRight = nextTabDimensions.contentRight - scrollPosition;
189
- const leftIncrement = relativeContentRight - TAB_BAR_CONSTANTS.numbers.EXTRA_SCROLL_AMOUNT;
190
- const rightIncrement = relativeContentLeft + TAB_BAR_CONSTANTS.numbers.EXTRA_SCROLL_AMOUNT;
191
- if (nextIndex < index) {
192
- return Math.min(leftIncrement, 0);
117
+ // Selecting a tab causes an animation of the indicator to start relative to the currently selected tab
118
+ tab.selected = true;
119
+ tab.focus({ preventScroll: true });
120
+ await this._adapter.tryScrollTabIntoView(tab);
121
+ // Always deselect the currently selected tab after selecting a new tab to allow
122
+ // for the tab indicator animation to run properly (the newly selected tab attempts
123
+ // to locate the current selected tab for its calculations)
124
+ if (currentSelectedTab) {
125
+ currentSelectedTab.selected = false;
193
126
  }
194
- return Math.max(rightIncrement, 0);
127
+ this._activeTab = this._tabs.indexOf(tab);
195
128
  }
196
129
  /**
197
- * Private method for determining the index of the destination tab based on what key was pressed
198
- * @param origin The original index from which to determine the destination
199
- * @param key The name of the key
130
+ * Ensures that all tabs have the correct state based on the tab bar state.
131
+ *
132
+ * This is called whenever a child tab is added to the DOM.
200
133
  */
201
- _determineTargetFromKey(origin, key, nextIndex) {
202
- if (origin === nextIndex) {
203
- return origin;
204
- }
205
- const maxIndex = this._adapter.getTabCount() - 1;
206
- const shouldGoToEnd = key === TAB_BAR_CONSTANTS.strings.END_KEY;
207
- const shouldDecrement = key === TAB_BAR_CONSTANTS.strings.ARROW_LEFT_KEY;
208
- const shouldIncrement = key === TAB_BAR_CONSTANTS.strings.ARROW_RIGHT_KEY;
209
- let index = nextIndex !== undefined ? nextIndex : origin;
210
- if (shouldGoToEnd) {
211
- index = maxIndex;
212
- }
213
- else if (shouldDecrement) {
214
- index -= 1;
215
- }
216
- else if (shouldIncrement) {
217
- index += 1;
218
- }
219
- else {
220
- index = 0;
221
- }
222
- if (index < 0) {
223
- index = maxIndex;
224
- }
225
- else if (index > maxIndex) {
226
- index = 0;
227
- }
228
- // If this tab is disabled, then we'll try again...
229
- if (this._adapter.isTabDisabled(index)) {
230
- return this._determineTargetFromKey(origin, key, index);
231
- }
232
- return index;
233
- }
234
- _isScrollable() {
235
- return this._forceScrollButtons ||
236
- (this._scrollButtons &&
237
- !Platform.isMobile &&
238
- !this._isFixed &&
239
- this._adapter.getScrollContentWidth() > this._adapter.getOffsetWidth());
240
- }
241
- _getKeyFromEvent(evt) {
242
- if (ACCEPTABLE_KEYS.includes(evt.key)) {
243
- return evt.key;
244
- }
245
- return KEYCODE_MAP[evt.keyCode];
134
+ _syncTabState() {
135
+ this._tabs.forEach((tab, index) => {
136
+ tab.selected = index === this._activeTab;
137
+ tab.disabled = this._disabled;
138
+ tab.vertical = this._vertical;
139
+ tab.stacked = this._stacked;
140
+ tab.secondary = this._secondary;
141
+ tab.inverted = this._inverted;
142
+ });
246
143
  }
247
- _isActivationKey(key) {
248
- return key === TAB_BAR_CONSTANTS.strings.SPACE_KEY || key === TAB_BAR_CONSTANTS.strings.ENTER_KEY;
144
+ /** Called when the container size changes, but only if scroll buttons are enabled. */
145
+ _onResize() {
146
+ this._detectScrollableStatus();
249
147
  }
250
- _indexIsInRange(index) {
251
- return index >= 0 && index < this._adapter.getTabCount();
148
+ /** Called when the scroll container scrolls, but only if scroll buttons are enabled. */
149
+ _onScroll() {
150
+ this._updateScrollState();
252
151
  }
253
- activateTab(index) {
254
- if (!isNumber(index)) {
255
- index = -1;
256
- }
257
- // If we have a currently selected tab we need to deactivate that now
258
- if (this._activeTab !== -1) {
259
- this._adapter.deactivateTab(this._activeTab);
260
- }
261
- // Activate the requested tab
262
- const previousTabBounds = this._adapter.getTabBounds(this._activeTab);
263
- this._adapter.activateTab(index, previousTabBounds);
264
- this._adapter.syncTabIndex(index);
265
- this._adapter.ensureFocusableTab();
266
- this.scrollIntoView(index);
267
- this._activeTab = index;
268
- this._syncScrollButtons();
269
- this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.ACTIVE_TAB, this._activeTab.toString());
270
- }
271
- scrollIntoView(index) {
272
- if (!this._indexIsInRange(index)) {
152
+ /** Handles clicking the scroll backward button. */
153
+ _onScrollBackward() {
154
+ this._adapter.scroll('backward');
155
+ }
156
+ /** Handles clicking the scroll forward button. */
157
+ _onScrollForward() {
158
+ this._adapter.scroll('forward');
159
+ }
160
+ /** Determines whether scroll buttons should be displayed based on the size of the container. */
161
+ _detectScrollableStatus() {
162
+ const scrollable = this._adapter.isScrollable();
163
+ if (this._scrollButtonsVisible === scrollable) {
273
164
  return;
274
165
  }
275
- if (index === 0) {
276
- return this._adapter.scrollTo(0);
166
+ this._adapter.setScrollButtons(scrollable);
167
+ if (scrollable) {
168
+ this._adapter.initializeScrollObserver(this._scrollListener);
169
+ this._updateScrollState();
170
+ this._adapter.setScrollBackwardButtonListener(this._scrollBackwardButtonListener);
171
+ this._adapter.setScrollForwardButtonListener(this._scrollForwardButtonListener);
277
172
  }
278
- if (index === this._adapter.getTabCount() - 1) {
279
- return this._adapter.scrollTo(this._adapter.getScrollContentWidth());
280
- }
281
- const scrollPosition = this._adapter.getScrollPosition();
282
- const barWidth = this._adapter.getOffsetWidth();
283
- const tabDimensions = this._adapter.getTabDimensionsAtIndex(index);
284
- const nextIndex = this._findAdjacentTabIndexClosestToEdge(index, tabDimensions, scrollPosition, barWidth);
285
- if (!this._indexIsInRange(nextIndex)) {
286
- return;
173
+ else {
174
+ this._adapter.destroyScrollObserver(this._scrollListener);
175
+ }
176
+ this._scrollButtonsVisible = scrollable;
177
+ }
178
+ /** Updates the enabled/disabled state of the scroll buttons. */
179
+ _updateScrollState() {
180
+ const { isScrolledEnd, isScrolledStart } = this._adapter.getScrollState();
181
+ const state = {
182
+ backwardEnabled: !isScrolledStart,
183
+ forwardEnabled: !isScrolledEnd
184
+ };
185
+ this._adapter.syncScrollButtons(state);
186
+ }
187
+ _tryScrollActiveTabIntoView() {
188
+ if (this._tabScrollAnimationFrame) {
189
+ window.cancelAnimationFrame(this._tabScrollAnimationFrame);
190
+ }
191
+ // We batch the tab scrolling into a single animation frame to unnecessarily scrolling for each tab
192
+ this._tabScrollAnimationFrame = window.requestAnimationFrame(() => {
193
+ this._tabScrollAnimationFrame = undefined;
194
+ if (this._adapter.isScrollable()) {
195
+ if (typeof this._activeTab === 'number' && this._activeTab >= 0 && this._tabs[this._activeTab]) {
196
+ this._adapter.tryScrollTabIntoView(this._tabs[this._activeTab]);
197
+ }
198
+ }
199
+ });
200
+ }
201
+ get disabled() {
202
+ return this._disabled;
203
+ }
204
+ set disabled(value) {
205
+ value = Boolean(value);
206
+ if (this._disabled !== value) {
207
+ this._disabled = value;
208
+ this._tabs.forEach(tab => tab.disabled = this._disabled);
209
+ this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.DISABLED, this._disabled);
287
210
  }
288
- const scrollIncrement = this._calculateScrollIncrement(index, nextIndex, scrollPosition, barWidth);
289
- this._adapter.incrementScroll(scrollIncrement);
290
211
  }
291
- /** Gets and sets the active tab index. */
292
212
  get activeTab() {
293
213
  return this._activeTab;
294
214
  }
295
215
  set activeTab(value) {
296
216
  if (this._activeTab !== value) {
297
- if (!this._isInitialized) {
298
- this._activeTab = value;
299
- this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.ACTIVE_TAB, this._activeTab.toString());
217
+ this._activeTab = value !== null && value !== void 0 ? value : undefined;
218
+ if (typeof this._activeTab === 'number') {
219
+ const newSelectedTab = this._tabs[this._activeTab];
220
+ this._selectTab(newSelectedTab, false);
221
+ this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.ACTIVE_TAB, String(this._activeTab));
300
222
  }
301
223
  else {
302
- this.activateTab(value);
224
+ this._tabs.forEach(tab => tab.selected = false);
225
+ this._adapter.removeHostAttribute(TAB_BAR_CONSTANTS.attributes.ACTIVE_TAB);
303
226
  }
304
227
  }
305
228
  }
306
- get _isFixed() {
307
- return this._layoutMode === 'fixed';
308
- }
309
- get layoutMode() {
310
- return this._layoutMode;
311
- }
312
- set layoutMode(value) {
313
- if (this._layoutMode !== value) {
314
- this._layoutMode = value;
315
- this._adapter.setLayoutMode(this._layoutMode);
316
- this._syncScrollButtons();
317
- }
229
+ get vertical() {
230
+ return this._vertical;
318
231
  }
319
- get layoutAlign() {
320
- return this._layoutAlign;
321
- }
322
- set layoutAlign(value) {
323
- if (this._layoutAlign !== value) {
324
- this._layoutAlign = value;
325
- this._adapter.setLayoutAlign(this._layoutAlign);
232
+ set vertical(value) {
233
+ value = Boolean(value);
234
+ if (this._vertical !== value) {
235
+ this._vertical = value;
236
+ if (this._isInitialized) {
237
+ this._adapter.setVertical(this._vertical);
238
+ }
239
+ this._tabs.forEach(tab => tab.vertical = this._vertical);
240
+ if (this._scrollButtonsVisible) {
241
+ this._adapter.updateScrollButtonIcons(this._vertical);
242
+ }
243
+ this._adapter.toggleHostAttribute(TAB_CONSTANTS.attributes.VERTICAL, this._vertical);
326
244
  }
327
245
  }
328
- get underline() {
329
- return this._underline;
246
+ get clustered() {
247
+ return this._clustered;
330
248
  }
331
- set underline(value) {
332
- if (this._underline !== value) {
333
- this._underline = value;
334
- this._adapter.setUnderline(this._underline);
335
- this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.UNDERLINE, this._underline);
249
+ set clustered(value) {
250
+ value = Boolean(value);
251
+ if (this._clustered !== value) {
252
+ this._clustered = value;
253
+ this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.CLUSTERED, this._clustered);
336
254
  }
337
255
  }
338
256
  get stacked() {
339
257
  return this._stacked;
340
258
  }
341
259
  set stacked(value) {
260
+ value = Boolean(value);
342
261
  if (this._stacked !== value) {
343
262
  this._stacked = value;
344
- this._adapter.setStacked(this._stacked);
345
- if (this._stacked) {
346
- this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.STACKED);
347
- }
348
- else {
349
- this._adapter.removeHostAttribute(TAB_BAR_CONSTANTS.attributes.STACKED);
350
- }
263
+ this._tabs.forEach(tab => tab.stacked = this._stacked);
264
+ this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.STACKED, this._stacked);
351
265
  }
352
266
  }
353
- get scrollButtons() {
354
- return this._scrollButtons;
267
+ get secondary() {
268
+ return this._secondary;
355
269
  }
356
- set scrollButtons(value) {
357
- if (this._scrollButtons !== value) {
358
- this._scrollButtons = value;
359
- this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.SCROLL_BUTTONS, this._scrollButtons.toString());
360
- if (this._isInitialized) {
361
- this._syncScrollButtons();
362
- }
270
+ set secondary(value) {
271
+ value = Boolean(value);
272
+ if (this._secondary !== value) {
273
+ this._secondary = value;
274
+ this._tabs.forEach(tab => tab.secondary = this._secondary);
275
+ this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.SECONDARY, this._secondary);
363
276
  }
364
277
  }
365
- get forceScrollButtons() {
366
- return this._forceScrollButtons;
278
+ get inverted() {
279
+ return this._inverted;
367
280
  }
368
- set forceScrollButtons(value) {
369
- if (this._forceScrollButtons !== value) {
370
- this._forceScrollButtons = value;
371
- if (this._isInitialized) {
372
- this._syncScrollButtons();
373
- }
281
+ set inverted(value) {
282
+ value = Boolean(value);
283
+ if (this._inverted !== value) {
284
+ this._inverted = value;
285
+ this._tabs.forEach(tab => tab.inverted = this._inverted);
286
+ this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.INVERTED, this._inverted);
374
287
  }
375
288
  }
376
289
  get autoActivate() {
377
290
  return this._autoActivate;
378
291
  }
379
292
  set autoActivate(value) {
293
+ value = Boolean(value);
380
294
  if (this._autoActivate !== value) {
381
295
  this._autoActivate = value;
382
- this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.AUTO_ACTIVATE, this._autoActivate.toString());
296
+ this._adapter.toggleHostAttribute(TAB_BAR_CONSTANTS.attributes.AUTO_ACTIVATE, this._autoActivate);
297
+ }
298
+ }
299
+ get scrollButtons() {
300
+ return this._scrollButtons;
301
+ }
302
+ set scrollButtons(value) {
303
+ value = Boolean(value);
304
+ if (this._scrollButtons !== value) {
305
+ this._scrollButtons = Boolean(value);
306
+ if (this._isInitialized) {
307
+ if (this._scrollButtons) {
308
+ this._adapter.initializeContainerSizeObserver(this._resizeListener);
309
+ this._adapter.initializeScrollObserver(this._scrollListener);
310
+ this._detectScrollableStatus();
311
+ this._updateScrollState();
312
+ this._tryScrollActiveTabIntoView();
313
+ }
314
+ else {
315
+ this._adapter.destroyContainerSizeObserver();
316
+ this._adapter.destroyScrollObserver(this._scrollListener);
317
+ this._adapter.setScrollButtons(this._scrollButtons);
318
+ this._scrollButtonsVisible = false;
319
+ }
320
+ }
321
+ this._adapter.setHostAttribute(TAB_BAR_CONSTANTS.attributes.SCROLL_BUTTONS, String(this._scrollButtons));
383
322
  }
384
323
  }
385
324
  }