@ably/ui 17.4.2 → 17.4.3

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 (339) hide show
  1. package/AGENTS.md +573 -0
  2. package/README.md +120 -68
  3. package/core/Accordion/types.js.map +1 -1
  4. package/core/Accordion/utils.js +1 -1
  5. package/core/Accordion/utils.js.map +1 -1
  6. package/core/Accordion.js +1 -1
  7. package/core/Accordion.js.map +1 -1
  8. package/core/Badge.js +1 -1
  9. package/core/Badge.js.map +1 -1
  10. package/core/Code/Code.test.js +2 -0
  11. package/core/Code/Code.test.js.map +1 -0
  12. package/core/Code.js +1 -1
  13. package/core/Code.js.map +1 -1
  14. package/core/CodeSnippet/ApiKeySelector.js +1 -1
  15. package/core/CodeSnippet/ApiKeySelector.js.map +1 -1
  16. package/core/CodeSnippet/CodeSnippet.test.js +2 -0
  17. package/core/CodeSnippet/CodeSnippet.test.js.map +1 -0
  18. package/core/CodeSnippet/CopyButton.js +1 -1
  19. package/core/CodeSnippet/CopyButton.js.map +1 -1
  20. package/core/CodeSnippet/LanguageSelector.js +1 -1
  21. package/core/CodeSnippet/LanguageSelector.js.map +1 -1
  22. package/core/CodeSnippet/PlainCodeView.js +1 -1
  23. package/core/CodeSnippet/PlainCodeView.js.map +1 -1
  24. package/core/CodeSnippet/TooltipButton.js +1 -1
  25. package/core/CodeSnippet/TooltipButton.js.map +1 -1
  26. package/core/CodeSnippet/languages.js +1 -1
  27. package/core/CodeSnippet/languages.js.map +1 -1
  28. package/core/CodeSnippet/languages.test.js +2 -0
  29. package/core/CodeSnippet/languages.test.js.map +1 -0
  30. package/core/CodeSnippet.js +1 -1
  31. package/core/CodeSnippet.js.map +1 -1
  32. package/core/ConnectStateWrapper.js.map +1 -1
  33. package/core/ContentTile.js +2 -0
  34. package/core/ContentTile.js.map +1 -0
  35. package/core/DropdownMenu.js +1 -1
  36. package/core/DropdownMenu.js.map +1 -1
  37. package/core/Expander.js +1 -1
  38. package/core/Expander.js.map +1 -1
  39. package/core/FeaturedLink.js +1 -1
  40. package/core/FeaturedLink.js.map +1 -1
  41. package/core/Flash.js +1 -1
  42. package/core/Flash.js.map +1 -1
  43. package/core/Flyout.js +1 -1
  44. package/core/Flyout.js.map +1 -1
  45. package/core/Footer/data.js +1 -1
  46. package/core/Footer/data.js.map +1 -1
  47. package/core/Footer.js +1 -1
  48. package/core/Footer.js.map +1 -1
  49. package/core/Header/HeaderLinks.js +1 -1
  50. package/core/Header/HeaderLinks.js.map +1 -1
  51. package/core/Header/types.js +2 -0
  52. package/core/Header/types.js.map +1 -0
  53. package/core/Header.js +1 -1
  54. package/core/Header.js.map +1 -1
  55. package/core/Icon/components/icon-display-cloud-servers-mono.js +2 -0
  56. package/core/Icon/components/icon-display-cloud-servers-mono.js.map +1 -0
  57. package/core/Icon/components/icon-display-data-integrity.js +2 -0
  58. package/core/Icon/components/icon-display-data-integrity.js.map +1 -0
  59. package/core/Icon/components/icon-display-database-connector.js +2 -0
  60. package/core/Icon/components/icon-display-database-connector.js.map +1 -0
  61. package/core/Icon/components/icon-display-ephemeral-messages-dark-col.js +2 -0
  62. package/core/Icon/components/icon-display-ephemeral-messages-dark-col.js.map +1 -0
  63. package/core/Icon/components/icon-display-ephemeral-messages.js +2 -0
  64. package/core/Icon/components/icon-display-ephemeral-messages.js.map +1 -0
  65. package/core/Icon/components/icon-display-live-updates.js +2 -0
  66. package/core/Icon/components/icon-display-live-updates.js.map +1 -0
  67. package/core/Icon/components/icon-display-message-annotations-dark-col.js +2 -0
  68. package/core/Icon/components/icon-display-message-annotations-dark-col.js.map +1 -0
  69. package/core/Icon/components/icon-display-message-annotations.js +2 -0
  70. package/core/Icon/components/icon-display-message-annotations.js.map +1 -0
  71. package/core/Icon/components/icon-display-multi-user-spaces.js +2 -0
  72. package/core/Icon/components/icon-display-multi-user-spaces.js.map +1 -0
  73. package/core/Icon/components/icon-display-sdks.js +2 -0
  74. package/core/Icon/components/icon-display-sdks.js.map +1 -0
  75. package/core/Icon/components/icon-display-something-else-mono.js +2 -0
  76. package/core/Icon/components/icon-display-something-else-mono.js.map +1 -0
  77. package/core/Icon/components/icon-display-something-else.js +2 -0
  78. package/core/Icon/components/icon-display-something-else.js.map +1 -0
  79. package/core/Icon/components/icon-display-ui-mono.js +2 -0
  80. package/core/Icon/components/icon-display-ui-mono.js.map +1 -0
  81. package/core/Icon/components/icon-display-ui.js +2 -0
  82. package/core/Icon/components/icon-display-ui.js.map +1 -0
  83. package/core/Icon/components/icon-gui-checklist-checked.js +1 -1
  84. package/core/Icon/components/icon-gui-checklist-checked.js.map +1 -1
  85. package/core/Icon/components/icon-gui-code-doc.js +1 -1
  86. package/core/Icon/components/icon-gui-code-doc.js.map +1 -1
  87. package/core/Icon/components/icon-gui-cursor.js +1 -1
  88. package/core/Icon/components/icon-gui-cursor.js.map +1 -1
  89. package/core/Icon/components/icon-gui-expand.js +1 -1
  90. package/core/Icon/components/icon-gui-expand.js.map +1 -1
  91. package/core/Icon/components/icon-gui-filter-flow-step-0.js +1 -1
  92. package/core/Icon/components/icon-gui-filter-flow-step-0.js.map +1 -1
  93. package/core/Icon/components/icon-gui-flower-growth.js +1 -1
  94. package/core/Icon/components/icon-gui-flower-growth.js.map +1 -1
  95. package/core/Icon/components/icon-gui-glasses.js +1 -1
  96. package/core/Icon/components/icon-gui-glasses.js.map +1 -1
  97. package/core/Icon/components/icon-gui-heartbeat-outline.js +2 -0
  98. package/core/Icon/components/icon-gui-heartbeat-outline.js.map +1 -0
  99. package/core/Icon/components/icon-gui-heartbeat-solid.js +2 -0
  100. package/core/Icon/components/icon-gui-heartbeat-solid.js.map +1 -0
  101. package/core/Icon/components/icon-gui-mouse.js +1 -1
  102. package/core/Icon/components/icon-gui-mouse.js.map +1 -1
  103. package/core/Icon/components/icon-gui-pitfall.js +1 -1
  104. package/core/Icon/components/icon-gui-pitfall.js.map +1 -1
  105. package/core/Icon/components/icon-gui-prod-ai-transport-outline.js +2 -0
  106. package/core/Icon/components/icon-gui-prod-ai-transport-outline.js.map +1 -0
  107. package/core/Icon/components/icon-gui-prod-ai-transport-solid.js +2 -0
  108. package/core/Icon/components/icon-gui-prod-ai-transport-solid.js.map +1 -0
  109. package/core/Icon/components/icon-gui-quote-marks-fill.js +1 -1
  110. package/core/Icon/components/icon-gui-quote-marks-fill.js.map +1 -1
  111. package/core/Icon/components/icon-product-ai-transport-mono.js +2 -0
  112. package/core/Icon/components/icon-product-ai-transport-mono.js.map +1 -0
  113. package/core/Icon/components/icon-product-ai-transport.js +2 -0
  114. package/core/Icon/components/icon-product-ai-transport.js.map +1 -0
  115. package/core/Icon/components/icon-product-chat-mono.js +1 -1
  116. package/core/Icon/components/icon-product-chat-mono.js.map +1 -1
  117. package/core/Icon/components/icon-product-liveobjects-mono.js +1 -1
  118. package/core/Icon/components/icon-product-liveobjects-mono.js.map +1 -1
  119. package/core/Icon/components/icon-product-livesync-mono.js +1 -1
  120. package/core/Icon/components/icon-product-livesync-mono.js.map +1 -1
  121. package/core/Icon/components/icon-product-pubsub-mono.js +1 -1
  122. package/core/Icon/components/icon-product-pubsub-mono.js.map +1 -1
  123. package/core/Icon/components/icon-product-spaces-mono.js +1 -1
  124. package/core/Icon/components/icon-product-spaces-mono.js.map +1 -1
  125. package/core/Icon/components/icon-tech-claude-mono.js +2 -0
  126. package/core/Icon/components/icon-tech-claude-mono.js.map +1 -0
  127. package/core/Icon/components/icon-tech-claude.js +2 -0
  128. package/core/Icon/components/icon-tech-claude.js.map +1 -0
  129. package/core/Icon/components/icon-tech-jetpack.js +2 -0
  130. package/core/Icon/components/icon-tech-jetpack.js.map +1 -0
  131. package/core/Icon/components/icon-tech-terraform-outline.js +2 -0
  132. package/core/Icon/components/icon-tech-terraform-outline.js.map +1 -0
  133. package/core/Icon/components/index.js +1 -1
  134. package/core/Icon/components/index.js.map +1 -1
  135. package/core/Icon/computed-icons/display-icons.js +1 -1
  136. package/core/Icon/computed-icons/display-icons.js.map +1 -1
  137. package/core/Icon/computed-icons/gui-icons.js +1 -1
  138. package/core/Icon/computed-icons/gui-icons.js.map +1 -1
  139. package/core/Icon/computed-icons/product-icons.js +1 -1
  140. package/core/Icon/computed-icons/product-icons.js.map +1 -1
  141. package/core/Icon/computed-icons/tech-icons.js +1 -1
  142. package/core/Icon/computed-icons/tech-icons.js.map +1 -1
  143. package/core/Icon.js +1 -1
  144. package/core/Icon.js.map +1 -1
  145. package/core/LinkButton.js +1 -1
  146. package/core/LinkButton.js.map +1 -1
  147. package/core/Logo.js +1 -1
  148. package/core/Logo.js.map +1 -1
  149. package/core/Meganav/MeganavBlog.js +2 -0
  150. package/core/Meganav/MeganavBlog.js.map +1 -0
  151. package/core/Meganav/MeganavCustomerStories.js +2 -0
  152. package/core/Meganav/MeganavCustomerStories.js.map +1 -0
  153. package/core/Meganav/MeganavMobile.js +1 -1
  154. package/core/Meganav/MeganavMobile.js.map +1 -1
  155. package/core/Meganav/MeganavPanel.js +1 -1
  156. package/core/Meganav/MeganavPanel.js.map +1 -1
  157. package/core/Meganav/MeganavPanelItemLinks.js +2 -0
  158. package/core/Meganav/MeganavPanelItemLinks.js.map +1 -0
  159. package/core/Meganav/MeganavTile.js +2 -0
  160. package/core/Meganav/MeganavTile.js.map +1 -0
  161. package/core/Meganav/PanelTitle.js +2 -0
  162. package/core/Meganav/PanelTitle.js.map +1 -0
  163. package/core/Meganav/data.js +1 -1
  164. package/core/Meganav/data.js.map +1 -1
  165. package/core/Meganav/images/cust-logo-doxy-dark.png +0 -0
  166. package/core/Meganav/images/cust-logo-doxy-light.png +0 -0
  167. package/core/Meganav/utils/getMenuItemsForHeader.js +2 -0
  168. package/core/Meganav/utils/getMenuItemsForHeader.js.map +1 -0
  169. package/core/Meganav.js +1 -1
  170. package/core/Meganav.js.map +1 -1
  171. package/core/Notice/component.css +9 -3
  172. package/core/Notice/component.js +1 -1
  173. package/core/Notice/component.js.map +1 -1
  174. package/core/Notice.js +1 -1
  175. package/core/Notice.js.map +1 -1
  176. package/core/Pricing/PricingCards.js +1 -1
  177. package/core/Pricing/PricingCards.js.map +1 -1
  178. package/core/Pricing/data.js +1 -1
  179. package/core/Pricing/data.js.map +1 -1
  180. package/core/Pricing/types.js.map +1 -1
  181. package/core/ProductTile/ProductDescription.js +1 -1
  182. package/core/ProductTile/ProductDescription.js.map +1 -1
  183. package/core/ProductTile/ProductIcon.js +1 -1
  184. package/core/ProductTile/ProductIcon.js.map +1 -1
  185. package/core/ProductTile/ProductLabel.js +1 -1
  186. package/core/ProductTile/ProductLabel.js.map +1 -1
  187. package/core/ProductTile/data.js +1 -1
  188. package/core/ProductTile/data.js.map +1 -1
  189. package/core/ProductTile.js +1 -1
  190. package/core/ProductTile.js.map +1 -1
  191. package/core/SegmentedControl.js +1 -1
  192. package/core/SegmentedControl.js.map +1 -1
  193. package/core/Slider/component.js +1 -1
  194. package/core/Slider/component.js.map +1 -1
  195. package/core/Slider.js +1 -1
  196. package/core/Slider.js.map +1 -1
  197. package/core/TabMenu.js +1 -1
  198. package/core/TabMenu.js.map +1 -1
  199. package/core/Table/data.js +1 -1
  200. package/core/Table/data.js.map +1 -1
  201. package/core/Toggle.js +1 -1
  202. package/core/Toggle.js.map +1 -1
  203. package/core/Tooltip.js +1 -1
  204. package/core/Tooltip.js.map +1 -1
  205. package/core/fonts/NEXT-Book-Light-Italic.eot +0 -0
  206. package/core/fonts/NEXT-Book-Light-Italic.otf +0 -0
  207. package/core/fonts/NEXT-Book-Light-Italic.woff +0 -0
  208. package/core/fonts/NEXT-Book-Light-Italic.woff2 +0 -0
  209. package/core/fonts/NEXT-Book-Light.eot +0 -0
  210. package/core/fonts/NEXT-Book-Light.otf +0 -0
  211. package/core/fonts/NEXT-Book-Light.woff +0 -0
  212. package/core/fonts/NEXT-Book-Light.woff2 +0 -0
  213. package/core/fonts/NEXT-Book-Medium-Italic.eot +0 -0
  214. package/core/fonts/NEXT-Book-Medium-Italic.otf +0 -0
  215. package/core/fonts/NEXT-Book-Medium-Italic.woff +0 -0
  216. package/core/fonts/NEXT-Book-Medium-Italic.woff2 +0 -0
  217. package/core/fonts/NEXT-Book-Medium.eot +0 -0
  218. package/core/fonts/NEXT-Book-Medium.otf +0 -0
  219. package/core/fonts/NEXT-Book-Medium.woff +0 -0
  220. package/core/fonts/NEXT-Book-Medium.woff2 +0 -0
  221. package/core/hooks/use-content-height.js +2 -0
  222. package/core/hooks/use-content-height.js.map +1 -0
  223. package/core/hooks/use-themed-scrollpoints.js +2 -0
  224. package/core/hooks/use-themed-scrollpoints.js.map +1 -0
  225. package/core/hooks/use-themed-scrollpoints.test.js +2 -0
  226. package/core/hooks/use-themed-scrollpoints.test.js.map +1 -0
  227. package/core/icons/display/icon-display-cloud-servers-mono.svg +3 -0
  228. package/core/icons/display/icon-display-data-integrity.svg +9 -0
  229. package/core/icons/display/icon-display-database-connector.svg +13 -0
  230. package/core/icons/display/icon-display-ephemeral-messages-dark-col.svg +6 -0
  231. package/core/icons/display/icon-display-ephemeral-messages.svg +6 -0
  232. package/core/icons/display/icon-display-live-updates.svg +8 -0
  233. package/core/icons/display/icon-display-message-annotations-dark-col.svg +11 -0
  234. package/core/icons/display/icon-display-message-annotations.svg +11 -0
  235. package/core/icons/display/icon-display-multi-user-spaces.svg +13 -0
  236. package/core/icons/display/icon-display-sdks.svg +11 -0
  237. package/core/icons/display/icon-display-something-else-mono.svg +4 -0
  238. package/core/icons/display/icon-display-something-else.svg +4 -0
  239. package/core/icons/display/icon-display-ui-mono.svg +22 -0
  240. package/core/icons/display/icon-display-ui.svg +22 -0
  241. package/core/icons/gui/icon-gui-checklist-checked.svg +1 -1
  242. package/core/icons/gui/icon-gui-code-doc.svg +1 -1
  243. package/core/icons/gui/icon-gui-cursor.svg +1 -1
  244. package/core/icons/gui/icon-gui-expand.svg +1 -1
  245. package/core/icons/gui/icon-gui-filter-flow-step-0.svg +3 -3
  246. package/core/icons/gui/icon-gui-flower-growth.svg +1 -1
  247. package/core/icons/gui/icon-gui-glasses.svg +1 -1
  248. package/core/icons/gui/icon-gui-heartbeat-outline.svg +4 -0
  249. package/core/icons/gui/icon-gui-heartbeat-solid.svg +4 -0
  250. package/core/icons/gui/icon-gui-mouse.svg +1 -1
  251. package/core/icons/gui/icon-gui-pitfall.svg +1 -1
  252. package/core/icons/gui/icon-gui-prod-ai-transport-outline.svg +5 -0
  253. package/core/icons/gui/icon-gui-prod-ai-transport-solid.svg +5 -0
  254. package/core/icons/gui/icon-gui-quote-marks-fill.svg +2 -2
  255. package/core/icons/product/icon-product-ai-transport-mono.svg +5 -0
  256. package/core/icons/product/icon-product-ai-transport.svg +12 -0
  257. package/core/icons/product/icon-product-chat-mono.svg +1 -1
  258. package/core/icons/product/icon-product-liveobjects-mono.svg +1 -4
  259. package/core/icons/product/icon-product-livesync-mono.svg +4 -4
  260. package/core/icons/product/icon-product-pubsub-mono.svg +1 -1
  261. package/core/icons/product/icon-product-spaces-mono.svg +1 -1
  262. package/core/icons/tech/icon-tech-claude-mono.svg +5 -0
  263. package/core/icons/tech/icon-tech-claude.svg +3 -0
  264. package/core/icons/tech/icon-tech-jetpack.svg +1 -0
  265. package/core/icons/tech/icon-tech-terraform-outline.svg +5 -0
  266. package/core/images/badges/g2-best-meets-requirements-spring-2025.svg +26 -0
  267. package/core/images/badges/g2-best-results-spring-2025.svg +26 -0
  268. package/core/images/badges/g2-best-support-spring-2025.svg +26 -0
  269. package/core/images/badges/g2-easiest-to-use-spring-2025.svg +26 -0
  270. package/core/images/badges/g2-users-most-likely-to-recommend-spring-2025.svg +26 -0
  271. package/core/images/cust-logo-mentimeter-mono-pos.svg +0 -0
  272. package/core/insights/command-queue.js +1 -1
  273. package/core/insights/command-queue.js.map +1 -1
  274. package/core/insights/datalayer.js +1 -1
  275. package/core/insights/datalayer.js.map +1 -1
  276. package/core/insights/index.js +1 -1
  277. package/core/insights/index.js.map +1 -1
  278. package/core/insights/index.test.js +1 -1
  279. package/core/insights/index.test.js.map +1 -1
  280. package/core/insights/mixpanel.js +1 -1
  281. package/core/insights/mixpanel.js.map +1 -1
  282. package/core/insights/mixpanel.test.js +2 -0
  283. package/core/insights/mixpanel.test.js.map +1 -0
  284. package/core/insights/posthog.js +1 -1
  285. package/core/insights/posthog.js.map +1 -1
  286. package/core/insights/posthog.test.js +2 -0
  287. package/core/insights/posthog.test.js.map +1 -0
  288. package/core/insights/service.js +1 -1
  289. package/core/insights/service.js.map +1 -1
  290. package/core/insights/types.js.map +1 -1
  291. package/core/react-renderer.js.map +1 -1
  292. package/core/sprites-display.svg +1 -1
  293. package/core/sprites-gui.svg +1 -1
  294. package/core/sprites-product.svg +1 -1
  295. package/core/sprites-tech.svg +1 -1
  296. package/core/styles/buttons.css +6 -6
  297. package/core/styles/colors/types.js +1 -1
  298. package/core/styles/colors/types.js.map +1 -1
  299. package/core/styles/forms.css +5 -5
  300. package/core/styles/legacy-buttons.css +8 -8
  301. package/core/styles/properties.css +4 -4
  302. package/core/styles/text.css +2 -2
  303. package/core/styles.components.css +4 -4
  304. package/core/utils/syntax-highlighter.css +31 -0
  305. package/core/utils/syntax-highlighter.js +1 -1
  306. package/core/utils/syntax-highlighter.js.map +1 -1
  307. package/core/utils/syntax-highlighter.test.js +2 -0
  308. package/core/utils/syntax-highlighter.test.js.map +1 -0
  309. package/index.d.ts +1201 -118
  310. package/package.json +66 -59
  311. package/tailwind.config.js +2 -2
  312. package/core/CookieMessage/component.css +0 -15
  313. package/core/CookieMessage.js +0 -2
  314. package/core/CookieMessage.js.map +0 -1
  315. package/core/Icon/components/icon-display-asset-tracking-col.js +0 -2
  316. package/core/Icon/components/icon-display-asset-tracking-col.js.map +0 -1
  317. package/core/Icon/components/icon-gui-prod-asset-tracking-outline.js +0 -2
  318. package/core/Icon/components/icon-gui-prod-asset-tracking-outline.js.map +0 -1
  319. package/core/Icon/components/icon-gui-prod-asset-tracking-solid.js +0 -2
  320. package/core/Icon/components/icon-gui-prod-asset-tracking-solid.js.map +0 -1
  321. package/core/Icon/components/icon-product-asset-tracking-mono.js +0 -2
  322. package/core/Icon/components/icon-product-asset-tracking-mono.js.map +0 -1
  323. package/core/Icon/components/icon-product-asset-tracking.js +0 -2
  324. package/core/Icon/components/icon-product-asset-tracking.js.map +0 -1
  325. package/core/Meganav/MeganavProductTile.js +0 -2
  326. package/core/Meganav/MeganavProductTile.js.map +0 -1
  327. package/core/Meganav/images/fan-engagement-nav-image.png +0 -0
  328. package/core/Meganav/images/founders-nav-image.png +0 -0
  329. package/core/icons/display/icon-display-asset-tracking-col.svg +0 -18
  330. package/core/icons/gui/icon-gui-prod-asset-tracking-outline.svg +0 -3
  331. package/core/icons/gui/icon-gui-prod-asset-tracking-solid.svg +0 -3
  332. package/core/icons/product/icon-product-asset-tracking-mono.svg +0 -3
  333. package/core/icons/product/icon-product-asset-tracking.svg +0 -12
  334. package/core/images/g2-best-meets-requirements-2025.svg +0 -10
  335. package/core/images/g2-best-support-2025.svg +0 -10
  336. package/core/images/g2-high-performer-2025.svg +0 -9
  337. package/core/images/g2-users-most-likely-to-recommend-2025.svg +0 -10
  338. package/core/utils/useCopyToClipboard.js +0 -2
  339. package/core/utils/useCopyToClipboard.js.map +0 -1
