Convert vfsSelectUI to TS

This commit is contained in:
Hadi Nategh 2020-02-26 12:19:17 +01:00
parent de426e1232
commit e48000d149
5 changed files with 669 additions and 343 deletions

View File

@ -606,7 +606,7 @@ export class et2_dialog extends et2_widget {
* @param {integer|array} _buttons One of the BUTTONS_ constants defining the set of buttons at the bottom of the box * @param {integer|array} _buttons One of the BUTTONS_ constants defining the set of buttons at the bottom of the box
* @param {string|egw} _egw_or_appname egw object with already laoded translations or application name to load translations for * @param {string|egw} _egw_or_appname egw object with already laoded translations or application name to load translations for
*/ */
static show_prompt(_callback, _message, _title, _value, _buttons, _egw_or_appname) { static show_prompt(_callback, _message, _title?, _value?, _buttons?, _egw_or_appname?) {
var callback = _callback; var callback = _callback;
// Just pass them along, widget handles defaults & missing // Just pass them along, widget handles defaults & missing
return et2_createWidget("dialog", { return et2_createWidget("dialog", {

View File

@ -213,6 +213,7 @@ var et2_vfs = /** @class */ (function (_super) {
et2_vfs.DIR_MIME_TYPE = 'httpd/unix-directory'; et2_vfs.DIR_MIME_TYPE = 'httpd/unix-directory';
return et2_vfs; return et2_vfs;
}(et2_core_valueWidget_1.et2_valueWidget)); }(et2_core_valueWidget_1.et2_valueWidget));
exports.et2_vfs = et2_vfs;
et2_core_widget_1.et2_register_widget(et2_vfs, ["vfs"]); et2_core_widget_1.et2_register_widget(et2_vfs, ["vfs"]);
/** /**
* vfs-name * vfs-name
@ -378,6 +379,7 @@ var et2_vfsPath = /** @class */ (function (_super) {
}; };
return et2_vfsPath; return et2_vfsPath;
}(et2_vfsName)); }(et2_vfsName));
exports.et2_vfsPath = et2_vfsPath;
et2_core_widget_1.et2_register_widget(et2_vfsPath, ["vfs-path"]); et2_core_widget_1.et2_register_widget(et2_vfsPath, ["vfs-path"]);
/** /**
* vfs-name * vfs-name
@ -1321,6 +1323,7 @@ var et2_vfsSelect = /** @class */ (function (_super) {
}; };
return et2_vfsSelect; return et2_vfsSelect;
}(et2_core_inputWidget_1.et2_inputWidget)); }(et2_core_inputWidget_1.et2_inputWidget));
exports.et2_vfsSelect = et2_vfsSelect;
; ;
et2_core_widget_1.et2_register_widget(et2_vfsSelect, ["vfs-select"]); et2_core_widget_1.et2_register_widget(et2_vfsSelect, ["vfs-select"]);
//# sourceMappingURL=et2_widget_vfs.js.map //# sourceMappingURL=et2_widget_vfs.js.map

View File

