blob: 8e46b6ce5d1e4d26fc9f0c4e501b3eefa9b0dae1 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function configure() {
var span = document.getElementById('configField');
if (!span) {
return;
}
var select = document.getElementById('configSelection_pid');
var pid = select.options[select.selectedIndex].value;
var parm = pluginRoot + '/' + pid;
sendRequest('POST', parm, displayConfigForm);
}
function create() {
var span = document.getElementById('configField');
if (!span) {
return;
}
var select = document.getElementById('configSelection_factory');
var pid = select.options[select.selectedIndex].value;
var parm = pluginRoot + '/' + pid + '?create=true';
sendRequest('POST', parm, displayConfigForm);
}
function displayConfigForm(obj) {
var span1 = document.getElementById('configField');
var span2 = document.getElementById('factoryField');
if (!span1 && !span2) {
return;
}
var parent = span1 ? span1.parentNode : span2.parentNode;
clearChildren( parent );
if (span1) {
parent.appendChild( span1 );
}
if (span2) {
parent.appendChild( span2 );
}
var trEl = tr( "content" );
var tdEl = createElement( "th", "content", { colSpan: "2" } );
addText( tdEl, obj.title );
trEl.appendChild( tdEl );
parent.appendChild( trEl );
trEl = tr( "content" );
parent.appendChild( trEl );
tdEl = td( "content" );
addText( tdEl, "\u00a0" );
trEl.appendChild( tdEl );
tdEl = td( "content" );
trEl.appendChild( tdEl );
var formEl = createElement( "form", null, {
method: "POST",
action: pluginRoot + "/" + obj.pid
});
tdEl.appendChild( formEl );
var inputEl = createElement( "input", null, {
type: "hidden",
name: "apply",
value: "true"
});
formEl.appendChild( inputEl );
// add the factory PID as a hidden form field if present
if (obj.factoryPid)
{
inputEl = createElement( "input", null, {
type: "hidden",
name: "factoryPid",
value: obj.factoryPid
});
formEl.appendChild( inputEl );
}
// add the PID filter as a hidden form field if present
if (obj.pidFilter)
{
inputEl = createElement( "input", null, {
type: "hidden",
name: "pidFilter",
value: obj.pidFilter
});
formEl.appendChild( inputEl );
}
inputEl = createElement( "input", null, {
type: "hidden",
name: "action",
value: "ajaxConfigManager"
});
formEl.appendChild( inputEl );
var tableEl = createElement( "table", null, {
border: 0,
width: "100%"
});
formEl.appendChild( tableEl );
var bodyEl = createElement( "tbody" );
tableEl.appendChild( bodyEl );
if (obj.description)
{
trEl = tr( "content" );
tdEl = td( "content", { colSpan: "2" } );
addText( tdEl, obj.description );
trEl.appendChild( tdEl );
bodyEl.appendChild( trEl );
}
if (obj.propertylist == 'properties')
{
printTextArea(bodyEl, obj.properties);
}
else
{
printForm(bodyEl, obj);
}
trEl = tr( "content" );
bodyEl.appendChild( trEl );
tdEl = td( "content" );
addText( tdEl, "\u00a0" );
trEl.appendChild( tdEl );
tdEl = td( "content" );
trEl.appendChild( tdEl );
// define this TD as innerHTML otherwise the onClick event handler
// of the Delete button is not accepted by IE6 (!)...
var innerHTML = '<input type="submit" class="submit" name="submit" value="Save" />';
innerHTML += '&nbsp;&nbsp;&nbsp;';
innerHTML += '<input type="reset" class="submit" name="reset" value="Reset" />';
innerHTML += '&nbsp;&nbsp;&nbsp;';
innerHTML += '<input type="submit" class="submit" name="delete" value="Delete" onClick="return confirmDelete(\'' + obj.pid + '\', \'' + obj.bundleLocation + '\');"/>';
tdEl.innerHTML = innerHTML;
printConfigurationInfo(parent, obj);
}
function printTextArea(/* Element */ parent, props )
{
var propsValue = "";
for (var key in props)
{
propsValue += key + ' = ' + props[key] + '\r\n';
}
parent.appendChild(
tr( "content", null, [
td( "content aligntop", null, [
text( "Properties" )
]),
td( "content", { style: { width: "99%" } }, [
createElement( "textarea", null, {
name: "properties",
style: { height: "20em", width: "99%" }
}, [ text( propsValue ) ] ),
createElement( "br" ),
text( "Enter Name-Value pairs of configuration properties" )
])
])
);
}
function printForm( /* Element */ parent, obj ) {
var propList;
for (var idx in obj.propertylist)
{
var prop = obj.propertylist[idx];
var attr = obj[prop];
var trEl = tr( "content", null, [
td( "content aligntop", null, [ text( attr.name ) ] )
]);
parent.appendChild( trEl );
var tdEl = td( "content", { style: { width: "99%" } } );
trEl.appendChild( tdEl );
if (attr.value != undefined)
{
// check is required to also handle empty strings, 0 and false
tdEl.appendChild( createInput( prop, attr.value, attr.type, '99%' ) );
tdEl.appendChild( createElement( "br" ) );
}
else if (typeof(attr.type) == 'object')
{
// assume attr.values and multiselect
createMultiSelect( tdEl, prop, attr.values, attr.type, '99%' );
tdEl.appendChild( createElement( "br" ) );
}
else if (attr.values.length == 0)
{
tdEl.appendChild( createSpan( prop, "", attr.type ) );
}
else
{
for (var i=0;i<attr.values.length;i++)
{
tdEl.appendChild( createSpan( prop, attr.values[i], attr.type ) );
}
}
if (attr.description)
{
addText( tdEl, attr.description );
}
if (propList) {
propList += ',' + prop;
} else {
propList = prop;
}
}
parent.appendChild( createElement( "input", null, {
type: "hidden",
name: "propertylist",
value: propList
})
);
// FIX for IE6 and above: checkbox can only be checked after it is in the DOM
$(".checked_box").attr("checked", true).removeClass("checked_box");
}
function printConfigurationInfo( /* Element */ parent, obj )
{
parent.appendChild( tr( "content", null, [
createElement( "th", "content", { colSpan: "2" }, [
text( "Configuration Information" )
])
])
);
parent.appendChild( tr( "content", null, [
td( "content", null, [
text( "Persistent Identity (PID)" )
]),
td( "content", null, [
text( obj.pid )
])
])
);
if (obj.factoryPid)
{
parent.appendChild( tr( "content", null, [
td( "content", null, [
text( "Factory Peristent Identifier (Factory PID)" )
]),
td( "content", null, [
text( obj.factoryPid )
])
])
);
}
var binding = obj.bundleLocation;
if (!binding)
{
binding = "Unbound or new configuration";
}
parent.appendChild( tr( "content", null, [
td( "content", null, [
text( "Configuration Binding" )
]),
td( "content", null, [
text( binding )
])
])
);
if (obj.bundleLocation)
{
var form = createElement( "form", null, {
method: "POST",
action: pluginRoot + "/" + obj.pid
});
// define this form contents as innerHTML otherwise the onClick
// event handler of the Unbind button is not accepted by IE6 (!)...
var formInner = '<input type="hidden" name="unbind" value="true"/>';
formInner += '<input type="submit" name="submit" value="Unbind" class="submit" title="Unbind Configuration from Bundle" onClick="return confirmUnbind(\'' + obj.pid + '\', \'' + obj.bundleLocation + '\');"/>';
form.innerHTML = formInner;
parent.appendChild( tr( "content", null, [
td( "content", null, [
text( " " )
]),
td( "content", null, [ form ] )
])
);
}
}
var spanCounter = 0;
/* Element */ function createSpan(prop, value, type) {
spanCounter++;
var newId = prop + spanCounter;
var addButton = createElement("input", "input",
{ type: "button",
style: {width : "5%"},
value: "+"
}
);
$(addButton).click(function() {addValue(prop, newId)});
var remButton = createElement("input", "input",
{ type: "button",
style: {width : "5%"},
value: "-"
}
);
$(remButton).click(function() {removeValue(newId)});
var spanEl = createElement( "span", null, { id: newId }, [
createInput( prop, value, type, '89%' ), addButton, remButton,
createElement("br")
]);
return spanEl;
}
/* Element */ function createInput(prop, value, type, width) {
if (type == 11) { // AttributeDefinition.BOOLEAN
var inputEl = createElement( "input", "input", {
type: "checkbox",
name: prop,
value: "true"
});
if (value && typeof(value) != "boolean")
{
value = value.toString().toLowerCase() == "true";
}
if (value)
{
$(inputEl).addClass("checked_box");
}
var hiddenEl = createElement( "input", "input", {
type: "hidden",
name: prop,
value: "false"
});
var divEl = createElement("div");
divEl.appendChild(inputEl);
divEl.appendChild(hiddenEl);
return divEl;
} else if (typeof(type) == "object") { // predefined values
var selectEl = createElement( "select", "select", {
name: prop,
style: { width: width }
});
var labels = type.labels;
var values = type.values;
for (var idx in labels) {
var optionEl = createElement( "option", null, {
value: values[idx]
}, [ text( labels[idx] ) ]);
if (value == values[idx])
{
optionEl.setAttribute( "selected", true );
}
selectEl.appendChild( optionEl );
}
return selectEl;
} else { // Simple
return createElement( "input", "input", {
type: "text",
name: prop,
value: value,
style: { width: width }
});
}
}
function createMultiSelect(/* Element */ parent, prop, values, options, width) {
// convert value list into 'set'
var valueSet = new Object();
for (var idx in values) {
valueSet[ values[idx] ] = true;
}
var labels = options.labels;
var values = options.values;
for (var idx in labels) {
var inputEl = createElement( "input", null, {
type: "checkbox",
name: prop,
value: values[idx]
});
if (valueSet[ values[idx] ])
{
inputEl.setAttribute( "checked", true );
}
var labelEl = createElement( "label", "multiselect" );
labelEl.appendChild( inputEl );
addText( labelEl, labels[idx] );
parent.appendChild( labelEl );
}
}
function addValue(prop, vidx)
{
var span = document.getElementById(vidx);
if (!span)
{
return;
}
var newSpan = createSpan(prop, '');
span.parentNode.insertBefore(newSpan, span.nextSibling);
// FIX for IE6 and above: checkbox can only be checked after it is in the DOM
$(".checked_box").attr("checked", true).removeClass("checked_box");
}
function removeValue(vidx)
{
var span = document.getElementById(vidx);
if (!span)
{
return;
}
span.parentNode.removeChild(span);
}
function configConfirm(/* String */ message, /* String */ title, /* String */ location)
{
var message = "Are you sure to delete this configuration ?";
if (title) {
message += "\r\nConfiguration: " + title;
}
if (location) {
message += "\r\nBundle: " + location;
}
return confirm(message);
}
function confirmDelete(/* String */ title, /* String */ location)
{
return configConfirm("Are you sure to unbind this configuration ?", title, location);
}
function confirmUnbind(/* String */ title, /* String */ location)
{
return configConfirm("Are you sure to unbind this configuration ?", title, location);
}