@@ -20,11 +20,11 @@
20
20
  }
21
21
 
22
22
  .ui-button-disabled-base {
23
- @apply disabled:cursor-not-allowed disabled:bg-gui-unavailable disabled:text-gui-unavailable-dark disabled:hover:bg-gui-unavailable;
23
+ @apply disabled:cursor-not-allowed disabled:bg-gui-disabled-light disabled:text-gui-disabled-dark disabled:hover:bg-gui-disabled-light;
24
24
  }
25
25
 
26
26
  .ui-button-disabled-base-dark {
27
- @apply disabled:cursor-not-allowed disabled:bg-gui-unavailable-dark disabled:text-gui-unavailable disabled:hover:bg-gui-unavailable-dark;
27
+ @apply disabled:cursor-not-allowed disabled:bg-gui-disabled-dark disabled:text-gui-disabled-light disabled:hover:bg-gui-disabled-dark;
28
28
  }
29
29
 
30
30
  .ui-button-priority-base {
@@ -44,11 +44,11 @@
44
44
  }
45
45
 
46
46
  .ui-button-secondary-base {
47
- @apply text-neutral-1300 active:text-neutral-1000 border border-neutral-600 hover:border-neutral-800 active:border-neutral-700 disabled:border-gui-unavailable disabled:text-gui-unavailable;
47
+ @apply text-neutral-1300 active:text-neutral-1000 border border-neutral-400 hover:border-neutral-600 active:border-neutral-500 disabled:border-gui-disabled-light disabled:text-gui-disabled-light;
48
48
  }
