@dub/ui 0.0.0

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 (397) hide show
  1. package/.turbo/turbo-build.log +129 -0
  2. package/dist/accordion.d.ts +9 -0
  3. package/dist/accordion.mjs +2 -0
  4. package/dist/avatar.d.ts +15 -0
  5. package/dist/avatar.mjs +2 -0
  6. package/dist/background/index.css +1 -0
  7. package/dist/background/index.d.ts +5 -0
  8. package/dist/background/index.mjs +2 -0
  9. package/dist/background.d.ts +5 -0
  10. package/dist/background.mjs +2 -0
  11. package/dist/badge.d.ts +12 -0
  12. package/dist/badge.mjs +2 -0
  13. package/dist/blur-image.d.ts +6 -0
  14. package/dist/blur-image.mjs +2 -0
  15. package/dist/button.css +1 -0
  16. package/dist/button.d.ts +13 -0
  17. package/dist/button.mjs +2 -0
  18. package/dist/chunk-244OSE43.mjs +2 -0
  19. package/dist/chunk-25PGVVAM.mjs +2 -0
  20. package/dist/chunk-2CR6AI65.mjs +2 -0
  21. package/dist/chunk-2KZFWJJX.mjs +2 -0
  22. package/dist/chunk-2O5K4D5Q.mjs +2 -0
  23. package/dist/chunk-2SFV6FGR.mjs +2 -0
  24. package/dist/chunk-2TGXECZQ.mjs +2 -0
  25. package/dist/chunk-2ZQKPJ36.mjs +2 -0
  26. package/dist/chunk-33QWEDY7.mjs +8 -0
  27. package/dist/chunk-3GU5I4KI.mjs +2 -0
  28. package/dist/chunk-3Q6B4UEP.mjs +2 -0
  29. package/dist/chunk-3S3WMTNJ.mjs +2 -0
  30. package/dist/chunk-3YDMSFPQ.mjs +2 -0
  31. package/dist/chunk-3ZOR7HDE.mjs +2 -0
  32. package/dist/chunk-4555QYZ6.mjs +2 -0
  33. package/dist/chunk-46KYE2TK.mjs +2 -0
  34. package/dist/chunk-4B27GTB4.mjs +3 -0
  35. package/dist/chunk-4JKAA2S4.mjs +2 -0
  36. package/dist/chunk-4JXT2OCG.mjs +2 -0
  37. package/dist/chunk-4OESW4SN.mjs +2 -0
  38. package/dist/chunk-4QDUUMAW.mjs +2 -0
  39. package/dist/chunk-4XBYRIVX.mjs +2 -0
  40. package/dist/chunk-4ZSCYPP2.mjs +2 -0
  41. package/dist/chunk-56D4WGXU.mjs +2 -0
  42. package/dist/chunk-56DTUGDB.mjs +2 -0
  43. package/dist/chunk-5A2BHTHD.mjs +2 -0
  44. package/dist/chunk-5EWSH7PD.mjs +2 -0
  45. package/dist/chunk-5JYRCHLM.mjs +2 -0
  46. package/dist/chunk-5SGX2GJA.mjs +2 -0
  47. package/dist/chunk-5UODCYNT.mjs +2 -0
  48. package/dist/chunk-5VNTIKQZ.mjs +2 -0
  49. package/dist/chunk-5WZZBGKJ.mjs +2 -0
  50. package/dist/chunk-6C6ANQBQ.mjs +2 -0
  51. package/dist/chunk-6DKNMNDW.mjs +2 -0
  52. package/dist/chunk-6GJY5OO4.mjs +2 -0
  53. package/dist/chunk-6KTUEBPU.mjs +2 -0
  54. package/dist/chunk-6S57E6BS.mjs +2 -0
  55. package/dist/chunk-6TNUMRJD.mjs +3 -0
  56. package/dist/chunk-7AQLFQZX.mjs +2 -0
  57. package/dist/chunk-7FBJXRA5.mjs +2 -0
  58. package/dist/chunk-7FTHTS2N.mjs +2 -0
  59. package/dist/chunk-7GWUKTP3.mjs +2 -0
  60. package/dist/chunk-7HABTH45.mjs +2 -0
  61. package/dist/chunk-7JAMW2DV.mjs +2 -0
  62. package/dist/chunk-7LB36OSM.mjs +2 -0
  63. package/dist/chunk-7O2ZOJNB.mjs +2 -0
  64. package/dist/chunk-7QQZYSZX.mjs +2 -0
  65. package/dist/chunk-7RM43KIQ.mjs +2 -0
  66. package/dist/chunk-7UOWPARW.mjs +2 -0
  67. package/dist/chunk-A3PUDJ7V.mjs +1 -0
  68. package/dist/chunk-AACJEMFS.mjs +2 -0
  69. package/dist/chunk-ABLQYIFT.mjs +2 -0
  70. package/dist/chunk-AUBFB4SI.mjs +2 -0
  71. package/dist/chunk-AUVV5HUC.mjs +2 -0
  72. package/dist/chunk-AZD2JXYJ.mjs +2 -0
  73. package/dist/chunk-B3VKF2VA.mjs +2 -0
  74. package/dist/chunk-B4HABAR3.mjs +2 -0
  75. package/dist/chunk-B6VWIQYU.mjs +3 -0
  76. package/dist/chunk-BHTYGPAI.mjs +2 -0
  77. package/dist/chunk-BZJK6BT5.mjs +2 -0
  78. package/dist/chunk-C33FCZ32.mjs +2 -0
  79. package/dist/chunk-C3ZLFBBA.mjs +1 -0
  80. package/dist/chunk-C4PESNHJ.mjs +2 -0
  81. package/dist/chunk-C5IOO5UD.mjs +2 -0
  82. package/dist/chunk-CBHHIJGG.mjs +2 -0
  83. package/dist/chunk-CCKZ5QDB.mjs +2 -0
  84. package/dist/chunk-CFCHBBAJ.mjs +2 -0
  85. package/dist/chunk-D2Q6GSHJ.mjs +2 -0
  86. package/dist/chunk-D3NFRR3I.mjs +2 -0
  87. package/dist/chunk-DG5QULNJ.mjs +2 -0
  88. package/dist/chunk-DHJFK2S6.mjs +2 -0
  89. package/dist/chunk-DIJAPN4A.mjs +2 -0
  90. package/dist/chunk-DMNL3RKY.mjs +2 -0
  91. package/dist/chunk-DNZ5INSW.mjs +2 -0
  92. package/dist/chunk-DOE7DSDC.mjs +2 -0
  93. package/dist/chunk-E2TMZ3II.mjs +2 -0
  94. package/dist/chunk-E5ZJGOXG.mjs +2 -0
  95. package/dist/chunk-ECNXBGSQ.mjs +2 -0
  96. package/dist/chunk-EFQSHW3O.mjs +2 -0
  97. package/dist/chunk-EGZBNRFB.mjs +2 -0
  98. package/dist/chunk-EHYVEIOL.mjs +2 -0
  99. package/dist/chunk-EL4XTTMC.mjs +2 -0
  100. package/dist/chunk-EY55E5DB.mjs +2 -0
  101. package/dist/chunk-F6OPUNTW.mjs +2 -0
  102. package/dist/chunk-F6RVKSBN.mjs +2 -0
  103. package/dist/chunk-FMOY54OP.mjs +2 -0
  104. package/dist/chunk-FMUX4F5B.mjs +2 -0
  105. package/dist/chunk-FR336PIX.mjs +2 -0
  106. package/dist/chunk-G4PPRIHO.mjs +2 -0
  107. package/dist/chunk-GA4JDGWI.mjs +2 -0
  108. package/dist/chunk-GF6NH2NZ.mjs +2 -0
  109. package/dist/chunk-GFMXORYG.mjs +2 -0
  110. package/dist/chunk-GR726Z6I.mjs +2 -0
  111. package/dist/chunk-GRAJLMHF.mjs +2 -0
  112. package/dist/chunk-GSQUGPJ2.mjs +2 -0
  113. package/dist/chunk-GVANYQ67.mjs +1 -0
  114. package/dist/chunk-GVCIDQOF.mjs +2 -0
  115. package/dist/chunk-GXDFY5X2.mjs +2 -0
  116. package/dist/chunk-HCV274NJ.mjs +2 -0
  117. package/dist/chunk-HFY7GEA4.mjs +2 -0
  118. package/dist/chunk-HI3TSQ5W.mjs +2 -0
  119. package/dist/chunk-HMVFMHDB.mjs +2 -0
  120. package/dist/chunk-HNCJ4TJR.mjs +2 -0
  121. package/dist/chunk-HRN3EQEB.mjs +2 -0
  122. package/dist/chunk-I23BSUWS.mjs +2 -0
  123. package/dist/chunk-I57LZ6JE.mjs +2 -0
  124. package/dist/chunk-IG7XYDDR.mjs +2 -0
  125. package/dist/chunk-IHPV7RPK.mjs +2 -0
  126. package/dist/chunk-IJBZR4LN.mjs +8 -0
  127. package/dist/chunk-IJKZ5HB5.mjs +2 -0
  128. package/dist/chunk-IK4XBUOE.mjs +2 -0
  129. package/dist/chunk-ITDAQXDS.mjs +1 -0
  130. package/dist/chunk-IWV22LBB.mjs +2 -0
  131. package/dist/chunk-IY2HG3NK.mjs +8 -0
  132. package/dist/chunk-IYAB6FPB.mjs +2 -0
  133. package/dist/chunk-IZXIJLTW.mjs +2 -0
  134. package/dist/chunk-J5SA2VPW.mjs +3 -0
  135. package/dist/chunk-J63GHRZH.mjs +2 -0
  136. package/dist/chunk-JBL2DUF5.mjs +2 -0
  137. package/dist/chunk-JEJ4EWU7.mjs +2 -0
  138. package/dist/chunk-JIFH2LYE.mjs +3 -0
  139. package/dist/chunk-JJNAD6S4.mjs +3 -0
  140. package/dist/chunk-JLET4OCX.mjs +3 -0
  141. package/dist/chunk-JORK4T7Q.mjs +2 -0
  142. package/dist/chunk-JP7IWWG3.mjs +2 -0
  143. package/dist/chunk-JVM44TKC.mjs +2 -0
  144. package/dist/chunk-KBSQGAWB.mjs +2 -0
  145. package/dist/chunk-KDGZ6H77.mjs +2 -0
  146. package/dist/chunk-KF5NIC53.mjs +2 -0
  147. package/dist/chunk-KKCOE2RH.mjs +2 -0
  148. package/dist/chunk-KMHFLT2M.mjs +2 -0
  149. package/dist/chunk-KNYITJKS.mjs +2 -0
  150. package/dist/chunk-KQEO6U4W.mjs +2 -0
  151. package/dist/chunk-KQFL4H7A.mjs +2 -0
  152. package/dist/chunk-KUSH4SR2.mjs +2 -0
  153. package/dist/chunk-KVVEZANZ.mjs +2 -0
  154. package/dist/chunk-KWZ4DBE4.mjs +2 -0
  155. package/dist/chunk-L5KPIGCR.mjs +2 -0
  156. package/dist/chunk-L6UWBEZE.mjs +2 -0
  157. package/dist/chunk-LAQSQMES.mjs +2 -0
  158. package/dist/chunk-LFMW2GVW.mjs +3 -0
  159. package/dist/chunk-LRCJQIJG.mjs +2 -0
  160. package/dist/chunk-M4Q2EF5G.mjs +2 -0
  161. package/dist/chunk-MCXA7VY2.mjs +2 -0
  162. package/dist/chunk-MKKBN6XG.mjs +2 -0
  163. package/dist/chunk-MN57ZXBI.mjs +2 -0
  164. package/dist/chunk-MO5Z5S7B.mjs +2 -0
  165. package/dist/chunk-MOPBLS6N.mjs +2 -0
  166. package/dist/chunk-MURAUI3W.mjs +2 -0
  167. package/dist/chunk-MYBLDYMF.mjs +2 -0
  168. package/dist/chunk-MYKWMBLF.mjs +2 -0
  169. package/dist/chunk-N7BNEQPU.mjs +2 -0
  170. package/dist/chunk-NA4EVPAY.mjs +2 -0
  171. package/dist/chunk-NEH5H6FT.mjs +8 -0
  172. package/dist/chunk-NFAXHR5T.mjs +2 -0
  173. package/dist/chunk-NHHVF35L.mjs +2 -0
  174. package/dist/chunk-NJKAWDPD.mjs +2 -0
  175. package/dist/chunk-NPDJHIVO.mjs +2 -0
  176. package/dist/chunk-NSWEINWF.mjs +2 -0
  177. package/dist/chunk-NWB2AZNS.mjs +2 -0
  178. package/dist/chunk-NX47KGRW.mjs +2 -0
  179. package/dist/chunk-NYBTLOVB.mjs +3 -0
  180. package/dist/chunk-O55CBIBG.mjs +8 -0
  181. package/dist/chunk-OGAYDFMV.mjs +2 -0
  182. package/dist/chunk-OI77O6SL.mjs +2 -0
  183. package/dist/chunk-OIU4BN7T.mjs +2 -0
  184. package/dist/chunk-OJXGRTYX.mjs +2 -0
  185. package/dist/chunk-OKOSJ4DF.mjs +2 -0
  186. package/dist/chunk-OLQNYINM.mjs +2 -0
  187. package/dist/chunk-OMIP4OG5.mjs +2 -0
  188. package/dist/chunk-OTLHHZOF.mjs +2 -0
  189. package/dist/chunk-OX66FZYY.mjs +2 -0
  190. package/dist/chunk-OXANJWH4.mjs +2 -0
  191. package/dist/chunk-OYEGFR5W.mjs +2 -0
  192. package/dist/chunk-PGXM347Z.mjs +2 -0
  193. package/dist/chunk-PIEMQYVU.mjs +2 -0
  194. package/dist/chunk-PISF5LGD.mjs +2 -0
  195. package/dist/chunk-PMAKRWPB.mjs +2 -0
  196. package/dist/chunk-PPNWHWNQ.mjs +2 -0
  197. package/dist/chunk-PPR7AQWS.mjs +2 -0
  198. package/dist/chunk-PRUCD3QQ.mjs +2 -0
  199. package/dist/chunk-PVPFL6D6.mjs +2 -0
  200. package/dist/chunk-Q64KZRX2.mjs +2 -0
  201. package/dist/chunk-QDT2R7NG.mjs +2 -0
  202. package/dist/chunk-QLD74AUU.mjs +2 -0
  203. package/dist/chunk-QP2EHAF7.mjs +2 -0
  204. package/dist/chunk-QS3K2BUJ.mjs +2 -0
  205. package/dist/chunk-QTY5FUJ3.mjs +2 -0
  206. package/dist/chunk-QXM65Z6A.mjs +2 -0
  207. package/dist/chunk-QZJO3GBP.mjs +2 -0
  208. package/dist/chunk-RF3BM6RY.mjs +2 -0
  209. package/dist/chunk-RF6IPNCO.mjs +2 -0
  210. package/dist/chunk-RF757N25.mjs +3 -0
  211. package/dist/chunk-RQBEORWD.mjs +2 -0
  212. package/dist/chunk-RRZDOFPB.mjs +2 -0
  213. package/dist/chunk-RT4DYHL4.mjs +2 -0
  214. package/dist/chunk-RWND7PHS.mjs +2 -0
  215. package/dist/chunk-S7GVW42L.mjs +2 -0
  216. package/dist/chunk-SGDLNADF.mjs +2 -0
  217. package/dist/chunk-SJHDGCSL.mjs +2 -0
  218. package/dist/chunk-SN3ZPBNA.mjs +2 -0
  219. package/dist/chunk-SRB37H2M.mjs +2 -0
  220. package/dist/chunk-SVXEWZS2.mjs +2 -0
  221. package/dist/chunk-SWY5WJTL.mjs +2 -0
  222. package/dist/chunk-T2HLWVVR.mjs +3 -0
  223. package/dist/chunk-T4YFARK5.mjs +2 -0
  224. package/dist/chunk-TEYRN5YH.mjs +2 -0
  225. package/dist/chunk-TFO3ND3W.mjs +2 -0
  226. package/dist/chunk-TLCO7PTI.mjs +2 -0
  227. package/dist/chunk-TN7DEVEE.mjs +2 -0
  228. package/dist/chunk-TNTITL6S.mjs +3 -0
  229. package/dist/chunk-TRZ3KXED.mjs +8 -0
  230. package/dist/chunk-TSU5QRYZ.mjs +2 -0
  231. package/dist/chunk-TTICNZG7.mjs +2 -0
  232. package/dist/chunk-U7OUT2WV.mjs +1 -0
  233. package/dist/chunk-UBZTDYQG.mjs +2 -0
  234. package/dist/chunk-UEZD34PU.mjs +2 -0
  235. package/dist/chunk-UQPZMB6C.mjs +2 -0
  236. package/dist/chunk-UTIBO7SO.mjs +2 -0
  237. package/dist/chunk-UVSGUIBW.mjs +8 -0
  238. package/dist/chunk-VAQHITBV.mjs +2 -0
  239. package/dist/chunk-VBY3N2TS.mjs +3 -0
  240. package/dist/chunk-VE55VEAS.mjs +2 -0
  241. package/dist/chunk-VFWL5XAA.mjs +2 -0
  242. package/dist/chunk-VIDJ5SRV.mjs +2 -0
  243. package/dist/chunk-W2MLKAZN.mjs +2 -0
  244. package/dist/chunk-W65Y5YRU.mjs +2 -0
  245. package/dist/chunk-W6R5YWL6.mjs +2 -0
  246. package/dist/chunk-WB7VZJZA.mjs +2 -0
  247. package/dist/chunk-WDSNVW3W.mjs +2 -0
  248. package/dist/chunk-WURMVTJP.mjs +2 -0
  249. package/dist/chunk-WWM6WQCY.mjs +2 -0
  250. package/dist/chunk-X2XFCFUL.mjs +2 -0
  251. package/dist/chunk-X374ODLH.mjs +2 -0
  252. package/dist/chunk-X7ADEEVD.mjs +8 -0
  253. package/dist/chunk-XE5CT2M3.mjs +2 -0
  254. package/dist/chunk-XE5QS5VD.mjs +8 -0
  255. package/dist/chunk-XHGXSXB3.mjs +2 -0
  256. package/dist/chunk-XQ47XIIO.mjs +2 -0
  257. package/dist/chunk-XYVV643U.mjs +8 -0
  258. package/dist/chunk-XZMMZD3Z.mjs +2 -0
  259. package/dist/chunk-XZSQWDME.mjs +2 -0
  260. package/dist/chunk-YBWQTHOI.mjs +2 -0
  261. package/dist/chunk-YOWYEBY3.mjs +2 -0
  262. package/dist/chunk-YQXTW7IL.mjs +2 -0
  263. package/dist/chunk-YVROMH7J.mjs +2 -0
  264. package/dist/chunk-YVVQMYLM.mjs +2 -0
  265. package/dist/chunk-Z46XMMXR.mjs +2 -0
  266. package/dist/chunk-Z4MSMGYC.mjs +2 -0
  267. package/dist/chunk-Z5P2KHPP.mjs +2 -0
  268. package/dist/chunk-ZGUSKAF7.mjs +2 -0
  269. package/dist/chunk-ZMZG5IED.mjs +8 -0
  270. package/dist/chunk-ZNLJMM2N.mjs +2 -0
  271. package/dist/chunk-ZSF6CHQK.mjs +2 -0
  272. package/dist/chunk-ZXOXZAH4.mjs +2 -0
  273. package/dist/copy-button.css +1 -0
  274. package/dist/copy-button.d.ts +8 -0
  275. package/dist/copy-button.mjs +2 -0
  276. package/dist/footer.css +1 -0
  277. package/dist/footer.d.ts +5 -0
  278. package/dist/footer.mjs +2 -0
  279. package/dist/form.css +1 -0
  280. package/dist/form.d.ts +14 -0
  281. package/dist/form.mjs +2 -0
  282. package/dist/google-b9019ca9.d.ts +7 -0
  283. package/dist/grid-AJXQWCY6.svg +5 -0
  284. package/dist/icon-menu.d.ts +10 -0
  285. package/dist/icon-menu.mjs +2 -0
  286. package/dist/icons/copy.d.ts +7 -0
  287. package/dist/icons/copy.mjs +2 -0
  288. package/dist/icons/expanding-arrow.d.ts +7 -0
  289. package/dist/icons/expanding-arrow.mjs +2 -0
  290. package/dist/icons/facebook.d.ts +8 -0
  291. package/dist/icons/facebook.mjs +2 -0
  292. package/dist/icons/github.d.ts +7 -0
  293. package/dist/icons/github.mjs +2 -0
  294. package/dist/icons/google.d.ts +7 -0
  295. package/dist/icons/google.mjs +2 -0
  296. package/dist/icons/index.css +1 -0
  297. package/dist/icons/index.d.ts +16 -0
  298. package/dist/icons/index.mjs +2 -0
  299. package/dist/icons/linkedin.d.ts +8 -0
  300. package/dist/icons/linkedin.mjs +2 -0
  301. package/dist/icons/loading-circle.d.ts +7 -0
  302. package/dist/icons/loading-circle.mjs +2 -0
  303. package/dist/icons/loading-dots.css +1 -0
  304. package/dist/icons/loading-dots.d.ts +5 -0
  305. package/dist/icons/loading-dots.mjs +2 -0
  306. package/dist/icons/loading-spinner.css +1 -0
  307. package/dist/icons/loading-spinner.d.ts +7 -0
  308. package/dist/icons/loading-spinner.mjs +2 -0
  309. package/dist/icons/logo.d.ts +7 -0
  310. package/dist/icons/logo.mjs +2 -0
  311. package/dist/icons/logotype.d.ts +7 -0
  312. package/dist/icons/logotype.mjs +2 -0
  313. package/dist/icons/photo.d.ts +7 -0
  314. package/dist/icons/photo.mjs +2 -0
  315. package/dist/icons/tick.d.ts +7 -0
  316. package/dist/icons/tick.mjs +2 -0
  317. package/dist/icons/twitter.d.ts +7 -0
  318. package/dist/icons/twitter.mjs +2 -0
  319. package/dist/icons/unsplash.d.ts +7 -0
  320. package/dist/icons/unsplash.mjs +2 -0
  321. package/dist/index.css +1 -0
  322. package/dist/index.d.ts +128 -0
  323. package/dist/index.mjs +2 -0
  324. package/dist/link-preview.css +1 -0
  325. package/dist/link-preview.d.ts +7 -0
  326. package/dist/link-preview.mjs +2 -0
  327. package/dist/max-width-wrapper.d.ts +9 -0
  328. package/dist/max-width-wrapper.mjs +2 -0
  329. package/dist/modal.d.ts +14 -0
  330. package/dist/modal.mjs +2 -0
  331. package/dist/nav-mobile.css +1 -0
  332. package/dist/nav-mobile.d.ts +5 -0
  333. package/dist/nav-mobile.mjs +2 -0
  334. package/dist/nav.css +1 -0
  335. package/dist/nav.d.ts +9 -0
  336. package/dist/nav.mjs +2 -0
  337. package/dist/number-tooltip.d.ts +12 -0
  338. package/dist/number-tooltip.mjs +2 -0
  339. package/dist/number.d.ts +12 -0
  340. package/dist/number.mjs +2 -0
  341. package/dist/popover.d.ts +13 -0
  342. package/dist/popover.mjs +2 -0
  343. package/dist/switch.d.ts +14 -0
  344. package/dist/switch.mjs +2 -0
  345. package/dist/tab-select.d.ts +9 -0
  346. package/dist/tab-select.mjs +2 -0
  347. package/dist/tooltip.d.ts +32 -0
  348. package/dist/tooltip.mjs +2 -0
  349. package/package.json +65 -0
  350. package/postcss.config.js +9 -0
  351. package/src/accordion.tsx +60 -0
  352. package/src/avatar.tsx +47 -0
  353. package/src/background.tsx +71 -0
  354. package/src/badge.tsx +33 -0
  355. package/src/button.tsx +60 -0
  356. package/src/content.ts +230 -0
  357. package/src/copy-button.tsx +39 -0
  358. package/src/footer.tsx +203 -0
  359. package/src/form.tsx +77 -0
  360. package/src/hooks/index.ts +5 -0
  361. package/src/hooks/use-current-anchor.ts +65 -0
  362. package/src/hooks/use-intersection-observer.ts +41 -0
  363. package/src/hooks/use-local-storage.ts +24 -0
  364. package/src/hooks/use-media-query.ts +46 -0
  365. package/src/hooks/use-scroll.ts +21 -0
  366. package/src/icon-menu.tsx +15 -0
  367. package/src/icons/copy.tsx +18 -0
  368. package/src/icons/expanding-arrow.tsx +39 -0
  369. package/src/icons/facebook.tsx +23 -0
  370. package/src/icons/github.tsx +14 -0
  371. package/src/icons/google.tsx +12 -0
  372. package/src/icons/index.tsx +22 -0
  373. package/src/icons/linkedin.tsx +22 -0
  374. package/src/icons/loading-circle.tsx +25 -0
  375. package/src/icons/loading-dots.css +40 -0
  376. package/src/icons/loading-dots.tsx +13 -0
  377. package/src/icons/loading-spinner.tsx +34 -0
  378. package/src/icons/logo.tsx +29 -0
  379. package/src/icons/logotype.tsx +51 -0
  380. package/src/icons/photo.tsx +20 -0
  381. package/src/icons/tick.tsx +18 -0
  382. package/src/icons/twitter.tsx +31 -0
  383. package/src/icons/unsplash.tsx +17 -0
  384. package/src/index.tsx +35 -0
  385. package/src/link-preview.tsx +111 -0
  386. package/src/max-width-wrapper.tsx +21 -0
  387. package/src/modal.tsx +102 -0
  388. package/src/nav-mobile.tsx +108 -0
  389. package/src/nav.tsx +205 -0
  390. package/src/popover.tsx +61 -0
  391. package/src/styles.css +3 -0
  392. package/src/switch.tsx +60 -0
  393. package/src/tab-select.tsx +27 -0
  394. package/src/tooltip.tsx +184 -0
  395. package/tailwind.config.ts +9 -0
  396. package/tsconfig.json +5 -0
  397. package/tsup.config.ts +15 -0
