Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tahq69/vue-loading

Loading bar for Vue.js apps using axios
https://github.com/tahq69/vue-loading

axios crip loader loading loading-bar vue vue-component vuejs2

Last synced: 3 months ago
JSON representation

Loading bar for Vue.js apps using axios

Awesome Lists containing this project

README

        

# crip-vue-loading

> A Vue.js project to wrap axios and display global loading bar of http requests.
For more details read [documentation with examples](http://rawgit.com/tahq69/vue-loading/master/index.html)

## Usage

### Install
```bash
> npm i -S crip-vue-loading
```

### Setup
```javascript
import Vue from "vue"
import CripLoading from "crip-vue-loading"
import axios from "axios"

// Install component in to Vue instance and inject in to axios.
Vue.use(CripLoading, {axios})

// If you use "vue-router" and do not disable `applyOnRouter` option
// make sure you install plugin before router:
// https://github.com/vuejs/vue-router/issues/315

```

### Display loading bar
```vue
// App.vue



Save

import axios from 'axios'

export default {
methods: {
async save (e, timeout = 0) {
try {
// simply call axios to save or request data and loading bar will
// show up while response is not received from server.
await axios.get(`http://www.fakeresponse.com/api/?sleep=${timeout}`)
} catch (err) {
console.error(err)
}
},
},
}

```

## TODO:

- Add algorithm with exponential progression instead of current linear;

## Build Setup

```bash
# install dependencies and serve with hot reload at localhost:8080
> npm i && npm run dev
```

## Release steps

```bash
> npm run release
```