49
49
 
50
50
  .ui-theme-dark .ui-button-secondary-base {
51
- @apply text-neutral-000 active:text-neutral-300 border-neutral-700 hover:border-neutral-500 active:border-neutral-600 disabled:border-gui-unavailable-dark disabled:text-gui-unavailable-dark;
51
+ @apply text-neutral-000 active:text-neutral-300 border-neutral-900 hover:border-neutral-700 active:border-neutral-800 disabled:border-gui-disabled-dark disabled:text-gui-disabled-dark;
52
52
  }
53
53
 
54
54
  .ui-button-priority-lg {
@@ -124,10 +124,10 @@
124
124
  }
125
125
 
126
126
  .ui-button-disabled {
127
- @apply select-none pointer-events-none bg-gui-unavailable text-gui-unavailable-dark hover:bg-gui-unavailable;
127
+ @apply select-none pointer-events-none bg-gui-disabled-light text-gui-disabled-dark hover:bg-gui-disabled-light;
128
128
  }
129
129
 
130
130
  .ui-theme-dark .ui-button-disabled {
131
- @apply select-none pointer-events-none bg-gui-unavailable-dark text-gui-unavailable hover:bg-gui-unavailable-dark;
131
+ @apply select-none pointer-events-none bg-gui-disabled-dark text-gui-disabled-light hover:bg-gui-disabled-dark;
132
132
  }
133
133
  }
