list_editor.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. import { Map as ImmutableMap, List as ImmutableList } from 'immutable';
  2. import {
  3. LIST_CREATE_REQUEST,
  4. LIST_CREATE_FAIL,
  5. LIST_CREATE_SUCCESS,
  6. LIST_UPDATE_REQUEST,
  7. LIST_UPDATE_FAIL,
  8. LIST_UPDATE_SUCCESS,
  9. LIST_EDITOR_RESET,
  10. LIST_EDITOR_SETUP,
  11. LIST_EDITOR_TITLE_CHANGE,
  12. LIST_ACCOUNTS_FETCH_REQUEST,
  13. LIST_ACCOUNTS_FETCH_SUCCESS,
  14. LIST_ACCOUNTS_FETCH_FAIL,
  15. LIST_EDITOR_SUGGESTIONS_READY,
  16. LIST_EDITOR_SUGGESTIONS_CLEAR,
  17. LIST_EDITOR_SUGGESTIONS_CHANGE,
  18. LIST_EDITOR_ADD_SUCCESS,
  19. LIST_EDITOR_REMOVE_SUCCESS,
  20. } from '../actions/lists';
  21. const initialState = ImmutableMap({
  22. listId: null,
  23. isSubmitting: false,
  24. isChanged: false,
  25. title: '',
  26. isExclusive: false,
  27. accounts: ImmutableMap({
  28. items: ImmutableList(),
  29. loaded: false,
  30. isLoading: false,
  31. }),
  32. suggestions: ImmutableMap({
  33. value: '',
  34. items: ImmutableList(),
  35. }),
  36. });
  37. export default function listEditorReducer(state = initialState, action) {
  38. switch(action.type) {
  39. case LIST_EDITOR_RESET:
  40. return initialState;
  41. case LIST_EDITOR_SETUP:
  42. return state.withMutations(map => {
  43. map.set('listId', action.list.get('id'));
  44. map.set('title', action.list.get('title'));
  45. map.set('isExclusive', action.list.get('is_exclusive'));
  46. map.set('isSubmitting', false);
  47. });
  48. case LIST_EDITOR_TITLE_CHANGE:
  49. return state.withMutations(map => {
  50. map.set('title', action.value);
  51. map.set('isChanged', true);
  52. });
  53. case LIST_CREATE_REQUEST:
  54. case LIST_UPDATE_REQUEST:
  55. return state.withMutations(map => {
  56. map.set('isSubmitting', true);
  57. map.set('isChanged', false);
  58. });
  59. case LIST_CREATE_FAIL:
  60. case LIST_UPDATE_FAIL:
  61. return state.set('isSubmitting', false);
  62. case LIST_CREATE_SUCCESS:
  63. case LIST_UPDATE_SUCCESS:
  64. return state.withMutations(map => {
  65. map.set('isSubmitting', false);
  66. map.set('listId', action.list.id);
  67. });
  68. case LIST_ACCOUNTS_FETCH_REQUEST:
  69. return state.setIn(['accounts', 'isLoading'], true);
  70. case LIST_ACCOUNTS_FETCH_FAIL:
  71. return state.setIn(['accounts', 'isLoading'], false);
  72. case LIST_ACCOUNTS_FETCH_SUCCESS:
  73. return state.update('accounts', accounts => accounts.withMutations(map => {
  74. map.set('isLoading', false);
  75. map.set('loaded', true);
  76. map.set('items', ImmutableList(action.accounts.map(item => item.id)));
  77. }));
  78. case LIST_EDITOR_SUGGESTIONS_CHANGE:
  79. return state.setIn(['suggestions', 'value'], action.value);
  80. case LIST_EDITOR_SUGGESTIONS_READY:
  81. return state.setIn(['suggestions', 'items'], ImmutableList(action.accounts.map(item => item.id)));
  82. case LIST_EDITOR_SUGGESTIONS_CLEAR:
  83. return state.update('suggestions', suggestions => suggestions.withMutations(map => {
  84. map.set('items', ImmutableList());
  85. map.set('value', '');
  86. }));
  87. case LIST_EDITOR_ADD_SUCCESS:
  88. return state.updateIn(['accounts', 'items'], list => list.unshift(action.accountId));
  89. case LIST_EDITOR_REMOVE_SUCCESS:
  90. return state.updateIn(['accounts', 'items'], list => list.filterNot(item => item === action.accountId));
  91. default:
  92. return state;
  93. }
  94. }