WP_Interactivity_API::data_wp_class_processorprivateWP 6.5.0

Processes the data-wp-class directive.

It adds or removes CSS classes in the current HTML element based on the evaluation of its associated references.

Method of the class: WP_Interactivity_API{}

No Hooks.

Returns

null. Nothing (null).

Usage

// private - for code of main (parent) class only
$result = $this->data_wp_class_processor( $p, $mode );
$p(WP_Interactivity_API_Directives_Processor) (required)
The directives processor instance.
$mode(string) (required)
Whether the processing is entering or exiting the tag.

Changelog

Since 6.5.0 Introduced.

WP_Interactivity_API::data_wp_class_processor() code WP 6.9.1

private function data_wp_class_processor( WP_Interactivity_API_Directives_Processor $p, string $mode ) {
	if ( 'enter' === $mode ) {
		$all_class_directives = $p->get_attribute_names_with_prefix( 'data-wp-class--' );
		$entries              = $this->get_directive_entries( $p, 'class' );
		foreach ( $entries as $entry ) {
			if ( empty( $entry['suffix'] ) ) {
				continue;
			}
			$class_name = isset( $entry['unique_id'] ) && $entry['unique_id']
				? "{$entry['suffix']}---{$entry['unique_id']}"
				: $entry['suffix'];

			if ( empty( $class_name ) ) {
				return;
			}

			$result = $this->evaluate( $entry );

			if ( $result ) {
				$p->add_class( $class_name );
			} else {
				$p->remove_class( $class_name );
			}
		}
	}
}