This course is no longer maintained and may be out-of-date. While it remains available for reference, its content may not reflect the latest updates, best practices, or supported features.
Variables de consulta
¿En qué consiste una variable en el contexto GraphQL?
GraphQL tiene una manera genial de factorizar los valores dinámicos fuera de la consulta, y de pasarlos como diccionarios independientes. Estos valores se denominan variables. En nuestro caso, vamos a definir el objeto que va a insertarse como mutación.
Vamos entonces a definir la mutación Graphql a utilizar.
Abra src/components/Todo/TodoInput.js
y añada el siguiente código:
import React from 'react';+ import { gql } from "@apollo/client";+ const ADD_TODO = gql `+ mutation ($todo: String!, $isPublic: Boolean!) {+ insert_todos(objects: {title: $todo, is_public: $isPublic}) {+ affected_rows+ returning {+ id+ title+ created_at+ is_completed+ }+ }+ }+ `;const TodoInput = ({isPublic=false}) => {return (<form className="formInput" onSubmit={(e) => {e.preventDefault();}}><inputclassName="input"placeholder="What needs to be done?"/><i className="inputMarker fa fa-angle-right" /></form>);};export default TodoInput;
¿Qué hace esta mutación?
La mutación se inserta en la tabla todos
con la variable $objets, que es pasada como un tipo de tarea pendiente.
¡Maravilloso! Acabamos de definir nuestra primera mutación Graphql.
Build apps and APIs 10x faster
Built-in authorization and caching
8x more performant than hand-rolled APIs

