@scalar/components 0.10.1 → 0.11.1

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 (245) hide show
  1. package/README.md +2 -76
  2. package/dist/_virtual/_plugin-vue_export-helper.js +9 -0
  3. package/dist/components/ScalarButton/ScalarButton.vue.js +51 -0
  4. package/dist/components/ScalarButton/ScalarButton.vue2.js +4 -0
  5. package/dist/components/ScalarButton/variants.js +40 -0
  6. package/dist/components/ScalarCodeBlock/ScalarCodeBlock.vue.js +28 -0
  7. package/dist/components/ScalarCodeBlock/ScalarCodeBlock.vue2.js +4 -0
  8. package/dist/components/ScalarCodeBlock/ScalarCodeBlock.vue3.js +5 -0
  9. package/dist/components/ScalarCodeBlock/utils/prettyPrintString.js +15 -0
  10. package/dist/components/ScalarCodeBlock/utils/replaceCircularReferences.js +18 -0
  11. package/dist/components/ScalarDropdown/ScalarDropdown.vue.js +51 -0
  12. package/dist/components/ScalarDropdown/ScalarDropdown.vue2.js +4 -0
  13. package/dist/components/ScalarDropdown/ScalarDropdownDivider.vue.js +10 -0
  14. package/dist/components/ScalarDropdown/ScalarDropdownItem.vue.js +42 -0
  15. package/dist/components/ScalarDropdown/ScalarDropdownItem.vue2.js +4 -0
  16. package/dist/components/ScalarFloating/ScalarFloating.vue.js +68 -0
  17. package/dist/components/ScalarFloating/ScalarFloating.vue2.js +4 -0
  18. package/dist/components/ScalarFloating/useResizeWithTarget.js +24 -0
  19. package/dist/components/ScalarIcon/ScalarIcon.vue.js +39 -0
  20. package/dist/components/ScalarIcon/ScalarIcon.vue2.js +4 -0
  21. package/dist/components/ScalarIcon/icons/Info.svg.js +16 -0
  22. package/dist/components/ScalarIcon/icons/index.js +8 -0
  23. package/dist/components/ScalarIconButton/ScalarIconButton.vue.js +46 -0
  24. package/dist/components/ScalarIconButton/ScalarIconButton.vue2.js +4 -0
  25. package/dist/components/ScalarListbox/ScalarListbox.vue.js +102 -0
  26. package/dist/components/ScalarListbox/ScalarListbox.vue2.js +4 -0
  27. package/dist/components/ScalarLoading/ScalarLoading.vue.js +9 -0
  28. package/dist/components/ScalarLoading/ScalarLoading.vue2.js +83 -0
  29. package/dist/components/ScalarLoading/ScalarLoading.vue3.js +4 -0
  30. package/dist/components/ScalarMarkdown/ScalarMarkdown.vue.js +25 -0
  31. package/dist/components/ScalarMarkdown/ScalarMarkdown.vue2.js +4 -0
  32. package/dist/components/ScalarModal/ScalarModal.vue.js +9 -0
  33. package/dist/components/ScalarModal/ScalarModal.vue2.js +108 -0
  34. package/dist/components/ScalarModal/ScalarModal.vue3.js +4 -0
  35. package/dist/components/ScalarPopover/ScalarPopover.vue.js +49 -0
  36. package/dist/components/ScalarPopover/ScalarPopover.vue2.js +4 -0
  37. package/dist/components/ScalarSearchInput/ScalarSearchInput.vue.js +62 -0
  38. package/dist/components/ScalarSearchInput/ScalarSearchInput.vue2.js +4 -0
  39. package/dist/components/ScalarSearchResults/ScalarSearchResultItem.vue.js +57 -0
  40. package/dist/components/ScalarSearchResults/ScalarSearchResultItem.vue2.js +4 -0
  41. package/dist/components/ScalarSearchResults/ScalarSearchResultList.vue.js +29 -0
  42. package/dist/components/ScalarSearchResults/ScalarSearchResultList.vue2.js +4 -0
  43. package/dist/components/ScalarTextField/ScalarTextField.vue.js +7 -0
  44. package/dist/components/ScalarTextField/ScalarTextField.vue2.js +107 -0
  45. package/dist/components/ScalarTextField/ScalarTextField.vue3.js +4 -0
  46. package/dist/cva.js +19 -0
  47. package/dist/helpers/sleep.js +4 -0
  48. package/dist/index.d.ts +92 -45
  49. package/dist/index.js +40 -1311
  50. package/dist/style.css +1 -1
  51. package/dist/tailwind/tailwind.css.js +4 -0
  52. package/package.json +16 -16
  53. package/dist/Add-BHOyatcf.cjs +0 -1
  54. package/dist/ArrowLeft-D0Lenmyx.cjs +0 -1
  55. package/dist/ArrowRight-CtFXKmN-.cjs +0 -1
  56. package/dist/Background-CC9MR0o5.cjs +0 -1
  57. package/dist/Brackets-BH2hJOrC.cjs +0 -1
  58. package/dist/Branch-DscqPJxw.cjs +0 -1
  59. package/dist/CallToAction-CH2urf5-.cjs +0 -1
  60. package/dist/Checkmark-zGf1EnxZ.cjs +0 -1
  61. package/dist/ChevronDown-BB1ECzOu.cjs +0 -1
  62. package/dist/ChevronLeft-B1fJRTS6.cjs +0 -1
  63. package/dist/ChevronRight-67haRaE0.cjs +0 -1
  64. package/dist/ChevronUp-DZmVf1ZI.cjs +0 -1
  65. package/dist/Clipboard-CMP6ZrLh.cjs +0 -1
  66. package/dist/Close-DqX2BfNh.cjs +0 -1
  67. package/dist/CodeFolder-1sbKUi4C.cjs +0 -1
  68. package/dist/Cookie-Dai0Vq-L.cjs +0 -1
  69. package/dist/DarkMode-YTngOyuf.cjs +0 -1
  70. package/dist/Delete-C5KJApGv.cjs +0 -1
  71. package/dist/Discord-bYns0mfM.cjs +0 -1
  72. package/dist/DocsPage-BUQM1ZP5.cjs +0 -1
  73. package/dist/Duplicate-BcpwaK9W.cjs +0 -1
  74. package/dist/Edit-B2Dib3l9.cjs +0 -1
  75. package/dist/Ellipses-lwFMwsvO.cjs +0 -1
  76. package/dist/Error-BEEilYrB.cjs +0 -1
  77. package/dist/ExternalLink-Cdev1TTT.cjs +0 -1
  78. package/dist/FilterList-Ch3lrlmt.cjs +0 -1
  79. package/dist/Folder-BDWpN5FK.cjs +0 -1
  80. package/dist/GitHub-DgVS74mp.cjs +0 -1
  81. package/dist/Hide-BpM8svWr.cjs +0 -1
  82. package/dist/History-CIjAbmel.cjs +0 -1
  83. package/dist/JsonObject-D-pZ81gx.cjs +0 -1
  84. package/dist/Key-C9vNtSgp.cjs +0 -1
  85. package/dist/Leave-DNKXl2pb.cjs +0 -1
  86. package/dist/LightDarkModeToggle-CK1SiK6S.cjs +0 -1
  87. package/dist/LightMode-CbktVjW4.cjs +0 -1
  88. package/dist/Link-NVOZGmsH.cjs +0 -1
  89. package/dist/Lock-CEwhrvWA.cjs +0 -1
  90. package/dist/Logo-CPK0sTGo.cjs +0 -1
  91. package/dist/LogoAPI-auvrtupZ.cjs +0 -1
  92. package/dist/LogoClient-DrkORYwm.cjs +0 -1
  93. package/dist/LogoMarket-Bpc5LKT8.cjs +0 -1
  94. package/dist/LogoSwagger-DezmPG0T.cjs +0 -1
  95. package/dist/Magic-D_nChUbo.cjs +0 -1
  96. package/dist/Menu-BMIM0ijJ.cjs +0 -1
  97. package/dist/Page-vHFXthOd.cjs +0 -1
  98. package/dist/PaperAirplane-CCHkYifV.cjs +0 -1
  99. package/dist/Payment-D0GqQgZi.cjs +0 -1
  100. package/dist/Play-D-MVpYlN.cjs +0 -1
  101. package/dist/Refresh-BW_PXJVB.cjs +0 -1
  102. package/dist/Response-kwZlQMN4.cjs +0 -1
  103. package/dist/Search-Bd6LPK9x.cjs +0 -1
  104. package/dist/Show-CGQdMeuP.cjs +0 -1
  105. package/dist/SideBarClosed-DvogXH7H.cjs +0 -1
  106. package/dist/SideBarOpen-C4lWzbws.cjs +0 -1
  107. package/dist/Sort-ownhPFMM.cjs +0 -1
  108. package/dist/Terminal-32pUnEJb.cjs +0 -1
  109. package/dist/ThumbsDown-CaDWC79Q.cjs +0 -1
  110. package/dist/ThumbsUp-2Uv5cZwr.cjs +0 -1
  111. package/dist/Trash-Cu7tKxXp.cjs +0 -1
  112. package/dist/Unlock-CNorWYJe.cjs +0 -1
  113. package/dist/Upload-jkvbAI71.cjs +0 -1
  114. package/dist/User-CTJkuv9t.cjs +0 -1
  115. package/dist/index.cjs +0 -1
  116. package/dist/prism-autoloader-Dlh8Vzlw.js +0 -370
  117. package/dist/prism-autoloader-hGN9n4IP.cjs +0 -1
  118. package/dist/programming-framework-angular-Cb3hOem2.cjs +0 -1
  119. package/dist/programming-framework-astro-CqzXmk7-.cjs +0 -1
  120. package/dist/programming-framework-laravel-DPR0ohMY.cjs +0 -1
  121. package/dist/programming-framework-nextdotjs-CEJkEXh_.cjs +0 -1
  122. package/dist/programming-framework-react-C8QbUlg2.cjs +0 -1
  123. package/dist/programming-framework-vuedotjs-CfbQc23o.cjs +0 -1
  124. package/dist/programming-language-c-D_xNi2oU.cjs +0 -1
  125. package/dist/programming-language-clojure-C5dOsI4K.cjs +0 -1
  126. package/dist/programming-language-csharp-BHivZJkg.cjs +0 -1
  127. package/dist/programming-language-css3-wgDmqbZB.cjs +0 -1
  128. package/dist/programming-language-go-BjshiBx9.cjs +0 -1
  129. package/dist/programming-language-html5-CtUUccLl.cjs +0 -1
  130. package/dist/programming-language-http-Dz4cvjKh.cjs +0 -1
  131. package/dist/programming-language-java-d4f1Y0fu.cjs +0 -1
  132. package/dist/programming-language-javascript-BV0cufZy.cjs +0 -1
  133. package/dist/programming-language-json-D4cFxPs5.cjs +0 -1
  134. package/dist/programming-language-kotlin-eKkN_tOl.cjs +0 -1
  135. package/dist/programming-language-node-CFlS5cG5.cjs +0 -1
  136. package/dist/programming-language-objc-B5s5jkUH.cjs +0 -1
  137. package/dist/programming-language-ocaml-COhyM4XA.cjs +0 -1
  138. package/dist/programming-language-php-L-yPjdeD.cjs +0 -1
  139. package/dist/programming-language-powershell-CETg5mF_.cjs +0 -1
  140. package/dist/programming-language-python-D81TlBUm.cjs +0 -1
  141. package/dist/programming-language-r-BA21GfCv.cjs +0 -1
  142. package/dist/programming-language-ruby-CZdOfp80.cjs +0 -1
  143. package/dist/programming-language-scala-DXPi3PgB.cjs +0 -1
  144. package/dist/programming-language-shell-C5XFKH1k.cjs +0 -1
  145. package/dist/programming-language-swift-ARCBHgkE.cjs +0 -1
  146. package/dist/programming-language-typescript-DCLuAk73.cjs +0 -1
  147. package/dist/programming-script-code-DbeLXUtP.cjs +0 -1
  148. package/dist/programming-tool-git-D92HKo9l.cjs +0 -1
  149. package/dist/programming-tool-tailwindcss-Cog36cMC.cjs +0 -1
  150. package/src/tailwind/index.ts +0 -1
  151. package/src/tailwind/tailwind.theme.ts +0 -82
  152. /package/dist/{Add-yNxGpRcH.js → components/ScalarIcon/icons/Add.svg.js} +0 -0
  153. /package/dist/{ArrowLeft-D7tW1xQo.js → components/ScalarIcon/icons/ArrowLeft.svg.js} +0 -0
  154. /package/dist/{ArrowRight-DmO-sdb2.js → components/ScalarIcon/icons/ArrowRight.svg.js} +0 -0
  155. /package/dist/{Background-CU9VIbfN.js → components/ScalarIcon/icons/Background.svg.js} +0 -0
  156. /package/dist/{Brackets-CI207-BL.js → components/ScalarIcon/icons/Brackets.svg.js} +0 -0
  157. /package/dist/{Branch-CXwj8YuG.js → components/ScalarIcon/icons/Branch.svg.js} +0 -0
  158. /package/dist/{CallToAction-XLYRSI1h.js → components/ScalarIcon/icons/CallToAction.svg.js} +0 -0
  159. /package/dist/{Checkmark-DhbrPM0P.js → components/ScalarIcon/icons/Checkmark.svg.js} +0 -0
  160. /package/dist/{ChevronDown-Co7EAKAv.js → components/ScalarIcon/icons/ChevronDown.svg.js} +0 -0
  161. /package/dist/{ChevronLeft-DYt0idAu.js → components/ScalarIcon/icons/ChevronLeft.svg.js} +0 -0
  162. /package/dist/{ChevronRight-ylxToVWl.js → components/ScalarIcon/icons/ChevronRight.svg.js} +0 -0
  163. /package/dist/{ChevronUp-xAnukIfj.js → components/ScalarIcon/icons/ChevronUp.svg.js} +0 -0
  164. /package/dist/{Clipboard-CU_KxGEv.js → components/ScalarIcon/icons/Clipboard.svg.js} +0 -0
  165. /package/dist/{Close-xHiYwS8Q.js → components/ScalarIcon/icons/Close.svg.js} +0 -0
  166. /package/dist/{CodeFolder-Cv_igzJE.js → components/ScalarIcon/icons/CodeFolder.svg.js} +0 -0
  167. /package/dist/{Cookie-CEHvXpqB.js → components/ScalarIcon/icons/Cookie.svg.js} +0 -0
  168. /package/dist/{DarkMode-BMR457PH.js → components/ScalarIcon/icons/DarkMode.svg.js} +0 -0
  169. /package/dist/{Delete-BCZmxrDD.js → components/ScalarIcon/icons/Delete.svg.js} +0 -0
  170. /package/dist/{Discord-BHYOFBB2.js → components/ScalarIcon/icons/Discord.svg.js} +0 -0
  171. /package/dist/{DocsPage-Dwx7ZMU9.js → components/ScalarIcon/icons/DocsPage.svg.js} +0 -0
  172. /package/dist/{Duplicate-DRWEv4R_.js → components/ScalarIcon/icons/Duplicate.svg.js} +0 -0
  173. /package/dist/{Edit-Br04RNYb.js → components/ScalarIcon/icons/Edit.svg.js} +0 -0
  174. /package/dist/{Ellipses-Bo_X36Hx.js → components/ScalarIcon/icons/Ellipses.svg.js} +0 -0
  175. /package/dist/{Error-C5LiISnw.js → components/ScalarIcon/icons/Error.svg.js} +0 -0
  176. /package/dist/{ExternalLink-DK8L-EH7.js → components/ScalarIcon/icons/ExternalLink.svg.js} +0 -0
  177. /package/dist/{FilterList-CS8Il7NE.js → components/ScalarIcon/icons/FilterList.svg.js} +0 -0
  178. /package/dist/{Folder-CTvnVSEo.js → components/ScalarIcon/icons/Folder.svg.js} +0 -0
  179. /package/dist/{GitHub-NdE6Zs9k.js → components/ScalarIcon/icons/GitHub.svg.js} +0 -0
  180. /package/dist/{Hide-BgcCtErz.js → components/ScalarIcon/icons/Hide.svg.js} +0 -0
  181. /package/dist/{History-D9nmhNIn.js → components/ScalarIcon/icons/History.svg.js} +0 -0
  182. /package/dist/{JsonObject-hGdHUQ4M.js → components/ScalarIcon/icons/JsonObject.svg.js} +0 -0
  183. /package/dist/{Key-CWXJqX28.js → components/ScalarIcon/icons/Key.svg.js} +0 -0
  184. /package/dist/{Leave-K1J3uwoG.js → components/ScalarIcon/icons/Leave.svg.js} +0 -0
  185. /package/dist/{LightDarkModeToggle-De3vO47x.js → components/ScalarIcon/icons/LightDarkModeToggle.svg.js} +0 -0
  186. /package/dist/{LightMode-BeoMphBY.js → components/ScalarIcon/icons/LightMode.svg.js} +0 -0
  187. /package/dist/{Link-Bzuc__Nc.js → components/ScalarIcon/icons/Link.svg.js} +0 -0
  188. /package/dist/{Lock-xhiH1mKz.js → components/ScalarIcon/icons/Lock.svg.js} +0 -0
  189. /package/dist/{Logo-DwEDtgj-.js → components/ScalarIcon/icons/Logo.svg.js} +0 -0
  190. /package/dist/{LogoAPI-CohCfL3L.js → components/ScalarIcon/icons/LogoAPI.svg.js} +0 -0
  191. /package/dist/{LogoClient-Bq5O2QL2.js → components/ScalarIcon/icons/LogoClient.svg.js} +0 -0
  192. /package/dist/{LogoMarket-DwlApcab.js → components/ScalarIcon/icons/LogoMarket.svg.js} +0 -0
  193. /package/dist/{LogoSwagger-CH60H5qW.js → components/ScalarIcon/icons/LogoSwagger.svg.js} +0 -0
  194. /package/dist/{Magic-Dsi9_bEc.js → components/ScalarIcon/icons/Magic.svg.js} +0 -0
  195. /package/dist/{Menu-CFK5cOsm.js → components/ScalarIcon/icons/Menu.svg.js} +0 -0
  196. /package/dist/{Page-DA7CO5gc.js → components/ScalarIcon/icons/Page.svg.js} +0 -0
  197. /package/dist/{PaperAirplane-BC-4mGEB.js → components/ScalarIcon/icons/PaperAirplane.svg.js} +0 -0
  198. /package/dist/{Payment-hzcXP1Xb.js → components/ScalarIcon/icons/Payment.svg.js} +0 -0
  199. /package/dist/{Play-Cd4-o7Ji.js → components/ScalarIcon/icons/Play.svg.js} +0 -0
  200. /package/dist/{Refresh-BHRzzQ8P.js → components/ScalarIcon/icons/Refresh.svg.js} +0 -0
  201. /package/dist/{Response-DsTlT4S-.js → components/ScalarIcon/icons/Response.svg.js} +0 -0
  202. /package/dist/{Search-DqtlswRG.js → components/ScalarIcon/icons/Search.svg.js} +0 -0
  203. /package/dist/{Show-CbiiMLUa.js → components/ScalarIcon/icons/Show.svg.js} +0 -0
  204. /package/dist/{SideBarClosed-K53-CtXh.js → components/ScalarIcon/icons/SideBarClosed.svg.js} +0 -0
  205. /package/dist/{SideBarOpen-C7UgT82P.js → components/ScalarIcon/icons/SideBarOpen.svg.js} +0 -0
  206. /package/dist/{Sort-CaVMT7jM.js → components/ScalarIcon/icons/Sort.svg.js} +0 -0
  207. /package/dist/{Terminal-DJ7x2McL.js → components/ScalarIcon/icons/Terminal.svg.js} +0 -0
  208. /package/dist/{ThumbsDown-BMgnsASL.js → components/ScalarIcon/icons/ThumbsDown.svg.js} +0 -0
  209. /package/dist/{ThumbsUp-C1j6zY2j.js → components/ScalarIcon/icons/ThumbsUp.svg.js} +0 -0
  210. /package/dist/{Trash-BpA3zWPD.js → components/ScalarIcon/icons/Trash.svg.js} +0 -0
  211. /package/dist/{Unlock-HVYHMLxl.js → components/ScalarIcon/icons/Unlock.svg.js} +0 -0
  212. /package/dist/{Upload-D_pwqBDY.js → components/ScalarIcon/icons/Upload.svg.js} +0 -0
  213. /package/dist/{User-BLGkPc5I.js → components/ScalarIcon/icons/User.svg.js} +0 -0
  214. /package/dist/{programming-framework-angular-DD4Vjgbk.js → components/ScalarIcon/icons/programming-framework-angular.svg.js} +0 -0
  215. /package/dist/{programming-framework-astro-CLfrRt19.js → components/ScalarIcon/icons/programming-framework-astro.svg.js} +0 -0
  216. /package/dist/{programming-framework-laravel-kAy2wVLy.js → components/ScalarIcon/icons/programming-framework-laravel.svg.js} +0 -0
  217. /package/dist/{programming-framework-nextdotjs-BKdd_DY_.js → components/ScalarIcon/icons/programming-framework-nextdotjs.svg.js} +0 -0
  218. /package/dist/{programming-framework-react-PDgmtZuN.js → components/ScalarIcon/icons/programming-framework-react.svg.js} +0 -0
  219. /package/dist/{programming-framework-vuedotjs-Cim7D5tw.js → components/ScalarIcon/icons/programming-framework-vuedotjs.svg.js} +0 -0
  220. /package/dist/{programming-language-c-hPGu2Zvg.js → components/ScalarIcon/icons/programming-language-c.svg.js} +0 -0
  221. /package/dist/{programming-language-clojure-uqYXn7U6.js → components/ScalarIcon/icons/programming-language-clojure.svg.js} +0 -0
  222. /package/dist/{programming-language-csharp-CGxYkVA6.js → components/ScalarIcon/icons/programming-language-csharp.svg.js} +0 -0
  223. /package/dist/{programming-language-css3-Dpp4Cr6b.js → components/ScalarIcon/icons/programming-language-css3.svg.js} +0 -0
  224. /package/dist/{programming-language-go-CuKo8iD9.js → components/ScalarIcon/icons/programming-language-go.svg.js} +0 -0
  225. /package/dist/{programming-language-html5-DlqJK4EL.js → components/ScalarIcon/icons/programming-language-html5.svg.js} +0 -0
  226. /package/dist/{programming-language-http-f3NXC-Ae.js → components/ScalarIcon/icons/programming-language-http.svg.js} +0 -0
  227. /package/dist/{programming-language-java-BBodetdf.js → components/ScalarIcon/icons/programming-language-java.svg.js} +0 -0
  228. /package/dist/{programming-language-javascript-VxLvi1QG.js → components/ScalarIcon/icons/programming-language-javascript.svg.js} +0 -0
  229. /package/dist/{programming-language-json-Dq_K-q5f.js → components/ScalarIcon/icons/programming-language-json.svg.js} +0 -0
  230. /package/dist/{programming-language-kotlin-eTASnmL3.js → components/ScalarIcon/icons/programming-language-kotlin.svg.js} +0 -0
  231. /package/dist/{programming-language-node-oucaVOgY.js → components/ScalarIcon/icons/programming-language-node.svg.js} +0 -0
  232. /package/dist/{programming-language-objc-CPgQxmNi.js → components/ScalarIcon/icons/programming-language-objc.svg.js} +0 -0
  233. /package/dist/{programming-language-ocaml-Q1-Jv5Q5.js → components/ScalarIcon/icons/programming-language-ocaml.svg.js} +0 -0
  234. /package/dist/{programming-language-php-GY38f8r4.js → components/ScalarIcon/icons/programming-language-php.svg.js} +0 -0
  235. /package/dist/{programming-language-powershell-xLOxAYP_.js → components/ScalarIcon/icons/programming-language-powershell.svg.js} +0 -0
  236. /package/dist/{programming-language-python-Ct-_kNjo.js → components/ScalarIcon/icons/programming-language-python.svg.js} +0 -0
  237. /package/dist/{programming-language-r-Ch3T1qiC.js → components/ScalarIcon/icons/programming-language-r.svg.js} +0 -0
  238. /package/dist/{programming-language-ruby-DhdM4d7g.js → components/ScalarIcon/icons/programming-language-ruby.svg.js} +0 -0
  239. /package/dist/{programming-language-scala-BVg0dToJ.js → components/ScalarIcon/icons/programming-language-scala.svg.js} +0 -0
  240. /package/dist/{programming-language-shell-uj1zoCVW.js → components/ScalarIcon/icons/programming-language-shell.svg.js} +0 -0
  241. /package/dist/{programming-language-swift-Dn72xPjg.js → components/ScalarIcon/icons/programming-language-swift.svg.js} +0 -0
  242. /package/dist/{programming-language-typescript-CdF-HuRi.js → components/ScalarIcon/icons/programming-language-typescript.svg.js} +0 -0
  243. /package/dist/{programming-script-code-CUHv6qR8.js → components/ScalarIcon/icons/programming-script-code.svg.js} +0 -0
  244. /package/dist/{programming-tool-git-C-BMJCAo.js → components/ScalarIcon/icons/programming-tool-git.svg.js} +0 -0
  245. /package/dist/{programming-tool-tailwindcss-xjXi0E6g.js → components/ScalarIcon/icons/programming-tool-tailwindcss.svg.js} +0 -0
