/wp-content/plugins/wpml-string-translation/inc/functions.php
PHP | 2963 lines | 2343 code | 469 blank | 151 comment | 546 complexity | c25a6991b5a201f95a94d3a846626dd6 MD5 | raw file
Possible License(s): GPL-3.0, MIT, BSD-3-Clause, LGPL-2.1, GPL-2.0, Apache-2.0
Large files files are truncated, but you can click here to view the full file
- <?php
-
- $icl_st_string_translation_statuses = array(
- ICL_STRING_TRANSLATION_COMPLETE => __('Translation complete','wpml-string-translation'),
- ICL_STRING_TRANSLATION_PARTIAL => __('Partial translation','wpml-string-translation'),
- ICL_STRING_TRANSLATION_NEEDS_UPDATE => __('Translation needs update','wpml-string-translation'),
- ICL_STRING_TRANSLATION_NOT_TRANSLATED => __('Not translated','wpml-string-translation'),
- ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR => __('Waiting for translator','wpml-string-translation')
- );
-
- add_action('plugins_loaded', 'icl_st_init');
-
- if(!defined('XMLRPC')){
- // called separately for XMLRPC post saves
- add_action('save_post', 'icl_st_fix_links_in_strings', 19);
- }
-
- //add_filter('xmlrpc_methods','icl_add_custom_xmlrpc_methods');
-
- function icl_st_init(){
- global $sitepress_settings, $sitepress, $wpdb, $icl_st_err_str;
-
- if ( $GLOBALS['pagenow'] == 'site-new.php' && isset($_REQUEST['action']) && 'add-site' == $_REQUEST['action'] ) return;
-
- add_action('icl_update_active_languages', 'icl_update_string_status_all');
- add_action('update_option_blogname', 'icl_st_update_blogname_actions',5,2);
- add_action('update_option_blogdescription', 'icl_st_update_blogdescription_actions',5,2);
-
- if(isset($_GET['icl_action']) && $_GET['icl_action'] == 'view_string_in_page'){
- icl_st_string_in_page($_GET['string_id']);
- exit;
- }
-
- if(isset($_GET['icl_action']) && $_GET['icl_action'] == 'view_string_in_source'){
- icl_st_string_in_source($_GET['string_id']);
- exit;
- }
-
- if ( get_magic_quotes_gpc() && isset($_GET['page']) && $_GET['page'] == WPML_ST_FOLDER . '/menu/string-translation.php'){
- $_POST = stripslashes_deep( $_POST );
- }
-
- if(!isset($sitepress_settings['existing_content_language_verified']) || !$sitepress_settings['existing_content_language_verified']){
- return;
- }
-
- if(!isset($sitepress_settings['st']['sw'])){
- $sitepress_settings['st']['sw'] = array(); //no settings for now
- $sitepress->save_settings($sitepress_settings);
- $init_all = true;
- }
-
- if(!isset($sitepress_settings['st']['strings_per_page'])){
- $sitepress_settings['st']['strings_per_page'] = 10;
- $sitepress->save_settings($sitepress_settings);
- }elseif(isset($_GET['strings_per_page']) && $_GET['strings_per_page'] > 0){
- $sitepress_settings['st']['strings_per_page'] = $_GET['strings_per_page'];
- $sitepress->save_settings($sitepress_settings);
- }
- if(!isset($sitepress_settings['st']['icl_st_auto_reg'])){
- $sitepress_settings['st']['icl_st_auto_reg'] = 'disable';
- $sitepress->save_settings($sitepress_settings);
- }
- if(empty($sitepress_settings['st']['strings_language'])){
- $iclsettings['st']['strings_language'] = $sitepress_settings['st']['strings_language'] = 'en';
- $sitepress->save_settings($iclsettings);
- }
-
- if(!isset($sitepress_settings['st']['translated-users'])) $sitepress_settings['st']['translated-users'] = array();
-
- if((isset($_POST['iclt_st_sw_save']) && wp_verify_nonce($_POST['_wpnonce'], 'icl_sw_form')) || isset($init_all)){
- if(isset($init_all)){
-
- icl_register_string('WP',__('Blog Title','wpml-string-translation'), get_option('blogname'));
- icl_register_string('WP',__('Tagline', 'wpml-string-translation'), get_option('blogdescription'));
-
- __icl_st_init_register_widget_titles();
-
- // create a list of active widgets
- $active_text_widgets = array();
- $widgets = (array)get_option('sidebars_widgets');
- foreach($widgets as $k=>$w){
- if('wp_inactive_widgets' != $k && $k != 'array_version'){
- if(is_array($widgets[$k])){
- foreach($widgets[$k] as $v){
- if(preg_match('#text-([0-9]+)#i',$v, $matches)){
- $active_text_widgets[] = $matches[1];
- }
- }
- }
- }
- }
-
- $widget_text = get_option('widget_text');
- if(is_array($widget_text)){
- foreach($widget_text as $k=>$w){
- if(!empty($w) && isset($w['title']) && in_array($k, $active_text_widgets)){
- icl_register_string('Widgets', 'widget body - ' . md5($w['text']), $w['text']);
- }
- }
- }
- }
-
- if(isset($_POST['iclt_st_sw_save'])){
- $updat_string_statuses = false;
- $sitepress_settings['st']['sw'] = $_POST['icl_st_sw'];
- if($sitepress_settings['st']['strings_language'] != $_POST['icl_st_sw']['strings_language']){
- $updat_string_statuses = true;
- }
- $sitepress_settings['st']['strings_language'] = $_POST['icl_st_sw']['strings_language'];
- $sitepress->save_settings($sitepress_settings);
-
- $wpdb->query($wpdb->prepare("UPDATE {$wpdb->prefix}icl_strings SET language=%s WHERE language <> %s",
- $sitepress_settings['st']['strings_language'], $sitepress_settings['st']['strings_language']));
-
- if($updat_string_statuses){
- icl_update_string_status_all();
- }
-
-
- //register author strings
- if(!empty($sitepress_settings['st']['translated-users'])){
- icl_st_register_user_strings_all();
- }
-
- wp_redirect(admin_url('admin.php?page='. WPML_ST_FOLDER .'/menu/string-translation.php&updated=true'));
- }
-
- }
-
- // handle po file upload
- if ( isset( $_POST[ 'icl_po_upload' ] ) && wp_verify_nonce( $_POST[ '_wpnonce' ], 'icl_po_form' ) ) {
- global $icl_st_po_strings;
-
- if ( $_FILES[ 'icl_po_file' ][ 'size' ] == 0 ) {
- $icl_st_err_str = __( 'File upload error', 'wpml-string-translation' );
- } else {
- $lines = file( $_FILES[ 'icl_po_file' ][ 'tmp_name' ] );
- $icl_st_po_strings = array();
-
- $fuzzy = 0;
- for ( $k = 0; $k < count( $lines ); $k ++ ) {
- $date_time_flag = false;
- if ( 0 === strpos( $lines[ $k ], '#, fuzzy' ) ) {
- $fuzzy = 1;
- $k ++;
- }
- $name = false;
- if ( 0 === strpos( $lines[ $k ], '# wpml-name: ' ) ) {
- $name = preg_replace( "/^# wpml-name: /i", '', trim( $lines[ $k ] ) );
- $k ++;
- }
-
- if ( preg_match( '/msgctxt/', $lines[ $k ] ) ) { //we look for the line that poedit needs for unique identification of the string
-
- if ( preg_match( '/wpmldatei18/', $lines[ $k ] ) ) { //if it contains the date_time setting we add the flag to escape the control structures in the date time placeholder string
- $date_time_flag = true;
- }
- $k ++;
- }
- $int = preg_match( '#msgid "(.+)"#im', trim( $lines[ $k ] ), $matches );
- if ( $int ) {
- $string = str_replace( '\"', '"', $matches[ 1 ] );
- $int = preg_match( '#msgstr "(.+)"#im', trim( $lines[ $k + 1 ] ), $matches );
- if ( $int ) {
- $translation = str_replace( '\"', '"', $matches[ 1 ] );
- } else {
- $translation = "";
- }
-
- if ( $name === false ) {
- $name = md5( $string );
- }
-
- $string_exists = $wpdb->get_var( "
- SELECT id FROM {$wpdb->prefix}icl_strings
- WHERE context='" . esc_sql( $_POST[ 'icl_st_i_context_new' ] ? $_POST[ 'icl_st_i_context_new' ] : $_POST[ 'icl_st_i_context' ] ) . "'
- AND name='" . $name . "'" );
-
- if ( $date_time_flag ) {
- $string = str_replace( "\\\\", "\\", $string );
- $translation = str_replace( "\\\\", "\\", $translation );
- $name = str_replace( "\\\\", "\\", $name );
- }
-
- $icl_st_po_strings[ ] = array(
- 'string' => $string,
- 'translation' => $translation,
- 'name' => $name,
- 'fuzzy' => $fuzzy,
- 'exists' => $string_exists
- );
- $k ++;
- }
- if ( ! trim( $lines[ $k ] ) ) {
- $fuzzy = 0;
- }
- }
- if ( empty( $icl_st_po_strings ) ) {
- $icl_st_err_str = __( 'No string found', 'wpml-string-translation' );
- }
- }
- } elseif ( isset( $_POST[ 'action' ] ) && 'icl_st_save_strings' == $_POST[ 'action' ] ) {
- $arr = array_intersect_key( $_POST[ 'icl_strings' ], array_flip( $_POST[ 'icl_strings_selected' ] ) );
- //$arr = array_map('html_entity_decode', $arr);
- if ( isset( $_POST[ 'icl_st_po_language' ] ) ) {
- $arr_t = array_intersect_key( $_POST[ 'icl_translations' ], array_flip( $_POST[ 'icl_strings_selected' ] ) );
- $arr_f = array_intersect_key( $_POST[ 'icl_fuzzy' ], array_flip( $_POST[ 'icl_strings_selected' ] ) );
- //$arr_t = array_map('html_entity_decode', $arr_t);
- }
-
- foreach ( $arr as $k => $string ) {
-
- $name = isset( $_POST[ 'icl_name' ][ $k ] ) && $_POST[ 'icl_name' ][ $k ] ? $_POST[ 'icl_name' ][ $k ] : md5( $string );
-
- $string_id = icl_register_string( $_POST[ 'icl_st_domain_name' ], $name, $string );
- if ( $string_id && isset( $_POST[ 'icl_st_po_language' ] ) ) {
- if ( $arr_t[ $k ] != "" ) {
- if ( $arr_f[ $k ] ) {
- $_status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- } else {
- $_status = ICL_STRING_TRANSLATION_COMPLETE;
- }
- icl_add_string_translation( $string_id, $_POST[ 'icl_st_po_language' ], $arr_t[ $k ], $_status );
- icl_update_string_status( $string_id );
- }
- }
- }
- }
-
- //handle po export
- if(isset($_POST['icl_st_pie_e']) && wp_verify_nonce($_POST['_wpnonce'], 'icl_po_export')){
- //force some filters
- if(isset($_GET['status'])) unset($_GET['status']);
- $_GET['show_results']='all';
- if($_POST['icl_st_e_context']){
- $_GET['context'] = $_POST['icl_st_e_context'];
- }
-
- $_GET['translation_language'] = $_POST['icl_st_e_language'];
- $strings = icl_get_string_translations();
- if(!empty($strings)){
- $po = icl_st_generate_po_file($strings, !isset($_POST['icl_st_pe_translations']));
- }else{
- $po = "";
- }
- if(!isset($_POST['icl_st_pe_translations'])){
- $popot = 'pot';
- $poname = $_POST['icl_st_e_context'] ? urlencode($_POST['icl_st_e_context']) : 'all_context';
- }else{
- $popot = 'po';
- $poname = $_GET['translation_language'];
- }
- header("Content-Type: application/force-download");
- header("Content-Type: application/octet-stream");
- header("Content-Type: application/download");
- header("Content-Disposition: attachment; filename=".$poname.'.'.$popot.";");
- header("Content-Length: ". strlen($po));
- echo $po;
- exit(0);
- }
-
- // handle string translation request
- elseif(isset($_POST['icl_st_action']) && $_POST['icl_st_action'] == 'send_strings'){
-
- if($_POST['iclnonce'] == wp_create_nonce('icl-string-translation')){
- $_POST = stripslashes_deep($_POST);
- $services = $_POST['service'];
- $string_ids = explode(',', $_POST['strings']);
- $translate_to = array();
- foreach($_POST['translate_to'] as $lang_to=>$one){
- if(isset($services[$lang_to])){
- $translate_to[$lang_to] = $services[$lang_to];
- }
- }
- if(!empty($translate_to)){
- icl_translation_send_strings($string_ids, $translate_to);
- }
- }
- }
-
-
- // hook into blog title and tag line
- add_filter('option_blogname', 'icl_sw_filters_blogname');
- add_filter('option_blogdescription', 'icl_sw_filters_blogdescription');
- add_filter('widget_title', 'icl_sw_filters_widget_title', 0); //highest priority
- add_filter('widget_text', 'icl_sw_filters_widget_text', 0); //highest priority
-
- if(isset($sitepress_settings['theme_localization_type']) && $sitepress_settings['theme_localization_type']==1){
- add_filter('gettext', 'icl_sw_filters_gettext', 9, 3);
- add_filter('gettext_with_context', 'icl_sw_filters_gettext_with_context', 1, 4);
- add_filter('ngettext', 'icl_sw_filters_ngettext', 9, 5);
- add_filter('ngettext_with_context', 'icl_sw_filters_nxgettext', 9, 6);
- }
-
- $widget_groups = $wpdb->get_results("SELECT option_name, option_value FROM {$wpdb->options} WHERE option_name LIKE 'widget\\_%'");
- foreach($widget_groups as $w){
- add_action('update_option_' . $w->option_name, 'icl_st_update_widget_title_actions', 5, 2);
- }
-
- add_action('update_option_widget_text', 'icl_st_update_text_widgets_actions', 5, 2);
- add_action('update_option_sidebars_widgets', '__icl_st_init_register_widget_titles');
-
- if($icl_st_err_str){
- add_action('admin_notices', 'icl_st_admin_notices');
- }
- if (isset($_REQUEST['string-translated']) && $_REQUEST['string-translated'] == true) {
- add_action('admin_notices', 'icl_st_admin_notices_string_updated');
- }
-
- add_filter('get_the_author_first_name', 'icl_st_author_first_name_filter', 10, 2);
- add_filter('get_the_author_last_name', 'icl_st_author_last_name_filter', 10, 2);
- add_filter('get_the_author_nickname', 'icl_st_author_nickname_filter', 10, 2);
- add_filter('get_the_author_description', 'icl_st_author_description_filter', 10, 2);
- add_filter('the_author', 'icl_st_author_displayname_filter', 10);
-
- }
-
-
- add_action('profile_update', 'icl_st_register_user_strings');
- add_action('user_register', 'icl_st_register_user_strings');
-
- function __icl_st_init_register_widget_titles(){
- global $wpdb;
-
- // create a list of active widgets
- $active_widgets = array();
- $widgets = (array)get_option('sidebars_widgets');
-
- foreach($widgets as $k=>$w){
- if('wp_inactive_widgets' != $k && $k != 'array_version'){
- if(is_array($widgets[$k]))
- foreach($widgets[$k] as $v){
- $active_widgets[] = $v;
- }
- }
- }
- foreach($active_widgets as $aw){
- $int = preg_match('#-([0-9]+)$#i',$aw, $matches);
- if($int){
- $suffix = $matches[1];
- }else{
- $suffix = 1;
- }
- $name = preg_replace('#-[0-9]+#','',$aw);
- //if($name == 'rss-links') $name = 'rss';
-
- //$w = $wpdb->get_row("SELECT option_name, option_value FROM {$wpdb->options} WHERE option_name = 'widget_{$name}'");
- //$value = unserialize($w->option_value);
- $value = get_option("widget_".$name);
- if(isset($value[$suffix]['title']) && $value[$suffix]['title']){
- $w_title = $value[$suffix]['title'];
- }else{
- $w_title = __icl_get_default_widget_title($aw);
- $value[$suffix]['title'] = $w_title;
- update_option("widget_".$name, $value);
- }
-
- if($w_title){
- icl_register_string('Widgets', 'widget title - ' . md5($w_title), $w_title);
-
- }
- }
- }
-
- function __icl_get_default_widget_title($id){
- if(preg_match('#archives(-[0-9]+)?$#i',$id)){
- $w_title = 'Archives';
- }elseif(preg_match('#categories(-[0-9]+)?$#i',$id)){
- $w_title = 'Categories';
- }elseif(preg_match('#calendar(-[0-9]+)?$#i',$id)){
- $w_title = 'Calendar';
- }elseif(preg_match('#links(-[0-9]+)?$#i',$id)){
- $w_title = 'Links';
- }elseif(preg_match('#meta(-[0-9]+)?$#i',$id)){
- $w_title = 'Meta';
- }elseif(preg_match('#pages(-[0-9]+)?$#i',$id)){
- $w_title = 'Pages';
- }elseif(preg_match('#recent-posts(-[0-9]+)?$#i',$id)){
- $w_title = 'Recent Posts';
- }elseif(preg_match('#recent-comments(-[0-9]+)?$#i',$id)){
- $w_title = 'Recent Comments';
- }elseif(preg_match('#rss-links(-[0-9]+)?$#i',$id)){
- $w_title = 'RSS';
- }elseif(preg_match('#search(-[0-9]+)?$#i',$id)){
- $w_title = 'Search';
- }elseif(preg_match('#tag-cloud(-[0-9]+)?$#i',$id)){
- $w_title = 'Tag Cloud';
- }else{
- $w_title = false;
- }
- return $w_title;
- }
-
- function icl_register_string($context, $name, $value, $allow_empty_value = false){
- global $wpdb, $sitepress_settings;
-
- /* cpt slugs - do not register them when scanning themes and plugins
- * if name starting from 'URL slug: '
- * and context is different from 'WordPress'
- */
- if (substr($name, 0, 10) === 'URL slug: ' && 'WordPress' !== $context) {
- return false;
- }
-
- // if the default language is not set up return without doing anything
- if(
- !isset($sitepress_settings['existing_content_language_verified']) ||
- !$sitepress_settings['existing_content_language_verified']
- ){
- return false;
- }
-
- // Check if cached (so exists)
- $cached = icl_t_cache_lookup($context, $name);
- if ($cached && isset($cached['original']) && $cached['original'] == $value) {
- return false;
- }
-
- $language = isset($sitepress_settings['st']['strings_language']) ? $sitepress_settings['st']['strings_language'] : 'en';
- $res = $wpdb->get_row("SELECT id, value, status, language FROM {$wpdb->prefix}icl_strings WHERE context='".esc_sql($context)."' AND name='".esc_sql($name)."'");
- if($res){
- $string_id = $res->id;
- $update_string = array();
-
-
- /*
- * If Sticky Links plugin is active and set to change links in Strings,
- * we need to process $value and change links into sticky before comparing
- * with saved in DB $res->value.
- * Otherwise after every String Translation screen refresh status of this string
- * will be changed into 'needs update'
- */
- $alp_settings = get_option('alp_settings');
- if (!empty($alp_settings['sticky_links_strings']) // do we have setting about sticky links in strings?
- && $alp_settings['sticky_links_strings'] // is this set to TRUE?
- && defined('WPML_STICKY_LINKS_VERSION')) { // sticky links plugin is active?
- require_once ICL_PLUGIN_PATH . '/inc/absolute-links/absolute-links.class.php';
- $absolute_links_object = new AbsoluteLinks;
- $alp_broken_links = array();
- $value = $absolute_links_object->_process_generic_text($value, $alp_broken_links);
- }
-
-
- if($value != $res->value){
- $update_string['value'] = $value;
- }
- if($language != $res->language){
- $update_string['language'] = $language;
- }
- if(!empty($update_string)){
- $wpdb->update($wpdb->prefix.'icl_strings', $update_string, array('id'=>$string_id));
- $wpdb->update($wpdb->prefix.'icl_string_translations', array('status'=>ICL_STRING_TRANSLATION_NEEDS_UPDATE), array('string_id'=>$string_id));
- icl_update_string_status($string_id);
- }
- }else{
- if(!empty($value) && is_scalar($value) && trim($value) || $allow_empty_value){
- $string = array(
- 'language' => $language,
- 'context' => $context,
- 'name' => $name,
- 'value' => $value,
- 'status' => ICL_STRING_TRANSLATION_NOT_TRANSLATED,
- );
- $wpdb->insert($wpdb->prefix.'icl_strings', $string);
- $string_id = $wpdb->insert_id;
- }else{
- $string_id = 0;
- }
- }
- global $WPML_Sticky_Links;
- if(!empty($WPML_Sticky_Links) && $WPML_Sticky_Links->settings['sticky_links_strings']){
- require_once ICL_PLUGIN_PATH . '/inc/translation-management/pro-translation.class.php';
- ICL_Pro_Translation::_content_make_links_sticky($string_id, 'string', false);
- }
- return $string_id;
- }
-
- add_filter('register_string_for_translation', 'icl_register_string', 10, 4);
-
- function icl_translate($context, $name, $original_value = false, $allow_empty_value = false, &$has_translation = null) {
- global $sitepress;
- $current_language = $sitepress->get_current_language();
- static $cache = null;
- if (isset($cache[$context][$name][$current_language])) {
- if ( $cache[$context][$name][$current_language] != $original_value ) {
- $has_translation = true;
- } else {
- $has_translation = false;
- }
- return $cache[$context][$name][$current_language];
- }
- icl_register_string($context, $name, $original_value, $allow_empty_value);
- $cache[$context][$name][$current_language] = icl_t($context, $name, $original_value, $has_translation);
- return $cache[$context][$name][$current_language];
- }
-
- function icl_st_is_registered_string($context, $name){
- global $wpdb;
- static $cache = array();
- if(isset($cache[$context][$name])){
- $string_id = $cache[$context][$name];
- }else{
- $string_id = $wpdb->get_var("
- SELECT id
- FROM {$wpdb->prefix}icl_strings WHERE context='".esc_sql($context)."' AND name='".esc_sql($name)."'");
- $cache[$context][$name] = $string_id;
- }
- return $string_id;
- }
-
- function icl_st_string_has_translations($context, $name){
- global $wpdb;
- $sql = "
- SELECT COUNT(st.id)
- FROM {$wpdb->prefix}icl_string_translations st
- JOIN {$wpdb->prefix}icl_strings s ON s.id=st.string_id
- WHERE s.name='".esc_sql($name)."' AND s.context='".esc_sql($context)."'
- ";
- return $wpdb->get_var($sql);
- }
-
- function icl_rename_string($context, $old_name, $new_name){
- global $wpdb;
- $wpdb->update($wpdb->prefix.'icl_strings', array('name'=>$new_name), array('context'=>$context, 'name'=>$old_name));
- }
-
- function icl_update_string_status($string_id){
- global $wpdb, $sitepress, $sitepress_settings;
- $st = $wpdb->get_results($wpdb->prepare("SELECT language, status FROM {$wpdb->prefix}icl_string_translations WHERE string_id=%d", $string_id));
-
- if($st){
-
- if (isset($sitepress_settings['st']['strings_language'])) {
- $strings_language = $sitepress_settings['st']['strings_language'];
- } else {
- $strings_language = false;
- }
- foreach($st as $t){
- if( $strings_language != $t->language){
- $translations[$t->language] = $t->status;
- }
- }
-
- $active_languages = $sitepress->get_active_languages();
-
- if(empty($translations) || max($translations) == ICL_STRING_TRANSLATION_NOT_TRANSLATED){
- $status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- }elseif( in_array(ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR,$translations) ){
- $status = ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR;
- }elseif(count($translations) < count($active_languages) - intval(in_array($strings_language, array_keys($active_languages)))){
- if(in_array(ICL_STRING_TRANSLATION_NEEDS_UPDATE,$translations)){
- $status = ICL_STRING_TRANSLATION_NEEDS_UPDATE;
- }elseif(in_array(ICL_STRING_TRANSLATION_COMPLETE,$translations)){
- $status = ICL_STRING_TRANSLATION_PARTIAL;
- }else{
- $status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- }
- }elseif(ICL_STRING_TRANSLATION_NEEDS_UPDATE == array_unique($translations)){
- $status = ICL_STRING_TRANSLATION_NEEDS_UPDATE;
- }else{
- if(in_array(ICL_STRING_TRANSLATION_NEEDS_UPDATE,$translations)){
- $status = ICL_STRING_TRANSLATION_NEEDS_UPDATE;
- }elseif(in_array(ICL_STRING_TRANSLATION_NOT_TRANSLATED,$translations)){
- $status = ICL_STRING_TRANSLATION_PARTIAL;
- }else{
- $status = ICL_STRING_TRANSLATION_COMPLETE;
- }
- }
- }else{
- $status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- }
- $wpdb->update($wpdb->prefix.'icl_strings', array('status'=>$status), array('id'=>$string_id));
- return $status;
- }
-
- function icl_update_string_status_all(){
- global $wpdb;
- $res = $wpdb->get_col("SELECT id FROM {$wpdb->prefix}icl_strings");
- foreach($res as $id){
- icl_update_string_status($id);
- }
- }
-
- function icl_unregister_string($context, $name){
- global $wpdb;
- $string_id = $wpdb->get_var("SELECT id FROM {$wpdb->prefix}icl_strings WHERE context='".esc_sql($context)."' AND name='".esc_sql($name)."'");
- if($string_id){
- $wpdb->query( $wpdb->prepare("DELETE FROM {$wpdb->prefix}icl_strings WHERE id=%d", $string_id));
- $wpdb->query( $wpdb->prepare("DELETE FROM {$wpdb->prefix}icl_string_translations WHERE string_id=%d", $string_id));
- $wpdb->query( $wpdb->prepare("DELETE FROM {$wpdb->prefix}icl_string_positions WHERE string_id=%d", $string_id));
- }
- do_action('icl_st_unregister_string', $string_id);
- }
-
- function __icl_unregister_string_multi($arr){
- global $wpdb;
- $str = join(',', array_map('intval', $arr));
- $wpdb->query("
- DELETE s.*, t.* FROM {$wpdb->prefix}icl_strings s LEFT JOIN {$wpdb->prefix}icl_string_translations t ON s.id = t.string_id
- WHERE s.id IN ({$str})");
- $wpdb->query("DELETE FROM {$wpdb->prefix}icl_string_positions WHERE string_id IN ({$str})");
- do_action('icl_st_unregister_string_multi', $arr);
- }
-
- function icl_t($context, $name, $original_value=false, &$has_translation=null, $dont_auto_register = false){
- global $sitepress, $sitepress_settings;
-
- // we need this to devide static $results cache by blogs in multiblog
- $blog_id = 0;
- if (isset($GLOBALS['blog_id'])) {
- $blog_id = $GLOBALS['blog_id'];
- }
-
- // if the default language is not set up return
- if(!isset($sitepress_settings['existing_content_language_verified'])){
- if(isset($has_translation)) $has_translation = false;
- return $original_value !== false ? $original_value : $name;
- }
-
- $current_language = get_current_string_language( $name );
- $default_language = !empty($sitepress_settings['st']['strings_language']) ? $sitepress_settings['st']['strings_language'] : $sitepress->get_default_language();
-
- $cache_key_args = array($blog_id, $current_language, $default_language, $context, $name, $original_value);
- $cache_key = md5( json_encode( $cache_key_args ) );
- $cache_group = '_icl_t';
- $found = false;
-
- $to_return = wp_cache_get($cache_key, $cache_group, false, $found);
-
- if ($found) {
- if ($to_return == $original_value) {
- $has_translation = false;
- } else {
- $has_translation = true;
- }
- return $to_return;
- }
-
- if($current_language == $default_language && $original_value){
-
- $ret_val = $original_value;
- if(isset($has_translation)) $has_translation = false;
-
- }else{
- $result = icl_t_cache_lookup($context, $name);
-
- $is_string_change = _icl_is_string_change($result, $original_value);
-
- if (($result === false || $is_string_change) && !is_admin() && !$dont_auto_register && $context != 'Widgets') {
-
- static $string_registrations_per_request = 0;
-
- if($string_registrations_per_request < ICL_STRING_TRANSLATION_AUTO_REGISTER_THRESHOLD){
-
- // See if we should auto register the strings.
- if (isset($sitepress_settings['st']['icl_st_auto_reg'])) {
- $auto_reg = $sitepress_settings['st']['icl_st_auto_reg'];
- } else {
- $auto_reg = 'disable';
- }
-
- if($auto_reg == 'auto-always' || ($auto_reg == 'auto-admin' && current_user_can('manage_options'))){
- icl_register_string($context, $name, $original_value);
- $string_registrations_per_request++;
- }
-
- }
-
- }
- if($result === false || ( is_array($result) && ( !isset($result['value']) || ( isset($result['translated']) && !$result['translated'] && $original_value ) ) ) ){
- $ret_val = $original_value;
- if(isset($has_translation)) $has_translation = false;
- }else{
- $ret_val = $result['value'];
- if(isset($has_translation)) $has_translation = true;
- }
-
- }
-
- wp_cache_set($cache_key, $ret_val, $cache_group);
-
- return $ret_val;
- }
-
- /**
- * @param $name
- *
- * Checks whether a given string is to be translated in the Admin back-end.
- * Currently only tagline and title of a site are to be translated.
- * All other admin strings are to always be displayed in the user admin language.
- *
- * @return bool
- */
- function is_translated_admin_string( $name ) {
- $translated = false;
-
- $exclusions = array( 'Tagline', 'Blog Title' );
-
- if ( in_array( $name, $exclusions ) ) {
- $translated = true;
- }
-
- return $translated;
- }
-
- /**
- * @param $name
- * Returns the language the current string is to be translated into.
- *
- * @return string
- */
- function get_current_string_language( $name ) {
- global $sitepress;
-
- if ( defined( 'DOING_AJAX' ) ) {
- $current_language = $sitepress->get_language_cookie();
- } else {
- $current_language = $sitepress->get_current_language();
- }
-
- /*
- * The logic for this is a little different in the admin backend. Here we always use the user admin language if the admin backend is accessed.
- * We have to take care of two exceptions though.
- * 1. Plugins doing admin ajax calls in the frontend.
- * 2. Certain strings are to always be translated in the admin backend.
- * 3. We have to handle special exception when check_if_admin_action_from_referrer is not available yet (during upgrade)
- */
- if (version_compare(ICL_SITEPRESS_VERSION, '3.1.7.2', '>')) {
- if (defined('WP_ADMIN') && ( $sitepress->check_if_admin_action_from_referer() || !defined('DOING_AJAX') ) && !is_translated_admin_string($name)) {
- $current_user = $sitepress->get_current_user();
- if (isset($current_user->ID)) {
- $current_language = $sitepress->get_user_admin_language($current_user->ID);
- }
- }
- }
-
- return $current_language;
- }
-
- /**
- * Helper function for icl_t()
- * @param array $result
- * @param string $original_value
- * @return boolean
- */
- function _icl_is_string_change($result, $original_value) {
-
- if ($result == false) {
- return false;
- }
-
- if (!isset($result['value'])) {
- return false;
- }
- return (
- $result['translated'] && $result['original'] != $original_value ||
- !$result['translated'] && $result['value'] != $original_value
- );
- }
-
- add_filter('translate_string', 'icl_t', 10, 5);
-
- function icl_add_string_translation($string_id, $language, $value = null, $status = false, $translator_id = null){
- global $wpdb, $sitepress;
-
- $current_user = $sitepress->get_current_user();
-
-
- $res = $wpdb->get_row("SELECT id, value, status FROM {$wpdb->prefix}icl_string_translations WHERE string_id='".esc_sql($string_id)."' AND language='".esc_sql($language)."'");
-
- // the same string should not be sent two times to translation
- if(isset($res->status) && $res->status == ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR && is_null($value)){
- return false;
- }
-
- if($res){
- $st_id = $res->id;
- $st_update = array();
- if(!is_null($value) && $value != $res->value){ // null $value is for sending to translation. don't override existing.
- $st_update['value'] = $value;
- }
- if($status){
- $st_update['status'] = $status;
- }elseif($status === ICL_STRING_TRANSLATION_NOT_TRANSLATED){
- $st_update['status'] = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- }
-
- if(!empty($st_update)){
- if(!is_null($translator_id)){
- $st_update['translator_id'] = $current_user->ID;
- }
- $st_update['translation_date'] = current_time("mysql");
- $wpdb->update($wpdb->prefix.'icl_string_translations', $st_update, array('id'=>$st_id));
- }
- }else{
- if(!$status){
- $status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- }
- $st = array(
- 'string_id' => $string_id,
- 'language' => $language,
- 'status' => $status
- );
- if(!is_null($value)){
- $st['value'] = $value;
- }
- if(!is_null($translator_id)){
- $st_update['translator_id'] = $current_user->ID;
- }
- $wpdb->insert($wpdb->prefix.'icl_string_translations', $st);
- $st_id = $wpdb->insert_id;
- }
-
- if(isset($GLOBALS['ICL_Pro_Translation'])){
- $GLOBALS['ICL_Pro_Translation']->_content_fix_links_to_translated_content($st_id, $language, 'string');
- }
-
- icl_update_string_status($string_id);
-
- do_action('icl_st_add_string_translation', $st_id);
-
- return $st_id;
- }
-
- /**
- *
- * @global WPDB $wpdb
- * @global array $sitepress_settings
- * @param string $option_name
- * @param string $language
- * @param string $new_value
- * @param int|bool $status
- * @param int $translator_id
- * @param int $rec_level
- * @return boolean|mixed
- */
- function icl_update_string_translation($option_name, $language, $new_value = null, $status = false, $translator_id = null, $rec_level = 0) {
- global $wpdb, $sitepress_settings;
-
- if (!is_array($new_value)) {
- $new_value = (array) $new_value;
- }
-
- $updated = array();
-
- foreach ($new_value as $index => $value) {
-
- if (is_array($value)) {
- $name = "[". $option_name ."][" . $index . "]";
- $result = icl_update_string_translation($name, $language, $value, $status, $translator_id, $rec_level + 1);
- $updated[] = array_sum( explode(",", $result) );
- } else {
- if (is_string($index)) {
- if ($rec_level == 0) {
- $name = "[". $option_name ."]" . $index;
- } else {
- $name = $option_name . $index;
- }
- } else {
- $name = $option_name;
- }
-
- $select_original_string = "SELECT * FROM {$wpdb->prefix}icl_strings WHERE name = %s AND language = %s";
- $original_string = $wpdb->get_row($wpdb->prepare($select_original_string, $name, $sitepress_settings['st']['strings_language']));
- if (!$original_string || !isset($original_string->id) || !is_numeric($original_string->id)) {
- continue;
- }
-
- $updated[] = icl_add_string_translation($original_string->id, $language, $value, $status, $translator_id);
-
- }
-
-
- }
-
- if (array_sum($updated) > 0) {
- return join(",", $updated);
- } else {
- return false;
- }
-
-
- }
-
- function icl_get_string_id($string, $context){
- global $wpdb;
- $id = (int) $wpdb->get_var($wpdb->prepare("SELECT id FROM {$wpdb->prefix}icl_strings WHERE value=%s AND context=%s", $string, $context));
- return $id;
- }
-
- function icl_get_string_translations($offset=0){
- global $wpdb, $sitepress, $sitepress_settings, $wp_query, $icl_st_string_translation_statuses;
- $string_translations = array();
-
- $current_user = $sitepress->get_current_user();
-
- $extra_cond = "";
- if(icl_st_is_translator() && isset($_GET['status']) && preg_match("#".ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR."-(.+)#", $_GET['status'], $matches)){
- $status_filter = ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR;
- $status_filter_lang = $matches[1];
- $lcode_alias = str_replace('-', '', $status_filter_lang);
- $extra_cond .= " AND str_{$lcode_alias}.language = '{$status_filter_lang}' ";
- }else{
- $status_filter = isset($_GET['status']) ? intval($_GET['status']) : false;
- }
-
- $search_filter = isset($_GET['search']) ? $_GET['search'] : false;
- $exact_match = isset($_GET['em']) ? $_GET['em'] == 1 : false;
-
- if($status_filter !== false){
- if($status_filter == ICL_STRING_TRANSLATION_COMPLETE){
- $extra_cond .= " AND s.status = " . ICL_STRING_TRANSLATION_COMPLETE;
- }elseif($status_filter == ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR){
- ; // do nothing
- }else{
- $extra_cond .= " AND status IN (" . ICL_STRING_TRANSLATION_PARTIAL . "," . ICL_STRING_TRANSLATION_NEEDS_UPDATE . "," . ICL_STRING_TRANSLATION_NOT_TRANSLATED . "," . ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR . ")";
- }
- }
-
- if($search_filter != false){
- if($exact_match){
- $extra_cond .= " AND s.value = '". esc_sql($search_filter)."' ";
- }else{
- $extra_cond .= " AND s.value LIKE '%". esc_sql($search_filter)."%' ";
- }
- }
-
- $context_filter = isset($_GET['context']) ? $_GET['context'] : false;
- if($context_filter !== false){
- $extra_cond .= " AND s.context = '" . esc_sql($context_filter) . "'";
- }
-
- if(isset($_GET['show_results']) && $_GET['show_results']=='all'){
- $limit = 9999;
- $offset = 0;
- }else{
- $limit = $sitepress_settings['st']['strings_per_page'];
- if(!isset($_GET['paged'])) $_GET['paged'] = 1;
- $offset = ($_GET['paged']-1)*$limit;
- }
-
- /* TRANSLATOR - START */
- if(icl_st_is_translator()){
-
- $user_lang_pairs = get_user_meta($current_user->ID, $wpdb->prefix.'language_pairs', true);
-
- if(!empty($status_filter_lang)){
-
- $_joins = $_sels = $_where = array();
- foreach($sitepress->get_active_languages() as $l){
- if($l['code'] == $sitepress_settings['st']['strings_language']) continue;
- $lcode_alias = str_replace('-', '', $l['code']);
- $_sels[] = "str_{$lcode_alias}.id AS id_{$lcode_alias},
- str_{$lcode_alias}.status AS status_{$lcode_alias},
- str_{$lcode_alias}.value AS value_{$lcode_alias},
- str_{$lcode_alias}.translator_id AS translator_{$lcode_alias},
- str_{$lcode_alias}.translation_date AS date_{$lcode_alias}
- ";
- $_joins[] = " LEFT JOIN {$wpdb->prefix}icl_string_translations str_{$lcode_alias} ON str_{$lcode_alias}.string_id = s.id AND str_{$lcode_alias}.language = '{$l['code']}'";
- }
-
- $sql = "
- SELECT SQL_CALC_FOUND_ROWS s.id AS string_id, s.language AS string_language, s.context, s.name, s.value, s.status,
- " . join(", ", $_sels) . "
- FROM {$wpdb->prefix}icl_strings s
- " . join("\n", $_joins) . "
- WHERE
- str_{$status_filter_lang}.status = %d AND
- (str_{$status_filter_lang}.translator_id IS NULL OR str_{$status_filter_lang}.translator_id = %d)
- {$extra_cond}
- ORDER BY string_id DESC
- LIMIT {$offset},{$limit}
- ";
- $sql_prepared = $wpdb->prepare($sql, array(ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR, $current_user->ID));
- $res = $wpdb->get_results($sql_prepared, ARRAY_A);
-
- }else{
- $_joins = $_sels = $_where = array();
-
- foreach($sitepress->get_active_languages() as $l){
-
- if($l['code'] == $sitepress_settings['st']['strings_language']
- || empty($user_lang_pairs[$sitepress_settings['st']['strings_language']][$l['code']])) continue;
- $lcode_alias = str_replace('-', '', $l['code']);
- $lcode_alias = str_replace('-', '', $l['code']);
-
- $_sels[] = "str_{$lcode_alias}.id AS id_{$lcode_alias},
- str_{$lcode_alias}.status AS status_{$lcode_alias},
- str_{$lcode_alias}.value AS value_{$lcode_alias},
- str_{$lcode_alias}.translator_id AS translator_{$lcode_alias},
- str_{$lcode_alias}.translation_date AS date_{$lcode_alias}
- ";
- $_joins[] = "LEFT JOIN {$wpdb->prefix}icl_string_translations str_{$lcode_alias} ON str_{$lcode_alias}.string_id = s.id AND str_{$lcode_alias}.language='{$l['code']}'";
-
- if($status_filter == ICL_STRING_TRANSLATION_COMPLETE){
- $_where[] .= " AND str_{$lcode_alias}.status = " . ICL_STRING_TRANSLATION_COMPLETE;
- }else{
- if(empty($_lwhere)){
- $_lwhere = ' AND (';
- foreach($sitepress->get_active_languages() as $l2){
- if($l2['code'] == $sitepress_settings['st']['strings_language'] || empty($user_lang_pairs[$sitepress_settings['st']['strings_language']][$l2['code']])) continue;
- $l2code_alias = str_replace('-', '', $l2['code']);
- $_lwheres[] = " str_{$l2code_alias}.status = " . ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR . " OR
- str_{$l2code_alias}.translator_id = " . $current_user->ID ;
- }
- $_lwhere .= join(' OR ', $_lwheres ) . ')';
- $_where[] = $_lwhere;
- }
- }
-
- }
-
-
- $sql = "
- SELECT SQL_CALC_FOUND_ROWS s.id AS string_id, s.language AS string_language, s.context, s.name, s.value, s.status, ".
- join(', ', $_sels) . "
- FROM {$wpdb->prefix}icl_strings s " . join("\n", $_joins) . "
- WHERE s.language = '{$sitepress_settings['st']['strings_language']}' ".join(' ', $_where) . "
- {$extra_cond}
- ORDER BY s.id DESC
- LIMIT {$offset},{$limit}
- ";
-
- $res = $wpdb->get_results($sql, ARRAY_A);
- }
-
- $wp_query->found_posts = $wpdb->get_var("SELECT FOUND_ROWS()");
- $wp_query->query_vars['posts_per_page'] = $limit;
- $wp_query->max_num_pages = ceil($wp_query->found_posts/$limit);
-
- if($res){
- if(!empty($status_filter_lang)){
- foreach($res as $row){
-
- $_translations = array();
- foreach($sitepress->get_active_languages() as $l){
- if($l['code'] == $sitepress_settings['st']['strings_language']) continue;
- $lcode_alias = str_replace('-', '', $l['code']);
- if($row['id_'. $lcode_alias]){
- $_translations[$l['code']] = array(
- 'id' => $row['id_'. $lcode_alias],
- 'status' => $row['status_'. $lcode_alias],
- 'language' => $l['code'],
- 'value' => $row['value_'. $lcode_alias],
- 'translator_id' => $row['translator_'. $lcode_alias],
- 'translation_date' => $row['date_'. $lcode_alias]
- );
- }
- }
-
-
- $string_translations[$row['string_id']] = array(
- 'string_id' => $row['string_id'],
- 'string_language' => $row['string_language'],
- 'context' => $row['context'],
- 'name' => $row['name'],
- 'value' => $row['value'],
- 'status' => ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR,
- 'translations' => $_translations
- );
- }
- }else{
- foreach($res as $row){
-
- $_translations = array();
-
- $_status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- $_statuses = array();
- foreach($sitepress->get_active_languages() as $l){
- if($l['code'] == $sitepress_settings['st']['strings_language'] || empty($user_lang_pairs[$sitepress_settings['st']['strings_language']][$l['code']])) continue;
- $lcode_alias = str_replace('-', '', $l['code']);
- if($row['id_'. $lcode_alias]){
- $_translations[$l['code']] = array(
- 'id' => $row['id_'. $lcode_alias],
- 'status' => $row['status_'. $lcode_alias],
- 'language' => $l['code'],
- 'value' => $row['value_'. $lcode_alias],
- 'translator_id' => $row['translator_'. $lcode_alias],
- 'translation_date' => $row['date_'. $lcode_alias]
- );
- }
-
- $_statuses[$l['code']] = @intval($row['status_'. $lcode_alias]);
-
- if($row['status_'. $lcode_alias] == ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR){
- $_status == ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR;
- }
-
- }
- $_statuses = array_values($_statuses);
- $_statuses = array_unique($_statuses);
-
- if($_statuses == array(ICL_STRING_TRANSLATION_NOT_TRANSLATED)){
- $_status = ICL_STRING_TRANSLATION_NOT_TRANSLATED;
- }elseif($_statuses == array(ICL_STRING_TRANSLATION_COMPLETE, ICL_STRING_TRANSLATION_NOT_TRANSLATED)){
- $_status = ICL_STRING_TRANSLATION_PARTIAL;
- }elseif($_statuses == array(ICL_STRING_TRANSLATION_COMPLETE)){
- $_status = ICL_STRING_TRANSLATION_COMPLETE;
- }elseif(in_array(ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR, $_statuses) || in_array(ICL_STRING_TRANSLATION_NEEDS_UPDATE, $_statuses)){
- $_status = ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR;
- }
-
-
- $string_translations[$row['string_id']] = array(
- 'string_id' => $row['string_id'],
- 'string_language' => $row['string_language'],
- 'context' => $row['context'],
- 'name' => $row['name'],
- 'value' => $row['value'],
- 'status' => $_status,
- 'translations' => $_translations
- );
- }
-
- }
-
- }
- /* TRANSLATOR - END */
- }else{
-
- // removed check for language = default lang
- if($status_filter != ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR){
- $res = $wpdb->get_results("
- SELECT SQL_CALC_FOUND_ROWS id AS string_id, language AS string_language, context, name, value, status
- FROM {$wpdb->prefix}icl_strings s
- WHERE
- 1
- {$extra_cond}
- ORDER BY string_id DESC
- LIMIT {$offset},{$limit}
- ", ARRAY_A);
- }else{
- $res = $wpdb->get_results("
- SELECT SQL_CALC_FOUND_ROWS s.id AS string_id, s.language AS string_language, s.context, s.name, s.value, " . ICL_STRING_TRANSLATION_WAITING_FOR_TRANSLATOR . " AS status
- FROM {$wpdb->prefix}icl_strings s
- JOIN {$wpdb->prefix}icl_string_translations str ON str.str…
Large files files are truncated, but you can click here to view the full file