@ionic/core 8.4.4 → 8.4.6-dev.11741906766.14c01edc

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 (462) hide show
  1. package/components/checkbox.js +40 -6
  2. package/components/index6.js +11 -3
  3. package/components/ion-input.js +22 -9
  4. package/components/ion-item-divider.js +2 -2
  5. package/components/ion-item-group.js +1 -1
  6. package/components/ion-item-option.js +2 -2
  7. package/components/ion-item-options.js +1 -1
  8. package/components/ion-item-sliding.js +1 -1
  9. package/components/ion-loading.js +2 -2
  10. package/components/ion-menu-button.js +2 -2
  11. package/components/ion-menu-toggle.js +2 -2
  12. package/components/ion-menu.js +2 -2
  13. package/components/ion-nav-link.js +1 -1
  14. package/components/ion-nav.js +1 -1
  15. package/components/ion-note.js +2 -2
  16. package/components/ion-picker-legacy.js +2 -2
  17. package/components/ion-progress-bar.js +1 -1
  18. package/components/ion-range.js +3 -3
  19. package/components/ion-refresher-content.js +1 -1
  20. package/components/ion-refresher.js +1 -1
  21. package/components/ion-reorder-group.js +1 -1
  22. package/components/ion-reorder.js +1 -1
  23. package/components/ion-router-link.js +2 -2
  24. package/components/ion-router-outlet.js +1 -1
  25. package/components/ion-row.js +1 -1
  26. package/components/ion-searchbar.js +4 -4
  27. package/components/ion-segment-button.js +2 -2
  28. package/components/ion-segment-content.js +1 -1
  29. package/components/ion-segment-view.js +2 -2
  30. package/components/ion-segment.js +2 -2
  31. package/components/ion-select-option.js +1 -1
  32. package/components/ion-select.js +50 -6
  33. package/components/ion-skeleton-text.js +2 -2
  34. package/components/ion-split-pane.js +2 -2
  35. package/components/ion-tab-bar.js +2 -2
  36. package/components/ion-tab-button.js +2 -2
  37. package/components/ion-tab.js +2 -2
  38. package/components/ion-tabs.js +1 -1
  39. package/components/ion-text.js +2 -2
  40. package/components/ion-textarea.js +21 -8
  41. package/components/ion-thumbnail.js +1 -1
  42. package/components/ion-toast.js +2 -2
  43. package/components/ion-toggle.js +40 -6
  44. package/components/label.js +2 -2
  45. package/components/list-header.js +2 -2
  46. package/components/modal.js +267 -35
  47. package/components/picker-column-option.js +2 -2
  48. package/components/picker-column2.js +2 -2
  49. package/components/popover.js +2 -2
  50. package/components/radio-group.js +39 -2
  51. package/components/radio.js +3 -3
  52. package/components/ripple-effect.js +1 -1
  53. package/components/select-modal.js +1 -1
  54. package/components/select-popover.js +1 -1
  55. package/components/spinner.js +1 -1
  56. package/components/title.js +2 -2
  57. package/components/toolbar.js +2 -2
  58. package/css/core.css.map +1 -1
  59. package/css/ionic.bundle.css.map +1 -1
  60. package/dist/cjs/{data-21dc0f81.js → data-27cc2c9c.js} +1 -1
  61. package/dist/cjs/{index-5915f9b3.js → index-48b2a28e.js} +11 -3
  62. package/dist/cjs/{index-77e085b4.js → index-9b945a2d.js} +1 -1
  63. package/dist/cjs/{index-55a184f7.js → index-f68a486a.js} +3 -3
  64. package/dist/cjs/{index-864d95f4.js → index-fd6383b6.js} +1 -1
  65. package/dist/cjs/index.cjs.js +6 -6
  66. package/dist/cjs/{input-shims-52924092.js → input-shims-2d27a5be.js} +4 -2
  67. package/dist/cjs/{input.utils-e4144534.js → input.utils-2f642324.js} +1 -1
  68. package/dist/cjs/ion-accordion_2.cjs.entry.js +1 -1
  69. package/dist/cjs/ion-action-sheet.cjs.entry.js +2 -2
  70. package/dist/cjs/ion-alert.cjs.entry.js +2 -2
  71. package/dist/cjs/ion-app_8.cjs.entry.js +10 -10
  72. package/dist/cjs/ion-avatar_3.cjs.entry.js +1 -1
  73. package/dist/cjs/ion-button_2.cjs.entry.js +1 -1
  74. package/dist/cjs/ion-checkbox.cjs.entry.js +37 -6
  75. package/dist/cjs/ion-col_3.cjs.entry.js +1 -1
  76. package/dist/cjs/ion-datetime-button.cjs.entry.js +2 -2
  77. package/dist/cjs/ion-datetime_3.cjs.entry.js +7 -7
  78. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +2 -2
  79. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +1 -1
  80. package/dist/cjs/ion-input.cjs.entry.js +21 -9
  81. package/dist/cjs/ion-item-option_3.cjs.entry.js +6 -6
  82. package/dist/cjs/ion-item_8.cjs.entry.js +11 -11
  83. package/dist/cjs/ion-loading.cjs.entry.js +4 -4
  84. package/dist/cjs/ion-menu_3.cjs.entry.js +9 -9
  85. package/dist/cjs/ion-modal.cjs.entry.js +270 -39
  86. package/dist/cjs/ion-nav_2.cjs.entry.js +4 -4
  87. package/dist/cjs/ion-picker-column-option.cjs.entry.js +2 -2
  88. package/dist/cjs/ion-popover.cjs.entry.js +5 -5
  89. package/dist/cjs/ion-progress-bar.cjs.entry.js +1 -1
  90. package/dist/cjs/ion-radio_2.cjs.entry.js +39 -4
  91. package/dist/cjs/ion-range.cjs.entry.js +5 -5
  92. package/dist/cjs/ion-refresher_2.cjs.entry.js +4 -4
  93. package/dist/cjs/ion-reorder_2.cjs.entry.js +4 -4
  94. package/dist/cjs/ion-ripple-effect.cjs.entry.js +1 -1
  95. package/dist/cjs/ion-route_4.cjs.entry.js +2 -2
  96. package/dist/cjs/ion-searchbar.cjs.entry.js +4 -4
  97. package/dist/cjs/ion-segment-content.cjs.entry.js +1 -1
  98. package/dist/cjs/ion-segment-view.cjs.entry.js +2 -2
  99. package/dist/cjs/ion-segment_2.cjs.entry.js +4 -4
  100. package/dist/cjs/ion-select-modal.cjs.entry.js +3 -3
  101. package/dist/cjs/ion-select_3.cjs.entry.js +51 -10
  102. package/dist/cjs/ion-spinner.cjs.entry.js +1 -1
  103. package/dist/cjs/ion-split-pane.cjs.entry.js +2 -2
  104. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +4 -4
  105. package/dist/cjs/ion-tab_2.cjs.entry.js +3 -3
  106. package/dist/cjs/ion-text.cjs.entry.js +2 -2
  107. package/dist/cjs/ion-textarea.cjs.entry.js +20 -8
  108. package/dist/cjs/ion-toast.cjs.entry.js +4 -4
  109. package/dist/cjs/ion-toggle.cjs.entry.js +37 -6
  110. package/dist/cjs/ionic.cjs.js +1 -1
  111. package/dist/cjs/{ios.transition-abac30e4.js → ios.transition-f970164c.js} +2 -2
  112. package/dist/cjs/loader.cjs.js +1 -1
  113. package/dist/cjs/{md.transition-e328f70d.js → md.transition-aa8820dd.js} +2 -2
  114. package/dist/cjs/{overlays-2f264f05.js → overlays-737576a2.js} +1 -1
  115. package/dist/cjs/{status-tap-191ccc90.js → status-tap-08d1ac81.js} +3 -2
  116. package/dist/collection/components/checkbox/checkbox.ios.css +52 -15
  117. package/dist/collection/components/checkbox/checkbox.js +90 -4
  118. package/dist/collection/components/checkbox/checkbox.md.css +52 -15
  119. package/dist/collection/components/input/input.ios.css +3 -2
  120. package/dist/collection/components/input/input.js +18 -4
  121. package/dist/collection/components/input/input.md.css +7 -2
  122. package/dist/collection/components/item-divider/item-divider.js +2 -2
  123. package/dist/collection/components/item-group/item-group.js +1 -1
  124. package/dist/collection/components/item-option/item-option.js +2 -2
  125. package/dist/collection/components/item-options/item-options.js +1 -1
  126. package/dist/collection/components/item-sliding/item-sliding.js +1 -1
  127. package/dist/collection/components/label/label.js +2 -2
  128. package/dist/collection/components/list-header/list-header.js +2 -2
  129. package/dist/collection/components/loading/loading.js +2 -2
  130. package/dist/collection/components/menu/menu.js +2 -2
  131. package/dist/collection/components/menu-button/menu-button.js +2 -2
  132. package/dist/collection/components/menu-toggle/menu-toggle.js +2 -2
  133. package/dist/collection/components/modal/animations/ios.enter.js +50 -4
  134. package/dist/collection/components/modal/animations/ios.leave.js +24 -2
  135. package/dist/collection/components/modal/animations/md.enter.js +52 -5
  136. package/dist/collection/components/modal/animations/md.leave.js +26 -3
  137. package/dist/collection/components/modal/animations/sheet.js +11 -2
  138. package/dist/collection/components/modal/gestures/sheet.js +87 -10
  139. package/dist/collection/components/modal/modal.ios.css +16 -0
  140. package/dist/collection/components/modal/modal.js +32 -7
  141. package/dist/collection/components/modal/modal.md.css +6 -0
  142. package/dist/collection/components/nav/nav.js +1 -1
  143. package/dist/collection/components/nav-link/nav-link.js +1 -1
  144. package/dist/collection/components/note/note.js +2 -2
  145. package/dist/collection/components/picker-column-option/picker-column-option.js +2 -2
  146. package/dist/collection/components/picker-legacy/picker.js +2 -2
  147. package/dist/collection/components/picker-legacy-column/picker-column.js +2 -2
  148. package/dist/collection/components/popover/popover.js +2 -2
  149. package/dist/collection/components/progress-bar/progress-bar.js +1 -1
  150. package/dist/collection/components/radio/radio.js +3 -3
  151. package/dist/collection/components/radio-group/radio-group.ios.css +205 -0
  152. package/dist/collection/components/radio-group/radio-group.js +72 -1
  153. package/dist/collection/components/radio-group/radio-group.md.css +205 -0
  154. package/dist/collection/components/range/range.js +3 -3
  155. package/dist/collection/components/refresher/refresher.js +1 -1
  156. package/dist/collection/components/refresher-content/refresher-content.js +1 -1
  157. package/dist/collection/components/reorder/reorder.js +1 -1
  158. package/dist/collection/components/reorder-group/reorder-group.js +1 -1
  159. package/dist/collection/components/ripple-effect/ripple-effect.js +1 -1
  160. package/dist/collection/components/router-link/router-link.js +2 -2
  161. package/dist/collection/components/router-outlet/router-outlet.js +1 -1
  162. package/dist/collection/components/row/row.js +1 -1
  163. package/dist/collection/components/searchbar/searchbar.js +4 -4
  164. package/dist/collection/components/segment/segment.js +2 -2
  165. package/dist/collection/components/segment-button/segment-button.js +2 -2
  166. package/dist/collection/components/segment-content/segment-content.js +1 -1
  167. package/dist/collection/components/segment-view/segment-view.js +2 -2
  168. package/dist/collection/components/select/select.ios.css +59 -0
  169. package/dist/collection/components/select/select.js +100 -4
  170. package/dist/collection/components/select/select.md.css +61 -0
  171. package/dist/collection/components/select-modal/select-modal.js +1 -1
  172. package/dist/collection/components/select-option/select-option.js +1 -1
  173. package/dist/collection/components/select-popover/select-popover.js +1 -1
  174. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -2
  175. package/dist/collection/components/spinner/spinner.js +1 -1
  176. package/dist/collection/components/split-pane/split-pane.js +2 -2
  177. package/dist/collection/components/tab/tab.js +2 -2
  178. package/dist/collection/components/tab-bar/tab-bar.js +2 -2
  179. package/dist/collection/components/tab-button/tab-button.js +2 -2
  180. package/dist/collection/components/tabs/tabs.js +1 -1
  181. package/dist/collection/components/text/text.js +2 -2
  182. package/dist/collection/components/textarea/textarea.ios.css +3 -2
  183. package/dist/collection/components/textarea/textarea.js +17 -3
  184. package/dist/collection/components/textarea/textarea.md.css +7 -2
  185. package/dist/collection/components/thumbnail/thumbnail.js +1 -1
  186. package/dist/collection/components/title/title.js +2 -2
  187. package/dist/collection/components/toast/toast.js +2 -2
  188. package/dist/collection/components/toggle/toggle.ios.css +52 -15
  189. package/dist/collection/components/toggle/toggle.js +90 -4
  190. package/dist/collection/components/toggle/toggle.md.css +52 -15
  191. package/dist/collection/components/toolbar/toolbar.js +6 -2
  192. package/dist/collection/utils/logging/index.js +10 -3
  193. package/dist/docs.json +379 -2
  194. package/dist/esm/{data-ae11fd43.js → data-174ad5e0.js} +1 -1
  195. package/dist/esm/{index-9b0d46f4.js → index-738d7504.js} +11 -3
  196. package/dist/esm/{index-d4642b24.js → index-933ca126.js} +1 -1
  197. package/dist/esm/{index-c4a831fd.js → index-a313df53.js} +3 -3
  198. package/dist/esm/{index-df741ec6.js → index-c63afbe6.js} +1 -1
  199. package/dist/esm/index.js +6 -6
  200. package/dist/esm/{input-shims-80c5b98e.js → input-shims-3070628a.js} +4 -2
  201. package/dist/esm/{input.utils-3a4c0a2a.js → input.utils-926c04a8.js} +1 -1
  202. package/dist/esm/ion-accordion_2.entry.js +1 -1
  203. package/dist/esm/ion-action-sheet.entry.js +2 -2
  204. package/dist/esm/ion-alert.entry.js +2 -2
  205. package/dist/esm/ion-app_8.entry.js +10 -10
  206. package/dist/esm/ion-avatar_3.entry.js +1 -1
  207. package/dist/esm/ion-button_2.entry.js +1 -1
  208. package/dist/esm/ion-checkbox.entry.js +37 -6
  209. package/dist/esm/ion-col_3.entry.js +1 -1
  210. package/dist/esm/ion-datetime-button.entry.js +2 -2
  211. package/dist/esm/ion-datetime_3.entry.js +7 -7
  212. package/dist/esm/ion-infinite-scroll_2.entry.js +2 -2
  213. package/dist/esm/ion-input-password-toggle.entry.js +1 -1
  214. package/dist/esm/ion-input.entry.js +22 -10
  215. package/dist/esm/ion-item-option_3.entry.js +6 -6
  216. package/dist/esm/ion-item_8.entry.js +11 -11
  217. package/dist/esm/ion-loading.entry.js +4 -4
  218. package/dist/esm/ion-menu_3.entry.js +9 -9
  219. package/dist/esm/ion-modal.entry.js +270 -39
  220. package/dist/esm/ion-nav_2.entry.js +4 -4
  221. package/dist/esm/ion-picker-column-option.entry.js +2 -2
  222. package/dist/esm/ion-popover.entry.js +5 -5
  223. package/dist/esm/ion-progress-bar.entry.js +1 -1
  224. package/dist/esm/ion-radio_2.entry.js +39 -4
  225. package/dist/esm/ion-range.entry.js +5 -5
  226. package/dist/esm/ion-refresher_2.entry.js +4 -4
  227. package/dist/esm/ion-reorder_2.entry.js +4 -4
  228. package/dist/esm/ion-ripple-effect.entry.js +1 -1
  229. package/dist/esm/ion-route_4.entry.js +2 -2
  230. package/dist/esm/ion-searchbar.entry.js +4 -4
  231. package/dist/esm/ion-segment-content.entry.js +1 -1
  232. package/dist/esm/ion-segment-view.entry.js +2 -2
  233. package/dist/esm/ion-segment_2.entry.js +4 -4
  234. package/dist/esm/ion-select-modal.entry.js +3 -3
  235. package/dist/esm/ion-select_3.entry.js +51 -10
  236. package/dist/esm/ion-spinner.entry.js +1 -1
  237. package/dist/esm/ion-split-pane.entry.js +2 -2
  238. package/dist/esm/ion-tab-bar_2.entry.js +4 -4
  239. package/dist/esm/ion-tab_2.entry.js +3 -3
  240. package/dist/esm/ion-text.entry.js +2 -2
  241. package/dist/esm/ion-textarea.entry.js +21 -9
  242. package/dist/esm/ion-toast.entry.js +4 -4
  243. package/dist/esm/ion-toggle.entry.js +37 -6
  244. package/dist/esm/ionic.js +1 -1
  245. package/dist/esm/{ios.transition-a81c9c6b.js → ios.transition-5fe4d6c8.js} +2 -2
  246. package/dist/esm/loader.js +1 -1
  247. package/dist/esm/{md.transition-dbb51edc.js → md.transition-3d0d3730.js} +2 -2
  248. package/dist/esm/{overlays-4ff1fca8.js → overlays-7579a420.js} +1 -1
  249. package/dist/esm/{status-tap-73b183f4.js → status-tap-6367b913.js} +3 -2
  250. package/dist/esm-es5/{data-ae11fd43.js → data-174ad5e0.js} +1 -1
  251. package/dist/esm-es5/index-738d7504.js +4 -0
  252. package/dist/esm-es5/{index-d4642b24.js → index-933ca126.js} +1 -1
  253. package/dist/esm-es5/{index-c4a831fd.js → index-a313df53.js} +1 -1
  254. package/dist/esm-es5/{index-df741ec6.js → index-c63afbe6.js} +1 -1
  255. package/dist/esm-es5/index.js +1 -1
  256. package/dist/esm-es5/input-shims-3070628a.js +4 -0
  257. package/dist/esm-es5/{input.utils-3a4c0a2a.js → input.utils-926c04a8.js} +1 -1
  258. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  259. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  260. package/dist/esm-es5/ion-alert.entry.js +1 -1
  261. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  262. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  263. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  264. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  265. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  266. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  267. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  268. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  269. package/dist/esm-es5/ion-input-password-toggle.entry.js +1 -1
  270. package/dist/esm-es5/ion-input.entry.js +1 -1
  271. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  272. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  273. package/dist/esm-es5/ion-loading.entry.js +1 -1
  274. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  275. package/dist/esm-es5/ion-modal.entry.js +1 -1
  276. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  277. package/dist/esm-es5/ion-picker-column-option.entry.js +1 -1
  278. package/dist/esm-es5/ion-popover.entry.js +1 -1
  279. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  280. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  281. package/dist/esm-es5/ion-range.entry.js +1 -1
  282. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  283. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  284. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  285. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  286. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  287. package/dist/esm-es5/ion-segment-content.entry.js +1 -1
  288. package/dist/esm-es5/ion-segment-view.entry.js +1 -1
  289. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  290. package/dist/esm-es5/ion-select-modal.entry.js +1 -1
  291. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  292. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  293. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  294. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  295. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  296. package/dist/esm-es5/ion-text.entry.js +1 -1
  297. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  298. package/dist/esm-es5/ion-toast.entry.js +1 -1
  299. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  300. package/dist/esm-es5/ionic.js +1 -1
  301. package/dist/esm-es5/{ios.transition-a81c9c6b.js → ios.transition-5fe4d6c8.js} +1 -1
  302. package/dist/esm-es5/loader.js +1 -1
  303. package/dist/esm-es5/md.transition-3d0d3730.js +4 -0
  304. package/dist/esm-es5/{overlays-4ff1fca8.js → overlays-7579a420.js} +1 -1
  305. package/dist/esm-es5/status-tap-6367b913.js +4 -0
  306. package/dist/html.html-data.json +48 -0
  307. package/dist/ionic/index.esm.js +1 -1
  308. package/dist/ionic/ionic.esm.js +1 -1
  309. package/dist/ionic/{p-f30071a2.system.js → p-042d5353.system.js} +1 -1
  310. package/dist/ionic/{p-ad780230.js → p-060e4551.js} +1 -1
  311. package/dist/ionic/p-094c82d7.entry.js +4 -0
  312. package/dist/ionic/{p-1ef02643.system.entry.js → p-0adb6909.system.entry.js} +1 -1
  313. package/dist/ionic/{p-a9b9259c.entry.js → p-0be8a0b5.entry.js} +1 -1
  314. package/dist/ionic/{p-811ff2a0.system.entry.js → p-0bedc891.system.entry.js} +1 -1
  315. package/dist/ionic/p-0ec5b7cf.system.js +4 -0
  316. package/dist/ionic/{p-df61d353.entry.js → p-13886789.entry.js} +1 -1
  317. package/dist/ionic/p-143ff664.system.entry.js +4 -0
  318. package/dist/ionic/p-18f9b6d5.entry.js +4 -0
  319. package/dist/ionic/{p-afd7a6a9.entry.js → p-19c32a76.entry.js} +1 -1
  320. package/dist/ionic/{p-dd141012.system.entry.js → p-1a9613bf.system.entry.js} +1 -1
  321. package/dist/ionic/{p-f687573e.system.js → p-1bf5ec17.system.js} +1 -1
  322. package/dist/ionic/{p-dbac4f3e.system.entry.js → p-1d2844a5.system.entry.js} +1 -1
  323. package/dist/ionic/{p-dc8cbb8b.entry.js → p-1f837356.entry.js} +1 -1
  324. package/dist/ionic/p-2027221d.js +4 -0
  325. package/dist/ionic/{p-b8e3b3ca.system.entry.js → p-21371278.system.entry.js} +1 -1
  326. package/dist/ionic/{p-adbbf974.system.js → p-24ae7b33.system.js} +1 -1
  327. package/dist/ionic/p-29a5b4e4.entry.js +4 -0
  328. package/dist/ionic/{p-611d105b.entry.js → p-2ee9a2c6.entry.js} +1 -1
  329. package/dist/ionic/p-2fa5a4b1.entry.js +4 -0
  330. package/dist/ionic/{p-782ed885.system.js → p-3479f51b.system.js} +1 -1
  331. package/dist/ionic/{p-3705c194.entry.js → p-35f14792.entry.js} +1 -1
  332. package/dist/ionic/{p-21d1c1c7.system.entry.js → p-37a438ad.system.entry.js} +2 -2
  333. package/dist/ionic/{p-cd239b25.entry.js → p-3af7b907.entry.js} +1 -1
  334. package/dist/ionic/{p-8dbe745b.system.js → p-3bd5fedc.system.js} +1 -1
  335. package/dist/ionic/{p-31d6b3d0.system.entry.js → p-3be7cdeb.system.entry.js} +2 -2
  336. package/dist/ionic/p-3f4327f7.js +4 -0
  337. package/dist/ionic/{p-85f19de9.entry.js → p-42f6e75c.entry.js} +1 -1
  338. package/dist/ionic/{p-bf973e4b.system.entry.js → p-4470f87b.system.entry.js} +2 -2
  339. package/dist/ionic/p-4493c1ac.entry.js +4 -0
  340. package/dist/ionic/{p-0b860115.system.entry.js → p-4630688e.system.entry.js} +1 -1
  341. package/dist/ionic/{p-a8cc566d.system.entry.js → p-472c7e08.system.entry.js} +1 -1
  342. package/dist/ionic/{p-1a289aba.system.entry.js → p-491de063.system.entry.js} +1 -1
  343. package/dist/ionic/{p-ec631b0f.js → p-4c44d04c.js} +1 -1
  344. package/dist/ionic/{p-8db97fa1.js → p-4c94580e.js} +1 -1
  345. package/dist/ionic/{p-36079188.system.entry.js → p-4d0190ad.system.entry.js} +1 -1
  346. package/dist/ionic/{p-53d4d8c7.entry.js → p-50f38461.entry.js} +1 -1
  347. package/dist/ionic/{p-91fe21bb.system.js → p-51c363e7.system.js} +1 -1
  348. package/dist/ionic/{p-bf7f7084.system.entry.js → p-524ad57e.system.entry.js} +2 -2
  349. package/dist/ionic/p-54893ae3.entry.js +4 -0
  350. package/dist/ionic/p-54e9620f.js +4 -0
  351. package/dist/ionic/{p-4e1b109b.entry.js → p-58c482af.entry.js} +1 -1
  352. package/dist/ionic/{p-f59611e2.system.js → p-5eb6f582.system.js} +1 -1
  353. package/dist/ionic/p-606887b7.system.entry.js +4 -0
  354. package/dist/ionic/p-6797c66e.system.js +4 -0
  355. package/dist/ionic/{p-9023f5eb.entry.js → p-72e6a9c6.entry.js} +1 -1
  356. package/dist/ionic/{p-f1b20f28.entry.js → p-747f9517.entry.js} +1 -1
  357. package/dist/ionic/{p-00ab8b89.system.js → p-77991411.system.js} +2 -2
  358. package/dist/ionic/{p-16cd36e4.entry.js → p-7ff4f502.entry.js} +1 -1
  359. package/dist/ionic/{p-3250466d.system.entry.js → p-81378456.system.entry.js} +2 -2
  360. package/dist/ionic/p-81474833.system.entry.js +4 -0
  361. package/dist/ionic/{p-39b5611c.entry.js → p-838cc359.entry.js} +1 -1
  362. package/dist/ionic/{p-df4c00a4.system.entry.js → p-888d383b.system.entry.js} +1 -1
  363. package/dist/ionic/{p-5175f06a.entry.js → p-8b1c1fd7.entry.js} +1 -1
  364. package/dist/ionic/{p-6390c6ab.system.entry.js → p-8deac7df.system.entry.js} +1 -1
  365. package/dist/ionic/{p-b88c5ce4.entry.js → p-8fa4fa3f.entry.js} +1 -1
  366. package/dist/ionic/{p-f1ad06bd.system.entry.js → p-8fa62efe.system.entry.js} +1 -1
  367. package/dist/ionic/{p-4979cd1d.entry.js → p-8fc426e2.entry.js} +1 -1
  368. package/dist/ionic/p-959cf042.system.entry.js +4 -0
  369. package/dist/ionic/{p-32d4ac00.entry.js → p-9b069739.entry.js} +1 -1
  370. package/dist/ionic/{p-3fc787a8.system.entry.js → p-9df36075.system.entry.js} +1 -1
  371. package/dist/ionic/{p-85446175.js → p-9e51f822.js} +1 -1
  372. package/dist/ionic/{p-fd0f8d68.entry.js → p-a520973b.entry.js} +1 -1
  373. package/dist/ionic/{p-89204f3f.system.js → p-a587b2ae.system.js} +1 -1
  374. package/dist/ionic/p-a9f2c0a7.entry.js +4 -0
  375. package/dist/ionic/{p-4cfb0dc8.entry.js → p-ab7337e1.entry.js} +1 -1
  376. package/dist/ionic/{p-f9e7de97.system.entry.js → p-ac58d726.system.entry.js} +1 -1
  377. package/dist/ionic/{p-3c66a690.entry.js → p-ace2d2be.entry.js} +1 -1
  378. package/dist/ionic/{p-b7ed7f16.entry.js → p-ada878ce.entry.js} +1 -1
  379. package/dist/ionic/{p-f1be5454.entry.js → p-b055d618.entry.js} +1 -1
  380. package/dist/ionic/{p-7d425376.system.entry.js → p-b2296998.system.entry.js} +1 -1
  381. package/dist/ionic/{p-da5ae6cf.system.entry.js → p-b2ee0628.system.entry.js} +1 -1
  382. package/dist/ionic/{p-1cfb788a.entry.js → p-b6174297.entry.js} +1 -1
  383. package/dist/ionic/p-b8c2dbcd.entry.js +4 -0
  384. package/dist/ionic/{p-2f890012.system.entry.js → p-b9eb1465.system.entry.js} +1 -1
  385. package/dist/ionic/{p-afcd55c6.entry.js → p-b9f2e353.entry.js} +1 -1
  386. package/dist/ionic/p-bbc6db8c.entry.js +4 -0
  387. package/dist/ionic/p-bc3e5577.system.entry.js +4 -0
  388. package/dist/ionic/p-bf64af90.system.js +1 -1
  389. package/dist/ionic/p-c258efb9.entry.js +4 -0
  390. package/dist/ionic/{p-847fd113.entry.js → p-c25c0ba4.entry.js} +1 -1
  391. package/dist/ionic/p-c5b5f44a.entry.js +4 -0
  392. package/dist/ionic/{p-8cfaf64f.system.entry.js → p-c6a20407.system.entry.js} +1 -1
  393. package/dist/ionic/{p-96f7bb84.system.entry.js → p-c8331397.system.entry.js} +1 -1
  394. package/dist/ionic/{p-9e7a9a27.entry.js → p-c8bf9ba7.entry.js} +1 -1
  395. package/dist/ionic/{p-af873227.system.js → p-d7032956.system.js} +1 -1
  396. package/dist/ionic/p-d8c9d5ac.system.entry.js +4 -0
  397. package/dist/ionic/{p-d4308e05.system.entry.js → p-daf1e8ec.system.entry.js} +1 -1
  398. package/dist/ionic/{p-684c6a80.system.entry.js → p-def7a8bd.system.entry.js} +1 -1
  399. package/dist/ionic/{p-37e874f1.js → p-e00b72ce.js} +1 -1
  400. package/dist/ionic/{p-7737b8fa.js → p-e0a05506.js} +1 -1
  401. package/dist/ionic/{p-f97efff5.system.entry.js → p-e0c0218f.system.entry.js} +1 -1
  402. package/dist/ionic/{p-6386ccd6.system.entry.js → p-e0c43e11.system.entry.js} +1 -1
  403. package/dist/ionic/{p-8b378b48.system.entry.js → p-e4683bfd.system.entry.js} +1 -1
  404. package/dist/ionic/{p-0eb49e5c.system.entry.js → p-e5708e5d.system.entry.js} +1 -1
  405. package/dist/ionic/{p-a8584808.system.entry.js → p-e5c27d9f.system.entry.js} +1 -1
  406. package/dist/ionic/p-e5cf01f1.entry.js +4 -0
  407. package/dist/ionic/{p-27da8c2c.js → p-e7309bfa.js} +1 -1
  408. package/dist/ionic/p-ed768b77.entry.js +4 -0
  409. package/dist/ionic/{p-ded39921.entry.js → p-eec4b772.entry.js} +1 -1
  410. package/dist/ionic/{p-34b077b1.system.entry.js → p-eeee3990.system.entry.js} +1 -1
  411. package/dist/ionic/{p-360f5507.entry.js → p-efa0f3f5.entry.js} +1 -1
  412. package/dist/ionic/p-f02e9382.system.entry.js +4 -0
  413. package/dist/ionic/{p-c8c27ae7.system.entry.js → p-f6bb9be7.system.entry.js} +1 -1
  414. package/dist/ionic/{p-d60342e3.js → p-f7ce606e.js} +1 -1
  415. package/dist/ionic/{p-11bbdab8.system.entry.js → p-f94b2f2f.system.entry.js} +1 -1
  416. package/dist/ionic/{p-c5abee89.system.entry.js → p-ff4a1ba0.system.entry.js} +1 -1
  417. package/dist/types/components/checkbox/checkbox.d.ts +25 -0
  418. package/dist/types/components/input/input.d.ts +8 -0
  419. package/dist/types/components/modal/animations/sheet.d.ts +1 -0
  420. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  421. package/dist/types/components/modal/modal-interface.d.ts +1 -0
  422. package/dist/types/components/modal/modal.d.ts +14 -0
  423. package/dist/types/components/radio-group/radio-group.d.ts +15 -0
  424. package/dist/types/components/select/select.d.ts +29 -0
  425. package/dist/types/components/textarea/textarea.d.ts +8 -0
  426. package/dist/types/components/toggle/toggle.d.ts +25 -0
  427. package/dist/types/components/toolbar/toolbar.d.ts +4 -0
  428. package/dist/types/components.d.ts +96 -0
  429. package/dist/types/utils/config.d.ts +9 -0
  430. package/dist/types/utils/logging/index.d.ts +13 -1
  431. package/hydrate/index.js +575 -153
  432. package/hydrate/index.mjs +575 -153
  433. package/package.json +2 -2
  434. package/dist/esm-es5/index-9b0d46f4.js +0 -4
  435. package/dist/esm-es5/input-shims-80c5b98e.js +0 -4
  436. package/dist/esm-es5/md.transition-dbb51edc.js +0 -4
  437. package/dist/esm-es5/status-tap-73b183f4.js +0 -4
  438. package/dist/ionic/p-06fee233.js +0 -4
  439. package/dist/ionic/p-1332050e.entry.js +0 -4
  440. package/dist/ionic/p-19179876.js +0 -4
  441. package/dist/ionic/p-1ffab75e.entry.js +0 -4
  442. package/dist/ionic/p-2d4658d4.system.entry.js +0 -4
  443. package/dist/ionic/p-3e0bb0e1.entry.js +0 -4
  444. package/dist/ionic/p-3ef5e7fc.entry.js +0 -4
  445. package/dist/ionic/p-51fc2fac.system.entry.js +0 -4
  446. package/dist/ionic/p-5430a6da.entry.js +0 -4
  447. package/dist/ionic/p-64279526.js +0 -4
  448. package/dist/ionic/p-64da0521.system.js +0 -4
  449. package/dist/ionic/p-6aa6839e.entry.js +0 -4
  450. package/dist/ionic/p-6cb61a35.entry.js +0 -4
  451. package/dist/ionic/p-8d611ccd.entry.js +0 -4
  452. package/dist/ionic/p-9048389e.entry.js +0 -4
  453. package/dist/ionic/p-a300835e.system.entry.js +0 -4
  454. package/dist/ionic/p-a6042939.entry.js +0 -4
  455. package/dist/ionic/p-a6f13a4e.system.entry.js +0 -4
  456. package/dist/ionic/p-aae8187b.system.entry.js +0 -4
  457. package/dist/ionic/p-ae518f0b.system.entry.js +0 -4
  458. package/dist/ionic/p-cbd5b96a.entry.js +0 -4
  459. package/dist/ionic/p-ccbb47f5.entry.js +0 -4
  460. package/dist/ionic/p-e394222f.entry.js +0 -4
  461. package/dist/ionic/p-ea925d34.system.entry.js +0 -4
  462. package/dist/ionic/p-ff4b7e40.system.js +0 -4