@@ -0,0 +1,102 @@
1
+ import { defineComponent as b, openBlock as i, createBlock as d, unref as t, withCtx as s, createVNode as a, mergeProps as x, createElementBlock as v, Fragment as g, renderList as y, createElementVNode as o, normalizeClass as m, toDisplayString as _, renderSlot as h } from "vue";
2
+ import { Listbox as V, ListboxOptions as k, ListboxOption as z, ListboxButton as B } from "@headlessui/vue";
3
+ import { cva as w, cx as L } from "../../cva.js";
4
+ import O from "../ScalarFloating/ScalarFloating.vue.js";
5
+ import $ from "../ScalarIcon/ScalarIcon.vue.js";
6
+ const C = { class: "inline-block min-w-0 flex-1 truncate text-c-1" }, S = /* @__PURE__ */ o("div", { class: "absolute inset-0 -z-1 rounded bg-b-1 shadow-md brightness-lifted" }, null, -1), P = /* @__PURE__ */ b({
7
+ inheritAttrs: !1,
8
+ __name: "ScalarListbox",
9
+ props: {
10
+ options: {},
11
+ modelValue: {},
12
+ placement: {},
13
+ resize: { type: Boolean },
14
+ isOpen: { type: Boolean },
15
+ teleport: { type: Boolean }
16
+ },
17
+ emits: ["update:modelValue"],
18
+ setup(E) {
19
+ const u = w({
20
+ base: [
21
+ // Layout
22
+ "group",
23
+ "text-lef flex min-w-0 items-center gap-1.5 rounded px-2 py-1.5",
24
+ "first-of-type:mt-0.75 last-of-type:mb-0.75",
25
+ // Text / background style
26
+ "truncate bg-transparent text-c-1",
27
+ // Interaction
28
+ "cursor-pointer hover:bg-b-2"
29
+ ],
30
+ variants: {
31
+ selected: { true: "text-c-1" },
32
+ active: { true: "bg-b-2" },
33
+ disabled: { true: "pointer-events-none opacity-50" }
34
+ }
35
+ });
36
+ return (e, n) => (i(), d(t(V), {
37
+ as: "div",
38
+ class: "text-xs",
39
+ modelValue: e.modelValue,
40
+ "onUpdate:modelValue": n[0] || (n[0] = (r) => e.$emit("update:modelValue", r))
41
+ }, {
42
+ default: s(({ open: r }) => [
43
+ a(t(O), {
44
+ isOpen: r ?? e.isOpen,
45
+ placement: e.placement ?? "bottom-start",
46
+ resize: e.resize,
47
+ teleport: e.teleport
48
+ }, {
49
+ floating: s(({ width: c }) => [
50
+ a(t(k), x({
51
+ class: "relative flex w-40 flex-col p-0.75",
52
+ style: { width: c }
53
+ }, e.$attrs), {
54
+ default: s(() => [
55
+ (i(!0), v(g, null, y(e.options, (l) => (i(), d(t(z), {
56
+ key: l.id,
57
+ as: "template",
58
+ disabled: l.disabled,
59
+ value: l
60
+ }, {
61
+ default: s(({ active: f, selected: p }) => [
62
+ o("li", {
63
+ class: m(
64
+ t(L)(t(u)({ active: f, selected: p, disabled: l.disabled }))
65
+ )
66
+ }, [
67
+ o("div", {
68
+ class: m(["flex size-4 items-center justify-center rounded-full p-[3px] group-hover:shadow-border", p ? "bg-blue text-b-1" : "text-transparent"])
69
+ }, [
70
+ a(t($), {
71
+ class: "relative top-[0.5px] size-2.5 stroke-[1.75]",
72
+ icon: "Checkmark"
73
+ })
74
+ ], 2),
75
+ o("span", C, _(l.label), 1)
76
+ ], 2)
77
+ ]),
78
+ _: 2
79
+ }, 1032, ["disabled", "value"]))), 128)),
80
+ S
81
+ ]),
82
+ _: 2
83
+ }, 1040, ["style"])
84
+ ]),
85
+ default: s(() => [
86
+ a(t(B), { as: "template" }, {
87
+ default: s(() => [
88
+ h(e.$slots, "default")
89
+ ]),
90
+ _: 3
91
+ })
92
+ ]),
93
+ _: 2
94
+ }, 1032, ["isOpen", "placement", "resize", "teleport"])
95
+ ]),
96
+ _: 3
97
+ }, 8, ["modelValue"]));
98
+ }
99
+ });
100
+ export {
101
+ P as default
102
+ };
@@ -0,0 +1,4 @@
1
+ import f from "./ScalarListbox.vue.js";
2
+ export {
3
+ f as default
4
+ };
@@ -0,0 +1,9 @@
1
+ import o from "./ScalarLoading.vue2.js";
2
+ import { useLoadingState as c } from "./ScalarLoading.vue2.js";
3
+ import "./ScalarLoading.vue3.js";
4
+ import a from "../../_virtual/_plugin-vue_export-helper.js";
5
+ const f = /* @__PURE__ */ a(o, [["__scopeId", "data-v-47faceda"]]);
6
+ export {
7
+ f as default,
8
+ c as useLoadingState
9
+ };
@@ -0,0 +1,83 @@
1
+ import { defineComponent as r, useCssVars as n, openBlock as s, createElementBlock as i, normalizeClass as l, unref as o, createElementVNode as c, createCommentVNode as d, createStaticVNode as h, reactive as p } from "vue";
2
+ import { cx as g } from "../../cva.js";
3
+ const m = /* @__PURE__ */ h('<path class="svg-path svg-check-mark" d="m 0 60 l 30 30 l 70 -80" data-v-47faceda></path><path class="svg-path svg-x-mark" d="m 50 50 l 40 -40" data-v-47faceda></path><path class="svg-path svg-x-mark" d="m 50 50 l 40 40" data-v-47faceda></path><path class="svg-path svg-x-mark" d="m 50 50 l -40 -40" data-v-47faceda></path><path class="svg-path svg-x-mark" d="m 50 50 l -40 40" data-v-47faceda></path>', 5), v = {
4
+ key: 0,
5
+ class: "circular-loader"
6
+ };
7
+ function w() {
8
+ return p({
9
+ isValid: !1,
10
+ isInvalid: !1,
11
+ isLoading: !1,
12
+ startLoading() {
13
+ this.isLoading = !0;
14
+ },
15
+ stopLoading() {
16
+ this.isLoading = !1;
17
+ },
18
+ validate(e = 800) {
19
+ this.isValid = !0;
20
+ const a = e - 300;
21
+ return new Promise(
22
+ (t) => setTimeout(() => this.clear().then(() => t(!0)), a)
23
+ );
24
+ },
25
+ invalidate(e = 1100) {
26
+ this.isInvalid = !0;
27
+ const a = e - 300;
28
+ return new Promise(
29
+ (t) => setTimeout(() => this.clear().then(() => t(!0)), a)
30
+ );
31
+ },
32
+ clear(e = 300) {
33
+ return this.isValid = !1, this.isInvalid = !1, this.isLoading = !1, new Promise((a) => {
34
+ setTimeout(() => {
35
+ a(!0);
36
+ }, e);
37
+ });
38
+ }
39
+ });
40
+ }
41
+ const k = /* @__PURE__ */ r({
42
+ __name: "ScalarLoading",
43
+ props: {
44
+ loadingState: {},
45
+ size: { default: "24px" }
46
+ },
47
+ setup(e) {
48
+ return n((a) => ({
49
+ d6cae758: a.size
50
+ })), (a, t) => a.loadingState ? (s(), i("div", {
51
+ key: 0,
52
+ class: l(o(g)("loader-wrapper"))
53
+ }, [
54
+ (s(), i("svg", {
55
+ class: l(["svg-loader", {
56
+ "icon-is-valid": a.loadingState.isValid,
57
+ "icon-is-invalid": a.loadingState.isInvalid
58
+ }]),
59
+ viewBox: "0 0 100 100",
60
+ xmlns: "http://www.w3.org/2000/svg",
61
+ "xmlns:xlink": "http://www.w3.org/1999/xlink"
62
+ }, [
63
+ m,
64
+ a.loadingState.isLoading ? (s(), i("g", v, [
65
+ c("circle", {
66
+ class: l(["loader-path", {
67
+ "loader-path-off": a.loadingState.isValid || a.loadingState.isInvalid
68
+ }]),
69
+ cx: "50",
70
+ cy: "50",
71
+ fill: "none",
72
+ r: "20",
73
+ "stroke-width": "2"
74
+ }, null, 2)
75
+ ])) : d("", !0)
76
+ ], 2))
77
+ ], 2)) : d("", !0);
78
+ }
79
+ });
80
+ export {
81
+ k as default,
82
+ w as useLoadingState
83
+ };
@@ -0,0 +1,4 @@
1
+ const e = "";
2
+ export {
3
+ e as default
4
+ };
@@ -0,0 +1,25 @@
1
+ import { defineComponent as r, computed as a, onServerPrefetch as n, openBlock as m, createElementBlock as s } from "vue";
2
+ import { htmlFromMarkdown as c } from "@scalar/code-highlight";
3
+ import "@scalar/code-highlight/css/markdown.css";
4
+ import { sleep as l } from "../../helpers/sleep.js";
5
+ const p = ["innerHTML"], v = /* @__PURE__ */ r({
6
+ __name: "ScalarMarkdown",
7
+ props: {
8
+ value: {},
9
+ withImages: { type: Boolean, default: !1 }
10
+ },
11
+ setup(o) {
12
+ const e = o, t = a(
13
+ () => c(e.value ?? "", {
14
+ removeTags: e.withImages ? [] : ["img", "picture"]
15
+ })
16
+ );
17
+ return n(async () => await l(1)), (i, u) => (m(), s("div", {
18
+ class: "markdown",
19
+ innerHTML: t.value
20
+ }, null, 8, p));
21
+ }
22
+ });
23
+ export {
24
+ v as default
25
+ };
@@ -0,0 +1,4 @@
1
+ import f from "./ScalarMarkdown.vue.js";
2
+ export {
3
+ f as default
4
+ };
@@ -0,0 +1,9 @@
1
+ import o from "./ScalarModal.vue2.js";
2
+ import { useModal as s } from "./ScalarModal.vue2.js";
3
+ import "./ScalarModal.vue3.js";
4
+ import r from "../../_virtual/_plugin-vue_export-helper.js";
5
+ const m = /* @__PURE__ */ r(o, [["__scopeId", "data-v-f4327857"]]);
6
+ export {
7
+ m as default,
8
+ s as useModal
9
+ };
@@ -0,0 +1,108 @@
1
+ import { defineComponent as c, openBlock as l, createBlock as s, unref as a, withCtx as o, createElementVNode as f, normalizeClass as t, createVNode as u, normalizeStyle as v, createTextVNode as h, toDisplayString as y, createCommentVNode as b, createElementBlock as g, renderSlot as i, reactive as x } from "vue";
2
+ import { Dialog as w, DialogPanel as z, DialogTitle as C, DialogDescription as k } from "@headlessui/vue";
3
+ import { cva as d, cx as n } from "../../cva.js";
4
+ const W = () => x({
5
+ open: !1,
6
+ show() {
7
+ this.open = !0;
8
+ },
9
+ hide() {
10
+ this.open = !1;
11
+ }
12
+ }), $ = /* @__PURE__ */ c({
13
+ __name: "ScalarModal",
14
+ props: {
15
+ state: {},
16
+ title: {},
17
+ bodyClass: {},
18
+ maxWidth: {},
19
+ size: { default: "md" },
20
+ variant: {}
21
+ },
22
+ setup(D) {
23
+ const m = d({
24
+ base: [
25
+ "scalar-modal",
26
+ "col relative mx-auto mb-0 mt-20 w-full rounded-lg bg-b-2 text-left leading-snug text-c-1 opacity-0"
27
+ ].join(" "),
28
+ variants: {
29
+ size: {
30
+ xs: "max-w-screen-xs",
31
+ sm: "max-w-screen-sm",
32
+ md: "max-w-screen-md",
33
+ lg: "max-w-screen-lg",
34
+ full: "mt-0 overflow-hidden"
35
+ },
36
+ variant: {
37
+ history: "scalar-modal-history bg-b-1",
38
+ search: "scalar-modal-search"
39
+ }
40
+ }
41
+ }), p = d({
42
+ base: [
43
+ "scalar-modal-body",
44
+ "relative max-h-[calc(100dvh-240px)] overflow-y-auto rounded-lg bg-b-1 px-6 pb-4 pt-6"
45
+ ].join(" "),
46
+ variants: {
47
+ variant: {
48
+ history: "pt-3",
49
+ search: "col max-h-[440px] overflow-hidden p-0"
50
+ }
51
+ }
52
+ });
53
+ return (e, r) => (l(), s(a(w), {
54
+ open: e.state.open,
55
+ onClose: r[0] || (r[0] = (B) => e.state.hide())
56
+ }, {
57
+ default: o(() => [
58
+ f("div", {
59
+ class: t(
60
+ a(n)(
61
+ "scalar-modal-layout fixed left-0 top-0",
62
+ "z-[1001] h-[100dvh] w-[100dvw]",
63
+ "bg-backdrop opacity-0",
64
+ e.size === "full" && "flex"
65
+ )
66
+ )
67
+ }, [
68
+ u(a(z), {
69
+ class: t(a(m)({ size: e.size, variant: e.variant })),
70
+ style: v({ maxWidth: e.maxWidth })
71
+ }, {
72
+ default: o(() => [
73
+ e.title ? (l(), s(a(C), {
74
+ key: 0,
75
+ class: t(["scalar-modal-header font-semiBold m-0 rounded-lg px-6 py-3 text-left text-xs text-c-1", { "pb-0 pt-6": e.variant === "history" }])
76
+ }, {
77
+ default: o(() => [
78
+ h(y(e.title), 1)
79
+ ]),
80
+ _: 1
81
+ }, 8, ["class"])) : b("", !0),
82
+ e.size === "full" ? (l(), g("div", {
83
+ key: 1,
84
+ class: t(e.bodyClass)
85
+ }, [
86
+ i(e.$slots, "default", {}, void 0, !0)
87
+ ], 2)) : (l(), s(a(k), {
88
+ key: 2,
89
+ class: t(a(n)(e.bodyClass, a(p)({ variant: e.variant })))
90
+ }, {
91
+ default: o(() => [
92
+ i(e.$slots, "default", {}, void 0, !0)
93
+ ]),
94
+ _: 3
95
+ }, 8, ["class"]))
96
+ ]),
97
+ _: 3
98
+ }, 8, ["class", "style"])
99
+ ], 2)
100
+ ]),
101
+ _: 3
102
+ }, 8, ["open"]));
103
+ }
104
+ });
105
+ export {
106
+ $ as default,
107
+ W as useModal
108
+ };
@@ -0,0 +1,4 @@
1
+ const _ = "";
2
+ export {
3
+ _ as default
4
+ };
@@ -0,0 +1,49 @@
1
+ import { defineComponent as i, openBlock as f, createBlock as d, unref as t, withCtx as o, createVNode as l, mergeProps as r, renderSlot as s, createElementVNode as u } from "vue";
2
+ import { Popover as m, PopoverPanel as c, PopoverButton as _ } from "@headlessui/vue";
3
+ import v from "../ScalarFloating/ScalarFloating.vue.js";
4
+ const h = /* @__PURE__ */ u("div", { class: "absolute inset-0 -z-1 rounded bg-b-1 shadow-lg brightness-lifted" }, null, -1), b = /* @__PURE__ */ i({
5
+ inheritAttrs: !1,
6
+ __name: "ScalarPopover",
7
+ props: {
8
+ placement: {},
9
+ resize: { type: Boolean },
10
+ isOpen: { type: Boolean },
11
+ teleport: { type: Boolean }
12
+ },
13
+ setup(B) {
14
+ return (e, P) => (f(), d(t(m), null, {
15
+ default: o(({ open: p }) => [
16
+ l(t(v), r(e.$props, {
17
+ isOpen: p ?? e.isOpen,
18
+ teleport: e.teleport
19
+ }), {
20
+ floating: o(({ width: a, height: n }) => [
21
+ l(t(c), r({
22
+ class: "relative flex flex-col p-0.75",
23
+ style: { width: a, height: n }
24
+ }, e.$attrs), {
25
+ default: o(() => [
26
+ s(e.$slots, "popover"),
27
+ h
28
+ ]),
29
+ _: 2
30
+ }, 1040, ["style"])
31
+ ]),
32
+ default: o(() => [
33
+ l(t(_), { as: "template" }, {
34
+ default: o(() => [
35
+ s(e.$slots, "default")
36
+ ]),
37
+ _: 3
38
+ })
39
+ ]),
40
+ _: 2
41
+ }, 1040, ["isOpen", "teleport"])
42
+ ]),
43
+ _: 3
44
+ }));
45
+ }
46
+ });
47
+ export {
48
+ b as default
49
+ };
@@ -0,0 +1,4 @@
1
+ import f from "./ScalarPopover.vue.js";
2
+ export {
3
+ f as default
4
+ };
@@ -0,0 +1,62 @@
1
+ import { defineComponent as d, computed as m, useAttrs as i, openBlock as a, createElementBlock as p, mergeProps as f, unref as l, createElementVNode as n, renderSlot as g, createTextVNode as h, createBlock as s, createCommentVNode as V } from "vue";
2
+ import { cx as b } from "../../cva.js";
3
+ import S from "../ScalarLoading/ScalarLoading.vue.js";
4
+ import k from "../ScalarIconButton/ScalarIconButton.vue.js";
5
+ const v = { class: "sr-only" }, N = ["value"], E = /* @__PURE__ */ d({
6
+ inheritAttrs: !1,
7
+ __name: "ScalarSearchInput",
8
+ props: {
9
+ loading: {},
10
+ modelValue: {}
11
+ },
12
+ emits: ["update:modelValue"],
13
+ setup(_, { emit: c }) {
14
+ const o = c;
15
+ function u(e) {
16
+ o("update:modelValue", e.target.value);
17
+ }
18
+ const r = m(() => {
19
+ const { class: e, ...t } = i();
20
+ return { className: e || "", rest: t };
21
+ });
22
+ return (e, t) => (a(), p("label", f(r.value.rest, {
23
+ class: l(b)(
24
+ "flex rounded border bg-b-1 text-sm font-medium focus-within:border-c-1",
25
+ r.value.className
26
+ )
27
+ }), [
28
+ n("span", v, [
29
+ g(e.$slots, "label", {}, () => [
30
+ h("Enter search")
31
+ ])
32
+ ]),
33
+ n("input", {
34
+ autocapitalize: "off",
35
+ autocomplete: "off",
36
+ autocorrect: "off",
37
+ class: "flex-1 rounded bg-transparent p-3 outline-none",
38
+ placeholder: "Search...",
39
+ spellcheck: "false",
40
+ type: "text",
41
+ value: e.modelValue,
42
+ onInput: u
43
+ }, null, 40, N),
44
+ e.loading && e.loading.isLoading ? (a(), s(l(S), {
45
+ key: 0,
46
+ class: "mr-3 self-center",
47
+ loadingState: e.loading,
48
+ size: "20px"
49
+ }, null, 8, ["loadingState"])) : e.modelValue ? (a(), s(l(k), {
50
+ key: 1,
51
+ class: "self-center",
52
+ icon: "Close",
53
+ label: "Clear Search",
54
+ size: "md",
55
+ onClick: t[0] || (t[0] = (C) => o("update:modelValue", ""))
56
+ })) : V("", !0)
57
+ ], 16));
58
+ }
59
+ });
60
+ export {
61
+ E as default
62
+ };
@@ -0,0 +1,4 @@
1
+ import f from "./ScalarSearchInput.vue.js";
2
+ export {
3
+ f as default
4
+ };
@@ -0,0 +1,57 @@
1
+ import { defineComponent as i, computed as d, useAttrs as m, openBlock as o, createElementBlock as r, createElementVNode as t, mergeProps as p, unref as a, renderSlot as s, createBlock as u, createCommentVNode as l } from "vue";
2
+ import { cx as f } from "../../cva.js";
3
+ import _ from "../ScalarIcon/ScalarIcon.vue.js";
4
+ const h = { class: "contents" }, v = { class: "text-c-3 group-hover:text-c-1" }, x = { class: "flex min-w-0 flex-1 flex-col gap-0.75" }, g = { class: "flex items-center gap-1" }, $ = { class: "flex-1 truncate text-sm font-medium" }, k = {
5
+ key: 0,
6
+ class: "text-xs text-c-2"
7
+ }, N = { class: "truncate text-xs text-c-2" }, A = /* @__PURE__ */ i({
8
+ inheritAttrs: !1,
9
+ __name: "ScalarSearchResultItem",
10
+ props: {
11
+ icon: {},
12
+ active: { type: Boolean }
13
+ },
14
+ setup(b) {
15
+ const c = d(() => {
16
+ const { class: e, ...n } = m();
17
+ return { className: e || "", rest: n };
18
+ });
19
+ return (e, n) => (o(), r("li", h, [
20
+ t("a", p(c.value.rest, {
21
+ class: a(f)(
22
+ "group flex cursor-pointer gap-3 rounded px-3 py-1.5 no-underline hover:bg-b-2",
23
+ {
24
+ "bg-b-2": e.active
25
+ },
26
+ c.value.className
27
+ )
28
+ }), [
29
+ t("div", v, [
30
+ s(e.$slots, "icon", {}, () => [
31
+ e.icon ? (o(), u(a(_), {
32
+ key: 0,
33
+ icon: e.icon,
34
+ size: "sm"
35
+ }, null, 8, ["icon"])) : l("", !0)
36
+ ])
37
+ ]),
38
+ t("div", x, [
39
+ t("div", g, [
40
+ t("div", $, [
41
+ s(e.$slots, "default")
42
+ ]),
43
+ e.$slots.addon ? (o(), r("div", k, [
44
+ s(e.$slots, "addon")
45
+ ])) : l("", !0)
46
+ ]),
47
+ t("div", N, [
48
+ s(e.$slots, "description")
49
+ ])
50
+ ])
51
+ ], 16)
52
+ ]));
53
+ }
54
+ });
55
+ export {
56
+ A as default
57
+ };
@@ -0,0 +1,4 @@
1
+ import f from "./ScalarSearchResultItem.vue.js";
2
+ export {
3
+ f as default
4
+ };
@@ -0,0 +1,29 @@
1
+ import { defineComponent as r, computed as a, useAttrs as n, openBlock as c, createElementBlock as m, mergeProps as u, unref as p, renderSlot as l, createCommentVNode as f, createElementVNode as t } from "vue";
2
+ import { cx as d } from "../../cva.js";
3
+ const i = /* @__PURE__ */ t("div", { class: "flex flex-col items-center gap-2 px-3 py-4" }, [
4
+ /* @__PURE__ */ t("div", { class: "rotate-90 text-lg font-bold" }, ":("),
5
+ /* @__PURE__ */ t("div", { class: "text-sm font-medium text-c-2" }, "No results found")
6
+ ], -1), v = /* @__PURE__ */ r({
7
+ inheritAttrs: !1,
8
+ __name: "ScalarSearchResultList",
9
+ props: {
10
+ noResults: { type: Boolean }
11
+ },
12
+ setup(x) {
13
+ const s = a(() => {
14
+ const { class: e, ...o } = n();
15
+ return { className: e || "", rest: o };
16
+ });
17
+ return (e, o) => (c(), m("ul", u(s.value.rest, {
18
+ class: p(d)("flex flex-col", s.value.className)
19
+ }), [
20
+ e.noResults ? l(e.$slots, "noResults", { key: 0 }, () => [
21
+ i
22
+ ]) : f("", !0),
23
+ l(e.$slots, "default")
24
+ ], 16));
25
+ }
26
+ });
27
+ export {
28
+ v as default
29
+ };
@@ -0,0 +1,4 @@
1
+ import f from "./ScalarSearchResultList.vue.js";
2
+ export {
3
+ f as default
4
+ };
@@ -0,0 +1,7 @@
1
+ import o from "./ScalarTextField.vue2.js";
2
+ import "./ScalarTextField.vue3.js";
3
+ import t from "../../_virtual/_plugin-vue_export-helper.js";
4
+ const e = /* @__PURE__ */ t(o, [["__scopeId", "data-v-94574cc9"]]);
5
+ export {
6
+ e as default
7
+ };