@reduxjs/toolkit
Version:
The official, opinionated, batteries-included toolset for efficient Redux development
56 lines (46 loc) • 1.48 kB
text/typescript
import { createApi, fetchBaseQuery } from '@reduxjs/toolkit/query/react'
import { createSelector, configureStore } from '@reduxjs/toolkit'
import { expectExactType } from './helpers'
describe('buildSelector', () => {
test.skip('buildSelector typetest', () => {
interface Todo {
userId: number
id: number
title: string
completed: boolean
}
type Todos = Array<Todo>
const exampleApi = createApi({
reducerPath: 'api',
baseQuery: fetchBaseQuery({
baseUrl: 'https://jsonplaceholder.typicode.com',
}),
endpoints: (build) => ({
getTodos: build.query<Todos, string>({
query: () => '/todos',
}),
}),
})
const exampleQuerySelector = exampleApi.endpoints.getTodos.select('/')
const todosSelector = createSelector(
[exampleQuerySelector],
(queryState) => {
return queryState?.data?.[0] ?? ({} as Todo)
}
)
const firstTodoTitleSelector = createSelector(
[todosSelector],
(todo) => todo?.title
)
const store = configureStore({
reducer: {
[exampleApi.reducerPath]: exampleApi.reducer,
other: () => 1,
},
})
const todoTitle = firstTodoTitleSelector(store.getState())
// This only compiles if we carried the types through
const upperTitle = todoTitle.toUpperCase()
expectExactType<string>(upperTitle)
})
})