Revision as of 18:39, July 31, 2017 by Bfriend (talk | contribs) (Common.createPath(object, path, value))
Jump to: navigation, search

Common

Common is a utility object available for import into Plugins/Widgets and Extensions. It is also accessible directly from the path window._genesys.widgets.common.

Common provides utility functions and dynamically generates common HTML Containers used throughout Genesys Widgets.

Methods

Common.Generate.Container({options})

Dynamically generates a new HTML Container in matching the style of Genesys Widgets with the selected components you request in your options object. Returns the generated container HTML as a jQuery wrapped set.

Argument Type Description
options object An object containing options to apply to the generated container.
options.type string "generic" or "overlay". Overlay containers have special CSS properties for appearing inside the Overlay widget. Default is "generic".
options.title string Title to apply to the container's titlebar area.
options.body string or jQuery wrapped set The HTML body you want the container to wrap.
options.icon string CSS Classname of icon to use
options.controls string Select from a set of window control buttons to show at the top right. "close" = Show only the close button. "minimize" = Show only the minimize button. "all" = Show both close and minimize buttons.
options.buttons object Options for displaying action buttons at the bottom of the container, such as OK and Cancel buttons.
options.buttons.type string Currently "binary" is the only supported button set at this time. Additional sets and arrangements will be available in a later release. Please pass "binary" as the type here if you wish to show typical "accept" and "dismiss" buttons.
options.buttons.primary string Display name on the primary button. (for example 'OK', 'Yes', 'Accept', 'Continue', etc)
options.buttons.secondary string Display name on the secondary button. (for example 'Cancel', 'No', 'Dismiss', 'Reject', etc)


Example

"Generate an Overlay Container"

var ndContainer = Common.Generate.Container({
    
    type: "overlay",
    title: "My Overlay",
    body: "Some HTML here as a string or jQuery wrapped set",
    icon: "call-outgoing",
    controls: "close",
    buttons: false
}),


"Generate a Toast Container"

var ndContainer = Common.Generate.Container({

    type: "generic",
    title: "My Toast",
    body: "Some HTML here as a string or jQuery wrapped set",
    icon: "chat",
    controls: "",
    buttons: {

        type: "binary",
        primary: "OK",
        secondary: "Cancel"
    }
}),

Common.Generate.Buttons({options})

Dynamically generates a new HTML Binary Button set in matching the style of Genesys Widgets with the selected options in your options object. Returns the buttons as a jQuery wrapped set.

Argument Type Description
options object Options for generating buttons, such as OK and Cancel buttons.
options.type string Currently "binary" is the only supported button set at this time. Additional sets and arrangements will be available in a later release. Please pass "binary" as the type here if you wish to show typical "accept" and "dismiss" buttons.
options.primary string Display name on the primary button. (for example 'OK', 'Yes', 'Accept', 'Continue', etc)
options.secondary string Display name on the secondary button. (for example 'Cancel', 'No', 'Dismiss', 'Reject', etc)


Example

"Generate Binary Buttons"

var ndButtons = Common.Generate.Buttons( {

    type: "binary",
    primary: "OK",
    secondary: "Cancel"
}),

Common.checkPath(object, path)

Check for the existence of a sub-property of an object at any depth. Returns the value of that property if found otherwise it returns false. Useful for checking configuration object paths without having to check each sub-property level individually.

Argument Type Description
object object An Object you want checked for a particular sub property at any depth
path string The object path in dot notation you wish to search for.


Example

"Check for window._genesys.main"

 
    var oMainConfig = false;

    if(oMainConfig = Common.checkPath(window, "_genesys.main")){
        
        //... Utilize oMainConfig
    }


Common.createPath(object, path, value)

Related to checkPath, createPath lets you specify a target object and path string but lets you create the path and set a value for it. This saves you the pain of defining each node in the path individually. All nodes in your path will be created as objects. Your final node, the property you are trying to create, will be whatever value you assign it.

Argument Type Description
object object An Object you want to add your new path to.
path string The object path in dot notation you wish to create.
value any The value you want to assign to the final node (property) in your path


Example

"Create window._genesys.main"

 
    var oMainConfig = false;

    if(oMainConfig = Common.createPath(window, "_genesys.main", {debug:true})){
        
        //... Utilize oMainConfig
    }

Common.linkify(string, options)

Search for and convert URLs within a string into HTML links. Returns transformed string.

Argument Type Description
string string Any string you want to check for URLs and have them converted.
options object A list of options to apply to the linkify operation.
options.target string Choose the HTML TARGET attribute to apply to the generated links. Default is "_blank". Set this option to "self" to apply the target "_self" to the generated links.


Example

"Check for window._genesys.main"

 
    var sString = "Please visit www.genesys.com";

    sString = Common.linkify(sString, {target: 'self'});

    // sString == "Please visit <a href='www.genesys.com' target='_self'>www.genesys.com</a>"


Common.sanitizeHTML(string)

Search for and escape < and > characters within a string. Returns transformed string. Useful for escaping HTML.

Argument Type Description
string string Any string you want to be transformed.


Example

"Check for window._genesys.main"

 
    var sString = "Please visit <a href='www.genesys.com' target='_self'>www.genesys.com</a>";

    sString = Common.sanitizeHTML(sString);

    // sString == "Please visit &lt;a href='www.genesys.com' target='_self'&gt;www.genesys.com&lt;/a&gt;'"

Common.updateTemplateI18n(element, object)

Searches through an element's contents for i18n string elements to update with new strings. Used when updating the language in real-time. Works by searching for elements with the CSS classname "i18n" and reading the custom attribute "data-message" to match the string name in the language object. See example below.

Argument Type Description
element jQuery wrapped set Element you want to search within to replace i18n strings.
object Object of i18n Strings The list of languages strings you want to update your UI with. This object comes from the App.i18n event or you can define your own custom object inline or using some other system. Object format is a simple name:value pair format. the "data-message" attribute on your HTML element must match one of these property names to be updated.


Example

"Check for window._genesys.main"

 
    var ndContainer = $("<div><button class="i18n" data-message="CustomButton001"></button></div>");

    Common.updateTemplateI18n(ndContainer, {CustomButton001: "Accept"});

    // ndContainer == <div><button class="i18n" data-message="CustomButton001">Accept</button></div>
Comments or questions about this documentation? Contact us for support!