闭社主体 forked from https://github.com/tootsuite/mastodon
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

93 lines
2.3 KiB

  1. import { SETTING_CHANGE } from '../actions/settings';
  2. import { COLUMN_ADD, COLUMN_REMOVE, COLUMN_MOVE } from '../actions/columns';
  3. import { STORE_HYDRATE } from '../actions/store';
  4. import { Map as ImmutableMap, fromJS } from 'immutable';
  5. import uuid from '../uuid';
  6. const initialState = ImmutableMap({
  7. onboarded: false,
  8. home: ImmutableMap({
  9. shows: ImmutableMap({
  10. reblog: true,
  11. reply: true,
  12. }),
  13. regex: ImmutableMap({
  14. body: '',
  15. }),
  16. }),
  17. notifications: ImmutableMap({
  18. alerts: ImmutableMap({
  19. follow: true,
  20. favourite: true,
  21. reblog: true,
  22. mention: true,
  23. }),
  24. shows: ImmutableMap({
  25. follow: true,
  26. favourite: true,
  27. reblog: true,
  28. mention: true,
  29. }),
  30. sounds: ImmutableMap({
  31. follow: true,
  32. favourite: true,
  33. reblog: true,
  34. mention: true,
  35. }),
  36. }),
  37. community: ImmutableMap({
  38. regex: ImmutableMap({
  39. body: '',
  40. }),
  41. }),
  42. public: ImmutableMap({
  43. regex: ImmutableMap({
  44. body: '',
  45. }),
  46. }),
  47. });
  48. const defaultColumns = fromJS([
  49. { id: 'COMPOSE', uuid: uuid(), params: {} },
  50. { id: 'HOME', uuid: uuid(), params: {} },
  51. { id: 'NOTIFICATIONS', uuid: uuid(), params: {} },
  52. ]);
  53. const hydrate = (state, settings) => state.mergeDeep(settings).update('columns', (val = defaultColumns) => val);
  54. const moveColumn = (state, uuid, direction) => {
  55. const columns = state.get('columns');
  56. const index = columns.findIndex(item => item.get('uuid') === uuid);
  57. const newIndex = index + direction;
  58. let newColumns;
  59. newColumns = columns.splice(index, 1);
  60. newColumns = newColumns.splice(newIndex, 0, columns.get(index));
  61. return state.set('columns', newColumns);
  62. };
  63. export default function settings(state = initialState, action) {
  64. switch(action.type) {
  65. case STORE_HYDRATE:
  66. return hydrate(state, action.state.get('settings'));
  67. case SETTING_CHANGE:
  68. return state.setIn(action.key, action.value);
  69. case COLUMN_ADD:
  70. return state.update('columns', list => list.push(fromJS({ id: action.id, uuid: uuid(), params: action.params })));
  71. case COLUMN_REMOVE:
  72. return state.update('columns', list => list.filterNot(item => item.get('uuid') === action.uuid));
  73. case COLUMN_MOVE:
  74. return moveColumn(state, action.uuid, action.direction);
  75. default:
  76. return state;
  77. }
  78. };