From 740939ec61b1ae35ff87b30ef8661da8e2be23e3 Mon Sep 17 00:00:00 2001 From: tjhunt Date: Thu, 25 Sep 2008 10:07:11 +0000 Subject: [PATCH] MDL-16654 Move javascript used by the emoticons help file from javascript.php to javascript-static.js. Fix it so that it actually works. --- help.php | 25 +------------ lang/en_utf8/help/emoticons.html | 5 +++ lib/javascript-static.js | 33 ++++++++++++++++- lib/javascript.php | 63 ++++++++++---------------------- lib/weblib.php | 48 ++++++++++++++++++++---- 5 files changed, 99 insertions(+), 75 deletions(-) diff --git a/help.php b/help.php index e170c6ec619..7a89337ae0a 100644 --- a/help.php +++ b/help.php @@ -142,7 +142,7 @@ if(preg_match('~^(.*?)(.*?)(.*)$~s',$output,$matches)) { // use ##emoticons_html## to replace the emoticons documentation if(preg_match('~(##emoticons_html##)~', $output, $matches)) { - $output = preg_replace('~(##emoticons_html##)~', get_emoticons_html(), $output); + $output = preg_replace('~(##emoticons_html##)~', get_emoticons_list_for_help_file(), $output); } // Do the main output. @@ -163,29 +163,6 @@ echo '

'. get_string('hel $CFG->docroot = ''; // We don't want a doc link here print_footer('none'); -// Utility function ================================================================= - -function get_emoticons_html(){ - global $CFG; - $output = ''; - $emoticonstring = $CFG->emoticons; - $output .= '

'; - return $output; - -} - function file_exists_and_readable($filepath) { return file_exists($filepath) and is_file($filepath) and is_readable($filepath); } diff --git a/lang/en_utf8/help/emoticons.html b/lang/en_utf8/help/emoticons.html index db97c4f2388..99ee6b78ec2 100644 --- a/lang/en_utf8/help/emoticons.html +++ b/lang/en_utf8/help/emoticons.html @@ -1,5 +1,10 @@

Using Smilies (emoticons)

+ +
diff --git a/lib/javascript-static.js b/lib/javascript-static.js index 5670f0da485..8959784abd4 100644 --- a/lib/javascript-static.js +++ b/lib/javascript-static.js @@ -514,7 +514,7 @@ function getElementsByClassName(oElm, strTagName, oClassNames){ } function openpopup(url, name, options, fullscreen) { - var fullurl = moodle_config.wwwroot + url; + var fullurl = moodle_cfg.wwwroot + url; var windowobj = window.open(fullurl,name,options); if (fullscreen) { windowobj.moveTo(0,0); @@ -523,3 +523,34 @@ function openpopup(url, name, options, fullscreen) { windowobj.focus(); return false; } + +/* This is only used on a few help pages. */ +emoticons_help = { + inputarea: null, + + init: function(formname, fieldname, listid) { + if (!opener || !opener.document.forms[formname]) { + return; + } + emoticons_help.inputarea = opener.document.forms[formname][fieldname]; + if (!emoticons_help.inputarea) { + return; + } + var emoticons = document.getElementById(listid).getElementsByTagName('li'); + for (var i = 0; i < emoticons.length; i++) { + var text = emoticons[i].getElementsByTagName('img')[0].alt; + YAHOO.util.Event.addListener(emoticons[i], 'click', emoticons_help.inserttext, text); + } + }, + + inserttext: function(e, text) { + text = ' ' + text + ' '; + if (emoticons_help.inputarea.createTextRange && emoticons_help.inputarea.caretPos) { + var caretPos = emoticons_help.inputarea.caretPos; + caretPos.text = caretPos.text.charAt(caretPos.text.length - 1) == ' ' ? text + ' ' : text; + } else { + emoticons_help.inputarea.value += text; + } + emoticons_help.inputarea.focus(); + } +} \ No newline at end of file diff --git a/lib/javascript.php b/lib/javascript.php index 69a273cbb47..a691468e363 100644 --- a/lib/javascript.php +++ b/lib/javascript.php @@ -1,17 +1,15 @@ editorsrc)) { + foreach ( $CFG->editorsrc as $scriptsource ) { + echo ''."\n"; } - - if (can_use_html_editor() && !empty($CFG->editorsrc)) { - foreach ( $CFG->editorsrc as $scriptsource ) { - echo ''."\n"; - } - } - +} ?> @@ -30,40 +28,19 @@ setTimeout('fix_column_widths()', 20); \n"; + $focus = false; // Prevent themes from adding it to body tag which breaks addonload(), MDL-10249 +} ?> +//]]> + diff --git a/lib/weblib.php b/lib/weblib.php index d9917b4dc14..0bf3b5f40b0 100644 --- a/lib/weblib.php +++ b/lib/weblib.php @@ -2040,6 +2040,40 @@ function replace_smilies(&$text) { } } +/** + * This code is called from help.php to inject a list of smilies into the + * emoticons help file. + * + * @return string HTML for a list of smilies. + */ +function get_emoticons_list_for_help_file(){ + global $CFG, $SESSION; + if (empty($CFG->emoticons)) { + return ''; + } + + require_js(array('yui_yahoo', 'yui_event')); + $items = explode('{;}', $CFG->emoticons); + $output = '
    '; + foreach ($items as $item) { + $item = explode('{:}', $item); + $output .= '
  • ' .
+                $item[0] . '' . $item[0] . '
  • '; + } + $output .= '
'; + if (!empty($SESSION->inserttextform)) { + $formname = $SESSION->inserttextform; + $fieldname = $SESSION->inserttextfield; + } else { + $formname = 'theform'; + $fieldname = 'message'; + } + + $output .= print_js_call('emoticons_help.init', array($formname, $fieldname, 'emoticonlist'), true); + return $output; + +} + /** * Given plain text, makes it into HTML as nicely as possible. * May contain HTML tags already @@ -2716,12 +2750,12 @@ function print_js_config($settings = array(), $prefix='', $return = false) { // Have to treat the prefix and no prefix cases separately. if ($prefix) { // Recommended way, only one thing in global scope. - $html .= 'var $name = ' . json_encode($settings) . "\n"; + $html .= "var $prefix = " . json_encode($settings) . "\n"; } else { // Old fashioned way. foreach ($settings as $name => $value) { - $html .= "var " . $name . " = '" . addslashes_js($value) . "'\n"; + $html .= "var $name = '" . addslashes_js($value) . "'\n"; } } @@ -5797,9 +5831,9 @@ function editorhelpbutton(){ $urlparams[] = "module$i=".urlencode($item[2]); } $titles[] = trim($item[1], ". \t"); - }elseif (is_string($item)){ + } else if (is_string($item)) { $urlparams[] = "button$i=".urlencode($item); - switch ($item){ + switch ($item) { case 'reading' : $titles[] = get_string("helpreading"); break; @@ -5809,13 +5843,13 @@ function editorhelpbutton(){ case 'questions' : $titles[] = get_string("helpquestions"); break; - case 'emoticons' : + case 'emoticons2' : $titles[] = get_string("helpemoticons"); break; - case 'richtext' : + case 'richtext2' : $titles[] = get_string('helprichtext'); break; - case 'text' : + case 'text2' : $titles[] = get_string('helptext'); break; default :