MediaWiki:Centralnotice-template-scervantes message bubbles white

<style> /* css variables */

root {
   --wmui-base100: #fff;
   --wmui-base90: #f8f9fa;
   --wmui-base80: #eaecf0;
   --wmui-base70: #c8ccd1;
   --wmui-base50: #a2a9b1;
   --wmui-base30: #72777d;
   --wmui-base20: #54595d;
   --wmui-base10: #202122;
   --wmui-base0: #000;
   --wmui-accent: #36c;
   --wmui-accent-light: #eaf3ff;
   --wmui-accent-dark: #2a4b8d;
   --wmui-red: #d33;
   --wmui-red-light: #fee7e6;
   --wmui-red-dark: #b32424;
   --wmui-green: #00af89;
   --wmui-green-light: #d5fdf4;
   --wmui-green-dark: #14866d;
   --wmui-yellow: #fc3;
   --wmui-yellow-light: #fef6e7;
   --wmui-yellow-dark: #ac6600;
   --frb-primary: #2e5cb8;
   --frb-primary-light: #dde4f3;
   --frb-primary-dark: #2a4b8d;
   --frb-body: var(--wmui-base0);
   --frb-link: var(--wmui-accent);
   --frb-link-hover: #447ff5;
   --frb-message-background: #308557;
   --frb-message: var(--wmui-base100);
   --frb-muted: var(--wmui-base20);
   --frb-muted-hover: var(--wmui-base0);
   --frb-radio: var(--wmui-accent);
   --frb-button: var(--wmui-base90);
   --frb-button-border: var(--wmui-base50);
   --frb-button-hover: var(--wmui-accent-light);
   --frb-button-border-hover: var(--wmui-base50);
   --frb-button-focus: var(--wmui-accent-light);
   --frb-button-border-focus: var(--wmui-base50);
   --frb-button-selected: var(--wmui-accent);
   --frb-button-border-selected: var(--wmui-accent-dark);
   --frb-submit: var(--wmui-accent);
   --frb-submit-border: var(--wmui-accent);
   --frb-submit-hover: #447ff5;
   --frb-submit-border-hover: #447ff5;
   --frb-error: var(--wmui-red-dark);

}

.banner-container {

   max-width: none;

}

/* Resets */ .frb * {

   margin: 0;
   padding: 0;

}

/* Box-sizing */ .frb, .frb *, .frb *:before, .frb *:after, .frb-nag {

   -moz-box-sizing: border-box;
   -webkit-box-sizing: border-box;
   box-sizing: border-box;

}

.frb input[type="radio"], .frb input[type="text"], .frb input[type="email"] {

   appearance: none;
   -webkit-appearance: none;
   -moz-appearance: none;

}

.frb input[type="radio"]:focus, .frb input[type="text"]:focus, .frb-radio:focus + .frb-label, .frb-submit:focus, .frb-rml-email:focus, .frb-submit-rml:focus, .frb-label:focus {

   outline: 0;

}

.frb-ptf-checkbox, .frb input[type="radio"], .frb-visually-hidden {

   position: absolute;
   overflow: hidden;
   clip: rect(0 0 0 0);
   margin: -1px;
   height: 1px;
   width: 1px;
   border: 0;
   padding: 0;

}

.frb frb-amt, .frb-replaced {

   white-space: nowrap;

}

@media (prefers-reduced-motion: reduce) {

   .frb,
   .frb * {
       transition: none !important;
   }

}

/* Font sizes and line heights */ .frb-options, .frb-footer {

   font-size: 12px;

}

.frb-footer {

   line-height: 1.5;

}

.frb, .frb input, .frb-form button {

   font-size: 17px;
   line-height: 1;

}

.frb-ptf {

   font-size: 16px;

}

.frb-message, .frb-ptf, .frb-error {

   line-height: 1.3529411765; /*23px @17px*/

}

/* Styles */ /* Hide banner when Wikipedia site search is enabled */ .overlay-enabled .frb {

   display: none !important;

}

.frb-main {

   background-color: var(--wmui-base100);

}

.frb-top {

   font-family: -apple-system, 'BlinkMacSystemFont', 'Segoe UI', 'Roboto', 'Lato', 'Helvetica', 'Arial', sans-serif;

}

.frb-footer {

   display: none;
   margin: 0 14px;
   padding-top: 20px;
   padding-bottom: 20px;
   color: var(--frb-muted);

}

.frb-footer a {

   color: var(--frb-muted);
   text-decoration: underline;

}

.frb-footer a:hover {

   color: var(--frb-muted-hover);

}

.frb-separator {

   display: block;
   border: none;
   margin-top: 16px;
   height: 1px;
   background-color: var(--wmui-base80); /*same border as #page-actions*/

}

.frb-header-inside, .frb-conversation, .frb-footer, .frb-separator {

   margin-left: 16px;
   margin-right: 16px;

}

@media screen and (min-width: 720px) {

   .frb-header-inside,
   .frb-conversation,
   .frb-footer,
   .frb-separator {
       max-width: 993px;
       margin-left: 53.6px;
       margin-right: 53.6px;
   }

}

@media screen and (min-width: 1000px) {

   .frb-header-inside,
   .frb-conversation,
   .frb-footer,
   .frb-separator {
       margin-left: auto;
       margin-right: auto;
   }

}

.frb-message {

   position: relative;
   clear: both;
   margin-bottom: 12px;
   //padding: 10px 18px;
   background-color: var(--wmui-base100);
   color: var(--wmui-base0);
   border-radius: 1.5em;
   font-size: 16px;
   line-height: 1.5; /* 24px @16px */

}

.frb-message p {

   margin-bottom: 16px;
   border-radius: 1.5em;
   border: 3px solid #990000;
   padding: 16px;

}

.frb-message.frb-cta {

  padding: 16px;
  border: 3px solid #990000;

}

.frb-message.frb-message--optin {

   background-color: transparent;
   color: var(--frb-body);

}

@media all and (min-width: 720px) {

   .frb-message {
       //padding: 12px 20px;
       font-size: 17px;
       line-height: 1.5294117647; /*26px @17px*/
   }

}

.frb-message.frb-message-amount {

  padding: 10px 16px;

}

.frb-message-icon {

   vertical-align: top;

}

.frb-message-icon circle {

   fill: var(--wmui-red-dark);

}

.frb-message-icon path {

   fill: var(--wmui-base100);

}

.frb-greeting {

   display: block;
   font-size: 1.5em;
   font-weight: bold;
   text-align: center;
   padding: 0 0 2px;

} .frb-greeting b {

   display: block;
   font-size: 16px;

}

/* Typing indicator */

.frb-message--typing {

   max-width: 82px;
   padding: 6px 20px 8px;

}

.is-hidden {

   display: none;

}

@keyframes blink {

   50% {
       fill: var(--wmui-base50);
   }

} .type-indicator__circle {

   fill: var(--wmui-base70);

} .type-indicator__circle {

   animation: 1s blink infinite;

} .type-indicator__circle:nth-child(2) {

   animation-delay: 250ms;

} .type-indicator__circle:nth-child(3) {

   animation-delay: 500ms;

}

.form-monthly .no-monthly {

   opacity: 0.4 !important;

}

.form-monthly .no-monthly .frb-label {

   cursor: default;

}

/* 4px tweak to visually align buttons with chat bubbles*/ .frb-buttons-wrapper {

   display: flex;
   flex-wrap: wrap;
   padding: 18px;
   margin: 0 0 -10px -4px;
   width: calc(100% + 8px);

}

/* reduce padding for small screens */ @media (max-width: 374px) {

   .frb-buttons-wrapper {
       padding: 18px 10px;
   }

}

.frb-button {

   display: flex;
   justify-content: center;
   align-items: center;
   padding: 4px;
   flex: 1 0 0;
   cursor: pointer;

}

  1. frb-frequency-monthly:disabled + label {
   opacity: 0.4 !important;
   cursor: default;

}

.frb-amounts .frb-button {

   flex: 0 0 33.33%;
   max-width: 33.33%;

}

.frb-amounts .frb-button.frb-button--other {

   flex: 0 0 66.67%;
   max-width: 66.67%;

}

.frb-payment-options .frb-button {

   min-width: 33%;

}

/* 4 payment methods - 2+2 layout */ .frb-payment-options .frb-button:first-child:nth-last-child(4), .frb-payment-options .frb-button:first-child:nth-last-child(4) ~ .frb-button {

   min-width: 50%;

}

/* Other amount field */ .frb-other-txt, .frb-other-input {

   line-height: 1;
   text-align: left;

}

.frb-other-txt {

   font-size: 14px;
   display: block;
   text-align: center;
   margin-bottom: 2px;

}

@media all and (min-width: 375px) {

   .frb-other-txt {
       font-size: 16px;
   }

}

@media all and (min-width: 720px) {

   .frb-other-txt {
       font-size: inherit;
   }

}

.frb-other-input {

   width: 100% !important;
   border: none;
   text-align: center !important;
   font-weight: bold;
   color: var(--frb-radio);
   box-shadow: 0 2px 0 0 var(--frb-radio);
   text-align: right;
   border-radius: 0; /* Needed for iOS */

}

.frb-button--other .frb-label {

   padding: 2px 8px 4px;
   flex-direction: column;

}

.frb-radio:checked + .frb-label .frb-other-input {

   color: var(--wmui-base100);
   box-shadow: 0 2px 0 0 var(--wmui-base100);

}

.frb-label {

   display: flex;
   justify-content: center;
   align-items: center;
   width: 100%;
   height: 54px;
   color: var(--frb-link);
   background-color: var(--frb-button);
   border-radius: 10px;
   border: 1px solid var(--frb-button-border);
   text-align: center;
   cursor: pointer;
   transition: all 0.2s ease;
   font-weight: bold;
   padding: 5px 6px;
   line-height: 1;

}

/* reduce padding on credit card label for small screens */ @media (max-width: 374px) {

   .frb-pm-cc .frb-label {
       padding: 5px 3px;
   }

}

.frb-label:hover, .frb-rml-email:hover, .frb-submit-rml:hover {

   background-color: var(--frb-button-hover);

}

.frb-radio:checked + .frb-label {

   background-color: var(--frb-button-selected);
   border-color: var(--frb-button-border-selected);
   color: var(--wmui-base100);

}

.frb-radio:checked + .frb-label .frb-logo-payments--paypal path, .frb-radio:checked + .frb-label .frb-logo-payments--paypal-usd path, .frb-radio:checked + .frb-label .frb-logo-payments--amazon path, .frb-radio:checked + .frb-label .frb-logo-payments--applepay path {

   fill: var(--wmui-base100);

}

.frb-ptf-checkbox:focus + .frb-ptf-label .frb-ptf-img {

   box-shadow: inset 0 0 0 2px var(--wmui-accent);

}

.frb-radio:focus:checked + .frb-label, .frb-button--is-focused .frb-label, .frb-ptf-checkbox:focus:checked + .frb-ptf-label .frb-ptf-img {

   border-color: var(--frb-button-border-selected);
   box-shadow: inset 0 0 0 1px var(--frb-button-border-selected), inset 0 0 0 3px var(--wmui-base100);

}

.frb-submit:focus {

   box-shadow: inset 0 0 0 1px var(--frb-submit-border), inset 0 0 0 3px var(--wmui-base100);

}

.frb-ptf-checkbox:focus + .frb-ptf-label .frb-ptf-img {

   border-radius: 5px;

}

.frb-radio:focus + .frb-label, .frb-label:focus, .frb-submit-rml:focus, .frb-rml-email:focus, .frb-submit {

   border-color: var(--frb-submit-border);

}

.frb-radio:focus + .frb-label, .frb-label:focus, .frb-rml-email:focus, .frb-submit-rml:focus {

   box-shadow: inset 0 0 0 1px var(--frb-submit-border);

}

.frb-logo-payments {

   width: 100%;
   height: 100%;
   max-height: 34px;

}

.frb-logo-payments--paypal-usd {

   margin-top: 3px; /* Visual tweak */

}

.frb-logo-payments--applepay {

   margin-top: 3px; /* Visual tweak */

}

.frb-form fieldset legend {

   float: left;
   width: 100%;
   color: var(--frb-body);
   margin-bottom: -10px;
   font-weight: 600;
   background-color: transparent;

}

.frb-form fieldset {

   position: relative;
   background-color: var(--wmui-base100);
   padding: 6px 0px 6px;
   border-radius: 1.5em;
   margin-bottom: 10px;
   border: 3px solid var(--wmui-base20);

}

.frb-form fieldset.frb-haserror .error-highlight {

   color: var(--frb-error);
   font-weight: bold;

}

.frb-form fieldset legend .frb-explanation {

   font-weight: normal;

}

.frb-submit {

   height: 64px;
   display: inline-block;
   cursor: default;
   margin: 12px 0 8px;
   width: 100%;
   color: var(--frb-submit);
   background-color: var(--frb-button);
   border: 1px solid var(--frb-button-border);
   border-radius: 10px;
   font-weight: bold;
   text-transform: uppercase;
   transition: background-color 0.5s ease;
   opacity: .5;

}

.frb-submit.active {

   color: var(--wmui-base100);
   background-color: var(--frb-submit);
   border-color: var(--frb-submit-border);
   cursor: pointer;
   opacity: 1;

} .frb-submit.active:hover {

   background-color: var(--frb-submit-hover);
   border-color: var(--frb-submit-border-hover);

}

.frb-submit-amount {

   display: none;

}

.frb-submit-label-monthly {

   display: none;

}

.frb-submit-label-now {

   display: inline;

}

.form-monthly .frb-submit-label-monthly {

   display: inline;

}

.form-monthly .frb-submit-label-now {

   display: none;

}

/* Remind me later (RML) */ .frb-options {

   margin: 0 4px;
   text-align: center;
   color: var(--frb-body);
   font-weight: bold;
   text-transform: uppercase;

}

.frb-rml-link {

   display: block;
   margin: 8px auto 0 auto;
   padding: 16px;
   color: var(--frb-link);
   transition: color 0.2s ease;
   font-size: 14px;
   line-height: 1.1428571429; /*16px @14px*/
   font-weight: bold;
   text-transform: uppercase;

}

.frb-rml-link:hover {

   text-decoration: underline;

}

.frb-rml-disabled .js-rml {

   display: none;

}

.frb-rml-email, .frb-submit-rml {

   height: 54px;
   padding: 16px 18px;

}

.frb-rml-email {

   margin: 4px 0 0 0;
   width: 100%;
   color: var(--frb-body);
   background-color: var(--frb-button);
   border-radius: 10px;
   border: 1px solid var(--frb-button-border);
   box-shadow: none;
   transition: background-color 0.2s ease;
   cursor: pointer;
   font-weight: normal;

}

.frb-rml-email.frb-haserror {

   border-color: var(--frb-error);
   box-shadow: inset 0 0 0 1px var(--frb-error);

}

.frb-submit-rml {

   display: block;
   margin: 8px auto;
   min-width: 200px;
   cursor: pointer;
   color: var(--frb-link);
   background-color: var(--frb-button);
   border-radius: 10px;
   border: 1px solid var(--frb-button-border);
   transition: background-color 0.2s ease;
   cursor: pointer;

}

/* -- Credit card logos -- */

.frb-cc-logo-wrapper {

   display: none;
   margin: 0 auto;
   width: 66px;
   font-size: 0; /* Remove spacing between icons */

}

.frb-pm-cc svg {

   width: 27px;
   height: 18px;
   margin: 2px;
   display: none;

}

/* Countries with 3 card types */ .frb-cctypes-vma .frb-cc-logo-wrapper {

   width: 100%;

}

@media (min-width: 374px) {

   .frb-cctypes-vma svg  {
       width: 30%;
       max-height: 34px;
   }

}

.frb-cctypes-vmad .frb-cc-logo-wrapper, .frb-cctypes-vmaj .frb-cc-logo-wrapper, .frb-cctypes-vma .frb-cc-logo-wrapper, .frb-cctypes-vm .frb-cc-logo-wrapper {

   display: block;

}

.frb-cctypes-vmad .frb-pm-cc-label, .frb-cctypes-vmaj .frb-pm-cc-label, .frb-cctypes-vma .frb-pm-cc-label, .frb-cctypes-vm .frb-pm-cc-label {

   display: none;

}

