729 lines
16 KiB
PHP
Raw Normal View History

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');
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;
use Joomla\CMS\Plugin\PluginHelper;
use Joomla\CMS\Toolbar\ToolbarHelper;
use Joomla\CMS\Session\Session;
use Joomla\CMS\Router\Route;
use Joomla\CMS\Uri\Uri;
use Joomla\CMS\Helper\ModuleHelper;
use VDM\Joomla\Utilities\StringHelper;
use VDM\Joomla\Utilities\ArrayHelper;
2023-07-26 11:09:42 +02:00
/**
* Getbible Html View class for the Openai
*/
class GetbibleViewOpenai extends HtmlView
{
// Overwriting JView display method
function display($tpl = null)
{
2023-07-26 11:09:42 +02:00
// get combined params of both component and menu
$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
$this->user = Factory::getUser();
2023-07-26 11:09:42 +02:00
// Initialise variables.
$this->item = $this->get('Item');
$this->translation = $this->get('Translation');
// remove from page (in case debug mode is on)
$this->params->set('openai_token', null);
2023-09-07 07:51:44 +02:00
$this->params->set('gitea_token', null);
// set meta
$this->setMetaData();
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')))
{
throw new \Exception(implode(PHP_EOL, $errors), 500);
2023-07-26 11:09:42 +02:00
}
parent::display($tpl);
}
2023-09-07 07:51:44 +02:00
/**
* Set the page metadata
*
* @return void
* @since 2.0.1
*/
protected function setMetaData()
{
if (empty($this->item))
{
return;
}
// set the page title
$title = Text::sprintf('COM_GETBIBLE_OPEN_AI_S_IN_S_S',
2023-09-07 07:51:44 +02:00
$this->getSelectedWord(),
$this->translation->translation,
$this->params->get('page_title', '')
);
$this->getDocument()->setTitle($title);
2023-09-07 07:51:44 +02:00
$url = $this->getCanonicalUrl();
// set the Generator
$this->getDocument()->setGenerator('getBible! - Open AI - Open Source Bible App.');
2023-09-07 07:51:44 +02:00
// set the metadata values
$description = Text::sprintf('COM_GETBIBLE_OPEN_AI_RESPOND_TO_PROMPT_ABOUT_S_IN_S',
2023-09-07 07:51:44 +02:00
$this->getSelectedWord(),
$this->translation->translation
);
$this->getDocument()->setDescription($description);
$this->getDocument()->setMetadata('keywords', Text::sprintf('COM_GETBIBLE_OPEN_AI_S_S_BIBLE_S_S_SCRIPTURE_RESEARCH_GETBIBLE',
2023-09-07 07:51:44 +02:00
$this->getSelectedWord(),
$this->translation->translation,
$this->translation->abbreviation,
$this->translation->language
));
$this->getDocument()->setMetaData('author', Text::_('COM_GETBIBLE_OPEN_AI'));
2023-09-07 07:51:44 +02:00
// set canonical URL
$this->getDocument()->addHeadLink($url, 'canonical');
2023-09-07 07:51:44 +02:00
// OG:Title
$this->getDocument()->setMetadata('og:title', $title, 'property');
2023-09-07 07:51:44 +02:00
// OG:Description
$this->getDocument()->setMetadata('og:description', $description, 'property');
2023-09-07 07:51:44 +02:00
// OG:Image
// $this->getDocument()->setMetadata('og:image', 'YOUR_IMAGE_URL_HERE', 'property');
2023-09-07 07:51:44 +02:00
// OG:URL
$this->getDocument()->setMetadata('og:url', $url, 'property');
2023-09-07 07:51:44 +02:00
// OG:Type
$this->getDocument()->setMetadata('og:type', 'website', 'property');
2023-09-07 07:51:44 +02:00
// Twitter Card Type
$this->getDocument()->setMetadata('twitter:card', 'summary');
2023-09-07 07:51:44 +02:00
// Twitter Title
$this->getDocument()->setMetadata('twitter:title', $title);
2023-09-07 07:51:44 +02:00
// Twitter Description
$this->getDocument()->setMetadata('twitter:description', $description);
2023-09-07 07:51:44 +02:00
// Twitter Image
// $this->getDocument()->setMetadata('twitter:image', 'YOUR_IMAGE_URL_HERE');
2023-09-07 07:51:44 +02:00
// Twitter Site (Your website's Twitter handle)
// $this->getDocument()->setMetadata('twitter:site', '@YourTwitterHandle');
2023-09-07 07:51:44 +02:00
// Twitter Creator (Author's Twitter handle or your website's Twitter handle)
// $this->getDocument()->setMetadata('twitter:creator', '@AuthorTwitterHandle');
2023-09-07 07:51:44 +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 AI url
*
* @return string
* @since 2.0.1
*/
public function getAiUrl(): string
{
if (empty($this->url_ai))
{
$this->setAiUrl();
}
return $this->url_ai ?? '';
}
/**
* 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))
{
return '&bibleurl=' . $this->url_return_value;
}
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 last prompt
*
* @return object|null
* @since 2.0.1
*/
public function getPrompt(): ?object
{
if (empty($this->prompt))
{
$this->setPrompt();
}
return $this->prompt ?? null;
}
/**
* Get the selected word
*
* @return string
* @since 2.0.1
*/
public function getSelectedWord(): string
{
if (empty($this->selected_word))
{
$this->setSelectedWord();
}
return $this->selected_word ?? '';
}
/**
* Get the word number/s
*
* @return string
* @since 2.0.1
*/
public function getWord(): string
{
if (empty($this->word))
{
$this->setWord();
}
return $this->word ?? '';
}
/**
* Get the verse number/s
*
* @return string
* @since 2.0.1
*/
public function getVerse(): string
{
if (empty($this->verse))
{
$this->setVerse();
}
return $this->verse ?? '';
}
/**
* Get the chapter number/s
*
* @return string
* @since 2.0.1
*/
public function getChapter(): string
{
if (empty($this->chapter))
{
$this->setChapter();
}
return $this->chapter ?? '';
}
/**
* Get the book number/s
*
* @return string
* @since 2.0.1
*/
public function getBook(): string
{
if (empty($this->book))
{
$this->setBook();
}
return $this->book ?? '';
}
/**
* Get the prompt guid
*
* @return string
* @since 2.0.1
*/
public function getGuid(): string
{
if (empty($this->prompt_guid))
{
$this->setGuid();
}
return $this->prompt_guid ?? '';
}
/**
* Set the return URL if it's provided and internal.
*
* @return void
* @since 2.0.1
*/
protected function setReturnUrl(): void
{
$encodedUrl = $this->input->get('bibleurl', null, 'base64');
if ($encodedUrl === null)
{
return;
}
$decodedUrl = base64_decode($encodedUrl);
$uri = Uri::getInstance($decodedUrl);
$router = Router::getInstance('site');
2023-09-07 07:51:44 +02:00
$this->url_return_value = $encodedUrl;
$this->url_return = $decodedUrl;
$this->url_return_query = $router->parse($uri);
}
/**
* Set the prompt guid
*
* @return void
* @since 2.0.1
*/
protected function setGuid()
{
$prompt = $this->getPrompt();
$this->prompt_guid = $prompt->prompt ?? '';
}
/**
* Set the book number/s
*
* @return void
* @since 2.0.1
*/
protected function setBook()
{
$prompt = $this->getPrompt();
$this->book = $prompt->book ?? '';
}
/**
* Set the chapter number/s
*
* @return void
* @since 2.0.1
*/
protected function setChapter()
{
$prompt = $this->getPrompt();
$this->chapter = $prompt->chapter ?? '';
}
/**
* Set the verse number/s
*
* @return void
* @since 2.0.1
*/
protected function setVerse()
{
$prompt = $this->getPrompt();
$this->verse = $prompt->verse ?? '';
}
/**
* Set the word number/s
*
* @return void
* @since 2.0.1
*/
protected function setWord()
{
$prompt = $this->getPrompt();
$this->word = $prompt->word ?? '';
}
/**
* Set the selected word
*
* @return void
* @since 2.0.1
*/
public function setSelectedWord()
{
$prompt = $this->getPrompt();
$this->selected_word = $prompt->selected_word ?? '';
}
/**
* Set the last prompt
*
* @return void
* @since 2.0.1
*/
protected function setPrompt()
{
// Check if the 'item' property or its first element is empty.
if (empty($this->item) || empty($this->item[0]))
{
return;
}
// Set the last item from the 'item' array as the prompt.
$this->prompt = end($this->item);
// Reset the internal pointer of the array to ensure consistent behaviour elsewhere.
reset($this->item);
}
/**
* Set the base url
*
* @return void
* @since 2.0.1
*/
protected function setBaseUrl()
{
$this->url_base = Uri::base();
2023-09-07 07:51:44 +02:00
}
/**
* Set the AJAX url
*
* @return void
* @since 2.0.1
*/
protected function setAjaxUrl()
{
$this->url_ajax = $this->getBaseUrl() . 'index.php?option=com_getbible&format=json&raw=true&' . Session::getFormToken() . '=1&task=ajax.';
2023-09-07 07:51:44 +02:00
}
/**
* Set the Bible url
*
* @return void
* @since 2.0.1
*/
protected function setBibleUrl()
{
$this->url_bible = $this->getReturnUrl() ?? Route::_('index.php?option=com_getbible&view=app&Itemid=' . $this->params->get('app_menu', 0) . '&t=' . $this->translation->abbreviation);
2023-09-07 07:51:44 +02:00
}
/**
* Set the AI url
*
* @return void
* @since 2.0.1
*/
protected function setAiUrl()
{
// set the current search URL
$this->url_ai = Route::_('index.php?option=com_getbible&view=openai&t=' . $this->translation->abbreviation .
2023-09-07 07:51:44 +02:00
'&Itemid=' . $this->params->get('app_menu', 0) .
$this->getReturnUrlValue() .
'&guid=' . $this->getGuid() .
'&book=' . $this->getBook() .
'&chapter=' . $this->getChapter() .
'&verse=' . $this->getVerse() .
'&words=' . $this->getWord());
}
/**
* Set the canonical url
*
* @return void
* @since 2.0.1
*/
protected function setCanonicalUrl()
{
// set the current search URL
$this->url_canonical = trim($this->getBaseUrl(), '/') .
Route::_('index.php?option=com_getbible&view=openai&Itemid=' . $this->params->get('app_menu', 0) .
2023-09-07 07:51:44 +02:00
'&t=' . $this->translation->abbreviation .
'&guid=' . $this->getGuid() .
'&book=' . $this->getBook() .
'&chapter=' . $this->getChapter() .
'&verse=' . $this->getVerse() .
'&words=' . $this->getWord());
}
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)
{
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.
$HeaderCheck = new getbibleHeaderCheck();
2023-07-26 11:09:42 +02:00
// Add View JavaScript File
Html::_('script', "components/com_getbible/assets/js/openai.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)
{
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)
{
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
// add the document default css file
Html::_('stylesheet', 'components/com_getbible/assets/css/openai.css', ['version' => 'auto']);
2023-07-26 11:09:42 +02:00
}
/**
* Setting the toolbar
*/
protected function addToolBar()
{
// set help url for this view if found
$this->help_url = GetbibleHelper::getHelpUrl('openai');
if (StringHelper::check($this->help_url))
2023-07-26 11:09:42 +02:00
{
ToolbarHelper::help('COM_GETBIBLE_HELP_MANAGER', false, $this->help_url);
2023-07-26 11:09:42 +02:00
}
// now initiate the toolbar
$this->toolbar = Toolbar::getInstance();
2023-07-26 11:09:42 +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
$modules = ModuleHelper::getModules($position);
if (ArrayHelper::check($modules, true))
2023-07-26 11:09:42 +02:00
{
// set the place holder
$this->setModules[$position] = [];
2023-07-26 11:09:42 +02:00
foreach($modules as $module)
{
$this->setModules[$position][] = ModuleHelper::renderModule($module);
2023-07-26 11:09:42 +02:00
}
$found = true;
}
}
// check if modules were found
if ($found && isset($this->setModules[$position]) && ArrayHelper::check($this->setModules[$position]))
2023-07-26 11:09:42 +02:00
{
// set class
if (StringHelper::check($class))
2023-07-26 11:09:42 +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;
}
/**
* 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.
return StringHelper::html($var, $this->_charset, $sorten, $length);
2023-07-26 11:09:42 +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
}