@topconsultnpm/sdkui-react 6.20.0-dev2.43 → 6.20.0-dev2.45
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/lib/components/features/documents/TMDcmtForm.js +4 -4
- package/lib/components/features/tasks/TMTasksUtils.d.ts +1 -0
- package/lib/components/features/tasks/TMTasksUtils.js +13 -3
- package/lib/components/features/tasks/TMTasksUtilsView.js +6 -2
- package/lib/helper/SDKUI_Localizator.d.ts +1 -0
- package/lib/helper/SDKUI_Localizator.js +10 -0
- package/lib/helper/helpers.js +1 -0
- package/package.json +2 -2
|
@@ -647,7 +647,7 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
647
647
|
if (layoutMode !== LayoutModes.Update || !moreInfoTasks) {
|
|
648
648
|
return false;
|
|
649
649
|
}
|
|
650
|
-
return moreInfoTasks.some(task => isTaskMoreInfo(task.name) && task.state !== Task_States.Completed);
|
|
650
|
+
return moreInfoTasks.some(task => isTaskMoreInfo(task.name) && task.state !== Task_States.Completed && task.state !== Task_States.Closed);
|
|
651
651
|
}, [layoutMode, moreInfoTasks]);
|
|
652
652
|
const showToppyForReferences = useMemo(() => {
|
|
653
653
|
if (!allowButtonsRefs || layoutMode !== LayoutModes.Update || isOpenDetails || isOpenMaster)
|
|
@@ -1209,7 +1209,7 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
1209
1209
|
}
|
|
1210
1210
|
}, [shouldShowAll, showAll]);
|
|
1211
1211
|
const afterTaskSaved = useCallback(async (task, formMode, forceRefresh = false) => {
|
|
1212
|
-
const shouldRefresh = forceRefresh || (task && task.state === Task_States.Completed) || formMode === FormModes.Create || formMode === FormModes.Duplicate;
|
|
1212
|
+
const shouldRefresh = forceRefresh || (task && (task.state === Task_States.Completed || task.state === Task_States.Closed)) || formMode === FormModes.Create || formMode === FormModes.Duplicate;
|
|
1213
1213
|
if (TID && DID && shouldRefresh) {
|
|
1214
1214
|
await triggerBlogRefresh();
|
|
1215
1215
|
}
|
|
@@ -1373,8 +1373,8 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
1373
1373
|
};
|
|
1374
1374
|
}
|
|
1375
1375
|
try {
|
|
1376
|
-
const assignedToMe = getTaskAssignedToMe(allTasks).filter(task => task.iD1?.toString() === TID.toString() && task.iD2?.toString() === DID.toString() && task.state !== Task_States.Completed).length ?? 0;
|
|
1377
|
-
const assignedByMe = getTaskAssignedByMe(allTasks).filter(task => task.iD1?.toString() === TID.toString() && task.iD2?.toString() === DID.toString() && task.state !== Task_States.Completed).length ?? 0;
|
|
1376
|
+
const assignedToMe = getTaskAssignedToMe(allTasks).filter(task => task.iD1?.toString() === TID.toString() && task.iD2?.toString() === DID.toString() && task.state !== Task_States.Completed && task.state !== Task_States.Closed).length ?? 0;
|
|
1377
|
+
const assignedByMe = getTaskAssignedByMe(allTasks).filter(task => task.iD1?.toString() === TID.toString() && task.iD2?.toString() === DID.toString() && task.state !== Task_States.Completed && task.state !== Task_States.Closed).length ?? 0;
|
|
1378
1378
|
return {
|
|
1379
1379
|
assignedToMe,
|
|
1380
1380
|
assignedByMe
|
|
@@ -134,6 +134,8 @@ export const getStatusLocalizatorValues = () => {
|
|
|
134
134
|
switch (status) {
|
|
135
135
|
case Task_States.Completed:
|
|
136
136
|
return ({ value: status, display: SDKUI_Localizator.Completed });
|
|
137
|
+
case Task_States.Closed:
|
|
138
|
+
return ({ value: status, display: SDKUI_Localizator.Closed });
|
|
137
139
|
case Task_States.Deferred:
|
|
138
140
|
return ({ value: status, display: SDKUI_Localizator.Postponed });
|
|
139
141
|
case Task_States.InProgress:
|
|
@@ -151,6 +153,8 @@ export const getStatusLocalizatorValue = (status) => {
|
|
|
151
153
|
switch (status) {
|
|
152
154
|
case Task_States.Completed:
|
|
153
155
|
return SDKUI_Localizator.Completed;
|
|
156
|
+
case Task_States.Closed:
|
|
157
|
+
return SDKUI_Localizator.Closed;
|
|
154
158
|
case Task_States.Deferred:
|
|
155
159
|
return SDKUI_Localizator.Postponed;
|
|
156
160
|
case Task_States.InProgress:
|
|
@@ -179,7 +183,8 @@ export const getTaskNotPersonalAssignedToMe = (tasks) => {
|
|
|
179
183
|
.filter((task) => task.fromID !== undefined &&
|
|
180
184
|
task.fromID !== userID &&
|
|
181
185
|
task.toID === userID &&
|
|
182
|
-
task.state !== Task_States.Completed
|
|
186
|
+
task.state !== Task_States.Completed &&
|
|
187
|
+
task.state !== Task_States.Closed)
|
|
183
188
|
.sort((a, b) => {
|
|
184
189
|
if (!a.endTime && !b.endTime)
|
|
185
190
|
return 0;
|
|
@@ -196,7 +201,8 @@ export const getTaskPersonalAssignedToMe = (tasks) => {
|
|
|
196
201
|
.filter((task) => task.fromID !== undefined &&
|
|
197
202
|
task.fromID === userID &&
|
|
198
203
|
task.toID === userID &&
|
|
199
|
-
task.state !== Task_States.Completed
|
|
204
|
+
task.state !== Task_States.Completed &&
|
|
205
|
+
task.state !== Task_States.Closed)
|
|
200
206
|
.sort((a, b) => {
|
|
201
207
|
if (!a.endTime && !b.endTime)
|
|
202
208
|
return 0;
|
|
@@ -216,7 +222,8 @@ export const getTaskNotCompletedAssignedByMe = (tasks) => {
|
|
|
216
222
|
return tasks
|
|
217
223
|
.filter((task) => task.toID !== undefined &&
|
|
218
224
|
task.toID !== userID &&
|
|
219
|
-
task.state !== Task_States.Completed
|
|
225
|
+
task.state !== Task_States.Completed &&
|
|
226
|
+
task.state !== Task_States.Closed).sort((a, b) => {
|
|
220
227
|
if (!a.endTime && !b.endTime)
|
|
221
228
|
return 0;
|
|
222
229
|
if (!a.endTime)
|
|
@@ -484,6 +491,7 @@ export const createTasksMenuItems = (taskDescriptor, showId, setShowId, showSear
|
|
|
484
491
|
{ icon: _jsx("span", { className: "dx-icon-product" }), name: SDKUI_Localizator.NewFemale, operationType: 'multiRow', onClick: (rowIds) => markAsStatus(getRowIdsAsArray(rowIds), Task_States.NotStarted) },
|
|
485
492
|
{ icon: _jsx("span", { className: "dx-icon-refresh" }), name: SDKUI_Localizator.InProgress, operationType: 'multiRow', onClick: (rowIds) => markAsStatus(getRowIdsAsArray(rowIds), Task_States.InProgress) },
|
|
486
493
|
{ icon: _jsx("span", { className: "dx-icon-check" }), name: SDKUI_Localizator.Completed, operationType: 'multiRow', onClick: (rowIds) => markAsStatus(getRowIdsAsArray(rowIds), Task_States.Completed) },
|
|
494
|
+
{ icon: _jsx("span", { className: "dx-icon-imgarlock" }), name: SDKUI_Localizator.Closed, operationType: 'multiRow', onClick: (rowIds) => markAsStatus(getRowIdsAsArray(rowIds), Task_States.Closed) },
|
|
487
495
|
{ icon: _jsx("span", { className: "dx-icon-taskstop" }), name: SDKUI_Localizator.Pending, operationType: 'multiRow', onClick: (rowIds) => markAsStatus(getRowIdsAsArray(rowIds), Task_States.Waiting) },
|
|
488
496
|
{ icon: _jsx("span", { className: "dx-icon-clock" }), name: SDKUI_Localizator.Postponed, operationType: 'multiRow', onClick: (rowIds) => markAsStatus(getRowIdsAsArray(rowIds), Task_States.Deferred) }
|
|
489
497
|
]
|
|
@@ -636,6 +644,7 @@ export var FilterCategoryId;
|
|
|
636
644
|
FilterCategoryId[FilterCategoryId["New"] = 1.2] = "New";
|
|
637
645
|
FilterCategoryId[FilterCategoryId["InProgress"] = 1.3] = "InProgress";
|
|
638
646
|
FilterCategoryId[FilterCategoryId["Completed"] = 1.4] = "Completed";
|
|
647
|
+
FilterCategoryId[FilterCategoryId["Closed"] = 1.45] = "Closed";
|
|
639
648
|
FilterCategoryId[FilterCategoryId["Pending"] = 1.5] = "Pending";
|
|
640
649
|
FilterCategoryId[FilterCategoryId["Postponed"] = 1.6] = "Postponed";
|
|
641
650
|
FilterCategoryId[FilterCategoryId["Low"] = 2.1] = "Low";
|
|
@@ -651,6 +660,7 @@ export const filterTreeTask = (tasks, filtersApplied) => {
|
|
|
651
660
|
[FilterCategoryId.New]: (task) => task.state === undefined || task.state === Task_States.NotStarted,
|
|
652
661
|
[FilterCategoryId.InProgress]: (task) => task.state === Task_States.InProgress,
|
|
653
662
|
[FilterCategoryId.Completed]: (task) => task.state === Task_States.Completed,
|
|
663
|
+
[FilterCategoryId.Closed]: (task) => task.state === Task_States.Closed,
|
|
654
664
|
[FilterCategoryId.Pending]: (task) => task.state === Task_States.Waiting,
|
|
655
665
|
[FilterCategoryId.Postponed]: (task) => task.state === Task_States.Deferred,
|
|
656
666
|
// Low = Low + Normal: Merged 'Low' and 'Normal' filters for backwards compatibility
|
|
@@ -11,6 +11,7 @@ const taskStateIconClassMap = () => {
|
|
|
11
11
|
[Task_States.NotStarted, "dx-icon-product"],
|
|
12
12
|
[Task_States.InProgress, "dx-icon-refresh"],
|
|
13
13
|
[Task_States.Completed, "dx-icon-check"],
|
|
14
|
+
[Task_States.Closed, "dx-icon-imgarlock"],
|
|
14
15
|
[Task_States.Waiting, "dx-icon-taskstop"],
|
|
15
16
|
[Task_States.Deferred, "dx-icon-clock"],
|
|
16
17
|
]);
|
|
@@ -21,6 +22,7 @@ export const taskStateIconMap = (fontSize = 20) => {
|
|
|
21
22
|
[Task_States.NotStarted, _jsx("i", { style: { fontSize }, className: taskStateIconClassMap().get(Task_States.NotStarted) }, "Task_States-NotStarted")],
|
|
22
23
|
[Task_States.InProgress, _jsx("i", { style: { fontSize }, className: taskStateIconClassMap().get(Task_States.InProgress) }, "Task_States-InProgress")],
|
|
23
24
|
[Task_States.Completed, _jsx("i", { style: { fontSize }, className: taskStateIconClassMap().get(Task_States.Completed) }, "Task_States-Completed")],
|
|
25
|
+
[Task_States.Closed, _jsx("i", { style: { fontSize }, className: taskStateIconClassMap().get(Task_States.Closed) }, "Task_States-Closed")],
|
|
24
26
|
[Task_States.Waiting, _jsx("i", { style: { fontSize }, className: taskStateIconClassMap().get(Task_States.Waiting) }, "Task_States-Waiting")],
|
|
25
27
|
[Task_States.Deferred, _jsx("i", { style: { fontSize }, className: taskStateIconClassMap().get(Task_States.Deferred) }, "Task_States-Deferred")]
|
|
26
28
|
]);
|
|
@@ -35,8 +37,8 @@ export const calculateNumberOfDays = (startTime, endTime) => {
|
|
|
35
37
|
};
|
|
36
38
|
export const renderTaskIcons = (taskData) => {
|
|
37
39
|
const { stateLabel, stateTooltipLabel, pdg, ID1Name, endTime, remTime, isNew, numberOfDays } = taskData;
|
|
38
|
-
return (_jsxs("div", { style: { display: "flex", alignItems: "center", gap: "4px" }, children: [_jsx(TMTooltip, { content: stateTooltipLabel, children: _jsx("div", { className: "task-icon", children: taskStateIconMap().get(stateLabel) }) }), (stateLabel !== Task_States.Completed && endTime && taskIsExpiringSoon(endTime, remTime)) &&
|
|
39
|
-
_jsx(TMTooltip, { content: SDKUI_Localizator.Expiring, children: _jsx("i", { className: "dx-icon-warning task-icon" }) }), _jsx(TMTooltip, { content: gotoPDGExtendedLabel(false, pdg ?? PdGs.None, ID1Name), children: _jsx("div", { className: "task-icon", style: {
|
|
40
|
+
return (_jsxs("div", { style: { display: "flex", alignItems: "center", gap: "4px" }, children: [_jsx(TMTooltip, { content: stateTooltipLabel, children: _jsx("div", { className: "task-icon", children: taskStateIconMap().get(stateLabel) }) }), (stateLabel !== Task_States.Completed && stateLabel !== Task_States.Closed && endTime && taskIsExpiringSoon(endTime, remTime)) &&
|
|
41
|
+
_jsx(TMTooltip, { content: SDKUI_Localizator.Expiring, children: _jsx("i", { className: "dx-icon-warning task-icon", style: { fontSize: 20 } }) }), _jsx(TMTooltip, { content: gotoPDGExtendedLabel(false, pdg ?? PdGs.None, ID1Name), children: _jsx("div", { className: "task-icon", style: {
|
|
40
42
|
marginLeft: pdg === PdGs.CF || pdg === PdGs.WG ? "-4px" : undefined,
|
|
41
43
|
marginRight: pdg === PdGs.CF || pdg === PdGs.WG ? "-4px" : undefined,
|
|
42
44
|
}, children: getPdgsIconMap().get(pdg) }) }), numberOfDays > 1 &&
|
|
@@ -106,6 +108,7 @@ export const treeFilterDataSource = (allTasks) => {
|
|
|
106
108
|
const newNotStartedLength = filterTreeTask(allTasks, [FilterCategoryId.New]).length ?? 0;
|
|
107
109
|
const inProgressLength = filterTreeTask(allTasks, [FilterCategoryId.InProgress]).length ?? 0;
|
|
108
110
|
const completedLength = filterTreeTask(allTasks, [FilterCategoryId.Completed]).length ?? 0;
|
|
111
|
+
const closedLength = filterTreeTask(allTasks, [FilterCategoryId.Closed]).length ?? 0;
|
|
109
112
|
const pendingLength = filterTreeTask(allTasks, [FilterCategoryId.Pending]).length ?? 0;
|
|
110
113
|
const postponedLength = filterTreeTask(allTasks, [FilterCategoryId.Postponed]).length ?? 0;
|
|
111
114
|
const lowLength = filterTreeTask(allTasks, [FilterCategoryId.Low]).length ?? 0;
|
|
@@ -120,6 +123,7 @@ export const treeFilterDataSource = (allTasks) => {
|
|
|
120
123
|
{ id: FilterCategoryId.New, label: SDKUI_Localizator.NewFemale + " (" + newNotStartedLength + ")", value: Task_States.NotStarted, categoryId: FilterCategoryId.AllStates },
|
|
121
124
|
{ id: FilterCategoryId.InProgress, label: SDKUI_Localizator.InProgress + " (" + inProgressLength + ")", value: Task_States.InProgress, categoryId: FilterCategoryId.AllStates },
|
|
122
125
|
{ id: FilterCategoryId.Completed, label: SDKUI_Localizator.Completed + " (" + completedLength + ")", value: Task_States.Completed, categoryId: FilterCategoryId.AllStates },
|
|
126
|
+
{ id: FilterCategoryId.Closed, label: SDKUI_Localizator.Closed + " (" + closedLength + ")", value: Task_States.Closed, categoryId: FilterCategoryId.AllStates },
|
|
123
127
|
{ id: FilterCategoryId.Pending, label: SDKUI_Localizator.Pending + " (" + pendingLength + ")", value: Task_States.Waiting, categoryId: FilterCategoryId.AllStates },
|
|
124
128
|
{ id: FilterCategoryId.Postponed, label: SDKUI_Localizator.Postponed + " (" + postponedLength + ")", value: Task_States.Deferred, categoryId: FilterCategoryId.AllStates },
|
|
125
129
|
// Low = Low + Normal for backwards compatibility with version 5
|
|
@@ -99,6 +99,7 @@ export declare class SDKUI_Localizator {
|
|
|
99
99
|
static get ClearCache(): string;
|
|
100
100
|
static get ClearOTP(): "OTP löschen" | "Clear OTP" | "Borrar OTP" | "Effacer l'OTP" | "Limpar OTP" | "Cancella OTP";
|
|
101
101
|
static get Close(): "Ausgang" | "Close" | "Salida" | "Sortie" | "Saída" | "Chiudi";
|
|
102
|
+
static get Closed(): "Geschlossen" | "Closed" | "Cerrada" | "Fermée" | "Fechada" | "Chiusa";
|
|
102
103
|
static get Columns_All_Hide(): "Alle Spalten ausblenden" | "Hide all columns" | "Ocultar todas las columnas" | "Masquer toutes les colonnes" | "Ocultar todas as colunas" | "Nascondi tutte le colonne";
|
|
103
104
|
static get Columns_All_Show(): "Alle Spalten anzeigen" | "Show all columns" | "Mostrar todas las columnas" | "Afficher toutes les colonnes" | "Mostrar todas as colunas" | "Visualizza tutte le colonne";
|
|
104
105
|
static get Comment(): string;
|
|
@@ -970,6 +970,16 @@ export class SDKUI_Localizator {
|
|
|
970
970
|
default: return "Chiudi";
|
|
971
971
|
}
|
|
972
972
|
}
|
|
973
|
+
static get Closed() {
|
|
974
|
+
switch (this._cultureID) {
|
|
975
|
+
case CultureIDs.De_DE: return "Geschlossen";
|
|
976
|
+
case CultureIDs.En_US: return "Closed";
|
|
977
|
+
case CultureIDs.Es_ES: return "Cerrada";
|
|
978
|
+
case CultureIDs.Fr_FR: return "Fermée";
|
|
979
|
+
case CultureIDs.Pt_PT: return "Fechada";
|
|
980
|
+
default: return "Chiusa";
|
|
981
|
+
}
|
|
982
|
+
}
|
|
973
983
|
static get Columns_All_Hide() {
|
|
974
984
|
switch (this._cultureID) {
|
|
975
985
|
case CultureIDs.De_DE: return "Alle Spalten ausblenden";
|
package/lib/helper/helpers.js
CHANGED
|
@@ -540,6 +540,7 @@ export const getMoreInfoTasksForDocument = (allTasks, TID, DID) => {
|
|
|
540
540
|
return [];
|
|
541
541
|
return allTasks.filter(task => isTaskMoreInfo(task.name) &&
|
|
542
542
|
task.state !== Task_States.Completed &&
|
|
543
|
+
task.state !== Task_States.Closed &&
|
|
543
544
|
task.iD1?.toString() === TID.toString() &&
|
|
544
545
|
task.iD2?.toString() === DID.toString());
|
|
545
546
|
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@topconsultnpm/sdkui-react",
|
|
3
|
-
"version": "6.20.0-dev2.
|
|
3
|
+
"version": "6.20.0-dev2.45",
|
|
4
4
|
"description": "",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"test": "echo \"Error: no test specified\" && exit 1",
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
"lib"
|
|
41
41
|
],
|
|
42
42
|
"dependencies": {
|
|
43
|
-
"@topconsultnpm/sdk-ts": "6.20.0-dev2.
|
|
43
|
+
"@topconsultnpm/sdk-ts": "6.20.0-dev2.12",
|
|
44
44
|
"buffer": "^6.0.3",
|
|
45
45
|
"devextreme": "25.2.4",
|
|
46
46
|
"devextreme-react": "25.2.4",
|