feat(SW-1259): Enter details multiroom * refactor: remove per-step URLs * WIP: map multiroom data * fix: lint errors in details page * fix: made useEnterDetailsStore tests pass * fix: WIP refactor enter details store * fix: WIP enter details store update * fix: added room index to select correct room * fix: added logic for navigating between steps and rooms * fix: update summary to work with store changes * fix: added room and total price calculation * fix: removed unused code and added test for breakfast included * refactor: move store selectors into helpers * refactor: session storage state for multiroom booking * feat: update enter details accordion navigation * fix: added room index to each form component so they select correct room * fix: added unique id to input to handle case when multiple inputs have same name * fix: update payment step with store changes * fix: rebase issues * fix: now you should only be able to go to a step if previous room is completed * refactor: cleanup * fix: if no availability just skip that room for now * fix: add select-rate Summary and adjust typings Approved-by: Arvid Norlin
102 lines
1.5 KiB
CSS
102 lines
1.5 KiB
CSS
.summary {
|
|
border-radius: var(--Corner-radius-Large);
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--Spacing-x2);
|
|
padding: var(--Spacing-x3);
|
|
height: 100%;
|
|
}
|
|
|
|
.header {
|
|
display: grid;
|
|
grid-template-areas: "title button" "date button";
|
|
}
|
|
|
|
.title {
|
|
grid-area: title;
|
|
}
|
|
|
|
.chevronButton {
|
|
grid-area: button;
|
|
justify-self: end;
|
|
align-items: center;
|
|
margin-right: calc(0px - var(--Spacing-x2));
|
|
}
|
|
|
|
.date {
|
|
align-items: center;
|
|
display: flex;
|
|
gap: var(--Spacing-x1);
|
|
justify-content: flex-start;
|
|
grid-area: date;
|
|
}
|
|
|
|
.link {
|
|
margin-top: var(--Spacing-x1);
|
|
}
|
|
|
|
.addOns {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--Spacing-x-one-and-half);
|
|
overflow-y: auto;
|
|
}
|
|
|
|
.rateDetailsPopover {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--Spacing-x-half);
|
|
max-width: 360px;
|
|
}
|
|
|
|
.entry {
|
|
display: flex;
|
|
gap: var(--Spacing-x-half);
|
|
justify-content: space-between;
|
|
}
|
|
|
|
.entry > :last-child {
|
|
justify-items: flex-end;
|
|
}
|
|
|
|
.total {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--Spacing-x2);
|
|
}
|
|
|
|
.bottomDivider {
|
|
display: none;
|
|
}
|
|
|
|
.modalContent {
|
|
width: 560px;
|
|
}
|
|
|
|
.terms {
|
|
margin-top: var(--Spacing-x3);
|
|
margin-bottom: var(--Spacing-x3);
|
|
}
|
|
.termsText:nth-child(n) {
|
|
display: flex;
|
|
align-items: center;
|
|
margin-bottom: var(--Spacing-x1);
|
|
}
|
|
.terms .termsIcon {
|
|
margin-right: var(--Spacing-x1);
|
|
}
|
|
|
|
@media screen and (min-width: 1367px) {
|
|
.bottomDivider {
|
|
display: block;
|
|
}
|
|
|
|
.header {
|
|
display: block;
|
|
}
|
|
|
|
.summary .header .chevronButton {
|
|
display: none;
|
|
}
|
|
}
|