forked from extern/egroupware
Fix not working regexp mime type attribute in file widget
This commit is contained in:
parent
1ea45e6591
commit
1a91dfab7d
api/js/etemplate
@ -264,9 +264,7 @@ var et2_file = /** @class */ (function (_super) {
|
|||||||
this.options.mime = mime.toLowerCase();
|
this.options.mime = mime.toLowerCase();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// Convert into a js regex
|
this.options.mime = mime;
|
||||||
var parts = mime.substr(1).match(/(.*)\/([igm]?)$/);
|
|
||||||
this.options.mime = new RegExp(parts[1], parts.length > 2 ? parts[2] : "");
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
et2_file.prototype.set_multiple = function (_multiple) {
|
et2_file.prototype.set_multiple = function (_multiple) {
|
||||||
@ -283,11 +281,21 @@ var et2_file = /** @class */ (function (_super) {
|
|||||||
* @return boolean
|
* @return boolean
|
||||||
*/
|
*/
|
||||||
et2_file.prototype.checkMime = function (f) {
|
et2_file.prototype.checkMime = function (f) {
|
||||||
|
var mime = '';
|
||||||
|
if (this.options.mime.indexOf("/") != 0) {
|
||||||
|
// Lower case it now, if it's not a regex
|
||||||
|
mime = this.options.mime.toLowerCase();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Convert into a js regex
|
||||||
|
var parts = this.options.mime.substr(1).match(/(.*)\/([igm]?)$/);
|
||||||
|
mime = new RegExp(parts[1], parts.length > 2 ? parts[2] : "");
|
||||||
|
}
|
||||||
// If missing, let the server handle it
|
// If missing, let the server handle it
|
||||||
if (!this.options.mime || !f.type)
|
if (!mime || !f.type)
|
||||||
return true;
|
return true;
|
||||||
var is_preg = (typeof this.options.mime == "object");
|
var is_preg = (typeof mime == "object");
|
||||||
if (!is_preg && f.type.toLowerCase() == this.options.mime || is_preg && this.options.mime.test(f.type)) {
|
if (!is_preg && f.type.toLowerCase() == mime || is_preg && mime.test(f.type)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
// Not right mime
|
// Not right mime
|
||||||
|
@ -381,9 +381,7 @@ export class et2_file extends et2_inputWidget
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Convert into a js regex
|
this.options.mime = mime;
|
||||||
var parts = mime.substr(1).match(/(.*)\/([igm]?)$/);
|
|
||||||
this.options.mime = new RegExp(parts[1],parts.length > 2 ? parts[2] : "");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -405,11 +403,24 @@ export class et2_file extends et2_inputWidget
|
|||||||
*/
|
*/
|
||||||
checkMime(f)
|
checkMime(f)
|
||||||
{
|
{
|
||||||
// If missing, let the server handle it
|
let mime: string | RegExp = '';
|
||||||
if(!this.options.mime || !f.type) return true;
|
if(this.options.mime.indexOf("/") != 0)
|
||||||
|
{
|
||||||
|
// Lower case it now, if it's not a regex
|
||||||
|
mime = this.options.mime.toLowerCase();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Convert into a js regex
|
||||||
|
var parts = this.options.mime.substr(1).match(/(.*)\/([igm]?)$/);
|
||||||
|
mime = new RegExp(parts[1],parts.length > 2 ? parts[2] : "");
|
||||||
|
}
|
||||||
|
|
||||||
var is_preg = (typeof this.options.mime == "object");
|
// If missing, let the server handle it
|
||||||
if(!is_preg && f.type.toLowerCase() == this.options.mime || is_preg && this.options.mime.test(f.type))
|
if(!mime || !f.type) return true;
|
||||||
|
|
||||||
|
var is_preg = (typeof mime == "object");
|
||||||
|
if(!is_preg && f.type.toLowerCase() == mime || is_preg && mime.test(f.type))
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user