Skip to main content

Kendo UI File Uploading Client Side Validation

In Kendo UI async file uploading there is no option to make some client side validation like:
  • No of files you can upload at a time
  • Size of the file
  • Extension of your uploading file
              So, how we can achieve this ? So, to know that see the javascript code snippet below. I am going to explain that.
$('#selectedFiles-edit-win').kendoUpload({
multiple: true,
localization: {
select: 'Select File(s)'
},
async: {
saveUrl: "/CFCS/AjaxFactory.cfc?method=uploadFile",
removeUrl: "/CFCS/AjaxFactory.cfc?method=cancelUploadedFile",
autoUpload: true
},
select: function(e) {
var files = e.files;
if( files.length > 10 ) {
alert("Maximum 10 files can be uploaded at a time.");
e.preventDefault();
return false;
}
 
for(var fileCntr = 0; fileCntr < files.length; fileCntr ++) {
if( files[fileCntr].size > 10485760 ) {
alert("File size more than 10MB can not be uploaded.");
e.preventDefault();
return false;
}
 
if( files[fileCntr].extension.toLowerCase() == '.exe' ) {
alert("Executable files can not be uploaded.");
e.preventDefault();
return false;
}
}
}
});
  So, if you notice in select method we are getting all selected files in "e.files". Using that we can get all information of the selected files .

              To cancel the selected files we are just writing the line "e.preventDefault();". After each e.preventDefault() I am writing "return false" that is because when the condition checking gets an error it just comes out of the function with one message. If we will remove that then it will alert all error messages then it will cancel the selected files.
          To display only first error message I have wrote "return false". If you want to display all error messages then you write your own javascript logic.

So, now you can see what other information "e.files" and according to that you can implement your logic.


Comments

Popular posts from this blog

ASP.NET MVC - Set custom IIdentity or IPrincipal

Here's how I do it. I decided to use IPrincipal instead of IIdentity because it means I don't have to implement both IIdentity and IPrincipal. Create the interface interface ICustomPrincipal : IPrincipal { int UserId { get ; set ; } string FirstName { get ; set ; } string LastName { get ; set ; } } CustomPrincipal public class CustomPrincipal : ICustomPrincipal { public IIdentity Identity { get ; private set ; } public bool IsInRole ( string role ) { return false ; } public CustomPrincipal ( string email ) { this . Identity = new GenericIdentity ( email ); } public int UserId { get ; set ; } public string FirstName { get ; set ; } public string LastName { get ; set ; } } CustomPrincipalSerializeModel - for serializing custom information into userdata field in FormsAuthenticationTicket object. public class CustomPrincipalSerializeMode...

Validate credit card number with Mod 10 algorithm in C#

Introduction All you know what information contains in your NIC number. But do you know what information contains in the Credit Card Number? Following article provides brief details about what information contain in your credit card and demonstrates to how to validate credit card number using mod 10 (Luhn) algorithms with C#. Background  Card Length   Typically, credit card numbers are all numeric and the length of the credit card number is between 12 digits to 19 digits.  14, 15, 16 digits – Diners Club 15 digits – American Express 13, 16 digits – Visa 16 digits - MasterCard   For more information please refer  http://en.wikipedia.org/wiki/Bank_card_number . Hidden information  Major Industry Identifier (MII)   The first digit of the credit card number is the Major Industry Identifier (MII). It designates the category of the entry which issued the card.     1 and 2 – Airlin...

kendo ui menu dynamic - ASP.NET MVC

Model Class public class DynamicMenu {     public int MenuID { get; set; }     public string MenuName { get; set; }     public int ParentMenuID { get; set; } } Controller Code public ActionResult Menu() {      ViewData["DynamicMenu"] = new List<DynamicMenu> {             new DynamicMenu{ MenuID = 1, MenuName = "Self", ParentMenuID = 0 },             new DynamicMenu{ MenuID = 2, MenuName = "Functional", ParentMenuID = 0  },             new DynamicMenu{ MenuID = 3, MenuName = "Leave", ParentMenuID = 1 },             new DynamicMenu{ MenuID = 4, MenuName = "Leave Application", ParentMenuID = 3 },             new Dynamic...