Skip to content

A React client for the Spinitron API

License

Notifications You must be signed in to change notification settings

dctalbot/react-spinitron

Repository files navigation

react-spinitron

Installation

npm install @dctalbot/react-spinitron

Example

App.tsx

import { ApiClientProvider } from "@dctalbot/react-spinitron";
import { MyComponent } from "./MyComponent";

const API_BASE_URL = "https://my-spinitron-proxy.com/api";

function App() {
  return (
    <ApiClientProvider baseURL={API_BASE_URL}>
      <MyComponent />
    </ApiClientProvider>
  );
}

MyComponent.tsx

import { useSpins } from "@dctalbot/react-spinitron";

export function MyComponent() {
  // GET Spins for Playlist #123 every 10 seconds
  const { data, error, isFetching } = useSpins(
    {
      playlist_id: 123,
      // start?: string;
      // end?: string;
      // show_id?: number;
      // count?: number;
      // page?: number;
      // fields?: string[];
      // expand?: string[];
    },
    { refetchInterval: 10000 },
  );

  const listdata = data ?? [];

  if (error) return <div>Error</div>;
  if (isFetching) return <div>Loading...</div>;

  return (
    <div>
      {listdata.map((spin) => (
        <p key={spin.id}>
          {spin.song} by {spin.artist}
        </p>
      ))}
    </div>
  );
}

Hooks include:

  • usePersona(params, options)
  • usePersonas(params, options)
  • usePlaylist(params, options)
  • usePlaylists(params, options)
  • useShow(params, options)
  • useShows(params, options)
  • useSpin(params, options)
  • useSpins(params, options)

Related Projects

Contributing

Please run make check and resolve any errors before submitting a pull request.

Type generation

The client is written in Typescript and is based on the OpenAPI specification.

To generate these types, run:

make generate