give.salvationarmyusa.org
Open in
urlscan Pro
104.18.124.73
Public Scan
Submitted URL: https://give.salvationarmyusa.org/
Effective URL: https://give.salvationarmyusa.org/give/164006/
Submission: On November 18 via api from SG — Scanned from SG
Effective URL: https://give.salvationarmyusa.org/give/164006/
Submission: On November 18 via api from SG — Scanned from SG
Form analysis
1 forms found in the DOMName: FORM —
<form name="FORM" novalidate="novalidate" data-ng-submit="submit()" class="donation-block_form ng-pristine ng-invalid ng-invalid-required ng-valid-email-address ng-valid-phone-number ng-valid-min ng-valid-max" data-sc-broadcast-form-errors="">
<!-- Honeypot -->
<input type="hidden" data-ng-model="MODEL.z" autocomplete="off" class="ng-pristine ng-untouched ng-valid ng-empty ng-not-modified">
<!-- Components -->
<!-- ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<section class="donation-welcome ng-scope" data-ng-controller="frsDonationWelcomeCtrl">
<div data-sc-filler-text="{
fontBase: 16,
fontRatio: 14
}" data-title-container="'.donation-welcome_container'" data-parent-container="'.donation-welcome_container'" class="ng-isolate-scope">
<div class="donation-welcome_container">
<div class="sr-only">
<!-- ngIf: META.errorList.length -->
<!-- ngRepeat: error in META.errorList -->
</div>
<!-- ngIf: !editable && !isPreview() -->
<h1 class="donation-welcome_title ng-binding ng-scope" data-ng-if="!editable && !isPreview()" data-ng-bind-html="trustedBlockHeadlineHtml">
<p style="font-size: 40px;">Love Beyond <span style="color: rgb(237, 28, 43);">Christmas</span></p>
</h1><!-- end ngIf: !editable && !isPreview() -->
<!-- ngIf: !editable && isPreview() -->
<!-- ngIf: editable && !getLock('headline') -->
<!-- ngIf: editable && getLock('headline') -->
<!-- Appeal -->
<!-- ngIf: !editable -->
<div class="donation-welcome_description ng-scope" data-ng-if="!editable" sc-allow-html="block.description | scImgAssetRef | userLinks" sc-responsive-video="">
<p>Your gift to The Salvation Army supports local families this season and beyond. Challenges that families face don’t end when the holidays do and when you give monthly, each hard-earned dollar goes further, and you are able to make a
greater impact in your community. So you can put a present under someone’s tree today and a roof over someone’s head tomorrow.</p>
</div><!-- end ngIf: !editable -->
<!-- ngIf: editable && !getLock('description') -->
<!-- ngIf: editable && getLock('description') -->
</div>
</div>
</section>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<section class="donation-amount ng-scope" data-ng-controller="frsDonationAmountCtrl">
<!-- ngIf: preventRecurringFrequency -->
<!-- ngIf: show.levels() && !displayRecurringExperiment() && preventRecurringFrequency -->
<!-- ngIf: !displayRecurringExperiment() && preventRecurringFrequency -->
<!-- ngIf: showLegacyDonationGrid --><donation-amount-recurring-rf ng-if="showLegacyDonationGrid" donation-context="CONTEXT" frequency="MODEL.frequency" setting-page-frequency="MODEL.frequency"
frequency-levels="DonationBlock.current['recurring-level']" levels="state.levels" recurring-donation-levels="state.recurringDonationLevels" recur_until="MODEL.recur_until" amount="MODEL.items[0].raw_final_price"
previous-frequency-price="MODEL.items[0].previous_frequency_price" new-amount="MODEL.items[0].raw_final_price" preview="globalState.isPreview" currency="MODEL.payment.raw_currency_code" class="ng-scope ng-isolate-scope"><!-- **** DONT MAKE CHANGES TO THIS FILE ****
This file is LEGACY and is only being kept around for certain orgs
that have customized this section of the page.
They must have the `legacy-donation-grid` org tag
-->
<div class="donation-amount-recurring">
<!-- FREQUENCY TOGGLE-->
<!-- ngIf: !$ctrl.preventOldrfForDeque && !$ctrl.onlyReccurringFrequency($ctrl.frequencyLevels) && $ctrl.recurringLevels($ctrl.frequencyLevels).length > 0 -->
<div data-ng-init="$ctrl.showFreqDropdown()" data-ng-if="!$ctrl.preventOldrfForDeque && !$ctrl.onlyReccurringFrequency($ctrl.frequencyLevels) && $ctrl.recurringLevels($ctrl.frequencyLevels).length > 0"
class="donation-amount-recurring__switch rf ng-scope" role="radiogroup" aria-label="Select a donation frequency">
<div data-ng-click="$ctrl.selectFrequency('one-time'); $ctrl.showFreqDropdown('one-time'); $ctrl.isRecurringFrequency($event)" data-ng-keypress="$ctrl.selectFrequency('one-time',$event); $ctrl.isRecurringFrequency($event)"
data-ng-mouseover="$ctrl.hoverFrequencyStyle('one-time',true)" data-ng-mouseout="$ctrl.hoverFrequencyStyle('one-time',false)" class="donation-amount-recurring__btn once hover-state_one-time selected" _spec="one-time" tabindex="0"
data-ng-class="{'selected': $ctrl.frequency === 'one-time'}" data-ng-style="$ctrl.oneTimeBtnStyle('one-time')" style="background-color: rgb(239, 62, 66); color: rgb(255, 255, 255); border: 2px solid rgb(239, 62, 66);">
<label for="donation-amount-recurring__radio-input" class="donation-amount-recurring__btn__frequency-label">
<input type="radio" id="donation-amount-recurring__radio-input" role="radio" tabindex="-1" name="donation-frequency" class="donation-amount-recurring__btn__frequency-input" aria-checked="true">One time </label>
</div>
<div data-ng-click="$ctrl.selectFrequency($ctrl.frequency); $ctrl.showFreqDropdown($ctrl.recurringBtnText()); $ctrl.isRecurringFrequency($event)"
data-ng-keypress="$ctrl.selectFrequency($ctrl.recurringBtnText(),$event); $ctrl.isRecurringFrequency($event)" data-ng-mouseover="$ctrl.hoverFrequencyStyle('recurring',true)"
data-ng-mouseout="$ctrl.hoverFrequencyStyle('recurring',false)" class="donation-amount-recurring__btn monthly hover-state_recurring" _spec="recurring" tabindex="0"
data-ng-class="{'selected': $ctrl.recurringBtnSelected($ctrl.frequency)}" data-ng-style="$ctrl.recurringBtnStyle($ctrl.frequency)"
style="background-color: rgb(255, 255, 255); color: rgb(239, 62, 66); border: 2px solid rgb(239, 62, 66);">
<label for="donation-amount-monthly__radio-input" class="donation-amount-recurring__btn__frequency-label ng-binding">
<input type="radio" role="radio" id="donation-amount-monthly__radio-input" name="donation-frequency" tabindex="-1" class="donation-amount-recurring__btn__frequency-input" aria-checked="false"> monthly </label>
</div>
</div><!-- end ngIf: !$ctrl.preventOldrfForDeque && !$ctrl.onlyReccurringFrequency($ctrl.frequencyLevels) && $ctrl.recurringLevels($ctrl.frequencyLevels).length > 0 -->
<!-- FREQUENCY DROPDOWN PHASE 1-->
<!-- ngIf: $ctrl.preventOldrfForDeque && $ctrl.noOfFrequencyLevel($ctrl.frequencyLevels) !== 1 -->
<!-- FREQUENCY DROPDOWN PHASE 2 -->
<!-- ngIf: !$ctrl.preventOldrfForDeque && ($ctrl.isFreqDropdown || ($ctrl.onlyReccurringFrequency($ctrl.frequencyLevels) && $ctrl.recurringLevels($ctrl.frequencyLevels).length > 1)) -->
<!-- END DATE -->
<!-- ngIf: !$ctrl.preventOldrfForDeque && $ctrl.showRecurringEndDate && $ctrl.frequency !== 'one-time' -->
<!-- ngIf: !$ctrl.showRecurringDonationArray && (!!$ctrl.frequency && ($ctrl.noOfDonationAmount($ctrl.levels) !== 1 || $ctrl.showCustomAmtField($ctrl.levels))) -->
<p data-ng-if="!$ctrl.showRecurringDonationArray && (!!$ctrl.frequency && ($ctrl.noOfDonationAmount($ctrl.levels) !== 1 || $ctrl.showCustomAmtField($ctrl.levels)))" id="amount-options-label" class="ng-scope"> Choose a
<b class="ng-binding">one-time</b> amount</p><!-- end ngIf: !$ctrl.showRecurringDonationArray && (!!$ctrl.frequency && ($ctrl.noOfDonationAmount($ctrl.levels) !== 1 || $ctrl.showCustomAmtField($ctrl.levels))) -->
<!-- ngIf: $ctrl.showRecurringDonationArray && (!!$ctrl.frequency && ($ctrl.noOfDonationAmount($ctrl.recurringDonationLevels) !== 1 || $ctrl.showCustomAmtField($ctrl.recurringDonationLevels))) -->
<!-- IF MULTIPLE AMOUNT DISPLAYED -->
<!-- ngIf: !$ctrl.showRecurringDonationArray && ($ctrl.noOfDonationAmount($ctrl.levels) > 1 || $ctrl.showCustomAmtField($ctrl.levels)) -->
<ul data-ng-if="!$ctrl.showRecurringDonationArray && ($ctrl.noOfDonationAmount($ctrl.levels) > 1 || $ctrl.showCustomAmtField($ctrl.levels))" class="donation-amount-recurring__levels rf ng-scope bb"
aria-labelledby="amount-options-label" role="radiogroup" data-ng-class="{'bb': $ctrl.hasBigButtons, 'multiple-amount-hidden' : $ctrl.noOfDonationAmount($ctrl.levels) === 1 && !$ctrl.showCustomAmtField($ctrl.levels)}">
<!-- ngRepeat: level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true}) --><!-- ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 -->
<li data-ng-if="level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1" id="D-A500"
data-ng-repeat="level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true})" data-ng-click="$ctrl.selectAmount(level.displayAmount)"
data-ng-keydown="$ctrl.selectAmount(level.displayAmount, $event)" data-ng-mouseover="$ctrl.hoverStyle($index,true)" data-ng-mouseout="$ctrl.hoverStyle($index,false)" class="donation-amount-recurring__level-item rf hover-state_0 bb"
role="radio" tabindex="0" aria-checked="false" data-ng-class="{'bb': $ctrl.hasBigButtons, 'selected': $ctrl.amount === level.displayAmount && !$ctrl.showCustomAmtSelected}"
data-ng-style="$ctrl.donationLevelStyle(level.displayAmount)" style="color: rgba(0, 0, 0, 0.87); background-color: rgba(239, 62, 66, 0.12); border: none; max-width: 50%;">
<!-- ngIf: !level.loading --><label data-ng-if="!level.loading" for="D-A500" class="donation-amount-recurring__level-item__amount-label rf ng-binding ng-scope bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">
<input data-ng-model="$ctrl.amount" type="radio" role="radio" tabindex="-1" aria-hidden="true" name="donation-amount"
class="donation-amount-recurring__level-item__amount-input rf ng-pristine ng-untouched ng-valid ng-not-empty ng-not-modified bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">SGD 680 </label><!-- end ngIf: !level.loading -->
<!-- ngIf: level.loading -->
</li>
<!-- end ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 --><!-- end ngRepeat: level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true}) --><!-- ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 -->
<li data-ng-if="level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1" id="D-A250"
data-ng-repeat="level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true})" data-ng-click="$ctrl.selectAmount(level.displayAmount)"
data-ng-keydown="$ctrl.selectAmount(level.displayAmount, $event)" data-ng-mouseover="$ctrl.hoverStyle($index,true)" data-ng-mouseout="$ctrl.hoverStyle($index,false)" class="donation-amount-recurring__level-item rf hover-state_1 bb"
role="radio" tabindex="0" aria-checked="false" data-ng-class="{'bb': $ctrl.hasBigButtons, 'selected': $ctrl.amount === level.displayAmount && !$ctrl.showCustomAmtSelected}"
data-ng-style="$ctrl.donationLevelStyle(level.displayAmount)" style="color: rgba(0, 0, 0, 0.87); background-color: rgba(239, 62, 66, 0.12); border: none; max-width: 50%;">
<!-- ngIf: !level.loading --><label data-ng-if="!level.loading" for="D-A250" class="donation-amount-recurring__level-item__amount-label rf ng-binding ng-scope bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">
<input data-ng-model="$ctrl.amount" type="radio" role="radio" tabindex="-1" aria-hidden="true" name="donation-amount"
class="donation-amount-recurring__level-item__amount-input rf ng-pristine ng-untouched ng-valid ng-not-empty ng-not-modified bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">SGD 340 </label><!-- end ngIf: !level.loading -->
<!-- ngIf: level.loading -->
</li>
<!-- end ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 --><!-- end ngRepeat: level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true}) --><!-- ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 -->
<li data-ng-if="level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1" id="D-A100"
data-ng-repeat="level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true})" data-ng-click="$ctrl.selectAmount(level.displayAmount)"
data-ng-keydown="$ctrl.selectAmount(level.displayAmount, $event)" data-ng-mouseover="$ctrl.hoverStyle($index,true)" data-ng-mouseout="$ctrl.hoverStyle($index,false)"
class="donation-amount-recurring__level-item rf hover-state_2 bb selected" role="radio" tabindex="0" aria-checked="true"
data-ng-class="{'bb': $ctrl.hasBigButtons, 'selected': $ctrl.amount === level.displayAmount && !$ctrl.showCustomAmtSelected}" data-ng-style="$ctrl.donationLevelStyle(level.displayAmount)"
style="color: rgb(255, 255, 255); background-color: rgb(239, 62, 66); border: none; max-width: 50%;">
<!-- ngIf: !level.loading --><label data-ng-if="!level.loading" for="D-A100" class="donation-amount-recurring__level-item__amount-label rf ng-binding ng-scope bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">
<input data-ng-model="$ctrl.amount" type="radio" role="radio" tabindex="-1" aria-hidden="true" name="donation-amount"
class="donation-amount-recurring__level-item__amount-input rf ng-pristine ng-untouched ng-valid ng-not-empty ng-not-modified bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">SGD 140 </label><!-- end ngIf: !level.loading -->
<!-- ngIf: level.loading -->
</li>
<!-- end ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 --><!-- end ngRepeat: level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true}) --><!-- ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 -->
<li data-ng-if="level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1" id="D-A50"
data-ng-repeat="level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true})" data-ng-click="$ctrl.selectAmount(level.displayAmount)"
data-ng-keydown="$ctrl.selectAmount(level.displayAmount, $event)" data-ng-mouseover="$ctrl.hoverStyle($index,true)" data-ng-mouseout="$ctrl.hoverStyle($index,false)" class="donation-amount-recurring__level-item rf hover-state_3 bb"
role="radio" tabindex="0" aria-checked="false" data-ng-class="{'bb': $ctrl.hasBigButtons, 'selected': $ctrl.amount === level.displayAmount && !$ctrl.showCustomAmtSelected}"
data-ng-style="$ctrl.donationLevelStyle(level.displayAmount)" style="color: rgba(0, 0, 0, 0.87); background-color: rgba(239, 62, 66, 0.12); border: none; max-width: 50%;">
<!-- ngIf: !level.loading --><label data-ng-if="!level.loading" for="D-A50" class="donation-amount-recurring__level-item__amount-label rf ng-binding ng-scope bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">
<input data-ng-model="$ctrl.amount" type="radio" role="radio" tabindex="-1" aria-hidden="true" name="donation-amount"
class="donation-amount-recurring__level-item__amount-input rf ng-pristine ng-untouched ng-valid ng-not-empty ng-not-modified bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">SGD 68 </label><!-- end ngIf: !level.loading -->
<!-- ngIf: level.loading -->
</li>
<!-- end ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 --><!-- end ngRepeat: level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true}) --><!-- ngIf: level.amount !== 'Custom' && $ctrl.noOfDonationAmount($ctrl.levels) !== 1 --><!-- end ngRepeat: level in $ctrl.levels | filter: ($ctrl.noOfDonationAmount($ctrl.levels) > 1 && { display_on_page: true}) -->
<!-- REMOVE WHEN BIG BUTTONS GO TO ALL ORGS -->
<!-- ngRepeat: level in $ctrl.levels | filter: { display_on_page: true} --><!-- ngIf: !$ctrl.hasBigButtons && level.amount === 'Custom' && $ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time' --><!-- end ngRepeat: level in $ctrl.levels | filter: { display_on_page: true} --><!-- ngIf: !$ctrl.hasBigButtons && level.amount === 'Custom' && $ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time' --><!-- end ngRepeat: level in $ctrl.levels | filter: { display_on_page: true} --><!-- ngIf: !$ctrl.hasBigButtons && level.amount === 'Custom' && $ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time' --><!-- end ngRepeat: level in $ctrl.levels | filter: { display_on_page: true} --><!-- ngIf: !$ctrl.hasBigButtons && level.amount === 'Custom' && $ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time' --><!-- end ngRepeat: level in $ctrl.levels | filter: { display_on_page: true} --><!-- ngIf: !$ctrl.hasBigButtons && level.amount === 'Custom' && $ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time' --><!-- end ngRepeat: level in $ctrl.levels | filter: { display_on_page: true} -->
</ul><!-- end ngIf: !$ctrl.showRecurringDonationArray && ($ctrl.noOfDonationAmount($ctrl.levels) > 1 || $ctrl.showCustomAmtField($ctrl.levels)) -->
<!-- IF MULTIPLE RECURRING DONATION AMOUNT DISPLAYED -->
<!-- ngIf: $ctrl.showRecurringDonationArray && ($ctrl.noOfDonationAmount($ctrl.recurringDonationLevels) > 1 || $ctrl.showCustomAmtField($ctrl.recurringDonationLevels)) -->
<!-- ngRepeat: level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true} --><!-- ngIf: $ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time')) --><!-- end ngRepeat: level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true} --><!-- ngIf: $ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time')) --><!-- end ngRepeat: level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true} --><!-- ngIf: $ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time')) --><!-- end ngRepeat: level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true} --><!-- ngIf: $ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time')) --><!-- end ngRepeat: level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true} --><!-- ngIf: $ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time')) -->
<div
data-ng-if="$ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time'))"
data-ng-repeat="level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true}" data-ng-click="$ctrl.selectAmount('Custom')"
class="donation-amount-recurring__level-item other-rf hover-state_other ng-scope bb" role="radio" data-ng-class="{'bb': $ctrl.hasBigButtons, 'selected': $ctrl.showCustomAmtSelected}">
<label for="D-AOther" class="donation-amount-recurring__level-item__amount-label other-rf bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">
<div id="custom-amount" class="donation-amount-recurring__amount rf currency-picker" data-ng-class="{'has-focus': $ctrl.show.inputFocus === true}" data-sc-form-error="highlight if amount fails" aria-invalid="false">
<div sc-currency-picker="" currency-model="$ctrl.currency" currency-entity="'donation'" selected="$ctrl.showCustomAmtSelected" class="currency-picker__wrapper-rf ng-isolate-scope bb" data-ng-class="{'bb': $ctrl.hasBigButtons}">
<div class="currency-picker__wrapper ng-isolate-scope" ng-style="selected ? changeWrapperStyle() : defaultStyle()" ng-class="{'no-pick':!showDropdown, 'disabled': disabled}" aria-hidden="false" sc-lock-field="disabled"
tooltip-text="tooltipText">
<div class="currency-picker__select-wrapper">
<select class="currency-picker__select ng-pristine ng-untouched ng-valid ng-not-empty ng-not-modified" ng-change="optionSwap()" ng-model="currency" id="dropdown" ng-show="showDropdown"
ng-options="currency as currency.longText for currency in currencyOptions track by currency.currency" aria-label="Select a currency" ng-disabled="disabled">
<option label="AED | United Arab Emirates Dirham" value="AED">AED | United Arab Emirates Dirham</option>
<option label="AFN | Afghan Afghani" value="AFN">AFN | Afghan Afghani</option>
<option label="ALL | Albanian Lek" value="ALL">ALL | Albanian Lek</option>
<option label="AMD | Armenian Dram" value="AMD">AMD | Armenian Dram</option>
<option label="ANG | Netherlands Antillean Guilder" value="ANG">ANG | Netherlands Antillean Guilder</option>
<option label="AOA | Angolan Kwanza" value="AOA">AOA | Angolan Kwanza</option>
<option label="ARS | Argentine Peso" value="ARS">ARS | Argentine Peso</option>
<option label="AUD | Australian Dollar" value="AUD">AUD | Australian Dollar</option>
<option label="AWG | Aruban Florin" value="AWG">AWG | Aruban Florin</option>
<option label="AZN | Azerbaijani Manat" value="AZN">AZN | Azerbaijani Manat</option>
<option label="BAM | Bosnia And Herzegovina Convertible Mark" value="BAM">BAM | Bosnia And Herzegovina Convertible Mark</option>
<option label="BBD | Barbados Dollar" value="BBD">BBD | Barbados Dollar</option>
<option label="BDT | Bangladeshi Taka" value="BDT">BDT | Bangladeshi Taka</option>
<option label="BGN | Bulgarian Lev" value="BGN">BGN | Bulgarian Lev</option>
<option label="BHD | Bahraini Dinar" value="BHD">BHD | Bahraini Dinar</option>
<option label="BIF | Burundian Franc" value="BIF">BIF | Burundian Franc</option>
<option label="BMD | Bermudian Dollar (customarily Known As Bermuda Dollar)" value="BMD">BMD | Bermudian Dollar (customarily Known As Bermuda Dollar)</option>
<option label="BND | Brunei Dollar" value="BND">BND | Brunei Dollar</option>
<option label="BOB | Boliviano" value="BOB">BOB | Boliviano</option>
<option label="BRL | Brazilian Real" value="BRL">BRL | Brazilian Real</option>
<option label="BSD | Bahamian Dollar" value="BSD">BSD | Bahamian Dollar</option>
<option label="BTN | Bhutanese Ngultrum" value="BTN">BTN | Bhutanese Ngultrum</option>
<option label="BWP | Botswana Pula" value="BWP">BWP | Botswana Pula</option>
<option label="BZD | Belize Dollar" value="BZD">BZD | Belize Dollar</option>
<option label="CAD | Canadian Dollar" value="CAD">CAD | Canadian Dollar</option>
<option label="CDF | Congolese Franc" value="CDF">CDF | Congolese Franc</option>
<option label="CHF | Swiss Franc" value="CHF">CHF | Swiss Franc</option>
<option label="CLF | Unidad De Fomento (funds Code)" value="CLF">CLF | Unidad De Fomento (funds Code)</option>
<option label="CLP | Chilean Peso" value="CLP">CLP | Chilean Peso</option>
<option label="CNY | Chinese Yuan" value="CNY">CNY | Chinese Yuan</option>
<option label="COP | Colombian Peso" value="COP">COP | Colombian Peso</option>
<option label="CRC | Costa Rican Colon" value="CRC">CRC | Costa Rican Colon</option>
<option label="CUC | Cuban Convertible Peso" value="CUC">CUC | Cuban Convertible Peso</option>
<option label="CUP | Cuban Peso" value="CUP">CUP | Cuban Peso</option>
<option label="CVE | Cape Verde Escudo" value="CVE">CVE | Cape Verde Escudo</option>
<option label="CZK | Czech Koruna" value="CZK">CZK | Czech Koruna</option>
<option label="DJF | Djiboutian Franc" value="DJF">DJF | Djiboutian Franc</option>
<option label="DKK | Danish Krone" value="DKK">DKK | Danish Krone</option>
<option label="DOP | Dominican Peso" value="DOP">DOP | Dominican Peso</option>
<option label="DZD | Algerian Dinar" value="DZD">DZD | Algerian Dinar</option>
<option label="EGP | Egyptian Pound" value="EGP">EGP | Egyptian Pound</option>
<option label="ERN | Eritrean Nakfa" value="ERN">ERN | Eritrean Nakfa</option>
<option label="ETB | Ethiopian Birr" value="ETB">ETB | Ethiopian Birr</option>
<option label="EUR | Euro" value="EUR">EUR | Euro</option>
<option label="FJD | Fiji Dollar" value="FJD">FJD | Fiji Dollar</option>
<option label="FKP | Falkland Islands Pound" value="FKP">FKP | Falkland Islands Pound</option>
<option label="GBP | Pound Sterling" value="GBP">GBP | Pound Sterling</option>
<option label="GEL | Georgian Lari" value="GEL">GEL | Georgian Lari</option>
<option label="GHS | Ghanaian Cedi" value="GHS">GHS | Ghanaian Cedi</option>
<option label="GIP | Gibraltar Pound" value="GIP">GIP | Gibraltar Pound</option>
<option label="GMD | Gambian Dalasi" value="GMD">GMD | Gambian Dalasi</option>
<option label="GNF | Guinean Franc" value="GNF">GNF | Guinean Franc</option>
<option label="GTQ | Guatemalan Quetzal" value="GTQ">GTQ | Guatemalan Quetzal</option>
<option label="GYD | Guyanese Dollar" value="GYD">GYD | Guyanese Dollar</option>
<option label="HKD | Hong Kong Dollar" value="HKD">HKD | Hong Kong Dollar</option>
<option label="HNL | Honduran Lempira" value="HNL">HNL | Honduran Lempira</option>
<option label="HRK | Croatian Kuna" value="HRK">HRK | Croatian Kuna</option>
<option label="HTG | Haitian Gourde" value="HTG">HTG | Haitian Gourde</option>
<option label="HUF | Hungarian Forint" value="HUF">HUF | Hungarian Forint</option>
<option label="IDR | Indonesian Rupiah" value="IDR">IDR | Indonesian Rupiah</option>
<option label="ILS | Israeli New Shekel" value="ILS">ILS | Israeli New Shekel</option>
<option label="INR | Indian Rupee" value="INR">INR | Indian Rupee</option>
<option label="IQD | Iraqi Dinar" value="IQD">IQD | Iraqi Dinar</option>
<option label="IRR | Iranian Rial" value="IRR">IRR | Iranian Rial</option>
<option label="ISK | Icelandic Króna" value="ISK">ISK | Icelandic Króna</option>
<option label="JMD | Jamaican Dollar" value="JMD">JMD | Jamaican Dollar</option>
<option label="JOD | Jordanian Dinar" value="JOD">JOD | Jordanian Dinar</option>
<option label="JPY | Japanese Yen" value="JPY">JPY | Japanese Yen</option>
<option label="KES | Kenyan Shilling" value="KES">KES | Kenyan Shilling</option>
<option label="KGS | Kyrgyzstani Som" value="KGS">KGS | Kyrgyzstani Som</option>
<option label="KHR | Cambodian Riel" value="KHR">KHR | Cambodian Riel</option>
<option label="KMF | Comoro Franc" value="KMF">KMF | Comoro Franc</option>
<option label="KPW | North Korean Won" value="KPW">KPW | North Korean Won</option>
<option label="KRW | South Korean Won" value="KRW">KRW | South Korean Won</option>
<option label="KWD | Kuwaiti Dinar" value="KWD">KWD | Kuwaiti Dinar</option>
<option label="KYD | Cayman Islands Dollar" value="KYD">KYD | Cayman Islands Dollar</option>
<option label="KZT | Kazakhstani Tenge" value="KZT">KZT | Kazakhstani Tenge</option>
<option label="LAK | Lao Kip" value="LAK">LAK | Lao Kip</option>
<option label="LBP | Lebanese Pound" value="LBP">LBP | Lebanese Pound</option>
<option label="LKR | Sri Lankan Rupee" value="LKR">LKR | Sri Lankan Rupee</option>
<option label="LRD | Liberian Dollar" value="LRD">LRD | Liberian Dollar</option>
<option label="LSL | Lesotho Loti" value="LSL">LSL | Lesotho Loti</option>
<option label="LYD | Libyan Dinar" value="LYD">LYD | Libyan Dinar</option>
<option label="MAD | Moroccan Dirham" value="MAD">MAD | Moroccan Dirham</option>
<option label="MDL | Moldovan Leu" value="MDL">MDL | Moldovan Leu</option>
<option label="MGA | Malagasy Ariary" value="MGA">MGA | Malagasy Ariary</option>
<option label="MKD | Macedonian Denar" value="MKD">MKD | Macedonian Denar</option>
<option label="MMK | Myanma Kyat" value="MMK">MMK | Myanma Kyat</option>
<option label="MNT | Mongolian Tugrik" value="MNT">MNT | Mongolian Tugrik</option>
<option label="MOP | Macanese Pataca" value="MOP">MOP | Macanese Pataca</option>
<option label="MUR | Mauritian Rupee" value="MUR">MUR | Mauritian Rupee</option>
<option label="MVR | Maldivian Rufiyaa" value="MVR">MVR | Maldivian Rufiyaa</option>
<option label="MWK | Malawian Kwacha" value="MWK">MWK | Malawian Kwacha</option>
<option label="MXN | Mexican Peso" value="MXN">MXN | Mexican Peso</option>
<option label="MYR | Malaysian Ringgit" value="MYR">MYR | Malaysian Ringgit</option>
<option label="MZN | Mozambican Metical" value="MZN">MZN | Mozambican Metical</option>
<option label="NAD | Namibian Dollar" value="NAD">NAD | Namibian Dollar</option>
<option label="NGN | Nigerian Naira" value="NGN">NGN | Nigerian Naira</option>
<option label="NIO | Nicaraguan Córdoba" value="NIO">NIO | Nicaraguan Córdoba</option>
<option label="NOK | Norwegian Krone" value="NOK">NOK | Norwegian Krone</option>
<option label="NPR | Nepalese Rupee" value="NPR">NPR | Nepalese Rupee</option>
<option label="NZD | New Zealand Dollar" value="NZD">NZD | New Zealand Dollar</option>
<option label="OMR | Omani Rial" value="OMR">OMR | Omani Rial</option>
<option label="PAB | Panamanian Balboa" value="PAB">PAB | Panamanian Balboa</option>
<option label="PEN | Peruvian Nuevo Sol" value="PEN">PEN | Peruvian Nuevo Sol</option>
<option label="PGK | Papua New Guinean Kina" value="PGK">PGK | Papua New Guinean Kina</option>
<option label="PHP | Philippine Peso" value="PHP">PHP | Philippine Peso</option>
<option label="PKR | Pakistani Rupee" value="PKR">PKR | Pakistani Rupee</option>
<option label="PLN | Polish Złoty" value="PLN">PLN | Polish Złoty</option>
<option label="PYG | Paraguayan Guaraní" value="PYG">PYG | Paraguayan Guaraní</option>
<option label="QAR | Qatari Riyal" value="QAR">QAR | Qatari Riyal</option>
<option label="RON | Romanian New Leu" value="RON">RON | Romanian New Leu</option>
<option label="RSD | Serbian Dinar" value="RSD">RSD | Serbian Dinar</option>
<option label="RWF | Rwandan Franc" value="RWF">RWF | Rwandan Franc</option>
<option label="SAR | Saudi Riyal" value="SAR">SAR | Saudi Riyal</option>
<option label="SBD | Solomon Islands Dollar" value="SBD">SBD | Solomon Islands Dollar</option>
<option label="SCR | Seychelles Rupee" value="SCR">SCR | Seychelles Rupee</option>
<option label="SDG | Sudanese Pound" value="SDG">SDG | Sudanese Pound</option>
<option label="SEK | Swedish Krona/kronor" value="SEK">SEK | Swedish Krona/kronor</option>
<option label="SGD | Singapore Dollar" value="SGD" selected="selected">SGD | Singapore Dollar</option>
<option label="SHP | Saint Helena Pound" value="SHP">SHP | Saint Helena Pound</option>
<option label="SLL | Sierra Leonean Leone" value="SLL">SLL | Sierra Leonean Leone</option>
<option label="SOS | Somali Shilling" value="SOS">SOS | Somali Shilling</option>
<option label="SRD | Surinamese Dollar" value="SRD">SRD | Surinamese Dollar</option>
<option label="SSP | South Sudanese Pound" value="SSP">SSP | South Sudanese Pound</option>
<option label="STD | São Tomé And Príncipe Dobra" value="STD">STD | São Tomé And Príncipe Dobra</option>
<option label="SYP | Syrian Pound" value="SYP">SYP | Syrian Pound</option>
<option label="SZL | Swazi Lilangeni" value="SZL">SZL | Swazi Lilangeni</option>
<option label="THB | Thai Baht" value="THB">THB | Thai Baht</option>
<option label="TJS | Tajikistani Somoni" value="TJS">TJS | Tajikistani Somoni</option>
<option label="TMT | Turkmenistani Manat" value="TMT">TMT | Turkmenistani Manat</option>
<option label="TND | Tunisian Dinar" value="TND">TND | Tunisian Dinar</option>
<option label="TOP | Tongan Paʻanga" value="TOP">TOP | Tongan Paʻanga</option>
<option label="TRY | Turkish Lira" value="TRY">TRY | Turkish Lira</option>
<option label="TTD | Trinidad And Tobago Dollar" value="TTD">TTD | Trinidad And Tobago Dollar</option>
<option label="TWD | New Taiwan Dollar" value="TWD">TWD | New Taiwan Dollar</option>
<option label="TZS | Tanzanian Shilling" value="TZS">TZS | Tanzanian Shilling</option>
<option label="UAH | Ukrainian Hryvnia" value="UAH">UAH | Ukrainian Hryvnia</option>
<option label="UGX | Ugandan Shilling" value="UGX">UGX | Ugandan Shilling</option>
<option label="USD | United States Dollar" value="USD">USD | United States Dollar</option>
<option label="UYU | Uruguayan Peso" value="UYU">UYU | Uruguayan Peso</option>
<option label="UZS | Uzbekistan Som" value="UZS">UZS | Uzbekistan Som</option>
<option label="VND | Vietnamese Dong" value="VND">VND | Vietnamese Dong</option>
<option label="VUV | Vanuatu Vatu" value="VUV">VUV | Vanuatu Vatu</option>
<option label="WST | Samoan Tala" value="WST">WST | Samoan Tala</option>
<option label="XAF | CFA Franc BEAC" value="XAF">XAF | CFA Franc BEAC</option>
<option label="XCD | East Caribbean Dollar" value="XCD">XCD | East Caribbean Dollar</option>
<option label="XDR | Special Drawing Rights" value="XDR">XDR | Special Drawing Rights</option>
<option label="XOF | CFA Franc BCEAO" value="XOF">XOF | CFA Franc BCEAO</option>
<option label="XPF | CFP Franc" value="XPF">XPF | CFP Franc</option>
<option label="YER | Yemeni Rial" value="YER">YER | Yemeni Rial</option>
<option label="ZAR | South African Rand" value="ZAR">ZAR | South African Rand</option>
</select>
<span class="currency-picker__short ng-binding" ng-style="selected ? changeSpanStyle() : defaultStyle(true)">SGD</span>
</div>
<!-- ngIf: currency.currency !== currency.fullSymbol -->
</div>
</div>
<currency-field-rf model="$ctrl.otherAmount" modal-bind-value="$ctrl.amount" selected="$ctrl.showCustomAmtSelected" class="currency-field rf ng-isolate-scope bb" data-ng-class="{'bb': $ctrl.hasBigButtons}" label="''"
round-currency="false" name="'amount'" placeholder="!$ctrl.preventOldrfForDeque ? 'Other': 'Custom amount'" currency-aria-label="Enter an other amount to donate">
<!-- ngIf: $ctrl.label -->
<input class="form__text-input--dark ng-pristine ng-untouched ng-isolate-scope ng-empty sc-valid ng-valid-required ng-not-modified ng-valid-min ng-valid ng-valid-max" ng-model="$ctrl.model"
ng-model-options="{ getterSetter: $ctrl.getterSetter }" ng-required="$ctrl.required" sc-currency="" sc-validity-reporter="" sc-validity-classes="" symbol="" round-currency="$ctrl.roundCurrency" ng-disabled="$ctrl.disableFlag"
max="$ctrl.max" min="$ctrl.min" type="string" inputmode="numeric" autocomplete="off" name="amount" placeholder="Other" ng-change="$ctrl.onChange()" ng-blur="$ctrl.onFocus = false"
ng-style="$ctrl.selected ? $ctrl.changeInputStyle() : $ctrl.defaultStyle()" qa-id="text-input" aria-label="Enter an other amount to donate" _spec="input">
<div style="position: absolute;
width: 100%;
left: 0;
text-align: left;" aria-live="polite">
<form-error name="$ctrl.name" messages="$ctrl.errorMessages" _spec="errors" class="ng-isolate-scope">
<p class="form__error" aria-live="polite" role="alert" sc-validity-message="::$ctrl.name" messages="::$ctrl.messages" style="display: none;"></p>
</form-error>
</div>
</currency-field-rf>
</div>
</label>
</div>
<!-- end ngIf: $ctrl.hasBigButtons && level.amount === 'Custom' && (($ctrl.showCustomAmtField($ctrl.levels) && $ctrl.frequency === 'one-time') || ($ctrl.showCustomAmtField($ctrl.recurringDonationLevels) && $ctrl.frequency !== 'one-time')) --><!-- end ngRepeat: level in ($ctrl.frequency === 'one-time' ? $ctrl.levels : $ctrl.recurringDonationLevels) | filter: { display_on_page: true} -->
<!-- IF ONLY SINGLE AMOUNT DISPLAYED-->
<!-- ngIf: !$ctrl.showRecurringDonationArray && ($ctrl.noOfDonationAmount($ctrl.levels) === 1 && !$ctrl.showCustomAmtField($ctrl.levels)) -->
<!-- IF ONLY SINGLE RECURRING AMOUNT DISPLAYED-->
<!-- ngIf: $ctrl.showRecurringDonationArray && ($ctrl.noOfDonationAmount($ctrl.recurringDonationLevels) === 1 && !$ctrl.showCustomAmtField($ctrl.recurringDonationLevels)) -->
</div>
</donation-amount-recurring-rf><!-- end ngIf: showLegacyDonationGrid -->
<!-- ngIf: !showLegacyDonationGrid -->
</section>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<section class="donation-dedication ng-scope" data-ng-controller="frsDonationDedicationCtrl">
<button type="button" class="sc-checkbox " data-ng-click="toggle()" role="checkbox" aria-checked="false" data-sc-checkbox="" data-ng-model="state.dedicationFormEnabled" name="dedicate"
aria-label="Dedicate my donation in honor or in memory of someone"><span class="sc-checkbox_input"></span><span class="sc-checkbox_label" data-ng-transclude="" aria-hidden="true"> Dedicate my donation <strong class="ng-scope">in honor or in
memory</strong> of someone </span></button>
<div data-ng-show="show.dedicationForm()" data-ng-form="dedicationForm" class="ng-pristine ng-hide ng-valid-email-address ng-invalid ng-invalid-required">
<!-- ngInclude: ::template('type') -->
<div data-heap-ignore="true" data-ng-include="::template('type')" class="mp-sensitive ng-scope">
<div class="donation-table ng-scope">
<div class="donation-table-label-type">
<label class="donation-label">Type</label>
</div>
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column">
<radio-group role="radiogroup" aria-label="select dedication type" class="ng-isolate-scope"><ng-transclude>
<radio-control ng-model="dedicationModel.type" name="'type'" value="'honor'" ng-required="true" aria-label="select to donate in honor of someone"
class="ng-pristine ng-untouched ng-valid ng-scope ng-isolate-scope ng-not-empty ng-valid-required ng-not-modified" required="required">
<button class="form__radio-control checked" aria-checked="true" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)" ng-disabled="$ctrl.disabled"
type="button" aria-label="select to donate in honor of someone" _spec="button">
<span class="form__radio-control_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control_label" qa-id="radio-field" ng-transclude="" _spec="label"> In honor of … </span>
</button>
</radio-control>
<radio-control ng-model="dedicationModel.type" name="'type'" value="'memory'" ng-required="true" aria-label="select to donate in memory of someone"
class="ng-pristine ng-untouched ng-valid ng-scope ng-isolate-scope ng-not-empty ng-valid-required ng-not-modified" required="required">
<button class="form__radio-control" aria-checked="false" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)" ng-disabled="$ctrl.disabled"
type="button" aria-label="select to donate in memory of someone" _spec="button">
<span class="form__radio-control_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control_label" qa-id="radio-field" ng-transclude="" _spec="label"> In memory of … </span>
</button>
</radio-control>
</ng-transclude></radio-group>
</div>
</div>
</div>
</div>
</div>
<!-- ngInclude: ::template('honoree') -->
<div data-heap-ignore="true" data-ng-include="::template('honoree')" class="mp-sensitive ng-scope">
<div class="donation-table donation-dedication__honoree ng-scope">
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column half">
<span class="donation-label required" data-sc-form-error="highlight if dedicationForm.honoree_first_name fails">Honoree’s First Name</span>
<input class="donation-text_input ng-pristine ng-untouched ng-empty ng-invalid ng-invalid-required ng-not-modified" data-ng-model="dedicationModel.honoree_first_name" data-sc-retain-focus-validity=""
data-sc-form-error="highlight if dedicationForm.honoree_first_name fails" type="text" name="honoree_first_name" aria-label="honoree's first name" required="" aria-invalid="false">
</div>
<div class="donation-table_column half">
<span class="donation-label required" data-sc-form-error="highlight if dedicationForm.honoree_last_name fails">Honoree’s Last Name</span>
<input class="donation-text_input ng-pristine ng-untouched ng-empty ng-invalid ng-invalid-required ng-not-modified" data-ng-model="dedicationModel.honoree_last_name" data-sc-retain-focus-validity=""
data-sc-form-error="highlight if dedicationForm.honoree_last_name fails" type="text" name="honoree_last_name" aria-label="honoree's last name" required="" aria-invalid="false">
</div>
</div>
<div aria-live="polite" role="alert">
<span class="donation-error ng-binding" data-sc-form-error="show if [dedicationForm.honoree_first_name, dedicationForm.honoree_last_name] fails required" style="display: none;"> Don't forget to give us a name for the dedication.
</span>
</div>
</div>
</div>
</div>
<!-- ngIf: show.emailForm() || state.postcardEnabled --><!-- ngInclude: ::template('recipient-email') -->
<div data-heap-ignore="true" data-ng-include="::template('recipient-email')" data-ng-if="show.emailForm() || state.postcardEnabled" class="mp-sensitive ng-scope">
<div class="donation-table donation-dedication_recipient-info ng-scope">
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column">
<label class="donation-label" data-ng-class="{required: show.requiredDedicationInfo()}" data-sc-form-error="highlight if [dedicationForm.name, dedicationForm.email_address] fails">Recipient's email</label>
<input class="donation-text_input ng-pristine ng-untouched ng-valid ng-empty ng-valid-email-address ng-valid-required ng-not-modified" data-ng-model="dedicationModel.email_address" data-sc-validate-email-address=""
data-sc-retain-focus-validity="" data-sc-form-error="highlight if dedicationForm.email_address fails" data-ng-required="show.requiredDedicationInfo()" type="text" name="email_address" placeholder="Email Address"
aria-label="recipient's email address, not required, use to optionally send a notification email" aria-invalid="false">
</div>
</div>
<div>
<span aria-live="polite" role="alert" class="donation-error ng-binding" data-sc-form-error="show if dedicationForm.email_address fails emailAddress" style="display: none;"> Please enter dedication recipient email in the format:
name@domain.com. </span>
</div>
<small class="donation-table_row-helper ng-binding"> Optionally send a notification email </small>
</div>
</div>
<div class="donation-table donation-dedication_recipient-info ng-scope">
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column half">
<span class="donation-label" data-sc-form-error="highlight if billing_first_name fails" data-ng-class="{required: show.requiredDedicationInfo() || state.postcardEnabled}">Recipient’s First Name</span>
<input class="donation-text_input ng-pristine ng-untouched ng-valid ng-empty ng-valid-required ng-not-modified" data-ng-model="dedicationModel.first_name" data-sc-retain-focus-validity=""
data-sc-form-error="highlight if dedicationForm.first_name fails" type="text" name="first_name" ng-required="show.requiredDedicationInfo() || state.postcardEnabled" aria-label="recipient's first name" aria-invalid="false">
</div>
<div class="donation-table_column half">
<span class="donation-label" data-sc-form-error="highlight if billing_first_name fails" data-ng-class="{required: show.requiredDedicationInfo() || state.postcardEnabled}">Recipient’s Last Name</span>
<input class="donation-text_input ng-pristine ng-untouched ng-valid ng-empty ng-valid-required ng-not-modified" data-ng-model="dedicationModel.last_name" data-sc-retain-focus-validity=""
data-sc-form-error="highlight if dedicationForm.last_name fails" type="text" name="last_name" ng-required="show.requiredDedicationInfo() || state.postcardEnabled" aria-label="recipient's last name" aria-invalid="false">
</div>
</div>
<div aria-live="polite" role="alert">
<span class="donation-error ng-binding" data-sc-form-error="show if [dedicationForm.name,dedicationForm.email_address] fails required" style="display: none;"> Don't forget to include the of your recipient. </span>
</div>
</div>
</div>
</div><!-- end ngIf: show.emailForm() || state.postcardEnabled -->
<!-- ngIf: show.postcardToggle() --><!-- ngInclude: ::template('recipient-postcard-toggle') -->
<div data-heap-ignore="true" data-ng-include="::template('recipient-postcard-toggle')" data-ng-if="show.postcardToggle()" class="mp-sensitive ng-scope">
<div class="donation-table ng-scope">
<div class="donation-table-label-type">
<label class="donation-label">Printed Card</label>
</div>
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column">
<button type="button" class="sc-checkbox " data-ng-click="toggle()" role="checkbox" aria-checked="false" data-sc-checkbox="" data-ng-model="state.postcardEnabled" aria-label="Send a printed card in the mail"><span
class="sc-checkbox_input"></span><span class="sc-checkbox_label" data-ng-transclude="" aria-hidden="true"> Send a card in the mail </span></button>
</div>
</div>
</div>
</div>
</div><!-- end ngIf: show.postcardToggle() -->
<!-- ngIf: show.postcardForm() -->
<!-- ngIf: show.emailForm() || state.postcardEnabled --><!-- ngInclude: ::template('recipient-message') -->
<div data-heap-ignore="true" data-ng-include="::template('recipient-message')" data-ng-if="show.emailForm() || state.postcardEnabled" class="mp-sensitive ng-scope">
<div class="donation-dedication_message ng-scope" data-sc-form-error="highlight if dedicationForm.ecard_message fails" aria-invalid="false">
<!-- Message Text -->
<div class="donation-dedication_message-text half" data-ng-class="{ half: show.ecardsForm() }">
<div class="donation-dedication_message-label">
<label class="donation-label" for="dedicationMessage" data-sc-form-error="highlight if dedicationForm.ecard_message fails">Your Message to the Recipient</label>
<!-- ngIf: dedicationModel.ecard_id -->
</div>
<textarea class="donation-dedication_message-input ng-pristine ng-untouched ng-valid ng-empty ng-not-modified" data-sc-form-error="highlight if dedicationForm.ecard_message fails" data-ng-model="dedicationModel.ecard_message"
data-sc-retain-focus-validity="" name="ecard_message" aria-label="Your Message to the Recipient." aria-invalid="false"></textarea>
<small class="donation-dedication_message-helper"> Please spell check, include how you would like your name(s) signed, mention the amount if desired, and format your message as you would like it delivered. </small>
</div>
<!-- Image (ecard) -->
<!-- ngIf: show.ecardsForm() -->
<div class="donation-dedication_message-ecard ng-scope" data-ng-if="show.ecardsForm()">
<label class="donation-dedication_message-label">Include an e-Card?</label>
<radio-group role="radiogroup" aria-label="select eCard to send" class="ng-isolate-scope"><ng-transclude>
<div class="donation-dedication_message-ecard-none ng-scope">
<radio-control ng-model="dedicationModel.ecard_id" name="'ecard_id'" value="null" aria-label="don't include an e-card design with the e-mail"
class="ng-pristine ng-untouched ng-valid ng-isolate-scope ng-not-empty ng-not-modified">
<button class="form__radio-control checked" aria-checked="true" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)" ng-disabled="$ctrl.disabled"
type="button" aria-label="don't include an e-card design with the e-mail" _spec="button">
<span class="form__radio-control_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control_label" qa-id="radio-field" ng-transclude="" _spec="label"> No e-Card </span>
</button>
</radio-control>
</div>
<div class="donation-dedication_message-ecard-grid ng-scope">
<!-- ngRepeat: ecard in list.ecards | orderBy: 'order' -->
<div class="donation-dedication_message-ecard-item ng-scope" data-ng-repeat="ecard in list.ecards | orderBy: 'order'" data-ng-class="{'active': dedicationModel.ecard_id == ecard.id }" data-ng-click="selectEcard(ecard.id)"
data-ng-style="{color: theme.current.styles.primaryColor}" style="color: rgb(239, 62, 66);">
<div class="donation-dedication_message-ecard-radio">
<radio-control value="ecard.id" ng-model="dedicationModel.ecard_id" name="'ecard_id'" size="'small'" aria-label="e-Card option 1" class="ng-pristine ng-untouched ng-valid ng-isolate-scope ng-not-empty ng-not-modified">
<button class="form__radio-control--small" aria-checked="false" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)"
ng-disabled="$ctrl.disabled" type="button" aria-label="e-Card option 1" _spec="button">
<span class="form__radio-control--small_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control--small_label" qa-id="radio-field" ng-transclude="" _spec="label"></span>
</button>
</radio-control>
</div>
<img class="donation-dedication_message-ecard-image" data-ng-src="https://assets.classy.org/4372862/a5acf23e-475a-11e8-b49e-063732f7f9b0.jpg" alt="dedication message ecard 1"
src="https://assets.classy.org/4372862/a5acf23e-475a-11e8-b49e-063732f7f9b0.jpg" data-airgap-id="55">
</div><!-- end ngRepeat: ecard in list.ecards | orderBy: 'order' -->
<div class="donation-dedication_message-ecard-item ng-scope" data-ng-repeat="ecard in list.ecards | orderBy: 'order'" data-ng-class="{'active': dedicationModel.ecard_id == ecard.id }" data-ng-click="selectEcard(ecard.id)"
data-ng-style="{color: theme.current.styles.primaryColor}" style="color: rgb(239, 62, 66);">
<div class="donation-dedication_message-ecard-radio">
<radio-control value="ecard.id" ng-model="dedicationModel.ecard_id" name="'ecard_id'" size="'small'" aria-label="e-Card option 2" class="ng-pristine ng-untouched ng-valid ng-isolate-scope ng-not-empty ng-not-modified">
<button class="form__radio-control--small" aria-checked="false" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)"
ng-disabled="$ctrl.disabled" type="button" aria-label="e-Card option 2" _spec="button">
<span class="form__radio-control--small_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control--small_label" qa-id="radio-field" ng-transclude="" _spec="label"></span>
</button>
</radio-control>
</div>
<img class="donation-dedication_message-ecard-image" data-ng-src="https://assets.classy.org/4372862/af67fdfa-475a-11e8-a7de-0a5beb8d1b7a.jpg" alt="dedication message ecard 2"
src="https://assets.classy.org/4372862/af67fdfa-475a-11e8-a7de-0a5beb8d1b7a.jpg" data-airgap-id="56">
</div><!-- end ngRepeat: ecard in list.ecards | orderBy: 'order' -->
<div class="donation-dedication_message-ecard-item ng-scope" data-ng-repeat="ecard in list.ecards | orderBy: 'order'" data-ng-class="{'active': dedicationModel.ecard_id == ecard.id }" data-ng-click="selectEcard(ecard.id)"
data-ng-style="{color: theme.current.styles.primaryColor}" style="color: rgb(239, 62, 66);">
<div class="donation-dedication_message-ecard-radio">
<radio-control value="ecard.id" ng-model="dedicationModel.ecard_id" name="'ecard_id'" size="'small'" aria-label="e-Card option 3" class="ng-pristine ng-untouched ng-valid ng-isolate-scope ng-not-empty ng-not-modified">
<button class="form__radio-control--small" aria-checked="false" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)"
ng-disabled="$ctrl.disabled" type="button" aria-label="e-Card option 3" _spec="button">
<span class="form__radio-control--small_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control--small_label" qa-id="radio-field" ng-transclude="" _spec="label"></span>
</button>
</radio-control>
</div>
<img class="donation-dedication_message-ecard-image" data-ng-src="https://assets.classy.org/4372862/b46d0f70-475a-11e8-b963-06ca153bb396.jpg" alt="dedication message ecard 3"
src="https://assets.classy.org/4372862/b46d0f70-475a-11e8-b963-06ca153bb396.jpg" data-airgap-id="57">
</div><!-- end ngRepeat: ecard in list.ecards | orderBy: 'order' -->
<div class="donation-dedication_message-ecard-item ng-scope" data-ng-repeat="ecard in list.ecards | orderBy: 'order'" data-ng-class="{'active': dedicationModel.ecard_id == ecard.id }" data-ng-click="selectEcard(ecard.id)"
data-ng-style="{color: theme.current.styles.primaryColor}" style="color: rgb(239, 62, 66);">
<div class="donation-dedication_message-ecard-radio">
<radio-control value="ecard.id" ng-model="dedicationModel.ecard_id" name="'ecard_id'" size="'small'" aria-label="e-Card option 4" class="ng-pristine ng-untouched ng-valid ng-isolate-scope ng-not-empty ng-not-modified">
<button class="form__radio-control--small" aria-checked="false" role="radio" tabindex="0" ng-class="{ checked: $ctrl.isChecked() }" ng-click="$ctrl.select()" ng-keydown="$ctrl.onKeyDown($event)"
ng-disabled="$ctrl.disabled" type="button" aria-label="e-Card option 4" _spec="button">
<span class="form__radio-control--small_input" sc-error-class="$ctrl.ngModelCtrl.$name" ng-style="{ color: $ctrl.color }" _spec="radio" style="color: rgb(239, 62, 66);"></span>
<span class="form__radio-control--small_label" qa-id="radio-field" ng-transclude="" _spec="label"></span>
</button>
</radio-control>
</div>
<img class="donation-dedication_message-ecard-image" data-ng-src="https://assets.classy.org/4372862/ba2eff90-475a-11e8-80bc-0e536837d064.jpg" alt="dedication message ecard 4"
src="https://assets.classy.org/4372862/ba2eff90-475a-11e8-80bc-0e536837d064.jpg" data-airgap-id="58">
</div><!-- end ngRepeat: ecard in list.ecards | orderBy: 'order' -->
<!-- ngIf: dedicationModel.ecard_id -->
</div>
</ng-transclude></radio-group>
</div><!-- end ngIf: show.ecardsForm() -->
</div>
</div><!-- end ngIf: show.emailForm() || state.postcardEnabled -->
</div>
</section>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<section class="donation-matching ng-scope" data-ng-controller="frsDoubleTheDonationCtrl" data-ng-show="isEmployerMatchOnDonationPage">
<button type="button" class="sc-checkbox " data-ng-click="toggle()" role="checkbox" aria-checked="false" data-sc-checkbox="" data-ng-model="state.doubleTheDonationFormEnabled" aria-label="Have your employer match your donation"><span
class="sc-checkbox_input"></span><span class="sc-checkbox_label" data-ng-transclude="" aria-hidden="true"> See if your employer will match your donation </span></button>
<div data-ng-show="show.doubleTheDonationForm()" data-ng-form="doubleTheDonationForm" class="ng-pristine ng-valid ng-hide">
<div class="double-the-donation-label"> Check to see if your employer will match your donation. You may receive an email on how to submit your match request to maximize your impact. </div>
<!-- ngInclude: ::template('company') -->
<div data-heap-ignore="true" class="mp-sensitive ng-scope" data-ng-include="::template('company')">
<div class="donation-table donation-table_margin_top_12 ng-scope">
<div class="donation-table_label">
<label class="donation-label">Company</label>
</div>
<div class="donation-table_row">
<div class="donation-table_columns">
<div class="donation-table_column">
<div id="dd-company-name-input"></div>
<script>
var DDCONF = {
API_KEY: SC.organization.doubleTheDonationChannel.publicKey
};
</script>
</div>
</div>
</div>
</div>
</div>
</div>
</section>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<section class="donation-credit ng-scope no-fundraising" ng-class="{'no-fundraising': !campaign.HAS_FUNDRAISING}" data-ng-controller="frsDonationCreditCtrl">
<!-- ngIf: !campaign.current.disable_donation_attribution && campaign.HAS_FUNDRAISING -->
<!-- ngIf: show.designation() --><!-- ngInclude: ::template('designation') -->
<div data-ng-if="show.designation()" data-ng-include="::template('designation')" class="ng-scope"></div><!-- end ngIf: show.designation() -->
</section>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<div class="donation-donor ng-scope" data-ng-controller="frsDonationDonorCtrl" aria-labelledby="donationPage_your-information-heading">
<h2 class="donation-subtitle" id="donationPage_your-information-heading">Your Information</h2>
<!-- ngIf: show.prefix() -->
<!-- ngInclude: ::template('name') -->
<div data-heap-ignore="true" class="mp-sensitive ng-scope" data-ng-include="::template('name')">
<div class="donation-table ng-scope">
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column half" data-ng-class="show.middleName() ? 'third' : 'half'">
<span class="donation-label required" data-sc-form-error="highlight if member_first_name fails">First Name</span>
<input class="donation-text_input ng-pristine ng-untouched ng-empty ng-invalid ng-invalid-required ng-not-modified" data-ng-model="META.member_first_name" data-sc-form-error="highlight if member_first_name fails"
data-sc-retain-focus-validity="" type="text" name="member_first_name" aria-label="Please enter your first name" required="" aria-invalid="false">
</div>
<!-- ngIf: show.middleName() -->
<div class="donation-table_column half" data-ng-class="show.middleName() ? 'third' : 'half'">
<span class="donation-label required" data-sc-form-error="highlight if member_last_name fails">Last Name</span>
<input class="donation-text_input ng-pristine ng-untouched ng-empty ng-invalid ng-invalid-required ng-not-modified" data-ng-model="META.member_last_name" data-sc-form-error="highlight if member_last_name fails"
data-sc-retain-focus-validity="" type="text" name="member_last_name" aria-label="Please enter your last name" required="" aria-invalid="false">
</div>
</div>
<div aria-live="assertive">
<span class="donation-error ng-binding" data-sc-form-error="show if [member_first_name,optional_middle_name,member_last_name] fails" ng-bind="build.nameError()" style="display: none;">Be sure to provide your name.</span>
</div>
<!-- ngIf: show.anonymous() || show.anonymousDonationAmounts() -->
</div>
</div>
</div>
<!-- ngIf: show.suffix() -->
<!-- ngInclude: ::template('email') -->
<div data-heap-ignore="true" class="mp-sensitive ng-scope" data-ng-include="::template('email')">
<div class="donation-table ng-scope">
<div class="donation-table_label">
<label class="donation-label required" data-sc-form-error="highlight if member_email_address fails">Email</label>
</div>
<div class="donation-table_row">
<div class="donation-table_columns">
<div class="donation-table_column">
<input class="donation-text_input ng-pristine ng-untouched ng-empty ng-valid-email-address ng-invalid ng-invalid-required ng-not-modified" data-ng-model="MODEL.member_email_address"
data-sc-form-error="highlight if member_email_address fails" data-sc-validate-email-address="" data-sc-retain-focus-validity="" type="text" name="member_email_address" aria-label="Email address. Your receipt will be emailed here."
required="" aria-invalid="false">
</div>
</div>
<div aria-live="polite" role="alert">
<span class="donation-error ng-binding" data-sc-form-error="show if member_email_address fails required" style="display: none;"> Don't forget your email address. </span>
<span class="donation-error ng-binding" data-sc-form-error="show if member_email_address fails emailAddress" style="display: none;"> Please enter in the format: name@domain.com. </span>
</div>
<small class="donation-table_row-helper"> Your receipt will be emailed here. </small>
<sc-consent data-show="!campaign.current.hide_contact_opt_in" data-opt-in="MODEL.opt_in" data-language="MODEL.opt_in_wording" name="opt_in" class="ng-isolate-scope">
<!-- ngIf: $ctrl.show -->
<div data-ng-if="$ctrl.show" data-ng-hide="$ctrl.hide" class="sc-consent ng-scope">
<button type="button" class="sc-checkbox_top sc-checkbox checked" data-ng-click="toggle()" role="checkbox" aria-checked="true" data-sc-checkbox="" data-ng-model="$ctrl.optIn"
aria-label="I would like to receive emails from The Salvation Army." name="opt_in"><span class="sc-checkbox_input"></span><span class="sc-checkbox_label" data-ng-transclude="" aria-hidden="true"> I would like to receive emails
from The Salvation Army. </span></button>
</div><!-- end ngIf: $ctrl.show -->
</sc-consent>
</div>
</div>
</div>
<!-- ngInclude: ::template('phone') -->
<div data-heap-ignore="true" class="mp-sensitive ng-scope" data-ng-include="::template('phone')">
<div class="donation-table ng-scope" style="display: none;">
<div class="donation-table_label">
<label class="donation-label" data-ng-class="{ required: get.homephone('is_required') }" data-sc-form-error="highlight if member_phone fails">Phone Number</label>
</div>
<div class="donation-table_row">
<div class="donation-table_columns">
<div class="donation-table_column half">
<input class="donation-text_input ng-pristine ng-untouched ng-valid ng-empty ng-valid-phone-number ng-valid-required ng-not-modified" data-ng-model="MODEL.member_phone" data-sc-form-error="highlight if member_phone fails"
data-sc-validate-phone="" data-sc-retain-focus-validity="" data-ng-required="get.homephone('is_required')" inputmode="numeric" type="tel" aria-label="phone number, numbers only" name="member_phone" aria-invalid="false">
</div>
</div>
<div aria-live="polite" role="alert">
<span class="donation-error ng-binding" data-sc-form-error="show if member_phone fails phoneNumber" style="display: none;"> Please enter a valid phone number. </span>
<span class="donation-error ng-binding" data-sc-form-error="show if member_phone fails required" style="display: none;"> Don't forget your phone number. </span>
</div>
</div>
</div>
</div>
<!-- ngIf: show.cellPhone() -->
<!-- ngIf: show.comment() -->
<!-- ngIf: show.company() -->
<!-- ngIf: show.blog() -->
<!-- ngIf: show.website() -->
<!-- ngIf: show.gender() -->
<!-- ngIf: show.pronoun() -->
<!-- ngIf: show.birthdate() -->
<!-- ngIf: show.customQuestions() --><!-- ngInclude: ::template('custom-questions') -->
<div data-heap-ignore="true" class="mp-sensitive ng-scope" data-ng-include="::template('custom-questions')" data-ng-if="show.customQuestions()">
<!-- ngRepeat: question in list.customQuestions --><!-- end ngRepeat: question in list.customQuestions --></div><!-- end ngIf: show.customQuestions() -->
<div class="donation-table ng-scope locationQ" data-ng-repeat="question in list.customQuestions">
<!-- ngInclude: ::template('questions/' + question.type) -->
<div data-ng-include="::template('questions/' + question.type)" class="ng-scope">
<div class="donation-table_label ng-scope" style="display: none;">
<label class="donation-label" data-sc-form-error="highlight if cq_240443 fails" data-ng-class="{ required: question.is_required }" style="display: none;">Waiver</label>
</div>
<div class="donation-table_row ng-scope">
<div class="donation-table_columns">
<div class="donation-table_column">
<div class="donation-waiver ng-binding" ng-bind-html="question.label | nl2br" style="display: none;">This donation is for a specific city, state OUTSIDE of my local community.</div>
<button type="button" class="sc-checkbox " data-ng-click="toggle()" role="checkbox" aria-checked="false" data-sc-checkbox="" data-ng-model="META.answers[question.id]" data-ng-model-options="{ getterSetter: true }"
data-sc-form-error="highlight if cq_240443 fails" data-ng-required="question.is_required" name="cq_240443" aria-invalid="false"><span class="sc-checkbox_input"></span><span class="sc-checkbox_label" data-ng-transclude=""
aria-hidden="true">This donation is for a specific city, state OUTSIDE of my local community.</span></button>
</div>
</div>
<div aria-live="polite" role="alert">
<span class="donation-error ng-binding" data-sc-form-error="show if cq_240443 fails required" style="display: none;"> This field is required. </span>
</div>
</div>
</div>
</div>
<div class="donation-credit_designation ng-scope no-fundraising" ng-class="{'no-fundraising': !campaign.HAS_FUNDRAISING}" style="display: none;">
<program-designation-field entity="campaign.current" selected-id="campaign.current.designation_id" model="MODEL.designation_id" form-name="FORM" field-option-settings="designationOptions" class="ng-isolate-scope">
<div class="program-designation-field form_field full">
<label class="form__label ng-binding" _spec="label">
<!-- ngIf: $ctrl.fieldOptionSettings.check.enabled -->
<!-- ngIf: $ctrl.fieldOptionSettings.required -->
</label>
<!-- ngIf: $ctrl.selected --><typeahead-dropdown-control ng-if="$ctrl.selected" fetch-action="$ctrl.getDesignations" selected-item="$ctrl.selected" element-index="" on-item-selected="$ctrl.onItemSelected(item, model, label)"
on-scroll-to-bottom="$ctrl.onScrollToBottom()" show-group-names="$ctrl.entity.display_group_name" class="ng-scope ng-isolate-scope">
<div ng-class="{'typeahead_is-loading': $ctrl.loadingItems}">
<div class="typeahead_input-dropdown" ng-class="{ 'typeahead-show-groups': $ctrl.showGroupNames }">
<input uib-typeahead="item as item.name for item in $ctrl.executeFetchAction($viewValue)" typeahead-loading="$ctrl.loadingItems" typeahead-no-results="$ctrl.noResults" typeahead-is-open="$ctrl.isOpen"
typeahead-on-select="$ctrl.itemSelected($item, $model, $label)" typeahead-min-length="0" typeahead-focus-on-select="false" typeahead-editable="$ctrl.noResults"
typeahead-popup-template-url="global/components/controls/typeaheadDropdownControlPopup" autocomplete="6642052159880161" ng-model="$ctrl.selected" ng-model-options="$ctrl.typeaheadOptions"
class="typeahead_input ng-pristine ng-untouched ng-valid ng-empty ng-not-modified" placeholder="City, ST" type="text" ng-disabled="" role="combobox" aria-label="Program Designation" aria-autocomplete="list" aria-expanded="false"
aria-owns="typeahead-280-9041">
<div class="typeahead_popup-placeholder typeahead_custom-popup-container ng-isolate-scope ng-hide" ng-style="{top: position().top + 8 + 'px', left: position().left + 'px'}" style="display: block; top: 8px;"
ng-show="isOpen() && !moveInProgress" aria-hidden="true" uib-typeahead-popup="" id="typeahead-280-9041" matches="matches" active="activeIdx" select="select(activeIdx, evt)" move-in-progress="moveInProgress" query="query"
position="position" assign-is-open="assignIsOpen(isOpen)" debounce="debounceUpdate" popup-template-url="global/components/controls/typeaheadDropdownControlPopup">
<!-- ngRepeat: match in matches track by $index -->
</div>
<div class="typeahead_arrow-overlay" ng-click="$ctrl.onArrowClick()"></div>
<!-- ngIf: $ctrl.loadingItems -->
<!-- ngIf: $ctrl.noResults -->
</div>
</div>
</typeahead-dropdown-control><!-- end ngIf: $ctrl.selected -->
</div>
</program-designation-field>
</div>
</div>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<div data-ng-controller="frsDonationPaymentCtrl" id="df_checkout_donation-payment" class="donation-payment ng-scope" aria-label="Payment Details">
<div>
<cp-payment-widget id="classy-payment-widget" api="API" payment="MODEL.payment" submit-digital-wallets="submitDigitalWallets" fee-processing="globalState.feeProcessing" meta="META" parent-model="MODEL" hide-postal="true"
currency="MODEL.payment.raw_currency_code" class="ng-isolate-scope">
<div class="donation-payment-method-select row" ng-hide="$ctrl.hideButtons">
<div class="column-md-7">
<summary-amount amount="$ctrl.meta.summaryAmount" recur_until="$ctrl.parentModel.recur_until" feeprocessing="$ctrl.feeProcessing" frequency="$ctrl.parentModel.frequency" taxcompliance="$ctrl.meta.unsupportedTaxCompliance"
currency="$ctrl.parentModel.payment.raw_currency_code" estimatedcharge="$ctrl.meta.estimatedCharge" class="ng-isolate-scope">
<p class="donation-summary-amount">
<span class="sr-only">your currently selected donation amount is </span>
<!-- ngIf: !$ctrl.preventRecurringFrequency --><span class="donation-summary-amount-label ng-binding ng-scope" aria-hidden="true" ng-if="!$ctrl.preventRecurringFrequency">One-time
donation</span><!-- end ngIf: !$ctrl.preventRecurringFrequency -->
<!-- ngIf: $ctrl.preventRecurringFrequency -->
<span class="donation-summary-amount-amount ng-binding" data-ng-class="{ processing: $ctrl.feeprocessing }"> SGD 140.00<!-- ngIf: $ctrl.preventRecurringFrequency -->
<span class="donation-summary-amount-currency ng-binding">SGD</span>
<span class="donation-summary-amount-processing">
<span class="donation-summary-amount-processing-spinner"></span>
</span>
</span>
<!-- ngIf: !$ctrl.preventRecurringFrequency && $ctrl.recurUntil -->
<!-- ngIf: !$ctrl.preventRecurringFrequency --><span class="donation-summary-amount-date ng-binding ng-scope" ng-if="!$ctrl.preventRecurringFrequency"></span><!-- end ngIf: !$ctrl.preventRecurringFrequency -->
<!-- ngIf: $ctrl.taxCompliance -->
</p>
</summary-amount>
<fee-on-top fot="$ctrl.parentModel.fee_on_top" class="ng-isolate-scope"><!-- ngIf: $ctrl.showFOT() -->
<div class="donation-table ng-scope" ng-if="$ctrl.showFOT()" style="margin-top:0">
<div class="donation-table_row">
<div class="donation-table_columns donation-table_columns_without_margin">
<div class="donation-table_column">
<button type="button" class="fot-checkbox sc-checkbox " data-ng-click="toggle()" role="checkbox" aria-checked="false" data-sc-checkbox="" data-ng-model="$ctrl.fot" name="donation_fot"
aria-label="I’d like to cover the fees so more of my donation goes to The Salvation Army"><span class="sc-checkbox_input"></span><span class="sc-checkbox_label" data-ng-transclude="" aria-hidden="true">
<span data-sc-ctx-bind-html="$ctrl.classyModeAppeal() | scTrustedHtml" class="ng-scope">
<p>I’d like to cover the fees so more of my donation goes to The Salvation Army</p>
</span>
</span></button>
</div>
</div>
</div>
</div><!-- end ngIf: $ctrl.showFOT() -->
</fee-on-top>
</div>
<div class="column-md-5">
<small ng-hide="$ctrl.showDW" class="donation-payment-method-select_description ng-hide"> Donate with your preferred payment method: </small>
<!-- ngIf: $ctrl.showDW --><small ng-if="$ctrl.showDW" class="donation-payment-method-select_dwterms ng-scope"> By clicking the donate button, I agree to the <a href="https://www.classy.org/terms/" target="_blank">Terms of Service</a>
and <a href="https://www.classy.org/terms/privacy/" target="_blank">Privacy Policy</a>
</small><!-- end ngIf: $ctrl.showDW -->
<!-- ngIf: !$ctrl.isTrial --><cp-digital-wallets data-ng-if="!$ctrl.isTrial" frequency="$ctrl.parentModel.frequency" amount="$ctrl.getAmount()" currency="$ctrl.parentModel.payment.raw_currency_code" submit="$ctrl.submitDigitalWallets"
pay-type="$ctrl.meta.digitalWalletType" fot="$ctrl.parentModel.fee_on_top" classymode="$ctrl.isClassyMode" class="ng-scope ng-isolate-scope"><!-- ngIf: $ctrl.showDigitalWallets -->
<div ng-if="$ctrl.showDigitalWallets" class="ng-scope">
<button type="button" aria-label="Donate With Google Pay" role="link" class="digital-wallets-btn google-pay" data-tracked-element="donation-page_checkout_digital-wallet" ng-click="$ctrl.openDWModal()">
<img ng-src="/static/global/images/digitalWallets/GooglePay-logo.svg" alt="Google Pay" src="/static/global/images/digitalWallets/GooglePay-logo.svg" data-airgap-id="74">
</button>
</div><!-- end ngIf: $ctrl.showDigitalWallets -->
</cp-digital-wallets><!-- end ngIf: !$ctrl.isTrial -->
<!-- ngIf: $ctrl.show.paypal() && !$ctrl.isTrial --><cp-paypal-widget data-ng-if="$ctrl.show.paypal() && !$ctrl.isTrial" model="$ctrl.payment.paypal" sc-validity-reporter="" ng-model="$ctrl.payment.paypal.status"
on-ready="$ctrl.onPaypalReady()" on-success="$ctrl.onPaypalSuccess(params)" on-cancel="$ctrl.onPaypalCancel()" currency="$ctrl.currency"
class="ng-pristine ng-untouched ng-valid ng-scope ng-isolate-scope ng-not-empty ng-not-modified">
<div class="cp-paypal-widget">
<button data-tracked-element="donation-page_checkout_paypal-btn" type="button" ng-click="$ctrl.openModal()" ng-class="{'logged-in': $ctrl.model.status === $ctrl.constants.STATUS.SUCCESS}" class="payment-method-select-btn__paypal"
id="btPaypal" ng-show="$ctrl.model.status !== $ctrl.constants.STATUS.INACTIVE"><img ng-src="/static/global/images/payments/logo-paypal.svg" alt="PayPal" <="" button="" src="/static/global/images/payments/logo-paypal.svg"
data-airgap-id="47">
</button>
</div>
</cp-paypal-widget><!-- end ngIf: $ctrl.show.paypal() && !$ctrl.isTrial -->
<!-- ngIf: $ctrl.show.paypalCommerce() || $ctrl.show.venmo() -->
<button data-tracked-element="donation-page_checkout_credit-card-btn" class="payment-method-select-btn__cc" type="button" style="background:rgb(239, 62, 66)" ng-click="$ctrl.showCardInputs()" aria-expanded="false"
aria-controls="donation-page_checkout_payment-form donation-page_checkout_payment-details">Credit Card</button>
<!-- ngIf: $ctrl.show.achButton() && !$ctrl.isTrial --><cp-plaid-widget data-ng-if="$ctrl.show.achButton() && !$ctrl.isTrial" &="" model="$ctrl.payment.ach" sc-validity-reporter="" ng-model="$ctrl.payment.ach.status"
on-ready="$ctrl.onAchReady()" on-success="$ctrl.onAchSuccess(lastFour, accountType)" on-cancel="$ctrl.onAchCancel()" currency="$ctrl.currency"
class="ng-pristine ng-untouched ng-valid ng-scope ng-isolate-scope ng-not-empty ng-not-modified">
<button type="button" data-tracked-element="donation-page_checkout_ach-plaid-btn" class="payment-method-select-btn__ach" ng-style="{ 'background': $ctrl.primaryColor }"
ng-show="$ctrl.model.status !== $ctrl.constants.STATUS.INACTIVE" ng-click="$ctrl.openPlaidDialog()" tabindex="0" style="background: rgb(239, 62, 66);"> Bank Transfer </button>
</cp-plaid-widget><!-- end ngIf: $ctrl.show.achButton() && !$ctrl.isTrial -->
<!-- ngIf: $ctrl.show.accountRoutingButton() && !$ctrl.isTrial -->
</div>
</div>
<!-- ngIf: $ctrl.meta.showPaymentDetails -->
<!-- ngIf: $ctrl.meta.showPaymentDetails -->
</cp-payment-widget>
</div>
<!-- ngIf: META.showPaymentDetails -->
</div>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
<section class="block-component ng-scope" data-ng-repeat="component in list.components | filter:{section:'main'} | orderBy:'order'">
<!-- ngInclude: component.templateUrl -->
<div data-ng-include="component.templateUrl" class="ng-scope">
<section id="df_checkout_donation-footer" class="donation-footer ng-scope ng-hide" data-ng-controller="frsDonationFooterCtrl" data-ng-show="META.showPaymentDetails">
<div class="donation-footer_container">
<!-- ngIf: show.achTerms() -->
<small class="donation-footer_terms"> By clicking <span class="ng-binding">DONATE</span>, I agree to the <a href="https://www.classy.org/terms" target="_blank" aria-label="View Terms of Service page">Terms of Service</a> and
<a href="https://www.classy.org/terms/privacy" target="_blank" aria-label="View Classy Privacy Policy page">Classy Privacy Policy</a>
</small>
<!-- ngIf: show.feeOnTop() -->
<div class="donation-footer_controls">
<!-- ngIf: !editable --><button id="donate-cta-main" class="donation-footer_submit ng-binding ng-scope" ng-if="!editable" data-ng-style="{'background-color': theme.current.styles.primaryColor}"
data-ng-disabled="globalState.processing || globalState.submitDisabled" data-ng-bind="block['submit-button-text'] || 'Donate' " aria-label="click give now to donate SGD 140.00" type="submit"
style="background-color: rgb(239, 62, 66);">DONATE</button><!-- end ngIf: !editable -->
<!-- ngIf: editable -->
</div>
<div class="donation-footer_summary">
<!-- ngIf: show.creditee() -->
<summary-amount amount="META.summaryAmount" recur_until="MODEL.recur_until" feeprocessing="globalState.feeProcessing" frequency="MODEL.frequency" taxcompliance="META.unsupportedTaxCompliance" currency="MODEL.payment.raw_currency_code"
estimatedcharge="META.estimatedCharge" class="ng-isolate-scope">
<p class="donation-summary-amount">
<span class="sr-only">your currently selected donation amount is </span>
<!-- ngIf: !$ctrl.preventRecurringFrequency --><span class="donation-summary-amount-label ng-binding ng-scope" aria-hidden="true" ng-if="!$ctrl.preventRecurringFrequency">One-time
donation</span><!-- end ngIf: !$ctrl.preventRecurringFrequency -->
<!-- ngIf: $ctrl.preventRecurringFrequency -->
<span class="donation-summary-amount-amount ng-binding" data-ng-class="{ processing: $ctrl.feeprocessing }"> SGD 140.00<!-- ngIf: $ctrl.preventRecurringFrequency -->
<span class="donation-summary-amount-currency ng-binding">SGD</span>
<span class="donation-summary-amount-processing">
<span class="donation-summary-amount-processing-spinner"></span>
</span>
</span>
<!-- ngIf: !$ctrl.preventRecurringFrequency && $ctrl.recurUntil -->
<!-- ngIf: !$ctrl.preventRecurringFrequency --><span class="donation-summary-amount-date ng-binding ng-scope" ng-if="!$ctrl.preventRecurringFrequency"></span><!-- end ngIf: !$ctrl.preventRecurringFrequency -->
<!-- ngIf: $ctrl.taxCompliance -->
</p>
</summary-amount>
</div>
<!-- ngIf: META.unsupportedTaxCompliance -->
<div class="donation-footer__compliance--unsupported ng-scope" ng-if="META.unsupportedTaxCompliance">
<div class="donation-footer__compliance-img">
<i class="ci ci-world-hands"></i>
</div>
<div class="donation-footer__compliance-text">
<span class="donation-footer__compliance-title">International Gift</span>
<p class="ng-binding">You are giving to an organization located in United States. This donation will be processed and receipted in USD and deposited to a US bank account. Contributions are tax deductible to the extent allowed by the
laws of your country. Consult your local tax professional.</p>
</div>
</div><!-- end ngIf: META.unsupportedTaxCompliance -->
</div>
</section>
<div class="donation-border-top donation-footer__compliance ng-scope ng-hide" ng-show="META.showTaxComplianceLanguage">
<p ng-bind-html="META.taxComplianceLanguage" class="ng-binding"></p>
</div>
</div>
</section><!-- end ngRepeat: component in list.components | filter:{section:'main'} | orderBy:'order' -->
</form>
Text Content
Close LOVE BEYOND CHRISTMAS Your gift to The Salvation Army supports local families this season and beyond. Challenges that families face don’t end when the holidays do and when you give monthly, each hard-earned dollar goes further, and you are able to make a greater impact in your community. So you can put a present under someone’s tree today and a roof over someone’s head tomorrow. One time monthly Choose a one-time amount * SGD 680 * SGD 340 * SGD 140 * SGD 68 AED | United Arab Emirates DirhamAFN | Afghan AfghaniALL | Albanian LekAMD | Armenian DramANG | Netherlands Antillean GuilderAOA | Angolan KwanzaARS | Argentine PesoAUD | Australian DollarAWG | Aruban FlorinAZN | Azerbaijani ManatBAM | Bosnia And Herzegovina Convertible MarkBBD | Barbados DollarBDT | Bangladeshi TakaBGN | Bulgarian LevBHD | Bahraini DinarBIF | Burundian FrancBMD | Bermudian Dollar (customarily Known As Bermuda Dollar)BND | Brunei DollarBOB | BolivianoBRL | Brazilian RealBSD | Bahamian DollarBTN | Bhutanese NgultrumBWP | Botswana PulaBZD | Belize DollarCAD | Canadian DollarCDF | Congolese FrancCHF | Swiss FrancCLF | Unidad De Fomento (funds Code)CLP | Chilean PesoCNY | Chinese YuanCOP | Colombian PesoCRC | Costa Rican ColonCUC | Cuban Convertible PesoCUP | Cuban PesoCVE | Cape Verde EscudoCZK | Czech KorunaDJF | Djiboutian FrancDKK | Danish KroneDOP | Dominican PesoDZD | Algerian DinarEGP | Egyptian PoundERN | Eritrean NakfaETB | Ethiopian BirrEUR | EuroFJD | Fiji DollarFKP | Falkland Islands PoundGBP | Pound SterlingGEL | Georgian LariGHS | Ghanaian CediGIP | Gibraltar PoundGMD | Gambian DalasiGNF | Guinean FrancGTQ | Guatemalan QuetzalGYD | Guyanese DollarHKD | Hong Kong DollarHNL | Honduran LempiraHRK | Croatian KunaHTG | Haitian GourdeHUF | Hungarian ForintIDR | Indonesian RupiahILS | Israeli New ShekelINR | Indian RupeeIQD | Iraqi DinarIRR | Iranian RialISK | Icelandic KrónaJMD | Jamaican DollarJOD | Jordanian DinarJPY | Japanese YenKES | Kenyan ShillingKGS | Kyrgyzstani SomKHR | Cambodian RielKMF | Comoro FrancKPW | North Korean WonKRW | South Korean WonKWD | Kuwaiti DinarKYD | Cayman Islands DollarKZT | Kazakhstani TengeLAK | Lao KipLBP | Lebanese PoundLKR | Sri Lankan RupeeLRD | Liberian DollarLSL | Lesotho LotiLYD | Libyan DinarMAD | Moroccan DirhamMDL | Moldovan LeuMGA | Malagasy AriaryMKD | Macedonian DenarMMK | Myanma KyatMNT | Mongolian TugrikMOP | Macanese PatacaMUR | Mauritian RupeeMVR | Maldivian RufiyaaMWK | Malawian KwachaMXN | Mexican PesoMYR | Malaysian RinggitMZN | Mozambican MeticalNAD | Namibian DollarNGN | Nigerian NairaNIO | Nicaraguan CórdobaNOK | Norwegian KroneNPR | Nepalese RupeeNZD | New Zealand DollarOMR | Omani RialPAB | Panamanian BalboaPEN | Peruvian Nuevo SolPGK | Papua New Guinean KinaPHP | Philippine PesoPKR | Pakistani RupeePLN | Polish ZłotyPYG | Paraguayan GuaraníQAR | Qatari RiyalRON | Romanian New LeuRSD | Serbian DinarRWF | Rwandan FrancSAR | Saudi RiyalSBD | Solomon Islands DollarSCR | Seychelles RupeeSDG | Sudanese PoundSEK | Swedish Krona/kronorSGD | Singapore DollarSHP | Saint Helena PoundSLL | Sierra Leonean LeoneSOS | Somali ShillingSRD | Surinamese DollarSSP | South Sudanese PoundSTD | São Tomé And Príncipe DobraSYP | Syrian PoundSZL | Swazi LilangeniTHB | Thai BahtTJS | Tajikistani SomoniTMT | Turkmenistani ManatTND | Tunisian DinarTOP | Tongan PaʻangaTRY | Turkish LiraTTD | Trinidad And Tobago DollarTWD | New Taiwan DollarTZS | Tanzanian ShillingUAH | Ukrainian HryvniaUGX | Ugandan ShillingUSD | United States DollarUYU | Uruguayan PesoUZS | Uzbekistan SomVND | Vietnamese DongVUV | Vanuatu VatuWST | Samoan TalaXAF | CFA Franc BEACXCD | East Caribbean DollarXDR | Special Drawing RightsXOF | CFA Franc BCEAOXPF | CFP FrancYER | Yemeni RialZAR | South African Rand SGD Dedicate my donation in honor or in memory of someone Type In honor of … In memory of … Honoree’s First Name Honoree’s Last Name Don't forget to give us a name for the dedication. Recipient's email Please enter dedication recipient email in the format: name@domain.com. Optionally send a notification email Recipient’s First Name Recipient’s Last Name Don't forget to include the of your recipient. Printed Card Send a card in the mail Your Message to the Recipient Please spell check, include how you would like your name(s) signed, mention the amount if desired, and format your message as you would like it delivered. Include an e-Card? No e-Card See if your employer will match your donation Check to see if your employer will match your donation. You may receive an email on how to submit your match request to maximize your impact. Company YOUR INFORMATION First Name Last Name Be sure to provide your name. Email Don't forget your email address. Please enter in the format: name@domain.com. Your receipt will be emailed here. I would like to receive emails from The Salvation Army. Phone Number Please enter a valid phone number. Don't forget your phone number. Waiver This donation is for a specific city, state OUTSIDE of my local community. This donation is for a specific city, state OUTSIDE of my local community. This field is required. your currently selected donation amount is One-time donation SGD 140.00 SGD I’d like to cover the fees so more of my donation goes to The Salvation Army Donate with your preferred payment method: By clicking the donate button, I agree to the Terms of Service and Privacy Policy Credit Card Bank Transfer By clicking DONATE, I agree to the Terms of Service and Classy Privacy Policy DONATE your currently selected donation amount is One-time donation SGD 140.00 SGD International Gift You are giving to an organization located in United States. This donation will be processed and receipted in USD and deposited to a US bank account. Contributions are tax deductible to the extent allowed by the laws of your country. Consult your local tax professional. Prefer to donate with cryptocurrency? Donate Crypto LOVE BEYOND CHRISTMAS Bitcoin Ethereum USDC Choose a donation amount $500.00 0.01369861 BTC $250.00 0.00684931 BTC $100.00 0.00273972 BTC $50.00 0.00136986 BTC USD BTC enter an amount greater than 0 What would you like your donation to support? Donate NaN BTC QUESTIONS Is this donation tax deductible? The Salvation Army National Corporation is a 501(c)3 tax-exempt organization and your donation is tax-deductible within the guidelines of U.S. law. To claim a donation as a deduction on your U.S. taxes, please keep your email donation receipt as your official record. We'll send it to you upon successful completion of your donation. Can I donate by check? Please click here to find the address for your local Salvation Army. Can I donate by phone? To donate by phone, please call 1-800-SAL-ARMY (1-800-725-2769). Can I support the work of The Salvation Army outside of the USA? Click here to support the work of The Salvation Army outside of the USA. How can I support Salvation Army disaster relief efforts? Click here to support current large-scale National and International disaster relief efforts or to learn more about how The Salvation Army supports disaster recovery efforts. Have an account? Sign in ❤️ Before you go Would you consider a donation? Your support will help create change and inspire hope throughout our community. Return to donate The Salvation Army Mission Statement -------------------------------------------------------------------------------- * What We Do * About Us * Ways to Give * Corporate Partnerships * Newsroom * World Service Office * Contact Us * Employment Opportunities -------------------------------------------------------------------------------- The Salvation Army USA 615 Slaters Lane, Alexandria, Virginia 22314 | 1-800-SAL-ARMY ©2021 The Salvation Army USA Privacy Policy Hey there! * Sign in * Share this page