diff options
Diffstat (limited to 'SemanticResultFormats/resources/ext.srf.api.results.js')
-rw-r--r-- | SemanticResultFormats/resources/ext.srf.api.results.js | 267 |
1 files changed, 0 insertions, 267 deletions
diff --git a/SemanticResultFormats/resources/ext.srf.api.results.js b/SemanticResultFormats/resources/ext.srf.api.results.js deleted file mode 100644 index f6c1f04b..00000000 --- a/SemanticResultFormats/resources/ext.srf.api.results.js +++ /dev/null @@ -1,267 +0,0 @@ -/** - * SRF JavaScript for the api/results - * - * @since 1.9 - * @release 0.1 - * - * @file - * @ingroup SRF - * - * @licence GNU GPL v2 or later - * @author mwjames - */ -/* global wgMonthNames:true */ -( function( $, mw, srf ) { - 'use strict'; - - ////////////////////////// PRIVATE METHODS ////////////////////////// - - var timeLocales = { - monthNames: ['January','February','March','April','May','June','July','August','September','October','November','December'], - monthNamesShort: ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'], - dayNames: ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'], - dayNamesShort: ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'], - amDesignator: 'AM', - pmDesignator: 'PM' - }; - - // Map wgMonthNames and create an indexed array - var monthNames = []; - $.map ( mw.config.get( 'wgMonthNames' ), function( value, key ) { - if( value !== '' ){ - monthNames.push( value ); - } - } ); - - ////////////////////////// PUBLIC METHODS ///////////////////////// - - /** - * API namespace declaration - * - * @since 1.9 - * @type Object - */ - srf.api = srf.api || {}; - - /** - * Base constructor for objects representing a api.results instance - * - * @since 1.9 - */ - srf.api.results = function() {}; - srf.api.util = function() {}; - - /** - * Public to access results information retrieved through the SMWAPI - * - * @since 1.9 - * @type Object - */ - srf.api.util.prototype = { - - /** - * Array helper functions - * - * @since 1.9 - */ - array:{ - /** - * Array unique function - * - * $.unique only allows to be an array of DOM elements therefore - * this returns a nromal "array" with no duplicates - * - * @credits http://paulirish.com/2010/duck-punching-with-jquery/ - * - * @since 1.9 - */ - unique: function( arr ){ - if ( !!arr[0].nodeType ){ - return $.unique.apply( this, arguments ); - } else { - return $.grep(arr,function(v,k){ return $.inArray(v,arr) === k; } ); - } - } - } - }; - - /** - * Public to access results information retrieved through the SMWAPI - * - * @since 1.9 - * @type Object - */ - srf.api.results.prototype = { - - /** - * Collection related to printrequests and properties - * - * @since 1.9 - */ - printrequests: function( printrequests ){ - var list = printrequests; - - return { - list: list, - - /** - * Returns a key reference array - * - * Transforms printrequest objects into an accessible flat array - * allowing a key reference - * - * Call as class instance via printrequests( [...] ).toArray() - * or as operational method via printrequests().toArray( [...] ) - * - * @since 1.9 - * @type Object - */ - toArray: function ( printrequests ){ - var tList = {}; - printrequests = printrequests || list; - - if ( printrequests !== undefined ){ - $.map( printrequests, function( key, index ) { - tList[key.label] = { typeid: key.typeid, position: index, meta: key.meta }; - } ); - } - return list = tList; - }, - - /** - * Returns typeid for a property - * - * @since 1.9 - * @type Object - */ - getTypeId: function ( property ){ - return list[property].typeid || null; - }, - - /** - * Returns some meta data for a property - * - * @since 1.9 - * @type Object - */ - getMetaData: function ( property ){ - return list[property].meta || null; - }, - - /** - * Returns the position for a property - * - * Printouts in the result object are not sorted - * therefore this returns its position in accordance with the query - * - * @since 1.9 - */ - getPosition: function ( property ){ - return list[property].position || null; - } - }; - }, - - /** - * Collection related to data values - * - * @since 1.9 - */ - dataValues: { - - /** - * Methods related to time data value - * - * @since 1.9 - */ - time: { - - /** - * Returns normalized timestamp as JS date object - * - * @since 1.9 - * @type Object - */ - parseDate: function( d ) { - if ( typeof d === 'object') { - return d; - } - if ( typeof d === 'number' ) { - return new Date( d * 1000 ); - } - if ( typeof d === 'string' ) { - if ( d.match(/^\d+(\.\d+)?$/) ) { - return new Date( parseFloat( d ) * 1000 ); - } - } - return null; - }, - - /** - * Create a new JavasScript date object based on the timestamp and return - * an ISO string - * - * @see SMWTimeValue::getISO8601Date() - * - * @since 1.9 - * @type Object - */ - getISO8601Date: function( timestamp ) { - var d = this.parseDate( timestamp ); - return d !== null ? d.toISOString() : null; - }, - - /** - * Returns a formatted time (HH:MM:SS) - * - * @param string|Date time - * @return string - */ - getTime: function( time ) { - var d = typeof time === 'object' ? time : this.parseDate( time ); - return ( d.getHours() < 10 ? '0' + d.getHours() : d.getHours() ) + - ':' + ( d.getMinutes() < 10 ? '0' + d.getMinutes() : d.getMinutes() ) + - ':' + ( d.getSeconds() < 10 ? '0' + d.getSeconds() : d.getSeconds() ); - }, - - /** - * Returns a formatted date - * - * @param string|Date - * @param string format - * @return string - */ - getDate: function( date, format ) { - var d = typeof date === 'object' ? date : this.parseDate( date ), - formatDate = ''; - - switch( format ) { - case 'dmY': - formatDate = d.getDate() + '.' + ( '' + d.getMonth() + 1 ) + '.' + d.getFullYear(); - break; - case 'Ymd': - formatDate = d.getFullYear() + '.' + ( '' + d.getMonth() + 1 ) + '.' + d.getDate(); - break; - default: - formatDate = d.getDate() + ' ' + monthNames[d.getMonth()] + ' ' + d.getFullYear(); - } - - return formatDate; - }, - - /** - * Returns date - * - * @param string timestamp - * @param string format - * @return string - */ - getMediaWikiDate: function( timestamp, format ) { - var date = this.parseDate( timestamp ); - return this.getDate( date, format ) + ' ' + this.getTime( date ); - } - } - } - }; - -} )( jQuery, mediaWiki, semanticFormats );
\ No newline at end of file |