[ABANDONED] React/Redux front end for the Flexor social network.
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.

104 lines
3.0 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. // forms.ts
  2. // Copyright (C) 2020 Dwayne Harris
  3. // This program is free software: you can redistribute it and/or modify
  4. // it under the terms of the GNU General Public License as published by
  5. // the Free Software Foundation, either version 3 of the License, or
  6. // (at your option) any later version.
  7. // This program is distributed in the hope that it will be useful,
  8. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. // GNU General Public License for more details.
  11. // You should have received a copy of the GNU General Public License
  12. // along with this program. If not, see <https://www.gnu.org/licenses/>.
  13. import { Reducer } from 'redux'
  14. import { FormsActions } from '../actions/forms'
  15. import { FormsState } from '../types'
  16. const initialState: FormsState = {
  17. form: {},
  18. notification: undefined,
  19. }
  20. const reducer: Reducer<FormsState, FormsActions> = (state = initialState, action) => {
  21. switch (action.type) {
  22. case 'FORMS_INIT':
  23. return {
  24. form: {},
  25. notification: undefined,
  26. }
  27. case 'FORMS_INIT_FIELD':
  28. const { name, value, apiName } = action.payload
  29. return {
  30. ...state,
  31. form: {
  32. ...state.form,
  33. [name]: {
  34. name,
  35. value,
  36. apiName,
  37. },
  38. },
  39. }
  40. case 'FORMS_SET_FIELD_VALUE': {
  41. const field = state.form[action.payload.name]
  42. return {
  43. ...state,
  44. form: {
  45. ...state.form,
  46. [action.payload.name]: {
  47. ...field,
  48. value: action.payload.value,
  49. notification: undefined,
  50. },
  51. },
  52. }
  53. }
  54. case 'FORMS_SET_FORM_NOTIFICATION':
  55. const { type, message } = action.payload
  56. return {
  57. ...state,
  58. notification: {
  59. type,
  60. message,
  61. },
  62. }
  63. case 'FORMS_SET_FIELD_NOTIFICATION': {
  64. const { name, type, message } = action.payload
  65. const getField = () => {
  66. const field = Object.entries(state.form).find(([_, value]) => value.apiName ? name === value.apiName : false)
  67. if (field) return field[1]
  68. return state.form[name]
  69. }
  70. const field = getField()
  71. return {
  72. ...state,
  73. form: {
  74. ...state.form,
  75. [field.name]: {
  76. ...field,
  77. notification: {
  78. type,
  79. message,
  80. },
  81. },
  82. },
  83. }
  84. }
  85. default:
  86. return state
  87. }
  88. }
  89. export default reducer