data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
redux-request-status
Advanced tools
Declarative async request status handling for redux applications
Must use redux-thunk (or any custom middleware that provides the dispatch method to an action that is a funciton)
npm install --save redux-request-status
Provide a Declarative, readable, easy to implement utility for handling asyncronous status changes. Typically, this will be an http request, but could be anything asyncronous action that returns a promise. Using redux-request-status
we're able to respond to 3 different actions by ( onRequest
, onSuccess
, or onError
) for a single action type.
// actions.js
import { asyncActionCreator } from 'redux-request-status';
import { GET_JOKE } from './constants';
function getJokeAsyncronously() {
return new Promise(function(resolve, reject) {
setTimeout(function() {
resolve({
joke: `A sailor in a bar leans over to the guy next to him and says, "Wanna hear a MARINE joke?" The guy next to him replies, "Well, before you tell that joke, you should know something. I'm 6'. tall, 200 lbs, and I'm a MARINE. The guy sitting next to me is 6'2" tall, weighs 225, and he's a MARINE. The fella next to him is 6'5" tall, weighs 250, and he's also a MARINE. Now, you still wanna tell that joke?"`,
punchline: `The sailor says, "Nah, I don't want to have to explain it three times.`
});
}, 2000);
})
}
export function fetchJoke() {
return asyncActionCreator({
promise: getJokeAsyncronously(),
type: GET_JOKE
});
}
// reducer.js
import { onSuccess, onError, onRequest } from 'redux-request-status';
import { GET_JOKE } from './constants';
import { merge } from './utilities'; // just a shortcut helper to merge state... returns Object.assign({}, ...arguments);
export default function jokeReducer(state, action) {
switch (action.type) {
case onRequest(GET_JOKE):
return merge(state, { isLoading: true, isError: false });
case onSuccess(GET_JOKE):
return merge(state, {
joke: action.data.joke,
isLoading: false,
});
case onError(GET_JOKE):
return merge(state, { isError: true });
}
}
the function asyncActionCreator
will return a thunk (a function which deleys execution) for redux-thunk
to execute.
by dispatching the actionCreator getJoke
, redux-response-status
will dispatch one action for when the initial action was dispatched (this is where we would typically disable the UI or display a loader), and one action when the promise resolve/rejects.
import { asyncActionCreator } from 'redux-request-status';
export function getJoke() {
return asyncActionCreator({
promise: getJokeAsyncronously(), // `getJokeAsyncronously` must return a promise.
type: GET_JOKE
});
}
dispatching the result of asyncActionCreator()
will dispatch 2 actions; 1 immidiatly to handle the initial request and another on resolution or rejection of the promise passed to it.
the sucess action will assign the result of the promise to the data
key on the success action. the error action will assign the result of the rejected promise to the error
key on the error action. All three of these actions will also contain any additional properties on the object passed to asyncActionCreator
export function getJoke(jokeOptions) {
const { category, vulgarity } = jokeOptions;
return asyncActionCreator({
promise: getJokeAsyncronously(category, vulgarity),
type: GET_JOKE,
jokeOptions
});
}
store.dispatch(getJobs({ category: 'military', vulgarity: 2 }));
/*
1st -- before making request
{
type: 'GET_JOKE [REQUEST]',
jokeOptions: { category: 'military', vulgarity: 2 }
}
2nd -- after promise resolves successfully
{
type: 'GET_JOKE [SUCCESS]',
jokeOptions: { category: 'military', vulgarity: 2 },
data: {
joke: 'How do you tell an officer to get lost?',
punchline: 'Give him a compass and a map.'
}
}
OR -- if the promose rejects
{
type: 'GET_JOKE [ERROR]',
jokeOptions: { category: 'military', vulgarity: 2 },
error: {
error_type: 'NO_JOKES_AVAILABLE',
message: 'There are no jokes that match your query'
}
}
*/
Thanks to @JevinAnderson for the feedback on the API.
MIT
FAQs
Declarative async request status handling for redux applications
The npm package redux-request-status receives a total of 5 weekly downloads. As such, redux-request-status popularity was classified as not popular.
We found that redux-request-status demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.