HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/confeduphaar/backip-old-files/administrator/components/com_spsimpleportfolio/models/item.php
<?php

/**
* @package     SP Simple Portfolio
*
* @copyright   Copyright (C) 2010 - 2018 JoomShaper. All rights reserved.
* @license     GNU General Public License version 2 or later.
*/

defined('_JEXEC') or die();

class SpsimpleportfolioModelItem extends JModelAdmin {

	public function getTable($type = 'Item', $prefix = 'SpsimpleportfolioTable', $config = array()) {
		return JTable::getInstance($type, $prefix, $config);
	}

	public function getForm($data = array(), $loadData = true) {
		$form = $this->loadForm('com_spsimpleportfolio.item', 'item', array( 'control' => 'jform', 'load_data' => $loadData ) );

		if (empty($form)) {
			return false;
		}

		return $form;
	}

	protected function loadFormData() {
		$data = JFactory::getApplication()->getUserState( 'com_spsimpleportfolio.edit.item.data', array() );

		if (empty($data)) {
			$data = $this->getItem();
		}

		return $data;
	}

	public function getItem($pk = null) {
		if ($item = parent::getItem($pk)) {
			$item->tagids = $this->getTags($item->tagids);
		}

		return $item;
	}

	// Get Tags
	public function getTags($ids = '[]') {

		$db = JFactory::getDbo();
		$query = $db->getQuery(true);
		$ids = json_decode($ids);

		if(is_array($ids) && count($ids)) {
			$query
			->select('a.*')
			->from($db->quoteName('#__spsimpleportfolio_tags', 'a'))
			->where('(a.id IN ('. implode(',', $ids) .'))');

			$db->setQuery($query);
			$results = $db->loadObjectList();

			$tags = array();
			foreach ($results as $value) {
				$tags[] = $value->id;
			}
			$tags = array_unique($tags);
		} else {
			$tags = array();
		}

		return $tags;
	}

	public function save($data) {
		$input  = JFactory::getApplication()->input;
		$filter = JFilterInput::getInstance();

		// Automatic handling of alias for empty fields
		if (in_array($input->get('task'), array('apply', 'save')) && (!isset($data['id']) || (int) $data['id'] == 0)) {
			if ($data['alias'] == null) {
				if (JFactory::getConfig()->get('unicodeslugs') == 1) {
					$data['alias'] = JFilterOutput::stringURLUnicodeSlug($data['title']);
				} else {
					$data['alias'] = JFilterOutput::stringURLSafe($data['title']);
				}

				$table = JTable::getInstance('Item', 'SpsimpleportfolioTable');

				while ($table->load(array('alias' => $data['alias'], 'catid' => $data['catid']))) {
					$data['alias'] = StringHelper::increment($data['alias'], 'dash');
				}
			}
		}

		if (isset($data['tagids']) && is_array($data['tagids'])) {
			$data['tagids'] = $this->storeTags($data['tagids']);
		}

		if (parent::save($data)) {
			return true;
		}

		return false;
	}

	public function storeTags($tags = array()) {
		$itemTags = array();
		foreach ($tags as $tag) {
			if(strpos($tag, '#new#') !== false) {
				$title = str_replace('#new#', '', $tag);
				$alias = JFilterOutput::stringURLSafe($title);

				// Insert New
				if(!$this->checkTag($alias)) {
					$object = new stdClass();
					$object->title = $title;
					$object->alias = $alias;
					$db = JFactory::getDbo();
					$db->insertObject('#__spsimpleportfolio_tags', $object);
					$itemTags[] = $db->insertid();
				}
			} else {
				$itemTags[] = $tag;
			}
		}

		if(count($itemTags)) {
			return json_encode($itemTags);
		}

		return '[]';
	}

	private function checkTag($alias) {
		$db = JFactory::getDbo();
		$query = $db->getQuery(true);
		$query->select('COUNT(alias)');
		$query->from($db->quoteName('#__spsimpleportfolio_tags'));
		$query->where($db->quoteName('alias') . ' = '. $db->quote($alias));
		$db->setQuery($query);
		return $db->loadResult();
	}

}