Opened 12 years ago
Last modified 7 years ago
#4458 reopened defect (bug)
Activity update deletion and the "Are you sure" dialog box
Reported by: | tifire | Owned by: | |
---|---|---|---|
Milestone: | Awaiting Contributions | Priority: | normal |
Severity: | normal | Version: | |
Component: | Activity | Keywords: | dev-feedback needs-patch |
Cc: |
Description
I assume the "Are you sure" dialog box is required for every activity update deletion, so I think this is a buddypress bug.
I have tested this on testbp.org. Here is what I found:
1) Right after posting an activity update, no "Are you sure" dialog box shows up if I click the "delete" button. The activity update is just deleted.
2) After posting an activity update, if I refresh the page then click the "delete" button, the "Are you sure" dialog box shows up for me to confirm the deletion.
3) If I refresh the page, select any of the filter ( everything, updates, new groups, group memberships, etc), all my activity updates can be just deleted without seeing the "Are you sure" dialog box.
Attachments (1)
Change History (12)
#1
@
12 years ago
- Milestone changed from Awaiting Review to 1.7
- Severity changed from critical to normal
#2
@
12 years ago
- Keywords dev-feedback added
What's our policy on fixing this kind of issue for bp-default/bp-legacy?
#3
@
12 years ago
The issue is the jQuery is bound to DOM elements that exist at page load time. Elements added in later aren't bound to the click detection, so our message box doesn't appear. If this can be fixed without a huge rewrite of BP-Default's JS, I say we should do it -- ideally we not to ought have differing behaviour for the "same" button.
#4
@
12 years ago
Right. In the rest of the activity stream, we use proper delegation. But in the case of our .confirm
js, it's printed in the document head, with bp_core_confirmation_js()
. Something like 4458.diff should work, in theory. I had to change the priority to 1 so that it was printed before the main site scripts, otherwise it wouldn't fire in time. Still, there's a race condition somewhere that's causing the confirm script not to fire in all cases. If anyone has any bright ideas....
FWIW this is not a bp-default issue, as we print this bit of script in core.
#7
@
12 years ago
- Milestone changed from 1.7 to Future Release
- Resolution fixed deleted
- Status changed from closed to reopened
The delegation solution won't work globally. See #4843. We're going to have to live with this bug for now.
#8
@
11 years ago
This could probably be fixed by changing some return false;
statements to e.preventDefault();
For example, line 169 of bp-themes/bp-default/_inc/global.js uses a return false;
which will definitely break bubbling, but that's exactly what the jQuery method's for. If this is a lost cause, please let me know, otherwise I'll happily whip up a quick patch.
#9
@
11 years ago
- Keywords needs-patch added
vhauri - Absolutely, please do write a patch. Could you please patch against bp-templates/bp-legacy/js/buddypress.js
? bp-default is being EOLed.
#10
@
7 years ago
@boonebgorges @hnla with the bp-nouveau work going on, would this potentially be an obsolete ticket?
#11
@
7 years ago
Nouveau JS handles this correctly, I'm inclined to close this ticket due to age and lack of suggested patch forthcoming & fact we have lived with this minor issue for this long.
For the sake of it I just tried patching, can add e.preventDefault();
and that does at least allow the success message to be returned, but figuring out a confirm dialogue without also running the default one escapes me & haven't really further time to lend to this.
Confirmed on testbp which is currently running 1.6.