172 lines
4.0 KiB
PHP
172 lines
4.0 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @author Tassos Marinos <info@tassos.gr>
|
|
* @link http://www.tassos.gr
|
|
* @copyright Copyright © 2021 Tassos Marinos All Rights Reserved
|
|
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> or later
|
|
*/
|
|
|
|
namespace ACF\Helpers\Fields;
|
|
|
|
defined('_JEXEC') or die;
|
|
|
|
use YOOtheme\Builder\Joomla\Fields\Type\FieldsType;
|
|
use YOOtheme\Builder\Joomla\Source\ArticleHelper;
|
|
use Joomla\CMS\Factory;
|
|
|
|
class Articles
|
|
{
|
|
/**
|
|
* Returns the YooTheme type.
|
|
*
|
|
* If this accepts one image:
|
|
* - Tells YooTheme to use the default type for the dropdown mapping option.
|
|
*
|
|
* If this accepts multiple images:
|
|
* - Tells YooTheme to only return the value of this field in the dropdown mapping option.
|
|
*
|
|
* @param object $field
|
|
* @param object $source
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function getYooType($field = [], $source = [])
|
|
{
|
|
if ($field->only_use_in_subform === 1)
|
|
{
|
|
return;
|
|
}
|
|
|
|
$max_articles = (int) $field->fieldparams->get('max_articles', 0);
|
|
$multiple = $max_articles === 0 || $max_articles > 1;
|
|
return $multiple ? ['listOf' => 'Article'] : 'Article';
|
|
}
|
|
|
|
/**
|
|
* Transforms the field value to an appropriate value that YooTheme can understand.
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function yooResolve($item, $args, $ctx, $info)
|
|
{
|
|
$name = str_replace('String', '', strtr($info->fieldName, '_', '-'));
|
|
|
|
// Check if it's a subform field
|
|
$subfield = clone \ACF\Helpers\Yoo::getSubfield($args['field_id'], $args['context']);
|
|
|
|
// When we have a subform field, the $item is an array of values
|
|
if (!$subfield || !is_array($item))
|
|
{
|
|
if (!isset($item->id) || !($field = FieldsType::getField($name, $item, $args['context'])))
|
|
{
|
|
return;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// Set rawvalue
|
|
$subfield->rawvalue = isset($item["field{$args['field_id']}"]) ? $item["field{$args['field_id']}"] : '';
|
|
|
|
// Use the subform field
|
|
$field = $subfield;
|
|
}
|
|
|
|
$ids = $field->rawvalue;
|
|
|
|
$max_articles = 0;
|
|
$multiple = true;
|
|
|
|
// Handle Linked Articles
|
|
$field_type = $field->fieldparams->get('articles_type', 'default');
|
|
if ($field_type === 'linked')
|
|
{
|
|
|
|
if (in_array($ids, ['1', 'true']))
|
|
{
|
|
$ids = self::getLinkedArticlesIDs($item->id, $field);
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
$max_articles = (int) $field->fieldparams->get('max_articles', 0);
|
|
$multiple = $max_articles === 0 || $max_articles > 1;
|
|
}
|
|
|
|
if (is_scalar($ids))
|
|
{
|
|
$ids = [(int) $ids];
|
|
}
|
|
|
|
if (!is_array($ids))
|
|
{
|
|
return;
|
|
}
|
|
|
|
$value = ArticleHelper::get($ids);
|
|
|
|
if ($field->only_use_in_subform === 1)
|
|
{
|
|
$data = array_values(array_map(function($article) {
|
|
return $article->title;
|
|
}, $value));
|
|
|
|
return implode(', ', $data);
|
|
}
|
|
|
|
if ($multiple)
|
|
{
|
|
return array_values(array_map(function ($value) {
|
|
return is_scalar($value) ? compact('value') : $value;
|
|
}, $value));
|
|
}
|
|
else
|
|
{
|
|
return array_shift($value);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
public static function getLinkedArticlesIDs($item_id = null, $field = [])
|
|
{
|
|
if (!$acf_articles = array_filter($field->fieldparams->get('articles_fields', [])))
|
|
{
|
|
return;
|
|
}
|
|
|
|
// Grab all linked articles
|
|
$db = Factory::getDbo();
|
|
$query = $db->getQuery(true);
|
|
|
|
$query->select('a.id')
|
|
->from($db->quoteName('#__fields_values', 'fv'))
|
|
->join('LEFT', $db->quoteName('#__content', 'a') . ' ON a.id = fv.item_id')
|
|
->where($db->quoteName('fv.field_id') . ' IN (' . implode(',', $acf_articles) . ')')
|
|
->where($db->quoteName('fv.value') . ' = ' . $db->q($item_id));
|
|
|
|
// Filter results
|
|
require_once JPATH_PLUGINS . '/fields/acfarticles/fields/acfarticlesfilters.php';
|
|
$payload = $field->fieldparams;
|
|
$filters = new \ACFArticlesFilters($query, $payload);
|
|
$query = $filters->apply();
|
|
|
|
// Set query
|
|
$db->setQuery($query);
|
|
|
|
// Get articles
|
|
if (!$articles = $db->loadAssocList())
|
|
{
|
|
return;
|
|
}
|
|
|
|
// Return article IDs
|
|
$articles = array_map(function($article) {
|
|
return $article['id'];
|
|
}, $articles);
|
|
|
|
return $articles;
|
|
}
|
|
|
|
} |