clippy-widget
Advanced tools
Comparing version 0.1.17 to 0.1.18
@@ -1,3 +0,3 @@ | ||
var H=Object.defineProperty,V=Object.defineProperties;var U=Object.getOwnPropertyDescriptors;var k=Object.getOwnPropertySymbols;var B=Object.prototype.hasOwnProperty,_=Object.prototype.propertyIsEnumerable;var N=(r,e,a)=>e in r?H(r,e,{enumerable:!0,configurable:!0,writable:!0,value:a}):r[e]=a,w=(r,e)=>{for(var a in e||(e={}))B.call(e,a)&&N(r,a,e[a]);if(k)for(var a of k(e))_.call(e,a)&&N(r,a,e[a]);return r},z=(r,e)=>V(r,U(e));import*as t from"react";import{useMemo as G}from"react";import K from"react-shadow";import X from"remark-gfm";var P={a:({href:r,children:e})=>t.createElement("a",{href:r,target:"_blank",rel:"noopener noreferrer",className:"underline"},e)},S=P;var Q=`@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-cyrillic-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-cyrillic-ext-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c88,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-greek-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0370-03ff}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-greek-ext-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-latin-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+2000-206f,u+2074,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-latin-ext-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0100-024f,u+0259,u+1e??,u+2020,u+20a0-20ab,u+20ad-20cf,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-vietnamese-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+1ea0-1ef9,u+20ab} | ||
/*! tailwindcss v3.2.4 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e4e4e7}:after,:before{--tw-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#a1a1aa}input::placeholder,textarea::placeholder{opacity:1;color:#a1a1aa}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-y-0{top:0;bottom:0}.bottom-5{bottom:1.25rem}.right-5{right:1.25rem}.right-2{right:.5rem}.z-50{z-index:50}.-mx-2{margin-left:-.5rem;margin-right:-.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.block{display:block}.flex{display:flex}.hidden{display:none}.h-12{height:3rem}.h-4{height:1rem}.w-12{width:3rem}.w-full{width:100%}.w-4{width:1rem}.min-w-0{min-width:0}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-wait{cursor:wait}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem*var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px*var(--tw-divide-y-reverse))}.divide-gray-700>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(63 63 70/var(--tw-divide-opacity))}.overflow-hidden{overflow:hidden}.rounded-md{border-radius:.375rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-gray-700{--tw-border-opacity:1;border-color:rgb(63 63 70/var(--tw-border-opacity))}.bg-transparent{background-color:initial}.bg-gradient-to-bl{background-image:linear-gradient(to bottom left,var(--tw-gradient-stops))}.from-gray-800\\/70{--tw-gradient-from:#27272ab3;--tw-gradient-to:#27272a00;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-gray-900{--tw-gradient-to:#18181b00;--tw-gradient-stops:var(--tw-gradient-from),#18181b,var(--tw-gradient-to)}.to-gray-900{--tw-gradient-to:#18181b}.p-3{padding:.75rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.px-2{padding-left:.5rem;padding-right:.5rem}.pr-8{padding-right:2rem}.font-sans{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-gray-300{--tw-text-opacity:1;color:rgb(212 212 216/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(113 113 122/var(--tw-text-opacity))}.text-gray-200{--tw-text-opacity:1;color:rgb(228 228 231/var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.hover\\:bg-gray-800\\/70:hover{background-color:#27272ab3}.hover\\:underline:hover{text-decoration-line:underline}.focus\\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}`,M=r=>t.createElement("style",w({},r),Q);var q=r=>t.createElement("svg",z(w({},r),{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 20 20",fill:"currentColor"}),t.createElement("path",{d:"M3.105 2.289a.75.75 0 00-.826.95l1.414 4.925A1.5 1.5 0 005.135 9.25h6.115a.75.75 0 010 1.5H5.135a1.5 1.5 0 00-1.442 1.086l-1.414 4.926a.75.75 0 00.826.95 28.896 28.896 0 0015.293-7.154.75.75 0 000-1.115A28.897 28.897 0 003.105 2.289z"})),I=q;import{useEffect as D,useState as J}from"react";var W=()=>{let[r,e]=J("desktop");return D(()=>{let a=globalThis.matchMedia("(max-width: 768px)"),m=b=>e(b.matches?"mobile":"desktop");return m(a),a.addEventListener("change",m),()=>{a.removeEventListener("change",m)}},[]),r},A=W;var E=(...r)=>r.filter(Boolean).join(" ");import Y from"react-markdown";import Z from"swr/immutable";import{memo as $,useCallback as C,useState as c}from"react";import{AnimatePresence as j,motion as i}from"framer-motion";import{fetchEventSource as R}from"@microsoft/fetch-event-source";var tt=()=>{let r=A(),[e,a]=c(""),[m,b]=c(!1),[O,g]=c(!1),[h,y]=c(!1),[l,v]=c(null),[f,x]=c(null),{data:s}=Z("https://api.clippy.help/widget",o=>fetch(o).then(n=>n.json()),{revalidateOnMount:!0}),F=C(()=>{v(null),x(null),g(o=>!o)},[]),T=C(async o=>{o.preventDefault(),e&&(y(!0),await R("https://api.clippy.help/widget/stream",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({query:e}),onmessage(n){switch(n.id){case"references":x(JSON.parse(n.data));break;case"answer":v(JSON.parse(n.data));break;default:throw new Error("Unknown event")}}}),a(""),g(!1),y(!1))},[e]),u=G(()=>{if(!f)return[];if(!l)return f.slice(0,1);let o=l.sources.filter(Boolean);return o.length===0?[]:o.map(n=>f.find(d=>d.path===n)).filter(Boolean)},[l,f]);return s?t.createElement(K.div,{mode:"open"},t.createElement("div",{className:"fixed bottom-5 right-5 z-50"},t.createElement(M,{hidden:!0}),r=="desktop"||m?t.createElement(i.div,{initial:{y:"50%",width:"18rem"},animate:{y:0,width:l?"24rem":"18rem"},transition:{width:{type:l?"spring":"tween",duration:.15}},className:E("divide-y divide-gray-700 rounded-md border border-gray-700 bg-gradient-to-bl from-gray-800/70 via-gray-900 to-gray-900 font-sans shadow-md backdrop-blur-sm")},t.createElement("div",null,t.createElement(j,null,l?t.createElement("div",null,t.createElement("div",{className:"flex items-center gap-2 overflow-hidden p-3"},t.createElement(i.div,{initial:{opacity:0},animate:{opacity:1},className:"min-w-0 flex-1"},t.createElement(Y,{components:S,remarkPlugins:[X],allowedElements:["p","a","code"],className:"mt-1 text-sm text-gray-300"},l.answer),u.length>0&&t.createElement("div",{className:"mt-2"},t.createElement("div",{className:"space-y-1 text-xs text-gray-500"},u.map((o,n)=>{var d;return t.createElement("a",{key:n,href:o.path,className:"block hover:underline"},(d=o.title)!=null?d:o.page_title," \u2192")})))))):h?t.createElement("div",{className:"p-3"},t.createElement("div",{className:"flex items-center gap-2"},t.createElement(i.div,{initial:{opacity:0},animate:{opacity:1},className:"flex-1"},t.createElement("h3",{className:"text-sm font-bold text-gray-200"},"Loading..."),t.createElement("p",{className:"mt-1 text-xs text-gray-500"},s.copy.loading)),t.createElement("div",{className:"relative h-12 w-12 shrink-0"},t.createElement(i.img,{layoutId:"bunny",src:s.image_url,alt:"avatar",className:"rounded-full"}))),u.length>0&&t.createElement(i.div,{initial:{opacity:0,y:"50%"},animate:{opacity:1,y:0}},t.createElement("div",{className:"space-y-1 text-xs text-gray-500"},u.map((o,n)=>{var d;return t.createElement("a",{key:n,href:o.path,className:"block hover:underline"},(d=o.title)!=null?d:o.page_title," \u2192")})))):t.createElement("div",{className:"flex items-center gap-2 p-3"},t.createElement(i.div,{exit:{opacity:0},className:"flex-1"},t.createElement("h3",{className:"text-sm font-bold text-gray-200"},s.copy.title),t.createElement("p",{className:"mt-1 text-xs text-gray-500"},s.copy.subtitle)),t.createElement("div",{className:"relative h-12 w-12 shrink-0"},t.createElement(i.img,{layoutId:"bunny",src:s.image_url,alt:"avatar",className:"rounded-full"}))))),t.createElement("div",{className:"w-full"},t.createElement(j,{mode:"wait"},h?t.createElement(i.div,{initial:{opacity:0},animate:{opacity:1},transition:{duration:.05},className:"flex w-full animate-pulse cursor-wait justify-center px-5 py-3 text-sm font-medium text-white"},t.createElement("p",null,"Thinking...")):O?t.createElement(i.form,{initial:{opacity:0},animate:{opacity:1},transition:{duration:.05},onSubmit:o=>void T(o),className:"relative w-full",key:"two"},t.createElement("input",{type:"text",value:e,onChange:o=>a(o.target.value),className:"w-full bg-transparent px-5 py-3 pr-8 text-sm text-white focus:outline-none",placeholder:s.copy.placeholder,autoFocus:!0}),t.createElement(i.button,{initial:{opacity:0},animate:{opacity:e?1:0},disabled:!e,className:"absolute inset-y-0 right-2 -mx-2 px-2",type:"submit"},t.createElement(I,{className:"h-4 w-4 text-white"}))):t.createElement(i.button,{exit:{opacity:0},transition:{duration:.05},onClick:F,className:"flex w-full justify-center px-5 py-3 text-sm font-bold text-white transition duration-300 hover:bg-gray-800/70"},t.createElement("p",null,s.copy.cta))))):t.createElement(i.button,{onClick:()=>b(!0),className:"relative h-12 w-12 shrink-0"},t.createElement(i.img,{layoutId:"bunny",src:s.image_url,alt:"avatar",className:"rounded-full"})))):null},L=$(tt);var zt=L;export{zt as default}; | ||
var H=Object.defineProperty,V=Object.defineProperties;var U=Object.getOwnPropertyDescriptors;var k=Object.getOwnPropertySymbols;var P=Object.prototype.hasOwnProperty,_=Object.prototype.propertyIsEnumerable;var N=(o,e,r)=>e in o?H(o,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):o[e]=r,u=(o,e)=>{for(var r in e||(e={}))P.call(e,r)&&N(o,r,e[r]);if(k)for(var r of k(e))_.call(e,r)&&N(o,r,e[r]);return o},z=(o,e)=>V(o,U(e));import*as t from"react";import{useMemo as J}from"react";import K from"react-shadow";import X from"remark-gfm";var B={a:({href:o,children:e})=>t.createElement("a",{href:o,target:"_blank",rel:"noopener noreferrer",className:"underline"},e)},S=B;var Q=`@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-cyrillic-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-cyrillic-ext-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c88,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-greek-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0370-03ff}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-greek-ext-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-latin-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+2000-206f,u+2074,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-latin-ext-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0100-024f,u+0259,u+1e??,u+2020,u+20a0-20ab,u+20ad-20cf,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:InterVariable;font-style:normal;font-display:swap;font-weight:100 900;src:url(files/inter-vietnamese-variable-wghtOnly-normal.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+1ea0-1ef9,u+20ab} | ||
/*! tailwindcss v3.2.4 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e4e4e7}:after,:before{--tw-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#a1a1aa}input::placeholder,textarea::placeholder{opacity:1;color:#a1a1aa}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-y-0{top:0;bottom:0}.bottom-5{bottom:1.25rem}.right-5{right:1.25rem}.right-2{right:.5rem}.z-50{z-index:50}.-mx-2{margin-left:-.5rem;margin-right:-.5rem}.mt-1{margin-top:.25rem}.block{display:block}.flex{display:flex}.hidden{display:none}.h-12{height:3rem}.h-4{height:1rem}.w-12{width:3rem}.w-full{width:100%}.w-4{width:1rem}.min-w-0{min-width:0}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-wait{cursor:wait}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem*var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px*var(--tw-divide-y-reverse))}.divide-gray-700>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(63 63 70/var(--tw-divide-opacity))}.overflow-hidden{overflow:hidden}.rounded-md{border-radius:.375rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-gray-700{--tw-border-opacity:1;border-color:rgb(63 63 70/var(--tw-border-opacity))}.bg-transparent{background-color:initial}.bg-gradient-to-bl{background-image:linear-gradient(to bottom left,var(--tw-gradient-stops))}.from-gray-800\\/70{--tw-gradient-from:#27272ab3;--tw-gradient-to:#27272a00;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-gray-900{--tw-gradient-to:#18181b00;--tw-gradient-stops:var(--tw-gradient-from),#18181b,var(--tw-gradient-to)}.to-gray-900{--tw-gradient-to:#18181b}.p-3{padding:.75rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.px-2{padding-left:.5rem;padding-right:.5rem}.pr-8{padding-right:2rem}.font-sans{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-gray-300{--tw-text-opacity:1;color:rgb(212 212 216/var(--tw-text-opacity))}.text-gray-200{--tw-text-opacity:1;color:rgb(228 228 231/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(113 113 122/var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.hover\\:bg-gray-800\\/70:hover{background-color:#27272ab3}.hover\\:underline:hover{text-decoration-line:underline}.focus\\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}`,I=o=>t.createElement("style",u({},o),Q);var q=o=>t.createElement("svg",z(u({},o),{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 20 20",fill:"currentColor"}),t.createElement("path",{d:"M3.105 2.289a.75.75 0 00-.826.95l1.414 4.925A1.5 1.5 0 005.135 9.25h6.115a.75.75 0 010 1.5H5.135a1.5 1.5 0 00-1.442 1.086l-1.414 4.926a.75.75 0 00.826.95 28.896 28.896 0 0015.293-7.154.75.75 0 000-1.115A28.897 28.897 0 003.105 2.289z"})),M=q;import{useEffect as D,useState as W}from"react";var G=()=>{let[o,e]=W("desktop");return D(()=>{let r=globalThis.matchMedia("(max-width: 768px)"),p=w=>e(w.matches?"mobile":"desktop");return p(r),r.addEventListener("change",p),()=>{r.removeEventListener("change",p)}},[]),o},E=G;var C=(...o)=>o.filter(Boolean).join(" ");import Y from"react-markdown";import Z from"swr/immutable";import{memo as $,useCallback as j,useState as d}from"react";import{AnimatePresence as A,motion as i}from"framer-motion";import{fetchEventSource as R}from"@microsoft/fetch-event-source";var tt=()=>{let o=E(),[e,r]=d(""),[p,w]=d(!1),[O,g]=d(!1),[h,y]=d(!1),[c,b]=d(""),[m,v]=d(null),{data:n}=Z("https://api.clippy.help/widget",a=>fetch(a).then(s=>s.json()),{revalidateOnMount:!0}),F=j(()=>{b(""),v(null),g(a=>!a)},[]),T=j(async a=>{a.preventDefault(),e&&(y(!0),await R("https://api.clippy.help/widget/stream",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({query:e}),onmessage(s){switch(s.id){case"references":v(JSON.parse(s.data));break;case"partial_answer":b(f=>f+s.data);break;case"error":b("Something went wrong! Please try again.");break;default:throw new Error("Unknown event")}}}),r(""),g(!1),y(!1))},[e]),x=J(()=>{var a;return(a=m==null?void 0:m.slice(0,1))!=null?a:[]},[m]);return n?t.createElement(K.div,{mode:"open"},t.createElement("div",{className:"fixed bottom-5 right-5 z-50"},t.createElement(I,{hidden:!0}),o=="desktop"||p?t.createElement(i.div,{initial:{y:"50%",width:"18rem"},animate:{y:0,width:c?"24rem":"18rem"},transition:{width:{type:c?"spring":"tween",duration:.15}},className:C("divide-y divide-gray-700 rounded-md border border-gray-700 bg-gradient-to-bl from-gray-800/70 via-gray-900 to-gray-900 font-sans shadow-md backdrop-blur-sm")},t.createElement("div",null,t.createElement(A,null,c?t.createElement("div",null,t.createElement("div",{className:"flex items-center gap-2 overflow-hidden p-3"},t.createElement(i.div,{initial:{opacity:0},animate:{opacity:1},className:"min-w-0 flex-1"},t.createElement(Y,{components:S,remarkPlugins:[X],allowedElements:["p","a","code"],className:"mt-1 text-sm text-gray-300"},c)))):h?t.createElement("div",{className:"p-3"},t.createElement("div",{className:"flex items-center gap-2"},t.createElement(i.div,{initial:{opacity:0},animate:{opacity:1},className:"flex-1"},t.createElement("h3",{className:"text-sm font-bold text-gray-200"},"Loading..."),t.createElement("p",{className:"mt-1 text-xs text-gray-500"},n.copy.loading)),t.createElement("div",{className:"relative h-12 w-12 shrink-0"},t.createElement(i.img,{layoutId:"clippyImg",src:n.image_url,alt:"avatar",className:"rounded-full"}))),x.length>0&&t.createElement(i.div,{initial:{opacity:0,y:"50%"},animate:{opacity:1,y:0}},t.createElement("div",{className:"space-y-1 text-xs text-gray-500"},x.map((a,s)=>{var f;return t.createElement("a",{key:s,href:a.path,className:"block hover:underline"},(f=a.title)!=null?f:a.page_title," \u2192")})))):t.createElement("div",{className:"flex items-center gap-2 p-3"},t.createElement(i.div,{exit:{opacity:0},className:"flex-1"},t.createElement("h3",{className:"text-sm font-bold text-gray-200"},n.copy.title),t.createElement("p",{className:"mt-1 text-xs text-gray-500"},n.copy.subtitle)),t.createElement("div",{className:"relative h-12 w-12 shrink-0"},t.createElement(i.img,{layoutId:"clippyImg",src:n.image_url,alt:"avatar",className:"rounded-full"}))))),t.createElement("div",{className:"w-full"},t.createElement(A,{mode:"wait"},h?t.createElement(i.div,{initial:{opacity:0},animate:{opacity:1},transition:{duration:.05},className:"flex w-full animate-pulse cursor-wait justify-center px-5 py-3 text-sm font-medium text-white"},t.createElement("p",null,"Thinking...")):O?t.createElement(i.form,{initial:{opacity:0},animate:{opacity:1},transition:{duration:.05},onSubmit:a=>void T(a),className:"relative w-full",key:"two"},t.createElement("input",{type:"text",value:e,onChange:a=>r(a.target.value),className:"w-full bg-transparent px-5 py-3 pr-8 text-sm text-white focus:outline-none",placeholder:n.copy.placeholder,autoFocus:!0}),t.createElement(i.button,{initial:{opacity:0},animate:{opacity:e?1:0},disabled:!e,className:"absolute inset-y-0 right-2 -mx-2 px-2",type:"submit"},t.createElement(M,{className:"h-4 w-4 text-white"}))):t.createElement(i.button,{exit:{opacity:0},transition:{duration:.05},onClick:F,className:"flex w-full justify-center px-5 py-3 text-sm font-bold text-white transition duration-300 hover:bg-gray-800/70"},t.createElement("p",null,n.copy.cta))))):t.createElement(i.button,{onClick:()=>w(!0),className:"relative h-12 w-12 shrink-0"},t.createElement(i.img,{layoutId:"clippyImg",src:n.image_url,alt:"avatar",className:"rounded-full"})))):null},L=$(tt);var zt=L;export{zt as default}; | ||
//# sourceMappingURL=index.js.map |
@@ -12,6 +12,2 @@ export type WidgetData = { | ||
}; | ||
export type Answer = { | ||
answer: string; | ||
sources: string[]; | ||
}; | ||
export type References = Array<{ | ||
@@ -18,0 +14,0 @@ path: string; |
{ | ||
"name": "clippy-widget", | ||
"version": "0.1.17", | ||
"version": "0.1.18", | ||
"private": false, | ||
@@ -5,0 +5,0 @@ "type": "module", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
531001
1808