diff --git a/JavaScript/React/Redux.md b/JavaScript/React/Redux.md
index 70a7603..a56508d 100644
--- a/JavaScript/React/Redux.md
+++ b/JavaScript/React/Redux.md
@@ -271,34 +271,6 @@ Redux Toolkit includes these APIs:
[new_async_thunk]: https://redux-toolkit.js.org/api/createAsyncThunk
[entity_adapt]: https://redux-toolkit.js.org/api/createEntityAdapter
-### RTK Query
-
-RTK Query is provided as an optional addon within the `@reduxjs/toolkit` package.
-It is purpose-built to solve the use case of data fetching and caching, supplying a compact, but powerful toolset to define an API interface layer got the app.
-It is intended to simplify common cases for loading data in a web application, eliminating the need to hand-write data fetching & caching logic yourself.
-
-RTK Query is included within the installation of the core Redux Toolkit package. It is available via either of the two entry points below:
-
-```cs
-import { createApi } from '@reduxjs/toolkit/query'
-
-/* React-specific entry point that automatically generates hooks corresponding to the defined endpoints */
-import { createApi } from '@reduxjs/toolkit/query/react'
-```
-
-RTK Query includes these APIs:
-
-- [`createApi()`][new_api]: The core of RTK Query's functionality. It allows to define a set of endpoints describe how to retrieve data from a series of endpoints,
- including configuration of how to fetch and transform that data.
-- [`fetchBaseQuery()`][fetch_query]: A small wrapper around fetch that aims to simplify requests. Intended as the recommended baseQuery to be used in createApi for the majority of users.
-- [``][api_provider]: Can be used as a Provider if you do not already have a Redux store.
-- [`setupListeners()`][setup_listener]: A utility used to enable refetchOnMount and refetchOnReconnect behaviors.
-
-[new_api]: https://redux-toolkit.js.org/rtk-query/api/createApi
-[fetch_query]: https://redux-toolkit.js.org/rtk-query/api/fetchBaseQuery
-[api_provider]: https://redux-toolkit.js.org/rtk-query/api/ApiProvider
-[setup_listener]: https://redux-toolkit.js.org/rtk-query/api/setupListeners
-
### [`configureStore`](https://redux-toolkit.js.org/api/configureStore)
Included Default Middleware:
@@ -424,3 +396,70 @@ const counterSlice = createSlice({
export const { increment, decrement, incrementByAmount } = counterSlice.actions
export default counterSlice.reducer
```
+
+### [`createAsyncThunk`](https://redux-toolkit.js.org/api/createAsyncThunk)
+
+The function `createAsyncThunk` returns a standard Redux thunk action creator.
+The thunk action creator function will have plain action creators for the pending, fulfilled, and rejected cases attached as nested fields.
+
+The `payloadCreator` function will be called with two arguments:
+
+- `arg`: a single value, containing the first parameter that was passed to the thunk action creator when it was dispatched.
+- `thunkAPI`: an object containing all of the parameters that are normally passed to a Redux thunk function, as well as additional options:
+ - `dispatch`: the Redux store dispatch method
+ - `getState`: the Redux store getState method
+ - `extra`: the "extra argument" given to the thunk middleware on setup, if available
+ - `requestId`: a unique string ID value that was automatically generated to identify this request sequence
+ - `signal`: an `AbortController.signal` object that may be used to see if another part of the app logic has marked this request as needing cancellation.
+ - [...]
+
+The logic in the `payloadCreator` function may use any of these values as needed to calculate the result.
+
+```js
+import { createAsyncThunk, createSlice } from '@reduxjs/toolkit'
+
+const payloadCreator = async (arg, ThunkAPI): Promise => { /* ... */ };
+const thunk = createAsyncThunk("", payloadCreator);
+
+thunk.pending; // action creator that dispatches an '/pending'
+thunk.fulfilled; // action creator that dispatches an '/fulfilled'
+thunk.rejected; // action creator that dispatches an '/rejected'
+
+const slice = createSlice({
+ name: '',
+ initialState,
+ reducers: { /* standard reducer logic, with auto-generated action types per reducer */ },
+ extraReducers: (builder) => {
+ // Add reducers for additional action types here, and handle loading state as needed
+ builder.addCase(thunk.fulfilled, (state, action) => { /* body of the reducer */ })
+ },
+})
+```
+
+## RTK Query
+
+RTK Query is provided as an optional addon within the `@reduxjs/toolkit` package.
+It is purpose-built to solve the use case of data fetching and caching, supplying a compact, but powerful toolset to define an API interface layer got the app.
+It is intended to simplify common cases for loading data in a web application, eliminating the need to hand-write data fetching & caching logic yourself.
+
+RTK Query is included within the installation of the core Redux Toolkit package. It is available via either of the two entry points below:
+
+```cs
+import { createApi } from '@reduxjs/toolkit/query'
+
+/* React-specific entry point that automatically generates hooks corresponding to the defined endpoints */
+import { createApi } from '@reduxjs/toolkit/query/react'
+```
+
+RTK Query includes these APIs:
+
+- [`createApi()`][new_api]: The core of RTK Query's functionality. It allows to define a set of endpoints describe how to retrieve data from a series of endpoints,
+ including configuration of how to fetch and transform that data.
+- [`fetchBaseQuery()`][fetch_query]: A small wrapper around fetch that aims to simplify requests. Intended as the recommended baseQuery to be used in createApi for the majority of users.
+- [``][api_provider]: Can be used as a Provider if you do not already have a Redux store.
+- [`setupListeners()`][setup_listener]: A utility used to enable refetchOnMount and refetchOnReconnect behaviors.
+
+[new_api]: https://redux-toolkit.js.org/rtk-query/api/createApi
+[fetch_query]: https://redux-toolkit.js.org/rtk-query/api/fetchBaseQuery
+[api_provider]: https://redux-toolkit.js.org/rtk-query/api/ApiProvider
+[setup_listener]: https://redux-toolkit.js.org/rtk-query/api/setupListeners