2.0.0 • Published 3 years ago
pinia-plugin-loading v2.0.0
Auto loading data binding plugin for pinia. You don't need to write showLoading or hideLoading any more.
Installation
npm install pinia-plugin-loadingor
yarn add pinia-plugin-loadingUsage
import { createPinia } from 'pinia'
import { PiniaLoading } from 'pinia-plugin-loading'
const pinia = createPinia()
pinia.use(PiniaLoading)All actions in your stores now have a matching, reactive boolean in $loading that indicates whether the action is pending or not.
Example
import { defineStore } from 'pinia'
export const useStore = defineStore('main', {
  state: () => {
    return {
      info: null
    }
  },
  actions: {
    async fetchData() {
      this.info = await request('/api')
    }
  }
})<template>
  <div>
    <loading v-if="store.$loading.fetchData" message="Loading…" />
  </div>
</template>
<script lang="ts" setup>
import { useStore } from '@/store'
const store = useStore()
</script>