KEMBAR78
ServiceNow UI Customization Guide | PDF | Json | User Interface
0% found this document useful (0 votes)
28 views59 pages

ServiceNow UI Customization Guide

Uploaded by

Chanakya Varma
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
28 views59 pages

ServiceNow UI Customization Guide

Uploaded by

Chanakya Varma
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 59

CSCI3111: Client Relationship Management

UI Customization

Session-2

Dr. Santosh Kumar Uppada


Assistant Professor

Department of Computer Science


GITAM School of Science
GITAM University
UI Customization- Branding Your Instance

Branding your instance in ServiceNow involves customizing the user interface, col-
ors, logos, and other visual elements to align with your organization's branding
guidelines.

Branding can help to create a consistent and familiar experience for your users
when they interact with the platform.

Steps to Brand Your Company Instance on ServiceNow


Log in to your ServiceNow Instance - Access using Administrator credentials.

Navigate to Branding Settings - Look for Branding/UI Properties in the navigation


menu.

Customize Logo and Favicon - Upload your organization's logo and favicon (the
small icon displayed in the browser tab) in the branding settings. These images
will be used across the platform.

Set Color Themes - Customize the color theme to match your organization's brand-
ing colors. This includes primary and secondary colors, as well as accent colors for
various UI elements.

2 / 59
Contd . . .

Modify Header and Footer - Customize the header and footer sections of the user
interface. One can add links to important resources, display contact information,
or any other content that aligns with your organization's needs.

Update Login Page - Personalize the login page by adding your logo and possibly
changing the background image or color to match your branding.

Congure Email Templates - Customize email templates that are sent from the
ServiceNow instance to match your branding, which includes incident notications,
password reset emails, and other automated communications.

Testing and Feedback - After making changes, it's important to thoroughly test
the user interface to ensure that the branding changes have been applied correctly
and that the overall user experience remains positive. Gather feedback from users
and make adjustments as needed.

Documentation and Training - Update any relevant documentation or training


materials to reect the new branding, that helps users to become familiar with the
changes and understand how to navigate the platform.

Roll Out Branding Changes - Once you are satised with the changes, you can roll
them out to your entire organization. Communicate the changes to users so they
are aware of the updates to the platform's look and feel.

3 / 59
Custom Themes in UI Builder - Vancover

Create a custom theme so that it can override default component styles. One can
dene their own style properties in a theme record.

It is to be remembered that the Role required for doing these changes is either
ui_builder_admin or admin.

Themes enable one to change the visual style of the experiences so that one can
express the look and feel of their brand.

To apply a theme, do one of the following steps

Navigate to Menu → Edit experience settings → Branding and theming.

On the Brand and theming settings screen under Themes, select Create a theme.

Navigate to Now Experience Framework → Themes.


The Themes list view appears.

4 / 59
Contd . . .

To create a theme record in the Theme [sys_ux_theme] table, click New.

On the form, ll in the elds.

5 / 59
Contd . . .

6 / 59
Contd . . .

7 / 59
Contd . . .

8 / 59
Contd . . .

9 / 59
Contd . . .

10 / 59
Contd . . .

11 / 59
UI-Impacting in SeviceNow

User Interface (UI) design and its impact on ServiceNow, a popular IT service
management platform, can greatly inuence the user experience, eciency, and
overall success of your implementation.

An eective UI design in ServiceNow can lead to improved user adoption, increased


productivity, and better outcomes.

UI Impacts of ServiceNow

User Adoption:
A well-designed and intuitive UI encourages users to engage with the platform more
readily.
If the UI is user-friendly and aligns with users' mental models, they are more likely to
embrace the platform and its capabilities.

Ease of Use:
The UI design should make it easy for users to navigate through the various features
and functionalities of ServiceNow.
Intuitive navigation, clear labels, and logical grouping of functions can contribute to
a positive user experience.

12 / 59
Contd . . .

Eciency:
An ecient UI design can streamline workows and processes.
Users should be able to perform tasks quickly and easily, minimizing the time and
eort required to complete tasks.

Consistency:
Consistency in UI design across dierent modules and components within ServiceNow
fosters a sense of familiarity for users.
They can apply their understanding of one part of the platform to other parts, reducing
the learning curve.

