summaryrefslogtreecommitdiff
path: root/www/wiki/extensions/Translate/resources/js/ext.translate.statsbar.js
diff options
context:
space:
mode:
Diffstat (limited to 'www/wiki/extensions/Translate/resources/js/ext.translate.statsbar.js')
-rw-r--r--www/wiki/extensions/Translate/resources/js/ext.translate.statsbar.js187
1 files changed, 187 insertions, 0 deletions
diff --git a/www/wiki/extensions/Translate/resources/js/ext.translate.statsbar.js b/www/wiki/extensions/Translate/resources/js/ext.translate.statsbar.js
new file mode 100644
index 00000000..aeec9314
--- /dev/null
+++ b/www/wiki/extensions/Translate/resources/js/ext.translate.statsbar.js
@@ -0,0 +1,187 @@
+/*!
+ * Translate language statistics bar - jQuery plugin.
+ *
+ * @author Niklas Laxström
+ * @author Santhosh Thottingal
+ * @license GPL-2.0-or-later
+ * @since 2012-11-30
+ */
+
+/*
+ * Usage:
+ * $( '<div>' ).languagestatsbar( {
+ * language: 'fi',
+ * group: 'core'
+ * } );
+ * The status bar will be rendered to the newly created div. Or use any container.
+ */
+( function () {
+ 'use strict';
+
+ var LanguageStatsBar = function ( container, options ) {
+ this.$container = $( container );
+ this.group = options.group;
+ this.language = options.language;
+ this.$statsBar = null;
+ this.elements = null;
+ this.init();
+ };
+
+ LanguageStatsBar.prototype = {
+ init: function () {
+ if ( mw.translate.languagestats[ this.language ] ) {
+ this.render();
+ } else {
+ mw.translate.loadLanguageStats( this.language )
+ .done( this.render.bind( this ) );
+ }
+ },
+
+ /**
+ * Listen for the change events and update the statsbar
+ */
+ listen: function () {
+ var i,
+ statsbar = this,
+ languageStats = mw.translate.languagestats[ this.language ];
+
+ statsbar.$statsBar.on( 'change', function ( event, to, from ) {
+ for ( i = 0; i < languageStats.length; i++ ) {
+ if ( languageStats[ i ].group === statsbar.group ) {
+ // Changing a proofread message does not create a new translation
+ if ( to === 'translated' && from !== 'proofread' ) {
+ languageStats[ i ].translated++;
+ }
+ if ( to === 'proofread' ) {
+ languageStats[ i ].proofread++;
+ }
+ if ( to === 'fuzzy' ) {
+ languageStats[ i ].fuzzy++;
+ }
+
+ if ( from === 'fuzzy' ) {
+ languageStats[ i ].fuzzy--;
+ }
+ if ( from === 'proofread' ) {
+ languageStats[ i ].proofread--;
+ }
+ // Proofreading a message does not remove translation
+ if ( from === 'translated' && to !== 'proofread' ) {
+ languageStats[ i ].translated--;
+ }
+ break;
+ }
+ }
+
+ // Update the stats bar
+ statsbar.update();
+ } );
+
+ statsbar.$container.on( {
+ mouseenter: function () {
+ statsbar.elements.$info.removeClass( 'hide' );
+ },
+ mouseleave: function () {
+ statsbar.elements.$info.addClass( 'hide' );
+ }
+ } );
+ },
+
+ render: function () {
+ this.$statsBar = $( '<div>' )
+ .addClass( 'tux-statsbar' )
+ .data( 'group', this.group );
+
+ this.elements = {
+ $proofread: $( '<span>' ).addClass( 'tux-proofread' ),
+ $translated: $( '<span>' ).addClass( 'tux-translated' ),
+ $fuzzy: $( '<span>' ).addClass( 'tux-fuzzy' ),
+ $untranslated: $( '<span>' ).addClass( 'tux-untranslated' ),
+ $info: $( '<div>' ).addClass( 'tux-statsbar-info hide' )
+ };
+
+ this.update();
+ this.$statsBar.append( [
+ // Append needs an array instead of an object
+ this.elements.$proofread,
+ this.elements.$translated,
+ this.elements.$fuzzy,
+ this.elements.$untranslated,
+ this.elements.$info
+ ] );
+ this.$container.append( this.$statsBar );
+
+ this.listen();
+ },
+
+ update: function () {
+ var proofread, translated, fuzzy, untranslated,
+ stats = this.getStatsForGroup( this.group );
+
+ proofread = 100 * stats.proofread / stats.total;
+ // Proofread messages are also translated, so remove those for
+ // the bar showing only translated count.
+ translated = stats.translated - stats.proofread;
+ translated = 100 * translated / stats.total;
+ fuzzy = 100 * stats.fuzzy / stats.total;
+ untranslated = 100 - proofread - translated - fuzzy;
+
+ this.elements.$proofread[ 0 ].style.width = proofread + '%';
+ this.elements.$translated[ 0 ].style.width = translated + '%';
+ this.elements.$fuzzy[ 0 ].style.width = fuzzy + '%';
+ this.elements.$untranslated[ 0 ].style.width = untranslated + '%';
+
+ translated = !translated ? 0 : translated + proofread;
+ proofread = !proofread ? 0 : proofread;
+
+ if ( fuzzy ) {
+ this.elements.$info
+ .text( mw.msg( 'translate-statsbar-tooltip-with-fuzzy',
+ translated.toFixed(), proofread.toFixed(),
+ fuzzy.toFixed() ) );
+ } else {
+ this.elements.$info
+ .text( mw.msg( 'translate-statsbar-tooltip',
+ translated.toFixed(), proofread.toFixed() ) );
+ }
+ },
+
+ getStatsForGroup: function ( group ) {
+ var i,
+ languageStats = mw.translate.languagestats[ this.language ];
+
+ for ( i = 0; i < languageStats.length; i++ ) {
+ if ( languageStats[ i ].group === group ) {
+ return languageStats[ i ];
+ }
+ }
+
+ return {
+ proofread: 0,
+ total: 0,
+ fuzzy: 0,
+ translated: 0
+ };
+ }
+ };
+
+ /*
+ * languagestatsbar PLUGIN DEFINITION
+ */
+
+ $.fn.languagestatsbar = function ( options ) {
+ return this.each( function () {
+ var $this = $( this ),
+ data = $this.data( 'languagestatsbar' );
+
+ if ( !data ) {
+ $this.data( 'languagestatsbar', ( data = new LanguageStatsBar( this, options ) ) );
+ }
+ } );
+ };
+
+ $.fn.languagestatsbar.Constructor = LanguageStatsBar;
+
+ mw.translate = mw.translate || {};
+
+}() );