$.when(mw.loader.using('ext.gadget.Twinkle'), $.ready).then(function() {

/*
 ****************************************
 *** twinkleos.js: Oversight/OS module
 ****************************************
 * Mode of invocation:     Tab ("OS")
 * Active on:              Non-special pages
 */

Twinkle.os = function twinkleos() {
	// Disable on special pages
	if (mw.config.get('wgNamespaceNumber') < 0) {
		return;
	}
	Twinkle.addPortletLink( Twinkle.os.callback, "OS", "tw-os", "Request oversight" );
};

Twinkle.os.callback = function oscallback() {
	var getUrl = function(pageName, params) {
		return "https://" + mw.config.get('wgServerName') + mw.util.getUrl(pageName, params);
	};
	var pageName = Morebits.pageNameNorm;

	var Window = new Morebits.simpleWindow( 800, 500 );
	Window.setTitle( "Request oversight" );
	Window.setScriptName( "Twinkle" );
	Window.addFooterLink( "Oversight policy", "WP:OS" );
	Window.addFooterLink( "Twinkle help", "WP:TW/DOC" );

	var form = new Morebits.quickForm( Twinkle.os.evaluate );

	var field1 = form.append( {
		type: 'field',
		label: 'Choose reason for oversight',
		id: 'type_fieldset'
	} );

	field1.append( {
		type: 'select',
		name: 'options',
		event: Twinkle.os.optionChanged,
		list: [
				{
					label: 'Non-public personal information',
					value: 'personal',
					checked: true
				},
				{
					label: 'Potentially libelous information',
					value: 'libel'
				},
				{
					label: 'Other',
					value: 'other'
				}
			]
	} );

	field1.append({
		type: 'div',
		label: [
			$("<div>").html('For redaction of copyright violations, please request <a href="//en.wikipedia.orghttps://wikines.com/en/WP:REVDEL">revision deletion</a> instead via {{<a href="//en.wikipedia.orghttps://wikines.com/en/Template:Copyvio-revdel">copyvio-revdel</a>}}.'),

			$("<div>").html('<u>Make sure</u> you are familiar with the <a href="//en.wikipedia.orghttps://wikines.com/en/Wikipedia:Oversight#Policy">oversight policy</a>, before you send a request. <a href="//en.wikipedia.orghttps://wikines.com/en/Wikipedia:Oversight/FAQ">Oversight FAQ</a>.')
		]
	});

	var field2 = form.append( {
		type: 'field',
		label: 'Email',
		name: 'work_area'
	} );

	field2.append({
		type: 'div',
		label: $("<div>").html('Note that emails are sent as plain text. Wiki markup (such as ]) and HTML code will not work.')
	});

	field2.append({
		type: 'input',
		name: 'subject',
		label: 'Subject: ',
		size: 80,
		value: ''
	});

	if (mw.util.getParamValue('action') === 'history' && $('#pagehistory input').length) {
		field2.append({
			type: 'div',
			label: $("<div>").html('To insert a diff link, move away this window and select the revisions, then click here:    ' +
			'<button class="os-add-revs">Add selected revisions</button>')
		});
	}

	field2.append({
		type: 'textarea',
		name: 'body',
		className: 'os-email-subject',
		label: 'Message',
		value: ''
	});

	mw.util.addCSS(
		"div.os-email-subject textarea { font-size: 110%; height: 10em; }"
	);

	field2.append({
		type: 'div',
		label: $("<div>").html('Please provide the reason for oversight (unless it is really obvious). Avoid boilerplate messages.')
	});

	form.append( { type:'submit', label:'Send email' } );

	var result = form.render();
	Window.setContent(result);
	Window.display();

	Twinkle.os.subjectValues = {
		personal: 'Non-public personal information at ' + pageName,
		libel: 'Potentially libellous content at ' + pageName,
		other: 'Oversight request at page ' + pageName
	};

	var data = '\n\nPage link: ' + getUrl();

	// Diff pages
	if (mw.util.getParamValue('diff')) {
		data += '\nLink to diff: ' + location.href.replace(/&diffmode=.*$/,'')
			+ '\nRevisions:'
			+ '\nFrom ' + mw.config.get('wgDiffOldId') + ' - ' + getUrl(pageName,{'oldid':mw.config.get('wgDiffOldId')})
			+   '\nTo ' + mw.config.get('wgDiffNewId') + ' - ' + getUrl(pageName,{'oldid':mw.config.get('wgDiffNewId')});

	// Oldid pages
	} else if (mw.util.getParamValue('oldid') ) {
		data += '\nLink to revision: ' + location.href;

	// History pages with more than one revision
	} else if (mw.util.getParamValue('action') === 'history' && $('#pagehistory input').length ) {
		var old_ = $("ul#pagehistory input:checked").val();
		var new_ = $("ul#pagehistory input:checked").val();
		data += "\nLink to diff: " + getUrl(pageName, {'diff':new_, 'oldid':old_});
		$(".os-add-revs").click(function onaddclick(e) {
			e.preventDefault();
			var old_ = $("ul#pagehistory input:checked").value;
			var new_ = $("ul#pagehistory input:checked").value;
			$(".os-email-subject textarea").value += '\nLink to diff: ' + getUrl(pageName, {'diff':new_, 'oldid':old_});
		});
	}

	Twinkle.os.bodyValues = {
		personal : 'Requesting removal of personal information from page "' + pageName + '".' + data,
		libel: 'Requesting removal of libellous content from page "' + pageName + '".' + data,
		other: 'Requesting oversight of content from page "' + pageName + '".' + data
	};
	
	// Fake a change event on the first type radio, to initialize the type-dependent controls
	var evt = document.createEvent("Event");
	evt.initEvent("change", true, true);
	result.options.dispatchEvent(evt);
};

Twinkle.os.optionChanged = function optionChanged(event) {
	var form = event.target.form;

	if(Twinkle.os.prevOption) {
		// save the entered values so that they are retained if the user switches back to this option
		Twinkle.os.subjectValues = form.subject.value;
		Twinkle.os.bodyValues = form.body.value;
	}

	form.subject.value = Twinkle.os.subjectValues;
	form.body.value = Twinkle.os.bodyValues;

	Twinkle.os.prevOption = event.target.value;
};

Twinkle.os.evaluate = function evaluate(e) {
	var form = e.target;
	var params = {
		emailSubject: form.subject.value,
		emailBody: form.body.value
	};

	Morebits.simpleWindow.setButtonsEnabled(false);
	var token_api = new Morebits.wiki.api( 'Obtaining token for email', {
		"action": "query",
		"meta": "tokens"
	}, Twinkle.os.sendEmail );
	token_api.parent = params;
	token_api.post();
	Morebits.status.init(form);
	Morebits.wiki.actionCompleted.notice = "Email";
	Morebits.wiki.actionCompleted.postfix = "Sent successfully";
};

Twinkle.os.sendEmail = function sendemail(apiobj) {
	var params = apiobj.parent;
	var token = $(apiobj.responseXML).find("tokens").attr("csrftoken");
	var mail_api = new Morebits.wiki.api( 'Sending email', {
		'action': 'emailuser',
		'target': 'Oversight',
		'subject': params.emailSubject,
		'text':  params.emailBody, // + '\n\n' + 'Sent via Twinkle', // Twinkle.getPref('emailSummaryAd'),
		'ccme': 1, // Twinkle.getPref('ccCopyOfEmail'),
		'token' : token
	// onSuccess and statusElement are null
	}, null , null, function onError() {
		Morebits.status.printUserText('Subject: ' + params.emailSubject + '\n' + params.emailBody, 
		"Your email is provided below, which you can copy and paste into a new OS dialog if you wish to try again:");
	});
	mail_api.post();
};

Twinkle.os(); 

});