Open farzinmonsef opened 4 years ago
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . 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
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 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;
}
}
}
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;
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);
}
}
}
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);
}
}
}
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 | ||||
[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()'> " +
"</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);
}
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
[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; }
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . } }
@using Entitites @using EQM.Enumerations; @{ViewBag.Title = "Transactions"; }
@*
<br />
<input type="button" value="download" onclick="testDownload( 163 );" />*@
<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> [To]</td></tr>
<tr><td colspan="5"><b>From:</b> [From]</td></tr>
<tr><td colspan="5"> </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">♦ Requisition Number: [RequisitionNumber]</td></tr>
<tr><td></td><td colspan="3">♦ Effective Date: [TransactionEffectiveDate]</td></tr>
<tr><td></td><td colspan="3">♦ Debit: [ReserveName]</td></tr>
<tr><td></td><td colspan="3">♦ Debit Shares: [TotalVestedShares]</td></tr>
<tr><td></td><td colspan="3">♦ Credit: Restricted Stock Account for Stock Plan Participants </td></tr>
<tr><td></td><td colspan="3">♦ Credit Shares: [TotalVestedShares]</td></tr>
<tr><td colspan="5"> </td></tr>
<tr><td colspan="4"> </td></tr>
<tr><td colspan="5">Approved By: [Approved]</td></tr>
<tr><td colspan="5">Corporate Title: [CorporateTitle]</td></tr>
<tr><td colspan="5"> </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"> </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> </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()">
</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();">×</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);" />
<input type="button" value="Cancel" class="k-button" onclick="modaldlgclick(0);" />
</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);
}
}
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")
})
},
color:red;
}
color:yellow;
background-color:blue;
text-decoration: underline;
text-decoration-color: red;
}
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;
}
}
}
}
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("");
}
}
}
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
{
///
/// Otherwise, filter the category by their role.
///
RequiredIf,