@alveole/components 0.20.0 → 0.21.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.
- package/dist/core/A/A.d.ts +16 -0
- package/dist/core/A/A.d.ts.map +1 -0
- package/dist/core/A/A.js +16 -0
- package/dist/core/A/A.stories.d.ts +20 -0
- package/dist/core/A/A.stories.d.ts.map +1 -0
- package/dist/core/A/A.stories.js +13 -0
- package/dist/core/A/A.styles.d.ts +11 -0
- package/dist/core/A/A.styles.d.ts.map +1 -0
- package/dist/core/A/A.styles.js +11 -0
- package/dist/core/A/index.d.ts +2 -0
- package/dist/core/A/index.d.ts.map +1 -0
- package/dist/core/A/index.js +1 -0
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +1 -0
- package/dist/stories/index.d.ts +3 -0
- package/dist/stories/index.d.ts.map +1 -1
- package/dist/stories/index.js +3 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.d.ts +28 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.d.ts.map +1 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.js +42 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.stories.d.ts +45 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.stories.d.ts.map +1 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.stories.js +34 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.styles.d.ts +33 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.styles.d.ts.map +1 -0
- package/dist/ui/Breadcrumbs/Breadcrumbs.styles.js +27 -0
- package/dist/ui/Breadcrumbs/index.d.ts +3 -0
- package/dist/ui/Breadcrumbs/index.d.ts.map +1 -0
- package/dist/ui/Breadcrumbs/index.js +1 -0
- package/dist/ui/LucideIcon/LucideIcon.props.d.ts +2 -2
- package/dist/ui/LucideIcon/LucideIcon.stories.d.ts +1 -1
- package/dist/ui/PageHeader/PageHeader.d.ts +15 -0
- package/dist/ui/PageHeader/PageHeader.d.ts.map +1 -0
- package/dist/ui/PageHeader/PageHeader.js +12 -0
- package/dist/ui/PageHeader/PageHeader.stories.d.ts +39 -0
- package/dist/ui/PageHeader/PageHeader.stories.d.ts.map +1 -0
- package/dist/ui/PageHeader/PageHeader.stories.js +15 -0
- package/dist/ui/PageHeader/PageHeader.styles.d.ts +29 -0
- package/dist/ui/PageHeader/PageHeader.styles.d.ts.map +1 -0
- package/dist/ui/PageHeader/PageHeader.styles.js +26 -0
- package/dist/ui/PageHeader/index.d.ts +3 -0
- package/dist/ui/PageHeader/index.d.ts.map +1 -0
- package/dist/ui/PageHeader/index.js +1 -0
- package/dist/ui/index.d.ts +2 -0
- package/dist/ui/index.d.ts.map +1 -1
- package/dist/ui/index.js +2 -0
- package/package.json +1 -1
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Href } from 'expo-router';
|
|
2
|
+
import React, { CSSProperties } from 'react';
|
|
3
|
+
export type CanAccessHref = (href: Href & string) => boolean;
|
|
4
|
+
/** Contexte optionnel pour fournir la logique d'accès aux liens (ex. droits métier). Non fourni = tous les liens sont cliquables. */
|
|
5
|
+
export declare const LinkAccessContext: React.Context<CanAccessHref | null>;
|
|
6
|
+
export type AProps = React.PropsWithChildren<{
|
|
7
|
+
href: Href & string;
|
|
8
|
+
/** default: "push" */
|
|
9
|
+
direction?: 'push' | 'replace' | 'dismiss';
|
|
10
|
+
style?: CSSProperties;
|
|
11
|
+
hoverStyle?: CSSProperties;
|
|
12
|
+
/** Override la logique d'accès (sinon utilise LinkAccessContext si fourni, sinon accès autorisé). */
|
|
13
|
+
canAccessHref?: CanAccessHref;
|
|
14
|
+
}>;
|
|
15
|
+
export declare const A: (props: AProps) => import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
//# sourceMappingURL=A.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A.d.ts","sourceRoot":"","sources":["../../../src/core/A/A.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAQ,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,EAAE,EAAE,aAAa,EAA6B,MAAM,OAAO,CAAC;AAKxE,MAAM,MAAM,aAAa,GAAG,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,KAAK,OAAO,CAAC;AAE7D,qIAAqI;AACrI,eAAO,MAAM,iBAAiB,qCAA4C,CAAC;AAE3E,MAAM,MAAM,MAAM,GAAG,KAAK,CAAC,iBAAiB,CAAC;IAC3C,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC;IACpB,sBAAsB;IACtB,SAAS,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,CAAC;IAC3C,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,UAAU,CAAC,EAAE,aAAa,CAAC;IAC3B,qGAAqG;IACrG,aAAa,CAAC,EAAE,aAAa,CAAC;CAC/B,CAAC,CAAC;AAEH,eAAO,MAAM,CAAC,GAAI,OAAO,MAAM,4CAwB9B,CAAC"}
|
package/dist/core/A/A.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Link } from 'expo-router';
|
|
3
|
+
import { createContext, useContext } from 'react';
|
|
4
|
+
import { Pressable } from 'react-native';
|
|
5
|
+
import { Box } from '../Box';
|
|
6
|
+
import { useStyles } from './A.styles';
|
|
7
|
+
/** Contexte optionnel pour fournir la logique d'accès aux liens (ex. droits métier). Non fourni = tous les liens sont cliquables. */
|
|
8
|
+
export const LinkAccessContext = createContext(null);
|
|
9
|
+
export const A = (props) => {
|
|
10
|
+
const { children, href, direction = 'push', style, hoverStyle, canAccessHref: canAccessProp } = props;
|
|
11
|
+
const styles = useStyles();
|
|
12
|
+
const canAccessFromContext = useContext(LinkAccessContext);
|
|
13
|
+
const canAccess = canAccessProp ?? canAccessFromContext ?? (() => true);
|
|
14
|
+
const expoLink = (_jsx(Link, { href: href, asChild: true, replace: direction === 'replace', push: direction === 'push', dismissTo: direction === 'dismiss', children: _jsx(Pressable, { children: _jsx(Box, { tag: "a-pressable", style: { ...styles.pressable, ...style }, hoverStyle: hoverStyle, children: children }) }) }));
|
|
15
|
+
return canAccess(href) ? expoLink : _jsx(_Fragment, { children: children });
|
|
16
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
title: string;
|
|
3
|
+
tags: ["Kit"];
|
|
4
|
+
experimental: true;
|
|
5
|
+
description: string;
|
|
6
|
+
component: (props: import("./A").AProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
styleFn: () => {
|
|
8
|
+
container: {};
|
|
9
|
+
pressable: {
|
|
10
|
+
cursor: "pointer";
|
|
11
|
+
color: "inherit";
|
|
12
|
+
transitionProperty: "all";
|
|
13
|
+
transitionDuration: "0.1s";
|
|
14
|
+
transitionTimingFunction: "ease-in-out";
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export default _default;
|
|
19
|
+
export declare const Default: () => import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
//# sourceMappingURL=A.stories.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A.stories.d.ts","sourceRoot":"","sources":["../../../src/core/A/A.stories.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAKA,wBAOkB;AAElB,eAAO,MAAM,OAAO,+CAInB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Typography } from '../Typography';
|
|
3
|
+
import { A } from './A';
|
|
4
|
+
import { useStyles } from './A.styles';
|
|
5
|
+
export default {
|
|
6
|
+
title: 'A',
|
|
7
|
+
tags: ['Kit'],
|
|
8
|
+
experimental: true,
|
|
9
|
+
description: 'Equivalent d’une balise <a>',
|
|
10
|
+
component: A,
|
|
11
|
+
styleFn: useStyles,
|
|
12
|
+
};
|
|
13
|
+
export const Default = () => (_jsx(A, { href: '/ui-kit/components/A', children: _jsx(Typography, { children: "Children" }) }));
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare const useStyles: () => {
|
|
2
|
+
container: {};
|
|
3
|
+
pressable: {
|
|
4
|
+
cursor: "pointer";
|
|
5
|
+
color: "inherit";
|
|
6
|
+
transitionProperty: "all";
|
|
7
|
+
transitionDuration: "0.1s";
|
|
8
|
+
transitionTimingFunction: "ease-in-out";
|
|
9
|
+
};
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=A.styles.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"A.styles.d.ts","sourceRoot":"","sources":["../../../src/core/A/A.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS;;;;;;;;;CASnB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { makeStyles } from '@alveole/theme';
|
|
2
|
+
export const useStyles = makeStyles(() => ({
|
|
3
|
+
container: {},
|
|
4
|
+
pressable: {
|
|
5
|
+
cursor: 'pointer',
|
|
6
|
+
color: 'inherit',
|
|
7
|
+
transitionProperty: 'all',
|
|
8
|
+
transitionDuration: '0.1s',
|
|
9
|
+
transitionTimingFunction: 'ease-in-out',
|
|
10
|
+
},
|
|
11
|
+
}));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/A/index.ts"],"names":[],"mappings":"AAAA,cAAc,KAAK,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './A';
|
package/dist/core/index.d.ts
CHANGED
package/dist/core/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC;AAC3B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,cAAc,KAAK,CAAC;AACpB,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC;AAC3B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC"}
|
package/dist/core/index.js
CHANGED
package/dist/stories/index.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export * as AStory from '../core/A/A.stories';
|
|
1
2
|
export * as BoxStory from '../core/Box/Box.stories';
|
|
2
3
|
export * as ImageStory from '../core/Image/Image.stories';
|
|
3
4
|
export * as MetabaseStory from '../core/Metabase/Metabase.stories';
|
|
@@ -6,12 +7,14 @@ export * as SectionStory from '../core/Section/Section.stories';
|
|
|
6
7
|
export * as TypographyStory from '../core/Typography/Typography.stories';
|
|
7
8
|
export * as VersionStory from '../core/Version/Version.stories';
|
|
8
9
|
export * as AvatarStory from '../ui/Avatar/Avatar.stories';
|
|
10
|
+
export * as BreadcrumbsStory from '../ui/Breadcrumbs/Breadcrumbs.stories';
|
|
9
11
|
export * as ButtonStory from '../ui/Button/Button.stories';
|
|
10
12
|
export * as CardStory from '../ui/Card/Card.stories';
|
|
11
13
|
export * as DividerStory from '../ui/Divider/Divider.stories';
|
|
12
14
|
export * as EmptyStateStory from '../ui/EmptyState/EmptyState.stories';
|
|
13
15
|
export * as ListItemStory from '../ui/ListItem/ListItem.stories';
|
|
14
16
|
export * as LucideIconStory from '../ui/LucideIcon/LucideIcon.stories';
|
|
17
|
+
export * as PageHeaderStory from '../ui/PageHeader/PageHeader.stories';
|
|
15
18
|
export * as ResourceListStory from '../ui/ResourceList/ResourceList.stories';
|
|
16
19
|
export * as ToolbarBottomNavStory from '../ui/ToolbarBottomNav/ToolbarBottomNav.stories';
|
|
17
20
|
export * as ToolbarTopStory from '../ui/ToolbarTop/ToolbarTop.stories';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/stories/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,QAAQ,MAAM,yBAAyB,CAAC;AACpD,OAAO,KAAK,UAAU,MAAM,6BAA6B,CAAC;AAC1D,OAAO,KAAK,aAAa,MAAM,mCAAmC,CAAC;AACnE,OAAO,KAAK,SAAS,MAAM,2BAA2B,CAAC;AACvD,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,eAAe,MAAM,uCAAuC,CAAC;AACzE,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAGhE,OAAO,KAAK,WAAW,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,WAAW,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,SAAS,MAAM,yBAAyB,CAAC;AACrD,OAAO,KAAK,YAAY,MAAM,+BAA+B,CAAC;AAC9D,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC;AACvE,OAAO,KAAK,aAAa,MAAM,iCAAiC,CAAC;AACjE,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC;AACvE,OAAO,KAAK,iBAAiB,MAAM,yCAAyC,CAAC;AAC7E,OAAO,KAAK,qBAAqB,MAAM,iDAAiD,CAAC;AACzF,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/stories/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,qBAAqB,CAAC;AAC9C,OAAO,KAAK,QAAQ,MAAM,yBAAyB,CAAC;AACpD,OAAO,KAAK,UAAU,MAAM,6BAA6B,CAAC;AAC1D,OAAO,KAAK,aAAa,MAAM,mCAAmC,CAAC;AACnE,OAAO,KAAK,SAAS,MAAM,2BAA2B,CAAC;AACvD,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,eAAe,MAAM,uCAAuC,CAAC;AACzE,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAGhE,OAAO,KAAK,WAAW,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,gBAAgB,MAAM,uCAAuC,CAAC;AAC1E,OAAO,KAAK,WAAW,MAAM,6BAA6B,CAAC;AAC3D,OAAO,KAAK,SAAS,MAAM,yBAAyB,CAAC;AACrD,OAAO,KAAK,YAAY,MAAM,+BAA+B,CAAC;AAC9D,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC;AACvE,OAAO,KAAK,aAAa,MAAM,iCAAiC,CAAC;AACjE,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC;AACvE,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC;AACvE,OAAO,KAAK,iBAAiB,MAAM,yCAAyC,CAAC;AAC7E,OAAO,KAAK,qBAAqB,MAAM,iDAAiD,CAAC;AACzF,OAAO,KAAK,eAAe,MAAM,qCAAqC,CAAC"}
|
package/dist/stories/index.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
// Core
|
|
2
|
+
export * as AStory from '../core/A/A.stories';
|
|
2
3
|
export * as BoxStory from '../core/Box/Box.stories';
|
|
3
4
|
export * as ImageStory from '../core/Image/Image.stories';
|
|
4
5
|
export * as MetabaseStory from '../core/Metabase/Metabase.stories';
|
|
@@ -8,12 +9,14 @@ export * as TypographyStory from '../core/Typography/Typography.stories';
|
|
|
8
9
|
export * as VersionStory from '../core/Version/Version.stories';
|
|
9
10
|
// UI
|
|
10
11
|
export * as AvatarStory from '../ui/Avatar/Avatar.stories';
|
|
12
|
+
export * as BreadcrumbsStory from '../ui/Breadcrumbs/Breadcrumbs.stories';
|
|
11
13
|
export * as ButtonStory from '../ui/Button/Button.stories';
|
|
12
14
|
export * as CardStory from '../ui/Card/Card.stories';
|
|
13
15
|
export * as DividerStory from '../ui/Divider/Divider.stories';
|
|
14
16
|
export * as EmptyStateStory from '../ui/EmptyState/EmptyState.stories';
|
|
15
17
|
export * as ListItemStory from '../ui/ListItem/ListItem.stories';
|
|
16
18
|
export * as LucideIconStory from '../ui/LucideIcon/LucideIcon.stories';
|
|
19
|
+
export * as PageHeaderStory from '../ui/PageHeader/PageHeader.stories';
|
|
17
20
|
export * as ResourceListStory from '../ui/ResourceList/ResourceList.stories';
|
|
18
21
|
export * as ToolbarBottomNavStory from '../ui/ToolbarBottomNav/ToolbarBottomNav.stories';
|
|
19
22
|
export * as ToolbarTopStory from '../ui/ToolbarTop/ToolbarTop.stories';
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export type BreadcrumbItem = {
|
|
3
|
+
label: string;
|
|
4
|
+
href: string;
|
|
5
|
+
isCurrent: boolean;
|
|
6
|
+
};
|
|
7
|
+
export type BreadcrumbsProps = React.PropsWithChildren<{
|
|
8
|
+
/** Label du premier élément (lien vers la racine). Défaut : "Accueil" */
|
|
9
|
+
rootLabel?: string;
|
|
10
|
+
/**
|
|
11
|
+
* Segments à ne pas afficher dans le fil d'Ariane (ex. ["admin"] pour avoir Accueil > Missions au lieu de Accueil > Admin > Missions).
|
|
12
|
+
*/
|
|
13
|
+
segmentsToSkip?: string[];
|
|
14
|
+
/**
|
|
15
|
+
* Personnalisation du libellé pour un segment.
|
|
16
|
+
* Par défaut : capitalisation + remplacement des - et _ par des espaces.
|
|
17
|
+
*/
|
|
18
|
+
getLabel?: (segment: string, index: number, path: string) => string;
|
|
19
|
+
}>;
|
|
20
|
+
/**
|
|
21
|
+
* Fil d'Ariane construit à partir de la navigation Expo Router.
|
|
22
|
+
* Tous les éléments sauf le dernier (page en cours) sont cliquables.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* Accueil > Admin > Missions > Détail
|
|
26
|
+
*/
|
|
27
|
+
export declare const Breadcrumbs: (props: BreadcrumbsProps) => import("react/jsx-runtime").JSX.Element;
|
|
28
|
+
//# sourceMappingURL=Breadcrumbs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumbs.d.ts","sourceRoot":"","sources":["../../../src/ui/Breadcrumbs/Breadcrumbs.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,OAAO,CAAC;CACpB,CAAC;AAQF,MAAM,MAAM,gBAAgB,GAAG,KAAK,CAAC,iBAAiB,CAAC;IACrD,yEAAyE;IACzE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B;;;OAGG;IACH,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;CACrE,CAAC,CAAC;AAEH;;;;;;GAMG;AACH,eAAO,MAAM,WAAW,GAAI,OAAO,gBAAgB,4CAoDlD,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { usePathname } from 'expo-router';
|
|
3
|
+
import { A, Box, Typography } from '../../core';
|
|
4
|
+
import { useStyles } from './Breadcrumbs.styles';
|
|
5
|
+
function humanizeSegment(segment) {
|
|
6
|
+
return segment
|
|
7
|
+
.replace(/[-_]/g, ' ')
|
|
8
|
+
.replace(/^\w/, (c) => c.toUpperCase());
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Fil d'Ariane construit à partir de la navigation Expo Router.
|
|
12
|
+
* Tous les éléments sauf le dernier (page en cours) sont cliquables.
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* Accueil > Admin > Missions > Détail
|
|
16
|
+
*/
|
|
17
|
+
export const Breadcrumbs = (props) => {
|
|
18
|
+
const { rootLabel = 'Accueil', segmentsToSkip, getLabel = (segment) => humanizeSegment(segment), } = props;
|
|
19
|
+
const pathname = usePathname();
|
|
20
|
+
const styles = useStyles();
|
|
21
|
+
const segments = pathname.split('/').filter(Boolean);
|
|
22
|
+
const segmentItems = segments
|
|
23
|
+
.map((segment, index) => ({
|
|
24
|
+
segment,
|
|
25
|
+
index,
|
|
26
|
+
path: '/' + segments.slice(0, index + 1).join('/'),
|
|
27
|
+
}))
|
|
28
|
+
.filter(({ segment }) => !segmentsToSkip?.includes(segment));
|
|
29
|
+
const items = [
|
|
30
|
+
{
|
|
31
|
+
label: rootLabel,
|
|
32
|
+
href: '/',
|
|
33
|
+
isCurrent: segments.length === 0,
|
|
34
|
+
},
|
|
35
|
+
...segmentItems.map(({ segment, index, path }) => ({
|
|
36
|
+
label: getLabel(segment, index, path),
|
|
37
|
+
href: path,
|
|
38
|
+
isCurrent: index === segments.length - 1,
|
|
39
|
+
})),
|
|
40
|
+
];
|
|
41
|
+
return (_jsx(Box, { style: styles.container, children: items.map((item, index) => (_jsxs(Box, { style: { flexDirection: 'row', alignItems: 'center' }, children: [index > 0 && (_jsx(Typography, { style: styles.separator, children: " > " })), item.isCurrent ? (_jsx(Typography, { style: styles.current, children: item.label })) : (_jsx(A, { href: item.href, style: styles.link, hoverStyle: styles.linkHover, children: item.label }))] }, `${item.href}-${index}`))) }));
|
|
42
|
+
};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
title: string;
|
|
3
|
+
tags: ["Kit"];
|
|
4
|
+
experimental: false;
|
|
5
|
+
description: string;
|
|
6
|
+
component: (props: import("./Breadcrumbs").BreadcrumbsProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
styleFn: () => {
|
|
8
|
+
container: {
|
|
9
|
+
fontFamily: "Barlow-Light" | "Barlow-Regular" | "Barlow-Medium" | "Barlow-SemiBold" | "Barlow-Bold" | "Inter-Light" | "Inter-Regular" | "Inter-Medium" | "Inter-SemiBold" | "Inter-Bold";
|
|
10
|
+
fontSize: 12;
|
|
11
|
+
lineHeight: 20;
|
|
12
|
+
letterSpacing: 0;
|
|
13
|
+
flexDirection: "row";
|
|
14
|
+
flexWrap: "wrap";
|
|
15
|
+
alignItems: "center";
|
|
16
|
+
gap: import("@alveole/theme").Spacing;
|
|
17
|
+
};
|
|
18
|
+
separator: {
|
|
19
|
+
color: "#5F6571";
|
|
20
|
+
};
|
|
21
|
+
current: {
|
|
22
|
+
color: "#151617";
|
|
23
|
+
};
|
|
24
|
+
link: {
|
|
25
|
+
transitionProperty: "text-decoration";
|
|
26
|
+
transitionDuration: "0.1s";
|
|
27
|
+
transitionTimingFunction: "ease-in-out";
|
|
28
|
+
fontFamily: "Barlow-Light" | "Barlow-Regular" | "Barlow-Medium" | "Barlow-SemiBold" | "Barlow-Bold" | "Inter-Light" | "Inter-Regular" | "Inter-Medium" | "Inter-SemiBold" | "Inter-Bold";
|
|
29
|
+
fontSize: 12;
|
|
30
|
+
lineHeight: 20;
|
|
31
|
+
letterSpacing: 0;
|
|
32
|
+
color: "#5F6571";
|
|
33
|
+
textDecoration: string;
|
|
34
|
+
};
|
|
35
|
+
linkHover: {
|
|
36
|
+
textDecoration: string;
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
export default _default;
|
|
41
|
+
export declare const Default: () => import("react/jsx-runtime").JSX.Element;
|
|
42
|
+
export declare const WithCustomRootLabel: () => import("react/jsx-runtime").JSX.Element;
|
|
43
|
+
export declare const WithCustomLabels: () => import("react/jsx-runtime").JSX.Element;
|
|
44
|
+
export declare const WithSegmentsToSkip: () => import("react/jsx-runtime").JSX.Element;
|
|
45
|
+
//# sourceMappingURL=Breadcrumbs.stories.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumbs.stories.d.ts","sourceRoot":"","sources":["../../../src/ui/Breadcrumbs/Breadcrumbs.stories.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,wBAQkB;AAElB,eAAO,MAAM,OAAO,+CAInB,CAAC;AAEF,eAAO,MAAM,mBAAmB,+CAI/B,CAAC;AAEF,eAAO,MAAM,gBAAgB,+CAe5B,CAAC;AAEF,eAAO,MAAM,kBAAkB,+CAgB9B,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Box } from '../../core';
|
|
3
|
+
import { Breadcrumbs } from './Breadcrumbs';
|
|
4
|
+
import { useStyles } from './Breadcrumbs.styles';
|
|
5
|
+
export default {
|
|
6
|
+
title: 'Breadcrumbs',
|
|
7
|
+
tags: ['Kit'],
|
|
8
|
+
experimental: false,
|
|
9
|
+
description: "Fil d'Ariane construit à partir de la navigation Expo Router. Tous les éléments sauf le dernier (page en cours) sont cliquables.",
|
|
10
|
+
component: Breadcrumbs,
|
|
11
|
+
styleFn: useStyles,
|
|
12
|
+
};
|
|
13
|
+
export const Default = () => (_jsx(Box, { p: 4, children: _jsx(Breadcrumbs, {}) }));
|
|
14
|
+
export const WithCustomRootLabel = () => (_jsx(Box, { p: 4, children: _jsx(Breadcrumbs, { rootLabel: "Tableau de bord" }) }));
|
|
15
|
+
export const WithCustomLabels = () => (_jsx(Box, { p: 4, children: _jsx(Breadcrumbs, { getLabel: (segment, _index, _path) => {
|
|
16
|
+
const labels = {
|
|
17
|
+
admin: 'Administration',
|
|
18
|
+
missions: 'Missions',
|
|
19
|
+
show: 'Détail',
|
|
20
|
+
salarie: 'Espace salarié',
|
|
21
|
+
client: 'Espace client',
|
|
22
|
+
};
|
|
23
|
+
return labels[segment] ?? segment;
|
|
24
|
+
} }) }));
|
|
25
|
+
export const WithSegmentsToSkip = () => (_jsx(Box, { p: 4, children: _jsx(Breadcrumbs, { segmentsToSkip: ['admin', 'ui-kit'], getLabel: (segment, _index, _path) => {
|
|
26
|
+
const labels = {
|
|
27
|
+
admin: 'Administration',
|
|
28
|
+
missions: 'Missions',
|
|
29
|
+
show: 'Détail',
|
|
30
|
+
salarie: 'Espace salarié',
|
|
31
|
+
client: 'Espace client',
|
|
32
|
+
};
|
|
33
|
+
return labels[segment] ?? segment;
|
|
34
|
+
} }) }));
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export declare const useStyles: () => {
|
|
2
|
+
container: {
|
|
3
|
+
fontFamily: "Barlow-Light" | "Barlow-Regular" | "Barlow-Medium" | "Barlow-SemiBold" | "Barlow-Bold" | "Inter-Light" | "Inter-Regular" | "Inter-Medium" | "Inter-SemiBold" | "Inter-Bold";
|
|
4
|
+
fontSize: 12;
|
|
5
|
+
lineHeight: 20;
|
|
6
|
+
letterSpacing: 0;
|
|
7
|
+
flexDirection: "row";
|
|
8
|
+
flexWrap: "wrap";
|
|
9
|
+
alignItems: "center";
|
|
10
|
+
gap: import("@alveole/theme").Spacing;
|
|
11
|
+
};
|
|
12
|
+
separator: {
|
|
13
|
+
color: "#5F6571";
|
|
14
|
+
};
|
|
15
|
+
current: {
|
|
16
|
+
color: "#151617";
|
|
17
|
+
};
|
|
18
|
+
link: {
|
|
19
|
+
transitionProperty: "text-decoration";
|
|
20
|
+
transitionDuration: "0.1s";
|
|
21
|
+
transitionTimingFunction: "ease-in-out";
|
|
22
|
+
fontFamily: "Barlow-Light" | "Barlow-Regular" | "Barlow-Medium" | "Barlow-SemiBold" | "Barlow-Bold" | "Inter-Light" | "Inter-Regular" | "Inter-Medium" | "Inter-SemiBold" | "Inter-Bold";
|
|
23
|
+
fontSize: 12;
|
|
24
|
+
lineHeight: 20;
|
|
25
|
+
letterSpacing: 0;
|
|
26
|
+
color: "#5F6571";
|
|
27
|
+
textDecoration: string;
|
|
28
|
+
};
|
|
29
|
+
linkHover: {
|
|
30
|
+
textDecoration: string;
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=Breadcrumbs.styles.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Breadcrumbs.styles.d.ts","sourceRoot":"","sources":["../../../src/ui/Breadcrumbs/Breadcrumbs.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyBnB,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { makeStyles } from '@alveole/theme';
|
|
2
|
+
export const useStyles = makeStyles(({ text, color, spacing }) => ({
|
|
3
|
+
container: {
|
|
4
|
+
flexDirection: 'row',
|
|
5
|
+
flexWrap: 'wrap',
|
|
6
|
+
alignItems: 'center',
|
|
7
|
+
gap: spacing('1V'),
|
|
8
|
+
...text['Corps de texte'].XS.Regular,
|
|
9
|
+
},
|
|
10
|
+
separator: {
|
|
11
|
+
color: color.light.text['mention-grey'],
|
|
12
|
+
},
|
|
13
|
+
current: {
|
|
14
|
+
color: color.light.text['active-grey'],
|
|
15
|
+
},
|
|
16
|
+
link: {
|
|
17
|
+
color: color.light.text['mention-grey'],
|
|
18
|
+
textDecoration: 'underline',
|
|
19
|
+
...text['Corps de texte'].XS.Regular,
|
|
20
|
+
transitionProperty: 'text-decoration',
|
|
21
|
+
transitionDuration: '0.1s',
|
|
22
|
+
transitionTimingFunction: 'ease-in-out',
|
|
23
|
+
},
|
|
24
|
+
linkHover: {
|
|
25
|
+
textDecoration: 'none',
|
|
26
|
+
},
|
|
27
|
+
}));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ui/Breadcrumbs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,YAAY,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { Breadcrumbs } from './Breadcrumbs';
|
|
@@ -19,8 +19,8 @@ declare const PublicPropsSchema: z.ZodObject<{
|
|
|
19
19
|
tab: "tab";
|
|
20
20
|
olive: "olive";
|
|
21
21
|
Menu: "Menu";
|
|
22
|
-
Image: "Image";
|
|
23
22
|
toolbox: "toolbox";
|
|
23
|
+
Image: "Image";
|
|
24
24
|
AArrowDown: "AArrowDown";
|
|
25
25
|
AArrowUp: "AArrowUp";
|
|
26
26
|
ALargeSmall: "ALargeSmall";
|
|
@@ -2126,8 +2126,8 @@ export declare const LucideIconPropsJSON: z.core.ZodStandardJSONSchemaPayload<z.
|
|
|
2126
2126
|
tab: "tab";
|
|
2127
2127
|
olive: "olive";
|
|
2128
2128
|
Menu: "Menu";
|
|
2129
|
-
Image: "Image";
|
|
2130
2129
|
toolbox: "toolbox";
|
|
2130
|
+
Image: "Image";
|
|
2131
2131
|
AArrowDown: "AArrowDown";
|
|
2132
2132
|
AArrowUp: "AArrowUp";
|
|
2133
2133
|
ALargeSmall: "ALargeSmall";
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Breadcrumbs } from '../Breadcrumbs';
|
|
3
|
+
export type PageHeaderProps = React.PropsWithChildren<{
|
|
4
|
+
/** Titre de la page (à gauche). Peut être une chaîne ou un contenu personnalisé. */
|
|
5
|
+
title: string;
|
|
6
|
+
/** Contenu affiché à droite (boutons, liens, etc.). */
|
|
7
|
+
actions?: React.ReactNode;
|
|
8
|
+
/** Props passées au Breadcrumbs (rootLabel, getLabel). */
|
|
9
|
+
breadcrumbsProps?: React.ComponentProps<typeof Breadcrumbs>;
|
|
10
|
+
}>;
|
|
11
|
+
/**
|
|
12
|
+
* En-tête de page : fil d'Ariane, puis une ligne avec le titre à gauche et des actions à droite.
|
|
13
|
+
*/
|
|
14
|
+
export declare const PageHeader: (props: PageHeaderProps) => import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
//# sourceMappingURL=PageHeader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PageHeader.d.ts","sourceRoot":"","sources":["../../../src/ui/PageHeader/PageHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7C,MAAM,MAAM,eAAe,GAAG,KAAK,CAAC,iBAAiB,CAAC;IACpD,oFAAoF;IACpF,KAAK,EAAE,MAAM,CAAC;IACd,uDAAuD;IACvD,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,0DAA0D;IAC1D,gBAAgB,CAAC,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,WAAW,CAAC,CAAC;CAC7D,CAAC,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,UAAU,GAAI,OAAO,eAAe,4CAahD,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Box, Typography } from '../../core';
|
|
3
|
+
import { Breadcrumbs } from '../Breadcrumbs';
|
|
4
|
+
import { useStyles } from './PageHeader.styles';
|
|
5
|
+
/**
|
|
6
|
+
* En-tête de page : fil d'Ariane, puis une ligne avec le titre à gauche et des actions à droite.
|
|
7
|
+
*/
|
|
8
|
+
export const PageHeader = (props) => {
|
|
9
|
+
const { title, actions, breadcrumbsProps } = props;
|
|
10
|
+
const styles = useStyles();
|
|
11
|
+
return (_jsxs(Box, { style: styles.container, children: [_jsx(Breadcrumbs, { ...breadcrumbsProps }), _jsxs(Box, { style: styles.row, children: [_jsx(Typography, { style: styles.title, children: title }), actions && _jsx(Box, { style: styles.actions, children: actions })] })] }));
|
|
12
|
+
};
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
title: string;
|
|
3
|
+
tags: ["Kit"];
|
|
4
|
+
experimental: false;
|
|
5
|
+
description: string;
|
|
6
|
+
component: (props: import("./PageHeader").PageHeaderProps) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
styleFn: () => {
|
|
8
|
+
container: {
|
|
9
|
+
display: "flex";
|
|
10
|
+
flexDirection: "column";
|
|
11
|
+
gap: import("@alveole/theme").Spacing;
|
|
12
|
+
};
|
|
13
|
+
row: {
|
|
14
|
+
display: "flex";
|
|
15
|
+
flexDirection: "row";
|
|
16
|
+
justifyContent: "space-between";
|
|
17
|
+
alignItems: "center";
|
|
18
|
+
gap: import("@alveole/theme").Spacing;
|
|
19
|
+
};
|
|
20
|
+
title: {
|
|
21
|
+
color: "#151617";
|
|
22
|
+
fontFamily: "Barlow-Light" | "Barlow-Regular" | "Barlow-Medium" | "Barlow-SemiBold" | "Barlow-Bold" | "Inter-Light" | "Inter-Regular" | "Inter-Medium" | "Inter-SemiBold" | "Inter-Bold";
|
|
23
|
+
fontSize: 28 | 32;
|
|
24
|
+
lineHeight: 36 | 32;
|
|
25
|
+
letterSpacing: 0;
|
|
26
|
+
};
|
|
27
|
+
actions: {
|
|
28
|
+
display: "flex";
|
|
29
|
+
flexDirection: "row";
|
|
30
|
+
alignItems: "center";
|
|
31
|
+
gap: import("@alveole/theme").Spacing;
|
|
32
|
+
flexShrink: number;
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
export default _default;
|
|
37
|
+
export declare const Default: () => import("react/jsx-runtime").JSX.Element;
|
|
38
|
+
export declare const WithActions: () => import("react/jsx-runtime").JSX.Element;
|
|
39
|
+
//# sourceMappingURL=PageHeader.stories.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PageHeader.stories.d.ts","sourceRoot":"","sources":["../../../src/ui/PageHeader/PageHeader.stories.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,wBAOkB;AAElB,eAAO,MAAM,OAAO,+CAInB,CAAC;AAEF,eAAO,MAAM,WAAW,+CAWvB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Box } from '../../core';
|
|
3
|
+
import { Button } from '../Button';
|
|
4
|
+
import { PageHeader } from './PageHeader';
|
|
5
|
+
import { useStyles } from './PageHeader.styles';
|
|
6
|
+
export default {
|
|
7
|
+
title: 'PageHeader',
|
|
8
|
+
tags: ['Kit'],
|
|
9
|
+
experimental: false,
|
|
10
|
+
description: 'En-tête de page : fil d’Ariane, puis titre à gauche et actions à droite.',
|
|
11
|
+
component: PageHeader,
|
|
12
|
+
styleFn: useStyles,
|
|
13
|
+
};
|
|
14
|
+
export const Default = () => (_jsx(Box, { p: 4, children: _jsx(PageHeader, { title: "Titre de la page" }) }));
|
|
15
|
+
export const WithActions = () => (_jsx(Box, { p: 4, children: _jsx(PageHeader, { title: "D\u00E9tail de la mission", actions: _jsx(_Fragment, { children: _jsx(Button, { variant: "primary", title: "Enregistrer", size: "sm", onPress: () => { } }) }) }) }));
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export declare const useStyles: () => {
|
|
2
|
+
container: {
|
|
3
|
+
display: "flex";
|
|
4
|
+
flexDirection: "column";
|
|
5
|
+
gap: import("@alveole/theme").Spacing;
|
|
6
|
+
};
|
|
7
|
+
row: {
|
|
8
|
+
display: "flex";
|
|
9
|
+
flexDirection: "row";
|
|
10
|
+
justifyContent: "space-between";
|
|
11
|
+
alignItems: "center";
|
|
12
|
+
gap: import("@alveole/theme").Spacing;
|
|
13
|
+
};
|
|
14
|
+
title: {
|
|
15
|
+
color: "#151617";
|
|
16
|
+
fontFamily: "Barlow-Light" | "Barlow-Regular" | "Barlow-Medium" | "Barlow-SemiBold" | "Barlow-Bold" | "Inter-Light" | "Inter-Regular" | "Inter-Medium" | "Inter-SemiBold" | "Inter-Bold";
|
|
17
|
+
fontSize: 28 | 32;
|
|
18
|
+
lineHeight: 36 | 32;
|
|
19
|
+
letterSpacing: 0;
|
|
20
|
+
};
|
|
21
|
+
actions: {
|
|
22
|
+
display: "flex";
|
|
23
|
+
flexDirection: "row";
|
|
24
|
+
alignItems: "center";
|
|
25
|
+
gap: import("@alveole/theme").Spacing;
|
|
26
|
+
flexShrink: number;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=PageHeader.styles.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PageHeader.styles.d.ts","sourceRoot":"","sources":["../../../src/ui/PageHeader/PageHeader.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwBnB,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { makeStyles } from '@alveole/theme';
|
|
2
|
+
export const useStyles = makeStyles(({ color, text, spacing }) => ({
|
|
3
|
+
container: {
|
|
4
|
+
display: 'flex',
|
|
5
|
+
flexDirection: 'column',
|
|
6
|
+
gap: spacing('1W'),
|
|
7
|
+
},
|
|
8
|
+
row: {
|
|
9
|
+
display: 'flex',
|
|
10
|
+
flexDirection: 'row',
|
|
11
|
+
justifyContent: 'space-between',
|
|
12
|
+
alignItems: 'center',
|
|
13
|
+
gap: spacing('1V'),
|
|
14
|
+
},
|
|
15
|
+
title: {
|
|
16
|
+
...text.Titres['H2 - LG'],
|
|
17
|
+
color: color.light.text['title-grey'],
|
|
18
|
+
},
|
|
19
|
+
actions: {
|
|
20
|
+
display: 'flex',
|
|
21
|
+
flexDirection: 'row',
|
|
22
|
+
alignItems: 'center',
|
|
23
|
+
gap: spacing('050'),
|
|
24
|
+
flexShrink: 0,
|
|
25
|
+
},
|
|
26
|
+
}));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ui/PageHeader/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,YAAY,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { PageHeader } from './PageHeader';
|
package/dist/ui/index.d.ts
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
export * from './Avatar';
|
|
2
|
+
export * from './Breadcrumbs';
|
|
2
3
|
export * from './Button';
|
|
3
4
|
export * from './Card';
|
|
4
5
|
export * from './Divider';
|
|
5
6
|
export * from './EmptyState';
|
|
6
7
|
export * from './ListItem';
|
|
7
8
|
export * from './LucideIcon';
|
|
9
|
+
export * from './PageHeader';
|
|
8
10
|
export * from './ResourceList';
|
|
9
11
|
export * from './ToolbarBottomNav';
|
|
10
12
|
export * from './ToolbarTop';
|
package/dist/ui/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,eAAe,CAAC;AAC9B,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC"}
|
package/dist/ui/index.js
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
export * from './Avatar';
|
|
2
|
+
export * from './Breadcrumbs';
|
|
2
3
|
export * from './Button';
|
|
3
4
|
export * from './Card';
|
|
4
5
|
export * from './Divider';
|
|
5
6
|
export * from './EmptyState';
|
|
6
7
|
export * from './ListItem';
|
|
7
8
|
export * from './LucideIcon';
|
|
9
|
+
export * from './PageHeader';
|
|
8
10
|
export * from './ResourceList';
|
|
9
11
|
export * from './ToolbarBottomNav';
|
|
10
12
|
export * from './ToolbarTop';
|