From 13dedb7b0e834b41241178085f41770ef985961c Mon Sep 17 00:00:00 2001 From: aB0t Date: Tue, 30 Apr 2024 10:42:14 +0200 Subject: [PATCH] Release of v4.0.0-rc2 Improved the Schema Table update engine (more). Fix autoloader timing, and loading. Implement the Joomla Powers in JCB code, to move away from JClasses. Remove the SQL update, to only use the Schema updates of table columns to avoid collusion. --- CHANGELOG.md | 35 +++----- ComponentbuilderInstallerScript.php | 37 +------- README.md | 10 +-- admin/README.txt | 10 +-- .../en-GB/en-GB.com_componentbuilder.ini | 1 - .../server/linked_components_fullwidth.php | 29 ------- admin/sql/install.mysql.utf8.sql | 87 +------------------ admin/sql/updates/mysql/4.0.0-alpha.sql | 3 +- .../mysql/{4.0.0-beta1.sql => 4.0.0-beta.sql} | 0 admin/sql/updates/mysql/4.0.0-beta2.sql | 28 ------ admin/sql/updates/mysql/4.0.0-beta3.sql | 2 - admin/sql/updates/mysql/4.0.0-beta4.sql | 18 ---- admin/sql/updates/mysql/4.0.0-beta5.sql | 1 - admin/tmpl/server/default.php | 12 --- componentbuilder.xml | 6 +- componentbuilder_update_server.xml | 80 +---------------- .../Compiler/JoomlaPower/Extractor.php | 1 + .../Compiler/Service/Utilities.php | 3 +- .../Compiler/Utilities/FileInjector.php | 60 +++++++++++-- media/js/help_document.js | 50 +++++------ 20 files changed, 115 insertions(+), 358 deletions(-) delete mode 100644 admin/layouts/server/linked_components_fullwidth.php rename admin/sql/updates/mysql/{4.0.0-beta1.sql => 4.0.0-beta.sql} (100%) delete mode 100644 admin/sql/updates/mysql/4.0.0-beta2.sql delete mode 100644 admin/sql/updates/mysql/4.0.0-beta3.sql delete mode 100644 admin/sql/updates/mysql/4.0.0-beta4.sql delete mode 100644 admin/sql/updates/mysql/4.0.0-beta5.sql diff --git a/CHANGELOG.md b/CHANGELOG.md index 93482224f..253e50644 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,36 +1,25 @@ -# v4.0.0-rc1 +# v4.0.0-rc2 - Improved the Schema Table update engine (more). - Fix autoloader timing, and loading. -- Implement the Joomla Powers in JCB code, to move away from JClasses. +- Implement the Joomla Powers in JCB code, to move away from JClasses. +- Remove the SQL update, to only use the Schema updates of table columns to avoid collusion. -# v4.0.0-beta5 +# v4.0.0-beta +- Add the compiler menu back. +- Fix the CustomfolderlistField #1094 +- Add view list and single name fix. +- Add component code name fix. +- Add reset list of powers. +- Add Joomla powers for namespace dynamic management. +- Add fallback option to ensure that all JCB tables and fields exist. +- Move the powers autoloader to its own file. - Fix the media field size limitation. #1109 - Add dynamic datatype update to schema field check. - Fix version_update column size. - Improved the Schema Table update engine. -# v4.0.0-beta4 - -- Add fallback option to ensure that all JCB tables and fields exist. -- Move the powers autoloader to its own file. - -# v4.0.0-beta3 - -- Add Joomla powers for namespace dynamic management. - -# v4.0.0-beta2 - -- Add view list and single name fix. -- Add component code name fix. -- Add reset list of powers. - -# v4.0.0-beta1 - -- Add the compiler menu back. -- Fix the CustomfolderlistField #1094 - # v4.0.0-alpha - First alpha release of Component Builder towards Joomla 4 (very unstable...) diff --git a/ComponentbuilderInstallerScript.php b/ComponentbuilderInstallerScript.php index 37ef51bef..2b3e75d78 100644 --- a/ComponentbuilderInstallerScript.php +++ b/ComponentbuilderInstallerScript.php @@ -503,9 +503,6 @@ class Com_ComponentbuilderInstallerScript implements InstallerScriptInterface // Remove Joomla_plugin_files_folders_urls from action logs config table. $this->removeActionLogConfig('com_componentbuilder.joomla_plugin_files_folders_urls'); - - // Remove Joomla_component from action logs config table. - $this->removeActionLogConfig('com_componentbuilder.joomla_component'); // little notice as after service, in case of bad experience with component. echo '

Did something go wrong? Are you disappointed?

@@ -2313,22 +2310,6 @@ class Com_ComponentbuilderInstallerScript implements InstallerScriptInterface // textPrefix 'COM_COMPONENTBUILDER' ); - - // Add Joomla_component to the action logs config table. - $this->setActionLogConfig( - // typeTitle - 'JOOMLA_COMPONENT', - // typeAlias - 'com_componentbuilder.joomla_component', - // idHolder - 'id', - // titleHolder - 'system_name', - // tableName - '#__componentbuilder_joomla_component', - // textPrefix - 'COM_COMPONENTBUILDER' - ); } // do any updates needed @@ -3229,7 +3210,7 @@ class Com_ComponentbuilderInstallerScript implements InstallerScriptInterface echo '
-

Upgrade to Version 4.0.0-rc1 Was Successful! Let us know if anything is not working as expected.

'; +

Upgrade to Version 4.0.0-rc2 Was Successful! Let us know if anything is not working as expected.

'; // Add/Update component in the action logs extensions table. $this->setActionLogsExtensions(); @@ -4033,22 +4014,6 @@ class Com_ComponentbuilderInstallerScript implements InstallerScriptInterface // textPrefix 'COM_COMPONENTBUILDER' ); - - // Add/Update Joomla_component in the action logs config table. - $this->setActionLogConfig( - // typeTitle - 'JOOMLA_COMPONENT', - // typeAlias - 'com_componentbuilder.joomla_component', - // idHolder - 'id', - // titleHolder - 'system_name', - // tableName - '#__componentbuilder_joomla_component', - // textPrefix - 'COM_COMPONENTBUILDER' - ); } // move CLI files diff --git a/README.md b/README.md index 69fb990e9..500d1dca5 100644 --- a/README.md +++ b/README.md @@ -9,7 +9,7 @@ The Component Builder for [Joomla](https://extensions.joomla.org/extension/compo Whether you're a seasoned [Joomla](https://extensions.joomla.org/extension/component-builder/) developer, or have just started, Component Builder will save you lots of time and money. A real must have! -You can install it quite easily and with no limitations. On [gitea](https://git.vdm.dev/joomla/Component-Builder/tags) is the latest release (4.0.0-rc1) with **ALL** its features and **ALL** concepts totally open-source and free! +You can install it quite easily and with no limitations. On [gitea](https://git.vdm.dev/joomla/Component-Builder/tags) is the latest release (4.0.0-rc2) with **ALL** its features and **ALL** concepts totally open-source and free! > Watch Quick Build of a Hello World component in [JCB on Youtube](https://www.youtube.com/watch?v=IQfsLYIeblk&list=PLQRGFI8XZ_wtGvPQZWBfDzzlERLQgpMRE&index=45) @@ -144,13 +144,13 @@ TODO + *Author*: [Llewellyn van der Merwe](mailto:joomla@vdm.io) + *Name*: [Component Builder](https://git.vdm.dev/joomla/Component-Builder) + *First Build*: 30th April, 2015 -+ *Last Build*: 27th April, 2024 -+ *Version*: 4.0.0-rc1 ++ *Last Build*: 30th April, 2024 ++ *Version*: 4.0.0-rc2 + *Copyright*: Copyright (C) 2015 Vast Development Method. All rights reserved. + *License*: GNU General Public License version 2 or later; see LICENSE.txt -+ *Line count*: **746056** ++ *Line count*: **745929** + *Field count*: **2097** -+ *File count*: **5293** ++ *File count*: **5288** + *Folder count*: **528** > This **component** was build with a [Joomla](https://extensions.joomla.org/extension/component-builder/) [Automated Component Builder](https://www.joomlacomponentbuilder.com). diff --git a/admin/README.txt b/admin/README.txt index 69fb990e9..500d1dca5 100644 --- a/admin/README.txt +++ b/admin/README.txt @@ -9,7 +9,7 @@ The Component Builder for [Joomla](https://extensions.joomla.org/extension/compo Whether you're a seasoned [Joomla](https://extensions.joomla.org/extension/component-builder/) developer, or have just started, Component Builder will save you lots of time and money. A real must have! -You can install it quite easily and with no limitations. On [gitea](https://git.vdm.dev/joomla/Component-Builder/tags) is the latest release (4.0.0-rc1) with **ALL** its features and **ALL** concepts totally open-source and free! +You can install it quite easily and with no limitations. On [gitea](https://git.vdm.dev/joomla/Component-Builder/tags) is the latest release (4.0.0-rc2) with **ALL** its features and **ALL** concepts totally open-source and free! > Watch Quick Build of a Hello World component in [JCB on Youtube](https://www.youtube.com/watch?v=IQfsLYIeblk&list=PLQRGFI8XZ_wtGvPQZWBfDzzlERLQgpMRE&index=45) @@ -144,13 +144,13 @@ TODO + *Author*: [Llewellyn van der Merwe](mailto:joomla@vdm.io) + *Name*: [Component Builder](https://git.vdm.dev/joomla/Component-Builder) + *First Build*: 30th April, 2015 -+ *Last Build*: 27th April, 2024 -+ *Version*: 4.0.0-rc1 ++ *Last Build*: 30th April, 2024 ++ *Version*: 4.0.0-rc2 + *Copyright*: Copyright (C) 2015 Vast Development Method. All rights reserved. + *License*: GNU General Public License version 2 or later; see LICENSE.txt -+ *Line count*: **746056** ++ *Line count*: **745929** + *Field count*: **2097** -+ *File count*: **5293** ++ *File count*: **5288** + *Folder count*: **528** > This **component** was build with a [Joomla](https://extensions.joomla.org/extension/component-builder/) [Automated Component Builder](https://www.joomlacomponentbuilder.com). diff --git a/admin/language/en-GB/en-GB.com_componentbuilder.ini b/admin/language/en-GB/en-GB.com_componentbuilder.ini index 2e355364f..9ccfcaebb 100644 --- a/admin/language/en-GB/en-GB.com_componentbuilder.ini +++ b/admin/language/en-GB/en-GB.com_componentbuilder.ini @@ -8100,7 +8100,6 @@ COM_COMPONENTBUILDER_SERVER_HOST_HINT="yourhost.com" COM_COMPONENTBUILDER_SERVER_HOST_LABEL="Host/IP
(encrypted field)" COM_COMPONENTBUILDER_SERVER_HOST_MESSAGE="Error! Please add server host name here." COM_COMPONENTBUILDER_SERVER_ID="Id" -COM_COMPONENTBUILDER_SERVER_LINKED_COMPONENTS="Linked Components" COM_COMPONENTBUILDER_SERVER_MODIFIED_BY_DESC="The last user that modified this Server." COM_COMPONENTBUILDER_SERVER_MODIFIED_BY_LABEL="Modified By" COM_COMPONENTBUILDER_SERVER_MODIFIED_DATE_DESC="The date this Server was modified." diff --git a/admin/layouts/server/linked_components_fullwidth.php b/admin/layouts/server/linked_components_fullwidth.php deleted file mode 100644 index 56499febe..000000000 --- a/admin/layouts/server/linked_components_fullwidth.php +++ /dev/null @@ -1,29 +0,0 @@ - - * @git Joomla Component Builder - * @copyright Copyright (C) 2015 Vast Development Method. All rights reserved. - * @license GNU General Public License version 2 or later; see LICENSE.txt - */ - -use Joomla\CMS\Factory; -use Joomla\CMS\Language\Text; -use Joomla\CMS\HTML\HTMLHelper as Html; -use VDM\Component\Componentbuilder\Administrator\Helper\ComponentbuilderHelper; - -// No direct access to this file -defined('_JEXEC') or die; - -// set the defaults -$items = $displayData->vyclinked_components; -$user = Factory::getApplication()->getIdentity(); -$id = $displayData->item->id; - - -?> -
-oops! error..... -
diff --git a/admin/sql/install.mysql.utf8.sql b/admin/sql/install.mysql.utf8.sql index 4aac1cae4..dbe4d37e7 100644 --- a/admin/sql/install.mysql.utf8.sql +++ b/admin/sql/install.mysql.utf8.sql @@ -2047,91 +2047,8 @@ CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_plugin_files_folders_urls -- Dumping data for table `#__componentbuilder_joomla_component` -- -INSERT INTO `#__componentbuilder_joomla_component` (`id`, `add_admin_event`, `add_backup_folder_path`, `add_css_admin`, `add_css_site`, `add_email_helper`, `add_git_folder_path`, `add_javascript`, `add_license`, `add_menu_prefix`, `add_namespace_prefix`, `add_php_helper_admin`, `add_php_helper_both`, `add_php_helper_site`, `add_php_method_uninstall`, `add_php_postflight_install`, `add_php_postflight_update`, `add_php_preflight_install`, `add_php_preflight_update`, `add_placeholders`, `add_powers`, `add_sales_server`, `add_site_event`, `add_sql`, `add_sql_uninstall`, `add_update_server`, `addcontributors`, `addfootable`, `addreadme`, `adduikit`, `assets_table_fix`, `author`, `backup_folder_path`, `bom`, `buildcomp`, `buildcompsql`, `companyname`, `component_version`, `copyright`, `created`, `creatuserhelper`, `crowdin_account_api_key`, `crowdin_project_api_key`, `crowdin_project_identifier`, `crowdin_username`, `css_admin`, `css_site`, `dashboard`, `dashboard_type`, `debug_linenr`, `description`, `email`, `emptycontributors`, `export_buy_link`, `export_key`, `git_folder_path`, `guid`, `image`, `javascript`, `joomla_source_link`, `license`, `license_type`, `menu_prefix`, `modified`, `mvc_versiondate`, `name`, `name_code`, `namespace_prefix`, `number`, `php_admin_event`, `php_helper_admin`, `php_helper_both`, `php_helper_site`, `php_method_uninstall`, `php_postflight_install`, `php_postflight_update`, `php_preflight_install`, `php_preflight_update`, `php_site_event`, `readme`, `remove_line_breaks`, `sales_server`, `short_description`, `sql`, `sql_uninstall`, `system_name`, `toignore`, `translation_tool`, `update_server`, `update_server_target`, `update_server_url`, `website`, `whmcs_buy_link`, `whmcs_key`, `whmcs_url`, `params`, `published`, `version`, `hits`, `access`, `ordering`) VALUES -(1, '', '', '', '', 1, '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', '', '', 1, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '3.2.10', 'Copyright (C) 2015. All Rights Reserved', '2015-03-20 15:27:13', 1, 'mIu5D5hcoKG7Qwq9t9+EbeIDz5myyqPT+Y9gfumTOnU=', 'ASZTKYzZpIKCLc9tWjeUim24yOLGP/P7x7ltY1+yCeQ=', '', 'kEHnfNOmA6lJcwrJs2YKnN6cupuqs/W9lZPuNJQfNJw=', '', '', '', 1, '', 'The Basic Learning Management System for Joomla.', 'info@vdm.io', 1, '', '0wpowsjavpfWE8NBDaANtTAa2HI1HwCS0MeJ0cJvu1C0O9lituow6lJ5QS5burG5YtvM0v0pJgKRnah0ucjLsw==', '', '90f80dee-d3d8-487d-a6c4-5627cb317824', 'images/vdm/LMS500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2023-09-28 06:26:25', 1, 'Learning Management', 'learningmanager', '', 4, '', '', '	/**
	* 	Should Dropbox be updated
	**/
	public static $update_dropbox = false;

	/**
	* 	The dropbox links
	**/
	public static $links_dropbox;

	/**
	* 	Use counter to insure code run once
	**/
	protected static $update_dropbox_counter = 0;

	/**
	 *	check if this session has a download attached
	 *	via dropbox
	 */
	public static function hasDownload($session,$date)
	{
		// set the dropbox links
		self::getDropbox();
		// check if it was set
		if(Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$links_dropbox))
		{
			// buld the link from session id
			$link = self::getSessionDropboxLink($session);
			$bucket = array();
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($link))
			{
				$link = strtolower($link);
				foreach (self::$links_dropbox as $folder => $db_link)
				{
					$folder = strtolower($folder);
					if (strpos($folder,$link) !== false)
					{
						$fileName = str_replace($link, '', $folder);
						$bucket[$fileName] = $db_link;
					}
				}
				// check if we found som files
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
				{
					// get Token!
					$token = Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
					// and user
					$user = Factory::getUser();
					foreach ($bucket as $filename => $keyLink)
					{
						$filedate = 0;
						list($name,$ext) = explode('.',$filename);
						$key = $name;
						// check for names with date
						if (strpos($name,'__') !== false)
						{
							list($name,$filedate) = explode('__',$name);
							// check if we should use this file
							$filedate = strtotime($filedate);
						}
						// setup the name
						if (strpos($name,'_') !== false)
						{
							$name = explode('_',$name);
						}
						elseif (strpos($name,'-') !== false)
						{
							$name = explode('-',$name);
						}
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($name))
						{
							$name = ucwords(strtolower(implode(' ',$name)));
						}
						// build link
						$dropboxLink = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_('index.php?option=com_[[[component]]]&task=download.file&token='.$token.'&filename='.$filename.'&key='.$user->id.'ba&link='.$keyLink);
						if ($filedate == $date)
						{
							$found[$key] = '<a class="uk-button uk-button-primary uk-button-small uk-margin-small-bottom" href="'.$dropboxLink.'" title="'.$filename.'"><i class="uk-icon-download"></i> Download '.$name.' ('.$ext.') <em>exclusive</em></a>';
						}
						elseif ($filedate == 0)
						{
							$found[$key] = '<a class="uk-button uk-button-primary uk-button-small uk-margin-small-bottom" href="'.$dropboxLink.'" title="'.$filename.'"><i class="uk-icon-download"></i> Download '.$name.' ('.$ext.')</a>';
						}
					}
					// only group button if more then one is set
					if (count($found) > 1)
					{
						return '<div class="uk-button-group uk-hidden-small">'.implode('', $found).'</div><div class="uk-visible-small">'.implode('', $found).'</div>';
					}
					else
					{
						return implode('', $found);
					}
				}
			}
		}
		return '<small>No downloads found for this session at this time.</small>';
	}

	protected static function getSessionDropboxLink($session)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('a.alias','c.alias','p.acronym'),array('session','course','program')));
		$query->from($db->quoteName('#__[[[component]]]_session', 'a'));
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_program', 'p') . ' ON (' . $db->quoteName('a.program') . ' = ' . $db->quoteName('p.id') . ')');
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_course', 'c') . ' ON (' . $db->quoteName('a.course') . ' = ' . $db->quoteName('c.id') . ')');
		$query->where($db->quoteName('a.id') . ' = '.(int) $session);
		// echo nl2br(str_replace('#__','cb_',$query)); die;
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$result = $db->loadObject();
			// construct the search string for the links
			return 'VDM_pLeK_h0uEr/'.$result->program.'/'.$result->course.'/'.$result->session.'/';
		}
		return false;
	}

	protected static function getDropbox()
	{
		// Get main url
		$mainUrl = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('dropbox', null);
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($mainUrl) && self::$update_dropbox_counter == 0)
		{
			// Get update timer time
			$timer = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('dropbox_timer', '60');
			// Get the Time for Now
			$nowTime = time();
			// Get Next Update Time
			$nextupdate = strtotime('+'.$timer.' minutes', $nowTime);
			// update filename
			$infoFile = JPATH_COMPONENT_SITE.'/helpers/'.md5($mainUrl.'info');
			// get last update info
			$updateInfoNow = false;
			if (($json = @file_get_contents($infoFile.".json")) !== FALSE)
			{
				$updateInfo = json_decode($json,true);
			}
			else
			{
				$updateInfo = array('nextupdate' => $nextupdate, 'updateactive' => false, 'updatenow' => false);
				$updateInfoNow = true;
			}
			// check if we should update the local set of links
			if ($updateInfo['nextupdate'] < $nowTime && !$updateInfo['updateactive'])
			{
				self::$update_dropbox = true;
				$updateInfo = array('nextupdate' => $nextupdate, 'updateactive' => false, 'updatenow' => true);
				$updateInfoNow = true;
			}
			// update info now
			if ($updateInfoNow)
			{
				// save the update info for next run
				self::saveJson(json_encode($updateInfo),$infoFile);
			}
			// Get local key
			$localkey = md5(Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('basic_key', 'localKey34fdWEkl'));
			// links filename
			$linkFile = JPATH_COMPONENT_SITE.'/helpers/'.md5($mainUrl.'links');
			// this function should only run once per excution
			self::$update_dropbox_counter++;
			// get the local links
			if (($jsonlinks = @file_get_contents($linkFile.".json")) !== FALSE && !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$links_dropbox))
			{
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($jsonlinks))
				{
					// get saved links
					$storeage = json_decode($jsonlinks,true);
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($storeage))
					{
						// get saved links
						self::$links_dropbox = $storeage;
						return true;
					}
				}
				else
				{
					if ( !$updateInfo['updateactive'])
					{
						self::$update_dropbox = true;
						$updateInfo = array('nextupdate' => $nextupdate, 'updateactive' => false, 'updatenow' => true);
						self::saveJson(json_encode($updateInfo),$infoFile);
					}
				}
			}
		}
		return false;
	}

	public static function updateDropbox()
	{
		// Get main url
		$mainUrl = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('dropbox', null);
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($mainUrl))
		{
			// dont allow other updates
			self::$update_dropbox = false;
			// update filename
			$infoFile = JPATH_COMPONENT_SITE.'/helpers/'.md5($mainUrl.'info');
			if (($json = @file_get_contents($infoFile.".json")) !== FALSE)
			{
				$updateInfo = json_decode($json,true);
				if (!$updateInfo['updateactive'] && $updateInfo['updatenow'])
				{
					$updateInfo['updateactive'] = true;
					$updateInfo['updatenow'] = false;
					// save the update info for next run
					self::saveJson(json_encode($updateInfo),$infoFile);
				}
				else
				{
					// update already running
					return false;
				}
			}
			else
			{
				// oops something is wrong
				return false;
			}
			// load the file
			JLoader::import('dropbox', JPATH_COMPONENT_SITE.'/helpers');
			// update the dropbox links
			$compilerConfig = array('save' => false, 'download' => false);
			$dropbox = new Dropbox($mainUrl, $compilerConfig);
			// setup the links
			self::$links_dropbox = $dropbox->files;
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$links_dropbox))
			{
				// Get local key
				$localkey = md5(Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('basic_key', 'localKey34fdWEkl'));
				// links filename
				$linkFile = JPATH_COMPONENT_SITE.'/helpers/'.md5($mainUrl.'links');
				// encrypt the urls
				$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 256);
				foreach (self::$links_dropbox as $folder => $link)
				{
					$storeage[$folder] = base64_encode($locker->encryptString($link));
				}
				// save the update links for next time
				self::saveJson(json_encode($storeage),$linkFile);
				$updateInfo['updateactive'] = false;
				// save the update info for next run
				self::saveJson(json_encode($updateInfo),$infoFile);
				return true;
			}
		}
		return false;
	}

	protected static function saveJson($data,$filename)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data))
		{
			$fp = fopen($filename.'.json', 'w');
			fwrite($fp, $data);
			fclose($fp);
		}
	}

	/**
	* 	Is user a Facultymember
	**/
	public static $isFacultymember = false;

	/**
	* 	Is user a Facilitator
	**/
	public static $isFacilitator = false;

	/**
	* 	Is user a Student
	**/
	public static $isStudent = false;

	public static function userIs($id = null)
	{
		if($id > 0)
		{
			$user = Factory::getUser($id);
		}
		else
		{
			$user = Factory::getUser();
		}
		// set params
		if (empty(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// get this user groups
		$groups = (array) $user->get('groups');
		// Get faculty member groups
		$facultymemberGroups = (array) self::$params->get('facultymemberuser');
		// Get facilitator groups
		$facilitatorGroups = (array) self::$params->get('facilitatoruser');
		// Get student groups
		$studentGroups = (array) self::$params->get('studentuser');
		// now check if user is in group
		if (array_intersect($facultymemberGroups, $groups))
		{
			// is Facultymember
			self::$isFacultymember = true;
		}
		if (array_intersect($facilitatorGroups, $groups))
		{
			// is Facilitator
			self::$isFacilitator = true;
		}
		if (array_intersect($studentGroups, $groups))
		{
			// is Student
			self::$isStudent = true;
		}
	}

	/**
	 *	check attendance of this relation
	 */
	public static function checkAttendance($event, $program, $course = null, $session = null, $userId = null, $what = 'id')
	{
		// set user to target
		if(!$userId)
		{
			$userId = self::$user->id;
		}
		
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array($what)));
		$query->from($db->quoteName('#__[[[component]]]_attendance'));
		$query->where($db->quoteName('studentuser') . ' = '. (int)$userId);
		if ($session)
		{
			$query->where($db->quoteName('session') . ' = '. (int)$session);
		}
		if ($course)
		{
			$query->where($db->quoteName('course') . ' = '. (int)$course);
		}
		$query->where($db->quoteName('program') . ' = '. (int)$program);
		$query->where($db->quoteName('event') . ' = '. (int)$event);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}
	
	/**
	 *	check attendance of any given spect
	 */
	protected static function checkAttendanceDynamic($data)
	{
		$attendance = false;
		// switch on active types
		switch ($data->assessment_type_release_type)
		{
			case 0:
				// immediatly
				$attendance = self::checkAttendance($data->event_id,$data->program);
				break;
			case 2:
				// after target
			case 3:
				// on target
				switch ($data->assessment_type_release_target)
				{
					case 1:
						// Session
						$attendance = self::checkAttendance($data->event_id,$data->program,$data->course,$data->assessment_type_release_session);
						break;
					case 2:
						// Day
						$sessions = self::getSessions($data->program,$data->course,$data->day);
						// now check if any attandeance for this day was loged
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sessions))
						{
							foreach ($sessions as $session)
							{
								$attendance = self::checkAttendance($data->event_id,$data->program,$data->course,$session);
								// if one is found break
								if ($attendance)
								{
									break;
								}
							}
						}
						break;
					case 3:
						// Course
						$attendance = self::checkAttendance($data->event_id,$data->program,$data->course);
						break;
					case 4:
						// Program
						$attendance = self::checkAttendance($data->event_id,$data->program);
						break;
				}
				break;
			default :
				// the default
				$attendance = false;
				break;
		}
		return $attendance;
	}
	
	/**
	 *	check sessions of this relation
	 */
	public static function getSessions($program, $course = null, $day = null)
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('id')));
		$query->from($db->quoteName('#__[[[component]]]_session'));
		if ($course)
		{
			$query->where($db->quoteName('course') . ' = '. (int)$course);
		}
		if ($day)
		{
			$query->where($db->quoteName('day') . ' = '. (int)$day);
		}
		$query->where($db->quoteName('program') . ' = '. (int)$program);
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadColumn();
		}
		return false;
	}

	/**
	* 	The target user/student
	**/
	public static $user;

	/**
	* 	The Assessments
	**/
	public static $assessments = array();
	
	/**
	* 	The build checking dates
	**/
	public static $notDate_one;
	
	/**
	 *	Get Assessments
	 */
	public static function assessments($data = null, $userId = null)
	{
		// set the cheching time
		self::$notDate_one = strtotime('0000-00-00');
		// set user to target
		if($userId)
		{
			self::$user = Factory::getUser($userId);
		}
		else
		{
			self::$user = Factory::getUser();
		}
		// make sure this is a student
		self::userIs(self::$user->id);
		if (self::$isStudent)
		{
			// set available assessments
			$avaliable = self::getAvaliableAssessments($data);
			// set assessments state
			self::setAssessmentsState($avaliable);
			// return the assessments
			return self::$assessments;
		}
		return false;
	}
	
	/**
	 *	set assessments state
	 */
	protected static function setAssessmentsState($assessments)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($assessments))
		{
			// always reset
			$assessments_bucket = array();
			// build return array
			self::$assessments = array();
			foreach ($assessments as $key => $days)
			{
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($days))
				{
					foreach ($days as $day => $types)
					{
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($types))
						{
							foreach ($types as $type => $data)
							{
								// check if data is released & active & get the start and end of assessment
								$ra = self::getAssessmentStatus($data);
								$data->key = $ra['id'];
								$data->order =  $ra['start'];
								$data->active = $ra['status'];
								$data->start = date("l jS \of F Y",$ra['start']);
								$data->end = ($ra['end'] != self::$notDate_one && $ra['end']) ? date("l jS \of F Y",$ra['end']):false;
								$data->course_name = self::getVar('course',$data->course,'id','name');
								$data->day_name = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($data->day,'Ww');
								// first insure that there is not another event with the same name
								$data->event_name = self::getEventUniqueName($data->event_name, $data->event_id);
								if (!isset(self::$assessments[$data->event_name]['program_name']))
								{
									self::$assessments[$data->event_name]['program_name'] = $data->program_name;
									self::$assessments[$data->event_name]['program_acronym'] = $data->program_acronym;
									self::$assessments[$data->event_name]['program_icon'] = $data->program_icon;
									self::$assessments[$data->event_name]['program_credit_system'] = $data->program_credit_system;
									self::$assessments[$data->event_name]['id'] = $data->event_id;
									self::$assessments[$data->event_name]['event_name'] = $data->event_name;
									self::$assessments[$data->event_name]['active'] = 0;
								}
								// load assessments
								$assessments_bucket[] = $data;	
							}
						}
					}
				}
			}
		}
		
		// lets sort these assessments
		if (isset($assessments_bucket) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($assessments_bucket))
		{
			self::sort_assessments($assessments_bucket, array('day','order'));
			foreach ($assessments_bucket as $value)
			{
				self::$assessments[$value->event_name]['values'][$value->course_name][$data->day_name][$value->assessment_type_name][$value->key] = $value;
				// count the number of active per event
				if ($value->active)
				{
					self::$assessments[$value->event_name]['active']++;
				}
			}
			self::sort_assessments($assessments_bucket, array('order','assessment_type_name'));
			foreach ($assessments_bucket as $value)
			{
				$month = date("F Y",$value->order);
				$value->start_day = date("l jS",$value->order);
				self::$assessments[$value->event_name]['calender'][$month][$value->start_day][$value->key] = $value;
				self::$assessments[$value->event_name]['types'][$value->assessment_type_id] = $value->assessment_type_name;
			}
			unset($assessments_bucket);
		}
	}

	protected static $eventUniqueName = array();

	protected static function getEventUniqueName($name, $id)
	{
		// first check if other events with same name exist
		if (!isset(self::$eventUniqueName[$name][$id]))
		{
			$nr = 0; $new = '';
			if (isset(self::$eventUniqueName[$name]))
			{
				$nr = count(self::$eventUniqueName[$name]);
			}
			else
			{
				self::$eventUniqueName[$name] = array();
			}
			if (0 != $nr)
			{
				$nr++;
				$new = ' (' . $nr . ')';
			}
			self::$eventUniqueName[$name][$id] = $name . $new; 
		}
		return self::$eventUniqueName[$name][$id];
	}
	
	/**
	 *	sort assessments by day and date/order
	 */
	protected static function sort_assessments(&$assessments, $props)
	{
		usort($assessments, function($a, $b) use ($props) {
			if($a->$props[0] == $b->$props[0])
			{
				return $a->$props[1] > $b->$props[1] ? 1 : -1;
			}
			return $a->$props[0] > $b->$props[0] ? 1 : -1;
		});
	}
	
	/**
	 *	set assessment state in DB
	 */
	protected static function setAssessmentState($releasedActive, $db_releasedActive, $event, $program, $course, $day, $assessment_type, $userId = null)
	{
		$status = 0;
		$check = 0;
		// first check if update is needed
		if ($releasedActive['status'])
		{
			$check = 2;
			++$status;
		}
		if ($db_releasedActive['status'])
		{
			$check = 2;
			++$status;
		}
		if (!isset($db_releasedActive['id']) || $status != $check || $releasedActive['start'] != $db_releasedActive['start'] || $releasedActive['end'] != $db_releasedActive['end'])
		{
			// set user to target
			if(!$userId)
			{
				$userId = self::$user->id;
			}
			// set the date object
			$date = Factory::getDate();
			// set the start date to sql if set
			$start = false;
			if ($releasedActive['start'] != self::$notDate_one && $releasedActive['start'])
			{
				$releasedActive['start'] = date("Y-m-d H:i:s", $releasedActive['start']);
				$start = true;
			}
			// set the end date to sql if set
			$end = false;
			if ($releasedActive['end'] != self::$notDate_one && $releasedActive['end'])
			{
				$releasedActive['end'] = date("Y-m-d H:i:s", $releasedActive['end']);
				$end = true;
			}
			// convert to 1 or 0
			if ($releasedActive['status'])
			{
				$releasedActive['status'] = 1;
			}
			else
			{
				$releasedActive['status'] = 0;
			}
			// get batabase object
			$db = Factory::getDbo();
			if (isset($db_releasedActive['id']) && $db_releasedActive['id'])
			{
				$db_releasedActive['version']++;
				// update entry
				$object = new \stdClass();
				// Must be a valid primary key value.
				$object->id = $db_releasedActive['id'];
				if ($start)
				{
					$object->release_date	= $releasedActive['start'];
				}
				if ($end)
				{
					$object->active_date	= $releasedActive['end'];
				}
				$object->active			= $releasedActive['status'];
				$object->modified		= $date->toSql();
				$object->modified_by		= $userId;
				$object->version		= $db_releasedActive['version'];
				// Update their details in the users table using id as the primary key.
				$done = $db->updateObject('#__[[[component]]]_assessment_status', $object, 'id');
				// if done return last used id
				if ($done)
				{
					return $object->id;
				}
			}
			else
			{
				// create entry
				$object = new \stdClass();
				if ($start)
				{
					$object->release_date = $releasedActive['start'];
				}
				if ($end)
				{
					$object->active_date = $releasedActive['end'];
				}
				$object->active			= $releasedActive['status'];
				$object->studentuser		= $userId;
				$object->assessment_type	= $assessment_type;
				$object->course			= $course;
				$object->day			= $day;
				$object->event			= $event;
				$object->program		= $program;
				$object->created		= $date->toSql();
				$object->created_by		= $userId;
				$object->version		= 1;
				$object->access		= 1; // TODO should be the registered view access
				// Insert the object into the user profile table.
				$done = $db->insertObject('#__[[[component]]]_assessment_status', $object);
				// if done return last used id
				if ($done)
				{
					$newId =  $db->insertid();
					// make sure the access of asset is set
					self::setAsset($newId,'assessment_status');
					return $newId;
				}
			}
		}
		if (isset($db_releasedActive['id']))
		{
			return $db_releasedActive['id'];
		}
		return false;
	}
	
	/**
	 *	check if assessments are released and active
	 */
	protected static function getAssessmentStatus(&$data)
	{
		// first check if this assesment was already set
		$db_releasedActive		= self::dbAssessmentStatus($data);
		$db_releasedActive['start']	= strtotime($db_releasedActive['start']);
		$db_releasedActive['end']	= strtotime($db_releasedActive['end']);
		// defaults
		$active		= true;
		$release	= false;
		$releasedActive = array('status' => false, 'start' => strtotime('0000-00-00'), 'end' => strtotime('0000-00-00'));
		$data->not_release_note = null;
		$data->not_active_note = null;
		$application	= self::checkEventApplication($data->event_id);
		// set the date for now
		$data->today	= Factory::getDate()->toUnix();
		// check if submistion was already made
		$data->submission = self::checkSubmission($data->event_id,$data->program,$data->course,$data->day,$data->assessment_type_id);
		// add the attendance switch
		$data->attendance = ($data->assessment_type_attendance == 1) ? self::checkAttendanceDynamic($data):true;
		// only check if not released
		if ($db_releasedActive['status'] != 1)
		{
			// check if the release active start should be set
			if ($db_releasedActive['start'] == self::$notDate_one || !$db_releasedActive['start'])
			{
				$getDate = true;
			}
			else
			{
				$getDate = false;
			}
			// switch on release types
			switch ($data->assessment_type_release_type)
			{
				case 0:
					// immediatly
					$release = ($data->attendance) ? $application:$data->attendance;
					if (!$release)
					{
						$data->not_release_note = 'no_attendance';
					}
					// set start
					if ($getDate)
					{
						$releasedActive['start'] = self::$eventFirstDate;
					}
					else
					{
						$releasedActive['start'] = $db_releasedActive['start'];
					}
					break;
				case 1:
					// before target
					if ($getDate)
					{
						$releasedActive['start'] = self::getTargetReleaseDate($data,'before');
					}
					else
					{
						$releasedActive['start'] = $db_releasedActive['start'];
					}
					if ($application && $data->attendance)
					{
						if ($data->today > $releasedActive['start'])
						{
							$release = true;
						}
						else
						{
							$data->not_release_note = 'before_open_date';
						}
					}
					else
					{
						$data->not_release_note = 'no_attendance';
					}
					break;
				case 2:
					// after target
					if ($getDate)
					{
						$releasedActive['start'] = self::getTargetReleaseDate($data,'after');
					}
					else
					{
						$releasedActive['start'] = $db_releasedActive['start'];
					}
					if ($application && $data->attendance)
					{
						if ($data->today > $releasedActive['start'])
						{
							$release = true;
						}
						else
						{
							$data->not_release_note = 'before_open_date';
						}
					}
					else
					{
						$data->not_release_note = 'no_attendance';
					}
					break;
				case 3:
					// on target
					if ($getDate)
					{
						$releasedActive['start'] = self::getTargetReleaseDate($data,'on');
					}
					else
					{
						$releasedActive['start'] = $db_releasedActive['start'];
					}
					if ($application && $data->attendance)
					{
						if ($data->today > $releasedActive['start'])
						{
							$release = true;
						}
						else
						{
							$data->not_release_note = 'before_open_date';
						}
					}
					else
					{
						$data->not_release_note = 'no_attendance';
					}
					break;
			}
		}
		else
		{
			$release = true;
			$releasedActive['start'] = $db_releasedActive['start'];
		}
		// only check if active
		if ($db_releasedActive['status'] == 1 || $release)
		{
			// check if the release active start should be set
			if ($db_releasedActive['end'] == self::$notDate_one || !$db_releasedActive['end'])
			{
				$getDate = true;
			}
			else
			{
				$getDate = false;
			}
			// switch on active type
			switch ($data->assessment_type_active_type)
			{
				case 1:
					// until submission
					if ($data->submission)
					{
						$active = false;
						$data->not_active_note = 'submitted';
					}
					break;
				case 2:
					// until submission or period after target
					if ($getDate)
					{
						$releasedActive['end'] = self::getTargetActiveDate($data, 'after',$releasedActive['start']);
					}
					else
					{
						// must be checked every time since it is dynamic
						if (6 == $data->assessment_type_active_target)
						{
							$releasedActive['end'] = self::getTargetActiveDate($data, 'after',$releasedActive['start']);
						}
						else
						{
							$releasedActive['end'] = $db_releasedActive['end'];
						}
					}
					if ($data->submission)
					{
						$active = false;
						$data->not_active_note = 'submitted';
					}
					elseif ($data->today > $releasedActive['end'])
					{
						$active = false;
						$data->not_active_note = 'past_close_date';
					}
					break;
				case 3:
					// period after target
					if ($getDate)
					{
						$releasedActive['end'] = self::getTargetActiveDate($data, 'after',$releasedActive['start']);
					}
					else
					{
						// must be checked every time since it is dynamic
						if (6 == $data->assessment_type_active_target)
						{
							$releasedActive['end'] = self::getTargetActiveDate($data, 'after',$releasedActive['start']);
						}
						else
						{
							$releasedActive['end'] = $db_releasedActive['end'];
						}
					}
					if ($data->today > $releasedActive['end'])
					{
						$active = false;
						$data->not_active_note = 'past_close_date';
					}
					break;
			}
		}
		else
		{
			$releasedActive['end'] = $db_releasedActive['end'];
		}
		// set globally release of this assessment
		if ($release && $active)
		{
			$releasedActive['status'] = true;
			// set the database if needed
			$releasedActive['id'] = self::setAssessmentState($releasedActive,$db_releasedActive,$data->event_id,$data->program,$data->course,$data->day,$data->assessment_type_id);
		}
		// set globally inactivity of this assessment
		else
		{
			$releasedActive['status'] = false;
			// set the database if needed
			$releasedActive['id'] = self::setAssessmentState($releasedActive,$db_releasedActive,$data->event_id,$data->program,$data->course,$data->day,$data->assessment_type_id);
		}
		return $releasedActive;
	}
	
	/**
	 *	check if assessments already set in DB
	 */
	protected static function dbAssessmentStatus($data,$userId = null)
	{
		// set user to target
		if(!$userId)
		{
			$userId = self::$user->id;
		}
		
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array('id','active','release_date','active_date','version'),
			array('id','status','start','end','version')));
		$query->from($db->quoteName('#__[[[component]]]_assessment_status'));
		$query->where($db->quoteName('studentuser') . ' = '. (int)$userId);
		$query->where($db->quoteName('assessment_type') . ' = '. (int)$data->assessment_type_id);
		$query->where($db->quoteName('course') . ' = '. (int)$data->course);
		$query->where($db->quoteName('day') . ' = '. (int)$data->day);
		$query->where($db->quoteName('program') . ' = '. (int)$data->program);
		$query->where($db->quoteName('event') . ' = '. (int)$data->event_id);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadAssoc();
		}
		return array('status' => 0, 'start' => '0000-00-00', 'end' => '0000-00-00');
	}
	
	/**
	 *	Target Release Date
	 */
	protected static function getTargetReleaseDate(&$data,$action)
	{
		// first get the target start date
		$tagetStartDate = false;
		switch ($data->assessment_type_release_target)
		{
			case 1:
				// Session
				$day = self::getVar('session', $data->assessment_type_release_session, 'id', 'day');
				$course = self::getVar('session', $data->assessment_type_release_session, 'id', 'course');
				if ('after' == $action)
				{
					$tagetStartDate = strtotime(self::checkAttendance($data->event_id,$data->program,$course,$data->assessment_type_release_session,self::$user->id,'date'));
				}
				else
				{
					$tagetStartDate = (isset(self::$courseBucket[$data->event_id][$course][$day])) ? (self::$courseBucket[$data->event_id][$course][$day]):false;
				}
				break;
			case 2:
				// Day
				$tagetStartDate = (isset(self::$courseBucket[$data->event_id][$data->course][$data->day])) ? (self::$courseBucket[$data->event_id][$data->course][$data->day]):false;
				break;
			case 3:
				// Course
				$tagetStartDate = (isset(self::$courseFirstDate[$data->course])) ? (self::$courseFirstDate[$data->course]):false;
				break;
			case 4:
				// Program
				$tagetStartDate = (isset(self::$eventFirstDate)) ? (self::$eventFirstDate):false;
				break;
		}
		return self::getTagetDate($data,$tagetStartDate,'release',$action);
		
	}
	
	/**
	 *	Target Active Until Date
	 */
	protected static function getTargetActiveDate(&$data,$action,$releaseDate)
	{
		// first get the target start date
		$tagetStartDate = false;
		switch ($data->assessment_type_active_target)
		{
			case 1:
				// Release
				$tagetStartDate = $releaseDate;
				break;
			case 2:
				// Session
				$day = self::getVar('session', $data->assessment_type_active_session, 'id', 'day');
				$course = self::getVar('session', $data->assessment_type_active_session, 'id', 'course');
				if ('after' == $action)
				{
					$tagetStartDate = strtotime(self::checkAttendance($data->event_id,$data->program,$course,$data->assessment_type_active_session,self::$user->id,'date'));
				}
				else
				{
					$tagetStartDate = (isset(self::$courseBucket[$data->event_id][$course][$day])) ? (self::$courseBucket[$data->event_id][$course][$day]):false;
				}
				break;
			case 3:
				// Day
				$tagetStartDate = (isset(self::$courseBucket[$data->event_id][$data->course][$data->day])) ? (self::$courseBucket[$data->event_id][$data->course][$data->day]):false;
				break;
			case 4:
				// Course
				$tagetStartDate = (isset(self::$courseFirstDate[$data->course])) ? (self::$courseFirstDate[$data->course]):false;
				break;
			case 5:
				// Program
				$tagetStartDate = (isset(self::$eventFirstDate)) ? (self::$eventFirstDate):false;
				break;
			case 6:
				// Opened the assessment - use now with added time
				$tagetStartDate = Factory::getDate()->toUnix();
				break;
		}
		return self::getTagetDate($data,$tagetStartDate,'active',$action);
		
	}
	
	protected static function getTagetDate($data,$tagetStartDate,$type,$action)
	{
		$tagetDate = strtotime('0000-00-00');
		// if target start date was found
		if ($tagetStartDate)
		{
			if ($action != 'on')
			{
				// set operator
				$operator = '+';
				if ($action == 'before')
				{
					$operator = '-';
				}
				// get period length
				switch ($data->{'assessment_type_'.$type.'_period_type'})
				{
					case 1:
						// minutes
						$tagetDate = strtotime($operator.$data->{'assessment_type_'.$type.'_period_length'}.' minutes', $tagetStartDate);
						break;
					case 2:
						// hours
						$tagetDate = strtotime($operator.$data->{'assessment_type_'.$type.'_period_length'}.' hours', $tagetStartDate);
						break;
					case 3:
						// days
						$tagetDate = strtotime($operator.$data->{'assessment_type_'.$type.'_period_length'}.' days', $tagetStartDate);
						break;
					case 4:
						// seven days/weeks
						$tagetDate = strtotime($operator.$data->{'assessment_type_'.$type.'_period_length'}.' weeks', $tagetStartDate);
						break;
					case 5:
						// thirty days/months
						$tagetDate = strtotime($operator.$data->{'assessment_type_'.$type.'_period_length'}.' months', $tagetStartDate);						
						break;
				}
			}
			else
			{
				return $tagetStartDate;
			}
		}
		return $tagetDate;
	}

	protected static $assessmentsOutstanding = array();
	
	/**
	 *	set Assessment Completion Notes
	 */
	protected static function setAssessmentsOutstanding($assessment, $event_name, $add = false)
	{
		// check if this assessment has been done
		if ($add || !$assessment->submission)
		{
			if (!isset(self::$assessmentsOutstanding[$event_name]))
			{
				self::$assessmentsOutstanding[$event_name] = array();
			}
			self::$assessmentsOutstanding[$event_name][] = $assessment->assessment_type_name . ' ' . Text::_('for') . ' '. $assessment->course_name;
			return true;
		}
		return false;
	}
	
	/**
	 *	get Assessment Completion Notes
	 */
	protected static function getAssessmentsOutstanding($event_name)
	{
		// check if this event has any notes
		if (isset(self::$assessmentsOutstanding[$event_name]))
		{
			return '<ul class="uk-list"><li>' . implode('</li><li>', self::$assessmentsOutstanding[$event_name]) . '</li></ul>';
		}
		return '';
	}
	
	/**
	 *	check submission
	 */
	public static function checkSubmission($event,$program,$course,$day,$assessment,$userId = null)
	{
		// set user to target
		if(!$userId)
		{
			$userId = self::$user->id;
		}
		
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('id')));
		$query->from($db->quoteName('#__[[[component]]]_assessment'));
		$query->where($db->quoteName('studentuser') . ' = '. (int)$userId);
		$query->where($db->quoteName('assessment_type') . ' = '. (int)$assessment);
		$query->where($db->quoteName('course') . ' = '. (int)$course);
		$query->where($db->quoteName('day') . ' = '. (int)$day);
		$query->where($db->quoteName('program') . ' = '. (int)$program);
		$query->where($db->quoteName('event') . ' = '. (int)$event);
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}
	
	/**
	* 	The Course temp/Bucket
	**/
	public static $courseBucket = array();
	
	/**
	* 	The Event First Date
	**/
	public static $eventFirstDate;
	
	/**
	* 	The Course First Date
	**/
	public static $courseFirstDate = array();
	
	/**
	 *	set available assessments
	 */
	protected static function getAvaliableAssessments($data)
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
		{
			// load profile model
			$model = self::getModel('profile', JPATH_COMPONENT_SITE);
			// load data if none given
			$data = $model->getAssessments();
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
		{
			$assessments = array();
			// sort the data
			foreach ($data as $event)
			{
				// set the courses info
				$courseBucket = array();
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($event->event_course_date))
				{
					// convert to an array
					$event_course_date = json_decode($event->event_course_date);
					if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($event_course_date))
					{
						$event->event_course_date = array();
						$firstCourse = 999;
						$firstDay = 999;
						// set the courses to days
						foreach ($event_course_date as $key => $values)
						{
							if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($values))
							{
								foreach($values as $nr => $value)
								{
									$event->event_course_date[$nr][$key] = $value;
									// set first course (TODO) should use order instead
									if ($key == 'course')
									{	
										if ($firstCourse > $value)
										{
											$firstCourse = $value;
										}
									}
									// set first day (should always be 1 but just incase)
									if ($key == 'day')
									{	
										if ($firstDay > $value)
										{
											$firstDay = $value;
										}
									}
								}
							}
						}
					}
					// build search bucket
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event->event_course_date))
					{
						foreach ($event->event_course_date as $val)
						{
							self::$courseBucket[$event->event_id][$val['course']][$val['day']] = strtotime($val['date']);
							// set first day of event/program
							if ($val['day'] == $firstDay && $val['course'] == $firstCourse && $val['date'])
							{
								self::$eventFirstDate = strtotime($val['date']);
							}
							// set each course first day
							if ($val['day'] == $firstDay && $val['date'])
							{
								self::$courseFirstDate[$val['course']] = strtotime($val['date']);
							}
						}
					}
				}
				// set the assessments available
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event->idProgramQuestionDD))
				{
					foreach ($event->idProgramQuestionDD as $question)
					{
						if (!isset($assessments
								['program_'.str_pad($question->program, 3, '0',STR_PAD_LEFT).
								    '__event_'.str_pad($event->event_id, 3, '0',STR_PAD_LEFT).
								    '__course_'.str_pad($question->course, 3, '0',STR_PAD_LEFT)]
								['day_'.str_pad($question->day, 3, '0',STR_PAD_LEFT)]
								['assessmenttype_'.str_pad($question->assessment_type_id, 3, '0',STR_PAD_LEFT)]))
						{
							// linup the data
							$question->event_id = $event->event_id;
							$question->event_name = $event->event_name;
							$question->event_groups = $event->event_groups;
							$question->program_name = $event->program_name;
							$question->program_acronym = $event->program_acronym;
							$question->program_icon = $event->program_icon;
							$question->program_credit_system = $event->program_credit_system;
							$question->day_date = (isset(self::$courseBucket[$event->event_id][$question->course][$question->day])) ? self::$courseBucket[$event->event_id][$question->course][$question->day] : null;
							// setup the storage object
							$assessments
								['program_'.str_pad($question->program, 3, '0',STR_PAD_LEFT).
								    '__event_'.str_pad($event->event_id, 3, '0',STR_PAD_LEFT).
								    '__course_'.str_pad($question->course, 3, '0',STR_PAD_LEFT)]
								['day_'.str_pad($question->day, 3, '0',STR_PAD_LEFT)]
								['assessmenttype_'.str_pad($question->assessment_type_id, 3, '0',STR_PAD_LEFT)] = $question;
						}
					}
				}
			}
			return $assessments;
		}
		return false;
	}

	/**
	 *	check if users can access a given area
	 */
	public static function canAccess($id,$type = 'event')
	{
		switch($type)
		{
			case 'event':
				// check if user may access event data
				if ($id)
				{
					return self::checkEventApplication($id);
				}

			break;
			case 'assessment':
				// check if user may access assessment data

			break;
			case 'module':
				// check if user may access assessment data
				if ($id)
				{
					$event = self::getEventId($id,$type);
					if ($event)
					{
						return self::checkEventApplication($event);
					}
				}
			break;
			case 'register':
				// check if user can register
				if ($id)
				{
					$status = self::checkEventApplication($id,true);
					switch ($status)
					{
						case 1:
							// active
							$response = array('can' => false, 'why' => Text::_('Your application was approved and is active.'));
						break;
						case 2:
							// pending
							$response = array('can' => false, 'why' => Text::_('Application is pending review, please contact our office for more information.'));
						break;
						case -1:
							// rejected
							$response = array('can' => false, 'why' => Text::_('Application was rejected, please contact our office for more information.'));
						break;
						default :
							// good has not registration
							$response = array('can' => true);
						break;
					}
					return $response;
				}
			break;
		}
		return false;
	}

	/**
	 *	get the event id in relation to the type
	 */
	public static function getEventId($id,$type)
	{
		if ($type == 'module')
		{
			// get program id
			$program = self::getVar('module', $id, 'id', 'program');
			if ($program)
			{
				// get event id
				return self::getVar('event', $program, 'program', 'id');
			}
		}
		return false;
	}

	/**
	 *	get the note for this user and session
	 */
	public static function getNote($session)
	{
		$userId = Factory::getUser()->id;
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('content')));
		$query->from($db->quoteName('#__[[[component]]]_student_note'));
		$query->where($db->quoteName('studentuser') . ' = '.(int) $userId);
		$query->where($db->quoteName('session') . ' = '.(int) $session);
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return '';
	}

	/**
	 *	get the attendance in relation to a session
	 */
	public static function getAttendanceList($session,$course,$program,$event)
	{
		return false; // TODO Hmmmm not sure what happened here
	}

	/**
	 *	check if user's application to event is approved
	 */
	public static function checkEventApplication($event,$returnStatus = false)
	{
		$userId = Factory::getUser()->id;
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('status')));
		$query->from($db->quoteName('#__[[[component]]]_application'));
		if (!$returnStatus)
		{
			$query->where($db->quoteName('status') . ' = '.(int) 1);
		}
		$query->where($db->quoteName('studentuser') . ' = '.(int) $userId);
		$query->where($db->quoteName('event') . ' = '.(int) $event);
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}
	
	/**
	 *	set groups names
	 */
	public static function setGroupNames($groups)
	{
		// change array of group ids to string of group names
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			$groupsNames = array();
			foreach ($groups as $group)
			{
				$groupsNames[] = self::getGroupName($group);
			}
			return implode(', ',$groupsNames);
		}
		return '';
	}

	/**
	 *	Change to nice fancy date
	 */
	public static function fancyDate($date)
	{
		if (!self::isValidTimeStamp($date))
		{
			$date = strtotime($date);
		}
		return date('jS \o\f F Y',$date);
	}

	/**
	 *	Change to nice fancy time and date
	 */
	public static function fancyDateTime($time)
	{
		if (!self::isValidTimeStamp($time))
		{
			$time = strtotime($time);
		}
		return date('(G:i) jS \o\f F Y',$time);
	}

	/**
	 *	Change to nice hour:minutes time
	 */
	public static function fancyTime($time)
	{
		if (!self::isValidTimeStamp($time))
		{
			$time = strtotime($time);
		}
		return date('G:i',$time);
	}

	/**
	 *	Check if string is a valid time stamp
	 */
	public static function isValidTimeStamp($timestamp)
	{
		return ((int) $timestamp === $timestamp)
		&& ($timestamp <= PHP_INT_MAX)
		&& ($timestamp >= ~PHP_INT_MAX);
	}

	/**
	 *	Prepare the questions
	 */
	public static function prepQuestions(&$data,$questionsKey)
	{	
		// build question types array
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data->$questionsKey))
		{
			// to identify the types
			$typeName = array(
				1 => Text::_('Yes No'),
				2 => Text::_('Selection'),
				3 => Text::_('Multi Selection'),
				4 => Text::_('Text'),
				5 => Text::_('Text Plus'));
			// set some defaults
			$points		= array();
			$total		= 0;
			$subtotal		= array(1=>0,2=>0,3=>0,4=>0,5=>0);
			$loaded		= array(1=>0,2=>0,3=>0,4=>0,5=>0);
			$keeper		= array();
			foreach ($data->$questionsKey as $nr => $object)
			{
				$found = self::getAvailablePoint($object, true);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($found) && isset($found['type']) && isset($found['point']) && $found['point'] > 0)
				{
					// build points
					$type = $found['type'];
					$points[$type][$nr]	= (int) $found['point'];
					// build sub total to see if we have enough points for the question map relation 
					$subtotal[$type]		= bcadd($subtotal[$type], $points[$type][$nr]);
					// set the total to insure we have enough questions
					$total			= bcadd($total, $points[$type][$nr]);
				}
			}
			// check if we have enough points
			if ($total < $data->assessment_type_total_points)
			{
				// set error
				JError::raiseWarning(500, Text::_('There is not enough question (points) in the system, please notify the system administrator.'));
				$return = false;
			}
			// set needed point map
			$dynamicSelect = json_decode($data->assessment_type_question_map, true);
			$checkPercent = 0;
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($dynamicSelect))
			{
				$mapType = array();
				foreach ($dynamicSelect as $label => $valus)
				{
					foreach($valus as $g => $valu)
					{
						$mapType[$g][$label] = $valu;
					}
				}
				// final run on map
				foreach ($mapType as $va)
				{
					$map[$va['answer_type']] = $va['percent'];
					$checkPercent = bcadd($checkPercent, $va['percent']);
				}
			}
			if ($checkPercent != 100)
			{
				// set error
				JError::raiseWarning(500, Text::_('The question percent breakdown is not setup correctly, please notify the system administrator.'));
				$return = false;
			}
			// now work out how much points should be loaded from each type
			$get = array();
			foreach ($map as $typeKey => $percent)
			{
				$get[$typeKey] = bcmul(bcdiv($percent, '100', 5), $data->assessment_type_total_points);
				// check if the type has enough points
				if ($get[$typeKey] > $subtotal[$typeKey])
				{
					if ($get[$typeKey] != 0 && $subtotal[$typeKey] != 0)
					{
						// get persent mis match
						$pilo = bcdiv($get[$typeKey], bcmul($subtotal[$typeKey], 10));
					}
					else
					{
						$pilo = 1;
					}
					// allow for assessment_type_mismatch_buffer % play in the mismatch
					if ($pilo > $data->assessment_type_mismatch_buffer)
					{
						// set error
						JError::raiseWarning(500, Text::sprintf('There is not enough points in %s question type, please notify the system administrator.',$typeName[$typeKey]));
						$return = false;
					}
				}
			}
			// if the brake down does not match up, fix it
			$getTotal = array_sum($get);
			if ($getTotal != $data->assessment_type_total_points)
			{
				$remove = 0;
				$add = 0;
				if ($getTotal > $data->assessment_type_total_points)
				{
					$remove	= bcsub($getTotal, $data->assessment_type_total_points);
					// remove from the get
					for ($i = 1; $i <= $remove; ) 
					{
						$tfrom = array_rand($get);
						if ($get[$tfrom] > 2)
						{
							$get[$tfrom]--;
							$i++;
						}
					}
				}
				elseif ($getTotal < $data->assessment_type_total_points)
				{
					$add	= bcsub($data->assessment_type_total_points, $getTotal);
					// add to the get
					for ($i = 1; $i <= $add; ) 
					{
						$tfrom = array_rand($get);
						if ($get[$tfrom] > 2)
						{
							$get[$tfrom]++;
							$i++;
						}
					}
				}
			}
			$match = self::questionSortSelection($points,$data->assessment_type_total_points,$subtotal,$get,$loaded,$keeper);
			// if we still did not make it set error
			if (!$match)
			{
				// set error
				JError::raiseWarning(500, Text::_('There is not enough points in system to reach set total, please notify the system administrator.'));
				$return = false;
			}
			// make sure we have no errors
			if ((!isset($return) || $return) && self::shuffleArray($match))
			{
				$buket = array();
				// set the questions that should be used
				foreach ($match as $id => $point)
				{
					// first load the point
					$data->{$questionsKey}[$id]->point = $point;
					// set the text area mode based on assessment type switch
					if ($data->{$questionsKey}[$id]->answer_type == 3 && $data->assessment_type_text_input_mode == 1)
					{
						$data->{$questionsKey}[$id]->answer_type = 4;
					}
					$buket[] = $data->{$questionsKey}[$id];
				}
				// set by default order if needed
				if (!self::$fieldShuffle)
				{
					usort($buket, function($a, $b) {
						return $a->ordering - $b->ordering;
					});
				}
				// update old set
				$data->$questionsKey = $buket;
				return true;
			}
			return false;
		}
		// set error
		JError::raiseWarning(500, Text::_('No questions were set for this assessment, please notify the system administrator.'));
		return false;
	}
	
	/**
	* 	The retry counter
	**/
	public static $retry = 0;

	/**
	 *	Sort the selection of questions
	 */
	protected static function questionSortSelection($points,$targetTotal,$subtotal,$get,$loaded,$keeper)
	{
		$re_try = $points;
		$getSort = false;
		// use question get map and point to sort
		foreach ($points as $type => $point_s)
		{
			if (isset($get[$type]) && isset($subtotal[$type]) && self::shuffleArray($point_s))
			{
				if ($get[$type] != $subtotal[$type])
				{
					// add untill we reach our sum
					foreach ($point_s as $i => $poin)
					{
						$checkValue = bcadd($loaded[$type], $poin);
						if ($checkValue <= $get[$type])
						{
							$keeper[$i] = $poin;
							$loaded[$type] = bcadd($loaded[$type], $poin);
							// remove from points
							unset($points[$type][$i]);
						}
					}
				}
				elseif ($get[$type] == $subtotal[$type])
				{
					// just add all unless we are full
					$nowTotal = array_sum($keeper);
					foreach ($point_s as $id => $point)
					{
						$checkTotal = bcadd($nowTotal, $point);
						if ($checkTotal <= $targetTotal)
						{
							$keeper[$id] = $point;
							$loaded[$type] = bcadd($loaded[$type], $point);
							// remove from points
							unset($points[$type][$id]);
						}
					}
				}
			}
			// check if we reached our number
			if (isset($get[$type]) && isset($subtotal[$type]) && $loaded[$type] != $get[$type])
			{
				$getSort = true;
			}
		}
		// do we still short?
		if ($getSort && self::shuffleArray($points))
		{
			// try to load more
			foreach ($points as $type => $point_r)
			{
				if (isset($get[$type]) && isset($subtotal[$type]) && self::shuffleArray($point_r))
				{
					if (array_sum($keeper) != $targetTotal)
					{
						// add untill we reach our sum
						foreach ($point_r as $in => $poind)
						{
							$checkTotal = bcadd(array_sum($keeper), $poind);
							if ($checkTotal <= $targetTotal)
							{
								$keeper[$in] = $poind;
								$loaded[$type] = bcadd($loaded[$type], $poind);
								// remove from points
								unset($points[$type][$in]);
							}
						}
					}
				}
			}
		}
		if (array_sum($keeper) == $targetTotal)
		{
			// return the ids to keep
			return $keeper;
		}
		// we retry a few times
		if (self::$retry < 40)
		{
			// reset few defaults
			$loaded = array(1=>0,2=>0,3=>0,4=>0,5=>0);
			$keeper = array();
			// increment counter
			self::$retry++;
			// lets try again >>
			return self::questionSortSelection($re_try,$targetTotal,$subtotal,$get,$loaded,$keeper);
		}
		return false;
	}

	/**
	 *	Shuffle array but keep keys
	 */
	protected static function shuffleArray(&$array) 
	{
		if (isset($array) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($array))
		{
			if (self::$fieldShuffle)
			{
				// first set the keys
				$keys = array_keys($array);
				// then shuffle them
				shuffle($keys);
				// load based on the result
				foreach($keys as $key)
				{
				    $new[$key] = $array[$key];
				}
				// load the new order
				$array = $new;
				// done
			}
			return true;
		}
		return false;
		
	}
	
	/**
	 *	Get the questions max available point
	 */
	public static function getAvailablePoint(&$question, $returnType = false)
	{
		$point = 0;
		if ($type = self::getQuestionType($question))
		{
			$point = self::availablePoint($question, $type);
			if ($returnType)
			{
				return array('type' => $type, 'point' => $point);
			}
		}
		return $point;
	}

	/**
	* 	to identify the question types
	**/
	public static $questionTypes = array(
		1 => array('answer_type' => 1),						// Yes No
		2 => array('answer_type' => 2, 'selectiontype' => 1),		// Selection
		3 => array('answer_type' => 2, 'selectiontype' => 2),		// Multi Selection
		4 => array('answer_type' => 3, 'text_mark_type' => 1),		// Text
		5 => array('answer_type' => 3, 'text_mark_type' => 2));		// Text Plus
	/**
	 *	Get the questions type
	 */
	protected static function getQuestionType(&$question)
	{				
		foreach (self::$questionTypes as $type => $search)
		{
			$found = 0;
			$look = count($search);
			foreach ($search as $key => $val)
			{
				if ((int) $question->$key == (int) $val)
				{
					$found++;
				}
			}
			if ($look == $found)
			{
				// return the found type
				return $type;
			}
		}
		return false;
	}
	
	/**
	 *	Get the questions max available point
	 */
	protected static function availablePoint($question, $type)
	{
		$point = self::getPoint($question->id);
		if ($point == 0)
		{
			switch ($type)
			{
				case 1:
					// radio
					$point = $question->yesno_point;
					break;
				case 2:
					// list
					$point = $question->list_point;
					break;
				case 3:
					// multi list
					$point = self::getAvailableListPoint($question);
					break;
				case 4:
					// text
					$point = $question->completion_point;
					break;
				case 5:
					// text plus
					$point = self::getAvailableTextPlusPoint($question);
					break;
			}	
			return self::setPoint($question->id, $point);
		}
		return $point;
	}

	/**
	* 	the helper session
	**/
	protected static $session;
		
	/**
	 *	Store the point
	 */
	protected static function setPoint($id, $point)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$session))
		{
			self::$session = Factory::getSession();
		}
		self::$session->set('questionPoint'.$id, $point);
		return $point;
	}
		
	/**
	 *	Get the stored the point
	 */
	protected static function getPoint($id)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$session))
		{
			self::$session = Factory::getSession();
		}
		return self::$session->get('questionPoint'.$id, 0);
	}
		
	/**
	 *	Get the questions max point (for a list)
	 */
	protected static function getAvailableListPoint($question)
	{
		$value = 0;
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($question->selection))
		{
			$options = json_decode($question->selection, true);
			if (isset($options['type']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($options['type']))
			{
				foreach ($options['type'] as $correct)
				{
					if ($correct == 1)
					{
						$value++;
					}
				}
			}
		}
		elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($question->selection))
		{
			$value = count($question->selection);
		}
		return bcmul($question->list_point, $value);
	}
		
	/**
	 *	Get the questions max point (for a text plus)
	 */
	protected static function getAvailableTextPlusPoint($question)
	{
		$value = 1;
		// check if it is already an array of values
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($question->key_words))
		{
			$value = count($question->key_words);
		}
		elseif (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($question->key_words))
		{
			if (strpos($question->key_words, ';') !== false)
			{
				$keyword = explode(';', $question->key_words);
				$value = count($keyword);
			}
			elseif (strpos($question->key_words, ',') !== false)
			{
				$keyword = explode(',', $question->key_words);
				$value = count($keyword);
			}
		}
		return bcmul(bcadd($question->word_count_point, $question->key_words_point), $value);
	}
	
	/**
	* 	The shuffle switch
	**/
	public static $fieldShuffle = false;
	
	/**
	 *	The main call function to load a form
	 */
	public static function getTheForm($data,$fieldsKey,$settings, $type)
	{
		// should it be set per user
		$controleKey = '';
		if (4 != $data->assessment_type_build_method)
		{
			// get the username
			$controleKey = Factory::getUser()->username;
			if (2 == $data->assessment_type_build_method)
			{
				$controleKey = $controleKey.Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
			}
		}
		// set file name
		$fileName = md5(serialize($data).$controleKey);
		// set params
		if (empty(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// set some defaults
		$path	= self::$params->get('xmlpath', JPATH_ADMINISTRATOR . '/models/forms');
		// build full path to file
		$fullPath = $path.'/'.$fileName.'.xml';
		// add this file name to the session
		$session = Factory::getSession();
		$session->set($type.'_'.$data->id, $fileName );
		// check if file exists
		if ($data->assessment_type_build_method != 1 && file_exists($fullPath))
		{
			// great we are done return results
			$done = true;
		}
		else
		{
			// check the ordering option
			if (2 == $data->assessment_type_ordering_option)
			{
				self::$fieldShuffle = true;
			}
			// if this is an assessment form first prepare fields/questions
			if ('assessment' == $type)
			{
				if (!self::prepQuestions($data,$fieldsKey))
				{
					return false;
				}
			}
			// prepare the fields
			if (!self::prepFields($data->$fieldsKey,$settings,$type))
			{
				return false;
			}
			// build the XML for the form
			$result = self::buildXML($data->$fieldsKey,$settings,$type);
			// did we get a valid result set
			if ($result)
			{
				// now save for next time
				$done = self::saveXML($result, $fullPath, $path);
			}
		}
		// did we get a valid result set
		if ($done)
		{
			// Get the form.
			jimport( 'joomla.form.form' );
			// set the paths
			JForm::addFormPath($path);
			JForm::addFieldPath(JPATH_ADMINISTRATOR . '/models/fields');
			// great we are done return results
			return JForm::getInstance('com_[[[component]]].'.$fileName, $fileName, array('control' => 'jform', 'load_data' => false), false, false);
		}
		return false;
	}
	
	/**
	 *	Prepare the fields to load into xml
	 */
	protected static function prepFields(&$data,&$settings,$type)
	{
		if(Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
		{
			// default fields
			$defaults = array('type','keys','name','label','description');
			// some extra prep for assessments
			if ('assessment' == $type)
			{
				// we must build the name and description
				foreach ($data as $field)
				{
					$field->name = $field->id;
					$field->description = Text::sprintf('This question counts %s points.', $field->point);
					$field->labelPoint = '&nbsp;&nbsp;<em>' . $field->point .'&nbsp;'. Text::_('Points') . '</em>';
					$field->autocomplete = 'false';
					$field->autofocus = 'false';
					$field->labelclass = '';
				}
				$defaults[] = 'required';
				$defaults[] = 'class';
			}
			
			foreach ($data as $nr => &$field)
			{
				// set the key propety
				$field->keys = array();
				// fix the options
				if (2 == $field->{$settings['type']})
				{
					// set the options
					self::setOptionsField($field,$settings);
				}
				elseif (1 == $field->{$settings['type']})
				{
					// some extra prep for assessments
					if ('assessment' == $type)
					{
						$field->{$settings['options']}['yes'] = Text::_('Yes');
						$field->{$settings['options']}['no'] = Text::_('No');
						if (!isset($field->{$settings['filter']}))
						{
							$field->filter = 'WORD';
						}
					}
					else
					{
						// set the options
						self::setOptionsField($field,$settings,'radio');
					}
				}
				else
				{
					unset($field->{$settings['options']});
				}
				// some country fix
				if (11 == $field->{$settings['type']} && isset($field->defaultcountry))
				{
					$field->{$settings['default']} = $field->defaultcountry;
				}
				// load the given keys
				foreach ($settings as $key => $keyField)
				{
					if (!in_array($key,$defaults) && isset($field->$keyField))
					{			
						// only set keys needed for this type
						$set = self::$fieldTypes[$field->{$settings['type']}];
						// check if this field is part of this type
						if (isset($set[$key]) && !empty($field->$keyField))
						{
							$field->keys[$key] = $field->$keyField;
						}
						// remove the filed
						unset($field->$keyField);
					}
				}
			}
			return true;
		}
		// set error
		JError::raiseWarning(500, Text::sprintf('No fields were set for this %s, please notify the system administrator.', $type));
		return false;
	}
	
	protected static function setOptionsField(&$field,$settings,$type = 'list')
	{
		// fix the options
		if (isset($field->{$settings['options']}) && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($field->{$settings['options']}))
		{
			$filter = 'STRING';
			$notSetFilter = true;
			$buildSelection = json_decode($field->{$settings['options']},true);
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($buildSelection['selection']))
			{
				$bucket = array();
				if (isset($buildSelection['value']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($buildSelection['value']))
				{
					// to use values instead of the text
					$filter = 'INT';
				}
				else
				{
					// if not multi then add some fix to insure no selection is selected by default
					if (isset($field->{$settings['multiple']}) && is_numeric($field->{$settings['multiple']}))
					{
						if (2 != $field->{$settings['multiple']} && 'list' == $type)
						{
							$bucket[''] = Text::_('Select some option');
						}
					}
					// build the selection array
					foreach ($buildSelection['selection'] as $selection)
					{
						if (strpos($selection,'|') !== false)
						{
							$array_setter = explode('|', $selection);
							if (count($array_setter) == 2)
							{
								list($value_setter, $text_setter) = $array_setter;
								$bucket[Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($value_setter)] = $text_setter;
								// set the filter based on the type
								if (is_numeric($value_setter) && $notSetFilter)
								{
									if (is_int($value_setter))
									{
										$filter = 'INT';
										$notSetFilter = false;
									}
									elseif (is_float($value_setter))
									{
										$filter = 'FLOAT';
										$notSetFilter = false;
									}
								}
								elseif (is_string($value_setter) && $notSetFilter)
								{
									$filter = 'WORD';
									$notSetFilter = false;
								}
							}
							elseif (count($array_setter) == 1)
							{
								$bucket[''] = $array_setter[0];
							}
							else
							{
								$bucket[Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($selection)] = $selection;
								// set the filter based on the type
								if (is_numeric($selection) && $notSetFilter)
								{
									if (is_int($selection))
									{
										$filter = 'INT';
										$notSetFilter = false;
									}
									elseif (is_float($selection))
									{
										$filter = 'FLOAT';
										$notSetFilter = false;
									}
								}
								elseif (is_string($selection) && $notSetFilter)
								{
									$filter = 'WORD';
									$notSetFilter = false;
								}
							}
						}
						else
						{
							$bucket[Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($selection)] = $selection;
							// set the filter based on the type
							if (is_numeric($selection) && $notSetFilter)
							{
								if (is_int($selection))
								{
									$filter = 'INT';
									$notSetFilter = false;
								}
								elseif (is_float($selection))
								{
									$filter = 'FLOAT';
									$notSetFilter = false;
								}
							}
							elseif (is_string($selection) && $notSetFilter)
							{
								$filter = 'WORD';
								$notSetFilter = false;
							}
						}
					}
				}
				$field->{$settings['options']} = $bucket;
			}
			
			// fix multiple switch
			if (2 == $field->{$settings['type']} && isset($field->{$settings['multiple']}) && is_numeric($field->{$settings['multiple']}))
			{
				if (2 == $field->{$settings['multiple']})
				{
					$field->{$settings['multiple']} = 'true';
					$filter = 'ARRAY';
				}
				else
				{
					$field->{$settings['multiple']} = 'false';
				}
			}
			else
			{
				unset($field->{$settings['multiple']});
			}
			
			// set the filter if not set already
			if (!isset($field->{$settings['filter']}) || empty($field->{$settings['filter']}))
			{
				$field->filter = $filter;
			}
		}
	}
	
	/**
	 *	Check if a string is json
	 */
	public static function isJson($string)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($string))
		{
			json_decode($string);
			return (json_last_error() === JSON_ERROR_NONE);
		}
		return false;
	}

	/**
	* 	To add numbers to questions
	**/
	protected static $qCounter;
	
	/**
	 *	Build the form xml
	 */
	public static function buildXML($data,$settings,$typeFieldSet)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
		{
			// always reset
			$fieldSet = array();
			// set the defautl fields
			$fieldSet[] = '<?xml version="1.0" encoding="utf-8"?>';
			$fieldSet[] = '<form addfieldpath="/administrator/components/com_[[[component]]]/models/fields">';
			$fieldSet[] = '<fieldset name="'.$typeFieldSet.'">';
			$fieldSet[] = "\t<!-- Dynamic Fields. -->";
			// load the fields
			self::$qCounter = 1;
			foreach ($data as $field)
			{
				// build values
				$type = (isset($field->{$settings['type']})) ? $field->{$settings['type']}:null;
				$label = (isset($field->{$settings['label']})) ? $field->{$settings['label']}:null;
				$description = (isset($field->{$settings['description']})) ? $field->{$settings['description']}:null;
				if ('assessment' == $typeFieldSet)
				{
					$label .= (isset($field->labelPoint)) ? $field->labelPoint:'';
				}
				$name = (isset($field->{$settings['name']})) ? $field->{$settings['name']}:null;
				$keys = (isset($field->keys)) ? $field->keys:null;
				// check if we can continue
				if ($b_field = self::setDynamicField($type,$label,$description,$name,$keys))
				{
					$fieldSet[] = "\t".$b_field;
				}
				else
				{
					return false;
				}
			}

			$fieldSet[] = "</fieldset>";
			$fieldSet[] = "</form>";

			// retunr the set
			return implode("\n",$fieldSet);
		}
		return false;
	}
	
	/**
	 *	Build the xml for the field (dynamicly)
	 */
	protected static function setDynamicField($type,$label,$description,$name,$keys = null)
	{
		// only load the fields that are set
		if (isset(self::$fieldTypes[$type]) && !is_null($name))
		{
			// always reset
			$field = array();
			$set = self::$fieldTypes[$type];
			// to skip
			$not = array('type','name','class','label','filter','description','required');
			// the not counter array
			$notCount = array('note','spacer');
			$options = false;
			// set some defaults
			$class = (isset($keys['class'])) ? $keys['class'].((isset($set['class'])) ? ' '.$set['class']:''):((isset($set['class'])) ? $set['class']:'');
			$filter = (isset($keys['filter'])) ? $keys['filter']:((isset($set['filter'])) ? $set['filter']:'STRING');
			$required = (isset($keys['required'])) ? $keys['required']: ((isset($set['required'])) ? $set['required']:'false');
			// build the field
			$field[] = '<!-- '.Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($name,'Ww').' Field. Type: '.Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($set['type'],'Ww').' (joomla) -->';
			$field[] = "\t".'<field';
			$field[] = "\t\t".'type="'.$set['type'].'"';
			$field[] = "\t\t".'name="'.$name.'"';
			if (!in_array($set['type'],$notCount))
			{
				$field[] = "\t\t".'label="'.self::$qCounter.'. '.htmlspecialchars(trim($label)).'"';
				self::$qCounter++;
			}
			elseif (14 == $type)
			{
				$field[] = "\t\t".'label="'.htmlspecialchars(trim($label)).'"';
			}
			// check if desc is set
			if ($description)
			{
				$field[] = "\t\t".'description="'.htmlspecialchars($description).'"';
			}
			$field[] = "\t\t".'class="'.$class.'"';
			$field[] = "\t\t".'filter="'.$filter.'"';
			$field[] = "\t\t".'required="'.$required.'"';
			if (isset($keys) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keys))
			{
				foreach ($keys as $key => $value)
				{
					if ($key == 'options')
					{
						$options = $value;
						$not[] = $key;
						continue;
					}
					if (!in_array($key,$not))
					{
						$not[] = $key;
						$field[] = "\t\t".self::htmlEscape($key).'="'.htmlspecialchars($value).'"';
					}
				}
			}
			// load the dafaults still not set
			foreach ($set as $_key => $_value)
			{
				if ($_key == 'options' && !$options)
				{
					$options = $_value;
					continue;
				}
				if (!in_array($_key,$not))
				{
					$field[] = "\t\t".self::htmlEscape($_key).'="'.htmlspecialchars($_value).'"';
					$not[] = $_key;
				}
			}
			// check if this field has options
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($options))
			{
				$field[] = "\t\t>";
				$field[] = "\t\t<!-- Option Set. -->";
				foreach($options as $val => $text)
				{
					$field[] = "\t\t".'<option value="'.$val.'">';
					$field[] = "\t\t\t".htmlspecialchars(self::htmlEscape($text))."</option>";
				}
				$field[] = "\t</field>";
			}
			else
			{
				$field[] = "\t/>";
			}
			// done, return dynamic builded field
			return implode("\n",$field);
		}
		// set error
		JError::raiseWarning(500, Text::_('A field could not be build, please notify the system administrator.'));
		return false;
	}

	/**
	* 	fieldTypes Default Settings
	**/
	public static $fieldTypes = array(
			1 => array(
				'type' => 'radio', 
				'default' => '',
				'description' => '',
				'class' => 'btn-group btn-group-yesno',
				'options' => array('Yes','No'),
				'filter' => 'word', 
				'required' => 'true',
				'showon' => ''),
			2 => array(
				'type' => 'list', 
				'default' => '',
				'description' => '',
				'class' => 'list_class',
				'multiple' => false,
				'options' => array(),
				'filter' => 'int', 
				'required' => 'true',
				'showon' => '' ),
			3 => array(
				'type' => 'editor', 
				'description' => '',
				'default' => '',
				'width' => '100%', 
				'height' => '500px', 
				'filter' => 'safehtml', 
				'required' => 'true',
				'buttons' => 'false',
				'hide' => '',
				'editor' => 'jce|none',
				'rows' => '',
				'cols' => '',
				'showon' => ''),
			4 => array(
				'type' => 'textarea',
				'default' => '',
				'description' => '',
				'maxlength' => '1400',
				'class' => 'text_area uk-width-1-1',
				'width' => '100%', 
				'height' => '500px', 
				'filter' => 'string', 
				'required' => 'true',
				'hint' => '',
				'rows' => '20',
				'cols' => '10',
				'showon' => ''),
			5 => array(
				'type' => 'text', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'filter' => 'string', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			6 => array(
				'type' => 'url', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			7 => array(
				'type' => 'email', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			8 => array(
				'type' => 'tel', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			9 => array(
				'type' => 'calendar', 
				'description' => '',
				'class' => 'text_area',
				'size' => '60', 
				'maxlength' => '150',
				'filter' => 'server_utc', 
				'required' => 'true',
				'format' => '%d-%m-%Y',
				'message' => '',
				'default' => '',
				'showon' => ''),
			10 => array(
				'type' => 'color', 
				'description' => '',
				'class' => 'text_area',
				'size' => '60', 
				'maxlength' => '150',
				'filter' => 'string', 
				'required' => 'true',
				'message' => '',
				'default' => '',
				'showon' => ''),
			11 => array(
				'type' => 'countryname', 
				'description' => '',
				'class' => 'list_class',
				'filter' => 'string', 
				'required' => 'true',
				'message' => '',
				'default' => '',
				'showon' => ''),
			12 => array(
				'type' => 'hidden', 
				'class' => 'text_hidden', 
				'filter' => 'int', 
				'required' => 'true',
				'default' => '1' ),
			13 => array(
				'type' => 'file', 
				'description' => '',
				'class' => 'text_area',
				'size' => '60', 
				'filter' => '', 
				'required' => 'true',
				'accept' => 'image/*',
				'message' => '',
				'showon' => ''),
			14 => array(
				'type' => 'note', 
				'description' => '',
				'heading' => 'h4',
				'class' => 'alert',
				'close' => '',
				'showon' => ''),
			15 => array(
				'type' => 'spacer', 
				'description' => '',
				'hr' => 'true',
				'class' => 'text_area',
				'showon' => ''),
			16 => array(
				'type' => 'note', 
				'description' => '',
				'heading' => 'h4',
				'class' => 'text_area',
				'showon' => ''),
			17 => array(
				'type' => 'regionname', 
				'description' => '',
				'class' => 'list_class',
				'filter' => 'string', 
				'required' => 'true',
				'message' => '',
				'default' => '',
				'showon' => ''),
			30 => array(
				'type' => 'password', 
				'description' => '',
				'class' => 'validate-password',
				'size' => '60', 
				'maxlength' => '150', 
				'filter' => 'raw', 
				'validate' => 'password', 
				'required' => 'true',
				'autocomplete' => 'off',
				'field' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			31 => array(
				'type' => 'captcha', 
				'description' => '',
				'validate' => 'captcha', 
				'namespace' => '')
			);

	/**
	* 	save XML
	**/
	public static function saveXML($data, $fullPath, $path)
	{
		// check if path exists
		if (!file_exists($path))
		{
			// if not the make the path
			mkdir($path, 0755, true);
		}
		libxml_use_internal_errors(true);
		// make sure this is valid xml
		if (simplexml_load_string($data))
		{
			$fp = fopen($fullPath, 'w');
			fwrite($fp, $data);
			fclose($fp);
			return true;
		}
		
		// set error
		JError::raiseWarning(500, Text::_('The xml for this from could not be validated, please notify the system administrator.'));
		return false;
	}
	
	protected static $dynamicData = array();

	public static function setDynamicData($data, $placeholders)
	{
		$keyMD5 = md5($data.json_encode($placeholders));
		if (!isset(self::$dynamicData[$keyMD5]))
		{
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($placeholders))
			{
				self::setTheIF($data, $placeholders);
				self::$dynamicData[$keyMD5] = str_replace(array_keys($placeholders), array_values($placeholders), $data);
			}
			else
			{
				self::$dynamicData[$keyMD5] = $data;
			}
		}
		return self::$dynamicData[$keyMD5];
	}

	protected static function setTheIF(&$string, $placeholders)
	{		
		// only normal if endif
		$condition 	= '[a-z0-9\_\-]+';
		$inner		= '((?:(?!\[\/?IF)(?!\[\/?ELSE)(?!\[\/?ELSEIF).)*?)';
		$if		= '\[IF\s?('.$condition.')\]';
		$elseif		= '\[ELSEIF\s?('.$condition.')\]';
		$else		= '\[ELSE\]';
		$endif		= '\[ENDIF\]';
		// set the patterns
		$patterns = array();
		// normal if endif
		$patterns[] = '#'.$if.$inner.$endif.'#is';
		// normal if else endif
		$patterns[] = '#'.$if.$inner.$else.$inner.$endif.'#is';
		// dynamic if elseif's endif
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		// dynamic if elseif's else endif
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		// run the patterns to setup the string
		foreach ($patterns as $pattern)
		{
			while (preg_match($pattern, $string, $match))
			{
				$keep 	= self::remainderIF($match, $placeholders);
				$string	= preg_replace($pattern, $keep, $string, 1);
			}
		}
	}

	protected static function remainderIF(&$match, &$placeholders)
	{	
		// default we keep nothing
		$keep = '';
		$found = false;
		// get match lenght
		$length = count($match);
		// ranges to check
		$ii = range(2,30,2); // even numbers (content)
		$iii = range(1, 25, 2); // odd numbers (placeholder)
		// if empty value remove whole line else show line but remove all [CODE]
		foreach ($iii as $content => $placeholder)
		{
			if (isset($match[$placeholder]) && empty($placeholders['['.$match[$placeholder].']']))
			{
				// keep nothing or next option
				$keep = '';
			}
			elseif (isset($match[$ii[$content]]))
			{
				$keep = addcslashes($match[$ii[$content]], '$');
				$found = true;
				break;
			}
		}
		// if not found load else if set
		if (!$found && in_array($length, $ii))
		{
			$keep = addcslashes($match[$length - 1], '$');
		}
		return $keep;	
	}

	protected static $placeHolders;
	
	public static function getPlaceHolders($student, $type = null, $config = array())
	{
		if (!isset(self::$placeHolders[$student]))
		{
			// get needed details
			$details = array();
			$details[] = self::getinstitutionDetails();
			$details[] = self::getstudentDetails($student);
			// type switch (TODO)
			self::$placeHolders[$student] = self::mergeArrays($details);
		}
		// add the cofig array if needed
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($config))
		{
			$details[] = self::$placeHolders[$student];
			$details[] = $config;
			self::$placeHolders[$student] = self::mergeArrays($details);
		}
		return self::$placeHolders[$student];
	}

	protected static $institutionDetails = array();
	
	public static function getinstitutionDetails()
	{
		if (!isset(self::$institutionDetails['institution_name']))
		{
			// get the global institution details
			$app_params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
			self::$institutionDetails['[institution_name]'] = $app_params->get('institutionname', '');
			self::$institutionDetails['[institution_logo]'] = '<img alt="'.self::$institutionDetails['[institution_name]'].'" src="'.Uri::root().$app_params->get('institutionlogo', '').'">';
			self::$institutionDetails['[institution_email]'] = $app_params->get('email', '');
			self::$institutionDetails['[institution_phone]'] = $app_params->get('phone', '');
			self::$institutionDetails['[institution_fax]'] = $app_params->get('fax', '');
			self::$institutionDetails['[institution_street]'] = $app_params->get('street', '');
			self::$institutionDetails['[institution_postal]'] = $app_params->get('postal', '');
			self::$institutionDetails['[institution_postalcode]'] = $app_params->get('postalcode', '');
			self::$institutionDetails['[institution_city]'] = $app_params->get('city', '');
			self::$institutionDetails['[institution_website]'] = $app_params->get('website', '');
			// set the region
			$region = $app_params->get('region');
			if ($region && is_numeric($region) && $region > 0)
			{
				self::$institutionDetails['[institution_region_name]'] = self::getVar('region', $region, 'id', 'name');
			}
			elseif (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($region))
			{
				self::$institutionDetails['[institution_region_name]'] = $region;
			}
			else
			{
				self::$institutionDetails['[institution_region_name]'] = '';
			}
			// set the country
			$country = $app_params->get('country');
			if ($country && is_numeric($country) && $country > 0)
			{
				self::$institutionDetails['[institution_country_name]'] = self::getVar('country', $country, 'id', 'name');
			}
			elseif (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($country))
			{
				self::$institutionDetails['[institution_country_name]'] = $country;
			}
			else
			{
				self::$institutionDetails['[institution_country_name]'] = '';
			}
		}
		return self::$institutionDetails;
	}

	protected static $studentDetails = array();
	
	public static function getstudentDetails($id, $field = null)
	{
		if ($id > 0)
		{
			if (!isset(self::$studentDetails[$id]))
			{
				// Create a new query object.
				$db = Factory::getDBO();
				$query = $db->getQuery(true);
		
				// Select some fields
				$query->select($db->quoteName(
					array(
						'a.id','a.user','a.mobile_phone','a.gender','a.marriagestatus',
						'a.dateofbirth','a.national_id','a.occupation','a.employer',
						'a.work_phone','a.home_phone','a.street','a.postal','a.city',
						'a.region','a.country','a.postalcode','a.autobiography'),
					array(
						'[id]','[user_id]','[mobile_phone]','[gender]','[marriagestatus]','[dateofbirth]',
						'[national_id]','[occupation]','[employer]','[work_phone]','[home_phone]',
						'[street]','[postal]','[city]','[region_name]','[country_name]','[postalcode]','[autobiography]')));
				$query->select($db->quoteName(
					array('b.name','b.username','b.email'),
					array('[name]','[username]','[email]')));
				
				$query->join('LEFT', ($db->quoteName('#__users', 'b')) . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('b.id') . ')');
				// From the [[[component]]]_student table				
				$query->from($db->quoteName('#__[[[component]]]_student', 'a'));
				$query->where($db->quoteName('a.id') . ' = '. (int) $id);
				// load the query
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					self::$studentDetails[$id] = $db->loadAssoc();
				}
			}
			if ($field)
			{
				$field = '['.$field.']';
				if (isset(self::$studentDetails[$id][$field]))
				{
					return self::$studentDetails[$id][$field];
				}
				return false;
			}
			return self::$studentDetails[$id];
		}
		return false;
	}

	/**
	* 	component params
	**/
	public static $params;

	/**
	* 	Report Card Items
	**/
	public static $reportCardItems;
	
	/**
	* 	Is users report card
	**/
	public static $reportCard = array();
	
	/**
	* 	Is event details
	**/
	public static $eventDetails = array();

	/**
	* 	Is Report Card Program
	**/
	protected static $reportCardProgram = array();

	public static function setReportCard(&$items, &$assessments)
	{
		// set params
		if (empty(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// set report card items
		self::$reportCardItems = $items;
		// Build report card
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($assessments))
		{
			foreach($assessments as $event_name => &$data)
			{
				// start date
				$startdate = strtotime('3000-00-00');
				$notdate = strtotime('2000-00-00');
				// insure that event name is correct
				$data['event_name'] = $event_name;
				// add needed event details
				self::$eventDetails[$event_name]['[event_name]'] = $event_name;
				self::$eventDetails[$event_name]['[program_name]'] = $data['program_name'];
				self::$eventDetails[$event_name]['[program_acronym]'] = $data['program_acronym'];
				self::$eventDetails[$event_name]['[program_icon]'] = $data['program_icon'];
				// insure we have a program id
				if (!isset($data['program_id']) && isset($data['program_acronym']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data['program_acronym']))
				{
					$data['program_id'] = self::getVar('program', $data['program_acronym'], 'acronym', 'id');
					// set the pass point
					self::$eventDetails[$event_name]['[pass_credit]'] = self::getVar('program', $data['program_id'], 'id', 'pass_credit');
					// set report card header switch
					self::$reportCardProgram[$data['program_id']] = self::getVar('program', $data['program_id'], 'id', 'set_report_card');
				}
				else
				{
					// set the pass point
					self::$eventDetails[$event_name]['[pass_credit]'] = null;
				}
				// load the report card values and set the start date
				foreach($data['values'] as $course_name => $days)
				{
					foreach($days as $day_name => $assessments_types)
					{
						foreach($assessments_types as $assessment_name => $_assessments)
						{
							foreach($_assessments as $values)
							{
								if ($values->assessment_type_add_reportcard == 1)
								{
									self::addToReport($values, $event_name, $course_name, $assessment_name);
								}
								// build start date
								if (is_numeric($values->day_date) && $values->day_date < $startdate && $values->day_date > $notdate)
								{
									$startdate = $values->day_date;
								}
							}
						}
					}
				}
				// get assessment notice (check if all assessments are submitted)
				self::$eventDetails[$event_name]['[assessments_outstanding]'] = self::getAssessmentsOutstanding($event_name);
				// add event date
				self::$eventDetails[$event_name]['[event_date]'] = self::fancyDate($startdate);
			}
			// build the report table
			self::setReportTable();
		}
	}
	
	protected static function setReportTable()
	{
		// set final defaults per/event
		self::setDefaultsPerEvent();
		// some defaults
		$style = 'style="padding: 10px; text-align: center; border: 1px solid rgb(221, 221, 221);"';
		$styleName = 'style="padding: 10px; text-align: right; border: 1px solid rgb(221, 221, 221);"';
		// the module credit system tables
		if (isset(self::$total['module']['credit']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$total['module']['credit']))
		{
			// initiate the module report card
			self::$reportCard['module'] = array();
			// load the credit and percentage
			foreach(self::$per['moduleProgram']['credit'] as $event_name => $modules)
			{
				$addCredit = false;
				if (!isset(self::$assessmentsOutstanding[$event_name]))
				{
					$addCredit = true;
				}
				foreach($modules as $module_name => $credit)
				{
					$row = array();
					$row[] = $module_name;
					$row[] = self::loadPerModule('Course', $event_name, $module_name);
					$row[] = self::loadPerModule('Assessment', $event_name, $module_name);
					$row[] = self::$per['moduleProgramAvailable']['credit'][$event_name][$module_name];
					if ($addCredit)
					{
						$row[] = $credit;
					}
					else
					{
						$row[] = Text::_('pending');
					}
					// load the row
					self::$reportCard['module'][$event_name][$module_name] = '<td '.$styleName.'>'.implode('</td><td '.$style.'>',$row).'</td>';
				}
				ksort(self::$reportCard['module'][$event_name]);
			}
		}
		// the assessment credit system tables
		if (isset(self::$total['assessment']['credit']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$total['assessment']['credit']))
		{
			// initiate the assessment report card
			self::$reportCard['assessment'] = array();
			// first load the per program
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$per['program']['credit']))
			{
				foreach(self::$per['program']['credit'] as $event_name => $_assessments)
				{
					$addCredit = false;
					if (!isset(self::$assessmentsOutstanding[$event_name]))
					{
						$addCredit = true;
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($_assessments))
					{
						foreach($_assessments as $assessment_name => $credits)
						{
							$row = array();
							$row[] = $assessment_name;
							$row[] = array_sum(self::$per['programAvailable']['credit'][$event_name][$assessment_name]);
							if ($addCredit)
							{
								$row[] = array_sum($credits);
							}
							else
							{
								$row[] = Text::_('pending');
							}
							// load the row
							self::$reportCard['assessment'][$event_name][] = '<td '.$styleName.'>'.implode('</td><td '.$style.'>',$row).'</td>';
						}
					}
				}
			}
			// load the per course
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$per['course']['credit']))
			{
				foreach(self::$per['course']['credit'] as $event_name => $courses)
				{
					$addCredit = false;
					if (!isset(self::$assessmentsOutstanding[$event_name]))
					{
						$addCredit = true;
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($courses))
					{
						$bucket = array();
						foreach($courses as $course_name => $_assessments)
						{
							if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($_assessments))
							{
								foreach($_assessments as $assessment_name => $credits)
								{
									$row = array();
									$row[] = $course_name . ' - ' .$assessment_name;
									$row[] = array_sum(self::$per['courseAvailable']['credit'][$event_name][$course_name][$assessment_name]);
									if ($addCredit)
									{
										$row[] = array_sum($credits);
									}
									else
									{
										$row[] = Text::_('pending');
									}
									// load the row
									$bucket[$assessment_name][] = '<td '.$styleName.'>'.implode('</td><td '.$style.'>',$row).'</td>';
								}
							}
						}
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
						{
							// load assessment types together
							foreach ($bucket as $assement_name => $rows)
							{
								foreach ($rows as $row)
								{
									self::$reportCard['assessment'][$event_name][] = $row;
								}
							}
						}
					}
				}
			}
			// load the per assessment
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$per['assessment']['credit']))
			{
				foreach(self::$per['assessment']['credit'] as $event_name => $courses)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($courses))
					{
						$bucket = array();
						foreach($courses as $course_name => $_assessments)
						{
							if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($_assessments))
							{
								foreach($_assessments as $assessment_name => $credits)
								{
									if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($credits))
									{
										foreach($credits as $key => $credit)
										{
											$row = array();
											$row[] = $course_name . ' - ' .$assessment_name;
											$row[] = self::$per['assessmentAvailable']['credit'][$event_name][$course_name][$assessment_name][$key];
											$row[] = $credit;
											// load the row
											$bucket[$assessment_name][] = '<td '.$styleName.'>'.implode('</td><td '.$style.'>',$row).'</td>';
										}
									}
								}
							}
						}
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
						{
							// load assessment types together
							foreach ($bucket as $assement_name => $rows)
							{
								foreach ($rows as $row)
								{
									self::$reportCard['assessment'][$event_name][] = $row;
								}
							}
						}
					}
				}
			}
		}
	}

	protected static function loadPerModule($type, $event_name, $module_name)
	{
		if (isset(self::$per['module'.$type]['percentage'][$event_name][$module_name]))
		{
			$bucket = array();
			foreach (self::$per['module'.$type]['percentage'][$event_name][$module_name] as $name => $value)
			{
				$bucket[] = $name . ': ' . $value . '%';
			}
			return implode('<br />', $bucket);
		}
	}

	protected static function setDefaultsPerEvent()
	{
		// the module credit system tables
		if (isset(self::$total['module']['point']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$total['module']['point']))
		{
			// build the percentage and credit
			self::moduleBuilder();
		}
		if (isset(self::$total['module']['credit']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$total['module']['credit']))
		{
			// build the place holder credit info
			foreach (self::$total['module']['credit'] as $event_name => $values)
			{
				$credit_int = array_sum($values);
				$credit_received = self::displayCredit($event_name, $credit_int);
				$credit_available = 0;
				if (isset(self::$total['moduleAvailable']['credit'][$event_name]))
				{
					$credit_available = array_sum(self::$total['moduleAvailable']['credit'][$event_name]);
				}
				$pass_status = self::passStatus($event_name, $credit_int);
				// set some final event details
				self::$eventDetails[$event_name]['[credit_received]'] = $credit_received;
				self::$eventDetails[$event_name]['[credit_available]'] = $credit_available;
				self::$eventDetails[$event_name]['[pass_status]'] = $pass_status;
			}
		}
		// the assessment credit system tables
		if (isset(self::$total['assessment']['credit']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$total['assessment']['credit']))
		{
			// build the place holder credit info
			foreach (self::$total['assessment']['credit'] as $event_name => $values)
			{
				$credit_int = array_sum($values);
				$credit_received = self::displayCredit($event_name, $credit_int);
				$credit_available = 0;
				if (isset(self::$total['assessmentAvailable']['credit'][$event_name]))
				{
					$credit_available = array_sum(self::$total['assessmentAvailable']['credit'][$event_name]);
				}
				$pass_status = self::passStatus($event_name, $credit_int);
				// set some final event details
				self::$eventDetails[$event_name]['[credit_received]'] = $credit_received;
				self::$eventDetails[$event_name]['[credit_available]'] = $credit_available;
				self::$eventDetails[$event_name]['[pass_status]'] = $pass_status;
			}
		}		
	}

	protected static function loaditem(&$id)
	{
		// find the assessment if it has been done
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$reportCardItems))
		{
			foreach (self::$reportCardItems as $item)
			{
				if (isset($item->id) && $item->id == $id)
				{
					return $item;
				}
			}
		}
		return false;
	}

	protected static function getPointModuleOfAssessment($id)
	{
		$db	= Factory::getDbo();
		$query	= $db->getQuery(true);
		$query->select(array('a.point', 'a.available_point', 'a.module', 'a.question', 'm.name', 'm.pass_credit', 'm.pass_percentage', 'b.reviewed')); // not sure if name is the best
		$query->from($db->quoteName('#__[[[component]]]_assessment_value', 'a'));
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_module', 'm') . ' ON (' . $db->quoteName('a.module') . ' = ' . $db->quoteName('m.id') . ')');
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_assessment', 'b') . ' ON (' . $db->quoteName('a.assessment') . ' = ' . $db->quoteName('b.id') . ')');
		$query->where('a.assessment = '. (int) $id);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$answers = $db->loadObjectList();
			// we must check if all module values are set
			foreach ($answers as $nr => &$answer)
			{
				// FIX for old assessment results that does not have module and available point set (not ideal)
				if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($answer->name) || 0 == $answer->available_point)
				{
					// find the needed module name
					$query	= $db->getQuery(true);
					$query->select(
						array(
							'a.id', 'm.name', 'm.pass_credit', 'm.pass_percentage', 'a.answer_type', 'a.selectiontype', 'a.text_mark_type',
							'a.yesno_point', 'a.list_point', 'a.completion_point', 'a.selection', 'a.key_words',
							'a.key_words_point', 'a.word_count_point'
						));
					$query->from($db->quoteName('#__[[[component]]]_question', 'a'));
					$query->join('LEFT', $db->quoteName('#__[[[component]]]_module', 'm') . ' ON (' . $db->quoteName('a.module') . ' = ' . $db->quoteName('m.id') . ')');
					$query->where('a.question = '. $db->quote($answer->question));
					$db->setQuery($query);
					$db->execute();
					if ($db->getNumRows())
					{
						$question = $db->loadObject();
						// insure we have the module name
						if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($question->name))
						{
							unset($answers[$nr]); // remove this since we can't resolve the module
							continue;
						}
						// load the available point if not set
						if (0 == $answer->available_point)
						{
							$question->available_point = self::getAvailablePoint($question);
						}
					}
					else
					{
						unset($answers[$nr]); // remove this since we can't resolve the module
						continue;
					}
					// load the module name if not set
					if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($answer->name))
					{
						$answer->name = $question->name;
						$answer->pass_credit = $question->pass_credit;
						$answer->pass_percentage = $question->pass_percentage;
					}
					// load the available point if not set
					if (0 == $answer->available_point)
					{
						$answer->available_point = $question->available_point;
					}
				}
				// remove unneeded values
				unset($answer->module);
				unset($answer->question);
			}
			return $answers;
		}
		return false;
	}

	protected static function getAssessmentReportValue($id, $type = 'credit')
	{
		// find the assessment if it has been done
		if ($item = self::loaditem($id))
		{
			if ($item->reviewed == 1 && 'credit' == $type)
			{
				// now do calculation
				if ($item->assessment_type_pass_type == 1 && isset($item->point) && $item->point > 0)
				{
					// percentage
					$percent = bcmul(bcdiv($item->point, $item->assessment_type_total_points), 100);
					if ($percent >= $item->assessment_type_pass_percentage)
					{
						// return pass credit
						return $item->assessment_type_pass_credit;
					}
				}
				elseif ($item->assessment_type_pass_type == 2)
				{
					// completion (just return the pass credit)
					return $item->assessment_type_pass_credit;
				}
			}
			elseif ($item->reviewed == 1 && 'percentage' == $type)
			{
				// now do calculation
				if ($item->assessment_type_pass_type == 1 && isset($item->point) && $item->point > 0)
				{
					// percentage
					return bcmul(bcdiv($item->point, $item->assessment_type_total_points, 5), 100);
				}
				elseif ($item->assessment_type_pass_type == 2)
				{
					// completion (just return 100%)
					return 100;
				}
			}
		}
		return 'not-found';
	}

	/**
	* 	Is All Totals Array
	**/
	public static $total = array(
		'assessment' => array('credit' => array(), 'percentage' => array()),
		'assessmentAvailable' => array('credit' => array(), 'percentage' => array()),
		'module' => array('credit' => array(), 'percentage' => array(), 'point' => array()),
		'moduleAvailable' => array('credit' => array(), 'point' => array())
		);

	/**
	* 	Is per Array
	**/
	public static $per = array(
		// assessment credit system
		'assessment' => array('credit' => array(), 'percentage' => array()),
		'assessmentAvailable' => array('credit' => array(), 'percentage' => array()),
		'course' => array('credit' => array(), 'percentage' => array()),
		'courseAvailable' => array('credit' => array(), 'percentage' => array()),
		'program' => array('credit' => array(), 'percentage' => array()),
		'programAvailable' => array('credit' => array(), 'percentage' => array()),
		// module credit system
		'moduleAssessment' => array('percentage' => array(), 'point' => array()),
		'moduleAssessmentAvailable' => array('point' => array()),
		'moduleCourse' => array('percentage' => array(), 'point' => array()),
		'moduleCourseAvailable' => array('point' => array()),
		'moduleProgram' => array('credit' => array(), 'percentage' => array(), 'point' => array()),
		'moduleProgramAvailable' => array('credit' => array(), 'point' => array())
		);

	/**
	* 	the pass credit and pass percentage for modules
	**/
	protected static $passSettingsModule = array();

	protected static function addToReport(&$values, &$event_name, &$course_name, &$assessment_name)
	{
		// use Assessment Credit System
		if ($values->program_credit_system == 1)
		{
			if (!self::addToAssessmentReport($values, $event_name, $course_name, $assessment_name))
			{
				// set the assessment notice (check if all assessments are submitted)
				self::setAssessmentsOutstanding($values, $event_name, true);
			}
		}
		// use Module Credit System
		elseif ($values->program_credit_system == 2)
		{
			if (!self::addToModuleReport($values, $event_name, $course_name, $assessment_name))
			{
				// set the assessment notice (check if all assessments are submitted)
				self::setAssessmentsOutstanding($values, $event_name, true);
			}	
		}
	}

	protected static function addToModuleReport(&$values, &$event_name, &$course_name, &$assessment_name)
	{
		if ($values->submission)
		{
			// get the points and modules onf this assessment
			if ($items = self::getPointModuleOfAssessment($values->submission))
			{
				$type = 'point';
				foreach ($items as $item)
				{
					if ($item->reviewed == 1)
					{
						// per program/module
						self::$per['moduleProgram'][$type][$event_name][$item->name][] = $item->point;
						self::$per['moduleProgramAvailable'][$type][$event_name][$item->name][] = $item->available_point;
						// per course
						self::$per['moduleCourse'][$type][$event_name][$item->name][$course_name][] = $item->point;
						self::$per['moduleCourseAvailable'][$type][$event_name][$item->name][$course_name][] = $item->available_point;
						// per assessment
						self::$per['moduleAssessment'][$type][$event_name][$item->name][$assessment_name][] = $item->point;
						self::$per['moduleAssessmentAvailable'][$type][$event_name][$item->name][$assessment_name][] = $item->available_point;
						// now add to totals
						self::$total['module'][$type][$event_name][] = $item->point;
						self::$total['moduleAvailable'][$type][$event_name][] = $item->available_point;
						// set pass settings for the module globally
						if (!isset(self::$passSettingsModule[$item->name]))
						{
							self::$passSettingsModule[$item->name]['pass_credit'] = (int) $item->pass_credit;
							self::$passSettingsModule[$item->name]['pass_percentage'] = (int) $item->pass_percentage;
						}
					}
				}
				return true;
			}
		}
		return false;
	}

	/**
	* 	module builder array
	**/
	public static $moduleBuilder = array(
		'moduleAssessment' => 3,
		'moduleCourse' => 3,
		'moduleProgram' => 2
		);

	protected static function moduleBuilder()
	{
		// set per program
		foreach (self::$moduleBuilder as $type => $depth)
		{
			self::runModuleBuilder($type, $depth);
		}
	}
	
	protected static function runModuleBuilder($type, $depth)
	{
		// set per program
		if (isset(self::$per[$type]['point']) && self:: checkArray(self::$per[$type]['point']))
		{
			// sum and calculate the percentages
			foreach (self::$per[$type]['point'] as $event =>  $modules)
			{
				foreach ($modules as $module => $arrays)
				{
					if (3 == $depth)
					{
						foreach ($arrays as $name => $values)
						{
							// reset 
							$point = 0;
							$pointAvailable = 0;
							// set the point
							$point = array_sum($values);
							self::$per[$type]['point'][$event][$module][$name] = $point;
							// set the avalable point
							$pointAvailable = array_sum(self::$per[$type.'Available']['point'][$event][$module][$name]);
							self::$per[$type.'Available']['point'][$event][$module][$name] = $pointAvailable;
							// set percentage
							self::$per[$type]['percentage'][$event][$module][$name] = bcmul(bcdiv($point, $pointAvailable, 5), 100);
							// now set the credit
							if ('moduleProgram' == $type && isset(self::$passSettingsModule[$module]['pass_credit']))
							{
								$credit = 0;
								$creditAvailable = self::$passSettingsModule[$module]['pass_credit'];
								if (	isset(self::$passSettingsModule[$module]['pass_percentage']) && 
									self::$per[$type]['percentage'][$event][$module][$name] >= self::$passSettingsModule[$module]['pass_percentage'])
								{
									$credit = $creditAvailable;
								}
								self::$per[$type]['credit'][$event][$module][$name] = $credit;
								self::$per[$type.'Available']['credit'][$event][$module][$name] = $creditAvailable;
								// now add to totals
								self::$total['module']['credit'][$event][] = $credit;
								self::$total['moduleAvailable']['credit'][$event][] = $creditAvailable;
							}
							// now add to totals
							self::$total['module']['percentage'][$event][] = self::$per[$type]['percentage'][$event][$module][$name];
						}
					}
					elseif (2 == $depth)
					{
						// reset 
						$point = 0;
						$pointAvailable = 0;
						// set the point
						$point = array_sum($arrays);
						self::$per[$type]['point'][$event][$module] = $point;
						// set the avalable point
						$pointAvailable = array_sum(self::$per[$type.'Available']['point'][$event][$module]);
						self::$per[$type.'Available']['point'][$event][$module] = $pointAvailable;
						// set percentage
						self::$per[$type]['percentage'][$event][$module] = bcmul(bcdiv($point, $pointAvailable, 5), 100);
						// now set the credit
						if ('moduleProgram' == $type && isset(self::$passSettingsModule[$module]['pass_credit']))
						{
							$credit = 0;
							$creditAvailable = self::$passSettingsModule[$module]['pass_credit'];
							if (	isset(self::$passSettingsModule[$module]['pass_percentage']) && 
								self::$per[$type]['percentage'][$event][$module] >= self::$passSettingsModule[$module]['pass_percentage'])
							{
								$credit = $creditAvailable;
							}
							self::$per[$type]['credit'][$event][$module] = $credit;
							self::$per[$type.'Available']['credit'][$event][$module] = $creditAvailable;
							// now add to totals
							self::$total['module']['credit'][$event][] = $credit;
							self::$total['moduleAvailable']['credit'][$event][] = $creditAvailable;
						}
						// now add to totals
						self::$total['module']['percentage'][$event][] = self::$per[$type]['percentage'][$event][$module];
					}
				}
			}
		}
	}

	protected static function addToAssessmentReport(&$values, &$event_name, &$course_name, &$assessment_name)
	{
		// only use credit if program also set to use assessment credit system
		if ($values->assessment_type_add_credits == 1)
		{
			// get the credit to add
			$type = 'credit';
			$valueAvailable = $values->assessment_type_pass_credit;
		}
		else
		{
			// get the percentage to add
			$type = 'percentage';
			$valueAvailable = 100;
		}
		// set the available value to the report card
		if ($values->assessment_type_consolidate == 1)
		{
			// per course
			self::$per['courseAvailable'][$type][$event_name][$course_name][$assessment_name][] = $valueAvailable;
		}
		elseif ($values->assessment_type_consolidate == 2)
		{
			// per program
			self::$per['programAvailable'][$type][$event_name][$assessment_name][] = $valueAvailable;
		}
		else
		{
			// per assessment
			self::$per['assessmentAvailable'][$type][$event_name][$course_name][$assessment_name][] = $valueAvailable;
		}
		// now add to available totals
		self::$total['assessmentAvailable'][$type][$event_name][] = $valueAvailable;
		// check if submission were made
		if ($values->submission)
		{
			// get the values
			$value = self::getAssessmentReportValue($values->submission, $type);
			// only continue if a value is found
			if ('not-found' != $value)
			{
				// set the value to the report card
				if ($values->assessment_type_consolidate == 1)
				{
					// per course
					self::$per['course'][$type][$event_name][$course_name][$assessment_name][] = $value;
				}
				elseif ($values->assessment_type_consolidate == 2)
				{
					// per program
					self::$per['program'][$type][$event_name][$assessment_name][] = $value;
				}
				else
				{
					// per assessment
					self::$per['assessment'][$type][$event_name][$course_name][$assessment_name][] = $value;
				}
				// now add to totals
				self::$total['assessment'][$type][$event_name][] = $value;
				return true;
			}
		}
		return false;
	}

	public static function setReportCardButtons($key, $name)
	{
		$buttons = array();
		$buttons[] = '<div class="uk-button-group uk-width-1-1 uk-margin-small-bottom">';
		$buttons[] = '<button  type="button" class="uk-button uk-button-success uk-width-1-2" ';
		$buttons[] = 'onclick="viewPrint(\''.$name.'\', \'get'.$key.'\'); return false;">';
		$buttons[] = '<i class="uk-icon-print"></i> '.Text::_('View Print').'</button>';
		$buttons[] = '<button  onclick="setupEmail(\'get'.$key.'\', \''.$name.'\')" type="button" class="uk-button uk-button-primary uk-width-1-2">';
		$buttons[] = '<i class="uk-icon-envelope"></i> '.Text::_('Email').'</button>';
		$buttons[] = '</div>';
		return implode('', $buttons);
	}

	public static function setReportCardHeader($program, $event_details, $student)
	{
		// get place holders
		$placeholders = self::getPlaceHolders($student, null, $event_details);
		$header = '';
		// get header
		if (is_numeric($program) && (int) $program > 0 && isset(self::$reportCardProgram[$program]) && 1 == self::$reportCardProgram[$program])
		{
			$header = self::getVar('program', $program, 'id', 'report_card_header');
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($header))
		{
			$header = self::$params->get('doc_header');
		}
		// set the header
		return self::setDynamicData($header, $placeholders);
	}

	public static function setReportCardFooter($program, $event_details, $student)
	{
		// get place holders
		$placeholders = self::getPlaceHolders($student, null, $event_details);
		// get footer
		$footer = '';
		if (is_numeric($program) && (int) $program > 0 && isset(self::$reportCardProgram[$program]) && 1 == self::$reportCardProgram[$program])
		{
			$footer = self::getVar('program', $program, 'id', 'report_card_footer');
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($footer))
		{
			$footer = self::$params->get('doc_footer');
		}
		// set the footer
		return self::setDynamicData($footer, $placeholders);
	}

	public static function passed( $event_name, $credit)
	{
		if (!isset(self::$assessmentsOutstanding[$event_name]) && $credit >= self::$eventDetails[$event_name]['[pass_credit]'])
		{
			return true;
		}
		return false;
	}

	public static function displayCredit($event_name, $credit)
	{
		if (self::passed($event_name, $credit))
		{
			return '<span style="color: green;">'.$credit.'</span>';
		}
		return '<span style="color: red;">'.$credit.'</span>';
	}

	public static function passStatus($event_name, $credit)
	{
		if (self::passed($event_name, $credit))
		{
			return '<span style="color: green;">'.Text::_('PASSED').'</span>';
		}
		return '';
	}

	public static function storeMessage($send, $recipient, $subject, $body, $text, $mode = 0, $type = 'email')
	{
		// set the storing object
		$message = new \stdClass;
		$message->send_status = 0;
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($subject))
		{
			$message->subject = $subject;
		}
		if ($send)
		{
			$message->send_status = 1;
		}
		// if this is an email
		if ($type == 'email')
		{
			// check who the user is this message was send to
			$userId = self::getVar(null, $recipient, 'email', 'id', '=', 'users');
			if (is_numeric($userId))
			{
				$message->user = (int) $userId;
			}
			// set the email
			$message->email = $recipient;
		}
		elseif ($type == 'sms' && $type == 'notice')
		{
			if (is_numeric($recipient))
			{
				$message->user = (int) $recipient;
			}
		}
		if (isset($message->user))
		{
			// set the body stuff
			if ($mode || $type == 'notice')
			{
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($body))
				{
					$message->html = $body;
					// set the kind
					if ($type == 'email')
					{
						$message->kind = 1;	
					}
				}
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($text) && $type != 'notice')
				{
					$message->text = $text;
					// set the kind
					if ($type == 'email' && !isset($message->html))
					{
						$message->kind = 2;	
					}
				}
				if ($type == 'sms')
				{
					$message->kind = 3;
				}
				elseif ($type == 'notice')
				{
					$message->kind = 4;	
				}
			}
			else
			{
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($body))
				{
					$message->text = $body;
				}
				// set the kind
				if ($type == 'email')
				{
					$message->kind = 2;
				}
				elseif ($type == 'sms')
				{
					$message->kind = 3;
				}
			}
			// check if this message was send already
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(array('id')));		
			$query->from($db->quoteName('#__[[[component]]]_message'));
			$query->where($db->quoteName('user') . ' = '.$message->user);
			if (isset($message->subject))
			{
				$query->where($db->quoteName('subject') . ' = '.$db->quote($message->subject));
			}
			if (isset($message->kind))
			{
				$query->where($db->quoteName('kind') . ' = '.$message->kind);
			}
			if (isset($message->email))
			{
				$query->where($db->quoteName('email') . ' = '.$db->quote($message->email));
			}
			if (isset($message->html))
			{
				$query->where($db->quoteName('html') . ' = '.$db->quote($message->html));
			}
			if (isset($message->text))
			{
				$query->where($db->quoteName('text') . ' = '.$db->quote($$message->text));
			}
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$message->id = $db->loadResult();
				$message->modified_by = Factory::getUser()->id;
				$message->modified = Factory::getDate()->toSql();
				$message->datesent = $message->modified;
			}
			else
			{
				// set some more defaults
				$message->published = 1;
				$message->created_by = Factory::getUser()->id;
				$message->created = Factory::getDate()->toSql();
				$message->datesent = $message->created;
				$message->version = 1;
				$message->access = 1;
			}
			// update if id is found
			if (isset($message->id))
			{
				$db->updateObject('#__[[[component]]]_message', $message, 'id');
			}
			else
			{
				// insert the new message
				$result = $db->insertObject('#__[[[component]]]_message', $message);
				if ($result)
				{
					$aId = $db->insertid();
					// make sure the access of asset is set
					self::setAsset($aId,'message');
				}
			}
		}
	}', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdICgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10gKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdICgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdIChodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKSkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gbmV2ZXIgbWFraW5nIG9uZSBtaXN0YWtlIG9yIHRha2luZyBhbnkgY29mZmVlIGJyZWFrLikNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KKiojIyNhY3R1YWxIb3Vyc1NwZW50IyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxEYXlzU3BlbnQjIyMgRWlnaHQgSG91ciBEYXlzKiogKHRoZSBhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNwZW50KQ0KDQo+ICh3aXRoIHRoZSBmb2xsb3dpbmcgYnJlYWsgZG93bjoNCj4gKipkZWJ1Z2dpbmcgQCMjI2RlYnVnZ2luZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA0Ow0KPiAqKnBsYW5uaW5nIEAjIyNwbGFubmluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA3Ow0KPiAqKm1hcHBpbmcgQCMjI21hcHBpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gMTA7DQo+ICoqb2ZmaWNlIEAjIyNvZmZpY2VIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNjspDQoNCioqIyMjYWN0dWFsVG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsVG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqDQooYSB0b3RhbCBvZiB0aGUgcmVhbGlzdGljIHRpbWUgZnJhbWUgZm9yIHRoaXMgcHJvamVjdCkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gd2l0aCB0aGUgbm9ybWFsIGV2ZXJ5ZGF5IHJlYWxpdGllcyBhdCB0aGUgb2ZmaWNlLCB0aGF0IGluY2x1ZGVzIHRoZSBjb21wb25lbnQgcGxhbm5pbmcsIG1hcHBpbmcgJiBkZWJ1Z2dpbmcuKQ0KDQpQcm9qZWN0IGR1cmF0aW9uOiAqKiMjI3Byb2plY3RXZWVrVGltZSMjIyB3ZWVrcyoqIG9yICoqIyMjcHJvamVjdE1vbnRoVGltZSMjIyBtb250aHMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXSAoaHR0cHM6Ly93d3cudmRtLmlvL2pvb21sYS1jb21wb25lbnQtYnVpbGRlcikuDQo+IERldmVsb3BlZCBieSBbTGxld2VsbHluIHZhbiBkZXIgTWVyd2VdIChtYWlsdG86am9vbWxhQHZkbS5pbyk=', '', '', 'The Basic Learning Management System', '', '', 'Learning Management (public)', '.git', '', 1, 1, 'https://www.vdm.io/updates/learningmanager_update_server.xml', 'https://www.vdm.io', '', 'ZLC+o/uT82WtR+AsHX8HD8RBExDEA4h2p2RU848nDmnR7hfKjzQtlqomgRr8Zhvjduh5+Rn+zu38xQxmfhTMdg==', 'https://www.vdm.io/access/', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 439, '', 1, 2), -(2, 1, 1, 1, '', 1, '', '', '', 1, '', '', 1, '', '', 1, 1, 1, 1, '', 1, '', 1, 1, 1, 1, '{}', 3, 1, 1, 3, 'Llewellyn van der Merwe', '/var/www/jcb_j3', 'JCB.txt', '', '', 'Vast Development Method', '3.2.1-rc1', 'Copyright (C) 2015 Vast Development Method. All rights reserved.', '2015-04-30 12:04:35', '', 'HMhMLDKSyLrEPuBMJEM2GcDUhj7OY7lbAC8YaknszR8=', '6KTVm+xbGX1pknoG+r1guYUDh+l+YlLHJq2VeeKeWzo=', '', 'MARGltHnMVybJlT/Ul3J5JynJa3pt+aqtJNO8yPwhLY=', 'LmZpZWxkTWVkaXVtIHsgd2lkdGg6IDEyMHB4OyB9DQouZmllbGRMYXJnZSB7IHdpZHRoOiAzMjBweDsgfQ0KLmZpZWxkTWlkIHsgd2lkdGg6IDgwcHg7IH0NCi5maWVsZEZ1bGwgeyB3aWR0aDogMTAwJTsgfQ0KLmZpZWxkU21hbGwgeyB3aWR0aDogNjBweDsgfQ0KY29kZSB7IGRpc3BsYXk6IGlubGluZS1ibG9jazsgbWFyZ2luOiAzcHg7fQ==', '', '', 1, '', 'The Component Builder for [Joomla](https://extensions.joomla.org/extension/component-builder/) is highly advanced tool that is truly able to build extremely complex components in a fraction of the time.\r\n\r\nWhether you\'re a seasoned [Joomla](https://extensions.joomla.org/extension/component-builder/) developer, or have just started, Component Builder will save you lots of time and money. A real must have!', 'joomla@vdm.io', '', 'https://vdm.bz/component-builder-self', 'q0Nx5ndmXh3j8Y4iCBNd20YXY0eaJ69bpL5GcQKyWNw=', '', '7331e978-f213-4404-9fa5-0613db40ba57', 'images/vdm/jcb500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder', 'GNU General Public License version 2 or later; see LICENSE.txt', 1, '✓', '2024-04-27 10:37:31', 2, 'Component Builder', 'Componentbuilder', 'JCB', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlckhlbHBlckJvdGhd', '', '', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJGFwcF0=', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclBvc3RmbGlnaHRVcGRhdGVdDQpbQ1VTVE9NQ09ERT1kYXRhYmFzZVNjaGVtYUNoZWNrQ2FsbCskYXBwXQ==', 'W0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskYXBwXQ==', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclByZWZsaWdodFVwZGF0ZV0NCltDVVNUT01DT0RFPXBocENvbmZpZ3VyYXRpb25DaGVja0NhbGwrJGFwcF0=', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclJlYWRNZV0=', 1, '', 'Builds Complex Joomla Components', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMSW5zdGFsbF0=', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMVW5pbnN0YWxsXQ==', 'Component Builder (Public)', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', 3, 2, 'https://git.vdm.dev/joomla/Component-Builder/raw/branch/3.x/componentbuilder_update_server.xml', 'https://dev.vdm.io', '', 'AuPSKSfpljRFR8L15MBTyaMykK/qZhUlmcEmwddy7G0=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"0\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\\r\\nuse Joomla\\\\CMS\\\\Session\\\\Session;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\\r\\nuse Joomla\\\\CMS\\\\Session\\\\Session;\",\"power_site_helper\":[]}}', 1, 1218, '', 1, 1), -(3, '', '', '', '', '', '', '', 1, 1, '', 1, '', 1, '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 1, 1, 1, 3, 'Llewellyn van der Merwe', '', 'giz.txt', '', '', 'Deutsche Gesellschaft für International Zusammenarbeit (GIZ) Gmb', '3.5.0', 'Copyright (C) 2015. All Rights Reserved', '2012-06-15 01:19:00', 1, '/DM4B/gNsYQI1djKmChnS9Zk3OadbsxiRZIt2CObOv0=', 'JCABekFYdCb1Jid7QjGQJpkUNhnahz42rnQUKqqdSGc=', '', 'Fweh9P/AReEKLcdjy9FUzKN8w7tEnsX+66Pc7GBhrlo=', '', '', '', 1, '', 'Create Epidemiological Profiles for diseases and risks affecting your company. Detailed information on projected work days lost and costs. Create and edit activities and wellness responses for your workplace. Access to Small Business Modeling. Results displayed by gender. Network with other companies and wellness professionals.\r\n\r\nHaving seen the health priorities for your workforce, the tool outputs projections for how the interventions – which you have designed - are expected to benefit the company financially.\r\n\r\nBenefits are calculated based on the model projecting reductions in workdays lost due to sickness, presenteeism and death.', 'joomla@vdm.io', 1, 'https://vdm.bz/cost-benefit-projection', 'fh5IX0VlAKgp6nBbq0C83HnKqabnAWgoFNIekqjYDaEHw1aQBxWfO/Wz732g2IinutKTaGbTRfMNEsaGdU30Gw==', '', '829cc38c-5a2d-4455-9bc8-8f7129e56f19', 'images/giz.png', '', 'https://github.com/Llewellynvdm/Joomla-Cost-Benefit-Projection', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2022-05-27 05:31:41', 2, 'Cost Benefit Projection', 'costbenefitprojection', '', 2, '', '	public static function userIs($id = null)
	{
		if($id > 0)
		{
			$user = Factory::getUser($id);
		}
		else
		{
			$user = Factory::getUser();
		}
		// get this user groups
		$groups	= (array) $user->getAuthorisedGroups();
		// get params
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		// get target groups
		$countryGroups 			= (array) $params->get('countryuser');
		$serviceproviderGroups		= (array) $params->get('serviceprovideruser');
		$memberGroups 			= (array) $params->get('memberuser');
		// now check in what group this user belongs
		if (array_intersect($countryGroups, $groups))
		{
			// is country
			return 3;
		}
		elseif (array_intersect($serviceproviderGroups, $groups))
		{
			// is serviceprovider
			return 2;
		}
		elseif (array_intersect($memberGroups, $groups))
		{
			// is member
			return 1;
		}
		return false;
	}

	public static function accessCompany($id)
	{
		// check the per value
		$lock = self::getVar('company', $id, 'id', 'per');
		if ( 1 == $lock)
		{
			return true;
		}
		return false;
	}

	public static function checkIntervetionAccess($id, $share = null, $comp = null)
	{
                // set share value if not set
                if (!$share)
                {
                        $share = self::getId('intervention', $id, 'id', 'share');
                }
                // based on shared we set needed values
                switch ($share)
                {
                        case 1:
                        case 2:
                                // get this interventions company (owner)
                                if (!$comp)
                                {
                                        $comp = self::getId('intervention', $id, 'id', 'company');
                                }
                                // get his companies
                                $companies = self::hisCompanies();
                                // get user type
                                $userType = self::userIs();
                        break;
                }
                // based on shared value we will respond
                switch ($share)
                {
                        case 1:
                                // if sharing is 1 only owner may see it
                                if ($userType == 1)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        case 2:
                                // if sharing is 2 only owner and service provider may see it
                               if ($userType == 1 || $userType == 2)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        break;
                }
		return true;
	}

	public static function notHisUsers($id = null)
	{
		// first get all the users to keep
		$keepUsers = self::hisUsers($id);
		if (is_array($keepUsers))
		{
			// return those not to keep
			return self::getIds('id',$keepUsers,'users','id','NOT IN','');
		}
		return false;
	}

	public static function hisUsers($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load himself)
			case 1:
			return array($id);
			break;
			// serves provider (only load companies users that belong to the service provider and himself)
			case 2:
			$companies	= self::hisCompanies($id);
			$keep		= self::getIds('id',$companies,'company','user');
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
			// country (only load companies and service providers that belong to the country)
			case 3:
			$companies	= self::hisCompanies($id);
			$keepC		= self::getIds('id',$companies,'company','user');
			$service	= self::hisServiceProviders($id);
			$keepS		= self::getIds('id',$service,'service_provider','user');
			// merge these values
			$keep		= self::mergeArrays(array($keepC,$keepS));
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
		}
		return false;
	}

	public static function hisCompanies($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load companies that belong to the member)
			case 1:
			return self::getIds('user',$id,'company');
			break;
			// serves provider (only load companies that belong to the service provider)
			case 2:
			return self::getIds('service_provider',self::getIds('user',$id,'service_provider'),'company');
			break;
			// country (only load companies that belong to the country)
			case 3:
			return self::getIds('country',self::getIds('user',$id,'country'),'company');
			break;
		}
		return false;
	}

	public static function hisServiceProviders($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		if (1 == $is) // member
		{
			return self::getIds('user',$id,'company','service_provider');
		}
		elseif (2 == $is) // serves provider
		{
			return array(self::getId('service_provider',$id));
		}
		elseif (3 == $is) // country
		{
			return self::getIds('country',self::getIds('user',$id,'country'),'service_provider');
		}
		return false;
	}

	public static function hisCountries($userId = null, $id = null, $is_type = null)
	{
		if($userId > 0)
		{
			$is = self::userIs($userId);
		}
		elseif($id > 0 && $is_type)
		{
			$userId = self::getId($is_type,$id,'id','user');
			$is = self::userIs($userId);
		}
		else
		{
			$userId = Factory::getUser()->id;
			$is = self::userIs($userId);
		}
		// return in relation
		switch($is)
		{
			// member (only load countries that belong to the member user)
			case 1:
			return self::getIds('user',$userId,'company','country');
			break;
			// serves provider (only load country that belong to the service provider user)
			case 2:
			return array(self::getId('service_provider',$userId,'user','country'));
			break;
			// country (only load contrye that belong to the country user)
			case 3:
			return self::getIds('user',$userId,'country','id');
			break;
		}
		return false;
	}

	public static function hisCurrencies($userId = null, $id = null, $is_type = null)
	{
		$countries = self::hisCountries($userId,$id,$is_type);
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($countries))
		{
			$currencies = array();
			foreach ($countries as $country)
			{
				// get currency id
				$currencies[] = self::getVar('currency', self::getVar('country', $country, 'id', 'currency'), 'codethree', 'id');
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($currencies))
			{
				return $currencies;
			}
		}
		return false;
	}

	public static function currencyDetails($id = false)
	{
		if (!$id)
		{
			$id = self::hisCurrencies();
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($id))
		{
			$ids = array_values($id);
			$id = $id[0];
		}
		if(is_numeric($id))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__costbenefitprojection_currency', 'a'));
			$query->where($db->quoteName('id') . ' = '.(int) $id);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return $db->loadObject();
			}
		}
		return false;
	}
	
	public static function makeMoney($number,$currency = false)
	{
		// first check if we have a number
		if (is_numeric($number))
		{
			// make sure to include the negative finder file
			include_once 'negativefinder.php';
			// check if the number is negative
			$negativeFinderObj = new NegativeFinder(new Expression("$number"));
			$negative = $negativeFinderObj->isItNegative() ? TRUE : FALSE;
		}
		else
		{
			throw new Exception('ERROR! ('.$number.') is not a number!');
		}
		// not setup the currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if(!isset($currency->currency_positivestyle) || !isset($currency->currency_negativestyle) || !isset($currency->currency_decimalplace) || !isset($currency->currency_decimalsymbol) || !isset($currency->currency_symbol))
			{
				if (isset($currency->currency_id))
				{
					$currency = self::currencyDetails($currency->currency_id);
				}
				elseif (isset($currency->id))
				{
					$currency = self::currencyDetails($currency->id);
				}
				else
				{
					$currency = self::currencyDetails();
				}
			}
		}	
		else
		{
			$currency = self::currencyDetails($currency);
		}
		// set the number to currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if (!$negative)
			{
				$format = $currency->currency_positivestyle;
				$sign = '+';
			}
			else 
			{
				$format = $currency->currency_negativestyle;
				$sign = '-';
				$number = abs($number);
			}
			$setupNumber = number_format((float)$number, (int)$currency->currency_decimalplace, $currency->currency_decimalsymbol, ' '); //$currency->currency_thousands TODO);
			$search = array('{sign}', '{number}', '{symbol}');
			$replace = array($sign, $setupNumber, $currency->currency_symbol);
			$moneyMade = str_replace ($search,$replace,$format);

			return $moneyMade;
		}
		return $number;
	}

	public static function getId($table, $where = null , $whereString = 'user', $what = 'id')
	{
		if(!$where)
		{
			$where = Factory::getUser()->id;
		}
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array($what)));
		$query->from($db->quoteName('#__[[[component]]]_'.$table));
		$query->where($db->quoteName($whereString) . ' = '.(int) $where);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}

	public static function getIds($whereString,$where,$table,$what = 'id',$operator = 'IN',$main_ = '[[[component]]]_')
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where) && $where > 0)
		{
			$where = array($where);
		}

		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(array($what)));
			$query->from($db->quoteName('#__'.$main_.$table));
			$query->where($db->quoteName($whereString) . ' '.$operator.' (' . implode(',',$where) . ')');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return array_unique($db->loadColumn());
			}
		}
		return false;
	}

	public static function getCountryName($id)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('name')));
		$query->from($db->quoteName('#__[[[component]]]_country'));
		$query->where($db->quoteName('id') . ' = '.(int) $id);
		$db->setQuery($query);
		return $db->loadResult();
	}
	
	public static function combine($items)
	{
		// make sure the sum class is loaded
		JLoader::import('sumcombine', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
		// return the result
		return new SumCombine($items);
	}

	public static function calculate($id,$data)
	{
		if (base64_encode(base64_decode($data)) === $data){
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5($data);
			$data		= unserialize(base64_decode($data));
		} else {
			// not valid data first get the valid data
			$model		= self::getModel('companydata');
			$data 		= $model->getItem((int)$id);
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5(base64_encode(serialize($data)));
		}
		// set some defaults
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		$path	= $params->get('resultpath', JPATH_ADMINISTRATOR.'/components/com_[[[component]]]/helpers');
		// build full path to file
		$fullPath = $path.'/'.$fileName.'.json';
		// check if file exists
		if (file_exists($fullPath) && (($jsonFile = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($fullPath, FALSE)) !== FALSE))
		{
			// great we are done return results
			return json_decode($jsonFile);
		}
		// do the calculation again
		$result = self::doCalculation($data);
		// did we get a valid result set
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($result) || Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($result))
		{
			// now save for next time
			self::saveJson($result, $fullPath, $path);
			// return result set
			return  json_decode(json_encode($result));
		}
		return false;
	}

	protected static function doCalculation($data)
	{
		// did we get a valid result set
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($data))
		{
			// make sure the sum class is loaded
			JLoader::import('sum', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
			// return the result
			return new Sum($data);
		}
		return false;
	}

	/**
	* Safes json to a file
	*
	* @input	  object/array/json  $data      Data to be stored
	* @input	  string                  $fullPath Full path to file
	* @input	  string                  $path      Full path to folder
	*
	* @returns  boolean on success
	**/
	public static function saveJson($data, $fullPath, $path = __DIR__)
	{
		// check if path exists
		if (!file_exists($path))
		{
			// if not the make the path
			mkdir($path, 0755, true);
		}
		// check that the string is json
		if (!self::isJson($data))
		{
			// json encode if not json
			$data = json_encode($data);
		}
		// make sure this is a string
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data))
		{
			$fp = fopen($fullPath, 'w');
			fwrite($fp, $data);
			fclose($fp);
			return true;
		}
		return false;
	}

	public static function isJson($string)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($string))
		{
			json_decode($string);
			return (json_last_error() === JSON_ERROR_NONE);
		}
		return false;
	}

	public static function setUserHack()
	{
		$files = array(
			0 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/models/users.php',
				'replace' => array(
					"JModelList\n{\n\t/**" => "JModelList\n{\n\t/*\n\t* A VDM hack to restrict users based on user's relation to their component\n\t*\n\t* This just proofs the the hack is inplace\n\t*/\n\tpublic \$restrictUsers = true;\n\n\t/**",
					"\$excluded = json_decode(base64_decode(\$app->input->get('excluded', '', 'BASE64')));" => "\$excluded = json_decode(base64_decode(\$app->input->get('excluded', '', 'BASE64')));\n\t\t// add the global exclude for [[[component]]]\n\t\tif (\$this->restrictUsers && !Factory::getUser()->authorise('core.options', 'com_[[[component]]]'))\n\t\t{\n\t\t\tJLoader::register('[[[Component]]]Helper', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/[[[component]]].php');\n\t\t\t// check if the component is installed\n\t\t\tif (class_exists('[[[Component]]]Helper'))\n\t\t\t{\n\t\t\t\t\$excludedGlobal = [[[Component]]]Helper::notHisUsers();\n\t\t\t\tif (\$excludedGlobal)\n\t\t\t\t{\n\t\t\t\t\t\$excluded = Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::merge(array(\$excludedGlobal,\$excluded));\n\t\t\t\t}\n\t\t\t}\n\t\t}")
			),
			1 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/models/user.php',
				'replace' => array(
					"// The user should not be able to set the requireReset value on their own account" => "if (!Factory::getUser()->authorise('core.admin', 'com_[[[component]]]') && !Factory::getUser()->authorise('core.options', 'com_[[[component]]]'))
		{
			// load our helper class for Cost Benefit Projection Component
			JLoader::register('[[[Component]]]Helper', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/[[[component]]].php');
			// check if the component is installed
			if (class_exists('[[[Component]]]Helper'))
			{
				\$is = [[[Component]]]Helper::userIs();
				switch(\$is)
				{
					case 1:
					case 2:
					case 3:
						// Disable fields for display.
						\$form->removeGroup('params');
						// disable some fields
						\$form->setFieldAttribute('sendEmail', 'disabled', 'true');
						\$form->setFieldAttribute('sendEmail', 'filter', 'unset');
						\$form->removeField('sendEmail');
					break;
				}
			}
		}

		// The user should not be able to set the requireReset value on their own account",
					"\$user->authorise('core.manage', 'com_users')" => "\$user->authorise('core.manage', 'com_users') &&  \$user->authorise('core.options', 'com_[[[component]]]')")
			),
			2 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/controllers/user.php',
				'replace' => array(
					"return parent::allowEdit(\$data, \$key);" => "if (!Factory::getUser()->authorise('core.admin', 'com_[[[component]]]') && !Factory::getUser()->authorise('core.options', 'com_[[[component]]]'))
		{
			// load our helper class for Cost Benefit Projection Component
			JLoader::register('[[[Component]]]Helper', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/[[[component]]].php');
			// check if the component is installed
			if (class_exists('[[[Component]]]Helper'))
			{
				\$hisUsers = [[[Component]]]Helper::hisUsers();
				if (!in_array(\$data[\$key],\$hisUsers))
				{
					return false;
				}
			}
		}

		return parent::allowEdit(\$data, \$key);")
			),
			3 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/views/users/view.html.php',
				'replace' => array(
					"if (\$canDo->get('core.create'))" => "if (\$canDo->get('core.create') && \$user->authorise('core.options', 'com_costbenefitprojection'))")
			),
			4 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/views/users/view.html.php',
				'replace' => array(					
					"// Add a batch button\n\t\tif (\$user->authorise('core.create', 'com_users')" => "// Add a batch button only if user also has admin right in com_costbenefitprojection\n\t\tif (\$user->authorise('core.create', 'com_users')\n\t\t\t&& \$user->authorise('core.options', 'com_costbenefitprojection')")
			)
		);
		// check if hack is still set
		return self::setHack($files);
	}

	protected static function setHack($files)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($files))
		{
			$checking = array();
			// get the file tools
			jimport('joomla.filesystem.file');
			foreach ($files as $file)
			{
				$update = false;
				// get related files
				$actualFile = JFile::read($file['path']);
				// check if hack is still set
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($file['replace']))
				{
					foreach ($file['replace'] as $original => $updateString)
					{
						if (strpos($actualFile,$updateString) === false)
						{
							// set the hack again
							$update = true;
							$actualFile = str_replace($original, $updateString, $actualFile);
						}
					}
				}
				if ($update)
				{
					$done[$file['path']] = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::write($file['path'],$actualFile);
				}
				else
				{
					$done[$file['path']] = true;
				}
			}
			return $done;
		}
		return false;
	}

	protected static function writeFile($path,$data)
	{
		$fh = fopen($path, "w");
		if (!is_resource($fh))
		{
			return false;
		}
		if (fwrite($fh, $data))
		{
			// close file.
			fclose($fh);
			return true;
		}
		// close file.
		fclose($fh);
		return false;
	}

	/**
	* Get CSV Headers
	*/
	public static function getFileHeadersCSV($path)
	{
		// set the headers
		if(($handle = fopen($path, 'r')) !== false)
		{
			$result = fgetcsv($handle);
			fclose($handle);
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($result))
			{
				$key = 'A';
				foreach ($result as $header)
				{
					$headers[$key] = $header;
					$key++;
				}
				return $headers;
			}
		}
		return false;
	}

	/**
	* 	The user notice info File Name
	**/
	protected static $usernotice = false;

	public static function getFilePath($type, $name = 'listing', $key = '', $fileType = '.json', $PATH = JPATH_COMPONENT_SITE)
	{
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::${$type.$name}))
		{
			// Get local key
			$localkey = self::getLocalKey();
			// set the name
			$fileName = md5($type.$name.$localkey.$key);
			// set file path			
			self::${$type.$name} = $PATH.'/helpers/'.$fileName.$fileType;
		}
		// return the path
		return self::${$type.$name};
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = false;
	
	public static function getLocalKey()
	{
		if (!self::$localkey)
		{
			// get the main key
			self::$localkey = md5(Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('basic', 'localKey34fdWEkl'));
		}
		return self::$localkey;
	}', '', '	public static function userIs($id = null)
	{
		if($id > 0)
		{
			$user = Factory::getUser($id);
		}
		else
		{
			$user = Factory::getUser();
		}
		// get this user groups
		$groups	= (array) $user->getAuthorisedGroups();
		// get params
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		// get target groups
		$countryGroups 			= (array) $params->get('countryuser');
		$serviceproviderGroups		= (array) $params->get('serviceprovideruser');
		$memberGroups 			= (array) $params->get('memberuser');
		// now check in what group this user belongs
		if (array_intersect($countryGroups, $groups))
		{
			// is country
			return 3;
		}
		elseif (array_intersect($serviceproviderGroups, $groups))
		{
			// is serviceprovider
			return 2;
		}
		elseif (array_intersect($memberGroups, $groups))
		{
			// is member
			return 1;
		}
		return false;
	}

	public static function checkIntervetionAccess($id, $share = null, $comp = null)
	{
                // set share value if not set
                if (!$share)
                {
                        $share = self::getId('intervention', $id, 'id', 'share');
                }
                // based on shared we set needed values
                switch ($share)
                {
                        case 1:
                        case 2:
                                // get this interventions company (owner)
                                if (!$comp)
                                {
                                        $comp = self::getId('intervention', $id, 'id', 'company');
                                }
                                // get his companies
                                $companies = self::hisCompanies();
                                // get user type
                                $userType = self::userIs();
                        break;
                }
                // based on shared value we will respond
                switch ($share)
                {
                        case 1:
                                // if sharing is 1 only owner may see it
                                if ($userType == 1)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        case 2:
                                // if sharing is 2 only owner and service provider may see it
                               if ($userType == 1 || $userType == 2)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        break;
                }
		return true;
	}

	public static function notHisUsers($id = null)
	{
		// first get all the users to keep
		$keepUsers = self::hisUsers($id);
		if (is_array($keepUsers))
		{
			// return those not to keep
			return self::getIds('id',$keepUsers,'users','id','NOT IN','');
		}
		return false;
	}

	public static function hisUsers($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load himself)
			case 1:
			return array($id);
			break;
			// serves provider (only load companies users that belong to the service provider and himself)
			case 2:
			$companies	= self::hisCompanies($id);
			$keep		= self::getIds('id',$companies,'company','user');
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
			// country (only load companies and service providers that belong to the country)
			case 3:
			$companies	= self::hisCompanies($id);
			$keepC		= self::getIds('id',$companies,'company','user');
			$service	= self::hisServiceProviders($id);
			$keepS		= self::getIds('id',$service,'service_provider','user');
			// merge these values
			$keep		= self::mergeArrays(array($keepC,$keepS));
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
		}
		return false;
	}

	public static function hisCompanies($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load companies that belong to the member)
			case 1:
			return self::getIds('user',$id,'company');
			break;
			// serves provider (only load companies that belong to the service provider)
			case 2:
			return self::getIds('service_provider',self::getIds('user',$id,'service_provider'),'company');
			break;
			// country (only load companies that belong to the country)
			case 3:
			return self::getIds('country',self::getIds('user',$id,'country'),'company');
			break;
		}
		return false;
	}

	public static function hisServiceProviders($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		if (1 == $is) // member
		{
			return self::getIds('user',$id,'company','service_provider');
		}
		elseif (2 == $is) // serves provider
		{
			return array(self::getId('service_provider',$id));
		}
		elseif (3 == $is) // country
		{
			return self::getIds('country',self::getIds('user',$id,'country'),'service_provider');
		}
		return false;
	}

	public static function hisCountries($userId = null, $id = null, $is_type = null)
	{
		if($userId > 0)
		{
			$is = self::userIs($userId);
		}
		elseif($id > 0 && $is_type)
		{
			$userId = self::getId($is_type,$id,'id','user');
			$is = self::userIs($userId);
		}
		else
		{
			$userId = Factory::getUser()->id;
			$is = self::userIs($userId);
		}
		// return in relation
		switch($is)
		{
			// member (only load countries that belong to the member user)
			case 1:
			return self::getIds('user',$userId,'company','country');
			break;
			// serves provider (only load country that belong to the service provider user)
			case 2:
			return array(self::getId('service_provider',$userId,'user','country'));
			break;
			// country (only load contrye that belong to the country user)
			case 3:
			return self::getIds('user',$userId,'country','id');
			break;
		}
		return false;
	}

	public static function hisCurrencies($userId = null, $id = null, $is_type = null)
	{
		$countries = self::hisCountries($userId,$id,$is_type);
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($countries))
		{
			$currencies = array();
			foreach ($countries as $country)
			{
				// get currency id
				$currencies[] = self::getVar('currency', self::getVar('country', $country, 'id', 'currency'), 'codethree', 'id');
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($currencies))
			{
				return $currencies;
			}
		}
		return false;
	}

	public static function currencyDetails($id = false)
	{
		if (!$id)
		{
			$id = self::hisCurrencies();
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($id))
		{
			$ids = array_values($id);
			$id = $id[0];
		}
		if(is_numeric($id))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			$query->where($db->quoteName('id') . ' = '.(int) $id);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return $db->loadObject();
			}
		}
		return false;
	}
	
	public static function makeMoney($number,$currency = false)
	{
		// first check if we have a number
		if (is_numeric($number))
		{
			// make sure to include the negative finder file
			include_once 'negativefinder.php';
			// check if the number is negative
			$negativeFinderObj = new NegativeFinder(new Expression("$number"));
			$negative = $negativeFinderObj->isItNegative() ? TRUE : FALSE;
		}
		else
		{
			throw new Exception('ERROR! ('.$number.') is not a number!');
		}
		// not setup the currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if(!isset($currency->currency_positivestyle) || !isset($currency->currency_negativestyle) || !isset($currency->currency_decimalplace) || !isset($currency->currency_decimalsymbol) || !isset($currency->currency_symbol))
			{
				if (isset($currency->currency_id))
				{
					$currency = self::currencyDetails($currency->currency_id);
				}
				elseif (isset($currency->id))
				{
					$currency = self::currencyDetails($currency->id);
				}
				else
				{
					$currency = self::currencyDetails();
				}
			}
		}	
		else
		{
			$currency = self::currencyDetails($currency);
		}
		// set the number to currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if (!$negative)
			{
				$format = $currency->currency_positivestyle;
				$sign = '+';
			}
			else 
			{
				$format = $currency->currency_negativestyle;
				$sign = '-';
				$number = abs($number);
			}
			$setupNumber = number_format((float)$number, (int)$currency->currency_decimalplace, $currency->currency_decimalsymbol, ' '); //$currency->currency_thousands TODO);
			$search = array('{sign}', '{number}', '{symbol}');
			$replace = array($sign, $setupNumber, $currency->currency_symbol);
			$moneyMade = str_replace ($search,$replace,$format);

			return $moneyMade;
		}
		return $number;
	}

	public static function getCauseRiskDetails($id,$details = null)
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($details))
		{
			$details = array('name','alias','description','ref');
		}
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName($details));
		$query->from($db->quoteName('#__[[[component]]]_causerisk'));
		$query->where($db->quoteName('id') . ' = '.(int) $id);
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadObject();
		}
		return false;
	}

	public static function getId($table, $where = null , $whereString = 'user', $what = 'id')
	{
		if(!$where)
		{
			$where = Factory::getUser()->id;
		}
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array($what)));
		$query->from($db->quoteName('#__[[[component]]]_'.$table));
		$query->where($db->quoteName($whereString) . ' = '.(int) $where);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}

	public static function getIds($whereString,$where,$table,$what = 'id',$operator = 'IN',$main_ = '[[[component]]]_')
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where) && $where > 0)
		{
			$where = array($where);
		}

		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(array($what)));
			$query->from($db->quoteName('#__'.$main_.$table));
			$query->where($db->quoteName($whereString) . ' '.$operator.' (' . implode(',',$where) . ')');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return array_unique($db->loadColumn());
			}
		}
		return false;
	}

	public static function getCountryName($id)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('name')));
		$query->from($db->quoteName('#__[[[component]]]_country'));
		$query->where($db->quoteName('id') . ' = '.(int) $id);
		$db->setQuery($query);
		return $db->loadResult();
	}
	
	public static function combine($items)
	{
		// make sure the sum class is loaded
		JLoader::import('sumcombine', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
		// return the result
		return new SumCombine($items);
	}

	public static function calculate($id,$data)
	{
		if (base64_encode(base64_decode($data)) === $data){
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5($data);
			$data		= unserialize(base64_decode($data));
		} else {
			// not valid data first get the valid data
			$model		= self::getModel('companydata');
			$data 		= $model->getItem((int)$id);
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5(base64_encode(serialize($data)));
		}
		// set some defaults
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		$path	= $params->get('resultpath', JPATH_ADMINISTRATOR.'/components/com_[[[component]]]/helpers');
		// build full path to file
		$fullPath = $path.'/'.$fileName.'.json';
		// check if file exists
		if (file_exists($fullPath) && (($jsonFile = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($fullPath, FALSE)) !== FALSE))
		{
			// great we are done return results
			return json_decode($jsonFile);
		}
		// do the calculation again
		$result = self::doCalculation($data);
		// did we get a valid result set
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($result) || Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($result))
		{
			// now save for next time
			self::saveJson($result, $fullPath, $path);
			// return result set
			return  json_decode(json_encode($result));
		}
		return false;
	}

	protected static function doCalculation($data)
	{
		// did we get a valid result set
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($data))
		{
			// make sure the sum class is loaded
			JLoader::import('sum', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
			// return the result
			return new Sum($data);
		}
		return false;
	}

	public static function saveJson($data, $fullPath, $path = __DIR__)
	{
		// check if path exists
		if (!file_exists($path))
		{
			// if not the make the path
			mkdir($path, 0755, true);
		}
		// check that the string is json
		if (!self::isJson($data))
		{
			// json encode if not json
			$data = json_encode($data);
		}
		// make sure this is a string
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data))
		{
			$fp = fopen($fullPath, 'w');
			fwrite($fp, $data);
			fclose($fp);
			return true;
		}
		return false;
	}

	public static function isJson($string)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($string))
		{
			json_decode($string);
			return (json_last_error() === JSON_ERROR_NONE);
		}
		return false;
	}

	/**
	 *	set groups names
	 */
	public static function setGroupNames($groups)
	{
		// change array of group ids to string of group names
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			$groupsNames = array();
			foreach ($groups as $group)
			{
				$groupsNames[] = self::getGroupName($group);
			}
			return implode(', ',$groupsNames);
		}
		return '';
	}', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXShodHRwczovL3Jhdy5naXRodWJ1c2VyY29udGVudC5jb20vbmFtaWJpYS9DQlAtSm9vbWxhLTMtQ29tcG9uZW50L21hc3Rlci9hZG1pbi9hc3NldHMvaW1hZ2VzL3ZkbS1jb21wb25lbnQucG5nICJUaGUgIyMjQ29tcG9uZW50X25hbWUjIyMiKQ0KDQojIyNERVNDUklQVElPTiMjIw0KDQojIFJlcXVpcmVtZW50cw0KDQpEdWUgdG8gdGhlIHNpemUgb2YgdGhlIHBlcm1pc3Npb25hbCBzdHJ1Y3R1cmUsIHlvdSB3aWxsIG5lZWQgdG8gaW5jcmVhc2UgbWF4X2lucHV0X3ZhcnMgdW50aWwgdGhlIHBlcm1pc3Npb25zIGFyZSBhYmxlIHRvIHNhdmUuDQpgYGANCm1heF9pbnB1dF92YXJzID0gNTAwMA0KYGBgDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10oaHR0cHM6Ly93d3cuc3RhZmZoZWFsdGhjYnAuY29tLykNCisgKkF1dGhvcio6IFsjIyNBVVRIT1IjIyNdKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdKGh0dHBzOi8vd3d3LnN0YWZmaGVhbHRoY2JwLmNvbS8pDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3LnZkbS5pby9qb29tbGEtY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbyk=', '', '', 'Cost Benefit Projection Tool.', '', '', 'Cost Benefit Projection (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/Llewellynvdm/Joomla-Cost-Benefit-Projection/master/costbenefitprojection_update_server.xml', 'http://www.vdm.io', '', 'KF4DOoTG/SbAenJVZ+C70b8v2mo/9AGoHRUZn38fNjGbD5l8WbBkTcAJsbhGhgenVlLqlgMCYhDPW1id2M7vdg==', 'http://www.vdm.io/access/', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 229, '', 1, 6), -(4, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '3.0.2', 'Copyright (C) 2014. All Rights Reserved', '2015-07-16 21:16:17', '', '', '', '', '', '', '', '', 1, '', 'Adding PHP/JS/CSS to your joomla articles and modules has never been so easy!', 'joomla@vdm.io', '', '', 'ikiTKPjL3OpNgd4GSy83H6r6AqvvqqJL3eq1OJcbwZY=', '', '79cd73b9-3989-4e44-ad15-4c8e44fe272e', 'images/vdm/codebox500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2017-08-17 21:48:57', 1, 'Code Box', 'codebox', '', 4, '', '', '', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKSA=', '', '', 'Adding PHP/JS/CSS', '', '', 'Code Box', '', '', '', 1, '', 'http://www.vdm.io/joomla', '', '614dod0JnHfCW3c4CWFarRBQIwKacNEPkOsMoRdEfjY=', '', '', 1, 20, '', 1, 3), -(5, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'default.txt', '', '', 'Vast Development Method', '1.0.5', 'Copyright (C) 2015. All Rights Reserved', '2015-08-05 00:40:06', '', 'fJ8k5rxm0gLeNHfPfCHRUdLna4XdjaIF6J2QAv6Jd4M=', 'sQUMRQJ3xdXI2mZ/01zGerfPjyaNSu+2B/qqqGPboCg=', '', 'Q1plhG96+yqMLlJnmvFINIm6j3X6XnOLfhnre4pAcZU=', '', '', '', 1, '', 'Just a basic demo of the most basic implementations of the [Joomla] (http://www.joomla.org) Component Builder\'s ability.', 'info@vdm.io', '', 'http://vdm.bz/get-advance-demo-key', 'Arlr/PFBJ+vUM2vgEoMU6IyzriNLJ8dfZQZ39QyPL4pAVL02VyXNvoMUo8M3q0wV', '', 'ec2c3e36-e2b1-4bab-842d-bd0f9d07ea00', 'images/vdm/demo500.jpg', '', 'https://github.com/vdm-io/JCB-Packages/raw/master/JCB_demoAdvanced.zip', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2020-11-17 17:18:18', '', 'Demo', 'demo', '', 4, '', '', '', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIVsjIyNDb21wb25lbnRfbmFtZSMjIyBpbWFnZV0gKGh0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9uYW1pYmlhL2RlbW8tam9vbWxhLTMtY29tcG9uZW50L21hc3Rlci9hZG1pbi9hc3NldHMvaW1hZ2VzL3ZkbS1jb21wb25lbnQuanBnICJUaGUgIyMjQ29tcG9uZW50X25hbWUjIyMiKQ0KDQojIyNERVNDUklQVElPTiMjIw0KDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10gKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXSAobWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10gKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCg0KIyMgQnVpbGQgVGltZQ0KDQoqKiMjI3RvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI3RvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKiAoYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzYXZlZCAtDQpkdWUgdG8gW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0gKGh0dHBzOi8vd3d3LnZkbS5pby9qb29tbGEtY29tcG9uZW50LWJ1aWxkZXIpKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdIChodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0gKG1haWx0bzpqb29tbGFAdmRtLmlvKQ0KDQpbQ1VTVE9NQ09ERT1yZWFkTUVjb250cmlidXRvcnNd', '', '', 'Demo Component', '', '', 'Demo - advanced (public)', '.git', '', 1, 1, 'https://www.vdm.io/updates/demo_update_server.xml', 'https://www.vdm.io/', '', 'WNVXyWZW/ISgKhNT6u/2tJuir0CX7eM+kOhmLyGdh7g=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 33, '', 1, 8), -(7, 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, 1, '{}', 3, 1, 2, 3, 'Llewellyn van der Merwe', '', 'member.txt', '', '', 'Joomla Component Builder', '2.1.0', 'Copyright (C) 2015. All Rights Reserved', '2018-07-06 07:11:12', 1, '68wV5f9XVz3GHqOVYxj2taJbVlf8VAuydrJiTerSRcg=', 'v9x/NUXzZ3Sr0jujcwzSi9+vLlW825igzyKS8VKSa6Q=', '', 'g9p4Kk67OAYDRed7Ci4v96amxeN72DdzI6dVt/P+KyI=', '', 'LmZpZWxkLWNhbGVuZGFyIGlucHV0IHsNCglmb250OmNhcHRpb24gIWltcG9ydGFudDsNCn0=', 'A_177', 2, '', 'A [Members manager](https://github.com/vdm-io/Joomla-Members-Manager) to use as a base for any kind of project that needs user integration. You can with much ease adapt it using the [JCB package](https://github.com/vdm-io/JCB-Community-Packages/raw/master/JCB_membersManager.zip).\r\n\r\nWatch this [tutorial](https://youtu.be/lkE0ZiSWufg) to see how.', 'joomla@vdm.io', '', 'https://vdm.bz/how-to-get-free-vdm-package-keys', 'kBdRTTE3bIx3bSYH77nanyPGPm4sktWK6zWiZjaXbb3bJ1at45ns37DLeH17pszTwEqgwZR2kfYWVsHgDbu5vA==', '', '40130d87-591c-4f8a-b0ba-62c65fa2ec5d', 'images/membermanager300.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Members-Manager', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '★', '2021-03-08 03:19:07', 2, 'Members Manager', 'membersmanager', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9bWVtYmVybWFuYWdlckhlbHBlckJvdGhdDQoJLyoqDQoJICogQ2FuIGEgbWVtYmVyIGFjY2VzcyBhbm90aGVyIG1lbWJlcidzIGRhdGENCgkgKg0KCSAqIEBwYXJhbSAgIG1peCAgICAgICRtZW1iZXIgICAgVGhlIHRoZSBtZW1iZXIgYmVpbmcgYWNjZXNzZWQNCgkgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRvIGRvIGEgZHluYW1pYyBnZXQgb2YgbWVtYmVyIElEIHVzZSB0aGUgZm9sbG93aW5nIGFycmF5DQoJICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhcnJheSggdGFibGUsIHdoZXJlLCB3aGVyZVN0cmluZywgd2hhdCkNCgkgKiBAcGFyYW0gICBhcnJheSAgICAkdHlwZXMgICAgIFRoZSB0eXBlIG9mIG1lbWJlciBiZWluZyBhY2Nlc3NlZA0KCSAqIEBwYXJhbSAgIG1peCAgICAgICR1c2VyICAgICAgVGhlIGFjdGl2ZSB1c2VyDQoJICogQHBhcmFtICAgb2JqZWN0ICAgJGRiICAgICAgICBUaGUgZGF0YWJhc2Ugb2JqZWN0DQoJICoNCgkgKiBAcmV0dXJuICBib29sIHRydWUgb2YgY2FuIGFjY2Vzcw0KCSAqDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBjYW5BY2Nlc3NNZW1iZXIoJG1lbWJlciA9IG51bGwsICR0eXBlcyA9IG51bGwsICR1c2VyID0gbnVsbCwgJGRiID0gbnVsbCkNCgl7DQoJCS8vIGhlcmUgeW91IGNhbiBkbyB5b3VyIG93biBjdXN0b20gdmFsaWRhdGlvbg0KCQlyZXR1cm4gdHJ1ZTsNCgl9', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoSk1NKQ0KWyFbR2l0SHViIHJlbGVhc2VdKGh0dHBzOi8vaW1nLnNoaWVsZHMuaW8vZ2l0aHViL3JlbGVhc2UvbGxld2VsbHludmRtL0pvb21sYS1NZW1iZXJzLU1hbmFnZXIuc3ZnKV0oaHR0cHM6Ly9naXRodWIuY29tL2xsZXdlbGx5bnZkbS9Kb29tbGEtTWVtYmVycy1NYW5hZ2VyL3JlbGVhc2VzKQ0KDQogIVtNZW1iZXJzIE1hbmFnZXIgaW1hZ2VdKGh0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9sbGV3ZWxseW52ZG0vSm9vbWxhLU1lbWJlcnMtTWFuYWdlci9tYXN0ZXIvYWRtaW4vYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlIE1lbWJlcnMgTWFuYWdlciIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IG5ldmVyIG1ha2luZyBvbmUgbWlzdGFrZSBvciB0YWtpbmcgYW55IGNvZmZlZSBicmVhay4pDQoNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCioqIyMjYWN0dWFsSG91cnNTcGVudCMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsRGF5c1NwZW50IyMjIEVpZ2h0IEhvdXIgRGF5cyoqICh0aGUgYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzcGVudCkNCg0KPiAod2l0aCB0aGUgZm9sbG93aW5nIGJyZWFrIGRvd246DQo+ICoqZGVidWdnaW5nIEAjIyNkZWJ1Z2dpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNDsNCj4gKipwbGFubmluZyBAIyMjcGxhbm5pbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNzsNCj4gKiptYXBwaW5nIEAjIyNtYXBwaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDEwOw0KPiAqKm9mZmljZSBAIyMjb2ZmaWNlSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDY7KQ0KDQoqKiMjI2FjdHVhbFRvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbFRvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKg0KKGEgdG90YWwgb2YgdGhlIHJlYWxpc3RpYyB0aW1lIGZyYW1lIGZvciB0aGlzIHByb2plY3QpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IHdpdGggdGhlIG5vcm1hbCBldmVyeWRheSByZWFsaXRpZXMgYXQgdGhlIG9mZmljZSwgdGhhdCBpbmNsdWRlcyB0aGUgY29tcG9uZW50IHBsYW5uaW5nLCBtYXBwaW5nICYgZGVidWdnaW5nLikNCg0KUHJvamVjdCBkdXJhdGlvbjogKiojIyNwcm9qZWN0V2Vla1RpbWUjIyMgd2Vla3MqKiBvciAqKiMjI3Byb2plY3RNb250aFRpbWUjIyMgbW9udGhzKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KW0NVU1RPTUNPREU9cmVhZE1FY29udHJpYnV0b3JzXQ==', '', '', 'Members Manager', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGAgKA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTsNCg0KQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbl9tYXBgICgNCglgcmVsYXRpb25gIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTs=', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGA7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3JlbGF0aW9uX21hcGA7', 'Members Manager (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/llewellynvdm/Joomla-Members-Manager/master/membersmanager_server.xml', 'https://www.joomlacomponentbuilder.com/', '', 'mwbQuahJB22SvquixI5MRucHYJFNOn2yLIUdF2q/9wU=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 243, '', 1, 49), -(8, '', 1, '', '', '', 1, '', '', 1, 1, '', 1, '', '', '', 1, '', 1, '', 1, '', '', '', '', 1, '{}', 1, 1, 2, 3, 'Llewellyn van der Merwe', '/var/www/sermondistributor_j3', 'SD.txt', '', '', 'Vast Development Method', '3.0.4', 'Copyright (C) 2015. All Rights Reserved', '2015-10-22 16:59:20', '', 'ZKUukroWwDG76wW55dhuJx1syv/siy0FTMf+luh7V7E=', 'uKEL3D/OAqh3fm21KTakHQMlMHJywXvPgRQmRSWb/28=', '', 'ntJ42FGYUvbPqWaIIj5uFAtmIrKbUk+LNtcmjE2ptuQ=', '', '', '', 1, '', 'Distributor is a highly advanced sermon distributor that runs on the [Joomla 3.x](http://www.joomla.org) framework. You can link a shared folder from Dropbox to the component and use Dropbox as your file host, not to mention the advanced auto builder that gives you the ability to simply load sermons to your website by only adding them to Dropbox.', 'joomla@vdm.io', 1, 'http://vdm.bz/get-sermon-distributor-key', 'dS20XbfUACMfeeeKiURfZJAuxLcOZ8HT6pQQzWhg0LsaP4JEn2B4/s9+PLBHV+QjgKJ6grZntqY+ltqzNgVAVQ==', '/var/git_', '11b41fbe-26e2-4257-a987-5b1278784539', 'images/vdm/SD500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Sermon-Distributor', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-03-07 13:39:29', 2, 'Sermon Distributor', 'sermondistributor', 'TrueChristianChurch', 4, '', '', '	/**
	* 	The global params
	**/
	protected static $params = false;

	/**
	* 	Update Watcher
	**/
	public static $updateWatch = 1;

	/**
	* 	Update Watcher (if array is only one value)
	**/
	public static $updateWatch_ = 0;

	/**
	* 	The external source links auto
	**/
	protected static $links_externalsource_auto;

	/**
	* 	The external source links manual
	**/
	protected static $links_externalsource_manual;

	/**
	* 	The external source selection auto
	**/
	protected static $select_externalsource_auto;

	/**
	* 	The external source selection manual
	**/
	protected static $select_externalsource_manual;

	/**
	* 	The update errors
	**/
	protected static $updateErrors = array();
[CUSTOMCODE=baseSixtyFourURL]
	/**
	* 	get Download links of a sermon
	**/
	public static function getDownloadLinks(&$sermon)
	{
		$links = array();
		// Get local key
		$localkey = self::getLocalKey();
		// decrypt the urls
		$safe = new FOFEncryptAes($localkey, 128);
		// internal download url
		$keyCounter = new \stdClass;
		$keyCounter->sermon = $sermon->id;
		if ($sermon->preacher)
		{
			$keyCounter->preacher = $sermon->preacher;
		}
		if ($sermon->series)
		{
			$keyCounter->series = $sermon->series;
		}
		$keyCounterRAW = $safe->encryptString(json_encode($keyCounter));
		$keyCounter = self::base64_urlencode($keyCounterRAW);
		$token = Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
		$downloadURL = Uri::root().'index.php?option=com_[[[component]]]&task=download.file&key='.$keyCounter.'&token='.$token;
		// check if local .htaccess should be set
		$setHtaccess = false;
		$onclick = ' onclick="sermonCounter(\''.$keyCounterRAW.'\',\'FILENAME\');"';
		// check what source of our link
		switch ($sermon->source)
		{
			case 1:
				// local file get local folder and check if outside root (if not then allow direct)
				$localFolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('localfolder', JPATH_ROOT.'/images').'/';
				// should we allow direct downloads
				$allowDirect = false;
				if (2 == $sermon->link_type && strpos($localFolder, JPATH_ROOT) !== false)
				{
					$allowDirect = true;
					$localFolderURL = Uri::root().str_replace(JPATH_ROOT, '', $localFolder);
					// insure no double // is in the URL
					$localFolderURL = str_replace('//', '/', $localFolderURL);
					$localFolderURL = str_replace(':/', '://', $localFolderURL);
				}
				// insure no double // is in the path name
				$localFolder = str_replace('//', '/', $localFolder);
				$localFolder = str_replace(':/', '://', $localFolder);
				if (self::checkArray($sermon->local_files))
				{
					foreach($sermon->local_files as $key)
					{
						if (1 == $sermon->link_type || !$allowDirect)
						{
							// get the file name use the same method as the auto
							$filename = self::getDownloadFileName($sermon,$key,'local');
							$lockedFolderPath = $safe->encryptString($localFolder.$key);
							$sermon->download_links[$filename] = $downloadURL.'&link='.self::base64_urlencode($lockedFolderPath).'&filename='.$filename;
							$sermon->onclick[$filename] = '';
						}
						elseif (2 == $sermon->link_type && $allowDirect)
						{
							$filename = $key;
							$sermon->download_links[$filename] = $localFolderURL.$key;
							$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							$setHtaccess = true;
						}
					}
				}
				break;
			case 2:
				// Dropbox get global dropbox switch 
				$addToButton = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('add_to_button', 0);
				if (1 == $sermon->build)
				{
					if (self::checkArray($sermon->manual_files))
					{
						// manual dropbox
						foreach($sermon->manual_files as $key)
						{
							// get the link
							$dropURL = self::getExternalSourceLink('manual',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name use the same method as the auto
								$filename = self::getDownloadFileName($sermon,$key,'dropbox_manual');
								// should we encrypt string this string
								if ('localKey34fdWEkl' == $localkey || (base64_encode(base64_decode($dropURL, true)) !== $dropURL)) // hmmm no global key has been set
								{
									$dropURL = $safe->encryptString($dropURL);
								}
								// lock the info key
								$infoKey = $safe->encryptString($key);
								$sermon->download_links[$filename] = $downloadURL.'&info='.self::base64_urlencode($infoKey).'&link='.self::base64_urlencode($dropURL).'&filename='.$filename;
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$filename = str_replace('VDM_pLeK_h0uEr/', '', $key);
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->download_links[$filename] = $dropURL;
								}
								else
								{
									$sermon->download_links[$filename] = rtrim($safe->decryptString($dropURL), "\0");
								}
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $addToButton && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', $dropURL);
								}
								else
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString($dropURL), "\0"));
								}
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				elseif (2 == $sermon->build)
				{
					if (self::checkArray($sermon->auto_sermons))
					{
						// automatic dropbox
						foreach($sermon->auto_sermons as $filename => $key)
						{
							// get the link
							$dropURL = self::getExternalSourceLink('auto',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// should we encrypt string this string
								if ('localKey34fdWEkl' == $localkey || (base64_encode(base64_decode($dropURL, true)) !== $dropURL)) // hmmm no global key has been set
								{
									$dropURL = $safe->encryptString($dropURL);
								}
								// lock the info key
								$infoKey = $safe->encryptString($key);
								$sermon->download_links[$filename] = $downloadURL.'&info='.self::base64_urlencode($infoKey).'&link='.self::base64_urlencode($dropURL).'&filename='.$filename;
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->download_links[$filename] = $dropURL;
								}
								else
								{
									$sermon->download_links[$filename] = rtrim($safe->decryptString($dropURL), "\0");
								}
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $addToButton && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', $dropURL);
								}
								else
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString($dropURL), "\0"));
								}
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				break;
			case 3:
				// url get the file name use the same method as the auto
				$filename = self::getDownloadFileName($sermon,$sermon->url,'url');
				if (1 == $sermon->link_type)
				{
					$lockedURL = $safe->encryptString($sermon->url);
					$sermon->download_links[$filename] = $downloadURL.'&link='.self::base64_urlencode($lockedURL).'&filename='.$filename;
					$sermon->onclick[$filename] = '';
				}
				elseif (2 == $sermon->link_type)
				{
					$sermon->download_links[$filename] = $sermon->url;
					$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
				}
				break;
		}
		// remove the values no longer needed
		unset($sermon->local_files);
		unset($sermon->manual_files);
		unset($sermon->auto_sermons);
		unset($sermon->url);
		// should we set the local .htaccess for the download folder
		if ($setHtaccess)
		{
			// TODO we may need to add this latter to enforce download of files.
		}
		return true;
	}

	public static function getNextUpdateValues($asArray = false)
	{
		// find the next value
		$next = false;
		// get actual update values
		$updates = self::getExternalListingUpdateKeys();
		// get last update
		$updatePath = self::getFilePath('path', 'updatelast', 'txt', 'vDm', JPATH_COMPONENT_ADMINISTRATOR);
		if (($lastUpdate = @file_get_contents($updatePath)) !== FALSE && self::checkArray($updates))
		{
			// is it time to watch
			if (self::$updateWatch_ > 0)
			{
				// increment the watch, as this is the start of new round
				self::$updateWatch++;
				// new round has started
				self::$updateWatch_ = 0;
			}
			// now check what is next
			$lastKey = array_search($lastUpdate, $updates);
			if (!is_null($lastKey))
			{
				$nextKey = $lastKey + 1;
				if (isset($updates[$nextKey]))
				{
					$next = $updates[$nextKey];
				}
				else
				{
					// last item in array, so next round about to start
					self::$updateWatch_++;
				}
			}
		}
		// rest and start with the first key
		if (!$next && self::checkArray($updates))
		{
			// save the first set
			$start = reset($updates);
			$next = $start;
		}
		// save to file if next is found
		if ($next)
		{
			self::writeFile($updatePath,$next);
			// convert to array of needed
			if ($asArray)
			{
				if (strpos($next, ',') !== false)
				{
					$next = array_map('trim', explode(',', $next));
				}
				else
				{
					return false;
				}
			}
		}
		return $next;
	}
[CUSTOMCODE=getFilePath]
[CUSTOMCODE=writeFile]
	protected static function saveFile($data, $path_filename)
	{
		return self::writeFile($path_filename, $data);
	}

	public static function getExternalListingUpdateKeys($id = null, $updateMethod = 2, $returnType = 1)
	{
		// first check if this file already has statistics
		$db = Joomla___39403062_84fb_46e0_bac4_0023f766e827___Power::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('id','sharedurl','folder','permissiontype','dropboxoptions','build')));
		$query->from($db->quoteName('#__[[[component]]]_external_source'));
		if ($updateMethod && is_numeric($updateMethod))
		{
			$query->where($db->quoteName('update_method') . ' = '. (int) $updateMethod);
		}
		if ($id && is_numeric($id))
		{
			$query->where($db->quoteName('id') . ' = '. (int) $id);
		}
		elseif ($id && self::checkArray($id))
		{
			$ids = implode(',', array_map( 'intval', $id));
			$query->where($db->quoteName('id') . ' IN  (' . $ids . ')');
		}
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$results = $db->loadObjectList();
			$updates = array();
			foreach ($results as $result)
			{
				if ('full' == $result->permissiontype)
				{
					// load folder or urls
					switch ($result->dropboxoptions)
					{
						case 1: // sharedurl
							if (self::checkJson($result->sharedurl))
							{
								$targets = json_decode($result->sharedurl)->tsharedurl;
							}
						break;
						case 2: // folders
							if (self::checkJson($result->folder))
							{
								$targets = json_decode($result->folder)->tfolder;
							}
						break;
					}
					if (self::checkArray($targets))
					{
						foreach ($targets as $key => $value)
						{
							$nr = $key + 1;
							// id, target, type
							if (1 == $returnType)
							{
								$updates[] = $result->id . ', '. $nr . ', ' . $result->build;
							}
							else // only return the targets
							{
								$updates[] = $nr;
							}
						}
					}
				}
				else
				{
					// id, target, type
					if (1 == $returnType)
					{
						$updates[] = $result->id . ', 1, '. $result->build;
					}
					else // only return the targets
					{
						$updates[] = 1;
					}
				}
			}
			return $updates;
		}
		return false;
	}

	public static function getExternalSourceLink($type, $return = 7, $get = false, $target = 'links')
	{
		// make sure all defaults are set
		$found = self::checkExternalSourceLocalListing($type, $target);
		if ($found)
		{
			switch($return)
			{
				case 1:
					// return a link
					if (isset(self::${$target.'_externalsource_'.$type}[$get]))
					{
						return self::${$target.'_externalsource_'.$type}[$get];
					}
					break;
				case 2:
					// return all links
					return self::${$target.'_externalsource_'.$type};
					break;
				default :
					// just confirm that it is set
					return true;
					break;
			}
		}
		return false;
	}

	public static function countDownload($counter, $filename)
	{
		// Get local key
		$localkey = self::getLocalKey();
		$opener = new FOFEncryptAes($localkey, 128);
		$counter = json_decode(rtrim($opener->decryptString($counter), "\0"));
		if (self::checkObject($counter))
		{
			$counter->filename = $filename;
			// set the date object
			$date = Joomla___39403062_84fb_46e0_bac4_0023f766e827___Power::getDate();
			// first check if this file already has statistics
			$db = Joomla___39403062_84fb_46e0_bac4_0023f766e827___Power::getDbo();
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('id','counter')));
			$query->from($db->quoteName('#__[[[component]]]_statistic'));
			$query->where($db->quoteName('sermon') . ' = '. (int) $counter->sermon);
			$query->where($db->quoteName('filename') . ' = '. $db->quote($counter->filename));
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$statistic = $db->loadObject();
				// already has an entry
				$statistic->counter++;
				$statistic->modified = $date->toSql();
				// update the entry
				return $db->updateObject('#__[[[component]]]_statistic', $statistic, 'id');
			}
			else
			{
				// set a new entry
				$counter->counter = 1;
				$counter->published = 1;
				$counter->created = $date->toSql();
				$counter->access = 1;
				$counter->version = 1;
				// set a new entry
				$done = $db->insertObject('#__[[[component]]]_statistic', $counter);
				// if done return last used id
				if ($done)
				{
					$newId =  $db->insertid();
					// make sure the access of asset is set
					return self::setAsset($newId,'statistic');
				}
			}
		}
		return false;
	}

	public static function getFileInfo($key)
	{
		if (self::checkString($key) && (base64_encode(base64_decode($key, true)) === $key))
		{
			// Get local key
			$localkey = self::getLocalKey();
			$opener = new FOFEncryptAes($localkey, 128);
			$key = rtrim($opener->decryptString($key), "\0");
			// load the links from the database
			$db = Joomla___39403062_84fb_46e0_bac4_0023f766e827___Power::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select('size');
			$query->from($db->quoteName('#__[[[component]]]_local_listing'));
			$query->where($db->quoteName('key') . ' = '. $db->quote($key));
 			// Reset the query using our newly populated query object.
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$info = array();
				// get the size of the file
				$info['filesize'] = $db->loadResult();
				// get the mime type
				$info['type'] = Super___f11dc790_713e_4706_9a85_a318ed3ad56e___Power::mimeType($key);
				// return info
				return $info;
			}
		}
		return false;
	}

	protected static function getDownloadFileName(&$sermon, $file, $type)
	{
		// first get file name and file type
		$file = str_replace('VDM_pLeK_h0uEr/', '', $file);
		$fileType = pathinfo($file, PATHINFO_EXTENSION);
		if ($fileType)
		{
			$file = str_replace('.'.$fileType, '', $file);
		}
		else
		{
			$fileType = 'error';
		}
		// now build download name
		$downloadName = array();
		// build the Download File Name - first add the preacher name if set
		if ($sermon->preacher)
		{
			$downloadName[] = self::safeString($sermon->preacher_name,'U');
		}
		// add the series name if set
		if ($sermon->series)
		{
			$downloadName[] = self::safeString($sermon->series_name,'F');
		}
		// add the category name if set
		if ($sermon->catid && self::checkString($sermon->category))
		{
			$downloadName[] = self::safeString($sermon->category, 'F');
		}
		if ('dropbox_manual' == $type || 'local' == $type)
		{
			// add the main file name
			$downloadName[] = self::safeString($sermon->name,'F');
			$downloadName[] = self::safeString($file,'F');
		}
		else
		{
			$downloadName[] = self::safeString($sermon->name,'F');
			if ('error' == $fileType || strpos('?', $fileType) !== false || strpos('&', $fileType) !== false )
			{
				$fileType = 'mp3'; // TODO we don't know the url filetype (setting to mp3 but this could be wrong)
			}
		}
		// now build the download file name
		return implode('__', $downloadName).'.'.$fileType;
	}

	/**
	* 	check External Source Local Listing (do we have the files)
	**/
	public static function checkExternalSourceLocalListing($type, $get = 'links')
	{
		// get the local links
		if (isset(self::${$get.'_externalsource_'.$type}) && self::checkArray(self::${$get.'_externalsource_'.$type}))
		{
			// return true we have links loaded
			return true;
		}
		else
		{
			$target = array('links' => 'url', 'select' => 'name');
			$build = array( 'auto' => 2, 'manual' => 1);
			if (isset($build[$type]))
			{
				// load the links from the database
				$db = Joomla___39403062_84fb_46e0_bac4_0023f766e827___Power::getDbo();
				// Create a new query object.
				$query = $db->getQuery(true);
				$query->select($db->quoteName(array('key', $target[$get])));
				$query->from($db->quoteName('#__[[[component]]]_local_listing'));
				$query->where($db->quoteName('build') . ' = '. (int) $build[$type]);
				$query->where($db->quoteName('published') . ' = 1'); // TODO we can now limit the links to access groups
 				// Reset the query using our newly populated query object.
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					self::${$get.'_externalsource_'.$type} = $db->loadAssocList('key', $target[$get]);
					// return true we have links loaded
					return true;
				}
			}
		}
		return false;
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = array();
	
	public static function getLocalKey($type = 'basic_key')
	{
		if (!isset(self::$localkey[$type]))
		{
			// get the main key
			self::$localkey[$type] = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get($type, 'localKey34fdWEkl');
		}
		return self::$localkey[$type];
	}

	public static function updateExternalSource($id, $target = 0, $type = false, $force = false, $sleutel = null)
	{
		$source = self::getVar('external_source', (int) $id, 'id', 'externalsources');
		if (1 == $source) // Dropbox is the source
		{
			// load the file
			JLoader::import('dropboxupdater', JPATH_COMPONENT_SITE.'/helpers');
			// update types
			$types = array('manual','auto');
			// okay now update this type
			if (self::checkString($type) && in_array($type,$types))
			{
				$dropbox = new Dropboxupdater();
				if ($dropbox->update($id, $target, $type, $force, $sleutel))
				{
					return true;
				}
				self::setUpdateError($id, $dropbox->getErrors());
				return false;
			}
		}
		self::setUpdateError($id, array(Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('The external source could not be found.')));
		return false;
	}

	public static function getSourceStatus($id)
	{
		// fist get errors if any is found
		$errors = array();
		if ($targets = self::getExternalListingUpdateKeys($id, null, 1))
		{
			foreach ($targets as $target)
			{
				$key = preg_replace('/[ ,]+/', '', trim($target));
				if ($error = self::getUpdateError(0, $key))
				{
					$errors[] = $error;
				}
			}
		}
		// check when was the last update
		$updateInfo = self::updateInfo($id);
		if (!$updateInfo)
		{
			$errors[] = Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('This source has no local listing set.');
		}
		// build the return string
		if (isset($updateInfo['last']) || self::checkArray($errors))
		{
			$body = array();
			// great we have source status
			if (isset($updateInfo['last']))
			{
				$body[] = '<h3>'. Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('Listing Info') . '</h3>';
				$body[] = '<p><b>'. Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('Last Update') . ':</b> <em>'.$updateInfo['last'];
				$body[] = '</em><br /><b>'. Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('Number of Files Listed') . ':</b> <em>'.$updateInfo['qty'];
				$body[] = '</em></p>';
			}
			// now set any errors found
			if (self::checkArray($errors))
			{
				$body[] = '<h3>'. Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('Notice!') . '</h3>';
				$body[] = implode('', $errors);
			}
			return '<a class="btn btn-small btn-success" href="#source-status'.$id.'" data-toggle="modal">'.Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('View Update Status').'</a>' 
				. Joomla___34690c75_1090_47eb_8c06_7228dc7eedd6___Power::_('bootstrap.renderModal', 'source-status'.$id, array('title' => Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('Source Status Report.')), implode('', $body));
		}
 		// no status found
		return false;
	}

	public static function updateInfo($id)
	{
		$db = Joomla___39403062_84fb_46e0_bac4_0023f766e827___Power::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('a.created','a.modified')));
		$query->from($db->quoteName('#__[[[component]]]_local_listing', 'a'));
		$query->where($db->quoteName('a.external_source') . ' = ' . (int) $id);
 		// Reset the query using our newly populated query object.
		$db->setQuery($query);
		$db->execute();
		if ($qty = $db->getNumRows())
		{
			$data = $db->loadRowList();
			$last = 0;
			foreach ($data as $dates)
			{
				foreach ($dates as $date)
				{
					$time = strtotime($date);
					if ($time > $last)
					{
						$last = $time;
					}
				}
			}
			$info['qty'] = (int) $qty;
			$info['last'] = self::fancyDate($last);
			return $info;
		}
		return false;
	}

	public static function getUpdateError($id, $fileKey = null)
	{
		// get update error from file
		if ($fileKey)
		{
			$file_path = self::getFilePath('path', 'updateerror', 'txt', $fileKey, JPATH_COMPONENT_ADMINISTRATOR);
			// check if it is set
			if (($text = @file_get_contents($file_path)) !== FALSE)
			{
				// no error on success
				if ('success' != $text)
				{
					return $text;
				}
			}
			return false;
		}
		elseif (isset(self::$updateErrors[$id]) && self::checkArray(self::$updateErrors[$id]))
		{
			return '<ul><li>'.implode('</li><li>', self::$updateErrors[$id]).'</li></ul>';
		}
		return Joomla___ba6326ef_cb79_4348_80f4_ab086082e3c5___Power::_('Unknown error has occurred.');
	}

	protected static function setUpdateError($id, $errorArray)
	{
		if (self::checkArray($errorArray) && $id > 0)
		{
			foreach ($errorArray as $error)
			{
				if (!isset(self::$updateErrors[$id]))
				{
					self::$updateErrors[$id] = array();
				}
				self::$updateErrors[$id][] = $error;
			}
		}
	}
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=curlWorkerHelper]
[CUSTOMCODE=locker]', '', '', '', 'CQkJLy8gY2hlY2sgaWYgYW55IGxpbmtzIHdlcmUgZm91bmQNCgkJCWlmICgoaXNzZXQoJHRoaXMtPnVwZGF0ZVRhcmdldHNVKSAmJiBbW1tDb21wb25lbnRdXV1IZWxwZXI6OmNoZWNrQXJyYXkoJHRoaXMtPnVwZGF0ZVRhcmdldHNVKSkgfHwgKGlzc2V0KCR0aGlzLT51cGRhdGVUYXJnZXRzRikgJiYgW1tbQ29tcG9uZW50XV1dSGVscGVyOjpjaGVja0FycmF5KCR0aGlzLT51cGRhdGVUYXJnZXRzRikpKQ0KCQkJew0KCQkJCS8vIEdldCBhIGRiIGNvbm5lY3Rpb24uDQoJCQkJJGRiID0gSm9vbWxhX19fMzk0MDMwNjJfODRmYl80NmUwX2JhYzRfMDAyM2Y3NjZlODI3X19fUG93ZXI6OmdldERibygpOw0KDQoJCQkJLy8gZ2V0IHRoZSBmaWxlIHR5cGVzDQoJCQkJJGRyb3Bib3hfZmlsZXR5cGVzID0gJHRoaXMtPmNvbVBhcmFtcy0+Z2V0KCJkcm9wYm94X2ZpbGV0eXBlcyIsIG51bGwpOw0KDQoJCQkJLy8gc29tZSBkZWZhdWx0cw0KCQkJCSR1c2VyID0gSm9vbWxhX19fMzk0MDMwNjJfODRmYl80NmUwX2JhYzRfMDAyM2Y3NjZlODI3X19fUG93ZXI6OmdldFVzZXIoKTsNCgkJCQkkdG9kYXlEYXRlID0gSm9vbWxhX19fMzk0MDMwNjJfODRmYl80NmUwX2JhYzRfMDAyM2Y3NjZlODI3X19fUG93ZXI6OmdldERhdGUoKS0+dG9TcWwoKTsNCg0KCQkJCS8vIG5vdyBzdG9yZSB0aGUgb2xkIGRhdGEgdG8gdGhlIG5ldyBhcmVhDQoJCQkJaWYgKGlzc2V0KCR0aGlzLT51cGRhdGVUYXJnZXRzVSkgJiZbW1tDb21wb25lbnRdXV1IZWxwZXI6OmNoZWNrQXJyYXkoJHRoaXMtPnVwZGF0ZVRhcmdldHNVKSkNCgkJCQl7DQoJCQkJCWZvcmVhY2ggKCR0aGlzLT51cGRhdGVUYXJnZXRzVSBhcyAkdHlwZSA9PiAkdXJscykNCgkJCQkJew0KCQkJCQkJJGRlc2NyaXB0aW9uID0gJ0NvbmZpZyAnLiAkdHlwZSAuICcgdXJsICc7DQoJCQkJCQkkYnVpbGRPcHRpb24gPSAxOw0KCQkJCQkJaWYgKCdhdXRvJyA9PSAkdHlwZSkNCgkJCQkJCXsNCgkJCQkJCQkkYnVpbGRPcHRpb24gPSAyOw0KCQkJCQkJfQ0KCQkJCQkJJHVybHMgPSAnIicuaW1wbG9kZSgnIiwgIicsICR1cmxzKS4nIic7DQoJCQkJCQkkZGF0YSA9IG5ldyBcc3RkQ2xhc3MoKTsNCgkJCQkJCWlmIChbW1tDb21wb25lbnRdXV1IZWxwZXI6OmNoZWNrQXJyYXkoJGRyb3Bib3hfZmlsZXR5cGVzKSkNCgkJCQkJCXsNCgkJCQkJCQkkZGF0YS0+ZmlsZXR5cGVzID0ganNvbl9lbmNvZGUoJGRyb3Bib3hfZmlsZXR5cGVzKTsNCgkJCQkJCX0NCgkJCQkJCSRkYXRhLT5leHRlcm5hbHNvdXJjZXMgPSAxOw0KCQkJCQkJJGRhdGEtPmJ1aWxkID0gJGJ1aWxkT3B0aW9uOw0KCQkJCQkJJGRhdGEtPmRlc2NyaXB0aW9uID0gJGRlc2NyaXB0aW9uOw0KCQkJCQkJJGRhdGEtPnVwZGF0ZV9tZXRob2QgPSAxOw0KCQkJCQkJJGRhdGEtPnVwZGF0ZV90aW1lciA9IDA7DQoJCQkJCQkkZGF0YS0+cGVybWlzc2lvbnR5cGUgPSAnZnVsbCc7DQoJCQkJCQkkZGF0YS0+Y3JlYXRlZCA9ICR0b2RheURhdGU7DQoJCQkJCQkkZGF0YS0+Y3JlYXRlZF9ieSA9ICR1c2VyLT5pZDsNCgkJCQkJCSRkYXRhLT5zaGFyZWR1cmwgPSAneyJ0c2hhcmVkdXJsIjpbJy4kdXJscy4nXX0nOw0KCQkJCQkJLy8gYWRkIHRvIGRhdGFiYXNlDQoJCQkJCQlpZiAoJGRiLT5pbnNlcnRPYmplY3QoJyNfX1tbW2NvbXBvbmVudF1dXV9leHRlcm5hbF9zb3VyY2UnLCAkZGF0YSkpDQoJCQkJCQl7DQoJCQkJCQkJJGFJZCA9ICRkYi0+aW5zZXJ0aWQoKTsNCgkJCQkJCQkvLyBtYWtlIHN1cmUgdGhlIGFjY2VzcyBvZiBhc3NldCBpcyBzZXQNCgkJCQkJCQlbW1tDb21wb25lbnRdXV1IZWxwZXI6OnNldEFzc2V0KCRhSWQsJ2V4dGVybmFsX3NvdXJjZScpOw0KCQkJCQkJfQ0KCQkJCQl9DQoJCQkJfQ0KCQkJCWlmIChpc3NldCgkdGhpcy0+dXBkYXRlVGFyZ2V0c0YpICYmIFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6Y2hlY2tBcnJheSgkdGhpcy0+dXBkYXRlVGFyZ2V0c0YpKQ0KCQkJCXsNCgkJCQkJZm9yZWFjaCAoJHRoaXMtPnVwZGF0ZVRhcmdldHNGIGFzICR0eXBlID0+ICRmb2xkZXIpDQoJCQkJCXsNCgkJCQkJCSRkZXNjcmlwdGlvbiA9ICdDb25maWcgJy4gJHR5cGUgLiAnIGZvbGRlciAnOw0KCQkJCQkJJGJ1aWxkT3B0aW9uID0gMTsNCgkJCQkJCWlmICgnYXV0bycgPT0gJHR5cGUpDQoJCQkJCQl7DQoJCQkJCQkJJGJ1aWxkT3B0aW9uID0gMjsNCgkJCQkJCX0NCgkJCQkJCSRmb2xkZXIgPSAnIicuaW1wbG9kZSgnIiwgIicsICRmb2xkZXIpLiciJzsNCgkJCQkJCSRkYXRhID0gbmV3IFxzdGRDbGFzcygpOw0KCQkJCQkJaWYgKFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6Y2hlY2tBcnJheSgkZHJvcGJveF9maWxldHlwZXMpKQ0KCQkJCQkJew0KCQkJCQkJCSRkYXRhLT5maWxldHlwZXMgPSBqc29uX2VuY29kZSgkZHJvcGJveF9maWxldHlwZXMpOw0KCQkJCQkJfQ0KCQkJCQkJJGRhdGEtPmV4dGVybmFsc291cmNlcyA9IDE7DQoJCQkJCQkkZGF0YS0+YnVpbGQgPSAkYnVpbGRPcHRpb247DQoJCQkJCQkkZGF0YS0+ZGVzY3JpcHRpb24gPSAkZGVzY3JpcHRpb247DQoJCQkJCQkkZGF0YS0+dXBkYXRlX21ldGhvZCA9IDE7DQoJCQkJCQkkZGF0YS0+dXBkYXRlX3RpbWVyID0gMDsNCgkJCQkJCSRkYXRhLT5wZXJtaXNzaW9udHlwZSA9ICdmdWxsJzsNCgkJCQkJCSRkYXRhLT5jcmVhdGVkID0gJHRvZGF5RGF0ZTsNCgkJCQkJCSRkYXRhLT5jcmVhdGVkX2J5ID0gJHVzZXItPmlkOw0KCQkJCQkJJGRhdGEtPmZvbGRlciA9ICd7InRmb2xkZXIiOlsnLiRmb2xkZXIuJ119JzsNCgkJCQkJCS8vIGFkZCB0byBkYXRhYmFzZQ0KCQkJCQkJaWYgKCRkYi0+aW5zZXJ0T2JqZWN0KCcjX19bW1tjb21wb25lbnRdXV1fZXh0ZXJuYWxfc291cmNlJywgJGRhdGEpKQ0KCQkJCQkJew0KCQkJCQkJCSRhSWQgPSAkZGItPmluc2VydGlkKCk7DQoJCQkJCQkJLy8gbWFrZSBzdXJlIHRoZSBhY2Nlc3Mgb2YgYXNzZXQgaXMgc2V0DQoJCQkJCQkJW1tbQ29tcG9uZW50XV1dSGVscGVyOjpzZXRBc3NldCgkYUlkLCdleHRlcm5hbF9zb3VyY2UnKTsNCgkJCQkJCX0NCgkJCQkJfQ0KCQkJCX0NCgkJCQkvLyBHZXQgQXBwbGljYXRpb24gb2JqZWN0DQoJCQkJJGFwcCA9IEpvb21sYV9fXzM5NDAzMDYyXzg0ZmJfNDZlMF9iYWM0XzAwMjNmNzY2ZTgyN19fX1Bvd2VyOjpnZXRBcHBsaWNhdGlvbigpOw0KCQkJCSRhcHAtPmVucXVldWVNZXNzYWdlKCdZb3VyIERyb3Bib3ggaW50ZWdyYXRpb24gaGFzIGJlZW4gbW92ZWQsIGFuZCBjYW4gbm93IGJlIHZpZXdlZCBhdCB0aGUgbmV3IGV4dGVybmFsIHNvdXJjZSB2aWV3LiBZb3Ugd2lsbCBub3cgbmVlZCBhbiBBUFAgdG9rZW4gdG8gdXBkYXRlIHlvdXIgbG9jYWwgbGlzdGluZyBvZiB0aGUgRHJvcGJveCBmaWxlcy4gUGxlYXNlIHJldmlldyB0aGUgV2lraSB0YWIgd2hlbiBjcmVhdGluZy9lZGl0aW5nIHRoZSBleHRlcm5hbCBzb3VyY2UsIG9yIG9wZW4gYW4gaXNzdWUgb24gZ2l0aHViIGlmIHlvdSBleHBlcmllbmNlIGFueSBtb3JlIGRpZmZpY3VsdGllcy4nLCAnSW5mbycpOw0KCQkJfQ==', '', 'CQkvLyBsb2FkIHRoZSBoZWxwZXIgY2xhc3MNCgkJSkxvYWRlcjo6cmVnaXN0ZXIoJ1tbW0NvbXBvbmVudF1dXUhlbHBlcicsIEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX1tbW2NvbXBvbmVudF1dXS9oZWxwZXJzL1tbW2NvbXBvbmVudF1dXS5waHAnKTsNCgkJLy8gY2hlY2sgdGhlIHZlcnNpb24gb2YgU2VybW9uIERpc3RyaWJ1dG9yDQoJCSRtYW5pZmVzdCA9IFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6bWFuaWZlc3QoKTsNCgkJaWYgKGlzc2V0KCRtYW5pZmVzdC0+dmVyc2lvbikgJiYgc3RycG9zKCRtYW5pZmVzdC0+dmVyc2lvbiwgJy4nKSAhPT0gZmFsc2UpDQoJCXsNCgkJCSR2ZXJzaW9uID0gZXhwbG9kZSgnLicsICRtYW5pZmVzdC0+dmVyc2lvbik7DQoJCQkvLyBHZXQgYSBkYiBjb25uZWN0aW9uLg0KCQkJJGRiID0gSm9vbWxhX19fMzk0MDMwNjJfODRmYl80NmUwX2JhYzRfMDAyM2Y3NjZlODI3X19fUG93ZXI6OmdldERibygpOw0KCQkJaWYgKCR2ZXJzaW9uWzBdID09IDEgJiYgJHZlcnNpb25bMV0gPCA0KQ0KCQkJew0KCQkJCS8vIENyZWF0ZSBhIG5ldyBxdWVyeSBvYmplY3QuDQoJCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCgkJCQkvLyB1cGRhdGUgYWxsIG1hbnVhbCBhbmQgYXV0byBsaW5rcyBpbiBzZXJtb25zDQoJCQkJJHF1ZXJ5LT5zZWxlY3QoJGRiLT5xdW90ZU5hbWUoYXJyYXkoJ2lkJywgJ21hbnVhbF9maWxlcycpKSk7DQoJCQkJJHF1ZXJ5LT5mcm9tKCRkYi0+cXVvdGVOYW1lKCcjX19bW1tjb21wb25lbnRdXV1fc2VybW9uJykpOw0KCQkJCSRxdWVyeS0+d2hlcmUoJGRiLT5xdW90ZU5hbWUoJ3NvdXJjZScpIC4gJyA9IDInKTsNCgkJCQkvLyBSZXNldCB0aGUgcXVlcnkgdXNpbmcgb3VyIG5ld2x5IHBvcHVsYXRlZCBxdWVyeSBvYmplY3QuDQoJCQkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkJCSRkYi0+ZXhlY3V0ZSgpOw0KCQkJCWlmICgkZGItPmdldE51bVJvd3MoKSkNCgkJCQl7DQoJCQkJCSRyb3dzID0gJGRiLT5sb2FkQXNzb2NMaXN0KCdpZCcsICdtYW51YWxfZmlsZXMnKTsNCgkJCQkJZm9yZWFjaCAoJHJvd3MgYXMgJGlkID0+ICRmaWxlcykNCgkJCQkJew0KCQkJCQkJaWYgKFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6Y2hlY2tKc29uKCRmaWxlcykpDQoJCQkJCQl7DQoJCQkJCQkJJGZpbGVzID0ganNvbl9kZWNvZGUoJGZpbGVzLCB0cnVlKTsNCgkJCQkJCQlpZiAoW1tbQ29tcG9uZW50XV1dSGVscGVyOjpjaGVja0FycmF5KCRmaWxlcykpDQoJCQkJCQkJew0KCQkJCQkJCQlmb3JlYWNoICgkZmlsZXMgYXMgJG5yID0+ICYkZmlsZSkNCgkJCQkJCQkJew0KCQkJCQkJCQkJJHRtcCA9IHN0cl9yZXBsYWNlKCdWRE1fcExlS19oMHVFci8nLCAnJywgJGZpbGUpOw0KCQkJCQkJCQkJJG5ldyA9IHN0cnRvbG93ZXIoJHRtcCk7DQoJCQkJCQkJCQkvLyBub3cgdXBkYXRlIHRoZSBmaWxlDQoJCQkJCQkJCQkkZmlsZSA9IHN0cl9yZXBsYWNlKCR0bXAsICRuZXcsICRmaWxlKTsNCgkJCQkJCQkJfQ0KCQkJCQkJCX0NCgkJCQkJCX0NCgkJCQkJCS8vIG9ubHkgdXBkYXRlIGlmIGl0IHdhcyBmaXhlZA0KCQkJCQkJaWYgKFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6Y2hlY2tBcnJheSgkZmlsZXMpKQ0KCQkJCQkJew0KCQkJCQkJCSRvYmplY3QgPSBuZXcgXHN0ZENsYXNzKCk7DQoJCQkJCQkJLy8gbWFrZSBzdXJlIHRoZSBmaWxlcyBhcmUgc2V0IHRvIGpzb24NCgkJCQkJCQkkb2JqZWN0LT5tYW51YWxfZmlsZXMgPSBqc29uX2VuY29kZSgkZmlsZXMpOw0KCQkJCQkJCSRvYmplY3QtPmlkID0gJGlkOw0KCQkJCQkJCUpvb21sYV9fXzM5NDAzMDYyXzg0ZmJfNDZlMF9iYWM0XzAwMjNmNzY2ZTgyN19fX1Bvd2VyOjpnZXREYm8oKS0+dXBkYXRlT2JqZWN0KCcjX19bW1tjb21wb25lbnRdXV1fc2VybW9uJywgJG9iamVjdCwgJ2lkJyk7DQoJCQkJCQl9DQoJCQkJCX0NCgkJCQl9DQoJCQkJLy8gZG8gYW4gdXBkYXRlIGJ5IG1vdmluZyBjb25maWcgZGF0YSB0byB0aGUgbmV3IGV4dGVybmFsIHNvdXJjZSBhcmVhLg0KCQkJCSR0aGlzLT5jb21QYXJhbXMgPSBKb29tbGFfX19hZWI4ZTQ2M18yOTFmXzQ0NDVfOWFjNF8zNGI2MzdjMTJkYmRfX19Qb3dlcjo6Z2V0UGFyYW1zKCdjb21fW1tbY29tcG9uZW50XV1dJyk7DQoJCQkJLy8gdGhlIG51bWJlciBvZiBsaW5rcw0KCQkJCSRudW1iZXJzID0gcmFuZ2UoMSwgNCk7DQoJCQkJLy8gdGhlIHR5cGVzIG9mIGxpbmtzDQoJCQkJJHR5cGVzID0gYXJyYXkoJ2F1dG8nLCdtYW51YWwnKTsNCgkJCQkvLyB0aGUgdXBkYXRlIHRhcmdldHMNCgkJCQkkdGhpcy0+dXBkYXRlVGFyZ2V0c1UgPSBhcnJheSgpOw0KCQkJCSR0aGlzLT51cGRhdGVUYXJnZXRzRiA9IGFycmF5KCk7DQoJCQkJLy8gZ2V0IGFsbCBsaXN0ZWQgdGFyZ2V0cyBiYXN0IG9uIHR5cGUNCgkJCQlmb3JlYWNoICgkdHlwZXMgYXMgJHR5cGUpDQoJCQkJew0KCQkJCQkvLyBub3cgY2hlY2sgaWYgdGhleSBhcmUgc2V0DQoJCQkJCWZvcmVhY2ggKCRudW1iZXJzIGFzICRudW1iZXIpDQoJCQkJCXsNCgkJCQkJCS8vIHNldCB0aGUgbnVtYmVyIHRvIHN0cmluZw0KCQkJCQkJJG51bVN0ciA9IFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6c2FmZVN0cmluZygkbnVtYmVyKTsNCgkJCQkJCS8vIEdldCB0aGUgdXJsDQoJCQkJCQkkdXJsID0gJHRoaXMtPmNvbVBhcmFtcy0+Z2V0KCR0eXBlLidkcm9wYm94Jy4kbnVtU3RyLCBudWxsKTsNCgkJCQkJCS8vIG9ubHkgbG9hZCB0aG9zZSB0aGF0IGFyZSBzZXQNCgkJCQkJCWlmICgkdXJsICYmIFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6Y2hlY2tTdHJpbmcoJHVybCkpDQoJCQkJCQl7DQoJCQkJCQkJaWYgKCFpc3NldCgkdGhpcy0+dXBkYXRlVGFyZ2V0c1VbJHR5cGVdKSkNCgkJCQkJCQl7DQoJCQkJCQkJCSR0aGlzLT51cGRhdGVUYXJnZXRzVVskdHlwZV0gPSBhcnJheSgpOw0KCQkJCQkJCX0NCgkJCQkJCQkkdGhpcy0+dXBkYXRlVGFyZ2V0c1VbJHR5cGVdW10gPSAkdXJsOw0KCQkJCQkJfQ0KCQkJCQkJLy8gR2V0IHRoZSBmb2xkZXJzIGlmIHNldA0KCQkJCQkJJGZvbGRlciA9ICR0aGlzLT5jb21QYXJhbXMtPmdldCgkdHlwZS4nZHJvcGJveGZvbGRlcicuJG51bVN0ciwgbnVsbCk7DQoJCQkJCQkvLyBvbmx5IGxvYWQgdGhvc2UgdGhhdCBhcmUgc2V0DQoJCQkJCQlpZiAoJGZvbGRlciAmJiBbW1tDb21wb25lbnRdXV1IZWxwZXI6OmNoZWNrU3RyaW5nKCRmb2xkZXIpKQ0KCQkJCQkJew0KCQkJCQkJCWlmICghaXNzZXQoJHRoaXMtPnVwZGF0ZVRhcmdldHNGWyR0eXBlXSkpDQoJCQkJCQkJew0KCQkJCQkJCQkkdGhpcy0+dXBkYXRlVGFyZ2V0c0ZbJHR5cGVdID0gYXJyYXkoKTsNCgkJCQkJCQl9DQoJCQkJCQkJJHRoaXMtPnVwZGF0ZVRhcmdldHNGWyR0eXBlXVtdID0gJGZvbGRlcjsNCgkJCQkJCX0NCgkJCQkJfQ0KCQkJCX0NCgkJCX0NCgkJCS8vIHRhcmdldCB2ZXJzaW9uIGxlc3MgdGhlbiBvciBlcXVhbCB0byAyLjAuMg0KCQkJaWYgKGNvdW50KCR2ZXJzaW9uKSA9PSAzICYmICgkdmVyc2lvblswXSA9PSAyICYmICR2ZXJzaW9uWzFdID09IDAgJiYgJHZlcnNpb25bMl0gPD0gMykgfHwgICgkdmVyc2lvblswXSA8IDIpKQ0KCQkJew0KCQkJCS8vIHdlIG5lZWQgdG8gbWFrZSBhIGRhdGFiYXNlIGNvcnJlY3Rpb24NCgkJCQkkZml4X2NhdGVnb3JpZXMgPSBhcnJheSgNCgkJCQkJJ2NvbV9zZXJtb25kaXN0cmlidXRvci5zZXJtb25zJyA9PiAnY29tX3Nlcm1vbmRpc3RyaWJ1dG9yLnNlcm1vbicNCgkJCQkpOw0KW0NVU1RPTUNPREU9Zml4Q2F0ZWdvcmllc05hbWluZ10NCgkJCX0NCgkJfQ==', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vZ2l0LnZkbS5kZXYvY2hyaXN0aWFuL0pvb21sYS1TZXJtb24tRGlzdHJpYnV0b3IvcmF3L2JyYW5jaC9tYXN0ZXIvYWRtaW4vYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KVGhlIGJlc3Qgd2F5IHRvIHNlZSBhbGwgeW91ciBvcHRpb25zIGlzIHRvIGluc3RhbGwgdGhpcyBjb21wb25lbnQgb24geW91IEpvb21sYSB3ZWJzaXRlIGFuZCB0ZXN0IGFsbCBmZWF0dXJlcyB5b3Vyc2VsZi4gSGVyZSBpcyBhIFtkaXJlY3QgZG93bmxvYWQgbGlua10oaHR0cHM6Ly9naXQudmRtLmRldi9jaHJpc3RpYW4vSm9vbWxhLVNlcm1vbi1EaXN0cmlidXRvci9hcmNoaXZlL21hc3Rlci56aXApDQoNCiAqKklmIHlvdSBsaWtlIG91ciBjb21wb25lbnQgcGxlYXNlIHJhdGUgaXQgb24gdGhlIFtKb29tbGEgSW5kZXhdKGh0dHA6Ly9leHRlbnNpb25zLmpvb21sYS5vcmcvZXh0ZW5zaW9ucy9leHRlbnNpb24vbGl2aW5nL3JlbGlnaW9uL3Nlcm1vbi1kaXN0cmlidXRvcikqKg0KDQojIyMgRXhhbXBsZSBXZWJzaXRlLCBUaGF0IEhhcyBPdmVyIDYwMDAgQXVkaW8gRmlsZXMNCg0KW0xvdWRWb2ljZS5vcmddKGh0dHA6Ly93d3cubG91ZHZvaWNlLm9yZykNCltUcnVlQ2hyaXN0aWFuLkNodXJjaF0oaHR0cHM6Ly90cnVlY2hyaXN0aWFuLmNodXJjaC8pDQoNCiMjIyBTb21lIFZpZGVvIERlbW9uc3RyYXRpb25zDQoNCisgW1NldHVwIG92ZXJ2aWV3XShodHRwczovL3lvdXR1LmJlL3lNUHAxQ3AzV18wP3Q9MjBtOHMpDQorIFtTZXR1cCBEcm9wYm94XShodHRwczovL3lvdXR1LmJlL2J0cEtGRGswLWRJKQ0KDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkF1dGhvcio6IFsjIyNBVVRIT1IjIyNdKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCg0KIyMgQnVpbGQgVGltZSA6aG91cmdsYXNzOg0KDQoqKiMjI3RvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI3RvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKiAoYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzYXZlZCAtDQpkdWUgdG8gW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmxsZXdlbGx5bkBqb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSk=', 1, '', 'A sermon distributor that links to Dropbox.', '', '', 'SermonDistributor (public)', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', '', 2, 'https://git.vdm.dev/christian/Joomla-Sermon-Distributor/raw/branch/3.x/sermondistributor_update_server.xml', 'https://www.vdm.io/', '', 'wYUPtkF7wf9oElDwxV+wpc7+8d1dEbx+60+sCitHg6I=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_site_helper\":[]}}', 1, 456, '', 1, 51), -(9, '', 1, '', '', '', 1, '', '', '', 1, '', 1, '', '', 1, 1, 1, 1, '', 1, '', '', 1, '', 1, '{\"addcontributors0\":{\"name\":\"CrossWire\",\"title\":\"Modules\",\"email\":\"sword-support@crosswire.org\",\"website\":\"https:\\/\\/wiki.crosswire.org\\/\",\"use\":\"2\",\"show\":\"3\"}}', 3, 1, 3, 2, 'Llewellyn van der Merwe', '/var/www/getbible_j3', 'getBible.txt', '', '', 'Vast Development Method', '3.0.9', 'Copyright (C) 2015. All Rights Reserved', '2015-12-03 01:42:15', '', 'WhakPvjCkWnGdctg/smdT6v066C5C4LVSQEB6mI8IUY=', 'ufh7xN30c2gDeh3Ond+j0avLsgeYmHCznjyggIFu9II=', '', 'jfhmfXB1y7wL18HAkAe05yoha/QmICC3BDTbmW8LcnY=', '', '', '', 1, '', 'Welcome to the next level of scripture engagement - The Bible for Joomla! Our purpose is to bring the Word of God to every person, in their native language, entirely free. This isn\'t just a typical extension; it\'s a groundbreaking tool developed to span language divides and deliver a rich, customizable Bible study experience to users worldwide.\r\n\r\nWith an impressive array of 80 translations, our Joomla extension allows people from all corners of the globe to read, comprehend, and meditate on the Holy Scriptures in their preferred language. Moreover, we offer the unique opportunity for individuals to host the Bible on their own website, further extending the reach of the Word.\r\n\r\nWe\'ve integrated robust features such as note-taking, tagging, and a search function, to enhance your interaction with the Scriptures. This allows users to immerse themselves in the text, crafting a personal journey through the Bible that can be revisited in future sessions. Furthermore, our innovative linker system assigns each visitor a unique identifier (GUID) - no login required. This means you can create notes, select favorite verses, and even share sessions, while maintaining control over your personalized content.\r\n\r\nA distinctive feature of our application is the integration with OpenAI. This advanced capability allows website owners to create custom prompts to interact with OpenAI using text from any translation. This function allows you to ask questions, gain clarity, and deepen your understanding of the Scriptures in an engaging and user-friendly manner.\r\n\r\nIn essence, The Bible for Joomla is designed to transform how the Word of God is shared, studied, and comprehended. Its comprehensive features, combined with a user-friendly interface, make it an essential tool for individuals, churches, and website owners alike. Join us on this journey of faith as we make the wisdom and guidance of the Scriptures accessible to all, one verse, one language, and one website at a time.', 'joomla@vdm.io', '', 'https://vdm.bz/get-bible', 'p80zGYsGeHr9dMLJ3A4I1NFtH/rbsPznXzsY6dSKtUM=', '/var/git_', '294267c5-bcf9-4b61-b462-af2364e0358b', 'images/getBible.jpg', '', 'https://git.vdm.dev/getBible/joomla-component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-04-25 15:35:03', '', 'Get Bible', 'Getbible', 'TrueChristianChurch', 4, '', '', 'CS8qKg0KCSAqIExvYWQgdGhlIHNjcmlwdHVyZSBpbnRvIGNvbnRlbnQNCgkgKg0KCSAqIEBwYXJhbSAgIG9iamVjdCAgICYkcm93ICAgICBUaGUgYXJ0aWNsZSBvYmplY3QuICBOb3RlICRhcnRpY2xlLT50ZXh0IGlzIGFsc28gYXZhaWxhYmxlDQoJICogQHBhcmFtICAgb2JqZWN0ICAgJHBsdWdpbiAgIFRoZSBwbHVnaW4gcGFyYW1zDQoJICoNCgkgKiBAcmV0dXJuICB2b2lkDQoJICogQHNpbmNlICAgMi4wLjENCgkgKiovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBsb2FkU2NyaXB0dXJlKG9iamVjdCAmJHJvdywgb2JqZWN0ICRwbHVnaW4pOiB2b2lkDQoJew0KCQkvLyBnZXQgY2FsbCBzdHJpbmcNCgkJJGNhbGxfY2xhc3MgPSAkcGx1Z2luLT5nZXQoJ2NhbGxfY2xhc3MnLCAnZ2V0QmlibGUnKTsNCg0KCQkvLyBTaW1wbGUgcGVyZm9ybWFuY2UgY2hlY2sgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYm90IHNob3VsZCBwcm9jZXNzIGZ1cnRoZXINCgkJaWYgKHN0cnBvcygkcm93LT50ZXh0LCAkY2FsbF9jbGFzcykgPT09IGZhbHNlKQ0KCQl7DQoJCQlyZXR1cm47DQoJCX0NCg0KCQlTdXBlcl9fXzExODkyY2ZhXzM3NGVfNGUzZl9iMGJjXzUzMTg3MWM4MjJkOV9fX1Bvd2VyOjpfKCdHZXRCaWJsZS5Mb2FkZXInKS0+c2V0KCRyb3csICRwbHVnaW4pOw0KCX0=', '', '', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJGFwcF0=', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJGFwcF0=', 'W0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskYXBwXQ==', 'CQkJLy8gY2hlY2sgaWYgdGhpcyBoYXMgdGhlIG9sZCBnZXRCaWJsZSBleHRlbnNpb24gaW5zdGFsbGVkDQoJCQkkcGF0aCA9IEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX1tbW2NvbXBvbmVudF1dXS9oZWxwZXJzL2dldC5waHAnOw0KCQkJaWYgKGlzX3JlYWRhYmxlKCRwYXRoKSkNCgkJCXsNCgkJCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgiDQoJCQkJCTxwPlVuZm9ydHVuYXRlbHksIHlvdXIgYXR0ZW1wdCB0byBpbnN0YWxsIGdldEJpYmxlIFZlcnNpb24gMiBoYXMgZmFpbGVkLiBUaGUgcmVhc29uIGZvciB0aGlzIGZhaWx1cmUgaXMgZHVlIHRvIGFuIGV4aXN0aW5nIGluc3RhbGxhdGlvbiBvZiB0aGUgcHJldmlvdXMgdmVyc2lvbiB3aGljaCBpcyBpbmNvbXBhdGlibGUgd2l0aCBvdXIgbGF0ZXN0IHVwZGF0ZS4NCgkJCQkJV2UgZGVlcGx5IHJlZ3JldCB0aGlzIGludGVycnVwdGlvbiB0byB5b3VyIGluc3RhbGxhdGlvbiBwcm9jZXNzLiBUbyByZXNvbHZlIHRoaXMgaXNzdWUsIHBsZWFzZSBmaXJzdCB1bmluc3RhbGwgdGhlIG9sZCB2ZXJzaW9uIG9mIGdldEJpYmxlLiBJZiB5b3UgaGF2ZSBwZXJzb25hbGl6ZWQgbm90ZXMgYW5kIHRhZ3MgaW4gdGhlIGN1cnJlbnQgdmVyc2lvbiwgPGI+ZG9uJ3QgZm9yZ2V0IHRvIG1hbnVhbGx5IGJhY2sgdGhlbSB1cDwvYj4sIGFzIHRoZXkgd2lsbCBiZSBsb3N0IG90aGVyd2lzZS48L3A+DQoJCQkJCTxwPldlIHVuZGVyc3RhbmQgdGhhdCB0aGlzIHByb2Nlc3MgbWF5IGJlIGluY29udmVuaWVudCBhbmQgY291bGQgcG90ZW50aWFsbHkgcG9zZSBjaGFsbGVuZ2VzLiBUaGVyZWZvcmUsIHdlJ3ZlIHB1dCBhIHN1cHBvcnQgdGVhbSBpbiBwbGFjZSB0byBhc3Npc3QgeW91LiBTaG91bGQgeW91IHJlcXVpcmUgYW55IHRlY2huaWNhbCBhc3Npc3RhbmNlIG9yIGhhdmUgcXVlc3Rpb25zLCBwbGVhc2UgZG9uJ3QgaGVzaXRhdGUgdG8gcmVhY2ggb3V0IHRvIHVzIGF0OiA8YSBocmVmPSdodHRwczovL2dpdC52ZG0uZGV2L2dldEJpYmxlL3N1cHBvcnQnIHRpdGxlPSdnZXRCaWJsZSBTdXBwb3J0Jz5nZXRCaWJsZSBTdXBwb3J0PC9hPi4NCgkJCQkJV2UgYXBwcmVjaWF0ZSB5b3VyIHVuZGVyc3RhbmRpbmcgYW5kIGNvb3BlcmF0aW9uIGR1cmluZyB0aGlzIHRyYW5zaXRpb24gdG8gZ2V0QmlibGUgVmVyc2lvbiAyLiBPdXIgdGVhbSBpcyBjb21taXR0ZWQgdG8gaGVscGluZyB5b3UgZXZlcnkgc3RlcCBvZiB0aGUgd2F5LiBUaGFuayB5b3UhPC9wPiIsICdlcnJvcicpOw0KDQoJCQkJcmV0dXJuIGZhbHNlOw0KCQkJfQ0KW0NVU1RPTUNPREU9Z2V0QmlibGVSZW1vdmVPbGRMaWJdDQpbQ1VTVE9NQ09ERT1waHBDb25maWd1cmF0aW9uQ2hlY2tDYWxsKyRhcHBd', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vZ2l0LnZkbS5kZXYvZ2V0QmlibGUvam9vbWxhLWNvbXBvbmVudC9yYXcvYnJhbmNoL21hc3Rlci9hZG1pbi9hc3NldHMvaW1hZ2VzL3ZkbS1jb21wb25lbnQuanBnICJHZXRCaWJsZSIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IG5ldmVyIG1ha2luZyBvbmUgbWlzdGFrZSBvciB0YWtpbmcgYW55IGNvZmZlZSBicmVhay4pDQoNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCioqIyMjYWN0dWFsSG91cnNTcGVudCMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsRGF5c1NwZW50IyMjIEVpZ2h0IEhvdXIgRGF5cyoqICh0aGUgYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzcGVudCkNCg0KPiAod2l0aCB0aGUgZm9sbG93aW5nIGJyZWFrIGRvd246DQo+ICoqZGVidWdnaW5nIEAjIyNkZWJ1Z2dpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNDsNCj4gKipwbGFubmluZyBAIyMjcGxhbm5pbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNzsNCj4gKiptYXBwaW5nIEAjIyNtYXBwaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDEwOw0KPiAqKm9mZmljZSBAIyMjb2ZmaWNlSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDY7KQ0KDQoqKiMjI2FjdHVhbFRvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbFRvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKg0KKGEgdG90YWwgb2YgdGhlIHJlYWxpc3RpYyB0aW1lIGZyYW1lIGZvciB0aGlzIHByb2plY3QpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IHdpdGggdGhlIG5vcm1hbCBldmVyeWRheSByZWFsaXRpZXMgYXQgdGhlIG9mZmljZSwgdGhhdCBpbmNsdWRlcyB0aGUgY29tcG9uZW50IHBsYW5uaW5nLCBtYXBwaW5nICYgZGVidWdnaW5nLikNCg0KUHJvamVjdCBkdXJhdGlvbjogKiojIyNwcm9qZWN0V2Vla1RpbWUjIyMgd2Vla3MqKiBvciAqKiMjI3Byb2plY3RNb250aFRpbWUjIyMgbW9udGhzKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKQ==', 1, '', 'The Bible for Joomla', 'Q1JFQVRFIElOREVYIGlkeF8jX19bW1tjb21wb25lbnRdXV1fdGFnZ2VkX3ZlcnNlX29uX2xpbmtlcl9hbmRfdGFnDQpPTiAjX19bW1tjb21wb25lbnRdXV1fdGFnZ2VkX3ZlcnNlKGxpbmtlciwgdGFnKTsNCg0KQ1JFQVRFIElOREVYIGlkeF8jX19bW1tjb21wb25lbnRdXV1fdmVyc2Vfb25fdmVyc2VfYW5kX2FiYnJldmlhdGlvbg0KT04gI19fW1tbY29tcG9uZW50XV1dX3ZlcnNlKHZlcnNlLCBhYmJyZXZpYXRpb24pOw0KDQpDUkVBVEUgSU5ERVggaWR4XyNfX1tbW2NvbXBvbmVudF1dXV9ib29rX29uX25yX2FuZF9hYmJyZXZpYXRpb24NCk9OICNfX1tbW2NvbXBvbmVudF1dXV9ib29rKG5yLCBhYmJyZXZpYXRpb24pOw0KDQpDUkVBVEUgSU5ERVggaWR4XyNfX1tbW2NvbXBvbmVudF1dXV90YWdfb25fZ3VpZF9hbmRfcHVibGlzaGVkDQpPTiAjX19bW1tjb21wb25lbnRdXV1fdGFnKGd1aWQsIHB1Ymxpc2hlZCk7', '', 'Get Bible', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', '', 2, 'https://git.vdm.dev/getBible/joomla-component/raw/branch/3.x/update_server.xml', 'https://getbible.net', '', 'q9tMo1AjOAL6I9oZqofypze1ACLIXoHGBjPM4tQ3i20=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"\",\"power_admin_helper\":{\"power_admin_helper0\":{\"power\":\"11892cfa-374e-4e3f-b0bc-531871c822d9\",\"as\":\"GetBibleFactory\",\"build\":\"2\"},\"power_admin_helper1\":{\"power\":\"4612af84-5a42-4ea5-87bf-9d79cc19c330\",\"as\":\"GiteaFactory\",\"build\":\"2\"}},\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 231, '', 1, 53), -(10, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'JCB.txt', '', '', 'Joomla Component Builder', '1.0.6', 'Copyright (C) 2015. All Rights Reserved', '2015-08-05 00:40:06', '', 'Sb63t8FUeBmJerlrccYnV+c45itSf6qozwyJbovlt00=', 'Scf4AZ51hU0np7AfozZ9okVz5XH/+i2h7HG0vAuMxzs=', '', 'n/IPG15cndggdC4wOdJ39irK69zVxjsQvlGLtJQWF5w=', '', '', '', 1, '', 'Just a basic country listing with currency and region linkage.', 'joomla@vdm.io', '', '', 'TMwZZ6OZ74oJ8SHkEmmHI6+8kFIcSE79ZVaUl6FEGWU=', '', '1813baef-e42d-4673-aca6-94327e1fe873', 'images/vdm/jcb500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2020-11-17 17:18:47', 2, 'JCB Countries', 'jcb_countries', '', 4, '', '', '', '', '', '', '', '', '', '', 'ICMgIyMjQ29tcG9uZW50X25hbWUjIyMgKCMjI1ZFUlNJT04jIyMpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IG5ldmVyIG1ha2luZyBvbmUgbWlzdGFrZSBvciB0YWtpbmcgYW55IGNvZmZlZSBicmVhay4pDQoNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCioqIyMjYWN0dWFsSG91cnNTcGVudCMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsRGF5c1NwZW50IyMjIEVpZ2h0IEhvdXIgRGF5cyoqICh0aGUgYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzcGVudCkNCg0KPiAod2l0aCB0aGUgZm9sbG93aW5nIGJyZWFrIGRvd246DQo+ICoqZGVidWdnaW5nIEAjIyNkZWJ1Z2dpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNDsNCj4gKipwbGFubmluZyBAIyMjcGxhbm5pbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNzsNCj4gKiptYXBwaW5nIEAjIyNtYXBwaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDEwOw0KPiAqKm9mZmljZSBAIyMjb2ZmaWNlSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDY7KQ0KDQoqKiMjI2FjdHVhbFRvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbFRvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKg0KKGEgdG90YWwgb2YgdGhlIHJlYWxpc3RpYyB0aW1lIGZyYW1lIGZvciB0aGlzIHByb2plY3QpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IHdpdGggdGhlIG5vcm1hbCBldmVyeWRheSByZWFsaXRpZXMgYXQgdGhlIG9mZmljZSwgdGhhdCBpbmNsdWRlcyB0aGUgY29tcG9uZW50IHBsYW5uaW5nLCBtYXBwaW5nICYgZGVidWdnaW5nLikNCg0KUHJvamVjdCBkdXJhdGlvbjogKiojIyNwcm9qZWN0V2Vla1RpbWUjIyMgd2Vla3MqKiBvciAqKiMjI3Byb2plY3RNb250aFRpbWUjIyMgbW9udGhzKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KW0NVU1RPTUNPREU9cmVhZE1FY29udHJpYnV0b3JzXQ==', '', '', 'JCB Country Component', '', '', 'JCB Countries (public)', '.git', '', '', 1, 'https://www.vdm.io/updates/demointernal_update_server.xml', 'http://www.joomlacomponentbuilder.com', '', 'B4bdzi10xwbp40t4yt2GfwJHBHY4jZKHXBEOUqcSR1E=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 31, '', 1, 4), -(11, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', 1, '', 1, 3, 'Llewellyn van der Merwe', '', 'JCB.txt', '', '', 'Joomla Component Builder', '2.10.0', 'Copyright (C) 2015. All Rights Reserved', '2015-04-30 12:04:35', '', 'eowQ0CIjxqtgfLAW0VSgzSDJLZOeYQVvAaBcSgQLsn8=', 'QkCHQBQPz4f6gdF6impjQPKUtbWS0aq0tLfRA6nWGyw=', '', 'fUkVTE3M3hVpj/Nmb/klQBRsOLD33eE9yP7JdwU0fNs=', '', '', 'A_134', 2, '', 'The Component helps to update/sync all your field types to the latest release of JCB without the need to install a fresh JCB. Since all JCB packages also include the data down to the field-type layer, we basically build one view that has all field types in it and so will include all field-types as per/say to update your system.\r\n\r\nShould you have customized your field-types, it will probably override them!', 'joomla@vdm.io', '', '', 'IHelGQOmQQriHgaIu3hZcGbfg2ooXq5p+9BTWRsd1V8=', '', '551053a0-0e17-4cec-909a-28079878ce1e', 'images/vdm/jcb500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '«', '2022-06-22 14:47:21', 3, 'Field Type Updater', 'field_type_updater', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'JCB Field Type Updater', '', '', 'Field Type Updater (public)', '.git', '', '', 1, 'https://www.vdm.io/updates/componentbuilder_basic_update_server.xml', 'http://www.joomlacomponentbuilder.com', '', 'oDiIF5J79N0K4p7b6ygC6MYCzSEIH7iVML4/SlvsFwg=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 43, '', 1, 55), -(12, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, '', 2, 3, 'Llewellyn van der Merwe', '', 'JCB.txt', '', '', 'Joomla Component Builder', '1.0.1', 'Copyright (C) 2015. All Rights Reserved', '2015-04-30 13:04:35', '', 'sajfsZ/cXooNKDqU/c9mb8GPS2LhFpIcHFtG0p7HcnI=', 'wFf9c7zgXfT5EeLS81c1EfTkTGNDbp2sVo6qMqilMgU=', '', 'SQ28+O95n2Iw3QJquIZOTi0SDj2ORX4iJYP+BgIaPIY=', '', '', '', 1, '', 'The Component Builder\'s Compiler Configuration Architect', 'joomla@vdm.io', '', '', 'aMOO874VLYioby1Mp/sowVQ/lsbMV1maSl+R40gxrVY=', '', 'e3272f27-e9ec-42a5-bdd4-e45976f67ce3', 'images/vdm/jcb500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2019-07-04 01:17:05', 2, 'Compiler Configuration Architect', 'compilerconfigurationarchitect', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Builds JCB Compiler', '', '', 'Compiler Configuration Architect', '.git', '', '', 2, 'https://raw.githubusercontent.com/vdm-io/Compiler-Configuration-Architect/master/compilerconfigurationarchitect_update_server.xml', 'http://www.joomlacomponentbuilder.com', '', '6wcdNcmqeGJ8qOOVr0KBv/GSfHo6NFLlQK/Tw7ZRtro=', '', '', 1, 41, '', 1, 57), -(13, 1, '', '', '', '', '', '', '', 1, '', '', 1, 1, '', '', '', '', '', '', 1, '', '', '', '', '', '{}', 3, 1, 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.3', 'Copyright (C) 2019 Vast Development Method. All rights reserved.', '2019-07-30 11:04:35', '', '0L8umlMVGbIHBECkJo9MdF/WOL+DKQ36mdkuHyiSfc4=', 'TJMfFavY9uf+yMAG9r2+PP/+p5+th76IQsqYDUq7Dd4=', '', '5z12QnQCfREITlFuWJKPAy2AyjYtFg+Z5oqxtZgAe1o=', '', '', '', 1, '', 'The library of books, documents, media and other type of files.', 'dev@vdm.io', '', '', 'zprR7+IHQCH3c3V94azOxAawULNZzTAHdgrseaOKw4M=', '', 'b8fa56f7-483b-4b8f-9845-4479ce15ccc7', 'images/vdm/Libary500.jpg', '', '', 'GNU General Public License version 2 or later; see LICENSE.txt', 1, 'ℂ𝕃', '2021-03-08 03:13:22', 3, 'Library', 'librarydatabase', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9ZmlsZUhlbHBlckJvdGhd', 'W0NVU1RPTUNPREU9Y291bnRMb2NhbERvd25sb2FkXQ==', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXSgvYWRtaW5pc3RyYXRvci9jb21wb25lbnRzL2NvbV8jIyNjb21wb25lbnQjIyMvYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMgQ29tcG9uZW50IE51bWJlcg0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCiMgSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyDQoNCkZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IEpDQiB2aXNpdCBbVkRNXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKSBUb2RheSEgVGhlIGZ1dHVyZSBpcyBoZXJlIQ==', '', '', 'Library of books and more', '', '', 'Library (books)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Plugin-Builder/master/pluginbuilder_update_server.xml', 'https://www.vdm.io/', '', 'uxsjjVYguNu3me77pIvjROAyZO635/LEg6Xv32Xs24o=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 96, '', 1, 54), -(14, 1, '', 1, '', 1, '', '', '', 1, '', '', 1, '', '', '', 1, '', 1, '', 1, '', 1, 1, 1, 1, '{}', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'JCB-pro.txt', '', '', 'Vast Development Method', '3.1.6', 'Copyright (C) 2015 Vast Development Method. All rights reserved.', '2015-04-30 12:04:35', '', 'Szn2KFyt+xquQEoCXEQGYeN/K01CYQG9mzQ6/5sy0kY=', '2apXsgmRStpvRORC56BI8bYI0tCfEK5qrmgVx5eclh/JUyy3NLstqb7a8IWAow/3VIk5aovN3J7hQccaiFb54A==', 'joomla-component-builder', 'fk1chg/pRL/5EzYsisjrDCv/+I72xNIpZzRjakzqsWo=', 'LmZpZWxkTWVkaXVtIHsgd2lkdGg6IDEyMHB4OyB9DQouZmllbGRMYXJnZSB7IHdpZHRoOiAzMjBweDsgfQ0KLmZpZWxkTWlkIHsgd2lkdGg6IDgwcHg7IH0NCi5maWVsZEZ1bGwgeyB3aWR0aDogMTAwJTsgfQ0KLmZpZWxkU21hbGwgeyB3aWR0aDogNjBweDsgfQ0KY29kZSB7IGRpc3BsYXk6IGlubGluZS1ibG9jazsgbWFyZ2luOiAzcHg7fQ==', '', '', 1, '', 'The Component Builder for [Joomla](https://extensions.joomla.org/extension/component-builder/) is highly advanced tool that is truly able to build extremely complex components in a fraction of the time.\r\n\r\nWhether you\'re a seasoned [Joomla](https://extensions.joomla.org/extension/component-builder/) developer, or have just started, Component Builder will save you lots of time and money. A real must have!', 'joomla@vdm.io', '', 'https://vdm.bz/contribute-financially-to-jcb', 'wtbW3I4qj/wjgY5xeJ1EF65i5V2eyZmXu6dRGsbBYi8Qg05hB39CdFNEeVZjIqDKkkTO98phUEkK2+q3E0HD7g==', '', '67d8681b-6556-45a0-94f1-a53cd9cdad97', 'images/vdm/jcb500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder', 'GNU General Public License version 2 or later; see LICENSE.txt', 1, '✓', '2023-10-21 13:48:20', 2, 'Component Builder', 'componentbuilder', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'CS8qDQoJICogQ29tcGlsZXIgYXV0b2xvYWRlcg0KCSAqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gYXV0b0xvYWRlcigpDQoJew0KCQkvLyBsb2FkIHRoZSBjb21waWxlciBjbGFzc2VzDQoJCXJlcXVpcmVfb25jZSBKUEFUSF9BRE1JTklTVFJBVE9SLicvY29tcG9uZW50cy9jb21fW1tbY29tcG9uZW50XV1dL2hlbHBlcnMvZ2V0LnBocCc7DQoJCXJlcXVpcmVfb25jZSBKUEFUSF9BRE1JTklTVFJBVE9SLicvY29tcG9uZW50cy9jb21fW1tbY29tcG9uZW50XV1dL2hlbHBlcnMvc3RydWN0dXJlLnBocCc7DQoJCXJlcXVpcmVfb25jZSBKUEFUSF9BRE1JTklTVFJBVE9SLicvY29tcG9uZW50cy9jb21fW1tbY29tcG9uZW50XV1dL2hlbHBlcnMvaW50ZXJwcmV0YXRpb24ucGhwJzsNCgkJcmVxdWlyZV9vbmNlIEpQQVRIX0FETUlOSVNUUkFUT1IuJy9jb21wb25lbnRzL2NvbV9bW1tjb21wb25lbnRdXV0vaGVscGVycy9pbmZ1c2lvbi5waHAnOw0KCX0NCg0KCS8qKg0KCSAqCWluZGVudCBIVE1MDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBpbmRlbnQoJGh0bWwpDQoJew0KCQkvLyBsb2FkIHRoZSBjbGFzcw0KCQlyZXF1aXJlX29uY2UgSlBBVEhfQURNSU5JU1RSQVRPUi4nL2NvbXBvbmVudHMvY29tX1tbW2NvbXBvbmVudF1dXS9oZWxwZXJzL2luZGVudGVyLnBocCc7DQoJCS8vIHNldCBuZXcgaW5kZW50ZXINCgkJJGluZGVudGVyID0gbmV3IEluZGVudGVyKCk7DQoJCS8vIHJldHVybiBpbmRlbnRlZCBodG1sDQoJCXJldHVybiAkaW5kZW50ZXItPmluZGVudCgkaHRtbCk7DQoJfQ0KDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBjaGVja0ZpbGVUeXBlKCRmaWxlLCAkc3VmaXgpIHsNCgkJLy8gbm93IGNoZWNrIGlmIHRoZSBmaWxlIGVuZHMgd2l0aCB0aGUgc3VmaXgNCgkJcmV0dXJuICRzdWZpeCA9PT0gIiIgfHwgKCRzdWZpeCA9PSBzdWJzdHIoc3RycmNocigkZmlsZSwgIi4iKSwgLXN0cmxlbigkc3VmaXgpKSk7DQoJfQ0KDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBpbWFnZUluZm8oJHBhdGgsJHJlcXVlc3QgPSAndHlwZScpDQoJew0KCQkvLyBzZXQgaW1hZ2UNCgkJJGltYWdlID0gSlBBVEhfU0lURS4nLycuJHBhdGg7DQoJCS8vIGNoYWNrIGlmIGV4aXN0cw0KCQlpZiAoZmlsZV9leGlzdHMoJGltYWdlKSkNCgkJew0KCQkJLy8gZ2V0IGltYWdlIGluZm8NCgkJCSRyZXN1bHQgPSBnZXRpbWFnZXNpemUoJGltYWdlKTsNCgkJCS8vIHJldHVybiB0eXBlIHJlcXVlc3QNCgkJCXN3aXRjaCAoJHJlcXVlc3QpDQoJCQl7DQoJCQkJY2FzZSAnd2lkdGgnOg0KCQkJCQlyZXR1cm4gJHJlc3VsdFswXTsNCgkJCQkJYnJlYWs7DQoJCQkJY2FzZSAnaGVpZ2h0JzoNCgkJCQkJcmV0dXJuICRyZXN1bHRbMV07DQoJCQkJCWJyZWFrOw0KCQkJCWNhc2UgJ3R5cGUnOg0KCQkJCQkkZXh0ZW5zaW9ucyA9IGFycmF5KA0KCQkJCQkJSU1BR0VUWVBFX0dJRiA9PiAiZ2lmIiwNCgkJCQkJCUlNQUdFVFlQRV9KUEVHID0+ICJqcGciLA0KCQkJCQkJSU1BR0VUWVBFX1BORyA9PiAicG5nIiwNCgkJCQkJCUlNQUdFVFlQRV9TV0YgPT4gInN3ZiIsDQoJCQkJCQlJTUFHRVRZUEVfUFNEID0+ICJwc2QiLA0KCQkJCQkJSU1BR0VUWVBFX0JNUCA9PiAiYm1wIiwNCgkJCQkJCUlNQUdFVFlQRV9USUZGX0lJID0+ICJ0aWZmIiwNCgkJCQkJCUlNQUdFVFlQRV9USUZGX01NID0+ICJ0aWZmIiwNCgkJCQkJCUlNQUdFVFlQRV9KUEMgPT4gImpwYyIsDQoJCQkJCQlJTUFHRVRZUEVfSlAyID0+ICJqcDIiLA0KCQkJCQkJSU1BR0VUWVBFX0pQWCA9PiAianB4IiwNCgkJCQkJCUlNQUdFVFlQRV9KQjIgPT4gImpiMiIsDQoJCQkJCQlJTUFHRVRZUEVfU1dDID0+ICJzd2MiLA0KCQkJCQkJSU1BR0VUWVBFX0lGRiA9PiAiaWZmIiwNCgkJCQkJCUlNQUdFVFlQRV9XQk1QID0+ICJ3Ym1wIiwNCgkJCQkJCUlNQUdFVFlQRV9YQk0gPT4gInhibSIsDQoJCQkJCQlJTUFHRVRZUEVfSUNPID0+ICJpY28iDQoJCQkJCSk7DQoJCQkJCXJldHVybiAkZXh0ZW5zaW9uc1skcmVzdWx0WzJdXTsNCgkJCQkJYnJlYWs7DQoJCQkJY2FzZSAnYXR0cic6DQoJCQkJCXJldHVybiAkcmVzdWx0WzNdOw0KCQkJCQlicmVhazsNCgkJCQljYXNlICdhbGwnOg0KCQkJCWRlZmF1bHQ6DQoJCQkJCXJldHVybiAkcmVzdWx0Ow0KCQkJCQlicmVhazsNCgkJCX0NCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ0KCQ0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0QmV0d2VlbigkY29udGVudCwkc3RhcnQsJGVuZCkNCgl7DQoJCSRyID0gZXhwbG9kZSgkc3RhcnQsICRjb250ZW50KTsNCgkJaWYgKGlzc2V0KCRyWzFdKSkNCgkJew0KCQkJJHIgPSBleHBsb2RlKCRlbmQsICRyWzFdKTsNCgkJCXJldHVybiAkclswXTsNCgkJfQ0KCQlyZXR1cm4gJyc7DQoJfQ0KCQ0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0QWxsQmV0d2VlbigkY29udGVudCwkc3RhcnQsJGVuZCkNCgl7DQoJCSRidWtldCA9IGFycmF5KCk7DQoJCWZvciAoJGkgPSAwOyA7ICRpKyspDQoJCXsNCgkJCSRmb3VuZCA9IFN1cGVyX19fZGI4N2MzMzlfNWJiNl80MjkxX2E3ZWZfMmM0OGVhMWIwNmJjX19fUG93ZXI6OmJldHdlZW4oJGNvbnRlbnQsJHN0YXJ0LCRlbmQpOw0KCQkJaWYgKFN1cGVyX19fMWYyOGNiNTNfNjBkOV80ZGIxX2I1MTdfM2M3ZGM2YjQyOWVmX19fUG93ZXI6OmNoZWNrKCRmb3VuZCkpDQoJCQl7DQoJCQkJJGJ1a2V0W10gPSAkZm91bmQ7DQoJCQkJJHJlbW92ZSA9ICRzdGFydC4kZm91bmQuJGVuZDsNCgkJCQkkY29udGVudCA9IHN0cl9yZXBsYWNlKCRyZW1vdmUsJycsJGNvbnRlbnQpOw0KCQkJfQ0KCQkJZWxzZQ0KCQkJew0KCQkJCWJyZWFrOw0KCQkJfQ0KCQkJLy8gc2FmZXR5IGNhdGNoDQoJCQlpZiAoJGkgPT0gNTAwKQ0KCQkJew0KCQkJCWJyZWFrOw0KCQkJfQ0KCQl9DQoJCXJldHVybiAgYXJyYXlfdW5pcXVlKCRidWtldCk7DQoJfQ0KCQ0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gdHlwZUZpZWxkKCR0eXBlLCRvcHRpb24gPSAnZGVmYXVsdCcpDQoJew0KCQkvLyBsaXN0IG9mIGRlZmF1bHQgZmllbGRzDQoJCS8vIGh0dHBzOi8vZG9jcy5qb29tbGEub3JnL0Zvcm1fZmllbGQNCgkJJGZpZWxkcyA9IGFycmF5KA0KCQkJJ2RlZmF1bHQnID0+IGFycmF5KA0KCQkJCSdhY2Nlc3NsZXZlbCcsJ2NhY2hlaGFuZGxlcicsJ2NhbGVuZGFyJywnY2FwdGNoYScsJ2NhdGVnb3J5JywnY2hlY2tib3gnLA0KCQkJCSdjaGVja2JveGVzJywnY29sb3InLCdjb21ibycsJ2NvbXBvbmVudGxheW91dCcsJ2NvbnRlbnRsYW5ndWFnZScsJ2VkaXRvcicsDQoJCQkJJ2Nocm9tZXN0eWxlJywnY29udGVudHR5cGUnLCdkYXRhYmFzZWNvbm5lY3Rpb24nLCdlZGl0b3JzJywnZW1haWwnLCdmaWxlJywNCgkJCQknZmlsZWxpc3QnLCdmb2xkZXJsaXN0JywnZ3JvdXBlZGxpc3QnLCdoaWRkZW4nLCdmaWxlJywnaGVhZGVydGFnJywnaGVscHNpdGUnLA0KCQkJCSdpbWFnZWxpc3QnLCdpbnRlZ2VyJywnbGFuZ3VhZ2UnLCdsaXN0JywnbWVkaWEnLCdtZW51Jywnbm90ZScsJ3Bhc3N3b3JkJywNCgkJCQkncGx1Z2lucycsJ3JhbmdlJywncmFkaW8nLCdyZXBlYXRhYmxlJywncnVsZXMnLCdzZXNzaW9uaGFuZGxlcicsJ3NwYWNlcicsJ3NxbCcsJ3RhZycsDQoJCQkJJ3RlbCcsJ21lbnVpdGVtJywnbW9kdWxlbGF5b3V0JywnbWV0ZXInLCdtb2R1bGVvcmRlcicsJ21vZHVsZXBvc2l0aW9uJywnbW9kdWxldGFnJywNCgkJCQkndGVtcGxhdGVzdHlsZScsJ3RleHQnLCd0ZXh0YXJlYScsJ3RpbWV6b25lJywndXJsJywndXNlcicsJ3VzZXJncm91cCcNCgkJCSksIA0KCQkJJ3RleHQnID0+IGFycmF5KA0KCQkJCSdjYWxlbmRhcicsJ2NvbG9yJywnZWRpdG9yJywnZW1haWwnLCdwYXNzd29yZCcsJ3RlbCcsJ3RleHQnLCd0ZXh0YXJlYScsJ3VybCcsJ251bWJlcicsJ3JhbmdlJw0KCQkJKSwgDQoJCQknbGlzdCcgPT4gYXJyYXkoDQoJCQkJJ2NoZWNrYm94ZXMnLCdjaGVja2JveCcsJ2xpc3QnLCdyYWRpbycNCgkJCSksIA0KCQkJJ2R5bmFtaWMnID0+IGFycmF5KA0KCQkJCSdjYXRlZ29yeScsJ2hlYWRlcnRhZycsJ3RhZycsJ3J1bGVzJywndXNlcicsJ2ZpbGUnLCdmaWxlbGlzdCcsJ2ZvbGRlcmxpc3QnLCdpbWFnZWxpc3QnLCdpbnRlZ2VyJywndGltZXpvbmUnLCdtZWRpYScsJ21ldGVyJw0KCQkJKQ0KCQkpOw0KCQkNCgkJaWYgKGluX2FycmF5KCR0eXBlLCRmaWVsZHNbJG9wdGlvbl0pKQ0KCQl7DQoJCQlyZXR1cm4gdHJ1ZTsNCgkJfQ0KCQlyZXR1cm4gZmFsc2U7CQkNCgl9', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlckhlbHBlckJvdGhd', '', '', '', '[CUSTOMCODE=componentbuilderPostflightUpdate]
			// we must update all areas that may have linked powers in the target fields of their params
			$targets = [
				'admin_view' => [
					'add_admin_view_model' => 'power_admin_view_model',
					'add_admin_view' => 'power_admin_view',
					'add_admin_view_html' => 'power_admin_view_html',
					'add_site_admin_view_html' => 'power_site_admin_view_html',
					'add_admin_view_controller'  => 'power_admin_view_controller',
					'add_ajax_model' => 'power_ajax_model',
					'add_admin_views_model' => 'power_admin_views_model',
					'add_admin_views' => 'power_admin_views',
					'add_admin_views_html' => 'power_admin_views_html',
					'add_admin_views_controller' => 'power_admin_views_controller'
				],
				'site_view' => [
					'add_site_view_model' => 'power_site_view_model',
					'add_site_view' => 'power_site_view',
					'add_site_view_html' => 'power_site_view_html',
					'add_site_view_controller'  => 'power_site_view_controller',
					'add_site_views_model' => 'power_site_views_model',
					'add_site_views' => 'power_site_views',
					'add_site_views_html' => 'power_site_views_html',
					'add_site_views_controller' => 'power_site_views_controller',
					'add_ajax_model' => 'power_ajax_model'
				],
				'custom_admin_view' => [
					'add_custom_admin_view_model' => 'power_custom_admin_view_model',
					'add_custom_admin_view' => 'power_custom_admin_view',
					'add_custom_admin_view_html' => 'power_custom_admin_view_html',
					'add_custom_admin_view_controller'  => 'power_custom_admin_view_controller',
					'add_custom_admin_views_model' => 'power_custom_admin_views_model',
					'add_custom_admin_views' => 'power_custom_admin_views',
					'add_custom_admin_views_html' => 'power_custom_admin_views_html',
					'add_custom_admin_views_controller' => 'power_custom_admin_views_controller',
					'add_ajax_model' => 'power_ajax_model'
				],
				'dynamic_get' => [
					'add_site_view_model' => 'power_site_view_model',
					'add_site_view' => 'power_site_view',
					'add_site_view_html' => 'power_site_view_html',
					'add_site_view_controller'  => 'power_site_view_controller',
					'add_site_views_model' => 'power_site_views_model',
					'add_site_views' => 'power_site_views',
					'add_site_views_html' => 'power_site_views_html',
					'add_site_views_controller' => 'power_site_views_controller',
					'add_custom_admin_view_model' => 'power_custom_admin_view_model',
					'add_custom_admin_view' => 'power_custom_admin_view',
					'add_custom_admin_view_html' => 'power_custom_admin_view_html',
					'add_custom_admin_view_controller'  => 'power_custom_admin_view_controller',
					'add_custom_admin_views_model' => 'power_custom_admin_views_model',
					'add_custom_admin_views' => 'power_custom_admin_views',
					'add_custom_admin_views_html' => 'power_custom_admin_views_html',
					'add_custom_admin_views_controller' => 'power_custom_admin_views_controller',
					'add_ajax_model' => 'power_ajax_model'
				],
				'component_dashboard' => [
					'add_dashboard_model' => 'power_dashboard_model',
					'add_dashboard_view' => 'power_dashboard_view',
					'add_dashboard_view_html'  => 'power_dashboard_view_html',
					'add_dashboard_controller' => 'power_dashboard_controller',
					'add_ajax_model' => 'power_ajax_model'
				],
				'joomla_component' => [
					'add_admin_component' => 'power_admin_component',
					'add_site_component'  => 'power_site_component',
					'add_admin_helper' => 'power_admin_helper',
					'add_site_helper' => 'power_site_helper'
				]
			];
			// target version less then or equal to 3.0.10
			if (count($this->JCBversion) == 3 && $this->JCBversion[0] <= 3 && $this->JCBversion[1] == 0 && $this->JCBversion[2] <= 10)
			{
				// keep track of used
				$mapper = array();
				// our get function
				$getGuidFromId = function ($id) use(&$mapper)
				{
					if (is_numeric($id) && isset($mapper[$id]))
					{
						// to update this power
						return $mapper[$id];
					}
					elseif (is_numeric($id) &&
						($guid = Super___db87c339_5bb6_4291_a7ef_2c48ea1b06bc___Power::var('power', $id, 'id', 'guid')) !== false)
					{
						// not to fetch it again
						$mapper[$id] = $guid;
						return $guid;
					}
					elseif(!is_numeric($id) && 
						[[[Component]]]Helper::validGUID($id))
					{
						// keep this power
						return $id;
					}
					return false;
				};
				// update all tables
				foreach ($targets as $table => $fields)
				{
					// check it this table active
					$active = $table . '_headers';
					// Create a new query object.
					$query = $db->getQuery(true);
					// get all ids and guids of each table
					$query->select($db->quoteName(array('id', 'params')));
					$query->from($db->quoteName('#__[[[component]]]_' . $table));
					// Reset the query using our newly populated query object.
					$db->setQuery($query);
					$db->execute();
					if ($db->getNumRows())
					{
						// get the rows
						$rows = $db->loadObjectList();
						foreach ($rows as $row)
						{
							// load value not to use it again
							if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($row->params))
							{
								// now open the params
								$params = json_decode($row->params);
								$update = false;
								// check if we have active data
								if (isset($params->{$active}))
								{
									foreach ($fields as $add => $power)
									{
										// check if headers in active
										if (isset($params->{$active}->{$add}) &&
											$params->{$active}->{$add} &&
											is_array($params->{$active}->{$power}))
										{
											// get powers and update
											$powers = [];
											foreach ($params->{$active}->{$power} as $id)
											{
												if (($guid = $getGuidFromId($id)) !==false)
												{
													// to update this power
													$powers[] = $guid;
												}
											}
											// check that we have found powers to update
											if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($powers))
											{
												// update the local params
												$params->{$active}->{$power} = $powers;
												// to update this params
												$update = true;
											}
										}
									}
								}
								// check if update must be made
								if ($update)
								{
									// Create a new query object.
									$query = $db->getQuery(true);
									// load the guid
									$update_fields = array(
										$db->quoteName('params') . ' = ' . $db->quote(json_encode($params))
									);
									// Conditions for which records should be updated.
									$conditions = array(
										$db->quoteName('id') . ' = ' . (int) $row->id
									);
							 		// update the row
									$query->update($db->quoteName('#__[[[component]]]_'. $table))->set($update_fields)->where($conditions);
									$db->setQuery($query);
									$db->execute();
								}
							}
						}
					}
				}
				// we must update all powers as-well where it has linked ID's in its own fields
				$fields = [
					'use_selection' => 'use',
					'load_selection' => 'load',
					'implements' => 2,
					'extends' => 1
				];
				// Create a new query object.
				$query = $db->getQuery(true);
				// get all ids and guids of each table
				$query->select($db->quoteName(array('id')));
				$query->select($db->quoteName(array_keys($fields)));
				$query->from($db->quoteName('#__[[[component]]]_power'));
				// Reset the query using our newly populated query object.
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					// get the rows
					$rows = $db->loadObjectList();
					foreach ($rows as $row)
					{
						$update = false;
						$update_fields = [];
						foreach ($fields as $field => $key)
						{
							if (is_int($key) && $key == 1)
							{
								if (is_numeric($row->{$field}) &&
									$row->{$field} > 0 &&
									($guid = $getGuidFromId($row->{$field})) !==false)
								{
									// load the field
									$update_fields[] = $db->quoteName($field) . ' = ' . $db->quote($guid);
									$update = true;
								}
							}
							elseif (is_int($key) && $key == 2)
							{
								$array = (array) json_decode($row->{$field}, true);
								if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($array, true))
								{
									$powers = [];
									foreach ($array as $id)
									{
										if (is_numeric($id) && $id > 0 &&
											($guid = $getGuidFromId($id)) !==false)
										{
											// to update this power
											$powers[] = $guid;
										}
									}
									if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($powers))
									{
										// load the field
										$update_fields[] = $db->quoteName($field) . ' = ' . $db->quote(json_encode($powers));
										$update = true;
									}
								}
							}
							elseif (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($row->{$field}))
							{
								$subform = json_decode($row->{$field}, true);
								if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($subform, true))
								{
									$powers = [];
									foreach ($subform as $selection => $value)
									{
										if (isset($value[$key]) && is_numeric($value[$key]) && $value[$key] > 0 &&
											($guid = $getGuidFromId($value[$key])) !==false)
										{
											// to update this power
											$powers[$selection] = [$key => $guid];
										}
									}
									if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($powers))
									{
										// load the field
										$update_fields[] = $db->quoteName($field) . ' = ' . $db->quote(json_encode($powers));
										$update = true;
									}
								}
							}
						}
						// check if we should update this power
						if ($update)
						{
							// Create a new query object.
							$query = $db->getQuery(true);
							// Conditions for which records should be updated.
							$conditions = array(
								$db->quoteName('id') . ' = ' . (int) $row->id
							);
							// update the row
							$query->update($db->quoteName('#__[[[component]]]_power'))->set($update_fields)->where($conditions);
							$db->setQuery($query);
							$db->execute();
						}
					}
				}
			}
			// target version less then or equal to 3.0.14
			if (count($this->JCBversion) == 3 && $this->JCBversion[0] <= 3 && $this->JCBversion[1] == 0 && $this->JCBversion[2] <= 14)
			{
				// convert all powers in params to subform format
				foreach ($targets as $table => $fields)
				{
					// check it this table active
					$active = $table . '_headers';
					// Create a new query object.
					$query = $db->getQuery(true);
					// get all ids and guids of each table
					$query->select($db->quoteName(array('id', 'params')));
					$query->from($db->quoteName('#__[[[component]]]_' . $table));
					// Reset the query using our newly populated query object.
					$db->setQuery($query);
					$db->execute();
					if ($db->getNumRows())
					{
						// get the rows
						$rows = $db->loadObjectList();
						foreach ($rows as $row)
						{
							// load value not to use it again
							if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($row->params))
							{
								// now open the params
								$params = json_decode($row->params);
								$update = false;
								// check if we have active data
								if (isset($params->{$active}))
								{
									foreach ($fields as $add => $power)
									{
										// check if headers in active
										if (isset($params->{$active}->{$add}) &&
											$params->{$active}->{$add} &&
											is_array($params->{$active}->{$power}))
										{
											// get powers and update
											$powers = [];
											foreach ($params->{$active}->{$power} as $nr => $guid)
											{
												// convert to sub-form format
												$powers[$power.$nr] = ['power' => $guid, 'build' => 2, 'as' => 'default'];
											}
											// update the local params
											$params->{$active}->{$power} = $powers;
										}
									}
								}
								// Create a new query object.
								$query = $db->getQuery(true);
								// load the guid
								$update_fields = array(
									$db->quoteName('params') . ' = ' . $db->quote(json_encode($params))
								);
								// Conditions for which records should be updated.
								$conditions = array(
									$db->quoteName('id') . ' = ' . (int) $row->id
								);
							 	// update the row
								$query->update($db->quoteName('#__[[[component]]]_'. $table))->set($update_fields)->where($conditions);
								$db->setQuery($query);
								$db->execute();
							}
						}
					}
				}
			}', '', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclByZWZsaWdodFVwZGF0ZV0=', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclJlYWRNZV0=', '', '', 'Builds Complex Joomla Components', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMSW5zdGFsbF0=', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMVW5pbnN0YWxsXQ==', 'Component Builder (Pro)', '.git, .github, .gitignore, .idea, SECURITY.md, .editorconfig, .octojpack', 1, '', 2, 'https://io.vdm.dev/update/componentbuilder_update_server.xml', 'https://dev.vdm.io', '', 'kv00V8vcC2V9uJmCbRyLTsOX93B3ECsPzipj7bZ7PoU=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\",\"power_admin_helper\":{\"power_admin_helper0\":{\"power\":\"79d765b3-7319-4988-9730-446c7f347020\",\"as\":\"default\",\"build\":\"1\"}},\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\",\"power_site_helper\":{\"power_site_helper0\":{\"power\":\"79d765b3-7319-4988-9730-446c7f347020\",\"as\":\"default\",\"build\":\"1\"}}}}', 2, 99, '', 1, 56), -(15, '', '', '', '', '', '', '', 1, 1, '', 1, '', 1, '', '', '', '', '', '', 1, '', '', '', '', 1, '{\"addcontributors0\":{\"name\":\"Patrick Hanlon, M.Sc. PH\",\"title\":\"Health Economist\",\"email\":\"Patrick.Hanlon@unibas.ch\",\"website\":\"http:\\/\\/www.swisstph.ch\\/about-us\\/staff\\/detailview.html?tx_x4epersdb_pi1[showUid]=2267&cHash=1b1c5db0808e04d3f1afe0f3a3f67998\",\"use\":\"2\",\"show\":\"3\"},\"addcontributors1\":{\"name\":\"Matthew Black\",\"title\":\"Development Advisor\",\"email\":\"matthew.black@giz.de\",\"website\":\"http:\\/\\/www.giz.de\",\"use\":\"2\",\"show\":\"3\"},\"addcontributors2\":{\"name\":\"Dr. Pascal Geldsetzer\",\"title\":\"Associate Expert\",\"email\":\"pascal.geldsetzer@giz.de\",\"website\":\"http:\\/\\/www.giz.de\",\"use\":\"2\",\"show\":\"1\"}}', 1, 1, 1, 3, 'Llewellyn van der Merwe', '', 'giz.txt', '', '', 'Deutsche Gesellschaft für International Zusammenarbeit (GIZ) Gmb', '3.3.9', 'Copyright (C) 2015. All Rights Reserved', '2016-01-31 20:20:17', 1, '', '', '', '', '', '', '', 1, '', '[Create Epidemiological Profiles] (https://www.staffhealthcbp.com/) for diseases and risks affecting your company. Detailed information on projected work days lost and costs. Create and edit activities and wellness responses for your workplace. Access to Small Business Modelling. Results displayed by gender. Network with other companies and wellness professionals.\r\n\r\nHaving seen the health priorities for your workforce, the tool outputs projections for how the interventions – which you have designed - are expected to benefit the company financially.\r\n\r\nBenefits are calculated based on the model projecting reductions in workdays lost due to sickness, presenteeism and death.', 'llewellyn@vdm.io', 1, '', '', '', '9be33818-561f-4020-9625-653ba0caef01', 'images/giz.png', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2016-03-11 13:48:37', '', 'Cost Benefit Projection', 'costbenefitprojection', '', 2, '', '	public static function userIs($id = null)
	{
		if($id > 0)
		{
			$user = Factory::getUser($id);
		}
		else
		{
			$user = Factory::getUser();
		}
		// get this user groups
		$groups	= (array) $user->getAuthorisedGroups();
		// get params
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		// get target groups
		$countryGroups 			= (array) $params->get('countryuser');
		$serviceproviderGroups		= (array) $params->get('serviceprovideruser');
		$memberGroups 			= (array) $params->get('memberuser');
		// now check in what group this user belongs
		if (array_intersect($countryGroups, $groups))
		{
			// is country
			return 3;
		}
		elseif (array_intersect($serviceproviderGroups, $groups))
		{
			// is serviceprovider
			return 2;
		}
		elseif (array_intersect($memberGroups, $groups))
		{
			// is member
			return 1;
		}
		return false;
	}

	public static function accessCompany($id)
	{
		// check the per value
		$lock = self::getVar('company', $id, 'id', 'per');
		if ( 1 == $lock)
		{
			return true;
		}
		return false;
	}

	public static function checkIntervetionAccess($id, $share = null, $comp = null)
	{
                // set share value if not set
                if (!$share)
                {
                        $share = self::getId('intervention', $id, 'id', 'share');
                }
                // based on shared we set needed values
                switch ($share)
                {
                        case 1:
                        case 2:
                                // get this interventions company (owner)
                                if (!$comp)
                                {
                                        $comp = self::getId('intervention', $id, 'id', 'company');
                                }
                                // get his companies
                                $companies = self::hisCompanies();
                                // get user type
                                $userType = self::userIs();
                        break;
                }
                // based on shared value we will respond
                switch ($share)
                {
                        case 1:
                                // if sharing is 1 only owner may see it
                                if ($userType == 1)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        case 2:
                                // if sharing is 2 only owner and service provider may see it
                               if ($userType == 1 || $userType == 2)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        break;
                }
		return true;
	}

	public static function notHisUsers($id = null)
	{
		// first get all the users to keep
		$keepUsers = self::hisUsers($id);
		if (is_array($keepUsers))
		{
			// return those not to keep
			return self::getIds('id',$keepUsers,'users','id','NOT IN','');
		}
		return false;
	}

	public static function hisUsers($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load himself)
			case 1:
			return array($id);
			break;
			// serves provider (only load companies users that belong to the service provider and himself)
			case 2:
			$companies	= self::hisCompanies($id);
			$keep		= self::getIds('id',$companies,'company','user');
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
			// country (only load companies and service providers that belong to the country)
			case 3:
			$companies	= self::hisCompanies($id);
			$keepC		= self::getIds('id',$companies,'company','user');
			$service	= self::hisServiceProviders($id);
			$keepS		= self::getIds('id',$service,'service_provider','user');
			// merge these values
			$keep		= self::mergeArrays(array($keepC,$keepS));
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
		}
		return false;
	}

	public static function hisCompanies($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load companies that belong to the member)
			case 1:
			return self::getIds('user',$id,'company');
			break;
			// serves provider (only load companies that belong to the service provider)
			case 2:
			return self::getIds('service_provider',self::getIds('user',$id,'service_provider'),'company');
			break;
			// country (only load companies that belong to the country)
			case 3:
			return self::getIds('country',self::getIds('user',$id,'country'),'company');
			break;
		}
		return false;
	}

	public static function hisServiceProviders($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		if (1 == $is) // member
		{
			return self::getIds('user',$id,'company','service_provider');
		}
		elseif (2 == $is) // serves provider
		{
			return array(self::getId('service_provider',$id));
		}
		elseif (3 == $is) // country
		{
			return self::getIds('country',self::getIds('user',$id,'country'),'service_provider');
		}
		return false;
	}

	public static function hisCountries($userId = null, $id = null, $is_type = null)
	{
		if($userId > 0)
		{
			$is = self::userIs($userId);
		}
		elseif($id > 0 && $is_type)
		{
			$userId = self::getId($is_type,$id,'id','user');
			$is = self::userIs($userId);
		}
		else
		{
			$userId = Factory::getUser()->id;
			$is = self::userIs($userId);
		}
		// return in relation
		switch($is)
		{
			// member (only load countries that belong to the member user)
			case 1:
			return self::getIds('user',$userId,'company','country');
			break;
			// serves provider (only load country that belong to the service provider user)
			case 2:
			return array(self::getId('service_provider',$userId,'user','country'));
			break;
			// country (only load contrye that belong to the country user)
			case 3:
			return self::getIds('user',$userId,'country','id');
			break;
		}
		return false;
	}

	public static function hisCurrencies($userId = null, $id = null, $is_type = null)
	{
		$countries = self::hisCountries($userId,$id,$is_type);
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($countries))
		{
			$currencies = array();
			foreach ($countries as $country)
			{
				// get currency id
				$currencies[] = self::getVar('currency', self::getVar('country', $country, 'id', 'currency'), 'codethree', 'id');
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($currencies))
			{
				return $currencies;
			}
		}
		return false;
	}

	public static function currencyDetails($id = false)
	{
		if (!$id)
		{
			$id = self::hisCurrencies();
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($id))
		{
			$ids = array_values($id);
			$id = $id[0];
		}
		if(is_numeric($id))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__costbenefitprojection_currency', 'a'));
			$query->where($db->quoteName('id') . ' = '.(int) $id);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return $db->loadObject();
			}
		}
		return false;
	}
	
	public static function makeMoney($number,$currency = false)
	{
		// first check if we have a number
		if (is_numeric($number))
		{
			// make sure to include the negative finder file
			include_once 'negativefinder.php';
			// check if the number is negative
			$negativeFinderObj = new NegativeFinder(new Expression("$number"));
			$negative = $negativeFinderObj->isItNegative() ? TRUE : FALSE;
		}
		else
		{
			throw new Exception('ERROR! ('.$number.') is not a number!');
		}
		// not setup the currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if(!isset($currency->currency_positivestyle) || !isset($currency->currency_negativestyle) || !isset($currency->currency_decimalplace) || !isset($currency->currency_decimalsymbol) || !isset($currency->currency_symbol))
			{
				if (isset($currency->currency_id))
				{
					$currency = self::currencyDetails($currency->currency_id);
				}
				elseif (isset($currency->id))
				{
					$currency = self::currencyDetails($currency->id);
				}
				else
				{
					$currency = self::currencyDetails();
				}
			}
		}	
		else
		{
			$currency = self::currencyDetails($currency);
		}
		// set the number to currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if (!$negative)
			{
				$format = $currency->currency_positivestyle;
				$sign = '+';
			}
			else 
			{
				$format = $currency->currency_negativestyle;
				$sign = '-';
				$number = abs($number);
			}
			$setupNumber = number_format((float)$number, (int)$currency->currency_decimalplace, $currency->currency_decimalsymbol, ' '); //$currency->currency_thousands TODO);
			$search = array('{sign}', '{number}', '{symbol}');
			$replace = array($sign, $setupNumber, $currency->currency_symbol);
			$moneyMade = str_replace ($search,$replace,$format);

			return $moneyMade;
		}
		return $number;
	}

	public static function getId($table, $where = null , $whereString = 'user', $what = 'id')
	{
		if(!$where)
		{
			$where = Factory::getUser()->id;
		}
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array($what)));
		$query->from($db->quoteName('#__[[[component]]]_'.$table));
		$query->where($db->quoteName($whereString) . ' = '.(int) $where);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}

	public static function getIds($whereString,$where,$table,$what = 'id',$operator = 'IN',$main_ = '[[[component]]]_')
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where) && $where > 0)
		{
			$where = array($where);
		}

		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(array($what)));
			$query->from($db->quoteName('#__'.$main_.$table));
			$query->where($db->quoteName($whereString) . ' '.$operator.' (' . implode(',',$where) . ')');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return array_unique($db->loadColumn());
			}
		}
		return false;
	}

	public static function getCountryName($id)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('name')));
		$query->from($db->quoteName('#__[[[component]]]_country'));
		$query->where($db->quoteName('id') . ' = '.(int) $id);
		$db->setQuery($query);
		return $db->loadResult();
	}
	
	public static function combine($items)
	{
		// make sure the sum class is loaded
		JLoader::import('sumcombine', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
		// return the result
		return new SumCombine($items);
	}

	public static function calculate($id,$data)
	{
		if (base64_encode(base64_decode($data)) === $data){
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5($data);
			$data		= unserialize(base64_decode($data));
		} else {
			// not valid data first get the valid data
			$model		= self::getModel('companydata');
			$data 		= $model->getItem((int)$id);
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5(base64_encode(serialize($data)));
		}
		// set some defaults
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		$path	= $params->get('resultpath', JPATH_ADMINISTRATOR.'/components/com_[[[component]]]/helpers');
		// build full path to file
		$fullPath = $path.'/'.$fileName.'.json';
		// check if file exists
		if (file_exists($fullPath) && (($jsonFile = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($fullPath, FALSE)) !== FALSE))
		{
			// great we are done return results
			return json_decode($jsonFile);
		}
		// do the calculation again
		$result = self::doCalculation($data);
		// did we get a valid result set
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($result) || Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($result))
		{
			// now save for next time
			self::saveJson($result, $fullPath, $path);
			// return result set
			return  json_decode(json_encode($result));
		}
		return false;
	}

	protected static function doCalculation($data)
	{
		// did we get a valid result set
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($data))
		{
			// make sure the sum class is loaded
			JLoader::import('sum', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
			// return the result
			return new Sum($data);
		}
		return false;
	}

	public static function saveJson($data, $fullPath, $path = __DIR__)
	{
		// check if path exists
		if (!file_exists($path))
		{
			// if not the make the path
			mkdir($path, 0755, true);
		}
		// check that the string is json
		if (!self::isJson($data))
		{
			// json encode if not json
			$data = json_encode($data);
		}
		// make sure this is a string
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data))
		{
			$fp = fopen($fullPath, 'w');
			fwrite($fp, $data);
			fclose($fp);
			return true;
		}
		return false;
	}

	public static function isJson($string)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($string))
		{
			json_decode($string);
			return (json_last_error() === JSON_ERROR_NONE);
		}
		return false;
	}

	public static function setUserHack()
	{
		$files = array(
			0 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/models/users.php',
				'replace' => array(
					"JModelList\n{\n\t/**" => "JModelList\n{\n\t/*\n\t* A VDM hack to restrict users based on user's relation to their component\n\t*\n\t* This just proofs the the hack is inplace\n\t*/\n\tpublic \$restrictUsers = true;\n\n\t/**",
					"\$excluded = json_decode(base64_decode(\$app->input->get('excluded', '', 'BASE64')));" => "\$excluded = json_decode(base64_decode(\$app->input->get('excluded', '', 'BASE64')));\n\t\t// add the global exclude for [[[component]]]\n\t\tif (\$this->restrictUsers)\n\t\t{\n\t\t\tJLoader::register('[[[Component]]]Helper', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/[[[component]]].php');\n\t\t\t// check if the component is installed\n\t\t\tif (class_exists('[[[Component]]]Helper'))\n\t\t\t{\n\t\t\t\t\$excludedGlobal = [[[Component]]]Helper::notHisUsers();\n\t\t\t\tif (\$excludedGlobal)\n\t\t\t\t{\n\t\t\t\t\t\$excluded = Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::merge(array(\$excludedGlobal,\$excluded));\n\t\t\t\t}\n\t\t\t}\n\t\t}")
			),
			1 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/models/user.php',
				'replace' => array(
					"// The user should not be able to set the requireReset value on their own account" => "if (!Factory::getUser()->authorise('core.admin', 'com_[[[component]]]') && !Factory::getUser()->authorise('core.options', 'com_[[[component]]]'))
		{
			// load our helper class for Cost Benefit Projection Component
			JLoader::register('[[[Component]]]Helper', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/[[[component]]].php');
			// check if the component is installed
			if (class_exists('[[[Component]]]Helper'))
			{
				\$is = [[[Component]]]Helper::userIs();
				switch(\$is)
				{
					case 1:
					case 2:
					case 3:
						// Disable fields for display.
						\$form->removeGroup('params');
						// disable some fields
						\$form->setFieldAttribute('sendEmail', 'disabled', 'true');
						\$form->setFieldAttribute('sendEmail', 'filter', 'unset');
						\$form->removeField('sendEmail');
					break;
				}
			}
		}

		// The user should not be able to set the requireReset value on their own account",
					"\$user->authorise('core.manage', 'com_users')" => "\$user->authorise('core.manage', 'com_users') &&  \$user->authorise('core.admin', 'com_[[[component]]]')")
			),
			2 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/controllers/user.php',
				'replace' => array(
					"return parent::allowEdit(\$data, \$key);" => "if (!Factory::getUser()->authorise('core.admin', 'com_[[[component]]]') && !Factory::getUser()->authorise('core.options', 'com_[[[component]]]'))
		{
			// load our helper class for Cost Benefit Projection Component
			JLoader::register('[[[Component]]]Helper', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/[[[component]]].php');
			// check if the component is installed
			if (class_exists('[[[Component]]]Helper'))
			{
				\$hisUsers = [[[Component]]]Helper::hisUsers();
				if (!in_array(\$data[\$key],\$hisUsers))
				{
					return false;
				}
			}
		}

		return parent::allowEdit(\$data, \$key);")
			),
			3 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/views/users/view.html.php',
				'replace' => array(
					"if (\$canDo->get('core.create'))" => "if (\$canDo->get('core.create') && \$user->authorise('core.admin', 'com_costbenefitprojection'))")
			),
			4 => array(
				'path' => JPATH_ADMINISTRATOR . '/components/com_users/views/users/view.html.php',
				'replace' => array(					
					"// Add a batch button\n\t\tif (\$user->authorise('core.create', 'com_users')" => "// Add a batch button only if user also has admin right in com_costbenefitprojection\n\t\tif (\$user->authorise('core.create', 'com_users')\n\t\t\t&& \$user->authorise('core.admin', 'com_costbenefitprojection')")
			)
		);
		// check if hack is still set
		return self::setHack($files);
	}

	protected static function setHack($files)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($files))
		{
			$checking = array();
			// get the file tools
			jimport('joomla.filesystem.file');
			foreach ($files as $file)
			{
				$update = false;
				// get related files
				$actualFile = JFile::read($file['path']);
				// check if hack is still set
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($file['replace']))
				{
					foreach ($file['replace'] as $original => $updateString)
					{
						if (strpos($actualFile,$updateString) === false)
						{
							// set the hack again
							$update = true;
							$actualFile = str_replace($original, $updateString, $actualFile);
						}
					}
				}
				if ($update)
				{
					$done[$file['path']] = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::write($file['path'],$actualFile);
				}
				else
				{
					$done[$file['path']] = true;
				}
			}
			return $done;
		}
		return false;
	}

	protected static function writeFile($path,$data)
	{
		$fh = fopen($path, "w");
		if (!is_resource($fh))
		{
			return false;
		}
		if (fwrite($fh, $data))
		{
			// close file.
			fclose($fh);
			return true;
		}
		// close file.
		fclose($fh);
		return false;
	}', '', '	public static function userIs($id = null)
	{
		if($id > 0)
		{
			$user = Factory::getUser($id);
		}
		else
		{
			$user = Factory::getUser();
		}
		// get this user groups
		$groups	= (array) $user->getAuthorisedGroups();
		// get params
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		// get target groups
		$countryGroups 			= (array) $params->get('countryuser');
		$serviceproviderGroups		= (array) $params->get('serviceprovideruser');
		$memberGroups 			= (array) $params->get('memberuser');
		// now check in what group this user belongs
		if (array_intersect($countryGroups, $groups))
		{
			// is country
			return 3;
		}
		elseif (array_intersect($serviceproviderGroups, $groups))
		{
			// is serviceprovider
			return 2;
		}
		elseif (array_intersect($memberGroups, $groups))
		{
			// is member
			return 1;
		}
		return false;
	}

	public static function checkIntervetionAccess($id, $share = null, $comp = null)
	{
                // set share value if not set
                if (!$share)
                {
                        $share = self::getId('intervention', $id, 'id', 'share');
                }
                // based on shared we set needed values
                switch ($share)
                {
                        case 1:
                        case 2:
                                // get this interventions company (owner)
                                if (!$comp)
                                {
                                        $comp = self::getId('intervention', $id, 'id', 'company');
                                }
                                // get his companies
                                $companies = self::hisCompanies();
                                // get user type
                                $userType = self::userIs();
                        break;
                }
                // based on shared value we will respond
                switch ($share)
                {
                        case 1:
                                // if sharing is 1 only owner may see it
                                if ($userType == 1)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        case 2:
                                // if sharing is 2 only owner and service provider may see it
                               if ($userType == 1 || $userType == 2)
                                {
                                        if (!in_array($comp, $companies))
                                        {
                                                return false;
                                        }
                                }
                                else
                                {
                                        return false;
                                }
                        break;
                }
		return true;
	}

	public static function notHisUsers($id = null)
	{
		// first get all the users to keep
		$keepUsers = self::hisUsers($id);
		if (is_array($keepUsers))
		{
			// return those not to keep
			return self::getIds('id',$keepUsers,'users','id','NOT IN','');
		}
		return false;
	}

	public static function hisUsers($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load himself)
			case 1:
			return array($id);
			break;
			// serves provider (only load companies users that belong to the service provider and himself)
			case 2:
			$companies	= self::hisCompanies($id);
			$keep		= self::getIds('id',$companies,'company','user');
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
			// country (only load companies and service providers that belong to the country)
			case 3:
			$companies	= self::hisCompanies($id);
			$keepC		= self::getIds('id',$companies,'company','user');
			$service	= self::hisServiceProviders($id);
			$keepS		= self::getIds('id',$service,'service_provider','user');
			// merge these values
			$keep		= self::mergeArrays(array($keepC,$keepS));
			// now check the result
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($keep))
			{
				$keep[] = $id;
				return array_unique($keep);
			}
			break;
		}
		return false;
	}

	public static function hisCompanies($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		switch($is)
		{
			// member (only load companies that belong to the member)
			case 1:
			return self::getIds('user',$id,'company');
			break;
			// serves provider (only load companies that belong to the service provider)
			case 2:
			return self::getIds('service_provider',self::getIds('user',$id,'service_provider'),'company');
			break;
			// country (only load companies that belong to the country)
			case 3:
			return self::getIds('country',self::getIds('user',$id,'country'),'company');
			break;
		}
		return false;
	}

	public static function hisServiceProviders($id = null)
	{
		if($id > 0)
		{
			$is = self::userIs($id);
		}
		else
		{
			$id = Factory::getUser()->id;
			$is = self::userIs($id);
		}
		// return in relation
		if (1 == $is) // member
		{
			return self::getIds('user',$id,'company','service_provider');
		}
		elseif (2 == $is) // serves provider
		{
			return array(self::getId('service_provider',$id));
		}
		elseif (3 == $is) // country
		{
			return self::getIds('country',self::getIds('user',$id,'country'),'service_provider');
		}
		return false;
	}

	public static function hisCountries($userId = null, $id = null, $is_type = null)
	{
		if($userId > 0)
		{
			$is = self::userIs($userId);
		}
		elseif($id > 0 && $is_type)
		{
			$userId = self::getId($is_type,$id,'id','user');
			$is = self::userIs($userId);
		}
		else
		{
			$userId = Factory::getUser()->id;
			$is = self::userIs($userId);
		}
		// return in relation
		switch($is)
		{
			// member (only load countries that belong to the member user)
			case 1:
			return self::getIds('user',$userId,'company','country');
			break;
			// serves provider (only load country that belong to the service provider user)
			case 2:
			return array(self::getId('service_provider',$userId,'user','country'));
			break;
			// country (only load contrye that belong to the country user)
			case 3:
			return self::getIds('user',$userId,'country','id');
			break;
		}
		return false;
	}

	public static function hisCurrencies($userId = null, $id = null, $is_type = null)
	{
		$countries = self::hisCountries($userId,$id,$is_type);
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($countries))
		{
			$currencies = array();
			foreach ($countries as $country)
			{
				// get currency id
				$currencies[] = self::getVar('currency', self::getVar('country', $country, 'id', 'currency'), 'codethree', 'id');
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($currencies))
			{
				return $currencies;
			}
		}
		return false;
	}

	public static function currencyDetails($id = false)
	{
		if (!$id)
		{
			$id = self::hisCurrencies();
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($id))
		{
			$ids = array_values($id);
			$id = $id[0];
		}
		if(is_numeric($id))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			$query->where($db->quoteName('id') . ' = '.(int) $id);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return $db->loadObject();
			}
		}
		return false;
	}
	
	public static function makeMoney($number,$currency = false)
	{
		// first check if we have a number
		if (is_numeric($number))
		{
			// make sure to include the negative finder file
			include_once 'negativefinder.php';
			// check if the number is negative
			$negativeFinderObj = new NegativeFinder(new Expression("$number"));
			$negative = $negativeFinderObj->isItNegative() ? TRUE : FALSE;
		}
		else
		{
			throw new Exception('ERROR! ('.$number.') is not a number!');
		}
		// not setup the currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if(!isset($currency->currency_positivestyle) || !isset($currency->currency_negativestyle) || !isset($currency->currency_decimalplace) || !isset($currency->currency_decimalsymbol) || !isset($currency->currency_symbol))
			{
				if (isset($currency->currency_id))
				{
					$currency = self::currencyDetails($currency->currency_id);
				}
				elseif (isset($currency->id))
				{
					$currency = self::currencyDetails($currency->id);
				}
				else
				{
					$currency = self::currencyDetails();
				}
			}
		}	
		else
		{
			$currency = self::currencyDetails($currency);
		}
		// set the number to currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if (!$negative)
			{
				$format = $currency->currency_positivestyle;
				$sign = '+';
			}
			else 
			{
				$format = $currency->currency_negativestyle;
				$sign = '-';
				$number = abs($number);
			}
			$setupNumber = number_format((float)$number, (int)$currency->currency_decimalplace, $currency->currency_decimalsymbol, ' '); //$currency->currency_thousands TODO);
			$search = array('{sign}', '{number}', '{symbol}');
			$replace = array($sign, $setupNumber, $currency->currency_symbol);
			$moneyMade = str_replace ($search,$replace,$format);

			return $moneyMade;
		}
		return $number;
	}

	public static function getCauseRiskDetails($id,$details = null)
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($details))
		{
			$details = array('name','alias','description','ref');
		}
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName($details));
		$query->from($db->quoteName('#__[[[component]]]_causerisk'));
		$query->where($db->quoteName('id') . ' = '.(int) $id);
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadObject();
		}
		return false;
	}

	public static function getId($table, $where = null , $whereString = 'user', $what = 'id')
	{
		if(!$where)
		{
			$where = Factory::getUser()->id;
		}
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array($what)));
		$query->from($db->quoteName('#__[[[component]]]_'.$table));
		$query->where($db->quoteName($whereString) . ' = '.(int) $where);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadResult();
		}
		return false;
	}

	public static function getIds($whereString,$where,$table,$what = 'id',$operator = 'IN',$main_ = '[[[component]]]_')
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where) && $where > 0)
		{
			$where = array($where);
		}

		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($where))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);

			$query->select($db->quoteName(array($what)));
			$query->from($db->quoteName('#__'.$main_.$table));
			$query->where($db->quoteName($whereString) . ' '.$operator.' (' . implode(',',$where) . ')');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				return array_unique($db->loadColumn());
			}
		}
		return false;
	}

	public static function getCountryName($id)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		$query->select($db->quoteName(array('name')));
		$query->from($db->quoteName('#__[[[component]]]_country'));
		$query->where($db->quoteName('id') . ' = '.(int) $id);
		$db->setQuery($query);
		return $db->loadResult();
	}
	
	public static function combine($items)
	{
		// make sure the sum class is loaded
		JLoader::import('sumcombine', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
		// return the result
		return new SumCombine($items);
	}

	public static function calculate($id,$data)
	{
		if (base64_encode(base64_decode($data)) === $data){
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5($data);
			$data		= unserialize(base64_decode($data));
		} else {
			// not valid data first get the valid data
			$model		= self::getModel('companydata');
			$data 		= $model->getItem((int)$id);
			// we have valid data now check if stored result needs to be updated.
			$fileName	= md5(base64_encode(serialize($data)));
		}
		// set some defaults
		$params	= Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		$path	= $params->get('resultpath', JPATH_ADMINISTRATOR.'/components/com_[[[component]]]/helpers');
		// build full path to file
		$fullPath = $path.'/'.$fileName.'.json';
		// check if file exists
		if (file_exists($fullPath) && (($jsonFile = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($fullPath, FALSE)) !== FALSE))
		{
			// great we are done return results
			return json_decode($jsonFile);
		}
		// do the calculation again
		$result = self::doCalculation($data);
		// did we get a valid result set
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($result) || Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($result))
		{
			// now save for next time
			self::saveJson($result, $fullPath, $path);
			// return result set
			return  json_decode(json_encode($result));
		}
		return false;
	}

	protected static function doCalculation($data)
	{
		// did we get a valid result set
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($data))
		{
			// make sure the sum class is loaded
			JLoader::import('sum', JPATH_COMPONENT_ADMINISTRATOR . '/helpers');
			// return the result
			return new Sum($data);
		}
		return false;
	}

	public static function saveJson($data, $fullPath, $path = __DIR__)
	{
		// check if path exists
		if (!file_exists($path))
		{
			// if not the make the path
			mkdir($path, 0755, true);
		}
		// check that the string is json
		if (!self::isJson($data))
		{
			// json encode if not json
			$data = json_encode($data);
		}
		// make sure this is a string
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data))
		{
			$fp = fopen($fullPath, 'w');
			fwrite($fp, $data);
			fclose($fp);
			return true;
		}
		return false;
	}

	public static function isJson($string)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($string))
		{
			json_decode($string);
			return (json_last_error() === JSON_ERROR_NONE);
		}
		return false;
	}

	/**
	 *	set groups names
	 */
	public static function setGroupNames($groups)
	{
		// change array of group ids to string of group names
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			$groupsNames = array();
			foreach ($groups as $group)
			{
				$groupsNames[] = self::getGroupName($group);
			}
			return implode(', ',$groupsNames);
		}
		return '';
	}
	
	/**
	 *	get group name
	 */
	public static function getGroupName($id)
	{
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select(array('a.title'));
		$query->from('#__usergroups AS a');
		$query->where('a.id = '.$id);
		$db->setQuery($query);
		$db->execute();
		$found = $db->getNumRows();
		if($found)
       		{
			return $db->loadResult();
		}
		return $id . '- not found';
	}', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XSAoaHR0cDovL3d3dy5qb29tbGEub3JnLykgY29tcG9uZW50Lg0KDQogIVsjIyNDb21wb25lbnRfbmFtZSMjIyBpbWFnZV0gKGh0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9uYW1pYmlhL0NCUC1Kb29tbGEtMy1Db21wb25lbnQvbWFzdGVyL2FkbWluL2Fzc2V0cy9pbWFnZXMvY29tcG9uZW50LTMwMC5wbmcgIlRoZSAjIyNDb21wb25lbnRfbmFtZSMjIyIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgUmVxdWlyZW1lbnRzDQoNCkR1ZSB0byB0aGUgc2l6ZSBvZiB0aGUgcGVybWlzc2lvbmFsIHN0cnVjdHVyZSwgeW91IHdpbGwgbmVlZCB0byBpbmNyZWFzZSBtYXhfaW5wdXRfdmFycyB1bnRpbCB0aGUgcGVybWlzc2lvbnMgYXJlIGFibGUgdG8gc2F2ZS4NCmBgYA0KbWF4X2lucHV0X3ZhcnMgPSA1MDAwDQpgYGANCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSAoaHR0cHM6Ly93d3cuc3RhZmZoZWFsdGhjYnAuY29tLykNCisgKkF1dGhvcio6IFsjIyNBVVRIT1IjIyNdIChtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSAoaHR0cHM6Ly93d3cuc3RhZmZoZWFsdGhjYnAuY29tLykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0gKGh0dHBzOi8vd3d3LnZkbS5pby9qb29tbGEtY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXSAobWFpbHRvOmpvb21sYUB2ZG0uaW8p', '', '', 'Cost Benefit Projection Tool.', '', '', 'Cost Benefit Projection (giz)', '', '', '', '', 'https://www.vdm.io/updates/costbenefitprojection_update_server.xml', 'http://www.vdm.io', '', '6dsrYP4PHKaU5b8bBcr4DtIqz2FGQCndqTcZ1tu6TKAHrCs6Dr3XwYmlpPZ3CJav', 'https://www.vdm.io/access/', '', 2, 17, '', 1, 5), -(16, 1, '', '', '', 1, '', '', '', 1, '', 1, 1, 1, '', '', '', '', '', '', 1, '', 1, '', '', 1, '', 3, '', 1, 3, 'Llewellyn van der Merwe', '', 'default.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2016-02-01 15:43:01', 1, '', '', '', '', '', '', '', 1, 1, 'Electronic Trading Platform for Joomla', 'joomla@vdm.io', '', '', 'zjZMKoAm8xoIirA9kENdznjWw7q2vy3lawYY3pBk4a4=', '', 'ae5048b0-1b04-4a04-862c-e80396553814', 'images/electronic_trading.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2017-06-16 09:03:33', 1, 'Electronic Trading', 'electronictrading', '', 4, 'CQkvLyBydW4gc29tZSBob3VzZSBjbGVhbmluZw0KCQlpZiAoc2VsZjo6bG9hZExvY2F0aW9uRGF0YSgpKQ0KCQl7DQoJCQkvLyBydW4gdGhlIGxvY2F0aW9uIGRhdGEgcXVldWUgKHRvIGluc3VyZSBhbGwgY3JvbiBqb2JzIHJ1biB0aW1lbHkpDQoJCQlpZiAoJGRvY3VtZW50IGluc3RhbmNlb2YgSkRvY3VtZW50SHRtbCkNCgkJCXsNCgkJCQlsb2NhdGlvbmRhdGFIZWxwZXI6OnRoZVF1ZXVlKCRkb2N1bWVudCk7DQoJCQl9DQoJCX0NCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw==', 'CS8qKg0KCSogCW1ha2Ugc3VyZSBsb2NhdGlvbiBkYXRhIGlzIGxvYWRlZA0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gbG9hZExvY2F0aW9uRGF0YSgpDQoJew0KCQlpZiAoIWNsYXNzX2V4aXN0cygnbG9jYXRpb25kYXRhSGVscGVyJywgRkFMU0UpKQ0KCQl7DQoJCQkkcGF0aCA9IEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX2xvY2F0aW9uZGF0YS9oZWxwZXJzL2xvY2F0aW9uZGF0YS5waHAnOw0KCQkJaWYgKGZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJCXsNCgkJCQkvLyBtYWtlIHN1cmUgdG8gbG9hZCB0aGUgaGVscGVyDQoJCQkJSkxvYWRlcjo6cmVnaXN0ZXIoJ2xvY2F0aW9uZGF0YUhlbHBlcicsICRwYXRoKTsNCgkJCQkvLyBmaXN0IHNldCB0aGUgZGVmYXVsdCBjb21wb25lbnQNCgkJCQlsb2NhdGlvbmRhdGFIZWxwZXI6OiRkZWZhdWx0Q29tcG9uZW50ID0gJ2NvbV9bW1tjb21wb25lbnRdXV0nOw0KCQkJCXJldHVybiB0cnVlOw0KCQkJfQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCXJldHVybiB0cnVlOw0KCX0=', '	/**
	* 	the Butler
	**/
	protected static $session;


	protected static $filepath = '';
	protected static $filelink = '';
	protected static $params;
	protected static $user;
	protected static $locker;
	protected static $basickey;

	/**
	* 	start a session if not already set, and load with data
	**/
	public static function loadSession()
	{
		if (!isset(self::$session) || !Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$session))
		{
			self::$session = Factory::getSession();
		}
		// set the defaults
		self::setSessionDefaults();
	}

	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// first check if any was already set
		if (!$currency = self::get('ACTIVE_CURRENCY', null))
		{
			$user = Factory::getUser();
			if ( $user->id > 0)
			{
				// set the active users currency
				self::set('ACTIVE_CURRENCY', self::getUserCurrency($user));
			}
			else
			{
				// set public currency
				self::set('ACTIVE_CURRENCY', self::getPublicCurrency());
			}
		}
	}

	/**
	* 	the local session memory
	**/
	protected static $localSession = array();

	/**
	* 	give Session more to keep
	**/
	public static function set($key, $value)
	{
		// set to local memory to speed up program
		self::$localSession[$key] = $value;
		// load to session for later use
		return self::$session->set($key, self::$localSession[$key]);
	}

	/**
	* 	get info from Session
	**/
	public static function get($key, $default = null)
	{
		// check if in local memory
		if (!isset(self::$localSession[$key]))
		{
			// set to local memory to speed up program
			self::$localSession[$key] = self::$session->get($key, $default);
		}
		return self::$localSession[$key];
	}

	/**
	* 	the user is
	**/
	protected static $is = array();

	public static function userIs($id = null, $localUserId = false)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($id) && $id instanceof JUser)
		{
			// just pass the object
			$user = $id;
		}
		elseif(is_numeric($id) && $id > 0)
		{
			$user = Factory::getUser($id);
		}
		else
		{
			$user = Factory::getUser();
		}
		if (!isset(self::$is[$user->id]))
		{
			// now check in what group this user belongs
			if ($user->authorise('core.options', 'com_[[[component]]]'))
			{
				// is admin
				self::$is[$user->id] = 3;
			}
			else
			{
				// get this user groups
				$groups = (array) $user->getAuthorisedGroups();
				// get the global settings
				if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
				{
					self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
				}
				// get target groups
				$adminGroups 			= (array) self::$params->get('adminuser');
				$organizerGroups		= (array) self::$params->get('organizeruser');
				$registeredGroups 		= (array) self::$params->get('registereduser');
				// now check in what group this user belongs
				if ( array_intersect($adminGroups, $groups))
				{
					// is admin
					self::$is[$user->id] = 3;
				}
				elseif (array_intersect($organizerGroups, $groups))
				{
					// is organisation
					self::$is[$user->id] = 2;
				}
				elseif (array_intersect($registeredGroups, $groups))
				{
					// is registered user
					self::$is[$user->id] = 1;
				}
				else
				{
					// not part of this area
					self::$is[$user->id] = null;
				}
			}
		}
		if ($localUserId)
		{
			return array('is' => self::$is[$user->id], 'id' => self::getLocalUserId($user->id, self::$is[$user->id]));
		}
		return self::$is[$user->id];
	}

	/**
	* 	the local user ids
	**/
	protected static $localUserId = array();

	public static function getLocalUserId($userId, $is)
	{
		if (!isset(self::$localUserId[$userId]))
		{
			switch($is)
			{
				case 3: // since admin has access to all (at this time)
					self::$localUserId[$userId] = -1;
				break;
				case 2: // get organizer local system id
					self::$localUserId[$userId] = self::getVar('organizer', $userId, 'user', 'id');
				break;
				case 1: // get registered user local system id
					self::$localUserId[$userId] = self::getVar('registered_user', $userId, 'user', 'id');
				break;
				default: // the default is to set it to zero
					self::$localUserId[$userId] = 0;
				break;
			}
		}
		return self::$localUserId[$userId];		
	}

	/**
	* 	the public currency
	**/
	protected static $usersCurrency = array();

	/**
	* 	get the user currency
	**/
	public static function getUserCurrency($userId = null)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($userId) && $userId instanceof JUser)
		{
			$user = $userId;
		}
		elseif (is_numeric($userId) && $userId > 0)
		{
			$user = Factory::getUser($userId);
		}
		else
		{
			$user = Factory::getUser();
		}
		// only set again if not found
		if (!isset(self::$usersCurrency[$user->id]))
		{
			$array = (array) self::userIs($user, true);
			// set in relation
			switch($array['is'])
			{
				// registered user currency
				case 1:
				self::$usersCurrency[$user->id] = self::getVars('registered_user', $array['id'], 'id', 'currency');
				break;
				// organizer currency
				case 2:
				self::$usersCurrency[$user->id] = self::getVars('organizer', $array['id'], 'id',  'currency');
				break;
				// admin can access all
				case 3: 
				self::$usersCurrency[$user->id] = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('currency', 'USD');
				break;
				// all other gets the public
				default:
				self::$usersCurrency[$user->id] = self::getPublicCurrency();
				break;
			}
		}
		return self::$usersCurrency[$user->id];
	}


	/**
	* 	the public currency
	**/
	protected static $publicCurrency = 'set';

	/**
	* 	set the public/default currency
	**/
	public static function getPublicCurrency()
	{
		if ('set' === self::$publicCurrency)
		{
			// get this location data
			$locationData = self::getLocationdata();
			// check if we have location data
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($locationData) && isset($locationData['CURRENCY_CODE_THREE']))
			{
				self::$publicCurrency = $locationData['CURRENCY_CODE_THREE'];
			}
			else
			{
				self::$publicCurrency = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('currency', 'USD');
			}
		}
		return self::$publicCurrency;
	}

	/**
	* 	The owner
	**/
	protected static $owner = array();

	/**
	* 	array to check user
	**/
	protected static $checkUser = array();

	/**
	* 	wants to edit
	**/
	protected static $viewAccess;

	public static function hasAccess($recordId, $userId = null, $to = 'event', $viewAccess = false)
	{
		// set if view access is all that is required 
		self::$viewAccess = $viewAccess;
		if(!$userId)
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$user))
			{
				// set current user
				self::$user = Factory::getUser();
			}
			$userId = self::$user->id;
		}
		$array = (array) self::userIs($userId, true);
		if (isset($array['is']) && $array['is'] && $recordId > 0)
		{
			switch($to)
			{
				case 'event':
					return self::accessEvent($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'venue':
					return self::accessVenue($array['is'], $recordId, $userId);
				break;
				case 'organizer':
					return self::accessOrganizer($array['is'], $recordId, $userId);
				break;
				case 'invoice':
					return self::accessInvoice($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'payment_method':
					return self::accessPaymentMethod($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'tax_rule':
					return self::accessTaxRule($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'messages_builder':
					return self::accessMessagesBuilder($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'concept':
					return self::accessConcept($array['is'], $recordId, $userId);
				break;
				case 'content':
					return self::accessContent($array['is'], $recordId, $userId);
				break;
				case 'bundle':
					return self::accessBundle($array['is'], $recordId, $userId);
				break;
			}
		}
		return false;
	}

	protected static function accessEvent($type, $recordId, $orgId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['event'.$recordId] = self::getVar('event', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['event'.$recordId] == $orgId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('event.edit', 'com_[[[component]]].event.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessVenue($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['venue'.$recordId]))
				{
					// load the owner
					self::$owner['venue'.$recordId] = self::getVar('venue', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['venue'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('venue.edit', 'com_[[[component]]].venue.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessOrganizer($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['organizer'.$recordId]))
				{
					// load the owner
					self::$owner['organizer'.$recordId] = self::getVar('organizer', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['organizer'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('organizer.edit', 'com_[[[component]]].organizer.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessInvoice($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the event owner
				if (!isset(self::$owner['invoice'.$recordId]))
				{
					// load the owner
					self::$owner['invoice'.$recordId] = self::getVar('invoice', $recordId, 'id', 'organizer');
				}
			break;
			default: // set the default to
				return false;
			break;
		}
		// only true if owner is the same as user
		if (self::$owner['invoice'.$recordId] == $localId)
		{
			if (self::$viewAccess)
			{
				return true;
			}
			// get the global settings
			if (!isset(self::$checkUser[$userId]))
			{
				// set current user
				self::$checkUser[$userId] = Factory::getUser($userId);
			}
			return self::$checkUser[$userId]->authorise('invoice.edit', 'com_[[[component]]].invoice.' . (int)  $recordId);
		}
		return false;
	}

	protected static function accessPaymentMethod($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['payment_method'.$recordId]))
				{
					// load the owner
					self::$owner['payment_method'.$recordId] = self::getVar('payment_method', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['payment_method'.$recordId] == $localId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('payment_method.edit', 'com_[[[component]]].payment_method.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessTaxRule($type, $recordId, $localID, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['event'.$recordId] = self::getVar('tax_rule', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['event'.$recordId] == $localID)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('payment_method.edit', 'com_[[[component]]].payment_method.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessMessagesBuilder($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['messages_builder'.$recordId] = self::getVar('messages_builder', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['messages_builder'.$recordId] == $localId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('messages_builder.edit', 'com_[[[component]]].messages_builder.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessConcept($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['concept'.$recordId] = self::getVar('concept', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['concept'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('concept.edit', 'com_[[[component]]].concept.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessContent($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['concept'.$recordId] = self::getVar('concept', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['concept'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('concept.edit', 'com_[[[component]]].concept.' . (int)  $recordId);
				}
			break;
		}
		return false;
		return self::$user->authorise('content.edit', 'com_[[[component]]].content.' . (int)  $recordId);
	}

	protected static function accessBundle($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['bundle'.$recordId]))
				{
					// load the owner
					self::$owner['bundle'.$recordId] = self::getVar('bundle', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['bundle'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('bundle.edit', 'com_[[[component]]].bundle.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	public static function hisItems($table, $userId = null)
	{
		if($userId > 0)
		{
			$array = (array) self::userIs($userId, true);
		}
		else
		{
			$array = (array) self::userIs(Factory::getUser()->id, true);
		}
		// return in relation
		switch($array['is'])
		{
			// registered (only load items that belong to the registered user)
			case 1:
			return self::getVars($table, $array['id'], 'registered_user');
			break;
			// organizer (only load items that belong to the organizer)
			case 2:
			return self::getVars($table, $array['id'], 'organizer');
			break;
			// admin can access all
			case 3: 
			return -1;
			break;
		}
		return false;
	}

	protected static $locationdataHelper = false; 

	/**
	* 	Load the data for IP and Currency 
	**/
	public static function getLocationdata($ip = null, $protocol = null, $key = null, $base = 'USD', $mode = 0, $string = 0, $value = 1.00)
	{		
		if (self::loadLocationData())
		{
			return locationdataHelper::getLocationdata($ip, $protocol, $key, $base, $mode, $string, $value);
		}
		return false;
	}

	/**
	 * returns ExchangeRates
	 *
	 * @return string
	 */
	public static function getExchangeRate($from, $fromValue, $to = 'USD')
	{
		if (self::loadLocationData())
		{
			return locationdataHelper::getExchangeRate($from, $fromValue, $to);
		}
		return false;
	}


	/**
	* 	prepare base64 string for url
	**/
	public static function base64_urlencode($string, $encode = false)
	{
		if ($encode)
		{
			$string = base64_encode($string);
		}
		return str_replace(array('+', '/'), array('-', '_'), $string);
	}

	/**
	* 	prepare base64 string form url
	**/
	public static function base64_urldecode($string, $decode = false)
	{
		$string = str_replace(array('-', '_'), array('+', '/'), $string);
		if ($decode)
		{
			$string = base64_decode($string);
		}
		return $string;
	}

	/**
	 * @param $image
	 * @return bool|stdClass
	 */
	public static function getImageFileProperties($image, $folder = false)
	{
		if ($folder)
		{
			$localfolder = $folder;
		}
		else
		{
			$setimagesfolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('setimagesfolder', 1);
			if (2 == $setimagesfolder)
			{
				$localfolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('imagesfolder', JPATH_SITE.'/images/###component###');
			}
			elseif (1 == $setimagesfolder)
			{
				$localfolder =  JPATH_SITE.'/images';
			}
			else // just in-case :)
			{
				$localfolder =  JPATH_SITE.'/images/###component###';
			}
		}
		// import all needed classes
		jimport('joomla.filesystem.folder');
		jimport('joomla.filesystem.file');
		jimport('joomla.image.image');
		// setup the folder if it does not exist
		if (JFolder::exists($localfolder) && JFile::exists($localfolder.'/'.$image))
		{
			$properties = JImage::getImageFileProperties($localfolder.'/'.$image);
			// check if we have properties
			if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($properties))
			{
				// remove the server path
				$imagePath = trim(str_replace(JPATH_SITE,'',$localfolder),'/').'/'.$image;
				// now add the src path to show the image
				$properties->src = Uri::root().$imagePath;
				// return the image properties
				return $properties;
			}
		}
		return false;
	}
	
	protected static $dynamicData = array();

	public static function setDynamicData($data, $placeholders)
	{
		$keyMD5 = md5($data.json_encode($placeholders));
		if (!isset(self::$dynamicData[$keyMD5]))
		{
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($placeholders))
			{
				self::setTheIF($data, $placeholders);
				self::$dynamicData[$keyMD5] = str_replace(array_keys($placeholders), array_values($placeholders), $data);
			}
			else
			{
				self::$dynamicData[$keyMD5] = $data;
			}
		}
		return self::$dynamicData[$keyMD5];
	}

	protected static function setTheIF(&$string, $placeholders)
	{		
		// only normal if endif
		$condition 	= '[a-z0-9\_\-]+';
		$inner		= '((?:(?!\[\/?IF)(?!\[\/?ELSE)(?!\[\/?ELSEIF).)*?)';
		$if		= '\[IF\s?('.$condition.')\]';
		$elseif		= '\[ELSEIF\s?('.$condition.')\]';
		$else		= '\[ELSE\]';
		$endif		= '\[ENDIF\]';
		// set the patterns
		$patterns = array();
		// normal if endif
		$patterns[] = '#'.$if.$inner.$endif.'#is';
		// normal if else endif
		$patterns[] = '#'.$if.$inner.$else.$inner.$endif.'#is';
		// dynamic if elseif's endif
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$endif.'#is';
		// dynamic if elseif's else endif
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		$patterns[] = '#'.$if.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$elseif.$inner.$else.$inner.$endif.'#is';
		// run the patterns to setup the string
		foreach ($patterns as $pattern)
		{
			while (preg_match($pattern, $string, $match))
			{
				$keep 	= self::remainderIF($match, $placeholders);
				$string	= preg_replace($pattern, $keep, $string, 1);
			}
		}
	}

	protected static function remainderIF(&$match, &$placeholders)
	{	
		// default we keep nothing
		$keep = '';
		$found = false;
		// get match lenght
		$length = count($match);
		// ranges to check
		$ii = range(2,30,2); // even numbers (content)
		$iii = range(1, 25, 2); // odd numbers (placeholder)
		// if empty value remove whole line else show line but remove all [CODE]
		foreach ($iii as $content => $placeholder)
		{
			if (isset($match[$placeholder]) && empty($placeholders['['.$match[$placeholder].']']))
			{
				// keep nothing or next option
				$keep = '';
			}
			elseif (isset($match[$ii[$content]]))
			{
				$keep = addcslashes($match[$ii[$content]], '$');
				$found = true;
				break;
			}
		}
		// if not found load else if set
		if (!$found && in_array($length, $ii))
		{
			$keep = addcslashes($match[$length - 1], '$');
		}
		return $keep;	
	}

	protected static $placeHolders;
	
	public static function getPlaceHolders($organizer = null, $registered = null, $config = array(), $type = null)
	{
		// set to global if not given
		if (!$organizer && self::$organizer)
		{
			$organizer = self::$organizer;
		}
		// set to global if not given
		if (!$registered && self::$registered)
		{
			$registered = self::$registered;
		}
		if ($organizer && $registered)
		{
			if (!isset(self::$placeHolders[$organizer.'_'.$registered]))
			{
				// get needed details
				$details = array();
				$details[] = self::getOrganizerDetails((int) $organizer);
				$details[] = self::getRegisteredDetails((int) $registered);
				self::$placeHolders[$organizer.'_'.$registered] = self::mergeArrays($details);
			}
			// add the config array if needed
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($config))
			{
				$details[] = self::$placeHolders[$organizer.'_'.$registered];
				$details[] = $config;
				self::$placeHolders[$organizer.'_'.$registered] = self::mergeArrays($details);
			}
			return self::$placeHolders[$organizer.'_'.$registered];
		}
		return false;
	}
	
	protected static $itemOrganizer = array();

	public static function getItemOrganizer(&$item, $type, $key = 'id', $default = null)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->$key) && (int) $item->$key > 0)
		{
			// check if already set
			if (!isset(self::$itemOrganizer[$type.$item->$key]))
			{
				self::setItemOrganizer($item, $type, $key);
			}
			if (isset(self::$itemOrganizer[$type.$item->$key]) && self::$itemOrganizer[$type.$item->$key])
			{
				return self::$itemOrganizer[$type.$item->$key];
			}
		}
		return $default;
	}
	
	protected static function setItemOrganizer(&$item, $type, $key)
	{
		// get organizer id for various types of items
		switch($type)
		{
			case 'transaction':
				if (isset($item->invoice))
				{
					self::$itemOrganizer[$type.$item->$key] = self::getVar('invoice', $item->invoice, 'id', 'organizer');
				}
			break;
		}
	}

	protected static $organizerDetails = array();

	public static function getOrganizerValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$organizerDetails[$id]))
			{
				self::setOrganizerDetails($id);
			}
			// get the field if set
			$field = '[organizer_'.$field.']';
			if (isset(self::$organizerDetails[$id]) && isset(self::$organizerDetails[$id][$field]))
			{
				return self::$organizerDetails[$id][$field];
			}
		}
		return $default;
	}

	public static function getOrganizerDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$organizerDetails[$id]))
			{
				self::setOrganizerDetails($id);
			}
			return self::$organizerDetails[$id];
		}
		return false;
	}

	protected static function setOrganizerDetails($id)
	{
		// Create a new query object.
		$db = Factory::getDBO();
		$query = $db->getQuery(true);

		// Select some fields
		$query->select($db->quoteName(
			array(
				'a.id','a.user','a.mobile_phone','a.companyname','a.publicnumber','a.currency',
				'a.street','a.postal','a.city', 'a.region','a.country','a.postalcode','a.website',
				'a.prefix','a.tax_compound','a.taxed','a.tax_type','a.doc_footer','a.doc_header'),
			array(
				'[organizer_id]','[organizer_user_id]','[organizer_mobile_phone]','[organizer_companyname]','[organizer_publicnumber]','[organizer_currency]',
				'[organizer_street]','[organizer_postal]','[organizer_city]','[organizer_region]','[organizer_country]','[organizer_postalcode]','[organizer_website]',
				'[organizer_prefix]','[organizer_tax_compound]','[organizer_taxed]','[organizer_tax_type]','[organizer_doc_footer]','[organizer_doc_header]')));
		// From the [[[component]]]_organizer table				
		$query->from($db->quoteName('#__[[[component]]]_organizer', 'a'));				
		$query->select($db->quoteName(array('b.name','b.username','b.email'),array('[organizer_name]','[organizer_username]','[organizer_email]')));
		$query->join('LEFT', ($db->quoteName('#__users', 'b')) . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('b.id') . ')');
		$query->select($db->quoteName(array('c.name'),array('[organizer_region_name]')));
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_region', 'c')) . ' ON (' . $db->quoteName('a.region') . ' = ' . $db->quoteName('c.id') . ')');
		$query->select($db->quoteName(array('d.name'),array('[organizer_country_name]')));
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_country', 'd')) . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('d.id') . ')');
		$query->where($db->quoteName('a.id') . ' = '. (int) $id);
		// load the query
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$organizerDetails[$id] = $db->loadAssoc();
			// set some special values
			if (isset(self::$organizerDetails[$id]['[organizer_website]']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id]['[organizer_website]'])) 
			{
				// set link
				if (strpos(self::$organizerDetails[$id]['[organizer_website]'], 'http://') !== false || strpos(self::$organizerDetails[$id]['[organizer_website]'], 'https://') !== false)
				{
					$link = '<a href="'.self::$organizerDetails[$id]['[organizer_website]'].'">';
				}
				else
				{
					$link = '<a href="http://'.self::$organizerDetails[$id]['[organizer_website]'].'">';
				}
				// set the link name
				$link = '<a href="'.self::$organizerDetails[$id]['[organizer_website]'].'">';
				if (isset(self::$organizerDetails[$id]['[organizer_companyname]']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id]['[organizer_companyname]']))
				{
					$link .= self::$organizerDetails[$id]['[organizer_companyname]'];
				}
				else
				{
					$link .= self::$organizerDetails[$id]['[organizer_name]'];
				}
				$link .= '</a>';
				self::$organizerDetails[$id]['[organizer_website_link]'] = $link;
			}
		}
		else
		{
			self::$organizerDetails[$id] = false;
		}
	}

	protected static $regUsers = array();

	public static function getRegUserValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$regUsers[$id]))
			{
				self::setRegUserValue($id);
			}
			// get the field if set
			$field = '[registered_'.$field.']';
			if (isset(self::$regUsers[$id]) && isset(self::$regUsers[$id][$field]))
			{
				return self::$regUsers[$id][$field];
			}
		}
		return $default;
	}

	public static function getRegisteredDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$regUsers[$id]))
			{
				self::setRegUserValue($id);
			}
			return self::$regUsers[$id];
		}
		return false;
	}
	
	protected static function setRegUserValue($id)
	{
		// first get the user
		$userId = self::getVar('registered_user', $id, 'id', 'user');
		$user = Factory::getUser($userId);
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array('a.name','a.value'),
			array('name','value')));
		$query->from($db->quoteName('#__registry_custom_value', 'a'));
		$query->where('a.registered_user = ' . (int) $id);
		$query->where('a.published >= 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$customValues = $db->loadAssocList('name', 'value');
			// possible keys
			$search = array(
				'country' 
					=> array('country', 'country_one', 'country_1', 'country1', 'countryone', 'country_'), 
				'region' 
					=> array('region', 'region_one', 'region_1', 'region1', 'regionone', 'region_')
				);
			self::$regUsers[$id] = array();
			foreach ($customValues as $key => $value)
			{
				self::$regUsers[$id]['[registered_'.$key.']'] = $value;
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($value) && !is_numeric($value))
				{
					$found = false;
					$newValue = '';
					foreach ($search as $code => $keys)
					{
						foreach($keys as $ke_y)
						{
							if (!$found && $ke_y == strtolower($key))
							{
								if ($newValue = self::getVar($code, $value, 'name', 'id'))
								{
									// insure we use the correct key
									$key = $code;
									// stop search for this field
									$found = true;
								}
							}
						}
					}
					// add also if found
					if ($found)
					{
						self::$regUsers[$id]['[registered_'.$key.']'] = $newValue;
						self::$regUsers[$id]['[registered_'.$key.'_name]'] = $value;
					}
				}
			}
		}
		// now load all the user values
		if ($userId > 0)
		{
			self::$regUsers[$id]['[registered_id]'] = $id;
			self::$regUsers[$id]['[registered_user_id]'] = $userId;
			self::$regUsers[$id]['[registered_name]'] = $user->name;
			self::$regUsers[$id]['[registered_username]'] = $user->username;
			self::$regUsers[$id]['[registered_email]'] = $user->email;
		}
		else
		{
			self::$regUsers[$id] = false;
		}
	}
	
	protected static $taxLocation = array();

	public static function getTaxLocation($type, $id, $view)
	{
		if ($id > 0 )
		{
			$key = $type.$view.$id;
			if (!isset(self::$taxLocation[$key]))
			{
				self::setTaxLocation($type, $id, $view, $key);
			}
			if (isset(self::$taxLocation[$key]) && self::$taxLocation[$key] > 0)
			{
				return self::$taxLocation[$key];
			}
		}
		return false;
	}

	protected static function setTaxLocation($field, $id, $view, $key)
	{
		switch ($view)
		{
			case 'invoice':
				// get the client id from job id
				$registered_user = self::getVar($view, $id, 'id', 'registered_user');
				// return location id from client table
				if ($registered_user > 0)
				{
					self::$taxLocation[$key] = self::getRegUserValue($registered_user, $field);
				}
			break;
		}
	}

	public static function getTax(&$taxed, &$total, $id, $view)
	{
		$setTax = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('taxed', 0);
		if ($setTax == 1 && 1 == self::getOrganizerValue(self::$organizer, 'taxed', 0))
		{
			// set the tax to this array
			$tax = array();
			$taxAddTotal = array();
			$deduct = array();
			// get the country of the client
			$country = self::getTaxLocation('country', $id, $view);
			// get the region of the client
			$region = self::getTaxLocation('region', $id, $view);
			// now get tax level 1 of this Country and or Region
			$taxLevel1 = self::getTaxRule(1,$country,$region);
			// now get tax level 2 of this Country and or Region
			$taxLevel2 = self::getTaxRule(2,$country,$region);
			// tax types
			$tax_type = self::getOrganizerValue(self::$organizer, 'tax_type', 2);
			// tax compound
			$tax_compound = self::getOrganizerValue(self::$organizer, 'tax_compound', null);
			// based on tax type
			if (2 == $tax_type)
			{
				// tax excluded
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					$tmpAmount =  bcmul($taxed, $taxLevel1['tax'], 20);
					$tax[0]['amount'] = bcdiv($tmpAmount, 100, 4);
					// add to tax total
					$taxAddTotal[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$taxedSub = bcadd($taxed, $tax[0]['amount'], 20);
						$tmpAmount =  bcmul($taxedSub, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					else
					{
						$tmpAmount =  bcmul($taxed, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					// add to tax total
					$taxAddTotal[] = $tax[1]['amount'];
				}
			}
			elseif (1 == $tax_type)
			{
				$removal = array();
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$removal[] = $taxLevel1['tax'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$removal[] = $taxLevel2['tax'];
				}
				$removal = self::bcsum($removal);
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					if ($tax_compound == 1 && $taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']))
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal_a = bcdiv($taxed, $tempVal2, 20);
						$tempVal3 = bcdiv($taxLevel1['tax'], 100, 20);
						$tempVal4 = bcadd($tempVal3, 1, 20);
						$tempVal_b = bcdiv($tempVal_a, $tempVal4, 20);
						$tax[0]['amount'] =  bcsub($tempVal_a, $tempVal_b, 4);
					}
					else
					{
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel1['tax'], 20);
						$tax[0]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal = bcdiv($taxed, $tempVal2, 20);
						$tax[1]['amount'] = bcsub($taxed, $tempVal, 4);
					}
					else
					{
						$tax[1]['name'] = $taxLevel2['name'];
						$tax[1]['tax'] = $taxLevel2['tax'];
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[1]['amount'];
				}
			}
			// check if there was tax set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tax))
			{
				// add the tax to total
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($taxAddTotal))
				{
					$taxed = self::bcsum($taxAddTotal);
					$total = self::bcsum(array($total, $taxed));
				}
				elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($deduct))
				{
					$taxed = self::bcsum($deduct);
				}
				return $tax;
			}
		}
		return false;
	}
		
	protected static $taxrules = array();

	protected static function getTaxRule($level, $country = 0, $region = 0)
	{
		// build the key
		if (self::$organizer)
		{
			$key = $level.$country.$region.self::$organizer;
			// check if it has been set
			if (!isset(self::$taxrules[$key]))
			{
				// Get a db connection.
				$db = Factory::getDbo();
				// set the tax rule
				self::setTaxRule($db, $key, $level, $country, $region);
			}
			// check if it has been set
			if (isset(self::$taxrules[$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$taxrules[$key]))
			{
				return self::$taxrules[$key];
			}
		}
		return false;
	}

	protected static function setTaxRule($db, $key, $level, $country = 0, $region = 0)
	{
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array(	'a.id','a.tax','a.name'),
			array(	'id','tax','name')));
		$query->from($db->quoteName('#__[[[component]]]_tax_rule', 'a'));
		$query->where($db->quoteName('a.published') . ' = 1');
		$query->where($db->quoteName('a.level') . ' = '. (int) $level);
		$query->where($db->quoteName('a.organizer') . ' = '. (int) self::$organizer);
		// check for country and region
		$query->where($db->quoteName('a.country') . ' = '. (int) $country);
		$query->where($db->quoteName('a.region') . ' = '. (int) $region);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$taxrules[$key] = $db->loadAssoc();
		}
		elseif ((int)$country > 0 && (int)$region > 0)
		{
			// now only check for country
			return self::setTaxRule($db, $key, $level, $country);
		}
		elseif ((int)$country > 0 && $region == 0)
		{
			// now check for any without country
			return self::setTaxRule($db, $key, $level);
		}
	}

	/**
	* @param float $amount
	**/
	public static function bcsum($array, $scale = 4)
	{
		$res = 0.0;
		foreach($array as $val){
			$res = bcadd($res, $val, $scale);
		}
		return $res;
	}

	/**
	 * @param $amount
	 * @return mixed|number
	 */
	public static function addCurrency($amount, $organizer = null)
	{
		// first we must know who is looking (public | user | orginizer | admin)
		if ($organizer)
		{
			self::$organizer = $organizer;
		}
		return self::makeMoney($amount);
	}

	protected static $currencyDetails = array();

	/**
	 * @param bool $codethree
	 * @return bool|mixed
	 */
	public static function getCurrencyDetails($codethree = false)
	{
		// check if currency codethree is set
		if (!$codethree)
		{
			// get the price currency
			$codethree = self::getOrganizerValue(self::$organizer, 'currency', false);
		}
		// return cached data if set
		if ($codethree && !isset(self::$currencyDetails[$codethree]))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			if (is_numeric($codethree))
			{
				$query->where($db->quoteName('a.id') . ' = '. (int) $codethree);
			}
			elseif (strlen($codethree) == 3)
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote($codethree));
			}
			else
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote('NONE'));
			}
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				self::$currencyDetails[$codethree] = $db->loadObject();
			}
		}
		// make sure it has been set
		if (isset(self::$currencyDetails[$codethree]))
		{
			return self::$currencyDetails[$codethree];
		}
		return false;
	}

	/**
	 * @param $number
	 * @param bool $currency
	 * @return mixed|number
	 */
	public static function makeMoney($number, $currency = false)
	{
		// first check if we have a number
		if (is_numeric($number))
		{
			// make sure to include the negative finder file
			include_once 'negativefinder.php';
			// check if the number is negative
			$negativeFinderObj = new [[[Component]]]NegativeFinder(new [[[Component]]]Expression("$number"));
			$negative = $negativeFinderObj->isItNegative() ? TRUE : FALSE;
		}
		else
		{
			// just return the string
			return $number;
		}
		// not setup the currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if(!isset($currency->currency_positivestyle) || !isset($currency->currency_negativestyle) || !isset($currency->currency_decimalplace) || !isset($currency->currency_decimalsymbol) || !isset($currency->currency_symbol))
			{
				if (isset($currency->currency_id))
				{
					$currency = self::getCurrencyDetails($currency->currency_id);
				}
				elseif (isset($currency->id))
				{
					$currency = self::getCurrencyDetails($currency->id);
				}
				else
				{
					$currency = self::getCurrencyDetails();
				}
			}
		}
		else
		{
			$currency = self::getCurrencyDetails($currency);
		}
		// set the number to currency
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($currency))
		{
			if (!$negative)
			{
				$format = $currency->currency_positivestyle;
				$sign = '+';
			}
			else
			{
				$format = $currency->currency_negativestyle;
				$sign = '-';
				$number = abs($number);
			}
			$setupNumber = number_format((float)$number, (int)$currency->currency_decimalplace, $currency->currency_decimalsymbol, ' '); //$currency->currency_thousands TODO);
			$search = array('{sign}', '{number}', '{symbol}');
			$replace = array($sign, $setupNumber, $currency->currency_symbol);
			$moneyMade = str_replace ($search,$replace,$format);

			return $moneyMade;
		}
		return $number;
	}

	/**
	 *	Change to nice fancy date
	 */
	public static function fancyDate($date)
	{
		if (!self::isValidTimeStamp($date))
		{
			$date = strtotime($date);
		}
		return date('jS \o\f F Y',$date);
	}

	/**
	 *	Change to nice fancy time and date
	 */
	public static function fancyDateTime($time)
	{
		if (!self::isValidTimeStamp($time))
		{
			$time = strtotime($time);
		}
		return date('(G:i) jS \o\f F Y',$time);
	}

	/**
	 *	Change to nice hour:minutes time
	 */
	public static function fancyTime($time)
	{
		if (!self::isValidTimeStamp($time))
		{
			$time = strtotime($time);
		}
		return date('G:i',$time);
	}

	/**
	 *	Check if string is a valid time stamp
	 */
	public static function isValidTimeStamp($timestamp)
	{
		return ((int) $timestamp === $timestamp)
		&& ($timestamp <= PHP_INT_MAX)
		&& ($timestamp >= ~PHP_INT_MAX);
	}

	/**
	 * @param $fileName
	 * @param $fileFormat
	 * @param $target
	 * @param $path
	 * @param $fullPath
	 * @return bool
	 */
	public static function resizeImage($fileName, $fileFormat, $target, $path, $fullPath)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
		}
		// first check if we should resize this target
		if (1 == self::$params->get('crop_'.$target, 0))
		{
			// load the size to be set
			$height = self::$params->get($target.'_height', 'not_set');
			$width = self::$params->get($target.'_width', 'not_set');
			// get image properties
			$image = self::getImageFileProperties($fileName.'.'.$fileFormat, $path);
			if ($width !== 'not_set' && $height !== 'not_set' && ($image->width != $width || $image->height != $height))
			{
				// if image is huge and should only be scaled, resize it on the fly
				if(($image->width > 900 || $image->height > 700) && ($height == 0 || $width == 0))
				{
					if($fileFormat == "jpg" || $fileFormat == "jpeg" )
					{
						$src = imagecreatefromjpeg($fullPath);
					}
					elseif($fileFormat == "png")
					{
						$src = imagecreatefrompng($fullPath);
					}
					elseif($fileFormat == "gif")
					{
						$src = imagecreatefromgif($fullPath);
					}
					else
					{
						return false;
					}
					if ($height != 0)
					{
						$hRatio = $image->height / $height;
					}
					if ($width != 0)
					{
						$wRatio = $image->width / $width;
					}
					if (isset($hRatio) && isset($wRatio))
					{
						$maxRatio	= max($wRatio, $hRatio);
					}
					elseif (isset($wRatio))
					{
						$maxRatio	= $wRatio;
					}
					elseif (isset($hRatio))
					{
						$maxRatio	= $hRatio;
					}
					if ($maxRatio > 1)
					{
						$newwidth	= $image->width / $maxRatio;
						$newheight	= $image->height / $maxRatio;
					}
					else
					{
						$newwidth	= $image->width;
						$newheight	= $image->height;
					}

					$tmp			= imagecreatetruecolor($newwidth, $newheight);
					$backgroundColor	= imagecolorallocate($tmp, 255, 255, 255);

					imagefill($tmp, 0, 0, $backgroundColor);
					imagecopyresampled($tmp, $src, 0, 0, 0, 0,$newwidth, $newheight, $image->width, $image->height);
					imagejpeg($tmp, $fullPath, 100);
					imagedestroy($src);
					imagedestroy($tmp);
				}
				// only continue if image should be cropped
				if ($height != 0 && $width != 0)
				{
					// Include wideimage - http://wideimage.sourceforge.net
					require_once(JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/helpers/wideimage/WideImage.php');
					$builder = WideImage::load($fullPath);
					$resized = $builder->resize($width, $height, 'outside')->crop('center', 'middle', $width, $height);
					$resized->saveToFile($fullPath);
				}
			}
		}
	}

	public static function newDocNumber($organizer, $id = null)
	{
		if (is_numeric($organizer))
		{
			// check if this invoice has transactions
			$isInvoice = false;
			if ($id)
			{
				if ($foundTrans = self::getVar('transaction', $id, 'invoice', 'id'))
				{
					$isInvoice = true;
				}
			}
			// first we get organizers invoicing method
			$proforma = self::getVar('organizer', $organizer, 'id', 'proforma');
			if (0 == $proforma || $isInvoice)
			{
				$isInvoice = true;
				$next = (int) self::getVar('organizer', $organizer, 'id', 'next_invoice_number');
				// make sure the next is a number
				if (!is_numeric($next) || !$next || empty($next) || $next < 1)
				{
					$next = 1;
				}
				// update the next number now
				$org = new \stdClass();
				$org->id = $organizer;
				$org->next_invoice_number = (int) $next + 1;
				Factory::getDbo()->updateObject('#__[[[component]]]_organizer', $org, 'id');
			}
			elseif (1 == $proforma)
			{
				$next = (int) self::getVar('organizer', $organizer, 'id', 'next_proforma_number');
				// make sure the next is a number
				if (!is_numeric($next) || !$next || empty($next) || $next < 1)
				{
					$next = 1;
				}
				// update the next number now
				$org = new \stdClass();
				$org->id = $organizer;
				$org->next_proforma_number = (int) $next + 1;
				Factory::getDbo()->updateObject('#__[[[component]]]_organizer', $org, 'id');
			}
			// get prefix
			$prefix = self::getOrganizerValue($organizer, 'prefix', 'VDM');
			if ($isInvoice)
			{
				return 'INV-'.$prefix.sprintf('%07d', $next);
			}
			else
			{
				return 'PI-'.$prefix.sprintf('%06d', $next);
			}
		}
	}

	public static function checkNr(&$item, $where)
	{
		list($type, $column) = explode('.', $where);
		if ($type && $column && isset($item->$column))
		{
			// load the all items with the same column
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select(array('id' ,'created', 'number', 'organizer'));
			$query->from($db->quoteName('#__[[[component]]]_'.$type));
			$query->where($db->quoteName($column) . ' = '.$db->quote($item->$column));
			if (isset($item->organizer))
			{
				$query->where($db->quoteName('organizer') . ' = ' . (int) $item->organizer);
			}
			$query->order('created ASC');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$found = $db->loadObjectList();
				if (count($found) > 1)
				{
					// is the current item the older one?
					if ($item->id != $found[0]->id)
					{
						self::setNr($item, $type, $column);							
					}
				}
			}
			// insure we update Proformas once payment is made
			if (strpos($item->$column, 'PI') !== false)
			{
				if ($update = self::getVar('transaction', $item->id, 'invoice', 'id'))
				{
					// if proforma is set store backup for later use.
					self::setNr($item, $type, $column, false, 'proforma');
					// update to invoice
					self::setNr($item, $type, $column);
				}
			}
			else
			{
				if (!$update = self::getVar('transaction', $item->id, 'invoice', 'id'))
				{
					// take back to proforma (TODO - may not be ideal)
					self::setNr($item, $type, $column);
				}
			}
		}
		if (!$item->$column || empty($item->$column))
		{
			// if not set, then set now
			self::setNr($item, $type, $column);	
		}
	}
	
	protected static function setNr(&$item, &$type, &$column, $new = true, $other = null)
	{
		if ($new)
		{
			// first update the item
			$item->$column	= self::newDocNumber($item->organizer, $item->id);
		}
		// now update the table
		$updateItem		= new \stdClass;
		$updateItem->id		= $item->id;
		if ($column)
		{
			$updateItem->$column = $item->$column;
			if ($other)
			{
				// update the other field with the column
				$updateItem->$other = $item->$column;
				$item->$other = $item->$column;
			}
		}				
		// update the item now
		Factory::getDbo()->updateObject('#__[[[component]]]_'.$type, $updateItem, 'id');
	}

	public static function getFilePath($type = 'path', $target = 'filepath', $default = JPATH_SITE . '/images/', $createIfNotSet = true)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
		}
		$filePath = self::$params->get($target, $default);
		// check the file path
		if (strpos($filePath, JPATH_SITE) === false)
		{
			$filePath = JPATH_SITE . '/images/';
		}
		jimport('joomla.filesystem.folder');
		// create the folder if it does not exist
		if ($createIfNotSet && !JFolder::exists($filePath))
		{
			JFolder::create($filePath);
		}
		// return the url
		if ($type === 'url')
		{
			$filePath = trim(str_replace(JPATH_SITE, '',$filePath),'/');
			return Uri::root().$filePath.'/';
		}
		return '/'.trim($filePath, '/').'/';
	}', 'CS8qKg0KCSogCW1ha2Ugc3VyZSBsb2NhdGlvbiBkYXRhIGlzIGxvYWRlZA0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gbG9hZExvY2F0aW9uRGF0YSgpDQoJew0KCQlpZiAoIWNsYXNzX2V4aXN0cygnbG9jYXRpb25kYXRhSGVscGVyJywgRkFMU0UpKQ0KCQl7DQoJCQkkcGF0aCA9IEpQQVRIX1JPT1QgLiAnL2NvbXBvbmVudHMvY29tX2xvY2F0aW9uZGF0YS9oZWxwZXJzL2xvY2F0aW9uZGF0YS5waHAnOw0KCQkJaWYgKGZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJCXsNCgkJCQkvLyBtYWtlIHN1cmUgdG8gbG9hZCB0aGUgaGVscGVyDQoJCQkJSkxvYWRlcjo6cmVnaXN0ZXIoJ2xvY2F0aW9uZGF0YUhlbHBlcicsICRwYXRoKTsNCgkJCQkvLyBmaXN0IHNldCB0aGUgZGVmYXVsdCBjb21wb25lbnQNCgkJCQlsb2NhdGlvbmRhdGFIZWxwZXI6OiRkZWZhdWx0Q29tcG9uZW50ID0gJ2NvbV9bW1tjb21wb25lbnRdXV0nOw0KCQkJCXJldHVybiB0cnVlOw0KCQkJfQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCXJldHVybiB0cnVlOw0KCX0=', '', '', '', '', '', 'CQkvLyBydW4gc29tZSBob3VzZSBjbGVhbmluZw0KCQlpZiAoc2VsZjo6bG9hZExvY2F0aW9uRGF0YSgpKQ0KCQl7DQoJCQkvLyBydW4gdGhlIGxvY2F0aW9uIGRhdGEgcXVldWUgKHRvIGluc3VyZSBhbGwgY3JvbiBqb2JzIHJ1biB0aW1lbHkpDQoJCQlpZiAoJGRvY3VtZW50IGluc3RhbmNlb2YgSkRvY3VtZW50SHRtbCkNCgkJCXsNCgkJCQlsb2NhdGlvbmRhdGFIZWxwZXI6OnRoZVF1ZXVlKCRkb2N1bWVudCk7DQoJCQl9DQoJCX0NCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw==', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Electronic Trading Platform', '', '', 'Electronic Trading', '', '', '', 2, 'https://www.vdm.io/updates/electronic_trading_update_server.xml', 'https://www.vdm.io/', '', 'rhDqJicA7+30SXfWLrbrcIZjn/Urz39X3VeSsq2rTq4=', '', '', 2, 55, '', 1, 58), -(17, 1, '', 1, '', '', '', '', '', 1, '', 1, '', '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'JCB-pro.txt', '', '', 'Vast Development Method', '3.1.19', 'Copyright (C) 2015. All Rights Reserved', '2016-02-29 09:48:50', '', 'xmPvSegoAgCMLKDgZYrxDfZk72ACVYwppJH8oNbz1LA=', 'p+fdxfXxLoZ55Tfe/CgzA/EVRkLPVW0i9pwi2qkp/4Y=', '', 'G8usp0HTPVHhb3fhDSNaFpTuMTLgEXtyaElwU1ZCVSM=', 'LmZpZWxkTWVkaXVtIHsgd2lkdGg6IDEzMHB4OyB9DQouZmllbGRTbWFsbCB7IHdpZHRoOiA2MHB4OyB9DQpjb2RlIHsgZGlzcGxheTogaW5saW5lLWJsb2NrOyBtYXJnaW46IDNweDt9', '', '', 1, '', 'The Component Builder for [Joomla](http://www.joomla.org/) that is highly advanced, truly able to build extremely complex components in a fraction of the time.\r\n\r\nWhether you\'re a seasoned [Joomla](http://www.joomla.org/) developer, or have just started, Component Builder will safe you lots of time and money. A real must have!', 'joomla@vdm.io', '', '', '1UI8B7I2vDDAV21z06SbWlfsn9fztwTv/xXftsr743hbcGVO0yacLAqNoy9X8kYq9wbGYYaSy3yatbFyvNJCQQ==', '', '93a8be13-f9bb-4e22-82a3-3bf27ef1cba1', 'images/vdm/jcb500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2023-10-21 13:48:03', 1, 'Component Builder', 'componentbuilder', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '	/*
	 * Autoloader
	 */
	public static function autoLoader($type = 'compiler')
	{
		// load the type classes
		if ('smart' !== $type)
		{
			foreach (glob(JPATH_ADMINISTRATOR."/components/com_[[[component]]]/helpers/".$type."/*.php") as $autoFile)
			{
				require_once $autoFile;
			}
		}
		// load only if compiler
		if ('compiler' === $type)
		{
			// import the Joomla librarys
			jimport('joomla.filesystem.file');
			jimport('joomla.filesystem.folder');
			jimport('joomla.filesystem.archive');
			jimport('joomla.application.component.modellist');
			// include class to minify js
			require_once JPATH_ADMINISTRATOR.'/components/com_[[[component]]]/helpers/js.php';
		}
		// load only if smart
		if ('smart' === $type)
		{
			// import the Joomla libraries
			jimport('joomla.filesystem.file');
			jimport('joomla.filesystem.folder');
			jimport('joomla.filesystem.archive');
			jimport('joomla.application.component.modellist');
		}
		// load this for all
		jimport('joomla.application');
	}

	/**
	* 	The dynamic builder of views, tables and fields
	**/
	public static function dynamicBuilder(&$data, $type)
	{
		$extruder__ = new Super___19a39379_d192_45d6_b158_d18cbd4049bd___Power($data);
	}

	/**
	* 	The zipper method
	**/
	public static function zip($workingDIR, &$filepath)
	{
		// store the current joomla working directory
		$joomla = getcwd();

		// we are changing the working directory to the component temp folder
		chdir($workingDIR);

		// the full file path of the zip file
		$filepath = JPath::clean($filepath);

		// delete an existing zip file (or use an exclusion parameter in JFolder::files()
		JFile::delete($filepath);

		// get a list of files in the current directory tree
		$files = JFolder::files('.', '', true, true);
		$zipArray = array();
		// setup the zip array
		foreach ($files as $file)
		{
		   $tmp = array();
		   $tmp['name'] = str_replace('./', '', $file);
		   $tmp['data'] = JFile::read($file);
		   $tmp['time'] = filemtime($file);
		   $zipArray[] = $tmp;
		}

		// change back to joomla working directory
		chdir($joomla);

		// get the zip adapter
		$zip = JArchive::getAdapter('zip');

		//create the zip file
		if ($zip->create($filepath, $zipArray))
		{
			return true;
		}
		return false;
	}
	
	/**
	 * Remove folders with files
	 * 
	 * @param   string   $dir  The path to folder to remove
	 * @param   boolean   $git  if there is a git folder in that must not be removed
	 *
	 * @return  boolean   True in all is removed
	 * 
	 */
	public static function removeFolder($dir, $git = false)
	{
		if (JFolder::exists($dir))
		{
			$it = new RecursiveDirectoryIterator($dir);
			$it = new RecursiveIteratorIterator($it, RecursiveIteratorIterator::CHILD_FIRST);
			foreach ($it as $file)
			{
				if ('.' === $file->getBasename() || '..' ===  $file->getBasename()) continue;
				if ($file->isDir())
				{
					if ($git && strpos($file->getPathname(), $dir.'/.git') !== false) continue;
					JFolder::delete($file->getPathname());
				}
				else
				{
					if ($git && strpos($file->getPathname(), $dir.'/.git') !== false) continue;
					JFile::delete($file->getPathname());
				}
			}
			if (!$git && JFolder::delete($dir))
			{
				return true;
			}
		}
		return false;
	}

	/**
	* 	Create file and write data to the file
	**/
	public static function writeFile($path, $data)
	{
		$fh = fopen($path, "w");
		if (!is_resource($fh))
		{
			return false;
		}
		if (fwrite($fh, $data))
		{
			// close file.
			fclose($fh);
			return true;
		}
		// close file.
		fclose($fh);
		return false;
	}

	/**
	* 	The user notice info File Name
	**/
	protected static $usernotice = false;
	
	public static function getFilePath($type, $name = 'listing', $key = '', $fileType = '.json', $PATH = JPATH_COMPONENT_SITE)
	{
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::${$type.$name}))
		{
			// Get local key
			$localkey = self::getLocalKey();
			// set the name
			$fileName = md5($type.$name.$localkey.$key);
			// set file path			
			self::${$type.$name} = $PATH.'/helpers/'.$fileName.$fileType;
		}
		// return the path
		return self::${$type.$name};
	}
	
	public static function getFieldOptions($value, $type, $settings = array())
	{
		// Get a db connection.
		$db = Factory::getDbo();
		 
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('properties', 'short_description', 'description')));
		$query->from($db->quoteName('#__[[[component]]]_fieldtype'));
		$query->where($db->quoteName('published') . ' = 1');
		$query->where($db->quoteName($type) . ' = '. $value);
		 
		// Reset the query using our newly populated query object.
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$result = $db->loadObject();
			$properties = json_decode($result->properties,true);
			$pointer = 0;
			$field = array('values' => "<field ", 'values_description' => '<ul>', 'short_description' => $result->short_description, 'description' => $result->description);
			foreach ($properties['name'] as $line)
			{
				$field['values_description'] .= '<li><b>'.$properties['name'][$pointer].'</b> '.$properties['description'][$pointer].'</li>';
				if(isset($settings[$properties['name'][$pointer]]))
				{
					$field['values'] .= "\n\t".$properties['name'][$pointer].'="'.$settings[$properties['name'][$pointer]].'" ';
				}
				else
				{
					$field['values'] .= "\n\t".$properties['name'][$pointer].'="'.$properties['example'][$pointer].'" ';
				}
				$pointer++;
			}
			$field['values'] .= "\n/>";
			$field['values_description'] .= '</ul>';
			// return found field options
			return $field;
		}
		return false;
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = false;
	
	public static function getLocalKey()
	{
		if (!self::$localkey)
		{
			// get the main key
			self::$localkey = md5(Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('basic_key', 'localKey34fdWEkl'));
		}
		return self::$localkey;
	}

	/**
	 *	indent HTML
	 */
	public static function indent($html)
	{
		// load the class
		require_once JPATH_ADMINISTRATOR.'/components/com_[[[component]]]/helpers/indenter.php';
		// set new indenter
		$indenter = new Indenter();
		// return indented html
		return $indenter->indent($html);
	}

	public static function checkFileType($file, $sufix) {
		// now check if the file ends with the sufix
		return $sufix === "" || ($sufix == substr(strrchr($file, "."), -strlen($sufix)));
	}

	public static function imageInfo($path,$request = 'type')
	{
		// set image
		$image = JPATH_SITE.'/'.$path;
		// check if exists
		if (file_exists($image) && $result = @getimagesize($image))
		{
			// return type request
			switch ($request)
			{
				case 'width':
					return $result[0];
					break;
				case 'height':
					return $result[1];
					break;
				case 'type':
					$extensions = array(
						IMAGETYPE_GIF => "gif",
						IMAGETYPE_JPEG => "jpg",
						IMAGETYPE_PNG => "png",
						IMAGETYPE_SWF => "swf",
						IMAGETYPE_PSD => "psd",
						IMAGETYPE_BMP => "bmp",
						IMAGETYPE_TIFF_II => "tiff",
						IMAGETYPE_TIFF_MM => "tiff",
						IMAGETYPE_JPC => "jpc",
						IMAGETYPE_JP2 => "jp2",
						IMAGETYPE_JPX => "jpx",
						IMAGETYPE_JB2 => "jb2",
						IMAGETYPE_SWC => "swc",
						IMAGETYPE_IFF => "iff",
						IMAGETYPE_WBMP => "wbmp",
						IMAGETYPE_XBM => "xbm",
						IMAGETYPE_ICO => "ico"
					);
					return $extensions[$result[2]];
					break;
				case 'attr':
					return $result[3];
					break;
				case 'all':
				default:
					return $result;
					break;
			}
		}
		return false;
	}
	
	public static function getBetween($content,$start,$end)
	{
		$r = explode($start, $content);
		if (isset($r[1]))
		{
			$r = explode($end, $r[1]);
			return $r[0];
		}
		return '';
	}
	
	public static function getAllBetween($content,$start,$end)
	{
		$buket = array();
		for ($i = 0; ; $i++)
		{
			$found = Super___db87c339_5bb6_4291_a7ef_2c48ea1b06bc___Power::between($content,$start,$end);
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($found))
			{
				$buket[] = $found;
				$remove = $start.$found.$end;
				$content = str_replace($remove,'',$content);
			}
			else
			{
				break;
			}
			// safety catch
			if ($i == 500)
			{
				break;
			}
		}
		return  array_unique($buket);
	}
	
	public static function typeField($type,$option = 'default')
	{
		// list of default fields
		// https://docs.joomla.org/Form_field
		$fields = array(
			'default' => array(
				'accesslevel','cachehandler','calendar','captcha','category','checkbox',
				'checkboxes','color','combo','componentlayout','contentlanguage','editor',
				'chromestyle','contenttype','databaseconnection','editors','email','file',
				'filelist','folderlist','groupedlist','hidden','file','headertag','helpsite',
				'imagelist','integer','language','list','media','menu','note','password',
				'plugins','range','radio','repeatable','rules','sessionhandler','spacer','sql','tag',
				'tel','menuitem','modulelayout','meter','moduleorder','moduleposition','moduletag',
				'templatestyle','text','textarea','timezone','url','user','usergroup'
			), 
			'text' => array(
				'calendar','color','editor','email','password','tel','text','textarea','url','number','range'
			), 
			'list' => array(
				'checkboxes','checkbox','list','radio'
			), 
			'dynamic' => array(
				'category','headertag','tag','rules','user','file','filelist','folderlist','imagelist','integer','timezone','media','meter'
			)
		);
		
		if (in_array($type,$fields[$option]))
		{
			return true;
		}
		return false;		
	}
[CUSTOMCODE=getImportScripts]
	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// noting for now
		return true;
	}
[CUSTOMCODE=theButler] ', '', '', '', '', '', '', '', '', '# Joomla ###Component_name### (JCB)
[![GitHub release](https://img.shields.io/github/release/vdm-io/Joomla-Component-Builder.svg)](https://github.com/vdm-io/Joomla-Component-Builder/releases) [![Total Downloads](https://img.shields.io/github/downloads/vdm-io/Joomla-Component-Builder/total.svg)](https://github.com/vdm-io/Joomla-Component-Builder/releases)

This is a [Joomla 3.x](http://www.joomla.org/) component.

 ![###Component_name### image](https://raw.githubusercontent.com/vdm-io/Joomla-Component-Builder/master/admin/assets/images/component-300.jpg "The ###Component_name###")

###DESCRIPTION###

You can install it quite easily and with no limitations. On [github](https://github.com/vdm-io/Joomla-Component-Builder/releases) is the latest release (###VERSION###) with **ALL** its features and **ALL** concepts totally open-source and free!

Once installed upgrades are quick and easy via the default Joomla upgrade area.

# Some of the Features

+ Adding mySQL Dump to any View/Table.
+ Grab existing Table data and build a dynamic dump.
+ Unlimited Joomla Components.
+ Unlimited Tables/Views.
+ Reusing Views and Fields.
+ Runs on Your Own Joomla Install.
+ Add Dynamic/custom back-end views that uses Table and Chart result sets.
+ Build data query of extreme complex nature to use in Dynamic/custom views.
+ Highly Dynamic/custom Front-end Structures.
+ Dynamically setup templates and layouts for Front-end design.
+ Integration of the excellent UIKIT lib.
+ Integration of the excellent FOOTABLE lib.
+ All Joomla Standard Field Types (including repeatable fields).
+ Strong Implementation of all Joomla Form Security.
+ Load data via ajax with ease.
+ You can add an Update Server to Components you build.
+ Build advanced Dynamic front-end forms.
+ Dynamic data queries from multiple tables.
+ Place in local GIT folder, and publish to sales server.
+ Include any amount of custom files and folders during build.
+ Static helper class with smart methods already included.
+ Static helper methods Can easily be added.
+ Direct install from complier view.
+ Integrative with native Joomla Categories and Tags.
+ Fully Dynamic Search Friendly URL Auto Implementation.
+ Custom scripting options all over the MVC structure.
+ Permission implementation down to each view, item and field.
+ Easy extendible to include other libraries.
+ Can include SQL and visioning update link to distribute your component updates via Joomla default upgrade of components.
+ Easy Export & Import addon to all backend-tables.
+ Overriding ability of import concepts in all backend-tables.
+ The Batch and Filter implementation on all backend-list views.
+ This and much much more are all possible with this component builder!

# Just Imagine

+ Your Component Back-end can be more advanced then the Joomla Article Manager.
+ Your Code as Perfectly Unified to the strict Joomla Standards.
+ Adding Custom Scripting almost anywhere in the MVC structure.
+ Import and export feature to all backend-views.
+ Batch copy and move/update feature for all backend-views.
+ History tracking per/change made on any back-end item.
+ Dynamic field control, to show and hide fields in amazing ways.
+ Front-end freedom of design that allows for any library to be used.
+ This and much much more are all possible with this component builder!

# You are in Control

+ You can change the licensing template for your components.
+ You can change/improve existing field types and add more.
+ Line numbers to show where in compiler was the code build.
+ You can improve the component since all code are open-source.
+ Free updates for the lifetime of the project.
+ You can dynamically add internal help structures to all component.
+ There is no limitations on how big or how much you want to build (server limitation only).
+ This is a complete factory kind of component that functions like a deployment hub.
+ Export any component completely mapped in JCB and import into another JCB.
+ This and much much more are all possible with this component builder!

# Access the Video Tutorials

See the breakdown of the [tutorials on github](https://github.com/vdm-io/Joomla-Component-Builder/wiki) be sure to login to your youtube account to view these tutorials.

# gitHub Support

Would you require more help please open and issue here on [gitHub today](https://github.com/vdm-io/Joomla-Component-Builder/issues)!

# WHY GIVE IT AWAY LIKE THIS?

> I am an Open Source Enthusiast
> Who Support the Joomla Community

My idea was to almost let this tool serve as a cheat sheet to how things can be done... and with the help of other developers (more advanced then me) end up formulating the way how things not only can, but must be done to insure secure, stable, scalable and maintainable code is produced. 

# MAKING IT BETTER!

Component Builder is mapped as a component in itself on my local development environment. So I am improving it like you would any other component in it. I am looking for developers with the **skill** and the **desire** to really join me... and then I will possible give them access to this, so we can all help improve this simple, yet advanced tool.

# Build Details

+ *Company*: [###COMPANYNAME###](###AUTHORWEBSITE###)
+ *Author*: [###AUTHOR###](mailto:###AUTHOREMAIL###)
+ *Name*: [###Component_name###](###AUTHORWEBSITE###)
+ *First Build*: ###CREATIONDATE###
+ *Last Build*: ###BUILDDATE###
+ *Version*: ###VERSION###
+ *Copyright*: ###COPYRIGHT###
+ *License*: ###LICENSE###
+ *Line count*: **###LINE_COUNT###**
+ *File count*: **###FILE_COUNT###**
+ *Folder count*: **###FOLDER_COUNT###**

> This **component** was build with a Joomla [Automated Component Builder](http://vdm.bz/component-builder).
> Developed by [Llewellyn van der Merwe](mailto:joomla@vdm.io)

## Donations

Come on buy me a coffee :)
 * Open Collective: [Joomla-Component-Builder](https://opencollective.com/Joomla-Component-Builder)', '', '', 'Builds Complex Joomla Components', '', '', 'Component Builder (Packager)', '.git', '', '', 3, 'https://io.vdm.dev/update/componentbuilder_public_update_server.xml', 'https://dev.vdm.io', '', '15B/DnhhAf9l5DqzHLDbRPk/6CerG+Yc70BjTuJcbFk=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 2, 163, '', 1, 59), -(18, '', '', '', '', '', '', '', '', '', '', 1, '', 1, '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.1.0', 'Copyright (C) 2015. All Rights Reserved', '2016-02-24 13:21:00', '', 'PprMpPvlxnRi9ShaF7Sow9ENowuNfZw1tbyLnCocGBU=', '2FYCb5rnMNxRgDaDgcSPlfmf6VR7f2CtVGAxW3dSb5c=', '', 'UXU18uqabZOU8kYAoNwRTFBevvohQ7cK2F4c+M3puXk=', '', '', '', 1, '', 'Support Groups component adds the ability to your Joomla website to manage various support groups and their related details. Integration with Google Maps is one of its main features.', 'joomla@vdm.io', '', 'https://vdm.bz/jcb-support-groups', 'zDF8cOazWQPMVpPc5EBb781TrBjsgNplnrZ/ko36KH7kb39urdAkJZcD11DAZAenJJ0CZOrI5/I+FZeTWwSuZQ==', '', '36d66191-9524-4800-966c-be16df1cd5a2', 'images/vdm/SGD500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Support-Groups', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-04-14 15:47:40', 1, 'Support Groups', 'supportgroups', '', 4, '', 'CS8qKg0KCSogCVRoZSBnbG9iYWwgcGFyYW1zDQoJKiovDQoJcHJvdGVjdGVkIHN0YXRpYyAkcGFyYW1zID0gZmFsc2U7DQoNCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIHNldEN1cnJlbmN5KCRhbW91bnQsJHN1cHBvcnRfZ3JvdXApDQoJew0KCQkvLyBnZXQgdGhlIGN1cnJlbmN5IGlkDQoJCSRjdXJyZW5jeSA9IHNlbGY6OmdldEN1cnJlbmN5KCRzdXBwb3J0X2dyb3VwKTsNCgkJLy8gbWFrZSBtb25leQ0KCQlyZXR1cm4gc2VsZjo6bWFrZU1vbmV5KCRhbW91bnQsJGN1cnJlbmN5KTsNCgl9DQoNCglwcm90ZWN0ZWQgc3RhdGljICRjdXJyZW5jeSA9IGFycmF5KCk7DQoNCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGdldEN1cnJlbmN5KCRzdXBwb3J0X2dyb3VwKQ0KCXsNCgkJaWYgKCFpc3NldChzZWxmOjokY3VycmVuY3lbJHN1cHBvcnRfZ3JvdXBdKSkNCgkJew0KCQkJLy8gZ2V0IHRoZSBsb2NhdGlvbg0KCQkJJGFyZWEgPSBzZWxmOjpnZXRWYXIoJ3N1cHBvcnRfZ3JvdXAnLCAkc3VwcG9ydF9ncm91cCwgJ2lkJywgJ2FyZWEnKTsNCgkJCS8vIGdldCB0aGUgUmVnaW9uDQoJCQkkcmVnaW9uID0gc2VsZjo6Z2V0VmFyKCdhcmVhJywgJGFyZWEsICdpZCcsICdyZWdpb24nKTsNCgkJCS8vIGdldCB0aGUgQ291bnRyeQ0KCQkJJGNvdW50cnkgPSBzZWxmOjpnZXRWYXIoJ3JlZ2lvbicsICRyZWdpb24sICdpZCcsICdjb3VudHJ5Jyk7DQoJCQkvLyBnZXQgdGhlIEN1cnJlbmN5IENvZGV0aHJlZQ0KCQkJJGNvZGV0aHJlZSA9IHNlbGY6OmdldFZhcignY291bnRyeScsICRjb3VudHJ5LCAnaWQnLCAnY3VycmVuY3knKTsNCgkJCS8vIGdldCBjdXJyZW5jeSBpZA0KCQkJc2VsZjo6JGN1cnJlbmN5WyRzdXBwb3J0X2dyb3VwXSA9IHNlbGY6OmdldFZhcignY3VycmVuY3knLCAkY29kZXRocmVlLCAnY29kZXRocmVlJywgJ2lkJyk7DQoJCX0NCgkJcmV0dXJuIHNlbGY6OiRjdXJyZW5jeVskc3VwcG9ydF9ncm91cF07DQoJfQ0KDQoJcHJvdGVjdGVkIHN0YXRpYyAkY3VycmVuY3lEZXRhaWxzID0gYXJyYXkoKTsNCg0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0Q3VycmVuY3lEZXRhaWxzKCRjb2RldGhyZWUgPSBmYWxzZSkNCgl7DQoJCS8vIHJldHVybiBjYWNoZWQgZGF0YSBpZiBzZXQNCgkJaWYgKCRjb2RldGhyZWUgJiYgIWlzc2V0KHNlbGY6OiRjdXJyZW5jeURldGFpbHNbJGNvZGV0aHJlZV0pKQ0KCQl7DQoJCQkvLyBHZXQgYSBkYiBjb25uZWN0aW9uLg0KCQkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCQkvLyBDcmVhdGUgYSBuZXcgcXVlcnkgb2JqZWN0Lg0KCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCgkJCSRxdWVyeS0+c2VsZWN0KCRkYi0+cXVvdGVOYW1lKA0KCQkJCWFycmF5KAknYS5pZCcsJ2EubmFtZScsJ2EuY29kZXRocmVlJywnYS5udW1lcmljY29kZScsJ2Euc3ltYm9sJywnYS50aG91c2FuZHMnLCdhLmRlY2ltYWxwbGFjZScsDQoJCQkJCSdhLmRlY2ltYWxzeW1ib2wnLCdhLnBvc2l0aXZlc3R5bGUnLCdhLm5lZ2F0aXZlc3R5bGUnKSwNCgkJCQlhcnJheSgJJ2N1cnJlbmN5X2lkJywnY3VycmVuY3lfbmFtZScsJ2N1cnJlbmN5X2NvZGV0aHJlZScsJ2N1cnJlbmN5X251bWVyaWNjb2RlJywnY3VycmVuY3lfc3ltYm9sJywNCgkJCQkJJ2N1cnJlbmN5X3Rob3VzYW5kcycsJ2N1cnJlbmN5X2RlY2ltYWxwbGFjZScsJ2N1cnJlbmN5X2RlY2ltYWxzeW1ib2wnLCdjdXJyZW5jeV9wb3NpdGl2ZXN0eWxlJywNCgkJCQkJJ2N1cnJlbmN5X25lZ2F0aXZlc3R5bGUnKSkpOw0KCQkJJHF1ZXJ5LT5mcm9tKCRkYi0+cXVvdGVOYW1lKCcjX19bW1tjb21wb25lbnRdXV1fY3VycmVuY3knLCAnYScpKTsNCgkJCWlmIChpc19udW1lcmljKCRjb2RldGhyZWUpKQ0KCQkJew0KCQkJCSRxdWVyeS0+d2hlcmUoJGRiLT5xdW90ZU5hbWUoJ2EuaWQnKSAuICcgPSAnLiAoaW50KSAkY29kZXRocmVlKTsNCgkJCX0NCgkJCWVsc2VpZiAoc3RybGVuKCRjb2RldGhyZWUpID09IDMpDQoJCQl7DQoJCQkJJHF1ZXJ5LT53aGVyZSgkZGItPnF1b3RlTmFtZSgnYS5jb2RldGhyZWUnKSAuICcgPSAnLiRkYi0+cXVvdGUoJGNvZGV0aHJlZSkpOw0KCQkJfQ0KCQkJZWxzZQ0KCQkJew0KCQkJCSRxdWVyeS0+d2hlcmUoJGRiLT5xdW90ZU5hbWUoJ2EuY29kZXRocmVlJykgLiAnID0gJy4kZGItPnF1b3RlKCdOT05FJykpOw0KCQkJfQ0KCQkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkJJGRiLT5leGVjdXRlKCk7DQoJCQlpZiAoJGRiLT5nZXROdW1Sb3dzKCkpDQoJCQl7DQoJCQkJc2VsZjo6JGN1cnJlbmN5RGV0YWlsc1skY29kZXRocmVlXSA9ICRkYi0+bG9hZE9iamVjdCgpOw0KCQkJfQ0KCQl9DQoJCS8vIG1ha2Ugc3VyZSBpdCBoYXMgYmVlbiBzZXQNCgkJaWYgKGlzc2V0KHNlbGY6OiRjdXJyZW5jeURldGFpbHNbJGNvZGV0aHJlZV0pKQ0KCQl7DQoJCQlyZXR1cm4gc2VsZjo6JGN1cnJlbmN5RGV0YWlsc1skY29kZXRocmVlXTsNCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ0KW0NVU1RPTUNPREU9bWFrZU1vbmV5XQ0KW0NVU1RPTUNPREU9Z2V0RmlsZVBhdGhd', '', 'CXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gc2V0VG90YWxzKCYkZGF0YSwmJHR5cGUsJiRpZCkNCgl7DQoJCWxpc3QoJHBhdGgsICRmaWxlTmFtZSwgJGZ1bGxQYXRoKSA9IHNlbGY6OmdldFRvdGFsc0ZpbGVQYXRoKCR0eXBlLCRpZCk7DQoJCS8vIGRpZCB3ZSBnZXQgYSB2YWxpZCByZXN1bHQgc2V0DQoJCWlmIChTdXBlcl9fXzBhNTljNjVjXzlkYWZfNGJjOV9iYWY0X2UwNjNmZjllNmE4YV9fX1Bvd2VyOjpjaGVjaygkZGF0YSkpDQoJCXsNCgkJCS8vIG5vdyBzYXZlIGZvciBuZXh0IHRpbWUNCgkJCXJldHVybiBzZWxmOjpzYXZlSnNvbigkZGF0YSwgJGZ1bGxQYXRoLCAkcGF0aCk7DQoJCX0NCgkJcmV0dXJuIGZhbHNlOw0KCX0NCg0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0VG90YWxzKCYkdHlwZSwmJGlkKQ0KCXsNCgkJbGlzdCgkcGF0aCwgJGZpbGVOYW1lLCAkZnVsbFBhdGgpID0gc2VsZjo6Z2V0VG90YWxzRmlsZVBhdGgoJHR5cGUsJGlkKTsNCgkJLy8gY2hlY2sgaWYgZmlsZSBleGlzdHMNCgkJaWYgKGZpbGVfZXhpc3RzKCRmdWxsUGF0aCkgJiYgKCgkanNvbkZpbGUgPSBTdXBlcl9fX2EyMjNiMzFlX2VhMWRfNGNkZl85MmFlXzVmOWJlY2ZmYWZmMF9fX1Bvd2VyOjpnZXRDb250ZW50KCRmdWxsUGF0aCwgRkFMU0UpKSAhPT0gRkFMU0UpKQ0KCQl7DQoJCQkvLyBncmVhdCB3ZSBhcmUgZG9uZSByZXR1cm4gcmVzdWx0cyBhcyBhcnJheQ0KCQkJcmV0dXJuIGpzb25fZGVjb2RlKCRqc29uRmlsZSx0cnVlKTsNCgkJfQ0KCQkvLyByZW1vdmUgdGhlIG9sZCBmaWxlcw0KCQlzZWxmOjpyZW1vdmVGaWxlKCRwYXRoLCAkZmlsZU5hbWUpOw0KCQlyZXR1cm4gZmFsc2U7DQoJfQ0KCQ0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0VG90YWxzRmlsZVBhdGgoJiR0eXBlLCYkaWQpDQoJew0KCQkkcGF0aFswXSA9IEpQQVRIX0FETUlOSVNUUkFUT1IuJy9jb21wb25lbnRzL2NvbV9bW1tjb21wb25lbnRdXV0vaGVscGVycy90b3RhbHMnOw0KCQkkcGF0aFsxXSA9IHNlbGY6OmdldEZpbGVLRVkoJHR5cGUsJGlkKTsNCgkJLy8gYnVpbGQgZnVsbCBwYXRoIHRvIGZpbGUNCgkJJHBhdGhbMl0gPSAkcGF0aFswXS4nLycuJHBhdGhbMV0uJy5qc29uJzsNCg0KCQlyZXR1cm4gJHBhdGg7DQoJfQ0KCQ0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0RmlsZUtFWSgmJHR5cGUsJiRpZCkNCgl7DQoJCS8vIEdldCBhIGRiIGNvbm5lY3Rpb24uDQoJCSRkYiA9IEZhY3Rvcnk6OmdldERibygpOw0KCQkvLyBDcmVhdGUgYSBuZXcgcXVlcnkgb2JqZWN0Lg0KCQkkcXVlcnkgPSAkZGItPmdldFF1ZXJ5KHRydWUpOw0KCQkvLyBHZXQgZnJvbSAjX19zdXBwb3J0Z3JvdXBzX3N1cHBvcnRfZ3JvdXAgYXMgYQ0KCQkkcXVlcnktPnNlbGVjdCgnTUFYKGEubW9kaWZpZWQpJyk7DQoJCSRxdWVyeS0+ZnJvbSgkZGItPnF1b3RlTmFtZSgnI19fc3VwcG9ydGdyb3Vwc19zdXBwb3J0X2dyb3VwJywgJ2EnKSk7DQoJCSRxdWVyeS0+d2hlcmUoJ2EucHVibGlzaGVkID0gMScpOw0KCQkkZGItPnNldFF1ZXJ5KCRxdWVyeSk7DQoJCSRkYi0+ZXhlY3V0ZSgpOw0KCQlpZiAoJGRiLT5nZXROdW1Sb3dzKCkpDQoJCXsNCgkJCXJldHVybiAnVkRNXycuJHR5cGUuJ19fJy5tZDUoJGRiLT5sb2FkUmVzdWx0KCkpLidfXycuJGlkOw0KCQl9DQoJCXJldHVybiAnVkRNXycuJHR5cGUuJ19fMjg5ZDdiMDUyNzg2OGQ3ZjlhNWY4YzdiMWM4MGQ3YTZfXycuJGlkOw0KCX0NCg0KCS8qKg0KCSogU2FmZXMganNvbiB0byBhIGZpbGUNCgkqDQoJKiBAaW5wdXQJICBvYmplY3QvYXJyYXkvanNvbiAgJGRhdGEgICAgICBEYXRhIHRvIGJlIHN0b3JlZA0KCSogQGlucHV0CSAgc3RyaW5nICAgICAgICAgICAgICAgICAgJGZ1bGxQYXRoIEZ1bGwgcGF0aCB0byBmaWxlDQoJKiBAaW5wdXQJICBzdHJpbmcgICAgICAgICAgICAgICAgICAkcGF0aCAgICAgIEZ1bGwgcGF0aCB0byBmb2xkZXINCgkqDQoJKiBAcmV0dXJucyAgYm9vbGVhbiBvbiBzdWNjZXNzDQoJKiovDQoJcHJvdGVjdGVkIHN0YXRpYyBmdW5jdGlvbiBzYXZlSnNvbigkZGF0YSwgJGZ1bGxQYXRoLCAkcGF0aCA9IF9fRElSX18pDQoJew0KCQkvLyBjaGVjayBpZiBwYXRoIGV4aXN0cw0KCQlpZiAoIWZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJew0KCQkJLy8gaWYgbm90IHRoZSBtYWtlIHRoZSBwYXRoDQoJCQlta2RpcigkcGF0aCwgMDc1NSwgdHJ1ZSk7DQoJCX0NCgkJLy8gY2hlY2sgdGhhdCB0aGUgc3RyaW5nIGlzIGpzb24NCgkJaWYgKCFTdXBlcl9fXzRiMjI1YzUxX2QyOTNfNDhlNF9iM2Y2XzUxMzZjZjVjM2YxOF9fX1Bvd2VyOjpjaGVjaygkZGF0YSkpDQoJCXsNCgkJCS8vIGpzb24gZW5jb2RlIGlmIG5vdCBqc29uDQoJCQkkZGF0YSA9IGpzb25fZW5jb2RlKCRkYXRhKTsNCgkJfQ0KCQkvLyBtYWtlIHN1cmUgdGhpcyBpcyBhIHN0cmluZw0KCQlpZiAoU3VwZXJfX18xZjI4Y2I1M182MGQ5XzRkYjFfYjUxN18zYzdkYzZiNDI5ZWZfX19Qb3dlcjo6Y2hlY2soJGRhdGEpKQ0KCQl7DQoJCQkkZnAgPSBmb3BlbigkZnVsbFBhdGgsICd3Jyk7DQoJCQlmd3JpdGUoJGZwLCAkZGF0YSk7DQoJCQlmY2xvc2UoJGZwKTsNCgkJCXJldHVybiB0cnVlOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoJDQoJLyoqDQoJICogUmVtb3ZlIGZpbGUNCgkgKiANCgkgKiBAcGFyYW0gICBzdHJpbmcgICAkZGlyICBUaGUgcGF0aCB0byBmb2xkZXIgdG8gcmVtb3ZlDQoJICogQHBhcmFtICAgc3RyaW5nICAgJG5ld0ZpbGVOYW1lIHRoZSBuZXcgZmlsZSBuYW1lDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICAgVHJ1ZSBpbiBhbGwgaXMgcmVtb3ZlZA0KCSAqIA0KCSAqLw0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gcmVtb3ZlRmlsZSgkZGlyLCAkbmV3RmlsZU5hbWUpDQoJew0KCQlpZiAoaXNfZGlyKCRkaXIpKQ0KCQl7DQoJCQkvLyBidWlsZCB0aGUgb2xkIGZvbGRlciBuYW1lDQoJCQkkb2xkRmlsZU5hbWUgPSBleHBsb2RlKCdfXycsJG5ld0ZpbGVOYW1lKTsNCgkJCS8vIGxpdHRsZSBmaXggdG8gcmVtb3ZlIHRoaXMgaXRlbSBvbGQgZmlsZSBpZiBmb3VuZA0KCQkJJGZvdW5kID0gZ2xvYigkZGlyLicvJy4kb2xkRmlsZU5hbWVbMF0uJyonLiRvbGRGaWxlTmFtZVsyXS4nLmpzb24nKTsNCgkJCWlmIChTdXBlcl9fXzBhNTljNjVjXzlkYWZfNGJjOV9iYWY0X2UwNjNmZjllNmE4YV9fX1Bvd2VyOjpjaGVjaygkZm91bmQpICYmICgkZG9uZSA9IEBhcnJheV9tYXAoICJ1bmxpbmsiLCRmb3VuZCkpICE9PSBGQUxTRSkNCgkJCXsNCgkJCQlyZXR1cm4gdHJ1ZTsNCgkJCX0NCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ==', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXShodHRwczovL2dpdGh1Yi5jb20vTGxld2VsbHludmRtL0pvb21sYS1TdXBwb3J0LUdyb3Vwcy9yYXcvbWFzdGVyL2FkbWluL2Fzc2V0cy9pbWFnZXMvdmRtLWNvbXBvbmVudC5qcGcgIlRoZSAjIyNDb21wb25lbnRfbmFtZSMjIyIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIENvbXBvbmVudCBOdW1iZXINCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cDovL3ZkbS5iei9jb21wb25lbnQtYnVpbGRlcikuDQo+IERldmVsb3BlZCBieSBbTGxld2VsbHluIHZhbiBkZXIgTWVyd2VdKG1haWx0bzpqb29tbGFAdmRtLmlvKQ0KDQojIEpvb21sYSBDb21wb25lbnQgQnVpbGRlcg0KDQpGb3IgbW9yZSBpbmZvcm1hdGlvbiBhYm91dCBKQ0IgdmlzaXQgW1ZETV0oaHR0cDovL3ZkbS5iei9jb21wb25lbnQtYnVpbGRlcikgVG9kYXkhIFRoZSBmdXR1cmUgaXMgaGVyZSENCg0KW0NVU1RPTUNPREU9cmVhZE1FY29udHJpYnV0b3JzXQ==', '', '', 'Support Groups', '', '', 'Support Groups (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/Llewellynvdm/Joomla-Support-Groups/master/supportgroups_update_server.xml', 'http://www.vdm.io', '', 'MnqAN/BKB4RuSo9ssgLixjWmebnM+y38CXbQNAFuIII=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 144, '', 1, 63), -(19, 1, '', '', '', 1, '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, '', '', 3, '', 1, 3, 'Ty Coon', '', 'default.txt', '', '', 'Yoyodyne, Inc.', '1.0.14', 'Copyright (C) 2015. All Rights Reserved', '2016-03-07 02:41:12', '', 'ZeWxi5fFOiZerEt+g/op1T9TR9PdxqXLighoYlKcWSU=', 'L6B/srznyHaxTDT3/Oq6C8IILZBj7KdleiRPmBoUhHg=', '', 'a+oNwrKFUAUh3fq4wi9j+cnSHkcbMARJoW8Gm5AZKiw=', '', '', 'A_174', 2, '', 'gitHubbing', 'hacker@gnu.org', '', '', '69IXWWHwipHPBqDFjepXHwmLfs470iYEsn3PHouCrmk=', '', '67499184-219e-40f3-bf38-8b1c7d619126', 'images/toilet-paper-icon.png', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2020-07-23 13:36:28', '', 'gitHubbing', 'githubbing', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', '	protected static $params;
	protected static $doTest = false;
	public static $notEmail = array( 'users.noreply.github.com', 'noreply', 'no_reply');

	// Array of relationship names
	public static $relationshipName = array(
			1 => 'Admin',
			2 => 'Push',
			3 => 'Pull',
			4 => 'Forked',
			5 => 'Stargazer',
			6 => 'Watcher'
		);

	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// noting for now
		return true;
	}

	/**
	* 	Send the confirmation emails
	**/
	protected static function getTemplate($type, $default = null)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		$body = self::$params->get($type, $default);
		// return the template if found
		if ($body)
		{
			return $body;
		}
		return Text::sprintf('No template for <b>%s</b> were found', Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($type, 'w'));
	}

	/**
	* 	get place holders
	**/
	public static function getPlaceHolders($type)
	{
		if ('document' == $type)
		{
			return array_keys(self::getCompanyDetails('placeholder'));
		}
		elseif ('email' == $type)
		{
			$f = '[';
			$b = ']';
			$placeholder = array();
			$placeholder[] = array('[document_header]');
			$placeholder[] = array('[text_header]');
			$placeholder[] = array_keys(self::getCompanyDetails('placeholder'));
			$placeholder[] = array_values(self::getSelection('developer', $f.'developer_', $b));
			$placeholder[] = array_values(self::getSelection('project', $f.'project_', $b));
			$placeholder[] = array('[unsubscribe_link]', '[unsubscribe_url]');
			$placeholder[] = array('[document_footer]');
			$placeholder[] = array('[text_footer]');
			return  self::mergeArrays($placeholder);
		}
		return false;
	}

	/**
	* Return array of selections
	* 
	* @return    array if type match
	*/
	public static function getSelection($type, $f = '', $b = '')
	{
		if ('developer' == $type)
		{
			return array(
				'a.id' => $f.'id'.$b,	
				'a.name' => $f.'name'.$b,	
				'a.email' => $f.'email'.$b,
				'a.hireable' => $f.'hireable'.$b,
				'a.location' => $f.'location'.$b,
				'a.bio' => $f.'bio'.$b,
				'a.blog' => $f.'blog'.$b,
				'a.login' => $f.'username'.$b,
				'a.github_id' => $f.'github_id'.$b
			);
		}
		if ('project' == $type)
		{
			return array(
				'a.id' => $f.'id'.$b,
				'a.name' => $f.'name'.$b,
				'a.description' => $f.'description'.$b,
				'a.short_description' => $f.'short_description'.$b,
				'a.project' => $f.'project'.$b,
				'a.tokens' => $f.'tokens'.$b
			);
		}
		return false;
	}

	/**
	* 	send messages
	**/
	public static function sendMessages($pks, $db = null, $test = false)
	{
		// test switch
		self::$doTest = $test;
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		// send one message at a time
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($pks))
		{
			$send = true;
			$f = '[developer_';
			$b = ']';
			$selection = self::getSelection('developer', $f, $b);
			foreach ($pks as $pk)
			{
				$project = null;
				$rel['relationship'] = Text::_('any');
				$rel['not_relationship'] = Text::_('no');
				$rel['hireable'] = '';
				if (!$items = self::getSubscribers($pk, $rel, $project, $db, $selection))
				{
					// don't show success message
					$send = false;
				}
				elseif (!self::sendMessagesNow($items, $pk, $project, $db))
				{
					// tailor around a project
					if ($project)
					{
						// set a message that this mail list has no subscription
						self::$messages['Error'][] = Text::sprintf('There was an error sending <b>%s</b> to the subscribers of <b>%s/%s</b> based on <b>%s</b> relationship excluding <b>%s</b> relationship%s.', self::getVar('message', $pk, 'id', 'subject'), self::getVar('project', $project, 'id', 'name'), self::getVar('project', $project, 'id', 'project'), $rel['relationship'], $rel['not_relationship'], $rel['hireable']);
					}
					else
					{
						// set a message that this mail list has no subscription
						self::$messages['Error'][] = Text::sprintf('There was an error sending <b>%s</b> to the subscribers.', self::getVar('message', $pk, 'id', 'subject'));
					}
					// don't show success message
					$send = false;
				}
				else
				{
					if ($project)
					{
						// set a message that this mail list has no subscription
						self::$messages['Success'][] = Text::sprintf('<b>%s</b> was send to the subscribers of <b>%s/%s</b> based on <b>%s</b> relationship excluding <b>%s</b> relationship%s.', self::getVar('message', $pk, 'id', 'subject'), self::getVar('project', $project, 'id', 'name'), self::getVar('project', $project, 'id', 'project'), $rel['relationship'], $rel['not_relationship'], $rel['hireable']);
					}
					else
					{
						// set a message that this mail list has no subscription
						self::$messages['Success'][] = Text::sprintf('<b>%s</b> was send to all subscribers.', self::getVar('message', $pk, 'id', 'subject'));
					}
				}
				// free memory
				unset($items);
			}
			return $send;
		}
		return false;
	}

	/**
	* 	get Subscription Messages of One Developer that was send
	**/
	public static function getSubscriptionMessages($github_id, $db = null)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		$query = $db->getQuery(true);
		// Select some fields
		$query->select(
			$db->quoteName(
				array('m.id', 'm.subject', 'm.project', 'p.project', 'p.name', 'm.textbody'), array('message_id', 'subject', 'project_id', 'project', 'project_name', 'textbody')
			)
		);
		// From the [[[component]]]_send table
		$query->from($db->quoteName('#__[[[component]]]_send', 'a'));
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_message', 'm') . ' ON (' . $db->quoteName('a.message') . ' = ' . $db->quoteName('m.id') . ')');
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_project', 'p') . ' ON (' . $db->quoteName('m.project') . ' = ' . $db->quoteName('p.id') . ')');
		// only get this developer
		$query->where($db->quoteName('a.user') . ' = ' . (int) $github_id);
		// Order the results by ordering
		$query->order('m.subject  ASC');
		// Load the items
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadAssocList();
		}
		return false;
	}

	/**
	* 	get the developers github IDs of a given list of Projects (subscribed)
	**/
	public static function getProjectsDeveloperIDs($projects, $db = null)
	{
		// check that it is an array
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($projects) && is_numeric($projects))
		{
			$projects = array($projects);
		}
		elseif (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($projects))
		{
			return false;
		}
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		$query = $db->getQuery(true);
		// Select some fields
		$query->select('user');
		// From the [[[Component]]]_relationship_builder
		$query->from($db->quoteName('#__[[[component]]]_relationship_builder', 'a'));
		// only for the selected project
		$query->where($db->quoteName('a.project') . ' IN (' . implode(', ', $projects) . ')');
		// only get users still subscribed
		$query->where($db->quoteName('a.status') . ' = 1');
		// Load the items
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			// return found IDs
			return array_unique((array)$db->loadColumn());
		}
		return false;
	}

	/**
	* 	get Subscribers
	**/
	public static function getSubscribers($pk, &$rel, &$project, $db = null, $selection = null, $f = '[developer_', $b = ']', $remove_send = true)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		// get selection
		if (!$selection || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($selection))
		{
			$selection = self::getSelection('developer', $f, $b);
		}
		$query = $db->getQuery(true);
		// Select some fields
		$query->select(
			$db->quoteName(
				array_keys($selection), array_values($selection)
			)
		);
		// From the [[[Component]]]_developer table
		$query->from($db->quoteName('#__[[[component]]]_developer', 'a'));
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_relationship_builder', 'r') . ' ON (' . $db->quoteName('a.github_id') . ' = ' . $db->quoteName('r.user') . ')');
		// get the message
		$message = self::getMessage($pk, $db);
		// get the message project
		if (isset($message->project) && $message->project > 0)
		{
			$project = $message->project;
		}
		else
		{
			$project = self::getVar('message', $pk, 'id', 'project');
		}
		// make sure we have a project ID
		if ($project > 0)
		{
			// only developers part of this project
			if (!self::$doTest)
			{
				if ($_active_github_users = self::getProjectsDeveloperIDs($project, $db))
				{
					// check if we have excluding users
					if (isset($message->not_projects) && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($message->not_projects))
					{
						// convert to an array
						$not_projects = (array) json_decode($message->not_projects, true);
						// remove users from active if found
						if ($_remove_users = self::getProjectsDeveloperIDs($not_projects, $db))
						{
							$_active_github_users = array_diff($_active_github_users, $_remove_users);
						}
					}
				}
				// now check if we can continue
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($_active_github_users))
				{
					$query->where($db->quoteName('a.github_id') . '  IN (' . implode(', ', $_active_github_users) . ')');
				}
				else
				{
					return false; // we must have subscribers
				}
			}
		}
		else
		{
			return false; // maybe later we can allow build or global email (TODO)
		}
		// filter by relationship
		$rel_targets = array(
			'relationship' => array('operator' => 'IN', 'field' => 'r.relationship'),
			'not_relationship' => array('operator' => 'NOT IN', 'field' => 'r.relationship'));
		$tmp = array();
		foreach ($rel_targets as $_rel => $_target)
		{
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($message->{$_rel}))
			{
				// convert to an array
				$tmp[$_rel] = (array) json_decode($message->{$_rel}, true);
				// check that we still have an array
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmp[$_rel]))
				{
					if (!self::$doTest)
					{
						// only get users who has the correct relationship
						$query->where($db->quoteName($_target['field']) .' '.$_target['operator'].' (' . implode(', ', $tmp[$_rel]) . ')');
					}
					// update the relationship string
					$bucket = array();
					foreach ($tmp[$_rel] as $rel_id)
					{
						// Set the name.
						if (isset(self::$relationshipName[$rel_id]))
						{
							$bucket[] = self::$relationshipName[$rel_id];
						}
					}
					// do we have an array
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
					{
						$rel[$_rel] = implode(', ', $bucket);
					}
				}
			}
		}
		// filter based on hireable
		if (self::$doTest)
		{
			$rel['hireable'] = ' '. Text::_('and is testable');
		}
		elseif (isset($message->hireable))
		{
			if ($message->hireable == 1)
			{
				// load only those hireable
				$query->where($db->quoteName('a.hireable') . ' = 1');
				$rel['hireable'] = ' '. Text::_('and is hireable');
			}
			elseif ($message->hireable == 2)
			{
				// load both
				$rel['hireable'] = '';
			}
			else
			{
				// load only those who aren't hireable
				$query->where($db->quoteName('a.hireable') . ' = 0');
				$rel['hireable'] = ' '. Text::_("and isn't hireable");
			}
		}
		// only if not a test
		if (!self::$doTest)
		{
			// only get published users
			$query->where($db->quoteName('a.published') . ' = 1');
			// only get users with emails
			$query->where($query->charLength('a.email').' > 4');
			// Order the results by ordering
			$query->order('a.login  ASC');
		}
		else
		{
			// only get the tester
			$query->where($db->quoteName('a.id') . ' = ' . (int) self::getTester());
		}
		// Load the items
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			// insure it loads each user only once
			$items = $db->loadAssocList($f.'github_id'.$b);
			// set values to display correctly.
			foreach ($items as $nr => &$item)
			{
				// check if this user already received the message
				if (!self::$doTest && $remove_send && self::wasSend($pk, $item[$f.'github_id'.$b], $db))
				{
					// already received this message
					unset($items[$nr]);
					continue;
				}
				// fix name if none found
				if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($item[$f.'name'.$b]))
				{
					$item[$f.'name'.$b] = $item[$f.'username'.$b];
				}
				// set relationship names
				if (!self::$doTest && $project)
				{
					// get this uses relationship
					$relationship = self::getRelationships($project, $item[$f.'github_id'.$b]);
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($relationship))
					{
						// do a second round to remove if in a not relationship
						if (isset($tmp['not_relationship']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmp['not_relationship']))
						{
							// get the relationship array
							$relationshipArray = (array) array_map( function ($relation) { return $relation->relationship; }, $relationship);
							if (array_intersect($tmp['not_relationship'], $relationshipArray))
							{
								// has a not relationship
								unset($items[$nr]);
								continue;
							}
						}
						$item[$f.'relationships'.$b] = implode(', ', array_map( function ($relation) { return $relation->relationship_name; }, $relationship));
					}
					elseif (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($relationship))
					{
						// do a second round to remove if in a not relationship
						if (isset($tmp['not_relationship']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmp['not_relationship']))
						{
							if (in_array($relationship->relationship, $tmp['not_relationship']))
							{
								// has a not relationship
								unset($items[$nr]);
								continue;
							}
						}
						$item[$f.'relationships'.$b] = $relationship->relationship_name;
					}
					else
					{
						$item[$f.'relationships'.$b] = '';
					}
				}
				elseif (self::$doTest)
				{
					$item[$f.'relationships'.$b] = 'tester';
				}
			}
			// check that we still have items
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($items))
			{
				return $items;
			}
			else
			{
				if ($project)
				{
					// set a message that this mail list has no subscription
					self::$messages['Notice'][] = Text::sprintf('All subscribers to <b>%s/%s</b> has already received <b>%s</b> based on <b>%s</b> relationship excluding <b>%s</b> relationship%s.', self::getVar('project', $project, 'id', 'name'), self::getVar('project', $project, 'id', 'project'), self::getVar('message', $pk, 'id', 'subject'), $rel['relationship'], $rel['not_relationship'], $rel['hireable']);
				}
				else
				{
					// set a message that this mail list has no subscription
					self::$messages['Notice'][] = Text::sprintf('All subscribers have already received <b>%s</b>.', self::getVar('message', $pk, 'id', 'subject'));
				}
			}
		}
		else
		{
			if ($project)
			{
				// set a message that this mail list has no subscription
				self::$messages['Warning'][] = Text::sprintf('There are no subscribers for <b>%s/%s</b> based on <b>%s</b> relationship excluding <b>%s</b> relationship%s, so <b>%s</b> can not be send at this time.', self::getVar('project', $project, 'id', 'name'), self::getVar('project', $project, 'id', 'project'), $rel['relationship'], $rel['not_relationship'], $rel['hireable'], self::getVar('message', $pk, 'id', 'subject'));
			}
			else
			{
				// set a message that this mail list has no subscription
				self::$messages['Warning'] = Text::sprintf('There are no subscribers for <b>%s</b> at this time.', self::getVar('message', $pk, 'id', 'subject'));
			}
		}
		return false;
	}

	/**
	* 	Get the tester
	**/
	protected static function getTester()
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		return self::$params->get('tester', 0);
	}

	/**
	* 	Get the unsubscribe key
	**/
	protected static function getUnsubscribeKey()
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		return self::$params->get('unsubscribe_key', 'th1sMustB3LOck3d!nSom3F0rm');
	}

	/**
	* 	Get the unsubscribe url
	**/
	protected static function getUnsubscribeUrl()
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		return self::$params->get('unsubscribe_url', '#');
	}

	/**
	* 	Send messages now
	**/
	protected static function sendMessagesNow($items, $message_id, $project_id, $db = null)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		// get the message
		if (!$message = self::getMessage($message_id, $db))
		{
			return false;
		}
		// check that we have a message html body
		if (!isset($message->htmlbody) || !Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($message->htmlbody))
		{
			Factory::getApplication()->enqueueMessage(Text::sprintf('There was an error sending <b>%s</b> since it has no html set.', $message->subject), 'Error');
			return false;
		}
		// build global values
		$global = array();
		// add footer & header
		$global[] = array('[document_footer]' => self::getTemplate('doc_footer', ''), '[document_header]' => self::getTemplate('doc_header', ''), '[text_footer]' => self::getTemplate('text_footer', ''), '[text_header]' => self::getTemplate('text_header', ''));
		// get company details
		$global[] = self::getCompanyDetails('placeholder');
		// get project details
		if ($project_id)
		{
			$global[] = self::getProjects($project_id, $db, false, true);
		}
		// combine
		$global = self::mergeArrays($global);
		// get the unsubscribe key
		$keyUnsubscribe = self::getUnsubscribeKey();
		// get the unsubscribe url
		$urlUnsubscribe = self::getUnsubscribeUrl();
		// start the engine
		foreach ($items as $item)
		{
			// load to project details
			$item['[project_name]'] = $global['[project_name]'];
			$item['[project_project]'] = $global['[project_project]'];
			$item['[project_description]'] = $global['[project_description]'];
			$item['[project_short_description]'] = $global['[project_short_description]'];
			// set unsubscribe
			$unsubscribe = $urlUnsubscribe . self::lock($item, $keyUnsubscribe, 0);
			// load to email the unsubscribe
			$item['[unsubscribe_link]'] = '<a href="' . $unsubscribe . '" target="_blank" title="' . Text::_('Unsubscribe') . '">' . Text::_('Unsubscribe') . '</a>';
			$item['[unsubscribe_url]'] = $unsubscribe;
			// set placeholders
			$placeholders = self::mergeArrays(array($global, $item));
			// get the body for both html and text
			$html = self::setDynamicData($message->htmlbody, $placeholders);
			$text = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($message->textbody)) ? self::setDynamicData($message->textbody, $placeholders) : '';
			// set the subject
			$subject = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($message->subject)) ? self::setDynamicData($message->subject, $placeholders) : Text::_('No subject was set');
			// add some custom email headers
			[[[Component]]]Email::setHeader('List-Unsubscribe', '<' . $unsubscribe . '>');
			// now send the email
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($html) && $result = [[[Component]]]Email::send($item['[developer_email]'], $subject, [[[Component]]]Email::setTableBody($html, $subject), $text, 1))
			{
				// update the send table to make sure we do not send this message to this developer again
				self::messageSend($message_id, $item['[developer_github_id]'], $db);
			}
		}
		return true;
	}

	/**
	* 	set that the message was send
	**/
	public static function messageSend($message_id, $user, $db = null)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		// update the table
		$object = new \stdClass();
		$object->user = (int) $user;
		$object->message = (int) $message_id;
		$db->insertObject('#__[[[component]]]_send', $object);
	}

	/**
	* 	check if a message was send
	**/
	public static function wasSend($message_id, $user, $db = null)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		// start the query
		$query = $db->getQuery(true);
		// Select all the values in the message
		$query->select('a.*');
		$query->from('#__[[[component]]]_send AS a');
		$query->where($db->quoteName('a.message') . ' = ' . (int) $message_id);
		$query->where($db->quoteName('a.user') . ' = ' . (int) $user);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return true;
		}
		return false;
	}

	/**
	* 	messages in memory
	**/
	protected static $massageMemory = array();

	/**
	* 	get a message
	**/
	public static function getMessage($message_id, $db = null)
	{
		if (!isset(self::$massageMemory[$message_id]))
		{
			// Get a db connection
			if (!$db)
			{
				$db = Factory::getDbo();
			}
			// start the query
			$query = $db->getQuery(true);
			// Select all the values in the message
			$query->select('a.*');
			$query->from('#__[[[component]]]_message AS a');
			$query->where($db->quoteName('a.id') . ' = ' . (int) $message_id);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				self::$massageMemory[$message_id] = $db->loadObject();
			}
			else
			{
				self::$massageMemory[$message_id] = false;
			}
		}
		// return the message
		return self::$massageMemory[$message_id];
	}

	public static function getRelationships($project = null, $user = null, $rel = null, $db = null)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		$query = $db->getQuery(true);
		// Select all the values in the relationship builder
		$query->select('a.*');
		// link in the other values
		$query->select(
			$db->quoteName(
				array(
					'd.login',
					'd.email',
					'p.name',
					'p.project'
				), array(
					'login',
					'email',
					'owner',
					'project_name'
				)
			)
		);
		$query->from('#__[[[component]]]_relationship_builder AS a');
		// only check for user if set
		if ($user)
		{
			$query->where($db->quoteName('a.user') . ' = ' . (int) $user);
		}
		// only check for project if set
		if ($project)
		{
			$query->where($db->quoteName('a.project') . ' = ' . (int) $project);
		}
		// only check for relationship if set
		if ($rel)
		{
			$query->where($db->quoteName('a.relationship') . ' = ' . (int) $rel);
		}
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_developer', 'd') . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('d.github_id') . ')');
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_project', 'p') . ' ON (' . $db->quoteName('a.project') . ' = ' . $db->quoteName('p.id') . ')');
		// set the query using our newly populated query object.
		$db->setQuery($query);
		$db->execute();
		$number = $db->getNumRows();
		if ($number == 1)
		{
			// load the item
			$item = $db->loadObject();
			// set the name
			if (isset(self::$relationshipName[$item->relationship]))
			{
				$item->relationship_name = self::$relationshipName[$item->relationship];
			}
			return $item;
		}
		elseif ($number > 1)
		{
			// load the items
			$items = $db->loadObjectList();
			foreach ($items as $nr => &$item)
			{
				// set the name
				if (isset(self::$relationshipName[$item->relationship]))
				{
					$item->relationship_name = self::$relationshipName[$item->relationship];
				}
			}
			return $items;
		}
		return false;
	}

	public static function getToken(&$tokens)
	{
		$tokens = array_values($tokens);
		$token = array_shift($tokens);
		array_push($tokens, $token);
		return $token['token'];
	}

	public static function getProjects($id = null, $db = null, $justTokens = false, $placeholders = false)
	{
		// Get a db connection
		if (!$db)
		{
			$db = Factory::getDbo();
		}
		$query = $db->getQuery(true);
		// Select all the values in the field
		if ($placeholders)
		{
			$selection = self::getSelection('project', '[project_', ']');
		}
		else
		{
			$selection = self::getSelection('project');
		}
		// Select some fields
		$query->select(
			$db->quoteName(
				array_keys($selection), array_values($selection)
			)
		);
		$query->from('#__[[[component]]]_project AS a');
		if (is_numeric($id) && $id > 0)
		{
			$query->where($db->quoteName('a.id') . ' = ' . (int) $id);
		}
		else
		{
			$query->where($db->quoteName('a.published') . ' = 1');
		}
		// set the query using our newly populated query object.
		$db->setQuery($query);
		$db->execute();
		$number = $db->getNumRows();
		// get details of one project as placeholders
		if ($placeholders && $number == 1)
		{
			return $db->loadAssoc();
		}
		elseif (!$placeholders && $number == 1)
		{
			// load the item
			$item = $db->loadObject();
			// Get the medium encryption.
			$mediumkey = self::getCryptKey('medium');
			// Get the encryption object.
			$medium = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($mediumkey);
			if (!empty($item->tokens) && $mediumkey && !is_numeric($item->tokens) && $item->tokens === base64_encode(base64_decode($item->tokens, true)))
			{
				// medium decrypt data tokens.
				$item->tokens = rtrim($medium->decryptString($item->tokens), "\0");
			}
			if (!empty($item->tokens))
			{
				// Convert the tokens field to an array.
				$item->tokens = json_decode($item->tokens, true);
			}
			// return just the tokens
			if ($justTokens)
			{
				return array_values($item->tokens);
			}
			// return the project
			return $item;
		}
		elseif (!$placeholders && $number > 1)
		{
			// load the items
			$items = $db->loadObjectList();
			// Get the medium encryption.
			$mediumkey = self::getCryptKey('medium');
			// Get the encryption object.
			$medium = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($mediumkey);
			foreach($items as $nr => &$item)
			{
				if (!empty($item->tokens) && $mediumkey && !is_numeric($item->tokens) && $item->tokens === base64_encode(base64_decode($item->tokens, true)))
				{
					// medium decrypt data tokens.
					$item->tokens = rtrim($medium->decryptString($item->tokens), "\0");
				}
				if (!empty($item->tokens))
				{
					// Convert the tokens field to an array.
					$item->tokens = json_decode($item->tokens, true);
				}
				// return just the tokens
				if ($justTokens)
				{
					$item = new \stdClass();
					$item->tokens = array_values($item->tokens);
				}
			}
			return $items;
		}
		return false;
	}

	public static function checkEmailAndDomain($_email)
	{
		$exp = "/^(.*)@(.*)$/";
		preg_match($exp, $_email, $matches);

		if (!empty($matches[1]) && (!filter_var($_email, FILTER_VALIDATE_EMAIL)))
		{
			return false;
		}

		// check if it has the users.noreply.github.com
		if (self::strposa($_email, self::$notEmail) !== false)
		{
			return false;
		}

		return (checkdnsrr($matches[2], 'MX'));
	}

	public static function strposa($haystack, $needles = array(), $offset = 0)
	{
		$chr = array();
		foreach($needles as $needle)
		{
			$res = strpos($haystack, $needle, $offset);
			if ($res !== false)
			{
				$chr[$needle] = $res;
			}
		}

		if(!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($chr))
		{
			return false;
		}
		return min($chr);
	}
[CUSTOMCODE=getGithubRepoFileList]
[CUSTOMCODE=loadMessages]
[CUSTOMCODE=theButler]
[CUSTOMCODE=getFileContents]
[CUSTOMCODE=locker]
[CUSTOMCODE=urlExists]
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=curlWorkerHelper]
[CUSTOMCODE=getCompanyDetails]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=setSubformTable]', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'gitHubbing', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbnNoaXBfYnVpbGRlcmAgKA0KCWB1c2VyYCBJTlQoNjUpIHVuc2lnbmVkIE5PVCBOVUxMIERFRkFVTFQgMCwNCglgcHJvamVjdGAgSU5UKDEwKSB1bnNpZ25lZCBOT1QgTlVMTCBERUZBVUxUIDAsDQoJYHJlbGF0aW9uc2hpcGAgSU5UKDEwKSB1bnNpZ25lZCBOT1QgTlVMTCBERUZBVUxUIDAsDQoJYHN0YXR1c2AgSU5UKDEwKSB1bnNpZ25lZCBOT1QgTlVMTCBERUZBVUxUIDEsDQoJS0VZICBgaWR4X3VzZXJgIChgdXNlcmApLA0KCUtFWSAgYGlkeF9wcm9qZWN0YCAoYHByb2plY3RgKSwNCglLRVkgIGBpZHhfcmVsYXRpb25zaGlwYCAoYHJlbGF0aW9uc2hpcGApLA0KCUtFWSAgYGlkeF9zdGF0dXNgIChgc3RhdHVzYCkNCikgRU5HSU5FPU15SVNBTSBBVVRPX0lOQ1JFTUVOVD0wIERFRkFVTFQgQ0hBUlNFVD11dGY4Ow0KDQpDUkVBVEUgVEFCTEUgSUYgTk9UIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3NlbmRgICgNCglgdXNlcmAgSU5UKDY1KSB1bnNpZ25lZCBOT1QgTlVMTCBERUZBVUxUIDAsDQoJYG1lc3NhZ2VgIElOVCgxMCkgdW5zaWduZWQgTk9UIE5VTEwgREVGQVVMVCAwLA0KCUtFWSAgYGlkeF91c2VyYCAoYHVzZXJgKSwNCglLRVkgIGBpZHhfbWVzc2FnZWAgKGBtZXNzYWdlYCkNCikgRU5HSU5FPU15SVNBTSBBVVRPX0lOQ1JFTUVOVD0wIERFRkFVTFQgQ0hBUlNFVD11dGY4Ow==', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbnNoaXBfYnVpbGRlcmA7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3NlbmRgOw==', 'gitHubbing', '.git', '', '', 1, '', 'https://www.gnu.org/', '', 'FgU8dnv4esXb4Y0Pod03W/PVxU/lV2IK9pwkJK3hDVo=', '', '', 1, 148, '', 1, 64), -(20, 1, '', 1, '', 1, '', '', '', 1, '', 1, '', '', '', '', '', '', 1, '', 1, '', 1, '', '', '', '', 3, '', 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.2.6', 'Copyright (C) 2015. All Rights Reserved', '2016-03-07 02:59:34', 1, 'F4Hy7Xd96SXDPdxXM6kP3JBujyRs+yFWvq8rjqWAASY=', 'AJ9USWMt2/6+tbNPYO+ugWnRfRWRjK5XB8V0gq0Kq3I=', '', '+7JrFIHK+uE62eET7M02iOMjaFYQ40ItHM8t7bUPCN0=', 'LnZkbS1iYWRnZSB7DQogICAgLW1vei1ib3JkZXItYm90dG9tLWNvbG9yczogbm9uZTsNCiAgICAtbW96LWJvcmRlci1sZWZ0LWNvbG9yczogbm9uZTsNCiAgICAtbW96LWJvcmRlci1yaWdodC1jb2xvcnM6IG5vbmU7DQogICAgLW1vei1ib3JkZXItdG9wLWNvbG9yczogbm9uZTsNCiAgICBiYWNrZ3JvdW5kOiAjMDA5ZGQ4IGxpbmVhci1ncmFkaWVudCh0byBib3R0b20sICMwMGI0ZjUsICMwMDhkYzUpIHJlcGVhdCBzY3JvbGwgMCAwIGJvcmRlci1ib3g7DQogICAgYm9yZGVyLWNvbG9yOiByZ2JhKDAsIDAsIDAsIDAuMikgcmdiYSgwLCAwLCAwLCAwLjIpIHJnYmEoMCwgMCwgMCwgMC4zKTsNCiAgICBib3JkZXItaW1hZ2U6IG5vbmU7DQogICAgYm9yZGVyLXJhZGl1czogMnB4Ow0KICAgIGJvcmRlci1zdHlsZTogc29saWQ7DQogICAgYm9yZGVyLXdpZHRoOiAxcHg7DQogICAgY29sb3I6ICNmZmY7DQogICAgZGlzcGxheTogaW5saW5lLWJsb2NrOw0KICAgIGZvbnQtc2l6ZTogMTBweDsNCiAgICBmb250LXdlaWdodDogNzAwOw0KICAgIGxpbmUtaGVpZ2h0OiAxNHB4Ow0KICAgIHBhZGRpbmc6IDAgNXB4Ow0KICAgIHRleHQtYWxpZ246IGNlbnRlcjsNCiAgICB0ZXh0LXNoYWRvdzogMCAtMXB4IDAgcmdiYSgwLCAwLCAwLCAwLjIpOw0KICAgIHRleHQtdHJhbnNmb3JtOiBub25lOw0KICAgIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7DQp9DQoNCi52ZG0tdGV4dC1kYW5nZXIgew0KICAgIGNvbG9yOiAjZDMyYzQ2Ow0KfQ0KDQoudmRtLWRhbmdlciB7DQogICAgYmFja2dyb3VuZC1jb2xvcjogI2QzMmM0NjsNCiAgICBiYWNrZ3JvdW5kLWltYWdlOiBsaW5lYXItZ3JhZGllbnQodG8gYm90dG9tLCAjZWU0NjVhLCAjYzExYTM5KTsNCn0NCi52ZG0td2FybmluZyB7DQogICAgYmFja2dyb3VuZC1jb2xvcjogI2Y5YTEyNDsNCiAgICBiYWNrZ3JvdW5kLWltYWdlOiBsaW5lYXItZ3JhZGllbnQodG8gYm90dG9tLCAjZmJiNDUwLCAjZjg5NDA2KTsNCn0NCi52ZG0tc3VjY2VzcyB7DQogICAgYmFja2dyb3VuZC1jb2xvcjogIzgyYmI0MjsNCiAgICBiYWNrZ3JvdW5kLWltYWdlOiBsaW5lYXItZ3JhZGllbnQodG8gYm90dG9tLCAjOWZkMjU2LCAjNmZhYzM0KTsNCn0=', '', '', 1, '', 'Job Tracking System', 'joomla@vdm.io', '', 'https://vdm.bz/jcb-job-tracking-system', 'KN+kAEoH9uOH3HwtlSviUI4XYyRQ+MlhzXeHP8OqsMYeF3xrBw4uQhF+EsiBOYbCihsiM3vM7fjR6tTejSrPig==', '', 'd742c3eb-c2fe-4796-ab8e-5e37b9748c4d', 'images/vdm/JT500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-08-05 09:37:35', '', 'Job Tracking', 'Jobtracking', '', 4, 'CQlzZWxmOjpsb2FkVXBkYXRlckFqYXgoJGRvY3VtZW50KTsNCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw==', '	/**
	* the params
	**/
	protected static $params;

	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// noting set for now
	}

	/**
	* 	Load the auto updater
	**/
	public static function loadUpdaterAjax($document)
	{
		$document->addScriptDeclaration("
			jQuery(window).load(function() {
				runQueue(3);
			});
			
			function runQueue(fromview){
				var getUrl = '".Uri::root()."administrator/index.php?option=com_[[[component]]]&task=ajax.updating&format=json';
				if(fromview > 0){
					var request = 'token=".Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken()."&fromview='+fromview;
				}
				return jQuery.ajax({
					type: 'GET',
					url: getUrl,
					dataType: 'jsonp',
					data: request,
					jsonp: 'callback'
				});
			}
		");
	}

	protected static $clientDetails = array();
	
	public static function getClientDetails($id, $type = 'client', $method = 'object')
	{
		if (!isset(self::$clientDetails[$id.$method]))
		{
			if ($type != 'client')
			{
				$id = self::getVar((string) $type, (int) $id, 'id', 'client');
			}
			// Create a new query object.
			$db = Factory::getDBO();
			$query = $db->getQuery(true);
	
			// Select some fields
			if ('placeholder' == $method)
			{
				$query->select($db->quoteName(
					array('a.name', 'a.contact_person','a.email','a.phone','a.mobile_phone','a.fax','a.postal','a.postalcode','a.city','a.street','a.website','a.discount'), 
					array('[client_name]','[client_contact_person]','[client_email]','[client_phone]','[client_mobile]','[client_fax]','[client_postal]','[client_postalcode]','[client_city]','[client_street]','[client_website]','[discount_id]')));
					
				$query->select($db->quoteName(array('r.name', 'c.name','d.amount','d.type'), array('[client_region_name]','[client_country_name]','[discount_amount]','[discount_type]')));
			}
			else
			{
				$query->select('a.*');
				$query->select($db->quoteName(array('r.name', 'c.name','d.amount','d.type'), array('region_name','country_name','discount_amount','discount_type')));
			}

			// From the [[[component]]]_client table
			$query->from($db->quoteName('#__[[[component]]]_client', 'a'));
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_region', 'r') . ' ON (' . $db->quoteName('a.region') . ' = ' . $db->quoteName('r.id') . ')');
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'c') . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('c.id') . ')');
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_discount', 'd') . ' ON (' . $db->quoteName('a.discount') . ' = ' . $db->quoteName('d.id') . ')');
			$query->where($db->quoteName('a.id') . ' = '. (int) $id);
			// load the query
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				if ('object' == $method)
				{
					self::$clientDetails[$id.$method] = $db->loadObject();
				}
				else
				{
					self::$clientDetails[$id.$method] = $db->loadAssoc();
				}
			}
		}
		if (!isset(self::$clientDetails[$id.$method]))
		{
			self::$clientDetails[$id.$method] = false;
		}
		return self::$clientDetails[$id.$method];
	}

	protected static $jobOrdersDetails = array();
	
	public static function getJobOrderDetails($id, $type, $method = 'object')
	{
		if (!isset(self::$jobOrdersDetails[$id.$method]))
		{
			if ($id > 0 )
			{
				// Create a new query object.
				$db = Factory::getDBO();
				$query = $db->getQuery(true);
				
				// Select some fields
				if ('placeholder' == $method)
				{
					$query->select($db->quoteName(
						array('a.jobnumber','a.order_date','a.delivery_date','a.created_by','a.check_list'), 
						array('[jobnumber]','[order_date]','[delivery_date]','created_by','check_list')));
				}
				else
				{
					$query->select('a.*');
				
				}
				// From the [[[component]]]_job_order table
				$query->from($db->quoteName('#__[[[component]]]_job_order', 'a'));
				if ($type == 'job_order' || $type == 'job_orders')
				{
					$query->where($db->quoteName('a.id') . ' = '. (int) $id);
				}
				// load the query
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					if ('object' == $method)
					{
						$details = $db->loadObject();
					}
					else
					{		
						$details = $db->loadAssoc();
						foreach ($details as $key => &$value)
						{
							if ($key == 'created_by' && $value > 0)
							{
								$staff = Factory::getUser($value);
								// set staff details
								$details['[staff_name]'] = $staff->name;
								$details['[staff_email]'] = $staff->email;
							}
							if ('0000-00-00 00:00:00' != $value && strpos($key, '_date') !== false)
							{
								$value = self::fancyDate($value);
							}
							elseif ('0000-00-00 00:00:00' == $value)
							{
								$value = '0000-00-00';
							}
							if ($key == 'check_list')
							{
								// build check list
								if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($value))
								{
									$fields = json_decode($value,true);
									if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($fields))
									{
										foreach($fields as $field)
										{
											if (!isset($details[$field]))
											{
												$details['['.$field.']'] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($field, 'Ww');
											}	
										}
									}
								}
								unset($details[$key]);						
							}
						}
					}
					unset($details['created_by']);
					self::$jobOrdersDetails[$id.$method] = $details;
				}
			}
		}
		if (!isset(self::$jobOrdersDetails[$id.$method]))
		{
			self::$jobOrdersDetails[$id.$method] = false;
		}
		return self::$jobOrdersDetails[$id.$method];
	}

	public static function getJobOrder($id, $db = null, $type = 'job_status', $method = 'array')
	{
		if (!$db)
		{
			// get a database connection
			$db = Factory::getDBO();
		}
		$query = $db->getQuery(true);
				
		// Select all fields
		$query->select('a.*');
		// From the [[[component]]]_job_order table
		$query->from($db->quoteName('#__[[[component]]]_job_order', 'a'));
		if ($type == 'job_status')
		{
			$query->where($db->quoteName('a.id') . ' = '. (int) $id);
		}
		// load the query
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			if ('object' == $method)
			{
				return $db->loadObject();
			}
			elseif ('array' == $method)
			{
				return $db->loadAssoc();
			}
			else
			{
				return $db->loadRow();
			}
		}
		return false;
	}

	public static function getNeededItem($job_order, $item, $db = null)
	{
		if ($job_order > 0)
		{
			if (!$db)
			{
				$db = Factory::getDbo();
			}
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select(array('id','item','needed','ordered','allocated'));
			$query->from($db->quoteName('#__[[[component]]]_needed_item'));
			$query->where($db->quoteName('job_order') . ' = '. (int) $job_order);
			$query->where($db->quoteName('item') . '  = ' . (int) $item);
			// Reset the query using our newly populated query object.
			$db->setQuery($query);
			$db->execute();
			// check if there was data returned
			if ($db->getNumRows())
			{
				return $db->loadObject();
			}
		}
		return false;
	}

	public static function getNeededItems($job_order, $type = 0)
	{
		if ($job_order > 0)
		{
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select(array('id','item','needed','ordered','allocated'));
			$query->from($db->quoteName('#__[[[component]]]_needed_item'));
			$query->where($db->quoteName('job_order') . ' = '. (int) $job_order);
			// default is to get all (0)
			if (1 == $type) // ready
			{
				$query->where('allocated = needed');
			}
			elseif (2 == $type) // not ready
			{
				$query->where('allocated != needed');
			}
			elseif (6 == $type) // has problems
			{
				$query->where('problem = 0');
			}
			// Reset the query using our newly populated query object.
			$db->setQuery($query);
			$db->execute();
			// check if there was data returned
			if ($db->getNumRows())
			{
				if (3 == $type || 6 == $type)
				{
					return true;
				}
				return $db->loadObjectList('item');
			}
		}
		return false;
	}

	public static function hasProblem($job_order)
	{
		return self::getNeededItems($job_order, 6);
	}
	
	protected static $neededItems = array();
	protected static $neededQty = array();

	public static function updateNeededItems($job_order, $products = null, $job_status = null, $userId = null, $todayDate = null, $db = null)
	{
		if ($job_order > 0)
		{
			// get job status
			if (!$job_status)
			{
				$job_status = self::getVar('job_order', $job_order, 'id', 'job_status');	
			}
			// convert producs to array
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($job_status))
			{
				$job_status = json_decode($job_status, true);
			}
			// get activation status
			$activating_order_status = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('order_status', null);
			// only continue if job status has ordering status active, or already has needed items set.
			if ((Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($job_status) && in_array($activating_order_status, $job_status)) || self::getNeededItems($job_order, 3))
			{
				// checker
				$checker = true;
				self::$neededItems = array();
				self::$neededQty = array();
				$table = 'needed_item';
				// Get a db connection.
				if (!$db)
				{
					$db = Factory::getDbo();
				}
				// get products
				if (!$products)
				{
					$products = self::getVar('job_order', $job_order, 'id', 'product');	
				}
				// convert producs to array
				if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($products))
				{
					$products = json_decode($products, true);
				}
				// continue only if products are found
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($products) && isset($products['item']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($products['item']))
				{
					// make sure we have the user ID
					if(!$userId)
					{
						$userId = Factory::getUser()->id;
					}
					// also get todays date if not found
					if (!$todayDate)
					{
						$todayDate = Factory::getDate()->toSql();
					}
					// now loop products and see if they are all ready set
					foreach ($products['item'] as $nr => $itemId)
					{
						if ($itemId > 1) // TODO own product has ID 1
						{
							self::$neededQty[$itemId][] = (int) (isset($products['qty'][$nr])) ? $products['qty'][$nr] : 0;
							if (!self::setNeededItem($job_order, $itemId, self::$neededQty[$itemId], $userId, $todayDate, $db, $table))
							{
								$checker = false;
							}
							self::$neededItems[] = $itemId;
						}
					}
				}
				// check if needed items were found
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$neededItems))
				{
					// remove all that is not in this array
					$conditions = array(
					    $db->quoteName('item') . ' NOT IN (' . implode(',', self::$neededItems) . ')',
					    $db->quoteName('job_order') . ' = ' . (int) $job_order
					);
				}
				else
				{
					// no needed items for this job, so clear all items
					$conditions = array(
					    $db->quoteName('job_order') . ' = ' . (int) $job_order
					);
				}
				// delete all not needed
				$query = $db->getQuery(true);
				$query->delete($db->quoteName('#__[[[component]]]_'.$table));
				$query->where($conditions);
				$db->setQuery($query);
				$db->execute();
				// return the checker
				return $checker;
			}
		}
		return false;
	}
	
	protected static function setNeededItem(&$job_order, &$item, &$needed, &$userId, &$todayDate, &$db, &$table)
	{
		// always get supplier
		$supplier = self::getVar('item', $item, 'id', 'supplier');
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select(array('id','version','needed','supplier'));
		$query->from($db->quoteName('#__[[[component]]]_'.$table));
		$query->where($db->quoteName('job_order') . ' = '. (int) $job_order);
		$query->where($db->quoteName('item') . ' = '. (int) $item);
		$db->setQuery($query);
		$db->execute();
		// check if found
		if ($db->getNumRows())
		{
			// update the record
			$record = $db->loadAssoc();
			if ($needed != $record['needed'] || $supplier != $record['supplier'])
			{
				// create new object
				$object = new \stdClass();
				$object->id = (int) $record['id'];
				$object->needed = (int) array_sum($needed);
				$object->supplier = (int) $supplier;
				$object->version = (int) $record['version'] + 1;
				$object->modified_by = (int) $userId;
				$object->modified = $todayDate;
				// update now
				return $db->updateObject('#__[[[component]]]_'.$table, $object, 'id');
			}
			return true;
		}
		// add new record
		$object = new \stdClass();
		$object->item = (int) $item;
		$object->job_order = (int) $job_order;
		$object->needed = (int) array_sum($needed);
		$object->supplier = (int) $supplier;
		$object->created_by = (int) $userId;
		$object->created = $todayDate;
		$object->published = 1;
		$object->version = 1;
		// add now
		$done = $db->insertObject('#__[[[component]]]_'.$table, $object);
		if ($done)
		{
			$aId = $db->insertid();
			// make sure the access of asset is set
			return self::setAsset($aId,$table);
		}
		return false;
	}

	public static function getCheckList()
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select('*');
		$query->from($db->quoteName('#__[[[component]]]_job_status'));
		$query->where($db->quoteName('published'). ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$items = $db->loadObjectList();
			$options = array();
			foreach ($items as $item)
			{
				if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($item->switch))
				{
					$switches = json_decode($item->switch, true);
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($switches))
					{
						foreach ($switches as $field => $values)
						{
							if ('switch' == $field && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($values))
							{
								foreach ($values as $value)
								{
									$statusName = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->name);
									$switchName = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($value);
									$tmp = array(
										'value'    => $statusName.'__'.$switchName.'__selected',
										'text'     => '&nbsp;&nbsp;<b>'.$value.'</b>',
										'checked'  => false
									);
									$options[] = (object) $tmp;
								}
							}
						}
					}
				}
			}
			return $options;
		}
		return false;
	}

	public static function getProductionTypes($setStatus = null)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select('*');
		$query->from($db->quoteName('#__[[[component]]]_production_type'));
		$query->where($db->quoteName('published'). ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$items = $db->loadObjectList();
			$options = array();
			foreach ($items as $item)
			{
				if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($item->empty))
				{
					$targets= json_decode($item->empty, true);
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($targets))
					{
						foreach ($targets as $fieldName)
						{
							$tmp = array(
								'value'    => 'job_order__'.Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->alias).'__'.Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($fieldName).'_empty',
								'text'     => '&nbsp;&nbsp;<b>'.$item->alias.' '.$fieldName.' Empty</b>',
								'checked'  => false
							);
							if ($setStatus)
							{
								$tmp['field'] = $fieldName;
								$tmp['id'] = $item->id;
								$tmp['type'] = 'empty';
							}
							$options[] = (object) $tmp;
						}
					}
				}
				$tmp = array(
					'value'    => 'job_order__'.Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->alias).'__selected',
					'text'     => '&nbsp;&nbsp;<b>'.$item->alias.' Selected</b>',
					'checked'  => false
				);
				if ($setStatus)
				{
					$tmp['field'] = 'production_type';
					$tmp['id'] = $item->id;
					$tmp['type'] = 'selected';
				}
				$options[] = (object) $tmp;
			}
			return $options;
		}
		return false;
	}

	public static function checkCheckList(&$data)
	{
		$check['his']	= self::hisStatuses('check-list');
		$merge		= array();
		$typeSet	= 'json';
		if (isset($data['id']) && $data['id'] > 0)
		{
			// get the old checklist
			$check['old'] = self::getVar('job_order',$data['id'],'id','check_list');
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($check['old']))
			{
				$check['old'] = json_decode($check['old'], true);
			}
		}
		if (isset($data['check_list']) && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($data['check_list']))
		{
			$check['new'] = json_decode($data['check_list'], true);
			$typeSet = 'json';
		}
		elseif (isset($data['check_list']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data['check_list']))
		{
			$check['new'] = $data['check_list'];
			$typeSet = 'array';
		}
		// now lets see does he have any access
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($check['his']))
		{
			// he can edit some lets find it
			if (isset($check['old']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($check['old']))
			{
				// remove what he can update from old
				$merge[] = (array) array_diff($check['old'], $check['his']);
			}
			if (isset($check['new']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($check['new']))
			{
				// get those he has and can edit.
				$merge[] = (array) array_intersect($check['new'], $check['his']);
			}
			$check['keep'] = self::mergeArrays($merge);
			// ensure only the keep what he can update
			self::setCheckList($data, $check, 'keep', $typeSet);
		}
		else
		{
			// he is not allowed to edit any
			self::setCheckList($data, $check, 'old', $typeSet);
		}
	}
	
	protected static function setCheckList(&$data, $check, $with, $typeSet)
	{
		if (isset($check[$with]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($check[$with]))
		{
			// restore the old set
			if ('json' == $typeSet)
			{
				$data['check_list'] = json_encode($check[$with]);
			}
			else
			{
				$data['check_list'] = $check[$with];
			}
		}
		else
		{
			// clear any selections made
			$data['check_list'] = '';
		}
	}

	public static function dynamicUpdateJobStatus()
	{
		// first we must get all the published jobs and their data
		$ids = self::getVars('job_order', 1, 'published', 'id');
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
             		$db = Factory::getDbo();
			foreach ($ids as $id)
			{
				if ($job = self::getJobOrder($id, $db))
				{
					$jobStatus = self::setJobStatus($job);
					if ($job['job_status'] != $jobStatus)
					{
						// update the status
						$updateItem		= new \stdClass;
						$updateItem->id		= $id;
						$updateItem->job_status	= $jobStatus;						
						// update the item now
						$db->updateObject('#__[[[component]]]_job_order', $updateItem, 'id');
					}
				}
			}
              		return true;
		}
                return false;
	}

	public static function setJobStatus($job)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($job))
		{
			$job = (array) $job;
		}
		// make sure we have an array
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($job))
		{
			$updater = array();
			$jobStatus = array();
			$now = Factory::getDate()->toUnix();
			$orderTime = (isset($job['order_date'])) ? strtotime($job['order_date']) : false;
			$deliveryTime = (isset($job['delivery_date'])) ? strtotime($job['delivery_date']) : false;
			// set some basic values
			$updater['job_order__product__selected'] = 
				(isset($job['product']) && (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($job['product']) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($job['product']))) ? true : false;
			$updater['job_order__product__all_allocated'] = 
				($updater['job_order__product__selected']) ? self::isAllAllocated($job['id'], $job['product']) : false;
			$updater['job_order__production__selected'] = 
				(isset($job['production']) && (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($job['production']) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($job['production']))) ? true : false;
			$updater['job_order__order_date__set'] = (isset($job['order_date'])) ? true : false;
			$updater['job_order__order_date__past'] = ($orderTime && $orderTime < $now) ? true : false;
			$updater['job_order__delivery_date__set'] = (isset($job['delivery_date'])) ? true : false;
			$updater['job_order__delivery_date__past'] = ($deliveryTime && $deliveryTime < $now) ? true : false;
			// setup replacement array
			$replace['job_order__product__selected'] = "updater['job_order__product__selected']";
			$replace['job_order__product__all_allocated'] = "updater['job_order__product__all_allocated']";
			$replace['job_order__production__selected'] = "updater['job_order__production__selected']";
			$replace['job_order__order_date__set'] = "updater['job_order__order_date__set']";
			$replace['job_order__order_date__past'] = "updater['job_order__order_date__past']";
			$replace['job_order__delivery_date__set'] = "updater['job_order__delivery_date__set']";
			$replace['job_order__delivery_date__past'] = "updater['job_order__delivery_date__past']";
			// set the check-list values
			$checkList = self::getCheckList();
			// make sure we have an array
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($checkList))
			{
				foreach($checkList as $object)
				{
					// setup switches
					$updater[(string) $object->value] = false;
					$replace[(string) $object->value] = "updater['".(string) $object->value."']";
				}
			}
			// now set job check list
			if (isset($job['check_list']) && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($job['check_list']))
			{
				$jobCheckList = json_decode($job['check_list'], true);
			}
			elseif (isset($job['check_list']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($job['check_list']))
			{
				$jobCheckList = $job['check_list'];
			}
			// now update the once selected
			if (isset($jobCheckList) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($jobCheckList))
			{
				foreach ($jobCheckList as $value)
				{
					$updater[(string) $value] = true;
				}
			}
			// get the production types
			$productionTypes = self::getProductionTypes(true);
			// make sure we have an array
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($productionTypes))
			{
				foreach($productionTypes as $object)
				{
					// setup empty types
					if ($object->type == 'empty')
					{
						$updater[(string) $object->value] = self::isEmpty($job['production'],(string) $object->field, 'production_type', (int) $object->id);
						$replace[(string) $object->value] = "updater['".(string) $object->value."']";
					}
					elseif ($object->type == 'selected')
					{
						$updater[(string) $object->value] = self::isEq($job['production'],(string) $object->field, (int) $object->id);
						$replace[(string) $object->value] = "updater['".(string) $object->value."']";
					}
				}
			}
			// now lets run the activation scripts
			$scripts = self::getActivationScripts();
			// make sure we have an array
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($scripts))
			{
				foreach ($scripts as $id => $script)
				{
					if (!empty($script['activate']))
					{
						$script = str_replace(array_keys($replace), array_values($replace), base64_decode($script['activate']));
						if (self::runFunc($script,$updater))
						{
							$jobStatus[] = $id;
						}
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($jobStatus))
			{
				return json_encode($jobStatus);
			}
		}
		return '';
	}

	protected static function isEq($data, $find, $id)
	{
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($data))
		{
			$data = json_decode($data,true);
		}
		// not check if find is found
		if (isset($data[$find]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data[$find]))
		{
			foreach ($data[$find] as $key => $value)
			{
				if ($value == $id)
				{
					// even if one field is equal return that it is found
					return true;
				}
			}
		}
		// the field is not set, therefore not selected.
		return false;
	}

	protected static function isEmpty($data, $find, $and = null, $at = null)
	{
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($data))
		{
			$data = json_decode($data,true);
		}
		// not check if find is found
		if (isset($data[$find]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data[$find]))
		{
			foreach ($data[$find] as $key => $value)
			{
				if ($and)
				{
					if ($at)
					{
						if ((empty($value) || $value == '') && isset($data[$and][$key]) && $data[$and][$key] == $at)
						{
							// even if one field in empty we should return that it is empty
							return true;
						}
					}
					elseif ((empty($value) || $value == '') && (empty($data[$and][$key]) || $data[$and][$key] == ''))
					{
						// even if one field in empty we should return that it is empty
						return true;
					}
				}
				elseif (empty($value) || $value == '')
				{
					// even if one field in empty we should return that it is empty
					return true;
				}
			}
			// if we arrived here that means the field is not empty
			return false;
		}
		// the field is not set, therefore empty.
		return true;
	}

	protected static function runFunc($script,&$updater)
	{
		return strlen($script) ? eval(" ". $script . " " ): false;
	}

	public static function getActivationScripts()
	{
		// Create a new query object.
		$db = Factory::getDBO();
		$query = $db->getQuery(true);

		// Select some fields
		$query->select('a.*');

		// From the [[[component]]]_item table
		$query->from($db->quoteName('#__[[[component]]]_job_status', 'a'));

		// Load the items
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadAssocList('id');
		}
		return false;
	}

	protected static function isAllAllocated($job_order, $products)
	{
		if ($job_order > 0)
		{
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($products))
			{
				$products = json_decode($products, true);
			}
			if (isset($products['item']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($products['item']))
			{
				$db = Factory::getDbo();
				foreach ($products['item'] as $nr => $item)
				{
					$found = self::getNeededItem($job_order, $item, $db);
					if (!isset($found->allocated) || $found->allocated != $products['qty'][$nr])
					{
						return false;
					}
				}
				return true;
			}
		}
		return false;
	}

	public static function newJobNumber()
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select('jobnumber');
		$query->from($db->quoteName('#__[[[component]]]_job_order'));
		$query->order('jobnumber ASC');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$jobnumbers = $db->loadColumn();
			$last = end($jobnumbers);
			// get the number
			$last = (int) preg_replace("/[^0-9,.]/", "", $last);
			// increment
			return 'J'.sprintf('%08d', ++$last);
		}
		return 'J'.sprintf('%08d', 1);
	}

	public static function uniqueNr(&$item , $where)
	{
		list($type, $column) = explode('.', $where);
		if ($type && $column)
		{
			// load the all items with the same column
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select(array('id' ,'created'));
			$query->from($db->quoteName('#__[[[component]]]_'.$type));
			$query->where($db->quoteName($column) . ' = '.$db->quote($item->$column));
			$query->order('created ASC');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$found = $db->loadObjectList();
				if (count($found) > 1)
				{
					// is the current item the older one?
					if ($item->id != $found[0]->id)
					{
						// first update the item
						$item->$column		= self::newJobNumber();
						// now update the table
						$updateItem		= new \stdClass;
						$updateItem->id		= $item->id;
						$updateItem->$column	= $item->$column;						
						// update the item now
						Factory::getDbo()->updateObject('#__[[[component]]]_'.$type, $updateItem, 'id');						
					}
				}
		
			}
			
		}
	}

	public static function getTable($type = null, $prefix = '[[[Component]]]Table', $config = array())
	{
		if ($type)
		{
			return JTable::getInstance($type, $prefix, $config);
		}
		return false;
	}

	public static function hisJobs($user = null, $group = null)
	{
		// Get a db connection.
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('id','job_status')));
		$query->from($db->quoteName('#__[[[component]]]_job_order'));
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$items = $db->loadObjectList();
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($items))
			{
				if (!isset($user) || !Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($user))
				{
					$user = Factory::getUser();
				}
				if (!isset($groups) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
				{
					$groups = (array) $user->get('groups');
				}
				// the bucket of his ids
				$bucket = array();
				foreach ($items as $item)
				{
					if (self::isHis($item->id, $user, $group, $item->job_status))
					{
						$bucket[] = $item->id;
					}
				}
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
				{
					return $bucket;
				}
			}
		}
		return false;
	}

	public static function isHis($job, $user = null, $group = null, $jobStatus = null)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($user))
		{
			$user = Factory::getUser();
		}
		if (!$user->authorise('core.options', 'com_[[[component]]]'))
		{
			if (!$jobStatus)
			{
				if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($job) && !isset($job->job_status))
				{
					$jobStatus = self::getVar('job_order', (int) $job, 'id', 'job_status');
				}
				else
				{
					$jobStatus = self::getVar('job_order', (int) $job->id, 'id', 'job_status');
				}
			}
			// check that there are status set for this job-order
			if (isset($jobStatus) && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($jobStatus))
			{
				$jobStatuses = json_decode($jobStatus, true);
			}
			elseif (isset($jobStatus) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($jobStatus))
			{
				$jobStatuses = array($jobStatus);
			}
			if (isset($jobStatuses) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($jobStatuses))
			{
				if (!isset($groups) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
				{
					$groups = (array) $user->get('groups');
				}
				if ($hisStatuses = self::hisStatuses('status-id',$groups))
				{
					if (array_intersect($hisStatuses, $jobStatuses))
					{
						return true;
					}
				}
			}
			return self::editingAccess($job, $user);
		}
		return true;
	}
	
	protected static $statuses = array();

	public static function hisStatuses($type, $groups = null)
	{
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			$user = Factory::getUser();
			$groups = (array) $user->get('groups');
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			$md5 = md5(json_encode($groups).$type);
			if (!isset(self::$statuses[$md5]))
			{
				// Create a new query object.
				$db = Factory::getDBO();
				$query = $db->getQuery(true);

				// Select some fields
				$query->select('a.*');

				// From the [[[component]]]_item table
				$query->from($db->quoteName('#__[[[component]]]_job_status', 'a'));

				// Load the items
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					$items = $db->loadObjectList();
					self::$statuses[$md5] = array();
					foreach ($items as $item)
					{
						if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($item->switch))
						{
							$switches = json_decode($item->switch, true);
							if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($switches))
							{
								foreach ($switches as $field => $values)
								{
									if ('switch' == $field && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($values))
									{
										foreach ($values as $nr => $value)
										{
											if (array_intersect($switches['groups'][$nr], $groups))
											{
												if ($type == 'check-list')
												{
													$statusName = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->name);
													$switchName = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($value);
													self::$statuses[$md5][] = $statusName.'__'.$switchName.'__selected';
												}
												elseif ($type == 'status-id')
												{
													self::$statuses[$md5][$item->id] = $item->id;
												}
											}
										}
									}
								}
							}
						}
					}
				}
			}
			// only return if values has been set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$statuses[$md5]))
			{
				return self::$statuses[$md5];
			}
		}
		return false;
	}

	public static function editingAccess($item, $user = null)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($user))
		{
			$user = Factory::getUser();
		}
		if (!$user->authorise('core.options', 'com_[[[component]]]'))
		{
			// if owner who created it
			if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->created_by))
			{
				$created_by = $item->created_by;
			}
			elseif (is_numeric($item))
			{
				$created_by = self::getVar('job_order', (int) $item, 'id', 'created_by');
			}
			if (isset($created_by) && is_numeric($created_by) && !empty($created_by) && $created_by != 0 && $created_by == $user->id)
			{
				return true;
			}
			// if checked it out by this user
			if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->checked_out))
			{
				$checked_out = $item->checked_out;
			}
			elseif (is_numeric($item))
			{
				$checked_out = self::getVar('job_order', (int) $item, 'id', 'checked_out');
			}
			if (isset($checked_out) && is_numeric($checked_out) && !empty($checked_out) && $checked_out != 0 && $checked_out == $user->id)
			{
				return true;
			}
			// or if modified by this user 10 minutes ago
			if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->modified_by))
			{
				$modified_by = $item->modified_by;
			}
			elseif (is_numeric($item))
			{
				$modified_by = self::getVar('job_order', (int) $item, 'id', 'modified_by');
			}				
			if (isset($modified_by) && !empty($modified_by) && $modified_by != 0 && $modified_by == $user->id)
			{
				if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->modified))
				{
					$modified = $item->modified;
				}
				elseif (is_numeric($item))
				{
					$modified = self::getVar('job_order', (int) $item, 'id', 'modified');
				}
				$modifiedTime = (!empty($modified) && $modified != '0000-00-00 00:00:00') ? strtotime($modified) : false;
				if ($modifiedTime)
				{
					$now = Factory::getDate()->toUnix();
 					$tenMinutsAgo = $now - (10 * 60);
					if ($modifiedTime > $tenMinutsAgo)
					{
						return true;
					}
				}
			}
			return false;
		}
		return true;
	}

	public static function setClient($data)
	{
		$setValues  = array(
			'name','contact_person','email',
			'phone','mobile_phone','fax','website',
			'street','postal','region','city','country',
			'postalcode' );
		// new client
		$client = new \stdClass();
		foreach ($setValues as $load)
		{
			if (isset($data[$load]) && !empty($data[$load]))
			{
				$client->$load = $data[$load];
			}
		}
		// only create if all needed values are set
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($client) && isset($client->name) && isset($client->email) && (isset($client->phone) || isset($client->mobile_phone)))
		{
			$db = Factory::getDbo();
			// load few more needed values
			$client->created_by	= Factory::getUser()->id;
			$client->created		= Factory::getDate()->toSql();
			$client->published	= 1;
			$client->access		= 1;
			$client->ordering	= 1;
			$client->version		= 1;
			// now create the client
			$done = $db->insertObject('#__[[[component]]]_client', $client);
			if ($done)
			{
				$id = $db->insertid();
				// make sure the access of asset is set
				self::setAsset($id,'client');
				// return the new client id
				return $id;
			}
		}
		return 0;
	}

	public static function getImageFileProperties($image)
	{
		$setimagesfolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('setimagesfolder', 1);
		if (2 == $setimagesfolder)
		{
			$localfolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('imagesfolder', JPATH_SITE.'/images/###component###');
		}
		elseif (1 == $setimagesfolder)
		{
			$localfolder =  JPATH_SITE.'/images';
		}
		else // just in-case :)
		{
			$localfolder =  JPATH_SITE.'/images/###component###';
		}
		// import all needed classes
		jimport('joomla.filesystem.folder');
		jimport('joomla.filesystem.file');
		jimport('joomla.image.image');
		// setup the folder if it does not exist
		if (JFolder::exists($localfolder) && JFile::exists($localfolder.'/'.$image))
		{
			$properties = JImage::getImageFileProperties($localfolder.'/'.$image);
			// check if we have properties
			if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($properties))
			{
				// remove the server path
				$imagePath = trim(str_replace(JPATH_SITE,'',$localfolder),'/').'/'.$image;
				// now add the src path to show the image
				$properties->src = Uri::root().$imagePath;
				// return the image properties
				return $properties;
			}
		}
		return false;
	}
	
	protected static $taxLocation = array();

	public static function getTaxLocation($type, $id, $view)
	{
		if ($id > 0 )
		{
			$key = $type.$view.$id;
			if (!isset(self::$taxLocation[$key]))
			{
				self::setTaxLocation($type, $id, $view, $key);
			}
			if (isset(self::$taxLocation[$key]) && self::$taxLocation[$key] > 0)
			{
				return self::$taxLocation[$key];
			}
		}
		return false;
	}

	protected static function setTaxLocation($type, $id, $view, $key)
	{
		switch ($view)
		{
			case 'job_order':
				// get the client id from job id
				$client_id = self::getVar($view, $id, 'id', 'client');
				// return location id from client table
				if ($client_id > 0)
				{
					self::$taxLocation[$key] = self::getVar('client', $client_id, 'id', $type);
				}
			break;
		}
	}

	public static function getTax(&$taxed, &$total, $id, $view)
	{
		$setTax = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('taxed', 0);
		if ($setTax == 1)
		{
			// set the tax to this array
			$tax = array();
			$taxAddTotal = array();
			$deduct = array();
			// get the country of the client
			$country = self::getTaxLocation('country', $id, $view);
			// get the region of the client
			$region = self::getTaxLocation('region', $id, $view);
			// now get tax level 1 of this Country and or Region
			$taxLevel1 = self::getTaxRule(1,$country,$region);
			// now get tax level 2 of this Country and or Region
			$taxLevel2 = self::getTaxRule(2,$country,$region);
			// tax types
			$tax_type = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('tax_type', 2);
			// tax compound
			$tax_compound = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('tax_compound', null);
			// based on tax type
			if (2 == $tax_type)
			{
				// tax excluded
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					$tmpAmount =  bcmul($taxed, $taxLevel1['tax'], 20);
					$tax[0]['amount'] = bcdiv($tmpAmount, 100, 4);
					// add to tax total
					$taxAddTotal[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$taxedSub = bcadd($taxed, $tax[0]['amount'], 20);
						$tmpAmount =  bcmul($taxedSub, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					else
					{
						$tmpAmount =  bcmul($taxed, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					// add to tax total
					$taxAddTotal[] = $tax[1]['amount'];
				}
			}
			elseif (1 == $tax_type)
			{
				$removal = array();
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$removal[] = $taxLevel1['tax'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$removal[] = $taxLevel2['tax'];
				}
				$removal = self::bcsum($removal);
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					if ($tax_compound == 1 && $taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']))
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal_a = bcdiv($taxed, $tempVal2, 20);
						$tempVal3 = bcdiv($taxLevel1['tax'], 100, 20);
						$tempVal4 = bcadd($tempVal3, 1, 20);
						$tempVal_b = bcdiv($tempVal_a, $tempVal4, 20);
						$tax[0]['amount'] =  bcsub($tempVal_a, $tempVal_b, 4);
					}
					else
					{
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel1['tax'], 20);
						$tax[0]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal = bcdiv($taxed, $tempVal2, 20);
						$tax[1]['amount'] = bcsub($taxed, $tempVal, 4);
					}
					else
					{
						$tax[1]['name'] = $taxLevel2['name'];
						$tax[1]['tax'] = $taxLevel2['tax'];
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[1]['amount'];
				}
			}
			// check if there was tax set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tax))
			{
				// add the tax to total
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($taxAddTotal))
				{
					$taxed = self::bcsum($taxAddTotal);
					$total = self::bcsum(array($total, $taxed));
				}
				elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($deduct))
				{
					$taxed = self::bcsum($deduct);
				}
				return $tax;
			}
		}
		return false;
	}
		
	protected static $taxrules = array();

	protected static function getTaxRule($level, $country = 0, $region = 0)
	{
		// build the key
		$key = $level.$country.$region;
		// check if it has been set
		if (!isset(self::$taxrules[$key]))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// set the tax rule
			self::setTaxRule($db, $key, $level, $country, $region);
		}
		if (isset(self::$taxrules[$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$taxrules[$key]))
		{
			return self::$taxrules[$key];
		}
		return false;
	}

	protected static function setTaxRule($db, $key, $level, $country = 0, $region = 0)
	{
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array(	'a.id','a.tax','a.name'),
			array(	'id','tax','name')));
		$query->from($db->quoteName('#__[[[component]]]_tax_rule', 'a'));
		$query->where($db->quoteName('a.published') . ' = 1');
		$query->where($db->quoteName('a.level') . ' = '. (int) $level);
		// check for country and region
		$query->where($db->quoteName('a.country') . ' = '. (int) $country);
		$query->where($db->quoteName('a.region') . ' = '. (int) $region);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$taxrules[$key] = $db->loadAssoc();
		}
		elseif ((int)$country > 0 && (int)$region > 0)
		{
			// now only check for country
			return self::setTaxRule($db, $key, $level, $country);
		}
		elseif ((int)$country > 0 && $region == 0)
		{
			// now check for any without country
			return self::setTaxRule($db, $key, $level);
		}
	}

	/**
	* @param float $amount
	**/
	public static function bcsum($array, $scale = 4)
	{
		$res = 0.0;
		foreach($array as $val){
			$res = bcadd($res, $val, $scale);
		}
		return $res;
	}

	/**
	* @param float $amount
	**/
	public static function addCurrency($amount)
	{
		return self::makeMoney($amount);
	}

	protected static $currencyDetails = array();

	public static function getCurrencyDetails($codethree = false)
	{
		// check if currency codethree is set
		if (!$codethree)
		{
			// get the main currency
			$codethree = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('currency', null);
		}
		// return cached data if set
		if ($codethree && !isset(self::$currencyDetails[$codethree]))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			if (is_numeric($codethree))
			{
				$query->where($db->quoteName('a.id') . ' = '. (int) $codethree);
			}
			elseif (strlen($codethree) == 3)
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote($codethree));
			}
			else
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote('NONE'));
			}
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				self::$currencyDetails[$codethree] = $db->loadObject();
			}
		}
		// make sure it has been set
		if (isset(self::$currencyDetails[$codethree]))
		{
			return self::$currencyDetails[$codethree];
		}
		return false;
	}

	/**
	 *	Publish all related data from the system
	 */
	public static function publishRelatedData(&$pks, $value,  $type)
	{
		switch ($type)
		{
			// clear all related data to job_orders
			case 'job_order':
				// get needed_item ids that are related to this job order
				$ids = self::getVars('needed_item', $pks, 'job_order');
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
				{
					// get model
					$neededItem = self::getModel('needed_item');
					// update the state
					$neededItem->publish($ids, (int) $value);
				}
			break;
			default:
				// do nothing
			break;
		}
	}

	/**
	 *	Delete all related data from the system
	 */
	public static function deleteRelatedData($pks, $type)
	{
		switch ($type)
		{
			// clear all related data to job_orders
			case 'job_order':
				// get needed_item ids that are related to this job order
				$ids = self::getVars('needed_item', $pks, 'job_order');
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
				{
					// get model
					$neededItem = self::getModel('needed_item');
					// first move to trash
					$neededItem->publish($ids, '-2');
					// then delete the needed_items
					$neededItem->delete($ids);
				}
			break;
			default:
				// do nothing
			break;
		}
	}

	/**
	* Get CSV Headers
	*/
	public static function getFileHeadersCSV($path)
	{
		// set the headers
		if(($handle = fopen($path, 'r')) !== false)
		{
			$result = fgetcsv($handle);
			fclose($handle);
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($result))
			{
				$key = 'A';
				foreach ($result as $header)
				{
					$headers[$key] = $header;
					$key++;
				}
				return $headers;
			}
		}
		return false;
	}
[CUSTOMCODE=theButler]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getCompanyDetails]
[CUSTOMCODE=makeMoney]
[CUSTOMCODE=niceFancyDate]', '', '', '', '', '', '', 'Ly8gbG9hZCB0aGUgaGVscGVyIGNsYXNzDQpKTG9hZGVyOjpyZWdpc3RlcignW1tbQ29tcG9uZW50XV1dSGVscGVyJywgSlBBVEhfQURNSU5JU1RSQVRPUiAuICcvY29tcG9uZW50cy9jb21fW1tbY29tcG9uZW50XV1dL2hlbHBlcnMvW1tbY29tcG9uZW50XV1dLnBocCcpOw0KLy8gY2hlY2sgdGhlIHZlcnNpb24gb2YgSkNCDQokbWFuaWZlc3QgPSBbW1tDb21wb25lbnRdXV1IZWxwZXI6Om1hbmlmZXN0KCk7DQppZiAoaXNzZXQoJG1hbmlmZXN0LT52ZXJzaW9uKSAmJiBzdHJwb3MoJG1hbmlmZXN0LT52ZXJzaW9uLCAnLicpICE9PSBmYWxzZSkNCnsNCgkvLyBnZXQgdGhlIHZlcnNpb24NCgkkdGhpcy0+SkNCdmVyc2lvbiA9IGV4cGxvZGUoJy4nLCAkbWFuaWZlc3QtPnZlcnNpb24pOw0KCS8vIEdldCBhIGRiIGNvbm5lY3Rpb24uDQoJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoNCgkvLyB0YXJnZXQgdmVyc2lvbiBsZXNzIHRoZW4gb3IgZXF1YWwgdG8gMS4yLjQNCglpZiAoY291bnQoJHRoaXMtPkpDQnZlcnNpb24pID09IDMgJiYgJHRoaXMtPkpDQnZlcnNpb25bMF0gPT0gMSAmJiAoJHRoaXMtPkpDQnZlcnNpb25bMV0gPCAyIHx8ICgkdGhpcy0+SkNCdmVyc2lvblsxXSA9PSAyICYmICR0aGlzLT5KQ0J2ZXJzaW9uWzJdIDw9IDQpKSkNCgl7DQoJCSRmaXhfY2F0ZWdvcmllcyA9IGFycmF5KA0KCQkJJ2NvbV9qb2J0cmFja2luZy5pdGVtcycgPT4gJ2NvbV9qb2J0cmFja2luZy5pdGVtJw0KCQkpOw0KCQkvLyB0YXJnZXRlZCB0YWJsZXMgKHRvIGZpeCBhbGwgcGxhY2VzIGNhdGVnb3JpZXMgYXJlIG1hcHBlZCBpbnRvIEpvb21sYSkNCgkJJGZpeF90YWJsZXMgPSBhcnJheSgNCgkJCSdjb250ZW50X3R5cGVzJyA9PiBhcnJheSgNCgkJCQknaWQnID0+ICd0eXBlX2lkJywNCgkJCQkna2V5JyA9PiAndHlwZV9hbGlhcycsDQoJCQkJJ3N1ZmZpeCcgPT4gJy5jYXRlZ29yeScpLA0KCQkJJ2NvbnRlbnRpdGVtX3RhZ19tYXAnID0+IGFycmF5KA0KCQkJCSdpZCcgPT4gJ3R5cGVfaWQnLA0KCQkJCSdrZXknID0+ICd0eXBlX2FsaWFzJywNCgkJCQknc3VmZml4JyA9PiAnLmNhdGVnb3J5JyksDQoJCQkndWNtX2NvbnRlbnQnID0+IGFycmF5KA0KCQkJCSdpZCcgPT4gJ2NvcmVfY29udGVudF9pZCcsDQoJCQkJJ2tleScgPT4gJ2NvcmVfdHlwZV9hbGlhcycsDQoJCQkJJ3N1ZmZpeCcgPT4gJy5jYXRlZ29yeScpLA0KCQkJJ2NhdGVnb3JpZXMnID0+IGFycmF5KA0KCQkJCSdpZCcgPT4gJ2lkJywNCgkJCQkna2V5JyA9PiAnZXh0ZW5zaW9uJywNCgkJCQknc3VmZml4JyA9PiAnJykNCgkJKTsNCg0KCQkvLyB0aGUgc2NyaXB0IHRoYXQgZG9lcyB0aGUgd29yaw0KCQlmb3JlYWNoICgkZml4X2NhdGVnb3JpZXMgYXMgJGZpeCA9PiAkY2F0ZWdvcnkpDQoJCXsNCgkJCS8vIGxvb3Agb3ZlciB0aGUgdGFyZ2V0ZWQgdGFibGVzDQoJCQlmb3JlYWNoICgkZml4X3RhYmxlcyBhcyAkX3RhYmxlID0+ICRfdXBkYXRlKQ0KCQkJew0KCQkJCS8vIENyZWF0ZSBhIG5ldyBxdWVyeSBvYmplY3QuDQoJCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCgkJCQkvLyBnZXQgYWxsIHR5cGVfaWRzDQoJCQkJJHF1ZXJ5LT5zZWxlY3QoJGRiLT5xdW90ZU5hbWUoJF91cGRhdGVbJ2lkJ10pKTsNCgkJCQkkcXVlcnktPmZyb20oJGRiLT5xdW90ZU5hbWUoJyNfXycgLiAkX3RhYmxlKSk7DQoJCQkJJHF1ZXJ5LT53aGVyZSggJGRiLT5xdW90ZU5hbWUoJF91cGRhdGVbJ2tleSddKSAuICcgPSAnIC4gJGRiLT5xdW90ZSgkZml4IC4gJF91cGRhdGVbJ3N1ZmZpeCddKSk7DQoJCQkJLy8gUmVzZXQgdGhlIHF1ZXJ5IHVzaW5nIG91ciBuZXdseSBwb3B1bGF0ZWQgcXVlcnkgb2JqZWN0Lg0KCQkJCSRkYi0+c2V0UXVlcnkoJHF1ZXJ5KTsNCgkJCQkkZGItPmV4ZWN1dGUoKTsNCgkJCQlpZiAoJGRiLT5nZXROdW1Sb3dzKCkpDQoJCQkJew0KDQoJCQkJCS8vIGFsbCB0aGVzZSBtdXN0IGJlIHVwZGF0ZWQNCgkJCQkJJGlkcyA9ICRkYi0+bG9hZENvbHVtbigpOw0KCQkJCQkvLyBGaWVsZHMgdG8gdXBkYXRlLg0KCQkJCQkkZmllbGRzID0gYXJyYXkoDQoJCQkJCQkkZGItPnF1b3RlTmFtZSgkX3VwZGF0ZVsna2V5J10pIC4gJyA9ICcgLiAkZGItPnF1b3RlKCRjYXRlZ29yeSAuICRfdXBkYXRlWydzdWZmaXgnXSkNCgkJCQkJKTsNCgkJCQkJLy8gQ29uZGl0aW9ucyBmb3Igd2hpY2ggcmVjb3JkcyBzaG91bGQgYmUgdXBkYXRlZC4NCgkJCQkJJGNvbmRpdGlvbnMgPSBhcnJheSgNCgkJCQkJCSRkYi0+cXVvdGVOYW1lKCRfdXBkYXRlWydpZCddKSAuICcgSU4gKCcgLiBpbXBsb2RlKCcsICcsICRpZHMpIC4gJyknDQoJCQkJCSk7DQoJCQkJCSRxdWVyeS0+dXBkYXRlKCRkYi0+cXVvdGVOYW1lKCcjX18nIC4gJF90YWJsZSkpLT5zZXQoJGZpZWxkcyktPndoZXJlKCRjb25kaXRpb25zKTsNCgkJCQkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkJCQkkcmVzdWx0ID0gJGRiLT5leGVjdXRlKCk7DQoJCQkJCS8vIG9uIHN1Y2Nlc3MNCgkJCQkJaWYgKCRyZXN1bHQpDQoJCQkJCXsNCgkJCQkJCSRhcHAtPmVucXVldWVNZXNzYWdlKCI8cD5VcGRhdGVkIDxiPiNfXyRfdGFibGUgLSAiIC4gJF91cGRhdGVbJ2tleSddIC4gIjwvYj4gZnJvbSA8Yj4kZml4PC9iPiIgLiAkX3VwZGF0ZVsnc3VmZml4J10gLiAiIHRvIDxiPiRjYXRlZ29yeTwvYj4iIC4gJF91cGRhdGVbJ3N1ZmZpeCddIC4gIiE8L3A+IiwgJ05vdGljZScpOw0KCQkJCQl9DQoNCgkJCQl9DQoJCQl9DQoJCX0NCgl9DQp9', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Job Tracking System', '', '', 'Job Tracking System (public)', '.git', '', '', 1, 'https://www.vdm.io/updates/jobtracking_update_server.xml', 'http://www.vdm.io', '', 'CJpVqCNFjGXI6kAZq2SeW2o81dbCpl/nKa1qKI95sxc=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 276, '', 1, 65), -(21, 1, '', '', '', 1, '', '', 1, 1, '', 1, 1, 1, '', '', '', '', '', '', 1, '', 1, '', '', '', '{}', 3, '', 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.9', 'Copyright (C) 2015. All Rights Reserved', '2016-04-12 06:15:10', 1, 'W+rX/bAf3YBY7mg27LxP1c1hUSTt/X3nrC92YrQ6N4w=', 'V2dMVofpOp4cynARFJWeWoTjXJoU80WVQIYa+tr/HbU=', '', '6ICvaCumsJ9IXoiqJ535qHF8Qt/CQwBRb54bQEdV1JA=', '', '', '', 1, '', 'Event registration component.', 'joomla@vdm.io', '', '', 'Mp77p5kOVAltncyTBfVIrsdXLV5sQWDqmsQFJ3O9Dq4=', '', 'e9b1b779-cb04-453c-b606-31c3e12e92c9', 'images/event_registry.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 3, '', '2021-03-08 03:12:03', 1, 'Registry', 'registry', '', 4, 'CQkvLyBydW4gc29tZSBob3VzZSBjbGVhbmluZw0KCQlpZiAoc2VsZjo6bG9hZExvY2F0aW9uRGF0YSgpKQ0KCQl7DQoJCQkvLyBydW4gdGhlIGxvY2F0aW9uIGRhdGEgcXVldWUgKHRvIGluc3VyZSBhbGwgY3JvbiBqb2JzIHJ1biB0aW1lbHkpDQoJCQlpZiAoJGRvY3VtZW50IGluc3RhbmNlb2YgSkRvY3VtZW50SHRtbCkNCgkJCXsNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OnRoZVF1ZXVlKCRkb2N1bWVudCk7DQoJCQl9DQoJCX0NCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw0KCQkvLyBjbGVhciB0aGUgY2FydCBpdGVtcyBpZiBleHBpcmVkDQoJCXNlbGY6OmNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KTs=', 'CS8qKg0KCSogCW1ha2Ugc3VyZSBsb2NhdGlvbiBkYXRhIGlzIGxvYWRlZA0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gbG9hZExvY2F0aW9uRGF0YSgpDQoJew0KCQlpZiAoIWNsYXNzX2V4aXN0cygnTG9jYXRpb25kYXRhSGVscGVyJywgRkFMU0UpKQ0KCQl7DQoJCQkkcGF0aCA9IEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX2xvY2F0aW9uZGF0YS9oZWxwZXJzL2xvY2F0aW9uZGF0YS5waHAnOw0KCQkJaWYgKGZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJCXsNCgkJCQkvLyBtYWtlIHN1cmUgdG8gbG9hZCB0aGUgaGVscGVyDQoJCQkJSkxvYWRlcjo6cmVnaXN0ZXIoJ0xvY2F0aW9uZGF0YUhlbHBlcicsICRwYXRoKTsNCgkJCQkvLyBmaXN0IHNldCB0aGUgZGVmYXVsdCBjb21wb25lbnQNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OiRkZWZhdWx0Q29tcG9uZW50ID0gJ2NvbV9bW1tjb21wb25lbnRdXV0nOw0KCQkJCXJldHVybiB0cnVlOw0KCQkJfQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCXJldHVybiB0cnVlOw0KCX0NCg0KCS8qKg0KCSogCWNhbmNlbCBFeHBpcmVkIENhcnQgSXRlbXMNCgkqKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIGNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KQ0KCXsNCgkJLy8gYWRkIGFuIGV2ZW50IHRoYXQgd2lsbCBzZW5kIG91dCBhbGwgY29uZmlybWF0aW9uIGVtYWlscywgbm90IHlldCBzZW5kDQoJCSRkb2N1bWVudC0+YWRkU2NyaXB0RGVjbGFyYXRpb24oIg0KCQkJalF1ZXJ5KHdpbmRvdykubG9hZChmdW5jdGlvbigpIHsNCgkJCQljYW5jZWxFeHBpcmVkQ2FydEl0ZW1zKDEpLmRvbmUoZnVuY3Rpb24ocmVzdWx0KSB7DQoJCQkJCWlmKHJlc3VsdCl7DQoJCQkJCQljb25zb2xlLmxvZyhyZXN1bHQpOw0KCQkJCQl9DQoJCQkJfSk7DQoJCQl9KTsNCgkJCQ0KCQkJZnVuY3Rpb24gY2FuY2VsRXhwaXJlZENhcnRJdGVtcyh0eXBlKSB7DQoJCQkJdmFyIGdldFVybCA9ICciLlVyaTo6cm9vdCgpLiJhZG1pbmlzdHJhdG9yL2luZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ0YXNrPWFqYXguY2FuY2VsRXhwaXJlZENhcnRJdGVtcyZmb3JtYXQ9anNvbic7DQoJCQkJaWYodHlwZSA+IDApew0KCQkJCQl2YXIgcmVxdWVzdCA9ICd0b2tlbj0iLkpvb21sYV9fXzViYTM4NTEzXzVjNGZfNGIwZF85MzVlXzQ5ZTk4NmE2YmNlOF9fX1Bvd2VyOjpnZXRGb3JtVG9rZW4oKS4iJnR5cGU9Jyt0eXBlOw0KCQkJCX0NCgkJCQlyZXR1cm4galF1ZXJ5LmFqYXgoew0KCQkJCQl0eXBlOiAnUE9TVCcsDQoJCQkJCXVybDogZ2V0VXJsLA0KCQkJCQlkYXRhVHlwZTogJ2pzb25wJywNCgkJCQkJZGF0YTogcmVxdWVzdCwNCgkJCQkJanNvbnA6ICdjYWxsYmFjaycNCgkJCQl9KTsNCgkJCX0iKTsNCgl9', '	public static $event;
	public static $eventBuilder = array();
	public static $conceptHTML = array();
	public static $eventOptions = array();
	public static $locations = array();
	public static $filterInput;
	public static $organizer = null;
	public static $registered = null;

	protected static $disableButtons = array();
	protected static $disableButtonsCheck = array();
	protected static $conceptSwitchOnly = array();
	protected static $bundleSwitchOnly = array();
	protected static $concepts = array();
	protected static $conceptData = array();
	protected static $contentData = array();
	protected static $buttonScript = array(' ');
	protected static $returnType;
	protected static $filepath = '';
	protected static $filelink = '';
	protected static $params;
	protected static $user;
	protected static $locker;
	protected static $basickey;
[CUSTOMCODE=theButler]
[CUSTOMCODE=getItemData]
	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// get user object
		$user = Factory::getUser();
		// first check if any was already set
		if (!$currency = self::get('ACTIVE_CURRENCY', null))
		{
			if ($user->id > 0)
			{
				// set the active users currency
				self::set('ACTIVE_CURRENCY', self::getUserCurrency($user));
			}
			else
			{
				// set public currency
				self::set('ACTIVE_CURRENCY', self::getPublicCurrency());
			}
		}
		// set public key if needed
		if ( $user->id == 0)
		{
			if (!$public = self::get('publicKeeY', null))
			{
				// set the active users public
				self::set('publicKeeY', self::randomkey(7));
			}
		}
	}
[CUSTOMCODE=userIsThree+adminuser,organizeruser,registereduser,organizer,registered_user]
	/**
	* 	the public currency
	**/
	protected static $usersCurrency = array();

	/**
	* 	get the user currency
	**/
	public static function getUserCurrency($userId = null)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($userId) && $userId instanceof JUser)
		{
			$user = $userId;
		}
		elseif (is_numeric($userId) && $userId > 0)
		{
			$user = Factory::getUser($userId);
		}
		else
		{
			$user = Factory::getUser();
		}
		// only set again if not found
		if (!isset(self::$usersCurrency[$user->id]))
		{
			$array = (array) self::userIs($user, true);
			// set in relation
			switch($array['is'])
			{
				// admin use global
				case 3: 
				self::$usersCurrency[$user->id] = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('currency', 'USD');
				break;
				// organizer currency
				case 2:
				self::$usersCurrency[$user->id] = self::getVar('organizer', $array['id'], 'id',  'currency');
				break;
				// registered user currency
				case 1:
				self::$usersCurrency[$user->id] = self::getRegUserValue($array['id'], 'currency_codethree', self::getPublicCurrency());
				break;
				// all other gets the public
				default:
				return self::getPublicCurrency();
				break;
			}
		}
		return self::$usersCurrency[$user->id];
	}

	/**
	* 	the event currency
	**/
	protected static $eventCurrency = array();

	/**
	* 	get the user currency
	**/
	public static function getEventCurrency($id = null)
	{
		if (is_numeric($id) && $id > 0)
		{
			$event = (int) $id;
		}
		elseif (isset(self::$event->id) && self::$event->id > 0)
		{
			$event = (int) self::$event->id;
		}
		elseif (!$id && isset(self::$event->organizer) && self::$event->organizer > 0)
		{
			if ($currency = self::getVar('organizer', self::$event->organizer, 'id', 'currency'))
			{
				return $currency;
			}
		}
		else
		{
			// return default currency of the current user
			return self::getUserCurrency();
		}
		// check if already set
		if (!isset(self::$eventCurrency[$event]))
		{
			// get event organizer
			if (!$id && isset(self::$event->organizer) && self::$event->organizer > 0)
			{
				if ($currency = self::getVar('organizer', self::$event->organizer, 'id', 'currency'))
				{
					self::$eventCurrency[$event] = $currency;
				}
			}
			elseif ($orgId = self::getVar('event', $event, 'id', 'organizer'))
			{
				if ($currency = self::getVar('organizer', $orgId, 'id', 'currency'))
				{
					self::$eventCurrency[$event] = $currency;
				}
			}
		}
		// return if found
		if (isset(self::$eventCurrency[$event]))
		{
			return self::$eventCurrency[$event];
		}
		return false;
	}


	/**
	* 	the public currency
	**/
	protected static $publicCurrency = 'set';

	/**
	* 	set the public/default currency
	**/
	public static function getPublicCurrency()
	{
		if ('set' === self::$publicCurrency)
		{
			// get this location data
			$locationData = self::getLocationdata();
			// check if we have location data
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($locationData) && isset($locationData['CURRENCY_CODE_THREE']))
			{
				self::$publicCurrency = $locationData['CURRENCY_CODE_THREE'];
			}
			else
			{
				self::$publicCurrency = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('currency', 'USD');
			}
		}
		return self::$publicCurrency;
	}

	/**
	* 	The owner
	**/
	protected static $owner = array();

	/**
	* 	array to check user
	**/
	protected static $checkUser = array();

	/**
	* 	wants to edit
	**/
	protected static $viewAccess;

	public static function hasAccess($recordId, $userId = null, $to = 'event', $viewAccess = false)
	{
		// set if view access is all that is required 
		self::$viewAccess = $viewAccess;
		if(!$userId)
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$user))
			{
				// set current user
				self::$user = Factory::getUser();
			}
			$userId = self::$user->id;
		}
		$array = (array) self::userIs($userId, true);
		if (isset($array['is']) && $array['is'] && $recordId > 0)
		{
			switch($to)
			{
				case 'event':
					return self::accessEvent($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'venue':
					return self::accessVenue($array['is'], $recordId, $userId);
				break;
				case 'organizer':
					return self::accessOrganizer($array['is'], $recordId, $userId);
				break;
				case 'invoice':
					return self::accessInvoice($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'payment_method':
					return self::accessPaymentMethod($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'tax_rule':
					return self::accessTaxRule($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'messages_builder':
					return self::accessMessagesBuilder($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'concept':
					return self::accessConcept($array['is'], $recordId, $userId);
				break;
				case 'content':
					return self::accessContent($array['is'], $recordId, $userId);
				break;
				case 'bundle':
					return self::accessBundle($array['is'], $recordId, $userId);
				break;
			}
		}
		return false;
	}

	protected static function accessEvent($type, $recordId, $orgId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['event'.$recordId] = self::getVar('event', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['event'.$recordId] == $orgId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('event.edit', 'com_[[[component]]].event.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessVenue($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['venue'.$recordId]))
				{
					// load the owner
					self::$owner['venue'.$recordId] = self::getVar('venue', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['venue'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('venue.edit', 'com_[[[component]]].venue.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessOrganizer($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['organizer'.$recordId]))
				{
					// load the owner
					self::$owner['organizer'.$recordId] = self::getVar('organizer', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['organizer'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('organizer.edit', 'com_[[[component]]].organizer.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessInvoice($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the event owner
				if (!isset(self::$owner['invoice'.$recordId]))
				{
					// load the owner
					self::$owner['invoice'.$recordId] = self::getVar('invoice', $recordId, 'id', 'organizer');
				}
			break;
			default: // set the default to
				return false;
			break;
		}
		// only true if owner is the same as user
		if (self::$owner['invoice'.$recordId] == $localId)
		{
			if (self::$viewAccess)
			{
				return true;
			}
			// get the global settings
			if (!isset(self::$checkUser[$userId]))
			{
				// set current user
				self::$checkUser[$userId] = Factory::getUser($userId);
			}
			return self::$checkUser[$userId]->authorise('invoice.edit', 'com_[[[component]]].invoice.' . (int)  $recordId);
		}
		return false;
	}

	protected static function accessPaymentMethod($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['payment_method'.$recordId]))
				{
					// load the owner
					self::$owner['payment_method'.$recordId] = self::getVar('payment_method', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['payment_method'.$recordId] == $localId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('payment_method.edit', 'com_[[[component]]].payment_method.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessTaxRule($type, $recordId, $localID, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['event'.$recordId] = self::getVar('tax_rule', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['event'.$recordId] == $localID)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('payment_method.edit', 'com_[[[component]]].payment_method.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessMessagesBuilder($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['messages_builder'.$recordId] = self::getVar('messages_builder', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['messages_builder'.$recordId] == $localId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('messages_builder.edit', 'com_[[[component]]].messages_builder.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessConcept($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['concept'.$recordId] = self::getVar('concept', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['concept'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('concept.edit', 'com_[[[component]]].concept.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessContent($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['concept'.$recordId] = self::getVar('concept', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['concept'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('concept.edit', 'com_[[[component]]].concept.' . (int)  $recordId);
				}
			break;
		}
		return false;
		return self::$user->authorise('content.edit', 'com_[[[component]]].content.' . (int)  $recordId);
	}

	protected static function accessBundle($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['bundle'.$recordId]))
				{
					// load the owner
					self::$owner['bundle'.$recordId] = self::getVar('bundle', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['bundle'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('bundle.edit', 'com_[[[component]]].bundle.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	public static function hisItems($table, $userId = null)
	{
		if($userId > 0)
		{
			$array = (array) self::userIs($userId, true);
		}
		else
		{
			$array = (array) self::userIs(Factory::getUser()->id, true);
		}
		// return in relation
		switch($array['is'])
		{
			// registered (only load items that belong to the registered user)
			case 1:
			return self::getVars($table, $array['id'], 'registered_user');
			break;
			// organizer (only load items that belong to the organizer)
			case 2:
			return self::getVars($table, $array['id'], 'organizer');
			break;
			// admin can access all
			case 3: 
			return -1;
			break;
		}
		return false;
	}

	protected static $LocationdataHelper = false; 

	/**
	* 	Load the data for IP and Currency 
	**/
	public static function getLocationdata($ip = null, $protocol = null, $key = null, $base = 'USD', $mode = 0, $string = 0, $value = 1.00)
	{		
		if (self::loadLocationData())
		{
			return LocationdataHelper::getLocationdata($ip, $protocol, $key, $base, $mode, $string, $value);
		}
		return false;
	}

	/**
	 * returns ExchangeRates
	 *
	 * @return string
	 */
	public static function getExchangeRate($from, $fromValue, $to = 'USD')
	{
		if (self::loadLocationData())
		{
			return LocationdataHelper::getExchangeRate($from, $fromValue, $to);
		}
		return false;
	}

	/**
	 * @param $data
	 * @param $type
	 * @return bool|string
	 */
	public static function getEvent($event, $type)
	{
		// if only id given get the object
		if (is_numeric($event) && $event > 0 )
		{
			$event = self::getAllValues($event, 'event', array('event_documents','banner_image','poster_image','teaser_image','event_images'));
		}
		// check if we have the event object, make sure we have the needed data
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($event))
		{
			// make sure we have the needed dates
			if (isset($event->date) && 'nee' != $event->date && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->date))
			{
				$event->date = json_decode($event->date, true);
			}
			// make sure we have the needed cost
			if (isset($event->cost) && 'nee' != $event->cost && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->cost))
			{
				$event->cost = json_decode($event->cost, true);
			}
			// make sure important data was set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event->cost) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event->date))
			{
				// set adjustments
				if (isset($event->adjustment) && 'nee' != $event->adjustment && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->adjustment))
				{
					$event->adjustment = json_decode($event->adjustment, true);
				}
				// set limit per group
				if (isset($event->limitpergroup) && 'nee' != $event->limitpergroup && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->limitpergroup))
				{
					$event->limitpergroup = json_decode($event->limitpergroup, true);
				}
				// final check
				if (	isset($event->type) && is_numeric($event->type) &&
					isset($event->id) && is_numeric($event->id))
				{
					self::$event = $event;
					// date or just cost
					return self::eventBuilder($type);
				}
			}
		}
		return false;
	}

	/**
	 * @param $returnType
	 * @return bool|string
	 */
	public static function eventBuilder($returnType)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
		}
		// set the return type
		self::$returnType = $returnType;
		// setup a filterInput
		self::$filterInput = new JFilterInput();
		// set the file path
		self::$filepath = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath();
		// now add the url path to show the image
		self::$filelink = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath('url');
		// Get the basic encryption.
		self::$basickey = self::getCryptKey('basic');
		// Get the encryption object.
		self::$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power(self::$basickey, 128);
		// reset global
		$timeSet = false;
		// load concept per date
		if (self::setDates())
		{
			$timeSet = true;
		}
		// load concept per cost
		elseif (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']))
		{
			self::$concepts = array_unique(array_filter(self::$event->cost['concept']));
		}
		// check bundler
		self::setBundler();
		if (isset(self::$concepts) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$concepts))
		{
			// build concepts
			foreach (self::$concepts as $event_concept_time => $concept)
			{
				if (!$timeSet)
				{
					$event_concept_time = self::$event->id.'_'.$concept.'__0';
				}
				// build concept div
				self::$conceptHTML[$event_concept_time] = self::buildConcept($concept,$event_concept_time);
			}

			// load orphan price variations
			if (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']))
			{
				self::loadOrphanVariations();
			}

			if (self::$returnType == 'admin' || self::$returnType == 'site')
			{
				// build the Display Content
				$content = array();
				$content[] = '<div id="preview" class="wire-border"><div class="uk-grid"><div class="uk-panel uk-width-1-1">';

				// set the Event Start and End Date
				if (isset(self::$eventBuilder['start-end']))
				{
					$content[] = '<div class="event-start-end">'.self::$eventBuilder['start-end'].'</div>';
				}
				// set event name
				if (self::$event->id > 0)
				{
					$edit = (self::$returnType == 'site') ? self::loadEditButton('event',self::$event->id) : '';
					$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' class="uk-visible-hover-inline"' : '';
					self::$event->name = self::loadName('event',self::$event->id);
					$content[] = '<h2'.$editClass.'>'. self::$event->name . $edit .'</h2>';
				}
				else
				{
					self::$event->name = Text::_('The Event Name');
					$content[] = '<h2><span id="eventName">'. self::$event->name .'</span></h2>';
				}
				// now load the banner
				if ($banner = self::getEventImage('banner_image', 1, self::$event->name, 'uk-thumbnail uk-margin'))
				{
					$content[] = $banner;
				}
				// set event details
				if (isset(self::$event->details) &&  Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->details))
				{
					$content[] = '<p>'.self::$filterInput->clean(self::$event->details).'</p>';
				}
				else
				{
					$content[] = '<p>'.Text::_('The event details come here').', lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor.</p>';
				}
				// load the concepts
				$content[] = self::loadConceptLayout();

				if (self::$returnType == 'admin')
				{
					// add dummy buy button
					$content[] = '<div class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel">';
					$content[] = '<button class="uk-button uk-button-large uk-width-1-1 uk-button-success" type="button" onclick="alert(\'Cart not active in admin area\');"> ';
					$content[] = Text::_('Total');
					$content[] = ': <span id="total">0.00</span> - ';
					$content[] = Text::_('Buy Now');
					$content[] = '</button>';
					$content[] = '</div></div></div>';
				}
				elseif (self::$returnType == 'site')
				{
					// the real shopping cart button
					$content[] = '<div class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel">';
					$content[] = '<div class="cart-active-buttons uk-button-group uk-width-1-1" style="display: none;">';
					$content[] = '<a class="uk-button uk-button-large uk-width-1-4 uk-button-primary" href="#VDM-view-cart-now" data-uk-modal><i class="uk-icon-eye"></i> <span class="uk-hidden-small">';
					$content[] = Text::_('View Cart');
					$content[] = '</span></a>';
					$content[] = '<a class="uk-button uk-button-large uk-width-3-4 uk-button-success" href="'. Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_([[[Component]]]HelperRoute::getCheckoutRoute()) .'"><span class="VDM-cart-total"></span> <span class="uk-hidden-small">';
					$content[] = Text::_('Check Out');
					$content[] = '</span> <i class="uk-icon-shopping-cart"></i></a></div>';
					$content[] = '<div class="cart-inactive-button">';
					$content[] = '<a class="uk-button uk-button-large uk-width-1-1 uk-button-primary" href="#VDM-view-cart-now" data-uk-modal><i class="uk-icon-eye"></i> <span class="uk-hidden-small">';
					$content[] = Text::_('View Empty Cart');
					$content[] = '</span></a></div>';
					$content[] = '</div></div></div>';
				}

				$content[] = '</div></div></div>';


				if (self::$returnType == 'admin')
				{
					// add some script;
					$script = array();
					$script[] = '<script type="text/javascript">';
					$script[] = 'var total = {};';
					$script[] = 'var available = {};';
					$script[] = 'var taken = {}; var tickets = {};';
					$script[] = 'var capacity = '.self::$event->capacity.';';
					$script[] = 'jQuery("#eventName").text(jQuery("#jform_name").val());';
					$script[] = 'jQuery(document).ready(function($) {';
					$script[] = 'jQuery(".select-button").click(function() {';
					$script[] = 'var button = this.id.split("-");';
					$script[] = 'var currentValue = jQuery("#"+button[0]+"-number").data("qty");';
					$script[] = 'if (button[1] == "plus") {';
					$script[] = 'var newValue = 1 + +currentValue;';
					$script[] = 'if (tickets.hasOwnProperty(button[0])) {';
					$script[] = 'taken[button[0]] = newValue;';
					$script[] = 'var totalTaken = sum(taken);';
					$script[] = 'if (capacity != 0 && totalTaken > capacity) {';
					$script[] = 'newValue = newValue - 1;';
					$script[] = 'taken[button[0]] = newValue;';
					$script[] = 'UIkit.notify("The Event Is Full.", {status:\'warning\'});';
					$script[] = '}}';
					$script[] = 'if (available.hasOwnProperty(button[0]) && available[button[0]] != 0 && newValue == available[button[0]]) {';
					$script[] = 'UIkit.notify("This Option is Full.", {status:\'warning\'}); jQuery("#"+button[0]+"-plus").attr("disabled", "disabled");';
					$script[] = '}';
					$script[] = '} else if (button[1] == "minus" && currentValue != 0) {';
					$script[] = 'var newValue = +currentValue - 1;';
					$script[] = 'taken[button[0]] = newValue; jQuery("#"+button[0]+"-plus").removeAttr("disabled");';
					$script[] = '} else if (button[1] == "select") {';
					$script[] = 'var pressed = jQuery(this).data("uk-button");';
					$script[] = 'if (pressed == 1) {';
					$script[] = 'var newValue = 1; jQuery(this).data("uk-button", 2);';
					$script[] = '} else {';
					$script[] = 'var newValue = 0; jQuery(this).data("uk-button", 1);';
					$script[] = '}';
					$script[] = '} else {';
					$script[] = 'var newValue = 0;';
					$script[] = '}';
					$script[] = 'if(jQuery(this).data("only")) { onlySwitch(this,newValue); }';
					$script[] = 'totalSetter(this,newValue);';
					$script[] = 'if (button[1] == "minus" || button[1] == "plus") {';
					$script[] = 'jQuery("#"+button[0]+"-number").data("qty", newValue);';
					$script[] = 'if (newValue == 0) {';
					$script[] = 'newValueHTML = 0;';
					$script[] = '} else {';
					$script[] = 'newValueHTML = \'<span class="uk-badge uk-badge-notification uk-badge-success">\'+newValue+\'</span>\';';
					$script[] = '}';
					$script[] = 'jQuery("#"+button[0]+"-number").html(newValueHTML);';
					$script[] = '}';
					$script[] = '});});';
					$script[] = implode('',self::$buttonScript);
					$script[] = '</script>';
					// load the display
					return implode('',$content).implode('',$script);
				}
				elseif (self::$returnType == 'site')
				{
					// add some script;
					$script = array();
					$script[] = '<script type="text/javascript">';
					$script[] = 'var available = {};';
					$script[] = 'var taken = {}; var tickets = {};';
					$script[] = 'var capacity = '.self::$event->capacity.';';
					$script[] = implode('',self::$buttonScript);
					$script[] = '</script>';

					// load the display
					$content = implode('',$content).implode('',$script);

					// get the documents for downloads
					if ($downloads = self::getEventDownloads())
					{
						$content = str_replace(array_keys($downloads), array_values($downloads), $content);
						// remove links
						foreach ($downloads as $key => $link)
						{
							if (strpos($key, '[DOCLINK=') !== false)
							{
								unset($downloads[$key]);
							}
						}
					}

					// set event poster
					$poster = self::getEventImage('poster_image');
					// set event images
					$eventImages = self::getEventImage('event_images', 2);
					$eventImageWidth = self::$params->get('event_width', 800);
					$eventImageHeight =  self::$params->get('event_height', 600);
					
					// now set the selection only switches  (($bundle != 0 && $bundle == $otherBundle) || ($bundle == $otherBundle && $concept == $otherConcept)) <--- the JavaScript logic
					foreach (self::$disableButtonsCheck as $buttonId => $at)
					{
						if (isset(self::$conceptSwitchOnly[$at['concept']]))
						{
							foreach (self::$conceptSwitchOnly[$at['concept']] as $nr => $bucket)
							{
								if (((int) $at['bundle'] > 0 && (int) $at['bundle'] == (int) $bucket['bundle']))
								{
									self::$disableButtons['###'.$buttonId.'###'] = 'disabled';
								}
							}
						}
						if (isset(self::$bundleSwitchOnly[$at['bundle']]))
						{
							foreach (self::$bundleSwitchOnly[$at['bundle']] as $nr => $bucket)
							{
								if ((int) $at['bundle'] > 0 || (int) $at['concept'] == (int) $bucket['concept'])
								{
									self::$disableButtons['###'.$buttonId.'###'] = 'disabled';
								}
							}
						}
					}
					// update the disabled buttons
					$content = str_replace(array_keys(self::$disableButtons), array_values(self::$disableButtons), $content);

					// now lets add the poster event images and the download buttons if found
					$tabs = false;
					if ($poster || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
					{
						if ($poster && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
						{
							if (count($downloads) == 1)
							{
								$tabName2 = Text::_('Poster & Download');
							}
							else
							{
								$tabName2 = Text::_('Poster & Downloads');
							}
						}
						elseif ($poster)
						{
							$tabName = Text::_('Poster');
						}
						elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
						{
							if (count($downloads) == 1)
							{
								$tabName2 = Text::_('Download');
							}
							else
							{
								$tabName2 = Text::_('Downloads');
							}
						}
						$tabs = true;
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($eventImages))
					{
						if (count($eventImages) == 1)
						{
							$tabName3 = Text::_('Event Image');
						}
						else
						{
							$tabName3 = Text::_('Event Images');
						}
						$tabs = true;
					}
					// build tabs
					if ($tabs)
					{
						$tabControlID = md5(self::$event->name.self::$event->id);
						$body = array();
						$body[] = '<ul class="uk-subnav uk-subnav-pill" data-uk-switcher="{connect:\'#'.$tabControlID.'\'}">';
						$body[] = '<li><a href="">'. Text::_('Register') .'</a></li>';
						if (isset($tabName2))
						{
							$body[] = '<li><a href="">'. $tabName2 .'</a></li>';
						}
						if (isset($tabName3))
						{
							$body[] = '<li><a href="">'. $tabName3 .'</a></li>';
						}
						$body[] = '</ul>';

						$body[] = '<ul id="'.$tabControlID.'" class="uk-switcher">';
						$body[] = '<li>' . $content . '</li>';
						if (isset($tabName2))
						{
							$body[] = '<li>';
							if ($poster && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
							{
								$body[] = '<div class="uk-grid">';
								$body[] = '<div class="uk-width-medium-4-5">';
								$body[] = '<div class="uk-panel">' . $poster . '</div>';
								$body[] = '</div>';
								$body[] = '<div class="uk-width-medium-1-5">';
								$body[] = '<div class="uk-panel">' . implode('', $downloads) . '</div>';
								$body[] = '</div>';
								$body[] = '</div>';
							}
							elseif ($poster)
							{
								$body[] = $poster;
							}
							elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
							{
								$body[] = implode('', $downloads);
							}
							$body[] = '</li>';
						}
						if (isset($tabName3))
						{
							$body[] = '<li>';
							$body[] = '<div class="uk-grid uk-grid-width-medium-1-4" data-uk-grid-margin>';
							foreach ($eventImages as $val)
							{
								$body[] = '<div>';
								$body[] = '<a href="' . $val['url'] . '" data-uk-lightbox="{group:\'group-' . $tabControlID . '\'}" title="' . $val['name'] . '">';
								$body[] = '<img src="' . $val['url'] . '" alt="" width="' . $eventImageWidth . '" height="' . $eventImageHeight . '">';
								$body[] = '</a>';
								$body[] = '</div>';
							}
							$body[] = '</div>';
							$body[] = '</li>';
						}
						$body[] = '</ul>';
						// return body
						return implode('',$body);
					}
					return $content;
				}
			}
			elseif (self::$returnType == 'options' && $options = self::getEventOptions())
			{
				return $options;
			}
		}
		return false;
	}

	/**
	 * @return string image link
	 */
	protected static function getEventImage($target, $type = 1, $name = null, $class = 'uk-margin')
	{
		// get image if not available
		if ((!isset(self::$event->$target) || !Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->$target)) && self::$event->id > 0)
		{
			self::$event->$target = self::decryptString(self::getVar('event', self::$event->id, 'id', $target));
		}
		// check that image is json
		if ($type == 2 && self::$event->$target && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$event->$target))
		{
			$setFileName = false;
			if (!$name)
			{
				$setFileName = true;
			}
			// build an array of images
			$tmp = json_decode(self::$event->$target, true);
			if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmp))
			{
				return false;
			}
			$bucket = array();
			foreach ($tmp as $fileName)
			{
				// build the array
				if (strpos($fileName, '_') !== false)
				{
					$extention = explode('_', $fileName);
					$actualName = self::$event->name;
					if ($setFileName && strpos($fileName, 'VDM') !== false)
					{
						$fileNameArray = explode('VDM', $fileName);
						if (isset($fileNameArray[1]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($fileNameArray[1]))
						{
							$actualName = $fileNameArray[1];
						}
					}
					if (isset($extention[2]))
					{
						if ($setFileName)
						{
							$name = $actualName;
						}
						// set basic bucket details
						$tmpBucket = array();
						$tmpBucket['link'] = '<img class="'.$class.'" src="'.self::$filelink.$fileName.'.'.$extention[2].'" alt="'. $name .'">';
						$tmpBucket['url'] = self::$filelink.$fileName.'.'.$extention[2];
						$tmpBucket['name'] =  $name;
						// add to bucket
						$bucket[] = $tmpBucket;
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
			{
				return $bucket;
			}
		}
		// check that image is only a string
		elseif ($type == 1 && isset(self::$event->$target) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->$target))
		{
			// return one image link
			if (strpos(self::$event->$target, '_') !== false)
			{
				$extention = explode('_', self::$event->$target);
				$actualName = self::$event->name;
				if (strpos(self::$event->$target, 'VDM') !== false)
				{
					$fileNameArray = explode('VDM', self::$event->$target);
					if (isset($fileNameArray[1]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($fileNameArray[1]))
					{
						$actualName = $fileNameArray[1];
					}
				}
				if (isset($extention[2]))
				{
					if (!$name)
					{
						$name = $actualName;
					}
					return '<img class="'.$class.'" src="'.self::$filelink.self::$event->$target.'.'.$extention[2].'" alt="'. $name .'">';
				}
			}
		}
		return false;
	}

	/**
	 * @return array of links
	 */
	protected static function getEventDownloads()
	{
		if (isset(self::$event->event_documents))
		{
			// first make sure it is Json values
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$event->event_documents))
			{
				self::$event->event_documents = json_decode(self::$event->event_documents, true);
			}
			// now check if it is an array
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->event_documents))
			{
				$sessionToken = Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
				$domain = Uri::root();
				$downloads = array();
				foreach (self::$event->event_documents as $fileName)
				{
					// make sure this a correct file name
					if (strpos($fileName, '_') !== false && strpos($fileName, 'VDM') !== false)
					{
						$fileArray = explode('_', $fileName);
						$nameArray = explode('VDM', $fileName);
						// more checks
						if (isset($nameArray[1]) && isset($fileArray[2]))
						{
							if (self::$basickey)
							{
								// Get the encryption object.
								$localFile = self::base64_urlencode(self::$locker->encryptString($fileName));
							}
							else
							{
								// can not get the encryption object so only base64 encode
								$localFile = self::base64_urlencode($fileName, true);
							}
							// build link 
							$link = $domain . 'index.php?option=com_[[[component]]]&task=download.document&file=' . $localFile . '&token=' . $sessionToken;
							// build the file name
							$fileName = $nameArray[1] . '.' . $fileArray[2];
							$downloads['[DOCLINK='.$fileName.']'] = '<a href="' . $link . '" tytle=" ' . Text::_('Download') . '">' . $fileName . '</a>';
							$downloads['[DOCBUTTON='.$fileName.']'] = '<a href="' . $link . '" class="uk-button uk-button-success uk-margin-small-bottom uk-width-1-1"><i class="uk-icon-download"></i> ' . Text::_('Download') . ' ' . $fileName . '</a>';
						} 
					}
				}
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
				{
					return $downloads;
				}
			}
		}
		return false;
	}

	/**
	 * @param $table
	 * @param $value
	 * @return bool|mixed
	 */
	protected static function loadEditButton($table, $id)
	{		
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$user))
		{
			// set current user
			self::$user = Factory::getUser();
		}
		// only load to admin and organizer who own this item
		if (self::hasAccess($id, self::$user->id, $table))
		{
			if (self::$returnType == 'admin')
			{
				$ref = (isset(self::$event->id) && self::$event->id > 0) ? "&ref=event&refid=".self::$event->id : '';
				$edit = "index.php?option=com_[[[component]]]&view=".$table."&task=".$table.".edit&id=".$id.$ref;
				return ' <a onclick="UIkit.modal.confirm(\''.Text::_('All unsaved work will be lost, are you sure you want to continue?').'\', function(){ window.location.href = \''.$edit.'\' })"  href="javascript:void(0)" class="uk-icon-pencil uk-hidden"></a>';
			}
			elseif (self::$returnType == 'site')
			{
				$ref = (isset(self::$event->id) && self::$event->id > 0) ? "&ref=registry&refid=".self::$event->id : '';
				$edit = "index.php?option=com_[[[component]]]&view=".$table."&task=".$table.".edit&id=".$id.$ref;
				return ' <a href="'.$edit.'" class="uk-icon-pencil uk-hidden"></a>';
			}
		}
		return '';
	}

	/**
	 * @param $table
	 * @param $value
	 * @return bool|mixed
	 */
	protected static function loadName($table,$value)
	{
		if ('event' === $table && isset(self::$event->name))
		{
			return self::$event->name;
		}
		return self::getVar($table,(int) $value,'id','name');
	}

	protected static function loadOrphanVariations()
	{
		$content = array();
		// isolate the orphan variations
		if (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']))
		{
			$anotherConcept = array();
			$variations = array();
			foreach (self::$event->cost['concept'] as $key => $concept)
			{
				if (!in_array($concept,self::$concepts))
				{
					if (is_numeric($concept))
					{
						// another concept
						$anotherConcept[$concept] = $concept;
					}
					else
					{
						// total orphan
						$variations[self::$event->cost['variation'][$key]] = $key;
					}
				}
			}
			// first load the other consepts (that have no date - target whole event)
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($anotherConcept))
			{
				foreach ($anotherConcept as $concept)
				{
					// another concept
					self::$conceptHTML[self::$event->id.'_'.$concept.'__0'] = self::buildConcept($concept,self::$event->id.'_'.$concept.'__0');
				}
			}
			// now load the orphan variations (that have no date or concept - target whole event)
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($variations))
			{
				$price = array();
				foreach ($variations as $variation => $key)
				{
					// another variation button
					if (count($price) > 2 && (self::$returnType == 'admin' || self::$returnType == 'site'))
					{
						$price[] = '<br />';
					}
					if ($button = self::setBuyButtons($key))
					{
						$price[] = $button;
					}
				}
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					$content = array();
					$content[] = '<div class="uk-grid"><div class="uk-width-medium-3-5"></div><div class="uk-width-medium-2-5">';
					$content[] = implode('',$price);
					$content[] = '</div></div>';

					// return the orphan stuff to a belong (TODO - this is not ideal)
					self::$conceptHTML[self::$event->id.'_999999999__0'] = implode('',$content);
				}
				elseif (self::$returnType == 'options')
				{
					self::$eventOptions[self::$event->id.'_999999999__0'] = $price;
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions[self::$event->id.'_999999999__0']))
					{
						foreach (self::$eventOptions[self::$event->id.'_999999999__0'] as $nr => &$costing)
						{
							$costing['name'] = self::loadName('event',self::$event->id) . ' (' .$costing['name'] .')';
						}
					}
				}
			}
		}
	}

	/**
	 * @param $concepts
	 * @return string
	 */
	protected static function loadConceptLayout()
	{
		$content = array();
		$concepts = self::getConceptsHTML();
		// check layout option
		if (!isset(self::$eventBuilder['bundler']) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['bundler']))
		{
			// load default layout
			$content[] = '<div data-uk-grid-margin="" class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel uk-margin-small uk-panel-hover">';
			$content[] = implode('</div></div><div class="uk-width-1-1"><div class="uk-panel uk-margin-small uk-panel-hover">',$concepts);
			$content[] = '</div></div></div>';
		}
		elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['bundler']))
		{
			// load in bundles layout
			foreach (self::$eventBuilder['bundler'] as $bundle => $array)
			{
				$content[] = '<div data-uk-grid-margin="" class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel uk-margin-small uk-panel-hover">';
				$edit = self::loadEditButton('bundle', $bundle);
				$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' uk-visible-hover-inline' : '';
				$content[] = '<h3 class="uk-panel-title'.$editClass.'">'. self::loadName('bundle',$bundle) . $edit .'</h3>';
				$details = self::getVar('bundle',(int) $bundle,'id','description');
				// load bundle details
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($details))
				{
					$content[] = '<div>'.$details.'</div>';
				}
				$content[] = '<div class="wire-border"><div class="uk-grid">';
				$bucket = array();
				foreach ($array as $event_concept_time)
				{
					if (isset($concepts[$event_concept_time]))
					{
						$bucket[] = $concepts[$event_concept_time];
						unset($concepts[$event_concept_time]);
					}
				}
				$content[] = '<div class="uk-width-1-1">'.implode('</div><div class="uk-width-1-1"><hr>',$bucket).'</div>';
				$content[] = '</div></div></div></div></div>';
			}
			// check if there is more concepts left
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($concepts))
			{
				$content[] = '<div data-uk-grid-margin="" class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel uk-panel-space">';
				$content[] = implode('</div></div><div class="uk-width-1-1"><div class="uk-panel uk-panel-space">',$concepts);
				$content[] = '</div></div></div>';
			}
		}
		return implode('',$content);
	}

	protected static function setBundler()
	{
		if (isset(self::$event->date['bundle']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->date['bundle']))
		{
			$bundler = array();
			foreach (self::$event->date['bundle'] as $key => $bundle)
			{
				$concept = self::$event->date['concept'][$key];
				if (is_numeric($bundle))
				{
					if ($key_time = self::getEventConceptTime($key))
					{
						if (!isset(self::$eventBuilder['timestamps'][$key_time]['start']))
						{
							self::$eventBuilder['timestamps'][$key_time]['start'] = 0;
						}
					}
					else
					{
						$key_time = 0;
						self::$eventBuilder['timestamps'][0]['start'] = 0;
					}

					$bundler[] = array('bundle' => (int) $bundle, 'concept' => (int) $concept, 'start' => (int) self::$eventBuilder['timestamps'][$key_time]['start']);
				}
			}
			// check if any bundles has been loaded
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bundler))
			{
				// sort the bundles
				usort($bundler, function($a, $b) {
					return $a['start'] - $b['start'];
				});
				// pack the bundles
				foreach ($bundler as $array)
				{
					self::$eventBuilder['bundler'][$array['bundle']][self::$event->id.'_'.$array['concept'].'__'.$array['start']] = self::$event->id.'_'.$array['concept'].'__'.$array['start'];
					self::$eventBuilder['bundle'][self::$event->id.'_'.$array['concept'].'__'.$array['start']] = $array['bundle'];
				}
			}
		}
	}

	/**
	 * @param $concept
	 * @param $event_concept_time
	 * @return bool|string
	 */
	protected static function buildConcept(&$concept, $event_concept_time)
	{
		$content = array();
		if (self::$returnType == 'admin' || self::$returnType == 'site')
		{
			if (isset(self::$eventBuilder['dates'][$event_concept_time]['start-end']))
			{
				$content[] = '<div class="concept-start-end">'.self::$eventBuilder['dates'][$event_concept_time]['start-end'].'</div>';
			}
			// check if this concept is already loaded
			if (!isset(self::$conceptData[$concept]))
			{
				self::$conceptData[$concept] = self::getAllValues($concept, 'concept', array('concept_image'));
			}
			// only continue if we have values
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$conceptData[$concept]))
			{
				return false;
			}
			$edit = self::loadEditButton('concept',$concept);
			$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' uk-visible-hover-inline' : '';
			$content[] = '<h3 class="uk-panel-title'.$editClass.'">'.self::$conceptData[$concept]->name . $edit .'</h3>';
			// add concept image
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$conceptData[$concept]->concept_image) && strpos(self::$conceptData[$concept]->concept_image, '_') !== false)
			{
				$extention = explode('_',self::$conceptData[$concept]->concept_image);
				if (isset($extention[2]))
				{
					$content[] = '<img class="uk-thumbnail" src="'.self::$filelink.self::$conceptData[$concept]->concept_image.'.'.$extention[2].'" alt="concept image">';
				}
			}
			$content[] = '<div class="uk-grid">';

			// workout widths
			$conceptDetails = false;
			$conceptContent = false;
			$conceptCosting = false;
			$setSpacer = false;
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$conceptData[$concept]->details))
			{
				$conceptDetails = true;
			}
			if (self::setConceptContent($event_concept_time))
			{
				$conceptContent = true;
			}
			if (self::setConceptCosting($concept,$event_concept_time))
			{
				$conceptCosting = true;
			}
			if ($conceptDetails && $conceptContent && $conceptCosting)
			{
				// three is true
				$widthsDetails = 1;
				$widthsContent = 2;
			}
			elseif ($conceptDetails xor $conceptContent xor $conceptCosting)
			{
				// one is true
				$widthsDetails = 5;
				$widthsContent = 5;
				// load blank spacer
				$setSpacer = true;
			}
			elseif ($conceptDetails || $conceptContent || $conceptCosting)
			{
				// two is true
				if ($conceptCosting)
				{
					$widthsDetails = 3;
					$widthsContent = 3;
				}
				else
				{
					$widthsDetails = 2;
					$widthsContent = 3;
				}
			}
			// load concept details
			if ($conceptDetails && isset(self::$conceptData[$concept]) && isset(self::$conceptData[$concept]->details))
			{
				$content[] = '<div class="uk-width-medium-'.$widthsDetails.'-5">';
				$content[] = '<div>'.self::$conceptData[$concept]->details.'</div>';
				$content[] = '</div>';
			}
			// set some content
			if ($conceptContent && isset(self::$eventBuilder['content']) && isset(self::$eventBuilder['content'][$event_concept_time]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['content'][$event_concept_time]))
			{
				$content[] = '<div class="uk-width-medium-'.$widthsContent.'-5">';
				$content[] = implode('',self::$eventBuilder['content'][$event_concept_time]);
				$content[] = '</div>';
			}
			// set some content
			if ($conceptCosting && isset(self::$eventOptions[$event_concept_time]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions[$event_concept_time]))
			{
				if ($setSpacer)
				{
					$content[] = '<div class="uk-width-medium-3-5">';
					$content[] = '</div>';
				}
				$content[] = '<div class="uk-width-medium-2-5">';
				$content[] = implode('',self::$eventOptions[$event_concept_time]);
				$content[] = '</div>';
			}
			$content[] = '</div>';

			return implode('',$content);
		}
		elseif (self::$returnType == 'options')
		{
			if (self::setConceptCosting($concept,$event_concept_time))
			{
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions[$event_concept_time]))
				{
					foreach (self::$eventOptions[$event_concept_time] as $nr => &$costing)
					{
						$costing['name'] = self::loadName('event',self::$event->id) . ' (' .self::loadName('concept',$concept) . ' - ' . $costing['name'] .')';
						if (isset(self::$eventBuilder['dates'][$event_concept_time]['start-end']))
						{
							$costing['date'] = self::$eventBuilder['dates'][$event_concept_time]['start-end'];
						}
					}
				}
			}
		}
		return false;
	}

	/**
	 * @param $event_concept_time
	 * @return bool
	 */
	protected static function setConceptContent(&$event_concept_time)
	{
		if (isset(self::$locations[$event_concept_time]))
		{
			$key = self::getLocation($event_concept_time);
			if (isset(self::$event->date['content'][$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->date['content'][$key]))
			{
				if (!isset(self::$eventBuilder['content'][$event_concept_time]))
				{
					self::$eventBuilder['content'][$event_concept_time] = array();
				}
				foreach (self::$event->date['content'][$key] as $content)
				{
					// check if this content is already loaded
					if (!isset(self::$contentData[$content]))
					{
						// load the data
						self::$contentData[$content] = self::getAllValues($content, 'content', array('content_image'));
					}
					// only load the content if we have values
					if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$contentData[$content]))
					{
						continue;
					}
					// now load the banner
					$banner = false;
					if (isset(self::$contentData[$content]->content_image) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$contentData[$content]->content_image) && strpos(self::$contentData[$content]->content_image, '_') !== false)
					{
						$extention = explode('_', self::$contentData[$content]->content_image);
						if (isset($extention[2]))
						{
							$banner = '<img class="uk-thumbnail uk-margin" src="'.self::$filelink.self::$contentData[$content]->content_image.'.'.$extention[2].'" alt="'.self::$contentData[$content]->name.'">';
						}
					}
					$edit = self::loadEditButton('content',$content);
					$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' uk-visible-hover-inline' : '';
					if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$contentData[$content]->details) || $banner)
					{
						$random = self::randomkey(5);
						self::$eventBuilder['content'][$event_concept_time][] = '<div class="uk-margin'.$editClass.'"><a href="#" data-uk-toggle="{target:\'#con'.$random.'\'}">'.self::$contentData[$content]->name.'</a>' . $edit .'</div>';
						self::$eventBuilder['content'][$event_concept_time][] = '<div id="con'.$random.'" class="uk-hidden">';
						if ($banner)
						{
							self::$eventBuilder['content'][$event_concept_time][] = $banner;
						}
						if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$contentData[$content]->details) || $banner)
						{
							self::$eventBuilder['content'][$event_concept_time][] = self::$contentData[$content]->details;
						}
						self::$eventBuilder['content'][$event_concept_time][] = '</div>';
					}
					else
					{
						self::$eventBuilder['content'][$event_concept_time][] = '<div class="uk-margin'.$editClass.'">'.self::$contentData[$content]->name . $edit .'</div>';
					}
				}
				// found
				return true;
			}
		}
		return false;
	}

	/**
	 * @param $concept
	 * @param $event_concept_time
	 * @return bool
	 */
	protected static function setConceptCosting(&$concept,&$event_concept_time)
	{
		$found = false;
		// check if this concept has a variation relation
		if (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']) && in_array($concept, self::$event->cost['concept']))
		{
			$extras = array();
			$buttons = array();
			foreach (self::$event->cost['concept'] as $key => $checker)
			{
				if ($concept == $checker && isset(self::$event->cost['price'][$key]) && isset(self::$event->cost['variation'][$key]) && !self::$event->cost['extra'][$key])
				{
					if (count($buttons) > 2 && (self::$returnType == 'admin' || self::$returnType == 'site'))
					{
						$buttons[] = '<br />';
					}
					if ($button = self::setBuyButtons($key, $concept, $event_concept_time))
					{
						$buttons[] = $button;
					}
				}
				elseif ($concept == $checker && isset(self::$event->cost['price'][$key]) && isset(self::$event->cost['variation'][$key]) && self::$event->cost['extra'][$key])
				{
					if (count($extras) > 2 && (self::$returnType == 'admin' || self::$returnType == 'site'))
					{
						$extras[] = '<br />';
					}
					if ($button = self::setBuyButtons($key, $concept, $event_concept_time))
					{
						$extras[] = $button;
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($buttons))
			{
				self::$eventOptions[$event_concept_time] = array();
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					self::$eventOptions[$event_concept_time][] = implode('',$buttons);
				}
				elseif (self::$returnType == 'options')
				{
					self::$eventOptions[$event_concept_time] = $buttons;
				}
				$found = true;
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($extras))
			{
				if (!isset(self::$eventOptions[$event_concept_time]))
				{
					self::$eventOptions[$event_concept_time] = array();
					if (self::$returnType == 'admin' || self::$returnType == 'site')
					{
						self::$eventOptions[$event_concept_time][] = implode('',$extras);
					}
					elseif (self::$returnType == 'options')
					{
						self::$eventOptions[$event_concept_time] = $extras;
					}

				}
				else
				{
					if (self::$returnType == 'admin' || self::$returnType == 'site')
					{
						self::$eventOptions[$event_concept_time][] = '<hr>';
						self::$eventOptions[$event_concept_time][] = implode('',$extras);
					}
					elseif (self::$returnType == 'options')
					{
						self::$eventOptions[$event_concept_time] = array_merge(self::$eventOptions[$event_concept_time], $extras);
					}
				}
				$found = true;
			}
		}
		return $found;
	}

	/**
	 * @param $key
	 * @param int $concept
	 * @param string $event_concept_time
	 * @return array|bool|string
	 */
	protected static function setBuyButtons($key, $concept = 0, $event_concept_time = '0__0')
	{
		// 1  <- individual and group
		// 2  <- only individual
		// 3 <- only group
		// 4 <- custom reg
		// 5 <- close reg
		if (isset(self::$event->id))
		{
			// set the price
			if (self::$event->type != 5 && ($conceptPrice = self::getConceptPrice($key)))
			{
				$variation = (int) self::$event->cost['variation'][$key];
				$qty = (int) self::$event->cost['qty'][$key];
				$only = (int) self::$event->cost['only'][$key];
				$extra = (int) self::$event->cost['extra'][$key];
				$taxed = (int) self::$event->cost['taxed'][$key];
				// start building the button
				$button = array();
				if (self::$event->type == 4)
				{
					$button[] = '<div  class="uk-width-1-1 uk-text-bold uk-text-success uk-text-large">';
					$button[] = self::loadName('variation',$variation);
					$button[] = '  ' .$conceptPrice['EXCHANGE_RATE_TO_MONEY'];
					$button[] = '</div>';
					$button[] = '<a href="#CUSTOM_LINK" class="uk-button uk-button-primary uk-margin-small-bottom uk-width-1-1" target="_blank">';
					$button[] = Text::_('Register');
					$button[] = '</a>';

					$buyId = null;
				}
				else
				{
					$bundle = 0;
					$time = explode('__',$event_concept_time);
					if (isset(self::$eventBuilder['bundle'][$event_concept_time]))
					{
						$bundle = self::$eventBuilder['bundle'][$event_concept_time];
					}
					// switch ID
					$switchID = self::$event->id . '_' . (int) $bundle . '_' .(int) $time[1] . '_' .(int) $concept . '_' . (int) $variation;
					// checking ID
					$checkingID = self::$event->organizer . '_' . $switchID;
					// checking KEY
					$IDKEY = md5($checkingID);
					// set buy ID
					$buyId = $IDKEY . '__' . $conceptPrice['EXCHANGE_RATE_TO'] . '__' . $conceptPrice['EXCHANGE_RATE_ID'];
					// get qty available
					$actualQTY = self::getQtyAvailable($qty, 'variation', $checkingID);
					// get qty this user has selected 
					$selectedQTY = self::activeCartQty($checkingID);
					// set variation name
					$variationName = self::loadName('variation',$variation);
					// set button by ID
					$buttonId = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($buyId, 'cAmel');
					// we remove disabler if not needed
					self::$disableButtons['###'.$buttonId.'###'] = '';
					if ( self::$returnType !== 'options')
					{
						// set some JavaScript values
						if (self::$returnType == 'admin')
						{
							self::$buttonScript[] = 'available["'.$buttonId.'"] = '. (int) $qty.';';
						}
						// ticket behavior 
						if (!$extra)
						{
							self::$buttonScript[] = 'tickets["'.$buttonId.'"] = 1;';
						}
						// set the only switch
						$onlySwitch = '';
						if (1 == $only && !$extra)
						{
							$onlySwitch = 'data-only="1"';
							// make sure selected only values are set again
							if ($selectedQTY > 0)
							{
								// load per concept
								if (!isset(self::$conceptSwitchOnly[$concept]))
								{
									self::$conceptSwitchOnly[$concept] = array();
								}
								// this is the active selection
								self::$conceptSwitchOnly[$concept][] = array('concept' => (int) $concept, 'bundle' => (int) $bundle);
								// load per bundle
								if (!isset(self::$bundleSwitchOnly[$bundle]))
								{
									self::$bundleSwitchOnly[$bundle] = array();
								}
								// this is the active selection
								self::$bundleSwitchOnly[$bundle][] = array('concept' => (int) $concept, 'bundle' => (int) $bundle);
							}
							else
							{
								self::$disableButtonsCheck[$buttonId] = array('concept' => (int) $concept, 'bundle' => (int) $bundle);
							}
						}
						$button[] = '<div class="uk-width-1-1 uk-text-bold uk-text-success uk-text-large">';
						$button[] = $variationName;
						$button[] = '<br class="uk-visible-small"/>  <span class="'.$buttonId.'-price">' . $conceptPrice['EXCHANGE_RATE_TO_MONEY'] .'</span>';
						$button[] = '</div>';

						// check if there is still place open on this variation
						if ($qty != 0 && $actualQTY <= 0 && $selectedQTY <= 0 && self::$returnType !== 'admin')
						{
							// start building the button
							$button = array();
							$button[] = '<div class="uk-width-1-1 uk-text-bold uk-text-muted uk-text-large">';
							$button[] = $variationName;
							$button[] = '<br class="uk-visible-small"/> ' . $conceptPrice['EXCHANGE_RATE_TO_MONEY'] .' <small>(' . Text::_('This Option is Full.') . ')</small>';
							$button[] = '</div>';
							$button[] = '<button class="uk-button uk-margin-small-bottom uk-width-1-1" type="button" disabled> ';
							$button[] = Text::_('Closed');
							$button[] = '</button>';
						}
						elseif (self::$event->type == 2)
						{
							if ($selectedQTY > 0)
							{
								$button[] = '<button  id="'.$buttonId.'-select" class="select-button uk-button uk-margin-small-bottom uk-width-1-1 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' data-uk-button="0"> ';
								$button[] = Text::_('Select');
								$button[] = '</button>';
							}
							else
							{
								$button[] = '<button  id="'.$buttonId.'-select" class="select-button uk-button uk-margin-small-bottom uk-width-1-1 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' data-uk-button="0"> ';
								$button[] = Text::_('Select');
								$button[] = '</button>';
							}
						}
						else
						{
							// add to cart button
							$button[] = '<div class="uk-button-group uk-width-1-1">';
							if ($qty != 0 && $actualQTY <= 0 && $selectedQTY > 0)
							{
								$button[] = '<button id="'.$buttonId.'-plus" class="select-button uk-button uk-button-small uk-margin-small-bottom uk-width-1-3 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' disabled>';
							}
							else
							{
								$button[] = '<button id="'.$buttonId.'-plus" class="select-button uk-button uk-button-small uk-margin-small-bottom uk-width-1-3 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' ###'.$buttonId.'###>';
							}
							$button[] = '<i class="uk-icon-plus"></i>';
							$button[] = '</button>';
							$button[] = '<button id="'.$buttonId.'-minus" class="select-button uk-button uk-button-small uk-margin-small-bottom uk-width-1-3 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' ###'.$buttonId.'###>';
							$button[] = '<i class="uk-icon-minus"></i>';
							$button[] = '</button>';
							$button[] = '<button class="uk-button uk-button-small uk-margin-small-bottom uk-width-1-3" type="button" disabled>';
							if ($selectedQTY > 0)
							{
								$button[] = '<span id="'.$buttonId.'-number" data-qty="'.$selectedQTY.'"><span class="uk-badge uk-badge-notification uk-badge-success">'.$selectedQTY.'</span></span>';
							}
							else
							{
									$button[] = '<span id="'.$buttonId.'-number" data-qty="0">0</span>';						
							}
							$button[] = '</button>';
							$button[] = '</div>';
						}
						
						// check if there has been a change in price
						$storedPrice = self::getEventDetails($IDKEY, 'price', 'id', false);
						if ($storedPrice !== $conceptPrice['EXCHANGE_RATE_TO'])
						{
							// update the price if there was a change
							self::updateEventDetail($IDKEY, array(
								'id' => $IDKEY,
								'buy_id' => $buyId,
								'check_id' => $checkingID,
								'switch_id' => $switchID,
								'price' => $conceptPrice['EXCHANGE_RATE_FROM'],
								'name' => $variationName,
								'qty' => $qty,
								'only' => $only,
								'extra' => $extra,
								'taxed' => $taxed,
								'priceObject' => $conceptPrice));
						}
					}
				}
				// only return button if admin or site return type
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					return  implode('',$button);
				}
				// if options then return array of results
				elseif ($buyId && self::$returnType == 'options')
				{
					return array(
						'id' => $IDKEY,
						'buy_id' => $buyId,
						'check_id' => $checkingID,
						'switch_id' => $switchID,
						'price' => $conceptPrice['EXCHANGE_RATE_TO'],
						'name' => $variationName,
						'qty' => $qty,
						'only' => $only,
						'extra' => $extra,
						'taxed' => $taxed,
						'priceObject' => $conceptPrice);
				}
			}
		}
		return false;
	}

	public static function getEventDetails($key, $what = 'price', $type = 'name', $retry = true, $priceConvertion = true)
	{
		if ('name' == $type)
		{
			$key = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($key);
		}
		// get the event details
		$eventDetails = self::get('eventDetailsVDM', null);
		if ($eventDetails && isset($eventDetails[$type][$key]) && isset($eventDetails[$type][$key][$what]))
		{
			return self::eventDetailPrep($eventDetails[$type][$key], $what, $priceConvertion);
		}
		// if not set retry, by setting it
		if ($retry)
		{
			self::setEventOptions();
			return self::getEventDetails($key, $what, $type, false);
		}
		return false;
	}

	protected static function eventDetailPrep(&$values, &$what, $priceConvertion)
	{
		if ('price' === $what && $priceConvertion)
		{
			// used for the invoice view mainly
			$jinput = Factory::getApplication()->input;
			$data = $jinput->getArray(array(
				'organizer_currency' => 'word',
				'registered_user_currency' => 'word',
				'exchange_rate' => 'float'
			));
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data['organizer_currency']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data['registered_user_currency']))
			{
				$check = $data['organizer_currency'].$data['registered_user_currency'];
				$organizer_currency = 'NONE';
				if (isset($values['priceObject']['EXCHANGE_RATE_NAME']) && $check === $values['priceObject']['EXCHANGE_RATE_NAME'])
				{
					return $values[$what];
				}
				// if exchange rate is not set
				if (isset($values['priceObject']['EXCHANGE_RATE_ID']))
				{
					$organizer_currency = self::getFromCurrency($values['priceObject']['EXCHANGE_RATE_ID']);
				}
				if ($data['exchange_rate'] == 0 && $organizer_currency === $data['organizer_currency'])
				{
					$result = self::getExchangeRate($data['organizer_currency'], $values[$what], $data['registered_user_currency']);
					// now update the data
					return $result['EXCHANGE_RATE_TO'];
				}
				else
				{
					return bcmul($values[$what], $data['exchange_rate'], 2);
				}
			}
			// for other views
			elseif (isset($values['priceObject']['EXCHANGE_RATE_ID']))
			{
				$organizer_currency = self::getFromCurrency($values['priceObject']['EXCHANGE_RATE_ID']);
				$active_currency =  self::getUserCurrency();
				$result = self::getExchangeRate($organizer_currency, $values[$what], $active_currency);
				// now update the data
				return $result['EXCHANGE_RATE_TO'];
			}
		}
		return $values[$what];
	}

	protected static function getFromCurrency($exchange_ID)
	{
		$fromArray = array_map('strtoupper', (array) explode('-', $exchange_ID));
		return $fromArray[0];
	}

	protected static function setEventOptions()
	{
		$events = self::getVars('event', 1, 'published');
		// only continue if we have an array
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($events))
		{
			$bucket = array(); $bucket['name'] = array();  $bucket['id'] = array();
			foreach($events as $item)
			{
				if ($eventOptions = self::getEvent($item, 'options'))
				{
					foreach($eventOptions as $event)
					{
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event))
						{
							foreach ($event as $option)
							{
								$option['_name'] = (isset($option['date']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($option['date'])) ?  $option['name']. ' ~ ' . $option['date'] :  $option['name'];
								$select = JFilterOutput::cleanText($option['_name']);
								// store in session
								$key = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($select);
								$option['select'] =  $select;
								$bucket['name'][$key] = $option;
								$bucket['id'][$option['id']] = $option;
							}
						}
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket['id']))
			{
				self::set('eventDetailsVDM', $bucket);
			}
		}
	}

	protected static function updateEventDetail($key, $values)
	{
		// get the event Details from memory
		$eventDetails = self::get('eventDetailsVDM', null);
		// make sure the id is found
		if ($eventDetails && isset($eventDetails['id'][$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($eventDetails['id'][$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($values))
		{
			$select = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($eventDetails['id'][$key]['select']);
			foreach ($values as $field => $value)
			{
				// update the field in ID
				$eventDetails['id'][$key][$field] = $value;
				// update the field in selection
				$eventDetails['name'][$select][$field] = $value;
			}
			// store back to memory
			self::set('eventDetailsVDM', $eventDetails);
		}
	}

	/**
	*  Get all items in Cart
	*/
	public static function getCart($status = 1, $both = true)
	{
		// always check for public key
		$public = self::get('publicKeeY', null);
		// get user object
		$userIs = self::userIs(null, true);
		// now check the id against the registered values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('a.key')));
		$query->from($db->quoteName('#__[[[component]]]_register', 'a'));
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_event', 'e')) . ' ON (' . $db->quoteName('a.event') . ' = ' . $db->quoteName('e.id') . ')');
		$query->where('a.status = ' . (int) $status);
		$query->order('e.name ASC');
		if ($userIs['is'] == 1 && $userIs['id'] > 0)
		{
			if ($public && $both === true)
			{
				$query->where('a.public = ' . $db->quote($public) . ' OR a.registered_user = '. (int) $userIs['id']);
			}
			else
			{
				$query->where('a.registered_user = '. (int) $userIs['id']);
			}
		}
		elseif ($public)
		{
			$query->where('a.public = ' . $db->quote($public));
		}
		else
		{
			return false;
		}
		$db->setQuery($query);
		$db->execute();
		// return the number of cart items
		if ($db->getNumRows())
		{
			$bucket = array();
			$registrations = $db->loadObjectList();
			foreach ($registrations as $reg)
			{
				// organizer_event_bundle_time_concept_variation
				$get = explode('_', $reg->key);
				$id = md5($reg->key);
				// load the values
				if (!isset($bucket[$get[0]]))
				{
					$bucket[$get[0]] = array();
				}
				// count the number of registrations for this variation and set its needed values
				if (!isset($bucket[$get[0]][$id]))
				{
					$bucket[$get[0]][$id] = array();
					$bucket[$get[0]][$id]['qty'] = 1;
					$bucket[$get[0]][$id]['event'] = (int) $get[1];
				}
				else
				{
					$bucket[$get[0]][$id]['qty']++;
				}
			}
			return $bucket;
		}
		return false;
	}

	/**
	*  Check if the qty is still available
	*/
	public static function activeCartQty($keyID)
	{
		// always check for public key
		$public = self::get('publicKeeY', null);
		// get user object
		$userIs = self::userIs(null, true);
		// now check the id against the registered values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName('a.id'));
		$query->from($db->quoteName('#__[[[component]]]_register', 'a'));
		$query->where('a.key = ' . $db->quote($keyID));
		$query->where('a.status = 1');
		if ($userIs['is'] == 1 && $userIs['id'] > 0)
		{
			if ($public)
			{
				$query->where('a.public = ' . $db->quote($public) . ' OR a.registered_user = '. (int) $userIs['id']);
			}
			else
			{
				$query->where('a.registered_user = '. (int) $userIs['id']);
			}
		}
		elseif ($public)
		{
			$query->where('a.public = ' . $db->quote($public));
		}
		else
		{
			return 0;
		}
		$db->setQuery($query);
		$db->execute();
		// return the number of cart items
		return (int) $db->getNumRows();
	}

	/**
	*  Check if the qty is still available
	*/
	public static function getQtyAvailable($qty, $type, $keyID)
	{
		if (('variation' === $type || 'event' === $type) && ((is_numeric($qty) && $qty > 0) || 'taken' === $qty))
		{
			// now check the id against the registered values
			$db = Factory::getDBO();
			$query = $db->getQuery(true);
			$query->select($db->quoteName('a.id'));
			$query->from($db->quoteName('#__[[[component]]]_register', 'a'));
			if ('variation' === $type)
			{
				$query->where('a.key = ' . $db->quote($keyID));
			}
			elseif ('event' === $type)
			{
				$query->where('a.event = ' . (int) $keyID);
			}
			else
			{
				return $qty;
			}
			$query->where('a.status >= 1');
			$db->setQuery($query);
			$db->execute();
			$registered = $db->getNumRows();
			if ('taken' === $qty)
			{
				return $registered;
			}
			if ($registered >= $qty)
			{
				return 0;
			}
			return bcsub($qty, $registered);
		}
		return $qty;
	}

	/**
	* @ return float on success
	*/
	protected static function getConceptPrice($key)
	{
		// first we get the raw set price (in organizers currency)
		if (isset(self::$event->cost['price'][$key]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->cost['price'][$key]))
		{
			$orgRaw = self::$filterInput->clean(self::$event->cost['price'][$key]);
			if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($orgRaw))
			{
				$orgRaw = "0.00";
			}
			// get organizer currency
			if ($orgCurrency = self::getEventCurrency())
			{
				if (self::$returnType == 'site')
				{
					// get the active party currency
					$activeCurrency = self::get('ACTIVE_CURRENCY');
				}
				else
				{
					$activeCurrency = $orgCurrency;
				}
				// set active price object
				return self::getExchangeRate($orgCurrency, $orgRaw, $activeCurrency);
			}
		}
		return false;
	}

	/**
	 * @return mixed
	 */
	protected static function getConceptsHTML()
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$conceptHTML))
		{
			$thisEvent = array();
			foreach (self::$conceptHTML as $event_concept__time => $HTML)
			{
				$looking = explode('_',$event_concept__time);
				if (self::$event->id == $looking[0])
				{
					$thisEvent[$event_concept__time] = $HTML;
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($thisEvent))
			{
				return $thisEvent;
			}
		}
		return false;
	}

	/**
	 * @return mixed
	 */
	protected static function getEventOptions()
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions))
		{
			$thisEvent = array();
			foreach (self::$eventOptions as $event_concept__time => $options)
			{
				$looking = explode('_',$event_concept__time);
				if (self::$event->id == $looking[0])
				{
					$thisEvent[$event_concept__time] = $options;
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($thisEvent))
			{
				return $thisEvent;
			}
		}
		return false;
	}

	/**
	 * @param $event_concept_time
	 * @return mixed
	 */
	protected static function getConseptId($event_concept_time)
	{
		if (isset(self::$concepts[$event_concept_time]))
		{
			return self::$concepts[$event_concept_time];
		}
		return $event_concept_time;
	}

	/**
	 * @param $event_concept_time
	 * @return int|mixed
	 */
	protected static function getLocation($event_concept_time)
	{
		if (isset(self::$locations[$event_concept_time]))
		{
			return self::$locations[$event_concept_time];
		}
		return 9999;
	}

	/**
	 * @param $location
	 * @return bool|string
	 */
	protected static function getEventConceptTime($location)
	{
		if (isset(self::$event->date['start'][$location]) && isset(self::$event->date['concept'][$location]))
		{
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->date['start'][$location]))
			{
				$timestamp = strtotime(self::$event->date['start'][$location]);
			}
			else
			{
				$timestamp = 0;
			}
			return self::$event->id.'_'.self::$event->date['concept'][$location].'__'.$timestamp;
		}
		return false;
	}

	protected static function setDates()
	{
		if (isset(self::$event->date['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->date['concept']))
		{
			$types = array('start', 'end');
			self::$eventBuilder['start'] = strtotime('2300-00-00');
			self::$eventBuilder['end'] = strtotime('0000-00-00');
			self::$eventBuilder['timestamps'] = array();
			self::$eventBuilder['dates'] = array();
			foreach( $types as $type)
			{
				foreach (self::$event->date[$type] as $nr => $date)
				{
					$date = self::$filterInput->clean($date);
					// get the key
					$key = self::getEventConceptTime($nr);
					if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($date))
					{
						$timestamp = strtotime($date);
						if (('start' == $type) && self::$eventBuilder[$type] > $timestamp)
						{
							self::$eventBuilder[$type] = $timestamp;
						}
						elseif (('end' == $type) && self::$eventBuilder[$type] < $timestamp)
						{
							self::$eventBuilder[$type] = $timestamp;
						}
						// set time stamp
						if (!isset(self::$eventBuilder['timestamps'][$key]))
						{
							self::$eventBuilder['timestamps'][$key] = array();
						}
						self::$eventBuilder['timestamps'][$key][$type] = $timestamp;
					}
					// set global concept keys
					if ('start' == $type)
					{
						self::$concepts[$key] = self::$event->date['concept'][$nr];
						self::$locations[$key] = $nr;
					}
				}
			}
			// check if time are set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['timestamps']))
			{
				// now loop the time stamps
				foreach (self::$eventBuilder['timestamps'] as $on => $dates)
				{
					if (isset($dates['start']) && isset($dates['end']))
					{
						if (!isset(self::$eventBuilder['dates'][$on]))
						{
							self::$eventBuilder['dates'][$on] = array();
						}
						self::$eventBuilder['dates'][$on]['start'] = self::fancyDate($dates['start']);
						self::$eventBuilder['dates'][$on]['end'] = self::fancyDate($dates['end']);
						if (date('Ymd', $dates['start']) == date('Ymd', $dates['end']))
						{
							// same day
							self::$eventBuilder['dates'][$on]['start-end'] =  	self::fancyTime($dates['start'])
								.' '.Text::_('to').' '. self::fancyTime($dates['end'])
								.' '.Text::_('on the').' '. self::fancyDate($dates['end']);
						}
						else
						{
							// another day
							self::$eventBuilder['dates'][$on]['start-end'] =  	self::fancyDateTime($dates['start'])
								.' '.Text::_('to').' '. self::fancyDateTime($dates['end']);
						}
					}
				}
				// set the event start and end date
				if (date('Ymd', self::$eventBuilder['start']) == date('Ymd', self::$eventBuilder['end']))
				{
					// one day event
					self::$eventBuilder['start-end'] = self::fancyDate(self::$eventBuilder['start']);
				}
				elseif (date('Ym', self::$eventBuilder['start']) == date('Ym', self::$eventBuilder['end']))
				{
					//  multi day event in same month
					self::$eventBuilder['start-end'] =  date('jS', self::$eventBuilder['start']).' - '. self::fancyDate(self::$eventBuilder['end']);
				}
				else
				{
					// multi day event
					self::$eventBuilder['start-end'] = self::fancyDate(self::$eventBuilder['start']).' - '. self::fancyDate(self::$eventBuilder['end']);
				}
				return true;
			}
		}
		return false;
	}

	/**
	 * @param $id
	 * @param $type
	 */
	protected static function getAllValues($id, $type, $encryptedNames = array())
	{
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName('a.*'));
		$query->from($db->quoteName('#__[[[component]]]_'.$type, 'a'));
		$query->where('a.id = ' . (int) $id);
		$query->where('a.published >= 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$result = $db->loadObject();
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($encryptedNames))
			{
				foreach ($encryptedNames as $encrypted)
				{
					if (isset($result->$encrypted) && !empty($result->$encrypted))
					{
						$result->$encrypted = self::decryptString($result->$encrypted);
					}
				}
			}
			return $result;
		}
		return false;
	}

	protected static function decryptString($value)
	{
		if (self::$basickey && !is_numeric($value) && $value === base64_encode(base64_decode($value, true)))
		{
			// decrypt  value
			$value= rtrim(self::$locker->decryptString($value), "\0");
		}
		return $value;
	}

	/**
	 * @param $ids
	 * @param $type
	 * @return array|null
	 */
	public static function getNames($ids, $type)
	{
		// setup the get array
		$get = array('a.id');
		switch($type)
		{
			case 'venue':
				// set related values
				$get[] = 'a.name';
				$table = '#__[[[component]]]_venue';
			break;
			case 'catid':
				// set related values
				$get[] = 'a.title';
				$table = '#__categories';
			break;
			case 'organizer':
				// set related values
				$get[] = 'a.companyname';
				$get[] = 'a.user';
				$table = '#__[[[component]]]_organizer';
			break;				
		}
		if (!isset($table) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
			return null;
		}
		// check the array of ids
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
			foreach ($ids as $id)
			{ 
				if (!(is_numeric($id)))
				{
					return null;
				} 
			}
		}
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName($get));
		$query->from($db->quoteName($table, 'a'));
		$query->where('a.id IN (' . implode(', ', $ids) . ')');
		$query->where('a.published = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$items = $db->loadObjectList();
			$bucket = array();
			foreach ($items as $item)
			{
				switch($type)
				{
					case 'venue':
						// set related values
						$bucket[$item->id] = $item->name;
					break;
					case 'catid':
						// set related values
						$bucket[$item->id] = $item->title;
					break;
					case 'organizer':
						// set related values
						if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($item->companyname))
						{
							$name = $item->companyname;
						}
						else
						{
							$name = Factory::getUser($item->user)->name;
						}
						$bucket[$item->id] = $name;
					break;
				}
			}
			return $bucket;
		}
		return null;
	}
[CUSTOMCODE=imageHelpers] 
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=setDynamicDataIF]
	protected static $placeHolders;
	
	public static function getPlaceHolders($type, $id = null, $registered = null, $config = array())
	{
		if ('invoice' === $type)
		{
			// set to global if not given
			if (!$id && self::$organizer)
			{
				$id = self::$organizer;
			}
			// set to global if not given
			if (!$registered && self::$registered)
			{
				$registered = self::$registered;
			}
			if ($organizer && $registered)
			{
				// get needed details
				if (!isset(self::$placeHolders[$type.'_'.$id.'_'.$registered]))
				{
					$details = array();
					$details[] = self::getOrganizerDetails((int) $id);
					$details[] = self::getRegisteredDetails((int) $registered);
					self::$placeHolders[$type.'_'.$id.'_'.$registered] = self::mergeArrays($details);
				}
				// add the config array if needed
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($config))
				{
					self::$placeHolders[$type.'_'.$id.'_'.$registered] = self::mergeArrays(array(self::$placeHolders[$type.'_'.$id.'_'.$registered], $config));
				}
				return self::$placeHolders[$type.'_'.$id.'_'.$registered];
			}
			return false;
		}
		elseif (!$id && ('organizer' === $type || 'venue' === $type))
		{
			return array_values(self::getSelection($type, '['.$type.'_', ']'));
		}
		elseif ('venue' === $type && $id > 0)
		{
			
		}
		elseif ('organizer' === $type && $id > 0)
		{
			// get needed details
			if (!isset(self::$placeHolders[$type.'_'.$id]))
			{
				// load the organizer
				self::$placeHolders[$type.'_'.$id] = self::getOrganizerDetails((int) $id);
			}

			// add the config array if needed
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($config) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$placeHolders[$type.'_'.$id]))
			{
				self::$placeHolders[$type.'_'.$id] = self::mergeArrays(array(self::$placeHolders[$type.'_'.$id], $config));
			}

			// if loaded return
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$placeHolders[$type.'_'.$id]))
			{
				return self::$placeHolders[$type.'_'.$id];
			}
		}
		return false;
	}

	/**
	* Return array of selections
	* 
	* @return    array if type match
	*/
	protected static function getSelection($type, $f, $b)
	{
		if ('organizer' === $type)
		{
			return array(
				'a.id' => $f.'id'.$b,	
				'a.user' => $f.'user_id'.$b,
				'a.mobile_phone' => $f.'mobile_phone'.$b,
				'a.companyname' => $f.'companyname'.$b,
				'a.publicnumber' => $f.'publicnumber'.$b,
				'a.currency' => $f.'currency'.$b,
				'a.street' => $f.'street'.$b,
				'a.postal' => $f.'postal'.$b,
				'a.city' => $f.'city'.$b,
				'a.region' => $f.'region'.$b,
				'a.country' => $f.'country'.$b,
				'a.postalcode' => $f.'postalcode'.$b,
				'a.website' => $f.'website'.$b,
				'a' => $f.'website_link'.$b,
				'a.logo_image' => $f.'logo'.$b,
				'b' => $f.'logo_url'.$b,
				'a.prefix' => $f.'prefix'.$b,
				'a.tax_compound' => $f.'tax_compound'.$b,
				'a.taxed' => $f.'taxed'.$b,
				'a.tax_type' => $f.'tax_type'.$b,
				'a.doc_footer' => $f.'doc_footer'.$b,
				'a.doc_header' => $f.'doc_header'.$b,
				'b.name' => $f.'name'.$b,
				'c' => $f.'_name'.$b,
				'b.username' => $f.'username'.$b,
				'b.email' => $f.'email'.$b,
				'c.name' => $f.'region_name'.$b,
				'd.name' => $f.'country_name'.$b
			);
		}
		if ('venue' === $type)
		{
			return array(
				'a.id' => $f.'id'.$b,	
				'a.user' => $f.'user_id'.$b,
				'a.mobile_phone' => $f.'mobile_phone'.$b,
				'a.companyname' => $f.'companyname'.$b,
				'a.publicnumber' => $f.'publicnumber'.$b,
				'a.currency' => $f.'currency'.$b,
				'a.street' => $f.'street'.$b,
				'a.postal' => $f.'postal'.$b,
				'a.city' => $f.'city'.$b,
				'a.region' => $f.'region'.$b,
				'a.country' => $f.'country'.$b,
				'a.postalcode' => $f.'postalcode'.$b,
				'a.website' => $f.'website'.$b,
				'a.prefix' => $f.'prefix'.$b,
				'a.tax_compound' => $f.'tax_compound'.$b,
				'a.taxed' => $f.'taxed'.$b,
				'a.tax_type' => $f.'tax_type'.$b,
				'a.doc_footer' => $f.'doc_footer'.$b,
				'a.doc_header' => $f.'doc_header'.$b,
				'b.name' => $f.'name'.$b,
				'b.username' => $f.'username'.$b,
				'b.email' => $f.'email'.$b,
				'c.name' => $f.'region_name'.$b
			);
		}
		return false;
	}
	
	protected static $itemOrganizer = array();

	public static function getItemOrganizer(&$item, $type, $key = 'id', $default = null)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->$key) && (int) $item->$key > 0)
		{
			// check if already set
			if (!isset(self::$itemOrganizer[$type.$item->$key]))
			{
				self::setItemOrganizer($item, $type, $key);
			}
			if (isset(self::$itemOrganizer[$type.$item->$key]) && self::$itemOrganizer[$type.$item->$key])
			{
				return self::$itemOrganizer[$type.$item->$key];
			}
		}
		return $default;
	}
	
	protected static function setItemOrganizer(&$item, $type, $key)
	{
		// get organizer id for various types of items
		switch($type)
		{
			case 'transaction':
				if (isset($item->invoice))
				{
					self::$itemOrganizer[$type.$item->$key] = self::getVar('invoice', $item->invoice, 'id', 'organizer');
				}
			break;
		}
	}

	protected static $organizerDetails = array();

	public static function getOrganizerValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$organizerDetails[$id]))
			{
				self::setOrganizerDetails($id);
			}
			// get the field if set
			$field = '[organizer_'.$field.']';
			if (isset(self::$organizerDetails[$id]) && isset(self::$organizerDetails[$id][$field]))
			{
				return self::$organizerDetails[$id][$field];
			}
		}
		return $default;
	}

	public static function getOrganizerDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$organizerDetails[$id]))
			{
				self::setOrganizerDetails($id);
			}
			return self::$organizerDetails[$id];
		}
		return false;
	}

	protected static function setOrganizerDetails($id, $method = 'placeholder')
	{
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			$f = '[organizer_';
			$b = ']';
		}
		// Create a new query object.
		$db = Factory::getDBO();
		$query = $db->getQuery(true);

		// Select some fields
		$selection = self::getSelection('organizer', $f, $b);
		// remove some that are set dynamically
		unset($selection['a']);
		unset($selection['b']);
		unset($selection['c']);
		$query->select($db->quoteName(array_keys($selection), array_values($selection)));

		// From the [[[component]]]_organizer table				
		$query->from($db->quoteName('#__[[[component]]]_organizer', 'a'));				
		$query->join('LEFT', ($db->quoteName('#__users', 'b')) . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('b.id') . ')');
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_region', 'c')) . ' ON (' . $db->quoteName('a.region') . ' = ' . $db->quoteName('c.id') . ')');
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_country', 'd')) . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('d.id') . ')');
		$query->where($db->quoteName('a.id') . ' = '. (int) $id);
		// load the query
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$organizerDetails[$id] = $db->loadAssoc();
			// load the name
			if (isset(self::$organizerDetails[$id][$f.'companyname'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id][$f.'companyname'.$b]))
			{
				$name = self::$organizerDetails[$id][$f.'companyname'.$b];
			}
			else
			{
				$name = self::$organizerDetails[$id][$f.'name'.$b];
			}
			self::$organizerDetails[$id][$f.'_name'.$b] = $name;
			// set website link
			$link = '';
			if (isset(self::$organizerDetails[$id][$f.'website'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id][$f.'website'.$b])) 
			{
				// set link
				if (strpos(self::$organizerDetails[$id][$f.'website'.$b], 'http://') !== false || strpos(self::$organizerDetails[$id][$f.'website'.$b], 'https://') !== false)
				{
					$link = '<a href="'.self::$organizerDetails[$id][$f.'website'.$b].'">' . $name . '</a>';
				}
				else
				{
					$link = '<a href="http://'.self::$organizerDetails[$id][$f.'website'.$b].'">' . $name . '</a>';
				}
			}
			self::$organizerDetails[$id][$f.'website_link'.$b] = $link;

			// set logo image
			$logoFound = '';
			$logoUrl = '';
			if (isset(self::$organizerDetails[$id][$f.'logo'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id][$f.'logo'.$b])) 
			{
				// Get the basic encryption.
				self::$basickey = self::getCryptKey('basic');
				$logo = self::$organizerDetails[$id][$f.'logo'.$b];
				if (self::$basickey)
				{
					// Get the encryption object.
					self::$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power(self::$basickey, 128);
					$logo = self::decryptString($logo);
				}
				if (strpos($logo, '_') !== false)
				{
					$extention = explode('_', $logo);
					if (isset($extention[2]))
					{
						$logoUrl = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath('url').$logo.'.'.$extention[2];
						$logoFound = '<img class="uk-thumbnail" src="'.$logoUrl.'" alt="'.$name.'">';
					}
				}
			}
			// now add the logo
			self::$organizerDetails[$id][$f.'logo'.$b] = $logoFound;
			self::$organizerDetails[$id][$f.'logo_url'.$b] = $logoUrl;
		}
		else
		{
			self::$organizerDetails[$id] = false;
		}
	}

	protected static $regUsers = array();

	public static function getRegUserValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$regUsers[$id]))
			{
				self::setRegUserValue($id);
			}
			// get the field if set
			$field = '[registered_'.$field.']';
			if (isset(self::$regUsers[$id]) && isset(self::$regUsers[$id][$field]))
			{
				return self::$regUsers[$id][$field];
			}
		}
		return $default;
	}

	public static function getRegisteredDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$regUsers[$id]))
			{
				self::setRegUserValue($id);
			}
			return self::$regUsers[$id];
		}
		return false;
	}
	
	protected static function setRegUserValue($id, $method = 'placeholder')
	{
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			$f = '[registered_';
			$b = ']';
		}
		// first get the user
		$userId = self::getVar('registered_user', $id, 'id', 'user');
		$user = Factory::getUser($userId);
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array('a.name','a.value'),
			array('name','value')));
		$query->from($db->quoteName('#__registry_custom_value', 'a'));
		$query->where('a.registered_user = ' . (int) $id);
		$query->where('a.published >= 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$customValues = $db->loadAssocList('name', 'value');
			// possible keys
			$search = array(
				'country' 
					=> array('country', 'country_one', 'country_1', 'country1', 'countryone', 'country_'), 
				'currency' 
					=> array('currency', 'currency_one', 'currency_1', 'currency1', 'currencyone', 'currency_'), 
				'region' 
					=> array('region', 'region_one', 'region_1', 'region1', 'regionone', 'region_')
				);
			self::$regUsers[$id] = array();
			foreach ($customValues as $key => $value)
			{
				self::$regUsers[$id][$f.$key.$b] = $value;
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($value) && !is_numeric($value))
				{
					$found = false;
					$newValue = '';
					foreach ($search as $code => $keys)
					{
						if (!$found)
						{
							foreach($keys as $ke_y)
							{
								if (!$found && $ke_y === strtolower($key))
								{
									if ($newValue = self::getVar($code, $value, 'name', 'id'))
									{
										// insure we use the correct key
										$key = $code;
										// stop search for this field
										$found = true;
									}
								}
							}
						}
					}
					// add also if found
					if ($found)
					{
						self::$regUsers[$id][$f.$key.$b] = (int) $newValue;
						self::$regUsers[$id][$f.$key.'_name'.$b] = $value;
						if ('country' === $key || 'currency' === $key)
						{
							self::$regUsers[$id][$f.$key.'_codethree'.$b] = self::getVar($key, (int) $newValue, 'id', 'codethree');
						}
					}
				}
			}
		}
		// if no currency was found but country, then set the currency to that of the country
		if (!isset(self::$regUsers[$id][$f.'currency_name'.$b]) && isset(self::$regUsers[$id][$f.'country_name'.$b]))
		{
			self::$regUsers[$id][$f.'currency_codethree'.$b] = self::getVar('country', self::$regUsers[$id][$f.'country'.$b], 'id', 'currency');
			self::$regUsers[$id][$f.'currency'.$b] = self::getVar('currency', self::$regUsers[$id][$f.'currency_codethree'.$b], 'codethree', 'id');
			self::$regUsers[$id][$f.'currency_name'.$b] = self::getVar('currency', self::$regUsers[$id][$f.'currency'.$b], 'id', 'name');
		}
		// now load all the user values
		if ($userId > 0)
		{
			self::$regUsers[$id]['[registered_id]'] = $id;
			self::$regUsers[$id]['[registered_user_id]'] = $userId;
			self::$regUsers[$id]['[registered_name]'] = $user->name;
			self::$regUsers[$id]['[registered_username]'] = $user->username;
			self::$regUsers[$id]['[registered_email]'] = $user->email;
		}
		else
		{
			self::$regUsers[$id] = false;
		}
	}
	
	protected static $taxLocation = array();

	public static function getTaxLocation($type, $id, $view)
	{
		if ($id > 0 || 'cart' === $view)
		{
			$key = $type.$view.$id;
			if (!isset(self::$taxLocation[$key]))
			{
				self::setTaxLocation($type, $id, $view, $key);
			}
			if (isset(self::$taxLocation[$key]) && self::$taxLocation[$key] > 0)
			{
				return self::$taxLocation[$key];
			}
		}
		return false;
	}

	protected static function setTaxLocation($field, $id, $view, $key)
	{
		switch ($view)
		{
			case 'invoice':
				// get the client id from job id
				$registered_user = self::getVar($view, $id, 'id', 'registered_user');
				// return location id from client table
				if ($registered_user > 0)
				{
					self::$taxLocation[$key] = self::getRegUserValue($registered_user, $field);
				}
			break;
			case 'cart':
			case 'event':
				// first find out who this is
				$userIs = self::userIs(null, true);
				if ($userIs['is'] == 3 || $userIs['is'] == 2)
				{
					break;
				}
				elseif ($userIs['is'] == 1 && $userIs['id'] > 0)
				{
					self::$taxLocation[$key] = self::getRegUserValue($userIs['id'], $field);
				}
				elseif ('country' === $field)
				{
					// public user so we first get country
					if ($countryThree = self::getLocationdata(null, null, null, 'USD', 10, 1))
					{
						self::$taxLocation[$key] = self::getVar('country', $countryThree, 'codethree', 'id');
					}
				}
			break;
		}
	}

	public static function getTax(&$taxed, &$total, $id, $view)
	{
		$setTax = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('taxed', 0);
		if ($setTax == 1 && 1 == self::getOrganizerValue(self::$organizer, 'taxed', 0))
		{
			// set the tax to this array
			$tax = array();
			$taxAddTotal = array();
			$deduct = array();
			// get the country of the client
			$country = self::getTaxLocation('country', $id, $view);
			// get the region of the client
			$region = self::getTaxLocation('region', $id, $view);
			// now get tax level 1 of this Country and or Region
			$taxLevel1 = self::getTaxRule(1,$country,$region);
			// now get tax level 2 of this Country and or Region
			$taxLevel2 = self::getTaxRule(2,$country,$region);
			// tax types
			$tax_type = self::getOrganizerValue(self::$organizer, 'tax_type', 2);
			// tax compound
			$tax_compound = self::getOrganizerValue(self::$organizer, 'tax_compound', null);
			// based on tax type
			if (2 == $tax_type)
			{
				// tax excluded
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					$tmpAmount =  bcmul($taxed, $taxLevel1['tax'], 20);
					$tax[0]['amount'] = bcdiv($tmpAmount, 100, 4);
					// add to tax total
					$taxAddTotal[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$taxedSub = bcadd($taxed, $tax[0]['amount'], 20);
						$tmpAmount =  bcmul($taxedSub, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					else
					{
						$tmpAmount =  bcmul($taxed, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					// add to tax total
					$taxAddTotal[] = $tax[1]['amount'];
				}
			}
			elseif (1 == $tax_type)
			{
				$removal = array();
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$removal[] = $taxLevel1['tax'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$removal[] = $taxLevel2['tax'];
				}
				$removal = self::bcsum($removal);
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					if ($tax_compound == 1 && $taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']))
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal_a = bcdiv($taxed, $tempVal2, 20);
						$tempVal3 = bcdiv($taxLevel1['tax'], 100, 20);
						$tempVal4 = bcadd($tempVal3, 1, 20);
						$tempVal_b = bcdiv($tempVal_a, $tempVal4, 20);
						$tax[0]['amount'] =  bcsub($tempVal_a, $tempVal_b, 4);
					}
					else
					{
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel1['tax'], 20);
						$tax[0]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal = bcdiv($taxed, $tempVal2, 20);
						$tax[1]['amount'] = bcsub($taxed, $tempVal, 4);
					}
					else
					{
						$tax[1]['name'] = $taxLevel2['name'];
						$tax[1]['tax'] = $taxLevel2['tax'];
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[1]['amount'];
				}
			}
			// check if there was tax set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tax))
			{
				// add the tax to total
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($taxAddTotal))
				{
					$taxed = self::bcsum($taxAddTotal);
					$total = self::bcsum(array($total, $taxed));
				}
				elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($deduct))
				{
					$taxed = self::bcsum($deduct);
				}
				return $tax;
			}
		}
		return false;
	}
		
	protected static $taxrules = array();

	protected static function getTaxRule($level, $country = 0, $region = 0)
	{
		// build the key
		if (self::$organizer)
		{
			$key = $level.$country.$region.self::$organizer;
			// check if it has been set
			if (!isset(self::$taxrules[$key]))
			{
				// Get a db connection.
				$db = Factory::getDbo();
				// set the tax rule
				self::setTaxRule($db, $key, $level, $country, $region);
			}
			// check if it has been set
			if (isset(self::$taxrules[$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$taxrules[$key]))
			{
				return self::$taxrules[$key];
			}
		}
		return false;
	}

	protected static function setTaxRule($db, $key, $level, $country = 0, $region = 0)
	{
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array(	'a.id','a.tax','a.name'),
			array(	'id','tax','name')));
		$query->from($db->quoteName('#__[[[component]]]_tax_rule', 'a'));
		$query->where($db->quoteName('a.published') . ' = 1');
		$query->where($db->quoteName('a.level') . ' = '. (int) $level);
		$query->where($db->quoteName('a.organizer') . ' = '. (int) self::$organizer);
		// check for country and region
		$query->where($db->quoteName('a.country') . ' = '. (int) $country);
		$query->where($db->quoteName('a.region') . ' = '. (int) $region);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$taxrules[$key] = $db->loadAssoc();
		}
		elseif ((int)$country > 0 && (int)$region > 0)
		{
			// now only check for country
			return self::setTaxRule($db, $key, $level, $country);
		}
		elseif ((int)$country > 0 && $region == 0)
		{
			// now check for any without country
			return self::setTaxRule($db, $key, $level);
		}
	}

	/**
	* @param float $amount
	**/
	public static function bcsum($array, $scale = 4)
	{
		$res = 0.0;
		foreach($array as $val){
			$res = bcadd($res, $val, $scale);
		}
		return $res;
	}

	/**
	 * @param $amount
	 * @return mixed|number
	 */
	public static function addCurrency($amount, $codethree = null)
	{
		return self::makeMoney($amount, $codethree);
	}

	protected static $currencyDetails = array();

	/**
	 * @param bool $codethree
	 * @return bool|mixed
	 */
	public static function getCurrencyDetails($codethree = false)
	{
		// check if currency codethree is set
		if (!$codethree && isset(self::$organizer) && self::$organizer > 0)
		{
			// get the price currency
			$codethree = self::getOrganizerValue(self::$organizer, 'currency', false);
		}
		elseif (!$codethree)
		{
			$codethree = self::get('ACTIVE_CURRENCY');
		}
		// return cached data if set
		if ($codethree && !isset(self::$currencyDetails[$codethree]))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			if (is_numeric($codethree))
			{
				$query->where($db->quoteName('a.id') . ' = '. (int) $codethree);
			}
			elseif (strlen($codethree) == 3)
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote($codethree));
			}
			else
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote('NONE'));
			}
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				self::$currencyDetails[$codethree] = $db->loadObject();
			}
		}
		// make sure it has been set
		if (isset(self::$currencyDetails[$codethree]))
		{
			return self::$currencyDetails[$codethree];
		}
		return false;
	}
[CUSTOMCODE=makeMoney]
[CUSTOMCODE=niceFancyDate]
	public static function newDocNumber($organizer, $id = null)
	{
		if (is_numeric($organizer))
		{
			// check if this invoice has transactions
			$isInvoice = false;
			if ($id)
			{
				if ($foundTrans = self::getVar('transaction', $id, 'invoice', 'id'))
				{
					$isInvoice = true;
				}
			}
			// first we get organizers invoicing method
			$proforma = self::getVar('organizer', $organizer, 'id', 'proforma');
			if (0 == $proforma || $isInvoice)
			{
				$isInvoice = true;
				$next = (int) self::getVar('organizer', $organizer, 'id', 'next_invoice_number');
				// make sure the next is a number
				if (!is_numeric($next) || !$next || empty($next) || $next < 1)
				{
					$next = 1;
				}
				// update the next number now
				$org = new \stdClass();
				$org->id = $organizer;
				$org->next_invoice_number = (int) $next + 1;
				Factory::getDbo()->updateObject('#__[[[component]]]_organizer', $org, 'id');
			}
			elseif (1 == $proforma)
			{
				$next = (int) self::getVar('organizer', $organizer, 'id', 'next_proforma_number');
				// make sure the next is a number
				if (!is_numeric($next) || !$next || empty($next) || $next < 1)
				{
					$next = 1;
				}
				// update the next number now
				$org = new \stdClass();
				$org->id = $organizer;
				$org->next_proforma_number = (int) $next + 1;
				Factory::getDbo()->updateObject('#__[[[component]]]_organizer', $org, 'id');
			}
			// get prefix
			$prefix = self::getOrganizerValue($organizer, 'prefix', 'VDM');
			if ($isInvoice)
			{
				return 'INV-'.$prefix.sprintf('%07d', $next);
			}
			else
			{
				return 'PI-'.$prefix.sprintf('%06d', $next);
			}
		}
	}

	public static function checkNr(&$item, $where)
	{
		list($type, $column) = explode('.', $where);
		if ($type && $column && isset($item->$column))
		{
			// load the all items with the same column
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select(array('id' ,'created', 'number', 'organizer'));
			$query->from($db->quoteName('#__[[[component]]]_'.$type));
			$query->where($db->quoteName($column) . ' = '.$db->quote($item->$column));
			if (isset($item->organizer))
			{
				$query->where($db->quoteName('organizer') . ' = ' . (int) $item->organizer);
			}
			$query->order('created ASC');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$found = $db->loadObjectList();
				if (count($found) > 1)
				{
					// is the current item the older one?
					if ($item->id != $found[0]->id)
					{
						self::setNr($item, $type, $column);							
					}
				}
			}
			// insure we update Proformas once payment is made
			if (strpos($item->$column, 'PI') !== false)
			{
				if ($update = self::getVar('transaction', $item->id, 'invoice', 'id'))
				{
					// if proforma is set store backup for later use.
					self::setNr($item, $type, $column, false, 'proforma');
					// update to invoice
					self::setNr($item, $type, $column);
				}
			}
			else
			{
				if (!$update = self::getVar('transaction', $item->id, 'invoice', 'id'))
				{
					// take back to proforma (TODO - may not be ideal)
					self::setNr($item, $type, $column);
				}
			}
		}
		if (!$item->$column || empty($item->$column))
		{
			// if not set, then set now
			self::setNr($item, $type, $column);	
		}
	}
	
	protected static function setNr(&$item, &$type, &$column, $new = true, $other = null)
	{
		if ($new)
		{
			// first update the item
			$item->$column	= self::newDocNumber($item->organizer, $item->id);
		}
		// now update the table
		$updateItem		= new \stdClass;
		$updateItem->id		= $item->id;
		if ($column)
		{
			$updateItem->$column = $item->$column;
			if ($other)
			{
				// update the other field with the column
				$updateItem->$other = $item->$column;
				$item->$other = $item->$column;
			}
		}				
		// update the item now
		Factory::getDbo()->updateObject('#__[[[component]]]_'.$type, $updateItem, 'id');
	}
[CUSTOMCODE=getFilePath]', 'CS8qKg0KCSogCW1ha2Ugc3VyZSBsb2NhdGlvbiBkYXRhIGlzIGxvYWRlZA0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gbG9hZExvY2F0aW9uRGF0YSgpDQoJew0KCQlpZiAoIWNsYXNzX2V4aXN0cygnTG9jYXRpb25kYXRhSGVscGVyJywgRkFMU0UpKQ0KCQl7DQoJCQkkcGF0aCA9IEpQQVRIX1JPT1QgLiAnL2NvbXBvbmVudHMvY29tX2xvY2F0aW9uZGF0YS9oZWxwZXJzL2xvY2F0aW9uZGF0YS5waHAnOw0KCQkJaWYgKGZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJCXsNCgkJCQkvLyBtYWtlIHN1cmUgdG8gbG9hZCB0aGUgaGVscGVyDQoJCQkJSkxvYWRlcjo6cmVnaXN0ZXIoJ0xvY2F0aW9uZGF0YUhlbHBlcicsICRwYXRoKTsNCgkJCQkvLyBmaXN0IHNldCB0aGUgZGVmYXVsdCBjb21wb25lbnQNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OiRkZWZhdWx0Q29tcG9uZW50ID0gJ2NvbV9bW1tjb21wb25lbnRdXV0nOw0KCQkJCXJldHVybiB0cnVlOw0KCQkJfQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCXJldHVybiB0cnVlOw0KCX0NCg0KCS8qKg0KCSogCWNhbmNlbCBFeHBpcmVkIENhcnQgSXRlbXMNCgkqKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIGNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KQ0KCXsNCgkJLy8gYWRkIGFuIGV2ZW50IHRoYXQgd2lsbCBzZW5kIG91dCBhbGwgY29uZmlybWF0aW9uIGVtYWlscywgbm90IHlldCBzZW5kDQoJCSRkb2N1bWVudC0+YWRkU2NyaXB0RGVjbGFyYXRpb24oIg0KCQkJalF1ZXJ5KHdpbmRvdykubG9hZChmdW5jdGlvbigpIHsNCgkJCQljYW5jZWxFeHBpcmVkQ2FydEl0ZW1zKDEpLmRvbmUoZnVuY3Rpb24ocmVzdWx0KSB7DQoJCQkJCWlmKHJlc3VsdCl7DQoJCQkJCQljb25zb2xlLmxvZyhyZXN1bHQpOw0KCQkJCQl9DQoJCQkJfSk7DQoJCQl9KTsNCgkJCQ0KCQkJZnVuY3Rpb24gY2FuY2VsRXhwaXJlZENhcnRJdGVtcyh0eXBlKSB7DQoJCQkJdmFyIGdldFVybCA9ICciLlVyaTo6cm9vdCgpLiJpbmRleC5waHA/b3B0aW9uPWNvbV9bW1tjb21wb25lbnRdXV0mdGFzaz1hamF4LmNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMmZm9ybWF0PWpzb24nOw0KCQkJCWlmKHR5cGUgPiAwKXsNCgkJCQkJdmFyIHJlcXVlc3QgPSAndG9rZW49Ii5Kb29tbGFfX181YmEzODUxM181YzRmXzRiMGRfOTM1ZV80OWU5ODZhNmJjZThfX19Qb3dlcjo6Z2V0Rm9ybVRva2VuKCkuIiZ0eXBlPScrdHlwZTsNCgkJCQl9DQoJCQkJcmV0dXJuIGpRdWVyeS5hamF4KHsNCgkJCQkJdHlwZTogJ1BPU1QnLA0KCQkJCQl1cmw6IGdldFVybCwNCgkJCQkJZGF0YVR5cGU6ICdqc29ucCcsDQoJCQkJCWRhdGE6IHJlcXVlc3QsDQoJCQkJCWpzb25wOiAnY2FsbGJhY2snDQoJCQkJfSk7DQoJCQl9Iik7DQoJfQ==', '', '', '', '', '', 'CQkvLyBydW4gc29tZSBob3VzZSBjbGVhbmluZw0KCQlpZiAoc2VsZjo6bG9hZExvY2F0aW9uRGF0YSgpKQ0KCQl7DQoJCQkvLyBydW4gdGhlIGxvY2F0aW9uIGRhdGEgcXVldWUgKHRvIGluc3VyZSBhbGwgY3JvbiBqb2JzIHJ1biB0aW1lbHkpDQoJCQlpZiAoJGRvY3VtZW50IGluc3RhbmNlb2YgSkRvY3VtZW50SHRtbCkNCgkJCXsNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OnRoZVF1ZXVlKCRkb2N1bWVudCk7DQoJCQl9DQoJCX0NCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw0KCQkvLyBjbGVhciB0aGUgY2FydCBpdGVtcyBpZiBleHBpcmVkDQoJCXNlbGY6OmNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KTs=', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Event registration component.', '', '', 'Registry (Roline\'s)', '.git', '', '', 1, '', 'https://www.vdm.io/', '', 'HWgZuTTqfBVha6eZiPtm59rZlYbUddGwhlDZ4oCnvVRn+FEWarAZm4q721Rvwehy', 'https://www.vdm.io/access/', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 2, 492, '', 1, 66), -(22, 1, '', '', '', '', '', '', '', 1, '', 1, '', 1, '', '', '', '', '', '', 1, '', 1, '', '', 1, '', 1, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.3.2', 'Copyright (C) 2015. All Rights Reserved', '2016-05-25 04:13:34', '', '', '', '', '', '', '', '', 1, 1, 'Distributor is a highly advanced sermon distributor that runs on the [Joomla 3.x] (http://www.joomla.org) framework. You can link a shared folder from Dropbox to the component and use Dropbox as your file host, not to mention the advanced auto builder that gives you the ability to simply load sermons to your website by only adding them to Dropbox.', 'llewellyn@vdm.io', 1, '', '', '', '409c36f3-5699-4cd3-a15b-4e495e96f32c', 'images/sermon-distro.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2016-05-25 04:13:21', '', 'Sermon Distributor', 'sermondistributor', '', 4, 'CQlzZWxmOjpsb2FkRHJvcGJveEFqYXgoJGRvY3VtZW50KTs=', '	/**
	* 	Load the Dropbox Ajax to page
	**/
	public static function loadDropboxAjax($document)
	{
		$document->addScriptDeclaration("
			jQuery(window).load(function() {
				checkDropboxListing(3);
			});
			
			function checkDropboxListing(fromview){
				var getUrl = '".Uri::root()."administrator/index.php?option=com_[[[component]]]&task=ajax.checkDropboxListing&format=json';
				if(fromview > 0){
					var request = 'token=".Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken()."&fromview='+fromview;
				}
				return jQuery.ajax({
					type: 'GET',
					url: getUrl,
					dataType: 'jsonp',
					data: request,
					jsonp: 'callback'
				});
			}
		");
	}

	/**
	* 	The dropbox links auto
	**/
	protected static $links_dropbox_auto;
	
	/**
	* 	The dropbox links manual
	**/
	protected static $links_dropbox_manual;

	/**
	* 	The dropbox info File Name
	**/
	protected static $autoprogress = false;

	/**
	* 	The dropbox info File Name
	**/
	protected static $manualprogress = false;

	/**
	* 	The dropbox info File Name
	**/
	protected static $autolisting = false;

	/**
	* 	The dropbox info File Name
	**/
	protected static $manuallisting = false;

	/**
	* 	check Dropbox Local Listing
	**/
	public static function getDownloadLinks(&$sermon)
	{
		$links = array();
		// Get local key
		$localkey = self::getLocalKey();
		// decrypt the urls
		$safe = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 256);
		// internal download url
		$keyCounter = new \stdClass;
		$keyCounter->sermon = $sermon->id;
		if ($sermon->preacher)
		{
			$keyCounter->preacher = $sermon->preacher;
		}
		if ($sermon->series)
		{
			$keyCounter->series = $sermon->series;
		}
		$keyCounter = base64_encode($safe->encryptString(json_encode($keyCounter)));
		$token = Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
		$downloadURL = 'index.php?option=com_[[[component]]]&task=download.file&key='.$keyCounter.'&token='.$token;
		// check if local .htaccess should be set
		$setHtaccess = false;
		$onclick = ' onclick="sermonCounter(\''.$keyCounter.'\',\'FILENAME\');"';
		// check what source of our link
		switch ($sermon->source)
		{
			case 1:
				// local file get local folder and check if outside root (if not then allow direct)
				$localFolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('localfolder', JPATH_ROOT.'/images').'/';
				// should we allow direct downloads
				$allowDirect = false;
				if (2 == $sermon->link_type && strpos($localFolder, JPATH_ROOT) !== false)
				{
					$allowDirect = true;
					$localFolderURL = Uri::root().str_replace(JPATH_ROOT, '', $localFolder);
					// insure no double // is in the URL
					$localFolderURL = str_replace('//', '/', $localFolderURL);
					$localFolderURL = str_replace(':/', '://', $localFolderURL);
				}
				// insure no double // is in the path name
				$localFolder = str_replace('//', '/', $localFolder);
				$localFolder = str_replace(':/', '://', $localFolder);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->local_files))
				{
					foreach($sermon->local_files as $key)
					{
						if (1 == $sermon->link_type || !$allowDirect)
						{
							// get the file name use the same method as the auto
							$filename = self::getDownloadFileName($sermon,$key,'local');
							$lockedFolderPath = base64_encode($safe->encryptString($localFolder.$key));
							$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$lockedFolderPath.'&filename='.$filename);
							$sermon->onclick[$filename] = '';
						}
						elseif (2 == $sermon->link_type && $allowDirect)
						{
							$filename = $key;
							$sermon->download_links[$filename] = $localFolderURL.$key;
							$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							$setHtaccess = true;
						}
					}
				}
				break;
			case 2:
				// Dropbox get global dropbox switch 
				$dropboxButton = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('add_to_dropbox', 1);
				if (1 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->manual_files))
					{
						// manual dropbox
						foreach($sermon->manual_files as $key)
						{
							// get the link
							$dropURL = self::getDropboxLink('manual',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name use the same method as the auto
								$filename = self::getDownloadFileName($sermon,$key,'dropbox_manual');
								$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$dropURL.'&filename='.$filename);
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$filename = str_replace('VDM_pLeK_h0uEr/', '', $key);
								$sermon->download_links[$filename] = rtrim($safe->decryptString(base64_decode($dropURL)));
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $dropboxButton && $dropURL)
							{
								$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString(base64_decode($dropURL))));
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				elseif (2 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->auto_sermons))
					{
						// automatic dropbox
						foreach($sermon->auto_sermons as $filename => $key)
						{
							// get the link
							$dropURL = self::getDropboxLink('auto',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name (use the same method as the auto
								$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$dropURL.'&filename='.$filename);
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$sermon->download_links[$filename] = rtrim($safe->decryptString(base64_decode($dropURL)));
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $dropboxButton && $dropURL)
							{
								$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString(base64_decode($dropURL))));
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				break;
			case 3:
				// url get the file name use the same method as the auto
				$filename = self::getDownloadFileName($sermon,$sermon->url,'url');
				if (1 == $sermon->link_type)
				{
					$lockedURL = base64_encode($safe->encryptString($sermon->url));
					$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$lockedURL.'&filename='.$filename);
					$sermon->onclick[$filename] = '';
				}
				elseif (2 == $sermon->link_type)
				{
					$sermon->download_links[$filename] = $sermon->url;
					$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
				}
				break;
		}
		// remove the values no longer needed
		unset($sermon->local_files);
		unset($sermon->manual_files);
		unset($sermon->auto_sermons);
		unset($sermon->url);
		// should we set the local .htaccess for the download folder
		if ($setHtaccess)
		{
			// TODO we may need to add this latter to enforce download of files.
		}
		return true;
	}
	
	public static function getDropboxLink($type, $return = false, $target = false)
	{
		// make sure all defaults are set
		$found = self::checkDropboxLocalListing($type);
		if ($found)
		{
			switch($return)
			{
				case 1:
					// return a link
					if (isset(self::${'links_dropbox_'.$type}[$target]))
					{
						return self::${'links_dropbox_'.$type}[$target];
					}
					break;
				case 2:
					// return all links
					return self::${'links_dropbox_'.$type};
					break;
				default :
					// just confirm that it is set
					return true;
					break;
			}
		}
		return false;
	}

	public static function countDownload($counter,$filename)
	{
		// Get local key
		$localkey = self::getLocalKey();
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 256);
		$counter = json_decode(rtrim($opener->decryptString(base64_decode($counter))));
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($counter))
		{
			$counter->filename = $filename;
			// set the date object
			$date = Factory::getDate();
			// first check if this file already has statistics
			$db = Factory::getDbo();
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('id','counter')));
			$query->from($db->quoteName('#__[[[component]]]_statistic'));
			$query->where($db->quoteName('sermon') . ' = '. (int) $counter->sermon);
			$query->where($db->quoteName('filename') . ' = '. $db->quote($counter->filename));
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$statistic = $db->loadObject();
				// already has an entry
				$statistic->counter++;
				$statistic->modified = $date->toSql();
				// update the entry
				return $db->updateObject('#__[[[component]]]_statistic', $statistic, 'id');
			}
			else
			{
				// set a new entry
				$counter->counter = 1;
				$counter->published = 1;
				$counter->created = $date->toSql();
				$counter->access = 1;
				$counter->version = 1;
				// set a new entry
				$done = $db->insertObject('#__[[[component]]]_statistic', $counter);
				// if done return last used id
				if ($done)
				{
					$newId =  $db->insertid();
					// make sure the access of asset is set
					return self::setAsset($newId,'statistic');
				}
			}
		}
		return false;
	}
	
	protected static function getDownloadFileName(&$sermon,$file,$type)
	{
		// first get file name and file type
		$file = str_replace('VDM_pLeK_h0uEr/', '', $file);
		$fileType = pathinfo($file, PATHINFO_EXTENSION);
		if ($fileType)
		{
			$file = str_replace('.'.$fileType, '', $file);
		}
		else
		{
			$fileType = 'error';
		}
		// now build download name
		$downloadName = array();
		// build the Download File Name - first add the preacher name if set
		if ($sermon->preacher)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->preacher_name,'U');
		}
		// add the series name if set
		if ($sermon->series)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->series_name,'F');
		}
		// add the category name if set
		if ($sermon->catid && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($sermon->category))
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->category, 'F');
		}
		if ('dropbox_manual' == $type || 'local' == $type)
		{
			// add the main file name
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($file,'F');
		}
		else
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			if ('error' == $fileType || strpos('?', $fileType) !== false || strpos('&', $fileType) !== false )
			{
				$fileType = 'mp3'; // TODO we don't know the url filetype (setting to mp3 but this could be wrong)
			}
		}
		// now build the download file name
		return implode('__', $downloadName).'.'.$fileType;
	}

	/**
	* 	check Dropbox Local Listing (do we have the files)
	**/
	public static function checkDropboxLocalListing($type)
	{
		$filePath = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath($type);
		// get the local links
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::${'links_dropbox_'.$type}))
		{
			// return true we have links loaded
			return true;
		}
		elseif (($jsonlinks = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($filePath, FALSE)) !== FALSE)
		{			
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($jsonlinks))
			{
				// get saved links
				$storeage = json_decode($jsonlinks,true);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($storeage))
				{
					// load the saved links
					self::${'links_dropbox_'.$type} = $storeage;
					return true;
				}
			}
		}
		return false;
	}
	
	protected static function getFilePath($type, $name = 'listing')
	{
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::${$type.$name}))
		{
			// Get local key
			$localkey = self::getLocalKey();
			// set the name
			$fileName = md5($type.$name.$localkey);
			// set file path			
			self::${$type.$name} = JPATH_COMPONENT_SITE.'/helpers/'.$fileName.'.json';
		}
		// return the path
		return self::${$type.$name};
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = false;
	
	public static function getLocalKey()
	{
		if (!self::$localkey)
		{
			// get the main key
			self::$localkey = md5(Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('link_encryption', 'localKey34fdWEkl'));
		}
		return self::$localkey;
	}

	public static function updateDropbox($type = false, $force = false)
	{
		// load the file
		JLoader::import('dropboxupdater', JPATH_COMPONENT_SITE.'/helpers');
		// update types
		$types = array('manual','auto');
		// okay now update this type
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($type) && in_array($type,$types))
		{
			$dropbox = new Dropboxupdater();
			return $dropbox->update($type,$force);
		}
		return false;
	}
	
	public static function getUpdateProgress($type)
	{
		$filePath = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath($type,'progress');
		// get the set progress
		if (($progress = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($filePath, FALSE)) !== FALSE)
		{			
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($progress))
			{
				// get set progress
				$progress = json_decode($progress,true);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($progress))
				{
					// return te progress
					return $progress['report'];
				}
			}
		}
		return 0;
	}
', '', '	/**
	* 	Load the Dropbox Ajax to page
	**/
	public static function loadDropboxAjax($document)
	{
		$document->addScriptDeclaration("
			jQuery(window).load(function() {
				checkDropboxListing(3);
			});
			
			function checkDropboxListing(fromview){
				var getUrl = '".Uri::root()."index.php?option=com_[[[component]]]&task=ajax.checkDropboxListing&format=json';
				if(fromview > 0){
					var request = 'token=".Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken()."&fromview='+fromview;
				}
				return jQuery.ajax({
					type: 'GET',
					url: getUrl,
					dataType: 'jsonp',
					data: request,
					jsonp: 'callback'
				});
			}
		");
	}

	/**
	* 	The dropbox links auto
	**/
	protected static $links_dropbox_auto;
	
	/**
	* 	The dropbox links manual
	**/
	protected static $links_dropbox_manual;

	/**
	* 	The dropbox info File Name
	**/
	protected static $autoprogress = false;

	/**
	* 	The dropbox info File Name
	**/
	protected static $manualprogress = false;

	/**
	* 	The dropbox info File Name
	**/
	protected static $autolisting = false;

	/**
	* 	The dropbox info File Name
	**/
	protected static $manuallisting = false;

	/**
	* 	check Dropbox Local Listing
	**/
	public static function getDownloadLinks(&$sermon)
	{
		$links = array();
		// Get local key
		$localkey = self::getLocalKey();
		// decrypt the urls
		$safe = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 256);
		// internal download url
		$keyCounter = new \stdClass;
		$keyCounter->sermon = $sermon->id;
		if ($sermon->preacher)
		{
			$keyCounter->preacher = $sermon->preacher;
		}
		if ($sermon->series)
		{
			$keyCounter->series = $sermon->series;
		}
		$keyCounter = base64_encode($safe->encryptString(json_encode($keyCounter)));
		$token = Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
		$downloadURL = 'index.php?option=com_[[[component]]]&task=download.file&key='.$keyCounter.'&token='.$token;
		// check if local .htaccess should be set
		$setHtaccess = false;
		$onclick = ' onclick="sermonCounter(\''.$keyCounter.'\',\'FILENAME\');"';
		// check what source of our link
		switch ($sermon->source)
		{
			case 1:
				// local file get local folder and check if outside root (if not then allow direct)
				$localFolder = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('localfolder', JPATH_ROOT.'/images').'/';
				// should we allow direct downloads
				$allowDirect = false;
				if (2 == $sermon->link_type && strpos($localFolder, JPATH_ROOT) !== false)
				{
					$allowDirect = true;
					$localFolderURL = Uri::root().str_replace(JPATH_ROOT, '', $localFolder);
					// insure no double // is in the URL
					$localFolderURL = str_replace('//', '/', $localFolderURL);
					$localFolderURL = str_replace(':/', '://', $localFolderURL);
				}
				// insure no double // is in the path name
				$localFolder = str_replace('//', '/', $localFolder);
				$localFolder = str_replace(':/', '://', $localFolder);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->local_files))
				{
					foreach($sermon->local_files as $key)
					{
						if (1 == $sermon->link_type || !$allowDirect)
						{
							// get the file name use the same method as the auto
							$filename = self::getDownloadFileName($sermon,$key,'local');
							$lockedFolderPath = base64_encode($safe->encryptString($localFolder.$key));
							$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$lockedFolderPath.'&filename='.$filename);
							$sermon->onclick[$filename] = '';
						}
						elseif (2 == $sermon->link_type && $allowDirect)
						{
							$filename = $key;
							$sermon->download_links[$filename] = $localFolderURL.$key;
							$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							$setHtaccess = true;
						}
					}
				}
				break;
			case 2:
				// Dropbox get global dropbox switch 
				$dropboxButton = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('add_to_dropbox', 1);
				if (1 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->manual_files))
					{
						// manual dropbox
						foreach($sermon->manual_files as $key)
						{
							// get the link
							$dropURL = self::getDropboxLink('manual',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name use the same method as the auto
								$filename = self::getDownloadFileName($sermon,$key,'dropbox_manual');
								$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$dropURL.'&filename='.$filename);
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$filename = str_replace('VDM_pLeK_h0uEr/', '', $key);
								$sermon->download_links[$filename] = rtrim($safe->decryptString(base64_decode($dropURL)));
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $dropboxButton && $dropURL)
							{
								$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString(base64_decode($dropURL))));
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				elseif (2 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->auto_sermons))
					{
						// automatic dropbox
						foreach($sermon->auto_sermons as $filename => $key)
						{
							// get the link
							$dropURL = self::getDropboxLink('auto',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name (use the same method as the auto
								$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$dropURL.'&filename='.$filename);
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$sermon->download_links[$filename] = rtrim($safe->decryptString(base64_decode($dropURL)));
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $dropboxButton && $dropURL)
							{
								$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString(base64_decode($dropURL))));
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				break;
			case 3:
				// url get the file name use the same method as the auto
				$filename = self::getDownloadFileName($sermon,$sermon->url,'url');
				if (1 == $sermon->link_type)
				{
					$lockedURL = base64_encode($safe->encryptString($sermon->url));
					$sermon->download_links[$filename] = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_($downloadURL.'&link='.$lockedURL.'&filename='.$filename);
					$sermon->onclick[$filename] = '';
				}
				elseif (2 == $sermon->link_type)
				{
					$sermon->download_links[$filename] = $sermon->url;
					$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
				}
				break;
		}
		// remove the values no longer needed
		unset($sermon->local_files);
		unset($sermon->manual_files);
		unset($sermon->auto_sermons);
		unset($sermon->url);
		// should we set the local .htaccess for the download folder
		if ($setHtaccess)
		{
			// TODO we may need to add this latter to enforce download of files.
		}
		return true;
	}
	
	public static function getDropboxLink($type, $return = false, $target = false)
	{
		// make sure all defaults are set
		$found = self::checkDropboxLocalListing($type);
		if ($found)
		{
			switch($return)
			{
				case 1:
					// return a link
					if (isset(self::${'links_dropbox_'.$type}[$target]))
					{
						return self::${'links_dropbox_'.$type}[$target];
					}
					break;
				case 2:
					// return all links
					return self::${'links_dropbox_'.$type};
					break;
				default :
					// just confirm that it is set
					return true;
					break;
			}
		}
		return false;
	}

	public static function countDownload($counter,$filename)
	{
		// Get local key
		$localkey = self::getLocalKey();
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 256);
		$counter = json_decode(rtrim($opener->decryptString(base64_decode($counter))));
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($counter))
		{
			$counter->filename = $filename;
			// set the date object
			$date = Factory::getDate();
			// first check if this file already has statistics
			$db = Factory::getDbo();
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('id','counter')));
			$query->from($db->quoteName('#__[[[component]]]_statistic'));
			$query->where($db->quoteName('sermon') . ' = '. (int) $counter->sermon);
			$query->where($db->quoteName('filename') . ' = '. $db->quote($counter->filename));
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$statistic = $db->loadObject();
				// already has an entry
				$statistic->counter++;
				$statistic->modified = $date->toSql();
				// update the entry
				return $db->updateObject('#__[[[component]]]_statistic', $statistic, 'id');
			}
			else
			{
				// set a new entry
				$counter->counter = 1;
				$counter->published = 1;
				$counter->created = $date->toSql();
				$counter->access = 1;
				$counter->version = 1;
				// set a new entry
				$done = $db->insertObject('#__[[[component]]]_statistic', $counter);
				// if done return last used id
				if ($done)
				{
					$newId =  $db->insertid();
					// make sure the access of asset is set
					return self::setAsset($newId,'statistic');
				}
			}
		}
		return false;
	}
	
	protected static function getDownloadFileName(&$sermon,$file,$type)
	{
		// first get file name and file type
		$file = str_replace('VDM_pLeK_h0uEr/', '', $file);
		$fileType = pathinfo($file, PATHINFO_EXTENSION);
		if ($fileType)
		{
			$file = str_replace('.'.$fileType, '', $file);
		}
		else
		{
			$fileType = 'error';
		}
		// now build download name
		$downloadName = array();
		// build the Download File Name - first add the preacher name if set
		if ($sermon->preacher)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->preacher_name,'U');
		}
		// add the series name if set
		if ($sermon->series)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->series_name,'F');
		}
		// add the category name if set
		if ($sermon->catid && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($sermon->category))
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->category, 'F');
		}
		if ('dropbox_manual' == $type || 'local' == $type)
		{
			// add the main file name
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($file,'F');
		}
		else
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			if ('error' == $fileType || strpos('?', $fileType) !== false || strpos('&', $fileType) !== false )
			{
				$fileType = 'mp3'; // TODO we don't know the url filetype (setting to mp3 but this could be wrong)
			}
		}
		// now build the download file name
		return implode('__', $downloadName).'.'.$fileType;
	}

	/**
	* 	check Dropbox Local Listing (do we have the files)
	**/
	public static function checkDropboxLocalListing($type)
	{
		$filePath = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath($type);
		// get the local links
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::${'links_dropbox_'.$type}))
		{
			// return true we have links loaded
			return true;
		}
		elseif (($jsonlinks = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($filePath, FALSE)) !== FALSE)
		{			
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($jsonlinks))
			{
				// get saved links
				$storeage = json_decode($jsonlinks,true);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($storeage))
				{
					// load the saved links
					self::${'links_dropbox_'.$type} = $storeage;
					return true;
				}
			}
		}
		return false;
	}
	
	protected static function getFilePath($type, $name = 'listing')
	{
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::${$type.$name}))
		{
			// Get local key
			$localkey = self::getLocalKey();
			// set the name
			$fileName = md5($type.$name.$localkey);
			// set file path			
			self::${$type.$name} = JPATH_COMPONENT_SITE.'/helpers/'.$fileName.'.json';
		}
		// return the path
		return self::${$type.$name};
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = false;
	
	public static function getLocalKey()
	{
		if (!self::$localkey)
		{
			// get the main key
			self::$localkey = md5(Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('link_encryption', 'localKey34fdWEkl'));
		}
		return self::$localkey;
	}

	public static function updateDropbox($type = false, $force = false)
	{
		// load the file
		JLoader::import('dropboxupdater', JPATH_COMPONENT_SITE.'/helpers');
		// update types
		$types = array('manual','auto');
		// okay now update this type
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($type) && in_array($type,$types))
		{
			$dropbox = new Dropboxupdater();
			return $dropbox->update($type,$force);
		}
		return false;
	}', '', '', '', '', '', 'CQlzZWxmOjpsb2FkRHJvcGJveEFqYXgoJGRvY3VtZW50KTs=', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdIChodHRwczovL3Jhdy5naXRodWJ1c2VyY29udGVudC5jb20vU2VybW9uRGlzdHJpYnV0b3IvSm9vbWxhLTMtQ29tcG9uZW50L21hc3Rlci9hZG1pbi9hc3NldHMvaW1hZ2VzL2NvbXBvbmVudC0zMDAuanBnICJUaGUgIyMjQ29tcG9uZW50X25hbWUjIyMiKQ0KDQojIyNERVNDUklQVElPTiMjIw0KDQpUaGUgYmVzdCB3YXkgdG8gc2VlIGFsbCB5b3VyIG9wdGlvbnMgaXMgdG8gaW5zdGFsbCB0aGlzIGNvbXBvbmVudCBvbiB5b3UgSm9vbWxhIHdlYnNpdGUgYW5kIHRlc3QgYWxsIGZlYXR1cmVzIHlvdXJzZWxmLiBIZXJlIGlzIGEgW2RpcmVjdCBkb3dubG9hZCBsaW5rXSAoaHR0cHM6Ly9naXRodWIuY29tL1Nlcm1vbkRpc3RyaWJ1dG9yL0pvb21sYS0zLUNvbXBvbmVudC9hcmNoaXZlL21hc3Rlci56aXApDQoNCiAqKklmIHlvdSBsaWtlIG91ciBjb21wb25lbnQgcGxlYXNlIHJhdGUgaXQgb24gdGhlIFtKb29tbGEgSW5kZXhdIChodHRwOi8vZXh0ZW5zaW9ucy5qb29tbGEub3JnL2V4dGVuc2lvbnMvZXh0ZW5zaW9uL2xpdmluZy9yZWxpZ2lvbi9zZXJtb24tZGlzdHJpYnV0b3IpKioNCg0KIyMjIEV4YW1wbGUgV2Vic2l0ZSwgVGhhdCBIYXMgT3ZlciA2MDAwIEF1ZGlvIEZpbGVzDQoNCltMb3VkVm9pY2Uub3JnXSAoaHR0cDovL3d3dy5sb3Vkdm9pY2Uub3JnKQ0KDQojIyMgU29tZSBWaWRlbyBEZW1vbnN0cmF0aW9ucw0KDQorIFtTZXR1cCBvdmVydmlld10gKGh0dHBzOi8veW91dHUuYmUveU1QcDFDcDNXXzA/dD0yMG04cykNCisgW1NldHVwIERyb3Bib3hdIChodHRwczovL3lvdXR1LmJlL2J0cEtGRGswLWRJKQ0KDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10gKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXSAobWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10gKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCg0KIyMgQnVpbGQgVGltZSA6aG91cmdsYXNzOg0KDQoqKiMjI3RvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI3RvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKiAoYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzYXZlZCAtDQpkdWUgdG8gW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0gKGh0dHBzOi8vd3d3LnZkbS5pby9qb29tbGEtY29tcG9uZW50LWJ1aWxkZXIpKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdIChodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0gKG1haWx0bzpqb29tbGFAdmRtLmlvKQ==', '', '', 'A sermon distributor that links to Dropbox.', '', '', 'SermonDistributor CB', '', '', '', '', 'https://www.vdm.io/updates/sermondistributor_update_server.xml', 'https://www.vdm.io/', '', 'oz68X4QEkJLSanYLWykDILqykGlGZ/7ZfYrbysptSlA=', '', '', 2, 1, '', 1, 52), -(23, 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, '', '', '', '', '', '', 1, '', 1, '', '', 1, '{}', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.0', 'Copyright (C) 2015. All Rights Reserved', '2016-06-28 05:19:42', '', '7ciMzl2FIRZhkqI3MKfNRBqkUFXJiJZYyFCv8JjP32w=', '13ZRKOEE+tbXzZsi5sW0onLPXpxNcZDkm/h8y/aIeJQ=', '', 'iyhjiaUATJV6Eb/6DmVfzoauOOgZ2KePKC4IW2tFF1Y=', '', '', '', 1, '', 'The internal Joomla API for currency conversion per/user location.', 'joomla@vdm.io', '', 'http://vdm.bz/get-location-data-key', 'oQvbVMpd0fOhPxFeJB8DYgd6WWK00uEEHYPl9Ew0KZ5xvyit+X8iFY6Owy+9bC097N6k4CYNfTNHJQ21FzuRsg==', '', '121fc9c5-efcc-4473-9b9f-ca2bea65ee13', 'images/vdm/LOCATION500.jpg', '', 'https://github.com/vdm-io/JCB-Packages/raw/master/JCB_locationData.zip', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2021-03-08 03:11:50', 1, 'Currency Method', 'currencymethod', '', 4, 'CQlzZWxmOjp0aGVRdWV1ZSgkZG9jdW1lbnQpOw==', 'CS8qKg0KCSogCVRoZSB1c2VyIG5vdGljZSBpbmZvIEZpbGUgTmFtZQ0KCSoqLw0KCXByb3RlY3RlZCBzdGF0aWMgJHVzZXJub3RpY2UgPSBmYWxzZTsNCg0KCS8qKg0KCSogCUxvYWQgdGhlIFVwZGF0ZSBRdWV1ZSBBamF4IHRvIHBhZ2UNCgkqKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIHRoZVF1ZXVlKCRkb2N1bWVudCwgJGZvcmNlID0gZmFsc2UpDQoJew0KCQkvLyBzZXQgdGhlIHRpbWUNCgkJJG5vdyA9IEZhY3Rvcnk6OmdldERhdGUoKS0+dG9Vbml4KCk7DQoJCS8vIHNob3VsZCBhbiB1cGRhdGUgYmUgZm9yY2VkDQoJCSR1cGRhdGUgPSAxOyAvLyA8LS0gZG9u4oCZdCBmb3JjZSB1cGRhdGUNCgkJaWYgKCRmb3JjZSkNCgkJew0KCQkJJHVwZGF0ZSA9IDI7IC8vIDwtLSBmb3JjZSB1cGRhdGUNCgkJfQ0KCQkkZG9jdW1lbnQtPmFkZFNjcmlwdERlY2xhcmF0aW9uKCINCgkJCWpRdWVyeSh3aW5kb3cpLmxvYWQoZnVuY3Rpb24oKSB7DQoJCQkJdGhlUXVldWUoKTsNCgkJCX0pOw0KCQkJZnVuY3Rpb24gdGhlUXVldWUoKSB7DQoJCQkJdmFyIGdldFVybCA9ICciLlVyaTo6cm9vdCgpLiJhZG1pbmlzdHJhdG9yL2luZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ0YXNrPWFqYXgudGhlUXVldWUmZm9ybWF0PWpzb24nOw0KCQkJCXZhciByZXF1ZXN0ID0gJ3Rva2VuPSIuSm9vbWxhX19fNWJhMzg1MTNfNWM0Zl80YjBkXzkzNWVfNDllOTg2YTZiY2U4X19fUG93ZXI6OmdldEZvcm1Ub2tlbigpLiImdGltZT0iLiRub3cuIiZmb3JjZT0iLiR1cGRhdGUuIic7DQoJCQkJcmV0dXJuIGpRdWVyeS5hamF4KHsNCgkJCQkJdHlwZTogJ0dFVCcsDQoJCQkJCXVybDogZ2V0VXJsLA0KCQkJCQlkYXRhVHlwZTogJ2pzb25wJywNCgkJCQkJZGF0YTogcmVxdWVzdCwNCgkJCQkJanNvbnA6ICdjYWxsYmFjaycNCgkJCQl9KTsNCgkJCX0NCgkJIik7DQoJfQ==', '	/**
	* 	The component params
	**/
	protected static $params;

	/**
	* 	The notice switch if curl not found
	**/
	protected static $curlErrorLoaded = false;

	/**
	* 	Load the data for IP and Currency 
	**/
	public static function get[[[Component]]]($ip, $protocol, $key, $base, $mode, $string, $value)
	{
		// we still need to add key check
		// if no ip detected try getting the ip or return the default
		if (!$ip)
		{
			if ($found = self::getIP())
			{
				// load the results found
				$ip = $found['ip'];
				$protocol = $found['protocol'];
			}
			else
			{
				// set the default
				$ip = '0.0.0.0';
				$protocol = 1;
			}
		}
		// check that we have protocol
		if (!$protocol)
		{
			if (!$protocol = self::isValidIP($ip, $strict = true))
			{
				// set the default
				$ip = '0.0.0.0';
				$protocol = 1;
			}
		}
		return self::get[[[Component]]]Factory($ip, $protocol)->getInfo((int) $mode, (int) $string, (float) $value, $base);
	}

	public static $force[[[Component]]]Table = true; 

	public static $defaultComponent = "com_[[[component]]]"; 

	protected static $[[[component]]]Factory = array(); 
	
	protected static function get[[[Component]]]Factory($ip, $protocol)
	{
		$getter = md5($ip);
		if (!isset(self::$[[[component]]]Factory[$getter]))
		{
			// make sure to include the factory file
			include_once '[[[component]]]factory.php';
			// first load the factory
			self::$[[[component]]]Factory[$getter] = new [[[Component]]]Factory($ip, $protocol, self::$defaultComponent, self::$force[[[Component]]]Table);
		}
		return self::$[[[component]]]Factory[$getter];
	}

	protected static $exchangeRates = array(); 

	/**
	 * returns ExchangeRate from #__###component###_exchange_rate database
	 *
	 * @return string
	 */
	public static function getExchangeRate($from, $fromValue, $to = 'USD', $retry = true)
	{
		// only continue if from and to is set
		if($from && $to)
		{
			if (!isset(self::$exchangeRates[$from.$to]))
			{
				if ($from == $to)
				{
					// it is the same currency so set all one on one
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_ID']		= strtolower($from).'-'.strtolower($from);
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_NAME']		= $from.$from;
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE']		= 1.00;
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_ASK']		= 1.00;
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_BID']		= 1.00;
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_DATE']		= 0;
					// now set the money
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_MONEY']		= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE'], $from);
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_ASK_MONEY']	= self::$exchangeRates[$from.$to]['EXCHANGE_RATE_MONEY'];
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_BID_MONEY']	= self::$exchangeRates[$from.$to]['EXCHANGE_RATE_MONEY'];
					if (!$fromValue)
					{
						$fromValue = 1.00;
					}
					// set the convertion
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM']		= (float) $fromValue;
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM_MONEY']	= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM'], $from);
					// calculate the new value
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_TO']		= (float) $fromValue;
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_TO_MONEY']	= self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM_MONEY'];
					
					return self::$exchangeRates[$from.$to];		
				}
				// the get values
				$get = array(
					'EXCHANGE_RATE_ID'	=> 'a.alias', 
					'EXCHANGE_RATE_NAME'	=> 'a.name', 
					'EXCHANGE_RATE'		=> 'a.rate',
					'EXCHANGE_RATE_ASK'	=> 'a.ask',
					'EXCHANGE_RATE_BID'	=> 'a.bid',
					'EXCHANGE_RATE_DATE'	=> 'a.date_rate');
				// Get a db connection.
				$db = Factory::getDbo();
				// Create a new query object.
				$query = $db->getQuery(true);
				$query
					->select($db->quoteName(array_values($get),array_keys($get)))
					->from($db->quoteName('#__###component###_exchange_rate', 'a'))
					->where($db->quoteName('a.from') . ' = '. $db->quote($from))
					->where($db->quoteName('a.to') . ' = '. $db->quote($to))
					->where($db->quoteName('a.published') . ' = 1');
				// Reset the query using our newly populated query object.
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					$rates = $db->loadAssoc();
					// load in to active data
					self::$exchangeRates[$from.$to] = array();
					foreach ($rates as $key => $value)
					{
						self::$exchangeRates[$from.$to][$key] = $value;
					}
					// now set the money
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_MONEY']		= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE'], $to);
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_ASK_MONEY']	= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE_ASK'], $to);
					self::$exchangeRates[$from.$to]['EXCHANGE_RATE_BID_MONEY']	= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE_BID'], $to);
				}
				elseif ($retry)
				{
					// if not found try again with default
					$default = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams(self::$defaultComponent)->get('currency', 'USD');
					return self::getExchangeRate($from, $fromValue, $default, false);
				}
			}
			// confirm that it was actually set
			if (isset(self::$exchangeRates[$from.$to]))
			{
				// check if a from value is set
				if (!$fromValue)
				{
					$fromValue = 1.00;
				}
				// set the convertion
				self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM']			= (float) $fromValue;
				self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM_MONEY']		= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM'], $from);
				// calculate the new value
				self::$exchangeRates[$from.$to]['EXCHANGE_RATE_TO']			= bcmul(self::$exchangeRates[$from.$to]['EXCHANGE_RATE_FROM'], self::$exchangeRates[$from.$to]['EXCHANGE_RATE'], 4);
				self::$exchangeRates[$from.$to]['EXCHANGE_RATE_TO_MONEY']		= self::makeMoney(self::$exchangeRates[$from.$to]['EXCHANGE_RATE_TO'], $to);
				// load the currency pair name
				self::$exchangeRates[$from.$to]['CURRENCY_PAIR']				= $from.$to;
				// load the currency names
				self::$exchangeRates[$from.$to]['FROM_CURRENCY_CODE_THREE']			= $from;
				self::$exchangeRates[$from.$to]['TO_CURRENCY_CODE_THREE']			= $to;
				// return the exchange rate
				return self::$exchangeRates[$from.$to];
			}
		}
		return false;
	}

	/**
	*  get ip address
	**/
	public static function getIP($plusProtocol = true, $useProxy = 'global')
	{
		// check if we should use proxy
		$useProxy = ($useProxy == 'global') ? Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('use_proxy', true) :  ( ($useProxy) ? true : false);
		// get the input values
		$server = Factory::getApplication()->input->server;
		// get remote address (most secure IP since it is set by the server)
		$defaultIP = $server->get('REMOTE_ADDR', false, 'CMD');
		if ($useProxy)
		{
			// proxy options array
			$proxiesDefault = array(
				'HTTP_X_REAL_IP',
				'HTTP_CLIENT_IP',
				'HTTP_TRUE_CLIENT_IP',
				'HTTP_X_FWD_IP_ADDR',
				'HTTP_X_FORWARDED_FOR',
				'HTTP_X_FORWARDED',
				'HTTP_FORWARDED_FOR',
				'HTTP_FORWARDED',
				'HTTP_VIA',
				'HTTP_X_COMING_FROM',
				'HTTP_COMING_FROM'
			);
			$proxies = (array) Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('proxies', $proxiesDefault);

			foreach ($proxies as $proxy)
			{
				if ($ip =  $server->get($proxy, false, 'STRING'))
				{
					// let's see if there are multiple IPs
					if (strpos($ip, ',') !== false)
					{
						$tmp = explode(', ', $ip);
						// grab the first IP
						$ip = reset($tmp);
						// no longer need this
						unset($tmp);
					}
					// check if valid IP in strict mode
					if ($protocol = self::isValidIP($ip, true))
					{
						// return proxy IP (not that secure)
						if ($plusProtocol)
						{
							return array('ip' => $ip, 'protocol' => $protocol);
						}
						else
						{
							return $ip;
						}
					}
				}
			}
		}
		// check if vailid IP
		if ($protocol = self::isValidIP($defaultIP, true))
		{
			// return default IP (most secure)
			if ($plusProtocol)
			{
				return  array('ip' => $defaultIP, 'protocol' => $protocol);
			}
			else
			{
				return $defaultIP;
			}
		}
		return false;
	}
[CUSTOMCODE=isValidIP]
	/**
	* @param float $amount
	**/
	public static function addCurrency($amount, $codethree = false)
	{
		return self::makeMoney($amount, $codethree);
	}

	protected static $currencyDetails = array();

	public static function getCurrencyDetails($codethree = false)
	{
		// check if currency codethree is set
		if (!$codethree)
		{
			// get the main currency
			$codethree = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams(self::$defaultComponent)->get('currency', 'USD');
		}
		// return cached data if set
		if ($codethree && !isset(self::$currencyDetails[$codethree]))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			if (is_numeric($codethree))
			{
				$query->where($db->quoteName('a.id') . ' = '. (int) $codethree);
			}
			elseif (strlen($codethree) == 3)
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote($codethree));
			}
			else
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote('NONE'));
			}
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				self::$currencyDetails[$codethree] = $db->loadObject();
			}
		}
		// make sure it has been set
		if (isset(self::$currencyDetails[$codethree]))
		{
			return self::$currencyDetails[$codethree];
		}
		return false;
	}
[CUSTOMCODE=makeMoney] 
[CUSTOMCODE=niceFancyDate] 
[CUSTOMCODE=getFilePath]
[CUSTOMCODE=getFileContents]
 [CUSTOMCODE=writeFile]', 'CS8qKg0KCSogCUxvYWQgdGhlIFVwZGF0ZSBRdWV1ZSBBamF4IHRvIHBhZ2UNCgkqKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIHRoZVF1ZXVlKCRkb2N1bWVudCwgJGZvcmNlID0gZmFsc2UpDQoJew0KCQkvLyBzZXQgdGhlIHRpbWUNCgkJJG5vdyA9IEZhY3Rvcnk6OmdldERhdGUoKS0+dG9Vbml4KCk7DQoJCS8vIHNob3VsZCBhbiB1cGRhdGUgYmUgZm9yY2VkDQoJCSR1cGRhdGUgPSAxOyAvLyA8LS0gZG9u4oCZdCBmb3JjZSB1cGRhdGUNCgkJaWYgKCRmb3JjZSkNCgkJew0KCQkJJHVwZGF0ZSA9IDI7IC8vIDwtLSBmb3JjZSB1cGRhdGUNCgkJfQ0KCQkkZG9jdW1lbnQtPmFkZFNjcmlwdERlY2xhcmF0aW9uKCINCgkJCWpRdWVyeSh3aW5kb3cpLmxvYWQoZnVuY3Rpb24oKSB7DQoJCQkJdGhlUXVldWUoKTsNCgkJCX0pOw0KCQkJZnVuY3Rpb24gdGhlUXVldWUoKSB7DQoJCQkJdmFyIGdldFVybCA9ICciLlVyaTo6cm9vdCgpLiJpbmRleC5waHA/b3B0aW9uPWNvbV9bW1tjb21wb25lbnRdXV0mdGFzaz1hamF4LnRoZVF1ZXVlJmZvcm1hdD1qc29uJzsNCgkJCQl2YXIgcmVxdWVzdCA9ICd0b2tlbj0iLkpvb21sYV9fXzViYTM4NTEzXzVjNGZfNGIwZF85MzVlXzQ5ZTk4NmE2YmNlOF9fX1Bvd2VyOjpnZXRGb3JtVG9rZW4oKS4iJnRpbWU9Ii4kbm93LiImZm9yY2U9Ii4kdXBkYXRlLiInOw0KCQkJCXJldHVybiBqUXVlcnkuYWpheCh7DQoJCQkJCXR5cGU6ICdHRVQnLA0KCQkJCQl1cmw6IGdldFVybCwNCgkJCQkJZGF0YVR5cGU6ICdqc29ucCcsDQoJCQkJCWRhdGE6IHJlcXVlc3QsDQoJCQkJCWpzb25wOiAnY2FsbGJhY2snDQoJCQkJfSk7DQoJCQl9DQoJCSIpOw0KCX0=', '', '', '', '', '', 'CQlzZWxmOjp0aGVRdWV1ZSgkZG9jdW1lbnQpOw==', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS92ZG0taW8vSm9vbWxhLUN1cnJlbmN5LU1ldGhvZC9tYXN0ZXIvYWRtaW4vYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KV2hhdCBpcyB0aGlzPw0KLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQoqIFRoaXMgaXMgYSAjIyNDb21wb25lbnRfbmFtZSMjIyBBUEkgQ29tcG9uZW50IGZvciBKb29tbGEhIHZlcnNpb24gMy54DQoqIERldGFpbGVkIGNoYW5nZXMgaW4gdGhlIFtDaGFuZ2Vsb2ddKGh0dHBzOi8vZ2l0aHViLmNvbS92ZG0taW8vSm9vbWxhLUxvY2F0aW9uLURhdGEvY29tbWl0cy9tYXN0ZXIpDQoNCldoYXQgaXMgIyMjQ29tcG9uZW50X25hbWUjIyMgQVBJPw0KLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQoqICMjI0NvbXBvbmVudF9uYW1lIyMjISBpcyBhICoqSVAgdG8gQ291bnRyeSwgQ3VycmVuY3kgYW5kIEV4Y2hhbmdlIFJhdGUgQ29tcG9uZW50KiogKEFwcGxpY2F0aW9uIFByb2dyYW1tYWJsZSBJbnRlcmZhY2UpIHdoaWNoIGVuYWJsZXMgeW91IHRvIHJldHJpZXZlIHRoZSBjb3VudHJ5LCBjdXJyZW5jeSBhbmQgZXhjaGFuZ2UgcmF0ZSBkYXRhIGZyb20gYW55IGdpdmVuIElQLg0KKiBJdCdzIGEgKipmcmVlIGFuZCBPcGVuU291cmNlIHNvZnR3YXJlKiosIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSB2ZXJzaW9uIDIgb3IgbGF0ZXINCiogVGhpcyBpcyBhIHNpbXBsZSBhbmQgcG93ZXJmdWwgYWRkb24gdG8gSm9vbWxhIGFuZCBpdCByZXF1aXJlcyBhIHNlcnZlciB3aXRoIFBIUCBhbmQgTXlTUUwgd2l0aCB0aGUgSm9vbWxhIDMueCBmcmFtZXdvcmsgaW5zdGFsbGVkIHRvIHJ1biBpdC4NCk1vcmUgW2RldGFpbHMgaGVyZSBhYm91dCBKb29tbGFdKGh0dHA6Ly93d3cuam9vbWxhLm9yZy9hYm91dC1qb29tbGEuaHRtbCkNCg0KQnVpbGQgRGV0YWlscw0KLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQpJcyAjIyNDb21wb25lbnRfbmFtZSMjIyBmb3IgeW91Pw0KLS0tLS0tLS0tLS0tLS0tLS0tLS0tDQoqIElmIHlvdXIgcnVubmluZyBhIEpvb21sYSAzIFdlYnNpdGUgYW5kIHdvdWxkIGxpa2UgeW91ciBvd24gSVAgdG8gQ291bnRyeSBhbmQgQ3VycmVuY3kgRXhjaGFuZ2UgUmF0ZSBBUEkuDQoNCkxlYXJuICMjI0NvbXBvbmVudF9uYW1lIyMjIEFQSSENCi0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KKiBtb3JlIGluZm8gY29taW5nIHNvb24uLi4NCg0KV2hlcmUgZG8gd2UgZ2V0IElQIFVwZGF0ZXM/DQotLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiogVGhlIGRhdGFiYXNlIHVzZWQgdG8gdXBkYXRlIHRoZSBJUCB0YWJsZXMgaXMgcHJvdmlkZWQgYnkgW3NvZnR3YXJlNzcubmV0XShodHRwOi8vc29mdHdhcmU3Ny5uZXQvZ2VvLWlwLykgYXMgW2RvbmF0aW9ud2FyZV0oaHR0cDovL3NvZnR3YXJlNzcubmV0L2dlby1pcC8/bGljZW5zZSkuIFRoZXkgbmVlZCB5b3VyIHN1cHBvcnQhIFBsZWFzZSBtYWtlIGEgW2RvbmF0aW9uIHZpYSBwYXlwYWxdKGh0dHBzOi8vd3d3LnBheXBhbC5jb20vY2dpLWJpbi93ZWJzY3I/Y21kPV9zLXhjbGljayZob3N0ZWRfYnV0dG9uX2lkPTNIS004TjVYWFVIVjYpIG5vdyENCg0KV2hlcmUgZG8gd2UgZ2V0IEV4Y2hhbmdlIFJhdGUgVXBkYXRlcz8NCi0tLS0tLS0tLS0tLS0tLS0tLS0tDQoqIFsxRm9yZ2VdKGh0dHBzOi8vMWZvcmdlLmNvbS8pIGNhbiBiZSB1c2VkIHRvIHVwZGF0ZSB0aGUgZXhjaGFuZ2UgcmF0ZXMuIFlvdSB3aWxsIG5lZWQgYSBbZnJlZSBBUEkga2V5XShodHRwczovLzFmb3JnZS5jb20vcmVnaXN0ZXIpLg0KKiBbT3BlbiBFeGNoYW5nZSBSYXRlc10oaHR0cHM6Ly9vcGVuZXhjaGFuZ2VyYXRlcy5vcmcvKSBjYW4gYmUgdXNlZCB0byB1cGRhdGUgdGhlIGV4Y2hhbmdlIHJhdGVzLiBZb3Ugd2lsbCBuZWVkIGEgW2ZyZWUgQVBJIGtleV0oaHR0cHM6Ly9vcGVuZXhjaGFuZ2VyYXRlcy5vcmcvc2lnbnVwL2ZyZWUpLg0KKiBbRXhjaGFuZ2UgUmF0ZSBBUEldKGh0dHBzOi8vd3d3LmV4Y2hhbmdlcmF0ZS1hcGkuY29tKSBjYW4gYmUgdXNlZCB0byB1cGRhdGUgdGhlIGV4Y2hhbmdlIHJhdGVzLiBZb3Ugd2lsbCBuZWVkIGEgW2ZyZWUgQVBJIGtleV0oaHR0cHM6Ly93d3cuZXhjaGFuZ2VyYXRlLWFwaS5jb20vYXBwL3NpZ251cCkuDQoqIFtGaXhlcl0oaHR0cHM6Ly9maXhlci5pby8pIGNhbiBiZSB1c2VkIHRvIHVwZGF0ZSB0aGUgZXhjaGFuZ2UgcmF0ZXMuIFlvdSB3aWxsIG5lZWQgYSBbZnJlZSBBUEkga2V5XShodHRwczovL2ZpeGVyLmlvL3NpZ251cC9mcmVlKS4NCiogW0N1cnJlbmN5IExheWVyXShodHRwczovL2N1cnJlbmN5bGF5ZXIuY29tLykgY2FuIGJlIHVzZWQgdG8gdXBkYXRlIHRoZSBleGNoYW5nZSByYXRlcy4gWW91IHdpbGwgbmVlZCBhIFtmcmVlIEFQSSBrZXldKGh0dHBzOi8vY3VycmVuY3lsYXllci5jb20vc2lnbnVwP3BsYW49MSkuDQoqIFlvdSB0ZWxsIHVzIHdobyB3ZSBzaG91bGQgYWxzbyBhZGQuLi4uDQoNClVwZGF0ZXMgYXJlIGZyZWUhDQotLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiogQWx3YXlzIHVzZSB0aGUgW2xhdGVzdCB2ZXJzaW9uXShodHRwczovL2dpdGh1Yi5jb20vdmRtLWlvL0pvb21sYS1DdXJyZW5jeS1NZXRob2QvemlwYmFsbC9tYXN0ZXIvKS4NCg0KV2hlcmUgY2FuIHlvdSBnZXQgc3VwcG9ydCBhbmQgaGVscD8NCi0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KKiBbTmVlZCBIZWxwP10oaHR0cHM6Ly9naXRodWIuY29tL3ZkbS1pby9Kb29tbGEtQ3VycmVuY3ktTWV0aG9kL2lzc3VlcykuDQoqIFJlcG9ydCBhbiBbaXNzdWVdKGh0dHBzOi8vZ2l0aHViLmNvbS92ZG0taW8vSm9vbWxhLUN1cnJlbmN5LU1ldGhvZC9pc3N1ZXMpLg0KDQpDb3B5cmlnaHQ6DQotLS0tLS0tLS0tLS0tLS0tLS0tLS0NCiogQ29weXJpZ2h0IChDKSBbVmFzdCBEZXZlbG9wbWVudCBNZXRob2RdKGh0dHBzOi8vd3d3LnZkbS5pbykuIEFsbCByaWdodHMgcmVzZXJ2ZWQuIA0KKiBEaXN0cmlidXRlZCB1bmRlciB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgdmVyc2lvbiAyIG9yIGxhdGVyDQoqIFNlZSBbTGljZW5zZSBkZXRhaWxzXShodHRwczovL3d3dy52ZG0uaW8vZ251LWdwbCkNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cudmRtLmlvL2pvb21sYS1jb21wb25lbnQtYnVpbGRlcikuDQo+IERldmVsb3BlZCBieSBbTGxld2VsbHluIHZhbiBkZXIgTWVyd2VdKGh0dHA6Ly9jYXJlZXJzLnN0YWNrb3ZlcmZsb3cuY29tL2xsZXdlbGx5bikNCg0KIyMgRG9uYXRpb25zDQoNCkNvbWUgb24gYnV5IG1lIGEgY29mZmVlIDopDQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKQ==', '', '', 'The internal Joomla API for currency conversion per/user location.', '', '', 'Currency Method', '.git', '', '', 2, 'https://raw.githubusercontent.com/vdm-io/Joomla-Location-Data/master/update_server.xml', 'https://www.vdm.io/', '', 'yCK3vIvvmW9lhQWhjQ59UYZNI2+Gu8ea3xi/9pIsZmo=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 140, '', 1, 68), -(24, 1, '', '', '', 1, '', '', '', 1, '', 1, 1, 1, '', '', '', '', '', '', 1, 1, 1, '', '', 1, '', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.2.4', 'Copyright (C) 2015. All Rights Reserved', '2016-10-11 13:21:41', 1, 'oFMwe3AxUsKMJtJimKkJsHaTYqDYqWZkC61nC1SxEfo=', 'sZha0cp6FAtJnJFM3FA4KZ9a9LRPQWleEVOfkQERTVg=', '', '4w0Rzv/4G3yVkL4YNV1q5vXzbInZDw9WsrRqb49Wz98=', '', '', '', 1, '', 'Expert Database component adds the ability to your Joomla to manage various experts and their related details.', 'llewellyn@vdm.io', '', 'https://vdm.bz/jcb-expert-database', 'g5iSlb/hQAUP2TW/lKRX5LOTtOtKoaCU1Z9vJSRU2/KybhqmUpzRFEvM5l9nu1pqIxQ2lbplpKvzFRt4WlqMDQ==', '', '9c00695f-70da-4e01-a1c4-1fc766994467', 'images/vdm/EXPERT500.jpg', '', 'https://github.com/vdm-io/JCB-Packages/raw/master/JCB_expertDatabase.zip', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2022-03-18 18:16:48', 1, 'Expert Database', 'expertdatabase', '', 4, 'CQlzZWxmOjpsb2FkQ29uZmlybWF0aW9uQWpheCgkZG9jdW1lbnQpOw==', 'CS8qKg0KCSogCUxvYWQgdGhlIENvbmZpcm1hdGlvbiBBamF4IHRvIHBhZ2UNCgkqKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGxvYWRDb25maXJtYXRpb25BamF4KCRkb2N1bWVudCkNCgl7DQoJCS8vIGFkZCBhbiBldmVudCB0aGF0IHdpbGwgc2VuZCBvdXQgYWxsIGNvbmZpcm1hdGlvbiBlbWFpbHMsIG5vdCB5ZXQgc2VuZA0KCQkkZG9jdW1lbnQtPmFkZFNjcmlwdERlY2xhcmF0aW9uKCINCgkJCWpRdWVyeSh3aW5kb3cpLmxvYWQoZnVuY3Rpb24oKSB7DQoJCQkJc2VuZENvbmZpcm1hdGlvbkVtYWlscygxKTsNCgkJCX0pOw0KCQkJDQoJCQlmdW5jdGlvbiBzZW5kQ29uZmlybWF0aW9uRW1haWxzKHR5cGUpIHsNCgkJCQl2YXIgZ2V0VXJsID0gJyIuVXJpOjpyb290KCkuImFkbWluaXN0cmF0b3IvaW5kZXgucGhwP29wdGlvbj1jb21fW1tbY29tcG9uZW50XV1dJnRhc2s9YWpheC5zZW5kQ29uZmlybWF0aW9uRW1haWxzJmZvcm1hdD1qc29uJzsNCgkJCQlpZih0eXBlID4gMCl7DQoJCQkJCXZhciByZXF1ZXN0ID0gJ3Rva2VuPSIuSm9vbWxhX19fNWJhMzg1MTNfNWM0Zl80YjBkXzkzNWVfNDllOTg2YTZiY2U4X19fUG93ZXI6OmdldEZvcm1Ub2tlbigpLiImdHlwZT0nK3R5cGU7DQoJCQkJfQ0KCQkJCXJldHVybiBqUXVlcnkuYWpheCh7DQoJCQkJCXR5cGU6ICdQT1NUJywNCgkJCQkJdXJsOiBnZXRVcmwsDQoJCQkJCWRhdGFUeXBlOiAnanNvbnAnLA0KCQkJCQlkYXRhOiByZXF1ZXN0LA0KCQkJCQlqc29ucDogJ2NhbGxiYWNrJw0KCQkJCX0pOw0KCQkJfSIpOw0KCX0=', '	/**
	* 	The main send email
	**/
	protected static $replyEmail;

	/**
	* 	The component params
	**/
	public static $params;

	/**
	* 	The Main from name
	**/
	protected static $replyName;

	/**
	* 	Send the confirmation emails
	**/
	protected static function getTemplate($type, $default = null)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		$body = self::$params->get($type, $default);
		// return the template if found
		if ($body)
		{
			return $body;
		}
		return Text::sprintf('No template for <b>%s</b> were found', Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($type, 'w'));
	}

	/**
	* 	get place holders
	**/
	public static function getPlaceHolders($type)
	{
		if ('document' == $type)
		{
			return array_keys(self::getCompanyDetails('placeholder'));
		}
		elseif ('confirmation_email' == $type)
		{
			$f = '[';
			$b = ']';
			$placeholder = array();
			$placeholder[] = array('[document_header]');
			$placeholder[] = array_keys(self::getCompanyDetails('placeholder'));
			$placeholder[] = array_values(self::getSelection('expert', $f.'expert_', $b));
			$placeholder[] = array_values(self::getSelection('referral', $f.'referral_', $b));
			$placeholder[] = array('[confirmation_link]');
			$placeholder[] = array('[document_footer]');
			return  self::mergeArrays($placeholder);
		}
		elseif ('expert_profile' == $type)
		{
			$f = '[';
			$b = ']';
			$placeholder = array();
			$placeholder[] = array('[document_header]');
			$placeholder[] = array_keys(self::getCompanyDetails('placeholder'));
			$placeholder[] = array_values(self::getSelection('expert', $f.'expert_', $b));
			$placeholder[] = array('[is_organisation]', '[is_admin]');
			$placeholder[] = array('[document_footer]');
			return  self::mergeArrays($placeholder);
		}
		return false;
	}

	/**
	* 	Send a message
	**/
	public static function sendMessage($eposcode, $replyToName, $replyToEmail, $message)
	{
		$eposcode = [[[Component]]]Helper::base64_urldecode($eposcode);
		// Get a Crypt Key
		$basickey = [[[Component]]]Helper::getCryptKey('basic');
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
		$eposCode = rtrim($opener->decryptString($eposcode), "\0");
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($eposCode))
		{
			$target = json_decode($eposCode);
			if (isset($target->id) && $target->id > 0)
			{
				$expert = self::getExpertDetails($target->id, 'object', 'special');
				if (isset($expert->email) && isset($target->email) && $expert->email == $target->email)
				{
					// setup the subject
					$subject = Text::sprintf('A message from %s to %s', $replyToName, $expert->name);
					// setup the html
					$messageHtml = str_replace("\n", "<br />", $message);
					$html = Text::sprintf('%s<br /><br />%s<br />%s', $messageHtml, $replyToName, $replyToEmail);
					$text = Text::sprintf("%s\n\n%s\n%s", $message, $replyToName, $replyToEmail);
					// send the email
					if ([[[Component]]]Email::send($expert->email, $subject, [[[Component]]]Email::setTableBody($html, $subject), $text, 1, null, null, $replyToEmail,  $replyToName))
					{
						return array('message' =>  Text::sprintf('%s your message to %s was send successfully!', $replyToName, $expert->name), 'status' => 'success');
					}
				}
			}
		}
		return array('message' =>  Text::sprintf('%s there was an ERROR sending your message!', $replyToName), 'status' => 'danger');
	}

	/**
	* 	the confirmation emails to send
	**/
	protected static $confirmationEmails = array();

	/**
	* 	Send the confirmation emails
	**/
	public static function sendConfirmationEmails()
	{
		// first we get all the data and set the emails as send (to insure emails are not send more then once)
		if ($list = self::getConfirmationNeededList())
		{
			// get the company
			$company =  self::getCompanyDetails('placeholder');
			// get email template
			$template = self::getTemplate('confirmation_email');
			$subject_template = self::getTemplate('subject_confirmation_email', 'Hi [referral_name], please confirm the details of [expert_name]');
			// set some defaults
			$doc_header = self::getTemplate('doc_header');
			$doc_footer = self::getTemplate('doc_footer');
			$default[] = array('[document_header]' => self::setDynamicData($doc_header, $company), '[document_footer]' => self::setDynamicData($doc_footer, $company));
			// now lets get the company details
			$default[] = $company;
			$details = array();
			$details[0] = self::mergeArrays($default);
			// start building the emails
			foreach ($list as $reference)
			{
				// now lets get the expert details
				$details[1] = self::getExpertDetails($reference['[referral_expert_id]'], 'placeholder', 'full');
				$details[2] = $reference;
				// now more values
				$placeholders = self::mergeArrays($details);
				$body = self::setDynamicData($template, $placeholders);
				$subject = self::setDynamicData($subject_template, $placeholders);
				// set the email details
				self::$confirmationEmails[] = array('id' => $reference['[referral_id]'], 'email' => $reference['[referral_email]'], 'subject' => $subject, 'html' => $body);
				// lets send mail each time we have more then 10 set
				self::sendConfirmationEmail(10);
			}
			// send final emails if any remain
			self::sendConfirmationEmail();
			return true;
		}
		return false;
	}

	/**
	* Send the email needed for confirmation
	*
	* @param int  $qty the qty before emailing the list
	*
	* @return  boolean false on failure
	*
	**/	
	protected static function sendConfirmationEmail($qty = 1)
	{
		if (count(self::$confirmationEmails) >= $qty)
		{
			// send the emails
			foreach (self::$confirmationEmails as $details)
			{
				if (![[[Component]]]Email::send($details['email'], $details['subject'], [[[Component]]]Email::setTableBody($details['html'], $details['subject']), '', 1, null, null, self::$replyEmail,  self::$replyName))
				{
					$fields = array();
					$fields[] = $db->quoteName('emailsend') . ' = 0';  // set to error as not send
					self::$updater[]  = array('fields' => $fields, 'conditions' => array($db->quoteName('id') . ' = ' . $details['id']));
					// run update if many values found
					self::updateData(10);
				}
			}
			// run update on last remaining values
			self::updateData();
			// clear the values array
			self::$confirmationEmails = array();
			return true;
		}
		return false;
	}

	/**
	* 	Once the email was send the gives us the option the store the massage
	**/
	public static function storeMessage($sendmail, $recipient, $subject, $body, $textonly, $mode, $type)
	{
		return true;
	}

	/**
	* 	the updater array
	**/
	protected static $updater = array();

	/**
	* 	Get the list of un-emailed confirmations and lock them
	**/
	protected static function getConfirmationNeededList($method = 'placeholder')
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		if ('placeholder' == $method)
		{
			$f = '[referral_';
			$b = ']';
		}
		// get the list of values we want from db
		$selection = self::getSelection('referral', $f, $b);
		$query->select($db->quoteName(array_keys($selection), array_values($selection)));
		// From the [[[component]]]_confirmation table.
		$query->from('#__[[[component]]]_confirmation AS a');
		// From the [[[component]]]_country table.
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'b') . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('b.id') . ')');
		$query->where('a.emailsend = 2');
		$query->where('a.confirmed = 0');
		$db->setQuery($query);
		$db->execute();
		if($db->getNumRows())
		{
			// Get the basic encryption.
			$basickey = self::getCryptKey('basic', 'erjg4359widcuje3asaif09tbv99howid0rgf038hfhodi8wfoed'); // we must have a key here
			// Get the encryption object.
			$basic = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
			// load the list of experts to confirm
			$list = $db->loadAssocList();
			foreach ($list as $nr => $reference)
			{
				$fields = array();
				$fields[] = $db->quoteName('emailsend') . ' = 1'; // lock down to look as send to keep multi emails from being send
				self::$updater[]  = array('fields' => $fields, 'conditions' => array($db->quoteName('id') . ' = ' . $reference[$f.'id'.$b]));
				// build the confirmation link
				$list[$nr]['[confirmation_link]'] = self::getConfirmationLink($reference, array($f, $b), $basic);
				// run update if many values found
				self::updateData(100);
			}
			// run update on last remaining values
			self::updateData();
			// return the found list
			return $list;
		}
		return false;
	}
[CUSTOMCODE=baseSixtyFourURL]
	/**
	 *	To load the application form
	 */
	public static function getApplicationForm($data = null, $type = 'expert', $access = 'public')
	{
		// get forms path
		$path	= JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/models/forms';
		// build full path to file
		$fullPath = $path.'/'.$type.'.xml';
		// check if file exists
		if (file_exists($fullPath))
		{
			// Get the form.
			jimport( 'joomla.form.form' );
			// set the paths
			JForm::addFormPath($path);
			JForm::addFieldPath(JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/models/fields');
			// great we are done return results
			$form = JForm::getInstance('com_[[[component]]].'.$type, $type, array('control' => 'jform', 'load_data' => false), false, false);
			// change the form for public submission
			if ('public' == $access)
			{
				self::publicApplicationForm($form, $type);
			}
			// now load the data
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
			{
				$form->bind($data);
			}
			return $form;
		}
		return false;
	}

	protected static $applicationFields = 
		array(
			'expert' =>
				array(
					'removeFields' =>
						array('id','created','created_by','published','modified','modified_by','access','ordering','version','metakey','metadesc','user','asset_id','rules'),
					'removeGroups' =>
						array('metadata','accesscontrol')
				)
		);

	/**
	 *	Model the form for publi submission
	 */
	protected static function publicApplicationForm(&$form, $type)
	{
		if (isset(self::$applicationFields[$type]))
		{
			if (isset(self::$applicationFields[$type]['removeFields']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$applicationFields[$type]['removeFields']))
			{
				// first remove all unwanted fields
				foreach (self::$applicationFields[$type]['removeFields'] as $field)
				{
					$form->removeField($field);
				}
			}
			if (isset(self::$applicationFields[$type]['removeGroups']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$applicationFields[$type]['removeGroups']))
			{
				// first remove all unwanted fields
				foreach (self::$applicationFields[$type]['removeGroups'] as $group)
				{
					$form->removeGroup($group);
				}
			}
		}
		// add the user fields
		self::addUserFields($form);
	}

	/**
	 *	Add user fields to application
	 */
	protected static function addUserFields(&$form)
	{
		// we must add some user fields
		$userFields =
			array(
				'name' =>
					array('name','username','email','password','password2', 'captcha'),
				'type' =>
					array('text','text','email','password','password','captcha'),
				'label' =>
					array(Text::_('Name'),Text::_('Username/Login-name'),Text::_('Email'),Text::_('Password'),Text::_('Confirm Password'),Text::_('ReCaptcha')),
				'description' =>
					array(Text::_('Your Full Name'),Text::_('Set the username/login-name of your choice.'),Text::_('Your Email Address'),Text::_('Use at least 6 characters, upper-case and lower-case letter, numbers and at least one special character.'),Text::_('Confirm Password'),Text::_('Just checking that your not a robot.')),
				'hint' =>
					array(Text::_('Expert Full Name'), Text::_('Username'), 'your@email.com',null,null,null),
				'class' =>
					array('text_area','text_area','text_area','text_area','text_area',null),
				'validate' =>
					array(null, null, 'email', null, null, 'captcha'),
				'filter' =>
					array('string', 'string', 'email', null, null,null),
				'field' =>
					array(null, null, null, 'password2', null, null)
			);
		$addReCaptcha = Factory::getConfig()->get('captcha');
		// now loop the fields and add to form
		foreach ($userFields['name'] as $nr => $name)
		{
			// build the field
			$xml = array();
			// only load ReCaptcha if turned on in system
			if ('captcha' != $name || $addReCaptcha)
			{
				$xml[] = '<field ';
				$xml[] = 'type="'.$userFields['type'][$nr].'" ';
				$xml[] = 'name="'.$name.'" ';
				if ($userFields['label'][$nr])
				{
					$xml[] = 'label="'.$userFields['label'][$nr].'" ';
				}
				if ($userFields['description'][$nr])
				{
					$xml[] = 'description="'.$userFields['description'][$nr].'" ';
				}
				if ($userFields['class'][$nr])
				{
					$xml[] = 'class="'.$userFields['class'][$nr].'" ';
				}
				if ('captcha' != $name)
				{
					$xml[] = 'required="true" ';
				}
				if ($userFields['filter'][$nr])
				{
					$xml[] = 'filter="'.$userFields['filter'][$nr].'" ';
				}
				if ($userFields['validate'][$nr])
				{
					$xml[] = 'validate="'.$userFields['validate'][$nr].'" ';
				}
				if ($userFields['field'][$nr])
				{
					$xml[] = 'field="'.$userFields['field'][$nr].'" ';
				}
				if ($userFields['hint'][$nr])
				{
					$xml[] = 'hint="'.$userFields['hint'][$nr].'" ';
				}
				$xml[] = '/>';
				// set the field
				$form->setField( simplexml_load_string(implode("\n", $xml)));
			}
		}
	}

	/**
	* This confirms experts
	*
	* @param string the base64 encrypted string
	*
	* @return  boolean false on failure
	*
	**/	
	public static function confirmExpert($action)
	{
		// error array if needed
		$errors = array();
		// Get the basic encryption.
		$basickey = self::getCryptKey('basic', 'erjg4359widcuje3asaif09tbv99howid0rgf038hfhodi8wfoed'); // we must have a key here
		// Get the encription object.
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
		// we try to open it
		if ($reference = json_decode(rtrim($opener->decryptString(self::base64_urldecode($action)), "\0")))
		{
			if (isset($reference->id))
			{
				// Get a db connection.
				$db = Factory::getDbo();
				// Create a new query object.
				$query = $db->getQuery(true);
				// get values in database
				$query->select($db->quoteName(array('expert', 'name', 'email', 'confirmed')));
				$query->from($db->quoteName('#__[[[component]]]_confirmation'));
				$query->where($db->quoteName('id') . ' = '. (int) $reference->id);
				// now get the data
				$db->setQuery($query);
				if ($db->execute())
				{
					$local = $db->loadObject();
					$verified = false;			
					// now check if the data is still the same
					if ($local->confirmed == 1)
					{
						$errors[] = Text::_('The details were already successfully verified.');
						$verified = true;
					}
					if ($local->expert != $reference->expert_id)
					{
						$errors[] = Text::_('The wrong expert was selected.');
					}
					if ($local->name != $reference->name)
					{
						$errors[] = Text::_('Your name no longer match the name we have on file.');
					}
					if ($local->email != $reference->email)
					{
						$errors[] = Text::_('Your email no longer match the email we have on file.');
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errors))
					{
						if (!$verified)
						{
							$errors[] = Text::_('These changes may have been made by the expert after the email was send to you.');
						}
						// set the error
						self::setError(1, $errors);
						return false;
					}
					else
					{
						// Create an object for the record we are going to update.
						$object = new \stdClass();
						// Must be a valid primary key value.
						$object->id = $reference->id;
						$object->confirmed = 1;

						// Update their details in the confirmation table using id as the primary key.
						if (Factory::getDbo()->updateObject('#__[[[component]]]_confirmation', $object, 'id'))
						{
							return true;
						}
						$errors[] = Text::_('There was an error during the verification proses.');
						// set the error
						self::setError(1, $errors);
						return false;
					}
				}
			}
		}
		$errors[] = Text::_('Your link is not valid.');
		// set the error
		self::setError(1, $errors);
		return false;
	}

	/**
	* Build the link used to confirm expert data
	*
	* @param array the referrals details
	*
	* @return  boolean false on failure
	*
	**/	
	protected static function getConfirmationLink($reference, $out, Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power $locker)
	{
		$bucket = array();
		foreach($reference as $key => $value)
		{
			$atKey = str_replace($out, '', $key);
			$bucket[$atKey] = $value;
		}
		return Uri::root().'index.php?option=com_[[[component]]]&task=confirm.expert&action='.self::base64_urlencode($locker->encryptString(json_encode($bucket)));
	}

	/**
	* Update the data from the file to the database
	*
	* @param int  $qty the qty before doing an update
	* @param array  $table The table being updated
	*
	* @return  boolean false on failure
	*
	**/	
	protected static function updateData($qty = 1, $table = 'confirmation')
	{
		if (count(self::$updater) >= $qty)
		{
			// load the data
			foreach(self::$updater as $value)
			{
				$db = Factory::getDbo();
				$query = $db->getQuery(true);
				// Prepare the update query.
				$query->update($db->quoteName('#__[[[component]]]_'.$table))
					->set($value['fields'])->where($value['conditions']);
				// Set the query using our newly populated query object and execute it.
				$db->setQuery($query);
				$db->execute();
			}
			// clear the values array
			self::$updater = array();
			return true;
		}
		return false;
	}

	public static function getExpertDisplay(&$id, $view = null, $type = null)
	{
		if ($id > 0)
		{
			// reset the details array
			$details = array();
			// get the company
			$company =  self::getCompanyDetails('placeholder');
			// get email template
			$template = self::getTemplate('expert_profile');
			// set document header and footer
			$doc_header = self::getTemplate('doc_header');
			$doc_footer = self::getTemplate('doc_footer');
			$details[] = array('[document_header]' => self::setDynamicData($doc_header, $company), '[document_footer]' => self::setDynamicData($doc_footer, $company));
			// now lets get the company details
			$details[] = $company;
			// get user access rights
			$userIs = self::userIs();
			$access = 'public';
			if ($userIs == 2 || $userIs == 3)
			{
				$access = 'special';
				if ($userIs == 2) 
				{
					$details[] = array('[is_organisation]' => 1);
				}
				elseif ($userIs == 3)
				{
					$details[] = array('[is_admin]' => 1);
				}
			}
			elseif ($userIs == 1)
			{
				if ('profile' == $view && 1948 == $type) // when expert views own profile (TODO more checks to insure it is true)
				{
					$access = 'full';
				}
				$details[] = array('[is_expert]' => 1);
			}
			// now lets get the expert details
			$details[] = self::getExpertDetails($id, 'placeholder', $access);
			// now mere values
			$placeholders = self::mergeArrays($details);
			if ($body = self::setDynamicData($template, $placeholders))
			{
				return $body;
			}			
		}
		return false;
	}

	protected static $expertDetails = array();
	
	public static function getExpertDetails(&$id, $method = 'object', $access = 'public')
	{
		// we need to manage some memory here
		if (count(self::$expertDetails) >= 200)
		{
			// remove first 100 from memory
			foreach (self::$expertDetails as $remove => $now)
			{
				// remove the first values that was set
				unset(self::$expertDetails[$remove]);
				if (count(self::$expertDetails) <= 100)
				{
					break;
				}
			}
		}
		if (!isset(self::$expertDetails[$id.$method.$access]))
		{
			// get expert details
			self::$expertDetails[$id.$method.$access] = self::getExpert($id, $method, $access);
		}
		if (!isset(self::$expertDetails[$id.$method.$access]))
		{
			self::$expertDetails[$id.$method.$access] = false;
		}
		return self::$expertDetails[$id.$method.$access];
	}

	protected static $expert = array();

	/**
	* Get the 
	* 
	* @return    html string
	*/
	protected static function getExpert(&$id, $method = 'object', $access = 'public')
	{
		// we need to manage some memory here
		if (count(self::$expert) >= 100)
		{
			// remove first 50 from memory
			foreach (self::$expert as $remove => $now)
			{
				// remove the first values that was set
				unset(self::$expert[$remove]);
				if (count(self::$expert) <= 50)
				{
					break;
				}
			}
		}
		$f = '';
		$b = '';
		if ('placeholder' == $method)
		{
			$f = '[expert_';
			$b = ']';
		}
		if (!isset(self::$expert[$id.$method.$access]))
		{
			$db = Factory::getDbo();
			$query = $db->getQuery(true);

			// Select some fields
			$selection = self::getSelection('expert', $f, $b);
			$query->select($db->quoteName(array_keys($selection), array_values($selection)));

			// From the [[[component]]]_expert table
			$query->from($db->quoteName('#__[[[component]]]_expert', 'a'));

			// From the users table.
			$query->join('LEFT', $db->quoteName('#__users', 'g') . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('g.id') . ')');
			// From the [[[component]]]_country table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'h') . ' ON (' . $db->quoteName('a.countryresidence') . ' = ' . $db->quoteName('h.id') . ')');
			// From the [[[component]]]_area_of_expertise table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_area_of_expertise', 'i') . ' ON (' . $db->quoteName('a.area_of_expertise') . ' = ' . $db->quoteName('i.id') . ')');
			// From the [[[component]]]_country table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'j') . ' ON (' . $db->quoteName('a.nationality') . ' = ' . $db->quoteName('j.id') . ')');
			// From the [[[component]]]_academic_qualification table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_academic_qualification', 'k') . ' ON (' . $db->quoteName('a.academic_qualification') . ' = ' . $db->quoteName('k.id') . ')');
			// From the [[[component]]]_prefix table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_prefix', 'p') . ' ON (' . $db->quoteName('a.prefix') . ' = ' . $db->quoteName('p.id') . ')');
			// From the [[[component]]]_title table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_title', 't') . ' ON (' . $db->quoteName('a.title') . ' = ' . $db->quoteName('t.id') . ')');

			$query->where('a.id = '.(int) $id);
			// only load confirmed profiles to these groups
			if ('public' == $access || 'special' == $access)
			{
				// From the [[[component]]]_confirmation table.
				$query->join('LEFT', $db->quoteName('#__[[[component]]]_confirmation', 'c') . ' ON (' . $db->quoteName('a.id') . ' = ' . $db->quoteName('c.expert') . ')');
				$query->where('c.confirmed = 1');
			}
			// make sure they have access to this profile and it is published
			if ('public' == $access)
			{
				$user	= Factory::getUser();
				$levels	= $user->getAuthorisedViewLevels();
				$query->where('a.published = 1');
				$query->where('a.access IN (' . implode(',', $levels) . ')');
			}

			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				if ('object' == $method)
				{
					self::$expert[$id.$method.$access] = self::modelExpert($db->loadObject(), $method, $access, $f, $b);
				}
				else
				{
					self::$expert[$id.$method.$access] = self::modelExpert($db->loadAssoc(), $method, $access, $f, $b);
				}
			}
		}
		// return the values
		if (!isset(self::$expert[$id.$method.$access]))
		{
			self::$expert[$id.$method.$access] = false;
		}
		return self::$expert[$id.$method.$access];
	}

	/**
	* Return array of selections
	* 
	* @return    array if type match
	*/
	protected static function getSelection($type, $f, $b)
	{
		if ('expert' == $type)
		{
			return array(
				'g.name' => $f.'name'.$b,	
				'g.email' => $f.'email'.$b,
				'h.name' => $f.'countryresidence'.$b,
				'i.name' => $f.'area_of_expertise'.$b,
				'a.city' => $f.'city'.$b,
				'a.phone' => $f.'phone'.$b,
				'a.summary' => $f.'summary'.$b,
				'a.address' => $f.'address'.$b,
				'a.cvkey' => $f.'cvlink'.$b,
				'p.name' => $f.'prefix'.$b,
				'a.membership' => $f.'membership'.$b,
				't.name' => $f.'title'.$b,
				'a.profession' => $f.'profession'.$b,
				'a.experience' => $f.'experience'.$b,
				'a.mobile_phone' => $f.'mobile_phone'.$b,
				'j.name' => $f.'nationality'.$b,
				'a.organisation' => $f.'organisation'.$b,
				'k.name' => $f.'academic_qualification'.$b,
				'a.specialisation' => $f.'specialisation'.$b,
				'a.worked_for' => $f.'worked_for'.$b,
				'a.website' => $f.'website'.$b,
				'a.geographic_focus' => $f.'geographic_focus'.$b,
				'a.professional_networks' => $f.'professional_networks'.$b,
				'a.privacy_academic_qualification' => $f.'privacy_academic_qualification'.$b,
				'a.privacy_address' => $f.'privacy_address'.$b,
				'a.privacy_city' => $f.'privacy_city'.$b,
				'a.privacy_countryresidence' => $f.'privacy_countryresidence'.$b,
				'a.privacy_cv' => $f.'privacy_cvlink'.$b,
				'a.privacy_membership' => $f.'privacy_membership'.$b,
				'a.privacy_mobile_phone' => $f.'privacy_mobile_phone'.$b,
				'a.privacy_nationality' => $f.'privacy_nationality'.$b,
				'a.privacy_organisation' => $f.'privacy_organisation'.$b,
				'a.privacy_phone' => $f.'privacy_phone'.$b,
				'a.privacy_profession' => $f.'privacy_profession'.$b,
				'a.privacy_professional_networks' => $f.'privacy_professional_networks'.$b,
				'a.privacy_worked_for' => $f.'privacy_worked_for'.$b
			);
		}
		if ('referral' == $type)
		{
			return array(
				'a.id' => $f.'id'.$b,
				'a.expert' => $f.'expert_id'.$b,
				'a.name' => $f.'name'.$b,
				'a.organisation' => $f.'organisation'.$b,
				'a.position' => $f.'position'.$b,
				'b.name' => $f.'country'.$b,
				'a.email' => $f.'email'.$b
			);
		}
		return false;
	}

	/**
	* The modelling of Expert data
	* 
	* @return    object of allowed values
	*/
	protected static function modelExpert($item, &$method, &$access, &$f, &$b)
	{
		// filer all privacy info that they user does not want public
		if ('public' == $access)
		{
			foreach ($item as $key => $value)
			{
				if (strpos($key, $f.'privacy_') !== false)
				{
					if ($value == 0)
					{
						// remove from data it is not public
						$valueKey = str_replace('privacy_', '', $key);
						if ('object' == $method)
						{
							unset($item->$valueKey);
						}
						else
						{
							unset($item[$valueKey]);
						}
						// also remove the privacy values
						if ('object' == $method)
						{
							unset($item->$key);
						}
						else
						{
							unset($item[$key]);
						}
					}
				}	
			}
		}
		// Get the basic encription.
		$basickey = self::getCryptKey('basic');
		// Get the encription object.
		$basic = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
		// not found, remove
		$removeLink = true;
		// start implementation to build CV link
		if ($basickey && 'object' == $method && isset($item->{$f.'cvlink'.$b}))
		{
			if (!empty($item->{$f.'cvlink'.$b}) && !is_numeric($item->{$f.'cvlink'.$b}) && $item->{$f.'cvlink'.$b} === base64_encode(base64_decode($item->{$f.'cvlink'.$b}, true)))
			{
				$key = rtrim($basic->decryptString($item->{$f.'cvlink'.$b}), "\0");
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($key) && !is_numeric($key))
				{
					$keyArray = explode('.', $key);
					$item->{$f.'cvlink'.$b} = Uri::root().'index.php?option=com_[[[component]]]&task=download.pdf&token='.Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken().'&file=' . $keyArray[0] . '.pdf';
					$removeLink = false;
				}
			}
		}
		elseif ($basickey && isset($item[$f.'cvlink'.$b]))
		{
			if (!empty($item[$f.'cvlink'.$b]) && !is_numeric($item[$f.'cvlink'.$b]) && $item[$f.'cvlink'.$b] === base64_encode(base64_decode($item[$f.'cvlink'.$b], true)))
			{
				$key = rtrim($basic->decryptString($item[$f.'cvlink'.$b]), "\0");
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($key) && !is_numeric($key))
				{
					$keyArray = explode('.', $key);
					$item[$f.'cvlink'.$b] = Uri::root().'index.php?option=com_[[[component]]]&task=download.pdf&token='.Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken().'&file=' . $keyArray[0] . '.pdf';
					$removeLink = false;
				}
			}
		}
		if ($removeLink)
		{
			if (isset($item->{$f.'cvlink'.$b}))
			{
				unset($item->{$f.'cvlink'.$b});
			}
			elseif (isset($item[$f.'cvlink'.$b]))
			{
				unset($item[$f.'cvlink'.$b]);
			}
		}
		// build the name
		if ('object' == $method && isset($item->{$f.'name'.$b}))
		{
			$title = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->{$f.'title'.$b})) ? $item->{$f.'title'.$b}.'. ' : ((Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->{$f.'prefix'.$b})) ? $item->{$f.'prefix'.$b}.'. ': '');
			$item->{$f.'name'.$b} = $title.$item->{$f.'name'.$b};
			// also remove title and prefix
			unset($item->{$f.'prefix'.$b});
			unset($item->{$f.'title'.$b});
		}
		if ('placeholder' == $method && isset($item[$f.'name'.$b]))
		{
			$title = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item[$f.'title'.$b])) ? $item[$f.'title'.$b].'. ' : ((Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item[$f.'prefix'.$b])) ? $item[$f.'prefix'.$b].'. ': '');
			$item[$f.'name'.$b] = $title.$item[$f.'name'.$b];
			// also remove title and prefix
			unset($item[$f.'prefix'.$b]);
			unset($item[$f.'title'.$b]);
		}
		// build the experience
		if ('object' == $method && isset($item->{$f.'experience'.$b}))
		{
			$years = ($item->{$f.'experience'.$b} == 1) ? Text::_('Year'): Text::_('Years');
			$item->{$f.'experience'.$b} = $item->{$f.'experience'.$b}.' '.$years;
		}
		if ('placeholder' == $method && isset($item[$f.'experience'.$b]))
		{
			$years = ($item[$f.'experience'.$b] == 1) ? Text::_('Year'): Text::_('Years');
			$item[$f.'experience'.$b] = $item[$f.'experience'.$b].' '.$years;
		}
		// set specialisation and geographic_focus to string
		$tables = array('specialisation','geographic_focus');
		foreach ($tables as $table)
		{
			if ('object' == $method && isset($item->{$f.$table.$b}))
			{
				$stuff = json_decode($item->{$f.$table.$b},true);
				$line = array();
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($stuff))
				{
					$naam = '';
					foreach ($stuff as $val)
					{
						if ($naam = self::getVar($table, $val, 'id', 'name'))
						{
							$line[] = $naam;
						}
					}
				}
				if (isset($line) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($line))
				{
					$item->{$f.$table.$b} = implode(', ', $line);
				}
				else
				{
					unset($item->{$f.$table.$b});
				}
			}
			elseif (isset($item[$f.$table.$b]))
			{
				$stuff = json_decode($item[$f.$table.$b],true);
				$line = array();
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($stuff))
				{
					$naam = '';
					foreach ($stuff as $val)
					{
						if ($naam = self::getVar($table, $val, 'id', 'name'))
						{
							$line[] = $naam;
						}
					}
				}
				if (isset($line) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($line))
				{
					$item[$f.$table.$b] = implode(', ', $line);
				}
				else
				{
					unset($item[$f.$table.$b]);
				}
			}
		}
		// remove 0 and replace with empty string
		if ('placeholder' == $method)
		{
			foreach ($item as $key => &$value)
			{
				if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($value))
				{
					$value = '';
				}
			}
		}
		return $item;
	}
[CUSTOMCODE=getCompanyDetails]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=userIsThree+adminuser,organisationuser,expertuser,organisation,expert]
	/**
	* 	The owner
	**/
	protected static $owner = array();

	public static function hasAccess($recordId, $userId = null, $to = 'expert')
	{
		if(!$userId)
		{
			$userId = Factory::getUser()->id;
		}
		$type = self::userIs($userId);
		if ($type && $recordId > 0)
		{
			switch($to)
			{
				case 'expert':
					return self::accessExpert($type, $recordId, $userId);
				break;
				case 'organisation':
					return self::accessOrganisation($type, $recordId, $userId);
				break;
			}
		}
		return false;
	}

	protected static function accessOrganisation($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organisation is the owner
				if (!isset(self::$owner['organisation'.$recordId]))
				{
					// load the owner
					self::$owner['organisation'.$recordId] = self::getVar('organisation', $recordId, 'id', 'user');
				}
				// only true if owner is the same as user
				if (self::$owner['organisation'.$recordId] == $userId)
				{
						return true;
				}
			break;
		}
		return false;
	}

	protected static function accessExpert($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 1: // check if expert is the owner
				if (!isset(self::$owner['expert'.$recordId]))
				{
					// load the owner
					self::$owner['expert'.$recordId] = self::getVar('expert', $recordId, 'id', 'user');
				}
				// only true if owner is the same as user
				if (self::$owner['expert'.$recordId] == $userId)
				{
						return true;
				}
			break;
		}
		return false;
	}

	/**
	* check confirmation
	*
	* @input	  int                       $id     The data id
	* @input	  array                   $data     The valid data
	*
	* @returns  boolean on success
	**/
	public static function checkConfirmation($id, &$data)
	{
		$updateData = array();
		// load the reference data if set
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($data['reference']))
		{
			$reference = json_decode($data['reference'],true);
		}
		// check if we already have a confirmation data set
		if ($confirmation = self::getConfirmation($id))
		{
			// there is any reference data set
			if (isset($reference) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($reference['email']))
			{
				// we may need to update the data if the email changed
				if (	$reference['email'][0] !== $confirmation['email'] ||
					$reference['organisation_ref'][0] !== $confirmation['organisation'] ||
					$reference['name'][0] !== $confirmation['name'] ||
					$reference['phone'][0] !== $confirmation['phone'] ||
					$reference["country"][0] !== $confirmation['country']  ||
					$reference["position"][0] !== $confirmation['position']
					)
				{
					if ((isset($confirmation['confirmed']) && $confirmation['confirmed'] == 1) || (!self::updateConfirmation($id, $reference, $data)))
					{
						// set the reference data back en load error
						$reference["organisation_ref"][0] = $confirmation['organisation'];
						$reference["name"][0] = $confirmation['name'];
						$reference["email"][0] = $confirmation['email'];
						$reference["phone"][0] = $confirmation['phone'];
						$reference["position"][0] = $confirmation['position'];
						$reference["country"][0] = $confirmation['country'];
						// update the reference data
						self::updateReferenceData($id, json_encode($reference));
						// set the warning notice since not referral was set
						if (isset($confirmation['confirmed']) && $confirmation['confirmed'] == 1)
						{
							$data['errors'][] = Text::_('You cannot delete or change this first reference person details after this person has verified your information, unless you contact support with the reasons for doing so.');
						}
						return false;
					}
				}
				return true;
			}
			// set the reference data back en load error
			$updateData["organisation_ref"][] = $confirmation['organisation'];
			$updateData["name"][] = $confirmation['name'];
			$updateData["email"][] = $confirmation['email'];
			$updateData["phone"][] = $confirmation['phone'];
			$updateData["position"][] = $confirmation['position'];
			$updateData["country"][] = $confirmation['country'];
			// update the reference data
			self::updateReferenceData($id, json_encode($updateData));
			$data['errors'][] = Text::_('You cannot delete or change this first reference person details after this person has verified your information, unless you contact support with the reasons for doing so.');
			return false;
		}
		// there is any reference data set
		if (isset($reference) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($reference['email']))
		{
			if (self::setConfirmation($id, $reference, $data))
			{
				return true;
			}
		}
		// set the warning notice since not referral was set
		$data['errors'][] = Text::_('Your account will not be activated. It is mandatory to add at least one reference person in order to verify the information you provided.');
		return false;
	}

	/**
	* update Reference Data
	*
	* @input	  int        $id     The expert id
	* @input	  string        $reference     The reference json
	*
	* @returns  bool on success
	**/
	public static function updateReferenceData($id, $value, $target = "reference")
	{		
		// Create an object for the record we are going to update.
		$object = new \stdClass();
 
		// Must be a valid primary key value.
		$object->id = $id;
		$object->$target = $value;
 
		// Update their details in the expert table using id as the primary key.
		return Factory::getDbo()->updateObject('#__[[[component]]]_expert', $object, 'id');
	}

	/**
	* get confirmation
	*
	* @input	  int        $id     The expert id
	*
	* @returns  object if found
	**/
	protected static function getConfirmation($id)
	{		
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select('a.*');
		$query->from('#__[[[component]]]_confirmation AS a');
		$query->where('a.expert = '. (int) $id);
		$db->setQuery($query);
		$db->execute();
		if($db->getNumRows())
		{
			return $db->loadAssoc();
		}
		return false;
	}

	/**
	* update confirmation
	**/
	protected static function updateConfirmation($id, $reference, &$data)
	{
		// make sure we have enough data and that it is correct
		$mail = Factory::getMailer();
		$update = true;
		if (!$mail->ValidateAddress($reference['email'][0]))
		{
			$data['errors'][] = $reference['email'][0] . ' ' . Text::_('is not a valid email address. <b>(References ERROR!)</b>');
			$update = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['name'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference name. <b>(References ERROR!)</b>');
			$update = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['organisation_ref'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference organisation name. <b>(References ERROR!)</b>');
			$update = false;
		}
		if (!isset($reference['country'][0]) || $reference['country'][0] <= 0)
		{
			$data['errors'][] = Text::_('You need to add reference country. <b>(References ERROR!)</b>');
			$update = false;
		}
		if ($update)
		{
			// Create an object for the record we are going to update.
			$object = new \stdClass();
			// Must be a valid primary key value.
			$object->expert = $id;
			$object->organisation = $reference['organisation_ref'][0];
			$object->name = $reference['name'][0];
			$object->email = $reference['email'][0];
			$object->phone = $reference['phone'][0];
			$object->position = $reference['position'][0];
			$object->country = (int) $reference['country'][0];
			$object->emailsend = 2;

			// Update their details in the expert table using expert as the primary key.
			return Factory::getDbo()->updateObject('#__[[[component]]]_confirmation', $object, 'expert');
		}
		return false;
	}

	/**
	* set confirmation
	**/
	protected static function setConfirmation($id, $reference, &$data)
	{
		// make sure we have enough data and that it is correct
		$mail = Factory::getMailer();
		$store = true;
		if (!$mail->ValidateAddress($reference['email'][0]))
		{
			$data['errors'][] = $reference['email'][0] . ' ' . Text::_('is not a valid email address. <b>(References ERROR!)</b>');
			$store = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['name'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference name. <b>(References ERROR!)</b>');
			$store = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['organisation_ref'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference organisation name. <b>(References ERROR!)</b>');
			$store = false;
		}
		if (!isset($reference['country'][0]) || $reference['country'][0] <= 0)
		{
			$data['errors'][] = Text::_('You need to add reference country. <b>(References ERROR!)</b>');
			$store = false;
		}
		if ($store)
		{
			// Create an object for the record we are going to update.
			$object = new \stdClass();
			// Must be a valid primary key value.
			$object->expert = $id;
			$object->organisation = $reference['organisation_ref'][0];
			$object->name = $reference['name'][0];
			$object->email = $reference['email'][0];
			$object->phone = $reference['phone'][0];
			$object->position = $reference['position'][0];
			$object->country = (int) $reference['country'][0];
			$object->emailsend = 2;

			// Update their details in the expert table using id as the primary key.
			return Factory::getDbo()->insertObject('#__[[[component]]]_confirmation', $object);
		}
		return false;
	}
[CUSTOMCODE=helperErrors]', 'CS8qKg0KCSogCUxvYWQgdGhlIENvbmZpcm1hdGlvbiBBamF4IHRvIHBhZ2UNCgkqKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGxvYWRDb25maXJtYXRpb25BamF4KCRkb2N1bWVudCkNCgl7DQoJCS8vIGFkZCBhbiBldmVudCB0aGF0IHdpbGwgc2VuZCBvdXQgYWxsIGNvbmZpcm1hdGlvbiBlbWFpbHMsIG5vdCB5ZXQgc2VuZA0KCQkkZG9jdW1lbnQtPmFkZFNjcmlwdERlY2xhcmF0aW9uKCINCgkJCWpRdWVyeSh3aW5kb3cpLmxvYWQoZnVuY3Rpb24oKSB7DQoJCQkJc2VuZENvbmZpcm1hdGlvbkVtYWlscygxKTsNCgkJCX0pOw0KCQkJDQoJCQlmdW5jdGlvbiBzZW5kQ29uZmlybWF0aW9uRW1haWxzKHR5cGUpIHsNCgkJCQl2YXIgZ2V0VXJsID0gJyIuVXJpOjpyb290KCkuImluZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ0YXNrPWFqYXguc2VuZENvbmZpcm1hdGlvbkVtYWlscyZmb3JtYXQ9anNvbic7DQoJCQkJaWYodHlwZSA+IDApew0KCQkJCQl2YXIgcmVxdWVzdCA9ICd0b2tlbj0iLkpvb21sYV9fXzViYTM4NTEzXzVjNGZfNGIwZF85MzVlXzQ5ZTk4NmE2YmNlOF9fX1Bvd2VyOjpnZXRGb3JtVG9rZW4oKS4iJnR5cGU9Jyt0eXBlOw0KCQkJCX0NCgkJCQlyZXR1cm4galF1ZXJ5LmFqYXgoew0KCQkJCQl0eXBlOiAnUE9TVCcsDQoJCQkJCXVybDogZ2V0VXJsLA0KCQkJCQlkYXRhVHlwZTogJ2pzb25wJywNCgkJCQkJZGF0YTogcmVxdWVzdCwNCgkJCQkJanNvbnA6ICdjYWxsYmFjaycNCgkJCQl9KTsNCgkJCX0iKTsNCgl9', '', '', '', '', '', 'CQlzZWxmOjpsb2FkQ29uZmlybWF0aW9uQWpheCgkZG9jdW1lbnQpOw==', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXSgvYWRtaW5pc3RyYXRvci9jb21wb25lbnRzL2NvbV8jIyNjb21wb25lbnQjIyMvYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMgQ29tcG9uZW50IE51bWJlcg0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCiMgSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyDQoNCkZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IEpDQiB2aXNpdCBbVkRNXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKSBUb2RheSEgVGhlIGZ1dHVyZSBpcyBoZXJlIQ==', '', '', 'Expert Database', '', '', 'Expert Database (public)', '.git', '', 1, 1, 'https://www.vdm.io/updates/expertdatabase_update_server.xml', 'http://www.vdm.io', '', '+0F3f7K0ampGK9b6ZYmR+QGwNik51oBRG+Mail7kHsJ3c4Td3MPUUp290mkpqjm2FElXcGch52OM0I19xHtStQ==', 'https://www.vdm.io/access/', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 221, '', 1, 60), -(25, '', '', '', '', '', '', '', '', 1, '', '', '', 1, '', 1, '', '', '', '', 1, '', '', '', '', 1, '{}', '', 1, 1, 3, 'Llewellyn van der Merwe', '', 'default.txt', '', '', 'Vast Development Method', '2.1.0', 'Copyright (C) 2015. All Rights Reserved', '2016-10-18 11:44:09', '', 'mvVkzmHCEIoBhzD3gR3uTzXRGwNVNRWw8Hr1vrXxb+I=', 'BbloLSYT6Yup6v3I/YNmrdOwzjbI4BGfDvJSB82N9DU=', '', 'VtSt2RMz+AHCrwc7jk1G70t83ZwZsNp2upqfzMyaVHE=', '', '', '', 1, '', 'Just a basic demo of the most basic implementations of the [Joomla](http://www.joomla.org) Component Builder\'s ability.', 'joomla@vdm.io', '', '', 'nZDegSPK87rXA4KMC6P8I6zEldjVIJpPYGRPZlKBI+U=', '', 'efde995e-60aa-4b39-b644-44349dfb660d', 'images/vdm/demo500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Demo-Component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-01-19 11:57:08', '', 'Demo', 'demo', 'JCB', 4, '', '', '', 'CS8qKg0KCSAqCUNoYW5nZSB0byBuaWNlIGZhbmN5IGRhdGUNCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGZhbmN5RGF0ZSgkZGF0ZSkNCgl7DQoJCWlmICghc2VsZjo6aXNWYWxpZFRpbWVTdGFtcCgkZGF0ZSkpDQoJCXsNCgkJCSRkYXRlID0gc3RydG90aW1lKCRkYXRlKTsNCgkJfQ0KCQlyZXR1cm4gZGF0ZSgnalMgXG9cZiBGIFknLCRkYXRlKTsNCgl9DQoNCgkvKioNCgkgKglDaGFuZ2UgdG8gbmljZSBmYW5jeSB0aW1lIGFuZCBkYXRlDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBmYW5jeURhdGVUaW1lKCR0aW1lKQ0KCXsNCgkJaWYgKCFzZWxmOjppc1ZhbGlkVGltZVN0YW1wKCR0aW1lKSkNCgkJew0KCQkJJHRpbWUgPSBzdHJ0b3RpbWUoJHRpbWUpOw0KCQl9DQoJCXJldHVybiBkYXRlKCcoRzppKSBqUyBcb1xmIEYgWScsJHRpbWUpOw0KCX0NCg0KCS8qKg0KCSAqCUNoYW5nZSB0byBuaWNlIGhvdXI6bWludXRlcyB0aW1lDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBmYW5jeVRpbWUoJHRpbWUpDQoJew0KCQlpZiAoIXNlbGY6OmlzVmFsaWRUaW1lU3RhbXAoJHRpbWUpKQ0KCQl7DQoJCQkkdGltZSA9IHN0cnRvdGltZSgkdGltZSk7DQoJCX0NCgkJcmV0dXJuIGRhdGUoJ0c6aScsJHRpbWUpOw0KCX0NCg0KCS8qKg0KCSAqCUNoZWNrIGlmIHN0cmluZyBpcyBhIHZhbGlkIHRpbWUgc3RhbXANCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGlzVmFsaWRUaW1lU3RhbXAoJHRpbWVzdGFtcCkNCgl7DQoJCXJldHVybiAoKGludCkgJHRpbWVzdGFtcCA9PT0gJHRpbWVzdGFtcCkNCgkJJiYgKCR0aW1lc3RhbXAgPD0gUEhQX0lOVF9NQVgpDQoJCSYmICgkdGltZXN0YW1wID49IH5QSFBfSU5UX01BWCk7DQoJfQ0K', '', 'CQkvLyBHZXQgQXBwbGljYXRpb24gb2JqZWN0DQoJCSRhcHAgPSBGYWN0b3J5OjpnZXRBcHBsaWNhdGlvbigpOw0KCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnVGhpcyBpcyBhIGRlbW8gY29tcG9uZW50IGRldmVsb3BlZCBpbiA8YSBocmVmPSJodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyIiB0YWdldD0iX2JhbG5rIiB0aXRsZT0iSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyIj5KQ0I8L2E+ISBZb3UgY2FuIGJ1aWxkIG1vcmUgY29tcG9uZW50cyBsaWtlIHRoaXMgd2l0aCBKQ0IsIGNoZWNrb3V0IG91ciBwYWdlIG9uIDxhIGhyZWY9Imh0dHBzOi8vZ2l0aHViLmNvbS92ZG0taW8vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyIiB0YWdldD0iX2JhbG5rIiB0aXRsZT0iSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyIj5naXRodWI8L2E+IGZvciBtb3JlIGluZm8uIFRoZSBmdXR1cmUgb2YgPGEgaHJlZj0iaHR0cDovL3ZkbS5iei9jb21wb25lbnQtYnVpbGRlciIgdGFnZXQ9Il9iYWxuayIgdGl0bGU9Ikpvb21sYSBDb21wb25lbnQgQnVpbGRlciI+Sm9vbWxhIENvbXBvbmVudCBEZXZlbG9wbWVudDwvYT4gaXMgSGVyZSEnLCAnSW5mbycpOw==', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIVsjIyNDb21wb25lbnRfbmFtZSMjIyBpbWFnZV0oaHR0cHM6Ly9yYXcuZ2l0aHVidXNlcmNvbnRlbnQuY29tL25hbWliaWEvZGVtby1qb29tbGEtMy1jb21wb25lbnQvbWFzdGVyL2FkbWluL2Fzc2V0cy9pbWFnZXMvdmRtLWNvbXBvbmVudC5qcGcgIlRoZSAjIyNDb21wb25lbnRfbmFtZSMjIyIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKSkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gbmV2ZXIgbWFraW5nIG9uZSBtaXN0YWtlIG9yIHRha2luZyBhbnkgY29mZmVlIGJyZWFrLikNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KKiojIyNhY3R1YWxIb3Vyc1NwZW50IyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxEYXlzU3BlbnQjIyMgRWlnaHQgSG91ciBEYXlzKiogKHRoZSBhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNwZW50KQ0KDQo+ICh3aXRoIHRoZSBmb2xsb3dpbmcgYnJlYWsgZG93bjoNCj4gKipkZWJ1Z2dpbmcgQCMjI2RlYnVnZ2luZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA0Ow0KPiAqKnBsYW5uaW5nIEAjIyNwbGFubmluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA3Ow0KPiAqKm1hcHBpbmcgQCMjI21hcHBpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gMTA7DQo+ICoqb2ZmaWNlIEAjIyNvZmZpY2VIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNjspDQoNCioqIyMjYWN0dWFsVG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsVG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqDQooYSB0b3RhbCBvZiB0aGUgcmVhbGlzdGljIHRpbWUgZnJhbWUgZm9yIHRoaXMgcHJvamVjdCkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gd2l0aCB0aGUgbm9ybWFsIGV2ZXJ5ZGF5IHJlYWxpdGllcyBhdCB0aGUgb2ZmaWNlLCB0aGF0IGluY2x1ZGVzIHRoZSBjb21wb25lbnQgcGxhbm5pbmcsIG1hcHBpbmcgJiBkZWJ1Z2dpbmcuKQ0KDQpQcm9qZWN0IGR1cmF0aW9uOiAqKiMjI3Byb2plY3RXZWVrVGltZSMjIyB3ZWVrcyoqIG9yICoqIyMjcHJvamVjdE1vbnRoVGltZSMjIyBtb250aHMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCltDVVNUT01DT0RFPXJlYWRNRWNvbnRyaWJ1dG9yc10=', '', '', 'Demo Component', '', '', 'Demo (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/namibia/demo-joomla-3-component/master/demo_updateserver.xml', 'https://www.vdm.io/', '', '6GeGhXcYZEQosGCi0ZXeuAj3oXBwARl7OnRm9h3rxPQ=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 54, '', 1, 10), -(26, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.5', 'Copyright (C) 2015. All Rights Reserved', '2016-10-18 11:44:09', '', 'V57IYyl69MoRbHvbC+yMIgFWIddrGmkXyPSp1h92rwI=', 'S6GyJe2D2H9ZYjSpC3AQucfZQLo6Dh+PwMvHmOTXgaE=', '', 'awUIYFU9kVsk5AJjwLVFX+F3goHgHrjjKrcQiXnn3k0=', '', '', 'A_110', 2, '', 'Just a basic Notice Board.', 'info@vdm.io', '', '', 'UNL4cGpxdFD7CctzvGO1ixIUs28WPZKXLEcrp9+GXNHbF4gQux3b2G7AqI2n+AxprTYcmla/cEn2C72BdnAvAw==', '', 'c327d3ae-57a4-4403-817d-6f1c694b4b29', 'images/demo300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-05-16 15:19:34', '', 'Notice Board', 'noticeboard', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Notice Board', '', '', 'Notice Board', '.git', '', '', 1, '', 'https://www.vdm.io/', '', 'lmEbDzExkqR4uqaWVPEL/ysXmPo6eNVDGOYmP3V3zb0=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 49, '', 1, 9), -(27, '', '', '', '', '', '', '', '', 1, '', 1, '', 1, '', '', '', '', '', '', 1, '', '', '', '', 1, '', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.1', 'Copyright (C) 2015. All Rights Reserved', '2016-10-24 02:49:33', '', '', '', '', '', '', '', '', 1, 1, 'Expert Database component adds the ability to your Joomla to manage various experts and their related details.', 'llewellyn@vdm.io', '', '', '', '', 'f051c1f2-cedb-41e4-bd3c-3cc0cd594979', 'images/expertdatabase.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2016-10-12 09:25:30', '', 'Expert Database', 'expertdatabase', '', 4, '', 'CXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gc2V0Q3VycmVuY3koJGFtb3VudCwkc3VwcG9ydF9ncm91cCkNCgl7DQoJCS8vIGdldCB0aGUgY3VycmVuY3kgaWQNCgkJJGN1cnJlbmN5ID0gc2VsZjo6Z2V0Q3VycmVuY3koJHN1cHBvcnRfZ3JvdXApOw0KCQkvLyBtYWtlIG1vbmV5DQoJCXJldHVybiBzZWxmOjptYWtlTW9uZXkoJGFtb3VudCwkY3VycmVuY3kpOw0KCX0NCg0KCXByb3RlY3RlZCBzdGF0aWMgJGN1cnJlbmN5ID0gYXJyYXkoKTsNCg0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0Q3VycmVuY3koJHN1cHBvcnRfZ3JvdXApDQoJew0KCQlpZiAoIWlzc2V0KHNlbGY6OiRjdXJyZW5jeVskc3VwcG9ydF9ncm91cF0pKQ0KCQl7DQoJCQkvLyBnZXQgdGhlIGxvY2F0aW9uDQoJCQkkYXJlYSA9IHNlbGY6OmdldFZhcignc3VwcG9ydF9ncm91cCcsICRzdXBwb3J0X2dyb3VwLCAnaWQnLCAnYXJlYScpOw0KCQkJLy8gZ2V0IHRoZSBSZWdpb24NCgkJCSRyZWdpb24gPSBzZWxmOjpnZXRWYXIoJ2FyZWEnLCAkYXJlYSwgJ2lkJywgJ3JlZ2lvbicpOw0KCQkJLy8gZ2V0IHRoZSBDb3VudHJ5DQoJCQkkY291bnRyeSA9IHNlbGY6OmdldFZhcigncmVnaW9uJywgJHJlZ2lvbiwgJ2lkJywgJ2NvdW50cnknKTsNCgkJCS8vIGdldCB0aGUgQ3VycmVuY3kgQ29kZXRocmVlDQoJCQkkY29kZXRocmVlID0gc2VsZjo6Z2V0VmFyKCdjb3VudHJ5JywgJGNvdW50cnksICdpZCcsICdjdXJyZW5jeScpOw0KCQkJLy8gZ2V0IGN1cnJlbmN5IGlkDQoJCQlzZWxmOjokY3VycmVuY3lbJHN1cHBvcnRfZ3JvdXBdID0gc2VsZjo6Z2V0VmFyKCdjdXJyZW5jeScsICRjb2RldGhyZWUsICdjb2RldGhyZWUnLCAnaWQnKTsNCgkJfQ0KCQlyZXR1cm4gc2VsZjo6JGN1cnJlbmN5WyRzdXBwb3J0X2dyb3VwXTsNCgl9DQoNCglwcm90ZWN0ZWQgc3RhdGljICRjdXJyZW5jeURldGFpbHMgPSBhcnJheSgpOw0KDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBnZXRDdXJyZW5jeURldGFpbHMoJGlkID0gZmFsc2UpDQoJew0KCQlpZihpc19udW1lcmljKCRpZCkpDQoJCXsNCgkJCWlmICghaXNzZXQoc2VsZjo6JGN1cnJlbmN5RGV0YWlsc1skaWRdKSkNCgkJCXsNCgkJCQkvLyBHZXQgYSBkYiBjb25uZWN0aW9uLg0KCQkJCSRkYiA9IEZhY3Rvcnk6OmdldERibygpOw0KCQkJCS8vIENyZWF0ZSBhIG5ldyBxdWVyeSBvYmplY3QuDQoJCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCg0KCQkJCSRxdWVyeS0+c2VsZWN0KCRkYi0+cXVvdGVOYW1lKA0KCQkJCQlhcnJheSgJJ2EuaWQnLCdhLm5hbWUnLCdhLmNvZGV0aHJlZScsJ2EubnVtZXJpY2NvZGUnLCdhLnN5bWJvbCcsJ2EudGhvdXNhbmRzJywnYS5kZWNpbWFscGxhY2UnLA0KCQkJCQkJJ2EuZGVjaW1hbHN5bWJvbCcsJ2EucG9zaXRpdmVzdHlsZScsJ2EubmVnYXRpdmVzdHlsZScpLA0KCQkJCQlhcnJheSgJJ2N1cnJlbmN5X2lkJywnY3VycmVuY3lfbmFtZScsJ2N1cnJlbmN5X2NvZGV0aHJlZScsJ2N1cnJlbmN5X251bWVyaWNjb2RlJywnY3VycmVuY3lfc3ltYm9sJywNCgkJCQkJCSdjdXJyZW5jeV90aG91c2FuZHMnLCdjdXJyZW5jeV9kZWNpbWFscGxhY2UnLCdjdXJyZW5jeV9kZWNpbWFsc3ltYm9sJywnY3VycmVuY3lfcG9zaXRpdmVzdHlsZScsDQoJCQkJCQknY3VycmVuY3lfbmVnYXRpdmVzdHlsZScpKSk7DQoJCQkJJHF1ZXJ5LT5mcm9tKCRkYi0+cXVvdGVOYW1lKCcjX19bW1tjb21wb25lbnRdXV1fY3VycmVuY3knLCAnYScpKTsNCgkJCQkkcXVlcnktPndoZXJlKCRkYi0+cXVvdGVOYW1lKCdpZCcpIC4gJyA9ICcuKGludCkgJGlkKTsNCgkJCQkkZGItPnNldFF1ZXJ5KCRxdWVyeSk7DQoJCQkJJGRiLT5leGVjdXRlKCk7DQoJCQkJaWYgKCRkYi0+Z2V0TnVtUm93cygpKQ0KCQkJCXsNCgkJCQkJc2VsZjo6JGN1cnJlbmN5RGV0YWlsc1skaWRdID0gJGRiLT5sb2FkT2JqZWN0KCk7DQoJCQkJfQ0KCQkJCWVsc2UNCgkJCQl7DQoJCQkJCXNlbGY6OiRjdXJyZW5jeURldGFpbHNbJGlkXSA9IGZhbHNlOw0KCQkJCX0NCgkJCX0NCgkJCXJldHVybiBzZWxmOjokY3VycmVuY3lEZXRhaWxzWyRpZF07DQoJCX0NCgkJcmV0dXJuIGZhbHNlOw0KCX0NCgkNCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIG1ha2VNb25leSgkbnVtYmVyLCRjdXJyZW5jeSA9IGZhbHNlKQ0KCXsNCgkJLy8gZmlyc3QgY2hlY2sgaWYgd2UgaGF2ZSBhIG51bWJlcg0KCQlpZiAoaXNfbnVtZXJpYygkbnVtYmVyKSkNCgkJew0KCQkJLy8gbWFrZSBzdXJlIHRvIGluY2x1ZGUgdGhlIG5lZ2F0aXZlIGZpbmRlciBmaWxlDQoJCQlpbmNsdWRlX29uY2UgJ25lZ2F0aXZlZmluZGVyLnBocCc7DQoJCQkvLyBjaGVjayBpZiB0aGUgbnVtYmVyIGlzIG5lZ2F0aXZlDQoJCQkkbmVnYXRpdmVGaW5kZXJPYmogPSBuZXcgTmVnYXRpdmVGaW5kZXIobmV3IEV4cHJlc3Npb24oIiRudW1iZXIiKSk7DQoJCQkkbmVnYXRpdmUgPSAkbmVnYXRpdmVGaW5kZXJPYmotPmlzSXROZWdhdGl2ZSgpID8gVFJVRSA6IEZBTFNFOw0KCQl9DQoJCWVsc2UNCgkJew0KCQkJdGhyb3cgbmV3IEV4Y2VwdGlvbignRVJST1IhICgnLiRudW1iZXIuJykgaXMgbm90IGEgbnVtYmVyIScpOw0KCQl9DQoJCS8vIHNldHVwIHRoZSBjdXJyZW5jeQ0KCQkkY3VycmVuY3kgPSBzZWxmOjpnZXRDdXJyZW5jeURldGFpbHMoJGN1cnJlbmN5KTsNCgkJLy8gc2V0IHRoZSBudW1iZXIgdG8gY3VycmVuY3kNCgkJaWYgKFN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKCRjdXJyZW5jeSkpDQoJCXsNCgkJCWlmICghJG5lZ2F0aXZlKQ0KCQkJew0KCQkJCSRmb3JtYXQgPSAkY3VycmVuY3ktPmN1cnJlbmN5X3Bvc2l0aXZlc3R5bGU7DQoJCQkJJHNpZ24gPSAnKyc7DQoJCQl9DQoJCQllbHNlIA0KCQkJew0KCQkJCSRmb3JtYXQgPSAkY3VycmVuY3ktPmN1cnJlbmN5X25lZ2F0aXZlc3R5bGU7DQoJCQkJJHNpZ24gPSAnLSc7DQoJCQkJJG51bWJlciA9IGFicygkbnVtYmVyKTsNCgkJCX0NCgkJCSRzZXR1cE51bWJlciA9IG51bWJlcl9mb3JtYXQoKGZsb2F0KSRudW1iZXIsIChpbnQpJGN1cnJlbmN5LT5jdXJyZW5jeV9kZWNpbWFscGxhY2UsICRjdXJyZW5jeS0+Y3VycmVuY3lfZGVjaW1hbHN5bWJvbCwgJyAnKTsgLy8kY3VycmVuY3ktPmN1cnJlbmN5X3Rob3VzYW5kcyBUT0RPKTsNCgkJCSRzZWFyY2ggPSBhcnJheSgne3NpZ259JywgJ3tudW1iZXJ9JywgJ3tzeW1ib2x9Jyk7DQoJCQkkcmVwbGFjZSA9IGFycmF5KCRzaWduLCAkc2V0dXBOdW1iZXIsICRjdXJyZW5jeS0+Y3VycmVuY3lfc3ltYm9sKTsNCgkJCSRtb25leU1hZGUgPSBzdHJfcmVwbGFjZSAoJHNlYXJjaCwkcmVwbGFjZSwkZm9ybWF0KTsNCg0KCQkJcmV0dXJuICRtb25leU1hZGU7DQoJCX0NCgkJcmV0dXJuICRudW1iZXI7DQoJfQ==', '', 'CXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gc2V0VG90YWxzKCYkZGF0YSwmJHR5cGUsJiRpZCkNCgl7DQoJCWxpc3QoJHBhdGgsICRmaWxlTmFtZSwgJGZ1bGxQYXRoKSA9IHNlbGY6OmdldFRvdGFsc0ZpbGVQYXRoKCR0eXBlLCRpZCk7DQoJCS8vIGRpZCB3ZSBnZXQgYSB2YWxpZCByZXN1bHQgc2V0DQoJCWlmIChTdXBlcl9fXzBhNTljNjVjXzlkYWZfNGJjOV9iYWY0X2UwNjNmZjllNmE4YV9fX1Bvd2VyOjpjaGVjaygkZGF0YSkpDQoJCXsNCgkJCS8vIG5vdyBzYXZlIGZvciBuZXh0IHRpbWUNCgkJCXJldHVybiBzZWxmOjpzYXZlSnNvbigkZGF0YSwgJGZ1bGxQYXRoLCAkcGF0aCk7DQoJCX0NCgkJcmV0dXJuIGZhbHNlOw0KCX0NCg0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0VG90YWxzKCYkdHlwZSwmJGlkKQ0KCXsNCgkJbGlzdCgkcGF0aCwgJGZpbGVOYW1lLCAkZnVsbFBhdGgpID0gc2VsZjo6Z2V0VG90YWxzRmlsZVBhdGgoJHR5cGUsJGlkKTsNCgkJLy8gY2hlY2sgaWYgZmlsZSBleGlzdHMNCgkJaWYgKGZpbGVfZXhpc3RzKCRmdWxsUGF0aCkgJiYgKCgkanNvbkZpbGUgPSBTdXBlcl9fX2EyMjNiMzFlX2VhMWRfNGNkZl85MmFlXzVmOWJlY2ZmYWZmMF9fX1Bvd2VyOjpnZXRDb250ZW50KCRmdWxsUGF0aCwgRkFMU0UpKSAhPT0gRkFMU0UpKQ0KCQl7DQoJCQkvLyBncmVhdCB3ZSBhcmUgZG9uZSByZXR1cm4gcmVzdWx0cyBhcyBhcnJheQ0KCQkJcmV0dXJuIGpzb25fZGVjb2RlKCRqc29uRmlsZSx0cnVlKTsNCgkJfQ0KCQkvLyByZW1vdmUgdGhlIG9sZCBmaWxlcw0KCQlzZWxmOjpyZW1vdmVGaWxlKCRwYXRoLCAkZmlsZU5hbWUpOw0KCQlyZXR1cm4gZmFsc2U7DQoJfQ0KCQ0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0VG90YWxzRmlsZVBhdGgoJiR0eXBlLCYkaWQpDQoJew0KCQkkcGF0aFswXSA9IEpQQVRIX0FETUlOSVNUUkFUT1IuJy9jb21wb25lbnRzL2NvbV9bW1tjb21wb25lbnRdXV0vaGVscGVycy90b3RhbHMnOw0KCQkkcGF0aFsxXSA9IHNlbGY6OmdldEZpbGVLRVkoJHR5cGUsJGlkKTsNCgkJLy8gYnVpbGQgZnVsbCBwYXRoIHRvIGZpbGUNCgkJJHBhdGhbMl0gPSAkcGF0aFswXS4nLycuJHBhdGhbMV0uJy5qc29uJzsNCg0KCQlyZXR1cm4gJHBhdGg7DQoJfQ0KCQ0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0RmlsZUtFWSgmJHR5cGUsJiRpZCkNCgl7DQoJCS8vIEdldCBhIGRiIGNvbm5lY3Rpb24uDQoJCSRkYiA9IEZhY3Rvcnk6OmdldERibygpOw0KCQkvLyBDcmVhdGUgYSBuZXcgcXVlcnkgb2JqZWN0Lg0KCQkkcXVlcnkgPSAkZGItPmdldFF1ZXJ5KHRydWUpOw0KCQkvLyBHZXQgZnJvbSAjX19zdXBwb3J0Z3JvdXBzX3N1cHBvcnRfZ3JvdXAgYXMgYQ0KCQkkcXVlcnktPnNlbGVjdCgnTUFYKGEubW9kaWZpZWQpJyk7DQoJCSRxdWVyeS0+ZnJvbSgkZGItPnF1b3RlTmFtZSgnI19fc3VwcG9ydGdyb3Vwc19zdXBwb3J0X2dyb3VwJywgJ2EnKSk7DQoJCSRxdWVyeS0+d2hlcmUoJ2EucHVibGlzaGVkID0gMScpOw0KCQkkZGItPnNldFF1ZXJ5KCRxdWVyeSk7DQoJCSRkYi0+ZXhlY3V0ZSgpOw0KCQlpZiAoJGRiLT5nZXROdW1Sb3dzKCkpDQoJCXsNCgkJCXJldHVybiAnVkRNXycuJHR5cGUuJ19fJy5tZDUoJGRiLT5sb2FkUmVzdWx0KCkpLidfXycuJGlkOw0KCQl9DQoJCXJldHVybiAnVkRNXycuJHR5cGUuJ19fMjg5ZDdiMDUyNzg2OGQ3ZjlhNWY4YzdiMWM4MGQ3YTZfXycuJGlkOw0KCX0NCg0KCS8qKg0KCSogU2FmZXMganNvbiB0byBhIGZpbGUNCgkqDQoJKiBAaW5wdXQJICBvYmplY3QvYXJyYXkvanNvbiAgJGRhdGEgICAgICBEYXRhIHRvIGJlIHN0b3JlZA0KCSogQGlucHV0CSAgc3RyaW5nICAgICAgICAgICAgICAgICAgJGZ1bGxQYXRoIEZ1bGwgcGF0aCB0byBmaWxlDQoJKiBAaW5wdXQJICBzdHJpbmcgICAgICAgICAgICAgICAgICAkcGF0aCAgICAgIEZ1bGwgcGF0aCB0byBmb2xkZXINCgkqDQoJKiBAcmV0dXJucyAgYm9vbGVhbiBvbiBzdWNjZXNzDQoJKiovDQoJcHJvdGVjdGVkIHN0YXRpYyBmdW5jdGlvbiBzYXZlSnNvbigkZGF0YSwgJGZ1bGxQYXRoLCAkcGF0aCA9IF9fRElSX18pDQoJew0KCQkvLyBjaGVjayBpZiBwYXRoIGV4aXN0cw0KCQlpZiAoIWZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJew0KCQkJLy8gaWYgbm90IHRoZSBtYWtlIHRoZSBwYXRoDQoJCQlta2RpcigkcGF0aCwgMDc1NSwgdHJ1ZSk7DQoJCX0NCgkJLy8gY2hlY2sgdGhhdCB0aGUgc3RyaW5nIGlzIGpzb24NCgkJaWYgKCFTdXBlcl9fXzRiMjI1YzUxX2QyOTNfNDhlNF9iM2Y2XzUxMzZjZjVjM2YxOF9fX1Bvd2VyOjpjaGVjaygkZGF0YSkpDQoJCXsNCgkJCS8vIGpzb24gZW5jb2RlIGlmIG5vdCBqc29uDQoJCQkkZGF0YSA9IGpzb25fZW5jb2RlKCRkYXRhKTsNCgkJfQ0KCQkvLyBtYWtlIHN1cmUgdGhpcyBpcyBhIHN0cmluZw0KCQlpZiAoU3VwZXJfX18xZjI4Y2I1M182MGQ5XzRkYjFfYjUxN18zYzdkYzZiNDI5ZWZfX19Qb3dlcjo6Y2hlY2soJGRhdGEpKQ0KCQl7DQoJCQkkZnAgPSBmb3BlbigkZnVsbFBhdGgsICd3Jyk7DQoJCQlmd3JpdGUoJGZwLCAkZGF0YSk7DQoJCQlmY2xvc2UoJGZwKTsNCgkJCXJldHVybiB0cnVlOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoJDQoJLyoqDQoJICogUmVtb3ZlIGZpbGUNCgkgKiANCgkgKiBAcGFyYW0gICBzdHJpbmcgICAkZGlyICBUaGUgcGF0aCB0byBmb2xkZXIgdG8gcmVtb3ZlDQoJICogQHBhcmFtICAgc3RyaW5nICAgJG5ld0ZpbGVOYW1lIHRoZSBuZXcgZmlsZSBuYW1lDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICAgVHJ1ZSBpbiBhbGwgaXMgcmVtb3ZlZA0KCSAqIA0KCSAqLw0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gcmVtb3ZlRmlsZSgkZGlyLCAkbmV3RmlsZU5hbWUpDQoJew0KCQlpZiAoaXNfZGlyKCRkaXIpKQ0KCQl7DQoJCQkvLyBidWlsZCB0aGUgb2xkIGZvbGRlciBuYW1lDQoJCQkkb2xkRmlsZU5hbWUgPSBleHBsb2RlKCdfXycsJG5ld0ZpbGVOYW1lKTsNCgkJCS8vIGxpdHRsZSBmaXggdG8gcmVtb3ZlIHRoaXMgaXRlbSBvbGQgZmlsZSBpZiBmb3VuZA0KCQkJJGZvdW5kID0gZ2xvYigkZGlyLicvJy4kb2xkRmlsZU5hbWVbMF0uJyonLiRvbGRGaWxlTmFtZVsyXS4nLmpzb24nKTsNCgkJCWlmIChTdXBlcl9fXzBhNTljNjVjXzlkYWZfNGJjOV9iYWY0X2UwNjNmZjllNmE4YV9fX1Bvd2VyOjpjaGVjaygkZm91bmQpICYmICgkZG9uZSA9IEBhcnJheV9tYXAoICJ1bmxpbmsiLCRmb3VuZCkpICE9PSBGQUxTRSkNCgkJCXsNCgkJCQlyZXR1cm4gdHJ1ZTsNCgkJCX0NCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ==', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdICgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10gKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdICgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdIChodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKSkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gbmV2ZXIgbWFraW5nIG9uZSBtaXN0YWtlIG9yIHRha2luZyBhbnkgY29mZmVlIGJyZWFrLikNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KKiojIyNhY3R1YWxIb3Vyc1NwZW50IyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxEYXlzU3BlbnQjIyMgRWlnaHQgSG91ciBEYXlzKiogKHRoZSBhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNwZW50KQ0KDQo+ICh3aXRoIHRoZSBmb2xsb3dpbmcgYnJlYWsgZG93bjoNCj4gKipkZWJ1Z2dpbmcgQCMjI2RlYnVnZ2luZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA0Ow0KPiAqKnBsYW5uaW5nIEAjIyNwbGFubmluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA3Ow0KPiAqKm1hcHBpbmcgQCMjI21hcHBpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gMTA7DQo+ICoqb2ZmaWNlIEAjIyNvZmZpY2VIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNjspDQoNCioqIyMjYWN0dWFsVG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsVG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqDQooYSB0b3RhbCBvZiB0aGUgcmVhbGlzdGljIHRpbWUgZnJhbWUgZm9yIHRoaXMgcHJvamVjdCkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gd2l0aCB0aGUgbm9ybWFsIGV2ZXJ5ZGF5IHJlYWxpdGllcyBhdCB0aGUgb2ZmaWNlLCB0aGF0IGluY2x1ZGVzIHRoZSBjb21wb25lbnQgcGxhbm5pbmcsIG1hcHBpbmcgJiBkZWJ1Z2dpbmcuKQ0KDQpQcm9qZWN0IGR1cmF0aW9uOiAqKiMjI3Byb2plY3RXZWVrVGltZSMjIyB3ZWVrcyoqIG9yICoqIyMjcHJvamVjdE1vbnRoVGltZSMjIyBtb250aHMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXSAoaHR0cHM6Ly93d3cudmRtLmlvL2pvb21sYS1jb21wb25lbnQtYnVpbGRlcikuDQo+IERldmVsb3BlZCBieSBbTGxld2VsbHluIHZhbiBkZXIgTWVyd2VdIChtYWlsdG86am9vbWxhQHZkbS5pbyk=', '', '', 'Expert Database', '', '', 'Expert Database', '', '', 1, '', 'https://www.vdm.io/updates/expertdatabase_update_server.xml', 'http://www.vdm.io', '', '6Yhb0wT+oV3orb5BRtGGXTErmcOt5zbG9qvp6gXBAKE=', '', '', 2, 1, '', 1, 61), -(28, 1, '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', '', 1, '', 1, '', 1, '', '', 1, '{}', 3, 1, 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.1.0', 'Copyright (C) 2015. All Rights Reserved', '2017-01-30 13:53:54', '', 'W5w/1yunFpPFY2FzYnFJShB59TlJQgDT6OKL7VpdsHw=', '6bgN5/SL8NYyDfXP9WkSciik8zsDc4IFiZR2CxAR4o4=', '', 'CQPzu/5seQ3SMX8Wwe2NTYuybly28gzpYdqcsH11vbo=', '', '', '', 1, '', 'Just a basic Questions & Answers.', 'joomla@vdm.io', '', 'https://vdm.bz/jcb-questions-and-answers', '+vgKi8pQvsX3FKwpeuyJjwhf0lQDrMgAJHxAhPeiXn6otdpQhSZjMH5GN4ZMKUAj/HRP3gI5RWbSrPg8iBTOkA==', '', 'a9f20ea4-e0f6-481e-874f-9eb9536d274c', 'images/vdm/QA500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Questions-and-Answers', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-05-27 00:47:00', 2, 'Questions and Answers', 'questionsanswers', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'CS8qKg0KCSogCXRoZSBnbG9iYWxzDQoJKiovDQoJcHJvdGVjdGVkIHN0YXRpYyAkcGFyYW1zOw0KCXByb3RlY3RlZCBzdGF0aWMgJHVzZXI7DQoJcHJvdGVjdGVkIHN0YXRpYyAkbG9ja2VyOw0KCXByb3RlY3RlZCBzdGF0aWMgJGJhc2lja2V5Ow0KDQoJLyoqDQoJKiAJc2V0IHRoZSBzZXNzaW9uIGRlZmF1bHRzIGlmIG5vdCBzZXQNCgkqKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIHNldFNlc3Npb25EZWZhdWx0cygpDQoJew0KCQkvLyBub3Rpbmcgc2V0IGZvciBub3cNCgl9DQoNCgkvKioNCgkgKiBAcGFyYW0gJGlkcw0KCSAqIEBwYXJhbSAkdHlwZQ0KCSAqIEByZXR1cm4gYXJyYXl8bnVsbA0KCSAqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0TmFtZXMoJGlkcywgJHR5cGUpDQoJew0KCQkvLyBzZXR1cCB0aGUgZ2V0IGFycmF5DQoJCSRnZXQgPSBhcnJheSgnYS5pZCcpOw0KCQlzd2l0Y2goJHR5cGUpDQoJCXsNCgkJCWNhc2UgJ2NhdGlkJzoNCgkJCQkvLyBzZXQgcmVsYXRlZCB2YWx1ZXMNCgkJCQkkZ2V0W10gPSAnYS50aXRsZSc7DQoJCQkJJHRhYmxlID0gJyNfX2NhdGVnb3JpZXMnOw0KCQkJYnJlYWs7CQkNCgkJfQ0KCQlpZiAoIWlzc2V0KCR0YWJsZSkgfHwgIVN1cGVyX19fMGE1OWM2NWNfOWRhZl80YmM5X2JhZjRfZTA2M2ZmOWU2YThhX19fUG93ZXI6OmNoZWNrKCRpZHMpKQ0KCQl7DQoJCQlyZXR1cm4gbnVsbDsNCgkJfQ0KCQkvLyBjaGVjayB0aGUgYXJyYXkgb2YgaWRzDQoJCWlmIChTdXBlcl9fXzBhNTljNjVjXzlkYWZfNGJjOV9iYWY0X2UwNjNmZjllNmE4YV9fX1Bvd2VyOjpjaGVjaygkaWRzKSkNCgkJew0KCQkJZm9yZWFjaCAoJGlkcyBhcyAkaWQpDQoJCQl7IA0KCQkJCWlmICghKGlzX251bWVyaWMoJGlkKSkpDQoJCQkJew0KCQkJCQlyZXR1cm4gbnVsbDsNCgkJCQl9IA0KCQkJfQ0KCQl9DQoJCS8vIG5vdyBsb2FkIGFsbCBjdXN0b20gdmFsdWVzDQoJCSRkYiA9IEZhY3Rvcnk6OmdldERCTygpOw0KCQkkcXVlcnkgPSAkZGItPmdldFF1ZXJ5KHRydWUpOw0KCQkkcXVlcnktPnNlbGVjdCgkZGItPnF1b3RlTmFtZSgkZ2V0KSk7DQoJCSRxdWVyeS0+ZnJvbSgkZGItPnF1b3RlTmFtZSgkdGFibGUsICdhJykpOw0KCQkkcXVlcnktPndoZXJlKCdhLmlkIElOICgnIC4gaW1wbG9kZSgnLCAnLCAkaWRzKSAuICcpJyk7DQoJCSRxdWVyeS0+d2hlcmUoJ2EucHVibGlzaGVkID0gMScpOw0KCQkkZGItPnNldFF1ZXJ5KCRxdWVyeSk7DQoJCSRkYi0+ZXhlY3V0ZSgpOw0KCQlpZiAoJGRiLT5nZXROdW1Sb3dzKCkpDQoJCXsNCgkJCSRpdGVtcyA9ICRkYi0+bG9hZE9iamVjdExpc3QoKTsNCgkJCSRidWNrZXQgPSBhcnJheSgpOw0KCQkJZm9yZWFjaCAoJGl0ZW1zIGFzICRpdGVtKQ0KCQkJew0KCQkJCXN3aXRjaCgkdHlwZSkNCgkJCQl7DQoJCQkJCWNhc2UgJ2NhdGlkJzoNCgkJCQkJCS8vIHNldCByZWxhdGVkIHZhbHVlcw0KCQkJCQkJJGJ1Y2tldFskaXRlbS0+aWRdID0gJGl0ZW0tPnRpdGxlOw0KCQkJCQlicmVhazsNCgkJCQl9DQoJCQl9DQoJCQlyZXR1cm4gJGJ1Y2tldDsNCgkJfQ0KCQlyZXR1cm4gbnVsbDsNCgl9DQoNCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGhhc0VkaXRBY2Nlc3MoJHJlY29yZElkLCAkdXNlcklkID0gbnVsbCwgJHRvID0gJ3F1ZXN0aW9uX2FuZF9hbnN3ZXInKQ0KCXsNCgkJaWYgKFN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKCR1c2VySWQpICYmICR1c2VySWQgaW5zdGFuY2VvZiBKVXNlcikNCgkJew0KCQkJJHVzZXIgPSAkdXNlcklkOw0KCQl9DQoJCWVsc2VpZiAoaXNfbnVtZXJpYygkdXNlcklkKSAmJiAkdXNlcklkID4gMCkNCgkJew0KCQkJJHVzZXIgPSBGYWN0b3J5OjpnZXRVc2VyKCR1c2VySWQpOw0KCQl9DQoJCWVsc2UNCgkJew0KCQkJJHVzZXIgPSBGYWN0b3J5OjpnZXRVc2VyKCk7DQoJCX0NCgkJaWYgKCR1c2VyLT5hdXRob3Jpc2UoJHRvLicuZWRpdCcsICdjb21fW1tbY29tcG9uZW50XV1dLicuJHRvLicuJyAuIChpbnQpICAkcmVjb3JkSWQpKQ0KCQl7DQoJCQlyZXR1cm4gdHJ1ZTsNCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ0KW0NVU1RPTUNPREU9dGhlQnV0bGVyXQ0KW0NVU1RPTUNPREU9aW1hZ2VIZWxwZXJzXQ0KW0NVU1RPTUNPREU9Z2V0Rm9sZGVyUGF0aF0NCltDVVNUT01DT0RFPWdldEZpbGVQYXRoXQ0KW0NVU1RPTUNPREU9bmljZUZhbmN5RGF0ZV0NCltDVVNUT01DT0RFPWJhc2VTaXh0eUZvdXJVUkxdDQpbQ1VTVE9NQ09ERT1zZXREeW5hbWljRGF0YUlGXQ0KW0NVU1RPTUNPREU9Z2V0TGlua09wdGlvbnNdDQpbQ1VTVE9NQ09ERT1taW1lVHlwZV0=', '', '', '', '', '', 'CQkvLyBsb2FkIHRoZSBoZWxwZXIgY2xhc3MNCgkJSkxvYWRlcjo6cmVnaXN0ZXIoJ1tbW0NvbXBvbmVudF1dXUhlbHBlcicsIEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX1tbW2NvbXBvbmVudF1dXS9oZWxwZXJzL1tbW2NvbXBvbmVudF1dXS5waHAnKTsNCgkJLy8gY2hlY2sgdGhlIHZlcnNpb24gb2YgUW5BDQoJCSRtYW5pZmVzdCA9IFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6bWFuaWZlc3QoKTsNCgkJaWYgKGlzc2V0KCRtYW5pZmVzdC0+dmVyc2lvbikgJiYgc3RycG9zKCRtYW5pZmVzdC0+dmVyc2lvbiwgJy4nKSAhPT0gZmFsc2UpDQoJCXsNCgkJCSR2ZXJzaW9uID0gZXhwbG9kZSgnLicsICRtYW5pZmVzdC0+dmVyc2lvbik7DQoJCQkvLyBHZXQgYSBkYiBjb25uZWN0aW9uLg0KCQkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCQkvLyB0YXJnZXQgdmVyc2lvbiBsZXNzIHRoZW4gb3IgZXF1YWwgdG8gMS4wLjMNCgkJCWlmIChjb3VudCgkdmVyc2lvbikgPT0gMyAmJiAkdmVyc2lvblswXSA9PSAxICYmICR2ZXJzaW9uWzFdID09IDAgJiYgJHZlcnNpb25bMl0gPD0gNCkNCgkJCXsNCgkJCQkvLyB3ZSBuZWVkIHRvIG1ha2UgYSBkYXRhYmFzZSBjb3JyZWN0aW9uDQoJCQkJJGZpeF9jYXRlZ29yaWVzID0gYXJyYXkoDQoJCQkJCSdjb21fcXVlc3Rpb25zYW5zd2Vycy5xdWVzdGlvbnNfYW5kX2Fuc3dlcnMnID0+ICdjb21fcXVlc3Rpb25zYW5zd2Vycy5xdWVzdGlvbl9hbmRfYW5zd2VyJw0KCQkJCSk7DQpbQ1VTVE9NQ09ERT1maXhDYXRlZ29yaWVzTmFtaW5nXQ0KCQkJfQ0KCQl9', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXShodHRwczovL2dpdGh1Yi5jb20vTGxld2VsbHludmRtL0pvb21sYS1RdWVzdGlvbnMtYW5kLUFuc3dlcnMvcmF3L21hc3Rlci9hZG1pbi9hc3NldHMvaW1hZ2VzL3ZkbS1jb21wb25lbnQuanBnICJUaGUgIyMjQ29tcG9uZW50X25hbWUjIyMiKQ0KDQojIyNERVNDUklQVElPTiMjIw0KDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkF1dGhvcio6IFsjIyNBVVRIT1IjIyNdKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCg0KIyBDb21wb25lbnQgTnVtYmVyDQoNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KW0NVU1RPTUNPREU9cmVhZE1FY29udHJpYnV0b3JzXQ==', '', '', 'Questions & Answers', '', '', 'Questions and Answers (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/Llewellynvdm/Joomla-Questions-and-Answers/master/questionsanswers_server.xml', 'https://www.vdm.io/', '', 'KzaMID78l8VUzhcvn64zaWH8zYrTFYKtsnTeY7CkXOw=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 70, '', 1, 7), -(29, 1, '', '', '', 1, '', '', '', 1, '', 1, 1, 1, '', '', '', '', '', '', 1, '', 1, '', '', '', '{}', 3, '', 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.1.1', 'Copyright (C) 2015. All Rights Reserved', '2017-03-02 01:16:34', 1, 'SPum2cLzUIYtL7B0+ssENc8brbn7pp6iBpbW0zLxMHo=', 'ewagRPPiNZsft15c4vz3DCDjtYsu+AKQw1SdqIdyEFw=', '', 'SLB9t4i32oC7pPDr+hk0B37QywO1uh10I3T8xRHAfvI=', '', '', 'A_76', 2, '', 'Event registration component.', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_registry', 'DNj5SxMf3DEhnKMVRBJfY9rvhxemC3cDMVbuWrWnBvRBmQWF+jpV/wkNfyjhfoNa8F4C2eOjtot7QDt7+E6NxA==', '', 'b7f99d5a-57ee-4d91-8470-dcee7d8fc5d6', 'images/vdm/ER500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-03-08 03:17:40', 2, 'Registry', 'registry', '', 4, 'CQkvLyBydW4gc29tZSBob3VzZSBjbGVhbmluZw0KCQlpZiAoc2VsZjo6bG9hZExvY2F0aW9uRGF0YSgpKQ0KCQl7DQoJCQkvLyBydW4gdGhlIGxvY2F0aW9uIGRhdGEgcXVldWUgKHRvIGluc3VyZSBhbGwgY3JvbiBqb2JzIHJ1biB0aW1lbHkpDQoJCQlpZiAoJGRvY3VtZW50IGluc3RhbmNlb2YgSkRvY3VtZW50SHRtbCkNCgkJCXsNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OnRoZVF1ZXVlKCRkb2N1bWVudCk7DQoJCQl9DQoJCX0NCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw0KCQkvLyBjbGVhciB0aGUgY2FydCBpdGVtcyBpZiBleHBpcmVkDQoJCXNlbGY6OmNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KTs=', 'CS8qKg0KCSogCW1ha2Ugc3VyZSBsb2NhdGlvbiBkYXRhIGlzIGxvYWRlZA0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gbG9hZExvY2F0aW9uRGF0YSgpDQoJew0KCQlpZiAoIWNsYXNzX2V4aXN0cygnTG9jYXRpb25kYXRhSGVscGVyJywgRkFMU0UpKQ0KCQl7DQoJCQkkcGF0aCA9IEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX2xvY2F0aW9uZGF0YS9oZWxwZXJzL2xvY2F0aW9uZGF0YS5waHAnOw0KCQkJaWYgKGZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJCXsNCgkJCQkvLyBtYWtlIHN1cmUgdG8gbG9hZCB0aGUgaGVscGVyDQoJCQkJSkxvYWRlcjo6cmVnaXN0ZXIoJ0xvY2F0aW9uZGF0YUhlbHBlcicsICRwYXRoKTsNCgkJCQkvLyBmaXN0IHNldCB0aGUgZGVmYXVsdCBjb21wb25lbnQNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OiRkZWZhdWx0Q29tcG9uZW50ID0gJ2NvbV9bW1tjb21wb25lbnRdXV0nOw0KCQkJCXJldHVybiB0cnVlOw0KCQkJfQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCXJldHVybiB0cnVlOw0KCX0NCg0KCS8qKg0KCSogCWNhbmNlbCBFeHBpcmVkIENhcnQgSXRlbXMNCgkqKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIGNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KQ0KCXsNCgkJLy8gYWRkIGFuIGV2ZW50IHRoYXQgd2lsbCBzZW5kIG91dCBhbGwgY29uZmlybWF0aW9uIGVtYWlscywgbm90IHlldCBzZW5kDQoJCSRkb2N1bWVudC0+YWRkU2NyaXB0RGVjbGFyYXRpb24oIg0KCQkJalF1ZXJ5KHdpbmRvdykubG9hZChmdW5jdGlvbigpIHsNCgkJCQljYW5jZWxFeHBpcmVkQ2FydEl0ZW1zKDEpLmRvbmUoZnVuY3Rpb24ocmVzdWx0KSB7DQoJCQkJCWlmKHJlc3VsdCl7DQoJCQkJCQljb25zb2xlLmxvZyhyZXN1bHQpOw0KCQkJCQl9DQoJCQkJfSk7DQoJCQl9KTsNCgkJCQ0KCQkJZnVuY3Rpb24gY2FuY2VsRXhwaXJlZENhcnRJdGVtcyh0eXBlKSB7DQoJCQkJdmFyIGdldFVybCA9ICciLlVyaTo6cm9vdCgpLiJhZG1pbmlzdHJhdG9yL2luZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ0YXNrPWFqYXguY2FuY2VsRXhwaXJlZENhcnRJdGVtcyZmb3JtYXQ9anNvbic7DQoJCQkJaWYodHlwZSA+IDApew0KCQkJCQl2YXIgcmVxdWVzdCA9ICd0b2tlbj0iLkpvb21sYV9fXzViYTM4NTEzXzVjNGZfNGIwZF85MzVlXzQ5ZTk4NmE2YmNlOF9fX1Bvd2VyOjpnZXRGb3JtVG9rZW4oKS4iJnR5cGU9Jyt0eXBlOw0KCQkJCX0NCgkJCQlyZXR1cm4galF1ZXJ5LmFqYXgoew0KCQkJCQl0eXBlOiAnUE9TVCcsDQoJCQkJCXVybDogZ2V0VXJsLA0KCQkJCQlkYXRhVHlwZTogJ2pzb25wJywNCgkJCQkJZGF0YTogcmVxdWVzdCwNCgkJCQkJanNvbnA6ICdjYWxsYmFjaycNCgkJCQl9KTsNCgkJCX0iKTsNCgl9', '	public static $event;
	public static $eventBuilder = array();
	public static $conceptHTML = array();
	public static $locations = array();
	public static $filterInput;
	public static $organizer = null;
	public static $registered = null;

	protected static $eventOptions = array('display' => array(), 'options' => array());
	protected static $disableButtons = array();
	protected static $disableButtonsCheck = array();
	protected static $conceptSwitchOnly = array();
	protected static $bundleSwitchOnly = array();
	protected static $concepts = array();
	protected static $conceptData = array();
	protected static $contentData = array();
	protected static $buttonScript = array(' ');
	protected static $returnType;
	protected static $filepath = '';
	protected static $filelink = '';
	protected static $params;
	protected static $user;
	protected static $locker;
	protected static $basickey;

	protected static $eventFields = array();
[CUSTOMCODE=theButler]
[CUSTOMCODE=getHTML]
	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// get user object
		$user = Factory::getUser();
		// first check if any was already set
		if (!$currency = self::get('ACTIVE_CURRENCY', null))
		{
			if ($user->id > 0)
			{
				// set the active users currency
				self::set('ACTIVE_CURRENCY', self::getUserCurrency($user));
			}
			else
			{
				// set public currency
				self::set('ACTIVE_CURRENCY', self::getPublicCurrency());
			}
		}
		// set public key if needed
		if ( $user->id == 0)
		{
			if (!$public = self::get('publicKeeY', null))
			{
				// set the active users public
				self::set('publicKeeY', self::randomkey(7));
			}
		}
	}

	/**
	 *	To load the application form
	 */
	public static function getPaperWork($id, $keys)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
		}
		// get forms path
		$path = self::$params->get('xmlpath', JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/models/forms');
		// build full path to file
		$fileName = 'vdm_dynamic_form';
		$fullPath = $path.'/'.$fileName.'.xml';
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$user))
		{
			// set current user
			self::$user = Factory::getUser();
		}
		// check if file exists
		if (!file_exists($fullPath))
		{
			// great the file and safe to path
			self::setDynamicFormXML($fullPath, $path);
		}
		// check if file exists
		if (file_exists($fullPath))
		{
			// Get the form.
			jimport( 'joomla.form.form' );
			// set the paths
			JForm::addFormPath($path);
			JForm::addFieldPath(JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/models/fields');
			// great we are done return results
			$form = JForm::getInstance('com_[[[component]]].'.$fileName, $fileName, array('control' => 'jform', 'load_data' => false), false, false);
			if (self::$user->id == 0)
			{
				// add the user fields
				self::addUserFields($form);
			}
			// load the dynamic field
			self::getDynamicFields($id, $keys, $form);
			// now load the data
			$data = self::get('formData'.$id);
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
			{
				$form->bind($data);
			}
			return self::modelForm($form);
		}
		return false;
	}

	/**
	 *	Model the form display
	 */
	protected static function modelForm(&$form)
	{
		return 'soon we will add more html here!';
	}

	/**
	 *	Get the dynamic fields
	 */
	protected static function getDynamicFields($id, $build, &$form)
	{
		// get the form selection
		$formBuilder = json_decode(self::base64_urldecode($build, true), true);
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($formBuilder))
		{
			// loop the events
			self::$eventFields = array();
			foreach ($formBuilder as $event => $builder)
			{
				// get all custom fields of event
				if ($fields = self::getVar('event', (int) $event, 'id', 'customfield'))
				{
					if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($fields))
					{
						$fields = json_decode($fields, true);
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($fields))
					{
						// okay so we have custom fields
						self::setDynamicFields($event, $builder, $fields);
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventFields))
			{
				var_dump(self::$eventFields);exit;
			}
		}
		return true;
	}

	/**
	 *	Set the dynamic fields
	 */
	protected static function setDynamicFields(&$event, &$builder, &$fields)
	{
		foreach ($fields['field'] as $nr => $field)
		{
			// first load those based on variation
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($fields['variation'][$nr]))
			{
				// only add it if the variation is selected
				if ($variations = array_intersect($builder['variation'], $fields['variation'][$nr]))
				{
					$qty = array();
					foreach ($variations as $variation)
					{
						$vNr = array_search($variation, $builder['variation']);
						self::setDynamicField($event, $field,  $builder['qty'][$vNr], $fields['each_registration'][$nr], $builder['switch'][$vNr], $builder['concept'][$vNr], $builder['bundle'][$vNr], $builder['variation'][$vNr]);
					}
				}
			}
			else
			{
				// add all fields not linked to variations
				self::setDynamicField($event, $field, array_sum($builder['qty']), $fields['each_registration'][$nr]);
			}
		}
		exit;
	}

	/**
	 *	Set the dynamic field
	 */
	protected static function setDynamicField($event, $id, $qty, $each, $switch = null, $concept = 0, $bundle = 0, $variation = 0)
	{
		// start event field array
		if (!isset(self::$eventFields[$event]))
		{
			self::$eventFields[$event] = array();
		}
		// get the field
		$field = self::getField($id);
		var_dump($field);
	}

	/**
	 *	get the field
	 */
	protected static function getField($id)
	{
		// get database values of this field
		$db = self::getAllValues($id, 'custom_field');
		If (isset(self::$fieldTypes[$db->field_type]))
		{
			$field = array();
			foreach (self::$fieldTypes[$db->field_type] as $key => $value)
			{
				if (isset($db->{$key}))
				{
					$field[$key] = $db->{$key};
				}
				else
				{
					$field[$key] = $value;
				}
			}
			// do some extra prep
			if ($db->field_type == 11 && isset($db->defaultcountry))
			{
				// load the correct country default value
				$field['default'] = $db->defaultcountry;
			}
			elseif ($db->field_type == 17 && isset($db->defaultregion))
			{
				// load the correct region default value
				$field['default'] = $db->defaultregion;
			}
			elseif (($db->field_type == 1 || $db->field_type == 2) && (isset($db->selection) && isset($db->selectiontype)))
			{
				// build the options array
				self::setFieldOptions($field, $db);
			}
			return $field;
		}
		return false;
	}

	/**
	 *	Set the options for the field
	 */
	protected static function setFieldOptions(&$field, &$db)
	{
		// set the selection option
		if ($db->field_type == 2 && $db->selectiontype == 2)
		{
			$field['multiple'] = 'true';
			$field['filter'] = 'ARRAY';
		}
		elseif ($db->field_type == 2 && $db->selectiontype == 1)
		{
			$field['multiple'] = 'false';
		}
		// set options
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($db->selection))
		{
			$db->selection = json_decode($db->selection, true);
		}
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($db->selection))
		{
			$options = array();
			foreach($db->selection['selection'] as $selection)
			{
				self::setFieldOption($selection, $options);
			}
			// load the options
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($options))
			{
				$field['options'] = $options;
			}
		}
	}

	/**
	 *	Set the option for the field
	 */
	protected static function setFieldOption($selection, &$options)
	{
		if (strpos($selection,'|') !== false)
		{
			$array_setter = explode('|', $selection);
			if (count($array_setter) == 2)
			{
				if (is_numeric($array_setter[0]) || Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($array_setter[0]))
				{
					$options[$array_setter[0]] = $array_setter[1];
				}
				else
				{
					$options[''] = $array_setter[1];
				}
			}
			elseif (count($array_setter) == 1)
			{
				$options[''] = $array_setter[0];
			}
			else
			{
				if (is_numeric($selection) || Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($selection))
				{
					$options[$selection] = $selection;
				}
			}
		}
		else
		{
			if (is_numeric($selection) || Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($selection))
			{
				$options[$selection] = $selection;
			}
		}
	}

	/**
	 *	Set the dynamic base form xml
	 */
	protected static function setDynamicFormXML($fullPath, $path)
	{
		// always reset
		$fieldSet = array();
		// set the default fields
		$fieldSet[] = '<?xml version="1.0" encoding="utf-8"?>';
		$fieldSet[] = '<form addfieldpath="/administrator/components/com_[[[component]]]/models/fields">';
		$fieldSet[] = '<fieldset name="default">';
		$fieldSet[] = "\t<!-- Just to have a form to start with. -->";
		$fieldSet[] = "</fieldset>";
		$fieldSet[] = "</form>";
		// set the form
		$form = implode("\n",$fieldSet);
		// set the file
		return self::saveXML($form, $fullPath, $path);
	}

	/**
	* 	save XML
	**/
	public static function saveXML($data, $fullPath, $path)
	{
		// check if path exists
		if (!file_exists($path))
		{
			// if not the make the path
			mkdir($path, 0755, true);
		}
		libxml_use_internal_errors(true);
		// make sure this is valid xml
		if (simplexml_load_string($data))
		{
			$fp = fopen($fullPath, 'w');
			fwrite($fp, $data);
			fclose($fp);
			return true;
		}
		
		// set error
		JError::raiseWarning(500, Text::_('The xml for this from could not be validated, please notify the system administrator.'));
		return false;
	}

	/**
	 *	Add user fields to application
	 */
	protected static function addUserFields(&$form)
	{
		// we must add some user fields
		$userFields =
			array(
				'name' =>
					array('name','username','email','password','password2', 'captcha'),
				'type' =>
					array('text','text','email','password','password','captcha'),
				'label' =>
					array(Text::_('Name'), Text::_('Username/Login-name'), Text::_('Email'), Text::_('Password'), Text::_('Confirm Password'), Text::_('ReCaptcha')),
				'description' =>
					array(Text::_('Your Full Name'), Text::_('Set the username/login-name of your choice.'), Text::_('Your Email Address'), Text::_('Use at least 6 characters, upper-case and lower-case letter, numbers and at least one special character.'), Text::_('Confirm Password'), Text::_('Just checking that your not a robot.')),
				'hint' =>
					array(Text::_('Your Full Name'), Text::_('Username'), 'your@email.com',null,null,null),
				'class' =>
					array('text_area','text_area','text_area','text_area','text_area',null),
				'validate' =>
					array(null, null, 'email', null, null, 'captcha'),
				'filter' =>
					array('string', 'string', 'email', null, null,null),
				'field' =>
					array(null, null, null, 'password2', null, null)
			);
		$addReCaptcha = Factory::getConfig()->get('captcha');
		// now loop the fields and add to form
		foreach ($userFields['name'] as $nr => $name)
		{
			// build the field
			$xml = array();
			// only load ReCaptcha if turned on in system
			if ('captcha' != $name || $addReCaptcha)
			{
				$xml[] = '<field ';
				$xml[] = 'type="'.$userFields['type'][$nr].'" ';
				$xml[] = 'name="'.$name.'" ';
				if ($userFields['label'][$nr])
				{
					$xml[] = 'label="'.$userFields['label'][$nr].'" ';
				}
				if ($userFields['description'][$nr])
				{
					$xml[] = 'description="'.$userFields['description'][$nr].'" ';
				}
				if ($userFields['class'][$nr])
				{
					$xml[] = 'class="'.$userFields['class'][$nr].'" ';
				}
				if ('captcha' != $name)
				{
					$xml[] = 'required="true" ';
				}
				if ($userFields['filter'][$nr])
				{
					$xml[] = 'filter="'.$userFields['filter'][$nr].'" ';
				}
				if ($userFields['validate'][$nr])
				{
					$xml[] = 'validate="'.$userFields['validate'][$nr].'" ';
				}
				if ($userFields['field'][$nr])
				{
					$xml[] = 'field="'.$userFields['field'][$nr].'" ';
				}
				if ($userFields['hint'][$nr])
				{
					$xml[] = 'hint="'.$userFields['hint'][$nr].'" ';
				}
				$xml[] = '/>';
				// set the field
				$form->setField( simplexml_load_string(implode("\n", $xml)));
			}
		}
	}

	/**
	* 	fieldTypes Default Settings
	**/
	public static $fieldTypes = array(
			1 => array(
				'type' => 'radio', 
				'default' => '',
				'description' => '',
				'class' => 'btn-group btn-group-yesno',
				'options' => array('Yes','No'),
				'filter' => 'word', 
				'required' => 'true',
				'message' => '',
				'showon' => ''),
			2 => array(
				'type' => 'list', 
				'default' => '',
				'description' => '',
				'class' => 'list_class',
				'multiple' => 'false',
				'options' => array(),
				'filter' => 'int', 
				'validate' => '',
				'required' => 'true',
				'message' => '',
				'showon' => '' ),
			3 => array(
				'type' => 'editor', 
				'description' => '',
				'default' => '',
				'width' => '100%', 
				'height' => '500px', 
				'filter' => 'safehtml', 
				'required' => 'true',
				'buttons' => 'false',
				'message' => '',
				'hide' => '',
				'editor' => 'jce|none',
				'rows' => '',
				'cols' => '',
				'showon' => ''),
			4 => array(
				'type' => 'textarea',
				'default' => '',
				'description' => '',
				'maxlength' => '1400',
				'class' => 'text_area uk-width-1-1',
				'width' => '100%', 
				'height' => '500px', 
				'filter' => 'string', 
				'validate' => '',
				'required' => 'true',
				'message' => '',
				'hint' => '',
				'rows' => '20',
				'cols' => '10',
				'showon' => ''),
			5 => array(
				'type' => 'text', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'filter' => 'string', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			6 => array(
				'type' => 'url', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			7 => array(
				'type' => 'email', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			8 => array(
				'type' => 'tel', 
				'description' => '',
				'class' => 'text_area',
				'autocomplete' => 'on',
				'validate' => '', 
				'field' => '',
				'size' => '60', 
				'maxlength' => '150', 
				'required' => 'true',
				'hint' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			9 => array(
				'type' => 'calendar', 
				'description' => '',
				'class' => 'text_area',
				'size' => '60', 
				'maxlength' => '150',
				'filter' => 'server_utc', 
				'required' => 'true',
				'format' => '%d-%m-%Y',
				'message' => '',
				'default' => '',
				'showon' => ''),
			10 => array(
				'type' => 'color', 
				'description' => '',
				'class' => 'text_area',
				'size' => '60', 
				'maxlength' => '150',
				'filter' => 'string', 
				'required' => 'true',
				'message' => '',
				'default' => '',
				'showon' => ''),
			11 => array(
				'type' => 'countryname', 
				'description' => '',
				'class' => 'list_class',
				'filter' => 'string', 
				'required' => 'true',
				'message' => '',
				'default' => '',
				'showon' => ''),
			12 => array(
				'type' => 'hidden', 
				'class' => 'text_hidden', 
				'filter' => 'int', 
				'required' => 'true',
				'default' => '1' ),
			13 => array(
				'type' => 'file', 
				'description' => '',
				'class' => 'text_area',
				'size' => '60', 
				'filter' => '', 
				'required' => 'true',
				'accept' => 'image/*',
				'message' => '',
				'showon' => ''),
			14 => array(
				'type' => 'note', 
				'description' => '',
				'heading' => 'h4',
				'class' => 'alert',
				'close' => '',
				'showon' => ''),
			15 => array(
				'type' => 'spacer', 
				'description' => '',
				'hr' => 'true',
				'class' => 'text_area',
				'showon' => ''),
			16 => array(
				'type' => 'note', 
				'description' => '',
				'heading' => 'h4',
				'class' => 'text_area',
				'showon' => ''),
			17 => array(
				'type' => 'regionname', 
				'description' => '',
				'class' => 'list_class',
				'filter' => 'string', 
				'required' => 'true',
				'message' => '',
				'default' => '',
				'showon' => ''),
			30 => array(
				'type' => 'password', 
				'description' => '',
				'class' => 'validate-password',
				'size' => '60', 
				'maxlength' => '150', 
				'filter' => 'raw', 
				'validate' => 'password', 
				'required' => 'true',
				'autocomplete' => 'off',
				'field' => '',
				'message' => '',
				'default' => '',
				'showon' => ''),
			31 => array(
				'type' => 'captcha', 
				'description' => '',
				'validate' => 'captcha', 
				'namespace' => '')
			);
[CUSTOMCODE=userIsThree+adminuser,organizeruser,registereduser,organizer,registered_user]
	/**
	* 	the public currency
	**/
	protected static $usersCurrency = array();

	/**
	* 	get the user currency
	**/
	public static function getUserCurrency($userId = null)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($userId) && $userId instanceof JUser)
		{
			$user = $userId;
		}
		elseif (is_numeric($userId) && $userId > 0)
		{
			$user = Factory::getUser($userId);
		}
		else
		{
			$user = Factory::getUser();
		}
		// only set again if not found
		if (!isset(self::$usersCurrency[$user->id]))
		{
			$array = (array) self::userIs($user, true);
			// set in relation
			switch($array['is'])
			{
				// admin use global
				case 3: 
				self::$usersCurrency[$user->id] = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('currency', 'USD');
				break;
				// organizer currency
				case 2:
				self::$usersCurrency[$user->id] = self::getVar('organizer', $array['id'], 'id',  'currency');
				break;
				// registered user currency
				case 1:
				self::$usersCurrency[$user->id] = self::getRegUserValue($array['id'], 'currency_codethree', self::getPublicCurrency());
				break;
				// all other gets the public
				default:
				return self::getPublicCurrency();
				break;
			}
		}
		return self::$usersCurrency[$user->id];
	}

	/**
	* 	the event currency
	**/
	protected static $eventCurrency = array();

	/**
	* 	get the user currency
	**/
	public static function getEventCurrency($id = null)
	{
		if (is_numeric($id) && $id > 0)
		{
			$event = (int) $id;
		}
		elseif (isset(self::$event->id) && self::$event->id > 0)
		{
			$event = (int) self::$event->id;
		}
		elseif (!$id && isset(self::$event->organizer) && self::$event->organizer > 0)
		{
			if ($currency = self::getVar('organizer', self::$event->organizer, 'id', 'currency'))
			{
				return $currency;
			}
		}
		else
		{
			// return default currency of the current user
			return self::getUserCurrency();
		}
		// check if already set
		if (!isset(self::$eventCurrency[$event]))
		{
			// get event organizer
			if (!$id && isset(self::$event->organizer) && self::$event->organizer > 0)
			{
				if ($currency = self::getVar('organizer', self::$event->organizer, 'id', 'currency'))
				{
					self::$eventCurrency[$event] = $currency;
				}
			}
			elseif ($orgId = self::getVar('event', $event, 'id', 'organizer'))
			{
				if ($currency = self::getVar('organizer', $orgId, 'id', 'currency'))
				{
					self::$eventCurrency[$event] = $currency;
				}
			}
		}
		// return if found
		if (isset(self::$eventCurrency[$event]))
		{
			return self::$eventCurrency[$event];
		}
		return false;
	}


	/**
	* 	the public currency
	**/
	protected static $publicCurrency = 'set';

	/**
	* 	set the public/default currency
	**/
	public static function getPublicCurrency()
	{
		if ('set' === self::$publicCurrency)
		{
			// get this location data
			$locationData = self::getLocationdata();
			// check if we have location data
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($locationData) && isset($locationData['CURRENCY_CODE_THREE']))
			{
				self::$publicCurrency = $locationData['CURRENCY_CODE_THREE'];
			}
			else
			{
				// fall over to your component default currency
				self::$publicCurrency = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]')->get('currency', 'USD');
			}
		}
		return self::$publicCurrency;
	}

	/**
	* 	The owner
	**/
	protected static $owner = array();

	/**
	* 	array to check user
	**/
	protected static $checkUser = array();

	/**
	* 	wants to edit
	**/
	protected static $viewAccess;

	public static function hasAccess($recordId, $userId = null, $to = 'event', $viewAccess = false)
	{
		// set if view access is all that is required 
		self::$viewAccess = $viewAccess;
		if(!$userId)
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$user))
			{
				// set current user
				self::$user = Factory::getUser();
			}
			$userId = self::$user->id;
		}
		$array = (array) self::userIs($userId, true);
		if (isset($array['is']) && $array['is'] && $recordId > 0)
		{
			switch($to)
			{
				case 'event':
					return self::accessEvent($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'venue':
					return self::accessVenue($array['is'], $recordId, $userId);
				break;
				case 'organizer':
					return self::accessOrganizer($array['is'], $recordId, $userId);
				break;
				case 'invoice':
					return self::accessInvoice($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'payment_method':
					return self::accessPaymentMethod($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'tax_rule':
					return self::accessTaxRule($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'messages_builder':
					return self::accessMessagesBuilder($array['is'], $recordId, $array['id'], $userId);
				break;
				case 'concept':
					return self::accessConcept($array['is'], $recordId, $userId);
				break;
				case 'content':
					return self::accessContent($array['is'], $recordId, $userId);
				break;
				case 'bundle':
					return self::accessBundle($array['is'], $recordId, $userId);
				break;
			}
		}
		return false;
	}

	protected static function accessEvent($type, $recordId, $orgId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['event'.$recordId] = self::getVar('event', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['event'.$recordId] == $orgId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('event.edit', 'com_[[[component]]].event.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessVenue($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['venue'.$recordId]))
				{
					// load the owner
					self::$owner['venue'.$recordId] = self::getVar('venue', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['venue'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('venue.edit', 'com_[[[component]]].venue.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessOrganizer($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['organizer'.$recordId]))
				{
					// load the owner
					self::$owner['organizer'.$recordId] = self::getVar('organizer', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['organizer'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('organizer.edit', 'com_[[[component]]].organizer.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessInvoice($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the event owner
				if (!isset(self::$owner['invoice'.$recordId]))
				{
					// load the owner
					self::$owner['invoice'.$recordId] = self::getVar('invoice', $recordId, 'id', 'organizer');
				}
			break;
			default: // set the default to
				return false;
			break;
		}
		// only true if owner is the same as user
		if (self::$owner['invoice'.$recordId] == $localId)
		{
			if (self::$viewAccess)
			{
				return true;
			}
			// get the global settings
			if (!isset(self::$checkUser[$userId]))
			{
				// set current user
				self::$checkUser[$userId] = Factory::getUser($userId);
			}
			return self::$checkUser[$userId]->authorise('invoice.edit', 'com_[[[component]]].invoice.' . (int)  $recordId);
		}
		return false;
	}

	protected static function accessPaymentMethod($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['payment_method'.$recordId]))
				{
					// load the owner
					self::$owner['payment_method'.$recordId] = self::getVar('payment_method', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['payment_method'.$recordId] == $localId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('payment_method.edit', 'com_[[[component]]].payment_method.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessTaxRule($type, $recordId, $localID, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['event'.$recordId] = self::getVar('tax_rule', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['event'.$recordId] == $localID)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('payment_method.edit', 'com_[[[component]]].payment_method.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessMessagesBuilder($type, $recordId, $localId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['messages_builder'.$recordId] = self::getVar('messages_builder', $recordId, 'id', 'organizer');
				}
				// only true if owner is the same as user
				if (self::$owner['messages_builder'.$recordId] == $localId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('messages_builder.edit', 'com_[[[component]]].messages_builder.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessConcept($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['concept'.$recordId] = self::getVar('concept', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['concept'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('concept.edit', 'com_[[[component]]].concept.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	protected static function accessContent($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['event'.$recordId]))
				{
					// load the owner
					self::$owner['concept'.$recordId] = self::getVar('concept', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['concept'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('concept.edit', 'com_[[[component]]].concept.' . (int)  $recordId);
				}
			break;
		}
		return false;
		return self::$user->authorise('content.edit', 'com_[[[component]]].content.' . (int)  $recordId);
	}

	protected static function accessBundle($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organizer is the owner
				if (!isset(self::$owner['bundle'.$recordId]))
				{
					// load the owner
					self::$owner['bundle'.$recordId] = self::getVar('bundle', $recordId, 'id', 'created_by');
				}
				// only true if owner is the same as user
				if (self::$owner['bundle'.$recordId] == $userId)
				{
					if (self::$viewAccess)
					{
						return true;
					}
					// get the global settings
					if (!isset(self::$checkUser[$userId]))
					{
						// set current user
						self::$checkUser[$userId] = Factory::getUser($userId);
					}
					return self::$checkUser[$userId]->authorise('bundle.edit', 'com_[[[component]]].bundle.' . (int)  $recordId);
				}
			break;
		}
		return false;
	}

	public static function hisItems($table, $userId = null)
	{
		if($userId > 0)
		{
			$array = (array) self::userIs($userId, true);
		}
		else
		{
			$array = (array) self::userIs(Factory::getUser()->id, true);
		}
		// return in relation
		switch($array['is'])
		{
			// registered (only load items that belong to the registered user)
			case 1:
			return self::getVars($table, $array['id'], 'registered_user');
			break;
			// organizer (only load items that belong to the organizer)
			case 2:
			return self::getVars($table, $array['id'], 'organizer');
			break;
			// admin can access all
			case 3: 
			return -1;
			break;
		}
		return false;
	}

	protected static $LocationdataHelper = false; 

	/**
	* 	Load the data for IP and Currency 
	**/
	public static function getLocationdata($ip = null, $protocol = null, $key = null, $base = 'USD', $mode = 0, $string = 0, $value = 1.00)
	{		
		if (self::loadLocationData())
		{
			return LocationdataHelper::getLocationdata($ip, $protocol, $key, $base, $mode, $string, $value);
		}
		return false;
	}

	/**
	 * returns ExchangeRates
	 *
	 * @return string
	 */
	public static function getExchangeRate($from, $fromValue, $to = 'USD')
	{
		if (self::loadLocationData())
		{
			return LocationdataHelper::getExchangeRate($from, $fromValue, $to);
		}
		return false;
	}

	/**
	 * @param $data
	 * @param $type
	 * @return bool|string
	 */
	public static function getEvent($event, $type)
	{
		// if only id given get the object
		if (is_numeric($event) && $event > 0 )
		{
			$event = self::getAllValues($event, 'event', array('event_documents','banner_image','poster_image','teaser_image','event_images'));
		}
		// check if we have the event object, make sure we have the needed data
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($event))
		{
			// make sure we have the needed dates
			if (isset($event->date) && 'nee' != $event->date && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->date))
			{
				$event->date = json_decode($event->date, true);
			}
			// make sure we have the needed cost
			if (isset($event->cost) && 'nee' != $event->cost && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->cost))
			{
				$event->cost = json_decode($event->cost, true);
			}
			// make sure important data was set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event->cost) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event->date))
			{
				// set adjustments
				if (isset($event->adjustment) && 'nee' != $event->adjustment && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->adjustment))
				{
					$event->adjustment = json_decode($event->adjustment, true);
				}
				// set limit per group
				if (isset($event->limitpergroup) && 'nee' != $event->limitpergroup && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($event->limitpergroup))
				{
					$event->limitpergroup = json_decode($event->limitpergroup, true);
				}
				// final check
				if (	isset($event->type) && is_numeric($event->type) &&
					isset($event->id) && is_numeric($event->id))
				{
					self::$event = $event;
					// date or just cost
					return self::eventBuilder($type);
				}
			}
		}
		return false;
	}

	/**
	 * @param $returnType
	 * @return bool|string
	 */
	protected static function eventBuilder($returnType)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
		}
		// set the return type
		self::$returnType = $returnType;
		// setup a filterInput
		self::$filterInput = new JFilterInput();
		// set the file path
		self::$filepath = self::getFolderPath();
		// now add the url path to show the image
		self::$filelink = self::getFolderPath('url');
		// Get the basic encryption.
		self::$basickey = self::getCryptKey('basic');
		// Get the encryption object.
		self::$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power(self::$basickey, 128);
		// reset global
		$timeSet = false;
		// load concept per date
		if (self::setDates())
		{
			$timeSet = true;
		}
		// load concept per cost
		elseif (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']))
		{
			self::$concepts = array_unique(array_filter(self::$event->cost['concept']));
		}
		// check bundler
		self::setBundler();
		if (isset(self::$concepts) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$concepts))
		{
			// build concepts
			foreach (self::$concepts as $event_concept_time => $concept)
			{
				if (!$timeSet)
				{
					$event_concept_time = self::$event->id.'_'.$concept.'__0';
				}
				// build concept div
				self::$conceptHTML[$event_concept_time] = self::buildConcept($concept,$event_concept_time);
			}

			// load orphan price variations
			if (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']))
			{
				self::loadOrphanVariations();
			}

			if (self::$returnType == 'admin' || self::$returnType == 'site')
			{
				// build the Display Content
				$content = array();
				$content[] = '<div id="preview" class="wire-border"><div class="uk-grid"><div class="uk-panel uk-width-1-1">';

				// set the Event Start and End Date
				if (isset(self::$eventBuilder['start-end']))
				{
					$content[] = '<div class="event-start-end">'.self::$eventBuilder['start-end'].'</div>';
				}
				// set event name
				if (self::$event->id > 0)
				{
					$edit = (self::$returnType == 'site') ? self::loadEditButton('event',self::$event->id) : '';
					$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' class="uk-visible-hover-inline"' : '';
					self::$event->name = self::loadName('event',self::$event->id);
					$content[] = '<h2'.$editClass.'>'. self::$event->name . $edit .'</h2>';
				}
				else
				{
					self::$event->name = Text::_('The Event Name');
					$content[] = '<h2><span id="eventName">'. self::$event->name .'</span></h2>';
				}
				// now load the banner
				if ($banner = self::getEventImage('banner_image', 1, self::$event->name, 'uk-thumbnail uk-margin'))
				{
					$content[] = $banner;
				}
				// set event details
				if (isset(self::$event->details) &&  Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->details))
				{
					$content[] = self::$event->details;
				}
				else
				{
					$content[] = '<p>'.Text::_('The event details come here').', lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor.</p>';
				}
				// load the concepts
				$content[] = self::loadConceptLayout();

				if (self::$returnType == 'admin')
				{
					// add dummy buy button
					$content[] = '<div class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel">';
					$content[] = '<button class="uk-button uk-button-large uk-width-1-1 uk-button-success" type="button" onclick="alert(\'Cart not active in admin area\');"> ';
					$content[] = Text::_('Total');
					$content[] = ': <span id="total">0.00</span> - ';
					$content[] = Text::_('Buy Now');
					$content[] = '</button>';
					$content[] = '</div></div></div>';
				}
				elseif (self::$returnType == 'site')
				{
					// the real shopping cart button
					$content[] = '<div class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel">';
					$content[] = '<div class="cart-active-buttons uk-button-group uk-width-1-1" style="display: none;">';
					$content[] = '<a class="uk-button uk-button-large uk-width-1-4 uk-button-primary" href="#VDM-view-cart-now" data-uk-modal><i class="uk-icon-eye"></i> <span class="uk-hidden-small">';
					$content[] = Text::_('View Cart');
					$content[] = '</span></a>';
					$content[] = '<a class="uk-button uk-button-large uk-width-3-4 uk-button-success" href="'. Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_([[[Component]]]HelperRoute::getCheckoutRoute()) .'"><span class="VDM-cart-total"></span> <span class="uk-hidden-small">';
					$content[] = Text::_('Check Out');
					$content[] = '</span> <i class="uk-icon-shopping-cart"></i></a></div>';
					$content[] = '<div class="cart-inactive-button">';
					$content[] = '<a class="uk-button uk-button-large uk-width-1-1 uk-button-primary" href="#VDM-view-cart-now" data-uk-modal><i class="uk-icon-eye"></i> <span class="uk-hidden-small">';
					$content[] = Text::_('View Empty Cart');
					$content[] = '</span></a></div>';
					$content[] = '</div></div></div>';
				}

				$content[] = '</div></div></div>';


				if (self::$returnType == 'admin')
				{
					// add some script;
					$script = array();
					$script[] = '<script type="text/javascript">';
					$script[] = 'var total = {};';
					$script[] = 'var available = {};';
					$script[] = 'var taken = {}; var tickets = {};';
					$script[] = 'var capacity = '.self::$event->capacity.';';
					$script[] = 'jQuery("#eventName").text(jQuery("#jform_name").val());';
					$script[] = 'jQuery(document).ready(function($) {';
					$script[] = 'jQuery(".select-button").click(function() {';
					$script[] = 'var button = this.id.split("-");';
					$script[] = 'var currentValue = jQuery("#"+button[0]+"-number").data("qty");';
					$script[] = 'if (button[1] == "plus") {';
					$script[] = 'var newValue = 1 + +currentValue;';
					$script[] = 'if (tickets.hasOwnProperty(button[0])) {';
					$script[] = 'taken[button[0]] = newValue;';
					$script[] = 'var totalTaken = sum(taken);';
					$script[] = 'if (capacity != 0 && totalTaken > capacity) {';
					$script[] = 'newValue = newValue - 1;';
					$script[] = 'taken[button[0]] = newValue;';
					$script[] = 'UIkit2.notify("The Event Is Full.", {status:\'warning\'});';
					$script[] = '}}';
					$script[] = 'if (available.hasOwnProperty(button[0]) && available[button[0]] != 0 && newValue == available[button[0]]) {';
					$script[] = 'UIkit2.notify("This Option is Full.", {status:\'warning\'}); jQuery("#"+button[0]+"-plus").attr("disabled", "disabled");';
					$script[] = '}';
					$script[] = '} else if (button[1] == "minus" && currentValue != 0) {';
					$script[] = 'var newValue = +currentValue - 1;';
					$script[] = 'taken[button[0]] = newValue; jQuery("#"+button[0]+"-plus").removeAttr("disabled");';
					$script[] = '} else if (button[1] == "select") {';
					$script[] = 'var pressed = jQuery(this).data("selection");';
					$script[] = 'if (pressed == 1) {';
					$script[] = 'var newValue = 1; jQuery(this).data("selection", 2);';
					$script[] = '} else {';
					$script[] = 'var newValue = 0; jQuery(this).data("selection", 1);';
					$script[] = '}';
					$script[] = '} else {';
					$script[] = 'var newValue = 0;';
					$script[] = '}';
					$script[] = 'if(jQuery(this).data("only")) { onlySwitch(this,newValue); }';
					$script[] = 'totalSetter(this,newValue);';
					$script[] = 'if (button[1] == "minus" || button[1] == "plus") {';
					$script[] = 'jQuery("#"+button[0]+"-number").data("qty", newValue);';
					$script[] = 'if (newValue == 0) {';
					$script[] = 'newValueHTML = 0;';
					$script[] = '} else {';
					$script[] = 'newValueHTML = \'<span class="uk-badge uk-badge-notification uk-badge-success">\'+newValue+\'</span>\';';
					$script[] = '}';
					$script[] = 'jQuery("#"+button[0]+"-number").html(newValueHTML);';
					$script[] = '}';
					$script[] = '});});';
					$script[] = implode('',self::$buttonScript);
					$script[] = '</script>';
					// load the display
					return implode('',$content).implode('',$script);
				}
				elseif (self::$returnType == 'site')
				{
					// add some script;
					$script = array();
					$script[] = '<script type="text/javascript">';
					$script[] = 'var available = {};';
					$script[] = 'var taken = {}; var tickets = {};';
					$script[] = 'var capacity = '.self::$event->capacity.';';
					$script[] = implode('',self::$buttonScript);
					$script[] = '</script>';

					// load the display
					$content = implode('',$content).implode('',$script);

					// get the documents for downloads
					if ($downloads = self::getEventDownloads())
					{
						$content = str_replace(array_keys($downloads), array_values($downloads), $content);
						// remove links
						foreach ($downloads as $key => $link)
						{
							if (strpos($key, '[DOCLINK=') !== false)
							{
								unset($downloads[$key]);
							}
						}
					}

					// set event poster
					$poster = self::getEventImage('poster_image');
					// set event images
					$eventImages = self::getEventImage('event_images', 2);
					$eventImageWidth = self::$params->get('event_width', 800);
					$eventImageHeight =  self::$params->get('event_height', 600);
					
					// now set the selection only switches  (($bundle != 0 && $bundle == $otherBundle) || ($bundle == $otherBundle && $concept == $otherConcept)) <--- the JavaScript logic
					foreach (self::$disableButtonsCheck as $buttonId => $at)
					{
						if (isset(self::$conceptSwitchOnly[$at['concept']]))
						{
							foreach (self::$conceptSwitchOnly[$at['concept']] as $nr => $bucket)
							{
								if (((int) $at['bundle'] > 0 && (int) $at['bundle'] == (int) $bucket['bundle']))
								{
									self::$disableButtons['###'.$buttonId.'###'] = 'disabled';
								}
							}
						}
						if (isset(self::$bundleSwitchOnly[$at['bundle']]))
						{
							foreach (self::$bundleSwitchOnly[$at['bundle']] as $nr => $bucket)
							{
								if ((int) $at['bundle'] > 0 || (int) $at['concept'] == (int) $bucket['concept'])
								{
									self::$disableButtons['###'.$buttonId.'###'] = 'disabled';
								}
							}
						}
					}
					// update the disabled buttons
					$content = str_replace(array_keys(self::$disableButtons), array_values(self::$disableButtons), $content);

					// now lets add the poster event images and the download buttons if found
					$tabs = false;
					if ($poster || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
					{
						if ($poster && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
						{
							if (count($downloads) == 1)
							{
								$tabName2 = Text::_('Poster & Download');
							}
							else
							{
								$tabName2 = Text::_('Poster & Downloads');
							}
						}
						elseif ($poster)
						{
							$tabName2 = Text::_('Poster');
						}
						elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
						{
							if (count($downloads) == 1)
							{
								$tabName2 = Text::_('Download');
							}
							else
							{
								$tabName2 = Text::_('Downloads');
							}
						}
						$tabs = true;
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($eventImages))
					{
						if (count($eventImages) == 1)
						{
							$tabName3 = Text::_('Event Image');
						}
						else
						{
							$tabName3 = Text::_('Event Images');
						}
						$tabs = true;
					}
					// build tabs
					if ($tabs)
					{
						$tabControlID = md5(self::$event->name.self::$event->id);
						$body = array();
						$body[] = '<ul class="uk-subnav uk-subnav-pill" data-uk-switcher="{connect:\'#'.$tabControlID.'\'}">';
						$body[] = '<li><a href="">'. Text::_('Register') .'</a></li>';
						if (isset($tabName2))
						{
							$body[] = '<li><a href="">'. $tabName2 .'</a></li>';
						}
						if (isset($tabName3))
						{
							$body[] = '<li><a href="">'. $tabName3 .'</a></li>';
						}
						$body[] = '</ul>';

						$body[] = '<ul id="'.$tabControlID.'" class="uk-switcher">';
						$body[] = '<li>' . $content . '</li>';
						if (isset($tabName2))
						{
							$body[] = '<li>';
							if ($poster && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
							{
								$body[] = '<div class="uk-grid">';
								$body[] = '<div class="uk-width-medium-4-5">';
								$body[] = '<div class="uk-panel">' . $poster . '</div>';
								$body[] = '</div>';
								$body[] = '<div class="uk-width-medium-1-5">';
								$body[] = '<div class="uk-panel">' . implode('', $downloads) . '</div>';
								$body[] = '</div>';
								$body[] = '</div>';
							}
							elseif ($poster)
							{
								$body[] = $poster;
							}
							elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
							{
								$body[] = implode('', $downloads);
							}
							$body[] = '</li>';
						}
						if (isset($tabName3))
						{
							$body[] = '<li>';
							$body[] = '<div class="uk-grid uk-grid-width-medium-1-4" data-uk-grid-margin>';
							foreach ($eventImages as $val)
							{
								$body[] = '<div>';
								$body[] = '<a href="' . $val['url'] . '" data-uk-lightbox="{group:\'group-' . $tabControlID . '\'}" title="' . $val['name'] . '">';
								$body[] = '<img src="' . $val['url'] . '" alt="" width="' . $eventImageWidth . '" height="' . $eventImageHeight . '">';
								$body[] = '</a>';
								$body[] = '</div>';
							}
							$body[] = '</div>';
							$body[] = '</li>';
						}
						$body[] = '</ul>';
						// return body
						return implode('',$body);
					}
					return $content;
				}
			}
			elseif (self::$returnType == 'options' && $options = self::getEventOptions())
			{
				return $options;
			}
		}
		return false;
	}

	/**
	 * @return string image link
	 */
	protected static function getEventImage($target, $type = 1, $name = null, $class = 'uk-margin')
	{
		// get image if not available
		if ((!isset(self::$event->$target) || !Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->$target)) && self::$event->id > 0)
		{
			self::$event->$target = self::decryptString(self::getVar('event', self::$event->id, 'id', $target));
		}
		// check that image is json
		if ($type == 2 && self::$event->$target && Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$event->$target))
		{
			$setFileName = false;
			if (!$name)
			{
				$setFileName = true;
			}
			// build an array of images
			$tmp = json_decode(self::$event->$target, true);
			if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmp))
			{
				return false;
			}
			$bucket = array();
			foreach ($tmp as $fileName)
			{
				// build the array
				if (strpos($fileName, '_') !== false)
				{
					$extention = explode('_', $fileName);
					$actualName = self::$event->name;
					if ($setFileName && strpos($fileName, 'VDM') !== false)
					{
						$fileNameArray = explode('VDM', $fileName);
						if (isset($fileNameArray[1]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($fileNameArray[1]))
						{
							$actualName = $fileNameArray[1];
						}
					}
					if (isset($extention[2]))
					{
						if ($setFileName)
						{
							$name = $actualName;
						}
						// set basic bucket details
						$tmpBucket = array();
						$tmpBucket['link'] = '<img class="'.$class.'" src="'.self::$filelink.$fileName.'.'.$extention[2].'" alt="'. $name .'">';
						$tmpBucket['url'] = self::$filelink.$fileName.'.'.$extention[2];
						$tmpBucket['name'] =  $name;
						// add to bucket
						$bucket[] = $tmpBucket;
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
			{
				return $bucket;
			}
		}
		// check that image is only a string
		elseif ($type == 1 && isset(self::$event->$target) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->$target))
		{
			// return one image link
			if (strpos(self::$event->$target, '_') !== false)
			{
				$extention = explode('_', self::$event->$target);
				$actualName = self::$event->name;
				if (strpos(self::$event->$target, 'VDM') !== false)
				{
					$fileNameArray = explode('VDM', self::$event->$target);
					if (isset($fileNameArray[1]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($fileNameArray[1]))
					{
						$actualName = $fileNameArray[1];
					}
				}
				if (isset($extention[2]))
				{
					if (!$name)
					{
						$name = $actualName;
					}
					return '<img class="'.$class.'" src="'.self::$filelink.self::$event->$target.'.'.$extention[2].'" alt="'. $name .'">';
				}
			}
		}
		return false;
	}

	/**
	 * @return array of links
	 */
	protected static function getEventDownloads()
	{
		if (isset(self::$event->event_documents))
		{
			// first make sure it is Json values
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$event->event_documents))
			{
				self::$event->event_documents = json_decode(self::$event->event_documents, true);
			}
			// now check if it is an array
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->event_documents))
			{
				$sessionToken = Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken();
				$domain = Uri::root();
				$downloads = array();
				foreach (self::$event->event_documents as $fileName)
				{
					// make sure this a correct file name
					if (strpos($fileName, '_') !== false && strpos($fileName, 'VDM') !== false)
					{
						$fileArray = explode('_', $fileName);
						$nameArray = explode('VDM', $fileName);
						// more checks
						if (isset($nameArray[1]) && isset($fileArray[2]))
						{
							if (self::$basickey)
							{
								// Get the encryption object.
								$localFile = self::base64_urlencode(self::$locker->encryptString($fileName));
							}
							else
							{
								// can not get the encryption object so only base64 encode
								$localFile = self::base64_urlencode($fileName, true);
							}
							// build link 
							$link = $domain . 'index.php?option=com_[[[component]]]&task=download.document&file=' . $localFile . '&token=' . $sessionToken;
							// build the file name
							$fileName = $nameArray[1] . '.' . $fileArray[2];
							$downloads['[DOCLINK='.$fileName.']'] = '<a href="' . $link . '" tytle=" ' . Text::_('Download') . '">' . $fileName . '</a>';
							$downloads['[DOCBUTTON='.$fileName.']'] = '<a href="' . $link . '" class="uk-button uk-button-success uk-margin-small-bottom uk-width-1-1"><i class="uk-icon-download"></i> ' . Text::_('Download') . ' ' . $fileName . '</a>';
						} 
					}
				}
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($downloads))
				{
					return $downloads;
				}
			}
		}
		return false;
	}

	/**
	 * @param $table
	 * @param $value
	 * @return bool|mixed
	 */
	protected static function loadEditButton($table, $id)
	{		
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$user))
		{
			// set current user
			self::$user = Factory::getUser();
		}
		// only load to admin and organizer who own this item
		if (self::hasAccess($id, self::$user->id, $table))
		{
			if (self::$returnType == 'admin')
			{
				$ref = (isset(self::$event->id) && self::$event->id > 0) ? "&ref=event&refid=".self::$event->id : '';
				$edit = "index.php?option=com_[[[component]]]&view=".$table."&task=".$table.".edit&id=".$id.$ref;
				return ' <a onclick="UIkit2.modal.confirm(\''.Text::_('All unsaved work will be lost, are you sure you want to continue?').'\', function(){ window.location.href = \''.$edit.'\' })"  href="javascript:void(0)" class="uk-icon-pencil uk-hidden"></a>';
			}
			elseif (self::$returnType == 'site')
			{
				$ref = (isset(self::$event->id) && self::$event->id > 0) ? "&ref=registry&refid=".self::$event->id : '';
				$edit = "index.php?option=com_[[[component]]]&view=".$table."&task=".$table.".edit&id=".$id.$ref;
				return ' <a href="'.$edit.'" class="uk-icon-pencil uk-hidden"></a>';
			}
		}
		return '';
	}

	/**
	 * @param $table
	 * @param $value
	 * @return bool|mixed
	 */
	protected static function loadName($table,$value)
	{
		if ('event' === $table && isset(self::$event->name))
		{
			return self::$event->name;
		}
		return self::getVar($table,(int) $value,'id','name');
	}

	protected static function loadOrphanVariations()
	{
		$content = array();
		// isolate the orphan variations
		if (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']))
		{
			$anotherConcept = array();
			$variations = array();
			foreach (self::$event->cost['concept'] as $key => $concept)
			{
				if (!in_array($concept,self::$concepts))
				{
					if (is_numeric($concept))
					{
						// another concept
						$anotherConcept[$concept] = $concept;
					}
					else
					{
						// total orphan
						$variations[self::$event->cost['variation'][$key]] = $key;
					}
				}
			}
			// first load the other consepts (that have no date - target whole event)
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($anotherConcept))
			{
				foreach ($anotherConcept as $concept)
				{
					// another concept
					self::$conceptHTML[self::$event->id.'_'.$concept.'__0'] = self::buildConcept($concept,self::$event->id.'_'.$concept.'__0');
				}
			}
			// now load the orphan variations (that have no date or concept - target whole event)
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($variations))
			{
				$price = array();
				foreach ($variations as $variation => $key)
				{
					// another variation button
					if (count($price) > 2 && (self::$returnType == 'admin' || self::$returnType == 'site'))
					{
						$price[] = '<br />';
					}
					if ($button = self::setBuyButtons($key))
					{
						$price[] = $button;
					}
				}
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					$content = array();
					$content[] = '<div class="uk-grid"><div class="uk-width-medium-3-5"></div><div class="uk-width-medium-2-5">';
					$content[] = implode('',$price);
					$content[] = '</div></div>';

					// return the orphan stuff to a belong (TODO - this is not ideal)
					self::$conceptHTML[self::$event->id.'_999999999__0'] = implode('',$content);
				}
				elseif (self::$returnType == 'options')
				{
					self::$eventOptions['options'][self::$event->id.'_999999999__0'] = $price;
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['options'][self::$event->id.'_999999999__0']))
					{
						foreach (self::$eventOptions['options'][self::$event->id.'_999999999__0'] as $nr => &$costing)
						{
							$costing['name'] = self::loadName('event',self::$event->id) . ' (' .$costing['name'] .')';
						}
					}
				}
			}
		}
	}

	/**
	 * @param $concepts
	 * @return string
	 */
	protected static function loadConceptLayout()
	{
		$content = array();
		$concepts = self::getConceptsHTML();
		// check layout option
		if (!isset(self::$eventBuilder['bundler']) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['bundler']))
		{
			// load default layout
			$content[] = '<div data-uk-grid-margin="" class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel uk-margin-small uk-panel-hover">';
			$content[] = implode('</div></div><div class="uk-width-1-1"><div class="uk-panel uk-margin-small uk-panel-hover">',$concepts);
			$content[] = '</div></div></div>';
		}
		elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['bundler']))
		{
			// load in bundles layout
			foreach (self::$eventBuilder['bundler'] as $bundle => $array)
			{
				$content[] = '<div data-uk-grid-margin="" class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel uk-margin-small uk-panel-hover">';
				$edit = self::loadEditButton('bundle', $bundle);
				$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' uk-visible-hover-inline' : '';
				$content[] = '<h3 class="uk-panel-title'.$editClass.'">'. self::loadName('bundle',$bundle) . $edit .'</h3>';
				$details = self::getVar('bundle',(int) $bundle,'id','description');
				// load bundle details
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($details))
				{
					$content[] = '<div>'.$details.'</div>';
				}
				$content[] = '<div class="wire-border"><div class="uk-grid">';
				$bucket = array();
				foreach ($array as $event_concept_time)
				{
					if (isset($concepts[$event_concept_time]))
					{
						$bucket[] = $concepts[$event_concept_time];
						unset($concepts[$event_concept_time]);
					}
				}
				$content[] = '<div class="uk-width-1-1">'.implode('</div><div class="uk-width-1-1"><hr>',$bucket).'</div>';
				$content[] = '</div></div></div></div></div>';
			}
			// check if there is more concepts left
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($concepts))
			{
				$content[] = '<div data-uk-grid-margin="" class="uk-grid"><div class="uk-width-1-1"><div class="uk-panel uk-panel-space">';
				$content[] = implode('</div></div><div class="uk-width-1-1"><div class="uk-panel uk-panel-space">',$concepts);
				$content[] = '</div></div></div>';
			}
		}
		return implode('',$content);
	}

	protected static function setBundler()
	{
		if (isset(self::$event->date['bundle']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->date['bundle']))
		{
			$bundler = array();
			foreach (self::$event->date['bundle'] as $key => $bundle)
			{
				$concept = self::$event->date['concept'][$key];
				if (is_numeric($bundle))
				{
					if ($key_time = self::getEventConceptTime($key))
					{
						if (!isset(self::$eventBuilder['timestamps'][$key_time]['start']))
						{
							self::$eventBuilder['timestamps'][$key_time]['start'] = 0;
						}
					}
					else
					{
						$key_time = 0;
						self::$eventBuilder['timestamps'][0]['start'] = 0;
					}

					$bundler[] = array('bundle' => (int) $bundle, 'concept' => (int) $concept, 'start' => (int) self::$eventBuilder['timestamps'][$key_time]['start']);
				}
			}
			// check if any bundles has been loaded
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bundler))
			{
				// sort the bundles
				usort($bundler, function($a, $b) {
					return $a['start'] - $b['start'];
				});
				// pack the bundles
				foreach ($bundler as $array)
				{
					self::$eventBuilder['bundler'][$array['bundle']][self::$event->id.'_'.$array['concept'].'__'.$array['start']] = self::$event->id.'_'.$array['concept'].'__'.$array['start'];
					self::$eventBuilder['bundle'][self::$event->id.'_'.$array['concept'].'__'.$array['start']] = $array['bundle'];
				}
			}
		}
	}

	/**
	 * @param $concept
	 * @param $event_concept_time
	 * @return bool|string
	 */
	protected static function buildConcept(&$concept, $event_concept_time)
	{
		$content = array();
		if (self::$returnType == 'admin' || self::$returnType == 'site')
		{
			if (isset(self::$eventBuilder['dates'][$event_concept_time]['start-end']))
			{
				$content[] = '<div class="concept-start-end">'.self::$eventBuilder['dates'][$event_concept_time]['start-end'].'</div>';
			}
			// check if this concept is already loaded
			if (!isset(self::$conceptData[$concept]))
			{
				self::$conceptData[$concept] = self::getAllValues($concept, 'concept', array('concept_image'));
			}
			// only continue if we have values
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$conceptData[$concept]))
			{
				return false;
			}
			$edit = self::loadEditButton('concept',$concept);
			$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' uk-visible-hover-inline' : '';
			$content[] = '<h3 class="uk-panel-title'.$editClass.'">'.self::$conceptData[$concept]->name . $edit .'</h3>';
			// add concept image
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$conceptData[$concept]->concept_image) && strpos(self::$conceptData[$concept]->concept_image, '_') !== false)
			{
				$extention = explode('_',self::$conceptData[$concept]->concept_image);
				if (isset($extention[2]))
				{
					$content[] = '<img class="uk-thumbnail" src="'.self::$filelink.self::$conceptData[$concept]->concept_image.'.'.$extention[2].'" alt="concept image">';
				}
			}
			$content[] = '<div class="uk-grid">';

			// workout widths
			$conceptDetails = false;
			$conceptContent = false;
			$conceptCosting = false;
			$setSpacer = false;
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$conceptData[$concept]->details))
			{
				$conceptDetails = true;
			}
			if (self::setConceptContent($event_concept_time))
			{
				$conceptContent = true;
			}
			if (self::setConceptCosting($concept,$event_concept_time))
			{
				$conceptCosting = true;
			}
			if ($conceptDetails && $conceptContent && $conceptCosting)
			{
				// three is true
				$widthsDetails = 1;
				$widthsContent = 2;
			}
			elseif ($conceptDetails xor $conceptContent xor $conceptCosting)
			{
				// one is true
				$widthsDetails = 5;
				$widthsContent = 5;
				// load blank spacer
				$setSpacer = true;
			}
			elseif ($conceptDetails || $conceptContent || $conceptCosting)
			{
				// two is true
				if ($conceptCosting)
				{
					$widthsDetails = 3;
					$widthsContent = 3;
				}
				else
				{
					$widthsDetails = 2;
					$widthsContent = 3;
				}
			}
			// load concept details
			if ($conceptDetails && isset(self::$conceptData[$concept]) && isset(self::$conceptData[$concept]->details))
			{
				$content[] = '<div class="uk-width-medium-'.$widthsDetails.'-5">';
				$content[] = '<div>'.self::$conceptData[$concept]->details.'</div>';
				$content[] = '</div>';
			}
			// set some content
			if ($conceptContent && isset(self::$eventBuilder['content']) && isset(self::$eventBuilder['content'][$event_concept_time]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['content'][$event_concept_time]))
			{
				$content[] = '<div class="uk-width-medium-'.$widthsContent.'-5">';
				$content[] = implode('',self::$eventBuilder['content'][$event_concept_time]);
				$content[] = '</div>';
			}
			// set some content
			if ($conceptCosting && isset(self::$eventOptions['display'][$event_concept_time]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['display'][$event_concept_time]))
			{
				if ($setSpacer)
				{
					$content[] = '<div class="uk-width-medium-3-5">';
					$content[] = '</div>';
				}
				$content[] = '<div class="uk-width-medium-2-5">';
				$content[] = implode('',self::$eventOptions['display'][$event_concept_time]);
				$content[] = '</div>';
			}
			$content[] = '</div>';

			return implode('',$content);
		}
		elseif (self::$returnType == 'options')
		{
			if (self::setConceptCosting($concept,$event_concept_time))
			{
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['options'][$event_concept_time]))
				{
					foreach (self::$eventOptions['options'][$event_concept_time] as $nr => &$costing)
					{
						$costing['name'] = self::loadName('event',self::$event->id) . ' (' .self::loadName('concept',$concept) . ' - ' . $costing['name'] .')';
						if (isset(self::$eventBuilder['dates'][$event_concept_time]['start-end']))
						{
							$costing['date'] = self::$eventBuilder['dates'][$event_concept_time]['start-end'];
						}
					}
				}
			}
		}
		return false;
	}

	/**
	 * @param $event_concept_time
	 * @return bool
	 */
	protected static function setConceptContent(&$event_concept_time)
	{
		if (isset(self::$locations[$event_concept_time]))
		{
			$key = self::getLocation($event_concept_time);
			if (isset(self::$event->date['content'][$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->date['content'][$key]))
			{
				if (!isset(self::$eventBuilder['content'][$event_concept_time]))
				{
					self::$eventBuilder['content'][$event_concept_time] = array();
				}
				foreach (self::$event->date['content'][$key] as $content)
				{
					// check if this content is already loaded
					if (!isset(self::$contentData[$content]))
					{
						// load the data
						self::$contentData[$content] = self::getAllValues($content, 'content', array('content_image'));
					}
					// only load the content if we have values
					if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$contentData[$content]))
					{
						continue;
					}
					// now load the banner
					$banner = false;
					if (isset(self::$contentData[$content]->content_image) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$contentData[$content]->content_image) && strpos(self::$contentData[$content]->content_image, '_') !== false)
					{
						$extention = explode('_', self::$contentData[$content]->content_image);
						if (isset($extention[2]))
						{
							$banner = '<img class="uk-thumbnail uk-margin" src="'.self::$filelink.self::$contentData[$content]->content_image.'.'.$extention[2].'" alt="'.self::$contentData[$content]->name.'">';
						}
					}
					$edit = self::loadEditButton('content',$content);
					$editClass = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($edit)) ? ' uk-visible-hover-inline' : '';
					if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$contentData[$content]->details) || $banner)
					{
						$random = self::randomkey(5);
						self::$eventBuilder['content'][$event_concept_time][] = '<div class="uk-margin'.$editClass.'"><a href="#" data-uk-toggle="{target:\'#con'.$random.'\'}">'.self::$contentData[$content]->name.'</a>' . $edit .'</div>';
						self::$eventBuilder['content'][$event_concept_time][] = '<div id="con'.$random.'" class="uk-hidden">';
						if ($banner)
						{
							self::$eventBuilder['content'][$event_concept_time][] = $banner;
						}
						if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$contentData[$content]->details) || $banner)
						{
							self::$eventBuilder['content'][$event_concept_time][] = self::$contentData[$content]->details;
						}
						self::$eventBuilder['content'][$event_concept_time][] = '</div>';
					}
					else
					{
						self::$eventBuilder['content'][$event_concept_time][] = '<div class="uk-margin'.$editClass.'">'.self::$contentData[$content]->name . $edit .'</div>';
					}
				}
				// found
				return true;
			}
		}
		return false;
	}

	/**
	 * @param $concept
	 * @param $event_concept_time
	 * @return bool
	 */
	protected static function setConceptCosting(&$concept,&$event_concept_time)
	{
		$found = false;
		// check if this concept has a variation relation
		if (isset(self::$event->cost['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->cost['concept']) && in_array($concept, self::$event->cost['concept']))
		{
			$extras = array();
			$buttons = array();
			foreach (self::$event->cost['concept'] as $key => $checker)
			{
				if ($concept == $checker && isset(self::$event->cost['price'][$key]) && isset(self::$event->cost['variation'][$key]) && !self::$event->cost['extra'][$key])
				{
					if (count($buttons) > 2 && (self::$returnType == 'admin' || self::$returnType == 'site'))
					{
						$buttons[] = '<br />';
					}
					if ($button = self::setBuyButtons($key, $concept, $event_concept_time))
					{
						$buttons[] = $button;
					}
				}
				elseif ($concept == $checker && isset(self::$event->cost['price'][$key]) && isset(self::$event->cost['variation'][$key]) && self::$event->cost['extra'][$key])
				{
					if (count($extras) > 2 && (self::$returnType == 'admin' || self::$returnType == 'site'))
					{
						$extras[] = '<br />';
					}
					if ($button = self::setBuyButtons($key, $concept, $event_concept_time))
					{
						$extras[] = $button;
					}
				}
			}
			// load the buttons
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($buttons))
			{
				// ignite the engine
				self::startEventOptionsBuilder($event_concept_time);
				// load the payload
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					self::$eventOptions['display'][$event_concept_time][] = implode('',$buttons);
				}
				elseif (self::$returnType == 'options')
				{
					self::$eventOptions['options'][$event_concept_time] = $buttons;
				}
				$found = true;
			}
			// load the extras
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($extras))
			{
				// ignite the engine
				self::startEventOptionsBuilder($event_concept_time);
				// load the payload
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['display'][$event_concept_time]))
					{
						self::$eventOptions['display'][$event_concept_time][] = '<hr>';
					}
					self::$eventOptions['display'][$event_concept_time][] = implode('',$extras);
				}
				elseif (self::$returnType == 'options')
				{
					self::$eventOptions['options'][$event_concept_time] = array_merge(self::$eventOptions['options'][$event_concept_time], $extras);
				}
				$found = true;
			}
		}
		return $found;
	}

	protected static function startEventOptionsBuilder(&$event_concept_time)
	{
		if (self::$returnType == 'admin' || self::$returnType == 'site')
		{
			// set array if not set
			if (!isset(self::$eventOptions['display'][$event_concept_time]) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['display'][$event_concept_time]))
			{
				self::$eventOptions['display'][$event_concept_time] = array();
			}
		}
		elseif (self::$returnType == 'options')
		{
			// set array if not set
			if (!isset(self::$eventOptions['options'][$event_concept_time]) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['options'][$event_concept_time]))
			{
				self::$eventOptions['options'][$event_concept_time] = array();
			}
		}	
	}

	/**
	 * @param $key
	 * @param int $concept
	 * @param string $event_concept_time
	 * @return array|bool|string
	 */
	protected static function setBuyButtons($key, $concept = 0, $event_concept_time = '0__0')
	{
		// 1 <- individual and group
		// 2 <- only individual
		// 3 <- only group
		// 4 <- custom reg
		// 5 <- close reg
		if (isset(self::$event->id))
		{
			// set the price
			if (self::$event->type != 5 && ($conceptPrice = self::getConceptPrice($key)))
			{
				$variation = (int) self::$event->cost['variation'][$key];
				$qty = (int) self::$event->cost['qty'][$key];
				$only = (int) self::$event->cost['only'][$key];
				$extra = (int) self::$event->cost['extra'][$key];
				$taxed = (int) self::$event->cost['taxed'][$key];
				// build swtich id
				$bundle = 0;
				$time = explode('__',$event_concept_time);
				if (isset(self::$eventBuilder['bundle'][$event_concept_time]))
				{
					$bundle = self::$eventBuilder['bundle'][$event_concept_time];
				}
				// switch ID
				$switchID = self::$event->id . '_' . (int) $bundle . '_' .(int) $time[1] . '_' .(int) $concept . '_' . (int) $variation;
				// start building the button
				$button = array();
				if (self::$event->type == 4)
				{
					// set link if not set
					if (!isset(self::$event->customurl) && self::$event->id > 0)
					{
						self::$event->customurl = self::getVar('event', self::$event->id, 'id', 'customurl');
					}
					if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->customurl))
					{
						self::$event->customurl = '#CUSTOM_LINK';
					}
					// add the needed vars to pass the selection
					$selectionValue = $switchID . '__' . $conceptPrice['EXCHANGE_RATE_TO'] . '__' . $conceptPrice['EXCHANGE_RATE_ID'];
					$selectionVar = '&[[[component]]]_selection='.$selectionValue;
					$button[] = '<div  class="uk-width-1-1 uk-text-bold uk-text-success uk-text-large">';
					$button[] = self::loadName('variation',$variation);
					$button[] = '  ' .$conceptPrice['EXCHANGE_RATE_TO_MONEY'];
					$button[] = '</div>';
					$button[] = '<a href="' . self::$event->customurl . $selectionVar . '" class="uk-button uk-button-primary uk-margin-small-bottom uk-width-1-1" target="_blank">';
					$button[] = Text::_('Register');
					$button[] = '</a>';

					$buyId = null;
				}
				else
				{
					// checking ID
					$checkingID = self::$event->organizer . '_' . $switchID;
					// checking KEY
					$IDKEY = md5($checkingID);
					// set buy ID
					$buyId = $IDKEY . '__' . $conceptPrice['EXCHANGE_RATE_TO'] . '__' . $conceptPrice['EXCHANGE_RATE_ID'];
					// get qty available
					$actualQTY = self::getQtyAvailable($qty, 'variation', $checkingID);
					// get qty this user has selected 
					$selectedQTY = self::activeCartQty($checkingID);
					// set variation name
					$variationName = self::loadName('variation',$variation);
					// set button by ID
					$buttonId = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($buyId, 'cAmel');
					// we remove disabler if not needed
					self::$disableButtons['###'.$buttonId.'###'] = '';
					if ( self::$returnType !== 'options')
					{
						// set some JavaScript values
						if (self::$returnType == 'admin')
						{
							self::$buttonScript[] = 'available["'.$buttonId.'"] = '. (int) $qty.';';
						}
						// ticket behavior 
						if (!$extra)
						{
							self::$buttonScript[] = 'tickets["'.$buttonId.'"] = 1;';
						}
						// set the only switch
						$onlySwitch = '';
						if (1 == $only && !$extra)
						{
							$onlySwitch = 'data-only="1"';
							// make sure selected only values are set again
							if ($selectedQTY > 0)
							{
								// load per concept
								if (!isset(self::$conceptSwitchOnly[$concept]))
								{
									self::$conceptSwitchOnly[$concept] = array();
								}
								// this is the active selection
								self::$conceptSwitchOnly[$concept][] = array('concept' => (int) $concept, 'bundle' => (int) $bundle);
								// load per bundle
								if (!isset(self::$bundleSwitchOnly[$bundle]))
								{
									self::$bundleSwitchOnly[$bundle] = array();
								}
								// this is the active selection
								self::$bundleSwitchOnly[$bundle][] = array('concept' => (int) $concept, 'bundle' => (int) $bundle);
							}
							else
							{
								self::$disableButtonsCheck[$buttonId] = array('concept' => (int) $concept, 'bundle' => (int) $bundle);
							}
						}
						$button[] = '<div class="uk-width-1-1 uk-text-bold uk-text-success uk-text-large">';
						$button[] = $variationName;
						$button[] = '<br class="uk-visible-small"/>  <span class="'.$buttonId.'-price">' . $conceptPrice['EXCHANGE_RATE_TO_MONEY'] .'</span>';
						$button[] = '</div>';

						// check if there is still place open on this variation
						if ($qty != 0 && $actualQTY <= 0 && $selectedQTY <= 0 && self::$returnType !== 'admin')
						{
							// start building the button
							$button = array();
							$button[] = '<div class="uk-width-1-1 uk-text-bold uk-text-muted uk-text-large">';
							$button[] = $variationName;
							$button[] = '<br class="uk-visible-small"/> ' . $conceptPrice['EXCHANGE_RATE_TO_MONEY'] .' <small>(' . Text::_('This Option is Full.') . ')</small>';
							$button[] = '</div>';
							$button[] = '<button class="uk-button uk-margin-small-bottom uk-width-1-1" type="button" disabled> ';
							$button[] = Text::_('Closed');
							$button[] = '</button>';
						}
						elseif (self::$event->type == 2)
						{
							if ($selectedQTY > 0)
							{
								$button[] = '<button  id="'.$buttonId.'-select" class="select-button uk-button uk-margin-small-bottom uk-width-1-1 uk-button-success uk-active" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' data-selection="2" ###'.$buttonId.'###> ';
								$button[] = Text::_('Select');
								$button[] = '</button>';
							}
							else
							{
								$button[] = '<button  id="'.$buttonId.'-select" class="select-button uk-button uk-margin-small-bottom uk-width-1-1 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' data-selection="1" ###'.$buttonId.'###> ';
								$button[] = Text::_('Select');
								$button[] = '</button>';
							}
						}
						else
						{
							// add to cart button
							$button[] = '<div class="uk-button-group uk-width-1-1">';
							if ($qty != 0 && $actualQTY <= 0 && $selectedQTY > 0)
							{
								$button[] = '<button id="'.$buttonId.'-plus" class="select-button uk-button uk-button-small uk-margin-small-bottom uk-width-1-3 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' disabled>';
							}
							else
							{
								$button[] = '<button id="'.$buttonId.'-plus" class="select-button uk-button uk-button-small uk-margin-small-bottom uk-width-1-3 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' ###'.$buttonId.'###>';
							}
							$button[] = '<i class="uk-icon-plus"></i>';
							$button[] = '</button>';
							$button[] = '<button id="'.$buttonId.'-minus" class="select-button uk-button uk-button-small uk-margin-small-bottom uk-width-1-3 uk-button-success" type="button" data-buy="'.$buyId.'" data-switch="'.$switchID.'" '.$onlySwitch.' ###'.$buttonId.'###>';
							$button[] = '<i class="uk-icon-minus"></i>';
							$button[] = '</button>';
							$button[] = '<button class="uk-button uk-button-small uk-margin-small-bottom uk-width-1-3" type="button" disabled>';
							if ($selectedQTY > 0)
							{
								$button[] = '<span id="'.$buttonId.'-number" data-qty="'.$selectedQTY.'"><span class="uk-badge uk-badge-notification uk-badge-success">'.$selectedQTY.'</span></span>';
							}
							else
							{
									$button[] = '<span id="'.$buttonId.'-number" data-qty="0">0</span>';						
							}
							$button[] = '</button>';
							$button[] = '</div>';
						}
						
						// check if there has been a change in price
						$storedPrice = self::getEventDetails($IDKEY, 'price', 'id', false);
						if ($storedPrice !== $conceptPrice['EXCHANGE_RATE_TO'])
						{
							// update the price if there was a change
							self::updateEventDetail($IDKEY, array(
								'id' => $IDKEY,
								'buy_id' => $buyId,
								'check_id' => $checkingID,
								'switch_id' => $switchID,
								'price' => $conceptPrice['EXCHANGE_RATE_FROM'],
								'name' => $variationName,
								'qty' => $qty,
								'only' => $only,
								'extra' => $extra,
								'taxed' => $taxed,
								'priceObject' => $conceptPrice));
						}
					}
				}
				// only return button if admin or site return type
				if (self::$returnType == 'admin' || self::$returnType == 'site')
				{
					return  implode('',$button);
				}
				// if options then return array of results
				elseif ($buyId && self::$returnType == 'options')
				{
					return array(
						'id' => $IDKEY,
						'buy_id' => $buyId,
						'check_id' => $checkingID,
						'switch_id' => $switchID,
						'price' => $conceptPrice['EXCHANGE_RATE_TO'],
						'name' => $variationName,
						'qty' => $qty,
						'only' => $only,
						'extra' => $extra,
						'taxed' => $taxed,
						'priceObject' => $conceptPrice);
				}
			}
		}
		return false;
	}

	public static function getEventDetails($key, $what = 'price', $type = 'name', $retry = true, $priceConvertion = true)
	{
		if ('name' == $type)
		{
			$key = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($key);
		}
		// get the event details
		$eventDetails = self::get('eventDetailsVDM', null);
		if ($eventDetails && isset($eventDetails[$type][$key]) && isset($eventDetails[$type][$key][$what]))
		{
			return self::eventDetailPrep($eventDetails[$type][$key], $what, $priceConvertion);
		}
		// if not set retry, by setting it
		if ($retry)
		{
			self::setEventOptions();
			return self::getEventDetails($key, $what, $type, false, $priceConvertion);
		}
		return false;
	}

	protected static function eventDetailPrep(&$values, &$what, $priceConvertion)
	{
		if ('price' === $what && $priceConvertion)
		{
			// used for the invoice view mainly
			$jinput = Factory::getApplication()->input;
			$data = $jinput->getArray(array(
				'organizer_currency' => 'word',
				'registered_user_currency' => 'word',
				'exchange_rate' => 'float'
			));
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data['organizer_currency']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($data['registered_user_currency']))
			{
				$check = $data['organizer_currency'].$data['registered_user_currency'];
				$organizer_currency = 'NONE';
				if (isset($values['priceObject']['EXCHANGE_RATE_NAME']) && $check === $values['priceObject']['EXCHANGE_RATE_NAME'])
				{
					return $values[$what];
				}
				// if exchange rate is not set
				if (isset($values['priceObject']['EXCHANGE_RATE_ID']))
				{
					$organizer_currency = self::getFromCurrency($values['priceObject']['EXCHANGE_RATE_ID']);
				}
				if ($data['exchange_rate'] == 0 && $organizer_currency === $data['organizer_currency'])
				{
					$result = self::getExchangeRate($data['organizer_currency'], $values[$what], $data['registered_user_currency']);
					// now update the data
					return $result['EXCHANGE_RATE_TO'];
				}
				else
				{
					return bcmul($values[$what], $data['exchange_rate'], 2);
				}
			}
			// for other views
			elseif (isset($values['priceObject']['EXCHANGE_RATE_ID']))
			{
				$organizer_currency = self::getFromCurrency($values['priceObject']['EXCHANGE_RATE_ID']);
				$active_currency =  self::getUserCurrency();
				$result = self::getExchangeRate($organizer_currency, $values[$what], $active_currency);
				// now update the data
				return $result['EXCHANGE_RATE_TO'];
			}
		}
		return $values[$what];
	}

	protected static function getFromCurrency($exchange_ID)
	{
		$fromArray = array_map('strtoupper', (array) explode('-', $exchange_ID));
		return $fromArray[0];
	}

	protected static function setEventOptions()
	{
		$events = self::getVars('event', 1, 'published');
		// only continue if we have an array
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($events))
		{
			$bucket = array(); $bucket['name'] = array();  $bucket['id'] = array();
			foreach($events as $item)
			{
				if ($eventOptions = self::getEvent($item, 'options'))
				{
					foreach($eventOptions as $event)
					{
						if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($event))
						{
							foreach ($event as $option)
							{
								$option['_name'] = (isset($option['date']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($option['date'])) ?  $option['name']. ' ~ ' . $option['date'] :  $option['name'];
								$select = JFilterOutput::cleanText($option['_name']);
								// store in session
								$key = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($select);
								$option['select'] =  $select;
								$bucket['name'][$key] = $option;
								$bucket['id'][$option['id']] = $option;
							}
						}
					}
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket['id']))
			{
				self::set('eventDetailsVDM', $bucket);
			}
		}
	}

	protected static function updateEventDetail($key, $values)
	{
		// get the event Details from memory
		$eventDetails = self::get('eventDetailsVDM', null);
		// make sure the id is found
		if ($eventDetails && isset($eventDetails['id'][$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($eventDetails['id'][$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($values))
		{
			$select = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($eventDetails['id'][$key]['select']);
			foreach ($values as $field => $value)
			{
				// update the field in ID
				$eventDetails['id'][$key][$field] = $value;
				// update the field in selection
				$eventDetails['name'][$select][$field] = $value;
			}
			// store back to memory
			self::set('eventDetailsVDM', $eventDetails);
		}
	}

	public static function setEventStartDate($dates)
	{
		if (isset($dates['start']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($dates['start']))
		{
			$start = strtotime('00-00-3000 00:00:00');
			$found = false;
			foreach ($dates['start'] as $date)
			{
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($date))
				{
					$time = strtotime($date);
					if ($time < $start)
					{
						$start = $time;
						$found = true;
					}
				}
			}
			if ($found)
			{
				return array('text' => self::fancyDayTimeDate($start), 'int' => bcdiv((int) $start, 3600));
			}	
			return false;
		}
		return array('text' => Text::_('Not Set'), 'int' => 0);
	}

	public static function setEventTeaserImage($item, $fileLink, $default_teaser_image)
	{
		$teaser_image = '';
		// load the event teaser image
		if (isset($item->teaser_image) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($item->teaser_image) && strpos($item->teaser_image, '_') !== false)
		{
			$extention = explode('_', $item->teaser_image);
			if (isset($extention[2]))
			{
				$teaser_image = '<img class="uk-thumbnail uk-margin" src="'.$fileLink.$item->teaser_image.'.'.$extention[2].'" alt="'.$item->name.'">';
			}
		}
		// set default teaser image, if one is not set
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($teaser_image))
		{
			$teaser_image = $default_teaser_image;
		}
		return $teaser_image;
	}

	public static function loadButtons($item, $type, $user, $name, $id, $checked_out, $organizer_name = 'organizer', $eposcode = 'eposcode', $slug = 'slug')
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item))
		{
			$item = (array) $item;
		}
		$edit = Uri::root()."index.php?option=com_[[[component]]]&view=events&task=".$type.".edit&ref=events";
		$canCheckin = $item[$checked_out] == $user->id || $item[$checked_out] == 0;
		$canEdit = self::hasAccess($item[$id], $user->id, $type);
		$start = '<div class="uk-button-group uk-width-1-1">';
		$end = '</div>';
		$button = array();
		$size = 1;
		if ($canEdit && !$item[$checked_out])
		{
			$button[] = ' <a class="uk-button uk-button-primary uk-width-1-5" href="'.$edit.'&id='.$item[$id].'">'
					. '<i class="uk-icon-pencil"></i></a>';
			$size = 2;
		}
		elseif ($canEdit && $canCheckin)
		{
			$button[] = ' <a class="uk-button uk-width-1-5" href="'.$edit.'&id='.$item[$id].'">'
					. '<i class="uk-icon-lock"></i></a>'; 
			$size = 2;
		}
		elseif ($canEdit)
		{
			$button[] = ' <a class="uk-button uk-width-1-5" href="#" disabled>'
					. '<i class="uk-icon-lock"></i></a>'; 
			$size = 2;
		}
		if ($type === 'organizer')
		{
			// set the contact (email) button
			$button[] = ' <button class="uk-button uk-width-1-5" '
				. 'data-uk-modal="{target:\'#setMessage\', center:true}" type="button" onclick="setMessage(\''.$item[$eposcode].'\', \''.$item[$organizer_name].'\')">'
				. '<i class="uk-icon-envelope"></i></button>';
			if (2 === $size)
			{
				$size = 3;
			}
			else
			{
				$size = 2;
			}
		}
		if (2 === $size)
		{
			$buttonSize = '4-5';
		}
		elseif (3 === $size)
		{
			$buttonSize = '3-5';
		}
		else
		{
			$start = '';
			$end = '';
			$buttonSize = '1-1';
		}
		$typeButton = self::getTypeButton($item, $type, $id, $slug);
		// set the main button
		$button[] = ' <'.$typeButton['type'].' class="uk-button uk-button-success uk-width-'.$buttonSize.'" '.$typeButton['action'].'>'
			. $typeButton['icon'] . $item[$name] . $typeButton['extraText'] . '</'.$typeButton['type'].'>';
		// set group button
		return $start.implode('', $button).$end;
	}

	public static function getTypeButton($item, $type, $id, $slug)
	{
		// set the main stuff
		$button = array();
		switch($type)
		{
			case 'event':
				$button['action'] = ' href="'.Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_([[[Component]]]HelperRoute::getRegistryRoute($item[$slug])).'" ';
				$button['type'] = 'a';
				$button['extraText'] = ' (' . Text::_('Get More Info') . ')';
			break;
			default:
				$button['action'] = ' type="button" data-uk-modal="{target:\'#item-info-full\'}" onclick="getItemDataFull(\''.$type.'__'.$item[$id].'\')" ';
				$button['type'] = 'button';
				$button['extraText'] = '';
		}
		// set the icon
		switch($type)
		{
			case 'event':
				$button['icon'] = '<i class="uk-icon-shopping-cart"></i> ';
			break;
			case 'organizer':
				$button['icon'] = '<i class="uk-icon-user"></i> ';
			break;
			case 'venue':
				$button['icon'] = '<i class="uk-icon-map-marker"></i> ';
			break;
			default:
				$button['icon'] = '';	
		}
		return $button;
	}

	/**
	*  Get all items in Cart
	*/
	public static function getCart($status = 1, $both = true)
	{
		// always check for public key
		$public = self::get('publicKeeY', null);
		// get user object
		$userIs = self::userIs(null, true);
		// now check the id against the registered values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('a.key')));
		$query->from($db->quoteName('#__[[[component]]]_register', 'a'));
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_event', 'e')) . ' ON (' . $db->quoteName('a.event') . ' = ' . $db->quoteName('e.id') . ')');
		$query->where('a.status = ' . (int) $status);
		$query->order('e.name ASC');
		if ($userIs['is'] == 1 && $userIs['id'] > 0)
		{
			if ($public && $both === true)
			{
				$query->where('a.public = ' . $db->quote($public) . ' OR a.registered_user = '. (int) $userIs['id']);
			}
			else
			{
				$query->where('a.registered_user = '. (int) $userIs['id']);
			}
		}
		elseif ($public)
		{
			$query->where('a.public = ' . $db->quote($public));
		}
		else
		{
			return false;
		}
		$db->setQuery($query);
		$db->execute();
		// return the number of cart items
		if ($db->getNumRows())
		{
			$bucket = array();
			$registrations = $db->loadObjectList();
			foreach ($registrations as $reg)
			{
				// organizer_event_bundle_time_concept_variation
				$get = explode('_', $reg->key);
				$id = md5($reg->key);
				// load the values
				if (!isset($bucket[$get[0]]))
				{
					$bucket[$get[0]] = array();
				}
				// count the number of registrations for this variation and set its needed values
				if (!isset($bucket[$get[0]][$id]))
				{
					$bucket[$get[0]][$id] = array();
					$bucket[$get[0]][$id]['qty'] = 1;
					$bucket[$get[0]][$id]['event'] = (int) $get[1];
				}
				else
				{
					$bucket[$get[0]][$id]['qty']++;
				}
			}
			return $bucket;
		}
		return false;
	}

	/**
	*  Check if the qty is still available
	*/
	public static function activeCartQty($keyID)
	{
		// always check for public key
		$public = self::get('publicKeeY', null);
		// get user object
		$userIs = self::userIs(null, true);
		// now check the id against the registered values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName('a.id'));
		$query->from($db->quoteName('#__[[[component]]]_register', 'a'));
		$query->where('a.key = ' . $db->quote($keyID));
		$query->where('a.status = 1');
		if ($userIs['is'] == 1 && $userIs['id'] > 0)
		{
			if ($public)
			{
				$query->where('a.public = ' . $db->quote($public) . ' OR a.registered_user = '. (int) $userIs['id']);
			}
			else
			{
				$query->where('a.registered_user = '. (int) $userIs['id']);
			}
		}
		elseif ($public)
		{
			$query->where('a.public = ' . $db->quote($public));
		}
		else
		{
			return 0;
		}
		$db->setQuery($query);
		$db->execute();
		// return the number of cart items
		return (int) $db->getNumRows();
	}

	/**
	*  Check if the qty is still available
	*/
	public static function getQtyAvailable($qty, $type, $keyID)
	{
		if (('variation' === $type || 'event' === $type) && ((is_numeric($qty) && $qty > 0) || 'taken' === $qty))
		{
			// now check the id against the registered values
			$db = Factory::getDBO();
			$query = $db->getQuery(true);
			$query->select($db->quoteName('a.id'));
			$query->from($db->quoteName('#__[[[component]]]_register', 'a'));
			if ('variation' === $type)
			{
				$query->where('a.key = ' . $db->quote($keyID));
			}
			elseif ('event' === $type)
			{
				$query->where('a.event = ' . (int) $keyID);
			}
			else
			{
				return $qty;
			}
			$query->where('a.status >= 1');
			$db->setQuery($query);
			$db->execute();
			$registered = $db->getNumRows();
			if ('taken' === $qty)
			{
				return $registered;
			}
			if ($registered >= $qty)
			{
				return 0;
			}
			return bcsub($qty, $registered);
		}
		return $qty;
	}

	/**
	* @ return float on success
	*/
	protected static function getConceptPrice($key)
	{
		// first we get the raw set price (in organizers currency)
		if (isset(self::$event->cost['price'][$key]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->cost['price'][$key]))
		{
			$orgRaw = self::$filterInput->clean(self::$event->cost['price'][$key]);
			if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($orgRaw))
			{
				$orgRaw = "0.00";
			}
			// get organizer currency
			if ($orgCurrency = self::getEventCurrency())
			{
				if (self::$returnType == 'site')
				{
					// get the active party currency
					$activeCurrency = self::get('ACTIVE_CURRENCY');
				}
				else
				{
					$activeCurrency = $orgCurrency;
				}
				// set active price object
				return self::getExchangeRate($orgCurrency, $orgRaw, $activeCurrency);
			}
		}
		return false;
	}

	/**
	 * @return mixed
	 */
	protected static function getConceptsHTML()
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$conceptHTML))
		{
			$thisEvent = array();
			foreach (self::$conceptHTML as $event_concept__time => $HTML)
			{
				$looking = explode('_',$event_concept__time);
				if (self::$event->id == $looking[0])
				{
					$thisEvent[$event_concept__time] = $HTML;
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($thisEvent))
			{
				return $thisEvent;
			}
		}
		return false;
	}

	/**
	 * @return mixed
	 */
	protected static function getEventOptions()
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventOptions['options']))
		{
			$thisEvent = array();
			foreach (self::$eventOptions['options'] as $event_concept__time => $options)
			{
				$looking = explode('_',$event_concept__time);
				if (self::$event->id == $looking[0])
				{
					$thisEvent[$event_concept__time] = $options;
				}
			}
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($thisEvent))
			{
				return $thisEvent;
			}
		}
		return false;
	}

	/**
	 * @param $event_concept_time
	 * @return mixed
	 */
	protected static function getConseptId($event_concept_time)
	{
		if (isset(self::$concepts[$event_concept_time]))
		{
			return self::$concepts[$event_concept_time];
		}
		return $event_concept_time;
	}

	/**
	 * @param $event_concept_time
	 * @return int|mixed
	 */
	protected static function getLocation($event_concept_time)
	{
		if (isset(self::$locations[$event_concept_time]))
		{
			return self::$locations[$event_concept_time];
		}
		return 9999;
	}

	/**
	 * @param $location
	 * @return bool|string
	 */
	protected static function getEventConceptTime($location)
	{
		if (isset(self::$event->date['start'][$location]) && isset(self::$event->date['concept'][$location]))
		{
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$event->date['start'][$location]))
			{
				$timestamp = strtotime(self::$event->date['start'][$location]);
			}
			else
			{
				$timestamp = 0;
			}
			return self::$event->id.'_'.self::$event->date['concept'][$location].'__'.$timestamp;
		}
		return false;
	}

	protected static function setDates()
	{
		if (isset(self::$event->date['concept']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$event->date['concept']))
		{
			$types = array('start', 'end');
			self::$eventBuilder['start'] = strtotime('2300-00-00');
			self::$eventBuilder['end'] = strtotime('0000-00-00');
			self::$eventBuilder['timestamps'] = array();
			self::$eventBuilder['dates'] = array();
			foreach( $types as $type)
			{
				foreach (self::$event->date[$type] as $nr => $date)
				{
					// get the key
					if ($key = self::getEventConceptTime($nr))
					{
						// prep the data
						$date = self::$filterInput->clean($date);
						if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($date))
						{
							$timestamp = strtotime($date);
							if (('start' == $type) && self::$eventBuilder[$type] > $timestamp)
							{
								self::$eventBuilder[$type] = $timestamp;
							}
							elseif (('end' == $type) && self::$eventBuilder[$type] < $timestamp)
							{
								self::$eventBuilder[$type] = $timestamp;
							}
							// set time stamp
							if (!isset(self::$eventBuilder['timestamps'][$key]))
							{
								self::$eventBuilder['timestamps'][$key] = array();
							}
							self::$eventBuilder['timestamps'][$key][$type] = $timestamp;
						}
						// set global concept keys
						if ('start' == $type)
						{
							self::$concepts[$key] = self::$event->date['concept'][$nr];
							self::$locations[$key] = $nr;
						}
					}
				}
			}
			// check if time are set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$eventBuilder['timestamps']))
			{
				// now loop the time stamps
				foreach (self::$eventBuilder['timestamps'] as $on => $dates)
				{
					if (isset($dates['start']) && isset($dates['end']))
					{
						if (!isset(self::$eventBuilder['dates'][$on]))
						{
							self::$eventBuilder['dates'][$on] = array();
						}
						self::$eventBuilder['dates'][$on]['start'] = self::fancyDate($dates['start']);
						self::$eventBuilder['dates'][$on]['end'] = self::fancyDate($dates['end']);
						if (date('Ymd', $dates['start']) == date('Ymd', $dates['end']))
						{
							// same day
							self::$eventBuilder['dates'][$on]['start-end'] =  	self::fancyTime($dates['start'])
								.' '.Text::_('to').' '. self::fancyTime($dates['end'])
								.' '.Text::_('on the').' '. self::fancyDate($dates['end']);
						}
						else
						{
							// another day
							self::$eventBuilder['dates'][$on]['start-end'] =  	self::fancyDateTime($dates['start'])
								.' '.Text::_('to').' '. self::fancyDateTime($dates['end']);
						}
					}
				}
				// set the event start and end date
				if (date('Ymd', self::$eventBuilder['start']) == date('Ymd', self::$eventBuilder['end']))
				{
					// one day event
					self::$eventBuilder['start-end'] = self::fancyDate(self::$eventBuilder['start']);
				}
				elseif (date('Ym', self::$eventBuilder['start']) == date('Ym', self::$eventBuilder['end']))
				{
					//  multi day event in same month
					self::$eventBuilder['start-end'] =  date('jS', self::$eventBuilder['start']).' - '. self::fancyDate(self::$eventBuilder['end']);
				}
				else
				{
					// multi day event
					self::$eventBuilder['start-end'] = self::fancyDate(self::$eventBuilder['start']).' - '. self::fancyDate(self::$eventBuilder['end']);
				}
				return true;
			}
		}
		return false;
	}

	/**
	 * @param $id
	 * @param $type
	 */
	protected static function getAllValues($id, $type, $encryptedNames = array())
	{
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select('a.*');
		$query->from($db->quoteName('#__[[[component]]]_'.$type, 'a'));
		$query->where('a.id = ' . (int) $id);
		$query->where('a.published >= 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$result = $db->loadObject();
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($encryptedNames))
			{
				foreach ($encryptedNames as $encrypted)
				{
					if (isset($result->$encrypted) && !empty($result->$encrypted))
					{
						$result->$encrypted = self::decryptString($result->$encrypted);
					}
				}
			}
			return $result;
		}
		return false;
	}

	protected static function decryptString($value)
	{
		if (self::$basickey && !is_numeric($value) && $value === base64_encode(base64_decode($value, true)))
		{
			// decrypt  value
			$value= rtrim(self::$locker->decryptString($value), "\0");
		}
		return $value;
	}

	/**
	 * @param $ids
	 * @param $type
	 * @return array|null
	 */
	public static function getNames($ids, $type)
	{
		// setup the get array
		$get = array('a.id');
		switch($type)
		{
			case 'venue':
				// set related values
				$get[] = 'a.name';
				$table = '#__[[[component]]]_venue';
			break;
			case 'catid':
				// set related values
				$get[] = 'a.title';
				$table = '#__categories';
			break;
			case 'organizer':
				// set related values
				$get[] = 'a.companyname';
				$get[] = 'a.user';
				$table = '#__[[[component]]]_organizer';
			break;				
		}
		if (!isset($table) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
			return null;
		}
		// check the array of ids
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
			foreach ($ids as $id)
			{ 
				if (!(is_numeric($id)))
				{
					return null;
				} 
			}
		}
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName($get));
		$query->from($db->quoteName($table, 'a'));
		$query->where('a.id IN (' . implode(', ', $ids) . ')');
		$query->where('a.published = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$items = $db->loadObjectList();
			$bucket = array();
			foreach ($items as $item)
			{
				switch($type)
				{
					case 'venue':
						// set related values
						$bucket[$item->id] = $item->name;
					break;
					case 'catid':
						// set related values
						$bucket[$item->id] = $item->title;
					break;
					case 'organizer':
						// set related values
						if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($item->companyname))
						{
							$name = $item->companyname;
						}
						else
						{
							$name = Factory::getUser($item->user)->name;
						}
						$bucket[$item->id] = $name;
					break;
				}
			}
			return $bucket;
		}
		return null;
	}
[CUSTOMCODE=imageHelpers] 
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=setDynamicDataIF]
	protected static $placeHolders;
	
	public static function getPlaceHolders($type, $id = null, $registered = null, $config = array())
	{
		if ('invoice' === $type)
		{
			// set to global if not given
			if (!$id && self::$organizer)
			{
				$id = self::$organizer;
			}
			// set to global if not given
			if (!$registered && self::$registered)
			{
				$registered = self::$registered;
			}
			if ($organizer && $registered)
			{
				// get needed details
				if (!isset(self::$placeHolders[$type.'_'.$id.'_'.$registered]))
				{
					$details = array();
					$details[] = self::getOrganizerDetails((int) $id);
					$details[] = self::getRegisteredDetails((int) $registered);
					self::$placeHolders[$type.'_'.$id.'_'.$registered] = self::mergeArrays($details);
				}
				// add the config array if needed
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($config))
				{
					self::$placeHolders[$type.'_'.$id.'_'.$registered] = self::mergeArrays(array(self::$placeHolders[$type.'_'.$id.'_'.$registered], $config));
				}
				return self::$placeHolders[$type.'_'.$id.'_'.$registered];
			}
			return false;
		}
		elseif ('venue' === $type && $id > 0)
		{
			// get needed details
			return self::getVenueDetails((int) $id);
		}
		elseif ('event' === $type && $id > 0)
		{
			// get needed details
			return self::getBasicEventDetails((int) $id);
		}
		elseif ('organizer' === $type && $id > 0)
		{
			// get needed details
			if (!isset(self::$placeHolders[$type.'_'.$id]))
			{
				// load the organizer
				self::$placeHolders[$type.'_'.$id] = self::getOrganizerDetails((int) $id);
			}

			// add the config array if needed
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($config) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$placeHolders[$type.'_'.$id]))
			{
				self::$placeHolders[$type.'_'.$id] = self::mergeArrays(array(self::$placeHolders[$type.'_'.$id], $config));
			}

			// if loaded return
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$placeHolders[$type.'_'.$id]))
			{
				return self::$placeHolders[$type.'_'.$id];
			}
		}
		elseif ((!$id || $id == 0) && ('organizer' === $type || 'venue' === $type || 'event' === $type))
		{
			return array_values(self::getSelection($type, '['.$type.'_', ']'));
		}
		return false;
	}

	/**
	* Return array of selections
	* 
	* @return    array if type match
	*/
	protected static function getSelection($type, $f, $b)
	{
		if ('organizer' === $type)
		{
			return array(
				'a.id' => $f.'id'.$b,	
				'a.user' => $f.'user_id'.$b,
				'a.mobile_phone' => $f.'mobile_phone'.$b,
				'a.companyname' => $f.'companyname'.$b,
				'a.publicnumber' => $f.'publicnumber'.$b,
				'a.currency' => $f.'currency'.$b,
				'a.street' => $f.'street'.$b,
				'a.postal' => $f.'postal'.$b,
				'a.city' => $f.'city'.$b,
				'c.name' => $f.'region'.$b,
				'd.name' => $f.'country'.$b,
				'a.postalcode' => $f.'postalcode'.$b,
				'a.website' => $f.'website'.$b,
				'a' => $f.'website_link'.$b,
				'a.logo_image' => $f.'logo'.$b,
				'b' => $f.'logo_url'.$b,
				'a.prefix' => $f.'prefix'.$b,
				'a.tax_compound' => $f.'tax_compound'.$b,
				'a.taxed' => $f.'taxed'.$b,
				'a.tax_type' => $f.'tax_type'.$b,
				'a.doc_footer' => $f.'doc_footer'.$b,
				'a.doc_header' => $f.'doc_header'.$b,
				'b.name' => $f.'name'.$b,
				'c' => $f.'_name'.$b,
				'b.username' => $f.'username'.$b,
				'b.email' => $f.'email'.$b,
				'c.name' => $f.'region_name'.$b,
				'd.name' => $f.'country_name'.$b
			);
		}
		elseif ('venue' === $type)
		{
			return array(
				'a.id' => $f.'id'.$b,	
				'a.contact_person' => $f.'contact_person'.$b,
				'a.email' => $f.'email'.$b,
				'a.phone' => $f.'phone'.$b,
				'a.name' => $f.'name'.$b,
				'a.details' => $f.'details'.$b,
				'a.banner_image' => $f.'banner_image'.$b,
				'a' => $f.'banner_image_url'.$b,
				'a.poster_image' => $f.'poster_image'.$b,
				'b' => $f.'poster_image_url'.$b,
				'a.teaser_image' => $f.'teaser_image'.$b,
				'c' => $f.'teaser_image_url'.$b,
				'a.venue_images' => $f.'venue_images'.$b,
				'a.street' => $f.'street'.$b,
				'a.city' => $f.'city'.$b,
				'd.name' => $f.'country'.$b,
				'a.marker' => $f.'map'.$b,
				'a.created_by' => $f.'created_by_id'.$b
			);
		}
		elseif ('event' === $type)
		{
			return array(
				'a.id' => $f.'id'.$b,	
				'a.name' => $f.'name'.$b,
				'a.alias' => $f.'alias'.$b,
				'a.date' => $f.'date'.$b,
				'a.related_event' => $f.'related_event'.$b,
				'a.article' => $f.'article'.$b,
				'a.details' => $f.'details'.$b,
				'a.teaser' => $f.'teaser'.$b,
				'a.banner_image' => $f.'banner_image'.$b,
				'a' => $f.'banner_image_url'.$b,
				'a.poster_image' => $f.'poster_image'.$b,
				'b' => $f.'poster_image_url'.$b,
				'a.teaser_image' => $f.'teaser_image'.$b,
				'c' => $f.'teaser_image_url'.$b,
				'a.event_images' => $f.'event_images'.$b,
				'a.checked_out' => $f.'checked_out'.$b,
				'd' => $f.'event_button'.$b,
				'e' => $f.'organizer_button'.$b,
				'f' => $f.'venue_button'.$b,
				'd.id' => $f.'venue_id'.$b,
				'd.name' => $f.'venue_name'.$b,
				'd.checked_out' => $f.'venue_checked_out'.$b,
				'e.id' => $f.'category_id'.$b,
				'e.title' => $f.'category_name'.$b,
				'e.checked_out' => $f.'category_checked_out'.$b,
				'f.id' => $f.'organizer_id'.$b,
				'f.companyname' => $f.'organization'.$b,
				'f.user' => $f.'organizer_user'.$b,
				'f.checked_out' => $f.'organizer_checked_out'.$b,
				'c.name' => $f.'organizer'.$b,
				'c.email' => $f.'organizer_email'.$b
			);
		}
		return false;
	}

	protected static $basicEventDetails = array();

	public static function getBasicEventValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$basicEventDetails[$id]))
			{
				self::setBasicEventDetails($id);
			}
			// get the field if set
			$field = '[event_'.$field.']';
			if (isset(self::$basicEventDetails[$id]) && isset(self::$basicEventDetails[$id][$field]))
			{
				return self::$basicEventDetails[$id][$field];
			}
		}
		return $default;
	}

	public static function getBasicEventDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$basicEventDetails[$id]))
			{
				self::setBasicEventDetails($id);
			}
			return self::$basicEventDetails[$id];
		}
		return false;
	}

	protected static function setBasicEventDetails($id, $method = 'placeholder')
	{
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			$f = '[event_';
			$b = ']';
		}
		// Create a new query object.
		$db = Factory::getDBO();
		$query = $db->getQuery(true);

		// Select some fields
		$selection = self::getSelection('event', $f, $b);
		// remove some that are set dynamically
		unset($selection['a']);
		unset($selection['b']);
		unset($selection['c']);
		unset($selection['d']);
		unset($selection['e']);
		unset($selection['f']);
		$query->select($db->quoteName(array_keys($selection), array_values($selection)));

		// Get the current user for authorisation checks
		$user	= Factory::getUser();
		$levels	= $user->getAuthorisedViewLevels();

		// Get from #__[[[component]]]_event as a
		$query->from($db->quoteName('#__[[[component]]]_event', 'a'));

		// Get from #__[[[component]]]_venue as d
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_venue', 'd')) . ' ON (' . $db->quoteName('a.venue') . ' = ' . $db->quoteName('d.id') . ')');

		// Get from #__categories as e
		$query->join('LEFT', ($db->quoteName('#__categories', 'e')) . ' ON (' . $db->quoteName('a.catid') . ' = ' . $db->quoteName('e.id') . ')');

		// Get from #__[[[component]]]_organizer as f
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_organizer', 'f')) . ' ON (' . $db->quoteName('a.organizer') . ' = ' . $db->quoteName('f.id') . ')');

		// Get from #__users as c
		$query->join('LEFT', ($db->quoteName('#__users', 'c')) . ' ON (' . $db->quoteName('f.user') . ' = ' . $db->quoteName('c.id') . ')');
		// filters
		$query->where('a.accessregistration IN (' . implode(',', $levels) . ')');
		$query->where('a.published = 1');
		$query->where($db->quoteName('a.id') . ' = '. (int) $id);
		// load the query
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$basicEventDetails[$id] = $db->loadAssoc();
			// Get the basic encryption.
			self::$basickey = self::getCryptKey('basic');
			// Get the encryption object.
			self::$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power(self::$basickey, 128);
			// set image file link
			self::$filelink = self::getFolderPath('url');
			// open the teaser image
			$images = array('teaser_image','poster_image','banner_image');
			foreach ($images as $image)
			{
				// set image
				$imageFound = '';
				$imageUrl = '';
				if (isset(self::$basicEventDetails[$id][$f.$image.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$basicEventDetails[$id][$f.$image.$b])) 
				{
	
					$tmpImage = self::$basicEventDetails[$id][$f.$image.$b];
					// open the string.
					$tmpImage = self::decryptString($tmpImage);
					if (strpos($tmpImage, '_') !== false)
					{
						$extention = explode('_', $tmpImage);
						if (isset($extention[2]))
						{
							$imageUrl = self::$filelink.$tmpImage.'.'.$extention[2];
							$imageFound = '<img class="uk-thumbnail" src="'.$imageUrl.'" alt="'.self::$basicEventDetails[$id][$f.'name'.$b].'">';
						}
					}
				}
				// now add the image
				self::$basicEventDetails[$id][$f.$image.$b] = $imageFound;
				self::$basicEventDetails[$id][$f.$image.'_url'.$b] = $imageUrl;
			}
			// set the gallery of images
			if (isset(self::$basicEventDetails[$id][$f.'event_images'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$basicEventDetails[$id][$f.'event_images'.$b]))
			{
				$tmpImages = self::$basicEventDetails[$id][$f.'event_images'.$b];
				if (self::$basickey)
				{
					// open the string.
					$tmpImages = self::decryptString($tmpImages);
				}
				// build an array of images
				if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($tmpImages))
				{
					$tmpImages = json_decode($tmpImages, true);
				}
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmpImages))
				{
					$bucket = array();
					foreach ($tmpImages as $fileName)
					{
						// build the array
						if (strpos($fileName, '_') !== false)
						{
							$extention = explode('_', $fileName);
							if (isset($extention[2]))
							{
								// set link
								$bucket[] = self::$filelink.$fileName.'.'.$extention[2];
							}
						}
					}
				}
				if (isset($bucket) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
				{
					$eventImageWidth = self::$params->get('event_width', 800);
					$eventImageHeight =  self::$params->get('event_height', 600);
					$tabControlID = md5(self::$basicEventDetails[$id][$f.'name'.$b].self::$basicEventDetails[$id][$f.'id'.$b]);
					// build gallery
					$gallery = array();
					$count = count($bucket);
					if ($count == 1)
					{
						$gallery[] = '<div class="uk-grid uk-grid-width-1-1" data-uk-grid-margin>';
					}
					else
					{
						$gallery[] = '<div class="uk-grid uk-grid-width-medium-1-4" data-uk-grid-margin>';
					}
					foreach ($bucket as $val)
					{
						$gallery[] = '<div>';
						$gallery[] = '<a href="' . $val . '" data-uk-lightbox="{group:\'group-' . $tabControlID . '\'}" title="' . self::$basicEventDetails[$id][$f.'name'.$b] . '">';
						$gallery[] = '<img src="' . $val . '" alt="event image" width="' . $eventImageWidth . '" height="' . $eventImageHeight . '">';
						$gallery[] = '</a>';
						$gallery[] = '</div>';
					}
					$gallery[] = '</div>';
					self::$basicEventDetails[$id][$f.'event_images'.$b] = implode('', $gallery);
				}
				else
				{
					self::$basicEventDetails[$id][$f.'event_images'.$b] = '';
				}
			}
			// do final build
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$basicEventDetails[$id][$f.'related_event'.$b]))
			{
				// Decode related_event
				self::$basicEventDetails[$id][$f.'related_event'.$b] = json_decode(self::$basicEventDetails[$id][$f.'related_event'.$b], true);
			}
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$basicEventDetails[$id][$f.'article'.$b]))
			{
				// Decode articles
				self::$basicEventDetails[$id][$f.'article'.$b] = json_decode(self::$basicEventDetails[$id][$f.'article'.$b], true);
			}
			if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check(self::$basicEventDetails[$id][$f.'date'.$b]))
			{
				// Decode dates
				self::$basicEventDetails[$id][$f.'date'.$b] = json_decode(self::$basicEventDetails[$id][$f.'date'.$b], true);
				if ($date = self::setEventStartDate(self::$basicEventDetails[$id][$f.'date'.$b]))
				{
					self::$basicEventDetails[$id][$f.'date'.$b] = $date['text'];
				}
				else
				{
					self::$basicEventDetails[$id][$f.'date'.$b] = '';
				}
			}
			// set email secret
			$eposCode = array('id' => self::$basicEventDetails[$id][$f.'organizer_id'.$b], 'email' => self::$basicEventDetails[$id][$f.'organizer_email'.$b]);
			$eposCode = json_encode($eposCode);
			self::$basicEventDetails[$id][$f.'eposcode'.$b] = self::base64_urlencode(self::$locker->encryptString($eposCode));
			// Always create a slug for sef URL's
			self::$basicEventDetails[$id][$f.'slug'.$b] = (isset(self::$basicEventDetails[$id][$f.'alias'.$b]) && isset(self::$basicEventDetails[$id][$f.'id'.$b])) ? self::$basicEventDetails[$id][$f.'id'.$b].':'.self::$basicEventDetails[$id][$f.'alias'.$b] : self::$basicEventDetails[$id][$f.'id'.$b];
			// set event buttons
			self::$basicEventDetails[$id][$f.'event_button'.$b] = self::loadButtons(self::$basicEventDetails[$id], 'event', $user, $f.'name'.$b, $f.'id'.$b, $f.'checked_out'.$b, $f.'organizer'.$b, $f.'eposcode'.$b, $f.'slug'.$b);
			// set organizer buttons
			self::$basicEventDetails[$id][$f.'organizer_button'.$b] = self::loadButtons(self::$basicEventDetails[$id], 'organizer', $user, $f.'organizer'.$b, $f.'organizer_id'.$b, $f.'organizer_checked_out'.$b, $f.'organizer'.$b, $f.'eposcode'.$b, $f.'slug'.$b);
			// set venue buttons
			self::$basicEventDetails[$id][$f.'venue_button'.$b] = self::loadButtons(self::$basicEventDetails[$id], 'venue', $user, $f.'venue_name'.$b, $f.'venue_id'.$b, $f.'venue_checked_out'.$b, $f.'organizer'.$b, $f.'eposcode'.$b, $f.'slug'.$b);			
		}
		else
		{
			self::$basicEventDetails[$id] = false;
		}
	}

	protected static $venueDetails = array();

	public static function getVenueValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$venueDetails[$id]))
			{
				self::setVenueDetails($id);
			}
			// get the field if set
			$field = '[venue_'.$field.']';
			if (isset(self::$venueDetails[$id]) && isset(self::$venueDetails[$id][$field]))
			{
				return self::$venueDetails[$id][$field];
			}
		}
		return $default;
	}

	public static function getVenueDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$venueDetails[$id]))
			{
				self::setVenueDetails($id);
			}
			return self::$venueDetails[$id];
		}
		return false;
	}

	protected static function setVenueDetails($id, $method = 'placeholder')
	{
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			$f = '[venue_';
			$b = ']';
		}
		// Create a new query object.
		$db = Factory::getDBO();
		$query = $db->getQuery(true);

		// Select some fields
		$selection = self::getSelection('venue', $f, $b);
		// remove some that are set dynamically
		unset($selection['a']);
		unset($selection['b']);
		unset($selection['c']);
		unset($selection['d']);
		$query->select($db->quoteName(array_keys($selection), array_values($selection)));

		// From the [[[component]]]_venue table				
		$query->from($db->quoteName('#__[[[component]]]_venue', 'a'));				

		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_country', 'd')) . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('d.id') . ')');
		$query->where($db->quoteName('a.id') . ' = '. (int) $id);
		// load the query
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$venueDetails[$id] = $db->loadAssoc();
			// Get the basic encryption.
			self::$basickey = self::getCryptKey('basic');
			if (self::$basickey)
			{
				// Get the encryption object.
				self::$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power(self::$basickey, 128);
			}
			// set image file link
			self::$filelink = self::getFolderPath('url');
			// set single images
			$images = array('banner_image', 'poster_image', 'teaser_image');
			foreach ($images as $image)
			{
				// set image
				$imageFound = '';
				$imageUrl = '';
				if (isset(self::$venueDetails[$id][$f.$image.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$venueDetails[$id][$f.$image.$b])) 
				{
					
					$tmpImage = self::$venueDetails[$id][$f.$image.$b];
					// open the string.
					$tmpImage = self::decryptString($tmpImage);
					if (strpos($tmpImage, '_') !== false)
					{
						$extention = explode('_', $tmpImage);
						if (isset($extention[2]))
						{
							$imageUrl = self::$filelink.$tmpImage.'.'.$extention[2];
							$imageFound = '<img class="uk-thumbnail" src="'.$imageUrl.'" alt="'.self::$venueDetails[$id][$f.'name'.$b].'">';
						}
					}
				}
				// now add the image
				self::$venueDetails[$id][$f.$image.$b] = $imageFound;
				self::$venueDetails[$id][$f.$image.'_url'.$b] = $imageUrl;
			}
			// set the gallery of images
			if (isset(self::$venueDetails[$id][$f.'venue_images'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$venueDetails[$id][$f.'venue_images'.$b]))
			{
				$tmpImages = self::$venueDetails[$id][$f.'venue_images'.$b];
				if (self::$basickey)
				{
					// open the string.
					$tmpImages = self::decryptString($tmpImages);
				}
				// build an array of images
				if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($tmpImages))
				{
					$tmpImages = json_decode($tmpImages, true);
				}
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tmpImages))
				{
					$bucket = array();
					foreach ($tmpImages as $fileName)
					{
						// build the array
						if (strpos($fileName, '_') !== false)
						{
							$extention = explode('_', $fileName);
							if (isset($extention[2]))
							{
								// set link
								$bucket[] = self::$filelink.$fileName.'.'.$extention[2];
							}
						}
					}
				}
				if (isset($bucket) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($bucket))
				{
					$eventImageWidth = self::$params->get('venue_width', 800);
					$eventImageHeight =  self::$params->get('venue_height', 600);
					$tabControlID = md5(self::$venueDetails[$id][$f.'name'.$b].self::$venueDetails[$id][$f.'id'.$b]);
					// build gallery
					$gallery = array();
					$count = count($bucket);
					if ($count == 1)
					{
						$gallery[] = '<div class="uk-grid uk-grid-width-1-1" data-uk-grid-margin>';
					}
					else
					{
						$gallery[] = '<div class="uk-grid uk-grid-width-medium-1-4" data-uk-grid-margin>';
					}
					foreach ($bucket as $val)
					{
						$gallery[] = '<div>';
						$gallery[] = '<a href="' . $val . '" data-uk-lightbox="{group:\'group-' . $tabControlID . '\'}" title="' . self::$venueDetails[$id][$f.'name'.$b] . '">';
						$gallery[] = '<img src="' . $val . '" alt="venue image" width="' . $eventImageWidth . '" height="' . $eventImageHeight . '">';
						$gallery[] = '</a>';
						$gallery[] = '</div>';
					}
					$gallery[] = '</div>';
					self::$venueDetails[$id][$f.'venue_images'.$b] = implode('', $gallery);
				}
				else
				{
					self::$venueDetails[$id][$f.'venue_images'.$b] = '';
				}
			}
		}
		else
		{
			self::$venueDetails[$id] = false;
		}
	}
	
	protected static $itemOrganizer = array();

	public static function getItemOrganizer(&$item, $type, $key = 'id', $default = null)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($item) && isset($item->$key) && (int) $item->$key > 0)
		{
			// check if already set
			if (!isset(self::$itemOrganizer[$type.$item->$key]))
			{
				self::setItemOrganizer($item, $type, $key);
			}
			if (isset(self::$itemOrganizer[$type.$item->$key]) && self::$itemOrganizer[$type.$item->$key])
			{
				return self::$itemOrganizer[$type.$item->$key];
			}
		}
		return $default;
	}
	
	protected static function setItemOrganizer(&$item, $type, $key)
	{
		// get organizer id for various types of items
		switch($type)
		{
			case 'transaction':
				if (isset($item->invoice))
				{
					self::$itemOrganizer[$type.$item->$key] = self::getVar('invoice', $item->invoice, 'id', 'organizer');
				}
			break;
		}
	}

	protected static $organizerDetails = array();

	public static function getOrganizerValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$organizerDetails[$id]))
			{
				self::setOrganizerDetails($id);
			}
			// get the field if set
			$field = '[organizer_'.$field.']';
			if (isset(self::$organizerDetails[$id]) && isset(self::$organizerDetails[$id][$field]))
			{
				return self::$organizerDetails[$id][$field];
			}
		}
		return $default;
	}

	public static function getOrganizerDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$organizerDetails[$id]))
			{
				self::setOrganizerDetails($id);
			}
			return self::$organizerDetails[$id];
		}
		return false;
	}

	protected static function setOrganizerDetails($id, $method = 'placeholder')
	{
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			$f = '[organizer_';
			$b = ']';
		}
		// Create a new query object.
		$db = Factory::getDBO();
		$query = $db->getQuery(true);

		// Select some fields
		$selection = self::getSelection('organizer', $f, $b);
		// remove some that are set dynamically
		unset($selection['a']);
		unset($selection['b']);
		unset($selection['c']);
		$query->select($db->quoteName(array_keys($selection), array_values($selection)));

		// From the [[[component]]]_organizer table				
		$query->from($db->quoteName('#__[[[component]]]_organizer', 'a'));				
		$query->join('LEFT', ($db->quoteName('#__users', 'b')) . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('b.id') . ')');
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_region', 'c')) . ' ON (' . $db->quoteName('a.region') . ' = ' . $db->quoteName('c.id') . ')');
		$query->join('LEFT', ($db->quoteName('#__[[[component]]]_country', 'd')) . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('d.id') . ')');
		$query->where($db->quoteName('a.id') . ' = '. (int) $id);
		// load the query
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$organizerDetails[$id] = $db->loadAssoc();
			// load the name
			if (isset(self::$organizerDetails[$id][$f.'companyname'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id][$f.'companyname'.$b]))
			{
				$name = self::$organizerDetails[$id][$f.'companyname'.$b];
			}
			else
			{
				$name = self::$organizerDetails[$id][$f.'name'.$b];
			}
			self::$organizerDetails[$id][$f.'_name'.$b] = $name;
			// set website link
			$link = '';
			if (isset(self::$organizerDetails[$id][$f.'website'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id][$f.'website'.$b])) 
			{
				// set link
				if (strpos(self::$organizerDetails[$id][$f.'website'.$b], 'http://') !== false || strpos(self::$organizerDetails[$id][$f.'website'.$b], 'https://') !== false)
				{
					$link = '<a href="'.self::$organizerDetails[$id][$f.'website'.$b].'">' . $name . '</a>';
				}
				else
				{
					$link = '<a href="http://'.self::$organizerDetails[$id][$f.'website'.$b].'">' . $name . '</a>';
				}
			}
			self::$organizerDetails[$id][$f.'website_link'.$b] = $link;

			// set logo image
			$logoFound = '';
			$logoUrl = '';
			if (isset(self::$organizerDetails[$id][$f.'logo'.$b]) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$organizerDetails[$id][$f.'logo'.$b])) 
			{
				// Get the basic encryption.
				self::$basickey = self::getCryptKey('basic');
				$logo = self::$organizerDetails[$id][$f.'logo'.$b];
				if (self::$basickey)
				{
					// Get the encryption object.
					self::$locker = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power(self::$basickey, 128);
					$logo = self::decryptString($logo);
				}
				if (strpos($logo, '_') !== false)
				{
					$extention = explode('_', $logo);
					if (isset($extention[2]))
					{
						$logoUrl = self::getFolderPath('url').$logo.'.'.$extention[2];
						$logoFound = '<img class="uk-thumbnail" src="'.$logoUrl.'" alt="'.$name.'">';
					}
				}
			}
			// now add the logo
			self::$organizerDetails[$id][$f.'logo'.$b] = $logoFound;
			self::$organizerDetails[$id][$f.'logo_url'.$b] = $logoUrl;
		}
		else
		{
			self::$organizerDetails[$id] = false;
		}
	}

	protected static $regUsers = array();

	public static function getRegUserValue($id, $field, $default = null)
	{
		if ($id > 0 )
		{
			if (!isset(self::$regUsers[$id]))
			{
				self::setRegUserValue($id);
			}
			// get the field if set
			$field = '[registered_'.$field.']';
			if (isset(self::$regUsers[$id]) && isset(self::$regUsers[$id][$field]))
			{
				return self::$regUsers[$id][$field];
			}
		}
		return $default;
	}

	public static function getRegisteredDetails($id)
	{
		if ($id > 0)
		{
			if (!isset(self::$regUsers[$id]))
			{
				self::setRegUserValue($id);
			}
			return self::$regUsers[$id];
		}
		return false;
	}
	
	protected static function setRegUserValue($id, $method = 'placeholder')
	{
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			$f = '[registered_';
			$b = ']';
		}
		// first get the user
		$userId = self::getVar('registered_user', $id, 'id', 'user');
		$user = Factory::getUser($userId);
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array('a.name','a.value'),
			array('name','value')));
		$query->from($db->quoteName('#__registry_custom_value', 'a'));
		$query->where('a.registered_user = ' . (int) $id);
		$query->where('a.published >= 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$customValues = $db->loadAssocList('name', 'value');
			// possible keys
			$search = array(
				'country' 
					=> array('country', 'country_one', 'country_1', 'country1', 'countryone', 'country_'), 
				'currency' 
					=> array('currency', 'currency_one', 'currency_1', 'currency1', 'currencyone', 'currency_'), 
				'region' 
					=> array('region', 'region_one', 'region_1', 'region1', 'regionone', 'region_')
				);
			self::$regUsers[$id] = array();
			foreach ($customValues as $key => $value)
			{
				self::$regUsers[$id][$f.$key.$b] = $value;
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($value) && !is_numeric($value))
				{
					$found = false;
					$newValue = '';
					foreach ($search as $code => $keys)
					{
						if (!$found)
						{
							foreach($keys as $ke_y)
							{
								if (!$found && $ke_y === strtolower($key))
								{
									if ($newValue = self::getVar($code, $value, 'name', 'id'))
									{
										// insure we use the correct key
										$key = $code;
										// stop search for this field
										$found = true;
									}
								}
							}
						}
					}
					// add also if found
					if ($found)
					{
						self::$regUsers[$id][$f.$key.$b] = (int) $newValue;
						self::$regUsers[$id][$f.$key.'_name'.$b] = $value;
						if ('country' === $key || 'currency' === $key)
						{
							self::$regUsers[$id][$f.$key.'_codethree'.$b] = self::getVar($key, (int) $newValue, 'id', 'codethree');
						}
					}
				}
			}
		}
		// if no currency was found but country, then set the currency to that of the country
		if (!isset(self::$regUsers[$id][$f.'currency_name'.$b]) && isset(self::$regUsers[$id][$f.'country_name'.$b]))
		{
			self::$regUsers[$id][$f.'currency_codethree'.$b] = self::getVar('country', self::$regUsers[$id][$f.'country'.$b], 'id', 'currency');
			self::$regUsers[$id][$f.'currency'.$b] = self::getVar('currency', self::$regUsers[$id][$f.'currency_codethree'.$b], 'codethree', 'id');
			self::$regUsers[$id][$f.'currency_name'.$b] = self::getVar('currency', self::$regUsers[$id][$f.'currency'.$b], 'id', 'name');
		}
		// now load all the user values
		if ($userId > 0)
		{
			self::$regUsers[$id]['[registered_id]'] = $id;
			self::$regUsers[$id]['[registered_user_id]'] = $userId;
			self::$regUsers[$id]['[registered_name]'] = $user->name;
			self::$regUsers[$id]['[registered_username]'] = $user->username;
			self::$regUsers[$id]['[registered_email]'] = $user->email;
		}
		else
		{
			self::$regUsers[$id] = false;
		}
	}
	
	protected static $taxLocation = array();

	public static function getTaxLocation($type, $id, $view)
	{
		if ($id > 0 || 'cart' === $view)
		{
			$key = $type.$view.$id;
			if (!isset(self::$taxLocation[$key]))
			{
				self::setTaxLocation($type, $id, $view, $key);
			}
			if (isset(self::$taxLocation[$key]) && self::$taxLocation[$key] > 0)
			{
				return self::$taxLocation[$key];
			}
		}
		return false;
	}

	protected static function setTaxLocation($field, $id, $view, $key)
	{
		switch ($view)
		{
			case 'invoice':
				// get the client id from job id
				$registered_user = self::getVar($view, $id, 'id', 'registered_user');
				// return location id from client table
				if ($registered_user > 0)
				{
					self::$taxLocation[$key] = self::getRegUserValue($registered_user, $field);
				}
			break;
			case 'cart':
			case 'event':
				// first find out who this is
				$userIs = self::userIs(null, true);
				if ($userIs['is'] == 3 || $userIs['is'] == 2)
				{
					break;
				}
				elseif ($userIs['is'] == 1 && $userIs['id'] > 0)
				{
					self::$taxLocation[$key] = self::getRegUserValue($userIs['id'], $field);
				}
				elseif ('country' === $field)
				{
					// public user so we first get country
					if ($countryThree = self::getLocationdata(null, null, null, 'USD', 10, 1))
					{
						self::$taxLocation[$key] = self::getVar('country', $countryThree, 'codethree', 'id');
					}
				}
			break;
		}
	}

	public static function getTax(&$taxed, &$total, $id, $view)
	{
		$setTax = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###')->get('taxed', 0);
		if ($setTax == 1 && 1 == self::getOrganizerValue(self::$organizer, 'taxed', 0))
		{
			// set the tax to this array
			$tax = array();
			$taxAddTotal = array();
			$deduct = array();
			// get the country of the client
			$country = self::getTaxLocation('country', $id, $view);
			// get the region of the client
			$region = self::getTaxLocation('region', $id, $view);
			// now get tax level 1 of this Country and or Region
			$taxLevel1 = self::getTaxRule(1,$country,$region);
			// now get tax level 2 of this Country and or Region
			$taxLevel2 = self::getTaxRule(2,$country,$region);
			// tax types
			$tax_type = self::getOrganizerValue(self::$organizer, 'tax_type', 2);
			// tax compound
			$tax_compound = self::getOrganizerValue(self::$organizer, 'tax_compound', null);
			// based on tax type
			if (2 == $tax_type)
			{
				// tax excluded
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					$tmpAmount =  bcmul($taxed, $taxLevel1['tax'], 20);
					$tax[0]['amount'] = bcdiv($tmpAmount, 100, 4);
					// add to tax total
					$taxAddTotal[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$taxedSub = bcadd($taxed, $tax[0]['amount'], 20);
						$tmpAmount =  bcmul($taxedSub, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					else
					{
						$tmpAmount =  bcmul($taxed, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tmpAmount, 100, 4);
					}
					// add to tax total
					$taxAddTotal[] = $tax[1]['amount'];
				}
			}
			elseif (1 == $tax_type)
			{
				$removal = array();
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$removal[] = $taxLevel1['tax'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$removal[] = $taxLevel2['tax'];
				}
				$removal = self::bcsum($removal);
				// tax included
				if ($taxLevel1 && isset($taxLevel1['tax']) && is_numeric($taxLevel1['tax']) && isset($taxLevel1['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel1['name']))
				{
					$tax[0]['name'] = $taxLevel1['name'];
					$tax[0]['tax'] = $taxLevel1['tax'];
					if ($tax_compound == 1 && $taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']))
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal_a = bcdiv($taxed, $tempVal2, 20);
						$tempVal3 = bcdiv($taxLevel1['tax'], 100, 20);
						$tempVal4 = bcadd($tempVal3, 1, 20);
						$tempVal_b = bcdiv($tempVal_a, $tempVal4, 20);
						$tax[0]['amount'] =  bcsub($tempVal_a, $tempVal_b, 4);
					}
					else
					{
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel1['tax'], 20);
						$tax[0]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[0]['amount'];
				}
				if ($taxLevel2 && isset($taxLevel2['tax']) && is_numeric($taxLevel2['tax']) && isset($taxLevel2['name']) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($taxLevel2['name']))
				{
					$tax[1]['name'] = $taxLevel2['name'];
					$tax[1]['tax'] = $taxLevel2['tax'];
					if ($tax_compound == 1 && isset($tax[0]['amount']) && $tax[0]['amount'] > 0)
					{
						$tempVal1 = bcdiv($taxLevel2['tax'], 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$tempVal = bcdiv($taxed, $tempVal2, 20);
						$tax[1]['amount'] = bcsub($taxed, $tempVal, 4);
					}
					else
					{
						$tax[1]['name'] = $taxLevel2['name'];
						$tax[1]['tax'] = $taxLevel2['tax'];
						$tempVal1 = bcdiv($removal, 100, 20);
						$tempVal2 = bcadd($tempVal1, 1, 20);
						$excluding = bcdiv($taxed, $tempVal2, 20);
						$tempVal = bcmul($excluding, $taxLevel2['tax'], 20);
						$tax[1]['amount'] = bcdiv($tempVal, 100, 4); 
					}
					// remove from price
					$deduct[] = $tax[1]['amount'];
				}
			}
			// check if there was tax set
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($tax))
			{
				// add the tax to total
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($taxAddTotal))
				{
					$taxed = self::bcsum($taxAddTotal);
					$total = self::bcsum(array($total, $taxed));
				}
				elseif (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($deduct))
				{
					$taxed = self::bcsum($deduct);
				}
				return $tax;
			}
		}
		return false;
	}
		
	protected static $taxrules = array();

	protected static function getTaxRule($level, $country = 0, $region = 0)
	{
		// build the key
		if (self::$organizer)
		{
			$key = $level.$country.$region.self::$organizer;
			// check if it has been set
			if (!isset(self::$taxrules[$key]))
			{
				// Get a db connection.
				$db = Factory::getDbo();
				// set the tax rule
				self::setTaxRule($db, $key, $level, $country, $region);
			}
			// check if it has been set
			if (isset(self::$taxrules[$key]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$taxrules[$key]))
			{
				return self::$taxrules[$key];
			}
		}
		return false;
	}

	protected static function setTaxRule($db, $key, $level, $country = 0, $region = 0)
	{
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(
			array(	'a.id','a.tax','a.name'),
			array(	'id','tax','name')));
		$query->from($db->quoteName('#__[[[component]]]_tax_rule', 'a'));
		$query->where($db->quoteName('a.published') . ' = 1');
		$query->where($db->quoteName('a.level') . ' = '. (int) $level);
		$query->where($db->quoteName('a.organizer') . ' = '. (int) self::$organizer);
		// check for country and region
		$query->where($db->quoteName('a.country') . ' = '. (int) $country);
		$query->where($db->quoteName('a.region') . ' = '. (int) $region);
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			self::$taxrules[$key] = $db->loadAssoc();
		}
		elseif ((int)$country > 0 && (int)$region > 0)
		{
			// now only check for country
			return self::setTaxRule($db, $key, $level, $country);
		}
		elseif ((int)$country > 0 && $region == 0)
		{
			// now check for any without country
			return self::setTaxRule($db, $key, $level);
		}
	}

	/**
	* @param float $amount
	**/
	public static function bcsum($array, $scale = 4)
	{
		$res = 0.0;
		foreach($array as $val){
			$res = bcadd($res, $val, $scale);
		}
		return $res;
	}

	/**
	 * @param $amount
	 * @return mixed|number
	 */
	public static function addCurrency($amount, $codethree = null)
	{
		return self::makeMoney($amount, $codethree);
	}

	protected static $currencyDetails = array();

	/**
	 * @param bool $codethree
	 * @return bool|mixed
	 */
	public static function getCurrencyDetails($codethree = false)
	{
		// check if currency codethree is set
		if (!$codethree && isset(self::$organizer) && self::$organizer > 0)
		{
			// get the price currency
			$codethree = self::getOrganizerValue(self::$organizer, 'currency', false);
		}
		elseif (!$codethree)
		{
			$codethree = self::get('ACTIVE_CURRENCY');
		}
		// return cached data if set
		if ($codethree && !isset(self::$currencyDetails[$codethree]))
		{
			// Get a db connection.
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(
				array(	'a.id','a.name','a.codethree','a.numericcode','a.symbol','a.thousands','a.decimalplace',
					'a.decimalsymbol','a.positivestyle','a.negativestyle'),
				array(	'currency_id','currency_name','currency_codethree','currency_numericcode','currency_symbol',
					'currency_thousands','currency_decimalplace','currency_decimalsymbol','currency_positivestyle',
					'currency_negativestyle')));
			$query->from($db->quoteName('#__[[[component]]]_currency', 'a'));
			if (is_numeric($codethree))
			{
				$query->where($db->quoteName('a.id') . ' = '. (int) $codethree);
			}
			elseif (strlen($codethree) == 3)
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote($codethree));
			}
			else
			{
				$query->where($db->quoteName('a.codethree') . ' = '.$db->quote('NONE'));
			}
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				self::$currencyDetails[$codethree] = $db->loadObject();
			}
		}
		// make sure it has been set
		if (isset(self::$currencyDetails[$codethree]))
		{
			return self::$currencyDetails[$codethree];
		}
		return false;
	}
[CUSTOMCODE=makeMoney]
[CUSTOMCODE=niceFancyDate]
	public static function newDocNumber($organizer, $id = null)
	{
		if (is_numeric($organizer))
		{
			// check if this invoice has transactions
			$isInvoice = false;
			if ($id)
			{
				if ($foundTrans = self::getVar('transaction', $id, 'invoice', 'id'))
				{
					$isInvoice = true;
				}
			}
			// first we get organizers invoicing method
			$proforma = self::getVar('organizer', $organizer, 'id', 'proforma');
			if (0 == $proforma || $isInvoice)
			{
				$isInvoice = true;
				$next = (int) self::getVar('organizer', $organizer, 'id', 'next_invoice_number');
				// make sure the next is a number
				if (!is_numeric($next) || !$next || empty($next) || $next < 1)
				{
					$next = 1;
				}
				// update the next number now
				$org = new \stdClass();
				$org->id = $organizer;
				$org->next_invoice_number = (int) $next + 1;
				Factory::getDbo()->updateObject('#__[[[component]]]_organizer', $org, 'id');
			}
			elseif (1 == $proforma)
			{
				$next = (int) self::getVar('organizer', $organizer, 'id', 'next_proforma_number');
				// make sure the next is a number
				if (!is_numeric($next) || !$next || empty($next) || $next < 1)
				{
					$next = 1;
				}
				// update the next number now
				$org = new \stdClass();
				$org->id = $organizer;
				$org->next_proforma_number = (int) $next + 1;
				Factory::getDbo()->updateObject('#__[[[component]]]_organizer', $org, 'id');
			}
			// get prefix
			$prefix = self::getOrganizerValue($organizer, 'prefix', 'VDM');
			if ($isInvoice)
			{
				return 'INV-'.$prefix.sprintf('%07d', $next);
			}
			else
			{
				return 'PI-'.$prefix.sprintf('%06d', $next);
			}
		}
	}

	public static function checkNr(&$item, $where)
	{
		list($type, $column) = explode('.', $where);
		if ($type && $column && isset($item->$column))
		{
			// load the all items with the same column
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select(array('id' ,'created', 'number', 'organizer'));
			$query->from($db->quoteName('#__[[[component]]]_'.$type));
			$query->where($db->quoteName($column) . ' = '.$db->quote($item->$column));
			if (isset($item->organizer))
			{
				$query->where($db->quoteName('organizer') . ' = ' . (int) $item->organizer);
			}
			$query->order('created ASC');
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$found = $db->loadObjectList();
				if (count($found) > 1)
				{
					// is the current item the older one?
					if ($item->id != $found[0]->id)
					{
						self::setNr($item, $type, $column);							
					}
				}
			}
			// insure we update Proformas once payment is made
			if (strpos($item->$column, 'PI') !== false)
			{
				if ($update = self::getVar('transaction', $item->id, 'invoice', 'id'))
				{
					// if proforma is set store backup for later use.
					self::setNr($item, $type, $column, false, 'proforma');
					// update to invoice
					self::setNr($item, $type, $column);
				}
			}
			else
			{
				if (!$update = self::getVar('transaction', $item->id, 'invoice', 'id'))
				{
					// take back to proforma (TODO - may not be ideal)
					self::setNr($item, $type, $column);
				}
			}
		}
		if (!$item->$column || empty($item->$column))
		{
			// if not set, then set now
			self::setNr($item, $type, $column);	
		}
	}
	
	protected static function setNr(&$item, &$type, &$column, $new = true, $other = null)
	{
		if ($new)
		{
			// first update the item
			$item->$column	= self::newDocNumber($item->organizer, $item->id);
		}
		// now update the table
		$updateItem		= new \stdClass;
		$updateItem->id		= $item->id;
		if ($column)
		{
			$updateItem->$column = $item->$column;
			if ($other)
			{
				// update the other field with the column
				$updateItem->$other = $item->$column;
				$item->$other = $item->$column;
			}
		}				
		// update the item now
		Factory::getDbo()->updateObject('#__[[[component]]]_'.$type, $updateItem, 'id');
	}
[CUSTOMCODE=getFilePath]
[CUSTOMCODE=getFolderPath]
[CUSTOMCODE=getLinkOptions]', 'CS8qKg0KCSogCW1ha2Ugc3VyZSBsb2NhdGlvbiBkYXRhIGlzIGxvYWRlZA0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gbG9hZExvY2F0aW9uRGF0YSgpDQoJew0KCQlpZiAoIWNsYXNzX2V4aXN0cygnTG9jYXRpb25kYXRhSGVscGVyJywgRkFMU0UpKQ0KCQl7DQoJCQkkcGF0aCA9IEpQQVRIX1JPT1QgLiAnL2NvbXBvbmVudHMvY29tX2xvY2F0aW9uZGF0YS9oZWxwZXJzL2xvY2F0aW9uZGF0YS5waHAnOw0KCQkJaWYgKGZpbGVfZXhpc3RzKCRwYXRoKSkNCgkJCXsNCgkJCQkvLyBtYWtlIHN1cmUgdG8gbG9hZCB0aGUgaGVscGVyDQoJCQkJSkxvYWRlcjo6cmVnaXN0ZXIoJ0xvY2F0aW9uZGF0YUhlbHBlcicsICRwYXRoKTsNCgkJCQkvLyBmaXN0IHNldCB0aGUgZGVmYXVsdCBjb21wb25lbnQNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OiRkZWZhdWx0Q29tcG9uZW50ID0gJ2NvbV9bW1tjb21wb25lbnRdXV0nOw0KCQkJCXJldHVybiB0cnVlOw0KCQkJfQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCXJldHVybiB0cnVlOw0KCX0NCg0KCS8qKg0KCSogCWNhbmNlbCBFeHBpcmVkIENhcnQgSXRlbXMNCgkqKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIGNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KQ0KCXsNCgkJLy8gYWRkIGFuIGV2ZW50IHRoYXQgd2lsbCBzZW5kIG91dCBhbGwgY29uZmlybWF0aW9uIGVtYWlscywgbm90IHlldCBzZW5kDQoJCSRkb2N1bWVudC0+YWRkU2NyaXB0RGVjbGFyYXRpb24oIg0KCQkJalF1ZXJ5KHdpbmRvdykubG9hZChmdW5jdGlvbigpIHsNCgkJCQljYW5jZWxFeHBpcmVkQ2FydEl0ZW1zKDEpLmRvbmUoZnVuY3Rpb24ocmVzdWx0KSB7DQoJCQkJCWlmKHJlc3VsdCl7DQoJCQkJCQljb25zb2xlLmxvZyhyZXN1bHQpOw0KCQkJCQl9DQoJCQkJfSk7DQoJCQl9KTsNCgkJCQ0KCQkJZnVuY3Rpb24gY2FuY2VsRXhwaXJlZENhcnRJdGVtcyh0eXBlKSB7DQoJCQkJdmFyIGdldFVybCA9ICciLlVyaTo6cm9vdCgpLiJpbmRleC5waHA/b3B0aW9uPWNvbV9bW1tjb21wb25lbnRdXV0mdGFzaz1hamF4LmNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMmZm9ybWF0PWpzb24nOw0KCQkJCWlmKHR5cGUgPiAwKXsNCgkJCQkJdmFyIHJlcXVlc3QgPSAndG9rZW49Ii5Kb29tbGFfX181YmEzODUxM181YzRmXzRiMGRfOTM1ZV80OWU5ODZhNmJjZThfX19Qb3dlcjo6Z2V0Rm9ybVRva2VuKCkuIiZ0eXBlPScrdHlwZTsNCgkJCQl9DQoJCQkJcmV0dXJuIGpRdWVyeS5hamF4KHsNCgkJCQkJdHlwZTogJ1BPU1QnLA0KCQkJCQl1cmw6IGdldFVybCwNCgkJCQkJZGF0YVR5cGU6ICdqc29ucCcsDQoJCQkJCWRhdGE6IHJlcXVlc3QsDQoJCQkJCWpzb25wOiAnY2FsbGJhY2snDQoJCQkJfSk7DQoJCQl9Iik7DQoJfQ==', '', '', '', '', '', 'CQkvLyBydW4gc29tZSBob3VzZSBjbGVhbmluZw0KCQlpZiAoc2VsZjo6bG9hZExvY2F0aW9uRGF0YSgpKQ0KCQl7DQoJCQkvLyBydW4gdGhlIGxvY2F0aW9uIGRhdGEgcXVldWUgKHRvIGluc3VyZSBhbGwgY3JvbiBqb2JzIHJ1biB0aW1lbHkpDQoJCQlpZiAoJGRvY3VtZW50IGluc3RhbmNlb2YgSkRvY3VtZW50SHRtbCkNCgkJCXsNCgkJCQlMb2NhdGlvbmRhdGFIZWxwZXI6OnRoZVF1ZXVlKCRkb2N1bWVudCk7DQoJCQl9DQoJCX0NCgkJLy8gdGhlIFNlc3Npb24ga2VlcHMgdHJhY2sgb2YgYWxsIGRhdGEgcmVsYXRlZCB0byB0aGUgY3VycmVudCBzZXNzaW9uIG9mIHRoaXMgdXNlcg0KCQlzZWxmOjpsb2FkU2Vzc2lvbigpOw0KCQkvLyBjbGVhciB0aGUgY2FydCBpdGVtcyBpZiBleHBpcmVkDQoJCXNlbGY6OmNhbmNlbEV4cGlyZWRDYXJ0SXRlbXMoJGRvY3VtZW50KTs=', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Event registration component.', '', '', 'Registry', '.git', '', 1, 1, 'https://www.vdm.io/updates/registry_update_server.xml', 'https://www.vdm.io/', '', 'jqif3P20pl7i+oN/1eoZAJmOTlPh+TxrApbvTXJTruk86ZFIi6euOwrcLiunSXiH', 'https://www.vdm.io/access/', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 96, '', 1, 67), -(30, 1, '', '', '', '', '', '', '', 1, '', '', 1, 1, '', '', '', '', 1, '', 1, '', 1, '', '', '', '{}', 3, 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.1.0', 'Copyright (C) 2015. All Rights Reserved', '2017-01-30 13:53:54', '', 'Zdib+VUoIO/nAixMFHZyp2kTyD8oovQFhnAqodP9u6c=', 'EUg/4403qYU3kFEWMPLOQ//UpQBIJVDy36kZcnuooyk=', '', 'KSHC/+OhgfJ+HNbeFktXS39k1XO/hHNoB0f8P+7XzWQ=', '', '', '', 1, '', 'Just a basic document manager.', 'joomla@vdm.io', '', 'https://vdm.bz/jcb-document-manager', 'wnfGON0VXO+EKjfaWp2UHLQHb2EwbwTjs77WSjBR8rhfMb5/Ry8MsIK7XSbzqvrWW7j/YCn79Ku+E7ze924KWA==', '', '99cefa69-b61d-4964-adf5-2147b4b01742', 'images/vdm/DM500.jpg', '', 'https://github.com/vdm-io/JCB-Packages/raw/master/JCB_documentManager.zip', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-03-08 03:12:29', 1, 'Document Manager', 'documentmananger', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', '	/**
	* 	the globals
	**/
	protected static $params;
	protected static $user;
	protected static $locker;
	protected static $basickey;

	/**
	* 	set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// noting set for now
	}

	/**
	 * @param $ids
	 * @param $type
	 * @return array|null
	 */
	public static function getNames($ids, $type, $getAlias = false)
	{
		// setup the get array
		$get = array('a.id');
		if ($getAlias)
		{
			$get[] = 'a.alias';
		}
		switch($type)
		{
			case 'catid':
				// set related values
				$get[] = 'a.title';
				$table = '#__categories';
			break;
			case 'type':
				// set related values
				$get[] = 'a.name';
				$table = '#__[[[component]]]_type';
			break;
			case 'tag':
				// set related values
				$get[] = 'a.title';
				$table = '#__tags';
			break;		
		}
		if (!isset($table) || !Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
			return null;
		}
		// check the array of ids
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($ids))
		{
			foreach ($ids as $id)
			{ 
				if (!(is_numeric($id)))
				{
					return null;
				} 
			}
		}
		// now load all custom values
		$db = Factory::getDBO();
		$query = $db->getQuery(true);
		$query->select($db->quoteName($get));
		$query->from($db->quoteName($table, 'a'));
		$query->where('a.id IN (' . implode(', ', $ids) . ')');
		$query->where('a.published = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$items = $db->loadObjectList();
			$bucket = array();
			foreach ($items as $item)
			{
				// set alias if needed
				if ($getAlias && isset($item->alias) && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($item->alias))
				{
					$item->id = $item->id . ':' . $item->alias;
				}
				// set related values
				switch($type)
				{
					case 'catid':
					case 'tag':
						$bucket[$item->id] = $item->title;
					break;
					case 'type':
						// set related values
						$bucket[$item->id] = $item->name;
					break;
				}
			}
			return $bucket;
		}
		return null;
	}

	public static function hasEditAccess($recordId, $userId = null, $to = 'document')
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($userId) && $userId instanceof JUser)
		{
			$user = $userId;
		}
		elseif (is_numeric($userId) && $userId > 0)
		{
			$user = Factory::getUser($userId);
		}
		else
		{
			$user = Factory::getUser();
		}
		if ($user->authorise($to.'.edit', 'com_[[[component]]].'.$to.'.' . (int)  $recordId))
		{
			return true;
		}
		return false;
	}

	/**
	* get the list of target (id => name)
	**/
	public static function getList($target)
	{
		switch($target)
		{
			case 'catid':
				// set related values
				return self::getCategoryList();
			break;
			case 'type':
				// set related values
				return self::getTypeList();
			break;
			case 'tag':
				// set related values
				return self::getTagList();
			break;		
		}
		return false;
	}

	/**
	* get the list of categories (id => title)
	**/
	protected static function getCategoryList()
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);

		$query
			->select($db->quoteName(array('id', 'title')))
			->from($db->quoteName('#__categories'))
			->where($db->quoteName('published') . ' >= 1')
			->where($db->quoteName('extension') . ' = ' . $db->quote('com_[[[component]]].document'))
			->order($db->quoteName('title') . ' asc');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadAssocList('id', 'title');
		}
		return false;
	}

	/**
	* get the list of types (id => title)
	**/
	protected static function getTagList()
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);

		$query
			->select($db->quoteName(array('a.id', 'a.title')))
			->from($db->quoteName('#__tags', 'a'))
			->where($db->quoteName('a.published') . ' >= 1')
			->join('LEFT', $db->quoteName('#__contentitem_tag_map', 't') . ' ON (' . $db->quoteName('a.id') . ' = ' . $db->quoteName('t.tag_id') . ')')
			->where($db->quoteName('a.published') . ' >= 1')
			->where($db->quoteName('t.type_alias') . ' = ' . $db->quote('com_[[[component]]].document'))
			->order($db->quoteName('a.title') . ' asc');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadAssocList('id', 'title');
		}
		return false;
	}

	/**
	* get the list of types (id => name)
	**/
	protected static function getTypeList()
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);

		$query
			->select($db->quoteName(array('id', 'name')))
			->from($db->quoteName('#__[[[component]]]_type'))
			->where($db->quoteName('published') . ' >= 1')
			->order($db->quoteName('name') . ' asc');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return $db->loadAssocList('id', 'name');
		}
		return false;
	}

	/**
	* get the document IDs of the targets
	**/
	public static function getDocumentFilterIds($target, $targets)
	{
		// What ever...
		if ($target === 'type')
		{
			return self::getTypeDocumentIDs($targets);
		}
		elseif ($target === 'tag')
		{
			return self::getTagDocumentIDs($targets);
		}
		elseif ($target === 'catid')
		{
			return self::getCategoryDocumentIDs($targets);
		}
		return false;
	}

	/**
	* get the list document ids of these types
	**/
	protected static function getTypeDocumentIDs($ids)
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);

		$query
			->select($db->quoteName(array('id', 'type')))
			->from($db->quoteName('#__[[[component]]]_document'))
			->where($db->quoteName('type') . ' != ' . $db->quote(''));
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$results = $db->loadAssocList();
			$matches = array();
			foreach ($results as $k => $v)
			{
				$values = json_decode($v['type'], true);
				if (array_intersect($ids, $values))
				{
					$matches[$v['id']] = $v['id'];
				}
			}
			// Checks that we found matches
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($matches))
			{
				return array_values($matches);
			}
		}
		return false;
	}

	/**
	* get the list document ids of these tags
	**/
	protected static function getTagDocumentIDs($ids)
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);

		$query
			->select('content_item_id')
			->from($db->quoteName('#__contentitem_tag_map'))
			->where($db->quoteName('tag_id') . ' IN (' . implode(',', $ids) . ')');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			return array_unique($db->loadColumn());
		}
		return false;
	}

	/**
	* get the list document ids of these categories
	**/
	protected static function getCategoryDocumentIDs($ids)
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);

		$query
			->select($db->quoteName(array('id', 'catid')))
			->from($db->quoteName('#__[[[component]]]_document'))
			->where($db->quoteName('catid') . ' != ' . $db->quote(''));
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$results = $db->loadAssocList();
			$matches = array();
			foreach ($results as $k => $v)
			{
				$value = json_decode($v['catid'], true);
				if (array_intersect($ids, $value))
				{
					$matches[$v['id']] = $v['id'];
				}
			}
			// Checks that we found matches
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($matches))
			{
				return array_values($matches);
			}
		}
		return false;
	}
[CUSTOMCODE=theButler]
[CUSTOMCODE=imageHelpers]
[CUSTOMCODE=getFolderPath]
[CUSTOMCODE=getFilePath]
[CUSTOMCODE=getImageLink]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getLinkOptions]
[CUSTOMCODE=mimeType]', 'CS8qKg0KCSogCXNldCB0aGUgc2Vzc2lvbiBkZWZhdWx0cyBpZiBub3Qgc2V0DQoJKiovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBjb3VudExvY2FsRG93bmxvYWQoJiRuYW1lLCAmJGlucHV0KQ0KCXsNCgkJLy8gZ2V0IHRoZSBpZA0KCQlpZiAoJGlkID0gJGlucHV0LT5nZXQoJ2NvdW50ZXInLCBOVUxMLCAnSU5UJykpDQoJCXsNCgkJCS8vIHNldCB0aGUgZGF0ZSBvYmplY3QNCgkJCSRkYXRlID0gRmFjdG9yeTo6Z2V0RGF0ZSgpOw0KCQkJLy8gZmlyc3QgY2hlY2sgaWYgdGhpcyBmaWxlIGFscmVhZHkgaGFzIHN0YXRpc3RpY3MNCgkJCSRkYiA9IEZhY3Rvcnk6OmdldERibygpOw0KCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCgkJCSRxdWVyeS0+c2VsZWN0KCRkYi0+cXVvdGVOYW1lKGFycmF5KCdpZCcsJ2NvdW50ZXInKSkpOw0KCQkJJHF1ZXJ5LT5mcm9tKCRkYi0+cXVvdGVOYW1lKCcjX19bW1tjb21wb25lbnRdXV1fc3RhdGlzdGljJykpOw0KCQkJJHF1ZXJ5LT53aGVyZSgkZGItPnF1b3RlTmFtZSgnZG9jdW1lbnQnKSAuICcgPSAnLiAoaW50KSAkaWQpOw0KCQkJJHF1ZXJ5LT53aGVyZSgkZGItPnF1b3RlTmFtZSgnZmlsZW5hbWUnKSAuICcgPSAnLiAkZGItPnF1b3RlKCRuYW1lKSk7DQoJCQkkZGItPnNldFF1ZXJ5KCRxdWVyeSk7DQoJCQkkZGItPmV4ZWN1dGUoKTsNCgkJCWlmICgkZGItPmdldE51bVJvd3MoKSkNCgkJCXsNCgkJCQkkc3RhdGlzdGljID0gJGRiLT5sb2FkT2JqZWN0KCk7DQoJCQkJLy8gYWxyZWFkeSBoYXMgYW4gZW50cnkNCgkJCQkkc3RhdGlzdGljLT5jb3VudGVyKys7DQoJCQkJJHN0YXRpc3RpYy0+bW9kaWZpZWQgPSAkZGF0ZS0+dG9TcWwoKTsNCgkJCQkvLyB1cGRhdGUgdGhlIGVudHJ5DQoJCQkJcmV0dXJuICRkYi0+dXBkYXRlT2JqZWN0KCcjX19bW1tjb21wb25lbnRdXV1fc3RhdGlzdGljJywgJHN0YXRpc3RpYywgJ2lkJyk7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJLy8gc2V0IGEgbmV3IGVudHJ5DQoJCQkJJGNvdW50ZXIgPSBuZXcgXHN0ZENsYXNzKCk7DQoJCQkJJGNvdW50ZXItPmZpbGVuYW1lID0gKHN0cmluZykgJG5hbWU7DQoJCQkJJGNvdW50ZXItPmRvY3VtZW50ID0gKGludCkgJGlkOw0KCQkJCSRjb3VudGVyLT5jb3VudGVyID0gMTsNCgkJCQkkY291bnRlci0+cHVibGlzaGVkID0gMTsNCgkJCQkkY291bnRlci0+Y3JlYXRlZCA9ICRkYXRlLT50b1NxbCgpOw0KCQkJCSRjb3VudGVyLT5hY2Nlc3MgPSAxOw0KCQkJCSRjb3VudGVyLT52ZXJzaW9uID0gMTsNCgkJCQkvLyBzZXQgYSBuZXcgZW50cnkNCgkJCQkkZG9uZSA9ICRkYi0+aW5zZXJ0T2JqZWN0KCcjX19bW1tjb21wb25lbnRdXV1fc3RhdGlzdGljJywgJGNvdW50ZXIpOw0KCQkJCS8vIGlmIGRvbmUgcmV0dXJuIGxhc3QgdXNlZCBpZA0KCQkJCWlmICgkZG9uZSkNCgkJCQl7DQoJCQkJCSRuZXdJZCA9ICAkZGItPmluc2VydGlkKCk7DQoJCQkJCS8vIG1ha2Ugc3VyZSB0aGUgYWNjZXNzIG9mIGFzc2V0IGlzIHNldA0KCQkJCQlyZXR1cm4gc2VsZjo6c2V0QXNzZXQoJG5ld0lkLCdzdGF0aXN0aWMnKTsNCgkJCQl9DQoJCQl9DQoJCX0NCgl9', '', '', '', '', 'Ly8gbG9hZCB0aGUgaGVscGVyIGNsYXNzDQpKTG9hZGVyOjpyZWdpc3RlcignW1tbQ29tcG9uZW50XV1dSGVscGVyJywgSlBBVEhfQURNSU5JU1RSQVRPUiAuICcvY29tcG9uZW50cy9jb21fW1tbY29tcG9uZW50XV1dL2hlbHBlcnMvW1tbY29tcG9uZW50XV1dLnBocCcpOw0KLy8gY2hlY2sgdGhlIHZlcnNpb24gb2YgSkNCDQokbWFuaWZlc3QgPSBbW1tDb21wb25lbnRdXV1IZWxwZXI6Om1hbmlmZXN0KCk7DQppZiAoaXNzZXQoJG1hbmlmZXN0LT52ZXJzaW9uKSAmJiBzdHJwb3MoJG1hbmlmZXN0LT52ZXJzaW9uLCAnLicpICE9PSBmYWxzZSkNCnsNCgkvLyBnZXQgdGhlIHZlcnNpb24NCgkkdGhpcy0+SkNCdmVyc2lvbiA9IGV4cGxvZGUoJy4nLCAkbWFuaWZlc3QtPnZlcnNpb24pOw0KCS8vIEdldCBhIGRiIGNvbm5lY3Rpb24uDQoJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJLy8gdGFyZ2V0IHZlcnNpb24gbGVzcyB0aGVuIG9yIGVxdWFsIHRvIDEuMC4xMA0KCWlmIChjb3VudCgkdGhpcy0+SkNCdmVyc2lvbikgPT0gMyAmJiAkdGhpcy0+SkNCdmVyc2lvblswXSA8PSAxICYmICR0aGlzLT5KQ0J2ZXJzaW9uWzFdID09IDAgJiYgJHRoaXMtPkpDQnZlcnNpb25bMl0gPD0gMTApDQoJew0KCQkvLyB3ZSBuZWVkIHRvIG1ha2UgYSBkYXRhYmFzZSBjb3JyZWN0aW9uIGZvciB0aGUgZmllbGQgY2F0ZWdvcmllcyBhbmQgdGhlIGZpZWxkdHlwZSBjYXRlZ29yaWVzDQoJCSRmaXhfY2F0ZWdvcmllcyA9IGFycmF5KA0KCQkJJ2NvbV9kb2N1bWVudG1hbmFuZ2VyLmRvY3VtZW50cycgPT4gJ2NvbV9kb2N1bWVudG1hbmFuZ2VyLmRvY3VtZW50Jw0KCQkpOw0KCQkvLyB0YXJnZXRlZCB0YWJsZXMgKHRvIGZpeCBhbGwgcGxhY2VzIGNhdGVnb3JpZXMgYXJlIG1hcHBlZCBpbnRvIEpvb21sYSkNCgkJJGZpeF90YWJsZXMgPSBhcnJheSgNCgkJCSdjb250ZW50X3R5cGVzJyA9PiBhcnJheSgNCgkJCQknaWQnID0+ICd0eXBlX2lkJywNCgkJCQkna2V5JyA9PiAndHlwZV9hbGlhcycsDQoJCQkJJ3N1ZmZpeCcgPT4gJy5jYXRlZ29yeScpLA0KCQkJJ2NvbnRlbnRpdGVtX3RhZ19tYXAnID0+IGFycmF5KA0KCQkJCSdpZCcgPT4gJ3R5cGVfaWQnLA0KCQkJCSdrZXknID0+ICd0eXBlX2FsaWFzJywNCgkJCQknc3VmZml4JyA9PiAnLmNhdGVnb3J5JyksDQoJCQkndWNtX2NvbnRlbnQnID0+IGFycmF5KA0KCQkJCSdpZCcgPT4gJ2NvcmVfY29udGVudF9pZCcsDQoJCQkJJ2tleScgPT4gJ2NvcmVfdHlwZV9hbGlhcycsDQoJCQkJJ3N1ZmZpeCcgPT4gJy5jYXRlZ29yeScpLA0KCQkJJ2NhdGVnb3JpZXMnID0+IGFycmF5KA0KCQkJCSdpZCcgPT4gJ2lkJywNCgkJCQkna2V5JyA9PiAnZXh0ZW5zaW9uJywNCgkJCQknc3VmZml4JyA9PiAnJykNCgkJKTsNCg0KCQkvLyB0aGUgc2NyaXB0IHRoYXQgZG9lcyB0aGUgd29yaw0KCQlmb3JlYWNoICgkZml4X2NhdGVnb3JpZXMgYXMgJGZpeCA9PiAkY2F0ZWdvcnkpDQoJCXsNCgkJCS8vIGxvb3Agb3ZlciB0aGUgdGFyZ2V0ZWQgdGFibGVzDQoJCQlmb3JlYWNoICgkZml4X3RhYmxlcyBhcyAkX3RhYmxlID0+ICRfdXBkYXRlKQ0KCQkJew0KCQkJCS8vIENyZWF0ZSBhIG5ldyBxdWVyeSBvYmplY3QuDQoJCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCgkJCQkvLyBnZXQgYWxsIHR5cGVfaWRzDQoJCQkJJHF1ZXJ5LT5zZWxlY3QoJGRiLT5xdW90ZU5hbWUoJF91cGRhdGVbJ2lkJ10pKTsNCgkJCQkkcXVlcnktPmZyb20oJGRiLT5xdW90ZU5hbWUoJyNfXycgLiAkX3RhYmxlKSk7DQoJCQkJJHF1ZXJ5LT53aGVyZSggJGRiLT5xdW90ZU5hbWUoJF91cGRhdGVbJ2tleSddKSAuICcgPSAnIC4gJGRiLT5xdW90ZSgkZml4IC4gJF91cGRhdGVbJ3N1ZmZpeCddKSk7DQoJCQkJLy8gUmVzZXQgdGhlIHF1ZXJ5IHVzaW5nIG91ciBuZXdseSBwb3B1bGF0ZWQgcXVlcnkgb2JqZWN0Lg0KCQkJCSRkYi0+c2V0UXVlcnkoJHF1ZXJ5KTsNCgkJCQkkZGItPmV4ZWN1dGUoKTsNCgkJCQlpZiAoJGRiLT5nZXROdW1Sb3dzKCkpDQoJCQkJew0KCQkJCQkvLyBhbGwgdGhlc2UgbXVzdCBiZSB1cGRhdGVkDQoJCQkJCSRpZHMgPSAkZGItPmxvYWRDb2x1bW4oKTsNCgkJCQkJLy8gRmllbGRzIHRvIHVwZGF0ZS4NCgkJCQkJJGZpZWxkcyA9IGFycmF5KA0KCQkJCQkJJGRiLT5xdW90ZU5hbWUoJF91cGRhdGVbJ2tleSddKSAuICcgPSAnIC4gJGRiLT5xdW90ZSgkY2F0ZWdvcnkgLiAkX3VwZGF0ZVsnc3VmZml4J10pDQoJCQkJCSk7DQoJCQkJCS8vIENvbmRpdGlvbnMgZm9yIHdoaWNoIHJlY29yZHMgc2hvdWxkIGJlIHVwZGF0ZWQuDQoJCQkJCSRjb25kaXRpb25zID0gYXJyYXkoDQoJCQkJCQkkZGItPnF1b3RlTmFtZSgkX3VwZGF0ZVsnaWQnXSkgLiAnIElOICgnIC4gaW1wbG9kZSgnLCAnLCAkaWRzKSAuICcpJw0KCQkJCQkpOw0KCQkJCQkkcXVlcnktPnVwZGF0ZSgkZGItPnF1b3RlTmFtZSgnI19fJyAuICRfdGFibGUpKS0+c2V0KCRmaWVsZHMpLT53aGVyZSgkY29uZGl0aW9ucyk7DQoJCQkJCSRkYi0+c2V0UXVlcnkoJHF1ZXJ5KTsNCgkJCQkJJHJlc3VsdCA9ICRkYi0+ZXhlY3V0ZSgpOw0KCQkJCQkvLyBvbiBzdWNjZXNzDQoJCQkJCWlmICgkcmVzdWx0KQ0KCQkJCQl7DQoJCQkJCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgiPHA+VXBkYXRlZCA8Yj4jX18kX3RhYmxlIC0gIiAuICRfdXBkYXRlWydrZXknXSAuICI8L2I+IGZyb20gPGI+JGZpeDwvYj4iIC4gJF91cGRhdGVbJ3N1ZmZpeCddIC4gIiB0byA8Yj4kY2F0ZWdvcnk8L2I+IiAuICRfdXBkYXRlWydzdWZmaXgnXSAuICIhPC9wPiIsICdOb3RpY2UnKTsNCgkJCQkJfQ0KDQoJCQkJfQ0KCQkJfQ0KCQl9DQoJfQ0KfQ==', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXSgvYWRtaW5pc3RyYXRvci9jb21wb25lbnRzL2NvbV8jIyNjb21wb25lbnQjIyMvYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMgQ29tcG9uZW50IE51bWJlcg0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCiMgSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyDQoNCkZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IEpDQiB2aXNpdCBbVkRNXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKSBUb2RheSEgVGhlIGZ1dHVyZSBpcyBoZXJlIQ==', '', '', 'Document Manager', '', '', 'Document Manager (public)', '.git', '', 1, 1, 'https://www.vdm.io/updates/documentmananger_server.xml', 'https://www.vdm.io/', '', 'aTztaqDOt1+Vw90EP+DXPDoPAdbiYmjtFnAiRryEkn4=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 97, '', 1, 11), -(31, 1, '', '', '', 1, '', '', '', 1, '', 1, 1, 1, '', '', '', '', '', '', 1, '', 1, '', '', '', '', 3, '', 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.2.1', 'Copyright (C) 2015. All Rights Reserved', '2017-06-01 22:25:40', 1, '', '', '', '', '', '', '', 1, '', 'Expert Database component adds the ability to your Joomla to manage various experts and their related details.', 'llewellyn@vdm.io', '', '', 'tVUYzE97vvcoI5JEiOwLKU3BzT5nGjkhmsAag9Qu0DsyHgSoWt2XzuB3SQ/sMh2Y', '', '4adef9ac-bbcc-40ac-8449-9e0baa27e73a', 'images/expertdatabase.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2017-08-25 00:36:38', 1, 'Expert Database', 'expertdatabase', '', 4, 'CQlzZWxmOjpsb2FkQ29uZmlybWF0aW9uQWpheCgkZG9jdW1lbnQpOw==', 'CS8qKg0KCSogCUxvYWQgdGhlIENvbmZpcm1hdGlvbiBBamF4IHRvIHBhZ2UNCgkqKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGxvYWRDb25maXJtYXRpb25BamF4KCRkb2N1bWVudCkNCgl7DQoJCS8vIGFkZCBhbiBldmVudCB0aGF0IHdpbGwgc2VuZCBvdXQgYWxsIGNvbmZpcm1hdGlvbiBlbWFpbHMsIG5vdCB5ZXQgc2VuZA0KCQkkZG9jdW1lbnQtPmFkZFNjcmlwdERlY2xhcmF0aW9uKCINCgkJCWpRdWVyeSh3aW5kb3cpLmxvYWQoZnVuY3Rpb24oKSB7DQoJCQkJc2VuZENvbmZpcm1hdGlvbkVtYWlscygxKTsNCgkJCX0pOw0KCQkJDQoJCQlmdW5jdGlvbiBzZW5kQ29uZmlybWF0aW9uRW1haWxzKHR5cGUpIHsNCgkJCQl2YXIgZ2V0VXJsID0gJyIuVXJpOjpyb290KCkuImFkbWluaXN0cmF0b3IvaW5kZXgucGhwP29wdGlvbj1jb21fW1tbY29tcG9uZW50XV1dJnRhc2s9YWpheC5zZW5kQ29uZmlybWF0aW9uRW1haWxzJmZvcm1hdD1qc29uJzsNCgkJCQlpZih0eXBlID4gMCl7DQoJCQkJCXZhciByZXF1ZXN0ID0gJ3Rva2VuPSIuSm9vbWxhX19fNWJhMzg1MTNfNWM0Zl80YjBkXzkzNWVfNDllOTg2YTZiY2U4X19fUG93ZXI6OmdldEZvcm1Ub2tlbigpLiImdHlwZT0nK3R5cGU7DQoJCQkJfQ0KCQkJCXJldHVybiBqUXVlcnkuYWpheCh7DQoJCQkJCXR5cGU6ICdQT1NUJywNCgkJCQkJdXJsOiBnZXRVcmwsDQoJCQkJCWRhdGFUeXBlOiAnanNvbnAnLA0KCQkJCQlkYXRhOiByZXF1ZXN0LA0KCQkJCQlqc29ucDogJ2NhbGxiYWNrJw0KCQkJCX0pOw0KCQkJfSIpOw0KCX0=', '	/**
	* 	The main send email
	**/
	protected static $replyEmail;

	/**
	* 	The component params
	**/
	public static $params;

	/**
	* 	The Main from name
	**/
	protected static $replyName;

	/**
	* 	Send the confirmation emails
	**/
	protected static function getTemplate($type, $default = null)
	{
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		$body = self::$params->get($type, $default);
		// return the template if found
		if ($body)
		{
			return $body;
		}
		return Text::sprintf('No template for <b>%s</b> were found', Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($type, 'w'));
	}

	/**
	* 	get place holders
	**/
	public static function getPlaceHolders($type)
	{
		if ('document' == $type)
		{
			return array_keys(self::getCompanyDetails('placeholder'));
		}
		elseif ('confirmation_email' == $type)
		{
			$f = '[';
			$b = ']';
			$placeholder = array();
			$placeholder[] = array('[document_header]');
			$placeholder[] = array_keys(self::getCompanyDetails('placeholder'));
			$placeholder[] = array_values(self::getSelection('expert', $f.'expert_', $b));
			$placeholder[] = array_values(self::getSelection('referral', $f.'referral_', $b));
			$placeholder[] = array('[confirmation_link]');
			$placeholder[] = array('[document_footer]');
			return  self::mergeArrays($placeholder);
		}
		elseif ('expert_profile' == $type)
		{
			$f = '[';
			$b = ']';
			$placeholder = array();
			$placeholder[] = array('[document_header]');
			$placeholder[] = array_keys(self::getCompanyDetails('placeholder'));
			$placeholder[] = array_values(self::getSelection('expert', $f.'expert_', $b));
			$placeholder[] = array('[is_organisation]', '[is_admin]');
			$placeholder[] = array('[document_footer]');
			return  self::mergeArrays($placeholder);
		}
		return false;
	}

	/**
	* 	Send a message
	**/
	public static function sendMessage($eposcode, $replyToName, $replyToEmail, $message)
	{
		$eposcode = [[[Component]]]Helper::base64_urldecode($eposcode);
		// Get a Crypt Key
		$basickey = [[[Component]]]Helper::getCryptKey('basic');
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
		$eposCode = rtrim($opener->decryptString($eposcode), "\0");
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($eposCode))
		{
			$target = json_decode($eposCode);
			if (isset($target->id) && $target->id > 0)
			{
				$expert = self::getExpertDetails($target->id, 'object', 'special');
				if (isset($expert->email) && isset($target->email) && $expert->email == $target->email)
				{
					// setup the subject
					$subject = Text::sprintf('A message from %s to %s', $replyToName, $expert->name);
					// setup the html
					$messageHtml = str_replace("\n", "<br />", $message);
					$html = Text::sprintf('%s<br /><br />%s<br />%s', $messageHtml, $replyToName, $replyToEmail);
					$text = Text::sprintf("%s\n\n%s\n%s", $message, $replyToName, $replyToEmail);
					// send the email
					if ([[[Component]]]Email::send($expert->email, $subject, self::emailBody($html, $subject), $text, 1, null, null, $replyToEmail,  $replyToName))
					{
						return array('message' =>  Text::sprintf('%s your message to %s was send successfully!', $replyToName, $expert->name), 'status' => 'success');
					}
				}
			}
		}
		return array('message' =>  Text::sprintf('%s there was an ERROR sending your message!', $replyToName), 'status' => 'danger');
	}

	/**
	* 	the confirmation emails to send
	**/
	protected static $confirmationEmails = array();

	/**
	* 	Send the confirmation emails
	**/
	public static function sendConfirmationEmails()
	{
		// first we get all the data and set the emails as send (to insure emails are not send more then once)
		if ($list = self::getConfirmationNeededList())
		{
			// get the company
			$company =  self::getCompanyDetails('placeholder');
			// get email template
			$template = self::getTemplate('confirmation_email');
			$subject_template = self::getTemplate('subject_confirmation_email', 'Hi [referral_name], please confirm the details of [expert_name]');
			// set some defaults
			$doc_header = self::getTemplate('doc_header');
			$doc_footer = self::getTemplate('doc_footer');
			$default[] = array('[document_header]' => self::setDynamicData($doc_header, $company), '[document_footer]' => self::setDynamicData($doc_footer, $company));
			// now lets get the company details
			$default[] = $company;
			$details = array();
			$details[0] = self::mergeArrays($default);
			// start building the emails
			foreach ($list as $reference)
			{
				// now lets get the expert details
				$details[1] = self::getExpertDetails($reference['[referral_expert_id]'], 'placeholder', 'full');
				$details[2] = $reference;
				// now more values
				$placeholders = self::mergeArrays($details);
				$body = self::setDynamicData($template, $placeholders);
				$subject = self::setDynamicData($subject_template, $placeholders);
				// set the email details
				self::$confirmationEmails[] = array('id' => $reference['[referral_id]'], 'email' => $reference['[referral_email]'], 'subject' => $subject, 'html' => $body);
				// lets send mail each time we have more then 10 set
				self::sendConfirmationEmail(10);
			}
			// send final emails if any remain
			self::sendConfirmationEmail();
			return true;
		}
		return false;
	}

	/**
	* Send the email needed for confirmation
	*
	* @param int  $qty the qty before emailing the list
	*
	* @return  boolean false on failure
	*
	**/	
	protected static function sendConfirmationEmail($qty = 1)
	{
		if (count(self::$confirmationEmails) >= $qty)
		{
			// send the emails
			foreach (self::$confirmationEmails as $details)
			{
				if (![[[Component]]]Email::send($details['email'], $details['subject'], self::emailBody($details['html'], $details['subject']), '', 1, null, null, self::$replyEmail,  self::$replyName))
				{
					$fields = array();
					$fields[] = $db->quoteName('emailsend') . ' = 0';  // set to error as not send
					self::$updater[]  = array('fields' => $fields, 'conditions' => array($db->quoteName('id') . ' = ' . $details['id']));
					// run update if many values found
					self::updateData(10);
				}
			}
			// run update on last remaining values
			self::updateData();
			// clear the values array
			self::$confirmationEmails = array();
			return true;
		}
		return false;
	}

	/**
	* 	Once the email was send the gives us the option the store the massage
	**/
	public static function storeMessage($sendmail, $recipient, $subject, $body, $textonly, $mode, $type)
	{
		return true;
	}

	/**
	* 	the updater array
	**/
	protected static $updater = array();

	/**
	* 	Get the list of un-emailed confirmations and lock them
	**/
	protected static function getConfirmationNeededList($method = 'placeholder')
	{
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		if ('placeholder' == $method)
		{
			$f = '[referral_';
			$b = ']';
		}
		// get the list of values we want from db
		$selection = self::getSelection('referral', $f, $b);
		$query->select($db->quoteName(array_keys($selection), array_values($selection)));
		// From the [[[component]]]_confirmation table.
		$query->from('#__[[[component]]]_confirmation AS a');
		// From the [[[component]]]_country table.
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'b') . ' ON (' . $db->quoteName('a.country') . ' = ' . $db->quoteName('b.id') . ')');
		$query->where('a.emailsend = 2');
		$query->where('a.confirmed = 0');
		$db->setQuery($query);
		$db->execute();
		if($db->getNumRows())
		{
			// Get the basic encryption.
			$basickey = self::getCryptKey('basic', 'erjg4359widcuje3asaif09tbv99howid0rgf038hfhodi8wfoed'); // we must have a key here
			// Get the encryption object.
			$basic = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
			// load the list of experts to confirm
			$list = $db->loadAssocList();
			foreach ($list as $nr => $reference)
			{
				$fields = array();
				$fields[] = $db->quoteName('emailsend') . ' = 1'; // lock down to look as send to keep multi emails from being send
				self::$updater[]  = array('fields' => $fields, 'conditions' => array($db->quoteName('id') . ' = ' . $reference[$f.'id'.$b]));
				// build the confirmation link
				$list[$nr]['[confirmation_link]'] = self::getConfirmationLink($reference, array($f, $b), $basic);
				// run update if many values found
				self::updateData(100);
			}
			// run update on last remaining values
			self::updateData();
			// return the found list
			return $list;
		}
		return false;
	}
[CUSTOMCODE=baseSixtyFourURL]
	/**
	 *	To load the application form
	 */
	public static function getApplicationForm($data = null, $type = 'expert', $access = 'public')
	{
		// get forms path
		$path	= JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/models/forms';
		// build full path to file
		$fullPath = $path.'/'.$type.'.xml';
		// check if file exists
		if (file_exists($fullPath))
		{
			// Get the form.
			jimport( 'joomla.form.form' );
			// set the paths
			JForm::addFormPath($path);
			JForm::addFieldPath(JPATH_ADMINISTRATOR . '/components/com_[[[component]]]/models/fields');
			// great we are done return results
			$form = JForm::getInstance('com_[[[component]]].'.$type, $type, array('control' => 'jform', 'load_data' => false), false, false);
			// change the form for public submission
			if ('public' == $access)
			{
				self::publicApplicationForm($form, $type);
			}
			// now load the data
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
			{
				$form->bind($data);
			}
			return $form;
		}
		return false;
	}

	protected static $applicationFields = 
		array(
			'expert' =>
				array(
					'removeFields' =>
						array('id','created','created_by','published','modified','modified_by','access','ordering','version','metakey','metadesc','user','asset_id','rules'),
					'removeGroups' =>
						array('metadata','accesscontrol')
				)
		);

	/**
	 *	Model the form for publi submission
	 */
	protected static function publicApplicationForm(&$form, $type)
	{
		if (isset(self::$applicationFields[$type]))
		{
			if (isset(self::$applicationFields[$type]['removeFields']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$applicationFields[$type]['removeFields']))
			{
				// first remove all unwanted fields
				foreach (self::$applicationFields[$type]['removeFields'] as $field)
				{
					$form->removeField($field);
				}
			}
			if (isset(self::$applicationFields[$type]['removeGroups']) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$applicationFields[$type]['removeGroups']))
			{
				// first remove all unwanted fields
				foreach (self::$applicationFields[$type]['removeGroups'] as $group)
				{
					$form->removeGroup($group);
				}
			}
		}
		// add the user fields
		self::addUserFields($form);
	}

	/**
	 *	Add user fields to application
	 */
	protected static function addUserFields(&$form)
	{
		// we must add some user fields
		$userFields =
			array(
				'name' =>
					array('name','username','email','password','password2', 'captcha'),
				'type' =>
					array('text','text','email','password','password','captcha'),
				'label' =>
					array(Text::_('Name'),Text::_('Username/Login-name'),Text::_('Email'),Text::_('Password'),Text::_('Confirm Password'),Text::_('ReCaptcha')),
				'description' =>
					array(Text::_('Your Full Name'),Text::_('Set the username/login-name of your choice.'),Text::_('Your Email Address'),Text::_('Use at least 6 characters, upper-case and lower-case letter, numbers and at least one special character.'),Text::_('Confirm Password'),Text::_('Just checking that your not a robot.')),
				'hint' =>
					array(Text::_('Expert Full Name'), Text::_('Username'), 'your@email.com',null,null,null),
				'class' =>
					array('text_area','text_area','text_area','text_area','text_area',null),
				'validate' =>
					array(null, null, 'email', null, null, 'captcha'),
				'filter' =>
					array('string', 'string', 'email', null, null,null),
				'field' =>
					array(null, null, null, 'password2', null, null)
			);
		$addReCaptcha = Factory::getConfig()->get('captcha');
		// now loop the fields and add to form
		foreach ($userFields['name'] as $nr => $name)
		{
			// build the field
			$xml = array();
			// only load ReCaptcha if turned on in system
			if ('captcha' != $name || $addReCaptcha)
			{
				$xml[] = '<field ';
				$xml[] = 'type="'.$userFields['type'][$nr].'" ';
				$xml[] = 'name="'.$name.'" ';
				if ($userFields['label'][$nr])
				{
					$xml[] = 'label="'.$userFields['label'][$nr].'" ';
				}
				if ($userFields['description'][$nr])
				{
					$xml[] = 'description="'.$userFields['description'][$nr].'" ';
				}
				if ($userFields['class'][$nr])
				{
					$xml[] = 'class="'.$userFields['class'][$nr].'" ';
				}
				if ('captcha' != $name)
				{
					$xml[] = 'required="true" ';
				}
				if ($userFields['filter'][$nr])
				{
					$xml[] = 'filter="'.$userFields['filter'][$nr].'" ';
				}
				if ($userFields['validate'][$nr])
				{
					$xml[] = 'validate="'.$userFields['validate'][$nr].'" ';
				}
				if ($userFields['field'][$nr])
				{
					$xml[] = 'field="'.$userFields['field'][$nr].'" ';
				}
				if ($userFields['hint'][$nr])
				{
					$xml[] = 'hint="'.$userFields['hint'][$nr].'" ';
				}
				$xml[] = '/>';
				// set the field
				$form->setField( simplexml_load_string(implode("\n", $xml)));
			}
		}
	}

	/**
	* This confirms experts
	*
	* @param string the base64 encrypted string
	*
	* @return  boolean false on failure
	*
	**/	
	public static function confirmExpert($action)
	{
		// error array if needed
		$errors = array();
		// Get the basic encryption.
		$basickey = self::getCryptKey('basic', 'erjg4359widcuje3asaif09tbv99howid0rgf038hfhodi8wfoed'); // we must have a key here
		// Get the encription object.
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
		// we try to open it
		if ($reference = json_decode(rtrim($opener->decryptString(self::base64_urldecode($action)), "\0")))
		{
			if (isset($reference->id))
			{
				// Get a db connection.
				$db = Factory::getDbo();
				// Create a new query object.
				$query = $db->getQuery(true);
				// get values in database
				$query->select($db->quoteName(array('expert', 'name', 'email', 'confirmed')));
				$query->from($db->quoteName('#__[[[component]]]_confirmation'));
				$query->where($db->quoteName('id') . ' = '. (int) $reference->id);
				// now get the data
				$db->setQuery($query);
				if ($db->execute())
				{
					$local = $db->loadObject();
					$verified = false;			
					// now check if the data is still the same
					if ($local->confirmed == 1)
					{
						$errors[] = Text::_('The details were already successfully verified.');
						$verified = true;
					}
					if ($local->expert != $reference->expert_id)
					{
						$errors[] = Text::_('The wrong expert was selected.');
					}
					if ($local->name != $reference->name)
					{
						$errors[] = Text::_('Your name no longer match the name we have on file.');
					}
					if ($local->email != $reference->email)
					{
						$errors[] = Text::_('Your email no longer match the email we have on file.');
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errors))
					{
						if (!$verified)
						{
							$errors[] = Text::_('These changes may have been made by the expert after the email was send to you.');
						}
						// set the error
						self::setError(1, $errors);
						return false;
					}
					else
					{
						// Create an object for the record we are going to update.
						$object = new \stdClass();
						// Must be a valid primary key value.
						$object->id = $reference->id;
						$object->confirmed = 1;

						// Update their details in the confirmation table using id as the primary key.
						if (Factory::getDbo()->updateObject('#__[[[component]]]_confirmation', $object, 'id'))
						{
							return true;
						}
						$errors[] = Text::_('There was an error during the verification proses.');
						// set the error
						self::setError(1, $errors);
						return false;
					}
				}
			}
		}
		$errors[] = Text::_('Your link is not valid.');
		// set the error
		self::setError(1, $errors);
		return false;
	}

	/**
	* Build the link used to confirm expert data
	*
	* @param array the referrals details
	*
	* @return  boolean false on failure
	*
	**/	
	protected static function getConfirmationLink($reference, $out, Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power $locker)
	{
		$bucket = array();
		foreach($reference as $key => $value)
		{
			$atKey = str_replace($out, '', $key);
			$bucket[$atKey] = $value;
		}
		return Uri::root().'index.php?option=com_[[[component]]]&task=confirm.expert&action='.self::base64_urlencode($locker->encryptString(json_encode($bucket)));
	}

	/**
	* Update the data from the file to the database
	*
	* @param int  $qty the qty before doing an update
	* @param array  $table The table being updated
	*
	* @return  boolean false on failure
	*
	**/	
	protected static function updateData($qty = 1, $table = 'confirmation')
	{
		if (count(self::$updater) >= $qty)
		{
			// load the data
			foreach(self::$updater as $value)
			{
				$db = Factory::getDbo();
				$query = $db->getQuery(true);
				// Prepare the update query.
				$query->update($db->quoteName('#__[[[component]]]_'.$table))
					->set($value['fields'])->where($value['conditions']);
				// Set the query using our newly populated query object and execute it.
				$db->setQuery($query);
				$db->execute();
			}
			// clear the values array
			self::$updater = array();
			return true;
		}
		return false;
	}

	protected static function emailBody(&$html, &$subject)
	{
		$body = array();
		$body[] = "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">";
		$body[] = "<html xmlns=\"http://www.w3.org/1999/xhtml\">";
		$body[] = "<head>";
		$body[] = "<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\" />";
		$body[] = "<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"/>";
		$body[] = "<title>".$subject."</title>";
		$body[] = "<style type=\"text/css\">";
		$body[] = "#outlook a {padding:0;}";
		$body[] = ".ExternalClass {width:100%;}";
		$body[] = ".ExternalClass, .ExternalClass p, .ExternalClass span, .ExternalClass font, .ExternalClass td, .ExternalClass div {line-height: 100%;} ";
		$body[] = "p {margin: 0; padding: 0; font-size: 0px; line-height: 0px;} ";
		$body[] = "table td {border-collapse: collapse;}";
		$body[] = "table {border-collapse: collapse; mso-table-lspace:0pt; mso-table-rspace:0pt; }";
		$body[] = "img {display: block; outline: none; text-decoration: none; -ms-interpolation-mode: bicubic;}";
		$body[] = "a img {border: none;}";
		$body[] = "a {text-decoration: none; color: #000001;}";
		$body[] = "a.phone {text-decoration: none; color: #000001 !important; pointer-events: auto; cursor: default;}";
		$body[] = "span {font-size: 13px; line-height: 17px; font-family: monospace; color: #000001;}";
		$body[] = "</style>";
		$body[] = "<!--[if gte mso 9]>";
		$body[] = "<style>";
		$body[] = "/* Target Outlook 2007 and 2010 */";
		$body[] = "</style>";
		$body[] = "<![endif]-->";
		$body[] = "</head>";
		$body[] = "<body style=\"width:100%; margin:0; padding:0; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%;\">";
		$body[] = "\n<!-- body wrapper -->";
		$body[] = "<table cellpadding=\"0\" cellspacing=\"0\" border=\"0\" style=\"margin:0; padding:0; width:100%; line-height: 100% !important;\">";
		$body[] = "<tr>";
		$body[] = "<td valign=\"top\">";
		$body[] = "<!-- edge wrapper -->";
		$body[] = "<table cellpadding=\"0\" cellspacing=\"0\" border=\"0\" align=\"center\" width=\"800\" >";
		$body[] = "<tr>";
		$body[] = "<td valign=\"top\">";
		$body[] = "<!-- content wrapper -->";
		$body[] = "<table cellpadding=\"0\" cellspacing=\"0\" border=\"0\" align=\"center\" width=\"780\">";
		$body[] = "<tr>";
		$body[] = "<td valign=\"top\" style=\"vertical-align: top;\">";
		$body[] = $html;
		$body[] = "</td>";
		$body[] = "</tr>";
		$body[] = "</table>";
		$body[] = "<!-- / content wrapper -->";
		$body[] = "</td>";
		$body[] = "</tr>";
		$body[] = "</table>";
		$body[] = "<!-- / edge wrapper -->";
		$body[] = "</td>";
		$body[] = "</tr>";
		$body[] = "</table>";
		$body[] = "<!-- / page wrapper -->";
		$body[] = "</body>";
		$body[] = "</html>";
		return implode("\n", $body);
	}

	public static function getExpertDisplay(&$id, $view = null, $type = null)
	{
		if ($id > 0)
		{
			// reset the details array
			$details = array();
			// get the company
			$company =  self::getCompanyDetails('placeholder');
			// get email template
			$template = self::getTemplate('expert_profile');
			// set document header and footer
			$doc_header = self::getTemplate('doc_header');
			$doc_footer = self::getTemplate('doc_footer');
			$details[] = array('[document_header]' => self::setDynamicData($doc_header, $company), '[document_footer]' => self::setDynamicData($doc_footer, $company));
			// now lets get the company details
			$details[] = $company;
			// get user access rights
			$userIs = self::userIs();
			$access = 'public';
			if ($userIs == 2 || $userIs == 3)
			{
				$access = 'special';
				if ($userIs == 2) 
				{
					$details[] = array('[is_organisation]' => 1);
				}
				elseif ($userIs == 3)
				{
					$details[] = array('[is_admin]' => 1);
				}
			}
			elseif ($userIs == 1)
			{
				if ('profile' == $view && 1948 == $type) // when expert views own profile (TODO more checks to insure it is true)
				{
					$access = 'full';
				}
				$details[] = array('[is_expert]' => 1);
			}
			// now lets get the expert details
			$details[] = self::getExpertDetails($id, 'placeholder', $access);
			// now mere values
			$placeholders = self::mergeArrays($details);
			if ($body = self::setDynamicData($template, $placeholders))
			{
				return $body;
			}			
		}
		return false;
	}

	protected static $expertDetails = array();
	
	public static function getExpertDetails(&$id, $method = 'object', $access = 'public')
	{
		// we need to manage some memory here
		if (count(self::$expertDetails) >= 200)
		{
			// remove first 100 from memory
			foreach (self::$expertDetails as $remove => $now)
			{
				// remove the first values that was set
				unset(self::$expertDetails[$remove]);
				if (count(self::$expertDetails) <= 100)
				{
					break;
				}
			}
		}
		if (!isset(self::$expertDetails[$id.$method.$access]))
		{
			// get expert details
			self::$expertDetails[$id.$method.$access] = self::getExpert($id, $method, $access);
		}
		if (!isset(self::$expertDetails[$id.$method.$access]))
		{
			self::$expertDetails[$id.$method.$access] = false;
		}
		return self::$expertDetails[$id.$method.$access];
	}

	protected static $expert = array();

	/**
	* Get the 
	* 
	* @return    html string
	*/
	protected static function getExpert(&$id, $method = 'object', $access = 'public')
	{
		// we need to manage some memory here
		if (count(self::$expert) >= 100)
		{
			// remove first 50 from memory
			foreach (self::$expert as $remove => $now)
			{
				// remove the first values that was set
				unset(self::$expert[$remove]);
				if (count(self::$expert) <= 50)
				{
					break;
				}
			}
		}
		$f = '';
		$b = '';
		if ('placeholder' == $method)
		{
			$f = '[expert_';
			$b = ']';
		}
		if (!isset(self::$expert[$id.$method.$access]))
		{
			$db = Factory::getDbo();
			$query = $db->getQuery(true);

			// Select some fields
			$selection = self::getSelection('expert', $f, $b);
			$query->select($db->quoteName(array_keys($selection), array_values($selection)));

			// From the [[[component]]]_expert table
			$query->from($db->quoteName('#__[[[component]]]_expert', 'a'));

			// From the users table.
			$query->join('LEFT', $db->quoteName('#__users', 'g') . ' ON (' . $db->quoteName('a.user') . ' = ' . $db->quoteName('g.id') . ')');
			// From the [[[component]]]_country table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'h') . ' ON (' . $db->quoteName('a.countryresidence') . ' = ' . $db->quoteName('h.id') . ')');
			// From the [[[component]]]_area_of_expertise table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_area_of_expertise', 'i') . ' ON (' . $db->quoteName('a.area_of_expertise') . ' = ' . $db->quoteName('i.id') . ')');
			// From the [[[component]]]_country table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_country', 'j') . ' ON (' . $db->quoteName('a.nationality') . ' = ' . $db->quoteName('j.id') . ')');
			// From the [[[component]]]_academic_qualification table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_academic_qualification', 'k') . ' ON (' . $db->quoteName('a.academic_qualification') . ' = ' . $db->quoteName('k.id') . ')');
			// From the [[[component]]]_prefix table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_prefix', 'p') . ' ON (' . $db->quoteName('a.prefix') . ' = ' . $db->quoteName('p.id') . ')');
			// From the [[[component]]]_title table.
			$query->join('LEFT', $db->quoteName('#__[[[component]]]_title', 't') . ' ON (' . $db->quoteName('a.title') . ' = ' . $db->quoteName('t.id') . ')');

			$query->where('a.id = '.(int) $id);
			// only load confirmed profiles to these groups
			if ('public' == $access || 'special' == $access)
			{
				// From the [[[component]]]_confirmation table.
				$query->join('LEFT', $db->quoteName('#__[[[component]]]_confirmation', 'c') . ' ON (' . $db->quoteName('a.id') . ' = ' . $db->quoteName('c.expert') . ')');
				$query->where('c.confirmed = 1');
			}
			// make sure they have access to this profile and it is published
			if ('public' == $access)
			{
				$user	= Factory::getUser();
				$levels	= $user->getAuthorisedViewLevels();
				$query->where('a.published = 1');
				$query->where('a.access IN (' . implode(',', $levels) . ')');
			}

			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				if ('object' == $method)
				{
					self::$expert[$id.$method.$access] = self::modelExpert($db->loadObject(), $method, $access, $f, $b);
				}
				else
				{
					self::$expert[$id.$method.$access] = self::modelExpert($db->loadAssoc(), $method, $access, $f, $b);
				}
			}
		}
		// return the values
		if (!isset(self::$expert[$id.$method.$access]))
		{
			self::$expert[$id.$method.$access] = false;
		}
		return self::$expert[$id.$method.$access];
	}

	/**
	* Return array of selections
	* 
	* @return    array if type match
	*/
	protected static function getSelection($type, $f, $b)
	{
		if ('expert' == $type)
		{
			return array(
				'g.name' => $f.'name'.$b,	
				'g.email' => $f.'email'.$b,
				'h.name' => $f.'countryresidence'.$b,
				'i.name' => $f.'area_of_expertise'.$b,
				'a.city' => $f.'city'.$b,
				'a.phone' => $f.'phone'.$b,
				'a.summary' => $f.'summary'.$b,
				'a.address' => $f.'address'.$b,
				'a.cvkey' => $f.'cvlink'.$b,
				'p.name' => $f.'prefix'.$b,
				'a.membership' => $f.'membership'.$b,
				't.name' => $f.'title'.$b,
				'a.profession' => $f.'profession'.$b,
				'a.experience' => $f.'experience'.$b,
				'a.mobile_phone' => $f.'mobile_phone'.$b,
				'j.name' => $f.'nationality'.$b,
				'a.organisation' => $f.'organisation'.$b,
				'k.name' => $f.'academic_qualification'.$b,
				'a.specialisation' => $f.'specialisation'.$b,
				'a.worked_for' => $f.'worked_for'.$b,
				'a.website' => $f.'website'.$b,
				'a.geographic_focus' => $f.'geographic_focus'.$b,
				'a.professional_networks' => $f.'professional_networks'.$b,
				'a.privacy_academic_qualification' => $f.'privacy_academic_qualification'.$b,
				'a.privacy_address' => $f.'privacy_address'.$b,
				'a.privacy_city' => $f.'privacy_city'.$b,
				'a.privacy_countryresidence' => $f.'privacy_countryresidence'.$b,
				'a.privacy_cv' => $f.'privacy_cvlink'.$b,
				'a.privacy_membership' => $f.'privacy_membership'.$b,
				'a.privacy_mobile_phone' => $f.'privacy_mobile_phone'.$b,
				'a.privacy_nationality' => $f.'privacy_nationality'.$b,
				'a.privacy_organisation' => $f.'privacy_organisation'.$b,
				'a.privacy_phone' => $f.'privacy_phone'.$b,
				'a.privacy_profession' => $f.'privacy_profession'.$b,
				'a.privacy_professional_networks' => $f.'privacy_professional_networks'.$b,
				'a.privacy_worked_for' => $f.'privacy_worked_for'.$b
			);
		}
		if ('referral' == $type)
		{
			return array(
				'a.id' => $f.'id'.$b,
				'a.expert' => $f.'expert_id'.$b,
				'a.name' => $f.'name'.$b,
				'a.organisation' => $f.'organisation'.$b,
				'a.position' => $f.'position'.$b,
				'b.name' => $f.'country'.$b,
				'a.email' => $f.'email'.$b
			);
		}
		return false;
	}

	/**
	* The modelling of Expert data
	* 
	* @return    object of allowed values
	*/
	protected static function modelExpert($item, &$method, &$access, &$f, &$b)
	{
		// filer all privacy info that they user does not want public
		if ('public' == $access)
		{
			foreach ($item as $key => $value)
			{
				if (strpos($key, $f.'privacy_') !== false)
				{
					if ($value == 0)
					{
						// remove from data it is not public
						$valueKey = str_replace('privacy_', '', $key);
						if ('object' == $method)
						{
							unset($item->$valueKey);
						}
						else
						{
							unset($item[$valueKey]);
						}
						// also remove the privacy values
						if ('object' == $method)
						{
							unset($item->$key);
						}
						else
						{
							unset($item[$key]);
						}
					}
				}	
			}
		}
		// Get the basic encription.
		$basickey = self::getCryptKey('basic');
		// Get the encription object.
		$basic = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($basickey, 128);
		// not found, remove
		$removeLink = true;
		// start implementation to build CV link
		if ($basickey && 'object' == $method && isset($item->{$f.'cvlink'.$b}))
		{
			if (!empty($item->{$f.'cvlink'.$b}) && !is_numeric($item->{$f.'cvlink'.$b}) && $item->{$f.'cvlink'.$b} === base64_encode(base64_decode($item->{$f.'cvlink'.$b}, true)))
			{
				$key = rtrim($basic->decryptString($item->{$f.'cvlink'.$b}), "\0");
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($key) && !is_numeric($key))
				{
					$keyArray = explode('.', $key);
					$item->{$f.'cvlink'.$b} = Uri::root().'index.php?option=com_[[[component]]]&task=download.pdf&token='.Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken().'&file=' . $keyArray[0] . '.pdf';
					$removeLink = false;
				}
			}
		}
		elseif ($basickey && isset($item[$f.'cvlink'.$b]))
		{
			if (!empty($item[$f.'cvlink'.$b]) && !is_numeric($item[$f.'cvlink'.$b]) && $item[$f.'cvlink'.$b] === base64_encode(base64_decode($item[$f.'cvlink'.$b], true)))
			{
				$key = rtrim($basic->decryptString($item[$f.'cvlink'.$b]), "\0");
				if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($key) && !is_numeric($key))
				{
					$keyArray = explode('.', $key);
					$item[$f.'cvlink'.$b] = Uri::root().'index.php?option=com_[[[component]]]&task=download.pdf&token='.Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken().'&file=' . $keyArray[0] . '.pdf';
					$removeLink = false;
				}
			}
		}
		if ($removeLink)
		{
			if (isset($item->{$f.'cvlink'.$b}))
			{
				unset($item->{$f.'cvlink'.$b});
			}
			elseif (isset($item[$f.'cvlink'.$b]))
			{
				unset($item[$f.'cvlink'.$b]);
			}
		}
		// build the name
		if ('object' == $method && isset($item->{$f.'name'.$b}))
		{
			$title = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->{$f.'title'.$b})) ? $item->{$f.'title'.$b}.'. ' : ((Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item->{$f.'prefix'.$b})) ? $item->{$f.'prefix'.$b}.'. ': '');
			$item->{$f.'name'.$b} = $title.$item->{$f.'name'.$b};
			// also remove title and prefix
			unset($item->{$f.'prefix'.$b});
			unset($item->{$f.'title'.$b});
		}
		if ('placeholder' == $method && isset($item[$f.'name'.$b]))
		{
			$title = (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item[$f.'title'.$b])) ? $item[$f.'title'.$b].'. ' : ((Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($item[$f.'prefix'.$b])) ? $item[$f.'prefix'.$b].'. ': '');
			$item[$f.'name'.$b] = $title.$item[$f.'name'.$b];
			// also remove title and prefix
			unset($item[$f.'prefix'.$b]);
			unset($item[$f.'title'.$b]);
		}
		// build the experience
		if ('object' == $method && isset($item->{$f.'experience'.$b}))
		{
			$years = ($item->{$f.'experience'.$b} == 1) ? Text::_('Year'): Text::_('Years');
			$item->{$f.'experience'.$b} = $item->{$f.'experience'.$b}.' '.$years;
		}
		if ('placeholder' == $method && isset($item[$f.'experience'.$b]))
		{
			$years = ($item[$f.'experience'.$b] == 1) ? Text::_('Year'): Text::_('Years');
			$item[$f.'experience'.$b] = $item[$f.'experience'.$b].' '.$years;
		}
		// set specialisation and geographic_focus to string
		$tables = array('specialisation','geographic_focus');
		foreach ($tables as $table)
		{
			if ('object' == $method && isset($item->{$f.$table.$b}))
			{
				$stuff = json_decode($item->{$f.$table.$b},true);
				$line = array();
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($stuff))
				{
					$naam = '';
					foreach ($stuff as $val)
					{
						if ($naam = self::getVar($table, $val, 'id', 'name'))
						{
							$line[] = $naam;
						}
					}
				}
				if (isset($line) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($line))
				{
					$item->{$f.$table.$b} = implode(', ', $line);
				}
				else
				{
					unset($item->{$f.$table.$b});
				}
			}
			elseif (isset($item[$f.$table.$b]))
			{
				$stuff = json_decode($item[$f.$table.$b],true);
				$line = array();
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($stuff))
				{
					$naam = '';
					foreach ($stuff as $val)
					{
						if ($naam = self::getVar($table, $val, 'id', 'name'))
						{
							$line[] = $naam;
						}
					}
				}
				if (isset($line) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($line))
				{
					$item[$f.$table.$b] = implode(', ', $line);
				}
				else
				{
					unset($item[$f.$table.$b]);
				}
			}
		}
		// remove 0 and replace with empty string
		if ('placeholder' == $method)
		{
			foreach ($item as $key => &$value)
			{
				if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($value))
				{
					$value = '';
				}
			}
		}
		return $item;
	}

	protected static $companyDetails = array();
	
	public static function getCompanyDetails($method = 'array')
	{
		if (!isset(self::$companyDetails[$method]))
		{
			$f = '';
			$b = '';
			if ('placeholder' == $method)
			{
				$f = '[';
				$b = ']';
			}
			$appParams = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
			self::$companyDetails[$method] = array();
			self::$companyDetails[$method][$f.'company_name'.$b] = $appParams->get('companyname', '');
			self::$companyDetails[$method][$f.'company_logo'.$b] = '<img alt="'.self::$companyDetails[$method][$f.'company_name'.$b].'" src="'.Uri::root().$appParams->get('companylogo', '').'">';
			self::$companyDetails[$method][$f.'company_email'.$b] = $appParams->get('email', '');
			self::$companyDetails[$method][$f.'company_phone'.$b] = $appParams->get('phone', '');
			self::$companyDetails[$method][$f.'company_mobile'.$b] = $appParams->get('mobile_phone', '');
			self::$companyDetails[$method][$f.'company_street'.$b] = $appParams->get('street', '');
			self::$companyDetails[$method][$f.'company_postal'.$b] = $appParams->get('postal', '');
			self::$companyDetails[$method][$f.'company_postalcode'.$b] = $appParams->get('postalcode', '');
			self::$companyDetails[$method][$f.'company_city'.$b] = $appParams->get('city', '');
			self::$companyDetails[$method][$f.'company_website'.$b] = $appParams->get('website', '');
			self::$companyDetails[$method][$f.'company_region'.$b] = $appParams->get('region', '');
			// set the country
			$country = $appParams->get('country');
			if ($country && $country > 0)
			{
				self::$companyDetails[$method][$f.'company_country_name'.$b] = self::getVar('country', $country, 'id', 'name');
			}
			else
			{
				self::$companyDetails[$method][$f.'company_country_name'.$b] = '';
			}
			// if object is called for
			if ('object' == $method)
			{
				self::$companyDetails[$method] = (object) self::$companyDetails[$method];
			}
		}
		// return the values
		if (!isset(self::$companyDetails[$method]))
		{
			self::$companyDetails[$method] = false;
		}
		return self::$companyDetails[$method];
	}
[CUSTOMCODE=setDynamicDataIF]
 [CUSTOMCODE=userIsThree+adminuser,organisationuser,expertuser,organisation,expert]
	/**
	* 	The owner
	**/
	protected static $owner = array();

	public static function hasAccess($recordId, $userId = null, $to = 'expert')
	{
		if(!$userId)
		{
			$userId = Factory::getUser()->id;
		}
		$type = self::userIs($userId);
		if ($type && $recordId > 0)
		{
			switch($to)
			{
				case 'expert':
					return self::accessExpert($type, $recordId, $userId);
				break;
				case 'organisation':
					return self::accessOrganisation($type, $recordId, $userId);
				break;
			}
		}
		return false;
	}

	protected static function accessOrganisation($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 2: // check if organisation is the owner
				if (!isset(self::$owner['organisation'.$recordId]))
				{
					// load the owner
					self::$owner['organisation'.$recordId] = self::getVar('organisation', $recordId, 'id', 'user');
				}
				// only true if owner is the same as user
				if (self::$owner['organisation'.$recordId] == $userId)
				{
						return true;
				}
			break;
		}
		return false;
	}

	protected static function accessExpert($type, $recordId, $userId)
	{
		switch ($type)
		{
			case 3: // admin is allowed to edit
				return true;
			break;
			case 1: // check if expert is the owner
				if (!isset(self::$owner['expert'.$recordId]))
				{
					// load the owner
					self::$owner['expert'.$recordId] = self::getVar('expert', $recordId, 'id', 'user');
				}
				// only true if owner is the same as user
				if (self::$owner['expert'.$recordId] == $userId)
				{
						return true;
				}
			break;
		}
		return false;
	}

	/**
	* check confirmation
	*
	* @input	  int                       $id     The data id
	* @input	  array                   $data     The valid data
	*
	* @returns  boolean on success
	**/
	public static function checkConfirmation($id, &$data)
	{
		$updateData = array();
		// load the reference data if set
		if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($data['reference']))
		{
			$reference = json_decode($data['reference'],true);
		}
		// check if we already have a confirmation data set
		if ($confirmation = self::getConfirmation($id))
		{
			// there is any reference data set
			if (isset($reference) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($reference['email']))
			{
				// we may need to update the data if the email changed
				if (	$reference['email'][0] !== $confirmation['email'] ||
					$reference['organisation_ref'][0] !== $confirmation['organisation'] ||
					$reference['name'][0] !== $confirmation['name'] ||
					$reference['phone'][0] !== $confirmation['phone'] ||
					$reference["country"][0] !== $confirmation['country']  ||
					$reference["position"][0] !== $confirmation['position']
					)
				{
					if ((isset($confirmation['confirmed']) && $confirmation['confirmed'] == 1) || (!self::updateConfirmation($id, $reference, $data)))
					{
						// set the reference data back en load error
						$reference["organisation_ref"][0] = $confirmation['organisation'];
						$reference["name"][0] = $confirmation['name'];
						$reference["email"][0] = $confirmation['email'];
						$reference["phone"][0] = $confirmation['phone'];
						$reference["position"][0] = $confirmation['position'];
						$reference["country"][0] = $confirmation['country'];
						// update the reference data
						self::updateReferenceData($id, json_encode($reference));
						// set the warning notice since not referral was set
						if (isset($confirmation['confirmed']) && $confirmation['confirmed'] == 1)
						{
							$data['errors'][] = Text::_('You cannot delete or change this first reference person details after this person has verified your information, unless you contact support with the reasons for doing so.');
						}
						return false;
					}
				}
				return true;
			}
			// set the reference data back en load error
			$updateData["organisation_ref"][] = $confirmation['organisation'];
			$updateData["name"][] = $confirmation['name'];
			$updateData["email"][] = $confirmation['email'];
			$updateData["phone"][] = $confirmation['phone'];
			$updateData["position"][] = $confirmation['position'];
			$updateData["country"][] = $confirmation['country'];
			// update the reference data
			self::updateReferenceData($id, json_encode($updateData));
			$data['errors'][] = Text::_('You cannot delete or change this first reference person details after this person has verified your information, unless you contact support with the reasons for doing so.');
			return false;
		}
		// there is any reference data set
		if (isset($reference) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($reference['email']))
		{
			if (self::setConfirmation($id, $reference, $data))
			{
				return true;
			}
		}
		// set the warning notice since not referral was set
		$data['errors'][] = Text::_('Your account will not be activated. It is mandatory to add at least one reference person in order to verify the information you provided.');
		return false;
	}

	/**
	* update Reference Data
	*
	* @input	  int        $id     The expert id
	* @input	  string        $reference     The reference json
	*
	* @returns  bool on success
	**/
	public static function updateReferenceData($id, $value, $target = "reference")
	{		
		// Create an object for the record we are going to update.
		$object = new \stdClass();
 
		// Must be a valid primary key value.
		$object->id = $id;
		$object->$target = $value;
 
		// Update their details in the expert table using id as the primary key.
		return Factory::getDbo()->updateObject('#__[[[component]]]_expert', $object, 'id');
	}

	/**
	* get confirmation
	*
	* @input	  int        $id     The expert id
	*
	* @returns  object if found
	**/
	protected static function getConfirmation($id)
	{		
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select('a.*');
		$query->from('#__[[[component]]]_confirmation AS a');
		$query->where('a.expert = '. (int) $id);
		$db->setQuery($query);
		$db->execute();
		if($db->getNumRows())
		{
			return $db->loadAssoc();
		}
		return false;
	}

	/**
	* update confirmation
	**/
	protected static function updateConfirmation($id, $reference, &$data)
	{
		// make sure we have enough data and that it is correct
		$mail = Factory::getMailer();
		$update = true;
		if (!$mail->ValidateAddress($reference['email'][0]))
		{
			$data['errors'][] = $reference['email'][0] . ' ' . Text::_('is not a valid email address. <b>(References ERROR!)</b>');
			$update = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['name'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference name. <b>(References ERROR!)</b>');
			$update = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['organisation_ref'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference organisation name. <b>(References ERROR!)</b>');
			$update = false;
		}
		if (!isset($reference['country'][0]) || $reference['country'][0] <= 0)
		{
			$data['errors'][] = Text::_('You need to add reference country. <b>(References ERROR!)</b>');
			$update = false;
		}
		if ($update)
		{
			// Create an object for the record we are going to update.
			$object = new \stdClass();
			// Must be a valid primary key value.
			$object->expert = $id;
			$object->organisation = $reference['organisation_ref'][0];
			$object->name = $reference['name'][0];
			$object->email = $reference['email'][0];
			$object->phone = $reference['phone'][0];
			$object->position = $reference['position'][0];
			$object->country = (int) $reference['country'][0];
			$object->emailsend = 2;

			// Update their details in the expert table using expert as the primary key.
			return Factory::getDbo()->updateObject('#__[[[component]]]_confirmation', $object, 'expert');
		}
		return false;
	}

	/**
	* set confirmation
	**/
	protected static function setConfirmation($id, $reference, &$data)
	{
		// make sure we have enough data and that it is correct
		$mail = Factory::getMailer();
		$store = true;
		if (!$mail->ValidateAddress($reference['email'][0]))
		{
			$data['errors'][] = $reference['email'][0] . ' ' . Text::_('is not a valid email address. <b>(References ERROR!)</b>');
			$store = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['name'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference name. <b>(References ERROR!)</b>');
			$store = false;
		}
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($reference['organisation_ref'][0]))
		{
			$data['errors'][] = Text::_('You need to add reference organisation name. <b>(References ERROR!)</b>');
			$store = false;
		}
		if (!isset($reference['country'][0]) || $reference['country'][0] <= 0)
		{
			$data['errors'][] = Text::_('You need to add reference country. <b>(References ERROR!)</b>');
			$store = false;
		}
		if ($store)
		{
			// Create an object for the record we are going to update.
			$object = new \stdClass();
			// Must be a valid primary key value.
			$object->expert = $id;
			$object->organisation = $reference['organisation_ref'][0];
			$object->name = $reference['name'][0];
			$object->email = $reference['email'][0];
			$object->phone = $reference['phone'][0];
			$object->position = $reference['position'][0];
			$object->country = (int) $reference['country'][0];
			$object->emailsend = 2;

			// Update their details in the expert table using id as the primary key.
			return Factory::getDbo()->insertObject('#__[[[component]]]_confirmation', $object);
		}
		return false;
	}
[CUSTOMCODE=helperErrors]', 'CS8qKg0KCSogCUxvYWQgdGhlIENvbmZpcm1hdGlvbiBBamF4IHRvIHBhZ2UNCgkqKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGxvYWRDb25maXJtYXRpb25BamF4KCRkb2N1bWVudCkNCgl7DQoJCS8vIGFkZCBhbiBldmVudCB0aGF0IHdpbGwgc2VuZCBvdXQgYWxsIGNvbmZpcm1hdGlvbiBlbWFpbHMsIG5vdCB5ZXQgc2VuZA0KCQkkZG9jdW1lbnQtPmFkZFNjcmlwdERlY2xhcmF0aW9uKCINCgkJCWpRdWVyeSh3aW5kb3cpLmxvYWQoZnVuY3Rpb24oKSB7DQoJCQkJc2VuZENvbmZpcm1hdGlvbkVtYWlscygxKTsNCgkJCX0pOw0KCQkJDQoJCQlmdW5jdGlvbiBzZW5kQ29uZmlybWF0aW9uRW1haWxzKHR5cGUpIHsNCgkJCQl2YXIgZ2V0VXJsID0gJyIuVXJpOjpyb290KCkuImluZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ0YXNrPWFqYXguc2VuZENvbmZpcm1hdGlvbkVtYWlscyZmb3JtYXQ9anNvbic7DQoJCQkJaWYodHlwZSA+IDApew0KCQkJCQl2YXIgcmVxdWVzdCA9ICd0b2tlbj0iLkpvb21sYV9fXzViYTM4NTEzXzVjNGZfNGIwZF85MzVlXzQ5ZTk4NmE2YmNlOF9fX1Bvd2VyOjpnZXRGb3JtVG9rZW4oKS4iJnR5cGU9Jyt0eXBlOw0KCQkJCX0NCgkJCQlyZXR1cm4galF1ZXJ5LmFqYXgoew0KCQkJCQl0eXBlOiAnUE9TVCcsDQoJCQkJCXVybDogZ2V0VXJsLA0KCQkJCQlkYXRhVHlwZTogJ2pzb25wJywNCgkJCQkJZGF0YTogcmVxdWVzdCwNCgkJCQkJanNvbnA6ICdjYWxsYmFjaycNCgkJCQl9KTsNCgkJCX0iKTsNCgl9', '', '', '', '', '', 'CQlzZWxmOjpsb2FkQ29uZmlybWF0aW9uQWpheCgkZG9jdW1lbnQpOw==', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Expert Database', '', '', 'Expert Database (Manos)', '', '', '', 1, 'https://www.vdm.io/updates/expertdatabase_update_server.xml', 'http://www.vdm.io', '', 'zSYEoVlA9p1iyV/JrkCLRwmThI0jeYJfXizVtS48+Dbcg8C5CE8A/fZMNtJWaNvLoOrv2asyvQOQB2Vh7F/h4w==', 'https://www.vdm.io/access/', '', 2, 5, '', 1, 62), -(32, '', '', '', '', '', '', '', '', 1, '', '', '', 1, '', 1, '', '', '', '', 1, '', '', '', '', '', '', '', 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.3', 'Copyright (C) 2015. All Rights Reserved', '2017-06-16 19:13:20', '', '54Nlhb/V3NPJ/yahgAFbte09Jo8xyB7TWPRZKvhXaqM=', '40sDxN28jGZ9sFg9B24mgBQItFN9xm+qYBeE05PYVwk=', '', '41s1TWjLw/emmZi1+vw6yTm65rhbpIsVama2dtpEys0=', '', '', '', 1, '', 'The watcher that helps monitor dynamic IP changes.', 'info@vdm.io', '', '', 't17fhvVRF0sPjxpHhemffyAy+Tp52Wc0B9S1hsdKMnK5RLQoTPV1dsw5IEsofM5V', '', '9220910b-4c08-40b2-bdb2-57514a493910', 'images/vdm/DYNAMICIP500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2020-05-25 12:10:19', '', 'Dynamic IP', 'dynamicip', '', 4, '', '', '', 'W0NVU1RPTUNPREU9bmljZUZhbmN5RGF0ZV0NCltDVVNUT01DT0RFPWlzVmFsaWRJUF0NCg0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0VmFyXygmJGtleSwgJHRhYmxlLCAkd2hlcmUgPSBudWxsLCAkd2hlcmVTdHJpbmcgPSAndXNlcicsICR3aGF0ID0gJ2lkJywgJG9wZXJhdG9yID0gJz0nLCAkbWFpbiA9ICdbW1tjb21wb25lbnRdXV0nKQ0KCXsNCgkJLy8gR2V0IGEgZGIgY29ubmVjdGlvbi4NCgkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCS8vIENyZWF0ZSBhIG5ldyBxdWVyeSBvYmplY3QuDQoJCSRxdWVyeSA9ICRkYi0+Z2V0UXVlcnkodHJ1ZSk7DQoJCSRxdWVyeS0+c2VsZWN0KCRkYi0+cXVvdGVOYW1lKGFycmF5KCR3aGF0LCAkd2hlcmVTdHJpbmcpKSk7DQoJCWlmIChlbXB0eSgkdGFibGUpKQ0KCQl7DQoJCQkkcXVlcnktPmZyb20oJGRiLT5xdW90ZU5hbWUoJyNfXycuJG1haW4pKTsNCgkJfQ0KCQllbHNlDQoJCXsNCgkJCSRxdWVyeS0+ZnJvbSgkZGItPnF1b3RlTmFtZSgnI19fJy4kbWFpbi4nXycuJHRhYmxlKSk7DQoJCX0NCgkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkkZGItPmV4ZWN1dGUoKTsNCgkJaWYgKCRkYi0+Z2V0TnVtUm93cygpKQ0KCQl7DQoJCQkkc2VhcmNoID0gJGRiLT5sb2FkT2JqZWN0TGlzdCgpOw0KCQkJZm9yZWFjaCAoJHNlYXJjaCBhcyAkaXRlbSkNCgkJCXsNCgkJCQlpZiAoaXNzZXQoJGl0ZW0tPnskd2hlcmVTdHJpbmd9KSAmJiAhaXNfbnVtZXJpYygkaXRlbS0+eyR3aGVyZVN0cmluZ30pICYmICRpdGVtLT57JHdoZXJlU3RyaW5nfSA9PT0gYmFzZTY0X2VuY29kZShiYXNlNjRfZGVjb2RlKCRpdGVtLT57JHdoZXJlU3RyaW5nfSwgdHJ1ZSkpKQ0KCQkJCXsNCgkJCQkJLy8gYmFzaWMgZGVjcnlwdCBkYXRhIHZhbHVlLg0KCQkJCQkkaXRlbS0+eyR3aGVyZVN0cmluZ30gPSBydHJpbSgka2V5LT5kZWNyeXB0U3RyaW5nKCRpdGVtLT57JHdoZXJlU3RyaW5nfSksICJcMCIpOw0KCQkJCX0NCgkJCQkvLyBzZWUgaWYgaXQgaXMgdGhpcyBvbmUNCgkJCQlpZiAoaXNzZXQoJGl0ZW0tPnskd2hlcmVTdHJpbmd9KSAmJiBpc3NldCgkaXRlbS0+eyR3aGF0fSkgJiYgJGl0ZW0tPnskd2hlcmVTdHJpbmd9ID09PSAkd2hlcmUpDQoJCQkJew0KCQkJCQlyZXR1cm4gJGl0ZW0tPnskd2hhdH07DQoJCQkJfQ0KCQkJfQ0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9', '', 'CQkvLyBHZXQgQXBwbGljYXRpb24gb2JqZWN0DQoJCSRhcHAgPSBGYWN0b3J5OjpnZXRBcHBsaWNhdGlvbigpOw0KCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnRmlyc3Qgc2V0IHRoZSBjb21wb25lbnRzIGdsb2JhbCBzZXR0aW5ncyBhbmQgcGVybWlzc2lvbnMgaW4gdGhlIDxiPk9wdGlvbnM8L2I+IGFyZWEsIG9yIHRoZSBmcm9udC1lbmQgb2YgdGhlIGNvbXBvbmVudCB3aWxsIG5vdCB3b3JrIGFzIGV4cGVjdGVkLiA8YnIgLz5QbGVhc2Ugbm90ZSB0aGF0IGVhY2ggdmlldyBvbiB0aGUgZnJvbnQtZW5kIGhhcyBhY2Nlc3MgYW5kIHBlcm1pc3Npb25zLCBzbyBpZiB5b3Ugd291bGQgbGlrZSB0aGUgcHVibGljIHRvIGFjY2VzcyB0aG9zZSB2aWV3cyB0aGV5IG11c3QgYmUgZ2l2ZW4gdGhlIGFjY2VzcyBhbmQgcGVybWlzc2lvbi4nLCAnSW5mbycpOw==', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKQ==', '', '', 'Dynamic IP', '', '', 'Dynamic IP', '.git', '', 1, 1, 'https://www.vdm.io/updates/demo_update_server.xml', 'https://www.vdm.io/', '', 'qcgAgVbJW4swWf16dQYpJw73vqPuS+NB/B+ck6XsdqE=', '', '', 1, 34, '', 1, 13), -(33, '', '', '', '', '', '', '', '', 1, '', '', '', 1, '', 1, '', '', '', '', 1, '', '', '', '', '', '{}', '', '', 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '3.0.3', 'Copyright (C) 2015. All Rights Reserved', '2016-10-18 11:44:09', '', 'o8KXSRmDTHWcqZCIQBGBEIzUWKp3gloU4rAwbGXE+5Q=', 'Dcwzi8PkJn+0a6NOGjmtWUw3JIDQGN/wJI9PPKq1OTQ=', '', 'koqQzSNiTjmHtjFu+bZEoZ6m/gsmQGHSApLDOF9n958=', '', '', '', 1, '', 'Google Plus Profile Feed.', 'joomla@vdm.io', '', 'https://vdm.bz/jcb-google-plus-profiles', 'IC9msQX0nf9zeyJ8LnlRwuo9nq+9gPDN/7MNC9tLXQ/x41kDGVsIqVlLvDKN5nCjrXskwgVR5vrm3fpMYbZ0fA==', '', 'c4e35263-cf03-4e12-9045-ad416ab613ad', 'images/vdm/GooglePlus500.jpg', '', 'https://github.com/vdm-io/JCB-Packages/raw/master/JCB_googlePlusProfileFeed.zip', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:11:26', 2, 'Google Plus Profiles', 'googleplusprofile', '', 4, '', '', '', 'W0NVU1RPTUNPREU9bmljZUZhbmN5RGF0ZV0=', '', 'CQkvLyBHZXQgQXBwbGljYXRpb24gb2JqZWN0DQoJCSRhcHAgPSBGYWN0b3J5OjpnZXRBcHBsaWNhdGlvbigpOw0KCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnRmlyc3Qgc2V0IHRoZSBjb21wb25lbnRzIGdsb2JhbCBzZXR0aW5ncyBhbmQgcGVybWlzc2lvbnMgaW4gdGhlIDxiPk9wdGlvbnM8L2I+IGFyZWEsIG9yIHRoZSBmcm9udC1lbmQgb2YgdGhlIGNvbXBvbmVudCB3aWxsIG5vdCB3b3JrIGFzIGV4cGVjdGVkLiA8YnIgLz5QbGVhc2Ugbm90ZSB0aGF0IGVhY2ggdmlldyBvbiB0aGUgZnJvbnQtZW5kIGhhcyBhY2Nlc3MgYW5kIHBlcm1pc3Npb25zLCBzbyBpZiB5b3Ugd291bGQgbGlrZSB0aGUgcHVibGljIHRvIGFjY2VzcyB0aG9zZSB2aWV3cyB0aGV5IG11c3QgYmUgZ2l2ZW4gdGhlIGFjY2VzcyBhbmQgcGVybWlzc2lvbi4nLCAnSW5mbycpOw==', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Google Plus Profile Feed.', '', '', 'Google Plus Profiles (public)', '.git', '', 1, 1, 'https://www.vdm.io/updates/google_plus_profile_server.xml', 'https://www.vdm.io/', '', 'DLskP0PGQKG9Zbggb/uWlfr3MMzyMJsMuuwsGMcr7KE=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 85, '', 1, 14), -(34, '', '', '', '', 1, '', '', '', 1, '', '', 1, '', '', 1, '', 1, '', '', 1, '', '', '', '', '', '', '', 1, 1, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.1', 'Copyright (C) 2015. All Rights Reserved', '2017-07-17 10:38:15', '', '', '', '', '', '', '', '', 1, '', 'The Sync Portal that helps synchronization of data across multiple databases.', 'info@vdm.io', '', '', 'qqDFvORZ7GJ/mZpJbbg3wdmHk5u2AGSiHN+BOV8XuExPRj6zvjNi8CHf5R6RveTMusOYhval993w7PsFEZ7mng==', '', 'd51f4a4a-d524-4458-8c27-7f3ee458d36a', 'images/vdm/SYNC500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2018-02-22 15:15:30', '', 'Sync Portal', 'syncportal', '', 4, '', '', 'CXByb3RlY3RlZCBzdGF0aWMgJHBhcmFtczsNCltDVVNUT01DT0RFPWNvbmZpcm1UcnVzdCt0cnVzdF9zaXRlLFZETV0NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGdldFN5bmNVcmwoJHN5c3RlbSwgJHR5cGUgPSAndHJ1c3QnKQ0KCXsNCgkJLy8gYnVpbGQgdGhlIHN5bmMgdXJsIHRvIHF1ZXJ5DQoJCXN3aXRjaCAoJHN5c3RlbVsnbGlua190eXBlJ10pDQoJCXsNCgkJCWNhc2UgMToNCgkJCQkvLyBJUA0KCQkJCWlmICgyID09ICRzeXN0ZW1bJ2lwX3R5cGUnXSAmJiBzZWxmOjppc1ZhbGlkSVAoJHN5c3RlbVsnaXAnXSkpDQoJCQkJew0KCQkJCQkvLyBzZXQgdGhlIFN0YXRpYyBJUA0KCQkJCQkkdXJsID0gJ2h0dHA6Ly8nIC4gdHJpbSgkc3lzdGVtWydpcCddKTsNCgkJCQl9DQoJCQkJZWxzZWlmICgxID09ICRzeXN0ZW1bJ2lwX3R5cGUnXSkNCgkJCQl7DQoJCQkJCS8vIG11c3Qgc3RpbGwgYnVpbGQgdGhpcw0KCQkJCX0NCgkJCWJyZWFrOw0KCQkJY2FzZSAyOg0KCQkJCS8vIERPTUFJTg0KCQkJCWlmIChTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkc3lzdGVtWyd1cmwnXSkpDQoJCQkJew0KCQkJCQkkdXJsID0gdHJpbSgkc3lzdGVtWyd1cmwnXSwgJy8nKTsNCgkJCQl9DQoJCQlicmVhazsNCgkJfQ0KCQkvLyBjaGVjayBpZiBhIHVybCB3YXMgZm91bmQNCgkJaWYgKGlzc2V0KCR1cmwpKQ0KCQl7DQoJCQkvLyByZXR1cm4gdGhlIHVybA0KCQkJcmV0dXJuICR1cmwgLiAnL2luZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ0YXNrPWFwaS4nIC4gJHR5cGU7DQoJCX0NCgkJcmV0dXJuICcnOw0KCX0NCg0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gc3luY1RhYmxlc0F2YWlsYWJsZSgkdGFibGVzKQ0KCXsNCgkJLy8gZ2V0IHRoZSB3YXRjaGVyIG1vZGVsDQoJCSRtb2RlbCA9IHNlbGY6OmdldE1vZGVsKCd3YXRjaGVycycsIEpQQVRIX0NPTVBPTkVOVF9BRE1JTklTVFJBVE9SKTsNCgl9DQoNCgkvKioNCgkqIAlnZXQgcGxhY2UgaG9sZGVycw0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0UGxhY2VIb2xkZXJzKCR0eXBlKQ0KCXsNCgkJaWYgKCd0cnVzdF9yZXF1ZXN0JyA9PSAkdHlwZSkNCgkJew0KCQkJJGYgPSAnWyc7DQoJCQkkYiA9ICddJzsNCgkJCSRwbGFjZWhvbGRlciA9IGFycmF5KCk7DQoJCQkkcGxhY2Vob2xkZXJbXSA9IGFycmF5X2tleXMoc2VsZjo6Z2V0Q29tcGFueURldGFpbHMoJ3BsYWNlaG9sZGVyJykpOw0KCQkJJHBsYWNlaG9sZGVyW10gPSBzZWxmOjpnZXRTZWxlY3Rpb24oJ3RydXN0X3JlcXVlc3QnLCAkZiwgJGIpOw0KCQkJJHBsYWNlaG9sZGVyW10gPSBhcnJheSgnW2NvbmZpcm1hdGlvbl9saW5rXScpOw0KCQkJcmV0dXJuICBzZWxmOjptZXJnZUFycmF5cygkcGxhY2Vob2xkZXIpOw0KCQl9DQoJCWVsc2VpZiAoJ3RydXN0X2NvbmZpcm0nID09ICR0eXBlKQ0KCQl7DQoJCQkkZiA9ICdbJzsNCgkJCSRiID0gJ10nOw0KCQkJJHBsYWNlaG9sZGVyID0gYXJyYXkoKTsNCgkJCSRwbGFjZWhvbGRlcltdID0gYXJyYXlfa2V5cyhzZWxmOjpnZXRDb21wYW55RGV0YWlscygncGxhY2Vob2xkZXInKSk7DQoJCQkkcGxhY2Vob2xkZXJbXSA9IHNlbGY6OmdldFNlbGVjdGlvbigndHJ1c3RfY29uZmlybScsICRmLCAkYik7DQoJCQlyZXR1cm4gIHNlbGY6Om1lcmdlQXJyYXlzKCRwbGFjZWhvbGRlcik7DQoJCX0NCgkJcmV0dXJuIGZhbHNlOw0KCX0NCg0KCS8qKg0KCSogCU9uY2UgdGhlIGVtYWlsIHdhcyBzZW5kIHRoZSBnaXZlcyB1cyB0aGUgb3B0aW9uIHRoZSBzdG9yZSB0aGUgbWFzc2FnZQ0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gc3RvcmVNZXNzYWdlKCRzZW5kbWFpbCwgJHJlY2lwaWVudCwgJHN1YmplY3QsICRib2R5LCAkdGV4dG9ubHksICRtb2RlLCAkdHlwZSkNCgl7DQoJCXJldHVybiB0cnVlOw0KCX0NCg0KCS8qKg0KCSogUmV0dXJuIGFycmF5IG9mIHNlbGVjdGlvbnMNCgkqIA0KCSogQHJldHVybiAgICBhcnJheSBpZiB0eXBlIG1hdGNoDQoJKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIGdldFNlbGVjdGlvbigkdHlwZSwgJGYsICRiKQ0KCXsNCgkJaWYgKCd0cnVzdF9yZXF1ZXN0JyA9PSAkdHlwZSkNCgkJew0KCQkJcmV0dXJuIGFycmF5KA0KCQkJCSdhLmNoYWluJyA9PiAkZi4nY2hhaW4nLiRiLAkNCgkJCQknYS51cmwnID0+ICRmLid1cmwnLiRiLA0KCQkJCSdhLnBhdGgnID0+ICRmLidwYXRoJy4kYiwNCgkJCQknYS5lbWFpbCcgPT4gJGYuJ2VtYWlsJy4kYiwNCgkJCQknYS5uYW1lJyA9PiAkZi4nbmFtZScuJGIsDQoJCQkJJ2EubWV0aG9kJyA9PiAkZi4nbWV0aG9kJy4kYiwNCgkJCQknYS5yZXF1ZXN0X2lkJyA9PiAkZi4ncmVxdWVzdF9pZCcuJGINCgkJCSk7DQoJCX0NCgkJZWxzZWlmICgndHJ1c3RfY29uZmlybScgPT0gJHR5cGUpDQoJCXsNCgkJCXJldHVybiBhcnJheSgNCgkJCQknYS51cmwnID0+ICRmLid1cmwnLiRiLA0KCQkJCSdhLnBhdGgnID0+ICRmLidwYXRoJy4kYiwNCgkJCQknYS5lbWFpbCcgPT4gJGYuJ2VtYWlsJy4kYiwNCgkJCQknYS5uYW1lJyA9PiAkZi4nbmFtZScuJGIsDQoJCQkJJ2EudHJ1c3RrZXknID0+ICRmLid0cnVzdGtleScuJGIsDQoJCQkpOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoNCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGdldFN5bmNDaGFpbigkaWQpDQoJew0KCQkvLyBsb2FkIHRoZSBidWNrZXQNCgkJJGJ1Y2tldCA9IGFycmF5KCk7DQoJCS8vIGZpcnN0IGdldCBhbGwgR2F0ZXdheXMgTGlua2VkIHRvIHN5bmMgc2l0ZQ0KCQkkbW9kZWwgPSBzZWxmOjpnZXRNb2RlbCgnc3luY19zaXRlJywgSlBBVEhfQ09NUE9ORU5UX0FETUlOSVNUUkFUT1IpOw0KCQkkbW9kZWwtPnN5bmNfc2l0ZXZ2dnYgPSAkaWQ7DQoJCS8vIG5vdyBnZXQgYWxsIHdhdGNoZXJzIGxpbmtlZCB0byBnYXRld2F5cw0KCQlpZiAoJGdhdGVXYXlzID0gJG1vZGVsLT5nZXRWdnlnYXRld2F5cygpKQ0KCQl7DQoJCQlmb3JlYWNoICgkZ2F0ZVdheXMgYXMgJGdhdGUpDQoJCQl7DQoJCQkJLy8gbWFrZSBzdXJlIHRvIGNvbnZlcnQgaWYgbmVlZGVkDQoJCQkJaWYgKFN1cGVyX19fNGIyMjVjNTFfZDI5M180OGU0X2IzZjZfNTEzNmNmNWMzZjE4X19fUG93ZXI6OmNoZWNrKCRnYXRlLT5oYXNoZXMpKQ0KCQkJCXsNCgkJCQkJJGdhdGUtPmhhc2hlcyA9IGpzb25fZGVjb2RlKCRnYXRlLT5oYXNoZXMsIHRydWUpOw0KCQkJCX0NCgkJCQkvLyBtYWtlIHN1cmUgaXQgaXMgYXJyYXkNCgkJCQlpZiAoU3VwZXJfX18wYTU5YzY1Y185ZGFmXzRiYzlfYmFmNF9lMDYzZmY5ZTZhOGFfX19Qb3dlcjo6Y2hlY2soJGdhdGUtPmhhc2hlcykpDQoJCQkJew0KCQkJCQlmb3JlYWNoICgkZ2F0ZS0+aGFzaGVzIGFzICRnZXQpDQoJCQkJCXsNCgkJCQkJCSR3YXRjaGVycyA9IHNlbGY6OmdldFZhcignd2F0Y2hlcicsICRnZXRbJ3dhdGNoZXInXSwgJ2lkJywgJ2hhc2hlcycpOw0KCQkJCQkJLy8gbWFrZSBzdXJlIHRvIGNvbnZlcnQgaWYgbmVlZGVkDQoJCQkJCQlpZiAoU3VwZXJfX180YjIyNWM1MV9kMjkzXzQ4ZTRfYjNmNl81MTM2Y2Y1YzNmMThfX19Qb3dlcjo6Y2hlY2soJHdhdGNoZXJzKSkNCgkJCQkJCXsNCgkJCQkJCQkkd2F0Y2hlcnMgPSBqc29uX2RlY29kZSgkd2F0Y2hlcnMsIHRydWUpOw0KCQkJCQkJfQ0KCQkJCQkJLy8gbWFrZSBzdXJlIGl0IGlzIGFycmF5DQoJCQkJCQlpZiAoU3VwZXJfX18wYTU5YzY1Y185ZGFmXzRiYzlfYmFmNF9lMDYzZmY5ZTZhOGFfX19Qb3dlcjo6Y2hlY2soJHdhdGNoZXJzKSkNCgkJCQkJCXsNCgkJCQkJCQlmb3JlYWNoICgkd2F0Y2hlcnMgYXMgJHdhdGNoZXIpDQoJCQkJCQkJew0KCQkJCQkJCQkvLyBub3cgZ2V0IGFsbCB0YWJsZXMgbGlua2VkIHRvIHdhdGNoZXJzDQoJCQkJCQkJCSRuYW1lID0gc2VsZjo6Z2V0VmFyKCd0YWJsZScsICR3YXRjaGVyWyd0YWJsZSddLCAnaWQnLCAnbmFtZScpOw0KCQkJCQkJCQkkYnVja2V0WyRuYW1lXSA9IGFycmF5KCduYW1lJyA9PiAkbmFtZSk7DQoJCQkJCQkJfQ0KCQkJCQkJfQ0KCQkJCQl9DQoJCQkJfQ0KCQkJfQ0KCQl9DQoJCS8vIGlmIGZvdW5kIHRhYmxlcw0KCQlpZiAoU3VwZXJfX18wYTU5YzY1Y185ZGFmXzRiYzlfYmFmNF9lMDYzZmY5ZTZhOGFfX19Qb3dlcjo6Y2hlY2soJGJ1Y2tldCkpDQoJCXsNCgkJCS8vIHNvcnQgYnkgdGFibGUgbmFtZQ0KCQkJa3NvcnQoJGJ1Y2tldCk7DQoJCQkvLyBsb2FkIHRoZSBjaGFpbg0KCQkJJGNoYWluID0gYXJyYXkoKTsNCgkJCSRjb3VudGVyID0gMDsNCgkJCWZvcmVhY2ggKCRidWNrZXQgYXMgJGFycmF5KQ0KCQkJew0KCQkJCSRjaGFpblsnY2hhaW4nLiRjb3VudGVyXSA9ICRhcnJheTsNCgkJCQkkY291bnRlcisrOw0KCQkJfQ0KCQkJcmV0dXJuICRjaGFpbjsNCgkJfQ0KCQkvLyBub25lIGZvdW5kDQoJCXJldHVybiBudWxsOw0KCX0NCltDVVNUT01DT0RFPWdldFRlbXBsYXRlXQ0KW0NVU1RPTUNPREU9bWRzaXhdDQpbQ1VTVE9NQ09ERT1nZXRDb21wYW55RGV0YWlsc10NCltDVVNUT01DT0RFPWN1cmxXb3JrZXJIZWxwZXJdDQpbQ1VTVE9NQ09ERT1iYXNlU2l4dHlGb3VyVVJMXQ0KW0NVU1RPTUNPREU9d3JpdGVGaWxlXQ0KW0NVU1RPTUNPREU9c2V0SGlkZGVuRmlsZV0NCltDVVNUT01DT0RFPWxvY2tlcl0NCltDVVNUT01DT0RFPXNldER5bmFtaWNEYXRhSUZdDQpbQ1VTVE9NQ09ERT1pc1ZhbGlkSVBdDQpbQ1VTVE9NQ09ERT1uaWNlRmFuY3lEYXRlXQ==', '', '', 'CQkvLyBHZXQgQXBwbGljYXRpb24gb2JqZWN0DQoJCSRhcHAgPSBGYWN0b3J5OjpnZXRBcHBsaWNhdGlvbigpOw0KCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnPGgxPkhvdyBpdCB3b3JrczwvaDE+PHA+UGxlYXNlIHdhdGNoIHRoZSBmb2xsb3dpbmcgPGEgaHJlZj0iIyIgdGFyZ2V0PSJfYmxhbmsiPnR1dG9yaWFsPC9hPiBiZWZvcmUgeW91IGNvbnRpbnVlLiBUaGlzIHdpbGwgaW5zdXJlIHRoYXQgeW91IGZ1bGwgdW5kZXJzdGFuZCBob3cgaXQgd29ya3MgYW5kIGF2b2lkIGNvcnJ1cHRpb24gb2YgeW91IGRhdGEuPC9wPicsICdJbmZvJyk7', '', 'CQkJLy8gbWFrZSBzdXJlIHdlIGhhdmUgY3VybCBpbnN0YWxsZWQNCgkJCWlmICghZnVuY3Rpb25fZXhpc3RzKCdjdXJsX3ZlcnNpb24nKSkNCgkJCXsNCgkJCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnRXJyb3IhIEN1cmwgbm90IGZvdW5kISBDdXJsIGlzIHJlcXVpcmVkIHRvIHJ1biB0aGUgc3luYyBvcGVyYXRpb25zLCB3aXRob3V0IGl0IHdlIGNhbiBub3QgY29udGludWUuJywgJ2Vycm9yJyk7DQoJCQkJcmV0dXJuIGZhbHNlOw0KCQkJfQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKQ==', '', '', 'Sync Portal', '', '', 'Sync Portal', '.git', '', '', 1, 'https://www.vdm.io/updates/demo_update_server.xml', 'https://www.vdm.io/', '', '3NkQKoYfIUTod/HWu93LdYEEjTyf7G5ti0El5QJRaqM=', '', '', 1, 127, '', 1, 16), -(35, '', '', '', '', 1, '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, 1, '', '', '', 1, '{}', 3, 1, 3, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.8', 'Copyright (C) 2015. All Rights Reserved', '2018-02-26 15:27:39', '', 'AIEdncGGYhXwT3K9riCVHj77bZdow5JNzfd5v/JFWRE=', '+qzH++P20Vn9Lu6rDFk8Guugn5VHGPApQXV92hIl21o=', '', 'VxGjDkRxSYPEI0CbN5lPWPGZMuMBwE7dh48Jb4AZxn0=', '', '', '', 1, '', 'Certification Authority', 'joomla@vdm.io', '', '', 'VMTs0q3O6q5SP+sxS2o2+28AeqDNOJbwXric5PkFxS8yVHU+7K9o8XeGgIDrcW4xHSw5dCLESW4Rnadyr4OAXg==', '', '679e64b0-9d16-42df-a5ca-87e1de35c2a9', 'images/vdm/CA500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-03-08 03:12:42', 2, 'Certification Authority', 'CertificationAuthority', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29uZmlybVRydXN0K3RydXN0X3BvcnRhbCxKQ0JdDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBnZXRTeW5jVXJsKCRzeXN0ZW0sICR0eXBlID0gJ3RydXN0JykNCgl7DQoJCS8vIGJ1aWxkIHRoZSBzeW5jIHVybCB0byBxdWVyeQ0KCQlzd2l0Y2ggKCRzeXN0ZW1bJ2xpbmtfdHlwZSddKQ0KCQl7DQoJCQljYXNlIDE6DQoJCQkJLy8gSVANCgkJCQlpZiAoMiA9PSAkc3lzdGVtWydpcF90eXBlJ10gJiYgc2VsZjo6aXNWYWxpZElQKCRzeXN0ZW1bJ2lwJ10pKQ0KCQkJCXsNCgkJCQkJLy8gc2V0IHRoZSBTdGF0aWMgSVANCgkJCQkJJHVybCA9ICdodHRwOi8vJyAuIHRyaW0oJHN5c3RlbVsnaXAnXSk7DQoJCQkJfQ0KCQkJCWVsc2VpZiAoMSA9PSAkc3lzdGVtWydpcF90eXBlJ10pDQoJCQkJew0KCQkJCQkvLyBtdXN0IHN0aWxsIGJ1aWxkIHRoaXMNCgkJCQl9DQoJCQlicmVhazsNCgkJCWNhc2UgMjoNCgkJCQkvLyBET01BSU4NCgkJCQlpZiAoU3VwZXJfX18xZjI4Y2I1M182MGQ5XzRkYjFfYjUxN18zYzdkYzZiNDI5ZWZfX19Qb3dlcjo6Y2hlY2soJHN5c3RlbVsndXJsJ10pKQ0KCQkJCXsNCgkJCQkJJHVybCA9IHRyaW0oJHN5c3RlbVsndXJsJ10sICcvJyk7DQoJCQkJfQ0KCQkJYnJlYWs7DQoJCX0NCgkJLy8gY2hlY2sgaWYgYSB1cmwgd2FzIGZvdW5kDQoJCWlmIChpc3NldCgkdXJsKSkNCgkJew0KCQkJLy8gcmV0dXJuIHRoZSB1cmwNCgkJCXJldHVybiAkdXJsIC4gJy9pbmRleC5waHA/b3B0aW9uPWNvbV9bW1tjb21wb25lbnRdXV0mdGFzaz1hcGkuJyAuICR0eXBlOw0KCQl9DQoJCXJldHVybiAnJzsNCgl9DQoNCgkvKioNCgkqIAlnZXQgcGxhY2UgaG9sZGVycw0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0UGxhY2VIb2xkZXJzKCR0eXBlKQ0KCXsNCgkJaWYgKCd0cnVzdF9yZXF1ZXN0JyA9PSAkdHlwZSkNCgkJew0KCQkJJGYgPSAnWyc7DQoJCQkkYiA9ICddJzsNCgkJCSRwbGFjZWhvbGRlciA9IGFycmF5KCk7DQoJCQkkcGxhY2Vob2xkZXJbXSA9IGFycmF5X2tleXMoc2VsZjo6Z2V0Q29tcGFueURldGFpbHMoJ3BsYWNlaG9sZGVyJykpOw0KCQkJJHBsYWNlaG9sZGVyW10gPSBzZWxmOjpnZXRTZWxlY3Rpb24oJ3RydXN0X3JlcXVlc3QnLCAkZiwgJGIpOw0KCQkJJHBsYWNlaG9sZGVyW10gPSBhcnJheSgnW2NvbmZpcm1hdGlvbl9saW5rXScpOw0KCQkJcmV0dXJuICBzZWxmOjptZXJnZUFycmF5cygkcGxhY2Vob2xkZXIpOw0KCQl9DQoJCWVsc2VpZiAoJ3RydXN0X2NvbmZpcm0nID09ICR0eXBlKQ0KCQl7DQoJCQkkZiA9ICdbJzsNCgkJCSRiID0gJ10nOw0KCQkJJHBsYWNlaG9sZGVyID0gYXJyYXkoKTsNCgkJCSRwbGFjZWhvbGRlcltdID0gYXJyYXlfa2V5cyhzZWxmOjpnZXRDb21wYW55RGV0YWlscygncGxhY2Vob2xkZXInKSk7DQoJCQkkcGxhY2Vob2xkZXJbXSA9IHNlbGY6OmdldFNlbGVjdGlvbigndHJ1c3RfY29uZmlybScsICRmLCAkYik7DQoJCQlyZXR1cm4gIHNlbGY6Om1lcmdlQXJyYXlzKCRwbGFjZWhvbGRlcik7DQoJCX0NCgkJcmV0dXJuIGZhbHNlOw0KCX0NCg0KCS8qKg0KCSogCU9uY2UgdGhlIGVtYWlsIHdhcyBzZW5kIHRoZSBnaXZlcyB1cyB0aGUgb3B0aW9uIHRoZSBzdG9yZSB0aGUgbWFzc2FnZQ0KCSoqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gc3RvcmVNZXNzYWdlKCRzZW5kbWFpbCwgJHJlY2lwaWVudCwgJHN1YmplY3QsICRib2R5LCAkdGV4dG9ubHksICRtb2RlLCAkdHlwZSkNCgl7DQoJCXJldHVybiB0cnVlOw0KCX0NCg0KCS8qKg0KCSogUmV0dXJuIGFycmF5IG9mIHNlbGVjdGlvbnMNCgkqIA0KCSogQHJldHVybiAgICBhcnJheSBpZiB0eXBlIG1hdGNoDQoJKi8NCglwcm90ZWN0ZWQgc3RhdGljIGZ1bmN0aW9uIGdldFNlbGVjdGlvbigkdHlwZSwgJGYsICRiKQ0KCXsNCgkJaWYgKCd0cnVzdF9yZXF1ZXN0JyA9PSAkdHlwZSkNCgkJew0KCQkJcmV0dXJuIGFycmF5KA0KCQkJCSdhLmNoYWluJyA9PiAkZi4nY2hhaW4nLiRiLAkNCgkJCQknYS51cmwnID0+ICRmLid1cmwnLiRiLA0KCQkJCSdhLnBhdGgnID0+ICRmLidwYXRoJy4kYiwNCgkJCQknYS5lbWFpbCcgPT4gJGYuJ2VtYWlsJy4kYiwNCgkJCQknYS5uYW1lJyA9PiAkZi4nbmFtZScuJGIsDQoJCQkJJ2EubWV0aG9kJyA9PiAkZi4nbWV0aG9kJy4kYiwNCgkJCQknYS5yZXF1ZXN0X2lkJyA9PiAkZi4ncmVxdWVzdF9pZCcuJGINCgkJCSk7DQoJCX0NCgkJZWxzZWlmICgndHJ1c3RfY29uZmlybScgPT0gJHR5cGUpDQoJCXsNCgkJCXJldHVybiBhcnJheSgNCgkJCQknYS51cmwnID0+ICRmLid1cmwnLiRiLA0KCQkJCSdhLnBhdGgnID0+ICRmLidwYXRoJy4kYiwNCgkJCQknYS5lbWFpbCcgPT4gJGYuJ2VtYWlsJy4kYiwNCgkJCQknYS5uYW1lJyA9PiAkZi4nbmFtZScuJGIsDQoJCQkJJ2EudHJ1c3RrZXknID0+ICRmLid0cnVzdGtleScuJGIsDQoJCQkpOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoNCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGdldFN5bmNDaGFpbigkaWQpDQoJew0KCQkvLyBub25lIGZvdW5kDQoJCXJldHVybiBudWxsOw0KCX0NCltDVVNUT01DT0RFPWdldENvbXBhbnlEZXRhaWxzXQ0KW0NVU1RPTUNPREU9YmFzZVNpeHR5Rm91clVSTF0NCltDVVNUT01DT0RFPXNldER5bmFtaWNEYXRhSUZdDQpbQ1VTVE9NQ09ERT1nZXRUZW1wbGF0ZV0gDQpbQ1VTVE9NQ09ERT1tZHNpeF0NCltDVVNUT01DT0RFPWN1cmxXb3JrZXJIZWxwZXJdDQpbQ1VTVE9NQ09ERT1sb2NrZXJdDQpbQ1VTVE9NQ09ERT11cmxFeGlzdHNdDQpbQ1VTVE9NQ09ERT1nZXRGaWxlUGF0aF0NCltDVVNUT01DT0RFPWdldEZvbGRlclBhdGhdDQpbQ1VTVE9NQ09ERT1nZXRGaWxlQ29udGVudHNdDQpbQ1VTVE9NQ09ERT1jb21wb3NlVkVORE9SK3BocHNlY2xpYl0NCltDVVNUT01DT0RFPWNyeXB0XQ==', '', '', '', '', '', '', '', '# Joomla ###Component_name### (JCB)
[![GitHub release](https://img.shields.io/github/release/vdm-io/Joomla-Component-Builder.svg)](https://github.com/vdm-io/Joomla-Component-Builder/releases) [![Total Downloads](https://img.shields.io/github/downloads/vdm-io/Joomla-Component-Builder/total.svg)](https://github.com/vdm-io/Joomla-Component-Builder/releases)

This is a [Joomla 3.x](https://extensions.joomla.org/extension/component-builder/) component. [__See In Action__](https://www.youtube.com/watch?v=IQfsLYIeblk&list=PLQRGFI8XZ_wtGvPQZWBfDzzlERLQgpMRE&index=45)

 ![###Component_name### image](https://raw.githubusercontent.com/vdm-io/Joomla-Component-Builder/master/admin/assets/images/vdm-component.jpg "The ###Component_name###")

###DESCRIPTION###

You can install it quite easily and with no limitations. On [github](https://github.com/vdm-io/Joomla-Component-Builder/releases) is the latest release (###ACTUALVERSION###) with **ALL** its features and **ALL** concepts totally open-source and free! 

> Watch Quick Build of a Hello World component in [JCB on Youtube](https://www.youtube.com/watch?v=IQfsLYIeblk&list=PLQRGFI8XZ_wtGvPQZWBfDzzlERLQgpMRE&index=45)

Once installed upgrades are quick and easy via the default Joomla upgrade area.

Some of the Features
====================

+ Adding mySQL Dump to any View/Table.
+ Grab existing Table data and build a dynamic dump.
+ Unlimited Joomla Components.
+ Unlimited Tables/Views.
+ Reusing Views and Fields.
+ Runs on Your Own Joomla Install.
+ Add Dynamic/custom back-end views that uses Table and Chart result sets.
+ Build data query of extreme complex nature to use in Dynamic/custom views.
+ Highly Dynamic/custom Front-end Structures.
+ Dynamically setup templates and layouts for Front-end design.
+ Integration of the excellent UIKIT lib.
+ Integration of the excellent FOOTABLE lib.
+ All Joomla Standard Field Types (including repeatable fields).
+ Strong Implementation of all Joomla Form Security.
+ Load data via ajax with ease.
+ You can add an Update Server to Components you build.
+ Build advanced Dynamic front-end forms.
+ Dynamic data queries from multiple tables.
+ Place in local GIT folder, and publish to sales server.
+ Include any amount of custom files and folders during build.
+ Static helper class with smart methods already included.
+ Static helper methods Can easily be added.
+ Direct install from complier view.
+ Integrative with native Joomla Categories and Tags.
+ Fully Dynamic Search Friendly URL Auto Implementation.
+ Custom scripting options all over the MVC structure.
+ Permission implementation down to each view, item and field.
+ Easy extendible to include other libraries.
+ Can include SQL and visioning update link to distribute your component updates via Joomla default upgrade of components.
+ Easy Export & Import addon to all backend-tables.
+ Overriding ability of import concepts in all backend-tables.
+ The Batch and Filter implementation on all backend-list views.
+ This and much much more are all possible with this component builder!

Just Imagine
====================

+ Your Component Back-end can be more advanced then the Joomla Article Manager.
+ Your Code as Perfectly Unified to the strict Joomla Standards.
+ Adding Custom Scripting almost anywhere in the MVC structure.
+ Import and export feature to all backend-views.
+ Batch copy and move/update feature for all backend-views.
+ History tracking per/change made on any back-end item.
+ Dynamic field control, to show and hide fields in amazing ways.
+ Front-end freedom of design that allows for any library to be used.
+ This and much much more are all possible with this component builder!

You are in Control
====================

+ You can change the licensing template for your components.
+ You can change/improve existing field types and add more.
+ Line numbers to show where in compiler was the code build.
+ You can improve the component since all code are open-source.
+ Free updates for the lifetime of the project.
+ You can dynamically add internal help structures to all component.
+ There is no limitations on how big or how much you want to build (server limitation only).
+ This is a complete factory kind of component that functions like a deployment hub.
+ Export any component completely mapped in JCB and import into another JCB.
+ This and much much more are all possible with this component builder!

Get More Demo Content
====================

> **You can purchase more [demo content](http://vdm.bz/jcb-packages) for ###Component_name###:**

+ *Demo Component* see the build on [github](https://github.com/namibia/demo-joomla-3-component) or get the [JCB Package](https://github.com/vdm-io/JCB-Packages/raw/master/JCB_demo.zip) _(free)_
+ *Advance Demo Component* get the [JCB Package](https://github.com/vdm-io/JCB-Packages/raw/master/JCB_demoAdvanced.zip) _([buy key](http://vdm.bz/get-advance-demo-key))_
+ *Sermon Distributor* see the build on [github](https://github.com/SermonDistributor/Joomla-3-Component) or get the [JCB Package](https://github.com/vdm-io/JCB-Packages/raw/master/JCB_sermondistributor.zip) _([buy key](http://vdm.bz/get-sermon-distributor-key))_
+ *Location Data* see the build on [github](https://github.com/vdm-io/Joomla-Location-Data) or get the [JCB Package](https://github.com/vdm-io/JCB-Packages/raw/master/JCB_locationData.zip) _([buy key](http://vdm.bz/get-location-data-key))_
+ *More Coming...*

Where can you get support and help?
====================

+ [The JCB Tutorials](https://www.youtube.com/playlist?list=PLQRGFI8XZ_wtGvPQZWBfDzzlERLQgpMRE)
+ [Hello World Tutorial](https://www.youtube.com/watch?v=IQfsLYIeblk&list=PLQRGFI8XZ_wtGvPQZWBfDzzlERLQgpMRE&index=45)
+ [The JCB! Wiki](https://github.com/vdm-io/Joomla-Component-Builder/wiki)
+ [JCB Google Group/forum](https://groups.google.com/a/vdm.io/d/forum/jcb)
+ [Report a Security Issue](https://www.joomlacomponentbuilder.com/report-security-issues)
+ [Community Complaint](https://www.joomlacomponentbuilder.com/community-complaint)
+ [Open Issue On Github](https://github.com/vdm-io/Joomla-Component-Builder/issues) ^^

Since JCB has [become a community](https://github.com/vdm-io/Joomla-Component-Builder/blob/staging/.github/SUPPORT.md) project [VDM.io](https://www.vdm.io/joomla-component-builder) is **no longer solely responsible** for support.

We have started a [**JCB forum**](https://groups.google.com/a/vdm.io/d/forum/jcb) where you can post questions, about how things work, or if you need some kind of help in relation to your development of your components.

^^ Then if you run into any issues, related to the JCB code, like bugs, **start by searching** the (*open & closed*) issues over on Github, and if the issue has not been mentioned before, **then only** open a new issue, following the [community guidelines](https://github.com/vdm-io/Joomla-Component-Builder/blob/master/.github/CONTRIBUTING.md).

WHY GIVE IT AWAY LIKE THIS?
====================

> We are Open Source Enthusiast
> Who Support the Joomla Community

Our idea was to almost let this tool serve as a cheat sheet to how things can be done... and with the help of other developers end up formulating the way how things not only can, but must be done to insure secure, stable, scalable and maintainable code is produced. 

MAKING IT BETTER!
====================

Component Builder is mapped as a component in itself on my local development environment. So we are improving it like you would any other component in it. I am looking for developers with the **skill** and the **desire** to really join us... and then we will [possible give them access](https://www.youtube.com/watch?v=lLOfx9YA7VQ&list=PLQRGFI8XZ_wsfz3NdKawCiYsALuZ-GhwJ) to this, so we can all help improve this simple, yet advanced tool.

# Build Details

+ *Company*: [###COMPANYNAME###](https://www.vdm.io/)
+ *Author*: [###AUTHOR###](mailto:###AUTHOREMAIL###)
+ *Name*: [###Component_name###](###AUTHORWEBSITE###)
+ *First Build*: ###CREATIONDATE###
+ *Last Build*: ###BUILDDATE###
+ *Version*: ###ACTUALVERSION###
+ *Copyright*: ###COPYRIGHT###
+ *License*: ###LICENSE###
+ *Line count*: **###LINE_COUNT###**
+ *Field count*: **###FIELD_COUNT###**
+ *File count*: **###FILE_COUNT###**
+ *Folder count*: **###FOLDER_COUNT###**

> This **component** was build with a Joomla [Automated Component Builder](https://www.joomlacomponentbuilder.com).
> Developed by [Llewellyn van der Merwe](mailto:joomla@vdm.io)

## Donations

Come on buy VDM a coffee :)
 * Open Collective: [Joomla-Component-Builder](https://opencollective.com/Joomla-Component-Builder)', '', '', 'Certification Authority', '', '', 'Certification Authority', '.git, .github', '', 1, 1, 'https://www.vdm.io/updates/certificationauthority_update_server.xml', 'https://www.vdm.io', '', 'CWxMWTAk4dMjFc8FuG0fB9okNIENoXyPlnUbkdHx4qE=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 12, '', 1, 69), -(36, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, 1, 1, 3, 'Llewellyn', '', 'default.txt', '', '', 'VDM', '1.1.1', 'Copyright (C) 2015. All Rights Reserved', '2017-09-20 01:21:36', '', '/XJGJoD2dKTqyJhxXeoGE0YK5BBlyg1fUR0SpwxDH30=', 'a8a8NXtGxOCg8ASo0XdOOeR8u5RUag2ET+ikfWxULmo=', '', '0jZ65WmtQKZrZKOJcAn4blOqs1kR7ILcMpYnjcvmCT8=', '', '', '', 1, '', '', 'joomla@vdm.io', '', '', 'fb5eHOid0kP2pP2rMqTX0T2IVb548xGD/yEis81L4Tw=', '', '2dea78a6-e0be-4260-8f7d-b278e0b661a8', 'images/demo300.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Hello-World-Component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-03-07 13:38:50', '', 'Hello World', 'HelloWorld', 'JCB', 4, '', '', 'W0NVU1RPTUNPREU9d3JpdGVGaWxlXQ0KW0NVU1RPTUNPREU9Z2V0RmlsZUNvbnRlbnRzXQ0KW0NVU1RPTUNPREU9cmVtb3ZlRm9sZGVyXQ==', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKSkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gbmV2ZXIgbWFraW5nIG9uZSBtaXN0YWtlIG9yIHRha2luZyBhbnkgY29mZmVlIGJyZWFrLikNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KKiojIyNhY3R1YWxIb3Vyc1NwZW50IyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxEYXlzU3BlbnQjIyMgRWlnaHQgSG91ciBEYXlzKiogKHRoZSBhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNwZW50KQ0KDQo+ICh3aXRoIHRoZSBmb2xsb3dpbmcgYnJlYWsgZG93bjoNCj4gKipkZWJ1Z2dpbmcgQCMjI2RlYnVnZ2luZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA0Ow0KPiAqKnBsYW5uaW5nIEAjIyNwbGFubmluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA3Ow0KPiAqKm1hcHBpbmcgQCMjI21hcHBpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gMTA7DQo+ICoqb2ZmaWNlIEAjIyNvZmZpY2VIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNjspDQoNCioqIyMjYWN0dWFsVG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsVG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqDQooYSB0b3RhbCBvZiB0aGUgcmVhbGlzdGljIHRpbWUgZnJhbWUgZm9yIHRoaXMgcHJvamVjdCkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gd2l0aCB0aGUgbm9ybWFsIGV2ZXJ5ZGF5IHJlYWxpdGllcyBhdCB0aGUgb2ZmaWNlLCB0aGF0IGluY2x1ZGVzIHRoZSBjb21wb25lbnQgcGxhbm5pbmcsIG1hcHBpbmcgJiBkZWJ1Z2dpbmcuKQ0KDQpQcm9qZWN0IGR1cmF0aW9uOiAqKiMjI3Byb2plY3RXZWVrVGltZSMjIyB3ZWVrcyoqIG9yICoqIyMjcHJvamVjdE1vbnRoVGltZSMjIyBtb250aHMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkuDQo+IERldmVsb3BlZCBieSBbTGxld2VsbHluIHZhbiBkZXIgTWVyd2VdKG1haWx0bzpqb29tbGFAdmRtLmlvKQ0KDQpbQ1VTVE9NQ09ERT1yZWFkTUVjb250cmlidXRvcnNd', '', '', 'Hello World', '', '', 'Hello World (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/Llewellynvdm/Joomla-Hello-World-Component/master/helloworld_updateserver.xml', 'https://www.vdm.io', '', '5ZLmKq90y+Rw5NhMdx4zzQIzGCQXnXPXNNKPt1VUJVo=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_site_helper\":[]}}', 1, 26, '', 1, 48), -(38, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.11', 'Copyright (C) 2015. All Rights Reserved', '2018-08-06 14:56:04', '', 'DDqhKfMaxgOxOi8Fi/LRCdMLwGehkjYNuvi7ABAiLPY=', '2lcbvIz8wbuYvgcTT0AkruIGkKk/eITskCWhJUe5iZw=', '', 'EOj0Eq9DxXxfbb1es7CtSnWWu/9MbbGia2HVegss6bc=', '', '', 'A_101', 2, '', 'Anthropometry', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_anthropometry', '+2q2ksbp2S8xrelxzlL93YeOn85WOaaH6AMXe8MRdhZErBnfo+S81DfJPMAD8ZTSjVn3LwQpzOcwo+NNJO1Kdw==', '', '12327a9d-f9c1-4ae1-bc23-5b254ce3bf5b', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:39:17', 2, 'Anthropometry', 'anthropometry', '', 4, '', '', 'W0NVU1RPTUNPREU9YW50aHJvcG9tZXRyeUhlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Anthropometry', '--
-- Dumping data for table `#__[[[component]]]_status_norm`
--

INSERT INTO `#__[[[component]]]_status_norm` (`id`, `calculation_type`, `calculations`, `selection`, `templates`, `published`, `created`) VALUES
(1, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"10, 24.9\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"25, 29.9\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"30, 40\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"41, 200\"}}', 'bmi', '{\"templates0\":{\"target\":\"0\",\"word\":\"desirable\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Desirable<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 1 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 2 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 3 Obesity\\/Morbid<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Desirable<\\/button>\"},\"templates1\":{\"target\":\"1\",\"word\":\"grade 1 obesity\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Desirable<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Grade 1 Obesity<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 2 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 3 Obesity\\/Morbid<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 1 Obesity<\\/button>\"},\"templates2\":{\"target\":\"2\",\"word\":\"grade 2 obesity\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Desirable<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 1 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Grade 2 Obesity<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 3 Obesity\\/Morbid<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 2 Obesity<\\/button>\"},\"templates3\":{\"target\":\"3\",\"word\":\"grade 3 obesity\\/morbid\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Desirable<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 1 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 2 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Grade 3 Obesity\\/Morbid<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 3 Obesity\\/Morbid<\\/button>\"}}', 1, '2018-09-07 19:41:55'),
(2, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0.959, 20.00\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0.91, 0.958\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0.000001, 0.95\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0.859, 20\"},\"calculations4\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0.81, 0.858\"},\"calculations5\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0.00, 0.80\"}}', 'whr', '{\"templates0\":{\"target\":\"0\",\"word\":\"high risk\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>High risk<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Moderate risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Low risk<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">High risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Moderate risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Low risk<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">High risk<\\/button>\"},\"templates1\":{\"target\":\"1\",\"word\":\"moderate risk\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">High risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Moderate risk<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Low risk<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>High risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Moderate risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Low risk<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Moderate risk<\\/button>\"},\"templates2\":{\"target\":\"2\",\"word\":\"low risk\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">High risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Moderate risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Low risk<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>High risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Moderate risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Low risk<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Low risk<\\/button>\"}}', 1, '2018-09-07 19:49:11'),
(3, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"22.4\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"17.4\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"15.9\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"14.1\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"9.4\"},\"calculations5\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"24.2\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"20.5\"},\"calculations7\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"19\"},\"calculations8\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"17.5\"},\"calculations9\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"13.9\"},\"calculations10\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"26.1\"},\"calculations11\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"22.5\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"21.1\"},\"calculations13\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"19.6\"},\"calculations14\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"16.3\"},\"calculations15\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"27.5\"},\"calculations16\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"24.1\"},\"calculations17\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"22.7\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"21.3\"},\"calculations19\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"17.9\"},\"calculations20\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"28.5\"},\"calculations21\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"25\"},\"calculations22\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"23.5\"},\"calculations23\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"22\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"18.4\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"27.7\"},\"calculations26\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"23.7\"},\"calculations27\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"22.1\"},\"calculations28\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"20.6\"},\"calculations29\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"17.1\"},\"calculations30\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"29.3\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"24.9\"},\"calculations32\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"23.1\"},\"calculations33\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"21.6\"},\"calculations34\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"18\"},\"calculations35\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"32.1\"},\"calculations36\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"28.1\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"26.4\"},\"calculations38\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"24.9\"},\"calculations39\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"21.3\"},\"calculations40\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"35.6\"},\"calculations41\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"31.6\"},\"calculations42\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"30.1\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"28.5\"},\"calculations44\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"25\"},\"calculations45\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"36.6\"},\"calculations46\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"32.5\"},\"calculations47\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"30.9\"},\"calculations48\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"29.3\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"25.1\"}}', 'fat_percentage', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Poor<\\/button>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Fair<\\/button>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Ave<\\/button>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Good<\\/button>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Excellent<\\/button>\"}}', 1, '2018-09-07 20:01:23');

--
-- Dumping data for table `#__[[[component]]]_chart`
--

INSERT INTO `#__[[[component]]]_chart` (`id`, `details`, `javascript_table`, `name`, `number`, `target`, `target_fields`, `type`, `published`, `created`) VALUES
(1, '{\"dataTable\":{\"cols\":[{\"label\":\"Label\",\"type\":\"string\"},{\"label\":\"Value\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"Lean Weight\"},{\"v\":92.34}]},{\"c\":[{\"v\":\"Fat Weight\"},{\"v\":19.65}]}]},\"options\":{\"fontName\":\"Verdana\",\"hAxis\":{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null},\"legacyScatterChartLabels\":true,\"legend\":\"none\",\"legendTextStyle\":{\"color\":\"#222\",\"fontSize\":12,\"bold\":true,\"italic\":true},\"title\":\"Body Weight\",\"titleTextStyle\":{\"color\":\"#000\",\"fontSize\":\"20\",\"bold\":true},\"vAxes\":[{\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true,\"logScale\":false},{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"logScale\":false}],\"type\":\"line\",\"booleanRole\":\"certainty\",\"series\":[{\"type\":\"bars\"},{\"type\":\"bars\"},{\"type\":\"bars\"},{\"type\":\"bars\"},{\"type\":\"bars\"}],\"width\":600,\"height\":371,\"is3D\":true,\"pieHole\":0,\"slices\":{\"0\":{\"color\":\"#93c47d\"},\"1\":{\"color\":\"#b4a7d6\"}},\"pieSliceText\":\"label\",\"theme\":\"maximized\"},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"PieChart\"}', '(Label, Value)\r\n([anthropometry_label_lean_weight], [anthropometry_lean_weight])\r\n([anthropometry_label_fat_weight], [anthropometry_fat_weight])', 'Body Weight', 3, 1, '{\"target_fields0\":{\"selection\":\"lean_weight\"},\"target_fields1\":{\"selection\":\"fat_weight\"}}', 'PieChart', 1, '2018-09-27 10:38:43'),
(2, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"BMI\",\"type\":\"number\"},{\"label\":\"Fat Percentage\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/08\"},{\"v\":32.72},{\"v\":23.63}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":32.72},{\"v\":23.63}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":32.72},{\"v\":17.55}]},{\"c\":[{\"v\":\"2018/09/10\"},{\"v\":32.72},{\"v\":17.55}]},{\"c\":[{\"v\":\"2018/09/09\"},{\"v\":30.55},{\"v\":28.2}]},{\"c\":[{\"v\":\"2018/09/08\"},{\"v\":32.72},{\"v\":26.71}]}]},\"options\":{\"hAxis\":{\"useFormatFromData\":true,\"slantedTextAngle\":30,\"slantedText\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null},\"legacyScatterChartLabels\":true,\"legend\":\"in\",\"title\":\"Progress\",\"vAxes\":[{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"logScale\":false},{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"logScale\":false}],\"isStacked\":false,\"booleanRole\":\"certainty\",\"width\":600,\"height\":371,\"lineWidth\":2,\"interpolateNulls\":true,\"domainAxis\":{\"direction\":-1},\"curveType\":\"function\",\"series\":{\"0\":{\"targetAxisIndex\":1,\"errorBars\":{\"errorType\":\"none\"}},\"1\":{\"targetAxisIndex\":0,\"errorBars\":{\"errorType\":\"none\",\"magnitude\":10}}},\"theme\":\"maximized\",\"focusTarget\":\"category\"},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '(Day, [anthropometry_label_bmi], [anthropometry_label_fat_percentage])\r\n([0_anthropometry_day], [0_anthropometry_bmi], [0_anthropometry_fat_percentage])\r\n([1_anthropometry_day], [1_anthropometry_bmi], [1_anthropometry_fat_percentage])\r\n([2_anthropometry_day], [2_anthropometry_bmi], [2_anthropometry_fat_percentage])', 'Progress', 4, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"bmi\"},\"target_fields2\":{\"selection\":\"fat_percentage\"}}', 'LineChart', 1, '2018-09-27 11:28:37'),
(3, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"Weight\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":112}]},{\"c\":[{\"v\":\"2018/09/10\"},{\"v\":112}]},{\"c\":[{\"v\":\"2018/09/09\"},{\"v\":99}]},{\"c\":[{\"v\":\"2018/09/08\"},{\"v\":112}]}]},\"options\":{\"title\":\"Weight\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null}},{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null}],\"legacyScatterChartLabels\":true,\"curveType\":\"function\",\"booleanRole\":\"certainty\",\"lineWidth\":2,\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null,\"slantedTextAngle\":30,\"slantedText\":true,\"title\":\"\"},\"legend\":\"none\",\"width\":600,\"height\":371,\"domainAxis\":{\"direction\":-1},\"series\":{\"0\":{\"color\":\"#741b47\",\"targetAxisIndex\":0,\"lineWidth\":4,\"pointSize\":10}},\"theme\":\"maximized\"},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":true,\"chartType\":\"LineChart\"}', '(Day, [anthropometry_label_weight])\r\n([0_anthropometry_day], [0_anthropometry_weight])\r\n([1_anthropometry_day], [1_anthropometry_weight])\r\n([2_anthropometry_day], [2_anthropometry_weight])\r\n([3_anthropometry_day], [3_anthropometry_weight])\r\n([4_anthropometry_day], [4_anthropometry_weight])', 'Weight', 5, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"weight\"}}', 'LineChart', 1, '2018-10-04 21:37:18'),
(4, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"Calf\",\"type\":\"number\"},{\"label\":\"Chest\",\"type\":\"number\"},{\"label\":\"Hip\",\"type\":\"number\"},{\"label\":\"Middle\",\"type\":\"number\"},{\"label\":\"Navel\",\"type\":\"number\"},{\"label\":\"Neck\",\"type\":\"number\"},{\"label\":\"Thigh\",\"type\":\"number\"},{\"label\":\"Upper Arm\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/08\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":106.5},{\"v\":32},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/10/08\"},{\"v\":42.5},{\"v\":113},{\"v\":85},{\"v\":80},{\"v\":110},{\"v\":null},{\"v\":23},{\"v\":23}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":42.5},{\"v\":119.5},{\"v\":125.2},{\"v\":106.5},{\"v\":106.5},{\"v\":null},{\"v\":65.5},{\"v\":36.5}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":80},{\"v\":30},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/09/10\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":80},{\"v\":30},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/09/09\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":110},{\"v\":45},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/09/08\"},{\"v\":42.5},{\"v\":119.5},{\"v\":115.5},{\"v\":106.5},{\"v\":112},{\"v\":null},{\"v\":65.5},{\"v\":36.5}]}]},\"options\":{\"legacyScatterChartLabels\":true,\"legend\":\"none\",\"title\":\"Circumferences\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"booleanRole\":\"certainty\",\"lineWidth\":2,\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null,\"textStyle\":{\"color\":\"#222\",\"fontSize\":\"12\",\"italic\":false},\"slantedTextAngle\":60,\"slantedText\":true},\"width\":600,\"height\":371,\"interpolateNulls\":true,\"focusTarget\":\"category\",\"series\":{\"0\":{\"targetAxisIndex\":1},\"2\":{\"targetAxisIndex\":1,\"lineWidth\":2},\"3\":{\"targetAxisIndex\":1}},\"domainAxis\":{\"direction\":1},\"curveType\":\"function\",\"fontName\":\"Verdana\",\"titleTextStyle\":{\"color\":\"#000\",\"fontSize\":12,\"bold\":true,\"italic\":true}},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '(Day, [anthropometry_label_circumferences_calf], [anthropometry_label_circumferences_chest], [anthropometry_label_circumferences_hip], [anthropometry_label_circumferences_middle], [anthropometry_label_circumferences_navel], [anthropometry_label_circumferences_neck], [anthropometry_label_circumferences_thigh], [anthropometry_label_circumferences_upper_arm])\r\n([0_anthropometry_day], [0_anthropometry_circumferences_calf], [0_anthropometry_circumferences_chest], [0_anthropometry_circumferences_hip], [0_anthropometry_circumferences_middle], [0_anthropometry_circumferences_navel], [0_anthropometry_circumferences_neck], [0_anthropometry_circumferences_thigh], [0_anthropometry_circumferences_upper_arm])\r\n([1_anthropometry_day], [1_anthropometry_circumferences_calf], [1_anthropometry_circumferences_chest], [1_anthropometry_circumferences_hip], [1_anthropometry_circumferences_middle], [1_anthropometry_circumferences_navel], [1_anthropometry_circumferences_neck], [1_anthropometry_circumferences_thigh], [1_anthropometry_circumferences_upper_arm])\r\n([2_anthropometry_day], [2_anthropometry_circumferences_calf], [2_anthropometry_circumferences_chest], [2_anthropometry_circumferences_hip], [2_anthropometry_circumferences_middle], [2_anthropometry_circumferences_navel], [2_anthropometry_circumferences_neck], [2_anthropometry_circumferences_thigh], [2_anthropometry_circumferences_upper_arm])\r\n([3_anthropometry_day], [3_anthropometry_circumferences_calf], [3_anthropometry_circumferences_chest], [3_anthropometry_circumferences_hip], [3_anthropometry_circumferences_middle], [3_anthropometry_circumferences_navel], [3_anthropometry_circumferences_neck], [3_anthropometry_circumferences_thigh], [3_anthropometry_circumferences_upper_arm])\r\n([4_anthropometry_day], [4_anthropometry_circumferences_calf], [4_anthropometry_circumferences_chest], [4_anthropometry_circumferences_hip], [4_anthropometry_circumferences_middle], [4_anthropometry_circumferences_navel], [4_anthropometry_circumferences_neck], [4_anthropometry_circumferences_thigh], [4_anthropometry_circumferences_upper_arm])\r\n// The rest of the rows are added dynamically\r\n// You need only set the few above', 'Circumferences', 3, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"circumferences_calf\"},\"target_fields2\":{\"selection\":\"circumferences_chest\"},\"target_fields3\":{\"selection\":\"circumferences_hip\"},\"target_fields4\":{\"selection\":\"circumferences_middle\"},\"target_fields5\":{\"selection\":\"circumferences_navel\"},\"target_fields6\":{\"selection\":\"circumferences_neck\"},\"target_fields7\":{\"selection\":\"circumferences_thigh\"},\"target_fields8\":{\"selection\":\"circumferences_upper_arm\"}}', 'LineChart', '', '2018-10-04 21:51:48');
', '', 'Anthropometry (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'AMcPvMJWBRsUNjLuEwg9tYNEFkXRrfn6TMayKbUalW8=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 151, '', 1, 47), -(39, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2018-08-10 13:06:34', '', 'WFTndiFWqEP3VQCQ0AxC8lHxV2wt5zmqZd676/YNImU=', 'IyB+NbU+o4/3Gt/VDPtD3P5YYgkui9RLCYcrmKai5jk=', '', 'ajsiq1dXN27cjOsdcFpVk82R1tItqdc0+DPn4xBmlX8=', '', '', 'A_188', 2, '', 'Medical Aid Info', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_medicalaid', 'KCDC7tfGMQPxIWoQYwWHJri/Dv+uBt4wxLYKnbb4Aw/V5Jc0teUehHc+hK5gxg5a', '', 'a918111a-c0f8-40b6-9484-14a718222cec', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:56', 2, 'Medical Aid', 'medicalaid', '', 4, '', '', 'W0NVU1RPTUNPREU9bWVkaWNhbGFpZEhlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Medical Aid Info', '', '', 'Medical Aid (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'wbujqapJbtxhp5KMWAoAL0nuh47xUD0cYnzAC8Lisqk=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 38, '', 1, 20), -(40, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2015. All Rights Reserved', '2018-08-21 13:15:04', '', 'wqakjzYJsqZ4J0z8Ubf+/uGndhzVE9VNr7qzCAcZxms=', '9Qfx4NouLwPCAleYwuyiyl4G3dOIJ2Z63XVDJyJyWDU=', '', 'jPr2Qo+KKztte9yW4/Lkm/3YQIaRdwZf2odiXY1EWww=', '', '', 'A_189', 2, '', 'Contact Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_contactdetails', 'Opdm097HIpeBhw8ceGrCBNLj3DH4qurxw6Cq/NIiQK9hEBr39lcEych/zvStB//ZE48LM8NjZ1k56VIxMLUr8w==', '', '4b11bb3d-fabf-4e7b-a61a-2777ac58f2d1', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:52', 2, 'Contact', 'contactdetails', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29udGFjdGRldGFpbHNIZWxwZXJCb3RoXQ==', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Contact Details', '', '', 'Contact Details (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'NAm0jkpCAyIQBpz1KePHBQNvgSmi3dCvevy91gyPOaM=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 40, '', 1, 46), -(41, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2015. All Rights Reserved', '2018-08-21 19:33:15', '', '9M+/Gjj00W7CZV5jgGmCKquJuUQb2thGxeT9+oVPJCQ=', 'YV5sZj5kK2MugOfwacI+zlMqpvxVUULI2jzGvKhjfb8=', '', '4aUyispvHA6idDSZH2HhZH+y+BdOTFcXoaWNjVA16xA=', '', '', 'A_190', 2, '', 'Personal Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_personaldetails', '/bw9MqxWvsKcP5ob3e+EXyxycrzNrbHH6RvL6rkYypQ0OUjncUIgCwsTxItFSYPdosA6WY+rT9RW6khunqSS9Q==', '', 'e6583709-0244-4d3a-807e-191e0f4a38f5', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:49', 2, 'Personal', 'personaldetails', '', 4, '', '', 'W0NVU1RPTUNPREU9cGVyc29uYWxkZXRhaWxzSGVscGVyQm90aF0=', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Personal Details', '', '', 'Personal Details (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', '9fJdT9+z3MMBT3JP/g8TBiv8yjoeWtZncrzm5Tlaa6Y=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 37, '', 1, 45), -(42, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2015. All Rights Reserved', '2018-09-12 00:41:47', '', 'tsbYVAclNERm1P8eqajX42R8Kbtmr6IUY5pnPNK7Myk=', '0GasKfzV/E7i5pzYhOyNPTbtF3G1aIIw9rTQc2TxDxw=', '', 'd5JzN7wmc7Z45uLmxvB/VaWD273BbnWGzcX/8Y48g2E=', '', '', 'A_193', 2, '', 'Doctor Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_doctordetails', 'FMIbYsaxQuRN2zWW9kKIg8E1wS2ZHpO8WwYnHxYZ8/XQaQ1IbaMprFLGolaP6dAbisgWMy+MyIMusJsLCuMp8w==', '', '7f8d6250-0847-4c9e-94f2-a763c2b92916', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:39:19', 2, 'Doctor', 'doctordetails', '', 4, '', '', 'W0NVU1RPTUNPREU9ZG9jdG9yZGV0YWlsc0hlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Doctor Details', '', '', 'Doctor Details (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', '7znurjprij+BlsXeCIs1X9qJN3hWKlIndblN0kQODKs=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 17, '', 1, 44), -(43, '', '', '', '', 1, '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.5', 'Copyright (C) 2015. All Rights Reserved', '2018-09-12 19:55:57', '', 'lVh4+h/JdcdCsM3P8kN5rga7qPxsad0Upvtg1c5tAaY=', 'TnqxzaYo3URMy9ERxS5oceROiGJ1j9bXoKvSl+89LFU=', '', 'pkfWlOLugsjdtcw61qCPc3SO5GsoYv28sla7akR47bI=', '', '', '', 1, '', 'Communicate', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_communicate', 'cm0Oae7wqQ7/T9g9jCTeZFq59QfbS3mtozQAfcyn/78AdUIytw7wJEK/PlElD1NyMb7wmx/hTI6pJ/l5+8w22g==', '', '4b980308-89af-4197-9806-74db00409630', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:32', 2, 'Communicate', 'communicate', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29tbXVuaWNhdGVIZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Communicate', '', '', 'Communicate (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'rrLXYfJQAdN+hwWEWgnKC3FkonVlvTuKS+atUkJvQkQ=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 55, '', 1, 43), -(44, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2015. All Rights Reserved', '2018-10-09 16:09:37', '', 'zyzQlJpk6sNhrkRgaomXxwY8XIIGpowvew7Oxv9MpfY=', '+ekjDgmY0soLJ4cWC7dlPMV4kZyIbyi4Sm5u7MD3Wds=', '', 'iWFsbz05JeFtBV83U1KslTdA+dwovh7BanK7iD9VVKY=', '', '', 'A_198', 2, '', 'Fitness Test', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_fitnesstest', 'Y7w/ZptPLhfcWIv4bKaIkmYHw07wrf9hjbF145UB0uR8lQ1CfLhQhI27vhUjSlA54KC9pFOTD3Ae2+CU/MCO9g==', '', '718b6c81-471b-49c7-b24d-d8fb526b0eff', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:28', 2, 'Fitness Test', 'fitnesstest', '', 4, '', '', 'W0NVU1RPTUNPREU9Zml0bmVzc3Rlc3RIZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Fitness Test', '--
-- Dumping data for table `#__[[[component]]]_status_norm`
--

INSERT INTO `#__[[[component]]]_status_norm` (`id`, `calculation_type`, `calculations`, `selection`, `templates`, `published`, `created`) VALUES
(1, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"53\"},\"calculations1\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"50\"},\"calculations2\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"44\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"39\"},\"calculations4\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"35\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"58\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"55\"},\"calculations7\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"49\"},\"calculations8\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"44\"},\"calculations9\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"39\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"60\"},\"calculations11\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"56\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"51\"},\"calculations13\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"46\"},\"calculations14\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"40\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"62\"},\"calculations16\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"59\"},\"calculations17\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"54\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"48\"},\"calculations19\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"42\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"67\"},\"calculations21\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"63\"},\"calculations22\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"59\"},\"calculations23\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"55\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"50\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"47\"},\"calculations26\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"40\"},\"calculations27\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"34\"},\"calculations28\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"30\"},\"calculations29\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"23\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"52\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"45\"},\"calculations32\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"40\"},\"calculations33\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"34\"},\"calculations34\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"26\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"55\"},\"calculations36\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"47\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"42\"},\"calculations38\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"37\"},\"calculations39\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"28\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"58\"},\"calculations41\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"49\"},\"calculations42\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"44\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"40\"},\"calculations44\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"31\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"64\"},\"calculations46\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"55\"},\"calculations47\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"49\"},\"calculations48\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"44\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"37\"}}', 'partial_curl_ups', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 19:56:59'),
(2, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"18\"},\"calculations1\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"12\"},\"calculations2\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"8\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"7\"},\"calculations4\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"3\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"21\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"16\"},\"calculations7\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"11\"},\"calculations8\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations9\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"4\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"27\"},\"calculations11\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"22\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"16\"},\"calculations13\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"15\"},\"calculations14\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"9\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"34\"},\"calculations16\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"28\"},\"calculations17\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"19\"},\"calculations19\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"14\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"37\"},\"calculations21\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"31\"},\"calculations22\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"24\"},\"calculations23\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"21\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"15\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"23\"},\"calculations26\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"18\"},\"calculations27\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"12\"},\"calculations28\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations29\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"7\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"26\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"23\"},\"calculations32\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"14\"},\"calculations33\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"12\"},\"calculations34\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"8\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"33\"},\"calculations36\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"27\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations38\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"17\"},\"calculations39\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"15\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"43\"},\"calculations41\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"34\"},\"calculations42\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"28\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"23\"},\"calculations44\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"21\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"49\"},\"calculations46\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"40\"},\"calculations47\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"32\"},\"calculations48\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"26\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"23\"}}', 'push_ups', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 19:58:45'),
(3, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"23\"},\"calculations1\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"18\"},\"calculations2\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"12\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations4\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"7\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"26\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"23\"},\"calculations7\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"14\"},\"calculations8\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"12\"},\"calculations9\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"8\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"33\"},\"calculations11\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"27\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations13\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"17\"},\"calculations14\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"15\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"43\"},\"calculations16\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"34\"},\"calculations17\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"28\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"23\"},\"calculations19\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"21\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"49\"},\"calculations21\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"40\"},\"calculations22\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"32\"},\"calculations23\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"26\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"23\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"18\"},\"calculations26\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"12\"},\"calculations27\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"8\"},\"calculations28\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"7\"},\"calculations29\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"3\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"21\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"16\"},\"calculations32\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"11\"},\"calculations33\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations34\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"4\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"27\"},\"calculations36\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"22\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"16\"},\"calculations38\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"15\"},\"calculations39\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"9\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"34\"},\"calculations41\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"28\"},\"calculations42\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"19\"},\"calculations44\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"14\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"37\"},\"calculations46\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"31\"},\"calculations47\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"24\"},\"calculations48\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"21\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"15\"}}', 'pull_ups', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:08:31'),
(4, 2, '{\"calculations49\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 20\"},\"calculations50\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"21, 40\"},\"calculations51\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"41, 60\"},\"calculations52\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"61, 80\"},\"calculations53\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"81, 100\"},\"calculations54\":{\"target\":\"5\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"101, 300\"}}', 'bridge_side_left', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates5\":{\"target\":\"5\",\"word\":\"Superior\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Superior<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:14:50'),
(5, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 20\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"21, 40\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"41, 60\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"61, 80\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"81, 100\"},\"calculations5\":{\"target\":\"5\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"101, 300\"}}', 'bridge_side_right', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates5\":{\"target\":\"5\",\"word\":\"Superior\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Superior<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:29:07'),
(6, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 30\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"31, 60\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"61, 90\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"91, 119\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"120, 149\"},\"calculations5\":{\"target\":\"5\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"150, 300\"}}', 'front_bridge', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates5\":{\"target\":\"5\",\"word\":\"Superior\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Superior<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:30:38'),
(7, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 83\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"84, 94\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"95, 102\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"103, 112\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"113, 300\"}}', 'grip_strength_total', '{\"templates5\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates6\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates7\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates8\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates9\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:33:41'),
(8, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 91\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"91, 125\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"126, 176\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"177, 208\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"209, 300\"}}', 'back_strength', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:38:52'),
(9, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"-50, -8\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"-7, -1\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0, 5\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"6, 16\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"17, 100\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"-50, -7\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"-6, -1\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0, 10\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"11, 20\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"21, 100\"}}', 'sit_reach', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 22:17:06');

--
-- Dumping data for table `#__[[[component]]]_chart`
--

INSERT INTO `#__[[[component]]]_chart` (`id`, `details`, `javascript_table`, `name`, `number`, `target`, `target_fields`, `type`, `published`, `created`) VALUES
(1, '{\"dataTable\":{\"cols\":[{\"label\":\"Stage\",\"type\":\"string\"},{\"label\":\"Heart Rate\",\"type\":\"number\"},{\"label\":\"Systolic Blood Pressure\",\"type\":\"number\"},{\"label\":\"Diastolic Blood Pressure\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"Rest\"},{\"v\":72},{\"v\":43},{\"v\":53}]},{\"c\":[{\"v\":\"@ 25 Watt\"},{\"v\":89},{\"v\":53},{\"v\":63}]},{\"c\":[{\"v\":\"@ 50 Watt\"},{\"v\":93},{\"v\":63},{\"v\":73}]},{\"c\":[{\"v\":\"@ 75 Watt\"},{\"v\":92},{\"v\":63},{\"v\":73}]},{\"c\":[{\"v\":\"Final - 3 min rest\"},{\"v\":78},{\"v\":54},{\"v\":58}]}]},\"options\":{\"focusTarget\":\"category\",\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null},\"legacyScatterChartLabels\":true,\"legend\":\"in\",\"theme\":\"maximized\",\"title\":\"YMCA\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"curveType\":\"function\",\"booleanRole\":\"certainty\",\"lineWidth\":2,\"width\":600,\"height\":371},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '([fitnesstest_label_ymca_stage], [fitnesstest_label_ymca_heart_rate], [fitnesstest_label_ymca_systolic_blood_pressure], [fitnesstest_label_ymca_diastolic_blood_pressure])\r\n([fitnesstest_template_ymca_stage_one], [fitnesstest_ymca_heart_rate_one], [fitnesstest_ymca_systolic_blood_pressure_one], [fitnesstest_ymca_diastolic_blood_pressure_one])\r\n[IF fitnesstest_ymca_stage_two]([fitnesstest_template_ymca_stage_two], [fitnesstest_ymca_heart_rate_two], [fitnesstest_ymca_systolic_blood_pressure_two], [fitnesstest_ymca_diastolic_blood_pressure_two])[ENDIF]\r\n[IF fitnesstest_ymca_stage_three]([fitnesstest_template_ymca_stage_three], [fitnesstest_ymca_heart_rate_three], [fitnesstest_ymca_systolic_blood_pressure_three], [fitnesstest_ymca_diastolic_blood_pressure_three])[ENDIF]\r\n[IF fitnesstest_ymca_stage_four]([fitnesstest_template_ymca_stage_four], [fitnesstest_ymca_heart_rate_four], [fitnesstest_ymca_systolic_blood_pressure_four], [fitnesstest_ymca_diastolic_blood_pressure_four])[ENDIF]\r\n[IF fitnesstest_ymca_stage_five]([fitnesstest_template_ymca_stage_five], [fitnesstest_ymca_heart_rate_five], [fitnesstest_ymca_systolic_blood_pressure_five], [fitnesstest_ymca_diastolic_blood_pressure_five])[ENDIF]\r\n[IF fitnesstest_ymca_stage_six]([fitnesstest_template_ymca_stage_six], [fitnesstest_ymca_heart_rate_six], [fitnesstest_ymca_systolic_blood_pressure_six], [fitnesstest_ymca_diastolic_blood_pressure_six])[ENDIF]\r\n[IF fitnesstest_ymca_stage_seven]([fitnesstest_template_ymca_stage_seven], [fitnesstest_ymca_heart_rate_seven], [fitnesstest_ymca_systolic_blood_pressure_seven], [fitnesstest_ymca_diastolic_blood_pressure_seven])[ENDIF]\r\n[IF fitnesstest_ymca_stage_eight]([fitnesstest_template_ymca_stage_eight], [fitnesstest_ymca_heart_rate_eight], [fitnesstest_ymca_systolic_blood_pressure_eight], [fitnesstest_ymca_diastolic_blood_pressure_eight])[ENDIF]\r\n[IF fitnesstest_ymca_stage_nine]([fitnesstest_template_ymca_stage_nine], [fitnesstest_ymca_heart_rate_nine], [fitnesstest_ymca_systolic_blood_pressure_nine], [fitnesstest_ymca_diastolic_blood_pressure_nine])[ENDIF]\r\n[IF fitnesstest_ymca_stage_ten]([fitnesstest_template_ymca_stage_ten], [fitnesstest_ymca_heart_rate_ten], [fitnesstest_ymca_systolic_blood_pressure_ten], [fitnesstest_ymca_diastolic_blood_pressure_ten])[ENDIF]\r\n[IF fitnesstest_ymca_stage_eleven]([fitnesstest_template_ymca_stage_eleven], [fitnesstest_ymca_heart_rate_eleven], [fitnesstest_ymca_systolic_blood_pressure_eleven], [fitnesstest_ymca_diastolic_blood_pressure_eleven])[ENDIF]\r\n[IF fitnesstest_ymca_stage_twelve]([fitnesstest_template_ymca_stage_twelve], [fitnesstest_ymca_heart_rate_twelve], [fitnesstest_ymca_systolic_blood_pressure_twelve], [fitnesstest_ymca_diastolic_blood_pressure_twelve])[ENDIF]\r\n[IF fitnesstest_ymca_stage_thirteen]([fitnesstest_template_ymca_stage_thirteen], [fitnesstest_ymca_heart_rate_thirteen], [fitnesstest_ymca_systolic_blood_pressure_thirteen], [fitnesstest_ymca_diastolic_blood_pressure_thirteen])[ENDIF]\r\n[IF fitnesstest_ymca_stage_fourteen]([fitnesstest_template_ymca_stage_fourteen], [fitnesstest_ymca_heart_rate_fourteen], [fitnesstest_ymca_systolic_blood_pressure_fourteen], [fitnesstest_ymca_diastolic_blood_pressure_fourteen])[ENDIF]', 'YMCA', 3, 1, '{\"target_fields0\":{\"selection\":\"ymca_stage_one\"}}', 'LineChart', 1, '2018-10-11 22:53:18'),
(2, '{\"dataTable\":{\"cols\":[{\"label\":\"Stage\",\"type\":\"string\"},{\"label\":\"Heart Rate\",\"type\":\"number\"},{\"label\":\"Systolic Blood Pressure\",\"type\":\"number\"},{\"label\":\"Diastolic Blood Pressure\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"Rest\"},{\"v\":72},{\"v\":64},{\"v\":54}]},{\"c\":[{\"v\":\"@ 10 Watt\"},{\"v\":83},{\"v\":67},{\"v\":57}]},{\"c\":[{\"v\":\"@ 12 Watt\"},{\"v\":90},{\"v\":69},{\"v\":59}]},{\"c\":[{\"v\":\"@ 14 Watt\"},{\"v\":94},{\"v\":69},{\"v\":60}]},{\"c\":[{\"v\":\"Final - 3 min rest\"},{\"v\":79},{\"v\":64},{\"v\":57}]}]},\"options\":{\"annotations\":{\"domain\":{}},\"hAxis\":{\"useFormatFromData\":true,\"viewWindow\":null,\"minValue\":null,\"maxValue\":null,\"viewWindowMode\":null},\"legacyScatterChartLabels\":true,\"legend\":\"in\",\"title\":\"Bruce\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"isStacked\":false,\"booleanRole\":\"certainty\",\"width\":600,\"height\":371,\"useFirstColumnAsDomain\":false,\"theme\":\"maximized\",\"focusTarget\":\"category\",\"series\":{\"0\":{\"color\":\"#e06666\"},\"1\":{\"color\":\"#e69138\"},\"2\":{\"color\":\"#85200c\"}}},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"ColumnChart\"}', '([fitnesstest_label_bruce_stage], [fitnesstest_label_bruce_heart_rate], [fitnesstest_label_bruce_systolic_blood_pressure], [fitnesstest_label_bruce_diastolic_blood_pressure])\r\n([fitnesstest_template_bruce_stage_one], [fitnesstest_bruce_heart_rate_one], [fitnesstest_bruce_systolic_blood_pressure_one], [fitnesstest_bruce_diastolic_blood_pressure_one])\r\n[IF fitnesstest_bruce_stage_two]([fitnesstest_template_bruce_stage_two], [fitnesstest_bruce_heart_rate_two], [fitnesstest_bruce_systolic_blood_pressure_two], [fitnesstest_bruce_diastolic_blood_pressure_two])[ENDIF]\r\n[IF fitnesstest_bruce_stage_three]([fitnesstest_template_bruce_stage_three], [fitnesstest_bruce_heart_rate_three], [fitnesstest_bruce_systolic_blood_pressure_three], [fitnesstest_bruce_diastolic_blood_pressure_three])[ENDIF]\r\n[IF fitnesstest_bruce_stage_four]([fitnesstest_template_bruce_stage_four], [fitnesstest_bruce_heart_rate_four], [fitnesstest_bruce_systolic_blood_pressure_four], [fitnesstest_bruce_diastolic_blood_pressure_four])[ENDIF]\r\n[IF fitnesstest_bruce_stage_five]([fitnesstest_template_bruce_stage_five], [fitnesstest_bruce_heart_rate_five], [fitnesstest_bruce_systolic_blood_pressure_five], [fitnesstest_bruce_diastolic_blood_pressure_five])[ENDIF]\r\n[IF fitnesstest_bruce_stage_six]([fitnesstest_template_bruce_stage_six], [fitnesstest_bruce_heart_rate_six], [fitnesstest_bruce_systolic_blood_pressure_six], [fitnesstest_bruce_diastolic_blood_pressure_six])[ENDIF]\r\n[IF fitnesstest_bruce_stage_seven]([fitnesstest_template_bruce_stage_seven], [fitnesstest_bruce_heart_rate_seven], [fitnesstest_bruce_systolic_blood_pressure_seven], [fitnesstest_bruce_diastolic_blood_pressure_seven])[ENDIF]\r\n[IF fitnesstest_bruce_stage_eight]([fitnesstest_template_bruce_stage_eight], [fitnesstest_bruce_heart_rate_eight], [fitnesstest_bruce_systolic_blood_pressure_eight], [fitnesstest_bruce_diastolic_blood_pressure_eight])[ENDIF]', 'Bruce', 3, 1, '{\"target_fields0\":{\"selection\":\"bruce_stage_one\"}}', 'ColumnChart', 1, '2018-10-11 23:28:17'),
(3, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"VO\\u2082max\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/12\"},{\"v\":170.567}]},{\"c\":[{\"v\":\"2018/10/11\"},{\"v\":163.146}]}]},\"options\":{\"title\":\"Vo2max\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"legacyScatterChartLabels\":true,\"curveType\":\"function\",\"booleanRole\":\"certainty\",\"lineWidth\":2,\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null},\"legend\":\"none\",\"width\":600,\"height\":371,\"domainAxis\":{\"direction\":1},\"theme\":\"maximized\",\"interpolateNulls\":true,\"series\":{\"0\":{\"color\":\"#a64d79\"}}},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '([fitnesstest_label_day], [fitnesstest_label_vo2max])\r\n([0_fitnesstest_day], [0_fitnesstest_vo2max])\r\n([1_fitnesstest_day], [1_fitnesstest_vo2max])\r\n([2_fitnesstest_day], [2_fitnesstest_vo2max]])\r\n([3_fitnesstest_day], [3_fitnesstest_vo2max])\r\n([4_fitnesstest_day], [4_fitnesstest_vo2max])', 'Vo2max', 3, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"vo2max\"}}', 'LineChart', 1, '2018-10-12 13:48:13');', '', 'Fitness Test (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'oih1GS9YYhu8cGMLn9xdQT8PVllZ0camYBjEYbHqsgQ=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 52, '', 1, 50), -(45, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2018-10-15 14:33:08', '', 'jKdfyoOPNLF1n3ZHp1Cb7IW4Lu13zO36e33wI/y7Ry4=', 'r7A8hbtLv0B/VHRfBtCmH5xvRq9j7PT7gz5PI6F/FP0=', '', '2dMIdzUuuZZ4g2G2DHEU74//Y4HkGUR+QOqQx9iFeLw=', '', '', 'A_199', 2, '', 'Bankable Projects', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_bankableprojects', 'kTcbfJRadrKm5MThXCqdHwpHH91ugchmvlgPE7biwFlFyD6m7Ccne2MzU3fh39KIEXq2Yu6Avl20OtlKBi3Pyw==', '', '3ed2025c-f489-44e4-9cc1-cf033a57b061', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:25', 2, 'Bankable Projects', 'bankableprojects', '', 4, '', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	 * Add Join Tables based on filter
	 *
	 * @param   object   $query  The database query object
	 * @param   string   $filter  The target area that made the request
	 *
	 * @return array
	 *
	 */
	protected static function joinFormDetails(&$query, $filter = 'none', $db = null)
	{
		// check if we have the DB object
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
		{
			// get the database object
			$db = Factory::getDBO();
		}
		// From the [[[component]]]_type table.
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_type', 't') . ' ON (' . $db->quoteName('a.type') . ' = ' . $db->quoteName('t.id') . ')');
	}

	/**
	 * Add order based on filter
	 *
	 * @param   object   $query  The database query object
	 * @param   string   $filter  The target area that made the request
	 * @param   object   $db     The database object
	 *
	 * @return void
	 *
	 */
	protected static function orderFormDetails(&$query, $filter = 'none', $db = null)
	{
		// check if we have the DB object
		// if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
		// {
			// get the database object
		// 	$db = Factory::getDBO();
		// }
		// the default order is by create date
		$query->order('a.created DESC'); // to insure last shows first
	}

	/**
	 * Get selection  based on type
	 *
	 * @param   string   $table     The main table to select
	 * @param   string   $method    The type of values to return
	 * @param   string   $filter    The kind of filter (to return only values required)
	 * @param   object   $db     The database object
	 *
	 * @return array
	 *
	 */
	public static function getSelection($table = 'form', $method = 'placeholder', $filter = 'none', $db = null)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// prep for placeholders
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			// get the placeholder prefix
			$prefix = self::$params->get('placeholder_prefix', '[[[component]]]');
			$f = '[' . $prefix . '_';
			$b = ']';
		}
		// get status norm fields
		if (method_exists(__CLASS__, 'getStatusNormFields'))
		{
			$norms = self::getStatusNormFields();
		}
		// get charts
		if ('chart' !== $filter && 'field' !== $filter && method_exists(__CLASS__, 'getAvailableCharts'))
		{
			$charts = self::getAvailableCharts();
		}
		// only get what we need
		if ('profile' === $filter)
		{
			// get the fields/columns
			$columns = array('id', 'created', 'modified', 'name');
		}
		// set the values you want to remove after modeling
		elseif ('remove' === $filter)
		{
			// remove params always
			$remove = array($f . 'params' . $b);
			// remove the norms if found
			if (isset($norms) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($norms))
			{
				foreach ($norms as $norm)
				{
					$remove[] = $f . 'status_' . $norm . $b;
				}
			}
			return $remove;
		}
		else
		{
			// check if we have the DB object
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
			{
				// get the database object
				$db = Factory::getDBO();
			}
			// get the database columns of this table
			$columns = $db->getTableColumns("#__[[[component]]]_" . $table, false);
			// always remove these
			$remove = array('asset_id', 'checked_out', 'checked_out_time');
			// if placeholder and none filter then remove some more
			if ('placeholder' === $method && ('report' === $filter || 'email' === $filter))
			{
				$remove[] = 'access';
				$remove[] = 'created_by';
				$remove[] = 'ordering';
				$remove[] = 'version';
				$remove[] = 'params';
				$remove[] = 'published';
				$remove[] = 'modified_by';
				$remove[] = 'modified';
				$remove[] = 'hits';
			}
			// remove
			foreach ($remove as $key)
			{
				unset($columns[$key]);
			}
			// prep the columns
			$columns = array_keys($columns);
		}
		// make sure we have columns
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($columns))
		{
			// convert the columns for query selection
			$selection = array();
			foreach ($columns as $column)
			{
				$selection['a.' . $column] = $f . $column . $b;
				// we must add the params
				if ('profile' !== $filter && 'field' !== $filter)
				{
					// set the label for these fields
					$selection['setLabel->' . $column] = $f . 'label_' . $column . $b;
				}
			}
			// add the linked values
			$selection['t.name'] = $f . 'type_name' . $b;
			// we must add the params
			if ('profile' !== $filter)
			{
				// do some conversion for created date
				if (in_array('created', $columns))
				{
					$selection['setYearMonthDay:created'] = $f . 'day' . $b;
					$selection['setYearMonth:created'] = $f . 'month' . $b;
					$selection['fancyDate:created'] = $f . 'created' . $b;
					// set label for day and month
					$selection['setLabel->day'] = $f . 'label_day' . $b;
					$selection['setLabel->month'] = $f . 'label_month' . $b;
				}
				// add the norms if found
				if (isset($norms) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($norms))
				{
					foreach ($norms as $norm)
					{
						if ('email' === $filter || 'report' === $filter || 'field' === $filter  || 'chart' === $filter)
						{
							$selection['getValueStatus:' . $norm. '|age|gender'] = $f . 'status_' . $norm . $b;
						}
						// do not load for field
						if ('field' !== $filter && 'chart' !== $filter)
						{
							$selection[] = $f . 'status_' . $norm. '_scale' . $b;
							$selection[] = $f . 'status_' . $norm. '_word' . $b;
							$selection[] = $f . 'status_' . $norm. '_table' . $b;
						}
					}
				}
				// add the chart div and JS code (only if filter is not chart)
				if ('chart' !== $filter && 'field' !== $filter && isset($charts) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($charts))
				{
					foreach ($charts as $chart => $values)
					{
						// make sure the chart name is save
						$selection['setChartCode->' . $chart] = $f . $chart . $b;
					}
				}
			}
			return $selection;
		}
		return false;
	}
[CUSTOMCODE=getPlaceHoldersReport]
[CUSTOMCODE=getValueStatus]
[CUSTOMCODE=getStatusNormFields]
[CUSTOMCODE=getChartCode]
[CUSTOMCODE=getAvailableCharts]
[CUSTOMCODE=getMultiChartDataTable]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=getTemplate]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getANYTemplate+Any]
[CUSTOMCODE=getANYFormDetails+Any]
[CUSTOMCODE=getANYCompanyDetails+Any]
[CUSTOMCODE=getANYDetails+form,Form]
[CUSTOMCODE=modelANYDetails+form,Form]
[CUSTOMCODE=paramsModelANYDetails+form,Form]
[CUSTOMCODE=labelModelANYDetails+form,Form]
[CUSTOMCODE=templateModelANYDetails+form,Form]
[CUSTOMCODE=chartModelANYDetails+form,Form]
[CUSTOMCODE=removeANYDetails+form,Form]
[CUSTOMCODE=loadReportTab]
[CUSTOMCODE=getReport]
[CUSTOMCODE=theButler]
[CUSTOMCODE=setTab]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=bcmath]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=getBetween]
[CUSTOMCODE=getCoreName]', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Bankable Projects', '', '', 'Bankable Projects (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'hf7yYVzaVFQ2UsPUbb+lb+2Xx79x7DKbXnLblPnk4ko=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 16, '', 1, 22), -(46, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2018-11-24 01:54:02', '', 'PDKvQr1omtxg1PHpAFU3HiVLe70cToFa/9eg87wOf3w=', 'o/rDMwNXBeOLEXJ0o9JpkhHeastC8pZ5hME9gq1JriQ=', '', 'fU3WMu9a1djTuX5mAz5t1mu/amTPpqmJmchvOzS/vTQ=', '', '', 'A_201', 2, '', 'Donor Funded Projects', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_donorfundedprojects', 'eVfE2ScgVPJ8DhBaw8UfCZbXbk/Sr8BR/ln+Mj3CYKoAZ1/lNB2mFx8IVIOc/VvZMjxKHPQDbrlNUwia8N4Mkg==', '', '92181cd8-81a3-448c-b4df-adc0e93c84f9', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2020-07-28 00:37:22', 2, 'Donor Funded Projects', 'donorfundedprojects', '', 4, '', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	 * Add Join Tables based on filter
	 *
	 * @param   object   $query  The database query object
	 * @param   string   $filter  The target area that made the request
	 *
	 * @return array
	 *
	 */
	protected static function joinFormDetails(&$query, $filter = 'none', $db = null)
	{
		// check if we have the DB object
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
		{
			// get the database object
			$db = Factory::getDBO();
		}
		// From the [[[component]]]_sector table.
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_sector', 's') . ' ON (' . $db->quoteName('a.sector') . ' = ' . $db->quoteName('s.id') . ')');
		// From the [[[component]]]_department table.
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_department', 'd') . ' ON (' . $db->quoteName('a.department') . ' = ' . $db->quoteName('d.id') . ')');
	}

	/**
	 * Add order based on filter
	 *
	 * @param   object   $query  The database query object
	 * @param   string   $filter  The target area that made the request
	 * @param   object   $db     The database object
	 *
	 * @return void
	 *
	 */
	protected static function orderFormDetails(&$query, $filter = 'none', $db = null)
	{
		// check if we have the DB object
		// if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
		// {
			// get the database object
		// 	$db = Factory::getDBO();
		// }
		// the default order is by create date
		$query->order('a.created DESC'); // to insure last shows first
	}

	/**
	 * Get selection  based on type
	 *
	 * @param   string   $table     The main table to select
	 * @param   string   $method    The type of values to return
	 * @param   string   $filter    The kind of filter (to return only values required)
	 * @param   object   $db     The database object
	 *
	 * @return array
	 *
	 */
	public static function getSelection($table = 'form', $method = 'placeholder', $filter = 'none', $db = null)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// prep for placeholders
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			// get the placeholder prefix
			$prefix = self::$params->get('placeholder_prefix', '[[[component]]]');
			$f = '[' . $prefix . '_';
			$b = ']';
		}
		// get status norm fields
		if (method_exists(__CLASS__, 'getStatusNormFields'))
		{
			$norms = self::getStatusNormFields();
		}
		// get charts
		if ('chart' !== $filter && 'field' !== $filter && method_exists(__CLASS__, 'getAvailableCharts'))
		{
			$charts = self::getAvailableCharts();
		}
		// only get what we need
		if ('profile' === $filter)
		{
			// get the fields/columns
			$columns = array('id', 'created', 'modified', 'name');
		}
		// set the values you want to remove after modeling
		elseif ('remove' === $filter)
		{
			// remove params always
			$remove = array($f . 'params' . $b);
			// remove the norms if found
			if (isset($norms) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($norms))
			{
				foreach ($norms as $norm)
				{
					$remove[] = $f . 'status_' . $norm . $b;
				}
			}
			return $remove;
		}
		else
		{
			// check if we have the DB object
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
			{
				// get the database object
				$db = Factory::getDBO();
			}
			// get the database columns of this table
			$columns = $db->getTableColumns("#__[[[component]]]_" . $table, false);
			// always remove these
			$remove = array('asset_id', 'checked_out', 'checked_out_time');
			// if placeholder and none filter then remove some more
			if ('placeholder' === $method && ('report' === $filter || 'email' === $filter))
			{
				$remove[] = 'access';
				$remove[] = 'created_by';
				$remove[] = 'ordering';
				$remove[] = 'version';
				$remove[] = 'params';
				$remove[] = 'published';
				$remove[] = 'modified_by';
				$remove[] = 'modified';
				$remove[] = 'hits';
			}
			// remove
			foreach ($remove as $key)
			{
				unset($columns[$key]);
			}
			// prep the columns
			$columns = array_keys($columns);
		}
		// make sure we have columns
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($columns))
		{
			// convert the columns for query selection
			$selection = array();
			foreach ($columns as $column)
			{
				$selection['a.' . $column] = $f . $column . $b;
				// we must add the params
				if ('profile' !== $filter && 'field' !== $filter)
				{
					// set the label for these fields
					$selection['setLabel->' . $column] = $f . 'label_' . $column . $b;
				}
			}
			// add the linked values
			$selection['s.name'] = $f . 'sector_name' . $b;
			$selection['d.name'] = $f . 'department_name' . $b;
			// set date details
			$selection['setYearMonthDay:start_date'] = $f . 'start_date' . $b;
			$selection['fancyDate:start_date'] = $f . 'start_date_fancy' . $b;
			$selection['setYearMonthDay:end_date'] = $f . 'end_date' . $b;
			$selection['fancyDate:end_date'] = $f . 'end_date_fancy' . $b;
			// we must add the params
			if ('profile' !== $filter)
			{
				// do some conversion for created date
				if (in_array('created', $columns))
				{
					$selection['setYearMonthDay:created'] = $f . 'day' . $b;
					$selection['setYearMonth:created'] = $f . 'month' . $b;
					$selection['fancyDate:created'] = $f . 'created' . $b;
					// set label for day and month
					$selection['setLabel->day'] = $f . 'label_day' . $b;
					$selection['setLabel->month'] = $f . 'label_month' . $b;
				}
				// add the norms if found
				if (isset($norms) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($norms))
				{
					foreach ($norms as $norm)
					{
						if ('email' === $filter || 'report' === $filter || 'field' === $filter  || 'chart' === $filter)
						{
							$selection['getValueStatus:' . $norm. '|age|gender'] = $f . 'status_' . $norm . $b;
						}
						// do not load for field
						if ('field' !== $filter && 'chart' !== $filter)
						{
							$selection[] = $f . 'status_' . $norm. '_scale' . $b;
							$selection[] = $f . 'status_' . $norm. '_word' . $b;
							$selection[] = $f . 'status_' . $norm. '_table' . $b;
						}
					}
				}
				// add the chart div and JS code (only if filter is not chart)
				if ('chart' !== $filter && 'field' !== $filter && isset($charts) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($charts))
				{
					foreach ($charts as $chart => $values)
					{
						// make sure the chart name is save
						$selection['setChartCode->' . $chart] = $f . $chart . $b;
					}
				}
			}
			return $selection;
		}
		return false;
	}
[CUSTOMCODE=getPlaceHoldersReport]
[CUSTOMCODE=getValueStatus]
[CUSTOMCODE=getStatusNormFields]
[CUSTOMCODE=getChartCode]
[CUSTOMCODE=getAvailableCharts]
[CUSTOMCODE=getMultiChartDataTable]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=getTemplate]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getANYTemplate+Any]
[CUSTOMCODE=getANYFormDetails+Any]
[CUSTOMCODE=getANYCompanyDetails+Any]
[CUSTOMCODE=getANYDetails+form,Form]
[CUSTOMCODE=modelANYDetails+form,Form]
[CUSTOMCODE=paramsModelANYDetails+form,Form]
[CUSTOMCODE=labelModelANYDetails+form,Form]
[CUSTOMCODE=templateModelANYDetails+form,Form]
[CUSTOMCODE=chartModelANYDetails+form,Form]
[CUSTOMCODE=removeANYDetails+form,Form]
[CUSTOMCODE=loadReportTab]
[CUSTOMCODE=getReport]
[CUSTOMCODE=theButler]
[CUSTOMCODE=setTab]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=bcmath]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=getBetween]
[CUSTOMCODE=getCoreName]', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Donor Funded Projects', '', '', 'Donor Funded Projects (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', 'UHkXmtEshVPYiMOPHun5etxQVJbdE7TwsUOniDLGDxc=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 17, '', 1, 27), -(47, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.7', 'Copyright (C) 2015. All Rights Reserved', '2018-12-17 13:44:13', '', '8KogkX0DGBXFLjRn89PBVw2v6bCMxl5JIcLRfxHqT3Y=', 'xHj9/R0B7h0jJc5mEbKXDwLLkPl7x81sIgNH637pf1E=', '', 'doZjfO8o56YZAFsCxzC9M5qGBHw/VyEqchNxp95a0WQ=', '', '', 'A_202', 2, '', 'Orthopedic', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_orthopedic', '3YAVq4fIs4AGim5iRlAS0IjrkUkh3kXpVSkwMUaIMnm2tTtK0Hz5q54IWoKBgZKM', '', 'fd4ac451-6e52-4381-9f0a-f4b30681a38d', 'images/membermanager300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-03-08 03:21:21', 2, 'Orthopedic', 'orthopedic', '', 4, '', '', 'W0NVU1RPTUNPREU9b3J0aG9wZWRpY0hlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Orthopedic', 'LS0NCi0tIER1bXBpbmcgZGF0YSBmb3IgdGFibGUgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlYA0KLS0NCg0KSU5TRVJUIElOVE8gYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlYCAoYGlkYCwgYGFsaWFzYCwgYGRlc2NyaXB0aW9uYCwgYG5hbWVgLCBgcHVibGlzaGVkYCwgYGNyZWF0ZWRgKSBWQUxVRVMNCigxLCAnYWN0aXZlLXJhbmdlLW9mLW1vdGlvbicsICcnLCAnQWN0aXZlIFJhbmdlIG9mIE1vdGlvbicsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooMiwgJ2Z1bmN0aW9uYWwtbW92ZW1lbnRzJywgJycsICdGdW5jdGlvbmFsIE1vdmVtZW50cycsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooMywgJ21hbnVhbC1tdXNjbGUtdGVzdCcsICcnLCAnTWFudWFsIE11c2NsZSBUZXN0JywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCig0LCAnbXVzY2xlLWxlbmd0aCcsICcnLCAnTXVzY2xlIExlbmd0aCcsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooNSwgJ211c2NsZS1zdHJlbmd0aC10ZXN0JywgJycsICdNdXNjbGUgU3RyZW5ndGggVGVzdCcsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooNiwgJ211c2NsZS10ZXN0JywgJycsICdNdXNjbGUgVGVzdCcsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooNywgJ25ldXJvbG9naWNhbC1leGFtJywgJycsICdOZXVyb2xvZ2ljYWwgRXhhbScsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooOCwgJ3BhbHBhdGlvbicsICcnLCAnUGFscGF0aW9uJywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCig5LCAncGFzc2l2ZS1yYW5nZS1vZi1tb3Rpb24nLCAnJywgJ1Bhc3NpdmUgUmFuZ2Ugb2YgTW90aW9uJywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCigxMCwgJ3NwZWNpYWwtdGVzdCcsICcnLCAnU3BlY2lhbCBUZXN0JywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCigxMSwgJ3N0cmVuZ3RoLXRlc3QnLCAnJywgJ1N0cmVuZ3RoIFRlc3QnLCAxLCAnMjAxOC0xMi0xOCAyMzoyMDo0MycpOw==', '', 'Orthopedic (public)', '.git', '', '', 1, 'https://raw.githubusercontent.com/vdm-io/Joomla-Members-Manager/master/membersmanager_server.xml', 'http://www.vdm.io', '', '79hK57LOaEERbWSvsJ2uCUgeC2v7Y9XGr7uYTA9yCZw=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 38, '', 1, 26), -(48, 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, 1, '{}', 3, '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2019-02-04 21:30:52', 1, 'cNJiur6BS8xT5BJp6M0QouQXp9BIhMdOKI0f98GwqKM=', 'daG3mVWavTJSf9unuChgSHkKoxbbPYXKS3yT17wHVEA=', '', '3xiTEv9mFVpLvXpCi9vYbSxw0wIVHilpdD12oPdQn7E=', '', 'LmZpZWxkLWNhbGVuZGFyIGlucHV0IHsNCglmb250OmNhcHRpb24gIWltcG9ydGFudDsNCn0=', 'A_177', 2, '', 'Coral is a system of integration that allows many diverse concepts to co exist.', 'joomla@vdm.io', '', '', 'HqMQciOxsDF38VTMdkXa3SAfmSBbWgwwI2wOQzgUnehKN8RNjPlgKBfU5gjhnkm6oiYo8EPLiIXwktqPHmtJxGKzUOdckz3fXAkdO2Om9Fs=', '', '3ff9d8f6-11a0-4f2c-9353-1895cf5810fc', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '★', '2021-12-19 22:22:11', 2, 'Coral', 'coral', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9bWVtYmVybWFuYWdlckhlbHBlckJvdGhdDQpbQ1VTVE9NQ09ERT1jYW5BY2Nlc3NNZW1iZXJd', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'The Beauty of Integration', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGAgKA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTsNCg0KQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbl9tYXBgICgNCglgcmVsYXRpb25gIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTs=', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGA7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3JlbGF0aW9uX21hcGA7', 'Coral', '.git', '', 3, 1, 'https://io.vdm.dev/update/coral_update_server.xml', 'https://www.vdm.io/', '', 'lR119LmUKB2wvDxdXvkP8+HxiLXH6bUZvhgRgQ8mNh8=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"0\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"}}', 1, 15, '', 1, 25), -(49, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'joomla_basic.txt', '', '', 'Vast Development Method', '1.0.0', 'Copyright (C) 2020. All Rights Reserved', '2019-02-06 20:27:41', '', 'qi7pclcRmViYcJ3HlGS8Z4EO7WvLPMXdFbpOXaO0HKo=', 'UKpPHjDizbeiqz9bOeJZnawh0fBaqWzX2+KIu2eF0us=', '', '1YrQH07qqwW4vfxK3+/kjkA3y7NtHVjkFMBQzbX0Q2U=', '', '', 'A_86', 2, '', 'Company Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_companies', 'IvHgukl+ExbWtxnsb4w/CqY1HGvjhOPvKkJxIY/+9WcfamkxSaK3Vkbq4QudMA4K', '', 'e906966f-c8c8-412e-8e3f-5817b1fe756b', 'images/vdm/INTER500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⊛', '2021-03-08 03:17:57', 2, 'Company', 'tradeshow_company', '', 4, '', '', 'CS8qKg0KCSogdGhlIHBhcmFtcw0KCSoqLw0KCXByb3RlY3RlZCBzdGF0aWMgJHBhcmFtczsNCg0KCS8qKg0KCSAqIEdldCBzZWxlY3Rpb24gIGJhc2VkIG9uIHR5cGUNCgkgKg0KCSAqIEBwYXJhbSAgIHN0cmluZyAgICR0YWJsZSAgICAgVGhlIG1haW4gdGFibGUgdG8gc2VsZWN0DQoJICogQHBhcmFtICAgc3RyaW5nICAgJG1ldGhvZCAgICBUaGUgdHlwZSBvZiB2YWx1ZXMgdG8gcmV0dXJuDQoJICogQHBhcmFtICAgc3RyaW5nICAgJGZpbHRlciAgICBUaGUga2luZCBvZiBmaWx0ZXIgKHRvIHJldHVybiBvbmx5IHZhbHVlcyByZXF1aXJlZCkNCgkgKiBAcGFyYW0gICBvYmplY3QgICAkZGIgICAgIFRoZSBkYXRhYmFzZSBvYmplY3QNCgkgKg0KCSAqIEByZXR1cm4gYXJyYXkNCgkgKg0KCSAqLw0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0U2VsZWN0aW9uKCR0YWJsZSA9ICdmb3JtJywgJG1ldGhvZCA9ICdwbGFjZWhvbGRlcicsICRmaWx0ZXIgPSAnbm9uZScsICRkYiA9IG51bGwpDQoJew0KCQkvLyBnZXQgdGhlIGdsb2JhbCBzZXR0aW5ncw0KCQlpZiAoIVN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKHNlbGY6OiRwYXJhbXMpKQ0KCQl7DQoJCQlzZWxmOjokcGFyYW1zID0gSm9vbWxhX19fYWViOGU0NjNfMjkxZl80NDQ1XzlhYzRfMzRiNjM3YzEyZGJkX19fUG93ZXI6OmdldFBhcmFtcygnY29tX1tbW2NvbXBvbmVudF1dXScpOw0KCQl9DQoJCS8vIHByZXAgZm9yIHBsYWNlaG9sZGVycw0KCQkkZiA9ICcnOw0KCQkkYiA9ICcnOw0KCQlpZiAoJ3BsYWNlaG9sZGVyJyA9PT0gJG1ldGhvZCkNCgkJew0KCQkJLy8gZ2V0IHRoZSBwbGFjZWhvbGRlciBwcmVmaXgNCgkJCSRwcmVmaXggPSBzZWxmOjokcGFyYW1zLT5nZXQoJ3BsYWNlaG9sZGVyX3ByZWZpeCcsICdbW1tjb21wb25lbnRdXV0nKTsNCgkJCSRmID0gJ1snIC4gJHByZWZpeCAuICdfJzsNCgkJCSRiID0gJ10nOw0KCQl9DQoJCS8vIG9ubHkgZ2V0IHdoYXQgd2UgbmVlZA0KCQlpZiAoJ3Byb2ZpbGUnID09PSAkZmlsdGVyKQ0KCQl7DQoJCQkvLyBnZXQgdGhlIGZpZWxkcy9jb2x1bW5zDQoJCQlpZiAoKCRmaWVsZHMgPSBzZWxmOjokcGFyYW1zLT5nZXQoJ3Byb2ZpbGVfZmllbGRzJywgZmFsc2UpKSAhPT0gZmFsc2UgJiYgU3VwZXJfX185MTAwNDUyOV85NGE5XzQ1OTBfYjg0Ml9lN2M2YjYyNGVjZjVfX19Qb3dlcjo6Y2hlY2soJGZpZWxkcykpDQoJCQl7DQoJCQkJJGNvbHVtbnMgPSBhcnJheSgnaWQnKTsgLy8gbmVlZGVkIGZvciBwZXJtaXNzaW9uIGNoZWNrDQoJCQkJZm9yZWFjaCAoJGZpZWxkcyBhcyAkZmllbGQpDQoJCQkJew0KCQkJCQkkY29sdW1uc1tdID0gJGZpZWxkLT5maWVsZDsNCgkJCQl9DQoJCQkJLy8gYWRkIGRhdGVzIGZvciBkaXNwbGF5DQoJCQkJJGNvbHVtbnNbXSA9ICdjcmVhdGVkJzsNCgkJCQkkY29sdW1uc1tdID0gJ21vZGlmaWVkJzsNCgkJCX0NCgkJfQ0KCQkvLyBzZXQgdGhlIHZhbHVlcyB5b3Ugd2FudCB0byByZW1vdmUgYWZ0ZXIgbW9kZWxpbmcNCgkJZWxzZWlmICgncmVtb3ZlJyA9PT0gJGZpbHRlcikNCgkJew0KCQkJLy8gbm90aW5nIHRvIHJlbW92ZQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCWVsc2UNCgkJew0KCQkJLy8gY2hlY2sgaWYgd2UgaGF2ZSB0aGUgREIgb2JqZWN0DQoJCQlpZiAoIVN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKCRkYikpDQoJCQl7DQoJCQkJLy8gZ2V0IHRoZSBkYXRhYmFzZSBvYmplY3QNCgkJCQkkZGIgPSBGYWN0b3J5OjpnZXREQk8oKTsNCgkJCX0NCgkJCS8vIGdldCB0aGUgZGF0YWJhc2UgY29sdW1ucyBvZiB0aGlzIHRhYmxlDQoJCQkkY29sdW1ucyA9ICRkYi0+Z2V0VGFibGVDb2x1bW5zKCIjX19bW1tjb21wb25lbnRdXV1fIiAuICR0YWJsZSwgZmFsc2UpOw0KCQkJLy8gYWx3YXlzIHJlbW92ZSB0aGVzZQ0KCQkJJHJlbW92ZSA9IGFycmF5KCdhc3NldF9pZCcsICdjaGVja2VkX291dCcsICdjaGVja2VkX291dF90aW1lJyk7DQoJCQkvLyBpZiBwbGFjZWhvbGRlciBhbmQgbm9uZSBmaWx0ZXIgdGhlbiByZW1vdmUgc29tZSBtb3JlDQoJCQlpZiAoJ3BsYWNlaG9sZGVyJyA9PT0gJG1ldGhvZCAmJiAoJ3JlcG9ydCcgPT09ICRmaWx0ZXIgfHwgJ2VtYWlsJyA9PT0gJGZpbHRlcikpDQoJCQl7DQoJCQkJJHJlbW92ZVtdID0gJ3BhcmFtcyc7DQoJCQkJJHJlbW92ZVtdID0gJ2FjY2Vzcyc7DQoJCQkJJHJlbW92ZVtdID0gJ2NyZWF0ZWRfYnknOw0KCQkJCSRyZW1vdmVbXSA9ICdpZCc7DQoJCQkJJHJlbW92ZVtdID0gJ29yZGVyaW5nJzsNCgkJCQkkcmVtb3ZlW10gPSAndmVyc2lvbic7DQoJCQkJJHJlbW92ZVtdID0gJ3B1Ymxpc2hlZCc7DQoJCQkJJHJlbW92ZVtdID0gJ21vZGlmaWVkX2J5JzsNCgkJCQkkcmVtb3ZlW10gPSAnbW9kaWZpZWQnOw0KCQkJCSRyZW1vdmVbXSA9ICdoaXRzJzsNCgkJCX0NCgkJCS8vIHJlbW92ZQ0KCQkJZm9yZWFjaCAoJHJlbW92ZSBhcyAka2V5KQ0KCQkJew0KCQkJCXVuc2V0KCRjb2x1bW5zWyRrZXldKTsNCgkJCX0NCgkJCS8vIHByZXAgdGhlIGNvbHVtbnMNCgkJCSRjb2x1bW5zID0gYXJyYXlfa2V5cygkY29sdW1ucyk7DQoJCX0NCgkJLy8gbWFrZSBzdXJlIHdlIGhhdmUgY29sdW1ucw0KCQlpZiAoU3VwZXJfX18wYTU5YzY1Y185ZGFmXzRiYzlfYmFmNF9lMDYzZmY5ZTZhOGFfX19Qb3dlcjo6Y2hlY2soJGNvbHVtbnMpKQ0KCQl7DQoJCQkvLyBjb252ZXJ0IHRoZSBjb2x1bW5zIGZvciBxdWVyeSBzZWxlY3Rpb24NCgkJCSRzZWxlY3Rpb24gPSBhcnJheSgpOw0KCQkJLy8gbG9hZCB0aGUgY29sdW1ucyB0byBzZWxlY3Rpb24NCgkJCWZvcmVhY2ggKCRjb2x1bW5zIGFzICRjb2x1bW4pDQoJCQl7DQoJCQkJJHNlbGVjdGlvblsnYS4nIC4gJGNvbHVtbl0gPSAkZiAuICRjb2x1bW4gLiAkYjsNCgkJCQkvLyB3ZSBtdXN0IGFkZCB0aGUgbGFiZWxzDQoJCQkJaWYgKCdwcm9maWxlJyAhPT0gJGZpbHRlciAmJiAnZmllbGQnICE9PSAkZmlsdGVyKQ0KCQkJCXsNCgkJCQkJLy8gc2V0IHRoZSBsYWJlbCBmb3IgdGhlc2UgZmllbGRzDQoJCQkJCSRzZWxlY3Rpb25bJ3NldExhYmVsLT4nIC4gJGNvbHVtbl0gPSAkZiAuICdsYWJlbF8nIC4gJGNvbHVtbiAuICRiOw0KCQkJCX0NCgkJCX0NCgkJCXJldHVybiAkc2VsZWN0aW9uOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQpbQ1VTVE9NQ09ERT1nZXRGb2xkZXJQYXRoXQ0KW0NVU1RPTUNPREU9dGhlQnV0bGVyXQ0KW0NVU1RPTUNPREU9Z2V0UGxhY2VIb2xkZXJzUmVwb3J0XQ0KW0NVU1RPTUNPREU9Z2V0QU5ZRGV0YWlscytmb3JtLEZvcm1dDQpbQ1VTVE9NQ09ERT1tb2RlbEFOWURldGFpbHMrZm9ybSxGb3JtXQ0KW0NVU1RPTUNPREU9bGFiZWxNb2RlbEFOWURldGFpbHMrZm9ybSxGb3JtXQ0KW0NVU1RPTUNPREU9cmVtb3ZlQU5ZRGV0YWlscytmb3JtLEZvcm1dDQpbQ1VTVE9NQ09ERT1nZXRNZW1iZXJOYW1lXQ0KW0NVU1RPTUNPREU9bmljZUZhbmN5RGF0ZV0NCltDVVNUT01DT0RFPWdldENvcmVOYW1lXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'Company Details', '', '', 'Company (tradeshow)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_companydetails_server.xml', 'http://www.vdm.io', '', 'P1gnb8JQEfs7tcSvkg6Swf2UhDZeDksNNBaerj9gWek=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 21, '', 1, 24), -(50, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.11', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 20:06:53', '', '4diAWcihanuttZ0jDXOo1UZosKniJAFHtkSlzOdB1Gc=', 'ZTymcvrTiJzWQyyRUh5xR0o4fs1N1oVU2s7OdYGytlo=', '', '8oZJl/ju/2LPdpwdoTW3YQOA3Obo7mdPx8BFs8M+MEw=', '', '', 'A_101', 2, '', 'Anthropometry', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_anthropometry', 'ECWXtQIFbWanedMA0C1fow6UxJdw41EEoNxrrOAwclDi/Q16K9ttdJvcG+ij0kOJkOiknEZPlGPn7ZOG9x1BUw==', '', '25a25b20-e7b7-465b-a398-4a6cb1448a13', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:28:04', 2, 'Anthropometry', 'coral_anthropometry', '', 4, '', '', 'W0NVU1RPTUNPREU9YW50aHJvcG9tZXRyeUhlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Anthropometry', '--
-- Dumping data for table `#__[[[component]]]_status_norm`
--

INSERT INTO `#__[[[component]]]_status_norm` (`id`, `calculation_type`, `calculations`, `selection`, `templates`, `published`, `created`) VALUES
(1, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"10, 24.9\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"25, 29.9\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"30, 40\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"41, 200\"}}', 'bmi', '{\"templates0\":{\"target\":\"0\",\"word\":\"desirable\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Desirable<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 1 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 2 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 3 Obesity\\/Morbid<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Desirable<\\/button>\"},\"templates1\":{\"target\":\"1\",\"word\":\"grade 1 obesity\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Desirable<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Grade 1 Obesity<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 2 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 3 Obesity\\/Morbid<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 1 Obesity<\\/button>\"},\"templates2\":{\"target\":\"2\",\"word\":\"grade 2 obesity\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Desirable<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 1 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Grade 2 Obesity<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 3 Obesity\\/Morbid<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 2 Obesity<\\/button>\"},\"templates3\":{\"target\":\"3\",\"word\":\"grade 3 obesity\\/morbid\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Desirable<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 1 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Grade 2 Obesity<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Grade 3 Obesity\\/Morbid<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Desirable<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Grade 1 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Grade 2 Obesity<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 3 Obesity\\/Morbid<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Grade 3 Obesity\\/Morbid<\\/button>\"}}', 1, '2018-09-07 19:41:55'),
(2, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0.959, 20.00\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0.91, 0.958\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0.000001, 0.95\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0.859, 20\"},\"calculations4\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0.81, 0.858\"},\"calculations5\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0.00, 0.80\"}}', 'whr', '{\"templates0\":{\"target\":\"0\",\"word\":\"high risk\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>High risk<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Moderate risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Low risk<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">High risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Moderate risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Low risk<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">High risk<\\/button>\"},\"templates1\":{\"target\":\"1\",\"word\":\"moderate risk\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">High risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Moderate risk<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Low risk<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>High risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Moderate risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Low risk<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Moderate risk<\\/button>\"},\"templates2\":{\"target\":\"2\",\"word\":\"low risk\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">High risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Moderate risk<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Low risk<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>High risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Moderate risk<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Low risk<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Low risk<\\/button>\"}}', 1, '2018-09-07 19:49:11'),
(3, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"22.4\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"17.4\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"15.9\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"14.1\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"9.4\"},\"calculations5\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"24.2\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"20.5\"},\"calculations7\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"19\"},\"calculations8\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"17.5\"},\"calculations9\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"13.9\"},\"calculations10\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"26.1\"},\"calculations11\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"22.5\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"21.1\"},\"calculations13\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"19.6\"},\"calculations14\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"16.3\"},\"calculations15\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"27.5\"},\"calculations16\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"24.1\"},\"calculations17\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"22.7\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"21.3\"},\"calculations19\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"17.9\"},\"calculations20\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"28.5\"},\"calculations21\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"25\"},\"calculations22\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"23.5\"},\"calculations23\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"22\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"18.4\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"27.7\"},\"calculations26\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"23.7\"},\"calculations27\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"22.1\"},\"calculations28\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"20.6\"},\"calculations29\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"17.1\"},\"calculations30\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"29.3\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"24.9\"},\"calculations32\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"23.1\"},\"calculations33\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"21.6\"},\"calculations34\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"18\"},\"calculations35\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"32.1\"},\"calculations36\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"28.1\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"26.4\"},\"calculations38\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"24.9\"},\"calculations39\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"21.3\"},\"calculations40\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"35.6\"},\"calculations41\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"31.6\"},\"calculations42\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"30.1\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"28.5\"},\"calculations44\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"25\"},\"calculations45\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"36.6\"},\"calculations46\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"32.5\"},\"calculations47\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"30.9\"},\"calculations48\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"29.3\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"25.1\"}}', 'fat_percentage', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Poor<\\/button>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Fair<\\/button>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Ave<\\/button>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Good<\\/button>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Excellent<\\/button>\\r\\n\\t\\t\\t\\t\\t<\\/span>\\r\\n\\t\\t\\t\\t\\t<button class=\\\"uk-button uk-button-mini uk-badge-success uk-visible-small\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\'#vdm-status-defaults\'}\\\">Excellent<\\/button>\"}}', 1, '2018-09-07 20:01:23');

--
-- Dumping data for table `#__[[[component]]]_chart`
--

INSERT INTO `#__[[[component]]]_chart` (`id`, `details`, `javascript_table`, `name`, `number`, `target`, `target_fields`, `type`, `published`, `created`) VALUES
(1, '{\"dataTable\":{\"cols\":[{\"label\":\"Label\",\"type\":\"string\"},{\"label\":\"Value\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"Lean Weight\"},{\"v\":92.34}]},{\"c\":[{\"v\":\"Fat Weight\"},{\"v\":19.65}]}]},\"options\":{\"fontName\":\"Verdana\",\"hAxis\":{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null},\"legacyScatterChartLabels\":true,\"legend\":\"none\",\"legendTextStyle\":{\"color\":\"#222\",\"fontSize\":12,\"bold\":true,\"italic\":true},\"title\":\"Body Weight\",\"titleTextStyle\":{\"color\":\"#000\",\"fontSize\":\"20\",\"bold\":true},\"vAxes\":[{\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true,\"logScale\":false},{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"logScale\":false}],\"type\":\"line\",\"booleanRole\":\"certainty\",\"series\":[{\"type\":\"bars\"},{\"type\":\"bars\"},{\"type\":\"bars\"},{\"type\":\"bars\"},{\"type\":\"bars\"}],\"width\":600,\"height\":371,\"is3D\":true,\"pieHole\":0,\"slices\":{\"0\":{\"color\":\"#93c47d\"},\"1\":{\"color\":\"#b4a7d6\"}},\"pieSliceText\":\"label\",\"theme\":\"maximized\"},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"PieChart\"}', '(Label, Value)\r\n([anthropometry_label_lean_weight], [anthropometry_lean_weight])\r\n([anthropometry_label_fat_weight], [anthropometry_fat_weight])', 'Body Weight', 3, 1, '{\"target_fields0\":{\"selection\":\"lean_weight\"},\"target_fields1\":{\"selection\":\"fat_weight\"}}', 'PieChart', 1, '2018-09-27 10:38:43'),
(2, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"BMI\",\"type\":\"number\"},{\"label\":\"Fat Percentage\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/08\"},{\"v\":32.72},{\"v\":23.63}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":32.72},{\"v\":23.63}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":32.72},{\"v\":17.55}]},{\"c\":[{\"v\":\"2018/09/10\"},{\"v\":32.72},{\"v\":17.55}]},{\"c\":[{\"v\":\"2018/09/09\"},{\"v\":30.55},{\"v\":28.2}]},{\"c\":[{\"v\":\"2018/09/08\"},{\"v\":32.72},{\"v\":26.71}]}]},\"options\":{\"hAxis\":{\"useFormatFromData\":true,\"slantedTextAngle\":30,\"slantedText\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null},\"legacyScatterChartLabels\":true,\"legend\":\"in\",\"title\":\"Progress\",\"vAxes\":[{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"logScale\":false},{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"logScale\":false}],\"isStacked\":false,\"booleanRole\":\"certainty\",\"width\":600,\"height\":371,\"lineWidth\":2,\"interpolateNulls\":true,\"domainAxis\":{\"direction\":-1},\"curveType\":\"function\",\"series\":{\"0\":{\"targetAxisIndex\":1,\"errorBars\":{\"errorType\":\"none\"}},\"1\":{\"targetAxisIndex\":0,\"errorBars\":{\"errorType\":\"none\",\"magnitude\":10}}},\"theme\":\"maximized\",\"focusTarget\":\"category\"},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '(Day, [anthropometry_label_bmi], [anthropometry_label_fat_percentage])\r\n([0_anthropometry_day], [0_anthropometry_bmi], [0_anthropometry_fat_percentage])\r\n([1_anthropometry_day], [1_anthropometry_bmi], [1_anthropometry_fat_percentage])\r\n([2_anthropometry_day], [2_anthropometry_bmi], [2_anthropometry_fat_percentage])', 'Progress', 4, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"bmi\"},\"target_fields2\":{\"selection\":\"fat_percentage\"}}', 'LineChart', 1, '2018-09-27 11:28:37'),
(3, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"Weight\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":112}]},{\"c\":[{\"v\":\"2018/09/10\"},{\"v\":112}]},{\"c\":[{\"v\":\"2018/09/09\"},{\"v\":99}]},{\"c\":[{\"v\":\"2018/09/08\"},{\"v\":112}]}]},\"options\":{\"title\":\"Weight\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null}},{\"useFormatFromData\":true,\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null}],\"legacyScatterChartLabels\":true,\"curveType\":\"function\",\"booleanRole\":\"certainty\",\"lineWidth\":2,\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null,\"slantedTextAngle\":30,\"slantedText\":true,\"title\":\"\"},\"legend\":\"none\",\"width\":600,\"height\":371,\"domainAxis\":{\"direction\":-1},\"series\":{\"0\":{\"color\":\"#741b47\",\"targetAxisIndex\":0,\"lineWidth\":4,\"pointSize\":10}},\"theme\":\"maximized\"},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":true,\"chartType\":\"LineChart\"}', '(Day, [anthropometry_label_weight])\r\n([0_anthropometry_day], [0_anthropometry_weight])\r\n([1_anthropometry_day], [1_anthropometry_weight])\r\n([2_anthropometry_day], [2_anthropometry_weight])\r\n([3_anthropometry_day], [3_anthropometry_weight])\r\n([4_anthropometry_day], [4_anthropometry_weight])', 'Weight', 5, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"weight\"}}', 'LineChart', 1, '2018-10-04 21:37:18'),
(4, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"Calf\",\"type\":\"number\"},{\"label\":\"Chest\",\"type\":\"number\"},{\"label\":\"Hip\",\"type\":\"number\"},{\"label\":\"Middle\",\"type\":\"number\"},{\"label\":\"Navel\",\"type\":\"number\"},{\"label\":\"Neck\",\"type\":\"number\"},{\"label\":\"Thigh\",\"type\":\"number\"},{\"label\":\"Upper Arm\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/08\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":106.5},{\"v\":32},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/10/08\"},{\"v\":42.5},{\"v\":113},{\"v\":85},{\"v\":80},{\"v\":110},{\"v\":null},{\"v\":23},{\"v\":23}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":42.5},{\"v\":119.5},{\"v\":125.2},{\"v\":106.5},{\"v\":106.5},{\"v\":null},{\"v\":65.5},{\"v\":36.5}]},{\"c\":[{\"v\":\"2018/10/04\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":80},{\"v\":30},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/09/10\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":80},{\"v\":30},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/09/09\"},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":null},{\"v\":110},{\"v\":45},{\"v\":null},{\"v\":null}]},{\"c\":[{\"v\":\"2018/09/08\"},{\"v\":42.5},{\"v\":119.5},{\"v\":115.5},{\"v\":106.5},{\"v\":112},{\"v\":null},{\"v\":65.5},{\"v\":36.5}]}]},\"options\":{\"legacyScatterChartLabels\":true,\"legend\":\"none\",\"title\":\"Circumferences\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"booleanRole\":\"certainty\",\"lineWidth\":2,\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null,\"textStyle\":{\"color\":\"#222\",\"fontSize\":\"12\",\"italic\":false},\"slantedTextAngle\":60,\"slantedText\":true},\"width\":600,\"height\":371,\"interpolateNulls\":true,\"focusTarget\":\"category\",\"series\":{\"0\":{\"targetAxisIndex\":1},\"2\":{\"targetAxisIndex\":1,\"lineWidth\":2},\"3\":{\"targetAxisIndex\":1}},\"domainAxis\":{\"direction\":1},\"curveType\":\"function\",\"fontName\":\"Verdana\",\"titleTextStyle\":{\"color\":\"#000\",\"fontSize\":12,\"bold\":true,\"italic\":true}},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '(Day, [anthropometry_label_circumferences_calf], [anthropometry_label_circumferences_chest], [anthropometry_label_circumferences_hip], [anthropometry_label_circumferences_middle], [anthropometry_label_circumferences_navel], [anthropometry_label_circumferences_neck], [anthropometry_label_circumferences_thigh], [anthropometry_label_circumferences_upper_arm])\r\n([0_anthropometry_day], [0_anthropometry_circumferences_calf], [0_anthropometry_circumferences_chest], [0_anthropometry_circumferences_hip], [0_anthropometry_circumferences_middle], [0_anthropometry_circumferences_navel], [0_anthropometry_circumferences_neck], [0_anthropometry_circumferences_thigh], [0_anthropometry_circumferences_upper_arm])\r\n([1_anthropometry_day], [1_anthropometry_circumferences_calf], [1_anthropometry_circumferences_chest], [1_anthropometry_circumferences_hip], [1_anthropometry_circumferences_middle], [1_anthropometry_circumferences_navel], [1_anthropometry_circumferences_neck], [1_anthropometry_circumferences_thigh], [1_anthropometry_circumferences_upper_arm])\r\n([2_anthropometry_day], [2_anthropometry_circumferences_calf], [2_anthropometry_circumferences_chest], [2_anthropometry_circumferences_hip], [2_anthropometry_circumferences_middle], [2_anthropometry_circumferences_navel], [2_anthropometry_circumferences_neck], [2_anthropometry_circumferences_thigh], [2_anthropometry_circumferences_upper_arm])\r\n([3_anthropometry_day], [3_anthropometry_circumferences_calf], [3_anthropometry_circumferences_chest], [3_anthropometry_circumferences_hip], [3_anthropometry_circumferences_middle], [3_anthropometry_circumferences_navel], [3_anthropometry_circumferences_neck], [3_anthropometry_circumferences_thigh], [3_anthropometry_circumferences_upper_arm])\r\n([4_anthropometry_day], [4_anthropometry_circumferences_calf], [4_anthropometry_circumferences_chest], [4_anthropometry_circumferences_hip], [4_anthropometry_circumferences_middle], [4_anthropometry_circumferences_navel], [4_anthropometry_circumferences_neck], [4_anthropometry_circumferences_thigh], [4_anthropometry_circumferences_upper_arm])\r\n// The rest of the rows are added dynamically\r\n// You need only set the few above', 'Circumferences', 3, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"circumferences_calf\"},\"target_fields2\":{\"selection\":\"circumferences_chest\"},\"target_fields3\":{\"selection\":\"circumferences_hip\"},\"target_fields4\":{\"selection\":\"circumferences_middle\"},\"target_fields5\":{\"selection\":\"circumferences_navel\"},\"target_fields6\":{\"selection\":\"circumferences_neck\"},\"target_fields7\":{\"selection\":\"circumferences_thigh\"},\"target_fields8\":{\"selection\":\"circumferences_upper_arm\"}}', 'LineChart', '', '2018-10-04 21:51:48');
', '', 'Anthropometry (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_anthropometry_server.xml', 'http://www.vdm.io', '', 'rfe7CO7xK6KBxobI8+M/YRQ0mg1zbOmv8pmsmWynCGg=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 11, '', 1, 23), -(51, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:03:52', '', '8NFbjPIRqtyFYjXf9cgXCa2Yw0ZLkjZ3vfsK1HODusg=', 't9QihU1+uDb6nkvICLy4Me4Kw3J4f+Tsw33K5oOdI7g=', '', 'xBQEhdioWj0xBhbZMEgkCo7PSwylsaadj5bvgOY6TIs=', '', '', 'A_188', 2, '', 'Medical Aid Info', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_medicalaid', 'cGCACZt85oxM20ztOyRarIDDgGMpqwxwypOIfljEh4w5jrd/Pux9+0RZyJax0UrY', '', '705be6e4-9cc0-405e-b772-6f9e54f07838', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:27:39', 2, 'Medical Aid', 'coral_medicalaid', '', 4, '', '', 'W0NVU1RPTUNPREU9bWVkaWNhbGFpZEhlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Medical Aid Info', '', '', 'Medical Aid (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_medicalaid_server.xml', 'http://www.vdm.io', '', 'Mq1QTg8AIvgd7JBiNDJI6rYhRb0plOs2qigJDc+6GHU=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 8, '', 1, 21), -(52, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.3', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:05:31', '', 'QwZI1BiaWmTS0anBpVvqtZEd2AsaMqHf+cQ61QijkNs=', '53XWHWscjYet9/2uOseE/YDP6vx6YXau/rRAGuJ5mhU=', '', '1tLvEhB5ag4ldY9ZSrZ9jQZ0k4/GQfY3U9P6KYzep20=', '', '', 'A_189', 2, '', 'Contact Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_contactdetails', '1PWzKLwhU2ENa8+yjDwwVgLP5mrAbFKQiHhbLnN3U2Z2ZdDVvB2j4lmhOasGRFFGOa5MZJiP9oEr8552E8vvUg==', '', 'e0228373-f560-4d61-8f2f-553d3674f245', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:28:14', 2, 'Contact', 'coral_contactdetails', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29udGFjdGRldGFpbHNIZWxwZXJCb3RoXQ==', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Contact Details', '', '', 'Contact Details (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_contactdetails_server.xml', 'http://www.vdm.io', '', 'oCK4MOKNKUHMkQ4HZuNY4C8OtpJw9l0HlOk39ZQAtlE=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 9, '', 1, 17), -(53, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:07:27', '', 'LE2CU3KIhuQ21TtiwtUlq46LG3MQq9AgCl8hDYjnuRE=', 'uA0toPlC2azBt7J+no6aB3v1r+UWExfqQhir8Wuk6wE=', '', 'yjGktgp/Mzqf9b3rcq/5sSay2p2r7KNeo84mkvkUv9c=', '', '', 'A_190', 2, '', 'Personal Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_personaldetails', 'cfl6/KQMzcbh+A0rQNy58iAMWa6Atm9obsfEIXdOqCyNE1d6l+p4419ftiJHXRpmYC+gFo/qpJlhopYj68MuTw==', '', '01db3a87-9e36-4959-a490-64582cc369db', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:27:49', 2, 'Personal', 'coral_personaldetails', '', 4, '', '', 'W0NVU1RPTUNPREU9cGVyc29uYWxkZXRhaWxzSGVscGVyQm90aF0=', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Personal Details', '', '', 'Personal Details (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_personaldetails_server.xml', 'http://www.vdm.io', '', 'gF3D+fLBYY4rK78k5Ty5rs3URFXZ7BXVKPhP+03knnU=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 13, '', 1, 19), -(54, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:08:53', '', 'mg467KYDaGLTXPeHtCf3G7ORrPHETnpqWAPAlL+ctp4=', 'kvUBCp6T568wVm1g+/9xVLPoJ3DgtPYIl0x3cEjKQkk=', '', '9Mtl4Gk+GgvwaHtOd8VXvsSOTgZ9qdAtI+YJoILNRO4=', '', '', 'A_193', 2, '', 'Doctor Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_doctordetails', 'UH3vD3UEpRgXVAsj95yFAjUMzBF4aoCVz/R6oMyxcON/32X2aCPW88suyBzRifapMEzKdthPFuC8IMLPqtaPkg==', '', '4e3321d6-0fad-4916-bd92-cd36d81fc695', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:27:33', 2, 'Doctor', 'coral_doctordetails', '', 4, '', '', 'W0NVU1RPTUNPREU9ZG9jdG9yZGV0YWlsc0hlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkK2NvcmFsXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Doctor Details', '', '', 'Doctor Details (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_doctordetails_server.xml', 'http://www.vdm.io', '', 'H0IcbqK10IAQdO5c8JSLzyhEot27+p+N/fmARYoCPC0=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 6, '', 1, 18), -(55, '', '', '', '', 1, '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.5', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:09:55', '', '1VWz93/qjNiFwZXP/wlBrYe4qI/oYn/hpYpSKbYJTss=', '3GX+XZCGa4PkBOFVnXeqOtcktbCrmsfY5lLr2OJyC+0=', '', 'n/xQ+LZhbxhSSzG7Wyd3dr1CtV4UJRraYmAGCvBeM2M=', '', '', '', 1, '', 'Communicate', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_communicate', 'umYy+mxep7WIgRkS4teMHfx7O8+f/SFg1kiDcJBXueDsEnrLjADFnHGs8fhq9fBdO4BLxi84O0iJs6S0CxwBUw==', '', 'a3809036-adb7-455e-b2f7-634aed05e33c', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:27:59', 2, 'Communicate', 'coral_communicate', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29tbXVuaWNhdGVIZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Communicate', '', '', 'Communicate (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_communicate_server.xml', 'http://www.vdm.io', '', 'xNLlKoDw7Ztj7nP3JHX08h/Pzz/514R2vkr04xFPJAw=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 8, '', 1, 28), -(56, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.5', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:10:55', '', 'FWA/RJgvHyHW80DpylnqtxdFCH0gYMx11Alf1TlY5NM=', '2ktBxO5XfGGgIDcjxYVMZYU6JxYYK6VL0lyr2Q52R2c=', '', 'oyAKzpNqvq19QlcEeQj43KTvJc+YwPakUSEHo2bgFYQ=', '', '', 'A_198', 2, '', 'Fitness Test', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_fitnesstest', '7Oofno/gye7Bh8McOZ0REABjxSVETqzyc7et70rLIlBoTFeUE0cnp8ZvA+L/IPifYPHbwQuIwMCDds/QVDgUqQ==', '', '5dc356a3-62fa-4c43-89f8-b942050645b1', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:27:54', 2, 'Fitness Test', 'coral_fitnesstest', '', 4, '', '', 'W0NVU1RPTUNPREU9Zml0bmVzc3Rlc3RIZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Fitness Test', '--
-- Dumping data for table `#__[[[component]]]_status_norm`
--

INSERT INTO `#__[[[component]]]_status_norm` (`id`, `calculation_type`, `calculations`, `selection`, `templates`, `published`, `created`) VALUES
(1, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"53\"},\"calculations1\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"50\"},\"calculations2\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"44\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"39\"},\"calculations4\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"35\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"58\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"55\"},\"calculations7\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"49\"},\"calculations8\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"44\"},\"calculations9\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"39\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"60\"},\"calculations11\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"56\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"51\"},\"calculations13\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"46\"},\"calculations14\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"40\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"62\"},\"calculations16\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"59\"},\"calculations17\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"54\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"48\"},\"calculations19\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"42\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"67\"},\"calculations21\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"63\"},\"calculations22\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"59\"},\"calculations23\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"55\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"50\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"47\"},\"calculations26\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"40\"},\"calculations27\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"34\"},\"calculations28\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"30\"},\"calculations29\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"23\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"52\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"45\"},\"calculations32\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"40\"},\"calculations33\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"34\"},\"calculations34\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"26\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"55\"},\"calculations36\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"47\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"42\"},\"calculations38\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"37\"},\"calculations39\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"28\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"58\"},\"calculations41\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"49\"},\"calculations42\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"44\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"40\"},\"calculations44\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"31\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"64\"},\"calculations46\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"55\"},\"calculations47\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"49\"},\"calculations48\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"44\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"37\"}}', 'partial_curl_ups', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 19:56:59'),
(2, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"18\"},\"calculations1\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"12\"},\"calculations2\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"8\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"7\"},\"calculations4\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"3\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"21\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"16\"},\"calculations7\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"11\"},\"calculations8\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations9\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"4\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"27\"},\"calculations11\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"22\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"16\"},\"calculations13\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"15\"},\"calculations14\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"9\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"34\"},\"calculations16\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"28\"},\"calculations17\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"19\"},\"calculations19\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"14\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"37\"},\"calculations21\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"31\"},\"calculations22\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"24\"},\"calculations23\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"21\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"15\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"23\"},\"calculations26\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"18\"},\"calculations27\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"12\"},\"calculations28\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations29\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"7\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"26\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"23\"},\"calculations32\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"14\"},\"calculations33\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"12\"},\"calculations34\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"8\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"33\"},\"calculations36\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"27\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations38\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"17\"},\"calculations39\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"15\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"43\"},\"calculations41\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"34\"},\"calculations42\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"28\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"23\"},\"calculations44\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"21\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"49\"},\"calculations46\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"40\"},\"calculations47\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"32\"},\"calculations48\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"26\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"23\"}}', 'push_ups', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 19:58:45'),
(3, 1, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"23\"},\"calculations1\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"18\"},\"calculations2\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"12\"},\"calculations3\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations4\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"7\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"26\"},\"calculations6\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"23\"},\"calculations7\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"14\"},\"calculations8\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"12\"},\"calculations9\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"8\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"33\"},\"calculations11\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"27\"},\"calculations12\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations13\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"17\"},\"calculations14\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"15\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"43\"},\"calculations16\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"34\"},\"calculations17\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"28\"},\"calculations18\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"23\"},\"calculations19\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"21\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"0\",\"number\":\"49\"},\"calculations21\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"1\",\"number\":\"40\"},\"calculations22\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"2\",\"number\":\"32\"},\"calculations23\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"3\",\"number\":\"26\"},\"calculations24\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"4\",\"number\":\"23\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"18\"},\"calculations26\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"12\"},\"calculations27\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"8\"},\"calculations28\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"7\"},\"calculations29\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"3\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"21\"},\"calculations31\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"16\"},\"calculations32\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"11\"},\"calculations33\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"10\"},\"calculations34\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"4\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"27\"},\"calculations36\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"22\"},\"calculations37\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"16\"},\"calculations38\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"15\"},\"calculations39\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"9\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"34\"},\"calculations41\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"28\"},\"calculations42\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"22\"},\"calculations43\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"19\"},\"calculations44\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"14\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"0\",\"number\":\"37\"},\"calculations46\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"1\",\"number\":\"31\"},\"calculations47\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"2\",\"number\":\"24\"},\"calculations48\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"3\",\"number\":\"21\"},\"calculations49\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"4\",\"number\":\"15\"}}', 'pull_ups', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:08:31'),
(4, 2, '{\"calculations49\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 20\"},\"calculations50\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"21, 40\"},\"calculations51\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"41, 60\"},\"calculations52\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"61, 80\"},\"calculations53\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"81, 100\"},\"calculations54\":{\"target\":\"5\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"101, 300\"}}', 'bridge_side_left', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates5\":{\"target\":\"5\",\"word\":\"Superior\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Superior<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:14:50'),
(5, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 20\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"21, 40\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"41, 60\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"61, 80\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"81, 100\"},\"calculations5\":{\"target\":\"5\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"101, 300\"}}', 'bridge_side_right', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates5\":{\"target\":\"5\",\"word\":\"Superior\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Superior<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:29:07'),
(6, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 30\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"31, 60\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"61, 90\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"91, 119\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"120, 149\"},\"calculations5\":{\"target\":\"5\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"150, 300\"}}', 'front_bridge', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Superior<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates5\":{\"target\":\"5\",\"word\":\"Superior\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Superior<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:30:38'),
(7, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 83\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"84, 94\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"95, 102\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"103, 112\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"113, 300\"}}', 'grip_strength_total', '{\"templates5\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates6\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates7\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates8\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates9\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:33:41'),
(8, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"0, 91\"},\"calculations1\":{\"target\":\"1\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"91, 125\"},\"calculations2\":{\"target\":\"2\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"126, 176\"},\"calculations3\":{\"target\":\"3\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"177, 208\"},\"calculations4\":{\"target\":\"4\",\"gender\":\"0\",\"age_norm\":\"\",\"number\":\"209, 300\"}}', 'back_strength', '{\"templates0\":{\"target\":\"0\",\"word\":\"very poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Very Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Very Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Very Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Superior<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 20:38:52'),
(9, 2, '{\"calculations0\":{\"target\":\"0\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"-50, -8\"},\"calculations5\":{\"target\":\"1\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"-7, -1\"},\"calculations10\":{\"target\":\"2\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"0, 5\"},\"calculations15\":{\"target\":\"3\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"6, 16\"},\"calculations20\":{\"target\":\"4\",\"gender\":\"1\",\"age_norm\":\"\",\"number\":\"17, 100\"},\"calculations25\":{\"target\":\"0\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"-50, -7\"},\"calculations30\":{\"target\":\"1\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"-6, -1\"},\"calculations35\":{\"target\":\"2\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"0, 10\"},\"calculations40\":{\"target\":\"3\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"11, 20\"},\"calculations45\":{\"target\":\"4\",\"gender\":\"2\",\"age_norm\":\"\",\"number\":\"21, 100\"}}', 'sit_reach', '{\"templates0\":{\"target\":\"0\",\"word\":\"poor\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#d85030\\\"><b>Poor<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates1\":{\"target\":\"1\",\"word\":\"fair\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#e28327\\\"><b>Fair<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates2\":{\"target\":\"2\",\"word\":\"average\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#2d7091\\\"><b>Average<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates3\":{\"target\":\"3\",\"word\":\"good\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Good<\\/b><\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Excellent<\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Excellent<\\/button>\\r\\n<\\/span>\"},\"templates4\":{\"target\":\"4\",\"word\":\"excellent\",\"table\":\"<table style=\\\"border:1px solid #9C0F13;\\\" cellpadding=\\\"5\\\" cellspacing=\\\"1\\\" width=\\\"100%\\\" bgcolor=\\\"#FFFFFF\\\"><tr>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Poor<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Fair<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Average<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#EDEDED\\\" style=\\\"color:#C6C6C6;\\\">Good<\\/td>\\r\\n<td align=\\\"center\\\" valign=\\\"middle\\\" bgcolor=\\\"#659f13\\\"><b>Excellent<\\/b><\\/td><\\/tr><\\/table>\",\"scale\":\"<span class=\\\"uk-button-group uk-hidden-small\\\">\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-danger\\\" type=\\\"button\\\" disabled>Poor<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini\\\" type=\\\"button\\\" disabled>Fair<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-button-primary\\\" type=\\\"button\\\" disabled>Ave<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" disabled>Good<\\/button>\\r\\n\\t<button class=\\\"uk-button uk-button-mini uk-badge-success\\\" type=\\\"button\\\" data-uk-modal=\\\"{target:\\\\\'#vdm-status-defaults\\\\\'}\\\">Excellent<\\/button>\\r\\n<\\/span>\"}}', 1, '2018-10-11 22:17:06');

--
-- Dumping data for table `#__[[[component]]]_chart`
--

INSERT INTO `#__[[[component]]]_chart` (`id`, `details`, `javascript_table`, `name`, `number`, `target`, `target_fields`, `type`, `published`, `created`) VALUES
(1, '{\"dataTable\":{\"cols\":[{\"label\":\"Stage\",\"type\":\"string\"},{\"label\":\"Heart Rate\",\"type\":\"number\"},{\"label\":\"Systolic Blood Pressure\",\"type\":\"number\"},{\"label\":\"Diastolic Blood Pressure\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"Rest\"},{\"v\":72},{\"v\":43},{\"v\":53}]},{\"c\":[{\"v\":\"@ 25 Watt\"},{\"v\":89},{\"v\":53},{\"v\":63}]},{\"c\":[{\"v\":\"@ 50 Watt\"},{\"v\":93},{\"v\":63},{\"v\":73}]},{\"c\":[{\"v\":\"@ 75 Watt\"},{\"v\":92},{\"v\":63},{\"v\":73}]},{\"c\":[{\"v\":\"Final - 3 min rest\"},{\"v\":78},{\"v\":54},{\"v\":58}]}]},\"options\":{\"focusTarget\":\"category\",\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null},\"legacyScatterChartLabels\":true,\"legend\":\"in\",\"theme\":\"maximized\",\"title\":\"YMCA\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"curveType\":\"function\",\"booleanRole\":\"certainty\",\"lineWidth\":2,\"width\":600,\"height\":371},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '([fitnesstest_label_ymca_stage], [fitnesstest_label_ymca_heart_rate], [fitnesstest_label_ymca_systolic_blood_pressure], [fitnesstest_label_ymca_diastolic_blood_pressure])\r\n([fitnesstest_template_ymca_stage_one], [fitnesstest_ymca_heart_rate_one], [fitnesstest_ymca_systolic_blood_pressure_one], [fitnesstest_ymca_diastolic_blood_pressure_one])\r\n[IF fitnesstest_ymca_stage_two]([fitnesstest_template_ymca_stage_two], [fitnesstest_ymca_heart_rate_two], [fitnesstest_ymca_systolic_blood_pressure_two], [fitnesstest_ymca_diastolic_blood_pressure_two])[ENDIF]\r\n[IF fitnesstest_ymca_stage_three]([fitnesstest_template_ymca_stage_three], [fitnesstest_ymca_heart_rate_three], [fitnesstest_ymca_systolic_blood_pressure_three], [fitnesstest_ymca_diastolic_blood_pressure_three])[ENDIF]\r\n[IF fitnesstest_ymca_stage_four]([fitnesstest_template_ymca_stage_four], [fitnesstest_ymca_heart_rate_four], [fitnesstest_ymca_systolic_blood_pressure_four], [fitnesstest_ymca_diastolic_blood_pressure_four])[ENDIF]\r\n[IF fitnesstest_ymca_stage_five]([fitnesstest_template_ymca_stage_five], [fitnesstest_ymca_heart_rate_five], [fitnesstest_ymca_systolic_blood_pressure_five], [fitnesstest_ymca_diastolic_blood_pressure_five])[ENDIF]\r\n[IF fitnesstest_ymca_stage_six]([fitnesstest_template_ymca_stage_six], [fitnesstest_ymca_heart_rate_six], [fitnesstest_ymca_systolic_blood_pressure_six], [fitnesstest_ymca_diastolic_blood_pressure_six])[ENDIF]\r\n[IF fitnesstest_ymca_stage_seven]([fitnesstest_template_ymca_stage_seven], [fitnesstest_ymca_heart_rate_seven], [fitnesstest_ymca_systolic_blood_pressure_seven], [fitnesstest_ymca_diastolic_blood_pressure_seven])[ENDIF]\r\n[IF fitnesstest_ymca_stage_eight]([fitnesstest_template_ymca_stage_eight], [fitnesstest_ymca_heart_rate_eight], [fitnesstest_ymca_systolic_blood_pressure_eight], [fitnesstest_ymca_diastolic_blood_pressure_eight])[ENDIF]\r\n[IF fitnesstest_ymca_stage_nine]([fitnesstest_template_ymca_stage_nine], [fitnesstest_ymca_heart_rate_nine], [fitnesstest_ymca_systolic_blood_pressure_nine], [fitnesstest_ymca_diastolic_blood_pressure_nine])[ENDIF]\r\n[IF fitnesstest_ymca_stage_ten]([fitnesstest_template_ymca_stage_ten], [fitnesstest_ymca_heart_rate_ten], [fitnesstest_ymca_systolic_blood_pressure_ten], [fitnesstest_ymca_diastolic_blood_pressure_ten])[ENDIF]\r\n[IF fitnesstest_ymca_stage_eleven]([fitnesstest_template_ymca_stage_eleven], [fitnesstest_ymca_heart_rate_eleven], [fitnesstest_ymca_systolic_blood_pressure_eleven], [fitnesstest_ymca_diastolic_blood_pressure_eleven])[ENDIF]\r\n[IF fitnesstest_ymca_stage_twelve]([fitnesstest_template_ymca_stage_twelve], [fitnesstest_ymca_heart_rate_twelve], [fitnesstest_ymca_systolic_blood_pressure_twelve], [fitnesstest_ymca_diastolic_blood_pressure_twelve])[ENDIF]\r\n[IF fitnesstest_ymca_stage_thirteen]([fitnesstest_template_ymca_stage_thirteen], [fitnesstest_ymca_heart_rate_thirteen], [fitnesstest_ymca_systolic_blood_pressure_thirteen], [fitnesstest_ymca_diastolic_blood_pressure_thirteen])[ENDIF]\r\n[IF fitnesstest_ymca_stage_fourteen]([fitnesstest_template_ymca_stage_fourteen], [fitnesstest_ymca_heart_rate_fourteen], [fitnesstest_ymca_systolic_blood_pressure_fourteen], [fitnesstest_ymca_diastolic_blood_pressure_fourteen])[ENDIF]', 'YMCA', 3, 1, '{\"target_fields0\":{\"selection\":\"ymca_stage_one\"}}', 'LineChart', 1, '2018-10-11 22:53:18'),
(2, '{\"dataTable\":{\"cols\":[{\"label\":\"Stage\",\"type\":\"string\"},{\"label\":\"Heart Rate\",\"type\":\"number\"},{\"label\":\"Systolic Blood Pressure\",\"type\":\"number\"},{\"label\":\"Diastolic Blood Pressure\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"Rest\"},{\"v\":72},{\"v\":64},{\"v\":54}]},{\"c\":[{\"v\":\"@ 10 Watt\"},{\"v\":83},{\"v\":67},{\"v\":57}]},{\"c\":[{\"v\":\"@ 12 Watt\"},{\"v\":90},{\"v\":69},{\"v\":59}]},{\"c\":[{\"v\":\"@ 14 Watt\"},{\"v\":94},{\"v\":69},{\"v\":60}]},{\"c\":[{\"v\":\"Final - 3 min rest\"},{\"v\":79},{\"v\":64},{\"v\":57}]}]},\"options\":{\"annotations\":{\"domain\":{}},\"hAxis\":{\"useFormatFromData\":true,\"viewWindow\":null,\"minValue\":null,\"maxValue\":null,\"viewWindowMode\":null},\"legacyScatterChartLabels\":true,\"legend\":\"in\",\"title\":\"Bruce\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"isStacked\":false,\"booleanRole\":\"certainty\",\"width\":600,\"height\":371,\"useFirstColumnAsDomain\":false,\"theme\":\"maximized\",\"focusTarget\":\"category\",\"series\":{\"0\":{\"color\":\"#e06666\"},\"1\":{\"color\":\"#e69138\"},\"2\":{\"color\":\"#85200c\"}}},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"ColumnChart\"}', '([fitnesstest_label_bruce_stage], [fitnesstest_label_bruce_heart_rate], [fitnesstest_label_bruce_systolic_blood_pressure], [fitnesstest_label_bruce_diastolic_blood_pressure])\r\n([fitnesstest_template_bruce_stage_one], [fitnesstest_bruce_heart_rate_one], [fitnesstest_bruce_systolic_blood_pressure_one], [fitnesstest_bruce_diastolic_blood_pressure_one])\r\n[IF fitnesstest_bruce_stage_two]([fitnesstest_template_bruce_stage_two], [fitnesstest_bruce_heart_rate_two], [fitnesstest_bruce_systolic_blood_pressure_two], [fitnesstest_bruce_diastolic_blood_pressure_two])[ENDIF]\r\n[IF fitnesstest_bruce_stage_three]([fitnesstest_template_bruce_stage_three], [fitnesstest_bruce_heart_rate_three], [fitnesstest_bruce_systolic_blood_pressure_three], [fitnesstest_bruce_diastolic_blood_pressure_three])[ENDIF]\r\n[IF fitnesstest_bruce_stage_four]([fitnesstest_template_bruce_stage_four], [fitnesstest_bruce_heart_rate_four], [fitnesstest_bruce_systolic_blood_pressure_four], [fitnesstest_bruce_diastolic_blood_pressure_four])[ENDIF]\r\n[IF fitnesstest_bruce_stage_five]([fitnesstest_template_bruce_stage_five], [fitnesstest_bruce_heart_rate_five], [fitnesstest_bruce_systolic_blood_pressure_five], [fitnesstest_bruce_diastolic_blood_pressure_five])[ENDIF]\r\n[IF fitnesstest_bruce_stage_six]([fitnesstest_template_bruce_stage_six], [fitnesstest_bruce_heart_rate_six], [fitnesstest_bruce_systolic_blood_pressure_six], [fitnesstest_bruce_diastolic_blood_pressure_six])[ENDIF]\r\n[IF fitnesstest_bruce_stage_seven]([fitnesstest_template_bruce_stage_seven], [fitnesstest_bruce_heart_rate_seven], [fitnesstest_bruce_systolic_blood_pressure_seven], [fitnesstest_bruce_diastolic_blood_pressure_seven])[ENDIF]\r\n[IF fitnesstest_bruce_stage_eight]([fitnesstest_template_bruce_stage_eight], [fitnesstest_bruce_heart_rate_eight], [fitnesstest_bruce_systolic_blood_pressure_eight], [fitnesstest_bruce_diastolic_blood_pressure_eight])[ENDIF]', 'Bruce', 3, 1, '{\"target_fields0\":{\"selection\":\"bruce_stage_one\"}}', 'ColumnChart', 1, '2018-10-11 23:28:17'),
(3, '{\"dataTable\":{\"cols\":[{\"label\":\"Day\",\"type\":\"string\"},{\"label\":\"VO\\u2082max\",\"type\":\"number\"}],\"rows\":[{\"c\":[{\"v\":\"2018/10/12\"},{\"v\":170.567}]},{\"c\":[{\"v\":\"2018/10/11\"},{\"v\":163.146}]}]},\"options\":{\"title\":\"Vo2max\",\"vAxes\":[{\"title\":null,\"minValue\":null,\"maxValue\":null,\"viewWindow\":{\"max\":null,\"min\":null},\"useFormatFromData\":true},{\"viewWindow\":{\"max\":null,\"min\":null},\"minValue\":null,\"maxValue\":null,\"useFormatFromData\":true}],\"legacyScatterChartLabels\":true,\"curveType\":\"function\",\"booleanRole\":\"certainty\",\"lineWidth\":2,\"hAxis\":{\"useFormatFromData\":true,\"minValue\":null,\"maxValue\":null,\"viewWindow\":null,\"viewWindowMode\":null},\"legend\":\"none\",\"width\":600,\"height\":371,\"domainAxis\":{\"direction\":1},\"theme\":\"maximized\",\"interpolateNulls\":true,\"series\":{\"0\":{\"color\":\"#a64d79\"}}},\"state\":{},\"view\":{\"columns\":null,\"rows\":null},\"isDefaultVisualization\":false,\"chartType\":\"LineChart\"}', '([fitnesstest_label_day], [fitnesstest_label_vo2max])\r\n([0_fitnesstest_day], [0_fitnesstest_vo2max])\r\n([1_fitnesstest_day], [1_fitnesstest_vo2max])\r\n([2_fitnesstest_day], [2_fitnesstest_vo2max]])\r\n([3_fitnesstest_day], [3_fitnesstest_vo2max])\r\n([4_fitnesstest_day], [4_fitnesstest_vo2max])', 'Vo2max', 3, 3, '{\"target_fields0\":{\"selection\":\"day\"},\"target_fields1\":{\"selection\":\"vo2max\"}}', 'LineChart', 1, '2018-10-12 13:48:13');', '', 'Fitness Test (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_fitnesstest_server.xml', 'http://www.vdm.io', '', 'MnxgjFaDrp3YgcpTRakS6MFgbPoXauxaYLh1uCupYtU=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 12, '', 1, 29), -(57, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:12:05', '', 'SJStMAudP7ng/sBm0iK0RPflolrulfOskLA32B2CQKU=', '45cYuqhCH35FFnDgYff1nWXE4iIRJFBLFn4xPNJIt40=', '', 'Ebil+Lx31hLp5Voef/f383O3nZcr3CigMYmvDEkTNz8=', '', '', 'A_240', 2, '', 'Health Logs', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_bankableprojects', 'ZtzPx0ECWxoMKqtVwka+aKUV3rVuAtgTXIrc0jKXE3X+Bwclk7BT84b62z8bHq3YRxrJf27roj/5HO149AHOQg==', '', 'b9391695-15ea-43cc-8f89-a9de41ed5d0f', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:28:09', 2, 'Health Log', 'coral_healthlog', '', 4, '', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	 * Add Join Tables based on filter
	 *
	 * @param   object   $query  The database query object
	 * @param   string   $filter  The target area that made the request
	 *
	 * @return array
	 *
	 */
	protected static function joinFormDetails(&$query, $filter = 'none', $db = null)
	{
		// check if we have the DB object
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
		{
			// get the database object
			$db = Factory::getDBO();
		}
		// From the [[[component]]]_type table.
		$query->join('LEFT', $db->quoteName('#__[[[component]]]_type', 't') . ' ON (' . $db->quoteName('a.type') . ' = ' . $db->quoteName('t.id') . ')');
	}

	/**
	 * Add order based on filter
	 *
	 * @param   object   $query  The database query object
	 * @param   string   $filter  The target area that made the request
	 * @param   object   $db     The database object
	 *
	 * @return void
	 *
	 */
	protected static function orderFormDetails(&$query, $filter = 'none', $db = null)
	{
		// check if we have the DB object
		// if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
		// {
			// get the database object
		// 	$db = Factory::getDBO();
		// }
		// the default order is by create date
		$query->order('a.created DESC'); // to insure last shows first
	}

	/**
	 * Get selection  based on type
	 *
	 * @param   string   $table     The main table to select
	 * @param   string   $method    The type of values to return
	 * @param   string   $filter    The kind of filter (to return only values required)
	 * @param   object   $db     The database object
	 *
	 * @return array
	 *
	 */
	public static function getSelection($table = 'form', $method = 'placeholder', $filter = 'none', $db = null)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// prep for placeholders
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			// get the placeholder prefix
			$prefix = self::$params->get('placeholder_prefix', '[[[component]]]');
			$f = '[' . $prefix . '_';
			$b = ']';
		}
		// get status norm fields
		if (method_exists(__CLASS__, 'getStatusNormFields'))
		{
			$norms = self::getStatusNormFields();
		}
		// get charts
		if ('chart' !== $filter && 'field' !== $filter && method_exists(__CLASS__, 'getAvailableCharts'))
		{
			$charts = self::getAvailableCharts();
		}
		// only get what we need
		if ('profile' === $filter)
		{
			// get the fields/columns
			$columns = array('id', 'created', 'modified', 'name');
		}
		// set the values you want to remove after modeling
		elseif ('remove' === $filter)
		{
			// remove params always
			$remove = array($f . 'params' . $b);
			// remove the norms if found
			if (isset($norms) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($norms))
			{
				foreach ($norms as $norm)
				{
					$remove[] = $f . 'status_' . $norm . $b;
				}
			}
			return $remove;
		}
		else
		{
			// check if we have the DB object
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
			{
				// get the database object
				$db = Factory::getDBO();
			}
			// get the database columns of this table
			$columns = $db->getTableColumns("#__[[[component]]]_" . $table, false);
			// always remove these
			$remove = array('asset_id', 'checked_out', 'checked_out_time');
			// if placeholder and none filter then remove some more
			if ('placeholder' === $method && ('report' === $filter || 'email' === $filter))
			{
				$remove[] = 'access';
				$remove[] = 'created_by';
				$remove[] = 'ordering';
				$remove[] = 'version';
				$remove[] = 'params';
				$remove[] = 'published';
				$remove[] = 'modified_by';
				$remove[] = 'modified';
				$remove[] = 'hits';
			}
			// remove
			foreach ($remove as $key)
			{
				unset($columns[$key]);
			}
			// prep the columns
			$columns = array_keys($columns);
		}
		// make sure we have columns
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($columns))
		{
			// convert the columns for query selection
			$selection = array();
			foreach ($columns as $column)
			{
				$selection['a.' . $column] = $f . $column . $b;
				// we must add the params
				if ('profile' !== $filter && 'field' !== $filter)
				{
					// set the label for these fields
					$selection['setLabel->' . $column] = $f . 'label_' . $column . $b;
				}
			}
			// add the linked values
			$selection['t.name'] = $f . 'type_name' . $b;
			// we must add the params
			if ('profile' !== $filter)
			{
				// do some conversion for created date
				if (in_array('created', $columns))
				{
					$selection['setYearMonthDay:created'] = $f . 'day' . $b;
					$selection['setYearMonth:created'] = $f . 'month' . $b;
					$selection['fancyDate:created'] = $f . 'created' . $b;
					// set label for day and month
					$selection['setLabel->day'] = $f . 'label_day' . $b;
					$selection['setLabel->month'] = $f . 'label_month' . $b;
				}
				// add the norms if found
				if (isset($norms) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($norms))
				{
					foreach ($norms as $norm)
					{
						if ('email' === $filter || 'report' === $filter || 'field' === $filter  || 'chart' === $filter)
						{
							$selection['getValueStatus:' . $norm. '|age|gender'] = $f . 'status_' . $norm . $b;
						}
						// do not load for field
						if ('field' !== $filter && 'chart' !== $filter)
						{
							$selection[] = $f . 'status_' . $norm. '_scale' . $b;
							$selection[] = $f . 'status_' . $norm. '_word' . $b;
							$selection[] = $f . 'status_' . $norm. '_table' . $b;
						}
					}
				}
				// add the chart div and JS code (only if filter is not chart)
				if ('chart' !== $filter && 'field' !== $filter && isset($charts) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($charts))
				{
					foreach ($charts as $chart => $values)
					{
						// make sure the chart name is save
						$selection['setChartCode->' . $chart] = $f . $chart . $b;
					}
				}
			}
			return $selection;
		}
		return false;
	}
[CUSTOMCODE=getPlaceHoldersReport]
[CUSTOMCODE=getValueStatus]
[CUSTOMCODE=getStatusNormFields]
[CUSTOMCODE=getChartCode]
[CUSTOMCODE=getAvailableCharts]
[CUSTOMCODE=getMultiChartDataTable]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=getTemplate]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getANYTemplate+Any]
[CUSTOMCODE=getANYFormDetails+Any]
[CUSTOMCODE=getANYCompanyDetails+Any]
[CUSTOMCODE=getANYDetails+form,Form]
[CUSTOMCODE=modelANYDetails+form,Form]
[CUSTOMCODE=paramsModelANYDetails+form,Form]
[CUSTOMCODE=labelModelANYDetails+form,Form]
[CUSTOMCODE=templateModelANYDetails+form,Form]
[CUSTOMCODE=chartModelANYDetails+form,Form]
[CUSTOMCODE=removeANYDetails+form,Form]
[CUSTOMCODE=loadReportTab]
[CUSTOMCODE=getReport]
[CUSTOMCODE=theButler]
[CUSTOMCODE=setTab]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=bcmath]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=getBetween]
[CUSTOMCODE=getCoreName]', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Health Logs', '', '', 'Health Log (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_bankableprojects_server.xml', 'http://www.vdm.io', '', 'krtqJQxW6xiHCLIHWBWvAWWGnNVRNM9fUviM2YkG7LA=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"}}', 1, 12, '', 1, 30), -(58, '', '', '', '', 1, '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, 1, '', '', '', 1, 3, 3, 'Llewellyn van der Merwe', '', 'george-media.txt', '', '', 'Vast Development Method', '1.0.20', 'Copyright (C) 2020. All Rights Reserved', '2019-02-12 21:13:15', '', 'rGg3D1+RxX1sMWck2P3t+KXdTBvPNzxL7jWorxm1v68=', 'OPMNRw3HOt7aql6sBmvzZMmvfA7CPVXkKX8DtaRLKbw=', '', 'K+niBg8TTYxQS2WekpOCXGv8xytOU/k8g5BeYYI5hd0=', '', '', 'A_247', 2, '', 'The MyMakita Products', 'joomla@vdm.io', '', '', 'cGUV2m2W7Lmf2fuwmxGcB5BEGfExdUArJ9cZo9zh899e52jZj1zbIoJ1fxx0Ax24ScJGtjichRWVNvuqHvFVoQ==', '', '4b059a57-6845-419c-bdec-505a537eda95', 'images/vdm/Makita500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⇝', '2020-07-08 01:07:33', 2, 'Products', 'mymakita_products', '', 4, '', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	 * JUST SOME LANG FIX FOR NOW
	 * Text::_('Register Products');
	 * Text::_('Edit Registered Products');
	 **/

	/**
	 * Get selection  based on type
	 *
	 * @param   string   $table     The main table to select
	 * @param   string   $method    The type of values to return
	 * @param   string   $filter    The kind of filter (to return only values required)
	 * @param   object   $db     The database object
	 *
	 * @return array
	 *
	 */
	protected static function getSelection($table = 'form', $method = 'placeholder', $filter = 'none', $db = null)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// prep for placeholders
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			// get the placeholder prefix
			$prefix = self::$params->get('placeholder_prefix', '[[[component]]]');
			$f = '[' . $prefix . '_';
			$b = ']';
		}
		// only get what we need
		if ('profile' === $filter)
		{
			// get the fields/columns
			if (($fields = self::$params->get('profile_fields', false)) !== false && Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($fields))
			{
				$columns = array('id'); // needed for permission check
				foreach ($fields as $field)
				{
					$columns[] = $field->field;
				}
				// add dates for display
				$columns[] = 'created';
				$columns[] = 'modified';
			}
		}
		// set the values you want to remove after modeling
		elseif ('remove' === $filter)
		{
			// remove params always
			$remove = array($f . 'params' . $b);
			return $remove;
		}
		else
		{
			// check if we have the DB object
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
			{
				// get the database object
				$db = Factory::getDBO();
			}
			// get the database columns of this table
			$columns = $db->getTableColumns("#__[[[component]]]_" . $table, false);
			// always remove these
			$remove = array('asset_id', 'checked_out', 'checked_out_time');
			// if placeholder and none filter then remove some more
			if ('placeholder' === $method && ('report' === $filter || 'email' === $filter))
			{
				$remove[] = 'params';
				$remove[] = 'access';
				$remove[] = 'created_by';
				$remove[] = 'id';
				$remove[] = 'ordering';
				$remove[] = 'version';
				$remove[] = 'published';
				$remove[] = 'modified_by';
				$remove[] = 'modified';
				$remove[] = 'hits';
			}
			// remove
			foreach ($remove as $key)
			{
				unset($columns[$key]);
			}
			// prep the columns
			$columns = array_keys($columns);
		}
		// make sure we have columns
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($columns))
		{
			// convert the columns for query selection
			$selection = array();
			foreach ($columns as $column)
			{
				$selection['a.' . $column] = $f . $column . $b;
				// we must add the label
				if ('profile' !== $filter && 'field' !== $filter)
				{
					// set the label for these fields
					$selection['setLabel->' . $column] = $f . 'label_' . $column . $b;
				}
			}
			return $selection;
		}
		return false;
	}

	/**
	 * Get the products from registry
	 *
	 * @return void
	 *
	 */
	public static function getProduct($id, $guid)
	{
		// make sure we have an int and it is grater then 0
		if (!is_numeric($id) && $id < 1)
		{
			return false;
		}
		// get the products from the registry
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);

		// Get from #__[[[component]]]_product_registration as p
		$query->select($db->quoteName(
			array('p.serial','p.dealer_name','p.invoice_number','p.invoice_date','p.brand','p.created','guid'),
			array('serial','dealer_name','invoice_number','invoice_date','brand','created','warranty_number')));
		$query->from($db->quoteName('#__[[[component]]]_product_registration', 'p'));

		// Get from #__[[[component]]]_product as pp
		$query->select($db->quoteName(array('pp.code','pp.warranty','pp.extended','pp.name','pp.type'), array('product_code','warranty','extended','product_name','type')));
		$query->join('LEFT', ($db->quoteName('#__mymakita_products_product', 'pp')) . ' ON (' . $db->quoteName('p.product') . ' = ' . $db->quoteName('pp.code') . ')');

		// Get from #__[[[core]]]_member as m
		$query->select($db->quoteName(array('m.surname'),array('surname')));
		$query->join('LEFT', ($db->quoteName('#__[[[core]]]_member', 'm')) . ' ON (' . $db->quoteName('m.id') . ' = ' . $db->quoteName('p.member') . ')');

		// Get from #__users as u
		$query->select($db->quoteName(array('u.name','u.email'), array('name','email')));
		$query->join('LEFT', ($db->quoteName('#__users', 'u')) . ' ON (' . $db->quoteName('m.user') . ' = ' . $db->quoteName('u.id') . ')');

		// Get from #__[[[core]]]_contactdetails_form as cc
		$query->select($db->quoteName(array('cc.occupation_other','cc.phone','cc.postal','cc.postalcode','cc.suburb'), array('occupation_other','phone','postal','postalcode','suburb')));
		$query->join('LEFT', ($db->quoteName('#__[[[core]]]_contactdetails_form', 'cc')) . ' ON (' . $db->quoteName('p.member') . ' = ' . $db->quoteName('cc.member') . ')');

		// Get from #__[[[core]]]_contactdetails_occupation as oo
		$query->select($db->quoteName(array('oo.name'), array('occupation')));
		$query->join('LEFT', ($db->quoteName('#__[[[core]]]_contactdetails_occupation', 'oo')) . ' ON (' . $db->quoteName('cc.occupation') . ' = ' . $db->quoteName('oo.id') . ')');

		// Get from #__[[[core]]]_contactdetails_region as r
		$query->select($db->quoteName(array('r.name'), array('region')));
		$query->join('LEFT', ($db->quoteName('#__[[[core]]]_contactdetails_region', 'r')) . ' ON (' . $db->quoteName('cc.region') . ' = ' . $db->quoteName('r.id') . ')');

		// Get from #__[[[core]]]_contactdetails_country as tt
		$query->select($db->quoteName(array('tt.name'), array('country')));
		$query->join('LEFT', ($db->quoteName('#__[[[core]]]_contactdetails_country', 'tt')) . ' ON (' . $db->quoteName('cc.country') . ' = ' . $db->quoteName('tt.id') . ')');

		// only return the product in question
		$query->where($db->quoteName('p.form') . ' = ' . $db->quote($guid));
		$query->where($db->quoteName('p.id') . ' = ' . (int) $id);

		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$product = $db->loadObject();
			// do some house cleaning
			$product->full_name = $product->name . ' ' . $product->surname;
			// get warranty
			$warranty = self::getWarrantyDetails($product, false);
			$product->warranty_expire_date = $warranty['expire'];
			$product->warranty_active = $warranty['active'];
			$product->warranty_status = ($warranty['active']) ? Text::_('Under Warranty') : Text::_('Out of Warranty');
			// make sure we are in Australia
			date_default_timezone_set('Australia/Sydney');
			// fix dates
			$product->registration_date = self::setDayMonthYear($product->created);
			// make sure we are in Australia
			date_default_timezone_set('Australia/Sydney');
			// set the invoice date
			$product->invoice_date = self::setDayMonthYear($product->invoice_date + 0);
			// set occupation
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($product->occupation_other) && !Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($product->occupation) )
			{
				$product->occupation = $product->occupation_other;
			}
			// make sure the full_name name is not longer then 60
			$product->full_name = self::sorten($product->full_name, 60, false);
			// make sure the dealer name is not longer then 60
			$product->dealer_name = self::sorten($product->dealer_name, 60, false);
			// make sure the product name is not longer then 40
			$product->product_name = self::sorten($product->product_name, 40, false);
			// remove some stuff no longer needed
			unset($product->occupation_other);
			unset($product->created);
			unset($product->type);
			unset($product->brand);
			unset($product->warranty);
			unset($product->extended);
			// now return product details
			return $product;
		}
		return false;
	}

	/**
	 * Get the products from registry
	 *
	 * @return void
	 *
	 */
	public static function getProducts(&$field, &$data, $brand
	) // data is an object
	{
		// Convert the field to an array.
		$field = array();
		if (self::validateGUID($data->guid)
			&& (($brand == 1 && $data->add_makita_products == 1)
				|| ($brand == 2
					&& $data->add_other_products == 1)))
		{
			// get the products from the registry
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('a.product', 'a.serial', 'a.name', 'a.product_code')));
			$query->from(
				$db->quoteName('#__[[[component]]]_product_registration', 'a')
			);
			$query->where($db->quoteName('a.published') . ' = 1');
			$query->where(
				$db->quoteName('a.form') . ' = ' . $db->quote($data->guid)
			);
			$query->where($db->quoteName('a.brand') . ' = ' . (int) $brand);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$products = $db->loadObjectList();
				foreach ($products as $nr => $product)
				{
					if ($brand == 1)
					{
						$field['makita_products' . $nr] = array(
							'product' => $product->product,
							'serial'  => $product->serial
						);
					}
					else
					{
						$field['other_products' . $nr] = array(
							'name'         => $product->name,
							'product_code' => $product->product_code,
							'serial'       => $product->serial
						);
					}
				}
			}
		}
	}

	/**
	 * Send product registration email
	 *
	 * @return void
	 *
	 */
	public static function sendProductRegistrationEmail(&$recipient)
	{
		// load the website link
		$recipient['makita_url'] = Uri::root(); // 'https://www.makita.com.au/' did hard code this, but was asked to use the website root (dynamic given by Joomla) instead.
		// get the message template
		$message = self::getEmailTemplate();
		// convert $recipient to placeholders
		$placeholders = array();
		foreach ($recipient as $key => $value)
		{
			$placeholders['[' . $key . ']'] = $value;
		}
		return self::sendMessage($recipient, $message, $placeholders);
	}

	/**
	 * Send a Message
	 *
	 * @return boolean
	 *
	 */
	public static function sendMessage(&$recipient, &$message, &$placeholders)
	{
		// make sure we have recipient details
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($recipient) && isset($recipient['email']))
		{
			// make sure we have placeholders
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($placeholders))
			{
				// both html and text
				$html = self::setDynamicData($message['html'], $placeholders);
				$text = self::setDynamicData($message['text'], $placeholders);
				// set mode to HTML
				$mode = 1;
				// set the subject
				$subject = self::setDynamicData($message['subject'], $placeholders);
				// now send the email
				if ([[[Component]]]Email::send($recipient['email'], $subject, $html, $text, $mode))
				{
					return true;
				}
			}
		}
		return false;
	}

	/**
	 * Set the products to the registry
	 *
	 * @return void
	 *
	 */
	public static function setProducts(&$field, &$data, $brand
	) // data is an array
	{
		// save the products to the registry
		if (self::validateGUID($data['guid']))
		{
			$products = array();
			// get the products from the registry
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('a.id', 'a.version', 'a.product', 'a.serial', 'a.name', 'a.product_code', 'a.guid', 'a.created')));
			$query->from(
				$db->quoteName('#__[[[component]]]_product_registration', 'a')
			);
			$query->where(
				$db->quoteName('a.form') . ' = ' . $db->quote($data['guid'])
			);
			$query->where($db->quoteName('a.brand') . ' = ' . (int) $brand);
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$products = $db->loadObjectList();
			}
			// check if we must insert or update products
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($field)
				&& (($brand == 1 && $data['add_makita_products'] == 1)
					|| ($brand == 2 && $data['add_other_products'] == 1)))
			{

				// get the user object
				$user = Factory::getUser();
				// set some defaults
				$todayDate = Factory::getDate()->toSql();
				// store the data
				foreach ($field as $k => $product)
				{
					// build storing object
					$store = new \stdClass();
					$store->form = $data['guid'];
					$store->serial = $product['serial'];
					$store->brand = (int) $brand;
					$store->member = (int) $data['member'];
					$store->dealer_name = $data['dealer_name'];
					$store->invoice_number = $data['invoice_number'];
					$store->invoice_date = $data['invoice_date'];
					$store->published = 1;
					// set product details
					if ($brand == 1 && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($product['product']))
					{
						$store->product = $product['product'];
						// stupid fix for combo (ThisisaComboKit) TODO
						if ('ThisisaComboKit' === $store->serial)
						{
							$store->serial = $store->product . '-' . self::randomkey(7);
						}
					}
					elseif ($brand == 2 && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($product['name'])
						&& Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($product['product_code']))
					{
						$store->name = $product['name'];
						$store->product_code = $product['product_code'];
					}
					else
					{
						// remove from field set
						unset($field[$k]);
						continue;
					}
					// check if we have products in the registry
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($products))
					{
						$searching = true;
						foreach ($products as $nr => $_product)
						{
							// check if product is found
							if ($searching && strcasecmp($store->serial, $_product->serial) == 0 && 
								(
								  ($brand == 1 && strcasecmp($store->product, $_product->product) == 0) ||
								  ($brand == 2 && strcasecmp($store->product_code, $_product->product_code) == 0)
								)
							)
							{
								// map to existing product (ID)
								$store->id = $_product->id;
								// set the GUID
								if (self::validateGUID($_product->guid))
								{
									$store->guid = $_product->guid;
								}
								$store->version = $_product->version + 1;
								$store->modified_by = $user->id;
								$store->modified = $todayDate;
								$store->created = $_product->created;
								// remove from array
								unset($products[$nr]);
								// break out of this loop
								$searching = false;
							}
						}
					}
					// update
					if (isset($store->id))
					{
						// check that we have GUID
						while (!self::validGUID($store->guid, 'product_registration', $store->id))
						{
							$store->guid = self::GUID();
						}
						$db->updateObject(
							'#__[[[component]]]_product_registration', $store,
							'id'
						);
					}
					// insert
					else
					{
						$store->version = 1;
						$store->guid = self::GUID();
						// validate until GUID
						while (!self::validGUID($store->guid, 'product_registration'))
						{
							$store->guid = self::GUID();
						}
						$store->created_by = $user->id;
						$store->created = $todayDate;
						$db->insertObject(
							'#__[[[component]]]_product_registration', $store
						);
					}
					// band=1 means Makita
					if ($store->brand == 1)
					{
						// do the competition check to see if this product qualify
						self::setQualifying($store);
					}
				}
				// Convert the field to an string (json).
				$json = new JRegistry;
				$json->loadArray($field);
				$field = (string) $json;
			}
			else
			{
				// empty the products
				$field = '';
			}
			// if we have products left delete them
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($products))
			{
				// get those we are going to delete
				$delete = array_map(function($product){
					return $product->id;
				}, $products);
				$db = Factory::getDbo();
				$query = $db->getQuery(true);
				// delete all all these
				$conditions = array(
					$db->quoteName('id') . ' IN (' . implode(',', $delete) . ')'
				);
				$query->delete($db->quoteName('#__[[[component]]]_product_registration'));
				$query->where($conditions);
				$db->setQuery($query);
				$db->execute();
			}
		}
		else
		{
			// empty the products
			$field = '';
		}
	}

	protected static function setQualifying(&$product)
	{
		if (($helperClass = self::getHelperClass('com_[[[competition]]]')) !== false && method_exists($helperClass, 'setQualifying'))
		{
			return $helperClass::setQualifying($product);
		}
	}

	/**
	 * The products warranty details
	 *
	 * @var array
	 *
	 */
	protected static $warrantyDetails = array();

	/**
	 * Get the products warranty details
	 *
	 * @return array
	 *
	 */
	public static function getWarrantyDetails(&$product, $add_link = true)
	{
		// band=1 means Makita, and type=1 means this is a product not a combo/kit
		if ($product->brand == 1 && $product->type == 1)
		{
			// to speedup, and avoid double calculations
			$cacheKey = ($add_link) ? $product->guid . '_L' : $product->guid;
			if (!isset(self::$warrantyDetails[$cacheKey]))
			{
				// make sure we are in Australia
				date_default_timezone_set('Australia/Sydney');
				// set the warranty to not being active (until proven otherwise)
				$active = 0;
				// link to get the warranty cert
				$link = null;
				// switch to add extended warranty once
				$should_still_add_extended = true;
				$years_extended = 5;
				// has certificate
				$has_cert = false;
				// make sure we are in Australia
				date_default_timezone_set('Australia/Sydney');
				// get the time stamp for now
				$today_date = time();
				// make sure we are in Australia
				date_default_timezone_set('Australia/Sydney');
				// the registration date is the created date
				$created_date = strtotime($product->created);
				// set the invoice date
				$invoice_date = (int) $product->invoice_date;
				// expire date default to invoice date
				$expire_date = $invoice_date;
				// add normal warranty if exist
				if ($product->warranty > 0)
				{
					// make sure we are in Australia
					date_default_timezone_set('Australia/Sydney');
					// update expire date with actual warranty
					$expire_date = strtotime('+' . $product->warranty .'years', $invoice_date);
					// deduct the normal warranty from extended warranty
					$years_extended = $years_extended - $product->warranty;

					// we count years added
					$years_added = $product->warranty;
				}
				// add extended date if product qualify
				if ($should_still_add_extended && $product->extended == 1)
				{
					// make sure we are in Australia
					date_default_timezone_set('Australia/Sydney');
					// step forward 30 days from purchase date (invoice date)
					$forward_thirty_date = strtotime('+30days', $invoice_date);
					// now check if the registration falls in the 
					// qualifying 30 days after purchasing the product
					// so if the forward_thirty_date is greater or equal to created_date
					// the the product qualifies
					if ($forward_thirty_date >= $created_date)
					{
						// make sure we are in Australia
						date_default_timezone_set('Australia/Sydney');
						// add the extended warranty years
						$expire_date = strtotime('+' . $years_extended . 'years', $expire_date);
						// make sure we add it only once
						$should_still_add_extended = false;
						// has certificate
						$has_cert = true;
					}
					// make sure we are still in 2020 and before end of August
					$this_year = self::setYear($today_date);
					$this_month = self::setMonth($today_date);
					// see if this falls in COVID-19 special
					if ($should_still_add_extended && '2020' == $this_year && $this_month <= 8)
					{
						// check if invoice year is 2020
						$year = self::setYear($invoice_date);
						// check if month is between January and July
						$month = self::setMonth($invoice_date);
						// if the criteria is met, we add extended warranty
						if ('2020' == $year && $month <= 7)
						{
							// make sure we are in Australia
							date_default_timezone_set('Australia/Sydney');
							// add the extended warranty years
							$expire_date = strtotime('+' . $years_extended . 'years', $expire_date);
							// make sure we add it only once TODO more options could be added
							$should_still_add_extended = false;
							// has certificate
							$has_cert = true;
						}
					}
				}
				// now check if warranty is active
				if ($expire_date >= $today_date)
				{
					// activate warranty
					$active = 1;
					// only add the link if asked to (default is true)
					if ($add_link && $has_cert)
					{
						// set the download link
						$link = Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_("index.php?option=com_[[[component]]]&task=download.warranty&key=" . urlencode(self::encrypt($product->id)) . "&guid=" . $product->form . "&" . Joomla___5ba38513_5c4f_4b0d_935e_49e986a6bce8___Power::getFormToken() . "=1");
					}
				}
				// make sure we are in Australia
				date_default_timezone_set('Australia/Sydney');
				// no return warranty details
				self::$warrantyDetails[$cacheKey] = array('active' => $active, 'expire' => self::setDayMonthYear($expire_date), 'link' => $link, 'qualify' => $has_cert);
			}
			// check if the value was indeed set
			if (isset(self::$warrantyDetails[$cacheKey]))
			{
				return self::$warrantyDetails[$cacheKey];
			}
		}
		// for other brands and combo/kit's
		return array('active' => 0, 'expire' => 0, 'link' => null, 'qualify' => false);
	}

	/**
	 * Main image link
	 **/
	protected static $imageLink;

	/**
	 * Dummy Image link
	 **/
	protected static $dummyImageLink;

	/**
	 * Get the products image link
	 *
	 * @return string
	 *
	 */
	public static function getImageLink(&$product)
	{
		if ($product->brand == 1 && ($path = self::getVar('images', strtolower($product->code), 'code', 'path')) !== false)
		{
			return Uri::root() . 'images/products/' . $path;
		}
		// return the dummy image TODO we can add types if we like
		if (!Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check(self::$dummyImageLink))
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
			{
				self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
			}
			// get the dummy image path.
			self::$dummyImageLink = Uri::root() . self::$params->get('image_dummy_path', 'images/logo.png');
			// check if image exist
			if (!self::urlExists(self::$dummyImageLink))
			{
				self::$dummyImageLink = '#';
			}
		}
		return self::$dummyImageLink;
	}

	/**
	* Get the product registration email template
	*
	* @return  array    On success the email template
	*
	*/
	public static function getEmailTemplate()
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_###component###');
		}
		return array(
			'subject' => self::$params->get('subject', Text::_('[name], you have successfully registered your tools with MyMakita')),
			'html' => self::$params->get('htmlbody', '[name]<br />[makita_url]'),
			'text' => self::$params->get('textbody', '[name]\n[makita_url]')
			);
	}

	/**
	* Get the warranty template
	*
	* @return  string    On success the warranty template
	*
	*/
	public static function getWarrantyTemplate()
	{
		return LOCKBASE64((((<table width="800">
<tbody><tr style="line-height: 152px;"><td width="150"></td><td></td></tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[full_name]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[phone]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[email]</b>
</td>
</tr>
</tbody></table>

<table width="800">
<tbody><tr style="line-height: 13px;"><td width="150"></td><td></td></tr>
<tr style="font-size:15px; line-height: 32px; vertical-align:bottom;">
<td></td>
<td>
<b>[dealer_name]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 32px; vertical-align:bottom;">
<td></td>
<td>
<b>[invoice_number]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 32px; vertical-align:bottom;">
<td></td>
<td>
<b>[invoice_date]</b>
</td>
</tr>
</tbody></table>

<table width="720">
<tbody><tr style="line-height: 28px;"><td width="350"></td><td></td></tr>
<tr style="font-size:15px; line-height:33px; vertical-align:bottom;">
<td></td>
<td>
<b>[product_code]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[serial]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[product_name]</b>
</td>
</tr>
</tbody></table>

<table width="720">
<tbody><tr style="line-height: 20px;"><td width="350"></td><td></td></tr>
<tr style="font-size:15px; line-height:33px; vertical-align:bottom;">
<td></td>
<td>
<b>[warranty_number]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[invoice_date]</b>
</td>
</tr>
<tr style="font-size:15px; line-height: 33px; vertical-align:bottom;">
<td></td>
<td>
<b>[warranty_expire_date]</b>
</td>
</tr>
</tbody></table>))));
	}
[CUSTOMCODE=theButler]
[CUSTOMCODE=getPlaceHoldersReport]
[CUSTOMCODE=getANYFormDetails+Any]
[CUSTOMCODE=getANYDetails+form,Form]
[CUSTOMCODE=modelANYDetails+form,Form]
[CUSTOMCODE=labelModelANYDetails+form,Form]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getLinkOptions]
[CUSTOMCODE=mimeType]
[CUSTOMCODE=writeFile]
[CUSTOMCODE=getBetween]
[CUSTOMCODE=gUID]
[CUSTOMCODE=crypt]
[CUSTOMCODE=getCrypt]
[CUSTOMCODE=getCryptPassUser]
[CUSTOMCODE=composeVENDOR+phpseclib]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=canAccessMemberData]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=arrayPartition]
 [CUSTOMCODE=urlExists]', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbQ29tcG9uZW50IGltYWdlXShodHRwczovL3d3dy52ZG0uaW8vaW1hZ2VzL01ha2l0YTUwMC5qcGcgIlRoZSBNYWtpdGEgQ29tcG9uZW50IikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'The MyMakita Products', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9pbWFnZXNgICgNCglgY29kZWAgVkFSQ0hBUig2NCkgTk9UIE5VTEwgREVGQVVMVCAnJywNCglgcGF0aGAgVkFSQ0hBUigyNTUpIE5PVCBOVUxMIERFRkFVTFQgJycsDQoJUFJJTUFSWSBLRVkgIChgY29kZWApDQopIEVOR0lORT1NeUlTQU0gREVGQVVMVCBDSEFSU0VUPXV0Zjg7', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9pbWFnZXNgOw==', 'Products (mymakita)', '.git', '', '', 1, '', 'http://www.vdm.io', '', 'ypLnpEqOfQEPOTOqxYyDK6yFt8umORR1fhiC/6K0TfU=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 176, '', 1, 31), -(59, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', 1, '', '', '{}', '', '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.7', 'Copyright (C) 2015. All Rights Reserved', '2019-02-12 21:14:30', '', 'C3Zg8urLsFMNpxaom1+0jJkHK1dEotIRUb1ZNX3RWbk=', 'XulMeX5W2+ecezoEL1+gulTaaJQf6baZNTbdTSujzP0=', '', 'DrAWJCUprUjO68dd93yw+EUa+CvH0XW4XxiC2AYPZng=', '', '', 'A_202', 2, '', 'Orthopedic', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_orthopedic', '3x5PSUKI0txZMgQTO2lfjAspJV1B65jIBD6H0O3n9pOylGn6kZ9UCzMYnDsJXHzY', '', 'f1b1ab96-6231-44f5-a21c-4d00fc7d2cb6', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-12-19 22:28:19', 2, 'Orthopedic', 'coral_orthopedic', '', 4, '', '', 'W0NVU1RPTUNPREU9b3J0aG9wZWRpY0hlbHBlckJvdGhd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Orthopedic', 'LS0NCi0tIER1bXBpbmcgZGF0YSBmb3IgdGFibGUgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlYA0KLS0NCg0KSU5TRVJUIElOVE8gYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlYCAoYGlkYCwgYGFsaWFzYCwgYGRlc2NyaXB0aW9uYCwgYG5hbWVgLCBgcHVibGlzaGVkYCwgYGNyZWF0ZWRgKSBWQUxVRVMNCigxLCAnYWN0aXZlLXJhbmdlLW9mLW1vdGlvbicsICcnLCAnQWN0aXZlIFJhbmdlIG9mIE1vdGlvbicsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooMiwgJ2Z1bmN0aW9uYWwtbW92ZW1lbnRzJywgJycsICdGdW5jdGlvbmFsIE1vdmVtZW50cycsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooMywgJ21hbnVhbC1tdXNjbGUtdGVzdCcsICcnLCAnTWFudWFsIE11c2NsZSBUZXN0JywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCig0LCAnbXVzY2xlLWxlbmd0aCcsICcnLCAnTXVzY2xlIExlbmd0aCcsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooNSwgJ211c2NsZS1zdHJlbmd0aC10ZXN0JywgJycsICdNdXNjbGUgU3RyZW5ndGggVGVzdCcsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooNiwgJ211c2NsZS10ZXN0JywgJycsICdNdXNjbGUgVGVzdCcsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooNywgJ25ldXJvbG9naWNhbC1leGFtJywgJycsICdOZXVyb2xvZ2ljYWwgRXhhbScsIDEsICcyMDE4LTEyLTE4IDIzOjIwOjQzJyksDQooOCwgJ3BhbHBhdGlvbicsICcnLCAnUGFscGF0aW9uJywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCig5LCAncGFzc2l2ZS1yYW5nZS1vZi1tb3Rpb24nLCAnJywgJ1Bhc3NpdmUgUmFuZ2Ugb2YgTW90aW9uJywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCigxMCwgJ3NwZWNpYWwtdGVzdCcsICcnLCAnU3BlY2lhbCBUZXN0JywgMSwgJzIwMTgtMTItMTggMjM6MjA6NDMnKSwNCigxMSwgJ3N0cmVuZ3RoLXRlc3QnLCAnJywgJ1N0cmVuZ3RoIFRlc3QnLCAxLCAnMjAxOC0xMi0xOCAyMzoyMDo0MycpOw==', '', 'Orthopedic (coral)', '.git', '', '', 1, 'https://www.vdm.io/updates/coral_orthopedic_server.xml', 'http://www.vdm.io', '', 'wkO7vaI4Mdw7BqUTMYlqxUqWoEo+M5Ch35qN7dZ9mi8=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"}}', 1, 13, '', 1, 32), -(60, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, 1, '', '', '', 1, '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.7', 'Copyright (C) 2015. All Rights Reserved', '2019-05-07 20:25:06', '', 'duF73iYN4QhKZ1/NE9GcVbG8VUbkP+aM060DGXwMqn4=', '3uO+1kKg9R603fAVO+dbA0Hkw/yZ9trV6dEcX2v+7Xo=', '', 'ecp2UWis3Sbd5VUvxquIULKhgJE6T1w5mNciWyI2ZUw=', '', '', 'A_213', 2, '', 'Invoicing', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_invoicing', 'k9EtnDjnEiCc0yQHlC9QpQ/m65IkMacyYQiYHmUAKcnKa0MBVqrah7fPljDcNPyVbcTFN27S6M1U97YLGNLqkw==', '', 'ccd30536-16a0-427f-98f9-327bb2f0ab4e', 'images/CORAL300.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '☆', '2021-03-08 03:18:14', 2, 'Invoicing', 'coral_invoicing', '', 4, '', '', 'CS8qKg0KCSogdGhlIHBhcmFtcw0KCSoqLw0KCXByb3RlY3RlZCBzdGF0aWMgJHBhcmFtczsNCg0KCS8qKg0KCSAqIEdldCBzZWxlY3Rpb24gIGJhc2VkIG9uIHR5cGUNCgkgKg0KCSAqIEBwYXJhbSAgIHN0cmluZyAgICR0YWJsZSAgICAgVGhlIG1haW4gdGFibGUgdG8gc2VsZWN0DQoJICogQHBhcmFtICAgc3RyaW5nICAgJG1ldGhvZCAgICBUaGUgdHlwZSBvZiB2YWx1ZXMgdG8gcmV0dXJuDQoJICogQHBhcmFtICAgc3RyaW5nICAgJGZpbHRlciAgICBUaGUga2luZCBvZiBmaWx0ZXIgKHRvIHJldHVybiBvbmx5IHZhbHVlcyByZXF1aXJlZCkNCgkgKiBAcGFyYW0gICBvYmplY3QgICAkZGIgICAgIFRoZSBkYXRhYmFzZSBvYmplY3QNCgkgKg0KCSAqIEByZXR1cm4gYXJyYXkNCgkgKg0KCSAqLw0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0U2VsZWN0aW9uKCR0YWJsZSA9ICdmb3JtJywgJG1ldGhvZCA9ICdwbGFjZWhvbGRlcicsICRmaWx0ZXIgPSAnbm9uZScsICRkYiA9IG51bGwpDQoJew0KCQkvLyBnZXQgdGhlIGdsb2JhbCBzZXR0aW5ncw0KCQlpZiAoIVN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKHNlbGY6OiRwYXJhbXMpKQ0KCQl7DQoJCQlzZWxmOjokcGFyYW1zID0gSm9vbWxhX19fYWViOGU0NjNfMjkxZl80NDQ1XzlhYzRfMzRiNjM3YzEyZGJkX19fUG93ZXI6OmdldFBhcmFtcygnY29tX1tbW2NvbXBvbmVudF1dXScpOw0KCQl9DQoJCS8vIHByZXAgZm9yIHBsYWNlaG9sZGVycw0KCQkkZiA9ICcnOw0KCQkkYiA9ICcnOw0KCQlpZiAoJ3BsYWNlaG9sZGVyJyA9PT0gJG1ldGhvZCkNCgkJew0KCQkJLy8gZ2V0IHRoZSBwbGFjZWhvbGRlciBwcmVmaXgNCgkJCSRwcmVmaXggPSBzZWxmOjokcGFyYW1zLT5nZXQoJ3BsYWNlaG9sZGVyX3ByZWZpeCcsICdbW1tjb21wb25lbnRdXV0nKTsNCgkJCSRmID0gJ1snIC4gJHByZWZpeCAuICdfJzsNCgkJCSRiID0gJ10nOw0KCQl9DQoJCS8vIG9ubHkgZ2V0IHdoYXQgd2UgbmVlZA0KCQlpZiAoJ3Byb2ZpbGUnID09PSAkZmlsdGVyKQ0KCQl7DQoJCQkvLyBnZXQgdGhlIGZpZWxkcy9jb2x1bW5zDQoJCQlpZiAoKCRmaWVsZHMgPSBzZWxmOjokcGFyYW1zLT5nZXQoJ3Byb2ZpbGVfZmllbGRzJywgZmFsc2UpKSAhPT0gZmFsc2UgJiYgU3VwZXJfX185MTAwNDUyOV85NGE5XzQ1OTBfYjg0Ml9lN2M2YjYyNGVjZjVfX19Qb3dlcjo6Y2hlY2soJGZpZWxkcykpDQoJCQl7DQoJCQkJJGNvbHVtbnMgPSBhcnJheSgnaWQnKTsgLy8gbmVlZGVkIGZvciBwZXJtaXNzaW9uIGNoZWNrDQoJCQkJZm9yZWFjaCAoJGZpZWxkcyBhcyAkZmllbGQpDQoJCQkJew0KCQkJCQkkY29sdW1uc1tdID0gJGZpZWxkLT5maWVsZDsNCgkJCQl9DQoJCQkJLy8gYWRkIGRhdGVzIGZvciBkaXNwbGF5DQoJCQkJJGNvbHVtbnNbXSA9ICdjcmVhdGVkJzsNCgkJCQkkY29sdW1uc1tdID0gJ21vZGlmaWVkJzsNCgkJCX0NCgkJfQ0KCQkvLyBzZXQgdGhlIHZhbHVlcyB5b3Ugd2FudCB0byByZW1vdmUgYWZ0ZXIgbW9kZWxpbmcNCgkJZWxzZWlmICgncmVtb3ZlJyA9PT0gJGZpbHRlcikNCgkJew0KCQkJLy8gbm90aW5nIHRvIHJlbW92ZQ0KCQkJcmV0dXJuIGZhbHNlOw0KCQl9DQoJCWVsc2UNCgkJew0KCQkJLy8gY2hlY2sgaWYgd2UgaGF2ZSB0aGUgREIgb2JqZWN0DQoJCQlpZiAoIVN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKCRkYikpDQoJCQl7DQoJCQkJLy8gZ2V0IHRoZSBkYXRhYmFzZSBvYmplY3QNCgkJCQkkZGIgPSBGYWN0b3J5OjpnZXREQk8oKTsNCgkJCX0NCgkJCS8vIGdldCB0aGUgZGF0YWJhc2UgY29sdW1ucyBvZiB0aGlzIHRhYmxlDQoJCQkkY29sdW1ucyA9ICRkYi0+Z2V0VGFibGVDb2x1bW5zKCIjX19bW1tjb21wb25lbnRdXV1fIiAuICR0YWJsZSwgZmFsc2UpOw0KCQkJLy8gYWx3YXlzIHJlbW92ZSB0aGVzZQ0KCQkJJHJlbW92ZSA9IGFycmF5KCdhc3NldF9pZCcsICdjaGVja2VkX291dCcsICdjaGVja2VkX291dF90aW1lJyk7DQoJCQkvLyBpZiBwbGFjZWhvbGRlciBhbmQgbm9uZSBmaWx0ZXIgdGhlbiByZW1vdmUgc29tZSBtb3JlDQoJCQlpZiAoJ3BsYWNlaG9sZGVyJyA9PT0gJG1ldGhvZCAmJiAoJ3JlcG9ydCcgPT09ICRmaWx0ZXIgfHwgJ2VtYWlsJyA9PT0gJGZpbHRlcikpDQoJCQl7DQoJCQkJJHJlbW92ZVtdID0gJ3BhcmFtcyc7DQoJCQkJJHJlbW92ZVtdID0gJ2FjY2Vzcyc7DQoJCQkJJHJlbW92ZVtdID0gJ2NyZWF0ZWRfYnknOw0KCQkJCSRyZW1vdmVbXSA9ICdpZCc7DQoJCQkJJHJlbW92ZVtdID0gJ29yZGVyaW5nJzsNCgkJCQkkcmVtb3ZlW10gPSAndmVyc2lvbic7DQoJCQkJJHJlbW92ZVtdID0gJ3B1Ymxpc2hlZCc7DQoJCQkJJHJlbW92ZVtdID0gJ21vZGlmaWVkX2J5JzsNCgkJCQkkcmVtb3ZlW10gPSAnbW9kaWZpZWQnOw0KCQkJCSRyZW1vdmVbXSA9ICdoaXRzJzsNCgkJCX0NCgkJCS8vIHJlbW92ZQ0KCQkJZm9yZWFjaCAoJHJlbW92ZSBhcyAka2V5KQ0KCQkJew0KCQkJCXVuc2V0KCRjb2x1bW5zWyRrZXldKTsNCgkJCX0NCgkJCS8vIHByZXAgdGhlIGNvbHVtbnMNCgkJCSRjb2x1bW5zID0gYXJyYXlfa2V5cygkY29sdW1ucyk7DQoJCX0NCgkJLy8gbWFrZSBzdXJlIHdlIGhhdmUgY29sdW1ucw0KCQlpZiAoU3VwZXJfX18wYTU5YzY1Y185ZGFmXzRiYzlfYmFmNF9lMDYzZmY5ZTZhOGFfX19Qb3dlcjo6Y2hlY2soJGNvbHVtbnMpKQ0KCQl7DQoJCQkvLyBjb252ZXJ0IHRoZSBjb2x1bW5zIGZvciBxdWVyeSBzZWxlY3Rpb24NCgkJCSRzZWxlY3Rpb24gPSBhcnJheSgpOw0KCQkJLy8gbG9hZCB0aGUgY29sdW1ucyB0byBzZWxlY3Rpb24NCgkJCWZvcmVhY2ggKCRjb2x1bW5zIGFzICRjb2x1bW4pDQoJCQl7DQoJCQkJJHNlbGVjdGlvblsnYS4nIC4gJGNvbHVtbl0gPSAkZiAuICRjb2x1bW4gLiAkYjsNCgkJCQkvLyB3ZSBtdXN0IGFkZCB0aGUgbGFiZWxzDQoJCQkJaWYgKCdwcm9maWxlJyAhPT0gJGZpbHRlciAmJiAnZmllbGQnICE9PSAkZmlsdGVyKQ0KCQkJCXsNCgkJCQkJLy8gc2V0IHRoZSBsYWJlbCBmb3IgdGhlc2UgZmllbGRzDQoJCQkJCSRzZWxlY3Rpb25bJ3NldExhYmVsLT4nIC4gJGNvbHVtbl0gPSAkZiAuICdsYWJlbF8nIC4gJGNvbHVtbiAuICRiOw0KCQkJCX0NCgkJCX0NCgkJCXJldHVybiAkc2VsZWN0aW9uOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoNCgkvKioNCgkgKiBHZXQgaW52b2ljZSBpdGVtcw0KCSAqDQoJICogQHBhcmFtICAgb2JqZWN0ICAgJGl0ZW0gICAgIFRoZSBpdGVtIG9iamVjdA0KCSAqDQoJICogQHJldHVybiB2b2lkDQoJICoNCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGdldEl0ZW1zKCYkaXRlbSkNCgl7DQoJCS8vIGNoZWNrIGlmIGludm9pY2UgZXhpc3QNCgkJaWYgKGlzc2V0KCRpdGVtLT5pZCkgJiYgJGl0ZW0tPmlkID4gMCkNCgkJew0KCQkJLy8gZ2V0IHRoZSBkYXRhYmFzZSBvYmplY3QNCgkJCSRkYiA9IEZhY3Rvcnk6OmdldERCTygpOw0KCQkJLy8gQ3JlYXRlIGEgbmV3IHF1ZXJ5IG9iamVjdC4NCgkJCSRxdWVyeSA9ICRkYi0+Z2V0UXVlcnkodHJ1ZSk7DQoJCQkkcXVlcnktPnNlbGVjdCgkZGItPnF1b3RlTmFtZShhcnJheSgnaWQnLCAncHJvZHVjdF9jb2RlJywgJ3RheGVkJywgJ21lbWJlcicsICdjb21wYW55JywgJ3ByaWNlJywgJ2Rlc2NyaXB0aW9uJykpKTsNCgkJCSRxdWVyeS0+ZnJvbSgkZGItPnF1b3RlTmFtZSgnI19fW1tbY29tcG9uZW50XV1dX2ludm9pY2VfaXRlbScpKTsNCgkJCSRxdWVyeS0+d2hlcmUoJGRiLT5xdW90ZU5hbWUoJ2Zvcm0nKSAuICcgPSAnIC4gKGludCkgJGl0ZW0tPmlkKTsNCgkJCSRkYi0+c2V0UXVlcnkoJHF1ZXJ5KTsNCgkJCSRkYi0+ZXhlY3V0ZSgpOw0KCQkJaWYgKCRkYi0+Z2V0TnVtUm93cygpKQ0KCQkJew0KCQkJCS8vIHN0YXJ0IGJ1aWxkaW5nIHN1YmZvcm0NCgkJCQkkaXRlbS0+aXRlbXMgPSBhcnJheSgpOw0KCQkJCSRpdGVtLT5jb21wYW5pZXMgPSBhcnJheSgpOw0KCQkJCSRpdGVtcyA9ICRkYi0+bG9hZE9iamVjdExpc3QoKTsNCgkJCQlmb3JlYWNoICgkaXRlbXMgYXMgJHIgPT4gJGxpbmUpDQoJCQkJew0KCQkJCQkvLyBsb2FkIGl0ZW1zDQoJCQkJCSRpdGVtLT5pdGVtc1snaXRlbXMnIC4gJHJdID0gYXJyYXkoKTsNCgkJCQkJJGl0ZW0tPml0ZW1zWydpdGVtcycgLiAkcl1bJ2hhc2gnXSA9ICRsaW5lLT5pZDsNCgkJCQkJJGl0ZW0tPml0ZW1zWydpdGVtcycgLiAkcl1bJ3Byb2R1Y3RfY29kZSddID0gJGxpbmUtPnByb2R1Y3RfY29kZTsNCgkJCQkJJGl0ZW0tPml0ZW1zWydpdGVtcycgLiAkcl1bJ2Rlc2NyaXB0aW9uJ10gPSAkbGluZS0+ZGVzY3JpcHRpb247DQoJCQkJCSRpdGVtLT5pdGVtc1snaXRlbXMnIC4gJHJdWydwcmljZSddID0gJGxpbmUtPnByaWNlOw0KCQkJCQkkaXRlbS0+aXRlbXNbJ2l0ZW1zJyAuICRyXVsndGF4ZWQnXSA9ICRsaW5lLT50YXhlZDsNCgkJCQkJLy8gJGl0ZW0tPml0ZW1zWydpdGVtcycgLiAkcl1bJ3F0eSddID0gJGxpbmUtPnF0eTsNCgkJCQkJLy8gbG9hZCBjb21wYW5pZXMNCgkJCQkJJGl0ZW0tPmNvbXBhbmllc1tdID0gJGxpbmUtPmNvbXBhbnk7DQoJCQkJfQ0KCQkJfQ0KCQl9DQoJfQ0KDQoJLyoqDQoJICogc2F2ZSBpbnZvaWNlIGl0ZW1zDQoJICoNCgkgKiBAcGFyYW0gICBhcnJheSAgICRpdGVtICAgICBUaGUgaXRlbSBhcnJheQ0KCSAqDQoJICogQHJldHVybiB2b2lkDQoJICoNCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIHNhdmVJdGVtcygmJGl0ZW0pDQoJew0KCQkvLyBjaGVjayBpZiBpbnZvaWNlIGV4aXN0DQoJCWlmIChpc3NldCgkaXRlbVsnaWQnXSkgJiYgJGl0ZW1bJ2lkJ10gPiAwKQ0KCQl7DQoJCQkvLyBtb3JlIHNvb24NCgkJfQ0KCX0NCltDVVNUT01DT0RFPWdldEZvbGRlclBhdGhdDQpbQ1VTVE9NQ09ERT10aGVCdXRsZXJdDQpbQ1VTVE9NQ09ERT1nZXRQbGFjZUhvbGRlcnNSZXBvcnRdDQpbQ1VTVE9NQ09ERT1nZXRBTllEZXRhaWxzK2Zvcm0sRm9ybV0NCltDVVNUT01DT0RFPW1vZGVsQU5ZRGV0YWlscytmb3JtLEZvcm1dDQpbQ1VTVE9NQ09ERT1sYWJlbE1vZGVsQU5ZRGV0YWlscytmb3JtLEZvcm1dDQpbQ1VTVE9NQ09ERT1yZW1vdmVBTllEZXRhaWxzK2Zvcm0sRm9ybV0NCltDVVNUT01DT0RFPWdldE1lbWJlck5hbWVdDQpbQ1VTVE9NQ09ERT1uaWNlRmFuY3lEYXRlXQ0KW0NVU1RPTUNPREU9Z2V0Q29yZU5hbWVd', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ0KW0NVU1RPTUNPREU9dGVzdElmQ29tcGFueUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Invoicing', '', '', 'Invoicing (coral)', '.git', '', 1, 1, 'https://www.vdm.io/updates/coral_billing_server.xml', 'http://www.vdm.io', '', 'Hz9S2dRlC31zdUbI6Se0qMK8BTuJqlgV16VhmPzFvbg=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 25, '', 1, 33), -(61, '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.2', 'Copyright (C) 2015. All Rights Reserved', '2019-06-24 12:49:07', '', 'n5BVLqYY61IDBZjyKKeBTi3PQR54i7v8rGoNwavhPgs=', '9ygtntEElSNNzfIKkn+gnd1EpsiUyhqV7jAfyvtyhn0=', '', 'vuP+5AtGk9ERYFsgT1Dxg663LrhU+d9FZZOCe7Jcqm4=', '', '', 'A_216', 2, '', 'Importing Tool', 'Joomla@vdm.io', '', '', 'a8n/ZinoyVCee7VxyI/QzyC867sY8+gdqp3MeWoZ9wc=', '', '3ffa1cc4-f8a0-4634-b4b3-1284c6af3b71', '', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2019-06-24 12:55:08', '', 'Importing Tool', 'importingtool', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Importing Tool', '', '', 'Importing Tool', '.git', '', '', 1, '', 'https://www.vdm.io/', '', '69/Iny0Vpc7HnQ9Z0NuCkAbvqk7MbjDQGM5cecflQBQ=', '', '', 1, 4, '', 1, 71), -(62, 1, '', '', '', '', '', '', '', 1, '', '', 1, 1, '', '', '', '', '', '', 1, '', 1, '', '', 1, '{}', 3, 1, 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.5', 'Copyright (C) 2015. All Rights Reserved', '2019-09-25 12:57:04', '', 'WJQGIiIAJINZg6MshYpOG+wYEjZxxPrMeeBW72hCQQA=', 'WAvyW/Ys6au3aN/lDopdZsfch1yxT2jghvhSQv0OGMU=', '', 'CsPjdpjUhnXzWNfsh1DGu81c46yHp1cvpcH471e/tng=', '', '', '', 1, '', 'A secure file repository.', 'joomla@vdm.io', '', 'https://vdm.bz/jcb-document-manager', 'jflVSFC/q6reGgpn/E2L+jgbmV79TOt8EQ4pknhJD4iT8FmAd10Tz1XmxBDVZ93QPKhkNyeorYC3NUgV16DNHg==', '', '2ca5b474-ca30-4577-913e-842a77e295ff', 'images/vdm/SR500.jpg', '', 'https://github.com/vdm-io/JCB-Packages/raw/master/JCB_documentManager.zip', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2021-03-08 03:13:35', 2, 'Secure Repository', 'SecureRepository', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9ZmlsZUhlbHBlckJvdGhd', 'W0NVU1RPTUNPREU9Y291bnRMb2NhbERvd25sb2FkXQ==', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXSgvYWRtaW5pc3RyYXRvci9jb21wb25lbnRzL2NvbV8jIyNjb21wb25lbnQjIyMvYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMgQ29tcG9uZW50IE51bWJlcg0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCiMgSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyDQoNCkZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IEpDQiB2aXNpdCBbVkRNXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKSBUb2RheSEgVGhlIGZ1dHVyZSBpcyBoZXJlIQ==', '', '', 'Secure File Repository', '', '', 'Secure Repository', '.git', '', 1, 2, 'https://www.vdm.io/updates/securerepository_server.xml', 'https://www.vdm.io/', '', 'dYJ+HemHdp1NE8uXQ/TfzLW3yZdv69Xq8aBSEfHR+pQ=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 27, '', 1, 15), -(63, 1, '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, '', '', '', '{}', '', 1, 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.4', 'Copyright (C) 2019 Vast Development Method. All rights reserved.', '2019-08-01 00:28:27', '', 'v2k4J0qsLE0E8nhLDz9zaVcCJHiADgckA+lBmOVV4ZA=', 'BfPUJkUrVutxYIDWt8i46MwpOE+JBPGPCN8xkLK5SdY=', '', 'kYoJjyBPIKCuC/DHdF8tEliOkOli3MEqrvWyj5qUZhc=', '', '', '', 1, '', 'Curriculum Builder', 'dev@vdm.io', '', '', '26mWghoAiABgwOQjiMXXhqHAXyS6SsYxbNhl8ocxPjE=', '', '4c3b9815-8930-4f11-8ad7-ad5b552927c2', 'images/vdm/CUB500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, 'ℂ𝕃', '2020-11-22 03:45:54', 3, 'Curriculum Builder', 'curriculumbuilder', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'CS8qKg0KCSogVGhlIGdsb2JhbCBwYXJhbXMNCgkqKi8NCglwcm90ZWN0ZWQgc3RhdGljICRwYXJhbXMgPSBmYWxzZTsNCg0KCS8qKg0KCSogIHNldCB0aGUgc2Vzc2lvbiBkZWZhdWx0cyBpZiBub3Qgc2V0DQoJKiovDQoJcHJvdGVjdGVkIHN0YXRpYyBmdW5jdGlvbiBzZXRTZXNzaW9uRGVmYXVsdHMoKQ0KCXsNCgkJLy8gbm90aW5nIGZvciBub3cNCgkJcmV0dXJuIHRydWU7DQoJfQ0KW0NVU1RPTUNPREU9dGhlQnV0bGVyXQ0KW0NVU1RPTUNPREU9Z1VJRF0NCltDVVNUT01DT0RFPWNyeXB0XQ0KW0NVU1RPTUNPREU9Z2V0Q3J5cHRdDQpbQ1VTVE9NQ09ERT1nZXRDcnlwdFBhc3NdDQpbQ1VTVE9NQ09ERT1nZXRFZGl0QnV0dG9uXQ0KW0NVU1RPTUNPREU9Z2V0RWRpdEJ1dHRvbkdVSURdDQpbQ1VTVE9NQ09ERT1zZXRTdWJmb3JtVGFibGVdDQpbQ1VTVE9NQ09ERT1uaWNlRmFuY3lEYXRlXQ0KW0NVU1RPTUNPREU9YmNtYXRoXQ0KW0NVU1RPTUNPREU9Y29tcG9zZVZFTkRPUitwaHBzZWNsaWJd', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KVGhpcyBpcyBhIFtKb29tbGEgMy54XShodHRwOi8vd3d3Lmpvb21sYS5vcmcvKSBjb21wb25lbnQuDQoNCiAhWyMjI0NvbXBvbmVudF9uYW1lIyMjIGltYWdlXSgvYWRtaW5pc3RyYXRvci9jb21wb25lbnRzL2NvbV8jIyNjb21wb25lbnQjIyMvYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMgQ29tcG9uZW50IE51bWJlcg0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCiMgSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyDQoNCkZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IEpDQiB2aXNpdCBbVkRNXShodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyKSBUb2RheSEgVGhlIGZ1dHVyZSBpcyBoZXJlIQ==', '', '', 'Curriculum Builder', '', '', 'Curriculum Builder', '.git', '', '', 1, '', 'https://www.vdm.io/', '', 'lYDhXW46jMK3cmBfyPcr95anvrilyVWw3rgaGrcxW08=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 39, '', 1, 70), -(64, 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, 1, '{}', 3, '', 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.1', 'Copyright (C) 2019. All Rights Reserved', '2019-06-24 19:13:57', 1, 'UdGyz2HyeSAWh4V8qTyePmiehQG9nsUBWfNYf0OZbx8=', 'B+mVpoNvMd5cBBoPVd0XCQ3GpdmTLzo5fWSED95/PAA=', '', 'hHNvxXcbEEU5JnV/KJWwk0x71HkcG3wVMyU92mmP7Ss=', '', 'LmZpZWxkLWNhbGVuZGFyIGlucHV0IHsNCglmb250OmNhcHRpb24gIWltcG9ydGFudDsNCn0=', '', 1, '', 'Whale is an education member manager that integrates with many other components in Joomla.', 'joomla@vdm.io', '', '', '3bz0m6mdJeP1QL1abyj5ZD2DgMbcbubdTYv5nGeH+leI9UIhDZuo9F5Fm64U2FGyaRBf93bT4GxN5IulwRtX7hgxAzms4n46F5cooeowSXw=', '', '4cd86a0a-b8f9-4f07-b904-9b96bdb5bf4b', 'images/vdm/WHALE500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, 'ℂ𝕃', '2021-03-08 03:19:29', 2, 'Whale', 'whale', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9bWVtYmVybWFuYWdlckhlbHBlckJvdGhdDQpbQ1VTVE9NQ09ERT1jYW5BY2Nlc3NNZW1iZXJd', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'The Education Member Manager', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGAgKA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTsNCg0KQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbl9tYXBgICgNCglgcmVsYXRpb25gIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTs=', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGA7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3JlbGF0aW9uX21hcGA7', 'Whale', '.git', '', 1, 3, 'https://www.vdm.io/updates/whale_server.xml', 'https://www.vdm.io/', '', 'LOFJmKrqH5HXUBZNbTRp+ZSsyjEDxokQ2BFhU65+M/Q=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 20, '', 1, 34), -(65, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.3', 'Copyright (C) 2019. All Rights Reserved', '2020-02-22 16:56:44', '', 'AILXAZHGoDcO84yVvQWM/oXimAYf7IlSW3NoEE6K1Tc=', 'A+hVHAQCVCgXZN1DHBRiEY/cyRqyhEBHfRMAglN9haM=', '', '9wTGn7cu1H2RW7fglZMBIdju1sCiUn1TpwxbYbsjErI=', '', '', 'A_189', 2, '', 'Contact Details', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_contactdetails', 'IpDszQXzrHdrZbDn3XBSP68F7/4AA8x1cozN2lg7IqFodiqcQ78JpVUITzBLMihLXKM8loLHj11ALZxsBLl5sg==', '', '12f14a26-d198-4b98-b662-686cedc379e6', 'images/vdm/WHALE500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, 'ℂ𝕃', '2020-07-26 00:38:28', 2, 'Contact', 'whale_contactdetails', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29udGFjdGRldGFpbHNIZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Contact Details', '', '', 'Contact Details (whale)', '.git', '', 1, 1, 'https://www.vdm.io/updates/coral_contactdetails_server.xml', 'http://www.vdm.io', '', 'wBtNQiZgcfgDr9dHyigBA5m4mX8huF+SSbTf9mtSatM=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 12, '', 1, 35), -(66, '', '', '', '', '', '', '', '', 1, '', '', 1, 1, '', '', '', 1, '', '', 1, '', '', 1, 1, '', '{}', '', 1, 2, 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '2.0.6', 'Copyright (C) 2020. All Rights Reserved', '2017-06-16 19:13:20', '', 'tLe8nXe/rm4UFzW9KPFSXJAF+tZRA2lR1QWsnms0zpc=', 'Z4dLjLE/k+oamCDLA3OIT6QFHHSZE8w6eaNmID2ma4g=', '', 'IxxErDaGXf2tioCBYsNN3L7Y/V/azZgA+YP9k1qlw2s=', '', '', 'A_243', 2, '', 'The sentinel server portal of the project.', 'info@vdm.io', '', '', 'X0i9nKs6X5SwD91kpEGmkWjpz+tQa4LmRTY4SeF/LDTLrzPzedd3UU56W5+HDy3l', '', '3dc577a9-81a8-4391-a82a-c47e51cb595d', 'images/vdm/Sentinel500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, 'Ω', '2020-05-24 22:57:50', '', 'Sentinel', 'sentinel', '', 4, '', '', 'W0NVU1RPTUNPREU9c2VudGluZWxIZWxwZXJCb3RoXQ==', 'CXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0VmFyXygkdGFibGUsICR3aGVyZSA9IG51bGwsICR3aGVyZVN0cmluZyA9ICd1c2VyJywgJHdoYXQgPSAnaWQnKQ0KCXsNCgkJLy8gR2V0IGEgZGIgY29ubmVjdGlvbi4NCgkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCS8vIENyZWF0ZSBhIG5ldyBxdWVyeSBvYmplY3QuDQoJCSRxdWVyeSA9ICRkYi0+Z2V0UXVlcnkodHJ1ZSk7DQoJCSRxdWVyeS0+c2VsZWN0KCRkYi0+cXVvdGVOYW1lKGFycmF5KCR3aGF0LCAkd2hlcmVTdHJpbmcpKSk7DQoJCSRxdWVyeS0+ZnJvbSgkZGItPnF1b3RlTmFtZSgnI19fW1tbY29tcG9uZW50XV1dXycuJHRhYmxlKSk7DQoJCSRkYi0+c2V0UXVlcnkoJHF1ZXJ5KTsNCgkJJGRiLT5leGVjdXRlKCk7DQoJCWlmICgkZGItPmdldE51bVJvd3MoKSkNCgkJew0KCQkJJHNlYXJjaCA9ICRkYi0+bG9hZE9iamVjdExpc3QoKTsNCgkJCWZvcmVhY2ggKCRzZWFyY2ggYXMgJGl0ZW0pDQoJCQl7DQoJCQkJaWYgKGlzc2V0KCRpdGVtLT57JHdoZXJlU3RyaW5nfSkpDQoJCQkJew0KCQkJCQkvLyBiYXNpYyBkZWNyeXB0IGRhdGEgdmFsdWUuDQoJCQkJCSRpdGVtLT57JHdoZXJlU3RyaW5nfSA9IHNlbGY6OmRlY3J5cHQoJGl0ZW0tPnskd2hlcmVTdHJpbmd9KTsNCgkJCQl9DQoJCQkJLy8gc2VlIGlmIGl0IGlzIHRoaXMgb25lDQoJCQkJaWYgKGlzc2V0KCRpdGVtLT57JHdoZXJlU3RyaW5nfSkgJiYgaXNzZXQoJGl0ZW0tPnskd2hhdH0pICYmICRpdGVtLT57JHdoZXJlU3RyaW5nfSA9PT0gJHdoZXJlKQ0KCQkJCXsNCgkJCQkJcmV0dXJuICRpdGVtLT57JHdoYXR9Ow0KCQkJCX0NCgkJCX0NCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ==', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHA6Ly92ZG0uYnovY29tcG9uZW50LWJ1aWxkZXIpLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKSA=', '', '', 'Sentinel Server.', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9kYXRhYCAoDQoJYG1lbWJlcmAgSU5UKDExKSBOT1QgTlVMTCBERUZBVUxUIDAsDQoJYGd1aWRgIFZBUkNIQVIoMzYpIE5PVCBOVUxMIERFRkFVTFQgJycsDQoJYHN0YXRpb25gIFZBUkNIQVIoMzYpIE5PVCBOVUxMIERFRkFVTFQgJycsDQoJYHR5cGVgIFZBUkNIQVIoMjU1KSBOT1QgTlVMTCBERUZBVUxUICcnLA0KCWBuYW1lYCBWQVJDSEFSKDI1NSkgTk9UIE5VTEwgREVGQVVMVCAnJywNCglgdGltZWAgdGV4dCBOT1QgTlVMTCwNCglgdmFsdWVgIHRleHQgTk9UIE5VTEwsDQoJS0VZIGBpZHhfZ3VpZGAgKGBndWlkYCksDQoJS0VZIGBpZHhfbmFtZWAgKGBuYW1lYCksDQoJS0VZIGBpZHhfc3RhdGlvbmAgKGBzdGF0aW9uYCksDQoJS0VZIGBpZHhfbWVtYmVyYCAoYG1lbWJlcmApLA0KCUtFWSBgaWR4X3R5cGVgIChgdHlwZWApDQopIEVOR0lORT1Jbm5vREIgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTs=', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9kYXRhYDs=', 'Sentinel', '.git', '', 1, 1, 'https://www.vdm.io/updates/demo_update_server.xml', 'https://www.vdm.io/', '', '7CXwuY5CJpupcDV211Gm4mRixTqVZ4QUhBmURvGvjGA=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 56, '', 1, 12), -(67, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'vdm.txt', '', '', 'Vast Development Method', '1.0.3', 'Copyright (C) 2019. All Rights Reserved', '2020-03-15 15:10:46', '', 'Ei1ioftwLwqpiUGX5/GiOeM7V+cmTj0TNA1jWTnKq60=', 'MFfw/alHiNeQaXzWCWenKPitzR/pBmFFnk4RXS43P8w=', '', 'OBcjRlhHM0pQeV44OmO+hHEpZk1gF1uiRTJqggpxhAg=', '', '', 'A_245', 2, '', 'The syllabus subscription manager', 'joomla@vdm.io', '', 'https://vdm.bz/jcb_syllabus_subscription', 'FoAPdDIBPxFQiCAv9VGUBoTzS7br/Rc21mR3mt6gtm39gdH0yCROk5g9elMAszus7Qtc0Hwk7HBKwLZLub/ylw==', '', '275549e5-e136-4ef7-b2ed-b3104f7844fe', 'images/vdm/WHALE500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, 'ℂ𝕃', '2020-05-25 19:34:55', 2, 'Syllabus Subscription', 'whale_syllabus_subscription', '', 4, '', '', 'W0NVU1RPTUNPREU9c3lsbGFidXNTdWJzY3JpcHRpb25IZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Syllabus subscription manager', '', '', 'Syllabus Subscription (whale)', '.git', '', 1, 1, 'https://www.vdm.io/updates/coral_contactdetails_server.xml', 'http://www.vdm.io', '', 'WvhI9MNG/3vvUYxbP+2uW95p+YSfgGqdHwUoGhaZp90=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 11, '', 1, 36), -(68, 1, '', '', 1, 1, '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, '', '{}', '', 1, 3, 3, 'Llewellyn van der Merwe', '', 'george-media.txt', '', '', 'Vast Development Method', '1.0.1', 'Copyright (C) 2020. All Rights Reserved', '2020-05-19 08:28:48', 1, 'c3bs902wPklTKLLOhd8mZpBsy9vve07ZUI+VFVjWEf4=', 'jiNQg1gpq38XPjjLiabqwJiZLNp+duN94peqXdc/Ia0=', '', 'CfL6QkMw5fRPkpzh+ozi3GknXWlFqROONLzCTXAjyjg=', '', 'LmZpZWxkLWNhbGVuZGFyIGlucHV0IHsNCglmb250OmNhcHRpb24gIWltcG9ydGFudDsNCn0=', 'A_252', 2, '', 'The MyMakita member manager that integrates with other components in Joomla.', 'joomla@vdm.io', '', '', 'mimu2TOQZEFLMMekPQ/peXSXRa+11onAIXm6+KAJd/sSRB+Sm3JjoDKggnteotqeRdWIBkSlHSAMxXAS3eC/+Q==', '', 'a0e5a4ff-690f-4536-b0d8-13fb58f9d5f9', 'images/vdm/Makita500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⇝', '2021-03-08 03:18:26', 2, 'MyMakita', 'mymakita', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	* the button names
	**/
	protected static $buttonNames = array();

	/**
	* the opener
	**/
	protected static $opener;

	/**
	* the return here path
	**/
	protected static $return_here;

	/**
	 * Get selection  based on type
	 *
	 * @param   string   $table     The main table to select
	 * @param   string   $method    The type of values to return
	 * @param   string   $filter    The kind of filter (to return only values required)
	 * @param   object   $db     The database object
	 *
	 * @return array
	 *
	 */
	protected static function getSelection($table = 'member', $method = 'placeholder', $filter = 'none', $db = null)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// prep for placeholders
		$f = '';
		$b = '';
		if ('placeholder' === $method)
		{
			// get the placeholder prefix
			$prefix = self::$params->get('placeholder_prefix', '[[[component]]]');
			$f = '[' . $prefix . '_';
			$b = ']';
		}
		// get charts
		if ('chart' !== $filter && 'field' !== $filter && method_exists(__CLASS__, 'getAnyAvailableCharts') && method_exists(__CLASS__, 'getAllComponents'))
		{
			if (($components = self::getAllComponents(null, array('Assessment'))) !== false && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($components))
			{
				// Chart Target Types
				$targets = array(2,3);
				// load per component
				foreach ($targets as $target)
				{
					foreach ($components as $component)
					{
						if (($data = self::getAnyAvailableCharts(null, $target, $component->element)) !== false && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($data))
						{
							$com = str_replace('com_', '', $component->element);
							foreach ($data as $key => $chartData)
							{
								$charts[$key . '\^/' . $component->element . '\^/' . $target] = $com . '_' . $key;
							}
						}
					}
				}
			}
		}
		// only get what we need
		if ('email' === $filter || 'report' === $filter)
		{
			// check if we have the DB object
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($db))
			{
				// get the database object
				$db = Factory::getDBO();
			}
			// get the database columns of this table
			$columns = $db->getTableColumns("#__[[[component]]]_" . $table, false);
			// always remove these
			$remove = array('asset_id', 'checked_out', 'checked_out_time');
			// remove
			foreach ($remove as $key)
			{
				unset($columns[$key]);
			}
			// prep the columns
			$columns = array_keys($columns);
		}
		// check if we have columns
		if (isset($columns) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($columns))
		{
			// convert the columns for query selection
			$selection = array();
			foreach ($columns as $column)
			{
				$selection['a.' . $column] = $f . $column . $b;
				// we must add the params
				if ('profile' !== $filter && 'field' !== $filter)
				{
					// set the label for these fields
					$selection['setLabel->' . $column] = $f . 'label_' . $column . $b;
				}
			}
			// needed values
			if ('member' === $table)
			{
				// set names and emails
				$selection['setMemberName:id|user|name|surname'] = $f . 'name' . $b;
				$selection['setMemberEmail:id|user|email'] = $f . 'email' . $b;
				$selection['setMemberName:created_by|user'] = $f . 'created_name' . $b;
				$selection['setMemberEmail:created_by|user'] = $f . 'created_email' . $b;
				$selection['setMemberName:modified_by|user'] = $f . 'modified_name' . $b;
				$selection['setMemberEmail:modified_by|user'] = $f . 'modified_email' . $b;
				// get name and email
				$selection['getMemberName:main_member'] = $f . 'main_name' . $b;
				$selection['getMemberEmail:main_member'] = $f . 'main_email' . $b;
				// set fancy dates
				$selection['fancyDate:created'] = $f . 'created' . $b;
				$selection['fancyDate:modified'] = $f . 'modified' . $b;
				// set profile image
				$selection['setImageLink:profile_image|name'] = $f . 'profile_image_url' . $b;
				$selection['setImageHTML:profile_image_url|name'] = $f . 'profile_image_html' . $b;
				// set profile
				$selection['setProfileLink:id|token'] =  $f . 'profile_link_url' . $b;
				// set the return value
				self::$return_here = urlencode(base64_encode((string) Uri::getInstance()));
				// set edit link
				$selection['setMemberEditURL:id|created_by'] =  $f . 'edit_url' . $b;
				// Get the medium encryption.
				$mediumkey = self::getCryptKey('medium');
				if ($mediumkey)
				{
					// Get the encryption object.
					self::$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($mediumkey);
				}
			}
			// add the chart div and JS code (only if filter is not chart)
			if ('chart' !== $filter && 'field' !== $filter && isset($charts) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($charts))
			{
				foreach ($charts as $chart => $value)
				{
					// make sure the chart name is save
					$selection['setMultiChart->' . $chart] = $f . $value . $b;
				}
			}
			return $selection;
		}
		return false;
	}

	/**
	* set image HTML
	**/
	protected static function setImageHTML($object)
	{
		return '<img src="' . $object->get('profile_image_url', '#') . '" class="member-image" alt="' . $object->get('name', Text::_('Member')) . ' ' . Text::_('Image') . '" />';
	}

	/**
	* set image link
	**/
	protected static function setImageLink($item)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$opener) && ($image = $item->get('profile_image', false)) !== false && !is_numeric($image) && $image === base64_encode(base64_decode($image, true)))
		{
			// now unlock
			$item->set('profile_image', rtrim(self::$opener->decryptString($image), "\0"));
		}
		// get link
		return self::getImageLink($item, 'profile_image', 'name', null, false);
	}

	/**
	* set member edit url
	**/
	protected static function setMemberEditURL($item)
	{
		if (self::canAccessMember($item->get('id', 0)) && ($url = self::getEditURL($item, 'member', 'members', '&return=' . self::$return_here)) !== false)
		{
			return $url;
		}
		return '';
	}

	/**
	* set profile link
	**/
	protected static function setProfileLink($object)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// only load link if open to public or has access
		if (2 == self::$params->get('login_required', 1) || self::canAccessMember($object->get('id', 0)))
		{
			return Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_('index.php?option=com_[[[component]]]&view=profile&id='. $object->get('id') . ':' . $object->get('token') . '&return=' . self::$return_here);
		}
		return '';
	}

	/**
	* set member name
	**/
	protected static function setMemberName($object)
	{
		// check if this is a created by or modified by
		if (($user = $object->get('created_by', false)) !== false || ($user = $object->get('modified_by', false)) !== false )
		{
			$object->set('user', $user);
		}
		return self::getMemberName($object->get('id', null), $object->get('user', null), $object->get('name', null), $object->get('surname', null));
	}

	/**
	* set member email
	**/
	protected static function setMemberEmail($object)
	{
		// check if this is a created by or modified by
		if (($user = $object->get('created_by', false)) !== false || ($user = $object->get('modified_by', false)) !== false )
		{
			$object->set('user', $user);
		}
		return self::getMemberEmail($object->get('id', null), $object->get('user', null), $object->get('email', null));
	}

	/**
	* set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// noting for now
		return true;
	}

	/**
	* get button name
	**/
	public static function getButtonName($type, $default)
	{
		if (!isset(self::$buttonNames[$type]))
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
			{
				self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
			}
			// get the button name
			self::$buttonNames[$type] = self::$params->get('button_'. $type . '_name', $default);
		}
		return self::$buttonNames[$type];
	}

	/**
	* remove all groups that are part of target groups in the member types
	**/
	public static function removeMemberGroups(&$groups)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			// get database object
			$db = Factory::getDBO();
			$query = $db->getQuery(true);
			$query->select(array('a.id'));
			$query->from('#__[[[component]]]_type AS a');
			$db->setQuery($query);
			$db->execute();
			// get all types
			$types = $db->loadColumn();
			// now get all target groups
			$groups_target = self::getMemberGroupsByType($types, 'groups_target');
			// now update the groups
			$groups = array_diff($groups, $groups_target);
		}
	}

	/**
	* get the registration form
	**/
	public static function getForms($targets)
	{
		// get the app object
		$app = Factory::getApplication();
		// get language object
		$lang = Factory::getLanguage();
		// start forms array
		$forms= array();
		// load the scripts also
		$script = array();
		// set the forms
		foreach ($targets as $detail)
		{
			// sore data in session
			$data = $app->getUserState($detail['com_'] . '.edit.' . $detail['table'] . '.data', null);
			// get the form
			$forms[$detail['com']] = self::getMemberForms(0, $detail['com_'], $detail['table'], $data, true, $detail['control']);
			// we must also get the scripts
			// try to load the translation
			$lang->load($detail['com_'], JPATH_ADMINISTRATOR, null, false, true);
			// get the scripts
			self::getFieldsScript($detail['com_'], $script);
		}
		// try some plugin langues
		$lang->load('plg_user_terms', JPATH_ADMINISTRATOR, null, false, true);
		// now add the scripts if found
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($script))
		{
			Factory::getDocument()->addScriptDeclaration(implode("\n", $script));
		}
		// return the forms
		return $forms;
	}

	/**
	* update the type map, for quick search
	 *
	 * @param   int   $member     The member ID
	 * @param   string/array   $types     The types
	 *
	 * @return void
	 *
	 */
	public static function updateTypes(&$member, $types = null)
	{
		// get the app object
		$app = Factory::getApplication();
		// get database object
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		// delete all types the are linked to this member
		$conditions = array(
		    $db->quoteName('member') . ' = ' . (int) $member
		);
		$query->delete($db->quoteName('#__[[[component]]]_type_map'));
		$query->where($conditions);
		$db->setQuery($query);
		$db->execute();
		// now set the new values
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($types))
		{
			// Create a new query object.
			$query = $db->getQuery(true);
			// Insert columns.
			$columns = array('member', 'type');
			// build insert query
			$query->insert($db->quoteName('#__[[[component]]]_type_map'));
			$query->columns($db->quoteName($columns));
			// build the values
			foreach ($types as $type)
			{
				 $query->values((int) $member . ',' . (int) $type);
			}
			// Set the query using our newly populated query object and execute it.
			$db->setQuery($query);
			$db->execute();
		}
	}
[CUSTOMCODE=validateDynamicForm]
[CUSTOMCODE=saveDynamicViews]
[CUSTOMCODE=saveDynamicForm]
[CUSTOMCODE=getAnyPlaceHolders+member]
[CUSTOMCODE=getPlaceHoldersReport]
[CUSTOMCODE=getMembersByType]
[CUSTOMCODE=getRelationshipsByTypes]
[CUSTOMCODE=getRelationshipsByMember]
[CUSTOMCODE=getAccess]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=getBetween]
[CUSTOMCODE=theButler]
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=openValidBaseSixtyFour] 
[CUSTOMCODE=locker]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getTemplate]
[CUSTOMCODE=getFolderPath]
[CUSTOMCODE=imageHelpers]
[CUSTOMCODE=writeFile]
[CUSTOMCODE=getLinkOptions]
[CUSTOMCODE=getImageLink]
[CUSTOMCODE=getEditButton]
[CUSTOMCODE=getCreateButton]
[CUSTOMCODE=checkUnique]
[CUSTOMCODE=getCompanyDetails]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=getReport]
[CUSTOMCODE=getANYTemplate+Any]
[CUSTOMCODE=getANYFormDetails+Any]
[CUSTOMCODE=getANYCompanyDetails+Any]
[CUSTOMCODE=getANYChartCode+Any]
[CUSTOMCODE=getANYMultiChartDataTable+Any]
[CUSTOMCODE=getANYAvailableCharts+Any]
[CUSTOMCODE=getANYForms+Member]
[CUSTOMCODE=getANYDetails+member,Member]
[CUSTOMCODE=modelANYDetails+member,Member]
[CUSTOMCODE=labelModelANYDetails+member,Member]
[CUSTOMCODE=multiChartModelANYDetails+member,Member]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=getAllComponents+'Info'&#44;'Assessment']
[CUSTOMCODE=getComponentName+'Info'&#44;'Assessment']
[CUSTOMCODE=getComponentsAvaillable+info,Info,&#91;&#91;&#91;component&#93;&#93;&#93;]
[CUSTOMCODE=getComponentsAvaillable+assessment,Assessment,&#91;&#91;&#91;component&#93;&#93;&#93;]
[CUSTOMCODE=loadIntegratedTabs]
[CUSTOMCODE=setTab]
[CUSTOMCODE=setSubformTable]
[CUSTOMCODE=saveRelationships]
[CUSTOMCODE=arrayPartition]
[CUSTOMCODE=getFileContents]
[CUSTOMCODE=bcmath]
[CUSTOMCODE=gUID]
[CUSTOMCODE=getCoreName]
[CUSTOMCODE=mimeType]
[CUSTOMCODE=triggerPlugin]
[CUSTOMCODE=canAccessMember]
[CUSTOMCODE=registerUser]', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbQ29tcG9uZW50IGltYWdlXShodHRwczovL3d3dy52ZG0uaW8vaW1hZ2VzL01ha2l0YTUwMC5qcGcgIlRoZSBNYWtpdGEgQ29tcG9uZW50IikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'The MyMakita Member Manager', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGAgKA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTsNCg0KQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbl9tYXBgICgNCglgcmVsYXRpb25gIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTs=', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGA7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3JlbGF0aW9uX21hcGA7', 'MyMakita', '.git', '', '', 1, 'https://raw.githubusercontent.com/george-media/com_mymakita/master/update_server.xml', 'http://www.vdm.io', '', 'WZPKTSsZfiK0J5Pujq+Lqgf9cG0dzik44VD5UljLVls=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 65, '', 1, 37), -(69, '', '', '', '', '', '', '', '', 1, '', '', 1, 1, '', '', '', 1, '', '', 1, '', '', 1, 1, '', '{}', '', 1, 3, 3, 'Llewellyn van der Merwe', '', 'george-media.txt', '', '', 'Vast Development Method', '1.0.7', 'Copyright (C) 2020. All Rights Reserved', '2020-05-20 11:23:58', '', 'nPivTPzlBZ91Y5p+LzlRAMbU/A43NFZ/ArMkylCqFYw=', 'SQLuWYe+Izc7i9CnY4qFhvroPAqlQ1NmbR1CmQPTYGo=', '', '+qs1ypqe6t+RFF+Pe81Nhi/jGNA9fzw8s9iu1jZcxeE=', '', '', 'A_248', 2, '', 'MyMakita Members Contact Details', 'joomla@vdm.io', '', '', 'KK233XYTqvWCH8mZocCiQJ54ys8pB8WW9MgZM4tDIDqO9mGtwyiE+V8HYDhXj0GcO1zu/nG6x4Gt39Hh+20T3A==', '', 'd4af561a-6410-466f-bfab-8b069a732fbd', 'images/vdm/Makita500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⇝', '2020-08-04 03:15:33', 2, 'Contact', 'mymakita_contactdetails', '', 4, '', '', 'CS8qKg0KCSAqIGxvYWQgY3JvbiB0YWJzDQoJICoNCgkgKiBAcGFyYW0gICBvYmplY3QgICAkaXRlbSAgICAgICAgICAgICAgVGhlIGl0ZW0gdmFsdWVzDQoJICogQHBhcmFtICAgc3RyaW5nICAgICR2aWV3X25hbWUgIFRoZSBuYW1lIG9mIHRoZSB2aWV3DQoJICoNCgkgKiBAcmV0dXJuIHN0cmluZw0KCSAqDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBsb2FkQ3JvblRhYnMoJiRpdGVtLCAkdmlld19uYW1lKQ0KCXsNCgkJJHRtcCA9ICcnOw0KCQkvLyBvbmx5IGlmIGFsbCB2YWx1ZXMgbmVlZGVkIGFyZSBzZXQNCgkJaWYgKGlzc2V0KCRpdGVtLT5hY2Nlc3NfdG9rZW4pICYmIGlzc2V0KCRpdGVtLT5hcHBfa2V5KSAmJiBpc3NldCgkaXRlbS0+YXBwX3NlY3JldCkgJiYgaXNzZXQoJGl0ZW0tPnJlZnJlc2hfdG9rZW4pICYmDQoJCQlTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkaXRlbS0+YWNjZXNzX3Rva2VuKSAmJiBTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkaXRlbS0+YXBwX2tleSkgJiYNCgkJCVN1cGVyX19fMWYyOGNiNTNfNjBkOV80ZGIxX2I1MTdfM2M3ZGM2YjQyOWVmX19fUG93ZXI6OmNoZWNrKCRpdGVtLT5hcHBfc2VjcmV0KSAmJiBTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkaXRlbS0+cmVmcmVzaF90b2tlbikgJiYNCgkJCWlzc2V0KCRpdGVtLT5ndWlkKSAmJiBzZWxmOjp2YWxpZGF0ZUdVSUQoJGl0ZW0tPmd1aWQpKQ0KCQl7DQoJCQkvLyBzZXQgdGhlIHVwZGF0ZSBVUkwNCgkJCSR1cGRhdGVfdXJsID0gVXJpOjpyb290KCkgLiAnaW5kZXgucGhwP29wdGlvbj1jb21fW1tbY29tcG9uZW50XV1dJmtleT0nIC4gJGl0ZW0tPmd1aWQgLiAnJnRhc2s9Y29uc3RhbnRjb250YWN0LnN5bmMnOw0KCQkJLy8gc2V0dXAgdGhlIGNyb24gdXJsDQoJCQlpZiAoZnVuY3Rpb25fZXhpc3RzKCdjdXJsX3ZlcnNpb24nKSkNCgkJCXsNCgkJCQkkcGF0aCA9ICcwIDAgKiAqICogY3VybCAtcyAiJyAuICR1cGRhdGVfdXJsIC4gJyIgPi9kZXYvbnVsbCAyPiYxJzsNCgkJCX0NCgkJCWVsc2UNCgkJCXsNCgkJCQkkcGF0aCA9ICdZb3UgbXVzdCBmaXJzdCBpbnN0YWxsL3NldHVwIGN1cmwgb24geW91ciBzZXJ2ZXIuJzsNCgkJCX0NCgkJCS8vIGJ1aWxkIHRoZSB0YWINCgkJCSR0bXAgLj0gSHRtbDo6XygnYm9vdHN0cmFwLmFkZFRhYicsICR2aWV3X25hbWUgLiAnVGFiJywgc2VsZjo6cmFuZG9ta2V5KDEwKSwgVGV4dDo6XygnQ3JvbiBKb2InLCB0cnVlKSk7DQoJCQkkdG1wIC49IFBIUF9FT0wgLiAnPGRpdiBjbGFzcz0id2VsbCB3ZWxsLWxhcmdlIj48ZGl2IGNsYXNzPSJyb3ctZmx1aWQgZm9ybS1ob3Jpem9udGFsLWRlc2t0b3AiPic7DQoJCQkkdG1wIC49IFBIUF9FT0wgLiAnPGgyIGNsYXNzPSJtb2R1bGUtdGl0bGUgbmF2LWhlYWRlciI+JyAuIFRleHQ6Ol8oJ0Nyb24gSm9iIERldGFpbHMnKSAuICc8L2gyPic7DQoNCgkJCSR0bXAgLj0gUEhQX0VPTCAuICc8cD5Zb3UgY2FuIHJ1biBhIGNyb25qb2IgdGhhdCB3aWxsIHN5bmMgYWxsIHlvdXIgY29udGFjdHMgd2l0aCBjb25zdGFudCBjb250YWN0IG9uY2UgcGVyL2RheS48YnIgLz48YnIgLz4nOw0KCQkJJHRtcCAuPSBQSFBfRU9MIC4gJzxiPlVTRSBUSEUgRk9MTE9XSU5HOjwvYj4gPHNwYW4gaWQ9ImNyb25qb2Itc3luYyI+PGNvZGU+JyAuICRwYXRoIC4gJzwvY29kZT48L3NwYW4+JzsNCgkJCSR0bXAgLj0gUEhQX0VPTCAuICc8YnIgLz48YnIgLz48YSBjbGFzcz0iYnRuIGJ0bi1zdWNjZXNzIiBocmVmPSInIC4gJHVwZGF0ZV91cmwgLiAnIiB0YXJnZXQ9Il9ibGFuayI+UnVuIFVwZGF0ZSBOb3cgTWFudWFsbHk8L2E+JzsNCgkJCSR0bXAgLj0gUEhQX0VPTCAuICc8YnIgLz48YnIgLz5QbGVhc2Ugbm90ZSB0aGF0IGlmIHlvdXIgSm9vbWxhIHdlYnNpdGUgaGFzIGEgRmlyZXdhbGwgaW5zdGFsbGVkLCBpdCB3aWxsIG5vdCBhbGxvdyBjcm9uam9iIHZpYSBkaXJlY3QgVVJMIChtb3N0IG9mIHRoZSB0aW1lKSwgeW91IHdpbGwgdGhlbiBuZWVkIHRvIGFkYXB0IHRoZSBjb3Juam9iIHJlcXVlc3QgdG8gbG9vayBsaWtlIGEgYnJvd3Nlci4gRm9yIG1vcmUgaW5mbyBwbGVhc2UgcmVhZCBodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL2EvMzE1OTc4MjMvMTQyOTY3Nyc7DQoNCgkJCSR0bXAgLj0gUEhQX0VPTCAuICc8L3A+PC9kaXY+PC9kaXY+JzsNCgkJCSR0bXAgLj0gSHRtbDo6XygnYm9vdHN0cmFwLmVuZFRhYicpOw0KCQl9DQoJCXJldHVybiAkdG1wOw0KCX0NCltDVVNUT01DT0RFPWNvbnRhY3RkZXRhaWxzSGVscGVyQm90aF0NCltDVVNUT01DT0RFPWdVSURd', 'CS8qKg0KCSAqIGdldCB0aGUgYXBwIHZhbHVlcw0KCSAqDQoJICogQHBhcmFtICAgc3RyaW5nICAgJGd1aWQgICAgVGhlIEdVSUQgb2YgdGhlIGxvY2FsIEFQUA0KCSAqDQoJICogQHJldHVybiBvYmplY3QNCgkgKg0KCSAqLw0KCXB1YmxpYyBzdGF0aWMgZnVuY3Rpb24gZ2V0QXBwKCRndWlkKQ0KCXsNCgkJLy8gY2hlY2sgaWYgdGhpcyBpcyBhIHZhbGlkIEdVSUQNCgkJaWYgKHNlbGY6OnZhbGlkYXRlR1VJRCgkZ3VpZCkgJiYgKCRpZCA9IHNlbGY6OmdldFZhcignY29uc3RhbnRfY29udGFjdCcsICRndWlkLCAnZ3VpZCcsICdpZCcpKSAhPT0gZmFsc2UpDQoJCXsNCgkJCS8vIG5vdyBnZXQgdGhlIG1vZGVsDQoJCQkkbW9kZWwgPSBzZWxmOjpnZXRNb2RlbCgnY29uc3RhbnRfY29udGFjdCcsIEpQQVRIX0NPTVBPTkVOVF9BRE1JTklTVFJBVE9SKTsNCgkJCS8vIG5vdyByZXR1cm4gdGhlIEFQUA0KCQkJcmV0dXJuICRtb2RlbC0+Z2V0SXRlbSgkaWQpOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoNCgkvKioNCgkgKiBzZXQgdGhlIGFwcCB2YWx1ZXMNCgkgKg0KCSAqIEBwYXJhbSAgIHN0cmluZyAgICR0eXBlICAgIFRoZSB0eXBlIG9mIHZhbHVlcw0KCSAqIEBwYXJhbSAgIG1peCAgICAgICR2YWx1ZSAgIFRoZSB2YWx1ZS9zDQoJICogQHBhcmFtICAgc3RyaW5nICAgJGd1aWQgICAgVGhlIEdVSUQgb2YgdGhlIGxvY2FsIEFQUA0KCSAqDQoJICogQHJldHVybiBib29sDQoJICoNCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIHNldEFwcCgkdHlwZSwgJHZhbHVlLCAkZ3VpZCkNCgl7DQoJCS8vIGNoZWNrIGlmIHRoaXMgaXMgYSB2YWxpZCBHVUlEDQoJCWlmIChzZWxmOjp2YWxpZGF0ZUdVSUQoJGd1aWQpICYmICgkaWQgPSBzZWxmOjpnZXRWYXIoJ2NvbnN0YW50X2NvbnRhY3QnLCAkZ3VpZCwgJ2d1aWQnLCAnaWQnKSkgIT09IGZhbHNlKQ0KCQl7DQoJCQlpZiAoJ25leHQnID09PSAkdHlwZSkNCgkJCXsNCgkJCQlyZXR1cm4gc2VsZjo6c2V0QXBwTmV4dElEKCRpZCwgJHZhbHVlKTsNCgkJCX0NCgkJCWVsc2VpZiAoJ3Rva2VuJyA9PT0gJHR5cGUpDQoJCQl7DQoJCQkJcmV0dXJuIHNlbGY6OnNldEFwcFRva2VucygkaWQsICR2YWx1ZSk7DQoJCQl9DQoJCX0NCgkJcmV0dXJuIGZhbHNlOw0KCX0NCg0KCS8qKg0KCSAqIHVwZGF0ZS9zZXQgdGhlIEFwcCBUb2tlbnMNCgkgKg0KCSAqIEBwYXJhbSAgIGludCAgICAgICAkaWQgICAgICAgICAgIFRoZSBJRCBvZiB0aGUgbG9jYWwgQVBQDQoJICogQHBhcmFtICAgYXJyYXkgICAkdG9rZW5zICAgIFRoZSBuZXcgdG9rZW5zDQoJICoNCgkgKiBAcmV0dXJuIGJvb2wNCgkgKg0KCSAqLw0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gc2V0QXBwVG9rZW5zKCRpZCwgJiR0b2tlbnMpDQoJew0KCQkvLyBjaGVjayBpZiB0b2tlbnMgYXJlIHNldA0KCQlpZiAoU3VwZXJfX18wYTU5YzY1Y185ZGFmXzRiYzlfYmFmNF9lMDYzZmY5ZTZhOGFfX19Qb3dlcjo6Y2hlY2soJHRva2VucykgJiYgIGlzc2V0KCR0b2tlbnNbJ2FjY2Vzc190b2tlbiddKSAmJiBpc3NldCgkdG9rZW5zWydyZWZyZXNoX3Rva2VuJ10pICYmDQoJCQlTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkdG9rZW5zWydhY2Nlc3NfdG9rZW4nXSkgJiYgU3VwZXJfX18xZjI4Y2I1M182MGQ5XzRkYjFfYjUxN18zYzdkYzZiNDI5ZWZfX19Qb3dlcjo6Y2hlY2soJHRva2Vuc1sncmVmcmVzaF90b2tlbiddKSkNCgkJew0KCQkJLy8gR2V0IHRoZSBiYXNpYyBlbmNyeXB0aW9uLg0KCQkJJGJhc2lja2V5ID0gc2VsZjo6Z2V0Q3J5cHRLZXkoJ2Jhc2ljJyk7DQoJCQkvLyBHZXQgdGhlIGVuY3J5cHRpb24gb2JqZWN0Lg0KCQkJJGJhc2ljID0gbmV3IFN1cGVyX19fOTkxNzVmNmRfZGJhOF80MDg2XzhhNjVfNWM0ZWMxNzVlNjFkX19fUG93ZXIoJGJhc2lja2V5KTsNCgkJCS8vIENyZWF0ZSBhbiBvYmplY3QgZm9yIHRoZSByZWNvcmQgd2UgYXJlIGdvaW5nIHRvIHVwZGF0ZS4NCgkJCSRvYmplY3QgPSBuZXcgXHN0ZENsYXNzKCk7DQoJCQkvLyBNdXN0IGJlIGEgdmFsaWQgcHJpbWFyeSBrZXkgdmFsdWUuDQoJCQkkb2JqZWN0LT5pZCA9IChpbnQpICRpZDsNCgkJCSRvYmplY3QtPmFjY2Vzc190b2tlbiA9ICRiYXNpYy0+ZW5jcnlwdFN0cmluZygkdG9rZW5zWydhY2Nlc3NfdG9rZW4nXSk7DQoJCQkkb2JqZWN0LT5yZWZyZXNoX3Rva2VuID0gJGJhc2ljLT5lbmNyeXB0U3RyaW5nKCR0b2tlbnNbJ3JlZnJlc2hfdG9rZW4nXSk7DQoJCQkvLyBVcGRhdGUgQVBQIFRPS0VOUyB1c2luZyBpZCBhcyB0aGUgcHJpbWFyeSBrZXkuDQoJCQlyZXR1cm4gRmFjdG9yeTo6Z2V0RGJvKCktPnVwZGF0ZU9iamVjdCgnI19fW1tbY29tcG9uZW50XV1dX2NvbnN0YW50X2NvbnRhY3QnLCAkb2JqZWN0LCAnaWQnKTsNCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ0KDQoJLyoqDQoJICogdXBkYXRlL3NldCB0aGUgQXBwIE5leHQgSUQNCgkgKg0KCSAqIEBwYXJhbSAgIGludCAgICAgICAkaWQgICAgICAgICAgIFRoZSBJRCBvZiB0aGUgbG9jYWwgQVBQDQoJICogQHBhcmFtICAgaW50ICAgICAgICRuZXh0ICAgICAgIFRoZSBuZXh0IGlkIHRvIHN0YXJ0IHdpdGgNCgkgKg0KCSAqIEByZXR1cm4gYm9vbA0KCSAqDQoJICovDQoJcHJvdGVjdGVkIHN0YXRpYyBmdW5jdGlvbiBzZXRBcHBOZXh0SUQoJGlkLCAmJG5leHQpDQoJew0KCQlpZiAoaXNfbnVtZXJpYygkbmV4dCkpDQoJCXsNCgkJCS8vIENyZWF0ZSBhbiBvYmplY3QgZm9yIHRoZSByZWNvcmQgd2UgYXJlIGdvaW5nIHRvIHVwZGF0ZS4NCgkJCSRvYmplY3QgPSBuZXcgXHN0ZENsYXNzKCk7DQoJCQkvLyBNdXN0IGJlIGEgdmFsaWQgcHJpbWFyeSBrZXkgdmFsdWUuDQoJCQkkb2JqZWN0LT5pZCA9IChpbnQpICRpZDsNCgkJCSRvYmplY3QtPm5leHRfaWQgPSAoaW50KSAkbmV4dDsNCgkJCS8vIFVwZGF0ZSBBUFAgbmV4dF9pZCB1c2luZyBpZCBhcyB0aGUgcHJpbWFyeSBrZXkuDQoJCQlyZXR1cm4gRmFjdG9yeTo6Z2V0RGJvKCktPnVwZGF0ZU9iamVjdCgnI19fW1tbY29tcG9uZW50XV1dX2NvbnN0YW50X2NvbnRhY3QnLCAkb2JqZWN0LCAnaWQnKTsNCgkJfQ0KCQlyZXR1cm4gZmFsc2U7DQoJfQ==', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbQ29tcG9uZW50IGltYWdlXShodHRwczovL3d3dy52ZG0uaW8vaW1hZ2VzL01ha2l0YTUwMC5qcGcgIlRoZSBNYWtpdGEgQ29tcG9uZW50IikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'Contact Details', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9zeW5jYCAoDQoJYGFwcGAgSU5UKDExKSBOT1QgTlVMTCwNCglgY29udGFjdGAgSU5UKDExKSBOT1QgTlVMTCwNCglgbW9kaWZpZWRgIERBVEVUSU1FIE5PVCBOVUxMIERFRkFVTFQgJzAwMDAtMDAtMDAgMDA6MDA6MDAnLA0KCVBSSU1BUlkgS0VZIChgYXBwYCwgYGNvbnRhY3RgKQ0KKSBFTkdJTkU9SW5ub0RCIERFRkFVTFQgQ0hBUlNFVD11dGY4bWI0IERFRkFVTFQgQ09MTEFURT11dGY4bWI0X3VuaWNvZGVfY2k7', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9zeW5jYDs=', 'Contact Details (mymakita)', '.git', '', '', 1, 'https://raw.githubusercontent.com/george-media/com_mymakita_contactdetails/master/update_server.xml', 'http://www.vdm.io', '', 'sGvJftIoLEAS6/R7xK/gfKEKZfTBKf1msC+mYDUfRsQ=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 74, '', 1, 38), -(70, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'george-media.txt', '', '', 'Vast Development Method', '1.0.1', 'Copyright (C) 2020. All Rights Reserved', '2020-06-27 20:06:25', '', 'lQRaWnxCVAXWbM3PSzpOwkwWOUTqhc42ltcwwyFr10w=', 'TWodCPpX+2hZKGepw4+/qy3E/VS17mS1mEA7yhc3rMc=', '', 'TzbmxqgmTHzpTLhbxhJ6KNTeehkYRrVG8KC1t8/eDLY=', '', '', 'A_254', 2, '', 'MyMakita Competition Details', 'joomla@vdm.io', '', '', 'W37pqjT2aYIvtmMLuunwJCCfxS00AEhMQX/451TmjYp6Vn9e2IMTYIfd3BJ15P0JY0e2Af+M8/IUvxJFfsjwNg==', '', 'c592813d-418e-4c18-b2a2-537e0a7b6d13', 'images/vdm/Makita500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⇝', '2020-07-08 03:16:16', 2, 'Competition', 'mymakita_competition', '', 4, '', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	* check if this product qualifying in a competition and set it if it does
	**/
	public static function setQualifying(&$product, $bulk = false, $competition_id = 0)
	{
		if (($competitions = self::getActiveCompetitions()) !== false && self::validateEntry($product, $competitions, $bulk))
		{
			// start entry
			$entry = new \stdClass();
			$entry->guid = $product->guid;
			$entry->member = $product->member;
			$entry->created_by = Factory::getUser()->get('id');
			$entry->created = $product->created;
			$entry->published = 1;
			$entry->version = 1;
			// build with competition ID deals with one competition at a time
			if ($bulk && $competition_id > 0)
			{
				self::storeCompetitionEntry($entry, $competition_id, $bulk);
			}
			else
			{
				// store the entries to all competitions
				foreach ($competitions as $competition)
				{
					self::storeCompetitionEntry($entry, $competition->id);
				}
			}
		}
	}

	/**
	* check if this product qualifying in a competition and set it if it does
	**/
	protected static function storeCompetitionEntry(&$entry, &$competition_id, $bulk = false)
	{
		// update entry
		$entry->competition = $competition_id;
		// insert entry
		Factory::getDbo()->insertObject(
			'#__[[[component]]]_entry', $entry
		);
		// do not set session if we have bulk update running
		if (!$bulk)
		{
			// set true to show notice in this session
			$key = $entry->competition . '_vdm_makita_' . $entry->member;
			self::set($key, 1);
		}
	}

	/**
	 * To Validate the Entry
	 */
	protected static function validateEntry(&$product, &$competitions, $bulk)
	{
		// bulk has already set the product details and validated that they are valid
		if ($bulk || (($p_details = self::getProductDetails($product->product)) !== false &&
			$p_details->extended == 1 && $p_details->type == 1))
		{
			// check if the product invoice date falls within the competitions dates
			if ($bulk || self::validateInvoiceDate($product, $competitions))
			{
				// load details to product
				if (!$bulk)
				{
					$product->type = $p_details->type;
					$product->extended = $p_details->extended;
					$product->warranty = $p_details->warranty;
				}
				$warranty = self::getWarrantyDetails($product);
				// only qualify if active extended warranty and has never been entered with ((this product)) in any previous competitions.
				if ($warranty['active'] == 1 && $warranty['qualify'] && ($bulk || ($exist = self::getVar('entry', $product->guid, 'guid', 'id')) === false))
				{
					return true;
				}
			}
		}
		return false;
	}

	/**
	 * To Validate the Invoice Date
	 */
	protected static function validateInvoiceDate(&$product, &$competitions)
	{
		// check if this product invoice qualify
		foreach ($competitions as $nr => $competition)
		{
			// check if invoice date is older then start date of competition
			if ((int) $product->invoice_date < (int) $competition->start)
			{
				// remove competitions to which the product does not qualify
				unset($competitions[$nr]);
			}
		}
		// now check if we have any competitions left
		return Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($competitions);
	}

	/**
	 * Active Competitions 
	 */
	protected static $activeCompetitions = array();

	/**
	 * Get Active Competitions 
	 */
	public static function getActiveCompetitions($member = 0, $comp = 0)
	{
		$key = $member . '_' . $comp;
		// check if we already set this
		if (!Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$activeCompetitions[$key]))
		{
			// make sure we are in Australia
			date_default_timezone_set('Australia/Sydney');
			// get database object
			$db = Factory::getDbo();
			// check if member was added
			if ($member > 0)
			{
				// get all item ids of entries that belong to this member
				$query = $db->getQuery(true)
					->select($db->quoteName(array('a.guid', 'c.id')))
					->from($db->quoteName('#__[[[component]]]_entry', 'a'));
				$query->join('LEFT', ($db->quoteName('#__[[[component]]]_competition', 'c')) . ' ON (' . $db->quoteName('a.competition') . ' = ' . $db->quoteName('c.id') . ')');
				$query->where($db->quoteName('c.start') . ' <= ' . (int) time());
				$query->where($db->quoteName('c.end') . ' >= ' . (int) time());
				$query->where($db->quoteName('a.member') . ' = ' . (int) $member);
				$query->where($db->quoteName('c.published') . ' = 1');
				$query->where($db->quoteName('a.published') . ' = 1');
			}
			elseif ($comp > 0)
			{
				// get all item details of this competition
				$query = $db->getQuery(true)
					->select($db->quoteName(
						array('name', 'start', 'end', 'competitions_notice_template', 'competitions_template'),
						array('competition_name', 'competition_start_date', 'competition_end_date', 'notice_template', 'competitions_template')
					))
					->from($db->quoteName('#__[[[component]]]_competition'));
				$query->where($db->quoteName('id') . ' = ' . (int) $comp);
			}
			else
			{
				// get all competitions that are active
				$query = $db->getQuery(true)
					->select($db->quoteName(array('id', 'name', 'start', 'end', 'competitions_notice_template')))
					->from($db->quoteName('#__[[[component]]]_competition'));
				$query->where($db->quoteName('start') . ' <= ' . (int) time());
				$query->where($db->quoteName('end') . ' >= ' . (int) time());
				$query->where($db->quoteName('published') . ' = 1');
			}
			$db->setQuery($query)->execute();
			if ($db->getNumRows())
			{
				// store for later
				if ($comp > 0)
				{
					self::$activeCompetitions[$key] = $db->loadObject();
				}
				else
				{
					self::$activeCompetitions[$key] = $db->loadObjectList();
				}
				// just return found competitions 
				return self::$activeCompetitions[$key];
			}
			return false;
		}
		return self::$activeCompetitions[$key];
	}

	/**
	 * Get Product Detail
	 */
	public static function getActiveCompetitionsMessages(&$member)
	{
		if ($member && ($competitions = self::getActiveCompetitions($member->id)) !== false)
		{
			// get competition details
			$_competitions = array();
			foreach ($competitions as $competition)
			{
				if (!isset($_competitions[$competition->id]))
				{
					// get competition details
					$_competitions[$competition->id] = self::getActiveCompetitions(0, $competition->id);
					// add counter
					$_competitions[$competition->id]->number_of_products_entered = 1;
				}
				else
				{
					$_competitions[$competition->id]->number_of_products_entered++;
				}
			}
			unset($competitions);
			unset($competition);
			// set base placeholders
			$placeholder = array('[full_name]' => $member->full_name, '[name]' => $member->name, '[surname]' => $member->surname);
			// now build the messages
			$member->competitions = array();
			foreach ($_competitions as $id => $competition)
			{
				$placeholder['[number_of_products_entered]'] = $competition->number_of_products_entered;
				$placeholder['[competition_end_date]'] = $competition->competition_end_date;
				$placeholder['[competition_start_date]'] = $competition->competition_start_date;
				$placeholder['[competition_name]'] = $competition->competition_name;
				// set key
				$key = $id . '_vdm_makita_' . $member->id;
				// add the profile notice
				$member->competitions[$id] = array('competitions_template' => trim(self::setDynamicData($competition->competitions_template, $placeholder)));
				// is the notice still active
				if (self::get($key) == 1)
				{
					$member->competitions[$id]['notice_template'] = trim(self::setDynamicData($competition->notice_template, $placeholder));
				}
				// make sure the notice is not added again
				self::set($key, null);
			}
			return true;
		}
		return false;
	}

	/**
	 * Get Product Detail
	 */
	protected static function getProductDetails(&$code)
	{
		// get database object
		$db = Factory::getDbo();
		// get all item ids of Entries that belong to this user
		$query = $db->getQuery(true)
			->select($db->quoteName(array('type','warranty','extended')))
			->from($db->quoteName('#__[[[products]]]_product'));
		$query->where($db->quoteName('code') . ' = ' .  $db->quote($code));
		$db->setQuery($query)->execute();
		if ($db->getNumRows())
		{
			return $db->loadObject();
		}
		return false;
	}

	protected static function getWarrantyDetails(&$product, $add_link = false)
	{
		if (($helperClass = self::getHelperClass('[[[products]]]')) !== false && method_exists($helperClass, 'getWarrantyDetails'))
		{
			return $helperClass::getWarrantyDetails($product, $add_link);
		}
	}
[CUSTOMCODE=theButler]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=canAccessMemberData]
[CUSTOMCODE=setDynamicDataIF]', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbQ29tcG9uZW50IGltYWdlXShodHRwczovL3d3dy52ZG0uaW8vaW1hZ2VzL01ha2l0YTUwMC5qcGcgIlRoZSBNYWtpdGEgQ29tcG9uZW50IikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'Competition Details', '', '', 'Competition (mymakita)', '.git', '', '', 1, 'https://raw.githubusercontent.com/george-media/com_mymakita_contactdetails/master/update_server.xml', 'http://www.vdm.io', '', '7zJ8lOdXDPAFp/EDYMkNaR2ykAAlesgeWbBdcvgecoY=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 50, '', 1, 39), -(71, 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', 1, 1, 1, '', '{}', '', 1, 3, 3, 'Llewellyn van der Merwe', '', 'joomla_basic.txt', '', '', 'Vast Development Method', '1.0.0', 'Copyright (C) 2020. All Rights Reserved', '2020-07-03 13:47:05', 1, 'NEe9OpwGlAPGqu8E+I9+15yDDexd+CY6BbIAQmwCaZs=', '9l7XznNOXO4eJo09NW06SeHHmSUdz56Aikwt+K93qto=', '', '6l6dpiHO0txj5F0mec0GrzEKvtDRaCkllWeBXz99XTQ=', '', 'LmZpZWxkLWNhbGVuZGFyIGlucHV0IHsNCglmb250OmNhcHRpb24gIWltcG9ydGFudDsNCn0=', 'A_252', 2, '', 'The tradeshow member manager that integrates with other components in Joomla, and the Joomla user suite.', 'joomla@vdm.io', '', '', 'obfWNiZGHzltZ5e+DYOTW5DtDS28vo4Q2s3aRO27LEjXk+FoFUdpPPA2go+he8S2kWlTYw+N9VkznCycTUjAPA==', '', '4962adb3-5e1e-4335-bb03-9cb11c9614eb', 'images/vdm/INTER500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⊛', '2021-03-08 03:18:38', 2, 'Trade Show', 'tradeshow', '', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', '	/**
	* the params
	**/
	protected static $params;

	/**
	* the button names
	**/
	protected static $buttonNames = array();

	/**
	* the opener
	**/
	protected static $opener;

	/**
	* the return here path
	**/
	protected static $return_here;

	/**
	* set image HTML
	**/
	protected static function setImageHTML($object)
	{
		return '<img src="' . $object->get('profile_image_url', '#') . '" class="member-image" alt="' . $object->get('name', Text::_('Member')) . ' ' . Text::_('Image') . '" />';
	}

	/**
	* set image link
	**/
	protected static function setImageLink($item)
	{
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$opener) && ($image = $item->get('profile_image', false)) !== false && !is_numeric($image) && $image === base64_encode(base64_decode($image, true)))
		{
			// now unlock
			$item->set('profile_image', rtrim(self::$opener->decryptString($image), "\0"));
		}
		// get link
		return self::getImageLink($item, 'profile_image', 'name', null, false);
	}

	/**
	* set member edit url
	**/
	protected static function setMemberEditURL($item)
	{
		if (self::canAccessMember($item->get('id', 0)) && ($url = self::getEditURL($item, 'member', 'members', '&return=' . self::$return_here)) !== false)
		{
			return $url;
		}
		return '';
	}

	/**
	* set profile link
	**/
	protected static function setProfileLink($object)
	{
		// get the global settings
		if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
		{
			self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
		}
		// only load link if open to public or has access
		if (2 == self::$params->get('login_required', 1) || self::canAccessMember($object->get('id', 0)))
		{
			return Joomla___d4c76099_4c32_408a_8701_d0a724484dfd___Power::_('index.php?option=com_[[[component]]]&view=profile&id='. $object->get('id') . ':' . $object->get('token') . '&return=' . self::$return_here);
		}
		return '';
	}

	/**
	* set member name
	**/
	protected static function setMemberName($object)
	{
		// check if this is a created by or modified by
		if (($user = $object->get('created_by', false)) !== false || ($user = $object->get('modified_by', false)) !== false )
		{
			$object->set('user', $user);
		}
		return self::getMemberName($object->get('id', null), $object->get('user', null), $object->get('name', null), $object->get('surname', null));
	}

	/**
	* set member email
	**/
	protected static function setMemberEmail($object)
	{
		// check if this is a created by or modified by
		if (($user = $object->get('created_by', false)) !== false || ($user = $object->get('modified_by', false)) !== false )
		{
			$object->set('user', $user);
		}
		return self::getMemberEmail($object->get('id', null), $object->get('user', null), $object->get('email', null));
	}

	/**
	* set the session defaults if not set
	**/
	protected static function setSessionDefaults()
	{
		// noting for now
		return true;
	}

	/**
	* get button name
	**/
	public static function getButtonName($type, $default)
	{
		if (!isset(self::$buttonNames[$type]))
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
			{
				self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
			}
			// get the button name
			self::$buttonNames[$type] = self::$params->get('button_'. $type . '_name', $default);
		}
		return self::$buttonNames[$type];
	}

	/**
	* remove all groups that are part of target groups in the member types
	**/
	public static function removeMemberGroups(&$groups)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($groups))
		{
			// get database object
			$db = Factory::getDBO();
			$query = $db->getQuery(true);
			$query->select(array('a.id'));
			$query->from('#__[[[component]]]_type AS a');
			$db->setQuery($query);
			$db->execute();
			// get all types
			$types = $db->loadColumn();
			// now get all target groups
			$groups_target = self::getMemberGroupsByType($types, 'groups_target');
			// now update the groups
			$groups = array_diff($groups, $groups_target);
		}
	}

	/**
	* get the registration form
	**/
	public static function getForms($targets)
	{
		// get the app object
		$app = Factory::getApplication();
		// get language object
		$lang = Factory::getLanguage();
		// start forms array
		$forms= array();
		// load the scripts also
		$script = array();
		// set the forms
		foreach ($targets as $detail)
		{
			// get data from session
			$data = $app->getUserState($detail['com_'] . '.edit.' . $detail['table'] . '.data', null);
			// get the form
			$forms[$detail['com']] = self::getMemberForms(0, $detail['com_'], $detail['table'], $data, true, $detail['control']);
			// we must also get the scripts
			// try to load the translation
			$lang->load($detail['com_'], JPATH_ADMINISTRATOR, null, false, true);
			// get the scripts
			self::getFieldsScript($detail['com_'], $script);
		}
		// try some plugin langues
		$lang->load('plg_user_terms', JPATH_ADMINISTRATOR, null, false, true);
		// now add the scripts if found
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($script))
		{
			Factory::getDocument()->addScriptDeclaration(implode("\n", $script));
		}
		// return the forms
		return $forms;
	}

	/**
	* update the type map, for quick search
	 *
	 * @param   int   $member     The member ID
	 * @param   string/array   $types     The types
	 *
	 * @return void
	 *
	 */
	public static function updateTypes(&$member, $types = null)
	{
		// get the app object
		$app = Factory::getApplication();
		// get database object
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		// delete all types the are linked to this member
		$conditions = array(
		    $db->quoteName('member') . ' = ' . (int) $member
		);
		$query->delete($db->quoteName('#__[[[component]]]_type_map'));
		$query->where($conditions);
		$db->setQuery($query);
		$db->execute();
		// now set the new values
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($types))
		{
			// Create a new query object.
			$query = $db->getQuery(true);
			// Insert columns.
			$columns = array('member', 'type');
			// build insert query
			$query->insert($db->quoteName('#__[[[component]]]_type_map'));
			$query->columns($db->quoteName($columns));
			// build the values
			foreach ($types as $type)
			{
				 $query->values((int) $member . ',' . (int) $type);
			}
			// Set the query using our newly populated query object and execute it.
			$db->setQuery($query);
			$db->execute();
		}
	}

	/**
	 * save the dynamic values
	 *
	 * @param   object   $date     The main Data
	 * @param   string   $view     The view name
	 *
	 * @return void
	 *
	 */
	public static function saveDynamicValues(&$data, $view = 'member')
	{
		// get all the available component calling metods
		$class = new ReflectionClass('[[[Component]]]Helper');
		$methods = array_filter($class->getMethods(ReflectionMethod::IS_PUBLIC),
			function ($method) {
				if (strpos($method->name, 'get') !== false && strpos($method->name, 'Availlable') !== false )
				{
					return true;
				}
				return false;
			}
		);
		// set type if not set
		if (!isset($data['type']) && $view == 'member')
		{
			$data['type'] = self::getVar($view, $data['id'], 'id', 'type');
		}
		// set account if not set
		if (!isset($data['account']) && $view == 'member')
		{
			$data['account'] = self::getVar($view, $data['id'], 'id', 'account');
		}
		// check if we have methods
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($methods) && isset($data['type'], $data['account']))
		{
			// get the global settings
			if (!Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check(self::$params))
			{
				self::$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams('com_[[[component]]]');
			}
			// get the app object
			$app = Factory::getApplication();
			// get the post object
			$post = Factory::getApplication()->input->post;
			// get the user object
			$user = Factory::getUser();
			// get the database object
			$db = Factory::getDBO();
			// start looping the methods
			foreach ($methods as $method)
			{
				// get components
				$components = self::{$method->name}($data['type'], $data['account']);
				// check if we found components
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($components))
				{
					// get assessment details
					foreach ($components as $_name => $comp)
					{
						// only save one to one components
						if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($comp) && isset($comp->element))
						{
							$_component = $comp->element;
							$component = str_replace('com_', '', $_component);
							$Component = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($component, 'F');
							$COMponent = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($component, 'W');
							// get the posted date if there were any
							$_data  = $post->get($component, array(), 'array');
							// check if user are allowed to edit form values or create form values
							if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($_data))
							{
								// get the local params
								$params = Joomla___aeb8e463_291f_4445_9ac4_34b637c12dbd___Power::getParams($_component);
								// make sure the ID is set
								if (!isset($_data['id']) || !is_numeric($_data['id']) || $_data['id'] == 0)
								{
									// set id to zero as this will cause new item to be created
									$_data['id'] = 0;
									// set default access
									$_data['access'] = $params->get('default_accesslevel', self::$params->get('default_accesslevel', 1));
								}
								// check if user may edit
								if ($_data['id'] > 0 && !$user->authorise('core.edit', $_component . '.form.' . (int) $_data['id']))
								{
									// check edit own
									if (($created_by = self::getVar('form', $_data['id'], 'id', 'created_by', '=', $component)) === false || $created_by != $user->id || !$user->authorise('core.edit.own', $_component))
									{
										$app->enqueueMessage(Text::sprintf('You do not have permission to edit %s, please contact your system administrator.', $COMponent, $_data['id']), 'warning');
										continue;
									}
								}
								// check if user may create
								if ($_data['id'] == 0 && !$user->authorise('core.create', $_component))
								{
									$app->enqueueMessage(Text::sprintf('You do not have permission to add data to %s, please contact your system administrator.', $COMponent), 'warning');
									continue;
								}
								// make sure the member ID is set if view is member
								if ('member' === $view && !isset($_data[$view]) || !is_numeric($_data[$view]) || $_data[$view] == 0)
								{
									if ($_data['id'] > 0 && $data['id'] > 0)
									{
										// get the member ID
										if (($member = self::getVar('form', $_data['id'], 'id', $view, '=', $component)) === false || $member != $data['id'])
										{
											$app->enqueueMessage(Text::sprintf('Member ID mismatch, %s-%s could not be saved.', $COMponent, $_data['id']), 'error');
											continue;
										}
									}
									elseif ($_data['id'] > 0)
									{
										// get the member ID
										if (($member = self::getVar('form', $_data['id'], 'id', $view, '=', $component)) === false || $member == 0)
										{
											$app->enqueueMessage(Text::sprintf('Member ID mismatch, %s-%s could not be saved.', $COMponent, $_data['id']), 'error');
											continue;
										}
									}
									elseif ($data['id'] > 0)
									{
										// get the member ID
										$member = $data['id'];
									}
									else
									{
										$app->enqueueMessage(Text::sprintf('%s could not be saved, please try again. This could be due to the fact this the member ID was not ready.', $COMponent), 'error');
										continue;
									}
									// set the member ID
									$_data[$view] = $member;
								}
								// check if the class and method exist
								if (($helperClass = self::getHelperClass($_component)) === false || !method_exists($helperClass, 'getModel'))
								{
									continue;
								}
								// get the model
								$model = $helperClass::getModel('form', JPATH_ADMINISTRATOR . '/components/' . $_component, $Component);
								// do we have the model
								if ($model)
								{
									// force other component path (TODO) will be an issue if forms and fields are the same
									\JForm::addFormPath(JPATH_ADMINISTRATOR . '/components/' . $_component . '/models/forms');
									\JForm::addFieldPath(JPATH_ADMINISTRATOR . '/components/' . $_component . '/models/fields');
									// Validate the posted data.
									// Sometimes the form needs some posted data, such as for plugins and modules.
									$form = $model->getForm($_data, false);
									if (!$form)
									{
										$app->enqueueMessage($model->getError(), 'error');
										continue;
									}
									// remove all fields not part of the allowed edit fields
									if (($fields = $params->get('edit_fields', false)) !== false && Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($fields))
									{
										// build a fields array bucket
										$fieldActive = array();
										foreach ($fields as $row)
										{
											$fieldActive[$row->field] = $row->field;
										}
										// set the keep values
										$fieldActive['id'] = 'id';
										$fieldActive['member'] = 'member';
										$fieldActive['asset_id'] = 'asset_id';
										$fieldActive['created'] = 'created';
										$fieldActive['created_by'] = 'created_by';
										$fieldActive['modified'] = 'modified';
										$fieldActive['modified_by'] = 'modified_by';
										$fieldActive['access'] = 'access';
										$fieldActive['version'] = 'version';
										$fieldActive['rules'] = 'rules';
										// get the database columns of this table
										$columns = $db->getTableColumns("#__" . $component . "_form", false);
										// now make sure the fields that are not editable are removed (so can't be updated via this form)
										foreach(array_keys($columns) as $field)
										{
											if (!isset($fieldActive[$field]))
											{
												$form->removeField($field);
											}
										}
									}
									// Send an object which can be modified through the plugin event
									$objData = (object) $_data;
									$app->triggerEvent(
										'onContentNormaliseRequestData',
										array($_component . '.form', $objData, $form)
									);
									$_data = (array) $objData;
									// Test whether the data is valid.
									$validData = $model->validate($form, $_data);
									// Check for validation errors.
									if ($validData === false)
									{
										// Get the validation messages.
										$errors = $model->getErrors();
										// Push up to three validation messages out to the user.
										for ($i = 0, $n = count($errors); $i < $n && $i < 3; $i++)
										{
											if ($errors[$i] instanceof \Exception)
											{
												$app->enqueueMessage($errors[$i]->getMessage(), 'warning');
											}
											else
											{
												$app->enqueueMessage($errors[$i], 'warning');
											}
										}
										continue;
									}
									// always load member back
									if (!is_numeric($validData[$view]) || $validData[$view] == 0)
									{
										$validData[$view] = $member;
									}
									// Attempt to save the data.
									if (!$model->save($validData))
									{
										$app->enqueueMessage(Text::sprintf('%s data could not be saved', $COMponent), 'error');
									}
								}
							}
						}
					}
				}
			}
		}
	}

[CUSTOMCODE=getAnyPlaceHolders+member]
[CUSTOMCODE=getPlaceHoldersReport]
[CUSTOMCODE=getMembersByType]
[CUSTOMCODE=getRelationshipsByTypes]
[CUSTOMCODE=getRelationshipsByMember]
[CUSTOMCODE=getAccess]
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=getBetween]
[CUSTOMCODE=theButler]
[CUSTOMCODE=baseSixtyFourURL]
[CUSTOMCODE=openValidBaseSixtyFour] 
[CUSTOMCODE=locker]
[CUSTOMCODE=setDynamicDataIF]
[CUSTOMCODE=getTemplate]
[CUSTOMCODE=getFolderPath]
[CUSTOMCODE=imageHelpers]
[CUSTOMCODE=writeFile]
[CUSTOMCODE=getLinkOptions]
[CUSTOMCODE=getImageLink]
[CUSTOMCODE=getEditButton]
[CUSTOMCODE=getCreateButton]
[CUSTOMCODE=checkUnique]
[CUSTOMCODE=getCompanyDetails]
[CUSTOMCODE=getHelperClass]
[CUSTOMCODE=getReport]
[CUSTOMCODE=getANYTemplate+Any]
[CUSTOMCODE=getANYFormDetails+Any]
[CUSTOMCODE=getANYCompanyDetails+Any]
[CUSTOMCODE=getANYForms+Member]
[CUSTOMCODE=getANYDetails+member,Member]
[CUSTOMCODE=modelANYDetails+member,Member]
[CUSTOMCODE=labelModelANYDetails+member,Member]
[CUSTOMCODE=getMemberName]
[CUSTOMCODE=getAllComponents+'Info'&#44;'Assessment']
[CUSTOMCODE=getComponentName+'Info'&#44;'Assessment']
[CUSTOMCODE=getComponentsAvaillable+info,Info,&#91;&#91;&#91;component&#93;&#93;&#93;]
[CUSTOMCODE=getComponentsAvaillable+assessment,Assessment,&#91;&#91;&#91;component&#93;&#93;&#93;]
[CUSTOMCODE=loadIntegratedTabs]
[CUSTOMCODE=setTab]
[CUSTOMCODE=setSubformTable]
[CUSTOMCODE=saveRelationships]
[CUSTOMCODE=arrayPartition]
[CUSTOMCODE=getFileContents]
[CUSTOMCODE=bcmath]
[CUSTOMCODE=gUID]
[CUSTOMCODE=getCoreName]
[CUSTOMCODE=mimeType]
[CUSTOMCODE=triggerPlugin]
[CUSTOMCODE=canAccessMember]', '', '', '', '', '', '', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'The Tradeshow Member Manager', 'Q1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGAgKA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTsNCg0KQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV9yZWxhdGlvbl9tYXBgICgNCglgcmVsYXRpb25gIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWBtZW1iZXJgIElOVCgxMSkgTk9UIE5VTEwgREVGQVVMVCAwLA0KCWB0eXBlYCBJTlQoMTEpIE5PVCBOVUxMIERFRkFVTFQgMA0KKSBFTkdJTkU9SW5ub0RCIEFVVE9fSU5DUkVNRU5UPTAgREVGQVVMVCBDSEFSU0VUPXV0ZjhtYjQgREVGQVVMVCBDT0xMQVRFPXV0ZjhtYjRfdW5pY29kZV9jaTs=', 'RFJPUCBUQUJMRSBJRiBFWElTVFMgYCNfX1tbW2NvbXBvbmVudF1dXV90eXBlX21hcGA7DQpEUk9QIFRBQkxFIElGIEVYSVNUUyBgI19fW1tbY29tcG9uZW50XV1dX3JlbGF0aW9uX21hcGA7', 'Trade Show', '.git', '', '', 1, 'https://raw.githubusercontent.com/george-media/com_mymakita/master/update_server.xml', 'http://www.vdm.io', '', '60dT/Pblxd6gCktQbfcYDS7dz1f+WwUbWB7tF33W3fg=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 15, '', 1, 40), -(72, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'joomla_basic.txt', '', '', 'Vast Development Method', '1.0.0', 'Copyright (C) 2020. All Rights Reserved', '2020-07-03 15:40:40', '', 'J9NlVYI02Eu7AgPKZpTm5FJn08mLqO8dFBsFtfPkXz8=', '8a60unLh/MKEy+Bk+U/DJKZpFatQlE10ON+7M0l6B9k=', '', 'TtVYGl4jbbtGejB8ajWigIAFBT35hSTBbYxPkDQlvmg=', '', '', 'A_255', 2, '', 'Tradeshow Members Contact Details', 'joomla@vdm.io', '', '', 'xte7yVjY5MNHAicUV1HSnpCG5bGN1Xqs61tQ+wrOIVrrPKTa45QbhayrfXo1plrqiVjKNheWOnCtvk+4S97eDw==', '', 'e2602a97-fc53-453c-a5bf-972b6402add3', 'images/vdm/INTER500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⊛', '2020-07-20 23:18:52', 2, 'Contact', 'tradeshow_contactdetails', '', 4, '', '', 'W0NVU1RPTUNPREU9Y29udGFjdGRldGFpbHNIZWxwZXJCb3RoXQ==', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'Contact Details', '', '', 'Contact Details (tradeshow)', '.git', '', '', 1, 'https://raw.githubusercontent.com/george-media/com_mymakita_contactdetails/master/update_server.xml', 'http://www.vdm.io', '', 'XZD29QMr0qG96JwEhYJavC6EAXsjzKqbvwf+IHduPQ0=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 12, '', 1, 41), -(73, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', 1, '', '', 1, '', '', '', '', '', '{}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'joomla_basic.txt', '', '', 'Vast Development Method', '1.0.0', 'Copyright (C) 2020. All Rights Reserved', '2020-07-05 02:26:09', '', 'yUyHgT14jAW4fsHUg7PkwaoYVdwkgGLQBVa+JpKmy6E=', 'iNI0cSm59PTSv7sJJ9S3WIarGn3RoDz8BGGq79BnEFY=', '', 'eLhRw2cXGVaGcDPohMuh5jgMlcSYRM4AdYSS+AiVT7g=', '', '', 'A_256', 2, '', 'Tradeshow Members Interests Details', 'joomla@vdm.io', '', '', 'eOuN2nUyNDC7P7RaoGD3naJ/uTavr8Q6ZOpcZD8IprH3IUN1EmCuJOCRT5DrIGZ53B6RNhxJbm0h5BQjwqur4Q==', '', 'e64adafd-3574-415f-8ef8-96bf201ccec6', 'images/vdm/INTER500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '⊛', '2020-07-09 02:34:42', 2, 'Interests', 'tradeshow_interests', '', 4, '', '', 'CS8qKg0KCSogdGhlIHBhcmFtcw0KCSoqLw0KCXByb3RlY3RlZCBzdGF0aWMgJHBhcmFtczsNCg0KCS8qKg0KCSAqIEdldCBzZWxlY3Rpb24gIGJhc2VkIG9uIHR5cGUNCgkgKg0KCSAqIEBwYXJhbSAgIHN0cmluZyAgICR0YWJsZSAgICAgVGhlIG1haW4gdGFibGUgdG8gc2VsZWN0DQoJICogQHBhcmFtICAgc3RyaW5nICAgJG1ldGhvZCAgICBUaGUgdHlwZSBvZiB2YWx1ZXMgdG8gcmV0dXJuDQoJICogQHBhcmFtICAgc3RyaW5nICAgJGZpbHRlciAgICBUaGUga2luZCBvZiBmaWx0ZXIgKHRvIHJldHVybiBvbmx5IHZhbHVlcyByZXF1aXJlZCkNCgkgKiBAcGFyYW0gICBvYmplY3QgICAkZGIgICAgIFRoZSBkYXRhYmFzZSBvYmplY3QNCgkgKg0KCSAqIEByZXR1cm4gYXJyYXkNCgkgKg0KCSAqLw0KCXByb3RlY3RlZCBzdGF0aWMgZnVuY3Rpb24gZ2V0U2VsZWN0aW9uKCR0YWJsZSA9ICdmb3JtJywgJG1ldGhvZCA9ICdwbGFjZWhvbGRlcicsICRmaWx0ZXIgPSAnbm9uZScsICRkYiA9IG51bGwpDQoJew0KCQkvLyBnZXQgdGhlIGdsb2JhbCBzZXR0aW5ncw0KCQlpZiAoIVN1cGVyX19fOTEwMDQ1MjlfOTRhOV80NTkwX2I4NDJfZTdjNmI2MjRlY2Y1X19fUG93ZXI6OmNoZWNrKHNlbGY6OiRwYXJhbXMpKQ0KCQl7DQoJCQlzZWxmOjokcGFyYW1zID0gSm9vbWxhX19fYWViOGU0NjNfMjkxZl80NDQ1XzlhYzRfMzRiNjM3YzEyZGJkX19fUG93ZXI6OmdldFBhcmFtcygnY29tX1tbW2NvbXBvbmVudF1dXScpOw0KCQl9DQoJCS8vIHByZXAgZm9yIHBsYWNlaG9sZGVycw0KCQkkZiA9ICcnOw0KCQkkYiA9ICcnOw0KCQlpZiAoJ3BsYWNlaG9sZGVyJyA9PT0gJG1ldGhvZCkNCgkJew0KCQkJLy8gZ2V0IHRoZSBwbGFjZWhvbGRlciBwcmVmaXgNCgkJCSRwcmVmaXggPSBzZWxmOjokcGFyYW1zLT5nZXQoJ3BsYWNlaG9sZGVyX3ByZWZpeCcsICdbW1tjb21wb25lbnRdXV0nKTsNCgkJCSRmID0gJ1snIC4gJHByZWZpeCAuICdfJzsNCgkJCSRiID0gJ10nOw0KCQl9DQoJCS8vIG9ubHkgZ2V0IHdoYXQgd2UgbmVlZA0KCQlpZiAoJ3Byb2ZpbGUnID09PSAkZmlsdGVyKQ0KCQl7DQoJCQkvLyBnZXQgdGhlIGZpZWxkcy9jb2x1bW5zDQoJCQlpZiAoKCRmaWVsZHMgPSBzZWxmOjokcGFyYW1zLT5nZXQoJ3Byb2ZpbGVfZmllbGRzJywgZmFsc2UpKSAhPT0gZmFsc2UgJiYgU3VwZXJfX185MTAwNDUyOV85NGE5XzQ1OTBfYjg0Ml9lN2M2YjYyNGVjZjVfX19Qb3dlcjo6Y2hlY2soJGZpZWxkcykpDQoJCQl7DQoJCQkJJGNvbHVtbnMgPSBhcnJheSgnaWQnKTsgLy8gbmVlZGVkIGZvciBwZXJtaXNzaW9uIGNoZWNrDQoJCQkJZm9yZWFjaCAoJGZpZWxkcyBhcyAkZmllbGQpDQoJCQkJew0KCQkJCQkkY29sdW1uc1tdID0gJGZpZWxkLT5maWVsZDsNCgkJCQl9DQoJCQkJLy8gYWRkIGRhdGVzIGZvciBkaXNwbGF5DQoJCQkJJGNvbHVtbnNbXSA9ICdjcmVhdGVkJzsNCgkJCQkkY29sdW1uc1tdID0gJ21vZGlmaWVkJzsNCgkJCX0NCgkJfQ0KCQkvLyBzZXQgdGhlIHZhbHVlcyB5b3Ugd2FudCB0byByZW1vdmUgYWZ0ZXIgbW9kZWxpbmcNCgkJZWxzZWlmICgncmVtb3ZlJyA9PT0gJGZpbHRlcikNCgkJew0KCQkJLy8gc3RhcnQgYnVpbGQgcmVtb3ZhbA0KCQkJJHJlbW92YWwgPSBhcnJheSgpOw0KCQkJLy8gZ2V0IHRoZSBmaWVsZHMvY29sdW1ucw0KCQkJJHJlbW92YWxbXSA9ICRmIC4gJ3BhcmFtcycgLiAkYjsNCgkJCXJldHVybiAkcmVtb3ZhbDsNCgkJfQ0KCQllbHNlDQoJCXsNCgkJCS8vIGNoZWNrIGlmIHdlIGhhdmUgdGhlIERCIG9iamVjdA0KCQkJaWYgKCFTdXBlcl9fXzkxMDA0NTI5Xzk0YTlfNDU5MF9iODQyX2U3YzZiNjI0ZWNmNV9fX1Bvd2VyOjpjaGVjaygkZGIpKQ0KCQkJew0KCQkJCS8vIGdldCB0aGUgZGF0YWJhc2Ugb2JqZWN0DQoJCQkJJGRiID0gRmFjdG9yeTo6Z2V0REJPKCk7DQoJCQl9DQoJCQkvLyBnZXQgdGhlIGRhdGFiYXNlIGNvbHVtbnMgb2YgdGhpcyB0YWJsZQ0KCQkJJGNvbHVtbnMgPSAkZGItPmdldFRhYmxlQ29sdW1ucygiI19fW1tbY29tcG9uZW50XV1dXyIgLiAkdGFibGUsIGZhbHNlKTsNCgkJCS8vIGFsd2F5cyByZW1vdmUgdGhlc2UNCgkJCSRyZW1vdmUgPSBhcnJheSgnYXNzZXRfaWQnLCAnY2hlY2tlZF9vdXQnLCAnY2hlY2tlZF9vdXRfdGltZScpOw0KCQkJLy8gaWYgcGxhY2Vob2xkZXIgYW5kIG5vbmUgZmlsdGVyIHRoZW4gcmVtb3ZlIHNvbWUgbW9yZQ0KCQkJaWYgKCdwbGFjZWhvbGRlcicgPT09ICRtZXRob2QgJiYgKCdyZXBvcnQnID09PSAkZmlsdGVyIHx8ICdlbWFpbCcgPT09ICRmaWx0ZXIpKQ0KCQkJew0KCQkJCSRyZW1vdmVbXSA9ICdwYXJhbXMnOw0KCQkJCSRyZW1vdmVbXSA9ICdhY2Nlc3MnOw0KCQkJCSRyZW1vdmVbXSA9ICdjcmVhdGVkX2J5JzsNCgkJCQkkcmVtb3ZlW10gPSAnaWQnOw0KCQkJCSRyZW1vdmVbXSA9ICdvcmRlcmluZyc7DQoJCQkJJHJlbW92ZVtdID0gJ3ZlcnNpb24nOw0KCQkJCSRyZW1vdmVbXSA9ICdwdWJsaXNoZWQnOw0KCQkJCSRyZW1vdmVbXSA9ICdtb2RpZmllZF9ieSc7DQoJCQkJJHJlbW92ZVtdID0gJ21vZGlmaWVkJzsNCgkJCQkkcmVtb3ZlW10gPSAnaGl0cyc7DQoJCQl9DQoJCQkvLyByZW1vdmUNCgkJCWZvcmVhY2ggKCRyZW1vdmUgYXMgJGtleSkNCgkJCXsNCgkJCQl1bnNldCgkY29sdW1uc1ska2V5XSk7DQoJCQl9DQoJCQkvLyBwcmVwIHRoZSBjb2x1bW5zDQoJCQkkY29sdW1ucyA9IGFycmF5X2tleXMoJGNvbHVtbnMpOw0KCQl9DQoJCS8vIG1ha2Ugc3VyZSB3ZSBoYXZlIGNvbHVtbnMNCgkJaWYgKFN1cGVyX19fMGE1OWM2NWNfOWRhZl80YmM5X2JhZjRfZTA2M2ZmOWU2YThhX19fUG93ZXI6OmNoZWNrKCRjb2x1bW5zKSkNCgkJew0KCQkJLy8gY29udmVydCB0aGUgY29sdW1ucyBmb3IgcXVlcnkgc2VsZWN0aW9uDQoJCQkkc2VsZWN0aW9uID0gYXJyYXkoKTsNCgkJCS8vIGxvYWQgdGhlIGNvbHVtbnMgdG8gc2VsZWN0aW9uDQoJCQlmb3JlYWNoICgkY29sdW1ucyBhcyAkY29sdW1uKQ0KCQkJew0KCQkJCSRzZWxlY3Rpb25bJ2EuJyAuICRjb2x1bW5dID0gJGYgLiAkY29sdW1uIC4gJGI7DQoJCQkJLy8gd2UgbXVzdCBhZGQgdGhlIGxhYmVsDQoJCQkJaWYgKCdwcm9maWxlJyAhPT0gJGZpbHRlciAmJiAnZmllbGQnICE9PSAkZmlsdGVyKQ0KCQkJCXsNCgkJCQkJLy8gc2V0IHRoZSBsYWJlbCBmb3IgdGhlc2UgZmllbGRzDQoJCQkJCSRzZWxlY3Rpb25bJ3NldExhYmVsLT4nIC4gJGNvbHVtbl0gPSAkZiAuICdsYWJlbF8nIC4gJGNvbHVtbiAuICRiOw0KCQkJCX0NCgkJCX0NCgkJCXJldHVybiAkc2VsZWN0aW9uOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9DQoNCltDVVNUT01DT0RFPWdldFBsYWNlSG9sZGVyc1JlcG9ydF0NCltDVVNUT01DT0RFPWdldEFOWURldGFpbHMrZm9ybSxGb3JtXQ0KW0NVU1RPTUNPREU9bW9kZWxBTllEZXRhaWxzK2Zvcm0sRm9ybV0NCltDVVNUT01DT0RFPWxhYmVsTW9kZWxBTllEZXRhaWxzK2Zvcm0sRm9ybV0NCltDVVNUT01DT0RFPXJlbW92ZUFOWURldGFpbHMrZm9ybSxGb3JtXQ0KW0NVU1RPTUNPREU9Z2V0TWVtYmVyTmFtZV0NCltDVVNUT01DT0RFPWdldEhlbHBlckNsYXNzXQ0KW0NVU1RPTUNPREU9Y2FuQWNjZXNzTWVtYmVyRGF0YV0=', '', '', '', '', 'W0NVU1RPTUNPREU9dGVzdElmQ29yZUlzSW5zdGFsbGVkXQ==', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoq', '', '', 'Interests Details', '', '', 'Interests (tradeshow)', '.git', '', '', 1, 'https://raw.githubusercontent.com/george-media/com_mymakita_contactdetails/master/update_server.xml', 'http://www.vdm.io', '', 'p64m7REo8QwAaxkYcuH3+j3lWdyOeu8LN0hd/GpEDKs=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 4, '', 1, 42), -(74, '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', '', 1, '', 3, 'Joomla! Project', '', 'joomla.txt', '', '', 'Open Source Matters', '2.0.1', '(C) 2020 Open Source Matters, Inc.', '2020-07-29 22:24:08', '', 'nuPe7BZe0OtMlyNeeHPuS8SHX8O9HvQWj5jF+XCWih554qg/aohgU1kHkZ8Bc9ZKXxaS0LNvAD1PDZ/mNvPKh/ZktsZmU/CiEIV7jDRfnn0Z67gQ4qq8ukNLvrA7vTSgnLMGHXGVOP5jkiSKKT6LfA==', 'wWB7GJgVI/YsjDN7d2Xx3J7X2yE5cu/7jHL0zRp36uM=', '', 'v3X9AzJS8wSMIb81VZpN4bI3w785Wil6K4jI4Cl2dcI=', '', '', 'A_265', 2, '', 'A component to keep track of release checking.', 'admin@joomla.org', '', '', 'v31/4wVSWaILOAk2YmJ+QAkatJjr/U4Q15RcHU8nXPA=', '/var/git_', '12903467-e133-4b2a-9fb2-5c8b6141fc0d', 'images/vdm/INTER500.jpg', '', 'https://git.vdm.dev/joomla/com_release_checking', 'GNU General Public License version 2 or later; see LICENSE.txt', 1, '»', '2024-03-07 13:38:20', 2, 'Track Release Checking', 'releasechecking', 'JCB', 4, '', '', '', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIFNvbWUgRnVuIE51bWJlcnMNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKio=', 1, '', 'Track Release Checking', '', '', 'Track Release Checking', '.git', '', '', 2, 'https://raw.githubusercontent.com/joomla-projects/com_release_checking/master/update_server.xml', 'http://www.joomla.org', '', 'DSEQLzE3zgLZWTiI7dH7LTbsTw5ebd58CnojuOFFj/g=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 51, '', 1, 19), -(75, '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{\"addcontributors0\":{\"name\":\"Mauritz van der Merwe\",\"title\":\"Lila-Lead\",\"email\":\"mauritz@nampharm.com.na\",\"website\":\"https:\\/\\/www.nampharm.com.na\\/\",\"use\":\"2\",\"show\":\"3\"}}', '', 1, '', 3, 'Llewellyn van der Merwe', '', 'nampharm.txt', '', '', 'NamPharm', '1.0.0', 'Copyright (C) 2021. All Rights Reserved', '2021-08-23 17:39:20', '', 'E2gQdKS7fPBdXSh5QGPg8XUxr5RE+KYb2O4hIRpPiJo=', 'nwDmkj3a/7a20Tx85owMgVKUVXmw1dXluKkupmanRME=', '', '+B2X3uAaAiq/s7njAISK7utK8wFgFrLLMAWxIFguvG4=', '', '', 'A_259', 2, '', 'Managing the integration with Lila', 'llewellyn@vdm.io', '', 'https://git.vdm.dev/NamPharm', '/QqJA76V+vHv0yV/XxFoZVVErzwjjZyg4PTcKxGfAHoah/HwHvVMA4h6kCm8qWuG', '', '3e6ad3e9-4638-4853-8a39-177338c9899c', 'images/vdm/INTER500.jpg', '', 'https://git.vdm.dev/NamPharm/lilapharm', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '', '2021-11-13 15:41:01', 2, 'LilaPharm', 'LilaPharm', '', 4, '', '', '', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8p', 1, '', 'Managing the integration with Lila', '', '', 'LilaPharm', '.git', '', '', 1, '', 'https://git.vdm.dev/NamPharm', '', 'E0X+mbMN8utwWS03NdaBIc2x8FL5/eQTD7xtRrqrduQ=', '', '{\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"add_site_component\":\"0\",\"site_component\":\"\",\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"add_site_helper\":\"0\",\"site_helper\":\"\"},\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"}}', 1, 16, '', 1, 73), -(77, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'JCB.txt', '', '', 'Joomla Component Builder', '1.0.2', 'Copyright (C) 2020. All Rights Reserved', '2022-05-19 19:45:15', '', 'ajPZSR9ECiF8dpmSxaMBqdg3FzmwebLHIqnh5aNP9oU=', 'Q7cGyROmDxs86z12EUNFK5OnnfGBdaet2LsCAiD6I18=', '', 'rf6ckpi4p5G/57685LcBwAeoPT2tUYuXlfK5J/EB0TI=', '', '', '', 1, '', 'To update the core powers of JCB', 'joomla@vdm.io', '', '', 'YxOrE3VZMV4NCTchaLing682C5FYf/BlivX9ncHR2SU=', '', '371f04cc-4f9b-466c-b6ad-e9b4466a48a7', 'images/vdm/jcb500.jpg', '', '', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '«', '2022-09-20 10:15:18', 3, 'Power Updater', 'PowerUpdater', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Power Updater', '', '', 'Power Updater', '.git', '', '', 1, 'https://www.vdm.io/updates/componentbuilder_basic_update_server.xml', 'http://www.joomlacomponentbuilder.com', '', 'mluySSH3I1cPJE6ONgLgnaQSbWmY8NrrI8bQh5nju/E=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"1\",\"admin_component\":\"\",\"power_admin_component\":{\"power_admin_component0\":{\"power\":\"8025e71c-8e21-44cb-b23e-dce2fb5a1ab5\",\"as\":\"default\",\"build\":\"2\"}},\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 14, '', 1, 55), -(78, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'JCB.txt', '', '', 'Joomla Component Builder', '1.0.2', 'Copyright (C) 2022. All Rights Reserved', '2022-09-20 10:22:50', '', 'WF9UyIOqL1Y1RmqBCYBgGNOOTmkKeb+bpiYUF0E97sc=', '/teVDI0QeBd/DEYVguwfIbG1gh/FCiStK0so6FKoYPc=', '', '7LZ6671VY+qBiuIGUzFFuuzTSBN+aqdXScZ4cV+IZhU=', '', '', '', 1, '', 'To update the core compiler of JCB', 'joomla@vdm.io', '', '', '/bu8qaakJoHxhQEQk+3Hhx5DxXCCaoPJaHpRA78vycU=', '', '7b7f5f0d-5d5d-4a14-b1c5-47f4541ec6df', 'images/vdm/jcb500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder/src/branch/staging/libraries/jcb_powers/VDM.Joomla/src/Componentbuilder/Compiler', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '«', '2022-09-20 10:36:48', 3, 'Compiler Updater', 'CompilerUpdater', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Compiler Updater', '', '', 'Compiler Updater', '.git', '', '', 1, '', 'http://www.joomlacomponentbuilder.com', '', 'WrCSG395h8L2AStJAE+GcU4y1jIvzHt8wS8tj66kP/g=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"1\",\"admin_component\":\"\",\"power_admin_component\":{\"power_admin_component0\":{\"power\":\"32533a86-e602-4941-87c3-90bdd703989a\",\"as\":\"default\",\"build\":\"2\"}},\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 5, '', 1, 55), -(79, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'JCB.txt', '', '', 'Joomla Component Builder', '1.0.0', 'Copyright (C) 2022. All Rights Reserved', '2022-12-02 13:22:33', '', 'lPYL2eF+0NZjPxC0XaIeqJA5TEhl2ThtH4A41XeH+D0=', 'vOO5Yu75v70pS9PTvr8KYIFiW3fIBHXJhPpdRuCLDPU=', '', 'MoGIpuhFxT5u/6Vjn1O6qulD52PVAGyOeg5aWGDAgFI=', '', '', '', 1, '', 'To update the search classes of JCB', 'joomla@vdm.io', '', '', 'Z3gsAcjBJsQ2wbjV0v8SIi/8uKXk3Ej6x1dbkcQqSBk=', '', '4940e53c-8f00-4b87-bf13-04ef9b8aa7e9', 'images/vdm/jcb500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder/src/branch/staging/libraries/jcb_powers/VDM.Joomla/src/Componentbuilder/Compiler', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '«', '2022-12-02 13:25:24', 3, 'Search Updater', 'SearchUpdater', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Search Updater', '', '', 'Search Updater', '.git', '', '', 1, '', 'http://www.joomlacomponentbuilder.com', '', '65PyHbdXxTdBj2RkLruCsjIvsxJzMesCfl/6pL8UKmw=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"1\",\"admin_component\":\"\",\"power_admin_component\":{\"power_admin_component0\":{\"power\":\"27977769-0fc0-4ade-8068-3299d0d66e25\",\"as\":\"default\",\"build\":\"1\"}},\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 3, '', 1, 55), -(80, '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '', '', '{}', '', '', '', 3, 'Llewellyn van der Merwe', '', 'joomla_basic.txt', '', '', 'Octoleo', '1.0.2', 'Copyright (C) 2022. All Rights Reserved', '2023-02-17 12:52:16', '', 'gjvvZWW9dda/XKgVcNl77diP4aIHScvJLVI873vJz9o=', 'fXaT9P1lb2dvQlpl5P8wrebvUJdVqEP5Da+aVdZVh9c=', '', 'QpJksp5hClG8qqwyEMDNBj1r3uzKameP7EKSuc7D3zM=', '', '', '', 1, '', 'Octoleo - Joomla Extension', 'octoleo@vdm.io', '', '', 'TcpNAqfyKC9Kxnonh76heWZTQS41BxXpUAvRPZKVNpo=', '', '70b0c5c7-2735-48a2-824d-39660179da67', 'images/vdm/WHALE500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder/src/branch/staging/libraries/jcb_powers/VDM.Joomla/src/Componentbuilder/Compiler', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '«', '2023-11-28 12:55:47', 3, 'Octoleo', 'Octoleo', '', 4, '', '', '', '', '', '', '', '', '', '', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', 'Joomla Extension', '', '', 'Octoleo', '.git', '', '', 1, '', 'https://git.vdm.dev/Llewellyn', '', '1IbAsXMv1z3laR1QOw/7+5OAKgZ43I1J4FvfS1ZTDSc=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"1\",\"admin_component\":\"\",\"power_admin_component\":{\"power_admin_component0\":{\"power\":\"1a41f760-fb8f-4ded-ab87-9180cc846ca7\",\"as\":\"default\",\"build\":\"2\"}},\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 8, '', 1, 55), -(83, '', 1, '', '', '', 1, '', '', '', 1, '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, 1, 3, 3, 'Llewellyn van der Merwe', '/var/www/sermondistributor_j4', 'SD.txt', '', '', 'Vast Development Method', '4.0.0-beta1', 'Copyright (C) 2015. All Rights Reserved', '2015-10-22 16:59:20', '', 'L0K4HBwUNnpeGTf4rx2/ggxpFlbUErmORKBYS7GXB4U=', 'P+K1TMDoiqK9KAgplYnZKNXjjZZRUN64kUhTHVPndMc=', '', 'igIrKuNnwzTkv6yQTWSlxJxzsj3UU94xRx5zieUpm2s=', '', '', '', 1, '', 'Distributor is a highly advanced sermon distributor that runs on the [Joomla 4.x & 5.x](http://www.joomla.org) framework. You can link a shared folder from Dropbox to the component and use Dropbox as your file host, not to mention the advanced auto builder that gives you the ability to simply load sermons to your website by only adding them to Dropbox.', 'joomla@vdm.io', 1, 'http://vdm.bz/get-sermon-distributor-key', 'XGvstI4CFtBkA5eZjfvf4o8t8ysiqasRS8sWAYi2oPjeARiIu+cKEhMzA6La9ZtQZzspXOokiZYuyOvZqJiD/A==', '/var/git_', '5aeca7ea-25aa-4ebb-b2ef-8e2a11be02af', 'images/vdm/SD500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Sermon-Distributor', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-03-07 13:39:40', 2, 'Sermon Distributor', 'sermondistributor', 'TrueChristianChurch', 4, '', '', '	/**
	* 	The global params
	**/
	protected static $params = false;

	/**
	* 	Update Watcher
	**/
	public static $updateWatch = 1;

	/**
	* 	Update Watcher (if array is only one value)
	**/
	public static $updateWatch_ = 0;

	/**
	* 	The external source links auto
	**/
	protected static $links_externalsource_auto;

	/**
	* 	The external source links manual
	**/
	protected static $links_externalsource_manual;

	/**
	* 	The external source selection auto
	**/
	protected static $select_externalsource_auto;

	/**
	* 	The external source selection manual
	**/
	protected static $select_externalsource_manual;

	/**
	* 	The update errors
	**/
	protected static $updateErrors = array();
[CUSTOMCODE=baseSixtyFourURL]
	/**
	* 	get Download links of a sermon
	**/
	public static function getDownloadLinks(&$sermon)
	{
		$links = array();
		// Get local key
		$localkey = self::getLocalKey();
		// decrypt the urls
		$safe = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 128);
		// internal download url
		$keyCounter = new \stdClass;
		$keyCounter->sermon = $sermon->id;
		if ($sermon->preacher)
		{
			$keyCounter->preacher = $sermon->preacher;
		}
		if ($sermon->series)
		{
			$keyCounter->series = $sermon->series;
		}
		$keyCounterRAW = $safe->encryptString(json_encode($keyCounter));
		$keyCounter = self::base64_urlencode($keyCounterRAW);
		$token = Session::getFormToken();
		$downloadURL = Uri::root().'index.php?option=com_[[[component]]]&task=download.file&key='.$keyCounter.'&token='.$token;
		// check if local .htaccess should be set
		$setHtaccess = false;
		$onclick = ' onclick="sermonCounter(\''.$keyCounterRAW.'\',\'FILENAME\');"';
		// check what source of our link
		switch ($sermon->source)
		{
			case 1:
				// local file get local folder and check if outside root (if not then allow direct)
				$localFolder = ComponentHelper::getParams('com_[[[component]]]')->get('localfolder', JPATH_ROOT.'/images').'/';
				// should we allow direct downloads
				$allowDirect = false;
				if (2 == $sermon->link_type && strpos($localFolder, JPATH_ROOT) !== false)
				{
					$allowDirect = true;
					$localFolderURL = Uri::root().str_replace(JPATH_ROOT, '', $localFolder);
					// insure no double // is in the URL
					$localFolderURL = str_replace('//', '/', $localFolderURL);
					$localFolderURL = str_replace(':/', '://', $localFolderURL);
				}
				// insure no double // is in the path name
				$localFolder = str_replace('//', '/', $localFolder);
				$localFolder = str_replace(':/', '://', $localFolder);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->local_files))
				{
					foreach($sermon->local_files as $key)
					{
						if (1 == $sermon->link_type || !$allowDirect)
						{
							// get the file name use the same method as the auto
							$filename = self::getDownloadFileName($sermon,$key,'local');
							$lockedFolderPath = $safe->encryptString($localFolder.$key);
							$sermon->download_links[$filename] = $downloadURL.'&link='.self::base64_urlencode($lockedFolderPath).'&filename='.$filename;
							$sermon->onclick[$filename] = '';
						}
						elseif (2 == $sermon->link_type && $allowDirect)
						{
							$filename = $key;
							$sermon->download_links[$filename] = $localFolderURL.$key;
							$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							$setHtaccess = true;
						}
					}
				}
				break;
			case 2:
				// Dropbox get global dropbox switch 
				$addToButton = ComponentHelper::getParams('com_[[[component]]]')->get('add_to_button', 0);
				if (1 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->manual_files))
					{
						// manual dropbox
						foreach($sermon->manual_files as $key)
						{
							// get the link
							$dropURL = self::getExternalSourceLink('manual',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name use the same method as the auto
								$filename = self::getDownloadFileName($sermon,$key,'dropbox_manual');
								// should we encrypt string this string
								if ('localKey34fdWEkl' == $localkey || (base64_encode(base64_decode($dropURL, true)) !== $dropURL)) // hmmm no global key has been set
								{
									$dropURL = $safe->encryptString($dropURL);
								}
								// lock the info key
								$infoKey = $safe->encryptString($key);
								$sermon->download_links[$filename] = $downloadURL.'&info='.self::base64_urlencode($infoKey).'&link='.self::base64_urlencode($dropURL).'&filename='.$filename;
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$filename = str_replace('VDM_pLeK_h0uEr/', '', $key);
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->download_links[$filename] = $dropURL;
								}
								else
								{
									$sermon->download_links[$filename] = rtrim($safe->decryptString($dropURL), "\0");
								}
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $addToButton && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', $dropURL);
								}
								else
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString($dropURL), "\0"));
								}
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				elseif (2 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->auto_sermons))
					{
						// automatic dropbox
						foreach($sermon->auto_sermons as $filename => $key)
						{
							// get the link
							$dropURL = self::getExternalSourceLink('auto',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// should we encrypt string this string
								if ('localKey34fdWEkl' == $localkey || (base64_encode(base64_decode($dropURL, true)) !== $dropURL)) // hmmm no global key has been set
								{
									$dropURL = $safe->encryptString($dropURL);
								}
								// lock the info key
								$infoKey = $safe->encryptString($key);
								$sermon->download_links[$filename] = $downloadURL.'&info='.self::base64_urlencode($infoKey).'&link='.self::base64_urlencode($dropURL).'&filename='.$filename;
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->download_links[$filename] = $dropURL;
								}
								else
								{
									$sermon->download_links[$filename] = rtrim($safe->decryptString($dropURL), "\0");
								}
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $addToButton && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', $dropURL);
								}
								else
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString($dropURL), "\0"));
								}
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				break;
			case 3:
				// url get the file name use the same method as the auto
				$filename = self::getDownloadFileName($sermon,$sermon->url,'url');
				if (1 == $sermon->link_type)
				{
					$lockedURL = $safe->encryptString($sermon->url);
					$sermon->download_links[$filename] = $downloadURL.'&link='.self::base64_urlencode($lockedURL).'&filename='.$filename;
					$sermon->onclick[$filename] = '';
				}
				elseif (2 == $sermon->link_type)
				{
					$sermon->download_links[$filename] = $sermon->url;
					$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
				}
				break;
		}
		// remove the values no longer needed
		unset($sermon->local_files);
		unset($sermon->manual_files);
		unset($sermon->auto_sermons);
		unset($sermon->url);
		// should we set the local .htaccess for the download folder
		if ($setHtaccess)
		{
			// TODO we may need to add this latter to enforce download of files.
		}
		return true;
	}

	public static function getNextUpdateValues($asArray = false)
	{
		// find the next value
		$next = false;
		// get actual update values
		$updates = self::getExternalListingUpdateKeys();
		// get last update
		$updatePath = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath('path', 'updatelast', 'txt', 'vDm', JPATH_COMPONENT_ADMINISTRATOR);
		if (($lastUpdate = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($updatePath, FALSE)) !== FALSE && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($updates))
		{
			// is it time to watch
			if (self::$updateWatch_ > 0)
			{
				// increment the watch, as this is the start of new round
				self::$updateWatch++;
				// new round has started
				self::$updateWatch_ = 0;
			}
			// now check what is next
			$lastKey = array_search($lastUpdate, $updates);
			if (!is_null($lastKey))
			{
				$nextKey = $lastKey + 1;
				if (isset($updates[$nextKey]))
				{
					$next = $updates[$nextKey];
				}
				else
				{
					// last item in array, so next round about to start
					self::$updateWatch_++;
				}
			}
		}
		// rest and start with the first key
		if (!$next && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($updates))
		{
			// save the first set
			$start = reset($updates);
			$next = $start;
		}
		// save to file if next is found
		if ($next)
		{
			Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::write($updatePath,$next);
			// convert to array of needed
			if ($asArray)
			{
				if (strpos($next, ',') !== false)
				{
					$next = array_map('trim', explode(',', $next));
				}
				else
				{
					return false;
				}
			}
		}
		return $next;
	}
[CUSTOMCODE=getFilePath]
[CUSTOMCODE=writeFile]
	protected static function saveFile($data, $path_filename)
	{
		return Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::write($path_filename, $data);
	}

	public static function getExternalListingUpdateKeys($id = null, $updateMethod = 2, $returnType = 1)
	{
		// first check if this file already has statistics
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('id','sharedurl','folder','permissiontype','dropboxoptions','build')));
		$query->from($db->quoteName('#__[[[component]]]_external_source'));
		if ($updateMethod && is_numeric($updateMethod))
		{
			$query->where($db->quoteName('update_method') . ' = '. (int) $updateMethod);
		}
		if ($id && is_numeric($id))
		{
			$query->where($db->quoteName('id') . ' = '. (int) $id);
		}
		elseif ($id && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($id))
		{
			$ids = implode(',', array_map( 'intval', $id));
			$query->where($db->quoteName('id') . ' IN  (' . $ids . ')');
		}
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$results = $db->loadObjectList();
			$updates = array();
			foreach ($results as $result)
			{
				if ('full' == $result->permissiontype)
				{
					// load folder or urls
					switch ($result->dropboxoptions)
					{
						case 1: // sharedurl
							if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($result->sharedurl))
							{
								$targets = json_decode($result->sharedurl)->tsharedurl;
							}
						break;
						case 2: // folders
							if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($result->folder))
							{
								$targets = json_decode($result->folder)->tfolder;
							}
						break;
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($targets))
					{
						foreach ($targets as $key => $value)
						{
							$nr = $key + 1;
							// id, target, type
							if (1 == $returnType)
							{
								$updates[] = $result->id . ', '. $nr . ', ' . $result->build;
							}
							else // only return the targets
							{
								$updates[] = $nr;
							}
						}
					}
				}
				else
				{
					// id, target, type
					if (1 == $returnType)
					{
						$updates[] = $result->id . ', 1, '. $result->build;
					}
					else // only return the targets
					{
						$updates[] = 1;
					}
				}
			}
			return $updates;
		}
		return false;
	}

	public static function getExternalSourceLink($type, $return = 7, $get = false, $target = 'links')
	{
		// make sure all defaults are set
		$found = self::checkExternalSourceLocalListing($type, $target);
		if ($found)
		{
			switch($return)
			{
				case 1:
					// return a link
					if (isset(self::${$target.'_externalsource_'.$type}[$get]))
					{
						return self::${$target.'_externalsource_'.$type}[$get];
					}
					break;
				case 2:
					// return all links
					return self::${$target.'_externalsource_'.$type};
					break;
				default :
					// just confirm that it is set
					return true;
					break;
			}
		}
		return false;
	}

	public static function countDownload($counter, $filename)
	{
		// Get local key
		$localkey = self::getLocalKey();
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 128);
		$counter = json_decode(rtrim($opener->decryptString($counter), "\0"));
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($counter))
		{
			$counter->filename = $filename;
			// set the date object
			$date = Factory::getDate();
			// first check if this file already has statistics
			$db = Factory::getDbo();
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('id','counter')));
			$query->from($db->quoteName('#__[[[component]]]_statistic'));
			$query->where($db->quoteName('sermon') . ' = '. (int) $counter->sermon);
			$query->where($db->quoteName('filename') . ' = '. $db->quote($counter->filename));
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$statistic = $db->loadObject();
				// already has an entry
				$statistic->counter++;
				$statistic->modified = $date->toSql();
				// update the entry
				return $db->updateObject('#__[[[component]]]_statistic', $statistic, 'id');
			}
			else
			{
				// set a new entry
				$counter->counter = 1;
				$counter->published = 1;
				$counter->created = $date->toSql();
				$counter->access = 1;
				$counter->version = 1;
				// set a new entry
				$done = $db->insertObject('#__[[[component]]]_statistic', $counter);
				// if done return last used id
				if ($done)
				{
					$newId =  $db->insertid();
					// make sure the access of asset is set
					return self::setAsset($newId,'statistic');
				}
			}
		}
		return false;
	}

	public static function getFileInfo($key)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($key) && (base64_encode(base64_decode($key, true)) === $key))
		{
			// Get local key
			$localkey = self::getLocalKey();
			$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 128);
			$key = rtrim($opener->decryptString($key), "\0");
			// load the links from the database
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select('size');
			$query->from($db->quoteName('#__[[[component]]]_local_listing'));
			$query->where($db->quoteName('key') . ' = '. $db->quote($key));
 			// Reset the query using our newly populated query object.
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$info = array();
				// get the size of the file
				$info['filesize'] = $db->loadResult();
				// get the mime type
				$info['type'] = Super___f11dc790_713e_4706_9a85_a318ed3ad56e___Power::mimeType($key);
				// return info
				return $info;
			}
		}
		return false;
	}

	protected static function getDownloadFileName(&$sermon, $file, $type)
	{
		// first get file name and file type
		$file = str_replace('VDM_pLeK_h0uEr/', '', $file);
		$fileType = pathinfo($file, PATHINFO_EXTENSION);
		if ($fileType)
		{
			$file = str_replace('.'.$fileType, '', $file);
		}
		else
		{
			$fileType = 'error';
		}
		// now build download name
		$downloadName = array();
		// build the Download File Name - first add the preacher name if set
		if ($sermon->preacher)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->preacher_name,'U');
		}
		// add the series name if set
		if ($sermon->series)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->series_name,'F');
		}
		// add the category name if set
		if ($sermon->catid && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($sermon->category))
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->category, 'F');
		}
		if ('dropbox_manual' == $type || 'local' == $type)
		{
			// add the main file name
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($file,'F');
		}
		else
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			if ('error' == $fileType || strpos('?', $fileType) !== false || strpos('&', $fileType) !== false )
			{
				$fileType = 'mp3'; // TODO we don't know the url filetype (setting to mp3 but this could be wrong)
			}
		}
		// now build the download file name
		return implode('__', $downloadName).'.'.$fileType;
	}

	/**
	* 	check External Source Local Listing (do we have the files)
	**/
	public static function checkExternalSourceLocalListing($type, $get = 'links')
	{
		// get the local links
		if (isset(self::${$get.'_externalsource_'.$type}) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::${$get.'_externalsource_'.$type}))
		{
			// return true we have links loaded
			return true;
		}
		else
		{
			$target = array('links' => 'url', 'select' => 'name');
			$build = array( 'auto' => 2, 'manual' => 1);
			if (isset($build[$type]))
			{
				// load the links from the database
				$db = Factory::getDbo();
				// Create a new query object.
				$query = $db->getQuery(true);
				$query->select($db->quoteName(array('key', $target[$get])));
				$query->from($db->quoteName('#__[[[component]]]_local_listing'));
				$query->where($db->quoteName('build') . ' = '. (int) $build[$type]);
				$query->where($db->quoteName('published') . ' = 1'); // TODO we can now limit the links to access groups
 				// Reset the query using our newly populated query object.
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					self::${$get.'_externalsource_'.$type} = $db->loadAssocList('key', $target[$get]);
					// return true we have links loaded
					return true;
				}
			}
		}
		return false;
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = array();
	
	public static function getLocalKey($type = 'basic_key')
	{
		if (!isset(self::$localkey[$type]))
		{
			// get the main key
			self::$localkey[$type] = ComponentHelper::getParams('com_[[[component]]]')->get($type, 'localKey34fdWEkl');
		}
		return self::$localkey[$type];
	}

	public static function updateExternalSource($id, $target = 0, $type = false, $force = false, $sleutel = null)
	{
		$source = self::getVar('external_source', (int) $id, 'id', 'externalsources');
		if (1 == $source) // Dropbox is the source
		{
			// load the file
			JLoader::import('dropboxupdater', JPATH_COMPONENT_SITE.'/helpers');
			// update types
			$types = array('manual','auto');
			// okay now update this type
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($type) && in_array($type,$types))
			{
				$dropbox = new Dropboxupdater();
				if ($dropbox->update($id, $target, $type, $force, $sleutel))
				{
					return true;
				}
				self::setUpdateError($id, $dropbox->getErrors());
				return false;
			}
		}
		self::setUpdateError($id, array(Text::_('The external source could not be found.')));
		return false;
	}

	public static function getSourceStatus($id)
	{
		// fist get errors if any is found
		$errors = array();
		if ($targets = self::getExternalListingUpdateKeys($id, null, 1))
		{
			foreach ($targets as $target)
			{
				$key = preg_replace('/[ ,]+/', '', trim($target));
				if ($error = self::getUpdateError(0, $key))
				{
					$errors[] = $error;
				}
			}
		}
		// check when was the last update
		$updateInfo = self::updateInfo($id);
		if (!$updateInfo)
		{
			$errors[] = Text::_('This source has no local listing set.');
		}
		// build the return string
		if (isset($updateInfo['last']) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errors))
		{
			$body = array();
			// great we have source status
			if (isset($updateInfo['last']))
			{
				$body[] = '<h3>'. Text::_('Listing Info') . '</h3>';
				$body[] = '<p><b>'. Text::_('Last Update') . ':</b> <em>'.$updateInfo['last'];
				$body[] = '</em><br /><b>'. Text::_('Number of Files Listed') . ':</b> <em>'.$updateInfo['qty'];
				$body[] = '</em></p>';
			}
			// now set any errors found
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errors))
			{
				$body[] = '<h3>'. Text::_('Notice!') . '</h3>';
				$body[] = implode('', $errors);
			}
			return '<a class="btn btn-small btn-success" href="#source-status'.$id.'" data-toggle="modal">'.Text::_('View Update Status').'</a>' 
				. Html::_('bootstrap.renderModal', 'source-status'.$id, array('title' => Text::_('Source Status Report.')), implode('', $body));
		}
 		// no status found
		return false;
	}

	public static function updateInfo($id)
	{
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('a.created','a.modified')));
		$query->from($db->quoteName('#__[[[component]]]_local_listing', 'a'));
		$query->where($db->quoteName('a.external_source') . ' = ' . (int) $id);
 		// Reset the query using our newly populated query object.
		$db->setQuery($query);
		$db->execute();
		if ($qty = $db->getNumRows())
		{
			$data = $db->loadRowList();
			$last = 0;
			foreach ($data as $dates)
			{
				foreach ($dates as $date)
				{
					$time = strtotime($date);
					if ($time > $last)
					{
						$last = $time;
					}
				}
			}
			$info['qty'] = (int) $qty;
			$info['last'] = self::fancyDate($last);
			return $info;
		}
		return false;
	}

	public static function getUpdateError($id, $fileKey = null)
	{
		// get update error from file
		if ($fileKey)
		{
			$file_path = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath('path', 'updateerror', 'txt', $fileKey, JPATH_COMPONENT_ADMINISTRATOR);
			// check if it is set
			if (($text = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($file_path, FALSE)) !== FALSE)
			{
				// no error on success
				if ('success' != $text)
				{
					return $text;
				}
			}
			return false;
		}
		elseif (isset(self::$updateErrors[$id]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$updateErrors[$id]))
		{
			return '<ul><li>'.implode('</li><li>', self::$updateErrors[$id]).'</li></ul>';
		}
		return Text::_('Unknown error has occurred.');
	}

	protected static function setUpdateError($id, $errorArray)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errorArray) && $id > 0)
		{
			foreach ($errorArray as $error)
			{
				if (!isset(self::$updateErrors[$id]))
				{
					self::$updateErrors[$id] = array();
				}
				self::$updateErrors[$id][] = $error;
			}
		}
	}
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=curlWorkerHelper]
[CUSTOMCODE=locker]', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vZ2l0LnZkbS5kZXYvY2hyaXN0aWFuL0pvb21sYS1TZXJtb24tRGlzdHJpYnV0b3IvcmF3L2JyYW5jaC9tYXN0ZXIvYWRtaW4vYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KVGhlIGJlc3Qgd2F5IHRvIHNlZSBhbGwgeW91ciBvcHRpb25zIGlzIHRvIGluc3RhbGwgdGhpcyBjb21wb25lbnQgb24geW91IEpvb21sYSB3ZWJzaXRlIGFuZCB0ZXN0IGFsbCBmZWF0dXJlcyB5b3Vyc2VsZi4gSGVyZSBpcyBhIFtkaXJlY3QgZG93bmxvYWQgbGlua10oaHR0cHM6Ly9naXQudmRtLmRldi9jaHJpc3RpYW4vSm9vbWxhLVNlcm1vbi1EaXN0cmlidXRvci9hcmNoaXZlL21hc3Rlci56aXApDQoNCiAqKklmIHlvdSBsaWtlIG91ciBjb21wb25lbnQgcGxlYXNlIHJhdGUgaXQgb24gdGhlIFtKb29tbGEgSW5kZXhdKGh0dHA6Ly9leHRlbnNpb25zLmpvb21sYS5vcmcvZXh0ZW5zaW9ucy9leHRlbnNpb24vbGl2aW5nL3JlbGlnaW9uL3Nlcm1vbi1kaXN0cmlidXRvcikqKg0KDQojIyMgRXhhbXBsZSBXZWJzaXRlLCBUaGF0IEhhcyBPdmVyIDYwMDAgQXVkaW8gRmlsZXMNCg0KW0xvdWRWb2ljZS5vcmddKGh0dHA6Ly93d3cubG91ZHZvaWNlLm9yZykNCltUcnVlQ2hyaXN0aWFuLkNodXJjaF0oaHR0cHM6Ly90cnVlY2hyaXN0aWFuLmNodXJjaC8pDQoNCiMjIyBTb21lIFZpZGVvIERlbW9uc3RyYXRpb25zDQoNCisgW1NldHVwIG92ZXJ2aWV3XShodHRwczovL3lvdXR1LmJlL3lNUHAxQ3AzV18wP3Q9MjBtOHMpDQorIFtTZXR1cCBEcm9wYm94XShodHRwczovL3lvdXR1LmJlL2J0cEtGRGswLWRJKQ0KDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkF1dGhvcio6IFsjIyNBVVRIT1IjIyNdKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCg0KIyMgQnVpbGQgVGltZSA6aG91cmdsYXNzOg0KDQoqKiMjI3RvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI3RvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKiAoYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzYXZlZCAtDQpkdWUgdG8gW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8p', 1, '', 'A sermon distributor that links to Dropbox.', '', '', 'SermonDistributor (public) J4', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', '', 2, 'https://git.vdm.dev/christian/Joomla-Sermon-Distributor/raw/branch/4.x/sermondistributor_update_server.xml', 'https://www.vdm.io/', '', 'CTe2AYh1RvzNnJ5tek4WGInU9PnFW5UVgUE6+8jwUds=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_site_helper\":[]}}', 1, 22, '', 1, 51), -(84, '', 1, '', '', '', 1, '', '', '', 1, '', 1, '', '', 1, 1, 1, 1, '', 1, '', '', 1, '', 1, '{\"addcontributors0\":{\"name\":\"CrossWire\",\"title\":\"Modules\",\"email\":\"sword-support@crosswire.org\",\"website\":\"https:\\/\\/wiki.crosswire.org\\/\",\"use\":\"2\",\"show\":\"3\"}}', 3, 1, 3, 2, 'Llewellyn van der Merwe', '/var/www/getbible_j5', 'getBible.txt', '', '', 'Vast Development Method', '5.0.12', 'Copyright (C) 2015. All Rights Reserved', '2015-12-03 01:42:15', '', '0XN4CcxFXCsxCXgMFjh2D0Dwqdy1AIqsbGC0LVszx2Q=', 'I6X7uvf/xn8zG2BHZx2oLsXwWfr4JG4DreGhyvNZFg8=', '', 'VDSl2o9iyJbk2J9aJCjxhYrp/G6JqRZkevdNX894bNc=', '', '', '', 1, '', 'Welcome to the next level of scripture engagement - The Bible for Joomla! Our purpose is to bring the Word of God to every person, in their native language, entirely free. This isn\'t just a typical extension; it\'s a groundbreaking tool developed to span language divides and deliver a rich, customizable Bible study experience to users worldwide.\r\n\r\nWith an impressive array of 80 translations, our Joomla extension allows people from all corners of the globe to read, comprehend, and meditate on the Holy Scriptures in their preferred language. Moreover, we offer the unique opportunity for individuals to host the Bible on their own website, further extending the reach of the Word.\r\n\r\nWe\'ve integrated robust features such as note-taking, tagging, and a search function, to enhance your interaction with the Scriptures. This allows users to immerse themselves in the text, crafting a personal journey through the Bible that can be revisited in future sessions. Furthermore, our innovative linker system assigns each visitor a unique identifier (GUID) - no login required. This means you can create notes, select favorite verses, and even share sessions, while maintaining control over your personalized content.\r\n\r\nA distinctive feature of our application is the integration with OpenAI. This advanced capability allows website owners to create custom prompts to interact with OpenAI using text from any translation. This function allows you to ask questions, gain clarity, and deepen your understanding of the Scriptures in an engaging and user-friendly manner.\r\n\r\nIn essence, The Bible for Joomla is designed to transform how the Word of God is shared, studied, and comprehended. Its comprehensive features, combined with a user-friendly interface, make it an essential tool for individuals, churches, and website owners alike. Join us on this journey of faith as we make the wisdom and guidance of the Scriptures accessible to all, one verse, one language, and one website at a time.', 'joomla@vdm.io', '', 'https://vdm.bz/get-bible', 'rPFLeDAp4QRfwLLtJwZnujlR11b2sDDB4wJQVzYSAbU=', '/var/git_', 'bbe46e21-60a6-4fb2-8010-97f30d01472d', 'images/getBible.jpg', '', 'https://git.vdm.dev/getBible/joomla-component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-04-25 15:35:17', '', 'Get Bible', 'Getbible', 'TrueChristianChurch', 4, '', '', 'CS8qKg0KCSAqIExvYWQgdGhlIHNjcmlwdHVyZSBpbnRvIGNvbnRlbnQNCgkgKg0KCSAqIEBwYXJhbSAgIG9iamVjdCAgICYkcm93ICAgICBUaGUgYXJ0aWNsZSBvYmplY3QuICBOb3RlICRhcnRpY2xlLT50ZXh0IGlzIGFsc28gYXZhaWxhYmxlDQoJICogQHBhcmFtICAgb2JqZWN0ICAgJHBsdWdpbiAgIFRoZSBwbHVnaW4gcGFyYW1zDQoJICoNCgkgKiBAcmV0dXJuICB2b2lkDQoJICogQHNpbmNlICAgMi4wLjENCgkgKiovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBsb2FkU2NyaXB0dXJlKG9iamVjdCAmJHJvdywgb2JqZWN0ICRwbHVnaW4pOiB2b2lkDQoJew0KCQkvLyBnZXQgY2FsbCBzdHJpbmcNCgkJJGNhbGxfY2xhc3MgPSAkcGx1Z2luLT5nZXQoJ2NhbGxfY2xhc3MnLCAnZ2V0QmlibGUnKTsNCg0KCQkvLyBTaW1wbGUgcGVyZm9ybWFuY2UgY2hlY2sgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYm90IHNob3VsZCBwcm9jZXNzIGZ1cnRoZXINCgkJaWYgKHN0cnBvcygkcm93LT50ZXh0LCAkY2FsbF9jbGFzcykgPT09IGZhbHNlKQ0KCQl7DQoJCQlyZXR1cm47DQoJCX0NCg0KCQlTdXBlcl9fXzExODkyY2ZhXzM3NGVfNGUzZl9iMGJjXzUzMTg3MWM4MjJkOV9fX1Bvd2VyOjpfKCdHZXRCaWJsZS5Mb2FkZXInKS0+c2V0KCRyb3csICRwbHVnaW4pOw0KCX0=', '', '', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9Z2V0QmlibGVSZW1vdmVPbGRMaWJdDQpbQ1VTVE9NQ09ERT1waHBDb25maWd1cmF0aW9uQ2hlY2tDYWxsKyR0aGlzLT5hcHBd', 'W0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskdGhpcy0+YXBwXQ==', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vZ2l0LnZkbS5kZXYvZ2V0QmlibGUvam9vbWxhLWNvbXBvbmVudC9yYXcvYnJhbmNoLzUuMC9hZG1pbi9hc3NldHMvaW1hZ2VzL3ZkbS1jb21wb25lbnQuanBnICJHZXRCaWJsZSIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IG5ldmVyIG1ha2luZyBvbmUgbWlzdGFrZSBvciB0YWtpbmcgYW55IGNvZmZlZSBicmVhay4pDQoNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCioqIyMjYWN0dWFsSG91cnNTcGVudCMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsRGF5c1NwZW50IyMjIEVpZ2h0IEhvdXIgRGF5cyoqICh0aGUgYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzcGVudCkNCg0KPiAod2l0aCB0aGUgZm9sbG93aW5nIGJyZWFrIGRvd246DQo+ICoqZGVidWdnaW5nIEAjIyNkZWJ1Z2dpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNDsNCj4gKipwbGFubmluZyBAIyMjcGxhbm5pbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNzsNCj4gKiptYXBwaW5nIEAjIyNtYXBwaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDEwOw0KPiAqKm9mZmljZSBAIyMjb2ZmaWNlSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDY7KQ0KDQoqKiMjI2FjdHVhbFRvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbFRvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKg0KKGEgdG90YWwgb2YgdGhlIHJlYWxpc3RpYyB0aW1lIGZyYW1lIGZvciB0aGlzIHByb2plY3QpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IHdpdGggdGhlIG5vcm1hbCBldmVyeWRheSByZWFsaXRpZXMgYXQgdGhlIG9mZmljZSwgdGhhdCBpbmNsdWRlcyB0aGUgY29tcG9uZW50IHBsYW5uaW5nLCBtYXBwaW5nICYgZGVidWdnaW5nLikNCg0KUHJvamVjdCBkdXJhdGlvbjogKiojIyNwcm9qZWN0V2Vla1RpbWUjIyMgd2Vla3MqKiBvciAqKiMjI3Byb2plY3RNb250aFRpbWUjIyMgbW9udGhzKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKQ==', 1, '', 'The Bible for Joomla', 'Q1JFQVRFIElOREVYIGlkeF8jX19bW1tjb21wb25lbnRdXV1fdGFnZ2VkX3ZlcnNlX29uX2xpbmtlcl9hbmRfdGFnDQpPTiAjX19bW1tjb21wb25lbnRdXV1fdGFnZ2VkX3ZlcnNlKGxpbmtlciwgdGFnKTsNCg0KQ1JFQVRFIElOREVYIGlkeF8jX19bW1tjb21wb25lbnRdXV1fdmVyc2Vfb25fdmVyc2VfYW5kX2FiYnJldmlhdGlvbg0KT04gI19fW1tbY29tcG9uZW50XV1dX3ZlcnNlKHZlcnNlLCBhYmJyZXZpYXRpb24pOw0KDQpDUkVBVEUgSU5ERVggaWR4XyNfX1tbW2NvbXBvbmVudF1dXV9ib29rX29uX25yX2FuZF9hYmJyZXZpYXRpb24NCk9OICNfX1tbW2NvbXBvbmVudF1dXV9ib29rKG5yLCBhYmJyZXZpYXRpb24pOw0KDQpDUkVBVEUgSU5ERVggaWR4XyNfX1tbW2NvbXBvbmVudF1dXV90YWdfb25fZ3VpZF9hbmRfcHVibGlzaGVkDQpPTiAjX19bW1tjb21wb25lbnRdXV1fdGFnKGd1aWQsIHB1Ymxpc2hlZCk7', '', 'Get Bible J5', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', '', 2, 'https://git.vdm.dev/getBible/joomla-component/raw/branch/5.x/update_server.xml', 'https://getbible.net', '', 'CLMpkr0hmWG0WixbK+MiXAMRzXc19qym7pfWgMP6XNQ=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"\",\"power_admin_helper\":{\"power_admin_helper0\":{\"power\":\"11892cfa-374e-4e3f-b0bc-531871c822d9\",\"as\":\"GetBibleFactory\",\"build\":\"1\"},\"power_admin_helper1\":{\"power\":\"4612af84-5a42-4ea5-87bf-9d79cc19c330\",\"as\":\"GiteaFactory\",\"build\":\"1\"}},\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 23, '', 1, 53), -(85, 1, 1, 1, '', 1, '', '', '', 1, 1, '', 1, '', '', 1, 1, 1, 1, '', 1, '', 1, 1, 1, 1, '', 3, 1, 3, 2, 'Llewellyn van der Merwe', '/var/www/jcb_j5', 'JCB.txt', '', '', 'Vast Development Method', '5.0.0-rc1', 'Copyright (C) 2015 Vast Development Method. All rights reserved.', '2015-04-30 12:04:35', '', 'r35h7GKtIY16mKdfOZcYz5p1gBuLfGZ1D/zsj9xZsSI=', 'P2XujNqxhLXCvrszLHvzLOZtmwtZ0G/sSd/v9q8y91U=', '', 'Rr66kUKLlDlnyYgUuJHgPHClIrU3q9w6KTgapmoY8sI=', 'LmZpZWxkTWVkaXVtIHsgd2lkdGg6IDEyMHB4OyB9DQouZmllbGRMYXJnZSB7IHdpZHRoOiAzMjBweDsgfQ0KLmZpZWxkTWlkIHsgd2lkdGg6IDgwcHg7IH0NCi5maWVsZEZ1bGwgeyB3aWR0aDogMTAwJTsgfQ0KLmZpZWxkU21hbGwgeyB3aWR0aDogNjBweDsgfQ0KY29kZSB7IGRpc3BsYXk6IGlubGluZS1ibG9jazsgbWFyZ2luOiAzcHg7fQ==', '', '', 1, '', 'The Component Builder for [Joomla](https://extensions.joomla.org/extension/component-builder/) is highly advanced tool that is truly able to build extremely complex components in a fraction of the time.\r\n\r\nWhether you\'re a seasoned [Joomla](https://extensions.joomla.org/extension/component-builder/) developer, or have just started, Component Builder will save you lots of time and money. A real must have!', 'joomla@vdm.io', '', 'https://vdm.bz/component-builder-self', 'mbosbpYKPxqf1TgM4T3HdThzA4Csx7uJ++3WlVmONfg=', '', '3d694e49-3821-41b3-a8b5-f262506e9673', 'images/vdm/jcb500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder', 'GNU General Public License version 2 or later; see LICENSE.txt', 1, '✓', '2024-04-27 10:55:57', 2, 'Component Builder', 'Componentbuilder', 'VDM', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlckhlbHBlckJvdGhd', '', '', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskdGhpcy0+YXBwXQ==', 'W0NVU1RPTUNPREU9Y29tcG9uZW50QnVpbGRlclByZWZsaWdodFVwZGF0ZUpmaXZlXQ0KW0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskdGhpcy0+YXBwXQ==', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclJlYWRNZV0=', 1, '', 'Builds Complex Joomla Components', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMSW5zdGFsbF0=', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMVW5pbnN0YWxsXQ==', 'Component Builder (Public) J5', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', 3, 2, 'https://git.vdm.dev/joomla/Component-Builder/raw/branch/5.x/componentbuilder_update_server.xml', 'https://dev.vdm.io', '', 'OhMBUNLb8a0uJIyDBTR7DHydbI+odzre/AwNBAP5uOY=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"0\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\\r\\nuse Joomla\\\\CMS\\\\Session\\\\Session;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\\r\\nuse Joomla\\\\CMS\\\\Session\\\\Session;\",\"power_site_helper\":[]}}', 1, 42, '', 1, 1), -(86, '', '', '', '', '', '', '', '', 1, '', '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, 1, 1, 3, 'Llewellyn', '', 'default.txt', '', '', 'VDM', '5.0.0', 'Copyright (C) 2015. All Rights Reserved', '2024-02-02 16:07:26', '', 'nBiES/HRMHYRdi2aYge8F1G3fOI436PehiXXUty6J7A=', '3Ek9cjcehKnHQLNiBLLhCpF+h53s2yWSqW97IFT/3Fo=', '', 'I6IvNpSaDtIK17mSc/OrqFFnJMajZPYaeBSCIqgLmGg=', '', '', '', 1, '', '', 'joomla@vdm.io', '', '', 'MLFFvGPVwPR5C7cK9g1SKaJvtolooz9HTTbPH91lhb0=', '', '3745af8f-f96b-4e17-831e-eb4062cd4389', 'images/demo300.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Hello-World-Component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-03-07 13:38:41', '', 'Hello World', 'HelloWorld', 'JCB', 4, '', '', 'W0NVU1RPTUNPREU9d3JpdGVGaWxlXQ0KW0NVU1RPTUNPREU9Z2V0RmlsZUNvbnRlbnRzXQ0KW0NVU1RPTUNPREU9cmVtb3ZlRm9sZGVyXQ==', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpOYW1lKjogWyMjI0NvbXBvbmVudF9uYW1lIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqRmlyc3QgQnVpbGQqOiAjIyNDUkVBVElPTkRBVEUjIyMNCisgKkxhc3QgQnVpbGQqOiAjIyNCVUlMRERBVEUjIyMNCisgKlZlcnNpb24qOiAjIyNWRVJTSU9OIyMjDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCiMjIEJ1aWxkIFRpbWUNCg0KKiojIyN0b3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyN0b3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKiogKGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc2F2ZWQgLQ0KZHVlIHRvIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKSkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gbmV2ZXIgbWFraW5nIG9uZSBtaXN0YWtlIG9yIHRha2luZyBhbnkgY29mZmVlIGJyZWFrLikNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KKiojIyNhY3R1YWxIb3Vyc1NwZW50IyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxEYXlzU3BlbnQjIyMgRWlnaHQgSG91ciBEYXlzKiogKHRoZSBhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNwZW50KQ0KDQo+ICh3aXRoIHRoZSBmb2xsb3dpbmcgYnJlYWsgZG93bjoNCj4gKipkZWJ1Z2dpbmcgQCMjI2RlYnVnZ2luZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA0Ow0KPiAqKnBsYW5uaW5nIEAjIyNwbGFubmluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA3Ow0KPiAqKm1hcHBpbmcgQCMjI21hcHBpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gMTA7DQo+ICoqb2ZmaWNlIEAjIyNvZmZpY2VIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNjspDQoNCioqIyMjYWN0dWFsVG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsVG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqDQooYSB0b3RhbCBvZiB0aGUgcmVhbGlzdGljIHRpbWUgZnJhbWUgZm9yIHRoaXMgcHJvamVjdCkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gd2l0aCB0aGUgbm9ybWFsIGV2ZXJ5ZGF5IHJlYWxpdGllcyBhdCB0aGUgb2ZmaWNlLCB0aGF0IGluY2x1ZGVzIHRoZSBjb21wb25lbnQgcGxhbm5pbmcsIG1hcHBpbmcgJiBkZWJ1Z2dpbmcuKQ0KDQpQcm9qZWN0IGR1cmF0aW9uOiAqKiMjI3Byb2plY3RXZWVrVGltZSMjIyB3ZWVrcyoqIG9yICoqIyMjcHJvamVjdE1vbnRoVGltZSMjIyBtb250aHMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkuDQo+IERldmVsb3BlZCBieSBbTGxld2VsbHluIHZhbiBkZXIgTWVyd2VdKG1haWx0bzpqb29tbGFAdmRtLmlvKQ0KDQpbQ1VTVE9NQ09ERT1yZWFkTUVjb250cmlidXRvcnNd', '', '', 'Hello World', '', '', 'HelloWorld (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/Llewellynvdm/Joomla-Hello-World-Component/master/helloworld_updateserver.xml', 'https://www.vdm.io', '', 'IYXEGnRpJLAhUHUm1R0kWAwYZdCVUAXn7W5LPacqCgM=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_site_helper\":[]}}', 1, 3, '', 1, 48), -(87, '', 1, '', '', '', 1, '', '', '', 1, '', 1, '', '', 1, 1, 1, 1, '', 1, '', '', 1, '', 1, '{\"addcontributors0\":{\"name\":\"CrossWire\",\"title\":\"Modules\",\"email\":\"sword-support@crosswire.org\",\"website\":\"https:\\/\\/wiki.crosswire.org\\/\",\"use\":\"2\",\"show\":\"3\"}}', 3, 1, 3, 2, 'Llewellyn van der Merwe', '/var/www/getbible_j4', 'getBible.txt', '', '', 'Vast Development Method', '4.0.12', 'Copyright (C) 2015. All Rights Reserved', '2015-12-03 01:42:15', '', 'RR4KRth9vUzGwahsXvGuDlE7/MZqGaa2oIVUysoj+Cc=', '5ueRIZmVndaaM0V//2OhWRG9EqiL+xkS8D1upoNI4n0=', '', 'zlDXIGUCHWjXN/D08bLet3sQs9jOE+coYn5i/vK1JlA=', '', '', '', 1, '', 'Welcome to the next level of scripture engagement - The Bible for Joomla! Our purpose is to bring the Word of God to every person, in their native language, entirely free. This isn\'t just a typical extension; it\'s a groundbreaking tool developed to span language divides and deliver a rich, customizable Bible study experience to users worldwide.\r\n\r\nWith an impressive array of 80 translations, our Joomla extension allows people from all corners of the globe to read, comprehend, and meditate on the Holy Scriptures in their preferred language. Moreover, we offer the unique opportunity for individuals to host the Bible on their own website, further extending the reach of the Word.\r\n\r\nWe\'ve integrated robust features such as note-taking, tagging, and a search function, to enhance your interaction with the Scriptures. This allows users to immerse themselves in the text, crafting a personal journey through the Bible that can be revisited in future sessions. Furthermore, our innovative linker system assigns each visitor a unique identifier (GUID) - no login required. This means you can create notes, select favorite verses, and even share sessions, while maintaining control over your personalized content.\r\n\r\nA distinctive feature of our application is the integration with OpenAI. This advanced capability allows website owners to create custom prompts to interact with OpenAI using text from any translation. This function allows you to ask questions, gain clarity, and deepen your understanding of the Scriptures in an engaging and user-friendly manner.\r\n\r\nIn essence, The Bible for Joomla is designed to transform how the Word of God is shared, studied, and comprehended. Its comprehensive features, combined with a user-friendly interface, make it an essential tool for individuals, churches, and website owners alike. Join us on this journey of faith as we make the wisdom and guidance of the Scriptures accessible to all, one verse, one language, and one website at a time.', 'joomla@vdm.io', '', 'https://vdm.bz/get-bible', 'P/9mu1sMoY6DTUiVy8dBt6OYYnw1ov6SL/DxzJl4eXw=', '/var/git_', '626c492a-25c8-4567-a9d0-1e2c80789308', 'images/getBible.jpg', '', 'https://git.vdm.dev/getBible/joomla-component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-04-25 15:35:10', '', 'Get Bible', 'Getbible', 'TrueChristianChurch', 4, '', '', 'CS8qKg0KCSAqIExvYWQgdGhlIHNjcmlwdHVyZSBpbnRvIGNvbnRlbnQNCgkgKg0KCSAqIEBwYXJhbSAgIG9iamVjdCAgICYkcm93ICAgICBUaGUgYXJ0aWNsZSBvYmplY3QuICBOb3RlICRhcnRpY2xlLT50ZXh0IGlzIGFsc28gYXZhaWxhYmxlDQoJICogQHBhcmFtICAgb2JqZWN0ICAgJHBsdWdpbiAgIFRoZSBwbHVnaW4gcGFyYW1zDQoJICoNCgkgKiBAcmV0dXJuICB2b2lkDQoJICogQHNpbmNlICAgMi4wLjENCgkgKiovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBsb2FkU2NyaXB0dXJlKG9iamVjdCAmJHJvdywgb2JqZWN0ICRwbHVnaW4pOiB2b2lkDQoJew0KCQkvLyBnZXQgY2FsbCBzdHJpbmcNCgkJJGNhbGxfY2xhc3MgPSAkcGx1Z2luLT5nZXQoJ2NhbGxfY2xhc3MnLCAnZ2V0QmlibGUnKTsNCg0KCQkvLyBTaW1wbGUgcGVyZm9ybWFuY2UgY2hlY2sgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYm90IHNob3VsZCBwcm9jZXNzIGZ1cnRoZXINCgkJaWYgKHN0cnBvcygkcm93LT50ZXh0LCAkY2FsbF9jbGFzcykgPT09IGZhbHNlKQ0KCQl7DQoJCQlyZXR1cm47DQoJCX0NCg0KCQlTdXBlcl9fXzExODkyY2ZhXzM3NGVfNGUzZl9iMGJjXzUzMTg3MWM4MjJkOV9fX1Bvd2VyOjpfKCdHZXRCaWJsZS5Mb2FkZXInKS0+c2V0KCRyb3csICRwbHVnaW4pOw0KCX0=', '', '', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9Z2V0QmlibGVSZW1vdmVPbGRMaWJdDQpbQ1VTVE9NQ09ERT1waHBDb25maWd1cmF0aW9uQ2hlY2tDYWxsKyR0aGlzLT5hcHBd', 'W0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskdGhpcy0+YXBwXQ==', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vZ2l0LnZkbS5kZXYvZ2V0QmlibGUvam9vbWxhLWNvbXBvbmVudC9yYXcvYnJhbmNoLzUuMC9hZG1pbi9hc3NldHMvaW1hZ2VzL3ZkbS1jb21wb25lbnQuanBnICJHZXRCaWJsZSIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy5qb29tbGFjb21wb25lbnRidWlsZGVyLmNvbSkpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IG5ldmVyIG1ha2luZyBvbmUgbWlzdGFrZSBvciB0YWtpbmcgYW55IGNvZmZlZSBicmVhay4pDQoNCisgKkxpbmUgY291bnQqOiAqKiMjI0xJTkVfQ09VTlQjIyMqKg0KKyAqRmlsZSBjb3VudCo6ICoqIyMjRklMRV9DT1VOVCMjIyoqDQorICpGb2xkZXIgY291bnQqOiAqKiMjI0ZPTERFUl9DT1VOVCMjIyoqDQoNCioqIyMjYWN0dWFsSG91cnNTcGVudCMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsRGF5c1NwZW50IyMjIEVpZ2h0IEhvdXIgRGF5cyoqICh0aGUgYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzcGVudCkNCg0KPiAod2l0aCB0aGUgZm9sbG93aW5nIGJyZWFrIGRvd246DQo+ICoqZGVidWdnaW5nIEAjIyNkZWJ1Z2dpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNDsNCj4gKipwbGFubmluZyBAIyMjcGxhbm5pbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNzsNCj4gKiptYXBwaW5nIEAjIyNtYXBwaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDEwOw0KPiAqKm9mZmljZSBAIyMjb2ZmaWNlSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDY7KQ0KDQoqKiMjI2FjdHVhbFRvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbFRvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKg0KKGEgdG90YWwgb2YgdGhlIHJlYWxpc3RpYyB0aW1lIGZyYW1lIGZvciB0aGlzIHByb2plY3QpDQoNCj4gKGlmIGNyZWF0aW5nIGEgZm9sZGVyIGFuZCBmaWxlIHRvb2sgKio1IHNlY29uZHMqKiBhbmQgd3JpdGluZyBvbmUgbGluZSBvZiBjb2RlIHRvb2sgKioxMCBzZWNvbmRzKiosDQo+IHdpdGggdGhlIG5vcm1hbCBldmVyeWRheSByZWFsaXRpZXMgYXQgdGhlIG9mZmljZSwgdGhhdCBpbmNsdWRlcyB0aGUgY29tcG9uZW50IHBsYW5uaW5nLCBtYXBwaW5nICYgZGVidWdnaW5nLikNCg0KUHJvamVjdCBkdXJhdGlvbjogKiojIyNwcm9qZWN0V2Vla1RpbWUjIyMgd2Vla3MqKiBvciAqKiMjI3Byb2plY3RNb250aFRpbWUjIyMgbW9udGhzKioNCg0KPiBUaGlzICoqY29tcG9uZW50Kiogd2FzIGJ1aWxkIHdpdGggYSBKb29tbGEgW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pLg0KPiBEZXZlbG9wZWQgYnkgW0xsZXdlbGx5biB2YW4gZGVyIE1lcndlXShtYWlsdG86am9vbWxhQHZkbS5pbykNCg0KIyMgRG9uYXRpb25zDQoNCklmIHlvdSB3YW50IHRvIHN1cHBvcnQgdGhpcyBwcm9qZWN0LCBwbGVhc2UgY29uc2lkZXIgZG9uYXRpbmc6DQoqIE9wZW4gQ29sbGVjdGl2ZTogW0pvb21sYS1Db21wb25lbnQtQnVpbGRlcl0oaHR0cHM6Ly9vcGVuY29sbGVjdGl2ZS5jb20vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyKQ==', 1, '', 'The Bible for Joomla', 'Q1JFQVRFIElOREVYIGlkeF8jX19bW1tjb21wb25lbnRdXV1fdGFnZ2VkX3ZlcnNlX29uX2xpbmtlcl9hbmRfdGFnDQpPTiAjX19bW1tjb21wb25lbnRdXV1fdGFnZ2VkX3ZlcnNlKGxpbmtlciwgdGFnKTsNCg0KQ1JFQVRFIElOREVYIGlkeF8jX19bW1tjb21wb25lbnRdXV1fdmVyc2Vfb25fdmVyc2VfYW5kX2FiYnJldmlhdGlvbg0KT04gI19fW1tbY29tcG9uZW50XV1dX3ZlcnNlKHZlcnNlLCBhYmJyZXZpYXRpb24pOw0KDQpDUkVBVEUgSU5ERVggaWR4XyNfX1tbW2NvbXBvbmVudF1dXV9ib29rX29uX25yX2FuZF9hYmJyZXZpYXRpb24NCk9OICNfX1tbW2NvbXBvbmVudF1dXV9ib29rKG5yLCBhYmJyZXZpYXRpb24pOw0KDQpDUkVBVEUgSU5ERVggaWR4XyNfX1tbW2NvbXBvbmVudF1dXV90YWdfb25fZ3VpZF9hbmRfcHVibGlzaGVkDQpPTiAjX19bW1tjb21wb25lbnRdXV1fdGFnKGd1aWQsIHB1Ymxpc2hlZCk7', '', 'Get Bible J4', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', '', 2, 'https://git.vdm.dev/getBible/joomla-component/raw/branch/4.x/update_server.xml', 'https://getbible.net', '', 'sarvt+VcI4GQlwrmL1w3kRhszBhGjIZwPdDFkiP+TvI=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"\",\"power_admin_helper\":{\"power_admin_helper0\":{\"power\":\"11892cfa-374e-4e3f-b0bc-531871c822d9\",\"as\":\"GetBibleFactory\",\"build\":\"1\"},\"power_admin_helper1\":{\"power\":\"4612af84-5a42-4ea5-87bf-9d79cc19c330\",\"as\":\"GiteaFactory\",\"build\":\"1\"}},\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 12, '', 1, 53), -(88, '', 1, '', '', '', 1, '', '', '', 1, '', 1, '', '', '', '', '', '', '', 1, '', '', '', '', 1, '{}', 3, 1, 3, 3, 'Llewellyn van der Merwe', '/var/www/sermondistributor_j5', 'SD.txt', '', '', 'Vast Development Method', '5.0.0-beta1', 'Copyright (C) 2015. All Rights Reserved', '2015-10-22 16:59:20', '', 'sCJHDIYwBV3t4M72i8g316yIPusajHN3qfiNBvsCg/g=', '18hUvFIOBZv3HelZKP4Ww7twWuxFqe65V3FxJmgMVzk=', '', '/WHc+nIN3Myh9BMZ9B80n/K9dMUsvO9hP8thR1OwOEY=', '', '', '', 1, '', 'Distributor is a highly advanced sermon distributor that runs on the [Joomla 4.x & 5.x](http://www.joomla.org) framework. You can link a shared folder from Dropbox to the component and use Dropbox as your file host, not to mention the advanced auto builder that gives you the ability to simply load sermons to your website by only adding them to Dropbox.', 'joomla@vdm.io', 1, 'http://vdm.bz/get-sermon-distributor-key', 'aXQ+iPTzl4tip40QGvzIh0EpOLfmTXtBW9L7fzzHTTL6miU3cDvcvQKkgCHv8XRLiVBi3KoxUV0SDXTIM88PKg==', '/var/git_', '2a62e359-1500-4adb-a2b5-f8d97f23d782', 'images/vdm/SD500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Sermon-Distributor', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-03-07 17:17:15', 2, 'Sermon Distributor', 'sermondistributor', 'TrueChristianChurch', 4, '', '', '	/**
	* 	The global params
	**/
	protected static $params = false;

	/**
	* 	Update Watcher
	**/
	public static $updateWatch = 1;

	/**
	* 	Update Watcher (if array is only one value)
	**/
	public static $updateWatch_ = 0;

	/**
	* 	The external source links auto
	**/
	protected static $links_externalsource_auto;

	/**
	* 	The external source links manual
	**/
	protected static $links_externalsource_manual;

	/**
	* 	The external source selection auto
	**/
	protected static $select_externalsource_auto;

	/**
	* 	The external source selection manual
	**/
	protected static $select_externalsource_manual;

	/**
	* 	The update errors
	**/
	protected static $updateErrors = array();
[CUSTOMCODE=baseSixtyFourURL]
	/**
	* 	get Download links of a sermon
	**/
	public static function getDownloadLinks(&$sermon)
	{
		$links = array();
		// Get local key
		$localkey = self::getLocalKey();
		// decrypt the urls
		$safe = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 128);
		// internal download url
		$keyCounter = new \stdClass;
		$keyCounter->sermon = $sermon->id;
		if ($sermon->preacher)
		{
			$keyCounter->preacher = $sermon->preacher;
		}
		if ($sermon->series)
		{
			$keyCounter->series = $sermon->series;
		}
		$keyCounterRAW = $safe->encryptString(json_encode($keyCounter));
		$keyCounter = self::base64_urlencode($keyCounterRAW);
		$token = Session::getFormToken();
		$downloadURL = Uri::root().'index.php?option=com_[[[component]]]&task=download.file&key='.$keyCounter.'&token='.$token;
		// check if local .htaccess should be set
		$setHtaccess = false;
		$onclick = ' onclick="sermonCounter(\''.$keyCounterRAW.'\',\'FILENAME\');"';
		// check what source of our link
		switch ($sermon->source)
		{
			case 1:
				// local file get local folder and check if outside root (if not then allow direct)
				$localFolder = ComponentHelper::getParams('com_[[[component]]]')->get('localfolder', JPATH_ROOT.'/images').'/';
				// should we allow direct downloads
				$allowDirect = false;
				if (2 == $sermon->link_type && strpos($localFolder, JPATH_ROOT) !== false)
				{
					$allowDirect = true;
					$localFolderURL = Uri::root().str_replace(JPATH_ROOT, '', $localFolder);
					// insure no double // is in the URL
					$localFolderURL = str_replace('//', '/', $localFolderURL);
					$localFolderURL = str_replace(':/', '://', $localFolderURL);
				}
				// insure no double // is in the path name
				$localFolder = str_replace('//', '/', $localFolder);
				$localFolder = str_replace(':/', '://', $localFolder);
				if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->local_files))
				{
					foreach($sermon->local_files as $key)
					{
						if (1 == $sermon->link_type || !$allowDirect)
						{
							// get the file name use the same method as the auto
							$filename = self::getDownloadFileName($sermon,$key,'local');
							$lockedFolderPath = $safe->encryptString($localFolder.$key);
							$sermon->download_links[$filename] = $downloadURL.'&link='.self::base64_urlencode($lockedFolderPath).'&filename='.$filename;
							$sermon->onclick[$filename] = '';
						}
						elseif (2 == $sermon->link_type && $allowDirect)
						{
							$filename = $key;
							$sermon->download_links[$filename] = $localFolderURL.$key;
							$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							$setHtaccess = true;
						}
					}
				}
				break;
			case 2:
				// Dropbox get global dropbox switch 
				$addToButton = ComponentHelper::getParams('com_[[[component]]]')->get('add_to_button', 0);
				if (1 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->manual_files))
					{
						// manual dropbox
						foreach($sermon->manual_files as $key)
						{
							// get the link
							$dropURL = self::getExternalSourceLink('manual',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// get the file name use the same method as the auto
								$filename = self::getDownloadFileName($sermon,$key,'dropbox_manual');
								// should we encrypt string this string
								if ('localKey34fdWEkl' == $localkey || (base64_encode(base64_decode($dropURL, true)) !== $dropURL)) // hmmm no global key has been set
								{
									$dropURL = $safe->encryptString($dropURL);
								}
								// lock the info key
								$infoKey = $safe->encryptString($key);
								$sermon->download_links[$filename] = $downloadURL.'&info='.self::base64_urlencode($infoKey).'&link='.self::base64_urlencode($dropURL).'&filename='.$filename;
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								$filename = str_replace('VDM_pLeK_h0uEr/', '', $key);
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->download_links[$filename] = $dropURL;
								}
								else
								{
									$sermon->download_links[$filename] = rtrim($safe->decryptString($dropURL), "\0");
								}
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $addToButton && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', $dropURL);
								}
								else
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString($dropURL), "\0"));
								}
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				elseif (2 == $sermon->build)
				{
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($sermon->auto_sermons))
					{
						// automatic dropbox
						foreach($sermon->auto_sermons as $filename => $key)
						{
							// get the link
							$dropURL = self::getExternalSourceLink('auto',1,$key);
							if (1 == $sermon->link_type && $dropURL)
							{
								// should we encrypt string this string
								if ('localKey34fdWEkl' == $localkey || (base64_encode(base64_decode($dropURL, true)) !== $dropURL)) // hmmm no global key has been set
								{
									$dropURL = $safe->encryptString($dropURL);
								}
								// lock the info key
								$infoKey = $safe->encryptString($key);
								$sermon->download_links[$filename] = $downloadURL.'&info='.self::base64_urlencode($infoKey).'&link='.self::base64_urlencode($dropURL).'&filename='.$filename;
								$sermon->onclick[$filename] = '';
							}
							elseif (2 == $sermon->link_type && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->download_links[$filename] = $dropURL;
								}
								else
								{
									$sermon->download_links[$filename] = rtrim($safe->decryptString($dropURL), "\0");
								}
								$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
							// build dropbox switch if needed
							if (1 == $addToButton && $dropURL)
							{
								if ('localKey34fdWEkl' == $localkey) // hmmm no global key has been set (so don't decrypt)
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', $dropURL);
								}
								else
								{
									$sermon->dropbox_buttons[$filename] = str_replace('?dl=1', '?dl=0', rtrim($safe->decryptString($dropURL), "\0"));
								}
								$sermon->onclick_drobox[$filename] = str_replace('FILENAME', $filename, $onclick);
							}
						}
					}
				}
				break;
			case 3:
				// url get the file name use the same method as the auto
				$filename = self::getDownloadFileName($sermon,$sermon->url,'url');
				if (1 == $sermon->link_type)
				{
					$lockedURL = $safe->encryptString($sermon->url);
					$sermon->download_links[$filename] = $downloadURL.'&link='.self::base64_urlencode($lockedURL).'&filename='.$filename;
					$sermon->onclick[$filename] = '';
				}
				elseif (2 == $sermon->link_type)
				{
					$sermon->download_links[$filename] = $sermon->url;
					$sermon->onclick[$filename] = str_replace('FILENAME', $filename, $onclick);
				}
				break;
		}
		// remove the values no longer needed
		unset($sermon->local_files);
		unset($sermon->manual_files);
		unset($sermon->auto_sermons);
		unset($sermon->url);
		// should we set the local .htaccess for the download folder
		if ($setHtaccess)
		{
			// TODO we may need to add this latter to enforce download of files.
		}
		return true;
	}

	public static function getNextUpdateValues($asArray = false)
	{
		// find the next value
		$next = false;
		// get actual update values
		$updates = self::getExternalListingUpdateKeys();
		// get last update
		$updatePath = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath('path', 'updatelast', 'txt', 'vDm', JPATH_COMPONENT_ADMINISTRATOR);
		if (($lastUpdate = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($updatePath, FALSE)) !== FALSE && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($updates))
		{
			// is it time to watch
			if (self::$updateWatch_ > 0)
			{
				// increment the watch, as this is the start of new round
				self::$updateWatch++;
				// new round has started
				self::$updateWatch_ = 0;
			}
			// now check what is next
			$lastKey = array_search($lastUpdate, $updates);
			if (!is_null($lastKey))
			{
				$nextKey = $lastKey + 1;
				if (isset($updates[$nextKey]))
				{
					$next = $updates[$nextKey];
				}
				else
				{
					// last item in array, so next round about to start
					self::$updateWatch_++;
				}
			}
		}
		// rest and start with the first key
		if (!$next && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($updates))
		{
			// save the first set
			$start = reset($updates);
			$next = $start;
		}
		// save to file if next is found
		if ($next)
		{
			Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::write($updatePath,$next);
			// convert to array of needed
			if ($asArray)
			{
				if (strpos($next, ',') !== false)
				{
					$next = array_map('trim', explode(',', $next));
				}
				else
				{
					return false;
				}
			}
		}
		return $next;
	}
[CUSTOMCODE=getFilePath]
[CUSTOMCODE=writeFile]
	protected static function saveFile($data, $path_filename)
	{
		return Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::write($path_filename, $data);
	}

	public static function getExternalListingUpdateKeys($id = null, $updateMethod = 2, $returnType = 1)
	{
		// first check if this file already has statistics
		$db = Factory::getDbo();
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('id','sharedurl','folder','permissiontype','dropboxoptions','build')));
		$query->from($db->quoteName('#__[[[component]]]_external_source'));
		if ($updateMethod && is_numeric($updateMethod))
		{
			$query->where($db->quoteName('update_method') . ' = '. (int) $updateMethod);
		}
		if ($id && is_numeric($id))
		{
			$query->where($db->quoteName('id') . ' = '. (int) $id);
		}
		elseif ($id && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($id))
		{
			$ids = implode(',', array_map( 'intval', $id));
			$query->where($db->quoteName('id') . ' IN  (' . $ids . ')');
		}
		$query->where($db->quoteName('published') . ' = 1');
		$db->setQuery($query);
		$db->execute();
		if ($db->getNumRows())
		{
			$results = $db->loadObjectList();
			$updates = array();
			foreach ($results as $result)
			{
				if ('full' == $result->permissiontype)
				{
					// load folder or urls
					switch ($result->dropboxoptions)
					{
						case 1: // sharedurl
							if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($result->sharedurl))
							{
								$targets = json_decode($result->sharedurl)->tsharedurl;
							}
						break;
						case 2: // folders
							if (Super___4b225c51_d293_48e4_b3f6_5136cf5c3f18___Power::check($result->folder))
							{
								$targets = json_decode($result->folder)->tfolder;
							}
						break;
					}
					if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($targets))
					{
						foreach ($targets as $key => $value)
						{
							$nr = $key + 1;
							// id, target, type
							if (1 == $returnType)
							{
								$updates[] = $result->id . ', '. $nr . ', ' . $result->build;
							}
							else // only return the targets
							{
								$updates[] = $nr;
							}
						}
					}
				}
				else
				{
					// id, target, type
					if (1 == $returnType)
					{
						$updates[] = $result->id . ', 1, '. $result->build;
					}
					else // only return the targets
					{
						$updates[] = 1;
					}
				}
			}
			return $updates;
		}
		return false;
	}

	public static function getExternalSourceLink($type, $return = 7, $get = false, $target = 'links')
	{
		// make sure all defaults are set
		$found = self::checkExternalSourceLocalListing($type, $target);
		if ($found)
		{
			switch($return)
			{
				case 1:
					// return a link
					if (isset(self::${$target.'_externalsource_'.$type}[$get]))
					{
						return self::${$target.'_externalsource_'.$type}[$get];
					}
					break;
				case 2:
					// return all links
					return self::${$target.'_externalsource_'.$type};
					break;
				default :
					// just confirm that it is set
					return true;
					break;
			}
		}
		return false;
	}

	public static function countDownload($counter, $filename)
	{
		// Get local key
		$localkey = self::getLocalKey();
		$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 128);
		$counter = json_decode(rtrim($opener->decryptString($counter), "\0"));
		if (Super___91004529_94a9_4590_b842_e7c6b624ecf5___Power::check($counter))
		{
			$counter->filename = $filename;
			// set the date object
			$date = Factory::getDate();
			// first check if this file already has statistics
			$db = Factory::getDbo();
			$query = $db->getQuery(true);
			$query->select($db->quoteName(array('id','counter')));
			$query->from($db->quoteName('#__[[[component]]]_statistic'));
			$query->where($db->quoteName('sermon') . ' = '. (int) $counter->sermon);
			$query->where($db->quoteName('filename') . ' = '. $db->quote($counter->filename));
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$statistic = $db->loadObject();
				// already has an entry
				$statistic->counter++;
				$statistic->modified = $date->toSql();
				// update the entry
				return $db->updateObject('#__[[[component]]]_statistic', $statistic, 'id');
			}
			else
			{
				// set a new entry
				$counter->counter = 1;
				$counter->published = 1;
				$counter->created = $date->toSql();
				$counter->access = 1;
				$counter->version = 1;
				// set a new entry
				$done = $db->insertObject('#__[[[component]]]_statistic', $counter);
				// if done return last used id
				if ($done)
				{
					$newId =  $db->insertid();
					// make sure the access of asset is set
					return self::setAsset($newId,'statistic');
				}
			}
		}
		return false;
	}

	public static function getFileInfo($key)
	{
		if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($key) && (base64_encode(base64_decode($key, true)) === $key))
		{
			// Get local key
			$localkey = self::getLocalKey();
			$opener = new Super___99175f6d_dba8_4086_8a65_5c4ec175e61d___Power($localkey, 128);
			$key = rtrim($opener->decryptString($key), "\0");
			// load the links from the database
			$db = Factory::getDbo();
			// Create a new query object.
			$query = $db->getQuery(true);
			$query->select('size');
			$query->from($db->quoteName('#__[[[component]]]_local_listing'));
			$query->where($db->quoteName('key') . ' = '. $db->quote($key));
 			// Reset the query using our newly populated query object.
			$db->setQuery($query);
			$db->execute();
			if ($db->getNumRows())
			{
				$info = array();
				// get the size of the file
				$info['filesize'] = $db->loadResult();
				// get the mime type
				$info['type'] = Super___f11dc790_713e_4706_9a85_a318ed3ad56e___Power::mimeType($key);
				// return info
				return $info;
			}
		}
		return false;
	}

	protected static function getDownloadFileName(&$sermon, $file, $type)
	{
		// first get file name and file type
		$file = str_replace('VDM_pLeK_h0uEr/', '', $file);
		$fileType = pathinfo($file, PATHINFO_EXTENSION);
		if ($fileType)
		{
			$file = str_replace('.'.$fileType, '', $file);
		}
		else
		{
			$fileType = 'error';
		}
		// now build download name
		$downloadName = array();
		// build the Download File Name - first add the preacher name if set
		if ($sermon->preacher)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->preacher_name,'U');
		}
		// add the series name if set
		if ($sermon->series)
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->series_name,'F');
		}
		// add the category name if set
		if ($sermon->catid && Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($sermon->category))
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->category, 'F');
		}
		if ('dropbox_manual' == $type || 'local' == $type)
		{
			// add the main file name
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($file,'F');
		}
		else
		{
			$downloadName[] = Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::safe($sermon->name,'F');
			if ('error' == $fileType || strpos('?', $fileType) !== false || strpos('&', $fileType) !== false )
			{
				$fileType = 'mp3'; // TODO we don't know the url filetype (setting to mp3 but this could be wrong)
			}
		}
		// now build the download file name
		return implode('__', $downloadName).'.'.$fileType;
	}

	/**
	* 	check External Source Local Listing (do we have the files)
	**/
	public static function checkExternalSourceLocalListing($type, $get = 'links')
	{
		// get the local links
		if (isset(self::${$get.'_externalsource_'.$type}) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::${$get.'_externalsource_'.$type}))
		{
			// return true we have links loaded
			return true;
		}
		else
		{
			$target = array('links' => 'url', 'select' => 'name');
			$build = array( 'auto' => 2, 'manual' => 1);
			if (isset($build[$type]))
			{
				// load the links from the database
				$db = Factory::getDbo();
				// Create a new query object.
				$query = $db->getQuery(true);
				$query->select($db->quoteName(array('key', $target[$get])));
				$query->from($db->quoteName('#__[[[component]]]_local_listing'));
				$query->where($db->quoteName('build') . ' = '. (int) $build[$type]);
				$query->where($db->quoteName('published') . ' = 1'); // TODO we can now limit the links to access groups
 				// Reset the query using our newly populated query object.
				$db->setQuery($query);
				$db->execute();
				if ($db->getNumRows())
				{
					self::${$get.'_externalsource_'.$type} = $db->loadAssocList('key', $target[$get]);
					// return true we have links loaded
					return true;
				}
			}
		}
		return false;
	}

	/**
	* 	get the localkey
	**/
	protected static $localkey = array();
	
	public static function getLocalKey($type = 'basic_key')
	{
		if (!isset(self::$localkey[$type]))
		{
			// get the main key
			self::$localkey[$type] = ComponentHelper::getParams('com_[[[component]]]')->get($type, 'localKey34fdWEkl');
		}
		return self::$localkey[$type];
	}

	public static function updateExternalSource($id, $target = 0, $type = false, $force = false, $sleutel = null)
	{
		$source = self::getVar('external_source', (int) $id, 'id', 'externalsources');
		if (1 == $source) // Dropbox is the source
		{
			// load the file
			JLoader::import('dropboxupdater', JPATH_COMPONENT_SITE.'/helpers');
			// update types
			$types = array('manual','auto');
			// okay now update this type
			if (Super___1f28cb53_60d9_4db1_b517_3c7dc6b429ef___Power::check($type) && in_array($type,$types))
			{
				$dropbox = new Dropboxupdater();
				if ($dropbox->update($id, $target, $type, $force, $sleutel))
				{
					return true;
				}
				self::setUpdateError($id, $dropbox->getErrors());
				return false;
			}
		}
		self::setUpdateError($id, array(Text::_('The external source could not be found.')));
		return false;
	}

	public static function getSourceStatus($id)
	{
		// fist get errors if any is found
		$errors = array();
		if ($targets = self::getExternalListingUpdateKeys($id, null, 1))
		{
			foreach ($targets as $target)
			{
				$key = preg_replace('/[ ,]+/', '', trim($target));
				if ($error = self::getUpdateError(0, $key))
				{
					$errors[] = $error;
				}
			}
		}
		// check when was the last update
		$updateInfo = self::updateInfo($id);
		if (!$updateInfo)
		{
			$errors[] = Text::_('This source has no local listing set.');
		}
		// build the return string
		if (isset($updateInfo['last']) || Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errors))
		{
			$body = array();
			// great we have source status
			if (isset($updateInfo['last']))
			{
				$body[] = '<h3>'. Text::_('Listing Info') . '</h3>';
				$body[] = '<p><b>'. Text::_('Last Update') . ':</b> <em>'.$updateInfo['last'];
				$body[] = '</em><br /><b>'. Text::_('Number of Files Listed') . ':</b> <em>'.$updateInfo['qty'];
				$body[] = '</em></p>';
			}
			// now set any errors found
			if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errors))
			{
				$body[] = '<h3>'. Text::_('Notice!') . '</h3>';
				$body[] = implode('', $errors);
			}
			return '<a class="btn btn-small btn-success" href="#source-status'.$id.'" data-toggle="modal">'.Text::_('View Update Status').'</a>' 
				. Html::_('bootstrap.renderModal', 'source-status'.$id, array('title' => Text::_('Source Status Report.')), implode('', $body));
		}
 		// no status found
		return false;
	}

	public static function updateInfo($id)
	{
		$db = Factory::getDbo();
		// Create a new query object.
		$query = $db->getQuery(true);
		$query->select($db->quoteName(array('a.created','a.modified')));
		$query->from($db->quoteName('#__[[[component]]]_local_listing', 'a'));
		$query->where($db->quoteName('a.external_source') . ' = ' . (int) $id);
 		// Reset the query using our newly populated query object.
		$db->setQuery($query);
		$db->execute();
		if ($qty = $db->getNumRows())
		{
			$data = $db->loadRowList();
			$last = 0;
			foreach ($data as $dates)
			{
				foreach ($dates as $date)
				{
					$time = strtotime($date);
					if ($time > $last)
					{
						$last = $time;
					}
				}
			}
			$info['qty'] = (int) $qty;
			$info['last'] = self::fancyDate($last);
			return $info;
		}
		return false;
	}

	public static function getUpdateError($id, $fileKey = null)
	{
		// get update error from file
		if ($fileKey)
		{
			$file_path = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getPath('path', 'updateerror', 'txt', $fileKey, JPATH_COMPONENT_ADMINISTRATOR);
			// check if it is set
			if (($text = Super___a223b31e_ea1d_4cdf_92ae_5f9becffaff0___Power::getContent($file_path, FALSE)) !== FALSE)
			{
				// no error on success
				if ('success' != $text)
				{
					return $text;
				}
			}
			return false;
		}
		elseif (isset(self::$updateErrors[$id]) && Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check(self::$updateErrors[$id]))
		{
			return '<ul><li>'.implode('</li><li>', self::$updateErrors[$id]).'</li></ul>';
		}
		return Text::_('Unknown error has occurred.');
	}

	protected static function setUpdateError($id, $errorArray)
	{
		if (Super___0a59c65c_9daf_4bc9_baf4_e063ff9e6a8a___Power::check($errorArray) && $id > 0)
		{
			foreach ($errorArray as $error)
			{
				if (!isset(self::$updateErrors[$id]))
				{
					self::$updateErrors[$id] = array();
				}
				self::$updateErrors[$id][] = $error;
			}
		}
	}
[CUSTOMCODE=niceFancyDate]
[CUSTOMCODE=curlWorkerHelper]
[CUSTOMCODE=locker]', '', '', '', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KICFbIyMjQ29tcG9uZW50X25hbWUjIyMgaW1hZ2VdKGh0dHBzOi8vZ2l0LnZkbS5kZXYvY2hyaXN0aWFuL0pvb21sYS1TZXJtb24tRGlzdHJpYnV0b3IvcmF3L2JyYW5jaC9tYXN0ZXIvYWRtaW4vYXNzZXRzL2ltYWdlcy92ZG0tY29tcG9uZW50LmpwZyAiVGhlICMjI0NvbXBvbmVudF9uYW1lIyMjIikNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KVGhlIGJlc3Qgd2F5IHRvIHNlZSBhbGwgeW91ciBvcHRpb25zIGlzIHRvIGluc3RhbGwgdGhpcyBjb21wb25lbnQgb24geW91IEpvb21sYSB3ZWJzaXRlIGFuZCB0ZXN0IGFsbCBmZWF0dXJlcyB5b3Vyc2VsZi4gSGVyZSBpcyBhIFtkaXJlY3QgZG93bmxvYWQgbGlua10oaHR0cHM6Ly9naXQudmRtLmRldi9jaHJpc3RpYW4vSm9vbWxhLVNlcm1vbi1EaXN0cmlidXRvci9hcmNoaXZlL21hc3Rlci56aXApDQoNCiAqKklmIHlvdSBsaWtlIG91ciBjb21wb25lbnQgcGxlYXNlIHJhdGUgaXQgb24gdGhlIFtKb29tbGEgSW5kZXhdKGh0dHA6Ly9leHRlbnNpb25zLmpvb21sYS5vcmcvZXh0ZW5zaW9ucy9leHRlbnNpb24vbGl2aW5nL3JlbGlnaW9uL3Nlcm1vbi1kaXN0cmlidXRvcikqKg0KDQojIyMgRXhhbXBsZSBXZWJzaXRlLCBUaGF0IEhhcyBPdmVyIDYwMDAgQXVkaW8gRmlsZXMNCg0KW0xvdWRWb2ljZS5vcmddKGh0dHA6Ly93d3cubG91ZHZvaWNlLm9yZykNCltUcnVlQ2hyaXN0aWFuLkNodXJjaF0oaHR0cHM6Ly90cnVlY2hyaXN0aWFuLmNodXJjaC8pDQoNCiMjIyBTb21lIFZpZGVvIERlbW9uc3RyYXRpb25zDQoNCisgW1NldHVwIG92ZXJ2aWV3XShodHRwczovL3lvdXR1LmJlL3lNUHAxQ3AzV18wP3Q9MjBtOHMpDQorIFtTZXR1cCBEcm9wYm94XShodHRwczovL3lvdXR1LmJlL2J0cEtGRGswLWRJKQ0KDQojIEJ1aWxkIERldGFpbHMNCg0KKyAqQ29tcGFueSo6IFsjIyNDT01QQU5ZTkFNRSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkF1dGhvcio6IFsjIyNBVVRIT1IjIyNdKG1haWx0bzojIyNBVVRIT1JFTUFJTCMjIykNCisgKk5hbWUqOiBbIyMjQ29tcG9uZW50X25hbWUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6ICMjI1ZFUlNJT04jIyMNCisgKkNvcHlyaWdodCo6ICMjI0NPUFlSSUdIVCMjIw0KKyAqTGljZW5zZSo6ICMjI0xJQ0VOU0UjIyMNCg0KIyMgQnVpbGQgVGltZSA6aG91cmdsYXNzOg0KDQoqKiMjI3RvdGFsSG91cnMjIyMgSG91cnMqKiBvciAqKiMjI3RvdGFsRGF5cyMjIyBFaWdodCBIb3VyIERheXMqKiAoYWN0dWFsIHRpbWUgdGhlIGF1dGhvciBzYXZlZCAtDQpkdWUgdG8gW0F1dG9tYXRlZCBDb21wb25lbnQgQnVpbGRlcl0oaHR0cHM6Ly93d3cuam9vbWxhY29tcG9uZW50YnVpbGRlci5jb20pKQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiBuZXZlciBtYWtpbmcgb25lIG1pc3Rha2Ugb3IgdGFraW5nIGFueSBjb2ZmZWUgYnJlYWsuKQ0KDQorICpMaW5lIGNvdW50KjogKiojIyNMSU5FX0NPVU5UIyMjKioNCisgKkZpbGUgY291bnQqOiAqKiMjI0ZJTEVfQ09VTlQjIyMqKg0KKyAqRm9sZGVyIGNvdW50KjogKiojIyNGT0xERVJfQ09VTlQjIyMqKg0KDQoqKiMjI2FjdHVhbEhvdXJzU3BlbnQjIyMgSG91cnMqKiBvciAqKiMjI2FjdHVhbERheXNTcGVudCMjIyBFaWdodCBIb3VyIERheXMqKiAodGhlIGFjdHVhbCB0aW1lIHRoZSBhdXRob3Igc3BlbnQpDQoNCj4gKHdpdGggdGhlIGZvbGxvd2luZyBicmVhayBkb3duOg0KPiAqKmRlYnVnZ2luZyBAIyMjZGVidWdnaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDQ7DQo+ICoqcGxhbm5pbmcgQCMjI3BsYW5uaW5nSG91cnMjIyNob3VycyoqID0gY29kaW5ndGltZSAvIDc7DQo+ICoqbWFwcGluZyBAIyMjbWFwcGluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyAxMDsNCj4gKipvZmZpY2UgQCMjI29mZmljZUhvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA2OykNCg0KKiojIyNhY3R1YWxUb3RhbEhvdXJzIyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxUb3RhbERheXMjIyMgRWlnaHQgSG91ciBEYXlzKioNCihhIHRvdGFsIG9mIHRoZSByZWFsaXN0aWMgdGltZSBmcmFtZSBmb3IgdGhpcyBwcm9qZWN0KQ0KDQo+IChpZiBjcmVhdGluZyBhIGZvbGRlciBhbmQgZmlsZSB0b29rICoqNSBzZWNvbmRzKiogYW5kIHdyaXRpbmcgb25lIGxpbmUgb2YgY29kZSB0b29rICoqMTAgc2Vjb25kcyoqLA0KPiB3aXRoIHRoZSBub3JtYWwgZXZlcnlkYXkgcmVhbGl0aWVzIGF0IHRoZSBvZmZpY2UsIHRoYXQgaW5jbHVkZXMgdGhlIGNvbXBvbmVudCBwbGFubmluZywgbWFwcGluZyAmIGRlYnVnZ2luZy4pDQoNClByb2plY3QgZHVyYXRpb246ICoqIyMjcHJvamVjdFdlZWtUaW1lIyMjIHdlZWtzKiogb3IgKiojIyNwcm9qZWN0TW9udGhUaW1lIyMjIG1vbnRocyoqDQoNCj4gVGhpcyAqKmNvbXBvbmVudCoqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8p', 1, '', 'A sermon distributor that links to Dropbox.', '', '', 'SermonDistributor (public) J5', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', '', 2, 'https://git.vdm.dev/christian/Joomla-Sermon-Distributor/raw/branch/5.x/sermondistributor_update_server.xml', 'https://www.vdm.io/', '', 'c5rhaxX7uhTwV9PXKN4f17ZBCnqfgXa+m8DRot2YmIA=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\CMS\\\\Filesystem\\\\File;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\",\"power_site_helper\":[]}}', 1, 5, '', 1, 51), -(89, 1, 1, 1, '', 1, '', '', '', 1, 1, '', 1, '', '', 1, 1, 1, 1, '', 1, '', 1, 1, 1, 1, '', 3, 1, 3, 2, 'Llewellyn van der Merwe', '/var/www/jcb_j4', 'JCB.txt', '', '', 'Vast Development Method', '4.0.0-rc1', 'Copyright (C) 2015 Vast Development Method. All rights reserved.', '2015-04-30 12:04:35', '', 'cpBTiwUUdMl4NaaOtDjZq1+0i8wqscXxjPW2RphsorY=', 'AJHOIg7SdMkXmFuvZ4PJ7SzL+FFFI51zsjU+6JHkhHo=', '', 'uRKIManIX3JIt/6bEDE3kVzH+WiGWQ7lv1VI0kjPCww=', 'LmZpZWxkTWVkaXVtIHsgd2lkdGg6IDEyMHB4OyB9DQouZmllbGRMYXJnZSB7IHdpZHRoOiAzMjBweDsgfQ0KLmZpZWxkTWlkIHsgd2lkdGg6IDgwcHg7IH0NCi5maWVsZEZ1bGwgeyB3aWR0aDogMTAwJTsgfQ0KLmZpZWxkU21hbGwgeyB3aWR0aDogNjBweDsgfQ0KY29kZSB7IGRpc3BsYXk6IGlubGluZS1ibG9jazsgbWFyZ2luOiAzcHg7fQ==', '', '', 1, '', 'The Component Builder for [Joomla](https://extensions.joomla.org/extension/component-builder/) is highly advanced tool that is truly able to build extremely complex components in a fraction of the time.\r\n\r\nWhether you\'re a seasoned [Joomla](https://extensions.joomla.org/extension/component-builder/) developer, or have just started, Component Builder will save you lots of time and money. A real must have!', 'joomla@vdm.io', '', 'https://vdm.bz/component-builder-self', 'pvFpmPCET6+0v1gpe5YIWYo8OEB0FhESnYmWwRahfiY=', '', '1e25ffd3-3535-4f6c-8cb4-d3418862c952', 'images/vdm/jcb500.jpg', '', 'https://git.vdm.dev/joomla/Component-Builder', 'GNU General Public License version 2 or later; see LICENSE.txt', 1, '✓', '2024-04-27 10:51:26', 2, 'Component Builder', 'Componentbuilder', 'VDM', 4, 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', '', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlckhlbHBlckJvdGhd', '', '', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9ZGF0YWJhc2VTY2hlbWFDaGVja0NhbGwrJHRoaXMtPmFwcF0=', 'W0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskdGhpcy0+YXBwXQ==', 'W0NVU1RPTUNPREU9Y29tcG9uZW50QnVpbGRlclByZWZsaWdodFVwZGF0ZUpmaXZlXQ0KW0NVU1RPTUNPREU9cGhwQ29uZmlndXJhdGlvbkNoZWNrQ2FsbCskdGhpcy0+YXBwXQ==', 'CQkvLyB0aGUgU2Vzc2lvbiBrZWVwcyB0cmFjayBvZiBhbGwgZGF0YSByZWxhdGVkIHRvIHRoZSBjdXJyZW50IHNlc3Npb24gb2YgdGhpcyB1c2VyDQoJCXNlbGY6OmxvYWRTZXNzaW9uKCk7', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlclJlYWRNZV0=', 1, '', 'Builds Complex Joomla Components', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMSW5zdGFsbF0=', 'W0NVU1RPTUNPREU9Y29tcG9uZW50YnVpbGRlck15U1FMVW5pbnN0YWxsXQ==', 'Component Builder (Public) J4', '.git, .github, .gitignore, .idea, .gitea, SECURITY.md, .editorconfig, .octojpack', '', 3, 2, 'https://git.vdm.dev/joomla/Component-Builder/raw/branch/4.x/componentbuilder_update_server.xml', 'https://dev.vdm.io', '', 'GfWpBeuAOZ83sPk5r1IW+rLmnkPElMrAlKHTjwyy4GY=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"0\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"1\",\"admin_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\\r\\nuse Joomla\\\\CMS\\\\Session\\\\Session;\",\"power_admin_helper\":[],\"add_site_helper\":\"1\",\"site_helper\":\"use Joomla\\\\Archive\\\\Archive;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Folder;\\r\\nuse Joomla\\\\CMS\\\\Filesystem\\\\Path;\\r\\nuse Joomla\\\\CMS\\\\Session\\\\Session;\",\"power_site_helper\":[]}}', 1, 27, '', 1, 1); +INSERT INTO `#__componentbuilder_joomla_component` (`id`, `add_admin_event`, `add_backup_folder_path`, `add_css_admin`, `add_css_site`, `add_email_helper`, `add_git_folder_path`, `add_javascript`, `add_license`, `add_menu_prefix`, `add_namespace_prefix`, `add_php_helper_admin`, `add_php_helper_both`, `add_php_helper_site`, `add_php_method_uninstall`, `add_php_postflight_install`, `add_php_postflight_update`, `add_php_preflight_install`, `add_php_preflight_update`, `add_placeholders`, `add_powers`, `add_sales_server`, `add_site_event`, `add_sql`, `add_sql_uninstall`, `add_update_server`, `addcontributors`, `addfootable`, `addreadme`, `adduikit`, `assets_table_fix`, `author`, `backup_folder_path`, `bom`, `buildcomp`, `buildcompsql`, `companyname`, `component_version`, `copyright`, `created`, `creatuserhelper`, `crowdin_account_api_key`, `crowdin_project_api_key`, `crowdin_project_identifier`, `crowdin_username`, `css_admin`, `css_site`, `dashboard`, `dashboard_type`, `debug_linenr`, `description`, `email`, `emptycontributors`, `export_buy_link`, `export_key`, `git_folder_path`, `guid`, `image`, `javascript`, `joomla_source_link`, `license`, `license_type`, `menu_prefix`, `modified`, `mvc_versiondate`, `name`, `name_code`, `namespace_prefix`, `number`, `php_admin_event`, `php_helper_admin`, `php_helper_both`, `php_helper_site`, `php_method_uninstall`, `php_method_install`, `php_postflight_install`, `php_postflight_update`, `php_preflight_install`, `php_preflight_update`, `php_site_event`, `readme`, `remove_line_breaks`, `sales_server`, `short_description`, `sql`, `sql_uninstall`, `system_name`, `toignore`, `translation_tool`, `update_server`, `update_server_target`, `update_server_url`, `website`, `whmcs_buy_link`, `whmcs_key`, `whmcs_url`, `params`, `published`, `version`, `hits`, `access`, `ordering`) VALUES +(25, '', '', '', '', '', '', '', '', 1, '', '', '', 1, '', 1, '', '', '', '', 1, '', '', '', '', 1, '{}', '', 1, 1, 3, 'Llewellyn van der Merwe', '', 'default.txt', '', '', 'Vast Development Method', '2.1.0', 'Copyright (C) 2015. All Rights Reserved', '2016-10-18 11:44:09', '', 'mvVkzmHCEIoBhzD3gR3uTzXRGwNVNRWw8Hr1vrXxb+I=', 'BbloLSYT6Yup6v3I/YNmrdOwzjbI4BGfDvJSB82N9DU=', '', 'VtSt2RMz+AHCrwc7jk1G70t83ZwZsNp2upqfzMyaVHE=', '', '', '', 1, '', 'Just a basic demo of the most basic implementations of the [Joomla](http://www.joomla.org) Component Builder\'s ability.', 'joomla@vdm.io', '', '', 'nZDegSPK87rXA4KMC6P8I6zEldjVIJpPYGRPZlKBI+U=', '', 'efde995e-60aa-4b39-b644-44349dfb660d', 'images/vdm/demo500.jpg', '', 'https://github.com/Llewellynvdm/Joomla-Demo-Component', 'GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html', 1, '»', '2024-01-19 11:57:08', '', 'Demo', 'demo', 'JCB', 4, '', '', '', 'CS8qKg0KCSAqCUNoYW5nZSB0byBuaWNlIGZhbmN5IGRhdGUNCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGZhbmN5RGF0ZSgkZGF0ZSkNCgl7DQoJCWlmICghc2VsZjo6aXNWYWxpZFRpbWVTdGFtcCgkZGF0ZSkpDQoJCXsNCgkJCSRkYXRlID0gc3RydG90aW1lKCRkYXRlKTsNCgkJfQ0KCQlyZXR1cm4gZGF0ZSgnalMgXG9cZiBGIFknLCRkYXRlKTsNCgl9DQoNCgkvKioNCgkgKglDaGFuZ2UgdG8gbmljZSBmYW5jeSB0aW1lIGFuZCBkYXRlDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBmYW5jeURhdGVUaW1lKCR0aW1lKQ0KCXsNCgkJaWYgKCFzZWxmOjppc1ZhbGlkVGltZVN0YW1wKCR0aW1lKSkNCgkJew0KCQkJJHRpbWUgPSBzdHJ0b3RpbWUoJHRpbWUpOw0KCQl9DQoJCXJldHVybiBkYXRlKCcoRzppKSBqUyBcb1xmIEYgWScsJHRpbWUpOw0KCX0NCg0KCS8qKg0KCSAqCUNoYW5nZSB0byBuaWNlIGhvdXI6bWludXRlcyB0aW1lDQoJICovDQoJcHVibGljIHN0YXRpYyBmdW5jdGlvbiBmYW5jeVRpbWUoJHRpbWUpDQoJew0KCQlpZiAoIXNlbGY6OmlzVmFsaWRUaW1lU3RhbXAoJHRpbWUpKQ0KCQl7DQoJCQkkdGltZSA9IHN0cnRvdGltZSgkdGltZSk7DQoJCX0NCgkJcmV0dXJuIGRhdGUoJ0c6aScsJHRpbWUpOw0KCX0NCg0KCS8qKg0KCSAqCUNoZWNrIGlmIHN0cmluZyBpcyBhIHZhbGlkIHRpbWUgc3RhbXANCgkgKi8NCglwdWJsaWMgc3RhdGljIGZ1bmN0aW9uIGlzVmFsaWRUaW1lU3RhbXAoJHRpbWVzdGFtcCkNCgl7DQoJCXJldHVybiAoKGludCkgJHRpbWVzdGFtcCA9PT0gJHRpbWVzdGFtcCkNCgkJJiYgKCR0aW1lc3RhbXAgPD0gUEhQX0lOVF9NQVgpDQoJCSYmICgkdGltZXN0YW1wID49IH5QSFBfSU5UX01BWCk7DQoJfQ0K', '', '', 'CQkvLyBHZXQgQXBwbGljYXRpb24gb2JqZWN0DQoJCSRhcHAgPSBGYWN0b3J5OjpnZXRBcHBsaWNhdGlvbigpOw0KCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnVGhpcyBpcyBhIGRlbW8gY29tcG9uZW50IGRldmVsb3BlZCBpbiA8YSBocmVmPSJodHRwOi8vdmRtLmJ6L2NvbXBvbmVudC1idWlsZGVyIiB0YWdldD0iX2JhbG5rIiB0aXRsZT0iSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyIj5KQ0I8L2E+ISBZb3UgY2FuIGJ1aWxkIG1vcmUgY29tcG9uZW50cyBsaWtlIHRoaXMgd2l0aCBKQ0IsIGNoZWNrb3V0IG91ciBwYWdlIG9uIDxhIGhyZWY9Imh0dHBzOi8vZ2l0aHViLmNvbS92ZG0taW8vSm9vbWxhLUNvbXBvbmVudC1CdWlsZGVyIiB0YWdldD0iX2JhbG5rIiB0aXRsZT0iSm9vbWxhIENvbXBvbmVudCBCdWlsZGVyIj5naXRodWI8L2E+IGZvciBtb3JlIGluZm8uIFRoZSBmdXR1cmUgb2YgPGEgaHJlZj0iaHR0cDovL3ZkbS5iei9jb21wb25lbnQtYnVpbGRlciIgdGFnZXQ9Il9iYWxuayIgdGl0bGU9Ikpvb21sYSBDb21wb25lbnQgQnVpbGRlciI+Sm9vbWxhIENvbXBvbmVudCBEZXZlbG9wbWVudDwvYT4gaXMgSGVyZSEnLCAnSW5mbycpOw==', '', '', '', '', 'IyAjIyNDb21wb25lbnRfbmFtZSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIVsjIyNDb21wb25lbnRfbmFtZSMjIyBpbWFnZV0oaHR0cHM6Ly9yYXcuZ2l0aHVidXNlcmNvbnRlbnQuY29tL25hbWliaWEvZGVtby1qb29tbGEtMy1jb21wb25lbnQvbWFzdGVyL2FkbWluL2Fzc2V0cy9pbWFnZXMvdmRtLWNvbXBvbmVudC5qcGcgIlRoZSAjIyNDb21wb25lbnRfbmFtZSMjIyIpDQoNCiMjI0RFU0NSSVBUSU9OIyMjDQoNCiMgQnVpbGQgRGV0YWlscw0KDQorICpDb21wYW55KjogWyMjI0NPTVBBTllOQU1FIyMjXSgjIyNBVVRIT1JXRUJTSVRFIyMjKQ0KKyAqQXV0aG9yKjogWyMjI0FVVEhPUiMjI10obWFpbHRvOiMjI0FVVEhPUkVNQUlMIyMjKQ0KKyAqTmFtZSo6IFsjIyNDb21wb25lbnRfbmFtZSMjI10oIyMjQVVUSE9SV0VCU0lURSMjIykNCisgKkZpcnN0IEJ1aWxkKjogIyMjQ1JFQVRJT05EQVRFIyMjDQorICpMYXN0IEJ1aWxkKjogIyMjQlVJTEREQVRFIyMjDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw0KDQojIyBCdWlsZCBUaW1lDQoNCioqIyMjdG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjdG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqIChhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNhdmVkIC0NCmR1ZSB0byBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKSkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gbmV2ZXIgbWFraW5nIG9uZSBtaXN0YWtlIG9yIHRha2luZyBhbnkgY29mZmVlIGJyZWFrLikNCg0KKyAqTGluZSBjb3VudCo6ICoqIyMjTElORV9DT1VOVCMjIyoqDQorICpGaWxlIGNvdW50KjogKiojIyNGSUxFX0NPVU5UIyMjKioNCisgKkZvbGRlciBjb3VudCo6ICoqIyMjRk9MREVSX0NPVU5UIyMjKioNCg0KKiojIyNhY3R1YWxIb3Vyc1NwZW50IyMjIEhvdXJzKiogb3IgKiojIyNhY3R1YWxEYXlzU3BlbnQjIyMgRWlnaHQgSG91ciBEYXlzKiogKHRoZSBhY3R1YWwgdGltZSB0aGUgYXV0aG9yIHNwZW50KQ0KDQo+ICh3aXRoIHRoZSBmb2xsb3dpbmcgYnJlYWsgZG93bjoNCj4gKipkZWJ1Z2dpbmcgQCMjI2RlYnVnZ2luZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA0Ow0KPiAqKnBsYW5uaW5nIEAjIyNwbGFubmluZ0hvdXJzIyMjaG91cnMqKiA9IGNvZGluZ3RpbWUgLyA3Ow0KPiAqKm1hcHBpbmcgQCMjI21hcHBpbmdIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gMTA7DQo+ICoqb2ZmaWNlIEAjIyNvZmZpY2VIb3VycyMjI2hvdXJzKiogPSBjb2Rpbmd0aW1lIC8gNjspDQoNCioqIyMjYWN0dWFsVG90YWxIb3VycyMjIyBIb3VycyoqIG9yICoqIyMjYWN0dWFsVG90YWxEYXlzIyMjIEVpZ2h0IEhvdXIgRGF5cyoqDQooYSB0b3RhbCBvZiB0aGUgcmVhbGlzdGljIHRpbWUgZnJhbWUgZm9yIHRoaXMgcHJvamVjdCkNCg0KPiAoaWYgY3JlYXRpbmcgYSBmb2xkZXIgYW5kIGZpbGUgdG9vayAqKjUgc2Vjb25kcyoqIGFuZCB3cml0aW5nIG9uZSBsaW5lIG9mIGNvZGUgdG9vayAqKjEwIHNlY29uZHMqKiwNCj4gd2l0aCB0aGUgbm9ybWFsIGV2ZXJ5ZGF5IHJlYWxpdGllcyBhdCB0aGUgb2ZmaWNlLCB0aGF0IGluY2x1ZGVzIHRoZSBjb21wb25lbnQgcGxhbm5pbmcsIG1hcHBpbmcgJiBkZWJ1Z2dpbmcuKQ0KDQpQcm9qZWN0IGR1cmF0aW9uOiAqKiMjI3Byb2plY3RXZWVrVGltZSMjIyB3ZWVrcyoqIG9yICoqIyMjcHJvamVjdE1vbnRoVGltZSMjIyBtb250aHMqKg0KDQo+IFRoaXMgKipjb21wb25lbnQqKiB3YXMgYnVpbGQgd2l0aCBhIEpvb21sYSBbQXV0b21hdGVkIENvbXBvbmVudCBCdWlsZGVyXShodHRwczovL3d3dy52ZG0uaW8vam9vbWxhLWNvbXBvbmVudC1idWlsZGVyKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQoNCltDVVNUT01DT0RFPXJlYWRNRWNvbnRyaWJ1dG9yc10=', '', '', 'Demo Component', '', '', 'Demo (public)', '.git', '', '', 2, 'https://raw.githubusercontent.com/namibia/demo-joomla-3-component/master/demo_updateserver.xml', 'https://www.vdm.io/', '', '6GeGhXcYZEQosGCi0ZXeuAj3oXBwARl7OnRm9h3rxPQ=', '', '{\"language_options\":{\"activate\":\"0\",\"use_percentagelanguageadd\":\"1\",\"percentagelanguageadd\":\"50\"},\"joomla_component_headers\":{\"add_admin_component\":\"0\",\"admin_component\":\"\",\"power_admin_component\":[],\"add_site_component\":\"0\",\"site_component\":\"\",\"power_site_component\":[],\"add_admin_helper\":\"0\",\"admin_helper\":\"\",\"power_admin_helper\":[],\"add_site_helper\":\"0\",\"site_helper\":\"\",\"power_site_helper\":[]}}', 1, 54, '', 1, 10); -- -- Dumping data for table `#__componentbuilder_joomla_plugin` diff --git a/admin/sql/updates/mysql/4.0.0-alpha.sql b/admin/sql/updates/mysql/4.0.0-alpha.sql index 7abab7322..8b1378917 100644 --- a/admin/sql/updates/mysql/4.0.0-alpha.sql +++ b/admin/sql/updates/mysql/4.0.0-alpha.sql @@ -1,2 +1 @@ -ALTER TABLE `#__componentbuilder_joomla_component` ADD `add_jcb_powers_path` TINYINT(1) NOT NULL DEFAULT 0 AFTER `add_javascript`; -ALTER TABLE `#__componentbuilder_joomla_component` ADD `jcb_powers_path` VARCHAR(255) NOT NULL DEFAULT '' AFTER `javascript`; + diff --git a/admin/sql/updates/mysql/4.0.0-beta1.sql b/admin/sql/updates/mysql/4.0.0-beta.sql similarity index 100% rename from admin/sql/updates/mysql/4.0.0-beta1.sql rename to admin/sql/updates/mysql/4.0.0-beta.sql diff --git a/admin/sql/updates/mysql/4.0.0-beta2.sql b/admin/sql/updates/mysql/4.0.0-beta2.sql deleted file mode 100644 index d525a44ab..000000000 --- a/admin/sql/updates/mysql/4.0.0-beta2.sql +++ /dev/null @@ -1,28 +0,0 @@ -CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_power` ( - `id` INT(11) NOT NULL AUTO_INCREMENT, - `asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.', - `description` TEXT NULL, - `guid` VARCHAR(36) NOT NULL DEFAULT '', - `settings` TEXT NOT NULL, - `system_name` VARCHAR(255) NOT NULL DEFAULT '', - `params` text NULL, - `published` TINYINT(3) NOT NULL DEFAULT 1, - `created_by` INT(10) unsigned NOT NULL DEFAULT 0, - `modified_by` INT(10) unsigned NOT NULL DEFAULT 0, - `created` DATETIME DEFAULT CURRENT_TIMESTAMP, - `modified` DATETIME DEFAULT NULL, - `checked_out` int(11) unsigned NOT NULL DEFAULT 0, - `checked_out_time` DATETIME DEFAULT NULL, - `version` INT(10) unsigned NOT NULL DEFAULT 1, - `hits` INT(10) unsigned NOT NULL DEFAULT 0, - `access` INT(10) unsigned NOT NULL DEFAULT 0, - `ordering` INT(11) NOT NULL DEFAULT 0, - PRIMARY KEY (`id`), - KEY `idx_system_name` (`system_name`), - KEY `idx_guid` (`guid`), - KEY `idx_access` (`access`), - KEY `idx_checkout` (`checked_out`), - KEY `idx_createdby` (`created_by`), - KEY `idx_modifiedby` (`modified_by`), - KEY `idx_state` (`published`) -) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8mb4 DEFAULT COLLATE=utf8mb4_unicode_ci ROW_FORMAT=DYNAMIC; diff --git a/admin/sql/updates/mysql/4.0.0-beta3.sql b/admin/sql/updates/mysql/4.0.0-beta3.sql deleted file mode 100644 index 902532589..000000000 --- a/admin/sql/updates/mysql/4.0.0-beta3.sql +++ /dev/null @@ -1,2 +0,0 @@ -ALTER TABLE `#__componentbuilder_joomla_component` ADD `add_php_method_install` TINYINT(1) NOT NULL DEFAULT 0 AFTER `add_php_helper_site`; -ALTER TABLE `#__componentbuilder_joomla_component` ADD `php_method_install` MEDIUMTEXT NOT NULL AFTER `php_helper_site`; diff --git a/admin/sql/updates/mysql/4.0.0-beta4.sql b/admin/sql/updates/mysql/4.0.0-beta4.sql deleted file mode 100644 index 59a009cf8..000000000 --- a/admin/sql/updates/mysql/4.0.0-beta4.sql +++ /dev/null @@ -1,18 +0,0 @@ -UPDATE `#__componentbuilder_admin_view` -SET `alias_builder_type` = 0 -WHERE `alias_builder_type` = ''; - -UPDATE `#__componentbuilder_dynamic_get` -SET `addcalculation` = 0 -WHERE `addcalculation` = ''; - -ALTER TABLE `#__componentbuilder_joomla_component` CHANGE `image` `image` VARCHAR(255) NOT NULL DEFAULT ''; -ALTER TABLE `#__componentbuilder_admin_view` CHANGE `alias_builder_type` `alias_builder_type` TINYINT(1) NOT NULL DEFAULT 0; -ALTER TABLE `#__componentbuilder_admin_view` CHANGE `icon` `icon` VARCHAR(255) NOT NULL DEFAULT ''; -ALTER TABLE `#__componentbuilder_admin_view` CHANGE `icon_add` `icon_add` VARCHAR(255) NOT NULL DEFAULT ''; -ALTER TABLE `#__componentbuilder_admin_view` CHANGE `icon_category` `icon_category` VARCHAR(255) NOT NULL DEFAULT ''; -ALTER TABLE `#__componentbuilder_custom_admin_view` CHANGE `icon` `icon` VARCHAR(255) NOT NULL DEFAULT ''; -ALTER TABLE `#__componentbuilder_dynamic_get` CHANGE `addcalculation` `addcalculation` TINYINT(1) NOT NULL DEFAULT 0; -ALTER TABLE `#__componentbuilder_component_updates` CHANGE `version_update` `version_update` MEDIUMTEXT NOT NULL; -ALTER TABLE `#__componentbuilder_joomla_module_updates` CHANGE `version_update` `version_update` MEDIUMTEXT NOT NULL; -ALTER TABLE `#__componentbuilder_joomla_plugin_updates` CHANGE `version_update` `version_update` MEDIUMTEXT NOT NULL; diff --git a/admin/sql/updates/mysql/4.0.0-beta5.sql b/admin/sql/updates/mysql/4.0.0-beta5.sql deleted file mode 100644 index 8b1378917..000000000 --- a/admin/sql/updates/mysql/4.0.0-beta5.sql +++ /dev/null @@ -1 +0,0 @@ - diff --git a/admin/tmpl/server/default.php b/admin/tmpl/server/default.php index 755dbb7df..4c3cbce77 100644 --- a/admin/tmpl/server/default.php +++ b/admin/tmpl/server/default.php @@ -64,18 +64,6 @@ defined('_JEXEC') or die; - canDo->get('joomla_component.access')) : ?> - -
-
-
-
- -
-
- - - ignore_fieldsets = array('details','metadata','vdmmetadata','accesscontrol'); ?> tab_name = 'serverTab'; ?> diff --git a/componentbuilder.xml b/componentbuilder.xml index 31d9f662b..d614cf5ba 100644 --- a/componentbuilder.xml +++ b/componentbuilder.xml @@ -1,15 +1,15 @@ COM_COMPONENTBUILDER - 27th April, 2024 + 30th April, 2024 Llewellyn van der Merwe joomla@vdm.io https://dev.vdm.io Copyright (C) 2015 Vast Development Method. All rights reserved. GNU General Public License version 2 or later; see LICENSE.txt - 4.0.0-rc1 + 4.0.0-rc2 Component Builder (v.4.0.0-rc1) +

Component Builder (v.4.0.0-rc2)

The Component Builder for [Joomla](https://extensions.joomla.org/extension/component-builder/) is highly advanced tool that is truly able to build extremely complex components in a fraction of the time. diff --git a/componentbuilder_update_server.xml b/componentbuilder_update_server.xml index 9b279eb50..b57283f58 100644 --- a/componentbuilder_update_server.xml +++ b/componentbuilder_update_server.xml @@ -26,7 +26,7 @@ 4.0.0-alpha https://dev.vdm.io - https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-beta1.zip + https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-alpha8.zip alpha @@ -41,79 +41,7 @@ pkg_component_builder package site - 4.0.0-beta1 - https://dev.vdm.io - - https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-beta1.zip - - - beta - - Llewellyn van der Merwe - https://dev.vdm.io - - - - Component Builder - Builds Complex Joomla Components - pkg_component_builder - package - site - 4.0.0-beta2 - https://dev.vdm.io - - https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-beta2.zip - - - beta - - Llewellyn van der Merwe - https://dev.vdm.io - - - - Component Builder - Builds Complex Joomla Components - pkg_component_builder - package - site - 4.0.0-beta3 - https://dev.vdm.io - - https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-beta3.zip - - - beta - - Llewellyn van der Merwe - https://dev.vdm.io - - - - Component Builder - Builds Complex Joomla Components - pkg_component_builder - package - site - 4.0.0-beta4 - https://dev.vdm.io - - https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-beta4.zip - - - beta - - Llewellyn van der Merwe - https://dev.vdm.io - - - - Component Builder - Builds Complex Joomla Components - pkg_component_builder - package - site - 4.0.0-beta5 + 4.0.0-beta https://dev.vdm.io https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-beta5.zip @@ -131,10 +59,10 @@ pkg_component_builder package site - 4.0.0-rc1 + 4.0.0-rc2 https://dev.vdm.io - https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-rc1.zip + https://git.vdm.dev/api/v1/repos/joomla/pkg-component-builder/archive/v4.0.0-rc2.zip releasecandidate diff --git a/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/JoomlaPower/Extractor.php b/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/JoomlaPower/Extractor.php index 043954dcc..71835a2fb 100644 --- a/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/JoomlaPower/Extractor.php +++ b/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/JoomlaPower/Extractor.php @@ -12,6 +12,7 @@ namespace VDM\Joomla\Componentbuilder\Compiler\JoomlaPower; +use VDM\Joomla\Utilities\JsonHelper; use VDM\Joomla\Componentbuilder\Compiler\Interfaces\Power\ExtractorInterface; use VDM\Joomla\Componentbuilder\Compiler\Power\Extractor as ExtendingExtractor; diff --git a/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Service/Utilities.php b/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Service/Utilities.php index 2f4b56a6d..bf14861fc 100644 --- a/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Service/Utilities.php +++ b/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Service/Utilities.php @@ -121,7 +121,8 @@ class Utilities implements ServiceProviderInterface public function getFileInjector(Container $container): FileInjector { return new FileInjector( - $container->get('Power.Injector') + $container->get('Power.Injector'), + $container->get('Joomla.Power.Injector') ); } diff --git a/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Utilities/FileInjector.php b/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Utilities/FileInjector.php index 47c9af0bf..eaf28e2c6 100644 --- a/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Utilities/FileInjector.php +++ b/libraries/vendor_jcb/VDM.Joomla/src/Componentbuilder/Compiler/Utilities/FileInjector.php @@ -13,6 +13,7 @@ namespace VDM\Joomla\Componentbuilder\Compiler\Utilities; use VDM\Joomla\Componentbuilder\Compiler\Power\Injector as Power; +use VDM\Joomla\Componentbuilder\Compiler\JoomlaPower\Injector as JoomlaPower; use VDM\Joomla\Utilities\MathHelper; @@ -33,23 +34,41 @@ final class FileInjector protected Power $power; /** - * The pattern to get the powers + * The Joomla Injector Class. + * + * @var JoomlaPower + * @since 3.2.1 + */ + protected JoomlaPower $joomla; + + /** + * The power pattern to get the powers * * @var string * @since 3.2.0 **/ - protected string $pattern = '/Super_'.'_'.'_[a-zA-Z0-9_]+_'.'_'.'_Power/'; + protected string $powerPattern = '/Super_'.'_'.'_[a-zA-Z0-9_]+_'.'_'.'_Power/'; + + /** + * The Joomla power pattern to get the powers + * + * @var string + * @since 3.2.1 + **/ + protected string $joomlaPattern = '/Joomla_'.'_'.'_[a-zA-Z0-9_]+_'.'_'.'_Power/'; /** * Constructor. * - * @param Power $power The Injector Class. + * @param Power $power The Injector Class. + * @param JoomlaPower $joomla The Joomla Injector Class. * - * @since 3.2.0 + * @since 3.2.1 */ - public function __construct(Power $power) + public function __construct(Power $power, JoomlaPower $joomla) { $this->power = $power; + $this->joomla = $joomla; } /** @@ -72,7 +91,9 @@ final class FileInjector throw new \InvalidArgumentException('Position cannot be negative.'); } - $found_super_powers = preg_match($this->pattern, $data); + $found_joomla_powers = preg_match($this->joomlaPattern, $data); + $found_super_powers = preg_match($this->powerPattern, $data); + $actual_file = $this->openFileWithLock($file); try @@ -85,6 +106,11 @@ final class FileInjector $this->processFile($actual_file, $temp_file, $data, $position, $replace); + if ($found_joomla_powers) + { + $this->injectJoomlaPowers($actual_file); + } + if ($found_super_powers) { $this->injectSuperPowers($actual_file); @@ -207,6 +233,28 @@ final class FileInjector ftruncate($actual_file, 0); rewind($actual_file); + fwrite($actual_file, $power_data); + } + + /** + * Injects Joomla powers into the file content, if found, and updates the file. + * + * @param resource $actual_file The file handle of the actual file. + * + * @return void + * @since 3.2.1 + */ + private function injectJoomlaPowers($actual_file): void + { + rewind($actual_file); + + $power_data = $this->joomla->power( + stream_get_contents($actual_file) + ); + + ftruncate($actual_file, 0); + rewind($actual_file); + fwrite($actual_file, $power_data); } } diff --git a/media/js/help_document.js b/media/js/help_document.js index 15d7f0fbf..1d4ee7777 100644 --- a/media/js/help_document.js +++ b/media/js/help_document.js @@ -9,11 +9,11 @@ */ // Some Global Values -jform_vvvvwcovyd_required = false; -jform_vvvvwcpvye_required = false; -jform_vvvvwcqvyf_required = false; -jform_vvvvwcrvyg_required = false; -jform_vvvvwctvyh_required = false; +jform_vvvvwcovyc_required = false; +jform_vvvvwcpvyd_required = false; +jform_vvvvwcqvye_required = false; +jform_vvvvwcrvyf_required = false; +jform_vvvvwctvyg_required = false; // Initial Script document.addEventListener('DOMContentLoaded', function() @@ -45,26 +45,26 @@ function vvvvwco(location_vvvvwco) { jQuery('#jform_admin_view').closest('.control-group').show(); // add required attribute to admin_view field - if (jform_vvvvwcovyd_required) + if (jform_vvvvwcovyc_required) { updateFieldRequired('admin_view',0); jQuery('#jform_admin_view').prop('required','required'); jQuery('#jform_admin_view').attr('aria-required',true); jQuery('#jform_admin_view').addClass('required'); - jform_vvvvwcovyd_required = false; + jform_vvvvwcovyc_required = false; } } else { jQuery('#jform_admin_view').closest('.control-group').hide(); // remove required attribute from admin_view field - if (!jform_vvvvwcovyd_required) + if (!jform_vvvvwcovyc_required) { updateFieldRequired('admin_view',1); jQuery('#jform_admin_view').removeAttr('required'); jQuery('#jform_admin_view').removeAttr('aria-required'); jQuery('#jform_admin_view').removeClass('required'); - jform_vvvvwcovyd_required = true; + jform_vvvvwcovyc_required = true; } } } @@ -77,26 +77,26 @@ function vvvvwcp(location_vvvvwcp) { jQuery('#jform_site_view').closest('.control-group').show(); // add required attribute to site_view field - if (jform_vvvvwcpvye_required) + if (jform_vvvvwcpvyd_required) { updateFieldRequired('site_view',0); jQuery('#jform_site_view').prop('required','required'); jQuery('#jform_site_view').attr('aria-required',true); jQuery('#jform_site_view').addClass('required'); - jform_vvvvwcpvye_required = false; + jform_vvvvwcpvyd_required = false; } } else { jQuery('#jform_site_view').closest('.control-group').hide(); // remove required attribute from site_view field - if (!jform_vvvvwcpvye_required) + if (!jform_vvvvwcpvyd_required) { updateFieldRequired('site_view',1); jQuery('#jform_site_view').removeAttr('required'); jQuery('#jform_site_view').removeAttr('aria-required'); jQuery('#jform_site_view').removeClass('required'); - jform_vvvvwcpvye_required = true; + jform_vvvvwcpvyd_required = true; } } } @@ -122,26 +122,26 @@ function vvvvwcq(type_vvvvwcq) { jQuery('#jform_url').closest('.control-group').show(); // add required attribute to url field - if (jform_vvvvwcqvyf_required) + if (jform_vvvvwcqvye_required) { updateFieldRequired('url',0); jQuery('#jform_url').prop('required','required'); jQuery('#jform_url').attr('aria-required',true); jQuery('#jform_url').addClass('required'); - jform_vvvvwcqvyf_required = false; + jform_vvvvwcqvye_required = false; } } else { jQuery('#jform_url').closest('.control-group').hide(); // remove required attribute from url field - if (!jform_vvvvwcqvyf_required) + if (!jform_vvvvwcqvye_required) { updateFieldRequired('url',1); jQuery('#jform_url').removeAttr('required'); jQuery('#jform_url').removeAttr('aria-required'); jQuery('#jform_url').removeClass('required'); - jform_vvvvwcqvyf_required = true; + jform_vvvvwcqvye_required = true; } } } @@ -178,26 +178,26 @@ function vvvvwcr(type_vvvvwcr) { jQuery('#jform_article').closest('.control-group').show(); // add required attribute to article field - if (jform_vvvvwcrvyg_required) + if (jform_vvvvwcrvyf_required) { updateFieldRequired('article',0); jQuery('#jform_article').prop('required','required'); jQuery('#jform_article').attr('aria-required',true); jQuery('#jform_article').addClass('required'); - jform_vvvvwcrvyg_required = false; + jform_vvvvwcrvyf_required = false; } } else { jQuery('#jform_article').closest('.control-group').hide(); // remove required attribute from article field - if (!jform_vvvvwcrvyg_required) + if (!jform_vvvvwcrvyf_required) { updateFieldRequired('article',1); jQuery('#jform_article').removeAttr('required'); jQuery('#jform_article').removeAttr('aria-required'); jQuery('#jform_article').removeClass('required'); - jform_vvvvwcrvyg_required = true; + jform_vvvvwcrvyf_required = true; } } } @@ -259,26 +259,26 @@ function vvvvwct(target_vvvvwct) { jQuery('#jform_groups').closest('.control-group').show(); // add required attribute to groups field - if (jform_vvvvwctvyh_required) + if (jform_vvvvwctvyg_required) { updateFieldRequired('groups',0); jQuery('#jform_groups').prop('required','required'); jQuery('#jform_groups').attr('aria-required',true); jQuery('#jform_groups').addClass('required'); - jform_vvvvwctvyh_required = false; + jform_vvvvwctvyg_required = false; } } else { jQuery('#jform_groups').closest('.control-group').hide(); // remove required attribute from groups field - if (!jform_vvvvwctvyh_required) + if (!jform_vvvvwctvyg_required) { updateFieldRequired('groups',1); jQuery('#jform_groups').removeAttr('required'); jQuery('#jform_groups').removeAttr('aria-required'); jQuery('#jform_groups').removeClass('required'); - jform_vvvvwctvyh_required = true; + jform_vvvvwctvyg_required = true; } } }