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.
Mapping Types
This is the final section of the tutorial. Here we will import type definitions relevant for this component.
Types for fetching older todos
import React, { Fragment, useState, useRef, useEffect } from "react";import { useSubscription, useApolloClient } from "@apollo/react-hooks";import gql from "graphql-tag";import TaskItem from "./TaskItem";+ import {+ GetOldPublicTodosQuery,+ GetOldPublicTodosQueryVariables,+ Todos+ } from '../../generated/graphql';- type TodoItem = {- id: number,- title: string,- user: { name: string }- }+ type publicListProps = {+ latestTodo?: Partial<Todos> | null+ }
Now we will handle the case of latestTodo object being undefined.
const TodoPublicList = (props: publicListProps) => {const [olderTodosAvailable, setOlderTodosAvailable] = useState(props.latestTodo ? true : false)const [newTodosCount, setNewTodosCount] = useState(0)const [error, setError] = useState(false);- const [todos, setTodos] = useState<TodoItem[]>([]);+ const [todos, setTodos] = useState<GetOldPublicTodosQuery["todos"]>([]);- let oldestTodoId = useRef(props.latestTodo ? props.latestTodo.id + 1 : 0);+ let oldestTodoId = useRef(props.latestTodo && props.latestTodo.id ? props.latestTodo.id + 1 : 0);- let newestTodoId = useRef(props.latestTodo ? props.latestTodo.id : 0);+ let newestTodoId = useRef(props.latestTodo && props.latestTodo.id ? props.latestTodo.id : 0);if(todos && todos.length) {oldestTodoId.current = todos[todos.length - 1].idnewestTodoId.current = todos[0].id;}
Let's apply the type definitions to client.query
in loadOlder function.
- const { data, networkStatus } = await client.query({+ const { data, networkStatus } = await client.query<GetOldPublicTodosQuery, GetOldPublicTodosQueryVariables>({query: GET_OLD_PUBLIC_TODOS,variables: { oldestTodoId: oldestTodoId.current }});
Types for fetching newer todos
Now let's apply the type definitions to client.query
in loadNew function.
import {GetOldPublicTodosQuery,GetOldPublicTodosQueryVariables,+ GetNewPublicTodosQuery,+ GetNewPublicTodosQueryVariables,Todos} from '../../generated/graphql';- const { data, networkStatus } = await client.query({+ const { data, networkStatus } = await client.query<GetNewPublicTodosQuery, GetNewPublicTodosQueryVariables>({query: GET_NEW_PUBLIC_TODOS,variables: {latestVisibleId: newestTodoId.current}});
Types for useSubscription
In the useSubscription hook, let's apply the NotifyNewPublicTodosSubscription type definitions. We will also handle the data
being undefined.
const TodoPublicListSubscription = () => {// Run a subscription to get the latest public todoconst NOTIFY_NEW_PUBLIC_TODOS = gql`subscription notifyNewPublicTodos {todos(where: { is_public: { _eq: true } }limit: 1order_by: { created_at: desc }) {idcreated_at}}`;- const { loading, error, data } = useSubscription(NOTIFY_NEW_PUBLIC_TODOS);+ const { loading, error, data } = useSubscription<NotifyNewPublicTodosSubscription>(NOTIFY_NEW_PUBLIC_TODOS);...- if (error) {+ if (error || !data) {return <span>Error</span>;}};
Build apps and APIs 10x faster
Built-in authorization and caching
8x more performant than hand-rolled APIs
data:image/s3,"s3://crabby-images/08273/082737b5576206d8c98366a4f33213a2c85cab87" alt="Promo"
data:image/s3,"s3://crabby-images/868ff/868ffb1210a1adc758a09817d07c9681a5c10cc9" alt="footer illustration"