firex-store
- if you use this npm, you can reference firestore data, easily
- it is influenced by vuexfire
- node v10 ~
Installation
npm install --save firex-store
Example
others comming soon
Important!
-
Return values or state values bounded to Firestore has docId
(documentId in Firestore) property.
-
This npm library methods use only one 'document' and 'collection' type in one store module
-
A store module cannot subscribe to more than one 'collection' and 'document'
-
If you want to subscribe again after unsubscribing 'collection', set the property of the store you want to subscribe to []
and then subscribe.
Usage
Before Start...
- you must initailize firebase
.....
firebase.initializeApp({
apiKey: [your firebase api key],
projectId: [your project id],
.....
})
export const firestore = firebase.firestore()
1. Subscribe Firestore, using firex-store actions
part1. Add below mutations to namespaced Store
- method:
firestoreMutations
- argments:
- stateKey: you want to bind in the state
- mutationType: 'collection' or 'document'
Ex. subscribe collection
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
.....
}
part2. Add below actions to namespaced Store
Ex. subscribe collection
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
actions: {
...firestoreSubscribeActions({ ref: firestore.collection('/comments') })
}
.....
}
part3. Call firex-store actionType to subscribe data
Ex. subscribe collection
<script>
import { actionTypes } from 'firex-store'
export default {
name: 'Comments',
created() {
this.$store.dispatch(`comment/${actionTypes.COLLECTION_SUBSCRIBE}`)
}
}
</script>
2. Subscribe Firestore, using custom actions
part1. Add below mutations to namespaced Store
- method:
firestoreMutations
- argments:
- stateKey: you want to bind in the state
- mutationType: 'collection' or 'document'
Ex. subscribe collection
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
.....
}
part2. Add subscribeFirestore
in custom-actions
- method:
subscribeFirestore
- argments:
- state: State
- commit: Commit
- ref: firebase.firestore.DocumentReference | firebase.firestore.CollectionReference | firebase.firestore.Query
- options?: see Options
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
actions: {
subscribe: ({ state, commit }) => {
subscribeFirestore({
state,
commit,
ref: firestore.collection('/comments'),
options
})
}
}
.....
}
3. Unsubscribe Firestore, using firex-store actions
Ex. unsubscribe collection
part1. Add firestoreUnsubscribeActions
in actions
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
actions: {
...firestoreSubscribeActions({ ref: firestore.collection('/comments') }),
...firestoreUnsubscribeActions({ type: 'collection' })
}
.....
}
part2. Call firex-store actionType to unsubscribe data
<script>
import { actionTypes } from 'firex-store'
export default {
name: 'Comments',
created() {
this.$store.dispatch(`comment/${actionTypes.COLLECTION_UNSUBSCRIBE}`)
}
}
</script>
4. Unsubscribe Firestore, using custom actions
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
actions: {
subscribe: ({ state, commit }) => {
subscribeFirestore({
state,
commit,
ref: firestore.collection('/comments'),
options
})
},
unsubscribe: ({ state }) => {
unsubscribeFirestore({
state,
type: 'collection'
})
}
}
.....
}
5. Fetch at Once
-
method: findFirestore
-
argments:
- ref: firebase.firestore.DocumentReference | firebase.firestore.CollectionReference | firebase.firestore.Query
- options?: see Options
EX. call in Store Action, to fetch collection
export default {
namespaced: true,
state: {},
getters: {},
mutations: {},
actions: {
fetchComments: async ({ commit }) => {
const ref = firestore.collection('/comments')
const result = await findFirestore({ ref })
commit(***, result)
}
}
}
Options
-
Options
-
mapper:
- Map to something. State prop bound to Firestore or return values map to something if mapper defined
-
errorHandler
- If it defined, call it when error occured. But if not, call
console.error(error)
-
onCompleted
- If it defined, call it when completed
Ex.
const mapUser = (data) => ({
id: data.id
name: data.name
.....
})
const errorHandler = (error) => {
console.error(`[App Name]: ${error}`)
}
const onCompleted = () => {
console.log('completed!')
}
export default {
namespaced: true,
state: {
comments: [],
comment: null
},
mutations: {
...firestoreMutations({ statePropName: 'comments', type: 'collection' })
},
actions: {
subscribe: ({ state, commit }) => {
subscribeFirestore({
state,
commit,
ref: firestore.collection('/users').doc('userId'),
options: {
mapper: mapUser,
errorHandler,
onCompleted
}
})
}
}
.....
}