+ {dropdown && (
+
+ )}
+
{navposition && (
@@ -54,29 +61,58 @@ function Kangaroo({
)}
- {otherInfo && (
-
-
+ {personalInfo || eventInfo || (otherInfo && tagsLabel) ? (
+
+
+ {otherInfo && (
+
+
+
+ )}
+ {tagsLabel && tags && tags.length > 0 && (
+
+
+
+
+ {tagsLabel}
+
+
+
+ {tags.map((tag, index) => (
+
+ ))}
+
+
+ )}
+
- )}
- {tagsLabel && tags && tags.length > 0 && (
-
-
-
-
- {tagsLabel}
-
-
-
- {tags.map((tag, index) => (
-
- ))}
-
+ ) : (
+
+ {tagsLabel && tags && tags.length > 0 && (
+
+
+
+
+ {tagsLabel}
+
+
+
+ {tags.map((tag, index) => (
+
+ ))}
+
+
+ )}
)}
{tagsDesignSystemLabel &&
@@ -103,13 +139,6 @@ function Kangaroo({
)}
- {dropdown && (
-
- )}
);
diff --git a/src/components/kangaroo/kangaroo.scss b/src/components/kangaroo/kangaroo.scss
index 8c27799dcc..82b4658d50 100644
--- a/src/components/kangaroo/kangaroo.scss
+++ b/src/components/kangaroo/kangaroo.scss
@@ -1,51 +1,65 @@
@import "../../scss/bootstrap-breakpoints";
.kangaroo {
- .title-wrapper {
+ .title-wrapper {
h2 {
font-size: var(--kangaroo-title-font-size);
font-weight: 600;
margin-bottom: 0;
}
- }
- .dropdwon-zone {
- .btn {
- font-size: var(--kangaroo-title-font-size);
- text-transform: uppercase;
- }
- }
+ }
+
+ .dropdown-zone {
+ .btn-dropdown {
+ padding: 12px 24px;
+ box-shadow: inset 0 0 0 2px hsl(210, 100%, 40%);
+ // border-width: 2px;
+ // border-style: solid;
+ border-radius: 4px;
+ font-size: var(--kangaroo-title-font-size);
+ // text-transform: uppercase;
+ }
+ }
+
.nav-position {
.container-xxl {
padding-left: 0;
padding-right: 0;
}
}
+
.chip.chip-lg {
min-width: 66px;
}
+
.tag-small-size {
font-size: 1rem;
}
}
.bg-primary {
- .kangaroo {
- .chip.chip-primary {
- border-color: var(--kangaroo-negative-element-color);
- &:active {
- border-color: var(--kangaroo-negative-element-color);
- }
+ .kangaroo {
+ .chip.chip-primary {
+ border-color: var(--kangaroo-negative-element-color);
+
+ &:active {
+ border-color: var(--kangaroo-negative-element-color);
+ }
+
&:hover {
background-color: var(--kangaroo-tags-hover-color);
}
- .chip-label {
- color: var(--kangaroo-negative-element-color)
- }
- }
- .btn-dropdown {
- color: var(--kangaroo-negative-element-color)
- }
- }
+
+ .chip-label {
+ color: var(--kangaroo-negative-element-color);
+ }
+ }
+
+ .btn-dropdown {
+ color: var(--kangaroo-negative-element-color);
+ box-shadow: inset 0 0 0 2px white;
+ }
+ }
}
@@ -61,10 +75,9 @@
// }
}
-//Small tablet ------------------------------------------------------------------------------------------
-@include media-breakpoint-up(sm) {
-}
+//Small tablet ------------------------------------------------------------------------------------------
+@include media-breakpoint-up(sm) {}
//Tablet portrait ---------------------------------------------------------------------------------------
@include media-breakpoint-up(md) {
@@ -78,12 +91,10 @@
//Tablet landscape --------------------------------------------------------------------------------------
@include media-breakpoint-up(lg) {
.kangaroo {
- .right-zone {
- // text-align: right;
- // width:33.33%
+ .kangaroo {
.dropdown-menu {
- width:14rem;
-
+ min-width: 14rem;
+ max-width: 16rem;
}
}
}
@@ -99,20 +110,13 @@
}
//Laptop ------------------------------------------------------------------------------------------------
-@include media-breakpoint-up(xl) {
-
-
-}
+@include media-breakpoint-up(xl) {}
//Desktop -----------------------------------------------------------------------------------------------
-@include media-breakpoint-up(xxl) {
-
-}
+@include media-breakpoint-up(xxl) {}
//Hover states ------------------------------------------------------------------------------------------
-@media (hover: hover) {
-}
+@media (hover: hover) {}
//Transitions (A11y reduced motion disabled) ------------------------------------------------------------
-@media screen and (prefers-reduced-motion: no-preference) {
-}
+@media screen and (prefers-reduced-motion: no-preference) {}
\ No newline at end of file
diff --git a/src/components/meta-collapse/meta-collapse.js b/src/components/meta-collapse/meta-collapse.js
new file mode 100644
index 0000000000..bc4ba0bd70
--- /dev/null
+++ b/src/components/meta-collapse/meta-collapse.js
@@ -0,0 +1,63 @@
+import React, { useRef, useEffect, useState } from "react";
+import { Collapse } from "bootstrap-italia";
+import Icon from "../icon/icon";
+import "./meta-collapse.scss";
+
+function MetaCollapse({ label, labelClose, children }) {
+ const icon = {
+ icon: "sprites.svg#it-expand",
+ size: "sm",
+ align: "middle",
+ color: "primary",
+ hidden: true,
+ addonClasses: "ms-2",
+ };
+
+ const collRef = useRef(null);
+ const collObjRef = useRef(null);
+
+ const [id, setId] = useState("meta-collapse-");
+
+ const toggleAria = (element) => {
+ const ariaAttr = element.getAttribute("aria-expanded");
+ let newVal = "true";
+ if (ariaAttr === "true") {
+ newVal = "false";
+ }
+ element.setAttribute("aria-expanded", newVal);
+ };
+ const collapseToggle = (evt) => {
+ evt.preventDefault();
+ if (collObjRef.current) {
+ collObjRef.current.toggle();
+ toggleAria(evt.currentTarget);
+ }
+ };
+
+ useEffect(() => {
+ collObjRef.current = new Collapse(collRef.current, { toggle: false });
+ setId(`meta-collapse-${new Date().getTime()}`);
+ }, []);
+
+ return (
+
+
+
+ {children}
+
+
+ );
+}
+
+export default MetaCollapse;
diff --git a/src/components/meta-collapse/meta-collapse.scss b/src/components/meta-collapse/meta-collapse.scss
new file mode 100644
index 0000000000..bf19d6b064
--- /dev/null
+++ b/src/components/meta-collapse/meta-collapse.scss
@@ -0,0 +1,26 @@
+.meta-collapse {
+ .read-more {
+ text-transform: none;
+ letter-spacing: 0;
+ font-size: 1rem;
+ .less-text {
+ display: none;
+ }
+ .icon {
+ transition: transform 0.3s;
+ width: 24px !important;
+ height: 24px !important;
+ }
+ &[aria-expanded="true"] {
+ .icon {
+ transform: scaleY(-1);
+ }
+ .less-text {
+ display: inline;
+ }
+ .more-text {
+ display: none;
+ }
+ }
+ }
+}