Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do I call a getter from another store in Vuex?

I have vuex a store abc.js:

import Vue from 'vue';

const state = {
  recordType: null
};

const getters = {

  recordType: state => state.recordType,

};
.... other code

The I have other vuex store xyz.js:

import { API } from '@/api';
import Vue from 'vue';

const state = {
  messages: null
};

const getters = {
  messages: state => state.messages || [],
};

const actions = {
  async openRecord({ dispatch, rootState, commit, state }, record) {

    // api data
    const response = await API.post('api/openrecord/', {
      recordUid: record.recordUid,

      //**** HELP !!! HERE ****//
      recordType: // *** HERE I need to get the recordType getter from abc.js

    });

  }

};

So on xyz.js store I need to get the recordType value from abc.js

like image 954
VAAA Avatar asked Oct 23 '25 03:10

VAAA


1 Answers

You can use the rootGetters property, along with specifying namespace :

rootGetters['abc/recordType']

In your case, it gives :

const actions = {
  async openRecord({ dispatch, rootGetters, commit, state }, record) {
    // api data
    const response = await API.post('api/openrecord/', {
      recordUid: record.recordUid,
      recordType: rootGetters['abc/recordType']
    });
  }
};
like image 73
Pierre Gerbaud Avatar answered Oct 25 '25 22:10

Pierre Gerbaud