Panel Header: Mouvements Cartes

Refer to panel header frame found in view tab for complete structure without content.

If content is to be aligned to the right, it has to be included in the "panelHeader__alignEnd" part of the component.

Include the headroom.min.js JS in the libs folder.

Add "-headroom to the panel header element. Nothing more is needed.

If a sidebar with the class "sds-stickSidebar" is present, it will respond to the panel header's scroll position.

You can use the javascript found in the assets panel to get an idea of how the plugin works.

You can find any and all information relating to it here

A usage example can be found in snet/pages/mouvements-cartes

<div class="sds-panelHeader">

    <div class="sds-panelHeader__actionGroup sds-panelHeader__back">
        <button type="button" class="sds-btn -iconBtn -btnSecondary">

            <span class="sds-icon sds-icon-arrowprevious"></span>

        </button>
    </div>
    <div class="sds-panelHeader__actionGroup -big -timelineStart">
        <a href="" class="sds-btn -iconBtn -btnPrimary -btnBig">

            <span class="sds-icon sds-icon-plus"></span>

        </a>
    </div>
    <div class="sds-panelHeader__actionGroup -big">
        <div class="sds-accountSelector dropdown">
            <div class="sds-accountSelector__content sds-stackXs">
                <div class="h4">{Account Name}</div>
                <div class="sds-accountSelector__number sds-textHelper">LU## #### #### #### ####</div>

                <div class="sds-amount -amountPositive -amountLg">

                    <div class="sds-amount__body">
                        <span class="sds-amount__value">{+#.###,##}</span>

                        <span class="sds-amount__currency"></span>

                    </div>

                </div>

            </div>
            <div class="sds-accountSelector__actions">
                <button type="button" class="sds-btn -iconBtn -btnSecondary sds-accountSelector__btn stretched-link" data-toggle="dropdown" aria-expanded="false" data-display="static">

                    <span class="sds-icon sds-icon-chevrondown"></span>

                    <div class="sr-only">Toggle account selector dropdown with accounts</div>

                </button>
                <div class="sds-accountSelector__dropdown dropdown-menu dropdown-menu-right">
                    <form class="sds-stackMd" action="">
                        <div class="sds-accountSelector__dropdownHeading h3">Mes comptes personnels</div>
                        <div class="sds-stackSm">
                            <div class="h4">Comptes et cartes</div>
                            <div class="sds-accountSelector__dropdownSection sds-stackSm">
                                <div class="sds-accountCard sds-showCustomIndicatorHover">
                                    <label class="sds-accountCard__inner">
                                        <input value="radio-value" type="radio" name="radio-name" class="sr-only sds-accountCard__input" id="" checked><span class="sds-radioDot  sds-accountCard__checkItem" aria-hidden="true"></span>

                                        <div class="sds-avatar centeredBgi -avatarSm">

                                            <img class="img-fluid" src="../../media/snet/avatars/avatarUser.png" alt="">

                                        </div>

                                        <span class="sds-accountCard__content sds-stackXs">
                                            <div>
                                                Jil Schmit

                                            </div>
                                            <span class="sds-textHelper sds-accountCard__meta">
                                                compte courant
                                            </span>
                                        </span>

                                        <div class="sds-amount -amountPositive -amountLg">

                                            <div class="sds-amount__body">
                                                <span class="sds-amount__value">{+#.###,##}</span>

                                                <span class="sds-amount__currency"></span>

                                            </div>

                                        </div>

                                    </label>
                                </div>
                                <div class="sds-accountCard sds-showCustomIndicatorHover">
                                    <label class="sds-accountCard__inner">
                                        <input value="radio-value" type="radio" name="radio-name" class="sr-only sds-accountCard__input" id=""><span class="sds-radioDot  sds-accountCard__checkItem" aria-hidden="true"></span>

                                        <div class="sds-avatar centeredBgi -avatarSm">

                                            <img class="img-fluid" src="../../media/snet/avatars/avatarUser.png" alt="">

                                        </div>

                                        <span class="sds-accountCard__content sds-stackXs">
                                            <div>
                                                Jil Schmit

                                            </div>
                                            <span class="sds-textHelper sds-accountCard__meta">
                                                compte courant
                                            </span>
                                        </span>

                                        <div class="sds-amount -amountPositive -amountLg">

                                            <div class="sds-amount__body">
                                                <span class="sds-amount__value">{+#.###,##}</span>

                                                <span class="sds-amount__currency"></span>

                                            </div>

                                        </div>

                                    </label>
                                </div>
                                <div class="sds-accountCard sds-showCustomIndicatorHover">
                                    <label class="sds-accountCard__inner">
                                        <input value="radio-value" type="radio" name="radio-name" class="sr-only sds-accountCard__input" id=""><span class="sds-radioDot  sds-accountCard__checkItem" aria-hidden="true"></span>

                                        <div class="sds-avatar centeredBgi -avatarSm">

                                            <img class="img-fluid" src="../../media/snet/avatars/avatarUser.png" alt="">

                                        </div>

                                        <span class="sds-accountCard__content sds-stackXs">
                                            <div>
                                                Jil Schmit

                                            </div>
                                            <span class="sds-textHelper sds-accountCard__meta">
                                                compte courant
                                            </span>
                                        </span>

                                        <div class="sds-amount -amountPositive -amountLg">

                                            <div class="sds-amount__body">
                                                <span class="sds-amount__value">{+#.###,##}</span>

                                                <span class="sds-amount__currency"></span>

                                            </div>

                                        </div>

                                    </label>
                                </div>
                            </div>
                        </div>
                        <div class="sds-stackSm">
                            <div class="h4">Epargne</div>
                            <div class="sds-accountSelector__dropdownSection sds-stackSm">
                                <div class="sds-accountCard sds-showCustomIndicatorHover">
                                    <label class="sds-accountCard__inner">
                                        <input value="radio-value" type="radio" name="radio-name" class="sr-only sds-accountCard__input" id=""><span class="sds-radioDot  sds-accountCard__checkItem" aria-hidden="true"></span>

                                        <div class="sds-avatar centeredBgi -avatarSm">

                                            <img class="img-fluid" src="../../media/snet/avatars/avatarUser.png" alt="">

                                        </div>

                                        <span class="sds-accountCard__content sds-stackXs">
                                            <div>
                                                Jil Schmit

                                            </div>
                                            <span class="sds-textHelper sds-accountCard__meta">
                                                compte courant
                                            </span>
                                        </span>

                                        <div class="sds-amount -amountPositive -amountLg">

                                            <div class="sds-amount__body">
                                                <span class="sds-amount__value">{+#.###,##}</span>

                                                <span class="sds-amount__currency"></span>

                                            </div>

                                        </div>

                                    </label>
                                </div>
                            </div>
                        </div>
                        <div class="sds-stackSm">
                            <div class="h4">Investissements</div>
                            <div class="sds-accountSelector__dropdownSection sds-stackSm">
                                <div class="sds-accountCard sds-showCustomIndicatorHover">
                                    <label class="sds-accountCard__inner">
                                        <input value="radio-value" type="radio" name="radio-name" class="sr-only sds-accountCard__input" id=""><span class="sds-radioDot  sds-accountCard__checkItem" aria-hidden="true"></span>

                                        <div class="sds-avatar centeredBgi -avatarSm">

                                            <img class="img-fluid" src="../../media/snet/avatars/avatarUser.png" alt="">

                                        </div>

                                        <span class="sds-accountCard__content sds-stackXs">
                                            <div>
                                                Jil Schmit

                                            </div>
                                            <span class="sds-textHelper sds-accountCard__meta">
                                                compte courant
                                            </span>
                                        </span>

                                        <div class="sds-amount -amountPositive -amountLg">

                                            <div class="sds-amount__body">
                                                <span class="sds-amount__value">{+#.###,##}</span>

                                                <span class="sds-amount__currency"></span>

                                            </div>

                                        </div>

                                    </label>
                                </div>
                            </div>
                        </div>
                        <div class="sds-stackSm">
                            <div class="h4">Prêts</div>
                            <div class="sds-accountSelector__dropdownSection sds-stackSm">
                                <div class="sds-accountCard sds-showCustomIndicatorHover">
                                    <label class="sds-accountCard__inner">
                                        <input value="radio-value" type="radio" name="radio-name" class="sr-only sds-accountCard__input" id=""><span class="sds-radioDot  sds-accountCard__checkItem" aria-hidden="true"></span>

                                        <div class="sds-avatar centeredBgi -avatarSm">

                                            <img class="img-fluid" src="../../media/snet/avatars/avatarUser.png" alt="">

                                        </div>

                                        <span class="sds-accountCard__content sds-stackXs">
                                            <div>
                                                Jil Schmit

                                            </div>
                                            <span class="sds-textHelper sds-accountCard__meta">
                                                compte courant
                                            </span>
                                        </span>

                                        <div class="sds-amount -amountPositive -amountLg">

                                            <div class="sds-amount__body">
                                                <span class="sds-amount__value">{+#.###,##}</span>

                                                <span class="sds-amount__currency"></span>

                                            </div>

                                        </div>

                                    </label>
                                </div>
                            </div>
                        </div>
                    </form>
                </div>

            </div>
        </div>
    </div>

    <div class="sds-panelHeader__alignEnd">

        <div class="sds-panelHeader__actionGroup">
            <a href="" class="sds-btn -btnSecondary">

                <span class="sds-icon sds-icon-search"></span>

                <span class="sds-btn__text">Recherche</span>

            </a>
        </div>
        <div class="sds-panelHeader__actionGroup">
            <button type="button" class="sds-btn -iconBtn -btnSecondary">

                <span class="sds-icon sds-icon-documentdata"></span>

            </button>
            <button type="button" class="sds-btn -iconBtn -btnSecondary">

                <span class="sds-icon sds-icon-printer"></span>

            </button>
            <div class="dropdown">

                <button type="button" class="sds-btn -iconBtn -btnSecondary dropdown-toggle" data-toggle="dropdown" data-display="static">

                    <span class="sds-icon sds-icon-more"></span>

                </button>

                <div aria-labelledby="" class="sds-actionMenu dropdown-menu dropdown-menu-right dropdown-menu-right">

                    <a href="" class="sds-actionMenu__item dropdown-item">
                        <span class="sds-iconCircle -secondary10" aria-hidden="true">

                            <span class="sds-icon sds-icon-edit"></span>

                        </span>

                        <span>Renommer</span>
                    </a>

                    <a href="" class="sds-actionMenu__item dropdown-item">
                        <span class="sds-iconCircle -secondary10" aria-hidden="true">

                            <span class="sds-icon sds-icon-infocircleborder"></span>

                        </span>

                        <span>Informations</span>
                    </a>

                    <a href="" class="sds-actionMenu__item dropdown-item">
                        <span class="sds-iconCircle -secondary10" aria-hidden="true">

                            <span class="sds-icon sds-icon-tablesetup"></span>

                        </span>

                        <span>Modification limite</span>
                    </a>

                    <a href="" class="sds-actionMenu__item dropdown-item">
                        <span class="sds-iconCircle -secondary10" aria-hidden="true">

                            <span class="sds-icon sds-icon-gear"></span>

                        </span>

                        <span>Paramètres de paiement</span>
                    </a>

                </div>
            </div>
        </div>

    </div>

</div>
{% extends "@snet-panel-header-frame" %}
{% block contentStart %}
	<div class="{{ namespace }}panelHeader__actionGroup {{ namespace }}panelHeader__back">
		{% render "@icon-btn-secondary",{
			disabled: disabled,
			icon: "icon-arrowprevious"
		},true %}
	</div>
	<div class="{{ namespace }}panelHeader__actionGroup -big -timelineStart">
		{% render "@icon-btn-primary--big",{
			disabled: disabled,
			eltType: "a"
		},true %}
	</div>
	<div class="{{ namespace }}panelHeader__actionGroup -big">
		{% render "@snet-account-selector" %}
	</div>
{% endblock %}
{% block contentEnd %}
	<div class="{{ namespace }}panelHeader__actionGroup">
		{% render "@btn-secondary--icon-left",{
			eltType: "a",
			icon: "icon-search",
			text: "Recherche",
			disabled: disabled
		},true %}
	</div>
	<div class="{{ namespace }}panelHeader__actionGroup">
		{% render "@icon-btn-secondary",{
			disabled: disabled,
			icon: "icon-documentdata"
		},true %}
		{% render "@icon-btn-secondary",{
			disabled: disabled,
			icon: "icon-printer"
		},true %}
		<div class="dropdown">
			{% if dropdownLoading %}
			{% render "@icon-btn-secondary--disabled-loading",{
				disabled: disabled,
				icon: "icon-more",
				classes: ["dropdown-toggle"],
				attrs: {
					"data-toggle": "dropdown",
					"data-display": "static"
				}
			},true %}
				{% else %}
			{% render "@icon-btn-secondary",{
				disabled: disabled,
				icon: "icon-more",
				classes: ["dropdown-toggle"],
				attrs: {
					"data-toggle": "dropdown",
					"data-display": "static"
				}
			},true %}
			{% endif %}

			{% render "@snet-action-menu--mouvements-cartes",{classes: ["dropdown-menu-right"]},true %}
		</div>
	</div>
{% endblock %}
  • Content:
    export default class PanelHeader {
    
    	constructor() {
    		this.fireHeadroom()
    	}
    
    	fireHeadroom () {
    
    		let stickyHeader = document.querySelector(".-headroom");
    
    		if (CSS && CSS.supports && CSS.supports("position", "sticky")) {
    			if(stickyHeader) {
    				let options = {
    					// vertical offset in px before element is first unpinned
    					offset : document.querySelector('.sds-navTopbar').clientHeight + document.querySelector('.-headroom').clientHeight,
    					// or you can specify offset individually for up/down scroll
    
    					// scroll tolerance in px before state changes
    					tolerance : 0,
    					// or you can specify tolerance individually for up/down scroll
    
    					// css classes to apply
    					classes : {
    						// when element is initialised
    						initial : "-headroom",
    						// when scrolling up
    						pinned : "-headroomPinned",
    						// when scrolling down
    						unpinned : "-headroomUnpinned",
    						// when above offset
    						top : "-headroomTop",
    						// when below offset
    						notTop : "-headroomNotTop",
    						// when at bottom of scroll area
    						bottom : "-headroomBottom",
    						// when not at bottom of scroll area
    						notBottom : "-headroomNotBottom",
    						// when frozen method has been called
    						frozen: "-headroomFrozen"
    
    					},
    
    					// callback when pinned, `this` is headroom object
    					onPin : function() {
    						$('.sds-stickySidebar').css("top", document.querySelector(".sds-navTopbar").clientHeight + document.querySelector('.-headroom').clientHeight + 8);
    						$('.sds-reactsToPanelHeader')?.css("top", document.querySelector(".sds-navTopbar").clientHeight + document.querySelector('.-headroom').clientHeight);
    					},
    					// callback when unpinned, `this` is headroom object
    					onUnpin : function() {
    						$('.sds-stickySidebar').css("top", (document.querySelector(".sds-navTopbar").clientHeight) + 8)
    						$('.sds-reactsToPanelHeader')?.css("top", (document.querySelector(".sds-navTopbar").clientHeight))
    					},
    					// callback when above offset, `this` is headroom object
    					onTop : function() {
    						$('.sds-stickySidebar').css("top", document.querySelector(".sds-navTopbar").clientHeight + document.querySelector('.-headroom').clientHeight)
    					},
    					// callback when below offset, `this` is headroom object
    					onNotTop : function() {},
    					// callback when at bottom of page, `this` is headroom object
    					onBottom : function() {},
    					// callback when moving away from bottom of page, `this` is headroom object
    					onNotBottom : function() {}
    				};
    				let headroom = new Headroom(stickyHeader, options);
    				headroom.init();
    			}
    		} else {
    			console.log("no position: sticky; support");
    		}
    
    	}
    
    }
    
  • URL: /components/raw/snet-panel-header/PanelHeader.js
  • Filesystem Path: components/snet/organisms/panel-header/PanelHeader.js
  • Size: 2.7 KB
  • Content:
    @use "sass:math";
    /* variables specific to current element */
    
    $panel-header-padding-bottom: map-deep-get($token-spacer-inset-map, "sm");
    
    .#{$namespace}panelHeader {
    
    	/* Save root element context for easy access if nesting is needed */
    
    	$self: &;
    
    	/* properties of current element  + media queries */
    
    	min-height: map-deep-get($token-sizes-component-map, "panel-header-height");
    	display: flex;
    	align-items: flex-start;
    	flex-wrap: wrap;
    	@include spacer-component-inline("xl");
    	padding-top: map-deep-get($token-spacer-inset-map, "md");
    	padding-bottom: $panel-header-padding-bottom;
    
    	@include media-breakpoint-up(md){
    		padding-top: map-deep-get($token-spacer-inset-map, "lg");
    	}
    
    	/* 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 */
    
    	&__container {
    
    		margin: 0 auto !important;
    		display: flex;
    		align-items: flex-start;
    		flex-wrap: wrap;
    	}
    
    	// panelHeader__back
    	&__back {
    
    		// follows same logic as parent
    
    		margin-right: map-deep-get($token-spacer-unit-map, "32");
    		flex-grow: 0;
    
    	}
    
    	&__alignEnd {
    
    		@include spacer-component-inline("xl");
    		display: flex;
    		align-items: center;
    		justify-content: flex-end;
    		margin-left: auto;
    		margin-bottom: map-deep-get($token-spacer-stack-max-map, "sm");
    
    		order: -1;
    		width: 100%;
    
    		@include media-breakpoint-up(lg){
    			order: 1;
    			width: auto;
    			margin-bottom: 0;
    		}
    
    	}
    
    	&__actionGroup {
    
    		@include spacer-component-inline("sm");
    		display: flex;
    		align-items: center;
    		min-height: 40px;
    
    		&.-alignEnd {
    
    			margin-left: auto;
    
    		}
    
    		&.-big {
    
    			margin-top: -(map-deep-get($token-spacer-unit-map, "12"));
    
    		}
    
    		&.-medium {
    
    			margin-top: -(map-deep-get($token-spacer-unit-map, "8"));
    
    		}
    
    		&.-timelineStart {
    
    			position: relative;
    			z-index: z("low");
    			margin-left: map-deep-get($design-tokens,"comp-icon-button-large-width") + map-deep-get($token-spacer-inline-map, "sm") + math.div(map-deep-get($token-spacer-inline-map, "sm"), 2);
    			align-self: stretch;
    			align-items: flex-start;
    
    			&::before {
    
    				content: "";
    				position: absolute;
    				z-index: z("negative");
    				top: 50%;
    				left: 50%;
    				transform: translateX(-50%);
    				bottom: -($panel-header-padding-bottom);
    				width: $border-width*2;
    				background-color: map-deep-get($token-color-brand-map, "secondary", "30");
    
    			}
    
    		}
    		
    	}
    
    	.sds-searchGrowing {
    
    
    	}
    
    	//&__dropdownMenuFilters {
    	//
    	//	top: map-deep-get($token-spacer-unit-map, "8") !important;
    	//	left: -(map-deep-get($token-spacer-unit-map, "24")) !important;
    	//
    	//}
    
    
    	/* modifiers */
    
    	// panelHeader -altStyle
    
    	/* random parent element */
    	/* 
    	*
    	*   Syntax : .randomParentElt & {}
    	*
    	*/
    
    	/* Pseudo Classes */
    
    	&:hover {
    		@media (hover: hover) {
    
    		}
    	}
    
    	&:focus {
    	}
    
    	&:active {
    	}
    
    	&:focus,
    	&:active {
    	}
    
    }
  • URL: /components/raw/snet-panel-header/_panel-header.scss
  • Filesystem Path: components/snet/organisms/panel-header/_panel-header.scss
  • Size: 3 KB