Members
-
componentName :String
-
Description
A unique name that identifies the component. Use the component name when getting a component, for example,
application.getComponent(componentName)
.Details
-
application :ComponentContainer
-
Description
The name which identify this kind of component. This name is used both for registering a new component and
getting a component implementation with ComponentContainerDetails
Methods
-
cancelableOn( event_name, handler ) → {void}
-
Description
Attaches an event handler to an event.
Parameters
Name Type Description event_name
String The name of the event to which the event handler will be attached.
handler
function The event handler method that will be invoked when event_name is triggered. This function can receive optionally one parameter representing the action parameter. Besides optionally can return a Deferred to details the execution of the trigger's callback. If the returned Deferred is rejected the trigger's callback wont be called
Returns
Details
-
getCurrentStep() → {Deferred.<CheckoutStep>}
-
Description
Gets the current checkout step.
Returns
-
cancelableOff( event_name, handler ) → {void}
-
Description
Detaches an event handler from an event.
Parameters
Name Type Description event_name
String The name of the event from which to detach the event handler. This argument is required.
handler
function The event handler that will be removed from the list of handlers attached to the event. This argument is required.
Returns
Details
-
extend( componentDefinition ) → {BaseComponent}
-
Description
Extends the current component and creates a child component.
Parameters
Name Type Description componentDefinition
Object An object with the appropriate properties and methods to create the component.
Returns
Details
-
setCurrentStep( step ) → {Deferred.<CheckoutStep>}
-
Description
Sets the current checkout step.
Parameters
Name Type Description step
CheckoutStep Returns
-
closeMessage( messageId )
-
Description
Lets you close a message on the page. To close a message, you must have the ID of the message, as returned by showMessage() when the message was first shown.
var layout = container.getComponent('Layout'); var message_vat_no; if (layout) { // Check if a VAT number was entered. If not, display a message. if ($('#vat_no').val() == '') { message_vat_no = layout.showMessage({message: 'You must enter a VAT number to register as a business customer.', type: 'error'}); } } // Clear the VAT number error message when the VAT number field gets focus. $('#vat_no').focus(function() { layout.closeMessage(message_vat_no); });
Parameters
Name Type Description messageId
string The ID of the message to close. Get the ID of a message by assigning the return value of
showMessage()
to a variable.Details
-
cancelableDisable( event_name ) → {void}
-
Description
Disables all the event handlers attached to an event.
Parameters
Name Type Description event_name
String The name of the event.
Returns
Details
-
getStepGroupsInfo() → {Deferred.<Array.<CheckoutStepGroup>>}
-
Description
Gets the step groups in the checkout flow.
Returns
-
on( event_name, handler ) → {void}
-
Description
Attaches an event handler to an event name. Alias for CancelableEvents#cancelableOn.
Parameters
Name Type Description event_name
String The name of the event to attach to
handler
function Returns
Details
-
getStepsInfo() → {Deferred.<Array.<CheckoutStep>>}
-
Description
Gets the steps in the checkout flow.
Returns
-
cancelableEnable( event_name ) → {Void}
-
Description
Re-enables all the event handlers attached to an event.
Parameters
Name Type Description event_name
String The name of the event.
Returns
Details
-
off( event_name, handler ) → {void}
-
Description
Detaches an event handler from an event name. Alias for CancelableEvents#cancelableOff.
Parameters
Name Type Description event_name
String The name of the event from which to detach the event handler.
handler
function Returns
Details
-
getCheckoutFlow() → {Deferred.<String>}
-
Description
Gets the current checkout flow of the web store, as specified on the SuiteCommerce Configuration page in the NetSuite account. The checkout flow can be one of the following: Standard, One Page, or Billing First. See the Checkout Flows topic in the Help Center (login required) for more information.
Returns
-
cancelableTrigger( event_name, ...args ) → {Deferred}
-
Description
Triggers an event with a set of arguments. If an event handler is rejected, the event handler callbacks will not be executed.
Parameters
Name Type Attributes Description event_name
String The name of the event to trigger.
args
params <repeatable> One or more arguments that will be broadcast to all event handlers attached to the event.
Returns
Details
-
cancelableTriggerUnsafe( event_name, ...args ) → {Deferred}
-
Description
Triggers an event with a set of unsanitized arguments. If an event handler is rejected, the event handler callbacks will not be executed.
Parameters
Name Type Attributes Description event_name
String The name of the event to trigger.
args
params <repeatable> One or more arguments that will be broadcast to all event handlers attached to the event.
Returns
Details
-
modifyViewJsonLd( view_id, callback ) → {void}
-
Description
Lets you modify JSON-LD data embedded in the
<head>
element of a SuiteCommerce product details page. JSON-LD data on SuiteCommerce websites adheres to the structured data schemas, as specified on https://schema.org/Product.If your extension modifies a view or adds a child view on the product details page, you can use
modifyViewJsonLd()
to update the related JSON-LD. For example, if you add a child view that displays additional product information, you can update the JSON-LD to ensure the page and its metadata are consistent.In general, the embedded JSON-LD data should be consistent with the content in the view. SuiteCommerce creates JSON-LD data when a view is rendered. For this reason, you need to pass in a view ID to
modifyViewJsonLd()
when modifying JSON-LD data.Note: To use this method, JSON-LD must be selected as the markup type on the SuiteCommerce Configuration page in the NetSuite account. See Structured Data Markup in the NetSuite Help Center for more information.
In the following example, we create an instance of the Layout component and use
modifyViewJsonLd()
to add a property to the JSON-LD object. We pass in 'ProductDetails.Full.View' as the view ID and a function that returns a Promise. The_.extend
function enables you to copy an object and add new properties to it.var layout = container.getComponent('Layout'); layout.modifyViewJsonLd('ProductDetails.Full.View', function(json) { json = _.extend(json, { manufacturer: 'NetSuite Industrial' }); return jQuery.Deferred().resolve(json); });
Parameters
Name Type Description view_id
string The identifier of the view that will update the JSON-LD data. For example, if you use the Layout component to modify the ProductDetails.Full.View view in the base theme template, pass in "ProductDetails.Full.View" as the
view_id
.callback
function A function that modifies the JSON-LD data. It must return a Promise that resolves with an object.
Returns
Throws
Details
-
addModuleToStep( data ) → {Deferred}
-
Description
Adds a module to a step. You must extend class WizardModule to add a new module.
checkout.addModuleToStep( { step_url: 'shipping/new_step' , module: { id: 'new_module' , index: 0 , classname: 'OrderWizard.Module.Shipmethod' , options: { container: '#wizard-step-content-right'} } })
Parameters
Name Type Description data
AddModuleData Returns
-
setChildViewIndex( view_id, placeholder_selector, view_name, index ) → {void}
-
Description
Changes the position of a child view inside a container.
Parameters
Name Type Description view_id
string The identifier of the view of the current component that contains the child view whose position will be changed.
placeholder_selector
string The identifier of a location in the specified view (view_id) where the child view will be added.
view_name
string The identifier of a view in the placeholder.
index
number The index of the child view's position.
Returns
Throws
Details
-
removeModuleFromStep( data ) → {Deferred}
-
Description
Removes a module from a step.
Parameters
Name Type Description data
RemoveModuleData Returns
-
addStepsGroup( data ) → {Deferred.<CheckoutStepGroup>}
-
Description
Adds a steps group. If a steps group with the same name already exists,
addStepsGroup()
returns an error.Parameters
Name Type Description data
AddStepsGroupData Returns
-
removeStepsGroup( data ) → {Deferred}
-
Description
Removes a steps group.
Parameters
Name Type Description data
RemoveStepGroupData Returns
-
addStep( data ) → {Deferred.<CheckoutStep>}
-
removeStep( step_url ) → {Deferred}
-
Description
Removes a step from a steps group.
Parameters
Name Type Description step_url
String Returns
-
showMessage( data ) → {string}
-
Description
Shows a message in the notifications area of a SuiteCommerce page. The message is displayed by default in the Notifications placeholder (a DIV element in the base theme template with the custom data attribute
data-view="Notifications"
). You can also choose to display the message in any other placeholder that uses either of the following custom data attributes:data-view
ordata-cms-area
.Messages can be closed by the user, by setting a timeout in the method, or with the closeMessage() method. If you want to use
closeMessage()
, first assign the return value ofshowMessage()
to a variable, and then pass the variable tocloseMessage()
.In the following example, the message is shown and then closed after 5 seconds by setting a timeout.
var layout = container.getComponent('Layout'); if (layout) { var message_shown = false; layout.on('afterShowContent', function() { if (message_shown != false) { layout.showMessage({ message: '', type: 'info', selector: 'Notifications', timeout: 5000 }); message_shown = true; } }); }
In the following example, a message is shown if an invalid VAT number is entered. When the user enters a valid number, the message is closed.
var layout = container.getComponent('Layout'); var message_vat_no; $('#vat_number').blur(function() { var vat_number = $(this).val(); if (message_vat_no !== undefined) { layout.closeMessage(message_vat_no); } // checkVatNumber() returns false if the number entered is invalid. if (!checkVatNumber(vat_number)) { message_vat_no = layout.showMessage({ message: 'You must enter a VAT number to register as a business customer.', type: 'error' }); } });
Parameters
Name Type Description data
Object Data required to display the message.
data
is an object, which can have the following properties:- message - Required. The text of the message.
- type - Required. The type of message. It also determines the appearance of the message on the page. Type can be one of the following:
info
,warning
,error
, orsuccess
. - selector - A placeholder on the page where you want the message to appear.
- timeout - Specifies the duration in milliseconds of the message on the page. If you do not specify a timeout, you can use closeMessage() to remove the message.
Returns
Details
-
addChildViews( view_id, child_views ) → {void}
-
Description
Adds one or more child views to an existing view. The existing view must already be in the DOM and must have the 'data-view' HTML attribute.
The
addChildViews
method is flexible, but more complex thanaddChildView
. Use the simpler addChildView() where possible.checkout.addChildViews( checkout.WIZARD_VIEW , { 'Wizard.StepNavigation': { 'CheckoutView': { childViewIndex: 1 , childViewConstructor: function () { return new CheckoutExtensionView({checkout:checkout}); } } } } );
Parameters
Name Type Description view_id
string The identifier of the view of the current component to which the child views will be added.
child_views
object Returns
Throws
Details
-
addChildView( data_view, view_constructor ) → {Void}
-
Description
Adds a child view to a view that already exists in the DOM. Child views can be added to elements that have the
data-view
ordata-cms-area
data attribute. If there are multiple elements in a template that have a data-view attribute value ofview_id
, the child view is added to all elements with that ID. Elements with the data-view attribute act as placeholders in the application. If there is content in the view (which is typically the case), the child view replaces the current content.If you want to add multiple views at the same time, or if you want to add a child view while preserving the current content in the existing view, use addChildViews.
layout.addChildView('Header.View', function () { return new HolidayBannerView({}); });
In the above example, the view
HolidayBannerView
will be added as a child view of an element in any template that has a data-view attribute ofHeader.View
.layout.addChildView('cms:header_banner_top', function () { return new HolidayBannerView({}); });
In the above example, a child view is added to a predefined SMT area called 'header_banner_top'. In the template, the header_banner_top SMT area might be in a div tag in the following way:
<div data-cms-area="header_banner_top"></div>
. Because header_banner_top is a predefined SMT area, thecms:
prefix is used before theview_id
argument.Parameters
Name Type Description data_view
String The view to which the child view will be added.
data_view
is the value of the 'data-view' or 'data-cms-area' data attributes of an element on the page. For example, the header logo view uses the following data-view data attribute:<div data-view="Header.Logo">
.view_constructor
SimpleChildViewConstructor An instance of a view. Use a constructor function to get an instance of a view.
Returns
Throws
Details
-
removeChildView( view_id, placeholder_selector [, view_name ] ) → {void}
-
Description
Removes a child view from a view.
Parameters
Name Type Attributes Description view_id
string The identifier of the view of the current component from which the child view will be removed.
placeholder_selector
string The identifier of the location in the specified view (view_id) from which the child view will be removed.
view_name
string <optional> The identifier of the view to be removed.
Returns
Throws
Details
-
addToViewContextDefinition( view_id, property_name, type, callback ) → {void}
-
Description
Adds a property to the UI context of a view to extend interaction with its template.
Parameters
Name Type Description view_id
string The identifier of the view of the current component to which the context property will be added.
property_name
string The name of the property.
type
string The type of the property. The value returned by the callback function must be of the same type.
callback
function A function that sets the value of the property (property_name).
Returns
Throws
Details
-
removeToViewContextDefinition( view_id, property_name ) → {void}
-
Description
Removes a property from the UI context of a view.
Parameters
Name Type Description view_id
string The identifier of the view of the current component from which the context property will be removed.
property_name
string The name of the property.
Returns
Throws
Details
-
addToViewEventsDefinition( view_id, event_selector, callback ) → {void}
-
Description
Adds an event handler to an event in a view.
Parameters
Name Type Description view_id
string The identifier of the view of the current component to which the event handler will be added.
event_selector
string callback
function The event handler function to call when the specified event occurs.
Returns
Throws
Details
-
removeToViewEventsDefinition( view_id, event_selector ) → {void}
-
Description
Removes an event handler from an event in a view.
Parameters
Name Type Description view_id
string The identifier of the view of the current component to which the event handler will be added.
event_selector
string Returns
Throws
Details
Events
-
beforeAddModuleToStep
-
-
afterAddModuleToStep
-
-
beforeSetCurrentStep
-
-
afterSetCurrentStep
-
-
beforeAddStep
-
-
afterAddStep
-
-
beforeAddStepsGroup
-
-
afterAddStepsGroup
-
-
afterShowContent
-
Description
Event triggered after content has been rendered in the main view. This event is available in components that extend VisualComponent (such as PDP, PLP, or Layout) and is triggered by the showContent() method.
See the Work with Events help topic in the NetSuite Help Center for more information.
Details
-
beforeShowContent
-
Description
Event triggered before content in the main view is rendered. This event is available in components that extend VisualComponent (such as PDP, PLP, or Layout) and is triggered by the showContent() method. For example, if the URL changes in the application, the showContent() method is called, which triggers the event.
Details