farzinmonsef / tk1

0 stars 0 forks source link

Programs #8

Open farzinmonsef opened 4 years ago

farzinmonsef commented 4 years ago

RequiredIf,

farzinmonsef commented 4 years ago

RequiredIfAttribute.cs

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Usage in MeataData . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . [UIHint("NumberFormated")] [RequiredIf(Field = "TransType", Values = "5|6|7", ErrorMessage = "Cancel and Retire is required for this Trans Type")] [Display(Name = "Cancel and Retire")] public Nullable CancelandRetire { get; set; } . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . In View . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . (function ($, kendo) { $.extend(true, kendo.ui.validator, { rules: { requiredif: function (input) { var tmp = input[0].attributes["data-val-requiredif"]; if (typeof tmp != 'undefined') { var requiredifExists = input[0].attributes["data-val-requiredif"].value; var requirediffield = input[0].attributes["data-val-requiredif-field"].value; var requiredifvalues = input[0].attributes["data-val-requiredif-values"].value; var v = $("input[name=" + requirediffield + "]")[0].value var requiredifvaluesArray = requiredifvalues.split('|'); var match = false; for (var i = 0; i < requiredifvaluesArray.length; i++) { if (requiredifvaluesArray[i] == v) { match = true; break; } } if (match) { if ((input[0].value == '') || (input[0].value == null)) { return false; } } } return true; } }, messages: { requiredif: function (input) { return input[0].attributes["data-val-requiredif"].value; } } }); })(jQuery, kendo);

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . RequiredIfAttribute.cs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Web.Mvc;

namespace Entitites { [AttributeUsage(AttributeTargets.Property, AllowMultiple = false, Inherited = true)] public class RequiredIfAttribute : ValidationAttribute, IClientValidatable { public string Field { get; set; } public string Values { get; set; }

    public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
    {
        var rule = new ModelClientValidationRule
        {
            ErrorMessage = ErrorMessage,
            ValidationType = "requiredif"
        };
        rule.ValidationParameters["field"] = Field;
        rule.ValidationParameters["values"] = Values;
        yield return rule;
    }
    private const string DefaultErrorMessageFormatString = "The {0} field is required.";

    private bool IsValueRequired(string checkValue, Object currentValue)
    {
        if (checkValue.Equals("!null", StringComparison.InvariantCultureIgnoreCase))
        {
            return currentValue != null;
        }
        return checkValue.Equals(currentValue.ToString());
    }

    protected override ValidationResult IsValid(Object value, ValidationContext context)
    {
        Object instance = context.ObjectInstance;
        System.Type type = instance.GetType();
        bool valueRequired = false;
        var ValuesArray = Values.Split('|').ToList();
        Object propertyValue = type.GetProperty(Field).GetValue(instance, null);
        for (int i = 0; i < ValuesArray.Count; i++) {
            valueRequired = IsValueRequired(ValuesArray[i], propertyValue);
            if (valueRequired) break;
        }

        if (valueRequired)
        {
            return !string.IsNullOrEmpty(Convert.ToString(value))
                ? ValidationResult.Success
                : new ValidationResult(ErrorMessage != "" ? ErrorMessage
                            : string.Format(DefaultErrorMessageFormatString, context.DisplayName));
        }
        return ValidationResult.Success;
    }
}

}

farzinmonsef commented 4 years ago

LINQ ++ LEFT OUTER JOIN

        DateTime dt1 = DateTime.Now;

        int categoryId = RoleToCategory((int)userRole);
        var transactions = new List<TransactionDTO>();
        var query = Db.Transactions
            .SelectMany(tr => Db.Types.Where(type => type.Id == tr.TransType).DefaultIfEmpty(), (tr, ty) => new { tr, ty })
            .SelectMany(tra => Db.Types.Where(type => type.Id == tra.tr.Status).DefaultIfEmpty(), (tra, typ) => new { tra, typ })
            .SelectMany(tran => Db.Types.Where(type => type.Id == tran.tra.tr.CategoryId).DefaultIfEmpty(), (tran, type) => new { tran, type })
            .SelectMany(trans => Db.Types.Where(type => type.Id == trans.tran.tra.tr.PlanName).DefaultIfEmpty(), (trans, typee) => new { trans, typee })
            .Where(x => (userRole != RoleType.Administrator ? x.trans.tran.tra.tr.CategoryId == categoryId : 1 == 1))
            .Select(x => new TransactionDTO
            {
                Id = x.trans.tran.tra.tr.Id,
                CategoryId = x.trans.tran.tra.tr.CategoryId,
                Category = x.trans.type.Name,
                . . . .
                . . . .
            })
            //.ToDataSourceResult(request)
            ;

        transactions = query.ToList();
        //DateTime dt1 = DateTime.Now;
        DateTime dt2 = DateTime.Now;
        TimeSpan span = dt2 - dt1;
        int ms = (int)span.TotalMilliseconds;
        Debug.WriteLine("Total, time(ms)= " + ms.ToString());
        return transactions;
farzinmonsef commented 4 years ago

Persist Custom Filters in Grid

https://demos.telerik.com/aspnet-mvc/filter/persist-state

farzinmonsef commented 4 years ago

MyDataSourceResult

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;

//using System; //using System.Collections.Generic; //using System.Linq; //using System.Linq.Dynamic; using System.Linq.Expressions; using DynamicExpression = System.Linq.Dynamic.DynamicExpression; using Kendo.DynamicLinq; using System.Linq.Dynamic;

namespace Data { public static class DBTools { }

public static class QueryableExtensions
{
    /// <summary>
    /// Applies data processing (paging, sorting, filtering and aggregates) over IQueryable using Dynamic Linq.
    /// </summary>
    /// <typeparam name="T">The type of the IQueryable.</typeparam>
    /// <param name="queryable">The IQueryable which should be processed.</param>
    /// <param name="take">Specifies how many items to take. Configurable via the pageSize setting of the Kendo DataSource.</param>
    /// <param name="skip">Specifies how many items to skip.</param>
    /// <param name="sort">Specifies the current sort order.</param>
    /// <param name="filter">Specifies the current filter.</param>
    /// <param name="aggregates">Specifies the current aggregates.</param>
    /// <returns>A DataSourceResult object populated from the processed IQueryable.</returns>
    public static DataSourceResult ToMyDataSourceResult<T>(this IQueryable<T> queryable, int take, int skip, IEnumerable<Sort> sort, Filter filter, IEnumerable<Aggregator> aggregates)
    {
        // Filter the data first
        queryable = MyFilter(queryable, filter);

        // Calculate the total number of records (needed for paging)
        var total = queryable.Count();

        // Calculate the aggregates
        var aggregate = MyAggregate(queryable, aggregates);

        // Sort the data
        queryable = MySort(queryable, sort);

        // Finally page the data
        if (take > 0)
        {
            queryable = MyPage(queryable, take, skip);
        }

        return new DataSourceResult
        {
            Data = queryable.ToList(),
            Total = total,
            Aggregates = aggregate
        };
    }

    /// <summary>
    /// Applies data processing (paging, sorting and filtering) over IQueryable using Dynamic Linq.
    /// </summary>
    /// <typeparam name="T">The type of the IQueryable.</typeparam>
    /// <param name="queryable">The IQueryable which should be processed.</param>
    /// <param name="take">Specifies how many items to take. Configurable via the pageSize setting of the Kendo DataSource.</param>
    /// <param name="skip">Specifies how many items to skip.</param>
    /// <param name="sort">Specifies the current sort order.</param>
    /// <param name="filter">Specifies the current filter.</param>
    /// <returns>A DataSourceResult object populated from the processed IQueryable.</returns>
    public static DataSourceResult ToMyDataSourceResult<T>(this IQueryable<T> queryable, int take, int skip, IEnumerable<Sort> sort, Filter filter)
    {
        return queryable.ToMyDataSourceResult(take, skip, sort, filter, null);
    }

    /// <summary>
    ///  Applies data processing (paging, sorting and filtering) over IQueryable using Dynamic Linq.
    /// </summary>
    /// <typeparam name="T">The type of the IQueryable.</typeparam>
    /// <param name="queryable">The IQueryable which should be processed.</param>
    /// <param name="request">The DataSourceRequest object containing take, skip, order, and filter data.</param>
    /// <returns>A DataSourceResult object populated from the processed IQueryable.</returns>
    public static DataSourceResult ToMyDataSourceResult<T>(this IQueryable<T> queryable, DataSourceRequest request)
    {
        return queryable.ToMyDataSourceResult(request.Take, request.Skip, request.Sort, request.Filter, null);
    }

    private static IQueryable<T> MyFilter<T>(IQueryable<T> queryable, Filter filter)
    {
        if (filter != null && filter.Logic != null)
        {
            // Collect a flat list of all filters
            var filters = filter.All();

            // Get all filter values as array (needed by the Where method of Dynamic Linq)
            var values = filters.Select(f => f.Value).ToArray();

            // Create a predicate expression e.g. Field1 = @0 And Field2 > @1
            string predicate = filter.ToExpression(filters);

            // Use the Where method of Dynamic Linq to filter the data
            queryable = queryable.Where(predicate, values);
        }

        return queryable;
    }

