|
- import { defineStore } from 'pinia'
- import { useLocalStorage } from '@vueuse/core'
-
- export const useCommentStore = defineStore('comment', {
- state: () => ({
- comment: useLocalStorage('comment', [])
- }),
- hydrate(state, initialState) { // as nuxt is in SSR localstorage is not available so we need to hydrate the app with data first
- state.comment = useLocalStorage('comment', [])
- },
- actions: {
- add(newComment) {
- this.comment.push(newComment)
- useLocalStorage('comment', this.comment)
- },
- },
- getters: {
- orderedComment: (state) => {
- return (filmId) => {
- return state.comment.filter(comment => comment.filmId === filmId).sort((a, b) => b.added - a.added)
- }
- }
- }
- })
|