Allow variation to be changed after registration

Created on 3 August 2023, over 1 year ago

Problem/Motivation

I have 2 variations for each event: online and in-person. It makes sense to have them as 2 variations, linked to 2 registration types, because they need different fields.

Unfortunately I can be sure that soon enough some user is going to want to change their mind about which variation they want to be, after they have completed checkout and registered. This seems like a pretty common requirement.

Proposed resolution

Phase 0: What works already
The good news is that we can set the existing registration on a new order item, and the registration checkout panes look like they will behave reasonably well; for example, RegistrationProcess won't create a new registration if one is already set on the order item.

Phase 1: Changing the registration type
In the RegistrationInformation pane's getItemRegistration() method we need to change it so that if the existing registration on the current order item is referenced from another (old) order item with a different purchased entity that references a different registration type, then we clone the existing registration as a new registration of the appropiate registration type, copying across all fields we can.

Phase 2: UI for initiating change of type
When viewing or editing an registration, it would be good to offer a way to change the registration variation. For one's own registration, that would initiate a new order to go through the checkout with a new item referencing the existing registration as above; for someone else (i.e. for staff managing registrations) it would need to immediately create a new registration, copy fields, and delete the old registration, without initiating a checkout.

I'm not sure what the best UX would be for all this. I see 3 choices:

(1) A fancy form where you pick the variation, and then AJAX updates the registration fields available. Nice idea, but Drupal's AJAX scares me.

(2)
(a) Make the entity_id field of the registration entity configurable.
(b) Add submit logic to the registration edit form that initiates a new checkout if its your own registration, or clones the entity as a new one (and deletes old one) if the variation is changed in a way that requires the registration to be of a different registration type.
(c) Offer a "Product variations" widget for the entity_id field that allows selecting between variations of the same product.

(3)
(a) Make the entity_id field of the registration entity configurable.
(b) Provide a widget for that field that simply gives you a link takes you to a form where you choose the variation, and from there to checkout (for own registration) or clones a immediately (for staff).
The problem with this approach is that offering a link on an edit form is weird UX, clicking it leads to losing any changes you've made on the form.

(4) Add a new "Change type" button on the registration edit form that saves changes made on the form, and then takes you to the form in (3). I don't think this is good UX, as it won't be obvious to people what their current type is and why they migh want to change it.

All things considered, I think (2) is the best approach.

Phase 3: Extra payments and refunds
If you change the variation you've registered for, mayb you need to pay more, or maybe you need a refund. I'm not familiar with how best to handle this stuff in commerce and it sounds tricky.

I'm happy to work on phase 1, and phase 2, but not phase 3. I think phase 1 and 2 are good improvements on their own.

Remaining tasks

Decide on approach.
Create subissues.
Code.

User interface changes

TBD

API changes

TBD

Data model changes

TBD

✨ Feature request
Status

Active

Version

3.0

Component

Code

Created by

πŸ‡¬πŸ‡§United Kingdom jonathanshaw Stroud, UK

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

Production build 0.71.5 2024