Toggle menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

MediaWiki:Gadget-calculator-crystals-core.js: Difference between revisions

MediaWiki interface page
Content added Content deleted
(added calculate button and song ranks)
(added tier options)
Line 35: Line 35:
* Event
* Event
*/
*/
var eventTierOptions = [ 'T1-10', 'T20-100', 'T200-500', 'T1000',
'T2000-5000', 'T10000-50000', 'T100000', 'T200000', 'T300000',
'T500000', 'T1000000' ];
var eventTierWidget = new OO.ui.FieldLayout(
var eventTierWidget = new OO.ui.FieldLayout(
new OO.ui.ButtonSelectWidget( {
new OO.ui.ButtonSelectWidget( {
items: eventTierOptions.map( function( tier ) {
items: [],
return new OO.ui.ButtonOptionWidget( {
data: tier,
label: tier
} );
} ),
} ),
} ),
{
{
Line 58: Line 66:
var songRankWidget = new OO.ui.FieldLayout(
var songRankWidget = new OO.ui.FieldLayout(
new OO.ui.ButtonSelectWidget( {
new OO.ui.ButtonSelectWidget( {
items: songRankOptions.map( function ( rank ) {
items: songRankOptions.map( function( rank ) {
return new OO.ui.ButtonOptionWidget( {
return new OO.ui.ButtonOptionWidget( {
data: rank,
data: rank,

Revision as of 05:51, 24 August 2022

( function ( $, mw ) {
	/* 
	 * Date range
	 */
	var startDateWidget = new OO.ui.FieldLayout(
		new mw.widgets.DateInputWidget( {
			type: 'date'
		} ),
		{
			label: 'Start date',
			align: 'inline',
			help: 'test'
		}
	);
	
	var endDateWidget = new OO.ui.FieldLayout(
		new mw.widgets.DateInputWidget( {
			type: 'date'
		} ),
		{
			label: 'End date',
			align: 'inline'
		}
	);
	
	var dateFieldset = new OO.ui.FieldsetLayout( {
	    label: 'Date range',
	    items: [
	    	startDateWidget,
			endDateWidget
		]
	} );
	
	/*
	 * Event
	 */
	var eventTierOptions = [ 'T1-10', 'T20-100', 'T200-500', 'T1000', 
		'T2000-5000', 'T10000-50000', 'T100000', 'T200000', 'T300000',
		'T500000', 'T1000000' ];
	var eventTierWidget = new OO.ui.FieldLayout(
		new OO.ui.ButtonSelectWidget( {
			items: eventTierOptions.map( function( tier ) {
				return new OO.ui.ButtonOptionWidget( {
					data: tier,
					label: tier
				} );
			} ),
		} ),
		{
			label: 'Average tier',
			align: 'inline'
		}
	); 
	 
    var eventFieldset = new OO.ui.FieldsetLayout( {
	    label: 'Events',
	    items: [
	    	eventTierWidget
		]
	} );
	
	/* 
	 * Song
	 */
	var songRankOptions = [ 'S', 'A', 'B', 'C' ];
	var songRankWidget = new OO.ui.FieldLayout(
		new OO.ui.ButtonSelectWidget( {
			items: songRankOptions.map( function( rank ) {
				return new OO.ui.ButtonOptionWidget( {
					data: rank,
					label: rank
				} );
			} ),
		} ),
		{
			label: 'Average song rank',
			align: 'inline'
		}
	);
	
	var songComboOptions = [ 'Full combo (combo 4)', 'Combo 3', 'Combo 2',
		'Combo 1' ];
	var songComboHardWidget = new OO.ui.FieldLayout(
		new OO.ui.ButtonSelectWidget( {
			items: [],
		} ),
		{
			label: 'Average song combo (on hard)',
			align: 'inline'
		}
	);
	
	var songComboExpertWidget = new OO.ui.FieldLayout(
		new OO.ui.ButtonSelectWidget( {
			items: [],
		} ),
		{
			label: 'Average song combo (on expert)',
			align: 'inline'
		}
	);
	
	var songComboMasterWidget = new OO.ui.FieldLayout(
		new OO.ui.ButtonSelectWidget( {
			items: [],
		} ),
		{
			label: 'Average song combo (on master)',
			align: 'inline'
		}
	);
	
    var songFieldset = new OO.ui.FieldsetLayout( {
	    label: 'Songs',
	    items: [
	    	songRankWidget,
	    	songComboHardWidget,
	    	songComboExpertWidget,
	    	songComboMasterWidget
		]
	} );

	/* 
	 * Challenge Stamp
	 */
	var clStampMenuItems = [];
	var clStampOptions = [ 'Crystals', 'Song cards', 'Miracle gems',
		'Magic cloth', 'Magic thread', 'Mysterious seeds', 
		'Intermediate practice scores', 'Coins' ];
	for (var i = 0; i < clStampOptions.length; i++) {
		clStampMenuItems.push(new OO.ui.MenuOptionWidget( {
            data: clStampOptions[i],
            label: clStampOptions[i]
        } ));
	}
	var clStampWidget = new OO.ui.DropdownWidget( {
	    menu: {
	        items: clStampMenuItems
	    }
    } );
    
    var clFieldset = new OO.ui.FieldsetLayout( {
	    label: 'Challenge Stamp reward',
	    items: [
	    	clStampWidget
		]
	} );
	
	/*
	 * Everything
	 */
	
	var submitButton = new OO.ui.ButtonInputWidget( { 
		label: 'Calculate',
		flags: [ 'primary', 'progressive' ],
		align: 'left',
		icon: 'mathematics'
	} );
	
	var fieldset = new OO.ui.FieldsetLayout( {
		items: [
			dateFieldset,
			eventFieldset,
			songFieldset,
			clFieldset,
			submitButton
		]
	} );

	$( '#calculator' ).append( fieldset.$element );
	
} )( jQuery, mediaWiki );
Cookies help us deliver our services. By using our services, you agree to our use of cookies.