-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathbp-group-announcements.php
334 lines (278 loc) · 8.9 KB
/
bp-group-announcements.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
<?php
/**
* Bootstrap the BP_Group_Announcements extension
*/
function bpga_bootstrap() {
bp_register_group_extension( 'BP_Group_Announcements' );
}
add_action( 'bp_init', 'bpga_bootstrap' );
/**
* Implementation of BP_Group_Extension
*
* Registers the group extension and provides a display method
*
* @since 1.0
*/
class BP_Group_Announcements extends BP_Group_Extension {
var $enable_create_step = false;
var $enable_nav_item = true;
var $enable_edit_item = false;
/**
* Constructor
*
* @since 1.0
* */
public function __construct() {
// localization
$this->localization();
// extension variables
$this->name = __( 'Announcements', 'bpga' );
$this->slug = bpga_get_slug();
$this->nav_item_position = 13;
// Disable the activity update form on the group home page. Props r-a-y
add_action( 'bp_before_group_activity_post_form', function() { ob_start(); }, 9999 );
add_action( 'bp_after_group_activity_post_form', function() { ob_end_clean(); }, 0 );
// Because this isn't the group home page, we have to ensure
// that 'groups' is passed as the object type with the post form
add_action( 'bp_activity_post_form_options', array( $this, 'object_input' ) );
// In the activity directory post form, there is a dropdown menu allowing
// users to select the group to post their update in
//
// We don't want non-admins to be able to post in groups, so we blank out the
// groups by returning false in bp_has_groups()
add_action( 'bp_before_activity_post_form', array( $this, 'remove_groups' ) );
add_action( 'bp_after_activity_post_form', array( $this, 'restore_groups' ) );
// Make sure that only announcements show up on that page
add_filter( 'bp_ajax_querystring', array( $this, 'filter_querystring' ), 9999 );
// disable RBE - we don't support replying to group announcements via email
add_filter( 'bp_rbe_block_activity_item', array( $this, 'disable_rbe' ), 20, 2 );
// disable activity commenting on group announcements
add_filter( 'bp_activity_can_comment', array( $this, 'disable_activity_comments' ) );
// Fake BP into thinking this is the group activity tab.
add_filter(
'bp_is_current_component',
function( $is, $component ) {
if ( 'activity' !== $component ) {
return $is;
}
remove_filter( 'bp_current_action', array( __CLASS__, 'action_filter_callback' ) );
if ( ! bp_is_groups_component() || ! bp_is_current_action( 'announcements' ) ) {
return $is;
}
add_filter( 'bp_current_action', array( __CLASS__, 'action_filter_callback' ) );
return true;
},
10,
2
);
// Fake BP into thinking that this is the activity directory, for AJAX.
add_filter( 'bp_current_action', array( __CLASS__, 'action_filter_callback' ) );
}
/**
* Action filter callback.
*/
public static function action_filter_callback( $action ) {
remove_filter( 'bp_current_action', array( __CLASS__, 'action_filter_callback' ) );
if ( ! bp_is_groups_component() || ! bp_is_current_action( 'announcements' ) ) {
return $action;
}
if ( ! wp_doing_ajax() ) {
return $action;
}
$db = debug_backtrace();
$is = false;
foreach ( $db as $_db ) {
if ( 'bp_nouveau_ajax_post_update' === $_db['function'] ) {
$is = true;
break;
}
}
if ( $is ) {
return '';
}
return $action;
}
/**
* Display the content of the Announcements tab
*
* @since 1.0
*
* @param int $group_id Available only on BP 2.2+.
*/
public function display( $group_id = null ) {
if ( bp_group_is_admin() || bp_current_user_can( 'bp_moderate' ) ) {
$group_role = 'an administrator';
} else if ( bp_group_is_mod() ) {
$group_role = 'a moderator';
}
?>
<h3><?php _e( 'Announcements', 'bpga' ) ?></h3>
<p><?php _e( 'On this page, you’ll see announcements that administrators and moderators have left for the group.', 'bpga' ) ?></p>
<?php if ( bpga_can_post_group_announcements() ) : ?>
<?php $group_role = bp_group_is_admin() || bp_current_user_can( 'bp_moderate' ) ? __( 'administrator', 'bpga' ) : __( 'moderator', 'bpga' ) ?>
<p><?php printf( __( 'As %1$s in %2$s, you can post announcements to the group’s activity stream.', 'bpga' ), $group_role, bp_get_group_name() ) ?></p>
<?php bp_locate_template( array( 'activity/post-form.php'), true ) ?>
<?php endif ?>
<div class="activity single-group">
<?php bp_locate_template( array( 'activity/activity-loop.php' ), true ) ?>
</div>
<?php
}
/**
* The post-form template logic won't provide the necessary -object
* -post-in hidden inputs because this is not the group home page. So
* we provide them manually
*
* @since 1.0
*/
public static function object_input() {
if ( bp_is_group() && bp_is_current_action( bpga_get_slug() ) ) {
echo '<input type="hidden" id="whats-new-post-object" name="whats-new-post-object" value="groups" />';
echo '<input type="hidden" id="whats-new-post-in" name="whats-new-post-in" value="' . bp_get_group_id() . '" />';
}
}
/**
* Make sure that the Announcement tab shows only updates
*
* @since 1.0.1
*/
public static function filter_querystring( $qs ) {
if ( bp_is_group() && bp_is_current_action( bpga_get_slug() ) ) {
if ( '' != $qs ) {
$qs .= '&';
}
$qs .= 'type=activity_update&action=activity_update';
}
return $qs;
}
/**
* Custom textdomain loader.
*
* Checks WP_LANG_DIR for the .mo file first, then the plugin's language folder.
* Allows for a custom language file other than those packaged with the plugin.
*
* @since 1.0.2
*
* @uses get_locale() To get the current locale
* @uses load_textdomain() Loads a .mo file into WP
* @return bool True on success, false on failure
*/
public function localization() {
// Use the WP plugin locale filter from load_plugin_textdomain()
$locale = apply_filters( 'plugin_locale', get_locale(), 'bpga' );
$mofile = sprintf( '%1$s-%2$s.mo', 'bpga', $locale );
$mofile_global = trailingslashit( constant( 'WP_LANG_DIR' ) ) . $mofile;
$mofile_local = trailingslashit( dirname( __FILE__ ) ) . 'languages/' . $mofile;
// look in /wp-content/languages/ first
if ( is_readable( $mofile_global ) ) {
return load_textdomain( 'bpga', $mofile_global );
// if that doesn't exist, check for bundled language file
} elseif ( is_readable( $mofile_local ) ) {
return load_textdomain( 'bpga', $mofile_local );
// no language file exists
} else {
return false;
}
}
/**
* Return no groups for the logged-in user when on the activity directory's
* post form.
*
* This is done so no groups can be listed under the post form dropdown menu.
*
* Note: This only occurs for users without the 'bp_moderate' capability.
* We don't do checks for group admins or mods as that would be intensive.
*
* @since 1.0.2
*
* @uses current_user_can() To see if the current user can do something
*/
public function remove_groups() {
if ( ! bp_current_user_can( 'bp_moderate' ) )
add_filter( 'bp_has_groups', '__return_false', 1, 1 );
}
/**
* Restore groups for the logged-in user after the activity directory post
* form.
*
* This is to prevent any unintended behavior when returning false for
* bp_has_groups().
*
* Note: We restore groups for users without the 'bp_moderate' capability.
*
* @since 1.0.2
*
* @uses current_user_can() To see if the current user can do something
* @see BP_Group_Announcements::remove_groups()
*/
public function restore_groups() {
if ( ! bp_current_user_can( 'bp_moderate' ) )
remove_filter( 'bp_has_groups', '__return_false', 1, 1 );
}
/**
* Disable Reply By Email header injection for group announcements.
*
* @since 1.0.4
*
* @param bool $retval
* @param BP_Activity_Activity $activity
* @return bool
*/
public function disable_rbe( $retval, $activity ) {
if ( ! bp_is_current_action( 'announcements' ) ) {
return $retval;
}
// not a group activity item? stop!
if ( $activity->component != 'groups' ) {
return $retval;
}
// not an activity update? stop!
if ( $activity->type != 'activity_update' ) {
return $retval;
}
return true;
}
/**
* Disable activity commenting for group announcements.
*
* @since 1.0.4
*
* @param bool $retval
* @return bool
*/
public function disable_activity_comments( $retval ) {
if ( ! bp_is_current_action( 'announcements' ) ) {
return $retval;
}
if ( ! bp_is_group() ) {
return $retval;
}
return false;
}
}
/**
* Return the Announcements slug
*/
function bpga_get_slug() {
return apply_filters( 'bpga_get_slug', 'announcements' );
}
/**
* Can the current user post group announcements?
*
* By default, posting is limited to
*
* @since 1.0
*/
function bpga_can_post_group_announcements() {
$can_post = false;
if ( bp_is_group() ) {
if ( bp_current_user_can( 'bp_moderate' ) ||
bp_group_is_admin() ||
bp_group_is_mod()
)
{
$can_post = true;
}
}
return apply_filters( 'bpga_can_post_group_announcements', $can_post );
}