show-popoverB(Default: true) - Show detail popover when avatar is clicked
placementS(Default: auto right) - Placement of popover (top, left, right, auto right, etc
animationB(Default: true) - Fade popover into and out of view
show-phoneB(Default: true) - Show phone contact icon in popover (if available and on mobile device)
show-phone-desktopB(Default: false) - Show phone contact icon on desktop in popover (if available)
show-connectB(Default: true) - Show Connect contact icon in popover
show-mailB(Default: true) - Show email contact icon in popover (if available)
show-infoB(Default: true) - Show info icon in popover (link to user profile)
show-pictureB(Default: true) - Show large user profile pic in popover
show-companyB(Default: false) - Show user company in popover
show-presenceB(Default: true) - Show user presence indicator on avatar
phone-orderS(Default: businessPhone,mobilePhone,homePhone) - Order in which to prioritize phone contact number (comma-separated)
close-clickB(Default: true) - Only allow one popover open at a time, and auto-close when clicked outside of popover (can affect performance with many avatars on screen)
A smart alerting engine utilizing the Flex Banner element. Alerts provide flexibility in how you notify your end users of announcements, outages, and more. Features include:
Customized styling for color, icon, and sizing
Fully internationalized for global audiences
Flexible behavior for persistence, user dismissal, or timed dismissal of alerts
Targeted alerts based on user, group, department, location or everyone
Real-time delivery to ensure alerts are seen as soon as they are available
prev
next
Text - Text or html to display in the alert
Identifier - A string identifier used to target specific alerts to a specific widget
Banner color(Default: #346F9A) - Background color for the alert banner
Text color(Default: #FFFFFF) - Font color for the alert text
Icon(Default: fa fa-bell) - Icon to place alongside the alert text
Position(Default: Top) - Position at which to place the banner (Top or Bottom)
Font size(Default: 12pt) - Font size for text in the banner (pt)
Dismiss text(Default: Click to dismiss) - Text to be placed in the dismiss popover dialog
Users - Specific users who should receive the alert (leave blank for all)
Groups - Specific groups who should receive the alert (leave blank for all)
Departments - Specific departments who should receive the alert (leave blank for all)
Locations - Specific locations who should receive the alert (leave blank for all)
Dismissable(Default: true) - Allow banner to be dismissed with a click (true or false)
Show once per user - For dismissable alerts, track the user dismissal and do not show again (true or false)
Auto-dismiss time - Time until banner auto-dismisses (ms)
Real time(Default: false) - Watch for incoming alerts and display them in real-time, versus on initial page load (true or false)
Days(Default: 7) - How many days past to query for data
Approvals
SP
W
A widget for displaying the logged-in user's requested approvals.
prev
next
Bootstrap color(Default: Default) - Color to apply to list header and border
Glyph - Icon to display in table header
Buttons stacked side by side(Default: false) - Display approve/reject buttons side-by-side
Badge
BS
E
The standard Bootstrap badge, with styling tailored for Service Portal.
The standard Service Portal alert, based on Bootstrap alert styling.
Your request was successfully submitted.
Something went wrong. Please try again later.
spUtil.addInfoMessage('Your request was successfully submitted.');
spUtil.addErrorMessage('Something went wrong. Please try again later.');
Banner (Flex)
YDS
E
A flexible banner at top or bottom of your Service Portal page - perfect for displaying news, alerts, outages, and more!
valueRD$ - Text or html to display in the banner
iconDS - Icon to place alongside the banner message, such as 'fa fa-bell'
colorDS(Default: #FFFFFF) - A hex (#XXXXXX) font color for the banner text
background-colorDS(Default: primary) - A hex (#XXXXXX) or boostrap (primary/success/info/warning/danger) color for the banner background
positionS(Default: top) - Position at which to place the banner (top or bottom)
font-sizeS(Default: 12pt) - Font size for text in the banner (pt)
dismissableB(Default: true) - Allow banner to be dismissed
dismiss-textS(Default: Click to dismiss) - Text to be placed in the dismiss popover dialog
dismiss-timeI(Default: never) - Time until banner auto-dismisses (ms)
$scope.setBannerTop =function(){
$scope.bannerValueTop ="An upgrade of the ServiceNow platform will occur this weekend. We will be installing the Yansa Design System in order to provide you with a superior Service Portal experience!";};
$scope.setBannerBottom =function(){
$scope.bannerValueBottom ="A meet & greet with the founders of Yansa Labs will be held in the staff lounge at 5 PM today.";};
<yds-bannericon="fa fa-bell"value="bannerValueTop"background-color="success"></yds-banner><yds-bannericon="fa fa-glass"value="bannerValueBottom"position="bottom"></yds-banner><buttonclass="btn btn-primary"ng-click="setBannerTop()">Click to Test Top Banner</button><buttonclass="btn btn-primary"ng-click="setBannerBottom()">Click to Test Bottom Banner</button>
Button (Standard)
BS
E
The standard Bootstrap button, with styling tailored for Service Portal.
ng-clickS - Name of a scope function to run when clicked
$scope.promFn =function(returnVal){var myPromise =$timeout(function(){//Expects return value of 'success', 'error', or 'failure'return returnVal;},1000);//To react to results of promise externally, attach .then function
myPromise.then(function(response){
console.log('Promise completed with result of '+ response);});return myPromise;};
A colorized callout for highlighting a block of content or presenting a dismissable alert.
This is some important information I want you to know!
This is normal paragraph text
This is a callout headline
This is normal callout text
And here is some more normal paragraph text
colorS(Default: primary) - A hex (#XXXXXX) or boostrap (primary/success/info/warning/danger) color. Color is applied to the gutter and any headline elements within the callout.
background-colorS(Default: transparent) - A hex (#XXXXXX) color to be applied to the callout background
border-colorS(Default: transparent) - A hex (#XXXXXX) color to be applied to the callout border
dismissableB(Default: false) - Allow callout to be dismissed
<yds-calloutcolor="danger"border-color="#8d8d8d"dismissable=true>
This is some important information I want you to know!
</yds-callout><p>This is normal paragraph text</p><yds-calloutcolor="success"><h4>This is a callout headline</h4>
This is normal callout text
</yds-callout><p>And here is some more normal paragraph text</p>
Catalog Item
YDS
W
An enhanced version of the Service Catalog Item view:
Display items in the standard platform layout, maintaining all variable set and container configurations - an enhanced iFrame solution with native styling and no scrollbars
Display additional fields for reference & list collector variables
Allow ordering of large quantities of items
prev
next
Catalog Order Guide
YDS
W
An enhanced version of the Service Catalog Order Guide view:
Display items in the standard platform layout, maintaining classic order guide appearance, variable sets, and container configurations - an enhanced iFrame solution with native styling and no scrollbars
prev
next
Charts
SHR
W
The Highcharts Widget by Darrin Achtman, for creating highly customizable advanced charts.
TypeR(Default: Count) - Type of panel ('count' or 'link')
URL - URL for 'link' type panels
IconRS(Default: fa-folder-o) - Fontawesome icon for panel
Table(Default: Incident) - Table to query for 'count' type panels
Query(Default: active=true) - Encoded query for 'count' type panels
Style(Default: Active) - Style of panel ('active'=opaque or 'inactive'=translucent)
Page - Page to link 'count' type panels to, passing along table & query parameters
Date Picker
YDS
E
A date picker built for simple deployment and automatic adjustment for the logged-in user's preferred date format. Utilizes MomentJS for formatting.
value$S - Initial value of the field as a MomentJS object or string
system-valueB(Default: false) - Return system date format (YYYY-MM-DD) instead of a MomentJS object
ng-disabledDB(Default: false) - Set field read-only
ng-requiredDB(Default: false) - Set field mandatory (requires ydsValidate)
ng-modelRDS - Name of the scope variable to map the field value to (either a momentJS object or a string in system format, depending on parameters)
options$(Default: {format:[Logged-in user format], useCurrent:false, pickTime:false, locale:[Logged-in user language]}) - DateTimePicker options as listed in Bootstrap Datetime Picker documentation
A date/time picker built for simple deployment and automatic adjustment for the logged-in user's preferred date/time format. Utilizes MomentJS for formatting.
value$S - Initial value of the field as a MomentJS object or string
system-valueB(Default: false) - Return system datetime format (YYYY-MM-DD HH:mm:ss) instead of a MomentJS object
ng-requiredDB(Default: false) - Set field mandatory (requires ydsValidate)
ng-disabledDB(Default: false) - Set field read-only
ng-modelRDS - Name of the scope variable to map the field value to (either a momentJS object or a string in system format, depending on parameters)
options$(Default: "{format:[Logged-in user format], useCurrent:false, locale:[Logged-in user language]}") - DateTimePicker options as listed in Bootstrap Datetime Picker documentation
<formname="myForm"><labelfor="monthField">Choose a month</label><yds-selectid="monthField"choices="monthChoices"name="myMonth"ng-model="myMonth"ng-required=trueyds-validate></yds-select><labelfor="yearField">Choose a year <spanstyle="color:red"ng-if="!myForm.myYear.$valid && myForm.myYear.$dirty">(Must be 4 digits)</span></label><inputid="yearField"class="form-control"name="myYear"ng-model="myYear"ng-required=trueng-minlength=4ng-maxlength=4yds-validate><buttonclass="btn btn-primary pull-right"ng-disabled="!myForm.$valid">Submit</button></form>
Form Fields
YDS
W
A ServiceNow-form style multiple field display
prev
next
TableR - Table from which to pull fields
Column 1 fieldsR - Fields to display in first column
Column 2 fieldsR - Fields to display in second column
Match fieldR - Field against which to match the 'sys_id' URL parameter
TitleS - Label in widget header
Only show if user can writeB(Default: false) - Only show the widget if the user can write something in it
Hide if no contentB(Default: true) - Hide the entire widget if there is no content
Hide field if no valueB(Default: false) - Hide an individual field if it has no value
A slider input for selecting values across a range of options.
2
32GB
64GB
128GB
choicesR$ - Array of Strings, Integers, or Objects in format {id:string, text:string}
value$ - Initial value of the field by id
orientationS(Default: horizontal) - Orientation of the level select (vertical or horizontal). Vertical orientation is not available in the Helsinki release.
colorS(Default: primary) - A hex (#XXXXXX) or boostrap (primary/success/info/warning/danger) color for level select highlights
ng-disabledDB(Default: false) - Set field read-only
ng-modelRDS - Name of the scope variable to map the field value to
An element and widget to display the current stage in a process. Can be used 1) with an array of stages and a current stage to manually render or 2) with record identifiers to automatically render for a specific record. The widget may be dropped directly onto the existing Form page with no inputs - it will attempt to render correctly for the current table.
Ordered
Fulfillment
Shipping
Delivered
stagesRD$ - (Option 1) Array of Strings or Objects in format {id:string, text:string, status:visited/current}
current-stageRD$ - (Option 1) Current active stage
tableRS - (Option 2) Table of the record for which the multistage is rendered
sys-idRS - (Option 2) SysID of the record for which the multistage is rendered
fieldS(Default: state) - (Option 2) Field on the table that contains available stages (for non-Process Flow)
process-flowB(Default: true) - (Option 2) If available, use Process Flow for multistage
workflow-stagesB(Default: false) - (Option 2) Query the wf_stage_default table for additional stages
orientationS(Default: horizontal) - Orientation of the multistage (vertical or horizontal)
text-placementS(Default: top) - Location of text labels (top or bottom)
show-future-stagesB(Default: true) - Display labels for future stages prior to being active
exception-stagesS - Stages that should only show if they are the current stage (comma-separated by id or numeric state)
colorS(Default: primary) - A hex (#XXXXXX) or boostrap (primary/success/info/warning/danger) color for level select highlights
A tailored select box for searching, displaying, and choosing one or many users. Customized select boxes like this can be created for any type of data!
A fresh take on the popular Table Saw application, built specially for Service Portal. Table Saw provides infinite customizability in intelligent, filterable data views.
Quickly define filter emitters with desired filtering capabilities
Fully customize the look/feel of the filter widget and the data displayed
Add user-friendly filtering to the standard Data Table widget
prev
next
Documentation is embedded in the application. Once installed, visit the Table Saw module in the left nav to begin using.
Tile Navigator
YDS
W
A table-driven, tile-based UI providing hierarchical link content for internal or external resources.
Works great as an interactive hero banner or a custom UI element providing curated link content
Provide an unlimited number of top-level tiles w/ custom images
Provide unlimited levels of links & categories of links beneath each tile
Role-based & script-based security limits visibility to tile & link content
prev
next
Additional documentation is embedded in the application. Once installed, visit the Tile Navigators module in the left nav to begin using.
Title - Descriptive name
Header Color(Default: #000000) - Color of widget header text
Text Color(Default: #FFFFFF) - Color of widget text
Primary Color(Default: #1F3031) - Primary color of links
Secondary Color(Default: #496D5E) - Hover color of links
Tooltip
UIB
E
The UI Bootstrap tooltip, with styling tailored for Service Portal. Can be used on any element type.
uib-tooltipRDS - Text to display in tooltip
tooltip-is-openDB(Default: false) - Show tooltip (useful for programmatic display of tooltip)
tooltip-placementS(Default: top) - Location of tooltip (top, right, right-bottom, auto top, etc)
<buttonuib-tooltip="I'm a Fancy Tooltip!"type="button"class="btn btn-primary btn-lg">Hover Me</button>
Translation
YDS
E
A translation service providing on-the-fly translation of any text to/from any language. Utilizes the ServiceNow Messages table and/or Google Translate to provide translations in real-time for capabilities ranging from portal localization to real-time chat translation. This includes an AngularJS directive and a service so that it is accessible within both HTML and client scripts.
English: Welcome to our design system!
Spanish: Bienvenido a nuestro sistema de diseño!
Arabic: مرحبا بكم في تصميم النظام لدينا!
Chinese: 歡迎到我們的設計系統!
from-languageS(Default: en) - Language translating from (en/fr/es/etc)
to-languageS(Default: Logged-in user language) - Language translating to (en/fr/es/etc)
translatorS(Default: sn,google) - Translation sources: sn/ServiceNow or google/Google (comma-separated)
watch-var$ - Scope variable to watch and, if it changes, retranslate field
show-missing-translationB(Default: false) - For debugging, show if translation missing for each translated term
show-translation-sourceB(Default: false) - For debugging, show translation source for each translated term
google-api-keyS - Google Translate API key
$scope.textToTranslate ="Welcome to our design system!";
The UI Bootstrap typeahead, with styling tailored for Service Portal. Can be used with static values or server-side values with the asynchronous $http service. For selecting records or values from a table, try the Select (Reference) element.
uib-typeaheadRD$ - Angular expression denoting available choices, similar to ngRepeat
typeahead-editableD$(Default: true) - Restrict available options to only those in the typeahead list
typeahead-focus-first$(Default: true) - Automatically focus first match as the user types
typeahead-min-lengthD$(Default: 1) - Minimum characters user must type before typeahead begins
typeahead-wait-msD$(Default: 0) - Minimal time after last character is typed before typeahead begins (ms)
typeahead-select-on-blur$(Default: false) - On blur, select the currently highlighted match
typeahead-select-on-exact$(Default: false) - Automatically select a choice when it is the only available match
ng-requiredDB(Default: false) - Set field mandatory (requires ydsValidate)
ng-disabledDB(Default: false) - Set field read-only
ng-modelRDS - Name of the scope variable to map the field value to
<inputtype="text"ng-model="taSelected"uib-typeahead="choice for choice in taChoices | filter:$viewValue | limitTo:10"class="form-control">
Widget Accordion
YDS
W
Display any combination of widgets in a Bootstrap accordion
prev
next
Title - Descriptive name
Tab labelRS - Label of a tab
Tab widgetR - Widget to display in a tab
Tab orderI - Order in which to display tabs
Tab visibility(Default: All users) - Limit visibility of a tab based on user roles, conditions, or server script
Widget Tabs
YDS
W
Display any combination of widgets in Bootstrap tabs
prev
next
Title - Descriptive name
Tab labelRS - Label of a tab
Tab widgetR - Widget to display in a tab
Tab orderI - Order in which to display tabs
Tab visibility(Default: All users) - Limit visibility of a tab based on user roles, conditions, or server script
Wonder List
YDS
W
The only list widget you'll ever need.
Point-and-click creation of customizable, paginated lists gathered from one or many tables
Sort uniformly on a common field, keeping pertinent information up-top, regardless of data source
Choose from several list styles, ranging from classic panels to tiles
Examples of uses include
Interleave your users' tasks & requests into a single handy list
Consolidate popular Links, News, Knowledge, and more
Create data-driven navigation panes for your portal
prev
next
Additional documentation is embedded in the application. Once installed, visit the Wonder Lists module in the left nav to begin using.
Title(Default: My Tickets) - Label in widget header
Glyph - Icon displayed in widget header
Sort field(Default: Updated) - Field by which to sort all items (works best if all records have this field) Note: Can be overridden for individual record types
# of Items per page(Default: 5) - Number of items to show per page
Max # of Items(Default: all) - Maximum number of items to display
Style(Default: panel) - Visual style of the list
Max label characters(Default: 40) - Maximum number of characters to show for labels
Max secondary characters(Default: 60) - Maximum number of characters to show for secondary fields
Empty message(Default: There are no items to list) - Message to display when there are no items to list
Word Cloud
YDS
W
A lightweight word cloud widget that contains weighted terms that may optionally link to content like KB Articles, Records, etc
prev
next
TagsR - A list of terms, weights, and URLs to display (Can also be provided dynamically via script or event broadcast)
Shuffle(Default: true) - Shuffle terms before display
Open links in new tab(Default: true) - Open links in new vs same tab