.frb-cctypes-vmad .frb-cc-logo-visa, .frb-cctypes-vmad .frb-cc-logo-mastercard, .frb-cctypes-vmad .frb-cc-logo-amex, .frb-cctypes-vmad .frb-cc-logo-discover,

.frb-cctypes-vmaj .frb-cc-logo-visa, .frb-cctypes-vmaj .frb-cc-logo-mastercard, .frb-cctypes-vmaj .frb-cc-logo-amex, .frb-cctypes-vmaj .frb-cc-logo-jcb,

.frb-cctypes-vma .frb-cc-logo-visa, .frb-cctypes-vma .frb-cc-logo-mastercard, .frb-cctypes-vma .frb-cc-logo-amex,

.frb-cctypes-vm .frb-cc-logo-visa, .frb-cctypes-vm .frb-cc-logo-mastercard {

   display: inline-block;

}

/* -- Pay the fee -- */ .frb-ptf {

   margin: 0px 0px 0px -2px;
   padding: 10px 18px;

}

.frb-ptf-fee {

   white-space: nowrap;

}

.frb-ptf-checkbox + .frb-ptf-label .frb-ptf-img {

   display: inline-block;
   margin-bottom: -4px;
   width: 32px;
   height: 32px;
   background-image: url('https://upload.wikimedia.org/wikipedia/donate/b/b7/Frb-checkbox-ooui.png');
   background-size: 64px;
   background-repeat: no-repeat;
   background-position: 0 0;

}

.frb-ptf-checkbox:checked + .frb-ptf-label .frb-ptf-img {

   background-position: -32px 0;

}

.frb-ptf-label {

   display: flex;
   cursor: pointer;
   align-items: center;

}

.frb-ptf-cell {

   display: inline-block;

}

.frb-ptf-cell:first-child {

   padding-left: 2px;

}

body.rtl .frb-ptf-cell:first-child {

   padding-left: 8px;

}

.frb-ptf-cell:nth-child(2) {

   padding-left: 14px;

}

/* --- Header --- */

.frb-header {

   top: 0;
   z-index: 999;
   width: 100%;
   overflow: hidden;
   background-color: var(--wmui-base100);

}

/* The sticky class is added to the toolbar with JS when it reaches its scroll position */ .frb-header--sticky {

   position: fixed;
   top: 0;
   left: 0;
   border-bottom: 1px solid var(--wmui-base70);
   box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.1);

}

.frb-header-inside {

   display: flex;
   margin: 0 auto;
   padding: 0 8px; /*padding needed to make focus outlines visible at edges*/
   width: 100%;
   min-height: 42px;
   height: 1px; /*needed for FF*/

}

.frb-header-action {

   flex: 1 0 0;
   padding: 8px 10px;
   text-align: center;
   font-size: 12px;
   line-height: 1;
   font-weight: bold;
   color: var(--frb-link);
   position: relative;

} .frb-header-action:hover {

   text-decoration: underline;

}

@media all and (min-width: 375px) {

   .frb-header-action {
       font-size: 13px;
   }

}

.frb-header-action:after {

   content: ' ';
   position: absolute;
   top: 50%;
   right: -0.5px;
   transform: translateY(-50%);
   height: 22px;
   width: 1px;
   background: var(--wmui-base50);

}

body.rtl .frb-header-action:after {

   right: auto;
   left: -0.5px;

}

.frb-header-action:last-child:after {

   display: none;

}

.frb-header-action--donate {

   font-weight: bold;

}

/* --- Disable I already donated --- */ .frb.frb-iad-disabled .frb-iad {

   display: none;

}

/* Error messages */ .frb-error {

   display: none;
   margin: 8px 0;
   color: var(--frb-error);
   font-size: 15px;
   font-weight: 500;

}

/* Opt-in */ .frb-optin.frb-haserror .frb-message {

   color: var(--frb-error);

}

.frb-optin .frb-button {

   width: 50%;

}

.frb-optin-no-prompt__yes {

   display: none;

}

.frb-optin-no-prompt__no {

   display: block;

}

.frb-optin-no-prompt.is-positive .frb-optin-no-prompt__yes {

   display: block;

}

.frb-optin-no-prompt.is-positive .frb-optin-no-prompt__no {

   display: none;

}

.frb-optin-legal {

   font-size: 14px;
   line-height: 1.3;
   font-weight: normal;
   padding: 0px 16px 10px;
   color: var(--frb-muted);

} .frb-optin-legal a {

   color: var(--frb-muted);
   text-decoration: underline;

} .frb-optin-legal a:hover {

   color: var(--frb-muted-hover);
   text-decoration: underline;

}

.frb-cta {

   margin-top: 8px;
   background-color: #f9dde9;
   color: #000;

}

/* UPSELL */

.frb-upsell, .frb-monthly-diff-amt .frb-amt-monthly, .frb-upsell-ty {

   width: calc(100% + 8px) !important;
   transition: background-color 0.5s ease;
   padding: 10px 4px;
   text-align: center;

}

.frb-upsell { padding-top: 40px; }

.frb-monthly-diff-amt .frb-amt-monthly {

   display: block;
   padding: 0 4px 10px 4px;

}

.frb-upsell-cta, .frb-upsell-ty {

   font-size: 17px;
   line-height: 1.3;
   font-weight: bold;
   text-align: center;

}

.frb-upsell-color, .frb-monthly-diff-amt .frb-amt-monthly label {

   display: block;
   font-size: 15px;
   line-height: 1.3;
   font-weight: normal;
   padding: 0 5%;
   margin: .5em 0;

}

.frb .frb-monthly-diff-amt-link {

   display: block;
   font-size: 15px;
   line-height: 1.3;
   color: var(--frb-link);
   margin: 8px auto;
   padding: 12px;
   text-align: center;
   cursor: pointer;
   font-weight: bold;

} .frb .frb-monthly-diff-amt-link:hover {

   text-decoration: underline;

}

.frb-back-step, .frb-back {

   display: none;
   position: absolute;
   margin-top: 10px;
   cursor: pointer;

}

.frb-monthly-diff-amt { display: none; }

  1. frb-amt-monthly-other-input {
   position: relative;
   width: 30%;
   height: 54px;
   padding: 16px 18px;
   text-align: center;
   font-size: 18px;
   color: var(--frb-body);
   background-color: var(--frb-button);
   border-radius: 10px;
   border: 1px solid var(--frb-button-border);
   box-shadow: none;
   transition: background-color 0.2s ease;
   cursor: pointer;
   font-weight: normal;

}

  1. frb-amt-monthly-other-input:hover {
   background-color: var(--frb-button-hover);

}

/* Overlay */ .frb-mask {

   display: none;
   position: absolute;
   z-index: 1000;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background-color: var(--wmui-base0);
   opacity: 0.8;
   touch-action: none;

}

.frb-step-upsell {

   position: fixed;
   z-index: 1001;
   top: 0;
   left: 0;
   right: 0;
   width: 90%;
   max-width: 800px;
   margin: 5% auto;
   padding: 5%;
   color: var(--frb-body);
   background: var(--wmui-base100);

}

.frb-monthly-buttons .frb-submit {

   padding: 10px 15px;
   height: auto;
   min-height: 64px;

}

/*

   Modal
  • /

.modal {

   display: none;
   position: fixed;
   z-index: 9999;
   background: rgba(255,255,255,0.95);
   min-width: 100vw;
   min-height: 100vh;
   top: 0;
   left: 0;
   overflow: hidden;

} .modal-container {

   width: 100%;
   max-width: 90%;
   margin: 0 auto;
   padding: 60px 30px 20px;
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%,-50%);
   box-shadow: 0 0 10px rgba(0,0,0,0.15);
   background: #fff;
   box-sizing: border-box;
   color: #000;

} .modal-close-x {

   border: none;
   background: none;
   margin: 0;
   padding: 0;
   cursor: pointer;
   position: absolute;
   top: 24px;
   left: 24px;
   width: 22px;
   height: 18px;
   opacity: 0.5;

}

.modal-title-icon {

   display: inline-block;
   vertical-align: middle;
   position: relative;
   left: -10px;
   top: -10px;

} .modal-title-text {

   font-size: 17px;
   margin: 0;
   color: #262626;
   font-weight: bold;
   display: inline-block;

} .modal-text {

   font-family: Arial;
   line-height: 1.44;
   font-size: 15px;
   max-width: 100%;
   margin: 16px auto 0;

} .frb-modal-buttons {

   display: block;
   justify-content: center;
   margin: 16px auto 0;

} .modal-close-button {

   margin: 0 0 10px;
   display: block;
   border-radius: 2px;
   border: solid 1px #a2a9b1;
   background-color: #f8f9fa;
   width: 100%;
   height: 45px;
   font-family: Arial;
   font-size: 13px;
   font-weight: bold;
   color: #007de2;
   cursor: pointer;

} .modal-close-button:hover{

   background-color: #eaf3ff;

}

/* screen reader visibility class */ .sr-only {

   border: 0 !important;
   clip: rect(1px, 1px, 1px, 1px) !important;
   -webkit-clip-path: inset(50%) !important;
   clip-path: inset(50%) !important;
   height: 1px !important;
   margin: -1px !important;
   overflow: hidden !important;
   padding: 0 !important;
   position: absolute !important;
   width: 1px !important;
   white-space: nowrap !important;

}

.frb-step-2 .frb-message {

   padding: 0 18px;

}

</style>

<script> var frb = frb || {};

frb.HIDE_DURATION_SKIP = 3600; // 1 hour frb.HIDE_DURATION_RML = 604800; // 1 week

frb.show = function() {

   $('.banner-container').insertBefore('#content');
   $('.frb').css('display', 'block');
   $('.frb').addClass('frb-country-' + mw.centralNotice.data.country);

};

frb.toggleMonthly = function( monthly ) {

   if ( monthly.type === 'checkbox' ) {
       monthly = monthly.checked;
   }
   if ( monthly ) {
       $('#frb-frequency-monthly').prop('checked', true);
       $('#frb-monthly-checkbox').prop('checked', true);
       $('.no-monthly input').attr('disabled', true);
       $('#frb-form').addClass('form-monthly');
       if ( $('.form-monthly .no-monthly input[type=radio]').is(':checked') ) {
           $('.form-monthly .no-monthly input[type=radio]').removeAttr('checked');
           frb.setMethod({});
       }
   } else {
       $('#frb-frequency-onetime').prop('checked', true);
       $('#frb-monthly-checkbox').prop('checked', false);
       $('.no-monthly input').attr('disabled', false);
       $('#frb-form').removeClass('form-monthly');
   }

};

/* jshint maxerr: 600 */ frb.amounts = frb.amounts || {};

// Hard minimum amounts that can be given // From https://github.com/wikimedia/wikimedia-fundraising-SmashPig/blob/master/PaymentData/ReferenceData/CurrencyRates.php // Updated 2023-12-12 frb.amounts.minimums = { 'USD' : 1, 'CAD' : 1.36, 'AUD' : 1.52, 'NZD' : 1.63, 'GBP' : 0.80, 'EUR' : 0.93, 'DKK' : 6.91, 'HUF' : 355, 'ILS' : 3.71, 'INR' : 10, // T309818 'JPY' : 146, 'MYR' : 4.68, 'NOK' : 11, 'PLN' : 4.02, 'CZK' : 23, 'RON' : 4.61, 'SEK' : 10, 'UAH' : 37, 'ZAR' : 19, // Latin America 'BRL' : 4.95, 'ARS' : 366, 'CLP' : 880, 'COP' : 3970, 'MXN' : 17, 'PEN' : 3.74, 'UYU' : 39, 'CHF' : 0.88 };

