Как интегрировать localStorage в Pinia с использованием TypeScript?

Возникла проблема с интеграцией localStorage в Pinia с использованием TypeScript. Когда я извлекаю clientsData из pinia дл рендера клиентов, то получаю undefined в pinia. Не могу понять в чём ошибка:

// clients.ts useClientsStore Pinia

import { ref } from 'vue'
import { defineStore } from 'pinia'
import idCreation from '@/helpers/idCreation'
import type { IContacts } from '@/models/ObjectModels'

export const useClientsStore = defineStore('client', () => {
  const clientJson: string | null = localStorage.getItem('clients')
  const clientsData = ref(clientJson !== null ? JSON.parse(clientJson) : [])

  function saveClients(): void {
    localStorage.setItem('clients', JSON.stringify(clientsData))
  }

  function addClient(
    firstName: string,
    secondName: string,
    thirdName: string,
    contacts: IContacts[]
  ): void {
    clientsData.value.push({
      id: idCreation(clientsData.value),
      firstName,
      secondName,
      thirdName,
      date: {
        newDate: new Date(),
        nowDate: Date.now()
      },
      edit: {
        newEdit: new Date(),
        nowEdit: Date.now()
      },
      contacts
    })

    saveClients()
  }

  return {
    clientsData,
    saveClients,
    addClient,
  }
})

// MainView.vue 

import { storeToRefs } from 'pinia';
import { useClientsStore } from '@/stores/clients';

const store = useClientsStore();
const { clientsData, searchValueStore } = storeToRefs(store);

console.log(clientsData) // выводит массив объектов, но в pinia state значение clientsData: undefined

В логах показывает массив объектов, а в setup MainView и state Pinia указывает undefined. Подскажите, пожалуйста, как это исправить?


Ответы (1 шт):

Автор решения: Esm

Решение — инициализировать пустой массив, а затем переназначить его:

const clientJson: string | null = localStorage.getItem('clients')

const clientsData = ref<IClient[]>([])
clientsData.value = clientJson !== null ? JSON.parse(clientJson) : []
→ Ссылка