-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Prepare Var for C24_WMDE_Desktop_DE_20
- Loading branch information
1 parent
c744cb1
commit 6a3681f
Showing
5 changed files
with
323 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
180 changes: 180 additions & 0 deletions
180
banners/desktop/C24_WMDE_Desktop_DE_20/components/BannerVar.vue
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,180 @@ | ||
<template> | ||
<div class="wmde-banner-wrapper" :class="contentState"> | ||
<MainBanner | ||
@form-interaction="$emit( 'bannerContentChanged' )" | ||
v-if="contentState === ContentStates.Main" | ||
:bannerState="bannerState" | ||
> | ||
<template #close-button> | ||
<ButtonClose @close="onCloseMain"/> | ||
</template> | ||
|
||
<template #banner-title> | ||
<BannerTitle/> | ||
</template> | ||
|
||
<template #banner-text> | ||
<BannerText/> | ||
</template> | ||
|
||
<template #banner-slides="{ play }: any"> | ||
<KeenSlider :with-navigation="true" :play="play" :interval="10000" :delay="2000" :navigation-color="'#ffffff'"> | ||
|
||
<template #slides="{ currentSlide }: any"> | ||
<BannerSlides :currentSlide="currentSlide"/> | ||
</template> | ||
|
||
</KeenSlider> | ||
</template> | ||
|
||
<template #progress> | ||
<ProgressBar amount-to-show-on-right="TARGET"/> | ||
</template> | ||
|
||
<template #donation-form="{ formInteraction }: any"> | ||
<MultiStepDonation | ||
:step-controllers="stepControllers" | ||
@form-interaction="formInteraction" | ||
:submit-callback="onSubmit" | ||
> | ||
|
||
<template #[FormStepNames.MainDonationFormStep]="{ pageIndex, submit, isCurrent, previous }: any"> | ||
<MainDonationForm :page-index="pageIndex" @submit="submit" :is-current="isCurrent" @previous="previous"/> | ||
</template> | ||
|
||
<template #[FormStepNames.UpgradeToYearlyFormStep]="{ pageIndex, submit, isCurrent, previous }: any"> | ||
<UpgradeToYearlyButtonForm :page-index="pageIndex" :show-manual-upgrade-option="false" @submit="submit" :is-current="isCurrent" @previous="previous"/> | ||
</template> | ||
|
||
</MultiStepDonation> | ||
</template> | ||
|
||
<template #footer> | ||
<FooterAlreadyDonated | ||
@showFundsModal="onModalOpened" | ||
@clickedAlreadyDonatedLink="onClose( 'AlreadyDonated', CloseChoices.AlreadyDonated )" | ||
/> | ||
</template> | ||
|
||
</MainBanner> | ||
|
||
<SoftClose | ||
v-if="contentState === ContentStates.SoftClosing" | ||
:show-close-icon="true" | ||
@close="() => onClose( 'SoftClose', CloseChoices.Close )" | ||
@maybeLater="() => onClose( 'SoftClose', CloseChoices.MaybeLater )" | ||
@timeOutClose="() => onClose( 'SoftClose', CloseChoices.TimeOut )" | ||
@maybeLater7Days="() => onClose('SoftClose', CloseChoices.Close)" | ||
/> | ||
|
||
<FundsModal | ||
:content="useOfFundsContent" | ||
:is-funds-modal-visible="isFundsModalVisible" | ||
@hideFundsModal="onHideFundsModal" | ||
> | ||
<template #infographic> | ||
<WMDEFundsForwardingDE/> | ||
</template> | ||
</FundsModal> | ||
</div> | ||
</template> | ||
|
||
<script setup lang="ts"> | ||
import { BannerStates } from '@src/components/BannerConductor/StateMachine/BannerStates'; | ||
import { inject, ref, watch } from 'vue'; | ||
import { UseOfFundsContent as useOfFundsContentInterface } from '@src/domain/UseOfFunds/UseOfFundsContent'; | ||
import MainBanner from './MainBannerVar.vue'; | ||
import FundsModal from '@src/components/UseOfFunds/FundsModal.vue'; | ||
import BannerText from '../content/BannerText.vue'; | ||
import BannerSlides from '../content/BannerSlides.vue'; | ||
import MultiStepDonation from '@src/components/DonationForm/MultiStepDonation.vue'; | ||
import MainDonationForm from '@src/components/DonationForm/Forms/MainDonationForm.vue'; | ||
import UpgradeToYearlyButtonForm from '@src/components/DonationForm/Forms/UpgradeToYearlyButtonForm.vue'; | ||
import KeenSlider from '@src/components/Slider/KeenSlider.vue'; | ||
import { useFormModel } from '@src/components/composables/useFormModel'; | ||
import { | ||
createSubmittableMainDonationForm | ||
} from '@src/components/DonationForm/StepControllers/SubmittableMainDonationForm'; | ||
import { | ||
createSubmittableUpgradeToYearly | ||
} from '@src/components/DonationForm/StepControllers/SubmittableUpgradeToYearly'; | ||
import { CloseChoices } from '@src/domain/CloseChoices'; | ||
import { CloseEvent } from '@src/tracking/events/CloseEvent'; | ||
import { TrackingFeatureName } from '@src/tracking/TrackingEvent'; | ||
import ButtonClose from '@src/components/ButtonClose/ButtonClose.vue'; | ||
import FooterAlreadyDonated from '@src/components/Footer/FooterAlreadyDonated.vue'; | ||
import WMDEFundsForwardingDE from '@src/components/UseOfFunds/Infographics/WMDEFundsForwardingDE.vue'; | ||
import ProgressBar from '@src/components/ProgressBar/ProgressBarAlternative.vue'; | ||
import SoftClose from '@src/components/SoftClose/SoftClose.vue'; | ||
import { LocalCloseTracker } from '@src/utils/LocalCloseTracker'; | ||
import { BannerSubmitOnReturnEvent } from '@src/tracking/events/BannerSubmitOnReturnEvent'; | ||
import { Tracker } from '@src/tracking/Tracker'; | ||
import { useBannerHider } from '@src/components/composables/useBannerHider'; | ||
import BannerTitle from '@banners/desktop/C24_WMDE_Desktop_DE_15/content/BannerTitle.vue'; | ||
enum ContentStates { | ||
Main = 'wmde-banner-wrapper--main', | ||
SoftClosing = 'wmde-banner-wrapper--soft-closing', | ||
} | ||
enum FormStepNames { | ||
MainDonationFormStep = 'MainDonationForm', | ||
UpgradeToYearlyFormStep = 'UpgradeToYearlyForm' | ||
} | ||
interface Props { | ||
bannerState: BannerStates; | ||
useOfFundsContent: useOfFundsContentInterface; | ||
remainingImpressions: number; | ||
localCloseTracker: LocalCloseTracker; | ||
} | ||
const props = defineProps<Props>(); | ||
const emit = defineEmits( [ 'bannerClosed', 'bannerContentChanged', 'modalOpened', 'modalClosed' ] ); | ||
useBannerHider( 800, emit ); | ||
const tracker = inject<Tracker>( 'tracker' ); | ||
const isFundsModalVisible = ref<boolean>( false ); | ||
const contentState = ref<ContentStates>( ContentStates.Main ); | ||
const formModel = useFormModel(); | ||
const stepControllers = [ | ||
createSubmittableMainDonationForm( formModel, FormStepNames.UpgradeToYearlyFormStep ), | ||
createSubmittableUpgradeToYearly( formModel, FormStepNames.MainDonationFormStep, FormStepNames.MainDonationFormStep ) | ||
]; | ||
watch( contentState, async () => { | ||
emit( 'bannerContentChanged' ); | ||
} ); | ||
const onSubmit = (): void => { | ||
// special callback function: asking for previous close choices | ||
const closeChoice = props.localCloseTracker.getItem(); | ||
if ( closeChoice !== '' ) { | ||
tracker.trackEvent( new BannerSubmitOnReturnEvent( closeChoice ) ); | ||
} | ||
}; | ||
function onCloseMain(): void { | ||
if ( props.remainingImpressions > 0 ) { | ||
contentState.value = ContentStates.SoftClosing; | ||
} else { | ||
onClose( 'MainBanner', CloseChoices.Close ); | ||
} | ||
} | ||
function onClose( feature: TrackingFeatureName, userChoice: CloseChoices ): void { | ||
emit( 'bannerClosed', new CloseEvent( feature, userChoice ) ); | ||
} | ||
function onHideFundsModal(): void { | ||
isFundsModalVisible.value = false; | ||
emit( 'modalClosed' ); | ||
} | ||
function onModalOpened(): void { | ||
isFundsModalVisible.value = true; | ||
emit( 'modalOpened' ); | ||
} | ||
</script> |
47 changes: 47 additions & 0 deletions
47
banners/desktop/C24_WMDE_Desktop_DE_20/components/MainBannerVar.vue
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
tart<template> | ||
<div class="wmde-banner-main"> | ||
<slot name="close-button"/> | ||
<div class="wmde-banner-content"> | ||
<div class="wmde-banner-column-left"> | ||
<div class="wmde-banner-message-container"> | ||
<slot name="banner-title"/> | ||
<slot name="banner-text" v-if="onLargeScreen"/> | ||
<slot name="banner-slides" v-else :play="slideshowShouldPlay"/> | ||
</div> | ||
<slot name="progress"/> | ||
</div> | ||
<div class="wmde-banner-column-right"> | ||
<slot name="donation-form" :form-interaction="onFormInteraction"/> | ||
</div> | ||
</div> | ||
<slot name="footer"/> | ||
</div> | ||
</template> | ||
|
||
<script setup lang="ts"> | ||
import { useDisplaySwitch } from '@src/components/composables/useDisplaySwitch'; | ||
import { computed, nextTick, ref } from 'vue'; | ||
import { BannerStates } from '@src/components/BannerConductor/StateMachine/BannerStates'; | ||
interface Props { | ||
bannerState: BannerStates; | ||
} | ||
const props = defineProps<Props>(); | ||
const emit = defineEmits( [ 'formInteraction' ] ); | ||
const slideShowStopped = ref<boolean>( false ); | ||
const slideshowShouldPlay = computed( () => props.bannerState === BannerStates.Visible && !slideShowStopped.value ); | ||
const onLargeScreen = useDisplaySwitch( 1300 ); | ||
const onFormInteraction = (): void => { | ||
slideShowStopped.value = true; | ||
nextTick( () => { | ||
emit( 'formInteraction' ); | ||
} ); | ||
}; | ||
</script> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
import CustomAmountFormDe from '@src/components/DonationForm/Forms/messages/CustomAmountForm.de'; | ||
import DynamicCampaignTextDe from '@src/utils/DynamicContent/messages/DynamicCampaignText.de'; | ||
import { TranslationMessages } from '@src/Translator'; | ||
import UpgradeToYearlyDe from '@src/components/DonationForm/Forms/messages/UpgradeToYearly.de'; | ||
import AddressFormDe from '@src/components/DonationForm/Forms/messages/AddressForm.de'; | ||
import FooterDe from '@src/components/Footer/messages/Footer.de'; | ||
import MainDonationFormDe from '@src/components/DonationForm/Forms/messages/MainDonationForm.de'; | ||
import FallbackBanner from '@src/components/FallbackBanner/messages/FallbackBanner.de'; | ||
import AlreadyDonatedModal from '@src/components/AlreadyDonatedModal/translations/AlreadyDonatedModal.de'; | ||
import SoftCloseDe from '@src/components/SoftClose/messages/SoftClose.de'; | ||
|
||
const messages: TranslationMessages = { | ||
...CustomAmountFormDe, | ||
...DynamicCampaignTextDe, | ||
...UpgradeToYearlyDe, | ||
...AddressFormDe, | ||
...FooterDe, | ||
...MainDonationFormDe, | ||
...AlreadyDonatedModal, | ||
...FallbackBanner, | ||
...SoftCloseDe, | ||
'already-donated-go-away-button': 'Im Moment nicht', | ||
'soft-close-prompt': 'Dürfen wir später nochmal fragen?', | ||
'upgrade-to-yearly-copy': `<p>Jedes Jahr sind wir auf Menschen wie Sie angewiesen. Jährliche Spenden helfen uns besonders und ermöglichen langfristige Weiterentwicklungen.</p> | ||
<p>Sie gehen kein Risiko ein: Jederzeit formlos zu sofort kündbar.</p>`, | ||
'upgrade-to-yearly-no': 'Nein, ich spende einmalig {{amount}}', | ||
'upgrade-to-yearly-yes': 'Ja, ich spende {{amount}} jährlich', | ||
'campaign-day-only-n-days': 'Heute sind es nur noch {{days}} Tage bis zum Ende unserer Spendenkampagne.', | ||
'custom-amount-placeholder': 'Wahlbetrag', | ||
'upgrade-to-yearly-header': 'Bitte spenden Sie {{amount}} jährlich!' | ||
}; | ||
|
||
export default messages; |
60 changes: 60 additions & 0 deletions
60
banners/desktop/C24_WMDE_Desktop_DE_20/styles/styles_var.scss
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
// This is the file where we import the theme-specific component styles | ||
@use 'src/themes/Treedip/swatches/skin_default' with ( | ||
$slider: true, | ||
$select-group: true, | ||
$upgrade-to-yearly: true, | ||
$fallback-banner: true, | ||
$progress-bar: true, | ||
$soft-close: true, | ||
); | ||
@use 'src/components/BannerConductor/banner-transition'; | ||
@use 'src/themes/UseOfFunds/swatches/skin_default' as uof-default; | ||
@use 'Banner'; | ||
@use 'src/themes/UseOfFunds/UseOfFunds'; | ||
@use 'MainBanner' with ( | ||
$banner-height: 357px, | ||
$form-width: 300px | ||
); | ||
@use 'src/themes/Treedip/defaults'; | ||
@use 'src/themes/Treedip/ButtonClose/ButtonClose'; | ||
@use 'src/themes/Treedip/ProgressBar/ProgressBarAlternative' with ( | ||
$progress-bar-margin: 0 15px | ||
); | ||
@use 'src/themes/Treedip/DonationForm/DonationForm'; | ||
@use 'src/themes/Treedip/DonationForm/MultiStepDonation'; | ||
@use 'src/themes/Treedip/DonationForm/SubComponents/SelectGroup'; | ||
@use 'src/themes/Treedip/DonationForm/SubComponents/SelectGroupRadios'; | ||
@use 'src/themes/Treedip/DonationForm/SubComponents/SelectCustomAmountRadio'; | ||
@use 'src/themes/Treedip/DonationForm/SubComponents/SmsBox'; | ||
@use 'src/themes/Treedip/DonationForm/Forms/MainDonationForm'; | ||
@use 'src/themes/Treedip/DonationForm/Forms/UpgradeToYearlyButtonForm' with ( | ||
$font-size: 14px | ||
); | ||
@use 'src/themes/Treedip/DonationForm/Forms/CustomAmountForm'; | ||
@use 'src/themes/Treedip/Footer/FooterAlreadyDonated'; | ||
@use 'src/themes/Treedip/Footer/SelectionInput'; | ||
@use 'src/themes/Treedip/Message/Message' with ( | ||
$slider-main-headline-font-size: 25px, | ||
$message-header-padding-bottom: 8px, | ||
$message-header-small-up-padding-bottom: 8px, | ||
$message-header-padding-top: 20px, | ||
$message-header-small-up-padding-top: 20px | ||
); | ||
@use 'src/themes/Treedip/SoftClose/SoftClose'; | ||
@use 'src/themes/Treedip/Slider/KeenSlider' with ( | ||
$slider-padding: 0 | ||
); | ||
|
||
/** | ||
* Fallback banner with "Fijitiv" theme | ||
* All selectors in Fijitiv theme are prefixed with the ".wmde-banner-fallback" class selector, | ||
so they override the "default" styles with the same selector | ||
*/ | ||
@use 'FallbackBanner'; | ||
@use 'src/themes/Fijitiv/FallbackBanner/FallbackButton'; | ||
@use 'src/themes/Fijitiv/FallbackBanner/LargeFooter'; | ||
@use 'src/themes/Fijitiv/FallbackBanner/SmallFooter'; | ||
@use 'src/themes/Fijitiv/ProgressBar/ProgressBar' as FallbackProgressBar with ( | ||
$progress-bar-margin: 0 15px | ||
); | ||
@use 'src/themes/Fijitiv/Slider/KeenSlider' as FallbackSlider; |