How to Setup Multiple Wishlist Magento 2 Functionality?

How to Setup Multiple Wishlist Magento 2 Functionality?

Experiencing customer confusion due to Magento 2's single wishlist limitation?

Multiple wishlist Magento 2 enhances user experience via better organization. The feature allows customers to save products into distinct lists.

This article explains Magento 2 multiple wishlist features, setup, and potential conflicts.

Best Magento Hosting now

Key Takeaways

  • Multiple Wishlist features extend standard Magento 2 wishlist saving capabilities.

  • Customers create separate named lists for better product organization needs.

  • Extensions alter core Magento code, databases, controllers, plus frontend templates.

  • Conflicts often happen between extensions, themes, JavaScript, and Magento upgrades.

  • Installation involves file placement, running setup commands, plus specific configuration.

  • Compare different vendor extensions based on features, API support, and pricing.

What is "Multiple Wishlist Magento 2"?

Description of Multiple Wishlist Magento 2

Magento 2 offers one default wishlist for saving customers' products. Multiple Wishlist features offer more ways to save desired products.

Shoppers create several separate lists instead of using only one. Organize saved items into lists with names of your choice. It helps with organizing shopping for holidays or personal project ideas. Managing saved products becomes much easier with various list categories.

Customers control saved items within various personal-themed product lists. Clear lists help people remember items for future planned purchases. This improved organization helps them find saved products much faster. A smooth wishlist experience encourages enjoyable return visits to stores.

Special store enhancements enable this powerful wishlist management feature. Shoppers gain excellent control over planning their future online buys. Finding wanted products becomes simple and efficient with these tools.

Core Functionality of Magento 2 Multiple Wishlists Explained

1. Fundamental Magento Model Modifications

  • Developers introduce new database tables like customer_wishlist_entity for list storage. This table holds list identifiers, customer links, and custom names.

  • The core wishlist_item table receives modifications for proper item linking. A new foreign key column connects items to specific lists.

  • This foreign key supplements or replaces default customer-wishlist relationships. Some methods reuse the core table, adding list name columns.

  • New PHP classes handle interactions with these altered database structures. Models, resource models, and collections help with data operations using code.

2. Controller Logic Extension

  • The standard Magento\Wishlist\Controller\Index\Add controller needs significant modification code. It determines the target wishlist for new product items.

  • Frontend interfaces like dropdowns or modals ease list selection actions. Users select existing lists or create new ones during additions.

  • Plugins or preferences intercept core logic, saving items as intended. They confirm that wishlist_item records link to the chosen wishlist_entity_id value.

  • The main Magento\Wishlist\Controller\Index\Index view action changes display logic. It shows all customer lists and allows list-switching actions.

  • Developers add new controller actions for list management functions. These include creating, renaming, deleting lists, and moving list items.

3. Block and Template Updates

Block and Template Updates of Magento 2 Multiple Wishlist

  • Product page templates integrate new "Add to Wishlist" user interactions. It includes dropdowns or buttons for selecting the target list.

  • The main magento_wishlist/view.phtml template undergoes significant structural template changes. It displays multiple lists, items, and management user interface options.

  • Customer account sections often receive new templates for list management. It provides a dedicated interface separate from the main view.

  • JavaScript handles dynamic frontend interactions for a smooth experience. AJAX requests manage list creation and item moving without page reloads.

4. Layout XML Configuration

  • New layout XML handles define page structures for added controllers. These handle link controller actions for specific blocks and template rendering.

  • Existing layout handles like wishlist_index_index receive necessary update instructions. Updates replace core blocks or add new blocks for management.

  • Layout XML orchestrates the arrangement of blocks on various pages. It controls which PHP block classes manage data and rendering.

5. API Layer Extension

  • Developers extend Magento's REST and SOAP APIs for external integrations. It supports headless architectures or connections with other system software.

  • Extended APIs expose CRUD operations for wishlists and their items. External applications manage multiple wishlists through these defined API endpoints.

  • API extensions allow reading, creating, updating, and deleting wishlist data via programming. It enables broader system integration possibilities for enhanced functionality.

Potential Conflicts Associated With Magento 2 Multiple Wishlists

1. Template File Conflicts

  • Themes and extensions alter wishlist-related page templates. Both may alter the main wishlist page, product page buttons, or header elements.

  • Theme structure changes can break extension JavaScript. Extensions rely on specific HTML elements for proper frontend function.

  • The "Add to Wishlist" button receives complex modifications. Extensions replace the simple button with dropdown menus or modals.

  • Themes that restyle this button can create visual or functional conflicts. For example, the theme and extension JavaScript might handle the same click event.

  • Magento uses a fallback system for template files. In this process, themes prevail over modules. Extensions use layout XML for unique template names.

