wpseek.com
A WordPress-centric search engine for devs and theme authors



term_is_ancestor_of › WordPress Function

Since3.4.0
Deprecatedn/a
term_is_ancestor_of ( $term1, $term2, $taxonomy )
Parameters: (3)
  • (int|object) $term1 ID or object to check if this is the parent term.
    Required: Yes
  • (int|object) $term2 The child term.
    Required: Yes
  • (string) $taxonomy Taxonomy name that $term1 and `$term2` belong to.
    Required: Yes
Returns:
  • (bool) Whether `$term2` is a child of `$term1`.
Defined at:
Codex:

Checks if a term is an ancestor of another term.

You can use either an ID or the term object for both parameters.


Source

function term_is_ancestor_of( $term1, $term2, $taxonomy ) {
	if ( ! isset( $term1->term_id ) ) {
		$term1 = get_term( $term1, $taxonomy );
	}
	if ( ! isset( $term2->parent ) ) {
		$term2 = get_term( $term2, $taxonomy );
	}

	if ( empty( $term1->term_id ) || empty( $term2->parent ) ) {
		return false;
	}
	if ( $term2->parent === $term1->term_id ) {
		return true;
	}

	return term_is_ancestor_of( $term1, get_term( $term2->parent, $taxonomy ), $taxonomy );
}