// GET: /Edit
        public ActionResult Edit(int id, string languageCode)
        {
            //Get Item
            PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage = new PolicyHotelVendorGroupItemLanguage();

            policyHotelVendorGroupItemLanguage = policyHotelVendorGroupItemLanguageRepository.GetItem(id, languageCode);

            //Check Exists
            if (policyHotelVendorGroupItemLanguage == null)
            {
                ViewData["ActionMethod"] = "EditGet";
                return(View("RecordDoesNotExistError"));
            }

            //Check AccessRights
            PolicyHotelVendorGroupItem policyHotelVendorGroupItem = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(id);
            RolesRepository rolesRepository = new RolesRepository();

            if (!rolesRepository.HasWriteAccessToPolicyGroup(policyHotelVendorGroupItem.PolicyGroupId))
            {
                ViewData["Message"] = "You do not have access to this item";
                return(View("Error"));
            }

            //Language SelectList
            SelectList languageList = new SelectList(policyHotelVendorGroupItemLanguageRepository.GetUnUsedLanguages(id).ToList(), "LanguageCode", "LanguageName");

            ViewData["Languages"] = languageList;

            policyHotelVendorGroupItemLanguageRepository.EditItemForDisplay(policyHotelVendorGroupItemLanguage);
            return(View(policyHotelVendorGroupItemLanguage));
        }
        public ActionResult Delete(int id, string languageCode)
        {
            //Get Item
            PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage = new PolicyHotelVendorGroupItemLanguage();

            policyHotelVendorGroupItemLanguage = policyHotelVendorGroupItemLanguageRepository.GetItem(id, languageCode);

            //Check Exists
            if (policyHotelVendorGroupItemLanguage == null)
            {
                ViewData["ActionMethod"] = "DeleteGet";
                return(View("RecordDoesNotExistError"));
            }

            //Check AccessRights
            PolicyHotelVendorGroupItem policyHotelVendorGroupItem = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(id);
            RolesRepository rolesRepository = new RolesRepository();

            if (!rolesRepository.HasWriteAccessToPolicyGroup(policyHotelVendorGroupItem.PolicyGroupId))
            {
                ViewData["Message"] = "You do not have access to this item";
                return(View("Error"));
            }

            //Add Linked Information
            policyHotelVendorGroupItemLanguageRepository.EditItemForDisplay(policyHotelVendorGroupItemLanguage);

            //Return View
            return(View(policyHotelVendorGroupItemLanguage));
        }
        //Add Data From Linked Tables for Display
        public void EditItemForDisplay(PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage)
        {
            //Add LanguageName
            if (policyHotelVendorGroupItemLanguage.LanguageCode != null)
            {
                LanguageRepository languageRepository = new LanguageRepository();
                Language           language           = new Language();
                language = languageRepository.GetLanguage(policyHotelVendorGroupItemLanguage.LanguageCode);
                if (language != null)
                {
                    policyHotelVendorGroupItemLanguage.LanguageName = language.LanguageName;
                }
            }

            //Add PolicyGroupName
            PolicyHotelVendorGroupItemRepository policyHotelVendorGroupItemRepository = new PolicyHotelVendorGroupItemRepository();
            PolicyHotelVendorGroupItem           policyHotelVendorGroupItem           = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId);


            if (policyHotelVendorGroupItem != null)
            {
                policyHotelVendorGroupItemRepository.EditItemForDisplay(policyHotelVendorGroupItem);
                policyHotelVendorGroupItemLanguage.PolicyGroupName = policyHotelVendorGroupItem.PolicyGroupName;
                policyHotelVendorGroupItemLanguage.PolicyGroupId   = policyHotelVendorGroupItem.PolicyGroupId;
            }
        }
        public ActionResult Create(PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage)
        {
            PolicyHotelVendorGroupItem policyHotelVendorGroupItem = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId);

            //Check Exists
            if (policyHotelVendorGroupItem == null)
            {
                ViewData["ActionMethod"] = "CreatePost";
                return(View("RecordDoesNotExistError"));
            }

            RolesRepository rolesRepository = new RolesRepository();

            if (!rolesRepository.HasWriteAccessToPolicyGroup(policyHotelVendorGroupItem.PolicyGroupId))
            {
                //AccessRights Error
                return(View("Error"));
            }

            //Update  Model from Form
            try
            {
                UpdateModel(policyHotelVendorGroupItemLanguage);
            }
            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"));
            }



            try
            {
                policyHotelVendorGroupItemLanguageRepository.Add(policyHotelVendorGroupItemLanguage);
            }
            catch
            {
                //Insert Error
                return(View("Error"));
            }

            return(RedirectToAction("List", new { id = policyHotelVendorGroupItem.PolicyHotelVendorGroupItemId }));
        }
        //Delete From DB
        public void Delete(PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage)
        {
            string adminUserGuid = HttpContext.Current.User.Identity.Name.Split(new[] { '|' })[0];

            db.spDesktopDataAdmin_DeletePolicyHotelVendorGroupItemHotelAdvice_v1(
                policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId,
                policyHotelVendorGroupItemLanguage.LanguageCode,
                adminUserGuid,
                policyHotelVendorGroupItemLanguage.VersionNumber
                );
        }
        //Add to DB
        public void Add(PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage)
        {
            string adminUserGuid = HttpContext.Current.User.Identity.Name.Split(new[] { '|' })[0];

            db.spDesktopDataAdmin_InsertPolicyHotelVendorGroupItemHotelAdvice_v1(
                policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId,
                policyHotelVendorGroupItemLanguage.LanguageCode,
                policyHotelVendorGroupItemLanguage.HotelAdvice,
                adminUserGuid
                );
        }
        //GET: View
        public ActionResult View(int id, string languageCode)
        {
            PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage = new PolicyHotelVendorGroupItemLanguage();

            policyHotelVendorGroupItemLanguage = policyHotelVendorGroupItemLanguageRepository.GetItem(id, languageCode);
            if (policyHotelVendorGroupItemLanguage == null)
            {
                ViewData["ActionMethod"] = "ViewGet";
                return(View("RecordDoesNotExistError"));
            }
            policyHotelVendorGroupItemLanguageRepository.EditItemForDisplay(policyHotelVendorGroupItemLanguage);
            return(View(policyHotelVendorGroupItemLanguage));
        }
        public ActionResult Delete(int id, string languageCode, FormCollection collection)
        {
            //Get Item
            PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage = new PolicyHotelVendorGroupItemLanguage();

            policyHotelVendorGroupItemLanguage = policyHotelVendorGroupItemLanguageRepository.GetItem(id, languageCode);

            //Check Exists
            if (policyHotelVendorGroupItemLanguage == null)
            {
                ViewData["ActionMethod"] = "DeletePost";
                return(View("RecordDoesNotExistError"));
            }

            //Check AccessRights
            PolicyHotelVendorGroupItem policyHotelVendorGroupItem = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(id);
            RolesRepository rolesRepository = new RolesRepository();

            if (!rolesRepository.HasWriteAccessToPolicyGroup(policyHotelVendorGroupItem.PolicyGroupId))
            {
                ViewData["Message"] = "You do not have access to this item";
                return(View("Error"));
            }

            //Delete Item
            try
            {
                policyHotelVendorGroupItemLanguage.VersionNumber = Int32.Parse(collection["VersionNumber"]);
                policyHotelVendorGroupItemLanguageRepository.Delete(policyHotelVendorGroupItemLanguage);
            }
            catch (SqlException ex)
            {
                //Versioning Error - go to standard versionError page
                if (ex.Message == "SQLVersioningError")
                {
                    ViewData["ReturnURL"] = "/HotelAdvice.mvc/Delete/" + policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId.ToString() + "/" + policyHotelVendorGroupItemLanguage.LanguageCode;
                    return(View("VersionError"));
                }
                //Generic Error
                ViewData["Message"] = "There was a problem with your request, please see the log file or contact an administrator for details";
                return(View("Error"));
            }

            //Return
            return(RedirectToAction("List", new { id = policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId }));
        }
        // GET: /Create
        public ActionResult Create(int id)
        {
            //Get PolicyHotelVendorGroupItem
            PolicyHotelVendorGroupItem policyHotelVendorGroupItem = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(id);

            //Check Exists
            if (policyHotelVendorGroupItem == null)
            {
                ViewData["ActionMethod"] = "CreateGet";
                return(View("RecordDoesNotExistError"));
            }

            //AccessRights
            RolesRepository rolesRepository = new RolesRepository();

            if (!rolesRepository.HasWriteAccessToPolicyGroup(policyHotelVendorGroupItem.PolicyGroupId))
            {
                ViewData["ActionMethod"] = "ViewGet";
                return(View("Error"));
            }

            //New PolicyHotelVendorGroupItemLanguage
            PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage = new PolicyHotelVendorGroupItemLanguage();

            policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId = id;
            policyHotelVendorGroupItemLanguageRepository.EditItemForDisplay(policyHotelVendorGroupItemLanguage);

            //Language SelectList
            SelectList languageList = new SelectList(policyHotelVendorGroupItemLanguageRepository.GetUnUsedLanguages(id).ToList(), "LanguageCode", "LanguageName");

            ViewData["Languages"] = languageList;

            //Show Create Form
            return(View(policyHotelVendorGroupItemLanguage));
        }
        public ActionResult Edit(int policyHotelVendorGroupItemId, string languageCode, string hotelAdvice)
        {
            //Get Item
            PolicyHotelVendorGroupItemLanguage policyHotelVendorGroupItemLanguage = new PolicyHotelVendorGroupItemLanguage();

            policyHotelVendorGroupItemLanguage = policyHotelVendorGroupItemLanguageRepository.GetItem(policyHotelVendorGroupItemId, languageCode);

            //Check Exists
            if (policyHotelVendorGroupItemLanguage == null)
            {
                ViewData["ActionMethod"] = "EditPost";
                return(View("RecordDoesNotExistError"));
            }

            //Check AccessRights
            PolicyHotelVendorGroupItem policyHotelVendorGroupItem = new PolicyHotelVendorGroupItem();

            policyHotelVendorGroupItem = policyHotelVendorGroupItemRepository.GetPolicyHotelVendorGroupItem(policyHotelVendorGroupItemId);
            RolesRepository rolesRepository = new RolesRepository();

            if (!rolesRepository.HasWriteAccessToPolicyGroup(policyHotelVendorGroupItem.PolicyGroupId))
            {
                ViewData["Message"] = "You do not have access to this item";
                return(View("Error"));
            }

            //Update Item from Form
            try
            {
                UpdateModel(policyHotelVendorGroupItemLanguage);
            }
            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"));
            }

            //Update CountryAdvice
            try
            {
                policyHotelVendorGroupItemLanguageRepository.Update(policyHotelVendorGroupItemLanguage);
            }
            catch (SqlException ex)
            {
                //Versioning Error
                if (ex.Message == "SQLVersioningError")
                {
                    ViewData["ReturnURL"] = "/HotelAdvice.mvc/Edit/" + policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId.ToString();
                    return(View("VersionError"));
                }

                //Generic Error
                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 = policyHotelVendorGroupItemLanguage.PolicyHotelVendorGroupItemId }));
        }