@seij/common-ui 0.1.6 → 0.1.8
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/README.md +0 -1
- package/dist/init/SeijUIProvider.d.ts.map +1 -1
- package/dist/init/SeijUIProvider.js.map +1 -1
- package/dist/lib/applicationshell/ApplicationShell.d.ts +73 -2
- package/dist/lib/applicationshell/ApplicationShell.d.ts.map +1 -1
- package/dist/lib/applicationshell/ApplicationShell.js +75 -70
- package/dist/lib/applicationshell/ApplicationShell.js.map +1 -1
- package/dist/lib/applicationshell/ApplicationShellHamburger.d.ts +4 -0
- package/dist/lib/applicationshell/ApplicationShellHamburger.d.ts.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellHamburger.js +17 -0
- package/dist/lib/applicationshell/ApplicationShellHamburger.js.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellPanelContract.d.ts +5 -0
- package/dist/lib/applicationshell/ApplicationShellPanelContract.d.ts.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellPanelContract.js +19 -0
- package/dist/lib/applicationshell/ApplicationShellPanelContract.js.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellRails.d.ts +11 -0
- package/dist/lib/applicationshell/ApplicationShellRails.d.ts.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellRails.js +111 -0
- package/dist/lib/applicationshell/ApplicationShellRails.js.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellSidebar.d.ts +18 -0
- package/dist/lib/applicationshell/ApplicationShellSidebar.d.ts.map +1 -0
- package/dist/lib/applicationshell/ApplicationShellSidebar.js +52 -0
- package/dist/lib/applicationshell/ApplicationShellSidebar.js.map +1 -0
- package/dist/lib/applicationshell/TitleBar.d.ts +6 -2
- package/dist/lib/applicationshell/TitleBar.d.ts.map +1 -1
- package/dist/lib/applicationshell/TitleBar.js +39 -33
- package/dist/lib/applicationshell/TitleBar.js.map +1 -1
- package/dist/lib/button_bar/ButtonBar.d.ts.map +1 -1
- package/dist/lib/button_bar/ButtonBar.js.map +1 -1
- package/dist/lib/commons/currencysymbol.js.map +1 -1
- package/dist/lib/errorbox/ErrorBox.js +6 -6
- package/dist/lib/errorbox/ErrorBox.js.map +1 -1
- package/dist/lib/i18n/i18n.detect.d.ts.map +1 -1
- package/dist/lib/i18n/i18n.react.d.ts.map +1 -1
- package/dist/lib/i18n/i18n.react.js.map +1 -1
- package/dist/lib/i18n/i18n.types.d.ts.map +1 -1
- package/dist/lib/i18n/index.d.ts.map +1 -1
- package/dist/lib/inlineedit/InlineEdit.js +12 -12
- package/dist/lib/inlineedit/InlineEdit.js.map +1 -1
- package/dist/lib/listview/ListView.js +25 -24
- package/dist/lib/listview/ListView.js.map +1 -1
- package/dist/lib/localdate/InputLocalDate.js +3 -2
- package/dist/lib/localdate/InputLocalDate.js.map +1 -1
- package/dist/lib/month/InputMonth.js +9 -8
- package/dist/lib/month/InputMonth.js.map +1 -1
- package/dist/lib/navigation/Navigation.d.ts +5 -1
- package/dist/lib/navigation/Navigation.d.ts.map +1 -1
- package/dist/lib/navigation/Navigation.js +24 -26
- package/dist/lib/navigation/Navigation.js.map +1 -1
- package/dist/lib/navigation/Navigation.types.d.ts +59 -17
- package/dist/lib/navigation/Navigation.types.d.ts.map +1 -1
- package/dist/lib/responsive/useMobile.d.ts +2 -0
- package/dist/lib/responsive/useMobile.d.ts.map +1 -0
- package/dist/lib/responsive/useMobile.js +12 -0
- package/dist/lib/responsive/useMobile.js.map +1 -0
- package/dist/lib/view_layout/ViewTitle.d.ts.map +1 -1
- package/dist/lib/view_layout/ViewTitle.js +22 -25
- package/dist/lib/view_layout/ViewTitle.js.map +1 -1
- package/package.json +4 -4
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { jsxs as n, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { NavDrawer as g, NavDrawerHeader as y, Tooltip as N, Hamburger as C, AppItem as x, NavDrawerBody as w, NavDrawerFooter as D } from "@fluentui/react-components";
|
|
3
|
+
import { Navigation as k } from "@seij/common-ui";
|
|
4
|
+
import { User as I } from "./TitleBar.js";
|
|
5
|
+
import { PanelLeftContract as S } from "./ApplicationShellPanelContract.js";
|
|
6
|
+
function B({
|
|
7
|
+
selectedItem: t,
|
|
8
|
+
isMobile: r,
|
|
9
|
+
applicationName: o,
|
|
10
|
+
drawerOpen: l,
|
|
11
|
+
openedCategories: i,
|
|
12
|
+
applicationIcon: c,
|
|
13
|
+
userStatus: d,
|
|
14
|
+
navigationItems: p,
|
|
15
|
+
onClickHome: m,
|
|
16
|
+
onClickMenuItem: s,
|
|
17
|
+
onClickCategory: v,
|
|
18
|
+
onClickHamburger: h,
|
|
19
|
+
onClickPanelReduce: u
|
|
20
|
+
}) {
|
|
21
|
+
return /* @__PURE__ */ n(
|
|
22
|
+
g,
|
|
23
|
+
{
|
|
24
|
+
selectedValue: t,
|
|
25
|
+
open: r && l || !r,
|
|
26
|
+
density: "small",
|
|
27
|
+
type: r ? "overlay" : "inline",
|
|
28
|
+
openCategories: i,
|
|
29
|
+
onNavItemSelect: (f, a) => {
|
|
30
|
+
s(a.value);
|
|
31
|
+
},
|
|
32
|
+
onNavCategoryItemToggle: (f, a) => {
|
|
33
|
+
v(a.categoryValue ?? "");
|
|
34
|
+
},
|
|
35
|
+
children: [
|
|
36
|
+
/* @__PURE__ */ n(y, { children: [
|
|
37
|
+
r ? /* @__PURE__ */ e(N, { content: "Navigation", relationship: "label", children: /* @__PURE__ */ e(C, { onClick: h }) }) : null,
|
|
38
|
+
/* @__PURE__ */ e(x, { onClick: m, icon: /* @__PURE__ */ e("span", { children: c }), children: o })
|
|
39
|
+
] }),
|
|
40
|
+
/* @__PURE__ */ e(w, { children: /* @__PURE__ */ e(k, { items: p }) }),
|
|
41
|
+
/* @__PURE__ */ e(D, { children: /* @__PURE__ */ n("div", { style: { display: "flex" }, children: [
|
|
42
|
+
/* @__PURE__ */ e(I, { status: d }),
|
|
43
|
+
r ? null : /* @__PURE__ */ e(S, { panelState: "expanded", onClick: u })
|
|
44
|
+
] }) })
|
|
45
|
+
]
|
|
46
|
+
}
|
|
47
|
+
);
|
|
48
|
+
}
|
|
49
|
+
export {
|
|
50
|
+
B as Sidebar
|
|
51
|
+
};
|
|
52
|
+
//# sourceMappingURL=ApplicationShellSidebar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ApplicationShellSidebar.js","sources":["../../../src/lib/applicationshell/ApplicationShellSidebar.tsx"],"sourcesContent":["import {\n AppItem,\n Hamburger,\n NavDrawer,\n NavDrawerBody,\n NavDrawerFooter,\n NavDrawerHeader,\n Tooltip,\n} from \"@fluentui/react-components\";\nimport { Navigation, NavigationTreeItem, UserStatus } from \"@seij/common-ui\";\nimport { User } from \"./TitleBar\";\nimport { PanelLeftContract } from \"./ApplicationShellPanelContract\";\nimport { ReactNode } from \"react\";\n\nexport function Sidebar({\n selectedItem,\n isMobile,\n applicationName,\n drawerOpen,\n openedCategories,\n applicationIcon,\n userStatus,\n navigationItems,\n onClickHome,\n onClickMenuItem,\n onClickCategory,\n onClickHamburger,\n onClickPanelReduce,\n}: {\n isMobile: boolean;\n drawerOpen: boolean;\n selectedItem: string;\n applicationName: string;\n applicationIcon?: ReactNode;\n openedCategories: string[];\n navigationItems: NavigationTreeItem[];\n userStatus: UserStatus;\n onClickHome: () => void;\n onClickMenuItem: (id: string) => void;\n onClickCategory: (id: string) => void;\n onClickHamburger: () => void;\n onClickPanelReduce: () => void;\n}) {\n return (\n <NavDrawer\n selectedValue={selectedItem}\n open={(isMobile && drawerOpen) || !isMobile}\n density={\"small\"}\n type={isMobile ? \"overlay\" : \"inline\"}\n openCategories={openedCategories}\n onNavItemSelect={(e, data) => {\n onClickMenuItem(data.value);\n }}\n onNavCategoryItemToggle={(e, data) => {\n onClickCategory(data.categoryValue ?? \"\");\n }}\n >\n <NavDrawerHeader>\n {isMobile ? (\n <Tooltip content=\"Navigation\" relationship=\"label\">\n <Hamburger onClick={onClickHamburger} />\n </Tooltip>\n ) : null}\n <AppItem onClick={onClickHome} icon={<span>{applicationIcon}</span>}>\n {applicationName}\n </AppItem>\n </NavDrawerHeader>\n <NavDrawerBody>\n <Navigation items={navigationItems} />\n </NavDrawerBody>\n <NavDrawerFooter>\n <div style={{ display: \"flex\" }}>\n <User status={userStatus} />\n {isMobile ? null : <PanelLeftContract panelState={\"expanded\"} onClick={onClickPanelReduce} />}\n </div>\n </NavDrawerFooter>\n </NavDrawer>\n );\n}\n"],"names":["Sidebar","selectedItem","isMobile","applicationName","drawerOpen","openedCategories","applicationIcon","userStatus","navigationItems","onClickHome","onClickMenuItem","onClickCategory","onClickHamburger","onClickPanelReduce","jsxs","NavDrawer","e","data","NavDrawerHeader","jsx","Tooltip","Hamburger","AppItem","NavDrawerBody","Navigation","NavDrawerFooter","User","PanelLeftContract"],"mappings":";;;;;AAcO,SAASA,EAAQ;AAAA,EACtB,cAAAC;AAAA,EACA,UAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,YAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,YAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,oBAAAC;AACF,GAcG;AACD,SACE,gBAAAC;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,eAAed;AAAA,MACf,MAAOC,KAAYE,KAAe,CAACF;AAAA,MACnC,SAAS;AAAA,MACT,MAAMA,IAAW,YAAY;AAAA,MAC7B,gBAAgBG;AAAA,MAChB,iBAAiB,CAACW,GAAGC,MAAS;AAC5B,QAAAP,EAAgBO,EAAK,KAAK;AAAA,MAC5B;AAAA,MACA,yBAAyB,CAACD,GAAGC,MAAS;AACpC,QAAAN,EAAgBM,EAAK,iBAAiB,EAAE;AAAA,MAC1C;AAAA,MAEA,UAAA;AAAA,QAAA,gBAAAH,EAACI,GAAA,EACE,UAAA;AAAA,UAAAhB,IACC,gBAAAiB,EAACC,GAAA,EAAQ,SAAQ,cAAa,cAAa,SACzC,UAAA,gBAAAD,EAACE,GAAA,EAAU,SAAST,EAAA,CAAkB,EAAA,CACxC,IACE;AAAA,UACJ,gBAAAO,EAACG,KAAQ,SAASb,GAAa,MAAM,gBAAAU,EAAC,QAAA,EAAM,UAAAb,EAAA,CAAgB,GACzD,UAAAH,EAAA,CACH;AAAA,QAAA,GACF;AAAA,0BACCoB,GAAA,EACC,UAAA,gBAAAJ,EAACK,GAAA,EAAW,OAAOhB,GAAiB,GACtC;AAAA,QACA,gBAAAW,EAACM,KACC,UAAA,gBAAAX,EAAC,OAAA,EAAI,OAAO,EAAE,SAAS,UACrB,UAAA;AAAA,UAAA,gBAAAK,EAACO,GAAA,EAAK,QAAQnB,EAAA,CAAY;AAAA,UACzBL,IAAW,OAAO,gBAAAiB,EAACQ,KAAkB,YAAY,YAAY,SAASd,EAAA,CAAoB;AAAA,QAAA,EAAA,CAC7F,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN;"}
|
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
import { ReactNode } from 'react';
|
|
2
2
|
import { UserStatus } from './ApplicationShell.types';
|
|
3
|
-
export declare function TitleBar({ hamburger, onClickHome, userStatus, applicationName
|
|
3
|
+
export declare function TitleBar({ hamburger, onClickHome, userStatus, applicationName, applicationIcon, }: {
|
|
4
4
|
userStatus: UserStatus;
|
|
5
|
-
applicationName:
|
|
5
|
+
applicationName: ReactNode;
|
|
6
|
+
applicationIcon?: ReactNode;
|
|
6
7
|
hamburger: ReactNode | null;
|
|
7
8
|
onClickHome: () => void;
|
|
8
9
|
}): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export declare function User({ status }: {
|
|
11
|
+
status: UserStatus;
|
|
12
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
9
13
|
//# sourceMappingURL=TitleBar.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TitleBar.d.ts","sourceRoot":"","sources":["../../../src/lib/applicationshell/TitleBar.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TitleBar.d.ts","sourceRoot":"","sources":["../../../src/lib/applicationshell/TitleBar.tsx"],"names":[],"mappings":"AACA,OAAO,EAAwB,SAAS,EAAE,MAAM,OAAO,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AA6DtD,wBAAgB,QAAQ,CAAC,EACvB,SAAS,EACT,WAAW,EACX,UAAU,EACV,eAAe,EACf,eAAe,GAChB,EAAE;IACD,UAAU,EAAE,UAAU,CAAC;IACvB,eAAe,EAAE,SAAS,CAAC;IAC3B,eAAe,CAAC,EAAE,SAAS,CAAC;IAC5B,SAAS,EAAE,SAAS,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,MAAM,IAAI,CAAC;CACzB,2CAkBA;AAiBD,wBAAgB,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE;IAAE,MAAM,EAAE,UAAU,CAAA;CAAE,2CA4BtD"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { jsx as n, jsxs as
|
|
2
|
-
import { makeStyles as
|
|
3
|
-
import {
|
|
4
|
-
const
|
|
1
|
+
import { jsx as n, jsxs as h } from "react/jsx-runtime";
|
|
2
|
+
import { makeStyles as p, tokens as c, Text as u, useKeyboardNavAttribute as m, Spinner as x, Avatar as d } from "@fluentui/react-components";
|
|
3
|
+
import { Icon as g } from "@seij/common-ui-icons";
|
|
4
|
+
const s = p({
|
|
5
5
|
root: {
|
|
6
6
|
height: "48px",
|
|
7
7
|
lineHeight: "48px",
|
|
@@ -9,8 +9,8 @@ const c = h({
|
|
|
9
9
|
},
|
|
10
10
|
appBar: {
|
|
11
11
|
display: "flex",
|
|
12
|
-
color:
|
|
13
|
-
backgroundColor:
|
|
12
|
+
color: c.colorNeutralForegroundOnBrand,
|
|
13
|
+
backgroundColor: c.colorBrandBackground,
|
|
14
14
|
width: "100%",
|
|
15
15
|
maxWidth: "100%"
|
|
16
16
|
},
|
|
@@ -22,13 +22,17 @@ const c = h({
|
|
|
22
22
|
flex: 0,
|
|
23
23
|
textAlign: "center",
|
|
24
24
|
":hover": {
|
|
25
|
-
background:
|
|
25
|
+
background: c.colorBrandBackgroundHover,
|
|
26
26
|
cursor: "pointer"
|
|
27
27
|
}
|
|
28
28
|
},
|
|
29
29
|
launcher_icon: {
|
|
30
30
|
fontSize: "24px",
|
|
31
|
-
|
|
31
|
+
"& img": {
|
|
32
|
+
maxWidth: "32px",
|
|
33
|
+
maxHeight: "32px",
|
|
34
|
+
verticalAlign: "text-top"
|
|
35
|
+
}
|
|
32
36
|
},
|
|
33
37
|
title: {
|
|
34
38
|
height: "48px",
|
|
@@ -54,47 +58,49 @@ const c = h({
|
|
|
54
58
|
textAlign: "center"
|
|
55
59
|
}
|
|
56
60
|
});
|
|
57
|
-
function
|
|
61
|
+
function b({
|
|
58
62
|
hamburger: e,
|
|
59
|
-
onClickHome:
|
|
60
|
-
userStatus:
|
|
61
|
-
applicationName:
|
|
63
|
+
onClickHome: r,
|
|
64
|
+
userStatus: i,
|
|
65
|
+
applicationName: t,
|
|
66
|
+
applicationIcon: l
|
|
62
67
|
}) {
|
|
63
|
-
const
|
|
64
|
-
return /* @__PURE__ */ n("div", { className:
|
|
65
|
-
e ? /* @__PURE__ */ n("div", { className:
|
|
66
|
-
/* @__PURE__ */ n("div", { className:
|
|
67
|
-
/* @__PURE__ */ n("div", { className:
|
|
68
|
-
/* @__PURE__ */ n("div", { className:
|
|
68
|
+
const a = s();
|
|
69
|
+
return /* @__PURE__ */ n("div", { className: a.root, children: /* @__PURE__ */ h("div", { className: a.appBar, children: [
|
|
70
|
+
e ? /* @__PURE__ */ n("div", { className: a.launcher, children: e }) : null,
|
|
71
|
+
/* @__PURE__ */ n("div", { className: a.launcher, children: /* @__PURE__ */ n(f, { applicationIcon: l, onClick: r }) }),
|
|
72
|
+
/* @__PURE__ */ n("div", { className: a.title, children: /* @__PURE__ */ n(u, { weight: "semibold", children: t }) }),
|
|
73
|
+
/* @__PURE__ */ n("div", { className: a.actions, children: /* @__PURE__ */ n(k, { status: i }) })
|
|
69
74
|
] }) });
|
|
70
75
|
}
|
|
71
|
-
function
|
|
72
|
-
const i =
|
|
73
|
-
return /* @__PURE__ */ n("a", { tabIndex: 0, ...l, className: i.home, "aria-label": "Accueil", ref:
|
|
76
|
+
function f({ applicationIcon: e, onClick: r }) {
|
|
77
|
+
const i = s(), t = m(), l = o(r);
|
|
78
|
+
return /* @__PURE__ */ n("a", { tabIndex: 0, ...l, className: i.home, "aria-label": "Accueil", ref: t, children: e ? /* @__PURE__ */ n("span", { className: i.launcher_icon, children: e }) : /* @__PURE__ */ n(g, { name: "genericapp", className: i.launcher_icon }) });
|
|
74
79
|
}
|
|
75
|
-
function
|
|
76
|
-
const
|
|
80
|
+
function k({ status: e }) {
|
|
81
|
+
const r = s();
|
|
77
82
|
if (e.isLoading)
|
|
78
|
-
return /* @__PURE__ */ n(
|
|
83
|
+
return /* @__PURE__ */ n(x, {});
|
|
79
84
|
if (e.errorMessage)
|
|
80
|
-
return /* @__PURE__ */
|
|
85
|
+
return /* @__PURE__ */ h("div", { children: [
|
|
81
86
|
"Oops... ",
|
|
82
87
|
e.errorMessage
|
|
83
88
|
] });
|
|
84
89
|
if (e.isAuthenticated) {
|
|
85
|
-
const
|
|
86
|
-
return /* @__PURE__ */ n("a", { tabIndex: 0, className:
|
|
90
|
+
const t = e.userName ?? "", l = o(e.onClickSignIn);
|
|
91
|
+
return /* @__PURE__ */ n("a", { tabIndex: 0, className: r.userActionButton, ...l, children: /* @__PURE__ */ n(d, { "aria-label": t, name: t }) });
|
|
87
92
|
}
|
|
88
|
-
const
|
|
89
|
-
return /* @__PURE__ */ n("a", { tabIndex: 0, className:
|
|
93
|
+
const i = o(e.onClickSignOut);
|
|
94
|
+
return /* @__PURE__ */ n("a", { tabIndex: 0, className: r.userActionButton, ...i, children: /* @__PURE__ */ n(d, { "aria-label": "Non connecté" }) });
|
|
90
95
|
}
|
|
91
|
-
const
|
|
96
|
+
const o = (e) => ({
|
|
92
97
|
onClick: e,
|
|
93
|
-
onKeyUp: (
|
|
94
|
-
(
|
|
98
|
+
onKeyUp: (i) => {
|
|
99
|
+
(i.key === "Enter" || i.key === " ") && (e(), i.preventDefault());
|
|
95
100
|
}
|
|
96
101
|
});
|
|
97
102
|
export {
|
|
98
|
-
|
|
103
|
+
b as TitleBar,
|
|
104
|
+
k as User
|
|
99
105
|
};
|
|
100
106
|
//# sourceMappingURL=TitleBar.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TitleBar.js","sources":["../../../src/lib/applicationshell/TitleBar.tsx"],"sourcesContent":["import { Avatar, makeStyles, Spinner, Text, tokens, useKeyboardNavAttribute } from \"@fluentui/react-components\";\nimport {
|
|
1
|
+
{"version":3,"file":"TitleBar.js","sources":["../../../src/lib/applicationshell/TitleBar.tsx"],"sourcesContent":["import { Avatar, makeStyles, Spinner, Text, tokens, useKeyboardNavAttribute } from \"@fluentui/react-components\";\nimport { KeyboardEventHandler, ReactNode } from \"react\";\nimport { UserStatus } from \"./ApplicationShell.types\";\nimport { Icon } from \"@seij/common-ui-icons\";\n\nconst useTitleBarStyles = makeStyles({\n root: {\n height: \"48px\",\n lineHeight: \"48px\",\n width: \"100%\",\n },\n appBar: {\n display: \"flex\",\n color: tokens.colorNeutralForegroundOnBrand,\n backgroundColor: tokens.colorBrandBackground,\n width: \"100%\",\n maxWidth: \"100%\",\n },\n launcher: {\n width: \"48px\",\n minWidth: \"48px\",\n height: \"48px\",\n lineHeight: \"48px\",\n flex: 0,\n textAlign: \"center\",\n \":hover\": {\n background: tokens.colorBrandBackgroundHover,\n cursor: \"pointer\",\n },\n },\n launcher_icon: {\n fontSize: \"24px\",\n \"& img\": {\n maxWidth: \"32px\",\n maxHeight: \"32px\",\n verticalAlign: \"text-top\",\n },\n },\n title: {\n height: \"48px\",\n flex: 1,\n whiteSpace: \"nowrap\",\n },\n actions: {\n height: \"48px\",\n minWidth: \"48px\",\n flex: 0,\n display: \"flex\",\n justifyContent: \"space-around\",\n },\n home: {\n width: \"100%\",\n height: \"100%\",\n display: \"inline-block\",\n },\n userActionButton: {\n width: \"100%\",\n height: \"100%\",\n display: \"inline-block\",\n textAlign: \"center\",\n },\n});\n\nexport function TitleBar({\n hamburger,\n onClickHome,\n userStatus,\n applicationName,\n applicationIcon,\n}: {\n userStatus: UserStatus;\n applicationName: ReactNode;\n applicationIcon?: ReactNode;\n hamburger: ReactNode | null;\n onClickHome: () => void;\n}) {\n const styles = useTitleBarStyles();\n return (\n <div className={styles.root}>\n <div className={styles.appBar}>\n {hamburger ? <div className={styles.launcher}>{hamburger}</div> : null}\n <div className={styles.launcher}>\n <Home applicationIcon={applicationIcon} onClick={onClickHome} />\n </div>\n <div className={styles.title}>\n <Text weight=\"semibold\">{applicationName}</Text>\n </div>\n <div className={styles.actions}>\n <User status={userStatus} />\n </div>\n </div>\n </div>\n );\n}\n\nfunction Home({ applicationIcon, onClick }: { applicationIcon?: ReactNode; onClick: () => void }) {\n const styles = useTitleBarStyles();\n const ref = useKeyboardNavAttribute<HTMLAnchorElement>();\n const onClickHandlers = createClickHandlers(onClick);\n return (\n <a tabIndex={0} {...onClickHandlers} className={styles.home} aria-label=\"Accueil\" ref={ref}>\n {applicationIcon ? (\n <span className={styles.launcher_icon}>{applicationIcon}</span>\n ) : (\n <Icon name=\"genericapp\" className={styles.launcher_icon} />\n )}\n </a>\n );\n}\n\nexport function User({ status }: { status: UserStatus }) {\n const styles = useTitleBarStyles();\n\n if (status.isLoading) {\n return <Spinner />;\n }\n\n if (status.errorMessage) {\n return <div>Oops... {status.errorMessage}</div>;\n }\n\n if (status.isAuthenticated) {\n const name = status.userName ?? \"\";\n const onClickHandlers = createClickHandlers(status.onClickSignIn);\n return (\n <a tabIndex={0} className={styles.userActionButton} {...onClickHandlers}>\n <Avatar aria-label={name} name={name} />\n </a>\n );\n }\n\n const onClickHandlers = createClickHandlers(status.onClickSignOut);\n\n return (\n <a tabIndex={0} className={styles.userActionButton} {...onClickHandlers}>\n <Avatar aria-label=\"Non connecté\" />\n </a>\n );\n}\n\nconst createClickHandlers = (onClick: () => void) => {\n const handleKeyUp: KeyboardEventHandler<HTMLAnchorElement> = (e) => {\n const correct = e.key === \"Enter\" || e.key === \" \";\n if (correct) {\n onClick();\n e.preventDefault();\n }\n };\n return {\n onClick: onClick,\n onKeyUp: handleKeyUp,\n };\n};\n"],"names":["useTitleBarStyles","makeStyles","tokens","TitleBar","hamburger","onClickHome","userStatus","applicationName","applicationIcon","styles","jsx","jsxs","Home","Text","User","onClick","ref","useKeyboardNavAttribute","onClickHandlers","createClickHandlers","Icon","status","Spinner","name","Avatar","e"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ButtonBar.d.ts","sourceRoot":"","sources":["../../../src/lib/button_bar/ButtonBar.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,
|
|
1
|
+
{"version":3,"file":"ButtonBar.d.ts","sourceRoot":"","sources":["../../../src/lib/button_bar/ButtonBar.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAa1C,wBAAgB,SAAS,CAAC,EACxB,QAAQ,EACR,OAAmB,GACpB,EAAE;IACD,OAAO,CAAC,EAAE,SAAS,GAAG,sBAAsB,CAAC;CAC9C,GAAG,iBAAiB,2CAOpB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ButtonBar.js","sources":["../../../src/lib/button_bar/ButtonBar.tsx"],"sourcesContent":["import { makeStyles, mergeClasses, tokens } from \"@fluentui/react-components\";\nimport { PropsWithChildren
|
|
1
|
+
{"version":3,"file":"ButtonBar.js","sources":["../../../src/lib/button_bar/ButtonBar.tsx"],"sourcesContent":["import { makeStyles, mergeClasses, tokens } from \"@fluentui/react-components\";\nimport { PropsWithChildren } from \"react\";\n\nconst useStyles = makeStyles({\n root: {\n display: \"flex\",\n columnGap: tokens.spacingHorizontalM,\n },\n variant_table_bottom_actions: {\n marginTop: tokens.spacingVerticalL,\n justifyContent: \"flex-end\",\n },\n});\n\nexport function ButtonBar({\n children,\n variant = \"default\",\n}: {\n variant?: \"default\" | \"table_bottom_actions\";\n} & PropsWithChildren) {\n const styles = useStyles();\n const classNames = mergeClasses(\n styles.root,\n variant === \"table_bottom_actions\" ? styles.variant_table_bottom_actions : undefined,\n );\n return <div className={classNames}>{children}</div>;\n}\n"],"names":["useStyles","makeStyles","tokens","ButtonBar","children","variant","styles","classNames","mergeClasses","jsx"],"mappings":";;AAGA,MAAMA,IAAYC,EAAW;AAAA,EAC3B,MAAM;AAAA,IACJ,SAAS;AAAA,IACT,WAAWC,EAAO;AAAA,EAAA;AAAA,EAEpB,8BAA8B;AAAA,IAC5B,WAAWA,EAAO;AAAA,IAClB,gBAAgB;AAAA,EAAA;AAEpB,CAAC;AAEM,SAASC,EAAU;AAAA,EACxB,UAAAC;AAAA,EACA,SAAAC,IAAU;AACZ,GAEuB;AACrB,QAAMC,IAASN,EAAA,GACTO,IAAaC;AAAA,IACjBF,EAAO;AAAA,IACPD,MAAY,yBAAyBC,EAAO,+BAA+B;AAAA,EAAA;AAE7E,SAAO,gBAAAG,EAAC,OAAA,EAAI,WAAWF,GAAa,UAAAH,EAAA,CAAS;AAC/C;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"currencysymbol.js","sources":["../../../src/lib/commons/currencysymbol.ts"],"sourcesContent":["import { toCurrencySymbol } from \"@seij/common-types\";\n\nexport function toCurrencySymbolSafe(code: string | null | undefined): string | undefined {\n if (code === null) return undefined;\n if (code === undefined) return code;\n if (code.length == 0) return code;\n if (code.length != 3) return code;\n try {\n return toCurrencySymbol(code);\n } catch (
|
|
1
|
+
{"version":3,"file":"currencysymbol.js","sources":["../../../src/lib/commons/currencysymbol.ts"],"sourcesContent":["import { toCurrencySymbol } from \"@seij/common-types\";\n\nexport function toCurrencySymbolSafe(code: string | null | undefined): string | undefined {\n if (code === null) return undefined;\n if (code === undefined) return code;\n if (code.length == 0) return code;\n if (code.length != 3) return code;\n try {\n return toCurrencySymbol(code);\n } catch (_) {\n return code;\n }\n}\n"],"names":["toCurrencySymbolSafe","code","toCurrencySymbol"],"mappings":";AAEO,SAASA,EAAqBC,GAAqD;AACxF,MAAIA,MAAS,MAGb;AAAA,QAFIA,MAAS,UACTA,EAAK,UAAU,KACfA,EAAK,UAAU,EAAG,QAAOA;AAC7B,QAAI;AACF,aAAOC,EAAiBD,CAAI;AAAA,IAC9B,QAAY;AACV,aAAOA;AAAA,IACT;AAAA;AACF;"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { jsxs as e, jsx as t } from "react/jsx-runtime";
|
|
2
|
-
import { MessageBar as s, MessageBarBody as a, MessageBarActions as
|
|
3
|
-
import { DismissRegular as c } from "@fluentui/react-icons";
|
|
2
|
+
import { MessageBar as s, MessageBarBody as a, MessageBarActions as c, Button as l } from "@fluentui/react-components";
|
|
4
3
|
import { isNil as m } from "lodash-es";
|
|
5
|
-
import { useI18n as
|
|
4
|
+
import { useI18n as u } from "../i18n/i18n.react.js";
|
|
5
|
+
import { Icon as d } from "@seij/common-ui-icons";
|
|
6
6
|
const _ = ({ error: r, onClose: n }) => {
|
|
7
|
-
const { t: o } =
|
|
7
|
+
const { t: o } = u();
|
|
8
8
|
if (!r) return null;
|
|
9
9
|
const i = r.title ?? o("errorbox_unknown_error", { error: r.status ? "" + r.status : o("errorbox_unknown_error_status") });
|
|
10
10
|
return /* @__PURE__ */ e(s, { intent: "error", layout: "multiline", children: [
|
|
@@ -13,9 +13,9 @@ const _ = ({ error: r, onClose: n }) => {
|
|
|
13
13
|
/* @__PURE__ */ t("div", { children: r.detail })
|
|
14
14
|
] }),
|
|
15
15
|
!m(n) && /* @__PURE__ */ t(
|
|
16
|
-
|
|
16
|
+
c,
|
|
17
17
|
{
|
|
18
|
-
containerAction: /* @__PURE__ */ t(
|
|
18
|
+
containerAction: /* @__PURE__ */ t(l, { appearance: "transparent", icon: /* @__PURE__ */ t(d, { name: "dismiss" }), onClick: n })
|
|
19
19
|
}
|
|
20
20
|
)
|
|
21
21
|
] });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ErrorBox.js","sources":["../../../src/lib/errorbox/ErrorBox.tsx"],"sourcesContent":["import { Problem } from \"@seij/common-types\";\nimport { Button, MessageBar, MessageBarActions, MessageBarBody } from \"@fluentui/react-components\";\nimport {
|
|
1
|
+
{"version":3,"file":"ErrorBox.js","sources":["../../../src/lib/errorbox/ErrorBox.tsx"],"sourcesContent":["import { Problem } from \"@seij/common-types\";\nimport { Button, MessageBar, MessageBarActions, MessageBarBody } from \"@fluentui/react-components\";\nimport { isNil } from \"lodash-es\";\nimport { useI18n } from \"../i18n/i18n.react\";\nimport { Icon } from \"@seij/common-ui-icons\";\n\nexport const ErrorBox = ({ error, onClose }: { error: Problem | null | undefined; onClose?: () => void }) => {\n const { t } = useI18n();\n\n if (!error) return null;\n const regularMessage =\n error.title ??\n t(\"errorbox_unknown_error\", { error: error.status ? \"\" + error.status : t(\"errorbox_unknown_error_status\") });\n\n return (\n <MessageBar intent=\"error\" layout=\"multiline\">\n <MessageBarBody>\n <div>{regularMessage}</div>\n <div>{error.detail}</div>\n </MessageBarBody>\n {!isNil(onClose) && (\n <MessageBarActions\n containerAction={<Button appearance=\"transparent\" icon={<Icon name=\"dismiss\" />} onClick={onClose} />}\n ></MessageBarActions>\n )}\n </MessageBar>\n );\n};\n"],"names":["ErrorBox","error","onClose","t","useI18n","regularMessage","jsxs","MessageBar","MessageBarBody","jsx","isNil","MessageBarActions","Button","Icon"],"mappings":";;;;;AAMO,MAAMA,IAAW,CAAC,EAAE,OAAAC,GAAO,SAAAC,QAA2E;AAC3G,QAAM,EAAE,GAAAC,EAAA,IAAMC,EAAA;AAEd,MAAI,CAACH,EAAO,QAAO;AACnB,QAAMI,IACJJ,EAAM,SACNE,EAAE,0BAA0B,EAAE,OAAOF,EAAM,SAAS,KAAKA,EAAM,SAASE,EAAE,+BAA+B,GAAG;AAE9G,SACE,gBAAAG,EAACC,GAAA,EAAW,QAAO,SAAQ,QAAO,aAChC,UAAA;AAAA,IAAA,gBAAAD,EAACE,GAAA,EACC,UAAA;AAAA,MAAA,gBAAAC,EAAC,SAAK,UAAAJ,EAAA,CAAe;AAAA,MACrB,gBAAAI,EAAC,OAAA,EAAK,UAAAR,EAAM,OAAA,CAAO;AAAA,IAAA,GACrB;AAAA,IACC,CAACS,EAAMR,CAAO,KACb,gBAAAO;AAAA,MAACE;AAAA,MAAA;AAAA,QACC,iBAAiB,gBAAAF,EAACG,GAAA,EAAO,YAAW,eAAc,MAAM,gBAAAH,EAACI,GAAA,EAAK,MAAK,UAAA,CAAU,GAAI,SAASX,EAAA,CAAS;AAAA,MAAA;AAAA,IAAA;AAAA,EACpG,GAEL;AAEJ;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i18n.detect.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/i18n.detect.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"i18n.detect.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/i18n.detect.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,MAAM,GAAG,MAAM,CAAC;AAK5B,wBAAgB,SAAS,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAM9C;AAmBD,wBAAgB,kBAAkB,IAAI,MAAM,CAO3C;AAGD,wBAAgB,kBAAkB,CAAC,IAAI,EAAE;IACvC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAChC,GAAG,MAAM,CAGT;AAGD,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,UAKxC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i18n.react.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/i18n.react.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"i18n.react.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/i18n.react.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAkE,MAAM,OAAO,CAAC;AAEvF,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAQpC,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B;AAED,wBAAgB,YAAY,CAAC,EAAE,QAAQ,EAAE,EAAE,iBAAiB,kDAsB3D;AAED,wBAAgB,OAAO,IAAI,IAAI,CAI9B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i18n.react.js","sources":["../../../src/lib/i18n/i18n.react.tsx"],"sourcesContent":["
|
|
1
|
+
{"version":3,"file":"i18n.react.js","sources":["../../../src/lib/i18n/i18n.react.tsx"],"sourcesContent":["import React, { createContext, useContext, useEffect, useMemo, useState } from \"react\";\nimport { I18nService, I18nServiceInstance } from \"./i18n.service\";\nimport { I18n } from \"./i18n.types\";\n\ntype I18nCtxType = {\n i18nService: I18nService;\n lastChange: number;\n};\nconst I18nCtx = createContext<I18nCtxType>({ i18nService: I18nServiceInstance, lastChange: 0 });\n\nexport interface I18nProviderProps {\n children: React.ReactNode;\n}\n\nexport function I18nProvider({ children }: I18nProviderProps) {\n // Detects the locale: first used the forced one, then initial, then use autodetection\n\n const [instanceTs, setInstanceTs] = useState(0);\n const [ready, setReady] = useState<boolean>(false);\n const value: I18nCtxType = useMemo(\n () => ({\n i18nService: I18nServiceInstance,\n lastChange: instanceTs,\n }),\n [instanceTs],\n );\n\n useEffect(() => {\n I18nServiceInstance.readyPromise.then(() => {\n setReady(true);\n });\n }, []);\n\n if (!ready) return null;\n\n return <I18nCtx.Provider value={value}>{children}</I18nCtx.Provider>;\n}\n\nexport function useI18n(): I18n {\n const v = useContext(I18nCtx);\n if (!v) throw new Error(\"useI18n must be used within I18nProvider\");\n return v.i18nService;\n}\n"],"names":["I18nCtx","createContext","I18nServiceInstance","I18nProvider","children","instanceTs","setInstanceTs","useState","ready","setReady","value","useMemo","useEffect","jsx","useI18n","v","useContext"],"mappings":";;;AAQA,MAAMA,IAAUC,EAA2B,EAAE,aAAaC,GAAqB,YAAY,GAAG;AAMvF,SAASC,EAAa,EAAE,UAAAC,KAA+B;AAG5D,QAAM,CAACC,GAAYC,CAAa,IAAIC,EAAS,CAAC,GACxC,CAACC,GAAOC,CAAQ,IAAIF,EAAkB,EAAK,GAC3CG,IAAqBC;AAAA,IACzB,OAAO;AAAA,MACL,aAAaT;AAAA,MACb,YAAYG;AAAA,IAAA;AAAA,IAEd,CAACA,CAAU;AAAA,EAAA;AASb,SANAO,EAAU,MAAM;AACd,IAAAV,EAAoB,aAAa,KAAK,MAAM;AAC1C,MAAAO,EAAS,EAAI;AAAA,IACf,CAAC;AAAA,EACH,GAAG,CAAA,CAAE,GAEAD,IAEE,gBAAAK,EAACb,EAAQ,UAAR,EAAiB,OAAAU,GAAe,UAAAN,EAAA,CAAS,IAF9B;AAGrB;AAEO,SAASU,IAAgB;AAC9B,QAAMC,IAAIC,EAAWhB,CAAO;AAC5B,MAAI,CAACe,EAAG,OAAM,IAAI,MAAM,0CAA0C;AAClE,SAAOA,EAAE;AACX;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i18n.types.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/i18n.types.ts"],"names":[],"mappings":"AACA,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC9C,MAAM,MAAM,OAAO,GAAG;IACpB,SAAS,EAAE;QACT,WAAW,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;IACjD,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACjD,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;CAC9C,CAAC;AAEF,MAAM,WAAW,IAAI;IACnB,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;IACxD,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,CAAC,CAAC,MAAM,EAAE,MAAM,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC;IAC5G,UAAU,CAAC,CAAC,EAAE,IAAI,GAAG,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACrD,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAChD,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACpD,cAAc,CAAC,CAAC,EAAE,IAAI,GAAG,MAAM,GAAG,MAAM,CAAC;IACzC,oBAAoB,IAAI,MAAM,CAAC;IAC/B,kBAAkB,IAAI,MAAM,CAAC;IAC7B,uBAAuB,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,CAAC;IACjD,4BAA4B,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,CAAC;IACtD,SAAS,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC/C,SAAS,IAAI,MAAM,CAAC;IACpB,iBAAiB,CAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"i18n.types.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/i18n.types.ts"],"names":[],"mappings":"AACA,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC9C,MAAM,MAAM,OAAO,GAAG;IACpB,SAAS,EAAE;QACT,WAAW,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;IACjD,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACjD,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;CAC9C,CAAC;AAEF,MAAM,WAAW,IAAI;IACnB,CAAC,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;IACxD,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,CAAC,CAAC,MAAM,EAAE,MAAM,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC;IAC5G,UAAU,CAAC,CAAC,EAAE,IAAI,GAAG,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACrD,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAChD,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACpD,cAAc,CAAC,CAAC,EAAE,IAAI,GAAG,MAAM,GAAG,MAAM,CAAC;IACzC,oBAAoB,IAAI,MAAM,CAAC;IAC/B,kBAAkB,IAAI,MAAM,CAAC;IAC7B,uBAAuB,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,CAAC;IACjD,4BAA4B,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,CAAC;IACtD,SAAS,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC/C,SAAS,IAAI,MAAM,CAAC;IACpB,iBAAiB,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC;CACtE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,gBAAgB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/i18n/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACnF,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,cAAc,CAAC"}
|
|
@@ -1,47 +1,47 @@
|
|
|
1
1
|
import { jsxs as r, jsx as e } from "react/jsx-runtime";
|
|
2
2
|
import { useState as d } from "react";
|
|
3
3
|
import { Tooltip as E, Button as a } from "@fluentui/react-components";
|
|
4
|
-
import { toProblem as
|
|
5
|
-
import {
|
|
6
|
-
function
|
|
4
|
+
import { toProblem as c } from "@seij/common-types";
|
|
5
|
+
import { Icon as g } from "@seij/common-ui-icons";
|
|
6
|
+
function K({
|
|
7
7
|
children: f,
|
|
8
8
|
editor: h,
|
|
9
9
|
onEditStart: u,
|
|
10
10
|
onEditOK: y,
|
|
11
11
|
onEditCancel: m
|
|
12
12
|
}) {
|
|
13
|
-
const [p, n] = d(!1), [
|
|
13
|
+
const [p, n] = d(!1), [o, t] = d(null), [s, i] = d(!1), v = async () => {
|
|
14
14
|
try {
|
|
15
15
|
t(null), await u(), n(!0);
|
|
16
16
|
} catch (l) {
|
|
17
|
-
t(
|
|
17
|
+
t(c(l));
|
|
18
18
|
}
|
|
19
19
|
}, x = async () => {
|
|
20
20
|
try {
|
|
21
21
|
t(null), i(!0), await y(), n(!1), i(!1);
|
|
22
22
|
} catch (l) {
|
|
23
|
-
t(
|
|
23
|
+
t(c(l)), i(!1);
|
|
24
24
|
}
|
|
25
25
|
}, C = async () => {
|
|
26
26
|
try {
|
|
27
27
|
t(null), i(!0), await m(), n(!1), i(!1);
|
|
28
28
|
} catch (l) {
|
|
29
|
-
t(
|
|
29
|
+
t(c(l)), i(!1);
|
|
30
30
|
}
|
|
31
31
|
};
|
|
32
32
|
return p ? /* @__PURE__ */ r("div", { children: [
|
|
33
33
|
/* @__PURE__ */ r("div", { style: { display: "flex", justifyContent: "flex-start" }, children: [
|
|
34
34
|
/* @__PURE__ */ e("div", { children: h }),
|
|
35
|
-
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(a, { disabled:
|
|
36
|
-
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(a, { disabled:
|
|
35
|
+
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(a, { disabled: s, onClick: x, children: "OK" }) }),
|
|
36
|
+
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(a, { disabled: s, onClick: C, children: "Cancel" }) })
|
|
37
37
|
] }),
|
|
38
|
-
|
|
38
|
+
o && /* @__PURE__ */ e("div", { style: { color: "red" }, children: o.title })
|
|
39
39
|
] }) : /* @__PURE__ */ r("div", { style: { display: "flex", justifyContent: "flex-start" }, children: [
|
|
40
40
|
/* @__PURE__ */ e("div", { children: f }),
|
|
41
|
-
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(E, { content: "Large with calendar icon only", relationship: "label", children: /* @__PURE__ */ e(a, { size: "small", icon: /* @__PURE__ */ e(g, {}), onClick: v }) }) })
|
|
41
|
+
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(E, { content: "Large with calendar icon only", relationship: "label", children: /* @__PURE__ */ e(a, { size: "small", icon: /* @__PURE__ */ e(g, { name: "edit" }), onClick: v }) }) })
|
|
42
42
|
] });
|
|
43
43
|
}
|
|
44
44
|
export {
|
|
45
|
-
|
|
45
|
+
K as InlineEdit
|
|
46
46
|
};
|
|
47
47
|
//# sourceMappingURL=InlineEdit.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InlineEdit.js","sources":["../../../src/lib/inlineedit/InlineEdit.tsx"],"sourcesContent":["import { ReactNode, useState } from \"react\";\nimport { Button, Tooltip } from \"@fluentui/react-components\";\nimport { Problem, toProblem } from \"@seij/common-types\";\nimport {
|
|
1
|
+
{"version":3,"file":"InlineEdit.js","sources":["../../../src/lib/inlineedit/InlineEdit.tsx"],"sourcesContent":["import { ReactNode, useState } from \"react\";\nimport { Button, Tooltip } from \"@fluentui/react-components\";\nimport { Problem, toProblem } from \"@seij/common-types\";\nimport { Icon } from \"@seij/common-ui-icons\";\n\nexport function InlineEdit({\n children,\n editor,\n onEditStart,\n onEditOK,\n onEditCancel,\n}: {\n children?: ReactNode | ReactNode[] | null;\n editor: ReactNode;\n onEditStart: () => Promise<any>;\n onEditOK: () => Promise<any>;\n onEditCancel: () => Promise<any>;\n}) {\n const [editing, setEditing] = useState<boolean>(false);\n const [error, setError] = useState<Problem | null>(null);\n const [pending, setPending] = useState<boolean>(false);\n\n const handleEdit = async () => {\n try {\n setError(null);\n await onEditStart();\n setEditing(true);\n } catch (err) {\n setError(toProblem(err));\n }\n };\n\n const handleEditOK = async () => {\n try {\n setError(null);\n setPending(true);\n await onEditOK();\n setEditing(false);\n setPending(false);\n } catch (err) {\n setError(toProblem(err));\n setPending(false);\n }\n };\n const handleEditCancel = async () => {\n try {\n setError(null);\n setPending(true);\n await onEditCancel();\n setEditing(false);\n setPending(false);\n } catch (err: any) {\n setError(toProblem(err));\n setPending(false);\n }\n };\n\n if (!editing)\n return (\n <div style={{ display: \"flex\", justifyContent: \"flex-start\" }}>\n <div>{children}</div>\n <div>\n <Tooltip content=\"Large with calendar icon only\" relationship=\"label\">\n <Button size=\"small\" icon={<Icon name=\"edit\" />} onClick={handleEdit} />\n </Tooltip>\n </div>\n </div>\n );\n\n return (\n <div>\n <div style={{ display: \"flex\", justifyContent: \"flex-start\" }}>\n <div>{editor}</div>\n <div>\n <Button disabled={pending} onClick={handleEditOK}>\n OK\n </Button>\n </div>\n <div>\n <Button disabled={pending} onClick={handleEditCancel}>\n Cancel\n </Button>\n </div>\n </div>\n {error && <div style={{ color: \"red\" }}>{error.title}</div>}\n </div>\n );\n}\n"],"names":["InlineEdit","children","editor","onEditStart","onEditOK","onEditCancel","editing","setEditing","useState","error","setError","pending","setPending","handleEdit","err","toProblem","handleEditOK","handleEditCancel","jsxs","jsx","Button","Tooltip","Icon"],"mappings":";;;;;AAKO,SAASA,EAAW;AAAA,EACzB,UAAAC;AAAA,EACA,QAAAC;AAAA,EACA,aAAAC;AAAA,EACA,UAAAC;AAAA,EACA,cAAAC;AACF,GAMG;AACD,QAAM,CAACC,GAASC,CAAU,IAAIC,EAAkB,EAAK,GAC/C,CAACC,GAAOC,CAAQ,IAAIF,EAAyB,IAAI,GACjD,CAACG,GAASC,CAAU,IAAIJ,EAAkB,EAAK,GAE/CK,IAAa,YAAY;AAC7B,QAAI;AACF,MAAAH,EAAS,IAAI,GACb,MAAMP,EAAA,GACNI,EAAW,EAAI;AAAA,IACjB,SAASO,GAAK;AACZ,MAAAJ,EAASK,EAAUD,CAAG,CAAC;AAAA,IACzB;AAAA,EACF,GAEME,IAAe,YAAY;AAC/B,QAAI;AACF,MAAAN,EAAS,IAAI,GACbE,EAAW,EAAI,GACf,MAAMR,EAAA,GACNG,EAAW,EAAK,GAChBK,EAAW,EAAK;AAAA,IAClB,SAASE,GAAK;AACZ,MAAAJ,EAASK,EAAUD,CAAG,CAAC,GACvBF,EAAW,EAAK;AAAA,IAClB;AAAA,EACF,GACMK,IAAmB,YAAY;AACnC,QAAI;AACF,MAAAP,EAAS,IAAI,GACbE,EAAW,EAAI,GACf,MAAMP,EAAA,GACNE,EAAW,EAAK,GAChBK,EAAW,EAAK;AAAA,IAClB,SAASE,GAAU;AACjB,MAAAJ,EAASK,EAAUD,CAAG,CAAC,GACvBF,EAAW,EAAK;AAAA,IAClB;AAAA,EACF;AAEA,SAAKN,sBAaF,OAAA,EACC,UAAA;AAAA,IAAA,gBAAAY,EAAC,SAAI,OAAO,EAAE,SAAS,QAAQ,gBAAgB,gBAC7C,UAAA;AAAA,MAAA,gBAAAC,EAAC,SAAK,UAAAjB,EAAA,CAAO;AAAA,MACb,gBAAAiB,EAAC,SACC,UAAA,gBAAAA,EAACC,GAAA,EAAO,UAAUT,GAAS,SAASK,GAAc,UAAA,KAAA,CAElD,EAAA,CACF;AAAA,MACA,gBAAAG,EAAC,SACC,UAAA,gBAAAA,EAACC,GAAA,EAAO,UAAUT,GAAS,SAASM,GAAkB,UAAA,SAAA,CAEtD,EAAA,CACF;AAAA,IAAA,GACF;AAAA,IACCR,uBAAU,OAAA,EAAI,OAAO,EAAE,OAAO,SAAU,UAAAA,EAAM,MAAA,CAAM;AAAA,EAAA,GACvD,IA1BE,gBAAAS,EAAC,SAAI,OAAO,EAAE,SAAS,QAAQ,gBAAgB,gBAC7C,UAAA;AAAA,IAAA,gBAAAC,EAAC,SAAK,UAAAlB,GAAS;AAAA,IACf,gBAAAkB,EAAC,SACC,UAAA,gBAAAA,EAACE,GAAA,EAAQ,SAAQ,iCAAgC,cAAa,SAC5D,UAAA,gBAAAF,EAACC,GAAA,EAAO,MAAK,SAAQ,wBAAOE,GAAA,EAAK,MAAK,QAAO,GAAI,SAAST,EAAA,CAAY,EAAA,CACxE,EAAA,CACF;AAAA,EAAA,GACF;AAqBN;"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
import { makeStyles as h, tokens as d, Input as
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import { useI18n as
|
|
6
|
-
|
|
1
|
+
import { jsxs as b, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { makeStyles as h, tokens as d, Input as v, Caption1 as m, List as I, ListItem as L, Card as w, CardHeader as y, Text as C } from "@fluentui/react-components";
|
|
3
|
+
import { isFunction as S } from "lodash-es";
|
|
4
|
+
import "../i18n/i18n.service.js";
|
|
5
|
+
import { useI18n as _ } from "../i18n/i18n.react.js";
|
|
6
|
+
import { Icon as u } from "@seij/common-ui-icons";
|
|
7
|
+
const N = h({
|
|
7
8
|
noresult: {
|
|
8
9
|
textAlign: "center",
|
|
9
10
|
padding: "1em"
|
|
@@ -17,25 +18,25 @@ function z({
|
|
|
17
18
|
pathFactory: r,
|
|
18
19
|
navigate: t
|
|
19
20
|
}) {
|
|
20
|
-
const
|
|
21
|
+
const p = N(), { t: c } = _(), f = (l) => {
|
|
21
22
|
n && n(l);
|
|
22
|
-
}, g =
|
|
23
|
-
return /* @__PURE__ */
|
|
23
|
+
}, g = S(n), a = c("ListView_search"), x = c("ListView_no_result");
|
|
24
|
+
return /* @__PURE__ */ b("div", { children: [
|
|
24
25
|
g && /* @__PURE__ */ e(
|
|
25
|
-
|
|
26
|
+
v,
|
|
26
27
|
{
|
|
27
28
|
style: { width: "100%" },
|
|
28
|
-
contentBefore: /* @__PURE__ */ e(
|
|
29
|
+
contentBefore: /* @__PURE__ */ e(u, { name: "search", "aria-label": a }),
|
|
29
30
|
value: o,
|
|
30
31
|
placeholder: a,
|
|
31
|
-
onChange: (l) =>
|
|
32
|
+
onChange: (l) => f(l.target.value)
|
|
32
33
|
}
|
|
33
34
|
),
|
|
34
|
-
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(
|
|
35
|
-
i.length === 0 ? /* @__PURE__ */ e("div", { className:
|
|
35
|
+
/* @__PURE__ */ e("div", { children: /* @__PURE__ */ e(M, { activeId: s, items: i, pathFactory: r, navigate: t }) }),
|
|
36
|
+
i.length === 0 ? /* @__PURE__ */ e("div", { className: p.noresult, children: /* @__PURE__ */ e(m, { children: x }) }) : null
|
|
36
37
|
] });
|
|
37
38
|
}
|
|
38
|
-
const
|
|
39
|
+
const k = h({
|
|
39
40
|
root: {
|
|
40
41
|
display: "flex"
|
|
41
42
|
},
|
|
@@ -57,21 +58,21 @@ const M = h({
|
|
|
57
58
|
borderRadius: d.borderRadiusNone
|
|
58
59
|
}
|
|
59
60
|
});
|
|
60
|
-
function
|
|
61
|
+
function M({
|
|
61
62
|
items: i,
|
|
62
63
|
activeId: s,
|
|
63
64
|
pathFactory: o,
|
|
64
65
|
navigate: n
|
|
65
66
|
}) {
|
|
66
|
-
const r =
|
|
67
|
-
return i.length === 0 ? null : /* @__PURE__ */ e(
|
|
68
|
-
|
|
67
|
+
const r = k();
|
|
68
|
+
return i.length === 0 ? null : /* @__PURE__ */ e(I, { navigationMode: "composite", children: i.map((t) => /* @__PURE__ */ e(
|
|
69
|
+
L,
|
|
69
70
|
{
|
|
70
71
|
onAction: () => {
|
|
71
72
|
n(o(t));
|
|
72
73
|
},
|
|
73
74
|
children: /* @__PURE__ */ e(
|
|
74
|
-
|
|
75
|
+
w,
|
|
75
76
|
{
|
|
76
77
|
role: "gridcell",
|
|
77
78
|
orientation: "horizontal",
|
|
@@ -81,11 +82,11 @@ function V({
|
|
|
81
82
|
n(o(t));
|
|
82
83
|
},
|
|
83
84
|
children: /* @__PURE__ */ e(
|
|
84
|
-
|
|
85
|
+
y,
|
|
85
86
|
{
|
|
86
|
-
header: /* @__PURE__ */ e(
|
|
87
|
-
description: /* @__PURE__ */ e(
|
|
88
|
-
action: /* @__PURE__ */ e(
|
|
87
|
+
header: /* @__PURE__ */ e(C, { weight: "regular", children: t.label ?? /* @__PURE__ */ e("span", { children: " " }) }),
|
|
88
|
+
description: /* @__PURE__ */ e(m, { children: t.description ?? /* @__PURE__ */ e("span", { children: " " }) }),
|
|
89
|
+
action: /* @__PURE__ */ e(u, { name: "chevron_right_filled" })
|
|
89
90
|
}
|
|
90
91
|
)
|
|
91
92
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ListView.js","sources":["../../../src/lib/listview/ListView.tsx"],"sourcesContent":["import {\n Caption1,\n Card,\n CardHeader,\n Input,\n List,\n ListItem,\n makeStyles,\n Text,\n tokens,\n} from \"@fluentui/react-components\";\nimport {
|
|
1
|
+
{"version":3,"file":"ListView.js","sources":["../../../src/lib/listview/ListView.tsx"],"sourcesContent":["import {\n Caption1,\n Card,\n CardHeader,\n Input,\n List,\n ListItem,\n makeStyles,\n Text,\n tokens,\n} from \"@fluentui/react-components\";\n\nimport { isFunction } from \"lodash-es\";\nimport { ReactNode } from \"react\";\nimport { useI18n } from \"../i18n\";\nimport { Icon } from \"@seij/common-ui-icons\";\nexport interface ListItemData {\n id: string;\n label: ReactNode;\n description: ReactNode | null;\n}\n\nconst useStyles = makeStyles({\n noresult: {\n textAlign: \"center\",\n padding: \"1em\",\n },\n});\nexport interface ListViewProps<T extends ListItemData = ListItemData> {\n data: T[];\n activeId: string;\n searchText?: string;\n search?: (input: string) => void;\n pathFactory: (item: T) => string;\n navigate: (url: string) => void;\n}\nexport function ListView<T extends ListItemData>({\n data,\n activeId,\n searchText = \"\",\n search,\n pathFactory,\n navigate,\n}: ListViewProps<T>) {\n const styles = useStyles();\n const { t } = useI18n();\n const handleChange = (value: string) => {\n if (search) search(value);\n };\n const isSearchEnabled = isFunction(search);\n const searchMessage = t(\"ListView_search\");\n const noResultMessage = t(\"ListView_no_result\");\n return (\n <div>\n {isSearchEnabled && (\n <Input\n style={{ width: \"100%\" }}\n contentBefore={<Icon name=\"search\" aria-label={searchMessage} />}\n value={searchText}\n placeholder={searchMessage}\n onChange={(e) => handleChange(e.target.value)}\n />\n )}\n <div>\n <ItemList activeId={activeId} items={data} pathFactory={pathFactory} navigate={navigate} />\n </div>\n {data.length === 0 ? (\n <div className={styles.noresult}>\n <Caption1>{noResultMessage}</Caption1>\n </div>\n ) : null}\n </div>\n );\n}\n\nconst useItemListStyles = makeStyles({\n root: {\n display: \"flex\",\n },\n content: {\n flex: 1,\n },\n title: {\n fontWeight: \"bold\",\n },\n description: {\n fontWeight: \"normal\",\n },\n action: {\n flex: 0,\n },\n\n card: {\n width: \"100%\",\n borderBottom: \"1px solid \" + tokens.colorNeutralStencil1,\n borderRadius: tokens.borderRadiusNone,\n },\n});\n\nfunction ItemList<T extends ListItemData>({\n items,\n activeId,\n pathFactory,\n navigate,\n}: {\n items: T[];\n activeId: string;\n pathFactory: (item: T) => string;\n navigate: (url: string) => void;\n}) {\n const style = useItemListStyles();\n if (items.length === 0) return null;\n return (\n <List navigationMode=\"composite\">\n {items.map((it) => (\n <ListItem\n key={it.id}\n onAction={() => {\n navigate(pathFactory(it));\n }}\n >\n <Card\n role=\"gridcell\"\n orientation=\"horizontal\"\n appearance=\"subtle\"\n className={style.card}\n onClick={() => {\n navigate(pathFactory(it));\n }}\n >\n <CardHeader\n header={<Text weight=\"regular\">{it.label ?? <span> </span>}</Text>}\n description={<Caption1>{it.description ?? <span> </span>}</Caption1>}\n action={<Icon name=\"chevron_right_filled\" />}\n />\n </Card>\n </ListItem>\n ))}\n </List>\n );\n}\n"],"names":["useStyles","makeStyles","ListView","data","activeId","searchText","search","pathFactory","navigate","styles","t","useI18n","handleChange","value","isSearchEnabled","isFunction","searchMessage","noResultMessage","jsx","Input","Icon","e","ItemList","Caption1","useItemListStyles","tokens","items","style","List","it","ListItem","Card","CardHeader","Text"],"mappings":"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"}
|
|
@@ -2,6 +2,7 @@ import { jsx as f } from "react/jsx-runtime";
|
|
|
2
2
|
import { makeStyles as S, Input as y } from "@fluentui/react-components";
|
|
3
3
|
import { forwardRef as A, useState as h, useEffect as C, useCallback as k } from "react";
|
|
4
4
|
import { Rifm as z } from "rifm";
|
|
5
|
+
import "../i18n/i18n.service.js";
|
|
5
6
|
import { useI18n as F } from "../i18n/i18n.react.js";
|
|
6
7
|
const N = S({
|
|
7
8
|
root: {
|
|
@@ -19,7 +20,7 @@ const N = S({
|
|
|
19
20
|
return `${e}/`;
|
|
20
21
|
}
|
|
21
22
|
return e;
|
|
22
|
-
}, w = (t) => t.length === 2 || t.length === 5 ? `${t}/` : t,
|
|
23
|
+
}, w = (t) => t.length === 2 || t.length === 5 ? `${t}/` : t, L = A((t, e) => {
|
|
23
24
|
const { onValueChange: r, value: o = "", children: n, size: l, defaultValue: x, type: O, ...g } = t, D = N(), { localDatePlaceholder: $, localDateFormattedToISO: d, localDateISOToFormattedInput: p } = F(), [u, c] = h(p(o)), [i, m] = h(o);
|
|
24
25
|
C(() => {
|
|
25
26
|
o !== i && (m(o), c(p(o)));
|
|
@@ -56,6 +57,6 @@ const N = S({
|
|
|
56
57
|
);
|
|
57
58
|
});
|
|
58
59
|
export {
|
|
59
|
-
|
|
60
|
+
L as InputLocalDate
|
|
60
61
|
};
|
|
61
62
|
//# sourceMappingURL=InputLocalDate.js.map
|