@gpichot/spectacle-deck 1.0.8 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. package/dist/components/DocumentationItem.d.ts +10 -0
  2. package/{index.cjs → dist/index.cjs} +288 -141
  3. package/{index.d.ts → dist/index.d.ts} +4 -6
  4. package/{index.mjs → dist/index.mjs} +287 -140
  5. package/dist/layouts/QuoteLayout.d.ts +6 -0
  6. package/{layouts → dist/layouts}/index.d.ts +2 -0
  7. package/dist/package.json +30 -0
  8. package/package.json +20 -16
  9. package/scripts/bundle.ts +84 -0
  10. package/src/components/CodeStepper/CodeStepper.tsx +223 -0
  11. package/src/components/CodeStepper/code-directives.test.ts +58 -0
  12. package/src/components/CodeStepper/code-directives.ts +129 -0
  13. package/src/components/DocumentationItem.tsx +85 -0
  14. package/src/components/FilePane.tsx +18 -0
  15. package/src/components/HorizontalList.tsx +140 -0
  16. package/src/components/IconBox.tsx +31 -0
  17. package/src/components/Image.tsx +34 -0
  18. package/src/components/ItemsColumn.tsx +56 -0
  19. package/src/components/Timeline.styled.tsx +24 -0
  20. package/src/components/Timeline.tsx +157 -0
  21. package/src/components/map.tsx +115 -0
  22. package/src/components/styled.tsx +73 -0
  23. package/src/front.png +0 -0
  24. package/src/index.tsx +109 -0
  25. package/src/layouts/CenteredLayout.tsx +40 -0
  26. package/src/layouts/Default3Layout.tsx +159 -0
  27. package/src/layouts/MainSectionLayout.tsx +31 -0
  28. package/src/layouts/QuoteLayout.tsx +99 -0
  29. package/src/layouts/SectionLayout.tsx +14 -0
  30. package/src/layouts/SideCodeLayout.tsx +44 -0
  31. package/src/layouts/SideImageLayout.tsx +72 -0
  32. package/src/layouts/SideLayout.tsx +31 -0
  33. package/src/layouts/columns.tsx +56 -0
  34. package/src/layouts/index.tsx +19 -0
  35. package/src/layouts/styled.ts +7 -0
  36. package/src/layouts/utils.ts +65 -0
  37. package/src/node.d.ts +5 -0
  38. package/src/style.d.ts +10 -0
  39. package/src/template.tsx +25 -0
  40. package/src/theme.ts +24 -0
  41. package/test.js +106 -0
  42. package/tsconfig.json +29 -0
  43. /package/{components → dist/components}/CodeStepper/CodeStepper.d.ts +0 -0
  44. /package/{components → dist/components}/CodeStepper/code-directives.d.ts +0 -0
  45. /package/{components → dist/components}/FilePane.d.ts +0 -0
  46. /package/{components → dist/components}/HorizontalList.d.ts +0 -0
  47. /package/{components → dist/components}/IconBox.d.ts +0 -0
  48. /package/{components → dist/components}/Image.d.ts +0 -0
  49. /package/{components → dist/components}/ItemsColumn.d.ts +0 -0
  50. /package/{components → dist/components}/Timeline.d.ts +0 -0
  51. /package/{components → dist/components}/Timeline.styled.d.ts +0 -0
  52. /package/{components → dist/components}/map.d.ts +0 -0
  53. /package/{components → dist/components}/styled.d.ts +0 -0
  54. /package/{layouts → dist/layouts}/CenteredLayout.d.ts +0 -0
  55. /package/{layouts → dist/layouts}/Default3Layout.d.ts +0 -0
  56. /package/{layouts → dist/layouts}/MainSectionLayout.d.ts +0 -0
  57. /package/{layouts → dist/layouts}/SectionLayout.d.ts +0 -0
  58. /package/{layouts → dist/layouts}/SideCodeLayout.d.ts +0 -0
  59. /package/{layouts → dist/layouts}/SideImageLayout.d.ts +0 -0
  60. /package/{layouts → dist/layouts}/SideLayout.d.ts +0 -0
  61. /package/{layouts → dist/layouts}/columns.d.ts +0 -0
  62. /package/{layouts → dist/layouts}/styled.d.ts +0 -0
  63. /package/{layouts → dist/layouts}/utils.d.ts +0 -0
  64. /package/{template.d.ts → dist/template.d.ts} +0 -0
  65. /package/{theme.d.ts → dist/theme.d.ts} +0 -0
@@ -46,10 +46,11 @@ __export(src_exports, {
46
46
  Side: () => Side,
47
47
  Success: () => Success,
48
48
  Timeline: () => Timeline,
49
- TimelineItem: () => TimelineItem
49
+ TimelineItem: () => TimelineItem,
50
+ Warning: () => Warning
50
51
  });
51
- var import_react19 = __toESM(require("react"));
52
- var import_react20 = require("@mdx-js/react");
52
+ var import_react21 = __toESM(require("react"));
53
+ var import_react22 = require("@mdx-js/react");
53
54
  var import_spectacle9 = require("spectacle");
54
55
 
55
56
  // src/layouts/CenteredLayout.tsx
@@ -401,9 +402,97 @@ var MainSectionLayout = ({
401
402
  );
402
403
  };
403
404
 
404
- // src/layouts/SectionLayout.tsx
405
+ // src/layouts/QuoteLayout.tsx
406
+ var import_react5 = __toESM(require("react"));
405
407
  var import_styled_components3 = __toESM(require("styled-components"));
406
- var SectionLayout = import_styled_components3.default.div`
408
+ function invariant(condition, message) {
409
+ if (!condition) {
410
+ throw new Error(message);
411
+ }
412
+ }
413
+ var QuoteBaseLayout = import_styled_components3.default.div`
414
+ .blockquote > * {
415
+ border-left: 0;
416
+ }
417
+ .blockquote {
418
+ position: relative;
419
+ }
420
+ .blockquote > :first-child {
421
+ &:before {
422
+ content: "“";
423
+ position: absolute;
424
+ font-size: 16rem;
425
+ left: -9rem;
426
+ font-family: serif;
427
+ top: 2rem;
428
+ color: #ffffff22;
429
+ }
430
+ &:after {
431
+ content: "”";
432
+ position: absolute;
433
+ font-size: 16rem;
434
+ right: 3rem;
435
+ bottom: -5rem;
436
+ font-family: serif;
437
+ color: #ffffff22;
438
+ pointer-events: none;
439
+ }
440
+ }
441
+ .blockquote * {
442
+ line-height: 3.5rem !important;
443
+ font-size: 2.5rem;
444
+ }
445
+ .source {
446
+ font-family: Bitter, "Helvetica Neue", Helvetica, Arial, sans-serif;
447
+ box-sizing: border-box;
448
+ width: 100%;
449
+ margin-top: 4rem;
450
+ text-align: right;
451
+ font-size: 2rem;
452
+ a {
453
+ text-decoration: none;
454
+ color: #ffffff77;
455
+ }
456
+ }
457
+ `;
458
+ function QuoteLayout({
459
+ children,
460
+ author,
461
+ url
462
+ }) {
463
+ const [blockquote, rest] = getMatchingMdxType(children, "blockquote");
464
+ invariant(rest, "QuoteLayout can only have one blockquote");
465
+ return /* @__PURE__ */ import_react5.default.createElement(QuoteBaseLayout, null, /* @__PURE__ */ import_react5.default.createElement(
466
+ "div",
467
+ {
468
+ style: {
469
+ display: "flex",
470
+ flexDirection: "column",
471
+ alignItems: "flex-start",
472
+ justifyContent: "center",
473
+ textAlign: "center",
474
+ margin: "0 10%"
475
+ }
476
+ },
477
+ /* @__PURE__ */ import_react5.default.createElement(
478
+ "div",
479
+ {
480
+ style: {
481
+ flex: 1,
482
+ padding: "0 8rem 0 0",
483
+ boxSizing: "border-box"
484
+ },
485
+ className: "blockquote"
486
+ },
487
+ blockquote
488
+ ),
489
+ /* @__PURE__ */ import_react5.default.createElement("div", { className: "source", style: { flex: 1, padding: "0 2rem" } }, /* @__PURE__ */ import_react5.default.createElement("a", { href: url, target: "_blank", rel: "noopener noreferrer" }, author))
490
+ ));
491
+ }
492
+
493
+ // src/layouts/SectionLayout.tsx
494
+ var import_styled_components4 = __toESM(require("styled-components"));
495
+ var SectionLayout = import_styled_components4.default.div`
407
496
  display: flex;