@@ -1,2 +1,2 @@
1
- export const variants=["","dark:"];export const prefixes=["text","bg","from","to","border"];export const colors=["neutral","orange","blue","yellow","green","violet","pink"];export const neutralColors=["neutral-000","neutral-100","neutral-200","neutral-300","neutral-400","neutral-500","neutral-600","neutral-700","neutral-800","neutral-900","neutral-1000","neutral-1100","neutral-1200","neutral-1300"];export const orangeColors=["orange-100","orange-200","orange-300","orange-400","orange-500","orange-600","orange-700","orange-800","orange-900","orange-1000","orange-1100"];export const yellowColors=["yellow-100","yellow-200","yellow-300","yellow-400","yellow-500","yellow-600","yellow-700","yellow-800","yellow-900"];export const greenColors=["green-100","green-200","green-300","green-400","green-500","green-600","green-700","green-800","green-900"];export const blueColors=["blue-100","blue-200","blue-300","blue-400","blue-500","blue-600","blue-700","blue-800","blue-900"];export const violetColors=["violet-100","violet-200","violet-300","violet-400","violet-500","violet-600","violet-700","violet-800","violet-900"];export const pinkColors=["pink-100","pink-200","pink-300","pink-400","pink-500","pink-600","pink-700","pink-800","pink-900"];const secondaryColors=[...yellowColors,...greenColors,...blueColors,...violetColors,...pinkColors];const guiColors=["gui-blue-default-light","gui-blue-hover-light","gui-blue-active-light","gui-blue-default-dark","gui-blue-hover-dark","gui-blue-active-dark","gui-blue-focus","gui-unavailable","gui-success-green","gui-error-red","gui-focus","gui-focus-outline","gui-visited"];export const aliasedColors=["white","extra-light-grey","light-grey","mid-grey","dark-grey","charcoal-grey","cool-black","active-orange","bright-red","red-orange","electric-cyan","zingy-green","jazzy-pink","gui-default","gui-hover","gui-active","gui-error","gui-success","gui-default-dark","gui-hover-dark","gui-active-dark","transparent"];export const colorRoles={neutral:neutralColors,orange:orangeColors,secondary:secondaryColors,gui:guiColors};export const colorGroupLengths={neutral:neutralColors.length,orange:orangeColors.length,blue:blueColors.length,yellow:yellowColors.length,green:greenColors.length,violet:violetColors.length,pink:pinkColors.length};
1
+ export const variants=["","dark:"];export const prefixes=["text","bg","from","to","border"];export const colors=["neutral","orange","blue","yellow","green","violet","pink"];export const neutralColors=["neutral-000","neutral-100","neutral-200","neutral-300","neutral-400","neutral-500","neutral-600","neutral-700","neutral-800","neutral-900","neutral-1000","neutral-1100","neutral-1200","neutral-1300"];export const orangeColors=["orange-100","orange-200","orange-300","orange-400","orange-500","orange-600","orange-700","orange-800","orange-900","orange-1000","orange-1100"];export const yellowColors=["yellow-100","yellow-200","yellow-300","yellow-400","yellow-500","yellow-600","yellow-700","yellow-800","yellow-900"];export const greenColors=["green-100","green-200","green-300","green-400","green-500","green-600","green-700","green-800","green-900"];export const blueColors=["blue-100","blue-200","blue-300","blue-400","blue-500","blue-600","blue-700","blue-800","blue-900"];export const violetColors=["violet-100","violet-200","violet-300","violet-400","violet-500","violet-600","violet-700","violet-800","violet-900"];export const pinkColors=["pink-100","pink-200","pink-300","pink-400","pink-500","pink-600","pink-700","pink-800","pink-900"];export const secondaryColors=[...yellowColors,...greenColors,...blueColors,...violetColors,...pinkColors];export const guiColors=["gui-blue-default-light","gui-blue-hover-light","gui-blue-active-light","gui-blue-default-dark","gui-blue-hover-dark","gui-blue-active-dark","gui-blue-focus","gui-disabled-light","gui-disabled-dark","gui-success-green","gui-error-red","gui-focus","gui-focus-outline","gui-visited"];export const aliasedColors=["white","extra-light-grey","light-grey","mid-grey","dark-grey","charcoal-grey","cool-black","active-orange","bright-red","red-orange","electric-cyan","zingy-green","jazzy-pink","gui-default","gui-hover","gui-active","gui-error","gui-success","gui-default-dark","gui-hover-dark","gui-active-dark","transparent"];export const colorRoles={neutral:neutralColors,orange:orangeColors,secondary:secondaryColors,gui:guiColors};export const colorGroupLengths={neutral:neutralColors.length,orange:orangeColors.length,blue:blueColors.length,yellow:yellowColors.length,green:greenColors.length,violet:violetColors.length,pink:pinkColors.length};
2
2
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/core/styles/colors/types.ts"],"sourcesContent":["export type ColorName =\n | (typeof neutralColors)[number]\n | (typeof orangeColors)[number]\n | (typeof secondaryColors)[number]\n | (typeof guiColors)[number]\n | (typeof aliasedColors)[number];\n\nexport const variants = [\"\", \"dark:\"] as const;\n\ntype ColorClassVariants = (typeof variants)[number];\n\nexport const prefixes = [\"text\", \"bg\", \"from\", \"to\", \"border\"] as const;\n\ntype ColorClassPrefixes = (typeof prefixes)[number];\n\nexport const colors = [\n \"neutral\",\n \"orange\",\n \"blue\",\n \"yellow\",\n \"green\",\n \"violet\",\n \"pink\",\n] as const;\n\nexport type ColorClassColorGroups = (typeof colors)[number];\n\nexport type Theme = \"light\" | \"dark\";\n\nexport type ColorClass =\n `${ColorClassVariants}${ColorClassPrefixes}-${ColorName}`;\n\nexport type ColorThemeSet = `${string} dark:${string}`;\n\nexport const neutralColors = [\n \"neutral-000\",\n \"neutral-100\",\n \"neutral-200\",\n \"neutral-300\",\n \"neutral-400\",\n \"neutral-500\",\n \"neutral-600\",\n \"neutral-700\",\n \"neutral-800\",\n \"neutral-900\",\n \"neutral-1000\",\n \"neutral-1100\",\n \"neutral-1200\",\n \"neutral-1300\",\n] as const;\n\nexport const orangeColors = [\n \"orange-100\",\n \"orange-200\",\n \"orange-300\",\n \"orange-400\",\n \"orange-500\",\n \"orange-600\",\n \"orange-700\",\n \"orange-800\",\n \"orange-900\",\n \"orange-1000\",\n \"orange-1100\",\n] as const;\n\nexport const yellowColors = [\n \"yellow-100\",\n \"yellow-200\",\n \"yellow-300\",\n \"yellow-400\",\n \"yellow-500\",\n \"yellow-600\",\n \"yellow-700\",\n \"yellow-800\",\n \"yellow-900\",\n] as const;\n\nexport const greenColors = [\n \"green-100\",\n \"green-200\",\n \"green-300\",\n \"green-400\",\n \"green-500\",\n \"green-600\",\n \"green-700\",\n \"green-800\",\n \"green-900\",\n] as const;\n\nexport const blueColors = [\n \"blue-100\",\n \"blue-200\",\n \"blue-300\",\n \"blue-400\",\n \"blue-500\",\n \"blue-600\",\n \"blue-700\",\n \"blue-800\",\n \"blue-900\",\n] as const;\n\nexport const violetColors = [\n \"violet-100\",\n \"violet-200\",\n \"violet-300\",\n \"violet-400\",\n \"violet-500\",\n \"violet-600\",\n \"violet-700\",\n \"violet-800\",\n \"violet-900\",\n] as const;\n\nexport const pinkColors = [\n \"pink-100\",\n \"pink-200\",\n \"pink-300\",\n \"pink-400\",\n \"pink-500\",\n \"pink-600\",\n \"pink-700\",\n \"pink-800\",\n \"pink-900\",\n] as const;\n\nconst secondaryColors = [\n ...yellowColors,\n ...greenColors,\n ...blueColors,\n ...violetColors,\n ...pinkColors,\n] as const;\n\nconst guiColors = [\n \"gui-blue-default-light\",\n \"gui-blue-hover-light\",\n \"gui-blue-active-light\",\n \"gui-blue-default-dark\",\n \"gui-blue-hover-dark\",\n \"gui-blue-active-dark\",\n \"gui-blue-focus\",\n \"gui-unavailable\",\n \"gui-success-green\",\n \"gui-error-red\",\n \"gui-focus\",\n \"gui-focus-outline\",\n \"gui-visited\",\n] as const;\n\nexport const aliasedColors = [\n \"white\",\n \"extra-light-grey\",\n \"light-grey\",\n \"mid-grey\",\n \"dark-grey\",\n \"charcoal-grey\",\n \"cool-black\",\n \"active-orange\",\n \"bright-red\",\n \"red-orange\",\n \"electric-cyan\",\n \"zingy-green\",\n \"jazzy-pink\",\n \"gui-default\",\n \"gui-hover\",\n \"gui-active\",\n \"gui-error\",\n \"gui-success\",\n \"gui-default-dark\",\n \"gui-hover-dark\",\n \"gui-active-dark\",\n \"transparent\",\n] as const;\n\nexport const colorRoles = {\n neutral: neutralColors,\n orange: orangeColors,\n secondary: secondaryColors,\n gui: guiColors,\n};\n\nexport const colorGroupLengths = {\n neutral: neutralColors.length,\n orange: orangeColors.length,\n blue: blueColors.length,\n yellow: yellowColors.length,\n green: greenColors.length,\n violet: violetColors.length,\n pink: pinkColors.length,\n};\n"],"names":["variants","prefixes","colors","neutralColors","orangeColors","yellowColors","greenColors","blueColors","violetColors","pinkColors","secondaryColors","guiColors","aliasedColors","colorRoles","neutral","orange","secondary","gui","colorGroupLengths","length","blue","yellow","green","violet","pink"],"mappings":"AAOA,OAAO,MAAMA,SAAW,CAAC,GAAI,QAAQ,AAAU,AAI/C,QAAO,MAAMC,SAAW,CAAC,OAAQ,KAAM,OAAQ,KAAM,SAAS,AAAU,AAIxE,QAAO,MAAMC,OAAS,CACpB,UACA,SACA,OACA,SACA,QACA,SACA,OACD,AAAU,AAWX,QAAO,MAAMC,cAAgB,CAC3B,cACA,cACA,cACA,cACA,cACA,cACA,cACA,cACA,cACA,cACA,eACA,eACA,eACA,eACD,AAAU,AAEX,QAAO,MAAMC,aAAe,CAC1B,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,cACA,cACD,AAAU,AAEX,QAAO,MAAMC,aAAe,CAC1B,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACD,AAAU,AAEX,QAAO,MAAMC,YAAc,CACzB,YACA,YACA,YACA,YACA,YACA,YACA,YACA,YACA,YACD,AAAU,AAEX,QAAO,MAAMC,WAAa,CACxB,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACD,AAAU,AAEX,QAAO,MAAMC,aAAe,CAC1B,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACD,AAAU,AAEX,QAAO,MAAMC,WAAa,CACxB,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACD,AAAU,CAEX,MAAMC,gBAAkB,IACnBL,gBACAC,eACAC,cACAC,gBACAC,WACJ,CAED,MAAME,UAAY,CAChB,yBACA,uBACA,wBACA,wBACA,sBACA,uBACA,iBACA,kBACA,oBACA,gBACA,YACA,oBACA,cACD,AAED,QAAO,MAAMC,cAAgB,CAC3B,QACA,mBACA,aACA,WACA,YACA,gBACA,aACA,gBACA,aACA,aACA,gBACA,cACA,aACA,cACA,YACA,aACA,YACA,cACA,mBACA,iBACA,kBACA,cACD,AAAU,AAEX,QAAO,MAAMC,WAAa,CACxBC,QAASX,cACTY,OAAQX,aACRY,UAAWN,gBACXO,IAAKN,SACP,CAAE,AAEF,QAAO,MAAMO,kBAAoB,CAC/BJ,QAASX,cAAcgB,MAAM,CAC7BJ,OAAQX,aAAae,MAAM,CAC3BC,KAAMb,WAAWY,MAAM,CACvBE,OAAQhB,aAAac,MAAM,CAC3BG,MAAOhB,YAAYa,MAAM,CACzBI,OAAQf,aAAaW,MAAM,CAC3BK,KAAMf,WAAWU,MAAM,AACzB,CAAE"}
1
+ {"version":3,"sources":["../../../../src/core/styles/colors/types.ts"],"sourcesContent":["export type ColorName =\n | (typeof neutralColors)[number]\n | (typeof orangeColors)[number]\n | (typeof secondaryColors)[number]\n | (typeof guiColors)[number]\n | (typeof aliasedColors)[number];\n\nexport const variants = [\"\", \"dark:\"] as const;\n\ntype ColorClassVariants = (typeof variants)[number];\n\nexport const prefixes = [\"text\", \"bg\", \"from\", \"to\", \"border\"] as const;\n\ntype ColorClassPrefixes = (typeof prefixes)[number];\n\nexport const colors = [\n \"neutral\",\n \"orange\",\n \"blue\",\n \"yellow\",\n \"green\",\n \"violet\",\n \"pink\",\n] as const;\n\nexport type ColorClassColorGroups = (typeof colors)[number];\n\nexport type Theme = \"light\" | \"dark\";\n\nexport type ColorClass =\n `${ColorClassVariants}${ColorClassPrefixes}-${ColorName}`;\n\nexport type ColorThemeSet = `${string} dark:${string}`;\n\nexport const neutralColors = [\n \"neutral-000\",\n \"neutral-100\",\n \"neutral-200\",\n \"neutral-300\",\n \"neutral-400\",\n \"neutral-500\",\n \"neutral-600\",\n \"neutral-700\",\n \"neutral-800\",\n \"neutral-900\",\n \"neutral-1000\",\n \"neutral-1100\",\n \"neutral-1200\",\n \"neutral-1300\",\n] as const;\n\nexport const orangeColors = [\n \"orange-100\",\n \"orange-200\",\n \"orange-300\",\n \"orange-400\",\n \"orange-500\",\n \"orange-600\",\n \"orange-700\",\n \"orange-800\",\n \"orange-900\",\n \"orange-1000\",\n \"orange-1100\",\n] as const;\n\nexport const yellowColors = [\n \"yellow-100\",\n \"yellow-200\",\n \"yellow-300\",\n \"yellow-400\",\n \"yellow-500\",\n \"yellow-600\",\n \"yellow-700\",\n \"yellow-800\",\n \"yellow-900\",\n] as const;\n\nexport const greenColors = [\n \"green-100\",\n \"green-200\",\n \"green-300\",\n \"green-400\",\n \"green-500\",\n \"green-600\",\n \"green-700\",\n \"green-800\",\n \"green-900\",\n] as const;\n\nexport const blueColors = [\n \"blue-100\",\n \"blue-200\",\n \"blue-300\",\n \"blue-400\",\n \"blue-500\",\n \"blue-600\",\n \"blue-700\",\n \"blue-800\",\n \"blue-900\",\n] as const;\n\nexport const violetColors = [\n \"violet-100\",\n \"violet-200\",\n \"violet-300\",\n \"violet-400\",\n \"violet-500\",\n \"violet-600\",\n \"violet-700\",\n \"violet-800\",\n \"violet-900\",\n] as const;\n\nexport const pinkColors = [\n \"pink-100\",\n \"pink-200\",\n \"pink-300\",\n \"pink-400\",\n \"pink-500\",\n \"pink-600\",\n \"pink-700\",\n \"pink-800\",\n \"pink-900\",\n] as const;\n\nexport const secondaryColors = [\n ...yellowColors,\n ...greenColors,\n ...blueColors,\n ...violetColors,\n ...pinkColors,\n] as const;\n\nexport const guiColors = [\n \"gui-blue-default-light\",\n \"gui-blue-hover-light\",\n \"gui-blue-active-light\",\n \"gui-blue-default-dark\",\n \"gui-blue-hover-dark\",\n \"gui-blue-active-dark\",\n \"gui-blue-focus\",\n \"gui-disabled-light\",\n \"gui-disabled-dark\",\n \"gui-success-green\",\n \"gui-error-red\",\n \"gui-focus\",\n \"gui-focus-outline\",\n \"gui-visited\",\n] as const;\n\nexport const aliasedColors = [\n \"white\",\n \"extra-light-grey\",\n \"light-grey\",\n \"mid-grey\",\n \"dark-grey\",\n \"charcoal-grey\",\n \"cool-black\",\n \"active-orange\",\n \"bright-red\",\n \"red-orange\",\n \"electric-cyan\",\n \"zingy-green\",\n \"jazzy-pink\",\n \"gui-default\",\n \"gui-hover\",\n \"gui-active\",\n \"gui-error\",\n \"gui-success\",\n \"gui-default-dark\",\n \"gui-hover-dark\",\n \"gui-active-dark\",\n \"transparent\",\n] as const;\n\nexport const colorRoles = {\n neutral: neutralColors,\n orange: orangeColors,\n secondary: secondaryColors,\n gui: guiColors,\n};\n\nexport const colorGroupLengths = {\n neutral: neutralColors.length,\n orange: orangeColors.length,\n blue: blueColors.length,\n yellow: yellowColors.length,\n green: greenColors.length,\n violet: violetColors.length,\n pink: pinkColors.length,\n};\n"],"names":["variants","prefixes","colors","neutralColors","orangeColors","yellowColors","greenColors","blueColors","violetColors","pinkColors","secondaryColors","guiColors","aliasedColors","colorRoles","neutral","orange","secondary","gui","colorGroupLengths","length","blue","yellow","green","violet","pink"],"mappings":"AAOA,OAAO,MAAMA,SAAW,CAAC,GAAI,QAAQ,AAAU,AAI/C,QAAO,MAAMC,SAAW,CAAC,OAAQ,KAAM,OAAQ,KAAM,SAAS,AAAU,AAIxE,QAAO,MAAMC,OAAS,CACpB,UACA,SACA,OACA,SACA,QACA,SACA,OACD,AAAU,AAWX,QAAO,MAAMC,cAAgB,CAC3B,cACA,cACA,cACA,cACA,cACA,cACA,cACA,cACA,cACA,cACA,eACA,eACA,eACA,eACD,AAAU,AAEX,QAAO,MAAMC,aAAe,CAC1B,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,cACA,cACD,AAAU,AAEX,QAAO,MAAMC,aAAe,CAC1B,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACD,AAAU,AAEX,QAAO,MAAMC,YAAc,CACzB,YACA,YACA,YACA,YACA,YACA,YACA,YACA,YACA,YACD,AAAU,AAEX,QAAO,MAAMC,WAAa,CACxB,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACD,AAAU,AAEX,QAAO,MAAMC,aAAe,CAC1B,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACA,aACD,AAAU,AAEX,QAAO,MAAMC,WAAa,CACxB,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACD,AAAU,AAEX,QAAO,MAAMC,gBAAkB,IAC1BL,gBACAC,eACAC,cACAC,gBACAC,WACJ,AAAU,AAEX,QAAO,MAAME,UAAY,CACvB,yBACA,uBACA,wBACA,wBACA,sBACA,uBACA,iBACA,qBACA,oBACA,oBACA,gBACA,YACA,oBACA,cACD,AAAU,AAEX,QAAO,MAAMC,cAAgB,CAC3B,QACA,mBACA,aACA,WACA,YACA,gBACA,aACA,gBACA,aACA,aACA,gBACA,cACA,aACA,cACA,YACA,aACA,YACA,cACA,mBACA,iBACA,kBACA,cACD,AAAU,AAEX,QAAO,MAAMC,WAAa,CACxBC,QAASX,cACTY,OAAQX,aACRY,UAAWN,gBACXO,IAAKN,SACP,CAAE,AAEF,QAAO,MAAMO,kBAAoB,CAC/BJ,QAASX,cAAcgB,MAAM,CAC7BJ,OAAQX,aAAae,MAAM,CAC3BC,KAAMb,WAAWY,MAAM,CACvBE,OAAQhB,aAAac,MAAM,CAC3BG,MAAOhB,YAAYa,MAAM,CACzBI,OAAQf,aAAaW,MAAM,CAC3BK,KAAMf,WAAWU,MAAM,AACzB,CAAE"}
@@ -59,11 +59,11 @@
59
59
  }
