helpers->getTerm(); $metaData = aioseo()->meta->metaData->getMetaData( $term ); $image = ''; if ( ! empty( $metaData ) ) { $imageSource = ! empty( $metaData->og_image_type ) && 'default' !== $metaData->og_image_type ? $metaData->og_image_type : aioseo()->options->social->facebook->general->defaultImageSourceTerms; $image = aioseo()->social->image->getImage( 'facebook', $imageSource, $term ); } return $image ? $image : aioseo()->helpers->getSiteLogoUrl(); } /** * Returns the width of the Open Graph image. * * @since 4.0.0 * * @return string The image width. */ public function getImageWidth() { if ( ! is_category() && ! is_tag() && ! is_tax() ) { return parent::getImageWidth(); } $image = $this->getImage(); if ( is_array( $image ) ) { return $image[1]; } return aioseo()->options->social->facebook->general->defaultImageTermsWidth; } /** * Returns the height of the Open Graph image. * * @since 4.0.0 * * @return string The image height. */ public function getImageHeight() { if ( ! is_category() && ! is_tag() && ! is_tax() ) { return parent::getImageHeight(); } $image = $this->getImage(); if ( is_array( $image ) ) { return $image[2]; } return aioseo()->options->social->facebook->general->defaultImageTermsHeight; } /** * Returns the Open Graph title for the current page. * * @since 4.0.0 * * @param \WP_Post|integer $post The post object or ID (optional). * @return string The Open Graph title. */ public function getTitle( $post = null ) { if ( ! is_category() && ! is_tag() && ! is_tax() ) { return parent::getTitle( $post ); } $term = aioseo()->helpers->getTerm(); $metaData = aioseo()->meta->metaData->getMetaData( $term ); $title = ''; if ( ! empty( $metaData->og_title ) ) { $title = aioseo()->meta->title->helpers->prepare( $metaData->og_title, $term->term_id ); } return $title ? $title : aioseo()->meta->title->getTermTitle( $term ); } /** * Returns the Open Graph description for the current page. * * @since 4.0.0 * * @param \WP_Post|integer $post The post object or ID (optional). * @return string The Open Graph description. */ public function getDescription( $post = null ) { if ( ! is_category() && ! is_tag() && ! is_tax() ) { return parent::getDescription( $post ); } $term = aioseo()->helpers->getTerm(); $metaData = aioseo()->meta->metaData->getMetaData( $term ); $description = ''; if ( ! empty( $metaData->og_description ) ) { $description = aioseo()->meta->description->helpers->prepare( $metaData->og_description, $term->term_id ); } return $description ? $description : aioseo()->meta->description->getTermDescription( $term ); } /** * Returns the Open Graph object type. * * @since 4.0.0 * * @return string The object type. */ public function getObjectType() { if ( ! is_category() && ! is_tag() && ! is_tax() ) { return parent::getObjectType(); } $term = aioseo()->helpers->getTerm(); if ( ! is_a( $term, 'WP_Term' ) ) { return 'article'; } $metaData = aioseo()->meta->metaData->getMetaData( $term ); if ( ! empty( $metaData->og_object_type ) && 'default' !== $metaData->og_object_type ) { return $metaData->og_object_type; } $dynamicOptions = aioseo()->dynamicOptions->noConflict(); $defaultObjectType = $dynamicOptions->social->facebook->general->taxonomies->has( $term->taxonomy ) ? $dynamicOptions->social->facebook->general->taxonomies->{$term->taxonomy}->objectType : null; return ! empty( $defaultObjectType ) ? $defaultObjectType : 'article'; } }