@pautena/react-design-system 0.0.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.js +28 -28
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/types/components/app-bar/app-bar.types.d.ts +2 -1
- package/dist/cjs/types/components/content/content.d.ts +2 -0
- package/dist/cjs/types/components/content/content.types.d.ts +4 -0
- package/dist/cjs/types/components/content/index.d.ts +2 -0
- package/dist/cjs/types/components/header/header.d.ts +2 -61
- package/dist/cjs/types/components/header/header.types.d.ts +55 -0
- package/dist/cjs/types/components/header/index.d.ts +1 -0
- package/dist/cjs/types/components/index.d.ts +1 -0
- package/dist/cjs/types/components/tab/index.d.ts +0 -1
- package/dist/cjs/types/components/tab/tab-card/tab-card.d.ts +1 -2
- package/dist/cjs/types/components/table-list/table-list.d.ts +4 -7
- package/dist/cjs/types/generators/generators.mock.d.ts +22 -1
- package/dist/cjs/types/generators/generators.model.d.ts +5 -1
- package/dist/cjs/types/generators/model-form/model-form.d.ts +5 -5
- package/dist/cjs/types/generators/model-router/model-router.d.ts +4 -35
- package/dist/cjs/types/generators/model-router/model-router.types.d.ts +8 -0
- package/dist/cjs/types/generators/model-router/screens/add-screen.d.ts +16 -2
- package/dist/cjs/types/generators/model-router/screens/details-screen.d.ts +20 -2
- package/dist/cjs/types/generators/model-router/screens/list-screen.d.ts +30 -2
- package/dist/cjs/types/generators/model-router/screens/screens.types.d.ts +11 -0
- package/dist/cjs/types/generators/model-router/screens/update-screen.d.ts +29 -2
- package/dist/cjs/types/generators/model-router/stories/templates.d.ts +23 -0
- package/dist/cjs/types/generators/object-details/object-details.d.ts +4 -4
- package/dist/cjs/types/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.d.ts +5 -8
- package/dist/cjs/types/layouts/header-layout/header-layout.d.ts +4 -5
- package/dist/cjs/types/layouts/index.d.ts +1 -6
- package/dist/cjs/types/providers/index.d.ts +1 -0
- package/dist/cjs/types/providers/notification-center/index.d.ts +1 -0
- package/dist/cjs/types/providers/tab-provider/index.d.ts +2 -0
- package/dist/cjs/types/providers/tab-provider/tab-provider.context.d.ts +4 -0
- package/dist/cjs/types/providers/tab-provider/tab-provider.provider.d.ts +6 -0
- package/dist/cjs/types/utils/theme.d.ts +7 -4
- package/dist/esm/index.js +28 -28
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types/components/app-bar/app-bar.types.d.ts +2 -1
- package/dist/esm/types/components/content/content.d.ts +2 -0
- package/dist/esm/types/components/content/content.types.d.ts +4 -0
- package/dist/esm/types/components/content/index.d.ts +2 -0
- package/dist/esm/types/components/header/header.d.ts +2 -61
- package/dist/esm/types/components/header/header.types.d.ts +55 -0
- package/dist/esm/types/components/header/index.d.ts +1 -0
- package/dist/esm/types/components/index.d.ts +1 -0
- package/dist/esm/types/components/tab/index.d.ts +0 -1
- package/dist/esm/types/components/tab/tab-card/tab-card.d.ts +1 -2
- package/dist/esm/types/components/table-list/table-list.d.ts +4 -7
- package/dist/esm/types/generators/generators.mock.d.ts +22 -1
- package/dist/esm/types/generators/generators.model.d.ts +5 -1
- package/dist/esm/types/generators/model-form/model-form.d.ts +5 -5
- package/dist/esm/types/generators/model-router/model-router.d.ts +4 -35
- package/dist/esm/types/generators/model-router/model-router.types.d.ts +8 -0
- package/dist/esm/types/generators/model-router/screens/add-screen.d.ts +16 -2
- package/dist/esm/types/generators/model-router/screens/details-screen.d.ts +20 -2
- package/dist/esm/types/generators/model-router/screens/list-screen.d.ts +30 -2
- package/dist/esm/types/generators/model-router/screens/screens.types.d.ts +11 -0
- package/dist/esm/types/generators/model-router/screens/update-screen.d.ts +29 -2
- package/dist/esm/types/generators/model-router/stories/templates.d.ts +23 -0
- package/dist/esm/types/generators/object-details/object-details.d.ts +4 -4
- package/dist/esm/types/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.d.ts +5 -8
- package/dist/esm/types/layouts/header-layout/header-layout.d.ts +4 -5
- package/dist/esm/types/layouts/index.d.ts +1 -6
- package/dist/esm/types/providers/index.d.ts +1 -0
- package/dist/esm/types/providers/notification-center/index.d.ts +1 -0
- package/dist/esm/types/providers/tab-provider/index.d.ts +2 -0
- package/dist/esm/types/providers/tab-provider/tab-provider.context.d.ts +4 -0
- package/dist/esm/types/providers/tab-provider/tab-provider.provider.d.ts +6 -0
- package/dist/esm/types/utils/theme.d.ts +7 -4
- package/dist/index.d.ts +146 -122
- package/package.json +4 -1
- package/.eslintrc.js +0 -26
- package/.github/workflows/ci.yml +0 -23
- package/.github/workflows/deploy-storybook.yaml +0 -23
- package/.github/workflows/publish.yml +0 -31
- package/.husky/pre-commit +0 -5
- package/.prettierignore +0 -4
- package/.storybook/main.js +0 -10
- package/.storybook/preview.js +0 -36
- package/babel.config.js +0 -3
- package/dist/cjs/types/components/tab/tab.context.d.ts +0 -4
- package/dist/cjs/types/layouts/data-table-layout/data-table-layout.d.ts +0 -12
- package/dist/cjs/types/layouts/data-table-layout/index.d.ts +0 -1
- package/dist/cjs/types/layouts/details-layout/details-layout.d.ts +0 -12
- package/dist/cjs/types/layouts/details-layout/index.d.ts +0 -1
- package/dist/cjs/types/layouts/form-layout/form-layout.d.ts +0 -8
- package/dist/cjs/types/layouts/form-layout/index.d.ts +0 -1
- package/dist/cjs/types/layouts/list-layout/index.d.ts +0 -1
- package/dist/cjs/types/layouts/list-layout/list-layout.d.ts +0 -8
- package/dist/cjs/types/layouts/tab-layout/index.d.ts +0 -1
- package/dist/cjs/types/layouts/tab-layout/tab-layout.d.ts +0 -7
- package/dist/esm/types/components/tab/tab.context.d.ts +0 -4
- package/dist/esm/types/layouts/data-table-layout/data-table-layout.d.ts +0 -12
- package/dist/esm/types/layouts/data-table-layout/index.d.ts +0 -1
- package/dist/esm/types/layouts/details-layout/details-layout.d.ts +0 -12
- package/dist/esm/types/layouts/details-layout/index.d.ts +0 -1
- package/dist/esm/types/layouts/form-layout/form-layout.d.ts +0 -8
- package/dist/esm/types/layouts/form-layout/index.d.ts +0 -1
- package/dist/esm/types/layouts/list-layout/index.d.ts +0 -1
- package/dist/esm/types/layouts/list-layout/list-layout.d.ts +0 -8
- package/dist/esm/types/layouts/tab-layout/index.d.ts +0 -1
- package/dist/esm/types/layouts/tab-layout/tab-layout.d.ts +0 -7
- package/jest.config.js +0 -14
- package/jest.setup.ts +0 -5
- package/rollup.config.js +0 -40
- package/src/components/app-bar/app-bar.stories.tsx +0 -54
- package/src/components/app-bar/app-bar.test.tsx +0 -142
- package/src/components/app-bar/app-bar.tsx +0 -150
- package/src/components/app-bar/app-bar.types.ts +0 -16
- package/src/components/app-bar/index.ts +0 -3
- package/src/components/app-bar/mini-app-bar/index.ts +0 -1
- package/src/components/app-bar/mini-app-bar/mini-app-bar.tsx +0 -31
- package/src/components/bullet/bullet.stories.tsx +0 -43
- package/src/components/bullet/bullet.test.tsx +0 -24
- package/src/components/bullet/bullet.tsx +0 -30
- package/src/components/bullet/index.ts +0 -1
- package/src/components/center-container/center-container.stories.tsx +0 -50
- package/src/components/center-container/center-container.test.tsx +0 -16
- package/src/components/center-container/center-container.tsx +0 -32
- package/src/components/center-container/index.ts +0 -1
- package/src/components/drawer/__snapshots__/drawer.test.tsx.snap +0 -20
- package/src/components/drawer/drawer.context.ts +0 -20
- package/src/components/drawer/drawer.mixins.ts +0 -24
- package/src/components/drawer/drawer.mock.tsx +0 -100
- package/src/components/drawer/drawer.provider.tsx +0 -23
- package/src/components/drawer/drawer.test.tsx +0 -97
- package/src/components/drawer/drawer.tsx +0 -30
- package/src/components/drawer/drawer.types.ts +0 -53
- package/src/components/drawer/index.ts +0 -5
- package/src/components/drawer/mini-drawer/index.ts +0 -1
- package/src/components/drawer/mini-drawer/mini-drawer.stories.tsx +0 -34
- package/src/components/drawer/mini-drawer/mini-drawer.tsx +0 -67
- package/src/components/drawer-content/drawer-content.stories.tsx +0 -29
- package/src/components/drawer-content/drawer-content.test.tsx +0 -34
- package/src/components/drawer-content/drawer-content.tsx +0 -18
- package/src/components/drawer-content/index.ts +0 -1
- package/src/components/drawer-item/drawer-item.stories.tsx +0 -62
- package/src/components/drawer-item/drawer-item.test.tsx +0 -119
- package/src/components/drawer-item/drawer-item.tsx +0 -69
- package/src/components/drawer-item/index.ts +0 -1
- package/src/components/drawer-section/drawer-section.mock.tsx +0 -39
- package/src/components/drawer-section/drawer-section.stories.tsx +0 -28
- package/src/components/drawer-section/drawer-section.test.tsx +0 -44
- package/src/components/drawer-section/drawer-section.tsx +0 -40
- package/src/components/drawer-section/index.ts +0 -1
- package/src/components/header/header.dummy.ts +0 -55
- package/src/components/header/header.stories.tsx +0 -116
- package/src/components/header/header.test.tsx +0 -167
- package/src/components/header/header.tsx +0 -185
- package/src/components/header/index.ts +0 -1
- package/src/components/index.ts +0 -17
- package/src/components/label/index.ts +0 -1
- package/src/components/label/label.stories.tsx +0 -49
- package/src/components/label/label.test.tsx +0 -30
- package/src/components/label/label.tsx +0 -60
- package/src/components/link/index.ts +0 -1
- package/src/components/link/link.tsx +0 -17
- package/src/components/loading-area/index.ts +0 -1
- package/src/components/loading-area/loading-area.stories.tsx +0 -17
- package/src/components/loading-area/loading-area.test.tsx +0 -11
- package/src/components/loading-area/loading-area.tsx +0 -13
- package/src/components/placeholder/index.ts +0 -1
- package/src/components/placeholder/placeholder.mock.ts +0 -15
- package/src/components/placeholder/placeholder.stories.tsx +0 -44
- package/src/components/placeholder/placeholder.test.tsx +0 -76
- package/src/components/placeholder/placeholder.tsx +0 -75
- package/src/components/query-container/index.ts +0 -1
- package/src/components/query-container/query-container.stories.tsx +0 -68
- package/src/components/query-container/query-container.test.tsx +0 -95
- package/src/components/query-container/query-container.tsx +0 -71
- package/src/components/sign-in/index.ts +0 -1
- package/src/components/sign-in/sign-in.stories.tsx +0 -36
- package/src/components/sign-in/sign-in.test.tsx +0 -95
- package/src/components/sign-in/sign-in.tsx +0 -97
- package/src/components/tab/index.ts +0 -3
- package/src/components/tab/tab-card/index.ts +0 -1
- package/src/components/tab/tab-card/tab-card.dummy.tsx +0 -27
- package/src/components/tab/tab-card/tab-card.stories.tsx +0 -22
- package/src/components/tab/tab-card/tab-card.test.tsx +0 -53
- package/src/components/tab/tab-card/tab-card.tsx +0 -30
- package/src/components/tab/tab-panel/index.ts +0 -1
- package/src/components/tab/tab-panel/tab-panel.test.tsx +0 -26
- package/src/components/tab/tab-panel/tab-panel.tsx +0 -27
- package/src/components/tab/tab.context.ts +0 -5
- package/src/components/table/enhanced-remote-table/enhanced-remote-table.mock.tsx +0 -27
- package/src/components/table/enhanced-remote-table/enhanced-remote-table.stories.tsx +0 -24
- package/src/components/table/enhanced-remote-table/enhanced-remote-table.test.tsx +0 -77
- package/src/components/table/enhanced-remote-table/enhanced-remote-table.tsx +0 -74
- package/src/components/table/enhanced-remote-table/index.ts +0 -1
- package/src/components/table/enhanced-table/enhanced-table-head.tsx +0 -58
- package/src/components/table/enhanced-table/enhanced-table.mock.tsx +0 -93
- package/src/components/table/enhanced-table/enhanced-table.stories.tsx +0 -21
- package/src/components/table/enhanced-table/enhanced-table.test.tsx +0 -107
- package/src/components/table/enhanced-table/enhanced-table.tsx +0 -136
- package/src/components/table/enhanced-table/index.ts +0 -2
- package/src/components/table/index.ts +0 -2
- package/src/components/table-list/index.ts +0 -1
- package/src/components/table-list/table-list.stories.tsx +0 -75
- package/src/components/table-list/table-list.test.tsx +0 -283
- package/src/components/table-list/table-list.tsx +0 -131
- package/src/components/value-displays/group-value-card/group-value-card.mock.tsx +0 -35
- package/src/components/value-displays/group-value-card/group-value-card.stories.tsx +0 -26
- package/src/components/value-displays/group-value-card/group-value-card.test.tsx +0 -58
- package/src/components/value-displays/group-value-card/group-value-card.tsx +0 -65
- package/src/components/value-displays/group-value-card/index.ts +0 -1
- package/src/components/value-displays/index.ts +0 -4
- package/src/components/value-displays/value-boolean/index.ts +0 -1
- package/src/components/value-displays/value-boolean/value-boolean.stories.tsx +0 -25
- package/src/components/value-displays/value-boolean/value-boolean.test.tsx +0 -27
- package/src/components/value-displays/value-boolean/value-boolean.tsx +0 -33
- package/src/components/value-displays/value-card/index.ts +0 -1
- package/src/components/value-displays/value-card/value-card.stories.tsx +0 -22
- package/src/components/value-displays/value-card/value-card.test.tsx +0 -18
- package/src/components/value-displays/value-card/value-card.tsx +0 -12
- package/src/components/value-displays/value-text/index.ts +0 -1
- package/src/components/value-displays/value-text/value-test.test.tsx +0 -21
- package/src/components/value-displays/value-text/value-text.stories.tsx +0 -26
- package/src/components/value-displays/value-text/value-text.tsx +0 -32
- package/src/generators/generators.mock.ts +0 -215
- package/src/generators/generators.model.ts +0 -41
- package/src/generators/index.ts +0 -4
- package/src/generators/model-form/index.ts +0 -1
- package/src/generators/model-form/model-form.stories.tsx +0 -30
- package/src/generators/model-form/model-form.test.tsx +0 -98
- package/src/generators/model-form/model-form.tsx +0 -97
- package/src/generators/model-router/index.ts +0 -1
- package/src/generators/model-router/model-router.stories.tsx +0 -160
- package/src/generators/model-router/model-router.test.tsx +0 -633
- package/src/generators/model-router/model-router.tsx +0 -54
- package/src/generators/model-router/screens/add-screen.tsx +0 -52
- package/src/generators/model-router/screens/details-screen.tsx +0 -53
- package/src/generators/model-router/screens/index.ts +0 -4
- package/src/generators/model-router/screens/list-screen.tsx +0 -81
- package/src/generators/model-router/screens/update-screen.tsx +0 -62
- package/src/generators/object-details/index.ts +0 -1
- package/src/generators/object-details/object-details.stories.tsx +0 -20
- package/src/generators/object-details/object-details.test.tsx +0 -21
- package/src/generators/object-details/object-details.tsx +0 -70
- package/src/index.ts +0 -4
- package/src/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.stories.tsx +0 -29
- package/src/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.tsx +0 -34
- package/src/layouts/app-bar-with-drawer-layout/index.ts +0 -1
- package/src/layouts/data-table-layout/data-table-layout.stories.tsx +0 -94
- package/src/layouts/data-table-layout/data-table-layout.tsx +0 -30
- package/src/layouts/data-table-layout/index.ts +0 -1
- package/src/layouts/details-layout/details-layout.stories.tsx +0 -81
- package/src/layouts/details-layout/details-layout.tsx +0 -33
- package/src/layouts/details-layout/index.ts +0 -1
- package/src/layouts/form-layout/form-layout.stories.tsx +0 -65
- package/src/layouts/form-layout/form-layout.tsx +0 -18
- package/src/layouts/form-layout/index.ts +0 -1
- package/src/layouts/header-layout/header-layout.stories.tsx +0 -68
- package/src/layouts/header-layout/header-layout.tsx +0 -24
- package/src/layouts/header-layout/index.ts +0 -1
- package/src/layouts/index.ts +0 -7
- package/src/layouts/list-layout/index.ts +0 -1
- package/src/layouts/list-layout/list-layout.stories.tsx +0 -102
- package/src/layouts/list-layout/list-layout.tsx +0 -36
- package/src/layouts/tab-layout/index.ts +0 -1
- package/src/layouts/tab-layout/tab-layout.stories.tsx +0 -88
- package/src/layouts/tab-layout/tab-layout.tsx +0 -11
- package/src/providers/index.ts +0 -1
- package/src/providers/notification-center/index.ts +0 -1
- package/src/providers/notification-center/notification-center.context.ts +0 -37
- package/src/providers/notification-center/notification-center.provider.tsx +0 -51
- package/src/providers/notification-center/notification-center.stories.tsx +0 -52
- package/src/providers/notification-center/notification-center.test.tsx +0 -112
- package/src/storybook.tsx +0 -56
- package/src/tests/assertions.ts +0 -72
- package/src/tests/components.tsx +0 -60
- package/src/tests/content-placeholder.stories.tsx +0 -16
- package/src/tests/index.ts +0 -3
- package/src/tests/skeleton-card.stories.tsx +0 -18
- package/src/tests/testing-library.tsx +0 -65
- package/src/utils/arrays.test.ts +0 -9
- package/src/utils/arrays.ts +0 -7
- package/src/utils/index.ts +0 -2
- package/src/utils/theme.ts +0 -6
- package/tsconfig.json +0 -27
- package/tsconfig.rollup.json +0 -26
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { FunctionComponent } from "react";
|
|
1
|
+
import { FunctionComponent, ReactElement } from "react";
|
|
2
2
|
import { AppBarProps as MuiAppBarProps } from "@mui/material";
|
|
3
3
|
export interface AppBarProfile {
|
|
4
4
|
name: string;
|
|
@@ -11,3 +11,4 @@ export interface AppBarProps extends MuiAppBarProps {
|
|
|
11
11
|
onClickSignOut: () => void;
|
|
12
12
|
}
|
|
13
13
|
export declare type AppBarComponent = FunctionComponent<AppBarProps>;
|
|
14
|
+
export declare type AppBarElement = ReactElement<AppBarProps, AppBarComponent>;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { PropsWithChildren, FunctionComponent, ReactElement } from "react";
|
|
2
|
+
export declare type ContentProps = PropsWithChildren;
|
|
3
|
+
export declare type ContentComponent = FunctionComponent<ContentProps>;
|
|
4
|
+
export declare type ContentElement = ReactElement<ContentElement, ContentComponent>;
|
|
@@ -1,65 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare type HeaderPreset = PropTypes.Color | "transparent";
|
|
3
|
-
export declare type HeaderActionVariant = "text" | "outlined" | "contained";
|
|
4
|
-
export declare type HeaderAction = {
|
|
5
|
-
id: string;
|
|
6
|
-
text: string;
|
|
7
|
-
disabled?: boolean;
|
|
8
|
-
href?: string;
|
|
9
|
-
onClick?: () => void;
|
|
10
|
-
};
|
|
11
|
-
export interface HeaderBreadcrumb {
|
|
12
|
-
id: string;
|
|
13
|
-
text: string;
|
|
14
|
-
link: string;
|
|
15
|
-
}
|
|
16
|
-
export interface HeaderTab {
|
|
17
|
-
id: string;
|
|
18
|
-
label: string;
|
|
19
|
-
disabled?: boolean;
|
|
20
|
-
}
|
|
21
|
-
export declare type HeaderProps = {
|
|
22
|
-
/**
|
|
23
|
-
* Title of the header
|
|
24
|
-
*/
|
|
25
|
-
title: string;
|
|
26
|
-
/**
|
|
27
|
-
* Subtitle of the header
|
|
28
|
-
*/
|
|
29
|
-
subtitle?: string;
|
|
30
|
-
/**
|
|
31
|
-
* Color palete used to render the component
|
|
32
|
-
*/
|
|
33
|
-
preset: HeaderPreset;
|
|
34
|
-
/**
|
|
35
|
-
* List of breadcumbs to represent the path to reach
|
|
36
|
-
* the page that we are
|
|
37
|
-
*/
|
|
38
|
-
breadcrumbs?: HeaderBreadcrumb[];
|
|
39
|
-
/**
|
|
40
|
-
* List of actions that can be performed by the user.
|
|
41
|
-
* Each action will be a button in the header.
|
|
42
|
-
*/
|
|
43
|
-
actions?: HeaderAction[];
|
|
44
|
-
/**
|
|
45
|
-
* Variant used to render the actions
|
|
46
|
-
*/
|
|
47
|
-
actionsVariant?: HeaderActionVariant;
|
|
48
|
-
/**
|
|
49
|
-
* If is set, a list of tabs is dispayed at the bottom
|
|
50
|
-
*/
|
|
51
|
-
tabs?: HeaderTab[];
|
|
52
|
-
/**
|
|
53
|
-
* Tab that has to be marked as selected
|
|
54
|
-
*/
|
|
55
|
-
selectedTab?: number;
|
|
56
|
-
/**
|
|
57
|
-
* Callback executed when the user click a tab
|
|
58
|
-
*/
|
|
59
|
-
onChangeTab?: (tab: HeaderTab, index: number) => void;
|
|
60
|
-
};
|
|
1
|
+
import { HeaderComponent } from "./header.types";
|
|
61
2
|
/**
|
|
62
3
|
* Section used to explain give basic information about the page
|
|
63
4
|
* and put the main actions
|
|
64
5
|
*/
|
|
65
|
-
export declare const Header:
|
|
6
|
+
export declare const Header: HeaderComponent;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { PropTypes } from "@mui/material";
|
|
2
|
+
import { FunctionComponent, ReactElement } from "react";
|
|
3
|
+
export declare type HeaderPreset = PropTypes.Color | "transparent";
|
|
4
|
+
export declare type HeaderActionVariant = "text" | "outlined" | "contained";
|
|
5
|
+
export declare type HeaderAction = {
|
|
6
|
+
id: string;
|
|
7
|
+
text: string;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
href?: string;
|
|
10
|
+
onClick?: () => void;
|
|
11
|
+
};
|
|
12
|
+
export interface HeaderBreadcrumb {
|
|
13
|
+
id: string;
|
|
14
|
+
text: string;
|
|
15
|
+
link: string;
|
|
16
|
+
}
|
|
17
|
+
export interface HeaderTab {
|
|
18
|
+
id: string;
|
|
19
|
+
label: string;
|
|
20
|
+
disabled?: boolean;
|
|
21
|
+
}
|
|
22
|
+
export declare type HeaderProps = {
|
|
23
|
+
/**
|
|
24
|
+
* Title of the header
|
|
25
|
+
*/
|
|
26
|
+
title: string;
|
|
27
|
+
/**
|
|
28
|
+
* Subtitle of the header
|
|
29
|
+
*/
|
|
30
|
+
subtitle?: string;
|
|
31
|
+
/**
|
|
32
|
+
* Color palete used to render the component
|
|
33
|
+
*/
|
|
34
|
+
preset?: HeaderPreset;
|
|
35
|
+
/**
|
|
36
|
+
* List of breadcumbs to represent the path to reach
|
|
37
|
+
* the page that we are
|
|
38
|
+
*/
|
|
39
|
+
breadcrumbs?: HeaderBreadcrumb[];
|
|
40
|
+
/**
|
|
41
|
+
* List of actions that can be performed by the user.
|
|
42
|
+
* Each action will be a button in the header.
|
|
43
|
+
*/
|
|
44
|
+
actions?: HeaderAction[];
|
|
45
|
+
/**
|
|
46
|
+
* Variant used to render the actions
|
|
47
|
+
*/
|
|
48
|
+
actionsVariant?: HeaderActionVariant;
|
|
49
|
+
/**
|
|
50
|
+
* If is set, a list of tabs is dispayed at the bottom
|
|
51
|
+
*/
|
|
52
|
+
tabs?: HeaderTab[];
|
|
53
|
+
};
|
|
54
|
+
export declare type HeaderComponent = FunctionComponent<HeaderProps>;
|
|
55
|
+
export declare type HeaderElement = ReactElement<HeaderProps, HeaderComponent>;
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { PropsWithChildren } from "react";
|
|
2
2
|
interface Props {
|
|
3
3
|
tabs: string[];
|
|
4
|
-
initialTab?: number;
|
|
5
4
|
}
|
|
6
|
-
export declare const TabCard: ({ children, tabs
|
|
5
|
+
export declare const TabCard: ({ children, tabs }: PropsWithChildren<Props>) => JSX.Element;
|
|
7
6
|
export {};
|
|
@@ -1,14 +1,11 @@
|
|
|
1
1
|
import { HeadCell, Order } from "../table/enhanced-table";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
[key: string]: any;
|
|
5
|
-
}
|
|
6
|
-
export interface TableRowOption<T extends BasicData> {
|
|
2
|
+
import { BasicModelInstance } from "~/generators";
|
|
3
|
+
export interface TableRowOption<T extends BasicModelInstance> {
|
|
7
4
|
id: string;
|
|
8
5
|
label: string;
|
|
9
6
|
onClick: (item: T) => void;
|
|
10
7
|
}
|
|
11
|
-
export interface TableListProps<T extends
|
|
8
|
+
export interface TableListProps<T extends BasicModelInstance> {
|
|
12
9
|
columns: HeadCell[];
|
|
13
10
|
data: T[];
|
|
14
11
|
search?: boolean;
|
|
@@ -18,4 +15,4 @@ export interface TableListProps<T extends BasicData> {
|
|
|
18
15
|
options?: TableRowOption<T>[];
|
|
19
16
|
onClick?: (d: T) => void;
|
|
20
17
|
}
|
|
21
|
-
export declare const TableList: <T extends
|
|
18
|
+
export declare const TableList: <T extends BasicModelInstance>({ columns: columnsProp, options, data, onClick, search, defaultSort, defaultOrder, loading, }: TableListProps<T>) => JSX.Element;
|
|
@@ -1,3 +1,24 @@
|
|
|
1
1
|
import { Model } from "./generators.model";
|
|
2
2
|
export declare const mockModel: Model;
|
|
3
|
-
export
|
|
3
|
+
export interface MockInstance {
|
|
4
|
+
id: string;
|
|
5
|
+
firstName: string;
|
|
6
|
+
middleName: string;
|
|
7
|
+
lastName: string;
|
|
8
|
+
gender: string;
|
|
9
|
+
age: number;
|
|
10
|
+
birthDate: string;
|
|
11
|
+
car: {
|
|
12
|
+
model: string;
|
|
13
|
+
manufacturer: string;
|
|
14
|
+
color: string;
|
|
15
|
+
type: string;
|
|
16
|
+
vin: string;
|
|
17
|
+
vrm: string;
|
|
18
|
+
};
|
|
19
|
+
quantity: number;
|
|
20
|
+
available: boolean;
|
|
21
|
+
currency: string;
|
|
22
|
+
tradeDate: string;
|
|
23
|
+
}
|
|
24
|
+
export declare const createModelInstance: <T extends BasicData>(model: Model, seed?: number) => T;
|
|
@@ -24,10 +24,14 @@ declare type SingleFields = StringField | NumberField | BooleanField;
|
|
|
24
24
|
export declare type GroupField = {
|
|
25
25
|
type: "group";
|
|
26
26
|
value: (Base & Breakpoints & SingleFields)[];
|
|
27
|
-
};
|
|
27
|
+
} & Base;
|
|
28
28
|
declare type Fields = SingleFields | GroupField;
|
|
29
29
|
export declare type ModelField = Base & Breakpoints & Fields;
|
|
30
30
|
export declare type Model = {
|
|
31
31
|
fields: ModelField[];
|
|
32
32
|
};
|
|
33
|
+
export interface BasicModelInstance {
|
|
34
|
+
id: string;
|
|
35
|
+
[key: string]: any;
|
|
36
|
+
}
|
|
33
37
|
export {};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Model } from "../generators.model";
|
|
2
|
-
export interface ModelFormProps {
|
|
1
|
+
import { Model, BasicModelInstance } from "../generators.model";
|
|
2
|
+
export interface ModelFormProps<T extends BasicModelInstance> {
|
|
3
3
|
model: Model;
|
|
4
|
-
initialValues?:
|
|
4
|
+
initialValues?: T;
|
|
5
5
|
saveButtonText: string;
|
|
6
|
-
onSubmit: (values:
|
|
6
|
+
onSubmit: (values: T) => void;
|
|
7
7
|
}
|
|
8
|
-
export declare const ModelForm: ({ model, saveButtonText, onSubmit, initialValues, }: ModelFormProps) => JSX.Element;
|
|
8
|
+
export declare const ModelForm: <T extends BasicModelInstance>({ model, saveButtonText, onSubmit, initialValues, }: ModelFormProps<T>) => JSX.Element;
|
|
@@ -1,35 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
error?: string;
|
|
6
|
-
success?: boolean;
|
|
7
|
-
}
|
|
8
|
-
export interface ModelRouterProps {
|
|
9
|
-
modelName: string;
|
|
10
|
-
model: Model;
|
|
11
|
-
requestList?: () => void;
|
|
12
|
-
list: {
|
|
13
|
-
data: any[];
|
|
14
|
-
onClickRemoveItem: (item: any) => void;
|
|
15
|
-
listRequest: RequestState;
|
|
16
|
-
requestDelete: RequestState;
|
|
17
|
-
};
|
|
18
|
-
add: {
|
|
19
|
-
onSubmit: (obj: object) => void;
|
|
20
|
-
request: RequestState;
|
|
21
|
-
};
|
|
22
|
-
detail: {
|
|
23
|
-
onScreenMount?: (id: string) => void;
|
|
24
|
-
request: RequestState;
|
|
25
|
-
instance?: any;
|
|
26
|
-
};
|
|
27
|
-
update: {
|
|
28
|
-
onSubmit: (obj: object) => void;
|
|
29
|
-
request: RequestState;
|
|
30
|
-
requestInstance: RequestState;
|
|
31
|
-
onRequestInstance: (id: string) => void;
|
|
32
|
-
instance?: any;
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
export declare const ModelRouter: (props: ModelRouterProps) => JSX.Element;
|
|
1
|
+
import { BasicModelInstance } from "../generators.model";
|
|
2
|
+
import { AddScreenProps, DetailsScreenProps, ListScreenProps, UpdateScreenProps } from "./screens";
|
|
3
|
+
export declare type ModelRouterProps<T extends BasicModelInstance> = DetailsScreenProps<T> & ListScreenProps<T> & AddScreenProps<T> & UpdateScreenProps<T>;
|
|
4
|
+
export declare const ModelRouter: <T extends BasicModelInstance>(props: ModelRouterProps<T>) => JSX.Element;
|
|
@@ -1,2 +1,16 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { BasicModelInstance } from "~/generators";
|
|
2
|
+
import { RequestState } from "../model-router.types";
|
|
3
|
+
import { BaseScreenProps } from "./screens.types";
|
|
4
|
+
export interface AddScreenProps<T extends BasicModelInstance> extends BaseScreenProps {
|
|
5
|
+
/**
|
|
6
|
+
* Callback executed when the user wants to
|
|
7
|
+
* add a new item
|
|
8
|
+
*/
|
|
9
|
+
onSubmitNewItem: (obj: T) => void;
|
|
10
|
+
/**
|
|
11
|
+
* Current status of the request to retrieve
|
|
12
|
+
* add a new item
|
|
13
|
+
*/
|
|
14
|
+
newItemRequest: RequestState;
|
|
15
|
+
}
|
|
16
|
+
export declare const AddScreen: <T extends BasicModelInstance>({ model, modelName, onSubmitNewItem, newItemRequest, }: AddScreenProps<T>) => JSX.Element;
|
|
@@ -1,2 +1,20 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { RequestState } from "../model-router.types";
|
|
2
|
+
import { BaseScreenProps } from "./screens.types";
|
|
3
|
+
import { BasicModelInstance } from "~/generators";
|
|
4
|
+
export interface DetailsScreenProps<T extends BasicModelInstance> extends BaseScreenProps {
|
|
5
|
+
/**
|
|
6
|
+
* Callback executed each time we want
|
|
7
|
+
* the details information of an item
|
|
8
|
+
*/
|
|
9
|
+
onRequestItem: (id: string) => void;
|
|
10
|
+
/**
|
|
11
|
+
* Current status of the request to retrieve
|
|
12
|
+
* an item
|
|
13
|
+
*/
|
|
14
|
+
itemRequest: RequestState;
|
|
15
|
+
/**
|
|
16
|
+
* Item to be displayed
|
|
17
|
+
*/
|
|
18
|
+
detailsItem?: T;
|
|
19
|
+
}
|
|
20
|
+
export declare const DetailsScreen: <T extends BasicModelInstance>({ model, modelName, onRequestItem, itemRequest, detailsItem, }: DetailsScreenProps<T>) => JSX.Element;
|
|
@@ -1,2 +1,30 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import { BasicModelInstance } from "~/generators";
|
|
2
|
+
import { RequestState } from "../model-router.types";
|
|
3
|
+
import { BaseScreenProps } from "./screens.types";
|
|
4
|
+
export interface ListScreenProps<T extends BasicModelInstance> extends BaseScreenProps {
|
|
5
|
+
/**
|
|
6
|
+
* Callback executed each time the list screen
|
|
7
|
+
* requests for a data update
|
|
8
|
+
*/
|
|
9
|
+
onRequestList: () => void;
|
|
10
|
+
/**
|
|
11
|
+
* List of items to be displayed in the list screen
|
|
12
|
+
*/
|
|
13
|
+
listData: T[];
|
|
14
|
+
/**
|
|
15
|
+
* Callback executed when the user clicks an option
|
|
16
|
+
* to delete an item
|
|
17
|
+
*/
|
|
18
|
+
onClickDeleteItem: (item: T) => void;
|
|
19
|
+
/**
|
|
20
|
+
* Current status of the request to retrieve
|
|
21
|
+
* the list items
|
|
22
|
+
*/
|
|
23
|
+
listRequest: RequestState;
|
|
24
|
+
/**
|
|
25
|
+
* Current status of the request to delete
|
|
26
|
+
* an item
|
|
27
|
+
*/
|
|
28
|
+
deleteRequest: RequestState;
|
|
29
|
+
}
|
|
30
|
+
export declare const ListScreen: <T extends BasicModelInstance>({ model, modelName, listData, onRequestList, onClickDeleteItem, listRequest, deleteRequest, }: ListScreenProps<T>) => JSX.Element;
|
|
@@ -1,2 +1,29 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import { BasicModelInstance } from "~/generators";
|
|
2
|
+
import { RequestState } from "../model-router.types";
|
|
3
|
+
import { BaseScreenProps } from "./screens.types";
|
|
4
|
+
export interface UpdateScreenProps<T extends BasicModelInstance> extends BaseScreenProps {
|
|
5
|
+
/**
|
|
6
|
+
* Callback executed when the user wants to update
|
|
7
|
+
* an item
|
|
8
|
+
*/
|
|
9
|
+
onSubmitUpdateItem: (obj: T) => void;
|
|
10
|
+
/**
|
|
11
|
+
* Current status of the request to update an item
|
|
12
|
+
*/
|
|
13
|
+
submitUpdateItemRequest: RequestState;
|
|
14
|
+
/**
|
|
15
|
+
* Current status of the request to retrieve
|
|
16
|
+
* the item to be updated
|
|
17
|
+
*/
|
|
18
|
+
updateItemRequest: RequestState;
|
|
19
|
+
/**
|
|
20
|
+
* Callback executed to retrive the item that
|
|
21
|
+
* has to going tobe updated
|
|
22
|
+
*/
|
|
23
|
+
onRequestUpdateItem: (id: string) => void;
|
|
24
|
+
/**
|
|
25
|
+
* Item that is going to be updated
|
|
26
|
+
*/
|
|
27
|
+
updateItem?: T;
|
|
28
|
+
}
|
|
29
|
+
export declare const UpdateScreen: <T extends BasicModelInstance>({ model, modelName, submitUpdateItemRequest, updateItemRequest, updateItem, onSubmitUpdateItem, onRequestUpdateItem, }: UpdateScreenProps<T>) => JSX.Element;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { MockInstance } from "../../generators.mock";
|
|
3
|
+
export declare const onRequestListAction: import("@storybook/addon-actions").HandlerFunction;
|
|
4
|
+
export declare const onSubmitNewItemAction: import("@storybook/addon-actions").HandlerFunction;
|
|
5
|
+
export declare const onRequestItem: import("@storybook/addon-actions").HandlerFunction;
|
|
6
|
+
export declare const onRequestUpdateItemAction: import("@storybook/addon-actions").HandlerFunction;
|
|
7
|
+
export declare const onSubmitUpdateAction: import("@storybook/addon-actions").HandlerFunction;
|
|
8
|
+
export declare const onRequestDeleteAction: import("@storybook/addon-actions").HandlerFunction;
|
|
9
|
+
export declare const REQUEST_TIMEOUT = 2000;
|
|
10
|
+
export declare const item1: MockInstance;
|
|
11
|
+
export declare const data: MockInstance[];
|
|
12
|
+
export declare const ModelRouterTemplate: import("@storybook/react").ComponentStory<import("react").JSXElementConstructor<import("../model-router").ModelRouterProps<import("../..").BasicModelInstance>>>;
|
|
13
|
+
export declare const baseArgs: {
|
|
14
|
+
modelName: string;
|
|
15
|
+
model: import("../..").Model;
|
|
16
|
+
listData: MockInstance[];
|
|
17
|
+
listRequest: import("../model-router.types").RequestState;
|
|
18
|
+
deleteRequest: import("../model-router.types").RequestState;
|
|
19
|
+
newItemRequest: import("../model-router.types").RequestState;
|
|
20
|
+
updateItemRequest: import("../model-router.types").RequestState;
|
|
21
|
+
submitUpdateItemRequest: import("../model-router.types").RequestState;
|
|
22
|
+
itemRequest: import("../model-router.types").RequestState;
|
|
23
|
+
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Model } from "../generators.model";
|
|
2
|
-
export interface ObjectDetailsProps {
|
|
1
|
+
import { Model, BasicModelInstance } from "../generators.model";
|
|
2
|
+
export interface ObjectDetailsProps<T extends BasicModelInstance> {
|
|
3
3
|
model: Model;
|
|
4
|
-
instance:
|
|
4
|
+
instance: T;
|
|
5
5
|
}
|
|
6
|
-
export declare const ObjectDetails: ({ model, instance }: ObjectDetailsProps) => JSX.Element;
|
|
6
|
+
export declare const ObjectDetails: <T extends BasicModelInstance>({ model, instance, }: ObjectDetailsProps<T>) => JSX.Element;
|
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { ReactNode } from "react";
|
|
2
|
+
import { AppBarElement } from "../../components/app-bar";
|
|
3
3
|
import { DrawerElement } from "../../components/drawer";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
drawer: DrawerElement;
|
|
7
|
-
appBar: ReactElement<AppBarProps, AppBarComponent>;
|
|
4
|
+
export interface AppBarWithDrawerLayoutProps {
|
|
5
|
+
children: [DrawerElement, AppBarElement, ReactNode];
|
|
8
6
|
}
|
|
9
|
-
export declare const AppBarWithDrawerLayout: ({
|
|
10
|
-
export {};
|
|
7
|
+
export declare const AppBarWithDrawerLayout: ({ children: childrenProps, }: AppBarWithDrawerLayoutProps) => JSX.Element;
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
interface Props {
|
|
1
|
+
import { ContentElement, HeaderElement } from "../../components";
|
|
2
|
+
interface HeaderLayoutProps {
|
|
4
3
|
loading?: boolean;
|
|
5
|
-
|
|
4
|
+
children: [HeaderElement, ContentElement];
|
|
6
5
|
}
|
|
7
|
-
export declare const HeaderLayout: ({ loading,
|
|
6
|
+
export declare const HeaderLayout: ({ loading, children }: HeaderLayoutProps) => JSX.Element;
|
|
8
7
|
export {};
|
|
@@ -1,7 +1,2 @@
|
|
|
1
|
-
export * from "./data-table-layout";
|
|
2
|
-
export * from "./header-layout";
|
|
3
|
-
export * from "./tab-layout";
|
|
4
|
-
export * from "./list-layout";
|
|
5
1
|
export * from "./app-bar-with-drawer-layout";
|
|
6
|
-
export * from "./
|
|
7
|
-
export * from "./form-layout";
|
|
2
|
+
export * from "./header-layout";
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Dispatch, SetStateAction } from "react";
|
|
2
|
+
export declare const TabContext: import("react").Context<[number, Dispatch<SetStateAction<number>>]>;
|
|
3
|
+
export declare const TabContextProvider: import("react").Provider<[number, Dispatch<SetStateAction<number>>]>;
|
|
4
|
+
export declare const useTab: () => [number, Dispatch<SetStateAction<number>>];
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { Color } from "@mui/material";
|
|
2
|
+
declare type KeyColor = keyof Color;
|
|
3
|
+
export declare const useGetDefaultThemeColor: ({ lightWeight, darkWeight, }?: {
|
|
4
|
+
lightWeight?: keyof Color | undefined;
|
|
5
|
+
darkWeight?: keyof Color | undefined;
|
|
6
|
+
}) => string;
|
|
7
|
+
export {};
|