X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=js%2Fcrm.ajax.js;h=3ea776c4f834190e1cd261bae28f1c509a8a3f9b;hb=e4a6290df32ba56cbbd81501e4258a2ca056347d;hp=b7813d7ec5896ee0b3ef009463e3ebac4821274b;hpb=07218de046ef00cb6f5be43179f5db18afa0352d;p=civicrm-core.git diff --git a/js/crm.ajax.js b/js/crm.ajax.js index b7813d7ec5..3ea776c4f8 100644 --- a/js/crm.ajax.js +++ b/js/crm.ajax.js @@ -272,6 +272,14 @@ that._handleOrderLinks(); that.element.trigger('crmLoad', data); if (that.options.crmForm) that.element.trigger('crmFormLoad', data); + // This is only needed by forms that load via ajax but submit without ajax, e.g. configure contribution page tabs + // TODO: remove this when those forms have been converted to use ajax submit + if (data.status === 'form_error' && $.isPlainObject(data.errors)) { + that.element.trigger('crmFormError', data); + $.each(data.errors, function(formElement, msg) { + $('[name="'+formElement+'"]', that.element).crmError(msg); + }); + } }).fail(function(data, msg, status) { that._onFailure(data, status); }); @@ -450,17 +458,20 @@ }, settings.ajaxForm)); if (settings.openInline) { settings.autoClose = $el.crmSnippet('isOriginalUrl'); - $(settings.openInline, this).not(exclude + ', .crm-popup').click(function(event) { + $(this).on('click', settings.openInline, function(e) { + if ($(this).is(exclude + ', .crm-popup')) { + return; + } if ($(this).hasClass('open-inline-noreturn')) { // Force reset of original url $el.data('civiCrmSnippet')._originalUrl = $(this).attr('href'); } $el.crmSnippet('option', 'url', $(this).attr('href')).crmSnippet('refresh'); - return false; + e.preventDefault(); }); } - // Show form buttons as part of the dialog if ($el.data('uiDialog')) { + // Show form buttons as part of the dialog var buttonContainers = '.crm-submit-buttons, .action-link', buttons = [], added = []; @@ -486,6 +497,15 @@ $el.parents(buttonContainers).css({height: 0, padding: 0, margin: 0, overflow: 'hidden'}).find('.crm-button-icon').hide(); }); $el.dialog('option', 'buttons', buttons); + + // Show done button for non-ajax dialogs (e.g. file downloads) + $(this).on('submit', "form[data-no-ajax-submit=true]", function() { + $el.dialog('option', 'buttons', [{ + text: ts('Done'), + icons: {primary: 'ui-icon-close'}, + click: function() {$(this).dialog('close');} + }]); + }); } // Allow a button to prevent ajax submit $('input[data-no-ajax-submit=true]').click(function() {