Customization:
ServiceNow oers a high degree of customization.
UI design should consider the ability to personalize interfaces based on user roles and
responsibilities, allowing users to access the information and tools they need most.

Responsive Design:
Many users access ServiceNow from dierent devices, such as desktops, tablets, and
smartphones.
A responsive UI design ensures that the platform adapts seamlessly to various screen
sizes and orientations.

13 / 59
Contd . . .

Accessibility:
A well-designed UI takes into account accessibility guidelines to ensure that users with
disabilities can also eectively use the platform.
This involves considerations such as proper contrast, keyboard navigation, and screen
reader compatibility.

Visual Hierarchy:
UI design should establish a clear visual hierarchy, emphasizing important elements
and de-emphasizing less important ones.
This guides users' attention to key actions and information.

Feedback and Notications:


Eective UI design provides timely feedback to users when they perform actions or
encounter errors.
Notications and alerts should be clear and actionable.

Search and Filters:


ServiceNow often involves handling a signicant amount of data.
A strong UI should include powerful search and ltering capabilities, enabling users
to quickly locate the information they need.

14 / 59
Contd . . .

Training and Onboarding:


A well-designed UI reduces the need for extensive training and onboarding.
New users should be able to explore and understand the platform relatively easily.

Aesthetics:
While functionality is crucial, aesthetics also play a role in user satisfaction.
A visually pleasing UI can positively inuence users' perception of the platform's
quality.

When working on the UI design for ServiceNow, consider involving users in the
design process through usability testing and gathering feedback.

The user-centered approach can help identify pain points and areas for improve-
ment.

Ultimately, a well-thought-out and user-friendly UI design can contribute signi-


cantly to the success of your ServiceNow implementation.

15 / 59
System properties of UI Customization in ServiceNow

In ServiceNow, system properties are key-value pairs that control various aspects
of the platform's behavior and customization.

When it comes to UI customization, there are several system properties that can
inuence the user interface and its behavior.

Important system properties related to UI customization in ServiceNow

glide.ui.escape_text:
Determines whether text entered into elds is automatically HTML escaped
1.
Setting this property to true helps prevent Cross-Site Scripting (XSS) vulnerabilities
by escaping special characters in user inputs.

glide.ui.display_all_tabs:
Controls whether users see all application tabs or just the ones they have access.
Setting this property to true displays all tabs in the application navigator, which can
be useful for troubleshooting and development.

glide.ui.encoded_slash_in_get:
Decides whether to allow encoded slashes (%2F) in URLs.
Setting this property to true enables URLs with encoded slashes to be properly han-
dled, which can be relevant for custom applications.

1 < > & " &apos

16 / 59
Contd . . .

glide.ui.escape_special_chars_in_http_headers:
Determines whether special characters in HTTP headers are escaped.
Setting this property to true helps prevent potential security vulnerabilities by escaping
special characters in HTTP headers.

glide.ui.escape_query_string:
Controls whether special characters in URLs' query strings are automatically escaped.
Enabling this property by setting it to true helps prevent security risks related to query
string manipulation.

glide.ui.list.max_entries_per_page:
Species the maximum number of records displayed per page in list views.
One can adjust this property to control the number of records shown in lists across
the platform.

glide.ui.popup_maximum_height:
Sets the maximum height for pop-up windows.
Adjusting this property can prevent pop-ups from becoming too large and aecting
the user experience.

17 / 59
Contd . . .

glide.ui.popup_modal:
Determines whether pop-up windows are displayed as modal dialogs.
Setting this property to true makes pop-up windows modal, which can help users
focus on the content of the pop-up.

glide.ui.style:
Allows you to set a custom CSS style sheet for the entire UI.
You can dene your own styles to customize the look and feel of the platform.

glide.ui.theme:
Species the default theme for the user interface.
You can set this property to control the visual style applied to the platform, including
color schemes and styling.

glide.ui.date_format:
Denes the default date format used in the UI.
You can congure this property to determine how dates are displayed throughout the
platform.

18 / 59
Contd . . .

glide.ui.time_format:
Sets the default time format used in the UI.
You can customize this property to control the display of time values across the
platform.