@ -35,7 +35,7 @@ import {et2_inputWidget} from "./et2_core_inputWidget";
* *
* @augments et2_valueWidget * @augments et2_valueWidget
*/ */
class et2_vfs extends et2_valueWidget implements et2_IDetachedDOM export class et2_vfs extends et2_valueWidget implements et2_IDetachedDOM
{ {
static readonly _attributes : any = { static readonly _attributes : any = {
"value": { "value": {
@ -284,7 +284,7 @@ et2_register_widget(et2_vfsName, ["vfs-name"]);
* *
* @augments et2_textbox * @augments et2_textbox
*/ */
class et2_vfsPath extends et2_vfsName export class et2_vfsPath extends et2_vfsName
{ {
static readonly _attributes : any = { static readonly _attributes : any = {
noicon: { noicon: {
@ -1128,7 +1128,7 @@ class et2_vfsUpload extends et2_file
et2_register_widget(et2_vfsUpload, ["vfs-upload"]); et2_register_widget(et2_vfsUpload, ["vfs-upload"]);
class et2_vfsSelect extends et2_inputWidget export class et2_vfsSelect extends et2_inputWidget
{ {
// Allowed mode options // Allowed mode options
modes : string[] = ['open','open-multiple','saveas','select-dir']; modes : string[] = ['open','open-multiple','saveas','select-dir'];
@ -1244,7 +1244,7 @@ class et2_vfsSelect extends et2_inputWidget
this.setDOMNode(this.button[0]); this.setDOMNode(this.button[0]);
} }
private _content(_content, _callback) _content(_content, _callback)
{ {
egw(window).loading_prompt('vfs-select', true, '', 'body'); egw(window).loading_prompt('vfs-select', true, '', 'body');
let self = this; let self = this;

View File

@ -1,3 +1,4 @@
"use strict";
/** /**
* EGroupware - VFS SELECT Widget UI * EGroupware - VFS SELECT Widget UI
* *
@ -8,42 +9,52 @@
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @version $Id$ * @version $Id$
*/ */
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
/*egw:uses
/api/js/jsapi/egw_app.js
*/
var egw_app_1 = require("../jsapi/egw_app");
require("../jsapi/egw_global");
require("../etemplate/et2_types");
/** /**
* UI for VFS Select widget * UI for VFS Select widget
* *
* @augments AppJS
*/ */
app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend( var vfsSelectUI = /** @class */ (function (_super) {
{ __extends(vfsSelectUI, _super);
appname: 'filemanager',
dirContent: {},
vfsSelectWidget: {},
path_widget: {},
/** /**
* Constructor * Constructor
* *
* @memberOf app.filemanager
*/ */
init: function() function vfsSelectUI() {
{ var _this =
// call parent // call parent
this._super.apply(this, arguments); _super.call(this) || this;
_this.egw.langRequireApp(_this.egw.window, 'filemanager');
this.egw.langRequireApp(this.egw.window, 'filemanager'); return _this;
}, }
/** /**
* Destructor * Destructor
*/ */
destroy: function() vfsSelectUI.prototype.destroy = function (_app) {
{
delete this.path_widget; delete this.path_widget;
delete this.vfsSelectWidget; delete this.vfsSelectWidget;
// call parent // call parent
this._super.apply(this, arguments); _super.prototype.destroy.call(this, _app);
}, };
/** /**
* This function is called when the etemplate2 object is loaded * This function is called when the etemplate2 object is loaded
* and ready. If you must store a reference to the et2 object, * and ready. If you must store a reference to the et2 object,
@ -52,66 +63,52 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
* @param et2 etemplate2 Newly ready object * @param et2 etemplate2 Newly ready object
* @param {string} name template name * @param {string} name template name
*/ */
et2_ready: function(et2,name) vfsSelectUI.prototype.et2_ready = function (et2, name) {
{
this.path_widget = this.et2.getWidgetById('path'); this.path_widget = this.et2.getWidgetById('path');
this.dirContent = this.et2.getArrayMgr('content').data.dir; this.dirContent = this.et2.getArrayMgr('content').data.dir;
}, };
/** /**
* Get directory of a path * Get directory of a path
* *
* @param {string} _path * @param {string} _path
* @returns string * @returns string
*/ */
dirname: function(_path) vfsSelectUI.prototype.dirname = function (_path) {
{
var parts = _path.split('/'); var parts = _path.split('/');
parts.pop(); parts.pop();
return parts.join('/') || '/'; return parts.join('/') || '/';
}, };
/** /**
* Get name of a path * Get name of a path
* *
* @param {string} _path * @param {string} _path
* @returns string * @returns string
*/ */
basename: function(_path) vfsSelectUI.prototype.basename = function (_path) {
{
return _path.split('/').pop(); return _path.split('/').pop();
}, };
/** /**
* Get current working directory * Get current working directory
* *
* @return string * @return string
*/ */
get_path: function() vfsSelectUI.prototype.get_path = function () {
{
return this.path_widget.get_value(); return this.path_widget.get_value();
}, };
/** /**
* Send names of uploaded files (again) to server, * Send names of uploaded files (again) to server,
* to process them: either copy to vfs or ask overwrite/rename * to process them: either copy to vfs or ask overwrite/rename
* *
* @param {event} _event * @param {event} _event
*/ */
storeFile: function(_event) vfsSelectUI.prototype.storeFile = function (_event) {
{
var path = this.get_path(); var path = this.get_path();
if (!jQuery.isEmptyObject(_event.data.getValue())) {
if (!jQuery.isEmptyObject(_event.data.getValue()))
{
var widget = _event.data; var widget = _event.data;
egw(window).json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_vfsSelect_storeFile', [widget.getValue(), path], egw(window).json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_vfsSelect_storeFile', [widget.getValue(), path], this._storeFile_callback, this, true, this).sendRequest(true);
this._storeFile_callback, this, true, this
).sendRequest(true);
widget.set_value(''); widget.set_value('');
} }
}, };
/** /**
* Callback for server response to storeFile request: * Callback for server response to storeFile request:
* - display message and refresh list * - display message and refresh list
@ -119,15 +116,12 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
* *
* @param {object} _data values for attributes msg, files, ... * @param {object} _data values for attributes msg, files, ...
*/ */
_storeFile_callback: function(_data) vfsSelectUI.prototype._storeFile_callback = function (_data) {
{ if (_data.msg || _data.uploaded)
if (_data.msg || _data.uploaded) egw(window).message(_data.msg); egw(window).message(_data.msg);
var that = this; var that = this;
for(var file in _data.uploaded) for (var file in _data.uploaded) {
{ if (_data.uploaded[file].confirm && !_data.uploaded[file].confirmed) {
if (_data.uploaded[file].confirm && !_data.uploaded[file].confirmed)
{
var buttons = [ var buttons = [
{ text: this.egw.lang("Yes"), id: "overwrite", class: "ui-priority-primary", "default": true, image: 'check' }, { text: this.egw.lang("Yes"), id: "overwrite", class: "ui-priority-primary", "default": true, image: 'check' },
{ text: this.egw.lang("Rename"), id: "rename", image: 'edit' }, { text: this.egw.lang("Rename"), id: "rename", image: 'edit' },
@ -138,8 +132,7 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
var dialog = et2_dialog.show_prompt(function (_button_id, _value) { var dialog = et2_dialog.show_prompt(function (_button_id, _value) {
var uploaded = {}; var uploaded = {};
uploaded[this.my_data.file] = this.my_data.data; uploaded[this.my_data.file] = this.my_data.data;
switch (_button_id) switch (_button_id) {
{
case "overwrite": case "overwrite":
uploaded[this.my_data.file].confirmed = true; uploaded[this.my_data.file].confirmed = true;
// fall through // fall through
@ -147,9 +140,7 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
uploaded[this.my_data.file].name = _value; uploaded[this.my_data.file].name = _value;
delete uploaded[this.my_data.file].confirm; delete uploaded[this.my_data.file].confirm;
// send overwrite-confirmation and/or rename request to server // send overwrite-confirmation and/or rename request to server
egw.json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_vfsSelect_storeFile', [uploaded, this.my_data.path], egw.json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_vfsSelect_storeFile', [uploaded, this.my_data.path], that._storeFile_callback, that, true, that).sendRequest();
that._storeFile_callback, that, true, that
).sendRequest();
return; return;
case "cancel": case "cancel":
// Remove that file from every file widget... // Remove that file from every file widget...
@ -157,12 +148,9 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
_widget.remove_file(this.my_data.data.name); _widget.remove_file(this.my_data.data.name);
}, this, et2_file); }, this, et2_file);
} }
}, }, _data.uploaded[file].confirm === "is_dir" ?
_data.uploaded[file].confirm === "is_dir" ?
this.egw.lang("There's already a directory with that name!") : this.egw.lang("There's already a directory with that name!") :
this.egw.lang('Do you want to overwrite existing file %1 in directory %2?', _data.uploaded[file].name, _data.path), this.egw.lang('Do you want to overwrite existing file %1 in directory %2?', _data.uploaded[file].name, _data.path), this.egw.lang('File %1 already exists', _data.uploaded[file].name), _data.uploaded[file].name, buttons, file);
this.egw.lang('File %1 already exists', _data.uploaded[file].name),
_data.uploaded[file].name, buttons, file);
// setting required data for callback in as my_data // setting required data for callback in as my_data
dialog.my_data = { dialog.my_data = {
file: file, file: file,
@ -170,124 +158,111 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
data: _data.uploaded[file], data: _data.uploaded[file],
}; };
} }
else else {
{
this.submit(); this.submit();
} }
} }
}, };
/** /**
* Prompt user for directory to create * Prompt user for directory to create
* *
* @param {egwAction|undefined|jQuery.Event} action Action, event or undefined if called directly * @param {egwAction|undefined|jQuery.Event} action Action, event or undefined if called directly
* @param {egwActionObject[] | undefined} selected Selected row, or undefined if called directly * @param {egwActionObject[] | undefined} selected Selected row, or undefined if called directly
*/ */
createdir: function(action, selected) vfsSelectUI.prototype.createdir = function (action, selected) {
{
var self = this; var self = this;
et2_dialog.show_prompt(function (button, dir) { et2_dialog.show_prompt(function (button, dir) {
if (button && dir) if (button && dir) {
{ var path_1 = self.get_path();
var path = self.get_path(); self.egw.json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_create_dir', [dir, path_1], function (msg) {
self.egw.json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_create_dir', [dir, path], function(msg){
self.egw.message(msg); self.egw.message(msg);
self.change_dir((path == '/' ? '' : path)+'/'+ dir); self.change_dir((path_1 == '/' ? '' : path_1) + '/' + dir);
}).sendRequest(false); }).sendRequest(false);
} }
}, this.egw.lang('New directory'), this.egw.lang('Create directory')); }, this.egw.lang('New directory'), this.egw.lang('Create directory'));
}, };
/** /**
* Change directory * Change directory
* *
* @param {string} _dir directory to change to incl. '..' for one up * @param {string} _dir directory to change to incl. '..' for one up
* @param {et2_widget} widget
*/ */
change_dir: function(_dir, widget) vfsSelectUI.prototype.change_dir = function (_dir) {
{ if (_dir == '..') {
switch (_dir)
{
case '..':
_dir = this.dirname(this.get_path()); _dir = this.dirname(this.get_path());
break;
} }
this.path_widget.set_value(_dir); this.path_widget.set_value(_dir);
}, };
/** /**
* Row or filename in select-file dialog clicked * Row or filename in select-file dialog clicked
* *
* @param {jQuery.event} event * @param {jQuery.event} event
* @param {et2_widget} widget * @param {et2_widget} widget
*/ */
select_clicked: function(event, widget) vfsSelectUI.prototype.select_clicked = function (event, widget) {
{ if (!widget || typeof widget.value != 'object') {
if (!widget || typeof widget.value != 'object')
{
} }
else if (widget.value.is_dir) // true for "httpd/unix-directory" and "egw/*" else if (widget.value.is_dir) // true for "httpd/unix-directory" and "egw/*"
{ {
var path = null; var path_2 = null;
// Cannot do this, there are multiple widgets named path // Cannot do this, there are multiple widgets named path
// widget.getRoot().getWidgetById("path"); // widget.getRoot().getWidgetById("path");
widget.getRoot().iterateOver(function (widget) { widget.getRoot().iterateOver(function (widget) {
if(widget.id == "path") path = widget; if (widget.id == "path")
path_2 = widget;
}, null, et2_textbox); }, null, et2_textbox);
if(path) if (path_2) {
{ path_2.set_value(widget.value.path);
path.set_value(widget.value.path);
} }
} }
else if (this.et2 && this.et2.getArrayMgr('content').getEntry('mode') != 'open-multiple') else if (this.et2 && this.et2.getArrayMgr('content').getEntry('mode') != 'open-multiple') {
{
var editfield = this.et2.getWidgetById('name'); var editfield = this.et2.getWidgetById('name');
if(editfield) if (editfield) {
{
editfield.set_value(widget.value.name); editfield.set_value(widget.value.name);
} }
} }
else else {
{ var file_1 = widget.value.name;
var file = widget.value.name; widget.getParent().iterateOver(function (widget) {
widget.getParent().iterateOver(function(widget) if (widget.options.selected_value == file_1) {
{ widget.set_value(widget.get_value() == file_1 ? widget.options.unselected_value : file_1);
if(widget.options.selected_value == file)
{
widget.set_value(widget.get_value() == file ? widget.options.unselected_value : file);
} }
}, null, et2_checkbox); }, null, et2_checkbox);
} }
// Stop event or it will toggle back off // Stop event or it will toggle back off
event.preventDefault(); event.preventDefault();
event.stopPropagation(); event.stopPropagation();
return false; return false;
}, };
/** /**
* Handles action and offer it to the submit * Handles action and offer it to the submit
* *
* @param {string} action action name * @param {string} action action name
* @param {object} widget widget which action was called from * @param {object} widget widget which action was called from
*/ */
do_action: function (action, widget) vfsSelectUI.prototype.do_action = function (action, widget) {
{ if (!action)
if (!action) return; return;
var field = '', value = ''; var field = '', value = '';
switch (action) switch (action) {
{ case 'path':
case 'path': field = 'path'; value = widget.getValue(); break; field = 'path';
case 'home': field = 'action'; value = 'home'; break; value = widget.getValue();
case 'app': field = 'app'; value = widget.getValue(); break; break;
case 'mime': field = 'mime'; value = widget.getValue(); break; case 'home':
field = 'action';
value = 'home';
break;
case 'app':
field = 'app';
value = widget.getValue();
break;
case 'mime':
field = 'mime';
value = widget.getValue();
break;
} }
this.submit(field, value); this.submit(field, value);
}, };
/** /**
* Sumbits content value after modification * Sumbits content value after modification
* *
@ -295,58 +270,50 @@ app.classes.vfsSelectUI = (function(){ "use strict"; return AppJS.extend(
* @param {any} _val value of field * @param {any} _val value of field
* @param {function} _callback * @param {function} _callback
*/ */
submit: function(_field, _val, _callback) vfsSelectUI.prototype.submit = function (_field, _val, _callback) {
{
var arrMgrs = this.et2.getArrayMgrs(); var arrMgrs = this.et2.getArrayMgrs();
if (_field) if (_field) {
{
arrMgrs.content.data[_field] = _val; arrMgrs.content.data[_field] = _val;
jQuery.extend(arrMgrs.content.data, arrMgrs.modifications.data); jQuery.extend(arrMgrs.content.data, arrMgrs.modifications.data);
this.et2.setArrayMgrs(arrMgrs); this.et2.setArrayMgrs(arrMgrs);
} }
// preserve value of the name // preserve value of the name
if (arrMgrs && this.et2.getWidgetById('name')) if (arrMgrs && this.et2.getWidgetById('name')) {
{
arrMgrs.content.data['name'] = this.et2.getWidgetById('name').get_value(); arrMgrs.content.data['name'] = this.et2.getWidgetById('name').get_value();
} }
this.vfsSelectWidget._content(arrMgrs.content.data, _callback); this.vfsSelectWidget._content(arrMgrs.content.data, _callback);
}, };
/** /**
* search through dir content and set its content base on searched query * search through dir content and set its content base on searched query
* @returns * @returns
*/ */
search: function(_widget) vfsSelectUI.prototype.search = function (_widget) {
{
var dir = this.et2.getWidgetById('dir'); var dir = this.et2.getWidgetById('dir');
var query = _widget.get_value(); var query = _widget.get_value();
if (query == "") if (query == "") {
{
dir.set_value({ content: this.dirContent }); dir.set_value({ content: this.dirContent });
return; return;
} }
var self = this; var self = this;
var searchQuery = function (_query) var searchQuery = function (_query) {
{
var result = {}; var result = {};
var reg = RegExp(_query, 'ig'); var reg = RegExp(_query, 'ig');
var key = 0; var key = 0;
for (var i in self.dirContent) for (var i in self.dirContent) {
{ if (typeof self.dirContent[i]['name'] != 'undefined' && self.dirContent[i]['name'].match(reg)) {
if (typeof self.dirContent[i]['name'] != 'undefined' && self.dirContent[i]['name'].match(reg))
{
result[key] = self.dirContent[i]; result[key] = self.dirContent[i];
key++; key++;
} }
else if (typeof self.dirContent[i]['name'] == 'undefined' && isNaN(i)) else if (typeof self.dirContent[i]['name'] == 'undefined' && isNaN(i)) {
{
result[i] = self.dirContent[i]; result[i] = self.dirContent[i];
} }
} }
return result; return result;
}; };
dir.set_value({ content: searchQuery(query) }); dir.set_value({ content: searchQuery(query) });
} };
});}).call(this); return vfsSelectUI;
}(egw_app_1.EgwApp));
exports.vfsSelectUI = vfsSelectUI;
app.classes.vfsSelectUI = vfsSelectUI;
//# sourceMappingURL=vfsSelectUI.js.map

View File

@ -0,0 +1,356 @@
/**
* EGroupware - VFS SELECT Widget UI
*
* @link http://www.egroupware.org
* @package et2_vfsSelect
* @author Hadi Nategh <hn@egroupware.org>
* @copyright (c) 2013-2017 by Hadi Nategh <hn@egroupware.org>
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @version $Id$
*/
/*egw:uses
/api/js/jsapi/egw_app.js
*/
import {EgwApp} from "../jsapi/egw_app";
import {et2_vfs, et2_vfsPath, et2_vfsSelect} from "./et2_widget_vfs";
import '../jsapi/egw_global';
import '../etemplate/et2_types';
/**
* UI for VFS Select widget
*
*/
export class vfsSelectUI extends EgwApp
{
readonly appname: 'filemanager';
private dirContent: {};
private vfsSelectWidget : et2_vfsSelect;
private path_widget: et2_vfsPath;
/**
* Constructor
*
*/
constructor()
{
// call parent
super();
this.egw.langRequireApp(this.egw.window, 'filemanager');
}
/**
* Destructor
*/
destroy(_app)
{
delete this.path_widget;
delete this.vfsSelectWidget;
// call parent
super.destroy(_app);
}
/**
* This function is called when the etemplate2 object is loaded
* and ready. If you must store a reference to the et2 object,
* make sure to clean it up in destroy().
*
* @param et2 etemplate2 Newly ready object
* @param {string} name template name
*/
et2_ready(et2,name)
{
this.path_widget = this.et2.getWidgetById('path');
this.dirContent = this.et2.getArrayMgr('content').data.dir;
}
/**
* Get directory of a path
*
* @param {string} _path
* @returns string
*/
dirname(_path)
{
let parts = _path.split('/');
parts.pop();
return parts.join('/') || '/';
}
/**
* Get name of a path
*
* @param {string} _path
* @returns string
*/
basename(_path)
{
return _path.split('/').pop();
}
/**
* Get current working directory
*
* @return string
*/
get_path()
{
return this.path_widget.get_value();
}
/**
* Send names of uploaded files (again) to server,
* to process them: either copy to vfs or ask overwrite/rename
*
* @param {event} _event
*/
storeFile(_event)
{
let path = this.get_path();
if (!jQuery.isEmptyObject(_event.data.getValue()))
{
let widget = _event.data;
egw(window).json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_vfsSelect_storeFile', [widget.getValue(), path],
this._storeFile_callback, this, true, this
).sendRequest(true);
widget.set_value('');
}
}
/**
* Callback for server response to storeFile request:
* - display message and refresh list
* - ask use to confirm overwritting existing files or rename upload
*
* @param {object} _data values for attributes msg, files, ...
*/
_storeFile_callback(_data : {msg : string, uploaded : any[], path : string})
{
if (_data.msg || _data.uploaded) egw(window).message(_data.msg);
let that = this;
for(let file in _data.uploaded)
{
if (_data.uploaded[file].confirm && !_data.uploaded[file].confirmed)
{
let buttons = [
{text: this.egw.lang("Yes"), id: "overwrite", class: "ui-priority-primary", "default": true, image: 'check'},
{text: this.egw.lang("Rename"), id:"rename", image: 'edit'},
{text: this.egw.lang("Cancel"), id:"cancel"}
];
if (_data.uploaded[file].confirm === "is_dir")
buttons.shift();
let dialog = et2_dialog.show_prompt(function(_button_id, _value) {
let uploaded = {};
uploaded[this.my_data.file] = this.my_data.data;
switch (_button_id)
{
case "overwrite":
uploaded[this.my_data.file].confirmed = true;
// fall through
case "rename":
uploaded[this.my_data.file].name = _value;
delete uploaded[this.my_data.file].confirm;
// send overwrite-confirmation and/or rename request to server
egw.json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_vfsSelect_storeFile', [uploaded, this.my_data.path],
that._storeFile_callback, that, true, that
).sendRequest();
return;
case "cancel":
// Remove that file from every file widget...
that.et2.iterateOver(function(_widget) {
_widget.remove_file(this.my_data.data.name);
}, this, et2_file);
}
},
_data.uploaded[file].confirm === "is_dir" ?
this.egw.lang("There's already a directory with that name!") :
this.egw.lang('Do you want to overwrite existing file %1 in directory %2?', _data.uploaded[file].name, _data.path),
this.egw.lang('File %1 already exists', _data.uploaded[file].name),
_data.uploaded[file].name, buttons, file);
// setting required data for callback in as my_data
dialog.my_data = {
file: file,
path: _data.path,
data: _data.uploaded[file],
};
}
else
{
this.submit();
}
}
}
/**
* Prompt user for directory to create
*
* @param {egwAction|undefined|jQuery.Event} action Action, event or undefined if called directly
* @param {egwActionObject[] | undefined} selected Selected row, or undefined if called directly
*/
createdir(action, selected)
{
let self = this;
et2_dialog.show_prompt(function(button, dir){
if (button && dir)
{
let path = self.get_path();
self.egw.json('EGroupware\\Api\\Etemplate\\Widget\\Vfs::ajax_create_dir', [dir, path], function(msg){
self.egw.message(msg);
self.change_dir((path == '/' ? '' : path)+'/'+ dir);
}).sendRequest(false);
}
},this.egw.lang('New directory'),this.egw.lang('Create directory'));
}
/**
* Change directory
*
* @param {string} _dir directory to change to incl. '..' for one up
*/
change_dir(_dir : string)
{
if (_dir == '..')
{
_dir = this.dirname(this.get_path());
}
this.path_widget.set_value(_dir);
}
/**
* Row or filename in select-file dialog clicked
*
* @param {jQuery.event} event
* @param {et2_widget} widget
*/
select_clicked(event : JQueryEventObject, widget : et2_vfs)
{
if (!widget || typeof widget.value != 'object')
{
}
else if (widget.value.is_dir) // true for "httpd/unix-directory" and "egw/*"
{
let path = null;
// Cannot do this, there are multiple widgets named path
// widget.getRoot().getWidgetById("path");
widget.getRoot().iterateOver(function(widget) {
if(widget.id == "path") path = widget;
},null, et2_textbox);
if(path)
{
path.set_value(widget.value.path);
}
}
else if (this.et2 && this.et2.getArrayMgr('content').getEntry('mode') != 'open-multiple')
{
let editfield = this.et2.getWidgetById('name');
if(editfield)
{
editfield.set_value(widget.value.name);
}
}
else
{
let file = widget.value.name;
widget.getParent().iterateOver(function(widget)
{
if(widget.options.selected_value == file)
{
widget.set_value(widget.get_value() == file ? widget.options.unselected_value : file);
}
}, null, et2_checkbox);
}
// Stop event or it will toggle back off
event.preventDefault();
event.stopPropagation();
return false;
}
/**
* Handles action and offer it to the submit
*
* @param {string} action action name
* @param {object} widget widget which action was called from
*/
do_action(action : string, widget : et2_button | et2_selectbox | et2_vfsPath)
{
if (!action) return;
let field = '', value = '';
switch (action)
{
case 'path': field = 'path'; value = (<et2_vfsPath>widget).getValue(); break;
case 'home': field = 'action'; value = 'home'; break;
case 'app': field = 'app'; value = (<et2_selectbox>widget).getValue(); break;
case 'mime': field = 'mime'; value = (<et2_selectbox>widget).getValue(); break;
}
this.submit(field, value);
}
/**
* Sumbits content value after modification
*
* @param {string} _field content field to be modified
* @param {any} _val value of field
* @param {function} _callback
*/
submit(_field? : string, _val? : any, _callback? : Function)
{
let arrMgrs = this.et2.getArrayMgrs();
if (_field)
{
arrMgrs.content.data[_field] = _val;
jQuery.extend(arrMgrs.content.data, arrMgrs.modifications.data);
this.et2.setArrayMgrs(arrMgrs);
}
// preserve value of the name
if (arrMgrs && this.et2.getWidgetById('name'))
{
arrMgrs.content.data['name'] = this.et2.getWidgetById('name').get_value();
}
this.vfsSelectWidget._content(arrMgrs.content.data, _callback);
}
/**
* search through dir content and set its content base on searched query
* @returns
*/
search(_widget)
{
let dir = this.et2.getWidgetById('dir');
let query = _widget.get_value();
if (query == "")
{
dir.set_value({content: this.dirContent});
return;
}
let self = this;
let searchQuery = function (_query)
{
let result = {};
let reg = RegExp(_query, 'ig');
let key = 0;
for (let i in self.dirContent)
{
if (typeof self.dirContent[i]['name'] != 'undefined' && self.dirContent[i]['name'].match(reg))
{
result[key] = self.dirContent[i];
key++;
}
else if (typeof self.dirContent[i]['name'] == 'undefined' && isNaN(<number><unknown>i))
{
result[i] = self.dirContent[i];
}
}
return result;
};
dir.set_value({content: searchQuery(query)});
}
}
app.classes.vfsSelectUI = vfsSelectUI;