Add HTTP client wrapper and upgrade Axios to v1 (#594)

* refactor: add HTTP client wrapper and upgrade axios to v1

Introduce a thin HTTP wrapper (resources/scripts/http) that centralizes
axios configuration, interceptors, and auth header injection. All 43
files now import from the wrapper instead of axios directly, making
future library swaps a single-file change. Upgrade axios from 0.30.0
to 1.14.0.

* fix: restore window.Ls assignment removed during axios refactor

company.js uses window.Ls.set() to persist selected company,
which broke after the axios plugin (that set window.Ls) was deleted.
This commit is contained in:
Darko Gjorgjijoski
2026-04-02 15:08:23 +02:00
committed by GitHub
parent a38f09cf7b
commit 691178857f
46 changed files with 637 additions and 394 deletions

View File

@@ -1,6 +1,6 @@
import { handleError } from '@/scripts/customer/helpers/error-handling'
const { defineStore } = window.pinia
import axios from 'axios'
import http from '@/scripts/http'
export const useInvoiceStore = defineStore({
id: 'customerInvoiceStore',
state: () => ({
@@ -12,7 +12,7 @@ export const useInvoiceStore = defineStore({
actions: {
fetchInvoices(params, slug) {
return new Promise((resolve, reject) => {
axios
http
.get(`/api/v1/${slug}/customer/invoices`, { params })
.then((response) => {
this.invoices = response.data.data
@@ -28,7 +28,7 @@ export const useInvoiceStore = defineStore({
fetchViewInvoice(params, slug) {
return new Promise((resolve, reject) => {
axios
http
.get(`/api/v1/${slug}/customer/invoices/${params.id}`, {
params,
})
@@ -46,7 +46,7 @@ export const useInvoiceStore = defineStore({
searchInvoice(params, slug) {
return new Promise((resolve, reject) => {
axios
http
.get(`/api/v1/${slug}/customer/invoices`, { params })
.then((response) => {
this.invoices = response.data