To manage these properties, you can navigate to "System Properties" in the plat-
form and search for the specic properties you want to modify.

It is to be noted that modifying system properties can have signicant eects on


the behavior and security of your ServiceNow instance.

Therefore, it is important to understand the implications before making changes.

19 / 59
Conguring Service Portal

End users are not interested in understanding the tool, but expect a wonderful
looking, automated, easy to use and as-user-friendly-as-possible way to interact
with any system.

ServiceNow as a Platform allows developers to develop a rich and enhanced user


experience for its users on ServiceNow Platform, which is termed as Service Portal.

ServiceNow provides a default Service Portals for almost all popular applications
like Customer Service Management, IT Service Management, HR Management
GRC etc.

20 / 59
Service Portal Conguration (ServiceNow Customer Service Portal)
Go to your ServiceNow Instance and type Service Portal in lter navigator Service
Portal → Service Portal Conguration

21 / 59
Contd . . .
Click on Service Portal Conguration

22 / 59
Contd . . .

Branding Editor:
Click to go to branding editor.
Branding editor provides a feature to edit branding information of the portal such
as Portal Title, Logo, Tag Line, Background, text colors, and other theme-related
congurations.
One can navigate the Branding editor either from the top header bar or a tile given
in the middle.

Designer: Opens a Service Portal Page designer with Drag and Drop functionality
for page editing.

Portals: Opens a service portal editor where a portal can be selected from a drop-
down, and its properties can be changed.

Pages(On Header)/ Page Editor(from tile): Allows a Page editor to change


Service Portal Page properties. Such as page-specic CSS, Background info, Width
style, background style, etc.

23 / 59
Contd . . .

Widgets/ Widget Editor: Opens an editor where a service portal widget can be
selected from a drop-down and edited
Portal Tables
When clicked, it shows all Service Portal-related tables.
These tables stores scripts or any supporting congurations to a service portal/ Pages/
Widgets.

New Portal: When clicked, this will open a form to create a new Service Portal
Record from scratch.

Get Help: Redirects to Service Portal Documentation on ServiceNow Docs.

24 / 59
Congure a portal

Navigate to Service Portal → Portals and open an existing record to update or


click a `New Button' to create a new Portal from Scratch.

25 / 59
Contd . . .

Fill out the Service Portal form with the required details.

It will ask to enter the name of Service Portal, a portal URL, a home page, a 404
page, a login page, Main Menu eld to add a header menu, a Theme, a logo eld,
KB Homepage, Catalog Homepage Quickstart cong, etc.

26 / 59
Contd . . .

Search for sources, Service Catalogs, and Knowledge Bases can be added from
related lists of the portal records.

27 / 59
Contd . . .

Conguring a page
A Service Portal Page can be congured from a Page Editor to update Page
properties or a Page designer to edit page layout and widget placement.
Open Page in Page Editor/ Page Designer
From Related Link on the Page Record, choose the option

28 / 59
Contd . . .
Ctrl + Right Click on Portal Page and Select from the Drop-down

29 / 59
Contd . . .
Congure a Widget
A widget can be edited in native UI as a Form or from a widget editor.
A widget context menu appears on the service portal when you click `Ctrl + Right
Click.'
The widget context menu provides links to Instance Options, instance in Page Editor,
Page in Designer, Show widget customization, Edit Container Background, Widget
Option Schema, Widget Form Modal, Widget in Editor, Log to Console: $scope.data,
Log to console: $scope.
Edit Widget in Native UI: Go to Service Portal > Widget. Open an existing record
or Click new.
Fill in the necessary information like HTML Template, CSS, Client controller, Server
script, etc.

30 / 59
Service Portal Development
ServiceNow provides its solution for Portal and Portal Component design. Service
Portal uses HTML, CSS, Angular JS, and Javascript.
While designing and developing a Service Portal, keep in mind the below structure.
This structure will help to understand what component should be updated/ con-
gured and where it must be congured.

31 / 59
Contd . . .

Portal
The Parent is the Portal. One can say a Service Portal Record in the Portals table
The portal consists of One or Many pages
A portal has a theme that applies to the whole portal
There are search sources that dene what all results should the portal search return
It applies to tables in ServiceNow to provide the search results