408
497
  flex-direction: row;
409
498
  align-items: center;
@@ -417,12 +506,12 @@ var SectionLayout = import_styled_components3.default.div`
417
506
  `;
418
507
 
419
508
  // src/layouts/SideCodeLayout.tsx
420
- var import_react6 = __toESM(require("react"));
509
+ var import_react7 = __toESM(require("react"));
421
510
 
422
511
  // src/layouts/columns.tsx
423
- var import_react5 = __toESM(require("react"));
424
- var import_styled_components4 = __toESM(require("styled-components"));
425
- var DivWithHeading = import_styled_components4.default.div`
512
+ var import_react6 = __toESM(require("react"));
513
+ var import_styled_components5 = __toESM(require("styled-components"));
514
+ var DivWithHeading = import_styled_components5.default.div`
426
515
  h2 {
427
516
  margin-top: 0;
428
517
  }
@@ -431,7 +520,7 @@ var DivWithHeading = import_styled_components4.default.div`
431
520
  font-weight: 400;
432
521
  }
433
522
  `;
434
- var ColumnsContainer = (0, import_styled_components4.default)(DivWithHeading)`
523
+ var ColumnsContainer = (0, import_styled_components5.default)(DivWithHeading)`
435
524
  display: flex;
436
525
  flex-direction: row;
437
526
  position: absolute;