@@ -0,0 +1,27 @@
1
+ export function TabSelect({
2
+ options,
3
+ selected,
4
+ selectAction,
5
+ }: {
6
+ options: string[];
7
+ selected: string;
8
+ selectAction: (option: string) => void;
9
+ }) {
10
+ return (
11
+ <div className="relative inline-flex items-center space-x-3">
12
+ {options.map((option) => (
13
+ <button
14
+ key={option}
15
+ className={`${
16
+ option === selected
17
+ ? "bg-gray-200 text-gray-800"
18
+ : "bg-gray-50 text-gray-600 hover:bg-gray-100"
19
+ } rounded-md px-2 py-1 text-sm font-medium capitalize transition-all duration-75 active:scale-90 sm:px-3`}
20
+ onClick={() => selectAction(option)}
21
+ >
22
+ {option}
23
+ </button>
24
+ ))}
25
+ </div>
26
+ );
27
+ }
@@ -0,0 +1,184 @@
1
+ "use client";
2
+
3
+ import * as TooltipPrimitive from "@radix-ui/react-tooltip";
4
+ import { nFormatter, timeAgo } from "@dub/utils";
5
+ import { HelpCircle } from "lucide-react";
6
+ import Link from "next/link";
7
+ import { ReactNode } from "react";
8
+ import { Drawer } from "vaul";
9
+ import { useMediaQuery } from "./hooks";
10
+
11
+ export function Tooltip({
12
+ children,
13
+ content,
14
+ fullWidth,
15
+ }: {
16
+ children: ReactNode;
17
+ content: ReactNode | string;
18
+ fullWidth?: boolean;
19
+ }) {
20
+ const { isMobile } = useMediaQuery();
21
+
22
+ if (isMobile) {
23
+ return (
24
+ <Drawer.Root>
25
+ <Drawer.Trigger
26
+ className={`${fullWidth ? "w-full" : "inline-flex"} md:hidden`}
27
+ onClick={(e) => {
28
+ e.stopPropagation();
29
+ }}
30
+ >
31
+ {children}
32
+ </Drawer.Trigger>
33
+ <Drawer.Overlay className="fixed inset-0 z-40 bg-gray-100 bg-opacity-10 backdrop-blur" />
34
+ <Drawer.Portal>
35
+ <Drawer.Content className="fixed bottom-0 left-0 right-0 z-50 mt-24 rounded-t-[10px] border-t border-gray-200 bg-white">
36
+ <div className="sticky top-0 z-20 flex w-full items-center justify-center rounded-t-[10px] bg-inherit">
37
+ <div className="my-3 h-1 w-12 rounded-full bg-gray-300" />
38
+ </div>
39
+ <div className="flex min-h-[150px] w-full items-center justify-center overflow-hidden bg-white align-middle shadow-xl">
40
+ {typeof content === "string" ? (
41
+ <span className="block text-center text-sm text-gray-700">
42
+ {content}
43
+ </span>
44
+ ) : (
45
+ content
46
+ )}
47
+ </div>
48
+ </Drawer.Content>
49
+ <Drawer.Overlay />
50
+ </Drawer.Portal>
51
+ </Drawer.Root>
52
+ );
53
+ }
54
+ return (
55
+ <TooltipPrimitive.Provider delayDuration={0}>
56
+ <TooltipPrimitive.Root>
57
+ <TooltipPrimitive.Trigger className="md:inline-flex" asChild>
58
+ {children}
59
+ </TooltipPrimitive.Trigger>
60
+ {/*
61
+ We don't use TooltipPrimitive.Portal here because for some reason it
62
+ prevents you from selecting the contents of a tooltip when used inside a modal
63
+ */}
64
+ <TooltipPrimitive.Content
65
+ sideOffset={8}
66
+ side="top"
67
+ className="animate-slide-up-fade z-[99] items-center overflow-hidden rounded-md border border-gray-200 bg-white shadow-md md:block"
68
+ >
69
+ {typeof content === "string" ? (
70
+ <div className="block max-w-xs px-4 py-2 text-center text-sm text-gray-700">
71
+ {content}
72
+ </div>
73
+ ) : (
74
+ content
75
+ )}
76
+ </TooltipPrimitive.Content>
77
+ </TooltipPrimitive.Root>
78
+ </TooltipPrimitive.Provider>
79
+ );
80
+ }
81
+
82
+ export function TooltipContent({
83
+ title,
84
+ cta,
85
+ href,
86
+ target,
87
+ onClick,
88
+ }: {
89
+ title: string;
90
+ cta?: string;
91
+ href?: string;
92
+ target?: string;
93
+ onClick?: () => void;
94
+ }) {
95
+ return (
96
+ <div className="flex flex-col items-center space-y-3 p-4 text-center md:max-w-xs">
97
+ <p className="text-sm text-gray-700">{title}</p>
98
+ {cta &&
99
+ (href ? (
100
+ <Link
101
+ href={href}
102
+ {...(target ? { target } : {})}
103
+ className="mt-4 w-full rounded-md border border-black bg-black px-3 py-1.5 text-center text-sm text-white transition-all hover:bg-white hover:text-black"
104
+ >
105
+ {cta}
106
+ </Link>
107
+ ) : onClick ? (
108
+ <button
109
+ type="button"
110
+ className="mt-4 w-full rounded-md border border-black bg-black px-3 py-1.5 text-center text-sm text-white transition-all hover:bg-white hover:text-black"
111
+ onClick={onClick}
112
+ >
113
+ {cta}
114
+ </button>
115
+ ) : null)}
116
+ </div>
117
+ );
118
+ }
119
+
120
+ export function SimpleTooltipContent({
121
+ title,
122
+ cta,
123
+ href,
124
+ }: {
125
+ title: string;
126
+ cta: string;
127
+ href: string;
128
+ }) {
129
+ return (
130
+ <div className="max-w-xs px-4 py-2 text-center text-sm text-gray-700">
131
+ {title}{" "}
132
+ <a
133
+ href={href}
134
+ target="_blank"
135
+ rel="noopener noreferrer"
136
+ className="inline-flex text-gray-500 underline underline-offset-4 hover:text-gray-800"
137
+ >
138
+ {cta}
139
+ </a>
140
+ </div>
141
+ );
142
+ }
143
+
144
+ export function InfoTooltip({ content }: { content: ReactNode | string }) {
145
+ return (
146
+ <Tooltip content={content}>
147
+ <HelpCircle className="h-4 w-4 text-gray-500" />
148
+ </Tooltip>
149
+ );
150
+ }
151
+
152
+ export function NumberTooltip({
153
+ value,
154
+ unit = "total clicks",
155
+ children,
156
+ lastClicked,
157
+ }: {
158
+ value?: number | null;
159
+ unit?: string;
160
+ children: ReactNode;
161
+ lastClicked?: Date | null;
162
+ }) {
163
+ if ((!value || value < 1000) && !lastClicked) {
164
+ return children;
165
+ }
166
+ return (
167
+ <Tooltip
168
+ content={
169
+ <div className="block max-w-xs px-4 py-2 text-center text-sm text-gray-700">
170
+ <p className="text-sm font-semibold text-gray-700">
171
+ {nFormatter(value || 0, { full: true })} {unit}
172
+ </p>
173
+ {lastClicked && (
174
+ <p className="mt-1 text-xs text-gray-500">
175
+ Last clicked {timeAgo(lastClicked, { withAgo: true })}
176
+ </p>
177
+ )}
178
+ </div>
179
+ }
180
+ >
181
+ {children}
182
+ </Tooltip>
183
+ );
184
+ }
@@ -0,0 +1,9 @@
1
+ // tailwind config is required for editor support
2
+ import sharedConfig from "tailwind-config/tailwind.config.ts";
3
+ import type { Config } from "tailwindcss";
4
+
5
+ const config: Pick<Config, "presets"> = {
6
+ presets: [sharedConfig],
7
+ };
8
+
9
+ export default config;
package/tsconfig.json ADDED
@@ -0,0 +1,5 @@
1
+ {
2
+ "extends": "tsconfig/react-library.json",
3
+ "include": ["."],
4
+ "exclude": ["dist", "build", "node_modules"]
5
+ }
package/tsup.config.ts ADDED
@@ -0,0 +1,15 @@
1
+ import { defineConfig, Options } from "tsup";
2
+
3
+ export default defineConfig((options: Options) => ({
4
+ entry: ["src/**/*.tsx"],
5
+ format: ["esm"],
6
+ esbuildOptions(options) {
7
+ options.banner = {
8
+ js: '"use client"',
9
+ };
10
+ },
11
+ dts: true,
12
+ minify: true,
13
+ external: ["react"],
14
+ ...options,
15
+ }));