Page
A Service Portal Page consists of one or many containers inside it
Widgets are placed inside containers only
A homepage is the rst page where you land once you log in to ServiceNow Service
Portal
A page can be reached via links provided on the widgets or menus
Use Page Route Map wherever possible

32 / 59
Contd . . .

Container
Widgets are placed inside containers
A container can have child containers as well
Each container can hold a maximum of one widget
The widget arrangement on a page is based on the container design
Each container can be divided up to a maximum of 12 compartments. Each com-
partment can then carry one widget
However, as per portal aesthetics, the container's minimum size should not go below
3

Widget
A widget is the core of the portal design.
Portal, Page, Container only provide the structure of how and where you can place
or track a particular component.
It is the widget responsible for representing the information on the portal

33 / 59
Contd . . .

Technology components
Angular JS: On Rome, the platform Service portal uses Angular 4 and supports
Angularjs 1.2.20 to 1.6.10
Service Portal widgets are developed using HTML. ServiceNow also has some
self-dened HTML tags. HTML is also used in Jelly Scripting for UI Pages and UI
Macro design, Email Notications, etc.
ServiceNow service portal development supports using CSS and SCSS. It also
supports up to Bootstrap 4.4.1.
ServiceNow platform, including Service Portal Development, supports using
JavaScript as a scripting language for client-side (browser end) and server-side
scripting.

Development Components
Service Portal UI is wholly based on widgets. Portal pages and containers provide a
placeholder for a widget.
Inside the widget, all the scripting like HTML, CSS, Angular, Javascript is done.
A widget can be edited from the widget Editor.
To open a widget editor, refer topic above as Introduction to Service Portal Congu-
ration.

34 / 59
Contd . . .

35 / 59
Contd . . .

Server Script
When the widget loads for the rst time. The script written in the Server Script
section runs rst.
Server Script is responsible for making any of CURD server operations using javascript.
ServiceNow also provides APIs to make server-side scripting more useful and easier.

For instance, $sp.getParameter(<parameter_name>) will fetch a value against a


