mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-16 19:08:50 +01:00
179 lines
4.7 KiB
JavaScript
179 lines
4.7 KiB
JavaScript
|
/**
|
||
|
* eGroupWare eTemplate2 - JS Itempicker object
|
||
|
* derived from et2_link_entry widget @copyright 2011 Nathan Gray
|
||
|
*
|
||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||
|
* @package etemplate
|
||
|
* @subpackage api
|
||
|
* @link http://www.egroupware.org
|
||
|
* @author Christian Binder
|
||
|
* @author Nathan Gray
|
||
|
* @copyright 2012 Christian Binder
|
||
|
* @copyright 2011 Nathan Gray
|
||
|
* @version $Id: et2_widget_itempicker.js 38623 2012-03-26 23:27:53Z jaytraxx $
|
||
|
*/
|
||
|
|
||
|
"use strict";
|
||
|
|
||
|
/*egw:uses
|
||
|
jquery.jquery;
|
||
|
et2_core_inputWidget;
|
||
|
et2_core_valueWidget;
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Class which implements the "itempicker" XET-Tag
|
||
|
*/
|
||
|
var et2_itempicker = et2_inputWidget.extend({
|
||
|
|
||
|
attributes: {
|
||
|
"value": {
|
||
|
"type": "any",
|
||
|
"default": {}
|
||
|
},
|
||
|
"application": {
|
||
|
"name": "Application",
|
||
|
"type": "string",
|
||
|
"default": "",
|
||
|
"description": "Limit to the listed application or applications (comma seperated)"
|
||
|
},
|
||
|
"blur": {
|
||
|
"name": "Placeholder",
|
||
|
"type": "string",
|
||
|
"default": et2_no_init,
|
||
|
"description": "This text get displayed if an input-field is empty and does not have the input-focus (blur). It can be used to show a default value or a kind of help-text."
|
||
|
},
|
||
|
"query": {
|
||
|
"name": "Query callback",
|
||
|
"type": "any",
|
||
|
"default": false,
|
||
|
"description": "Callback before query to server. Must return true, or false to abort query."
|
||
|
},
|
||
|
"select": {
|
||
|
"name": "Select callback",
|
||
|
"type": "any",
|
||
|
"default": false,
|
||
|
"description": "Callback when user selects an option. Must return true, or false to abort normal action."
|
||
|
},
|
||
|
},
|
||
|
|
||
|
legacyOptions: ["application"],
|
||
|
search_timeout: 200, //ms after change to send query
|
||
|
minimum_characters: 2, // Don't send query unless there's at least this many chars
|
||
|
|
||
|
init: function() {
|
||
|
this._super.apply(this, arguments);
|
||
|
|
||
|
this.div = null;
|
||
|
this.left = null;
|
||
|
this.right = null;
|
||
|
this.app_select = null;
|
||
|
this.search = null;
|
||
|
this.itemlist = null;
|
||
|
|
||
|
this.createInputWidget();
|
||
|
},
|
||
|
|
||
|
createInputWidget: function() {
|
||
|
|
||
|
this.div = $j(document.createElement("div"));
|
||
|
this.left = $j(document.createElement("div"));
|
||
|
this.right = $j(document.createElement("div"));
|
||
|
this.app_select = $j(document.createElement("ul"));
|
||
|
this.search = $j(document.createElement("div"));
|
||
|
this.itemlist = $j(document.createElement("div"));
|
||
|
|
||
|
// Container elements
|
||
|
this.div.addClass("et2_itempicker");
|
||
|
this.left.addClass("et2_itempicker_left");
|
||
|
this.right.addClass("et2_itempicker_right");
|
||
|
|
||
|
// Application select
|
||
|
this.app_select.addClass("et2_itempicker_app_select");
|
||
|
var item_count = 0;
|
||
|
for(var key in this.options.select_options) {
|
||
|
var img_icon = this.egw().image(key + "/navbar");
|
||
|
if(img_icon === null) {
|
||
|
continue;
|
||
|
}
|
||
|
var img = $j(document.createElement("img"));
|
||
|
img.attr("src", img_icon);
|
||
|
var item = $j(document.createElement("li"))
|
||
|
item.attr("id", key)
|
||
|
.click(function() {
|
||
|
$j(".et2_itempicker_app_select li").removeClass("selected");
|
||
|
$j(this).addClass("selected");
|
||
|
})
|
||
|
.append(img);
|
||
|
if(item_count == 0) {
|
||
|
item.addClass("selected"); // select first item by default
|
||
|
}
|
||
|
this.app_select.append(item);
|
||
|
item_count++;
|
||
|
}
|
||
|
if(item_count == 0)
|
||
|
{
|
||
|
this.app_select.hide();
|
||
|
this.div.addClass("no_app");
|
||
|
}
|
||
|
|
||
|
// Search input field
|
||
|
this.search.addClass("et2_itempicker_search");
|
||
|
//this.search.append(this.createSearchWidget());
|
||
|
|
||
|
// Itemlist
|
||
|
this.itemlist.attr("id", "itempicker_itemlist");
|
||
|
this.itemlist.addClass("et2_itempicker_itemlist");
|
||
|
|
||
|
// Put everything together
|
||
|
this.left.append(this.app_select);
|
||
|
this.right.append(this.search);
|
||
|
this.right.append(this.itemlist);
|
||
|
this.div.append(this.right); // right before left to have a natural
|
||
|
this.div.append(this.left); // z-index for left div over right div
|
||
|
|
||
|
this.setDOMNode(this.div[0]);
|
||
|
},
|
||
|
|
||
|
getValue: function()
|
||
|
{
|
||
|
if(this.options.blur && this.input.val() == this.options.blur) return "";
|
||
|
return this._super.apply(this, arguments);
|
||
|
},
|
||
|
|
||
|
transformAttributes: function(_attrs) {
|
||
|
this._super.apply(this, arguments);
|
||
|
|
||
|
_attrs["select_options"] = {};
|
||
|
if(_attrs["application"])
|
||
|
{
|
||
|
var apps = et2_csvSplit(_attrs["application"], null, ",");
|
||
|
for(var i = 0; i < apps.length; i++)
|
||
|
{
|
||
|
_attrs["select_options"][apps[i]] = this.egw().lang(apps[i]);
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
_attrs["select_options"] = this.egw().link_app_list('query');
|
||
|
}
|
||
|
|
||
|
// Check whether the options entry was found, if not read it from the
|
||
|
// content array.
|
||
|
if (_attrs["select_options"] == null)
|
||
|
{
|
||
|
_attrs["select_options"] = this.getArrayMgr('content')
|
||
|
.getEntry("options-" + this.id)
|
||
|
}
|
||
|
|
||
|
// Default to an empty object
|
||
|
if (_attrs["select_options"] == null)
|
||
|
{
|
||
|
_attrs["select_options"] = {};
|
||
|
}
|
||
|
},
|
||
|
|
||
|
});
|
||
|
|
||
|
et2_register_widget(et2_itempicker, ["itempicker"]);
|