2. Layout XML Conflicts

  • Layout XML files define page block structure and order. Themes and extensions use layout XML to arrange content on storefront pages.

  • Extensions might replace core wishlist blocks for custom display options. Themes referencing these removed blocks cause errors.

  • Conflicting block names between theme and extension create issues. Magento renders only one block with duplicate names.

  • Arguments set within layout XML create unpredictable outcomes. Themes and extensions might set different values for the same arguments.

3. JavaScript Conflicts

  • Extensions and themes use custom JavaScript for user interface features. Wishlist extensions add JavaScript to manage lists and items.

  • Both theme and extension might handle "Add to Wishlist" clicks. One script might prevent the other from executing its intended code.

  • DOM manipulation conflicts arise from structural differences. The extension expects HTML elements the theme changes or removes.

  • AJAX requests form the basis of dynamic wishlist features. Theme scripts or other extensions can interfere with wishlist AJAX calls.

  • JavaScript library version mismatches cause issues. Extensions and themes must use compatible versions of jQuery or other libraries.

  • requirejs-config.js files define module paths and dependencies. Conflicts in these files can lead to module loading failures.

4. Controller Logic Conflicts

  • Extensions change backend logic for wishlist items and page management. Multiple extensions targeting the same core class cause errors.

  • Preferences rewrite entire controller classes, creating conflicts. If two extensions set preferences for one controller, only one applies.

  • Plugins intercept specific controller methods at different points. Multiple plugins targeting the same method need attention to order and execution.

  • around plugins pose a risk by wrapping the original method. An around plugin must call proceed() to avoid breaking functionality.

  • Plugin execution order matters; plugins run based on sortOrder values. One plugin might change data another plugin expects, leading to errors.

  • before and after plugins alter arguments and return data. Multiple plugins changing the same values cause unpredictable results.

5. Database Conflicts

  • Multiple Wishlist extensions add database tables for list management. They also alter existing tables to link wishlists with customer records.

  • Altering core tables like wishlist_item can lead to upgrade issues. Multiple extensions adding columns create naming conflicts.

  • Other extensions assume standard wishlist data structures. These assumptions are not valid with multiple wishlists; queries return incorrect data.

  • Resource models handle database interactions using PHP code. Conflicts arise when multiple extensions change the same resource model classes.

Comparing Different Magento 2 Multiple Wishlist Extensions

Feature Amasty Multiple Wishlist for Magento 2 BSS Commerce Magento 2 Multiple Wishlists Extension WeltPixel Wishlist Magento 2 - Multiple Ajax Wishlist & Share Extension ITORIS INC. Multiple Wishlists for Magento 2 MageAnts Multiple Wishlists For Magento 2
Unlimited Wishlists Yes Yes Yes Yes Yes
AJAX Functionality Yes Yes Yes Yes Yes
Sharing (Email/Social) Yes Yes Yes Yes Yes
Move/Copy Items Yes Yes Yes Yes Yes
Price Drop Alerts Yes No Yes No No
Keep Items After Add to Cart Yes Yes Yes Yes Yes
Backend Management Yes Yes Yes Yes Yes
B2B Requisition Lists Yes No No No No
REST/GraphQL API Yes Yes No No Yes
Magento Compatibility 2.0.x - 2.4.x 2.3.x - 2.4.x 2.0.x - 2.4.x 2.0.x - 2.4.x 2.3.x - 2.4.x
Pricing (Starting) $49.00 to $99.00 $89 Free / $199 $169 $89 to $100

Steps to Install and Configure Magento 2 Multiple Wishlist Extension

Prerequisites

  • Get the extension package (the ZIP file) from the [third_party_provider].

  • CRITICAL: Back up your Magento installation (files and database) before proceeding.

IMPORTANT: Turn off Merge-JS in the Magento Admin before starting the installation. Find it in Stores > Configuration > Advanced > Developer > JavaScript Settings > Merge JavaScript Files. Turn it back on after the installation and configuration are complete and tested.

Step 1: Install the Extension

Choose one installation method; Composer offers better dependency management benefits.

Method 1: Install via App/Code (Manual Upload)

  • Unzip:

    • Extract the full contents of the downloaded extension ZIP archive. It will reveal the extension's file and directory structure inside.
  • Create Directory:

    • Navigate to the app/code/ directory in Magento's root folder. Create the specific directory path for the extension provider. Use app/code/[third_party_provider]/MultiWishlist/ as the extension's destination path.

    • Find the correct path identifier within the composer.json file. Look for the "psr-4" node inside the file structure.

  • Copy Files:

    • Place all extracted extension contents into the new directory. It includes files like registration.php and folders like etc/. Make sure the entire structure copies into the specified target path.

    • Confirm that the app/code/[third_party_provider]/MultiWishlist/ directory exists in your project. If necessary, upload the folder and its contents to your server. The directory structure on the server should match the one on your project.

