@axinom/mosaic-ui 0.35.0 → 0.36.0-rc.1
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/components/DynamicDataList/DynamicDataList.d.ts +3 -1
- package/dist/components/DynamicDataList/DynamicDataList.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicDataList.model.d.ts +6 -1
- package/dist/components/DynamicDataList/DynamicDataList.model.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.d.ts +7 -3
- package/dist/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.d.ts.map +1 -1
- package/dist/components/DynamicDataList/DynamicListRow/DynamicListRow.d.ts +4 -1
- package/dist/components/DynamicDataList/DynamicListRow/DynamicListRow.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.types.d.ts +7 -1
- package/dist/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.types.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/useDataHandler.d.ts +1 -0
- package/dist/components/DynamicDataList/helpers/useDataHandler.d.ts.map +1 -1
- package/dist/components/DynamicDataList/helpers/useRowEditing.d.ts +8 -0
- package/dist/components/DynamicDataList/helpers/useRowEditing.d.ts.map +1 -0
- package/dist/index.es.js +4 -4
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
- package/src/components/DynamicDataList/DynamicDataList.model.ts +7 -2
- package/src/components/DynamicDataList/DynamicDataList.spec.tsx +5 -0
- package/src/components/DynamicDataList/DynamicDataList.stories.tsx +37 -0
- package/src/components/DynamicDataList/DynamicDataList.tsx +58 -28
- package/src/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.scss +0 -1
- package/src/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.spec.tsx +2 -44
- package/src/components/DynamicDataList/DynamicListDataEntry/DynamicListDataEntry.tsx +37 -28
- package/src/components/DynamicDataList/DynamicListRow/DynamicListRow.scss +12 -0
- package/src/components/DynamicDataList/DynamicListRow/DynamicListRow.tsx +23 -12
- package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.spec.ts +26 -1
- package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.ts +8 -0
- package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.types.ts +8 -0
- package/src/components/DynamicDataList/helpers/useDataHandler.ts +11 -1
- package/src/components/DynamicDataList/helpers/useRowEditing.ts +30 -0
- package/src/styles/variables.scss +1 -1
package/src/components/DynamicDataList/helpers/DynamicListReducer/DynamicListReducer.types.ts
CHANGED
|
@@ -10,12 +10,14 @@ export interface DynamicListReducerInitArgs<T extends Data> {
|
|
|
10
10
|
export enum DynamicListReducerActionType {
|
|
11
11
|
Add = 'add',
|
|
12
12
|
Remove = 'remove',
|
|
13
|
+
Update = 'update',
|
|
13
14
|
Reset = 'reset',
|
|
14
15
|
}
|
|
15
16
|
|
|
16
17
|
export type DynamicListReducerAction<T extends Data> =
|
|
17
18
|
| DynamicListReducerAddAction<T>
|
|
18
19
|
| DynamicListReducerRemoveAction<T>
|
|
20
|
+
| DynamicListReducerUpdateAction<T>
|
|
19
21
|
| DynamicListReducerResetAction<T>;
|
|
20
22
|
|
|
21
23
|
interface DynamicListReducerAddAction<T extends Data> {
|
|
@@ -28,6 +30,12 @@ interface DynamicListReducerRemoveAction<T extends Data> {
|
|
|
28
30
|
item: T;
|
|
29
31
|
}
|
|
30
32
|
|
|
33
|
+
interface DynamicListReducerUpdateAction<T extends Data> {
|
|
34
|
+
type: DynamicListReducerActionType.Update;
|
|
35
|
+
currentItem: T;
|
|
36
|
+
newItem: T;
|
|
37
|
+
}
|
|
38
|
+
|
|
31
39
|
interface DynamicListReducerResetAction<T extends Data> {
|
|
32
40
|
type: DynamicListReducerActionType.Reset;
|
|
33
41
|
items: T[];
|
|
@@ -22,6 +22,7 @@ export const useDataHandler = <T extends Data>(
|
|
|
22
22
|
readonly canAddItems: boolean;
|
|
23
23
|
readonly addItem: (item: T) => void;
|
|
24
24
|
readonly removeItem: (item: T) => void;
|
|
25
|
+
readonly updateItem: (currentItem: T, newItem: T) => void;
|
|
25
26
|
} => {
|
|
26
27
|
const [shouldTriggerOnChange, setShouldTriggerOnChange] = useState(false);
|
|
27
28
|
|
|
@@ -71,7 +72,16 @@ export const useDataHandler = <T extends Data>(
|
|
|
71
72
|
setShouldTriggerOnChange(true);
|
|
72
73
|
};
|
|
73
74
|
|
|
75
|
+
const updateItem = (currentItem: T, newItem: T): void => {
|
|
76
|
+
dispatch({
|
|
77
|
+
type: DynamicListReducerActionType.Update,
|
|
78
|
+
currentItem,
|
|
79
|
+
newItem,
|
|
80
|
+
});
|
|
81
|
+
setShouldTriggerOnChange(true);
|
|
82
|
+
};
|
|
83
|
+
|
|
74
84
|
const { items, nextPosition, canAddItems } = state;
|
|
75
85
|
|
|
76
|
-
return { items, nextPosition, canAddItems, addItem, removeItem };
|
|
86
|
+
return { items, nextPosition, canAddItems, addItem, removeItem, updateItem };
|
|
77
87
|
};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { useState } from 'react';
|
|
2
|
+
import { Data } from '../../../types';
|
|
3
|
+
|
|
4
|
+
export const useRowEditing = <T extends Data>(
|
|
5
|
+
allowEditing: boolean,
|
|
6
|
+
updateItem: (currentItem: T, newItem: T) => void,
|
|
7
|
+
): {
|
|
8
|
+
readonly editingRow: T | undefined;
|
|
9
|
+
readonly isEditing: boolean;
|
|
10
|
+
readonly startEditing: (item: T) => void;
|
|
11
|
+
readonly finishEditing: (item: T) => void;
|
|
12
|
+
} => {
|
|
13
|
+
const [editingRow, setEditingRow] = useState<T>();
|
|
14
|
+
|
|
15
|
+
const startEditing = (item: T): void => {
|
|
16
|
+
allowEditing && setEditingRow(item);
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const finishEditing = (item: T): void => {
|
|
20
|
+
updateItem(editingRow as T, item);
|
|
21
|
+
setEditingRow(undefined);
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
return {
|
|
25
|
+
editingRow,
|
|
26
|
+
isEditing: !!editingRow,
|
|
27
|
+
startEditing,
|
|
28
|
+
finishEditing,
|
|
29
|
+
};
|
|
30
|
+
};
|
|
@@ -223,7 +223,7 @@ $calendar-container-bg-color: $blue;
|
|
|
223
223
|
|
|
224
224
|
/* Dynamic Data List */
|
|
225
225
|
$dynamic-list-row-bg-color: white;
|
|
226
|
-
$dynamic-list-row-hover-bg-color: $
|
|
226
|
+
$dynamic-list-row-hover-bg-color: rgba($blue, 0.1);
|
|
227
227
|
$dynamic-list-row-height: 50px;
|
|
228
228
|
$dynamic-list-column-gap: 20px;
|
|
229
229
|
$dynamic-list-row-gap: 0px;
|