Skip to content

Project-7525: [DO NOT MERGE] Feature branch for the new returns flow#2667

Open
bc-vivekaggarwal wants to merge 19 commits into
masterfrom
feature/PROJECT-7525-new-returns-flow
Open

Project-7525: [DO NOT MERGE] Feature branch for the new returns flow#2667
bc-vivekaggarwal wants to merge 19 commits into
masterfrom
feature/PROJECT-7525-new-returns-flow

Conversation

@bc-vivekaggarwal

@bc-vivekaggarwal bc-vivekaggarwal commented May 27, 2026

Copy link
Copy Markdown

What?

This PR is for a feature branch to park all reviewed changes related to the new returns flow PROJECT-7525

Requirements

  • CHANGELOG.md entry added (required for code changes only)

Tickets / Documentation

PROJECT-7525

Screenshots (if appropriate)

Not applicable: They are part of individual PRs

Testing

TBD


Note

Medium Risk
Touches customer order/return flows and introduces incomplete paths (no GQL submit, return-details not registered, placeholder detail links); behavior depends on new returns_v2_enabled settings.

Overview
This feature branch lands the returns v2 storefront UI behind settings.returns_v2_enabled, with settings.returns_enabled as a fallback for legacy return entry points on order details and the orders list.

New surfaces: a create_return page (templates/pages/create-return.html) with line-item qty/resolution/reason controls, client-side submit validation, and buildReturnInput() prepared for a future Storefront GQL createReturn call (submit is still a no-op). A returns list v2 partial shows RMA, OPEN/IN_PROGRESS/CLOSED badges, and summary fields when v2 is on. Return details and guest return portal templates exist (details JS uses mock data; neither is fully routed in app.js yet). create_return is wired in app.js; legacy account_new_return still uses the account bundle.

Supporting changes: SCSS for create-return and return-details, account list status badge styling, expanded lang/en.json copy, and small a11y fixes on the legacy add-return table.

Reviewed by Cursor Bugbot for commit a12175b. Bugbot is set up for automated code reviews on this repo. Configure here.

jpajar and others added 4 commits May 26, 2026 15:30
…2653)

* feat(returns): ORDERS-7704 condition for new returns on orders page

* feat(returns): ORDERS-7704 condition for new returns on orders page - confirmed
feat(orders): ORDERS-7706 add new return page layout
@bc-vivekaggarwal bc-vivekaggarwal requested a review from a team as a code owner May 27, 2026 00:42
@denis-bc denis-bc requested a review from Copilot May 27, 2026 00:50
@BC-SEven BC-SEven changed the title Project-7525: Feature branch for the new returns flow Project-7525: [DO NOT MERGE] Feature branch for the new returns flow May 27, 2026
@denis-bc denis-bc requested review from Copilot and removed request for Copilot May 27, 2026 03:33
…context (#2665)

* feat(returns): ORDERS-7708 new-return page — render items from order context, stepper qty controls, responsive layout, gate behind returns_v2_enabled flag

* feat(returns): ORDERS-7708 new-return page - review feedback

Copilot AI left a comment

Copy link
Copy Markdown

Choose a reason for hiding this comment

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

Pull request overview

This PR parks initial Cornerstone theme changes for PROJECT-7525’s “new returns flow”, adding new templates/assets for a redesigned return-request experience and gating existing “Return” affordances on a new settings.returns_v2_enabled flag (with fallback to settings.returns_enabled).

Changes:

  • Add new return-related templates: a guest return portal page and a new account “add return” page layout.
  • Add new styling and a new page manager (AddReturnNew) plus bundle wiring for the new return-request UI.
  • Gate “Return” entry points in order details and orders list on returns settings; update CHANGELOG.md.

Reviewed changes

Copilot reviewed 10 out of 10 changed files in this pull request and generated 5 comments.

Show a summary per file
File Description
templates/pages/guest-return-portal.html New guest-facing return portal page scaffold.
templates/pages/account/orders/details.html Gate “Return” button using returns_v2_enabled OR returns_enabled.
templates/pages/account/add-return-new.html New account return-request page markup for the redesigned flow.
templates/components/account/orders-list.html Gate “Return Items” link using returns_v2_enabled OR returns_enabled.
CHANGELOG.md Add draft entries for the new return pages / gating changes.
assets/scss/components/stencil/addReturn/_addReturn.scss Add styling for the new return-request page (.newReturn).
assets/js/theme/add-return-new.js New page manager that renders the new return UI (currently with placeholder data).
assets/js/app.js Wire account_new_return page type to load the new return page manager.
Comments suppressed due to low confidence (3)

assets/js/theme/add-return-new.js:96

  • Date formatting is hardcoded to the en-AU locale. This will display incorrect date formats for stores with different locales; use store locale from Stencil context (e.g. this.context.storeLocale) or omit the locale to allow the browser/store locale to drive formatting.
            // TODO ORDERS-7715: invoke createReturn Storefront GQL mutation.
        });
    }
}