Method 2: Install via Composer

  • Composer Requirements:

    • Many providers recommend installing Composer. This method handles dependencies and updates better for your project.

    • Open your terminal or a command prompt application interface. Navigate your session to the Magento installation root directory.

  • Run Command:

    • Execute the specific composer command given by the [third_party_provider]. This command downloads and installs the specified extension package.

    composer require [vendor]/[module-name]

  • If the system prompts, enter your Magento Marketplace keys. Then, wait while Composer downloads and installs the required extension files.

Step 2: Run Post-Installation Commands (CLI)

Execute commands from the Magento root directory using terminal/SSH access.

  • Enable Module (Manual Install Only):

    • If you used the manual method, run the enable command. This step registers the module with your Magento application.

    php bin/magento module:enable [Third_Party_Provider]_MultiWishlist

  • The exact name is in the extension's registration.php file. Running this specific command is not required for Composer installation.

  • Run Setup Upgrade:

    • Execute the setup upgrade command using your terminal interface. It applies database changes and registers the new module.

    php bin/magento setup:upgrade

  • Deploy Static Content:

    • Run the store's static content deployment command. This process generates the necessary static view files for the front-end display.

    php bin/magento setup:static-content:deploy -f

  • Compile Code:

    • Run the dependency injection compilation command for your instance. You need this command when operating in production mode.

    php bin/magento setup:di:compile

  • Clear Cache:

    • To apply all the changes, clear the Magento system cache. It confirms that the system uses the latest code configuration.

    php bin/magento cache:clean

  • You can use cache:flush to clear all storage types.

Step 3: Configuration

Adjust the extension's settings through the Magento Admin Panel interface.

  • Navigate Configuration:

    • Go to the Stores section and select the Configuration menu. In the left menu, find the provider's section, [THIRD_PARTY_PROVIDER]. Under the provider's main configuration tab, click Multiple Wishlist.
  • Set Options:

    • Set Enable to Yes to activate the extension's storefront features. Choose No to deactivate the module's frontend output function. Select your desired behavior for the module operation setting.

    • Configure Redirect to My Wish List Page setting preference. Choose Yes to send customers to their list after adding. Choose No for customers to stay on the product page.

    • Adjust Remove Items after Adding to Cart configuration setting. Choose Yes to remove items from lists upon cart addition. Choose No to keep items in lists after cart addition.

  • Save and Clear:

    • Click the Save Config button to store your chosen settings. Clear the Magento cache again after saving configuration changes.

    php bin/magento cache:flush

Step 4: Hyvä Theme Compatibility

Follow these specific instructions if your store uses a Hyvä theme.

  • Installation Prerequisite:

    • Install the main Multiple Wishlist extension using Composer. Manual app/code installation does not work with Hyvä packages. For better compatibility, use the Composer installation method.
  • Install Compatibility Package:

    • Install the separate Hyvä compatibility package via the Composer tool. Use the specific package name the [third_party_provider] supplied you.

    composer require hyva-themes/magento2-[third_party_provider]-multiwishlist

  • Run the setup:upgrade command again after installing the package.

    php bin/magento setup:upgrade

  • Generate Hyvä Config & Build CSS:

    • Generate the Hyvä configuration files using the provided command.

    bin/magento hyva:config:generate

  • Add Tailwind Source:

    • Edit the app/etc/hyva-themes.json file within your Magento installation. Add the correct path to the compatibility package's source.

    "src": "vendor/hyva-themes/magento2-[third_party_provider]-multiwishlist/src"

    • Place this entry within the correct theme configuration section. Make sure the path exactly matches your installation file structure.
  • Navigate and Build:

    • Change your terminal directory to the active theme's location.

      • Default Hyvä: cd /path/to/magento/vendor/hyva-themes/magento2-default-theme/web/tailwind/
      • Custom theme: cd /path/to/magento/app/design/frontend/YourVendor/YourTheme/web/tailwind/
    • Run the Tailwind CSS build process using node commands.

    npm run build-prod

  • Clear Cache:

    php bin/magento cache:flush

  • Disabling/Uninstalling Hyvä Package:

    • Disable package: php bin/magento module:disable Hyva_[Third_Party_Provider]_MultiWishlist followed by commands.

    • Uninstall package: composer remove hyva-themes/magento2-[third_party_provider]-multiwishlist followed by commands.

    • Run setup:upgrade and clear cache after disabling or uninstalling.

