model->get_languages_list( array( 'fields' => 'locale' ) ), $specific_locales ) ) {
add_filter( 'sanitize_title', array( $this, 'sanitize_title' ), 10, 3 );
add_filter( 'sanitize_user', array( $this, 'sanitize_user' ), 10, 3 );
}
}
/**
* modifies the widgets forms to add our language dropdwown list
*
* @since 0.3
*
* @param object $widget
*/
public function in_widget_form( $widget, $return, $instance ) {
$dropdown = new PLL_Walker_Dropdown();
printf( '
',
esc_attr( $widget->id.'_lang_choice' ),
esc_html__( 'The widget is displayed for:', 'polylang' ),
$dropdown->walk(
array_merge(
array( (object) array( 'slug' => 0, 'name' => __( 'All languages', 'polylang' ) ) ),
$this->model->get_languages_list()
),
array(
'name' => $widget->id.'_lang_choice',
'class' => 'tags-input',
'selected' => empty( $instance['pll_lang'] ) ? '' : $instance['pll_lang'],
)
)
);
}
/**
* called when widget options are saved
* saves the language associated to the widget
*
* @since 0.3
*
* @param array $instance widget options
* @param array $new_instance not used
* @param array $old_instance not used
* @param object $widget WP_Widget object
* @return array widget options
*/
public function widget_update_callback( $instance, $new_instance, $old_instance, $widget ) {
if ( ! empty( $_POST[ $key = $widget->id.'_lang_choice' ] ) && in_array( $_POST[ $key ], $this->model->get_languages_list( array( 'fields' => 'slug' ) ) ) ) {
$instance['pll_lang'] = $_POST[ $key ];
}
else {
unset( $instance['pll_lang'] );
}
return $instance;
}
/**
* updates language user preference set in user profile
*
* @since 0.4
*
* @param int $user_id
*/
public function personal_options_update( $user_id ) {
// admin language
$user_lang = in_array( $_POST['user_lang'], $this->model->get_languages_list( array( 'fields' => 'locale' ) ) ) ? $_POST['user_lang'] : 0;
update_user_meta( $user_id, 'user_lang', $user_lang );
// biography translations
foreach ( $this->model->get_languages_list() as $lang ) {
$meta = $lang->slug == $this->options['default_lang'] ? 'description' : 'description_' . $lang->slug;
$description = empty( $_POST[ 'description_' . $lang->slug ] ) ? '' : trim( $_POST[ 'description_' . $lang->slug ] );
/** This filter is documented in wp-includes/user.php */
$description = apply_filters( 'pre_user_description', $description ); // applies WP default filter wp_filter_kses
update_user_meta( $user_id, $meta, $description );
}
}
/**
* form for language user preference in user profile
*
* @since 0.4
*
* @param object $profileuser
*/
public function personal_options( $profileuser ) {
$dropdown = new PLL_Walker_Dropdown();
printf( '
%s
',
esc_html__( 'Admin language', 'polylang' ),
$dropdown->walk(
array_merge(
array( (object) array( 'locale' => 0, 'name' => __( 'WordPress default', 'polylang' ) ) ),
$this->model->get_languages_list()
),
array(
'name' => 'user_lang',
'value' => 'locale',
'selected' => get_user_meta( $profileuser->ID, 'user_lang', true ),
)
)
);
// hidden informations to modify the biography form with js
foreach ( $this->model->get_languages_list() as $lang ) {
$meta = $lang->slug == $this->options['default_lang'] ? 'description' : 'description_' . $lang->slug;
/** This filter is documented in wp-includes/user.php */
$description = apply_filters( 'user_description', get_user_meta( $profileuser->ID, $meta, true ) ); // applies WP default filter wp_kses_data
printf( '',
esc_attr( $lang->slug ),
esc_attr( $lang->name ),
esc_attr( $description )
);
}
}
/**
* ugprades languages files after a core upgrade
* only for backward compatibility WP < 4.0 *AND* Polylang < 1.6
*
* @since 0.6
*
* @param string $version new WP version
*/
public function upgrade_languages( $version ) {
// $GLOBALS['wp_version'] is the old WP version
if ( version_compare( $version, '4.0', '>=' ) && version_compare( $GLOBALS['wp_version'], '4.0', '<' ) ) {
/** This filter is documented in wp-admin/includes/update-core.php */
apply_filters( 'update_feedback', __( 'Upgrading language files…', 'polylang' ) );
PLL_Upgrade::download_language_packs();
}
}
/**
* allows to update translations files for plugins and themes
*
* @since 1.6
*
* @param array $locale not used
* @return array list of locales to update
*/
function update_check_locales( $locales ) {
return $this->model->get_languages_list( array( 'fields' => 'locale' ) );
}
/**
* Filters the locale according to the current language instead of the language
* of the admin interface
*
* @since 2.0
*
* @param string $locale
* @return string
*/
public function get_locale( $locale ) {
return $this->curlang->locale;
}
/**
* Maybe fix the result of sanitize_title() in case the languages include German or Danish
* Without this filter, if language of the title being sanitized is different from the language
* used for the admin interface and if one this language is German or Danish, some specific
* characters such as ä, ö, ü, ß are incorrectly sanitized.
*
* @since 2.0
*
* @param string $title Sanitized title.
* @param string $raw_title The title prior to sanitization.
* @param string $context The context for which the title is being sanitized.
* @return string
*/
public function sanitize_title( $title, $raw_title, $context ) {
static $once = false;
if ( ! $once && 'save' == $context && ! empty( $this->curlang ) && ! empty( $title ) ) {
$once = true;
add_filter( 'locale', array( $this, 'get_locale' ), 20 ); // After the filter for the admin interface
$title = sanitize_title( $raw_title, '', $context );
remove_filter( 'locale', array( $this, 'get_locale' ), 20 );
$once = false;
}
return $title;
}
/**
* Maybe fix the result of sanitize_user() in case the languages include German or Danish
*
* @since 2.0
*
* @param string $username Sanitized username.
* @param string $raw_username The username prior to sanitization.
* @param bool $strict Whether to limit the sanitization to specific characters. Default false.
* @return string
*/
public function sanitize_user( $username, $raw_username, $strict ) {
static $once = false;
if ( ! $once && ! empty( $this->curlang ) ) {
$once = true;
add_filter( 'locale', array( $this, 'get_locale' ), 20 ); // After the filter for the admin interface
$title = sanitize_title( $raw_username, '', $strict );
remove_filter( 'locale', array( $this, 'get_locale' ), 20 );
$once = false;
}
return $username;
}
}