Parameter given in the URL. For example, if the URL string is https://abc.service-
now.com/sp?id=top_apps&app_id=ServiceNow then using
$sp.getParameter (`app_id') will give the result as `ServiceNow.'

Some frequently used APIs are $sp.getWidget (<widget_id>, options),


$sp.canReadRecord(GlideRecord_Object), $sp.getValue("sys_id"),
$sp.getRecordValues(action),

36 / 59
Contd . . .

Client Controller
The client controller provides a space to write browser-side scripting using javascript.
It helps initiate client-side events, make calls to server scripts based on events and
send or receive
If any browser event tries to make a server side calls client controller allows to use
server.update(), server.get() and server.refresh().
https://serviceportal.io/docs/documentation/widget_client_script.md
To broadcast an event and listen it, you can use $rootScope.$broadcast('customEvent',
object) and $rootScope.$on('customEvent', function(event,object) respectively.
One can also use $emit in-place of $broadcast to send the events. The dierence between
the two is $broadcast sends the event downward from parent to child, and $emit sends
the event upward from child to all of its parents. https://serviceportal.io/using-events-
communicate-widgets/
Some commonly used Client controller APIs are spUtil.Recordwatch();

37 / 59
Contd . . .

Body HTML template


The UI Component which are visible on a page are designed using HTML.
In Body HTML template you can write HTML as per the requirement and design.
ServiceNow also provide some custom HTML tags for example <widget>
<sn-record-picker>

CSS section allows to add a styles to the elements in the widget.

The link function is used for DOM Manipulation from a widget.


Option schema
is an optional widget component. Option schema is used to create variables such that
a widget can be re-used.
Admin users dene instance options for a widget instance.

Dependencies (templates or widget angular provider):


Several pieces of code can be used in the widget by creating a relationship between
a widget and the code.
For example, a widget angular provider can provide additional functionality when
added to dependencies.
A CSS can be dened outside the widget and can be called and used in a widget.

38 / 59
Contd - Variables and Scopes used in the Service portal

Data
Data variable in service portal widget is an object that holds the data populated from
Server Script.
The same data is transferred to the browser end and can be accessed and represented
via Client Controller and Body HTML Template.
When the widget rst loads, the Server Script runs rst and loads data into Data
Variable.

Input
The input variable is populated with the same information held by the Data variable
once the Server Script completes the loading.
When a client event tries to call the server script, the data variable is cleared out (to
get new information in the data variable from the server script), and the previous
information can be accessed from Input Variable.

Options
Options variable helps design Option Schema of the widget.
Providing options to a widget allows developers to re-use the widget just by providing
some variable information.
Provide variable values from instance options of the widget.

39 / 59
Contd . . .
$Scope
As ServiceNow uses AngularJs in widget development, it uses the same concept of
angular scopes. $Scope a local scope of the widget and can be accessed within a
widget only.
$rootScope is a global scope, and variables dened in rootScope can be accessed
globally.

40 / 59
Contd . . .

Concept of Cloning a widget or a page


Any Service Portal page/widget can be cloned to make an exact copy of the existing
page.
This feature is useful when we clone OOB Service Portal pages/widgets to add extra
features to it.
ServiceNow recommends cloning the OOB pages/widgets if you want to make any
changes.
If any page/widget is custom or customized from OOB and it lands into any issues,
then ServiceNow doesn't support such page/widget.

A Service Portal can be developed in a custom application scope.

For this reason, a Service Portal can be a part of a custom application and can be
sold as a solution on ServiceNow Application Store.

41 / 59
Customize a Home Page

Administrators can customize the default homepages that appear for each user by
navigating to Homepage Admin → Pages and selecting the homepage.

Users who have roles can customize the homepages that are specied for their roles
by navigating to Self-Service → Homepage.

Procedure
Navigate to Homepage Admin → Pages.

Select the homepage to customize.

Click Edit Homepage. The homepage opens just as it does when you view it, but
it is in edit mode.

NOTE
Click Edit Homepage to make changes to a global homepage that take eect for
all users who can access the homepage.

If you click View Homepage and make changes, a personal homepage is automati-
cally created and those changes take eect only on that personal homepage.

To see the Edit Homepage link, one must enter a value in the View eld.

42 / 59
Contd . . .

Add items to the homepage.


Click Add Content.
Select from the homepage items that one can add.
Some items pertain to specic features and applications, such as CMS content blocks
and the Work Management dispatch map.
Note: Each widget on your homepage runs individually. For example, a homepage with
10 reports runs each report every time it refreshes. If your homepage consistently loads
slowly, try removing widgets to determine why.
Select an item to add
Reports: Reports to the homepage.
Knowledge Base: Knowledge base categories.
System Applications: Applications and modules.
Catalog Categories: Active service catalog categories. The homepage uses the desktop
icon of the category as the homepage icon.
Catalogs: Service catalogs, including all their active categories (starting with the Eureka
release).
Diagnostics: Information you can use for monitoring and troubleshooting your instance,
like database connections and JVM garbage collection.

43 / 59
Contd . . .

Reposition elements on your homepage by dragging and dropping them to a new


location.The change you make to the homepage is saved automatically.

To remove a homepage item, click the [X] on the right side of the header of the
item.

44 / 59
Styling Pages and Widgets

Styling pages and widgets in ServiceNow involves customizing the appearance of


your ServiceNow instance to match your organization's branding and design pref-
erences.

One can achieve this through CSS (Cascading Style Sheets) customization. Here
are the steps to style pages and widgets in ServiceNow

Styling Pages
Access the CSS Editor
Log in to your ServiceNow instance as an administrator or developer.
In the left navigation pane, search for and select "System UI" or "UI Properties."
Under "CSS Editor," you can add custom CSS code to style your pages.

Write Custom Code


In the CSS Editor, write custom CSS code to dene the styles you want for your
pages.
can use CSS to control various aspects of page styling, including colors, fonts, margins,
and more.

45 / 59
Contd . . .

For example, to change the background color of the page body, you might use
code like:

body {
background-color: #f2f2f2;
}
Apply Your CSS Styles
Save your custom CSS code, and the styles will be applied to all pages across your
ServiceNow instance.

Test Your Styles


Navigate to various pages in your ServiceNow instance to ensure that your custom
CSS styles are applied as expected. Make adjustments as needed.

46 / 59
Styling Widgets
Access the Widget Conguration
To style widgets, you will need to congure each widget individually.
Go to the page or Service Portal where the widget is displayed.

Edit the Widget:


Locate the widget you want to style on the page.
Depending on your instance's conguration, you may need to access the widget's
settings or conguration options.
Click on "Edit" or a similar option to open the widget for editing.

Apply Custom CSS Classes:


In the widget conguration, you can often nd a eld for adding custom CSS classes.
Assign a custom CSS class name to the widget. This class name will be used to apply
your custom styles.

Write Widget-Specic CSS:


In the CSS Editor (as mentioned earlier), write CSS rules targeting the custom CSS
class you assigned to the widget.
For example, if you assigned the class "my-custom-widget" to a widget, you can write
CSS rules like this:
.my-custom-widget {
background-color: #;
border: 1px solid #ccc;
/* Add other styles as needed */
}

47 / 59
Contd . . .

Save and Test


Save your widget conguration, and the custom styles will be applied to that specic
widget.
Test the widget on the page to ensure that the styles are correctly applied.

Repeat for Other Widgets:


If you have multiple widgets that require custom styling, repeat the above steps for
each widget.

Conclusion
By following these steps, one can customize the styling of both pages and widgets
in your ServiceNow instance to match your organization's branding and design
requirements.

It is to be noted that one should make sure to document your CSS customizations
and regularly test them to ensure they work as expected, especially after platform
updates or changes.

48 / 59
Setting-up the War Room Page

Setting up a War Room Page in ServiceNow involves creating a dedicated space


within the platform where your team can collaborate, monitor incidents, and man-
age critical situations eectively.

A War Room Page is typically used during incident response, major outages, or
other urgent scenarios.

Steps to Setup War Room Page


Log In to ServiceNow
Access your ServiceNow instance by entering the URL in your web browser.
Log in with your administrator or developer credentials.

Create a Dedicated War Room Space


To create a War Room Page, you typically start by creating a dedicated space or
portal for it.
In the left navigation pane, go to "Service Portal" or "Self-Service" (the name may
vary depending on your instance's conguration).
Click on "Service Portal Designer" to access the designer interface.

49 / 59
Contd . . .

Create a New War Room Page


In the Service Portal Designer, create a new page specically for your War Room.
Give it a descriptive name, such as War Room or Incident Response.

Design the War Room Page:


Use the Service Portal Designer's interface to design the War Room Page layout.
Add widgets, components, and sections that are relevant to your incident response
needs.
Typical components might include
Incident List: Display a list of ongoing incidents.
Chat or Communication Tools: Integrate chat functionality for real-time communication.
Metrics and Dashboards: Display key metrics and data related to ongoing incidents.
Knowledge Base: Provide access to relevant knowledge articles and documentation.
Task Lists: Show tasks or actions that need to be completed during incident response.
Escalation and Contact Information: Include contact details for key team members and
escalation procedures.

50 / 59
Contd . . .

Congure Widgets
Congure the widgets you added to the War Room Page to display the relevant
information and data.
For example, the Incident List widget should show active incidents, their statuses,
and priority levels.

Set Access Control


Determine who can access the War Room Page.
Congure access permissions in the Service Portal Designer to limit access to autho-
rized users or teams.

Publish the War Room Page


Once one have designed and congured the War Room Page, click the Publish
button or a similar option in the Service Portal Designer to make it available to users.

Test the War Room Page


After publishing, test the War Room Page to ensure that it displays as expected and
that all widgets and components function correctly.

51 / 59
Contd . . .

Promote Awareness
Inform your incident response team and relevant stakeholders about the War Room
Page.
Ensure that they know how to access it during critical incidents.

Use and Maintain


During incident response, use the War Room Page as the central hub for collaboration
and information sharing.
Continuously update and improve the page based on feedback and evolving incident
response needs.

Conclusion
Creating a War Room Page in ServiceNow can help streamline incident response
and ensure that your team has all the necessary tools and information at their
ngertips during critical situations.

52 / 59
Styling CMS

ServiceNow is a popular platform for IT service management and automation.

Styling the CMS (Content Management System) in ServiceNow typically involves


customizing the way your Service Portal or Content Management System pages
look and feel.

One can style it to match your organization's branding and provide a more user-
friendly experience.

Steps to Style CMS in ServiceNow


Service Portal Theme
ServiceNow Service Portal is a key component for building custom self-service portals.
Start by creating or customizing a Service Portal theme that aligns with your branding.
Themes in Service Portal allow you to control colors, fonts, and other design elements.

CSS Customization
To make more specic customizations, you'll likely need to write custom CSS.
ServiceNow allows you to add custom CSS rules to your Service Portal theme.
Create or edit a custom CSS le, and link it to your Service Portal theme.

53 / 59
Contd . . .

Page Customization
Customize individual CMS pages to have the desired layout and design. You can edit
these pages using the Service Portal Designer.

Header and Footer


Customize the header and footer components of your Service Portal.
Headers and Footers are usually standardized across your portal pages and play a
signicant role in branding.

Images and Icons


Upload and integrate custom images and icons that t your organization's branding.
Make sure to optimize images for web performance.

Typography
Dene fonts and text styling to ensure a consistent and appealing look for your
content.

Layouts and Widgets


Use Service Portal widgets to structure your page content. Customize these widgets
to control how content is displayed.

Responsive Design
Ensure that your Service Portal is responsive to various screen sizes and devices.
Test your design on dierent devices to make necessary adjustments.

54 / 59
Contd . . .

Accessibility
Implement accessibility features in your design to ensure that your portal is usable by
everyone.
Follow WCAG (Web Content Accessibility Guidelines) for accessibility compliance.

Testing and Validation


Regularly test your CMS styling across dierent browsers and devices.
Ensure that it loads correctly and looks good on all of them.

User Feedback
Collect feedback from users to identify areas where your CMS styling may need im-
provement.
This can be done through user testing and feedback forms.

Version Control
Use ServiceNow's version control system to track and manage changes to your CMS
styling.
This helps you maintain a history of your design changes.

55 / 59
Contd . . .

Security
Make sure that any custom code or plugins you add for styling do not introduce
security vulnerabilities.
Follow best practices for secure development.

Documentation:
Document your design decisions and customization steps for reference and to help
other team members.

56 / 59
Annexure - JSON Files

JSON (JavaScript Object Notation) is a lightweight data interchange format that is


commonly used for conguration and data storage in various applications, including
web services and APIs.

In ServiceNow, JSON les can be used for various purposes, such as dening
congurations, importing and exporting data, and more.

Common Scenarios in which JSON is used in ServiceNow


Conguration Files:
JSON les can be used to store conguration settings for various aspects of your
ServiceNow instance.
This could include settings related to custom applications, integrations, business rules,
and workows.

Data Imports and Exports:


JSON les are often used to import or export data to and from ServiceNow.
When importing data, one can use JSON les to provide the necessary data elds
and values.
When exporting data, ServiceNow can generate JSON les that contain the data one
want to share with other systems.

57 / 59
Contd . . .

Script Includes:
In ServiceNow, Script Includes are used to store reusable server-side JavaScript code.
These scripts can also be stored as JSON objects within Script Includes, allowing one
to dene and manage complex congurations or data structures.

REST API Integrations:


When interacting with external systems using RESTful APIs, JSON is a common
format for data exchange.
ServiceNow can send and receive JSON data when making API calls, and one may
need to work with JSON les to congure these integrations.

Client Scripts and UI Policies:


JSON objects can be used to dene conditions, scripts, and congurations for client-
side interactions.
This might include specifying eld visibility, required elds, or triggering certain ac-
tions based on user interactions.

Service Catalog Items:


JSON can be used to dene complex service catalog items with multiple variables,
conditions, and ordering details.

Custom Application Congurations:


JSON les can be used to store application-specic conguration settings that are
separate from ServiceNow's default conguration.

58 / 59
CSS Custom Properties for Themes

Using CSS custom properties (also known as CSS variables) for theming in Servi-
ceNow allows you to dene a set of reusable variables that control the appearance
of various elements throughout your instance.

This approach makes it easier to maintain consistent theming and update styles
across your application.

Custom properties can be dened to represent the various theme-related values you
want to control, such as colors, fonts, spacing, and more.

59 / 59

You might also like