assets/js/theme/add-return-new.js:142

  • Currency formatting is hardcoded to en-AU and always uses item.totalIncTax even though order.isTaxInclusive is available. This will display incorrect amounts/formatting for non-AU stores and for tax-exclusive display settings. Use a locale from context and choose totalIncTax vs totalExTax based on order.isTaxInclusive (or use server-provided formatted totals if available).
    assets/js/theme/add-return-new.js:239
  • console.log('Submitting return', ...) should not ship in theme code. Either remove it or gate it behind an explicit debug flag, and replace with the real API call / proper error handling when wiring this up.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread assets/js/app.js
Comment on lines 12 to 16
account_order: getAccount,
account_addressbook: getAccount,
shippingaddressform: getAccount,
account_new_return: getAccount,
account_new_return: getAddReturnNew,
'add-wishlist': () => import('./theme/wishlist'),
Comment on lines +3 to +6
{{> components/common/breadcrumbs breadcrumbs=breadcrumbs}}

<h1> Guest Return Portal</h1>

Comment on lines +10 to +16
</div>
<div class="newReturn-headerActions">
<a href="{{../urls.account.orders.all}}" class="newReturn-btnBack">{{lang 'account.orders.return.back_button'}}</a>
<a href="/return-policy" class="newReturn-btnPolicy">View return policy &rarr;</a>
</div>
</div>
{{#if date}}<p class="newReturn-orderDate">{{date}}</p>{{/if}}
Comment thread assets/js/theme/add-return-new.js Outdated
Comment on lines +9 to +20
this.bindSubmit($form);
}

bindOrderLineItemEvents() {
document.querySelectorAll('.newReturn-stepperBtn').forEach(button => {
button.addEventListener('click', () => {
// Derive itemId from the parent row — buttons do not carry data-item-id,
// so the [data-item-id] selector stays scoped to the row container only.
const row = button.closest('.newReturn-orderLineItem');
const itemId = row?.dataset?.itemId;
if (!itemId) return;
const action = button.getAttribute('data-action');
Comment thread CHANGELOG.md
- Fix duplicate `id="default_instrument"` on Update Payment Method page [#2661](https://github.com/bigcommerce/cornerstone/pull/2661)
- Respect `available_to_sell` on PDP so the Sold Out alert is hidden and the Add to Cart button stays enabled for backorderable products, and is disabled when quantity exceeds `available_to_sell` [#2659](https://github.com/bigcommerce/cornerstone/pull/2659)
- Updated accessibility features [2656](https://github.com/bigcommerce/cornerstone/pull/2656)
- Adds new guest-return-portal page. [2645](https://github.com/bigcommerce/cornerstone/pull/2645)
@denis-bc

Copy link
Copy Markdown

cursor review

Comment thread assets/js/app.js Outdated
feat(returns): ORDERS-7717 - add new returns list ui
Comment thread assets/js/theme/add-return-new.js Outdated

@cursor cursor Bot left a comment

Copy link
Copy Markdown

Choose a reason for hiding this comment

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

Cursor Bugbot has reviewed your changes and found 1 potential issue.

There are 3 total unresolved issues (including 2 from previous reviews).

Fix All in Cursor

❌ Bugbot Autofix is OFF. To automatically fix reported issues with cloud agents, have a team admin enable autofix in the Cursor dashboard.

Reviewed by Cursor Bugbot for commit 6ebc73c. Configure here.

Comment thread templates/pages/account/add-return.html Outdated
* feat(returns): ORDERS-7764 render create return page with stencil context

* feat(returns): ORDERS-7764 render create return page with stencil context

* feat(returns): ORDERS-7764 render create return page with stencil context

* feat(returns): ORDERS-7764 render create return page with stencil context

* feat(returns): ORDERS-7764 fix code review comments

* feat(returns): ORDERS-7764 fix code review comments

* feat(returns): ORDERS-7764 fix design feedback

* feat(returns): ORDERS-7764 fix design feedback
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

7 participants