Files @ 732bf3b4c8af
Branch filter:

Location: website/www/conservancy/static/supporter-page.js - annotation

732bf3b4c8af 6.7 KiB application/javascript Show Source Show as Raw Download as Raw
bkuhn
Not so high.
01eb8c80c8c1
01eb8c80c8c1
342590123ff5
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
60d0a06e2558
60d0a06e2558
60d0a06e2558
60d0a06e2558
f3b930579f1b
60d0a06e2558
f3b930579f1b
f3b930579f1b
8e22371f1931
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
01eb8c80c8c1
eea08767d361
9a4c92352d9a
7fec31ce8aef
1574b2dc3764
1574b2dc3764
7fec31ce8aef
9a4c92352d9a
1574b2dc3764
1574b2dc3764
7fec31ce8aef
1574b2dc3764
1574b2dc3764
7fec31ce8aef
7fec31ce8aef
674261e0f0c2
674261e0f0c2
674261e0f0c2
674261e0f0c2
8c3ecd347abd
674261e0f0c2
674261e0f0c2
86e780340a2b
86e780340a2b
674261e0f0c2
8c3ecd347abd
9bfb5e10dec2
9bfb5e10dec2
8c3ecd347abd
b2c18cc59e52
b2c18cc59e52
b2c18cc59e52
e0f0ee820fe3
e0f0ee820fe3
9bfb5e10dec2
9bfb5e10dec2
9bfb5e10dec2
090fb9f268a0
9bfb5e10dec2
9bfb5e10dec2
9bfb5e10dec2
9bfb5e10dec2
9bfb5e10dec2
b90413809f26
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
090fb9f268a0
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
2d96daee903c
090fb9f268a0
86e780340a2b
86e780340a2b
86e780340a2b
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
c41a897be2ce
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
44301d386ba0
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
b90413809f26
/* Copyright (C) 2012-2013 Denver Gingerich, 
** Copyright (C) 2013-2014 Bradley M. Kuhn.
** License: GPLv3-or-later
**  Find a copy of GPL at https://sfconservancy.org/GPLv3
*/