@@ -445,15 +534,15 @@ function ColumnsLayout({
445
534
  children,
446
535
  reverse
447
536
  }) {
448
- const childrenArray = import_react5.default.Children.toArray(children);
449
- return /* @__PURE__ */ import_react5.default.createElement(
537
+ const childrenArray = import_react6.default.Children.toArray(children);
538
+ return /* @__PURE__ */ import_react6.default.createElement(
450
539
  ColumnsContainer,
451
540
  {
452
541
  style: {
453
542
  flexDirection: reverse ? "row-reverse" : "row"
454
543
  }
455
544
  },
456
- childrenArray.map((child, i) => /* @__PURE__ */ import_react5.default.createElement(
545
+ childrenArray.map((child, i) => /* @__PURE__ */ import_react6.default.createElement(
457
546
  "div",
458
547
  {
459
548
  key: i,
@@ -472,8 +561,8 @@ function ColumnsLayout({
472
561
  }
473
562
 
474
563
  // src/layouts/SideCodeLayout.tsx
475
- var import_styled_components5 = __toESM(require("styled-components"));
476
- var CodeSide = import_styled_components5.default.div`
564
+ var import_styled_components6 = __toESM(require("styled-components"));
565
+ var CodeSide = import_styled_components6.default.div`
477
566
  pre {
478
567
  font-size: 0.9rem;
479
568
  }
@@ -483,7 +572,7 @@ function SidedCodeLayout({
483
572
  position = "right"
484
573
  }) {
485
574
  const [code, rest] = getCodeChildren(children);
486
- return /* @__PURE__ */ import_react6.default.createElement(ColumnsLayout, { reverse: position === "left" }, /* @__PURE__ */ import_react6.default.createElement(
575
+ return /* @__PURE__ */ import_react7.default.createElement(ColumnsLayout, { reverse: position === "left" }, /* @__PURE__ */ import_react7.default.createElement(
487
576
  "div",
488
577
  {
489
578
  style: {
@@ -492,7 +581,7 @@ function SidedCodeLayout({
492
581
  }
493
582
  },
494
583
  rest
495
- ), /* @__PURE__ */ import_react6.default.createElement(
584
+ ), /* @__PURE__ */ import_react7.default.createElement(
496
585
  CodeSide,
497
586
  {
498
587
  style: {
@@ -508,15 +597,15 @@ function SidedCodeLayout({
508
597
  }
509
598
 
510
599
  // src/layouts/SideImageLayout.tsx
511
- var import_react8 = __toESM(require("react"));
512
- var import_styled_components7 = __toESM(require("styled-components"));
600
+ var import_react9 = __toESM(require("react"));
601
+ var import_styled_components8 = __toESM(require("styled-components"));
513
602
 
514
603
  // src/components/Image.tsx
515
- var import_react7 = __toESM(require("react"));
604
+ var import_react8 = __toESM(require("react"));
516
605
 
517
606
  // src/layouts/styled.ts
518
- var import_styled_components6 = __toESM(require("styled-components"));
519
- var SVGObject = import_styled_components6.default.object`
607
+ var import_styled_components7 = __toESM(require("styled-components"));
608
+ var SVGObject = import_styled_components7.default.object`
520
609
  padding: 3rem 2rem;
521
610
  box-sizing: border-box;
522
611
  background-color: white;
@@ -526,7 +615,7 @@ var SVGObject = import_styled_components6.default.object`
526
615
  function Image(props) {
527
616
  const { src, height } = props;
528
617
  if (!(src == null ? void 0 : src.endsWith(".svg"))) {
529
- return /* @__PURE__ */ import_react7.default.createElement(
618
+ return /* @__PURE__ */ import_react8.default.createElement(
530
619
  "img",
531
620
  {
532
621
  src,
@@ -539,7 +628,7 @@ function Image(props) {
539
628
  }
540
629
  );
541
630
  }
542
- return /* @__PURE__ */ import_react7.default.createElement(
631
+ return /* @__PURE__ */ import_react8.default.createElement(
543
632
  SVGObject,
544
633
  {
545
634
  type: "image/svg+xml",
@@ -555,7 +644,7 @@ function Image(props) {
555
644
  Image.mdxType = "Image";
556
645
 
557
646
  // src/layouts/SideImageLayout.tsx
558
- var DivWithHeading2 = import_styled_components7.default.div`
647
+ var DivWithHeading2 = import_styled_components8.default.div`
559
648
  h2 {
560
649
  margin-top: 0;
561
650
  }
@@ -576,7 +665,7 @@ var SidedImageLayout = ({
576
665
  console.error("No image provided for SidedImageLayout");
577
666
  return null;
578
667
  }
579
- return /* @__PURE__ */ import_react8.default.createElement(
668
+ return /* @__PURE__ */ import_react9.default.createElement(
580
669
  DivWithHeading2,
581
670
  {
582
671
  style: {
@@ -589,7 +678,7 @@ var SidedImageLayout = ({
589
678
  top: 0
590
679
  }
591
680
  },
592
- /* @__PURE__ */ import_react8.default.createElement(
681
+ /* @__PURE__ */ import_react9.default.createElement(
593
682
  "div",
594
683
  {
595
684
  style: {
@@ -602,7 +691,7 @@ var SidedImageLayout = ({
602
691
  },
603
692
  rest
604
693
  ),
605
- /* @__PURE__ */ import_react8.default.createElement(
694
+ /* @__PURE__ */ import_react9.default.createElement(
606
695
  "div",
607
696
  {
608
697
  style: {
@@ -614,19 +703,19 @@ var SidedImageLayout = ({
614
703
  backgroundColor: "white"
615
704
  }
616
705
  },
617
- component || /* @__PURE__ */ import_react8.default.createElement(Image, { src: image })
706
+ component || /* @__PURE__ */ import_react9.default.createElement(Image, { src: image })
618
707
  )
619
708
  );
620
709
  };
621
710
 
622
711
  // src/layouts/SideLayout.tsx
623
- var import_react9 = __toESM(require("react"));
712
+ var import_react10 = __toESM(require("react"));
624
713
  function SideLayout({
625
714
  children,
626
715
  position = "right"
627
716
  }) {
628
717
  const [side, rest] = getMatchingMdxType(children, "Side");
629
- return /* @__PURE__ */ import_react9.default.createElement(ColumnsLayout, { reverse: position === "left" }, /* @__PURE__ */ import_react9.default.createElement("div", { style: { marginLeft: Margins.horizontal } }, rest), /* @__PURE__ */ import_react9.default.createElement(
718
+ return /* @__PURE__ */ import_react10.default.createElement(ColumnsLayout, { reverse: position === "left" }, /* @__PURE__ */ import_react10.default.createElement("div", { style: { marginLeft: Margins.horizontal } }, rest), /* @__PURE__ */ import_react10.default.createElement(
630
719
  "div",
631
720
  {
632
721
  style: {
@@ -648,6 +737,7 @@ var layouts_default = {
648
737
  mainSection: MainSectionLayout,
649
738
  centered: CenteredLayout,
650
739
  default3: Default3Layout,
740
+ quote: QuoteLayout,
651
741
  sidedCode: SidedCodeLayout,
652
742
  sidedImage: SidedImageLayout,
653
743
  side: SideLayout,
@@ -680,11 +770,11 @@ var theme_default = {
680
770
  };
681
771
 
682
772
  // src/template.tsx
683
- var import_react10 = __toESM(require("react"));
773
+ var import_react11 = __toESM(require("react"));
684
774
  var import_spectacle2 = require("spectacle");
685
775
  var template = ({ slideNumber, numberOfSlides }) => {
686
776
  const percentage = slideNumber / numberOfSlides * 100;
687
- return /* @__PURE__ */ import_react10.default.createElement("div", { style: { position: "absolute", bottom: 0, left: 0, right: 0 } }, /* @__PURE__ */ import_react10.default.createElement(import_spectacle2.Box, { padding: "0 0 0.5em 0.7em" }, /* @__PURE__ */ import_react10.default.createElement(import_spectacle2.FullScreen, null)), /* @__PURE__ */ import_react10.default.createElement("div", { style: { width: "100%", height: "4px", background: "#ffffff11" } }, /* @__PURE__ */ import_react10.default.createElement(
777
+ return /* @__PURE__ */ import_react11.default.createElement("div", { style: { position: "absolute", bottom: 0, left: 0, right: 0 } }, /* @__PURE__ */ import_react11.default.createElement(import_spectacle2.Box, { padding: "0 0 0.5em 0.7em" }, /* @__PURE__ */ import_react11.default.createElement(import_spectacle2.FullScreen, null)), /* @__PURE__ */ import_react11.default.createElement("div", { style: { width: "100%", height: "4px", background: "#ffffff11" } }, /* @__PURE__ */ import_react11.default.createElement(
688
778
  "div",
689
779
  {
690
780
  style: {
@@ -698,26 +788,26 @@ var template = ({ slideNumber, numberOfSlides }) => {
698
788
  };
699
789
 
700
790
  // src/components/map.tsx
701
- var import_react13 = __toESM(require("react"));
791
+ var import_react14 = __toESM(require("react"));
702
792
  var import_spectacle5 = require("spectacle");
703
793
 
704
794
  // src/components/styled.tsx
705
- var import_react11 = __toESM(require("react"));
795
+ var import_react12 = __toESM(require("react"));
706
796
  var import_spectacle3 = require("spectacle");
707
- var import_styled_components8 = __toESM(require("styled-components"));
708
- var StyledImage = (0, import_styled_components8.default)(import_spectacle3.Image)`
797
+ var import_styled_components9 = __toESM(require("styled-components"));
798
+ var StyledImage = (0, import_styled_components9.default)(import_spectacle3.Image)`
709
799
  object-fit: contain;
710
800
  max-height: 30vh;
711
801
  max-width: 70vw;
712
802
  `;
713
- var Image2 = (props) => /* @__PURE__ */ import_react11.default.createElement(import_spectacle3.FlexBox, { margin: "0 0", padding: "0 0" }, /* @__PURE__ */ import_react11.default.createElement(StyledImage, { ...props }));
714
- var CustomHeading = (0, import_styled_components8.default)(import_spectacle3.Heading)`
803
+ var Image2 = (props) => /* @__PURE__ */ import_react12.default.createElement(import_spectacle3.FlexBox, { margin: "0 0", padding: "0 0" }, /* @__PURE__ */ import_react12.default.createElement(StyledImage, { ...props }));
804
+ var CustomHeading = (0, import_styled_components9.default)(import_spectacle3.Heading)`
715
805
  strong {
716
806
  color: #f49676;
717
807
  font-weight: 500;
718
808
  }
719
809
  `;
720
- var CustomQuote = import_styled_components8.default.blockquote`
810
+ var CustomQuote = import_styled_components9.default.blockquote`
721
811
  margin: 1rem 0;
722
812
  padding-left: 1.5rem;
723
813
  padding-top: 0;
@@ -728,7 +818,7 @@ var CustomQuote = import_styled_components8.default.blockquote`
728
818
  padding: 0 !important;
729
819
  }
730
820
  `;
731
- var InlineCode = import_styled_components8.default.code`
821
+ var InlineCode = import_styled_components9.default.code`
732
822
  filter: brightness(1.05);
733
823
  zoom: 1.1;
734
824
  &:before,
@@ -737,12 +827,12 @@ var InlineCode = import_styled_components8.default.code`
737
827
  font-size: 0.8em;
738
828
  }
739
829
  `;
740
- var HeadingTwo = import_styled_components8.default.h2`
830
+ var HeadingTwo = import_styled_components9.default.h2`
741
831
  font-family: Bitter, \"Helvetica Neue\", Helvetica, Arial, sans-serif;
742
832
  font-size: 55px;
743
833
  font-weight: 400;
744
834
  `;
745
- var HeadingThree = import_styled_components8.default.h3`
835
+ var HeadingThree = import_styled_components9.default.h3`
746
836
  font-family: Bitter, \"Helvetica Neue\", Helvetica, Arial, sans-serif;
747
837
  font-size: 40px;
748
838
  font-weight: 400;
@@ -755,12 +845,12 @@ var HeadingThree = import_styled_components8.default.h3`
755
845
  `;
756
846
 
757
847
  // src/components/CodeStepper/CodeStepper.tsx
758
- var import_react12 = __toESM(require("react"));
848
+ var import_react13 = __toESM(require("react"));
759
849
  var import_react_is = __toESM(require("react-is"));
760
850
  var import_react_syntax_highlighter = require("react-syntax-highlighter");
761
851
  var import_prism = require("react-syntax-highlighter/dist/esm/styles/prism");
762
852
  var import_spectacle4 = require("spectacle");
763
- var import_styled_components9 = __toESM(require("styled-components"));
853
+ var import_styled_components10 = __toESM(require("styled-components"));
764
854
 
765
855
  // src/components/CodeStepper/code-directives.ts
766
856
  function range(start, end) {
@@ -825,7 +915,7 @@ function parseStepDirectives(directives) {
825
915
  // src/components/CodeStepper/CodeStepper.tsx
826
916
  var import_meta = {};
827
917
  var Highlighter = import_react_syntax_highlighter.Prism;
828
- var CodeContainer = import_styled_components9.default.div`
918
+ var CodeContainer = import_styled_components10.default.div`
829
919
  pre {
830
920
  padding: 1rem 0rem !important;
831
921
  background-color: transparent !important;
@@ -846,7 +936,7 @@ var CodeContainer = import_styled_components9.default.div`
846
936
  }
847
937
  `;
848
938
  function useCodeSteps(code) {
849
- return import_react12.default.useMemo(() => {
939
+ return import_react13.default.useMemo(() => {
850
940
  const prefixes = code.match(/(?:\/\/|<!--) @.*\n/g) || [];
851
941
  const prefixesLength = prefixes.reduce(
852
942
  (acc, prefix) => acc + prefix.length,
@@ -866,8 +956,8 @@ function useCodeSteps(code) {
866
956
  }, [code]);
867
957
  }
868
958
  function getCodeDetails(children) {
869
- const child = import_react12.default.Children.toArray(children)[0];
870
- if (!import_react12.default.isValidElement(child)) {
959
+ const child = import_react13.default.Children.toArray(children)[0];
960
+ if (!import_react13.default.isValidElement(child)) {
871
961
  return {
872
962
  language: "",
873
963
  code: import_react_is.default.isFragment(child) ? "" : String(child || "")
@@ -885,7 +975,7 @@ function CodeWrapper({
885
975
  hasName,
886
976
  children
887
977
  }) {
888
- return /* @__PURE__ */ import_react12.default.createElement(
978
+ return /* @__PURE__ */ import_react13.default.createElement(
889
979
  "div",
890
980
  {
891
981
  style: {
@@ -895,7 +985,7 @@ function CodeWrapper({
895
985
  borderRadius: "4px"
896
986
  }
897
987
  },
898
- name && /* @__PURE__ */ import_react12.default.createElement(
988
+ name && /* @__PURE__ */ import_react13.default.createElement(
899
989
  "span",
900
990
  {
901
991
  style: {
@@ -912,7 +1002,7 @@ function CodeWrapper({
912
1002
  name
913
1003
  ),
914
1004
  children,
915
- hasName && /* @__PURE__ */ import_react12.default.createElement(
1005
+ hasName && /* @__PURE__ */ import_react13.default.createElement(
916
1006
  "span",
917
1007
  {
918
1008
  style: {
@@ -927,7 +1017,7 @@ function CodeWrapper({
927
1017
  fontStyle: "italic"
928
1018
  }
929
1019
  },
930
- stepName || /* @__PURE__ */ import_react12.default.createElement("span", { style: { visibility: "hidden" } }, "Step")
1020
+ stepName || /* @__PURE__ */ import_react13.default.createElement("span", { style: { visibility: "hidden" } }, "Step")
931
1021
  )
932
1022
  );
933
1023
  }
@@ -936,7 +1026,7 @@ function CodeStepper({
936
1026
  name,
937
1027
  ...props
938
1028
  }) {
939
- const { language, code } = import_react12.default.useMemo(() => {
1029
+ const { language, code } = import_react13.default.useMemo(() => {
940
1030
  return getCodeDetails(props.children);
941
1031
  }, [props.children]);
942
1032
  const {
@@ -946,21 +1036,21 @@ function CodeStepper({
946
1036
  hasSteps,
947
1037
  hasName
948
1038
  } = useCodeSteps(code);
949
- return /* @__PURE__ */ import_react12.default.createElement(CodeContainer, null, import_meta.env.DEV && Boolean(prefixes == null ? void 0 : prefixes.length) && /* @__PURE__ */ import_react12.default.createElement("div", { style: { position: "absolute", top: 0, opacity: 0.5, left: 0 } }, /* @__PURE__ */ import_react12.default.createElement(Highlighter, { language, style: import_prism.gruvboxDark }, prefixes.join(""))), /* @__PURE__ */ import_react12.default.createElement(
1039
+ return /* @__PURE__ */ import_react13.default.createElement(CodeContainer, null, import_meta.env.DEV && Boolean(prefixes == null ? void 0 : prefixes.length) && /* @__PURE__ */ import_react13.default.createElement("div", { style: { position: "absolute", top: 0, opacity: 0.5, left: 0 } }, /* @__PURE__ */ import_react13.default.createElement(Highlighter, { language, style: import_prism.gruvboxDark }, prefixes.join(""))), /* @__PURE__ */ import_react13.default.createElement(
950
1040
  import_spectacle4.Stepper,
951
1041
  {
952
1042
  values: steps,
953
1043
  alwaysVisible: !hasSteps,
954
1044
  priority: priority ? priority + 1 : void 0
955
1045
  },
956
- (step, _, isActive) => /* @__PURE__ */ import_react12.default.createElement(
1046
+ (step, _, isActive) => /* @__PURE__ */ import_react13.default.createElement(
957
1047
  CodeWrapper,
958
1048
  {
959
1049
  name,
960
1050
  stepName: step == null ? void 0 : step.name,
961
1051
  hasName
962
1052
  },
963
- /* @__PURE__ */ import_react12.default.createElement(
1053
+ /* @__PURE__ */ import_react13.default.createElement(
964
1054
  Highlighter,
965
1055
  {
966
1056
  language,
@@ -1010,7 +1100,7 @@ CodeStepper.mdxType = "CodeStepper";
1010
1100
  // src/components/map.tsx
1011
1101
  var componentsMap = {
1012
1102
  ...import_spectacle5.mdxComponentMap,
1013
- inlineCode: (props) => /* @__PURE__ */ import_react13.default.createElement(
1103
+ inlineCode: (props) => /* @__PURE__ */ import_react14.default.createElement(
1014
1104
  InlineCode,
1015
1105
  {
1016
1106
  ...props,
@@ -1020,7 +1110,7 @@ var componentsMap = {
1020
1110
  }
1021
1111
  }
1022
1112
  ),
1023
- table: (props) => /* @__PURE__ */ import_react13.default.createElement(
1113
+ table: (props) => /* @__PURE__ */ import_react14.default.createElement(
1024
1114
  "table",
1025
1115
  {
1026
1116
  ...props,
@@ -1031,7 +1121,7 @@ var componentsMap = {
1031
1121
  }
1032
1122
  }
1033
1123
  ),
1034
- tr: (props) => /* @__PURE__ */ import_react13.default.createElement(
1124
+ tr: (props) => /* @__PURE__ */ import_react14.default.createElement(
1035
1125
  "tr",
1036
1126
  {
1037
1127
  ...props,
@@ -1043,7 +1133,7 @@ var componentsMap = {
1043
1133
  }
1044
1134
  }
1045
1135
  ),
1046
- td: (props) => /* @__PURE__ */ import_react13.default.createElement(
1136
+ td: (props) => /* @__PURE__ */ import_react14.default.createElement(
1047
1137
  "td",
1048
1138
  {
1049
1139
  ...props,
@@ -1056,7 +1146,7 @@ var componentsMap = {
1056
1146
  }
1057
1147
  }
1058
1148
  ),
1059
- h1: (props) => /* @__PURE__ */ import_react13.default.createElement(
1149
+ h1: (props) => /* @__PURE__ */ import_react14.default.createElement(
1060
1150
  CustomHeading,
1061
1151
  {
1062
1152
  fontSize: "h1",
@@ -1072,15 +1162,15 @@ var componentsMap = {
1072
1162
  },
1073
1163
  props.children
1074
1164
  ),
1075
- h2: (props) => /* @__PURE__ */ import_react13.default.createElement(HeadingTwo, null, props.children),
1076
- h3: (props) => /* @__PURE__ */ import_react13.default.createElement(HeadingThree, { ...props }),
1077
- img: (props) => /* @__PURE__ */ import_react13.default.createElement(Image2, { ...props }),
1165
+ h2: (props) => /* @__PURE__ */ import_react14.default.createElement(HeadingTwo, null, props.children),
1166
+ h3: (props) => /* @__PURE__ */ import_react14.default.createElement(HeadingThree, { ...props }),
1167
+ img: (props) => /* @__PURE__ */ import_react14.default.createElement(Image2, { ...props }),
1078
1168
  pre: CodeStepper,
1079
- li: (props) => /* @__PURE__ */ import_react13.default.createElement("li", { ...props, style: { margin: "24px 0" } }),
1080
- Side: (props) => /* @__PURE__ */ import_react13.default.createElement("div", { ...props }),
1169
+ li: (props) => /* @__PURE__ */ import_react14.default.createElement("li", { ...props, style: { margin: "24px 0" } }),
1170
+ Side: (props) => /* @__PURE__ */ import_react14.default.createElement("div", { ...props }),
1081
1171
  p: (props) => {
1082
1172
  const Text = import_spectacle5.mdxComponentMap.p;
1083
- return /* @__PURE__ */ import_react13.default.createElement(
1173
+ return /* @__PURE__ */ import_react14.default.createElement(
1084
1174
  Text,
1085
1175
  {
1086
1176
  style: { margin: "8px 0", padding: "8px 0", lineHeight: "2rem" },
@@ -1088,10 +1178,10 @@ var componentsMap = {
1088
1178
  }
1089
1179
  );
1090
1180
  },
1091
- blockquote: (props) => /* @__PURE__ */ import_react13.default.createElement(CustomQuote, { ...props }),
1181
+ blockquote: (props) => /* @__PURE__ */ import_react14.default.createElement(CustomQuote, { ...props }),
1092
1182
  a: ({ children, ...props }) => {
1093
1183
  const domain = new URL(props.href || "").hostname;
1094
- return /* @__PURE__ */ import_react13.default.createElement("a", { ...props, style: { color: "#f49676", textDecoration: "none" } }, children, " ", /* @__PURE__ */ import_react13.default.createElement(
1184
+ return /* @__PURE__ */ import_react14.default.createElement("a", { ...props, style: { color: "#f49676", textDecoration: "none" } }, children, " ", /* @__PURE__ */ import_react14.default.createElement(
1095
1185
  "small",
1096
1186
  {
1097
1187
  style: {
@@ -1107,14 +1197,14 @@ var componentsMap = {
1107
1197
  var map_default = componentsMap;
1108
1198
 
1109
1199
  // src/components/FilePane.tsx
1110
- var import_react14 = __toESM(require("react"));
1200
+ var import_react15 = __toESM(require("react"));
1111
1201
  function FilePane({
1112
1202
  name,
1113
1203
  children,
1114
1204
  priority,
1115
1205
  ...divProps
1116
1206
  }) {
1117
- return import_react14.default.isValidElement(children) ? import_react14.default.cloneElement(children, {
1207
+ return import_react15.default.isValidElement(children) ? import_react15.default.cloneElement(children, {
1118
1208
  // @ts-expect-error cloning
1119
1209
  priority,
1120
1210
  name
@@ -1123,14 +1213,14 @@ function FilePane({
1123
1213
  FilePane.mdxType = "FilePane";
1124
1214
 
1125
1215
  // src/components/ItemsColumn.tsx
1126
- var import_react15 = __toESM(require("react"));
1216
+ var import_react16 = __toESM(require("react"));
1127
1217
  var import_spectacle6 = require("spectacle");
1128
- var import_styled_components10 = __toESM(require("styled-components"));
1218
+ var import_styled_components11 = __toESM(require("styled-components"));
1129
1219
  var import_react_spring = require("react-spring");
1130
1220
  function ItemsColumn(divProps) {
1131
1221
  const { style: style2, children, ...props } = divProps;
1132
- const childrenArray = import_react15.default.Children.toArray(children);
1133
- return /* @__PURE__ */ import_react15.default.createElement(import_spectacle6.Stepper, { values: childrenArray }, (value, step) => /* @__PURE__ */ import_react15.default.createElement(
1222
+ const childrenArray = import_react16.default.Children.toArray(children);
1223
+ return /* @__PURE__ */ import_react16.default.createElement(import_spectacle6.Stepper, { values: childrenArray }, (value, step) => /* @__PURE__ */ import_react16.default.createElement(
1134
1224
  "div",
1135
1225
  {
1136
1226
  style: {
@@ -1144,14 +1234,14 @@ function ItemsColumn(divProps) {
1144
1234
  },
1145
1235
  childrenArray.map((child, index) => {
1146
1236
  const isVisible = index <= step;
1147
- if (!import_react15.default.isValidElement(child)) {
1237
+ if (!import_react16.default.isValidElement(child)) {
1148
1238
  return child;
1149
1239
  }
1150
- return /* @__PURE__ */ import_react15.default.createElement(ItemColumnWrapper, { key: index, isVisible }, child);
1240
+ return /* @__PURE__ */ import_react16.default.createElement(ItemColumnWrapper, { key: index, isVisible }, child);
1151
1241
  })
1152
1242
  ));
1153
1243
  }
1154
- var ItemColumnWrapperStyled = (0, import_styled_components10.default)(import_react_spring.animated.div)`
1244
+ var ItemColumnWrapperStyled = (0, import_styled_components11.default)(import_react_spring.animated.div)`
1155
1245
  * {
1156
1246
  text-align: center !important;
1157
1247
  }
@@ -1162,15 +1252,75 @@ function ItemColumnWrapper({
1162
1252
  ...props
1163
1253
  }) {
1164
1254
  const styles = (0, import_react_spring.useSpring)({ opacity: isVisible ? 1 : 0 });
1165
- return /* @__PURE__ */ import_react15.default.createElement(ItemColumnWrapperStyled, { style: styles, ...props }, children);
1255
+ return /* @__PURE__ */ import_react16.default.createElement(ItemColumnWrapperStyled, { style: styles, ...props }, children);
1256
+ }
1257
+
1258
+ // src/components/DocumentationItem.tsx
1259
+ var import_react17 = __toESM(require("react"));
1260
+ var import_styled_components12 = __toESM(require("styled-components"));
1261
+ var DocWrapper = import_styled_components12.default.div`
1262
+ position: absolute;
1263
+ bottom: 0;
1264
+ right: 0;
1265
+ z-index: 10000;
1266
+
1267
+ .docContent {
1268
+ display: none;
1269
+ }
1270
+
1271
+ &:hover .docContent {
1272
+ display: flex;
1273
+ }
1274
+ `;
1275
+ var DocContainer = import_styled_components12.default.div`
1276
+ margin: 2rem 1rem;
1277
+ background-color: #333;
1278
+ border: 1px solid #333;
1279
+ padding: 0.5rem 1rem;
1280
+ border-radius: 1.5rem;
1281
+ `;
1282
+ var DocLink = import_styled_components12.default.a`
1283
+ text-decoration: none;
1284
+ font-weight: normal;
1285
+ font-family: Bitter, "Helvetica Neue", Helvetica, Arial, sans-serif;
1286
+ color: #f49676;
1287
+ `;
1288
+ var DocLinkItem = (0, import_styled_components12.default)(DocLink)`
1289
+ width: fit-content;
1290
+ display: inline-block;
1291
+ background-color: #333;
1292
+ border: 1px solid #333;
1293
+ padding: 0.5rem 1rem;
1294
+ border-radius: 1.5rem;
1295
+ margin: 0.25rem 0;
1296
+ `;
1297
+ var DocContent = import_styled_components12.default.div`
1298
+ display: flex;
1299
+ flex-flow: column-reverse nowrap;
1300
+ position: absolute;
1301
+ right: 1rem;
1302
+ bottom: 4.5rem;
1303
+ text-align: right;
1304
+ border-radius: 0.5rem;
1305
+ align-items: flex-end;
1306
+ `;
1307
+ function Doc({
1308
+ label,
1309
+ link,
1310
+ children
1311
+ }) {
1312
+ return /* @__PURE__ */ import_react17.default.createElement(DocWrapper, null, /* @__PURE__ */ import_react17.default.createElement(DocContainer, null, children && /* @__PURE__ */ import_react17.default.createElement(DocContent, null, children), /* @__PURE__ */ import_react17.default.createElement("div", null, /* @__PURE__ */ import_react17.default.createElement(DocLink, { target: "_blank", rel: "noopener noreferrer", href: link }, label))));
1313
+ }
1314
+ function DocItem({ label, link }) {
1315
+ return /* @__PURE__ */ import_react17.default.createElement(DocLinkItem, { target: "_blank", rel: "noopener noreferrer", href: link }, label);
1166
1316
  }
1167
1317
 
1168
1318
  // src/components/HorizontalList.tsx
1169
- var import_react16 = __toESM(require("react"));
1319
+ var import_react18 = __toESM(require("react"));
1170
1320
  var import_react_spring2 = require("react-spring");
1171
1321
  var import_spectacle7 = require("spectacle");
1172
- var import_styled_components11 = __toESM(require("styled-components"));
1173
- var Container = import_styled_components11.default.div`
1322
+ var import_styled_components13 = __toESM(require("styled-components"));
1323
+ var Container = import_styled_components13.default.div`
1174
1324
  display: grid;
1175
1325
  grid-gap: 2rem;
1176
1326
  `;
@@ -1178,8 +1328,8 @@ function HorizontalList({
1178
1328
  children,
1179
1329
  columns = 3
1180
1330
  }) {
1181
- const items = import_react16.default.Children.toArray(children);
1182
- return /* @__PURE__ */ import_react16.default.createElement(import_spectacle7.Stepper, { values: items }, (_, step) => /* @__PURE__ */ import_react16.default.createElement(
1331
+ const items = import_react18.default.Children.toArray(children);
1332
+ return /* @__PURE__ */ import_react18.default.createElement(import_spectacle7.Stepper, { values: items }, (_, step) => /* @__PURE__ */ import_react18.default.createElement(
1183
1333
  Container,
1184
1334
  {
1185
1335
  style: {
@@ -1187,10 +1337,10 @@ function HorizontalList({
1187
1337
  }
1188
1338
  },
1189
1339
  items.map((item, k) => {
1190
- if (!import_react16.default.isValidElement(item)) {
1340
+ if (!import_react18.default.isValidElement(item)) {
1191
1341
  return item;
1192
1342
  }
1193
- return import_react16.default.cloneElement(item, {
1343
+ return import_react18.default.cloneElement(item, {
1194
1344
  // @ts-expect-error cloning
1195
1345
  position: k + 1,
1196
1346
  isVisible: k <= step,
@@ -1200,12 +1350,12 @@ function HorizontalList({
1200
1350
  ));
1201
1351
  }
1202
1352
  function Pill({ position }) {
1203
- return /* @__PURE__ */ import_react16.default.createElement(
1353
+ return /* @__PURE__ */ import_react18.default.createElement(
1204
1354
  "div",
1205
1355
  {
1206
1356
  style: { width: 48, transform: "translate(-25%, -25%)", opacity: 0.9 }
1207
1357
  },
1208
- /* @__PURE__ */ import_react16.default.createElement(
1358
+ /* @__PURE__ */ import_react18.default.createElement(
1209
1359
  "svg",
1210
1360
  {
1211
1361
  width: "48",
@@ -1214,14 +1364,14 @@ function Pill({ position }) {
1214
1364
  fill: "none",
1215
1365
  xmlns: "http://www.w3.org/2000/svg"
1216
1366
  },
1217
- /* @__PURE__ */ import_react16.default.createElement(
1367
+ /* @__PURE__ */ import_react18.default.createElement(
1218
1368
  "path",
1219
1369
  {
1220
1370
  d: "M8.64717 20L0 15.0094V5.00134L8.64717 0L17.289 5.00134V15.0094L8.64717 20ZM1.48222 14.141L8.64717 18.2846L15.8068 14.141V5.85902L8.64717 1.71536L1.48222 5.85902V14.141Z",
1221
1371
  fill: "#ffffff"
1222
1372
  }
1223
1373
  ),
1224
- /* @__PURE__ */ import_react16.default.createElement(
1374
+ /* @__PURE__ */ import_react18.default.createElement(
1225
1375
  "text",
1226
1376
  {
1227
1377
  x: "9",
@@ -1233,7 +1383,7 @@ function Pill({ position }) {
1233
1383
  },
1234
1384
  position
1235
1385
  ),
1236
- /* @__PURE__ */ import_react16.default.createElement(
1386
+ /* @__PURE__ */ import_react18.default.createElement(
1237
1387
  "path",
1238
1388
  {
1239
1389
  d: "M 8.758 16.01 L 3.549 13.004 L 3.549 6.975 L 8.758 3.963 L 13.964 6.975 L 13.964 13.004 L 8.758 16.01 Z",
@@ -1243,12 +1393,12 @@ function Pill({ position }) {
1243
1393
  )
1244
1394
  );
1245
1395
  }
1246
- var Item = (0, import_styled_components11.default)(import_react_spring2.animated.div)`
1396
+ var Item = (0, import_styled_components13.default)(import_react_spring2.animated.div)`
1247
1397
  display: flex;
1248
1398
  flex-direction: column;
1249
1399
  font-family: Bitter, "Helvetica Neue", Helvetica, Arial, sans-serif;
1250
1400
  `;
1251
- var ItemHead = import_styled_components11.default.div`
1401
+ var ItemHead = import_styled_components13.default.div`
1252
1402
  display: flex;
1253
1403
  flex-direction: row;
1254
1404
  font-size: 1.3rem;
@@ -1258,7 +1408,7 @@ var ItemHead = import_styled_components11.default.div`
1258
1408
  margin: 0;
1259
1409
  }
1260
1410
  `;
1261
- var ItemContent = import_styled_components11.default.div`
1411
+ var ItemContent = import_styled_components13.default.div`
1262
1412
  > * {
1263
1413
  font-size: 1rem;
1264
1414
  padding: 4px !important;
@@ -1286,31 +1436,31 @@ function HorizontalListItem({
1286
1436
  const opacityStyles = (0, import_react_spring2.useSpring)({
1287
1437
  opacity: getItemOpacity({ isVisible, isLast })
1288
1438
  });
1289
- return /* @__PURE__ */ import_react16.default.createElement(Item, { style: opacityStyles }, /* @__PURE__ */ import_react16.default.createElement(ItemHead, null, /* @__PURE__ */ import_react16.default.createElement(Pill, { position }), /* @__PURE__ */ import_react16.default.createElement("p", null, title)), /* @__PURE__ */ import_react16.default.createElement(ItemContent, null, children));
1439
+ return /* @__PURE__ */ import_react18.default.createElement(Item, { style: opacityStyles }, /* @__PURE__ */ import_react18.default.createElement(ItemHead, null, /* @__PURE__ */ import_react18.default.createElement(Pill, { position }), /* @__PURE__ */ import_react18.default.createElement("p", null, title)), /* @__PURE__ */ import_react18.default.createElement(ItemContent, null, children));
1290
1440
  }
1291
1441
 
1292
1442
  // src/components/Timeline.tsx
1293
- var import_react17 = __toESM(require("react"));
1443
+ var import_react19 = __toESM(require("react"));
1294
1444
  var import_react_spring3 = require("react-spring");
1295
1445
  var import_spectacle8 = require("spectacle");
1296
1446
 
1297
1447
  // src/components/Timeline.styled.tsx
1298
- var import_styled_components12 = __toESM(require("styled-components"));
1299
- var TimelineItemContent = import_styled_components12.default.div`
1448
+ var import_styled_components14 = __toESM(require("styled-components"));
1449
+ var TimelineItemContent = import_styled_components14.default.div`
1300
1450
  display: flex;
1301
1451
  padding: 0.7rem 0 1rem 12px;
1302
1452
  `;
1303
- var TimelineItemContentPhantom = (0, import_styled_components12.default)(TimelineItemContent)`
1453
+ var TimelineItemContentPhantom = (0, import_styled_components14.default)(TimelineItemContent)`
1304
1454
  opacity: 0;
1305
1455
  `;
1306
- var TimelineItemBody = import_styled_components12.default.div`
1456
+ var TimelineItemBody = import_styled_components14.default.div`
1307
1457
  &,
1308
1458
  & > * {
1309
1459
  font-size: 1.3rem !important;
1310
1460
  color: #ffffff !important;
1311
1461
  }
1312
1462
  `;
1313
- var TimelineItemTitle = import_styled_components12.default.div`
1463
+ var TimelineItemTitle = import_styled_components14.default.div`
1314
1464
  font-family: Bitter, "Helvetica Neue", Helvetica, Arial, sans-serif;
1315
1465
  font-size: 1rem;
1316
1466
  font-weight: bold;
@@ -1318,8 +1468,8 @@ var TimelineItemTitle = import_styled_components12.default.div`
1318
1468
  `;
1319
1469
 
1320
1470
  // src/components/Timeline.tsx
1321
- var import_styled_components13 = __toESM(require("styled-components"));
1322
- var TimelineItemStyled = (0, import_styled_components13.default)(import_react_spring3.animated.div)`
1471
+ var import_styled_components15 = __toESM(require("styled-components"));
1472
+ var TimelineItemStyled = (0, import_styled_components15.default)(import_react_spring3.animated.div)`
1323
1473
  flex: 1;
1324
1474
  flex-flow: column nowrap;
1325
1475
  display: inline-flex;
@@ -1337,7 +1487,7 @@ var TimelineItemStyled = (0, import_styled_components13.default)(import_react_sp
1337
1487
  }
1338
1488
  }
1339
1489
  `;
1340
- var TimelineItemGuide = (0, import_styled_components13.default)(import_react_spring3.animated.div)`
1490
+ var TimelineItemGuide = (0, import_styled_components15.default)(import_react_spring3.animated.div)`
1341
1491
  width: 100%;
1342
1492
  padding-top: 2px;
1343
1493
  display: flex;
@@ -1353,7 +1503,7 @@ var TimelineItemGuide = (0, import_styled_components13.default)(import_react_spr
1353
1503
  margin-right: 4px;
1354
1504
  }
1355
1505
  `;
1356
- var TimelineItemGuideLine = (0, import_styled_components13.default)(import_react_spring3.animated.div)`
1506
+ var TimelineItemGuideLine = (0, import_styled_components15.default)(import_react_spring3.animated.div)`
1357
1507
  border-top: 4px solid #ffffff;
1358
1508
  margin-right: 4px;
1359
1509
  `;
@@ -1364,8 +1514,8 @@ var style = {
1364
1514
  alignItems: "center"
1365
1515
  };
1366
1516
  function Timeline(props) {
1367
- const children = import_react17.default.Children.toArray(props.children);
1368
- return /* @__PURE__ */ import_react17.default.createElement(
1517
+ const children = import_react19.default.Children.toArray(props.children);
1518
+ return /* @__PURE__ */ import_react19.default.createElement(
1369
1519
  import_spectacle8.Stepper,
1370
1520
  {
1371
1521
  ...props,
@@ -1375,10 +1525,10 @@ function Timeline(props) {
1375
1525
  },
1376
1526
  (value, step) => {
1377
1527
  return children.map((child, index) => {
1378
- if (!import_react17.default.isValidElement(child)) {
1528
+ if (!import_react19.default.isValidElement(child)) {
1379
1529
  return child;
1380
1530
  }
1381
- return import_react17.default.cloneElement(child, {
1531
+ return import_react19.default.cloneElement(child, {
1382
1532
  // @ts-expect-error cloning
1383
1533
  isPhantom: step < index,
1384
1534
  isLast: step === index
@@ -1406,7 +1556,7 @@ function TimelineItem(props) {
1406
1556
  opacity: getItemOpacity2({ isPhantom, isLast })
1407
1557
  });
1408
1558
  const colorStyles = (0, import_react_spring3.useSpring)({ opacity: isPhantom || isLast ? 1 : 0.15 });
1409
- return /* @__PURE__ */ import_react17.default.createElement(
1559
+ return /* @__PURE__ */ import_react19.default.createElement(
1410
1560
  TimelineItemStyled,
1411
1561
  {
1412
1562
  ...rest,
@@ -1414,13 +1564,13 @@ function TimelineItem(props) {
1414
1564
  ...appearStyles
1415
1565
  }
1416
1566
  },
1417
- /* @__PURE__ */ import_react17.default.createElement(TimelineItemContentPhantom, null, /* @__PURE__ */ import_react17.default.createElement(TimelineItemTitle, null, title), /* @__PURE__ */ import_react17.default.createElement(TimelineItemBody, null, children)),
1418
- /* @__PURE__ */ import_react17.default.createElement(TimelineItemGuide, { style: colorStyles }, /* @__PURE__ */ import_react17.default.createElement(Hexagon, null), /* @__PURE__ */ import_react17.default.createElement(TimelineItemGuideLine, { style: guideLineProps })),
1419
- /* @__PURE__ */ import_react17.default.createElement(TimelineItemContent, null, /* @__PURE__ */ import_react17.default.createElement(TimelineItemTitle, null, title), /* @__PURE__ */ import_react17.default.createElement(TimelineItemBody, null, children))
1567
+ /* @__PURE__ */ import_react19.default.createElement(TimelineItemContentPhantom, null, /* @__PURE__ */ import_react19.default.createElement(TimelineItemTitle, null, title), /* @__PURE__ */ import_react19.default.createElement(TimelineItemBody, null, children)),
1568
+ /* @__PURE__ */ import_react19.default.createElement(TimelineItemGuide, { style: colorStyles }, /* @__PURE__ */ import_react19.default.createElement(Hexagon, null), /* @__PURE__ */ import_react19.default.createElement(TimelineItemGuideLine, { style: guideLineProps })),
1569
+ /* @__PURE__ */ import_react19.default.createElement(TimelineItemContent, null, /* @__PURE__ */ import_react19.default.createElement(TimelineItemTitle, null, title), /* @__PURE__ */ import_react19.default.createElement(TimelineItemBody, null, children))
1420
1570
  );
1421
1571
  }
1422
1572
  function Hexagon() {
1423
- return /* @__PURE__ */ import_react17.default.createElement(
1573
+ return /* @__PURE__ */ import_react19.default.createElement(
1424
1574
  "svg",
1425
1575
  {
1426
1576
  width: "18",
@@ -1429,14 +1579,14 @@ function Hexagon() {
1429
1579
  fill: "none",
1430
1580
  xmlns: "http://www.w3.org/2000/svg"
1431
1581
  },
1432
- /* @__PURE__ */ import_react17.default.createElement(
1582
+ /* @__PURE__ */ import_react19.default.createElement(
1433
1583
  "path",
1434
1584
  {
1435
1585
  d: "M8.64717 20L0 15.0094V5.00134L8.64717 0L17.289 5.00134V15.0094L8.64717 20ZM1.48222 14.141L8.64717 18.2846L15.8068 14.141V5.85902L8.64717 1.71536L1.48222 5.85902V14.141Z",
1436
1586
  fill: "#F49676"
1437
1587
  }
1438
1588
  ),
1439
- /* @__PURE__ */ import_react17.default.createElement(
1589
+ /* @__PURE__ */ import_react19.default.createElement(
1440
1590
  "path",
1441
1591
  {
1442
1592
  d: "M 8.758 16.01 L 3.549 13.004 L 3.549 6.975 L 8.758 3.963 L 13.964 6.975 L 13.964 13.004 L 8.758 16.01 Z",
@@ -1447,9 +1597,9 @@ function Hexagon() {
1447
1597
  }
1448
1598
 
1449
1599
  // src/components/IconBox.tsx
1450
- var import_react18 = __toESM(require("react"));
1451
- var import_styled_components14 = __toESM(require("styled-components"));
1452
- var IconBoxContent = import_styled_components14.default.div`
1600
+ var import_react20 = __toESM(require("react"));
1601
+ var import_styled_components16 = __toESM(require("styled-components"));
1602
+ var IconBoxContent = import_styled_components16.default.div`
1453
1603
  * {
1454
1604
  margin: 0.2rem !important;
1455
1605
  padding: 0 !important;
@@ -1459,7 +1609,7 @@ function IconBox({
1459
1609
  children,
1460
1610
  icon
1461
1611
  }) {
1462
- return /* @__PURE__ */ import_react18.default.createElement(
1612
+ return /* @__PURE__ */ import_react20.default.createElement(
1463
1613
  "div",
1464
1614
  {
1465
1615
  style: {
@@ -1469,14 +1619,14 @@ function IconBox({
1469
1619
  padding: "1rem 0"
1470
1620
  }
1471
1621
  },
1472
- /* @__PURE__ */ import_react18.default.createElement("div", { style: { fontSize: 60 } }, icon),
1473
- /* @__PURE__ */ import_react18.default.createElement(IconBoxContent, null, children)
1622
+ /* @__PURE__ */ import_react20.default.createElement("div", { style: { fontSize: 60 } }, icon),
1623
+ /* @__PURE__ */ import_react20.default.createElement(IconBoxContent, null, children)
1474
1624
  );
1475
1625
  }
1476
1626
 
1477
1627
  // src/index.tsx
1478
1628
  function PassThrough({ children }) {
1479
- return /* @__PURE__ */ import_react19.default.createElement(import_react19.default.Fragment, null, children);
1629
+ return /* @__PURE__ */ import_react21.default.createElement(import_react21.default.Fragment, null, children);
1480
1630
  }
1481
1631
  function Layout({
1482
1632
  children,
@@ -1488,47 +1638,44 @@ function Layout({
1488
1638
  console.warn(`Layout ${layout} not found`);
1489
1639
  }
1490
1640
  if (Layout2) {
1491
- return /* @__PURE__ */ import_react19.default.createElement(Layout2, { ...frontmatter }, children);
1641
+ return /* @__PURE__ */ import_react21.default.createElement(Layout2, { ...frontmatter }, children);
1492
1642
  }
1493
- return /* @__PURE__ */ import_react19.default.createElement(import_react19.default.Fragment, null, children);
1643
+ return /* @__PURE__ */ import_react21.default.createElement(import_react21.default.Fragment, null, children);
1494
1644
  }
1495
1645
  var componentsMap2 = {
1496
1646
  ...map_default,
1497
1647
  wrapper: Layout
1498
1648
  };
1499
1649
  function Deck({ deck }) {
1500
- import_react19.default.useEffect(() => {
1650
+ import_react21.default.useEffect(() => {
1501
1651
  document.title = deck.metadata.title || "Untitled";
1502
1652
  }, [deck.metadata.title]);
1503
- return /* @__PURE__ */ import_react19.default.createElement(import_react19.default.StrictMode, null, /* @__PURE__ */ import_react19.default.createElement(import_react20.MDXProvider, { components: componentsMap2 }, /* @__PURE__ */ import_react19.default.createElement(import_spectacle9.Deck, { theme: theme_default, template }, deck.slides.map((slide, i) => {
1653
+ return /* @__PURE__ */ import_react21.default.createElement(import_react21.default.StrictMode, null, /* @__PURE__ */ import_react21.default.createElement(import_react22.MDXProvider, { components: componentsMap2 }, /* @__PURE__ */ import_react21.default.createElement(import_spectacle9.Deck, { theme: theme_default, template }, deck.slides.map((slide, i) => {
1504
1654
  const Component = slide.slideComponent;
1505
- return /* @__PURE__ */ import_react19.default.createElement(import_spectacle9.Slide, { key: i }, /* @__PURE__ */ import_react19.default.createElement(Component, null));
1655
+ return /* @__PURE__ */ import_react21.default.createElement(import_spectacle9.Slide, { key: i }, /* @__PURE__ */ import_react21.default.createElement(Component, null));
1506
1656
  }))));
1507
1657
  }
1508
1658
  function Danger({ children }) {
1509
- return /* @__PURE__ */ import_react19.default.createElement("div", { style: { color: "red" } }, children);
1510
- }
1511
- function Doc({ children }) {
1512
- return /* @__PURE__ */ import_react19.default.createElement("div", { style: { color: "blue" } }, children);
1659
+ return /* @__PURE__ */ import_react21.default.createElement("div", { style: { color: "red" } }, children);
1513
1660
  }
1514
1661
  function Information({ children }) {
1515
- return /* @__PURE__ */ import_react19.default.createElement("div", { style: { color: "orange" } }, children);
1662
+ return /* @__PURE__ */ import_react21.default.createElement("div", { style: { color: "orange" } }, children);
1516
1663
  }
1517
1664
  function Success({ children }) {
1518
- return /* @__PURE__ */ import_react19.default.createElement("div", { style: { color: "green" } }, children);
1665
+ return /* @__PURE__ */ import_react21.default.createElement("div", { style: { color: "green" } }, children);
1666
+ }
1667
+ function Warning({ children }) {
1668
+ return /* @__PURE__ */ import_react21.default.createElement("div", { style: { color: "yellow" } }, children);
1519
1669
  }
1520
1670
  function Side({ children }) {
1521
- return /* @__PURE__ */ import_react19.default.createElement("div", null, children);
1671
+ return /* @__PURE__ */ import_react21.default.createElement("div", null, children);
1522
1672
  }
1523
1673
  Side.mdxType = "Side";
1524
1674
  function Documentation({ children }) {
1525
- return /* @__PURE__ */ import_react19.default.createElement("div", null, children);
1526
- }
1527
- function DocItem({ children }) {
1528
- return /* @__PURE__ */ import_react19.default.createElement("div", null, children);
1675
+ return /* @__PURE__ */ import_react21.default.createElement("div", null, children);
1529
1676
  }
1530
1677
  function Box2({ children }) {
1531
- return /* @__PURE__ */ import_react19.default.createElement("div", null, children);
1678
+ return /* @__PURE__ */ import_react21.default.createElement("div", null, children);
1532
1679
  }
1533
1680
 
1534
1681
  // <stdin>