forked from extern/egroupware
Add context menu to link list, gives ability to change comment & delete
This commit is contained in:
parent
5eae11346d
commit
c34a61308d
@ -186,6 +186,32 @@ class etemplate_widget_link extends etemplate_widget
|
||||
$response->data(array_values($links));
|
||||
}
|
||||
|
||||
/**
|
||||
* Allow changing of comment after link is created
|
||||
*/
|
||||
public static function ajax_link_comment($link_id, $comment)
|
||||
{
|
||||
$result = false;
|
||||
if((int)$link_id > 0)
|
||||
{
|
||||
solink::update_remark((int)$link_id, $comment);
|
||||
$result = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
$link = egw_link::get_link((int)$link_id);
|
||||
if($link && $link['app'] == egw_link::VFS_APPNAME)
|
||||
{
|
||||
$file = egw_link::list_attached($link['app2'],$link['id2']);
|
||||
$file = $file[(int)$link_id];
|
||||
$path = egw_link::vfs_path($link['app2'],$link['id2'],$file['id']);
|
||||
$result = egw_vfs::proppatch($path, array(array('name' => 'comment', 'val' => $comment)));
|
||||
}
|
||||
}
|
||||
$response = egw_json_response::get();
|
||||
$response->data($result !== false);
|
||||
}
|
||||
|
||||
public function ajax_delete($value) {
|
||||
$response = egw_json_response::get();
|
||||
$response->data(egw_link::unlink($value));
|
||||
|
@ -17,6 +17,9 @@
|
||||
jquery.jquery-ui;
|
||||
et2_core_inputWidget;
|
||||
et2_core_valueWidget;
|
||||
|
||||
// Include menu system for list context menu
|
||||
egw_action.egw_menu_dhtmlx;
|
||||
*/
|
||||
|
||||
/**
|
||||
@ -1009,10 +1012,38 @@ var et2_link_list = et2_link_string.extend({
|
||||
.addClass("et2_link_list");
|
||||
if(this.options['class']) this.node.addClass(this.options['class']);
|
||||
this.setDOMNode(this.list[0]);
|
||||
|
||||
// Set up context menu
|
||||
var self = this;
|
||||
this.context = new egwMenu();
|
||||
this.context.addItem("comment", this.egw().lang("Comment"), "", function() {
|
||||
var link_id = self.context.data.link_id;
|
||||
var comment = prompt(self.egw().lang("Comment"));
|
||||
if(comment !== null)
|
||||
{
|
||||
var remark = jQuery('#link_'+link_id, self.list).children('.remark');
|
||||
remark.addClass("loading");
|
||||
var request = new egw_json_request("etemplate_widget_link::ajax_link_comment::etemplate",
|
||||
[link_id, comment],
|
||||
this
|
||||
);
|
||||
request.sendRequest(true, function() {
|
||||
if(remark)
|
||||
{
|
||||
remark.removeClass("loading").text(comment+"");
|
||||
}
|
||||
}, self);
|
||||
}
|
||||
});
|
||||
this.context.addItem("delete", this.egw().lang("Delete link"), this.egw().image("delete"), function(menu_item) {
|
||||
var link_id = self.context.data.link_id;
|
||||
self._delete_link(link_id);
|
||||
});
|
||||
},
|
||||
|
||||
_add_link: function(_link_data) {
|
||||
var row = $j(document.createElement("tr"))
|
||||
.attr("id", "link_"+_link_data.link_id)
|
||||
.appendTo(this.list)
|
||||
|
||||
// Icon
|
||||
@ -1063,11 +1094,22 @@ var et2_link_list = et2_link_string.extend({
|
||||
var delete_button = $j(document.createElement("td"))
|
||||
.appendTo(row)
|
||||
.addClass("delete icon")
|
||||
.bind( 'click', function(){
|
||||
delete_button.addClass("loading").removeClass("delete");
|
||||
new egw_json_request("etemplate.etemplate_widget_link.ajax_delete", [_link_data.link_id])
|
||||
.sendRequest(true, function(data) { if(data) {row.slideUp(row.remove);}});
|
||||
});
|
||||
.bind( 'click', function() {self._delete_link(_link_data.link_id);});
|
||||
|
||||
// Context menu
|
||||
row.bind("contextmenu", function(e) {
|
||||
self.context.data = _link_data;
|
||||
self.context.showAt(e.pageX, e.pageY, true);
|
||||
e.preventDefault();
|
||||
});
|
||||
},
|
||||
_delete_link: function(link_id) {
|
||||
var row = jQuery('#link_'+link_id, this.list);
|
||||
var delete_button = jQuery('.delete.icon',row);
|
||||
delete_button.addClass("loading").removeClass("delete");
|
||||
new egw_json_request("etemplate.etemplate_widget_link.ajax_delete", [link_id])
|
||||
.sendRequest(true, function(data) { if(data) {row.slideUp(row.remove);}});
|
||||
|
||||
}
|
||||
});
|
||||
et2_register_widget(et2_link_list, ["link-list"]);
|
||||
|
Loading…
Reference in New Issue
Block a user