Center VSF register step object card
This commit is contained in:
@@ -8,221 +8,30 @@
|
|||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<h1 class="sg-main-heading">Registriere dich bei ValueStockFinder</h1>
|
<main class="sg-vsf-register-step-1">
|
||||||
|
<article class="sg-card sg-object-card sg-vsf-register-step-1__card" data-pattern="object-card" aria-label="Registriere dich">
|
||||||
<section id="pattern-portal-header">
|
<header class="sg-card-segment sg-card-segment--header sg-card-segment--darkblue sg-object-card__header" data-pattern-part="object-card-header">
|
||||||
<article class="sg-portal-header-pattern-variant" aria-label="Portal Header ohne Options Row">
|
<div class="sg-strong">Registriere dich.</div>
|
||||||
<header class="sg-portal-header" aria-label="Portal Header" data-pattern="portal-header">
|
<div class="sg-sandwich-menu-wrap" data-open="false" data-align="right" data-component="sandwich-menu" data-component-size="small">
|
||||||
<div class="sg-portal-header__main" data-pattern-part="portal-header-main">
|
<button class="sg-interaction-element sg-sandwich-button sg-sandwich-button--small" type="button" aria-expanded="false" aria-label="Menü öffnen" data-component-part="sandwich-trigger">
|
||||||
<p class="sg-portal-header__brand sg-brand-title" data-pattern-part="portal-header-brand">ValueStockFinder</p>
|
<span class="sg-sandwich-button__icon" aria-hidden="true">
|
||||||
|
<span class="sg-sandwich-button__line"></span>
|
||||||
<div class="sg-portal-header__menu-wrap" data-pattern-part="portal-header-action">
|
<span class="sg-sandwich-button__line"></span>
|
||||||
<div class="sg-component-row">
|
<span class="sg-sandwich-button__line"></span>
|
||||||
<button class="sg-interaction-element sg-button sg-button--active" type="button" data-component="button" data-component-state="active">
|
</span>
|
||||||
Login
|
</button>
|
||||||
</button>
|
<div class="sg-sandwich-menu-panel" aria-label="Ausgeklapptes Menü" data-component-part="sandwich-panel">
|
||||||
|
<a class="sg-sandwich-menu-link" href="#">Menüpunkt</a>
|
||||||
<button class="sg-interaction-element sg-button sg-button--active" type="button" data-component="button" data-component-state="active">
|
<a class="sg-sandwich-menu-link" href="#">Menüpunkt</a>
|
||||||
Registrieren
|
<a class="sg-sandwich-menu-link" href="#">Menüpunkt</a>
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<nav class="sg-portal-header__tabs sg-tab-button-group" aria-label="Hauptnavigation" data-component="tab-navigation" data-component-size="large" data-component-context="portal-header" data-pattern-part="portal-header-navigation">
|
|
||||||
<button class="sg-interaction-element sg-button sg-tab-button" type="button" aria-selected="true" data-component-part="tab-button" data-component-state="active">Übersicht</button>
|
|
||||||
<button class="sg-interaction-element sg-button sg-tab-button" type="button" aria-selected="false" data-component-part="tab-button" data-component-state="inactive">Features</button>
|
|
||||||
<button class="sg-interaction-element sg-button sg-tab-button" type="button" aria-selected="false" data-component-part="tab-button" data-component-state="inactive">Preise</button>
|
|
||||||
<button class="sg-interaction-element sg-button sg-tab-button" type="button" aria-selected="false" data-component-part="tab-button" data-component-state="inactive">Firma der Woche</button>
|
|
||||||
</nav>
|
|
||||||
</div>
|
</div>
|
||||||
</header>
|
</header>
|
||||||
|
<div class="sg-card-segment sg-card-segment--body sg-object-card__content" data-pattern-part="object-card-content">
|
||||||
<div class="sg-transparent-card sg-portal-header-pattern-variant__next-element" aria-label="Willkommen bei ValueStockFinder" data-component="transparent-card">
|
<p class="sg-body">Teste ValueStockFinder 7 Tage kostenlos und unverbindlich. Erhalte direkten Zugriff auf fundierte Aktienanalysen, klare Bewertungen und übersichtliche Entscheidungshilfen – ohne Verpflichtung.</p>
|
||||||
<h1 class="sg-heading-h1 sg-text-on-dark">Registriere dich bei ValueStockFinder</h1>
|
|
||||||
</div>
|
</div>
|
||||||
</article>
|
</article>
|
||||||
|
</main>
|
||||||
</section>
|
|
||||||
|
|
||||||
<script src="../scripts/help-icon-overlays.js"></script>
|
|
||||||
<script>
|
|
||||||
document.querySelectorAll('.sg-portal-header__tabs').forEach((group) => {
|
|
||||||
group.querySelectorAll('.sg-tab-button').forEach((button) => {
|
|
||||||
button.addEventListener('click', () => {
|
|
||||||
group.querySelectorAll('.sg-tab-button').forEach((otherButton) => {
|
|
||||||
const isActive = otherButton === button;
|
|
||||||
otherButton.setAttribute('aria-selected', String(isActive));
|
|
||||||
otherButton.dataset.componentState = isActive ? 'active' : 'inactive';
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
document.querySelectorAll('.sg-sandwich-menu-wrap').forEach((wrap) => {
|
|
||||||
const button = wrap.querySelector('.sg-sandwich-button');
|
|
||||||
|
|
||||||
button.addEventListener('click', (event) => {
|
|
||||||
event.stopPropagation();
|
|
||||||
const nextState = wrap.dataset.open !== 'true';
|
|
||||||
document.querySelectorAll('.sg-sandwich-menu-wrap').forEach((otherWrap) => {
|
|
||||||
const otherButton = otherWrap.querySelector('.sg-sandwich-button');
|
|
||||||
otherWrap.dataset.open = 'false';
|
|
||||||
if (otherButton) {
|
|
||||||
otherButton.setAttribute('aria-expanded', 'false');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
wrap.dataset.open = String(nextState);
|
|
||||||
button.setAttribute('aria-expanded', String(nextState));
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
document.querySelectorAll('.sg-mode-toggle').forEach((toggle) => {
|
|
||||||
toggle.addEventListener('click', () => {
|
|
||||||
const nextState = toggle.dataset.active === 'relative' ? 'absolute' : 'relative';
|
|
||||||
toggle.dataset.active = nextState;
|
|
||||||
toggle.dataset.componentState = nextState;
|
|
||||||
toggle.setAttribute(
|
|
||||||
'aria-label',
|
|
||||||
`Modus Schieber global: ${nextState === 'relative' ? 'relativ' : 'absolut'} aktiv`
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
const updatePulldownSelectionState = (demo) => {
|
|
||||||
const trigger = demo.querySelector('.sg-pulldown-demo__trigger');
|
|
||||||
const selectableOptions = demo.querySelectorAll('[data-pulldown-option]');
|
|
||||||
|
|
||||||
if (!trigger || selectableOptions.length === 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const selectedCount = Array.from(selectableOptions).filter((option) => {
|
|
||||||
return option.getAttribute('aria-checked') === 'true';
|
|
||||||
}).length;
|
|
||||||
|
|
||||||
selectableOptions.forEach((option) => {
|
|
||||||
const optionRow = option.closest('.sg-pulldown-option');
|
|
||||||
if (!optionRow) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
optionRow.classList.toggle(
|
|
||||||
'sg-pulldown-option--selected',
|
|
||||||
option.getAttribute('aria-checked') === 'true'
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
const labelBase = trigger.dataset.labelBase || 'Auswahl';
|
|
||||||
|
|
||||||
trigger.textContent = selectedCount > 0 ? `${labelBase} (${selectedCount})` : labelBase;
|
|
||||||
trigger.classList.toggle('sg-pulldown--selected', selectedCount > 0);
|
|
||||||
trigger.classList.toggle('sg-form-active', selectedCount > 0);
|
|
||||||
trigger.dataset.componentState = selectedCount > 0 ? 'selected' : 'inactive-selectable';
|
|
||||||
demo.dataset.componentState = selectedCount > 0 ? 'selected' : 'inactive-selectable';
|
|
||||||
trigger.setAttribute(
|
|
||||||
'aria-label',
|
|
||||||
selectedCount > 0 ? `Pulldown ${labelBase} mit aktiver Auswahl` : `Pulldown ${labelBase} ohne aktive Auswahl`
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
document.querySelectorAll('.sg-pulldown-demo').forEach((demo) => {
|
|
||||||
const trigger = demo.querySelector('.sg-pulldown-demo__trigger');
|
|
||||||
|
|
||||||
if (!trigger) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
trigger.addEventListener('click', (event) => {
|
|
||||||
event.stopPropagation();
|
|
||||||
const nextState = demo.dataset.open !== 'true';
|
|
||||||
|
|
||||||
document.querySelectorAll('.sg-pulldown-demo').forEach((otherDemo) => {
|
|
||||||
const otherTrigger = otherDemo.querySelector('.sg-pulldown-demo__trigger');
|
|
||||||
otherDemo.dataset.open = 'false';
|
|
||||||
if (otherTrigger) {
|
|
||||||
otherTrigger.setAttribute('aria-expanded', 'false');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
demo.dataset.align = 'left';
|
|
||||||
demo.dataset.open = String(nextState);
|
|
||||||
trigger.setAttribute('aria-expanded', String(nextState));
|
|
||||||
|
|
||||||
if (!nextState) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const panel = demo.querySelector('.sg-pulldown-panel');
|
|
||||||
if (!panel) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const panelRect = panel.getBoundingClientRect();
|
|
||||||
if (panelRect.right > window.innerWidth) {
|
|
||||||
demo.dataset.align = 'right';
|
|
||||||
}
|
|
||||||
|
|
||||||
const alignedPanelRect = panel.getBoundingClientRect();
|
|
||||||
if (alignedPanelRect.left < 0) {
|
|
||||||
demo.dataset.align = 'left';
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
document.querySelectorAll('.sg-checkbox-field').forEach((checkbox) => {
|
|
||||||
checkbox.addEventListener('click', (event) => {
|
|
||||||
event.stopPropagation();
|
|
||||||
if (checkbox.disabled) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const nextState = checkbox.getAttribute('aria-checked') !== 'true';
|
|
||||||
checkbox.setAttribute('aria-checked', String(nextState));
|
|
||||||
|
|
||||||
const pulldownDemo = checkbox.closest('.sg-pulldown-demo');
|
|
||||||
if (pulldownDemo) {
|
|
||||||
updatePulldownSelectionState(pulldownDemo);
|
|
||||||
pulldownDemo.dataset.open = 'true';
|
|
||||||
const trigger = pulldownDemo.querySelector('.sg-pulldown-demo__trigger');
|
|
||||||
if (trigger) {
|
|
||||||
trigger.setAttribute('aria-expanded', 'true');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
document.querySelectorAll('.sg-pulldown-option[data-pulldown-option]').forEach((option) => {
|
|
||||||
option.addEventListener('click', (event) => {
|
|
||||||
event.stopPropagation();
|
|
||||||
const pulldownDemo = option.closest('.sg-pulldown-demo');
|
|
||||||
if (pulldownDemo) {
|
|
||||||
const selectionMode = pulldownDemo.dataset.selectionMode || 'single';
|
|
||||||
if (selectionMode === 'multiple') {
|
|
||||||
const nextState = option.getAttribute('aria-checked') !== 'true';
|
|
||||||
option.setAttribute('aria-checked', String(nextState));
|
|
||||||
} else {
|
|
||||||
pulldownDemo.querySelectorAll('[data-pulldown-option]').forEach((otherOption) => {
|
|
||||||
otherOption.setAttribute('aria-checked', String(otherOption === option));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
updatePulldownSelectionState(pulldownDemo);
|
|
||||||
const trigger = pulldownDemo.querySelector('.sg-pulldown-demo__trigger');
|
|
||||||
if (selectionMode === 'multiple') {
|
|
||||||
pulldownDemo.dataset.open = 'true';
|
|
||||||
if (trigger) {
|
|
||||||
trigger.setAttribute('aria-expanded', 'true');
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
pulldownDemo.dataset.open = 'false';
|
|
||||||
if (trigger) {
|
|
||||||
trigger.setAttribute('aria-expanded', 'false');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
@@ -15,6 +15,7 @@
|
|||||||
@import "./styles/30-layouts-card-list-page.css";
|
@import "./styles/30-layouts-card-list-page.css";
|
||||||
@import "./styles/33-layouts-vsf-list-detailseite.css";
|
@import "./styles/33-layouts-vsf-list-detailseite.css";
|
||||||
@import "./styles/34-layouts-vsf-listen-uebersicht-seite-v2.css";
|
@import "./styles/34-layouts-vsf-listen-uebersicht-seite-v2.css";
|
||||||
|
@import "./styles/35-layouts-vsf-register-step-1.css";
|
||||||
@import "./styles/31-patterns-text-layouts.css";
|
@import "./styles/31-patterns-text-layouts.css";
|
||||||
@import "./styles/32-patterns-card-group-keyboard-nav.css";
|
@import "./styles/32-patterns-card-group-keyboard-nav.css";
|
||||||
@import "./styles/40-components-cards.css";
|
@import "./styles/40-components-cards.css";
|
||||||
|
|||||||
@@ -0,0 +1,16 @@
|
|||||||
|
/* ========================================================= */
|
||||||
|
/* Layouts: VSF Register Step 1 */
|
||||||
|
/* ========================================================= */
|
||||||
|
|
||||||
|
.sg-vsf-register-step-1 {
|
||||||
|
display: grid;
|
||||||
|
place-items: center;
|
||||||
|
min-height: 100vh;
|
||||||
|
padding: 1vh var(--layout-page-content-inset-inline) 0;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sg-vsf-register-step-1__card {
|
||||||
|
width: 100%;
|
||||||
|
max-width: var(--layout-object-card-max-width);
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user