synapse-react-client 4.0.5 → 4.0.6
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/SWC.index.d.ts +2 -0
- package/dist/SWC.index.d.ts.map +1 -1
- package/dist/SWC.index.js +47 -41
- package/dist/SWC.index.js.map +1 -1
- package/dist/assets/DefaultColorfulPortalCardBackground.svg +50 -12
- package/dist/assets/DefaultColorfulPortalCardBackground.svg.js +4 -4
- package/dist/assets/DefaultColorfulPortalCardBackground.svg.js.map +1 -1
- package/dist/components/CreateProjectModal/CreateProjectModal.d.ts +2 -1
- package/dist/components/CreateProjectModal/CreateProjectModal.d.ts.map +1 -1
- package/dist/components/CreateProjectModal/CreateProjectModal.js +35 -30
- package/dist/components/CreateProjectModal/CreateProjectModal.js.map +1 -1
- package/dist/components/DataGrid/DataGridWebSocket.d.ts +4 -0
- package/dist/components/DataGrid/DataGridWebSocket.d.ts.map +1 -1
- package/dist/components/DataGrid/DataGridWebSocket.js +47 -37
- package/dist/components/DataGrid/DataGridWebSocket.js.map +1 -1
- package/dist/components/DataGrid/SynapseGrid.d.ts.map +1 -1
- package/dist/components/DataGrid/SynapseGrid.js +193 -152
- package/dist/components/DataGrid/SynapseGrid.js.map +1 -1
- package/dist/components/DataGrid/useDataGridWebsocket.d.ts +6 -1
- package/dist/components/DataGrid/useDataGridWebsocket.d.ts.map +1 -1
- package/dist/components/DataGrid/useDataGridWebsocket.js +78 -69
- package/dist/components/DataGrid/useDataGridWebsocket.js.map +1 -1
- package/dist/components/SynapseTable/SynapseTable.d.ts +6 -1
- package/dist/components/SynapseTable/SynapseTable.d.ts.map +1 -1
- package/dist/components/SynapseTable/SynapseTable.js +123 -93
- package/dist/components/SynapseTable/SynapseTable.js.map +1 -1
- package/dist/components/TextField/TextField.css +1 -0
- package/dist/components/TextField/TextField.d.ts +1 -1
- package/dist/components/TextField/TextField.d.ts.map +1 -1
- package/dist/components/TextField/TextField.js +30 -28
- package/dist/components/TextField/TextField.js.map +1 -1
- package/dist/components/TextField/TextField.module.scss +18 -0
- package/dist/components/TextField/TextField.module.scss.js +12 -0
- package/dist/components/TextField/TextField.module.scss.js.map +1 -0
- package/dist/components/styled/HoverPopover.css +1 -1
- package/dist/components/styled/HoverPopover.d.ts.map +1 -1
- package/dist/components/styled/HoverPopover.js +6 -5
- package/dist/components/styled/HoverPopover.js.map +1 -1
- package/dist/components/styled/HoverPopover.module.scss +2 -1
- package/dist/components/styled/HoverPopover.module.scss.js +1 -1
- package/dist/features/entity/metadata-task/components/MetadataTaskTableActionCell.d.ts +5 -2
- package/dist/features/entity/metadata-task/components/MetadataTaskTableActionCell.d.ts.map +1 -1
- package/dist/features/entity/metadata-task/components/MetadataTaskTableActionCell.js +180 -36
- package/dist/features/entity/metadata-task/components/MetadataTaskTableActionCell.js.map +1 -1
- package/dist/features/entity/metadata-task/components/MetadataTasksPage.d.ts.map +1 -1
- package/dist/features/entity/metadata-task/components/MetadataTasksPage.js +52 -27
- package/dist/features/entity/metadata-task/components/MetadataTasksPage.js.map +1 -1
- package/dist/features/entity/metadata-task/components/MetadataTasksTableAssigneeCell.d.ts +7 -0
- package/dist/features/entity/metadata-task/components/MetadataTasksTableAssigneeCell.d.ts.map +1 -0
- package/dist/features/entity/metadata-task/components/MetadataTasksTableAssigneeCell.js +323 -0
- package/dist/features/entity/metadata-task/components/MetadataTasksTableAssigneeCell.js.map +1 -0
- package/dist/features/entity/metadata-task/hooks/useGetOrCreateGridSessionForSource.d.ts +7 -1
- package/dist/features/entity/metadata-task/hooks/useGetOrCreateGridSessionForSource.d.ts.map +1 -1
- package/dist/features/entity/metadata-task/hooks/useGetOrCreateGridSessionForSource.js +7 -7
- package/dist/features/entity/metadata-task/hooks/useGetOrCreateGridSessionForSource.js.map +1 -1
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask.d.ts +9 -5
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask.d.ts.map +1 -1
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask.js +79 -16
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask.js.map +1 -1
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask_legacy.d.ts +12 -0
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask_legacy.d.ts.map +1 -0
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask_legacy.js +20 -0
- package/dist/features/entity/metadata-task/hooks/useGridSessionForCurationTask_legacy.js.map +1 -0
- package/dist/features/entity/metadata-task/hooks/useMetadataTaskTable.d.ts +3 -3
- package/dist/features/entity/metadata-task/hooks/useMetadataTaskTable.d.ts.map +1 -1
- package/dist/features/entity/metadata-task/hooks/useMetadataTaskTable.js +54 -41
- package/dist/features/entity/metadata-task/hooks/useMetadataTaskTable.js.map +1 -1
- package/dist/features/entity/metadata-task/utils/getCreateGridRequestForMetadataTask.d.ts +2 -2
- package/dist/features/entity/metadata-task/utils/getCreateGridRequestForMetadataTask.d.ts.map +1 -1
- package/dist/features/entity/metadata-task/utils/getCreateGridRequestForMetadataTask.js +11 -4
- package/dist/features/entity/metadata-task/utils/getCreateGridRequestForMetadataTask.js.map +1 -1
- package/dist/features/entity/metadata-task/utils/taskHasAssignee.d.ts +3 -0
- package/dist/features/entity/metadata-task/utils/taskHasAssignee.d.ts.map +1 -0
- package/dist/features/entity/metadata-task/utils/taskHasAssignee.js +7 -0
- package/dist/features/entity/metadata-task/utils/taskHasAssignee.js.map +1 -0
- package/dist/mocks/curation/mockCurationTask.d.ts +10 -0
- package/dist/mocks/curation/mockCurationTask.d.ts.map +1 -0
- package/dist/mocks/curation/mockCurationTask.js +24 -0
- package/dist/mocks/curation/mockCurationTask.js.map +1 -0
- package/dist/synapse-queries/KeyFactory.d.ts +8 -3
- package/dist/synapse-queries/KeyFactory.d.ts.map +1 -1
- package/dist/synapse-queries/KeyFactory.js +22 -7
- package/dist/synapse-queries/KeyFactory.js.map +1 -1
- package/dist/synapse-queries/curation/task/useCurationTask.d.ts +6 -3
- package/dist/synapse-queries/curation/task/useCurationTask.d.ts.map +1 -1
- package/dist/synapse-queries/curation/task/useCurationTask.js +62 -18
- package/dist/synapse-queries/curation/task/useCurationTask.js.map +1 -1
- package/dist/synapse-queries/grid/useEstablishWebsocketConnection.d.ts +2 -0
- package/dist/synapse-queries/grid/useEstablishWebsocketConnection.d.ts.map +1 -1
- package/dist/synapse-queries/grid/useEstablishWebsocketConnection.js.map +1 -1
- package/dist/synapse-queries/grid/useGridSession.d.ts +17 -2
- package/dist/synapse-queries/grid/useGridSession.d.ts.map +1 -1
- package/dist/synapse-queries/grid/useGridSession.js +63 -30
- package/dist/synapse-queries/grid/useGridSession.js.map +1 -1
- package/dist/synapse-queries/index.js +103 -99
- package/dist/synapse-queries/team/index.js +18 -15
- package/dist/synapse-queries/team/useTeamMembers.d.ts +34 -0
- package/dist/synapse-queries/team/useTeamMembers.d.ts.map +1 -1
- package/dist/synapse-queries/team/useTeamMembers.js +110 -69
- package/dist/synapse-queries/team/useTeamMembers.js.map +1 -1
- package/dist/synapse-queries/types.d.ts +13 -0
- package/dist/synapse-queries/types.d.ts.map +1 -0
- package/dist/synapse-queries/types.js +2 -0
- package/dist/synapse-queries/types.js.map +1 -0
- package/dist/synapse-queries/user/index.js +12 -11
- package/dist/synapse-queries/user/useUserGroupHeader.d.ts +5 -0
- package/dist/synapse-queries/user/useUserGroupHeader.d.ts.map +1 -1
- package/dist/synapse-queries/user/useUserGroupHeader.js +28 -21
- package/dist/synapse-queries/user/useUserGroupHeader.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/utils/hooks/useOverlay.d.ts +2 -2
- package/dist/utils/hooks/useOverlay.d.ts.map +1 -1
- package/dist/utils/hooks/useOverlay.js +41 -41
- package/dist/utils/hooks/useOverlay.js.map +1 -1
- package/package.json +4 -4
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import { jsx as
|
|
1
|
+
import { jsx as a, Fragment as Z, jsxs as $ } from "react/jsx-runtime";
|
|
2
2
|
import "../../synapse-client/SynapseClient.js";
|
|
3
3
|
import "@sage-bionetworks/synapse-client/generated/models/ErrorResponseCode";
|
|
4
4
|
import "@sage-bionetworks/synapse-client/generated/models/TwoFactorAuthErrorResponse";
|
|
5
5
|
import "@sage-bionetworks/synapse-client/util/SynapseClientError";
|
|
6
|
-
import { ColumnTypeEnum as
|
|
6
|
+
import { ColumnTypeEnum as o } from "@sage-bionetworks/synapse-types";
|
|
7
7
|
import "../../utils/functions/EntityTypeUtils.js";
|
|
8
8
|
import "../../utils/SynapseConstants.js";
|
|
9
9
|
import "lodash-es";
|
|
10
10
|
import "@sage-bionetworks/synapse-client/util/synapseClientFetch";
|
|
11
11
|
import "@tanstack/react-query";
|
|
12
12
|
import "../../utils/PermissionLevelToAccessType.js";
|
|
13
|
-
import { useMemo as
|
|
14
|
-
import { useSynapseContext as
|
|
13
|
+
import { useMemo as l, useState as ee } from "react";
|
|
14
|
+
import { useSynapseContext as oe } from "../../utils/context/SynapseContext.js";
|
|
15
15
|
import "use-deep-compare-effect";
|
|
16
16
|
import "@mui/material";
|
|
17
17
|
import "../../utils/hooks/useCookiePreferences.js";
|
|
@@ -28,124 +28,153 @@ import "lodash-es/xorWith";
|
|
|
28
28
|
import "react-router";
|
|
29
29
|
import "@sage-bionetworks/synapse-client";
|
|
30
30
|
import "../../utils/types/IsType.js";
|
|
31
|
-
import { useGetEntity as
|
|
32
|
-
import { useReactTable as
|
|
33
|
-
import { useAtomValue as
|
|
34
|
-
import { ModalDownload as
|
|
35
|
-
import { useQueryContext as
|
|
36
|
-
import { useQueryVisualizationContext as
|
|
37
|
-
import { isRowSelectionVisibleAtom as
|
|
38
|
-
import
|
|
39
|
-
import { SynapseTableContext as
|
|
40
|
-
import { rowSelectionColumn as
|
|
41
|
-
import { isEntityViewOrDatasetOrCollection as
|
|
42
|
-
import { usePrefetchResourcesInTable as
|
|
43
|
-
import { useTableSort as
|
|
44
|
-
const
|
|
45
|
-
function
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
31
|
+
import { useGetEntity as te } from "../../synapse-queries/entity/useEntity.js";
|
|
32
|
+
import { useReactTable as ne, getCoreRowModel as re, createColumnHelper as se } from "@tanstack/react-table";
|
|
33
|
+
import { useAtomValue as ie } from "jotai";
|
|
34
|
+
import { ModalDownload as ae } from "../ModalDownload/ModalDownload.js";
|
|
35
|
+
import { useQueryContext as le } from "../QueryContext/QueryContext.js";
|
|
36
|
+
import { useQueryVisualizationContext as me } from "../QueryVisualizationWrapper/QueryVisualizationContext.js";
|
|
37
|
+
import { isRowSelectionVisibleAtom as ue } from "../QueryWrapper/TableRowSelectionState.js";
|
|
38
|
+
import ce from "../TanStackTable/StyledTanStackTable.js";
|
|
39
|
+
import { SynapseTableContext as de } from "./SynapseTableContext.js";
|
|
40
|
+
import { rowSelectionColumn as x, addToDownloadListColumn as L, directDownloadColumn as N, accessColumn as V, TableDataCell as pe, TableDataColumnHeader as Ce } from "./SynapseTableRenderers.js";
|
|
41
|
+
import { isEntityViewOrDatasetOrCollection as fe, isFileViewOrDataset as we, isSortableColumn as Se } from "./SynapseTableUtils.js";
|
|
42
|
+
import { usePrefetchResourcesInTable as Te } from "./usePrefetchTableData.js";
|
|
43
|
+
import { useTableSort as Ie } from "./useTableSort.js";
|
|
44
|
+
const De = [];
|
|
45
|
+
function he(r, s) {
|
|
46
|
+
const m = r.toLowerCase();
|
|
47
|
+
if (m.includes("name") || m.includes("description"))
|
|
48
|
+
return 250;
|
|
49
|
+
switch (s) {
|
|
50
|
+
case o.ENTITYID:
|
|
51
|
+
case o.ENTITYID_LIST:
|
|
52
|
+
case o.USERID:
|
|
53
|
+
case o.USERID_LIST:
|
|
54
|
+
case o.FILEHANDLEID:
|
|
55
|
+
case o.EVALUATIONID:
|
|
56
|
+
case o.SUBMISSIONID:
|
|
57
|
+
return 180;
|
|
58
|
+
case o.DATE:
|
|
59
|
+
case o.DATE_LIST:
|
|
60
|
+
return 120;
|
|
61
|
+
case o.STRING:
|
|
62
|
+
case o.STRING_LIST:
|
|
63
|
+
return 100;
|
|
64
|
+
default:
|
|
65
|
+
return 60;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
const ye = se();
|
|
69
|
+
function Co(r) {
|
|
70
|
+
const { showDownloadColumn: s, hideDownload: m } = r, {
|
|
71
|
+
rowSet: t,
|
|
72
|
+
isLoadingNewPage: O,
|
|
73
|
+
customColumns: w = De,
|
|
74
|
+
showAccessColumn: d,
|
|
75
|
+
showExternalAccessIcon: S,
|
|
76
|
+
showAccessColumnHeader: T,
|
|
77
|
+
showDirectDownloadColumn: v = s,
|
|
78
|
+
hideAddToDownloadListColumn: B = m,
|
|
79
|
+
columnLinks: I
|
|
80
|
+
} = r, {
|
|
81
|
+
entityId: P,
|
|
82
|
+
versionNumber: q,
|
|
83
|
+
getCurrentQueryRequest: D,
|
|
84
|
+
fileIdColumnName: u,
|
|
85
|
+
fileVersionColumnName: h
|
|
86
|
+
} = le(), p = l(
|
|
87
|
+
() => D(),
|
|
88
|
+
[D]
|
|
89
|
+
), i = t.headers, { data: c } = te(P, q), { columnsToShowInTable: y, NoContentPlaceholder: z } = me(), H = l(
|
|
66
90
|
() => ({
|
|
67
|
-
columnLinks:
|
|
68
|
-
showExternalAccessIcon:
|
|
91
|
+
columnLinks: I,
|
|
92
|
+
showExternalAccessIcon: S
|
|
69
93
|
}),
|
|
70
|
-
[
|
|
71
|
-
), { isAuthenticated:
|
|
94
|
+
[I, S]
|
|
95
|
+
), { isAuthenticated: U } = oe(), [_, F] = ee(!1), { sort: G, setSort: Q } = Ie(), C = ie(ue), b = !!(d && c && (fe(c) && M(t) || u)), g = c && U && (we(c) && M(t) || u), E = !!(g && v), R = !!(g && !B && !C), j = u ? t.headers.findIndex((e) => e.name == u) : void 0, k = h ? t.headers.findIndex((e) => e.name == h) : void 0, W = l(
|
|
72
96
|
() => [
|
|
73
|
-
...
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
97
|
+
...w,
|
|
98
|
+
x,
|
|
99
|
+
L,
|
|
100
|
+
N,
|
|
77
101
|
{
|
|
78
|
-
...
|
|
79
|
-
header:
|
|
102
|
+
...V,
|
|
103
|
+
header: d && T ? "Access" : ""
|
|
80
104
|
},
|
|
81
|
-
...
|
|
105
|
+
...i.map((e, n) => ye.accessor((f) => f.values[n], {
|
|
82
106
|
id: e.name,
|
|
83
|
-
enableSorting:
|
|
107
|
+
enableSorting: Se(e.columnType),
|
|
84
108
|
enableResizing: !0,
|
|
85
|
-
|
|
86
|
-
|
|
109
|
+
minSize: he(
|
|
110
|
+
e.name,
|
|
111
|
+
e.columnType
|
|
112
|
+
),
|
|
113
|
+
header: Ce,
|
|
114
|
+
cell: pe
|
|
87
115
|
})) ?? []
|
|
88
116
|
],
|
|
89
|
-
[
|
|
90
|
-
),
|
|
117
|
+
[w, i, d, T]
|
|
118
|
+
), A = l(
|
|
91
119
|
() => ({
|
|
92
|
-
[
|
|
93
|
-
[
|
|
94
|
-
[
|
|
95
|
-
[
|
|
120
|
+
[x.id]: C,
|
|
121
|
+
[L.id]: R,
|
|
122
|
+
[N.id]: E,
|
|
123
|
+
[V.id]: b
|
|
96
124
|
}),
|
|
97
125
|
[
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
126
|
+
C,
|
|
127
|
+
b,
|
|
128
|
+
R,
|
|
129
|
+
E
|
|
102
130
|
]
|
|
103
|
-
),
|
|
104
|
-
() =>
|
|
131
|
+
), Y = l(
|
|
132
|
+
() => i.reduce((e, n) => ({
|
|
105
133
|
...e,
|
|
106
|
-
[
|
|
107
|
-
}),
|
|
108
|
-
[
|
|
109
|
-
), { dataHasBeenPrefetched: J } =
|
|
110
|
-
data:
|
|
111
|
-
columns:
|
|
112
|
-
|
|
134
|
+
[n.name]: y.includes(n.name)
|
|
135
|
+
}), A),
|
|
136
|
+
[y, i, A]
|
|
137
|
+
), { dataHasBeenPrefetched: J } = Te(t), K = O || !J, X = ne({
|
|
138
|
+
data: t.rows,
|
|
139
|
+
columns: W,
|
|
140
|
+
defaultColumn: { minSize: 60 },
|
|
141
|
+
getCoreRowModel: re(),
|
|
113
142
|
manualSorting: !0,
|
|
114
143
|
manualFiltering: !0,
|
|
115
|
-
onSortingChange:
|
|
144
|
+
onSortingChange: Q,
|
|
116
145
|
enableMultiSort: !0,
|
|
117
146
|
columnResizeMode: "onChange",
|
|
118
147
|
state: {
|
|
119
|
-
sorting:
|
|
120
|
-
columnVisibility:
|
|
148
|
+
sorting: G,
|
|
149
|
+
columnVisibility: Y
|
|
121
150
|
},
|
|
122
151
|
meta: {
|
|
123
|
-
rowSet:
|
|
152
|
+
rowSet: t,
|
|
124
153
|
// make the rowEntityIDColumnIndex available to all cell renderers
|
|
125
|
-
rowEntityIDColumnIndex:
|
|
126
|
-
rowEntityVersionColumnIndex:
|
|
154
|
+
rowEntityIDColumnIndex: j,
|
|
155
|
+
rowEntityVersionColumnIndex: k,
|
|
127
156
|
renderPlaceholderData: K,
|
|
128
157
|
getWrapInExpandableTd: (e) => {
|
|
129
|
-
const
|
|
130
|
-
(
|
|
158
|
+
const n = i.find(
|
|
159
|
+
(f) => f.name === e.column.id
|
|
131
160
|
);
|
|
132
|
-
return !!(
|
|
133
|
-
|
|
161
|
+
return !!(n && /* JSON handles its own overflow*/
|
|
162
|
+
n.columnType !== o.JSON);
|
|
134
163
|
}
|
|
135
164
|
}
|
|
136
165
|
});
|
|
137
|
-
return
|
|
138
|
-
|
|
139
|
-
|
|
166
|
+
return t ? !((t.rows?.length ?? 0) > 0) && (p.query.offset === 0 || p.query.offset == null) ? /* @__PURE__ */ a(z, {}) : /* @__PURE__ */ a(de.Provider, { value: H, children: /* @__PURE__ */ $("div", { children: [
|
|
167
|
+
_ && /* @__PURE__ */ a(
|
|
168
|
+
ae,
|
|
140
169
|
{
|
|
141
170
|
onClose: () => {
|
|
142
|
-
|
|
171
|
+
F(!1);
|
|
143
172
|
},
|
|
144
|
-
queryBundleRequest:
|
|
173
|
+
queryBundleRequest: p
|
|
145
174
|
}
|
|
146
175
|
),
|
|
147
|
-
/* @__PURE__ */
|
|
148
|
-
|
|
176
|
+
/* @__PURE__ */ a(
|
|
177
|
+
ce,
|
|
149
178
|
{
|
|
150
179
|
styledTableContainerProps: {
|
|
151
180
|
className: "SynapseTable",
|
|
@@ -157,12 +186,13 @@ function pe(i) {
|
|
|
157
186
|
autoColumnSizing: !0
|
|
158
187
|
}
|
|
159
188
|
)
|
|
160
|
-
] }) }) : /* @__PURE__ */
|
|
189
|
+
] }) }) : /* @__PURE__ */ a(Z, {});
|
|
161
190
|
}
|
|
162
|
-
function
|
|
163
|
-
return !!
|
|
191
|
+
function M(r) {
|
|
192
|
+
return !!r.rows?.every((s) => !!s.rowId);
|
|
164
193
|
}
|
|
165
194
|
export {
|
|
166
|
-
|
|
195
|
+
Co as SynapseTable,
|
|
196
|
+
he as getColumnMinSize
|
|
167
197
|
};
|
|
168
198
|
//# sourceMappingURL=SynapseTable.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SynapseTable.js","sources":["../../../src/components/SynapseTable/SynapseTable.tsx"],"sourcesContent":["import { useGetEntity } from '@/synapse-queries'\nimport { useSynapseContext } from '@/utils'\nimport {\n ColumnTypeEnum,\n Row,\n RowSet,\n Table,\n} from '@sage-bionetworks/synapse-types'\nimport {\n Cell,\n ColumnDef,\n createColumnHelper,\n getCoreRowModel,\n useReactTable,\n VisibilityState,\n} from '@tanstack/react-table'\nimport { useAtomValue } from 'jotai'\nimport { useMemo, useState } from 'react'\nimport { LabelLinkConfig } from '../CardContainerLogic'\nimport ModalDownload from '../ModalDownload/ModalDownload'\nimport { useQueryContext } from '../QueryContext'\nimport { useQueryVisualizationContext } from '../QueryVisualizationWrapper'\nimport { isRowSelectionVisibleAtom } from '../QueryWrapper/TableRowSelectionState'\nimport StyledTanStackTable from '../TanStackTable/StyledTanStackTable'\nimport { SynapseTableContext } from './SynapseTableContext'\nimport {\n accessColumn,\n addToDownloadListColumn,\n directDownloadColumn,\n rowSelectionColumn,\n TableDataCell,\n TableDataColumnHeader,\n} from './SynapseTableRenderers'\nimport {\n isEntityViewOrDatasetOrCollection,\n isFileViewOrDataset,\n isSortableColumn,\n} from './SynapseTableUtils'\nimport { usePrefetchResourcesInTable } from './usePrefetchTableData'\nimport { useTableSort } from './useTableSort'\n\nconst DEFAULT_CUSTOM_COLUMNS: ColumnDef<Row, any>[] = []\n\nexport type SynapseTableConfiguration = Pick<\n SynapseTableProps,\n | 'showAccessColumn'\n | 'showExternalAccessIcon'\n | 'showAccessColumnHeader'\n | 'showDownloadColumn'\n | 'hideDownload'\n | 'showDirectDownloadColumn'\n | 'hideAddToDownloadListColumn'\n | 'columnLinks'\n | 'customColumns'\n>\n\nexport type SynapseTableProps = {\n /** The row data shown in the table. */\n rowSet: RowSet\n /** Whether a new page of data is being loaded */\n isLoadingNewPage: boolean\n /** Custom columns to render in the table */\n customColumns?: ColumnDef<Row, any>[]\n /** If true and entity is a view or dataset, renders a column that represents if the caller has permission to download the entity represented by the row */\n showAccessColumn?: boolean\n /**\n * If true, the component will show enhanced UI for the case where\n * - the entity is a FileEntity, AND\n * - the caller has permission to fetch the dataFileHandle, AND\n * - the dataFileHandle is an instance of ExternalFileHandleInterface (i.e. the file is not controlled by Synapse)\n * Note that this requires an additional API call that cannot be batched, so it should be avoided in bulk contexts if possible.\n * @default false\n */\n showExternalAccessIcon?: boolean\n showAccessColumnHeader?: boolean\n /** @deprecated use showDirectDownloadColumn */\n showDownloadColumn?: boolean\n /** @deprecated use hideAddToDownloadListColumn */\n hideDownload?: boolean\n /** If true and entity is a file view or dataset, renders a column that allows the logged-in user to directly download the file, if they have permission */\n showDirectDownloadColumn?: boolean\n /** If true, the add to download list column will be hidden */\n hideAddToDownloadListColumn?: boolean\n /** Configuration to override cell renderers with e.g. a link to a portals detail page */\n columnLinks?: LabelLinkConfig\n}\n\nconst columnHelper = createColumnHelper<Row>()\n\nexport function SynapseTable(props: SynapseTableProps) {\n const { showDownloadColumn, hideDownload } = props\n const {\n rowSet,\n isLoadingNewPage,\n customColumns = DEFAULT_CUSTOM_COLUMNS,\n showAccessColumn,\n showExternalAccessIcon,\n showAccessColumnHeader,\n showDirectDownloadColumn = showDownloadColumn,\n hideAddToDownloadListColumn = hideDownload,\n columnLinks,\n } = props\n const {\n entityId,\n versionNumber,\n getCurrentQueryRequest,\n fileIdColumnName,\n fileVersionColumnName,\n } = useQueryContext()\n const queryRequest = useMemo(\n () => getCurrentQueryRequest(),\n [getCurrentQueryRequest],\n )\n\n const selectColumns = rowSet.headers\n\n const { data: entity } = useGetEntity<Table>(entityId, versionNumber)\n\n const { columnsToShowInTable, NoContentPlaceholder } =\n useQueryVisualizationContext()\n const synapseTableContext = useMemo(\n () => ({\n columnLinks,\n showExternalAccessIcon,\n }),\n [columnLinks, showExternalAccessIcon],\n )\n const { isAuthenticated } = useSynapseContext()\n\n const [isExportTableDownloadOpen, setIsExportTableDownloadOpen] =\n useState(false)\n\n const { sort, setSort } = useTableSort()\n const isRowSelectionVisible = useAtomValue(isRowSelectionVisibleAtom)\n\n const isShowingAccessColumn: boolean = Boolean(\n showAccessColumn &&\n entity &&\n ((isEntityViewOrDatasetOrCollection(entity) && allRowsHaveId(rowSet)) ||\n fileIdColumnName),\n )\n const rowsAreDownloadable =\n entity &&\n isAuthenticated &&\n ((isFileViewOrDataset(entity) && allRowsHaveId(rowSet)) || fileIdColumnName)\n\n const isShowingDirectDownloadColumn = Boolean(\n rowsAreDownloadable && showDirectDownloadColumn,\n )\n\n const isShowingAddToV2DownloadListColumn: boolean = Boolean(\n rowsAreDownloadable &&\n !hideAddToDownloadListColumn &&\n !isRowSelectionVisible,\n )\n const rowEntityIDColumnIndex = fileIdColumnName\n ? rowSet.headers.findIndex(col => col.name == fileIdColumnName)\n : undefined\n const rowEntityVersionColumnIndex = fileVersionColumnName\n ? rowSet.headers.findIndex(col => col.name == fileVersionColumnName)\n : undefined\n\n const columns = useMemo(\n () => [\n ...customColumns,\n rowSelectionColumn,\n addToDownloadListColumn,\n directDownloadColumn,\n {\n ...accessColumn,\n header: showAccessColumn && showAccessColumnHeader ? 'Access' : '',\n },\n ...(selectColumns.map((selectColumn, index) => {\n return columnHelper.accessor(row => row.values[index], {\n id: selectColumn.name,\n enableSorting: isSortableColumn(selectColumn.columnType),\n enableResizing: true,\n header: TableDataColumnHeader,\n cell: TableDataCell,\n })\n }) ?? []),\n ],\n [customColumns, selectColumns, showAccessColumn, showAccessColumnHeader],\n )\n\n const prependColumnVisibility: VisibilityState = useMemo(\n () => ({\n [rowSelectionColumn.id as string]: isRowSelectionVisible,\n [addToDownloadListColumn.id as string]:\n isShowingAddToV2DownloadListColumn,\n [directDownloadColumn.id as string]: isShowingDirectDownloadColumn,\n [accessColumn.id as string]: isShowingAccessColumn,\n }),\n [\n isRowSelectionVisible,\n isShowingAccessColumn,\n isShowingAddToV2DownloadListColumn,\n isShowingDirectDownloadColumn,\n ],\n )\n\n // Transform our `columnsToShowInTable` to @tanstack/react-table's `VisibilityState`\n const columnVisibility: VisibilityState = useMemo(\n () =>\n selectColumns.reduce((prev: VisibilityState, curr) => {\n return {\n ...prev,\n [curr.name]: columnsToShowInTable.includes(curr.name),\n }\n }, prependColumnVisibility),\n [columnsToShowInTable, selectColumns, prependColumnVisibility],\n )\n\n const { dataHasBeenPrefetched } = usePrefetchResourcesInTable(rowSet)\n const renderTableDataPlaceholder = isLoadingNewPage || !dataHasBeenPrefetched\n\n const table = useReactTable({\n data: rowSet.rows,\n columns,\n getCoreRowModel: getCoreRowModel(),\n manualSorting: true,\n manualFiltering: true,\n onSortingChange: setSort,\n enableMultiSort: true,\n columnResizeMode: 'onChange',\n state: {\n sorting: sort,\n columnVisibility: columnVisibility,\n },\n meta: {\n rowSet,\n // make the rowEntityIDColumnIndex available to all cell renderers\n rowEntityIDColumnIndex,\n rowEntityVersionColumnIndex,\n renderPlaceholderData: renderTableDataPlaceholder,\n getWrapInExpandableTd: (cell: Cell<Row, unknown>) => {\n const selectColumn = selectColumns.find(\n cm => cm.name === cell.column.id,\n )\n return Boolean(\n selectColumn &&\n /* JSON handles its own overflow*/\n selectColumn.columnType !== ColumnTypeEnum.JSON,\n )\n },\n },\n })\n\n /**\n * Display the view\n */\n if (!rowSet) {\n return <></>\n }\n const hasResults = (rowSet.rows?.length ?? 0) > 0\n // Show the No Results UI if the current page has no rows, and this is the first page of data (offset === 0 or null/undefined).\n if (\n !hasResults &&\n (queryRequest.query.offset === 0 || queryRequest.query.offset == null)\n ) {\n return <NoContentPlaceholder />\n }\n\n return (\n <SynapseTableContext.Provider value={synapseTableContext}>\n <div>\n {isExportTableDownloadOpen && (\n <ModalDownload\n onClose={() => {\n setIsExportTableDownloadOpen(false)\n }}\n queryBundleRequest={queryRequest}\n />\n )}\n <StyledTanStackTable\n styledTableContainerProps={{\n className: 'SynapseTable',\n ['data-testid']: 'SynapseTable',\n density: 'default',\n }}\n table={table}\n fullWidth={false}\n autoColumnSizing={true}\n />\n </div>\n </SynapseTableContext.Provider>\n )\n}\n\n/**\n * If this is a view/dataset and rows have an ID, then rows represent individual objects in Synapse.\n * Presence of row IDs also indicates that the query is also necessarily not summary data, e.g. the query does\n * not include an operation like GROUP BY, DISTINCT, etc., that would cause rows to not map 1:1 to Synapse Entities\n */\nfunction allRowsHaveId(rowSet: RowSet): boolean {\n return Boolean(rowSet.rows?.every(row => !!row.rowId))\n}\n"],"names":["DEFAULT_CUSTOM_COLUMNS","columnHelper","createColumnHelper","SynapseTable","props","showDownloadColumn","hideDownload","rowSet","isLoadingNewPage","customColumns","showAccessColumn","showExternalAccessIcon","showAccessColumnHeader","showDirectDownloadColumn","hideAddToDownloadListColumn","columnLinks","entityId","versionNumber","getCurrentQueryRequest","fileIdColumnName","fileVersionColumnName","useQueryContext","queryRequest","useMemo","selectColumns","entity","useGetEntity","columnsToShowInTable","NoContentPlaceholder","useQueryVisualizationContext","synapseTableContext","isAuthenticated","useSynapseContext","isExportTableDownloadOpen","setIsExportTableDownloadOpen","useState","sort","setSort","useTableSort","isRowSelectionVisible","useAtomValue","isRowSelectionVisibleAtom","isShowingAccessColumn","isEntityViewOrDatasetOrCollection","allRowsHaveId","rowsAreDownloadable","isFileViewOrDataset","isShowingDirectDownloadColumn","isShowingAddToV2DownloadListColumn","rowEntityIDColumnIndex","col","rowEntityVersionColumnIndex","columns","rowSelectionColumn","addToDownloadListColumn","directDownloadColumn","accessColumn","selectColumn","index","row","isSortableColumn","TableDataColumnHeader","TableDataCell","prependColumnVisibility","columnVisibility","prev","curr","dataHasBeenPrefetched","usePrefetchResourcesInTable","renderTableDataPlaceholder","table","useReactTable","getCoreRowModel","cell","cm","ColumnTypeEnum","SynapseTableContext","jsx","ModalDownload","StyledTanStackTable","Fragment"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"SynapseTable.js","sources":["../../../src/components/SynapseTable/SynapseTable.tsx"],"sourcesContent":["import { useGetEntity } from '@/synapse-queries'\nimport { useSynapseContext } from '@/utils'\nimport {\n ColumnTypeEnum,\n Row,\n RowSet,\n Table,\n} from '@sage-bionetworks/synapse-types'\nimport {\n Cell,\n ColumnDef,\n createColumnHelper,\n getCoreRowModel,\n useReactTable,\n VisibilityState,\n} from '@tanstack/react-table'\nimport { useAtomValue } from 'jotai'\nimport { useMemo, useState } from 'react'\nimport { LabelLinkConfig } from '../CardContainerLogic'\nimport ModalDownload from '../ModalDownload/ModalDownload'\nimport { useQueryContext } from '../QueryContext'\nimport { useQueryVisualizationContext } from '../QueryVisualizationWrapper'\nimport { isRowSelectionVisibleAtom } from '../QueryWrapper/TableRowSelectionState'\nimport StyledTanStackTable from '../TanStackTable/StyledTanStackTable'\nimport { SynapseTableContext } from './SynapseTableContext'\nimport {\n accessColumn,\n addToDownloadListColumn,\n directDownloadColumn,\n rowSelectionColumn,\n TableDataCell,\n TableDataColumnHeader,\n} from './SynapseTableRenderers'\nimport {\n isEntityViewOrDatasetOrCollection,\n isFileViewOrDataset,\n isSortableColumn,\n} from './SynapseTableUtils'\nimport { usePrefetchResourcesInTable } from './usePrefetchTableData'\nimport { useTableSort } from './useTableSort'\n\nconst DEFAULT_CUSTOM_COLUMNS: ColumnDef<Row, any>[] = []\n\n/**\n * Returns the minimum column width (in px) for a Synapse table column\n * based on its type and name.\n */\nexport function getColumnMinSize(\n columnName: string,\n columnType: ColumnTypeEnum,\n): number {\n const nameLower = columnName.toLowerCase()\n if (nameLower.includes('name') || nameLower.includes('description')) {\n return 250\n }\n switch (columnType) {\n case ColumnTypeEnum.ENTITYID:\n case ColumnTypeEnum.ENTITYID_LIST:\n case ColumnTypeEnum.USERID:\n case ColumnTypeEnum.USERID_LIST:\n case ColumnTypeEnum.FILEHANDLEID:\n case ColumnTypeEnum.EVALUATIONID:\n case ColumnTypeEnum.SUBMISSIONID:\n return 180\n case ColumnTypeEnum.DATE:\n case ColumnTypeEnum.DATE_LIST:\n return 120\n case ColumnTypeEnum.STRING:\n case ColumnTypeEnum.STRING_LIST:\n return 100\n default:\n return 60\n }\n}\n\nexport type SynapseTableConfiguration = Pick<\n SynapseTableProps,\n | 'showAccessColumn'\n | 'showExternalAccessIcon'\n | 'showAccessColumnHeader'\n | 'showDownloadColumn'\n | 'hideDownload'\n | 'showDirectDownloadColumn'\n | 'hideAddToDownloadListColumn'\n | 'columnLinks'\n | 'customColumns'\n>\n\nexport type SynapseTableProps = {\n /** The row data shown in the table. */\n rowSet: RowSet\n /** Whether a new page of data is being loaded */\n isLoadingNewPage: boolean\n /** Custom columns to render in the table */\n customColumns?: ColumnDef<Row, any>[]\n /** If true and entity is a view or dataset, renders a column that represents if the caller has permission to download the entity represented by the row */\n showAccessColumn?: boolean\n /**\n * If true, the component will show enhanced UI for the case where\n * - the entity is a FileEntity, AND\n * - the caller has permission to fetch the dataFileHandle, AND\n * - the dataFileHandle is an instance of ExternalFileHandleInterface (i.e. the file is not controlled by Synapse)\n * Note that this requires an additional API call that cannot be batched, so it should be avoided in bulk contexts if possible.\n * @default false\n */\n showExternalAccessIcon?: boolean\n showAccessColumnHeader?: boolean\n /** @deprecated use showDirectDownloadColumn */\n showDownloadColumn?: boolean\n /** @deprecated use hideAddToDownloadListColumn */\n hideDownload?: boolean\n /** If true and entity is a file view or dataset, renders a column that allows the logged-in user to directly download the file, if they have permission */\n showDirectDownloadColumn?: boolean\n /** If true, the add to download list column will be hidden */\n hideAddToDownloadListColumn?: boolean\n /** Configuration to override cell renderers with e.g. a link to a portals detail page */\n columnLinks?: LabelLinkConfig\n}\n\nconst columnHelper = createColumnHelper<Row>()\n\nexport function SynapseTable(props: SynapseTableProps) {\n const { showDownloadColumn, hideDownload } = props\n const {\n rowSet,\n isLoadingNewPage,\n customColumns = DEFAULT_CUSTOM_COLUMNS,\n showAccessColumn,\n showExternalAccessIcon,\n showAccessColumnHeader,\n showDirectDownloadColumn = showDownloadColumn,\n hideAddToDownloadListColumn = hideDownload,\n columnLinks,\n } = props\n const {\n entityId,\n versionNumber,\n getCurrentQueryRequest,\n fileIdColumnName,\n fileVersionColumnName,\n } = useQueryContext()\n const queryRequest = useMemo(\n () => getCurrentQueryRequest(),\n [getCurrentQueryRequest],\n )\n\n const selectColumns = rowSet.headers\n\n const { data: entity } = useGetEntity<Table>(entityId, versionNumber)\n\n const { columnsToShowInTable, NoContentPlaceholder } =\n useQueryVisualizationContext()\n const synapseTableContext = useMemo(\n () => ({\n columnLinks,\n showExternalAccessIcon,\n }),\n [columnLinks, showExternalAccessIcon],\n )\n const { isAuthenticated } = useSynapseContext()\n\n const [isExportTableDownloadOpen, setIsExportTableDownloadOpen] =\n useState(false)\n\n const { sort, setSort } = useTableSort()\n const isRowSelectionVisible = useAtomValue(isRowSelectionVisibleAtom)\n\n const isShowingAccessColumn: boolean = Boolean(\n showAccessColumn &&\n entity &&\n ((isEntityViewOrDatasetOrCollection(entity) && allRowsHaveId(rowSet)) ||\n fileIdColumnName),\n )\n const rowsAreDownloadable =\n entity &&\n isAuthenticated &&\n ((isFileViewOrDataset(entity) && allRowsHaveId(rowSet)) || fileIdColumnName)\n\n const isShowingDirectDownloadColumn = Boolean(\n rowsAreDownloadable && showDirectDownloadColumn,\n )\n\n const isShowingAddToV2DownloadListColumn: boolean = Boolean(\n rowsAreDownloadable &&\n !hideAddToDownloadListColumn &&\n !isRowSelectionVisible,\n )\n const rowEntityIDColumnIndex = fileIdColumnName\n ? rowSet.headers.findIndex(col => col.name == fileIdColumnName)\n : undefined\n const rowEntityVersionColumnIndex = fileVersionColumnName\n ? rowSet.headers.findIndex(col => col.name == fileVersionColumnName)\n : undefined\n\n const columns = useMemo(\n () => [\n ...customColumns,\n rowSelectionColumn,\n addToDownloadListColumn,\n directDownloadColumn,\n {\n ...accessColumn,\n header: showAccessColumn && showAccessColumnHeader ? 'Access' : '',\n },\n ...(selectColumns.map((selectColumn, index) => {\n return columnHelper.accessor(row => row.values[index], {\n id: selectColumn.name,\n enableSorting: isSortableColumn(selectColumn.columnType),\n enableResizing: true,\n minSize: getColumnMinSize(\n selectColumn.name,\n selectColumn.columnType as ColumnTypeEnum,\n ),\n header: TableDataColumnHeader,\n cell: TableDataCell,\n })\n }) ?? []),\n ],\n [customColumns, selectColumns, showAccessColumn, showAccessColumnHeader],\n )\n\n const prependColumnVisibility: VisibilityState = useMemo(\n () => ({\n [rowSelectionColumn.id as string]: isRowSelectionVisible,\n [addToDownloadListColumn.id as string]:\n isShowingAddToV2DownloadListColumn,\n [directDownloadColumn.id as string]: isShowingDirectDownloadColumn,\n [accessColumn.id as string]: isShowingAccessColumn,\n }),\n [\n isRowSelectionVisible,\n isShowingAccessColumn,\n isShowingAddToV2DownloadListColumn,\n isShowingDirectDownloadColumn,\n ],\n )\n\n // Transform our `columnsToShowInTable` to @tanstack/react-table's `VisibilityState`\n const columnVisibility: VisibilityState = useMemo(\n () =>\n selectColumns.reduce((prev: VisibilityState, curr) => {\n return {\n ...prev,\n [curr.name]: columnsToShowInTable.includes(curr.name),\n }\n }, prependColumnVisibility),\n [columnsToShowInTable, selectColumns, prependColumnVisibility],\n )\n\n const { dataHasBeenPrefetched } = usePrefetchResourcesInTable(rowSet)\n const renderTableDataPlaceholder = isLoadingNewPage || !dataHasBeenPrefetched\n\n const table = useReactTable({\n data: rowSet.rows,\n columns,\n defaultColumn: { minSize: 60 },\n getCoreRowModel: getCoreRowModel(),\n manualSorting: true,\n manualFiltering: true,\n onSortingChange: setSort,\n enableMultiSort: true,\n columnResizeMode: 'onChange',\n state: {\n sorting: sort,\n columnVisibility: columnVisibility,\n },\n meta: {\n rowSet,\n // make the rowEntityIDColumnIndex available to all cell renderers\n rowEntityIDColumnIndex,\n rowEntityVersionColumnIndex,\n renderPlaceholderData: renderTableDataPlaceholder,\n getWrapInExpandableTd: (cell: Cell<Row, unknown>) => {\n const selectColumn = selectColumns.find(\n cm => cm.name === cell.column.id,\n )\n return Boolean(\n selectColumn &&\n /* JSON handles its own overflow*/\n selectColumn.columnType !== ColumnTypeEnum.JSON,\n )\n },\n },\n })\n\n /**\n * Display the view\n */\n if (!rowSet) {\n return <></>\n }\n const hasResults = (rowSet.rows?.length ?? 0) > 0\n // Show the No Results UI if the current page has no rows, and this is the first page of data (offset === 0 or null/undefined).\n if (\n !hasResults &&\n (queryRequest.query.offset === 0 || queryRequest.query.offset == null)\n ) {\n return <NoContentPlaceholder />\n }\n\n return (\n <SynapseTableContext.Provider value={synapseTableContext}>\n <div>\n {isExportTableDownloadOpen && (\n <ModalDownload\n onClose={() => {\n setIsExportTableDownloadOpen(false)\n }}\n queryBundleRequest={queryRequest}\n />\n )}\n <StyledTanStackTable\n styledTableContainerProps={{\n className: 'SynapseTable',\n ['data-testid']: 'SynapseTable',\n density: 'default',\n }}\n table={table}\n fullWidth={false}\n autoColumnSizing={true}\n />\n </div>\n </SynapseTableContext.Provider>\n )\n}\n\n/**\n * If this is a view/dataset and rows have an ID, then rows represent individual objects in Synapse.\n * Presence of row IDs also indicates that the query is also necessarily not summary data, e.g. the query does\n * not include an operation like GROUP BY, DISTINCT, etc., that would cause rows to not map 1:1 to Synapse Entities\n */\nfunction allRowsHaveId(rowSet: RowSet): boolean {\n return Boolean(rowSet.rows?.every(row => !!row.rowId))\n}\n"],"names":["DEFAULT_CUSTOM_COLUMNS","getColumnMinSize","columnName","columnType","nameLower","ColumnTypeEnum","columnHelper","createColumnHelper","SynapseTable","props","showDownloadColumn","hideDownload","rowSet","isLoadingNewPage","customColumns","showAccessColumn","showExternalAccessIcon","showAccessColumnHeader","showDirectDownloadColumn","hideAddToDownloadListColumn","columnLinks","entityId","versionNumber","getCurrentQueryRequest","fileIdColumnName","fileVersionColumnName","useQueryContext","queryRequest","useMemo","selectColumns","entity","useGetEntity","columnsToShowInTable","NoContentPlaceholder","useQueryVisualizationContext","synapseTableContext","isAuthenticated","useSynapseContext","isExportTableDownloadOpen","setIsExportTableDownloadOpen","useState","sort","setSort","useTableSort","isRowSelectionVisible","useAtomValue","isRowSelectionVisibleAtom","isShowingAccessColumn","isEntityViewOrDatasetOrCollection","allRowsHaveId","rowsAreDownloadable","isFileViewOrDataset","isShowingDirectDownloadColumn","isShowingAddToV2DownloadListColumn","rowEntityIDColumnIndex","col","rowEntityVersionColumnIndex","columns","rowSelectionColumn","addToDownloadListColumn","directDownloadColumn","accessColumn","selectColumn","index","row","isSortableColumn","TableDataColumnHeader","TableDataCell","prependColumnVisibility","columnVisibility","prev","curr","dataHasBeenPrefetched","usePrefetchResourcesInTable","renderTableDataPlaceholder","table","useReactTable","getCoreRowModel","cell","cm","SynapseTableContext","jsx","ModalDownload","StyledTanStackTable","Fragment"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
._labelRow_xvkho_1{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}._inputLabel_xvkho_8{position:relative!important;font-weight:700;margin-bottom:0;pointer-events:unset}._helperText_xvkho_15{font-weight:500;color:var(--synapse-gray-600)}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { TextFieldProps as MuiTextFieldProps } from '@mui/material';
|
|
2
|
-
export type TextFieldProps = Pick<MuiTextFieldProps, 'autoComplete' | 'autoFocus' | 'disabled' | 'error' | 'fullWidth' | 'id' | 'inputProps' | 'label' | 'maxRows' | 'minRows' | 'multiline' | 'onBlur' | 'onChange' | 'placeholder' | 'required' | 'rows' | 'sx' | 'type' | 'value'> & {
|
|
2
|
+
export type TextFieldProps = Pick<MuiTextFieldProps, 'autoComplete' | 'autoFocus' | 'disabled' | 'error' | 'fullWidth' | 'helperText' | 'id' | 'inputProps' | 'label' | 'maxRows' | 'minRows' | 'multiline' | 'onBlur' | 'onChange' | 'placeholder' | 'required' | 'rows' | 'sx' | 'type' | 'value'> & {
|
|
3
3
|
noWrapInFormControl?: boolean;
|
|
4
4
|
};
|
|
5
5
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TextField.d.ts","sourceRoot":"","sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"TextField.d.ts","sourceRoot":"","sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AACA,OAAO,EAIL,cAAc,IAAI,iBAAiB,EAEpC,MAAM,eAAe,CAAA;AAItB,MAAM,MAAM,cAAc,GAAG,IAAI,CAC/B,iBAAiB,EACf,cAAc,GACd,WAAW,GACX,UAAU,GACV,OAAO,GACP,WAAW,GACX,YAAY,GACZ,IAAI,GACJ,YAAY,GACZ,OAAO,GACP,SAAS,GACT,SAAS,GACT,WAAW,GACX,QAAQ,GACR,UAAU,GACV,aAAa,GACb,UAAU,GACV,MAAM,GACN,IAAI,GACJ,MAAM,GACN,OAAO,CACV,GAAG;IAAE,mBAAmB,CAAC,EAAE,OAAO,CAAA;CAAE,CAAA;AAErC;;GAEG;AACH,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,KAAK,EAAE,cAAc,2CA2CtD"}
|
|
@@ -1,34 +1,36 @@
|
|
|
1
|
-
import { jsx as
|
|
2
|
-
import { StyledFormControl as
|
|
3
|
-
import { InputLabel as
|
|
4
|
-
import
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
import { jsx as r, Fragment as c, jsxs as i } from "react/jsx-runtime";
|
|
2
|
+
import { StyledFormControl as s } from "../styled/StyledFormControl.js";
|
|
3
|
+
import { Box as h, InputLabel as u, Typography as f, InputBase as x } from "@mui/material";
|
|
4
|
+
import n from "./TextField.module.scss.js";
|
|
5
|
+
import { useId as b, useMemo as p } from "react";
|
|
6
|
+
function N(e) {
|
|
7
|
+
const o = b(), { noWrapInFormControl: a, label: y, helperText: t, ...m } = e, d = p(
|
|
8
|
+
() => a ? (l) => /* @__PURE__ */ r(c, { children: l.children }) : (l) => /* @__PURE__ */ r(s, { fullWidth: !0, sx: { my: 1 }, children: l.children }),
|
|
9
|
+
[a]
|
|
9
10
|
);
|
|
10
|
-
return /* @__PURE__ */ d
|
|
11
|
-
e.label && /* @__PURE__ */
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
11
|
+
return /* @__PURE__ */ i(d, { children: [
|
|
12
|
+
(e.label || t) && /* @__PURE__ */ i(h, { className: n.labelRow, children: [
|
|
13
|
+
e.label && /* @__PURE__ */ r(
|
|
14
|
+
u,
|
|
15
|
+
{
|
|
16
|
+
htmlFor: e.id || o,
|
|
17
|
+
className: n.inputLabel,
|
|
18
|
+
sx: {
|
|
19
|
+
"&::after": ({ palette: l }) => ({
|
|
20
|
+
content: e.required ? '"*"' : void 0,
|
|
21
|
+
marginLeft: "3px",
|
|
22
|
+
color: l.secondary.main
|
|
23
|
+
})
|
|
24
|
+
},
|
|
25
|
+
children: e.label
|
|
26
|
+
}
|
|
27
|
+
),
|
|
28
|
+
t && /* @__PURE__ */ r(f, { variant: "body2", className: n.helperText, children: t })
|
|
29
|
+
] }),
|
|
30
|
+
/* @__PURE__ */ r(x, { id: o, ...m })
|
|
29
31
|
] });
|
|
30
32
|
}
|
|
31
33
|
export {
|
|
32
|
-
|
|
34
|
+
N as default
|
|
33
35
|
};
|
|
34
36
|
//# sourceMappingURL=TextField.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TextField.js","sources":["../../../src/components/TextField/TextField.tsx"],"sourcesContent":["import StyledFormControl from '@/components/styled/StyledFormControl'\nimport {\n InputBase,\n InputLabel,\n TextFieldProps as MuiTextFieldProps,\n} from '@mui/material'\nimport { PropsWithChildren, useId, useMemo } from 'react'\n\nexport type TextFieldProps = Pick<\n MuiTextFieldProps,\n | 'autoComplete'\n | 'autoFocus'\n | 'disabled'\n | 'error'\n | 'fullWidth'\n | 'id'\n | 'inputProps'\n | 'label'\n | 'maxRows'\n | 'minRows'\n | 'multiline'\n | 'onBlur'\n | 'onChange'\n | 'placeholder'\n | 'required'\n | 'rows'\n | 'sx'\n | 'type'\n | 'value'\n> & { noWrapInFormControl?: boolean }\n\n/**\n * A styled text field built using MUI components and designed to match the Sage Design System (SDS) input fields.\n */\nexport default function TextField(props: TextFieldProps) {\n const id = useId()\n const { noWrapInFormControl, label, ...rest } = props\n const Wrapper = useMemo(\n () =>\n noWrapInFormControl\n ? (props: PropsWithChildren<object>) => <>{props.children}</>\n : (props: PropsWithChildren<object>) => (\n <StyledFormControl fullWidth sx={{ my: 1 }}>\n {props.children}\n </StyledFormControl>\n ),\n [noWrapInFormControl],\n )\n return (\n <Wrapper>\n {props.label && (\n <InputLabel\n
|
|
1
|
+
{"version":3,"file":"TextField.js","sources":["../../../src/components/TextField/TextField.tsx"],"sourcesContent":["import StyledFormControl from '@/components/styled/StyledFormControl'\nimport {\n Box,\n InputBase,\n InputLabel,\n TextFieldProps as MuiTextFieldProps,\n Typography,\n} from '@mui/material'\nimport styles from './TextField.module.scss'\nimport { PropsWithChildren, useId, useMemo } from 'react'\n\nexport type TextFieldProps = Pick<\n MuiTextFieldProps,\n | 'autoComplete'\n | 'autoFocus'\n | 'disabled'\n | 'error'\n | 'fullWidth'\n | 'helperText'\n | 'id'\n | 'inputProps'\n | 'label'\n | 'maxRows'\n | 'minRows'\n | 'multiline'\n | 'onBlur'\n | 'onChange'\n | 'placeholder'\n | 'required'\n | 'rows'\n | 'sx'\n | 'type'\n | 'value'\n> & { noWrapInFormControl?: boolean }\n\n/**\n * A styled text field built using MUI components and designed to match the Sage Design System (SDS) input fields.\n */\nexport default function TextField(props: TextFieldProps) {\n const id = useId()\n const { noWrapInFormControl, label: _label, helperText, ...rest } = props\n const Wrapper = useMemo(\n () =>\n noWrapInFormControl\n ? (props: PropsWithChildren<object>) => <>{props.children}</>\n : (props: PropsWithChildren<object>) => (\n <StyledFormControl fullWidth sx={{ my: 1 }}>\n {props.children}\n </StyledFormControl>\n ),\n [noWrapInFormControl],\n )\n return (\n <Wrapper>\n {(props.label || helperText) && (\n <Box className={styles.labelRow}>\n {props.label && (\n <InputLabel\n htmlFor={props.id || id}\n className={styles.inputLabel}\n sx={{\n '&::after': ({ palette }) => ({\n content: props.required ? '\"*\"' : undefined,\n marginLeft: '3px',\n color: palette.secondary.main,\n }),\n }}\n >\n {props.label}\n </InputLabel>\n )}\n {helperText && (\n <Typography variant=\"body2\" className={styles.helperText}>\n {helperText}\n </Typography>\n )}\n </Box>\n )}\n <InputBase id={id} {...rest}></InputBase>\n </Wrapper>\n )\n}\n"],"names":["TextField","props","id","useId","noWrapInFormControl","_label","helperText","rest","Wrapper","useMemo","StyledFormControl","jsxs","Box","styles","jsx","InputLabel","palette","Typography","InputBase"],"mappings":";;;;;AAsCA,SAAwBA,EAAUC,GAAuB;AACvD,QAAMC,IAAKC,EAAA,GACL,EAAE,qBAAAC,GAAqB,OAAOC,GAAQ,YAAAC,GAAY,GAAGC,MAASN,GAC9DO,IAAUC;AAAA,IACd,MACEL,IACI,CAACH,6BAAwC,UAAAA,EAAM,UAAS,IACxD,CAACA,wBACES,GAAA,EAAkB,WAAS,IAAC,IAAI,EAAE,IAAI,KACpC,UAAAT,EAAM,SAAA,CACT;AAAA,IAER,CAACG,CAAmB;AAAA,EAAA;AAEtB,2BACGI,GAAA,EACG,UAAA;AAAA,KAAAP,EAAM,SAASK,MACf,gBAAAK,EAACC,GAAA,EAAI,WAAWC,EAAO,UACpB,UAAA;AAAA,MAAAZ,EAAM,SACL,gBAAAa;AAAA,QAACC;AAAA,QAAA;AAAA,UACC,SAASd,EAAM,MAAMC;AAAA,UACrB,WAAWW,EAAO;AAAA,UAClB,IAAI;AAAA,YACF,YAAY,CAAC,EAAE,SAAAG,SAAe;AAAA,cAC5B,SAASf,EAAM,WAAW,QAAQ;AAAA,cAClC,YAAY;AAAA,cACZ,OAAOe,EAAQ,UAAU;AAAA,YAAA;AAAA,UAC3B;AAAA,UAGD,UAAAf,EAAM;AAAA,QAAA;AAAA,MAAA;AAAA,MAGVK,uBACEW,GAAA,EAAW,SAAQ,SAAQ,WAAWJ,EAAO,YAC3C,UAAAP,EAAA,CACH;AAAA,IAAA,GAEJ;AAAA,IAEF,gBAAAQ,EAACI,GAAA,EAAU,IAAAhB,GAAS,GAAGK,EAAA,CAAM;AAAA,EAAA,GAC/B;AAEJ;"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
.labelRow {
|
|
2
|
+
display: flex;
|
|
3
|
+
align-items: baseline;
|
|
4
|
+
gap: 6px;
|
|
5
|
+
margin-bottom: 4px;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
.inputLabel {
|
|
9
|
+
position: relative !important;
|
|
10
|
+
font-weight: 700;
|
|
11
|
+
margin-bottom: 0;
|
|
12
|
+
pointer-events: unset;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.helperText {
|
|
16
|
+
font-weight: 500;
|
|
17
|
+
color: var(--synapse-gray-600);
|
|
18
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import './TextField.css';const e = "_labelRow_xvkho_1", l = "_inputLabel_xvkho_8", t = "_helperText_xvkho_15", o = {
|
|
2
|
+
labelRow: e,
|
|
3
|
+
inputLabel: l,
|
|
4
|
+
helperText: t
|
|
5
|
+
};
|
|
6
|
+
export {
|
|
7
|
+
o as default,
|
|
8
|
+
t as helperText,
|
|
9
|
+
l as inputLabel,
|
|
10
|
+
e as labelRow
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=TextField.module.scss.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextField.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
.
|
|
1
|
+
._triggerWrapper_5sipe_1{display:inline-flex;align-items:center}._paper_5sipe_6{display:flex;flex-direction:column;overflow:hidden}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HoverPopover.d.ts","sourceRoot":"","sources":["../../../src/components/styled/HoverPopover.tsx"],"names":[],"mappings":"AAAA,OAAO,EAGL,WAAW,EAMZ,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAoB,MAAM,OAAO,CAAA;AAGtE,MAAM,MAAM,qBAAqB,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAA;AAiCvE,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,CAAC;IAChD,cAAc,EAAE,SAAS,CAAA;IACzB,8EAA8E;IAC9E,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,qBAAqB,CAAA;IAEjC,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC1B,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC1B,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC3B,YAAY,CAAC,EAAE;QACb,OAAO,EAAE,SAAS,CAAA;QAClB,KAAK,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAA;QAC5B,OAAO,CAAC,EAAE,WAAW,CAAC,SAAS,CAAC,CAAA;QAChC,OAAO,EAAE,MAAM,IAAI,CAAA;QACnB,8DAA8D;QAC9D,YAAY,CAAC,EAAE,OAAO,CAAA;KACvB,CAAA;CACF,CAAC,CAAA;AAEF;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,cAAc,EACd,KAAK,EACL,SAAmB,EACnB,QAAc,EACd,QAAc,EACd,SAAe,EACf,YAAY,GACb,EAAE,iBAAiB,
|
|
1
|
+
{"version":3,"file":"HoverPopover.d.ts","sourceRoot":"","sources":["../../../src/components/styled/HoverPopover.tsx"],"names":[],"mappings":"AAAA,OAAO,EAGL,WAAW,EAMZ,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAoB,MAAM,OAAO,CAAA;AAGtE,MAAM,MAAM,qBAAqB,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAA;AAiCvE,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,CAAC;IAChD,cAAc,EAAE,SAAS,CAAA;IACzB,8EAA8E;IAC9E,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,qBAAqB,CAAA;IAEjC,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC1B,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC1B,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IAC3B,YAAY,CAAC,EAAE;QACb,OAAO,EAAE,SAAS,CAAA;QAClB,KAAK,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAA;QAC5B,OAAO,CAAC,EAAE,WAAW,CAAC,SAAS,CAAC,CAAA;QAChC,OAAO,EAAE,MAAM,IAAI,CAAA;QACnB,8DAA8D;QAC9D,YAAY,CAAC,EAAE,OAAO,CAAA;KACvB,CAAA;CACF,CAAC,CAAA;AAEF;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,cAAc,EACd,KAAK,EACL,SAAmB,EACnB,QAAc,EACd,QAAc,EACd,SAAe,EACf,YAAY,GACb,EAAE,iBAAiB,2CAiFnB"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsxs as s, Fragment as O, jsx as e } from "react/jsx-runtime";
|
|
2
|
-
import { Box as
|
|
2
|
+
import { Box as E, Popover as z, DialogTitle as C, DialogContent as b, DialogActions as k, Button as L } from "@mui/material";
|
|
3
3
|
import { useState as M, useRef as S } from "react";
|
|
4
4
|
import u from "./HoverPopover.module.scss.js";
|
|
5
5
|
function T(t) {
|
|
@@ -46,7 +46,7 @@ function y({
|
|
|
46
46
|
}, { anchorOrigin: d, transformOrigin: v } = T(h);
|
|
47
47
|
return /* @__PURE__ */ s(O, { children: [
|
|
48
48
|
/* @__PURE__ */ e(
|
|
49
|
-
|
|
49
|
+
E,
|
|
50
50
|
{
|
|
51
51
|
component: "span",
|
|
52
52
|
onMouseEnter: (x) => {
|
|
@@ -58,7 +58,7 @@ function y({
|
|
|
58
58
|
}
|
|
59
59
|
),
|
|
60
60
|
/* @__PURE__ */ s(
|
|
61
|
-
|
|
61
|
+
z,
|
|
62
62
|
{
|
|
63
63
|
open: c !== null,
|
|
64
64
|
anchorEl: c,
|
|
@@ -68,17 +68,18 @@ function y({
|
|
|
68
68
|
disableAutoFocus: !0,
|
|
69
69
|
disableEnforceFocus: !0,
|
|
70
70
|
disableScrollLock: !0,
|
|
71
|
+
sx: { pointerEvents: "none" },
|
|
71
72
|
slotProps: {
|
|
72
73
|
backdrop: { sx: { pointerEvents: "none" } },
|
|
73
74
|
paper: {
|
|
74
75
|
onMouseEnter: i,
|
|
75
76
|
onMouseLeave: a,
|
|
76
77
|
className: u.paper,
|
|
77
|
-
sx: { maxWidth: g, minWidth: m }
|
|
78
|
+
sx: { maxWidth: g, minWidth: m, pointerEvents: "auto" }
|
|
78
79
|
}
|
|
79
80
|
},
|
|
80
81
|
children: [
|
|
81
|
-
l && /* @__PURE__ */ e(
|
|
82
|
+
l && /* @__PURE__ */ e(C, { sx: { fontSize: "18px", padding: "16px 10px" }, children: l }),
|
|
82
83
|
/* @__PURE__ */ e(b, { sx: { maxHeight: f, padding: "10px" }, children: p }),
|
|
83
84
|
r && /* @__PURE__ */ e(k, { sx: { paddingX: "10px" }, children: /* @__PURE__ */ e(
|
|
84
85
|
L,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HoverPopover.js","sources":["../../../src/components/styled/HoverPopover.tsx"],"sourcesContent":["import {\n Box,\n Button,\n ButtonProps,\n DialogActions,\n DialogContent,\n DialogTitle,\n Popover,\n PopoverOrigin,\n} from '@mui/material'\nimport { PropsWithChildren, ReactNode, useRef, useState } from 'react'\nimport styles from './HoverPopover.module.scss'\n\nexport type HoverPopoverPlacement = 'top' | 'bottom' | 'left' | 'right'\n\nfunction getOrigins(placement: HoverPopoverPlacement): {\n anchorOrigin: PopoverOrigin\n transformOrigin: PopoverOrigin\n} {\n switch (placement) {\n case 'top':\n return {\n anchorOrigin: { vertical: 'top', horizontal: 'center' },\n transformOrigin: { vertical: 'bottom', horizontal: 'center' },\n }\n case 'bottom':\n return {\n anchorOrigin: { vertical: 'bottom', horizontal: 'center' },\n transformOrigin: { vertical: 'top', horizontal: 'center' },\n }\n case 'left':\n return {\n anchorOrigin: { vertical: 'center', horizontal: 'left' },\n transformOrigin: { vertical: 'center', horizontal: 'right' },\n }\n case 'right':\n return {\n anchorOrigin: { vertical: 'center', horizontal: 'right' },\n transformOrigin: { vertical: 'center', horizontal: 'left' },\n }\n }\n}\n\n/** Delay in ms before the popover closes after the mouse leaves the trigger or popover */\nconst CLOSE_DELAY_MS = 150\n\nexport type HoverPopoverProps = PropsWithChildren<{\n popoverContent: ReactNode\n /** Optional title rendered as a sticky header above the scrollable content */\n title?: string\n placement?: HoverPopoverPlacement\n\n maxWidth?: string | number\n minWidth?: string | number\n /** Max height of the scrollable content area. Default 400px. */\n maxHeight?: string | number\n actionButton?: {\n content: ReactNode\n color?: ButtonProps['color']\n variant?: ButtonProps['variant']\n onClick: () => void\n /** If true, closes the popover after the button is clicked */\n closeOnClick?: boolean\n }\n}>\n\n/**\n * A popover that opens when the user hovers over the trigger child and remains\n * open as long as the mouse is over either the trigger or the popover itself.\n * The content area is scrollable, avoiding any interaction with browser scroll.\n */\nexport function HoverPopover({\n children,\n popoverContent,\n title,\n placement = 'right',\n maxWidth = 500,\n minWidth = 300,\n maxHeight = 400,\n actionButton,\n}: HoverPopoverProps) {\n const [anchorEl, setAnchorEl] = useState<HTMLElement | null>(null)\n const closeTimeoutRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const cancelClose = () => {\n if (closeTimeoutRef.current !== null) {\n clearTimeout(closeTimeoutRef.current)\n closeTimeoutRef.current = null\n }\n }\n\n const scheduleClose = () => {\n cancelClose()\n closeTimeoutRef.current = setTimeout(() => {\n setAnchorEl(null)\n }, CLOSE_DELAY_MS)\n }\n\n const { anchorOrigin, transformOrigin } = getOrigins(placement)\n\n return (\n <>\n <Box\n component=\"span\"\n onMouseEnter={e => {\n cancelClose()\n setAnchorEl(e.currentTarget)\n }}\n onMouseLeave={scheduleClose}\n className={styles.triggerWrapper}\n >\n {children}\n </Box>\n <Popover\n open={anchorEl !== null}\n anchorEl={anchorEl}\n anchorOrigin={anchorOrigin}\n transformOrigin={transformOrigin}\n onClose={() => setAnchorEl(null)}\n disableAutoFocus\n disableEnforceFocus\n disableScrollLock\n slotProps={{\n backdrop: { sx: { pointerEvents: 'none' } },\n paper: {\n onMouseEnter: cancelClose,\n onMouseLeave: scheduleClose,\n className: styles.paper,\n sx: { maxWidth, minWidth },\n },\n }}\n >\n {title && (\n <DialogTitle sx={{ fontSize: '18px', padding: '16px 10px' }}>\n {title}\n </DialogTitle>\n )}\n <DialogContent sx={{ maxHeight, padding: '10px' }}>\n {popoverContent}\n </DialogContent>\n {actionButton && (\n <DialogActions sx={{ paddingX: '10px' }}>\n <Button\n color={actionButton.color ?? 'primary'}\n variant={actionButton.variant ?? 'contained'}\n fullWidth\n onClick={() => {\n actionButton.onClick()\n if (actionButton.closeOnClick) {\n setAnchorEl(null)\n }\n }}\n >\n {actionButton.content}\n </Button>\n </DialogActions>\n )}\n </Popover>\n </>\n )\n}\n"],"names":["getOrigins","placement","CLOSE_DELAY_MS","HoverPopover","children","popoverContent","title","maxWidth","minWidth","maxHeight","actionButton","anchorEl","setAnchorEl","useState","closeTimeoutRef","useRef","cancelClose","scheduleClose","anchorOrigin","transformOrigin","jsxs","Fragment","jsx","Box","e","styles","Popover","DialogTitle","DialogContent","DialogActions","Button"],"mappings":";;;;AAeA,SAASA,EAAWC,GAGlB;AACA,UAAQA,GAAA;AAAA,IACN,KAAK;AACH,aAAO;AAAA,QACL,cAAc,EAAE,UAAU,OAAO,YAAY,SAAA;AAAA,QAC7C,iBAAiB,EAAE,UAAU,UAAU,YAAY,SAAA;AAAA,MAAS;AAAA,IAEhE,KAAK;AACH,aAAO;AAAA,QACL,cAAc,EAAE,UAAU,UAAU,YAAY,SAAA;AAAA,QAChD,iBAAiB,EAAE,UAAU,OAAO,YAAY,SAAA;AAAA,MAAS;AAAA,IAE7D,KAAK;AACH,aAAO;AAAA,QACL,cAAc,EAAE,UAAU,UAAU,YAAY,OAAA;AAAA,QAChD,iBAAiB,EAAE,UAAU,UAAU,YAAY,QAAA;AAAA,MAAQ;AAAA,IAE/D,KAAK;AACH,aAAO;AAAA,QACL,cAAc,EAAE,UAAU,UAAU,YAAY,QAAA;AAAA,QAChD,iBAAiB,EAAE,UAAU,UAAU,YAAY,OAAA;AAAA,MAAO;AAAA,EAC5D;AAEN;AAGA,MAAMC,IAAiB;AA2BhB,SAASC,EAAa;AAAA,EAC3B,UAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,OAAAC;AAAA,EACA,WAAAL,IAAY;AAAA,EACZ,UAAAM,IAAW;AAAA,EACX,UAAAC,IAAW;AAAA,EACX,WAAAC,IAAY;AAAA,EACZ,cAAAC;AACF,GAAsB;AACpB,QAAM,CAACC,GAAUC,CAAW,IAAIC,EAA6B,IAAI,GAC3DC,IAAkBC,EAA6C,IAAI,GAEnEC,IAAc,MAAM;AACxB,IAAIF,EAAgB,YAAY,SAC9B,aAAaA,EAAgB,OAAO,GACpCA,EAAgB,UAAU;AAAA,EAE9B,GAEMG,IAAgB,MAAM;AAC1B,IAAAD,EAAA,GACAF,EAAgB,UAAU,WAAW,MAAM;AACzC,MAAAF,EAAY,IAAI;AAAA,IAClB,GAAGV,CAAc;AAAA,EACnB,GAEM,EAAE,cAAAgB,GAAc,iBAAAC,MAAoBnB,EAAWC,CAAS;AAE9D,SACE,gBAAAmB,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,WAAU;AAAA,QACV,cAAc,CAAAC,MAAK;AACjB,UAAAR,EAAA,GACAJ,EAAYY,EAAE,aAAa;AAAA,QAC7B;AAAA,QACA,cAAcP;AAAA,QACd,WAAWQ,EAAO;AAAA,QAEjB,UAAArB;AAAA,MAAA;AAAA,IAAA;AAAA,IAEH,gBAAAgB;AAAA,MAACM;AAAA,MAAA;AAAA,QACC,MAAMf,MAAa;AAAA,QACnB,UAAAA;AAAA,QACA,cAAAO;AAAA,QACA,iBAAAC;AAAA,QACA,SAAS,MAAMP,EAAY,IAAI;AAAA,QAC/B,kBAAgB;AAAA,QAChB,qBAAmB;AAAA,QACnB,mBAAiB;AAAA,QACjB,WAAW;AAAA,UACT,UAAU,EAAE,IAAI,EAAE,eAAe,SAAO;AAAA,UACxC,OAAO;AAAA,YACL,cAAcI;AAAA,YACd,cAAcC;AAAA,YACd,WAAWQ,EAAO;AAAA,YAClB,IAAI,EAAE,UAAAlB,GAAU,UAAAC,
|
|
1
|
+
{"version":3,"file":"HoverPopover.js","sources":["../../../src/components/styled/HoverPopover.tsx"],"sourcesContent":["import {\n Box,\n Button,\n ButtonProps,\n DialogActions,\n DialogContent,\n DialogTitle,\n Popover,\n PopoverOrigin,\n} from '@mui/material'\nimport { PropsWithChildren, ReactNode, useRef, useState } from 'react'\nimport styles from './HoverPopover.module.scss'\n\nexport type HoverPopoverPlacement = 'top' | 'bottom' | 'left' | 'right'\n\nfunction getOrigins(placement: HoverPopoverPlacement): {\n anchorOrigin: PopoverOrigin\n transformOrigin: PopoverOrigin\n} {\n switch (placement) {\n case 'top':\n return {\n anchorOrigin: { vertical: 'top', horizontal: 'center' },\n transformOrigin: { vertical: 'bottom', horizontal: 'center' },\n }\n case 'bottom':\n return {\n anchorOrigin: { vertical: 'bottom', horizontal: 'center' },\n transformOrigin: { vertical: 'top', horizontal: 'center' },\n }\n case 'left':\n return {\n anchorOrigin: { vertical: 'center', horizontal: 'left' },\n transformOrigin: { vertical: 'center', horizontal: 'right' },\n }\n case 'right':\n return {\n anchorOrigin: { vertical: 'center', horizontal: 'right' },\n transformOrigin: { vertical: 'center', horizontal: 'left' },\n }\n }\n}\n\n/** Delay in ms before the popover closes after the mouse leaves the trigger or popover */\nconst CLOSE_DELAY_MS = 150\n\nexport type HoverPopoverProps = PropsWithChildren<{\n popoverContent: ReactNode\n /** Optional title rendered as a sticky header above the scrollable content */\n title?: string\n placement?: HoverPopoverPlacement\n\n maxWidth?: string | number\n minWidth?: string | number\n /** Max height of the scrollable content area. Default 400px. */\n maxHeight?: string | number\n actionButton?: {\n content: ReactNode\n color?: ButtonProps['color']\n variant?: ButtonProps['variant']\n onClick: () => void\n /** If true, closes the popover after the button is clicked */\n closeOnClick?: boolean\n }\n}>\n\n/**\n * A popover that opens when the user hovers over the trigger child and remains\n * open as long as the mouse is over either the trigger or the popover itself.\n * The content area is scrollable, avoiding any interaction with browser scroll.\n */\nexport function HoverPopover({\n children,\n popoverContent,\n title,\n placement = 'right',\n maxWidth = 500,\n minWidth = 300,\n maxHeight = 400,\n actionButton,\n}: HoverPopoverProps) {\n const [anchorEl, setAnchorEl] = useState<HTMLElement | null>(null)\n const closeTimeoutRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const cancelClose = () => {\n if (closeTimeoutRef.current !== null) {\n clearTimeout(closeTimeoutRef.current)\n closeTimeoutRef.current = null\n }\n }\n\n const scheduleClose = () => {\n cancelClose()\n closeTimeoutRef.current = setTimeout(() => {\n setAnchorEl(null)\n }, CLOSE_DELAY_MS)\n }\n\n const { anchorOrigin, transformOrigin } = getOrigins(placement)\n\n return (\n <>\n <Box\n component=\"span\"\n onMouseEnter={e => {\n cancelClose()\n setAnchorEl(e.currentTarget)\n }}\n onMouseLeave={scheduleClose}\n className={styles.triggerWrapper}\n >\n {children}\n </Box>\n <Popover\n open={anchorEl !== null}\n anchorEl={anchorEl}\n anchorOrigin={anchorOrigin}\n transformOrigin={transformOrigin}\n onClose={() => setAnchorEl(null)}\n disableAutoFocus\n disableEnforceFocus\n disableScrollLock\n sx={{ pointerEvents: 'none' }}\n slotProps={{\n backdrop: { sx: { pointerEvents: 'none' } },\n paper: {\n onMouseEnter: cancelClose,\n onMouseLeave: scheduleClose,\n className: styles.paper,\n sx: { maxWidth, minWidth, pointerEvents: 'auto' },\n },\n }}\n >\n {title && (\n <DialogTitle sx={{ fontSize: '18px', padding: '16px 10px' }}>\n {title}\n </DialogTitle>\n )}\n <DialogContent sx={{ maxHeight, padding: '10px' }}>\n {popoverContent}\n </DialogContent>\n {actionButton && (\n <DialogActions sx={{ paddingX: '10px' }}>\n <Button\n color={actionButton.color ?? 'primary'}\n variant={actionButton.variant ?? 'contained'}\n fullWidth\n onClick={() => {\n actionButton.onClick()\n if (actionButton.closeOnClick) {\n setAnchorEl(null)\n }\n }}\n >\n {actionButton.content}\n </Button>\n </DialogActions>\n )}\n </Popover>\n </>\n )\n}\n"],"names":["getOrigins","placement","CLOSE_DELAY_MS","HoverPopover","children","popoverContent","title","maxWidth","minWidth","maxHeight","actionButton","anchorEl","setAnchorEl","useState","closeTimeoutRef","useRef","cancelClose","scheduleClose","anchorOrigin","transformOrigin","jsxs","Fragment","jsx","Box","e","styles","Popover","DialogTitle","DialogContent","DialogActions","Button"],"mappings":"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"}
|