//Dokumentation unter ] <nowiki>
/*global mw: true */
(function($, libs){
var schnark_dialog = {
version: 1.6,
l10n: {ok: 'OK', cancel: 'Abbrechen', other: 'Sonstiges'},
render: {
input: function (param, uid) {
if (param.multiline) return schnark_dialog.render.inputbox(param, uid);
var h = mw.html;
var text = param.text;
if (!param.html) text = h.escape(text);
return $(h.element('div', {id: uid + 'dialog-tog-' + param.name, style: 'display:table; width:100%;'}, new h.Raw(
h.element('label', {'for': uid + 'dialog-' + param.name, style: 'display:table-cell;'}, new h.Raw(text)) +
h.element('input', {type: 'text', name: uid + 'dialog-' + param.name, id: uid + 'dialog-' + param.name, size: '50', style: 'display:table-cell; width:100%;', value: param.standard || ''})
)));
},
inputbox: function (param, uid) {
var h = mw.html;
var text = param.text;
if (!param.html) text = h.escape(text);
return $(h.element('div', {id: uid + 'dialog-tog-' + param.name}, new h.Raw(
h.element('label', {'for': uid + 'dialog-' + param.name}, new h.Raw(text)) +
h.element('textarea', {name: uid + 'dialog-' + param.name, id: uid + 'dialog-' + param.name, cols: '50', style: 'width:100%;', rows: '2'}, param.standard || '')
)));
},
label: function (param, uid) {
var h = mw.html;
var text = param.text;
if (!param.html) text = h.escape(text);
return $(h.element('div', {id: uid + 'dialog-tog-' + param.name}, new h.Raw(text)));
},
select: function (param, uid) {
var h = mw.html;
var options = '';
for (var i = 0; i < param.list.length; i++) {
var prop = {value: i.toString()};
if (param.standard === i) prop.selected = 'selected';
options += h.element('option', prop, param.list);
}
var text = param.text;
if (!param.html) text = h.escape(text);
var help = param.list;
if (!param.html) help = h.escape(help);
var ret = $(h.element('div', {id: uid + 'dialog-tog-' + param.name}, new h.Raw(
h.element('label', {'for': uid + 'dialog-' + param.name}, new h.Raw(text)) +
h.element('select', {name: uid + 'dialog-' + param.name, id: uid + 'dialog-' + param.name}, new h.Raw(options)) +
h.element('div', {id: uid + 'dialog-help-' + param.name}, new h.Raw(help)))));
ret.find('select').change(function() {
$('#' + uid + 'dialog-help-' + param.name)(param.list);
});
return ret;
},
select_multi: function (param, uid) {
var h = mw.html;
var checkboxes = '';
for (var i = 0; i < param.list.length; i++) {
var prop = {type: 'checkbox', id: uid + 'dialog-' + param.name + i};
if ($.isArray(param.standard) && $.inArray(i, param.standard) != -1) prop.checked = 'checked';
var item = param.list;
if (!param.html) item = h.escape(item);
checkboxes += h.element('input', prop) +
h.element('label', {'for': uid + 'dialog-' + param.name + i}, new h.Raw(item)) +
h.element('br', {});
}
var text = param.text;
if (!param.html) text = h.escape(text);
var ret = $(h.element('div', {id: uid + 'dialog-tog-' + param.name}, new h.Raw(
h.element('span', {}, new h.Raw(text)) +
h.element('div', {}, new h.Raw(checkboxes))
)));
return ret;
},
select_other: function (param, uid, dummy, resize) {
var h = mw.html;
param.list.push();
var options = '';
var std = (typeof param.standard == 'string') ? param.list.length - 1 : (param.standard || 0);
for (var i = 0; i < param.list.length; i++) {
var prop = {value: i.toString()};
if (i == std) prop.selected = 'selected';
options += h.element('option', prop, param.list);
}
var text = param.text;
if (!param.html) text = h.escape(text);
var help = param.list;
if (!param.html) help = h.escape(help);
var input = param.multiline ?
h.element('textarea', {name: uid + 'dialog-' + param.name + '-other', id: uid + 'dialog-' + param.name + '-other', cols: '50', style: 'width:100%;', rows: '2'}, (typeof param.standard == 'string') ? param.standard : '')
:
h.element('input', {type: 'text', name: uid + 'dialog-' + param.name + '-other', id: uid + 'dialog-' + param.name + '-other',
size: '50', style: 'width:100%',
value: (typeof param.standard == 'string') ? param.standard : ''});
var ret = $(h.element('div', {id: uid + 'dialog-tog-' + param.name}, new h.Raw(
h.element('label', {'for': uid + 'dialog-' + param.name}, new h.Raw(text)) +
h.element('select', {name: uid + 'dialog-' + param.name, id: uid + 'dialog-' + param.name}, new h.Raw(options)) +
h.element('div', {}, new h.Raw(input)) +
h.element('div', {id: uid + 'dialog-help-' + param.name}, new h.Raw(help)))));
if (std != param.list.length - 1) ret.find('#' + uid + 'dialog-' + param.name + '-other').hide();
ret.find('select').change(function() {
var nr = $('#' + uid + 'dialog-' + param.name + ' :selected').val();
$('#' + uid + 'dialog-help-' + param.name)(param.list);
if (nr == param.list.length - 1) {
$('#' + uid + 'dialog-' + param.name + '-other').show();
} else {
$('#' + uid + 'dialog-' + param.name + '-other').hide();
}
resize();
});
return ret;
},
toggle: function (param, uid, params, resize) {
var h = mw.html;
var text = param.text;
if (!param.html) text = h.escape(text);
var ret = $(h.element('div', {id: uid + 'dialog-tog-' + param.name}, new h.Raw(
h.element('input', {type: 'checkbox', id: uid + 'dialog-' + param.name, checked: 'checked'}) +
h.element('label', {'for': uid + 'dialog-' + param.name}, new h.Raw(text))
)));
ret.find('input').change(function() {
var func = this.checked ? 'show' : 'hide';
for (var i = 0; i < param.list.length; i++) {
params].offtoggle = !this.checked;
$('#' + uid + 'dialog-tog-' + params].name)();
}
resize();
});
return ret;
}
},
get: {
input: function (param, uid) {
return $('#' + uid + 'dialog-' + param.name).val();
},
inputbox: function (param, uid) {
return $('#' + uid + 'dialog-' + param.name).val();
},
select: function (param, uid) {
return param.list;
},
select_multi: function (param, uid) {
var ret = ;
for (var i = 0; i < param.list.length; i++)
if ($('#' + uid + 'dialog-' + param.name + i).prop('checked')) ret.push(param.list);
return ret;
},
select_other: function (param, uid) {
var nr = $('#' + uid + 'dialog-' + param.name + ' :selected').val();
if (nr == param.list.length - 1) {
return $('#' + uid + 'dialog-' + param.name + '-other').val();
} else {
return param.list;
}
},
toggle: function (param, uid) {
return !!$('#' + uid + 'dialog-' + param.name).prop('checked');
}
},
get_all: function (param, uid) {
var r = {}, ret;
for (var i = 0; i < param.length; i++) {
var p = param;
if (p.offtoggle) continue;
if (p.type == 'label') continue;
ret = schnark_dialog.get(p, uid);
if (!p.optional && typeof ret != 'boolean' && !ret.length) return false;
r = ret;
}
return r;
},
show: function (title, param, success, abort) {
abort = abort || function(){};
var h = mw.html;
var uid = 'dialog-form-' + $.now();
var select = function (field) {
if (field.selectionStart || field.selectionStart == '0') { //Code für Browser
field.selectionStart = 0;
field.selectionEnd = field.value.length;
} else if (document.body.createTextRange) { //Code für IE
var sel = field.createTextRange();
sel.moveStart('character', 0);
sel.moveEnd('character', 0);
try { sel.select(); } catch (e) {}
}
$(field).focus();
};
var done = false;
var kill = function() {
$(this).dialog('close');
$('#' + uid).remove();
},
ok = function() {
if (done) return; done = true;
var ret = schnark_dialog.get_all(param, uid);
kill();
if (ret) {
success(ret);
} else {
abort(false);
}
},
abbrechen = function() {
if (done) return; done = true;
kill();
abort(true);
};
var resize = function() {
$('#' + uid).dialog('option', {width: 'auto', height: 'auto'});
};
var onEnter = function (event) {
if (event.keyCode == $.ui.keyCode.ENTER) ok();
};
var i, p;
var dialog = $(h.element('div', {id: uid, style: 'width:auto;', title: title})), el;
for (i = 0; i < param.length; i++) {
p = param;
dialog.append(schnark_dialog.render(p, uid, param, resize));
}
var buttons = {};
buttons = ok;
buttons = abbrechen;
dialog.dialog({
buttons: buttons,
close: abbrechen,
width: 'auto', height: 'auto'
});
for (i = 0; i < param.length; i++) {
p = param;
if (p.type == 'toggle' && p.standard === false) $('#' + uid + 'dialog-' + p.name).click().change();
if (p.type == 'input' && p.focus === true) select(document.getElementById(uid + 'dialog-' + p.name));
if (p.type == 'select_other' && p.focus === true && typeof p.standard == 'string') select(document.getElementById(uid + 'dialog-' + p.name + '-other'));
if (p.enter) $('#' + uid + 'dialog-' + p.name).keydown(onEnter);
}
}
};
window.schnark_dialog = schnark_dialog; //legacy
libs.schnark_dialog = schnark_dialog;
$(document).trigger('loadWikiScript', );
/*
mw.loader.using('jquery.ui', function () {
schnark_dialog.show('Titel', [
{type: 'label', name: 'lab1', text: '<u>Label</u>'},
{type: 'toggle', name: 'tog1', text: '<u>Schalter</u>', list: , html: true, standard: false, enter: true},
{type: 'inputbox', name: 'inp1', text: 'Eingabe'},
{type: 'input', name: 'inp2', text: 'Eingabe', optional: true, focus: true, standard: 'Text', enter: true},
{type: 'select_other', name: 'sel1', text: 'Wahl', list: , ], standard: 'c', html: true, enter: true},
{type: 'select_multi', name: 'sel2', text: 'Aussuchen', list: , ], standard: , enter: true}
], function(a){var t='';for(var i in a) t+=i+': '+a+'\n';alert(t);}, function(a){alert(a);});
});
*/
})(jQuery, mw.libs);
//</nowiki>