name = 'options_page'; $this->label = __("Options Page",'acf'); $this->category = 'forms'; } /* * rule_match * * This function is used to match this location $rule to the current $screen * * @type function * @date 3/01/13 * @since 3.5.7 * * @param $match (boolean) * @param $rule (array) * @return $options (array) */ function rule_match( $result, $rule, $screen ) { $options_page = acf_maybe_get( $screen, 'options_page' ); return $this->compare( $options_page, $rule ); } /* * rule_operators * * This function returns the available values for this rule type * * @type function * @date 30/5/17 * @since 5.6.0 * * @param n/a * @return (array) */ function rule_values( $choices, $rule ) { // vars $pages = acf_get_options_pages(); // populate if( !empty($pages) ) { foreach( $pages as $page ) { $choices[ $page['menu_slug'] ] = $page['menu_title']; } } else { $choices[''] = __('No options pages exist', 'acf'); } // return return $choices; } } // initialize acf_register_location_rule( 'acf_location_options_page' ); endif; // class_exists check ?>