Skip to content
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

Address Book - Add & Edit #2879

Merged
merged 38 commits into from
Dec 10, 2020
Merged

Conversation

supernova-at
Copy link
Contributor

@supernova-at supernova-at commented Dec 1, 2020

Description

This PR adds the ability to add and edit addresses in the address book.

Related Issue

Closes PWA-634.

Acceptance

Verification Stakeholders

@schensley @dpatil-magento

Specification

n/a

Verification Steps

  1. Sign in
  2. Go to My Account > Address Book

Add New Address

  1. Click on "Add an Address" button
  2. Complete the form
  3. Click "Save"
  4. Verify that the newly created address appears on the page
Default
  1. Click on "Add an Address" button
  2. Complete the form
  3. Check the "make this my default address" checkbox
  4. Click "Save"
  5. Verify that the newly created address appears on the page and has the default icon on it

Edit Existing Address

  1. Click on "Edit" button of an existing address
  2. Complete the form
  3. Click "Save"
  4. Verify that the address is correctly updated on the page

Screenshots / Screen Captures (if appropriate)

Checklist

  • I have added tests to cover my changes, if necessary.
  • I have added translations for new strings, if necessary.
  • I have updated the documentation accordingly, if necessary.
  • Make this my default works
  • Errors need to be cleared out between showings of the dialog
  • Check and disable "make default" when the first address is being added
  • Check and disable "make default" when the only address is being edited

@PWAStudioBot
Copy link
Contributor

PWAStudioBot commented Dec 1, 2020

Messages
📖

Associated JIRA tickets: PWA-634.

📖 DangerCI Failures related to missing labels/description/linked issues/etc will persist until the next push or next nightly build run (assuming they are fixed).
📖

Access a deployed version of this PR here. Make sure to wait for the "pwa-pull-request-deploy" job to complete.

Generated by 🚫 dangerJS against f387313

@supernova-at supernova-at added the version: Minor This changeset includes functionality added in a backwards compatible manner. label Dec 1, 2020
Comment on lines 44 to 55
city
country_code
firstname
lastname
postcode
region {
region
region_code
region_id
}
street
telephone
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We may be able to remove these fields from the query result since we do a refetchQueries to get the updated data.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add definitely may not be needed, since this response isn't enough to slot it into the existing collection (we always could if wanted to do our own cache write to that collection).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed from the Add mutation in a10123d.

jimbo
jimbo previously requested changes Dec 2, 2020
Copy link
Contributor

@jimbo jimbo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Works pretty well for me.

@supernova-at
Copy link
Contributor Author

While adding first Address and/or during editing Default address, Make this my default address should be disabled but currently its enabled.

This was actually implemented but we talked about this at length during a group code review with UX and decided to revert it. It is possible to not have a default address.

If user has item in cart and then user updates default address in account address book and go to checkout > User still sees stale address.

After discussion we decided this is acceptable for now. Ideally GraphQL keeps the cart address in sync.

When user add Middle name in address, the middle name is not displayed in read only mode of address book.

Fixed in fc73ce7.

@supernova-at
Copy link
Contributor Author

Issue found in QA:

  1. Add or Update an address and set the country as "United Kingdom"
  2. Type a value into the Region field
  3. Save
  4. Edit the address
  5. Change the country dropdown to "United States"
  6. Cancel the edit
  7. Edit the address
  8. See that the value is empty / blank / not filled with the proper value

Investigation:

This happens because the form is seeded with initialValues, including an empty region.
When the edit dialog is opened, the form gets reset to its initial state and then the target address is filled in.
When the Region component in the form sees that the country value has changed, its useEffect fires and resets itself back to its initial value, which is empty.

Note that his happens with any country that doesn't populate the region dropdown, not just UK.
In fact, you can repeat the bug just by repeatedly editing an address in a country without a region dropdown.


Solution:

The solution was actually fixing a bug in the Dialog component so that it would properly destroy the form when shouldUnmountOnHide was true. Now that Dialog properly unmounts the form we can use initialValues instead of formApi.setValues to set the edit form values. This avoids the "field got reset to an empty initial state" bug described above.

@supernova-at
Copy link
Contributor Author

Other places that use shouldUnmountOnHide:

  1. Checkout Page > Edit Payment Information
  2. Wishlist Page > Confirm Remove Product

