-
-
Notifications
You must be signed in to change notification settings - Fork 27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
updated_at en updated_by guards, only in some cases #305
Comments
Hello. Thanks for your issue! If you're interested in contributing, I can point you to the area that needs to be updated. 😉 Otherwise, you can work around it by writing a custom wrapper function for the |
Well, I guess this is somewhere there : vuex-easy-firestore/src/module/getters.ts Line 174 in 017ee80
I need to know if this prop delete is because of a guard... I'll take a look. |
@mesqueeb I just come back to this one, because it actually cause bug in my app... Because even with guards on updated and created, it still try to patch (nothing)... Unfortunately because of firestore rules, some users can't update... Because my app is not yet in prod, I can open the rules a little bit to fix it. However if you can tell where to fix this, I would love to. Thanks 👍 |
@Fulbert there is actually an easy workaround I want to suggest you use instead: https://mesqueeb.github.io/vuex-easy-firestore/hooks.html#hooks-after-local-changes-before-sync {
// in your module config
sync: {
patchHookBeforeSync: function (updateFirestore, doc, store) {
// check if you are only trying to update the "selected" prop or not, if so, return early
if (selected in doc && Object.keys(doc) === 1) return
// else, continue:
updateFirestore(doc)
},
}
} Can you try this out and let me know how it goes? |
I actually fixed it like this yesterday, few minutes before I thought that I can mutate my Sorry for that 😳 |
We'll definitely make requests to Firestore only if they are non-empty in the future, so this will be solved. In the meantime, I have a question for you @Fulbert : is there a reason why your guarded property is within |
I have the following collections :
- customers
- machines
- task
- calls
In my app I have list view for all this collections and I can select
multiple items.
Instead of having locallyan array of selecteds IDs, I prefer to have a
property "selected" in each document. But I don't want to sync it because
of course each user can select their own documents.
User can trigger actions on multiple items, thanks to selection.
However I was using the vuex-easy-firestore patch action to mutate my
"selected" property (alone) but then I realized I should actually use my
own action to avoid syncing with firestore (as described in my previous
post).
I still think it shouldn't sync if there's nothing to mutate, but in my
case I'm still not sure what's the best way to do it.
You can see a bit more here :
https://github.com/ServiceTaskManager/servicetask/blob/ad55133e4350255e6ae3cd5c9d72a2d89ffec97f/src/store/firestore/index.js#L78
And here
https://github.com/ServiceTaskManager/servicetask/blob/master/src/components/generic/StItem.vue
Le ven. 15 mai 2020 à 17:41, Louis Ameline <notifications@github.com> a
écrit :
… We'll definitely make requests to Firestore only if they are non-empty in
the future, so this will be solved.
In the meantime, I have a question for you @Fulbert
<https://github.com/Fulbert> : is there a reason why your guarded
property is within state.data (if data is the prefix you chose) instead
of at the root of state, which is not synced? I'm trying to get a glimpse
of the use cases where people guard properties. Thank you
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#305 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABGCSIF4TXJ3V2PMVAKD4YTRRVPBJANCNFSM4LQZ674A>
.
|
Oh great thank you, I understand now. It's ok to use a non-vef action or mutation to mutate your property until we fix. I'll check tomorrow if a quick patch can be done for this issue. But in all cases, there will be another preferred way to handle your local properties of documents loaded by a collection in the future. |
Hello,
Thanks for this awesome tool!
I have a guarded property on my store,
selected
, which is used only by the UI, and I don't want to sync on Firestore.If the guards works well, the document is still synced everytime I change the
selected
value, because of theupdated_at
andupdated_by
value.Of course, I can add the two properties to the guards too, and it works, but I actually still want to use them for some other cases.
Did I miss something that could help, or would I need to use other property name and add logic to save updates when needed?
Thanks!
The text was updated successfully, but these errors were encountered: