@nationaldesignstudio/react 0.0.7 → 0.0.9

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 (170) hide show
  1. package/README.md +0 -4
  2. package/dist/assets/fonts/PPNeueMontreal-Variable.woff2 +0 -0
  3. package/dist/assets/react.svg +1 -0
  4. package/dist/components/atoms/accordion/accordion.d.ts +50 -0
  5. package/dist/components/{button → atoms/button}/button.d.ts +5 -4
  6. package/dist/components/{button → atoms/button}/icon-button.d.ts +20 -0
  7. package/dist/components/atoms/pager-control/pager-control.d.ts +62 -0
  8. package/dist/components/{card → organisms/card}/card.d.ts +6 -2
  9. package/dist/components/{navbar → organisms/navbar}/navbar.d.ts +28 -1
  10. package/dist/components/sections/banner/banner.d.ts +64 -0
  11. package/dist/components/sections/card-grid/card-grid.d.ts +53 -0
  12. package/dist/components/sections/faq-section/faq-section.d.ts +44 -0
  13. package/dist/components/sections/hero/hero.d.ts +73 -0
  14. package/dist/components/sections/river/river.d.ts +63 -0
  15. package/dist/components/sections/tout/tout.d.ts +73 -0
  16. package/dist/components/sections/two-column-section/two-column-section.d.ts +58 -0
  17. package/dist/index.d.ts +28 -12
  18. package/dist/index.js +6108 -953
  19. package/dist/index.js.map +1 -1
  20. package/dist/tailwind.css +23 -0
  21. package/dist/tokens.css +2009 -103
  22. package/package.json +23 -5
  23. package/src/App.css +0 -0
  24. package/src/App.tsx +7 -0
  25. package/src/assets/fonts/PPNeueMontreal-Variable.woff2 +0 -0
  26. package/src/assets/react.svg +1 -0
  27. package/src/components/atoms/accordion/accordion.stories.tsx +228 -0
  28. package/src/components/atoms/accordion/accordion.tsx +137 -0
  29. package/src/components/atoms/accordion/index.ts +6 -0
  30. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-charcoal-chromium-darwin.png +0 -0
  31. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-charcoal-chromium-linux.png +0 -0
  32. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-charcoal-outline-chromium-darwin.png +0 -0
  33. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-charcoal-outline-chromium-linux.png +0 -0
  34. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-charcoal-outline-quiet-chromium-darwin.png +0 -0
  35. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-charcoal-outline-quiet-chromium-linux.png +0 -0
  36. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-disabled-chromium-darwin.png +0 -0
  37. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-disabled-chromium-linux.png +0 -0
  38. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-ivory-chromium-darwin.png +0 -0
  39. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-ivory-chromium-linux.png +0 -0
  40. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-ivory-outline-chromium-darwin.png +0 -0
  41. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-ivory-outline-chromium-linux.png +0 -0
  42. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-ivory-outline-quiet-chromium-darwin.png +0 -0
  43. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-ivory-outline-quiet-chromium-linux.png +0 -0
  44. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-size-large-chromium-darwin.png +0 -0
  45. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-size-large-chromium-linux.png +0 -0
  46. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-size-medium-chromium-darwin.png +0 -0
  47. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-size-medium-chromium-linux.png +0 -0
  48. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-size-small-chromium-darwin.png +0 -0
  49. package/src/components/atoms/button/__screenshots__/button.visual.test.tsx/button-size-small-chromium-linux.png +0 -0
  50. package/src/components/atoms/button/button.stories.tsx +84 -0
  51. package/src/components/atoms/button/button.test.tsx +141 -0
  52. package/src/components/atoms/button/button.tsx +95 -0
  53. package/src/components/atoms/button/button.visual.test.tsx +102 -0
  54. package/src/components/atoms/button/icon-button.stories.tsx +166 -0
  55. package/src/components/atoms/button/icon-button.tsx +125 -0
  56. package/src/components/atoms/button/index.ts +6 -0
  57. package/src/components/atoms/pager-control/index.ts +5 -0
  58. package/src/components/atoms/pager-control/pager-control.stories.tsx +209 -0
  59. package/src/components/atoms/pager-control/pager-control.test.tsx +149 -0
  60. package/src/components/atoms/pager-control/pager-control.tsx +328 -0
  61. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-default-vertical-chromium-darwin.png +0 -0
  62. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-default-vertical-chromium-linux.png +0 -0
  63. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-horizontal-chromium-darwin.png +0 -0
  64. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-horizontal-chromium-linux.png +0 -0
  65. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-minimal-chromium-darwin.png +0 -0
  66. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-minimal-chromium-linux.png +0 -0
  67. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-without-actions-chromium-darwin.png +0 -0
  68. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-without-actions-chromium-linux.png +0 -0
  69. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-without-eyebrow-chromium-darwin.png +0 -0
  70. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-without-eyebrow-chromium-linux.png +0 -0
  71. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-without-image-chromium-darwin.png +0 -0
  72. package/src/components/organisms/card/__screenshots__/card.visual.test.tsx/card-without-image-chromium-linux.png +0 -0
  73. package/src/components/organisms/card/card.stories.tsx +293 -0
  74. package/src/components/organisms/card/card.test.tsx +245 -0
  75. package/src/components/organisms/card/card.tsx +227 -0
  76. package/src/components/organisms/card/card.visual.test.tsx +197 -0
  77. package/src/components/organisms/card/index.ts +19 -0
  78. package/src/components/organisms/navbar/__screenshots__/navbar.visual.test.tsx/navbar-active-link-chromium-darwin.png +0 -0
  79. package/src/components/organisms/navbar/__screenshots__/navbar.visual.test.tsx/navbar-active-link-chromium-linux.png +0 -0
  80. package/src/components/organisms/navbar/__screenshots__/navbar.visual.test.tsx/navbar-brand-only-chromium-darwin.png +0 -0
  81. package/src/components/organisms/navbar/__screenshots__/navbar.visual.test.tsx/navbar-brand-only-chromium-linux.png +0 -0
  82. package/src/components/organisms/navbar/__screenshots__/navbar.visual.test.tsx/navbar-default-chromium-darwin.png +0 -0
  83. package/src/components/organisms/navbar/__screenshots__/navbar.visual.test.tsx/navbar-default-chromium-linux.png +0 -0
  84. package/src/components/organisms/navbar/index.ts +18 -0
  85. package/src/components/organisms/navbar/navbar.stories.tsx +313 -0
  86. package/src/components/organisms/navbar/navbar.test.tsx +190 -0
  87. package/src/components/organisms/navbar/navbar.tsx +317 -0
  88. package/src/components/organisms/navbar/navbar.visual.test.tsx +85 -0
  89. package/src/components/organisms/us-gov-banner/__screenshots__/us-gov-banner.visual.test.tsx/us-gov-banner-custom-icon-chromium-darwin.png +0 -0
  90. package/src/components/organisms/us-gov-banner/__screenshots__/us-gov-banner.visual.test.tsx/us-gov-banner-custom-icon-chromium-linux.png +0 -0
  91. package/src/components/organisms/us-gov-banner/__screenshots__/us-gov-banner.visual.test.tsx/us-gov-banner-custom-text-chromium-darwin.png +0 -0
  92. package/src/components/organisms/us-gov-banner/__screenshots__/us-gov-banner.visual.test.tsx/us-gov-banner-custom-text-chromium-linux.png +0 -0
  93. package/src/components/organisms/us-gov-banner/__screenshots__/us-gov-banner.visual.test.tsx/us-gov-banner-default-chromium-darwin.png +0 -0
  94. package/src/components/organisms/us-gov-banner/__screenshots__/us-gov-banner.visual.test.tsx/us-gov-banner-default-chromium-linux.png +0 -0
  95. package/src/components/organisms/us-gov-banner/index.ts +1 -0
  96. package/src/components/organisms/us-gov-banner/us-gov-banner.stories.tsx +35 -0
  97. package/src/components/organisms/us-gov-banner/us-gov-banner.test.tsx +107 -0
  98. package/src/components/organisms/us-gov-banner/us-gov-banner.tsx +73 -0
  99. package/src/components/organisms/us-gov-banner/us-gov-banner.visual.test.tsx +46 -0
  100. package/src/components/sections/banner/banner.stories.tsx +150 -0
  101. package/src/components/sections/banner/banner.test.tsx +185 -0
  102. package/src/components/sections/banner/banner.tsx +130 -0
  103. package/src/components/sections/banner/index.ts +2 -0
  104. package/src/components/sections/card-grid/card-grid.stories.tsx +351 -0
  105. package/src/components/sections/card-grid/card-grid.tsx +118 -0
  106. package/src/components/sections/card-grid/index.ts +1 -0
  107. package/src/components/sections/faq-section/faq-section.tsx +77 -0
  108. package/src/components/sections/faq-section/index.ts +2 -0
  109. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a1-desktop-chromium-darwin.png +0 -0
  110. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a1-desktop-chromium-linux.png +0 -0
  111. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a1-mobile-chromium-darwin.png +0 -0
  112. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a1-mobile-chromium-linux.png +0 -0
  113. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a1-tablet-chromium-darwin.png +0 -0
  114. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a1-tablet-chromium-linux.png +0 -0
  115. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a2-desktop-chromium-darwin.png +0 -0
  116. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a2-desktop-chromium-linux.png +0 -0
  117. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a2-mobile-chromium-darwin.png +0 -0
  118. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a2-mobile-chromium-linux.png +0 -0
  119. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a2-tablet-chromium-darwin.png +0 -0
  120. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a2-tablet-chromium-linux.png +0 -0
  121. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a3-desktop-chromium-darwin.png +0 -0
  122. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a3-desktop-chromium-linux.png +0 -0
  123. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a3-mobile-chromium-darwin.png +0 -0
  124. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a3-mobile-chromium-linux.png +0 -0
  125. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a3-tablet-chromium-darwin.png +0 -0
  126. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-a3-tablet-chromium-linux.png +0 -0
  127. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-custom-class-chromium-darwin.png +0 -0
  128. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-custom-class-chromium-linux.png +0 -0
  129. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-default-chromium-linux.png +0 -0
  130. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-long-title-chromium-darwin.png +0 -0
  131. package/src/components/sections/hero/__screenshots__/hero.visual.test.tsx/hero-long-title-chromium-linux.png +0 -0
  132. package/src/components/sections/hero/hero.stories.tsx +145 -0
  133. package/src/components/sections/hero/hero.test.tsx +135 -0
  134. package/src/components/sections/hero/hero.tsx +191 -0
  135. package/src/components/sections/hero/hero.visual.test.tsx +140 -0
  136. package/src/components/sections/hero/index.ts +1 -0
  137. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-h3-heading-chromium-darwin.png +0 -0
  138. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-h3-heading-chromium-linux.png +0 -0
  139. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-multiple-paragraphs-chromium-darwin.png +0 -0
  140. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-multiple-paragraphs-chromium-linux.png +0 -0
  141. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-multiple-sections-chromium-darwin.png +0 -0
  142. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-multiple-sections-chromium-linux.png +0 -0
  143. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-single-section-chromium-darwin.png +0 -0
  144. package/src/components/sections/prose/__screenshots__/prose.visual.test.tsx/prose-single-section-chromium-linux.png +0 -0
  145. package/src/components/sections/prose/index.ts +6 -0
  146. package/src/components/sections/prose/prose.stories.tsx +144 -0
  147. package/src/components/sections/prose/prose.test.tsx +178 -0
  148. package/src/components/sections/prose/prose.tsx +88 -0
  149. package/src/components/sections/prose/prose.visual.test.tsx +105 -0
  150. package/src/components/sections/river/index.ts +1 -0
  151. package/src/components/sections/river/river.stories.tsx +237 -0
  152. package/src/components/sections/river/river.test.tsx +268 -0
  153. package/src/components/sections/river/river.tsx +175 -0
  154. package/src/components/sections/tout/index.ts +1 -0
  155. package/src/components/sections/tout/tout.stories.tsx +154 -0
  156. package/src/components/sections/tout/tout.test.tsx +242 -0
  157. package/src/components/sections/tout/tout.tsx +206 -0
  158. package/src/components/sections/two-column-section/index.ts +5 -0
  159. package/src/components/sections/two-column-section/two-column-section.stories.tsx +285 -0
  160. package/src/components/sections/two-column-section/two-column-section.tsx +152 -0
  161. package/src/index.ts +98 -0
  162. package/src/lib/utils.ts +6 -0
  163. package/src/main.tsx +13 -0
  164. package/src/stories/Introduction.mdx +114 -0
  165. package/src/stories/TokenShowcase.stories.tsx +92 -0
  166. package/src/stories/TokenShowcase.tsx +1352 -0
  167. package/src/styles.css +11 -0
  168. package/dist/components/hero/hero.d.ts +0 -17
  169. /package/dist/components/{us-gov-banner → organisms/us-gov-banner}/us-gov-banner.d.ts +0 -0
  170. /package/dist/components/{prose → sections/prose}/prose.d.ts +0 -0
