| /* |
| * 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 += ' '; |
| innerHTML += '<input type="reset" class="submit" name="reset" value="Reset" />'; |
| innerHTML += ' '; |
| 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: "50%", width: "99%" } |
| }, [ text( propsValue ) ] ), |
| 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); |
| } |