Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Minor documentation improvements #27

Open
mcshaz opened this issue Nov 21, 2020 · 2 comments
Open

Minor documentation improvements #27

mcshaz opened this issue Nov 21, 2020 · 2 comments
Labels
documentation Improvements or additions to documentation

Comments

@mcshaz
Copy link

mcshaz commented Nov 21, 2020

First thank you and well done for making such for a great library

The docs are great, but a few small thoughts on improvements:

Using with typescript

If you are passing a Task down as a property to a child component, you can use the typing

const t = props.modelValue as ReturnType<typeof useTask>

Error handling

if you need to perform error handling within the useTask yielded function, define it on the signal argument first. For example if you were logging all calls to the server.

const componentLog = log.create("MyComponent")
const task = useTask(function*(signal, ){
      signal.pr.then(() => componentLog.info('successfully posted'),
          err=> {
            componentLog.warn('failed post', err)
            return Promise.reject(err)
         })
      yield axios.post(`api/...`)

Cancelation

A bit more info would be great around - what happens to the try/catch block if cancel or cancelAll has been called vs the server returning an error. using the example above

const componentLog = log.create("MyComponent")
const task = useTask(function*(signal, ){
      signal.pr.then(() => componentLog.info('successfully posted'),
          err=> {
            if (err === 'cancel') {
               componentLog.warn('request cancelled by user')
            } else {
               componentLog.error('failed post', err)
            }
            return Promise.reject(err)
         })

Thanks again

@MartinMalinda
Copy link
Owner

MartinMalinda commented Nov 27, 2020

Hey thanks for the feedback, appreciated 👍

ReturnType<typeof useTask> will effectively give you something like Task<any, any>. You can import the Task type directly. Due to the plugin being distributed both for Vue 2 and Vue 3 it can be on two different places right now.

I haven't passed a task via v-model so far. I think it's better to pass explicitly via some named prop.

import { Task } from "vue-concurrency/dist/vue3/src/Task";

// ...

props: {
    task: {
      type: Object as () => Task<any, any[]>,
    },

Regarding the signal.pr.then and signal.pr.catch - that is useful especially if you need to react to task cancellation from within the task itself. From my experience its useful for some kind of generic task utils that can be reused on different places. More clear way seems to me to actually handle this outside:

const save = async () => {
  try {
   await someTask.perform();
 } catch (e) {
  if (e === 'cancel') {
    // usually theres no need to react to cancel
  } else {
   // rethrow, fill some ref...
  }
}
};

But in general if what needs to happen after the task is performed is only some rerendering (no side-effects such as flash message display, redirects and so on) then I'd just rely on the derived state such as task.last.error task.last.isCancelled right in the template.

Hope this helps and thanks for the input.

I'll try to incorporate this in the docs later in some way too.

@MartinMalinda MartinMalinda added the documentation Improvements or additions to documentation label Dec 7, 2020
@rudolfbyker
Copy link

Another little issue in the docs, under https://vue-concurrency.netlify.app/cancellation/#cancelation-cascade : The code example does not match with the words right below it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Improvements or additions to documentation
Projects
None yet
Development

No branches or pull requests

3 participants