private void RefreshSources(List <Publicacion> publications)
        {
            ClearDataGridView();
            var publicationsDictionary = new Dictionary <int, Publicacion>();

            #region Get the dictionary of visibilities

            if (publications == null)
            {
                //El datasource debe contener a todos los registros de publicaciones activas
                _publications = PublicacionPersistance.GetAllActive();
                if (_publications != null)
                {
                    publicationsDictionary = _publications.ToDictionary(a => a.ID, a => a);
                }
            }
            else
            {
                //El datasource debe ser la lista de publicaciones recibida por parámetro
                publicationsDictionary = _publications.ToDictionary(a => a.ID, a => a);
            }

            #endregion

            #region Cargar publicaciones en la grilla
            var bind = publicationsDictionary.Values.Select(a => new
            {
                ID                   = a.ID,
                Descripcion          = a.Descripcion,
                Inicio               = a.FechaInicio,
                Vencimiento          = a.FechaVencimiento,
                Stock                = a.Stock,
                Precio               = (OfertaPersistance.GetLastOfertaByPublication(a.ID) != null) ? OfertaPersistance.GetLastOfertaByPublication(a.ID).Monto: a.Precio,
                RecibirPreguntas     = a.RecibirPreguntas,
                Tipo                 = a.TipoPublicacion.Descripcion,
                Visibilidad          = a.Visibilidad.Descripcion,
                Rubros               = a.GetTextRubros(),
                CalificacionVendedor = CalificacionPersistance.GetByUserId(a.UsuarioCreador)
            });

            var bindlist = bind.ToList();
            if (bindlist.Count - _offset > 10)
            {
                DgvPublicacion.DataSource = bindlist.GetRange(_offset, 10); //paginas de a 10 contenidos
            }
            else
            {
                DgvPublicacion.DataSource = bindlist.GetRange(_offset, bindlist.Count - _offset);
            }
            DgvPublicacion.Columns[9].AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
            AddButtonsColumns();
            #endregion

            if (bindlist.Count < 10) //si tiene menos de 10 registros no debe paginar
            {
                lblFirst.Visible    = false;
                lblPrevious.Visible = false;
                lblNext.Visible     = false;
                lblLast.Visible     = false;
            }

            //Cargo los rubros
            var rubros = RubroPersistance.GetAll();
            LstRubro.DataSource    = rubros;
            LstRubro.DisplayMember = "Descripcion";
            LstRubro.ValueMember   = "ID";
        }