public ActionResult Delete(PolicyHotelOtherGroupItemDataTableItemVM policyHotelOtherGroupItemDataTableItemVM)
        {
            //Check PolicyHotelOtherGroupItemDataTableRow Exists
            PolicyHotelOtherGroupItemDataTableRow policyHotelOtherGroupItemDataTableRow = new PolicyHotelOtherGroupItemDataTableRow();

            policyHotelOtherGroupItemDataTableRow = policyHotelOtherGroupItemDataTableRowRepository.GetPolicyHotelOtherGroupItemDataTableRow(
                policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableRow.PolicyHotelOtherGroupItemDataTableRowId
                );
            if (policyHotelOtherGroupItemDataTableRow == null)
            {
                ViewData["ActionMethod"] = "DeletePost";
                return(View("RecordDoesNotExistError"));
            }

            //Check Policy Exists
            PolicyGroup policyGroup = new PolicyGroup();

            policyGroup = policyGroupRepository.GetGroup(policyHotelOtherGroupItemDataTableItemVM.PolicyGroup.PolicyGroupId);
            if (policyGroup == null)
            {
                ViewData["ActionMethod"] = "DeletePost";
                return(View("RecordDoesNotExistError"));
            }

            //Check PolicyOtherGroupHeader Exists
            PolicyOtherGroupHeader policyOtherGroupHeader = new PolicyOtherGroupHeader();

            policyOtherGroupHeader = policyOtherGroupHeaderRepository.GetPolicyOtherGroupHeader(
                policyHotelOtherGroupItemDataTableItemVM.PolicyOtherGroupHeader.PolicyOtherGroupHeaderId
                );
            if (policyOtherGroupHeader == null)
            {
                ViewData["ActionMethod"] = "DeletePost";
                return(View("RecordDoesNotExistError"));
            }

            //Delete Form Item
            try
            {
                policyHotelOtherGroupItemDataTableItemRepository.Delete(policyHotelOtherGroupItemDataTableRow);
            }
            catch (SqlException ex)
            {
                //Versioning Error - go to standard versionError page
                if (ex.Message == "SQLVersioningError")
                {
                    ViewData["ReturnURL"] = "/PolicyHotelOtherGroupItemDataTableItem.mvc/Delete/" + policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableRow.PolicyHotelOtherGroupItemDataTableRowId;
                    return(View("VersionError"));
                }

                LogRepository logRepository = new LogRepository();
                logRepository.LogError(ex.Message);

                ViewData["Message"] = "There was a problem with your request, please see the log file or contact an administrator for details";
                return(View("Error"));
            }
            return(RedirectToAction("List", new { id = policyHotelOtherGroupItemDataTableItemVM.PolicyOtherGroupHeader.PolicyOtherGroupHeaderId, policyGroupId = policyHotelOtherGroupItemDataTableItemVM.PolicyGroup.PolicyGroupId }));
        }
        //Edit
        public void Edit(PolicyHotelOtherGroupItemDataTableItemVM policyHotelOtherGroupItemDataTableItemVM)
        {
            string adminUserGuid = HttpContext.Current.User.Identity.Name.Split(new[] { '|' })[0];

            XmlDocument doc = ConvertPolicyHotelOtherGroupItemDataTableItemsToXML(policyHotelOtherGroupItemDataTableItemVM);

            db.spDesktopDataAdmin_UpdatePolicyHotelOtherGroupItemDataTableItem_v1(
                policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableRow.PolicyHotelOtherGroupItemDataTableRowId,
                System.Xml.Linq.XElement.Parse(doc.OuterXml),
                adminUserGuid,
                policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableRow.VersionNumber
                );
        }
        //Add
        public void Add(PolicyHotelOtherGroupItemDataTableItemVM policyHotelOtherGroupItemDataTableItemVM)
        {
            string adminUserGuid = HttpContext.Current.User.Identity.Name.Split(new[] { '|' })[0];

            XmlDocument doc = ConvertPolicyHotelOtherGroupItemDataTableItemsToXML(policyHotelOtherGroupItemDataTableItemVM);

            db.spDesktopDataAdmin_InsertPolicyHotelOtherGroupItemDataTableItem_v1(
                policyHotelOtherGroupItemDataTableItemVM.PolicyGroup.PolicyGroupId,
                policyHotelOtherGroupItemDataTableItemVM.PolicyOtherGroupHeader.PolicyOtherGroupHeaderId,
                System.Xml.Linq.XElement.Parse(doc.OuterXml),
                adminUserGuid
                );
        }
        public ActionResult Delete(int id, int policyGroupId, int policyOtherGroupHeaderId)
        {
            PolicyHotelOtherGroupItemDataTableItemVM policyHotelOtherGroupItemDataTableItemVM = new PolicyHotelOtherGroupItemDataTableItemVM();

            //Check PolicyHotelOtherGroupItemDataTableRow Exists
            PolicyHotelOtherGroupItemDataTableRow policyHotelOtherGroupItemDataTableRow = new PolicyHotelOtherGroupItemDataTableRow();

            policyHotelOtherGroupItemDataTableRow = policyHotelOtherGroupItemDataTableRowRepository.GetPolicyHotelOtherGroupItemDataTableRow(id);
            if (policyHotelOtherGroupItemDataTableRow == null)
            {
                ViewData["ActionMethod"] = "EditGet";
                return(View("RecordDoesNotExistError"));
            }

            //Check Policy Exists
            PolicyGroup policyGroup = new PolicyGroup();

            policyGroup = policyGroupRepository.GetGroup(policyGroupId);
            if (policyGroup == null)
            {
                ViewData["ActionMethod"] = "EditGet";
                return(View("RecordDoesNotExistError"));
            }

            //Check PolicyOtherGroupHeader Exists
            PolicyOtherGroupHeader policyOtherGroupHeader = new PolicyOtherGroupHeader();

            policyOtherGroupHeader = policyOtherGroupHeaderRepository.GetPolicyOtherGroupHeader(policyOtherGroupHeaderId);
            if (policyOtherGroupHeader == null)
            {
                ViewData["ActionMethod"] = "EditGet";
                return(View("RecordDoesNotExistError"));
            }

            policyHotelOtherGroupItemDataTableItemVM.PolicyOtherGroupHeader = policyOtherGroupHeader;
            policyGroupRepository.EditGroupForDisplay(policyGroup);
            policyHotelOtherGroupItemDataTableItemVM.PolicyGroup = policyGroup;

            policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableRow = policyHotelOtherGroupItemDataTableRow;

            List <PolicyHotelOtherGroupItemDataTableItem> policyHotelOtherGroupItemDataTableItems = new List <PolicyHotelOtherGroupItemDataTableItem>();

            policyHotelOtherGroupItemDataTableItems = policyHotelOtherGroupItemDataTableRowRepository.GetPolicyHotelOtherGroupItemDataTableItems(id, policyOtherGroupHeaderId);
            if (policyHotelOtherGroupItemDataTableItems != null)
            {
                policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableItems = policyHotelOtherGroupItemDataTableItems;
            }

            return(View(policyHotelOtherGroupItemDataTableItemVM));
        }
        //Loop through PolicyHotelOtherGroupItemDataTableItems into XML
        public XmlDocument ConvertPolicyHotelOtherGroupItemDataTableItemsToXML(PolicyHotelOtherGroupItemDataTableItemVM policyHotelOtherGroupItemDataTableItemVM)
        {
            XmlDocument    doc = new XmlDocument();
            XmlDeclaration dec = doc.CreateXmlDeclaration("1.0", null, null);

            doc.AppendChild(dec);
            XmlElement root = doc.CreateElement("PolicyHotelOtherGroupItemDataTableItems");

            doc.AppendChild(root);

            if (policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableItems != null)
            {
                if (policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableItems.Count > 0)
                {
                    XmlElement xmlPolicyHotelOtherGroupItemDataTableItems = doc.CreateElement("PolicyHotelOtherGroupItemDataTableItems");
                    foreach (PolicyHotelOtherGroupItemDataTableItem item in policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableItems)
                    {
                        if (item != null && !string.IsNullOrEmpty(item.TableDataItem))
                        {
                            XmlElement xmlPolicyHotelOtherGroupItemDataTableItem = doc.CreateElement("PolicyHotelOtherGroupItemDataTableItem");

                            XmlElement xmlPolicyHotelOtherGroupItemDataTableItem_TableDataItem = doc.CreateElement("TableDataItem");
                            xmlPolicyHotelOtherGroupItemDataTableItem_TableDataItem.InnerText = item.TableDataItem;
                            xmlPolicyHotelOtherGroupItemDataTableItem.AppendChild(xmlPolicyHotelOtherGroupItemDataTableItem_TableDataItem);

                            XmlElement xmlPolicyHotelOtherGroupItemDataTableItem_PolicyOtherGroupHeaderColumnNameId = doc.CreateElement("PolicyOtherGroupHeaderColumnNameId");
                            xmlPolicyHotelOtherGroupItemDataTableItem_PolicyOtherGroupHeaderColumnNameId.InnerText = item.PolicyOtherGroupHeaderColumnNameId.ToString();
                            xmlPolicyHotelOtherGroupItemDataTableItem.AppendChild(xmlPolicyHotelOtherGroupItemDataTableItem_PolicyOtherGroupHeaderColumnNameId);

                            xmlPolicyHotelOtherGroupItemDataTableItems.AppendChild(xmlPolicyHotelOtherGroupItemDataTableItem);
                        }
                    }
                    root.AppendChild(xmlPolicyHotelOtherGroupItemDataTableItems);
                }
            }
            return(doc);
        }
        public ActionResult Edit(PolicyHotelOtherGroupItemDataTableItemVM policyHotelOtherGroupItemDataTableItemVM, FormCollection formCollection)
        {
            //Check Policy Exists
            PolicyGroup policyGroup = new PolicyGroup();

            policyGroup = policyGroupRepository.GetGroup(policyHotelOtherGroupItemDataTableItemVM.PolicyGroup.PolicyGroupId);
            if (policyGroup == null)
            {
                ViewData["ActionMethod"] = "CreatePost";
                return(View("RecordDoesNotExistError"));
            }

            //Check PolicyOtherGroupHeader Exists
            PolicyOtherGroupHeader policyOtherGroupHeader = new PolicyOtherGroupHeader();

            policyOtherGroupHeader = policyOtherGroupHeaderRepository.GetPolicyOtherGroupHeader(policyHotelOtherGroupItemDataTableItemVM.PolicyOtherGroupHeader.PolicyOtherGroupHeaderId);
            if (policyOtherGroupHeader == null)
            {
                ViewData["ActionMethod"] = "CreatePost";
                return(View("RecordDoesNotExistError"));
            }

            //We need to extract group from groupVM
            List <PolicyHotelOtherGroupItemDataTableItem> policyHotelOtherGroupItemDataTableItems = new List <PolicyHotelOtherGroupItemDataTableItem>();

            foreach (string item in formCollection)
            {
                if (item.StartsWith("PolicyOtherGroupHeaderColumnNameId"))
                {
                    PolicyHotelOtherGroupItemDataTableItem policyHotelOtherGroupItemDataTableItem = new PolicyHotelOtherGroupItemDataTableItem()
                    {
                        PolicyOtherGroupHeaderColumnNameId = Int32.Parse(item.Replace("PolicyOtherGroupHeaderColumnNameId_", "")),
                        TableDataItem = formCollection[item]
                    };
                    policyHotelOtherGroupItemDataTableItems.Add(policyHotelOtherGroupItemDataTableItem);
                }
            }
            if (policyHotelOtherGroupItemDataTableItems.Count() <= 0)
            {
                ViewData["Message"] = "ValidationError : missing item";;
                return(View("Error"));
            }

            policyHotelOtherGroupItemDataTableItemVM.PolicyHotelOtherGroupItemDataTableItems = policyHotelOtherGroupItemDataTableItems;

            //Update Model From Form + Validate against DB
            try
            {
                UpdateModel <PolicyHotelOtherGroupItemDataTableItemVM>(policyHotelOtherGroupItemDataTableItemVM, "PolicyHotelOtherGroupItemDataTableItemVM");
            }
            catch
            {
                string n = "";
                foreach (ModelState modelState in ViewData.ModelState.Values)
                {
                    foreach (ModelError error in modelState.Errors)
                    {
                        n += error.ErrorMessage;
                    }
                }
                ViewData["Message"] = "ValidationError : " + n;
                return(View("Error"));
            }

            //Database Update
            try
            {
                policyHotelOtherGroupItemDataTableItemRepository.Edit(policyHotelOtherGroupItemDataTableItemVM);
            }
            catch (SqlException ex)
            {
                //Non-Unique Name
                if (ex.Message == "NonUniqueName")
                {
                    return(View("NonUniqueNameError"));
                }

                LogRepository logRepository = new LogRepository();
                logRepository.LogError(ex.Message);

                ViewData["Message"] = "There was a problem with your request, please see the log file or contact an administrator for details";
                return(View("Error"));
            }

            ViewData["NewSortOrder"] = 0;
            return(RedirectToAction("List", new { id = policyHotelOtherGroupItemDataTableItemVM.PolicyOtherGroupHeader.PolicyOtherGroupHeaderId, policyGroupId = policyHotelOtherGroupItemDataTableItemVM.PolicyGroup.PolicyGroupId }));
        }