* chore: rename APIs and Microservices to include "Backend" (#42515) * fix typo * fix typo * undo change * Corrected grammar mistake Corrected a grammar mistake by removing a comma. * change APIs and Microservices cert title * update title * Change APIs and Microservices certi title * Update translations.json * update title * feat(curriculum): rename apis and microservices cert * rename folder structure * rename certificate * rename learn Markdown * apis-and-microservices -> back-end-development-and-apis * update backend meta * update i18n langs and cypress test Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * fix: add development to front-end libraries (#42512) * fix: added-the-word-Development-to-front-end-libraries * fix/added-the-word-Development-to-front-end-libraries * fix/added-word-development-to-front-end-libraries-in-other-related-files * fix/added-the-word-Development-to-front-end-and-all-related-files * fix/removed-typos-from-last-commit-in-index.md * fix/reverted-changes-that-i-made-to-dependecies * fix/removed xvfg * fix/reverted changes that i made to package.json * remove unwanted changes * front-end-development-libraries changes * rename backend certSlug and README * update i18n folder names and keys * test: add legacy path redirect tests This uses serve.json from the client-config repo, since we currently use that in production * fix: create public dir before moving serve.json * fix: add missing script * refactor: collect redirect tests * test: convert to cy.location for stricter tests * rename certificate folder to 00-certificates * change crowdin config to recognise new certificates location * allow translations to be used Co-authored-by: Nicholas Carrigan (he/him) <nhcarrigan@gmail.com> * add forwards slashes to path redirects * fix cypress path tests again * plese cypress * fix: test different challenge Okay so I literally have no idea why this one particular challenge fails in Cypress Firefox ONLY. Tom and I paired and spun a full build instance and confirmed in Firefox the page loads and redirects as expected. Changing to another bootstrap challenge passes Cypress firefox locally. Absolutely boggled by this. AAAAAAAAAAAAAAA * fix: separate the test Okay apparently the test does not work unless we separate it into a different `it` statement. >:( >:( >:( >:( Co-authored-by: Sujal Gupta <55016909+heysujal@users.noreply.github.com> Co-authored-by: Noor Fakhry <65724923+NoorFakhry@users.noreply.github.com> Co-authored-by: Oliver Eyton-Williams <ojeytonwilliams@gmail.com> Co-authored-by: Nicholas Carrigan (he/him) <nhcarrigan@gmail.com>
		
			
				
	
	
		
			108 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 5a24c314108439a4d4036146
 | |
| title: Mappare la spedizione delle props
 | |
| challengeType: 6
 | |
| forumTopicId: 301432
 | |
| dashedName: map-dispatch-to-props
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| La funzione `mapDispatchToProps()` viene utilizzata per fornire specifici creatori di azioni ai componenti React in modo che possano inviare azioni allo store di Redux. La struttura è simile alla funzione `mapStateToProps()` che hai scritto nell'ultima sfida. Essa restituisce un oggetto che mappa azioni di invio a nomi di proprietà, che diventano `props` del componente. Tuttavia, invece di restituire una parte dello `state`, ogni proprietà restituisce una funzione che chiama `dispatch` con un creatore di azione e tutti i dati rilevanti per l'azione. Hai accesso a questa `dispatch` perché è passata a `mapDispatchToProps()` come parametro quando definisci la funzione, proprio come hai passato `state` a `mapStateToProps()`. Dietro le quinte, React Redux sta usando `store.dispatch()` di Redux per eseguire queste spedizioni con `mapDispatchToProps()`. Questo è simile a come usa `store.subscribe()` per i componenti che sono mappati allo `state`.
 | |
| 
 | |
| Ad esempio, hai un creatore di azione `loginUser()` che richiede uno `username` come payload dell'azione. L'oggetto restituito da `mapDispatchToProps()` per questo creatore di azione sarà di questo tipo:
 | |
| 
 | |
| ```jsx
 | |
| {
 | |
|   submitLoginUser: function(username) {
 | |
|     dispatch(loginUser(username));
 | |
|   }
 | |
| }
 | |
| ```
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| L'editor di codice fornisce un creatore di azioni chiamato `addMessage()`. Scrivi la funzione `mapDispatchToProps()` che richiede `dispatch` come argomento, quindi restituisce un oggetto. L'oggetto dovrebbe avere una proprietà `submitNewMessage` impostata alla funzione dispatch, che prende un parametro per il nuovo messaggio quando effettua il dispatch di `addMessage()`.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| `addMessage` dovrebbe restituire un oggetto con chiavi `type` e `message`.
 | |
| 
 | |
| ```js
 | |
| assert(
 | |
|   (function () {
 | |
|     const addMessageTest = addMessage();
 | |
|     return (
 | |
|       addMessageTest.hasOwnProperty('type') &&
 | |
|       addMessageTest.hasOwnProperty('message')
 | |
|     );
 | |
|   })()
 | |
| );
 | |
| ```
 | |
| 
 | |
| `mapDispatchToProps` dovrebbe essere una funzione.
 | |
| 
 | |
| ```js
 | |
| assert(typeof mapDispatchToProps === 'function');
 | |
| ```
 | |
| 
 | |
| `mapDispatchToProps` dovrebbe restituire un oggetto.
 | |
| 
 | |
| ```js
 | |
| assert(typeof mapDispatchToProps() === 'object');
 | |
| ```
 | |
| 
 | |
| Spedire `addMessage` con `submitNewMessage` da `mapDispatchToProps` dovrebbe restituire un messaggio alla funzione dispatch.
 | |
| 
 | |
| ```js
 | |
| assert(
 | |
|   (function () {
 | |
|     let testAction;
 | |
|     const dispatch = (fn) => {
 | |
|       testAction = fn;
 | |
|     };
 | |
|     let dispatchFn = mapDispatchToProps(dispatch);
 | |
|     dispatchFn.submitNewMessage('__TEST__MESSAGE__');
 | |
|     return (
 | |
|       testAction.type === 'ADD' && testAction.message === '__TEST__MESSAGE__'
 | |
|     );
 | |
|   })()
 | |
| );
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```jsx
 | |
| const addMessage = (message) => {
 | |
|   return {
 | |
|     type: 'ADD',
 | |
|     message: message
 | |
|   }
 | |
| };
 | |
| 
 | |
| // Change code below this line
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```jsx
 | |
| const addMessage = (message) => {
 | |
|   return {
 | |
|     type: 'ADD',
 | |
|     message: message
 | |
|   }
 | |
| };
 | |
| 
 | |
| // Change code below this line
 | |
| 
 | |
| const mapDispatchToProps = (dispatch) => {
 | |
|   return {
 | |
|     submitNewMessage: function(message) {
 | |
|       dispatch(addMessage(message));
 | |
|     }
 | |
|   }
 | |
| };
 | |
| ```
 |