Index: openacs-4/packages/acs-templating/tcl/richtext-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/acs-templating/tcl/richtext-procs.tcl,v diff -u -r1.48 -r1.49 --- openacs-4/packages/acs-templating/tcl/richtext-procs.tcl 12 Jul 2009 01:10:26 -0000 1.48 +++ openacs-4/packages/acs-templating/tcl/richtext-procs.tcl 13 Sep 2009 23:54:42 -0000 1.49 @@ -83,16 +83,6 @@ # enhanced text and HTML needs to be security checked if { [lsearch { text/enhanced text/html } $format] != -1 } { - # don't check, if user is side-wide admin or a package admin - # -gustaf neumann - if {[acs_user::site_wide_admin_p] || - ([ns_conn isconnected] - && [ad_conn user_id] != 0 - && [permission::permission_p -object_id [ad_conn package_id] -privilege admin \ - -party_id [ad_conn user_id]])} { - return 1 - } - set check_result [ad_html_security_check $contents] if { $check_result ne "" } { set message $check_result @@ -439,17 +429,19 @@ set user_agent [string tolower [ns_set get [ns_conn headers] User-Agent]] - if {[string first "chrome" $user_agent] != -1} { + if {[string first "chrome" $user_agent] != -1} { # vguerra: google chrome browser # needs more testing in order to check if chrome fully # supports xinha - # roc: this check has to go first since safari use applewebkit, so the agent always contain safari word - # once xinha officially support chrome (already supports safari), we can remove this if and add the check at the next if. - } elseif {[string first "safari" $user_agent] != -1} { + # roc: this check has to go first since safari use applewebkit, + # so the agent always contain safari word + # once xinha officially support chrome (already supports safari), we + # can remove this if and add the check at the next if. + } elseif {[string first "safari" $user_agent] != -1} { regexp {version/([0-9]+)[.]} $user_agent _ user_agent_version - if {$user_agent_version < 3} { - set element(htmlarea_p) false - } + if {$user_agent_version < 3} { + set element(htmlarea_p) false + } } elseif {[string first "opera" $user_agent] != -1} { regexp {^[^/]+/([0-9]+)[.]} $user_agent _ user_agent_version if {$user_agent_version < 9} { @@ -469,6 +461,10 @@ set format_menu [menu $element(id).format [template::util::richtext::format_options] $format {}] set output [textarea_internal $element(id) attributes $contents] + # Spell-checker + array set spellcheck [template::util::spellcheck::spellcheck_properties \ + -element_ref element] + if { $htmlarea_p } { # figure out, which rich text editor to use set richtextEditor [expr {[info exists options(editor)] ? @@ -481,8 +477,6 @@ set ::acs_blank_master($richtextEditor) 1 if {$richtextEditor eq "xinha"} { - append output "\n" - append output "[_ acs-templating.Format]: $format_menu\n" # we have a xinha richtext widget, specified by "options {editor xinha}" # The following options are supported: @@ -525,10 +519,8 @@ } elseif {$richtextEditor eq "tinymce"} { - append output "\n" - append output "Format: $format_menu\n" lappend ::acs_blank_master__htmlareas $attributes(id) - + # get default configs set tinymce_default_config { {mode "exact" } @@ -560,7 +552,8 @@ -parameter "TinyMCEDefaultConfig" \ -default $tinymce_default_config] set pairslist [list] - ns_log notice "options [array get options]" + ns_log debug "tinymce: options [array get options]" + foreach config_pair $tinymce_configs_list { set config_key [lindex $config_pair 0] if {[info exists options($config_key)]} { @@ -571,39 +564,44 @@ } else { set config_value [lindex $config_pair 1] } - ns_log notice "key $config_key value $config_value" + ns_log debug "tinymce: key $config_key value $config_value" lappend pairslist "${config_key}:\"${config_value}\"" } + foreach name [array names options] { - ns_log notice "NAME $name" + ns_log debug "tinymce: NAME $name" # add any additional options not specified in the # default config lappend pairslist "${name}:\"$options($name)\"" } + lappend pairslist "elements : \"[join $::acs_blank_master__htmlareas ","]\"" set tinymce_configs_js [join $pairslist ","] set ::acs_blank_master(tinymce.config) $tinymce_configs_js } + + append output "\n\n" + append output "[_ acs-templating.Format]: $format_menu" + + if { $spellcheck(render_p) } { + append output "[_ acs-templating.Spellcheck]: " \ + [menu "$element(id).spellcheck" [nsv_get spellchecker lang_options] \ + $spellcheck(selected_option) {}] + } + } else { - # Display mode - if { $element(mode) eq "display" && [info exists element(value)] } { - append output [template::util::richtext::get_property html_value $element(value)] - append output "" - append output "" - } else { - append output "" + # htmlarea_p is false + + append output "\n[_ acs-templating.Format]: $format_menu" + + if { $spellcheck(render_p) } { + append output "\n[_ acs-templating.Spellcheck]: " \ + [menu "$element(id).spellcheck" [nsv_get spellchecker lang_options] \ + $spellcheck(selected_option) {}] } - append output "[_ acs-templating.Format]: $format_menu" - } - # Spell-checker - array set spellcheck [template::util::spellcheck::spellcheck_properties \ - -element_ref element] - if { $spellcheck(render_p) } { - append output " [_ acs-templating.Spellcheck]: " \ - [menu "$element(id).spellcheck" [nsv_get spellchecker lang_options] \ - $spellcheck(selected_option) {}] } + } else { # Display mode if { $element(mode) eq "display" && [info exists element(value)] } {
Format: $format_menu