BlogEngine.Net: Widget Zone Multipli per i Razor Themes

    Hace poco tiempo, una empresa se puso en contacto conmigo para que apareciera un anuncio solo en la barra lateral de la página de inicio. Así que tuve que crear un widget personalizado para colocarlo solo en la página de inicio.

    Así que empecé a hurgar en los meandros del Foro BlogEngine.Net para tratar de encontrar algo que me permitiera crear múltiples zonas de widgets: widgets diferentes y diferentes entre la página de inicio y las publicaciones individuales.


    Un artículo interesante es el de Cuartos de Ben que explica muy bien la Zona de Widget Múltiple en los temas de BlogEngine.Net: Zona de Widget Múltiple en BE.


    El problema es que mi tema es un tema de la maquinilla de afeitar, por lo que el asunto se complicó tremendamente, ya que estamos hablando de archivos con la extensión chstml y no aspx o ascx (el Razor fue creado por Microsoft con el objetivo de obtener un diseño compacto y expresivo). Traté de pedir ayuda en el foro BE.Net tratando de definir un solo widget con el anuncio requerido en la página de inicio para ocultarlo en las páginas y publicaciones.

    Prácticamente todos los widgets tienen un ID, al establecer la ID del widget en visible = true en la página de inicio y en visible = false en las otras secciones, podría haber resuelto el problema, pero para el tema de la maquinilla de afeitar no hay widgetContainer, así que tuve que crear un widget de zona múltiple personalizado para el home y para páginas y publicaciones.

    BlogEngine.Net: Widget Zone Multipli per i Razor Themes

    Básicamente, así es como lo hice:

    @if (Request.Url.ToString (). ToLowerInvariant (). Contains ("/ default.aspx")) {if (Request.RawUrl.ToLowerInvariant (). Contains ("/ category /") || Request.RawUrl. ToLowerInvariant (). Contiene ("/ autor /") || Request.RawUrl.ToLowerInvariant (). Contiene ("? Tag =") || Request.QueryString ["year"]! = Null || Request.QueryString [" fecha "]! = null || Request.QueryString [" calendario "]! = null) { @ Html.Raw (Html.RenderWidgetZone ("barra lateral de la página")) } else {@ Html.Raw (Html.RenderWidgetZone ("be_WIDGET_ZONE"))}} else { @ Html.Raw (Html.RenderWidgetZone ("barra lateral de la página")) }


    He creado en el archivo principal de mi tema, en mi caso Site.Cshtml, una condición en la que le digo al sistema que si la página en la que estoy es diferente de la página de inicio, "page-sidebar" es la zona de widgets para utilizar como barra lateral; de lo contrario, puede utilizar "be_WIDGET_ZONE" de forma segura.


    Ayudándome con el CO todo lo que hice fue usar la identificación "siderbar-page" para definir los colores, formas y fuentes de los nuevos widgets.


    Además de la posibilidad de crear dos barras laterales diferentes con diferentes widgets para páginas, artículos, página de inicio, etc., también es posible crear zonas de widgets dentro de la barra lateral. Por ejemplo, si queremos diferentes zonas de widgets dentro de la barra lateral podemos crear un midWidget y un bottomWidget, ayudándonos siempre con CSS:

    @ Html.Raw (Html.RenderWidgetZone ("be_WIDGET_ZONE")) @if (Request.Url.ToString (). ToLowerInvariant (). Contains ("default.aspx") || Request.Url.ToString (). ToLowerInvariant (). Contains ("blog.aspx")) { @ Html.Raw (Html.RenderWidgetZone ("be_WIDGET_MID")) } @ Html.Raw (Html.RenderWidgetZone ("be_WIDGET_BOTTOM"))

    Añade un comentario de BlogEngine.Net: Widget Zone Multipli per i Razor Themes
    ¡Comentario enviado con éxito! Lo revisaremos en las próximas horas.

    End of content

    No more pages to load