I should note that animation in on the dialog still works but the animation out appears instant. We can open a separate ticket for that if we'd like.

Copy link
Contributor

@tjwiebell tjwiebell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tiny bug with add address flow. I'll also look into a solution to retaining the animation, it is a bit jarring.

Comment on lines 73 to 75
const [formInitialValues, setFormInitialValues] = useState({
country_code: 'US'
});
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You may not need a duplicate piece of state here; pass activeEditAddress as initialValues and update handleAddAddress to pass this default value when it calls setActiveEditAddress, eg. setActiveEditAddress({ country_code: 'US' });.

Regardless of this duplication, I think there is a bug here where initialValues is not being set correctly on add, and the previous edited address is being displayed. Either go with my proposal above, or add setFormInitialValues({ country_code: 'US' }); to that handler if there's a necessity to have two copies of this state.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Dang, you're totally right - great catch

@tjwiebell
Copy link
Contributor

@supernova-at - I did work out an onTransitionEnd solution, but every transition inside of the Dialog bubbles up to this handler, so I can see it becoming fragile unless we add some target/ref validation. Definitely understand @jimbo's concerns with this approach a little better now.

const [readyToUnmount, setReadyToUnmount] = useState(true);
// handles onTransitionEnd prop on element - fires both ways (open/close)
const handleTransitionEnd = useCallback(e => {
    if (e.propertyName === 'opacity') {
        setReadyToUnmount(current => !current);
    }
}, []);

Copy link
Contributor

@tjwiebell tjwiebell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixes look good, nice work 👍 I do believe we should solve the animation breakage before we release, so please get that in the backlog.

@dpatil-magento
Copy link
Contributor

@supernova-at Just a minor observation >> When user uncheck Make this my default address checkbox > Address card is moved to second position, which is not needed I believe. Rest all looks good.

