From 6d2af1878afe5eb15b5349b9d9d25d9399d0c1e8 Mon Sep 17 00:00:00 2001 From: Sandro Santilli Date: Tue, 22 Sep 2015 13:07:04 +0200 Subject: [PATCH] Add min confidence parameter to language filter --- langfilter/langfilter.php | 9 +++++++-- langfilter/templates/settings.tpl | 1 + 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/langfilter/langfilter.php b/langfilter/langfilter.php index 7adec235..b29084c8 100644 --- a/langfilter/langfilter.php +++ b/langfilter/langfilter.php @@ -35,6 +35,7 @@ function langfilter_addon_settings(&$a,&$s) { $enable_checked = (intval(get_pconfig(local_user(),'langfilter','disable')) ? '' : ' checked="checked" '); $languages = get_pconfig(local_user(),'langfilter','languages'); + $minconfidence = get_pconfig(local_user(),'langfilter','minconfidence')*100; if(! $languages) $languages = 'en,de,fr,it,es'; @@ -44,6 +45,7 @@ function langfilter_addon_settings(&$a,&$s) { '$intro' => t ('This addon tries to identify the language of a postings. If it does not match any language spoken by you (see below) the posting will be collapsed. Remember detecting the language is not perfect, especially with short postings.'), '$enabled' => array('langfilter_enable', t('Use the language filter'), $enable_checked, ''), '$languages' => array('langfilter_languages', t('I speak'), $languages, t('List of abbreviations (iso2 codes) for languages you speak, comma separated. For example "de,it".') ), + '$minconfidence' => array('langfilter_minconfidence', t('Minimum confidence in language detection'), $minconfidence, t('Minimum confidence in language detection being correct, from 0 to 100. Posts will not be filtered when the confidence of language detection is below this percent value.') ), '$submit' => t('Save Settings'), )); @@ -63,8 +65,11 @@ function langfilter_addon_settings_post(&$a,&$b) { $enable = ((x($_POST,'langfilter_enable')) ? intval($_POST['langfilter_enable']) : 0); $disable = 1-$enable; set_pconfig(local_user(),'langfilter','disable', $disable); - $confidence = ((x($_POST,'langfilter_minconfidence')) ? intval($_POST['langfilter_minconfidence']) : 0); - set_pconfig(local_user(),'langfilter','minconfidence', $confidence); + $minconfidence = 0+$_POST['langfilter_minconfidence']; + if ( ! $minconfidence ) $minconfidence = 0; + else if ( $minconfidence < 0 ) $minconfidence = 0; + else if ( $minconfidence > 100 ) $minconfidence = 100; + set_pconfig(local_user(),'langfilter','minconfidence', $minconfidence/100.0); info( t('Language Filter Settings saved.') . EOL); } } diff --git a/langfilter/templates/settings.tpl b/langfilter/templates/settings.tpl index 0597d755..5d1fb25f 100644 --- a/langfilter/templates/settings.tpl +++ b/langfilter/templates/settings.tpl @@ -10,6 +10,7 @@

{{$intro}}

{{include file="field_checkbox.tpl" field=$enabled}} {{include file="field_input.tpl" field=$languages}} + {{include file="field_input.tpl" field=$minconfidence}}