Home > Domino Tips > Developer > JavaScript > How to add keyboard functionality for Lotus Notes documents
Domino Tips:
EMAIL THIS
 TIPS & NEWSLETTERS TOPICS 

JAVASCRIPT

How to add keyboard functionality for Lotus Notes documents


Manikandan C
09.19.2007
Rating: -2.33- (out of 5)


Lotus Notes and Domino tips, tutorials and how-to articles
Digg This!    StumbleUpon Toolbar StumbleUpon    Bookmark with Delicious Del.icio.us    Add to Google


This JavaScript code will let users navigate Lotus Notes view documents using their keyboard "Up" and "Down" arrow keys. It will also allow them to open Lotus Notes documents with the "Enter" key.

To implement this functionality, just follow these simple steps:
Related resources from SearchDomino.com:
JavaScript Learning Guide

FAQ: Lotus Notes, Domino and JavaScript

JavaScript Reference Center

  1. Create a $$ViewTemplateDefault or $$ViewTemplatefor<VIEWNAME> form.
  2. Create a <div> tag with the ID "ViewBody" and mark the <div> tag as "pass-through HTML."
  3. Embed the Lotus Notes view and select "Domino Web Access" -> "Display" -> "Using View's display property."
  4. Close the <div> tag.
  5. Create a <style> tag for setting height and scrollbar controls for the <div> tag.
  6. Add this JavaScript code in the "OnLoad()" event.
  7. view_onloadfunction();
    
  8. Add this JavaScript code in the JSHeader event of the form.
var rowid=1;
var totalrows = 0;
var keypress_scroll_limit = 20; 
// Adjust this value based on the height 
of the view var viewdivid = "ViewBody"; 
var rowhighlightimage = "/icons/expand.gif";

//function to set the keypress event and 
select the first row, this function called from 
'onload()' event function view_onloadfunction() 
{ selectRow(rowid); var viewdivobj = 
document.getElementsByName(viewdivid).item(0);
viewdivobj.onkeydown = view_keypressHandler;

// to set the table border and get the totalrows 
count var tableElements = viewdivobj.
getElementsByTagName('table');
var table = tableElements[
tableElements.length - 1] ; table.border=1;
 rows = table.getElementsByTagName("tr") ; 
totalrows = rows.length; }

// VIEW KEY PRESS HANDLER
function view_keypressHandler (evt)
{
  // make sure we have a valid event variable
  if(!evt && window.event) {
    evt = window.event;
  }
  var key = evt.keyCode;
 
  var KEYUP = 38;
  var KEYDOWN = 40;

    if (key == KEYUP) {
       if(rowid != 1) 
rowid = rowid -1;   
selectRow(rowid);   
// control the scrollbar movement while KEYUP 
if(rowid >= totalrows - keypress_scroll_limit)
return false;
 }
    if (key == KEYDOWN) {
    if(rowid>=totalrows-1) {
   rowid = rowid; }
else {
rowid = rowid + 1; } 
selectRow(rowid);
 // control the scrollbar movement while KEYDOWN
  if(rowid<=keypress_scroll_limit)   
 return false;  
 }
  return true;
}

//function to select a row
function selectRow(rownum)
{
var viewdivobj = document.
getElementsByName(viewdivid).item(0);
var tableElements = viewdivobj.
getElementsByTagName('table');
var table = tableElements[
tableElements.length - 1] ;
rows = table.getElementsByTagName("tr") ;
for( i = 1; i < rows.length; i++) {
if( i == rownum) { 
Atag = rows[i].
getElementsByTagName("A");
if(Atag.length > 0) { 
Ahref = Atag[0].href;
Atag[0].focus();
// By default domino create a 
blank image  in the first column, 
// we change the image src to our custom 
arrow image
AImage = rows[i].cells[0].
getElementsByTagName("IMG");
AImage[0].height = 10;
AImage[0].src = rowhighlightimage; 
// You can also use custom arrow image
 }
}
else {
AImage = rows[i].cells[0].
getElementsByTagName("IMG");
AImage[0].height = 0
AImage[0].src = "";
  }
 }
}

Do you have comments on this tip? Let us know.

This tip was submitted to the SearchDomino.com tip library by member Manikandan C. Please let others know how useful it is via the rating scale below. Do you have a useful Lotus Notes, Domino, Workplace or WebSphere tip or code snippet to share? Submit it to our monthly tip contest and you could win a prize.

Rate this Tip
To rate tips, you must be a member of SearchDomino.com.
Register now to start rating these tips. Log in if you are already a member.


Submit a Tip




Digg This!    StumbleUpon Toolbar StumbleUpon    Bookmark with Delicious Del.icio.us    Add to Google



RELATED CONTENT
JavaScript
Trap JavaScript runtime errors in Domino Web apps
JavaScript workaround fixes Lotus Notes 8.x PostOpen event issue
Write HTML and JavaScript in Notes view rows and columns on the Web
JavaScript detects Web browser type and version in Notes/Domino 8.0.2
JavaScript creates a jump box on a Lotus Notes Web form
How to create dynamic JavaScript in Notes Domino without formulas
Trap an attachment path via the Domino file upload control field
Converting Lotus Notes views to XML documents using JavaScript
Prevent errors on iFramed pages with JavaScript
Validate Lotus Notes Domino fields using JavaScript

JavaScript for Lotus Notes Domino
Trap JavaScript runtime errors in Domino Web apps
JavaScript workaround fixes Lotus Notes 8.x PostOpen event issue
Write HTML and JavaScript in Notes view rows and columns on the Web
JavaScript detects Web browser type and version in Notes/Domino 8.0.2
JavaScript creates a jump box on a Lotus Notes Web form
Top 10 Lotus Notes/Domino coding and development tips of 2008
How to create dynamic JavaScript in Notes Domino without formulas
Trap an attachment path via the Domino file upload control field
Converting Lotus Notes views to XML documents using JavaScript
Mimic Lotus Notes Domino application functionality on the Web

RELATED RESOURCES
2020software.com, trial software downloads for accounting software, ERP software, CRM software and business software systems
Search Bitpipe.com for the latest white papers and business webcasts
Whatis.com, the online computer dictionary

DISCLAIMER: Our Tips Exchange is a forum for you to share technical advice and expertise with your peers and to learn from other enterprise IT professionals. TechTarget provides the infrastructure to facilitate this sharing of information. However, we cannot guarantee the accuracy or validity of the material submitted. You agree that your use of the Ask The Expert services and your reliance on any questions, answers, information or other materials received through this Web site is at your own risk.



Domino & Lotus Notes Security Solutions: Authentication, Antispam, Encryption and Antivirus
HomeTopicsITKnowledge ExchangeTipsAsk the ExpertsMultimediaWhite PapersDomino IT Downloads
About Us  |  Contact Us  |  For Advertisers  |  For Business Partners  |  Site Index  |  RSS
SEARCH 
TechTarget provides technology professionals with the information they need to perform their jobs - from developing strategy, to making cost-effective purchase decisions and managing their organizations' technology projects - with its network of technology-specific websites, events and online magazines.

TechTarget Corporate Web Site  |  Media Kits  |  Site Map




All Rights Reserved, Copyright 1999 - 2009, TechTarget | Read our Privacy Policy
  TechTarget - The IT Media ROI Experts