Merge pull request #5250 from consuldemocracy/content-block
Add new content block `footer_legal` to Footer
This commit is contained in:
@@ -734,6 +734,28 @@ footer {
|
||||
border-top: 1px solid $text-light;
|
||||
font-size: $small-font-size;
|
||||
padding-top: $line-height / 2;
|
||||
|
||||
.legal {
|
||||
display: inline-block;
|
||||
margin-#{$global-left}: 0;
|
||||
|
||||
&::before {
|
||||
content: "|";
|
||||
}
|
||||
|
||||
li {
|
||||
display: inline-block;
|
||||
|
||||
&::after {
|
||||
content: "|";
|
||||
margin-left: 4px;
|
||||
}
|
||||
|
||||
&:last-child::after {
|
||||
content: none;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 04. Tags
|
||||
|
||||
@@ -22,11 +22,12 @@
|
||||
|
||||
<div class="subfooter row">
|
||||
<div class="small-12 medium-8 column">
|
||||
<%= t("layouts.footer.copyright", year: Time.current.year) %> |
|
||||
<ul class="no-bullet inline-block">
|
||||
<li class="inline-block"><%= link_to t("layouts.footer.privacy"), page_path("privacy") %> |</li>
|
||||
<li class="inline-block"><%= link_to t("layouts.footer.conditions"), page_path("conditions") %> |</li>
|
||||
<li class="inline-block"><%= link_to t("layouts.footer.accessibility"), page_path("accessibility") %></li>
|
||||
<%= t("layouts.footer.copyright", year: Time.current.year) %>
|
||||
<ul class="legal">
|
||||
<li><%= link_to t("layouts.footer.privacy"), page_path("privacy") %></li>
|
||||
<li><%= link_to t("layouts.footer.conditions"), page_path("conditions") %></li>
|
||||
<li><%= link_to t("layouts.footer.accessibility"), page_path("accessibility") %></li>
|
||||
<%= raw footer_legal_content_block %>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
|
||||
@@ -1,2 +1,7 @@
|
||||
class Layout::FooterComponent < ApplicationComponent
|
||||
delegate :content_block, to: :helpers
|
||||
|
||||
def footer_legal_content_block
|
||||
content_block("footer_legal")
|
||||
end
|
||||
end
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
class SiteCustomization::ContentBlock < ApplicationRecord
|
||||
VALID_BLOCKS = %w[top_links footer subnavigation_left subnavigation_right].freeze
|
||||
VALID_BLOCKS = %w[top_links footer footer_legal subnavigation_left subnavigation_right].freeze
|
||||
|
||||
validates :locale, presence: true, inclusion: { in: I18n.available_locales.map(&:to_s) }
|
||||
validates :name, presence: true, uniqueness: { scope: :locale }, inclusion: { in: ->(*) { VALID_BLOCKS }}
|
||||
|
||||
@@ -1590,7 +1590,8 @@ en:
|
||||
name: Name
|
||||
names:
|
||||
top_links: Top Links
|
||||
footer: Footer
|
||||
footer: Footer (social media)
|
||||
footer_legal: Footer (legal terms)
|
||||
subnavigation_left: Main Navigation Left
|
||||
subnavigation_right: Main Navigation Right
|
||||
images:
|
||||
|
||||
@@ -1590,7 +1590,8 @@ es:
|
||||
name: Nombre
|
||||
names:
|
||||
top_links: Enlaces superiores
|
||||
footer: Pie de página
|
||||
footer: Pie de página (redes sociales)
|
||||
footer_legal: Pie de página (términos legales)
|
||||
subnavigation_left: Navegación principal izquierda
|
||||
subnavigation_right: Navegación principal derecha
|
||||
images:
|
||||
|
||||
@@ -26,13 +26,37 @@ describe "Custom content blocks" do
|
||||
|
||||
visit "/?locale=en"
|
||||
|
||||
expect(page).to have_content("content for footer")
|
||||
expect(page).not_to have_content("contenido para footer")
|
||||
within ".social" do
|
||||
expect(page).to have_content("content for footer")
|
||||
expect(page).not_to have_content("contenido para footer")
|
||||
end
|
||||
|
||||
visit "/?locale=es"
|
||||
|
||||
expect(page).to have_content("contenido para footer")
|
||||
expect(page).not_to have_content("content for footer")
|
||||
within ".social" do
|
||||
expect(page).to have_content("contenido para footer")
|
||||
expect(page).not_to have_content("content for footer")
|
||||
end
|
||||
end
|
||||
|
||||
scenario "footer_legal content block" do
|
||||
create(:site_customization_content_block, name: "footer_legal", locale: "en",
|
||||
body: "legal content for footer")
|
||||
create(:site_customization_content_block, name: "footer_legal", locale: "es",
|
||||
body: "contenido legal para el footer")
|
||||
|
||||
visit "/?locale=en"
|
||||
|
||||
within ".legal" do
|
||||
expect(page).to have_content("legal content for footer")
|
||||
expect(page).not_to have_content("contenido legal para el footer")
|
||||
end
|
||||
|
||||
visit "/?locale=es"
|
||||
within ".legal" do
|
||||
expect(page).to have_content("contenido legal para el footer")
|
||||
expect(page).not_to have_content("legal content for footer")
|
||||
end
|
||||
end
|
||||
|
||||
scenario "main navigation left" do
|
||||
|
||||
Reference in New Issue
Block a user