@@ -373,6 +373,7 @@
373
373
  justify-content: space-between;
374
374
  border-top: var(--border-width) var(--border-style) var(--border-color);
375
375
  font-size: 0.75rem;
376
+ white-space: normal;
376
377
  }
377
378
 
378
379
  /**
@@ -396,7 +397,7 @@
396
397
 
397
398
  .textarea-bottom .helper-text {
398
399
  display: block;
399
- color: var(--ion-color-step-550, var(--ion-text-color-step-450, #737373));
400
+ color: var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));
400
401
  }
401
402
 
402
403
  :host(.ion-touched.ion-invalid) .textarea-bottom .error-text {
@@ -415,7 +416,7 @@
415
416
  */
416
417
  -webkit-margin-start: auto;
417
418
  margin-inline-start: auto;
418
- color: var(--ion-color-step-550, var(--ion-text-color-step-450, #737373));
419
+ color: var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));
419
420
  white-space: nowrap;
420
421
  padding-inline-start: 16px;
421
422
  }
@@ -928,6 +929,10 @@
928
929
  --border-color: var(--highlight-color);
929
930
  }
930
931
 
932
+ /**
933
+ * The bottom content should never have
934
+ * a border with the solid style.
935
+ */
931
936
  :host(.textarea-fill-solid) .textarea-bottom {
932
937
  border-top: none;
933
938
  }
