@zeniai/client-epic-state 5.1.3-betaJK1 → 5.1.3

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.
Files changed (34) hide show
  1. package/lib/entity/snackbar/snackbarTypes.d.ts +1 -1
  2. package/lib/entity/snackbar/snackbarTypes.js +0 -1
  3. package/lib/entity/task/taskPayload.d.ts +0 -1
  4. package/lib/entity/task/taskPayload.js +0 -1
  5. package/lib/entity/task/taskReducer.d.ts +1 -5
  6. package/lib/entity/task/taskReducer.js +2 -8
  7. package/lib/entity/task/taskState.d.ts +0 -1
  8. package/lib/epic.d.ts +1 -3
  9. package/lib/epic.js +1 -3
  10. package/lib/esm/entity/snackbar/snackbarTypes.js +0 -1
  11. package/lib/esm/entity/task/taskPayload.js +0 -1
  12. package/lib/esm/entity/task/taskReducer.js +1 -7
  13. package/lib/esm/epic.js +1 -3
  14. package/lib/esm/index.js +2 -2
  15. package/lib/esm/view/taskManager/taskDetailView/epics/fetchTaskDetailEpic.js +0 -13
  16. package/lib/esm/view/taskManager/taskDetailView/taskDetailReducer.js +2 -56
  17. package/lib/esm/view/taskManager/taskDetailView/taskDetailSelector.js +8 -19
  18. package/lib/index.d.ts +3 -3
  19. package/lib/index.js +9 -12
  20. package/lib/view/expenseAutomationView/helpers/transactionCategorizationLocalDataHelper.d.ts +1 -1
  21. package/lib/view/taskManager/taskDetailView/epics/fetchTaskDetailEpic.d.ts +1 -2
  22. package/lib/view/taskManager/taskDetailView/epics/fetchTaskDetailEpic.js +0 -13
  23. package/lib/view/taskManager/taskDetailView/taskDetail.d.ts +0 -13
  24. package/lib/view/taskManager/taskDetailView/taskDetailReducer.d.ts +2 -14
  25. package/lib/view/taskManager/taskDetailView/taskDetailReducer.js +3 -57
  26. package/lib/view/taskManager/taskDetailView/taskDetailSelector.d.ts +1 -2
  27. package/lib/view/taskManager/taskDetailView/taskDetailSelector.js +6 -17
  28. package/package.json +1 -1
  29. package/lib/esm/view/taskManager/taskDetailView/epics/createSubTaskEpic.js +0 -80
  30. package/lib/esm/view/taskManager/taskDetailView/epics/fetchSubTasksEpic.js +0 -36
  31. package/lib/view/taskManager/taskDetailView/epics/createSubTaskEpic.d.ts +0 -9
  32. package/lib/view/taskManager/taskDetailView/epics/createSubTaskEpic.js +0 -84
  33. package/lib/view/taskManager/taskDetailView/epics/fetchSubTasksEpic.d.ts +0 -8
  34. package/lib/view/taskManager/taskDetailView/epics/fetchSubTasksEpic.js +0 -40
@@ -2,7 +2,7 @@ import { FetchStateAndError, ID } from '../../../commonStateTypes/common';
2
2
  import { SelectorView } from '../../../commonStateTypes/viewAndReport/viewAndReport';
3
3
  import { Class } from '../../../entity/class/classState';
4
4
  import { File } from '../../../entity/file/fileState';
5
- import { Task, TaskPriority, TaskStatus } from '../../../entity/task/taskState';
5
+ import { TaskPriority, TaskStatus } from '../../../entity/task/taskState';
6
6
  import { RootState } from '../../../reducer';
7
7
  import { ZeniDate } from '../../../zeniDayJS';
8
8
  import { UserAndRole } from '../../companyView/types/userAndRole';
