zero-to-app 2.0.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 (282) hide show
  1. package/README.md +929 -0
  2. package/dist/brand/brandConfig.d.ts +48 -0
  3. package/dist/brand/brandConfig.d.ts.map +1 -0
  4. package/dist/brand/brandConfig.js +41 -0
  5. package/dist/brand/brandConfig.js.map +1 -0
  6. package/dist/brand/brandContext.d.ts +10 -0
  7. package/dist/brand/brandContext.d.ts.map +1 -0
  8. package/dist/brand/brandContext.js +16 -0
  9. package/dist/brand/brandContext.js.map +1 -0
  10. package/dist/brand/brandTypes.d.ts +54 -0
  11. package/dist/brand/brandTypes.d.ts.map +1 -0
  12. package/dist/brand/brandTypes.js +2 -0
  13. package/dist/brand/brandTypes.js.map +1 -0
  14. package/dist/brand/index.d.ts +4 -0
  15. package/dist/brand/index.d.ts.map +1 -0
  16. package/dist/brand/index.js +5 -0
  17. package/dist/brand/index.js.map +1 -0
  18. package/dist/components/action/ActionRow.d.ts +25 -0
  19. package/dist/components/action/ActionRow.d.ts.map +1 -0
  20. package/dist/components/action/ActionRow.js +66 -0
  21. package/dist/components/action/ActionRow.js.map +1 -0
  22. package/dist/components/action/index.d.ts +2 -0
  23. package/dist/components/action/index.d.ts.map +1 -0
  24. package/dist/components/action/index.js +3 -0
  25. package/dist/components/action/index.js.map +1 -0
  26. package/dist/components/card/Card.d.ts +11 -0
  27. package/dist/components/card/Card.d.ts.map +1 -0
  28. package/dist/components/card/Card.js +32 -0
  29. package/dist/components/card/Card.js.map +1 -0
  30. package/dist/components/card/index.d.ts +2 -0
  31. package/dist/components/card/index.d.ts.map +1 -0
  32. package/dist/components/card/index.js +2 -0
  33. package/dist/components/card/index.js.map +1 -0
  34. package/dist/components/chat/ChatContainer.d.ts +27 -0
  35. package/dist/components/chat/ChatContainer.d.ts.map +1 -0
  36. package/dist/components/chat/ChatContainer.js +52 -0
  37. package/dist/components/chat/ChatContainer.js.map +1 -0
  38. package/dist/components/chat/ChatInput.d.ts +9 -0
  39. package/dist/components/chat/ChatInput.d.ts.map +1 -0
  40. package/dist/components/chat/ChatInput.js +219 -0
  41. package/dist/components/chat/ChatInput.js.map +1 -0
  42. package/dist/components/chat/ChatMessages.d.ts +9 -0
  43. package/dist/components/chat/ChatMessages.d.ts.map +1 -0
  44. package/dist/components/chat/ChatMessages.js +35 -0
  45. package/dist/components/chat/ChatMessages.js.map +1 -0
  46. package/dist/components/chat/EmptyChat.d.ts +18 -0
  47. package/dist/components/chat/EmptyChat.d.ts.map +1 -0
  48. package/dist/components/chat/EmptyChat.js +64 -0
  49. package/dist/components/chat/EmptyChat.js.map +1 -0
  50. package/dist/components/chat/Message.d.ts +8 -0
  51. package/dist/components/chat/Message.d.ts.map +1 -0
  52. package/dist/components/chat/Message.js +47 -0
  53. package/dist/components/chat/Message.js.map +1 -0
  54. package/dist/components/chat/index.d.ts +6 -0
  55. package/dist/components/chat/index.d.ts.map +1 -0
  56. package/dist/components/chat/index.js +7 -0
  57. package/dist/components/chat/index.js.map +1 -0
  58. package/dist/components/chat/types.d.ts +34 -0
  59. package/dist/components/chat/types.d.ts.map +1 -0
  60. package/dist/components/chat/types.js +2 -0
  61. package/dist/components/chat/types.js.map +1 -0
  62. package/dist/components/form/DropDownSelect.d.ts +12 -0
  63. package/dist/components/form/DropDownSelect.d.ts.map +1 -0
  64. package/dist/components/form/DropDownSelect.js +63 -0
  65. package/dist/components/form/DropDownSelect.js.map +1 -0
  66. package/dist/components/form/EmailSubscriptionForm.d.ts +14 -0
  67. package/dist/components/form/EmailSubscriptionForm.d.ts.map +1 -0
  68. package/dist/components/form/EmailSubscriptionForm.js +58 -0
  69. package/dist/components/form/EmailSubscriptionForm.js.map +1 -0
  70. package/dist/components/form/FormErrors.d.ts +7 -0
  71. package/dist/components/form/FormErrors.d.ts.map +1 -0
  72. package/dist/components/form/FormErrors.js +35 -0
  73. package/dist/components/form/FormErrors.js.map +1 -0
  74. package/dist/components/form/FormInput.d.ts +14 -0
  75. package/dist/components/form/FormInput.d.ts.map +1 -0
  76. package/dist/components/form/FormInput.js +35 -0
  77. package/dist/components/form/FormInput.js.map +1 -0
  78. package/dist/components/form/FormSeparator.d.ts +6 -0
  79. package/dist/components/form/FormSeparator.d.ts.map +1 -0
  80. package/dist/components/form/FormSeparator.js +25 -0
  81. package/dist/components/form/FormSeparator.js.map +1 -0
  82. package/dist/components/form/index.d.ts +6 -0
  83. package/dist/components/form/index.d.ts.map +1 -0
  84. package/dist/components/form/index.js +7 -0
  85. package/dist/components/form/index.js.map +1 -0
  86. package/dist/components/index.d.ts +11 -0
  87. package/dist/components/index.d.ts.map +1 -0
  88. package/dist/components/index.js +12 -0
  89. package/dist/components/index.js.map +1 -0
  90. package/dist/components/layout/Footer.d.ts +3 -0
  91. package/dist/components/layout/Footer.d.ts.map +1 -0
  92. package/dist/components/layout/Footer.js +60 -0
  93. package/dist/components/layout/Footer.js.map +1 -0
  94. package/dist/components/layout/MinimalFooter.d.ts +8 -0
  95. package/dist/components/layout/MinimalFooter.d.ts.map +1 -0
  96. package/dist/components/layout/MinimalFooter.js +57 -0
  97. package/dist/components/layout/MinimalFooter.js.map +1 -0
  98. package/dist/components/layout/MobileFooterBar.d.ts +7 -0
  99. package/dist/components/layout/MobileFooterBar.d.ts.map +1 -0
  100. package/dist/components/layout/MobileFooterBar.js +18 -0
  101. package/dist/components/layout/MobileFooterBar.js.map +1 -0
  102. package/dist/components/layout/ParallaxScrollView.d.ts +11 -0
  103. package/dist/components/layout/ParallaxScrollView.d.ts.map +1 -0
  104. package/dist/components/layout/ParallaxScrollView.js +67 -0
  105. package/dist/components/layout/ParallaxScrollView.js.map +1 -0
  106. package/dist/components/layout/WebPageLayout.d.ts +17 -0
  107. package/dist/components/layout/WebPageLayout.d.ts.map +1 -0
  108. package/dist/components/layout/WebPageLayout.js +103 -0
  109. package/dist/components/layout/WebPageLayout.js.map +1 -0
  110. package/dist/components/layout/index.d.ts +6 -0
  111. package/dist/components/layout/index.d.ts.map +1 -0
  112. package/dist/components/layout/index.js +9 -0
  113. package/dist/components/layout/index.js.map +1 -0
  114. package/dist/components/list/List.d.ts +10 -0
  115. package/dist/components/list/List.d.ts.map +1 -0
  116. package/dist/components/list/List.js +18 -0
  117. package/dist/components/list/List.js.map +1 -0
  118. package/dist/components/list/ListButton.d.ts +13 -0
  119. package/dist/components/list/ListButton.d.ts.map +1 -0
  120. package/dist/components/list/ListButton.js +24 -0
  121. package/dist/components/list/ListButton.js.map +1 -0
  122. package/dist/components/list/ListDivider.d.ts +7 -0
  123. package/dist/components/list/ListDivider.d.ts.map +1 -0
  124. package/dist/components/list/ListDivider.js +23 -0
  125. package/dist/components/list/ListDivider.js.map +1 -0
  126. package/dist/components/list/index.d.ts +4 -0
  127. package/dist/components/list/index.d.ts.map +1 -0
  128. package/dist/components/list/index.js +4 -0
  129. package/dist/components/list/index.js.map +1 -0
  130. package/dist/components/media/Carousel.d.ts +18 -0
  131. package/dist/components/media/Carousel.d.ts.map +1 -0
  132. package/dist/components/media/Carousel.js +60 -0
  133. package/dist/components/media/Carousel.js.map +1 -0
  134. package/dist/components/media/FeatureCard.d.ts +9 -0
  135. package/dist/components/media/FeatureCard.d.ts.map +1 -0
  136. package/dist/components/media/FeatureCard.js +68 -0
  137. package/dist/components/media/FeatureCard.js.map +1 -0
  138. package/dist/components/media/HorizontalCarousel.d.ts +17 -0
  139. package/dist/components/media/HorizontalCarousel.d.ts.map +1 -0
  140. package/dist/components/media/HorizontalCarousel.js +60 -0
  141. package/dist/components/media/HorizontalCarousel.js.map +1 -0
  142. package/dist/components/media/ImageCarousel.d.ts +14 -0
  143. package/dist/components/media/ImageCarousel.d.ts.map +1 -0
  144. package/dist/components/media/ImageCarousel.js +21 -0
  145. package/dist/components/media/ImageCarousel.js.map +1 -0
  146. package/dist/components/media/MediaTile.d.ts +30 -0
  147. package/dist/components/media/MediaTile.d.ts.map +1 -0
  148. package/dist/components/media/MediaTile.js +51 -0
  149. package/dist/components/media/MediaTile.js.map +1 -0
  150. package/dist/components/media/SkeletonMediaTile.d.ts +17 -0
  151. package/dist/components/media/SkeletonMediaTile.d.ts.map +1 -0
  152. package/dist/components/media/SkeletonMediaTile.js +67 -0
  153. package/dist/components/media/SkeletonMediaTile.js.map +1 -0
  154. package/dist/components/media/index.d.ts +7 -0
  155. package/dist/components/media/index.d.ts.map +1 -0
  156. package/dist/components/media/index.js +8 -0
  157. package/dist/components/media/index.js.map +1 -0
  158. package/dist/components/navigation/AppbarWeb.d.ts +18 -0
  159. package/dist/components/navigation/AppbarWeb.d.ts.map +1 -0
  160. package/dist/components/navigation/AppbarWeb.js +70 -0
  161. package/dist/components/navigation/AppbarWeb.js.map +1 -0
  162. package/dist/components/navigation/IconButtonGroup.d.ts +7 -0
  163. package/dist/components/navigation/IconButtonGroup.d.ts.map +1 -0
  164. package/dist/components/navigation/IconButtonGroup.js +33 -0
  165. package/dist/components/navigation/IconButtonGroup.js.map +1 -0
  166. package/dist/components/navigation/Logo.d.ts +16 -0
  167. package/dist/components/navigation/Logo.d.ts.map +1 -0
  168. package/dist/components/navigation/Logo.js +64 -0
  169. package/dist/components/navigation/Logo.js.map +1 -0
  170. package/dist/components/navigation/MobileMenuDrawer.d.ts +13 -0
  171. package/dist/components/navigation/MobileMenuDrawer.d.ts.map +1 -0
  172. package/dist/components/navigation/MobileMenuDrawer.js +184 -0
  173. package/dist/components/navigation/MobileMenuDrawer.js.map +1 -0
  174. package/dist/components/navigation/ScreenHeader.d.ts +30 -0
  175. package/dist/components/navigation/ScreenHeader.d.ts.map +1 -0
  176. package/dist/components/navigation/ScreenHeader.js +127 -0
  177. package/dist/components/navigation/ScreenHeader.js.map +1 -0
  178. package/dist/components/navigation/iconUtils.d.ts +24 -0
  179. package/dist/components/navigation/iconUtils.d.ts.map +1 -0
  180. package/dist/components/navigation/iconUtils.js +53 -0
  181. package/dist/components/navigation/iconUtils.js.map +1 -0
  182. package/dist/components/navigation/index.d.ts +6 -0
  183. package/dist/components/navigation/index.d.ts.map +1 -0
  184. package/dist/components/navigation/index.js +7 -0
  185. package/dist/components/navigation/index.js.map +1 -0
  186. package/dist/components/tile/Tile.d.ts +18 -0
  187. package/dist/components/tile/Tile.d.ts.map +1 -0
  188. package/dist/components/tile/Tile.js +41 -0
  189. package/dist/components/tile/Tile.js.map +1 -0
  190. package/dist/components/tile/index.d.ts +2 -0
  191. package/dist/components/tile/index.d.ts.map +1 -0
  192. package/dist/components/tile/index.js +2 -0
  193. package/dist/components/tile/index.js.map +1 -0
  194. package/dist/components/ui/ArrowButton.d.ts +8 -0
  195. package/dist/components/ui/ArrowButton.d.ts.map +1 -0
  196. package/dist/components/ui/ArrowButton.js +30 -0
  197. package/dist/components/ui/ArrowButton.js.map +1 -0
  198. package/dist/components/ui/BlurButton.d.ts +16 -0
  199. package/dist/components/ui/BlurButton.d.ts.map +1 -0
  200. package/dist/components/ui/BlurButton.js +26 -0
  201. package/dist/components/ui/BlurButton.js.map +1 -0
  202. package/dist/components/ui/Button.d.ts +24 -0
  203. package/dist/components/ui/Button.d.ts.map +1 -0
  204. package/dist/components/ui/Button.js +60 -0
  205. package/dist/components/ui/Button.js.map +1 -0
  206. package/dist/components/ui/ErrorBoundary.d.ts +18 -0
  207. package/dist/components/ui/ErrorBoundary.d.ts.map +1 -0
  208. package/dist/components/ui/ErrorBoundary.js +37 -0
  209. package/dist/components/ui/ErrorBoundary.js.map +1 -0
  210. package/dist/components/ui/IconButton.d.ts +13 -0
  211. package/dist/components/ui/IconButton.d.ts.map +1 -0
  212. package/dist/components/ui/IconButton.js +27 -0
  213. package/dist/components/ui/IconButton.js.map +1 -0
  214. package/dist/components/ui/LoadingIndicator.d.ts +6 -0
  215. package/dist/components/ui/LoadingIndicator.d.ts.map +1 -0
  216. package/dist/components/ui/LoadingIndicator.js +15 -0
  217. package/dist/components/ui/LoadingIndicator.js.map +1 -0
  218. package/dist/components/ui/NotificationBadge.d.ts +8 -0
  219. package/dist/components/ui/NotificationBadge.d.ts.map +1 -0
  220. package/dist/components/ui/NotificationBadge.js +24 -0
  221. package/dist/components/ui/NotificationBadge.js.map +1 -0
  222. package/dist/components/ui/SkeletonCard.d.ts +14 -0
  223. package/dist/components/ui/SkeletonCard.d.ts.map +1 -0
  224. package/dist/components/ui/SkeletonCard.js +50 -0
  225. package/dist/components/ui/SkeletonCard.js.map +1 -0
  226. package/dist/components/ui/StyledText.d.ts +17 -0
  227. package/dist/components/ui/StyledText.d.ts.map +1 -0
  228. package/dist/components/ui/StyledText.js +27 -0
  229. package/dist/components/ui/StyledText.js.map +1 -0
  230. package/dist/components/ui/StyledTextInput.d.ts +10 -0
  231. package/dist/components/ui/StyledTextInput.d.ts.map +1 -0
  232. package/dist/components/ui/StyledTextInput.js +62 -0
  233. package/dist/components/ui/StyledTextInput.js.map +1 -0
  234. package/dist/components/ui/TextLink.d.ts +14 -0
  235. package/dist/components/ui/TextLink.d.ts.map +1 -0
  236. package/dist/components/ui/TextLink.js +25 -0
  237. package/dist/components/ui/TextLink.js.map +1 -0
  238. package/dist/components/ui/ToggleIconButton.d.ts +14 -0
  239. package/dist/components/ui/ToggleIconButton.d.ts.map +1 -0
  240. package/dist/components/ui/ToggleIconButton.js +19 -0
  241. package/dist/components/ui/ToggleIconButton.js.map +1 -0
  242. package/dist/components/ui/index.d.ts +13 -0
  243. package/dist/components/ui/index.d.ts.map +1 -0
  244. package/dist/components/ui/index.js +14 -0
  245. package/dist/components/ui/index.js.map +1 -0
  246. package/dist/context/scrollContext.d.ts +8 -0
  247. package/dist/context/scrollContext.d.ts.map +1 -0
  248. package/dist/context/scrollContext.js +16 -0
  249. package/dist/context/scrollContext.js.map +1 -0
  250. package/dist/hooks/index.d.ts +4 -0
  251. package/dist/hooks/index.d.ts.map +1 -0
  252. package/dist/hooks/index.js +5 -0
  253. package/dist/hooks/index.js.map +1 -0
  254. package/dist/hooks/useDimensions.d.ts +31 -0
  255. package/dist/hooks/useDimensions.d.ts.map +1 -0
  256. package/dist/hooks/useDimensions.js +44 -0
  257. package/dist/hooks/useDimensions.js.map +1 -0
  258. package/dist/hooks/useWindowHeight.d.ts +7 -0
  259. package/dist/hooks/useWindowHeight.d.ts.map +1 -0
  260. package/dist/hooks/useWindowHeight.js +10 -0
  261. package/dist/hooks/useWindowHeight.js.map +1 -0
  262. package/dist/hooks/useWindowWidth.d.ts +20 -0
  263. package/dist/hooks/useWindowWidth.d.ts.map +1 -0
  264. package/dist/hooks/useWindowWidth.js +27 -0
  265. package/dist/hooks/useWindowWidth.js.map +1 -0
  266. package/dist/index.d.ts +6 -0
  267. package/dist/index.d.ts.map +1 -0
  268. package/dist/index.js +9 -0
  269. package/dist/index.js.map +1 -0
  270. package/dist/theme/index.d.ts +3 -0
  271. package/dist/theme/index.d.ts.map +1 -0
  272. package/dist/theme/index.js +4 -0
  273. package/dist/theme/index.js.map +1 -0
  274. package/dist/theme/theme.d.ts +15 -0
  275. package/dist/theme/theme.d.ts.map +1 -0
  276. package/dist/theme/theme.js +38 -0
  277. package/dist/theme/theme.js.map +1 -0
  278. package/dist/theme/themeConfig.d.ts +19 -0
  279. package/dist/theme/themeConfig.d.ts.map +1 -0
  280. package/dist/theme/themeConfig.js +43 -0
  281. package/dist/theme/themeConfig.js.map +1 -0
  282. package/package.json +104 -0
