2.0.7 • Published 4 years ago
@thesunny/api v2.0.7
@thesunny/api
A featherweight API abstraction and browser client in a few KB for Next.js with end-to-end TypeScript typing, colorful API call/response logging, and type validation on the API server to ensure you are getting the right data types.
Design Decisions
- Next.js gets upgraded frequently so we try not to build on top of Next.js methods and types
- The Clientmethod is unrelated to Next.js. It actually doesn't have any Next.js integration which keeps it clean.
- The API.methodfunction is as minimal as possible. Here's some thoughts on its design:
- Get Response Type: It does all you to get the Responsetype for consumption by the client usingAPI.Response.
- Opinionated JSON Return Type: It forces you to return a JSON object because if you don't, you get weird bugs.
- Response is otherwuse unopinionated: It does not type narrow the return type to jsendbut you have to do it manually. Because sometimes, that might not be what you want to return.
- No incoming validation: It does not validate the incoming props because that ties it too closely with superstruct which we use... and the problem is superstruct changes often
- Eliminates Res Setting Boilerplate: It does allow you to simply return a JSONresponse and you don't need to do all theres.statusstuff
- Better Debugging: Show important debug information in console like errors, execution time, incoming props, outgoing values.
 
- Get Response Type: It does all you to get the 
- Web- Self documenting (because they are the only two things in Web) use ofWeb.ContextandWeb.Propsin place of more verbose and hard to rememeber Next.js typesGetServerSidePropsContextandInferGetServerSidePropsContext
- It is redundant, but its easy to forget the name of these methods, and even as we remember, they use a lot of screen real estate.
 
- Self documenting (because they are the only two things in 
- jsend- Kept separate because sometimes we may not want to conform to jsend
- When we do, a single method takes jsendobject and returns the object making it super simple to use.
 
- Kept separate because sometimes we may not want to conform to 
Define an API method
import { API, jsend } from "@thesunny/api"
import * as s from "superstruct"
const Props = s.object({})
const method = API.method(async function (props) {
  const {} = s.create(props, Props)
  return jsend({ status: "success", data: {} })
})
export default method
export type APIProps = s.Infer<typeof Props>
export type APIResponse = API.Response<typeof method>Make an API call from the Client
Client can be on the browser or on the Node.js server. Both will work.
import { Client } from "@thesunny/api"
const client = Client.create("http://localhost:3000")
const response = await client.call("api/get-time", { username: "john" })Minimal Web Page (Without API)
import { Web } from "@thesunny/api"
export async function getServerSideProps(context: Web.Context) {
  return { props: {} }
}
type Props = Web.Props<typeof getServerSideProps>
export default function Page(props: Props) {
  return <div>Hello</div>
}Minimal Web Page (With API and Client)
import { Client, Web } from "@thesunny/api"
import { APIProps, APIResponse } from "~/pages/api/minimal-api"
export const client = Client.create(process.env.NEXT_PUBLIC_API_URL)
export async function getServerSideProps(context: Web.Context) {
  const response = await client.call<APIProps, APIResponse>("api/...path", {})
  return { props: response.data }
}
type Props = Web.Props<typeof getServerSideProps>
export default function Page({ number }: Props) {
  return <div>{number}</div>
}Features
Client features
- Supports end-to-end typing
- Proper calling types for API
- Proper return types for API
- If the Client hits a bad URL, throws a helpful Error
API Features
- Logs API calls to console with call arguments with pretty colors
- Logs API return values to console with pretty colors
- Logs Errors nicely into the console
- Adds a counter to identify each call and displays it with the response so you can match calls with responses if they don't happen in order
- Type generics to extract API Response type for use with client
JSend Features
- Easy method makes sure your types conform to jsendstandard.
Web Features
- Web.Contextshortcut for use with- getServerSidePropsfirst argument
- Web.Propsshortcut that takes- typeof getServerSidePropsand extracts the return value from the function for use in Page props.
2.0.5
4 years ago
2.0.7
4 years ago
2.0.6
4 years ago
1.0.35
5 years ago
1.0.30
5 years ago
1.0.28
5 years ago
1.0.27
5 years ago
1.0.25
5 years ago
1.0.22
5 years ago
1.0.21
5 years ago
1.0.19
5 years ago
1.0.18
5 years ago
1.0.17
5 years ago
1.0.15
5 years ago
1.0.11
5 years ago
1.0.13
5 years ago
1.0.2
5 years ago
1.0.7
5 years ago
1.0.6
5 years ago
1.0.0
5 years ago