-
Notifications
You must be signed in to change notification settings - Fork 0
/
TestReducer.js
78 lines (74 loc) · 1.75 KB
/
TestReducer.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
export default function TestReducer() {
const animatedWidthStyle = useAnimatedStyle(() => ({
width: `${progressWidth.value}%`
})
)
const deleteRef = useRef("")
const progressWidth = useSharedValue(0);
const height = useSharedValue(0);
const inputRef = useRef("")
const clipboardItems = useRef([])
const operationSource = useRef("")
const operationDest = useRef("")
const operationType = useRef(-1)
const failedItems = useRef([])
const decisionRef = useRef("")
const nameNewItem = useRef("")
}
const initialState = {
mainCache: {},
clipboardItems: [],
tabs: {},
tabCounter: 0,
currTab: "0",
funcId: -1,
breakOperation: 0,
favouriteItems: [],
favPaths: [],
mediaType: 0,
mediaBox: 0,
forceRefresh: 0,
showPaste: 0,
selectedItem: [],
alreadyExists: 0,
progressModal: 0,
inputModal: 0,
itemExistsModal: 0,
favouritesModal: 0,
clipBoardModal: 0,
deleteModal: 0,
aboutModal: 0,
progress: 0,
contextMenu: 0,
}
const rootReducer = combineReducers({
clipboardItems: clipBoardReducer
})
const [state, dispatch] = useReducer(rootReducer, initialState);
const clipBoardReducer = (state, action) => {
switch (action.type) {
case 'COPYTOCB':
return action.payload
case 'DELETECB':
return [...state].filter((item) => item.path !== action.payload)
case 'CLEARCB':
return []
}
}
const copyToCB = (selectedItems) => {
dispatch({
type: 'COPYTOCB',
payload: selectedItems
})
}
const deleteCB = (path) => {
dispatch({
type: 'DELETECB',
payload: path
})
}
const clearCB = () => {
dispatch({
type: 'CLEARCB'
})
}