From 980fb0f14b06319017b07eaad5cb3e7b9dd0f814 Mon Sep 17 00:00:00 2001 From: Bernie Reiter Date: Wed, 1 Mar 2023 19:04:11 +0100 Subject: [PATCH] Add pseudo-code-ish wp-each implementation --- src/directives/attributes/wp-each.php | 40 +++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 src/directives/attributes/wp-each.php diff --git a/src/directives/attributes/wp-each.php b/src/directives/attributes/wp-each.php new file mode 100644 index 00000000..a11ce5bd --- /dev/null +++ b/src/directives/attributes/wp-each.php @@ -0,0 +1,40 @@ +is_tag_closer() ) { + return; + } + + $prefixed_attributes = $tags->get_attribute_names_with_prefix( 'wp-each:' ); + if ( 0 === count( $prefixed_attributes ) ) { + return; + } + $attribute_name = $prefixed_attributes[0]; + + list( , $iterator_name ) = explode( ':', $attribute_name ); + + $value = $tags->get_attribute( $attribute_name ); + if ( null === $value ) { + // No wp-each directive. + return; + } + + $loop_array = evaluate( $value, $context->get_context() ); + // TODO: Error handling. + + $loop_inner_html = ''; + foreach ( $loop_array as $iteration_item ) { + $context->set_context( array( 'item' => $iteration_item ) ); + + $inner_html = $tags->get_inner_html(); + $inner_tags = new WP_Directive_Processor( $inner_html ); + $inner_tags = wp_process_directives( $inner_tags, $context ); + $loop_inner_html .= $inner_tags->get_inner_html(); + + $context->rewind_context(); + } + $tags->set_inner_html( $loop_inner_html ); + $tags->find_balanced_tag(); +}