@@ -5,7 +5,7 @@ import { Host, h } from "@stencil/core";
5
5
  import { getIonMode } from "../../global/ionic-global";
6
6
  export class Thumbnail {
7
7
  render() {
8
- return (h(Host, { key: 'cfa9aeb1d4fd624a9732c5230d29dd887e4b7771', class: getIonMode(this) }, h("slot", { key: '29bc6e64063cba44e2643228df54394883933918' })));
8
+ return (h(Host, { key: '7f5fd6c056da2d82feb2c3c33f3e6dec898787f5', class: getIonMode(this) }, h("slot", { key: 'd15fd2b6cdc03777edc1930be95ad838e1b376c8' })));
9
9
  }
10
10
  static get is() { return "ion-thumbnail"; }
11
11
  static get encapsulation() { return "shadow"; }
@@ -27,11 +27,11 @@ export class ToolbarTitle {
27
27
  render() {
28
28
  const mode = getIonMode(this);
29
29
  const size = this.getSize();
30
- return (h(Host, { key: '7293d2ecd6262feb0d8d769effbb208230baed89', class: createColorClasses(this.color, {
30
+ return (h(Host, { key: '3f7b19c99961dbb86c0a925218332528b22e6880', class: createColorClasses(this.color, {
31
31
  [mode]: true,
32
32
  [`title-${size}`]: true,
33
33
  'title-rtl': document.dir === 'rtl',
34
- }) }, h("div", { key: '086ec3a361ebdf6506846a8704b457cda3a6f897', class: "toolbar-title" }, h("slot", { key: '59add7eb92b82d6832a8f0894f897c51fdf4f214' }))));
34
+ }) }, h("div", { key: '12054fbdd60e40a15875e442c20143766fc34fc3', class: "toolbar-title" }, h("slot", { key: '9f14fb14a67d4bd1e4536a4d64a637fbe5a151c7' }))));
35
35
  }
36
36
  static get is() { return "ion-title"; }
37
37
  static get encapsulation() { return "shadow"; }
@@ -391,9 +391,9 @@ export class Toast {
391
391
  if (layout === 'stacked' && startButtons.length > 0 && endButtons.length > 0) {
392
392
  printIonWarning('This toast is using start and end buttons with the stacked toast layout. We recommend following the best practice of using either start or end buttons with the stacked toast layout.', el);
393
393
  }
394
- return (h(Host, Object.assign({ key: 'c05655ff06af8d0e48c2a85396b07ad942fa81b4', tabindex: "-1" }, this.htmlAttributes, { style: {
394
+ return (h(Host, Object.assign({ key: '34036afc0701173d51c9c11ea4a2e1d65685ba41', tabindex: "-1" }, this.htmlAttributes, { style: {
395
395
  zIndex: `${60000 + this.overlayIndex}`,
396
- }, class: createColorClasses(this.color, Object.assign(Object.assign({ [mode]: true }, getClassMap(this.cssClass)), { 'overlay-hidden': true, 'toast-translucent': this.translucent })), onIonToastWillDismiss: this.dispatchCancelHandler }), h("div", { key: '9393ead4de1bf28529661d6f64049d34e18d725c', class: wrapperClass }, h("div", { key: '3e9dd73c17c337849c3f26e8d0f395b3e5ee20a7', class: "toast-container", part: "container" }, this.renderButtons(startButtons, 'start'), this.icon !== undefined && (h("ion-icon", { key: '5d15b18364301ad55e44e9f601014ac33181590b', class: "toast-icon", part: "icon", icon: this.icon, lazy: false, "aria-hidden": "true" })), h("div", { key: 'f6dd164502637a882c5caf18445d8509b85ad6f9', class: "toast-content", role: "status", "aria-atomic": "true", "aria-live": "polite" }, !revealContentToScreenReader && header !== undefined && this.renderHeader('oldHeader', 'true'), !revealContentToScreenReader && message !== undefined && this.renderToastMessage('oldMessage', 'true'), revealContentToScreenReader && header !== undefined && this.renderHeader('header'), revealContentToScreenReader && message !== undefined && this.renderToastMessage('header')), this.renderButtons(endButtons, 'end')))));
396
+ }, class: createColorClasses(this.color, Object.assign(Object.assign({ [mode]: true }, getClassMap(this.cssClass)), { 'overlay-hidden': true, 'toast-translucent': this.translucent })), onIonToastWillDismiss: this.dispatchCancelHandler }), h("div", { key: 'd927e43957f47888ce4e64f1e99c935d55757af7', class: wrapperClass }, h("div", { key: 'ca43bc42478181acdf8cdea6601a85fa95d12216', class: "toast-container", part: "container" }, this.renderButtons(startButtons, 'start'), this.icon !== undefined && (h("ion-icon", { key: 'fdd6fb8f6e947ed002bd2e63fdc8ec7e764f4a7d', class: "toast-icon", part: "icon", icon: this.icon, lazy: false, "aria-hidden": "true" })), h("div", { key: '37c16c81ee3e4304379dfbcabdffe73db73e4653', class: "toast-content", role: "status", "aria-atomic": "true", "aria-live": "polite" }, !revealContentToScreenReader && header !== undefined && this.renderHeader('oldHeader', 'true'), !revealContentToScreenReader && message !== undefined && this.renderToastMessage('oldMessage', 'true'), revealContentToScreenReader && header !== undefined && this.renderHeader('header'), revealContentToScreenReader && message !== undefined && this.renderToastMessage('header')), this.renderButtons(endButtons, 'end')))));
397
397
  }
398
398
  static get is() { return "ion-toast"; }
399
399
  static get encapsulation() { return "shadow"; }
@@ -171,32 +171,39 @@ input {
171
171
  align-items: center;
172
172
  }
173
173
 
174
- :host(.toggle-justify-space-between) .toggle-wrapper {
174
+ .toggle-bottom {
175
+ padding-top: 4px;
176
+ display: flex;
175
177
  justify-content: space-between;
178
+ font-size: 0.75rem;
179
+ white-space: normal;
176
180
  }
177
181
 
178
- :host(.toggle-justify-start) .toggle-wrapper {
179
- justify-content: start;
182
+ :host(.toggle-label-placement-stacked) .toggle-bottom {
183
+ font-size: 1rem;
180
184
  }
181
185
 
182
- :host(.toggle-justify-end) .toggle-wrapper {
183
- justify-content: end;
186
+ /**
187
+ * Error text should only be shown when .ion-invalid is
188
+ * present on the checkbox. Otherwise the helper text should
189
+ * be shown.
190
+ */
191
+ .toggle-bottom .error-text {
192
+ display: none;
193
+ color: var(--ion-color-danger, #c5000f);
184
194
  }
185
195
 
186
- :host(.toggle-alignment-start) .toggle-wrapper {
187
- align-items: start;
196
+ .toggle-bottom .helper-text {
197
+ display: block;
198
+ color: var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));
188
199
  }
189
200
 
190
- :host(.toggle-alignment-center) .toggle-wrapper {
191
- align-items: center;
201
+ :host(.ion-touched.ion-invalid) .toggle-bottom .error-text {
202
+ display: block;
192
203
  }
193
204
 
194
- :host(.toggle-justify-space-between),
195
- :host(.toggle-justify-start),
196
- :host(.toggle-justify-end),
197
- :host(.toggle-alignment-start),
198
- :host(.toggle-alignment-center) {
199
- display: block;
205
+ :host(.ion-touched.ion-invalid) .toggle-bottom .helper-text {
206
+ display: none;
200
207
  }
201
208
 
202
209
  /**
@@ -225,6 +232,7 @@ input {
225
232
  */
226
233
  :host(.toggle-label-placement-end) .toggle-wrapper {
227
234
  flex-direction: row-reverse;
235
+ justify-content: start;
228
236
  }
229
237
 
230
238
  /**
@@ -267,6 +275,7 @@ input {
267
275
  */
268
276
  :host(.toggle-label-placement-stacked) .toggle-wrapper {
269
277
  flex-direction: column;
278
+ text-align: center;
270
279
  }
271
280
 
272
281
  :host(.toggle-label-placement-stacked) .label-text-wrapper {
@@ -312,6 +321,34 @@ input {
312
321
  }
313
322
  }
314
323
 
324
+ :host(.toggle-justify-space-between) .toggle-wrapper {
325
+ justify-content: space-between;
326
+ }
327
+
328
+ :host(.toggle-justify-start) .toggle-wrapper {
329
+ justify-content: start;
330
+ }
331
+
332
+ :host(.toggle-justify-end) .toggle-wrapper {
333
+ justify-content: end;
334
+ }
335
+
336
+ :host(.toggle-alignment-start) .toggle-wrapper {
337
+ align-items: start;
338
+ }
339
+
340
+ :host(.toggle-alignment-center) .toggle-wrapper {
341
+ align-items: center;
342
+ }
343
+
344
+ :host(.toggle-justify-space-between),
345
+ :host(.toggle-justify-start),
346
+ :host(.toggle-justify-end),
347
+ :host(.toggle-alignment-start),
348
+ :host(.toggle-alignment-center) {
349
+ display: block;
350
+ }
351
+
315
352
  .toggle-icon-wrapper {
316
353
  display: flex;
317
354
  position: relative;
@@ -17,10 +17,15 @@ import { getIonMode } from "../../global/ionic-global";
17
17
  * @part track - The background track of the toggle.
18
18
  * @part handle - The toggle handle, or knob, used to change the checked state.
19
19
  * @part label - The label text describing the toggle.
20
+ * @part supporting-text - Supporting text displayed beneath the toggle label.
21
+ * @part helper-text - Supporting text displayed beneath the toggle label when the toggle is valid.
22
+ * @part error-text - Supporting text displayed beneath the toggle label when the toggle is invalid and touched.
20
23
  */
21
24
  export class Toggle {
22
25
  constructor() {
23
26
  this.inputId = `ion-tg-${toggleIds++}`;
27
+ this.helperTextId = `${this.inputId}-helper-text`;
28
+ this.errorTextId = `${this.inputId}-error-text`;
24
29
  this.lastDrag = 0;
25
30
  this.inheritedAttributes = {};
26
31
  this.didLoad = false;
@@ -66,11 +71,14 @@ export class Toggle {
66
71
  this.name = this.inputId;
67
72
  this.checked = false;
68
73
  this.disabled = false;
74
+ this.errorText = undefined;
75
+ this.helperText = undefined;
69
76
  this.value = 'on';
70
77
  this.enableOnOffLabels = config.get('toggleOnOffLabels');
71
78
  this.labelPlacement = 'start';
72
79
  this.justify = undefined;
73
80
  this.alignment = undefined;
81
+ this.required = false;
74
82
  }
75
83
  disabledChanged() {
76
84
  if (this.gesture) {
@@ -152,13 +160,39 @@ export class Toggle {
152
160
  get hasLabel() {
153
161
  return this.el.textContent !== '';
154
162
  }
163
+ getHintTextID() {
164
+ const { el, helperText, errorText, helperTextId, errorTextId } = this;
165
+ if (el.classList.contains('ion-touched') && el.classList.contains('ion-invalid') && errorText) {
166
+ return errorTextId;
167
+ }
168
+ if (helperText) {
169
+ return helperTextId;
170
+ }
171
+ return undefined;
172
+ }
173
+ /**
174
+ * Responsible for rendering helper text and error text.
175
+ * This element should only be rendered if hint text is set.
176
+ */
177
+ renderHintText() {
178
+ const { helperText, errorText, helperTextId, errorTextId } = this;
179
+ /**
180
+ * undefined and empty string values should
181
+ * be treated as not having helper/error text.
182
+ */
183
+ const hasHintText = !!helperText || !!errorText;
184
+ if (!hasHintText) {
185
+ return;
186
+ }
187
+ return (h("div", { class: "toggle-bottom" }, h("div", { id: helperTextId, class: "helper-text", part: "supporting-text helper-text" }, helperText), h("div", { id: errorTextId, class: "error-text", part: "supporting-text error-text" }, errorText)));
188
+ }
155
189
  render() {
156
- const { activated, color, checked, disabled, el, justify, labelPlacement, inputId, name, alignment } = this;
190
+ const { activated, color, checked, disabled, el, justify, labelPlacement, inputId, name, alignment, required } = this;
157
191
  const mode = getIonMode(this);
158
192
  const value = this.getValue();
159
193
  const rtl = isRTL(el) ? 'rtl' : 'ltr';
160
194
  renderHiddenInput(true, el, name, checked ? value : '', disabled);
161
- return (h(Host, { key: '9d2a77db6d0bf36ef2452ac8b78a309943bff2b7', onClick: this.onClick, class: createColorClasses(color, {
195
+ return (h(Host, { key: 'c6db7f5bc0b358944c0d79e24aeb4d319793422f', "aria-describedby": this.getHintTextID(), "aria-invalid": this.getHintTextID() === this.errorTextId, onClick: this.onClick, class: createColorClasses(color, {
162
196
  [mode]: true,
163
197
  'in-item': hostContext('ion-item', el),
164
198
  'toggle-activated': activated,
@@ -168,10 +202,10 @@ export class Toggle {
168
202
  [`toggle-alignment-${alignment}`]: alignment !== undefined,
169
203
  [`toggle-label-placement-${labelPlacement}`]: true,
170
204
  [`toggle-${rtl}`]: true,
171
- }) }, h("label", { key: '079edf3636766fa423364e8e81712b83e8d5ec1c', class: "toggle-wrapper" }, h("input", Object.assign({ key: 'f822114a89c7a48480c06057c987c2d63f21a25b', type: "checkbox", role: "switch", "aria-checked": `${checked}`, checked: checked, disabled: disabled, id: inputId, onFocus: () => this.onFocus(), onBlur: () => this.onBlur(), ref: (focusEl) => (this.focusEl = focusEl) }, this.inheritedAttributes)), h("div", { key: '1029805e127d2632bafb484429fb79b244a52c57', class: {
205
+ }) }, h("label", { key: 'f49531391f4513d084061c27ebc4c4eb1dcd02ab', class: "toggle-wrapper" }, h("input", Object.assign({ key: 'f4ab2dc29eae053f54613d1304f755e151037f47', type: "checkbox", role: "switch", "aria-checked": `${checked}`, checked: checked, disabled: disabled, id: inputId, onFocus: () => this.onFocus(), onBlur: () => this.onBlur(), ref: (focusEl) => (this.focusEl = focusEl), required: required }, this.inheritedAttributes)), h("div", { key: '85674bfab5ec1e422c787d025c4f9f5b3aadd4f2', class: {
172
206
  'label-text-wrapper': true,
173
207
  'label-text-wrapper-hidden': !this.hasLabel,
174
- }, part: "label" }, h("slot", { key: 'ed27634a667c5bf30561f9911a3f94f3f755028f' })), h("div", { key: '72ef6224eece08b6539fb3797e81d8817651a952', class: "native-wrapper" }, this.renderToggleControl()))));
208
+ }, part: "label" }, h("slot", { key: '9bdf7e85c95dc7373f18894ebfe6ad022f098107' }), this.renderHintText()), h("div", { key: '33883642b38421a82001e37db3dd5e5c643785b0', class: "native-wrapper" }, this.renderToggleControl()))));
175
209
  }
176
210
  static get is() { return "ion-toggle"; }
177
211
  static get encapsulation() { return "shadow"; }
@@ -266,6 +300,40 @@ export class Toggle {
266
300
  "reflect": false,
267
301
  "defaultValue": "false"
268
302
  },
303
+ "errorText": {
304
+ "type": "string",
305
+ "mutable": false,
306
+ "complexType": {
307
+ "original": "string",
308
+ "resolved": "string | undefined",
309
+ "references": {}
310
+ },
311
+ "required": false,
312
+ "optional": true,
313
+ "docs": {
314
+ "tags": [],
315
+ "text": "Text that is placed under the toggle label and displayed when an error is detected."
316
+ },
317
+ "attribute": "error-text",
318
+ "reflect": false
319
+ },
320
+ "helperText": {
321
+ "type": "string",
322
+ "mutable": false,
323
+ "complexType": {
324
+ "original": "string",
325
+ "resolved": "string | undefined",
326
+ "references": {}
327
+ },
328
+ "required": false,
329
+ "optional": true,
330
+ "docs": {
331
+ "tags": [],
332
+ "text": "Text that is placed under the toggle label and displayed when no error is detected."
333
+ },
334
+ "attribute": "helper-text",
335
+ "reflect": false
336
+ },
269
337
  "value": {
270
338
  "type": "string",
271
339
  "mutable": false,
@@ -353,6 +421,24 @@ export class Toggle {
353
421
  },
354
422
  "attribute": "alignment",
355
423
  "reflect": false
424
+ },
425
+ "required": {
426
+ "type": "boolean",
427
+ "mutable": false,
428
+ "complexType": {
429
+ "original": "boolean",
430
+ "resolved": "boolean",
431
+ "references": {}
432
+ },
433
+ "required": false,
434
+ "optional": false,
435
+ "docs": {
436
+ "tags": [],
437
+ "text": "If true, screen readers will announce it as a required field. This property\nworks only for accessibility purposes, it will not prevent the form from\nsubmitting if the value is invalid."
438
+ },
439
+ "attribute": "required",
440
+ "reflect": false,
441
+ "defaultValue": "false"
356
442
  }
357
443
  };
358
444
  }
@@ -171,32 +171,39 @@ input {
171
171
  align-items: center;
172
172
  }
173
173
 
174
- :host(.toggle-justify-space-between) .toggle-wrapper {
174
+ .toggle-bottom {
175
+ padding-top: 4px;
176
+ display: flex;
175
177
  justify-content: space-between;
178
+ font-size: 0.75rem;
179
+ white-space: normal;
176
180
  }
177
181
 
178
- :host(.toggle-justify-start) .toggle-wrapper {
179
- justify-content: start;
182
+ :host(.toggle-label-placement-stacked) .toggle-bottom {
183
+ font-size: 1rem;
180
184
  }
181
185
 
182
- :host(.toggle-justify-end) .toggle-wrapper {
183
- justify-content: end;
186
+ /**
187
+ * Error text should only be shown when .ion-invalid is
188
+ * present on the checkbox. Otherwise the helper text should
189
+ * be shown.
190
+ */
191
+ .toggle-bottom .error-text {
192
+ display: none;
193
+ color: var(--ion-color-danger, #c5000f);
184
194
  }
185
195
 
186
- :host(.toggle-alignment-start) .toggle-wrapper {
187
- align-items: start;
196
+ .toggle-bottom .helper-text {
197
+ display: block;
198
+ color: var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));
188
199
  }
189
200
 
190
- :host(.toggle-alignment-center) .toggle-wrapper {
191
- align-items: center;
201
+ :host(.ion-touched.ion-invalid) .toggle-bottom .error-text {
202
+ display: block;
192
203
  }
193
204
 
194
- :host(.toggle-justify-space-between),
195
- :host(.toggle-justify-start),
196
- :host(.toggle-justify-end),
197
- :host(.toggle-alignment-start),
198
- :host(.toggle-alignment-center) {
199
- display: block;
205
+ :host(.ion-touched.ion-invalid) .toggle-bottom .helper-text {
206
+ display: none;
200
207
  }
201
208
 
202
209
  /**
@@ -225,6 +232,7 @@ input {
225
232
  */
226
233
  :host(.toggle-label-placement-end) .toggle-wrapper {
227
234
  flex-direction: row-reverse;
235
+ justify-content: start;
228
236
  }
229
237
 
230
238
  /**
@@ -267,6 +275,7 @@ input {
267
275
  */
268
276
  :host(.toggle-label-placement-stacked) .toggle-wrapper {
269
277
  flex-direction: column;
278
+ text-align: center;
270
279
  }
271
280
 
272
281
  :host(.toggle-label-placement-stacked) .label-text-wrapper {
@@ -312,6 +321,34 @@ input {
312
321
  }
313
322
  }
314
323
 
324
+ :host(.toggle-justify-space-between) .toggle-wrapper {
325
+ justify-content: space-between;
326
+ }
327
+
328
+ :host(.toggle-justify-start) .toggle-wrapper {
329
+ justify-content: start;
330
+ }
331
+
332
+ :host(.toggle-justify-end) .toggle-wrapper {
333
+ justify-content: end;
334
+ }
335
+
336
+ :host(.toggle-alignment-start) .toggle-wrapper {
337
+ align-items: start;
338
+ }
339
+
340
+ :host(.toggle-alignment-center) .toggle-wrapper {
341
+ align-items: center;
342
+ }
343
+
344
+ :host(.toggle-justify-space-between),
345
+ :host(.toggle-justify-start),
346
+ :host(.toggle-justify-end),
347
+ :host(.toggle-alignment-start),
348
+ :host(.toggle-alignment-center) {
349
+ display: block;
350
+ }
351
+
315
352
  .toggle-icon-wrapper {
316
353
  display: flex;
317
354
  position: relative;
@@ -12,6 +12,10 @@ import { getIonMode } from "../../global/ionic-global";
12
12
  * @slot secondary - Content is placed to the left of the toolbar text in `ios` mode, and directly to the right in `md` mode.
13
13
  * @slot primary - Content is placed to the right of the toolbar text in `ios` mode, and to the far right in `md` mode.
14
14
  * @slot end - Content is placed to the right of the toolbar text in LTR, and to the left in RTL.
15
+ *
16
+ * @part background - The background of the toolbar, covering the entire area behind the toolbar content.
17
+ * @part container - The container that wraps all toolbar content, including the default slot and named slot content.
18
+ * @part content - The container for the default slot, wrapping content provided without a named slot.
15
19
  */
16
20
  export class Toolbar {
17
21
  constructor() {
@@ -62,10 +66,10 @@ export class Toolbar {
62
66
  this.childrenStyles.forEach((value) => {
63
67
  Object.assign(childStyles, value);
64
68
  });
65
- return (h(Host, { key: '462538a5ecd01baf3cde116c9f029aeda26c81be', class: Object.assign(Object.assign({}, childStyles), createColorClasses(this.color, {
69
+ return (h(Host, { key: '402afe7ce0c97883cedd0e48a5a0492a9bfe76ae', class: Object.assign(Object.assign({}, childStyles), createColorClasses(this.color, {
66
70
  [mode]: true,
67
71
  'in-toolbar': hostContext('ion-toolbar', this.el),
68
- })) }, h("div", { key: 'c0b4415d3b2472de643a9be7cb3b13b3b628621b', class: "toolbar-background" }), h("div", { key: '0ccb8a2dbeaa28d8f9bed87629c0c097446690c2', class: "toolbar-container" }, h("slot", { key: '3e726dac359e923df21d80301651f16063a3de20', name: "start" }), h("slot", { key: 'cd799330b56a7f8833bc61bb2807aafb21846f71', name: "secondary" }), h("div", { key: '395282e6ac8c53576922dcdb5f08c25d34638c86', class: "toolbar-content" }, h("slot", { key: 'a437c60e4ba5aae65e55169ae82a6f379868ec1d' })), h("slot", { key: '711af9b9d321a7b31ede924c9bdcad767aa9a1ca', name: "primary" }), h("slot", { key: 'ecc02edeaf80a837890bcb08d5096df1e22a0b9a', name: "end" }))));
72
+ })) }, h("div", { key: '2465a6dc8d507ec650538378d1be2abd399c58ad', class: "toolbar-background", part: "background" }), h("div", { key: '6075096afd12303b961e4fe9ad345ef2887573af', class: "toolbar-container", part: "container" }, h("slot", { key: '8b7eec1148cfeb339d87cdf9273f2104703e7601', name: "start" }), h("slot", { key: 'b102d3926cade24faf78b7af78ad5e192c4c0308', name: "secondary" }), h("div", { key: 'c6ab2e978328324c6f9e7892024cbcd8b8987067', class: "toolbar-content", part: "content" }, h("slot", { key: '86f8952c4355a9df5b4bbb95e9d0cafefd272d5b' })), h("slot", { key: '501e43431da6b9dd35b47b79222f948d445f7a78', name: "primary" }), h("slot", { key: '84bf1a15a5e52e8e94df9f479c4ce18004f5ab57', name: "end" }))));
69
73
  }
70
74
  static get is() { return "ion-toolbar"; }
71
75
  static get encapsulation() { return "shadow"; }
@@ -1,6 +1,7 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
+ import { config } from "../../global/config";
4
5
  /**
5
6
  * Logs a warning to the console with an Ionic prefix
6
7
  * to indicate the library that is warning the developer.
@@ -8,9 +9,12 @@
8
9
  * @param message - The string message to be logged to the console.
9
10
  */
10
11
  export const printIonWarning = (message, ...params) => {
11
- return console.warn(`[Ionic Warning]: ${message}`, ...params);
12
+ const logLevel = config.get('logLevel', "WARN" /* LogLevel.WARN */);
13
+ if (["WARN" /* LogLevel.WARN */].includes(logLevel)) {
14
+ return console.warn(`[Ionic Warning]: ${message}`, ...params);
15
+ }
12
16
  };
13
- /*
17
+ /**
14
18
  * Logs an error to the console with an Ionic prefix
15
19
  * to indicate the library that is warning the developer.
16
20
  *
@@ -18,7 +22,10 @@ export const printIonWarning = (message, ...params) => {
18
22
  * @param params - Additional arguments to supply to the console.error.
19
23
  */
20
24
  export const printIonError = (message, ...params) => {
21
- return console.error(`[Ionic Error]: ${message}`, ...params);
25
+ const logLevel = config.get('logLevel', "ERROR" /* LogLevel.ERROR */);
26
+ if (["ERROR" /* LogLevel.ERROR */, "WARN" /* LogLevel.WARN */].includes(logLevel)) {
27
+ return console.error(`[Ionic Error]: ${message}`, ...params);
28
+ }
22
29
  };
23
30
  /**
24
31
  * Prints an error informing developers that an implementation requires an element to be used