60
60
 
61
61
  .ui-theme-dark .ui-checkbox-input:disabled + .ui-checkbox-styled {
62
- @apply bg-neutral-1000 border border-gui-unavailable-dark;
62
+ @apply bg-neutral-1000 border border-gui-disabled-dark;
63
63
  }
64
64
 
65
65
  .ui-theme-dark .ui-checkbox-input:checked + .ui-checkbox-styled {
66
- @apply bg-active-orange border-gui-unavailable-dark;
66
+ @apply bg-active-orange border-gui-disabled-dark;
67
67
  }
68
68
 
69
69
  .ui-textarea {
@@ -110,7 +110,7 @@
110
110
  }
111
111
 
112
112
  .ui-toggle input:disabled + .ui-toggle-slider {
113
- @apply bg-gui-unavailable;
113
+ @apply bg-gui-disabled-light dark:bg-gui-disabled-dark;
114
114
  }
115
115
 
116
116
  .ui-toggle input:checked + .ui-toggle-slider:before {
@@ -132,11 +132,11 @@
132
132
  }
133
133
 
134
134
  .ui-input:disabled {
135
- @apply bg-gui-unavailable placeholder-neutral-500 text-neutral-500;
135
+ @apply bg-gui-disabled-light placeholder-neutral-500 text-neutral-500;
136
136
  }
137
137
 
138
138
  .ui-theme-dark .ui-input:disabled {
139
- @apply bg-gui-unavailable-dark text-neutral-800 placeholder-neutral-800;
139
+ @apply bg-gui-disabled-dark text-neutral-800 placeholder-neutral-800;
140
140
  }
141
141
 
142
142
  .ui-radio {
@@ -4,7 +4,7 @@
4
4
  @apply hover:text-white hover:bg-neutral-1100;
5
5
  @apply active:text-white active:bg-neutral-1200;
6
6
  @apply focus:text-white focus:bg-cool-black focus-base;
7
- @apply disabled:text-mid-grey disabled:bg-gui-unavailable disabled:cursor-not-allowed;
7
+ @apply disabled:text-mid-grey disabled:bg-gui-disabled-light disabled:cursor-not-allowed;
8
8
  @apply transition-colors;
9
9
  @apply inline-flex items-center justify-center;
10
10
  }
@@ -36,7 +36,7 @@
36
36
 
37
37
  .ui-btn-alt:disabled {
38
38
  background: linear-gradient(var(--gradient-transparent));
39
- @apply bg-gui-unavailable text-mid-grey cursor-not-allowed;
39
+ @apply bg-gui-disabled-light text-mid-grey cursor-not-allowed;
40
40
  }
41
41
 
42
42
  .ui-btn-invert {
@@ -44,7 +44,7 @@
44
44
  @apply hover:text-white hover:bg-active-orange;
45
45
  @apply active:text-white active:bg-red-orange;
46
46
  @apply focus:text-white focus:bg-cool-black focus-base;
47
- @apply disabled:text-mid-grey disabled:bg-gui-unavailable disabled:cursor-not-allowed;
47
+ @apply disabled:text-mid-grey disabled:bg-gui-disabled-light disabled:cursor-not-allowed;
48
48
  @apply transition-colors;
49
49
  @apply inline-flex items-center justify-center;
50
50
  }
@@ -54,7 +54,7 @@
54
54
  @apply hover:text-cool-black hover:border-active-orange hover:bg-white;
55
55
  @apply active:border-red-orange active:bg-white;
56
56
  @apply focus:border-cool-black focus:bg-white focus-base;
57
- @apply disabled:text-gui-unavailable disabled:border-gui-unavailable disabled:bg-white disabled:cursor-not-allowed;
57
+ @apply disabled:text-gui-disabled-light disabled:border-gui-disabled-light disabled:bg-white disabled:cursor-not-allowed;
58
58
  @apply transition-colors;
59
59
  @apply inline-flex items-center justify-center;
60
60
  }
@@ -64,7 +64,7 @@
64
64
  @apply hover:text-white hover:border-active-orange;
65
65
  @apply active:border-red-orange;
66
66
  @apply focus-base;
67
- @apply disabled:text-gui-unavailable disabled:border-gui-unavailable disabled:cursor-not-allowed;
67
+ @apply disabled:text-gui-disabled-light disabled:border-gui-disabled-light disabled:cursor-not-allowed;
68
68
  @apply transition-colors;
69
69
  @apply inline-flex items-center justify-center;
70
70
  }
@@ -82,14 +82,14 @@
82
82
  }
83
83
  .ui-btn.ui-btn-disabled,
84
84
  .ui-btn-invert.ui-btn-disabled {
85
- @apply text-mid-grey bg-gui-unavailable cursor-not-allowed pointer-events-none select-none;
85
+ @apply text-mid-grey bg-gui-disabled-light cursor-not-allowed pointer-events-none select-none;
86
86
  }
87
87
 
88
88
  .ui-btn-secondary.ui-btn-disabled {
89
- @apply text-gui-unavailable border-gui-unavailable bg-white cursor-not-allowed pointer-events-none select-none;
89
+ @apply text-gui-disabled-light border-gui-disabled-light bg-white cursor-not-allowed pointer-events-none select-none;
90
90
  }
91
91
 
92
92
  .ui-btn-secondary-invert.ui-btn-disabled {
93
- @apply text-gui-unavailable border-gui-unavailable cursor-not-allowed pointer-events-none select-none;
93
+ @apply text-gui-disabled-light border-gui-disabled-light cursor-not-allowed pointer-events-none select-none;
94
94
  }
95
95
  }
@@ -10,8 +10,8 @@
10
10
  --color-neutral-600: #a7b1be;
11
11
  --color-neutral-700: #8992a4;
12
12
  --color-neutral-800: #687288;
13
- --color-neutral-900: #5b5a72;
14
- --color-neutral-1000: #434356;
13
+ --color-neutral-900: #575d71;
14
+ --color-neutral-1000: #3f4555;
15
15
  --color-neutral-1100: #2c3344;
16
16
  --color-neutral-1200: #141924;
17
17
  --color-neutral-1300: #03020d;
@@ -85,8 +85,8 @@
85
85
  --color-gui-blue-hover-dark: #2894ff;
86
86
  --color-gui-blue-active-dark: #0080ff;
87
87
  --color-gui-blue-focus: #80b9f2;
88
- --color-gui-unavailable: #a8a8a8;
89
- --color-gui-unavailable-dark: #575757;
88
+ --color-gui-disabled-light: #afb9c5;
89
+ --color-gui-disabled-dark: #676b7a;
90
90
  --color-gui-success-green: #11cb24;
91
91
  --color-gui-error-red: #fb0c0c;
92
92
  --color-gui-focus: #80b9f2;
@@ -159,13 +159,13 @@
159
159
 
160
160
  .ui-link {
161
161
  @apply text-gui-default;
162
- @apply hover:text-gui-hover active:text-gui-active disabled:text-gui-unavailable;
162
+ @apply hover:text-gui-hover active:text-gui-active disabled:text-gui-disabled-light dark:disabled:text-gui-disabled-dark;
163
163
  @apply focus:text-gui-default focus-base;
164
164
  @apply no-underline;
165
165
  }
166
166
 
167
167
  .ui-link-neutral {
168
- @apply hover:text-dark-grey active:text-cool-black disabled:text-gui-unavailable;
168
+ @apply hover:text-dark-grey active:text-cool-black disabled:text-gui-disabled-light dark:disabled:text-gui-disabled-dark;
169
169
  @apply focus:text-charcoal-grey focus-base;
170
170
  @apply underline;
171
171
  }
@@ -38,19 +38,19 @@
38
38
  in a way that handles margin collapsing as well (hence not an exact opposite) */
39
39
  .ui-section-spacing-collapse,
40
40
  .ui-section-spacing-collapse-full {
41
- @apply -my-4 sm:-my-8 md:-my-16;
41
+ @apply -my-4 sm:-my-8 md:-my-16 first:-mb-8 sm:first:-mb-16 md:first:-mb-32 last:-mt-8 sm:last:-mt-16 md:last:-mt-32;
42
42
  }
43
43
 