$(document).ready(function() {
    var goal  = $('span#fundraiser-goal').text();
    var soFar = $('span#fundraiser-so-far').text();
    var noCommaGoal = goal.replace(/,/g, "");
    var noCommaSoFar = soFar.replace(/,/g, "");
    var percentage = (parseFloat(noCommaSoFar) / parseFloat(noCommaGoal)) * 100;

    $('span#fundraiser-percentage').text(percentage.toFixed(2) + "%");
    $("#progressbar").progressbar({ value:  percentage });

    $('.toggle-content').hide();

    $('.toggle-control')
     .addClass('clickable')
     .bind('click', function() {
        var $control = $(this);
        var $parent = $control.parents('.toggle-unit');

        $parent.toggleClass('expanded');
        $parent.find('.toggle-content').slideToggle();

        // if control has HTML5 data attributes, use to update text
        if ($parent.hasClass('expanded')) {
            $control.html($control.attr('data-expanded-text'));
        } else {
            $control.html($control.attr('data-text'));
        }
    });
    $('a.donate-now')
      .addClass('clickable')
      .bind('click', function() {
        var $control = $('#donate-box');

        $control.toggleClass('expanded');
        $control.find('.toggle-content').slideUp("slow");
        $control.find('.toggle-content').slideDown("slow");
    });
    $(".t-shirt-size-selector").hide();
    $('input[name=on0]:radio').change(function() {
        var input=$(this);
        var tShirtSelector = input.parent().children('.t-shirt-size-selector')
        var noShippingSelector = input.parent().children('input#no_shipping');
        var value = input.val();
        if (value == "wantGiftYes") {
            tShirtSelector.show();
            noShippingSelector.val("2");
        } else {
            tShirtSelector.hide();
            noShippingSelector.val("0");
        }
    });

    // Forms start in "invalid" form, with the errors shown, so that
    // non-Javascript users see the errors by default and know what they must
    // enter.  The following two lines correct that.
    $('*#amount').addClass("valid");
    $('.supporter-form-inputs .form-error-show')
        .removeClass('form-error-show').addClass('form-error');
    $('.dinner-form-inputs .form-error-show')
        .removeClass('form-error-show').addClass('form-error');

    $('*#amount').on('input', function() {
        var input=$(this);
        var value = input.val();
        var errorElement=$("span#error", input.parent());
        var noCommaValue = value;
        noCommaValue = value.replace(/,/g, "");
        var re = /^((\d{1,3}(,?\d{3})*?(\.\d{0,2})?)|\d+(\.\d{0,2})?)$/;
        var isValid = ( re.test(value) &&
                        parseInt(noCommaValue) >= parseInt(input.attr("minimum")));
        if (isValid)  {
           input.removeClass("invalid").addClass("valid");
           errorElement.removeClass("form-error-show").addClass("form-error");
           $("#form-correction-needed").removeClass("form-error-show").addClass("form-error");
        }
        else {
            input.removeClass("valid").addClass("invalid");
            errorElement.removeClass("form-error").addClass("form-error-show");
        }
    });
    var validateFormAtSubmission = function(element, event) {
            var valid = element.hasClass("valid");
            if (! valid) {
                $("#form-correction-needed").removeClass("form-error").addClass("form-error-show")
                                        .css("font-weight", "bold").css("font-size", "150%");
	        event.preventDefault();
            } else {
                $("#form-correction-needed").removeClass("form-error-show").addClass("form-error");
            }
    };
    $(".supporter-form-submit#monthly").click(function (event) {
        validateFormAtSubmission($(".supporter-form#monthly input#amount"), event);
    });
    $(".supporter-form-submit#annual").click(function (event) {
        validateFormAtSubmission($(".supporter-form#annual input#amount"), event);
    });
    $(".dinner-form-submit").click(function (event) {
        validateFormAtSubmission($(".dinner-form input#amount"), event);
    });
    /* Handle toggling of annual/monthly form selections */
    $('.supporter-type-selection#monthly').hide();
    $('#annualSelector').css("font-weight", "bold").css("font-size", "127%");

    $("a[href$='monthly']").bind('click', function() {
        $('.supporter-type-selection#annual').hide();
        $('.supporter-type-selection#monthly').show();
        $('#monthlySelector').css("font-weight", "bold").css("font-size", "127%");
        $('#annualSelector').css("font-weight", "normal").css("font-size", "125%");
        $("#form-correction-needed").removeClass("form-error-show").addClass("form-error");
    });
    $("a[href$='annual']").bind('click', function() {
        $('.supporter-type-selection#annual').show();
        $('.supporter-type-selection#monthly').hide();
        $('#annualSelector').css("font-weight", "bold").css("font-size", "127%");
        $('#monthlySelector').css("font-weight", "normal").css("font-size", "125%");
    });
    $( ".footnote-mark" ).tooltip({
        items: "a",
        hide: { duration: 5000 },
        position: {
            my: "center bottom-20",
            at: "center left",
            using: function( position, feedback ) {
                $( this ).css( position );
                $( "<div>" )
                    .addClass( "arrow" )
                    .addClass( feedback.vertical )
                    .addClass( feedback.horizontal )
                    .appendTo( this );
            }
        },
        content: function() {
            return $('.footnote-1-text').text();
        }
    });
});

$(window).load(function () {
    verifySelctionCorrectOnPageLoad = function() {
        var ourURL = document.URL;
        if (ourURL.search("#monthly") > 0) {
            $('.supporter-type-selection#annual').hide();
            $('.supporter-type-selection#monthly').show();
            $('#monthlySelector').css("font-weight", "bold").css("font-size", "127%");
            $('#annualSelector').css("font-weight", "normal").css("font-size", "125%");
        }
        if (ourURL.search("#annual") > 0) {
            $('.supporter-type-selection#monthly').hide();
            $('.supporter-type-selection#annual').show();
            $('#annualSelector').css("font-weight", "bold").css("font-size", "127%");
            $('#monthlySelector').css("font-weight", "normal").css("font-size", "125%");
        }
    }
    if (location.hash) {
        setTimeout(verifySelctionCorrectOnPageLoad, 1);
    }
    window.addEventListener("hashchange", verifySelctionCorrectOnPageLoad);
});