Skip to content

Commit

Permalink
pkp/pkp-lib#9977 add isSuccess computed property to useFetch (pkp#355)
Browse files Browse the repository at this point in the history
  • Loading branch information
jardakotesovec authored May 23, 2024
1 parent ec72d49 commit 80b6f64
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 2 deletions.
5 changes: 5 additions & 0 deletions src/composables/useFetch.js
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ export function useFetch(url, options = {}) {
const modalStore = useModalStore();
const isLoading = ref(false);
const data = ref(null);
const isSuccess = ref(null);
const validationError = ref(null);

let lastRequestController = null;
Expand Down Expand Up @@ -91,12 +92,15 @@ export function useFetch(url, options = {}) {
}

isLoading.value = true;
isSuccess.value = null;
try {
const result = await ofetchInstance(unref(url), opts);
data.value = result;
validationError.value = null;
isSuccess.value = true;
} catch (e) {
data.value = null;
isSuccess.value = false;

if (signal) {
e.aborted = signal.aborted;
Expand All @@ -120,6 +124,7 @@ export function useFetch(url, options = {}) {

return {
data,
isSuccess,
validationError,
isLoading,
fetch,
Expand Down
22 changes: 21 additions & 1 deletion src/composables/useFetch.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ const body = {title: 'abc'};
const url = ref(submissionPostApiUrl);

// url, query and body can be normal objects or Refs
const {data, validationError, fetch} = useFetch(url, {
const {data, iSuccess, validationError, fetch} = useFetch(url, {
method: 'POST',
body,
// important if we expect endpoint to validate user input
Expand All @@ -70,6 +70,7 @@ await fetch();

console.log(validationError.value); // null
console.log(data.value); // {...} data returned from server
console.log(data.isSuccess); // true
```

### POST 4xx with validation error
Expand All @@ -93,6 +94,25 @@ console.log(validationError.value); // {title: ['Unsupported characters']}
console.log(data.value); // null
```

### POST 500

```javascript
const body = {title: 'abc'};
const url = ref(submissionPostApiUrl);

// url, query and body can be normal objects or Refs
const {data, isSuccess, fetch} = useFetch(url, {
method: 'POST',
body,
});

await fetch();

// Useful when some follow-up action should be triggered based on successfull request
console.log(isSuccess.value); // false
console.log(data.value); // null
```

### PUT 200

```javascript
Expand Down
24 changes: 23 additions & 1 deletion src/composables/useFetch.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,10 @@ export const restHandlers = [
);
}),

http.post('http://mock/post/status500', async ({request}) => {
return HttpResponse.json({}, {status: 500});
}),

http.post('http://mock/put/status200', async ({request}) => {
const postBody = await request.json();

Expand Down Expand Up @@ -127,7 +131,7 @@ describe('typical uses', () => {
test('POST 200 request', async () => {
const body = {title: 'abc'};
const url = ref('http://mock/post/status200');
const {data, validationError, fetch} = useFetch(url, {
const {data, isSuccess, validationError, fetch} = useFetch(url, {
method: 'POST',
body,
expectValidationError: true,
Expand All @@ -138,6 +142,24 @@ describe('typical uses', () => {
expect(validationError.value).toBe(null);

expect(data.value).toStrictEqual(body);
expect(isSuccess.value).toBe(true);
});

test('POST 500 request', async () => {
const body = {title: 'abc'};
const url = ref('http://mock/post/status500');
const {data, fetch, isSuccess} = useFetch(url, {
method: 'POST',
body,
});

expect(isSuccess.value).toBe(null);

await fetch();

expect(isSuccess.value).toBe(false);

expect(data.value).toStrictEqual(null);
});

test('POST 400 validation error request', async () => {
Expand Down

0 comments on commit 80b6f64

Please sign in to comment.