@storybook/addon-onboarding 0.0.32 → 0.0.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/manager.mjs +2 -2
- package/package.json +1 -1
package/dist/manager.mjs
CHANGED
|
@@ -381,7 +381,7 @@ var Ao=Object.defineProperty;var a=(t,o)=>()=>(t&&(o=t(t=0)),o);var jo=(t,o)=>{f
|
|
|
381
381
|
padding-top: 12px;
|
|
382
382
|
padding-bottom: 12px;
|
|
383
383
|
min-height: 57px;
|
|
384
|
-
`;});var we,Qt,Ut=a(()=>{Yt();we={default:{filter:"grayscale(1)",opacity:.5},active:{filter:"grayscale(0)",opacity:1}},Qt=forwardRef(({active:t,content:o,open:r},n)=>{let i={fontSize:"0.8125rem",lineHeight:"1.1875rem"};return e.createElement(Gt,{ref:n,initial:"default",animate:t?"active":"default","aria-hidden":!t,variants:we,transition:{ease:"easeInOut",duration:.6}},o.map(({toggle:s,code:p},l)=>e.createElement(Fragment,{key:l},s===void 0&&e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:i},p),s&&!r&&e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:i}," // ..."),s&&r&&e.createElement(motion.div,{initial:{opacity:0},animate:{opacity:1},transition:{delay:.4}},e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:i,codeTagProps:{style:{paddingLeft:"15px"}}},p)))))});});var Vt,Zt=a(()=>{Ht();Ut();Vt=({activeStep:t,data:o,width:r})=>{let[n,i]=useState([]),s=useMemo(()=>o.map(()=>createRef()),[o]),p=g=>{let u=0;for(let y=0;y<g;y++)u-=s[y].current.getBoundingClientRect().height;return u},l=useCallback(()=>{let g=o.flatMap((u,y)=>{let C=s[y].current.getBoundingClientRect().height,S=[{yPos:p(y),backdropHeight:C,index:y,open:!1}];return u.length>1&&S.push({yPos:p(y),backdropHeight:C,index:y,open:!0}),S});i(g);},[o]);useLayoutEffect(()=>{let g=new ResizeObserver(()=>{l();});return s.forEach(u=>{g.observe(u.current);}),()=>{g.disconnect();}},[]);let m={fontSize:"0.8125rem",lineHeight:"1.1875rem"};return e.createElement(Ft,{width:r},e.createElement(ThemeProvider,{theme:ensure(themes.dark)},e.createElement(jt,{animate:{y:n[t]?.yPos??0},transition:{ease:"easeInOut",duration:.4}},e.createElement(_t,null,e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:m},"// Button.stories.tsx")),o.map((g,u)=>e.createElement(Qt,{key:u,ref:s[u],active:n[t]?.index===u,open:n[t]?.index>u?!0:n[t]?.open??!1,content:g})))),e.createElement($t,{initial:{height:81},animate:{height:n[t]?.backdropHeight??81},transition:{ease:"easeInOut",duration:.4},className:"syntax-highlighter-backdrop"}))};});var Xt,Kt=a(()=>{Xt=styled.ul(()=>({display:"flex",flexDirection:"column",rowGap:16,padding:0,margin:0}));});var qt,Jt=a(()=>{Kt();qt=({children:t})=>e.createElement(Xt,null,t);});var Rt,to,oo,eo=a(()=>{Rt=styled.li(()=>({display:"flex",alignItems:"flex-start",columnGap:12})),to=styled.div(({theme:t})=>({fontFamily:t.typography.fonts.base,color:t.color.darker,fontSize:"13px"})),oo=styled.div(({isCompleted:t,theme:o})=>({display:"flex",alignItems:"center",justifyContent:"center",border:!t&&`1px solid ${o.color.medium}`,minWidth:20,width:20,height:20,borderRadius:"50%",backgroundColor:t?o.color.green:"white",fontFamily:o.typography.fonts.base,fontSize:10,fontWeight:600,color:o.color.dark}));});var j,ro=a(()=>{eo();j=({children:t,index:o,isCompleted:r})=>e.createElement(Rt,null,e.createElement(oo,{"aria-label":r?"complete":"not complete",isCompleted:r},r?e.createElement(Icons,{width:10,height:10,icon:"check",color:"white"}):o),e.createElement(to,null,t));});function no(){let[t,o]=useState(null);return useEffect(()=>{(async()=>{try{let s=(await(await fetch("/index.json")).json()).entries["example-button--primary"].importPath;o({data:s,error:null});}catch(n){o({data:null,error:n});}})();},[]),t}var io=a(()=>{});var ao,po=a(()=>{ao=(t,o,r)=>{let[n,i]=useState(null);return useEffect(()=>{if(t){let s=()=>{r.getChannel().once(STORY_RENDERED,()=>{o.getData("example-button--warning")&&i({data:!0,error:null});});};return o.getData("example-button--warning")?i({data:!0,error:null}):r.getServerChannel().on(STORY_INDEX_INVALIDATED,s),()=>{r.getServerChannel().off(STORY_INDEX_INVALIDATED,s);}}},[t]),n};});var lo,mo=a(()=>{lo=(t,o)=>{let[r,n]=useState(null),i=document.querySelector(`.${t}`);return useEffect(()=>{if(o){let s=new ResizeObserver(()=>{i&&n({top:i.offsetTop,left:i.offsetLeft,height:i.offsetHeight,width:i.offsetWidth});});return s.observe(i),()=>{s.disconnect();}}},[t,o]),r};});var co,uo=a(()=>{co="";});var go,fo=a(()=>{go="";});var ho,yo=a(()=>{ho="";});var xo,bo=a(()=>{xo=[[{code:"// Button.stories.jsx"}],[{code:"import { Button } from './Button';"}],[{code:`export default {
|
|
384
|
+
`;});var we,Qt,Ut=a(()=>{Yt();we={default:{filter:"grayscale(1)",opacity:.5},active:{filter:"grayscale(0)",opacity:1}},Qt=forwardRef(({active:t,content:o,open:r},n)=>{let i={fontSize:"0.8125rem",lineHeight:"1.1875rem"};return e.createElement(Gt,{ref:n,initial:"default",animate:t?"active":"default","aria-hidden":!t,variants:we,transition:{ease:"easeInOut",duration:.6}},o.map(({toggle:s,code:p},l)=>e.createElement(Fragment,{key:l},s===void 0&&e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:i},p),s&&!r&&e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:i}," // ..."),s&&r&&e.createElement(motion.div,{initial:{opacity:0},animate:{opacity:1},transition:{delay:.4}},e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:i,codeTagProps:{style:{paddingLeft:"15px"}}},p)))))});});var Vt,Zt=a(()=>{Ht();Ut();Vt=({activeStep:t,data:o,width:r})=>{let[n,i]=useState([]),s=useMemo(()=>o.map(()=>createRef()),[o]),p=g=>{let u=0;for(let y=0;y<g;y++)u-=s[y].current.getBoundingClientRect().height;return u},l=useCallback(()=>{let g=o.flatMap((u,y)=>{let C=s[y].current.getBoundingClientRect().height,S=[{yPos:p(y),backdropHeight:C,index:y,open:!1}];return u.length>1&&S.push({yPos:p(y),backdropHeight:C,index:y,open:!0}),S});i(g);},[o]);useLayoutEffect(()=>{let g=new ResizeObserver(()=>{l();});return s.forEach(u=>{g.observe(u.current);}),()=>{g.disconnect();}},[]);let m={fontSize:"0.8125rem",lineHeight:"1.1875rem"};return e.createElement(Ft,{width:r},e.createElement(ThemeProvider,{theme:ensure(themes.dark)},e.createElement(jt,{animate:{y:n[t]?.yPos??0},transition:{ease:"easeInOut",duration:.4}},e.createElement(_t,null,e.createElement(SyntaxHighlighter,{language:"typescript",customStyle:m},"// Button.stories.tsx")),o.map((g,u)=>e.createElement(Qt,{key:u,ref:s[u],active:n[t]?.index===u,open:n[t]?.index>u?!0:n[t]?.open??!1,content:g})))),e.createElement($t,{initial:{height:81},animate:{height:n[t]?.backdropHeight??81},transition:{ease:"easeInOut",duration:.4},className:"syntax-highlighter-backdrop"}))};});var Xt,Kt=a(()=>{Xt=styled.ul(()=>({display:"flex",flexDirection:"column",rowGap:16,padding:0,margin:0}));});var qt,Jt=a(()=>{Kt();qt=({children:t})=>e.createElement(Xt,null,t);});var Rt,to,oo,eo=a(()=>{Rt=styled.li(()=>({display:"flex",alignItems:"flex-start",columnGap:12})),to=styled.div(({theme:t})=>({fontFamily:t.typography.fonts.base,color:t.color.darker,fontSize:"13px"})),oo=styled.div(({isCompleted:t,theme:o})=>({display:"flex",alignItems:"center",justifyContent:"center",border:!t&&`1px solid ${o.color.medium}`,minWidth:20,width:20,height:20,borderRadius:"50%",backgroundColor:t?o.color.green:"white",fontFamily:o.typography.fonts.base,fontSize:10,fontWeight:600,color:o.color.dark}));});var j,ro=a(()=>{eo();j=({children:t,index:o,isCompleted:r})=>e.createElement(Rt,null,e.createElement(oo,{"aria-label":r?"complete":"not complete",isCompleted:r},r?e.createElement(Icons,{width:10,height:10,icon:"check",color:"white"}):o),e.createElement(to,null,t));});function no(){let[t,o]=useState(null);return useEffect(()=>{(async()=>{try{let s=(await(await fetch("/index.json")).json()).entries["example-button--primary"].importPath;o({data:s,error:null});}catch(n){o({data:null,error:n});}})();},[]),t}var io=a(()=>{});var ao,po=a(()=>{ao=(t,o,r)=>{let[n,i]=useState(null);return useEffect(()=>{if(t){let s=()=>{r.getChannel().once(STORY_RENDERED,()=>{let p=o.getData("example-button--warning");i(p?{data:!0,error:null}:{data:!1,error:null});});};return o.getData("example-button--warning")?i({data:!0,error:null}):r.getServerChannel().on(STORY_INDEX_INVALIDATED,s),()=>{r.getServerChannel().off(STORY_INDEX_INVALIDATED,s);}}},[t]),n};});var lo,mo=a(()=>{lo=(t,o)=>{let[r,n]=useState(null),i=document.querySelector(`.${t}`);return useEffect(()=>{if(o){let s=new ResizeObserver(()=>{i&&n({top:i.offsetTop,left:i.offsetLeft,height:i.offsetHeight,width:i.offsetWidth});});return s.observe(i),()=>{s.disconnect();}}},[t,o]),r};});var co,uo=a(()=>{co="";});var go,fo=a(()=>{go="";});var ho,yo=a(()=>{ho="";});var xo,bo=a(()=>{xo=[[{code:"// Button.stories.jsx"}],[{code:"import { Button } from './Button';"}],[{code:`export default {
|
|
385
385
|
title: 'Example/Button',
|
|
386
386
|
component: Button,
|
|
387
387
|
// ...
|
|
@@ -438,4 +438,4 @@ export const Warning: Story = {
|
|
|
438
438
|
label: 'Delete now',
|
|
439
439
|
backgroundColor: 'red',
|
|
440
440
|
}
|
|
441
|
-
};`}]];});function vo(){let[t,o]=useState(null);return useEffect(()=>{(async()=>{try{let i=await(await fetch("/project.json")).json();o({data:i,error:null});}catch(n){o({data:null,error:n});}})();},[]),t}var Po=a(()=>{});var v,K=a(()=>{v="STORYBOOK_ADDON_ONBOARDING_CHANNEL";});var Do,Lo=a(()=>{N();Y();At();Zt();Jt();ro();io();po();mo();uo();fo();yo();bo();So();ko();Po();K();Do=({onFinish:t,api:o,addonsStore:r,skipOnboarding:n})=>{let[i,s]=useState("imports"),p={imports:0,meta:1,story:2,args:3,customStory:4},[l,m]=useState(!1),[g,u]=Ze(),y=no(),C=ao(i==="customStory",o,r),S=lo("syntax-highlighter-backdrop",i==="customStory"),R=vo(),F=R?.data?.language==="javascript"?xo:R?.data?.framework.name==="@storybook/nextjs"?wo:Co,Wo=()=>{let $=F[
|
|
441
|
+
};`}]];});function vo(){let[t,o]=useState(null);return useEffect(()=>{(async()=>{try{let i=await(await fetch("/project.json")).json();o({data:i,error:null});}catch(n){o({data:null,error:n});}})();},[]),t}var Po=a(()=>{});var v,K=a(()=>{v="STORYBOOK_ADDON_ONBOARDING_CHANNEL";});var Do,Lo=a(()=>{N();Y();At();Zt();Jt();ro();io();po();mo();uo();fo();yo();bo();So();ko();Po();K();Do=({onFinish:t,api:o,addonsStore:r,skipOnboarding:n})=>{let[i,s]=useState("imports"),p={imports:0,meta:1,story:2,args:3,customStory:4},[l,m]=useState(!1),[g,u]=Ze(),y=no(),C=ao(i==="customStory",o,r),S=lo("syntax-highlighter-backdrop",i==="customStory"),R=vo(),F=R?.data?.language==="javascript"?xo:R?.data?.framework.name==="@storybook/nextjs"?wo:Co,Wo=()=>{let $=F[3][0].code;navigator.clipboard.writeText($.replace("// Copy the code below","")),m(!0);},Io=useCallback(()=>{o.emit(v,{step:"X:SkippedOnboarding",where:`HowToWriteAStoryModal:${i}`,type:"telemetry"});},[o,i]);return e.createElement(W,{width:740,height:430,defaultOpen:!0},({Title:$,Description:Mo,Close:Eo})=>e.createElement(Bt,null,F?e.createElement(Vt,{activeStep:p[i]||0,data:F,width:480}):null,i==="customStory"&&S&&!C?.data&&e.createElement(d,{ref:g,onClick:()=>Wo(),style:{position:"absolute",top:S.top+S.height-45,left:S.left+S.width-(u.width??0)-10,zIndex:1e3}},l?"Copied to clipboard":"Copy code"),e.createElement(Dt,null,e.createElement(Lt,null,e.createElement($,{asChild:!0},e.createElement(Ot,null,e.createElement(Icons,{icon:"bookmarkhollow",width:13}),e.createElement("span",null,"How to write a story"))),e.createElement(Eo,{onClick:Io,asChild:!0},e.createElement(Icons,{style:{cursor:"pointer"},icon:"cross",width:13,onClick:n}))),e.createElement(Mo,{asChild:!0},e.createElement(zt,null,i==="imports"&&e.createElement(e.Fragment,null,e.createElement("div",null,e.createElement("h3",null,"Imports"),e.createElement("p",null,"First, import ",e.createElement(I,null,"Meta")," and"," ",e.createElement(I,null,"StoryObj")," for type safety and autocompletion in TypeScript stories."),e.createElement("p",null,"Next, import a component. In this case, the Button component.")),e.createElement(d,{style:{marginTop:4},onClick:()=>{s("meta");}},"Next")),i==="meta"&&e.createElement(e.Fragment,null,e.createElement("div",null,e.createElement("h3",null,"Meta"),e.createElement("p",null,"The default export, Meta, contains metadata about this component's stories. The title field (optional) controls where stories appear in the sidebar."),e.createElement(M,{width:"204",alt:"Title property pointing to Storybook's sidebar",src:co})),e.createElement(L,null,e.createElement(d,{variant:"secondary",onClick:()=>s("imports")},"Previous"),e.createElement(d,{onClick:()=>s("story")},"Next"))),i==="story"&&e.createElement(e.Fragment,null,e.createElement("div",null,e.createElement("h3",null,"Story"),e.createElement("p",null,"Each named export is a story. Its contents specify how the story is rendered in addition to other configuration options."),e.createElement(M,{width:"190",alt:"Story export pointing to the sidebar entry of the story",src:go})),e.createElement(L,null,e.createElement(d,{variant:"secondary",onClick:()=>s("meta")},"Previous"),e.createElement(d,{onClick:()=>s("args")},"Next"))),i==="args"&&e.createElement(e.Fragment,null,e.createElement("div",null,e.createElement("h3",null,"Args"),e.createElement("p",null,"Args are inputs that are passed to the component, which Storybook uses to render the component in different states. In React, args = props. They also specify the initial control values for the story."),e.createElement(M,{alt:"Args mapped to their controls in Storybook",width:"253",src:ho})),e.createElement(L,null,e.createElement(d,{variant:"secondary",onClick:()=>s("story")},"Previous"),e.createElement(d,{onClick:()=>s("customStory")},"Next"))),i==="customStory"&&(C?.error?null:e.createElement(e.Fragment,null,e.createElement("div",null,e.createElement("h3",null,"Create your first story"),e.createElement("p",null,"Now it's your turn. See how easy it is to create your first story by following these steps below."),e.createElement(qt,null,e.createElement(j,{isCompleted:l||C?.data,index:1},"Copy the Warning story"),e.createElement(j,{isCompleted:C?.data,index:2},e.createElement(Et,null,"Open the Button story in your current working directory"),y?.data&&e.createElement(I,null,y.data)),e.createElement(j,{isCompleted:C?.data,index:3},"Paste it at the bottom of the file and save"))),e.createElement(L,null,e.createElement(d,{variant:"secondary",onClick:()=>s("args")},"Previous"),C?.data?e.createElement(d,{onClick:()=>t()},"Go to story"):null))))),e.createElement(Nt,null,e.createElement(Wt,null),e.createElement(It,null),e.createElement(Mt,null)))))};});var zo={};jo(zo,{default:()=>Oo});function Oo({api:t}){let[o,r]=useState(!0),[n,i]=useState(!1),[s,p]=useState("1:Welcome"),l=useCallback(()=>{let m=new URL(window.location.href),g=decodeURIComponent(m.searchParams.get("path"));m.search=`?path=${g}&onboarding=false`,history.replaceState({},"",m.href),t.setQueryParams({onboarding:"false"}),r(!1);},[r,t]);return useEffect(()=>{t.emit(v,{step:"1:Welcome",type:"telemetry"});},[]),useEffect(()=>{t.emit(v,{step:s,type:"telemetry"});},[t,s]),useEffect(()=>{let m;return s==="4:VisitNewStory"&&(i(!0),m=window.setTimeout(()=>{p("5:ConfigureYourProject");},2e3)),()=>{clearTimeout(m);}},[s]),useEffect(()=>{let m=t.getCurrentStoryData()?.id;t.setQueryParams({onboarding:"true"}),m!=="example-button--primary"&&t.selectStory("example-button--primary",void 0,{ref:void 0});},[]),o?e.createElement(ThemeProvider,{theme:tr},o&&n&&e.createElement(z,{numberOfPieces:800,recycle:!1,tweenDuration:2e4,onConfettiComplete:m=>{m.reset(),i(!1);}}),o&&s==="1:Welcome"&&e.createElement(Pt,{onProceed:()=>{p("2:StorybookTour");},skipOnboarding:()=>{l(),t.emit(v,{step:"X:SkippedOnboarding",where:"WelcomeModal",type:"telemetry"});}}),o&&(s==="2:StorybookTour"||s==="5:ConfigureYourProject")&&e.createElement(it,{api:t,isFinalStep:s==="5:ConfigureYourProject",onFirstTourDone:()=>{p("3:WriteYourStory");},onLastTourDone:()=>{t.selectStory("configure-your-project--docs"),t.emit(v,{step:"6:FinishedOnboarding",type:"telemetry"}),l();}}),o&&s==="3:WriteYourStory"&&e.createElement(Do,{api:t,addonsStore:addons,onFinish:()=>{t.selectStory("example-button--warning"),p("4:VisitNewStory");},skipOnboarding:l})):null}var tr,No=a(()=>{st();Tt();Lo();H();K();tr=ensure(themes.light);});var sr=lazy(()=>Promise.resolve().then(()=>(No(),zo)));addons.register("@storybook/addon-onboarding",async t=>{let o=t.getUrlState(),r=o.path==="/onboarding"||o.queryParams.onboarding==="true";t.once(STORY_SPECIFIED,()=>{if(!(!!t.getData("example-button--primary")||!!document.getElementById("example-button--primary"))){console.warn("[@storybook/addon-onboarding] It seems like you have finished the onboarding experience in Storybook! Therefore this addon is not necessary anymore and will not be loaded. You are free to remove it from your project. More info: https://github.com/storybookjs/addon-onboarding#uninstalling");return}if(!r||window.innerWidth<730)return;t.togglePanel(!0),t.togglePanelPosition("bottom"),t.setSelectedPanel("addon-controls");let i=document.createElement("div");i.id="storybook-addon-onboarding",document.body.appendChild(i),or.render(e.createElement(Suspense,{fallback:e.createElement("div",null,"Loading...")},e.createElement(sr,{api:t})),i);});});
|