Step 5: Functionality Overview & Testing

Verify the extension operates as intended after installation and configuration steps.

  • Adding Items:
    • Log into a customer account on the store's front-end interface. Visit any product page to test the added functionality. Then, click the standard "Add to Wish List" action icon/link.

    • A popup window appears to select or create a list. Select an existing list or type a new list name. Then, add the product to the chosen wishlist destination folder.

  • Managing Lists:
    • Navigate to the My Account section, then My Wish List. Here, you can view options for managing all your created wishlists. You can also create new wishlists using the provided input field and button.

    • You can view items inside each list using tabs or list names. You can also rename your existing wishlists using the provided editing options. You can delete all wishlists, so you no longer need to use controls.

  • Managing Items:
    • Select a specific wishlist to view its contained product items. Hover over product images or areas to show item options. Options appear for editing, commenting, changing quantity, and adding.

    • Add the item to the main shopping cart using controls. Remove the item from the current displayed wishlist. Copy or Move items between your different wishlists.

Step 6: API Support (GraphQL / REST)

  • The extension provides API endpoints for headless or integration use. Check the [third_party_provider]'s detailed documentation for endpoint specifics. Use APIs for querying, adding, updating, or removing list items.

  • APIs also support creating, renaming, or deleting the wishlists. Integrate these functions into your custom applications or third-party systems. Refer to the documentation for the exact API usage guidelines provided.

Step 7: Extension Troubleshooting & Support

  • If the extension functions flawed, review the installation steps. Make sure all commands execute without any reported system errors. Check the Magento log files (var/log/) for related error messages.

  • Verify that your Magento installation has the correct file permissions. Disable other third-party modules on a staging site on a temporary basis. It will help you identify potential extension conflicts that are causing problems.

  • Contact the [third_party_provider]'s support team for unresolved issues. Provide your Magento version, theme details, and steps taken. Include any relevant error messages from system log files.

FAQs

1. What are Magento 2 Multiple Wishlists?

Multiple Wishlists improve default Magento saving features for online shoppers. They allow shoppers to create several distinct product-saving lists. Customers organize desired items into named lists for better purchase planning. It improves user experience over the standard single wishlist feature.

2. How do extensions add this functionality?

Extensions change core Magento code plus database structures for implementation. They add new tables to store individual customer list information. Existing tables get changes linking items to specific customer wishlists. Controller logic, blocks, and templates receive the necessary code modifications.

3. Can multiple wishlists cause conflicts?

Yes, conflicts happen with themes or other third-party Magento extensions. Template overrides clash, breaking frontend layouts or expected user functions. JavaScript from different sources interferes with the expected user behavior. Controller logic changes conflict when multiple modules alter similar code.

4. Do themes affect multiple wishlists?

Themes change core wishlist templates, causing major Magento store conflicts. Structural template changes break extension JavaScript functionality for user interaction. Button styling or placement changes also create user interface presentation issues. Always test extensions with your specific theme installed first.

5. Is API support available for wishlists?

Some extensions offer REST or GraphQL API support feature sets. These allow developers to manage multiple wishlists through various external system applications. Developers integrate wishlist functions into headless setups using these provided APIs. Check specific extension documentation for available API endpoint details.

6. How do I install these extensions?

Install extensions using Composer or manual file upload methods. Composer installation handles Magento dependencies better for most hosting environments. After completing the extension installation, run setup commands like setup:upgrade. Clear the Magento cache to confirm all changes apply to the system.

CTA

Summary

Multiple Wishlist Magento 2 extensions improve customer product-saving capabilities online. They allow the creation of several lists instead of one default customer list. Correct installation and configuration prevent conflicts with installed website themes. Below are the main points of highlight from the article:

  1. Multiple Wishlist extensions add new database tables and change core Magento logic. They change controllers, blocks, templates, and system APIs.

  2. Conflicts start with theme template overrides and JavaScript code interactions. Sometimes, layout XML modifications and controller plugins clash.

  3. Install extensions using Composer or manual uploads, then run commands. Before installing any new extensions, back up your Magento store.

  4. Configure settings within the Magento Admin after successful extension installation. Test functionality, especially with custom themes installed on the store.

  5. If you are using a specific theme, check for Hyvä theme compatibility packages. Always follow special installation steps for Hyvä theme integration support.

Managed Magento Hosting supports complex extension installations without performance issues.

Sayan Chakraborty
Sayan Chakraborty
Technical Writer

Sayan is a seasoned technical writer with over 4 years of expertise in SDLCs and Magento. His proficiency lies in simplifying complex Magento hosting concepts in clear, concise words.


Get the fastest Magento Hosting! Get Started