mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-04 13:07:55 +00:00 
			
		
		
		
	* Feature: Agent Profile Update with avatar * Add Update Profile with name, avatar, email and password
		
			
				
	
	
		
			139 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/* eslint no-console: 0 */
 | 
						|
/* global axios */
 | 
						|
/* eslint no-undef: "error" */
 | 
						|
 | 
						|
import Cookies from 'js-cookie';
 | 
						|
import endPoints from './endPoints';
 | 
						|
import { setAuthCredentials, clearCookiesOnLogout } from '../store/utils/api';
 | 
						|
 | 
						|
export default {
 | 
						|
  login(creds) {
 | 
						|
    return new Promise((resolve, reject) => {
 | 
						|
      axios
 | 
						|
        .post('auth/sign_in', creds)
 | 
						|
        .then(response => {
 | 
						|
          setAuthCredentials(response);
 | 
						|
          resolve();
 | 
						|
        })
 | 
						|
        .catch(error => {
 | 
						|
          reject(error.response);
 | 
						|
        });
 | 
						|
    });
 | 
						|
  },
 | 
						|
 | 
						|
  register(creds) {
 | 
						|
    const urlData = endPoints('register');
 | 
						|
    const fetchPromise = new Promise((resolve, reject) => {
 | 
						|
      axios
 | 
						|
        .post(urlData.url, {
 | 
						|
          account_name: creds.name,
 | 
						|
          email: creds.email,
 | 
						|
        })
 | 
						|
        .then(response => {
 | 
						|
          setAuthCredentials(response);
 | 
						|
          resolve(response);
 | 
						|
        })
 | 
						|
        .catch(error => {
 | 
						|
          reject(error);
 | 
						|
        });
 | 
						|
    });
 | 
						|
    return fetchPromise;
 | 
						|
  },
 | 
						|
  validityCheck() {
 | 
						|
    const urlData = endPoints('validityCheck');
 | 
						|
    return axios.get(urlData.url);
 | 
						|
  },
 | 
						|
  logout() {
 | 
						|
    const urlData = endPoints('logout');
 | 
						|
    const fetchPromise = new Promise((resolve, reject) => {
 | 
						|
      axios
 | 
						|
        .delete(urlData.url)
 | 
						|
        .then(response => {
 | 
						|
          clearCookiesOnLogout();
 | 
						|
          resolve(response);
 | 
						|
        })
 | 
						|
        .catch(error => {
 | 
						|
          reject(error);
 | 
						|
        });
 | 
						|
    });
 | 
						|
    return fetchPromise;
 | 
						|
  },
 | 
						|
 | 
						|
  isLoggedIn() {
 | 
						|
    return !!Cookies.getJSON('auth_data');
 | 
						|
  },
 | 
						|
 | 
						|
  isAdmin() {
 | 
						|
    if (this.isLoggedIn()) {
 | 
						|
      return Cookies.getJSON('user').role === 'administrator';
 | 
						|
    }
 | 
						|
    return false;
 | 
						|
  },
 | 
						|
 | 
						|
  getAuthData() {
 | 
						|
    if (this.isLoggedIn()) {
 | 
						|
      return Cookies.getJSON('auth_data');
 | 
						|
    }
 | 
						|
    return false;
 | 
						|
  },
 | 
						|
  getPubSubToken() {
 | 
						|
    if (this.isLoggedIn()) {
 | 
						|
      return Cookies.getJSON('user').pubsub_token;
 | 
						|
    }
 | 
						|
    return null;
 | 
						|
  },
 | 
						|
  getCurrentUser() {
 | 
						|
    if (this.isLoggedIn()) {
 | 
						|
      return Cookies.getJSON('user');
 | 
						|
    }
 | 
						|
    return null;
 | 
						|
  },
 | 
						|
 | 
						|
  verifyPasswordToken({ confirmationToken }) {
 | 
						|
    return axios.post('auth/confirmation', {
 | 
						|
      confirmation_token: confirmationToken,
 | 
						|
    });
 | 
						|
  },
 | 
						|
 | 
						|
  setNewPassword({ resetPasswordToken, password, confirmPassword }) {
 | 
						|
    return new Promise((resolve, reject) => {
 | 
						|
      axios
 | 
						|
        .put('auth/password', {
 | 
						|
          reset_password_token: resetPasswordToken,
 | 
						|
          password_confirmation: confirmPassword,
 | 
						|
          password,
 | 
						|
        })
 | 
						|
        .then(response => {
 | 
						|
          setAuthCredentials(response);
 | 
						|
          resolve(response);
 | 
						|
        })
 | 
						|
        .catch(error => {
 | 
						|
          reject(error.response);
 | 
						|
        });
 | 
						|
    });
 | 
						|
  },
 | 
						|
 | 
						|
  resetPassword({ email }) {
 | 
						|
    const urlData = endPoints('resetPassword');
 | 
						|
    return axios.post(urlData.url, { email });
 | 
						|
  },
 | 
						|
 | 
						|
  profileUpdate({ name, email, password, password_confirmation, avatar }) {
 | 
						|
    const formData = new FormData();
 | 
						|
    if (name) {
 | 
						|
      formData.append('profile[name]', name);
 | 
						|
    }
 | 
						|
    if (email) {
 | 
						|
      formData.append('profile[email]', email);
 | 
						|
    }
 | 
						|
    if (password && password_confirmation) {
 | 
						|
      formData.append('profile[password]', password);
 | 
						|
      formData.append('profile[password_confirmation]', password_confirmation);
 | 
						|
    }
 | 
						|
    if (avatar) {
 | 
						|
      formData.append('profile[avatar]', avatar);
 | 
						|
    }
 | 
						|
    return axios.put(endPoints('profileUpdate').url, formData);
 | 
						|
  },
 | 
						|
};
 |