    private static object MyAggregate<T>(IQueryable<T> queryable, IEnumerable<Aggregator> aggregates)
    {
        if (aggregates != null && aggregates.Any())
        {
            var objProps = new Dictionary<DynamicProperty, object>();
            var groups = aggregates.GroupBy(g => g.Field);
            Type type = null;
            foreach (var group in groups)
            {
                var fieldProps = new Dictionary<DynamicProperty, object>();
                foreach (var aggregate in group)
                {
                    var prop = typeof(T).GetProperty(aggregate.Field);
                    var param = Expression.Parameter(typeof(T), "s");
                    var selector = aggregate.Aggregate == "count" && (Nullable.GetUnderlyingType(prop.PropertyType) != null)
                        ? Expression.Lambda(Expression.NotEqual(Expression.MakeMemberAccess(param, prop), Expression.Constant(null, prop.PropertyType)), param)
                        : Expression.Lambda(Expression.MakeMemberAccess(param, prop), param);
                    var mi = aggregate.MethodInfo(typeof(T));
                    if (mi == null)
                        continue;

                    var val = queryable.Provider.Execute(Expression.Call(null, mi,
                        aggregate.Aggregate == "count" && (Nullable.GetUnderlyingType(prop.PropertyType) == null)
                            ? new[] { queryable.Expression }
                            : new[] { queryable.Expression, Expression.Quote(selector) }));

                    fieldProps.Add(new DynamicProperty(aggregate.Aggregate, typeof(object)), val);
                }
                type = DynamicExpression.CreateClass(fieldProps.Keys);
                var fieldObj = Activator.CreateInstance(type);
                foreach (var p in fieldProps.Keys)
                    type.GetProperty(p.Name).SetValue(fieldObj, fieldProps[p], null);
                objProps.Add(new DynamicProperty(group.Key, fieldObj.GetType()), fieldObj);
            }

            type = DynamicExpression.CreateClass(objProps.Keys);

            var obj = Activator.CreateInstance(type);

            foreach (var p in objProps.Keys)
            {
                type.GetProperty(p.Name).SetValue(obj, objProps[p], null);
            }

            return obj;
        }
        else
        {
            return null;
        }
    }

    private static IQueryable<T> MySort<T>(IQueryable<T> queryable, IEnumerable<Sort> sort)
    {
        if (sort != null && sort.Any())
        {
            // Create ordering expression e.g. Field1 asc, Field2 desc
            var ordering = String.Join(",", sort.Select(s => s.ToExpression()));

            // Use the OrderBy method of Dynamic Linq to sort the data
            return queryable.OrderBy(ordering);
        }

        return queryable;
    }

    private static IQueryable<T> MyPage<T>(IQueryable<T> queryable, int take, int skip)
    {
        return queryable.Skip(skip).Take(take);
    }
}

}

farzinmonsef commented 4 years ago

BusEmail.cs

using Common.SendEmail; using Common.SendEmail.Model; using System; using System.Linq; using Data; using Entitites;

namespace Business { public class BusEmail { public string previewLetter(int TransactionId, User user) { //getting Template & SMTP values from databse, table appConfig var SmtpServerName = ""; var SmtpPortNumber = ""; var Username = ""; var Password = ""; string template = ""; string to = ""; string subject = ""; var appSettingData = new AppSettingData(); var settingsData = appSettingData.FindAppSettingByToolID(getToolId(TransactionId)); if (settingsData != null && settingsData.Count > 0) { SmtpServerName = settingsData.FirstOrDefault(x => x.Key.ToUpper() == "SMTPSERVER")?.Value; SmtpPortNumber = settingsData.FirstOrDefault(x => x.Key.ToUpper() == "SMTPPORT")?.Value; Username = settingsData.FirstOrDefault(x => x.Key.ToUpper() == "SMTPUSERNAME")?.Value; Password = settingsData.FirstOrDefault(x => x.Key.ToUpper() == "SMTPPASSWORD")?.Value; template = Convert.ToString(settingsData.FirstOrDefault(x => x.Key.ToUpper() == "TEMPLATE")?.Value); to = Convert.ToString(settingsData.FirstOrDefault(x => x.Key.ToUpper() == "TO")?.Value); subject = Convert.ToString(settingsData.FirstOrDefault(x => x.Key.ToUpper() == "SUBJECT")?.Value); } //replace field values in found template if (!string.IsNullOrEmpty(template)) { TransactionData transactionData = new TransactionData(); Transaction transaction = transactionData.FindTransactionByID(TransactionId); template = template.Replace("[NetSharesToBroker]", transaction.NetSharesToMerrillLynch == null ? "" : string.Format("{0:n0}", transaction.NetSharesToMerrillLynch));

            TypeData typeData = new TypeData();
            var planName = transaction.PlanName == null ? null : typeData.FindTypeByID((int)transaction.PlanName);
            template = template.Replace("[PlanName]", planName == null ? "" : (planName.Name == null ? "" : Convert.ToString(planName.Name)));
            var title = typeData.FindTypeByID((int)transaction.TransactionType);
            template = template.Replace("[Title]", title.Name == null ? "" : Convert.ToString(title.Name));

            var JobTitlkeFormated = "";
            CORPDIRECTORYLOADData corpdirectoryData = new CORPDIRECTORYLOADData();
            var corpdirectory = corpdirectoryData.FindCORPDIRECTORYLOADByNBKID(user.StandardId);
            if (corpdirectory != null)
            {
                var usertitle = corpdirectory.JobTitle;
                var tmp = usertitle.ToString().Split(';');
                JobTitlkeFormated = tmp[0];
            }

            template = template.Replace("[LetterYear]", DateTime.Now.ToString("yyyy"));

            template = template.Replace("[Approved]", Convert.ToString(user.FirstName) + " " + Convert.ToString(user.LastName));
            template = template.Replace("[CorporateTitle]", Convert.ToString(JobTitlkeFormated));

            UserData userData = new UserData();
            User preparedUser = userData.FindByID(transaction.CreatedById);
            template = template.Replace("[Prepared]",
                preparedUser != null ? Convert.ToString(preparedUser.FirstName) + " " + Convert.ToString(preparedUser.LastName) : "");
            template = template.Replace("[EntryDate]", transaction.EntryDate.Value == null ? "" : transaction.EntryDate.Value.ToString("MMMM dd, yyyy"));
        }

        return template;
    }

    public string sndEmail(int TransactionId, string msgBody, int Status_Pending, int Status_Approved, int approver, string BOALogo_filename) //, int testbit = 0)
    {
        string pendingReqRepResult = "";
        try
        {
            TransactionData transactionData = new TransactionData();
            Transaction transact = transactionData.FindTransactionByID(TransactionId, Status_Pending);
            if (transact != null)
            {
                string ToEmail = "",
                        CcEmail = "",
                        Subject = "";
                IAppSettingBLL _oAppSettingDomain = new Common.SendEmail.AppSettingBLL();
                IEmailMessage messageItem = new EmailMessage();

                var appSettingEmailData = _oAppSettingDomain.GetAppSettingsDataByToolId(getToolId(TransactionId));// Convert.ToInt32(appPortalTool.EQMPendingReport));
                var settingEmailData = appSettingEmailData.ToList();

                if (appSettingEmailData != null && settingEmailData.Count > 0)
                {
                    ToEmail = settingEmailData.FirstOrDefault(x => x.Key == "TO")?.Value;
                    CcEmail = settingEmailData.FirstOrDefault(x => x.Key == "CC")?.Value;
                    Subject = settingEmailData.FirstOrDefault(x => x.Key == "SUBJECT")?.Value;
                }
                messageItem.Body = msgBody;
                messageItem.Cc = CcEmail;
                messageItem.Subject = Subject;
                messageItem.To = ToEmail;
                messageItem.AttachmentFileName = BOALogo_filename;
                messageItem.Key = "WithAttachment";
                messageItem.MediaTypeName = "image/jpeg";

                Email msg = new Email(appPortalTool.SMTPSettings);
                msg.Send(messageItem);
                pendingReqRepResult = Convert.ToString(messageItem.Error);

                //////////   Logging return of Send Email for Checking Purposes
                BusLogDB busLogDB = new BusLogDB();
                busLogDB.LogDB(new LogDB()
                {
                    Date_Time = DateTime.Now,
                    UserName = Convert.ToString(approver),
                    Controller = "BusEmail",
                    Action = "sndEmail",
                    Message = pendingReqRepResult,
                    Comment = "Return From Send Email for Transaction ID= " + Convert.ToString(transact.Id) + " Setting Status=" + Convert.ToString(Status_Approved)
                });
                ///////////////////////////////////////////////////////////////
                if (string.IsNullOrEmpty(pendingReqRepResult) ||
                       ((pendingReqRepResult.ToUpper().IndexOf("FAILURE") < 0) &&
                        (pendingReqRepResult.ToUpper().IndexOf("ERROR") < 0))
                    )
                {
                    pendingReqRepResult = "";
                    transact = transactionData.SetTransactionStatus(transact, approver, Status_Approved);
                }
            }
            else
            {
                pendingReqRepResult = "You already EMAILED the transaction\nNo further action permitted!";
            }
        }
        catch (Exception ex)
        {
            pendingReqRepResult = "Error: " + ex.ToString();
        }
        return Convert.ToString(pendingReqRepResult);
    }

