Skip to content

Latest commit

 

History

History
101 lines (84 loc) · 2.48 KB

REACT.md

File metadata and controls

101 lines (84 loc) · 2.48 KB

React Example

Here's a common case on how one would use the SDK with React and TypeScript. These patterns are pretty similar to conventions we follow in the Cloud Manager app.

/** request.ts */

import { baseRequest } from 'linode-js-sdk/lib/request';

/**
 * intercepts every request with the following config
 * see https://github.com/axios/axios#interceptors for more documentation.
 */
baseRequest.interceptors.request.use(config => {
  const myToken = '1234';

  return {
    ...config,
    headers: {
      ...config.headers,
      Authorization: `Bearer ${myToken}`
    }
  };
});
/** LinodeList.tsx */

/**
 * The goal of this component is to create a list of all
 * your Linodes' labels
 */

import './request'
import { AxiosError } from 'axios'
import { getLinodes, Linode } from 'linode-js-sdk/lib/linodes'
import { APIError, ResourcePage } from 'linode-js-sdk/lib/types';
import React from 'react'

const MyComponent: React.FC<{}> = () => {
  const [linodes, setLinodesData] = React.useState<Linode[] | undefined>(undefined);
  const [errors, setErrors] = React.useState<APIError[] | undefined>(undefined);
  const [loading, setLoading] = React.useState<boolean>(false);

  React.useEffect(() => {

    /** set loading state while request is in flight */
    setLoading(true);

    getLinodes()
      .then((response: ResourcePage<Linode>) => {
        setLoading(false);
        setLinodesData(response.data)
      })
      .catch((e: AxiosError) => {
        setLoading(false);
        /**
         * All Linode error responses are wrapped in the Axios Error interface.
         * To override this and just return the Linode response, we recommend
         * looking into Axios interceptors:
         *
         * https://github.com/axios/axios#interceptors
         *
         * Need an example? Check out how we accomplish this in Cloud Manager:
         *
         * https://github.com/linode/manager/blob/develop/packages/manager/src/
         * request.tsx#L32
         */
        setErrors(e.response.data.errors)
      })
  }, [])

  if(loading) {
    return <div>Loading your Linodes...</div>
  }

  if(errors) {
    /**
     * you may need to do some additional undefined checking on
     * the AxiosError data
     */
    return <div>{errors[0].reason}</div>
  }

  if(!linodes) {
    return null;
  }

  return (
    <React.Fragment>
      {
        linodes.map(eachLinode => (
          <div key={eachLinode.id}>{eachLinode.label}</div>
        ))
      }
    </React.Fragment>
  )

}