44
44
  .ui-section-spacing-collapse-half {
45
- @apply -my-2 sm:-my-4 md:-my-8;
45
+ @apply -my-2 sm:-my-4 md:-my-8 first:-mb-4 sm:first:-mb-8 md:first:-mb-16 last:-mt-4 sm:last:-mt-8 md:last:-mt-16;
46
46
  }
47
47
 
48
48
  .ui-section-spacing-collapse-quarter {
49
- @apply -my-1 sm:-my-2 md:-my-4;
49
+ @apply -my-1 sm:-my-2 md:-my-4 first:-mb-2 sm:first:-mb-4 md:first:-mb-8 last:-mt-2 sm:last:-mt-4 md:last:-mt-8;
50
50
  }
51
51
 
52
52
  .ui-section-spacing-collapse-eighth {
53
- @apply -my-0.5 sm:-my-1 md:-my-2;
53
+ @apply -my-0.5 sm:-my-1 md:-my-2 first:-mb-1 sm:first:-mb-2 md:first:-mb-4 last:-mt-1 sm:last:-mt-2 md:last:-mt-4;
54
54
  }
55
55
 
56
56
  .ui-content-spacing {
@@ -128,4 +128,35 @@
128
128
  .ui-theme-dark .hljs-tag {
129
129
  /* purposely ignored */
130
130
  }
131
+
132
+ /* Line highlighting styles – rail + subtle tint */
133
+ .code-line-addition {
134
+ background-color: var(--color-green-100);
135
+ box-shadow: inset 3px 0 0 var(--color-green-400);
136
+ }
137
+
138
+ .code-line-removal {
139
+ background-color: var(--color-orange-100);
140
+ box-shadow: inset 3px 0 0 var(--color-gui-error-red);
141
+ }
142
+
143
+ .code-line-highlight {
144
+ background-color: var(--color-yellow-100);
145
+ box-shadow: inset 3px 0 0 var(--color-yellow-400);
146
+ }
147
+
148
+ .ui-theme-dark .code-line-addition {
149
+ background-color: var(--color-green-900);
150
+ box-shadow: inset 3px 0 0 var(--color-green-600);
151
+ }
152
+
153
+ .ui-theme-dark .code-line-removal {
154
+ background-color: var(--color-orange-1100);
155
+ box-shadow: inset 3px 0 0 var(--color-gui-error-red);
156
+ }
157
+
158
+ .ui-theme-dark .code-line-highlight {
159
+ background-color: var(--color-yellow-900);
160
+ box-shadow: inset 3px 0 0 var(--color-yellow-600);
161
+ }
131
162
  }
@@ -1,2 +1,2 @@
1
- import hljs from"highlight.js/lib/core";const languageToHighlightKey=lang=>{let id;if(!lang){lang="text"}switch(lang.toLowerCase()){case"android":id="java";break;case".net":case"net":case"dotnet":case"csharp":case"c#":id="cs";break;case"objc":case"objective c":id="objectivec";break;case"laravel":id="php";break;case"flutter":id="dart";break;case"node.js":case"js":id="javascript";break;case"ts":id="typescript";break;case"kotlin":case"kt":id="kotlin";break;case"shell":case"fh":case"sh":id="bash";break;case"https":case"http":case"txt":case"plaintext":id="text";break;case"cmd":case"bat":id="dos";break;case"yml":id="yaml";break;case"erl":id="erlang";break;case"patch":id="diff";break;case"svg":id="xml";break;default:break}return id||lang};const registerDefaultLanguages=register=>{register.forEach(({key,module})=>hljs.registerLanguage(key,module))};const highlightSnippet=(languageKeyword,snippet)=>{const language=languageToHighlightKey(languageKeyword);if(typeof snippet!=="string"||!snippet||!language)return;return hljs.highlight(snippet,{language}).value};export{highlightSnippet,languageToHighlightKey,registerDefaultLanguages};
1
+ import hljs from"highlight.js/lib/core";const languageToHighlightKey=lang=>{let id;if(!lang){lang="text"}switch(lang.toLowerCase()){case"android":id="java";break;case".net":case"net":case"dotnet":case"csharp":case"c#":id="cs";break;case"objc":case"objective c":id="objectivec";break;case"laravel":id="php";break;case"flutter":id="dart";break;case"node.js":case"js":id="javascript";break;case"ts":id="typescript";break;case"kotlin":case"kt":id="kotlin";break;case"shell":case"fh":case"sh":id="bash";break;case"https":case"http":case"txt":case"plaintext":id="text";break;case"cmd":case"bat":id="dos";break;case"yml":id="yaml";break;case"erl":id="erlang";break;case"patch":id="diff";break;case"svg":id="xml";break;default:break}return id||lang};const registerDefaultLanguages=register=>{register.forEach(({key,module})=>hljs.registerLanguage(key,module))};const highlightSnippet=(languageKeyword,snippet)=>{const language=languageToHighlightKey(languageKeyword);if(typeof snippet!=="string"||!snippet||!language)return;return hljs.highlight(snippet,{language}).value};const parseLineHighlights=(languageString,meta)=>{if(!meta){return{lang:languageString,highlights:{}}}const match=meta.match(/highlight=["']?([^"']+)["']?/);if(!match){return{lang:languageString,highlights:{}}}const spec=match[1];const highlights={};const tokens=spec.split(",");for(const token of tokens){const trimmed=token.trim();if(!trimmed)continue;let type="highlight";let rangePart=trimmed;if(trimmed.startsWith("+")){type="addition";rangePart=trimmed.slice(1)}else if(trimmed.startsWith("-")){type="removal";rangePart=trimmed.slice(1)}const rangeMatch=rangePart.match(/^(\d+)(?:-(\d+))?$/);if(!rangeMatch)continue;const start=parseInt(rangeMatch[1],10);const end=rangeMatch[2]?parseInt(rangeMatch[2],10):start;for(let i=start;i<=end;i++){highlights[i]=type}}return{lang:languageString,highlights}};const splitHtmlLines=html=>{const rawLines=html.split("\n");const result=[];let openTags=[];for(const rawLine of rawLines){let line=openTags.join("")+rawLine;const tagPattern=/<(\/?)span([^>]*)>/g;let m;while((m=tagPattern.exec(rawLine))!==null){if(m[1]==="/"){openTags.pop()}else{openTags.push(m[0])}}for(let i=0;i<openTags.length;i++){line+="</span>"}result.push(line)}return result};const LINE_HIGHLIGHT_CLASSES={addition:"code-line-addition",removal:"code-line-removal",highlight:"code-line-highlight"};export{highlightSnippet,languageToHighlightKey,LINE_HIGHLIGHT_CLASSES,parseLineHighlights,registerDefaultLanguages,splitHtmlLines};
2
2
  //# sourceMappingURL=syntax-highlighter.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/core/utils/syntax-highlighter.js"],"sourcesContent":["import hljs from \"highlight.js/lib/core\";\n\n// Map certain frameworks, protocols etc to available langauage packs\nconst languageToHighlightKey = (lang) => {\n let id;\n\n if (!lang) {\n lang = \"text\";\n }\n\n switch (lang.toLowerCase()) {\n case \"android\":\n id = \"java\";\n break;\n\n case \".net\":\n case \"net\":\n case \"dotnet\":\n case \"csharp\":\n case \"c#\":\n id = \"cs\";\n break;\n\n case \"objc\":\n case \"objective c\":\n id = \"objectivec\";\n break;\n\n case \"laravel\":\n id = \"php\";\n break;\n\n case \"flutter\":\n id = \"dart\";\n break;\n\n case \"node.js\":\n case \"js\":\n id = \"javascript\";\n break;\n\n case \"ts\":\n id = \"typescript\";\n break;\n\n case \"kotlin\":\n case \"kt\":\n id = \"kotlin\";\n break;\n\n case \"shell\":\n case \"fh\":\n case \"sh\":\n id = \"bash\";\n break;\n\n case \"https\":\n case \"http\":\n case \"txt\":\n case \"plaintext\":\n id = \"text\";\n break;\n\n case \"cmd\":\n case \"bat\":\n id = \"dos\";\n break;\n\n case \"yml\":\n id = \"yaml\";\n break;\n\n case \"erl\":\n id = \"erlang\";\n break;\n\n case \"patch\":\n id = \"diff\";\n break;\n\n case \"svg\":\n id = \"xml\";\n break;\n\n default:\n break;\n }\n\n return id || lang;\n};\n\nconst registerDefaultLanguages = (register) => {\n register.forEach(({ key, module }) => hljs.registerLanguage(key, module));\n};\n\nconst highlightSnippet = (languageKeyword, snippet) => {\n const language = languageToHighlightKey(languageKeyword);\n if (typeof snippet !== \"string\" || !snippet || !language) return;\n\n return hljs.highlight(snippet, { language }).value;\n};\n\nexport { highlightSnippet, languageToHighlightKey, registerDefaultLanguages };\n"],"names":["hljs","languageToHighlightKey","lang","id","toLowerCase","registerDefaultLanguages","register","forEach","key","module","registerLanguage","highlightSnippet","languageKeyword","snippet","language","highlight","value"],"mappings":"AAAA,OAAOA,SAAU,uBAAwB,CAGzC,MAAMC,uBAAyB,AAACC,OAC9B,IAAIC,GAEJ,GAAI,CAACD,KAAM,CACTA,KAAO,MACT,CAEA,OAAQA,KAAKE,WAAW,IACtB,IAAK,UACHD,GAAK,OACL,KAEF,KAAK,OACL,IAAK,MACL,IAAK,SACL,IAAK,SACL,IAAK,KACHA,GAAK,KACL,KAEF,KAAK,OACL,IAAK,cACHA,GAAK,aACL,KAEF,KAAK,UACHA,GAAK,MACL,KAEF,KAAK,UACHA,GAAK,OACL,KAEF,KAAK,UACL,IAAK,KACHA,GAAK,aACL,KAEF,KAAK,KACHA,GAAK,aACL,KAEF,KAAK,SACL,IAAK,KACHA,GAAK,SACL,KAEF,KAAK,QACL,IAAK,KACL,IAAK,KACHA,GAAK,OACL,KAEF,KAAK,QACL,IAAK,OACL,IAAK,MACL,IAAK,YACHA,GAAK,OACL,KAEF,KAAK,MACL,IAAK,MACHA,GAAK,MACL,KAEF,KAAK,MACHA,GAAK,OACL,KAEF,KAAK,MACHA,GAAK,SACL,KAEF,KAAK,QACHA,GAAK,OACL,KAEF,KAAK,MACHA,GAAK,MACL,KAEF,SACE,KACJ,CAEA,OAAOA,IAAMD,IACf,EAEA,MAAMG,yBAA2B,AAACC,WAChCA,SAASC,OAAO,CAAC,CAAC,CAAEC,GAAG,CAAEC,MAAM,CAAE,GAAKT,KAAKU,gBAAgB,CAACF,IAAKC,QACnE,EAEA,MAAME,iBAAmB,CAACC,gBAAiBC,WACzC,MAAMC,SAAWb,uBAAuBW,iBACxC,GAAI,OAAOC,UAAY,UAAY,CAACA,SAAW,CAACC,SAAU,OAE1D,OAAOd,KAAKe,SAAS,CAACF,QAAS,CAAEC,QAAS,GAAGE,KAAK,AACpD,CAEA,QAASL,gBAAgB,CAAEV,sBAAsB,CAAEI,wBAAwB,CAAG"}
