-
-
Notifications
You must be signed in to change notification settings - Fork 88
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
142 changed files
with
10,625 additions
and
850 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,7 +9,7 @@ plugins { | |
} | ||
|
||
group = "dev.zenstack" | ||
version = "2.4.1" | ||
version = "2.5.0" | ||
|
||
repositories { | ||
mavenCentral() | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
/* eslint-disable */ | ||
|
||
import type { AnyTRPCRouter as AnyRouter } from '@trpc/server'; | ||
import type { NextPageContext } from 'next'; | ||
import { type CreateTRPCNext, createTRPCNext as _createTRPCNext } from '@trpc/next'; | ||
import type { DeepOverrideAtPath } from './utils'; | ||
import type { ClientType } from '../routers'; | ||
|
||
export function createTRPCNext< | ||
TRouter extends AnyRouter, | ||
TPath extends string | undefined = undefined, | ||
TSSRContext extends NextPageContext = NextPageContext | ||
>(opts: Parameters<typeof _createTRPCNext>[0]) { | ||
const r: CreateTRPCNext<TRouter, TSSRContext> = _createTRPCNext<TRouter, TSSRContext>(opts); | ||
return r as DeepOverrideAtPath<CreateTRPCNext<TRouter, TSSRContext>, ClientType<TRouter>, TPath>; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
/* eslint-disable */ | ||
|
||
import type { AnyTRPCRouter as AnyRouter } from '@trpc/server'; | ||
import type { CreateTRPCReactOptions } from '@trpc/react-query/shared'; | ||
import { type CreateTRPCReact, createTRPCReact as _createTRPCReact } from '@trpc/react-query'; | ||
import type { DeepOverrideAtPath } from './utils'; | ||
import type { ClientType } from '../routers'; | ||
|
||
export function createTRPCReact< | ||
TRouter extends AnyRouter, | ||
TPath extends string | undefined = undefined, | ||
TSSRContext = unknown | ||
>(opts?: CreateTRPCReactOptions<TRouter>) { | ||
const r: CreateTRPCReact<TRouter, TSSRContext> = _createTRPCReact<TRouter, TSSRContext>(opts); | ||
return r as DeepOverrideAtPath<CreateTRPCReact<TRouter, TSSRContext>, ClientType<TRouter>, TPath>; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
/* eslint-disable */ | ||
|
||
// inspired by: https://stackoverflow.com/questions/70632026/generic-to-recursively-modify-a-given-type-interface-in-typescript | ||
|
||
type Primitive = string | Function | number | boolean | Symbol | undefined | null; | ||
|
||
/** | ||
* Recursively merges `T` and `R`. If there's a shared key, use `R`'s field type to overwrite `T`. | ||
*/ | ||
export type DeepOverride<T, R> = T extends Primitive | ||
? R | ||
: R extends Primitive | ||
? R | ||
: { | ||
[K in keyof T]: K extends keyof R ? DeepOverride<T[K], R[K]> : T[K]; | ||
} & { | ||
[K in Exclude<keyof R, keyof T>]: R[K]; | ||
}; | ||
|
||
/** | ||
* Traverse to `Path` (denoted by dot separated string literal type) in `T`, and starting from there, | ||
* recursively merge with `R`. | ||
*/ | ||
export type DeepOverrideAtPath<T, R, Path extends string | undefined = undefined> = Path extends undefined | ||
? DeepOverride<T, R> | ||
: Path extends `${infer P1}.${infer P2}` | ||
? P1 extends keyof T | ||
? Omit<T, P1> & Record<P1, DeepOverride<T[P1], DeepOverrideAtPath<T[P1], R, P2>>> | ||
: never | ||
: Path extends keyof T | ||
? Omit<T, Path> & Record<Path, DeepOverride<T[Path], R>> | ||
: never; |
Oops, something went wrong.