From b1112787e60be712d508e80baaf0d6f9a861f0ac Mon Sep 17 00:00:00 2001
From: Ben Coburn <btcoburn@silicodon.net>
Date: Fri, 28 Apr 2006 03:51:58 +0200
Subject: [PATCH] accesskey tooltip rewriting

Does client-side rewriting of accesskey tooltip text so that it will be
more OS and browser specific. Dokuwiki should output all accesskey tooltips
as [ALT+<key>] because this patch matches on "[ALT+".

darcs-hash:20060428015158-05dcb-0102a1b2068c053e81dd21ad3927c78b6c9f349e.gz
---
 inc/html.php          |  2 +-
 lib/exe/js.php        |  3 ++-
 lib/scripts/script.js | 27 +++++++++++++++++++++++++++
 3 files changed, 30 insertions(+), 2 deletions(-)

diff --git a/inc/html.php b/inc/html.php
index 908849d2b..6d0b7e116 100644
--- a/inc/html.php
+++ b/inc/html.php
@@ -248,7 +248,7 @@ function html_btn($name,$id,$akey,$params,$method='get'){
 
   $ret .= '<input type="submit" value="'.htmlspecialchars($label).'" class="button" ';
   if($akey){
-    $ret .= 'title="ALT+'.strtoupper($akey).'" ';
+    $ret .= 'title="[ALT+'.strtoupper($akey).']" ';
     $ret .= 'accesskey="'.$akey.'" ';
   }
   $ret .= '/>';
diff --git a/lib/exe/js.php b/lib/exe/js.php
index f18edc5d6..5c7ee1dbd 100644
--- a/lib/exe/js.php
+++ b/lib/exe/js.php
@@ -121,7 +121,8 @@ function js_out(){
     // load user script
     @readfile(DOKU_CONF.'userscript.js');
 
-    // add scroll event
+    // add scroll event and tooltip rewriting
+    js_runonstart('updateAccessKeyTooltip()');
     js_runonstart('scrollToMarker()');
 
     // initialize init pseudo event
diff --git a/lib/scripts/script.js b/lib/scripts/script.js
index 87fd8e503..d6be1cba9 100644
--- a/lib/scripts/script.js
+++ b/lib/scripts/script.js
@@ -16,6 +16,33 @@ if (clientPC.indexOf('opera')!=-1) {
     var is_opera_seven = (window.opera && document.childNodes);
 }
 
+/**
+ * Rewrite the accesskey tooltips to be more browser and OS specific.
+ *
+ * Accesskey tooltips are still only a best-guess of what will work
+ * on well known systems.
+ *
+ * @author Ben Coburn <btcoburn@silicodon.net>
+ */
+function updateAccessKeyTooltip() {
+  // determin tooltip text (order matters)
+  var tip = 'ALT+'; //default
+  if (domLib_isMac) { tip = 'CTRL+'; }
+  if (domLib_isOpera) { tip = 'SHIFT+ESC '; }
+  // add other cases here...
+
+  // do tooltip update
+  if (tip=='ALT+') { return; }
+  var exp = /\[ALT\+/i;
+  var rep = '['+tip;
+  var elements = domLib_getElementsByTagNames(['a', 'input', 'button']);
+  for (var i=0; i<elements.length; i++) {
+    if (elements[i].accessKey.length==1 && elements[i].title.length>0) {
+      elements[i].title = elements[i].title.replace(exp, rep);
+    }
+  }
+}
+
 /**
  * Handy shortcut to document.getElementById
  *
-- 
GitLab