1
+ {"version":3,"sources":["../../../src/core/utils/syntax-highlighter.js"],"sourcesContent":["import hljs from \"highlight.js/lib/core\";\n\n// Map certain frameworks, protocols etc to available langauage packs\nconst languageToHighlightKey = (lang) => {\n let id;\n\n if (!lang) {\n lang = \"text\";\n }\n\n switch (lang.toLowerCase()) {\n case \"android\":\n id = \"java\";\n break;\n\n case \".net\":\n case \"net\":\n case \"dotnet\":\n case \"csharp\":\n case \"c#\":\n id = \"cs\";\n break;\n\n case \"objc\":\n case \"objective c\":\n id = \"objectivec\";\n break;\n\n case \"laravel\":\n id = \"php\";\n break;\n\n case \"flutter\":\n id = \"dart\";\n break;\n\n case \"node.js\":\n case \"js\":\n id = \"javascript\";\n break;\n\n case \"ts\":\n id = \"typescript\";\n break;\n\n case \"kotlin\":\n case \"kt\":\n id = \"kotlin\";\n break;\n\n case \"shell\":\n case \"fh\":\n case \"sh\":\n id = \"bash\";\n break;\n\n case \"https\":\n case \"http\":\n case \"txt\":\n case \"plaintext\":\n id = \"text\";\n break;\n\n case \"cmd\":\n case \"bat\":\n id = \"dos\";\n break;\n\n case \"yml\":\n id = \"yaml\";\n break;\n\n case \"erl\":\n id = \"erlang\";\n break;\n\n case \"patch\":\n id = \"diff\";\n break;\n\n case \"svg\":\n id = \"xml\";\n break;\n\n default:\n break;\n }\n\n return id || lang;\n};\n\nconst registerDefaultLanguages = (register) => {\n register.forEach(({ key, module }) => hljs.registerLanguage(key, module));\n};\n\nconst highlightSnippet = (languageKeyword, snippet) => {\n const language = languageToHighlightKey(languageKeyword);\n if (typeof snippet !== \"string\" || !snippet || !language) return;\n\n return hljs.highlight(snippet, { language }).value;\n};\n\n/**\n * Parse line highlight specifications from a meta string.\n *\n * Syntax: `highlight=\"+1-3,-5,7\"`\n * - `+` prefix: addition (green)\n * - `-` prefix: removal (red)\n * - no prefix: neutral highlight (blue)\n * - `N-M`: inclusive line range\n * - comma-separated for multiple specs\n *\n * @param {string} languageString - the language, e.g. \"javascript\"\n * @param {string} [meta] - string containing highlight specs, e.g. 'highlight=\"+1-3,-5,7\"'\n * @returns {{ lang: string, highlights: Record<number, 'addition' | 'removal' | 'highlight'> }}\n */\nconst parseLineHighlights = (languageString, meta) => {\n if (!meta) {\n return { lang: languageString, highlights: {} };\n }\n\n const match = meta.match(/highlight=[\"']?([^\"']+)[\"']?/);\n if (!match) {\n return { lang: languageString, highlights: {} };\n }\n\n const spec = match[1];\n const highlights = {};\n\n const tokens = spec.split(\",\");\n for (const token of tokens) {\n const trimmed = token.trim();\n if (!trimmed) continue;\n\n let type = \"highlight\";\n let rangePart = trimmed;\n\n if (trimmed.startsWith(\"+\")) {\n type = \"addition\";\n rangePart = trimmed.slice(1);\n } else if (trimmed.startsWith(\"-\")) {\n type = \"removal\";\n rangePart = trimmed.slice(1);\n }\n\n const rangeMatch = rangePart.match(/^(\\d+)(?:-(\\d+))?$/);\n if (!rangeMatch) continue;\n\n const start = parseInt(rangeMatch[1], 10);\n const end = rangeMatch[2] ? parseInt(rangeMatch[2], 10) : start;\n\n for (let i = start; i <= end; i++) {\n highlights[i] = type;\n }\n }\n\n return { lang: languageString, highlights };\n};\n\n/**\n * Split highlighted HTML by newlines, repairing any spans that cross\n * line boundaries so each line fragment is valid HTML.\n *\n * @param {string} html - HTML string produced by highlight.js\n * @returns {string[]} one HTML fragment per source line\n */\nconst splitHtmlLines = (html) => {\n const rawLines = html.split(\"\\n\");\n const result = [];\n let openTags = [];\n\n for (const rawLine of rawLines) {\n let line = openTags.join(\"\") + rawLine;\n\n // Process open/close tags in document order\n const tagPattern = /<(\\/?)span([^>]*)>/g;\n let m;\n while ((m = tagPattern.exec(rawLine)) !== null) {\n if (m[1] === \"/\") {\n openTags.pop();\n } else {\n openTags.push(m[0]);\n }\n }\n\n // Close any tags still open so this line is valid HTML\n for (let i = 0; i < openTags.length; i++) {\n line += \"</span>\";\n }\n\n result.push(line);\n }\n\n return result;\n};\n\nconst LINE_HIGHLIGHT_CLASSES = {\n addition: \"code-line-addition\",\n removal: \"code-line-removal\",\n highlight: \"code-line-highlight\",\n};\n\nexport {\n highlightSnippet,\n languageToHighlightKey,\n LINE_HIGHLIGHT_CLASSES,\n parseLineHighlights,\n registerDefaultLanguages,\n splitHtmlLines,\n};\n"],"names":["hljs","languageToHighlightKey","lang","id","toLowerCase","registerDefaultLanguages","register","forEach","key","module","registerLanguage","highlightSnippet","languageKeyword","snippet","language","highlight","value","parseLineHighlights","languageString","meta","highlights","match","spec","tokens","split","token","trimmed","trim","type","rangePart","startsWith","slice","rangeMatch","start","parseInt","end","i","splitHtmlLines","html","rawLines","result","openTags","rawLine","line","join","tagPattern","m","exec","pop","push","length","LINE_HIGHLIGHT_CLASSES","addition","removal"],"mappings":"AAAA,OAAOA,SAAU,uBAAwB,CAGzC,MAAMC,uBAAyB,AAACC,OAC9B,IAAIC,GAEJ,GAAI,CAACD,KAAM,CACTA,KAAO,MACT,CAEA,OAAQA,KAAKE,WAAW,IACtB,IAAK,UACHD,GAAK,OACL,KAEF,KAAK,OACL,IAAK,MACL,IAAK,SACL,IAAK,SACL,IAAK,KACHA,GAAK,KACL,KAEF,KAAK,OACL,IAAK,cACHA,GAAK,aACL,KAEF,KAAK,UACHA,GAAK,MACL,KAEF,KAAK,UACHA,GAAK,OACL,KAEF,KAAK,UACL,IAAK,KACHA,GAAK,aACL,KAEF,KAAK,KACHA,GAAK,aACL,KAEF,KAAK,SACL,IAAK,KACHA,GAAK,SACL,KAEF,KAAK,QACL,IAAK,KACL,IAAK,KACHA,GAAK,OACL,KAEF,KAAK,QACL,IAAK,OACL,IAAK,MACL,IAAK,YACHA,GAAK,OACL,KAEF,KAAK,MACL,IAAK,MACHA,GAAK,MACL,KAEF,KAAK,MACHA,GAAK,OACL,KAEF,KAAK,MACHA,GAAK,SACL,KAEF,KAAK,QACHA,GAAK,OACL,KAEF,KAAK,MACHA,GAAK,MACL,KAEF,SACE,KACJ,CAEA,OAAOA,IAAMD,IACf,EAEA,MAAMG,yBAA2B,AAACC,WAChCA,SAASC,OAAO,CAAC,CAAC,CAAEC,GAAG,CAAEC,MAAM,CAAE,GAAKT,KAAKU,gBAAgB,CAACF,IAAKC,QACnE,EAEA,MAAME,iBAAmB,CAACC,gBAAiBC,WACzC,MAAMC,SAAWb,uBAAuBW,iBACxC,GAAI,OAAOC,UAAY,UAAY,CAACA,SAAW,CAACC,SAAU,OAE1D,OAAOd,KAAKe,SAAS,CAACF,QAAS,CAAEC,QAAS,GAAGE,KAAK,AACpD,EAgBA,MAAMC,oBAAsB,CAACC,eAAgBC,QAC3C,GAAI,CAACA,KAAM,CACT,MAAO,CAAEjB,KAAMgB,eAAgBE,WAAY,CAAC,CAAE,CAChD,CAEA,MAAMC,MAAQF,KAAKE,KAAK,CAAC,gCACzB,GAAI,CAACA,MAAO,CACV,MAAO,CAAEnB,KAAMgB,eAAgBE,WAAY,CAAC,CAAE,CAChD,CAEA,MAAME,KAAOD,KAAK,CAAC,EAAE,CACrB,MAAMD,WAAa,CAAC,EAEpB,MAAMG,OAASD,KAAKE,KAAK,CAAC,KAC1B,IAAK,MAAMC,SAASF,OAAQ,CAC1B,MAAMG,QAAUD,MAAME,IAAI,GAC1B,GAAI,CAACD,QAAS,SAEd,IAAIE,KAAO,YACX,IAAIC,UAAYH,QAEhB,GAAIA,QAAQI,UAAU,CAAC,KAAM,CAC3BF,KAAO,WACPC,UAAYH,QAAQK,KAAK,CAAC,EAC5B,MAAO,GAAIL,QAAQI,UAAU,CAAC,KAAM,CAClCF,KAAO,UACPC,UAAYH,QAAQK,KAAK,CAAC,EAC5B,CAEA,MAAMC,WAAaH,UAAUR,KAAK,CAAC,sBACnC,GAAI,CAACW,WAAY,SAEjB,MAAMC,MAAQC,SAASF,UAAU,CAAC,EAAE,CAAE,IACtC,MAAMG,IAAMH,UAAU,CAAC,EAAE,CAAGE,SAASF,UAAU,CAAC,EAAE,CAAE,IAAMC,MAE1D,IAAK,IAAIG,EAAIH,MAAOG,GAAKD,IAAKC,IAAK,CACjChB,UAAU,CAACgB,EAAE,CAAGR,IAClB,CACF,CAEA,MAAO,CAAE1B,KAAMgB,eAAgBE,UAAW,CAC5C,EASA,MAAMiB,eAAiB,AAACC,OACtB,MAAMC,SAAWD,KAAKd,KAAK,CAAC,MAC5B,MAAMgB,OAAS,EAAE,CACjB,IAAIC,SAAW,EAAE,CAEjB,IAAK,MAAMC,WAAWH,SAAU,CAC9B,IAAII,KAAOF,SAASG,IAAI,CAAC,IAAMF,QAG/B,MAAMG,WAAa,sBACnB,IAAIC,EACJ,MAAO,AAACA,CAAAA,EAAID,WAAWE,IAAI,CAACL,QAAO,IAAO,KAAM,CAC9C,GAAII,CAAC,CAAC,EAAE,GAAK,IAAK,CAChBL,SAASO,GAAG,EACd,KAAO,CACLP,SAASQ,IAAI,CAACH,CAAC,CAAC,EAAE,CACpB,CACF,CAGA,IAAK,IAAIV,EAAI,EAAGA,EAAIK,SAASS,MAAM,CAAEd,IAAK,CACxCO,MAAQ,SACV,CAEAH,OAAOS,IAAI,CAACN,KACd,CAEA,OAAOH,MACT,EAEA,MAAMW,uBAAyB,CAC7BC,SAAU,qBACVC,QAAS,oBACTtC,UAAW,qBACb,CAEA,QACEJ,gBAAgB,CAChBV,sBAAsB,CACtBkD,sBAAsB,CACtBlC,mBAAmB,CACnBZ,wBAAwB,CACxBgC,cAAc,CACd"}
@@ -0,0 +1,2 @@
1
+ import{describe,expect,it}from"vitest";import{splitHtmlLines,parseLineHighlights}from"./syntax-highlighter";describe("splitHtmlLines",()=>{it("splits plain text with no spans",()=>{expect(splitHtmlLines("hello\nworld")).toEqual(["hello","world"])});it("repairs a span crossing a line boundary",()=>{const html='<span class="a">hello\nworld</span>';expect(splitHtmlLines(html)).toEqual(['<span class="a">hello</span>','<span class="a">world</span>'])});it("handles close then open on the same line",()=>{const html='<span class="a">first\n</span><span class="b">second\nthird</span>';const result=splitHtmlLines(html);expect(result[0]).toBe('<span class="a">first</span>');expect(result[1]).toBe('<span class="a"></span><span class="b">second</span>');expect(result[2]).toBe('<span class="b">third</span>')});it("re-opens nested spans crossing lines",()=>{const html='<span class="a"><span class="b">text\nmore</span></span>';const result=splitHtmlLines(html);expect(result[0]).toBe('<span class="a"><span class="b">text</span></span>');expect(result[1]).toBe('<span class="a"><span class="b">more</span></span>')});it("preserves empty lines",()=>{expect(splitHtmlLines("line1\n\nline3")).toEqual(["line1","","line3"])});it("does not carry forward complete spans on one line",()=>{const html='<span class="a">x</span><span class="b">y</span>\nnext';expect(splitHtmlLines(html)).toEqual(['<span class="a">x</span><span class="b">y</span>',"next"])});it("handles a single line with no newlines",()=>{expect(splitHtmlLines('<span class="a">hello</span>')).toEqual(['<span class="a">hello</span>'])})});describe("parseLineHighlights",()=>{it("returns empty highlights when no meta is provided",()=>{expect(parseLineHighlights("javascript")).toEqual({lang:"javascript",highlights:{}})});it("parses addition ranges",()=>{const result=parseLineHighlights("js",'highlight="+1-3"');expect(result.highlights).toEqual({1:"addition",2:"addition",3:"addition"})});it("parses removal lines",()=>{const result=parseLineHighlights("js",'highlight="-5"');expect(result.highlights).toEqual({5:"removal"})});it("parses neutral highlight lines",()=>{const result=parseLineHighlights("js",'highlight="7"');expect(result.highlights).toEqual({7:"highlight"})});it("parses mixed specs",()=>{const result=parseLineHighlights("js",'highlight="+1-3,-5,7"');expect(result.highlights).toEqual({1:"addition",2:"addition",3:"addition",5:"removal",7:"highlight"})})});
2
+ //# sourceMappingURL=syntax-highlighter.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/core/utils/syntax-highlighter.test.js"],"sourcesContent":["import { describe, expect, it } from \"vitest\";\n\nimport { splitHtmlLines, parseLineHighlights } from \"./syntax-highlighter\";\n\ndescribe(\"splitHtmlLines\", () => {\n it(\"splits plain text with no spans\", () => {\n expect(splitHtmlLines(\"hello\\nworld\")).toEqual([\"hello\", \"world\"]);\n });\n\n it(\"repairs a span crossing a line boundary\", () => {\n const html = '<span class=\"a\">hello\\nworld</span>';\n expect(splitHtmlLines(html)).toEqual([\n '<span class=\"a\">hello</span>',\n '<span class=\"a\">world</span>',\n ]);\n });\n\n it(\"handles close then open on the same line\", () => {\n const html =\n '<span class=\"a\">first\\n</span><span class=\"b\">second\\nthird</span>';\n const result = splitHtmlLines(html);\n\n // Line 1: carries nothing, opens \"a\" → \"first\" with closing tag\n expect(result[0]).toBe('<span class=\"a\">first</span>');\n // Line 2: carries \"a\", raw line closes \"a\" then opens \"b\" → only \"b\" open\n expect(result[1]).toBe(\n '<span class=\"a\"></span><span class=\"b\">second</span>',\n );\n // Line 3: carries only \"b\"\n expect(result[2]).toBe('<span class=\"b\">third</span>');\n });\n\n it(\"re-opens nested spans crossing lines\", () => {\n const html = '<span class=\"a\"><span class=\"b\">text\\nmore</span></span>';\n const result = splitHtmlLines(html);\n expect(result[0]).toBe(\n '<span class=\"a\"><span class=\"b\">text</span></span>',\n );\n expect(result[1]).toBe(\n '<span class=\"a\"><span class=\"b\">more</span></span>',\n );\n });\n\n it(\"preserves empty lines\", () => {\n expect(splitHtmlLines(\"line1\\n\\nline3\")).toEqual([\"line1\", \"\", \"line3\"]);\n });\n\n it(\"does not carry forward complete spans on one line\", () => {\n const html = '<span class=\"a\">x</span><span class=\"b\">y</span>\\nnext';\n expect(splitHtmlLines(html)).toEqual([\n '<span class=\"a\">x</span><span class=\"b\">y</span>',\n \"next\",\n ]);\n });\n\n it(\"handles a single line with no newlines\", () => {\n expect(splitHtmlLines('<span class=\"a\">hello</span>')).toEqual([\n '<span class=\"a\">hello</span>',\n ]);\n });\n});\n\ndescribe(\"parseLineHighlights\", () => {\n it(\"returns empty highlights when no meta is provided\", () => {\n expect(parseLineHighlights(\"javascript\")).toEqual({\n lang: \"javascript\",\n highlights: {},\n });\n });\n\n it(\"parses addition ranges\", () => {\n const result = parseLineHighlights(\"js\", 'highlight=\"+1-3\"');\n expect(result.highlights).toEqual({\n 1: \"addition\",\n 2: \"addition\",\n 3: \"addition\",\n });\n });\n\n it(\"parses removal lines\", () => {\n const result = parseLineHighlights(\"js\", 'highlight=\"-5\"');\n expect(result.highlights).toEqual({ 5: \"removal\" });\n });\n\n it(\"parses neutral highlight lines\", () => {\n const result = parseLineHighlights(\"js\", 'highlight=\"7\"');\n expect(result.highlights).toEqual({ 7: \"highlight\" });\n });\n\n it(\"parses mixed specs\", () => {\n const result = parseLineHighlights(\"js\", 'highlight=\"+1-3,-5,7\"');\n expect(result.highlights).toEqual({\n 1: \"addition\",\n 2: \"addition\",\n 3: \"addition\",\n 5: \"removal\",\n 7: \"highlight\",\n });\n });\n});\n"],"names":["describe","expect","it","splitHtmlLines","parseLineHighlights","toEqual","html","result","toBe","lang","highlights"],"mappings":"AAAA,OAASA,QAAQ,CAAEC,MAAM,CAAEC,EAAE,KAAQ,QAAS,AAE9C,QAASC,cAAc,CAAEC,mBAAmB,KAAQ,sBAAuB,CAE3EJ,SAAS,iBAAkB,KACzBE,GAAG,kCAAmC,KACpCD,OAAOE,eAAe,iBAAiBE,OAAO,CAAC,CAAC,QAAS,QAAQ,CACnE,GAEAH,GAAG,0CAA2C,KAC5C,MAAMI,KAAO,sCACbL,OAAOE,eAAeG,OAAOD,OAAO,CAAC,CACnC,+BACA,+BACD,CACH,GAEAH,GAAG,2CAA4C,KAC7C,MAAMI,KACJ,qEACF,MAAMC,OAASJ,eAAeG,MAG9BL,OAAOM,MAAM,CAAC,EAAE,EAAEC,IAAI,CAAC,gCAEvBP,OAAOM,MAAM,CAAC,EAAE,EAAEC,IAAI,CACpB,wDAGFP,OAAOM,MAAM,CAAC,EAAE,EAAEC,IAAI,CAAC,+BACzB,GAEAN,GAAG,uCAAwC,KACzC,MAAMI,KAAO,2DACb,MAAMC,OAASJ,eAAeG,MAC9BL,OAAOM,MAAM,CAAC,EAAE,EAAEC,IAAI,CACpB,sDAEFP,OAAOM,MAAM,CAAC,EAAE,EAAEC,IAAI,CACpB,qDAEJ,GAEAN,GAAG,wBAAyB,KAC1BD,OAAOE,eAAe,mBAAmBE,OAAO,CAAC,CAAC,QAAS,GAAI,QAAQ,CACzE,GAEAH,GAAG,oDAAqD,KACtD,MAAMI,KAAO,yDACbL,OAAOE,eAAeG,OAAOD,OAAO,CAAC,CACnC,mDACA,OACD,CACH,GAEAH,GAAG,yCAA0C,KAC3CD,OAAOE,eAAe,iCAAiCE,OAAO,CAAC,CAC7D,+BACD,CACH,EACF,GAEAL,SAAS,sBAAuB,KAC9BE,GAAG,oDAAqD,KACtDD,OAAOG,oBAAoB,eAAeC,OAAO,CAAC,CAChDI,KAAM,aACNC,WAAY,CAAC,CACf,EACF,GAEAR,GAAG,yBAA0B,KAC3B,MAAMK,OAASH,oBAAoB,KAAM,oBACzCH,OAAOM,OAAOG,UAAU,EAAEL,OAAO,CAAC,CAChC,EAAG,WACH,EAAG,WACH,EAAG,UACL,EACF,GAEAH,GAAG,uBAAwB,KACzB,MAAMK,OAASH,oBAAoB,KAAM,kBACzCH,OAAOM,OAAOG,UAAU,EAAEL,OAAO,CAAC,CAAE,EAAG,SAAU,EACnD,GAEAH,GAAG,iCAAkC,KACnC,MAAMK,OAASH,oBAAoB,KAAM,iBACzCH,OAAOM,OAAOG,UAAU,EAAEL,OAAO,CAAC,CAAE,EAAG,WAAY,EACrD,GAEAH,GAAG,qBAAsB,KACvB,MAAMK,OAASH,oBAAoB,KAAM,yBACzCH,OAAOM,OAAOG,UAAU,EAAEL,OAAO,CAAC,CAChC,EAAG,WACH,EAAG,WACH,EAAG,WACH,EAAG,UACH,EAAG,WACL,EACF,EACF"}