modifications made for duplicate data in checkout

This commit is contained in:
2023-03-15 15:01:21 +05:30
bovenliggende 687974a238
commit ceac275279
@@ -33,9 +33,7 @@ namespace CRM.Visitors.ActionProviders
{ {
return "FeedBack"; return "FeedBack";
} }
}/// <summary> }
/// test 123
/// </summary>
public string Description public string Description
{ {
get get
@@ -81,59 +79,55 @@ namespace CRM.Visitors.ActionProviders
var code = Convert.ChangeType(req["uniqueid"].ToString(), typeof(object)).ToString(); var code = Convert.ChangeType(req["uniqueid"].ToString(), typeof(object)).ToString();
var feedBackJson = Convert.ChangeType(req["feedbackrating"].ToString(), typeof(object)).ToString(); var feedBackJson = Convert.ChangeType(req["feedbackrating"].ToString(), typeof(object)).ToString();
var feedBackObj = JsonSerializer.Deserialize<Request.VisitorRequest>(feedBackJson); var feedBackObj = JsonSerializer.Deserialize<Request.VisitorRequest>(feedBackJson);
List<Unibase.Platform.Forms.Requests.DocParameter> docParameters = dictObj["DocParameters"];
var checkinfo = docParameters.Find(x => x.DocType == "bizgazecrm_visitorcheckout");
var visitorcheckoutId= checkinfo.Parameters["visitorcheckoutid"].ToString();
var comments = feedBackObj.Comments; var comments = feedBackObj.Comments;
var rating = feedBackObj.Rating; var rating = feedBackObj.Rating;
var visitorInfo = await visitorManager.GetpreVisitorsAsync(srequest, code); var visitorInfo = await visitorManager.GetpreVisitorsAsync(srequest, code);
if (visitorInfo != null)
if (visitorInfo.Result != null)
{ {
var visitorId = Convert.ToInt64(visitorInfo.Result.VisitorId); var visitorId = Convert.ToInt64(visitorInfo.Result.VisitorId);
var sql = new Unibase.Data.Sql.Select("bizgazecrm_visitors").Columns("bizgazecrm_visitors.installedappid", "bizgazecrm_visitors.fullname", "bizgazecrm_visitors.mobilenumber", "bizgazecrm_visitors.emailid", "bizgazecrm_visitors.photourl", "unibase_stagestatus.stageStatusName", "unibase_stagestatus.RefStatusId").InnerJoin("unibase_stages", Exp.EqColumns("unibase_stages.stageid", "bizgazecrm_visitors.stageid")).InnerJoin("unibase_stagestatus", Exp.EqColumns("unibase_stagestatus.stagestatusid", "unibase_stages.stagestatusid")).Where("bizgazecrm_visitors.visitorid", visitorId); var stageStatusName = "CheckOut";
List<Parameter> param = new List<Parameter>(); var installedAppId = Convert.ToInt64(visitorInfo.Result.Installedappid);
param.Add(new Parameter("@bizgazecrm_visitors.visitorid", visitorId));
var dt = await GetDataTableAsync(srequest, sql, param);
var stageStatusName = "";
if (dt.Rows.Count > 0)
{
stageStatusName = "CheckOut";
for (int i = 0; i < dt.Rows.Count; i++)
{
var installedAppId = Convert.ToInt64(dt.Rows[i]["installedAppId"]);
var stage = await stageManager.GetStageByStageStatusAsync(srequest, installedAppId, stageStatusName); var stage = await stageManager.GetStageByStageStatusAsync(srequest, installedAppId, stageStatusName);
var NewStageId = stage.Result.StageId; var NewStageId = stage.Result.StageId;
var UpdateStage = new Update("bizgazecrm_visitors").Value("stageid", NewStageId).Where(Exp.Eq("visitorId", visitorId)); var UpdateStage = new Update("bizgazecrm_visitors").Value("stageid", NewStageId).Where(Exp.Eq("visitorId", visitorId));
await _repository.ExecuteAsync(request, UpdateStage); await _repository.ExecuteAsync(request, UpdateStage);
} var vistoroptions = new EntityOptions()
var options = new EntityOptions()
{ {
IsIdentity = true, IsIdentity = false,
IsNewEntity = true, IsNewEntity = false,
TableName = "bizgazecrm_visitorcheckout", TableName = "bizgazecrm_visitorcheckout",
PkColumn = "visitorcheckoutid", PkColumn = "visitorcheckoutid",
IsExcludeFromAudit = false, IsExcludeFromAudit = false,
Id = 0, Id =Convert.ToInt64(visitorcheckoutId),
}; };
dynamic visitor = new Dictionary<string, object>(); dynamic visitor = new Dictionary<string, object>();
visitor.Add("visitorcheckoutid", Convert.ToInt64(visitorcheckoutId));
visitor.Add("createdby", srequest.Identity.UserId); visitor.Add("createdby", srequest.Identity.UserId);
visitor.Add("createddate", DateTime.Now); visitor.Add("createddate", DateTime.Now);
visitor.Add("checkoutdate", DateTime.Now); visitor.Add("checkoutdate", DateTime.Now);
visitor.Add("checkindate", visitorInfo.Result.CheckInDate);
visitor.Add("comments", comments); visitor.Add("comments", comments);
visitor.Add("rating", Convert.ToInt32(rating)); visitor.Add("rating", Convert.ToInt32(rating));
visitor.Add("versionguid", Guid.NewGuid()); visitor.Add("versionguid", Guid.NewGuid());
visitor.Add("uniqueid", code); visitor.Add("uniqueid", code);
visitor.Add("statusid", (int)RowStatus.Active); visitor.Add("statusid", (int)RowStatus.Active);
visitor.Add("installedappid", visitorInfo.Result.Installedappid); visitor.Add("installedappid", visitorInfo.Result.Installedappid);
visitor.Add("visitorid", visitorInfo.Result.VisitorId); visitor.Add("visitorid", visitorId);
var responses = await _repository.SaveAsync(request, options, visitor); var responses = await _repository.SaveAsync(request, vistoroptions, visitor);
if (responses.Status == ResponseStatus.Error) if (responses.Status == ResponseStatus.Error)
{ {
if (requestTrans.StartedLocal) await request.RollbackTransactionAsync(); if (requestTrans.StartedLocal) await request.RollbackTransactionAsync();
return ActionResponse<FormActionResponse>.CreateErrorResponse("1", "Visitor Check Out Data Not Saved"); return ActionResponse<FormActionResponse>.CreateErrorResponse("1", "Visitor Check Out Data Not Saved");
} }
}
} }
var returnresponse = new FormActionResponse(); var returnresponse = new FormActionResponse();
returnresponse.Obj = dictObj as ExpandoObject; returnresponse.Obj = null;
returnresponse.PkValue = defaultPKValue; returnresponse.PkValue = 0;
return ActionResponse<FormActionResponse>.CreateSuccessResponse("success", returnresponse); return ActionResponse<FormActionResponse>.CreateSuccessResponse("success", returnresponse);
} }
} }