mirror of
				https://github.com/strapi/strapi.git
				synced 2025-10-26 07:30:17 +00:00 
			
		
		
		
	Remove immutable in webhooks page
Signed-off-by: soupette <cyril.lpz@gmail.com>
This commit is contained in:
		
							parent
							
								
									c3f5509de7
								
							
						
					
					
						commit
						a58f59ab8f
					
				| @ -33,7 +33,10 @@ function EditView() { | |||||||
|   const { formatMessage } = useGlobalContext(); |   const { formatMessage } = useGlobalContext(); | ||||||
|   const [submittedOnce, setSubmittedOnce] = useState(false); |   const [submittedOnce, setSubmittedOnce] = useState(false); | ||||||
|   const [isSubmitting, setIsSubmitting] = useState(false); |   const [isSubmitting, setIsSubmitting] = useState(false); | ||||||
|   const [reducerState, dispatch] = useReducer(reducer, initialState); |   const [ | ||||||
|  |     { formErrors, modifiedData, initialData, isLoading, isTriggering, triggerResponse }, | ||||||
|  |     dispatch, | ||||||
|  |   ] = useReducer(reducer, initialState); | ||||||
|   const { push, replace } = useHistory(); |   const { push, replace } = useHistory(); | ||||||
|   const { |   const { | ||||||
|     params: { id }, |     params: { id }, | ||||||
| @ -43,14 +46,14 @@ function EditView() { | |||||||
|   const { signal } = abortController; |   const { signal } = abortController; | ||||||
|   const isCreating = id === 'create'; |   const isCreating = id === 'create'; | ||||||
| 
 | 
 | ||||||
|   const { |   // const {
 | ||||||
|     formErrors, |   //   formErrors,
 | ||||||
|     modifiedData, |   //   modifiedData,
 | ||||||
|     initialData, |   //   initialData,
 | ||||||
|     isLoading, |   //   isLoading,
 | ||||||
|     isTriggering, |   //   isTriggering,
 | ||||||
|     triggerResponse, |   //   triggerResponse,
 | ||||||
|   } = reducerState.toJS(); |   // } = reducerState.toJS();
 | ||||||
| 
 | 
 | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     isMounted.current = true; |     isMounted.current = true; | ||||||
| @ -195,6 +198,7 @@ function EditView() { | |||||||
|     try { |     try { | ||||||
|       lockApp(); |       lockApp(); | ||||||
|       setIsSubmitting(true); |       setIsSubmitting(true); | ||||||
|  |       console.log(cleanData(modifiedData), modifiedData); | ||||||
|       const { data } = await request('/admin/webhooks', { |       const { data } = await request('/admin/webhooks', { | ||||||
|         method: 'POST', |         method: 'POST', | ||||||
|         body: cleanData(modifiedData), |         body: cleanData(modifiedData), | ||||||
|  | |||||||
| @ -1,5 +1,6 @@ | |||||||
| import { fromJS } from 'immutable'; | import produce from 'immer'; | ||||||
| import { get } from 'lodash'; | import get from 'lodash/get'; | ||||||
|  | import set from 'lodash/set'; | ||||||
| 
 | 
 | ||||||
| const header = { key: '', value: '' }; | const header = { key: '', value: '' }; | ||||||
| 
 | 
 | ||||||
| @ -10,67 +11,90 @@ const initialWebhook = { | |||||||
|   url: '', |   url: '', | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const initialState = fromJS({ | const initialState = { | ||||||
|   formErrors: {}, |   formErrors: {}, | ||||||
|   initialData: initialWebhook, |   initialData: initialWebhook, | ||||||
|   isTriggering: false, |   isTriggering: false, | ||||||
|   modifiedData: initialWebhook, |   modifiedData: initialWebhook, | ||||||
|   isLoading: true, |   isLoading: true, | ||||||
|   triggerResponse: {}, |   triggerResponse: {}, | ||||||
| }); | }; | ||||||
| 
 | 
 | ||||||
| const reducer = (state, action) => { | const reducer = (state, action) => | ||||||
|   switch (action.type) { |   // eslint-disable-next-line consistent-return
 | ||||||
|     case 'ADD_NEW_HEADER': |   produce(state, draftState => { | ||||||
|       return state.updateIn(['modifiedData', ...action.keys], arr => arr.push(fromJS(header))); |     switch (action.type) { | ||||||
|     case 'GET_DATA_SUCCEEDED': { |       case 'ADD_NEW_HEADER': { | ||||||
|       const headers = get(action, ['data', 'headers'], {}); |         draftState.modifiedData.headers.push(header); | ||||||
|       let formattedHeaders = [header]; |         break; | ||||||
| 
 |  | ||||||
|       if (Object.keys(headers).length > 0) { |  | ||||||
|         formattedHeaders = Object.keys(headers).map(key => { |  | ||||||
|           return { key, value: headers[key] }; |  | ||||||
|         }); |  | ||||||
|       } |       } | ||||||
|  |       case 'GET_DATA_SUCCEEDED': { | ||||||
|  |         const headers = get(action, ['data', 'headers'], {}); | ||||||
|  |         let formattedHeaders = [header]; | ||||||
| 
 | 
 | ||||||
|       const data = fromJS(action.data).update('headers', () => fromJS(formattedHeaders)); |         if (Object.keys(headers).length > 0) { | ||||||
| 
 |           formattedHeaders = Object.keys(headers).map(key => { | ||||||
|       return state |             return { key, value: headers[key] }; | ||||||
|         .update('isLoading', () => false) |           }); | ||||||
|         .update('initialData', () => data) |  | ||||||
|         .update('modifiedData', () => data); |  | ||||||
|     } |  | ||||||
|     case 'ON_CHANGE': |  | ||||||
|       return state.updateIn(['modifiedData', ...action.keys], () => action.value); |  | ||||||
|     case 'ON_HEADER_REMOVE': { |  | ||||||
|       return state.updateIn(['modifiedData', 'headers'], headers => { |  | ||||||
|         if (headers.size === 1) { |  | ||||||
|           return fromJS([header]); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return headers.remove(action.index); |         const data = { ...action.data, headers: formattedHeaders }; | ||||||
|       }); | 
 | ||||||
|  |         draftState.isLoading = false; | ||||||
|  |         draftState.initialData = data; | ||||||
|  |         draftState.modifiedData = data; | ||||||
|  | 
 | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'ON_CHANGE': { | ||||||
|  |         set(draftState, ['modifiedData', ...action.keys], action.value); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'ON_HEADER_REMOVE': { | ||||||
|  |         const nextHeaders = state.modifiedData.headers.filter((_, index) => index !== action.index); | ||||||
|  | 
 | ||||||
|  |         if (!nextHeaders.length) { | ||||||
|  |           nextHeaders.push(header); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         draftState.modifiedData.headers = nextHeaders; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'ON_TRIGGER_CANCELED': { | ||||||
|  |         draftState.isTriggering = false; | ||||||
|  |         draftState.triggerResponse = {}; | ||||||
|  | 
 | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'RESET_FORM': { | ||||||
|  |         draftState.modifiedData = state.initialData; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'SET_ERRORS': { | ||||||
|  |         draftState.formErrors = action.errors; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'SET_IS_TRIGGERING': { | ||||||
|  |         draftState.isTriggering = !state.isTriggering; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'SUBMIT_SUCCEEDED': { | ||||||
|  |         draftState.initialData = state.modifiedData; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'TRIGGER_SUCCEEDED': { | ||||||
|  |         draftState.triggerResponse = action.response; | ||||||
|  |         draftState.isTriggering = false; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'UNSET_LOADER': { | ||||||
|  |         draftState.isLoading = false; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       default: | ||||||
|  |         return draftState; | ||||||
|     } |     } | ||||||
|     case 'ON_TRIGGER_CANCELED': |   }); | ||||||
|       return state.update('isTriggering', () => false).set('triggerResponse', fromJS({})); |  | ||||||
|     case 'RESET_FORM': |  | ||||||
|       return state.update('modifiedData', () => state.get('initialData')); |  | ||||||
|     case 'SET_ERRORS': |  | ||||||
|       return state.update('formErrors', () => fromJS(action.errors)); |  | ||||||
|     case 'SET_IS_TRIGGERING': |  | ||||||
|       return state.update('isTriggering', isTriggering => !isTriggering); |  | ||||||
|     case 'SUBMIT_SUCCEEDED': |  | ||||||
|       return state.update('initialData', () => state.get('modifiedData')); |  | ||||||
|     case 'TRIGGER_SUCCEEDED': |  | ||||||
|       return state |  | ||||||
|         .update('triggerResponse', () => fromJS(action.response)) |  | ||||||
|         .update('isTriggering', () => false); |  | ||||||
|     case 'UNSET_LOADER': |  | ||||||
|       return state.update('isLoading', () => false); |  | ||||||
|     default: |  | ||||||
|       return state; |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| 
 | 
 | ||||||
| export default reducer; | export default reducer; | ||||||
| export { initialState }; | export { initialState }; | ||||||
|  | |||||||
| @ -1,4 +1,3 @@ | |||||||
| import { fromJS } from 'immutable'; |  | ||||||
| import reducer from '../reducer'; | import reducer from '../reducer'; | ||||||
| 
 | 
 | ||||||
| describe('Admin | containers | Webhooks | EditView | reducer', () => { | describe('Admin | containers | Webhooks | EditView | reducer', () => { | ||||||
| @ -11,14 +10,14 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|     url: '', |     url: '', | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   const initialState = fromJS({ |   const initialState = { | ||||||
|     formErrors: {}, |     formErrors: {}, | ||||||
|     initialData: initialWebhook, |     initialData: initialWebhook, | ||||||
|     isTriggering: false, |     isTriggering: false, | ||||||
|     modifiedData: initialWebhook, |     modifiedData: initialWebhook, | ||||||
|     isLoading: true, |     isLoading: true, | ||||||
|     triggerResponse: {}, |     triggerResponse: {}, | ||||||
|   }); |   }; | ||||||
| 
 | 
 | ||||||
|   describe('Format headers object', () => { |   describe('Format headers object', () => { | ||||||
|     it('should convert headers object to an array of an empty object if it is empty', () => { |     it('should convert headers object to an array of an empty object if it is empty', () => { | ||||||
| @ -39,10 +38,7 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const data = { ...receivedData, headers: [header] }; |       const data = { ...receivedData, headers: [header] }; | ||||||
|       const expectedState = state |       const expectedState = { ...state, isLoading: false, initialData: data, modifiedData: data }; | ||||||
|         .set('isLoading', false) |  | ||||||
|         .set('initialData', fromJS(data)) |  | ||||||
|         .set('modifiedData', fromJS(data)); |  | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -74,10 +70,7 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
| 
 | 
 | ||||||
|       const data = { ...receivedData, headers: formattedHeaders }; |       const data = { ...receivedData, headers: formattedHeaders }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state |       const expectedState = { ...state, isLoading: false, initialData: data, modifiedData: data }; | ||||||
|         .set('isLoading', false) |  | ||||||
|         .update('initialData', () => fromJS(data)) |  | ||||||
|         .update('modifiedData', () => fromJS(data)); |  | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -93,7 +86,10 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|         value: 'new webhook name', |         value: 'new webhook name', | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.setIn(['modifiedData', ...action.keys], action.value); |       const expectedState = { | ||||||
|  |         ...state, | ||||||
|  |         modifiedData: { ...state.modifiedData, name: action.value }, | ||||||
|  |       }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -106,13 +102,16 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|         keys: ['headers'], |         keys: ['headers'], | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.setIn( |       const expectedState = { | ||||||
|         ['modifiedData', 'headers'], |         ...state, | ||||||
|         fromJS([ |         modifiedData: { | ||||||
|           { key: '', value: '' }, |           ...state.modifiedData, | ||||||
|           { key: '', value: '' }, |           headers: [ | ||||||
|         ]) |             { key: '', value: '' }, | ||||||
|       ); |             { key: '', value: '' }, | ||||||
|  |           ], | ||||||
|  |         }, | ||||||
|  |       }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -122,9 +121,16 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|         { key: 'accept', value: 'text/html' }, |         { key: 'accept', value: 'text/html' }, | ||||||
|         { key: 'authorization', value: 'Basic YWxhZGRpbjpvcGVuc2VzYW1l' }, |         { key: 'authorization', value: 'Basic YWxhZGRpbjpvcGVuc2VzYW1l' }, | ||||||
|       ]; |       ]; | ||||||
|       const state = initialState |       const state = { | ||||||
|         .setIn(['initialData', 'headers'], fromJS(initialHeaders)) |         ...initialState, | ||||||
|         .setIn(['modifiedData', 'headers'], fromJS(initialHeaders)); |         initialData: { | ||||||
|  |           headers: initialHeaders, | ||||||
|  |         }, | ||||||
|  |         modifiedData: { | ||||||
|  |           ok: true, | ||||||
|  |           headers: initialHeaders, | ||||||
|  |         }, | ||||||
|  |       }; | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'ON_HEADER_REMOVE', |         type: 'ON_HEADER_REMOVE', | ||||||
| @ -132,26 +138,25 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const updatedHeaders = [{ key: 'accept', value: 'text/html' }]; |       const updatedHeaders = [{ key: 'accept', value: 'text/html' }]; | ||||||
| 
 |       const expectedState = { | ||||||
|       const expectedState = state.setIn(['modifiedData', 'headers'], fromJS(updatedHeaders)); |         ...state, | ||||||
|  |         modifiedData: { ...state.modifiedData, headers: updatedHeaders }, | ||||||
|  |       }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     it('should clear a header to modifiedData if it is the last', () => { |     it('should clear a header to modifiedData if it is the last', () => { | ||||||
|       const initialHeaders = [{ key: 'accept', value: 'text/html' }]; |       const initialHeaders = [{ key: 'accept', value: 'text/html' }]; | ||||||
|       const state = initialState |       const initialData = { headers: initialHeaders, ok: true }; | ||||||
|         .setIn(['initialData', 'headers'], fromJS(initialHeaders)) |       const state = { ...initialState, initialData, modifiedData: initialData }; | ||||||
|         .setIn(['modifiedData', 'headers'], fromJS(initialHeaders)); |  | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'ON_HEADER_REMOVE', |         type: 'ON_HEADER_REMOVE', | ||||||
|         index: 0, |         index: 0, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const updatedHeaders = [header]; |       const expectedState = { ...state, modifiedData: { headers: [header], ok: true } }; | ||||||
| 
 |  | ||||||
|       const expectedState = state.setIn(['modifiedData', 'headers'], fromJS(updatedHeaders)); |  | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -159,28 +164,31 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
| 
 | 
 | ||||||
|   describe('Trigger actions', () => { |   describe('Trigger actions', () => { | ||||||
|     it('should set isTriggering to false when trigger action is canceled', () => { |     it('should set isTriggering to false when trigger action is canceled', () => { | ||||||
|       const state = initialState.set('isTriggering', true); |       const state = { ...initialState, isTriggering: true }; | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'ON_TRIGGER_CANCELED', |         type: 'ON_TRIGGER_CANCELED', | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.update('isTriggering', () => false); |       const expectedState = { ...state, isTriggering: false }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     it('should clear triggerResponse when trigger action is canceled', () => { |     it('should clear triggerResponse when trigger action is canceled', () => { | ||||||
|       const state = initialState.set('triggerResponse', { |       const state = { | ||||||
|         statusCode: 200, |         ...initialState, | ||||||
|         message: 'succeed', |         triggerResponse: { | ||||||
|       }); |           statusCode: 200, | ||||||
|  |           message: 'succeed', | ||||||
|  |         }, | ||||||
|  |       }; | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'ON_TRIGGER_CANCELED', |         type: 'ON_TRIGGER_CANCELED', | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.update('triggerResponse', () => fromJS({})); |       const expectedState = { ...state, triggerResponse: {} }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -192,13 +200,13 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|         type: 'SET_IS_TRIGGERING', |         type: 'SET_IS_TRIGGERING', | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.set('isTriggering', true); |       const expectedState = { ...state, isTriggering: true }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     it('should update isTriggering and triggerResponse if trigger succeed', () => { |     it('should update isTriggering and triggerResponse if trigger succeed', () => { | ||||||
|       const state = initialState.set('isTriggering', true); |       const state = { ...initialState, isTriggering: true }; | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'TRIGGER_SUCCEEDED', |         type: 'TRIGGER_SUCCEEDED', | ||||||
| @ -208,9 +216,7 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|         }, |         }, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state |       const expectedState = { ...state, triggerResponse: action.response, isTriggering: false }; | ||||||
|         .update('triggerResponse', () => fromJS(action.response)) |  | ||||||
|         .update('isTriggering', () => false); |  | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -218,15 +224,13 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
| 
 | 
 | ||||||
|   describe('Reset form', () => { |   describe('Reset form', () => { | ||||||
|     it('should reset modifiedData with initialData values', () => { |     it('should reset modifiedData with initialData values', () => { | ||||||
|       const state = initialState |       const state = { ...initialState, modifiedData: { name: 'updated name', url: 'updated url' } }; | ||||||
|         .setIn(['modifiedData', 'name'], 'updated name') |  | ||||||
|         .setIn(['modifiedData', 'url'], 'updated url'); |  | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'RESET_FORM', |         type: 'RESET_FORM', | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.update('modifiedData', () => state.get('initialData')); |       const expectedState = initialState; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -243,7 +247,7 @@ describe('Admin | containers | Webhooks | EditView | reducer', () => { | |||||||
|         }, |         }, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.update('formErrors', () => fromJS(action.errors)); |       const expectedState = { ...state, formErrors: action.errors }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| import { set } from 'lodash'; | import { set } from 'lodash'; | ||||||
| 
 | 
 | ||||||
| const cleanData = data => { | const cleanData = data => { | ||||||
|   const webhooks = data; |   const webhooks = { ...data }; | ||||||
| 
 | 
 | ||||||
|   set(webhooks, 'headers', unformatHeaders(data.headers)); |   set(webhooks, 'headers', unformatHeaders(data.headers)); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -35,12 +35,13 @@ function ListView() { | |||||||
|   const isMounted = useRef(true); |   const isMounted = useRef(true); | ||||||
|   const { formatMessage } = useIntl(); |   const { formatMessage } = useIntl(); | ||||||
|   const [showModal, setShowModal] = useState(false); |   const [showModal, setShowModal] = useState(false); | ||||||
|   const [reducerState, dispatch] = useReducer(reducer, initialState); |   const [{ webhooks, webhooksToDelete, webhookToDelete }, dispatch] = useReducer( | ||||||
|  |     reducer, | ||||||
|  |     initialState | ||||||
|  |   ); | ||||||
|   const { push } = useHistory(); |   const { push } = useHistory(); | ||||||
|   const { pathname } = useLocation(); |   const { pathname } = useLocation(); | ||||||
| 
 | 
 | ||||||
|   const { webhooks, webhooksToDelete, webhookToDelete } = reducerState.toJS(); |  | ||||||
| 
 |  | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     isMounted.current = true; |     isMounted.current = true; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,43 +1,56 @@ | |||||||
| import { fromJS } from 'immutable'; | import produce from 'immer'; | ||||||
|  | import set from 'lodash/set'; | ||||||
| 
 | 
 | ||||||
| const initialState = fromJS({ | const initialState = { | ||||||
|   webhooks: [], |   webhooks: [], | ||||||
|   webhooksToDelete: [], |   webhooksToDelete: [], | ||||||
|   webhookToDelete: null, |   webhookToDelete: null, | ||||||
| }); | }; | ||||||
| 
 | 
 | ||||||
| const reducer = (state, action) => { | const reducer = (state, action) => | ||||||
|   switch (action.type) { |   // eslint-disable-next-line consistent-return
 | ||||||
|     case 'GET_DATA_SUCCEEDED': |   produce(state, draftState => { | ||||||
|       return state.update('webhooks', () => fromJS(action.data)); |     switch (action.type) { | ||||||
|     case 'SET_WEBHOOK_ENABLED': |       case 'GET_DATA_SUCCEEDED': { | ||||||
|       return state.updateIn(['webhooks', ...action.keys], () => action.value); |         draftState.webhooks = action.data; | ||||||
|     case 'SET_WEBHOOK_TO_DELETE': |         break; | ||||||
|       return state.update('webhookToDelete', () => action.id); |       } | ||||||
|     case 'SET_WEBHOOKS_TO_DELETE': | 
 | ||||||
|       return state.update('webhooksToDelete', list => { |       case 'SET_WEBHOOK_ENABLED': { | ||||||
|  |         set(draftState, ['webhooks', ...action.keys], action.value); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       case 'SET_WEBHOOK_TO_DELETE': { | ||||||
|  |         draftState.webhookToDelete = action.id; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case 'SET_WEBHOOKS_TO_DELETE': { | ||||||
|         if (action.value) { |         if (action.value) { | ||||||
|           return list.push(action.id); |           draftState.webhooksToDelete.push(action.id); | ||||||
|  |         } else { | ||||||
|  |           draftState.webhooksToDelete = state.webhooksToDelete.filter(id => id !== action.id); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return list.filter(data => data !== action.id); |         break; | ||||||
|       }); |       } | ||||||
|     case 'WEBHOOKS_DELETED': |       case 'WEBHOOKS_DELETED': { | ||||||
|       return state |         draftState.webhooks = state.webhooks.filter( | ||||||
|         .update('webhooks', webhooks => |           webhook => !state.webhooksToDelete.includes(webhook.id) | ||||||
|           webhooks.filter(webhook => { |         ); | ||||||
|             return !state.get('webhooksToDelete').includes(webhook.get('id')); |         draftState.webhooksToDelete = []; | ||||||
|           }) |         break; | ||||||
|         ) |       } | ||||||
|         .update('webhooksToDelete', () => []); |       case 'WEBHOOK_DELETED': { | ||||||
|     case 'WEBHOOK_DELETED': |         draftState.webhooks = state.webhooks.filter((_, index) => index !== action.index); | ||||||
|       return state |         draftState.webhookToDelete = null; | ||||||
|         .update('webhooks', webhooks => webhooks.remove(action.index)) | 
 | ||||||
|         .update('webhookToDelete', () => null); |         break; | ||||||
|     default: |       } | ||||||
|       return state; |       default: | ||||||
|   } |         return draftState; | ||||||
| }; |     } | ||||||
|  |   }); | ||||||
| 
 | 
 | ||||||
| export default reducer; | export default reducer; | ||||||
| export { initialState }; | export { initialState }; | ||||||
|  | |||||||
| @ -1,12 +1,11 @@ | |||||||
| import { fromJS } from 'immutable'; |  | ||||||
| import reducer from '../reducer'; | import reducer from '../reducer'; | ||||||
| 
 | 
 | ||||||
| describe('Admin | containers | Webhooks | ListView | reducer', () => { | describe('Admin | containers | Webhooks | ListView | reducer', () => { | ||||||
|   const initialState = fromJS({ |   const initialState = { | ||||||
|     webhooks: [], |     webhooks: [], | ||||||
|     webhooksToDelete: [], |     webhooksToDelete: [], | ||||||
|     webhookToDelete: null, |     webhookToDelete: null, | ||||||
|   }); |   }; | ||||||
| 
 | 
 | ||||||
|   describe('Load webhooks', () => { |   describe('Load webhooks', () => { | ||||||
|     it('should update webhooks with received data', () => { |     it('should update webhooks with received data', () => { | ||||||
| @ -35,7 +34,7 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
|         data: receivedData, |         data: receivedData, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.set('webhooks', fromJS(receivedData)); |       const expectedState = { ...state, webhooks: receivedData }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -61,15 +60,35 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
|           isEnabled: false, |           isEnabled: false, | ||||||
|         }, |         }, | ||||||
|       ]; |       ]; | ||||||
|       const state = initialState.set('webhooks', fromJS(webhooks)); |       const state = { ...initialState, webhooks }; | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'SET_WEBHOOK_ENABLED', |         type: 'SET_WEBHOOK_ENABLED', | ||||||
|         keys: [1, 'isEnabled'], |         keys: [1, 'isEnabled'], | ||||||
|         value: false, |         value: true, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.setIn(['webhooks', 1, 'isEnabled'], false); |       const expectedState = { | ||||||
|  |         ...state, | ||||||
|  |         webhooks: [ | ||||||
|  |           { | ||||||
|  |             id: 1, | ||||||
|  |             name: 'webhook 1', | ||||||
|  |             url: 'http://localhost:5000', | ||||||
|  |             headers: {}, | ||||||
|  |             events: ['entry.create', 'entry.update', 'entry.delete'], | ||||||
|  |             isEnabled: true, | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             id: 2, | ||||||
|  |             name: 'webhook 2', | ||||||
|  |             url: 'http://localhost:4000', | ||||||
|  |             headers: {}, | ||||||
|  |             events: ['media.create', 'media.update'], | ||||||
|  |             isEnabled: true, | ||||||
|  |           }, | ||||||
|  |         ], | ||||||
|  |       }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -95,13 +114,13 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
|           isEnabled: false, |           isEnabled: false, | ||||||
|         }, |         }, | ||||||
|       ]; |       ]; | ||||||
|       const state = initialState.set('webhooks', fromJS(webhooks)); |       const state = { ...initialState, webhooks }; | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'SET_WEBHOOK_TO_DELETE', |         type: 'SET_WEBHOOK_TO_DELETE', | ||||||
|         id: 1, |         id: 1, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.set('webhookToDelete', 1); |       const expectedState = { ...state, webhookToDelete: 1 }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -125,14 +144,14 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
|           isEnabled: false, |           isEnabled: false, | ||||||
|         }, |         }, | ||||||
|       ]; |       ]; | ||||||
|       const state = initialState.set('webhooks', fromJS(webhooks)); |       const state = { ...initialState, webhooks }; | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'SET_WEBHOOKS_TO_DELETE', |         type: 'SET_WEBHOOKS_TO_DELETE', | ||||||
|         id: 1, |         id: 1, | ||||||
|         value: true, |         value: true, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.set('webhooksToDelete', fromJS([1])); |       const expectedState = { ...state, webhooksToDelete: [1] }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -156,16 +175,15 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
|           isEnabled: false, |           isEnabled: false, | ||||||
|         }, |         }, | ||||||
|       ]; |       ]; | ||||||
|       const state = initialState |       const state = { ...initialState, webhooks, webhooksToDelete: [1, 2] }; | ||||||
|         .set('webhooks', fromJS(webhooks)) | 
 | ||||||
|         .set('webhooksToDelete', fromJS([1, 2])); |  | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'SET_WEBHOOKS_TO_DELETE', |         type: 'SET_WEBHOOKS_TO_DELETE', | ||||||
|         id: 1, |         id: 1, | ||||||
|         value: false, |         value: false, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state.set('webhooksToDelete', fromJS([2])); |       const expectedState = { ...state, webhooksToDelete: [2] }; | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -200,14 +218,12 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
|         }, |         }, | ||||||
|       ]; |       ]; | ||||||
| 
 | 
 | ||||||
|       const state = initialState.set('webhooksToDelete', [1]).set('webhooks', fromJS(webhooks)); |       const state = { ...initialState, webhooksToDelete: [1], webhooks }; | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'WEBHOOKS_DELETED', |         type: 'WEBHOOKS_DELETED', | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state |       const expectedState = { ...state, webhooks: updatedWebhooks, webhooksToDelete: [] }; | ||||||
|         .set('webhooks', fromJS(updatedWebhooks)) |  | ||||||
|         .set('webhooksToDelete', []); |  | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
| @ -260,18 +276,14 @@ describe('Admin | containers | Webhooks | ListView | reducer', () => { | |||||||
| 
 | 
 | ||||||
|       const webhookIdToDelete = 4; |       const webhookIdToDelete = 4; | ||||||
| 
 | 
 | ||||||
|       const state = initialState |       const state = { ...initialState, webhookToDelete: webhookIdToDelete, webhooks }; | ||||||
|         .set('webhookToDelete', webhookIdToDelete) |  | ||||||
|         .set('webhooks', fromJS(webhooks)); |  | ||||||
| 
 | 
 | ||||||
|       const action = { |       const action = { | ||||||
|         type: 'WEBHOOK_DELETED', |         type: 'WEBHOOK_DELETED', | ||||||
|         index: 1, |         index: 1, | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       const expectedState = state |       const expectedState = { ...state, webhooks: updatedWebhooks, webhookToDelete: null }; | ||||||
|         .set('webhooks', fromJS(updatedWebhooks)) |  | ||||||
|         .set('webhookToDelete', null); |  | ||||||
| 
 | 
 | ||||||
|       expect(reducer(state, action)).toEqual(expectedState); |       expect(reducer(state, action)).toEqual(expectedState); | ||||||
|     }); |     }); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 soupette
						soupette