PATH:
home
/
letacommog
/
rdvenunclick.fr1
/
wp-content
/
plugins
/
weforms
/
assets
/
js
/* assets/wpuf/js/frontend-form.js */ ;(function($, window) { $.fn.listautowidth = function() { return this.each(function() { var w = $(this).width(); var liw = w / $(this).children('li').length; $(this).children('li').each(function(){ var s = $(this).outerWidth(true)-$(this).width(); $(this).width(liw-s); }); }); }; window.WP_User_Frontend = { init: function() { //enable multistep this.enableMultistep(this); // clone and remove repeated field $('.wpuf-form').on('click', 'img.wpuf-clone-field', this.cloneField); $('.wpuf-form').on('click', 'img.wpuf-remove-field', this.removeField); $('.wpuf-form').on('click', 'a.wpuf-delete-avatar', this.deleteAvatar); $('.wpuf-form').on('click', 'a#wpuf-post-draft', this.draftPost); $('.wpuf-form').on('click', 'button#wpuf-account-update-profile', this.account_update_profile); $('.wpuf-form-add').on('submit', this.formSubmit); $('form#post').on('submit', this.adminPostSubmit); // $( '.wpuf-form').on('keyup', '#pass1', this.check_pass_strength ); // refresh pluploads on each step change (multistep form) $('.wpuf-form').on('step-change-fieldset', function(event, number, step) { if ( wpuf_plupload_items.length ) { for (var i = wpuf_plupload_items.length - 1; i >= 0; i--) { wpuf_plupload_items[i].refresh(); } } if ( wpuf_map_items.length ) { for (var i = wpuf_map_items.length - 1; i >= 0; i--) { google.maps.event.trigger(wpuf_map_items[i].map, 'resize'); wpuf_map_items[i].map.setCenter(wpuf_map_items[i].center); } } }); this.ajaxCategory(); // image insert // this.insertImage(); //comfirmation alert for canceling subscription $( ':submit[name="wpuf_user_subscription_cancel"]').click(function(e){ e.preventDefault(); swal({ text: wpuf_frontend.cancelSubMsg, type: 'warning', showCancelButton: true, confirmButtonColor: '#d54e21', confirmButtonText: wpuf_frontend.delete_it, cancelButtonText: wpuf_frontend.cancel_it, confirmButtonClass: 'btn btn-success', cancelButtonClass: 'btn btn-danger', }).then(function ( isConfirmed ) { if ( !isConfirmed ) { return false; } $('#wpuf_cancel_subscription').submit(); }); }); }, check_pass_strength : function() { var pass1 = $('#pass1').val(), strength; $('#pass-strength-result').show(); $('#pass-strength-result').removeClass('short bad good strong'); if ( ! pass1 ) { $('#pass-strength-result').html( ' ' ); $('#pass-strength-result').hide(); return; } if ( typeof wp.passwordStrength != 'undefined' ) { strength = wp.passwordStrength.meter( pass1, wp.passwordStrength.userInputBlacklist(), pass1 ); switch ( strength ) { case 2: $('#pass-strength-result').addClass('bad').html( pwsL10n.bad ); break; case 3: $('#pass-strength-result').addClass('good').html( pwsL10n.good ); break; case 4: $('#pass-strength-result').addClass('strong').html( pwsL10n.strong ); break; case 5: $('#pass-strength-result').addClass('short').html( pwsL10n.mismatch ); break; default: $('#pass-strength-result').addClass('short').html( pwsL10n['short'] ); } } }, enableMultistep: function(o) { var js_obj = this; var step_number = 0; var progressbar_type = $(':hidden[name="wpuf_multistep_type"]').val(); if ( progressbar_type == null ) { return; } // first fieldset doesn't have prev button, // last fieldset doesn't have next button $('fieldset.wpuf-multistep-fieldset').find('.wpuf-multistep-prev-btn').first().remove(); $('fieldset.wpuf-multistep-fieldset').find('.wpuf-multistep-next-btn').last().remove(); // at first first fieldset will be shown, and others will be hidden $('.wpuf-form fieldset').removeClass('field-active').first().addClass('field-active'); if ( progressbar_type == 'progressive' && $('.wpuf-form .wpuf-multistep-fieldset').length != 0 ) { var firstLegend = $('fieldset.wpuf-multistep-fieldset legend').first(); $('.wpuf-multistep-progressbar').html('<div class="wpuf-progress-percentage"></div>' ); var progressbar = $( ".wpuf-multistep-progressbar" ), progressLabel = $( ".wpuf-progress-percentage" ); $( ".wpuf-multistep-progressbar" ).progressbar({ change: function() { progressLabel.text( progressbar.progressbar( "value" ) + "%" ); } }); $('.wpuf-multistep-fieldset legend').hide(); } else { $('.wpuf-form').each(function() { var this_obj = $(this); var progressbar = $('.wpuf-multistep-progressbar', this_obj); var nav = ''; progressbar.addClass('wizard-steps'); nav += '<ul class="wpuf-step-wizard">'; $('.wpuf-multistep-fieldset', this).each(function(){ nav += '<li>' + $.trim( $('legend', this).text() ) + '</li>'; $('legend', this).hide(); }); nav += '</ul>'; progressbar.append( nav ); $('.wpuf-step-wizard li', progressbar).first().addClass('active-step'); $('.wpuf-step-wizard', progressbar).listautowidth(); }); } this.change_fieldset(step_number, progressbar_type); $('fieldset .wpuf-multistep-prev-btn, fieldset .wpuf-multistep-next-btn').click(function(e) { // js_obj.formSubmit(); if ( $(this).hasClass('wpuf-multistep-next-btn') ) { var result = js_obj.formStepCheck( '', $(this).closest('fieldset') ); if ( result != false ) { o.change_fieldset(++step_number,progressbar_type); } } else if ( $(this).hasClass('wpuf-multistep-prev-btn') ) { o.change_fieldset( --step_number,progressbar_type ); } var formDiv = $( "form.wpuf-form-add" ); var position = formDiv.offset().top; // this changes the scrolling behavior to "smooth" window.scrollTo({ top: position - 32, behavior: "smooth" }); return false; }); }, change_fieldset: function(step_number, progressbar_type) { var current_step = $('fieldset.wpuf-multistep-fieldset').eq(step_number); $('fieldset.wpuf-multistep-fieldset').removeClass('field-active').eq(step_number).addClass('field-active'); $('.wpuf-step-wizard li').each(function(){ if ( $(this).index() <= step_number ){ progressbar_type == 'step_by_step'? $(this).addClass('passed-wpuf-ms-bar') : $('.wpuf-ps-bar',this).addClass('passed-wpuf-ms-bar'); } else { progressbar_type == 'step_by_step'? $(this).removeClass('passed-wpuf-ms-bar') : $('.wpuf-ps-bar',this).removeClass('passed-wpuf-ms-bar'); } }); $('.wpuf-step-wizard li').removeClass('wpuf-ms-bar-active active-step completed-step'); $('.passed-wpuf-ms-bar').addClass('completed-step').last().addClass('wpuf-ms-bar-active'); $('.wpuf-ms-bar-active').addClass('active-step'); var legend = $('fieldset.wpuf-multistep-fieldset').eq(step_number).find('legend').text(); legend = $.trim( legend ); if ( progressbar_type == 'progressive' && $('.wpuf-form .wpuf-multistep-fieldset').length != 0 ) { var progress_percent = ( step_number + 1 ) * 100 / $('fieldset.wpuf-multistep-fieldset').length ; var progress_percent = Number( progress_percent.toFixed(2) ); $( ".wpuf-multistep-progressbar" ).progressbar({value: progress_percent }); $( '.wpuf-progress-percentage' ).text( legend + ' (' + progress_percent + '%)'); } // trigger a change event $('.wpuf-form').trigger('step-change-fieldset', [ step_number, current_step ]); }, ajaxCategory: function () { var el = '.cat-ajax', wrap = '.category-wrap'; $(wrap).on('change', el, function(){ currentLevel = parseInt( $(this).parent().attr('level') ); WP_User_Frontend.getChildCats( $(this), 'lvl', currentLevel+1, wrap, 'category'); }); }, getChildCats: function (dropdown, result_div, level, wrap_div, taxonomy) { cat = $(dropdown).val(); results_div = result_div + level; taxonomy = typeof taxonomy !== 'undefined' ? taxonomy : 'category'; field_attr = $(dropdown).siblings('span').data('taxonomy'); $.ajax({ type: 'post', url: wpuf_frontend.ajaxurl, data: { action: 'wpuf_get_child_cat', catID: cat, nonce: wpuf_frontend.nonce, field_attr: field_attr }, beforeSend: function() { $(dropdown).parent().parent().next('.loading').addClass('wpuf-loading'); }, complete: function() { $(dropdown).parent().parent().next('.loading').removeClass('wpuf-loading'); }, success: function(html) { //console.log( html ); return; $(dropdown).parent().nextAll().each(function(){ $(this).remove(); }); if(html != "") { $(dropdown).parent().addClass('hasChild').parent().append('<div id="'+result_div+level+'" level="'+level+'"></div>'); dropdown.parent().parent().find('#'+results_div).html(html).slideDown('fast'); } } }); }, cloneField: function(e) { e.preventDefault(); var $div = $(this).closest('tr'); var $clone = $div.clone(); // console.log($clone); //clear the inputs $clone.find('input').val(''); $clone.find(':checked').attr('checked', ''); $div.after($clone); }, removeField: function() { //check if it's the only item var $parent = $(this).closest('tr'); var items = $parent.siblings().andSelf().length; if( items > 1 ) { $parent.remove(); } }, adminPostSubmit: function(e) { e.preventDefault(); var form = $(this), form_data = WP_User_Frontend.validateForm(form); if (form_data) { return true; } }, draftPost: function (e) { e.preventDefault(); var self = $(this), form = $(this).closest('form'), form_data = form.serialize() + '&action=wpuf_draft_post', post_id = form.find('input[type="hidden"][name="post_id"]').val(); var rich_texts = [], val; // grab rich texts from tinyMCE $('.wpuf-rich-validation').each(function (index, item) { var item = $(item); var editor_id = item.data('id'); var item_name = item.data('name'); var val = $.trim( tinyMCE.get(editor_id).getContent() ); rich_texts.push(item_name + '=' + encodeURIComponent( val ) ); }); // append them to the form var form_data = form_data + '&' + rich_texts.join('&'); self.after(' <span class="wpuf-loading"></span>'); $.post(wpuf_frontend.ajaxurl, form_data, function(res) { // console.log(res, post_id); if ( typeof post_id === 'undefined') { var html = '<input type="hidden" name="post_id" value="' + res.post_id +'">'; html += '<input type="hidden" name="post_date" value="' + res.date +'">'; html += '<input type="hidden" name="post_author" value="' + res.post_author +'">'; html += '<input type="hidden" name="comment_status" value="' + res.comment_status +'">'; form.append( html ); } self.next('span.wpuf-loading').remove(); self.after('<span class="wpuf-draft-saved"> Post Saved</span>'); $('.wpuf-draft-saved').delay(2500).fadeOut('fast', function(){ $(this).remove(); }); }) }, // Frontend account dashboard update profile account_update_profile: function (e) { e.preventDefault(); var form = $(this).closest('form'); $.post(wpuf_frontend.ajaxurl, form.serialize(), function (res) { if (res.success) { form.find('.wpuf-error').hide(); form.find('.wpuf-success').show(); } else { form.find('.wpuf-success').hide(); form.find('.wpuf-error').show(); form.find('.wpuf-error').text(res.data); } }); }, formStepCheck : function(e,fieldset) { var form = fieldset, submitButton = form.find('input[type=submit]'); form_data = WP_User_Frontend.validateForm(form); if ( form_data == false ) { WP_User_Frontend.addErrorNotice( self, 'bottom' ); } return form_data; }, formSubmit: function(e) { e.preventDefault(); var form = $(this), submitButton = form.find('input[type=submit]') form_data = WP_User_Frontend.validateForm(form); if (form_data) { // send the request form.find('li.wpuf-submit').append('<span class="wpuf-loading"></span>'); submitButton.attr('disabled', 'disabled').addClass('button-primary-disabled'); $.post(wpuf_frontend.ajaxurl, form_data, function(res) { // var res = $.parseJSON(res); if ( res.success) { // enable external plugins to use events $('body').trigger('wpuf:postform:success', res); if ( res.show_message == true) { form.before( '<div class="wpuf-success">' + res.message + '</div>'); form.slideUp( 'fast', function() { form.remove(); }); //focus $('html, body').animate({ scrollTop: $('.wpuf-success').offset().top - 100 }, 'fast'); } else { window.location = res.redirect_to; } } else { if ( typeof res.type !== 'undefined' && res.type === 'login' ) { if ( confirm(res.error) ) { window.location = res.redirect_to; } else { submitButton.removeAttr('disabled'); submitButton.removeClass('button-primary-disabled'); form.find('span.wpuf-loading').remove(); } return; } else { if ( form.find('.g-recaptcha').length > 0 ) { grecaptcha.reset(); } swal({ html: res.error, type: 'warning', showCancelButton: false, confirmButtonColor: '#d54e21', confirmButtonText: 'OK', cancelButtonClass: 'btn btn-danger', }); } submitButton.removeAttr('disabled'); } submitButton.removeClass('button-primary-disabled'); form.find('span.wpuf-loading').remove(); }); } }, validateForm: function( self ) { var temp, temp_val = '', error = false, error_items = []; error_type = ''; // remove all initial errors if any WP_User_Frontend.removeErrors(self); WP_User_Frontend.removeErrorNotice(self); // ===== Validate: Text and Textarea ======== var required = self.find('[data-required="yes"]:visible'); required.each(function(i, item) { // temp_val = $.trim($(item).val()); // console.log( $(item).data('type') ); var data_type = $(item).data('type') val = ''; switch(data_type) { case 'rich': var name = $(item).data('id') val = $.trim( tinyMCE.get(name).getContent() ); if ( val === '') { error = true; // make it warn collor WP_User_Frontend.markError(item); } break; case 'textarea': case 'text': val = $.trim( $(item).val() ); if ( val === '') { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } break; case 'password': case 'confirm_password': var hasRepeat = $(item).data('repeat'); val = $.trim( $(item).val() ); if ( val === '') { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } if ( hasRepeat ) { var repeatItem = $('[data-type="confirm_password"]').eq(0);; if ( repeatItem.val() != val ) { error = true; error_type = 'mismatch'; WP_User_Frontend.markError( repeatItem, error_type ); } } break; case 'select': val = $(item).val(); // console.log(val); if ( !val || val === '-1' ) { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } break; case 'multiselect': val = $(item).val(); if ( val === null || val.length === 0 ) { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } break; case 'tax-checkbox': var length = $(item).children().find('input:checked').length; if ( !length ) { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } break; case 'radio': var length = $(item).find('input:checked').length; if ( !length ) { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } break; case 'file': var length = $(item).find('ul').children().length; if ( !length ) { error = true; error_type = 'required'; // make it warn collor WP_User_Frontend.markError( item, error_type ); } break; case 'email': var val = $(item).val(); if ( val !== '' ) { //run the validation if( !WP_User_Frontend.isValidEmail( val ) ) { error = true; error_type = 'validation'; WP_User_Frontend.markError( item, error_type ); } } else if( val === '' ) { error = true; error_type = 'required'; WP_User_Frontend.markError( item, error_type ); } break; case 'url': var val = $(item).val(); if ( val !== '' ) { //run the validation if( !WP_User_Frontend.isValidURL( val ) ) { error = true; error_type = 'validation'; WP_User_Frontend.markError( item, error_type ); } } break; }; }); //check Google Map is required var map_required = self.find('[data-required="yes"][name="google_map"]'); if ( map_required ) { var val = $(map_required).val(); if ( val == ',' ) { error = true; error_type = 'required'; WP_User_Frontend.markError( map_required, error_type ); } } // if already some error found, bail out if (error) { // add error notice WP_User_Frontend.addErrorNotice(self,'end'); return false; } var form_data = self.serialize(), rich_texts = []; // grab rich texts from tinyMCE $('.wpuf-rich-validation', self).each(function (index, item) { var item = $(item); var editor_id = item.data('id'); var item_name = item.data('name'); var val = $.trim( tinyMCE.get(editor_id).getContent() ); rich_texts.push(item_name + '=' + encodeURIComponent( val ) ); }); // append them to the form var form_data = form_data + '&' + rich_texts.join('&'); return form_data; }, /** * * @param form * @param position (value = bottom or end) end if form is onepare, bottom, if form is multistep */ addErrorNotice: function( form, position ) { if( position == 'bottom' ) { $('.wpuf-multistep-fieldset:visible').append('<div class="wpuf-errors">' + wpuf_frontend.error_message + '</div>'); } else { $(form).find('li.wpuf-submit').append('<div class="wpuf-errors">' + wpuf_frontend.error_message + '</div>'); } }, removeErrorNotice: function(form) { $(form).find('.wpuf-errors').remove(); }, markError: function(item, error_type) { var error_string = ''; $(item).closest('li').addClass('has-error'); if ( error_type ) { error_string = $(item).closest('li').data('label'); switch ( error_type ) { case 'required' : error_string = error_string + ' ' + error_str_obj[error_type]; break; case 'mismatch' : error_string = error_string + ' ' +error_str_obj[error_type]; break; case 'validation' : error_string = error_string + ' ' + error_str_obj[error_type]; break } $(item).siblings('.wpuf-error-msg').remove(); $(item).after('<div class="wpuf-error-msg">'+ error_string +'</div>') } $(item).focus(); }, removeErrors: function(item) { $(item).find('.has-error').removeClass('has-error'); $('.wpuf-error-msg').remove(); }, isValidEmail: function( email ) { var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i); return pattern.test(email); }, isValidURL: function(url) { var urlregex = new RegExp("^(http:\/\/www.|https:\/\/www.|ftp:\/\/www.|www.|http:\/\/|https:\/\/){1}([0-9A-Za-z]+\.)"); return urlregex.test(url); }, insertImage: function(button, form_id) { var container = 'wpuf-insert-image-container'; if ( ! $( '#' + button ).length ) { return; }; var imageUploader = new plupload.Uploader({ runtimes: 'html5,html4', browse_button: button, container: container, multipart: true, multipart_params: { action: 'wpuf_insert_image', form_id: $( '#' + button ).data('form_id') }, multiple_queues: false, multi_selection: false, urlstream_upload: true, file_data_name: 'wpuf_file', max_file_size: '2mb', url: wpuf_frontend_upload.plupload.url, flash_swf_url: wpuf_frontend_upload.flash_swf_url, filters: [{ title: 'Allowed Files', extensions: 'jpg,jpeg,gif,png,bmp' }] }); imageUploader.bind('Init', function(up, params) { // console.log("Current runtime environment: " + params.runtime); }); imageUploader.bind('FilesAdded', function(up, files) { var $container = $('#' + container); $.each(files, function(i, file) { $container.append( '<div class="upload-item" id="' + file.id + '"><div class="progress progress-striped active"><div class="bar"></div></div></div>'); }); up.refresh(); up.start(); }); imageUploader.bind('QueueChanged', function (uploader) { imageUploader.start(); }); imageUploader.bind('UploadProgress', function(up, file) { var item = $('#' + file.id); $('.bar', item).css({ width: file.percent + '%' }); $('.percent', item).html( file.percent + '%' ); }); imageUploader.bind('Error', function(up, error) { alert('Error #' + error.code + ': ' + error.message); }); imageUploader.bind('FileUploaded', function(up, file, response) { $('#' + file.id).remove(); if ( response.response !== 'error' ) { var success = false; if ( typeof tinyMCE !== 'undefined' ) { if ( typeof tinyMCE.execInstanceCommand !== 'function' ) { // tinyMCE 4.x var mce = tinyMCE.get( 'post_content_' + form_id ); if ( mce !== null ) { mce.insertContent(response.response); } } else { // tinyMCE 3.x tinyMCE.execInstanceCommand( 'post_content_' + form_id, 'mceInsertContent', false, response.response); } } // insert failed to the edit, perhaps insert into textarea var post_content = $('#post_content_' + form_id); post_content.val( post_content.val() + response.response ); } else { alert('Something went wrong'); } }); imageUploader.init(); }, deleteAvatar: function(e) { e.preventDefault(); if ( confirm( $(this).data('confirm') ) ) { $.post(wpuf_frontend.ajaxurl, {action: 'wpuf_delete_avatar', _wpnonce: wpuf_frontend.nonce}, function() { $(e.target).parent().remove(); $('[id^=wpuf-avatar]').css("display", ""); }); } }, editorLimit: { bind: function(limit, field, type) { if ( type === 'no' ) { // it's a textarea $('textarea#' + field).keydown( function(event) { WP_User_Frontend.editorLimit.textLimit.call(this, event, limit); }); $('input#' + field).keydown( function(event) { WP_User_Frontend.editorLimit.textLimit.call(this, event, limit); }); $('textarea#' + field).on('paste', function(event) { var self = $(this); setTimeout(function() { WP_User_Frontend.editorLimit.textLimit.call(self, event, limit); }, 100); }); $('input#' + field).on('paste', function(event) { var self = $(this); setTimeout(function() { WP_User_Frontend.editorLimit.textLimit.call(self, event, limit); }, 100); }); } else { // it's a rich textarea setTimeout(function () { tinyMCE.get(field).onKeyDown.add(function(ed, event) { WP_User_Frontend.editorLimit.tinymce.onKeyDown(ed, event, limit); } ); tinyMCE.get(field).onPaste.add(function(ed, event) { setTimeout(function() { WP_User_Frontend.editorLimit.tinymce.onPaste(ed, event, limit); }, 100); }); }, 1000); } }, tinymce: { getStats: function(ed) { var body = ed.getBody(), text = tinymce.trim(body.innerText || body.textContent); return { chars: text.length, words: text.split(/[\w\u2019\'-]+/).length }; }, onKeyDown: function(ed, event, limit) { var numWords = WP_User_Frontend.editorLimit.tinymce.getStats(ed).words - 1; limit ? $('.mce-path-item.mce-last', ed.container).html('Word Limit : '+ numWords +'/'+limit):''; if ( limit && numWords > limit ) { WP_User_Frontend.editorLimit.blockTyping(event); jQuery('.mce-path-item.mce-last', ed.container).html( wpuf_frontend.word_limit ); } }, onPaste: function(ed, event, limit) { var editorContent = ed.getContent().split(' ').slice(0, limit).join(' '); // Let TinyMCE do the heavy lifting for inserting that content into the editor. // ed.insertContent(content); //ed.execCommand('mceInsertContent', false, content); ed.setContent(editorContent); WP_User_Frontend.editorLimit.make_media_embed_code(editorContent, ed); } }, textLimit: function(event, limit) { var self = $(this), content = self.val().split(' '); if ( limit && content.length > limit ) { self.closest('.wpuf-fields').find('span.wpuf-wordlimit-message').html( wpuf_frontend.word_limit ); WP_User_Frontend.editorLimit.blockTyping(event); } else { self.closest('.wpuf-fields').find('span.wpuf-wordlimit-message').html(''); } // handle the paste event if ( event.type === 'paste' ) { self.val( content.slice(0, limit).join( ' ' ) ); } }, blockTyping: function(event) { // Allow: backspace, delete, tab, escape, minus enter and . backspace = 8,delete=46,tab=9,enter=13,.=190,escape=27, minus = 189 if ($.inArray(event.keyCode, [46, 8, 9, 27, 13, 110, 190, 189]) !== -1 || // Allow: Ctrl+A (event.keyCode == 65 && event.ctrlKey === true) || // Allow: home, end, left, right, down, up (event.keyCode >= 35 && event.keyCode <= 40)) { // let it happen, don't do anything return; } event.preventDefault(); event.stopPropagation(); }, make_media_embed_code: function(content, editor){ $.post( ajaxurl, { action:'make_media_embed_code', content: content }, function(data){ // console.log(data); editor.setContent(editor.getContent() + editor.setContent(data)); } ) } } }; $(function() { WP_User_Frontend.init(); // payment gateway selection $('ul.wpuf-payment-gateways').on('click', 'input[type=radio]', function(e) { $('.wpuf-payment-instruction').slideUp(250); $(this).parents('li').find('.wpuf-payment-instruction').slideDown(250); }); if( !$('ul.wpuf-payment-gateways li').find('input[type=radio]').is(':checked') ) { $('ul.wpuf-payment-gateways li').first().find('input[type=radio]').click() } else { var el = $('ul.wpuf-payment-gateways li').find('input[type=radio]:checked'); el.parents('li').find('.wpuf-payment-instruction').slideDown(250); } }); $(function() { $('input[name="first_name"], input[name="last_name"]').on('change keyup', function() { var myVal, newVal = $.makeArray($('input[name="first_name"], input[name="last_name"]').map(function(){ if (myVal = $(this).val()) { return(myVal); } })).join(' '); $('input[name="display_name"]').val(newVal); }); }); // script for Dokan vendor registration template $(function($) { $('.wpuf-form-add input[name="dokan_store_name"]').on('focusout', function() { var value = $(this).val().toLowerCase().replace(/-+/g, '').replace(/\s+/g, '-').replace(/[^a-z0-9-]/g, ''); $('input[name="shopurl"]').val(value); $('#url-alart').text( value ); $('input[name="shopurl"]').focus(); }); $('.wpuf-form-add input[name="shopurl"]').keydown(function(e) { var text = $(this).val(); // Allow: backspace, delete, tab, escape, enter and . if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 91, 109, 110, 173, 189, 190]) !== -1 || // Allow: Ctrl+A (e.keyCode == 65 && e.ctrlKey === true) || // Allow: home, end, left, right (e.keyCode >= 35 && e.keyCode <= 39)) { // let it happen, don't do anything return; } if ((e.shiftKey || (e.keyCode < 65 || e.keyCode > 90) && (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105) ) { e.preventDefault(); } }); $('.wpuf-form-add input[name="shopurl"]').keyup(function(e) { $('#url-alart').text( $(this).val() ); }); $('.wpuf-form-add input[name="shopurl"]').on('focusout', function() { var self = $(this), data = { action : 'shop_url', url_slug : self.val(), _nonce : dokan.nonce, }; if ( self.val() === '' ) { return; } $.post( dokan.ajaxurl, data, function(resp) { if ( resp == 0){ $('#url-alart').removeClass('text-success').addClass('text-danger'); $('#url-alart-mgs').removeClass('text-success').addClass('text-danger').text(dokan.seller.notAvailable); } else { $('#url-alart').removeClass('text-danger').addClass('text-success'); $('#url-alart-mgs').removeClass('text-danger').addClass('text-success').text(dokan.seller.available); } } ); }); // Set name attribute for google map search field $(".wpuf-form-add #wpuf-map-add-location").attr("name", "find_address"); }); })(jQuery, window); /* assets/wpuf/vendor/sweetalert2/dist/sweetalert2.js */ /*! * sweetalert2 v6.6.4 * Released under the MIT License. */ (function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : typeof define === 'function' && define.amd ? define(factory) : (global.Sweetalert2 = factory()); }(this, (function () { 'use strict'; var defaultParams = { title: '', titleText: '', text: '', html: '', type: null, customClass: '', target: 'body', animation: true, allowOutsideClick: true, allowEscapeKey: true, allowEnterKey: true, showConfirmButton: true, showCancelButton: false, preConfirm: null, confirmButtonText: 'OK', confirmButtonColor: '#3085d6', confirmButtonClass: null, cancelButtonText: 'Cancel', cancelButtonColor: '#aaa', cancelButtonClass: null, buttonsStyling: true, reverseButtons: false, focusCancel: false, showCloseButton: false, showLoaderOnConfirm: false, imageUrl: null, imageWidth: null, imageHeight: null, imageClass: null, timer: null, width: 500, padding: 20, background: '#fff', input: null, inputPlaceholder: '', inputValue: '', inputOptions: {}, inputAutoTrim: true, inputClass: null, inputAttributes: {}, inputValidator: null, progressSteps: [], currentProgressStep: null, progressStepsDistance: '40px', onOpen: null, onClose: null, useRejections: true }; var swalPrefix = 'swal2-'; var prefix = function prefix(items) { var result = {}; for (var i in items) { result[items[i]] = swalPrefix + items[i]; } return result; }; var swalClasses = prefix(['container', 'shown', 'iosfix', 'modal', 'overlay', 'fade', 'show', 'hide', 'noanimation', 'close', 'title', 'content', 'buttonswrapper', 'confirm', 'cancel', 'icon', 'image', 'input', 'file', 'range', 'select', 'radio', 'checkbox', 'textarea', 'inputerror', 'validationerror', 'progresssteps', 'activeprogressstep', 'progresscircle', 'progressline', 'loading', 'styled']); var iconTypes = prefix(['success', 'warning', 'info', 'question', 'error']); /* * Set hover, active and focus-states for buttons (source: http://www.sitepoint.com/javascript-generate-lighter-darker-color) */ var colorLuminance = function colorLuminance(hex, lum) { // Validate hex string hex = String(hex).replace(/[^0-9a-f]/gi, ''); if (hex.length < 6) { hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2]; } lum = lum || 0; // Convert to decimal and change luminosity var rgb = '#'; for (var i = 0; i < 3; i++) { var c = parseInt(hex.substr(i * 2, 2), 16); c = Math.round(Math.min(Math.max(0, c + c * lum), 255)).toString(16); rgb += ('00' + c).substr(c.length); } return rgb; }; var uniqueArray = function uniqueArray(arr) { var result = []; for (var i in arr) { if (result.indexOf(arr[i]) === -1) { result.push(arr[i]); } } return result; }; /* global MouseEvent */ // Remember state in cases where opening and handling a modal will fiddle with it. var states = { previousWindowKeyDown: null, previousActiveElement: null, previousBodyPadding: null }; /* * Add modal + overlay to DOM */ var init = function init(params) { if (typeof document === 'undefined') { console.error('SweetAlert2 requires document to initialize'); return; } var container = document.createElement('div'); container.className = swalClasses.container; container.innerHTML = sweetHTML; var targetElement = document.querySelector(params.target); if (!targetElement) { console.warn('SweetAlert2: Can\'t find the target "' + params.target + '"'); targetElement = document.body; } targetElement.appendChild(container); var modal = getModal(); var input = getChildByClass(modal, swalClasses.input); var file = getChildByClass(modal, swalClasses.file); var range = modal.querySelector('.' + swalClasses.range + ' input'); var rangeOutput = modal.querySelector('.' + swalClasses.range + ' output'); var select = getChildByClass(modal, swalClasses.select); var checkbox = modal.querySelector('.' + swalClasses.checkbox + ' input'); var textarea = getChildByClass(modal, swalClasses.textarea); input.oninput = function () { sweetAlert.resetValidationError(); }; input.onkeydown = function (event) { setTimeout(function () { if (event.keyCode === 13 && params.allowEnterKey) { event.stopPropagation(); sweetAlert.clickConfirm(); } }, 0); }; file.onchange = function () { sweetAlert.resetValidationError(); }; range.oninput = function () { sweetAlert.resetValidationError(); rangeOutput.value = range.value; }; range.onchange = function () { sweetAlert.resetValidationError(); range.previousSibling.value = range.value; }; select.onchange = function () { sweetAlert.resetValidationError(); }; checkbox.onchange = function () { sweetAlert.resetValidationError(); }; textarea.oninput = function () { sweetAlert.resetValidationError(); }; return modal; }; /* * Manipulate DOM */ var sweetHTML = ('\n <div role="dialog" aria-labelledby="' + swalClasses.title + '" aria-describedby="' + swalClasses.content + '" class="' + swalClasses.modal + '" tabindex="-1">\n <ul class="' + swalClasses.progresssteps + '"></ul>\n <div class="' + swalClasses.icon + ' ' + iconTypes.error + '">\n <span class="swal2-x-mark"><span class="swal2-x-mark-line-left"></span><span class="swal2-x-mark-line-right"></span></span>\n </div>\n <div class="' + swalClasses.icon + ' ' + iconTypes.question + '">?</div>\n <div class="' + swalClasses.icon + ' ' + iconTypes.warning + '">!</div>\n <div class="' + swalClasses.icon + ' ' + iconTypes.info + '">i</div>\n <div class="' + swalClasses.icon + ' ' + iconTypes.success + '">\n <div class="swal2-success-circular-line-left"></div>\n <span class="swal2-success-line-tip"></span> <span class="swal2-success-line-long"></span>\n <div class="swal2-success-ring"></div> <div class="swal2-success-fix"></div>\n <div class="swal2-success-circular-line-right"></div>\n </div>\n <img class="' + swalClasses.image + '">\n <h2 class="' + swalClasses.title + '" id="' + swalClasses.title + '"></h2>\n <div id="' + swalClasses.content + '" class="' + swalClasses.content + '"></div>\n <input class="' + swalClasses.input + '">\n <input type="file" class="' + swalClasses.file + '">\n <div class="' + swalClasses.range + '">\n <output></output>\n <input type="range">\n </div>\n <select class="' + swalClasses.select + '"></select>\n <div class="' + swalClasses.radio + '"></div>\n <label for="' + swalClasses.checkbox + '" class="' + swalClasses.checkbox + '">\n <input type="checkbox">\n </label>\n <textarea class="' + swalClasses.textarea + '"></textarea>\n <div class="' + swalClasses.validationerror + '"></div>\n <div class="' + swalClasses.buttonswrapper + '">\n <button type="button" class="' + swalClasses.confirm + '">OK</button>\n <button type="button" class="' + swalClasses.cancel + '">Cancel</button>\n </div>\n <button type="button" class="' + swalClasses.close + '" aria-label="Close this dialog">×</button>\n </div>\n').replace(/(^|\n)\s*/g, ''); var getContainer = function getContainer() { return document.body.querySelector('.' + swalClasses.container); }; var getModal = function getModal() { return getContainer() ? getContainer().querySelector('.' + swalClasses.modal) : null; }; var getIcons = function getIcons() { var modal = getModal(); return modal.querySelectorAll('.' + swalClasses.icon); }; var elementByClass = function elementByClass(className) { return getContainer() ? getContainer().querySelector('.' + className) : null; }; var getTitle = function getTitle() { return elementByClass(swalClasses.title); }; var getContent = function getContent() { return elementByClass(swalClasses.content); }; var getImage = function getImage() { return elementByClass(swalClasses.image); }; var getButtonsWrapper = function getButtonsWrapper() { return elementByClass(swalClasses.buttonswrapper); }; var getProgressSteps = function getProgressSteps() { return elementByClass(swalClasses.progresssteps); }; var getValidationError = function getValidationError() { return elementByClass(swalClasses.validationerror); }; var getConfirmButton = function getConfirmButton() { return elementByClass(swalClasses.confirm); }; var getCancelButton = function getCancelButton() { return elementByClass(swalClasses.cancel); }; var getCloseButton = function getCloseButton() { return elementByClass(swalClasses.close); }; var getFocusableElements = function getFocusableElements(focusCancel) { var buttons = [getConfirmButton(), getCancelButton()]; if (focusCancel) { buttons.reverse(); } var focusableElements = buttons.concat(Array.prototype.slice.call(getModal().querySelectorAll('button, input:not([type=hidden]), textarea, select, a, *[tabindex]:not([tabindex="-1"])'))); return uniqueArray(focusableElements); }; var hasClass = function hasClass(elem, className) { if (elem.classList) { return elem.classList.contains(className); } return false; }; var focusInput = function focusInput(input) { input.focus(); // place cursor at end of text in text input if (input.type !== 'file') { // http://stackoverflow.com/a/2345915/1331425 var val = input.value; input.value = ''; input.value = val; } }; var addClass = function addClass(elem, className) { if (!elem || !className) { return; } var classes = className.split(/\s+/).filter(Boolean); classes.forEach(function (className) { elem.classList.add(className); }); }; var removeClass = function removeClass(elem, className) { if (!elem || !className) { return; } var classes = className.split(/\s+/).filter(Boolean); classes.forEach(function (className) { elem.classList.remove(className); }); }; var getChildByClass = function getChildByClass(elem, className) { for (var i = 0; i < elem.childNodes.length; i++) { if (hasClass(elem.childNodes[i], className)) { return elem.childNodes[i]; } } }; var show = function show(elem, display) { if (!display) { display = 'block'; } elem.style.opacity = ''; elem.style.display = display; }; var hide = function hide(elem) { elem.style.opacity = ''; elem.style.display = 'none'; }; var empty = function empty(elem) { while (elem.firstChild) { elem.removeChild(elem.firstChild); } }; // borrowed from jqeury $(elem).is(':visible') implementation var isVisible = function isVisible(elem) { return elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length; }; var removeStyleProperty = function removeStyleProperty(elem, property) { if (elem.style.removeProperty) { elem.style.removeProperty(property); } else { elem.style.removeAttribute(property); } }; var fireClick = function fireClick(node) { if (!isVisible(node)) { return false; } // Taken from http://www.nonobtrusive.com/2011/11/29/programatically-fire-crossbrowser-click-event-with-javascript/ // Then fixed for today's Chrome browser. if (typeof MouseEvent === 'function') { // Up-to-date approach var mevt = new MouseEvent('click', { view: window, bubbles: false, cancelable: true }); node.dispatchEvent(mevt); } else if (document.createEvent) { // Fallback var evt = document.createEvent('MouseEvents'); evt.initEvent('click', false, false); node.dispatchEvent(evt); } else if (document.createEventObject) { node.fireEvent('onclick'); } else if (typeof node.onclick === 'function') { node.onclick(); } }; var animationEndEvent = function () { var testEl = document.createElement('div'); var transEndEventNames = { 'WebkitAnimation': 'webkitAnimationEnd', 'OAnimation': 'oAnimationEnd oanimationend', 'msAnimation': 'MSAnimationEnd', 'animation': 'animationend' }; for (var i in transEndEventNames) { if (transEndEventNames.hasOwnProperty(i) && testEl.style[i] !== undefined) { return transEndEventNames[i]; } } return false; }(); // Reset previous window keydown handler and focued element var resetPrevState = function resetPrevState() { window.onkeydown = states.previousWindowKeyDown; if (states.previousActiveElement && states.previousActiveElement.focus) { var x = window.scrollX; var y = window.scrollY; states.previousActiveElement.focus(); if (x && y) { // IE has no scrollX/scrollY support window.scrollTo(x, y); } } }; // Measure width of scrollbar // https://github.com/twbs/bootstrap/blob/master/js/modal.js#L279-L286 var measureScrollbar = function measureScrollbar() { var supportsTouch = 'ontouchstart' in window || navigator.msMaxTouchPoints; if (supportsTouch) { return 0; } var scrollDiv = document.createElement('div'); scrollDiv.style.width = '50px'; scrollDiv.style.height = '50px'; scrollDiv.style.overflow = 'scroll'; document.body.appendChild(scrollDiv); var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth; document.body.removeChild(scrollDiv); return scrollbarWidth; }; // JavaScript Debounce Function // Simplivied version of https://davidwalsh.name/javascript-debounce-function var debounce = function debounce(func, wait) { var timeout = void 0; return function () { var later = function later() { timeout = null; func(); }; clearTimeout(timeout); timeout = setTimeout(later, wait); }; }; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var modalParams = _extends({}, defaultParams); var queue = []; var swal2Observer = void 0; /* * Set type, text and actions on modal */ var setParameters = function setParameters(params) { var modal = getModal() || init(params); for (var param in params) { if (!defaultParams.hasOwnProperty(param) && param !== 'extraParams') { console.warn('SweetAlert2: Unknown parameter "' + param + '"'); } } // Set modal width modal.style.width = typeof params.width === 'number' ? params.width + 'px' : params.width; modal.style.padding = params.padding + 'px'; modal.style.background = params.background; var successIconParts = modal.querySelectorAll('[class^=swal2-success-circular-line], .swal2-success-fix'); for (var i = 0; i < successIconParts.length; i++) { successIconParts[i].style.background = params.background; } var title = getTitle(); var content = getContent(); var buttonsWrapper = getButtonsWrapper(); var confirmButton = getConfirmButton(); var cancelButton = getCancelButton(); var closeButton = getCloseButton(); // Title if (params.titleText) { title.innerText = params.titleText; } else { title.innerHTML = params.title.split('\n').join('<br>'); } // Content if (params.text || params.html) { if (_typeof(params.html) === 'object') { content.innerHTML = ''; if (0 in params.html) { for (var _i = 0; _i in params.html; _i++) { content.appendChild(params.html[_i].cloneNode(true)); } } else { content.appendChild(params.html.cloneNode(true)); } } else if (params.html) { content.innerHTML = params.html; } else if (params.text) { content.textContent = params.text; } show(content); } else { hide(content); } // Close button if (params.showCloseButton) { show(closeButton); } else { hide(closeButton); } // Custom Class modal.className = swalClasses.modal; if (params.customClass) { addClass(modal, params.customClass); } // Progress steps var progressStepsContainer = getProgressSteps(); var currentProgressStep = parseInt(params.currentProgressStep === null ? sweetAlert.getQueueStep() : params.currentProgressStep, 10); if (params.progressSteps.length) { show(progressStepsContainer); empty(progressStepsContainer); if (currentProgressStep >= params.progressSteps.length) { console.warn('SweetAlert2: Invalid currentProgressStep parameter, it should be less than progressSteps.length ' + '(currentProgressStep like JS arrays starts from 0)'); } params.progressSteps.forEach(function (step, index) { var circle = document.createElement('li'); addClass(circle, swalClasses.progresscircle); circle.innerHTML = step; if (index === currentProgressStep) { addClass(circle, swalClasses.activeprogressstep); } progressStepsContainer.appendChild(circle); if (index !== params.progressSteps.length - 1) { var line = document.createElement('li'); addClass(line, swalClasses.progressline); line.style.width = params.progressStepsDistance; progressStepsContainer.appendChild(line); } }); } else { hide(progressStepsContainer); } // Icon var icons = getIcons(); for (var _i2 = 0; _i2 < icons.length; _i2++) { hide(icons[_i2]); } if (params.type) { var validType = false; for (var iconType in iconTypes) { if (params.type === iconType) { validType = true; break; } } if (!validType) { console.error('SweetAlert2: Unknown alert type: ' + params.type); return false; } var icon = modal.querySelector('.' + swalClasses.icon + '.' + iconTypes[params.type]); show(icon); // Animate icon if (params.animation) { switch (params.type) { case 'success': addClass(icon, 'swal2-animate-success-icon'); addClass(icon.querySelector('.swal2-success-line-tip'), 'swal2-animate-success-line-tip'); addClass(icon.querySelector('.swal2-success-line-long'), 'swal2-animate-success-line-long'); break; case 'error': addClass(icon, 'swal2-animate-error-icon'); addClass(icon.querySelector('.swal2-x-mark'), 'swal2-animate-x-mark'); break; default: break; } } } // Custom image var image = getImage(); if (params.imageUrl) { image.setAttribute('src', params.imageUrl); show(image); if (params.imageWidth) { image.setAttribute('width', params.imageWidth); } else { image.removeAttribute('width'); } if (params.imageHeight) { image.setAttribute('height', params.imageHeight); } else { image.removeAttribute('height'); } image.className = swalClasses.image; if (params.imageClass) { addClass(image, params.imageClass); } } else { hide(image); } // Cancel button if (params.showCancelButton) { cancelButton.style.display = 'inline-block'; } else { hide(cancelButton); } // Confirm button if (params.showConfirmButton) { removeStyleProperty(confirmButton, 'display'); } else { hide(confirmButton); } // Buttons wrapper if (!params.showConfirmButton && !params.showCancelButton) { hide(buttonsWrapper); } else { show(buttonsWrapper); } // Edit text on cancel and confirm buttons confirmButton.innerHTML = params.confirmButtonText; cancelButton.innerHTML = params.cancelButtonText; // Set buttons to selected background colors if (params.buttonsStyling) { confirmButton.style.backgroundColor = params.confirmButtonColor; cancelButton.style.backgroundColor = params.cancelButtonColor; } // Add buttons custom classes confirmButton.className = swalClasses.confirm; addClass(confirmButton, params.confirmButtonClass); cancelButton.className = swalClasses.cancel; addClass(cancelButton, params.cancelButtonClass); // Buttons styling if (params.buttonsStyling) { addClass(confirmButton, swalClasses.styled); addClass(cancelButton, swalClasses.styled); } else { removeClass(confirmButton, swalClasses.styled); removeClass(cancelButton, swalClasses.styled); confirmButton.style.backgroundColor = confirmButton.style.borderLeftColor = confirmButton.style.borderRightColor = ''; cancelButton.style.backgroundColor = cancelButton.style.borderLeftColor = cancelButton.style.borderRightColor = ''; } // CSS animation if (params.animation === true) { removeClass(modal, swalClasses.noanimation); } else { addClass(modal, swalClasses.noanimation); } }; /* * Animations */ var openModal = function openModal(animation, onComplete) { var container = getContainer(); var modal = getModal(); if (animation) { addClass(modal, swalClasses.show); addClass(container, swalClasses.fade); removeClass(modal, swalClasses.hide); } else { removeClass(modal, swalClasses.fade); } show(modal); // scrolling is 'hidden' until animation is done, after that 'auto' container.style.overflowY = 'hidden'; if (animationEndEvent && !hasClass(modal, swalClasses.noanimation)) { modal.addEventListener(animationEndEvent, function swalCloseEventFinished() { modal.removeEventListener(animationEndEvent, swalCloseEventFinished); container.style.overflowY = 'auto'; }); } else { container.style.overflowY = 'auto'; } addClass(document.documentElement, swalClasses.shown); addClass(document.body, swalClasses.shown); addClass(container, swalClasses.shown); fixScrollbar(); iOSfix(); states.previousActiveElement = document.activeElement; if (onComplete !== null && typeof onComplete === 'function') { setTimeout(function () { onComplete(modal); }); } }; var fixScrollbar = function fixScrollbar() { // for queues, do not do this more than once if (states.previousBodyPadding !== null) { return; } // if the body has overflow if (document.body.scrollHeight > window.innerHeight) { // add padding so the content doesn't shift after removal of scrollbar states.previousBodyPadding = document.body.style.paddingRight; document.body.style.paddingRight = measureScrollbar() + 'px'; } }; var undoScrollbar = function undoScrollbar() { if (states.previousBodyPadding !== null) { document.body.style.paddingRight = states.previousBodyPadding; states.previousBodyPadding = null; } }; // Fix iOS scrolling http://stackoverflow.com/q/39626302/1331425 var iOSfix = function iOSfix() { var iOS = /iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream; if (iOS && !hasClass(document.body, swalClasses.iosfix)) { var offset = document.body.scrollTop; document.body.style.top = offset * -1 + 'px'; addClass(document.body, swalClasses.iosfix); } }; var undoIOSfix = function undoIOSfix() { if (hasClass(document.body, swalClasses.iosfix)) { var offset = parseInt(document.body.style.top, 10); removeClass(document.body, swalClasses.iosfix); document.body.style.top = ''; document.body.scrollTop = offset * -1; } }; // SweetAlert entry point var sweetAlert = function sweetAlert() { for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } if (args[0] === undefined) { console.error('SweetAlert2 expects at least 1 attribute!'); return false; } var params = _extends({}, modalParams); switch (_typeof(args[0])) { case 'string': params.title = args[0]; params.html = args[1]; params.type = args[2]; break; case 'object': _extends(params, args[0]); params.extraParams = args[0].extraParams; if (params.input === 'email' && params.inputValidator === null) { params.inputValidator = function (email) { return new Promise(function (resolve, reject) { var emailRegex = /^[a-zA-Z0-9.+_-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,6}$/; if (emailRegex.test(email)) { resolve(); } else { reject('Invalid email address'); } }); }; } if (params.input === 'url' && params.inputValidator === null) { params.inputValidator = function (url) { return new Promise(function (resolve, reject) { var urlRegex = /^(https?:\/\/)?([\da-z.-]+)\.([a-z.]{2,6})([/\w .-]*)*\/?$/; if (urlRegex.test(url)) { resolve(); } else { reject('Invalid URL'); } }); }; } break; default: console.error('SweetAlert2: Unexpected type of argument! Expected "string" or "object", got ' + _typeof(args[0])); return false; } setParameters(params); var container = getContainer(); var modal = getModal(); return new Promise(function (resolve, reject) { // Close on timer if (params.timer) { modal.timeout = setTimeout(function () { sweetAlert.closeModal(params.onClose); if (params.useRejections) { reject('timer'); } else { resolve({ dismiss: 'timer' }); } }, params.timer); } // Get input element by specified type or, if type isn't specified, by params.input var getInput = function getInput(inputType) { inputType = inputType || params.input; if (!inputType) { return null; } switch (inputType) { case 'select': case 'textarea': case 'file': return getChildByClass(modal, swalClasses[inputType]); case 'checkbox': return modal.querySelector('.' + swalClasses.checkbox + ' input'); case 'radio': return modal.querySelector('.' + swalClasses.radio + ' input:checked') || modal.querySelector('.' + swalClasses.radio + ' input:first-child'); case 'range': return modal.querySelector('.' + swalClasses.range + ' input'); default: return getChildByClass(modal, swalClasses.input); } }; // Get the value of the modal input var getInputValue = function getInputValue() { var input = getInput(); if (!input) { return null; } switch (params.input) { case 'checkbox': return input.checked ? 1 : 0; case 'radio': return input.checked ? input.value : null; case 'file': return input.files.length ? input.files[0] : null; default: return params.inputAutoTrim ? input.value.trim() : input.value; } }; // input autofocus if (params.input) { setTimeout(function () { var input = getInput(); if (input) { focusInput(input); } }, 0); } var confirm = function confirm(value) { if (params.showLoaderOnConfirm) { sweetAlert.showLoading(); } if (params.preConfirm) { params.preConfirm(value, params.extraParams).then(function (preConfirmValue) { sweetAlert.closeModal(params.onClose); resolve(preConfirmValue || value); }, function (error) { sweetAlert.hideLoading(); if (error) { sweetAlert.showValidationError(error); } }); } else { sweetAlert.closeModal(params.onClose); if (params.useRejections) { resolve(value); } else { resolve({ value: value }); } } }; // Mouse interactions var onButtonEvent = function onButtonEvent(event) { var e = event || window.event; var target = e.target || e.srcElement; var confirmButton = getConfirmButton(); var cancelButton = getCancelButton(); var targetedConfirm = confirmButton && (confirmButton === target || confirmButton.contains(target)); var targetedCancel = cancelButton && (cancelButton === target || cancelButton.contains(target)); switch (e.type) { case 'mouseover': case 'mouseup': if (params.buttonsStyling) { if (targetedConfirm) { confirmButton.style.backgroundColor = colorLuminance(params.confirmButtonColor, -0.1); } else if (targetedCancel) { cancelButton.style.backgroundColor = colorLuminance(params.cancelButtonColor, -0.1); } } break; case 'mouseout': if (params.buttonsStyling) { if (targetedConfirm) { confirmButton.style.backgroundColor = params.confirmButtonColor; } else if (targetedCancel) { cancelButton.style.backgroundColor = params.cancelButtonColor; } } break; case 'mousedown': if (params.buttonsStyling) { if (targetedConfirm) { confirmButton.style.backgroundColor = colorLuminance(params.confirmButtonColor, -0.2); } else if (targetedCancel) { cancelButton.style.backgroundColor = colorLuminance(params.cancelButtonColor, -0.2); } } break; case 'click': // Clicked 'confirm' if (targetedConfirm && sweetAlert.isVisible()) { sweetAlert.disableButtons(); if (params.input) { var inputValue = getInputValue(); if (params.inputValidator) { sweetAlert.disableInput(); params.inputValidator(inputValue, params.extraParams).then(function () { sweetAlert.enableButtons(); sweetAlert.enableInput(); confirm(inputValue); }, function (error) { sweetAlert.enableButtons(); sweetAlert.enableInput(); if (error) { sweetAlert.showValidationError(error); } }); } else { confirm(inputValue); } } else { confirm(true); } // Clicked 'cancel' } else if (targetedCancel && sweetAlert.isVisible()) { sweetAlert.disableButtons(); sweetAlert.closeModal(params.onClose); if (params.useRejections) { reject('cancel'); } else { resolve({ dismiss: 'cancel' }); } } break; default: } }; var buttons = modal.querySelectorAll('button'); for (var i = 0; i < buttons.length; i++) { buttons[i].onclick = onButtonEvent; buttons[i].onmouseover = onButtonEvent; buttons[i].onmouseout = onButtonEvent; buttons[i].onmousedown = onButtonEvent; } // Closing modal by close button getCloseButton().onclick = function () { sweetAlert.closeModal(params.onClose); if (params.useRejections) { reject('close'); } else { resolve({ dismiss: 'close' }); } }; // Closing modal by overlay click container.onclick = function (e) { if (e.target !== container) { return; } if (params.allowOutsideClick) { sweetAlert.closeModal(params.onClose); if (params.useRejections) { reject('overlay'); } else { resolve({ dismiss: 'overlay' }); } } }; var buttonsWrapper = getButtonsWrapper(); var confirmButton = getConfirmButton(); var cancelButton = getCancelButton(); // Reverse buttons (Confirm on the right side) if (params.reverseButtons) { confirmButton.parentNode.insertBefore(cancelButton, confirmButton); } else { confirmButton.parentNode.insertBefore(confirmButton, cancelButton); } // Focus handling var setFocus = function setFocus(index, increment) { var focusableElements = getFocusableElements(params.focusCancel); // search for visible elements and select the next possible match for (var _i3 = 0; _i3 < focusableElements.length; _i3++) { index = index + increment; // rollover to first item if (index === focusableElements.length) { index = 0; // go to last item } else if (index === -1) { index = focusableElements.length - 1; } // determine if element is visible var el = focusableElements[index]; if (isVisible(el)) { return el.focus(); } } }; var handleKeyDown = function handleKeyDown(event) { var e = event || window.event; var keyCode = e.keyCode || e.which; if ([9, 13, 32, 27, 37, 38, 39, 40].indexOf(keyCode) === -1) { // Don't do work on keys we don't care about. return; } var targetElement = e.target || e.srcElement; var focusableElements = getFocusableElements(params.focusCancel); var btnIndex = -1; // Find the button - note, this is a nodelist, not an array. for (var _i4 = 0; _i4 < focusableElements.length; _i4++) { if (targetElement === focusableElements[_i4]) { btnIndex = _i4; break; } } // TAB if (keyCode === 9) { if (!e.shiftKey) { // Cycle to the next button setFocus(btnIndex, 1); } else { // Cycle to the prev button setFocus(btnIndex, -1); } e.stopPropagation(); e.preventDefault(); // ARROWS - switch focus between buttons } else if (keyCode === 37 || keyCode === 38 || keyCode === 39 || keyCode === 40) { // focus Cancel button if Confirm button is currently focused if (document.activeElement === confirmButton && isVisible(cancelButton)) { cancelButton.focus(); // and vice versa } else if (document.activeElement === cancelButton && isVisible(confirmButton)) { confirmButton.focus(); } // ENTER/SPACE } else if (keyCode === 13 || keyCode === 32) { if (btnIndex === -1 && params.allowEnterKey) { // ENTER/SPACE clicked outside of a button. if (params.focusCancel) { fireClick(cancelButton, e); } else { fireClick(confirmButton, e); } e.stopPropagation(); e.preventDefault(); } // ESC } else if (keyCode === 27 && params.allowEscapeKey === true) { sweetAlert.closeModal(params.onClose); if (params.useRejections) { reject('esc'); } else { resolve({ dismiss: 'esc' }); } } }; if (!window.onkeydown || window.onkeydown.toString() !== handleKeyDown.toString()) { states.previousWindowKeyDown = window.onkeydown; window.onkeydown = handleKeyDown; } // Loading state if (params.buttonsStyling) { confirmButton.style.borderLeftColor = params.confirmButtonColor; confirmButton.style.borderRightColor = params.confirmButtonColor; } /** * Show spinner instead of Confirm button and disable Cancel button */ sweetAlert.hideLoading = sweetAlert.disableLoading = function () { if (!params.showConfirmButton) { hide(confirmButton); if (!params.showCancelButton) { hide(getButtonsWrapper()); } } removeClass(buttonsWrapper, swalClasses.loading); removeClass(modal, swalClasses.loading); confirmButton.disabled = false; cancelButton.disabled = false; }; sweetAlert.getTitle = function () { return getTitle(); }; sweetAlert.getContent = function () { return getContent(); }; sweetAlert.getInput = function () { return getInput(); }; sweetAlert.getImage = function () { return getImage(); }; sweetAlert.getButtonsWrapper = function () { return getButtonsWrapper(); }; sweetAlert.getConfirmButton = function () { return getConfirmButton(); }; sweetAlert.getCancelButton = function () { return getCancelButton(); }; sweetAlert.enableButtons = function () { confirmButton.disabled = false; cancelButton.disabled = false; }; sweetAlert.disableButtons = function () { confirmButton.disabled = true; cancelButton.disabled = true; }; sweetAlert.enableConfirmButton = function () { confirmButton.disabled = false; }; sweetAlert.disableConfirmButton = function () { confirmButton.disabled = true; }; sweetAlert.enableInput = function () { var input = getInput(); if (!input) { return false; } if (input.type === 'radio') { var radiosContainer = input.parentNode.parentNode; var radios = radiosContainer.querySelectorAll('input'); for (var _i5 = 0; _i5 < radios.length; _i5++) { radios[_i5].disabled = false; } } else { input.disabled = false; } }; sweetAlert.disableInput = function () { var input = getInput(); if (!input) { return false; } if (input && input.type === 'radio') { var radiosContainer = input.parentNode.parentNode; var radios = radiosContainer.querySelectorAll('input'); for (var _i6 = 0; _i6 < radios.length; _i6++) { radios[_i6].disabled = true; } } else { input.disabled = true; } }; // Set modal min-height to disable scrolling inside the modal sweetAlert.recalculateHeight = debounce(function () { var modal = getModal(); if (!modal) { return; } var prevState = modal.style.display; modal.style.minHeight = ''; show(modal); modal.style.minHeight = modal.scrollHeight + 1 + 'px'; modal.style.display = prevState; }, 50); // Show block with validation error sweetAlert.showValidationError = function (error) { var validationError = getValidationError(); validationError.innerHTML = error; show(validationError); var input = getInput(); if (input) { focusInput(input); addClass(input, swalClasses.inputerror); } }; // Hide block with validation error sweetAlert.resetValidationError = function () { var validationError = getValidationError(); hide(validationError); sweetAlert.recalculateHeight(); var input = getInput(); if (input) { removeClass(input, swalClasses.inputerror); } }; sweetAlert.getProgressSteps = function () { return params.progressSteps; }; sweetAlert.setProgressSteps = function (progressSteps) { params.progressSteps = progressSteps; setParameters(params); }; sweetAlert.showProgressSteps = function () { show(getProgressSteps()); }; sweetAlert.hideProgressSteps = function () { hide(getProgressSteps()); }; sweetAlert.enableButtons(); sweetAlert.hideLoading(); sweetAlert.resetValidationError(); // inputs var inputTypes = ['input', 'file', 'range', 'select', 'radio', 'checkbox', 'textarea']; var input = void 0; for (var _i7 = 0; _i7 < inputTypes.length; _i7++) { var inputClass = swalClasses[inputTypes[_i7]]; var inputContainer = getChildByClass(modal, inputClass); input = getInput(inputTypes[_i7]); // set attributes if (input) { for (var j in input.attributes) { if (input.attributes.hasOwnProperty(j)) { var attrName = input.attributes[j].name; if (attrName !== 'type' && attrName !== 'value') { input.removeAttribute(attrName); } } } for (var attr in params.inputAttributes) { input.setAttribute(attr, params.inputAttributes[attr]); } } // set class inputContainer.className = inputClass; if (params.inputClass) { addClass(inputContainer, params.inputClass); } hide(inputContainer); } var populateInputOptions = void 0; switch (params.input) { case 'text': case 'email': case 'password': case 'number': case 'tel': case 'url': input = getChildByClass(modal, swalClasses.input); input.value = params.inputValue; input.placeholder = params.inputPlaceholder; input.type = params.input; show(input); break; case 'file': input = getChildByClass(modal, swalClasses.file); input.placeholder = params.inputPlaceholder; input.type = params.input; show(input); break; case 'range': var range = getChildByClass(modal, swalClasses.range); var rangeInput = range.querySelector('input'); var rangeOutput = range.querySelector('output'); rangeInput.value = params.inputValue; rangeInput.type = params.input; rangeOutput.value = params.inputValue; show(range); break; case 'select': var select = getChildByClass(modal, swalClasses.select); select.innerHTML = ''; if (params.inputPlaceholder) { var placeholder = document.createElement('option'); placeholder.innerHTML = params.inputPlaceholder; placeholder.value = ''; placeholder.disabled = true; placeholder.selected = true; select.appendChild(placeholder); } populateInputOptions = function populateInputOptions(inputOptions) { for (var optionValue in inputOptions) { var option = document.createElement('option'); option.value = optionValue; option.innerHTML = inputOptions[optionValue]; if (params.inputValue === optionValue) { option.selected = true; } select.appendChild(option); } show(select); select.focus(); }; break; case 'radio': var radio = getChildByClass(modal, swalClasses.radio); radio.innerHTML = ''; populateInputOptions = function populateInputOptions(inputOptions) { for (var radioValue in inputOptions) { var radioInput = document.createElement('input'); var radioLabel = document.createElement('label'); var radioLabelSpan = document.createElement('span'); radioInput.type = 'radio'; radioInput.name = swalClasses.radio; radioInput.value = radioValue; if (params.inputValue === radioValue) { radioInput.checked = true; } radioLabelSpan.innerHTML = inputOptions[radioValue]; radioLabel.appendChild(radioInput); radioLabel.appendChild(radioLabelSpan); radioLabel.for = radioInput.id; radio.appendChild(radioLabel); } show(radio); var radios = radio.querySelectorAll('input'); if (radios.length) { radios[0].focus(); } }; break; case 'checkbox': var checkbox = getChildByClass(modal, swalClasses.checkbox); var checkboxInput = getInput('checkbox'); checkboxInput.type = 'checkbox'; checkboxInput.value = 1; checkboxInput.id = swalClasses.checkbox; checkboxInput.checked = Boolean(params.inputValue); var label = checkbox.getElementsByTagName('span'); if (label.length) { checkbox.removeChild(label[0]); } label = document.createElement('span'); label.innerHTML = params.inputPlaceholder; checkbox.appendChild(label); show(checkbox); break; case 'textarea': var textarea = getChildByClass(modal, swalClasses.textarea); textarea.value = params.inputValue; textarea.placeholder = params.inputPlaceholder; show(textarea); break; case null: break; default: console.error('SweetAlert2: Unexpected type of input! Expected "text", "email", "password", "number", "tel", "select", "radio", "checkbox", "textarea", "file" or "url", got "' + params.input + '"'); break; } if (params.input === 'select' || params.input === 'radio') { if (params.inputOptions instanceof Promise) { sweetAlert.showLoading(); params.inputOptions.then(function (inputOptions) { sweetAlert.hideLoading(); populateInputOptions(inputOptions); }); } else if (_typeof(params.inputOptions) === 'object') { populateInputOptions(params.inputOptions); } else { console.error('SweetAlert2: Unexpected type of inputOptions! Expected object or Promise, got ' + _typeof(params.inputOptions)); } } openModal(params.animation, params.onOpen); // Focus the first element (input or button) if (params.allowEnterKey) { setFocus(-1, 1); } else { if (document.activeElement) { document.activeElement.blur(); } } // fix scroll getContainer().scrollTop = 0; // Observe changes inside the modal and adjust height if (typeof MutationObserver !== 'undefined' && !swal2Observer) { swal2Observer = new MutationObserver(sweetAlert.recalculateHeight); swal2Observer.observe(modal, { childList: true, characterData: true, subtree: true }); } }); }; /* * Global function to determine if swal2 modal is shown */ sweetAlert.isVisible = function () { return !!getModal(); }; /* * Global function for chaining sweetAlert modals */ sweetAlert.queue = function (steps) { queue = steps; var resetQueue = function resetQueue() { queue = []; document.body.removeAttribute('data-swal2-queue-step'); }; var queueResult = []; return new Promise(function (resolve, reject) { (function step(i, callback) { if (i < queue.length) { document.body.setAttribute('data-swal2-queue-step', i); sweetAlert(queue[i]).then(function (result) { queueResult.push(result); step(i + 1, callback); }, function (dismiss) { resetQueue(); reject(dismiss); }); } else { resetQueue(); resolve(queueResult); } })(0); }); }; /* * Global function for getting the index of current modal in queue */ sweetAlert.getQueueStep = function () { return document.body.getAttribute('data-swal2-queue-step'); }; /* * Global function for inserting a modal to the queue */ sweetAlert.insertQueueStep = function (step, index) { if (index && index < queue.length) { return queue.splice(index, 0, step); } return queue.push(step); }; /* * Global function for deleting a modal from the queue */ sweetAlert.deleteQueueStep = function (index) { if (typeof queue[index] !== 'undefined') { queue.splice(index, 1); } }; /* * Global function to close sweetAlert */ sweetAlert.close = sweetAlert.closeModal = function (onComplete) { var container = getContainer(); var modal = getModal(); if (!modal) { return; } removeClass(modal, swalClasses.show); addClass(modal, swalClasses.hide); clearTimeout(modal.timeout); resetPrevState(); var removeModalAndResetState = function removeModalAndResetState() { if (container.parentNode) { container.parentNode.removeChild(container); } removeClass(document.documentElement, swalClasses.shown); removeClass(document.body, swalClasses.shown); undoScrollbar(); undoIOSfix(); }; // If animation is supported, animate if (animationEndEvent && !hasClass(modal, swalClasses.noanimation)) { modal.addEventListener(animationEndEvent, function swalCloseEventFinished() { modal.removeEventListener(animationEndEvent, swalCloseEventFinished); if (hasClass(modal, swalClasses.hide)) { removeModalAndResetState(); } }); } else { // Otherwise, remove immediately removeModalAndResetState(); } if (onComplete !== null && typeof onComplete === 'function') { setTimeout(function () { onComplete(modal); }); } }; /* * Global function to click 'Confirm' button */ sweetAlert.clickConfirm = function () { return getConfirmButton().click(); }; /* * Global function to click 'Cancel' button */ sweetAlert.clickCancel = function () { return getCancelButton().click(); }; /** * Show spinner instead of Confirm button and disable Cancel button */ sweetAlert.showLoading = sweetAlert.enableLoading = function () { var modal = getModal(); if (!modal) { sweetAlert(''); } var buttonsWrapper = getButtonsWrapper(); var confirmButton = getConfirmButton(); var cancelButton = getCancelButton(); show(buttonsWrapper); show(confirmButton, 'inline-block'); addClass(buttonsWrapper, swalClasses.loading); addClass(modal, swalClasses.loading); confirmButton.disabled = true; cancelButton.disabled = true; }; /** * Set default params for each popup * @param {Object} userParams */ sweetAlert.setDefaults = function (userParams) { if (!userParams || (typeof userParams === 'undefined' ? 'undefined' : _typeof(userParams)) !== 'object') { return console.error('SweetAlert2: the argument for setDefaults() is required and has to be a object'); } for (var param in userParams) { if (!defaultParams.hasOwnProperty(param) && param !== 'extraParams') { console.warn('SweetAlert2: Unknown parameter "' + param + '"'); delete userParams[param]; } } _extends(modalParams, userParams); }; /** * Reset default params for each popup */ sweetAlert.resetDefaults = function () { modalParams = _extends({}, defaultParams); }; sweetAlert.noop = function () {}; sweetAlert.version = '6.6.4'; sweetAlert.default = sweetAlert; return sweetAlert; }))); if (window.Sweetalert2) window.sweetAlert = window.swal = window.Sweetalert2; /* assets/wpuf/js/jquery-ui-timepicker-addon.js */ /* * jQuery timepicker addon * By: Trent Richardson [http://trentrichardson.com] * Version 1.2 * Last Modified: 02/02/2013 * * Copyright 2013 Trent Richardson * You may use this project under MIT or GPL licenses. * http://trentrichardson.com/Impromptu/GPL-LICENSE.txt * http://trentrichardson.com/Impromptu/MIT-LICENSE.txt */ /*jslint evil: true, white: false, undef: false, nomen: false */ (function($) { /* * Lets not redefine timepicker, Prevent "Uncaught RangeError: Maximum call stack size exceeded" */ $.ui.timepicker = $.ui.timepicker || {}; if ($.ui.timepicker.version) { return; } /* * Extend jQueryUI, get it started with our version number */ $.extend($.ui, { timepicker: { version: "1.2" } }); /* * Timepicker manager. * Use the singleton instance of this class, $.timepicker, to interact with the time picker. * Settings for (groups of) time pickers are maintained in an instance object, * allowing multiple different settings on the same page. */ var Timepicker = function() { this.regional = []; // Available regional settings, indexed by language code this.regional[''] = { // Default regional settings currentText: 'Now', closeText: 'Done', amNames: ['AM', 'A'], pmNames: ['PM', 'P'], timeFormat: 'HH:mm', timeSuffix: '', timeOnlyTitle: 'Choose Time', timeText: 'Time', hourText: 'Hour', minuteText: 'Minute', secondText: 'Second', millisecText: 'Millisecond', timezoneText: 'Time Zone', isRTL: false }; this._defaults = { // Global defaults for all the datetime picker instances showButtonPanel: true, timeOnly: false, showHour: true, showMinute: true, showSecond: false, showMillisec: false, showTimezone: false, showTime: true, stepHour: 1, stepMinute: 1, stepSecond: 1, stepMillisec: 1, hour: 0, minute: 0, second: 0, millisec: 0, timezone: null, useLocalTimezone: false, defaultTimezone: "+0000", hourMin: 0, minuteMin: 0, secondMin: 0, millisecMin: 0, hourMax: 23, minuteMax: 59, secondMax: 59, millisecMax: 999, minDateTime: null, maxDateTime: null, onSelect: null, hourGrid: 0, minuteGrid: 0, secondGrid: 0, millisecGrid: 0, alwaysSetTime: true, separator: ' ', altFieldTimeOnly: true, altTimeFormat: null, altSeparator: null, altTimeSuffix: null, pickerTimeFormat: null, pickerTimeSuffix: null, showTimepicker: true, timezoneIso8601: false, timezoneList: null, addSliderAccess: false, sliderAccessArgs: null, controlType: 'slider', defaultValue: null, parse: 'strict' }; $.extend(this._defaults, this.regional['']); }; $.extend(Timepicker.prototype, { $input: null, $altInput: null, $timeObj: null, inst: null, hour_slider: null, minute_slider: null, second_slider: null, millisec_slider: null, timezone_select: null, hour: 0, minute: 0, second: 0, millisec: 0, timezone: null, defaultTimezone: "+0000", hourMinOriginal: null, minuteMinOriginal: null, secondMinOriginal: null, millisecMinOriginal: null, hourMaxOriginal: null, minuteMaxOriginal: null, secondMaxOriginal: null, millisecMaxOriginal: null, ampm: '', formattedDate: '', formattedTime: '', formattedDateTime: '', timezoneList: null, units: ['hour','minute','second','millisec'], control: null, /* * Override the default settings for all instances of the time picker. * @param settings object - the new settings to use as defaults (anonymous object) * @return the manager object */ setDefaults: function(settings) { extendRemove(this._defaults, settings || {}); return this; }, /* * Create a new Timepicker instance */ _newInst: function($input, o) { var tp_inst = new Timepicker(), inlineSettings = {}, fns = {}, overrides, i; for (var attrName in this._defaults) { if(this._defaults.hasOwnProperty(attrName)){ var attrValue = $input.attr('time:' + attrName); if (attrValue) { try { inlineSettings[attrName] = eval(attrValue); } catch (err) { inlineSettings[attrName] = attrValue; } } } } overrides = { beforeShow: function (input, dp_inst) { if ($.isFunction(tp_inst._defaults.evnts.beforeShow)) { return tp_inst._defaults.evnts.beforeShow.call($input[0], input, dp_inst, tp_inst); } }, onChangeMonthYear: function (year, month, dp_inst) { // Update the time as well : this prevents the time from disappearing from the $input field. tp_inst._updateDateTime(dp_inst); if ($.isFunction(tp_inst._defaults.evnts.onChangeMonthYear)) { tp_inst._defaults.evnts.onChangeMonthYear.call($input[0], year, month, dp_inst, tp_inst); } }, onClose: function (dateText, dp_inst) { if (tp_inst.timeDefined === true && $input.val() !== '') { tp_inst._updateDateTime(dp_inst); } if ($.isFunction(tp_inst._defaults.evnts.onClose)) { tp_inst._defaults.evnts.onClose.call($input[0], dateText, dp_inst, tp_inst); } } }; for (i in overrides) { if (overrides.hasOwnProperty(i)) { fns[i] = o[i] || null; } } tp_inst._defaults = $.extend({}, this._defaults, inlineSettings, o, overrides, { evnts:fns, timepicker: tp_inst // add timepicker as a property of datepicker: $.datepicker._get(dp_inst, 'timepicker'); }); tp_inst.amNames = $.map(tp_inst._defaults.amNames, function(val) { return val.toUpperCase(); }); tp_inst.pmNames = $.map(tp_inst._defaults.pmNames, function(val) { return val.toUpperCase(); }); // controlType is string - key to our this._controls if(typeof(tp_inst._defaults.controlType) === 'string'){ if($.fn[tp_inst._defaults.controlType] === undefined){ tp_inst._defaults.controlType = 'select'; } tp_inst.control = tp_inst._controls[tp_inst._defaults.controlType]; } // controlType is an object and must implement create, options, value methods else{ tp_inst.control = tp_inst._defaults.controlType; } if (tp_inst._defaults.timezoneList === null) { var timezoneList = ['-1200', '-1100', '-1000', '-0930', '-0900', '-0800', '-0700', '-0600', '-0500', '-0430', '-0400', '-0330', '-0300', '-0200', '-0100', '+0000', '+0100', '+0200', '+0300', '+0330', '+0400', '+0430', '+0500', '+0530', '+0545', '+0600', '+0630', '+0700', '+0800', '+0845', '+0900', '+0930', '+1000', '+1030', '+1100', '+1130', '+1200', '+1245', '+1300', '+1400']; if (tp_inst._defaults.timezoneIso8601) { timezoneList = $.map(timezoneList, function(val) { return val == '+0000' ? 'Z' : (val.substring(0, 3) + ':' + val.substring(3)); }); } tp_inst._defaults.timezoneList = timezoneList; } tp_inst.timezone = tp_inst._defaults.timezone; tp_inst.hour = tp_inst._defaults.hour < tp_inst._defaults.hourMin? tp_inst._defaults.hourMin : tp_inst._defaults.hour > tp_inst._defaults.hourMax? tp_inst._defaults.hourMax : tp_inst._defaults.hour; tp_inst.minute = tp_inst._defaults.minute < tp_inst._defaults.minuteMin? tp_inst._defaults.minuteMin : tp_inst._defaults.minute > tp_inst._defaults.minuteMax? tp_inst._defaults.minuteMax : tp_inst._defaults.minute; tp_inst.second = tp_inst._defaults.second < tp_inst._defaults.secondMin? tp_inst._defaults.secondMin : tp_inst._defaults.second > tp_inst._defaults.secondMax? tp_inst._defaults.secondMax : tp_inst._defaults.second; tp_inst.millisec = tp_inst._defaults.millisec < tp_inst._defaults.millisecMin? tp_inst._defaults.millisecMin : tp_inst._defaults.millisec > tp_inst._defaults.millisecMax? tp_inst._defaults.millisecMax : tp_inst._defaults.millisec; tp_inst.ampm = ''; tp_inst.$input = $input; if (o.altField) { tp_inst.$altInput = $(o.altField).css({ cursor: 'pointer' }).focus(function() { $input.trigger("focus"); }); } if (tp_inst._defaults.minDate === 0 || tp_inst._defaults.minDateTime === 0) { tp_inst._defaults.minDate = new Date(); } if (tp_inst._defaults.maxDate === 0 || tp_inst._defaults.maxDateTime === 0) { tp_inst._defaults.maxDate = new Date(); } // datepicker needs minDate/maxDate, timepicker needs minDateTime/maxDateTime.. if (tp_inst._defaults.minDate !== undefined && tp_inst._defaults.minDate instanceof Date) { tp_inst._defaults.minDateTime = new Date(tp_inst._defaults.minDate.getTime()); } if (tp_inst._defaults.minDateTime !== undefined && tp_inst._defaults.minDateTime instanceof Date) { tp_inst._defaults.minDate = new Date(tp_inst._defaults.minDateTime.getTime()); } if (tp_inst._defaults.maxDate !== undefined && tp_inst._defaults.maxDate instanceof Date) { tp_inst._defaults.maxDateTime = new Date(tp_inst._defaults.maxDate.getTime()); } if (tp_inst._defaults.maxDateTime !== undefined && tp_inst._defaults.maxDateTime instanceof Date) { tp_inst._defaults.maxDate = new Date(tp_inst._defaults.maxDateTime.getTime()); } tp_inst.$input.bind('focus', function() { tp_inst._onFocus(); }); return tp_inst; }, /* * add our sliders to the calendar */ _addTimePicker: function(dp_inst) { var currDT = (this.$altInput && this._defaults.altFieldTimeOnly) ? this.$input.val() + ' ' + this.$altInput.val() : this.$input.val(); this.timeDefined = this._parseTime(currDT); this._limitMinMaxDateTime(dp_inst, false); this._injectTimePicker(); }, /* * parse the time string from input value or _setTime */ _parseTime: function(timeString, withDate) { if (!this.inst) { this.inst = $.datepicker._getInst(this.$input[0]); } if (withDate || !this._defaults.timeOnly) { var dp_dateFormat = $.datepicker._get(this.inst, 'dateFormat'); try { var parseRes = parseDateTimeInternal(dp_dateFormat, this._defaults.timeFormat, timeString, $.datepicker._getFormatConfig(this.inst), this._defaults); if (!parseRes.timeObj) { return false; } $.extend(this, parseRes.timeObj); } catch (err) { $.timepicker.log("Error parsing the date/time string: " + err + "\ndate/time string = " + timeString + "\ntimeFormat = " + this._defaults.timeFormat + "\ndateFormat = " + dp_dateFormat); return false; } return true; } else { var timeObj = $.datepicker.parseTime(this._defaults.timeFormat, timeString, this._defaults); if (!timeObj) { return false; } $.extend(this, timeObj); return true; } }, /* * generate and inject html for timepicker into ui datepicker */ _injectTimePicker: function() { var $dp = this.inst.dpDiv, o = this.inst.settings, tp_inst = this, litem = '', uitem = '', max = {}, gridSize = {}, size = null; // Prevent displaying twice if ($dp.find("div.ui-timepicker-div").length === 0 && o.showTimepicker) { var noDisplay = ' style="display:none;"', html = '<div class="ui-timepicker-div'+ (o.isRTL? ' ui-timepicker-rtl' : '') +'"><dl>' + '<dt class="ui_tpicker_time_label"' + ((o.showTime) ? '' : noDisplay) + '>' + o.timeText + '</dt>' + '<dd class="ui_tpicker_time"' + ((o.showTime) ? '' : noDisplay) + '></dd>'; // Create the markup for(var i=0,l=this.units.length; i<l; i++){ litem = this.units[i]; uitem = litem.substr(0,1).toUpperCase() + litem.substr(1); // Added by Peter Medeiros: // - Figure out what the hour/minute/second max should be based on the step values. // - Example: if stepMinute is 15, then minMax is 45. max[litem] = parseInt((o[litem+'Max'] - ((o[litem+'Max'] - o[litem+'Min']) % o['step'+uitem])), 10); gridSize[litem] = 0; html += '<dt class="ui_tpicker_'+ litem +'_label"' + ((o['show'+uitem]) ? '' : noDisplay) + '>' + o[litem +'Text'] + '</dt>' + '<dd class="ui_tpicker_'+ litem +'"><div class="ui_tpicker_'+ litem +'_slider"' + ((o['show'+uitem]) ? '' : noDisplay) + '></div>'; if (o['show'+uitem] && o[litem+'Grid'] > 0) { html += '<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>'; if(litem == 'hour'){ for (var h = o[litem+'Min']; h <= max[litem]; h += parseInt(o[litem+'Grid'], 10)) { gridSize[litem]++; var tmph = $.datepicker.formatTime(useAmpm(o.pickerTimeFormat || o.timeFormat)? 'hht':'HH', {hour:h}, o); html += '<td data-for="'+litem+'">' + tmph + '</td>'; } } else{ for (var m = o[litem+'Min']; m <= max[litem]; m += parseInt(o[litem+'Grid'], 10)) { gridSize[litem]++; html += '<td data-for="'+litem+'">' + ((m < 10) ? '0' : '') + m + '</td>'; } } html += '</tr></table></div>'; } html += '</dd>'; } // Timezone html += '<dt class="ui_tpicker_timezone_label"' + ((o.showTimezone) ? '' : noDisplay) + '>' + o.timezoneText + '</dt>'; html += '<dd class="ui_tpicker_timezone" ' + ((o.showTimezone) ? '' : noDisplay) + '></dd>'; // Create the elements from string html += '</dl></div>'; var $tp = $(html); // if we only want time picker... if (o.timeOnly === true) { $tp.prepend('<div class="ui-widget-header ui-helper-clearfix ui-corner-all">' + '<div class="ui-datepicker-title">' + o.timeOnlyTitle + '</div>' + '</div>'); $dp.find('.ui-datepicker-header, .ui-datepicker-calendar').hide(); } // add sliders, adjust grids, add events for(var i=0,l=tp_inst.units.length; i<l; i++){ litem = tp_inst.units[i]; uitem = litem.substr(0,1).toUpperCase() + litem.substr(1); // add the slider tp_inst[litem+'_slider'] = tp_inst.control.create(tp_inst, $tp.find('.ui_tpicker_'+litem+'_slider'), litem, tp_inst[litem], o[litem+'Min'], max[litem], o['step'+uitem]); // adjust the grid and add click event if (o['show'+uitem] && o[litem+'Grid'] > 0) { size = 100 * gridSize[litem] * o[litem+'Grid'] / (max[litem] - o[litem+'Min']); $tp.find('.ui_tpicker_'+litem+' table').css({ width: size + "%", marginLeft: o.isRTL? '0' : ((size / (-2 * gridSize[litem])) + "%"), marginRight: o.isRTL? ((size / (-2 * gridSize[litem])) + "%") : '0', borderCollapse: 'collapse' }).find("td").click(function(e){ var $t = $(this), h = $t.html(), n = parseInt(h.replace(/[^0-9]/g),10), ap = h.replace(/[^apm]/ig), f = $t.data('for'); // loses scope, so we use data-for if(f == 'hour'){ if(ap.indexOf('p') !== -1 && n < 12){ n += 12; } else{ if(ap.indexOf('a') !== -1 && n === 12){ n = 0; } } } tp_inst.control.value(tp_inst, tp_inst[f+'_slider'], litem, n); tp_inst._onTimeChange(); tp_inst._onSelectHandler(); }) .css({ cursor: 'pointer', width: (100 / gridSize[litem]) + '%', textAlign: 'center', overflow: 'hidden' }); } // end if grid > 0 } // end for loop // Add timezone options this.timezone_select = $tp.find('.ui_tpicker_timezone').append('<select></select>').find("select"); $.fn.append.apply(this.timezone_select, $.map(o.timezoneList, function(val, idx) { return $("<option />").val(typeof val == "object" ? val.value : val).text(typeof val == "object" ? val.label : val); })); if (typeof(this.timezone) != "undefined" && this.timezone !== null && this.timezone !== "") { var local_date = new Date(this.inst.selectedYear, this.inst.selectedMonth, this.inst.selectedDay, 12); var local_timezone = $.timepicker.timeZoneOffsetString(local_date); if (local_timezone == this.timezone) { selectLocalTimeZone(tp_inst); } else { this.timezone_select.val(this.timezone); } } else { if (typeof(this.hour) != "undefined" && this.hour !== null && this.hour !== "") { this.timezone_select.val(o.defaultTimezone); } else { selectLocalTimeZone(tp_inst); } } this.timezone_select.change(function() { tp_inst._defaults.useLocalTimezone = false; tp_inst._onTimeChange(); tp_inst._onSelectHandler(); }); // End timezone options // inject timepicker into datepicker var $buttonPanel = $dp.find('.ui-datepicker-buttonpane'); if ($buttonPanel.length) { $buttonPanel.before($tp); } else { $dp.append($tp); } this.$timeObj = $tp.find('.ui_tpicker_time'); if (this.inst !== null) { var timeDefined = this.timeDefined; this._onTimeChange(); this.timeDefined = timeDefined; } // slideAccess integration: http://trentrichardson.com/2011/11/11/jquery-ui-sliders-and-touch-accessibility/ if (this._defaults.addSliderAccess) { var sliderAccessArgs = this._defaults.sliderAccessArgs, rtl = this._defaults.isRTL; sliderAccessArgs.isRTL = rtl; setTimeout(function() { // fix for inline mode if ($tp.find('.ui-slider-access').length === 0) { $tp.find('.ui-slider:visible').sliderAccess(sliderAccessArgs); // fix any grids since sliders are shorter var sliderAccessWidth = $tp.find('.ui-slider-access:eq(0)').outerWidth(true); if (sliderAccessWidth) { $tp.find('table:visible').each(function() { var $g = $(this), oldWidth = $g.outerWidth(), oldMarginLeft = $g.css(rtl? 'marginRight':'marginLeft').toString().replace('%', ''), newWidth = oldWidth - sliderAccessWidth, newMarginLeft = ((oldMarginLeft * newWidth) / oldWidth) + '%', css = { width: newWidth, marginRight: 0, marginLeft: 0 }; css[rtl? 'marginRight':'marginLeft'] = newMarginLeft; $g.css(css); }); } } }, 10); } // end slideAccess integration } }, /* * This function tries to limit the ability to go outside the * min/max date range */ _limitMinMaxDateTime: function(dp_inst, adjustSliders) { var o = this._defaults, dp_date = new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay); if (!this._defaults.showTimepicker) { return; } // No time so nothing to check here if ($.datepicker._get(dp_inst, 'minDateTime') !== null && $.datepicker._get(dp_inst, 'minDateTime') !== undefined && dp_date) { var minDateTime = $.datepicker._get(dp_inst, 'minDateTime'), minDateTimeDate = new Date(minDateTime.getFullYear(), minDateTime.getMonth(), minDateTime.getDate(), 0, 0, 0, 0); if (this.hourMinOriginal === null || this.minuteMinOriginal === null || this.secondMinOriginal === null || this.millisecMinOriginal === null) { this.hourMinOriginal = o.hourMin; this.minuteMinOriginal = o.minuteMin; this.secondMinOriginal = o.secondMin; this.millisecMinOriginal = o.millisecMin; } if (dp_inst.settings.timeOnly || minDateTimeDate.getTime() == dp_date.getTime()) { this._defaults.hourMin = minDateTime.getHours(); if (this.hour <= this._defaults.hourMin) { this.hour = this._defaults.hourMin; this._defaults.minuteMin = minDateTime.getMinutes(); if (this.minute <= this._defaults.minuteMin) { this.minute = this._defaults.minuteMin; this._defaults.secondMin = minDateTime.getSeconds(); if (this.second <= this._defaults.secondMin) { this.second = this._defaults.secondMin; this._defaults.millisecMin = minDateTime.getMilliseconds(); } else { if (this.millisec < this._defaults.millisecMin) { this.millisec = this._defaults.millisecMin; } this._defaults.millisecMin = this.millisecMinOriginal; } } else { this._defaults.secondMin = this.secondMinOriginal; this._defaults.millisecMin = this.millisecMinOriginal; } } else { this._defaults.minuteMin = this.minuteMinOriginal; this._defaults.secondMin = this.secondMinOriginal; this._defaults.millisecMin = this.millisecMinOriginal; } } else { this._defaults.hourMin = this.hourMinOriginal; this._defaults.minuteMin = this.minuteMinOriginal; this._defaults.secondMin = this.secondMinOriginal; this._defaults.millisecMin = this.millisecMinOriginal; } } if ($.datepicker._get(dp_inst, 'maxDateTime') !== null && $.datepicker._get(dp_inst, 'maxDateTime') !== undefined && dp_date) { var maxDateTime = $.datepicker._get(dp_inst, 'maxDateTime'), maxDateTimeDate = new Date(maxDateTime.getFullYear(), maxDateTime.getMonth(), maxDateTime.getDate(), 0, 0, 0, 0); if (this.hourMaxOriginal === null || this.minuteMaxOriginal === null || this.secondMaxOriginal === null) { this.hourMaxOriginal = o.hourMax; this.minuteMaxOriginal = o.minuteMax; this.secondMaxOriginal = o.secondMax; this.millisecMaxOriginal = o.millisecMax; } if (dp_inst.settings.timeOnly || maxDateTimeDate.getTime() == dp_date.getTime()) { this._defaults.hourMax = maxDateTime.getHours(); if (this.hour >= this._defaults.hourMax) { this.hour = this._defaults.hourMax; this._defaults.minuteMax = maxDateTime.getMinutes(); if (this.minute >= this._defaults.minuteMax) { this.minute = this._defaults.minuteMax; this._defaults.secondMax = maxDateTime.getSeconds(); if (this.second >= this._defaults.secondMax) { this.second = this._defaults.secondMax; this._defaults.millisecMax = maxDateTime.getMilliseconds(); } else { if (this.millisec > this._defaults.millisecMax) { this.millisec = this._defaults.millisecMax; } this._defaults.millisecMax = this.millisecMaxOriginal; } } else { this._defaults.secondMax = this.secondMaxOriginal; this._defaults.millisecMax = this.millisecMaxOriginal; } } else { this._defaults.minuteMax = this.minuteMaxOriginal; this._defaults.secondMax = this.secondMaxOriginal; this._defaults.millisecMax = this.millisecMaxOriginal; } } else { this._defaults.hourMax = this.hourMaxOriginal; this._defaults.minuteMax = this.minuteMaxOriginal; this._defaults.secondMax = this.secondMaxOriginal; this._defaults.millisecMax = this.millisecMaxOriginal; } } if (adjustSliders !== undefined && adjustSliders === true) { var hourMax = parseInt((this._defaults.hourMax - ((this._defaults.hourMax - this._defaults.hourMin) % this._defaults.stepHour)), 10), minMax = parseInt((this._defaults.minuteMax - ((this._defaults.minuteMax - this._defaults.minuteMin) % this._defaults.stepMinute)), 10), secMax = parseInt((this._defaults.secondMax - ((this._defaults.secondMax - this._defaults.secondMin) % this._defaults.stepSecond)), 10), millisecMax = parseInt((this._defaults.millisecMax - ((this._defaults.millisecMax - this._defaults.millisecMin) % this._defaults.stepMillisec)), 10); if (this.hour_slider) { this.control.options(this, this.hour_slider, 'hour', { min: this._defaults.hourMin, max: hourMax }); this.control.value(this, this.hour_slider, 'hour', this.hour - (this.hour % this._defaults.stepHour)); } if (this.minute_slider) { this.control.options(this, this.minute_slider, 'minute', { min: this._defaults.minuteMin, max: minMax }); this.control.value(this, this.minute_slider, 'minute', this.minute - (this.minute % this._defaults.stepMinute)); } if (this.second_slider) { this.control.options(this, this.second_slider, 'second', { min: this._defaults.secondMin, max: secMax }); this.control.value(this, this.second_slider, 'second', this.second - (this.second % this._defaults.stepSecond)); } if (this.millisec_slider) { this.control.options(this, this.millisec_slider, 'millisec', { min: this._defaults.millisecMin, max: millisecMax }); this.control.value(this, this.millisec_slider, 'millisec', this.millisec - (this.millisec % this._defaults.stepMillisec)); } } }, /* * when a slider moves, set the internal time... * on time change is also called when the time is updated in the text field */ _onTimeChange: function() { var hour = (this.hour_slider) ? this.control.value(this, this.hour_slider, 'hour') : false, minute = (this.minute_slider) ? this.control.value(this, this.minute_slider, 'minute') : false, second = (this.second_slider) ? this.control.value(this, this.second_slider, 'second') : false, millisec = (this.millisec_slider) ? this.control.value(this, this.millisec_slider, 'millisec') : false, timezone = (this.timezone_select) ? this.timezone_select.val() : false, o = this._defaults, pickerTimeFormat = o.pickerTimeFormat || o.timeFormat, pickerTimeSuffix = o.pickerTimeSuffix || o.timeSuffix; if (typeof(hour) == 'object') { hour = false; } if (typeof(minute) == 'object') { minute = false; } if (typeof(second) == 'object') { second = false; } if (typeof(millisec) == 'object') { millisec = false; } if (typeof(timezone) == 'object') { timezone = false; } if (hour !== false) { hour = parseInt(hour, 10); } if (minute !== false) { minute = parseInt(minute, 10); } if (second !== false) { second = parseInt(second, 10); } if (millisec !== false) { millisec = parseInt(millisec, 10); } var ampm = o[hour < 12 ? 'amNames' : 'pmNames'][0]; // If the update was done in the input field, the input field should not be updated. // If the update was done using the sliders, update the input field. var hasChanged = (hour != this.hour || minute != this.minute || second != this.second || millisec != this.millisec || (this.ampm.length > 0 && (hour < 12) != ($.inArray(this.ampm.toUpperCase(), this.amNames) !== -1)) || ((this.timezone === null && timezone != this.defaultTimezone) || (this.timezone !== null && timezone != this.timezone))); if (hasChanged) { if (hour !== false) { this.hour = hour; } if (minute !== false) { this.minute = minute; } if (second !== false) { this.second = second; } if (millisec !== false) { this.millisec = millisec; } if (timezone !== false) { this.timezone = timezone; } if (!this.inst) { this.inst = $.datepicker._getInst(this.$input[0]); } this._limitMinMaxDateTime(this.inst, true); } if (useAmpm(o.timeFormat)) { this.ampm = ampm; } // Updates the time within the timepicker this.formattedTime = $.datepicker.formatTime(o.timeFormat, this, o); if (this.$timeObj) { if(pickerTimeFormat === o.timeFormat){ this.$timeObj.text(this.formattedTime + pickerTimeSuffix); } else{ this.$timeObj.text($.datepicker.formatTime(pickerTimeFormat, this, o) + pickerTimeSuffix); } } this.timeDefined = true; if (hasChanged) { this._updateDateTime(); } }, /* * call custom onSelect. * bind to sliders slidestop, and grid click. */ _onSelectHandler: function() { var onSelect = this._defaults.onSelect || this.inst.settings.onSelect; var inputEl = this.$input ? this.$input[0] : null; if (onSelect && inputEl) { onSelect.apply(inputEl, [this.formattedDateTime, this]); } }, /* * update our input with the new date time.. */ _updateDateTime: function(dp_inst) { dp_inst = this.inst || dp_inst; var dt = $.datepicker._daylightSavingAdjust(new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay)), dateFmt = $.datepicker._get(dp_inst, 'dateFormat'), formatCfg = $.datepicker._getFormatConfig(dp_inst), timeAvailable = dt !== null && this.timeDefined; this.formattedDate = $.datepicker.formatDate(dateFmt, (dt === null ? new Date() : dt), formatCfg); var formattedDateTime = this.formattedDate; // if a slider was changed but datepicker doesn't have a value yet, set it if(dp_inst.lastVal==""){ dp_inst.currentYear=dp_inst.selectedYear; dp_inst.currentMonth=dp_inst.selectedMonth; dp_inst.currentDay=dp_inst.selectedDay; } /* * remove following lines to force every changes in date picker to change the input value * Bug descriptions: when an input field has a default value, and click on the field to pop up the date picker. * If the user manually empty the value in the input field, the date picker will never change selected value. */ //if (dp_inst.lastVal !== undefined && (dp_inst.lastVal.length > 0 && this.$input.val().length === 0)) { // return; //} if (this._defaults.timeOnly === true) { formattedDateTime = this.formattedTime; } else if (this._defaults.timeOnly !== true && (this._defaults.alwaysSetTime || timeAvailable)) { formattedDateTime += this._defaults.separator + this.formattedTime + this._defaults.timeSuffix; } this.formattedDateTime = formattedDateTime; if (!this._defaults.showTimepicker) { this.$input.val(this.formattedDate); } else if (this.$altInput && this._defaults.altFieldTimeOnly === true) { this.$altInput.val(this.formattedTime); this.$input.val(this.formattedDate); } else if (this.$altInput) { this.$input.val(formattedDateTime); var altFormattedDateTime = '', altSeparator = this._defaults.altSeparator ? this._defaults.altSeparator : this._defaults.separator, altTimeSuffix = this._defaults.altTimeSuffix ? this._defaults.altTimeSuffix : this._defaults.timeSuffix; if (this._defaults.altFormat) altFormattedDateTime = $.datepicker.formatDate(this._defaults.altFormat, (dt === null ? new Date() : dt), formatCfg); else altFormattedDateTime = this.formattedDate; if (altFormattedDateTime) altFormattedDateTime += altSeparator; if (this._defaults.altTimeFormat) altFormattedDateTime += $.datepicker.formatTime(this._defaults.altTimeFormat, this, this._defaults) + altTimeSuffix; else altFormattedDateTime += this.formattedTime + altTimeSuffix; this.$altInput.val(altFormattedDateTime); } else { this.$input.val(formattedDateTime); } this.$input.trigger("change"); }, _onFocus: function() { if (!this.$input.val() && this._defaults.defaultValue) { this.$input.val(this._defaults.defaultValue); var inst = $.datepicker._getInst(this.$input.get(0)), tp_inst = $.datepicker._get(inst, 'timepicker'); if (tp_inst) { if (tp_inst._defaults.timeOnly && (inst.input.val() != inst.lastVal)) { try { $.datepicker._updateDatepicker(inst); } catch (err) { $.timepicker.log(err); } } } } }, /* * Small abstraction to control types * We can add more, just be sure to follow the pattern: create, options, value */ _controls: { // slider methods slider: { create: function(tp_inst, obj, unit, val, min, max, step){ var rtl = tp_inst._defaults.isRTL; // if rtl go -60->0 instead of 0->60 return obj.prop('slide', null).slider({ orientation: "horizontal", value: rtl? val*-1 : val, min: rtl? max*-1 : min, max: rtl? min*-1 : max, step: step, slide: function(event, ui) { tp_inst.control.value(tp_inst, $(this), unit, rtl? ui.value*-1:ui.value); tp_inst._onTimeChange(); }, stop: function(event, ui) { tp_inst._onSelectHandler(); } }); }, options: function(tp_inst, obj, unit, opts, val){ if(tp_inst._defaults.isRTL){ if(typeof(opts) == 'string'){ if(opts == 'min' || opts == 'max'){ if(val !== undefined) return obj.slider(opts, val*-1); return Math.abs(obj.slider(opts)); } return obj.slider(opts); } var min = opts.min, max = opts.max; opts.min = opts.max = null; if(min !== undefined) opts.max = min * -1; if(max !== undefined) opts.min = max * -1; return obj.slider(opts); } if(typeof(opts) == 'string' && val !== undefined) return obj.slider(opts, val); return obj.slider(opts); }, value: function(tp_inst, obj, unit, val){ if(tp_inst._defaults.isRTL){ if(val !== undefined) return obj.slider('value', val*-1); return Math.abs(obj.slider('value')); } if(val !== undefined) return obj.slider('value', val); return obj.slider('value'); } }, // select methods select: { create: function(tp_inst, obj, unit, val, min, max, step){ var sel = '<select class="ui-timepicker-select" data-unit="'+ unit +'" data-min="'+ min +'" data-max="'+ max +'" data-step="'+ step +'">', ul = tp_inst._defaults.timeFormat.indexOf('t') !== -1? 'toLowerCase':'toUpperCase', m = 0; for(var i=min; i<=max; i+=step){ sel += '<option value="'+ i +'"'+ (i==val? ' selected':'') +'>'; if(unit == 'hour' && useAmpm(tp_inst._defaults.pickerTimeFormat || tp_inst._defaults.timeFormat)) sel += $.datepicker.formatTime("hh TT", {hour:i}, tp_inst._defaults); else if(unit == 'millisec' || i >= 10) sel += i; else sel += '0'+ i.toString(); sel += '</option>'; } sel += '</select>'; obj.children('select').remove(); $(sel).appendTo(obj).change(function(e){ tp_inst._onTimeChange(); tp_inst._onSelectHandler(); }); return obj; }, options: function(tp_inst, obj, unit, opts, val){ var o = {}, $t = obj.children('select'); if(typeof(opts) == 'string'){ if(val === undefined) return $t.data(opts); o[opts] = val; } else o = opts; return tp_inst.control.create(tp_inst, obj, $t.data('unit'), $t.val(), o.min || $t.data('min'), o.max || $t.data('max'), o.step || $t.data('step')); }, value: function(tp_inst, obj, unit, val){ var $t = obj.children('select'); if(val !== undefined) return $t.val(val); return $t.val(); } } } // end _controls }); $.fn.extend({ /* * shorthand just to use timepicker.. */ timepicker: function(o) { o = o || {}; var tmp_args = Array.prototype.slice.call(arguments); if (typeof o == 'object') { tmp_args[0] = $.extend(o, { timeOnly: true }); } return $(this).each(function() { $.fn.datetimepicker.apply($(this), tmp_args); }); }, /* * extend timepicker to datepicker */ datetimepicker: function(o) { o = o || {}; var tmp_args = arguments; if (typeof(o) == 'string') { if (o == 'getDate') { return $.fn.datepicker.apply($(this[0]), tmp_args); } else { return this.each(function() { var $t = $(this); $t.datepicker.apply($t, tmp_args); }); } } else { return this.each(function() { var $t = $(this); $t.datepicker($.timepicker._newInst($t, o)._defaults); }); } } }); /* * Public Utility to parse date and time */ $.datepicker.parseDateTime = function(dateFormat, timeFormat, dateTimeString, dateSettings, timeSettings) { var parseRes = parseDateTimeInternal(dateFormat, timeFormat, dateTimeString, dateSettings, timeSettings); if (parseRes.timeObj) { var t = parseRes.timeObj; parseRes.date.setHours(t.hour, t.minute, t.second, t.millisec); } return parseRes.date; }; /* * Public utility to parse time */ $.datepicker.parseTime = function(timeFormat, timeString, options) { var o = extendRemove(extendRemove({}, $.timepicker._defaults), options || {}); // Strict parse requires the timeString to match the timeFormat exactly var strictParse = function(f, s, o){ // pattern for standard and localized AM/PM markers var getPatternAmpm = function(amNames, pmNames) { var markers = []; if (amNames) { $.merge(markers, amNames); } if (pmNames) { $.merge(markers, pmNames); } markers = $.map(markers, function(val) { return val.replace(/[.*+?|()\[\]{}\\]/g, '\\$&'); }); return '(' + markers.join('|') + ')?'; }; // figure out position of time elements.. cause js cant do named captures var getFormatPositions = function(timeFormat) { var finds = timeFormat.toLowerCase().match(/(h{1,2}|m{1,2}|s{1,2}|l{1}|t{1,2}|z|'.*?')/g), orders = { h: -1, m: -1, s: -1, l: -1, t: -1, z: -1 }; if (finds) { for (var i = 0; i < finds.length; i++) { if (orders[finds[i].toString().charAt(0)] == -1) { orders[finds[i].toString().charAt(0)] = i + 1; } } } return orders; }; var regstr = '^' + f.toString() .replace(/([hH]{1,2}|mm?|ss?|[tT]{1,2}|[lz]|'.*?')/g, function (match) { var ml = match.length; switch (match.charAt(0).toLowerCase()) { case 'h': return ml === 1? '(\\d?\\d)':'(\\d{'+ml+'})'; case 'm': return ml === 1? '(\\d?\\d)':'(\\d{'+ml+'})'; case 's': return ml === 1? '(\\d?\\d)':'(\\d{'+ml+'})'; case 'l': return '(\\d?\\d?\\d)'; case 'z': return '(z|[-+]\\d\\d:?\\d\\d|\\S+)?'; case 't': return getPatternAmpm(o.amNames, o.pmNames); default: // literal escaped in quotes return '(' + match.replace(/\'/g, "").replace(/(\.|\$|\^|\\|\/|\(|\)|\[|\]|\?|\+|\*)/g, function (m) { return "\\" + m; }) + ')?'; } }) .replace(/\s/g, '\\s?') + o.timeSuffix + '$', order = getFormatPositions(f), ampm = '', treg; treg = s.match(new RegExp(regstr, 'i')); var resTime = { hour: 0, minute: 0, second: 0, millisec: 0 }; if (treg) { if (order.t !== -1) { if (treg[order.t] === undefined || treg[order.t].length === 0) { ampm = ''; resTime.ampm = ''; } else { ampm = $.inArray(treg[order.t].toUpperCase(), o.amNames) !== -1 ? 'AM' : 'PM'; resTime.ampm = o[ampm == 'AM' ? 'amNames' : 'pmNames'][0]; } } if (order.h !== -1) { if (ampm == 'AM' && treg[order.h] == '12') { resTime.hour = 0; // 12am = 0 hour } else { if (ampm == 'PM' && treg[order.h] != '12') { resTime.hour = parseInt(treg[order.h], 10) + 12; // 12pm = 12 hour, any other pm = hour + 12 } else { resTime.hour = Number(treg[order.h]); } } } if (order.m !== -1) { resTime.minute = Number(treg[order.m]); } if (order.s !== -1) { resTime.second = Number(treg[order.s]); } if (order.l !== -1) { resTime.millisec = Number(treg[order.l]); } if (order.z !== -1 && treg[order.z] !== undefined) { var tz = treg[order.z].toUpperCase(); switch (tz.length) { case 1: // Z tz = o.timezoneIso8601 ? 'Z' : '+0000'; break; case 5: // +hhmm if (o.timezoneIso8601) { tz = tz.substring(1) == '0000' ? 'Z' : tz.substring(0, 3) + ':' + tz.substring(3); } break; case 6: // +hh:mm if (!o.timezoneIso8601) { tz = tz == 'Z' || tz.substring(1) == '00:00' ? '+0000' : tz.replace(/:/, ''); } else { if (tz.substring(1) == '00:00') { tz = 'Z'; } } break; } resTime.timezone = tz; } return resTime; } return false; };// end strictParse // First try JS Date, if that fails, use strictParse var looseParse = function(f,s,o){ try{ var d = new Date('2012-01-01 '+ s); if(isNaN(d.getTime())){ d = new Date('2012-01-01T'+ s); if(isNaN(d.getTime())){ d = new Date('01/01/2012 '+ s); if(isNaN(d.getTime())){ throw "Unable to parse time with native Date: "+ s; } } } return { hour: d.getHours(), minute: d.getMinutes(), second: d.getSeconds(), millisec: d.getMilliseconds(), timezone: $.timepicker.timeZoneOffsetString(d) }; } catch(err){ try{ return strictParse(f,s,o); } catch(err2){ $.timepicker.log("Unable to parse \ntimeString: "+ s +"\ntimeFormat: "+ f); } } return false; }; // end looseParse if(typeof o.parse === "function"){ return o.parse(timeFormat, timeString, o) } if(o.parse === 'loose'){ return looseParse(timeFormat, timeString, o); } return strictParse(timeFormat, timeString, o); }; /* * Public utility to format the time * format = string format of the time * time = a {}, not a Date() for timezones * options = essentially the regional[].. amNames, pmNames, ampm */ $.datepicker.formatTime = function(format, time, options) { options = options || {}; options = $.extend({}, $.timepicker._defaults, options); time = $.extend({ hour: 0, minute: 0, second: 0, millisec: 0, timezone: '+0000' }, time); var tmptime = format, ampmName = options.amNames[0], hour = parseInt(time.hour, 10); if (hour > 11) { ampmName = options.pmNames[0]; } tmptime = tmptime.replace(/(?:HH?|hh?|mm?|ss?|[tT]{1,2}|[lz]|('.*?'|".*?"))/g, function(match) { switch (match) { case 'HH': return ('0' + hour).slice(-2); case 'H': return hour; case 'hh': return ('0' + convert24to12(hour)).slice(-2); case 'h': return convert24to12(hour); case 'mm': return ('0' + time.minute).slice(-2); case 'm': return time.minute; case 'ss': return ('0' + time.second).slice(-2); case 's': return time.second; case 'l': return ('00' + time.millisec).slice(-3); case 'z': return time.timezone === null? options.defaultTimezone : time.timezone; case 'T': return ampmName.charAt(0).toUpperCase(); case 'TT': return ampmName.toUpperCase(); case 't': return ampmName.charAt(0).toLowerCase(); case 'tt': return ampmName.toLowerCase(); default: return match.replace(/\'/g, "") || "'"; } }); tmptime = $.trim(tmptime); return tmptime; }; /* * the bad hack :/ override datepicker so it doesnt close on select // inspired: http://stackoverflow.com/questions/1252512/jquery-datepicker-prevent-closing-picker-when-clicking-a-date/1762378#1762378 */ $.datepicker._base_selectDate = $.datepicker._selectDate; $.datepicker._selectDate = function(id, dateStr) { var inst = this._getInst($(id)[0]), tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { tp_inst._limitMinMaxDateTime(inst, true); inst.inline = inst.stay_open = true; //This way the onSelect handler called from calendarpicker get the full dateTime this._base_selectDate(id, dateStr); inst.inline = inst.stay_open = false; this._notifyChange(inst); this._updateDatepicker(inst); } else { this._base_selectDate(id, dateStr); } }; /* * second bad hack :/ override datepicker so it triggers an event when changing the input field * and does not redraw the datepicker on every selectDate event */ $.datepicker._base_updateDatepicker = $.datepicker._updateDatepicker; $.datepicker._updateDatepicker = function(inst) { // don't popup the datepicker if there is another instance already opened var input = inst.input[0]; if ($.datepicker._curInst && $.datepicker._curInst != inst && $.datepicker._datepickerShowing && $.datepicker._lastInput != input) { return; } if (typeof(inst.stay_open) !== 'boolean' || inst.stay_open === false) { this._base_updateDatepicker(inst); // Reload the time control when changing something in the input text field. var tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { tp_inst._addTimePicker(inst); // if (tp_inst._defaults.useLocalTimezone) { //checks daylight saving with the new date. // var date = new Date(inst.selectedYear, inst.selectedMonth, inst.selectedDay, 12); // selectLocalTimeZone(tp_inst, date); // tp_inst._onTimeChange(); // } } } }; /* * third bad hack :/ override datepicker so it allows spaces and colon in the input field */ $.datepicker._base_doKeyPress = $.datepicker._doKeyPress; $.datepicker._doKeyPress = function(event) { var inst = $.datepicker._getInst(event.target), tp_inst = $.datepicker._get(inst, 'timepicker'); if (tp_inst) { if ($.datepicker._get(inst, 'constrainInput')) { var ampm = useAmpm(tp_inst._defaults.timeFormat), dateChars = $.datepicker._possibleChars($.datepicker._get(inst, 'dateFormat')), datetimeChars = tp_inst._defaults.timeFormat.toString() .replace(/[hms]/g, '') .replace(/TT/g, ampm ? 'APM' : '') .replace(/Tt/g, ampm ? 'AaPpMm' : '') .replace(/tT/g, ampm ? 'AaPpMm' : '') .replace(/T/g, ampm ? 'AP' : '') .replace(/tt/g, ampm ? 'apm' : '') .replace(/t/g, ampm ? 'ap' : '') + " " + tp_inst._defaults.separator + tp_inst._defaults.timeSuffix + (tp_inst._defaults.showTimezone ? tp_inst._defaults.timezoneList.join('') : '') + (tp_inst._defaults.amNames.join('')) + (tp_inst._defaults.pmNames.join('')) + dateChars, chr = String.fromCharCode(event.charCode === undefined ? event.keyCode : event.charCode); return event.ctrlKey || (chr < ' ' || !dateChars || datetimeChars.indexOf(chr) > -1); } } return $.datepicker._base_doKeyPress(event); }; /* * Fourth bad hack :/ override _updateAlternate function used in inline mode to init altField */ $.datepicker._base_updateAlternate = $.datepicker._updateAlternate; /* Update any alternate field to synchronise with the main field. */ $.datepicker._updateAlternate = function(inst) { var tp_inst = this._get(inst, 'timepicker'); if(tp_inst){ var altField = tp_inst._defaults.altField; if (altField) { // update alternate field too var altFormat = tp_inst._defaults.altFormat || tp_inst._defaults.dateFormat, date = this._getDate(inst), formatCfg = $.datepicker._getFormatConfig(inst), altFormattedDateTime = '', altSeparator = tp_inst._defaults.altSeparator ? tp_inst._defaults.altSeparator : tp_inst._defaults.separator, altTimeSuffix = tp_inst._defaults.altTimeSuffix ? tp_inst._defaults.altTimeSuffix : tp_inst._defaults.timeSuffix, altTimeFormat = tp_inst._defaults.altTimeFormat !== null ? tp_inst._defaults.altTimeFormat : tp_inst._defaults.timeFormat; altFormattedDateTime += $.datepicker.formatTime(altTimeFormat, tp_inst, tp_inst._defaults) + altTimeSuffix; if(!tp_inst._defaults.timeOnly && !tp_inst._defaults.altFieldTimeOnly && date !== null){ if(tp_inst._defaults.altFormat) altFormattedDateTime = $.datepicker.formatDate(tp_inst._defaults.altFormat, date, formatCfg) + altSeparator + altFormattedDateTime; else altFormattedDateTime = tp_inst.formattedDate + altSeparator + altFormattedDateTime; } $(altField).val(altFormattedDateTime); } } else{ $.datepicker._base_updateAlternate(inst); } }; /* * Override key up event to sync manual input changes. */ $.datepicker._base_doKeyUp = $.datepicker._doKeyUp; $.datepicker._doKeyUp = function(event) { var inst = $.datepicker._getInst(event.target), tp_inst = $.datepicker._get(inst, 'timepicker'); if (tp_inst) { if (tp_inst._defaults.timeOnly && (inst.input.val() != inst.lastVal)) { try { $.datepicker._updateDatepicker(inst); } catch (err) { $.timepicker.log(err); } } } return $.datepicker._base_doKeyUp(event); }; /* * override "Today" button to also grab the time. */ $.datepicker._base_gotoToday = $.datepicker._gotoToday; $.datepicker._gotoToday = function(id) { var inst = this._getInst($(id)[0]), $dp = inst.dpDiv; this._base_gotoToday(id); var tp_inst = this._get(inst, 'timepicker'); selectLocalTimeZone(tp_inst); var now = new Date(); this._setTime(inst, now); $('.ui-datepicker-today', $dp).click(); }; /* * Disable & enable the Time in the datetimepicker */ $.datepicker._disableTimepickerDatepicker = function(target) { var inst = this._getInst(target); if (!inst) { return; } var tp_inst = this._get(inst, 'timepicker'); $(target).datepicker('getDate'); // Init selected[Year|Month|Day] if (tp_inst) { tp_inst._defaults.showTimepicker = false; tp_inst._updateDateTime(inst); } }; $.datepicker._enableTimepickerDatepicker = function(target) { var inst = this._getInst(target); if (!inst) { return; } var tp_inst = this._get(inst, 'timepicker'); $(target).datepicker('getDate'); // Init selected[Year|Month|Day] if (tp_inst) { tp_inst._defaults.showTimepicker = true; tp_inst._addTimePicker(inst); // Could be disabled on page load tp_inst._updateDateTime(inst); } }; /* * Create our own set time function */ $.datepicker._setTime = function(inst, date) { var tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { var defaults = tp_inst._defaults; // calling _setTime with no date sets time to defaults tp_inst.hour = date ? date.getHours() : defaults.hour; tp_inst.minute = date ? date.getMinutes() : defaults.minute; tp_inst.second = date ? date.getSeconds() : defaults.second; tp_inst.millisec = date ? date.getMilliseconds() : defaults.millisec; //check if within min/max times.. tp_inst._limitMinMaxDateTime(inst, true); tp_inst._onTimeChange(); tp_inst._updateDateTime(inst); } }; /* * Create new public method to set only time, callable as $().datepicker('setTime', date) */ $.datepicker._setTimeDatepicker = function(target, date, withDate) { var inst = this._getInst(target); if (!inst) { return; } var tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { this._setDateFromField(inst); var tp_date; if (date) { if (typeof date == "string") { tp_inst._parseTime(date, withDate); tp_date = new Date(); tp_date.setHours(tp_inst.hour, tp_inst.minute, tp_inst.second, tp_inst.millisec); } else { tp_date = new Date(date.getTime()); } if (tp_date.toString() == 'Invalid Date') { tp_date = undefined; } this._setTime(inst, tp_date); } } }; /* * override setDate() to allow setting time too within Date object */ $.datepicker._base_setDateDatepicker = $.datepicker._setDateDatepicker; $.datepicker._setDateDatepicker = function(target, date) { var inst = this._getInst(target); if (!inst) { return; } var tp_date = (date instanceof Date) ? new Date(date.getTime()) : date; this._updateDatepicker(inst); this._base_setDateDatepicker.apply(this, arguments); this._setTimeDatepicker(target, tp_date, true); }; /* * override getDate() to allow getting time too within Date object */ $.datepicker._base_getDateDatepicker = $.datepicker._getDateDatepicker; $.datepicker._getDateDatepicker = function(target, noDefault) { var inst = this._getInst(target); if (!inst) { return; } var tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { // if it hasn't yet been defined, grab from field if(inst.lastVal === undefined){ this._setDateFromField(inst, noDefault); } var date = this._getDate(inst); if (date && tp_inst._parseTime($(target).val(), tp_inst.timeOnly)) { date.setHours(tp_inst.hour, tp_inst.minute, tp_inst.second, tp_inst.millisec); } return date; } return this._base_getDateDatepicker(target, noDefault); }; /* * override parseDate() because UI 1.8.14 throws an error about "Extra characters" * An option in datapicker to ignore extra format characters would be nicer. */ $.datepicker._base_parseDate = $.datepicker.parseDate; $.datepicker.parseDate = function(format, value, settings) { var date; try { date = this._base_parseDate(format, value, settings); } catch (err) { // Hack! The error message ends with a colon, a space, and // the "extra" characters. We rely on that instead of // attempting to perfectly reproduce the parsing algorithm. date = this._base_parseDate(format, value.substring(0,value.length-(err.length-err.indexOf(':')-2)), settings); $.timepicker.log("Error parsing the date string: " + err + "\ndate string = " + value + "\ndate format = " + format); } return date; }; /* * override formatDate to set date with time to the input */ $.datepicker._base_formatDate = $.datepicker._formatDate; $.datepicker._formatDate = function(inst, day, month, year) { var tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { tp_inst._updateDateTime(inst); return tp_inst.$input.val(); } return this._base_formatDate(inst); }; /* * override options setter to add time to maxDate(Time) and minDate(Time). MaxDate */ $.datepicker._base_optionDatepicker = $.datepicker._optionDatepicker; $.datepicker._optionDatepicker = function(target, name, value) { var inst = this._getInst(target), name_clone; if (!inst) { return null; } var tp_inst = this._get(inst, 'timepicker'); if (tp_inst) { var min = null, max = null, onselect = null, overrides = tp_inst._defaults.evnts, fns = {}, prop; if (typeof name == 'string') { // if min/max was set with the string if (name === 'minDate' || name === 'minDateTime') { min = value; } else if (name === 'maxDate' || name === 'maxDateTime') { max = value; } else if (name === 'onSelect') { onselect = value; } else if (overrides.hasOwnProperty(name)) { if (typeof (value) === 'undefined') { return overrides[name]; } fns[name] = value; name_clone = {}; //empty results in exiting function after overrides updated } } else if (typeof name == 'object') { //if min/max was set with the JSON if (name.minDate) { min = name.minDate; } else if (name.minDateTime) { min = name.minDateTime; } else if (name.maxDate) { max = name.maxDate; } else if (name.maxDateTime) { max = name.maxDateTime; } for (prop in overrides) { if (overrides.hasOwnProperty(prop) && name[prop]) { fns[prop] = name[prop]; } } } for (prop in fns) { if (fns.hasOwnProperty(prop)) { overrides[prop] = fns[prop]; if (!name_clone) { name_clone = $.extend({}, name);} delete name_clone[prop]; } } if (name_clone && isEmptyObject(name_clone)) { return; } if (min) { //if min was set if (min === 0) { min = new Date(); } else { min = new Date(min); } tp_inst._defaults.minDate = min; tp_inst._defaults.minDateTime = min; } else if (max) { //if max was set if (max === 0) { max = new Date(); } else { max = new Date(max); } tp_inst._defaults.maxDate = max; tp_inst._defaults.maxDateTime = max; } else if (onselect) { tp_inst._defaults.onSelect = onselect; } } if (value === undefined) { return this._base_optionDatepicker.call($.datepicker, target, name); } return this._base_optionDatepicker.call($.datepicker, target, name_clone || name, value); }; /* * jQuery isEmptyObject does not check hasOwnProperty - if someone has added to the object prototype, * it will return false for all objects */ var isEmptyObject = function(obj) { var prop; for (prop in obj) { if (obj.hasOwnProperty(obj)) { return false; } } return true; }; /* * jQuery extend now ignores nulls! */ var extendRemove = function(target, props) { $.extend(target, props); for (var name in props) { if (props[name] === null || props[name] === undefined) { target[name] = props[name]; } } return target; }; /* * Determine by the time format if should use ampm * Returns true if should use ampm, false if not */ var useAmpm = function(timeFormat){ return (timeFormat.indexOf('t') !== -1 && timeFormat.indexOf('h') !== -1); }; /* * Converts 24 hour format into 12 hour * Returns 12 hour without leading 0 */ var convert24to12 = function(hour) { if (hour > 12) { hour = hour - 12; } if (hour == 0) { hour = 12; } return String(hour); }; /* * Splits datetime string into date ans time substrings. * Throws exception when date can't be parsed * Returns [dateString, timeString] */ var splitDateTime = function(dateFormat, dateTimeString, dateSettings, timeSettings) { try { // The idea is to get the number separator occurances in datetime and the time format requested (since time has // fewer unknowns, mostly numbers and am/pm). We will use the time pattern to split. var separator = timeSettings && timeSettings.separator ? timeSettings.separator : $.timepicker._defaults.separator, format = timeSettings && timeSettings.timeFormat ? timeSettings.timeFormat : $.timepicker._defaults.timeFormat, timeParts = format.split(separator), // how many occurances of separator may be in our format? timePartsLen = timeParts.length, allParts = dateTimeString.split(separator), allPartsLen = allParts.length; if (allPartsLen > 1) { return [ allParts.splice(0,allPartsLen-timePartsLen).join(separator), allParts.splice(0,timePartsLen).join(separator) ]; } } catch (err) { $.timepicker.log('Could not split the date from the time. Please check the following datetimepicker options' + "\nthrown error: " + err + "\ndateTimeString" + dateTimeString + "\ndateFormat = " + dateFormat + "\nseparator = " + timeSettings.separator + "\ntimeFormat = " + timeSettings.timeFormat); if (err.indexOf(":") >= 0) { // Hack! The error message ends with a colon, a space, and // the "extra" characters. We rely on that instead of // attempting to perfectly reproduce the parsing algorithm. var dateStringLength = dateTimeString.length - (err.length - err.indexOf(':') - 2), timeString = dateTimeString.substring(dateStringLength); return [$.trim(dateTimeString.substring(0, dateStringLength)), $.trim(dateTimeString.substring(dateStringLength))]; } else { throw err; } } return [dateTimeString, '']; }; /* * Internal function to parse datetime interval * Returns: {date: Date, timeObj: Object}, where * date - parsed date without time (type Date) * timeObj = {hour: , minute: , second: , millisec: } - parsed time. Optional */ var parseDateTimeInternal = function(dateFormat, timeFormat, dateTimeString, dateSettings, timeSettings) { var date; var splitRes = splitDateTime(dateFormat, dateTimeString, dateSettings, timeSettings); date = $.datepicker._base_parseDate(dateFormat, splitRes[0], dateSettings); if (splitRes[1] !== '') { var timeString = splitRes[1], parsedTime = $.datepicker.parseTime(timeFormat, timeString, timeSettings); if (parsedTime === null) { throw 'Wrong time format'; } return { date: date, timeObj: parsedTime }; } else { return { date: date }; } }; /* * Internal function to set timezone_select to the local timezone */ var selectLocalTimeZone = function(tp_inst, date) { if (tp_inst && tp_inst.timezone_select) { tp_inst._defaults.useLocalTimezone = true; var now = typeof date !== 'undefined' ? date : new Date(); var tzoffset = $.timepicker.timeZoneOffsetString(now); if (tp_inst._defaults.timezoneIso8601) { tzoffset = tzoffset.substring(0, 3) + ':' + tzoffset.substring(3); } tp_inst.timezone_select.val(tzoffset); } }; /* * Create a Singleton Insance */ $.timepicker = new Timepicker(); /** * Get the timezone offset as string from a date object (eg '+0530' for UTC+5.5) * @param date * @return string */ $.timepicker.timeZoneOffsetString = function(date) { var off = date.getTimezoneOffset() * -1, minutes = off % 60, hours = (off - minutes) / 60; return (off >= 0 ? '+' : '-') + ('0' + (hours * 101).toString()).slice(-2) + ('0' + (minutes * 101).toString()).slice(-2); }; /** * Calls `timepicker()` on the `startTime` and `endTime` elements, and configures them to * enforce date range limits. * n.b. The input value must be correctly formatted (reformatting is not supported) * @param Element startTime * @param Element endTime * @param obj options Options for the timepicker() call * @return jQuery */ $.timepicker.timeRange = function(startTime, endTime, options) { return $.timepicker.handleRange('timepicker', startTime, endTime, options); }; /** * Calls `datetimepicker` on the `startTime` and `endTime` elements, and configures them to * enforce date range limits. * @param Element startTime * @param Element endTime * @param obj options Options for the `timepicker()` call. Also supports `reformat`, * a boolean value that can be used to reformat the input values to the `dateFormat`. * @param string method Can be used to specify the type of picker to be added * @return jQuery */ $.timepicker.dateTimeRange = function(startTime, endTime, options) { $.timepicker.dateRange(startTime, endTime, options, 'datetimepicker'); }; /** * Calls `method` on the `startTime` and `endTime` elements, and configures them to * enforce date range limits. * @param Element startTime * @param Element endTime * @param obj options Options for the `timepicker()` call. Also supports `reformat`, * a boolean value that can be used to reformat the input values to the `dateFormat`. * @param string method Can be used to specify the type of picker to be added * @return jQuery */ $.timepicker.dateRange = function(startTime, endTime, options, method) { method = method || 'datepicker'; $.timepicker.handleRange(method, startTime, endTime, options); }; /** * Calls `method` on the `startTime` and `endTime` elements, and configures them to * enforce date range limits. * @param string method Can be used to specify the type of picker to be added * @param Element startTime * @param Element endTime * @param obj options Options for the `timepicker()` call. Also supports `reformat`, * a boolean value that can be used to reformat the input values to the `dateFormat`. * @return jQuery */ $.timepicker.handleRange = function(method, startTime, endTime, options) { $.fn[method].call(startTime, $.extend({ onClose: function(dateText, inst) { checkDates(this, endTime, dateText); }, onSelect: function(selectedDateTime) { selected(this, endTime, 'minDate'); } }, options, options.start)); $.fn[method].call(endTime, $.extend({ onClose: function(dateText, inst) { checkDates(this, startTime, dateText); }, onSelect: function(selectedDateTime) { selected(this, startTime, 'maxDate'); } }, options, options.end)); // timepicker doesn't provide access to its 'timeFormat' option, // nor could I get datepicker.formatTime() to behave with times, so I // have disabled reformatting for timepicker if (method != 'timepicker' && options.reformat) { $([startTime, endTime]).each(function() { var format = $(this)[method].call($(this), 'option', 'dateFormat'), date = new Date($(this).val()); if ($(this).val() && date) { $(this).val($.datepicker.formatDate(format, date)); } }); } checkDates(startTime, endTime, startTime.val()); function checkDates(changed, other, dateText) { if (other.val() && (new Date(startTime.val()) > new Date(endTime.val()))) { other.val(dateText); } } selected(startTime, endTime, 'minDate'); selected(endTime, startTime, 'maxDate'); function selected(changed, other, option) { if (!$(changed).val()) { return; } var date = $(changed)[method].call($(changed), 'getDate'); // timepicker doesn't implement 'getDate' and returns a jQuery if (date.getTime) { $(other)[method].call($(other), 'option', option, date); } } return $([startTime.get(0), endTime.get(0)]); }; /** * Log error or data to the console during error or debugging * @param Object err pass any type object to log to the console during error or debugging * @return void */ $.timepicker.log = function(err){ if(window.console) console.log(err); }; /* * Keep up with the version */ $.timepicker.version = "1.2"; })(jQuery); /* assets/wpuf/js/upload.js */ ;(function($) { /** * Upload handler helper * * @param string {browse_button} browse_button ID of the pickfile * @param string {container} container ID of the wrapper * @param int {max} maximum number of file uplaods * @param string {type} */ window.WPUF_Uploader = function (browse_button, container, max, type, allowed_type, max_file_size) { this.removed_files = []; this.container = container; this.browse_button = browse_button; this.max = max || 1; this.count = $('#' + container).find('.wpuf-attachment-list > li').length; //count how many items are there this.perFileCount = 0; //file count on each upload this.UploadedFiles = 0; //file count on each upload //if no element found on the page, bail out if( !$('#'+browse_button).length ) { return; } // enable drag option for ordering $( "ul.wpuf-attachment-list" ).sortable({ placeholder: "highlight" }); $( "ul.wpuf-attachment-list" ).disableSelection(); //instantiate the uploader this.uploader = new plupload.Uploader({ runtimes: 'html5,html4', browse_button: browse_button, container: container, multipart: true, multipart_params: { action: 'wpuf_upload_file', form_id: $( '#' + browse_button ).data('form_id') }, max_file_count : 2, multiple_queues: false, multi_selection: ( ( browse_button == 'wpuf-avatar-pickfiles' || browse_button == 'wpuf-featured_image-pickfiles' ) ? false : true ), urlstream_upload: true, file_data_name: 'wpuf_file', max_file_size: max_file_size + 'kb', url: wpuf_frontend_upload.plupload.url + '&type=' + type, flash_swf_url: wpuf_frontend_upload.flash_swf_url, filters: [{ title: 'Allowed Files', extensions: allowed_type }] }); //attach event handlers this.uploader.bind('Init', $.proxy(this, 'init')); this.uploader.bind('FilesAdded', $.proxy(this, 'added')); this.uploader.bind('QueueChanged', $.proxy(this, 'upload')); this.uploader.bind('UploadProgress', $.proxy(this, 'progress')); this.uploader.bind('Error', $.proxy(this, 'error')); this.uploader.bind('FileUploaded', $.proxy(this, 'uploaded')); this.uploader.init(); $('#' + container).on('click', 'a.attachment-delete', $.proxy(this.removeAttachment, this)); return this.uploader; }; WPUF_Uploader.prototype = { init: function (up, params) { this.showHide(); $('#' + this.container).prepend('<div class="wpuf-file-warning"></div>'); }, showHide: function () { if ( this.count >= this.max) { if ( this.count > this.max ) { $('#' + this.container + ' .wpuf-file-warning').html( wpuf_frontend_upload.warning ); } else { $('#' + this.container + ' .wpuf-file-warning').html( wpuf_frontend_upload.warning ); } $('#' + this.container).find('.file-selector').hide(); return; }; $('#' + this.container + ' .wpuf-file-warning').html( '' ); $('#' + this.container).find('.file-selector').show(); }, added: function (up, files) { var $container = $('#' + this.container).find('.wpuf-attachment-upload-filelist'); this.showHide(); $.each(files, function(i, file) { $(".wpuf-submit-button").attr("disabled", "disabled"); $container.append( '<div class="upload-item" id="' + file.id + '"><div class="progress progress-striped active"><div class="bar"></div></div><div class="filename original">' + file.name + ' (' + plupload.formatSize(file.size) + ') <b></b>' + '</div></div>'); }); up.refresh(); // Reposition Flash/Silverlight up.start(); }, upload: function (uploader) { this.count = uploader.files.length - this.removed_files.length ; this.showHide(); }, progress: function (up, file) { var item = $('#' + file.id); $('.bar', item).css({ width: file.percent + '%' }); $('.percent', item).html( file.percent + '%' ); }, error: function (up, error) { $('#' + this.container).find('#' + error.file.id).remove(); var msg = ''; switch (error.code) { case -600: msg = wpuf_frontend_upload.plupload.size_error; break; case -601: msg = wpuf_frontend_upload.plupload.type_error; break; default: msg = 'Error #' + error.code + ': ' + error.message; break; } alert(msg); this.count -= 1; this.showHide(); this.uploader.refresh(); }, uploaded: function (up, file, response) { // var res = $.parseJSON(response.response); var self = this; $('#' + file.id + " b").html("100%"); $('#' + file.id).remove(); if(response.response !== 'error') { this.perFileCount++; this.UploadedFiles++; var $container = $('#' + this.container).find('.wpuf-attachment-list'); $container.append(response.response); if ( this.perFileCount > this.max ) { var attach_id = $('.wpuf-image-wrap:last a.attachment-delete',$container).data('attach_id'); self.removeExtraAttachment(attach_id); $('.wpuf-image-wrap',$container).last().remove(); this.perFileCount--; } } else { alert(response.error); this.count -= 1; this.showHide(); } var uploaded = this.UploadedFiles, FileProgress = up.files.length, imageCount = $('ul.wpuf-attachment-list > li').length; if ( imageCount >= this.max ) { $('#' + this.container).find('.file-selector').hide(); } if ( FileProgress === uploaded ) { if ( typeof grecaptcha !== 'undefined' && !grecaptcha.getResponse().length ) { return; } $(".wpuf-submit-button").removeAttr("disabled"); } }, removeAttachment: function(e) { e.preventDefault(); var self = this, el = $(e.currentTarget); swal({ text: wpuf_frontend_upload.confirmMsg, type: 'warning', showCancelButton: true, confirmButtonColor: '#d54e21', confirmButtonText: wpuf_frontend_upload.delete_it, cancelButtonText: wpuf_frontend_upload.cancel_it, confirmButtonClass: 'btn btn-success', cancelButtonClass: 'btn btn-danger', }).then(function () { var data = { 'attach_id' : el.data('attach_id'), 'nonce' : wpuf_frontend_upload.nonce, 'action' : 'wpuf_file_del' }; self.removed_files.push(data); jQuery('#del_attach').val(el.data('attach_id')); jQuery.post(wpuf_frontend_upload.ajaxurl, data, function() { self.perFileCount--; el.parent().parent().remove(); self.count -= 1; self.showHide(); self.uploader.refresh(); }); }); }, removeExtraAttachment : function( attach_id ) { var self = this; var data = { 'attach_id' : attach_id, 'nonce' : wpuf_frontend_upload.nonce, 'action' : 'wpuf_file_del' }; this.removed_files.push(data); jQuery.post(wpuf_frontend_upload.ajaxurl, data, function() { self.count -= 1; self.showHide(); self.uploader.refresh(); }); } }; })(jQuery);
[+]
..
[+]
utils
[-] vendor.js
[edit]
[-] form-builder-components.min.js
[edit]
[-] spa-mixins.js
[edit]
[-] spa-app.min.js
[edit]
[-] spa-mixins.min.js
[edit]
[-] form-builder-components.js
[edit]
[-] wpuf-form-builder-contact-forms.min.js
[edit]
[-] weforms.min.js
[edit]
[+]
vendor
[-] wpuf-form-builder-contact-forms.js
[edit]
[-] vendor.min.js
[edit]
[-] weforms-shortcode.js
[edit]
[-] gutenblock.js
[edit]
[-] spa-app.js
[edit]
[-] weforms.js
[edit]
[-] blockFrameSetup.js
[edit]