collector->get_data(); $name = __( 'Hooks & Actions', 'query-monitor' ); if ( $data->all_hooks ) { $name = __( 'Hooks, Actions, & Filters', 'query-monitor' ); } return $name; } /** * @return void */ public function output() { /** @var QM_Data_Hooks */ $data = $this->collector->get_data(); if ( empty( $data->hooks ) ) { return; } $this->before_tabular_output(); $callback_label = __( 'Action', 'query-monitor' ); $th_type = ''; if ( $data->all_hooks ) { $callback_label = __( 'Callback', 'query-monitor' ); $th_type = '' . $this->build_filter( 'type', array( 'action' => __( 'Action', 'query-monitor' ), 'filter' => __( 'Filter', 'query-monitor' ), ), __( 'Type', 'query-monitor' ) ) . ''; } echo ''; echo ''; echo ''; echo $this->build_filter( 'name', $data->parts, __( 'Hook', 'query-monitor' ) ); // WPCS: XSS ok. echo ''; echo $th_type; // WPCS: XSS ok. echo '' . esc_html__( 'Priority', 'query-monitor' ) . ''; echo '' . esc_html( $callback_label ) . ''; echo ''; echo $this->build_filter( 'component', $data->components, __( 'Component', 'query-monitor' ), array( 'highlight' => 'subject', ) ); // WPCS: XSS ok. echo ''; echo ''; echo ''; echo ''; self::output_hook_table( $data->hooks, $data->all_hooks ); echo ''; $this->after_tabular_output(); } /** * @param array $hooks * @param bool $all_hooks * @return void */ public static function output_hook_table( array $hooks, bool $all_hooks ) { $core = __( 'WordPress Core', 'query-monitor' ); foreach ( $hooks as $hook ) { $row_attr = array(); $row_attr['data-qm-name'] = implode( ' ', $hook['parts'] ); $row_attr['data-qm-component'] = implode( ' ', $hook['components'] ); $row_attr['data-qm-type'] = $hook['type']; if ( ! empty( $row_attr['data-qm-component'] ) && $core !== $row_attr['data-qm-component'] ) { $row_attr['data-qm-component'] .= ' non-core'; } $attr = ''; if ( ! empty( $hook['actions'] ) ) { $rowspan = count( $hook['actions'] ); } else { $rowspan = 1; } foreach ( $row_attr as $a => $v ) { $attr .= ' ' . $a . '="' . esc_attr( $v ) . '"'; } if ( ! empty( $hook['actions'] ) ) { $first = true; foreach ( $hook['actions'] as $action ) { $component = ''; $subject = ''; if ( isset( $action['callback']['component'] ) ) { $component = $action['callback']['component']->name; $subject = $component; } if ( $core !== $component ) { $subject .= ' non-core'; } printf( // WPCS: XSS ok. '', esc_attr( $subject ), $attr ); if ( $first ) { echo ''; echo '' . esc_html( $hook['name'] ) . ''; if ( 'all' === $hook['name'] ) { // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped echo '
' . QueryMonitor::icon( 'warning' ); printf( /* translators: %s: Action name */ esc_html__( 'Warning: The %s action is extremely resource intensive. Try to avoid using it.', 'query-monitor' ), 'all' ); echo ''; } echo '
'; if ( $all_hooks ) { $type = ( 'action' === $hook['type'] ) ? __( 'Action', 'query-monitor' ) : __( 'Filter', 'query-monitor' ); echo '' . esc_html( $type ) . ''; } } if ( isset( $action['callback']['error'] ) ) { $class = ' qm-warn'; } else { $class = ''; } echo ''; echo esc_html( $action['priority'] ); if ( PHP_INT_MAX === $action['priority'] ) { echo ' (PHP_INT_MAX)'; } elseif ( PHP_INT_MIN === $action['priority'] ) { echo ' (PHP_INT_MIN)'; } elseif ( -PHP_INT_MAX === $action['priority'] ) { echo ' (-PHP_INT_MAX)'; } echo ''; if ( isset( $action['callback']['file'] ) ) { if ( self::has_clickable_links() ) { echo ''; echo self::output_filename( $action['callback']['name'], $action['callback']['file'], $action['callback']['line'] ); // WPCS: XSS ok. echo ''; } else { echo ''; echo self::build_toggler(); // WPCS: XSS ok; echo '
    '; echo '
  1. '; echo self::output_filename( $action['callback']['name'], $action['callback']['file'], $action['callback']['line'] ); // WPCS: XSS ok. echo '
  2. '; echo '
'; } } else { echo ''; echo '' . esc_html( $action['callback']['name'] ) . ''; if ( isset( $action['callback']['error'] ) ) { // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped echo '
' . QueryMonitor::icon( 'warning' ); echo esc_html( sprintf( /* translators: %s: Error message text */ __( 'Error: %s', 'query-monitor' ), $action['callback']['error']->get_error_message() ) ); } echo ''; } echo ''; echo esc_html( $component ); echo ''; echo ''; $first = false; } } else { echo ""; // WPCS: XSS ok. echo ''; echo '' . esc_html( $hook['name'] ) . ''; echo ''; echo ''; echo ''; echo ''; if ( $all_hooks ) { echo ''; } echo ''; } } } } /** * @param array $output * @param QM_Collectors $collectors * @return array */ function register_qm_output_html_hooks( array $output, QM_Collectors $collectors ) { $collector = QM_Collectors::get( 'hooks' ); if ( $collector ) { $output['hooks'] = new QM_Output_Html_Hooks( $collector ); } return $output; } add_filter( 'qm/outputter/html', 'register_qm_output_html_hooks', 80, 2 );