';
foreach ($terms as $t) {
$url = get_term_link($t->term_id, BASE.$term);
$out .= '
'.$t->name.'';
}
$out .= '';
}
return $out;
}
function jvbMetaTermList(string $value, string $tax, bool $icon = true):string
{
if ($value === '') {
return '';
}
$tax = jvbCheckBase($tax);
$terms = array_map('absint', explode(',', $value));
$out = [];
foreach ($terms as $t) {
$term = get_term($t, $tax);
if ($term && !is_wp_error($term)) {
$url = get_term_link($t, $tax);
$out[] = ''.$term->name.'';
}
}
$registrar = Registrar::getInstance($tax);
$icon = ($icon && $registrar) ? $registrar->getIcon() : '';
$icon = ($icon === '') ? '' : jvbIcon($icon);
$title = $registrar ? ''.$icon.$registrar->getSingular().'' : '';
return (!empty($out)) ? ''.$title.implode('',$out).'
' : '';
}
/**
* @param int $artistID
* @param string $taxonomy
*
* @return array
*/
function jvbGetArtistTerm(int $artistID, string $taxonomy):array
{
$taxonomy = (str_starts_with($taxonomy, BASE)) ? $taxonomy : BASE.$taxonomy;
$terms = get_the_terms($artistID, $taxonomy);
if ($terms && !is_wp_error($terms)) {
$ID = $terms[0]->term_id;
$name = $terms[0]->name;
return [
'id' => $ID,
'name' => $name,
'url' => get_term_link($ID, $taxonomy)
];
}
return [];
}
/**
* Gets the artist type taxonomy name
* @param int $ID
*
* @return string
*/
function jvbArtistType(int $ID):string
{
$types = get_the_terms($ID, BASE.'type');
$type = '';
if ($types && !is_wp_error($types)) {
$type = $types[0]->term_id;
$type = get_term_meta($type, BASE.'singular', true);
}
return ($type == '') ? 'Tattoo Artist' : $type;
}
/**
* Gets the first name of city listed
* @param int $ID
*
* @return string
*/
function jvbArtistCity(int $ID):string
{
$cities = get_the_terms($ID, 'jvb_city');
if ($cities && !is_wp_error($cities)) {
return $cities[0]->name;
}
return 'Edmonton';
}
function jvbGetContentUsers(int $termID, $user = BASE.'artist'):array
{
$users = get_term_meta($termID, BASE.'users', true);
if ($users === '') {
$term = get_term($termID);
$taxonomy = $term->taxonomy;
if (taxIsJVBContentTax($taxonomy)) {
$posts = new WP_Query([
'post_type' => jvbCheckBase($user),
'posts_per_page' => -1,
'tax_query' => [
[
'taxonomy' => $taxonomy,
'terms' => $term
]
]
]);
if (!empty($posts->posts)) {
$users = array_map(
function ($post) {
return $post->post_author;
},
$posts->posts
);
}
$users = implode(',', $users);
update_post_meta($termID, BASE.'users', $users);
}
}
return explode(',', $users);
}