@@ -14,7 +14,6 @@ export interface TaskDetailSelectorView extends SelectorView {
14
14
  deleteFileStatusById: Record<ID, FetchStateAndError | undefined>;
15
15
  files: File[];
16
16
  showTaskDetailFormFooter: boolean;
17
- subtasks: Task[];
18
17
  taskDetailView: EditTaskDetail;
19
18
  taskHistory: HistoricEvent[];
20
19
  updateFileStatusById: Record<ID, FetchStateAndError | undefined>;
@@ -33,13 +33,8 @@ const getTaskDetail = (state, taskId) => {
33
33
  let recurringSourceTaskId = undefined;
34
34
  let snoozedUntil = undefined;
35
35
  let taskGroupId = undefined;
36
- let subtasks = [];
37
36
  if (taskId != null && sourceTaskDetail != null) {
38
37
  const taskEntity = (0, taskSelector_1.getTaskById)(taskState, taskId);
39
- subtasks =
40
- taskEntity != null
41
- ? (0, taskSelector_1.getTasksByIds)(taskState, taskEntity.subTasksIds)
42
- : [];
43
38
  const fileIdsInEntity = taskEntity?.fileIds ?? [];
44
39
  if (taskEntity != null) {
45
40
  createdByUser = (0, userAndRole_1.getUserAndUserRole)(userState, userRoleState, addressState, taskEntity.createdBy);
@@ -50,27 +45,25 @@ const getTaskDetail = (state, taskId) => {
50
45
  taskGroupId = taskEntity.taskGroupIds[0];
51
46
  }
52
47
  if (fileIdsInEntity.length > 0) {
53
- fetchStatus = (0, reduceFetchState_1.reduceAnyFetchState)([
48
+ fetchStatus = (0, reduceFetchState_1.reduceFetchState)([
54
49
  fileViewState.fetchFilesStatus,
55
50
  sourceTaskDetail.fetchTaskStatus,
56
51
  userList,
57
52
  classListState,
58
- taskDetailState.subTaskListFetchStatusByParentId[taskId] ?? fetchStatus,
59
53
  ]);
60
54
  }
61
55
  else {
62
- fetchStatus = (0, reduceFetchState_1.reduceAnyFetchState)([
56
+ fetchStatus = (0, reduceFetchState_1.reduceFetchState)([
63
57
  sourceTaskDetail.fetchTaskStatus,
64
58
  userList,
65
59
  classListState,
66
- taskDetailState.subTaskListFetchStatusByParentId[taskId] ?? fetchStatus,
67
60
  ]);
68
61
  }
69
62
  showTaskDetailFormFooter = showFormFooter(sourceTaskDetail.taskDetailLocalData, taskEntity);
70
63
  taskHistory = taskDetailState.taskHistoryById[taskId]?.historicEvents ?? [];
71
64
  }
72
65
  else if (taskId == null) {
73
- fetchStatus = (0, reduceFetchState_1.reduceAnyFetchState)([userList, classListState]);
66
+ fetchStatus = (0, reduceFetchState_1.reduceFetchState)([userList, classListState]);
74
67
  }
75
68
  const { classIds } = classListState;
76
69
  const allAccountingClasses = (0, classSelector_1.getClassesByIds)(classState, {
@@ -103,7 +96,6 @@ const getTaskDetail = (state, taskId) => {
103
96
  showTaskDetailFormFooter,
104
97
  snoozedUntil,
105
98
  taskGroupId,
106
- subtasks,
107
99
  };
108
100
  };
109
101
  exports.getTaskDetail = getTaskDetail;
@@ -152,16 +144,13 @@ exports.allTaskPriority = [
152
144
  },
153
145
  ];
154
146
  const showFormFooter = (taskDetailLocalData, taskDetailInStore) => {
155
- if (taskDetailInStore == null) {
156
- return false;
157
- }
158
- if (taskDetailLocalData.name !== taskDetailInStore.name ||
147
+ if (taskDetailLocalData.name !== taskDetailInStore?.name ||
159
148
  taskDetailLocalData.description !== taskDetailInStore.description ||
160
149
  taskDetailLocalData.priority !== taskDetailInStore.priority.code ||
161
150
  taskDetailLocalData.status !== taskDetailInStore.status.code ||
162
151
  !(0, isEqual_1.default)(taskDetailInStore.tagIds, taskDetailLocalData.tagIds) ||
163
- !(0, isEqual_1.default)(taskDetailLocalData.assignee, taskDetailInStore.assignees ?? []) ||
164
- !(0, isEqual_1.default)(taskDetailLocalData.groupAssignees, taskDetailInStore.groupAssignees ?? []) ||
152
+ !(0, isEqual_1.default)(taskDetailLocalData.assignee, taskDetailInStore?.assignees ?? []) ||
153
+ !(0, isEqual_1.default)(taskDetailLocalData.groupAssignees, taskDetailInStore?.groupAssignees ?? []) ||
165
154
  !(0, isEqual_1.default)(taskDetailLocalData.fileIds, taskDetailInStore.fileIds ?? []) ||
166
155
  !(0, isEqual_1.default)(taskDetailLocalData.dueDate, taskDetailInStore.dueDate) ||
167
156
  !(0, isEqual_1.default)(taskDetailLocalData.type, taskDetailInStore.type) ||
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zeniai/client-epic-state",
3
- "version": "5.1.3-betaJK1",
3
+ "version": "5.1.3",
4
4
  "description": "Shared module between Web & Mobile containing required abstractions for state management, async network communication. ",
5
5
  "main": "lib/index.js",
6
6
  "module": "lib/esm/index.js",
@@ -1,80 +0,0 @@
1
- import { from, of } from 'rxjs';
2
- import { catchError, filter, mergeMap } from 'rxjs/operators';
3
- import { convertHHMMStrToMinutes } from '../../../../commonStateTypes/fiscalYearHelpers/formatMinutesToFromHHMM';
4
- import { openSnackbar } from '../../../../entity/snackbar/snackbarReducer';
5
- import { appendSubTaskId, updateTasks, } from '../../../../entity/task/taskReducer';
6
- import { getTaskById } from '../../../../entity/task/taskSelector';
7
- import { createZeniAPIStatus, isSuccessResponse, } from '../../../../responsePayload';
8
- import { updateTaskListOnNewTaskCreationSuccess } from '../../taskListView/taskListReducer';
9
- import { createSubTask, createSubTaskSuccessOrFailure, } from '../taskDetailReducer';
10
- export const createSubTaskEpic = (actions$, state$, zeniAPI) => actions$.pipe(filter(createSubTask.match), mergeMap((action) => {
11
- const state = state$.value;
12
- const parentTask = getTaskById(state.taskState, action.payload.parentTaskId);
13
- const parentTaskGroupId = parentTask?.taskGroupIds[0];
14
- const isTaskListFetched = state.taskListState.fetchState === 'Completed';
15
- const payload = prepareSubTaskPayload(action.payload, parentTaskGroupId);
16
- return zeniAPI
17
- .postAndGetJSON(`${zeniAPI.apiEndPoints.taskMicroServiceBaseUrl}/1.0/task-manager/tasks`, payload)
18
- .pipe(mergeMap((response) => {
19
- if (isSuccessResponse(response) &&
20
- response.data != null &&
21
- response.data.tasks.length > 0) {
22
- const newTaskId = response.data.tasks[0].task_id;
23
- const actions = [
24
- updateTasks(response.data.tasks),
25
- appendSubTaskId({
26
- parentTaskId: action.payload.parentTaskId,
27
- subTaskId: newTaskId,
28
- }),
29
- createSubTaskSuccessOrFailure({
30
- fetchState: 'Completed',
31
- newTaskId,
32
- }),
33
- openSnackbar({
34
- messageSection: 'create_sub_task',
35
- messageText: 'success',
36
- type: 'success',
37
- }),
38
- ];
39
- if (isTaskListFetched === true && parentTaskGroupId != null) {
40
- actions.push(updateTaskListOnNewTaskCreationSuccess({
41
- taskGroupId: parentTaskGroupId,
42
- task: response.data.tasks[0],
43
- }));
44
- }
45
- return from(actions);
46
- }
47
- else {
48
- return of(createSubTaskSuccessOrFailure({
49
- fetchState: 'Error',
50
- error: response.status,
51
- }), openSnackbar({
52
- messageSection: 'create_sub_task',
53
- messageText: 'failed',
54
- type: 'error',
55
- variables: [
56
- {
57
- variableName: '_api-error_',
58
- variableValue: response.status.message,
59
- },
60
- ],
61
- }));
62
- }
63
- }), catchError((error) => of(createSubTaskSuccessOrFailure({
64
- fetchState: 'Error',
65
- error: createZeniAPIStatus('Unexpected Error', 'Create Sub Task REST API call errored out' +
66
- JSON.stringify(error)),
67
- }))));
68
- }));
69
- const prepareSubTaskPayload = (subTask, parentTaskGroupId) => ({
70
- name: subTask.name,
71
- assignees: subTask.assignee,
72
- description: subTask.description,
73
- priority: subTask.priority,
74
- status: subTask.status,
75
- tags: subTask.tagIds,
76
- time_spent: convertHHMMStrToMinutes(subTask.timeSpent),
77
- group_assignees: subTask.groupAssignees,
78
- parent_task_id: subTask.parentTaskId,
79
- task_group_ids: parentTaskGroupId == null ? [] : [parentTaskGroupId],
80
- });
@@ -1,36 +0,0 @@
1
- import { of } from 'rxjs';
2
- import { catchError, filter, mergeMap, switchMap } from 'rxjs/operators';
3
- import { updateTasks } from '../../../../entity/task/taskReducer';
4
- import { createZeniAPIStatus, isSuccessResponse, } from '../../../../responsePayload';
5
- import { fetchSubTasks, updateSubTasks, updateSubTasksFetchStatus, } from '../taskDetailReducer';
6
- export const fetchSubTasksEpic = (actions$, _state$, zeniAPI) => actions$.pipe(filter(fetchSubTasks.match), switchMap((action) => {
7
- const { parentTaskId } = action.payload;
8
- const query = JSON.stringify({
9
- task_type: 'subtasks',
10
- parent_task_id: parentTaskId,
11
- });
12
- return zeniAPI
13
- .getJSON(`${zeniAPI.apiEndPoints.taskMicroServiceBaseUrl}/1.0/task-manager/tasks?query=${encodeURIComponent(query)}`)
14
- .pipe(mergeMap((response) => {
15
- if (isSuccessResponse(response) && response.data != null) {
16
- const { tasks } = response.data;
17
- return of(updateTasks(tasks), updateSubTasks({
18
- parentTaskId,
19
- }));
20
- }
21
- else {
22
- return of(updateSubTasksFetchStatus({
23
- parentTaskId,
24
- fetchState: 'Error',
25
- error: response.status,
26
- }));
27
- }
28
- }), catchError((error) => {
29
- return of(updateSubTasksFetchStatus({
30
- parentTaskId,
31
- fetchState: 'Error',
32
- error: createZeniAPIStatus('Unexpected Error', 'Fetch Sub Tasks REST API call errored out' +
33
- JSON.stringify(error)),
34
- }));
35
- }));
36
- }));
@@ -1,9 +0,0 @@
1
- import { ActionsObservable, StateObservable } from 'redux-observable';
2
- import { openSnackbar } from '../../../../entity/snackbar/snackbarReducer';
3
- import { appendSubTaskId, updateTasks } from '../../../../entity/task/taskReducer';
4
- import { RootState } from '../../../../reducer';
5
- import { ZeniAPI } from '../../../../zeniAPI';
6
- import { updateTaskListOnNewTaskCreationSuccess } from '../../taskListView/taskListReducer';
7
- import { createSubTask, createSubTaskSuccessOrFailure } from '../taskDetailReducer';
8
- export type ActionType = ReturnType<typeof createSubTask> | ReturnType<typeof updateTasks> | ReturnType<typeof appendSubTaskId> | ReturnType<typeof openSnackbar> | ReturnType<typeof updateTaskListOnNewTaskCreationSuccess> | ReturnType<typeof createSubTaskSuccessOrFailure>;
9
- export declare const createSubTaskEpic: (actions$: ActionsObservable<ActionType>, state$: StateObservable<RootState>, zeniAPI: ZeniAPI) => import("rxjs").Observable<ActionType>;
@@ -1,84 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createSubTaskEpic = void 0;
4
- const rxjs_1 = require("rxjs");
5
- const operators_1 = require("rxjs/operators");
6
- const formatMinutesToFromHHMM_1 = require("../../../../commonStateTypes/fiscalYearHelpers/formatMinutesToFromHHMM");
7
- const snackbarReducer_1 = require("../../../../entity/snackbar/snackbarReducer");
8
- const taskReducer_1 = require("../../../../entity/task/taskReducer");
9
- const taskSelector_1 = require("../../../../entity/task/taskSelector");
10
- const responsePayload_1 = require("../../../../responsePayload");
11
- const taskListReducer_1 = require("../../taskListView/taskListReducer");
12
- const taskDetailReducer_1 = require("../taskDetailReducer");
13
- const createSubTaskEpic = (actions$, state$, zeniAPI) => actions$.pipe((0, operators_1.filter)(taskDetailReducer_1.createSubTask.match), (0, operators_1.mergeMap)((action) => {
14
- const state = state$.value;
15
- const parentTask = (0, taskSelector_1.getTaskById)(state.taskState, action.payload.parentTaskId);
16
- const parentTaskGroupId = parentTask?.taskGroupIds[0];
17
- const isTaskListFetched = state.taskListState.fetchState === 'Completed';
18
- const payload = prepareSubTaskPayload(action.payload, parentTaskGroupId);
19
- return zeniAPI
20
- .postAndGetJSON(`${zeniAPI.apiEndPoints.taskMicroServiceBaseUrl}/1.0/task-manager/tasks`, payload)
21
- .pipe((0, operators_1.mergeMap)((response) => {
22
- if ((0, responsePayload_1.isSuccessResponse)(response) &&
23
- response.data != null &&
24
- response.data.tasks.length > 0) {
25
- const newTaskId = response.data.tasks[0].task_id;
26
- const actions = [
27
- (0, taskReducer_1.updateTasks)(response.data.tasks),
28
- (0, taskReducer_1.appendSubTaskId)({
29
- parentTaskId: action.payload.parentTaskId,
30
- subTaskId: newTaskId,
31
- }),
32
- (0, taskDetailReducer_1.createSubTaskSuccessOrFailure)({
33
- fetchState: 'Completed',
34
- newTaskId,
35
- }),
36
- (0, snackbarReducer_1.openSnackbar)({
37
- messageSection: 'create_sub_task',
38
- messageText: 'success',
39
- type: 'success',
40
- }),
41
- ];
42
- if (isTaskListFetched === true && parentTaskGroupId != null) {
43
- actions.push((0, taskListReducer_1.updateTaskListOnNewTaskCreationSuccess)({
44
- taskGroupId: parentTaskGroupId,
45
- task: response.data.tasks[0],
46
- }));
47
- }
48
- return (0, rxjs_1.from)(actions);
49
- }
50
- else {
51
- return (0, rxjs_1.of)((0, taskDetailReducer_1.createSubTaskSuccessOrFailure)({
52
- fetchState: 'Error',
53
- error: response.status,
54
- }), (0, snackbarReducer_1.openSnackbar)({
55
- messageSection: 'create_sub_task',
56
- messageText: 'failed',
57
- type: 'error',
58
- variables: [
59
- {
60
- variableName: '_api-error_',
61
- variableValue: response.status.message,
62
- },
63
- ],
64
- }));
65
- }
66
- }), (0, operators_1.catchError)((error) => (0, rxjs_1.of)((0, taskDetailReducer_1.createSubTaskSuccessOrFailure)({
67
- fetchState: 'Error',
68
- error: (0, responsePayload_1.createZeniAPIStatus)('Unexpected Error', 'Create Sub Task REST API call errored out' +
69
- JSON.stringify(error)),
70
- }))));
71
- }));
72
- exports.createSubTaskEpic = createSubTaskEpic;
73
- const prepareSubTaskPayload = (subTask, parentTaskGroupId) => ({
74
- name: subTask.name,
75
- assignees: subTask.assignee,
76
- description: subTask.description,
77
- priority: subTask.priority,
78
- status: subTask.status,
79
- tags: subTask.tagIds,
80
- time_spent: (0, formatMinutesToFromHHMM_1.convertHHMMStrToMinutes)(subTask.timeSpent),
81
- group_assignees: subTask.groupAssignees,
82
- parent_task_id: subTask.parentTaskId,
83
- task_group_ids: parentTaskGroupId == null ? [] : [parentTaskGroupId],
84
- });
@@ -1,8 +0,0 @@
1
- import { ActionsObservable, StateObservable } from 'redux-observable';
2
- import { Observable } from 'rxjs';
3
- import { updateTasks } from '../../../../entity/task/taskReducer';
4
- import { RootState } from '../../../../reducer';
5
- import { ZeniAPI } from '../../../../zeniAPI';
6
- import { fetchSubTasks, updateSubTasks, updateSubTasksFetchStatus } from '../taskDetailReducer';
7
- export type ActionType = ReturnType<typeof fetchSubTasks> | ReturnType<typeof updateTasks> | ReturnType<typeof updateSubTasks> | ReturnType<typeof updateSubTasksFetchStatus>;
8
- export declare const fetchSubTasksEpic: (actions$: ActionsObservable<ActionType>, _state$: StateObservable<RootState>, zeniAPI: ZeniAPI) => Observable<ActionType>;
@@ -1,40 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.fetchSubTasksEpic = void 0;
4
- const rxjs_1 = require("rxjs");
5
- const operators_1 = require("rxjs/operators");
6
- const taskReducer_1 = require("../../../../entity/task/taskReducer");
7
- const responsePayload_1 = require("../../../../responsePayload");
8
- const taskDetailReducer_1 = require("../taskDetailReducer");
9
- const fetchSubTasksEpic = (actions$, _state$, zeniAPI) => actions$.pipe((0, operators_1.filter)(taskDetailReducer_1.fetchSubTasks.match), (0, operators_1.switchMap)((action) => {
10
- const { parentTaskId } = action.payload;
11
- const query = JSON.stringify({
12
- task_type: 'subtasks',
13
- parent_task_id: parentTaskId,
14
- });
15
- return zeniAPI
16
- .getJSON(`${zeniAPI.apiEndPoints.taskMicroServiceBaseUrl}/1.0/task-manager/tasks?query=${encodeURIComponent(query)}`)
17
- .pipe((0, operators_1.mergeMap)((response) => {
18
- if ((0, responsePayload_1.isSuccessResponse)(response) && response.data != null) {
19
- const { tasks } = response.data;
20
- return (0, rxjs_1.of)((0, taskReducer_1.updateTasks)(tasks), (0, taskDetailReducer_1.updateSubTasks)({
21
- parentTaskId,
22
- }));
23
- }
24
- else {
25
- return (0, rxjs_1.of)((0, taskDetailReducer_1.updateSubTasksFetchStatus)({
26
- parentTaskId,
27
- fetchState: 'Error',
28
- error: response.status,
29
- }));
30
- }
31
- }), (0, operators_1.catchError)((error) => {
32
- return (0, rxjs_1.of)((0, taskDetailReducer_1.updateSubTasksFetchStatus)({
33
- parentTaskId,
34
- fetchState: 'Error',
35
- error: (0, responsePayload_1.createZeniAPIStatus)('Unexpected Error', 'Fetch Sub Tasks REST API call errored out' +
36
- JSON.stringify(error)),
37
- }));
38
- }));
39
- }));
40
- exports.fetchSubTasksEpic = fetchSubTasksEpic;