@storybook/addon-onboarding 2.0.0-next.1 → 2.0.0-next.2
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
CHANGED
|
@@ -471,7 +471,7 @@ var t0=Object.create;var hn=Object.defineProperty;var r0=Object.getOwnPropertyDe
|
|
|
471
471
|
font-size: 13px;
|
|
472
472
|
line-height: 18px;
|
|
473
473
|
margin-top: 2px;
|
|
474
|
-
`,Eb=styled.div(({isCompleted:e,theme:t})=>({display:"flex",alignItems:"center",justifyContent:"center",border:`1px solid ${e?"transparent":t.color.medium}`,width:20,height:20,flexShrink:0,borderRadius:"50%",backgroundColor:e?t.color.green:"white",fontFamily:t.typography.fonts.base,fontSize:10,fontWeight:600,color:t.color.dark}));});var Hs,Ab=m(()=>{Ob();Hs=({children:e,index:t,isCompleted:r})=>T__default.createElement(Pb,null,T__default.createElement(Eb,{"aria-label":r?"complete":"not complete",isCompleted:r},r?T__default.createElement(CheckIcon,{width:10,height:10,color:"white"}):t),T__default.createElement(Tb,null,e));});function $b(){let[e,t]=useState(null);return useEffect(()=>{(async()=>{try{let i=(await(await fetch("/index.json")).json()).entries["example-button--primary"].importPath;t({data:i,error:null});}catch(o){t({data:null,error:o});}})();},[]),e}var Rb=m(()=>{});var Db,kb=m(()=>{Db=(e,t,r)=>{let[o,n]=useState(null);return useEffect(()=>{if(e){let i=()=>{r.getChannel().once(STORY_RENDERED,()=>{let a=t.getData("example-button--warning");n(a?{data:!0,error:null}:{data:!1,error:null});});},s=r.getChannel?r.getChannel():r.getServerChannel();return t.getData("example-button--warning")?n({data:!0,error:null}):s.on(STORY_INDEX_INVALIDATED,i),()=>{s.off(STORY_INDEX_INVALIDATED,i);}}},[e]),o};});var Lb,Nb=m(()=>{Lb=(e,t)=>{let[r,o]=useState(null),n=document.querySelector(`.${e}`);return useEffect(()=>{if(t){let i=new ResizeObserver(()=>{n&&o({top:n.offsetTop,left:n.offsetLeft,height:n.offsetHeight,width:n.offsetWidth});});return i.observe(n),()=>{i.disconnect();}}},[e,t]),r};});var Vb,Ib=m(()=>{Vb="./01-title-sidebar-HYYN5EU2.png";});var jb,Fb=m(()=>{jb="./02-story-name-sidebar-LO3W4A4B.png";});var _b,Bb=m(()=>{_b="./03-args-E4ZMXWZU.png";});var ir,eu=m(()=>{ir="STORYBOOK_ADDON_ONBOARDING_CHANNEL";});var Ub,zb=m(()=>{In();il();dm();wa();bb();Cb();Ab();Rb();kb();Nb();Ib();Fb();Bb();eu();Ub=({onFinish:e,api:t,addonsStore:r,skipOnboarding:o,codeSnippets:n})=>{let[i,s]=useState("imports"),a=useTheme(),l={imports:0,meta:1,story:2,args:3,customStory:4},[c,u]=useState(!1),[f,p]=fm(),d=$b(),g=Db(i==="customStory",t,r),h=Lb("syntax-highlighter-backdrop",i==="customStory"),v=n?.language==="javascript",x=()=>{let b=n.code[3][0].snippet;navigator.clipboard.writeText(b.replace("// Copy the code below","")),u(!0);},y=useCallback(()=>{t.emit(ir,{step:"X:SkippedOnboarding",where:`HowToWriteAStoryModal:${i}`,type:"telemetry"});},[t,i]);return T__default.createElement(Qn,{width:740,height:430,defaultOpen:!0},({Title:b,Description:w,Close:C})=>T__default.createElement(Qf,null,n?T__default.createElement(vb,{activeStep:l[i]||0,data:n.code,width:480,filename:n.filename}):null,i==="customStory"&&h&&!g?.data&&T__default.createElement(ue,{ref:f,onClick:()=>x(),style:{position:"absolute",opacity:p.width?1:0,top:h.top+h.height-45,left:h.left+h.width-(p.width??0)-10,zIndex:1e3}},c?"Copied to clipboard":"Copy code"),T__default.createElement(Jf,null,T__default.createElement(ep,null,T__default.createElement(b,{asChild:!0},T__default.createElement(tp,null,T__default.createElement(BookmarkHollowIcon,{width:13}),T__default.createElement("span",null,"How to write a story"))),T__default.createElement(C,{onClick:y,asChild:!0},T__default.createElement(CrossIcon,{style:{cursor:"pointer"},width:13,onClick:o,color:a.color.darkest}))),T__default.createElement(w,{asChild:!0},T__default.createElement(rp,null,i==="imports"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Imports"),v?T__default.createElement("p",null,"Import a component. In this case, the Button component."):T__default.createElement(T__default.Fragment,null,T__default.createElement("p",null,"First, import ",T__default.createElement(br,null,"Meta")," ","and ",T__default.createElement(br,null,"StoryObj")," for type safety and autocompletion in TypeScript stories."),T__default.createElement("p",null,"Next, import a component. In this case, the Button component."))),T__default.createElement(ue,{style:{marginTop:4},onClick:()=>{s("meta");}},"Next")),i==="meta"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Meta"),T__default.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."),T__default.createElement(Vn,{width:"204",alt:"Title property pointing to Storybook's sidebar",src:Vb})),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("imports")},"Previous"),T__default.createElement(ue,{onClick:()=>s("story")},"Next"))),i==="story"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Story"),T__default.createElement("p",null,"Each named export is a story. Its contents specify how the story is rendered in addition to other configuration options."),T__default.createElement(Vn,{width:"190",alt:"Story export pointing to the sidebar entry of the story",src:jb})),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("meta")},"Previous"),T__default.createElement(ue,{onClick:()=>s("args")},"Next"))),i==="args"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Args"),T__default.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."),T__default.createElement(Vn,{alt:"Args mapped to their controls in Storybook",width:"253",src:_b})),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("story")},"Previous"),T__default.createElement(ue,{onClick:()=>s("customStory")},"Next"))),i==="customStory"&&(g?.error?null:T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Create your first story"),T__default.createElement("p",null,"Now it's your turn. See how easy it is to create your first story by following these steps below."),T__default.createElement(Sb,null,T__default.createElement(Hs,{isCompleted:c||g?.data,index:1},"Copy the Warning story."),T__default.createElement(Hs,{isCompleted:g?.data,index:2},T__default.createElement(ap,null,"Open the Button story in your current working directory."),d?.data&&T__default.createElement(br,null,d.data.replaceAll("/","/\u200B").replaceAll("\\","\\\u200B"))),T__default.createElement(Hs,{isCompleted:g?.data,index:3},"Paste it at the bottom of the file and save."))),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("args")},"Previous"),g?.data?T__default.createElement(ue,{onClick:()=>e()},"Go to story"):null))))),T__default.createElement(op,null,T__default.createElement(np,null),T__default.createElement(ip,null),T__default.createElement(sp,null)))))};});var EE,Hb,Gb=m(()=>{EE={filename:"Button.stories.js",language:"typescript",code:[[{snippet:"import { Button } from './Button';"}],[{snippet:`export default {
|
|
474
|
+
`,Eb=styled.div(({isCompleted:e,theme:t})=>({display:"flex",alignItems:"center",justifyContent:"center",border:`1px solid ${e?"transparent":t.color.medium}`,width:20,height:20,flexShrink:0,borderRadius:"50%",backgroundColor:e?t.color.green:"white",fontFamily:t.typography.fonts.base,fontSize:10,fontWeight:600,color:t.color.dark}));});var Hs,Ab=m(()=>{Ob();Hs=({children:e,index:t,isCompleted:r})=>T__default.createElement(Pb,null,T__default.createElement(Eb,{"aria-label":r?"complete":"not complete",isCompleted:r},r?T__default.createElement(CheckIcon,{width:10,height:10,color:"white"}):t),T__default.createElement(Tb,null,e));});function $b(){let[e,t]=useState(null);return useEffect(()=>{(async()=>{try{let i=(await(await fetch("/index.json")).json()).entries["example-button--primary"].importPath;t({data:i,error:null});}catch(o){t({data:null,error:o});}})();},[]),e}var Rb=m(()=>{});var Db,kb=m(()=>{Db=(e,t,r)=>{let[o,n]=useState(null);return useEffect(()=>{if(e){let i=()=>{r.getChannel().once(STORY_RENDERED,()=>{let a=t.getData("example-button--warning");n(a?{data:!0,error:null}:{data:!1,error:null});});},s=r.getChannel?r.getChannel():r.getServerChannel();return t.getData("example-button--warning")?n({data:!0,error:null}):s.on(STORY_INDEX_INVALIDATED,i),()=>{s.off(STORY_INDEX_INVALIDATED,i);}}},[e]),o};});var Lb,Nb=m(()=>{Lb=(e,t)=>{let[r,o]=useState(null),n=document.querySelector(`.${e}`);return useEffect(()=>{if(t){let i=new ResizeObserver(()=>{n&&o({top:n.offsetTop,left:n.offsetLeft,height:n.offsetHeight,width:n.offsetWidth});});return i.observe(n),()=>{i.disconnect();}}},[e,t]),r};});var Vb,Ib=m(()=>{Vb="";});var jb,Fb=m(()=>{jb="";});var _b,Bb=m(()=>{_b="";});var ir,eu=m(()=>{ir="STORYBOOK_ADDON_ONBOARDING_CHANNEL";});var Ub,zb=m(()=>{In();il();dm();wa();bb();Cb();Ab();Rb();kb();Nb();Ib();Fb();Bb();eu();Ub=({onFinish:e,api:t,addonsStore:r,skipOnboarding:o,codeSnippets:n})=>{let[i,s]=useState("imports"),a=useTheme(),l={imports:0,meta:1,story:2,args:3,customStory:4},[c,u]=useState(!1),[f,p]=fm(),d=$b(),g=Db(i==="customStory",t,r),h=Lb("syntax-highlighter-backdrop",i==="customStory"),v=n?.language==="javascript",x=()=>{let b=n.code[3][0].snippet;navigator.clipboard.writeText(b.replace("// Copy the code below","")),u(!0);},y=useCallback(()=>{t.emit(ir,{step:"X:SkippedOnboarding",where:`HowToWriteAStoryModal:${i}`,type:"telemetry"});},[t,i]);return T__default.createElement(Qn,{width:740,height:430,defaultOpen:!0},({Title:b,Description:w,Close:C})=>T__default.createElement(Qf,null,n?T__default.createElement(vb,{activeStep:l[i]||0,data:n.code,width:480,filename:n.filename}):null,i==="customStory"&&h&&!g?.data&&T__default.createElement(ue,{ref:f,onClick:()=>x(),style:{position:"absolute",opacity:p.width?1:0,top:h.top+h.height-45,left:h.left+h.width-(p.width??0)-10,zIndex:1e3}},c?"Copied to clipboard":"Copy code"),T__default.createElement(Jf,null,T__default.createElement(ep,null,T__default.createElement(b,{asChild:!0},T__default.createElement(tp,null,T__default.createElement(BookmarkHollowIcon,{width:13}),T__default.createElement("span",null,"How to write a story"))),T__default.createElement(C,{onClick:y,asChild:!0},T__default.createElement(CrossIcon,{style:{cursor:"pointer"},width:13,onClick:o,color:a.color.darkest}))),T__default.createElement(w,{asChild:!0},T__default.createElement(rp,null,i==="imports"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Imports"),v?T__default.createElement("p",null,"Import a component. In this case, the Button component."):T__default.createElement(T__default.Fragment,null,T__default.createElement("p",null,"First, import ",T__default.createElement(br,null,"Meta")," ","and ",T__default.createElement(br,null,"StoryObj")," for type safety and autocompletion in TypeScript stories."),T__default.createElement("p",null,"Next, import a component. In this case, the Button component."))),T__default.createElement(ue,{style:{marginTop:4},onClick:()=>{s("meta");}},"Next")),i==="meta"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Meta"),T__default.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."),T__default.createElement(Vn,{width:"204",alt:"Title property pointing to Storybook's sidebar",src:Vb})),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("imports")},"Previous"),T__default.createElement(ue,{onClick:()=>s("story")},"Next"))),i==="story"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Story"),T__default.createElement("p",null,"Each named export is a story. Its contents specify how the story is rendered in addition to other configuration options."),T__default.createElement(Vn,{width:"190",alt:"Story export pointing to the sidebar entry of the story",src:jb})),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("meta")},"Previous"),T__default.createElement(ue,{onClick:()=>s("args")},"Next"))),i==="args"&&T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Args"),T__default.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."),T__default.createElement(Vn,{alt:"Args mapped to their controls in Storybook",width:"253",src:_b})),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("story")},"Previous"),T__default.createElement(ue,{onClick:()=>s("customStory")},"Next"))),i==="customStory"&&(g?.error?null:T__default.createElement(T__default.Fragment,null,T__default.createElement("div",null,T__default.createElement("h3",null,"Create your first story"),T__default.createElement("p",null,"Now it's your turn. See how easy it is to create your first story by following these steps below."),T__default.createElement(Sb,null,T__default.createElement(Hs,{isCompleted:c||g?.data,index:1},"Copy the Warning story."),T__default.createElement(Hs,{isCompleted:g?.data,index:2},T__default.createElement(ap,null,"Open the Button story in your current working directory."),d?.data&&T__default.createElement(br,null,d.data.replaceAll("/","/\u200B").replaceAll("\\","\\\u200B"))),T__default.createElement(Hs,{isCompleted:g?.data,index:3},"Paste it at the bottom of the file and save."))),T__default.createElement(Oo,null,T__default.createElement(ue,{variant:"secondary",onClick:()=>s("args")},"Previous"),g?.data?T__default.createElement(ue,{onClick:()=>e()},"Go to story"):null))))),T__default.createElement(op,null,T__default.createElement(np,null),T__default.createElement(ip,null),T__default.createElement(sp,null)))))};});var EE,Hb,Gb=m(()=>{EE={filename:"Button.stories.js",language:"typescript",code:[[{snippet:"import { Button } from './Button';"}],[{snippet:`export default {
|
|
475
475
|
title: 'Example/Button',
|
|
476
476
|
component: Button,
|
|
477
477
|
// ...
|