I want to call a javascript function that will be conditional upon a user\'s response to the confirm box.
For example, I have the following anchor:
<%
I had a similar issue (How to use inline :confirm option for html helpers with AJAX calls?). @Micah's answer, even though works, is not what "Rails 3 way" would be.
link_to 'Sign Out', destroy_session_path, remote: true, confirm: 'Are you sure that you would like to sign out?', method: :delete
In the controller change respond_to
block to answer to js
create a js file with the name that corresponds to your method, e.g. destroy_session.js.coffee
jQuery ->
$("form[data-remote]").on "ajax:success", (e, data, status, xhr) ->
$(e.currentTarget).closest('tr').fadeOut()`
Hope that helps
By following the link_to
source, I see that the :confirm
modifier is passed to the convert_options_to_data_attributes method, which points to the ujs script that is bundled with Rails these days (the unobtrusive javascript via jQuery). Here we find that ultimately the user's response is passed to an event called confirm:complete
by using the data-confirm
attribute in the html.
So it appears that the answer is "no, you cannot pass a callback through the url helper". But you can put a callback in your app/javascript
to listen for this event. This seems to be the most unobtrusive way to accomplish my goal, considering that I am still letting rails handle the event prevention and propagation. I wait for all of this to happen, and then call my function.
$(document).on('confirm:complete', function (e, answer) {
if (answer) {
// user confirmed!
myCallbackFunction();
} else {
// user canceled!
}
});
In 2020, the accepted answer didn't work for me. I ended up doing something like this instead:
$(document).on('confirm:complete', function (e) {
if (e.originalEvent.detail[0]) {
// user confirmed!
myCallbackFunction();
} else {
// user canceled!
}
});