The following classes are added to the .sds-sectionForm__item element.
The JS snippet used is available under the Assets pane
<div class="sds-sectionForm__item sds-box -insetLg sds-stackMd -recap">
<div class="sds-sectionForm__itemBody sds-stackMd">
<div class="row row-sm align-items-center">
<div class="col-4">
<img class="img-fluid d-block mx-auto" src="../../media/illustrative-icons/sdsillu-sending.svg" alt="">
</div>
<div class="col-8">
<div class="sds-stackXs">
<div class="h3">Votre rendez-vous pour un prêt immobilier est confirmé !</div>
<p class="sds-textBodyLg">Si besoin, vous pouvez modifer ou annuler votre rendez-vous depuis votre espace utilisateur sous la rubrique Mes rendez-vous.</p>
</div>
</div>
<div class="col-12">
<div class="sds-contactBlock -recap">
<div class="sds-contactBlock__heading">
<div class="h3">Récapitulatif</div>
</div>
<div class="sds-contactBlock__body">
<div class="row row-sm align-items-stretch-immediate">
<div class="col-md-6 col-lg-4">
<div class="sds-actionCard -top sds-contactBlock__actionCard">
<div class="sds-actionCard__inner">
<div class="sds-avatar centeredBgi">
<img class="img-fluid" src="../../media/snet/avatars/nopic/avatarNoPicMan.svg" alt="">
</div>
<div class="sds-actionCard__text sds-stackXxs">
<div class="sds-actionCard__title sds-textBodyLg">Conseiller Prêt Immobilier</div>
<p>Conseiller</p>
</div>
</div>
</div>
</div>
<div class="col-md-6 col-lg-4">
<div class="sds-actionCard -top sds-contactBlock__actionCard">
<div class="sds-actionCard__inner">
<span class="sds-iconCircle -info100" aria-hidden="true">
<span class="sds-icon sds-icon-pin"></span>
</span>
<div class="sds-actionCard__text sds-stackXxs">
<div class="sds-actionCard__title sds-textBodyLg">Bascharage</div>
<p>Avenue de Luxembourg, 135<br>4940, Bascharage</p>
</div>
</div>
</div>
</div>
<div class="col-md-6 col-lg-4">
<div class="sds-actionCard -top sds-contactBlock__actionCard">
<div class="sds-actionCard__inner">
<span class="sds-iconCircle -info100" aria-hidden="true">
<span class="sds-icon sds-icon-calendar"></span>
</span>
<div class="sds-actionCard__text sds-stackXxs">
<div class="sds-actionCard__title sds-textBodyLg">Le 29 mars 2022</div>
<p>À 10h30</p>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="sds-contactBlock__footer">
<div class="sds-textHelper">
Vous recevrez un SMS de rappel 24 heures avant votre rendez-vous au +352 621 123 456.
<br>
<a href="#!" class="sds-contactBlock__footerLink">Le numéro de téléphone n’est pas correct ?</a>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="sds-sectionForm__itemFooter">
<div class="sds-btnGroup">
<button type="button" class="sds-btn -btnSecondary -btnInverse">
<span class="sds-btn__text">Accéder à Mes rendez-vous</span>
</button>
<button type="button" class="sds-btn -btnPrimary">
<span class="sds-btn__text">Retour à S-Net</span>
</button>
</div>
</div>
</div>
{% extends "@snet-section-form-frame" %}
{% block body %}
<div class="row row-sm align-items-center">
<div class="col-4">
<img class="img-fluid d-block mx-auto" src="{{ (mediaPath+img) | path }}" alt="">
</div>
<div class="col-8">
<div class="{{ namespace }}stackXs">
<div class="h3">{{ title }}</div>
<p class="{{ namespace }}textBodyLg">{{ text }}</p>
</div>
</div>
<div class="col-12">
{% render '@snet-contact-block--recap' %}
</div>
</div>
{% endblock %}
{% block footer %}
<div class="{{ namespace }}btnGroup">
{% render '@btn-secondary-inverse', {text: "Accéder à Mes rendez-vous"}, true %}
{% render '@btn-primary',{text: "Retour à S-Net"}, true %}
</div>
{% endblock %}
export default class SectionForm {
constructor() {
this.scrollIndicators();
}
scrollIndicators() {
const scrollElement = document.querySelectorAll('.sds-sectionForm__itemBody');
function setShadows(element) {
let lastScrollTop = 0;
element.addEventListener("scroll", (e) => {
if (e.target.scrollTop === 0) {
element.parentNode.classList.remove("-shadowTop")
} else if (element.scrollTop < lastScrollTop){
// upscroll
element.parentNode.classList.add("-shadowTop")
element.parentNode.classList.add("-shadowBottom")
} else if (e.target.scrollTop > 0) {
element.parentNode.classList.add("-shadowTop")
}
// ending of scrollable area reached
lastScrollTop = element.scrollTop <= 0 ? 0 : element.scrollTop;
if (element.scrollHeight - element.scrollTop - element.clientHeight < 2) {
element.parentNode.classList.remove("-shadowBottom")
}
})
}
let ro = new ResizeObserver((entries, observer) => {
for (let entry of entries) {
if(entry.target.scrollHeight > entry.target.clientHeight){
entry.target.parentNode.classList.add("-shadowBottom");
setShadows(entry.target)
console.log("set shadows event")
} else if(entry.target.scrollHeight <= entry.target.clientHeight){
if(entry.target.parentNode.classList.contains("-shadowBottom")) {
entry.target.parentNode.classList.remove("-shadowBottom");
}
}
}
});
scrollElement.forEach((element, index) => {
ro.observe(element);
})
}
}
@use "sass:math";
.#{$namespace}sectionForm {
/* Save root element context for easy access if nesting is needed */
$self: &;
/* variables specific to current element */
$section-form-items-transition-duration: 0.45s;
$section-form-container-transition-duration: 0.25s;
/* properties of current element + media queries */
display: flex;
flex-direction: column;
//position: relative;
height: 100%;
margin-bottom: 0;
@include media-breakpoint-up(lg) {
flex-direction: column;
}
/* Pseudo Elements */
&::before {
}
&::after {
}
/*
Include elements that are linked to the current element but have to reside at the root level of the stylesheet
(e.g: keyframes)
*/
@at-root {
}
/* children - write selector in full in comments in order to facilitate search */
&__item {
display: flex;
flex-direction: column;
position: relative;
height: 100%;
margin-bottom: 0;
@include spacer-component-stack("lg", true);
&.-hasStickyMobileBtn {
#{$self}__itemBody {
@include media-breakpoint-between(xs,sm) {
padding-bottom: map-deep-get($token-spacer-stack-max-map, "xl")*4;
}
}
}
&.-fullHeight {
height: auto;
#{$self}__itemBody {
overflow: visible;
}
}
#{$self}__itemHeading::before,
#{$self}__itemFooter::before {
content: "";
position: absolute;
left: -$box-lg-inset-spacing-desktop-global;
right: -$box-lg-inset-spacing-desktop-global;
height: map-deep-get($token-sizes-unit-map, "12");
background-color: transparent;
z-index: z("negative");
}
&.-shadowTop {
#{$self}__itemHeading::before {
top: calc(100% + map-deep-get($token-spacer-stack-max-map, "lg"));
opacity: 1;
z-index: z("low");
background-image: radial-gradient(farthest-side at 50% 0%, rgba($color-brand-secondary-20, 0.24) 0%, rgba($color-brand-secondary-20, 0) 100%);
}
}
&.-shadowBottom {
#{$self}__itemFooter::before {
bottom: calc(100% + map-deep-get($token-spacer-stack-max-map, "lg"));
opacity: 1;
z-index: z("low");
background-image: radial-gradient(farthest-side at 50% 100%, rgba($color-brand-secondary-20, 0.24) 0%, rgba($color-brand-secondary-20, 0) 100%);
}
}
}
// sectionForm__itemBody
&__itemBody {
display: flex;
flex-direction: column;
flex-grow: 1;
overflow: hidden;
padding-bottom: map-deep-get($token-spacer-unit-map, "64");
/* necessary tweak because of the overflow hidden behaviour */
padding-left: $box-lg-inset-spacing-mobile-global;
padding-right: $box-lg-inset-spacing-mobile-global;
margin-left: -$box-lg-inset-spacing-mobile-global;
margin-right: -$box-lg-inset-spacing-mobile-global;
@include media-breakpoint-up(lg) {
overflow-y: auto;
overflow-x: hidden;
padding-bottom: 0;
overscroll-behavior: none;
/* necessary tweak because of the overflow hidden behaviour */
padding-left: $box-lg-inset-spacing-desktop-global;
padding-right: $box-lg-inset-spacing-desktop-global;
margin-left: -$box-lg-inset-spacing-desktop-global;
margin-right: -$box-lg-inset-spacing-desktop-global;
}
}
&__itemHeading,
&__itemFooter {
@include media-breakpoint-up(lg) {
position: relative;
}
}
&__itemFooter {
display: flex;
justify-content: flex-end;
@include spacer-component-inline(sm);
position: fixed;
z-index: z("sticky");
bottom: 0;
left: 0;
right: 0;
background-color: inherit;
padding: $snet-frame-main-horiz-padding-mobile-global $snet-frame-main-horiz-padding-mobile-global calc(#{$snet-frame-main-horiz-padding-mobile-global} + env(safe-area-inset-bottom)) $snet-frame-main-horiz-padding-mobile-global;
border-top-left-radius: map-deep-get($token-radius-map, "16");
border-top-right-radius: map-deep-get($token-radius-map, "16");
box-shadow: map-deep-get($token-shadow-map, "sidebar");
transform: translateY(100%);
transition: opacity math.div($section-form-items-transition-duration, 2) ease-out, transform 0.1s linear;
@include media-breakpoint-up(lg) {
position: static;
padding: 0;
border-radius: 0;
box-shadow: none;
transform: none;
}
}
&__stickyFooterBtn {
position: absolute;
bottom: calc(100% + #{map-deep-get($token-spacer-unit-map, "8")});
left: 0;
right: 0;
text-align: center;
opacity: 0;
visibility: hidden;
transition: opacity 0.25s linear;
@include media-breakpoint-up(md) {
position: static;
transform: none;
opacity: 1;
visibility: visible;
}
&.-shown {
opacity: 1;
visibility: visible;
@include media-breakpoint-between(xs,sm) {
margin-right: 0 !important;
}
}
}
&__container {
flex-shrink: 0;
transition: transform $section-form-container-transition-duration ease-out;
width: 100%;
height: 100%;
top: 0;
left: 0;
@include media-breakpoint-up(lg) {
position: absolute;
left: 50%;
transform: translate(-50%,0) scale(1);
}
#{$self}__itemHeading,
#{$self}__itemBody,
#{$self}__itemFooter {
opacity: 0;
visibility: hidden;
transition: opacity $section-form-container-transition-duration $section-form-container-transition-duration ease-out, visibility 0 math.div($section-form-container-transition-duration, 2) linear;
transition-delay: $section-form-items-transition-duration;
}
&.-prev {
position: absolute;
transform: translate(calc(-100% + #{map-deep-get($token-spacer-inset-map, "sm")}),0);
@include media-breakpoint-up(lg) {
transform: translate(-50%,-96%) scale(0.90);
}
}
&.-isActive {
position: relative;
@include media-breakpoint-up(lg) {
position: absolute;
top: 0;
left: 50%;
transform: translate(-50%,0) scale(1);
}
#{$self}__itemHeading,
#{$self}__itemBody,
#{$self}__itemFooter {
opacity: 1;
visibility: visible;
transition: opacity $section-form-items-transition-duration math.div($section-form-items-transition-duration, 2) linear;
}
#{$self}__itemFooter {
transition: opacity math.div($section-form-items-transition-duration, 2) $section-form-items-transition-duration ease-out, transform math.div($section-form-items-transition-duration, 2) $section-form-items-transition-duration ease-out;
transform: translateY(0);
}
}
&.-next {
position: absolute;
transform: translate(calc(100% - #{map-deep-get($token-spacer-inset-map, "sm")}),0);
@include media-breakpoint-up(lg) {
transform: translate(-50%,96%) scale(0.90);
}
}
}
&__actionCardContainer {
margin-top: map-deep-get($token-spacer-unit-map, "24");
}
&__actionCard {
border: $border-width solid $border-color;
border-radius: map-deep-get($token-radius-map, "16");
padding: map-deep-get($token-spacer-inset-map, "lg");
background-color: map-deep-get($token-color-grayscale-map, "0");
}
&__divider {
width: 100%;
height: $border-width;
@include custom-prop-fallback("background-color", "sys-color-border-primary-moderate");
}
&__titlePretHyp {
margin-top: map-deep-get($token-spacer-unit-map, "48");
}
&__inputShadowAction {
display: flex;
align-items: center;
@include spacer-component-inline("md");
}
/* modifiers */
// sectionForm -recap
&.-recap {
#{$self}__itemHeading {
display: flex;
justify-content: center;
}
#{$self}__actionCardContainer {
margin-top: map-deep-get($token-spacer-unit-map, "64");
}
}
/* random parent element */
/*
*
* Syntax : .randomParentElt & {}
*
*/
/* Pseudo Classes */
&:hover {
@media (hover: hover) {
}
}
&:focus {
}
&:active {
}
&:focus,
&:active {
}
}