frb.amounts.options7 = { // Big English 'USD' : [2.75, 10, 15, 25, 50, 75, 100], 'CAD' : [2.75, 10, 15, 25, 50, 75, 100], 'AUD' : [2.75, 10, 15, 25, 50, 75, 100], 'NZD' : [2.75, 10, 15, 25, 50, 75, 100], 'GBP' : [2.75, 10, 15, 25, 50, 75, 100], 'EUR' : [2.75, 10, 15, 25, 50, 75, 100], // Others 'DKK' : [20, 75, 100, 200, 300, 500, 700], 'HUF' : [500, 1000, 2000, 4000, 5000, 7000, 10000], 'ILS' : [10, 35, 50, 100, 200, 300, 400], 'INR' : [25, 300, 500, 1000, 1500, 3000, 5000], 'JPY' : [300, 1000, 1500, 2000, 3000, 5000, 10000], 'MYR' : [10, 30, 50, 100, 200, 300, 500], 'NOK' : [30, 100, 150, 200, 500, 750, 1000], 'PLN' : [10, 20, 50, 100, 200, 300, 500], 'CZK' : [50, 100, 250, 500, 1000, 1500, 2500], 'RON' : [10, 50, 75, 100, 200, 300, 500], 'SEK' : [30, 100, 150, 200, 500, 750, 1000], 'UAH' : [50, 75, 150, 300, 500, 750, 1000], 'ZAR' : [30, 50, 100, 200, 300, 500, 1000], // Latin America 'BRL' : [10, 20, 30, 50, 100, 200, 300], 'ARS' : [200, 250, 500, 750, 1000, 1500, 2000], 'CLP' : [2000, 3000, 5000, 10000, 20000, 30000, 50000], 'COP' : [10000, 15000, 25000, 50000, 100000, 150000, 200000], 'MXN' : [40, 70, 150, 250, 500, 700, 1000], 'PEN' : [10, 15, 25, 50, 100, 150, 200], 'UYU' : [100, 200, 300, 500, 1000, 1500, 2000], 'CHF' : [3, 5, 10, 25, 50, 100, 200] };

// 5 amount options. Since 2020 6C, no longer used frb.amounts.options5 = { // Big English 'USD' : [2.75, 15, 20, 50, 100], 'CAD' : [2.75, 15, 20, 50, 100], 'AUD' : [2.75, 15, 20, 50, 100], 'NZD' : [2.75, 15, 20, 50, 100], 'GBP' : [2, 10, 20, 50, 100], 'EUR' : [2, 10, 20, 50, 100], // Others 'DKK' : [20, 100, 200, 500, 1000], 'HUF' : [500, 2500, 4000, 7000, 10000], 'ILS' : [10, 50, 200, 600, 1000], 'INR' : [150, 500, 1000, 3000, 5000], 'JPY' : [300, 1500, 2000, 5000, 10000], 'MYR' : [10, 50, 100, 300, 500], 'NOK' : [20, 100, 200, 500, 1000], 'PLN' : [10, 50, 100, 300, 500], 'RON' : [10, 50, 100, 200, 1000], 'SEK' : [30, 100, 200, 500, 1000], 'UAH' : [50, 150, 300, 750, 1000], 'ZAR' : [30, 100, 200, 500, 1000], // Latin America 'BRL' : [10, 30, 50, 100, 250], 'ARS' : [60, 200, 400, 1000, 2000], 'CLP' : [1500, 5000, 10000, 25000, 50000], 'COP' : [7000, 20000, 50000, 150000, 200000], 'MXN' : [35, 100, 200, 750, 1000], 'PEN' : [10, 50, 150, 300, 700], 'UYU' : [70, 200, 400, 1500, 2000], 'CHF' : [3, 10, 25, 50, 100] };

// "Average" donation frb.amounts.averages = { 'USD' : 13, 'CAD' : 12, 'AUD' : 11, 'NZD' : 12, 'GBP' : 6, 'EUR' : 8, // Others 'DKK' : 60, 'HUF' : 2500, 'ILS' : 50, 'INR' : 229, 'JPY' : 800, 'MYR' : 30, 'NOK' : 75, 'PLN' : 50, 'CZK' : 150, 'RON' : 50, 'SEK' : 85, 'UAH' : 150, 'ZAR' : 65, // Latin America 'BRL' : 25, 'ARS' : 780, 'CLP' : 10200, 'COP' : 35000, 'MXN' : 140, 'PEN' : 30, 'UYU' : 525, 'CHF' : 25 };

// 'If everyone gave X'. Mostly the same as first asks option. frb.amounts.ifEveryone = { // Big English 'USD' : 2.75, 'CAD' : 2.75, 'AUD' : 2.75, 'NZD' : 2.75, 'GBP' : 2.75, 'EUR' : 2.75, // Others 'DKK' : 20, 'HUF' : 500, 'ILS' : 10, 'INR' : 25, 'JPY' : 300, 'MYR' : 10, 'NOK' : 30, 'PLN' : 10, 'CZK' : 50, 'RON' : 10, 'SEK' : 30, 'UAH' : 50, 'ZAR' : 30, // Latin America 'BRL' : 10, 'ARS' : 175, 'CLP' : 1500, 'COP' : 7000, 'MXN' : 40, 'PEN' : 10, 'UYU' : 100, 'CHF' : 5 };

// Minimum fee/PTF amounts. Default is 0.35. // Updated 2018-07-05 based on Ppena's feedback // Updated 2019-05-21 to approx 0.35 USD equivalent frb.amounts.feeMinimums = { 'DKK' : 2, 'HUF' : 100, 'ILS' : 1.2, 'INR' : 4, 'JPY' : 35, 'MYR' : 1, 'NOK' : 3, 'PLN' : 1.35, 'CZK' : 7.5, 'RON' : 1.5, 'SEK' : 3, 'UAH' : 10, 'ZAR' : 5, // Latin America // Updated 2024-08-22 to approx 0.35 USD equivalent 'BRL' : 1.75, 'ARS' : 300, 'CLP' : 300, 'COP' : 1400, 'MXN' : 6, 'PEN' : 1.2, 'UYU' : 14 };

// If one-time amount <= left amount, suggest right amount for monthly // If changing these, please update spreadsheet // https://docs.google.com/spreadsheets/d/1z36zi8EegPLAvR5FYAgwz8ywKZ50QNB82SpwpTdk-xQ/edit#gid=1258723967 frb.amounts.monthlySuggest = { 'USD' : [ // also EUR, GBP, CAD, AUD, NZD [ 2.74, 0 ], [ 9, 1.75 ], [ 12, 2 ], [ 15, 2.5 ], [ 18, 3 ], [ 21, 3.5 ], [ 24, 4 ], [ 27, 4.5 ], [ 30, 5 ], [ 33, 5.5 ], [ 36, 6 ], [ 39, 6.5 ], [ 42, 7 ], [ 45, 7.5 ], [ 48, 8 ], [ 51, 8.5 ], [ 54, 9 ], [ 57, 9.5 ], [ 60, 10 ], [ 63, 10.5 ], [ 66, 11 ], [ 69, 11.5 ], [ 72, 12 ], [ 75, 12.5 ], [ 102, 17 ], [ 250, 25 ], [ 499, 50 ], [ Infinity, 0 ] ], 'JPY' : [ [ 299, 0 ], [ 900, 150 ], [ 1200, 200 ], [ 1500, 250 ], [ 1800, 300 ], [ 2100, 350 ], [ 2400, 400 ], [ 2700, 450 ], [ 3000, 500 ], [ 3300, 550 ], [ 3600, 600 ], [ 3900, 650 ], [ 4200, 700 ], [ 4500, 750 ], [ 4800, 800 ], [ 5100, 850 ], [ 5400, 900 ], [ 5700, 950 ], [ 6000, 1000 ], [ 6300, 1050 ], [ 6600, 1100 ], [ 6900, 1150 ], [ 7200, 1200 ], [ 7500, 1250 ], [ 10800, 1800 ], [ 18000, 3000 ], [ 50000, 6000 ], [ Infinity, 0 ] ], 'SEK' : [ // Also NOK [ 29, 0 ], [ 35, 20 ], [ 55, 25 ], [ 105, 30 ], [ 160, 40 ], [ 210, 50 ], [ 360, 60 ], [ 450, 75 ], [ 600, 100 ], [ 800, 125 ], [ 900, 150 ], [ 1200, 200 ], [ 1500, 250 ], [ 1800, 300 ], [ 2100, 350 ], [ Infinity, 0 ] ], 'HUF' : [ [ 499, 0 ], [ 3000, 500 ], [ 6000, 1000 ], [ 9000, 1500 ], [ 12000, 2000 ], [ 18000, 3000 ], [ 24000, 4000 ], [ 30000, 5000 ], [ 36000, 6000 ], [ 42000, 7000 ], [ 48000, 8000 ], [ 54000, 9000 ], [ 60000, 10000 ], [ Infinity, 0 ] ], 'ILS' : [ [ 9, 0 ], [ 10, 5 ], [ 60, 10 ], [ 90, 15 ], [ 120, 20 ], [ 180, 30 ], [ 240, 40 ], [ 300, 50 ], [ 360, 60 ], [ 420, 70 ], [ 480, 80 ], [ 540, 90 ], [ 600, 100 ], [ Infinity, 0 ] ], 'ZAR' : [ [ 29, 0 ], [ 30, 20 ], [ 50, 30 ], [ 100, 40 ], [ 300, 50 ], [ 450, 75 ], [ 600, 100 ], [ 900, 150 ], [ 1200, 200 ], [ 1500, 250 ], [ 1800, 300 ], [ 2400, 400 ], [ 3000, 500 ], [ 3600, 600 ], [ Infinity, 0 ] ], 'MYR' : [ // Also RON, PLN [ 9, 0 ], [ 30, 5 ], [ 50, 10 ], [ 120, 20 ], [ 180, 30 ], [ 240, 40 ], [ 300, 50 ], [ 360, 60 ], [ 420, 70 ], [ 480, 80 ], [ 540, 90 ], [ 600, 100 ], [ 900, 150 ], [ Infinity, 0 ] ], 'DKK' : [ [ 19, 0 ], [ 25, 10 ], [ 120, 20 ], [ 250, 40 ], [ 350, 50 ], [ 450, 75 ], [ 600, 100 ], [ 750, 125 ], [ 900, 150 ], [ 1200, 200 ], [ 1500, 250 ], [ 1800, 300 ], [ 2100, 350 ], [ Infinity, 0 ] ], 'CZK' : [ [ 49, 0 ], [ 180, 30 ], [ 300, 50 ], [ 600, 100 ], [ 900, 150 ], [ 1200, 200 ], [ 1500, 250 ], [ 1800, 300 ], [ 2100, 350 ], [ 2400, 400 ], [ 3000, 500 ], [ 3600, 600 ], [ 4200, 700 ], [ 4800, 800 ], [ Infinity, 0 ] ], 'CLP' : [ [ 1999, 0 ], [ 2300, 1000 ], [ 2700, 1100 ], [ 3300, 1200 ], [ 4200, 1300 ], [ 5500, 1400 ], [ 9000, 1500 ], [ 10500, 1700 ], [ 16000, 2600 ], [ 20800, 3400 ], [ 26000, 4200 ], [ 31200, 5000 ], [ 38400, 6400 ], [ 55000, 8500 ], [ Infinity, 0 ] ], 'UYU' : [ [ 99, 0 ], [ 120, 50 ], [ 170, 65 ], [ 220, 70 ], [ 320, 75 ], [ 480, 85 ], [ 520, 90 ], [ 750, 125 ], [ 1050, 170 ], [ 1350, 225 ], [ 1600, 250 ], [ 1800, 300 ], [ 2100, 320 ], [ Infinity, 0 ] ], 'PEN' : [ [ 9, 0 ], [ 12, 5 ], [ 17, 6 ], [ 26, 7 ], [ 48, 8 ], [ 55, 9 ], [ 78, 13 ], [ 105, 17 ], [ 130, 21 ], [ 160, 26 ], [ 180, 30 ], [ 210, 32 ], [ Infinity, 0 ] ], 'COP' : [ [ 9999, 0 ], [ 11300, 5000 ], [ 17000, 5200 ], [ 22000, 5500 ], [ 27000, 5800 ], [ 45000, 7500 ], [ 55000, 9000 ], [ 75000, 12500 ], [ 105000, 17000 ], [ 120000, 20000 ], [ 160000, 25000 ], [ 180000, 30000 ], [ 250000, 34000 ], [ Infinity, 0 ] ], 'BRL' : [ [ 9, 0 ], [ 12, 6 ], [ 22, 7 ], [ 35, 8 ], [ 45, 9 ], [ 55, 10 ], [ 80, 12 ], [ 105, 16 ], [ 160, 25 ], [ 210, 35 ], [ 270, 45 ], [ 320, 50 ], [ Infinity, 0 ] ], 'MXN' : [ [ 39, 0 ], [ 48, 25 ], [ 60, 28 ], [ 110, 30 ], [ 160, 35 ], [ 260, 45 ], [ 270, 50 ], [ 350, 60 ], [ 550, 85 ], [ 650, 90 ], [ 750, 120 ], [ 1500, 160 ], [ Infinity, 0 ] ], 'INR' : [ [ 29, 0 ], [ 75, 25 ], [ 79, 29 ], [ 104, 30 ], [ 208, 35 ], [ 312, 55 ], [ 416, 70 ], [ 520, 90 ], [ 624, 110 ], [ 728, 130 ], [ 832, 140 ], [ 936, 160 ], [ 1040, 175 ], [ 1144, 190 ], [ 1248, 210 ], [ 1352, 235 ], [ 1456, 245 ], [ 1560, 265 ], [ 2080, 350 ], [ 3120, 530 ], [ 4160, 700 ], [ 5200, 880 ], [ 7800, 1320 ], [ 10400, 1760 ], [ 15600, 2650 ], [ 20800, 3530 ], [ 26000, 4420 ], [ Infinity, 0 ] ] }; frb.amounts.monthlySuggest.EUR = frb.amounts.monthlySuggest.USD; frb.amounts.monthlySuggest.GBP = frb.amounts.monthlySuggest.USD; frb.amounts.monthlySuggest.CAD = frb.amounts.monthlySuggest.USD; frb.amounts.monthlySuggest.AUD = frb.amounts.monthlySuggest.USD; frb.amounts.monthlySuggest.NZD = frb.amounts.monthlySuggest.USD;

frb.amounts.monthlySuggest.RON = frb.amounts.monthlySuggest.MYR; frb.amounts.monthlySuggest.PLN = frb.amounts.monthlySuggest.MYR; frb.amounts.monthlySuggest.NOK = frb.amounts.monthlySuggest.SEK;

frb.amounts.test = function() {

/** * Check if amounts are less than minimum acceptable * * @param {string} desc - description for error message e.g. 'amount option' * @param {Object} dataObject - data to check e.g. frb.amounts.options7 * @param {Function} extractFunction - function to get test value e.g. d => d[0] for 1st amount */ var testMinimums = function( desc, dataObject, extractFunction = d => d ) { const errorMessage = 'Error %s %s %s is less than minimum %s'; for ( const currency in dataObject ) { let data = dataObject[currency].default || dataObject[currency], // need default for some EUR value = extractFunction(data), minimum = frb.amounts.minimums[currency]; console.assert( value >= minimum, errorMessage, currency, desc, value, minimum ); } };

testMinimums( 'if everyone', frb.amounts.ifEveryone, d => d ); testMinimums( 'average', frb.amounts.averages, d => d ); testMinimums( 'amount option', frb.amounts.options7, d => d[0] ); testMinimums( 'monthly suggestion', frb.amounts.monthlySuggest, d => d[1][1] );

};

frb.currencyFormats = { 'USD' : '$\t', 'CAD' : { 'fr' : '\t $', 'default' : '$\t' }, 'AUD' : '$\t', 'NZD' : '$\t', 'GBP' : '£\t', 'EUR' : { 'en' : '€\t', 'cy' : '€\t', 'ga' : '€\t', 'mt' : '€\t', 'nl' : '€ \t', 'lv' : '€ \t', 'tr' : '€ \t', 'default' : '\t €' }, // Others 'CZK' : '\t Kč', 'DKK' : '\t kr.', 'HUF' : '\t Ft', 'ILS' : { 'he' : '\t ₪', 'yi' : '\t ₪', 'ar' : '\t ₪', 'default' : '₪ \t' }, 'INR' : '₹ \t', 'JPY' : '¥\t', 'MYR' : 'RM\t', 'NOK' : '\t kr', 'PLN' : '\t zł', 'RON' : '\t lei', 'SEK' : '\t kr', 'UAH' : '₴\t', 'ZAR' : 'R \t', // Latin America 'BRL' : { 'en' : 'R$\t', 'default' : 'R$ \t' }, 'ARS' : '$\t', 'CLP' : '$\t', 'COP' : '$\t', 'MXN' : '$\t', 'PEN' : 'S/. \t', 'UYU' : '$U \t', 'CHF' : '\t CHF' };

// Check in user language first, then fall back to English frb.countryNames = { 'af' : { 'ZA' : 'Suid-Afrika' }, 'en' : { 'US' : 'the United States', 'CA' : 'Canada', 'GB' : 'the UK', 'IE' : 'Ireland', 'AU' : 'Australia', 'NZ' : 'New Zealand', 'AR' : 'Argentina', 'AT' : 'Austria', 'BE' : 'Belgium', 'BR' : 'Brazil', 'CH' : 'Switzerland', 'CL' : 'Chile', 'CO' : 'Colombia', 'CZ' : 'the Czech Republic', 'DK' : 'Denmark', 'ES' : 'Spain', 'FR' : 'France', 'GR' : 'Greece', 'HK' : 'Hong Kong', 'HU' : 'Hungary', 'IL' : 'Israel', 'IN' : 'India', 'IT' : 'Italy', 'JP' : 'Japan', 'LU' : 'Luxembourg', 'LV' : 'Latvia', 'MX' : 'Mexico', 'MY' : 'Malaysia', 'NL' : 'the Netherlands', 'NO' : 'Norway', 'PE' : 'Peru', 'PL' : 'Poland', 'PT' : 'Portugal', 'RO' : 'Romania', 'SE' : 'Sweden', 'SK' : 'Slovakia', 'UA' : 'Ukraine', 'UY' : 'Uruguay', 'ZA' : 'South Africa' }, 'ca' : { 'AT' : 'd’Àustria', 'BE' : 'de Bèlgica', 'DK' : 'de Dinamarca', 'ES' : 'a Espanya', 'HU' : 'd’Hongria', 'IL' : 'd’Israel', 'LV' : 'de Letònia', 'LU' : 'de Luxemburg', 'MY' : 'de Malàisia', 'NO' : 'de Noruega', 'PL' : 'de Polònia', 'PT' : 'de Portugal', 'RO' : 'de Romania', 'SK' : 'd’Eslovàquia', 'ZA' : 'de Sud-àfrica', 'UA' : 'd’Ucraïna' }, 'cs' : { 'CZ' : 'v České republice', 'AT' : 'v Rakousku', 'BE' : 'v Belgii', 'DK' : 'v Dánsku', 'GR' : 'v Řecku', 'IL' : 'v Izraeli', 'LU' : 'v Lucembursku', 'MY' : 'v Malajsii', 'NO' : 'v Norsku', 'PT' : 'v Portugalsku', 'SE' : 've Švédsku', 'ZA' : 'v Jihoafrické republice' }, 'es' : { 'AR' : 'en Argentina', 'AT' : 'en Austria', 'BE' : 'en Bélgica', 'BR' : 'en Brasil', 'CL' : 'en Chile', 'CO' : 'en Colombia', 'DK' : 'en Dinamarca', 'ES' : 'en España', 'HU' : 'en Hungría', 'IL' : 'en Israel', 'LU' : 'en Luxemburgo', 'LV' : 'en Letonia', 'MX' : 'en México', 'MY' : 'en Malasia ', 'NO' : 'en Noruega', 'PE' : 'en Perú', 'PL' : 'en Polonia', 'PT' : 'en Portugal', 'RO' : 'en Rumania', 'SK' : 'en Eslovaquia', 'UA' : 'en Ucrania', 'US' : 'en los Estados Unidos', 'UY' : 'en Uruguay', 'ZA' : 'en Sudafrica' }, 'da' : { 'AT' : 'i Østrig', 'BE' : 'i Belgien', 'CZ' : 'i Tjekkiet', 'DK' : 'i Danmark', 'ES' : 'i Spanien', 'GR' : 'i Grækenland', 'HU' : 'i Ungarn', 'IL' : 'i Israel', 'LV' : 'i Letland', 'LU' : 'i Luxembourg', 'MY' : 'i Malaysia', 'NO' : 'i Norge', 'PL' : 'i Polen', 'PT' : 'i Portugal', 'RO' : 'i Rumænien', 'SE' : 'i Sverige', 'SK' : 'i Slovakiet', 'ZA' : 'i Sydafrika', 'UA' : 'i Ukraine' }, 'nl' : { 'NL' : 'in Nederland', 'AT' : 'in Oostenrijk', 'BE' : 'in België', 'DK' : 'in Denemarken', 'CZ' : 'in Tsjechië', 'ES' : 'in Spanje', 'GR' : 'in Griekenland', 'HU' : 'in Hongarije', 'IL' : 'in Israël', 'LV' : 'in Letland', 'LU' : 'in Luxemburg', 'MY' : 'in Maleisië', 'NO' : 'in Noorwegen', 'PL' : 'in Polen', 'PT' : 'in Portugal', 'RO' : 'in Roemenië', 'SE' : 'in Zweden', 'SK' : 'in Slowakije', 'ZA' : 'in Zuid-Afrika', 'UA' : 'in Oekraïne' }, 'fr' : { 'AT' : 'en Autriche', 'BE' : 'en Belgique', 'CH' : 'en Suisse', 'CA' : 'au Canada', 'CZ' : 'en République tchèque', 'DK' : 'au Danemark', 'ES' : 'en Espagne', 'FR' : 'en France', 'GR' : 'en Grèce', 'HU' : 'en Hongrie', 'IL' : 'en Israël', 'LV' : 'en Lettonie', 'LU' : 'au Luxembourg', 'MY' : 'en Malaisie', 'NO' : 'en Norvège', 'PL' : 'en Pologne', 'PT' : 'au Portugal', 'RO' : 'en Roumanie', 'SE' : 'en Suède', 'SK' : 'en Slovaquie', 'ZA' : 'en Afrique du Sud', 'UA' : 'en Ukraine' }, 'de' : { 'AT' : 'in Österreich', 'BE' : 'in Belgien', 'CH' : 'in der Schweiz', 'CZ' : 'in Tschechien', 'DK' : 'in Dänemark', 'ES' : 'in Spanien', 'GR' : 'in Griechenland', 'HU' : 'in Ungarn', 'IL' : 'in Israel', 'LV' : 'in Lettland', 'LU' : 'in Luxemburg', 'MY' : 'in Malaysia', 'NO' : 'in Norwegen', 'PL' : 'in Polen', 'PT' : 'in Portugal', 'RO' : 'in Rumänien', 'SE' : 'in Schweden', 'SK' : 'in der Slowakei', 'ZA' : 'in Südafrika', 'UA' : 'in der Ukraine' }, 'el' : { 'AT' : 'στην Αυστρία', 'BE' : 'στο Βέλγιο', 'CZ' : 'στην Τσεχία', 'DK' : 'στη Δανία', 'ES' : 'στην Ισπανία', 'GR' : 'στην Ελλάδα', 'HU' : 'στην Ουγγαρία', 'IL' : 'στο Ισραήλ', 'LV' : 'στη Λετονία', 'LU' : 'στο Λουξεμβούργο', 'MY' : 'στη Μαλαισία', 'NO' : 'στη Νορβηγία', 'PL' : 'στην Πολωνία', 'PT' : 'στην Πορτογαλία', 'RO' : 'στη Ρουμανία', 'SE' : 'στη Σουηδία', 'SK' : 'στη Σλοβακία', 'ZA' : 'στη Νότια Αφρική', 'UA' : 'στην Ουκρανία' }, 'he' : { 'AT' : 'אוסטרליה', 'BE' : 'בלגיה', 'CZ' : "בצ'כיה", 'DK' : 'דנמרק', 'ES' : 'ספרד', 'GR' : 'ביוון', 'HU' : 'הונגריה', 'IL' : 'ישראל', 'LV' : 'לטביה', 'LU' : 'לוקסמבורג', 'MY' : 'מלזיה', 'NO' : 'נורווגיה', 'PL' : 'פולין', 'PT' : 'פורטוגל', 'RO' : 'רומניה', 'SE' : 'בשוודיה', 'SK' : 'סלובקיה', 'ZA' : 'דרום אפריקה', 'UA' : 'אוקראינה' }, 'hu' : { 'AT' : 'ausztriai', 'BE' : 'belgiumi', 'DK' : 'dániai', 'ES' : 'spanyolországi', 'HU' : 'magyarországi', 'IL' : 'izraeli', 'LV' : 'lettországi', 'LU' : 'luxemburgi', 'MY' : 'malajziai', 'NO' : 'norvégiai', 'PL' : 'lengyelországi', 'PT' : 'portugáliai', 'RO' : 'romániai', 'SK' : 'szlovákiai', 'ZA' : 'dél-afrikai', 'UA' : 'ukrajnai' }, 'it' : { 'IT' : 'Italia', 'CH' : 'Svizzera' }, 'lv' : { 'AT' : 'valstī Austrijā', 'BE' : 'valstī Beļģijā', 'DK' : 'valstī Dānijā', 'ES' : 'valstī Spānijā', 'HU' : 'valstī Ungārijā', 'IL' : 'Izraēlas valstī', 'LV' : 'valstī Latvijā', 'LU' : 'valstī Luksemburgā', 'MY' : 'valstī Malaizijā', 'NO' : 'valstī Norvēģijā', 'PL' : 'valstī Polijā', 'PT' : 'valstī Portugālē', 'RO' : 'valstī Rumānijā', 'SK' : 'valstī Slovākijā', 'ZA' : 'Dienvidāfrikas valstī', 'UA' : 'valstī Ukrainā' }, 'nb' : { 'AT' : 'i Østerrike', 'BE' : 'i Belgia', 'CZ' : 'i Tsjekkia', 'DK' : 'i Danmark', 'ES' : 'i Spania', 'GR' : 'i Hellas', 'HU' : 'i Ungarn', 'IL' : 'i Israel', 'LV' : 'i Latvia', 'LU' : 'i Luxembourg', 'MY' : 'i Malaysia', 'NO' : 'i Norge', 'PL' : 'i Polen', 'PT' : 'i Portugal', 'RO' : 'i Romania', 'SE' : 'i Sverige', 'SK' : 'i Slovakia', 'ZA' : 'i Sør-Afrika', 'UA' : 'i Ukraina' }, 'pl' : { 'AT' : 'w Austrii', 'BE' : 'w Belgii', 'DK' : 'w Danii', 'ES' : 'w Hiszpanii', 'HU' : 'na Węgrzech', 'IL' : 'w Izraelu', 'LV' : 'na Łotwie', 'LU' : 'w Luksemburgu', 'MY' : 'w Malezji', 'NO' : 'w Norwegii', 'PL' : 'w Polsce', 'PT' : 'w Portugalii', 'RO' : 'w Rumunii', 'SK' : 'na Słowacji', 'ZA' : 'w Republice Południowej Afryki', 'UA' : 'na Ukrainie' }, 'pt' : { 'AT' : 'na Áustria', 'BE' : 'na Bélgica', 'BR' : 'no Brasil', 'CZ' : 'na República Checa', 'DK' : 'na Dinamarca', 'ES' : 'na Espanha', 'GR' : 'na Grécia', 'HU' : 'na Hungria', 'IL' : 'em Israel', 'LV' : 'na Letónia', 'LU' : 'no Luxemburgo', 'MY' : 'na Malásia', 'NO' : 'na Noruega', 'PL' : 'na Polónia', 'PT' : 'em Portugal', 'RO' : 'na Roménia', 'SE' : 'na Suécia', 'SK' : 'na Eslováquia', 'ZA' : 'na África do Sul', 'UA' : 'na Ucrânia' }, 'ro' : { 'AT' : 'din Austria', 'BE' : 'din Belgia', 'DK' : 'din Danemarca', 'ES' : 'în Spania', 'HU' : 'din Ungaria', 'IL' : 'din Israel', 'LV' : 'din Latvia', 'LU' : 'din Luxemburg', 'MY' : 'din Malaezia', 'NO' : 'din Norvegia', 'PL' : 'din Polonia', 'PT' : 'din Portugalia', 'RO' : 'din România', 'SK' : 'din Slovacia', 'ZA' : 'din Africa de Sud', 'UA' : 'din Ucraina' }, 'ru' : { 'AT' : 'в Австрии', 'BE' : 'в Бельгии', 'DK' : 'в Дании', 'ES' : 'в Испании', 'HU' : 'в Венгрии', 'IL' : 'в Израиле', 'LV' : 'в Латвии', 'LU' : 'в Люксембурге', 'MY' : 'в Малайзии', 'NO' : 'в Норвегии', 'PL' : 'в Польше', 'PT' : 'в Португалии', 'RO' : 'в Румынии', 'SK' : 'в Словакии', 'ZA' : 'в Южной Африке', 'UA' : 'в Украине' }, 'sk' : { 'AT' : 'v Rakúsku', 'BE' : 'v Belgicku', 'DK' : 'v Dánsku', 'ES' : 'v Španielsku', 'HU' : 'v Maďarsku', 'IL' : 'v Izraeli', 'LV' : 'v Lotyšsku', 'LU' : 'v Luxembursku', 'MY' : 'v Malajzii', 'NO' : 'v Nórsku', 'PL' : 'v Poľsku', 'PT' : 'v Portugalsku', 'RO' : 'v Rumunsku', 'SK' : 'na Slovensku', 'ZA' : 'v Juhoafrickej republike', 'UA' : 'na Ukrajine' }, 'sv' : { 'SE' : 'i Sverige', 'AT' : 'i Österrike', 'BE' : 'i Belgien', 'CZ' : 'i Tjeckien', 'DK' : 'i Danmark', 'ES' : 'i Spanien', 'GR' : 'i Grekland', 'HU' : 'i Ungern', 'IL' : 'i Israel', 'LV' : 'i Lettland', 'LU' : 'i Luxemburg', 'MY' : 'i Malaysia', 'NO' : 'i Norge', 'PL' : 'i Polen', 'PT' : 'i Portugal', 'RO' : 'i Rumänien', 'SK' : 'i Slovakien', 'ZA' : 'i Sydafrika', 'UA' : 'i Ukraina' }, 'uk' : { 'AT' : 'у Австрії', 'BE' : 'у Бельгії', 'DK' : 'у Данії', 'ES' : 'в Іспанії', 'HU' : 'в Угорщині', 'IL' : 'в Ізраїлі', 'LV' : 'у Латвії', 'LU' : 'у Люксембургу', 'MY' : 'у Малайзії', 'NO' : 'у Норвегії', 'PL' : 'у Польщі', 'PT' : 'у Португалії', 'RO' : 'у Румунії', 'SK' : 'у Словаччині', 'ZA' : 'у ПАР', 'UA' : 'в Україні' } };

/* Most of the translations are actually using "in COUNTRY" or similar to account for grammar differences. So this makes English do the same, and allows us to use a clearer %in-country% variable, while avoiding breaking old content using %country%.

  • /

frb.inCountryNames = JSON.parse( JSON.stringify( frb.countryNames ) ); // deep copy frb.inCountryNames.en = { 'US' : 'in the United States', 'CA' : 'in Canada', 'GB' : 'in the UK', 'IE' : 'in Ireland', 'AU' : 'in Australia', 'NZ' : 'in New Zealand', 'AR' : 'in Argentina', 'AT' : 'in Austria', 'BE' : 'in Belgium', 'BR' : 'in Brazil', 'CH' : 'in Switzerland', 'CL' : 'in Chile', 'CO' : 'in Colombia', 'CZ' : 'in the Czech Republic', 'DK' : 'in Denmark', 'ES' : 'in Spain', 'FR' : 'in France', 'GR' : 'in Greece', 'HK' : 'in Hong Kong', 'HU' : 'in Hungary', 'IL' : 'in Israel', 'IN' : 'in India', 'IT' : 'in Italy', 'JP' : 'in Japan', 'LU' : 'in Luxembourg', 'LV' : 'in Latvia', 'MX' : 'in Mexico', 'MY' : 'in Malaysia', 'NL' : 'in the Netherlands', 'NO' : 'in Norway', 'PE' : 'in Peru', 'PL' : 'in Poland', 'PT' : 'in Portugal', 'RO' : 'in Romania', 'SE' : 'in Sweden', 'SK' : 'in Slovakia', 'UA' : 'in Ukraine', 'UY' : 'in Uruguay', 'ZA' : 'in South Africa' };

frb.dayNames = { 'en' : [ 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday' ], 'ca' : [ 'diumenge', 'dilluns', 'dimarts', 'dimecres', 'dijous', 'divendres', 'dissabte' ], 'ja' : [ '日', '月', '火', '水', '木', '金', '土' ], 'es' : [ 'domingo', 'lunes', 'martes', 'miércoles', 'jueves', 'viernes', 'sábado' ], 'sv' : [ 'söndag', 'måndag', 'tisdag', 'onsdag', 'torsdag', 'fredag', 'lördag' ], 'da' : [ 'søndag', 'mandag', 'tirsdag', 'onsdag', 'torsdag', 'fredag', 'lørdag' ], 'nb' : [ 'søndagen', 'mandagen', 'tirsdagen', 'onsdagen', 'torsdagen', 'fredagen', 'lørdagen' ], 'it' : [ 'domenica', 'lunedì', 'martedì', 'mercoledì', 'giovedì', 'venerdì', 'sabato' ], 'nl' : [ 'zondag', 'maandag', 'dinsdag', 'woensdag', 'donderdag', 'vrijdag', 'zaterdag' ], 'fr' : [ 'dimanche', 'lundi', 'mardi', 'mercredi', 'jeudi', 'vendredi', 'samedi' ], 'de' : [ 'Sonntag', 'Montag', 'Dienstag', 'Mittwoch', 'Donnerstag', 'Freitag', 'Samstag' ], 'he' : [ 'ראשון', 'שני', 'שלישי', 'רביעי', 'חמישי', 'שישי', 'שבת' ], 'lv' : [ 'svētdienā', 'pirmdienā', 'otrdienā', 'trešdienā', 'ceturtdienā', 'piektdienā', 'sestdienā' ], 'pl' : [ 'niedzielę', 'poniedziałek', 'wtorek', 'środę', 'czwartek', 'piątek', 'sobotę' ], 'pt' : [ 'neste domingo', 'nesta segunda-feira', 'nesta terça-feira', 'nesta quarta-feira', 'nesta quinta-feira', 'nesta sexta-feira', 'neste sábado' ], 'ru' : [ 'воскресенье', 'понедельник', 'вторник', 'среду', 'четверг', 'пятницу', 'субботу' ], 'uk' : [ 'неділі', 'понеділка', 'вівторка', 'середи', 'четверга', 'п’ятниц', 'суботи' ], 'hu' : [ 'vasárnap', 'hétfő', 'kedd', 'szerda', 'csütörtök', 'péntek', 'szombat' ], 'ro' : [ 'duminică', 'luni', 'marți', 'miercuri', 'joi', 'vineri', 'sâmbătă' ], 'af' : [ 'Sondag', 'Maandag', 'Dinsdag', 'Woensdag', 'Donderdag', 'Vrydag', 'Saterdag' ], 'aa' : [ 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday' ] };

// "This fooday" translations. Needed for some languages where gender varies and "this" must agree frb.dayNamesThis = { 'en' : [ 'this Sunday', 'this Monday', 'this Tuesday', 'this Wednesday', 'this Thursday', 'this Friday', 'this Saturday' ], 'el' : [ 'Αυτήν την Κυριακή', 'Αυτή τη Δευτέρα', 'Αυτήν την Τρίτη', 'Αυτήν την Τετάρτη', 'Αυτήν την Πέμπτη', 'Αυτήν την Παρασκευή', 'Αυτό το Σάββατο' ], 'jp' : [ 'この日曜日', 'この月曜日', 'この火曜日', 'この水曜日', 'この木曜日', 'この金曜日', 'この土曜日' ], 'it' : [ 'questa domenica', 'questo lunedì', 'questo martedì', 'questo mercoledì', 'questo giovedì', 'questo venerdì', 'questo sabato'], 'pl' : [ 'w tę niedzielę', 'w ten poniedziałek', 'w ten wtorek', 'w tę środę', 'w ten czwartek', 'w ten piątek', 'w tę sobotę' ], 'ru' : [ 'в это воскресенье', 'в этот понедельник', 'в этот вторник', 'в эту среду', 'в этот четверг', 'в эту пятницу', 'в эту субботу' ], 'uk' : [ 'цієї неділі', 'цього понеділка', 'цього вівторка', 'цієї середи', 'цього четверга', 'цієї п’ятниці', 'цієї суботи' ], 'pt' : [ 'este domingo', 'esta segunda-feira', 'esta terça-feira', 'esta quarta-feira', 'esta quinta-feira', 'esta sexta-feira', 'este sábado'], 'sk' : [ 'túto nedeľu', 'tento pondelok', 'tento utorok', 'túto stredu', 'tento štvrtok', 'tento piatok', 'túto sobotu'], 'cs' : [ 'tuto neděli', 'toto pondělí', 'toto úterý', 'tuto středu', 'tento čtvrtek', 'tento pátek', 'tuto sobotu'] };

frb.iPadTranslations = { 'en' : 'iPad' };

// Insert any localize data overrides here

/* jshint maxerr: 600 */ /* MediaWiki:FundraisingBanners/CoreJS-2018.js

* Core code for banner forms, with new inline error messages
*/

var frb = frb || {};

/**

* Test for general ES6 and <dialog> support
*
* Checks for arrow functions, default parameters, NodeList.prototype.forEach(), <dialog> support
* Should be roughly Chrome 51+, Firefox 98+, Edge 79+, Safari 15.4+
* Based on https://gist.github.com/bendc/d7f3dbc83d0f65ca0433caf90378cd95
* @return {boolean}
*/

frb.supportedBrowser = function() { try { new Function('(a = 0) => a'); document.querySelectorAll('.frb').forEach(a => a); if ( typeof HTMLDialogElement === 'function' ) { return true; } else { return false; } } catch (err) { return false; } }();

if ( !mw.centralNotice.adminUi ) { // T262693 frb.loadedTime = Date.now(); frb.didSelectAmount = false; frb.optinRequiredCountries = [ 'AR', 'AT', 'BE', 'BR', 'CL', 'CO', 'CZ', 'DK', 'ES', 'FR', 'GB', 'GR', 'HU', 'IE', 'IT', 'IL', 'LU', 'LV', 'MX', 'NL', 'NO', 'PE', 'PL', 'PT', 'RO', 'SE', 'SK', 'UA', 'UY' ]; frb.optinRequired = frb.optinRequiredCountries.indexOf(mw.centralNotice.data.country) !== -1; frb.maxUSD = 25000; frb.reduceMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches; }

// Keyboard shortcut to go from banner preview to editor - Ctrl+Shift+E if ( mw.config.get('wgUserName') ) { if ( mw.config.get('wgUserName').match(/\(WMF\)/) ) { window.addEventListener('keydown', function(e) { if ( e.ctrlKey && e.shiftKey && e.keyCode === 69 ) { window.open( 'https://meta.wikimedia.org/wiki/Special:CentralNoticeBanners/Edit/' + mw.centralNotice.data.banner ); } }); } }

/**

* Main function to submit to paymentswiki
*
* @param  {Object} options
* - method (required)
* - submethod (optional)
* - gateway (optional)
* - skipValidation (optional boolean, for pp-usd. Not yet implemented.)
* @param  {Boolean} isEndowment - deprecated, set frb.isEndowment instead
*/

frb.submitForm = function( options, isEndowment ) {

var url = new URL('https://payments.wikimedia.org/index.php/Special:GatewayChooser'); var params = {};

if ( !frb.validateForm( options ) ) { frb.extraData.validateError = 1; // Flag they had an error, even if fixed later return false; // Error, bail out of submitting }

if ( frb.isDarkMode() ) { frb.extraData.darkMode = 1; }

// Skip form chooser for Venmo if ( options.method === 'venmo' && options.gateway !== 'gravy' ) { url = new URL('https://payments.wikimedia.org/index.php/Special:BraintreeGateway'); }

// Form selection data params.payment_method = options.method; if ( options.submethod ) { params.payment_submethod = options.submethod; } if ( options.gateway ) { params.gateway = options.gateway; } if ( options.variant ) { params.variant = options.variant; } params.recurring = frb.getRecurring();

if ( params.recurring && params.variant && params.variant.match( /monthlyConvert/ ) ) { // Post-payments monthly convert makes no sense if it's already recurring // Avoid things like T312905 delete params.variant; }

params.currency = frb.getCurrency(mw.centralNotice.data.country) || 'USD';

params.uselang = mw.centralNotice.data.uselang || 'en'; params.country = mw.centralNotice.data.country || 'XX';

if ( params.uselang === 'pt' && params.country === 'BR' ) { params.uselang = 'pt-br'; } if ( params.uselang === 'es' && ( params.country === 'AR' || params.country === 'CL' || params.country === 'CO' || params.country === 'MX' || params.country === 'PE' || params.country === 'UY' || params.country === 'US' ) ) { params.uselang = 'es-419'; }

// dLocal override for South Africa if ( params.payment_method === 'cc' && params.country === 'ZA' ) { params.gateway = 'astropay'; }

// Amount var amount = frb.getAmount(); if ( $('#frb-ptf-checkbox').prop('checked') ) { amount = amount + frb.calculateFee(amount); frb.extraData.ptf = 1; } params.amount = amount;

// Email optin if ( frb.optinRequired && $('input[name="opt_in"]').length > 0 ) { var opt_inValue = $('input[name="opt_in"]:checked').val(); params.opt_in = opt_inValue; // frb.validateForm() already checked it's 1 or 0 }

// Tracking info if ( isEndowment || frb.isEndowment ) { params.wmf_medium = 'endowment'; params.appeal = 'EndowmentQuote'; } else { params.wmf_medium = 'sitenotice'; } params.wmf_campaign = mw.centralNotice.data.campaign || 'test'; params.wmf_source = frb.buildTrackingSource(params);

frb.extraData.time = Math.round( (Date.now() - frb.loadedTime)/1000 );

if ( !$.isEmptyObject( frb.extraData ) ) { params.wmf_key = frb.buildTrackingKey( frb.extraData ); }

// Link to Banner History if enabled var mixins = mw.centralNotice.getDataProperty( 'mixins' ); if ( mixins && mixins.bannerHistoryLogger ) { params.bannerhistlog = mw.centralNotice.bannerHistoryLogger.id; }

for ( var key of Object.keys( params ) ) { url.searchParams.set( key, params[key] ); }

// Set a cookie with current location so we can return here from TY page mw.loader.using( [ 'mediawiki.cookie', 'mediawiki.util' ] ).then( function () { // Exclude URL parameters like banner, but cope with paths like /w/index.php?title=Foo var returnToUrl = window.location.origin + mw.util.getUrl(); mw.cookie.set( 'fundraising_returnTo', returnToUrl, { expires: 300, prefix: , domain: '.wikipedia.org', secure: true } ); });

if ( mixins && mixins.bannerHistoryLogger ) { mw.centralNotice.bannerHistoryLogger.ensureLogSent().always(function() { frb.goToPayments( url ); }); } else { frb.goToPayments( url ); }

};

frb.goToPayments = function( url ) { if ( window.top !== window.self ) { // banner is in a frame, open payments in a new tab window.open( url.toString() ); } else { window.location.href = url.toString(); } };

/**

* Check the form for errors.
*
* Called on submission, can also be called on input
*
* @param {object} options
* @return {boolean} Whether form is error-free
*/

frb.validateForm = function( options ) { var error = false;

/* Reset all errors */ $('.frb-haserror').removeClass('frb-haserror'); $('.frb-error').hide();

if ( !options.method ) { error = true; $('.frb-methods').addClass('frb-haserror'); $('.frb-error-method').show(); }

if ( !frb.validateAmount() ) { error = true; }

/* Email optin */ if ( frb.optinRequired && $('.frb-optin').is(':visible') ) { var opt_inValue = $('input[name="opt_in"]:checked').val(); if ( opt_inValue !== '1' && opt_inValue !== '0' ) { $('.frb-optin').addClass('frb-haserror'); $('.frb-error-optin').show(); error = true; } }

return !error; };

/**

* Check if selected amount is valid i.e. a positive number, between minimum and maximum.
* If not, show an error and return false.
*/

frb.validateAmount = function() {

var amount = frb.getAmount(), currency = frb.getCurrency( mw.centralNotice.data.country ), minAmount = frb.amounts.minimums[ currency ], maxAmount = Math.round( frb.maxUSD * minAmount ); // Math.round to account for floating point math errors: https://phabricator.wikimedia.org/T246262

if ( amount === null || isNaN(amount) || amount <= 0 || amount < minAmount ) { $('fieldset.frb-amounts').addClass('frb-haserror'); $('.frb-error-bigamount').hide(); $('.frb-error-smallamount').show(); return false; } else if ( amount > Math.round( maxAmount ) ) { $('fieldset.frb-amounts').addClass('frb-haserror'); $('.frb-error-bigamount').show(); return false; } else { $('fieldset.frb-amounts').removeClass('frb-haserror'); $('.frb-error-smallamount, .frb-error-bigamount').hide(); return true; } };

/**

* Build the wmf_source for analytics.
*
* Own function so it can be overriden for weird tests
*
* @param  {Object} params
* @return {string} wmf_source
*/

frb.buildTrackingSource = function(params) {

var wmf_source; var fullDottedPaymentMethod = params.payment_method; if ( params.recurring ) { fullDottedPaymentMethod = 'r' + fullDottedPaymentMethod; } if ( params.payment_submethod ) { fullDottedPaymentMethod = fullDottedPaymentMethod + '.' + params.payment_submethod; }

wmf_source = mw.centralNotice.data.banner;

// Keeping opt-in in wmf_source for safety for now // Eventually remove it, or move to wmf_key? if ( params.opt_in ) { wmf_source += '_optIn' + params.opt_in; }

wmf_source += '.no-LP.' + fullDottedPaymentMethod;

return wmf_source; };

/**

* Build a string for wmf_key from extra tracking data
*
* @param  {Object} data
* @return {string} wmf_key
*/

frb.buildTrackingKey = function(data) { var dataArray = []; for (var key in data) { if (data.hasOwnProperty(key)) { dataArray.push( key + '_' + data[key] ); } } return dataArray.join('~'); };

/**

* Determine if we should show recurring choice on step 2
*
* NOTE 2023-12-07: we don't currently use this for step 2, since there are no
*	banners where users select method before frequency. However it is used by
*	frb.shouldShowMonthlyConvert()
*
* @param  {Object} options     Including method and optional gateway
* @param  {String} country
* @return {boolean}
*/

frb.shouldShowRecurring = function( options, country ) {

if ( frb.isEndowment ) { return false; } if ( frb.noRecurringCountries.indexOf( country ) !== -1 ) { // Defined in LocalizeJS-2017.js return false; } if ( options.method === undefined ) { return true; // Show if a method hasn't been selected yet } if ( [ 'cc', 'venmo', 'apple', 'google' ].indexOf( options.method ) !== -1 ) { return true; } if ( options.method === 'paypal' ) { if ( [ 'AR', 'BR', 'CL', 'CO', 'MX', 'PE', 'UY' ].includes( country ) ) { return false; } else { return true; } } // Adyen iDEAL if ( options.submethod === 'rtbt_ideal' ) { return true; } // SEPA if ( options.submethod === 'sepadirectdebit' ) { return true; } if ( options.submethod === 'upi' || options.submethod === 'paytmwallet' ) { return true; } return false; };

/* Is recurring method selected? This function can be overriden for different forms */ frb.getRecurring = function() { // Can't use simple form.frequency.value, doesn't work in IE var selected = $('#frb-form input[name="frequency"]:checked').val(); return selected === 'monthly'; };

/* Return amount selected */ frb.getAmount = function() { var form = document.getElementById('frb-form'); var amount = null; frb.extraData.otherAmt = 0;

// If there are some amount radio buttons, then look for the checked one if (form.amount) { for (var i = 0; i < form.amount.length; i++) { if (form.amount[i].checked) { amount = form.amount[i].value; } } }

// Check the "other" amount box if (form.otherAmount.value !== ) { var otherAmount = form.otherAmount.value; otherAmount = otherAmount.replace(/[,.](\d)$/, ':$10'); otherAmount = otherAmount.replace(/[,.](\d)(\d)$/, ':$1$2'); otherAmount = otherAmount.replace(/[$£€¥,.]/g, ); otherAmount = otherAmount.replace(/:/, '.'); amount = otherAmount; frb.extraData.otherAmt = 1; }

amount = parseFloat(amount);

if ( isNaN(amount) ) { return 0; } else { return amount; }

};

/* Localize the amount errors. Call when initialising banner. */ frb.localizeErrors = function() { var currency = frb.getCurrency( mw.centralNotice.data.country ), language = mw.centralNotice.data.uselang, minAmount = frb.amounts.minimums[ currency ], maxAmount = Math.round( frb.maxUSD * minAmount ); // Math.round to account for floating point math errors: https://phabricator.wikimedia.org/T246262

$('.frb-error-smallamount').text( function( index, oldText ) { return oldText.replace( '$1', frb.formatCurrency(currency, minAmount, language) ); });

$('.frb-error-bigamount').text( function( index, oldText ) { // We cannot accept donations greater than $1 $2 through our website. Please contact our major gifts staff at $3. return oldText.replace( '$1', maxAmount ) .replace( '$2', currency ) .replace( '$3', 'benefactors@wikimedia.org' ); }); };

/**

* Shared code for amount input handling
*/

frb.initAmountOptions = function() {

// Reset "Other" input if user clicks a preset amount $('#frb-form [id^=frb-amt-ps]').click(function() { $('#frb-amt-other-input').val(); });

// Track if they selected and then later changed amount var checkAmountChange = function(e) { if ( frb.didSelectAmount ) { frb.extraData.changedAmt = 1; } // check if amount radio button is selected OR there is a value in the other amount if ( $('.frb-amounts input[type="radio"]:checked').val() !== 'Other' || $('#frb-amt-other-input').val().length > 0 ) { frb.didSelectAmount = true; } return; };

$('.frb-amounts input[type="radio"]').on('change', checkAmountChange); $('#frb-amt-other-input').on('focusout', checkAmountChange);

// Block typing non-numerics in input field, otherwise Safari allows them and then chokes // https://phabricator.wikimedia.org/T118741, https://phabricator.wikimedia.org/T173431 var blockNonNumeric = function(e) { // Allow special keys in Firefox if ((e.code == 'ArrowLeft') || (e.code == 'ArrowRight') || (e.code == 'ArrowUp') || (e.code == 'ArrowDown') || (e.code == 'Delete') || (e.code == 'Backspace')) { return; } var chr = String.fromCharCode(e.which); if ("0123456789., ".indexOf(chr) === -1) { return false; } }; $('#frb-amt-other-input').on('keypress', blockNonNumeric); $('#frb-amt-monthly-other-input').on('keypress', blockNonNumeric);

};

/**

* Calculate approximate transaction fee on given amount
*
* @param  {number} amount
* @return {number}        Rounded to 2 decimal places
*/

frb.calculateFee = function(amount) { var currency = frb.getCurrency(mw.centralNotice.data.country), feeMultiplier = 0.04, feeMinimum = frb.amounts.feeMinimums[currency] || 0.35, feeAmount = amount * feeMultiplier;

if ( feeAmount < feeMinimum ) { feeAmount = feeMinimum; } return parseFloat(feeAmount.toFixed(2)); };

frb.updateFeeDisplay = function() { var currency = frb.getCurrency(mw.centralNotice.data.country), language = mw.centralNotice.data.uselang, amount, feeAmount, totalAmount;

amount = frb.getAmount(); feeAmount = frb.calculateFee(amount); if ( $('#frb-ptf-checkbox').prop('checked') ) { totalAmount = amount + feeAmount; } else { totalAmount = amount; }

var feeAmountFormatted = frb.formatCurrency(currency, feeAmount, language); $('.frb-ptf-fee').text(feeAmountFormatted);

var totalAmountFormatted = frb.formatCurrency(currency, totalAmount, language); $('.frb-ptf-total').text(totalAmountFormatted);

$('.frb-ptf').slideDown( frb.reduceMotion ? 0 : 400 ); };

/**

* Custom hide cookie function
*
* Purposely sets only for this domain.
* CentralNotice builtin method seems buggy - see T270401
*
* @param {string} reason Reason to store in the hide cookie
* @param {number} duration Cookie duration, in seconds
*/

frb.altSetHideCookie = function ( reason, duration ) {

mw.loader.using( 'mediawiki.cookie' ).then( function () {

var cookieName = 'centralnotice_hide_fundraising', date = new Date(), hideData = { v: 1, created: Math.floor( date.getTime() / 1000 ), reason: reason };

// Re-use the same date object to set the cookie's expiry time date.setSeconds( date.getSeconds() + duration );

mw.cookie.set( cookieName, JSON.stringify( hideData ), { expires: date, path: '/', domain: 'wikipedia.org', prefix: } );

});

};

frb.showDonateLinkTooltip = function ( content ) { try { mw.loader.using( [ 'oojs-ui-core' ] ).done( function () {

let $donateLink = $( '#pt-sitesupport-2 a, #pt-sitesupport a, #n-sitesupport a, #p-donation a' ); $donateLink.attr( 'href', ( i, oldUrl ) => { let url = new URL( oldUrl, 'https://donate.wikimedia.org' ); // base needed because some links are protocol relative url.searchParams.delete( 'utm_source' ); // Until we have updated sidebar links url.searchParams.set( 'wmf_source', 'tooltipOnBannerClose' ); return url.toString(); });

let popupOptions = {

$content: $( '

' + content + '

' ),

padded: true, autoclose: true, align: 'forwards', autoFlip: false };

if ( document.querySelector( '#p-donation a' ) ) { // Minerva popupOptions.$floatableContainer = $( '.navigation-drawer' ); popupOptions.position = 'below'; } else if ( $( '#pt-sitesupport-2 a:visible' ).length > 0 ) { // Vector 2022 user tools popupOptions.$floatableContainer = $( '#pt-sitesupport-2 a' ); popupOptions.position = 'below'; } else if ( document.querySelector( '#pt-sitesupport a' ) ) { // Vector 2022 user tools collapsed in menu popupOptions.$floatableContainer = $( '#vector-user-links-dropdown' ); popupOptions.position = 'below'; } else if ( document.querySelector( '#vector-main-menu-dropdown #n-sitesupport a') ) { // Vector 2022 main menu (only when logged in, so mostly here for testing) popupOptions.$floatableContainer = $( '#vector-main-menu-dropdown' ); popupOptions.position = 'below'; } else if ( document.querySelector( '#n-sitesupport a' ) ) { // Legacy Vector (sidebar) popupOptions.$floatableContainer = $( '#n-sitesupport a' ); popupOptions.position = 'after'; }

let popup = new OO.ui.PopupWidget( popupOptions );

popup.$element.css('z-index', 5); // Fix so it shows above header $( document.body ).append( popup.$element ); popup.toggle( true );

setTimeout( () => { popup.$element.fadeOut( frb.fadeDuration ); }, 5000 ); } ); } catch (e) { console.log('Problem showing banner close tooltip'); } };

frb.showSidebarTooltip = frb.showDonateLinkTooltip; // Alias for old name

frb.isDarkMode = function() { let rootClasses = document.documentElement.classList, osDark = window.matchMedia('(prefers-color-scheme: dark)').matches; return rootClasses.contains( 'skin-theme-clientpref-night' ) || ( rootClasses.contains( 'skin-theme-clientpref-os' ) && osDark ); };

/**

* Determine if banner should be shown, and set correct data for impression logging
*
* @return {boolean} Show banner?
*/

frb.shouldShowBanner = function() {

mw.centralNotice.bannerData.hideResult = false;

/* Hide in unsupported browsers */ if ( !frb.supportedBrowser ) { mw.centralNotice.bannerData.hideResult = true; mw.centralNotice.bannerData.hideReason = 'browser'; }

/* Hide outside main namespace (except Main Page, for sites where it isn't in main namespace) */ if ( mw.config.get('wgNamespaceNumber') > 0 && !mw.config.get('wgIsMainPage') ) { mw.centralNotice.bannerData.hideResult = true; mw.centralNotice.bannerData.hideReason = 'namespace'; }

// Hide banner on sensitive articles // TODO - possibly add wgWikibaseItemId for multilingual support and resilience to moves? var hideTitles = [ 'Murder of Don Banfield', 'Asian News International', 'Asian News International vs. Wikimedia Foundation' ]; var pageTitle = mw.config.get('wgTitle'); if ( hideTitles.indexOf( pageTitle ) !== -1 ) { mw.centralNotice.bannerData.hideResult = true; mw.centralNotice.bannerData.hideReason = 'article'; }

/* Hide banner if on wrong site (desktop/mobile) in case wrong device settings were chosen */ var bannerName = mw.centralNotice.data.banner, skin = mw.config.get('skin'), siteName = mw.config.get('wgSiteName'); if ( ( bannerName.indexOf('_dsk_') !== -1 && skin === 'minerva' ) || ( bannerName.indexOf('_m_') !== -1 && skin !== 'minerva' ) || skin === 'wikimediaapiportal' || // workaround for T270308 siteName === 'Wikitech' ) { mw.centralNotice.bannerData.hideResult = true; mw.centralNotice.bannerData.hideReason = 'other'; console.warn('Hiding fundraising banner on wrong site (desktop/mobile)'); }

return !mw.centralNotice.bannerData.hideResult;

};

/* Debug function to highlight dynamically replaced elements */ frb.highlightReplacements = function() { $('.frb [class^="frb-replace"], .frb-ptf-fee, .frb-ptf-total, .frb-upsell-ask, frb-amt').css('background-color', '#fa0'); };

if ( !mw.centralNotice.adminUi ) { // T262693 /** * Provides alterImpressionData hook for CentralNotice * This info will be sent back with Special:RecordImpression * TODO: check if/when we can remove this (and RecordImpression) */ mediaWiki.centralNotice.bannerData.alterImpressionData = function( impressionData ) { // Returning true from this function indicates the banner was shown if (mediaWiki.centralNotice.bannerData.hideReason) { impressionData.reason = mediaWiki.centralNotice.bannerData.hideReason; } if (mediaWiki.centralNotice.bannerData.cookieCount) { impressionData.banner_count = mediaWiki.centralNotice.bannerData.cookieCount; }

return !mediaWiki.centralNotice.bannerData.hideResult; }; }

/* End of MediaWiki:FundraisingBanners/CoreJS-2018.js */ /* jshint maxerr: 600 */ /* == MediaWiki:FundraisingBanners/LocalizeJS-2022.js == */

/**

* Get the currency for a given country
*
* NOTE: The following currency mapping is WMF-specific based on payment
* provider availability, NOT necessarily the official currency of the country
*
* @param  {string} country code
* @return {string} currency code
*/

frb.getCurrency = function(country) { switch ( country ) { // Big 6 case 'US': return 'USD'; case 'CA': return 'CAD'; case 'AU': return 'AUD'; case 'NZ': return 'NZD'; case 'GB': return 'GBP'; case 'IE': return 'EUR'; // Euro countries case 'AT': case 'BE': case 'ES': case 'FR': case 'GR': case 'IE': case 'IT': case 'LU': case 'LV': case 'NL': case 'PT': case 'SK': return 'EUR'; // Others case 'DK': return 'DKK'; case 'HU': return 'HUF'; case 'IL': return 'ILS'; case 'IN': return 'INR'; case 'JP': return 'JPY'; case 'MY': return 'MYR'; case 'NO': return 'NOK'; case 'PL': return 'PLN'; case 'CZ': return 'CZK'; case 'RO': return 'RON'; case 'SE': return 'SEK'; case 'UA': return 'UAH'; case 'ZA': return 'ZAR'; // Latin America case 'BR': return 'BRL'; case 'AR': return 'ARS'; case 'CL': return 'CLP'; case 'CO': return 'COP'; case 'MX': return 'MXN'; case 'PE': return 'PEN'; case 'UY': return 'UYU'; case 'CH': return 'CHF'; case 'LI': return 'CHF'; // Fall back to USD default: return 'USD'; } };

/**

* Format a currency value
*
* TODO: make this handle the ISO code overrides?
*
* @param  {string} currency code. Leave undefined to get without symbol.
* @param  {number} amount
* @param  {string} language code
* @return {string} formatted string e.g. '$3', '£5', '10 €'
*/

frb.formatCurrency = function(currency, amount, language) {

var locale, formatterOptions, formatter, fmAmount, supportsIntl;

if ( isNaN(amount) || amount === ) { // Not a number, it's probably the 'other' string or box // TODO: better way of doing this? fmAmount = amount; } else { // Check browser support try { supportsIntl = typeof window.Intl === 'object'; } catch (e) { supportsIntl = false; // T265396 }

if ( supportsIntl ) { // Use Intl for fancy number formatting - thousands separators etc locale = language + '-' + mw.centralNotice.data.country; if ( amount % 1 !== 0 ) { formatterOptions = { minimumFractionDigits: 2 }; } else { formatterOptions = {}; } formatter = new Intl.NumberFormat(locale, formatterOptions); } else { // Bad browser i.e. IE. Just do the basics: 2 decimal places if needed, or none formatter = {}; formatter.format = function(number) { if ( amount % 1 !== 0 ) { return number.toFixed(2); } else { return number.toString(); } }; } fmAmount = formatter.format(amount); }

// No symbol needed if ( currency === undefined ) { return fmAmount; }

// Better dive into the formatting object if ( frb.currencyFormats[currency] === undefined ) { return currency + ' ' + fmAmount; } if ( frb.currencyFormats[currency] instanceof Object ) { // not a string if ( frb.currencyFormats[currency][language] !== undefined ) { return frb.currencyFormats[currency][language].replace('\t', fmAmount); } return frb.currencyFormats[currency]['default'].replace('\t', fmAmount); }

return frb.currencyFormats[currency].replace('\t', fmAmount); };

/*

* Select the correct amount or array of amounts from object in "source"
*
* @param {Object} source   - the amounts data object e.g. frb.amounts.options7, frb.amounts.averages
* @param {string} currency - ISO code of currency
* @param {string} country  - ISO code of country (optional)
* @return {array/number}   - depending on source
*/

frb.pickAmounts = function(source, currency, country) {

if ( source[currency]['default'] ) { // we need to go deeper if ( source[currency][country] !== undefined ) { return source[currency][country]; } else { return source[currency]['default']; } } else { return source[currency]; } };

/* Credit card types so we can show the correct logos */ frb.cardTypes = { // Big 6 'US' : 'vmad', 'CA' : 'vma', 'GB' : 'vmaj', 'IE' : 'vmaj', 'AU' : 'vmaj', 'NZ' : 'vma', // Euro countries 'AT' : 'vmaj', 'BE' : 'vmaj', 'ES' : 'vmaj', 'FR' : 'vma', 'GR' : 'vma', 'IT' : 'vmaj', 'LU' : 'vmaj', 'LV' : 'vma', 'NL' : 'vmaj', 'PT' : 'vmaj', 'SK' : 'vmaj', // Others 'CZ' : 'vmad', 'DK' : 'vma', 'HU' : 'vma', 'IL' : 'vmad', 'JP' : 'vmaj', 'MY' : 'vmaj', 'NO' : 'vma', 'PL' : 'vma', 'RO' : 'vma', 'SE' : 'vma', 'UA' : 'vma', 'ZA' : 'vm', 'IN' : 'vmar', // dLocal - RuPay 'CH' : 'vma', 'LI' : 'vma' };

/**

* Should we show Apple Pay?
*
* Note there is a ~500ms delay in Safari when checking, so only call this if needed
*
* @param  {string} country
* @return {boolean}
*/

frb.shouldShowApplePay = function ( country ) { // https://support.apple.com/en-us/HT207957 - minus China mainland var appleCountries = [ 'ZA', 'AU', 'HK', 'JP', 'MO', 'NZ', 'SG', 'TW', 'AM', 'AT', 'AZ', 'BY', 'BE', 'BG', 'HR', 'CY', 'CZ', 'DK', 'EE', 'FO', 'FI', 'FR', 'GE', 'DE', 'GR', 'GL', 'GG', 'HU', 'IS', 'IE', 'IM', 'IT', 'KZ', 'JE', 'LV', 'LI', 'LT', 'LU', 'MT', 'MC', 'ME', 'NL', 'NO', 'PL', 'PT', 'RO', 'RU', 'SM', 'RS', 'SK', 'SI', 'ES', 'SE', 'CH', 'UA', 'GB', 'VA', 'CO', 'CR', 'BR', 'MX', 'BH', 'IL', 'PS', 'QA', 'SA', 'AE', 'CA', 'US' ]; if ( appleCountries.indexOf( country ) === -1 ) { return false; } if ( location.search.match('forceApplePay') ) { return true; } if ( window.ApplePaySession ) { if ( ApplePaySession.canMakePayments() ) { return true; } } return false; };

/**

* Display the correct payment methods for current country
*
* Methods should be labeled with class 'frb-pm-xxxx'
* TODO: clean this function up more
*
* @param  {string} country
*/

frb.localizeMethods = function(country) {

// Test country with *all the methods* if ( country === 'ZZ' ) { $('.frb-payment-options > div').show(); return; }

// Hide recurring completely for some countries and endowment if ( frb.isEndowment || frb.noRecurringCountries.indexOf(country) !== -1 ) { $('.frb-frequency, .recurring-details').hide(); }

// Remove any leftover WorldPay and Adyen $('.frb-pm-cc-wp').remove(); $('.frb-pm-cc-adyen').remove();

// Countries with no PayPal option var noPP = ['IN', 'RU', 'SG', 'AE', 'QA', 'OM', 'BD', 'BO', 'PA', 'PY', 'GT', 'JM', 'TT', 'DZ']; if ($.inArray(country, noPP) !== -1) { $('.frb-pm-pp').remove(); $('.frb-pm-pp-usd').remove(); }

// Countries with no PayPal for mobile only - https://phabricator.wikimedia.org/T173001 var noPPmobile = ['PH', 'ID', 'TH', 'KR', 'MY', 'VN']; var mobileRegex = /(_mob_|_ipd_|_m_)/; if ($.inArray(country, noPPmobile) !== -1) { if (mw.centralNotice.data.banner.search(mobileRegex) !== -1) { $('.frb-pm-pp').remove(); $('.frb-pm-pp-usd').remove(); } }

// Countries where PayPal must be in USD var ppUSD = ['BG', 'HR', 'LT', 'MK', 'RO', 'UA', 'SA', 'CN', 'ID', 'KR', 'KZ', 'MY', 'VN', 'AR', 'CL', 'DO', 'CO', 'NI', 'UY', 'ZA', 'BH', 'LB', 'VE', 'TR', 'IS', 'BA', 'MV', 'BB', 'BM', 'BZ', 'CR', 'CW', 'SX', 'HN', 'KN', 'DM', 'AG', 'LC', 'GD', 'FJ', 'TN', 'BJ', 'BF', 'CI', 'GW', 'ML', 'NE', 'SN', 'TG', 'BR', 'PE']; if ($.inArray(country, ppUSD) !== -1) { $('.frb-pm-pp').remove(); $('.frb-pm-pp-usd').show(); } else { $('.frb-pm-pp').show(); $('.frb-pm-pp-usd').remove(); }

// Show any extra local payment methods, or remove them if not needed var extrapaymentmethods = { 'amazon'  : ['US'], // Note Amazon was removed from current best 2023-10-20 'bpay'  : [], 'ideal'  : ['NL'], 'bt'  : ['BR', 'AR', 'CO', 'CL', 'PE', 'MX', 'IN', 'ZA', 'CZ'], // Bank Transfer (dLocal/Adyen) 'cash'  : ['MX', 'AR', 'CO', 'CL', 'PE', 'UY'], // 'Cash' methods (dLocal) 'pix'  : ['BR'], 'boleto'  : ['BR'], 'ach'  : ['US'], 'trustly'  : ['US'], 'sepa'  : ['AT', 'BE', 'CY', 'DE', 'EE', 'ES', 'FR', 'GR', 'HR', 'IE', 'IT', 'LT', 'LU', 'LV', 'MT', 'NL', 'PT', 'SI', 'SK'] };

// Methods with different labels per country

var language = mw.config.get('wgUserLanguage'); var btTranslation = 'Bank Transfer';

if (language === 'pt') {

if (country === 'BR') { btTranslation = 'Transferência bancária'; }

} else if (language === 'es') {

if (country === 'CL') { btTranslation = 'WebPay'; } else if (country === 'CO') { btTranslation = 'PSE Pagos'; } else { btTranslation = 'Transferencia bancaria'; }

}

if (country === 'CZ') { if (language === 'en') { btTranslation = 'Online Banking'; } if (language === 'cs') { btTranslation = 'Internetové Bankovnictví'; } }

$( '.frb-pm-bt button, .frb-pm-bt label, button.frb-pm-bt' ).text( btTranslation );

for (var method in extrapaymentmethods) { var $methodbutton = $('.frb-pm-' + method); if ( $.inArray(country, extrapaymentmethods[method]) !== -1 && !frb.isEndowment ) { $methodbutton.show(); } else { $methodbutton.remove(); } }

// Google Pay - separated from extrapaymentmethods as we want to show on Endowment too var googlePayCountries = [ 'AE', 'AT', 'AR', 'AU', 'BE', 'BG', 'BR', 'CA', 'CH', 'CL', 'CO', 'CZ', 'DE', 'DK', 'EE', 'ES', 'FR', 'GB', 'GR', 'HK', 'HR', 'HU', 'IE', 'IL', 'IT', 'JP', 'LU', 'LV', 'MX', 'MY', 'NL', 'NO', 'NZ', 'OM', 'PE', 'PL', 'PT', 'QA', 'RO', 'RU', 'SA', 'SE', 'SG', 'SK', 'TH', 'TR', 'TW', 'UA', 'US', 'UY', 'VN', 'ZA' ]; if ( $.inArray(country, googlePayCountries) !== -1 ) { $('.frb-pm-google').show(); } else { $('.frb-pm-google').remove(); }

// Apple Pay if ( $('.frb-pm-applepay').length > 0 ) { if ( !frb.shouldShowApplePay( country ) ) { $('.frb-pm-applepay').remove(); } }

// Venmo var $venmo = $('.frb-pm-venmo'); if ( country === 'US' && $venmo.length > 0 ) { // From MediaWiki:FundraisingBanners/VenmoBrowserCheck.js if ( frb.isVenmoSupported() ) { $venmo.show(); } else { $venmo.remove(); } } else { $venmo.remove(); }

/* Add card types class to credit card button, so we can show correct logos */ if ( frb.cardTypes[country] ) { $('.frb-pm-cc').addClass('frb-cctypes-' + frb.cardTypes[country] ); } };

/**

* Check scheduled payment method outages and hide buttons if needed
*
* Data at https://meta.wikimedia.org/wiki/MediaWiki:FR2013/Resources/PaymentOutages.js
* Methods should be labeled with class 'frb-pm-xxxx'
*
* @param  {string} country code
*/

frb.checkMethodOutages = function(country) {

// TODO - can we load this a better way? /* This file can be used to schedule hiding of individual payment methods from banners

* e.g. if they have scheduled downtime.
*
* Valid methods are:
*	ideal, cc, pp, amazon, bpay, webmoney, cash, pp-usd
* (most of the time it's 'ideal'...)
* Can also limit outage to a specific country with country: "XX" (where XX is an ISO code)
*
* Note that in JavaScript dates the months (and only the months) start at 0.
* Jan=0, Feb=1, Mar=2, Apr=3 etc. How hateful.
*
* Be sure to also update donatewiki if needed e.g. by commenting the method templates
* found at https://donate.wikimedia.org/wiki/Template:2012FR/Form-section/Paymentmethods
* 
*/

var outages = [

   {
       start:      new Date(Date.UTC(2016, 8, 18, 1)),
       end:        new Date(Date.UTC(2016, 8, 18, 7)),
       method:     "ideal"
   }

]; // jshint ignore:line var now = new Date();

for (var i = outages.length - 1; i >= 0; i--) { if ( now > outages[i].start && now < outages[i].end ) { if (outages[i].country === undefined || outages[i].country == country) { $('.frb-pm-' + outages[i].method).hide(); } } } };

/**

* Adjust the amount options and their labels
*
* Inputs should have id frb-amt-psX where X is the index number (starting from 1)
*
* @param  {Object}  source     - object with amounts e.g. frb.amounts.options7
* @param  {string}  currency   - currency code e.g. 'USD'
* @param  {string}  country    - country code  e.g. 'FR' Some currencies can have different options per country.
* @param  {string}  language   - language code e.g. 'en' For symbol formatting
* @param  {boolean} useSymbols - use currency symbols on labels or not? (3 vs $3)
*/

frb.localizeAmountOptions = function(source, currency, country, language, useSymbols) {

var amountOptions = frb.pickAmounts(source, currency, country);

$('#frb-form input[name="amount"]').each(function(index) { var $input = $(this); var $label = $input.siblings('label');

var i = $input.attr('id').replace('frb-amt-ps', ); var amount = amountOptions[i-1]; // because IDs start from 1

if ( amount ) { $input.val( amount ); if ( useSymbols ) { $label.text( frb.formatCurrency( currency, amount, language) ); } else { $label.text( frb.formatCurrency( undefined, amount, language) ); } } });

};

/**

* Make an element into a link
*
* @param  {string} selector    CSS selector for elements to convert to a link
* @param  {string} language    Code of language (could be es-419 or pt-br)
* @param  {string} baseUrl     URL of link (function will add language parameter)
*/

frb.makeLink = function( selector, language, baseUrl ) { var url = baseUrl + '&language=' + language; $( selector ).each( function() { var $link = $( '<a></a>' ); $link.html( $( this ).html() ); $link.attr( { href: url, _target: '_self' } ); $( this ).replaceWith( $link ); }); };

/**

* Get the number of banners seen from localStorage
* @return {number} Number of banners seen
*/

frb.getSeenCount = function () {

// Force with URL parameter 'impression' if ( typeof URLSearchParams === 'function' ) { // not available in old browsers var urlParams = new URLSearchParams( window.location.search ); if ( urlParams.has( 'impression' ) ) { return urlParams.get( 'impression' ); } }

try { if ( localStorage ) { var identifier = mw.centralNotice.internal.state.campaign.mixins.impressionDiet.cookieName, lsName = 'CentralNoticeKV|global|impression_diet_' + identifier, diet = JSON.parse( localStorage.getItem( lsName ) ); if ( diet ) { return diet.val.seenCount; } } } catch ( ex ) { // do nothing - localStorage is configured not to let us read it, or mixin not set return; } };

/**

* Helper function to do text replacements and wrap them in correct class
*
* @param  {RegExp} regex       Regular expression to replace
* @param  {string} replacement String to replace it with
*/

frb.textReplace = function( regex, replacement ) { $( '.frb' ).each( function( index ) { var newHtml = $( this ).html(); newHtml = newHtml.replace( regex, '' + replacement + '' ); $( this ).html( newHtml ); }); };

/**

* Replace elements with preset ask string amounts
*
* e.g. class="frb-replace-amt-ps4" will be replaced with amount #4, currently $25 in the US
*
* @param  {string} currency - currency code e.g. 'USD'
* @param  {string} country  - country code  e.g. 'FR'
* @param  {string} language - language code e.g. 'en' For symbol formatting
*/

frb.replaceCustomAmounts = function( currency, country, language ) { var amountOptions = frb.pickAmounts( frb.amounts.options7, currency, country );

// Old style element replacements $( '.frb [class^="frb-replace-amt-ps"]' ).each( function() { var i = $( this ).attr( 'class' ).replace( 'frb-replace-amt-ps', ), amount = amountOptions[ i - 1 ], formattedAmount = frb.formatCurrency( currency, amount, language ); $( this ).html( '<frb-amt>' + formattedAmount + '</frb-amt>' ); });

// Text replacements e.g. %amount-4% // There is probably a more efficient way to do this, but it's at least fairly simple for (var i = 0; i < amountOptions.length; i++) { var amount = amountOptions[i], formattedAmount, regex = new RegExp( '%amount-' + (i+1) + '%', 'gi' ); if ( frb.textAmountIsoCountries.includes( country ) ) { formattedAmount = frb.formatCurrency( undefined, amount, language ) + ' ' + currency; } else { formattedAmount = frb.formatCurrency( currency, amount, language ); } frb.textReplace( regex, formattedAmount ); } };

/**

* Get today's date like "December 3" - English only for now
*
* @return {string} Today's date as a string
*/

frb.getDateString = function() { var date = new Date(), locale = mw.centralNotice.data.uselang + '-' + mw.centralNotice.data.country; return date.toLocaleString( locale, { day: 'numeric', month: 'long' } ); };

frb.noRecurringCountries = ['AR', 'IN'];

/* These countries use potentially ambiguous $ sign. Use ISO code instead in text (but still $ for buttons) */ frb.textAmountIsoCountries = ['AR', 'CL', 'CO', 'MX'];

$(function() {

if ( mw.centralNotice.adminUi ) { // T262693 return; }

var language = mw.centralNotice.data.uselang; var variantLanguage; // for pt-br and es-419, note we can only use these for certain links var country = mw.centralNotice.data.country; var currency = frb.getCurrency(country);

if ( language === 'pt' && country === 'BR' ) { variantLanguage = 'pt-br'; } else if ( language === 'es' && ['AR', 'CL', 'CO', 'PE', 'MX', 'UY'].indexOf( country ) !== -1 ) { variantLanguage = 'es-419'; } else { variantLanguage = language; }

// Payment methods frb.localizeMethods(country); frb.checkMethodOutages(country);

// Preset amounts frb.replaceCustomAmounts( currency, country, language );

// Basic replacements $('.frb-replace-currencysymbol').text( frb.formatCurrency( currency, , language ).replace(' ', ) ); $('.frb-replace-currencycode').text( currency );

// Country name var countryName; if ( frb.countryNames[language] ) { countryName = frb.countryNames[language][country] || frb.countryNames.en[country]; } else { countryName = frb.countryNames.en[country]; } $( '.frb-replace-countryname' ).text( countryName ); frb.textReplace( /%country%/gi, countryName );

// "in COUNTRY" or equivalent var inCountryName; if ( frb.inCountryNames[language] ) { inCountryName = frb.inCountryNames[language][country] || frb.inCountryNames.en[country]; } else { inCountryName = frb.inCountryNames.en[country]; } $( '.frb-replace-incountryname' ).text( inCountryName ); frb.textReplace( /%in-country%/gi, inCountryName );

// Day of week // TODO: Replace these with date.toLocaleString so we can drop frb.dayNames? // Might still need some ways to deal with "this" and capitalization var now = new Date(); var dayNumber = now.getDay(); var capitalizeText = function( text ) { // Capitalize first letter, for use at start of sentence return text.charAt(0).toUpperCase() + text.slice(1); };

if ( $('.frb-replace-dayofweek, .frb-replace-dayofweek-capitalize').length > 0 ) { if ( frb.dayNames[language] ) { $('.frb-replace-dayofweek').text( frb.dayNames[language][dayNumber] ); $('.frb-replace-dayofweek-capitalize').text( capitalizeText( frb.dayNames[language][dayNumber] ) ); } else { console.log('Warning: banner should contain a day of the week, but no translations found.'); } }

if ( $('.frb-replace-dayofweek-this, .frb-replace-dayofweek-this-capitalize').length > 0 ) { if ( frb.dayNamesThis[language] ) { $('.frb-replace-dayofweek-this').text( frb.dayNamesThis[language][dayNumber] ); $('.frb-replace-dayofweek-this-capitalize').text( capitalizeText( frb.dayNamesThis[language][dayNumber] ) ); } else { console.log('Warning: banner should contain "this DAY", but no translations found.'); } }

// Simple %weekday% text replacement try { if ( frb.dayNames[language] ) { frb.textReplace( /%weekday%/gi, frb.dayNames[language][dayNumber] ); } else { frb.textReplace( /%weekday%/gi, frb.dayNames['en'][dayNumber] ); } } catch ( error ) { console.error( error ); }

// Replace %date% with today's date e.g. "December 3" try { frb.textReplace( /%date%/gi, frb.getDateString() ); } catch ( error ) { console.log( error ); }

// Capitalize $('.frb-capitalize').text(function( index, text ) { return text.charAt(0).toUpperCase() + text.slice(1); });

// Replace %average%, %minimum% and %amount% var average = frb.pickAmounts( frb.amounts.averages, currency, country ), ifEveryone = frb.pickAmounts( frb.amounts.ifEveryone, currency, country ), avgString, ifString;

if ( frb.textAmountIsoCountries.indexOf(country) !== -1 ) { avgString = frb.formatCurrency( undefined, average, language ) + ' ' + currency; ifString = frb.formatCurrency( undefined, ifEveryone, language ) + ' ' + currency; } else { avgString = frb.formatCurrency( currency, average, language ).replace( /\.$/, ); // strip any period from end for use in running text ifString = frb.formatCurrency( currency, ifEveryone, language ).replace( /\.$/, ); } frb.textReplace( /%average%/gi, avgString ); frb.textReplace( /%minimum%/gi, ifString ); frb.textReplace( /%amount%/gi, ifString );

/** * Call a function on every text node contained by a root node. * * Used so we can do text replacements without accidentally clobbering html and scripts * * @param {Node} rootNode The Node object whose descendants will be recursed through * @param {Function} callback Callback function that receives a Node as its only argument */ function eachTextNode( rootNode, callback ) { for ( var node = rootNode.firstChild; node !== null; node = node.nextSibling ) { if ( node.nodeType === Node.TEXT_NODE ) { callback( node ); } else if ( node.nodeType === Node.ELEMENT_NODE ) { eachTextNode( node, callback ); } } }

// French spacing: replace space before punctuation with   if ( language === 'fr' ) { var bannerRootElements = document.getElementsByClassName( 'frb' ); for ( var i = 0; i < bannerRootElements.length; i++ ) { eachTextNode( bannerRootElements[i], function( node ) { node.textContent = node.textContent.replace( / ([!?;:%])/g, '\u00a0$1' ); }); } }

// Links (in smallprint) TODO: merge with frb.makeLink() $('.frb-localize-links a').each(function() { // Add parameters for LandingCheck var url = new URL( $(this).attr('href') ); url.searchParams.set( 'country', country ); url.searchParams.set( 'language', variantLanguage ); // is this needed? url.searchParams.set( 'uselang', variantLanguage ); url.searchParams.set( 'wmf_medium', 'sitenotice' ); url.searchParams.set( 'wmf_campaign', mw.centralNotice.data.campaign || 'test' ); url.searchParams.set( 'wmf_source', mw.centralNotice.data.banner ); $(this).attr('href', url.toString()); $(this).attr('_target', '_self'); // Make links open in new tab });

// Add links frb.makeLink( '.frb-link-privacy', variantLanguage, 'https://foundation.wikimedia.org/wiki/Special:LandingCheck?basic=true&landing_page=Donor_privacy_policy' ); frb.makeLink( '.frb-link-tax', variantLanguage, 'https://donate.wikimedia.org/wiki/Special:LandingCheck?basic=true&landing_page=Tax_deductibility' ); frb.makeLink( '.frb-link-cancel', variantLanguage, 'https://donate.wikimedia.org/wiki/Special:LandingCheck?basic=true&landing_page=Cancel_or_change_recurring_giving' );

// Legal text variants if (country === 'US') { $('.frb-legal-US').show(); $('.frb-legal-nonUS, .frb-legal-NL').hide(); } else if (country === 'NL') { $('.frb-legal-NL').show(); $('.frb-legal-US, .frb-legal-nonUS').hide(); } else { $('.frb-legal-nonUS').show(); $('.frb-legal-US, .frb-legal-NL').hide(); }

// Quick hack for American/British/Commonwealth English differences if ( country === 'US' ) { $('.frb-lang-enUS').show(); $('.frb-lang-en5C').hide(); } else { $('.frb-lang-enUS').hide(); $('.frb-lang-en5C').show(); }

// Add this so they get white-space: nowrap from CSS $('.frb-ptf-fee, .frb-ptf-total, .frb-upsell-ask').addClass('frb-replaced');

// Where Remind Me Later should be shown var rmlCountries = ['US', 'CA', 'GB', 'IE', 'AU', 'NZ', 'NL', 'IN', 'FR', 'ES', 'JP', 'BR', 'CL', 'CO', 'MX', 'PE', 'UY']; var rmlLanguages = ['en', 'nl', 'ja', 'it', 'sv', 'pt', 'cs', 'es', 'ca', 'fr', 'aa']; var rmlEnabled = !frb.isEndowment && rmlCountries.indexOf(country) !== -1 && rmlLanguages.indexOf(language) !== -1;

if ( rmlEnabled ) { $('.frb').addClass('frb-rml-enabled'); } else { $('.frb').addClass('frb-rml-disabled'); }

});

/* == end of MediaWiki:FundraisingBanners/LocalizeJS-2022.js == */

frb.rml = {

   post: function() {
       /* Create the iframe for the form and use it as the form's _target */
       var frameName = 'remindFrame';
       var $form = $('#frb-rml-form');
       if ( $("iframe[name=" + frameName + "]").length === 0 ) {
           var $iframe = $('<iframe style="display: none;" name="' + frameName + '"></iframe>');
           $form.attr("_target", $iframe.attr("name"));
           $form.after($iframe);
       }
       $form[0].submit();
   },
   getCurrentDate: function() {
       /* Get current date in correct format for Silverpop */
       var today = new Date();
       var dd = today.getDate();
       var mm = today.getMonth()+1; // January is 0!
       var yyyy = today.getFullYear();
       if( dd < 10 ) {
           dd = '0' + dd;
       }
       if( mm < 10 ) {
           mm = '0' + mm;
       }
       return mm+'/'+dd+'/'+yyyy;
   },
   init: function() {
       /* Prep the reminder form */
       var form = document.getElementById('frb-rml-form');
       if ( !form ) return;
       form.rml_country.value    = mw.centralNotice.data.country;
       form.rml_language.value   = mw.centralNotice.data.uselang;
       form.rml_submitDate.value = frb.rml.getCurrentDate();
       form.rml_segment.value    = Math.floor((Math.random() * 100) + 1);
       $('#frb-rml-submit').click(function() {
           if ( mw.util.validateEmail( form.Email.value ) ) {
               frb.rml.post();
               $('.frb-rml-form, .frb-rml-link').hide();
               $('.frb-rml-ty').show();
               $('.frb').delay(3000).fadeOut( frb.fadeDuration, function() {
                   $('.frb').hide();
               });
               frb.altSetHideCookie( 'close', frb.HIDE_DURATION_RML );
               return false;
           } else {
               $('#frb-rml-email').addClass('frb-haserror').focus();
               $('.frb-error-invalidemail').show();
               return false;
           }
       });
   }

};

frb.initToolbar = function() {

   /* --- Code for sticky toolbar --- */
   $(window).scroll(function() {
       var articleLocation = $('.mw-body').offset().top;
       var headerContainerHeight = $('.header-container').height();
       var donateFormLocation = $('.frb-form').offset().top;
       // Handle .frb-header stickyness
       if ( $(window).scrollTop() >= headerContainerHeight ) {
           $('.frb-header').addClass('frb-header--sticky');
           $('.frb-conversation').css('padding-top', $('.frb-header').outerHeight() )
       } else {
           $('.frb-header').removeClass('frb-header--sticky');
           $('.frb-conversation').css('padding-top', 0);
       }
       // Handle .frb-header visibility
       if ( $(window).scrollTop() > donateFormLocation && $('.frb-header' ).css('visibility') == 'visible' ) {
           $('.frb-header').css('visibility', 'hidden');
       } else if ( $(window).scrollTop() <= donateFormLocation && $('.frb-header' ).css('visibility') == 'hidden' ) {
           $('.frb-header').css('visibility', 'visible');
       }
   });

};

$(function() {

   if ( mw.centralNotice.adminUi || !frb.supportedBrowser ) { // T262693
       return;
   }
   var language = mw.centralNotice.data.uselang;
   var country = mw.centralNotice.data.country;
   var currency = frb.getCurrency(country);
   var validAmount, validMethod, validStayInTouch;
   if ( !frb.optinRequired ) {
       validStayInTouch = 1;
   }
   var minAmount = frb.amounts.minimums[ currency ];
   var form = document.getElementById('frb-form');
   var donateFormLocation;
   mw.loader.using(['mediawiki.util']).then(function() {
       frb.rml.init();
   });
   frb.initAmountOptions();
   frb.localizeAmountOptions(frb.amounts.options7, currency, country, language, true);
   frb.localizeErrors();
   frb.storedOptions = {};
   frb.extraData = {};
   // TODO - make these all the same?
   frb.scrollDuration = frb.reduceMotion ? 0 : 600;
   frb.fadeDuration   = frb.reduceMotion ? 0 : 400;
   frb.messageDelay   = frb.reduceMotion ? 0 : 500; // Chat animation speed, for RML interaction
   frb.activateCTA = function () {
       if (validAmount && validMethod && validStayInTouch) {
           // console.log('valid - activate CTA');
           $('.frb-submit').addClass('active');
       } else {
           $('.frb-submit:not(#frb-btn-first-submit)').removeClass('active');
           // console.log('invalid - deactivate CTA');
       }
   };
   frb.setMethod = function(options, frequency) {
       if( frequency === 'no-monthly' ) {
           $('#frb-frequency-monthly').attr('disabled', true);
       } else {
           $('#frb-frequency-monthly').attr('disabled', false);
       }
       frb.storedOptions = options; // Default to credit card
   };
   $('.frb-amounts').on('input change', function() {
       frb.validateAmount();
       validAmount = 1;
       frb.updateFeeDisplay();
       frb.activateCTA();
       if ( frb.optinRequired ) {
           $('.frb-optin').show();
       }
       $('.frb-cta').fadeOut( frb.fadeDuration, function() {
           $('.frb-step-2, .frb-footer').fadeIn( frb.fadeDuration );
       });
   });
   $('.frb-methods').on('change', function() {
       $('.frb-methods').removeClass('frb-haserror');
       $('.frb-error-method').hide();
       validMethod = 1;
       frb.activateCTA();
   });
   // Opt-in interaction
   $('.frb-optin .frb-radio').on('click', function() {
       validStayInTouch = 1;
       frb.activateCTA();
       $('.frb-optin').removeClass('frb-haserror');
       $('.frb-error-optin').hide();
       if ( $('#frb-optin-no').is(':checked') ) {
           $('.frb-optin-no-prompt').removeClass('is-positive');
           if ( !$('.frb-optin-no-prompt').is(':visible') ) {
               $('.frb-optin .frb-message--typing')
                   .show()
                   .delay( frb.messageDelay )
                   .fadeOut( frb.fadeDuration, function() {
                       $('.frb-optin-no-prompt').fadeIn( frb.fadeDuration );
                   });
           }
       } else {
           $('.frb-optin-no-prompt').addClass('is-positive');
       }
   });
   /* Scroll to article option */
   $('.js-close').on('click', function(e) {
       var articleLocation = $('.mw-body').offset().top;
       $('html, body').animate( { scrollTop: articleLocation }, frb.scrollDuration );
       frb.altSetHideCookie( 'close', frb.HIDE_DURATION_SKIP );
       return false;
   });
   /* Scroll to donate option */
   $('.js-donate').on('click', function(e) {
       donateFormLocation = $('.frb-amounts').offset().top - $('.frb-header').outerHeight();
       $('html, body').animate( { scrollTop: donateFormLocation }, frb.scrollDuration );
       // Not a real "nag" but this way we can still use the standard queries
       frb.extraData.clickedNag = 1;
       return false;
   });
   var $rmlButtonParent = $('.frb-options');
   /* Remind me later (RML) form */
   /* Reveal the RML form after clicking 'Donate Later' */
   $('.js-rml').on('click', function(e) {
       var rmlLocation = $('.frb-rml-wrapper').offset().top;
       e.stopPropagation();
       $('.frb-footer').show();
       if ( $(this).parent().parent().hasClass('frb-header') ) {
           // Add '_nag' to RML source value for tracking
           $('#frb-rml-form input[name="rml_source"]').val('{{{banner}}}_nag');
           $('html, body').animate( { scrollTop: rmlLocation }, frb.scrollDuration );
       }
       if ( $('.frb-rml-form').css('display') === 'none' ) {
           $('.frb-rml-wrapper .frb-message--typing')
               .show()
               .delay( frb.messageDelay )
               .fadeOut( frb.fadeDuration, function () {
                   $('.frb-rml-form').fadeIn(function () {
                       $('#frb-rml-email').focus();
                   });
               });
       }
       return false;
   });
   /* Other amount field */
   $('.frb-button--other').on('click keypress', function(e) {
       if ( e.which === 13 || e.type === 'click' ) {
           document.getElementById('frb-input-other').checked = true;
           frb.updateFeeDisplay();
           $('.frb-other-input').focus();
       }
   });
   /* Other amount field focus styles */
   $('.frb-other-input')
       .focus(function() {
           $('.frb-button--other').addClass('frb-button--is-focused');
       })
       .blur(function() {
           $('.frb-button--other').removeClass('frb-button--is-focused');
       });
   frb.updateUpsellAsk = function(isOtherAmountStep) {
       var amount, feeAmount, upsellAmount,
           list = frb.amounts.monthlySuggest[currency] || frb.amounts.monthlySuggest.USD;
       // If user is on third step (write a different amount) then get monthly amount if not, the the first form amount
       if (isOtherAmountStep !== undefined) {
           amount = frb.getMonthlyAmount();
       } else {
           amount = frb.getAmount(form);
       }
       // If PTF is checked when we need to calculate the fee for that amount
       if ( $('#frb-ptf-checkbox').prop('checked') ) {
           amount = amount + frb.calculateFee(amount);
       }
       for (var i = list.length - 1; i >= 0; i--) {
           if ( amount <= list[i][0] ) {
               upsellAmount = list[i][1];
           }
       }
       // If user is in the upsell (second step) then the form.otherMonthlyAmount.value will be updated with the upsellAmount calculated
       if (isOtherAmountStep === undefined) {
           form.otherMonthlyAmount.value = upsellAmount;
       }
       // A formatted value will be returned
       var upsellAmountFormatted = frb.formatCurrency(currency, upsellAmount, language);
       // The value of the amount will be updated only if the user is in the upsell (second step)
       if (isOtherAmountStep === undefined) {
           $('.frb-upsell-ask').text(upsellAmountFormatted);
       }
   };
   // Pre-upsell submit button
   $('#frb-donate').on('click', function(e) {
       frb.updateUpsellAsk();
       // Only do monthly convert if initial selection is one-time, payment method supports monthly, upsell value is not 0 (meaning skip), and payment method isn't credit card.
       if ( frb.getRecurring(document.getElementById('frb-form')) ||
            !frb.shouldShowRecurring( frb.storedOptions, mw.centralNotice.data.country ) ||
            form.otherMonthlyAmount.value == 0 ||
            frb.storedOptions.method == 'cc' ) {
           frb.submitForm(frb.storedOptions);
       } else if ( frb.validateForm(frb.storedOptions) ) {
           $('.frb-step-upsell, .frb-back-step, .frb-mask').fadeIn( frb.fadeDuration );
       } else {
           frb.extraData.validateError = 1;
       }
       return false;
   });
   // Go back to main step
   $('.frb-back-step').on('click', function(e) {
       $('.frb-mask, .frb-step-upsell').fadeOut( frb.fadeDuration );
       return false;
   });
   // Donate monthly other amount
   $('.frb-monthly-diff-amt-link').on('click', function(e) {
       form.otherMonthlyAmount.value = ;
       validAmount = 0;
       frb.activateCTA();
       frb.toggleMonthly(true);
       $('.frb-upsell, .frb-monthly-buttons').hide();
       $('.frb-monthly-diff-amt, .frb-back').show();
       return false;
   });
   // Go back from diff amount
   $('.frb-back').on('click', function(e) {
       form.otherMonthlyAmount.value = ;
       frb.updateUpsellAsk();
       validAmount = 1;
       frb.activateCTA();
       frb.toggleMonthly(false);
       $('.frb-monthly-diff-amt, .frb-back').hide();
       $('.frb-upsell, .frb-monthly-buttons').show();
       return false;
   });
   // Validate monthly other amount
   $('#frb-amt-monthly-other-input').on('input change', function(e) {
       if ( frb.validateMonthlyAmount() ) {
           validAmount = 1;
           frb.activateCTA();
           frb.updateUpsellAsk(true);
       } else {
           validAmount = 0;
       }
   });
   frb.getMonthlyAmount = function() {
       var amount = null;
       // Check the "monthly other" amount box
       if (form.otherMonthlyAmount.value !== ) {
           var otherMonthlyAmount = form.otherMonthlyAmount.value;
           otherMonthlyAmount = otherMonthlyAmount.replace(/[,.](\d)$/, ':$10');
           otherMonthlyAmount = otherMonthlyAmount.replace(/[,.](\d)(\d)$/, ':$1$2');
           otherMonthlyAmount = otherMonthlyAmount.replace(/[$£€¥,.]/g, );
           otherMonthlyAmount = otherMonthlyAmount.replace(/:/, '.');
           amount = otherMonthlyAmount;
       }
       amount = parseFloat(amount);
       if ( isNaN(amount) ) {
           return 0;
       } else {
           var totalMonthlyAmountFormatted = frb.formatCurrency(currency, amount, language);
           $('.frb-monthly-total').text(totalMonthlyAmountFormatted);
           return amount;
       }
   };
   frb.validateMonthlyAmount = function() {
       var amount = frb.getMonthlyAmount();
       var currency  = frb.getCurrency( mw.centralNotice.data.country );
       var minAmount = frb.amounts.minimums[ currency ];
       if ( amount === null || isNaN(amount) || amount <= 0 || amount < minAmount ) {
           $('.frb-error-bigamount').hide();
           $('.frb-error-smallamount').show();
           return false;
       } else if ( amount > frb.maxUSD * minAmount ) {
           $('.frb-error-bigamount').show();
           return false;
       } else {
           $('.frb-error-smallamount, .frb-error-bigamount').hide();
           return true;
       }
   };
   frb.submitMonthly = function() {
       frb.extraData.monthlyUpsell = 1;
       frb.extraData.originalAmt = frb.getAmount().toString();
       frb.toggleMonthly(true);
       document.getElementById('frb-input-other').checked = true;
       document.getElementById('frb-ptf-checkbox').checked = false;
       form.otherAmount.value = form.otherMonthlyAmount.value;
       frb.submitForm(frb.storedOptions);
   }
   // Submit form
   $('#frb-monthly-donate-yes').on('click', function(e) {
       frb.submitMonthly();
       return false;
   });
   $('#frb-monthly-donate-no').on('click', function(e) {
       frb.submitForm(frb.storedOptions);
       return false;
   });
   $('#frb-donate-monthly-other').on('click', function (e) {
       if (frb.validateMonthlyAmount()) {
           frb.submitMonthly();
       }
       return false;
   });


   // Open already donated modal
   $('.modal-open').on('click', function(e) {
       $('.modal').show()
   })
   // Close already donated modal
   $('.modal-close').on('click', function(e) {
       closeModal(e)
   })


   $('.modal').click(function(e) {
       const modalContainer = $('.modal-container');
       if (!modalContainer.is(e._target) && modalContainer.has(e._target).length === 0) {
           closeModal(e)
       }
   })


   function closeModal(e) {
       $('.modal').hide()
       if (e._target.name == 'frb-hide-appeals-button') {
           $('.frb').hide();
           frb.altSetHideCookie( 'donate close', 604800 );
       }
       return false;
   }
   if ( frb.shouldShowBanner() ) {
       frb.show();
       frb.initToolbar();
   }

}); </script>

  NODES
3d 6
chat 2
HOME 1
Idea 10
idea 10
Intern 4
iOS 1
Javascript 1
languages 5
mac 1
Note 7
os 86
text 85
todo 9
Users 7
visual 4
web 6