mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-02 20:18:08 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			110 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import * as MutationHelpers from 'shared/helpers/vuex/mutationHelpers';
 | 
						|
import types from '../mutation-types';
 | 
						|
import AttributeAPI from '../../api/attributes';
 | 
						|
import camelcaseKeys from 'camelcase-keys';
 | 
						|
 | 
						|
export const state = {
 | 
						|
  records: [],
 | 
						|
  uiFlags: {
 | 
						|
    isFetching: false,
 | 
						|
    isCreating: false,
 | 
						|
    isUpdating: false,
 | 
						|
    isDeleting: false,
 | 
						|
  },
 | 
						|
};
 | 
						|
 | 
						|
export const getters = {
 | 
						|
  getUIFlags(_state) {
 | 
						|
    return _state.uiFlags;
 | 
						|
  },
 | 
						|
  getAttributes: _state => {
 | 
						|
    return _state.records;
 | 
						|
  },
 | 
						|
  getConversationAttributes: _state => {
 | 
						|
    return _state.records
 | 
						|
      .filter(record => record.attribute_model === 'conversation_attribute')
 | 
						|
      .map(camelcaseKeys);
 | 
						|
  },
 | 
						|
  getContactAttributes: _state => {
 | 
						|
    return _state.records
 | 
						|
      .filter(record => record.attribute_model === 'contact_attribute')
 | 
						|
      .map(camelcaseKeys);
 | 
						|
  },
 | 
						|
  getAttributesByModel: _state => attributeModel => {
 | 
						|
    return _state.records.filter(
 | 
						|
      record => record.attribute_model === attributeModel
 | 
						|
    );
 | 
						|
  },
 | 
						|
};
 | 
						|
 | 
						|
export const actions = {
 | 
						|
  get: async function getAttributesByModel({ commit }) {
 | 
						|
    commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isFetching: true });
 | 
						|
    try {
 | 
						|
      const response = await AttributeAPI.getAttributesByModel();
 | 
						|
      commit(types.SET_CUSTOM_ATTRIBUTE, response.data);
 | 
						|
    } catch (error) {
 | 
						|
      // Ignore error
 | 
						|
    } finally {
 | 
						|
      commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isFetching: false });
 | 
						|
    }
 | 
						|
  },
 | 
						|
  create: async function createAttribute({ commit }, attributeObj) {
 | 
						|
    commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isCreating: true });
 | 
						|
    try {
 | 
						|
      const response = await AttributeAPI.create(attributeObj);
 | 
						|
      commit(types.ADD_CUSTOM_ATTRIBUTE, response.data);
 | 
						|
    } catch (error) {
 | 
						|
      const errorMessage = error?.response?.data?.message;
 | 
						|
      throw new Error(errorMessage);
 | 
						|
    } finally {
 | 
						|
      commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isCreating: false });
 | 
						|
    }
 | 
						|
  },
 | 
						|
  update: async ({ commit }, { id, ...updateObj }) => {
 | 
						|
    commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isUpdating: true });
 | 
						|
    try {
 | 
						|
      const response = await AttributeAPI.update(id, updateObj);
 | 
						|
      commit(types.EDIT_CUSTOM_ATTRIBUTE, response.data);
 | 
						|
    } catch (error) {
 | 
						|
      const errorMessage = error?.response?.data?.message;
 | 
						|
      throw new Error(errorMessage);
 | 
						|
    } finally {
 | 
						|
      commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isUpdating: false });
 | 
						|
    }
 | 
						|
  },
 | 
						|
  delete: async ({ commit }, id) => {
 | 
						|
    commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isDeleting: true });
 | 
						|
    try {
 | 
						|
      await AttributeAPI.delete(id);
 | 
						|
      commit(types.DELETE_CUSTOM_ATTRIBUTE, id);
 | 
						|
    } catch (error) {
 | 
						|
      throw new Error(error);
 | 
						|
    } finally {
 | 
						|
      commit(types.SET_CUSTOM_ATTRIBUTE_UI_FLAG, { isDeleting: false });
 | 
						|
    }
 | 
						|
  },
 | 
						|
};
 | 
						|
 | 
						|
export const mutations = {
 | 
						|
  [types.SET_CUSTOM_ATTRIBUTE_UI_FLAG](_state, data) {
 | 
						|
    _state.uiFlags = {
 | 
						|
      ..._state.uiFlags,
 | 
						|
      ...data,
 | 
						|
    };
 | 
						|
  },
 | 
						|
 | 
						|
  [types.ADD_CUSTOM_ATTRIBUTE]: MutationHelpers.create,
 | 
						|
  [types.SET_CUSTOM_ATTRIBUTE]: MutationHelpers.set,
 | 
						|
  [types.EDIT_CUSTOM_ATTRIBUTE]: MutationHelpers.update,
 | 
						|
  [types.DELETE_CUSTOM_ATTRIBUTE]: MutationHelpers.destroy,
 | 
						|
};
 | 
						|
 | 
						|
export default {
 | 
						|
  namespaced: true,
 | 
						|
  actions,
 | 
						|
  state,
 | 
						|
  getters,
 | 
						|
  mutations,
 | 
						|
};
 |