2023-07-26 11:09:42 +02:00
|
|
|
<?php
|
|
|
|
/*----------------------------------------------------------------------------------| io.vdm.dev |----/
|
|
|
|
Vast Development Method
|
|
|
|
/-------------------------------------------------------------------------------------------------------/
|
|
|
|
|
|
|
|
@package getBible.net
|
|
|
|
|
|
|
|
@created 3rd December, 2015
|
|
|
|
@author Llewellyn van der Merwe <https://getbible.net>
|
|
|
|
@git Get Bible <https://git.vdm.dev/getBible>
|
|
|
|
@github Get Bible <https://github.com/getBible>
|
|
|
|
@support Get Bible <https://git.vdm.dev/getBible/support>
|
|
|
|
@copyright Copyright (C) 2015. All Rights Reserved
|
|
|
|
@license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
|
|
|
|
|
|
|
/------------------------------------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
// No direct access to this file
|
|
|
|
defined('_JEXEC') or die('Restricted access');
|
|
|
|
|
2024-01-22 10:48:28 +02:00
|
|
|
use Joomla\CMS\Factory;
|
|
|
|
use Joomla\CMS\Language\Text;
|
|
|
|
use Joomla\CMS\Toolbar\Toolbar;
|
|
|
|
use Joomla\CMS\Component\ComponentHelper;
|
|
|
|
use Joomla\CMS\HTML\HTMLHelper as Html;
|
|
|
|
use Joomla\CMS\Layout\FileLayout;
|
2023-07-26 11:09:42 +02:00
|
|
|
use Joomla\CMS\MVC\View\HtmlView;
|
2024-01-22 10:48:28 +02:00
|
|
|
use Joomla\CMS\Plugin\PluginHelper;
|
|
|
|
use Joomla\CMS\Toolbar\ToolbarHelper;
|
2024-01-26 17:18:26 +02:00
|
|
|
use Joomla\CMS\Session\Session;
|
|
|
|
use Joomla\CMS\Router\Router;
|
|
|
|
use Joomla\CMS\Router\Route;
|
|
|
|
use Joomla\CMS\Uri\Uri;
|
2024-01-22 10:48:28 +02:00
|
|
|
use Joomla\CMS\Helper\ModuleHelper;
|
|
|
|
use VDM\Joomla\GetBible\Factory as GetBibleFactory;
|
|
|
|
use VDM\Joomla\Utilities\StringHelper;
|
|
|
|
use VDM\Joomla\Utilities\ArrayHelper;
|
2023-07-26 11:09:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Getbible Html View class for the Search
|
|
|
|
*/
|
|
|
|
class GetbibleViewSearch extends HtmlView
|
|
|
|
{
|
|
|
|
// Overwriting JView display method
|
|
|
|
function display($tpl = null)
|
2024-01-22 10:48:28 +02:00
|
|
|
{
|
2023-07-26 11:09:42 +02:00
|
|
|
// get combined params of both component and menu
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->app = Factory::getApplication();
|
2023-07-26 11:09:42 +02:00
|
|
|
$this->params = $this->app->getParams();
|
|
|
|
$this->menu = $this->app->getMenu()->getActive();
|
|
|
|
// get the user object
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->user = Factory::getUser();
|
2023-07-26 11:09:42 +02:00
|
|
|
// Initialise variables.
|
|
|
|
$this->items = $this->get('Items');
|
|
|
|
$this->translations = $this->get('Translations');
|
|
|
|
$this->books = $this->get('Books');
|
|
|
|
$this->translation = $this->get('Translation');
|
2023-08-21 17:36:30 +02:00
|
|
|
// remove from page (in case debug mode is on)
|
|
|
|
$this->params->set('openai_token', null);
|
|
|
|
$this->params->set('gitea_token', null);
|
|
|
|
// set the input object
|
|
|
|
$this->input = $this->app->input;
|
2023-07-26 11:09:42 +02:00
|
|
|
if ($this->params->get('activate_search') == 1)
|
|
|
|
{
|
2023-08-21 17:36:30 +02:00
|
|
|
// set the page direction globally
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setDirection($this->translation->direction);
|
2023-08-21 17:36:30 +02:00
|
|
|
// set the global language declaration
|
2024-01-26 17:18:26 +02:00
|
|
|
// $this->getDocument()->setLanguage($this->translation->joomla); (soon ;)
|
2023-07-26 11:09:42 +02:00
|
|
|
// set the enough verses witch
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->enoughVerses = GetBibleFactory::_('GetBible.Watcher')->enoughVerses($this->translation->abbreviation ?? 'kjv');
|
2023-08-21 17:36:30 +02:00
|
|
|
// set metadata
|
|
|
|
$this->setMetaData();
|
2024-01-26 17:18:26 +02:00
|
|
|
// strip the slugs
|
|
|
|
if (!empty($this->items))
|
|
|
|
{
|
|
|
|
$this->removeSlugs();
|
|
|
|
}
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Set the toolbar
|
|
|
|
$this->addToolBar();
|
|
|
|
|
|
|
|
// set the document
|
|
|
|
$this->_prepareDocument();
|
|
|
|
|
|
|
|
// Check for errors.
|
|
|
|
if (count($errors = $this->get('Errors')))
|
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
throw new \Exception(implode(PHP_EOL, $errors), 500);
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
parent::display($tpl);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-08-21 17:36:30 +02:00
|
|
|
* Set the page metadata
|
2023-07-26 11:09:42 +02:00
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
2023-08-21 17:36:30 +02:00
|
|
|
protected function setMetaData()
|
|
|
|
{
|
|
|
|
// set the page title
|
2024-01-22 10:48:28 +02:00
|
|
|
$title = Text::sprintf('COM_GETBIBLE_SEARCHING_S_IN_S_S',
|
2023-08-21 17:36:30 +02:00
|
|
|
$this->getSearch(),
|
|
|
|
$this->translation->translation,
|
|
|
|
$this->params->get('page_title', '')
|
|
|
|
);
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setTitle($title);
|
2023-08-21 17:36:30 +02:00
|
|
|
$url = $this->getCanonicalUrl();
|
|
|
|
// set the Generator
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setGenerator('getBible! - Open Source Bible App.');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// set the metadata values
|
2024-01-22 10:48:28 +02:00
|
|
|
$description = Text::sprintf('COM_GETBIBLE_SEARCHING_S_IN_S_TARGETING_S_WITH_S_S_IN_S',
|
2023-08-21 17:36:30 +02:00
|
|
|
$this->getSearch(),
|
|
|
|
$this->translation->translation,
|
|
|
|
strtolower($this->getWordsText()),
|
|
|
|
strtolower($this->getMatchText()),
|
|
|
|
strtolower($this->getCaseText()),
|
|
|
|
$this->getTargetText()
|
|
|
|
);
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setDescription($description);
|
|
|
|
$this->getDocument()->setMetadata('keywords', Text::sprintf('COM_GETBIBLE_SEARCH_S_S_S_S_S_S_BIBLE_S_S_SCRIPTURE_SEARCH_GETBIBLE',
|
2023-08-21 17:36:30 +02:00
|
|
|
$this->getSearch(),
|
|
|
|
strtolower($this->getWordsText()),
|
|
|
|
strtolower($this->getMatchText()),
|
|
|
|
strtolower($this->getCaseText()),
|
|
|
|
$this->getTargetText(),
|
|
|
|
$this->translation->translation,
|
|
|
|
$this->translation->abbreviation,
|
|
|
|
$this->translation->language
|
|
|
|
));
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetaData('author', Text::_('COM_GETBIBLE_THE_WORD_OF_GOD'));
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// set canonical URL
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->addHeadLink($url, 'canonical');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// OG:Title
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('og:title', $title, 'property');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// OG:Description
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('og:description', $description, 'property');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// OG:Image
|
2024-01-26 17:18:26 +02:00
|
|
|
// $this->getDocument()->setMetadata('og:image', 'YOUR_IMAGE_URL_HERE', 'property');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// OG:URL
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('og:url', $url, 'property');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// OG:Type
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('og:type', 'website', 'property');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// Twitter Card Type
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('twitter:card', 'summary');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// Twitter Title
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('twitter:title', $title);
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// Twitter Description
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->getDocument()->setMetadata('twitter:description', $description);
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// Twitter Image
|
2024-01-26 17:18:26 +02:00
|
|
|
// $this->getDocument()->setMetadata('twitter:image', 'YOUR_IMAGE_URL_HERE');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// Twitter Site (Your website's Twitter handle)
|
2024-01-26 17:18:26 +02:00
|
|
|
// $this->getDocument()->setMetadata('twitter:site', '@YourTwitterHandle');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
// Twitter Creator (Author's Twitter handle or your website's Twitter handle)
|
2024-01-26 17:18:26 +02:00
|
|
|
// $this->getDocument()->setMetadata('twitter:creator', '@AuthorTwitterHandle');
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the canonical url
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getCanonicalUrl(): string
|
|
|
|
{
|
|
|
|
if (empty($this->url_canonical))
|
|
|
|
{
|
|
|
|
$this->setCanonicalUrl();
|
|
|
|
}
|
|
|
|
return $this->url_canonical ?? $this->getBaseUrl();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Bible url
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getBibleUrl(): string
|
|
|
|
{
|
|
|
|
if (empty($this->url_bible))
|
|
|
|
{
|
|
|
|
$this->setBibleUrl();
|
|
|
|
}
|
|
|
|
return $this->url_bible;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the base url
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getBaseUrl(): string
|
|
|
|
{
|
|
|
|
if (empty($this->url_base))
|
|
|
|
{
|
|
|
|
$this->setBaseUrl();
|
|
|
|
}
|
|
|
|
return $this->url_base ?? '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the search url
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getSearchUrl(): string
|
|
|
|
{
|
|
|
|
if (empty($this->url_search))
|
|
|
|
{
|
|
|
|
$this->setSearchUrl();
|
|
|
|
}
|
|
|
|
return $this->url_search ?? '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the AJAX url
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getAjaxUrl(): string
|
|
|
|
{
|
|
|
|
if (empty($this->url_ajax))
|
|
|
|
{
|
|
|
|
$this->setAjaxUrl();
|
|
|
|
}
|
|
|
|
return $this->url_ajax ?? '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the return url value
|
|
|
|
*
|
|
|
|
* @return string|null
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getReturnUrl(): ?string
|
|
|
|
{
|
|
|
|
if (empty($this->url_return))
|
|
|
|
{
|
|
|
|
$this->setReturnUrl();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->url_return ?? null;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the return url value
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getReturnUrlValue(): string
|
|
|
|
{
|
|
|
|
if (empty($this->url_return_value))
|
|
|
|
{
|
|
|
|
$this->setReturnUrl();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($this->url_return_value))
|
|
|
|
{
|
2023-08-21 18:31:01 +02:00
|
|
|
return '&bibleurl=' . $this->url_return_value;
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the return url book value
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getReturnUrlBook(): int
|
|
|
|
{
|
|
|
|
if (empty($this->url_return_query))
|
|
|
|
{
|
|
|
|
$this->setReturnUrl();
|
|
|
|
}
|
|
|
|
|
|
|
|
return (int) $this->url_return_query['book'] ?? 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the return url chapter value
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getReturnUrlChapter(): int
|
|
|
|
{
|
|
|
|
if (empty($this->url_return_query))
|
|
|
|
{
|
|
|
|
$this->setReturnUrl();
|
|
|
|
}
|
|
|
|
|
|
|
|
return (int) $this->url_return_query['chapter'] ?? 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Options Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getOptionsText(): array
|
|
|
|
{
|
|
|
|
if (empty($this->options_text))
|
|
|
|
{
|
|
|
|
$this->setOptionsText();
|
|
|
|
}
|
|
|
|
return $this->options_text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Words Search Behaviour
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getWords(): int
|
|
|
|
{
|
|
|
|
if (empty($this->words))
|
|
|
|
{
|
|
|
|
$this->setWords();
|
|
|
|
}
|
|
|
|
return $this->words ?? 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Words Search Behaviour
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getWordsText(): string
|
|
|
|
{
|
|
|
|
if (empty($this->words_text))
|
|
|
|
{
|
|
|
|
$this->setWordsText();
|
|
|
|
}
|
|
|
|
return $this->words_text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Match Search Behaviour
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getMatch(): int
|
|
|
|
{
|
|
|
|
if (empty($this->match))
|
|
|
|
{
|
|
|
|
$this->setMatch();
|
|
|
|
}
|
|
|
|
return $this->match ?? 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Match Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getMatchText(): string
|
|
|
|
{
|
|
|
|
if (empty($this->match_text))
|
|
|
|
{
|
|
|
|
$this->setMatchText();
|
|
|
|
}
|
|
|
|
return $this->match_text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Case Search Behaviour
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getCase(): int
|
|
|
|
{
|
|
|
|
if (empty($this->case))
|
|
|
|
{
|
|
|
|
$this->setCase();
|
|
|
|
}
|
|
|
|
return $this->case ?? 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Case Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getCaseText(): string
|
|
|
|
{
|
|
|
|
if (empty($this->case_text))
|
|
|
|
{
|
|
|
|
$this->setCaseText();
|
|
|
|
}
|
|
|
|
return $this->case_text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Target Search Behaviour
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getTarget(): int
|
|
|
|
{
|
|
|
|
if (empty($this->target))
|
|
|
|
{
|
|
|
|
$this->setTarget();
|
|
|
|
}
|
|
|
|
return $this->target ?? 1000;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Target Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getTargetText(): string
|
|
|
|
{
|
|
|
|
if (empty($this->target_text))
|
|
|
|
{
|
|
|
|
$this->setTargetText();
|
|
|
|
}
|
|
|
|
return $this->target_text;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Search String
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function getSearch(): string
|
|
|
|
{
|
|
|
|
if (empty($this->search))
|
|
|
|
{
|
|
|
|
$this->setSearch();
|
|
|
|
}
|
|
|
|
return $this->search;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Search String
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setSearch()
|
2023-07-26 11:09:42 +02:00
|
|
|
{
|
|
|
|
$this->search = $this->input->getString('search') ?? $this->input->getString('s') ?? '';
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Case Search Behaviour
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setTarget()
|
|
|
|
{
|
|
|
|
$target = $this->input->getInt('target', 1000);
|
|
|
|
$this->target = ($target == 4000) ? $this->input->getInt('target_book', $target) : $target;
|
|
|
|
}
|
2023-07-26 11:09:42 +02:00
|
|
|
|
2023-08-21 17:36:30 +02:00
|
|
|
/**
|
|
|
|
* Set the Target Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function setTargetText()
|
|
|
|
{
|
2023-07-26 11:09:42 +02:00
|
|
|
// set the value names
|
|
|
|
$target = [
|
2024-01-22 10:48:28 +02:00
|
|
|
1000 => Text::_('COM_GETBIBLE_ALL_BOOKS'),
|
|
|
|
2000 => Text::_('COM_GETBIBLE_OLD_TESTAMENT'),
|
|
|
|
3000 => Text::_('COM_GETBIBLE_NEW_TESTAMENT'),
|
|
|
|
4000 => Text::_('COM_GETBIBLE_A_BOOK')
|
2023-07-26 11:09:42 +02:00
|
|
|
];
|
|
|
|
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->target_text = $target[$this->getTarget()] ?? Text::_('COM_GETBIBLE_A_BOOK');
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Case Search Behaviour
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setCase()
|
|
|
|
{
|
|
|
|
$this->case = $this->input->getInt('case', $this->params->get('search_case', 1));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Case Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setCaseText()
|
|
|
|
{
|
|
|
|
// set the value names
|
|
|
|
$case = [
|
2024-01-22 10:48:28 +02:00
|
|
|
1 => Text::_('COM_GETBIBLE_CASE_INSENSITIVE'),
|
|
|
|
2 => Text::_('COM_GETBIBLE_CASE_SENSITIVE')
|
2023-08-21 17:36:30 +02:00
|
|
|
];
|
|
|
|
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->case_text = $case[$this->getCase()] ?? Text::_('COM_GETBIBLE_CASE_INSENSITIVE');
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Match Search Behaviour
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setMatch()
|
|
|
|
{
|
|
|
|
$this->match = $this->input->getInt('match', $this->params->get('search_match', 1));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Match Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setMatchText()
|
|
|
|
{
|
|
|
|
// set the value names
|
|
|
|
$match = [
|
2024-01-22 10:48:28 +02:00
|
|
|
1 => Text::_('COM_GETBIBLE_EXACT_MATCH'),
|
|
|
|
2 => Text::_('COM_GETBIBLE_PARTIAL_MATCH')
|
2023-08-21 17:36:30 +02:00
|
|
|
];
|
|
|
|
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->match_text = $match[$this->getMatch()] ?? Text::_('COM_GETBIBLE_EXACT_MATCH');
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Words Search Behaviour
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setWords()
|
|
|
|
{
|
|
|
|
$this->words = $this->input->getInt('words', $this->params->get('search_word', 1));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Words Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setWordsText()
|
|
|
|
{
|
|
|
|
// set the value names
|
|
|
|
$words = [
|
2024-01-22 10:48:28 +02:00
|
|
|
1 => Text::_('COM_GETBIBLE_ALL_WORDS'),
|
|
|
|
2 => Text::_('COM_GETBIBLE_ANY_WORDS'),
|
|
|
|
3 => Text::_('COM_GETBIBLE_EXACT_WORDS')
|
2023-08-21 17:36:30 +02:00
|
|
|
];
|
|
|
|
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->words_text = $words[$this->getWords()] ?? Text::_('COM_GETBIBLE_ALL_WORDS');
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Options Search Behaviour (text)
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setOptionsText()
|
|
|
|
{
|
2023-07-26 11:09:42 +02:00
|
|
|
$this->options_text = [];
|
2023-08-21 17:36:30 +02:00
|
|
|
$this->options_text[] = $this->getWordsText();
|
|
|
|
$this->options_text[] = $this->getMatchText();
|
|
|
|
$this->options_text[] = $this->getCaseText();
|
|
|
|
$this->options_text[] = $this->getTargetText();
|
|
|
|
}
|
2023-07-26 11:09:42 +02:00
|
|
|
|
2023-08-21 17:36:30 +02:00
|
|
|
/**
|
|
|
|
* Set the return URL if it's provided and internal.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setReturnUrl(): void
|
|
|
|
{
|
2023-08-21 18:31:01 +02:00
|
|
|
$encodedUrl = $this->input->get('bibleurl', null, 'base64');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
if ($encodedUrl === null)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$decodedUrl = base64_decode($encodedUrl);
|
2024-01-26 17:18:26 +02:00
|
|
|
$uri = Uri::getInstance($decodedUrl);
|
|
|
|
$router = Router::getInstance('site');
|
2023-08-21 17:36:30 +02:00
|
|
|
|
|
|
|
$this->url_return_value = $encodedUrl;
|
|
|
|
$this->url_return = $decodedUrl;
|
|
|
|
$this->url_return_query = $router->parse($uri);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the base url
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setBaseUrl()
|
|
|
|
{
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->url_base = Uri::base();
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the AJAX url
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setAjaxUrl()
|
|
|
|
{
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->url_ajax = $this->getBaseUrl() . 'index.php?option=com_getbible&format=json&raw=true&' . Session::getFormToken() . '=1&task=ajax.';
|
2023-08-21 17:36:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the search url
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setSearchUrl()
|
|
|
|
{
|
|
|
|
// set the current search URL
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->url_search = Route::_('index.php?option=com_getbible&view=search&Itemid=' . $this->params->get('app_menu', 0) .
|
2023-08-21 18:31:01 +02:00
|
|
|
'&t=' . $this->translation->abbreviation . $this->getReturnUrlValue() .
|
2023-08-21 17:36:30 +02:00
|
|
|
'&words=' . $this->getWords() . '&match=' . $this->getMatch() .
|
|
|
|
'&case=' . $this->getCase() . '&target=' . $this->getTarget() . '&search=' . $this->getSearch());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the canonical url
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setCanonicalUrl()
|
|
|
|
{
|
|
|
|
// set the current search URL
|
2023-08-21 18:31:01 +02:00
|
|
|
$this->url_canonical = trim($this->getBaseUrl(), '/') .
|
2024-01-26 17:18:26 +02:00
|
|
|
Route::_('index.php?option=com_getbible&view=search&Itemid=' . $this->params->get('app_menu', 0) .
|
2023-08-21 18:31:01 +02:00
|
|
|
'&t=' . $this->translation->abbreviation . '&words=' . $this->getWords() .
|
2023-08-21 17:36:30 +02:00
|
|
|
'&match=' . $this->getMatch() . '&case=' . $this->getCase() .
|
|
|
|
'&target=' . $this->getTarget() . '&search=' . $this->getSearch());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the Bible url
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
protected function setBibleUrl()
|
|
|
|
{
|
2024-01-26 17:18:26 +02:00
|
|
|
$this->url_bible = $this->getReturnUrl() ?? Route::_('index.php?option=com_getbible&view=app&Itemid=' . $this->params->get('app_menu', 0) . '&t=' . $this->translation->abbreviation);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove all slug values from the returned items
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
* @since 2.0.1
|
|
|
|
*/
|
|
|
|
public function removeSlugs()
|
|
|
|
{
|
|
|
|
foreach ($this->items as &$childArray)
|
|
|
|
{
|
|
|
|
if (is_array($childArray) && array_key_exists('slug', $childArray))
|
|
|
|
{
|
|
|
|
unset($childArray['slug']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (is_object($childArray) && isset($childArray->slug))
|
|
|
|
{
|
|
|
|
unset($childArray->slug);
|
|
|
|
}
|
|
|
|
}
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prepares the document
|
|
|
|
*/
|
|
|
|
protected function _prepareDocument()
|
|
|
|
{
|
|
|
|
|
|
|
|
// Only load jQuery if needed. (default is true)
|
|
|
|
if ($this->params->get('add_jquery_framework', 1) == 1)
|
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
Html::_('jquery.framework');
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
// Load the header checker class.
|
|
|
|
require_once( JPATH_COMPONENT_SITE.'/helpers/headercheck.php' );
|
|
|
|
// Initialize the header checker.
|
2024-01-22 10:48:28 +02:00
|
|
|
$HeaderCheck = new getbibleHeaderCheck();
|
2023-07-26 11:09:42 +02:00
|
|
|
|
|
|
|
// always load these files.
|
2024-01-22 10:48:28 +02:00
|
|
|
Html::_('stylesheet', "media/com_getbible/datatable/css/datatables.min.css", ['version' => 'auto']);
|
|
|
|
Html::_('script', "media/com_getbible/datatable/js/pdfmake.min.js", ['version' => 'auto']);
|
|
|
|
Html::_('script', "media/com_getbible/datatable/js/vfs_fonts.js", ['version' => 'auto']);
|
|
|
|
Html::_('script', "media/com_getbible/datatable/js/datatables.min.js", ['version' => 'auto']);
|
2023-07-26 11:09:42 +02:00
|
|
|
|
|
|
|
// Add View JavaScript File
|
2024-01-22 10:48:28 +02:00
|
|
|
Html::_('script', "components/com_getbible/assets/js/search.js", ['version' => 'auto']);
|
2023-07-26 11:09:42 +02:00
|
|
|
|
|
|
|
// Load uikit options.
|
|
|
|
$uikit = $this->params->get('uikit_load');
|
|
|
|
// Set script size.
|
|
|
|
$size = $this->params->get('uikit_min');
|
|
|
|
// The uikit css.
|
|
|
|
if ((!$HeaderCheck->css_loaded('uikit.min') || $uikit == 1) && $uikit != 2 && $uikit != 3)
|
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
Html::_('stylesheet', 'media/com_getbible/uikit-v3/css/uikit'.$size.'.css', ['version' => 'auto']);
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
// The uikit js.
|
|
|
|
if ((!$HeaderCheck->js_loaded('uikit.min') || $uikit == 1) && $uikit != 2 && $uikit != 3)
|
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
Html::_('script', 'media/com_getbible/uikit-v3/js/uikit'.$size.'.js', ['version' => 'auto']);
|
|
|
|
Html::_('script', 'media/com_getbible/uikit-v3/js/uikit-icons'.$size.'.js', ['version' => 'auto']);
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
$search_found_color = $this->params->get('search_found_color', '#4747ff');
|
2023-08-21 17:36:30 +02:00
|
|
|
$table_selection_color = $this->params->get('table_selection_color', '#dfdfdf');
|
|
|
|
|
|
|
|
$url_search = $this->getSearchUrl();
|
|
|
|
$url_ajax = $this->getAjaxUrl();
|
|
|
|
$book = $this->getReturnUrlBook();
|
|
|
|
$chapter = $this->getReturnUrlChapter();
|
2023-07-26 11:09:42 +02:00
|
|
|
// add the document default css file
|
2024-01-22 10:48:28 +02:00
|
|
|
Html::_('stylesheet', 'components/com_getbible/assets/css/search.css', ['version' => 'auto']);
|
2023-07-26 11:09:42 +02:00
|
|
|
// Set the Custom CSS script to view
|
|
|
|
$this->document->addStyleDeclaration("
|
|
|
|
.uk-table tr {
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
.uk-table table.dataTable tbody > tr.selected, .uk-table table.dataTable tbody > tr > .selected {
|
|
|
|
background-color: $table_selection_color;
|
|
|
|
}
|
|
|
|
.uk-table tr.selected td {
|
|
|
|
background-color: $table_selection_color;
|
|
|
|
}
|
|
|
|
.getbible-word-found {
|
|
|
|
font-weight: bolder;
|
|
|
|
color: $search_found_color;
|
|
|
|
}
|
|
|
|
.direction-rtl {
|
|
|
|
direction: rtl;
|
|
|
|
text-align: right;
|
|
|
|
unicode-bidi: bidi-override;
|
|
|
|
}
|
|
|
|
.direction-ltr {
|
|
|
|
direction: ltr;
|
|
|
|
text-align: left;
|
|
|
|
unicode-bidi: bidi-override;
|
|
|
|
}
|
|
|
|
");
|
2023-08-21 17:36:30 +02:00
|
|
|
// Set the Custom JS script to view
|
|
|
|
$this->document->addScriptDeclaration("
|
|
|
|
const urlSearch = '$url_search';
|
|
|
|
const urlAjax = '$url_ajax';
|
|
|
|
const getAppURL = (book, chapter, verse, translation = 'kjv') => {
|
|
|
|
// build search url
|
|
|
|
return urlAjax +
|
|
|
|
'getAppUrl&translation=' + urlencode(translation) +
|
|
|
|
'&book=' + book +
|
|
|
|
'&chapter=' + chapter +
|
|
|
|
'&verse=' + verse;
|
|
|
|
};
|
|
|
|
const getSearchURL = (search, words = 1, match = 1, type_case = 1, target = 1000, translation = 'kjv') => {
|
|
|
|
// build search url
|
|
|
|
return urlAjax +
|
|
|
|
'getSearchUrl&translation=' + urlencode(translation) +
|
|
|
|
'&words=' + words +
|
|
|
|
'&match=' + match +
|
|
|
|
'&case=' + type_case +
|
|
|
|
'&target=' + target +
|
|
|
|
'&search=' + urlencode(search) +
|
|
|
|
'&target_book=0' +
|
|
|
|
'&book=$book&chapter=$chapter';
|
|
|
|
};
|
|
|
|
");
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setting the toolbar
|
|
|
|
*/
|
|
|
|
protected function addToolBar()
|
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
|
2023-07-26 11:09:42 +02:00
|
|
|
// set help url for this view if found
|
|
|
|
$this->help_url = GetbibleHelper::getHelpUrl('search');
|
2024-01-22 10:48:28 +02:00
|
|
|
if (StringHelper::check($this->help_url))
|
2023-07-26 11:09:42 +02:00
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
ToolbarHelper::help('COM_GETBIBLE_HELP_MANAGER', false, $this->help_url);
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
// now initiate the toolbar
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->toolbar = Toolbar::getInstance();
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
|
|
|
|
2023-08-10 09:04:11 +02:00
|
|
|
/**
|
|
|
|
* Get the modules published in a position
|
|
|
|
*/
|
|
|
|
public function getModules($position, $seperator = '', $class = '')
|
|
|
|
{
|
|
|
|
// set default
|
|
|
|
$found = false;
|
|
|
|
// check if we aleady have these modules loaded
|
|
|
|
if (isset($this->setModules[$position]))
|
|
|
|
{
|
|
|
|
$found = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// this is where you want to load your module position
|
2024-01-22 10:48:28 +02:00
|
|
|
$modules = ModuleHelper::getModules($position);
|
|
|
|
if (ArrayHelper::check($modules, true))
|
2023-08-10 09:04:11 +02:00
|
|
|
{
|
|
|
|
// set the place holder
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->setModules[$position] = [];
|
2023-08-10 09:04:11 +02:00
|
|
|
foreach($modules as $module)
|
|
|
|
{
|
2024-01-22 10:48:28 +02:00
|
|
|
$this->setModules[$position][] = ModuleHelper::renderModule($module);
|
2023-08-10 09:04:11 +02:00
|
|
|
}
|
|
|
|
$found = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// check if modules were found
|
2024-01-22 10:48:28 +02:00
|
|
|
if ($found && isset($this->setModules[$position]) && ArrayHelper::check($this->setModules[$position]))
|
2023-08-10 09:04:11 +02:00
|
|
|
{
|
|
|
|
// set class
|
2024-01-22 10:48:28 +02:00
|
|
|
if (StringHelper::check($class))
|
2023-08-10 09:04:11 +02:00
|
|
|
{
|
|
|
|
$class = ' class="'.$class.'" ';
|
|
|
|
}
|
|
|
|
// set seperating return values
|
|
|
|
switch($seperator)
|
|
|
|
{
|
|
|
|
case 'none':
|
|
|
|
return implode('', $this->setModules[$position]);
|
|
|
|
break;
|
|
|
|
case 'div':
|
|
|
|
return '<div'.$class.'>'.implode('</div><div'.$class.'>', $this->setModules[$position]).'</div>';
|
|
|
|
break;
|
|
|
|
case 'list':
|
|
|
|
return '<ul'.$class.'><li>'.implode('</li><li>', $this->setModules[$position]).'</li></ul>';
|
|
|
|
break;
|
|
|
|
case 'array':
|
|
|
|
case 'Array':
|
|
|
|
return $this->setModules[$position];
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return implode('<br />', $this->setModules[$position]);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2023-07-26 11:09:42 +02:00
|
|
|
/**
|
|
|
|
* Escapes a value for output in a view script.
|
|
|
|
*
|
|
|
|
* @param mixed $var The output to escape.
|
|
|
|
*
|
|
|
|
* @return mixed The escaped value.
|
|
|
|
*/
|
|
|
|
public function escape($var, $sorten = false, $length = 40)
|
|
|
|
{
|
|
|
|
// use the helper htmlEscape method instead.
|
2024-01-22 10:48:28 +02:00
|
|
|
return StringHelper::html($var, $this->_charset, $sorten, $length);
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|
2024-01-26 17:18:26 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Document (helper method toward Joomla 4 and 5)
|
|
|
|
*/
|
|
|
|
public function getDocument()
|
|
|
|
{
|
|
|
|
$this->document ??= JFactory::getDocument();
|
|
|
|
|
|
|
|
return $this->document;
|
|
|
|
}
|
2023-07-26 11:09:42 +02:00
|
|
|
}
|