Skip to content

Commit

Permalink
feat: add pinia colada properties
Browse files Browse the repository at this point in the history
  • Loading branch information
posva committed Feb 15, 2024
1 parent fe3dd50 commit 63a768f
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 4 deletions.
4 changes: 4 additions & 0 deletions src/data-fetching_new/createDataLoader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,10 @@ export interface UseDataLoader<
UseDataLoaderResult<isLazy, Exclude<Data, NavigationResult>>
>

/**
* Internals of the data loader.
* @internal
*/
_: UseDataLoaderInternals<isLazy, Exclude<Data, NavigationResult>>
}

Expand Down
50 changes: 46 additions & 4 deletions src/data-fetching_new/defineColadaLoader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import {
} from './meta-extensions'
import {
IS_CLIENT,
_PromiseMerged,
assign,
getCurrentContext,
isSubsetOf,
Expand Down Expand Up @@ -58,17 +59,17 @@ export function defineColadaLoader<
>(
name: Name,
options: DefineDataLoaderOptions<isLazy, Name, Data>
): UseDataLoader<isLazy, Data>
): UseDataLoaderColada<isLazy, Data>
export function defineColadaLoader<Data, isLazy extends boolean>(
options: DefineDataLoaderOptions<isLazy, _RouteRecordName, Data>
): UseDataLoader<isLazy, Data>
): UseDataLoaderColada<isLazy, Data>

export function defineColadaLoader<Data, isLazy extends boolean>(
nameOrOptions:
| _RouteRecordName
| DefineDataLoaderOptions<isLazy, _RouteRecordName, Data>,
_options?: DefineDataLoaderOptions<isLazy, _RouteRecordName, Data>
): UseDataLoader<isLazy, Data> {
): UseDataLoaderColada<isLazy, Data> {
// TODO: make it DEV only and remove the first argument in production mode
// resolve option overrides
_options =
Expand Down Expand Up @@ -311,7 +312,7 @@ export function defineColadaLoader<Data, isLazy extends boolean>(

// @ts-expect-error: requires the internals and symbol that are added later
const useDataLoader: // for ts
UseDataLoader<isLazy, Data> = () => {
UseDataLoaderColada<isLazy, Data> = () => {
// work with nested data loaders
const [parentEntry, _router, _route] = getCurrentContext()
// fallback to the global router and routes for useDataLoaders used within components
Expand Down Expand Up @@ -475,10 +476,51 @@ export interface UseDataLoaderColadaResult<isLazy extends boolean, Data>
'isPending' | 'refetch' | 'refresh' | 'status'
> {}

/**
* Data Loader composable returned by `defineColadaLoader()`.
*/
export interface UseDataLoaderColada<isLazy extends boolean, Data>
extends UseDataLoader<isLazy, Data> {
/**
* Data Loader composable returned by `defineColadaLoader()`.
*
* @example
* Returns the Data loader data, isLoading, error etc. Meant to be used in `setup()` or `<script setup>` **without `await`**:
* ```vue
* <script setup>
* const { data, isLoading, error } = useUserData()
* </script>
* ```
*
* @example
* It also returns a promise of the data when used in nested loaders. Note this `data` is **not a ref**. This is not meant to be used in `setup()` or `<script setup>`.
* ```ts
* export const useUserConnections = defineLoader(async () => {
* const user = await useUserData()
* return fetchUserConnections(user.id)
* })
* ```
*/
(): _PromiseMerged<
// we can await the raw data
// excluding NavigationResult allows to ignore it in the type of Data when doing
// `return new NavigationResult()` in the loader
Exclude<Data, NavigationResult>,
// or use it as a composable
UseDataLoaderColadaResult<isLazy, Exclude<Data, NavigationResult>>
>
}

export interface DataLoaderColadaEntry<isLazy extends boolean, Data>
extends DataLoaderEntryBase<isLazy, Data> {
/**
* Reactive route passed to pinia colada so it automatically refetch
*/
route: ShallowRef<_RouteLocationNormalizedLoaded>

/**
* Tracked routes to know when the data should be refreshed. Key is the key of the query.
*/
tracked: Map<string, TrackedRoute>

/**
Expand Down

0 comments on commit 63a768f

Please sign in to comment.