No notes defined.
<div class="sds-activityLog">
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeDanger -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-crosscircleborder" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Non exécuté</p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeDanger -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-minuscircleborder" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Annulé <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeSuccess -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-check" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Traité <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeSuccess -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-checkcirclefill" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Exécuté <span class="sds-activityLog__meta">par la banque</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeInfo -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-checkcircleborder" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Exécuté partiellement <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeSuccess -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-checkcirclefill" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Validé <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeWarning -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-sign" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Validé partiellement <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
<span class="sds-badge badge -badgeInfo -badgeMuted -badgeIcon">
<span class="sds-icon sds-icon-edit" aria-hidden="true"></span>
<span class="sr-only">Draft</span>
</span>
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Modifié <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
<div class="sds-activityLog__row">
<span class="sds-itemConnector sds-activityLog__itemConnector">
</span>
<div class="sds-activityLog__rowContent sds-stackXxs">
<p>Saisi <span class="sds-activityLog__meta">par {User}</span></p>
<small class="sds-activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
</div>
<div class="{{ namespace }}activityLog{% for mod in modifiers %} {{ mod }}{% endfor %}{% for mod in classes %} {{ mod }}{% endfor %}">
{% for key, item in rows %}
{% if item %}
<div class="{{ namespace }}activityLog__row">
{% if item.connectorEmpty %}
{% render "@item-connector--default",item.options,true %}
{% else %}
{% render "@item-connector--icon-circle-small",item.options,true %}
{% endif %}
<div class="{{ namespace }}activityLog__rowContent {{ namespace }}stackXxs">
<p>{{ item.action | safe }}{% if item.text %} <span class="{{ namespace }}activityLog__meta">{{ item.text | safe }}</span>{% endif %}</p>
<small class="{{ namespace }}activityLog__meta">{DD.MM.YYYY • HH:MM}</small>
</div>
</div>
{% endif %}
{% endfor %}
</div>
@use "sass:math";
/* variables specific to current element */
$activity-log-item-divider-left-position: calc(map-deep-get($design-tokens, "comp-activitylog-inset-h") + (map-deep-get($design-tokens, "comp-activitylog-line-divider-width") / 2));
$activity-log-item-divider-stack-position: calc(50% + map-deep-get($design-tokens, "comp-activitylog-line-divider-stack") + (map-deep-get($design-tokens, "comp-badge-height") / 2));
$activity-log-item-align-start-divider-position: calc(map-deep-get($design-tokens, "comp-badge-height") + ((map-deep-get($design-tokens, "comp-activitylog-min-height") - map-deep-get($design-tokens, "comp-badge-height")) / 2) + map-deep-get($design-tokens, "comp-activitylog-line-divider-stack"));
$activity-log-item-divider-avatar-stack-position: calc(50% + map-deep-get($design-tokens, "comp-activitylog-line-divider-stack") + (map-deep-get($design-tokens, "comp-avatar-small-height") / 2));
$activity-log-item-align-start-divider-avatar-position: calc(map-deep-get($design-tokens, "comp-avatar-small-height") + ((map-deep-get($design-tokens, "comp-activitylog-min-height") - map-deep-get($design-tokens, "comp-avatar-small-height")) / 2) + map-deep-get($design-tokens, "comp-activitylog-line-divider-stack"));
.#{$namespace}activityLog {
/* Save root element context for easy access if nesting is needed */
$self: &;
/* properties of current element + media queries */
> * + * {
margin-top: map-deep-get($design-tokens, "comp-activitylog-line-divider-stack");
}
/* 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 */
// activityLog__row
&__row {
// follows same logic as parent
display: flex;
align-items: center;
padding: 0 map-deep-get($design-tokens, "comp-activitylog-inset-h");
border-radius: map-deep-get($design-tokens, "comp-activitylog-border-radius");
@include custom-prop-fallback("color", "sys-color-text-primary-contrast");
position: relative;
z-index: z("zero");
&::before,
&::after {
content: "";
position: absolute;
z-index: z("negative");
left: $activity-log-item-divider-left-position;
transform: translateX(-50%);
width: map-deep-get($design-tokens, "comp-activitylog-line-divider-divider-border-width");
@include custom-prop-fallback("background-color", "comp-activitylog-line-divider-border-color");
}
&::after {
top: 50%;
bottom: 0;
}
&:has(#{$self}__itemConnector > *) {
&::after {
top: $activity-log-item-divider-stack-position;
}
}
&:has(#{$self}__itemConnector > [class*="avatar"]) {
&::after {
top: $activity-log-item-divider-avatar-stack-position;
}
}
& + & {
&::before {
top: calc(-1 * map-deep-get($design-tokens, "comp-activitylog-line-divider-stack"));
bottom: 50%;
}
&:has(#{$self}__itemConnector > *) {
&::before {
bottom: $activity-log-item-divider-stack-position;
}
}
&:has(#{$self}__itemConnector > [class*="avatar"]) {
&::before {
bottom: $activity-log-item-divider-avatar-stack-position;
}
}
}
&:last-child {
&::after {
display: none;
}
}
&:focus-visible {
outline-style: solid;
outline-width: map-deep-get($design-tokens, "comp-activitylog-pressed-border-width");
@include custom-prop-fallback("outline-color", "comp-activitylog-pressed-border-color");
}
&:hover {
@include custom-prop-fallback("background-color", "comp-activitylog-hovered-background-color");
}
}
// .activityLog__rowContent
&__rowContent {
padding: map-deep-get($design-tokens, "comp-activitylog-content-container-inset-v") 0;
}
&__itemConnector {
width: map-deep-get($design-tokens, "comp-activitylog-line-divider-width") !important;
min-height: map-deep-get($design-tokens, "comp-activitylog-min-height") !important;
margin-right: map-deep-get($design-tokens, "comp-activitylog-inline") !important;
&::after {
right: auto !important;
width: math.div($icon-circle-regular-smaller-dimensions-global,2) !important;
}
}
&__avatar {
margin-right: map-deep-get($design-tokens, "comp-activitylog-container-inline") !important;
}
&__meta {
@include custom-prop-fallback("color", "sys-color-text-primary-muted");
font-size: map-deep-get($design-tokens, "sys-font-size-helper-medium") !important;
}
/* modifiers */
// activityLog -noAvatar
&.-noAvatar {
// follows same logic as base element
}
&.-alignStart {
#{$self}__itemConnector {
position: relative !important;
height: auto !important;
}
#{$self}__row {
align-items: flex-start;
&::after {
top: map-deep-get($design-tokens, "comp-badge-height");
}
&:has(#{$self}__itemConnector > *) {
&::after {
top: $activity-log-item-align-start-divider-position;
}
}
&:has(#{$self}__itemConnector > [class*="avatar"]) {
&::after {
top: $activity-log-item-align-start-divider-avatar-position;
}
}
& + #{$self}__row {
&::before {
bottom: auto;
height: calc(map-deep-get($design-tokens, "comp-activitylog-line-divider-stack") + map-deep-get($design-tokens, "comp-badge-height"));
}
&:has(#{$self}__itemConnector > *) {
&::before {
height: calc(map-deep-get($design-tokens, "comp-activitylog-line-divider-stack") + map-deep-get($design-tokens, "comp-activitylog-content-container-inset-v"));
}
}
&:has(#{$self}__itemConnector > [class*="avatar"]) {
&::before {
height: calc(map-deep-get($design-tokens, "comp-activitylog-line-divider-stack") + map-deep-get($design-tokens, "comp-activitylog-line-divider-stack"));
}
}
}
}
#{$self}__avatar {
margin-top: map-deep-get($design-tokens, "comp-activitylog-content-container-inset-v") !important;
}
}
&.-noVerticalSpacing {
> * + * {margin-top: 0}
}
&.-noConnector, // @TODO remove this class after replacing it with seconda one
&.-itemInteraction {
#{$self}__row {
border-radius: map-deep-get($token-radius-map, "16");
&:hover,
&:focus-visible {
@media (hover: hover) {
@include custom-prop-fallback("background-color", "sys-color-elevation-surface-sunken");
}
}
&:focus-visible {
z-index: z("low");
}
}
}
/* random parent element */
/*
*
* Syntax : .randomParentElt & {}
*
*/
/* Pseudo Classes */
&:hover {
@media (hover: hover) {
}
}
&:focus {
}
&:active {
}
&:focus,
&:active {
}
}