mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-08 06:01:22 +00:00
#268: Refactor field API.
This commit is contained in:
@@ -72,11 +72,11 @@
|
|||||||
Guacamole ${project.version}
|
Guacamole ${project.version}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<script type="text/javascript" src="scripts/session.js"></script>
|
||||||
|
<script type="text/javascript" src="scripts/guac-ui.js"></script>
|
||||||
<script type="text/javascript" src="scripts/admin.js"></script>
|
<script type="text/javascript" src="scripts/admin.js"></script>
|
||||||
<script type="text/javascript" src="scripts/service.js"></script>
|
<script type="text/javascript" src="scripts/service.js"></script>
|
||||||
<script type="text/javascript" src="scripts/session.js"></script>
|
|
||||||
<script type="text/javascript" src="scripts/history.js"></script>
|
<script type="text/javascript" src="scripts/history.js"></script>
|
||||||
<script type="text/javascript" src="scripts/guac-ui.js"></script>
|
|
||||||
|
|
||||||
<script type="text/javascript"><![CDATA[
|
<script type="text/javascript"><![CDATA[
|
||||||
|
|
||||||
|
@@ -29,10 +29,10 @@ var GuacAdmin = GuacAdmin || {};
|
|||||||
*
|
*
|
||||||
* @constructor
|
* @constructor
|
||||||
* @param {String} title A human-readable title for the field.
|
* @param {String} title A human-readable title for the field.
|
||||||
* @param {String} type The type of the input field.
|
* @param {String[]} available The allowed value(s), if any.
|
||||||
* @param {String} value The default value, if any.
|
* @param {String[]} selected The selected value(s), if any.
|
||||||
*/
|
*/
|
||||||
GuacAdmin.Field = function(title, type, value) {
|
GuacAdmin.Field = function(title, available, selected) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A human-readable title describing this field.
|
* A human-readable title describing this field.
|
||||||
@@ -40,18 +40,148 @@ GuacAdmin.Field = function(title, type, value) {
|
|||||||
this.title = title;
|
this.title = title;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of this field. Possible values are "text", "password", and
|
* All available values, if any.
|
||||||
* "checkbox".
|
|
||||||
*/
|
*/
|
||||||
this.type = type;
|
this.available = available || [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The default value of this field.
|
* All selected values, if any.
|
||||||
*/
|
*/
|
||||||
this.value = value;
|
this.selected = selected || [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the DOM Element representing this field.
|
||||||
|
*
|
||||||
|
* @return {Element} The DOM Element representing this field.
|
||||||
|
*/
|
||||||
|
this.getElement = function() {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the selected values of this field.
|
||||||
|
*
|
||||||
|
* @return {String[]} All selected values.
|
||||||
|
*/
|
||||||
|
this.getSelected = function() {};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Simple HTML input field.
|
||||||
|
*
|
||||||
|
* @augments GuacAdmin.Field
|
||||||
|
*/
|
||||||
|
GuacAdmin.Field._HTML_INPUT = function(type, title, available, selected) {
|
||||||
|
|
||||||
|
// Call parent constructor
|
||||||
|
GuacAdmin.Field.apply(this, [title, available, selected]);
|
||||||
|
|
||||||
|
// Create backing element
|
||||||
|
var element = GuacUI.createElement("input");
|
||||||
|
element.setAttribute("type", type);
|
||||||
|
if (selected && selected.length == 1)
|
||||||
|
element.setAttribute("value", selected[0]);
|
||||||
|
|
||||||
|
this.getSelected = function() {
|
||||||
|
return [element.value];
|
||||||
|
};
|
||||||
|
|
||||||
|
this.getElement = function() {
|
||||||
|
return element;
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
GuacAdmin.Field._HTML_INPUT.prototype = new GuacAdmin.Field();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A basic text field.
|
||||||
|
*
|
||||||
|
* @augments GuacAdmin.Field._HTML_INPUT
|
||||||
|
*/
|
||||||
|
GuacAdmin.Field.TEXT = function(title, available, selected) {
|
||||||
|
GuacAdmin.Field._HTML_INPUT.apply(this, ["text", title, available, selected]);
|
||||||
|
};
|
||||||
|
|
||||||
|
GuacAdmin.Field.TEXT.prototype = new GuacAdmin.Field._HTML_INPUT();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A basic password field.
|
||||||
|
*
|
||||||
|
* @augments GuacAdmin.Field._HTML_INPUT
|
||||||
|
*/
|
||||||
|
GuacAdmin.Field.PASSWORD = function(title, available, selected) {
|
||||||
|
GuacAdmin.Field._HTML_INPUT.apply(this, ["password", title, available, selected]);
|
||||||
|
};
|
||||||
|
|
||||||
|
GuacAdmin.Field.PASSWORD.prototype = new GuacAdmin.Field._HTML_INPUT();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Multi-select list where each element has a corresponding checkbox.
|
||||||
|
*
|
||||||
|
* @augments GuacAdmin.Field
|
||||||
|
*/
|
||||||
|
GuacAdmin.Field.LIST = function(title, available, selected) {
|
||||||
|
|
||||||
|
// Call parent constructor
|
||||||
|
GuacAdmin.Field.apply(this, [title, available, selected]);
|
||||||
|
|
||||||
|
var i;
|
||||||
|
|
||||||
|
// All selected connections
|
||||||
|
var is_selected = {};
|
||||||
|
for (i=0; i<selected.length; i++)
|
||||||
|
is_selected[selected[i]] = true;
|
||||||
|
|
||||||
|
// Add elements for all list items
|
||||||
|
var element = GuacUI.createElement("div", "list");
|
||||||
|
for (i=0; i<available.length; i++) {
|
||||||
|
|
||||||
|
// Get name
|
||||||
|
var name = available[i];
|
||||||
|
|
||||||
|
// Containing div
|
||||||
|
var list_item = GuacUI.createChildElement(element, "div", "connection");
|
||||||
|
|
||||||
|
// Checkbox
|
||||||
|
var checkbox = GuacUI.createChildElement(list_item, "input");
|
||||||
|
checkbox.setAttribute("type", "checkbox");
|
||||||
|
if (is_selected[name])
|
||||||
|
checkbox.checked = true;
|
||||||
|
|
||||||
|
// Update selected set when changed
|
||||||
|
checkbox.onclick =
|
||||||
|
checkbox.onchange = function() {
|
||||||
|
|
||||||
|
if (checkbox.checked)
|
||||||
|
is_selected[name] = true;
|
||||||
|
else if (is_selected[name])
|
||||||
|
delete is_selected[name];
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
// Connection name
|
||||||
|
var name_element = GuacUI.createChildElement(list_item, "span", "name");
|
||||||
|
name_element.textContent = name;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getElement = function() {
|
||||||
|
return element;
|
||||||
|
};
|
||||||
|
|
||||||
|
this.getSelected = function() {
|
||||||
|
return Object.keys(is_selected);
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
GuacAdmin.Field.LIST.prototype = new GuacAdmin.Field();
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An arbitrary button. Note that this object is not a component, and has
|
* An arbitrary button. Note that this object is not a component, and has
|
||||||
* no corresponding element. Other objects which use GuacAdmin.Button may
|
* no corresponding element. Other objects which use GuacAdmin.Button may
|
||||||
@@ -81,13 +211,22 @@ GuacAdmin.Button = function(title) {
|
|||||||
*/
|
*/
|
||||||
GuacAdmin.Form = function(fields, buttons) {
|
GuacAdmin.Form = function(fields, buttons) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reference to this form.
|
||||||
|
*/
|
||||||
|
var guac_form = this;
|
||||||
|
|
||||||
// Main div and fields
|
// Main div and fields
|
||||||
var element = GuacUI.createElement("div", "form");
|
var element = GuacUI.createElement("div", "form");
|
||||||
var field_table = GuacUI.createChildElement(element, "table", "fields");
|
var field_table = GuacUI.createChildElement(element, "table", "fields");
|
||||||
|
|
||||||
// Buttons
|
// Buttons
|
||||||
var button_div = GuacUI.createChildElement(element, "div", "object-buttons");
|
var button_div = GuacUI.createChildElement(element, "div", "object-buttons");
|
||||||
|
|
||||||
|
// Array of field value getters, corresponding to each field in the
|
||||||
|
// original field array.
|
||||||
|
var value_getters = [];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the DOM element representing this form.
|
* Returns the DOM element representing this form.
|
||||||
*/
|
*/
|
||||||
@@ -95,6 +234,14 @@ GuacAdmin.Form = function(fields, buttons) {
|
|||||||
return element;
|
return element;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Event called when a button is clicked.
|
||||||
|
*
|
||||||
|
* @event
|
||||||
|
* @param {String} title The title of the button clicked.
|
||||||
|
*/
|
||||||
|
this.onaction = null;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Add all fields
|
* Add all fields
|
||||||
*/
|
*/
|
||||||
@@ -113,25 +260,8 @@ GuacAdmin.Form = function(fields, buttons) {
|
|||||||
// Set title
|
// Set title
|
||||||
header.textContent = field.title;
|
header.textContent = field.title;
|
||||||
|
|
||||||
switch (field.type) {
|
// Add to cell
|
||||||
|
cell.appendChild(field.getElement());
|
||||||
// HTML types
|
|
||||||
case "text":
|
|
||||||
case "password":
|
|
||||||
case "checkbox":
|
|
||||||
var input = GuacUI.createChildElement(cell, "input");
|
|
||||||
|
|
||||||
// Set type and value
|
|
||||||
input.setAttribute("type", field.type);
|
|
||||||
if (field.value) input.setAttribute("value", field.value);
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Connection list
|
|
||||||
case "connections":
|
|
||||||
var connection_selector = GuacUI.createChildElement(cell, "div", "connection-list");
|
|
||||||
break;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -145,6 +275,29 @@ GuacAdmin.Form = function(fields, buttons) {
|
|||||||
var button = GuacUI.createChildElement(button_div, "button", name);
|
var button = GuacUI.createChildElement(button_div, "button", name);
|
||||||
button.textContent = buttons[i].title;
|
button.textContent = buttons[i].title;
|
||||||
|
|
||||||
|
// Set up event
|
||||||
|
(function() {
|
||||||
|
|
||||||
|
var title = buttons[i].title;
|
||||||
|
|
||||||
|
button.addEventListener("click", function(e) {
|
||||||
|
|
||||||
|
if (guac_form.onaction) {
|
||||||
|
|
||||||
|
// Build array of field values
|
||||||
|
var field_values = [];
|
||||||
|
for (var j=0; j<fields.length; j++)
|
||||||
|
field_values.push(fields[j].getSelected());
|
||||||
|
|
||||||
|
guac_form.onaction(title, field_values);
|
||||||
|
e.stopPropagation();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
})();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
@@ -227,9 +380,15 @@ GuacAdmin.UserManager = function() {
|
|||||||
var user_properties = new GuacAdmin.Form(
|
var user_properties = new GuacAdmin.Form(
|
||||||
|
|
||||||
/* Fields */
|
/* Fields */
|
||||||
[new GuacAdmin.Field("Password:", "password", "12341234"),
|
[new GuacAdmin.Field.PASSWORD("Password:", [],
|
||||||
new GuacAdmin.Field("Re-enter Password:", "password", "12341234"),
|
["f12a1930-7195-11e2-bcfd-0800200c9a66"]),
|
||||||
new GuacAdmin.Field("Connections:", "connections")],
|
|
||||||
|
new GuacAdmin.Field.PASSWORD("Re-enter Password:", [],
|
||||||
|
["f12a1930-7195-11e2-bcfd-0800200c9a66"]),
|
||||||
|
|
||||||
|
new GuacAdmin.Field.LIST("Connections:",
|
||||||
|
["A", "B", "C"],
|
||||||
|
["A"])],
|
||||||
|
|
||||||
/* Buttons */
|
/* Buttons */
|
||||||
[new GuacAdmin.Button("Save"),
|
[new GuacAdmin.Button("Save"),
|
||||||
@@ -238,6 +397,28 @@ GuacAdmin.UserManager = function() {
|
|||||||
|
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Set up events
|
||||||
|
user_properties.onaction = function(title, fields) {
|
||||||
|
|
||||||
|
// FIXME: STUB
|
||||||
|
if (title == "Delete") {
|
||||||
|
alert("Deletion not yet supported.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Save user
|
||||||
|
if (title == "Save") {
|
||||||
|
console.log(fields);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide
|
||||||
|
user_manager.selected = null;
|
||||||
|
item_element.removeChild(user_properties.getElement());
|
||||||
|
GuacUI.removeClass(element, "disabled");
|
||||||
|
GuacUI.removeClass(item_element, "selected");
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
// Display properties
|
// Display properties
|
||||||
item_element.appendChild(user_properties.getElement());
|
item_element.appendChild(user_properties.getElement());
|
||||||
|
|
||||||
|
@@ -261,7 +261,7 @@ div.section {
|
|||||||
-webkit-animation-duration: 0.125s;
|
-webkit-animation-duration: 0.125s;
|
||||||
}
|
}
|
||||||
|
|
||||||
.form .connection-list {
|
.form .list {
|
||||||
|
|
||||||
border: 1px solid rgba(0, 0, 0, 0.25);
|
border: 1px solid rgba(0, 0, 0, 0.25);
|
||||||
-moz-border-radius: 0.2em;
|
-moz-border-radius: 0.2em;
|
||||||
|
Reference in New Issue
Block a user