-
Notifications
You must be signed in to change notification settings - Fork 900
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
Changing UpdateData<T> to expand support for types with index signatures. #7318
Conversation
🦋 Changeset detectedLatest commit: 4ec7437 The changes in this PR will be included in the next version bump. This PR includes changesets to release 3 packages
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
Size Report 1Affected ProductsNo changes between base commit (f2fb56f) and merge commit (ed7ab0e).Test Logs |
Size Analysis Report 1Affected ProductsNo changes between base commit (f2fb56f) and merge commit (ed7ab0e).Test Logs |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for this fix! I can't honestly say I completely understand it; however, the I understand the unit tests so it looks good to me!
…kduckworth/nested-update-data-v9
…base/firebase-js-sdk into markduckworth/nested-update-data-v10
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good, just needs a changeset (minor)
…kduckworth/nested-update-data-v10
…ebase/firebase-js-sdk into markduckworth/nested-update-data-v10
This was included in the v10.0.0 release: https://firebase.google.com/support/release-notes/js#version_1000_-_july_6_2023 |
This change relaxes
UpdateData<T>
, so that dot notation can be used to update typesT
whereT
contains an index signature. An example typeT
that this affects:Without this change, dot notation can not be used to update field
'indexed.foo.booleanProperty'
.With this change, the following code is now possible:
The downside of this change is that we lose type safety and auto-complete for these types. For example we can do the following:
However, type safety and auto-complete are still in place if doing full object replacement:
And, we should note that type safety and auto complete are still in place for nested types when index signature is not involved.
Fixes #6105
Reviewers should understand that the unit tests in
lite-api/types.test.ts
are all new. These tests are introduced in a different pull request (7319) and are intended to ensure that UpdateData does not regress in unexpected ways with the fix in this PR.