- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎06-13-2017 08:03 PM
Hi: I have the variable editor displayed on request items on the portal as such:
As you can see the variable editor fields are editable. I need to make them read only after the request is submitted. I tried the following client script on Both UI Type but it didn't seem to work:
function onLoad() {
//Type appropriate comment here, and begin script below
if(g_user.hasRole('admin')) {
g_form.setVariablesReadOnly(false); //so that admins can edit the variables.
} else {
g_form.setVariablesReadOnly(true);
}
}
Any ideas?
Thank you!
Solved! Go to Solution.
- Labels:
-
Service Portal Development
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎06-15-2017 02:13 PM
Hi Rita,
Firstly, sorry for the delay - I wasn't online yesterday.
So let's get into it!
1. You might also want to remove the 'Save' button from it - you can do this by simply commenting out the line in HTML with element <button>, or the whole footer div
2. Important remark is, that we will not be able to embed the widget at exactly the same place as the original variables were. It's because the whole form is being generated dynamically from the script. What we can do, is to place it at the very beginning, or very end - before the buttons.
So if we want to put it in the beginning, open your cloned form widget in editor and in HTML go somewhere about line 62, where you see <!-- form -->
right before it place these lines:
<!-- Embedded variables -->
<sp-widget widget="data.embedVariables"></sp-widget>
If you want the variables after the form, place the lines right before the <!-- UI Action Links -->
3. Go to server script part and somewhere where the data objects are assigned, place this line
data.embedVariables = $sp.getWidget('your_cloned_variables_widget');
And this should work. Again, if you're using this page for more than just sc_req_item, you need to embed a condition so your variables are called only for the tables that can have variables. It could look like this:
HTML:
<!-- Embedded variables -->
<div ng-if="data.hasVariables">
<sp-widget widget="data.embedVariables"></sp-widget>
</div>
Server Script: (almost at the end - maybe right before the line // Activity formatter is hardcoded to set specific options)
if (data.table == 'sc_req_item') {
data.hasVariables = true;
}
Hope this helps!
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎06-13-2017 08:27 PM
Hi,
Does the read only variables field work in the back end?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎06-13-2017 08:36 PM
Hi: Yes in the tool, the read only works as expected, but on the portal it does not.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎06-13-2017 08:47 PM
Hi Rita,
So once the request is submitted the variables in RITM variable tab are editable?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎06-13-2017 08:48 PM
On the service portal, yes. Thanks
Sent from my iPhone