Using JavaScript in PeopleSoft: Creating your own dialog boxes
2012-06-07 15:54
477 查看
Using JavaScript in PeopleSoft: Creating your own dialog boxes
In previous posts, I've described how I have been using JavaScript to enhance our PeopleTools 8.49 application. I've covered calculations and validation, and showed how you can proxy "delivered" PeopleSoft JavaScript toenhance your pages.In this post I'll show how we are replacing the Peoplesoft confirmation (Yes/No OK/Cancel) message box with our own slick modal dialog boxes. I'm sure you'll agree with me that the bare, ugly pages produced by using PeopleCode messageBox() for confirmation
aren't up to modern web standards. I went searching for a way to replace it. I found jQuery UI dialog. jQuery UI is a jQuery plugin designed to provide JavaScript UI elements that complement
jQuery. Dialog
provides a robust set of tools for creating flexible client-side dialog boxes. Here's an example of a typical OK/Cancel confirmation dialog produced by Dialog.
Dialogs are typically defined statically and called by dynamic Javascript. I've settled on a pattern that seems to work well with PeopleSoft. I define the dialog based on an empty <div>, but set most of the properties, including the html displayed in the dialog,
from the event-driven code and bind variables.Here's a typical definition.
var $confirmDialog = $('<div></div>').dialog({ title: '%BIND(:10)', autoOpen: false, resizable: false, modal: true, minHeight: 400, minWidth: 350, buttons: { OK: confirmOK, Cancel: confirmCancel } });A few things to notice. The dialog html is an empty div (<div></div>). The actually html shown in the dialog is set when it is called from a function. I'm setting the dialog title with a bind variable. autoOpen is set to false; otherwise the dialog would
open when the page is loaded. The button actions are defined as named functions. They can be anonymous functions, but I find that using named functions here is cleaner, more flexible and can be reused. In many cases, I replace the actions when I call the dialog.Here' s a function that calls the $confirmDialog:
function confirmIt(msg){ //msg must be formated as html $confirmDialog.dialog('option' , 'height', 450); $confirmDialog.dialog('option' , 'width', 400); $confirmDialog.dialog('option' , 'buttons' , {OK: confirmSubmit, Cancel: closeDialog} ); $confirmDialog.html(msg); $confirmDialog.dialog('open'); }In this case, I'm replacing the button functions with:
// OK button function for confirm dialog var confirmSubmit = function() { $(this).dialog('close'); $('#TC_DERIVED_CONFIRMED').val('Y'); //hidden field return submitProxied.apply(window, localArgs); // continue submit process }; var closeDialog = function(){ confirmed = false; $(this).dialog('close'); }confirmSubmit:closes the dialog box;
sets a hidden field that I've added to the page with JavaScript following the PeopleTools naming convention that I can query in PeopleCode to confirm that the user has confirmed the submit on the client-side;
passes the processing to the standard PeopleTools submit processing JavaScript. (I describe how this works in a previous post.)closeDialog sets global confirmed to false and closes the dialog. This, in effect, cancels the submit and leaves the user on the original page.You can define as many buttons as you wish, each with its own function.The Validation ChainThis works fine for a single-step confirmation - something like "Submit your timesheet? You will not be able to make further changes. OK Cancel." But when you call a dialog box you are turning over processing to the dialog code. Unlike a PeopleSoft messageBox,
it never returns a value to the calling code. So, what if you need to process several validations and confirmations? To handle this, I use a technique I call the validation chain. In the validation chain, each step is a function that can stop the processing
or call the next step until the chain is complete.Here's an example.
function myFunction () { ... //validationChain is declared global
validationChain = [validateInOut,validateZeroHours,validateTimeOnHoliday,validateSubmit];
return nextValidation();
...
} // call the next validation in the chain function nextValidation() { var next = validationChain.shift(); var nextUndefined = next == undefined; if (!nextUndefined) { return next() }; return true; }First, we set up a global array of validation/confirmation functions; the validation chain. Then we call
nextValidation().nextValidation removes the first function from the chain and stores it in variable
next. Then, if the function is defined, it is called.Now each function can do validation or confirmation including calling a dialog box. To stop the process the function returns false. To continue, the function, or the dialog it calls, calls nextValidation().
Here's an example validation function that can be added to the validation chain:
// User confirms time on holiday function validateTimeOnHoliday() { if (timeOnHoliday()){ var msg = '%BIND(:2)'. replace('%1',holidayDateString); $confirmDialog.dialog('option' , 'buttons' , {OK: confirmContinue, Cancel: closeDialog} ); $confirmDialog.html(msg); $confirmDialog.dialog('open'); return false; // we'll only get here if the user cancels } else { return nextValidation() }; }
// Continue button function for validation chain dialog
var confirmContinue = function() {
$(this).dialog('close');
return nextValidation();
}
// Close the dialog without taking any action - this will end the validation chainvar closeDialog = function(){$(this).dialog('close');}Now you can call any number of validations and confirmations before submitting the page to the server.I hope you have found my JavaScript blog entries helpful. If you have your own ideas on how to use JavaScript to improve PeopleSoft applications, please let me know.
相关文章推荐
- Using JavaScript in PeopleSoft: Proxy PeopleSoft Functions
- Creating and Using Your Own Delegates in Objective-C
- Summary : Creating Dialog Boxes using ASP.NET, JavaScript and IE
- Creating your own header file in C
- Using Your Own Model in train
- Create Google Maps directions in PeopleSoft using Related Content
- Three Types of Dialog Boxes in JavaScript
- Embed an HTML control in your own window using plain C
- Using MC.exe, message resources and the NT event log in your own projects
- Embed an HTML control in your own window using plain C
- Embed an HTML control in your own window using plain C
- javascript debut trick, using the throw to make a interrupt(breakpoint) in your program
- Creating Your Own Widgets using SWT
- Start your own JavaScript library using webpack and ES6
- Check/Un-Check checkboxes items in ASP.NET DataGrid using JavaScript
- Reporting Crashes in IMVU: Creating Your Very Own Symbol Server
- Embed an HTML control in your own window using plain C
- Creating Vista Gadgets: Using HTML, CSS and JavaScript with Examples in RSS, Ajax, ActiveX (COM) and
- 【转】Build Your own Simplified AngularJS in 200 Lines of JavaScript
- Creating your own JavaScript Library