diff options
author | Silvio Rhatto <rhatto@riseup.net> | 2014-03-15 14:58:52 -0300 |
---|---|---|
committer | Silvio Rhatto <rhatto@riseup.net> | 2014-03-15 14:58:52 -0300 |
commit | 323fdcc59e467e6437aad244c475ed0184c7a020 (patch) | |
tree | 0dc86b7aeb394ee6d1c3c9106362dea16c982cde /mod/translation_editor/actions/translate.php | |
parent | 8d66daa258a58b65c3658b38e99382732c88e017 (diff) | |
parent | 2d9b20157957a55bd83875775085ed31c9062577 (diff) | |
download | elgg-323fdcc59e467e6437aad244c475ed0184c7a020.tar.gz elgg-323fdcc59e467e6437aad244c475ed0184c7a020.tar.bz2 |
Merge commit '2d9b20157957a55bd83875775085ed31c9062577' as 'mod/translation_editor'
Diffstat (limited to 'mod/translation_editor/actions/translate.php')
-rw-r--r-- | mod/translation_editor/actions/translate.php | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/mod/translation_editor/actions/translate.php b/mod/translation_editor/actions/translate.php new file mode 100644 index 000000000..973d050d4 --- /dev/null +++ b/mod/translation_editor/actions/translate.php @@ -0,0 +1,76 @@ +<?php + global $CONFIG; + + //action_gatekeeper(); + gatekeeper(); + + // Fixes for KSES filtering + // fix to allow javascript in href + $CONFIG->allowedprotocols[] = "javascript"; + + // fix allowed tags + $CONFIG->allowedtags["a"]["onclick"] = array(); + $CONFIG->allowedtags["span"]["id"] = array(); + + // get inputs + $current_language = get_input("current_language"); + $translate_input = get_input("translation"); + $plugin = get_input("plugin"); + $jquery = get_input("jquery", false); + + // Preparing jQuery result + $json_result = array(); + $json_result["result"] = false; + + if(translation_editor_is_translation_editor()){ + if(!empty($current_language) && !empty($translate_input) && !empty($plugin)){ + $translated = translation_editor_compare_translations($current_language, $translate_input); + + if(!empty($translated)){ + if(translation_editor_write_translation($current_language, $plugin, $translated)){ + if(!$jquery){ + system_message(elgg_echo("translation_editor:action:translate:success")); + } else { + $json_result["result"] = true; + } + } else { + if(!$jquery){ + register_error(elgg_echo("translation_editor:action:translate:error:write")); + } + } + } else { + translation_editor_delete_translation($current_language, $plugin); + if(!$jquery){ + system_message(elgg_echo("translation_editor:action:translate:no_changed_values")); + } else { + $json_result["result"] = true; + } + } + + // merge translations + translation_editor_merge_translations($current_language, true); + } else { + if(!$jquery){ + register_error(elgg_echo("translation_editor:action:translate:error:input")); + } + } + } else { + if(!$jquery){ + register_error(elgg_echo("translation_editor:action:translate:error:not_authorized")); + } + } + + if(!$jquery){ + forward(REFERER); + } else { + // Send JSON data + $json_string = json_encode($json_result); + + header("Content-Type: application/json; charset=UTF-8"); + header("Content-Length: " . strlen($json_string)); + header("Cache-Control: no-cache"); + header("Pragma: no-cache"); + + echo $json_string; + exit(); + } |