    /// <summary>
    /// Takes a transaction and returns the Tool Id needed for email settings for that type
    /// </summary>
    /// <param name="transactionId">Transaction Identitifer</param>
    /// <returns>Tool ID</returns>
    private int getToolId(int transactionId)
    {
        TransactionData transactionData = new TransactionData();
        Transaction transaction = transactionData.FindTransactionByID(transactionId);
        TypeData typeData = new TypeData();
        var transactionType = typeData.FindTypeByID((int)transaction.TransactionType);
        return Convert.ToInt32(transactionType.Comment);
    }
}

}

farzinmonsef commented 4 years ago

email-template


[BOA-Logo]
Equity Management Communication

[Title]

To: [To]
From: [From]
 
 
[Title]
We have been notified that the following shares should be released as follows:
 
●  Effective Date: [TransactionEffectiveDate]
 
●  Requisition Number: [RequisitionNumber]
 
●  Debit: DWAC from DTC
●  Debit Shares: [NetSharesToBroker]
 
●  Debit: Cancel and Retire (R469) - Payment for taxes
●  Debit Shares: [TotalShares]
 
●  Credit: Restricted Stock Account for Stock Plan Participants (Account #5793106)
●  Credit Shares: [SharesForTax]
 
 
Approved By: [Approved]
Corporate Title: [CorporateTitle]
 
Prepared by: [Prepared]
Date: [EntryDate]
Transaction Id:  [TransactionId]
 
Bank of America N.A. Member FDIC © [LetterYear] Bank of America Corporation. All rights reserved
 
farzinmonsef commented 4 years ago

Trans..Controler

[OutputCache(NoStore = true, Duration = 0, VaryByParam = "*")] [HttpPost] public ActionResult GetPreviewLetter(int TransactionId) { BusEmail ml = new BusEmail(); string tmp1 = ml.previewLetter(TransactionId, (User)Session["currentUser"]); string tmp2 = tmp1; Session["previewLetter"] = tmp2.Replace("[BOA-Logo]", "<img src=\"cid:DSitesEqmwwwrootImagesBOALogoLetter.jpg\" alt=\"Bank of America Logo\" />"); Session["TransactionId"] = TransactionId;

        string display_BOA_logo = "<p style='text-align:right'>" +
            "    <img alt='Bank Of America Logo' height='32' width='300'" +
            "         src='' />" +
            "</p>";
        string display_command =
            "<p style='text-align:right;padding:opx 50px'>" +
            "   <input type='button' class='k-button' name='cancelemailLetter' value='Cancel' onclick='cancelemailLetter()'>" +
            "   <input type='button' class='k-button k-primary' name='emailLetter' value='Send Email to ComputerShare' onclick='emailLetterconfirm()'>&nbsp;&nbsp;&nbsp;" +
            "</p>";
        tmp1 = tmp1.Replace("[BOA-Logo]", display_BOA_logo) + display_command;
        return Json(tmp1);
    }

    [OutputCache(NoStore = true, Duration = 0, VaryByParam = "*")]
    [HttpPost]
    public ActionResult SendMail()
    {
        var ret = "";
        try
        {
            int TransactionId = (int)Session["TransactionId"];
            BusEmail busEmail = new BusEmail();
            ret = busEmail.sndEmail(TransactionId, (string)Session["previewLetter"],
                (int)Session["Status_Pending"], (int)Session["Status_Approved"],
                (int)Session["userId"], Path.Combine(Server.MapPath("~/Images"), "BOALogoLetter.jpg"));
        }
        catch (Exception ex)
        {
            ret = ex.ToString();
            //throw ex;
        }
        return Json(ret);
    }
farzinmonsef commented 4 years ago

Data Metadata

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.ComponentModel.DataAnnotations; //using Attributes;

namespace Entitites { [MetadataType(typeof(TransactionMetaData))] public partial class Transaction { public static explicit operator List(Transaction t) { throw new NotImplementedException(); } } public class TransactionMetaData { //[UIHint("Date")] //[UIHint("NumberFormated")] //[DisplayFormat(DataFormatString = "{0:n0}")] //[ScaffoldColumn(false)] //[DataType(DataType.Text)] [Display(Name = "Transaction ID")] [Editable(false)] [UIHint("NumberFormatedDisbled")] public int Id { get; set; }

    [UIHint("DropDownCategory")]
    [Required(ErrorMessage = "Category is required.")]
    [Display(Name = "Category")]
    public Nullable<int> CategoryId { get; set; }

    //[UIHint("DropDownCategory")]
    [UIHint("DropDownTransactionType")]
    [Required(ErrorMessage = "Transaction Type is required.")]
    [Display(Name = "Transaction Type")]
    public Nullable<int> TransactionType { get; set; }

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . } }

farzinmonsef commented 4 years ago

GRID VIEW

@using Entitites @using EQM.Enumerations; @{ViewBag.Title = "Transactions"; }

@*

<br />
<input type="button" value="download" onclick="testDownload( 163 );" />*@


@(Html.Kendo().Grid() .Name("transactiongrid") .Columns(columns => { columns.Bound(c => c.Id).Title("ID").Filterable(filterable => filterable.UI("integerFilter")); ;//.ClientTemplate("#= kendo.toString(Id, \'n0\')#"); /*.Hidden();*/ columns.Bound(c => c.Category).Title("Category"); columns.Bound(c => c.TypeName).Title("Transaction Type"); columns.Bound(c => c.EntryDate).Format("{0: MM/dd/yyyy}"); columns.Bound(c => c.TransactionEffectiveDate).Format("{0: MM/dd/yyyy}"); columns.Command(command => { command.Edit().CancelText("Cancel").UpdateText("Submit").Text("Edit"); }).Hidden(); columns.Template(@) //.ClientTemplate(@"").Title("#"); .ClientTemplate(@"#if (FileName!= null) {# #} else {# #=''# #}#").Title("Attach"); columns.Bound(c => c.StatusName).Title("Status"); columns.Template(@).Width(100) .ClientTemplate(@" Edit") .Title("Actions"); columns.Command(command => command.Custom("Preview Letter") .HtmlAttributes(new { @class = "btn k-button k-grid-customCommand btnPreviewLetter" }).Click("showPreview")) .Width(90).Hidden(!((int)Session["userRole"] == (int)RoleType.Administrator)); columns.Template(@) .ClientTemplate(@"") .Title(" "); columns.Bound(c => c.FileName).Hidden(); }) .Groupable(g => g.Enabled(true)) .ColumnMenu() .Pageable(pageable => pageable .Refresh(true) .PageSizes(true) .ButtonCount(5) .PageSizes(new string[] { "10", "20", "50", "100" }) ) .Navigatable() .Selectable(selectable => { selectable.Mode(GridSelectionMode.Single); selectable.Type(GridSelectionType.Row); }) .ClientDetailTemplateId("template") .Sortable(sortable => { sortable.SortMode(GridSortMode.SingleColumn); }) .Filterable() .Scrollable(scrollable => scrollable.Enabled(false)) .Editable(ed => ed.Mode(GridEditMode.PopUp) .DisplayDeleteConfirmation(false) .TemplateName("_EditTransaction") .Window(w => w.Title("Add/Edit Transaction") .Width(1050) .Scrollable(false) .Name("EditTransaction") ) ) .Events(events => { events.DataBound("onTransactionDataBound"); events.Change("onTransactionChange"); events.Edit("onTransactionEdit"); events.Cancel("onTransactionCancel"); events.Save("onTransactionSave"); events.DetailExpand("onTransactionDetailExpand"); events.DetailCollapse("onTransactionDetailCollapse"); }) .Resizable(resize => resize.Columns(true)) .DataSource(dataSource => dataSource .Ajax() .ServerOperation(true) .Filter(filters => { filters.Add(TransactionDTO => TransactionDTO.StatusName).IsEqualTo("Pending"); }) .Model(model => { model.Id(p => p.Id); model.Field(t => t.Id).Editable(false); }) .PageSize(10) .Events(events => { events.Error("data_error_handler"); }) .Read(read => read.Action("ListAllTransactions", "Transaction")) .Create(create => create.Action("Transactions_Create", "Transaction")) .Update(update => update.Action("Transactions_Update", "Transaction")) .Destroy(destroy => destroy.Action("Transactions_Destroy", "Transaction")) ) //.ServerFitering(true) )
<Div id="myDiv">

</Div>
<br />
<script id="template" type="text/kendo-tmpl">
    #if(TransactionType=='14') @*Restricted Stock Issuance*@
    {#
    <div class="row">
        <div class="col-md-6 offset-md-3 row">
            <div class="col">
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Requisition Number:</span>
                    <span class="col-md-4">#= RequisitionNumber != null ? RequisitionNumber : '' #</span>
                </div>
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Reserve Name:</span>
                    <span class="col-md-4">#= ReserveName != null ? ReserveName : '' #</span>
                </div>
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Total Vested Shares:</span>
                    <span class="col-md-4">#= kendo.toString(TotalVestedShares != null ? TotalVestedShares : '', "n0") #</span>
                </div>
            </div>
            <div class="col">
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-4">Memo:</span>
                    <span class="col-md-8">#= Memo != null ? Memo : '' #</span>
                </div>
            </div>
        </div>
    </div>
    #}#

    #if(TransactionType=='15') @*Restricted Stock Issuance - Reversal*@
    {#
    <div class="row">
        <div class="col-md-6 offset-md-3 row">
            <div class="col">
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Requisition Number:</span>
                    <span class="col-md-4">#= RequisitionNumber != null ? RequisitionNumber : '' #</span>
                </div>
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Reserve Name:</span>
                    <span class="col-md-4">#= ReserveName != null ? ReserveName : '' #</span>
                </div>
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Total Vested Shares:</span>
                    <span class="col-md-4">#= kendo.toString(TotalVestedShares != null ? TotalVestedShares : '', "n0") #</span>
                </div>
            </div>
            <div class="col">
                <div class="form-group row">
                    <span class="font-weight-bold text-right col-md-4">Memo:</span>
                    <span class="col-md-8">#= Memo != null ? Memo : '' #</span>
                </div>
            </div>
        </div>
    </div>
    #}#

    #if(TransactionType=='3') @*Restricted Stock Release*@
    {#
    <div class="row">
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Requisition Number:</span>
                <span class="col-md-4">#= RequisitionNumber != null ? RequisitionNumber : '' #</span>
            </div>
            @*<div class="form-group row">
                    <span class="font-weight-bold text-right col-md-8">Reserve Name:</span>
                    <span class="col-md-4">#= ReserveName != null ? ReserveName : '' #</span>
                </div>*@
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Total Vested Shares:</span>
                <span class="col-md-4"> #= kendo.toString(TotalShares != null ? TotalShares : '', "n0") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Net Shares to Broker:</span>
                <span class="col-md-4"> #= kendo.toString(NetSharesToMerrillLynch != null ? NetSharesToMerrillLynch : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Shares for Tax:</span>
                <span class="col-md-4">#= kendo.toString(SharesForTax != null ? SharesForTax : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Value of Tax Shares:</span>
                <span class="col-md-4">#= kendo.toString(ValueOfTaxShares != null ? ValueOfTaxShares : '', "c") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-2">Memo:</span>
                <span class="col-md-10">#= Memo != null ? Memo : '' #</span>
            </div>
        </div>
    </div>
    #}#

    #if(TransactionType=='4') @*Restricted Stock Release - Reversal*@
    {#
    <div class="row">
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Requisition Number:</span>
                <span class="col-md-4">#= RequisitionNumber != null ? RequisitionNumber : '' #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Reserve Name:</span>
                <span class="col-md-4">#= ReserveName != null ? ReserveName : '' #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Total Vested Shares:</span>
                <span class="col-md-4"> #= kendo.toString(TotalShares != null ? TotalShares : '', "n0") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Net Shares to Broker:</span>
                <span class="col-md-4"> #= kendo.toString(NetSharesToMerrillLynch != null ? NetSharesToMerrillLynch : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Shares for Tax:</span>
                <span class="col-md-4">#= kendo.toString(SharesForTax != null ? SharesForTax : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Value of Tax Shares:</span>
                <span class="col-md-4">#= kendo.toString(ValueOfTaxShares != null ? ValueOfTaxShares : '', "c") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-2">Memo:</span>
                <span class="col-md-10">#= Memo != null ? Memo : '' #</span>
            </div>
        </div>
    </div>
    #}#

    #if(TransactionType=='5') @*Annuity*@
    {#
    <div class="row">
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Plan Name:</span>
                <span class="col-md-4">#= PlanName!= null ? TypePlanName : '' #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Gross Stock Units Distributed:</span>
                <span class="col-md-4">#= kendo.toString(GrossStockUnitsDistributed != null ? GrossStockUnitsDistributed : '', "n0")  #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Net Stock Unit Shares to Distribute:</span>
                <span class="col-md-4"> #= kendo.toString(NetStockUnitSharestoDistribute!= null ? NetStockUnitSharestoDistribute : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Cancel and Retire Shares:</span>
                <span class="col-md-4"> #= kendo.toString(CancelandRetireShares != null ? CancelandRetireShares : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Value of Tax Shares:</span>
                <span class="col-md-4">#= kendo.toString(ValueOfTaxShares != null ? ValueOfTaxShares : '', "c") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-2">Memo:</span>
                <span class="col-md-10">#= Memo != null ? Memo : '' #</span>
            </div>
        </div>
    </div>
    #}#

    #if(TransactionType=='6') @* For Director Grant *@
    {#
    <div class="row">
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Reserve Name:</span>
                <span class="col-md-4">#= ReserveName!= null ? ReserveName : '' #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Common Restricted Unvested Shares Granted:</span>
                <span class="col-md-4">#= kendo.toString(CommonRestrictedUnvestedSharesGranted != null ? CommonRestrictedUnvestedSharesGranted : '', "n0")  #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Common Restricted Unvested Shares INTO CR1:</span>
                <span class="col-md-4"> #= kendo.toString(CommonRestrictedUnvestedSharesINTOCR1!= null ? CommonRestrictedUnvestedSharesINTOCR1 : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Cancel and Retire Shares:</span>
                <span class="col-md-4"> #= kendo.toString(CancelandRetireShares != null ? CancelandRetireShares : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Director Name:</span>
                <span class="col-md-4"> #= kendo.toString(DirectorName != null ? DirectorName : '') #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Value of Tax Shares:</span>
                <span class="col-md-4">#= kendo.toString(ValueOfTaxShares != null ? ValueOfTaxShares : '', "c") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-2">Memo:</span>
                <span class="col-md-10">#= Memo != null ? Memo : '' #</span>
            </div>
        </div>
    </div>
    #}#

    #if(TransactionType=='7') @* For Director Vesting *@
    {#
    <div class="row">
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Common Restricted Unvested Shares FROM CR1:</span>
                <span class="col-md-4"> #= kendo.toString(CommonRestrictedUnvestedSharesFROMCR1!= null ? CommonRestrictedUnvestedSharesFROMCR1 : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8"> Common Restricted Shares INTO CR2:</span>
                <span class="col-md-4"> #= kendo.toString(CommonRestrictedShareINTOCR2!= null ? CommonRestrictedShareINTOCR2 : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Cancel and Retire Shares:</span>
                <span class="col-md-4"> #= kendo.toString(CancelandRetireShares != null ? CancelandRetireShares : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Director Name:</span>
                <span class="col-md-4"> #= kendo.toString(DirectorName != null ? DirectorName : '') #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Value of Tax Shares:</span>
                <span class="col-md-4">#= kendo.toString(ValueOfTaxShares != null ? ValueOfTaxShares : '', "c") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-2">Memo:</span>
                <span class="col-md-10">#= Memo != null ? Memo : '' #</span>
            </div>
        </div>
    </div>
    #}#
    #if(TransactionType=='10') @* For Retire Treasury Shares*@
    {#
    <div class="row">
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Account Name:</span>
                <span class="col-md-4"> #= kendo.toString(AccountName!= null ? AccountName : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8"> Total Treasury Shares:</span>
                <span class="col-md-4"> #= kendo.toString(TotalTreasurySharestoRetire!= null ? TotalTreasurySharestoRetire : '', "n0") #</span>
            </div>
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-8">Cancel and Retire Shares:</span>
                <span class="col-md-4"> #= kendo.toString(CancelandRetireShares != null ? CancelandRetireShares : '', "n0") #</span>
            </div>
        </div>
        <div class="col">
            <div class="form-group row">
                <span class="font-weight-bold text-right col-md-2">Memo:</span>
                <span class="col-md-10">#= Memo != null ? Memo : '' #</span>
            </div>
        </div>
    </div>
    #}#
</script>

@(Html.Kendo().Window()
.Name("windowPreview")
.Title("Preview Letter")
.Modal(true)
.Visible(false)
.Content(@<text>
        <html>
        <head>
        </head>
        <body lang=EN-US>
            <div style="font-size:medium">
                <br />
                [BOA-Logo]
                <table style="width:100%">
                    <tr><td colspan="5" style="padding:20px 0px 0px 0px"><h6>Equity Management Communication</h6></td></tr>
                    <tr><td colspan="5" style="padding:30px 0px 30px 0px"><h3>[Title]</h3></td></tr>
                    <tr><td colspan="5"><b>To:</b>&nbsp;[To]</td></tr>
                    <tr><td colspan="5"><b>From:</b>&nbsp;[From]</td></tr>

                    <tr><td colspan="5">&nbsp;</td></tr>
                    <tr><td colspan="5" style="padding:10px 0px 10px 0px">Under the terms of the Bank of America Key 2003 Employee Equity Plan, we instruct you as follows:</td></tr>
                    <tr><td colspan="5" style="padding:0px 0px 40px 0px;color:#e61837"><h5>[Title]</h5></td></tr>

                    <tr><td></td><td colspan="3">&#9830;&nbsp;&nbsp;Requisition Number:&nbsp;[RequisitionNumber]</td></tr>
                    <tr><td></td><td colspan="3">&#9830;&nbsp;&nbsp;Effective Date:&nbsp;[TransactionEffectiveDate]</td></tr>
                    <tr><td></td><td colspan="3">&#9830;&nbsp;&nbsp;Debit:&nbsp;[ReserveName]</td></tr>
                    <tr><td></td><td colspan="3">&#9830;&nbsp;&nbsp;Debit Shares:&nbsp;[TotalVestedShares]</td></tr>
                    <tr><td></td><td colspan="3">&#9830;&nbsp;&nbsp;Credit: Restricted Stock Account for Stock Plan Participants </td></tr>
                    <tr><td></td><td colspan="3">&#9830;&nbsp;&nbsp;Credit Shares:&nbsp;[TotalVestedShares]</td></tr>
                    <tr><td colspan="5">&nbsp;</td></tr>

                    <tr><td colspan="4">&nbsp;</td></tr>
                    <tr><td colspan="5">Approved By: [Approved]</td></tr>
                    <tr><td colspan="5">Corporate Title: [CorporateTitle]</td></tr>
                    <tr><td colspan="5">&nbsp;</td></tr>
                    <tr><td colspan="5">Prepared by: [Prepared]</td></tr>
                    <tr><td colspan="5">Date: [EntryDate]</td></tr>
                    <tr class="tblrowbotoomborder"><td colspan="5">&nbsp;</td></tr>
                    <tr><td colspan="5" style="padding:10px 0px 40px 0px">Bank of America N.A. Member FDIC © [LetterYear] Bank of America Corporation. All rights reserved</td></tr>
                    <tr><td>&nbsp;</td></tr>
                </table>
            </div>
        </body>
    </html>
    <p style="text-align:center;padding: 50px">
        <input type="button" class="k-button" name="cancelemailLetter" value="Cancel" onclick="cancelemailLetter()">
        <input type="button" class="k-button k-primary" name="emailLetter" value="Send Email to ComputerShare" onclick="emailLetter()">&nbsp;&nbsp;&nbsp;
    </p>
</text>)

.Draggable() .Resizable() .Width(800) .Actions(actions => actions.Pin().Minimize().Maximize().Close()) .Events(ev => ev.Close("onWindowClose")) )

<div id="msg" style="background:#0d005d;
        visibility:hidden;
        width:30%;
        top:0px;
        left: 0%;
        position:absolute;
        color:white;
        box-shadow: 10px 10px 5px #aaaaaa;
        text-align: center;
        border-radius: 4px;
        border: 4px black;
        padding: 0px 18px 18px 18px;
        border: 4px solid #333;
        font-size: 20px;
        z-index: 8888;
        opacity: 0.97;">
    <table style="width:100%;height:100%;">
        <tbody>
            <tr>
                <td id="mymsgtitle" colspan="2" style="text-align:center;padding: 0px 0px 18px 0px;font-size:30px;">
                </td>
            </tr>
            <tr>
                <td>
                    <img id="msgIcon" src="../Images/_info.png" alt="Success">
                </td>
                <td id="mymsg" style="vertical-align: middle">
                </td>
            </tr>
        </tbody>
    </table>
</div>
<div id="alertboxmodal"
     style="display: none; /* Hidden by default */
    position: fixed; /* Stay in place */
    z-index: 9999; /* Sit on top */
    padding-top: 100px; /* Location of the box */
    left: 0;
    top: 0;
    width: 100%; /* Full width */
    height: 100%; /* Full height */
    overflow: auto; /* Enable scroll if needed */
    background-color: rgb(0,0,0); /* Fallback color */
    background-color: rgba(0,0,0,0.4); /* Black w/ opacity */"
     class="alertboxmodal">
    <div style="background-color: #fefefe;
        margin: auto;
        padding: 20px;
        border: 1px solid #888;
        width: 40%;"
         class="alertbox-content">
        <table style="width:100%;height:100%;">
            <tbody>
                <tr>
                    <td id="mymsgtitle" colspan="5" style="text-align:center;padding: 0px 0px 0px 0px;">
                        <span class="close" id="alertboxclose"
                              style="{width:30px;height:30px;text-align:right;color: #aaaaaa;float:right;font-size:28px;font-weight:bold;}
                            :hover,
                            :focus {color: #000;text-decoration: none;cursor: pointer;}"
                              onclick="alertboxclose();">&times;</span>
                    </td>
                </tr>
                <tr>
                    <td id="mymsgtitle" colspan="5" style="text-align:center;padding: 0px 0px 18px 0px;font-size:30px;">
                        <span id="alertboxtitle" style="text-align:center">MY-TITLE-HERE</span>
                    </td>
                </tr>
                <tr>
                    <td>
                        <img id="msgIcon" src="../Images/_question.png" alt="Success">
                    </td>
                    <td colspan="3" style="vertical-align: middle">
                        <span id="alertboxmsg" style="text-align:center">MY-MESSAGE-HERE</span>
                    </td>
                </tr>
                <tr>
                    <td colspan="2" style="vertical-align:left;text-align:center;padding: 40px 0px 0px 0px;font-size:15px;">
                        <span id="alertboxftr" style="text-align:center">MY-FOOTER-HERE</span>
                    </td>
                    <td style="text-align:right">
                        <input type="button" value="OK" class="k-button k-primary" onclick="modaldlgclick(1);" />&nbsp;
                        <input type="button" value="Cancel" class="k-button" onclick="modaldlgclick(0);" />&nbsp;
                    </td>
                </tr>
            </tbody>
        </table>
    </div>
</div>
<!-- #endregion -->

<script type="text/javascript">
// #region Main
$(document).ready(function () {
    $("#transactiongrid").kendoTooltip({
        filter: "td:nth-child(8)",
        position: "below",
        hideAfter: 500,
        content: function (e) {
            //debugger;
            var dataItem = $("#transactiongrid").data("kendoGrid").dataItem(e.target.closest("tr"));
            var content = dataItem.FileName;
            if ((content == "") || (content == null))
            { content = "(No File)"; }
            else
            { content = 'Download "' + content + '"'; }
            return '<div style="text-align:center;width: ' + content.length * .5 + 'em; max-width: 14em">' + content + '</div>';
        }
    }).data("kendoTooltip");
})
function openWindow(e) {
    e.preventDefault();

    var row = $(e.currentTarget).closest("tr");
    wnd.center().open();

    $("#yes").click(function () {
        grid.removeRow(row);
        wnd.close();
    });

    $("#no").click(function () {
        wnd.close();
    });
}
function data_error_handler(e) {
    if (e.errors) {
        var message = "Data Errors:\n";
        //ev.preventDefault();
        $.each(e.errors, function (key, value) {
            if ('errors' in value) {
                $.each(value.errors, function () {
                    message += this + "\n";
                });
            }
        });
        alertBox(3, message, '', 10000);
    }
}
function integerFilter(e) {
    e.kendoNumericTextBox({
        decimals: 0,
        format: "g"
    });
}
// #endregion

// #region Transaction Grid Events

var rowselected;
var transactionEdit = 0

function onTransactionChange(e) {
    //if (typeof rowselected != 'undefined') {
    //    $("#transactiongrid").data("kendoGrid").select(rowselected);
    //}
}
var gridEdit = null;
function onTransactionEdit(e) {
    debugger;
    gridEdit = e;
    console.log("Grid data Edit= " + (transactionEdit++));
    //rowselected = $(event.srcElement).closest("tr");
    var row = $(event.srcElement).closest("tr");
    var grid = $("#transactiongrid").data("kendoGrid");
    rowselected = row;
    grid.select(row);

    var datepickerinput = e.container.find("input[name=EntryDate]"); // get the input element for the field
    var datepicker = datepickerinput.data("kendoDatePicker");
    datepicker.enable(false); //disable the date picker
    if (e.model.isNew() && !e.model.dirty) {
        var tmp = e.container.find("input[name=TransactionType]"); // get the input element for the field
        tmp.val(2); // set the value
        tmp.change(); // trigger change in order to notify the model binding

        var tmp1 = e.container.find("input[name=AccountName]"); // get the input element for the field
        tmp1.val("BAC Treasury Acct. (KEEP-TS) - T35"); // set the value
        tmp1.change(); // trigger change in order to notify the model binding

        var today = new Date();
        var dd = String(today.getDate()).padStart(2, '0');
        var mm = String(today.getMonth() + 1).padStart(2, '0'); //January is 0!
        var yyyy = today.getFullYear();
        today = mm + '/' + dd + '/' + yyyy;
        datepickerinput.val(today); // set the value
        datepickerinput.change(); // trigger change in order to notify the model binding
        hideAll();
        hideTransactionId();
    }
    else {
        var id = e.container.find("input[name=Id]");
        callSetFilePrefix(id[0].value);
        var cat = $("#Category").data("kendoDropDownList");
        cat.value(e.model.CategoryId);
        cat.enable(false);
        refreshTransactionType(e.model.CategoryId);
        var planname = $("#PlanName").data("kendoDropDownList");
        planname.value(e.model.PlanName);

        var tt = $("#TransactionType").data("kendoDropDownList");
        tt.value(e.model.TransactionType);
        tt.enable(false);
        //var ttt = tt.data("kendoDropDownList");
        var txt = tt.text();
        showTransactionFields(e, txt);
        console.log("DD-Text=" + txt);
    }
    //$("#transactiongrid").data("kendoGrid").select(".k-grid-edit-row");

    //grid.select(row);
}

function onTransactionCancel(e) {
}
function onTransactionDataBound(e) {
    var grid = this;
    adjustButtonPreview(grid);
    //if (typeof rowselected != 'undefined') {
    //    $("#transactiongrid").data("kendoGrid").select(rowselected);
    //}

}
function onTransactionSaveChanges(e) {
    var tmp = e.container.find("input[name=TransactionType]"); // get the input element for the field
    console.log("TransactionType is " + tmp[0].value); // set the value
    e.model.TransactionType = tmp[0].value;
    e.model.TypeName = $("#TransactionType").data("kendoDropDownList").text();
    var tmp1 = e.container.find("input[name=Category]"); // get the input element for the field
    console.log("Category is " + tmp1[0].value); // set the value
    e.model.CategoryId = tmp1[0].value;
    if ( '@Session["UplodedFile"]' != '') {
        e.model.FileName = '@Session["UplodedFile"]';
    }
}

function onTransactionDetailCollapse(e) {
    var row = $(event.srcElement).closest("tr");
    var grid = $("#transactiongrid").data("kendoGrid");
    rowselected = row;
    grid.select(row);
}
function onTransactionDetailExpand(e) {
    var row = $(event.srcElement).closest("tr");
    var grid = $("#transactiongrid").data("kendoGrid");
    rowselected = row;
    grid.select(row);
}

function onTransactionSave(e) {
    console.log("Grid Save");
    var tmp2 = e.container.find("input[name=PlanName]"); // get the input element for the field
    console.log("PlanName is " + tmp2[0].value); // set the value
    e.model.PlanName= tmp2[0].value;
    e.model.TypePlanName = $("#PlanName").data("kendoDropDownList").text();
    var tmp = e.container.find("input[name=TransactionType]"); // get the input element for the field
    console.log("TransactionType is " + tmp[0].value); // set the value
    e.model.TransactionType = tmp[0].value;
    e.model.TypeName = $("#TransactionType").data("kendoDropDownList").text();
    var tmp1 = e.container.find("input[name=Category]"); // get the input element for the field
    console.log("Category is " + tmp1[0].value); // set the value
    e.model.CategoryId = tmp1[0].value;
    e.model.Category = $("#Category").data("kendoDropDownList").text();
    if ( '@Session["UplodedFile"]' != '') {
        e.model.FileName = '@Session["UplodedFile"]';
    }

    if (e.model.isNew()) {
        var datepickerinput = e.container.find("input[name=EntryDate]"); // get the input element for the field
        //var datepicker = datepickerinput.data("kendoDatePicker");
        console.log("datepickerinput=" + datepickerinput[0].value);
        e.model.EntryDate = datepickerinput[0].value;
        e.model.CreatedOn = new Date();
        e.model.CreatedById = '@Session["userId"]';
        e.model.Status = '@Session["Status_Pending"]';
        e.model.StatusName = 'Pending';
    }
    else {
        e.model.ModifiedOn = new Date();
        e.model.ModifiedById = '@Session["userId"]';
    }
    //if (typeof rowselected != 'undefined') {
    //    $("#transactiongrid").data("kendoGrid").select(rowselected);
    //}
}

function callSetFilePrefix(id) {
    var data = {};
    data.id = id;
    $.ajax({
        type: "POST",
        url: '@Url.Action("setFilePrefix", "TransUpload")',
        //url: "/TransUpload/setFilePrefix",
        data: JSON.stringify(data),
        contentType: "application/json",
        dataType: "json",
        cache: false
    }).done(function (response) {
        console.log('callSetFilePrefix= ' + response);
    }).fail(function (response) {
        console.log('Error: ' + 'callSetFilePrefix= ' + response);
    });
}

function addRowTransaction() {
    var userNo = '@Session["userNumber"]';
    callSetFilePrefix(userNo);
    var grid = $("#transactiongrid").data("kendoGrid");
    grid.addRow();
}

function adjustButtonPreview(grid) {
    grid.tbody.find("tr[role='row']").each(function () {
        var model = grid.dataItem(this);
        if (model.Status != '@Session["Status_Pending"]') {
            $(this).find(".k-grid-customCommand").removeClass("k-primary");
            $(this).find(".k-grid-customCommand").addClass("k-state-disabled");
            $(this).find(".k-grid-customCommand").addClass("k-btn-grayed");
            $(this).find(".k-grid-edit").removeClass("k-outline-primary");
            $(this).find(".k-grid-edit").addClass("k-state-disabled");
            $(this).find(".k-grid-edit").addClass("k-btn-grayed");
        } else {
            $(this).find(".k-grid-customCommand").addClass("k-primary ");
            $(this).find(".k-grid-edit").addClass("k-outline-primary");
        }
    });
}
// #endregion

// #region Upload Functions
function onUploadSelect(e) {
    console.log("Select :: " + getFileInfo(e));
}

function onUploadUpload(e) {
    console.log("Upload :: " + getFileInfo(e));
}

function onUploadSuccess(e) {
    //debugger;
    console.log("Success (" + e.operation + ") :: " + getFileInfo(e));

    var upload = $("#files").data("kendoUpload"),
        files = upload.getFiles();
    console.log("You have selected " + files.length + " files");
    console.log(files);

    var txtfilename = $('input[name="FileName"]');
    var myfileName = files.length > 0 ? files[0].name : '';
    txtfilename.val(myfileName);
    gridEdit.model.FileName = myfileName;
    gridEdit.model.dirty = true;
}

function onUploadError(e) {
    console.log("Error (" + e.operation + ") :: " + getFileInfo(e));
}

function onUploadComplete(e) {
    console.log("Complete");
}

function onUploadCancel(e) {
    console.log("Cancel :: " + getFileInfo(e));
}

function onUploadRemove(e) {
    console.log("Remove :: " + getFileInfo(e));
}

function onUploadProgress(e) {
    console.log("Upload progress :: " + e.percentComplete + "% :: " + getFileInfo(e));
}

function getFileInfo(e) {
    return $.map(e.files, function (file) {
        var info = file.name;
        if (file.size > (5 * 1024 * 1024)) {
            return false;
        }
        return true;//info;
    });
}
// #endregion

// #region Dropdown Events
function onDDTransactionTypeChange(e) {
    if (e.item) {
        var dataItem = this.dataItem(e.item);
        //if ( dataItem.Text
        console.log("event :: Change (" + dataItem.Text + " : " + dataItem.Value + ")");
    } else {
        console.log("event :: Change");
    }
}
function onDDTransactionTypeSelect(e) {
    if (e.item) {
        var txt = e.item[0].innerText;
        console.log("Selected Text = " + txt);
        console.log(txt.indexOf("issuance") < 0);
        showTransactionFields(e, txt);
    } else {
        console.log("event :: select");
    }
}
function onChangeCategory(e) {
    var catval = $("#Category").data("kendoDropDownList").value();
    refreshTransactionType(catval);
}
function refreshTransactionType(categoryValue) {
    var tt = $("#TransactionType").data("kendoDropDownList");
    var ttData = tt.dataSource;
    ttData.data([]); tt.text(""); tt.value(""); hideAll();

    var ttList = '@Session["StrTransactionTypeList"]';
    var ttListAr = ttList.split('|');
    for (var i = 0; i < ttListAr.length; i++) {
        var ttListArItem = ttListAr[i].split('^');
        if (ttListArItem[0] == categoryValue) {
            ttData.add({ "Id": ttListArItem[1], "Name": ttListArItem[2] });
        }
    }
}
// #endregion

// #region Show/Hide Transaction Fields
function showTransactionFields(e, txt) {
    hideAll();
    var effectiveDate = gridEdit.container.find("label[for=TransactionEffectiveDate]");
    effectiveDate[0].innerText = 'Effective Date';
    if (txt.toLowerCase().indexOf("issuance") > 0) {
        showFieldsByClass("issuance");
    }
    else if (txt.toLowerCase().indexOf("release") > 0) {
        showFieldsByClass("release");
    }
    else if (txt.toLowerCase() == "annuity") {
        showFieldsByClass("annuity");
    }
    else if (txt.toLowerCase().indexOf("grant") > 0) {
        showFieldsByClass("Grant");
    }
    else if (txt.toLowerCase().indexOf("vesting") > 0) {
        showFieldsByClass("Vesting");
    }
    else if (txt.toLowerCase().indexOf("treasury") > 0) {
        showFieldsByClass("Treasury");
    }
    else if (txt.toLowerCase().indexOf("repurchase") > 0) {
        showFieldsByClass("Repurchase");
        effectiveDate[0].innerText = 'Settlement Date';
    }

}
function showFieldsByClass(className) {
    var i; var x = null;
    x = document.getElementsByClassName(className);
    for (i = 0; i < x.length; i++) {
        x[i].style.display = "";
    }
}
function hideFieldsByClass(className) {
    var i; var x = null;
    x = document.getElementsByClassName(className);
    for (i = 0; i < x.length; i++) {
        x[i].style.display = "none";
    }
}
function hideAll() {
    hideFieldsByClass("issuance");
    hideFieldsByClass("release");
    hideFieldsByClass("annuity");
    hideFieldsByClass("Grant");
    hideFieldsByClass("Vesting");
    hideFieldsByClass("Treasury");
    hideFieldsByClass("Repurchase");
}
function hideTransactionId() {
    hideFieldsByClass("TransactionId");
}
// #endregion

// #region Show Preview Letter & Send Email
function showPreview(e) {
    e.preventDefault();

    var row = $(event.srcElement).closest("tr");
    var grid = $("#transactiongrid").getKendoGrid();
    console.log(row);
    grid.select(row);

    var dataItem = grid.dataItem(row);
    console.log("TransactionId: " + dataItem.Id);

    grid.tbody.find("tr[role='row']")
    rowselected = row;

    var data = {};
    data.TransactionId = dataItem.Id;
    $.ajax({
        type: "POST",
        url: '@Url.Action("GetPreviewLetter", "Transaction")',
        data: JSON.stringify(data),
        contentType: "application/json",
        dataType: "json",
        cache: false
    }).done(function (data) {
        console.log('data= ' + data);
        var wnd = $("#windowPreview").data("kendoWindow");
        wnd.content(data);
        wnd.center().open();
    }).fail(function (data) {
        console.log('Error-GetPreviewLetter: ' + data);
    });
}

var emailLetterFunc = function emailLetter() {
    $.ajax({
        type: "POST",
        url: '@Url.Action("SendMail", "Transaction")',
        cache: false
    }).done(function (data) {
        console.log('data= ' + data);
        if (!data.toLowerCase().includes("error") && !data.toLowerCase().includes("failure")) {
            if (data.toLowerCase().includes("already emailed")) {
                $("#windowPreview").data("kendoWindow").close();
                alertBox(2, data, '', 7000);
            }
            else {
                $("#windowPreview").data("kendoWindow").close();
                $("#transactiongrid").data("kendoGrid").dataSource.read();
                $("#transactiongrid").data("kendoGrid").dataSource.sync();
                alertBox(0, "Letter emailed !", '', 8000);
            }
        }
        else {
            $("#windowPreview").data("kendoWindow").close();
            alertBox(2, "Sending Letter Error !\n" + data, '', 12000);
        }
    }).fail(function (data) {
        console.log('Error Connecting Send Email: \n' + data);
    });
}
function cancelemailLetter() {
    $("#windowPreview").data("kendoWindow").close();
}
function onWindowClose() {
    console.log("Popup Window Closed");
}

function emailLetterconfirm() {

    alertboxmodal("Are You Sure Want to Send Email to ComputerShare?"  //message
        , "Sending Email to ComputerShare"  //title
        , "Equity Management"  //footer
        , emailLetterFunc);    //callback function for OK

}
// #endregion

// #region Custom Validation Rules
(function ($, kendo) {
    $.extend(true, kendo.ui.validator, {
        rules: {
            requiredif: function (input) {
                var tmp = input[0].attributes["data-val-requiredif"];
                if (typeof tmp != 'undefined') {
                    var requiredifExists = input[0].attributes["data-val-requiredif"].value;
                    var requirediffield = input[0].attributes["data-val-requiredif-field"].value;
                    var requiredifvalues = input[0].attributes["data-val-requiredif-values"].value;
                    var v = $("input[name=" + requirediffield + "]")[0].value
                    var requiredifvaluesArray = requiredifvalues.split('|');
                    var match = false;
                    for (var i = 0; i < requiredifvaluesArray.length; i++) {
                        if (requiredifvaluesArray[i] == v) {
                            match = true;
                            break;
                        }
                    }
                    if (match) {
                        if ((input[0].value == '') || (input[0].value == null)) {
                            return false;
                        }
                    }
                }
                return true;
            }
        },
        messages: {
            requiredif: function (input) {
                return input[0].attributes["data-val-requiredif"].value;
            }
        }
    });
})(jQuery, kendo);
// #endregion

// #region AlertBox
//to Start the Alert Box, Selecting Mode(Success(Default=any value), Warning=2, Error=3, Info=4),
//Set Message, Title, Position and Show/Animate the Box
function alertBox(action, msg, title, alerttime) {
    var scroll_pos = (0);
    var scrollTop = 0;
    $('html, body').animate({ scrollTop: (scroll_pos) }, '2000');
    switch (action) {
        case 2://warn
            $("#msgIcon")[0].src = "../Images/_warn.png"
            $("#msg").css({ background: '#fae780', color: 'Black', border: '4px #4b4002' });
            if (title == '') { title = 'Warning'; }
            alertBoxMsg(msg, title, alerttime);
            break;
        case 3://error
            $("#msgIcon")[0].src = "../Images/_error.png"
            $("#msg").css({ background: '#f75656', color: 'Black', border: '4px #680707' });
            if (title == '') { title = 'Error'; }
            alertBoxMsg(msg, title, alerttime);
            break;
        case 4://info
            $("#msgIcon")[0].src = "../Images/_info.png"
            $("#msg").css({ background: '#35f9f9', color: 'Black', border: '4px #055e5f' });
            if (title == '') { title = 'Information'; }
            alertBoxMsg(msg, title, alerttime);
            break;
        default://success
            $("#msgIcon")[0].src = "../Images/_success.png"
            $("#msg").css({ background: '#0d005d', color: 'white', border: '4px black' });
            if (title == '') { title = 'Success'; }
            alertBoxMsg(msg, title, alerttime);
    }
}

function alertBoxShow(msg, mytime) {
    alertBoxPos();
    var ret = setwidth(msg);
    $("#msg").animate({ top: '30px', width: ret + '%', left: (98 - ret) + '%' });
    setTimeout(() => {
        $("#msg").animate({ top: '-50%' });
        setTimeout(() => { $("#msg").css({ visibility: 'hidden' }); }, 500);
    }, mytime);
}
//to Initiate the Alert Box Position, start mode
function alertBoxPos() {
    $("#msg").css({ top: '30px', left: '105%' });
    $("#msg").css({ visibility: 'visible' });
}
//to Set the Alert Box Message and Title, then Show the Box
function alertBoxMsg(msg, title, mytime) {
    $("#mymsg").text(msg);
    $("#mymsgtitle").text(title);
    setwidth(msg);
    alertBoxShow(msg, mytime);
}
function setwidth(msg) {
    var val = msg.length;
    var ret = 30;
    if ((200 <= val) && (val < 500)) { ret = 60; }
    else {
        if (500 <= val) { ret = 90; }
    }
    return ret;
}
// #endregion

// #region AlertBox Modal
var ModalDlgState = -1;
var modal = document.getElementById("alertboxmodal");
function alertboxclose() {
    modaldlgclick(0);
}
function modaldlgclick(ModalDlgValue) {
    ModalDlgState = ModalDlgValue;
    closeModal();
}
function closeModal() {
    modal.style.display = "none";
}
function alertboxmodalinit(msg, title, footer) {
    var alertboxtitle = document.getElementById("alertboxtitle");
    alertboxtitle.innerText = title;
    var alertboxmsg = document.getElementById("alertboxmsg");
    alertboxmsg.innerText = msg;
    var alertboxftr = document.getElementById("alertboxftr");
    alertboxftr.innerText = footer;

    ModalDlgState = -1;
    modal.style.display = "block";
}
var waitfunc = null;
var wait = function (condFunc, readyFunc, checkInterval) {
    var checkFunc = function () {
        if (condFunc()) {
            readyFunc();
        }
        else {
            waitfunc = setTimeout(checkFunc, checkInterval);
        }
    };
    checkFunc();
};
function alertboxmodal(msg, ttl, ftr, OKFunction, CancelFunction) {
    alertboxmodalinit(msg, ttl, ftr);
    wait(
        function () { return ((ModalDlgState >= 0) || (new Date().getSeconds() == 10)); },
        function () {
            clearTimeout(waitfunc);
            console.log("Done");
            if (ModalDlgState > 0) {
                if (typeof OKFunction != 'undefined') {
                    OKFunction();
                }
            }
            else {
                if (typeof CancelFunction != 'undefined') {
                    CancelFunction();
                }
            }
        },
        100
    );
    return ModalDlgState;
}
// #endregion

// #region Custom Delete Transaction
var rowToDelete = null;
function deleteTransaction() {
    var row = $(event.srcElement).closest("tr");
    var grid = $("#transactiongrid").data("kendoGrid");
    rowselected = row;
    grid.select(row);
    $("#transactiongrid").data("kendoGrid").removeRow(rowToDelete); // remove the row
}

function deleteTransactionconfirm(e) {

    var dataItem = $("#transactiongrid").data("kendoGrid").dataSource.get(e);
    rowToDelete = $("#transactiongrid").data("kendoGrid").tbody.find("tr[data-uid='" + dataItem.uid + "']");
    alertboxmodal("Are You Sure You Want to DELETE the Selected Transaction?"  //message
        , "DELETE the Transaction"  //title
        , "Equity Management"  //footer
        , deleteTransaction);    //callback function for OK
}
// #endregion
//////////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////// Download Attachment File
//////////////////////////////////////////////////////////////////////////////////////////////////
function downloadFile(id) {
    debugger;
    var mypath='@Url.Action("GetFile", "Transaction")' + "?Id=" + id;
    window.location = mypath;
}
//////////////////////////////////////////////////////////////////////////////////////////////////
function onChangeNumericNegative() {
        debugger;
        var value = this.value();
        if (value > 0) {
            value = -1 * value;
            this._old = this._value;
            this._value = value;
            this._text.val(this._value);
            this.element.val(this._value);
            gridEdit.model.set(this.element[0].id, value);
        }
}

farzinmonsef commented 4 years ago

Setting Color Grid Selected Row

grid > table > tbody > tr.k-state-selected >td {

color:yellow;
background-color:blue;
text-decoration: underline;
text-decoration-color: red;

}

https://dojo.telerik.com/IFejITAV

change: function(e){
$("tr.k-state-selected").hover(function(){ $(this).find("td").css("color", "red") }) $("tr.k-state-selected").mouseleave(function(){ $(this).find("td").css("color", "black") }) },

grid > table > tbody > tr.k-state-selected > td:hover {

    color:red;

}

grid > table > tbody > tr.k-state-selected >td {

color:yellow;
background-color:blue;
text-decoration: underline;
text-decoration-color: red;

}

farzinmonsef commented 4 years ago

UploadFileData.cs

using System; using System.Configuration; using System.Data; using System.Data.SqlClient; using System.IO; using System.Text; using System.Web;

namespace Data { public class UploadFileData { public char delimiterFile { get; set; } = '`'; //Method to put file into database from drive: public void databaseFilePut(string varFilePath, int LinkId, int Action, string tabelName, string dataFieldName, string fileFieldName, string idFieldName)//Action: (0=Add, 1=UPDATE) { byte[] file; var justFile = varFilePath.ToString().Split(delimiterFile); using (var stream = new FileStream(varFilePath, FileMode.Open, FileAccess.Read)) { using (var reader = new BinaryReader(stream)) { file = reader.ReadBytes((int)stream.Length); } } string connectionString = ConfigurationManager.ConnectionStrings["EQM"].ConnectionString; using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); if (Action == 0) {//ADD

                //string sql = "INSERT INTO [eqmuser].[Transaction] (Attachments, TransactionId, fileName) Values(@File, @TransactionId, @fileName)";
                string sql = "INSERT INTO " + tabelName + " (" + dataFieldName + ",  " + idFieldName + "," + fileFieldName + ") Values(@File, @TransactionId, @fileName)";
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;
                    command.Parameters.Add("@TransactionId", SqlDbType.Int).Value = LinkId;
                    command.Parameters.Add("@fileName", SqlDbType.VarChar, justFile[1].Length).Value = justFile[1];
                    command.ExecuteNonQuery();
                }
            }
            else
            {//update
                //string sql = "Update [eqmuser].[Transaction] set Attachments=@File, fileName=@fileName Where Id=@TransactionId";
                string sql = "Update " + tabelName + " set " + dataFieldName + "=@File, " + fileFieldName + "=@fileName Where  " + idFieldName + "=@TransactionId";
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;
                    command.Parameters.Add("@TransactionId", SqlDbType.Int).Value = LinkId;
                    command.Parameters.Add("@fileName", SqlDbType.VarChar, justFile[1].Length).Value = justFile[1];
                    command.ExecuteNonQuery();
                }
            }
        }
    }
    //This method is to get file from database and save it on drive:
    public void databaseFileRead(string varID, string varPathToNewLocation, string tabelName, string dataFieldName, string idFieldName)
    {

        string connectionString = ConfigurationManager.ConnectionStrings["EQM"].ConnectionString;
        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            connection.Open();
            //string sql = @"SELECT [Attachments] FROM [EQMUser].[Transaction] WHERE [AttachmentId] = @varID";
            string sql = @"SELECT " + dataFieldName + " FROM " + tabelName + " WHERE " + idFieldName + " = @varID";
            using (SqlCommand sqlQuery = new SqlCommand(sql, connection))
            {
                sqlQuery.Parameters.AddWithValue("@varID", varID);
                using (var sqlQueryResult = sqlQuery.ExecuteReader())
                    if (sqlQueryResult != null)
                    {
                        sqlQueryResult.Read();
                        var blob = new Byte[(sqlQueryResult.GetBytes(0, 0, null, 0, int.MaxValue))];
                        sqlQueryResult.GetBytes(0, 0, blob, 0, blob.Length);
                        using (var fs = new FileStream(varPathToNewLocation, FileMode.Create, FileAccess.Write))
                            fs.Write(blob, 0, blob.Length);
                    }
            }
        }
    }
    //This method is to get file from database and put it as MemoryStream
    //public MemoryStream databaseFileReadArray(string varID, string tabelName, string dataFieldName, string idFieldName)
    public byte[] databaseFileReadArray(string varID, string tabelName, string dataFieldName, string idFieldName)
    {

        MemoryStream memoryStream = new MemoryStream();

        //string result = "";
        byte[] blob = new byte[] { };
        try
        {
            string connectionString = ConfigurationManager.ConnectionStrings["EQM"].ConnectionString;
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();
                //string sql = @"SELECT [Attachments] FROM [EQMUser].[Transaction] WHERE [AttachmentId] = @varID";
                string sql = @"SELECT " + dataFieldName + " FROM " + tabelName + " WHERE " + idFieldName + " = @varID";
                using (SqlCommand sqlQuery = new SqlCommand(sql, connection))
                {
                    sqlQuery.Parameters.AddWithValue("@varID", varID);
                    using (var sqlQueryResult = sqlQuery.ExecuteReader())
                        if (sqlQueryResult != null)
                        {
                            sqlQueryResult.Read();
                            blob = new Byte[(sqlQueryResult.GetBytes(0, 0, null, 0, int.MaxValue))];
                            sqlQueryResult.GetBytes(0, 0, blob, 0, blob.Length);
                            //using (var fs = new MemoryStream(memoryStream, FileMode.Create, FileAccess.Write)) {
                            //memoryStream.Write(blob, 0, blob.Length);
                            //}

                            //result = Encoding.UTF8.GetString(blob, 0, blob.Length);
                        }
                }
                //return memoryStream;
                //string result = memoryStream.ReadToEnd();
            }
        }
        catch (Exception ex)
        {
            //result = "ERROR: " + ex.ToString();
            //throw ex;
        }
        return blob;
    }
    //This method is to put MemoryStream into database:
    public int databaseFilePut(MemoryStream fileToPut, string tabelName, string dataFieldName, string idFieldName)
    {
        int varID = 0;
        byte[] file = fileToPut.ToArray();
        string preparedCommand =
               "INSERT INTO " + tabelName + " (" + dataFieldName + ") VALUES (@File) "
               + " SELECT " + idFieldName + " FROM " + tabelName + " WHERE " + idFieldName + " = SCOPE_IDENTITY()";
        //@"INSERT INTO [EQMUser].[Transaction] ([Attachments]) VALUES (@File)
        // SELECT [AttachmentId] FROM [EQMUser].[Transaction] WHERE [AttachmentId] = SCOPE_IDENTITY()";
        string connectionString = ConfigurationManager.ConnectionStrings["EQM"].ConnectionString;
        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            connection.Open();
            using (SqlCommand sqlWrite = new SqlCommand(preparedCommand, connection))
            {
                sqlWrite.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;

                using (var sqlWriteQuery = sqlWrite.ExecuteReader())
                    while (sqlWriteQuery != null && sqlWriteQuery.Read())
                    {
                        varID = sqlWriteQuery["AttachmentId"] is int ? (int)sqlWriteQuery["AttachmentId"] : 0;
                    }
            }
            return varID;
        }

    }
}

}

farzinmonsef commented 4 years ago

TransUploadController.cs

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc;

using System.IO; using EQM.Helper;

namespace EQM.Controllers { public class TransUploadController : BaseController { [OutputCache(NoStore = true, Duration = 0, VaryByParam = "*")] [HttpPost] public void setFilePrefix(string id) { Tools.filePrefix = Convert.ToString(id) + Tools.delimiterFile; Session["UplodedFile"] = ""; }

    public ActionResult Async()
    {
        return View();
    }

    public ActionResult Async_Save(IEnumerable<HttpPostedFileBase> files)
    {
        if (files != null)
        {
            foreach (var file in files)
            {
                var fileName = Path.GetFileName(file.FileName);
                var physicalPath = Path.Combine(Server.MapPath("~/App_Data"), Tools.filePrefix + fileName);

                if (System.IO.File.Exists(physicalPath)) {
                    System.IO.File.Delete(physicalPath);
                }
                file.SaveAs(physicalPath);
                Session["UplodedFile"] = fileName;
                //fileDB.databaseFilePut(physicalPath, 3, 1);
            }
        }
        return Content("");
    }

    public ActionResult Async_Remove(string[] fileNames)
    {
        if (fileNames != null)
        {
            foreach (var fullName in fileNames)
            {
                var fileName = Path.GetFileName(fullName);
                var physicalPath = Path.Combine(Server.MapPath("~/App_Data"), Tools.filePrefix + fileName);
                if (System.IO.File.Exists(physicalPath))
                {
                    System.IO.File.Delete(physicalPath);
                }
                Session["UplodedFile"] = "";
            }
        }
        return Content("");
    }
}

}

farzinmonsef commented 4 years ago

BusUploadFile.cs

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using Data; using Entitites; using EQM.Enumerations;

namespace Business { public class BusUploadFile { ///

/// Gets all Transactions if the user is an Administrator.
/// Otherwise, filter the category by their role. ///
/// Transaction Entities public void databaseFilePut(string varFilePath, int LinkId, int Action, string tabelName, string dataFieldName, string fileFieldName, string idFieldName)//Action: (0=Add, 1=UPDATE) { UploadFileData uploadFileData = new UploadFileData(); uploadFileData.databaseFilePut(varFilePath, LinkId, Action, tabelName, dataFieldName, fileFieldName, idFieldName);//Action: (0=Add, 1=UPDATE) } public void databaseFileRead(string varID, string varPathToNewLocation, string tabelName, string dataFieldName, string idFieldName) { UploadFileData uploadFileData = new UploadFileData(); uploadFileData.databaseFileRead(varID, varPathToNewLocation, tabelName, dataFieldName, idFieldName); //(string varID, string tabelName, string dataFieldName, string idFieldName) } } }