public async Task<ActionResult> EditarCategoriaAspectoCaracter(TER_CATEGORIAASPECTOCARCTERMODEL _model)
        {
            if (ModelState.IsValid)
            {

                try
                {
                    // comprobar la existencia del nombre
                    var _test = await _context.TER_CATEGORIAASPECTOCARCTER.FirstOrDefaultAsync(i => i.NOMBRE == _model.NOMBRE);
                    //bool _nombreRepetido = false;
                    //_nombreRepetido = (_test.ID != _model.ID && _test.NOMBRE == _model.NOMBRE) ? true : false;

                    if (_test != null)
                    {
                        if (_test.ID != _model.ID)
                        {
                            ModelState.AddModelError("", "Ya existe un registro con este nombre, por favor elija otro!");
                            return View(_model);
                        }
                        else
                        {
                            // get entity
                            var _entity = new TER_CATEGORIAASPECTOCARCTER();
                            _entity = await _context.TER_CATEGORIAASPECTOCARCTER.FindAsync(_model.ID);

                            _entity.NOMBRE = _model.NOMBRE;
                            _entity.DESCRIPCION = _model.DESCRIPCION;


                            // guardar en el context
                            _context.Entry(_entity).State = EntityState.Modified;
                            await _context.SaveChangesAsync();

                            // to lista de Fases
                            return RedirectToAction("CategoriasAspectoCaracter", "Configuraciones");
                        }
                    }
                    else
                    {
                        // get entity
                        var _entity = new TER_CATEGORIAASPECTOCARCTER();
                        _entity = await _context.TER_CATEGORIAASPECTOCARCTER.FindAsync(_model.ID);

                        _entity.NOMBRE = _model.NOMBRE;
                        _entity.DESCRIPCION = _model.DESCRIPCION;


                        // guardar en el context
                        _context.Entry(_entity).State = EntityState.Modified;
                        await _context.SaveChangesAsync();

                        // to lista de Fases
                        return RedirectToAction("CategoriasAspectoCaracter", "Configuraciones");
                    }


                }
                catch (Exception ex)
                {
                    ModelState.AddModelError("", ex.Message);
                    return View(_model);
                }
            }

            return View(_model);
        }
        public async Task<ActionResult> NuevaCategoriaAspectoCaracter(TER_CATEGORIAASPECTOCARCTERMODEL _model)
        {
            if (ModelState.IsValid)
            {

                try
                {
                    // coprobar la existencia del nombre
                    if (_context.TER_CATEGORIAASPECTOCARCTER.FirstOrDefault(i => i.NOMBRE == _model.NOMBRE) != null)
                    {
                        ModelState.AddModelError("", "Ya existe un registro con este nombre, por favor elija otro!");
                        return View(_model);
                    }
                    else
                    {
                        // get entity
                        var _entity = new TER_CATEGORIAASPECTOCARCTER
                        {
                            NOMBRE = _model.NOMBRE,
                            DESCRIPCION = _model.DESCRIPCION
                        };

                        // guardar en el context
                        _context.TER_CATEGORIAASPECTOCARCTER.Add(_entity);
                        await _context.SaveChangesAsync();

                        // to lista de Fases
                        return RedirectToAction("CategoriasAspectoCaracter", "Configuraciones");
                    }


                }
                catch (Exception ex)
                {
                    ModelState.AddModelError("", ex.Message);
                    return View(_model);
                }
            }

            return View(_model);
        }
        //editar Aspecto - Carácter
        // get
        public async Task<ActionResult> EditarCategoriaAspectoCaracter(int? ID)
        {
            // comprobar la nulidad de ID
            if (ID == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }


            //get entity
            var _entity = await _context.TER_CATEGORIAASPECTOCARCTER.FindAsync(ID);

            // comprobar si existe un registro con es id
            if (_entity == null)
            {
                return HttpNotFound();
            }

            // set model
            var _model = new TER_CATEGORIAASPECTOCARCTERMODEL
            {
                ID = _entity.ID,
                NOMBRE = _entity.NOMBRE,
                DESCRIPCION = _entity.DESCRIPCION
            };

            // to view
            return View(_model);
        }
        // crear Aspecto - Carácter

        //get 
        public ActionResult NuevaCategoriaAspectoCaracter()
        {
            // get model 
            var _model = new TER_CATEGORIAASPECTOCARCTERMODEL();

            return View(_model);
        }