- LOAD_TREE_PICKER_NODE: ({ id, pickerId }) => {
- const picker = state[pickerId] || createTree();
- const updatedPicker = setNodeValueWith(setPending)(id)(picker);
- return { ...state, [pickerId]: updatedPicker };
- },
- LOAD_TREE_PICKER_NODE_SUCCESS: ({ id, nodes, pickerId }) => {
- const picker = state[pickerId] || createTree();
- const [updatedPicker] = [picker]
- .map(receiveNodes(nodes)(id))
- .map(setNodeValueWith(setLoaded)(id));
- return { ...state, [pickerId]: updatedPicker };
- },
- TOGGLE_TREE_PICKER_NODE_COLLAPSE: ({ id, pickerId }) => {
- const picker = state[pickerId] || createTree();
- const updatedPicker = setNodeValueWith(toggleCollapse)(id)(picker);
- return { ...state, [pickerId]: updatedPicker };
- },
- TOGGLE_TREE_PICKER_NODE_SELECT: ({ id, pickerId }) => {
- const picker = state[pickerId] || createTree();
- const updatedPicker = mapTreeValues(toggleSelect(id))(picker);
- return { ...state, [pickerId]: updatedPicker };
- },
+ LOAD_TREE_PICKER_NODE: ({ nodeId, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, setNodeValueWith(setPending)(nodeId)),
+ LOAD_TREE_PICKER_NODE_SUCCESS: ({ nodeId, nodes, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, compose(receiveNodes(nodes)(nodeId), setNodeValueWith(setLoaded)(nodeId))),
+ TOGGLE_TREE_PICKER_NODE_COLLAPSE: ({ nodeId, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, setNodeValueWith(toggleCollapse)(nodeId)),
+ TOGGLE_TREE_PICKER_NODE_SELECT: ({ nodeId, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, mapTreeValues(toggleSelect(nodeId))),
+ RESET_TREE_PICKER: ({ pickerId }) =>
+ updateOrCreatePicker(state, pickerId, createTree),
+ EXPAND_TREE_PICKER_NODES: ({ pickerId, nodeIds }) =>
+ updateOrCreatePicker(state, pickerId, mapTreeValues(expand(nodeIds))),