@@ -0,0 +1,58 @@
1
+ import { VariantProps } from 'class-variance-authority';
2
+ import * as React from "react";
3
+ /**
4
+ * TwoColumnSection component for text-heavy content sections
5
+ *
6
+ * Layout:
7
+ * - Desktop (lg+): Title left, content right with border-top divider
8
+ * - Mobile/Tablet: Stacked vertically
9
+ *
10
+ * Uses the 24-column grid system.
11
+ */
12
+ declare const twoColumnSectionVariants: (props?: ({
13
+ theme?: "light" | "dark" | null | undefined;
14
+ layout?: "asymmetric" | "equal" | null | undefined;
15
+ } & import('class-variance-authority/types').ClassProp) | undefined) => string;
16
+ export interface TwoColumnSectionProps extends React.HTMLAttributes<HTMLElement>, VariantProps<typeof twoColumnSectionVariants> {
17
+ /**
18
+ * The title text displayed in the left column
19
+ */
20
+ title: string;
21
+ /**
22
+ * Lead content - prominently styled (brighter text)
23
+ * Can be a string or ReactNode for rich content
24
+ */
25
+ lead?: React.ReactNode;
26
+ /**
27
+ * Body content - secondary styled (muted text)
28
+ * Can be a string or ReactNode for rich content
29
+ */
30
+ children: React.ReactNode;
31
+ /**
32
+ * Layout style for the columns
33
+ * - "asymmetric" (default): Uses 24-column grid with ~40/60 split (title: 9, content: 15)
34
+ * - "equal": Simple 2-column equal-width layout at md+ breakpoints
35
+ */
36
+ layout?: "asymmetric" | "equal";
37
+ }
38
+ /**
39
+ * TwoColumnSection component for text-heavy content with title/content split.
40
+ *
41
+ * Layout:
42
+ * - Mobile/Tablet: Stacked (title above content)
43
+ * - Desktop (lg+): Title left (~40%), Content right (~60%)
44
+ *
45
+ * @example
46
+ * ```tsx
47
+ * <TwoColumnSection
48
+ * title="US Tech Force"
49
+ * lead="The US Tech Force is recruiting an elite corps of engineers..."
50
+ * theme="dark"
51
+ * >
52
+ * <p>Through a two-year program, participants will work...</p>
53
+ * <p>Upon completing the program, engineers can seek...</p>
54
+ * </TwoColumnSection>
55
+ * ```
56
+ */
57
+ declare const TwoColumnSection: React.ForwardRefExoticComponent<TwoColumnSectionProps & React.RefAttributes<HTMLElement>>;
58
+ export { TwoColumnSection, twoColumnSectionVariants };
package/dist/index.d.ts CHANGED
@@ -1,13 +1,29 @@
1
- export type { ButtonProps, IconButtonProps } from './components/button';
2
- export { Button, buttonVariants, IconButton, iconButtonVariants, } from './components/button';
3
- export type { CardActionsProps, CardBodyProps, CardContentProps, CardDescriptionProps, CardEyebrowProps, CardImageProps, CardProps, CardTitleProps, } from './components/card';
4
- export { Card, CardActions, CardBody, CardContent, CardDescription, CardEyebrow, CardImage, CardTitle, cardVariants, } from './components/card';
5
- export type { HeroProps } from './components/hero';
6
- export { Hero } from './components/hero';
7
- export type { NavbarActionsProps, NavbarBrandProps, NavbarLinkProps, NavbarLinksProps, NavbarProps, } from './components/navbar';
8
- export { Navbar, NavbarActions, NavbarBrand, NavbarLink, NavbarLinks, } from './components/navbar';
9
- export type { ProseProps, ProseSectionProps } from './components/prose';
10
- export { Prose, ProseSection } from './components/prose';
11
- export type { USGovBannerProps } from './components/us-gov-banner';
12
- export { USGovBanner } from './components/us-gov-banner';
1
+ export type { AccordionItemProps, AccordionProps, } from './components/atoms/accordion';
2
+ export { Accordion, AccordionItem } from './components/atoms/accordion';
3
+ export type { ButtonProps, IconButtonProps } from './components/atoms/button';
4
+ export { Button, buttonVariants, IconButton, iconButtonVariants, } from './components/atoms/button';
5
+ export type { PagerControlProps } from './components/atoms/pager-control';
6
+ export { PagerControl, pagerControlVariants, } from './components/atoms/pager-control';
7
+ export type { CardActionsProps, CardBodyProps, CardContentProps, CardDescriptionProps, CardEyebrowProps, CardImageProps, CardProps, CardTitleProps, } from './components/organisms/card';
8
+ export { Card, CardActions, CardBody, CardContent, CardDescription, CardEyebrow, CardImage, CardTitle, cardVariants, } from './components/organisms/card';
9
+ export type { NavbarActionsProps, NavbarBrandProps, NavbarLinkProps, NavbarLinksProps, NavbarMobileMenuButtonProps, NavbarMobileMenuLinkProps, NavbarMobileMenuProps, NavbarProps, } from './components/organisms/navbar';
10
+ export { Navbar, NavbarActions, NavbarBrand, NavbarLink, NavbarLinks, NavbarMobileMenu, NavbarMobileMenuButton, NavbarMobileMenuLink, } from './components/organisms/navbar';
11
+ export type { USGovBannerProps } from './components/organisms/us-gov-banner';
12
+ export { USGovBanner } from './components/organisms/us-gov-banner';
13
+ export type { BannerProps } from './components/sections/banner';
14
+ export { Banner, bannerVariants } from './components/sections/banner';
15
+ export type { CardGridProps } from './components/sections/card-grid';
16
+ export { CardGrid, cardGridVariants } from './components/sections/card-grid';
17
+ export type { FaqSectionProps } from './components/sections/faq-section';
18
+ export { FaqSection } from './components/sections/faq-section';
19
+ export type { HeroProps } from './components/sections/hero';
20
+ export { Hero } from './components/sections/hero';
21
+ export type { ProseProps, ProseSectionProps, } from './components/sections/prose';
22
+ export { Prose, ProseSection } from './components/sections/prose';
23
+ export type { RiverProps } from './components/sections/river';
24
+ export { River, riverVariants } from './components/sections/river';
25
+ export type { ToutProps } from './components/sections/tout';
26
+ export { Tout } from './components/sections/tout';
27
+ export type { TwoColumnSectionProps } from './components/sections/two-column-section';
28
+ export { TwoColumnSection, twoColumnSectionVariants, } from './components/sections/two-column-section';
13
29
  export { cn } from './lib/utils';