- LOAD_TREE_PICKER_NODE: ({ id, pickerKind }) => {
- const picker = state[pickerKind] || createTree();
- const updatedPicker = setNodeValueWith(setPending)(id)(picker);
- return { ...state, [pickerKind]: updatedPicker };
- },
- LOAD_TREE_PICKER_NODE_SUCCESS: ({ id, nodes, pickerKind }) => {
- const picker = state[pickerKind] || createTree();
- const [updatedPicker] = [picker]
- .map(receiveNodes(nodes)(id))
- .map(setNodeValueWith(setLoaded)(id));
- return { ...state, [pickerKind]: updatedPicker };
- },
- TOGGLE_TREE_PICKER_NODE_COLLAPSE: ({ id, pickerKind }) => {
- const picker = state[pickerKind] || createTree();
- const updatedPicker = setNodeValueWith(toggleCollapse)(id)(picker);
- return { ...state, [pickerKind]: updatedPicker };
- },
- TOGGLE_TREE_PICKER_NODE_SELECT: ({ id, pickerKind }) => {
- const picker = state[pickerKind] || createTree();
- const updatedPicker = mapTreeValues(toggleSelect(id))(picker);
- return { ...state, [pickerKind]: updatedPicker };
- },
+ LOAD_TREE_PICKER_NODE: ({ id, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, setNodeStatus(id)(TreeNodeStatus.PENDING)),
+ LOAD_TREE_PICKER_NODE_SUCCESS: ({ id, nodes, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, compose(receiveNodes(nodes)(id), setNodeStatus(id)(TreeNodeStatus.LOADED))),
+ TOGGLE_TREE_PICKER_NODE_COLLAPSE: ({ id, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, toggleNodeCollapse(id)),
+ ACTIVATE_TREE_PICKER_NODE: ({ id, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, activateNode(id)),
+ TOGGLE_TREE_PICKER_NODE_SELECTION: ({ id, pickerId }) =>
+ updateOrCreatePicker(state, pickerId, toggleNodeSelection(id)),
+ RESET_TREE_PICKER: ({ pickerId }) =>
+ updateOrCreatePicker(state, pickerId, createTree),
+ EXPAND_TREE_PICKER_NODES: ({ pickerId, ids }) =>
+ updateOrCreatePicker(state, pickerId, expandNode(...ids)),