0.0.1 • Published 2 years ago
@tremor/tinybird-utils v0.0.1
Tremor Tinybird Plugin
npm i tinybird-utilsAPI
The plugin exports a useFetchPipe function that provides a single interface to easily query Tinybird pipes using SWR.
Arguments:
- name: The name of the Tinybird pipe.
- queryParams(optional): The query parameters of the pipe as a JSON-object.
- config(optional): The Tinybird configuration as a JSON-object.
- responseType(optional): The API response type.- 'JSON' | 'CSV' | 'Ndjson' | 'Parquet'
Example:
// Example.tsx
import { useFetchPipe } from 'tinybird-utils';
import { LineChart } from '@tremor/react';
export default function Example() {
  const { data, status } = useFetchPipe('my_sales_data_pipe', {
    date_from: '2023-01-01',
    date_to: '2023-03-01'
  });
  return status === 'loading' ? (
    <p>Loading...</p>
  ) : (
    <LineChart data={data} index="date" categories={['sales', 'profit']} />
  );
}Configuration
Configuration parameters:
- token: The Tinybird auth token
- baseUrl(optional): The Tinybird API base url, i.e. the tinybird pipe prefix up to the pipe name. Default:- https://api.tinybird.co/v0/pipes/
(1) Using the TbConfigProvider:
// ContextProvider.tsx
import { TbConfigProvider } from 'tinybird-utils';
export default function ContextProvider({ children }) {
  const token = '<my tinybird auth token>';
  const baseUrl = 'https://ui.us-east.tinybird.co/v0/pipes/';
  return (
    <TbConfigProvider
      token={token}
      // Optional
      baseUrl={baseUrl}>
      {children}
    </TbConfigProvider>
  );
}The config values can be set in one of the TbConfigProviders child components using the TbConfigContext and the provided setters:
// Example.tsx
import { TbConfigContext } from 'tinybird-utils';
import { useContext } from 'react';
...
const { setToken, setBaseUrl } = useContext(TbConfigContext);
...Once the config parameters are set in the TbConfigProvider, the useFetchPipe function will automatically obtain the config from the TbConfigContext.
(2) Directly providing a config via the config argument of the useFetchPipe as a JSON-object.
const { data } = useFetchPipe(
  'my_pipe',
  {
    date_from: '2023-01-01',
    date_to: '2023-03-01'
  },
  {
    token: '<my tinybird token>',
    // Optional
    baseUrl: 'https://api.us-east.tinybird.co/v0/pipes/'
  }
);0.0.1
2 years ago