Completed
Push — master ( 2cfa6f...8927a4 )
by Zack
10:00 queued 06:05
created

includes/class-admin.php (1 issue)

Severity

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
class GravityView_Admin {
4
5
	function __construct() {
6
7
		if( ! is_admin() ) { return; }
8
9
		// If Gravity Forms isn't active or compatibile, stop loading
10
		if( false === GravityView_Compatibility::is_valid() ) {
11
			return;
12
		}
13
14
		$this->include_required_files();
15
		$this->add_hooks();
16
	}
17
18
	/**
19
	 * @since 1.15
20
	 * @return void
21
	 */
22
	private function include_required_files() {
23
24
		// Migrate Class
25
		require_once( GRAVITYVIEW_DIR . 'includes/class-gravityview-migrate.php' );
26
27
		// Don't load tooltips if on Gravity Forms, otherwise it overrides translations
28
		if( class_exists( 'GFCommon' ) && class_exists( 'GFForms' ) && !GFForms::is_gravity_page() ) {
29
			require_once( GFCommon::get_base_path() . '/tooltips.php' );
30
		}
31
32
		require_once( GRAVITYVIEW_DIR . 'includes/admin/metaboxes/class-gravityview-admin-metaboxes.php' );
33
		require_once( GRAVITYVIEW_DIR . 'includes/admin/entry-list.php' );
34
		require_once( GRAVITYVIEW_DIR . 'includes/class-gravityview-change-entry-creator.php' );
35
36
		/** @since 1.15 **/
37
		require_once( GRAVITYVIEW_DIR . 'includes/admin/class-gravityview-support-port.php' );
38
39
		/** @since 1.6 */
40
		require_once( GRAVITYVIEW_DIR . 'includes/class-gravityview-admin-duplicate-view.php' );
41
42
		/** @since 1.17 */
43
		require_once( GRAVITYVIEW_DIR . 'includes/admin/class-gravityview-admin-no-conflict.php' );
44
	}
45
46
	/**
47
	 * @since 1.7.5
48
	 * @return void
49
	 */
50
	private function add_hooks() {
51
52
		// Filter Admin messages
53
		add_filter( 'post_updated_messages', array( $this, 'post_updated_messages' ) );
54
		add_filter( 'bulk_post_updated_messages', array( $this, 'post_updated_messages' ) );
55
56
		add_filter( 'plugin_action_links_'. plugin_basename( GRAVITYVIEW_FILE ) , array( $this, 'plugin_action_links' ) );
57
58
		add_action( 'plugins_loaded', array( $this, 'backend_actions' ), 100 );
59
60
	}
61
62
	/**
63
	 * Get text for no views found.
64
	 *
65
	 * @since 1.18 Moved to GravityView_Admin
66
	 *
67
	 * @return string HTML message with no container tags.
68
	 */
69
	public static function no_views_text() {
70
71
		// Floaty the Astronaut says "oi"
72
		$image = self::get_floaty();
73
74
		if ( GVCommon::has_cap( 'edit_gravityviews' ) ) {
75
			$output = sprintf( esc_attr__( "%sYou don't have any active views. Let&rsquo;s go %screate one%s!%s\n\nIf you feel like you're lost in space and need help getting started, check out the %sGetting Started%s page.", 'gravityview' ), '<h3>', '<a href="' . admin_url( 'post-new.php?post_type=gravityview' ) . '">', '</a>', '</h3>', '<a href="' . admin_url( 'edit.php?post_type=gravityview&page=gv-getting-started' ) . '">', '</a>' );
76
		} else {
77
			$output = esc_attr__( 'There are no active Views', 'gravityview' );
78
		}
79
80
		return $image . wpautop( $output );
81
	}
82
83
	/**
84
	 * Function to launch admin objects
85
	 *
86
	 * @access public
87
	 * @return void
88
	 */
89
	public function backend_actions() {
90
91
		/** @define "GRAVITYVIEW_DIR" "../" */
92
		include_once( GRAVITYVIEW_DIR .'includes/admin/class.field.type.php' );
93
		include_once( GRAVITYVIEW_DIR .'includes/admin/class.render.settings.php' );
94
		include_once( GRAVITYVIEW_DIR .'includes/admin/class-gravityview-admin-view-item.php' );
95
		include_once( GRAVITYVIEW_DIR .'includes/admin/class-gravityview-admin-view-field.php' );
96
		include_once( GRAVITYVIEW_DIR .'includes/admin/class-gravityview-admin-view-widget.php' );
97
		include_once( GRAVITYVIEW_DIR .'includes/class-admin-views.php' );
98
		include_once( GRAVITYVIEW_DIR .'includes/class-admin-welcome.php' );
99
		include_once( GRAVITYVIEW_DIR .'includes/class-admin-add-shortcode.php' );
100
		include_once( GRAVITYVIEW_DIR .'includes/class-admin-approve-entries.php' );
101
102
		/**
103
		 * @action `gravityview_include_backend_actions` Triggered after all GravityView admin files are loaded
104
		 *
105
		 * Nice place to insert extensions' backend stuff
106
		 */
107
		do_action('gravityview_include_backend_actions');
108
	}
109
110
	/**
111
	 * Modify plugin action links at plugins screen
112
	 *
113
	 * @since 1.15 Added check for `gravityview_view_settings` and `gravityview_support_port` capabilities
114
	 * @access public
115
	 * @static
116
	 * @param array $links Array of action links under GravityView on the plugin page
117
	 * @return array Action links with Settings and Support included, if the user has the appropriate caps
118
	 */
119
	public static function plugin_action_links( $links ) {
120
121
		$actions = array();
122
123
		if( GVCommon::has_cap( 'gravityview_view_settings' ) ) {
124
			$actions[] = sprintf( '<a href="%s">%s</a>', admin_url( 'edit.php?post_type=gravityview&page=gravityview_settings' ), esc_html__( 'Settings', 'gravityview' ) );
125
		}
126
127
		if( GVCommon::has_cap( 'gravityview_support_port' ) ) {
128
			$actions[] = '<a href="http://docs.gravityview.co">' . esc_html__( 'Support', 'gravityview' ) . '</a>';
129
		}
130
131
		return array_merge( $actions, $links );
132
	}
133
134
	/**
135
	 * Get an image of our intrepid explorer friend
136
	 * @return string HTML image tag with floaty's cute mug on it
137
	 */
138
	public static function get_floaty() {
139
		return gravityview_get_floaty();
140
	}
141
142
	/**
143
	 * Filter Admin messages
144
	 *
145
	 * @param  array      $messages Existing messages
146
	 * @return array                Messages with GravityView views!
147
	 */
148
	function post_updated_messages( $messages, $bulk_counts = NULL ) {
149
		global $post;
150
151
		$post_id = get_the_ID();
152
153
		// By default, there will only be one item being modified.
154
		// When in the `bulk_post_updated_messages` filter, there will be passed a number
155
		// of modified items that will override this array.
156
		$bulk_counts = is_null( $bulk_counts ) ? array( 'updated' => 1 , 'locked' => 1 , 'deleted' => 1 , 'trashed' => 1, 'untrashed' => 1 ) : $bulk_counts;
157
158
		// If we're starting fresh, a new form was created.
159
		// We should let the user know this is the case.
160
		$start_fresh = get_post_meta( $post_id, '_gravityview_start_fresh', true );
161
162
		$new_form_text = '';
163
164
		if( !empty( $start_fresh ) ) {
165
166
			// Get the form that was created
167
			$connected_form = gravityview_get_form_id( $post_id );
168
169
			if( !empty( $connected_form ) ) {
170
				$form = gravityview_get_form( $connected_form );
171
				$form_name = esc_attr( $form['title'] );
172
				$image = self::get_floaty();
173
				$new_form_text .= '<h3>'.$image.sprintf( __( 'A new form was created for this View: "%s"', 'gravityview' ), $form_name ).'</h3>';
174
				$new_form_text .=  sprintf( __( '%sThere are no entries for the new form, so the View will also be empty.%s To start collecting entries, you can add submissions through %sthe preview form%s and also embed the form on a post or page using this code: %s
175
176
					You can %sedit the form%s in Gravity Forms and the updated fields will be available here. Don&rsquo;t forget to %scustomize the form settings%s.
177
					', 'gravityview' ), '<strong>', '</strong>', '<a href="'.site_url( '?gf_page=preview&amp;id='.$connected_form ).'">', '</a>', '<code>[gravityform id="'.$connected_form.'" name="'.$form_name.'"]</code>', '<a href="'.admin_url( 'admin.php?page=gf_edit_forms&amp;id='.$connected_form ).'">', '</a>', '<a href="'.admin_url( 'admin.php?page=gf_edit_forms&amp;view=settings&amp;id='.$connected_form ).'">', '</a>');
178
				$new_form_text = wpautop( $new_form_text );
179
180
				delete_post_meta( $post_id, '_gravityview_start_fresh' );
181
			}
182
		}
183
184
		$messages['gravityview'] = array(
185
			0  => '', // Unused. Messages start at index 1.
186
			/* translators: %s and %s are HTML tags linking to the View on the website */
187
			1  => sprintf(__( 'View updated. %sView on website.%s', 'gravityview' ), '<a href="'.get_permalink( $post_id ).'">', '</a>'),
188
			/* translators: %s and %s are HTML tags linking to the View on the website */
189
			2  => sprintf(__( 'View updated. %sView on website.%s', 'gravityview' ), '<a href="'.get_permalink( $post_id ).'">', '</a>'),
190
			3  => __( 'View deleted.', 'gravityview' ),
191
			/* translators: %s and %s are HTML tags linking to the View on the website */
192
			4  => sprintf(__( 'View updated. %sView on website.%s', 'gravityview' ), '<a href="'.get_permalink( $post_id ).'">', '</a>'),
193
			/* translators: %s: date and time of the revision */
194
			5  => isset( $_GET['revision'] ) ? sprintf( __( 'View restored to revision from %s', 'gravityview' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
195
			/* translators: %s and %s are HTML tags linking to the View on the website */
196
			6  => sprintf(__( 'View published. %sView on website.%s', 'gravityview' ), '<a href="'.get_permalink( $post_id ).'">', '</a>') . $new_form_text,
197
			/* translators: %s and %s are HTML tags linking to the View on the website */
198
			7  => sprintf(__( 'View saved. %sView on website.%s', 'gravityview' ), '<a href="'.get_permalink( $post_id ).'">', '</a>') . $new_form_text,
199
			8  => __( 'View submitted.', 'gravityview' ),
200
			9  => sprintf(
201
		        /* translators: Date and time the View is scheduled to be published */
202
				__( 'View scheduled for: %1$s.', 'gravityview' ),
203
				// translators: Publish box date format, see http://php.net/date
204
				date_i18n( __( 'M j, Y @ G:i', 'gravityview' ), strtotime( ( isset( $post->post_date ) ? $post->post_date : NULL )  ) )
205
			) . $new_form_text,
206
			/* translators: %s and %s are HTML tags linking to the View on the website */
207
			10  => sprintf(__( 'View draft updated. %sView on website.%s', 'gravityview' ), '<a href="'.get_permalink( $post_id ).'">', '</a>') . $new_form_text,
0 ignored issues
show
Expected next thing to be a escaping function, not '$new_form_text'
Loading history...
208
209
			/**
210
			 * These apply to `bulk_post_updated_messages`
211
			 * @file wp-admin/edit.php
212
			 */
213
			'updated'   => _n( '%s View updated.', '%s Views updated.', $bulk_counts['updated'], 'gravityview' ),
214
			'locked'    => _n( '%s View not updated, somebody is editing it.', '%s Views not updated, somebody is editing them.', $bulk_counts['locked'], 'gravityview' ),
215
			'deleted'   => _n( '%s View permanently deleted.', '%s Views permanently deleted.', $bulk_counts['deleted'], 'gravityview' ),
216
			'trashed'   => _n( '%s View moved to the Trash.', '%s Views moved to the Trash.', $bulk_counts['trashed'], 'gravityview' ),
217
			'untrashed' => _n( '%s View restored from the Trash.', '%s Views restored from the Trash.', $bulk_counts['untrashed'], 'gravityview' ),
218
		);
219
220
		return $messages;
221
	}
222
223
224
	/**
225
	 * Get admin notices
226
	 * @deprecated since 1.12
227
	 * @return array
228
	 */
229
	public static function get_notices() {
230
		return GravityView_Admin_Notices::get_notices();
231
	}
232
233
	/**
234
	 * Add a notice to be displayed in the admin.
235
	 * @deprecated since 1.12
236
	 * @param array $notice Array with `class` and `message` keys. The message is not escaped.
237
	 */
238
	public static function add_notice( $notice = array() ) {
239
		GravityView_Admin_Notices::add_notice( $notice );
240
	}
241
242
	/**
243
	 * Check if Gravity Forms plugin is active and show notice if not.
244
	 *
245
	 * @deprecated since 1.12
246
	 * @see GravityView_Compatibility::get_plugin_status()
247
	 * @return boolean True: checks have been passed; GV is fine to run; False: checks have failed, don't continue loading
248
	 */
249
	public static function check_gravityforms() {
250
		return GravityView_Compatibility::check_gravityforms();
251
	}
252
253
	/**
254
	 * Check if specified plugin is active, inactive or not installed
255
	 *
256
	 * @deprecated since 1.12
257
	 * @see GravityView_Compatibility::get_plugin_status()
258
259
	 * @return boolean|string True: plugin is active; False: plugin file doesn't exist at path; 'inactive' it's inactive
260
	 */
261
	static function get_plugin_status( $location = '' ) {
262
		return GravityView_Compatibility::get_plugin_status( $location );
263
	}
264
265
	/**
266
	 * Is the current admin page a GravityView-related page?
267
	 *
268
	 * @todo Convert to use WP_Screen
269
	 * @param string $hook
270
	 * @param null|string $page Optional. String return value of page to compare against.
271
	 *
272
	 * @return bool|string|void If `false`, not a GravityView page. `true` if $page is passed and is the same as current page. Otherwise, the name of the page (`single`, `settings`, or `views`)
273
	 */
274
	static function is_admin_page( $hook = '', $page = NULL ) {
275
		global $current_screen, $plugin_page, $pagenow, $post;
276
277
		if( ! is_admin() ) { return false; }
278
279
		$is_page = false;
280
281
		$is_gv_screen = (!empty($current_screen) && isset($current_screen->post_type) && $current_screen->post_type === 'gravityview');
282
283
		$is_gv_post_type_get = (isset($_GET['post_type']) && $_GET['post_type'] === 'gravityview');
284
285
		$is_gv_settings_get = isset( $_GET['page'] ) && $_GET['page'] === 'gravityview_settings';
286
287
		if( empty( $post ) && $pagenow === 'post.php' && !empty( $_GET['post'] ) ) {
288
			$gv_post = get_post( intval( $_GET['post'] ) );
289
			$is_gv_post_type = (!empty($gv_post) && !empty($gv_post->post_type) && $gv_post->post_type === 'gravityview');
290
		} else {
291
			$is_gv_post_type = (!empty($post) && !empty($post->post_type) && $post->post_type === 'gravityview');
292
		}
293
294
		if( $is_gv_screen || $is_gv_post_type || $is_gv_post_type || $is_gv_post_type_get || $is_gv_settings_get ) {
295
296
			// $_GET `post_type` variable
297
			if(in_array($pagenow, array( 'post.php' , 'post-new.php' )) ) {
298
				$is_page = 'single';
299
			} else if ( in_array( $plugin_page, array( 'gravityview_settings', 'gravityview_page_gravityview_settings' ) ) || ( !empty( $_GET['page'] ) && $_GET['page'] === 'gravityview_settings' ) ) {
300
				$is_page = 'settings';
301
			} else {
302
				$is_page = 'views';
303
			}
304
		}
305
306
		/**
307
		 * @filter `gravityview_is_admin_page` Is the current admin page a GravityView-related page?
308
		 * @param[in,out] string|bool $is_page If false, no. If string, the name of the page (`single`, `settings`, or `views`)
309
		 * @param[in] string $hook The name of the page to check against. Is passed to the method.
310
		 */
311
		$is_page = apply_filters( 'gravityview_is_admin_page', $is_page, $hook );
312
313
		// If the current page is the same as the compared page
314
		if( !empty( $page ) ) {
315
			return $is_page === $page;
316
		}
317
318
		return $is_page;
319
	}
320
321
}
322
323
new GravityView_Admin;
324
325
/**
326
 * Alias for GravityView_Admin::is_admin_page()
327
 *
328
 * @see GravityView_Admin::is_admin_page
329
 *
330
 * @param string $hook
331
 * @param null|string $page Optional. String return value of page to compare against.
332
 *
333
 * @return bool|string|void If `false`, not a GravityView page. `true` if $page is passed and is the same as current page. Otherwise, the name of the page (`single`, `settings`, or `views`)
334
 */
335
function gravityview_is_admin_page($hook = '', $page = NULL) {
336
	return GravityView_Admin::is_admin_page( $hook, $page );
337
}
338