[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.

96 lines
2.5 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
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 { Action } from 'redux'
  14. import { NotificationType, FormValue } from '../types'
  15. export interface InitFormAction extends Action {
  16. type: 'FORMS_INIT'
  17. }
  18. export interface InitFieldAction extends Action {
  19. type: 'FORMS_INIT_FIELD'
  20. payload: {
  21. name: string
  22. value: FormValue
  23. apiName?: string
  24. }
  25. }
  26. export interface SetFieldValueAction extends Action {
  27. type: 'FORMS_SET_FIELD_VALUE'
  28. payload: {
  29. name: string
  30. value: FormValue
  31. }
  32. }
  33. export interface SetFormNotificationAction extends Action {
  34. type: 'FORMS_SET_FORM_NOTIFICATION'
  35. payload: {
  36. type: NotificationType
  37. message: string
  38. }
  39. }
  40. export interface SetFieldNotificationAction extends Action {
  41. type: 'FORMS_SET_FIELD_NOTIFICATION'
  42. payload: {
  43. name: string
  44. type: NotificationType
  45. message: string
  46. }
  47. }
  48. export type FormsActions = InitFormAction | InitFieldAction | SetFieldValueAction | SetFormNotificationAction | SetFieldNotificationAction
  49. export const initForm = (): InitFormAction => ({
  50. type: 'FORMS_INIT',
  51. })
  52. export const initField = (name: string, value: FormValue, apiName?: string): InitFieldAction => ({
  53. type: 'FORMS_INIT_FIELD',
  54. payload: {
  55. name,
  56. value,
  57. apiName,
  58. },
  59. })
  60. export const setFieldValue = (name: string, value: FormValue): SetFieldValueAction => ({
  61. type: 'FORMS_SET_FIELD_VALUE',
  62. payload: {
  63. name,
  64. value,
  65. },
  66. })
  67. export const setFormNotification = (type: NotificationType, message: string): SetFormNotificationAction => ({
  68. type: 'FORMS_SET_FORM_NOTIFICATION',
  69. payload: {
  70. type,
  71. message,
  72. }
  73. })
  74. export const setFieldNotification = (name: string, type: NotificationType, message: string): SetFieldNotificationAction => ({
  75. type: 'FORMS_SET_FIELD_NOTIFICATION',
  76. payload: {
  77. name,
  78. type,
  79. message,
  80. }
  81. })