@@ -0,0 +1,30 @@
1
+ import { ImageSourcePropType, ViewStyle, ImageStyle } from 'react-native';
2
+ export interface MediaTileProps {
3
+ image: ImageSourcePropType | {
4
+ uri: string;
5
+ };
6
+ fallbackImage?: ImageSourcePropType | {
7
+ uri: string;
8
+ };
9
+ title: string;
10
+ subtitle?: string;
11
+ metadata?: string[];
12
+ onPress?: () => void;
13
+ loading?: boolean;
14
+ width?: number | {
15
+ mobile: number;
16
+ desktop: number;
17
+ };
18
+ height?: number | {
19
+ mobile: number;
20
+ desktop: number;
21
+ };
22
+ imageStyle?: ImageStyle;
23
+ contentStyle?: ViewStyle;
24
+ }
25
+ /**
26
+ * A general-purpose media tile component that displays an image with title, subtitle, and metadata.
27
+ * Responsive sizing and integrates with the design system theme/brand.
28
+ */
29
+ export declare const MediaTile: ({ image, fallbackImage, title, subtitle, metadata, onPress, loading, width, height, imageStyle, contentStyle, }: MediaTileProps) => import("react/jsx-runtime").JSX.Element;
30
+ //# sourceMappingURL=MediaTile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MediaTile.d.ts","sourceRoot":"","sources":["../../../components/media/MediaTile.tsx"],"names":[],"mappings":"AACA,OAAO,EAAsC,mBAAmB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAK9G,MAAM,WAAW,cAAc;IAE7B,KAAK,EAAE,mBAAmB,GAAG;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IAC7C,aAAa,CAAC,EAAE,mBAAmB,GAAG;QAAE,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IAGtD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IAGpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAGlB,KAAK,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACrD,MAAM,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAGtD,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,YAAY,CAAC,EAAE,SAAS,CAAC;CAC1B;AAED;;;GAGG;AACH,eAAO,MAAM,SAAS,GAAI,iHAYvB,cAAc,4CAgFhB,CAAC"}
@@ -0,0 +1,51 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useMemo } from 'react';
3
+ import { View, Image, Pressable, StyleSheet } from 'react-native';
4
+ import { StyledText } from '../ui';
5
+ import { useBrand } from '../../brand';
6
+ import { useBreakpoints } from '../../hooks/useWindowWidth';
7
+ /**
8
+ * A general-purpose media tile component that displays an image with title, subtitle, and metadata.
9
+ * Responsive sizing and integrates with the design system theme/brand.
10
+ */
11
+ export const MediaTile = ({ image, fallbackImage, title, subtitle, metadata, onPress, loading, width, height, imageStyle, contentStyle, }) => {
12
+ const { isMediumOrLarger } = useBreakpoints();
13
+ const brand = useBrand();
14
+ const styles = useMemo(() => StyleSheet.create({
15
+ image: {
16
+ width: '100%',
17
+ borderRadius: brand.borderRadius,
18
+ },
19
+ infoContainer: {
20
+ marginTop: 10,
21
+ gap: 5,
22
+ },
23
+ }), [brand]);
24
+ // Handle responsive sizing
25
+ const getWidth = () => {
26
+ if (typeof width === 'object') {
27
+ return isMediumOrLarger ? width.desktop : width.mobile;
28
+ }
29
+ return width;
30
+ };
31
+ const getHeight = () => {
32
+ if (typeof height === 'object') {
33
+ return isMediumOrLarger ? height.desktop : height.mobile;
34
+ }
35
+ return height;
36
+ };
37
+ // Default responsive sizes if not provided
38
+ const tileWidth = getWidth() ?? (isMediumOrLarger ? 250 : 150);
39
+ const imageHeight = getHeight() ?? (isMediumOrLarger ? 150 : 200);
40
+ // Determine image source
41
+ const imageSource = image || fallbackImage;
42
+ const content = (_jsxs(_Fragment, { children: [_jsx(Image, { source: imageSource, style: [styles.image, { height: imageHeight }, imageStyle], resizeMode: 'cover' }), _jsxs(View, { style: [styles.infoContainer, contentStyle], children: [_jsx(StyledText, { fontSize: "md", numberOfLines: 1, align: "left", children: title }), subtitle && (_jsx(StyledText, { fontSize: 'sm', numberOfLines: 1, align: "left", muted: true, children: subtitle })), metadata && metadata.length > 0 && metadata.map((item, index) => (_jsx(StyledText, { fontSize: 'sm', numberOfLines: 1, align: "left", muted: true, children: item }, index)))] })] }));
43
+ if (onPress) {
44
+ return (_jsx(Pressable, { style: [
45
+ { marginRight: 10 },
46
+ { width: tileWidth },
47
+ ], onPress: onPress, children: content }));
48
+ }
49
+ return (_jsx(View, { style: [{ marginRight: 10, width: tileWidth }], children: content }));
50
+ };
51
+ //# sourceMappingURL=MediaTile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MediaTile.js","sourceRoot":"","sources":["../../../components/media/MediaTile.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ export interface SkeletonMediaTileProps {
2
+ width?: number | {
3
+ mobile: number;
4
+ desktop: number;
5
+ };
6
+ height?: number | {
7
+ mobile: number;
8
+ desktop: number;
9
+ };
10
+ metadataCount?: number;
11
+ }
12
+ /**
13
+ * Skeleton loading state for MediaTile component.
14
+ * Provides consistent loading states with responsive sizing.
15
+ */
16
+ export declare const SkeletonMediaTile: ({ width, height, metadataCount, }: SkeletonMediaTileProps) => import("react/jsx-runtime").JSX.Element;
17
+ //# sourceMappingURL=SkeletonMediaTile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SkeletonMediaTile.d.ts","sourceRoot":"","sources":["../../../components/media/SkeletonMediaTile.tsx"],"names":[],"mappings":"AAMA,MAAM,WAAW,sBAAsB;IACrC,KAAK,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACrD,MAAM,CAAC,EAAE,MAAM,GAAG;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACtD,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED;;;GAGG;AACH,eAAO,MAAM,iBAAiB,GAAI,mCAI/B,sBAAsB,4CA+ExB,CAAC"}
@@ -0,0 +1,67 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext, useMemo } from 'react';
3
+ import { View, StyleSheet } from 'react-native';
4
+ import { ThemeContext } from '../../theme';
5
+ import { useBrand } from '../../brand';
6
+ import { useBreakpoints } from '../../hooks/useWindowWidth';
7
+ /**
8
+ * Skeleton loading state for MediaTile component.
9
+ * Provides consistent loading states with responsive sizing.
10
+ */
11
+ export const SkeletonMediaTile = ({ width, height, metadataCount = 2, }) => {
12
+ const theme = useContext(ThemeContext);
13
+ const { isMediumOrLarger } = useBreakpoints();
14
+ const brand = useBrand();
15
+ const styles = useMemo(() => StyleSheet.create({
16
+ skeletonImage: {
17
+ width: '100%',
18
+ borderRadius: brand.borderRadius,
19
+ },
20
+ infoContainer: {
21
+ marginTop: 10,
22
+ gap: 5,
23
+ },
24
+ skeletonText: {
25
+ height: 10,
26
+ borderRadius: 4,
27
+ marginTop: 5,
28
+ },
29
+ }), [brand]);
30
+ // Handle responsive sizing
31
+ const getWidth = () => {
32
+ if (typeof width === 'object') {
33
+ return isMediumOrLarger ? width.desktop : width.mobile;
34
+ }
35
+ return width;
36
+ };
37
+ const getHeight = () => {
38
+ if (typeof height === 'object') {
39
+ return isMediumOrLarger ? height.desktop : height.mobile;
40
+ }
41
+ return height;
42
+ };
43
+ // Default responsive sizes if not provided
44
+ const tileWidth = getWidth() ?? (isMediumOrLarger ? 250 : 150);
45
+ const imageHeight = getHeight() ?? (isMediumOrLarger ? 150 : 200);
46
+ const skeletonColor = theme.values.isDark ? '#333333' : '#e0e0e0';
47
+ const skeletonWidths = ['70%', '40%', '30%'];
48
+ return (_jsxs(View, { style: [
49
+ { width: tileWidth, marginRight: 10 },
50
+ ], children: [_jsx(View, { style: [
51
+ styles.skeletonImage,
52
+ { backgroundColor: skeletonColor, height: imageHeight },
53
+ ] }), _jsxs(View, { style: styles.infoContainer, children: [_jsx(View, { style: [
54
+ styles.skeletonText,
55
+ {
56
+ width: (skeletonWidths[0] || '70%'),
57
+ backgroundColor: skeletonColor,
58
+ },
59
+ ] }), Array.from({ length: metadataCount }).map((_, index) => (_jsx(View, { style: [
60
+ styles.skeletonText,
61
+ {
62
+ width: (skeletonWidths[index + 1] || '40%'),
63
+ backgroundColor: skeletonColor,
64
+ },
65
+ ] }, index)))] })] }));
66
+ };
67
+ //# sourceMappingURL=SkeletonMediaTile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SkeletonMediaTile.js","sourceRoot":"","sources":["../../../components/media/SkeletonMediaTile.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export { ImageCarousel } from './ImageCarousel';
2
+ export { default as FeatureCard } from './FeatureCard';
3
+ export { HorizontalCarousel } from './HorizontalCarousel';
4
+ export { Carousel } from './Carousel';
5
+ export { MediaTile } from './MediaTile';
6
+ export { SkeletonMediaTile } from './SkeletonMediaTile';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/media/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,8 @@
1
+ // Media components
2
+ export { ImageCarousel } from './ImageCarousel';
3
+ export { default as FeatureCard } from './FeatureCard';
4
+ export { HorizontalCarousel } from './HorizontalCarousel';
5
+ export { Carousel } from './Carousel';
6
+ export { MediaTile } from './MediaTile';
7
+ export { SkeletonMediaTile } from './SkeletonMediaTile';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/media/index.ts"],"names":[],"mappings":"AAAA,mBAAmB;AACnB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ type AppbarProps = {
3
+ title?: string;
4
+ logoUri?: string;
5
+ tabs?: React.ReactElement | React.ReactElement[];
6
+ currentRoute?: string;
7
+ onNavigate?: (route: string) => void;
8
+ hideTabs?: boolean;
9
+ };
10
+ /**
11
+ * A responsive appbar that displays at the top of the page.
12
+ * Dynamically adapts its styling when the viewport is less than medium
13
+ * On mobile web: Logo + Hamburger menu
14
+ * On desktop/tablet: Logo + Top tabs + Theme toggle
15
+ */
16
+ declare const AppbarWeb: ({ title, logoUri, tabs, currentRoute, onNavigate, hideTabs }: AppbarProps) => import("react/jsx-runtime").JSX.Element;
17
+ export default AppbarWeb;
18
+ //# sourceMappingURL=AppbarWeb.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppbarWeb.d.ts","sourceRoot":"","sources":["../../../components/navigation/AppbarWeb.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAUnD,KAAK,WAAW,GAAG;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;IACjD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF;;;;;GAKG;AAEH,QAAA,MAAM,SAAS,GAAI,8DAAsE,WAAW,4CAwEnG,CAAC;AACF,eAAe,SAAS,CAAC"}
@@ -0,0 +1,70 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext, useMemo } from 'react';
3
+ import { StyleSheet, View } from 'react-native';
4
+ import { useDimensions } from '../../hooks';
5
+ import { useBrand } from '../../brand';
6
+ import { ThemeContext } from '../../theme';
7
+ import { Platform } from 'react-native';
8
+ import IconButtonGroup from './IconButtonGroup';
9
+ import AppbarBranding from './Logo';
10
+ import MobileMenuDrawer from './MobileMenuDrawer';
11
+ /**
12
+ * A responsive appbar that displays at the top of the page.
13
+ * Dynamically adapts its styling when the viewport is less than medium
14
+ * On mobile web: Logo + Hamburger menu
15
+ * On desktop/tablet: Logo + Top tabs + Theme toggle
16
+ */
17
+ const AppbarWeb = ({ title, logoUri, tabs, currentRoute, onNavigate, hideTabs = false }) => {
18
+ //Initialize theme
19
+ const theme = useContext(ThemeContext);
20
+ //Use dimensions hook
21
+ const dimensions = useDimensions();
22
+ const brand = useBrand();
23
+ const styles = useMemo(() => StyleSheet.create({
24
+ appbar: {
25
+ flexDirection: 'row',
26
+ alignItems: 'center',
27
+ justifyContent: 'space-between',
28
+ height: 80,
29
+ paddingHorizontal: '5%',
30
+ },
31
+ appbarWebSmall: {
32
+ flexDirection: 'row',
33
+ alignItems: 'center',
34
+ justifyContent: 'space-between',
35
+ height: 80,
36
+ width: '100%',
37
+ paddingHorizontal: brand.spacing.xl,
38
+ },
39
+ iconContainer: {
40
+ flexDirection: 'row',
41
+ gap: brand.spacing.sm + 2,
42
+ },
43
+ logo: {
44
+ width: 40,
45
+ height: 40,
46
+ },
47
+ title: {
48
+ fontSize: brand.fontSizes.large,
49
+ fontWeight: 'bold',
50
+ marginLeft: brand.spacing.sm + 2,
51
+ },
52
+ webContainer: {}, // WebContainer property for additional styling
53
+ }), [brand]);
54
+ return (_jsx(View, { style: {
55
+ //Configure a background with a theme background
56
+ backgroundColor: theme.values.appbarBackgroundColor,
57
+ // Ensure appbar appears above content
58
+ zIndex: 10,
59
+ position: 'relative',
60
+ }, children: _jsx(View, { style: {
61
+ ...styles.webContainer, //Configure appbar with theme appbar background color
62
+ backgroundColor: theme.values.appbarBackgroundColor,
63
+ ...(!theme.values.isDark && { borderBottomWidth: 1, borderBottomColor: theme.values.borderColor }),
64
+ }, children: _jsxs(View, { style: {
65
+ ...styles.appbar,
66
+ height: Platform.OS === 'web' && dimensions.breakpoint === 'small' ? 60 : 80,
67
+ }, children: [_jsx(AppbarBranding, { logoUri: logoUri }), Platform.OS === 'web' && dimensions.breakpoint === 'small' ? (_jsx(MobileMenuDrawer, { currentRoute: currentRoute, onNavigate: onNavigate, logoUri: logoUri })) : (_jsxs(_Fragment, { children: [!hideTabs && tabs, _jsx(IconButtonGroup, {})] }))] }) }) }));
68
+ };
69
+ export default AppbarWeb;
70
+ //# sourceMappingURL=AppbarWeb.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppbarWeb.js","sourceRoot":"","sources":["../../../components/navigation/AppbarWeb.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Icons to be rendered inside appbar on both web and mobile
3
+ * @returns Rendered IconButtonGroup
4
+ */
5
+ declare const IconButtonGroup: () => import("react/jsx-runtime").JSX.Element;
6
+ export default IconButtonGroup;
7
+ //# sourceMappingURL=IconButtonGroup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconButtonGroup.d.ts","sourceRoot":"","sources":["../../../components/navigation/IconButtonGroup.tsx"],"names":[],"mappings":"AAMA;;;GAGG;AACH,QAAA,MAAM,eAAe,+CAiBpB,CAAC;AACF,eAAe,eAAe,CAAC"}
@@ -0,0 +1,33 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import { StyleSheet, View } from 'react-native';
4
+ import { ToggleIconButton } from '../ui';
5
+ import { ThemeContext } from '../../theme';
6
+ import { useDimensions } from '../../hooks';
7
+ /**
8
+ * Icons to be rendered inside appbar on both web and mobile
9
+ * @returns Rendered IconButtonGroup
10
+ */
11
+ const IconButtonGroup = () => {
12
+ //Initialize theme toggle
13
+ const { toggleTheme } = useContext(ThemeContext);
14
+ const dimensions = useDimensions();
15
+ return (_jsx(View, { style: {
16
+ ...styles.buttonGroup,
17
+ width: dimensions.breakpoint !== 'small' ? 150 : 'auto',
18
+ justifyContent: 'flex-end',
19
+ }, children: _jsx(View, { style: styles.iconContainer, children: _jsx(ToggleIconButton, { iconName: "sun", alternateIconName: "moon", onPress: toggleTheme }) }) }));
20
+ };
21
+ export default IconButtonGroup;
22
+ const styles = StyleSheet.create({
23
+ buttonGroup: {
24
+ width: 150,
25
+ flexDirection: 'row',
26
+ alignItems: 'center',
27
+ },
28
+ iconContainer: {
29
+ flexDirection: 'row',
30
+ gap: 10,
31
+ },
32
+ });
33
+ //# sourceMappingURL=IconButtonGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconButtonGroup.js","sourceRoot":"","sources":["../../../components/navigation/IconButtonGroup.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C;;;GAGG;AACH,MAAM,eAAe,GAAG,GAAG,EAAE;IAC3B,yBAAyB;IACzB,MAAM,EAAE,WAAW,EAAE,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC;IACjD,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IAEnC,OAAO,CACL,KAAC,IAAI,IACH,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,WAAW;YACrB,KAAK,EAAE,UAAU,CAAC,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;YACvD,cAAc,EAAE,UAAU;SAC3B,YACD,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,aAAa,YAC/B,KAAC,gBAAgB,IAAC,QAAQ,EAAC,KAAK,EAAC,iBAAiB,EAAC,MAAM,EAAC,OAAO,EAAE,WAAW,GAAI,GAC7E,GACF,CACR,CAAC;AACJ,CAAC,CAAC;AACF,eAAe,eAAe,CAAC;AAE/B,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,WAAW,EAAE;QACX,KAAK,EAAE,GAAG;QACV,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,QAAQ;KACrB;IACD,aAAa,EAAE;QACb,aAAa,EAAE,KAAK;QACpB,GAAG,EAAE,EAAE;KACR;CACF,CAAC,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { ImageSourcePropType } from 'react-native';
2
+ type AppBarBrandingProps = {
3
+ /**
4
+ * Optional logo image source. Can be a string URI or ImageSourcePropType (require).
5
+ * If provided, this takes precedence over brand config logos.
6
+ */
7
+ logoUri?: string | ImageSourcePropType;
8
+ };
9
+ /**
10
+ * Appbar with optional Logo for the business
11
+ * Supports URI strings, ImageSourcePropType, or brand config logos
12
+ * Priority: logoUri > brand config > fallback
13
+ */
14
+ declare const Logo: ({ logoUri }: AppBarBrandingProps) => import("react/jsx-runtime").JSX.Element | null;
15
+ export default Logo;
16
+ //# sourceMappingURL=Logo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Logo.d.ts","sourceRoot":"","sources":["../../../components/navigation/Logo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAe,mBAAmB,EAAc,MAAM,cAAc,CAAC;AAO5E,KAAK,mBAAmB,GAAG;IACzB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,GAAG,mBAAmB,CAAC;CACxC,CAAC;AAEF;;;;GAIG;AAEH,QAAA,MAAM,IAAI,GAAI,aAAa,mBAAmB,mDA8C7C,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,64 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { View, Image, StyleSheet } from 'react-native';
4
+ import { Link } from 'expo-router';
5
+ import { useBrand } from '../../brand';
6
+ import { useDimensions } from '../../hooks';
7
+ import { ThemeContext } from '../../theme';
8
+ import { Platform } from 'react-native';
9
+ /**
10
+ * Appbar with optional Logo for the business
11
+ * Supports URI strings, ImageSourcePropType, or brand config logos
12
+ * Priority: logoUri > brand config > fallback
13
+ */
14
+ const Logo = ({ logoUri }) => {
15
+ const dimensions = useDimensions();
16
+ const theme = React.useContext(ThemeContext);
17
+ const brand = useBrand();
18
+ // Determine image source with priority: logoUri > brand config > undefined
19
+ const getImageSource = () => {
20
+ if (logoUri) {
21
+ // If logoUri is provided, use it (supports both string URIs and ImageSourcePropType)
22
+ return typeof logoUri === 'string' ? { uri: logoUri } : logoUri;
23
+ }
24
+ // Fall back to brand config logos
25
+ const brandLogo = theme.values.isDark ? brand.logo.dark : brand.logo.light;
26
+ if (brandLogo) {
27
+ return typeof brandLogo === 'string' ? { uri: brandLogo } : brandLogo;
28
+ }
29
+ // No logo available
30
+ return undefined;
31
+ };
32
+ const imageSource = getImageSource();
33
+ // Don't render if no image source is available
34
+ if (!imageSource) {
35
+ return null;
36
+ }
37
+ return (_jsx(Link, { href: "/", children: _jsx(View, { style: {
38
+ ...styles.container,
39
+ width: dimensions.breakpoint !== 'small' ? 150 : 'auto',
40
+ }, children: _jsx(Image, { source: imageSource, style: [
41
+ styles.logo,
42
+ Platform.OS === 'web' && dimensions.breakpoint === 'small' && styles.logoMobile,
43
+ ] }) }) }));
44
+ };
45
+ export default Logo;
46
+ const styles = StyleSheet.create({
47
+ container: {
48
+ width: 150,
49
+ flexDirection: 'row',
50
+ alignItems: 'center',
51
+ justifyContent: 'flex-start',
52
+ gap: 5,
53
+ },
54
+ logo: {
55
+ marginTop: 12,
56
+ width: 200,
57
+ height: 50,
58
+ },
59
+ logoMobile: {
60
+ width: 150,
61
+ height: 38,
62
+ },
63
+ });
64
+ //# sourceMappingURL=Logo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Logo.js","sourceRoot":"","sources":["../../../components/navigation/Logo.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAE,KAAK,EAAuB,UAAU,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAUxC;;;;GAIG;AAEH,MAAM,IAAI,GAAG,CAAC,EAAE,OAAO,EAAuB,EAAE,EAAE;IAChD,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;IAC7C,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IAEzB,2EAA2E;IAC3E,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,IAAI,OAAO,EAAE,CAAC;YACZ,qFAAqF;YACrF,OAAO,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;QAClE,CAAC;QAED,kCAAkC;QAClC,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;QAC3E,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,OAAO,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;QACxE,CAAC;QAED,oBAAoB;QACpB,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IAErC,+CAA+C;IAC/C,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CACL,KAAC,IAAI,IAAC,IAAI,EAAC,GAAG,YACZ,KAAC,IAAI,IACH,KAAK,EAAE;gBACL,GAAG,MAAM,CAAC,SAAS;gBACnB,KAAK,EAAE,UAAU,CAAC,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM;aACxD,YACD,KAAC,KAAK,IACJ,MAAM,EAAE,WAAW,EACnB,KAAK,EAAE;oBACL,MAAM,CAAC,IAAI;oBACX,QAAQ,CAAC,EAAE,KAAK,KAAK,IAAI,UAAU,CAAC,UAAU,KAAK,OAAO,IAAI,MAAM,CAAC,UAAU;iBAChF,GACD,GACG,GACF,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,SAAS,EAAE;QACT,KAAK,EAAE,GAAG;QACV,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,YAAY;QAC5B,GAAG,EAAE,CAAC;KACP;IACD,IAAI,EAAE;QACJ,SAAS,EAAE,EAAE;QACb,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;KACX;IACD,UAAU,EAAE;QACV,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;KACX;CACF,CAAC,CAAC"}
@@ -0,0 +1,13 @@
1
+ type MobileMenuDrawerProps = {
2
+ currentRoute?: string;
3
+ onNavigate?: (route: string) => void;
4
+ logoUri?: string;
5
+ };
6
+ /**
7
+ * Hamburger menu drawer for mobile web that opens a side drawer
8
+ * Contains navigation links and theme toggle
9
+ * Enhanced with keyboard support, accessibility, and improved animations
10
+ */
11
+ declare const MobileMenuDrawer: ({ currentRoute, onNavigate, logoUri }: MobileMenuDrawerProps) => import("react/jsx-runtime").JSX.Element | null;
12
+ export default MobileMenuDrawer;
13
+ //# sourceMappingURL=MobileMenuDrawer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MobileMenuDrawer.d.ts","sourceRoot":"","sources":["../../../components/navigation/MobileMenuDrawer.tsx"],"names":[],"mappings":"AAWA,KAAK,qBAAqB,GAAG;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF;;;;GAIG;AACH,QAAA,MAAM,gBAAgB,GAAI,uCAAuC,qBAAqB,mDAmRrF,CAAC;AAEF,eAAe,gBAAgB,CAAC"}