@dub/ui 0.2.60 → 0.2.61

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 (2) hide show
  1. package/dist/index.mjs +1 -1
  2. package/package.json +1 -1
package/dist/index.mjs CHANGED
@@ -50,4 +50,4 @@ void main(void) {
50
50
  <path fill-rule="evenodd" clip-rule="evenodd" d="M32.5 64C50.1731 64 64.5 49.6731 64.5 32C64.5 20.1555 58.0648 9.81393 48.5 4.28099V31.9999V47.9998H40.5V45.8594C38.1466 47.2207 35.4143 47.9999 32.5 47.9999C23.6634 47.9999 16.5 40.8364 16.5 31.9999C16.5 23.1633 23.6634 15.9999 32.5 15.9999C35.4143 15.9999 38.1466 16.779 40.5 18.1404V1.00812C37.943 0.350018 35.2624 0 32.5 0C14.8269 0 0.500038 14.3269 0.500038 32C0.500038 49.6731 14.8269 64 32.5 64Z" fill="black"/>
51
51
  </svg>`,vu=`<svg width="46" height="24" viewBox="0 0 46 24" fill="none" xmlns="http://www.w3.org/2000/svg">
52
52
  <path fill-rule="evenodd" clip-rule="evenodd" d="M11 2H14V13.9332L14.0003 13.9731L14.0003 14C14.0003 14.0223 14.0002 14.0445 14 14.0668V21H11V19.7455C9.86619 20.5362 8.48733 21 7.00016 21C3.13408 21 0 17.866 0 14C0 10.134 3.13408 7 7.00016 7C8.48733 7 9.86619 7.46375 11 8.25452V2ZM7 17.9998C9.20914 17.9998 11 16.209 11 13.9999C11 11.7908 9.20914 10 7 10C4.79086 10 3 11.7908 3 13.9999C3 16.209 4.79086 17.9998 7 17.9998ZM32 2H35V8.25474C36.1339 7.46383 37.5128 7 39.0002 7C42.8662 7 46.0003 10.134 46.0003 14C46.0003 17.866 42.8662 21 39.0002 21C35.1341 21 32 17.866 32 14V2ZM39 17.9998C41.2091 17.9998 43 16.209 43 13.9999C43 11.7908 41.2091 10 39 10C36.7909 10 35 11.7908 35 13.9999C35 16.209 36.7909 17.9998 39 17.9998ZM19 7H16V14C16 14.9192 16.1811 15.8295 16.5329 16.6788C16.8846 17.5281 17.4003 18.2997 18.0503 18.9497C18.7003 19.5997 19.472 20.1154 20.3213 20.4671C21.1706 20.8189 22.0809 21 23.0002 21C23.9194 21 24.8297 20.8189 25.679 20.4671C26.5283 20.1154 27.3 19.5997 27.95 18.9497C28.6 18.2997 29.1157 17.5281 29.4675 16.6788C29.8192 15.8295 30.0003 14.9192 30.0003 14H30V7H27V14C27 15.0608 26.5785 16.0782 25.8284 16.8283C25.0783 17.5784 24.0609 17.9998 23 17.9998C21.9391 17.9998 20.9217 17.5784 20.1716 16.8283C19.4215 16.0782 19 15.0608 19 14V7Z" fill="black"/>
53
- </svg>`;function Wr({variant:e="full",isInApp:t,className:r}){let{domain:o="dub.co"}=uu(),{theme:a}=fu(zo),[n,c]=gu(!1),s=pu(l=>{l.preventDefault(),c(!0)},[]),[,m]=pt();function d(l){bu.promise(m(l),{success:"Copied to clipboard!",error:"Failed to copy to clipboard"})}return Ri(Be.Root,{open:n,onOpenChange:c,children:[q(Be.Anchor,{asChild:!0,children:q("div",{onContextMenu:s,className:"max-w-fit",children:e==="full"?q(Si,{className:r}):q(Ht,{className:i("h-8 w-8 transition-all duration-75 active:scale-95",r)})})}),q(Be.Portal,{children:q(Be.Content,{sideOffset:14,align:"start",className:i("z-50 -mt-1.5",!t&&"-translate-x-8",a==="dark"&&"dark"),onClick:l=>{l.stopPropagation(),c(!1)},children:Ri("div",{className:"grid gap-1 rounded-lg border border-neutral-200 bg-white p-2 drop-shadow-sm sm:min-w-[240px] dark:border-white/[0.15] dark:bg-black",children:[q(Gt,{text:"Copy Logo as SVG",variant:"outline",onClick:()=>d(hu),icon:q(Ht,{className:"h-4 w-4"})}),q(Gt,{text:"Copy Wordmark as SVG",variant:"outline",onClick:()=>d(vu),icon:q(mu,{strokeWidth:2,className:"h-4 w-4"})}),q(Gt,{text:"Brand Guidelines",variant:"outline",onClick:()=>window.open("https://dub.co/brand","_blank"),icon:q(lu,{strokeWidth:2,className:"h-4 w-4"})}),t||o!="dub.co"?q(Gt,{text:"Home Page",variant:"outline",onClick:()=>window.open(`https://dub.co${t?"/home":""}`,"_blank"),icon:q(cu,{strokeWidth:2,className:"h-4 w-4"})}):q(Gt,{text:"Dashboard",variant:"outline",onClick:()=>window.open("https://app.dub.co","_blank"),icon:q(du,{strokeWidth:2,className:"h-4 w-4"})})]})})})]})}function Gt({className:e,...t}){return q(te,{className:i("h-9 justify-start px-3 font-medium hover:text-neutral-700 dark:text-white/70 dark:hover:bg-white/[0.15] dark:hover:text-white",e),...t})}import{jsx as I,jsxs as $}from"react/jsx-runtime";var Cu=[{name:"Twitter",icon:tr,href:"https://twitter.com/dubdotco"},{name:"LinkedIn",icon:er,href:"https://www.linkedin.com/company/dubinc"},{name:"GitHub",icon:Qt,href:"https://github.com/dubinc/dub"},{name:"YouTube",icon:rr,href:"https://www.youtube.com/@dubdotco"}],jt={product:[...Fr.filter(({title:e})=>e!=="Dub Integrations").map(({id:e,title:t,href:r})=>({id:e,name:t,href:r})),{id:null,name:"Dub Enterprise",href:"/enterprise"}],solutions:[{name:"Marketing attribution",href:"/analytics"},{name:"Content creators",href:"/solutions/creators"},{name:"Affiliate management",href:"/partners"}],resources:[{name:"Docs",href:"/docs/introduction"},{name:"Help Center",href:"/help"},{name:"Integrations",href:"/integrations"},{name:"Pricing",href:"/pricing"},{name:"Affiliates",href:"https://partners.dub.co/dub",target:"_blank"}],company:[{name:"About",href:"/about"},{name:"Blog",href:"/blog"},{name:"Careers",href:"/careers"},{name:"Changelog",href:"/changelog"},{name:"Customers",href:"/customers"},{name:"Brand",href:"/brand"},{name:"Contact",href:"/contact"},{name:"Privacy",href:"/privacy"}],compare:ci.map(({name:e,slug:t})=>({name:e,href:`/compare/${t}`,product:"links"})).concat(["Rewardful","PartnerStack","Tolt"].map(e=>({name:e,href:`/help/article/migrating-from-${e.toLowerCase()}`,product:"partners"})))},Kt="text-sm font-medium text-neutral-900",Yt="flex flex-col mt-2.5 gap-3.5",nt="flex items-center gap-2 text-sm text-neutral-500 hover:text-neutral-700 transition-colors duration-75";function ON({staticDomain:e,className:t}){let{domain:r="dub.co"}=wu();e&&(r=e);let[o,a]=Nu(!1);return I(Br,{className:i("relative z-10 overflow-hidden border border-b-0 border-neutral-200 bg-white/50 py-16 backdrop-blur-lg md:rounded-t-2xl",t),children:$("footer",{children:[$("div",{className:"xl:grid xl:grid-cols-3 xl:gap-8",children:[$("div",{className:"flex flex-col gap-6",children:[I("div",{className:"grow",children:$(We,{href:_("/",r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:"Logo"}),className:"block max-w-fit",children:[$("span",{className:"sr-only",children:[process.env.NEXT_PUBLIC_APP_NAME," Logo"]}),I(Wr,{className:"h-8 text-neutral-800"})]})}),I("div",{className:"flex items-center gap-3",children:Cu.map(({name:n,icon:c,href:s})=>$("a",{href:s,target:"_blank",rel:"noreferrer",className:"group rounded-full p-1",children:[I("span",{className:"sr-only",children:n}),I(c,{className:"size-4 text-neutral-900 transition-colors duration-75 group-hover:text-neutral-600"})]},n))})]}),$("div",{className:"mt-16 grid grid-cols-2 gap-4 xl:col-span-2 xl:mt-0",children:[$("div",{className:"md:grid md:grid-cols-2",children:[$("div",{className:"grid gap-8",children:[$("div",{children:[I("h3",{className:Kt,children:"Product"}),I("ul",{role:"list",className:Yt,children:jt.product.map(n=>I("li",{children:$(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:nt,children:[n.id&&I(Yr,{product:n.id}),n.name]})},n.name))})]}),$("div",{children:[I("h3",{className:Kt,children:"Solutions"}),I("ul",{role:"list",className:Yt,children:jt.solutions.map(n=>I("li",{children:I(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:nt,children:n.name})},n.name))})]})]}),$("div",{className:"mt-10 md:mt-0",children:[I("h3",{className:Kt,children:"Resources"}),I("ul",{role:"list",className:Yt,children:jt.resources.map(n=>I("li",{children:$(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),target:n.target,className:i(nt,"gap-1"),children:[n.name,n.target&&I(Ga,{className:"size-3.5"})]})},n.name))})]})]}),$("div",{className:"md:grid md:grid-cols-2",children:[I("div",{className:"grid gap-8",children:$("div",{children:[I("h3",{className:Kt,children:"Company"}),$("ul",{role:"list",className:Yt,children:[jt.company.map(n=>I("li",{children:I(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:i(nt,"gap-1"),children:n.name})},n.name)),I("li",{className:"-mt-1",children:I(ve,{content:I("div",{className:"flex w-screen flex-col gap-1 p-1.5 text-sm focus-visible:outline-none sm:w-auto sm:min-w-[200px]",children:di.map(n=>I(We,{href:_(`/legal/${n.slug}`,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:i(Co({variant:"default"}),nt,"justify-start font-normal"),children:n.name},n.name))}),openPopover:o,setOpenPopover:a,children:$("button",{className:nt,children:["Legal",I(xu,{className:"size-3.5"})]})})})]})]})}),$("div",{className:"mt-10 md:mt-0",children:[I("h3",{className:Kt,children:"Compare"}),I("ul",{role:"list",className:Yt,children:jt.compare.map(n=>I("li",{children:$(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:nt,children:[I(Yr,{product:n.product}),n.name]})},n.name))})]})]})]})]}),$("div",{className:"mt-12 grid grid-cols-1 items-center gap-8 sm:grid-cols-3",children:[I(Sn,{}),I(We,{href:_("/blog/soc2",r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:"SOC2"}),className:"flex sm:justify-center",children:I(yu,{src:"https://assets.dub.co/misc/soc2.svg",alt:"AICPA SOC 2 Type II Certified",width:63,height:32,className:"h-8 transition-[filter] duration-75 hover:brightness-90"})}),$("p",{className:"text-xs text-neutral-500 sm:text-right",children:["\xA9 ",new Date().getFullYear()," Dub Technologies, Inc."]})]})]})})}import{AnimatePresence as ku,motion as Pu}from"framer-motion";import{useEffect as Su,useState as Ru}from"react";import{jsx as Ti}from"react/jsx-runtime";var Li=({children:e,fallback:t,fadeInDuration:r=.5,className:o})=>{let[a,n]=Ru(!1);Su(()=>{n(!0)},[]);let c=r?Pu.div:"div";return Ti(ku,{children:a?Ti(c,{...r?{initial:{opacity:0},animate:{opacity:1},transition:{duration:r}}:{},className:o,children:e}):t||null})};import{cva as Tu}from"class-variance-authority";import{toast as Lu}from"sonner";import{jsx as Bo,jsxs as Du}from"react/jsx-runtime";var Mu=Tu("relative group rounded-full p-1.5 transition-all duration-75",{variants:{variant:{default:"bg-transparent hover:bg-neutral-100 active:bg-neutral-200",neutral:"bg-transparent hover:bg-neutral-100 active:bg-neutral-200"}},defaultVariants:{variant:"default"}});function KN({variant:e="default",value:t,className:r,icon:o,successMessage:a}){let[n,c]=pt(),s=o||na;return Du("button",{onClick:m=>{m.stopPropagation(),Lu.promise(c(t),{success:a||"Copied to clipboard!"})},className:i(Mu({variant:e}),r),type:"button",children:[Bo("span",{className:"sr-only",children:"Copy"}),n?Bo(ma,{className:"h-3.5 w-3.5"}):Bo(s,{className:"h-3.5 w-3.5"})]})}import{toast as Eu}from"sonner";import{jsx as Iu}from"react/jsx-runtime";function JN({value:e,children:t,className:r,successMessage:o}){let[a,n]=pt();return Iu("button",{onClick:c=>{c.stopPropagation(),Eu.promise(n(e),{success:o||"Copied to clipboard!"})},type:"button",className:i("cursor-copy text-sm text-neutral-700 decoration-dotted underline-offset-2 hover:underline",a&&"cursor-default",r),children:t})}import{jsx as Au,jsxs as Ou}from"react/jsx-runtime";function e6({icon:e,text:t}){return Ou("div",{className:"flex items-center justify-start space-x-2 truncate",children:[e,Au("p",{className:"truncate text-sm",children:t})]})}import{jsx as zu}from"react/jsx-runtime";var r6=({children:e})=>zu("span",{className:"inline-block rounded-md bg-blue-100 px-1 py-0.5 font-mono text-blue-900",children:e});import{jsx as Wo}from"react/jsx-runtime";function s6({apexDomain:e,className:t,imageProps:r}){return e?Wo(Ot,{src:`${oa}${e}`,alt:e,className:i("h-8 w-8 rounded-full sm:h-10 sm:w-10",t),width:20,height:20,draggable:!1,...r}):Wo("div",{className:i("flex h-8 w-8 items-center justify-center rounded-full bg-neutral-100 px-0 sm:h-10 sm:w-10",t),children:Wo(Fa,{className:"h-4 w-4 text-neutral-600 sm:h-5 sm:w-5"})})}import{Link2 as Mi}from"lucide-react";import{useSearchParams as Vu}from"next/navigation";import{useEffect as Hu,useMemo as _u,useRef as Fu}from"react";import Bu from"swr";import{useDebounce as Wu}from"use-debounce";import{Fragment as Di,jsx as K,jsxs as $e}from"react/jsx-runtime";function h6({defaultUrl:e}){let t=Vu(),r=e||(t==null?void 0:t.get("url"))||"https://github.com/dubinc/dub",[o]=Wu(Jo(r),500),a=_u(()=>ra(o||""),[o]),{data:n,isValidating:c}=Bu(o&&`/api/links/metatags?url=${encodeURIComponent(o)}`,ge,{revalidateOnFocus:!1}),{title:s,description:m,image:d}=n||{},l=Fu(null);Hu(()=>{!e&&l.current&&l.current.select()},[e]);let{isMobile:u}=Y();return $e(Di,{children:[!e&&$e("div",{className:"relative flex items-center",children:[K(Mi,{className:"absolute inset-y-0 left-0 my-2 ml-3 w-5 text-neutral-400"}),K("input",{ref:l,name:"url",id:"url",type:"url",autoFocus:!u,className:"block w-full rounded-md border-neutral-200 pl-10 text-sm text-neutral-900 placeholder-neutral-400 shadow-lg focus:border-neutral-500 focus:outline-none focus:ring-neutral-500",placeholder:"Enter your URL",defaultValue:r,"aria-invalid":"true"})]}),$e("div",{className:"relative overflow-hidden rounded-md border border-neutral-300 bg-neutral-50",children:[c&&K("div",{className:"absolute flex h-[250px] w-full flex-col items-center justify-center space-y-4 border-b border-neutral-300 bg-neutral-50",children:K(kt,{})}),d?K("img",{src:d,alt:"Preview",className:"h-[250px] w-full border-b border-neutral-300 object-cover"}):$e("div",{className:"flex h-[250px] w-full flex-col items-center justify-center space-y-4 border-b border-neutral-300",children:[K(la,{className:"h-8 w-8 text-neutral-400"}),K("p",{className:"text-sm text-neutral-400",children:"Enter a link to generate a preview."})]}),$e("div",{className:"grid gap-1 bg-white p-3 text-left",children:[a?K("p",{className:"text-sm text-[#536471]",children:a}):K("div",{className:"mb-1 h-4 w-24 rounded-md bg-neutral-100"}),s?K("h3",{className:"truncate text-sm font-medium text-[#0f1419]",children:s}):K("div",{className:"mb-1 h-4 w-full rounded-md bg-neutral-100"}),m?K("p",{className:"line-clamp-2 text-sm text-[#536471]",children:m}):$e("div",{className:"grid gap-2",children:[K("div",{className:"h-4 w-full rounded-md bg-neutral-100"}),K("div",{className:"h-4 w-48 rounded-md bg-neutral-100"})]})]})]})]})}function v6({defaultUrl:e}){return $e(Di,{children:[$e("div",{className:"relative flex items-center",children:[K(Mi,{className:"absolute inset-y-0 left-0 my-2 ml-3 w-5 text-neutral-400"}),K("input",{name:"url",id:"url",type:"url",disabled:!0,className:"block w-full rounded-md border-neutral-200 pl-10 text-sm text-neutral-900 placeholder-neutral-400 shadow-lg focus:border-neutral-500 focus:outline-none focus:ring-neutral-500",placeholder:"Enter your URL",defaultValue:e||"https://github.com/dubinc/dub"})]}),K("div",{className:"relative overflow-hidden rounded-md border border-neutral-300 bg-neutral-50",children:K("div",{className:"absolute flex h-[250px] w-full flex-col items-center justify-center space-y-4 border-b border-neutral-300 bg-neutral-50",children:K(kt,{})})})]})}import{AnimatePresence as $u}from"framer-motion";import Ei from"js-cookie";import{createContext as Uu,useState as Gu}from"react";import{jsx as $o}from"react/jsx-runtime";var ju=Uu({hidePopup:()=>{}});function P6({children:e,hiddenCookieId:t}){let[r,o]=Gu(Ei.get(t)==="1"),a=()=>{o(!0),Ei.set(t,"1")};return $o(Li,{children:$o(ju.Provider,{value:{hidePopup:a},children:$o($u,{children:!r&&e})})})}import{motion as Ku}from"framer-motion";import{jsx as Ii}from"react/jsx-runtime";function L6({value:e=0,max:t=100,className:r}){return Ii("div",{className:i("h-3 w-full overflow-hidden rounded-full bg-neutral-200",r),children:Ii(Ku.div,{initial:{width:0},animate:{width:e&&t?e/t*100+"%":"0%"},transition:{duration:.5,type:"spring",delay:.2},className:`${e&&t&&e>t?"bg-red-500":"bg-blue-500"} h-full`})})}import{cva as Oi}from"class-variance-authority";import{LayoutGroup as Yu,motion as Zu}from"framer-motion";import qu from"next/link";import{useId as Xu}from"react";import{jsx as Zt,jsxs as Ai}from"react/jsx-runtime";var Ju=Oi("p-4 transition-colors duration-75",{variants:{variant:{default:"text-content-subtle data-[selected=true]:text-content-emphasis data-[selected=false]:hover:text-content-default",accent:"text-content-subtle transition-[color,font-weight] data-[selected=true]:text-blue-600 data-[selected=false]:hover:text-content-default data-[selected=true]:font-medium"}},defaultVariants:{variant:"default"}}),Qu=Oi("absolute bottom-0 w-full px-1.5",{variants:{variant:{default:"text-bg-inverted",accent:"text-blue-600"}},defaultVariants:{variant:"default"}});function F6({variant:e,options:t,selected:r,onSelect:o,className:a}){let n=Xu();return Zt("div",{className:i("flex text-sm",a),children:Zt(Yu,{id:n,children:t.map(({id:c,label:s,href:m,target:d})=>{let l=c===r;return Ai(m?qu:"div",{className:"relative",href:m??"#",target:d??void 0,children:[Ai("button",{type:"button",...o&&!m&&{onClick:()=>o(c)},className:i(Ju({variant:e}),d==="_blank"&&"group flex items-center gap-1.5"),"data-selected":l,"aria-selected":l,children:[s,d==="_blank"&&Zt(xa,{className:"size-2.5"})]}),l&&Zt(Zu.div,{layoutId:"indicator",transition:{duration:.1},className:Qu({variant:e}),children:Zt("div",{className:"h-0.5 rounded-t-full bg-current"})})]},c)})})})}import{jsx as Uo,jsxs as zi}from"react/jsx-runtime";var ep=[{icon:Za,text:"Custom link previews",href:"https://dub.co/help/article/custom-link-previews"},{icon:Da,text:"Geo/device targeting",href:"https://dub.co/help/article/geo-targeting"},{icon:Wa,text:"Password protection",href:"https://dub.co/help/article/password-protected-links"},{icon:Ka,text:"Link expiration",href:"https://dub.co/help/article/link-expiration"},{icon:Ba,text:"Link cloaking",href:"https://dub.co/help/article/link-cloaking"}];function $6(){return zi("div",{className:"p-3",children:[Uo("span",{className:"block text-sm font-semibold text-neutral-600",children:"Advanced link features"}),Uo("div",{className:"mt-2 flex flex-col gap-2.5 text-xs text-neutral-600",children:ep.map(({text:e,icon:t,href:r})=>zi("a",{href:r,target:"_blank",className:"flex items-center gap-2.5 underline decoration-dotted underline-offset-2",children:[Uo(t,{className:"size-3.5 shrink-0"}),e]},e))})]})}import{jsx as Vi,jsxs as tp}from"react/jsx-runtime";function j6({className:e}){return tp("svg",{width:"177",height:"64",viewBox:"0 0 177 64",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:i("h-6 w-auto text-black dark:text-white",e),children:[Vi("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M106.5 8H112.5V31.8666C112.5 31.911 112.501 31.9554 112.501 31.9999C112.501 32.0444 112.5 32.0888 112.5 32.1332V46H106.5V43.4909C104.232 45.0724 101.475 45.9999 98.5003 45.9999C90.7682 45.9999 84.5 39.7319 84.5 31.9999C84.5 24.2679 90.7682 17.9999 98.5003 17.9999C101.475 17.9999 104.232 18.9274 106.5 20.5089V8ZM98.5 39.9996C102.918 39.9996 106.5 36.418 106.5 31.9998C106.5 27.5816 102.918 24 98.5 24C94.0818 24 90.5 27.5816 90.5 31.9998C90.5 36.418 94.0818 39.9996 98.5 39.9996ZM148.5 8.0001H154.5V20.5096C156.768 18.9278 159.526 18.0002 162.5 18.0002C170.233 18.0002 176.501 24.2682 176.501 32.0002C176.501 39.7322 170.233 46.0002 162.5 46.0002C154.768 46.0002 148.5 39.7322 148.5 32.0002V32.0001V8.0001ZM162.5 39.9997C166.918 39.9997 170.5 36.4181 170.5 31.9999C170.5 27.5817 166.918 24.0001 162.5 24.0001C158.082 24.0001 154.5 27.5817 154.5 31.9999C154.5 36.4181 158.082 39.9997 162.5 39.9997ZM122.5 18H116.5V32C116.5 33.8385 116.862 35.659 117.566 37.3576C118.269 39.0561 119.301 40.5995 120.601 41.8995C121.901 43.1995 123.444 44.2307 125.143 44.9343C126.841 45.6379 128.662 46 130.5 46C132.339 46 134.159 45.6379 135.858 44.9343C137.557 44.2307 139.1 43.1995 140.4 41.8995C141.7 40.5995 142.731 39.0561 143.435 37.3576C144.139 35.659 144.501 33.8385 144.501 32H144.5V18H138.5V32H138.5C138.5 34.1216 137.657 36.1563 136.157 37.6566C134.657 39.1568 132.622 39.9996 130.5 39.9996C128.378 39.9996 126.344 39.1568 124.843 37.6566C123.343 36.1563 122.5 34.1216 122.5 32H122.5V18Z",fill:"currentColor"}),Vi("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M32.5 64C50.1731 64 64.5 49.6731 64.5 32C64.5 20.1555 58.0648 9.81393 48.5 4.28099V31.9999V47.9998H40.5V45.8594C38.1466 47.2207 35.4143 47.9999 32.5 47.9999C23.6634 47.9999 16.5 40.8364 16.5 31.9999C16.5 23.1633 23.6634 15.9999 32.5 15.9999C35.4143 15.9999 38.1466 16.779 40.5 18.1404V1.00812C37.943 0.350018 35.2624 0 32.5 0C14.8269 0 0.500038 14.3269 0.500038 32C0.500038 49.6731 14.8269 64 32.5 64Z",fill:"currentColor"})]})}export{to as AUTOPLAY_DEFAULT_DELAY,yb as Accordion,Ui as AccordionContent,Wi as AccordionItem,$i as AccordionTrigger,$6 as AdvancedLinkFeaturesTooltip,wp as Africa,Ip as Airtm,Yi as Alert,qi as AlertDescription,Zi as AlertTitle,Rp as Amazon,Fp as AndroidLogo,Se as AnimatedSizeContainer,Bp as AppleLogo,Wp as ArrowBoldUp,$p as ArrowRight,Up as ArrowTrendUp,Gp as ArrowTurnLeft,jp as ArrowTurnRight2,xa as ArrowUpRight,rp as ArrowUpRight2,Kp as ArrowsOppositeDirectionX,Yp as ArrowsOppositeDirectionY,Np as Asia,_o as AuthButton,Tb as Avatar,k3 as Background,ur as Badge,Zp as BadgeCheck,qp as BadgeCheck2Fill,Zb as BadgeTooltip,Xp as Bell,Jp as Blog,Ot as BlurImage,Qp as Bolt,e0 as BoltFill,r0 as Book2,or as Book2Fill,o0 as Book2Small,t0 as BookOpen,a0 as Books2,n0 as BoxArchive,i0 as BracketsCurly,ya as BriefcaseFill,s0 as Brush,l0 as BulletList,wa as BulletListFill,te as Button,qb as ButtonTooltip,ci as COMPARE_PAGES,I3 as CUSTOMER_STORIES,c0 as Calculator,yn as Calendar,p0 as Calendar6,m0 as CalendarDays,d0 as CalendarIcon,u0 as CalendarRefresh,hp as CardAmex,vp as CardDiscover,y1 as CardList,xp as CardMastercard,yp as CardVisa,f0 as Cards,g0 as CaretUpFill,Ts as Carousel,Ls as CarouselContent,Ms as CarouselItem,H1 as CarouselNavBar,Es as CarouselNext,Ds as CarouselPrevious,Y1 as CarouselThumbnail,K1 as CarouselThumbnails,Ap as CashApp,b0 as ChartActivity2,h0 as ChartArea2,v0 as ChartLine,Tp as ChatGPT,Na as Check,ar as Check2,ut as Checkbox,Ca as CheckboxCheckedFill,ka as CheckboxUnchecked,x0 as ChevronLeft,y0 as ChevronRight,Pa as CircleCheck,w0 as CircleCheckFill,N0 as CircleDollar,C0 as CircleDotted,Sa as CircleHalfDottedCheck,Ra as CircleHalfDottedClock,Ta as CircleInfo,k0 as CirclePercentage,P0 as CirclePlay,S0 as CirclePlayFill,R0 as CircleQuestion,T0 as CircleUser,Zr as CircleWarning,L0 as CircleXmark,M0 as Circles,D0 as Circles3,Li as ClientOnly,La as CloudUpload,E0 as Code,I0 as ColorPalette2,Kv as Combobox,j6 as CompositeLogo,A0 as ConnectedDots,z0 as ConnectedDots4,O0 as ConnectedDotsFill,V0 as Connections3,na as Copy,KN as CopyButton,JN as CopyText,H0 as CreditCard,_0 as Crosshairs3,F0 as Crown,op as CrownSmall,B0 as Cube,W0 as CubeSettings,$0 as CubeSettingsFill,U0 as CurrencyDollar,Ma as CursorRays,G0 as DatabaseKey,so as DatePickerContext,Dx as DateRangePicker,j0 as Desktop,K0 as DiamondTurnRight,nr as DiamondTurnRightFill,Y0 as Directions,Z0 as Discount,q0 as Dots,_x as DotsPattern,X0 as Download,st as DubAnalyticsIcon,Jt as DubApiIcon,ap as DubCraftedShield,lt as DubLinksIcon,ct as DubPartnersIcon,Yr as DubProductIcon,Sn as DubStatusBadge,J0 as Duplicate,pr as DynamicTooltipWrapper,Da as Earth,Q0 as EarthPosition,Hy as EditColumnsButton,Kx as EmptyState,ef as Envelope,tf as EnvelopeAlert,rf as EnvelopeArrowRight,Ea as EnvelopeFill,Cp as Europe,ia as ExpandingArrow,Ia as Eye,Aa as EyeSlash,Fr as FEATURES_LIST,cp as Facebook,Oa as FeatherFill,Lp as Figma,of as FileContent,a2 as FileUpload,af as FileZip2,L2 as Filter,sf as Filter2,nf as FilterBars,cf as Flag2,za as Flag6,lf as FlagWavy,df as Flask,mf as FlaskSmall,uf as Folder,hf as Folder5,pf as FolderBookmark,ff as FolderLock,gf as FolderPlus,bf as FolderShield,ON as Footer,z2 as Form,vf as GamingConsole,xf as Gauge6,Va as Gear,yf as Gear2,wf as Gear3,Nf as Gem,Ha as Gift,Cf as GiftFill,Mp as GitHubEnhanced,Qt as Github,kf as Globe,Fa as Globe2,_a as GlobePointer,Pf as GlobeSearch,fa as Go,dp as Google,Dp as GoogleEnhanced,Sf as GreekTemple,Xe as Grid,Rf as GridIcon,Tf as GridLayoutRows,Lf as GridPlus,Mf as GripDotsVertical,Df as Headset,Ef as HeartFill,If as HexadecagonStar,Af as History,Of as Hyperlink,np as IOSAppStore,e6 as IconMenu,zf as Icosahedron,Ba as Incognito,Vf as InfinityIcon,Kb as InfoTooltip,r6 as InlineSnippet,Qc as Input,Hf as InputField,_f as InputPassword,Wa as InputPasswordPointer,$a as InputSearch,u4 as InputSelect,mp as Instagram,Ff as InvoiceDollar,Bf as Key,sn as KeyboardShortcutContext,Vh as KeyboardShortcutProvider,di as LEGAL_PAGES,yd as Label,Wf as LayoutSidebar,$f as License,ir as LifeRing,Uf as LinesY,jf as Link4,Gf as LinkBroken,s6 as LinkLogo,h6 as LinkPreview,v6 as LinkPreviewPlaceholder,er as LinkedIn,jb as LinkifyTooltipContent,kt as LoadingCircle,lp as LoadingDots,ke as LoadingSpinner,Kf as LocationPin,Yf as Lock,Zf as LockFill,Ht as Logo,sa as Magic,qf as Magnifier,Xf as MapPosition,ip as MarkdownIcon,Jf as MarketingTarget,sp as MatrixLines,Br as MaxWidthWrapper,Qf as Menu3,k4 as MenuItem,eg as MessageSmile,sr as MicrophoneFill,A4 as MiniAreaChart,lr as Minus,tg as MobilePhone,F4 as Modal,rg as MoneyBill,og as MoneyBill2,ag as MoneyBills2,ng as Msgs,$w as Nav,zo as NavContext,aN as NavMobile,Wr as NavWordmark,kp as NorthAmerica,ig as Note,fg as NucleoPhoto,K4 as NumberStepper,Yb as NumberTooltip,Pp as Oceania,sg as OfficeBuilding,fb as PLAN_FEATURE_ICONS,Ua as Page2,q4 as PaginationControls,lg as Paintbrush,cg as Palette2,dg as PaperPlane,Op as Payoneer,zp as Paypal,ug as Pen2,mg as PenWriting,pg as PercentageArrowDown,la as Photo,ga as Php,gg as Plug2,dt as Plus,bg as Plus2,ve as Popover,P6 as Popup,ju as PopupContext,hg as Post,up as Prisma,ua as ProductHunt,L6 as ProgressBar,vg as Pyramid,ba as Python,xg as QRCode,_t as RESOURCES,_d as RadioGroup,Fd as RadioGroupItem,pa as Raycast,yg as Receipt2,Ga as ReferredVia,wg as Refresh2,Ng as Robot,ha as Ruby,Oo as SDKS,A3 as SOCIAL_LINKS,li as SOLUTIONS,ja as SatelliteDish,Cg as ScanText,kg as Scribble,ay as Sheet,Pg as ShieldAlert,Sg as ShieldCheck,Rg as ShieldKeyhole,Tg as ShieldSlash,Lg as ShieldUser,ly as ShimmerDots,Mg as Shuffle,Gb as SimpleTooltipContent,pp as Slack,my as Slider,Dg as Sliders,gy as SmartDateTimePicker,ca as SortOrder,Sp as SouthAmerica,Eg as Sparkle3,Ep as Spotify,Ig as SquareChart,Ag as SquareLayoutGrid5,Og as SquareLayoutGrid6,zg as SquareUserSparkle2,Vg as SquareXmark,Hg as Stars2,Ny as StatusBadge,Vp as Stripe,Hp as StripeLink,da as Success,My as Switch,Kg as TV,F6 as TabSelect,l3 as Table,_g as TableIcon,Fg as TableRows2,Bg as Tablet,Wg as Tag,$g as Tags,ma as Tick,fp as TikTok,Ka as Timer2,gp as Tinybird,Ya as Toggle2Fill,f3 as ToggleGroup,Ug as Toggles,Lb as TokenAvatar,Q as Tooltip,Ub as TooltipContent,$b as TooltipProvider,Gg as Trash,jg as TriangleWarning,tr as Twitter,va as Typescript,N3 as UTMBuilder,Tm as UTM_PARAMETERS,Yg as UiCard,bp as Unsplash,Zg as User,qg as UserCheck,Xg as UserCrown,Jg as UserDelete,Qg as UserFocus,eb as UserMinus,tb as UserPlus,rb as UserXmark,ob as Users,nb as Users2,ib as Users6,Pt as UsersFill,ab as UsersSettings,_p as Venmo,sb as Versions2,Za as Views,lb as Watch,cb as Webhook,db as Window,mb as WindowSearch,ub as WindowSettings,Si as Wordmark,pb as Xmark,rr as YouTube,ts as badgeVariants,se as buttonVariants,Qi as getUserAvatarUrl,Co as menuItemVariants,Vo as navItems,om as statusBadgeVariants,he as useCarousel,rn as useCarouselActiveIndex,oh as useColumnVisibility,sh as useCookies,pt as useCopyToClipboard,uh as useCurrentAnchor,bh as useCurrentSubdomain,yh as useEnterSubmit,kh as useInViewport,Rh as useInputFocused,Dh as useIntersectionObserver,Ie as useKeyboardShortcut,oo as useLocalStorage,Y as useMediaQuery,Wh as useOptimisticUpdate,ev as usePagination,ov as useRemoveGAParams,gr as useResizeObserver,dn as useRouterStuff,pn as useScroll,Ae as useScrollProgress,s3 as useTable,cn as useTablePagination,vv as useToastWithUndo};
53
+ </svg>`;function Wr({variant:e="full",isInApp:t,className:r}){let{domain:o="dub.co"}=uu(),{theme:a}=fu(zo),[n,c]=gu(!1),s=pu(l=>{l.preventDefault(),c(!0)},[]),[,m]=pt();function d(l){bu.promise(m(l),{success:"Copied to clipboard!",error:"Failed to copy to clipboard"})}return Ri(Be.Root,{open:n,onOpenChange:c,children:[q(Be.Anchor,{asChild:!0,children:q("div",{onContextMenu:s,className:"max-w-fit",children:e==="full"?q(Si,{className:r}):q(Ht,{className:i("h-8 w-8 transition-all duration-75 active:scale-95",r)})})}),q(Be.Portal,{children:q(Be.Content,{sideOffset:14,align:"start",className:i("z-50 -mt-1.5",!t&&"-translate-x-8",a==="dark"&&"dark"),onClick:l=>{l.stopPropagation(),c(!1)},children:Ri("div",{className:"grid gap-1 rounded-lg border border-neutral-200 bg-white p-2 drop-shadow-sm sm:min-w-[240px] dark:border-white/[0.15] dark:bg-black",children:[q(Gt,{text:"Copy Logo as SVG",variant:"outline",onClick:()=>d(hu),icon:q(Ht,{className:"h-4 w-4"})}),q(Gt,{text:"Copy Wordmark as SVG",variant:"outline",onClick:()=>d(vu),icon:q(mu,{strokeWidth:2,className:"h-4 w-4"})}),q(Gt,{text:"Brand Guidelines",variant:"outline",onClick:()=>window.open("https://dub.co/brand","_blank"),icon:q(lu,{strokeWidth:2,className:"h-4 w-4"})}),t||o!="dub.co"?q(Gt,{text:"Home Page",variant:"outline",onClick:()=>window.open(`https://dub.co${t?"/home":""}`,"_blank"),icon:q(cu,{strokeWidth:2,className:"h-4 w-4"})}):q(Gt,{text:"Dashboard",variant:"outline",onClick:()=>window.open("https://app.dub.co","_blank"),icon:q(du,{strokeWidth:2,className:"h-4 w-4"})})]})})})]})}function Gt({className:e,...t}){return q(te,{className:i("h-9 justify-start px-3 font-medium hover:text-neutral-700 dark:text-white/70 dark:hover:bg-white/[0.15] dark:hover:text-white",e),...t})}import{jsx as I,jsxs as $}from"react/jsx-runtime";var Cu=[{name:"Twitter",icon:tr,href:"https://twitter.com/dubdotco"},{name:"LinkedIn",icon:er,href:"https://www.linkedin.com/company/dubinc"},{name:"GitHub",icon:Qt,href:"https://github.com/dubinc/dub"},{name:"YouTube",icon:rr,href:"https://www.youtube.com/@dubdotco"}],jt={product:[...Fr.filter(({title:e})=>e!=="Dub Integrations").map(({id:e,title:t,href:r})=>({id:e,name:t,href:r})),{id:null,name:"Dub Enterprise",href:"/enterprise"}],solutions:[{name:"Marketing attribution",href:"/analytics"},{name:"Content creators",href:"/solutions/creators"},{name:"Affiliate management",href:"/partners"}],resources:[{name:"Docs",href:"/docs/introduction"},{name:"Help Center",href:"/help"},{name:"Integrations",href:"/integrations"},{name:"Pricing",href:"/pricing"},{name:"Affiliates",href:"https://partners.dub.co/dub",target:"_blank"}],company:[{name:"About",href:"/about"},{name:"Blog",href:"/blog"},{name:"Careers",href:"/careers"},{name:"Changelog",href:"/changelog"},{name:"Customers",href:"/customers"},{name:"Brand",href:"/brand"},{name:"Contact",href:"/contact"},{name:"Privacy",href:"/privacy"}],compare:ci.map(({name:e,slug:t})=>({name:e,href:`/compare/${t}`,product:"links"})).concat(["Rewardful","PartnerStack","Tolt"].map(e=>({name:e,href:e==="Rewardful"?"/blog/dub-vs-rewardful":`/help/article/migrating-from-${e.toLowerCase()}`,product:"partners"})))},Kt="text-sm font-medium text-neutral-900",Yt="flex flex-col mt-2.5 gap-3.5",nt="flex items-center gap-2 text-sm text-neutral-500 hover:text-neutral-700 transition-colors duration-75";function ON({staticDomain:e,className:t}){let{domain:r="dub.co"}=wu();e&&(r=e);let[o,a]=Nu(!1);return I(Br,{className:i("relative z-10 overflow-hidden border border-b-0 border-neutral-200 bg-white/50 py-16 backdrop-blur-lg md:rounded-t-2xl",t),children:$("footer",{children:[$("div",{className:"xl:grid xl:grid-cols-3 xl:gap-8",children:[$("div",{className:"flex flex-col gap-6",children:[I("div",{className:"grow",children:$(We,{href:_("/",r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:"Logo"}),className:"block max-w-fit",children:[$("span",{className:"sr-only",children:[process.env.NEXT_PUBLIC_APP_NAME," Logo"]}),I(Wr,{className:"h-8 text-neutral-800"})]})}),I("div",{className:"flex items-center gap-3",children:Cu.map(({name:n,icon:c,href:s})=>$("a",{href:s,target:"_blank",rel:"noreferrer",className:"group rounded-full p-1",children:[I("span",{className:"sr-only",children:n}),I(c,{className:"size-4 text-neutral-900 transition-colors duration-75 group-hover:text-neutral-600"})]},n))})]}),$("div",{className:"mt-16 grid grid-cols-2 gap-4 xl:col-span-2 xl:mt-0",children:[$("div",{className:"md:grid md:grid-cols-2",children:[$("div",{className:"grid gap-8",children:[$("div",{children:[I("h3",{className:Kt,children:"Product"}),I("ul",{role:"list",className:Yt,children:jt.product.map(n=>I("li",{children:$(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:nt,children:[n.id&&I(Yr,{product:n.id}),n.name]})},n.name))})]}),$("div",{children:[I("h3",{className:Kt,children:"Solutions"}),I("ul",{role:"list",className:Yt,children:jt.solutions.map(n=>I("li",{children:I(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:nt,children:n.name})},n.name))})]})]}),$("div",{className:"mt-10 md:mt-0",children:[I("h3",{className:Kt,children:"Resources"}),I("ul",{role:"list",className:Yt,children:jt.resources.map(n=>I("li",{children:$(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),target:n.target,className:i(nt,"gap-1"),children:[n.name,n.target&&I(Ga,{className:"size-3.5"})]})},n.name))})]})]}),$("div",{className:"md:grid md:grid-cols-2",children:[I("div",{className:"grid gap-8",children:$("div",{children:[I("h3",{className:Kt,children:"Company"}),$("ul",{role:"list",className:Yt,children:[jt.company.map(n=>I("li",{children:I(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:i(nt,"gap-1"),children:n.name})},n.name)),I("li",{className:"-mt-1",children:I(ve,{content:I("div",{className:"flex w-screen flex-col gap-1 p-1.5 text-sm focus-visible:outline-none sm:w-auto sm:min-w-[200px]",children:di.map(n=>I(We,{href:_(`/legal/${n.slug}`,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:i(Co({variant:"default"}),nt,"justify-start font-normal"),children:n.name},n.name))}),openPopover:o,setOpenPopover:a,children:$("button",{className:nt,children:["Legal",I(xu,{className:"size-3.5"})]})})})]})]})}),$("div",{className:"mt-10 md:mt-0",children:[I("h3",{className:Kt,children:"Compare"}),I("ul",{role:"list",className:Yt,children:jt.compare.map(n=>I("li",{children:$(We,{href:_(n.href,r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:n.name}),className:nt,children:[I(Yr,{product:n.product}),n.name]})},n.name))})]})]})]})]}),$("div",{className:"mt-12 grid grid-cols-1 items-center gap-8 sm:grid-cols-3",children:[I(Sn,{}),I(We,{href:_("/blog/soc2",r,{utm_source:"Custom Domain",utm_medium:"Footer",utm_campaign:r,utm_content:"SOC2"}),className:"flex sm:justify-center",children:I(yu,{src:"https://assets.dub.co/misc/soc2.svg",alt:"AICPA SOC 2 Type II Certified",width:63,height:32,className:"h-8 transition-[filter] duration-75 hover:brightness-90"})}),$("p",{className:"text-xs text-neutral-500 sm:text-right",children:["\xA9 ",new Date().getFullYear()," Dub Technologies, Inc."]})]})]})})}import{AnimatePresence as ku,motion as Pu}from"framer-motion";import{useEffect as Su,useState as Ru}from"react";import{jsx as Ti}from"react/jsx-runtime";var Li=({children:e,fallback:t,fadeInDuration:r=.5,className:o})=>{let[a,n]=Ru(!1);Su(()=>{n(!0)},[]);let c=r?Pu.div:"div";return Ti(ku,{children:a?Ti(c,{...r?{initial:{opacity:0},animate:{opacity:1},transition:{duration:r}}:{},className:o,children:e}):t||null})};import{cva as Tu}from"class-variance-authority";import{toast as Lu}from"sonner";import{jsx as Bo,jsxs as Du}from"react/jsx-runtime";var Mu=Tu("relative group rounded-full p-1.5 transition-all duration-75",{variants:{variant:{default:"bg-transparent hover:bg-neutral-100 active:bg-neutral-200",neutral:"bg-transparent hover:bg-neutral-100 active:bg-neutral-200"}},defaultVariants:{variant:"default"}});function KN({variant:e="default",value:t,className:r,icon:o,successMessage:a}){let[n,c]=pt(),s=o||na;return Du("button",{onClick:m=>{m.stopPropagation(),Lu.promise(c(t),{success:a||"Copied to clipboard!"})},className:i(Mu({variant:e}),r),type:"button",children:[Bo("span",{className:"sr-only",children:"Copy"}),n?Bo(ma,{className:"h-3.5 w-3.5"}):Bo(s,{className:"h-3.5 w-3.5"})]})}import{toast as Eu}from"sonner";import{jsx as Iu}from"react/jsx-runtime";function JN({value:e,children:t,className:r,successMessage:o}){let[a,n]=pt();return Iu("button",{onClick:c=>{c.stopPropagation(),Eu.promise(n(e),{success:o||"Copied to clipboard!"})},type:"button",className:i("cursor-copy text-sm text-neutral-700 decoration-dotted underline-offset-2 hover:underline",a&&"cursor-default",r),children:t})}import{jsx as Au,jsxs as Ou}from"react/jsx-runtime";function e6({icon:e,text:t}){return Ou("div",{className:"flex items-center justify-start space-x-2 truncate",children:[e,Au("p",{className:"truncate text-sm",children:t})]})}import{jsx as zu}from"react/jsx-runtime";var r6=({children:e})=>zu("span",{className:"inline-block rounded-md bg-blue-100 px-1 py-0.5 font-mono text-blue-900",children:e});import{jsx as Wo}from"react/jsx-runtime";function s6({apexDomain:e,className:t,imageProps:r}){return e?Wo(Ot,{src:`${oa}${e}`,alt:e,className:i("h-8 w-8 rounded-full sm:h-10 sm:w-10",t),width:20,height:20,draggable:!1,...r}):Wo("div",{className:i("flex h-8 w-8 items-center justify-center rounded-full bg-neutral-100 px-0 sm:h-10 sm:w-10",t),children:Wo(Fa,{className:"h-4 w-4 text-neutral-600 sm:h-5 sm:w-5"})})}import{Link2 as Mi}from"lucide-react";import{useSearchParams as Vu}from"next/navigation";import{useEffect as Hu,useMemo as _u,useRef as Fu}from"react";import Bu from"swr";import{useDebounce as Wu}from"use-debounce";import{Fragment as Di,jsx as K,jsxs as $e}from"react/jsx-runtime";function h6({defaultUrl:e}){let t=Vu(),r=e||(t==null?void 0:t.get("url"))||"https://github.com/dubinc/dub",[o]=Wu(Jo(r),500),a=_u(()=>ra(o||""),[o]),{data:n,isValidating:c}=Bu(o&&`/api/links/metatags?url=${encodeURIComponent(o)}`,ge,{revalidateOnFocus:!1}),{title:s,description:m,image:d}=n||{},l=Fu(null);Hu(()=>{!e&&l.current&&l.current.select()},[e]);let{isMobile:u}=Y();return $e(Di,{children:[!e&&$e("div",{className:"relative flex items-center",children:[K(Mi,{className:"absolute inset-y-0 left-0 my-2 ml-3 w-5 text-neutral-400"}),K("input",{ref:l,name:"url",id:"url",type:"url",autoFocus:!u,className:"block w-full rounded-md border-neutral-200 pl-10 text-sm text-neutral-900 placeholder-neutral-400 shadow-lg focus:border-neutral-500 focus:outline-none focus:ring-neutral-500",placeholder:"Enter your URL",defaultValue:r,"aria-invalid":"true"})]}),$e("div",{className:"relative overflow-hidden rounded-md border border-neutral-300 bg-neutral-50",children:[c&&K("div",{className:"absolute flex h-[250px] w-full flex-col items-center justify-center space-y-4 border-b border-neutral-300 bg-neutral-50",children:K(kt,{})}),d?K("img",{src:d,alt:"Preview",className:"h-[250px] w-full border-b border-neutral-300 object-cover"}):$e("div",{className:"flex h-[250px] w-full flex-col items-center justify-center space-y-4 border-b border-neutral-300",children:[K(la,{className:"h-8 w-8 text-neutral-400"}),K("p",{className:"text-sm text-neutral-400",children:"Enter a link to generate a preview."})]}),$e("div",{className:"grid gap-1 bg-white p-3 text-left",children:[a?K("p",{className:"text-sm text-[#536471]",children:a}):K("div",{className:"mb-1 h-4 w-24 rounded-md bg-neutral-100"}),s?K("h3",{className:"truncate text-sm font-medium text-[#0f1419]",children:s}):K("div",{className:"mb-1 h-4 w-full rounded-md bg-neutral-100"}),m?K("p",{className:"line-clamp-2 text-sm text-[#536471]",children:m}):$e("div",{className:"grid gap-2",children:[K("div",{className:"h-4 w-full rounded-md bg-neutral-100"}),K("div",{className:"h-4 w-48 rounded-md bg-neutral-100"})]})]})]})]})}function v6({defaultUrl:e}){return $e(Di,{children:[$e("div",{className:"relative flex items-center",children:[K(Mi,{className:"absolute inset-y-0 left-0 my-2 ml-3 w-5 text-neutral-400"}),K("input",{name:"url",id:"url",type:"url",disabled:!0,className:"block w-full rounded-md border-neutral-200 pl-10 text-sm text-neutral-900 placeholder-neutral-400 shadow-lg focus:border-neutral-500 focus:outline-none focus:ring-neutral-500",placeholder:"Enter your URL",defaultValue:e||"https://github.com/dubinc/dub"})]}),K("div",{className:"relative overflow-hidden rounded-md border border-neutral-300 bg-neutral-50",children:K("div",{className:"absolute flex h-[250px] w-full flex-col items-center justify-center space-y-4 border-b border-neutral-300 bg-neutral-50",children:K(kt,{})})})]})}import{AnimatePresence as $u}from"framer-motion";import Ei from"js-cookie";import{createContext as Uu,useState as Gu}from"react";import{jsx as $o}from"react/jsx-runtime";var ju=Uu({hidePopup:()=>{}});function P6({children:e,hiddenCookieId:t}){let[r,o]=Gu(Ei.get(t)==="1"),a=()=>{o(!0),Ei.set(t,"1")};return $o(Li,{children:$o(ju.Provider,{value:{hidePopup:a},children:$o($u,{children:!r&&e})})})}import{motion as Ku}from"framer-motion";import{jsx as Ii}from"react/jsx-runtime";function L6({value:e=0,max:t=100,className:r}){return Ii("div",{className:i("h-3 w-full overflow-hidden rounded-full bg-neutral-200",r),children:Ii(Ku.div,{initial:{width:0},animate:{width:e&&t?e/t*100+"%":"0%"},transition:{duration:.5,type:"spring",delay:.2},className:`${e&&t&&e>t?"bg-red-500":"bg-blue-500"} h-full`})})}import{cva as Oi}from"class-variance-authority";import{LayoutGroup as Yu,motion as Zu}from"framer-motion";import qu from"next/link";import{useId as Xu}from"react";import{jsx as Zt,jsxs as Ai}from"react/jsx-runtime";var Ju=Oi("p-4 transition-colors duration-75",{variants:{variant:{default:"text-content-subtle data-[selected=true]:text-content-emphasis data-[selected=false]:hover:text-content-default",accent:"text-content-subtle transition-[color,font-weight] data-[selected=true]:text-blue-600 data-[selected=false]:hover:text-content-default data-[selected=true]:font-medium"}},defaultVariants:{variant:"default"}}),Qu=Oi("absolute bottom-0 w-full px-1.5",{variants:{variant:{default:"text-bg-inverted",accent:"text-blue-600"}},defaultVariants:{variant:"default"}});function F6({variant:e,options:t,selected:r,onSelect:o,className:a}){let n=Xu();return Zt("div",{className:i("flex text-sm",a),children:Zt(Yu,{id:n,children:t.map(({id:c,label:s,href:m,target:d})=>{let l=c===r;return Ai(m?qu:"div",{className:"relative",href:m??"#",target:d??void 0,children:[Ai("button",{type:"button",...o&&!m&&{onClick:()=>o(c)},className:i(Ju({variant:e}),d==="_blank"&&"group flex items-center gap-1.5"),"data-selected":l,"aria-selected":l,children:[s,d==="_blank"&&Zt(xa,{className:"size-2.5"})]}),l&&Zt(Zu.div,{layoutId:"indicator",transition:{duration:.1},className:Qu({variant:e}),children:Zt("div",{className:"h-0.5 rounded-t-full bg-current"})})]},c)})})})}import{jsx as Uo,jsxs as zi}from"react/jsx-runtime";var ep=[{icon:Za,text:"Custom link previews",href:"https://dub.co/help/article/custom-link-previews"},{icon:Da,text:"Geo/device targeting",href:"https://dub.co/help/article/geo-targeting"},{icon:Wa,text:"Password protection",href:"https://dub.co/help/article/password-protected-links"},{icon:Ka,text:"Link expiration",href:"https://dub.co/help/article/link-expiration"},{icon:Ba,text:"Link cloaking",href:"https://dub.co/help/article/link-cloaking"}];function $6(){return zi("div",{className:"p-3",children:[Uo("span",{className:"block text-sm font-semibold text-neutral-600",children:"Advanced link features"}),Uo("div",{className:"mt-2 flex flex-col gap-2.5 text-xs text-neutral-600",children:ep.map(({text:e,icon:t,href:r})=>zi("a",{href:r,target:"_blank",className:"flex items-center gap-2.5 underline decoration-dotted underline-offset-2",children:[Uo(t,{className:"size-3.5 shrink-0"}),e]},e))})]})}import{jsx as Vi,jsxs as tp}from"react/jsx-runtime";function j6({className:e}){return tp("svg",{width:"177",height:"64",viewBox:"0 0 177 64",fill:"none",xmlns:"http://www.w3.org/2000/svg",className:i("h-6 w-auto text-black dark:text-white",e),children:[Vi("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M106.5 8H112.5V31.8666C112.5 31.911 112.501 31.9554 112.501 31.9999C112.501 32.0444 112.5 32.0888 112.5 32.1332V46H106.5V43.4909C104.232 45.0724 101.475 45.9999 98.5003 45.9999C90.7682 45.9999 84.5 39.7319 84.5 31.9999C84.5 24.2679 90.7682 17.9999 98.5003 17.9999C101.475 17.9999 104.232 18.9274 106.5 20.5089V8ZM98.5 39.9996C102.918 39.9996 106.5 36.418 106.5 31.9998C106.5 27.5816 102.918 24 98.5 24C94.0818 24 90.5 27.5816 90.5 31.9998C90.5 36.418 94.0818 39.9996 98.5 39.9996ZM148.5 8.0001H154.5V20.5096C156.768 18.9278 159.526 18.0002 162.5 18.0002C170.233 18.0002 176.501 24.2682 176.501 32.0002C176.501 39.7322 170.233 46.0002 162.5 46.0002C154.768 46.0002 148.5 39.7322 148.5 32.0002V32.0001V8.0001ZM162.5 39.9997C166.918 39.9997 170.5 36.4181 170.5 31.9999C170.5 27.5817 166.918 24.0001 162.5 24.0001C158.082 24.0001 154.5 27.5817 154.5 31.9999C154.5 36.4181 158.082 39.9997 162.5 39.9997ZM122.5 18H116.5V32C116.5 33.8385 116.862 35.659 117.566 37.3576C118.269 39.0561 119.301 40.5995 120.601 41.8995C121.901 43.1995 123.444 44.2307 125.143 44.9343C126.841 45.6379 128.662 46 130.5 46C132.339 46 134.159 45.6379 135.858 44.9343C137.557 44.2307 139.1 43.1995 140.4 41.8995C141.7 40.5995 142.731 39.0561 143.435 37.3576C144.139 35.659 144.501 33.8385 144.501 32H144.5V18H138.5V32H138.5C138.5 34.1216 137.657 36.1563 136.157 37.6566C134.657 39.1568 132.622 39.9996 130.5 39.9996C128.378 39.9996 126.344 39.1568 124.843 37.6566C123.343 36.1563 122.5 34.1216 122.5 32H122.5V18Z",fill:"currentColor"}),Vi("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M32.5 64C50.1731 64 64.5 49.6731 64.5 32C64.5 20.1555 58.0648 9.81393 48.5 4.28099V31.9999V47.9998H40.5V45.8594C38.1466 47.2207 35.4143 47.9999 32.5 47.9999C23.6634 47.9999 16.5 40.8364 16.5 31.9999C16.5 23.1633 23.6634 15.9999 32.5 15.9999C35.4143 15.9999 38.1466 16.779 40.5 18.1404V1.00812C37.943 0.350018 35.2624 0 32.5 0C14.8269 0 0.500038 14.3269 0.500038 32C0.500038 49.6731 14.8269 64 32.5 64Z",fill:"currentColor"})]})}export{to as AUTOPLAY_DEFAULT_DELAY,yb as Accordion,Ui as AccordionContent,Wi as AccordionItem,$i as AccordionTrigger,$6 as AdvancedLinkFeaturesTooltip,wp as Africa,Ip as Airtm,Yi as Alert,qi as AlertDescription,Zi as AlertTitle,Rp as Amazon,Fp as AndroidLogo,Se as AnimatedSizeContainer,Bp as AppleLogo,Wp as ArrowBoldUp,$p as ArrowRight,Up as ArrowTrendUp,Gp as ArrowTurnLeft,jp as ArrowTurnRight2,xa as ArrowUpRight,rp as ArrowUpRight2,Kp as ArrowsOppositeDirectionX,Yp as ArrowsOppositeDirectionY,Np as Asia,_o as AuthButton,Tb as Avatar,k3 as Background,ur as Badge,Zp as BadgeCheck,qp as BadgeCheck2Fill,Zb as BadgeTooltip,Xp as Bell,Jp as Blog,Ot as BlurImage,Qp as Bolt,e0 as BoltFill,r0 as Book2,or as Book2Fill,o0 as Book2Small,t0 as BookOpen,a0 as Books2,n0 as BoxArchive,i0 as BracketsCurly,ya as BriefcaseFill,s0 as Brush,l0 as BulletList,wa as BulletListFill,te as Button,qb as ButtonTooltip,ci as COMPARE_PAGES,I3 as CUSTOMER_STORIES,c0 as Calculator,yn as Calendar,p0 as Calendar6,m0 as CalendarDays,d0 as CalendarIcon,u0 as CalendarRefresh,hp as CardAmex,vp as CardDiscover,y1 as CardList,xp as CardMastercard,yp as CardVisa,f0 as Cards,g0 as CaretUpFill,Ts as Carousel,Ls as CarouselContent,Ms as CarouselItem,H1 as CarouselNavBar,Es as CarouselNext,Ds as CarouselPrevious,Y1 as CarouselThumbnail,K1 as CarouselThumbnails,Ap as CashApp,b0 as ChartActivity2,h0 as ChartArea2,v0 as ChartLine,Tp as ChatGPT,Na as Check,ar as Check2,ut as Checkbox,Ca as CheckboxCheckedFill,ka as CheckboxUnchecked,x0 as ChevronLeft,y0 as ChevronRight,Pa as CircleCheck,w0 as CircleCheckFill,N0 as CircleDollar,C0 as CircleDotted,Sa as CircleHalfDottedCheck,Ra as CircleHalfDottedClock,Ta as CircleInfo,k0 as CirclePercentage,P0 as CirclePlay,S0 as CirclePlayFill,R0 as CircleQuestion,T0 as CircleUser,Zr as CircleWarning,L0 as CircleXmark,M0 as Circles,D0 as Circles3,Li as ClientOnly,La as CloudUpload,E0 as Code,I0 as ColorPalette2,Kv as Combobox,j6 as CompositeLogo,A0 as ConnectedDots,z0 as ConnectedDots4,O0 as ConnectedDotsFill,V0 as Connections3,na as Copy,KN as CopyButton,JN as CopyText,H0 as CreditCard,_0 as Crosshairs3,F0 as Crown,op as CrownSmall,B0 as Cube,W0 as CubeSettings,$0 as CubeSettingsFill,U0 as CurrencyDollar,Ma as CursorRays,G0 as DatabaseKey,so as DatePickerContext,Dx as DateRangePicker,j0 as Desktop,K0 as DiamondTurnRight,nr as DiamondTurnRightFill,Y0 as Directions,Z0 as Discount,q0 as Dots,_x as DotsPattern,X0 as Download,st as DubAnalyticsIcon,Jt as DubApiIcon,ap as DubCraftedShield,lt as DubLinksIcon,ct as DubPartnersIcon,Yr as DubProductIcon,Sn as DubStatusBadge,J0 as Duplicate,pr as DynamicTooltipWrapper,Da as Earth,Q0 as EarthPosition,Hy as EditColumnsButton,Kx as EmptyState,ef as Envelope,tf as EnvelopeAlert,rf as EnvelopeArrowRight,Ea as EnvelopeFill,Cp as Europe,ia as ExpandingArrow,Ia as Eye,Aa as EyeSlash,Fr as FEATURES_LIST,cp as Facebook,Oa as FeatherFill,Lp as Figma,of as FileContent,a2 as FileUpload,af as FileZip2,L2 as Filter,sf as Filter2,nf as FilterBars,cf as Flag2,za as Flag6,lf as FlagWavy,df as Flask,mf as FlaskSmall,uf as Folder,hf as Folder5,pf as FolderBookmark,ff as FolderLock,gf as FolderPlus,bf as FolderShield,ON as Footer,z2 as Form,vf as GamingConsole,xf as Gauge6,Va as Gear,yf as Gear2,wf as Gear3,Nf as Gem,Ha as Gift,Cf as GiftFill,Mp as GitHubEnhanced,Qt as Github,kf as Globe,Fa as Globe2,_a as GlobePointer,Pf as GlobeSearch,fa as Go,dp as Google,Dp as GoogleEnhanced,Sf as GreekTemple,Xe as Grid,Rf as GridIcon,Tf as GridLayoutRows,Lf as GridPlus,Mf as GripDotsVertical,Df as Headset,Ef as HeartFill,If as HexadecagonStar,Af as History,Of as Hyperlink,np as IOSAppStore,e6 as IconMenu,zf as Icosahedron,Ba as Incognito,Vf as InfinityIcon,Kb as InfoTooltip,r6 as InlineSnippet,Qc as Input,Hf as InputField,_f as InputPassword,Wa as InputPasswordPointer,$a as InputSearch,u4 as InputSelect,mp as Instagram,Ff as InvoiceDollar,Bf as Key,sn as KeyboardShortcutContext,Vh as KeyboardShortcutProvider,di as LEGAL_PAGES,yd as Label,Wf as LayoutSidebar,$f as License,ir as LifeRing,Uf as LinesY,jf as Link4,Gf as LinkBroken,s6 as LinkLogo,h6 as LinkPreview,v6 as LinkPreviewPlaceholder,er as LinkedIn,jb as LinkifyTooltipContent,kt as LoadingCircle,lp as LoadingDots,ke as LoadingSpinner,Kf as LocationPin,Yf as Lock,Zf as LockFill,Ht as Logo,sa as Magic,qf as Magnifier,Xf as MapPosition,ip as MarkdownIcon,Jf as MarketingTarget,sp as MatrixLines,Br as MaxWidthWrapper,Qf as Menu3,k4 as MenuItem,eg as MessageSmile,sr as MicrophoneFill,A4 as MiniAreaChart,lr as Minus,tg as MobilePhone,F4 as Modal,rg as MoneyBill,og as MoneyBill2,ag as MoneyBills2,ng as Msgs,$w as Nav,zo as NavContext,aN as NavMobile,Wr as NavWordmark,kp as NorthAmerica,ig as Note,fg as NucleoPhoto,K4 as NumberStepper,Yb as NumberTooltip,Pp as Oceania,sg as OfficeBuilding,fb as PLAN_FEATURE_ICONS,Ua as Page2,q4 as PaginationControls,lg as Paintbrush,cg as Palette2,dg as PaperPlane,Op as Payoneer,zp as Paypal,ug as Pen2,mg as PenWriting,pg as PercentageArrowDown,la as Photo,ga as Php,gg as Plug2,dt as Plus,bg as Plus2,ve as Popover,P6 as Popup,ju as PopupContext,hg as Post,up as Prisma,ua as ProductHunt,L6 as ProgressBar,vg as Pyramid,ba as Python,xg as QRCode,_t as RESOURCES,_d as RadioGroup,Fd as RadioGroupItem,pa as Raycast,yg as Receipt2,Ga as ReferredVia,wg as Refresh2,Ng as Robot,ha as Ruby,Oo as SDKS,A3 as SOCIAL_LINKS,li as SOLUTIONS,ja as SatelliteDish,Cg as ScanText,kg as Scribble,ay as Sheet,Pg as ShieldAlert,Sg as ShieldCheck,Rg as ShieldKeyhole,Tg as ShieldSlash,Lg as ShieldUser,ly as ShimmerDots,Mg as Shuffle,Gb as SimpleTooltipContent,pp as Slack,my as Slider,Dg as Sliders,gy as SmartDateTimePicker,ca as SortOrder,Sp as SouthAmerica,Eg as Sparkle3,Ep as Spotify,Ig as SquareChart,Ag as SquareLayoutGrid5,Og as SquareLayoutGrid6,zg as SquareUserSparkle2,Vg as SquareXmark,Hg as Stars2,Ny as StatusBadge,Vp as Stripe,Hp as StripeLink,da as Success,My as Switch,Kg as TV,F6 as TabSelect,l3 as Table,_g as TableIcon,Fg as TableRows2,Bg as Tablet,Wg as Tag,$g as Tags,ma as Tick,fp as TikTok,Ka as Timer2,gp as Tinybird,Ya as Toggle2Fill,f3 as ToggleGroup,Ug as Toggles,Lb as TokenAvatar,Q as Tooltip,Ub as TooltipContent,$b as TooltipProvider,Gg as Trash,jg as TriangleWarning,tr as Twitter,va as Typescript,N3 as UTMBuilder,Tm as UTM_PARAMETERS,Yg as UiCard,bp as Unsplash,Zg as User,qg as UserCheck,Xg as UserCrown,Jg as UserDelete,Qg as UserFocus,eb as UserMinus,tb as UserPlus,rb as UserXmark,ob as Users,nb as Users2,ib as Users6,Pt as UsersFill,ab as UsersSettings,_p as Venmo,sb as Versions2,Za as Views,lb as Watch,cb as Webhook,db as Window,mb as WindowSearch,ub as WindowSettings,Si as Wordmark,pb as Xmark,rr as YouTube,ts as badgeVariants,se as buttonVariants,Qi as getUserAvatarUrl,Co as menuItemVariants,Vo as navItems,om as statusBadgeVariants,he as useCarousel,rn as useCarouselActiveIndex,oh as useColumnVisibility,sh as useCookies,pt as useCopyToClipboard,uh as useCurrentAnchor,bh as useCurrentSubdomain,yh as useEnterSubmit,kh as useInViewport,Rh as useInputFocused,Dh as useIntersectionObserver,Ie as useKeyboardShortcut,oo as useLocalStorage,Y as useMediaQuery,Wh as useOptimisticUpdate,ev as usePagination,ov as useRemoveGAParams,gr as useResizeObserver,dn as useRouterStuff,pn as useScroll,Ae as useScrollProgress,s3 as useTable,cn as useTablePagination,vv as useToastWithUndo};
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@dub/ui",
3
3
  "description": "UI components for Dub",
4
- "version": "0.2.60",
4
+ "version": "0.2.61",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/index.js",
7
7
  "module": "./dist/index.mjs",