
catalog-items
by groeimetai
ð€ AI-powered ServiceNow development with 400+ MCP tools. Works with Claude, GPT, Gemini, Ollama & 75+ providers. Deploy widgets, manage incidents, automate workflows - all through natural language. Open-source Build Agent alternative.
SKILL.md
name: catalog-items description: This skill should be used when the user asks to "create catalog item", "service catalog", "request item", "catalog variables", "variable set", "catalog client script", "order guide", "record producer", or any ServiceNow Service Catalog development. license: Apache-2.0 compatibility: Designed for Snow-Code and ServiceNow development metadata: author: groeimetai version: "1.0.0" category: servicenow tools:
- snow_catalog_item_create
- snow_catalog_variable_create
- snow_query_table
- snow_find_artifact
Service Catalog Development for ServiceNow
The Service Catalog allows users to request services and items through a self-service portal.
Catalog Components
| Component | Purpose | Example |
|---|---|---|
| Catalog | Container for categories | IT Service Catalog |
| Category | Group of items | Hardware, Software |
| Item | Requestable service | New Laptop Request |
| Variable | Form field on item | Laptop Model dropdown |
| Variable Set | Reusable variable group | User Details |
| Producer | Creates records directly | Report an Incident |
| Order Guide | Multi-item wizard | New Employee Setup |
Catalog Item Structure
Catalog Item: Request New Laptop
âââ Variables
â âââ laptop_model (Reference: cmdb_model)
â âââ reason (Multi-line text)
â âââ urgency (Choice: Low, Medium, High)
âââ Variable Sets
â âââ Delivery Information (Address, Contact)
âââ Catalog Client Scripts
â âââ onLoad: Set defaults
â âââ onChange: Update price
âââ Workflows/Flows
â âââ Laptop Approval Flow
âââ Fulfillment
âââ Creates Task for IT
Variable Types
| Type | Use Case | Example |
|---|---|---|
| Single Line Text | Short input | Employee ID |
| Multi Line Text | Long input | Business Justification |
| Select Box | Single choice | Priority |
| Check Box | Yes/No | Express Delivery |
| Reference | Link to table | Requested For |
| Date | Date picker | Needed By Date |
| Lookup Select Box | Filtered reference | Model by Category |
| List Collector | Multiple selections | CC Recipients |
| Container Start/End | Visual grouping | Hardware Options |
| Macro | Custom widget | Cost Calculator |
Creating Catalog Variables
Basic Variable
// Via MCP
snow_create_catalog_variable({
catalog_item: 'laptop_request',
name: 'laptop_model',
type: 'reference',
reference: 'cmdb_model',
reference_qual: 'category=computer',
mandatory: true,
order: 100
});
Variable with Dynamic Default
// Variable: requested_for
// Type: Reference (sys_user)
// Default value (script):
javascript:gs.getUserID()
Variable with Reference Qualifier
// Variable: assignment_group
// Type: Reference (sys_user_group)
// Reference Qualifier:
// Simple:
active=true^type=it
// Dynamic (Script):
javascript: 'active=true^manager=' + gs.getUserID()
// Advanced (using current variables):
javascript: 'u_department=' + current.variables.department
Catalog Client Scripts
Set Defaults onLoad
function onLoad() {
// Set default values
g_form.setValue('urgency', 'low');
// Hide admin-only fields
if (!g_user.hasRole('catalog_admin')) {
g_form.setDisplay('cost_center', false);
}
// Set default date to tomorrow
var tomorrow = new GlideDateTime();
tomorrow.addDays(1);
g_form.setValue('needed_by', tomorrow.getDate().getValue());
}
Dynamic Pricing onChange
function onChange(control, oldValue, newValue, isLoading) {
if (isLoading) return;
// Get price from selected model
var ga = new GlideAjax('CatalogUtils');
ga.addParam('sysparm_name', 'getModelPrice');
ga.addParam('sysparm_model', newValue);
ga.getXMLAnswer(function(price) {
g_form.setValue('item_price', price);
updateTotal();
});
}
function updateTotal() {
var price = parseFloat(g_form.getValue('item_price')) || 0;
var quantity = parseInt(g_form.getValue('quantity')) || 1;
g_form.setValue('total_cost', (price * quantity).toFixed(2));
}
Validation onSubmit
function onSubmit() {
// Validate business justification for high-cost items
var cost = parseFloat(g_form.getValue('total_cost'));
var justification = g_form.getValue('business_justification');
if (cost > 1000 && !justification) {
g_form.showFieldMsg('business_justification',
'Required for items over $1000', 'error');
return false;
}
// Validate date is in future
var neededBy = g_form.getValue('needed_by');
var today = new GlideDateTime().getDate().getValue();
if (neededBy < today) {
g_form.showFieldMsg('needed_by',
'Date must be in the future', 'error');
return false;
}
return true;
}
Variable Sets
Creating Reusable Variable Sets
Variable Set: User Contact Information
âââ contact_name (Single Line Text)
âââ contact_email (Email)
âââ contact_phone (Single Line Text)
âââ preferred_contact (Choice: Email, Phone, Either)
Use in multiple catalog items:
- New Laptop Request
- Software Installation
- Network Access Request
Accessing Variable Set Values
// In workflow or script
var ritm = current; // sc_req_item
// Access variable from variable set
var contactEmail = ritm.variables.contact_email;
var preferredContact = ritm.variables.preferred_contact;
Catalog Workflows/Flows
Approval Pattern
Flow Trigger: sc_req_item created
âââ If: Total cost > $5000
â âââ Request Approval: Department Manager
â âââ If: Rejected
â âââ Update: RITM state = Closed Incomplete
âââ If: Total cost > $25000
â âââ Request Approval: VP
âââ Create: Catalog Task for Fulfillment
âââ Wait: Task completion
Fulfillment Script
// In catalog item's "Execution Plan" or workflow
var ritm = current; // sc_req_item
// Create an incident from catalog request
var inc = new GlideRecord('incident');
inc.initialize();
inc.setValue('short_description', ritm.short_description);
inc.setValue('description', ritm.description);
inc.setValue('caller_id', ritm.request.requested_for);
inc.setValue('category', ritm.variables.category);
inc.setValue('priority', ritm.variables.urgency);
inc.insert();
// Link incident to request
ritm.setValue('u_fulfillment_record', inc.getUniqueValue());
ritm.update();
Record Producers
Creating Incidents via Catalog
// Record Producer: Report an Issue
// Table: incident
// Script:
// Map variables to incident fields
current.short_description = producer.short_description;
current.description = producer.description;
current.caller_id = gs.getUserID();
current.category = producer.category;
current.subcategory = producer.subcategory;
current.priority = producer.urgency == 'urgent' ? '2' : '3';
// Set assignment based on category
if (producer.category == 'network') {
current.assignment_group.setDisplayValue('Network Support');
} else {
current.assignment_group.setDisplayValue('Service Desk');
}
Order Guides
Multi-Step Request Wizard
Order Guide: New Employee Onboarding
âââ Step 1: Employee Information
â âââ Variable Set: Employee Details
âââ Step 2: Hardware Selection
â âââ Catalog Item: Laptop
â âââ Catalog Item: Monitor
â âââ Catalog Item: Peripherals
âââ Step 3: Software Requests
â âââ Rule: Show software based on department
âââ Step 4: Access Requests
â âââ Cascade Variable: Copy employee info
âââ Submit: Creates multiple RITMs
Order Guide Rule
// Rule: Show software items based on department
function rule(item, guide_variables) {
var dept = guide_variables.department;
// Show engineering software only for Engineering
if (item.name == 'Engineering Software Suite') {
return dept == 'engineering';
}
// Show finance software only for Finance
if (item.name == 'Financial Tools') {
return dept == 'finance';
}
return true; // Show all other items
}
Pricing & Approvals
Dynamic Pricing
// Catalog Item Script (Pricing)
// Runs when item is added to cart
var basePrice = parseFloat(current.price) || 0;
var quantity = parseInt(current.variables.quantity) || 1;
var expedited = current.variables.expedited == 'true';
var total = basePrice * quantity;
if (expedited) {
total *= 1.5; // 50% rush fee
}
current.recurring_price = 0;
current.price = total;
Approval Rules
Approval Definition: High-Value Purchases
Condition: total_cost > 5000
Approver: requested_for.manager
Wait for: Approval
Rejection action: Cancel request
Best Practices
- Variable Naming - Use descriptive, lowercase names (no spaces)
- Variable Sets - Reuse common variable groups
- Reference Qualifiers - Filter to relevant records only
- Client Scripts - Minimize server calls (use GlideAjax sparingly)
- Fulfillment - Create tasks, don't complete directly
- Testing - Test as different user roles
- Mobile - Test catalog items on mobile/tablet
- Documentation - Add help text to variables
ã¹ã³ã¢
ç·åã¹ã³ã¢
ãªããžããªã®åè³ªææšã«åºã¥ãè©äŸ¡
SKILL.mdãã¡ã€ã«ãå«ãŸããŠãã
ã©ã€ã»ã³ã¹ãèšå®ãããŠãã
100æå以äžã®èª¬æããã
GitHub Stars 100以äž
3ã¶æä»¥å ã«æŽæ°
10å以äžãã©ãŒã¯ãããŠãã
ãªãŒãã³Issueã50æªæº
ããã°ã©ãã³ã°èšèªãèšå®ãããŠãã
1ã€ä»¥äžã®ã¿ã°ãèšå®ãããŠãã
ã¬ãã¥ãŒ
ã¬ãã¥ãŒæ©èœã¯è¿æ¥å ¬éäºå®ã§ã