@dpatil-magento dpatil-magento merged commit 60a069a into develop Dec 10, 2020
@dpatil-magento dpatil-magento deleted the supernova/634_add_edit_addressbook branch December 10, 2020 17:20
@dpatil-magento dpatil-magento restored the supernova/634_add_edit_addressbook branch December 10, 2020 17:20
revanth0212 added a commit to revanth0212/pwa-studio that referenced this pull request Feb 9, 2021
* [PWA-893] My Account: Order History - Remove @client directive (magento#2786)

* Remove client directive and work through errors from using live data

* Fixup region display so its not rendering ids

* Fix payment method display and remove extra comma in addresses

* Additional tweaks from UX feedback

* Fixup failing tests

* Fix couple tests failing after gql move

* Fix bug where tracking information doesn't exist for shipped order

* Updated Intl FormattedMessage component mock. (magento#2792)

* Updated FormattedMessage component mock.

* div -> mock-FormattedMessage

* div -> mock-FormattedMessage

* Resetting price mock.

* Price component snap rollback.

* - Adjust item grid based on UX feedback
- Add context for providing product url suffix that is missing from graphql response

* Fixup failing tests

* Address PR feedback

* Cover new context with tests

* Address QA feedback

* Fixup tests and hide incomplete features

* Address additional edges found in QA

* Dependently render discount row

* Update snaps with new mock

* Allow empty string as quantity value to support backspace

Co-authored-by: Revanth Kumar Annavarapu <[email protected]>

* fix: Service Worker caching for home page routes w/ store code (magento#2856)

* Fix regex for html file type. Previous regex matched incorrect

* Use available store views in SW home route check

Signed-off-by: sirugh <[email protected]>

* Update tests

Signed-off-by: sirugh <[email protected]>

Co-authored-by: Devagouda <[email protected]>

* issue-2743-function-retreiveAvailableShippingMethods-spelling-change- changed the function name in both the occurences (magento#2807)

Co-authored-by: Stephen <[email protected]>

* Update index.md (magento#2865)

Co-authored-by: Stephen <[email protected]>

* [docs]: Add info about RAIL model (magento#2761)

* Update index.md

* Update pwa-devdocs/src/technologies/overview/index.md

Co-authored-by: Stephen <[email protected]>

Co-authored-by: Stephen <[email protected]>
Co-authored-by: James Calcaben <[email protected]>

* [Doc] extensibility framework overview (magento#2863)

* Add TOC entry

* Add new topic file and outline

* Add how it works section

* Add interceptor pattern section and image

* Add content for Targets section

* Add content for Intercept files

* Finish Declare file content

* Add content for Targets in PWA Studio packages

* Add list of extension examples

* Add extensibility overview diagram

* Apply suggestions from code review

Co-authored-by: Andy Terranova <[email protected]>

* Fix links

* Fix linting issues

* Add example intercept file content

Co-authored-by: Andy Terranova <[email protected]>
Co-authored-by: Devagouda <[email protected]>

* [feature]: Display "no payment method available" message if no allowed or configured payment methods are present (magento#2855)

* Filtered payment method radios.

Filtered payment method radios array because it was coming like [undefined, undefined]

* Showing "No Payment method available." message

Showing "No Payment method available." message when there are no supported payment methods available.

* Created class to add padding to no payment method message

Created class to add padding to no payment method message

* Fixed formatting using prettier

* Formatted with prettier

* Fixed typo suggested by @sirugh

* Added plain string to i18n

* Added string to translations

* Fixed Typo

* Fixed typo

* Update packages/venia-ui/lib/components/CheckoutPage/PaymentInformation/paymentMethods.js

Co-authored-by: Stephen <[email protected]>

* Update packages/venia-ui/i18n/en_US.json

Co-authored-by: Stephen <[email protected]>

* Fixed suggested changes given by sirugh

* Added missing dep react-intl

* Updated error messages and added global error color to it.

* Added error test.

Co-authored-by: Stephen <[email protected]>
Co-authored-by: Devagouda <[email protected]>
Co-authored-by: Revanth Kumar <[email protected]>

* [PWA-633] My Account: Address Book: Main View (magento#2857)

* Stub out address card functionality based on new mocks

* - Address some missed AC and hide dead links
- Cover changes in tests

* Update snaps and cleanup

* - Sort addresses so default comes first
- Add full page loading indicator on cold cache render
- Add phone number
- Add full country name display

* Use country data from backend until DisplayNames is more widely supported

Co-authored-by: Devagouda <[email protected]>

* Move product detail GraphQl fields to fragment (magento#2868)

* move product detail graphql fields to fragment

* move gql from venia-ui to peregrine

* update test case

* Use ApolloClient for MagentoRoute (magento#2859)

* Use Apollo for MagentoRoute

* Move queries to the talon

* Adjust category page loading

* Refactor to avoid repeat calls

* Fixup

* Remove getRouteComponent

* Start tests

* Rewrite unit tests

* Lift state up to context

* @brendanfalkowski

* Remove old query

* Inline response objects

* Update snapshots

* Update category snapshots

Co-authored-by: Devagouda <[email protected]>

* Fix apiBase URL in resolveUnknownRoute.js (magento#2877)

* Fix apiBase URL in resolveUnknownRoute.js

Fix URL used by `resolveUnknownRoute.js` so it takes `apiBase` into account when constructing URL to GraphQL server

* Add test for store base

Signed-off-by: sirugh <[email protected]>

Co-authored-by: sirugh <[email protected]>
Co-authored-by: Devagouda <[email protected]>

* Use async version of act() (magento#2880)

* Added feature to pick from multiple sample backends. (magento#2853)

* Initial work

* Added magento backend validation.

* Updated intercept to fetch backends.

* Fetching sample backends while creating a pwa app.

* Minor.

* Added try catches.

* Updated docs.

* Minor.

* Added node-fetch peer dep.

* Minor pretty print stuff.

* Added lodash and node-fetch deps.

* Updated extension desc.

* Updated tests.

* Minor.

* Updated remaining tests.

* Added runEnvValidators.js tests.

* Fixed linter issues.

* Minor.

* Added intercept tests.

* Using debug instead of console.error.

* Moving backend related code to run after configureWebpack.

* Updated the skipped test.

* Update ENV error reporting message.

* Minor.

* Minor.

* Updated error snapshot test.

* Minor.

* Minor.

* Added or condition for path variable in tests.

* Minor.

* Updated tests to use snapshots.

* Mock everything, lets get this working.

* Removed unecessary mocks.

* Updated tests.

* Using try catch to avoid prj creations.

* Reporting different message if otherBackends is empty.

* Updated tests.

* Prettier fix.

* Added console warning for production deployment.

* Updated production launch checklist docs.

Co-authored-by: Devagouda <[email protected]>

* [PWA-1128] fix(buildpack): Stop apicache from overriding good cache headers. (magento#2870)

* fix(buildpack): Stop apicache from overriding good cache headers. Fixes PWA-1128.

* fix(venia-ui): add cache headers to upward.yml staticFromRoot resolver

* fix: add simple max-age behavior to upward DirectoryResolver

Co-authored-by: Devagouda <[email protected]>

* magento/magento2-page-builder/magento#637: Form field/field group viewport scope (magento#2881)

- collect only desktop styles

Co-authored-by: Devagouda <[email protected]>

* [doc] update cloud deployment topic (magento#2871)

* Add new sections in the beginning

* Revise steps and adding required extensions step

* Add section about setting environment variables

* Remove optional and unneeded steps

* Add build, commit, and deploy sections

* Add more details on finding the correct UPWARD path value

* Update based on feedback

* Minor content update

* Changes based on review feedback

* Clarify env variables section

* Minor fixes

Co-authored-by: Devagouda <[email protected]>

* Handle array of paths as route pattern (magento#2893)

* Handle array of paths as route pattern

* JSON.parse route pattern when applying to Route path prop

* Add tests to makeRoutesTarget

* Fix missing projectConfig in create-custom-origin (magento#2897)

* Fix missing projectConfig in create-custom-origin

* Update examples in docs

Co-authored-by: Devagouda <[email protected]>

* Improve RootComponents talons test coverage (magento#2896)

* Refactor useCategory tests

* Refactor useCategory test file

* Add test to useCategory.spec.js

* Add location search filter test to useCategory.spec.js

* Add test for error on useCategory.spec.js

* Finish test coverage for useCategory

* Write tests for useNoProductsFound() talon

* Add tests for useCategoryContent() talon

Co-authored-by: Devagouda <[email protected]>

* Address Book - Add & Edit (magento#2879)

* Initial layout of add / edit form

* Adds unit tests

* Adding address full flow. Stubs out edit address.

* Country field to use country_code

* Properly formats FormErrors

* Absolute imports

* Seeds and sets the form properly

* Implements edit flow end to end

* Disable dialog buttons while saving

* Updates unit tests and snapshots

* Implements default address checkbox

* Smoothing out edges around default addresses

* Attempt to fix broken test

* Determinant sorting for default addresses

* Update packages/venia-ui/lib/components/AddressBookPage/addressBookPage.js

Co-authored-by: Jimmy Sanford <[email protected]>

* Remove auto-defaulting of addresses

* Remove query result fields from add mutation

* Adds query result fields to upadte mutation

* Adds AddEditDialog classes to propTypes

* Simplify passing parameter to edit callback function

* Adds address fragments

* Wait for refetchQueries to complete before finishing mutation

* Waits for refetchQueries before closing dialog. Renames props.

* Updates unit tests based on prop rename

* Binds edit address function at creation time

* Updates unit tests

* Adds middle name to AddressCard display

* Dialog to properly unmount on hide

* Updates unit tests

* Fixes new address bug

* Simplifies seeding the form in useAddressBookPage talon

* Adds JSDocs

Co-authored-by: Jimmy Sanford <[email protected]>
Co-authored-by: Devagouda <[email protected]>

* [feature] Use root category id from gql (magento#2902)

* Use storeConfig query to obtain root category id instead of hardcoding.

* Update tests

* Lint

Signed-off-by: sirugh <[email protected]>

* Set the root category once it resolves

Signed-off-by: sirugh <[email protected]>

* prettier

Signed-off-by: sirugh <[email protected]>

* Query for root category id for fallback on cms

* Protect against null id

* fix tests

Signed-off-by: sirugh <[email protected]>

* Use id in storeConfig query

Signed-off-by: sirugh <[email protected]>

* magento#2797. Re-factor Edit Product to use Dialog (magento#2824)

* Re-factor Edit Product to use Dialog (magento#2797)

* Re-factor Edit Product to use Dialog - CR fixes

* Fixed QTY update on cart editing

Co-authored-by: Devagouda <[email protected]>

* [PWA-458] Checkout - Sign In View (magento#2889)

* Remove sign-in link from CartPage

* Apply new style and positioning to sign in container

* - Implement view switcher similar to how the account menu works
- Tweak some styles in mobile view

* - Order imports consistently
- Add/remove changes to language file

* - Reset view state when you return to checkout
- Add heading to Create Account form
- Made cancel buttons low priority per UX guidance
- Fixed button layout of Create Account form so it uses rows on mobile
- Move SignIn container above Guest Checkout header on mobile

* Update existing tests

* Cover new component with tests

* Add propTypes to new component

* Make callback optional and remove noop function prop

Co-authored-by: Devagouda <[email protected]>

* Allow self signed certs for backend validation and only attach to scaffold sample (magento#2891)

* Allow self signed certs for backend validation

Signed-off-by: sirugh <[email protected]>

* remove log

Signed-off-by: sirugh <[email protected]>

* Only copy the extension to scaffolded apps

Signed-off-by: sirugh <[email protected]>

* Only include sample backend validator if scaffold selection is sample

Signed-off-by: sirugh <[email protected]>

* Add lodash as dependency to venia-concept

Signed-off-by: sirugh <[email protected]>

* update lockfile

Signed-off-by: sirugh <[email protected]>

* Make createProjectFromVenia async

Signed-off-by: sirugh <[email protected]>

* Update test

Signed-off-by: sirugh <[email protected]>

Co-authored-by: Devagouda <[email protected]>

* Wait to render confirmation until details return (magento#2850)

* Add Adobe client data layer (magento#2852)

* Add Adobe client data layer

* Clean up

* Update package description

Co-authored-by: deloreyj <[email protected]>

* Move definition to the effect

* Don't parse acdl minified code

* Include react as peerDep

* Bump peregrine peerdep to a caret

* Revert eb59d1c

Revert to tilde. Release script doesn't handle carets well, and this isn't significant.

Co-authored-by: deloreyj <[email protected]>
Co-authored-by: Devagouda <[email protected]>
Co-authored-by: Dev Patil <[email protected]>

* Saved payment methods main view. (magento#2882)

* Enabled saved payments link.

* Added payment skeleton.

* Moved stuff around.

* Snapshot update.

* Added other card types.

* Cleaned up some css.

* Using INTL.

* Minor.

* Minor css change.

* Changed name of payments target to checkoutPagePaymentTypes.

* Added savedPaymentTypes target.

* Updated target docs.

* Minor.

* Hide delete text in mobile view.

* Address PR feedback

* Snapshot updates.

* Updated snapshots.

* Updated tests.

* Added new tests.

* Minor

* Hiding delete button till PWA-638 comes in.

* Added new tests.

* Minor.

* Rendering no payments message.

* Clear CustomerPaymentTokens on signout.

* Rendering fullpageindicator when data is loading.

* Snapshot update.

* Removing unnecessary piece of code.

Co-authored-by: Tommy Wiebell <[email protected]>
Co-authored-by: Devagouda <[email protected]>

* [Doc] Refactor tutorials section (magento#2907)

* Archive css modules topic in tutorials

* Archived Using Component Props topic

* Archive Manage State topic

* Archive Work with GraphQL topic

* Remove links to archived pages in overview topic

* Archive Hello UPWARD tutorials

* Various updates

* Add Next Steps to project structure

Co-authored-by: Devagouda <[email protected]>

* Add props to nav query to render root category links (magento#2911)

Signed-off-by: sirugh <[email protected]>

Co-authored-by: Devagouda <[email protected]>

* Relative import for local custom loader (magento#2912)

Signed-off-by: sirugh <[email protected]>

Co-authored-by: Devagouda <[email protected]>

* Delete Address from Address Book (magento#2888)

* Initial delete implementation

* * Binds delete function
* Waits to dismiss overlay
* Cancel button is low priority styled

* * Stabilizes sorting
* Consistent spacing between confirm buttons
* Updates unit tests and snapshots

* Fixes confirmation button spacing for mobile

* Remove max-width on confirmation buttons

* Responsive delete confirm buttons

* Updates unit tests to include new output properties

* Address UX feedback

* Added addressCard tests.

* Added addressBookPage tests.

Co-authored-by: Revanth Kumar <[email protected]>
Co-authored-by: Devagouda <[email protected]>

* Hide links (magento#2918)

* v9.0.0-alpha.1

* v9.0.0-alpha.2

* Order History Page Search (magento#2916)

* Initial work.

* Lil better with loading states.

* Using debounce to fetch order number.

* Re arranging useEffects.

* Updated CSS.

* Order search useEffect logic change.

* Using onCompleted instead.

* Final touchups.

* Minor.

* Addressed UX review.

* Using submit button to search for orders.

* Minor.

* Minor.

* Added orderHistoryPage tests.

* Using fragments.

* Using fuzzy search.

* Added useOrderHistory tests.

* Using single query for order and orders data.

* Fetch all orders if search text is empty.

* Allowing button submit even if the search field is empty to fetch all orders.

* Test update.

* [PWA-887] My Account: Order History - Pagination (magento#2928)

* Working PoC of moving form context to just wrap search inputs

* Add simple pagination logic

* - Fix rendering of reset button
- Add Load More button and wire up to orders query

* Increase page size to UX requirement and remove unnecessary currentPage argument

* Add page info label to top of page

* Cover changes with tests

* - Use token for font size
- Make callback optional and document

* [fix] offline cached search and category pages (magento#2929)

* Moves getPageSize query to talon default operation

Signed-off-by: sirugh <[email protected]>

* Only show search page error if there is no data.

Signed-off-by: sirugh <[email protected]>

* Only render errors when error AND no data

Signed-off-by: sirugh <[email protected]>

* Update tests

Signed-off-by: sirugh <[email protected]>

* Make sure we only do the page reset if there is no data

Signed-off-by: sirugh <[email protected]>

* Test page setting effect

Signed-off-by: sirugh <[email protected]>

Co-authored-by: Devagouda <[email protected]>

* v9.0.0-beta.1

* [doc] release notes 9.0.0 (magento#2935)

* Clear out old 8.0.0 content

* Add link references

* Add page 1 PR entries

* Add page 2 entries

* Add page 3 entries

* Add page 4 and 5 entries

* Add details to highlights

* Update compatibility table

* Update highlight and known issue

* Update Top Community Contributors

* Update content based on feedback

* Fix capitalization

* Add missing entries

Co-authored-by: Devagouda <[email protected]>

* Bump hastily dependency (magento#2963)

* v9.0.0-beta.2

* v9.0.0-rc.1

* Add known issue about watcher running out of memory (magento#2977)

* Add known issue about watcher running out of memory

* Add link

* Update note about watcher duration

* v9.0.0

* Remove lodash from create-pwa

* Fix bug

* Extend fix to venia-concept

* Using map instead of set.

Co-authored-by: Tommy Wiebell <[email protected]>
Co-authored-by: Stephen <[email protected]>
Co-authored-by: Devagouda <[email protected]>
Co-authored-by: Sathiya Prakash <[email protected]>
Co-authored-by: Hiren Patel <[email protected]>
Co-authored-by: Abrar Pathan <[email protected]>
Co-authored-by: James Calcaben <[email protected]>
Co-authored-by: Andy Terranova <[email protected]>
Co-authored-by: Ankur Raiyani <[email protected]>
Co-authored-by: Huy Kon <[email protected]>
Co-authored-by: Jimmy Sanford <[email protected]>
Co-authored-by: Sergey Kolodyazhnyy <[email protected]>
Co-authored-by: sirugh <[email protected]>
Co-authored-by: James Zetlen <[email protected]>
Co-authored-by: Oleksandr Miroshnichenko <[email protected]>
Co-authored-by: Papilion Dániel <[email protected]>
Co-authored-by: Kristof, Fooman <[email protected]>
Co-authored-by: Marcin Kwiatkowski <[email protected]>
Co-authored-by: deloreyj <[email protected]>
Co-authored-by: Dev Patil <[email protected]>
Co-authored-by: devops-pwa-codebuild <[email protected]>
@sirugh sirugh deleted the supernova/634_add_edit_addressbook branch April 26, 2021 21:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pkg:peregrine pkg:venia-ui Progress: done version: Minor This changeset includes functionality added in a backwards compatible manner.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants