Make link an optional ajax call not a redirect via configuration

Created on 22 July 2022, over 2 years ago
Updated 19 June 2024, 10 months ago

Problem/Motivation

This module is great and solves a huge problem in allowing us to have an Add To Cart button on a view. However if you look at the behavior and sequence of events, it introduces some problematic slowdowns and bottlenecks. Instead of a redirect, the link should add the item to the cart via ajax. The ajax_add_to_cart module provides this functionality but does not allow for a link to be added to a view. Ideally we'd be able to add items to the cart via ajax and save the overhead of the redirect. In our case, it would shave a second off the page load time to get to the cart.

Steps to reproduce

Proposed resolution

Remaining tasks

User interface changes

API changes

Data model changes

✨ Feature request
Status

Active

Version

2.0

Component

Code

Created by

πŸ‡ΊπŸ‡ΈUnited States brooke_heaton

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

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • First commit to issue fork.
  • Status changed to Needs review 10 months ago
  • πŸ‡¦πŸ‡ΊAustralia jannakha Brisbane!

    Check out MR!4
    - just add 'use-ajax' class to the link and 'Add to cart' becomes AJAX link (see readme.md in MR)

    Optional:
    add an event handler in your JS:

    $('html').on('addToCartLink.updated', (event) => {
    // process updated cart event, eg show a message "Item has been added to your cart!"
    });
    
  • Status changed to Needs work 10 months ago
  • πŸ‡¦πŸ‡ΉAustria agoradesign

    First of all, thank you very much for your MR, Jen :)

    It looks 99% good to me, especially the custom event part. One thing I'm not happy with, is the hardcoded and very opinionated CSS selector used for the counter update. eg, this would apply to none of our Commerce sites at all. Would you mind making this selector configurable + empty check for this?

  • πŸ‡¦πŸ‡ΊAustralia jannakha Brisbane!

    @agoradesign yeah, need to think about it
    I used default Commerce template's classes.

    I'll try to see if I can pass all parameters (name of product, total count, etc) to the custom event - so all alterations can be done in own JS to keep config super slim.

  • πŸ‡¦πŸ‡ΉAustria agoradesign

    oh that would be great :)

  • Status changed to Needs review 10 months ago
  • πŸ‡¦πŸ‡ΊAustralia jannakha Brisbane!

    updated custom JS event to return data:

    $('html').on('addToCartLink.updated', (event, data) => {
      // Cart has been updated, following data is available:
      // data.cart_total_count
      // data.product_title
      // data.quantity_added
      console.log(data);
    });
    

    By default commerce_cart template will be updated:

    ...
    <span class="cart-block--summary__count">{{ count_text }}</span>
    ...
    

    If template has been overwritten and classes don't exit - it will not cause an error.

  • Status changed to RTBC 8 months ago
  • πŸ‡¦πŸ‡ΊAustralia VladimirAus Brisbane, Australia

    Applies and works.
    Thank you for your commits. 🍻

  • First commit to issue fork.
  • πŸ‡¨πŸ‡­Switzerland luksak

    I needed this for wishlist links as well and updated the MR with it. It works quite well for me.

    Shouldn't we try to use a data-attribute selector for the count? The approach with the class won't work for most sites... But yeah, that'd require commerce and commerce_wishlist to change the templates. Alternatively we could make the selector configurable? Or we'd need to let users know that the functionality depends on that selector and that users should add it to their templates in case they want it to work.

    But at least the limitation of using a <span> for the count could be resolved.

    Any other takes on this?

  • πŸ‡¨πŸ‡­Switzerland luksak
  • πŸ‡―πŸ‡΄Jordan Anas_maw

    Can we show the status message printed by commerce or wishlist modules?
    When you add a product to the wishlist, there is a default message shown, I think we should just refresh the messages block.

  • πŸ‡¨πŸ‡­Switzerland luksak

    I added another MR that provides compatibility with ✨ Option to proivde remove links Active because the two MRs play nicely together. It simply updates the add to wishlist links.

    @anas_maw You can send messages using MessageCommand. It works, but I guess there must be a better way to collect and display messages in ajax command than this:

    $messages = \Drupal::messenger()->messagesByType('status');
    foreach ($messages as $message) {
      $response->addCommand(new MessageCommand($message));
    }
    \Drupal::messenger()->deleteByType('status');
    

    But as it is this just adds a message to the top of the page for me and doesn't really help the user to understand what happened.

  • πŸ‡―πŸ‡΄Jordan Anas_maw

    @luksak Thanks, I'm using 2 patches together and they are working nicely together

  • πŸ‡―πŸ‡΄Jordan Anas_maw

    @luksak please check my comment on your MR, it's changing both add to cart link and wishlist link
    here is a patch for your MR, as I can't push the fix to your MR

  • πŸ‡¦πŸ‡ΊAustralia VladimirAus Brisbane, Australia

    vladimiraus β†’ changed the visibility of the branch 3298965-3298965-compatiblity to hidden.

  • πŸ‡¦πŸ‡ΊAustralia jannakha Brisbane!

    just for future, let's not scope creep issues: add to wish list is totally independent from add to cart AJAX and could've been its own MR

    @anas_maw - can you expand on your comments on your patch? what should be done with it?
    @luksak can you please add documentation about "Add to wish list" to readme.md?

  • πŸ‡¦πŸ‡ΊAustralia jannakha Brisbane!

    created patch out of MR4 @ c3e20aa2

  • πŸ‡¦πŸ‡ΊAustralia jannakha Brisbane!

    can someone review?
    it'll be nice to get a release with this feature

  • Status changed to Needs review 2 months ago
  • πŸ‡¦πŸ‡ΊAustralia VladimirAus Brisbane, Australia

    vladimiraus β†’ changed the visibility of the branch 3298965-make-link-an to hidden.

  • πŸ‡¦πŸ‡ΊAustralia VladimirAus Brisbane, Australia

    Current branch is mix of different features with additional functionality like wish list which wasn't a requirement.
    Please fix current issue and create a new task for wish list.
    Cheers 🍻

Production build 0.71.5 2024