diff --git a/_app/immutable/chunks/10 questions to evaluate a startup idea.CEY9uffa.js b/_app/immutable/chunks/10 questions to evaluate a startup idea.CgztSJf-.js similarity index 99% rename from _app/immutable/chunks/10 questions to evaluate a startup idea.CEY9uffa.js rename to _app/immutable/chunks/10 questions to evaluate a startup idea.CgztSJf-.js index 2b6f1cb0df..34f6699249 100644 --- a/_app/immutable/chunks/10 questions to evaluate a startup idea.CEY9uffa.js +++ b/_app/immutable/chunks/10 questions to evaluate a startup idea.CgztSJf-.js @@ -1 +1 @@ -import{s as Fe,p as re,q as Ie,e as n,a as r,c as s,m as o,g as u,o as m,i,n as Se,f as a}from"./scheduler.ewBkyc9q.js";import{S as Ae,i as ze,c as Ge,a as Je,m as We,t as Ye,b as Ze,d as Ee}from"./index.DpmaPz1F.js";import{g as Ne,a as $e}from"./spread.CgU5AtxT.js";import{M as Oe}from"./MDSveXNoteLayout.PyyVkf3i.js";function Re(G){let l,y='This list comes from YC Group Partner Jared Friedman in his Startup School video on How to Get and Evaluate Startup Ideas.',c,h,d='1. Do you have founder/market fit?',p,f,ue="This might be the most important criteria. It’s a question of if you are the right team to be working on this idea. Do you know the industry you’re building in? Do you have the skills needed to execute?",J,L,de="When searching for a startup idea, you should scope the exercise to a good startup idea for your team. Focus on ideas that are connected to domains you and your co-founders are going to excel in.",W,b,he='2. How big is the market?',Y,M,pe="For a startup, you generally need a $1bn+ market. There are two common ways to get there:",Z,g,ce="
  • Pursue a large market opportunity
  • Target a market that is small now but growing quickly
  • ",E,v,fe='3. How acute is this problem?',N,P,me="You don’t want to pursue a problem nobody cares about. If your customers are okay with the problem continuing to exist, it’s going to be hard to sell them a solution. Similarly, if they have many options it’s going to be hard to sell them on yours.",O,q,ye="The ideal problem is one which is both very painful and that there is no alternative solution.",R,x,be='4. Do you have competition?',X,D,ve="If there is no competition that’s probably a bad sign. Having some competition is good, because it’s validation that there is a market.",B,I,xe="When there is deeply entrenched competition, you’re going to need a new insight or approach to win customers.",K,w,we='5. Do you want this?',Q,$,_e="Do you personally want this solution? Do you know someone who does? If the answer to both of these is “no” you need to do some customer-discovery. If you can’t discover any customers, you may want to move on.",U,_,ke='6. Did this recently become possible or necessary?',V,j,Ce="Did something recently change in the world, such as a new technology, problem, or regulatory change?",ee,k,He='7. Are there proxies for the business?',te,F,Te="A proxy is a company that does something similar, but isn’t a direct competitor. For example, Rappi launched in Latin America without competition and with the confidence that demand is strong because of proxies in other regions of the world such as DoorDash. Proxies are a good way to validate the business idea.",ie,C,Le='8. Do you want to work on this for years?',ae,S,Me="If the answer is yes it could be a good sign, but sometimes the idea will grow on you as it starts to work. Many great startups are in boring spaces, but as you start working on it successfully you can get more excited about helping your customers.",ne,H,ge='9. Is this a scalable business?',se,A,Pe="For software-only businesses this an easy yes. For services businesses, particularly with high-skill services it can be really hard to grow the company to a billion-dollar scale.",oe,T,qe='10. Is this a good idea space?',le,z,De="An idea space is a level of abstraction away from a specific startup idea, that encapsulates an area of adjacent business opportunities. For example, infrastructure monitoring tools. Different idea spaces have different hit rates; a good idea space increases the odds for success for you. That way even if the initial idea isn’t quite right, you can pivot into an adjacent idea and be successful. A fertile idea space increases your chances of bumping into a good startup idea.";return{c(){l=n("p"),l.innerHTML=y,c=r(),h=n("h2"),h.innerHTML=d,p=r(),f=n("p"),f.textContent=ue,J=r(),L=n("p"),L.innerHTML=de,W=r(),b=n("h2"),b.innerHTML=he,Y=r(),M=n("p"),M.textContent=pe,Z=r(),g=n("ol"),g.innerHTML=ce,E=r(),v=n("h2"),v.innerHTML=fe,N=r(),P=n("p"),P.textContent=me,O=r(),q=n("p"),q.textContent=ye,R=r(),x=n("h2"),x.innerHTML=be,X=r(),D=n("p"),D.innerHTML=ve,B=r(),I=n("p"),I.textContent=xe,K=r(),w=n("h2"),w.innerHTML=we,Q=r(),$=n("p"),$.innerHTML=_e,U=r(),_=n("h2"),_.innerHTML=ke,V=r(),j=n("p"),j.textContent=Ce,ee=r(),k=n("h2"),k.innerHTML=He,te=r(),F=n("p"),F.textContent=Te,ie=r(),C=n("h2"),C.innerHTML=Le,ae=r(),S=n("p"),S.textContent=Me,ne=r(),H=n("h2"),H.innerHTML=ge,se=r(),A=n("p"),A.textContent=Pe,oe=r(),T=n("h2"),T.innerHTML=qe,le=r(),z=n("p"),z.textContent=De,this.h()},l(e){l=s(e,"P",{"data-svelte-h":!0}),o(l)!=="svelte-abvhu5"&&(l.innerHTML=y),c=u(e),h=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(h)!=="svelte-w4ethf"&&(h.innerHTML=d),p=u(e),f=s(e,"P",{"data-svelte-h":!0}),o(f)!=="svelte-1co9a6r"&&(f.textContent=ue),J=u(e),L=s(e,"P",{"data-svelte-h":!0}),o(L)!=="svelte-18tv8wy"&&(L.innerHTML=de),W=u(e),b=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(b)!=="svelte-1i29rf6"&&(b.innerHTML=he),Y=u(e),M=s(e,"P",{"data-svelte-h":!0}),o(M)!=="svelte-6myjsu"&&(M.textContent=pe),Z=u(e),g=s(e,"OL",{"data-svelte-h":!0}),o(g)!=="svelte-o7tam1"&&(g.innerHTML=ce),E=u(e),v=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(v)!=="svelte-ubpiba"&&(v.innerHTML=fe),N=u(e),P=s(e,"P",{"data-svelte-h":!0}),o(P)!=="svelte-1ajn6q2"&&(P.textContent=me),O=u(e),q=s(e,"P",{"data-svelte-h":!0}),o(q)!=="svelte-nx5z65"&&(q.textContent=ye),R=u(e),x=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(x)!=="svelte-1g8wx03"&&(x.innerHTML=be),X=u(e),D=s(e,"P",{"data-svelte-h":!0}),o(D)!=="svelte-15n4eda"&&(D.innerHTML=ve),B=u(e),I=s(e,"P",{"data-svelte-h":!0}),o(I)!=="svelte-4t0uu"&&(I.textContent=xe),K=u(e),w=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(w)!=="svelte-3y3umr"&&(w.innerHTML=we),Q=u(e),$=s(e,"P",{"data-svelte-h":!0}),o($)!=="svelte-1s0eelf"&&($.innerHTML=_e),U=u(e),_=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(_)!=="svelte-1gsvray"&&(_.innerHTML=ke),V=u(e),j=s(e,"P",{"data-svelte-h":!0}),o(j)!=="svelte-1k778xs"&&(j.textContent=Ce),ee=u(e),k=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(k)!=="svelte-1jyyiuz"&&(k.innerHTML=He),te=u(e),F=s(e,"P",{"data-svelte-h":!0}),o(F)!=="svelte-1ustcm2"&&(F.textContent=Te),ie=u(e),C=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(C)!=="svelte-qecnpg"&&(C.innerHTML=Le),ae=u(e),S=s(e,"P",{"data-svelte-h":!0}),o(S)!=="svelte-1tj0596"&&(S.textContent=Me),ne=u(e),H=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(H)!=="svelte-1q7ozek"&&(H.innerHTML=ge),se=u(e),A=s(e,"P",{"data-svelte-h":!0}),o(A)!=="svelte-1gazlqq"&&(A.textContent=Pe),oe=u(e),T=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(T)!=="svelte-11p99qb"&&(T.innerHTML=qe),le=u(e),z=s(e,"P",{"data-svelte-h":!0}),o(z)!=="svelte-1ki8wbl"&&(z.textContent=De),this.h()},h(){m(h,"id","1-do-you-have-foundermarket-fit"),m(b,"id","2-how-big-is-the-market"),m(v,"id","3-how-acute-is-this-problem"),m(x,"id","4-do-you-have-competition"),m(w,"id","5-do-you-want-this"),m(_,"id","6-did-this-recently-become-possible-or-necessary"),m(k,"id","7-are-there-proxies-for-the-business"),m(C,"id","8-do-you-want-to-work-on-this-for-years"),m(H,"id","9-is-this-a-scalable-business"),m(T,"id","10-is-this-a-good-idea-space")},m(e,t){i(e,l,t),i(e,c,t),i(e,h,t),i(e,p,t),i(e,f,t),i(e,J,t),i(e,L,t),i(e,W,t),i(e,b,t),i(e,Y,t),i(e,M,t),i(e,Z,t),i(e,g,t),i(e,E,t),i(e,v,t),i(e,N,t),i(e,P,t),i(e,O,t),i(e,q,t),i(e,R,t),i(e,x,t),i(e,X,t),i(e,D,t),i(e,B,t),i(e,I,t),i(e,K,t),i(e,w,t),i(e,Q,t),i(e,$,t),i(e,U,t),i(e,_,t),i(e,V,t),i(e,j,t),i(e,ee,t),i(e,k,t),i(e,te,t),i(e,F,t),i(e,ie,t),i(e,C,t),i(e,ae,t),i(e,S,t),i(e,ne,t),i(e,H,t),i(e,se,t),i(e,A,t),i(e,oe,t),i(e,T,t),i(e,le,t),i(e,z,t)},p:Se,d(e){e&&(a(l),a(c),a(h),a(p),a(f),a(J),a(L),a(W),a(b),a(Y),a(M),a(Z),a(g),a(E),a(v),a(N),a(P),a(O),a(q),a(R),a(x),a(X),a(D),a(B),a(I),a(K),a(w),a(Q),a($),a(U),a(_),a(V),a(j),a(ee),a(k),a(te),a(F),a(ie),a(C),a(ae),a(S),a(ne),a(H),a(se),a(A),a(oe),a(T),a(le),a(z))}}}function Xe(G){let l,y;const c=[G[0],je];let h={$$slots:{default:[Re]},$$scope:{ctx:G}};for(let d=0;d{y(0,l=re(re({},l),Ie(c)))},l=Ie(l),[l]}class et extends Ae{constructor(l){super(),ze(this,l,Be,Xe,Fe,{})}}export{et as default,je as metadata}; +import{s as Fe,p as re,q as Ie,e as n,a as r,c as s,m as o,g as u,o as m,i,n as Se,f as a}from"./scheduler.ewBkyc9q.js";import{S as Ae,i as ze,c as Ge,a as Je,m as We,t as Ye,b as Ze,d as Ee}from"./index.DpmaPz1F.js";import{g as Ne,a as $e}from"./spread.CgU5AtxT.js";import{M as Oe}from"./MDSveXNoteLayout.Bx5vQYjx.js";function Re(G){let l,y='This list comes from YC Group Partner Jared Friedman in his Startup School video on How to Get and Evaluate Startup Ideas.',c,h,d='1. Do you have founder/market fit?',p,f,ue="This might be the most important criteria. It’s a question of if you are the right team to be working on this idea. Do you know the industry you’re building in? Do you have the skills needed to execute?",J,L,de="When searching for a startup idea, you should scope the exercise to a good startup idea for your team. Focus on ideas that are connected to domains you and your co-founders are going to excel in.",W,b,he='2. How big is the market?',Y,M,pe="For a startup, you generally need a $1bn+ market. There are two common ways to get there:",Z,g,ce="
  • Pursue a large market opportunity
  • Target a market that is small now but growing quickly
  • ",E,v,fe='3. How acute is this problem?',N,P,me="You don’t want to pursue a problem nobody cares about. If your customers are okay with the problem continuing to exist, it’s going to be hard to sell them a solution. Similarly, if they have many options it’s going to be hard to sell them on yours.",O,q,ye="The ideal problem is one which is both very painful and that there is no alternative solution.",R,x,be='4. Do you have competition?',X,D,ve="If there is no competition that’s probably a bad sign. Having some competition is good, because it’s validation that there is a market.",B,I,xe="When there is deeply entrenched competition, you’re going to need a new insight or approach to win customers.",K,w,we='5. Do you want this?',Q,$,_e="Do you personally want this solution? Do you know someone who does? If the answer to both of these is “no” you need to do some customer-discovery. If you can’t discover any customers, you may want to move on.",U,_,ke='6. Did this recently become possible or necessary?',V,j,Ce="Did something recently change in the world, such as a new technology, problem, or regulatory change?",ee,k,He='7. Are there proxies for the business?',te,F,Te="A proxy is a company that does something similar, but isn’t a direct competitor. For example, Rappi launched in Latin America without competition and with the confidence that demand is strong because of proxies in other regions of the world such as DoorDash. Proxies are a good way to validate the business idea.",ie,C,Le='8. Do you want to work on this for years?',ae,S,Me="If the answer is yes it could be a good sign, but sometimes the idea will grow on you as it starts to work. Many great startups are in boring spaces, but as you start working on it successfully you can get more excited about helping your customers.",ne,H,ge='9. Is this a scalable business?',se,A,Pe="For software-only businesses this an easy yes. For services businesses, particularly with high-skill services it can be really hard to grow the company to a billion-dollar scale.",oe,T,qe='10. Is this a good idea space?',le,z,De="An idea space is a level of abstraction away from a specific startup idea, that encapsulates an area of adjacent business opportunities. For example, infrastructure monitoring tools. Different idea spaces have different hit rates; a good idea space increases the odds for success for you. That way even if the initial idea isn’t quite right, you can pivot into an adjacent idea and be successful. A fertile idea space increases your chances of bumping into a good startup idea.";return{c(){l=n("p"),l.innerHTML=y,c=r(),h=n("h2"),h.innerHTML=d,p=r(),f=n("p"),f.textContent=ue,J=r(),L=n("p"),L.innerHTML=de,W=r(),b=n("h2"),b.innerHTML=he,Y=r(),M=n("p"),M.textContent=pe,Z=r(),g=n("ol"),g.innerHTML=ce,E=r(),v=n("h2"),v.innerHTML=fe,N=r(),P=n("p"),P.textContent=me,O=r(),q=n("p"),q.textContent=ye,R=r(),x=n("h2"),x.innerHTML=be,X=r(),D=n("p"),D.innerHTML=ve,B=r(),I=n("p"),I.textContent=xe,K=r(),w=n("h2"),w.innerHTML=we,Q=r(),$=n("p"),$.innerHTML=_e,U=r(),_=n("h2"),_.innerHTML=ke,V=r(),j=n("p"),j.textContent=Ce,ee=r(),k=n("h2"),k.innerHTML=He,te=r(),F=n("p"),F.textContent=Te,ie=r(),C=n("h2"),C.innerHTML=Le,ae=r(),S=n("p"),S.textContent=Me,ne=r(),H=n("h2"),H.innerHTML=ge,se=r(),A=n("p"),A.textContent=Pe,oe=r(),T=n("h2"),T.innerHTML=qe,le=r(),z=n("p"),z.textContent=De,this.h()},l(e){l=s(e,"P",{"data-svelte-h":!0}),o(l)!=="svelte-abvhu5"&&(l.innerHTML=y),c=u(e),h=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(h)!=="svelte-w4ethf"&&(h.innerHTML=d),p=u(e),f=s(e,"P",{"data-svelte-h":!0}),o(f)!=="svelte-1co9a6r"&&(f.textContent=ue),J=u(e),L=s(e,"P",{"data-svelte-h":!0}),o(L)!=="svelte-18tv8wy"&&(L.innerHTML=de),W=u(e),b=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(b)!=="svelte-1i29rf6"&&(b.innerHTML=he),Y=u(e),M=s(e,"P",{"data-svelte-h":!0}),o(M)!=="svelte-6myjsu"&&(M.textContent=pe),Z=u(e),g=s(e,"OL",{"data-svelte-h":!0}),o(g)!=="svelte-o7tam1"&&(g.innerHTML=ce),E=u(e),v=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(v)!=="svelte-ubpiba"&&(v.innerHTML=fe),N=u(e),P=s(e,"P",{"data-svelte-h":!0}),o(P)!=="svelte-1ajn6q2"&&(P.textContent=me),O=u(e),q=s(e,"P",{"data-svelte-h":!0}),o(q)!=="svelte-nx5z65"&&(q.textContent=ye),R=u(e),x=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(x)!=="svelte-1g8wx03"&&(x.innerHTML=be),X=u(e),D=s(e,"P",{"data-svelte-h":!0}),o(D)!=="svelte-15n4eda"&&(D.innerHTML=ve),B=u(e),I=s(e,"P",{"data-svelte-h":!0}),o(I)!=="svelte-4t0uu"&&(I.textContent=xe),K=u(e),w=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(w)!=="svelte-3y3umr"&&(w.innerHTML=we),Q=u(e),$=s(e,"P",{"data-svelte-h":!0}),o($)!=="svelte-1s0eelf"&&($.innerHTML=_e),U=u(e),_=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(_)!=="svelte-1gsvray"&&(_.innerHTML=ke),V=u(e),j=s(e,"P",{"data-svelte-h":!0}),o(j)!=="svelte-1k778xs"&&(j.textContent=Ce),ee=u(e),k=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(k)!=="svelte-1jyyiuz"&&(k.innerHTML=He),te=u(e),F=s(e,"P",{"data-svelte-h":!0}),o(F)!=="svelte-1ustcm2"&&(F.textContent=Te),ie=u(e),C=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(C)!=="svelte-qecnpg"&&(C.innerHTML=Le),ae=u(e),S=s(e,"P",{"data-svelte-h":!0}),o(S)!=="svelte-1tj0596"&&(S.textContent=Me),ne=u(e),H=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(H)!=="svelte-1q7ozek"&&(H.innerHTML=ge),se=u(e),A=s(e,"P",{"data-svelte-h":!0}),o(A)!=="svelte-1gazlqq"&&(A.textContent=Pe),oe=u(e),T=s(e,"H2",{id:!0,"data-svelte-h":!0}),o(T)!=="svelte-11p99qb"&&(T.innerHTML=qe),le=u(e),z=s(e,"P",{"data-svelte-h":!0}),o(z)!=="svelte-1ki8wbl"&&(z.textContent=De),this.h()},h(){m(h,"id","1-do-you-have-foundermarket-fit"),m(b,"id","2-how-big-is-the-market"),m(v,"id","3-how-acute-is-this-problem"),m(x,"id","4-do-you-have-competition"),m(w,"id","5-do-you-want-this"),m(_,"id","6-did-this-recently-become-possible-or-necessary"),m(k,"id","7-are-there-proxies-for-the-business"),m(C,"id","8-do-you-want-to-work-on-this-for-years"),m(H,"id","9-is-this-a-scalable-business"),m(T,"id","10-is-this-a-good-idea-space")},m(e,t){i(e,l,t),i(e,c,t),i(e,h,t),i(e,p,t),i(e,f,t),i(e,J,t),i(e,L,t),i(e,W,t),i(e,b,t),i(e,Y,t),i(e,M,t),i(e,Z,t),i(e,g,t),i(e,E,t),i(e,v,t),i(e,N,t),i(e,P,t),i(e,O,t),i(e,q,t),i(e,R,t),i(e,x,t),i(e,X,t),i(e,D,t),i(e,B,t),i(e,I,t),i(e,K,t),i(e,w,t),i(e,Q,t),i(e,$,t),i(e,U,t),i(e,_,t),i(e,V,t),i(e,j,t),i(e,ee,t),i(e,k,t),i(e,te,t),i(e,F,t),i(e,ie,t),i(e,C,t),i(e,ae,t),i(e,S,t),i(e,ne,t),i(e,H,t),i(e,se,t),i(e,A,t),i(e,oe,t),i(e,T,t),i(e,le,t),i(e,z,t)},p:Se,d(e){e&&(a(l),a(c),a(h),a(p),a(f),a(J),a(L),a(W),a(b),a(Y),a(M),a(Z),a(g),a(E),a(v),a(N),a(P),a(O),a(q),a(R),a(x),a(X),a(D),a(B),a(I),a(K),a(w),a(Q),a($),a(U),a(_),a(V),a(j),a(ee),a(k),a(te),a(F),a(ie),a(C),a(ae),a(S),a(ne),a(H),a(se),a(A),a(oe),a(T),a(le),a(z))}}}function Xe(G){let l,y;const c=[G[0],je];let h={$$slots:{default:[Re]},$$scope:{ctx:G}};for(let d=0;d{y(0,l=re(re({},l),Ie(c)))},l=Ie(l),[l]}class et extends Ae{constructor(l){super(),ze(this,l,Be,Xe,Fe,{})}}export{et as default,je as metadata}; diff --git a/_app/immutable/chunks/Add a demo link to TypeScript code blocks.DwCVGUbH.js b/_app/immutable/chunks/Add a demo link to TypeScript code blocks.DOBRZgS-.js similarity index 99% rename from _app/immutable/chunks/Add a demo link to TypeScript code blocks.DwCVGUbH.js rename to _app/immutable/chunks/Add a demo link to TypeScript code blocks.DOBRZgS-.js index 3e6ec50c78..8dfc471b32 100644 --- a/_app/immutable/chunks/Add a demo link to TypeScript code blocks.DwCVGUbH.js +++ b/_app/immutable/chunks/Add a demo link to TypeScript code blocks.DOBRZgS-.js @@ -1,4 +1,4 @@ -import{s as W,p as O,q as Z,e as h,a as c,H as L,u as $,c as y,m as u,g as d,v as H,i as e,n as Y,f as t}from"./scheduler.ewBkyc9q.js";import{S as ss,i as as,c as ns,a as ls,m as es,t as ts,b as os,d as is}from"./index.DpmaPz1F.js";import{g as ps,a as J}from"./spread.CgU5AtxT.js";import{M as rs}from"./MDSveXNoteLayout.PyyVkf3i.js";function ks(g){let a,k='TypeScript Playground is an online tool to interactive with TypeScript. It’s a great way to test out small snippets, share repros, and experiment with the language as it is portable and requires no setup. Recently, I learned about another amazing feature - it’s possible to Dynamically generate TypeScript Playground links for any TypeScript code! Technical writing should Make example code interactive, and this is an excellent way to do it.',p,i,l="Once I’ve got my TS playground link generated, all that’s left is to put the link on the page. Easy!",o,r,q="I already built a copy button for my code blocks, which makes this even easier. I modified that code to render TS playground links instead of copy buttons. This Svelte component renders a link as a small square button:",E,C,V=`
    <script lang="ts">
    +import{s as W,p as O,q as Z,e as h,a as c,H as L,u as $,c as y,m as u,g as d,v as H,i as e,n as Y,f as t}from"./scheduler.ewBkyc9q.js";import{S as ss,i as as,c as ns,a as ls,m as es,t as ts,b as os,d as is}from"./index.DpmaPz1F.js";import{g as ps,a as J}from"./spread.CgU5AtxT.js";import{M as rs}from"./MDSveXNoteLayout.Bx5vQYjx.js";function ks(g){let a,k='TypeScript Playground is an online tool to interactive with TypeScript. It’s a great way to test out small snippets, share repros, and experiment with the language as it is portable and requires no setup. Recently, I learned about another amazing feature - it’s possible to Dynamically generate TypeScript Playground links for any TypeScript code! Technical writing should Make example code interactive, and this is an excellent way to do it.',p,i,l="Once I’ve got my TS playground link generated, all that’s left is to put the link on the page. Easy!",o,r,q="I already built a copy button for my  code blocks, which makes this even easier. I modified that code to render TS playground links instead of copy buttons. This Svelte component renders a link as a small square button:",E,C,V=`
    <script lang="ts">
     	import { Icon } from '@steeze-ui/svelte-icon';
     	import { ArrowTopRightOnSquare } from '@steeze-ui/heroicons';
     
    diff --git a/_app/immutable/chunks/Adding users to new teams with Lucia auth and Prisma.D_BABdD6.js b/_app/immutable/chunks/Adding users to new teams with Lucia auth and Prisma.BDKAgZrZ.js
    similarity index 99%
    rename from _app/immutable/chunks/Adding users to new teams with Lucia auth and Prisma.D_BABdD6.js
    rename to _app/immutable/chunks/Adding users to new teams with Lucia auth and Prisma.BDKAgZrZ.js
    index 616455754f..d4ed06a0f5 100644
    --- a/_app/immutable/chunks/Adding users to new teams with Lucia auth and Prisma.D_BABdD6.js	
    +++ b/_app/immutable/chunks/Adding users to new teams with Lucia auth and Prisma.BDKAgZrZ.js	
    @@ -1,4 +1,4 @@
    -import{s as il,p as li,q as fn,e as t,a as n,H as p,u as k,c as r,m as o,g as l,v as c,o as y,i as e,n as nl,f as i}from"./scheduler.ewBkyc9q.js";import{S as ll,i as tl,c as rl,a as ol,m as pl,t as kl,b as cl,d as dl}from"./index.DpmaPz1F.js";import{g as hl,a as gn}from"./spread.CgU5AtxT.js";import{M as yl}from"./MDSveXNoteLayout.PyyVkf3i.js";function Al(Ls){let d,B='Recently I’ve been building Doc Duck, a user feedback platform. I wanted to add support for teams so that a customer can invite their coworkers to also participate. Multiple people from a team/company wanting access to the software is a really common scenario in B2B. For Doc Duck, I anticipate that an analyst or PM will want to view data in the dashboard and share it with their team. Plus they will want an engineer to do the integration work. In this post, I’m going to explain how I added support for teams and wired up that information in the auth library I’m using, Lucia-auth so that when accessing a user’s session I also get the information about teams they are on.',D,A,h='Updating the database with tables for auth and teams',u,m,ti='First, I needed to add the relevant tables and fields to my database to support auth & teams. I’m using prisma, so the following is what I’ve added to my schema.prisma file to support the fields needed for Lucia  and to add support for teams.',Oa,Ms,wn=`
    // This describes a user's role in a team.
    +import{s as il,p as li,q as fn,e as t,a as n,H as p,u as k,c as r,m as o,g as l,v as c,o as y,i as e,n as nl,f as i}from"./scheduler.ewBkyc9q.js";import{S as ll,i as tl,c as rl,a as ol,m as pl,t as kl,b as cl,d as dl}from"./index.DpmaPz1F.js";import{g as hl,a as gn}from"./spread.CgU5AtxT.js";import{M as yl}from"./MDSveXNoteLayout.Bx5vQYjx.js";function Al(Ls){let d,B='Recently I’ve been building Doc Duck, a user feedback platform. I wanted to add support for teams so that a customer can invite their coworkers to also participate. Multiple people from a team/company wanting access to the software is a really common scenario in B2B. For Doc Duck, I anticipate that an analyst or PM will want to view data in the dashboard and share it with their team. Plus they will want an engineer to do the integration work. In this post, I’m going to explain how I added support for teams and wired up that information in the auth library I’m using, Lucia-auth so that when accessing a user’s session I also get the information about teams they are on.',D,A,h='Updating the database with tables for auth and teams',u,m,ti='First, I needed to add the relevant tables and fields to my database to support auth & teams. I’m using prisma, so the following is what I’ve added to my schema.prisma file to support the fields needed for Lucia  and to add support for teams.',Oa,Ms,wn=`
    // This describes a user's role in a team.
     enum Role {
     	admin
     	user
    diff --git a/_app/immutable/chunks/Beautifully render markdown code blocks in Svelte.Bfiv8D18.js b/_app/immutable/chunks/Beautifully render markdown code blocks in Svelte.mHUdLjzS.js
    similarity index 99%
    rename from _app/immutable/chunks/Beautifully render markdown code blocks in Svelte.Bfiv8D18.js
    rename to _app/immutable/chunks/Beautifully render markdown code blocks in Svelte.mHUdLjzS.js
    index 351c2593f9..4927814e85 100644
    --- a/_app/immutable/chunks/Beautifully render markdown code blocks in Svelte.Bfiv8D18.js	
    +++ b/_app/immutable/chunks/Beautifully render markdown code blocks in Svelte.mHUdLjzS.js	
    @@ -1,4 +1,4 @@
    -import{s as _s,p as ns,q as Ds,e as r,a as t,H,u as S,c as p,m as k,g as o,v as M,o as es,i as e,n as bs,f as n}from"./scheduler.ewBkyc9q.js";import{S as Ts,i as Hs,c as Ss,a as Ms,m as Ls,t as js,b as Es,d as Fs}from"./index.DpmaPz1F.js";import{g as Is,a as us}from"./spread.CgU5AtxT.js";import{M as Ps}from"./MDSveXNoteLayout.PyyVkf3i.js";function qs(T){let i,f="I love the craft of building software. It amazes me that I can write something and have computers reliably and consistently do what I told it to. Add a few more clicks and I can make it instantly available to anyone, anywhere on the planet, so long as they have an internet connected device.",d,h,l="When I code something particularly interesting I want to share how I did it. Teaching is a valuable part of my own learning process, and it’s rewarding to help other people get excited about building. Sharing code is a critical part of that, and this note is about how I make the code I share look great!",c,y,is='To start with, it’s helpful to understand a bit about my pipeline for getting from raw markdown code blocks to a rendered page on allandeutsch.com.',G,A,ls=`
  • mdsvex is a svelte preprocessor that uses remark to process raw markdown and remark-rehype to transform it to HTML
  • mdsvex passes the markdown code blocks to a code highlighter to provide syntax highlighting
  • A meta string in the code fence of code blocks is used to pass options to twoslash; I use fenceparser to parse the code fence
  • I wrote a highlighter that uses shiki to render code in light & dark themes +import{s as _s,p as ns,q as Ds,e as r,a as t,H,u as S,c as p,m as k,g as o,v as M,o as es,i as e,n as bs,f as n}from"./scheduler.ewBkyc9q.js";import{S as Ts,i as Hs,c as Ss,a as Ms,m as Ls,t as js,b as Es,d as Fs}from"./index.DpmaPz1F.js";import{g as Is,a as us}from"./spread.CgU5AtxT.js";import{M as Ps}from"./MDSveXNoteLayout.Bx5vQYjx.js";function qs(T){let i,f="I love the craft of building software. It amazes me that I can write something and have computers reliably and consistently do what I told it to. Add a few more clicks and I can make it instantly available to anyone, anywhere on the planet, so long as they have an internet connected device.",d,h,l="When I code something particularly interesting I want to share how I did it. Teaching is a valuable part of my own learning process, and it’s rewarding to help other people get excited about building. Sharing code is a critical part of that, and this note is about how I make the code I share look great!",c,y,is='To start with, it’s helpful to understand a bit about my pipeline for getting from raw markdown code blocks to a rendered page on allandeutsch.com.',G,A,ls=`
  • mdsvex is a svelte preprocessor that uses remark to process raw markdown and remark-rehype to transform it to HTML
  • mdsvex passes the markdown code blocks to a code highlighter to provide syntax highlighting
  • A meta string in the code fence of code blocks is used to pass options to twoslash; I use fenceparser to parse the code fence
  • I wrote a highlighter that uses shiki to render code in light & dark themes
  • A CSS media query styles the code using the light or dark theme based on the user’s preference
  • `,J,m,ts='Installing the dependencies',N,g,os="My site is built using “Static Site Generation” (SSG), a technique which compiles my source into static HTML, CSS, and JS files at build time so the deployment can be delivered to visitors really efficiently via CDN since no logic needs to run on each request. This approach means I can do the highlighting at build time rather than runtime, and all of the tools I listed above can be included as dev dependencies. to install them:",R,L,gs='
    npm install --save-dev @shikijs/twoslash shiki mdsvex fenceparser
    ',j,E,vs='',F,D,rs='Configuring mdsvex',Z,v,ps='One important thing to know about mdsvex is that it is a svelte preprocessor. This is important to note: the preprocessor code doesn’t get preprocessed because it runs before the compiler. For now, that means it cannot use TypeScript because it would need to be compiled to JS first and that doesn’t happen for reasons. Hopefully that will change in the future.',U,B,ks="What this means practically is that the mdsvex config can’t be implemented in TypeScript: it must be javascript. Here’s how I configured mine to highlight code blocks!",K,I,Bs=`
    import { defineMDSveXConfig as defineConfig, escapeSvelte } from 'mdsvex';
     import { codeToHtml } from 'shiki';
     import { transformerTwoslash } from '@shikijs/twoslash';
    diff --git a/_app/immutable/chunks/Branded Types.BsIkdPj7.js b/_app/immutable/chunks/Branded Types.CL6b9hEC.js
    similarity index 99%
    rename from _app/immutable/chunks/Branded Types.BsIkdPj7.js
    rename to _app/immutable/chunks/Branded Types.CL6b9hEC.js
    index 0e75dd83e8..2d70c19a01 100644
    --- a/_app/immutable/chunks/Branded Types.BsIkdPj7.js	
    +++ b/_app/immutable/chunks/Branded Types.CL6b9hEC.js	
    @@ -1,4 +1,4 @@
    -import{s as La,p as Gs,q as Ba,e as p,a as e,H as c,u as d,c as i,m as r,g as o,v as h,i as n,n as Ia,f as l}from"./scheduler.ewBkyc9q.js";import{S as Sa,i as Ma,c as qa,a as Qa,m as Ya,t as Na,b as Ka,d as ja}from"./index.DpmaPz1F.js";import{g as Ga,a as Da}from"./spread.CgU5AtxT.js";import{M as Ja}from"./MDSveXNoteLayout.PyyVkf3i.js";function Oa(G){let t,B="Typescript is built on set theory, which is a cool feature for a language. it makes it possible to smash types together gracefully, like this:",A,D,k=`
    type 
    type User = {
    +import{s as La,p as Gs,q as Ba,e as p,a as e,H as c,u as d,c as i,m as r,g as o,v as h,i as n,n as Ia,f as l}from"./scheduler.ewBkyc9q.js";import{S as Sa,i as Ma,c as qa,a as Qa,m as Ya,t as Na,b as Ka,d as ja}from"./index.DpmaPz1F.js";import{g as Ga,a as Da}from"./spread.CgU5AtxT.js";import{M as Ja}from"./MDSveXNoteLayout.Bx5vQYjx.js";function Oa(G){let t,B="Typescript is built on set theory, which is a cool feature for a language. it makes it possible to smash types together gracefully, like this:",A,D,k=`
    type 
    type User = {
         email: string;
         password: string;
     }
    User
    = {
    diff --git a/_app/immutable/chunks/Build infrastructure after not having it becomes painful.BhUIeK0s.js b/_app/immutable/chunks/Build infrastructure after not having it becomes painful.BNitDpYR.js similarity index 97% rename from _app/immutable/chunks/Build infrastructure after not having it becomes painful.BhUIeK0s.js rename to _app/immutable/chunks/Build infrastructure after not having it becomes painful.BNitDpYR.js index 1b88248d38..56e2b1a351 100644 --- a/_app/immutable/chunks/Build infrastructure after not having it becomes painful.BhUIeK0s.js +++ b/_app/immutable/chunks/Build infrastructure after not having it becomes painful.BNitDpYR.js @@ -1 +1 @@ -import{s as $,p as b,q as w,e as d,a as g,c as _,m as h,g as v,i as c,n as k,f}from"./scheduler.ewBkyc9q.js";import{S as L,i as M,c as B,a as H,m as W,t as P,b as S,d as j}from"./index.DpmaPz1F.js";import{g as q,a as T}from"./spread.CgU5AtxT.js";import{M as Z}from"./MDSveXNoteLayout.PyyVkf3i.js";function A(m){let t,l="When starting something new, it can be tempting to build infrastructure and supporting pieces early on. That infrastructure - once built - can reduce the friction of the activity. There are a few problems with doing so too early though:",s,i,e="
  • Building infrastructure for an activity is time taken away from actually doing the activity
  • Without some experience doing the activity, it’s hard to determine what infrastructure is truly valuable
  • Building infrastructure isn’t progress, whereas doing the activity is
  • The activity may not be continued long term, and the infrastructure is unlikely to be a worthwhile investment in the short term
  • ",n,r,y="When lack of infrastructure becomes painful, it creates clarity about what problems the infrastructure needs to solve.",p,o,x="Once it becomes clear than an activity is going to continue, Automation unlocks progressively more meaningful problems.";return{c(){t=d("p"),t.textContent=l,s=g(),i=d("ul"),i.innerHTML=e,n=g(),r=d("p"),r.textContent=y,p=g(),o=d("p"),o.innerHTML=x},l(a){t=_(a,"P",{"data-svelte-h":!0}),h(t)!=="svelte-gcu0n6"&&(t.textContent=l),s=v(a),i=_(a,"UL",{"data-svelte-h":!0}),h(i)!=="svelte-16rulgd"&&(i.innerHTML=e),n=v(a),r=_(a,"P",{"data-svelte-h":!0}),h(r)!=="svelte-1agja4r"&&(r.textContent=y),p=v(a),o=_(a,"P",{"data-svelte-h":!0}),h(o)!=="svelte-go18a"&&(o.innerHTML=x)},m(a,u){c(a,t,u),c(a,s,u),c(a,i,u),c(a,n,u),c(a,r,u),c(a,p,u),c(a,o,u)},p:k,d(a){a&&(f(t),f(s),f(i),f(n),f(r),f(p),f(o))}}}function D(m){let t,l;const s=[m[0],C];let i={$$slots:{default:[A]},$$scope:{ctx:m}};for(let e=0;e{l(0,t=b(b({},t),w(s)))},t=w(t),[t]}class E extends L{constructor(t){super(),M(this,t,N,D,$,{})}}export{E as default,C as metadata}; +import{s as $,p as b,q as w,e as d,a as g,c as _,m as h,g as v,i as c,n as k,f}from"./scheduler.ewBkyc9q.js";import{S as L,i as M,c as B,a as H,m as W,t as P,b as S,d as j}from"./index.DpmaPz1F.js";import{g as q,a as T}from"./spread.CgU5AtxT.js";import{M as Z}from"./MDSveXNoteLayout.Bx5vQYjx.js";function A(m){let t,l="When starting something new, it can be tempting to build infrastructure and supporting pieces early on. That infrastructure - once built - can reduce the friction of the activity. There are a few problems with doing so too early though:",s,i,e="
  • Building infrastructure for an activity is time taken away from actually doing the activity
  • Without some experience doing the activity, it’s hard to determine what infrastructure is truly valuable
  • Building infrastructure isn’t progress, whereas doing the activity is
  • The activity may not be continued long term, and the infrastructure is unlikely to be a worthwhile investment in the short term
  • ",n,r,y="When lack of infrastructure becomes painful, it creates clarity about what problems the infrastructure needs to solve.",p,o,x="Once it becomes clear than an activity is going to continue, Automation unlocks progressively more meaningful problems.";return{c(){t=d("p"),t.textContent=l,s=g(),i=d("ul"),i.innerHTML=e,n=g(),r=d("p"),r.textContent=y,p=g(),o=d("p"),o.innerHTML=x},l(a){t=_(a,"P",{"data-svelte-h":!0}),h(t)!=="svelte-gcu0n6"&&(t.textContent=l),s=v(a),i=_(a,"UL",{"data-svelte-h":!0}),h(i)!=="svelte-16rulgd"&&(i.innerHTML=e),n=v(a),r=_(a,"P",{"data-svelte-h":!0}),h(r)!=="svelte-1agja4r"&&(r.textContent=y),p=v(a),o=_(a,"P",{"data-svelte-h":!0}),h(o)!=="svelte-go18a"&&(o.innerHTML=x)},m(a,u){c(a,t,u),c(a,s,u),c(a,i,u),c(a,n,u),c(a,r,u),c(a,p,u),c(a,o,u)},p:k,d(a){a&&(f(t),f(s),f(i),f(n),f(r),f(p),f(o))}}}function D(m){let t,l;const s=[m[0],C];let i={$$slots:{default:[A]},$$scope:{ctx:m}};for(let e=0;e{l(0,t=b(b({},t),w(s)))},t=w(t),[t]}class E extends L{constructor(t){super(),M(this,t,N,D,$,{})}}export{E as default,C as metadata}; diff --git a/_app/immutable/chunks/Classy coding - JavaScript OOP through the ages.jfyk4FZV.js b/_app/immutable/chunks/Classy coding - JavaScript OOP through the ages.d2kAFBeU.js similarity index 99% rename from _app/immutable/chunks/Classy coding - JavaScript OOP through the ages.jfyk4FZV.js rename to _app/immutable/chunks/Classy coding - JavaScript OOP through the ages.d2kAFBeU.js index 02456088a0..4801b6ba8d 100644 --- a/_app/immutable/chunks/Classy coding - JavaScript OOP through the ages.jfyk4FZV.js +++ b/_app/immutable/chunks/Classy coding - JavaScript OOP through the ages.d2kAFBeU.js @@ -1,4 +1,4 @@ -import{s as pl,p as Yt,q as _i,e as l,a as n,H as p,u as c,c as o,m as r,g as i,v as h,o as C,i as a,n as cl,f as t}from"./scheduler.ewBkyc9q.js";import{S as hl,i as dl,c as kl,a as yl,m as ul,t as fl,b as Al,d as ml}from"./index.DpmaPz1F.js";import{g as wl,a as bi}from"./spread.CgU5AtxT.js";import{M as Bl}from"./MDSveXNoteLayout.PyyVkf3i.js";function vl(Us){let d,m="This blog post was originally presented at SeattleJS in August 2024.",f,y,k='Constructing a class in JavaScript',u,A,Nt="Object-Oriented Programming (OOP) has been around for a long time and in many languages. JavaScript is no exception to that, which should come as no surprise to anyone using JS today. It hasn’t always been a first-class paradigm in the language, though.",ua,x,Wt="Let’s embark on a journey to learn about how OOP has been done throughout JavaScript’s history, with our destination set on understanding how we should do it today and what all the modern syntax is doing for us under the hood.",fa,w,Gt='The prototype chain',Aa,T,Zt="Imagine a classic OOP problem - you have a bunch of objects that share an “is a” relationship. This “is a” relationship is typically used to explain when multiple objects should share a “class” type. I’ll use rectangles to keep it easy. So we have a bunch of objects, each of which “is a” rectangle - how do we represent that so and give each rectangle instance the interface a rectangle class should have?",ma,L,Ut="To start, let’s make a rectangle instance. Write or paste this code into your browser console to make one:",wa,Ks,xi=`
    let rect1 = {width: 4, height: 5};
    +import{s as pl,p as Yt,q as _i,e as l,a as n,H as p,u as c,c as o,m as r,g as i,v as h,o as C,i as a,n as cl,f as t}from"./scheduler.ewBkyc9q.js";import{S as hl,i as dl,c as kl,a as yl,m as ul,t as fl,b as Al,d as ml}from"./index.DpmaPz1F.js";import{g as wl,a as bi}from"./spread.CgU5AtxT.js";import{M as Bl}from"./MDSveXNoteLayout.Bx5vQYjx.js";function vl(Us){let d,m="This blog post was originally presented at SeattleJS in August 2024.",f,y,k='Constructing a class in JavaScript',u,A,Nt="Object-Oriented Programming (OOP) has been around for a long time and in many languages. JavaScript is no exception to that, which should come as no surprise to anyone using JS today. It hasn’t always been a first-class paradigm in the language, though.",ua,x,Wt="Let’s embark on a journey to learn about how OOP has been done throughout JavaScript’s history, with our destination set on understanding how we should do it today and what all the modern syntax is doing for us under the hood.",fa,w,Gt='The prototype chain',Aa,T,Zt="Imagine a classic OOP problem - you have a bunch of objects that share an “is a” relationship. This “is a” relationship is typically used to explain when multiple objects should share a “class” type. I’ll use rectangles to keep it easy. So we have a bunch of objects, each of which “is a” rectangle - how do we represent that so and give each rectangle instance the interface a rectangle class should have?",ma,L,Ut="To start, let’s make a rectangle instance. Write or paste this code into your browser console to make one:",wa,Ks,xi=`
    let rect1 = {width: 4, height: 5};
     rect1
    `,$s,Xs,Ti=``,se,M,Kt="The second line should cause the console to display a reference to the rect1 object. You may have noticed that both properties fit in a single line, but the dev tools still give you an option to expand the object. Isn’t that weird?",Ba,R,$t=' The chrome dev tools showing the rectangle's width and height properties and values, as well as an arrow icon to expand the view.',va,H,Xt="If my object only those two properties and they both fit on screen, why would I need to expand it?",ga,E,sn="As you’ll quickly find, there’s my height and width properties, as well as some weird [[Prototype]] object. Continuing to expand the [[Prototype]] object reveals a few more things. Some of them, like toString() and hasOwnProperty() probably look familiar. Others, such as isPrototypeOf() may not be.",Da,j,en="You see, JavaScript has an unusual approach to inheritance called a prototype chain. It’s a linked list of object instances. Each instance makes up one part of the object. I think it’s easier to understand interactive exploration, so crack open your browser dev console or favorite JS REPL and let’s explore!",_a,S,an="The special [[Prototype]] property on this object by default is called the object prototype. Whenever you create an object in JS, the object prototype is added to your object’s prototype chain automatically. You can also access it without dev tools by using an arcane incantation: rect1.__proto__. Entering that in the dev tools console will show the same thing as expanding the [[Prototype]] object, and that’s because it is the same object.",ba,F,tn="But how does this relate to our rectangle? Well it turns out that you can specify a custom prototype object. Think of prototype objects as a “class” or “class type” from other languages. First, let’s define the functionality of our rectangle class:",Ca,ee,Li=`
    const baseRectangle = {
     	isSquare: function() { return this.width === this.height },
    diff --git a/_app/immutable/chunks/Dynamically generate TypeScript Playground links.CDm1Y06m.js b/_app/immutable/chunks/Dynamically generate TypeScript Playground links.ydr-BTfi.js
    similarity index 99%
    rename from _app/immutable/chunks/Dynamically generate TypeScript Playground links.CDm1Y06m.js
    rename to _app/immutable/chunks/Dynamically generate TypeScript Playground links.ydr-BTfi.js
    index e4f9c5128b..1e3aa18ff1 100644
    --- a/_app/immutable/chunks/Dynamically generate TypeScript Playground links.CDm1Y06m.js	
    +++ b/_app/immutable/chunks/Dynamically generate TypeScript Playground links.ydr-BTfi.js	
    @@ -1,4 +1,4 @@
    -import{s as J,p as E,q as R,e as d,a as c,H as U,u as Z,c as h,m as y,g as m,v as j,i as l,n as N,f as t}from"./scheduler.ewBkyc9q.js";import{S as W,i as X,c as K,a as Q,m as V,t as Y,b as ss,d as as}from"./index.DpmaPz1F.js";import{g as es,a as z}from"./spread.CgU5AtxT.js";import{M as ns}from"./MDSveXNoteLayout.PyyVkf3i.js";function ls(B){let a,k='Recently I was presenting a talk at SeattleJS on Branded Types using my blog post as the visual content. I wanted to do some live coding, so I decided to add TypeScript playground links to my code snippets.',p,o,e='Fun fact: it’s possible to dynamically generate TypeScript playground links!',i,r,P="The process is fairly simple:",x,u,H="
  • Use lz-string to base64 encode and zip the source code and URI encode the result (use LZString.compressToEncodedURIComponent(), an easy one-liner)
  • Append the encoded string to a playground URL
  • Put the link on the code block
  • ",b,D,I="I love this solution because it generates an updated link every time I build my site. I’m guaranteed to have up-to-date playground links and don’t have to do anything after the initial setup. Awesome!",L,f,F='I followed the TS playground docs to write the code that generates TS playground links. I updated my code highlighter function to generate the TS playground links and add them to a data-tsplay attribute on the containing <pre> tag for each TS code block. Check it out:',w,C,O=`
    import LZString from 'lz-string';
    +import{s as J,p as E,q as R,e as d,a as c,H as U,u as Z,c as h,m as y,g as m,v as j,i as l,n as N,f as t}from"./scheduler.ewBkyc9q.js";import{S as W,i as X,c as K,a as Q,m as V,t as Y,b as ss,d as as}from"./index.DpmaPz1F.js";import{g as es,a as z}from"./spread.CgU5AtxT.js";import{M as ns}from"./MDSveXNoteLayout.Bx5vQYjx.js";function ls(B){let a,k='Recently I was presenting a talk at SeattleJS on Branded Types using my blog post as the visual content. I wanted to do some live coding, so I decided to add TypeScript playground links to my code snippets.',p,o,e='Fun fact: it’s possible to dynamically generate TypeScript playground links!',i,r,P="The process is fairly simple:",x,u,H="
  • Use lz-string to base64 encode and zip the source code and URI encode the result (use LZString.compressToEncodedURIComponent(), an easy one-liner)
  • Append the encoded string to a playground URL
  • Put the link on the code block
  • ",b,D,I="I love this solution because it generates an updated link every time I build my site. I’m guaranteed to have up-to-date playground links and don’t have to do anything after the initial setup. Awesome!",L,f,F='I followed the TS playground docs to write the code that generates TS playground links. I updated my code highlighter function to generate the TS playground links and add them to a data-tsplay attribute on the containing <pre> tag for each TS code block. Check it out:',w,C,O=`
    import LZString from 'lz-string';
     import { codeToHtml } from 'shiki';
     import { transformerTwoslash } from '@shikijs/twoslash';
     import { lex, parse } from 'fenceparser';
    diff --git a/_app/immutable/chunks/Gifts.BhLplezO.js b/_app/immutable/chunks/Gifts.D3riRslI.js
    similarity index 98%
    rename from _app/immutable/chunks/Gifts.BhLplezO.js
    rename to _app/immutable/chunks/Gifts.D3riRslI.js
    index 3493e53c63..59fa47ae35 100644
    --- a/_app/immutable/chunks/Gifts.BhLplezO.js
    +++ b/_app/immutable/chunks/Gifts.D3riRslI.js
    @@ -1 +1 @@
    -import{s as F,p as L,q,e as m,a as g,c as h,m as u,g as b,i as s,f as l,n as Z}from"./scheduler.ewBkyc9q.js";import{S as O,i as Q,c as D,a as E,m as G,t as N,b as Y,d as U}from"./index.DpmaPz1F.js";import{g as R,a as z}from"./spread.CgU5AtxT.js";import{M as V}from"./MDSveXNoteLayout.PyyVkf3i.js";import{T as W}from"./Table.CTCItcQk.js";function X(p){let e,f="Price Item",r,n,a='$20 Bambu Lab P1 compatible PLA filament ??? A new iPhone 13 pro max case $30 The Art of Doing Science and Engineering $30 The Nature of Code $50 Dominion board game $180 Trash fire signet ring $320 Burning bridge ring $400 Egofit walker Pro $400ah Adjustable dumbbells $460 Le Creuset 7.25qt dutch oven in Cream $1600 Herman Miller Aeron in mineral/satin aluminum (used is fine!) $1900 Apple Studio display with VESA mount (used is fine!) $2400 Tenon mini smart desk (used is fine!) ??? Space age / retrofuturistic decor';return{c(){e=m("thead"),e.innerHTML=f,r=g(),n=m("tbody"),n.innerHTML=a},l(o){e=h(o,"THEAD",{"data-svelte-h":!0}),u(e)!=="svelte-m5fnal"&&(e.innerHTML=f),r=b(o),n=h(o,"TBODY",{"data-svelte-h":!0}),u(n)!=="svelte-2teed8"&&(n.innerHTML=a)},m(o,d){s(o,e,d),s(o,r,d),s(o,n,d)},p:Z,d(o){o&&(l(e),l(r),l(n))}}}function J(p){let e,f="Soon I will complete another lap around the sun, and I find myself in the fortunate position of having many wonderful people who wish to celebrate with me! Some wish to show their love with gifts, but often it can be challenging to figure out what to give. My hope with this post is to share my thoughts on gifting, some broad ideas of gifts I think are great, and some specific examples for anyone who prefers to know exactly what to get.",r,n,a="My view is that gifts should always be optional. I don’t ask or expect anyone to give me gifts, and I dislike when they are expected from me in other contexts. I think expectation robs them of their meaning as a gesture of love.",o,d,M="Sometimes I have a great idea for a gift for someone, and it brings me a lot of joy to give someone a gift they love. Not everyone is the same way, though. If you find buying gifts stressful and unpleasant, please don’t!",x,w,P="For those who want to give me a gift, I’ve identified some themes among gifts that I tend to like:",$,y,S="
  • They facilitate having quality time with the people in my life
  • They bring joy, inspiration, and/or beauty into my life
  • They are something I didn’t know existed or are hard to procure
  • They are useful
  • They are something I can see often that will remind me of the gift giver
  • They are made by you
  • ",T,v,H="It’s possible for a gift to touch on multiple themes and even to cost nothing. As one example, a friend helped me with some gardening. We got to spend some quality time together making my home more beautiful, and the plants double as a reminder of our friendship every time I see them.",C,_,A="If you really want to give me a gift, but none of those themes are leading you to a specific gift, or you are the type of person who prefers to pick something from a wishlist, I have one below. I apologize for the limited options at lower price points. Typically if I know I want something and it’s inexpensive, I will just buy it for myself and it doesn’t have the chance to end up on such a list.",I,c,k;return c=new W({props:{$$slots:{default:[X]},$$scope:{ctx:p}}}),{c(){e=m("p"),e.textContent=f,r=g(),n=m("p"),n.innerHTML=a,o=g(),d=m("p"),d.textContent=M,x=g(),w=m("p"),w.innerHTML=P,$=g(),y=m("ul"),y.innerHTML=S,T=g(),v=m("p"),v.textContent=H,C=g(),_=m("p"),_.textContent=A,I=g(),D(c.$$.fragment)},l(t){e=h(t,"P",{"data-svelte-h":!0}),u(e)!=="svelte-1it5kwz"&&(e.textContent=f),r=b(t),n=h(t,"P",{"data-svelte-h":!0}),u(n)!=="svelte-d59k34"&&(n.innerHTML=a),o=b(t),d=h(t,"P",{"data-svelte-h":!0}),u(d)!=="svelte-g6qop1"&&(d.textContent=M),x=b(t),w=h(t,"P",{"data-svelte-h":!0}),u(w)!=="svelte-evikek"&&(w.innerHTML=P),$=b(t),y=h(t,"UL",{"data-svelte-h":!0}),u(y)!=="svelte-1oxapta"&&(y.innerHTML=S),T=b(t),v=h(t,"P",{"data-svelte-h":!0}),u(v)!=="svelte-pe1npl"&&(v.textContent=H),C=b(t),_=h(t,"P",{"data-svelte-h":!0}),u(_)!=="svelte-1d6dxbc"&&(_.textContent=A),I=b(t),E(c.$$.fragment,t)},m(t,i){s(t,e,i),s(t,r,i),s(t,n,i),s(t,o,i),s(t,d,i),s(t,x,i),s(t,w,i),s(t,$,i),s(t,y,i),s(t,T,i),s(t,v,i),s(t,C,i),s(t,_,i),s(t,I,i),G(c,t,i),k=!0},p(t,i){const j={};i&2&&(j.$$scope={dirty:i,ctx:t}),c.$set(j)},i(t){k||(N(c.$$.fragment,t),k=!0)},o(t){Y(c.$$.fragment,t),k=!1},d(t){t&&(l(e),l(r),l(n),l(o),l(d),l(x),l(w),l($),l(y),l(T),l(v),l(C),l(_),l(I)),U(c,t)}}}function K(p){let e,f;const r=[p[0],B];let n={$$slots:{default:[J]},$$scope:{ctx:p}};for(let a=0;a{f(0,e=L(L({},e),q(r)))},e=q(e),[e]}class st extends O{constructor(e){super(),Q(this,e,tt,K,F,{})}}export{st as default,B as metadata}; +import{s as F,p as L,q,e as m,a as g,c as h,m as u,g as b,i as s,f as l,n as Z}from"./scheduler.ewBkyc9q.js";import{S as O,i as Q,c as D,a as E,m as G,t as N,b as Y,d as U}from"./index.DpmaPz1F.js";import{g as R,a as z}from"./spread.CgU5AtxT.js";import{M as V}from"./MDSveXNoteLayout.Bx5vQYjx.js";import{T as W}from"./Table.D4VRZ6lr.js";function X(p){let e,f="Price Item",r,n,a='$20 Bambu Lab P1 compatible PLA filament ??? A new iPhone 13 pro max case $30 The Art of Doing Science and Engineering $30 The Nature of Code $50 Dominion board game $180 Trash fire signet ring $320 Burning bridge ring $400 Egofit walker Pro $400ah Adjustable dumbbells $460 Le Creuset 7.25qt dutch oven in Cream $1600 Herman Miller Aeron in mineral/satin aluminum (used is fine!) $1900 Apple Studio display with VESA mount (used is fine!) $2400 Tenon mini smart desk (used is fine!) ??? Space age / retrofuturistic decor';return{c(){e=m("thead"),e.innerHTML=f,r=g(),n=m("tbody"),n.innerHTML=a},l(o){e=h(o,"THEAD",{"data-svelte-h":!0}),u(e)!=="svelte-m5fnal"&&(e.innerHTML=f),r=b(o),n=h(o,"TBODY",{"data-svelte-h":!0}),u(n)!=="svelte-2teed8"&&(n.innerHTML=a)},m(o,d){s(o,e,d),s(o,r,d),s(o,n,d)},p:Z,d(o){o&&(l(e),l(r),l(n))}}}function J(p){let e,f="Soon I will complete another lap around the sun, and I find myself in the fortunate position of having many wonderful people who wish to celebrate with me! Some wish to show their love with gifts, but often it can be challenging to figure out what to give. My hope with this post is to share my thoughts on gifting, some broad ideas of gifts I think are great, and some specific examples for anyone who prefers to know exactly what to get.",r,n,a="My view is that gifts should always be optional. I don’t ask or expect anyone to give me gifts, and I dislike when they are expected from me in other contexts. I think expectation robs them of their meaning as a gesture of love.",o,d,M="Sometimes I have a great idea for a gift for someone, and it brings me a lot of joy to give someone a gift they love. Not everyone is the same way, though. If you find buying gifts stressful and unpleasant, please don’t!",x,w,P="For those who want to give me a gift, I’ve identified some themes among gifts that I tend to like:",$,y,S="
  • They facilitate having quality time with the people in my life
  • They bring joy, inspiration, and/or beauty into my life
  • They are something I didn’t know existed or are hard to procure
  • They are useful
  • They are something I can see often that will remind me of the gift giver
  • They are made by you
  • ",T,v,H="It’s possible for a gift to touch on multiple themes and even to cost nothing. As one example, a friend helped me with some gardening. We got to spend some quality time together making my home more beautiful, and the plants double as a reminder of our friendship every time I see them.",C,_,A="If you really want to give me a gift, but none of those themes are leading you to a specific gift, or you are the type of person who prefers to pick something from a wishlist, I have one below. I apologize for the limited options at lower price points. Typically if I know I want something and it’s inexpensive, I will just buy it for myself and it doesn’t have the chance to end up on such a list.",I,c,k;return c=new W({props:{$$slots:{default:[X]},$$scope:{ctx:p}}}),{c(){e=m("p"),e.textContent=f,r=g(),n=m("p"),n.innerHTML=a,o=g(),d=m("p"),d.textContent=M,x=g(),w=m("p"),w.innerHTML=P,$=g(),y=m("ul"),y.innerHTML=S,T=g(),v=m("p"),v.textContent=H,C=g(),_=m("p"),_.textContent=A,I=g(),D(c.$$.fragment)},l(t){e=h(t,"P",{"data-svelte-h":!0}),u(e)!=="svelte-1it5kwz"&&(e.textContent=f),r=b(t),n=h(t,"P",{"data-svelte-h":!0}),u(n)!=="svelte-d59k34"&&(n.innerHTML=a),o=b(t),d=h(t,"P",{"data-svelte-h":!0}),u(d)!=="svelte-g6qop1"&&(d.textContent=M),x=b(t),w=h(t,"P",{"data-svelte-h":!0}),u(w)!=="svelte-evikek"&&(w.innerHTML=P),$=b(t),y=h(t,"UL",{"data-svelte-h":!0}),u(y)!=="svelte-1oxapta"&&(y.innerHTML=S),T=b(t),v=h(t,"P",{"data-svelte-h":!0}),u(v)!=="svelte-pe1npl"&&(v.textContent=H),C=b(t),_=h(t,"P",{"data-svelte-h":!0}),u(_)!=="svelte-1d6dxbc"&&(_.textContent=A),I=b(t),E(c.$$.fragment,t)},m(t,i){s(t,e,i),s(t,r,i),s(t,n,i),s(t,o,i),s(t,d,i),s(t,x,i),s(t,w,i),s(t,$,i),s(t,y,i),s(t,T,i),s(t,v,i),s(t,C,i),s(t,_,i),s(t,I,i),G(c,t,i),k=!0},p(t,i){const j={};i&2&&(j.$$scope={dirty:i,ctx:t}),c.$set(j)},i(t){k||(N(c.$$.fragment,t),k=!0)},o(t){Y(c.$$.fragment,t),k=!1},d(t){t&&(l(e),l(r),l(n),l(o),l(d),l(x),l(w),l($),l(y),l(T),l(v),l(C),l(_),l(I)),U(c,t)}}}function K(p){let e,f;const r=[p[0],B];let n={$$slots:{default:[J]},$$scope:{ctx:p}};for(let a=0;a{f(0,e=L(L({},e),q(r)))},e=q(e),[e]}class st extends O{constructor(e){super(),Q(this,e,tt,K,F,{})}}export{st as default,B as metadata}; diff --git a/_app/immutable/chunks/Gold Mac n Cheese.BJDx47al.js b/_app/immutable/chunks/Gold Mac n Cheese.wwiG7Xog.js similarity index 98% rename from _app/immutable/chunks/Gold Mac n Cheese.BJDx47al.js rename to _app/immutable/chunks/Gold Mac n Cheese.wwiG7Xog.js index 336fd20ee5..d9bc89134c 100644 --- a/_app/immutable/chunks/Gold Mac n Cheese.BJDx47al.js +++ b/_app/immutable/chunks/Gold Mac n Cheese.wwiG7Xog.js @@ -1,3 +1,3 @@ -import{s as de,p as U,q as ee,e as d,a as m,c as u,m as c,g as p,o as E,i as n,f as i,n as ue}from"./scheduler.ewBkyc9q.js";import{S as ce,i as he,c as ne,a as ie,m as le,t as se,b as oe,d as re}from"./index.DpmaPz1F.js";import{g as me,a as te}from"./spread.CgU5AtxT.js";import{M as pe}from"./MDSveXNoteLayout.PyyVkf3i.js";import{T as fe}from"./Table.CTCItcQk.js";function ve(v){let t,f="Ingredient Amount",r,o,l="Orzo pasta (dry) 3/4 cup grape or cherry tomatoes ~8 tomatoes Chicken (or vegetable) stock .75 quarts Cougar gold cheese 2.5 cups Butter 2 tbsp Heavy cream 1/2 cup Saffron ~1/3 tsp";return{c(){t=d("thead"),t.innerHTML=f,r=m(),o=d("tbody"),o.innerHTML=l},l(s){t=u(s,"THEAD",{"data-svelte-h":!0}),c(t)!=="svelte-1tnhzrc"&&(t.innerHTML=f),r=p(s),o=u(s,"TBODY",{"data-svelte-h":!0}),c(o)!=="svelte-eylzu0"&&(o.innerHTML=l)},m(s,h){n(s,t,h),n(s,r,h),n(s,o,h)},p:ue,d(s){s&&(i(t),i(r),i(o))}}}function _e(v){let t,f="As a kid, I absolutely loved mac n cheese. Easily my favorite dish. Even if it came in a blue box and the cheese was a powder that smelled a bit like dog food, I still enjoyed it. As I grew from an adolescent to a teenager and young adult, I would never miss out on the opportunity to order a fancy mac n cheese at a nice restaurant.",r,o,l="Now that I’m an adult, just about everything has changed! I’ve traveled the world and explored the cuisines of many cultures. I’ve dined in michelin-starred restaurants and even learned some molecular gastronomy techniques. My palate is much more refined than it was in my blue box mac n cheese days.",s,h,G="But I still adore mac n cheese. Some things never change 😅",M,y,N="Recently I’ve been on a mission to make an incredible mac n cheese that beautifully combines my favorite takes on mac n cheese into one luxurious package.",w,C,Z="This is a working note as I iterate on the recipe. I haven’t figure out how to incorporate all my favorite aspects of the best mac n cheeses I’ve eaten yet. This recipe isn’t done, but it is already delicious and at a point where guests rave about it.",I,k,R="Some of the techniques that make this mac n cheese especially luxurious are:",q,T,W="
  • Cooking the macaroni in stock instead of water to produce a richer flavor
  • Cougar gold cheese has a particularly deep and complex flavor. I prefer this to mixing cheeses.
  • Using saffron for an elevated taste and rich gold color
  • The blistered tomatoes add some complementary acidity that helps balance the fattiness of the cheese
  • ",z,_,X='Ingredients',S,$,Y="These ingredients make ~4 modest or 2-3 generous servings. As a main dish, plan on a generous serving per person.",O,x,A,b,F='Prep',P,H,J="
  • Break up the cheese into small pieces. This isn’t an exact science, but the smaller the pieces the faster it melts.
  • Wash the tomatoes
  • ",B,g,K='Steps',j,L,Q=`
  • Bring 2 cups of chicken stock to a low boil. Use a wide pot or sauté pan if available. +import{s as de,p as U,q as ee,e as d,a as m,c as u,m as c,g as p,o as E,i as n,f as i,n as ue}from"./scheduler.ewBkyc9q.js";import{S as ce,i as he,c as ne,a as ie,m as le,t as se,b as oe,d as re}from"./index.DpmaPz1F.js";import{g as me,a as te}from"./spread.CgU5AtxT.js";import{M as pe}from"./MDSveXNoteLayout.Bx5vQYjx.js";import{T as fe}from"./Table.D4VRZ6lr.js";function ve(v){let t,f="Ingredient Amount",r,o,l="Orzo pasta (dry) 3/4 cup grape or cherry tomatoes ~8 tomatoes Chicken (or vegetable) stock .75 quarts Cougar gold cheese 2.5 cups Butter 2 tbsp Heavy cream 1/2 cup Saffron ~1/3 tsp";return{c(){t=d("thead"),t.innerHTML=f,r=m(),o=d("tbody"),o.innerHTML=l},l(s){t=u(s,"THEAD",{"data-svelte-h":!0}),c(t)!=="svelte-1tnhzrc"&&(t.innerHTML=f),r=p(s),o=u(s,"TBODY",{"data-svelte-h":!0}),c(o)!=="svelte-eylzu0"&&(o.innerHTML=l)},m(s,h){n(s,t,h),n(s,r,h),n(s,o,h)},p:ue,d(s){s&&(i(t),i(r),i(o))}}}function _e(v){let t,f="As a kid, I absolutely loved mac n cheese. Easily my favorite dish. Even if it came in a blue box and the cheese was a powder that smelled a bit like dog food, I still enjoyed it. As I grew from an adolescent to a teenager and young adult, I would never miss out on the opportunity to order a fancy mac n cheese at a nice restaurant.",r,o,l="Now that I’m an adult, just about everything has changed! I’ve traveled the world and explored the cuisines of many cultures. I’ve dined in michelin-starred restaurants and even learned some molecular gastronomy techniques. My palate is much more refined than it was in my blue box mac n cheese days.",s,h,G="But I still adore mac n cheese. Some things never change 😅",M,y,N="Recently I’ve been on a mission to make an incredible mac n cheese that beautifully combines my favorite takes on mac n cheese into one luxurious package.",w,C,Z="This is a working note as I iterate on the recipe. I haven’t figure out how to incorporate all my favorite aspects of the best mac n cheeses I’ve eaten yet. This recipe isn’t done, but it is already delicious and at a point where guests rave about it.",I,k,R="Some of the techniques that make this mac n cheese especially luxurious are:",q,T,W="
  • Cooking the macaroni in stock instead of water to produce a richer flavor
  • Cougar gold cheese has a particularly deep and complex flavor. I prefer this to mixing cheeses.
  • Using saffron for an elevated taste and rich gold color
  • The blistered tomatoes add some complementary acidity that helps balance the fattiness of the cheese
  • ",z,_,X='Ingredients',S,$,Y="These ingredients make ~4 modest or 2-3 generous servings. As a main dish, plan on a generous serving per person.",O,x,A,b,F='Prep',P,H,J="
  • Break up the cheese into small pieces. This isn’t an exact science, but the smaller the pieces the faster it melts.
  • Wash the tomatoes
  • ",B,g,K='Steps',j,L,Q=`
  • Bring 2 cups of chicken stock to a low boil. Use a wide pot or sauté pan if available.
    1. Add 1/4 of the saffron to the stock
    2. if using unsalted chicken stock, add ~1tsp kosher salt.
  • Add dry orzo to chicken stock and reduce temperature to medium-low.
    1. Cover and stir every minute.
    2. Only add more chicken stock in small amounts if there is little to no liquid left. The goal is to get the orzo to slightly less than al dente with almost no liquid left.
    3. Turn off the heat and keep covered.
  • In a separate pan, melt the butter over medium heat. Once it is hot, add the tomatoes.
  • Sauté the tomatoes for 1.5-2 minutes without moving them. Once they start to blister, rotate and repeat.
  • Once tomatoes are twice blistered, reduce heat to medium-low. Add the cream, crumbled cougar gold cheese, and remaining saffron to the pan.
  • Stir cheese and cream continuously until the cheese is fully melted.
  • Once cheese is fully melted, combine cheese & tomatoes into the pot with orzo and mix together until thoroughly coated.
  • Serve and enjoy!
  • `,D;return x=new fe({props:{$$slots:{default:[ve]},$$scope:{ctx:v}}}),{c(){t=d("p"),t.textContent=f,r=m(),o=d("p"),o.textContent=l,s=m(),h=d("p"),h.textContent=G,M=m(),y=d("p"),y.textContent=N,w=m(),C=d("p"),C.innerHTML=Z,I=m(),k=d("p"),k.textContent=R,q=m(),T=d("ul"),T.innerHTML=W,z=m(),_=d("h2"),_.innerHTML=X,S=m(),$=d("p"),$.textContent=Y,O=m(),ne(x.$$.fragment),A=m(),b=d("h2"),b.innerHTML=F,P=m(),H=d("ol"),H.innerHTML=J,B=m(),g=d("h2"),g.innerHTML=K,j=m(),L=d("ol"),L.innerHTML=Q,this.h()},l(e){t=u(e,"P",{"data-svelte-h":!0}),c(t)!=="svelte-lv6pwl"&&(t.textContent=f),r=p(e),o=u(e,"P",{"data-svelte-h":!0}),c(o)!=="svelte-1ozemcx"&&(o.textContent=l),s=p(e),h=u(e,"P",{"data-svelte-h":!0}),c(h)!=="svelte-1aismis"&&(h.textContent=G),M=p(e),y=u(e,"P",{"data-svelte-h":!0}),c(y)!=="svelte-8bza9c"&&(y.textContent=N),w=p(e),C=u(e,"P",{"data-svelte-h":!0}),c(C)!=="svelte-elv609"&&(C.innerHTML=Z),I=p(e),k=u(e,"P",{"data-svelte-h":!0}),c(k)!=="svelte-kviz51"&&(k.textContent=R),q=p(e),T=u(e,"UL",{"data-svelte-h":!0}),c(T)!=="svelte-qqgqg6"&&(T.innerHTML=W),z=p(e),_=u(e,"H2",{id:!0,"data-svelte-h":!0}),c(_)!=="svelte-9bt1ri"&&(_.innerHTML=X),S=p(e),$=u(e,"P",{"data-svelte-h":!0}),c($)!=="svelte-1jz11v4"&&($.textContent=Y),O=p(e),ie(x.$$.fragment,e),A=p(e),b=u(e,"H2",{id:!0,"data-svelte-h":!0}),c(b)!=="svelte-1v0ieby"&&(b.innerHTML=F),P=p(e),H=u(e,"OL",{"data-svelte-h":!0}),c(H)!=="svelte-1gtc0s5"&&(H.innerHTML=J),B=p(e),g=u(e,"H2",{id:!0,"data-svelte-h":!0}),c(g)!=="svelte-1g870dg"&&(g.innerHTML=K),j=p(e),L=u(e,"OL",{"data-svelte-h":!0}),c(L)!=="svelte-blhef5"&&(L.innerHTML=Q),this.h()},h(){E(_,"id","ingredients"),E(b,"id","prep"),E(g,"id","steps")},m(e,a){n(e,t,a),n(e,r,a),n(e,o,a),n(e,s,a),n(e,h,a),n(e,M,a),n(e,y,a),n(e,w,a),n(e,C,a),n(e,I,a),n(e,k,a),n(e,q,a),n(e,T,a),n(e,z,a),n(e,_,a),n(e,S,a),n(e,$,a),n(e,O,a),le(x,e,a),n(e,A,a),n(e,b,a),n(e,P,a),n(e,H,a),n(e,B,a),n(e,g,a),n(e,j,a),n(e,L,a),D=!0},p(e,a){const V={};a&2&&(V.$$scope={dirty:a,ctx:e}),x.$set(V)},i(e){D||(se(x.$$.fragment,e),D=!0)},o(e){oe(x.$$.fragment,e),D=!1},d(e){e&&(i(t),i(r),i(o),i(s),i(h),i(M),i(y),i(w),i(C),i(I),i(k),i(q),i(T),i(z),i(_),i(S),i($),i(O),i(A),i(b),i(P),i(H),i(B),i(g),i(j),i(L)),re(x,e)}}}function xe(v){let t,f;const r=[v[0],ae];let o={$$slots:{default:[_e]},$$scope:{ctx:v}};for(let l=0;l{f(0,t=U(U({},t),ee(r)))},t=ee(t),[t]}class $e extends ce{constructor(t){super(),he(this,t,be,xe,de,{})}}export{$e as default,ae as metadata}; diff --git a/_app/immutable/chunks/I use Neovim btw.DU6k28i5.js b/_app/immutable/chunks/I use Neovim btw.BSDQA274.js similarity index 99% rename from _app/immutable/chunks/I use Neovim btw.DU6k28i5.js rename to _app/immutable/chunks/I use Neovim btw.BSDQA274.js index 3d794ea53b..7e59d5a3b1 100644 --- a/_app/immutable/chunks/I use Neovim btw.DU6k28i5.js +++ b/_app/immutable/chunks/I use Neovim btw.BSDQA274.js @@ -1 +1 @@ -import{s as Xe,p as ce,q as Ne,e as o,a as s,c as a,m as l,g as r,o as We,i,n as Ze,f as n}from"./scheduler.ewBkyc9q.js";import{S as Ge,i as Re,c as Ye,a as Be,m as Fe,t as Ke,b as Qe,d as Je}from"./index.DpmaPz1F.js";import{g as et,a as $e}from"./spread.CgU5AtxT.js";import{M as tt}from"./MDSveXNoteLayout.PyyVkf3i.js";function it(W){let h,p="I’ve been writing code in various capacities for nearly twenty years now, though only seriously for around the past 10 years. Despite getting into Arch linux as a hobby in my early teens, I never really put a lot of thought into my text editor & IDE setup. Notepad++, followed by Sublime text, then Visual Studio, and finally VS Code have always felt sufficient to me.",c,d,u="While I’ve been aware of vim for years, I’ve long held the opinion that the steep learning curve isn’t worth it. Most of my time programming isn’t spent text editing problems. I spend a lot more time on problems like:",m,f,fe="
  • What’s the best approach to implement this?
  • How can I configure X to do Y?
  • How should I architect this system?
  • Which API design is going to be the most intuitive for consumers?
  • What’s the best way to communicate these trade-offs in a spec to ensure we have a valuable discussion about this work?
  • Which edge cases do I need to consider and test for?
  • ",$,y,pe="I have spent comparably little time on text editing problems such as:",O,w,ve="
  • How can I delete this code I’m not using?
  • What’s the fastest way to refactor this hacky testing code into a proper unit/integration test?
  • How can I quickly reshape this series of function calls in object property k:v pairs?
  • ",X,b,ge="Learning vim to optimize my text editing skills - which only take up about 25% of my time “programming” - is something I’ve always concluded is not worth it.",Z,x,ye="Additionally, VS Code has incredibly broad adoption across technology stacks today. It’s excellent plugin architecture has produced a thriving ecosystem of 3rd-party add-ons that means in-editor support for every technology is just a couple clicks away. Plus, Microsoft has done something that seemed impossible in the past: established industry standards for integrating an editor with both programming language tools (via Language Server Protocol, or LSP) and debuggers (via the Debug Adapter Protocol, or DAP). It almost feels ridiculous to consider another editor right now…",G,k,we='As it turns out, Microsoft’s fantastic success establishing industry standards with LSP and DAP has been great for the rest of the editor ecosystem. Thanks to the standardized APIs, other editors have tapped into the incredible work. There are now many editors with modern features (or plugins) built leveraging these standards, such as:',R,I,be='
  • Language-aware semantic syntax highlighting
  • Language-specific text completion suggestions
  • Integrated debugger support
  • ',Y,C,xe="The reality is that while VS Code is perhaps the most dominant a text editor has ever been, the quality of alternatives is also better than ever. Recently, I’ve been doing more and more tinkering with my text editors. I tried out Zed, set up a custom launch.json to debug a Deno project, and even customized my VS Code UI to look more minimal:",B,T,ke=' A code block on allandeutsch.com rendered to show the filename in a tab along the top bar of the code block',F,_,Ie='Meanwhile, the YouTube algorithm has been recommending me videos from TypeCraft, a dev YouTuber who makes content about configuring your dev environment using linux, tmux, and neovim. I’ve been in the mood for learning recently, so on Sunday afternoon I decided to go through TypeCraft’s free course on setting up Neovim as an IDE. Note that the course is on setting up the IDE, not on vim motions and keybindings. I went into this with extremely basic vim skills - I could change between normal and insert mode, save a file, exit vim, and not much more.',K,v,Ce='Configuring Neovim',Q,L,Te="Despite my near-complete incompetence, I was able to get through the whole course. That fact says a lot about Chris (TypeCraft)‘s course quality. Neovim aside, I learned a lot about the workings of modern IDEs. If I end up going back to using VS Code as my daily driver, it still feels like time well spent.",J,H,_e='Something I particularly liked was the approach to configuring Neovim. All the extensions are written as lua scripts (and naturally there is a plugin to get better completions in your nvim config files) in ~/.config/nvim/. He set it up so that the plugin manager, Lazy is loaded first, and it will auto-load any other plugins that are included when Neovim is launched. These factors mean that:',ee,M,Le='
  • the config folder can be version controlled via git
  • cloning the config repo into ~/.config/nvim/ then opening neovim is all it takes to set up a new machine with my IDE
  • To try someone else’s config is as simple as cloning their config
  • ',te,P,He="Another detail I like about the Neovim config is that it is extremely minimal by default, and I only pay the cost of loading in features that I want. As the name implies, the Lazy package manager will lazy load packages by default. This means I only have to wait for my debugging plugins to load when I start to use debugging features! The result is an extremely snappy editor that opens in milliseconds with a minimal UI.",ie,z,Me="This approach of being minimal by default hearkens back to my time with Arch Linux, another environment where nearly all functionality is opt-in. The main drawback is quite obvious - some assembly is required. The benefits are plentiful though, and make a good case for why it’s worth the effort:",ne,q,Pe="
  • It provides the opportunity to customize things to my own preferences
  • Configuring all the features I want helps me learn a bit more about how they work
  • I don’t have to pay a performance costs for things I’m not going to use
  • 🌶️ take: it demonstrates to me and others that I take pride in my tools and my work.
  • ",oe,g,ze='Why I changed my mind about Vim',ae,A,qe="While I’ve historically felt that vim wasn’t worth the effort, a few things have come together to change my mind. These factors really changed how I evaluate the ROI on learning vim. I’m now of the opinion that it’s",le,D,Ae="I’m ashamed to admit it, but the biggest one was putting in some effort to learn vim. I incorrectly believed that it would be akin to learning an alternative keyboard layout like Dvorak: something I tried and decided wasn’t worth it after a couple weeks. The thing is, to have the same productivity with vim only requires knowing three vim hot keys:",se,S,De="
  • :wq - to save the current file and quit vim
  • i - Enters “insert mode”, which is basically identical to how every other text editor works - move the cursor with arrow keys, and typing a key adds it at the cursor.
  • Esc - exits insert mode, which is necessary to save and quit.
  • ",re,V,Se="After learning those three commands, I was surprised to find I’m roughly as productive in vim as without it. It turns out everything I thought was required to match my existing productivity in vim is pure upside. 🤯",he,j,Ve='Another big factor is the IDE experience. Coming from my background building games, I can’t imagine trying to debug code using only print statements; a life choice I’ve found shockingly common among web developers. I’m also quite fond of GitHub Copilot and language-specific completions, and wouldn’t want to give them up by changing IDE. This seemed like a huge barrier, but largely thanks to Microsoft these are widely available features now. I spent a few hours getting them setup, but now my config is on GitHub, so it’ll be extremely fast in the future.',ue,U,je='

    Vim transforms text-editing into a puzzle game-like experience

    ',me,E,Ue='The final reason, and one that caught me by surprise, is that using vim is fun! It has really changed the text editing experience. I think of text editing as the necessary labor that shapes and molds text like clay until it matches the picture in my mind of what the code should do. With a basic editor, this is laborious and menial work. It’s akin to sculpting using only a fine chisel. Vim transforms text-editing into a puzzle game-like experience that makes text editing a lot more fun. Look at Primeagen’s enthusiasm for nailing a macro! I have never seen anyone that excited about typing using a regular text editor.',de,N,Ee='The fun alone makes vim worth learning. I love coding, and I’m thrilled to still be finding new ways to add joy to the experience. Given the recent 2024 Stack Overflow developer survey showed only 20% of developers are happy at work, I’m hoping that we can all get a little better at putting the fun into development.';return{c(){h=o("p"),h.textContent=p,c=s(),d=o("p"),d.textContent=u,m=s(),f=o("ul"),f.innerHTML=fe,$=s(),y=o("p"),y.innerHTML=pe,O=s(),w=o("ul"),w.innerHTML=ve,X=s(),b=o("p"),b.textContent=ge,Z=s(),x=o("p"),x.textContent=ye,G=s(),k=o("p"),k.innerHTML=we,R=s(),I=o("ul"),I.innerHTML=be,Y=s(),C=o("p"),C.innerHTML=xe,B=s(),T=o("picture"),T.innerHTML=ke,F=s(),_=o("p"),_.innerHTML=Ie,K=s(),v=o("h2"),v.innerHTML=Ce,Q=s(),L=o("p"),L.textContent=Te,J=s(),H=o("p"),H.innerHTML=_e,ee=s(),M=o("ol"),M.innerHTML=Le,te=s(),P=o("p"),P.innerHTML=He,ie=s(),z=o("p"),z.textContent=Me,ne=s(),q=o("ul"),q.innerHTML=Pe,oe=s(),g=o("h2"),g.innerHTML=ze,ae=s(),A=o("p"),A.textContent=qe,le=s(),D=o("p"),D.textContent=Ae,se=s(),S=o("ul"),S.innerHTML=De,re=s(),V=o("p"),V.textContent=Se,he=s(),j=o("p"),j.innerHTML=Ve,ue=s(),U=o("blockquote"),U.innerHTML=je,me=s(),E=o("p"),E.innerHTML=Ue,de=s(),N=o("p"),N.innerHTML=Ee,this.h()},l(e){h=a(e,"P",{"data-svelte-h":!0}),l(h)!=="svelte-zkivtz"&&(h.textContent=p),c=r(e),d=a(e,"P",{"data-svelte-h":!0}),l(d)!=="svelte-1bbkmym"&&(d.textContent=u),m=r(e),f=a(e,"UL",{"data-svelte-h":!0}),l(f)!=="svelte-ftd1k9"&&(f.innerHTML=fe),$=r(e),y=a(e,"P",{"data-svelte-h":!0}),l(y)!=="svelte-196tzfe"&&(y.innerHTML=pe),O=r(e),w=a(e,"UL",{"data-svelte-h":!0}),l(w)!=="svelte-yefy1y"&&(w.innerHTML=ve),X=r(e),b=a(e,"P",{"data-svelte-h":!0}),l(b)!=="svelte-1lytok8"&&(b.textContent=ge),Z=r(e),x=a(e,"P",{"data-svelte-h":!0}),l(x)!=="svelte-ltcwr0"&&(x.textContent=ye),G=r(e),k=a(e,"P",{"data-svelte-h":!0}),l(k)!=="svelte-1i9zznc"&&(k.innerHTML=we),R=r(e),I=a(e,"UL",{"data-svelte-h":!0}),l(I)!=="svelte-tr1jrt"&&(I.innerHTML=be),Y=r(e),C=a(e,"P",{"data-svelte-h":!0}),l(C)!=="svelte-1rznajm"&&(C.innerHTML=xe),B=r(e),T=a(e,"PICTURE",{"data-svelte-h":!0}),l(T)!=="svelte-1yxtx4e"&&(T.innerHTML=ke),F=r(e),_=a(e,"P",{"data-svelte-h":!0}),l(_)!=="svelte-1l9hf83"&&(_.innerHTML=Ie),K=r(e),v=a(e,"H2",{id:!0,"data-svelte-h":!0}),l(v)!=="svelte-1szpcgd"&&(v.innerHTML=Ce),Q=r(e),L=a(e,"P",{"data-svelte-h":!0}),l(L)!=="svelte-1nkyewk"&&(L.textContent=Te),J=r(e),H=a(e,"P",{"data-svelte-h":!0}),l(H)!=="svelte-bkt5fd"&&(H.innerHTML=_e),ee=r(e),M=a(e,"OL",{"data-svelte-h":!0}),l(M)!=="svelte-hhsid6"&&(M.innerHTML=Le),te=r(e),P=a(e,"P",{"data-svelte-h":!0}),l(P)!=="svelte-4iuswv"&&(P.innerHTML=He),ie=r(e),z=a(e,"P",{"data-svelte-h":!0}),l(z)!=="svelte-19thoi1"&&(z.textContent=Me),ne=r(e),q=a(e,"UL",{"data-svelte-h":!0}),l(q)!=="svelte-1vg8q72"&&(q.innerHTML=Pe),oe=r(e),g=a(e,"H2",{id:!0,"data-svelte-h":!0}),l(g)!=="svelte-1ot9t4k"&&(g.innerHTML=ze),ae=r(e),A=a(e,"P",{"data-svelte-h":!0}),l(A)!=="svelte-15jpkag"&&(A.textContent=qe),le=r(e),D=a(e,"P",{"data-svelte-h":!0}),l(D)!=="svelte-10694c4"&&(D.textContent=Ae),se=r(e),S=a(e,"UL",{"data-svelte-h":!0}),l(S)!=="svelte-1f5wht3"&&(S.innerHTML=De),re=r(e),V=a(e,"P",{"data-svelte-h":!0}),l(V)!=="svelte-1c4tfgf"&&(V.textContent=Se),he=r(e),j=a(e,"P",{"data-svelte-h":!0}),l(j)!=="svelte-1w0kg62"&&(j.innerHTML=Ve),ue=r(e),U=a(e,"BLOCKQUOTE",{"data-svelte-h":!0}),l(U)!=="svelte-1fx5cjq"&&(U.innerHTML=je),me=r(e),E=a(e,"P",{"data-svelte-h":!0}),l(E)!=="svelte-b94g"&&(E.innerHTML=Ue),de=r(e),N=a(e,"P",{"data-svelte-h":!0}),l(N)!=="svelte-1y30bl5"&&(N.innerHTML=Ee),this.h()},h(){We(v,"id","configuring-neovim"),We(g,"id","why-i-changed-my-mind-about-vim")},m(e,t){i(e,h,t),i(e,c,t),i(e,d,t),i(e,m,t),i(e,f,t),i(e,$,t),i(e,y,t),i(e,O,t),i(e,w,t),i(e,X,t),i(e,b,t),i(e,Z,t),i(e,x,t),i(e,G,t),i(e,k,t),i(e,R,t),i(e,I,t),i(e,Y,t),i(e,C,t),i(e,B,t),i(e,T,t),i(e,F,t),i(e,_,t),i(e,K,t),i(e,v,t),i(e,Q,t),i(e,L,t),i(e,J,t),i(e,H,t),i(e,ee,t),i(e,M,t),i(e,te,t),i(e,P,t),i(e,ie,t),i(e,z,t),i(e,ne,t),i(e,q,t),i(e,oe,t),i(e,g,t),i(e,ae,t),i(e,A,t),i(e,le,t),i(e,D,t),i(e,se,t),i(e,S,t),i(e,re,t),i(e,V,t),i(e,he,t),i(e,j,t),i(e,ue,t),i(e,U,t),i(e,me,t),i(e,E,t),i(e,de,t),i(e,N,t)},p:Ze,d(e){e&&(n(h),n(c),n(d),n(m),n(f),n($),n(y),n(O),n(w),n(X),n(b),n(Z),n(x),n(G),n(k),n(R),n(I),n(Y),n(C),n(B),n(T),n(F),n(_),n(K),n(v),n(Q),n(L),n(J),n(H),n(ee),n(M),n(te),n(P),n(ie),n(z),n(ne),n(q),n(oe),n(g),n(ae),n(A),n(le),n(D),n(se),n(S),n(re),n(V),n(he),n(j),n(ue),n(U),n(me),n(E),n(de),n(N))}}}function nt(W){let h,p;const c=[W[0],Oe];let d={$$slots:{default:[it]},$$scope:{ctx:W}};for(let u=0;u{p(0,h=ce(ce({},h),Ne(c)))},h=Ne(h),[h]}class ht extends Ge{constructor(h){super(),Re(this,h,ot,nt,Xe,{})}}export{ht as default,Oe as metadata}; +import{s as Xe,p as ce,q as Ne,e as o,a as s,c as a,m as l,g as r,o as We,i,n as Ze,f as n}from"./scheduler.ewBkyc9q.js";import{S as Ge,i as Re,c as Ye,a as Be,m as Fe,t as Ke,b as Qe,d as Je}from"./index.DpmaPz1F.js";import{g as et,a as $e}from"./spread.CgU5AtxT.js";import{M as tt}from"./MDSveXNoteLayout.Bx5vQYjx.js";function it(W){let h,p="I’ve been writing code in various capacities for nearly twenty years now, though only seriously for around the past 10 years. Despite getting into Arch linux as a hobby in my early teens, I never really put a lot of thought into my text editor & IDE setup. Notepad++, followed by Sublime text, then Visual Studio, and finally VS Code have always felt sufficient to me.",c,d,u="While I’ve been aware of vim for years, I’ve long held the opinion that the steep learning curve isn’t worth it. Most of my time programming isn’t spent text editing problems. I spend a lot more time on problems like:",m,f,fe="
  • What’s the best approach to implement this?
  • How can I configure X to do Y?
  • How should I architect this system?
  • Which API design is going to be the most intuitive for consumers?
  • What’s the best way to communicate these trade-offs in a spec to ensure we have a valuable discussion about this work?
  • Which edge cases do I need to consider and test for?
  • ",$,y,pe="I have spent comparably little time on text editing problems such as:",O,w,ve="
  • How can I delete this code I’m not using?
  • What’s the fastest way to refactor this hacky testing code into a proper unit/integration test?
  • How can I quickly reshape this series of function calls in object property k:v pairs?
  • ",X,b,ge="Learning vim to optimize my text editing skills - which only take up about 25% of my time “programming” - is something I’ve always concluded is not worth it.",Z,x,ye="Additionally, VS Code has incredibly broad adoption across technology stacks today. It’s excellent plugin architecture has produced a thriving ecosystem of 3rd-party add-ons that means in-editor support for every technology is just a couple clicks away. Plus, Microsoft has done something that seemed impossible in the past: established industry standards for integrating an editor with both programming language tools (via Language Server Protocol, or LSP) and debuggers (via the Debug Adapter Protocol, or DAP). It almost feels ridiculous to consider another editor right now…",G,k,we='As it turns out, Microsoft’s fantastic success establishing industry standards with LSP and DAP has been great for the rest of the editor ecosystem. Thanks to the standardized APIs, other editors have tapped into the incredible work. There are now many editors with modern features (or plugins) built leveraging these standards, such as:',R,I,be='
  • Language-aware semantic syntax highlighting
  • Language-specific text completion suggestions
  • Integrated debugger support
  • ',Y,C,xe="The reality is that while VS Code is perhaps the most dominant a text editor has ever been, the quality of alternatives is also better than ever. Recently, I’ve been doing more and more tinkering with my text editors. I tried out Zed, set up a custom launch.json to debug a Deno project, and even customized my VS Code UI to look more minimal:",B,T,ke=' A code block on allandeutsch.com rendered to show the filename in a tab along the top bar of the code block',F,_,Ie='Meanwhile, the YouTube algorithm has been recommending me videos from TypeCraft, a dev YouTuber who makes content about configuring your dev environment using linux, tmux, and neovim. I’ve been in the mood for learning recently, so on Sunday afternoon I decided to go through TypeCraft’s free course on setting up Neovim as an IDE. Note that the course is on setting up the IDE, not on vim motions and keybindings. I went into this with extremely basic vim skills - I could change between normal and insert mode, save a file, exit vim, and not much more.',K,v,Ce='Configuring Neovim',Q,L,Te="Despite my near-complete incompetence, I was able to get through the whole course. That fact says a lot about Chris (TypeCraft)‘s course quality. Neovim aside, I learned a lot about the workings of modern IDEs. If I end up going back to using VS Code as my daily driver, it still feels like time well spent.",J,H,_e='Something I particularly liked was the approach to configuring Neovim. All the extensions are written as lua scripts (and naturally there is a plugin to get better completions in your nvim config files) in ~/.config/nvim/. He set it up so that the plugin manager, Lazy is loaded first, and it will auto-load any other plugins that are included when Neovim is launched. These factors mean that:',ee,M,Le='
  • the config folder can be version controlled via git
  • cloning the config repo into ~/.config/nvim/ then opening neovim is all it takes to set up a new machine with my IDE
  • To try someone else’s config is as simple as cloning their config
  • ',te,P,He="Another detail I like about the Neovim config is that it is extremely minimal by default, and I only pay the cost of loading in features that I want. As the name implies, the Lazy package manager will lazy load packages by default. This means I only have to wait for my debugging plugins to load when I start to use debugging features! The result is an extremely snappy editor that opens in milliseconds with a minimal UI.",ie,z,Me="This approach of being minimal by default hearkens back to my time with Arch Linux, another environment where nearly all functionality is opt-in. The main drawback is quite obvious - some assembly is required. The benefits are plentiful though, and make a good case for why it’s worth the effort:",ne,q,Pe="
  • It provides the opportunity to customize things to my own preferences
  • Configuring all the features I want helps me learn a bit more about how they work
  • I don’t have to pay a performance costs for things I’m not going to use
  • 🌶️ take: it demonstrates to me and others that I take pride in my tools and my work.
  • ",oe,g,ze='Why I changed my mind about Vim',ae,A,qe="While I’ve historically felt that vim wasn’t worth the effort, a few things have come together to change my mind. These factors really changed how I evaluate the ROI on learning vim. I’m now of the opinion that it’s",le,D,Ae="I’m ashamed to admit it, but the biggest one was putting in some effort to learn vim. I incorrectly believed that it would be akin to learning an alternative keyboard layout like Dvorak: something I tried and decided wasn’t worth it after a couple weeks. The thing is, to have the same productivity with vim only requires knowing three vim hot keys:",se,S,De="
  • :wq - to save the current file and quit vim
  • i - Enters “insert mode”, which is basically identical to how every other text editor works - move the cursor with arrow keys, and typing a key adds it at the cursor.
  • Esc - exits insert mode, which is necessary to save and quit.
  • ",re,V,Se="After learning those three commands, I was surprised to find I’m roughly as productive in vim as without it. It turns out everything I thought was required to match my existing productivity in vim is pure upside. 🤯",he,j,Ve='Another big factor is the IDE experience. Coming from my background building games, I can’t imagine trying to debug code using only print statements; a life choice I’ve found shockingly common among web developers. I’m also quite fond of GitHub Copilot and language-specific completions, and wouldn’t want to give them up by changing IDE. This seemed like a huge barrier, but largely thanks to Microsoft these are widely available features now. I spent a few hours getting them setup, but now my config is on GitHub, so it’ll be extremely fast in the future.',ue,U,je='

    Vim transforms text-editing into a puzzle game-like experience

    ',me,E,Ue='The final reason, and one that caught me by surprise, is that using vim is fun! It has really changed the text editing experience. I think of text editing as the necessary labor that shapes and molds text like clay until it matches the picture in my mind of what the code should do. With a basic editor, this is laborious and menial work. It’s akin to sculpting using only a fine chisel. Vim transforms text-editing into a puzzle game-like experience that makes text editing a lot more fun. Look at Primeagen’s enthusiasm for nailing a macro! I have never seen anyone that excited about typing using a regular text editor.',de,N,Ee='The fun alone makes vim worth learning. I love coding, and I’m thrilled to still be finding new ways to add joy to the experience. Given the recent 2024 Stack Overflow developer survey showed only 20% of developers are happy at work, I’m hoping that we can all get a little better at putting the fun into development.';return{c(){h=o("p"),h.textContent=p,c=s(),d=o("p"),d.textContent=u,m=s(),f=o("ul"),f.innerHTML=fe,$=s(),y=o("p"),y.innerHTML=pe,O=s(),w=o("ul"),w.innerHTML=ve,X=s(),b=o("p"),b.textContent=ge,Z=s(),x=o("p"),x.textContent=ye,G=s(),k=o("p"),k.innerHTML=we,R=s(),I=o("ul"),I.innerHTML=be,Y=s(),C=o("p"),C.innerHTML=xe,B=s(),T=o("picture"),T.innerHTML=ke,F=s(),_=o("p"),_.innerHTML=Ie,K=s(),v=o("h2"),v.innerHTML=Ce,Q=s(),L=o("p"),L.textContent=Te,J=s(),H=o("p"),H.innerHTML=_e,ee=s(),M=o("ol"),M.innerHTML=Le,te=s(),P=o("p"),P.innerHTML=He,ie=s(),z=o("p"),z.textContent=Me,ne=s(),q=o("ul"),q.innerHTML=Pe,oe=s(),g=o("h2"),g.innerHTML=ze,ae=s(),A=o("p"),A.textContent=qe,le=s(),D=o("p"),D.textContent=Ae,se=s(),S=o("ul"),S.innerHTML=De,re=s(),V=o("p"),V.textContent=Se,he=s(),j=o("p"),j.innerHTML=Ve,ue=s(),U=o("blockquote"),U.innerHTML=je,me=s(),E=o("p"),E.innerHTML=Ue,de=s(),N=o("p"),N.innerHTML=Ee,this.h()},l(e){h=a(e,"P",{"data-svelte-h":!0}),l(h)!=="svelte-zkivtz"&&(h.textContent=p),c=r(e),d=a(e,"P",{"data-svelte-h":!0}),l(d)!=="svelte-1bbkmym"&&(d.textContent=u),m=r(e),f=a(e,"UL",{"data-svelte-h":!0}),l(f)!=="svelte-ftd1k9"&&(f.innerHTML=fe),$=r(e),y=a(e,"P",{"data-svelte-h":!0}),l(y)!=="svelte-196tzfe"&&(y.innerHTML=pe),O=r(e),w=a(e,"UL",{"data-svelte-h":!0}),l(w)!=="svelte-yefy1y"&&(w.innerHTML=ve),X=r(e),b=a(e,"P",{"data-svelte-h":!0}),l(b)!=="svelte-1lytok8"&&(b.textContent=ge),Z=r(e),x=a(e,"P",{"data-svelte-h":!0}),l(x)!=="svelte-ltcwr0"&&(x.textContent=ye),G=r(e),k=a(e,"P",{"data-svelte-h":!0}),l(k)!=="svelte-1i9zznc"&&(k.innerHTML=we),R=r(e),I=a(e,"UL",{"data-svelte-h":!0}),l(I)!=="svelte-tr1jrt"&&(I.innerHTML=be),Y=r(e),C=a(e,"P",{"data-svelte-h":!0}),l(C)!=="svelte-1rznajm"&&(C.innerHTML=xe),B=r(e),T=a(e,"PICTURE",{"data-svelte-h":!0}),l(T)!=="svelte-1yxtx4e"&&(T.innerHTML=ke),F=r(e),_=a(e,"P",{"data-svelte-h":!0}),l(_)!=="svelte-1l9hf83"&&(_.innerHTML=Ie),K=r(e),v=a(e,"H2",{id:!0,"data-svelte-h":!0}),l(v)!=="svelte-1szpcgd"&&(v.innerHTML=Ce),Q=r(e),L=a(e,"P",{"data-svelte-h":!0}),l(L)!=="svelte-1nkyewk"&&(L.textContent=Te),J=r(e),H=a(e,"P",{"data-svelte-h":!0}),l(H)!=="svelte-bkt5fd"&&(H.innerHTML=_e),ee=r(e),M=a(e,"OL",{"data-svelte-h":!0}),l(M)!=="svelte-hhsid6"&&(M.innerHTML=Le),te=r(e),P=a(e,"P",{"data-svelte-h":!0}),l(P)!=="svelte-4iuswv"&&(P.innerHTML=He),ie=r(e),z=a(e,"P",{"data-svelte-h":!0}),l(z)!=="svelte-19thoi1"&&(z.textContent=Me),ne=r(e),q=a(e,"UL",{"data-svelte-h":!0}),l(q)!=="svelte-1vg8q72"&&(q.innerHTML=Pe),oe=r(e),g=a(e,"H2",{id:!0,"data-svelte-h":!0}),l(g)!=="svelte-1ot9t4k"&&(g.innerHTML=ze),ae=r(e),A=a(e,"P",{"data-svelte-h":!0}),l(A)!=="svelte-15jpkag"&&(A.textContent=qe),le=r(e),D=a(e,"P",{"data-svelte-h":!0}),l(D)!=="svelte-10694c4"&&(D.textContent=Ae),se=r(e),S=a(e,"UL",{"data-svelte-h":!0}),l(S)!=="svelte-1f5wht3"&&(S.innerHTML=De),re=r(e),V=a(e,"P",{"data-svelte-h":!0}),l(V)!=="svelte-1c4tfgf"&&(V.textContent=Se),he=r(e),j=a(e,"P",{"data-svelte-h":!0}),l(j)!=="svelte-1w0kg62"&&(j.innerHTML=Ve),ue=r(e),U=a(e,"BLOCKQUOTE",{"data-svelte-h":!0}),l(U)!=="svelte-1fx5cjq"&&(U.innerHTML=je),me=r(e),E=a(e,"P",{"data-svelte-h":!0}),l(E)!=="svelte-b94g"&&(E.innerHTML=Ue),de=r(e),N=a(e,"P",{"data-svelte-h":!0}),l(N)!=="svelte-1y30bl5"&&(N.innerHTML=Ee),this.h()},h(){We(v,"id","configuring-neovim"),We(g,"id","why-i-changed-my-mind-about-vim")},m(e,t){i(e,h,t),i(e,c,t),i(e,d,t),i(e,m,t),i(e,f,t),i(e,$,t),i(e,y,t),i(e,O,t),i(e,w,t),i(e,X,t),i(e,b,t),i(e,Z,t),i(e,x,t),i(e,G,t),i(e,k,t),i(e,R,t),i(e,I,t),i(e,Y,t),i(e,C,t),i(e,B,t),i(e,T,t),i(e,F,t),i(e,_,t),i(e,K,t),i(e,v,t),i(e,Q,t),i(e,L,t),i(e,J,t),i(e,H,t),i(e,ee,t),i(e,M,t),i(e,te,t),i(e,P,t),i(e,ie,t),i(e,z,t),i(e,ne,t),i(e,q,t),i(e,oe,t),i(e,g,t),i(e,ae,t),i(e,A,t),i(e,le,t),i(e,D,t),i(e,se,t),i(e,S,t),i(e,re,t),i(e,V,t),i(e,he,t),i(e,j,t),i(e,ue,t),i(e,U,t),i(e,me,t),i(e,E,t),i(e,de,t),i(e,N,t)},p:Ze,d(e){e&&(n(h),n(c),n(d),n(m),n(f),n($),n(y),n(O),n(w),n(X),n(b),n(Z),n(x),n(G),n(k),n(R),n(I),n(Y),n(C),n(B),n(T),n(F),n(_),n(K),n(v),n(Q),n(L),n(J),n(H),n(ee),n(M),n(te),n(P),n(ie),n(z),n(ne),n(q),n(oe),n(g),n(ae),n(A),n(le),n(D),n(se),n(S),n(re),n(V),n(he),n(j),n(ue),n(U),n(me),n(E),n(de),n(N))}}}function nt(W){let h,p;const c=[W[0],Oe];let d={$$slots:{default:[it]},$$scope:{ctx:W}};for(let u=0;u{p(0,h=ce(ce({},h),Ne(c)))},h=Ne(h),[h]}class ht extends Ge{constructor(h){super(),Re(this,h,ot,nt,Xe,{})}}export{ht as default,Oe as metadata}; diff --git a/_app/immutable/chunks/I want a smaller phone.Cp8ynRuz.js b/_app/immutable/chunks/I want a smaller phone.CBtpzzFK.js similarity index 98% rename from _app/immutable/chunks/I want a smaller phone.Cp8ynRuz.js rename to _app/immutable/chunks/I want a smaller phone.CBtpzzFK.js index 2638dc371f..75f8629e04 100644 --- a/_app/immutable/chunks/I want a smaller phone.Cp8ynRuz.js +++ b/_app/immutable/chunks/I want a smaller phone.CBtpzzFK.js @@ -1 +1 @@ -import{s as q,p as k,q as M,e as f,a as _,c as g,m as y,g as v,i as l,n as j,f as i}from"./scheduler.ewBkyc9q.js";import{S,i as z,c as A,a as B,m as F,t as H,b as R,d as U}from"./index.DpmaPz1F.js";import{g as Z,a as L}from"./spread.CgU5AtxT.js";import{M as D}from"./MDSveXNoteLayout.PyyVkf3i.js";function G(c){let t,u="Recently a friend and I decided to spend a Friday working from a nearby island. It was a great change of pace at the end of a long week. I really enjoy finding opportunities to co-work with friends; it’s a great opportunity to catch up, get a new perspective, and discuss ideas. One topic we discussed was smart phones - those great little computers that fit in a pocket and can do almost anything. But are they really great?",r,o,a="When you really think about it, what do you spend time doing on your phone? For me, there are two categories of answers. The first is the things I’m happy to do on my phone and which I consider quite valuable uses:",n,m,C="
  • Getting directions to wherever I’m going
  • playing music
  • Meditating
  • Reading without my kindle
  • Misc work tasks on the go - messaging, calendar, email, etc.
  • Quickly looking things up
  • ",w,p,b="There’s a common theme that ties most of these together - they are mostly short tasks done away from a computer! I’ve come to realize that my productive work is done at a computer, not on a smartphone. The smartphone is a complement to the computer, but not a replacement when it comes to doing productive work.",x,d,T="Unfortunately, I’m also a fallible human. I don’t use my phone for strictly productive work while away from a computer. I also play games, read twitter, and spend more time than I am proud of scrolling through short-form videos. Because the phone is so low-effort, I’ve found I’ll often pick it up even when I have access to something better for the task at hand - namely my laptop. As it turns out, I’m a big stupid dopamine-seeking monkey!",I,h,$="I’ve come to the realization that I don’t really want or need the latest and greatest phone. It doesn’t need to have the largest screen or the fastest processor. I’ve decided that my next phone will be smaller and less enticing to use, and that it’s better that way.";return{c(){t=f("p"),t.textContent=u,r=_(),o=f("p"),o.textContent=a,n=_(),m=f("ul"),m.innerHTML=C,w=_(),p=f("p"),p.textContent=b,x=_(),d=f("p"),d.textContent=T,I=_(),h=f("p"),h.textContent=$},l(e){t=g(e,"P",{"data-svelte-h":!0}),y(t)!=="svelte-il561k"&&(t.textContent=u),r=v(e),o=g(e,"P",{"data-svelte-h":!0}),y(o)!=="svelte-u7qr17"&&(o.textContent=a),n=v(e),m=g(e,"UL",{"data-svelte-h":!0}),y(m)!=="svelte-dnotmj"&&(m.innerHTML=C),w=v(e),p=g(e,"P",{"data-svelte-h":!0}),y(p)!=="svelte-4huf8b"&&(p.textContent=b),x=v(e),d=g(e,"P",{"data-svelte-h":!0}),y(d)!=="svelte-fvpy0e"&&(d.textContent=T),I=v(e),h=g(e,"P",{"data-svelte-h":!0}),y(h)!=="svelte-14iedxg"&&(h.textContent=$)},m(e,s){l(e,t,s),l(e,r,s),l(e,o,s),l(e,n,s),l(e,m,s),l(e,w,s),l(e,p,s),l(e,x,s),l(e,d,s),l(e,I,s),l(e,h,s)},p:j,d(e){e&&(i(t),i(r),i(o),i(n),i(m),i(w),i(p),i(x),i(d),i(I),i(h))}}}function N(c){let t,u;const r=[c[0],P];let o={$$slots:{default:[G]},$$scope:{ctx:c}};for(let a=0;a{u(0,t=k(k({},t),M(r)))},t=M(t),[t]}class J extends S{constructor(t){super(),z(this,t,O,N,q,{})}}export{J as default,P as metadata}; +import{s as q,p as k,q as M,e as f,a as _,c as g,m as y,g as v,i as l,n as j,f as i}from"./scheduler.ewBkyc9q.js";import{S,i as z,c as A,a as B,m as F,t as H,b as R,d as U}from"./index.DpmaPz1F.js";import{g as Z,a as L}from"./spread.CgU5AtxT.js";import{M as D}from"./MDSveXNoteLayout.Bx5vQYjx.js";function G(c){let t,u="Recently a friend and I decided to spend a Friday working from a nearby island. It was a great change of pace at the end of a long week. I really enjoy finding opportunities to co-work with friends; it’s a great opportunity to catch up, get a new perspective, and discuss ideas. One topic we discussed was smart phones - those great little computers that fit in a pocket and can do almost anything. But are they really great?",r,o,a="When you really think about it, what do you spend time doing on your phone? For me, there are two categories of answers. The first is the things I’m happy to do on my phone and which I consider quite valuable uses:",n,m,C="
  • Getting directions to wherever I’m going
  • playing music
  • Meditating
  • Reading without my kindle
  • Misc work tasks on the go - messaging, calendar, email, etc.
  • Quickly looking things up
  • ",w,p,b="There’s a common theme that ties most of these together - they are mostly short tasks done away from a computer! I’ve come to realize that my productive work is done at a computer, not on a smartphone. The smartphone is a complement to the computer, but not a replacement when it comes to doing productive work.",x,d,T="Unfortunately, I’m also a fallible human. I don’t use my phone for strictly productive work while away from a computer. I also play games, read twitter, and spend more time than I am proud of scrolling through short-form videos. Because the phone is so low-effort, I’ve found I’ll often pick it up even when I have access to something better for the task at hand - namely my laptop. As it turns out, I’m a big stupid dopamine-seeking monkey!",I,h,$="I’ve come to the realization that I don’t really want or need the latest and greatest phone. It doesn’t need to have the largest screen or the fastest processor. I’ve decided that my next phone will be smaller and less enticing to use, and that it’s better that way.";return{c(){t=f("p"),t.textContent=u,r=_(),o=f("p"),o.textContent=a,n=_(),m=f("ul"),m.innerHTML=C,w=_(),p=f("p"),p.textContent=b,x=_(),d=f("p"),d.textContent=T,I=_(),h=f("p"),h.textContent=$},l(e){t=g(e,"P",{"data-svelte-h":!0}),y(t)!=="svelte-il561k"&&(t.textContent=u),r=v(e),o=g(e,"P",{"data-svelte-h":!0}),y(o)!=="svelte-u7qr17"&&(o.textContent=a),n=v(e),m=g(e,"UL",{"data-svelte-h":!0}),y(m)!=="svelte-dnotmj"&&(m.innerHTML=C),w=v(e),p=g(e,"P",{"data-svelte-h":!0}),y(p)!=="svelte-4huf8b"&&(p.textContent=b),x=v(e),d=g(e,"P",{"data-svelte-h":!0}),y(d)!=="svelte-fvpy0e"&&(d.textContent=T),I=v(e),h=g(e,"P",{"data-svelte-h":!0}),y(h)!=="svelte-14iedxg"&&(h.textContent=$)},m(e,s){l(e,t,s),l(e,r,s),l(e,o,s),l(e,n,s),l(e,m,s),l(e,w,s),l(e,p,s),l(e,x,s),l(e,d,s),l(e,I,s),l(e,h,s)},p:j,d(e){e&&(i(t),i(r),i(o),i(n),i(m),i(w),i(p),i(x),i(d),i(I),i(h))}}}function N(c){let t,u;const r=[c[0],P];let o={$$slots:{default:[G]},$$scope:{ctx:c}};for(let a=0;a{u(0,t=k(k({},t),M(r)))},t=M(t),[t]}class J extends S{constructor(t){super(),z(this,t,O,N,q,{})}}export{J as default,P as metadata}; diff --git a/_app/immutable/chunks/Identity functions.CMbGr0CE.js b/_app/immutable/chunks/Identity functions.BWjbs7CM.js similarity index 99% rename from _app/immutable/chunks/Identity functions.CMbGr0CE.js rename to _app/immutable/chunks/Identity functions.BWjbs7CM.js index 9fff5fdf98..da6e42b6ae 100644 --- a/_app/immutable/chunks/Identity functions.CMbGr0CE.js +++ b/_app/immutable/chunks/Identity functions.BWjbs7CM.js @@ -1,4 +1,4 @@ -import{s as pa,p as vs,q as Ys,e as r,a as p,H as c,u as h,c as t,m as k,g as e,v as d,o as Js,i as n,n as ea,f as o}from"./scheduler.ewBkyc9q.js";import{S as ia,i as ra,c as ta,a as ka,m as ca,t as ha,b as da,d as ya}from"./index.DpmaPz1F.js";import{g as Aa,a as Ps}from"./spread.CgU5AtxT.js";import{M as Ba}from"./MDSveXNoteLayout.PyyVkf3i.js";function Da(H){let l,u="Identity functions are a tool to improve type information. They take the form of a function that provides TypeScript with extra type information and typically have a return value that is identical to argument passed to them. Typically identity functions are used to either provide a library’s users with better type information, or for a library to get better type information from a user. In both cases, the goal seems to be improving ease of use and developer experience.",B,y,i='Providing type hints to API consumers',A,D,Es="Libraries with many configuration options commonly use an identity function to make it easier for users to configure them. This is typically done by exporting a function with a name like defineConfig(). It will take a parameter typed identically to the library’s configuration object. Since this tells the IDE what values exist on the object, it can display those options to the users. I much prefer this in-editor experience to tabbing back and forth between my code and the docs. Some tools I use that take this approach are:",ts,f,bs='
  • typescript-eslint
  • vite’s defineConfig
  • ',ks,w,Fs="For example, compare the intellisense help with and without Vite’s defineConfig():",cs,S,qs=`
    import { function defineConfig(config: UserConfig): UserConfig (+3 overloads)
    Type helper to make it easier to use vite.config.ts +import{s as pa,p as vs,q as Ys,e as r,a as p,H as c,u as h,c as t,m as k,g as e,v as d,o as Js,i as n,n as ea,f as o}from"./scheduler.ewBkyc9q.js";import{S as ia,i as ra,c as ta,a as ka,m as ca,t as ha,b as da,d as ya}from"./index.DpmaPz1F.js";import{g as Aa,a as Ps}from"./spread.CgU5AtxT.js";import{M as Ba}from"./MDSveXNoteLayout.Bx5vQYjx.js";function Da(H){let l,u="Identity functions are a tool to improve type information. They take the form of a function that provides TypeScript with extra type information and typically have a return value that is identical to argument passed to them. Typically identity functions are used to either provide a library’s users with better type information, or for a library to get better type information from a user. In both cases, the goal seems to be improving ease of use and developer experience.",B,y,i='Providing type hints to API consumers',A,D,Es="Libraries with many configuration options commonly use an identity function to make it easier for users to configure them. This is typically done by exporting a function with a name like defineConfig(). It will take a parameter typed identically to the library’s configuration object. Since this tells the IDE what values exist on the object, it can display those options to the users. I much prefer this in-editor experience to tabbing back and forth between my code and the docs. Some tools I use that take this approach are:",ts,f,bs='
  • typescript-eslint
  • vite’s defineConfig
  • ',ks,w,Fs="For example, compare the intellisense help with and without Vite’s defineConfig():",cs,S,qs=`
    import { function defineConfig(config: UserConfig): UserConfig (+3 overloads)
    Type helper to make it easier to use vite.config.ts accepts a direct {@link UserConfig diff --git a/_app/immutable/chunks/Improve site previews on social media by unfurling webpages.BzVVj4EB.js b/_app/immutable/chunks/Improve site previews on social media by unfurling webpages.DYaIAgRS.js similarity index 99% rename from _app/immutable/chunks/Improve site previews on social media by unfurling webpages.BzVVj4EB.js rename to _app/immutable/chunks/Improve site previews on social media by unfurling webpages.DYaIAgRS.js index 700c941f1a..82d338c9e9 100644 --- a/_app/immutable/chunks/Improve site previews on social media by unfurling webpages.BzVVj4EB.js +++ b/_app/immutable/chunks/Improve site previews on social media by unfurling webpages.DYaIAgRS.js @@ -1,4 +1,4 @@ -import{s as me,p as K,q as pe,e as r,a as l,H as R,u as X,c as p,m as c,g as n,v as J,o as fe,i as t,n as De,f as a}from"./scheduler.ewBkyc9q.js";import{S as Be,i as Ce,c as ge,a as Ae,m as ve,t as we,b as be,d as _e}from"./index.DpmaPz1F.js";import{g as xe,a as ce}from"./spread.CgU5AtxT.js";import{M as Te}from"./MDSveXNoteLayout.PyyVkf3i.js";function Le(x){let i,u='Use OpenGraph meta tags to provide page previews on social media',h,k,o="You built a website to share something valuable with people. If other people find it valuable, they will share it too, on:",d,y,Q="
  • Facebook
  • Twitter
  • Slack
  • LinkedIn
  • ",O,m,V="…and other platforms!",$,f,W='To maximize your click-through rates for social media shares, give social media users a great first impression. To help social media platforms present your content to their users, you need to help them unfurl your pages. This is done using 2 simple APIs: Facebook Open Graph HTML Markup and Twitter Cards.',q,D,ee="Most platforms use the Open Graph API. It has 5 properties you need to know about:",S,B,se=`
  • og:type specifies what type of content is the focus of a page. There are 6 options: +import{s as me,p as K,q as pe,e as r,a as l,H as R,u as X,c as p,m as c,g as n,v as J,o as fe,i as t,n as De,f as a}from"./scheduler.ewBkyc9q.js";import{S as Be,i as Ce,c as ge,a as Ae,m as ve,t as we,b as be,d as _e}from"./index.DpmaPz1F.js";import{g as xe,a as ce}from"./spread.CgU5AtxT.js";import{M as Te}from"./MDSveXNoteLayout.Bx5vQYjx.js";function Le(x){let i,u='Use OpenGraph meta tags to provide page previews on social media',h,k,o="You built a website to share something valuable with people. If other people find it valuable, they will share it too, on:",d,y,Q="
  • Facebook
  • Twitter
  • Slack
  • LinkedIn
  • ",O,m,V="…and other platforms!",$,f,W='To maximize your click-through rates for social media shares, give social media users a great first impression. To help social media platforms present your content to their users, you need to help them unfurl your pages. This is done using 2 simple APIs: Facebook Open Graph HTML Markup and Twitter Cards.',q,D,ee="Most platforms use the Open Graph API. It has 5 properties you need to know about:",S,B,se=`
  • og:type specifies what type of content is the focus of a page. There are 6 options:
    • website - this is also the default option if no type is specified
    • article
    • profile
    • video
    • music
    • book
  • og:url specifies your website’s Canonical URL. Think of this as the address for your front door.
  • og:title is the title page title. This should be contextual and specific to each page. Think article title, not site title.
  • og:description is a brief description of the page content. Use it to help people make a quick decision about if they are interested in the content. It’s a great place for a hook.
  • og:image is used to specify a preview/thumbnail image for the page. This could be as simple as the header graphic for the page.
  • `,G,C,te='I wrote this note while adding unfurling content to allandeutsch.com. Here’s the Open Graph code I added to the <head> of my homepage:',N,T,ke=`
    <meta property="og:type" content="website"/>
     <meta property="og:url" content="https://allandeutsch.com" />
     <meta property="og:title" content="Allan Deutsch" />
    diff --git a/_app/immutable/chunks/Linting and formatting a svelte typescript project.DpAT0Kon.js b/_app/immutable/chunks/Linting and formatting a svelte typescript project.HFg0G87O.js
    similarity index 99%
    rename from _app/immutable/chunks/Linting and formatting a svelte typescript project.DpAT0Kon.js
    rename to _app/immutable/chunks/Linting and formatting a svelte typescript project.HFg0G87O.js
    index 78a2504989..8978ced9b1 100644
    --- a/_app/immutable/chunks/Linting and formatting a svelte typescript project.DpAT0Kon.js	
    +++ b/_app/immutable/chunks/Linting and formatting a svelte typescript project.HFg0G87O.js	
    @@ -1,4 +1,4 @@
    -import{s as On,p as ka,q as yn,e as l,a as i,H as c,u as k,c as o,m as p,g as t,v as d,o as u,i as a,n as Rn,f as n}from"./scheduler.ewBkyc9q.js";import{S as zn,i as $n,c as Gn,a as Yn,m as Qn,t as Nn,b as Un,d as Kn}from"./index.DpmaPz1F.js";import{g as Wn,a as fn}from"./spread.CgU5AtxT.js";import{M as Vn}from"./MDSveXNoteLayout.PyyVkf3i.js";function Jn(Bs){let r,g='Lately I’ve been working on Penguinsight. It’s a tool that helps teams building products for developers get precise & actionable feedback on their docs from the people who have to use them. I’ve been building Penguinsight solo, and it’s freeing to build everything myself and understand how it all works. I get a huge boost in personal productivity, but it’s not without downsides.',A,f,h='Often the downsides of working solo aren’t a big issue for me. I understand the importance of craftsmanship in software development, and usually write great code. On rare occasion, I am even struck with divine inspiration; my body becomes a mere vessel used by the incomprehensible powers of the universe to transcribe code until 3 in the morning. There is no greater sensation; it is a peak experience.',y,m,da='After waking up exhausted for the third time last week only to discover some asshole merged poorly formatted code with bugs into staging at 3am, it was time to act… I got up and walked to a coffee shop. With blood flowing and bean juice in hand, I was resolved to reign in that maniac by any means necessary. Tests weren’t cutting it, so it was time to introduce some static analysis tools: a formatter and linter.',ke,I,ha="This ended up being a bigger project than I expected for a few reasons:",de,L,ya='
  • I needed to integrate prettier-plugin-svelte since started using zed and no longer gett it via VS Code plugin
  • ESLint upgraded to a new flat config format which I needed to learn
  • typescript-eslint doesn’t support the latest eslint 9.0.0 yet, which naturally I discovered after trying to use the eslint 9 😅
  • There is a new eslint-plugin-svelte which replaced eslint-plugin-svelte3
  • ',he,P,fa="Here’s how I got it all up and running!",ye,B,ua='Setting up prettier',fe,E,Aa="Prettier handles file formatting. I prefer to have things formatted consistently and I don’t want to think about it, so I configure my editor to format files on save. This has the added benefit of also saving my files when I use cmd+s as a “format code” hotkey. Nifty!",ue,D,ma='Installing prettier packages',Ae,j,ga="From the top, here’s the setup. First, install all the dependencies for formatting (I’ve specified version I know work together). Since these are dev tools, using -D ensures they don’t get bundled into application code.",me,Ds,An=`
    npm i -D prettier@3.2.5
    +import{s as On,p as ka,q as yn,e as l,a as i,H as c,u as k,c as o,m as p,g as t,v as d,o as u,i as a,n as Rn,f as n}from"./scheduler.ewBkyc9q.js";import{S as zn,i as $n,c as Gn,a as Yn,m as Qn,t as Nn,b as Un,d as Kn}from"./index.DpmaPz1F.js";import{g as Wn,a as fn}from"./spread.CgU5AtxT.js";import{M as Vn}from"./MDSveXNoteLayout.Bx5vQYjx.js";function Jn(Bs){let r,g='Lately I’ve been working on Penguinsight. It’s a tool that helps teams building products for developers get precise & actionable feedback on their docs from the people who have to use them. I’ve been building Penguinsight solo, and it’s freeing to build everything myself and understand how it all works. I get a huge boost in personal productivity, but it’s not without downsides.',A,f,h='Often the downsides of working solo aren’t a big issue for me. I understand the importance of craftsmanship in software development, and usually write great code. On rare occasion, I am even struck with divine inspiration; my body becomes a mere vessel used by the incomprehensible powers of the universe to transcribe code until 3 in the morning. There is no greater sensation; it is a peak experience.',y,m,da='After waking up exhausted for the third time last week only to discover some asshole merged poorly formatted code with bugs into staging at 3am, it was time to act… I got up and walked to a coffee shop. With blood flowing and bean juice in hand, I was resolved to reign in that maniac by any means necessary. Tests weren’t cutting it, so it was time to introduce some static analysis tools: a formatter and linter.',ke,I,ha="This ended up being a bigger project than I expected for a few reasons:",de,L,ya='
  • I needed to integrate prettier-plugin-svelte since started using zed and no longer gett it via VS Code plugin
  • ESLint upgraded to a new flat config format which I needed to learn
  • typescript-eslint doesn’t support the latest eslint 9.0.0 yet, which naturally I discovered after trying to use the eslint 9 😅
  • There is a new eslint-plugin-svelte which replaced eslint-plugin-svelte3
  • ',he,P,fa="Here’s how I got it all up and running!",ye,B,ua='Setting up prettier',fe,E,Aa="Prettier handles file formatting. I prefer to have things formatted consistently and I don’t want to think about it, so I configure my editor to format files on save. This has the added benefit of also saving my files when I use cmd+s as a “format code” hotkey. Nifty!",ue,D,ma='Installing prettier packages',Ae,j,ga="From the top, here’s the setup. First, install all the dependencies for formatting (I’ve specified version I know work together). Since these are dev tools, using -D ensures they don’t get bundled into application code.",me,Ds,An=`
    npm i -D prettier@3.2.5
     npm i -D prettier-plugin-organize-imports@3.2.4
     npm i -D prettier-plugin-svelte@3.2.2
     npm i -D prettier-plugin-tailwindcss@0.5.13
    `,vs,Cs,mn=`