The release 0.14 of the Intershop Progressive Web App comes with basic B2C and B2B e-commerce features and – more importantly – it is a reference application with architectural best practices for developers for topics like e.g., initial page loads, server-side rendering, SEO or modularization. Based on the reference application and the full set of synaptic commerce® APIs for B2C and B2B features (like quoting, framework contract, etc.) developers can easily tailor the Intershop Progressive Web App to their specific needs.
|Benefits for Customers||Benefits for Companies||Benefits for Developers|
Smooth and responsive customer experience: This applies in particular to mobile devices with limited bandwidth. Since only data is transferred and not complete HTML pages, the response times of the pages are much shorter. With data held in the browser context, even page transitions are possible that do not require any communication with the server.
The digital world is developing rapidly. Mobile technologies, new end devices and touch points open up new possibilities for companies to access their customers via different channels and touch-points. It is therefore worth switching to new adaptable strategies. inSPIRED Progressive Web App is the first step towards digital success. The top priorities are: adaptability, user-friendliness and flexible use on a wide variety of devices and low programmatic development and operating costs.
By using widely accepted technologies such as Angular, web developers can build on their existing knowledge and make Intershop Storefront development easier than ever before.
2.1 Intershop Progressive Web Application
|Toolset||Web Developers can use the Intershop PWA to implement storefront applications based on the Intershop Commerce Management (ICM) WebShop REST API and/or 3rd Party Systems.|
|Templates||Templates contain the HTML that is rendered for the browser and displays the UI.|
|Services||Services implement business functionality using TypeScript. Services should have a single responsibility by encapsulating all functionality required in it. The API to a service should be as narrow as possible because services are used throughout the application. It is also possible to combine functionality of multiple services in another more general service if necessary.|
|Components||Components are small and (mostly) independent bridges between Services and Templates that prepare data for display in templates and collect input from the user to interact with services. Data Binding links the template with methods and properties from the component. |
The components handling the templates should only handle view logic and should not implement too much specific functionalities. If the component does more than just providing data for the template, it might be better to transfer this to service instances instead.
Multiple components and their templates are then composed to pages.
|Routes||Routes enable navigation from one view to the next as users perform application tasks. Routes can pass optional parameters along to the supporting view component that help it decide what specific content to present.|
|Models||Models are definitions of the data that are handled within the application.|
|Store||The store is the central representation of all data of the application.|
|State||The state is seen as the single source of truth for getting information of the current application state. All information should be held in the store. There is only one immutable state per application, which is composed of sub-states. To get information out of the state, selectors have to be used. Changing the state can only be done by dispatching actions.|
|Selectors||Selectors are used to retrieve information about the current state from the store. The selectors are grouped in a separate file. They always start the query from the root of the state tree and navigate to the required information. Selectors return Observables which can be held in containers and be bound to in templates.|
|Actions||Actions are used to alter the current state via reducers or trigger effects. Action creators are held in a separate file. The action class contains a type of the action and an optional payload. To alter the state synchronously, reducers have to be composed. To alter the state asynchronously, effects are used.|
|Reducers||Reducers alter the state synchronously. They take the previous state and an incoming action to compose a new state. This state is then published and all listening components react automatically to the new state information. Reducers should be simple operations which are easily testable.|
Effects use incoming actions to trigger asynchronous tasks like querying REST resources. After successful or erroneous completion an effect might trigger another action as a way to alter the current state of the application.
|Schematics||Schematics allow for easy creation of code artifacts that automatically comply to the coding guidelines of the project, saving a lot of time for repetitive tasks and increasing code quality.|
|Localization||Intershop Progressive Web App uses a mix of Angular's internationalization tools (i18n) and the internationalization library ngx-translate for localization.|
|Integrated Content Management|
Content managed in Intershop Commerce Management can be integrated into the Intershop Progressive Web App. The content model and integration points in the storefront can be customized according to project-specific needs.
|Deployment Scripts||Templates for Kubernetes Deployments and DevOps for Microsoft Azure are supplied as part of the project.|
2.2 Functional Scope
The Intershop Progressive Web App is an essential component of Intershop's new cloud strategy. Due to the clear separation of the Intershop Commerce Suite back-end from the visualization layer and the introduction of clearly defined synaptic commerce® APIs, partners and customers can design and customize the Intershop Storefront easier than ever before. Extensive knowledge of ISML and pipelines or the deployment of new layouts in the Intershop Commerce Management System are no longer necessary.
Customers can browse categories by different means, like category navigation, breadcrumbs or category lists.
Products can be browsed by category and filtered via search filters (supported filter types are dropdown and single or multi-select checkbox). Product lists support endless scrolling. Product lists can be sorted by different sorting criteria (relevance, price,...).
Customers can search products by SKU or search terms found in product name, description or any other attribute that is indexed in the search index. Suggest search supports search term suggestions. Search results can be filtered via search filters (supported filter types are dropdown and single or multi-select checkbox).
|Product Display & Actions|
The following product data can be displayed:
The following actions can be performed with products:
|Product Variations||Products with different variations are displayed in product lists, product detail pages, cart, wishlist, quote details and order history. The selection of the available options is supported via dropdown (swatch images are currently not supported). Advanced variation handling for complex products with a lot of variations can be enabled via Feature Toggle.|
|Product Bundles||Product bundles with all related bundled products are displayed on product detail pages and in the shopping cart.|
|Retail Sets||Retail Sets with all related items are displayed on product detail pages and can be added to the cart all at once or individually.|
Related products of a certain product are displayed on product detail pages. The following types are supported:
|Promotions||Promotion messages and prices are displayed in product detail, product listing, cart and checkout pages.|
The following data of the shopping cart is displayed:
The following actions can be performed on the shopping cart:
|Addresses||Invoice and shipping addresses can be selected, added and modified during checkout. Addresses can be managed in My Account as well.|
|Shipping||Shipping options including shipping costs, delivery times and descriptions of the options are displayed and can be selected during checkout.|
Payment options are displayed and can be selected during checkout.
The following payment methods are currently supported:
All complex payment methods require a payment connector integration with a 3rd party payment service provider. The mentioned payment methods are currently supported via the Concardis Payment Connector.
All details of the order are displayed before order placement.
The terms and conditions need to be accepted before placing an order.
A summary of the order is displayed after placing an order.
|Guest Checkout||Customers can perform a checkout without registering at the store.|
|Login & Registration|
The following actions are supported:
|My Account Dashboard|
The My Account dashboard provides a navigation overview and the following widgets:
Customers can view and edit the following profile data:
|Order History||Customers can view their order history and order details of all orders.|
|My Quotes||Customers can view a list of their quotes and quote details of all quotes.|
|My Addresses||Addresses can be created, edited and deleted. Preferred shipping and invoice addresses can be defined.|
The following pages of the storefront can be managed by the integrated Content Management System:
The following CMS components are supported within the storefront:
|Personalized Content||Personalized content can be displayed specifically for different customer segments.|
|Tracking Integration||Analytics tools can be integrated via Google Tag Manager. Tracking of page visits via Google Analytics are supported.|
|Cookie Information||Customers receive information about cookie usage during their first visit.|
|Multisite Support||One storefront installation can be used to connect to several Intershop Commerce Management channels. Mapping rules can be defined for incoming URLs to map to respective REST Endpoints.|
Storefront features can be activated and deactivated via configuration of feature toggles. The following features can be activated or deactivated:
The information provided in the Knowledge Base may not be applicable to all systems and situations. Intershop Communications will not be liable to any party for any direct or indirect damages resulting from the use of the Customer Support section of the Intershop Corporate Web site, including, without limitation, any lost profits, business interruption, loss of programs or other data on your information handling system.