Setting Worknotes field as mandatory on Problem recordIssue <!-- /*NS Branding Styles*/ --> .ns-kb-css-body-editor-container { p { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } span { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } h2 { font-size: 24pt; font-family: Lato; color: var(--now-color--text-primary, black); } h3 { font-size: 18pt; font-family: Lato; color: var(--now-color--text-primary, black); } h4 { font-size: 14pt; font-family: Lato; color: var(--now-color--text-primary, black); } a { font-size: 12pt; font-family: Lato; color: var(--now-color--link-primary, #00718F); } a:hover { font-size: 12pt; color: var(--now-color--link-primary, #024F69); } a:target { font-size: 12pt; color: var(--now-color--link-primary, #032D42); } a:visited { font-size: 12pt; color: var(--now-color--link-primary, #00718f); } ul { font-size: 12pt; font-family: Lato; } li { font-size: 12pt; font-family: Lato; } img { display: ; max-width: ; width: ; height: ; } } The Worknotes field is not set as mandatory on the Problem record when the problem record moves from 'New' to 'Assess' and 'Root Cause Analysis' to 'Fix in progress'. Facts<!-- /*NS Branding Styles*/ --> .ns-kb-css-body-editor-container { p { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } span { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } h2 { font-size: 24pt; font-family: Lato; color: var(--now-color--text-primary, black); } h3 { font-size: 18pt; font-family: Lato; color: var(--now-color--text-primary, black); } h4 { font-size: 14pt; font-family: Lato; color: var(--now-color--text-primary, black); } a { font-size: 12pt; font-family: Lato; color: var(--now-color--link-primary, #00718F); } a:hover { font-size: 12pt; color: var(--now-color--link-primary, #024F69); } a:target { font-size: 12pt; color: var(--now-color--link-primary, #032D42); } a:visited { font-size: 12pt; color: var(--now-color--link-primary, #00718f); } ul { font-size: 12pt; font-family: Lato; } li { font-size: 12pt; font-family: Lato; } img { display: ; max-width: ; width: ; height: ; } } Modifying onChange Client Script does not fulfil the request, since this is a modal setting that prevents making the field mandatory. Release<!-- /*NS Branding Styles*/ --> .ns-kb-css-body-editor-container { p { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } span { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } h2 { font-size: 24pt; font-family: Lato; color: var(--now-color--text-primary, black); } h3 { font-size: 18pt; font-family: Lato; color: var(--now-color--text-primary, black); } h4 { font-size: 14pt; font-family: Lato; color: var(--now-color--text-primary, black); } a { font-size: 12pt; font-family: Lato; color: var(--now-color--link-primary, #00718F); } a:hover { font-size: 12pt; color: var(--now-color--link-primary, #024F69); } a:target { font-size: 12pt; color: var(--now-color--link-primary, #032D42); } a:visited { font-size: 12pt; color: var(--now-color--link-primary, #00718f); } ul { font-size: 12pt; font-family: Lato; } li { font-size: 12pt; font-family: Lato; } img { display: ; max-width: ; width: ; height: ; } } Zurich Cause<!-- /*NS Branding Styles*/ --> .ns-kb-css-body-editor-container { p { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } span { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } h2 { font-size: 24pt; font-family: Lato; color: var(--now-color--text-primary, black); } h3 { font-size: 18pt; font-family: Lato; color: var(--now-color--text-primary, black); } h4 { font-size: 14pt; font-family: Lato; color: var(--now-color--text-primary, black); } a { font-size: 12pt; font-family: Lato; color: var(--now-color--link-primary, #00718F); } a:hover { font-size: 12pt; color: var(--now-color--link-primary, #024F69); } a:target { font-size: 12pt; color: var(--now-color--link-primary, #032D42); } a:visited { font-size: 12pt; color: var(--now-color--link-primary, #00718f); } ul { font-size: 12pt; font-family: Lato; } li { font-size: 12pt; font-family: Lato; } img { display: ; max-width: ; width: ; height: ; } } Resolution<!-- /*NS Branding Styles*/ --> .ns-kb-css-body-editor-container { p { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } span { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } h2 { font-size: 24pt; font-family: Lato; color: var(--now-color--text-primary, black); } h3 { font-size: 18pt; font-family: Lato; color: var(--now-color--text-primary, black); } h4 { font-size: 14pt; font-family: Lato; color: var(--now-color--text-primary, black); } a { font-size: 12pt; font-family: Lato; color: var(--now-color--link-primary, #00718F); } a:hover { font-size: 12pt; color: var(--now-color--link-primary, #024F69); } a:target { font-size: 12pt; color: var(--now-color--link-primary, #032D42); } a:visited { font-size: 12pt; color: var(--now-color--link-primary, #00718f); } ul { font-size: 12pt; font-family: Lato; } li { font-size: 12pt; font-family: Lato; } img { display: ; max-width: ; width: ; height: ; } } The out-of-the-box Assess UI Action calls ProblemModalUIHelpers.onAssess(). Since the onClick field is where the client-side execution begins, the work_notes validation can be added before onAssess(). Follow the steps below to create a new UI action to apply the required changes and deactivate the out-of-the-box UI Action: 1. Navigate to All > System Definition > UI Actions and filter to Problem table and name to Assess. 2. Open the Assess record: OnClick is onAssess(). Condition is current.canWrite() && new ProblemStateUtils().canAssess(current). And there is an onAssess() function in the Script. 3. Create a new record similar to the out-of-the-box UI Action in the previous step and add the desired changes: Name: Assess (Custom) Table: Problem Application: Global Orde: 100 Action name: move_to_assess Active, Show update, client, List V2 Compatible, Form button are selected. OnClick: checkWorkNotesAndAssess() Condition: current.canWrite() && new ProblemStateUtils().canAssess(current) Script: // This is out of the box function: function onAssess() { if (g_form && g_form.mandatoryCheck()) { ScriptLoader.getScripts("ProblemModalUIHelpers.jsdbx", function() { ProblemModalUIHelpers.onAssess(); }); } } // Add this function to set work_notes as mandatory: function checkWorkNotesAndAssess() { if (!g_form.getValue('work_notes') || g_form.getValue('work_notes').trim() === '') { g_form.setMandatory('work_notes', true); g_form.showFieldMsg('work_notes', 'Work notes are required before moving to Assess.', 'error'); g_form.scrollToField('work_notes'); return false; } // Work notes populated, proceed with OOB flow onAssess(); } 4. Save it. 5. Deactivate the out-of-the-box UI Action in step 2. 6. Confirm "Work notes" became mandatory by changing a problem from New to Assess. 7. Apply similar information when the problem record moves from 'Root Cause Analysis' to 'Fix in progress'. 8. (Optional) Since this is client-side, you can also add the Before Update Business Rule to enforce this at the server level:a. Navigate to All > System Definition > Business Rules b. Create New and configure: Name: Enforce Work Notes on Problem State Table: Problem [problem] Active and Advanced checked. When: Before Insert: Unchecked Update: Checked Condition: state | changes to | Assess or state | changes to | Fix in Progress Advanced Script: (function executeRule(current, previous /*null when async*/) { // Your code here if (!current.work_notes || current.work_notes.toString().trim() === '') { gs.addErrorMessage('Work notes are required when moving to Assess or Fix in Progress.'); current.setAbortAction(true); } })(current, previous); Note: Do not modify the out-of-the-box UI Action. Apply the required change to a new custom UI action.Validate the custom UI Action in the sub-product environment before Production. Related Links<!-- /*NS Branding Styles*/ --> .ns-kb-css-body-editor-container { p { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } span { font-size: 12pt; font-family: Lato; color: var(--now-color--text-primary, #000000); } h2 { font-size: 24pt; font-family: Lato; color: var(--now-color--text-primary, black); } h3 { font-size: 18pt; font-family: Lato; color: var(--now-color--text-primary, black); } h4 { font-size: 14pt; font-family: Lato; color: var(--now-color--text-primary, black); } a { font-size: 12pt; font-family: Lato; color: var(--now-color--link-primary, #00718F); } a:hover { font-size: 12pt; color: var(--now-color--link-primary, #024F69); } a:target { font-size: 12pt; color: var(--now-color--link-primary, #032D42); } a:visited { font-size: 12pt; color: var(--now-color--link-primary, #00718f); } ul { font-size: 12pt; font-family: Lato; } li { font-size: 12pt; font-family: Lato; } img { display: ; max-width: ; width: ; height: ; } } KB0831615: Post button disappears when work notes field is made mandatory by UI Policy or Client Script