Component-Builder/admin/sql/install.mysql.utf8.sql
Robot 0ec95282ee
Release of v4.0.0-rc1
Improved the Schema Table update engine (more). Fix autoloader timing, and loading. Implement the Joomla Powers in JCB code, to move away from JClasses.
2024-04-27 15:51:57 +02:00

2689 lines
2.4 MiB
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_component` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_admin_event` TINYINT(1) NOT NULL DEFAULT 0,
`add_backup_folder_path` TINYINT(1) NOT NULL DEFAULT 0,
`add_css_admin` TINYINT(1) NOT NULL DEFAULT 0,
`add_css_site` TINYINT(1) NOT NULL DEFAULT 0,
`add_email_helper` TINYINT(1) NOT NULL DEFAULT 0,
`add_git_folder_path` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript` TINYINT(1) NOT NULL DEFAULT 0,
`add_jcb_powers_path` TINYINT(1) NOT NULL DEFAULT 0,
`add_license` TINYINT(1) NOT NULL DEFAULT 0,
`add_menu_prefix` CHAR(1) NOT NULL DEFAULT '',
`add_namespace_prefix` CHAR(1) NOT NULL DEFAULT '',
`add_php_helper_admin` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_helper_both` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_helper_site` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_method_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_method_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postflight_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postflight_update` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_update` TINYINT(1) NOT NULL DEFAULT 0,
`add_placeholders` TINYINT(1) NOT NULL DEFAULT 0,
`add_powers` TINYINT(1) NOT NULL DEFAULT 1,
`add_sales_server` TINYINT(1) NOT NULL DEFAULT 0,
`add_site_event` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_update_server` TINYINT(1) NOT NULL DEFAULT 0,
`addcontributors` TEXT NOT NULL,
`addfootable` TINYINT(1) NOT NULL DEFAULT 0,
`addreadme` TINYINT(1) NOT NULL DEFAULT 0,
`adduikit` TINYINT(1) NOT NULL DEFAULT 0,
`assets_table_fix` TINYINT(1) NOT NULL DEFAULT 3,
`author` VARCHAR(255) NOT NULL DEFAULT '',
`backup_folder_path` VARCHAR(255) NOT NULL DEFAULT '',
`bom` CHAR(64) NOT NULL DEFAULT '',
`buildcomp` TINYINT(1) NOT NULL DEFAULT 0,
`buildcompsql` MEDIUMTEXT NOT NULL,
`companyname` CHAR(64) NOT NULL DEFAULT '',
`component_version` CHAR(64) NOT NULL DEFAULT '',
`copyright` VARCHAR(255) NOT NULL DEFAULT '',
`created` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
`creatuserhelper` TINYINT(1) NOT NULL DEFAULT 0,
`crowdin_account_api_key` TEXT NOT NULL,
`crowdin_project_api_key` TEXT NOT NULL,
`crowdin_project_identifier` VARCHAR(255) NOT NULL DEFAULT '',
`crowdin_username` TEXT NOT NULL,
`css_admin` TEXT NOT NULL,
`css_site` TEXT NOT NULL,
`dashboard` VARCHAR(64) NOT NULL DEFAULT '',
`dashboard_type` TINYINT(1) NOT NULL DEFAULT 1,
`debug_linenr` TINYINT(1) NOT NULL DEFAULT 0,
`description` TEXT NULL,
`email` VARCHAR(255) NOT NULL DEFAULT '',
`emptycontributors` TINYINT(1) NOT NULL DEFAULT 0,
`export_buy_link` VARCHAR(255) NOT NULL DEFAULT '',
`export_key` TEXT NOT NULL,
`git_folder_path` VARCHAR(255) NOT NULL DEFAULT '',
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`image` VARCHAR(255) NOT NULL DEFAULT '',
`javascript` TEXT NOT NULL,
`jcb_powers_path` VARCHAR(255) NOT NULL DEFAULT '',
`joomla_source_link` VARCHAR(255) NOT NULL DEFAULT '',
`license` VARCHAR(255) NOT NULL DEFAULT '',
`license_type` TINYINT(1) NOT NULL DEFAULT 0,
`menu_prefix` VARCHAR(100) NOT NULL DEFAULT '',
`modified` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
`mvc_versiondate` TINYINT(1) NOT NULL DEFAULT 0,
`name` CHAR(64) NOT NULL DEFAULT '',
`name_code` VARCHAR(255) NOT NULL DEFAULT '',
`namespace_prefix` VARCHAR(255) NOT NULL DEFAULT '',
`number` INT(11) NOT NULL DEFAULT 0,
`php_admin_event` MEDIUMTEXT NOT NULL,
`php_helper_admin` MEDIUMTEXT NOT NULL,
`php_helper_both` MEDIUMTEXT NOT NULL,
`php_helper_site` MEDIUMTEXT NOT NULL,
`php_method_install` MEDIUMTEXT NOT NULL,
`php_method_uninstall` MEDIUMTEXT NOT NULL,
`php_postflight_install` MEDIUMTEXT NOT NULL,
`php_postflight_update` MEDIUMTEXT NOT NULL,
`php_preflight_install` MEDIUMTEXT NOT NULL,
`php_preflight_update` MEDIUMTEXT NOT NULL,
`php_site_event` MEDIUMTEXT NOT NULL,
`preferred_joomla_version` INT(11) NOT NULL DEFAULT 3,
`readme` TEXT NOT NULL,
`remove_line_breaks` TINYINT(1) NOT NULL DEFAULT 0,
`sales_server` INT(11) NOT NULL DEFAULT 0,
`short_description` VARCHAR(255) NOT NULL DEFAULT '',
`sql` MEDIUMTEXT NOT NULL,
`sql_uninstall` MEDIUMTEXT NOT NULL,
`system_name` VARCHAR(255) NOT NULL DEFAULT '',
`toignore` TEXT NOT NULL,
`translation_tool` TINYINT(1) NOT NULL DEFAULT 0,
`update_server` INT(11) NOT NULL DEFAULT 0,
`update_server_target` TINYINT(1) NOT NULL DEFAULT 0,
`update_server_url` VARCHAR(255) NOT NULL DEFAULT '',
`website` CHAR(255) NOT NULL DEFAULT '',
`whmcs_buy_link` VARCHAR(255) NOT NULL DEFAULT '',
`whmcs_key` VARCHAR(255) NOT NULL DEFAULT '',
`whmcs_url` 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,
`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,
`metakey` TEXT,
`metadesc` TEXT NOT NULL,
`metadata` TEXT NOT NULL,
PRIMARY KEY (`id`),
KEY `idx_system_name` (`system_name`),
KEY `idx_name_code` (`name_code`),
KEY `idx_remove_line_breaks` (`remove_line_breaks`),
KEY `idx_debug_linenr` (`debug_linenr`),
KEY `idx_mvc_versiondate` (`mvc_versiondate`),
KEY `idx_addreadme` (`addreadme`),
KEY `idx_add_placeholders` (`add_placeholders`),
KEY `idx_add_backup_folder_path` (`add_backup_folder_path`),
KEY `idx_translation_tool` (`translation_tool`),
KEY `idx_add_license` (`add_license`),
KEY `idx_license_type` (`license_type`),
KEY `idx_add_powers` (`add_powers`),
KEY `idx_add_sales_server` (`add_sales_server`),
KEY `idx_add_jcb_powers_path` (`add_jcb_powers_path`),
KEY `idx_add_php_helper_admin` (`add_php_helper_admin`),
KEY `idx_add_admin_event` (`add_admin_event`),
KEY `idx_add_php_helper_site` (`add_php_helper_site`),
KEY `idx_add_site_event` (`add_site_event`),
KEY `idx_add_namespace_prefix` (`add_namespace_prefix`),
KEY `idx_add_javascript` (`add_javascript`),
KEY `idx_namespace_prefix` (`namespace_prefix`),
KEY `idx_add_css_admin` (`add_css_admin`),
KEY `idx_add_css_site` (`add_css_site`),
KEY `idx_add_menu_prefix` (`add_menu_prefix`),
KEY `idx_menu_prefix` (`menu_prefix`),
KEY `idx_add_php_preflight_install` (`add_php_preflight_install`),
KEY `idx_add_php_preflight_update` (`add_php_preflight_update`),
KEY `idx_add_php_postflight_install` (`add_php_postflight_install`),
KEY `idx_add_php_postflight_update` (`add_php_postflight_update`),
KEY `idx_add_php_method_uninstall` (`add_php_method_uninstall`),
KEY `idx_add_php_method_install` (`add_php_method_install`),
KEY `idx_add_sql` (`add_sql`),
KEY `idx_add_sql_uninstall` (`add_sql_uninstall`),
KEY `idx_assets_table_fix` (`assets_table_fix`),
KEY `idx_add_update_server` (`add_update_server`),
KEY `idx_emptycontributors` (`emptycontributors`),
KEY `idx_update_server_target` (`update_server_target`),
KEY `idx_add_git_folder_path` (`add_git_folder_path`),
KEY `idx_creatuserhelper` (`creatuserhelper`),
KEY `idx_adduikit` (`adduikit`),
KEY `idx_addfootable` (`addfootable`),
KEY `idx_add_email_helper` (`add_email_helper`),
KEY `idx_add_php_helper_both` (`add_php_helper_both`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_module` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_class_helper` TINYINT(1) NOT NULL DEFAULT 0,
`add_class_helper_header` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_method_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postflight_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postflight_update` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_update` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_script_construct` TINYINT(1) NOT NULL DEFAULT 0,
`add_sales_server` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_update_server` TINYINT(1) NOT NULL DEFAULT 0,
`addreadme` TINYINT(1) NOT NULL DEFAULT 0,
`class_helper_code` MEDIUMTEXT NOT NULL,
`class_helper_header` TEXT NOT NULL,
`custom_get` TEXT NOT NULL,
`default` MEDIUMTEXT NOT NULL,
`description` TEXT NULL,
`fields` TEXT NOT NULL,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`libraries` TEXT NOT NULL,
`mod_code` TEXT NOT NULL,
`module_version` CHAR(64) NOT NULL DEFAULT '',
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_method_uninstall` MEDIUMTEXT NOT NULL,
`php_postflight_install` MEDIUMTEXT NOT NULL,
`php_postflight_update` MEDIUMTEXT NOT NULL,
`php_preflight_install` MEDIUMTEXT NOT NULL,
`php_preflight_uninstall` MEDIUMTEXT NOT NULL,
`php_preflight_update` MEDIUMTEXT NOT NULL,
`php_script_construct` MEDIUMTEXT NOT NULL,
`readme` TEXT NOT NULL,
`sales_server` INT(11) NOT NULL DEFAULT 0,
`snippet` INT(11) NOT NULL DEFAULT 0,
`sql` MEDIUMTEXT NOT NULL,
`sql_uninstall` MEDIUMTEXT NOT NULL,
`system_name` VARCHAR(255) NOT NULL DEFAULT '',
`target` TINYINT(1) NOT NULL DEFAULT 0,
`update_server` INT(11) NOT NULL DEFAULT 0,
`update_server_target` TINYINT(1) NOT NULL DEFAULT 0,
`update_server_url` 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_add_php_method_uninstall` (`add_php_method_uninstall`),
KEY `idx_add_php_postflight_update` (`add_php_postflight_update`),
KEY `idx_add_php_postflight_install` (`add_php_postflight_install`),
KEY `idx_add_php_preflight_uninstall` (`add_php_preflight_uninstall`),
KEY `idx_addreadme` (`addreadme`),
KEY `idx_add_sql` (`add_sql`),
KEY `idx_update_server_target` (`update_server_target`),
KEY `idx_add_sql_uninstall` (`add_sql_uninstall`),
KEY `idx_add_update_server` (`add_update_server`),
KEY `idx_add_php_script_construct` (`add_php_script_construct`),
KEY `idx_add_php_preflight_install` (`add_php_preflight_install`),
KEY `idx_add_sales_server` (`add_sales_server`),
KEY `idx_add_php_preflight_update` (`add_php_preflight_update`),
KEY `idx_guid` (`guid`),
KEY `idx_name` (`name`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_plugin` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_head` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_method_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postflight_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postflight_update` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_install` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_preflight_update` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_script_construct` TINYINT(1) NOT NULL DEFAULT 0,
`add_sales_server` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql_uninstall` TINYINT(1) NOT NULL DEFAULT 0,
`add_update_server` TINYINT(1) NOT NULL DEFAULT 0,
`addreadme` TINYINT(1) NOT NULL DEFAULT 0,
`class_extends` INT(11) NOT NULL DEFAULT 0,
`description` TEXT NULL,
`fields` TEXT NOT NULL,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`head` TEXT NULL,
`joomla_plugin_group` INT(11) NOT NULL DEFAULT 0,
`main_class_code` MEDIUMTEXT NOT NULL,
`method_selection` TEXT NOT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_method_uninstall` MEDIUMTEXT NOT NULL,
`php_postflight_install` MEDIUMTEXT NOT NULL,
`php_postflight_update` MEDIUMTEXT NOT NULL,
`php_preflight_install` MEDIUMTEXT NOT NULL,
`php_preflight_uninstall` MEDIUMTEXT NOT NULL,
`php_preflight_update` MEDIUMTEXT NOT NULL,
`php_script_construct` MEDIUMTEXT NOT NULL,
`plugin_version` CHAR(64) NOT NULL DEFAULT '',
`property_selection` TEXT NOT NULL,
`readme` TEXT NOT NULL,
`sales_server` INT(11) NOT NULL DEFAULT 0,
`sql` MEDIUMTEXT NOT NULL,
`sql_uninstall` MEDIUMTEXT NOT NULL,
`system_name` VARCHAR(255) NOT NULL DEFAULT '',
`update_server` INT(11) NOT NULL DEFAULT 0,
`update_server_target` TINYINT(1) NOT NULL DEFAULT 0,
`update_server_url` 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_class_extends` (`class_extends`),
KEY `idx_joomla_plugin_group` (`joomla_plugin_group`),
KEY `idx_add_sql` (`add_sql`),
KEY `idx_add_php_method_uninstall` (`add_php_method_uninstall`),
KEY `idx_add_php_postflight_update` (`add_php_postflight_update`),
KEY `idx_add_php_postflight_install` (`add_php_postflight_install`),
KEY `idx_add_update_server` (`add_update_server`),
KEY `idx_add_sql_uninstall` (`add_sql_uninstall`),
KEY `idx_addreadme` (`addreadme`),
KEY `idx_update_server_target` (`update_server_target`),
KEY `idx_add_php_script_construct` (`add_php_script_construct`),
KEY `idx_add_php_preflight_install` (`add_php_preflight_install`),
KEY `idx_add_php_preflight_update` (`add_php_preflight_update`),
KEY `idx_add_php_preflight_uninstall` (`add_php_preflight_uninstall`),
KEY `idx_add_sales_server` (`add_sales_server`),
KEY `idx_guid` (`guid`),
KEY `idx_name` (`name`),
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;
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_power` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_head` TINYINT(1) NOT NULL DEFAULT 0,
`add_licensing_template` TINYINT(1) NOT NULL DEFAULT 1,
`approved` TINYINT(1) NOT NULL DEFAULT 0,
`approved_paths` TEXT NULL,
`composer` TEXT NULL,
`description` TEXT NULL,
`extends` VARCHAR(36) NOT NULL DEFAULT '',
`extends_custom` VARCHAR(64) NULL DEFAULT '',
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`head` TEXT NULL,
`implements` TEXT NULL,
`implements_custom` VARCHAR(1024) NOT NULL DEFAULT '',
`licensing_template` TEXT NULL,
`load_selection` TEXT NULL,
`main_class_code` MEDIUMTEXT NOT NULL,
`method_selection` TEXT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`namespace` VARCHAR(255) NOT NULL DEFAULT '',
`power_version` CHAR(64) NOT NULL DEFAULT '',
`property_selection` TEXT NULL,
`system_name` VARCHAR(255) NOT NULL DEFAULT '',
`type` VARCHAR(64) NOT NULL DEFAULT '',
`use_selection` TEXT NULL,
`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_namespace` (`namespace`),
KEY `idx_type` (`type`),
KEY `idx_extends_custom` (`extends_custom`),
KEY `idx_implements_custom` (`implements_custom`),
KEY `idx_add_licensing_template` (`add_licensing_template`),
KEY `idx_guid` (`guid`),
KEY `idx_name` (`name`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_admin_view` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_category_submenu` TINYINT(1) NOT NULL DEFAULT 1,
`add_css_view` TINYINT(1) NOT NULL DEFAULT 0,
`add_css_views` TINYINT(1) NOT NULL DEFAULT 0,
`add_custom_button` INT(1) NOT NULL DEFAULT 0,
`add_custom_import` TINYINT(1) NOT NULL DEFAULT 0,
`add_fadein` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript_view_file` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript_view_footer` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript_views_file` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript_views_footer` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_after_cancel` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_after_delete` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_after_publish` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_ajax` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_allowadd` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_allowedit` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_batchcopy` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_batchmove` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_before_cancel` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_before_delete` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_before_publish` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_before_save` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_getform` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_getitem` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_getitems` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_getitems_after_all` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_getlistquery` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_postsavehook` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_save` TINYINT(1) NOT NULL DEFAULT 0,
`add_sql` TINYINT(1) NOT NULL DEFAULT 0,
`addlinked_views` TEXT NOT NULL,
`addpermissions` TEXT NOT NULL,
`addtables` TEXT NOT NULL,
`addtabs` TEXT NOT NULL,
`ajax_input` TEXT NOT NULL,
`alias_builder` VARCHAR(255) NOT NULL DEFAULT '',
`alias_builder_type` TINYINT(1) NOT NULL DEFAULT 0,
`css_view` TEXT NOT NULL,
`css_views` TEXT NOT NULL,
`custom_button` TEXT NOT NULL,
`description` TEXT NULL,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`html_import_view` MEDIUMTEXT NOT NULL,
`icon` VARCHAR(255) NOT NULL DEFAULT '',
`icon_add` VARCHAR(255) NOT NULL DEFAULT '',
`icon_category` VARCHAR(255) NOT NULL DEFAULT '',
`javascript_view_file` TEXT NOT NULL,
`javascript_view_footer` TEXT NOT NULL,
`javascript_views_file` TEXT NOT NULL,
`javascript_views_footer` TEXT NOT NULL,
`mysql_table_charset` VARCHAR(64) NOT NULL DEFAULT 1,
`mysql_table_collate` VARCHAR(64) NOT NULL DEFAULT 1,
`mysql_table_engine` VARCHAR(64) NOT NULL DEFAULT 1,
`mysql_table_row_format` VARCHAR(64) NOT NULL DEFAULT 0,
`name_list` CHAR(64) NOT NULL DEFAULT '',
`name_single` CHAR(64) NOT NULL DEFAULT '',
`php_after_cancel` MEDIUMTEXT NOT NULL,
`php_after_delete` MEDIUMTEXT NOT NULL,
`php_after_publish` MEDIUMTEXT NOT NULL,
`php_ajaxmethod` MEDIUMTEXT NOT NULL,
`php_allowadd` MEDIUMTEXT NOT NULL,
`php_allowedit` MEDIUMTEXT NOT NULL,
`php_batchcopy` MEDIUMTEXT NOT NULL,
`php_batchmove` MEDIUMTEXT NOT NULL,
`php_before_cancel` MEDIUMTEXT NOT NULL,
`php_before_delete` MEDIUMTEXT NOT NULL,
`php_before_publish` MEDIUMTEXT NOT NULL,
`php_before_save` MEDIUMTEXT NOT NULL,
`php_controller` MEDIUMTEXT NOT NULL,
`php_controller_list` MEDIUMTEXT NOT NULL,
`php_document` MEDIUMTEXT NOT NULL,
`php_getform` MEDIUMTEXT NOT NULL,
`php_getitem` MEDIUMTEXT NOT NULL,
`php_getitems` MEDIUMTEXT NOT NULL,
`php_getitems_after_all` MEDIUMTEXT NOT NULL,
`php_getlistquery` MEDIUMTEXT NOT NULL,
`php_import` MEDIUMTEXT NOT NULL,
`php_import_display` MEDIUMTEXT NOT NULL,
`php_import_ext` MEDIUMTEXT NOT NULL,
`php_import_headers` MEDIUMTEXT NOT NULL,
`php_import_save` MEDIUMTEXT NOT NULL,
`php_import_setdata` MEDIUMTEXT NOT NULL,
`php_model` MEDIUMTEXT NOT NULL,
`php_model_list` MEDIUMTEXT NOT NULL,
`php_postsavehook` MEDIUMTEXT NOT NULL,
`php_save` MEDIUMTEXT NOT NULL,
`short_description` VARCHAR(255) NOT NULL DEFAULT '',
`source` TINYINT(1) NOT NULL DEFAULT 0,
`sql` MEDIUMTEXT NOT NULL,
`system_name` VARCHAR(255) NOT NULL DEFAULT '',
`type` INT(11) NOT NULL DEFAULT 0,
`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_name_single` (`name_single`),
KEY `idx_add_fadein` (`add_fadein`),
KEY `idx_mysql_table_charset` (`mysql_table_charset`),
KEY `idx_type` (`type`),
KEY `idx_source` (`source`),
KEY `idx_mysql_table_row_format` (`mysql_table_row_format`),
KEY `idx_add_category_submenu` (`add_category_submenu`),
KEY `idx_name_list` (`name_list`),
KEY `idx_add_php_getlistquery` (`add_php_getlistquery`),
KEY `idx_add_css_view` (`add_css_view`),
KEY `idx_add_php_getform` (`add_php_getform`),
KEY `idx_add_php_before_save` (`add_php_before_save`),
KEY `idx_add_css_views` (`add_css_views`),
KEY `idx_add_php_save` (`add_php_save`),
KEY `idx_add_php_postsavehook` (`add_php_postsavehook`),
KEY `idx_add_javascript_view_file` (`add_javascript_view_file`),
KEY `idx_add_php_allowadd` (`add_php_allowadd`),
KEY `idx_add_php_allowedit` (`add_php_allowedit`),
KEY `idx_add_javascript_view_footer` (`add_javascript_view_footer`),
KEY `idx_add_php_before_cancel` (`add_php_before_cancel`),
KEY `idx_add_php_after_cancel` (`add_php_after_cancel`),
KEY `idx_add_javascript_views_file` (`add_javascript_views_file`),
KEY `idx_add_php_batchcopy` (`add_php_batchcopy`),
KEY `idx_add_php_batchmove` (`add_php_batchmove`),
KEY `idx_add_javascript_views_footer` (`add_javascript_views_footer`),
KEY `idx_add_php_before_publish` (`add_php_before_publish`),
KEY `idx_add_php_after_publish` (`add_php_after_publish`),
KEY `idx_add_custom_button` (`add_custom_button`),
KEY `idx_add_php_before_delete` (`add_php_before_delete`),
KEY `idx_add_php_after_delete` (`add_php_after_delete`),
KEY `idx_add_php_document` (`add_php_document`),
KEY `idx_mysql_table_engine` (`mysql_table_engine`),
KEY `idx_mysql_table_collate` (`mysql_table_collate`),
KEY `idx_add_sql` (`add_sql`),
KEY `idx_add_php_ajax` (`add_php_ajax`),
KEY `idx_add_custom_import` (`add_custom_import`),
KEY `idx_add_php_getitem` (`add_php_getitem`),
KEY `idx_add_php_getitems` (`add_php_getitems`),
KEY `idx_guid` (`guid`),
KEY `idx_add_php_getitems_after_all` (`add_php_getitems_after_all`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_custom_admin_view` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_css` TINYINT(1) NOT NULL DEFAULT 0,
`add_css_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_custom_button` INT(1) NOT NULL DEFAULT 0,
`add_javascript_file` TINYINT(1) NOT NULL DEFAULT 0,
`add_js_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_ajax` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_jview` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_jview_display` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_view` TINYINT(1) NOT NULL DEFAULT 0,
`ajax_input` TEXT NOT NULL,
`codename` VARCHAR(255) NOT NULL DEFAULT '',
`context` VARCHAR(255) NOT NULL DEFAULT '',
`css` TEXT NOT NULL,
`css_document` TEXT NOT NULL,
`custom_button` TEXT NOT NULL,
`custom_get` TEXT NOT NULL,
`default` MEDIUMTEXT NOT NULL,
`description` VARCHAR(255) NOT NULL DEFAULT '',
`dynamic_get` INT(11) NOT NULL DEFAULT 0,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`icon` VARCHAR(255) NOT NULL DEFAULT '',
`javascript_file` TEXT NOT NULL,
`js_document` TEXT NOT NULL,
`libraries` TEXT NOT NULL,
`main_get` INT(11) NOT NULL DEFAULT 0,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_ajaxmethod` MEDIUMTEXT NOT NULL,
`php_controller` MEDIUMTEXT NOT NULL,
`php_document` MEDIUMTEXT NOT NULL,
`php_jview` MEDIUMTEXT NOT NULL,
`php_jview_display` MEDIUMTEXT NOT NULL,
`php_model` MEDIUMTEXT NOT NULL,
`php_view` MEDIUMTEXT NOT NULL,
`snippet` INT(11) NOT NULL DEFAULT 0,
`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_name` (`name`),
KEY `idx_main_get` (`main_get`),
KEY `idx_add_php_jview_display` (`add_php_jview_display`),
KEY `idx_codename` (`codename`),
KEY `idx_add_php_jview` (`add_php_jview`),
KEY `idx_context` (`context`),
KEY `idx_add_js_document` (`add_js_document`),
KEY `idx_add_javascript_file` (`add_javascript_file`),
KEY `idx_add_css_document` (`add_css_document`),
KEY `idx_add_php_document` (`add_php_document`),
KEY `idx_add_css` (`add_css`),
KEY `idx_add_php_view` (`add_php_view`),
KEY `idx_add_php_ajax` (`add_php_ajax`),
KEY `idx_dynamic_get` (`dynamic_get`),
KEY `idx_add_custom_button` (`add_custom_button`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_site_view` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_css` TINYINT(1) NOT NULL DEFAULT 0,
`add_css_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_custom_button` INT(1) NOT NULL DEFAULT 0,
`add_javascript_file` TINYINT(1) NOT NULL DEFAULT 0,
`add_js_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_ajax` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_document` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_jview` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_jview_display` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_view` TINYINT(1) NOT NULL DEFAULT 0,
`ajax_input` TEXT NOT NULL,
`button_position` TINYINT(1) NOT NULL DEFAULT 1,
`codename` VARCHAR(255) NOT NULL DEFAULT '',
`context` VARCHAR(255) NOT NULL DEFAULT '',
`css` TEXT NOT NULL,
`css_document` TEXT NOT NULL,
`custom_button` TEXT NOT NULL,
`custom_get` TEXT NOT NULL,
`default` MEDIUMTEXT NOT NULL,
`description` VARCHAR(255) NOT NULL DEFAULT '',
`dynamic_get` INT(11) NOT NULL DEFAULT 0,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`javascript_file` TEXT NOT NULL,
`js_document` TEXT NOT NULL,
`libraries` TEXT NOT NULL,
`main_get` INT(11) NOT NULL DEFAULT 0,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_ajaxmethod` MEDIUMTEXT NOT NULL,
`php_controller` MEDIUMTEXT NOT NULL,
`php_document` MEDIUMTEXT NOT NULL,
`php_jview` MEDIUMTEXT NOT NULL,
`php_jview_display` MEDIUMTEXT NOT NULL,
`php_model` MEDIUMTEXT NOT NULL,
`php_view` MEDIUMTEXT NOT NULL,
`snippet` INT(11) NOT NULL DEFAULT 0,
`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_name` (`name`),
KEY `idx_main_get` (`main_get`),
KEY `idx_add_php_jview_display` (`add_php_jview_display`),
KEY `idx_add_php_document` (`add_php_document`),
KEY `idx_add_php_view` (`add_php_view`),
KEY `idx_codename` (`codename`),
KEY `idx_context` (`context`),
KEY `idx_add_php_jview` (`add_php_jview`),
KEY `idx_add_javascript_file` (`add_javascript_file`),
KEY `idx_add_js_document` (`add_js_document`),
KEY `idx_add_css_document` (`add_css_document`),
KEY `idx_add_css` (`add_css`),
KEY `idx_dynamic_get` (`dynamic_get`),
KEY `idx_add_php_ajax` (`add_php_ajax`),
KEY `idx_add_custom_button` (`add_custom_button`),
KEY `idx_button_position` (`button_position`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_template` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_php_view` TINYINT(1) NOT NULL DEFAULT 0,
`alias` VARCHAR(255) NOT NULL DEFAULT '',
`description` VARCHAR(255) NOT NULL DEFAULT '',
`dynamic_get` INT(11) NOT NULL DEFAULT 0,
`libraries` TEXT NOT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_view` MEDIUMTEXT NOT NULL,
`snippet` INT(11) NOT NULL DEFAULT 0,
`template` TEXT NOT NULL,
`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_name` (`name`),
KEY `idx_dynamic_get` (`dynamic_get`),
KEY `idx_add_php_view` (`add_php_view`),
KEY `idx_alias` (`alias`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_layout` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_php_view` TINYINT(1) NOT NULL DEFAULT 0,
`alias` VARCHAR(255) NOT NULL DEFAULT '',
`description` VARCHAR(255) NOT NULL DEFAULT '',
`dynamic_get` INT(11) NOT NULL DEFAULT 0,
`layout` TEXT NOT NULL,
`libraries` TEXT NOT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_view` MEDIUMTEXT NOT NULL,
`snippet` INT(11) NOT NULL DEFAULT 0,
`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_name` (`name`),
KEY `idx_dynamic_get` (`dynamic_get`),
KEY `idx_add_php_view` (`add_php_view`),
KEY `idx_alias` (`alias`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_dynamic_get` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_php_after_getitem` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_after_getitems` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_before_getitem` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_before_getitems` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_getlistquery` TINYINT(1) NOT NULL DEFAULT 0,
`add_php_router_parse` TINYINT(1) NOT NULL DEFAULT 0,
`addcalculation` TINYINT(1) NOT NULL DEFAULT 0,
`db_selection` TEXT NOT NULL,
`db_table_main` VARCHAR(255) NOT NULL DEFAULT '',
`filter` TEXT NOT NULL,
`getcustom` VARCHAR(255) NOT NULL DEFAULT '',
`gettype` TINYINT(1) NOT NULL DEFAULT 0,
`global` TEXT NOT NULL,
`group` TEXT NOT NULL,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`join_db_table` TEXT NOT NULL,
`join_view_table` TEXT NOT NULL,
`main_source` TINYINT(1) NOT NULL DEFAULT 0,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`order` TEXT NOT NULL,
`pagination` TINYINT(1) NOT NULL DEFAULT 1,
`php_after_getitem` MEDIUMTEXT NOT NULL,
`php_after_getitems` MEDIUMTEXT NOT NULL,
`php_before_getitem` MEDIUMTEXT NOT NULL,
`php_before_getitems` MEDIUMTEXT NOT NULL,
`php_calculation` MEDIUMTEXT NOT NULL,
`php_custom_get` MEDIUMTEXT NOT NULL,
`php_getlistquery` MEDIUMTEXT NOT NULL,
`php_router_parse` MEDIUMTEXT NOT NULL,
`plugin_events` VARCHAR(255) NOT NULL DEFAULT '',
`select_all` TINYINT(1) NOT NULL DEFAULT 0,
`view_selection` TEXT NOT NULL,
`view_table_main` INT(11) NOT NULL DEFAULT 0,
`where` TEXT NOT NULL,
`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_name` (`name`),
KEY `idx_main_source` (`main_source`),
KEY `idx_gettype` (`gettype`),
KEY `idx_add_php_after_getitems` (`add_php_after_getitems`),
KEY `idx_add_php_router_parse` (`add_php_router_parse`),
KEY `idx_add_php_before_getitems` (`add_php_before_getitems`),
KEY `idx_add_php_before_getitem` (`add_php_before_getitem`),
KEY `idx_add_php_after_getitem` (`add_php_after_getitem`),
KEY `idx_add_php_getlistquery` (`add_php_getlistquery`),
KEY `idx_select_all` (`select_all`),
KEY `idx_getcustom` (`getcustom`),
KEY `idx_pagination` (`pagination`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_custom_code` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`code` MEDIUMTEXT NOT NULL,
`comment_type` TINYINT(1) NOT NULL DEFAULT 1,
`component` INT(11) NOT NULL DEFAULT 0,
`from_line` VARCHAR(100) NOT NULL DEFAULT '',
`function_name` VARCHAR(255) NOT NULL DEFAULT '',
`hashendtarget` VARCHAR(64) NOT NULL DEFAULT '',
`hashtarget` VARCHAR(64) NOT NULL DEFAULT '',
`joomla_version` INT(11) NOT NULL DEFAULT 3,
`path` TEXT NOT NULL,
`system_name` VARCHAR(255) NOT NULL DEFAULT '',
`target` TINYINT(1) NOT NULL DEFAULT 0,
`to_line` VARCHAR(100) NOT NULL DEFAULT '',
`type` TINYINT(1) NOT NULL DEFAULT 0,
`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_component` (`component`),
KEY `idx_target` (`target`),
KEY `idx_type` (`type`),
KEY `idx_function_name` (`function_name`),
KEY `idx_to_line` (`to_line`),
KEY `idx_from_line` (`from_line`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_class_property` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`comment` TEXT NOT NULL,
`default` TEXT NOT NULL,
`extension_type` VARCHAR(64) NOT NULL DEFAULT '',
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`joomla_plugin_group` INT(11) NOT NULL DEFAULT 0,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`visibility` 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_name` (`name`),
KEY `idx_visibility` (`visibility`),
KEY `idx_guid` (`guid`),
KEY `idx_joomla_plugin_group` (`joomla_plugin_group`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_class_method` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`arguments` TEXT NOT NULL,
`code` MEDIUMTEXT NOT NULL,
`comment` TEXT NOT NULL,
`extension_type` VARCHAR(64) NOT NULL DEFAULT '',
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`joomla_plugin_group` INT(11) NOT NULL DEFAULT 0,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`visibility` 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_name` (`name`),
KEY `idx_visibility` (`visibility`),
KEY `idx_guid` (`guid`),
KEY `idx_joomla_plugin_group` (`joomla_plugin_group`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_placeholder` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`target` VARCHAR(255) NOT NULL DEFAULT '',
`value` TEXT NOT NULL,
`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_target` (`target`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_library` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addconditions` MEDIUMTEXT NOT NULL,
`description` VARCHAR(255) NOT NULL DEFAULT '',
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`how` TINYINT(1) NOT NULL DEFAULT 1,
`libraries` TEXT NOT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php_setdocument` MEDIUMTEXT NOT NULL,
`target` TINYINT(1) NOT NULL DEFAULT 1,
`type` TINYINT(1) NOT NULL DEFAULT 0,
`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_name` (`name`),
KEY `idx_how` (`how`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_snippet` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`contributor_company` VARCHAR(255) NOT NULL DEFAULT '',
`contributor_email` VARCHAR(255) NOT NULL DEFAULT '',
`contributor_name` VARCHAR(255) NOT NULL DEFAULT '',
`contributor_website` VARCHAR(255) NOT NULL DEFAULT '',
`description` TEXT NULL,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`heading` VARCHAR(255) NOT NULL DEFAULT '',
`library` INT(11) NOT NULL DEFAULT 0,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`snippet` TEXT NOT NULL,
`type` INT(11) NOT NULL DEFAULT 0,
`url` VARCHAR(255) NOT NULL DEFAULT '',
`usage` TEXT NOT NULL,
`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_name` (`name`),
KEY `idx_type` (`type`),
KEY `idx_library` (`library`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_validation_rule` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`inherit` CHAR(64) NOT NULL DEFAULT '',
`name` VARCHAR(255) NOT NULL DEFAULT '',
`php` MEDIUMTEXT NOT NULL,
`short_description` 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_name` (`name`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_field` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`add_css_view` TINYINT(1) NOT NULL DEFAULT 0,
`add_css_views` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript_view_footer` TINYINT(1) NOT NULL DEFAULT 0,
`add_javascript_views_footer` TINYINT(1) NOT NULL DEFAULT 0,
`catid` INT(11) NOT NULL DEFAULT 0,
`css_view` TEXT NOT NULL,
`css_views` TEXT NOT NULL,
`datadefault` CHAR(64) NOT NULL DEFAULT '',
`datadefault_other` CHAR(64) NOT NULL DEFAULT '',
`datalenght` CHAR(64) NOT NULL DEFAULT '',
`datalenght_other` CHAR(64) NOT NULL DEFAULT '',
`datatype` CHAR(64) NOT NULL DEFAULT '',
`fieldtype` INT(11) NOT NULL DEFAULT 0,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`indexes` CHAR(64) NOT NULL DEFAULT '',
`initiator_on_get_model` TEXT NOT NULL,
`initiator_on_save_model` TEXT NOT NULL,
`javascript_view_footer` TEXT NOT NULL,
`javascript_views_footer` TEXT NOT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`null_switch` CHAR(64) NOT NULL DEFAULT '',
`on_get_model_field` TEXT NOT NULL,
`on_save_model_field` TEXT NOT NULL,
`store` INT(11) NOT NULL DEFAULT 0,
`xml` TEXT NOT NULL,
`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_name` (`name`),
KEY `idx_fieldtype` (`fieldtype`),
KEY `idx_datatype` (`datatype`),
KEY `idx_indexes` (`indexes`),
KEY `idx_null_switch` (`null_switch`),
KEY `idx_catid` (`catid`),
KEY `idx_datalenght` (`datalenght`),
KEY `idx_datadefault_other` (`datadefault_other`),
KEY `idx_datadefault` (`datadefault`),
KEY `idx_datalenght_other` (`datalenght_other`),
KEY `idx_add_css_view` (`add_css_view`),
KEY `idx_add_css_views` (`add_css_views`),
KEY `idx_add_javascript_view_footer` (`add_javascript_view_footer`),
KEY `idx_add_javascript_views_footer` (`add_javascript_views_footer`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_fieldtype` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`catid` INT(11) NOT NULL DEFAULT 0,
`datadefault` CHAR(64) NOT NULL DEFAULT '',
`datadefault_other` CHAR(64) NOT NULL DEFAULT '',
`datalenght` CHAR(64) NOT NULL DEFAULT '',
`datalenght_other` CHAR(64) NOT NULL DEFAULT '',
`datatype` CHAR(64) NOT NULL DEFAULT '',
`description` TEXT NULL,
`guid` VARCHAR(36) NOT NULL DEFAULT '',
`has_defaults` TINYINT(1) NOT NULL DEFAULT 0,
`indexes` CHAR(64) NOT NULL DEFAULT '',
`name` VARCHAR(255) NOT NULL DEFAULT '',
`null_switch` CHAR(64) NOT NULL DEFAULT '',
`properties` TEXT NOT NULL,
`short_description` VARCHAR(255) NOT NULL DEFAULT '',
`store` INT(11) NOT NULL DEFAULT 0,
`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_name` (`name`),
KEY `idx_null_switch` (`null_switch`),
KEY `idx_indexes` (`indexes`),
KEY `idx_datadefault_other` (`datadefault_other`),
KEY `idx_datadefault` (`datadefault`),
KEY `idx_datatype` (`datatype`),
KEY `idx_has_defaults` (`has_defaults`),
KEY `idx_datalenght` (`datalenght`),
KEY `idx_datalenght_other` (`datalenght_other`),
KEY `idx_guid` (`guid`),
KEY `idx_catid` (`catid`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_language_translation` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`components` TEXT NULL,
`modules` TEXT NULL,
`plugins` TEXT NULL,
`source` MEDIUMTEXT NOT NULL,
`translation` TEXT NULL,
`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_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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_language` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`langtag` VARCHAR(64) NOT NULL DEFAULT '',
`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_name` (`name`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_server` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`authentication` TINYINT(1) NOT NULL DEFAULT 0,
`host` TEXT NOT NULL,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`password` TEXT NOT NULL,
`path` TEXT NOT NULL,
`port` TEXT NOT NULL,
`private` TEXT NOT NULL,
`private_key` TEXT NOT NULL,
`protocol` TINYINT(1) NOT NULL DEFAULT 0,
`secret` TEXT NOT NULL,
`signature` TEXT NOT NULL,
`username` TEXT NOT NULL,
`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_name` (`name`),
KEY `idx_protocol` (`protocol`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_help_document` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`admin_view` CHAR(255) NOT NULL DEFAULT '',
`alias` CHAR(64) NOT NULL DEFAULT '',
`article` TINYINT(1) NOT NULL DEFAULT 0,
`content` TEXT NOT NULL,
`groups` TEXT NOT NULL,
`location` TINYINT(1) NOT NULL DEFAULT 0,
`not_required` INT(1) NOT NULL DEFAULT 0,
`site_view` CHAR(255) NOT NULL DEFAULT '',
`target` TINYINT(1) NOT NULL DEFAULT 0,
`title` CHAR(64) NOT NULL DEFAULT '',
`type` TINYINT(1) NOT NULL DEFAULT 0,
`url` 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,
`ordering` INT(11) NOT NULL DEFAULT 0,
PRIMARY KEY (`id`),
KEY `idx_title` (`title`),
KEY `idx_type` (`type`),
KEY `idx_location` (`location`),
KEY `idx_article` (`article`),
KEY `idx_target` (`target`),
KEY `idx_alias` (`alias`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_admin_fields` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addfields` MEDIUMTEXT NOT NULL,
`admin_view` INT(11) NOT NULL DEFAULT 0,
`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_admin_view` (`admin_view`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_admin_fields_conditions` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addconditions` MEDIUMTEXT NOT NULL,
`admin_view` INT(11) NOT NULL DEFAULT 0,
`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_admin_view` (`admin_view`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_admin_fields_relations` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addrelations` MEDIUMTEXT NOT NULL,
`admin_view` INT(11) NOT NULL DEFAULT 0,
`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_admin_view` (`admin_view`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_admin_custom_tabs` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`admin_view` INT(11) NOT NULL DEFAULT 0,
`tabs` TEXT NOT NULL,
`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_admin_view` (`admin_view`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_admin_views` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addadmin_views` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_site_views` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addsite_views` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_custom_admin_views` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addcustom_admin_views` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_updates` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`version_update` MEDIUMTEXT NOT NULL,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_mysql_tweaks` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`sql_tweak` TEXT NOT NULL,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_custom_admin_menus` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addcustommenus` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_router` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`constructor_after_parent_code` MEDIUMTEXT NOT NULL,
`constructor_before_parent_code` MEDIUMTEXT NOT NULL,
`constructor_before_parent_manual` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`methods_code` MEDIUMTEXT NOT NULL,
`mode_constructor_after_parent` TINYINT(1) NOT NULL DEFAULT 0,
`mode_constructor_before_parent` TINYINT(1) NOT NULL DEFAULT 0,
`mode_methods` TINYINT(1) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_config` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addconfig` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_dashboard` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`dashboard_tab` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`php_dashboard_methods` MEDIUMTEXT NOT NULL,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_files_folders` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addfiles` TEXT NOT NULL,
`addfilesfullpath` TEXT NOT NULL,
`addfolders` TEXT NOT NULL,
`addfoldersfullpath` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_placeholders` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addplaceholders` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_plugins` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addjoomla_plugins` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_component_modules` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addjoomla_modules` TEXT NOT NULL,
`joomla_component` INT(11) NOT NULL DEFAULT 0,
`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_joomla_component` (`joomla_component`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_snippet_type` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`description` VARCHAR(255) NOT NULL DEFAULT '',
`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_name` (`name`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_library_config` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addconfig` TEXT NOT NULL,
`library` INT(11) NOT NULL DEFAULT 0,
`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_library` (`library`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_library_files_folders_urls` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addfiles` TEXT NOT NULL,
`addfilesfullpath` TEXT NOT NULL,
`addfolders` TEXT NOT NULL,
`addfoldersfullpath` TEXT NOT NULL,
`addurls` TEXT NOT NULL,
`library` INT(11) NOT NULL DEFAULT 0,
`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_library` (`library`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_class_extends` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`comment` TEXT NOT NULL,
`extension_type` VARCHAR(64) NOT NULL DEFAULT '',
`head` TEXT NULL,
`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_name` (`name`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_module_updates` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`joomla_module` INT(11) NOT NULL DEFAULT 0,
`version_update` MEDIUMTEXT NOT NULL,
`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_joomla_module` (`joomla_module`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_module_files_folders_urls` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addfiles` TEXT NOT NULL,
`addfilesfullpath` TEXT NOT NULL,
`addfolders` TEXT NOT NULL,
`addfoldersfullpath` TEXT NOT NULL,
`addurls` TEXT NOT NULL,
`joomla_module` INT(11) NOT NULL DEFAULT 0,
`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_joomla_module` (`joomla_module`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_plugin_group` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`class_extends` INT(11) NOT NULL DEFAULT 0,
`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_name` (`name`),
KEY `idx_class_extends` (`class_extends`),
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;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_plugin_updates` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`joomla_plugin` INT(11) NOT NULL DEFAULT 0,
`version_update` MEDIUMTEXT NOT NULL,
`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_joomla_plugin` (`joomla_plugin`),
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_general_ci ROW_FORMAT=DYNAMIC;
CREATE TABLE IF NOT EXISTS `#__componentbuilder_joomla_plugin_files_folders_urls` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`asset_id` INT(10) unsigned NOT NULL DEFAULT 0 COMMENT 'FK to the #__assets table.',
`addfiles` TEXT NOT NULL,
`addfilesfullpath` TEXT NOT NULL,
`addfolders` TEXT NOT NULL,
`addfoldersfullpath` TEXT NOT NULL,
`addurls` TEXT NOT NULL,
`joomla_plugin` INT(11) NOT NULL DEFAULT 0,
`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_joomla_plugin` (`joomla_plugin`),
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_general_ci ROW_FORMAT=DYNAMIC;
--
-- 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, '&#10003', '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, '&#10003', '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, '&#10003', '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, '&#10003', '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);
--
-- Dumping data for table `#__componentbuilder_joomla_plugin`
--
INSERT INTO `#__componentbuilder_joomla_plugin` (`id`, `add_head`, `add_php_method_uninstall`, `add_php_postflight_install`, `add_php_postflight_update`, `add_php_preflight_install`, `add_php_preflight_uninstall`, `add_php_preflight_update`, `add_php_script_construct`, `add_sales_server`, `add_sql`, `add_sql_uninstall`, `add_update_server`, `addreadme`, `class_extends`, `description`, `fields`, `guid`, `head`, `joomla_plugin_group`, `method_selection`, `main_class_code`, `name`, `php_method_uninstall`, `php_postflight_install`, `php_postflight_update`, `php_preflight_install`, `php_preflight_uninstall`, `php_preflight_update`, `php_script_construct`, `plugin_version`, `property_selection`, `readme`, `sales_server`, `sql`, `sql_uninstall`, `system_name`, `update_server`, `update_server_target`, `update_server_url`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`) VALUES
(1, 1, '', '', '', 1, '', '', '', '', '', '', '', 1, 4, 'The plugin to fully integrate componentbuilder with the privacy suite of Joomla.', '{}', '518f7be7-140c-47d3-9fb2-b6717230e0fc', 'dXNlIEpvb21sYVxVdGlsaXRpZXNcQXJyYXlIZWxwZXI7DQoNCkpMb2FkZXI6OnJlZ2lzdGVyKCdQcml2YWN5UGx1Z2luJywgSlBBVEhfQURNSU5JU1RSQVRPUiAuICcvY29tcG9uZW50cy9jb21fcHJpdmFjeS9oZWxwZXJzL3BsdWdpbi5waHAnKTsNCkpMb2FkZXI6OnJlZ2lzdGVyKCdQcml2YWN5UmVtb3ZhbFN0YXR1cycsIEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX3ByaXZhY3kvaGVscGVycy9yZW1vdmFsL3N0YXR1cy5waHAnKTsNCkpMb2FkZXI6OnJlZ2lzdGVyKCdbW1tDb21wb25lbnRdXV1IZWxwZXInLCBKUEFUSF9BRE1JTklTVFJBVE9SIC4gJy9jb21wb25lbnRzL2NvbV9bW1tjb21wb25lbnRdXV0vaGVscGVycy9bW1tjb21wb25lbnRdXV0ucGhwJyk7IA==', 10, '{\"method_selection0\":{\"method\":\"51\"},\"method_selection1\":{\"method\":\"52\"},\"method_selection2\":{\"method\":\"53\"}}', 'CS8qKg0KCSAqIEFwcGxpY2F0aW9uIG9iamVjdA0KCSAqDQoJICogQHZhciAgICBDTVNBcHBsaWNhdGlvbg0KCSAqIEBzaW5jZSAgMS4wDQoJICovDQoJcHJvdGVjdGVkICAkYXBwOw0KDQoJLyoqDQoJICogRGF0YWJhc2Ugb2JqZWN0DQoJICoNCgkgKiBAdmFyICAgIERhdGFiYXNlRHJpdmVyDQoJICogQHNpbmNlICAxLjANCgkgKi8NCglwcm90ZWN0ZWQgICRkYjsNCg0KCS8qKg0KCSAqIEFmZmVjdHMgY29uc3RydWN0b3IgYmVoYXZpb3IuIElmIHRydWUsIGxhbmd1YWdlIGZpbGVzIHdpbGwgYmUgbG9hZGVkIGF1dG9tYXRpY2FsbHkuDQoJICoNCgkgKiBAdmFyICAgIGJvb2xlYW4NCgkgKiBAc2luY2UgIDEuMA0KCSAqLw0KCXByb3RlY3RlZCAgJGF1dG9sb2FkTGFuZ3VhZ2UgPSB0cnVlOw0KDQoJLyoqDQoJICogUGVyZm9ybXMgdmFsaWRhdGlvbiB0byBkZXRlcm1pbmUgaWYgdGhlIGRhdGEgYXNzb2NpYXRlZCB3aXRoIGEgcmVtb3ZlIGluZm9ybWF0aW9uIHJlcXVlc3QgY2FuIGJlIHByb2Nlc3NlZA0KCSAqDQoJICogQHBhcmFtICAgUHJpdmFjeVRhYmxlUmVxdWVzdCAgJHJlcXVlc3QgIFRoZSByZXF1ZXN0IHJlY29yZCBiZWluZyBwcm9jZXNzZWQNCgkgKiBAcGFyYW0gICBKVXNlciAgICAgICAgICAgICAgICAkdXNlciAgICAgVGhlIHVzZXIgYWNjb3VudCBhc3NvY2lhdGVkIHdpdGggdGhpcyByZXF1ZXN0IGlmIGF2YWlsYWJsZQ0KCSAqDQoJICogQHJldHVybiAgUHJpdmFjeVJlbW92YWxTdGF0dXMNCgkgKg0KCSAqIEBzaW5jZSAgIDEuMA0KCSAqLw0KCXB1YmxpYyBmdW5jdGlvbiBvblByaXZhY3lDYW5SZW1vdmVEYXRhKFByaXZhY3lUYWJsZVJlcXVlc3QgJHJlcXVlc3QsIEpVc2VyICR1c2VyID0gbnVsbCkNCgl7DQoJCSRzdGF0dXMgPSBuZXcgUHJpdmFjeVJlbW92YWxTdGF0dXM7DQoNCgkJLy8gVGhpcyBwbHVnaW4gb25seSBwcm9jZXNzZXMgZGF0YSBmb3IgcmVnaXN0ZXJlZCB1c2VyIGFjY291bnRzDQoJCWlmICghJHVzZXIpDQoJCXsNCgkJCXJldHVybiAkc3RhdHVzOw0KCQl9DQoNCgkJLy8gY2hlY2sgaWYgdGhlIGhlbHBlciBtZXRob2QgaXMgc2V0IGluIHRoZSBjb21wb25lbnQNCgkJaWYgKG1ldGhvZF9leGlzdHMoJ1tbW0NvbXBvbmVudF1dXUhlbHBlcicsICdvblByaXZhY3lDYW5SZW1vdmVEYXRhJykpDQoJCXsNCgkJCVtbW0NvbXBvbmVudF1dXUhlbHBlcjo6b25Qcml2YWN5Q2FuUmVtb3ZlRGF0YSgkdGhpcywgJHN0YXR1cywgJHJlcXVlc3QsICR1c2VyKTsNCgkJfQ0KDQoJCXJldHVybiAkc3RhdHVzOw0KCX0NCg0KCS8qKg0KCSAqIFByb2Nlc3NlcyBhbiBleHBvcnQgcmVxdWVzdCBmb3IgSm9vbWxhIGNvcmUgdXNlciBkYXRhDQoJICoNCgkgKiBAcGFyYW0gICBQcml2YWN5VGFibGVSZXF1ZXN0ICAkcmVxdWVzdCAgVGhlIHJlcXVlc3QgcmVjb3JkIGJlaW5nIHByb2Nlc3NlZA0KCSAqIEBwYXJhbSAgIEpVc2VyICAgICAgICAgICAgICAgICR1c2VyICAgICBUaGUgdXNlciBhY2NvdW50IGFzc29jaWF0ZWQgd2l0aCB0aGlzIHJlcXVlc3QgaWYgYXZhaWxhYmxlDQoJICoNCgkgKiBAcmV0dXJuICBQcml2YWN5RXhwb3J0RG9tYWluW10NCgkgKg0KCSAqIEBzaW5jZSAgIDEuMA0KCSAqLw0KCXB1YmxpYyBmdW5jdGlvbiBvblByaXZhY3lFeHBvcnRSZXF1ZXN0KFByaXZhY3lUYWJsZVJlcXVlc3QgJHJlcXVlc3QsIEpVc2VyICR1c2VyID0gbnVsbCkNCgl7DQoJCSRkb21haW5zID0gYXJyYXkoKTsNCg0KCQkvLyBUaGlzIHBsdWdpbiBvbmx5IHByb2Nlc3NlcyBkYXRhIGZvciByZWdpc3RlcmVkIHVzZXIgYWNjb3VudHMNCgkJaWYgKCEkdXNlcikNCgkJew0KCQkJcmV0dXJuICRkb21haW5zOw0KCQl9DQoNCgkJLy8gY2hlY2sgaWYgdGhlIGhlbHBlciBtZXRob2QgaXMgc2V0IGluIHRoZSBjb21wb25lbnQNCgkJaWYgKG1ldGhvZF9leGlzdHMoJ1tbW0NvbXBvbmVudF1dXUhlbHBlcicsICdvblByaXZhY3lFeHBvcnRSZXF1ZXN0JykpDQoJCXsNCgkJCVtbW0NvbXBvbmVudF1dXUhlbHBlcjo6b25Qcml2YWN5RXhwb3J0UmVxdWVzdCgkdGhpcywgJGRvbWFpbnMsICRyZXF1ZXN0LCAkdXNlcik7DQoJCX0NCg0KCQlyZXR1cm4gJGRvbWFpbnM7DQoJfQ0KDQoJLyoqDQoJICogUmVtb3ZlcyB0aGUgZGF0YSBhc3NvY2lhdGVkIHdpdGggYSByZW1vdmUgaW5mb3JtYXRpb24gcmVxdWVzdA0KCSAqDQoJICogQHBhcmFtICAgUHJpdmFjeVRhYmxlUmVxdWVzdCAgJHJlcXVlc3QgIFRoZSByZXF1ZXN0IHJlY29yZCBiZWluZyBwcm9jZXNzZWQNCgkgKiBAcGFyYW0gICBKVXNlciAgICAgICAgICAgICAgICAkdXNlciAgICAgVGhlIHVzZXIgYWNjb3VudCBhc3NvY2lhdGVkIHdpdGggdGhpcyByZXF1ZXN0IGlmIGF2YWlsYWJsZQ0KCSAqDQoJICogQHJldHVybiAgdm9pZA0KCSAqDQoJICogQHNpbmNlICAgMS4wDQoJICovDQoJcHVibGljIGZ1bmN0aW9uIG9uUHJpdmFjeVJlbW92ZURhdGEoUHJpdmFjeVRhYmxlUmVxdWVzdCAkcmVxdWVzdCwgSlVzZXIgJHVzZXIgPSBudWxsKQ0KCXsNCgkJLy8gVGhpcyBwbHVnaW4gb25seSBwcm9jZXNzZXMgZGF0YSBmb3IgcmVnaXN0ZXJlZCB1c2VyIGFjY291bnRzDQoJCWlmICghJHVzZXIpDQoJCXsNCgkJCXJldHVybjsNCgkJfQ0KDQoJCS8vIGNoZWNrIGlmIHRoZSBoZWxwZXIgbWV0aG9kIGlzIHNldCBpbiB0aGUgY29tcG9uZW50DQoJCWlmIChtZXRob2RfZXhpc3RzKCdbW1tDb21wb25lbnRdXV1IZWxwZXInLCAnb25Qcml2YWN5UmVtb3ZlRGF0YScpKQ0KCQl7DQoJCQlbW1tDb21wb25lbnRdXV1IZWxwZXI6Om9uUHJpdmFjeVJlbW92ZURhdGEoJHRoaXMsICRyZXF1ZXN0LCAkdXNlcik7DQoJCX0NCgl9', '[[[Component]]]', 'Ly8gUEhQIE1ldGhvZCAodW5pbnN0YWxsKQ==', 'Ly8gUEhQIFBvc3RmbGlnaHQgKGluc3RhbGwp', 'Ly8gUEhQIFBvc3RmbGlnaHQgKHVwZGF0ZSk=', 'CQkJLy8gY2hlY2sgdGhhdCBbW1tjb21wb25lbnRdXV0gaXMgaW5zdGFsbGVkDQoJCQkkcGF0aFRvQ29yZSA9IEpQQVRIX0FETUlOSVNUUkFUT1IgLiAnL2NvbXBvbmVudHMvY29tX1tbW2NvbXBvbmVudF1dXS9oZWxwZXJzL1tbW2NvbXBvbmVudF1dXS5waHAnOw0KCQkJaWYgKCFKRmlsZTo6ZXhpc3RzKCRwYXRoVG9Db3JlKSkNCgkJCXsNCgkJCQkkYXBwLT5lbnF1ZXVlTWVzc2FnZSgnW1tbY29tcG9uZW50X2Fjcm9ueW1dXV0gbXVzdCBmaXJzdCBiZSBpbnN0YWxsZWQgZnJvbSA8YSBocmVmPSJbW1tnZXRfY29tcG9uZW50X2xpbmtdXV0iIHRhcmdldD0iX2JsYW5rIj5bW1tjb21wb25lbnRfbGlua19uYW1lXV1dPC9hPi4nLCAnZXJyb3InKTsNCgkJCQlyZXR1cm4gZmFsc2U7DQoJCQl9', 'Ly8gUEhQIFByZWZsaWdodCAodW5pbnN0YWxsKQ==', 'Ly8gUEhQIFByZWZsaWdodCAodXBkYXRlKQ==', '', '1.0.0', '{\"property_selection0\":{\"property\":\"31\"},\"property_selection1\":{\"property\":\"32\"},\"property_selection2\":{\"property\":\"33\"}}', 'IyAjIyNQTFVHSU5fTkFNRSMjIyAoIyMjVkVSU0lPTiMjIykNCg0KIyMjREVTQ1JJUFRJT04jIyMNCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkNvbXBhbnkqOiBbIyMjQ09NUEFOWU5BTUUjIyNdKCMjI0FVVEhPUldFQlNJVEUjIyMpDQorICpBdXRob3IqOiBbIyMjQVVUSE9SIyMjXShtYWlsdG86IyMjQVVUSE9SRU1BSUwjIyMpDQorICpWZXJzaW9uKjogIyMjVkVSU0lPTiMjIw0KKyAqQ29weXJpZ2h0KjogIyMjQ09QWVJJR0hUIyMjDQorICpMaWNlbnNlKjogIyMjTElDRU5TRSMjIw==', '', '', '', 'Global Privacy', '', 1, 'https://www.vdm.io/updates/componentbuilder_global_privacy.xml', '', 1, '2019-07-16 00:49:50', '2020-05-24 22:49:38', 29, '', 1),
(21, '', '', '', '', 1, '', '', '', '', '', '', '', '', 1, 'Plugin to autoload the powers of componentbuilder', '{}', '86dd28b5-18d4-437e-8a53-7eaf23478fc8', '', 8, '{}', 'CS8qKg0KCSAqIEFwcGxpY2F0aW9uIG9iamVjdA0KCSAqDQoJICogQHZhciAgICBDTVNBcHBsaWNhdGlvbg0KCSAqIEBzaW5jZSAgMS4wLjANCgkgKi8NCglwcm90ZWN0ZWQgICRhcHA7DQoNCgkvKioNCgkgKiBBZmZlY3RzIGNvbnN0cnVjdG9yIGJlaGF2aW9yLiBJZiB0cnVlLCBsYW5ndWFnZSBmaWxlcyB3aWxsIGJlIGxvYWRlZCBhdXRvbWF0aWNhbGx5Lg0KCSAqDQoJICogQHZhciAgICBib29sZWFuDQoJICogQHNpbmNlICAxLjAuMA0KCSAqLw0KCXByb3RlY3RlZCAgJGF1dG9sb2FkTGFuZ3VhZ2UgPSBmYWxzZTsNCg0KCS8qKg0KCSAqIENvbnN0cnVjdG9yLg0KCSAqDQoJICogQHBhcmFtICAgb2JqZWN0ICAmJHN1YmplY3QgIFRoZSBvYmplY3QgdG8gb2JzZXJ2ZSAtLSBldmVudCBkaXNwYXRjaGVyLg0KCSAqIEBwYXJhbSAgIG9iamVjdCAgJGNvbmZpZyAgICBBbiBvcHRpb25hbCBhc3NvY2lhdGl2ZSBhcnJheSBvZiBjb25maWd1cmF0aW9uIHNldHRpbmdzLg0KCSAqDQoJICogQHNpbmNlICAgMS42DQoJICovDQoJcHVibGljIGZ1bmN0aW9uIF9fY29uc3RydWN0KCRzdWJqZWN0LCAkY29uZmlnKQ0KCXsNCgkJcGFyZW50OjpfX2NvbnN0cnVjdCgkc3ViamVjdCwgJGNvbmZpZyk7IyMjUExVR0lOX1BPV0VSX0FVVE9MT0FERVIjIyMNCgl9', '[[[Component]]] Powers Autoloader', '', '', '', 'Ly8gV0hBVD8=', '', '', '', '1.0.1', '{\"property_selection0\":{\"property\":\"25\"},\"property_selection1\":{\"property\":\"27\"}}', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', '', 'Powers Autoloader', '', 1, '', '', 1, '2021-11-11 02:22:02', '2024-03-01 21:18:38', 16, '', 8),
(24, '', '', '', '', 1, '', '', '', '', '', '', '', '', 1, 'Add Access Token to easy update [[[Component]]]', '{}', '29ac30d2-1c1a-4b9e-9cfa-c5fcb08caa01', 'dXNlIEpvb21sYVxDTVNcQXBwbGljYXRpb25cQ01TQXBwbGljYXRpb247DQp1c2UgSm9vbWxhXENNU1xQbHVnaW5cQ01TUGx1Z2luOw==', 12, '{\"method_selection0\":{\"method\":\"103\"}}', 'CS8qKg0KCSAqIEFwcGxpY2F0aW9uIG9iamVjdA0KCSAqDQoJICogQHZhciAgICBDTVNBcHBsaWNhdGlvbg0KCSAqIEBzaW5jZSAgMS4wLjANCgkgKi8NCglwcm90ZWN0ZWQgICRhcHA7DQoNCgkvKioNCgkgKiBBZmZlY3RzIGNvbnN0cnVjdG9yIGJlaGF2aW9yLiBJZiB0cnVlLCBsYW5ndWFnZSBmaWxlcyB3aWxsIGJlIGxvYWRlZCBhdXRvbWF0aWNhbGx5Lg0KCSAqDQoJICogQHZhciAgICBib29sZWFuDQoJICogQHNpbmNlICAxLjAuMA0KCSAqLw0KCXByb3RlY3RlZCAgJGF1dG9sb2FkTGFuZ3VhZ2UgPSB0cnVlOw0KDQoJLyoqDQoJICogb25JbnN0YWxsZXJCZWZvcmVQYWNrYWdlRG93bmxvYWQuDQoJICoNCgkgKiBGb3IgbW9kaWZpY2F0aW9uIG9mIFVSTCBhbmQgaGVhZGVycyBiZWZvcmUgcGFja2FnZSBkb3dubG9hZA0KCSAqDQoJICogQHJldHVybiAgdm9pZA0KCSAqDQoJICogQHNpbmNlICAgMS4wDQoJICovDQoJcHVibGljIGZ1bmN0aW9uIG9uSW5zdGFsbGVyQmVmb3JlUGFja2FnZURvd25sb2FkKCYkdXJsLCAmJGhlYWRlcnMpDQoJew0KCQkvLyBzZXQgdGhlIFVSSSBvYmplY3QNCgkJJHVyaSA9IEpvb21sYV9fX2VlY2MxNDNlX2I1Y2ZfNGMzM19iYTRkXzk3ZGExZGY2MTQyMl9fX1Bvd2VyOjpnZXRJbnN0YW5jZSgkdXJsKTsNCgkJJHBhcnRzID0gZXhwbG9kZSgnLycsICR1cmktPmdldFBhdGgoKSk7DQoNCgkJLy8gY2hlY2sgdGhhdCB0aGlzIGlzIG91ciBBUEkNCgkJaWYgKCR1cmktPmdldEhvc3QoKSA9PSAnW1tbZ2l0ZWFfdXJsXV1dJyAmJiBpbl9hcnJheSgnW1tbZ2l0ZWFfcGFja2FnZV9uYW1lXV1dJywgJHBhcnRzKSkNCgkJew0KCQkJLy8gZ2V0IHRoZSB0b2tlbiBpZiBzZXQNCgkJCSR0b2tlbiA9IEpvb21sYV9fX2FlYjhlNDYzXzI5MWZfNDQ0NV85YWM0XzM0YjYzN2MxMmRiZF9fX1Bvd2VyOjpnZXRQYXJhbXMoJ2NvbV9bW1tjb21wb25lbnRdXV0nKS0+Z2V0KCdnaXRlYV90b2tlbicsIGZhbHNlKTsNCgkJCS8vIG9ubHkgYWRkIGlmIHRva2VuIGlzIHNldA0KCQkJaWYgKCR0b2tlbikNCgkJCXsNCgkJCQkvLyBhZGQgdGhlIHRva2VuDQoJCQkJJHVyaS0+c2V0VmFyKCdhY2Nlc3NfdG9rZW4nLCAkdG9rZW4pOw0KCQkJCS8vIHVwZGF0ZSB0aGUgVVJMDQoJCQkJJHVybCA9ICR1cmktPnRvU3RyaW5nKCk7DQoJCQl9DQoJCQllbHNlDQoJCQl7DQoJCQkJLy8gc2V0IHRoZSByZXR1cm4gVVJMDQoJCQkJJHJldHVybiA9IHVybGVuY29kZShiYXNlNjRfZW5jb2RlKChzdHJpbmcpIEpvb21sYV9fX2VlY2MxNDNlX2I1Y2ZfNGMzM19iYTRkXzk3ZGExZGY2MTQyMl9fX1Bvd2VyOjpnZXRJbnN0YW5jZSgpKSk7DQoJCQkJLy8gc2V0IHRoZSB1cmxzDQoJCQkJJGdldF9hY2Nlc3NfdG9rZW5fdXJsID0gJyJodHRwczovL1tbW2dpdGVhX3VybF1dXS91c2VyL3NldHRpbmdzL2FwcGxpY2F0aW9ucyIgdGFyZ2V0PSJfYmxhbmsiIHRpdGxlPSInIC4gVGV4dDo6XygnR2V0IEFjY2VzcyBUb2tlbicpIC4gJyInOw0KCQkJCSRzZXRfYWNjZXNzX3Rva2VuX3VybCA9ICciJyAuIEpvb21sYV9fX2VlY2MxNDNlX2I1Y2ZfNGMzM19iYTRkXzk3ZGExZGY2MTQyMl9fX1Bvd2VyOjpyb290KCkgLiAnYWRtaW5pc3RyYXRvci9pbmRleC5waHA/b3B0aW9uPWNvbV9jb25maWcmdmlldz1jb21wb25lbnQmY29tcG9uZW50PWNvbV9bW1tjb21wb25lbnRdXV0mcGF0aD0mcmV0dXJuPScgLiAkcmV0dXJuIC4gJyIgdGl0bGU9IicgLiBUZXh0OjpfKCdTZXQgQWNjZXNzIFRva2VuJykgLiAnIic7DQoJCQkJLy8gbG9hZCB0aGUgbWVzc2FnZQ0KCQkJCSR0aGlzLT5hcHAtPmVucXVldWVNZXNzYWdlKA0KCQkJCQlUZXh0OjpzcHJpbnRmKCJJZiB0aGVyZSB3YXMgYSBkb3dubG9hZC91cGRhdGUgZXJyb3IsIGl0J3MgcHJvYmFibHkgYmVjYXVzZSB0aGUgPGEgaHJlZj0lcyA+QVBJIEFjY2VzcyBUb2tlbjwvYT4gZm9yIHVwZGF0ZXMgb2YgW1tbY29tcG9uZW50XV1dIGhhcyBub3QgYmVlbiBzZXQsIHlvdSBjYW4gc2V0IHRoaXMgYWNjZXNzIHRva2VuIGluIHRoZSA8YSBocmVmPSVzID5nbG9iYWwgb3B0aW9ucyB0YWI8L2E+LiIsDQoJCQkJCQkkZ2V0X2FjY2Vzc190b2tlbl91cmwsDQoJCQkJCQkkc2V0X2FjY2Vzc190b2tlbl91cmwNCgkJCQkJKSwgJ25vdGljZScpOw0KCQkJfQ0KCQl9DQoJfQ0K', 'componentbuilder', '', '', '', 'Ly8gbmVlZHMgZml4', '', '', '', '1.0.2', '{\"property_selection0\":{\"property\":\"39\"},\"property_selection1\":{\"property\":\"37\"}}', 'WW91IGNhbiB1c2UgYWxsIHRoZSBub3JtYWwgbWFya2Rvd24sIGluY2x1ZGluZyB0aGUgcGxhY2UtaG9sZGVycy4=', '', '', '', 'Update (git.vdm.dev)', '', 1, '', '', 1, '2021-12-08 07:42:39', '2024-03-01 21:17:50', 17, '', 9),
(28, 1, '', '', '', 1, '', '', '', '', '', '', '', 1, 1, 'This plugin is used to load PreUpVer on your website. So it adds https://cdn.jsdelivr.net/gh/Llewellynvdm/PreUpVer@1.0.0/dist/js/preupver.min.js to the header of your website. See: https://git.vdm.dev/Llewellyn/PreUpVer for more details.', '{}', 'dd6580c4-6bbb-4d13-a868-0b38fbb6a66e', 'dXNlIEpvb21sYVxDTVNcUGx1Z2luXENNU1BsdWdpbjsNCnVzZSBKb29tbGFcQ01TXEh0bWxcSFRNTEhlbHBlcjsNCg==', 8, '{\"method_selection0\":{\"method\":\"122\"}}', 'CS8qKg0KCSAqIEFwcGxpY2F0aW9uIG9iamVjdA0KCSAqDQoJICogQHZhciAgICBDTVNBcHBsaWNhdGlvbg0KCSAqIEBzaW5jZSAgMS4wLjANCgkgKi8NCglwcm90ZWN0ZWQgICRhcHA7DQoNCgkvKioNCgkgKiBUaGlzIG1ldGhvZCBpcyBjYWxsZWQgYmVmb3JlIHRoZSBoZWFkIGlzIGNvbXBpbGVkIGFuZCBhbGxvd3MgbWFuaXB1bGF0aW9uIG9mIHRoZSBoZWFkIGRhdGEuDQoJICogSW4gdGhpcyBjYXNlLCBpdCdzIHVzZWQgdG8gYWRkIGEgSmF2YVNjcmlwdCBmaWxlIHRvIHRoZSBmcm9udCBlbmQgb2YgdGhlIEpvb21sYSBzaXRlLg0KCSAqDQoJICogQHJldHVybiAgdm9pZA0KCSAqDQoJICogQHNpbmNlICAgMy4wLjANCgkgKiBAdGhyb3dzICBFeGNlcHRpb24gb24gZXJyb3IuDQoJICovDQoJcHVibGljIGZ1bmN0aW9uIG9uQmVmb3JlQ29tcGlsZUhlYWQoKQ0KCXsNCgkJLy8gQ2hlY2sgaWYgd2UgYXJlIGluIHRoZSBzaXRlIGFwcGxpY2F0aW9uDQoJCWlmICgkdGhpcy0+YXBwLT5pc0NsaWVudCgnc2l0ZScpKSB7DQoJCQlIVE1MSGVscGVyOjpfKCdzY3JpcHQnLCAnaHR0cHM6Ly9jZG4uanNkZWxpdnIubmV0L2doL0xsZXdlbGx5bnZkbS9QcmVVcFZlckAxLjAuMC9kaXN0L2pzL3ByZXVwdmVyLm1pbi5qcycsIFsndmVyc2lvbicgPT4gJ2F1dG8nXSk7DQoJCX0NCgl9', 'PreUpVerLoader', '', '', '', 'CQkJJGp2ZXJzaW9uID0gbmV3IEpWZXJzaW9uKCk7DQoJCQlpZiAoISRqdmVyc2lvbi0+aXNDb21wYXRpYmxlKCczLjEwLjAnKSkgew0KCQkJCSRhcHAtPmVucXVldWVNZXNzYWdlKCdQbGVhc2UgdXBncmFkZSB0byBhdCBsZWFzdCBKb29tbGEhIDMuMTAgYmVmb3JlIGNvbnRpbnVpbmchJywgJ2Vycm9yJyk7DQoJCQkJcmV0dXJuIGZhbHNlOw0KCQkJfQ0K', '', '', '', '1.0.0', '{\"property_selection0\":{\"property\":\"25\"}}', 'IyBQcmVVcFZlciBMb2FkZXIgKFtbW3BsdWdpbi52ZXJzaW9uXV1dKQ0KDQojIyBJbnRyb2R1Y3Rpb24NCg0KUHJlVXBWZXIgaXMgYSB2ZXJzYXRpbGUgSmF2YVNjcmlwdCBsaWJyYXJ5IGRlc2lnbmVkIHRvIGF1dG9tYXRpY2FsbHkgdXBkYXRlIHRoZSB2ZXJzaW9uIG51bWJlcnMgb2YgbGlicmFyeSBzY3JpcHRzIGluIHlvdXIgZG9jdW1lbnRhdGlvbi4gSXQgaWRlbnRpZmllcyBzcGVjaWZpYyBgPHByZT5gIHRhZ3Mgb24geW91ciB3ZWJwYWdlIGFuZCB1cGRhdGVzIHRoZW0gd2l0aCB0aGUgbGF0ZXN0IHZlcnNpb24gdGFnIGZldGNoZWQgZnJvbSBhIHNwZWNpZmllZCByZXBvc2l0b3J5LCBlbnN1cmluZyB5b3VyIGRvY3VtZW50YXRpb24gYWx3YXlzIGRpc3BsYXlzIHVwLXRvLWRhdGUgaW5mb3JtYXRpb24uDQoNCiMjIEhvdyBJdCBXb3Jrcw0KDQpQcmVVcFZlciBvcGVyYXRlcyBieSBzZWFyY2hpbmcgZm9yIGA8cHJlPmAgdGFncyB3aXRoIGEgZGVzaWduYXRlZCBjbGFzcyAoYHByZXVwdmVyYCkgYW5kIHVzaW5nIHRoZWlyIGRhdGEgYXR0cmlidXRlcyB0byBwZXJmb3JtIHZlcnNpb24gdXBkYXRlcy4gSXQgc2ltcGxpZmllcyB0aGUgcHJvY2VzcyBvZiBrZWVwaW5nIHlvdXIgbGlicmFyeSByZWZlcmVuY2VzIHVwLXRvLWRhdGUgaW4gZG9jdW1lbnRhdGlvbi4NCg0KIyMjIEF1dG9tYXRpYyBEZXRlY3Rpb24gYW5kIFVwZGF0aW5nDQoNCldoZW4gdGhlIHdlYnBhZ2UgbG9hZHMsIFByZVVwVmVyIGZpbmRzIGFsbCBgPHByZT5gIHRhZ3MgbWFya2VkIHdpdGggdGhlIGBwcmV1cHZlcmAgY2xhc3MuIEl0IHRoZW4gZXh0cmFjdHMgbmVjZXNzYXJ5IGRldGFpbHMgZnJvbSB0aGVpciBkYXRhIGF0dHJpYnV0ZXMgYW5kIHVwZGF0ZXMgZWFjaCB0YWcgd2l0aCB0aGUgbGF0ZXN0IGxpYnJhcnkgdmVyc2lvbi4NCg0KIyMjIFVzYWdlDQoNCjEuICoqTWFya2luZyBgPHByZT5gIFRhZ3M6KioNCg0KICAgQWRkIHRoZSBgY2xhc3M9InByZXVwdmVyImAgdG8gYDxwcmU+YCB0YWdzIGluIHlvdXIgSFRNTCBhbmQgZGVmaW5lIHRoZSByZXF1aXJlZCBkYXRhIGF0dHJpYnV0ZXMgZm9yIGF1dG9tYXRpYyB1cGRhdGluZzoNCg0KICAgYGBgaHRtbA0KICAgPHByZSBpZD0idW5pcXVlLWlkIiBjbGFzcz0icHJldXB2ZXIiDQogICAgICAgIGRhdGEtYXBpLXVybD0iaHR0cHM6Ly9hcGkuZ2l0aHViLmNvbS9yZXBvcy91c2VybmFtZS9saWJyYXJ5L3RhZ3MiDQogICAgICAgIGRhdGEtZGVzY3JpcHRpb249IkRlc2NyaXB0aW9uIG9mIHRoZSBsaWJyYXJ5IHNjcmlwdCINCiAgICAgICAgZGF0YS11cmw9Imh0dHBzOi8vY2RuLmpzZGVsaXZyLm5ldC9naC91c2VybmFtZS9saWJyYXJ5QCR7dmVyc2lvbn0vZGlzdC9saWJyYXJ5Lm1pbi5qcyI+DQogICA8L3ByZT4NCiAgIGBgYA0KDQogICBSZXBsYWNlIGB1bmlxdWUtaWRgLCBgdXNlcm5hbWVgLCBgbGlicmFyeWAsIGFuZCBvdGhlciBwbGFjZWhvbGRlcnMgd2l0aCB5b3VyIHNwZWNpZmljIGRldGFpbHMuDQoNCjIuICoqQXR0cmlidXRlcyBFeHBsYWluZWQ6KioNCg0KICAgLSBgaWRgOiBBIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgYDxwcmU+YCB0YWcuDQogICAtIGBkYXRhLWFwaS11cmxgOiBUaGUgQVBJIFVSTCB0byBmZXRjaCB0aGUgbGF0ZXN0IGxpYnJhcnkgdmVyc2lvbi4NCiAgIC0gYGRhdGEtZGVzY3JpcHRpb25gOiBBIGJyaWVmIGRlc2NyaXB0aW9uIG9mIHRoZSBsaWJyYXJ5IHNjcmlwdC4NCiAgIC0gYGRhdGEtdXJsYDogVGhlIFVSTCBvZiB0aGUgc2NyaXB0LCB3aGVyZSBgJHt2ZXJzaW9ufWAgd2lsbCBiZSByZXBsYWNlZCB3aXRoIHRoZSBsYXRlc3QgdmVyc2lvbiBudW1iZXIuDQoNCiMjIyBFeGFtcGxlDQoNCkNoZWNrIG91dCB0aGUgW3Rlc3RzXShodHRwczovL2dpdC52ZG0uZGV2L0xsZXdlbGx5bi9QcmVVcFZlci9zcmMvYnJhbmNoL21hc3Rlci90ZXN0cy8pIGZvbGRlciBmb3IgdGhlIGV4YW1wbGVzIHdlIHVzZSB0byB0ZXN0IGlmIHRoaXMgbGlicmFyeSB3b3JrcyBhcyBleHBlY3RlZC4NCg0KIyBCdWlsZCBEZXRhaWxzDQoNCisgKkF1dGhvcio6IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8pDQorICpOYW1lKjogW1ByZVVwVmVyIExvYWRlcl0oaHR0cHM6Ly9naXQudmRtLmRldi9MbGV3ZWxseW4vUHJlVXBWZXIpDQorICpGaXJzdCBCdWlsZCo6ICMjI0NSRUFUSU9OREFURSMjIw0KKyAqTGFzdCBCdWlsZCo6ICMjI0JVSUxEREFURSMjIw0KKyAqVmVyc2lvbio6IFtbW3BsdWdpbi52ZXJzaW9uXV1dDQorICpDb3B5cmlnaHQqOiAjIyNDT1BZUklHSFQjIyMNCisgKkxpY2Vuc2UqOiAjIyNMSUNFTlNFIyMjDQoNCj4gVGhpcyAqKnBsdWdpbioqIHdhcyBidWlsZCB3aXRoIGEgSm9vbWxhIFtBdXRvbWF0ZWQgQ29tcG9uZW50IEJ1aWxkZXJdKGh0dHBzOi8vd3d3Lmpvb21sYWNvbXBvbmVudGJ1aWxkZXIuY29tKS4NCj4gRGV2ZWxvcGVkIGJ5IFtMbGV3ZWxseW4gdmFuIGRlciBNZXJ3ZV0obWFpbHRvOmpvb21sYUB2ZG0uaW8p', '', '', '', 'PreUpVer Loader', '', 1, '', '', 1, '2023-11-28 09:01:02', '2023-11-28 11:27:32', 5, '', 2);
--
-- Dumping data for table `#__componentbuilder_joomla_power`
--
INSERT INTO `#__componentbuilder_joomla_power` (`id`, `description`, `guid`, `settings`, `system_name`, `params`, `published`, `created`, `modified`, `version`, `hits`, `access`, `ordering`) VALUES
(1, 'The Joomla Factory class', '39403062-84fb-46e0-bac4-0023f766e827', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Factory\",\"joomla_version\":\"0\"}}', 'JFactory', '', 1, '2024-04-09 15:00:24', '0000-00-00 00:00:00', 1, '', 1, 1),
(2, 'The core Joomla Text class.', 'ba6326ef-cb79-4348-80f4-ab086082e3c5', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Language\\\\Text\",\"joomla_version\":\"0\"}}', 'JText', '', 1, '2024-04-09 15:01:16', '0000-00-00 00:00:00', 1, '', 1, 2),
(3, 'The Joomla core component helper class.', 'aeb8e463-291f-4445-9ac4-34b637c12dbd', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Component\\\\ComponentHelper\",\"joomla_version\":\"0\"}}', 'JComponentHelper', '', 1, '2024-04-09 15:02:09', '0000-00-00 00:00:00', 1, '', 1, 3),
(4, 'The Joomla core session class.', '5ba38513-5c4f-4b0d-935e-49e986a6bce8', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Session\\\\Session\",\"joomla_version\":\"0\"}}', 'JSession', '', 1, '2024-04-09 15:03:18', '0000-00-00 00:00:00', 1, '', 1, 4),
(5, 'The Joomla core uri class.', 'eecc143e-b5cf-4c33-ba4d-97da1df61422', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Uri\\\\Uri\",\"joomla_version\":\"0\"}}', 'JUri', '', 1, '2024-04-09 15:04:32', '0000-00-00 00:00:00', 1, '', 1, 5),
(6, 'HTTP client class.', '8417ac0e-2abd-4452-91fd-4ca6493d55f2', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Http\\\\Http\",\"joomla_version\":\"0\"}}', 'JHttp', '', 1, '2024-04-27 11:59:57', '0000-00-00 00:00:00', 1, '', 1, 6),
(7, 'Route handling class', 'd4c76099-4c32-408a-8701-d0a724484dfd', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Router\\\\Route\",\"joomla_version\":\"0\"}}', 'JRoute', '', 1, '2024-04-27 12:01:46', '0000-00-00 00:00:00', 1, '', 1, 7),
(8, 'Class to create and parse routes', '4efa4c21-5114-472a-b1f8-48aa9bd14900', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Router\\\\Router\",\"joomla_version\":\"0\"}}', 'JRouter', '', 1, '2024-04-27 12:02:16', '0000-00-00 00:00:00', 1, '', 1, 7),
(9, 'This is an abstracted input class used to manage retrieving data from the application environment.', '59106b64-dd51-4280-be0a-1b9b9ebb7161', '{\"settings0\":{\"namespace\":\"Joomla\\\\Input\\\\Input\",\"joomla_version\":\"0\"}}', 'JInput', '', 1, '2024-04-27 12:04:55', '0000-00-00 00:00:00', 1, '', 1, 8),
(10, 'Helper to render a Layout object, storing a base path', '7ab82272-0b3d-4bb1-af35-e63a096cfe0b', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Layout\\\\LayoutHelper\",\"joomla_version\":\"0\"}}', 'JLayoutHelper', '', 1, '2024-04-27 12:06:33', '0000-00-00 00:00:00', 1, '', 1, 9),
(11, 'Utility class for all HTML drawing classes', '34690c75-1090-47eb-8c06-7228dc7eedd6', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\HTML\\\\HTMLHelper\",\"joomla_version\":\"0\"}}', 'JHtml', '', 1, '2024-04-27 12:07:27', '0000-00-00 00:00:00', 1, '', 1, 10),
(12, 'Class that handles all access authorisation routines.', '2d513d69-8c7c-4dab-bb84-c5ecafb91a9d', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Access\\\\Access\",\"joomla_version\":\"0\"}}', 'JAccess', '', 1, '2024-04-27 12:56:41', '0000-00-00 00:00:00', 1, '', 1, 11),
(13, 'Access rules class.', '80425d73-1789-4f59-b49d-1a712611a77a', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Access\\\\Rules\",\"joomla_version\":\"0\"}}', 'JRules', '', 1, '2024-04-27 12:57:12', '0000-00-00 00:00:00', 1, '', 1, 11),
(14, 'Rule class.', 'b07d4be5-bbbe-48c9-a2ab-843090a1c0de', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Access\\\\Rule\",\"joomla_version\":\"0\"}}', 'JRule', '', 1, '2024-04-27 12:57:34', '0000-00-00 00:00:00', 1, '', 1, 11),
(15, 'JDate is a class that stores a date and provides logic to manipulate and render that date in a variety of formats.', '3864fa33-ab10-48d5-98ea-5e1397e6a191', '{\"settings0\":{\"namespace\":\"Joomla\\\\CMS\\\\Date\\\\Date\",\"joomla_version\":\"0\"}}', 'JDate', '', 1, '2024-04-27 12:58:11', '0000-00-00 00:00:00', 1, '', 1, 11);
--
-- Dumping data for table `#__componentbuilder_admin_view`
--
INSERT INTO `#__componentbuilder_admin_view` (`id`, `add_css_view`, `add_css_views`, `add_custom_button`, `add_custom_import`, `add_fadein`, `add_javascript_view_file`, `add_javascript_view_footer`, `add_javascript_views_file`, `add_javascript_views_footer`, `add_php_ajax`, `add_php_allowedit`, `add_php_batchcopy`, `add_php_batchmove`, `add_php_getitem`, `add_php_getitems`, `add_php_getitems_after_all`, `add_php_getlistquery`, `add_php_postsavehook`, `add_php_save`, `add_sql`, `addlinked_views`, `addpermissions`, `addtables`, `addtabs`, `add_php_before_delete`, `add_php_before_publish`, `add_php_document`, `add_php_after_delete`, `add_php_after_publish`, `php_before_delete`, `php_before_publish`, `php_controller`, `php_document`, `php_after_delete`, `php_after_publish`, `ajax_input`, `css_view`, `css_views`, `custom_button`, `description`, `html_import_view`, `icon`, `icon_add`, `icon_category`, `javascript_view_file`, `javascript_view_footer`, `javascript_views_file`, `javascript_views_footer`, `name_list`, `system_name`, `name_single`, `php_ajaxmethod`, `php_allowedit`, `php_batchcopy`, `php_batchmove`, `php_getitem`, `php_getitems`, `php_getitems_after_all`, `php_getlistquery`, `php_import`, `php_import_display`, `php_import_save`, `php_import_setdata`, `php_model`, `php_postsavehook`, `php_save`, `short_description`, `source`, `sql`, `type`, `php_before_save`, `php_controller_list`, `php_getform`, `php_after_cancel`, `php_allowadd`, `php_before_cancel`, `php_import_ext`, `php_import_headers`, `php_model_list`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `guid`) VALUES
(109, '', '', '', '', 1, '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '{}', '{\"addpermissions0\":{\"action\":\"view.edit\",\"implementation\":3},\"addpermissions1\":{\"action\":\"view.edit.own\",\"implementation\":3},\"addpermissions2\":{\"action\":\"view.edit.state\",\"implementation\":3},\"addpermissions3\":{\"action\":\"view.edit.created_by\",\"implementation\":3},\"addpermissions4\":{\"action\":\"view.edit.created\",\"implementation\":3},\"addpermissions5\":{\"action\":\"view.create\",\"implementation\":3},\"addpermissions6\":{\"action\":\"view.delete\",\"implementation\":3},\"addpermissions7\":{\"action\":\"view.access\",\"implementation\":3}}', '{}', '{\"addtabs0\":{\"name\":\"Details\"},\"addtabs1\":{\"name\":\"More\"}}', '', '', '', '', '', '', '', '', '', '', '', '{}', '', '', '{}', '', '', 'images/WoodMannequin-icon.png', 'images/WoodMannequin-icon-plus.png', '', '', '', '', '', 'Looks', 'Look', 'Look', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', 'The demo view', '', '', 1, '', '', '', '', '', '', '', '', '', '{\"fieldordering\":{\"add_admin_ordering\":\"0\",\"admin_ordering_fields\":{\"admin_ordering_fields0\":{\"field\":\"\",\"direction\":\"ASC\"}},\"add_linked_ordering\":\"0\",\"linked_ordering_fields\":{\"linked_ordering_fields0\":{\"field\":\"\",\"direction\":\"ASC\"}}},\"privacy\":{\"activate\":\"1\",\"permissions\":\"1\",\"anonymize\":\"0\",\"anonymize_fields\":[],\"user_link\":\"1\",\"custom_link\":\"$query->where($db->quoteName(\'created_by\') . \' = \' . $db->quote($user->id));\",\"other_user_field\":\"682\"}}', 1, '2016-10-18 11:44:46', '2020-05-21 14:39:27', 18, '', 110, 'c1053952-8a84-4398-aef1-41726f7c0043');
--
-- Dumping data for table `#__componentbuilder_site_view`
--
INSERT INTO `#__componentbuilder_site_view` (`id`, `add_css_document`, `add_css`, `add_js_document`, `add_php_document`, `add_php_jview`, `add_php_jview_display`, `add_php_view`, `add_php_ajax`, `add_custom_button`, `custom_button`, `button_position`, `php_controller`, `php_model`, `ajax_input`, `php_ajaxmethod`, `codename`, `css_document`, `css`, `custom_get`, `default`, `description`, `dynamic_get`, `js_document`, `main_get`, `name`, `system_name`, `php_document`, `php_jview`, `php_jview_display`, `php_view`, `snippet`, `params`, `javascript_file`, `libraries`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `guid`) VALUES
(23, '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', 'looks', '', '', '', 'PHRhYmxlIGNsYXNzPSJ1ay10YWJsZSB1ay10YWJsZS1ob3ZlciI+DQogICAgPGNhcHRpb24+PD9waHAgZWNobyBUZXh0OjpfKCdMaXN0IG9mIGFsbCBsb29rcycpOyA/PjwvY2FwdGlvbj4NCiAgICA8dGhlYWQ+DQogICAgICAgIDx0cj4NCiAgICAgICAgICAgIDx0aD48P3BocCBlY2hvIFRleHQ6Ol8oJ05hbWUnKTsgPz48L3RoPg0KICAgICAgICAgICAgPHRoPjw/cGhwIGVjaG8gVGV4dDo6XygnRGVzY3JpcHRpb24nKTsgPz48L3RoPg0KICAgICAgICA8L3RyPg0KICAgIDwvdGhlYWQ+DQogICAgPHRib2R5Pg0KICAgICAgICA8P3BocCBmb3JlYWNoICgkdGhpcy0+aXRlbXMgYXMgJGl0ZW0pOiA/Pg0KICAgICAgICA8dHI+DQogICAgICAgICAgICA8dGQ+PGEgaHJlZj0iPD9waHAgZWNobyAgW1tbQ29tcG9uZW50XV1dSGVscGVyUm91dGU6OmdldExvb2tpbmdSb3V0ZSgkaXRlbS0+c2x1Zyk7ID8+IiA+PD9waHAgZWNobyAkaXRlbS0+bmFtZTsgPz48L2E+PC90ZD4NCiAgICAgICAgICAgIDx0ZD48P3BocCBlY2hvICR0aGlzLT5lc2NhcGUoJGl0ZW0tPmRlc2NyaXB0aW9uLCB0cnVlLCAxMjApOyA/Pjw/cGhwIGVjaG8gJGl0ZW0tPmVkaXRMaW5rOyA/PjwvdGQ+DQogICAgICAgIDwvdHI+DQogICAgICAgIDw/cGhwIGVuZGZvcmVhY2g7ID8+DQogICAgPC90Ym9keT4NCjwvdGFibGU+', 'The List of all published looks', 36, '', 36, 'Looks', 'Looks', '', '', '', '', '', '', '', '', 1, '2016-04-05 14:31:59', '2016-10-20 15:57:24', 9, '', 14, 'b2dce59e-e3b8-4467-bcb5-8f2df4bdfeb7'),
(25, '', '', '', '', 1, 1, '', '', '', '', 1, '', '', '', '', 'looking', '', '', '', 'PGFydGljbGUgY2xhc3M9InVrLWNvbW1lbnQiPg0KICAgIDxoZWFkZXIgY2xhc3M9InVrLWNvbW1lbnQtaGVhZGVyIj4NCiAgICAgICAgPGltZyBjbGFzcz0idWstY29tbWVudC1hdmF0YXIiIHNyYz0ie2ltYWdldXJsfSIgYWx0PSIiPg0KICAgICAgICA8aDQgY2xhc3M9InVrLWNvbW1lbnQtdGl0bGUiPjw/cGhwIGVjaG8gJHRoaXMtPmVzY2FwZSgkdGhpcy0+aXRlbS0+bmFtZSk7ID8+PC9oND4NCiAgICAgICAgPGRpdiBjbGFzcz0idWstY29tbWVudC1tZXRhIj48P3BocCBlY2hvIFRleHQ6Ol8oJ0hpdHMnKTsgPz46IDw/cGhwIGVjaG8gJHRoaXMtPml0ZW0tPmhpdHM7ID8+PC9kaXY+DQogICAgPC9oZWFkZXI+DQogICAgPGRpdiBjbGFzcz0idWstY29tbWVudC1ib2R5Ij4NCiAgICAgICAgPD9waHAgZWNobyAkdGhpcy0+aXRlbS0+ZGVzY3JpcHRpb247ID8+DQogICAgICAgIDw/cGhwIGlmICgkdGhpcy0+aXRlbS0+YWRkKTogPz4NCiAgICAgICAgICAgIDxiciAvPg0KICAgICAgICAgICAgPCEtLSBUaGlzIGlzIGEgYnV0dG9uIHRvZ2dsaW5nIHRoZSBtb2RhbCAtLT4NCiAgICAgICAgICAgIDxidXR0b24gY2xhc3M9InVrLWJ1dHRvbiIgZGF0YS11ay1tb2RhbD0ie3RhcmdldDonI21vcmUtZGV0YWlscy0wOTAnfSI+PD9waHAgZWNobyBUZXh0OjpfKCdNb3JlIERldGFpbHMnKTsgPz48L2J1dHRvbj4NCiAgICAgICAgPD9waHAgZW5kaWY7ID8+DQogICAgPC9kaXY+DQo8L2FydGljbGU+DQo8P3BocCBpZiAoJHRoaXMtPml0ZW0tPmFkZCk6ID8+DQo8IS0tIFRoaXMgaXMgdGhlIG1vZGFsIC0tPg0KPGRpdiBpZD0ibW9yZS1kZXRhaWxzLTA5MCIgY2xhc3M9InVrLW1vZGFsIj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay1tb2RhbC1kaWFsb2ciPg0KICAgICAgICA8YSBjbGFzcz0idWstbW9kYWwtY2xvc2UgdWstY2xvc2UiPjwvYT4NCiAgICAgICAgPGRsIGNsYXNzPSJ1ay1kZXNjcmlwdGlvbi1saXN0LWhvcml6b250YWwiPg0KICAgICAgICA8P3BocCBpZiAoU3VwZXJfX18xZjI4Y2I1M182MGQ5XzRkYjFfYjUxN18zYzdkYzZiNDI5ZWZfX19Qb3dlcjo6Y2hlY2soJHRoaXMtPml0ZW0tPmRhdGVvZmJpcnRoKSk6ID8+DQogICAgICAgICAgICA8ZHQ+PD9waHAgZWNobyBUZXh0OjpfKCdCaXJ0aCBkYXknKTsgPz48L2R0PjxkZD48P3BocCBlY2hvIFtbW0NvbXBvbmVudF1dXUhlbHBlcjo6ZmFuY3lEYXRlKCR0aGlzLT5lc2NhcGUoJHRoaXMtPml0ZW0tPmRhdGVvZmJpcnRoKSk7ID8+PC9kZD4NCiAgICAgICAgPD9waHAgZW5kaWY7ID8+DQogICAgICAgIDw/cGhwIGlmIChTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkdGhpcy0+aXRlbS0+ZW1haWwpKTogPz4NCiAgICAgICAgICAgIDxkdD48P3BocCBlY2hvIFRleHQ6Ol8oJ0VtYWlsJyk7ID8+PC9kdD48ZGQ+PD9waHAgZWNobyAkdGhpcy0+ZXNjYXBlKCR0aGlzLT5pdGVtLT5lbWFpbCk7ID8+PC9kZD4NCiAgICAgICAgPD9waHAgZW5kaWY7ID8+DQogICAgICAgIDw/cGhwIGlmIChTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkdGhpcy0+aXRlbS0+bW9iaWxlX3Bob25lKSk6ID8+DQogICAgICAgICAgICA8ZHQ+PD9waHAgZWNobyBUZXh0OjpfKCdNb2JpbGUnKTsgPz48L2R0PjxkZD48P3BocCBlY2hvICR0aGlzLT5lc2NhcGUoJHRoaXMtPml0ZW0tPm1vYmlsZV9waG9uZSk7ID8+PC9kZD4NCiAgICAgICAgPD9waHAgZW5kaWY7ID8+DQogICAgICAgIDw/cGhwIGlmIChTdXBlcl9fXzFmMjhjYjUzXzYwZDlfNGRiMV9iNTE3XzNjN2RjNmI0MjllZl9fX1Bvd2VyOjpjaGVjaygkdGhpcy0+aXRlbS0+d2Vic2l0ZSkpOiA/Pg0KICAgICAgICAgICAgPGR0Pjw/cGhwIGVjaG8gVGV4dDo6XygnV2Vic2l0ZScpOyA/PjwvZHQ+PGRkPjw/cGhwIGVjaG8gJHRoaXMtPmVzY2FwZSgkdGhpcy0+aXRlbS0+d2Vic2l0ZSk7ID8+PC9kZD4NCiAgICAgICAgPD9waHAgZW5kaWY7ID8+DQogICAgICAgIDwvZGw+DQogICAgPC9kaXY+DQo8L2Rpdj4NCjw/cGhwIGVuZGlmOyA/Pg==', 'Looking at a look', 39, '', 39, 'Looking', 'Looking', '', 'CSAvKioNCgkgKiBJbmNyZW1lbnQgdGhlIGhpdCBjb3VudGVyIGZvciB0aGUgcHJlYWNoZXIuDQoJICoNCgkgKiBAcGFyYW0gICBpbnRlZ2VyICAkcGsgIFByaW1hcnkga2V5IG9mIHRoZSBwcmVhY2hlciB0byBpbmNyZW1lbnQuDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICBUcnVlIGlmIHN1Y2Nlc3NmdWw7DQoJICovDQoJcHVibGljIGZ1bmN0aW9uIGhpdCgkcGsgPSAwKQ0KCXsNCgkJaWYgKCRwaykNCgkJew0KCQkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCQkkcXVlcnkgPSAkZGItPmdldFF1ZXJ5KHRydWUpOw0KDQoJCQkvLyBGaWVsZHMgdG8gdXBkYXRlLg0KCQkJJGZpZWxkcyA9IGFycmF5KA0KCQkJICAgICRkYi0+cXVvdGVOYW1lKCdoaXRzJykgLiAnID0gJy4kZGItPnF1b3RlTmFtZSgnaGl0cycpLicgKyAxJw0KCQkJKTsNCg0KCQkJLy8gQ29uZGl0aW9ucyBmb3Igd2hpY2ggcmVjb3JkcyBzaG91bGQgYmUgdXBkYXRlZC4NCgkJCSRjb25kaXRpb25zID0gYXJyYXkoDQoJCQkgICAgJGRiLT5xdW90ZU5hbWUoJ2lkJykgLiAnID0gJyAuICRwaw0KCQkJKTsNCg0KCQkJJHF1ZXJ5LT51cGRhdGUoJGRiLT5xdW90ZU5hbWUoJyNfX1tbW2NvbXBvbmVudF1dXV9sb29rJykpLT5zZXQoJGZpZWxkcyktPndoZXJlKCRjb25kaXRpb25zKTsNCg0KCQkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkJcmV0dXJuICRkYi0+ZXhlY3V0ZSgpOw0KCQl9DQoJCXJldHVybiBmYWxzZTsNCgl9', 'Ly8gYWRkIGEgaGl0IHRvIHRoZSBsb29rDQppZiAoJHRoaXMtPmhpdCgkdGhpcy0+aXRlbS0+aWQpKQ0Kew0KCSR0aGlzLT5pdGVtLT5oaXRzKys7DQp9', '', '', '', '', '', 1, '2016-10-20 15:11:29', '2016-10-20 17:10:58', 16, '', 14, '851ed44e-5431-4951-876f-4b62a4c56ad2');
--
-- Dumping data for table `#__componentbuilder_dynamic_get`
--
INSERT INTO `#__componentbuilder_dynamic_get` (`id`, `add_php_after_getitem`, `add_php_before_getitem`, `add_php_after_getitems`, `add_php_before_getitems`, `add_php_getlistquery`, `php_after_getitem`, `php_before_getitem`, `php_before_getitems`, `php_getlistquery`, `php_after_getitems`, `pagination`, `addcalculation`, `db_selection`, `db_table_main`, `filter`, `getcustom`, `gettype`, `global`, `join_db_table`, `join_view_table`, `main_source`, `name`, `order`, `php_calculation`, `php_custom_get`, `view_selection`, `view_table_main`, `where`, `php_router_parse`, `group`, `params`, `published`, `version`, `hits`, `ordering`, `guid`) VALUES
(36, '', '', 1, '', '', '', '', '', '', 'CQkvLyBkbyBhIHF1aWNrIGJ1aWxkIG9mIGFsbCBlZGl0IGxpbmtzIGxpbmtzDQoJCWlmIChpc3NldCgkaXRlbXMpICYmICRpdGVtcykNCgkJew0KCQkJZm9yZWFjaCAoJGl0ZW1zIGFzICRuciA9PiAmJGl0ZW0pDQoJCQl7DQoJCQkJJGNhbkRvID0gW1tbQ29tcG9uZW50XV1dSGVscGVyOjpnZXRBY3Rpb25zKCdsb29rJywkaXRlbSwnbG9va3MnKTsNCgkJCQlpZiAoJGNhbkRvLT5nZXQoJ2xvb2suZWRpdCcpKQ0KCQkJCXsNCgkJCQkJJGl0ZW0tPmVkaXRMaW5rID0gJzxiciAvPjxiciAvPjxhIGNsYXNzPSJ1ay1idXR0b24gdWstYnV0dG9uLXByaW1hcnkgdWstd2lkdGgtMS0xIiBocmVmPSInOw0KCQkJCQkkaXRlbS0+ZWRpdExpbmsgLj0gSm9vbWxhX19fZDRjNzYwOTlfNGMzMl80MDhhXzg3MDFfZDBhNzI0NDg0ZGZkX19fUG93ZXI6Ol8oJ2luZGV4LnBocD9vcHRpb249Y29tX1tbW2NvbXBvbmVudF1dXSZ2aWV3PWxvb2smdGFzaz1sb29rLmVkaXQmaWQ9JyAuICRpdGVtLT5pZCk7DQoJCQkJCSRpdGVtLT5lZGl0TGluayAuPSAnIj48aSBjbGFzcz0idWstaWNvbi1wZW5jaWwiPjwvaT48c3BhbiBjbGFzcz0idWstaGlkZGVuLXNtYWxsIj4nOw0KCQkJCQkkaXRlbS0+ZWRpdExpbmsgLj0gVGV4dDo6XygnRWRpdCBMb29rJyk7DQoJCQkJCSRpdGVtLT5lZGl0TGluayAuPSAnPC9zcGFuPjwvYT4nOw0KCQkJCX0NCgkJCQllbHNlDQoJCQkJew0KCQkJCQkkaXRlbS0+ZWRpdExpbmsgPSAnJzsNCgkJCQl9DQoJCQl9DQoJCX0=', 1, '', '', '', '', '', 2, '', '', '', 1, 'Looks', '{\"order0\":{\"table_key\":\"a.name\",\"direction\":\"ASC\"}}', '', '', 'a.*', 109, '{\"where0\":{\"table_key\":\"a.published\",\"operator\":\"1\",\"value_key\":\"1\"}}', '', '', '', 1, 12, '', 13, '32b3ae7d-8aa8-47f1-ab2e-30076ddaa029'),
(39, '', '', '', '', '', '', '', '', '', '', 1, '', '', '', '{\"filter0\":{\"filter_type\":\"1\",\"state_key\":\"id\",\"operator\":\"1\",\"table_key\":\"a.id\"}}', '', 1, '', '', '', 1, 'Looking', '', '', '', 'a.id AS id\r\na.name AS name\r\na.alias AS alias\r\na.description AS description\r\na.add AS add\r\na.email AS email\r\na.mobile_phone AS mobile_phone\r\na.dateofbirth AS dateofbirth\r\na.image AS image\r\na.website AS website\r\na.published AS published\r\na.hits AS hits\r\na.created_by AS created_by', 109, '', '', '', '', 1, 8, '', '', '98e6ea56-0911-4d89-b1f4-8f0bb1e4aa5a');
--
-- Dumping data for table `#__componentbuilder_library`
--
INSERT INTO `#__componentbuilder_library` (`id`, `addconditions`, `description`, `type`, `how`, `name`, `php_setdocument`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `libraries`, `params`, `guid`) VALUES
(1, '', '', 1, '', 'No Library', '', 1, '2017-11-11 22:08:33', '2017-12-08 15:51:34', 4, '', 1, '', '', 'bc8e675d-7536-4a68-b186-fb4b988fa3e2'),
(2, '', '', 1, 1, 'Bootstrap v4', '', 1, '2017-11-12 02:08:39', '2017-12-17 09:04:10', 18, '', 2, '', '', '6f6650a5-ebff-4783-8508-f0285c0e98a6'),
(3, '{}', '', 1, 1, 'Uikit v3', '', 1, '2017-11-11 22:08:45', '2021-05-27 00:18:36', 20, '', 3, '', '', '5eeee148-cebd-4a92-bc0e-56efea3cffdc'),
(4, '', '', 1, 4, 'Uikit v2', '', 1, '2017-11-11 22:08:51', '2018-06-29 02:36:17', 6, '', 4, '', '', '367fbf66-890e-42a7-a82d-f780d2f86786'),
(5, '', '', 1, 4, 'FooTable v2', '', 1, '2017-11-11 22:08:57', '2017-12-11 20:07:32', 9, '', 5, '', '', 'a90edd5a-8521-4fb1-b6b3-9a21e9f56642'),
(6, '', '', 1, 4, 'FooTable v3', '', 1, '2017-11-25 22:11:03', '2017-12-10 15:54:45', 12, '', 6, '', '', '86829029-dc8a-424e-b046-b189a92565d9');
--
-- Dumping data for table `#__componentbuilder_snippet`
--
INSERT INTO `#__componentbuilder_snippet` (`id`, `contributor_company`, `contributor_email`, `contributor_name`, `contributor_website`, `description`, `heading`, `library`, `name`, `snippet`, `type`, `url`, `usage`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `guid`) VALUES
(1, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The grid system of UIkit follows the mobile-first approach and accomodates up to 10 grid columns. It uses units with predefined classes inside each grid, which define the column width. It is also possible to combine the grid with classes from the Flex component, although it works only in modern browsers.', 'Create a fully responsive, fluid and nestable grid layout.', 4, 'Grid', 'PGRpdiBkYXRhLXVrLWdyaWQtbWFyZ2luPSIiIGNsYXNzPSJ0bS1ncmlkLXRydW5jYXRlIHVrLWdyaWQgdWstZ3JpZC1kaXZpZGVyIHVrLXRleHQtY2VudGVyIj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay13aWR0aC1tZWRpdW0tMS0zIj4NCiAgICAJPGRpdiBjbGFzcz0idWstcGFuZWwgdWstcGFuZWwtYm94Ij4NCiAgICAgICAgCXtjb250ZW50fQ0KICAgICAgICA8L2Rpdj4NCiAgICA8L2Rpdj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay13aWR0aC1tZWRpdW0tMS0zIj4NCiAgICAJPGRpdiBjbGFzcz0idWstcGFuZWwgdWstcGFuZWwtYm94Ij4NCiAgICAgICAgCXtjb250ZW50fQ0KICAgICAgICA8L2Rpdj4NCiAgICA8L2Rpdj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay13aWR0aC1tZWRpdW0tMS0zIj4NCiAgICAJPGRpdiBjbGFzcz0idWstcGFuZWwgdWstcGFuZWwtYm94Ij4NCiAgICAgICAgCXtjb250ZW50fQ0KICAgICAgICA8L2Rpdj4NCiAgICA8L2Rpdj4NCjwvZGl2Pg==', 1, 'http://getuikit.com/docs/grid.html', 'To create the grid container, add the .uk-grid class to a parent element. Add one of the .uk-width-* classes to child elements to determine, how the units shall be sized. The grid supports 1, 2, 3, 4, 5, 6 and 10 unit divisions. This table gives you an overview of the uk-width-* classes that can be applied to units.', '', 1, '2015-05-19 17:18:32', '2017-11-11 22:09:27', 77, '', 1, 'fba0aa3f-03e4-49e7-92b6-9d5e98f66967'),
(2, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'UIkit uses panels to outline certain sections of your content, which can be styled differently. Typically, panels are arranged in grid columns from the Grid component.', 'Create layout boxes with different styles.', 4, 'Panel', 'PGRpdiBkYXRhLXVrLWdyaWQtbWFyZ2luPSIiIGNsYXNzPSJ1ay1ncmlkIj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay13aWR0aC1tZWRpdW0tMS0yIj4NCiAgICAgICAgPGRpdiBjbGFzcz0idWstcGFuZWwgdWstcGFuZWwtYm94Ij4NCiAgICAgICAgICAgIDxoMyBjbGFzcz0idWstcGFuZWwtdGl0bGUiPnt0aXRsZX08L2gzPg0KICAgICAgICAgICAge2NvbnRlbnR9DQogICAgICAgIDwvZGl2Pg0KICAgIDwvZGl2Pg0KICAgIDxkaXYgY2xhc3M9InVrLXdpZHRoLW1lZGl1bS0xLTIiPg0KICAgICAgICA8ZGl2IGNsYXNzPSJ1ay1wYW5lbCB1ay1wYW5lbC1ib3giPg0KICAgICAgICAgICAgPGgzIGNsYXNzPSJ1ay1wYW5lbC10aXRsZSI+e3RpdGxlfTwvaDM+DQogICAgICAgICAgICB7Y29udGVudH0NCiAgICAgICAgPC9kaXY+DQogICAgPC9kaXY+DQo8L2Rpdj4=', 1, 'http://getuikit.com/docs/panel.html', 'The Panel component consists of the panel itself, the panel title and a panel badge. To prevent redundant white space, top and bottom margins are removed from the panel\'s content.', '', 1, '2015-05-19 20:04:54', '2017-11-11 22:09:27', 70, '', 1, '4b6e7ee3-75d9-459a-805e-764915247253'),
(3, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Separate content sections by bundling them in blocks with different styles.', 4, 'Block', 'PGRpdiBjbGFzcz0idWstYmxvY2sgdWstYmxvY2stcHJpbWFyeSI+e2NvbnRlbnR9PC9kaXY+', 1, 'http://getuikit.com/docs/block.html', 'To apply this component, just add the .uk-block class to a container element.', '', 1, '2015-05-19 20:09:41', '2017-11-11 22:09:27', 56, '', 2, 'cf2eb2fa-38d1-431c-9383-939c58becd7a'),
(4, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create articles within your page.', 4, 'Article', 'PGFydGljbGUgY2xhc3M9InVrLWFydGljbGUiPg0KICAgIDxoMSBjbGFzcz0idWstYXJ0aWNsZS10aXRsZSI+e3RpdGxlfTwvaDE+DQogICAgPHAgY2xhc3M9InVrLWFydGljbGUtbWV0YSI+e21ldGF9PC9wPg0KICAgIDxwIGNsYXNzPSJ1ay1hcnRpY2xlLWxlYWQiPntjb250ZW50fTwvcD4NCiAgICB7Y29udGVudH0NCiAgICA8aHIgY2xhc3M9InVrLWFydGljbGUtZGl2aWRlciI+DQogICAge2NvbnRlbnR9DQo8L2FydGljbGU+', 1, 'http://getuikit.com/docs/article.html', 'The article component consists of the article itself, a title, meta data, an opening paragraph and dividers.', '', 1, '2015-05-19 20:12:06', '2017-11-11 22:09:27', 53, '', 3, 'ced3bf82-0a72-4acd-a1f5-471959993f2b'),
(5, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create comments, for example about articles.', 4, 'Comment', 'PGFydGljbGUgY2xhc3M9InVrLWNvbW1lbnQiPg0KICAgIDxoZWFkZXIgY2xhc3M9InVrLWNvbW1lbnQtaGVhZGVyIj4NCiAgICAgICAgPGltZyBjbGFzcz0idWstY29tbWVudC1hdmF0YXIiIHNyYz0ie2ltYWdldXJsfSIgYWx0PSIiPg0KICAgICAgICA8aDQgY2xhc3M9InVrLWNvbW1lbnQtdGl0bGUiPnt0aXRsZX08L2g0Pg0KICAgICAgICA8ZGl2IGNsYXNzPSJ1ay1jb21tZW50LW1ldGEiPnttZXRhfTwvZGl2Pg0KICAgIDwvaGVhZGVyPg0KICAgIDxkaXYgY2xhc3M9InVrLWNvbW1lbnQtYm9keSI+e3RpdGxlfTwvZGl2Pg0KPC9hcnRpY2xlPg==', 1, 'http://getuikit.com/docs/comment.html', 'The Comment component consists of a comment header, including an avatar, a title and meta data, and a comment body.', '', 1, '2015-05-19 20:13:53', '2017-11-11 22:09:27', 54, '', 4, '29e9ecf1-0646-44a6-a226-37cfdd4242dc'),
(6, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful utility classes to style your content.', 4, 'Utility Container', 'PGRpdiBjbGFzcz0idWstd2lkdGgtbWVkaXVtLTEtMiB1ay1jb250YWluZXItY2VudGVyIj57Y29udGVudH08L2Rpdj4=', 1, 'http://getuikit.com/docs/utility.html', 'Add the .uk-container class to a block element to give it a max-width and wrap the main content of your website. For large screens it applies a different max-width.\r\n\r\nTo center the container, use the .uk-container-center class. For any other block element, you additionally need to apply a width.', '', 1, '2015-05-19 20:18:00', '2017-11-11 22:09:27', 56, '', 5, '18735087-2ad0-465b-9468-bfac52b56721'),
(7, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful utility classes to style your content.', 4, 'Utility Clearing and floating', 'PGRpdiBjbGFzcz0idWstY2xlYXJmaXgiPg0KICAgIDxkaXYgY2xhc3M9InVrLWZsb2F0LXJpZ2h0Ij57Y29udGVudH08L2Rpdj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay1mbG9hdC1sZWZ0Ij57Y29udGVudH08L2Rpdj4NCjwvZGl2Pg==', 1, 'http://getuikit.com/docs/utility.html', 'Floating is fundamental for creating all kinds of layouts. But floats need to be cleared or in the worst case, you might end up with a scrambled site. The following classes will help you to setup basic layouts.', '', 1, '2015-05-19 20:18:54', '2017-11-11 22:09:27', 54, '', 5, '24e36964-a3ba-416d-93f5-be56c0e30231'),
(8, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'This component uses Flexbox, a concept that is still quite new but extremely powerful for creating layouts.', 'Utilize the power of Flexbox to create a wide range of layouts.', 4, 'Flex', 'PGRpdiBjbGFzcz0idWstZmxleCB1ay1mbGV4LXdyYXAgdWstZmxleC13cmFwLXJldmVyc2UgdWstZmxleC13cmFwLXNwYWNlLWFyb3VuZCI+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtMS0zIHVrLXBhbmVsIHVrLXBhbmVsLWJveCB1ay1wYW5lbC1ib3gtcHJpbWFyeSI+e2NvbnRlbnR9PC9kaXY+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtMS0yIHVrLXBhbmVsIHVrLXBhbmVsLWJveCB1ay1wYW5lbC1ib3gtcHJpbWFyeSB1ay1tYXJnaW4tbGVmdCI+e2NvbnRlbnR9PC9kaXY+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtMS0zIHVrLXBhbmVsIHVrLXBhbmVsLWJveCB1ay1wYW5lbC1ib3gtcHJpbWFyeSI+e2NvbnRlbnR9PC9kaXY+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtMS0zIHVrLXBhbmVsIHVrLXBhbmVsLWJveCB1ay1wYW5lbC1ib3gtcHJpbWFyeSB1ay1tYXJnaW4tbGVmdCI+e2NvbnRlbnR9PC9kaXY+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtMS0yIHVrLXBhbmVsIHVrLXBhbmVsLWJveCB1ay1wYW5lbC1ib3gtcHJpbWFyeSI+e2NvbnRlbnR9PC9kaXY+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtMS0zIHVrLXBhbmVsIHVrLXBhbmVsLWJveCB1ay1wYW5lbC1ib3gtcHJpbWFyeSB1ay1tYXJnaW4tbGVmdCI+e2NvbnRlbnR9PC9kaXY+DQo8L2Rpdj4=', 1, 'http://getuikit.com/docs/flex.html', 'To apply this component, just add the .uk-flex class to a element. This will create the flex container. By default, all flex items will be aligned to the left and equally matched in height and width.', '', 1, '2015-05-19 20:22:23', '2017-11-11 22:09:27', 55, '', 5, '7725158d-f8b6-4fc3-ada7-0cd994f98ce5'),
(9, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'This component allows you to create fullscreen teasers using images, objects or even iframes. Regardless what kind of element, it will always be centered vertically and horizontally and cover its container without losing its proportions. You can also place additional content, like text or an image, on top of the image or video.', 'Expand images or videos to cover their entire container.', 4, 'Cover', 'PGRpdiBjbGFzcz0idWstY292ZXIiPg0KICAgIDx2aWRlbyBjbGFzcz0idWstY292ZXItb2JqZWN0IiB3aWR0aD0iIiBoZWlnaHQ9IiI+DQogICAgICAgIDxzb3VyY2Ugc3JjPSIiIHR5cGU9IiI+DQogICAgPC92aWRlbz4NCjwvZGl2Pg0KDQo8ZGl2IGNsYXNzPSJ1ay1jb3Zlci1iYWNrZ3JvdW5kIj4NCiAgICA8aW1nIGNsYXNzPSJ1ay1pbnZpc2libGUiIHNyYz0iIiB3aWR0aD0iIiBoZWlnaHQ9IiIgYWx0PSIiPg0KPC9kaXY+DQoNCjxkaXYgY2xhc3M9InVrLWNvdmVyIHVrLXBvc2l0aW9uLXJlbGF0aXZlIj4NCiAgICA8aW1nIGNsYXNzPSJ1ay1pbnZpc2libGUiIHNyYz0iIiB3aWR0aD0iIiBoZWlnaHQ9IiIgYWx0PSIiPg0KICAgIDx2aWRlbyBjbGFzcz0idWstY292ZXItb2JqZWN0IHVrLXBvc2l0aW9uLWFic29sdXRlIiB3aWR0aD0iIiBoZWlnaHQ9IiI+DQogICAgICAgIDxzb3VyY2Ugc3JjPSIiIHR5cGU9IiI+DQogICAgPC92aWRlbz4NCjwvZGl2Pg0KDQo8ZGl2IGNsYXNzPSJ1ay1jb3Zlci1iYWNrZ3JvdW5kIHVrLXBvc2l0aW9uLXJlbGF0aXZlIj4NCiAgICA8aW1nIGNsYXNzPSJ1ay1pbnZpc2libGUiIHNyYz0iIiB3aWR0aD0iIiBoZWlnaHQ9IiIgYWx0PSIiPg0KICAgIDxkaXYgY2xhc3M9InVrLXBvc2l0aW9uLWNvdmVyIHVrLWZsZXggdWstZmxleC1jZW50ZXIgdWstZmxleC1taWRkbGUiPntjb250ZW50fTwvZGl2Pg0KPC9kaXY+', 1, 'http://getuikit.com/docs/cover.html', 'The Cover component is applied differently, depending on whether you are using a background image, an object or an iframe. The simplest way is to add the .uk-cover-background class to a element with a background image.', '', 1, '2015-05-19 20:29:57', '2017-11-11 22:09:27', 54, '', 5, '2ca20d4d-82d3-412d-bada-95c2ba0d9bb0'),
(10, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The Dynamic Grid component allows you to create a dynamic and responsive grid layout utilizing the Grid component. Grid items will arrange themselves fluently and seamlessly for a gap-free multi-column layout on all device sizes.', 'Create a multi-column, dynamic grid layout whose items can be sorted and filtered.', 4, 'Dynamic Grid', 'PCEtLSBUaGlzIGlzIGEgZ3JpZCB1c2luZyB1ay13aWR0aC0qIG9uIGVhY2ggaXRlbSAtLT4NCjxkaXYgZGF0YS11ay1ncmlkPg0KICAgIDxkaXYgY2xhc3M9InVrLXdpZHRoLXNtYWxsLTEtMiB1ay13aWR0aC1tZWRpdW0tMS00Ij57Y29udGVudH08L2Rpdj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay13aWR0aC1zbWFsbC0xLTIgdWstd2lkdGgtbWVkaXVtLTEtNCI+e2NvbnRlbnR9PC9kaXY+DQo8L2Rpdj4NCg0KPCEtLSBUaGlzIGlzIGEgZ3JpZCB1c2luZyB1ay1ncmlkLXdpZHRoLSogb24gdGhlIGdyaWQgaXRzZWxmIC0tPg0KPGRpdiBjbGFzcz0idWstZ3JpZC13aWR0aC1zbWFsbC0xLTIgdWstZ3JpZC13aWR0aC1tZWRpdW0tMS00IiBkYXRhLXVrLWdyaWQ+DQogICAgPGRpdj57Y29udGVudH08L2Rpdj4NCiAgICA8ZGl2Pntjb250ZW50fTwvZGl2Pg0KPC9kaXY+DQoNCjwhLS0gRmlsdGVyIENvbnRyb2xzIC0tPg0KPHVsIGlkPSJteS1pZCIgY2xhc3M9InVrLXN1Ym5hdiI+DQogICAgPGxpIGRhdGEtdWstZmlsdGVyPSIiPjxhIGhyZWY9IiI+QWxsPC9hPjwvbGk+DQogICAgPGxpIGRhdGEtdWstZmlsdGVyPSJmaWx0ZXItYSI+PGEgaHJlZj0iIj5BIEZpbHRlcjwvYT48L2xpPg0KICAgIDxsaSBkYXRhLXVrLWZpbHRlcj0iZmlsdGVyLWIiPjxhIGhyZWY9IiI+YiBGaWx0ZXI8L2E+PC9saT4NCjwvdWw+DQo8IS0tIER5bmFtaWMgR3JpZCAtLT4NCjxkaXYgZGF0YS11ay1ncmlkPSJ7Y29udHJvbHM6ICcjbXktaWQnfSI+DQogICAgPGRpdiBkYXRhLXVrLWZpbHRlcj0iZmlsdGVyLWEiPntjb250ZW50fTwvZGl2Pg0KICAgIDxkaXYgZGF0YS11ay1maWx0ZXI9ImZpbHRlci1iIj57Y29udGVudH08L2Rpdj4NCjwvZGl2Pg==', 1, 'http://getuikit.com/docs/grid-js.html', 'To apply this component, add the data-uk-grid attribute to the container element. Set the width of the grid items by using the uk-width-* or .uk-grid-width-* classes from the Grid component.', '', 1, '2015-05-19 20:35:29', '2017-11-11 22:09:27', 53, '', 5, 'c7824206-e8db-4c3d-a910-5e0735fdb74b'),
(11, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Defines different styles for list navigations.', 4, 'Nav', 'PHVsIGNsYXNzPSJ1ay1uYXYgdWstbmF2LXNpZGUiPg0KICAgIDxsaSBjbGFzcz0idWstYWN0aXZlIj48YSBocmVmPSIjIj5BY3RpdmU8L2E+PC9saT4NCiAgICA8bGk+PGEgaHJlZj0iIyI+SXRlbTwvYT48L2xpPg0KICAgIDxsaT48YSBocmVmPSIjIj5JdGVtPC9hPjwvbGk+DQo8L3VsPg==', 2, 'http://getuikit.com/docs/nav.html', 'To apply this component, add the .uk-nav class to an element. Use elements as menu items within the list. To apply an active state to a menu item, just add the .uk-active class.', '', 1, '2015-05-19 20:39:09', '2017-11-11 22:09:27', 53, '', 6, '5e214ba9-2152-4192-9f26-143346ed8090'),
(12, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Defines different styles for the navigation bar.', 4, 'Navbar', 'PG5hdiBjbGFzcz0idWstbmF2YmFyIj4NCiAgICA8dWwgY2xhc3M9InVrLW5hdmJhci1uYXYiPg0KICAgICAgICA8bGkgY2xhc3M9InVrLWFjdGl2ZSI+PGEgaHJlZj0iIj5BY3RpdmU8L2E+PC9saT4NCiAgICAgICAgPGxpPjxhIGhyZWY9IiI+SXRlbTwvYT48L2xpPg0KICAgICAgICA8bGkgZGF0YS11ay1kcm9wZG93bj0iIiBjbGFzcz0idWstcGFyZW50IiBhcmlhLWhhc3BvcHVwPSJ0cnVlIiBhcmlhLWV4cGFuZGVkPSJmYWxzZSI+DQogICAgICAgICAgICA8YSBocmVmPSIiPlBhcmVudDwvYT4NCiAgICANCiAgICAgICAgICAgIDxkaXYgY2xhc3M9InVrLWRyb3Bkb3duIHVrLWRyb3Bkb3duLW5hdmJhciIgc3R5bGU9IiI+DQogICAgICAgICAgICAgICAgPHVsIGNsYXNzPSJ1ay1uYXYgdWstbmF2LW5hdmJhciI+DQogICAgICAgICAgICAgICAgICAgIDxsaT48YSBocmVmPSIjIj5JdGVtPC9hPjwvbGk+DQogICAgICAgICAgICAgICAgICAgIDxsaT48YSBocmVmPSIjIj5Bbm90aGVyIGl0ZW08L2E+PC9saT4NCiAgICAgICAgICAgICAgICAgICAgPGxpIGNsYXNzPSJ1ay1uYXYtaGVhZGVyIj5IZWFkZXI8L2xpPg0KICAgICAgICAgICAgICAgICAgICA8bGk+PGEgaHJlZj0iIyI+SXRlbTwvYT48L2xpPg0KICAgICAgICAgICAgICAgICAgICA8bGk+PGEgaHJlZj0iIyI+QW5vdGhlciBpdGVtPC9hPjwvbGk+DQogICAgICAgICAgICAgICAgICAgIDxsaSBjbGFzcz0idWstbmF2LWRpdmlkZXIiPjwvbGk+DQogICAgICAgICAgICAgICAgICAgIDxsaT48YSBocmVmPSIjIj5TZXBhcmF0ZWQgaXRlbTwvYT48L2xpPg0KICAgICAgICAgICAgICAgIDwvdWw+DQogICAgICAgICAgICA8L2Rpdj4NCiAgICANCiAgICAgICAgPC9saT4NCiAgICA8L3VsPg0KPC9uYXY+', 2, 'http://getuikit.com/docs/navbar.html', 'The Navbar component consists of the navbar itself and one or more navigations.', '', 1, '2015-05-19 20:41:10', '2017-11-11 22:09:27', 53, '', 6, '431dd68d-40cf-4b3b-9cce-b743a7f36ac3'),
(13, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Defines different styles for a sub navigation.', 4, 'Subnav', 'PHVsIGNsYXNzPSJ1ay1zdWJuYXYgdWstc3VibmF2LXBpbGwiPg0KICAgIDxsaSBjbGFzcz0idWstYWN0aXZlIj48YSBocmVmPSIjIj5BY3RpdmU8L2E+PC9saT4NCiAgICA8bGk+PGEgaHJlZj0iIyI+SXRlbTwvYT48L2xpPg0KICAgIDxsaSBjbGFzcz0idWstZGlzYWJsZWQiPjxhIGhyZWY9IiMiPkRpc2FibGVkPC9hPjwvbGk+DQogICAgPGxpIGRhdGEtdWstZHJvcGRvd249Inttb2RlOidjbGljayd9Ij4NCiAgICAgICAgPGEgaHJlZj0iIyI+TW9yZSA8aSBjbGFzcz0idWstaWNvbi1jYXJldC1kb3duIj48L2k+PC9hPg0KICAgICAgICA8ZGl2IGNsYXNzPSJ1ay1kcm9wZG93biB1ay1kcm9wZG93bi1zbWFsbCI+DQogICAgICAgICAgICA8dWwgY2xhc3M9InVrLW5hdiB1ay1uYXYtZHJvcGRvd24iPg0KICAgICAgICAgICAgICAgIDxsaT48YSBocmVmPSIjIj5JdGVtPC9hPjwvbGk+DQogICAgICAgICAgICAgICAgPGxpPjxhIGhyZWY9IiMiPkFub3RoZXIgaXRlbTwvYT48L2xpPg0KICAgICAgICAgICAgICAgIDxsaSBjbGFzcz0idWstbmF2LWhlYWRlciI+SGVhZGVyPC9saT4NCiAgICAgICAgICAgICAgICA8bGk+PGEgaHJlZj0iIyI+SXRlbTwvYT48L2xpPg0KICAgICAgICAgICAgICAgIDxsaT48YSBocmVmPSIjIj5Bbm90aGVyIGl0ZW08L2E+PC9saT4NCiAgICAgICAgICAgICAgICA8bGkgY2xhc3M9InVrLW5hdi1kaXZpZGVyIj48L2xpPg0KICAgICAgICAgICAgICAgIDxsaT48YSBocmVmPSIjIj5TZXBhcmF0ZWQgaXRlbTwvYT48L2xpPg0KICAgICAgICAgICAgPC91bD4NCiAgICAgICAgPC9kaXY+DQogICAgPC9saT4NCjwvdWw+', 2, 'http://getuikit.com/docs/subnav.html', 'To apply this component, use the following classes. To align a subnav, for example to horizontally center it, you can use the Flex component.', '', 1, '2015-05-19 20:42:37', '2017-11-11 22:09:27', 53, '', 6, 'b8f8835d-ffe4-4b0f-ad69-a7e847dbedbd'),
(14, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create breadcrumbs to show users their location within a website.', 4, 'Breadcrumb', 'PHVsIGNsYXNzPSJ1ay1icmVhZGNydW1iIj4NCiAgICA8bGk+PGEgaHJlZj0iIyI+SG9tZTwvYT48L2xpPg0KICAgIDxsaT48YSBocmVmPSIjIj5CbG9nPC9hPjwvbGk+DQogICAgPGxpPjxzcGFuPkNhdGVnb3J5PC9zcGFuPjwvbGk+DQogICAgPGxpIGNsYXNzPSJ1ay1hY3RpdmUiPjxzcGFuPlBvc3Q8L3NwYW4+PC9saT4NCjwvdWw+', 2, 'http://getuikit.com/docs/breadcrumb.html', 'The Breadcrumb component consists of links which are aligned side by side and separated by a divider.', '', 1, '2015-05-19 20:44:01', '2017-11-11 22:09:27', 53, '', 6, 'c1cccf2b-84c3-46de-81f1-0ca5f2bfd13d'),
(15, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easlily create a nicely looking pagination to navigate through pages.', 4, 'Pagination', 'PHVsIGNsYXNzPSJ1ay1wYWdpbmF0aW9uIj4NCiAgICA8bGk+PGEgaHJlZj0iIyI+MTwvYT48L2xpPg0KICAgIDxsaT48c3Bhbj4uLi48L3NwYW4+PC9saT4NCiAgICA8bGk+PGEgaHJlZj0iIyI+ODwvYT48L2xpPg0KICAgIDxsaT48YSBocmVmPSIjIj45PC9hPjwvbGk+DQogICAgPGxpIGNsYXNzPSJ1ay1hY3RpdmUiPjxzcGFuPjEwPC9zcGFuPjwvbGk+DQogICAgPGxpPjxhIGhyZWY9IiMiPjExPC9hPjwvbGk+DQogICAgPGxpPjxhIGhyZWY9IiMiPjEyPC9hPjwvbGk+DQogICAgPGxpPjxzcGFuPi4uLjwvc3Bhbj48L2xpPg0KICAgIDxsaT48YSBocmVmPSIjIj4yMDwvYT48L2xpPg0KPC91bD4=', 2, 'http://getuikit.com/docs/pagination.html', 'The Pagination component consists of button-like styled links, that are aligned side by side.', '', 1, '2015-05-19 20:45:49', '2017-11-11 22:09:27', 53, '', 6, '597e8806-9e28-4411-9a94-61d874d2ac0e'),
(16, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create a tabbed navigation with different styles.', 4, 'Tab', 'PHVsIGNsYXNzPSJ1ay10YWIiIGRhdGEtdWstdGFiPg0KICAgIDxsaSBjbGFzcz0idWstYWN0aXZlIj48YSBocmVmPSIiPkFjdGl2ZTwvYT48L2xpPg0KICAgIDxsaT48YSBocmVmPSIiPkl0ZW08L2E+PC9saT4NCiAgICA8bGk+PGEgaHJlZj0iIj5JdGVtPC9hPjwvbGk+DQogICAgPGxpIGNsYXNzPSJ1ay1kaXNhYmxlZCI+PGEgaHJlZj0iIj5EaXNhYmxlZDwvYT48L2xpPg0KPC91bD4=', 2, 'http://getuikit.com/docs/tab.html', 'The Tab component consists of clickable tabs, that are aligned side by side.\r\n\r\nThe data-uk-tab attribute is required for two purposes. Firstly, it enables the responsive behaviour. If the parent container is too small to accomodate all tabs, they will be combined into a dropdown, toggled by a single tab, which represents the active tab item. This also requires the Dropdown component in order to work.\r\n\r\nAnd secondly, its functionality is coupled to the Switcher component, which is necessary to dynamically transition through different contents using tabbed navigation.', '', 1, '2015-05-19 20:47:34', '2017-11-11 22:09:27', 55, '', 6, '690739e8-9547-472c-a4e7-c9362321b37b'),
(17, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create a tabbed navigation with different styles.', 4, 'Thumbnav', 'PHVsIGNsYXNzPSJ1ay10aHVtYm5hdiI+DQogICAgPGxpIGNsYXNzPSJ1ay1hY3RpdmUiPjxhIGhyZWY9IiI+PGltZyBzcmM9IiIgYWx0PSIiPjwvYT48L2xpPg0KICAgIDxsaT48YSBocmVmPSIiPjxpbWcgc3JjPSIiIGFsdD0iIj48L2E+PC9saT4NCjwvdWw+', 2, 'http://getuikit.com/docs/thumbnav.html', 'To apply this component, add the .uk-thumbnav class to an element and nest your thumbnail images inside elements within the list items. The thumbnav will wrap into several rows, if it is wider than its container and automatically applies a gutter. Add the .uk-active class to create an active state.\r\n\r\nTo align a subnav, for example to horizontally center it, you can use the Flex component.', '', 1, '2015-05-19 20:48:42', '2017-11-11 22:09:27', 54, '', 6, '0e405e4f-4701-46e1-8631-8ce5e13736de'),
(18, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'Modifiers\r\n\r\nTo display the list in a different style, just add a modifier class to the the .uk-list class. The modifiers of the List component are not combinable with each other.', 'Easily create nicely looking lists, which come in different styles.', 4, 'List', 'PHVsIGNsYXNzPSJ1ay1saXN0IHVrLWxpc3Qtc3RyaXBlZCI+DQogICAgPGxpPi4uLjwvbGk+DQogICAgPGxpPi4uLjwvbGk+DQogICAgPGxpPi4uLjwvbGk+DQo8L3VsPg==', 3, 'http://getuikit.com/docs/list.html', 'To apply this component, add the .uk-list class to an unordered or ordered list. The list will now display without any spacing or list-style. [uk-list-line] [uk-list-space]', '', 1, '2015-06-01 16:09:04', '2017-11-11 22:09:27', 3, '', 6, '74ab3937-65e0-4dab-9eb1-2ff87554bdde'),
(19, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'Add the .uk-description-list-horizontal class to display terms and descriptions side by side.', 'Easily create nicely looking description lists, which come in different styles.', 4, 'Description list', 'PGRsIGNsYXNzPSJ1ay1kZXNjcmlwdGlvbi1saXN0LWhvcml6b250YWwiPg0KICAgIDxkdD4uLi48L2R0Pg0KICAgIDxkZD4uLi48L2RkPg0KPC9kbD4=', 3, 'http://getuikit.com/docs/description-list.html', 'There is no component class necessary to create a description list, but UIkit provides a couple of modifier classes to display the list in a different style. The modifiers of the Description list component are not combinable with each other. [uk-description-list-line]', '', 1, '2015-06-01 16:10:54', '2017-11-11 22:09:27', 54, '', 6, 'dae0a910-056d-4e04-b603-43c23d705c1a'),
(20, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking tables, which come in different styles.', 4, 'Table', 'PHRhYmxlIGNsYXNzPSJ1ay10YWJsZSB1ay10YWJsZS1ob3ZlciI+DQogICAgPGNhcHRpb24+Li4uPC9jYXB0aW9uPg0KICAgIDx0aGVhZD4NCiAgICAgICAgPHRyPg0KICAgICAgICAgICAgPHRoPi4uLjwvdGg+DQogICAgICAgIDwvdHI+DQogICAgPC90aGVhZD4NCiAgICA8dGZvb3Q+DQogICAgICAgIDx0cj4NCiAgICAgICAgICAgIDx0ZD4uLi48L3RkPg0KICAgICAgICA8L3RyPg0KICAgIDwvdGZvb3Q+DQogICAgPHRib2R5Pg0KICAgICAgICA8dHI+DQogICAgICAgICAgICA8dGQ+Li4uPC90ZD4NCiAgICAgICAgPC90cj4NCiAgICA8L3Rib2R5Pg0KPC90YWJsZT4=', 3, 'http://getuikit.com/docs/table.html', 'To apply this component, add the .uk-table class to a element.', '', 1, '2015-06-01 16:12:46', '2017-11-11 22:09:27', 53, '', 6, 'b0f501cf-ca6c-4261-bf4c-dc10e036a259'),
(21, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button href', 'PGEgY2xhc3M9InVrLWJ1dHRvbiB1ay1idXR0b24tcHJpbWFyeSIgaHJlZj0iIj4uLi48L2E+', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:17:24', '2017-11-11 22:09:27', 11, '', 7, '0a0ed2e9-ab18-472b-899b-6209b60aff08'),
(22, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button primary', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLWJ1dHRvbi1wcmltYXJ5IiB0eXBlPSJidXR0b24iPi4uLjwvYnV0dG9uPg==', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:18:37', '2017-11-11 22:09:27', 10, '', 7, 'efaae1eb-1cb7-4761-84b7-a804c1b09b15'),
(23, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button disabled', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIiB0eXBlPSJidXR0b24iIGRpc2FibGVkPi4uLjwvYnV0dG9uPg==', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:18:53', '2017-11-11 22:09:27', 10, '', 7, 'b47d9020-eb39-45d4-a6e4-33b28ca51ac7'),
(24, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button success', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLWJ1dHRvbi1zdWNjZXNzIiB0eXBlPSJidXR0b24iPi4uLjwvYnV0dG9uPg==', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:19:15', '2017-11-11 22:09:27', 10, '', 7, 'd1686780-d1d4-4732-8a0f-184bc29e96ac'),
(25, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button danger', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLWJ1dHRvbi1kYW5nZXIiIHR5cGU9ImJ1dHRvbiI+Li4uPC9idXR0b24+', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:19:28', '2017-11-11 22:09:27', 10, '', 7, 'aaa1d48e-1f21-4f69-b503-27d462070d29'),
(26, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button mini', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLWJ1dHRvbi1wcmltYXJ5IHVrLWJ1dHRvbi1taW5pIiB0eXBlPSJidXR0b24iPi4uLjwvYnV0dG9uPg==', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:20:06', '2017-11-11 22:09:27', 10, '', 7, '5f6cfab0-c011-4f01-b4a2-a6e5712b3df1'),
(27, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button small', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLWJ1dHRvbi1zdWNjZXNzIHVrLWJ1dHRvbi1zbWFsbCIgdHlwZT0iYnV0dG9uIj4uLi48L2J1dHRvbj4=', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:20:37', '2017-11-11 22:09:27', 10, '', 7, 'c91a3e7d-d56c-43d5-90bf-5d0a436a92ea'),
(28, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button large', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLWJ1dHRvbi1sYXJnZSIgdHlwZT0iYnV0dG9uIj4uLi48L2J1dHRvbj4=', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:20:58', '2017-11-11 22:09:27', 10, '', 7, '29cbadf8-661a-479f-b219-60fbcfb819d9'),
(29, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button full width', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIHVrLXdpZHRoLTEtMSB1ay1tYXJnaW4tc21hbGwtYm90dG9tIiB0eXBlPSJidXR0b24iPi4uLjwvYnV0dG9uPg==', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:21:28', '2017-11-11 22:09:27', 10, '', 7, '1077c3fd-a993-4b8b-97a1-72f82327366c'),
(30, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button group', 'PGRpdiBjbGFzcz0idWstYnV0dG9uLWdyb3VwIj4NCiAgICA8YSBjbGFzcz0idWstYnV0dG9uIiBocmVmPSIiPi4uLjwvYT4NCiAgICA8YnV0dG9uIGNsYXNzPSJ1ay1idXR0b24iPi4uLjwvYnV0dG9uPg0KICAgIDxidXR0b24gY2xhc3M9InVrLWJ1dHRvbiI+Li4uPC9idXR0b24+DQo8L2Rpdj4=', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:21:42', '2017-11-11 22:09:27', 10, '', 7, '8cb09ac8-95c5-4eaa-a6c2-849f74bf5767'),
(31, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easily create nicely looking buttons, which come in different styles.', 4, 'Button dropdowns', 'PCEtLSBUaGlzIGlzIHRoZSBjb250YWluZXIgZW5hYmxpbmcgdGhlIEphdmFTY3JpcHQgLS0+DQo8ZGl2IGNsYXNzPSJ1ay1idXR0b24tZHJvcGRvd24iIGRhdGEtdWstZHJvcGRvd24+DQoNCiAgICA8IS0tIFRoaXMgaXMgdGhlIGJ1dHRvbiB0b2dnbGluZyB0aGUgZHJvcGRvd24gLS0+DQogICAgPGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIj4uLi48L2J1dHRvbj4NCg0KICAgIDwhLS0gVGhpcyBpcyB0aGUgZHJvcGRvd24gLS0+DQogICAgPGRpdiBjbGFzcz0idWstZHJvcGRvd24gdWstZHJvcGRvd24tc21hbGwiPg0KICAgICAgICA8dWwgY2xhc3M9InVrLW5hdiB1ay1uYXYtZHJvcGRvd24iPg0KICAgICAgICAgICAgPGxpPjxhIGhyZWY9IiI+Li4uPC9hPjwvbGk+DQogICAgICAgICAgICA8bGk+PGEgaHJlZj0iIj4uLi48L2E+PC9saT4NCiAgICAgICAgPC91bD4NCiAgICA8L2Rpdj4NCg0KPC9kaXY+', 4, 'http://getuikit.com/docs/button.html', 'To apply this component, add the .uk-button class to an or element. Now you have created a button. Add the disabled attribute to a element to disable the button.', '', 1, '2015-06-01 16:22:52', '2017-11-11 22:09:27', 10, '', 7, '5b5ebfa4-408c-4b5e-9d28-a6370c944bdc'),
(32, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'This component is using the fantastic Font Awesome icon font, a project by Dave Gandy. Altogether Font Awesome provides more than 300 symbols and glyphs for web-related actions. Icon fonts are great, because they enable you to easily change color, size and more via CSS. They are scalable vector graphics, which means that they look great on high-resolution displays.', 'Place vector icons anywhere using an icon font.', 4, 'Icon', 'PGkgY2xhc3M9InVrLWljb24tY29nIj48L2k+', 4, 'http://getuikit.com/docs/icon.html', 'To apply this component, add any .uk-icon-* class to an or element. Et voilà, you have a vector icon, which inherits size and color just like your text does.', '', 1, '2015-06-01 16:24:46', '2017-11-11 22:09:27', 10, '', 8, 'df1fa1bc-231e-4f67-be48-f9ea6812ae3d'),
(33, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Easlily create nicely looking badges to label and highlight your content.', 4, 'Badge', 'PGRpdiBjbGFzcz0idWstYmFkZ2UiPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/badge.html', 'To create a badge, just add the .uk-badge class to a or element.', '', 1, '2015-06-01 16:25:53', '2017-11-11 22:09:27', 10, '', 8, '20532a80-6b61-4b5d-a861-05dbc4d82e02'),
(34, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Defines styles for success, warning and error messages.', 4, 'Alert', 'PGRpdiBjbGFzcz0idWstYWxlcnQgdWstYWxlcnQtc3VjY2VzcyIgZGF0YS11ay1hbGVydD4NCiAgICA8YSBocmVmPSIiIGNsYXNzPSJ1ay1hbGVydC1jbG9zZSB1ay1jbG9zZSI+PC9hPg0KICAgIDxwPi4uLjwvcD4NCjwvZGl2Pg==', 4, 'http://getuikit.com/docs/badge.html', 'To apply this component, add the .uk-alert class to a block element.', '', 1, '2015-06-01 16:26:54', '2017-11-11 22:09:27', 10, '', 8, '9b0e4beb-680a-412b-a477-391cdb81c844'),
(35, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text small', 'PHNwYW4gY2xhc3M9InVrLXRleHQtc21hbGwiPkFkZCB0aGlzIGNsYXNzIHRvIGRlY3JlYXNlIHRoZSBmb250IHNpemUuPC9zcGFuPg==', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:29:02', '2017-11-11 22:09:27', 10, '', 8, '8516fb71-8f10-4828-a670-af861fd8aae5'),
(36, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text large', 'PHNwYW4gY2xhc3M9InVrLXRleHQtbGFyZ2UiPkFkZCB0aGlzIGNsYXNzIHRvIGRlY3JlYXNlIHRoZSBmb250IHNpemUuPC9zcGFuPg==', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:29:14', '2017-11-11 22:09:27', 10, '', 8, '6188947b-c807-4ab7-8960-51a1d808efcb'),
(37, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text bold', 'PHNwYW4gY2xhc3M9InVrLXRleHQtYm9sZCI+QWRkIHRoaXMgY2xhc3MgdG8gZGVjcmVhc2UgdGhlIGZvbnQgc2l6ZS48L3NwYW4+', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:29:24', '2017-11-11 22:09:27', 10, '', 8, 'adabb157-ec5d-4c62-857f-2d89e77815e2'),
(38, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text muted', 'PHNwYW4gY2xhc3M9InVrLXRleHQtbXV0ZWQiPkFkZCB0aGlzIGNsYXNzIHRvIGRlY3JlYXNlIHRoZSBmb250IHNpemUuPC9zcGFuPg==', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:29:36', '2017-11-11 22:09:27', 10, '', 8, 'bb0b4ed1-5fb2-4799-9645-9d878d8d86a7'),
(39, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text primary', 'PHNwYW4gY2xhc3M9InVrLXRleHQtcHJpbWFyeSI+QWRkIHRoaXMgY2xhc3MgdG8gZGVjcmVhc2UgdGhlIGZvbnQgc2l6ZS48L3NwYW4+', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:29:46', '2017-11-11 22:09:27', 10, '', 8, '02d1e0d7-d461-46f2-b7d5-4c6d95558e11'),
(40, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text success', 'PHNwYW4gY2xhc3M9InVrLXRleHQtc3VjY2VzcyI+QWRkIHRoaXMgY2xhc3MgdG8gZGVjcmVhc2UgdGhlIGZvbnQgc2l6ZS48L3NwYW4+', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:29:57', '2017-11-11 22:09:27', 10, '', 8, 'f6a191bb-ef7a-4a91-823a-466200d35b4d'),
(41, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text warning', 'PHNwYW4gY2xhc3M9InVrLXRleHQtd2FybmluZyI+QWRkIHRoaXMgY2xhc3MgdG8gZGVjcmVhc2UgdGhlIGZvbnQgc2l6ZS48L3NwYW4+', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:30:09', '2017-11-11 22:09:27', 10, '', 8, 'd3a259e2-9839-4922-98d1-ef7ddf03da6b'),
(42, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text danger', 'PHNwYW4gY2xhc3M9InVrLXRleHQtZGFuZ2VyIj5BZGQgdGhpcyBjbGFzcyB0byBkZWNyZWFzZSB0aGUgZm9udCBzaXplLjwvc3Bhbj4=', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:30:19', '2017-11-11 22:09:27', 10, '', 8, '0994d67d-401e-49e1-a7ad-68f8c3c0460a'),
(43, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text contrast', 'PHNwYW4gY2xhc3M9InVrLXRleHQtY29udHJhc3QiPkFkZCB0aGlzIGNsYXNzIHRvIGRlY3JlYXNlIHRoZSBmb250IHNpemUuPC9zcGFuPg==', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:30:31', '2017-11-11 22:09:27', 10, '', 8, 'a5931e90-0d0e-4c60-8485-ae8b5620d540'),
(44, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text right', 'PHNwYW4gY2xhc3M9InVrLXRleHQtcmlnaHQiPkFkZCB0aGlzIGNsYXNzIHRvIGRlY3JlYXNlIHRoZSBmb250IHNpemUuPC9zcGFuPg==', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:31:18', '2017-11-11 22:09:27', 10, '', 8, '24d3dcc3-5ac3-4366-85b8-0a75cac6cef9'),
(45, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text center', 'PHNwYW4gY2xhc3M9InVrLXRleHQtY2VudGVyIj5BZGQgdGhpcyBjbGFzcyB0byBkZWNyZWFzZSB0aGUgZm9udCBzaXplLjwvc3Bhbj4=', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:31:30', '2017-11-11 22:09:27', 10, '', 8, '2ced9267-0326-440e-85e7-3ac8911fbbf5'),
(46, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text justify', 'PHNwYW4gY2xhc3M9InVrLXRleHQtanVzdGlmeSI+QWRkIHRoaXMgY2xhc3MgdG8gZGVjcmVhc2UgdGhlIGZvbnQgc2l6ZS48L3NwYW4+', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:31:41', '2017-11-11 22:09:27', 10, '', 8, '79acfaa7-7a31-441e-8830-3f63c1e1aa54'),
(47, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text truncate', 'PHNwYW4gY2xhc3M9InVrLXRleHQtdHJ1bmNhdGUiPkFkZCB0aGlzIGNsYXNzIHRvIGRlY3JlYXNlIHRoZSBmb250IHNpemUuPC9zcGFuPg==', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:32:17', '2017-11-11 22:09:27', 10, '', 8, '0f43f9ec-98d6-4856-be34-f4e852520bf8'),
(48, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A collection of useful text utility classes to style your content.', 4, 'Text nowrap', 'PHNwYW4gY2xhc3M9InVrLXRleHQtbm93cmFwIj5BZGQgdGhpcyBjbGFzcyB0byBkZWNyZWFzZSB0aGUgZm9udCBzaXplLjwvc3Bhbj4=', 4, 'http://getuikit.com/docs/text.html', 'UIkit offers various text utlities to style your text. ', '', 1, '2015-06-01 16:32:30', '2017-11-11 22:09:27', 10, '', 8, '5489c68b-4926-43f3-980b-e5b251f10ac8'),
(49, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation fade', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLWZhZGUiPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:33:49', '2017-11-11 22:09:27', 10, '', 8, '6cba0fb7-f790-4ad2-ba03-2cdca25a8dd9'),
(50, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation scale-up', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNjYWxlLXVwIj4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:34:02', '2017-11-11 22:09:27', 10, '', 8, '11df7f35-5e63-43e1-96ef-f2a0f58bef19'),
(51, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation scale-down', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNjYWxlLWRvd24iPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:34:11', '2017-11-11 22:09:27', 10, '', 8, '1b4c533e-94f6-4a55-81a2-1370c088582d'),
(52, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-top', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLXRvcCI+Li4uPC9kaXY+', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:34:22', '2017-11-11 22:09:27', 10, '', 8, '8fc46f20-9783-42cb-92e2-3e0fc5a875c7'),
(53, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-bottom', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLWJvdHRvbSI+Li4uPC9kaXY+', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:34:34', '2017-11-11 22:09:27', 10, '', 8, '2d8ed2c0-20af-4c3e-8e0a-fea75fdce181'),
(54, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-left', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLWxlZnQiPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:34:46', '2017-11-11 22:09:27', 10, '', 8, '0bb64e85-6438-4aac-9f60-ad9c8f3c522b'),
(55, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-right', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLXJpZ2h0Ij4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:34:57', '2017-11-11 22:09:27', 10, '', 8, 'cc303d9d-7940-433f-a918-e46b937f34b6'),
(56, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation shake', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNoYWtlIj4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:35:08', '2017-11-11 22:09:27', 10, '', 8, 'b688ea4a-23b3-470c-b499-dedac36a9c19'),
(57, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation scale', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNjYWxlIj4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:35:19', '2017-11-11 22:09:27', 10, '', 8, '997b5991-5be8-4efb-b5e6-1ae988ea4f4a'),
(58, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation fade reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLWZhZGUgdWstYW5pbWF0aW9uLXJldmVyc2UiPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:37:24', '2017-11-11 22:09:27', 11, '', 8, '6bfd3c02-d4f2-464a-a61b-040324d96789'),
(59, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation scale-up reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNjYWxlLXVwIHVrLWFuaW1hdGlvbi1yZXZlcnNlIj4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:38:33', '2017-11-11 22:09:27', 10, '', 8, '71296148-4c2f-4c69-bbc8-de50d76dc6c8'),
(60, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation scale-down reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNjYWxlLWRvd24gdWstYW5pbWF0aW9uLXJldmVyc2UiPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:38:49', '2017-11-11 22:09:27', 10, '', 8, 'a5c4eadc-e98a-45e1-9c88-d9f761256c88'),
(61, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-top reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLXRvcCB1ay1hbmltYXRpb24tcmV2ZXJzZSI+Li4uPC9kaXY+', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:39:02', '2017-11-11 22:09:27', 10, '', 8, '79766303-ff2d-465c-8b4a-a2d2cae268e4'),
(62, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-bottom reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLWJvdHRvbSB1ay1hbmltYXRpb24tcmV2ZXJzZSI+Li4uPC9kaXY+', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:39:13', '2017-11-11 22:09:27', 10, '', 8, 'c20f18a6-74b4-4368-be0b-52d532500f79'),
(63, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-left reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLWxlZnQgdWstYW5pbWF0aW9uLXJldmVyc2UiPi4uLjwvZGl2Pg==', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:39:26', '2017-11-11 22:09:27', 10, '', 8, 'f4dfb5f9-33ed-4cfc-baab-4f6e3f80fa19'),
(64, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation slide-right reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNsaWRlLXJpZ2h0IHVrLWFuaW1hdGlvbi1yZXZlcnNlIj4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:39:38', '2017-11-11 22:09:27', 10, '', 8, '735a91e2-6867-43a7-ad66-cb6576018bfe'),
(65, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'A basic collection of smooth animations to use within your page.', 4, 'Animation scale reverse', 'PGRpdiBjbGFzcz0idWstYW5pbWF0aW9uLXNjYWxlIHVrLWFuaW1hdGlvbi1yZXZlcnNlIj4uLi48L2Rpdj4=', 4, 'http://getuikit.com/docs/animation.html', 'To apply this component, add any .uk-animation-* class to an element and it will fade in with a nice animation. These classes are commonly set by using JavaScript to apply the animation to specific behaviors.', '', 1, '2015-06-01 16:40:02', '2017-11-11 22:09:27', 10, '', 8, '918eaa08-13ff-4d7b-b691-2ced6afde21e'),
(66, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create modal dialogs with different styles and transitions.', 4, 'Modal default', 'PCEtLSBUaGlzIGlzIGEgYnV0dG9uIHRvZ2dsaW5nIHRoZSBtb2RhbCAtLT4NCjxidXR0b24gY2xhc3M9InVrLWJ1dHRvbiIgZGF0YS11ay1tb2RhbD0ie3RhcmdldDonI215LWlkJ30iPi4uLjwvYnV0dG9uPg0KDQo8IS0tIFRoaXMgaXMgdGhlIG1vZGFsIC0tPg0KPGRpdiBpZD0ibXktaWQiIGNsYXNzPSJ1ay1tb2RhbCI+DQogICAgPGRpdiBjbGFzcz0idWstbW9kYWwtZGlhbG9nIj4NCiAgICAgICAgPGEgY2xhc3M9InVrLW1vZGFsLWNsb3NlIHVrLWNsb3NlIj48L2E+DQogICAgICAgIC4uLg0KICAgIDwvZGl2Pg0KPC9kaXY+', 5, 'http://getuikit.com/docs/modal.html', 'The modal component consists of an overlay, a dialog and a close button.', '', 1, '2015-06-01 19:57:08', '2017-11-11 22:09:27', 10, '', 8, '732ecce3-c923-4221-ab04-d7f424b8cd1e'),
(67, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create modal dialogs with different styles and transitions.', 4, 'Modal header-footer', 'PCEtLSBUaGlzIGlzIGEgYnV0dG9uIHRvZ2dsaW5nIHRoZSBtb2RhbCAtLT4NCjxidXR0b24gY2xhc3M9InVrLWJ1dHRvbiIgZGF0YS11ay1tb2RhbD0ie3RhcmdldDonI215LWlkJ30iPi4uLjwvYnV0dG9uPg0KDQo8IS0tIFRoaXMgaXMgdGhlIG1vZGFsIC0tPg0KPGRpdiBpZD0ibXktaWQiIGNsYXNzPSJ1ay1tb2RhbCI+DQogICAgPGRpdiBjbGFzcz0idWstbW9kYWwtZGlhbG9nIj4NCiAgICAgICAgPGRpdiBjbGFzcz0idWstbW9kYWwtaGVhZGVyIj4uLi48L2Rpdj4NCiAgICAgICAgLi4uDQogICAgICAgIDxkaXYgY2xhc3M9InVrLW1vZGFsLWZvb3RlciI+Li4uPC9kaXY+DQogICAgPC9kaXY+DQo8L2Rpdj4=', 5, 'http://getuikit.com/docs/modal.html', 'The modal component consists of an overlay, a dialog and a close button.', '', 1, '2015-06-01 19:57:50', '2017-11-11 22:09:27', 10, '', 8, 'a0114851-724e-4bb1-b617-f44b33abafde'),
(68, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create modal dialogs with different styles and transitions.', 4, 'Modal image', 'PCEtLSBUaGlzIGlzIGEgYnV0dG9uIHRvZ2dsaW5nIHRoZSBtb2RhbCAtLT4NCjxidXR0b24gY2xhc3M9InVrLWJ1dHRvbiIgZGF0YS11ay1tb2RhbD0ie3RhcmdldDonI215LWlkJ30iPi4uLjwvYnV0dG9uPg0KDQo8IS0tIFRoaXMgaXMgdGhlIG1vZGFsIC0tPg0KPGRpdiBpZD0ibXktaWQiIGNsYXNzPSJ1ay1tb2RhbCI+DQogICAgPGRpdiBjbGFzcz0idWstbW9kYWwtZGlhbG9nIHVrLW1vZGFsLWRpYWxvZy1saWdodGJveCI+DQogICAgICAgIDxhIGhyZWY9IiIgY2xhc3M9InVrLW1vZGFsLWNsb3NlIHVrLWNsb3NlIHVrLWNsb3NlLWFsdCI+PC9hPg0KICAgICAgICA8aW1nIHNyYz0iIiBhbHQ9IiI+DQogICAgPC9kaXY+DQo8L2Rpdj4=', 5, 'http://getuikit.com/docs/modal.html', 'The modal component consists of an overlay, a dialog and a close button.', '', 1, '2015-06-01 19:58:26', '2017-11-11 22:09:27', 10, '', 8, '296abb37-599b-4fe2-bd17-9008b026a2fc'),
(69, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The Off-canvas component is perfect for building a mobile navigation, similar to those which are popular with many native mobile apps, where a single button in the upper left corner toggles an off-canvas sidebar with a menu.', 'Create a smooth off-canvas sidebar that slides in and out of the page.', 4, 'Off-canvas default', 'PCEtLSBUaGlzIGlzIGEgYnV0dG9uIHRvZ2dsaW5nIHRoZSBvZmYtY2FudmFzIHNpZGViYXIgLS0+DQo8YnV0dG9uIGNsYXNzPSJ1ay1idXR0b24iIGRhdGEtdWstb2ZmY2FudmFzPSJ7dGFyZ2V0OicjbXktaWQnfSI+Li4uPC9idXR0b24+DQoNCjwhLS0gVGhpcyBpcyB0aGUgb2ZmLWNhbnZhcyBzaWRlYmFyIC0tPg0KPGRpdiBpZD0ibXktaWQiIGNsYXNzPSJ1ay1vZmZjYW52YXMiPg0KICAgIDxkaXYgY2xhc3M9InVrLW9mZmNhbnZhcy1iYXIiPi4uLjwvZGl2Pg0KPC9kaXY+', 5, 'http://getuikit.com/docs/offcanvas.html', 'The Off-canvas component consists of an overlay and an off-canvas bar.', '', 1, '2015-06-01 20:00:09', '2017-11-11 22:09:27', 10, '', 8, '063b892a-956b-4950-a7e0-afa8a6c9e14f'),
(70, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The Off-canvas component is perfect for building a mobile navigation, similar to those which are popular with many native mobile apps, where a single button in the upper left corner toggles an off-canvas sidebar with a menu.', 'Create a smooth off-canvas sidebar that slides in and out of the page.', 4, 'Off-canvas right', 'PCEtLSBUaGlzIGlzIGEgYnV0dG9uIHRvZ2dsaW5nIHRoZSBvZmYtY2FudmFzIHNpZGViYXIgLS0+DQo8YnV0dG9uIGNsYXNzPSJ1ay1idXR0b24iIGRhdGEtdWstb2ZmY2FudmFzPSJ7dGFyZ2V0OicjbXktaWQnfSI+Li4uPC9idXR0b24+DQoNCjwhLS0gVGhpcyBpcyB0aGUgb2ZmLWNhbnZhcyBzaWRlYmFyIC0tPg0KPGRpdiBpZD0ibXktaWQiIGNsYXNzPSJ1ay1vZmZjYW52YXMiPg0KICAgIDxkaXYgY2xhc3M9InVrLW9mZmNhbnZhcy1iYXIgdWstb2ZmY2FudmFzLWJhci1mbGlwIj4uLi48L2Rpdj4NCjwvZGl2Pg==', 5, 'http://getuikit.com/docs/offcanvas.html', 'The Off-canvas component consists of an overlay and an off-canvas bar.', '', 1, '2015-06-01 20:00:37', '2017-11-11 22:09:27', 10, '', 8, 'e5a619b7-ef6f-46b4-a30b-4b79b2d8d43f'),
(71, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Dynamically transition through different content panes.', 4, 'Switcher default', 'PCEtLSBUaGlzIGlzIHRoZSBjb250YWluZXIgb2YgdGhlIHRvZ2dsaW5nIGVsZW1lbnRzIC0tPg0KPHVsIGRhdGEtdWstc3dpdGNoZXI9Intjb25uZWN0OicjbXktaWQnfSI+DQogICAgPGxpPjxhIGhyZWY9IiI+Li4uPC9hPjwvbGk+DQo8L3VsPg0KDQo8IS0tIFRoaXMgaXMgdGhlIGNvbnRhaW5lciBvZiB0aGUgY29udGVudCBpdGVtcyAtLT4NCjx1bCBpZD0ibXktaWQiIGNsYXNzPSJ1ay1zd2l0Y2hlciI+DQogICAgPGxpPi4uLjwvbGk+DQo8L3VsPg==', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:02:41', '2017-11-11 22:09:27', 10, '', 8, 'fd850fcf-366b-4b7e-9ccc-bb515f316ab7'),
(72, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'In some cases you want to switch to another content section from within the active content. This is possible using the data-uk-switcher-item attribute. To target the items, you need to set the data attribute to the number of the respective content item.', 'Dynamically transition through different content panes.', 4, 'Switcher in-content', 'PCEtLSBUaGlzIGlzIHRoZSBuYXYgY29udGFpbmluZyB0aGUgdG9nZ2xpbmcgZWxlbWVudHMgLS0+DQo8dWwgZGF0YS11ay1zd2l0Y2hlcj0ie2Nvbm5lY3Q6JyNteS1pZCd9Ij4NCiAgICA8bGk+PGEgaHJlZj0iIj4uLi48L2E+PC9saT4NCjwvdWw+DQoNCjwhLS0gVGhpcyBpcyB0aGUgY29udGFpbmVyIG9mIHRoZSBjb250ZW50IGl0ZW1zIC0tPg0KPHVsIGlkPSJteS1pZCIgY2xhc3M9InVrLXN3aXRjaGVyIj4NCiAgICA8bGk+IC4uLiA8YSBocmVmPSIiIGRhdGEtdWstc3dpdGNoZXItaXRlbT0iMCI+Li4uPC9hPjwvbGk+DQogICAgPGxpPiAuLi4gPGEgaHJlZj0iIiBkYXRhLXVrLXN3aXRjaGVyLWl0ZW09IjEiPi4uLjwvYT48L2xpPg0KPC91bD4=', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:04:24', '2017-11-11 22:09:27', 10, '', 8, 'c2e83f1f-facd-43ba-ae8d-fc3ccc1debc7'),
(73, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'It is also possible to connect multiple content containers. Just extend the connect parameter with the ID of the additional container.', 'Dynamically transition through different content panes.', 4, 'Switcher multiple-items', 'PCEtLSBUaGlzIGlzIHRoZSBuYXYgY29udGFpbmluZyB0aGUgdG9nZ2xpbmcgZWxlbWVudHMgLS0+DQo8dWwgZGF0YS11ay1zd2l0Y2hlcj0ie2Nvbm5lY3Q6JyNteS1pZC1vbmUsICNteS1pZC10d28nfSI+DQogICAgPGxpPjxhIGhyZWY9IiI+Li4uPC9hPjwvbGk+DQo8L3VsPg0KDQo8IS0tIFRoZXNlIGFyZSB0aGUgY29udGFpbmVycyBvZiB0aGUgY29udGVudCBpdGVtcyAtLT4NCjx1bCBpZD0ibXktaWQtb25lIiBjbGFzcz0idWstc3dpdGNoZXIiPg0KICAgIDxsaT4uLi48L2xpPg0KPC91bD4NCg0KPHVsIGlkPSJteS1pZC10d28iIGNsYXNzPSJ1ay1zd2l0Y2hlciI+DQogICAgPGxpPi4uLjwvbGk+DQo8L3VsPg==', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:04:53', '2017-11-11 22:09:27', 10, '', 8, '7ca69d59-8d39-4d54-a88b-f9c673fcef2d'),
(74, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The Switcher component allows you to add different animations to items when toggling between them. All you need to do is add the animation parameter to the data-attribute and define the animation that you want to apply. Check the table below for an overview of the animations provided.\r\n\r\nYou can also apply multiple animations by using the uk-animation-* classes from the Animation component. That way you can even create your own custom class to apply a different transition to the switcher.', 'Dynamically transition through different content panes.', 4, 'Switcher animation', 'PCEtLSBUaGlzIGlzIHRoZSBjb250YWluZXIgb2YgdGhlIHRvZ2dsaW5nIGVsZW1lbnRzIC0tPg0KPHVsIGRhdGEtdWstc3dpdGNoZXI9Intjb25uZWN0OicjbXktaWQnLCBhbmltYXRpb246ICd1ay1hbmltYXRpb24tZmFkZSwgdWstYW5pbWF0aW9uLXNsaWRlLWxlZnQnfSI+DQogICAgPGxpPjxhIGhyZWY9IiI+Li4uPC9hPjwvbGk+DQo8L3VsPg0KDQo8IS0tIFRoaXMgaXMgdGhlIGNvbnRhaW5lciBvZiB0aGUgY29udGVudCBpdGVtcyAtLT4NCjx1bCBpZD0ibXktaWQiIGNsYXNzPSJ1ay1zd2l0Y2hlciI+DQogICAgPGxpPi4uLjwvbGk+DQo8L3VsPg==', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:06:42', '2017-11-11 22:09:27', 10, '', 8, '2d1b0fad-f2ff-49b8-97dc-aab9d3553a15'),
(75, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'As an exception to the rule, add the data-uk-tab=\"{connect:\'#ID\'}\" attribute, using the parameter \"tab\" instead of \"switcher\", to the tabbed navigation to combine the switcher with the Tab component.', 'Dynamically transition through different content panes.', 4, 'Switcher tabs-horizontal', 'PCEtLSBUaGlzIGlzIHRoZSB0YWJiZWQgbmF2aWdhdGlvbiBjb250YWluaW5nIHRoZSB0b2dnbGluZyBlbGVtZW50cyAtLT4NCjx1bCBjbGFzcz0idWstdGFiIiBkYXRhLXVrLXRhYj0ie2Nvbm5lY3Q6JyNteS1pZCd9Ij4NCiAgICA8bGk+PGEgaHJlZj0iIj4uLi48L2E+PC9saT4NCjwvdWw+DQoNCjwhLS0gVGhpcyBpcyB0aGUgY29udGFpbmVyIG9mIHRoZSBjb250ZW50IGl0ZW1zIC0tPg0KPHVsIGlkPSJteS1pZCIgY2xhc3M9InVrLXN3aXRjaGVyIHVrLW1hcmdpbiI+DQogICAgPGxpPi4uLjwvbGk+DQo8L3VsPg==', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:08:04', '2017-11-11 22:09:27', 10, '', 8, 'f271532f-7bbb-4fab-a21c-7487ed72790e'),
(76, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'Use the Grid component to display content correctly with a vertical tabbed navigation.', 'Dynamically transition through different content panes.', 4, 'Switcher tabs-vertical', 'PCEtLSBUaGlzIGlzIHRoZSBsZWZ0IHZlcnRpY2FsIHRhYmJlZCBuYXZpZ2F0aW9uIC0tPg0KPGRpdiBjbGFzcz0idWstZ3JpZCI+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtbWVkaXVtLTEtMiI+DQogICAgICAgIDwhLS0gVGhpcyBpcyB0aGUgdmVydGljYWwgdGFiYmVkIG5hdmlnYXRpb24gY29udGFpbmluZyB0aGUgdG9nZ2xpbmcgZWxlbWVudHMgLS0+DQogICAgICAgIDx1bCBjbGFzcz0idWstdGFiIHVrLXRhYi1sZWZ0IiBkYXRhLXVrLXRhYj0ie2Nvbm5lY3Q6JyNteS1pZCd9Ij4uLi48L3VsPg0KICAgIDwvZGl2Pg0KICAgIDxkaXYgY2xhc3M9InVrLXdpZHRoLW1lZGl1bS0xLTIiPg0KICAgICAgICA8IS0tIFRoaXMgaXMgdGhlIGNvbnRhaW5lciBvZiB0aGUgY29udGVudCBpdGVtcyAtLT4NCiAgICAgICAgPHVsIGlkPSJteS1pZCIgY2xhc3M9InVrLXN3aXRjaGVyIj4uLi48L3VsPg0KICAgIDwvZGl2Pg0KPC9kaXY+DQoNCjwhLS0gVGhpcyBpcyB0aGUgcmlnaHQgdmVydGljYWwgdGFiYmVkIG5hdmlnYXRpb24gLS0+DQo8ZGl2IGNsYXNzPSJ1ay1ncmlkIj4NCiAgICA8ZGl2IGNsYXNzPSJ1ay13aWR0aC1tZWRpdW0tMS0yIHVrLXB1c2gtMS0yIj4NCiAgICAgICAgPCEtLSBUaGlzIGlzIHRoZSB2ZXJ0aWNhbCB0YWJiZWQgbmF2aWdhdGlvbiBjb250YWluaW5nIHRoZSB0b2dnbGluZyBlbGVtZW50cyAtLT4NCiAgICAgICAgPHVsIGNsYXNzPSJ1ay10YWIgdWstdGFiLXJpZ2h0IiBkYXRhLXVrLXRhYj0ie2Nvbm5lY3Q6JyNteS1pZCd9Ij4uLi48L3VsPg0KICAgIDwvZGl2Pg0KICAgIDxkaXYgY2xhc3M9InVrLXdpZHRoLW1lZGl1bS0xLTIgdWstcHVsbC0xLTIiPg0KICAgICAgICA8IS0tIFRoaXMgaXMgdGhlIGNvbnRhaW5lciBvZiB0aGUgY29udGVudCBpdGVtcyAtLT4NCiAgICAgICAgPHVsIGlkPSJteS1pZCIgY2xhc3M9InVrLXN3aXRjaGVyIj4uLi48L3VsPg0KICAgIDwvZGl2Pg0KPC9kaXY+', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:09:01', '2017-11-11 22:09:27', 10, '', 8, '86a0a1f5-5cce-4d65-9c74-2e39c6ba1bf8'),
(77, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The switcher can also be applied to buttons or button groups from the Button component. Just add the switcher data attribute to a element around a group of buttons or to the element with the .button-group class.', 'Dynamically transition through different content panes.', 4, 'Switcher button-group', 'PCEtLSBUaGlzIGlzIHRoZSBidXR0b24gZ3JvdXAgY29udGFpbmluZyB0aGUgdG9nZ2xpbmcgYnV0dG9ucyAtLT4NCjxkaXYgY2xhc3M9InVrLWJ1dHRvbi1ncm91cCIgZGF0YS11ay1zd2l0Y2hlcj0ie2Nvbm5lY3Q6JyNteS1pZCd9Ij4NCiAgICA8YnV0dG9uIGNsYXNzPSJ1ay1idXR0b24iIHR5cGU9ImJ1dHRvbiI+Li4uPC9idXR0b24+DQo8L2Rpdj4NCg0KPCEtLSBUaGlzIGlzIHRoZSBjb250YWluZXIgb2YgdGhlIGNvbnRlbnQgaXRlbXMgLS0+DQo8dWwgaWQ9Im15LWlkIiBjbGFzcz0idWstc3dpdGNoZXIgdWstbWFyZ2luIj4uLi48L3VsPg==', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:10:00', '2017-11-11 22:09:27', 10, '', 8, 'd252e658-4c57-4115-845c-0bdf66f4f640'),
(78, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'To apply the switcher to the Nav component, add the data attribute to the nav . Use the Grid component to arrange nav and content in a grid layout.', 'Dynamically transition through different content panes.', 4, 'Switcher navs', 'PGRpdiBjbGFzcz0idWstZ3JpZCI+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtbWVkaXVtLTEtNCI+DQoNCiAgICAgICAgPCEtLSBUaGlzIGlzIHRoZSBuYXYgY29udGFpbmluZyB0aGUgdG9nZ2xpbmcgZWxlbWVudHMgLS0+DQogICAgICAgIDx1bCBjbGFzcz0idWstbmF2IHVrLW5hdi1zaWRlIiBkYXRhLXVrLXN3aXRjaGVyPSJ7Y29ubmVjdDonI215LWlkJ30iPg0KICAgICAgICAgICAgPGxpPjxhIGhyZWY9IiI+Li4uPC9hPjwvbGk+DQogICAgICAgIDwvdWw+DQogICAgPC9kaXY+DQogICAgPGRpdiBjbGFzcz0idWstd2lkdGgtbWVkaXVtLTMtNCI+DQoNCiAgICAgICAgPCEtLSBUaGlzIGlzIHRoZSBjb250YWluZXIgb2YgdGhlIGNvbnRlbnQgaXRlbXMgLS0+DQogICAgICAgIDx1bCBpZD0ibXktaWQiIGNsYXNzPSJ1ay1zd2l0Y2hlciI+DQogICAgICAgICAgICA8bGk+Li4uPC9saT4NCiAgICAgICAgPC91bD4NCiAgICA8L2Rpdj4NCjwvZGl2Pg==', 5, 'http://getuikit.com/docs/switcher.html', 'The switcher component consists of a number of toggles and their related content items. Add the data-uk-switcher=\"{connect:\'#ID\'}\" attribute to the element which contains the toggles, targetting the same id as is used on the element containing the content items. Add the .uk-switcher class to the same element. Typically the switcher is combined with other components, some of which will be shown here.', '', 1, '2015-06-01 20:10:30', '2017-11-11 22:09:27', 10, '', 8, '517a296e-57c2-4d4b-9aae-589b23d1a398'),
(79, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Hide, switch or change the appearence of different contents through a toggle.', 4, 'Toggle default', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIiBkYXRhLXVrLXRvZ2dsZT0ie3RhcmdldDonI215LWlkJ30iPi4uLjwvYnV0dG9uPg0KDQo8ZGl2IGlkPSJteS1pZCI+Li4uPC9kaXY+', 5, 'http://getuikit.com/docs/toggle.html', 'To apply this component, just add the data-uk-toggle=\"{target: #ID}\" attribute to a or element. You can use any selector with the toggle attribute.\r\n\r\nThe toggle will add or remove a class from the item. By default, it adds the .uk-hidden class to hide the element.', '', 1, '2015-06-01 20:12:07', '2017-11-11 22:09:27', 10, '', 8, 'dae732b0-379e-4412-9bdb-559f87dc5992'),
(80, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'You can also toggle multiple items at the same time. Just use the appropriate selector.', 'Hide, switch or change the appearence of different contents through a toggle.', 4, 'Toggle multiple', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIiBkYXRhLXVrLXRvZ2dsZT0ie3RhcmdldDonLm15LWNsYXNzJ30iPi4uLjwvYnV0dG9uPg0KDQo8ZGl2IGNsYXNzPSJteS1jbGFzcyI+Li4uPC9kaXY+DQo8ZGl2IGNsYXNzPSJteS1jbGFzcyB1ay1oaWRkZW4iPi4uLjwvZGl2Pg==', 5, 'http://getuikit.com/docs/toggle.html', 'To apply this component, just add the data-uk-toggle=\"{target: #ID}\" attribute to a or element. You can use any selector with the toggle attribute.\r\n\r\nThe toggle will add or remove a class from the item. By default, it adds the .uk-hidden class to hide the element.', '', 1, '2015-06-01 20:12:34', '2017-11-11 22:09:27', 10, '', 8, '7a7c7acb-b309-40c5-92fe-33702c5f2f16'),
(81, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'You can also toggle multiple items at the same time. Just use the appropriate selector.', 'Hide, switch or change the appearence of different contents through a toggle.', 4, 'Toggle class', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIiBkYXRhLXVrLXRvZ2dsZT0ie3RhcmdldDonI215LWlkJywgY2xzOid1ay1wYW5lbC1ib3gtcHJpbWFyeSd9Ij4uLi48L2J1dHRvbj4NCg0KPGRpdiBpZD0ibXktaWQiIGNsYXNzPSJ1ay1wYW5lbCB1ay1wYW5lbC1ib3giPi4uLjwvZGl2Pg==', 5, 'http://getuikit.com/docs/toggle.html', 'To apply this component, just add the data-uk-toggle=\"{target: #ID}\" attribute to a or element. You can use any selector with the toggle attribute.\r\n\r\nThe toggle will add or remove a class from the item. By default, it adds the .uk-hidden class to hide the element.', '', 1, '2015-06-01 20:13:06', '2017-11-11 22:09:27', 19, '', 8, '10a7755a-4309-4172-b1bd-89a2e0d6edb6'),
(82, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'The Toggle component allows you to add animations to items when toggling between them. Just add one of the .uk-animation-* classes from the Animation component to the animation parameter. The class will be applied to the in as well as the out animation. If you prefer a different out animation, just add another class.', 'Hide, switch or change the appearence of different contents through a toggle.', 4, 'Toggle animations', 'PGJ1dHRvbiBjbGFzcz0idWstYnV0dG9uIiBkYXRhLXVrLXRvZ2dsZT0ie3RhcmdldDonI215LWlkJywgYW5pbWF0aW9uOid1ay1hbmltYXRpb24tc2xpZGUtbGVmdCwgdWstYW5pbWF0aW9uLXNsaWRlLWJvdHRvbSd9Ij4uLi48L2J1dHRvbj4NCg0KPGRpdiBpZD0ibXktaWQiPi4uLjwvZGl2Pg==', 5, 'http://getuikit.com/docs/toggle.html', 'To apply this component, just add the data-uk-toggle=\"{target: #ID}\" attribute to a or element. You can use any selector with the toggle attribute.\r\n\r\nThe toggle will add or remove a class from the item. By default, it adds the .uk-hidden class to hide the element.', '', 1, '2015-06-01 20:13:34', '2017-11-11 22:09:27', 19, '', 8, '31f54883-606b-43d5-b110-fba9774b7a34'),
(83, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Trigger events and animations while scrolling your page.', 4, 'Scrollspy default', 'PGRpdiBkYXRhLXVrLXNjcm9sbHNweT0ie2NsczondWstYW5pbWF0aW9uLWZhZGUnfSI+Li4uPC9kaXY+DQoNCjxkaXYgZGF0YS11ay1zY3JvbGxzcHk9IntjbHM6J3VrLWFuaW1hdGlvbi1mYWRlJywgcmVwZWF0OiB0cnVlfSI+Li4uPC9kaXY+DQoNCjxkaXYgZGF0YS11ay1zY3JvbGxzcHk9IntjbHM6J3VrLWFuaW1hdGlvbi1mYWRlJywgZGVsYXk6OTAwfSI+Li4uPC9kaXY+', 5, 'http://getuikit.com/docs/scrollspy.html', 'The scrollspy component listens to page scrolling and triggers events based on the scroll position. For example, if you scroll down a page and an element appears the first time in the viewport you can trigger a smooth animation to fade in the element. Just add the data-uk-scrollspy attribute and the following options.', '', 1, '2015-06-01 20:15:00', '2017-11-11 22:09:27', 19, '', 8, '39b72b40-85ec-4cc6-aded-c86611f31c24'),
(84, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'You can also group scrollspy elements, so you won\'t have to apply the data attribute to each of them. Just add the data-uk-scollspy\"{target:\'MY-CLASS\'}\" attribute to a container element, targetting the selector the items you want to animate within the container. When using a delay it will be applied cumulatively to the items within the row that scrolls into view. The delay will be resetted for the next row within the group when it scrolls into view.', 'Trigger events and animations while scrolling your page.', 4, 'Scrollspy groups', 'PGRpdiBkYXRhLXVrLXNjcm9sbHNweT0ie2NsczondWstYW5pbWF0aW9uLWZhZGUnLCB0YXJnZXQ6Jy5teS1jbGFzcycsIGRlbGF5OjMwMH0iPg0KDQogICAgPCEtLSBUaGlzIGl0ZW0gaGFzIG5vIGRlbGF5IC0tPg0KICAgIDxkaXYgY2xhc3M9Im15LWNsYXNzIj4uLi48L2Rpdj4NCg0KICAgIDwhLS0gVGhpcyBpdGVtIGhhcyBhIGRlbGF5IG9mIDMwMG1zIC0tPg0KICAgIDxkaXYgY2xhc3M9Im15LWNsYXNzIj4uLi48L2Rpdj4NCg0KICAgIDwhLS0gVGhpcyBpdGVtIGhhcyBhIGRlbGF5IG9mIDYwMG1zIC0tPg0KICAgIDxkaXYgY2xhc3M9Im15LWNsYXNzIj4uLi48L2Rpdj4NCg0KPC9kaXY+', 5, 'http://getuikit.com/docs/scrollspy.html', 'The scrollspy component listens to page scrolling and triggers events based on the scroll position. For example, if you scroll down a page and an element appears the first time in the viewport you can trigger a smooth animation to fade in the element. Just add the data-uk-scrollspy attribute and the following options.', '', 1, '2015-06-01 20:15:18', '2017-11-11 22:09:27', 20, '', 8, '6e666e60-5206-4633-a433-83f41f914ed7'),
(85, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create a fancy lightbox for images and videos utilizing the Modal component.', 4, 'Lightbox single-image', 'PGEgdGl0bGU9IlRpdGxlIiBkYXRhLXVrLWxpZ2h0Ym94PSIiIGhyZWY9IiIgY2xhc3M9InVrLWJ1dHRvbiI+T3BlbiBsaWdodGJveDwvYT4=', 5, 'http://getuikit.com/docs/lightbox.html', 'To apply this component, add the data-uk-lightbox attribute to an anchor linking to the image you wish to display. If a title attribute exists it will be displayed as a caption for the lightbox.', '', 1, '2015-06-01 20:18:50', '2017-11-11 22:09:27', 19, '', 9, 'b3fb0556-ff50-4380-b7f7-8f2519e02d81'),
(86, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'You can link multiple images to the same lightbox and switch between them from within the lightbox, thus creating a gallery. Just add the {group:\'my-group\'} option to the data attribute of each item using the same name on all items that you want to group. Make sure to include the CSS from the Slidenav component, so you can navigate between the items.', 'Create a fancy lightbox for images and videos utilizing the Modal component.', 4, 'Lightbox groups-image', 'PGRpdiBkYXRhLXVrLWdyaWQtbWFyZ2luPSIiIGNsYXNzPSJ1ay1ncmlkIHVrLWdyaWQtd2lkdGgtbWVkaXVtLTEtNCI+DQogICAgPGRpdj4NCiAgICAgICAgPGEgdGl0bGU9IlRpdGxlIiBkYXRhLXVrLWxpZ2h0Ym94PSJ7Z3JvdXA6J2dyb3VwMSd9IiBocmVmPSJpbWFnZXMvcGxhY2Vob2xkZXJfODAweDYwMF8xLmpwZyI+DQogICAgICAgICAgICA8aW1nIHdpZHRoPSI4MDAiIGhlaWdodD0iNjAwIiBhbHQ9IiIgc3JjPSJpbWFnZXMvcGxhY2Vob2xkZXJfODAweDYwMF8xLmpwZyI+DQogICAgICAgIDwvYT4NCiAgICA8L2Rpdj4NCiAgICA8ZGl2Pg0KICAgICAgICA8YSB0aXRsZT0iVGl0bGUiIGRhdGEtdWstbGlnaHRib3g9Intncm91cDonZ3JvdXAxJ30iIGRhdGEtbGlnaHRib3gtdHlwZT0iaW1hZ2UiIGhyZWY9ImltYWdlcy9wbGFjZWhvbGRlcl84MDB4NjAwXzIuanBnIj4NCiAgICAgICAgICAgIDxpbWcgd2lkdGg9IjgwMCIgaGVpZ2h0PSI2MDAiIGFsdD0iIiBzcmM9ImltYWdlcy9wbGFjZWhvbGRlcl84MDB4NjAwXzIuanBnIj4NCiAgICAgICAgPC9hPg0KICAgIDwvZGl2Pg0KICAgIDxkaXY+DQogICAgICAgIDxhIHRpdGxlPSJUaXRsZSIgZGF0YS11ay1saWdodGJveD0ie2dyb3VwOidncm91cDEnfSIgZGF0YS1saWdodGJveC10eXBlPSJpbWFnZSIgaHJlZj0iaW1hZ2VzL3BsYWNlaG9sZGVyXzgwMHg2MDBfMy5qcGciPg0KICAgICAgICAgICAgPGltZyB3aWR0aD0iODAwIiBoZWlnaHQ9IjYwMCIgYWx0PSIiIHNyYz0iaW1hZ2VzL3BsYWNlaG9sZGVyXzgwMHg2MDBfMy5qcGciPg0KICAgICAgICA8L2E+DQogICAgPC9kaXY+DQogICAgPGRpdj4NCiAgICAgICAgPGEgdGl0bGU9IlRpdGxlIiBkYXRhLXVrLWxpZ2h0Ym94PSJ7Z3JvdXA6J2dyb3VwMSd9IiBkYXRhLWxpZ2h0Ym94LXR5cGU9ImltYWdlIiBocmVmPSJpbWFnZXMvcGxhY2Vob2xkZXJfODAweDYwMF80LmpwZyI+DQogICAgICAgICAgICA8aW1nIHdpZHRoPSI4MDAiIGhlaWdodD0iNjAwIiBhbHQ9IiIgc3JjPSJpbWFnZXMvcGxhY2Vob2xkZXJfODAweDYwMF80LmpwZyI+DQogICAgICAgIDwvYT4NCiAgICA8L2Rpdj4NCjwvZGl2Pg==', 5, 'http://getuikit.com/docs/lightbox.html', 'To apply this component, add the data-uk-lightbox attribute to an anchor linking to the image you wish to display. If a title attribute exists it will be displayed as a caption for the lightbox.', '', 1, '2015-06-01 20:21:01', '2017-11-11 22:09:27', 20, '', 9, '9fb9dbd8-23b1-4a85-a144-c4ad95f105d1'),
(87, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'A lightbox is not restricted to images. Other media, like videos, can be displayed inside a lightbox and it will automatically generate the correct output by evaluating your path.', 'Create a fancy lightbox for images and videos utilizing the Modal component.', 4, 'Lightbox content-sources', 'PHA+DQogICAgPGEgdGl0bGU9IlRpdGxlIiBkYXRhLXVrLWxpZ2h0Ym94PSJ7Z3JvdXA6J2dyb3VwMid9IiBocmVmPSJpbWFnZXMvcGxhY2Vob2xkZXJfODAweDYwMF8xLmpwZyIgY2xhc3M9InVrLWJ1dHRvbiI+SW1hZ2U8L2E+DQogICAgPGEgZGF0YS11ay1saWdodGJveD0ie2dyb3VwOidncm91cDInfSIgaHJlZj0iaHR0cDovL3d3dy5xdWlya3Ntb2RlLm9yZy9odG1sNS92aWRlb3MvYmlnX2J1Y2tfYnVubnkubXA0IiBjbGFzcz0idWstYnV0dG9uIj5NUDQ8L2E+DQogICAgPGEgZGF0YS11ay1saWdodGJveD0ie2dyb3VwOidncm91cDInfSIgaHJlZj0iaHR0cDovL3ZpbWVvLmNvbS8xMDg0NTM3IiBjbGFzcz0idWstYnV0dG9uIj5WaW1lbzwvYT4NCiAgICA8YSBkYXRhLXVrLWxpZ2h0Ym94PSJ7Z3JvdXA6J2dyb3VwMid9IiBocmVmPSJodHRwczovL3d3dy55b3V0dWJlLmNvbS93YXRjaD92PVlFN1Z6bEx0cC00IiBjbGFzcz0idWstYnV0dG9uIj5Zb3VUdWJlPC9hPg0KPC9wPg==', 5, 'http://getuikit.com/docs/lightbox.html', 'To apply this component, add the data-uk-lightbox attribute to an anchor linking to the image you wish to display. If a title attribute exists it will be displayed as a caption for the lightbox.', '', 1, '2015-06-01 20:22:21', '2017-11-11 22:09:27', 19, '', 9, '4e0dcf96-2140-49e9-bbed-8f84b36f4f3c'),
(88, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'To display multiple content sections at the same time without one collapsing when the other one is opened, add the {collapse: false} option to the date attribute.', 'Create a list of items, allowing each item\'s content to be expanded and collapsed by clicking its header.', 4, 'Accordion', 'PGRpdiBjbGFzcz0idWstYWNjb3JkaW9uIiBkYXRhLXVrLWFjY29yZGlvbj4NCg0KICAgIDxoMyBjbGFzcz0idWstYWNjb3JkaW9uLXRpdGxlIj4uLi48L2gzPg0KICAgIDxkaXYgY2xhc3M9InVrLWFjY29yZGlvbi1jb250ZW50Ij4uLi48L2Rpdj4NCg0KICAgIDxoMyBjbGFzcz0idWstYWNjb3JkaW9uLXRpdGxlIj4uLi48L2gzPg0KICAgIDxkaXYgY2xhc3M9InVrLWFjY29yZGlvbi1jb250ZW50Ij4uLi48L2Rpdj4NCg0KICAgIDxoMyBjbGFzcz0idWstYWNjb3JkaW9uLXRpdGxlIj4uLi48L2gzPg0KICAgIDxkaXYgY2xhc3M9InVrLWFjY29yZGlvbi1jb250ZW50Ij4uLi48L2Rpdj4NCg0KPC9kaXY+', 5, 'http://getuikit.com/docs/accordion.html', 'To apply the Accordion component, add the uk-accordion class and the data-uk-accordion attribute to a container element. Add the uk-accordion-content class to each of the content sections within the container. Finally, add the uk-accordion-title class to any element, like a heading, above the content section to create a toggle.', '', 1, '2015-06-01 20:24:59', '2017-11-11 22:09:27', 20, '', 10, 'f5bd905c-8d79-4eb6-bb61-e139af27f573'),
(90, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'This is a input field for uikit form', 'Add Input field - row', 4, 'Input field', 'ICAgICAgICA8ZGl2IGNsYXNzPSJ1ay1mb3JtLXJvdyI+DQoJCTxsYWJlbCBjbGFzcz0idWstZm9ybS1sYWJlbCIgPg0KCQkJPD9waHAgZWNobyBUZXh0OjpfKCdMYWJlbCcpOyA/Pg0KCQk8L2xhYmVsPg0KCQk8aW5wdXQgdHlwZT0idGV4dCIgbmFtZT0ia2V5IiBwbGFjZWhvbGRlcj0iPD9waHAgZWNobyBUZXh0OjpfKCdhZGQgc29tZSB0ZXh0IGhlcmUhJyk7ID8+Ij4gPHNwYW4gY2xhc3M9InVrLWZvcm0taGVscC1pbmxpbmUiPjw/cGhwIGVjaG8gVGV4dDo6XygnaGVscCBuZWVkZWQnKTsgPz48L3NwYW4+DQoJPC9kaXY+', 3, 'http://getuikit.com/docs/form.html', '', '', 1, '2015-11-29 03:54:40', '2017-11-11 22:09:27', 20, '', 12, 'f1319e45-395a-492e-a899-f2fec00de5ec'),
(91, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'This is a textarea field for uikit form', 'Add textarea - row', 4, 'Textarea', 'CTxkaXYgY2xhc3M9InVrLWZvcm0tcm93Ij4NCgkJPGxhYmVsIGNsYXNzPSJ1ay1mb3JtLWxhYmVsIiA+DQoJCQk8P3BocCBlY2hvIEpUZXh0OjpfKCdMYWJlbCcpOyA/Pg0KCQk8L2xhYmVsPg0KCQk8dGV4dGFyZWEgY29scz0iIiByb3dzPSIiICBzdHlsZT0id2lkdGg6IDEwMCU7IGhlaWdodDogMjE2cHg7IiBwbGFjZWhvbGRlcj0iPD9waHAgZWNobyBKVGV4dDo6XygnYWRkIHNvbWUgdGV4dCBoZXJlIScpOyA/PiI+PHx8fHxGSVh8fHx8fHx0ZXh0YXJlYT4NCgkJPHAgY2xhc3M9InVrLWZvcm0taGVscC1ibG9jayI+PD9waHAgZWNobyBKVGV4dDo6XygnaGVscCBuZWVkZWQnKTsgPz48L3A+DQoJPC9kaXY+', 3, 'http://getuikit.com/docs/form.html', '', '', 1, '2015-11-29 03:55:57', '2017-11-11 22:09:27', 22, '', 12, '22207e7c-6096-4b6e-8e03-0616745c8447'),
(92, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'This is a uikit form', 'Add Form', 4, 'Form', 'PGZvcm0gY2xhc3M9InVrLWZvcm0iPg0KICAgIDxmaWVsZHNldD4NCiAgICAgICAgPGxlZ2VuZD48P3BocCBlY2hvIFRleHQ6Ol8oJ0xlZ2VuZCcpOyA/PjwvbGVnZW5kPg0KICAgICAgICA8ZGl2IGNsYXNzPSJ1ay1mb3JtLXJvdyI+DQoJCTxsYWJlbCBjbGFzcz0idWstZm9ybS1sYWJlbCIgPg0KCQkJPD9waHAgZWNobyBUZXh0OjpfKCdMYWJlbCcpOyA/Pg0KCQk8L2xhYmVsPg0KCQk8aW5wdXQgdHlwZT0idGV4dCIgbmFtZT0ia2V5IiBwbGFjZWhvbGRlcj0iPD9waHAgZWNobyBUZXh0OjpfKCdhZGQgc29tZSB0ZXh0IGhlcmUhJyk7ID8+Ij4gPHNwYW4gY2xhc3M9InVrLWZvcm0taGVscC1pbmxpbmUiPjw/cGhwIGVjaG8gVGV4dDo6XygnaGVscCBuZWVkZWQnKTsgPz48L3NwYW4+DQoJPC9kaXY+DQogICAgICAgIDxkaXYgY2xhc3M9InVrLWZvcm0tcm93Ij4NCgkJPGxhYmVsIGNsYXNzPSJ1ay1mb3JtLWxhYmVsIiA+DQoJCQk8P3BocCBlY2hvIFRleHQ6Ol8oJ0xhYmVsJyk7ID8+DQoJCTwvbGFiZWw+DQoJCTx0ZXh0YXJlYSBjb2xzPSIiIHJvd3M9IiIgIHN0eWxlPSJ3aWR0aDogMTAwJTsgaGVpZ2h0OiAyMTZweDsiIHBsYWNlaG9sZGVyPSI8P3BocCBlY2hvIFRleHQ6Ol8oJ2FkZCBzb21lIHRleHQgaGVyZSEnKTsgPz4iPjx8fHx8fEZJWHx8fHx8dGV4dGFyZWE+DQoJCTxwIGNsYXNzPSJ1ay1mb3JtLWhlbHAtYmxvY2siPjw/cGhwIGVjaG8gVGV4dDo6XygnaGVscCBuZWVkZWQnKTsgPz48L3A+DQoJPC9kaXY+DQogICAgPC9maWVsZHNldD4NCjwvZm9ybT4=', 1, 'http://getuikit.com/docs/form.html', 'To apply this component, add the .uk-form class to a form element. All form control elements are placed side by side within the next row.', '', 1, '2015-11-29 03:57:03', '2017-11-20 23:42:28', 21, '', 12, '6d6bebcf-e291-4344-a39e-f072fa22bf71'),
(95, 'Vast Development Method', 'joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', '', 'Create a list of items that can be shown individually by clicking an item\'s header.', 3, 'Accordion', 'PHVsIHVrLWFjY29yZGlvbj4NCiAgICA8bGkgY2xhc3M9InVrLW9wZW4iPg0KICAgICAgICA8aDMgY2xhc3M9InVrLWFjY29yZGlvbi10aXRsZSI+SXRlbSAxPC9oMz4NCiAgICAgICAgPGRpdiBjbGFzcz0idWstYWNjb3JkaW9uLWNvbnRlbnQiPg0KICAgICAgICAgICAgPHA+TG9yZW0gaXBzdW0gZG9sb3Igc2l0IGFtZXQsIGNvbnNlY3RldHVyIGFkaXBpc2NpbmcgZWxpdCwgc2VkIGRvIGVpdXNtb2QgdGVtcG9yIGluY2lkaWR1bnQgdXQgbGFib3JlIGV0IGRvbG9yZSBtYWduYSBhbGlxdWEuPC9wPg0KICAgICAgICA8L2Rpdj4NCiAgICA8L2xpPg0KICAgIDxsaT4NCiAgICAgICAgPGgzIGNsYXNzPSJ1ay1hY2NvcmRpb24tdGl0bGUiPkl0ZW0gMjwvaDM+DQogICAgICAgIDxkaXYgY2xhc3M9InVrLWFjY29yZGlvbi1jb250ZW50Ij4NCiAgICAgICAgICAgIDxwPlV0IGVuaW0gYWQgbWluaW0gdmVuaWFtLCBxdWlzIG5vc3RydWQgZXhlcmNpdGF0aW9uIHVsbGFtY28gbGFib3JpcyBuaXNpIHV0IGFsaXF1aXAgZXggZWEgY29tbW9kbyBjb25zZXF1YXQuIER1aXMgYXV0ZSBpcnVyZSBkb2xvciByZXByZWhlbmRlcml0LjwvcD4NCiAgICAgICAgPC9kaXY+DQogICAgPC9saT4NCiAgICA8bGk+DQogICAgICAgIDxoMyBjbGFzcz0idWstYWNjb3JkaW9uLXRpdGxlIj5JdGVtIDM8L2gzPg0KICAgICAgICA8ZGl2IGNsYXNzPSJ1ay1hY2NvcmRpb24tY29udGVudCI+DQogICAgICAgICAgICA8cD5EdWlzIGF1dGUgaXJ1cmUgZG9sb3IgaW4gcmVwcmVoZW5kZXJpdCBpbiB2b2x1cHRhdGUgdmVsaXQgZXNzZSBjaWxsdW0gZG9sb3JlIGV1IGZ1Z2lhdCBudWxsYSBwYXJpYXR1ci4gRXhjZXB0ZXVyIHNpbnQgb2NjYWVjYXQgY3VwaWRhdGF0IHByb2lkZW50LjwvcD4NCiAgICAgICAgPC9kaXY+DQogICAgPC9saT4NCjwvdWw+', 15, 'https://getuikit.com/docs/accordion', 'The Accordion component consists of a parent container with the uk-accordion attribute, and a title and content part for each accordion item.\r\n\r\n.uk-accordion-title - Defines and styles the toggle for each accordion item. Typically used on a heading.\r\n\r\n.uk-accordion-content - Defines the content part for each accordion item.\r\n\r\n', '', 1, '2017-11-20 17:21:09', '2017-11-20 23:41:14', 1, '', 14, 'c76d547f-8bcd-48e6-ba64-4ae971404a1b'),
(96, 'Vast Development Method', 'Joomla@vdm.io', 'Llewellyn van der Merwe', 'https://www.vdm.io/', 'FooTable is a jQuery plugin that aims to make HTML tables on smaller devices look awesome No matter how many columns of data you may have in them.\r\n\r\nHave you ever wanted to show a lot of data in a table, but hate how badly it scales on smaller mobile devices? The FooTable jQuery plugin solves this problem by allowing you to hide certain columns on smaller devices, but still allowing the user to expand each row to see the columns that were hidden.', 'metro-blue', 5, 'FooTable', 'PHRhYmxlIGNsYXNzPSJmb290YWJsZSBtZXRyby1ibHVlIiBkYXRhLWZpbHRlcj0iI2ZpbHRlciIgZGF0YS1wYWdlLXNpemU9IjUiPg0KICA8dGhlYWQ+DQogICAgPHRyPg0KICAgICAgPHRoIGRhdGEtdG9nZ2xlPSJ0cnVlIj5OYW1lPC90aD4NCiAgICAgIDx0aCBkYXRhLWhpZGU9InBob25lLHRhYmxldCI+UGhvbmU8L3RoPg0KICAgICAgPHRoIGRhdGEtaGlkZT0icGhvbmUsdGFibGV0Ij5FbWFpbDwvdGg+DQogICAgPC90cj4NCiAgPC90aGVhZD4NCiAgPHRib2R5Pg0KICAgIDx0cj4NCiAgICAgIDx0ZD5Cb2IgTWFuPC90ZD4NCiAgICAgIDx0ZD41NTUtMTIzNDU8L3RkPg0KICAgICAgPHRkPmJvYkBob21lLmNvbTwvdGQ+DQogICAgPC90cj4NCiAgICA8dHI+DQogICAgICA8dGQ+QnJpZGdldCBKb25lczwvdGQ+DQogICAgICA8dGQ+NTQ0LTc3NjY1NTwvdGQ+DQogICAgICA8dGQ+YmpvbmVzQG15c2l0ZS5jb208L3RkPg0KICAgIDwvdHI+DQogICAgPHRyPg0KICAgICAgPHRkPlRvbSBKb25lczwvdGQ+DQogICAgICA8dGQ+NTU1LTk5OTExPC90ZD4NCiAgICAgIDx0ZD5jcnVpc2UxQGNyYXp5LmNvbTwvdGQ+DQogICAgPC90cj4NCiAgPC90Ym9keT4NCjwvdGFibGU+', 32, 'https://github.com/fooplugins/FooTable/tree/V2', '', '', 1, '2015-09-26 14:07:03', '2017-11-25 22:24:55', 3, '', 15, '57eace63-c278-4685-8bb7-a40bfdee704e'),
(97, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-success', 2, 'Alerts - Success', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtc3VjY2VzcyIgcm9sZT0iYWxlcnQiPg0KICAgIDxzdHJvbmc+V2VsbCBkb25lITwvc3Ryb25nPiBZb3Ugc3VjY2Vzc2Z1bGx5IHJlYWQgdGhpcw0KICAgIGltcG9ydGFudCBhbGVydCBtZXNzYWdlLg0KPC9kaXY+', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-13 10:12:34', 1, '', 16, 'eac77139-a69b-4eef-9276-254194d2bed5'),
(98, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-heading', 2, 'Alerts - Heading', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtc3VjY2VzcyIgcm9sZT0iYWxlcnQiPg0KICA8aDQgY2xhc3M9ImFsZXJ0LWhlYWRpbmciPldlbGwgZG9uZSE8L2g0Pg0KICBZb3Ugc3VjY2Vzc2Z1bGx5IHJlYWQgdGhpcyBpbXBvcnRhbnQgYWxlcnQgbWVzc2FnZS4NCjwvZGl2Pg==', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:06:26', 1, '', 17, '7fdc4a3a-6b6b-4126-98d6-2c2dfe726f8d'),
(99, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-link', 2, 'Alerts - Link', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtZGFuZ2VyIiByb2xlPSJhbGVydCI+DQogIDxzdHJvbmc+T2ggc25hcCE8L3N0cm9uZz4NCiAgPGEgaHJlZj0iIyIgY2xhc3M9ImFsZXJ0LWxpbmsiPkNoYW5nZSBhIGZldyB0aGluZ3MgdXA8L2E+DQogIGFuZCB0cnkgc3VibWl0dGluZyBhZ2Fpbi4NCjwvZGl2Pg==', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:06:19', 1, '', 17, '0910fd26-4d44-4d85-827f-14207d99ce45'),
(100, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-danger', 2, 'Alerts - Danger', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtZGFuZ2VyIiByb2xlPSJhbGVydCI+DQogIDxzdHJvbmc+T2ggc25hcCE8L3N0cm9uZz4gQ2hhbmdlIGEgZmV3IHRoaW5ncyB1cCBhbmQgdHJ5IHN1Ym1pdHRpbmcgYWdhaW4uDQo8L2Rpdj4=', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:06:19', 1, '', 17, '597d1a5b-1dd9-438b-a019-5b074afa8191'),
(101, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-dismissible', 2, 'Alerts - Dismissible', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtd2FybmluZyBhbGVydC1kaXNtaXNzaWJsZSBmYWRlIHNob3ciIHJvbGU9ImFsZXJ0Ij4NCiAgPGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJjbG9zZSIgZGF0YS1kaXNtaXNzPSJhbGVydCIgYXJpYS1sYWJlbD0iQ2xvc2UiPg0KICAgIDxzcGFuIGFyaWEtaGlkZGVuPSJ0cnVlIj7Dlzwvc3Bhbj4NCiAgPC9idXR0b24+DQogIDxzdHJvbmc+SG9seSBndWFjYW1vbGUhPC9zdHJvbmc+IFlvdSBzaG91bGQgY2hlY2sgaW4gb24gc29tZSBvZiB0aG9zZSBmaWVsZHMgYmVsb3cuDQo8L2Rpdj4=', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:06:23', 1, '', 17, 'e0f1a436-8527-462b-ba27-cbe60504b8f6'),
(102, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-info', 2, 'Alerts - Info', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtaW5mbyIgcm9sZT0iYWxlcnQiPg0KICAgIDxzdHJvbmc+SGVhZHMgdXAhPC9zdHJvbmc+IFRoaXMgYWxlcnQgbmVlZHMgeW91ciBhdHRlbnRpb24sDQogICAgYnV0IGl0J3Mgbm90IHN1cGVyIGltcG9ydGFudC4NCjwvZGl2Pg==', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:06:08', 1, '', 18, 'c7a51b7a-c1b7-45cb-95c6-b8cda5d32417'),
(103, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-danger', 2, 'Badge - Danger', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLWRhbmdlciI+RGFuZ2VyPC9zcGFuPg==', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:21', 1, '', 19, '4cc7a7b5-7d3a-4086-8a00-d7b99e3db5b2'),
(104, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Provide contextual feedback messages for typical user actions with the handful of available and flexible alert messages.', 'alert-warning', 2, 'Alerts - Warning', 'PGRpdiBjbGFzcz0iYWxlcnQgYWxlcnQtaW5mbyIgcm9sZT0iYWxlcnQiPg0KICAgIDxzdHJvbmc+SGVhZHMgdXAhPC9zdHJvbmc+IFRoaXMgYWxlcnQgbmVlZHMgeW91ciBhdHRlbnRpb24sDQogICAgYnV0IGl0J3Mgbm90IHN1cGVyIGltcG9ydGFudC4NCjwvZGl2Pg==', 7, 'https://getbootstrap.com/docs/4.0/components/alerts/', 'Alerts are available for any length of text, as well as an optional dismiss button. For proper styling, use one of the eight required contextual classes (e.g., .alert-success).', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:06:13', 1, '', 20, 'f7de3d3c-326c-4039-a184-f0aa1e4719d3'),
(105, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-info', 2, 'Badge - Info', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLWluZm8iPkluZm88L3NwYW4+', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:15', 1, '', 21, 'b7eb3854-3024-440b-bb88-2197e3b934dc'),
(106, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-dark', 2, 'Badge - Dark', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLWRhcmsiPkRhcms8L3NwYW4+', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:28', 1, '', 21, 'c3e0aa51-2cbc-4bf3-8e84-1b6bc2672f2b'),
(107, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-light', 2, 'Badge - Light', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLWxpZ2h0Ij5MaWdodDwvc3Bhbj4=', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:26', 1, '', 22, 'f03cb9b8-fffd-41af-9c84-eeed30c97d4b'),
(108, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-pill', 2, 'Badge - Pill', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXBpbGwgYmFkZ2UtcHJpbWFyeSI+U2Vjb25kYXJ5PC9zcGFuPg==', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-11 23:53:03', 1, '', 23, '491da919-5afe-4cbb-8cec-1a4d49778c0a'),
(109, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-primary', 2, 'Badge - Primary', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXByaW1hcnkiPlByaW1hcnk8L3NwYW4+', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:06', 1, '', 23, 'c0d1d1f1-907a-4712-afc5-a905ff75bfbe'),
(110, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-secondary', 2, 'Badge - Secondary', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXNlY29uZGFyeSI+U2Vjb25kYXJ5PC9zcGFuPg==', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:09', 1, '', 24, '72bcef22-7fcc-4152-892f-23f4e619ef24'),
(111, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-warning', 2, 'Badge - Warning', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXdhcm5pbmciPldhcm5pbmc8L3NwYW4+', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:18', 1, '', 24, 'f6895007-f66b-4d66-ad52-9823e3b7dee0'),
(112, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Indicate the current page\'s location within a navigational hierarchy that automatically adds separators via CSS.', 'breadcrumb', 2, 'Breadcrumb', 'PG9sIGNsYXNzPSJicmVhZGNydW1iIj4NCiAgPGxpIGNsYXNzPSJicmVhZGNydW1iLWl0ZW0gYWN0aXZlIj5Ib21lPC9saT4NCjwvb2w+DQo8b2wgY2xhc3M9ImJyZWFkY3J1bWIiPg0KICA8bGkgY2xhc3M9ImJyZWFkY3J1bWItaXRlbSI+PGEgaHJlZj0iIyI+SG9tZTwvYT48L2xpPg0KICA8bGkgY2xhc3M9ImJyZWFkY3J1bWItaXRlbSBhY3RpdmUiPkxpYnJhcnk8L2xpPg0KPC9vbD4NCjxvbCBjbGFzcz0iYnJlYWRjcnVtYiI+DQogIDxsaSBjbGFzcz0iYnJlYWRjcnVtYi1pdGVtIj48YSBocmVmPSIjIj5Ib21lPC9hPjwvbGk+DQogIDxsaSBjbGFzcz0iYnJlYWRjcnVtYi1pdGVtIj48YSBocmVmPSIjIj5MaWJyYXJ5PC9hPjwvbGk+DQogIDxsaSBjbGFzcz0iYnJlYWRjcnVtYi1pdGVtIGFjdGl2ZSI+RGF0YTwvbGk+DQo8L29sPg==', 9, 'https://getbootstrap.com/docs/4.0/components/breadcrumb/', 'Separators are automatically added in CSS through ::before and content.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:01:21', 1, '', 25, '25ea0f36-f123-4b2e-82c1-3bb44991c0cb'),
(113, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge-success', 2, 'Badge - Success', 'PHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXN1Y2Nlc3MiPlN1Y2Nlc3M8L3NwYW4+', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:13:12', 1, '', 24, '736daa76-4a91-4a26-a684-3412c126e2ec'),
(114, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Group a series of buttons together on a single line with the button group, and super-power them with JavaScript.', 'btn-toolbar', 2, 'Button - Toolbar', 'PGRpdiBjbGFzcz0iYnRuLXRvb2xiYXIiIHJvbGU9InRvb2xiYXIiIGFyaWEtbGFiZWw9IlRvb2xiYXIgd2l0aCBidXR0b24gZ3JvdXBzIj4NCiAgPGRpdiBjbGFzcz0iYnRuLWdyb3VwIiByb2xlPSJncm91cCIgYXJpYS1sYWJlbD0iRmlyc3QgZ3JvdXAiPg0KICAgIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPjE8L2J1dHRvbj4NCiAgICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij4yPC9idXR0b24+DQogICAgPGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXNlY29uZGFyeSI+MzwvYnV0dG9uPg0KICA8L2Rpdj4NCiAgPGRpdiBjbGFzcz0iYnRuLWdyb3VwIiByb2xlPSJncm91cCIgYXJpYS1sYWJlbD0iU2Vjb25kIGdyb3VwIj4NCiAgICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij41PC9idXR0b24+DQogICAgPGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXNlY29uZGFyeSI+NjwvYnV0dG9uPg0KICA8L2Rpdj4NCiAgPGRpdiBjbGFzcz0iYnRuLWdyb3VwIiByb2xlPSJncm91cCIgYXJpYS1sYWJlbD0iVGhpcmQgZ3JvdXAiPg0KICAgIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPjg8L2J1dHRvbj4NCiAgPC9kaXY+DQo8L2Rpdj4=', 11, 'https://getbootstrap.com/docs/4.0/components/button-group/', 'Combine sets of button groups into button toolbars for more complex components. Use utility classes as needed to space out groups, buttons, and more.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:28:16', 1, '', 26, 'f7a6f877-ee4c-4cbe-b1a7-314ff55172b7'),
(115, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Group a series of buttons together on a single line with the button group, and super-power them with JavaScript.', 'btn-group (nested)', 2, 'Button Group (nested)', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwIiByb2xlPSJncm91cCIgYXJpYS1sYWJlbD0iQnV0dG9uIGdyb3VwIHdpdGggbmVzdGVkIGRyb3Bkb3duIj4NCiAgPGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXNlY29uZGFyeSI+MTwvYnV0dG9uPg0KICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij4yPC9idXR0b24+DQoNCiAgPGRpdiBjbGFzcz0iYnRuLWdyb3VwIiByb2xlPSJncm91cCI+DQogICAgPGJ1dHRvbiBpZD0iYnRuR3JvdXBEcm9wMSIgdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkgZHJvcGRvd24tdG9nZ2xlIiBkYXRhLXRvZ2dsZT0iZHJvcGRvd24iIGFyaWEtaGFzcG9wdXA9InRydWUiIGFyaWEtZXhwYW5kZWQ9ImZhbHNlIj4NCiAgICAgIERyb3Bkb3duDQogICAgPC9idXR0b24+DQogICAgPGRpdiBjbGFzcz0iZHJvcGRvd24tbWVudSIgYXJpYS1sYWJlbGxlZGJ5PSJidG5Hcm91cERyb3AxIj4NCiAgICAgIDxhIGNsYXNzPSJkcm9wZG93bi1pdGVtIiBocmVmPSIjIj5Ecm9wZG93biBsaW5rPC9hPg0KICAgICAgPGEgY2xhc3M9ImRyb3Bkb3duLWl0ZW0iIGhyZWY9IiMiPkRyb3Bkb3duIGxpbms8L2E+DQogICAgPC9kaXY+DQogIDwvZGl2Pg0KPC9kaXY+', 11, 'https://getbootstrap.com/docs/4.0/components/button-group/', 'Wrap a series of buttons with .btn in .btn-group. Add on optional JavaScript radio and checkbox style behavior with our buttons plugin.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:28:08', 1, '', 26, 'e97f45dd-c391-4b01-9737-c1cd90c2be30'),
(116, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Documentation and examples for badges, our small count and labeling component.', 'badge', 2, 'Badge', 'PGgxPkV4YW1wbGUgaGVhZGluZyA8c3BhbiBjbGFzcz0iYmFkZ2UgYmFkZ2Utc2Vjb25kYXJ5Ij5OZXc8L3NwYW4+PC9oMT4NCjxoMj5FeGFtcGxlIGhlYWRpbmcgPHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXNlY29uZGFyeSI+TmV3PC9zcGFuPjwvaDI+DQo8aDM+RXhhbXBsZSBoZWFkaW5nIDxzcGFuIGNsYXNzPSJiYWRnZSBiYWRnZS1zZWNvbmRhcnkiPk5ldzwvc3Bhbj48L2gzPg0KPGg0PkV4YW1wbGUgaGVhZGluZyA8c3BhbiBjbGFzcz0iYmFkZ2UgYmFkZ2Utc2Vjb25kYXJ5Ij5OZXc8L3NwYW4+PC9oND4NCjxoNT5FeGFtcGxlIGhlYWRpbmcgPHNwYW4gY2xhc3M9ImJhZGdlIGJhZGdlLXNlY29uZGFyeSI+TmV3PC9zcGFuPjwvaDU+DQo8aDY+RXhhbXBsZSBoZWFkaW5nIDxzcGFuIGNsYXNzPSJiYWRnZSBiYWRnZS1zZWNvbmRhcnkiPk5ldzwvc3Bhbj48L2g2Pg==', 8, 'https://getbootstrap.com/docs/4.0/components/badge/', 'Badges scale to match the size of the immediate parent element by using relative font sizing and em units.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:12:58', 1, '', 26, '003efb29-e3f9-4378-a463-4de8e5675766'),
(117, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Group a series of buttons together on a single line with the button group, and super-power them with JavaScript.', 'btn-group-lg', 2, 'Button Group - Large', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwIGJ0bi1ncm91cC1sZyIgcm9sZT0iZ3JvdXAiIGFyaWEtbGFiZWw9IkJhc2ljIGV4YW1wbGUiPg0KICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij5MZWZ0PC9idXR0b24+DQogIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPk1pZGRsZTwvYnV0dG9uPg0KICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij5SaWdodDwvYnV0dG9uPg0KPC9kaXY+', 11, 'https://getbootstrap.com/docs/4.0/components/button-group/', 'Wrap a series of buttons with .btn in .btn-group. Add on optional JavaScript radio and checkbox style behavior with our buttons plugin.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:27:34', 1, '', 27, '710bde0f-89cc-4acc-a83d-e20fa0cbb893'),
(118, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'radio as button', 2, 'Button - As Radio', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwIiBkYXRhLXRvZ2dsZT0iYnV0dG9ucyI+DQogIDxsYWJlbCBjbGFzcz0iYnRuIGJ0bi1wcmltYXJ5IGFjdGl2ZSI+DQogICAgPGlucHV0IHR5cGU9InJhZGlvIiBuYW1lPSJvcHRpb25zIiBpZD0ib3B0aW9uMSIgY2hlY2tlZD0iIj4gUmFkaW8gMSAocHJlc2VsZWN0ZWQpDQogIDwvbGFiZWw+DQogIDxsYWJlbCBjbGFzcz0iYnRuIGJ0bi1wcmltYXJ5Ij4NCiAgICA8aW5wdXQgdHlwZT0icmFkaW8iIG5hbWU9Im9wdGlvbnMiIGlkPSJvcHRpb24yIj4gUmFkaW8gMg0KICA8L2xhYmVsPg0KPC9kaXY+', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:35:00', 1, '', 27, '14c313be-d933-4858-92bc-b5d47a9db508'),
(119, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'active button', 2, 'Button - Active', 'PGEgaHJlZj0iIyIgY2xhc3M9ImJ0biBidG4tcHJpbWFyeSBidG4tbGcgYWN0aXZlIiByb2xlPSJidXR0b24iIGFyaWEtcHJlc3NlZD0idHJ1ZSI+UHJpbWFyeSBsaW5rPC9hPg==', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:17:18', 1, '', 27, '56f1534d-ea2d-471b-8633-aeed414df87a'),
(120, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'checkbox as button', 2, 'Button - As Checkbox', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwIiBkYXRhLXRvZ2dsZT0iYnV0dG9ucyI+DQogIDxsYWJlbCBjbGFzcz0iYnRuIGJ0bi1wcmltYXJ5IGFjdGl2ZSI+DQogICAgPGlucHV0IHR5cGU9ImNoZWNrYm94IiBjaGVja2VkPSIiPiBDaGVja2JveCAxIChwcmUtY2hlY2tlZCkNCiAgPC9sYWJlbD4NCiAgPGxhYmVsIGNsYXNzPSJidG4gYnRuLXByaW1hcnkiPg0KICAgIDxpbnB1dCB0eXBlPSJjaGVja2JveCI+IENoZWNrYm94IDINCiAgPC9sYWJlbD4NCjwvZGl2Pg==', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:34:41', 1, '', 27, '7f9ab8c9-15aa-4b2b-8271-114b032cdef4'),
(121, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-block', 2, 'Button - Block', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXByaW1hcnkgYnRuLWxnIGJ0bi1ibG9jayI+QmxvY2sgbGV2ZWwgYnV0dG9uPC9idXR0b24+', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:17:15', 1, '', 28, 'e64dd4ca-a1cd-4442-9cf4-5d18a9e3dd91'),
(122, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'disabled button', 2, 'Button - Disabled', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXByaW1hcnkiIGRhdGEtdG9nZ2xlPSJidXR0b24iIGFyaWEtcHJlc3NlZD0iZmFsc2UiPg0KICBTaW5nbGUgdG9nZ2xlDQo8L2J1dHRvbj4=', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:34:21', 1, '', 28, '52c9caa1-7f2b-4a8f-bb60-9a4158d27c0a'),
(123, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Group a series of buttons together on a single line with the button group, and super-power them with JavaScript.', 'btn-group-vertical', 2, 'Button Group - Vertical', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwLXZlcnRpY2FsIiByb2xlPSJncm91cCIgYXJpYS1sYWJlbD0iQmFzaWMgZXhhbXBsZSI+DQogIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPkxlZnQ8L2J1dHRvbj4NCiAgPGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXNlY29uZGFyeSI+TWlkZGxlPC9idXR0b24+DQogIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPlJpZ2h0PC9idXR0b24+DQo8L2Rpdj4=', 11, 'https://getbootstrap.com/docs/4.0/components/button-group/', 'Wrap a series of buttons with .btn in .btn-group. Add on optional JavaScript radio and checkbox style behavior with our buttons plugin.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:27:56', 1, '', 28, '64415e4e-f38f-4e46-9ca1-6eea596f2456'),
(124, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-lg', 2, 'Button - Large', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXByaW1hcnkgYnRuLWxnIj5MYXJnZSBidXR0b248L2J1dHRvbj4=', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:17:07', 1, '', 29, 'ed94a4f7-b396-4201-a7da-b268db30b13d'),
(125, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-sm', 2, 'Button - Small', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXByaW1hcnkgYnRuLXNtIj5TbWFsbCBidXR0b248L2J1dHRvbj4=', 12, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Fancy larger or smaller buttons? Add .btn-lg or .btn-sm for additional sizes.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:17:13', 1, '', 29, '4becf0e5-2fac-483a-b4bb-92b0b1608c3b'),
(126, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Group a series of buttons together on a single line with the button group, and super-power them with JavaScript.', 'btn-group-sm', 2, 'Button Group - Small', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwIGJ0bi1ncm91cC1zbSIgcm9sZT0iZ3JvdXAiIGFyaWEtbGFiZWw9IkJhc2ljIGV4YW1wbGUiPg0KICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij5MZWZ0PC9idXR0b24+DQogIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPk1pZGRsZTwvYnV0dG9uPg0KICA8YnV0dG9uIHR5cGU9ImJ1dHRvbiIgY2xhc3M9ImJ0biBidG4tc2Vjb25kYXJ5Ij5SaWdodDwvYnV0dG9uPg0KPC9kaXY+', 11, 'https://getbootstrap.com/docs/4.0/components/button-group/', 'Wrap a series of buttons with .btn in .btn-group. Add on optional JavaScript radio and checkbox style behavior with our buttons plugin.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:27:45', 1, '', 29, '3af366d7-978f-487a-a966-0477d7ea9d1a'),
(127, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-danger', 2, 'Button - Danger', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLWRhbmdlciI+RGFuZ2VyPC9idXR0b24+', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:20', 1, '', 30, '772bc812-118c-4bf0-a286-b467c3d4cee6'),
(128, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Group a series of buttons together on a single line with the button group, and super-power them with JavaScript.', 'btn-group', 2, 'Button Group', 'PGRpdiBjbGFzcz0iYnRuLWdyb3VwIiByb2xlPSJncm91cCIgYXJpYS1sYWJlbD0iQmFzaWMgZXhhbXBsZSI+DQogIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPkxlZnQ8L2J1dHRvbj4NCiAgPGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXNlY29uZGFyeSI+TWlkZGxlPC9idXR0b24+DQogIDxidXR0b24gdHlwZT0iYnV0dG9uIiBjbGFzcz0iYnRuIGJ0bi1zZWNvbmRhcnkiPlJpZ2h0PC9idXR0b24+DQo8L2Rpdj4=', 11, 'https://getbootstrap.com/docs/4.0/components/button-group/', 'Wrap a series of buttons with .btn in .btn-group. Add on optional JavaScript radio and checkbox style behavior with our buttons plugin.', '', 1, '2017-11-01 00:00:00', '2017-11-22 00:25:49', 1, '', 30, 'cebe97c4-ff4a-4a74-bd12-ebe02ecfd814'),
(129, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-info', 2, 'Button - Info', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLWluZm8iPkluZm88L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:14', 1, '', 31, '35d64d76-fd06-4821-9cfb-7cc8a8901ccf'),
(130, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-link', 2, 'Button - Link', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLWxpbmsiPkxpbms8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:30', 1, '', 32, 'e6356804-5499-478d-b0cb-5f708fd1a739'),
(131, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-danger', 2, 'Button - Outline Danger', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtZGFuZ2VyIj5EYW5nZXI8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:15:40', 1, '', 32, '206c8a71-71b4-4e66-9bdb-9247e0efdf27'),
(132, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-info', 2, 'Button - Outline Info', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtaW5mbyI+SW5mbzwvYnV0dG9uPg==', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:15:34', 1, '', 33, 'ab044e3e-675a-4172-8849-a5fd61d889e3'),
(133, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-primary', 2, 'Button - Outline Primary', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtcHJpbWFyeSI+UHJpbWFyeTwvYnV0dG9uPg==', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:51', 1, '', 34, '6a26904a-fdae-4333-892a-932548b8a11d'),
(134, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-light', 2, 'Button - Outline Light', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtbGlnaHQiPkxpZ2h0PC9idXR0b24+DQo=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-11 23:54:26', 1, '', 34, '5e418043-9a54-4cc3-abef-ac2c6b467a4f'),
(135, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-dark', 2, 'Button - Dark', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLWRhcmsiPkRhcms8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:26', 1, '', 35, 'ad5973b8-1860-49b8-9022-ac43d24a2bc5'),
(136, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-secondary', 2, 'Button - Outline Secondary', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtc2Vjb25kYXJ5Ij5TZWNvbmRhcnk8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:53', 1, '', 35, 'ea92c635-9155-451c-a7f8-4353c60641c8'),
(137, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-light', 2, 'Button - Light', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLWxpZ2h0Ij5MaWdodDwvYnV0dG9uPg==', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:23', 1, '', 36, '0cee266b-156e-44a9-aff0-af6935f139e9'),
(138, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-success', 2, 'Button - Outline Success', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtc3VjY2VzcyI+U3VjY2VzczwvYnV0dG9uPg==', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:55', 1, '', 36, '8798c735-ae7b-4657-8776-d07b0ec5bfe3'),
(139, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-warning', 2, 'Button - Outline Warning', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtd2FybmluZyI+V2FybmluZzwvYnV0dG9uPg==', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:15:37', 1, '', 36, '56c2a53e-7076-4c4a-9a79-0e9037e19fec'),
(140, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-outline-dark', 2, 'Button - Outline Dark', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLW91dGxpbmUtZGFyayI+RGFyazwvYnV0dG9uPg==', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'In need of a button, but not the hefty background colors they bring? Replace the default modifier classes with the .btn-outline-* ones to remove all background images and colors on any button.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:15:47', 1, '', 36, '4560a0a9-c5e9-4db5-b85b-f547206dc4f5'),
(141, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-primary', 2, 'Button - Primary', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXByaW1hcnkiPlByaW1hcnk8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 22:39:59', 1, '', 37, 'a2e15c1b-e002-41ba-b222-808a4de5d3cb'),
(142, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-success', 2, 'Button - Success', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXN1Y2Nlc3MiPlN1Y2Nlc3M8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:11', 1, '', 38, 'ba1c21b9-612d-4d8b-8d74-333e6dd6a140'),
(143, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-warning', 2, 'Button - Warning', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXdhcm5pbmciPldhcm5pbmc8L2J1dHRvbj4=', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 23:14:17', 1, '', 39, '7c1fd0a6-3460-4034-b562-9eed77e53764'),
(144, 'Most Wanted Web Services, Inc.', 'sales@mwweb.host', 'Steve Voorhees', 'https://mostwantedwebhosting.com', 'Use Bootstrap\'s custom button styles for actions in forms, dialogs, and more with support for multiple sizes, states, and more.', 'btn-secondary', 2, 'Button - Secondary', 'PGJ1dHRvbiB0eXBlPSJidXR0b24iIGNsYXNzPSJidG4gYnRuLXNlY29uZGFyeSI+U2Vjb25kYXJ5PC9idXR0b24+', 10, 'https://getbootstrap.com/docs/4.0/components/buttons/', 'Bootstrap includes several predefined button styles, each serving its own semantic purpose, with a few extras thrown in for more control.', '', 1, '2017-11-01 00:00:00', '2017-11-21 22:40:04', 1, '', 40, '5f6714fb-0030-40a6-b269-4d96d1b1bf08');
--
-- Dumping data for table `#__componentbuilder_validation_rule`
--
INSERT INTO `#__componentbuilder_validation_rule` (`id`, `name`, `php`, `short_description`, `published`, `created`, `params`) VALUES
(1, 'inspect', 'CS8qKg0KCSAqIE1ldGhvZCB0byB0ZXN0IHRoZSB2YWx1ZS4NCgkgKg0KCSAqIEBwYXJhbSAgIFxTaW1wbGVYTUxFbGVtZW50ICAkZWxlbWVudCAgVGhlIFNpbXBsZVhNTEVsZW1lbnQgb2JqZWN0IHJlcHJlc2VudGluZyB0aGUgYDxmaWVsZD5gIHRhZyBmb3IgdGhlIGZvcm0gZmllbGQgb2JqZWN0Lg0KCSAqIEBwYXJhbSAgIG1peGVkICAgICAgICAgICAgICAkdmFsdWUgICAgVGhlIGZvcm0gZmllbGQgdmFsdWUgdG8gdmFsaWRhdGUuDQoJICogQHBhcmFtICAgc3RyaW5nICAgICAgICAgICAgICRncm91cCAgICBUaGUgZmllbGQgbmFtZSBncm91cCBjb250cm9sIHZhbHVlLiBUaGlzIGFjdHMgYXMgYW4gYXJyYXkgY29udGFpbmVyIGZvciB0aGUgZmllbGQuDQoJICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGb3IgZXhhbXBsZSBpZiB0aGUgZmllbGQgaGFzIG5hbWU9ImZvbyIgYW5kIHRoZSBncm91cCB2YWx1ZSBpcyBzZXQgdG8gImJhciIgdGhlbiB0aGUNCgkgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZ1bGwgZmllbGQgbmFtZSB3b3VsZCBlbmQgdXAgYmVpbmcgImJhcltmb29dIi4NCgkgKiBAcGFyYW0gICBSZWdpc3RyeSAgICAgICAgICAgJGlucHV0ICAgIEFuIG9wdGlvbmFsIFJlZ2lzdHJ5IG9iamVjdCB3aXRoIHRoZSBlbnRpcmUgZGF0YSBzZXQgdG8gdmFsaWRhdGUgYWdhaW5zdCB0aGUgZW50aXJlIGZvcm0uDQoJICogQHBhcmFtICAgRm9ybSAgICAgICAgICAgICAgICRmb3JtICAgICBUaGUgZm9ybSBvYmplY3QgZm9yIHdoaWNoIHRoZSBmaWVsZCBpcyBiZWluZyB0ZXN0ZWQuDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICBUcnVlIGlmIHRoZSB2YWx1ZSBpcyB2YWxpZCwgZmFsc2Ugb3RoZXJ3aXNlLg0KCSAqDQoJICogQHNpbmNlICAgMTEuMQ0KCSAqLw0KCXB1YmxpYyBmdW5jdGlvbiB0ZXN0KFxTaW1wbGVYTUxFbGVtZW50ICRlbGVtZW50LCAkdmFsdWUsICRncm91cCA9IG51bGwsIFJlZ2lzdHJ5ICRpbnB1dCA9IG51bGwsIEZvcm0gJGZvcm0gPSBudWxsKQ0KCXsNCgkJLy8gbG9vayBpbnRvIHRoZXNlIHZhbHVlcyBvbmUgYXQgYSB0aW1lDQoJCWVjaG8gJzxwcmU+ZWxlbWVudDxiciAvPic7DQoJCXZhcl9kdW1wKCRlbGVtZW50KTsNCgkJZWNobyAndmFsdWU8YnIgLz4nOw0KCQl2YXJfZHVtcCgkdmFsdWUpOw0KCQllY2hvICdncm91cDxiciAvPic7DQoJCXZhcl9kdW1wKCRncm91cCk7DQoJCWVjaG8gJ2lucHV0PGJyIC8+JzsNCgkJdmFyX2R1bXAoJGlucHV0KTsNCgkJZWNobyAnZm9ybTxiciAvPic7DQoJCXZhcl9kdW1wKCRmb3JtKTsNCgkJamV4aXQoKTsNCgl9', 'simple function to inspect the test values', 1, '2018-03-30 09:22:15', ''),
(2, 'code', 'CS8qKg0KCSAqIE1ldGhvZCB0byB0ZXN0IHRoZSB2YWx1ZS4NCgkgKg0KCSAqIEBwYXJhbSAgIFxTaW1wbGVYTUxFbGVtZW50ICAkZWxlbWVudCAgVGhlIFNpbXBsZVhNTEVsZW1lbnQgb2JqZWN0IHJlcHJlc2VudGluZyB0aGUgYDxmaWVsZD5gIHRhZyBmb3IgdGhlIGZvcm0gZmllbGQgb2JqZWN0Lg0KCSAqIEBwYXJhbSAgIG1peGVkICAgICAgICAgICAgICAkdmFsdWUgICAgVGhlIGZvcm0gZmllbGQgdmFsdWUgdG8gdmFsaWRhdGUuDQoJICogQHBhcmFtICAgc3RyaW5nICAgICAgICAgICAgICRncm91cCAgICBUaGUgZmllbGQgbmFtZSBncm91cCBjb250cm9sIHZhbHVlLiBUaGlzIGFjdHMgYXMgYW4gYXJyYXkgY29udGFpbmVyIGZvciB0aGUgZmllbGQuDQoJICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGb3IgZXhhbXBsZSBpZiB0aGUgZmllbGQgaGFzIG5hbWU9ImZvbyIgYW5kIHRoZSBncm91cCB2YWx1ZSBpcyBzZXQgdG8gImJhciIgdGhlbiB0aGUNCgkgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZ1bGwgZmllbGQgbmFtZSB3b3VsZCBlbmQgdXAgYmVpbmcgImJhcltmb29dIi4NCgkgKiBAcGFyYW0gICBSZWdpc3RyeSAgICAgICAgICAgJGlucHV0ICAgIEFuIG9wdGlvbmFsIFJlZ2lzdHJ5IG9iamVjdCB3aXRoIHRoZSBlbnRpcmUgZGF0YSBzZXQgdG8gdmFsaWRhdGUgYWdhaW5zdCB0aGUgZW50aXJlIGZvcm0uDQoJICogQHBhcmFtICAgRm9ybSAgICAgICAgICAgICAgICRmb3JtICAgICBUaGUgZm9ybSBvYmplY3QgZm9yIHdoaWNoIHRoZSBmaWVsZCBpcyBiZWluZyB0ZXN0ZWQuDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICBUcnVlIGlmIHRoZSB2YWx1ZSBpcyB2YWxpZCwgZmFsc2Ugb3RoZXJ3aXNlLg0KCSAqLw0KCXB1YmxpYyBmdW5jdGlvbiB0ZXN0KFxTaW1wbGVYTUxFbGVtZW50ICRlbGVtZW50LCAkdmFsdWUsICRncm91cCA9IG51bGwsIFJlZ2lzdHJ5ICRpbnB1dCA9IG51bGwsIEZvcm0gJGZvcm0gPSBudWxsKQ0KCXsNCgkJLy8gVGhpcyByZW1vdmVzIGFsbCB2YWxpZGF0aW9uIChpcyBkYW5nZXJvdXMpIGJ1dCBuZWVkZWQgdG8gc3VibWl0IGNvZGUgdmlhIEpDQg0KCQlyZXR1cm4gdHJ1ZTsNCg0KCQkvKioNCgkJICogTXkgaWRlYSBpcyB0byBhZGQgc29tZSBraW5kIG9mIHZhbGlkYXRpb24gdG8gaW1wcm92ZSBKQ0IgY29kZSAocGVyL2xhbmd1YWdlKQ0KCQkgKg0KCQkgKiBTbyBhdCB0aGlzIHRpbWUgdGhpcyBjb2RlIHZhbGlkYXRpb24gaXMgdXNlZCBmb3IgSmF2YVNjcmlwdCxDU1MsSFRNTCBhbmQgUEhQLg0KCQkgKiBXZSBjYW4gc2VlIHdoYXQgbGFuZ3VhZ2UgaXMgYmVpbmcgd29ya2VkIG9uIHdpdGggdGhlIHN5bnRheCBwcm9wZXJ0eSBpbiB0aGUgJGVsZW1lbnQuIChpbiBKQ0IpDQoJCSAqIFdoYXQgY29tcGxpY2F0ZXMgdGhpbmdzIGlzIHRoZSBwbGFjZWhvbGRlcnMsIG9mIGJvdGggY3VzdG9tIGNvZGUsIGNvbXBvbmVudCwgYW5kIHZpZXcgbmFtZXMuDQoJCSAqIElkZWFsbHkgd2UgY291bGQgc3RyaXAgdGhlbSBhbmQgdGhlbiB2YWxpZGF0ZSB0aGUgY29kZSB0byBiZWluZyBzeW50YWN0aWNhbGx5IGNvcnJlY3QuDQoJCSAqIEJ1dCBzaW5jZSBzb21lIG9mIHRoZSBwbGFjZWhvbGRlcnMgZm9ybSBwYXJ0IG9mIHRoZSBjbGFzcy9mdW5jdGlvbiBuYW1lcyBhbmQgdGhlIG1vcmUsIGl0IHNlZW1zIGxpa2Ugd2UgYXJlIHByZXNzZWQgZm9yIGEgbXVjaCBtb3JlIGFkdmFuY2Ugc29sdXRpb24uDQoJCSAqIElmIHlvdSBoYXZlIGFueSBpZGVhcyB0byBob3cgd2UgY2FuIGdvIGFib3V0IHRvIGRvIHRoaXMsIHRoZW4gcGxlYXNlIG9wZW4gYW4gaXNzdWUgb24gZ2l0aHViIGFuZCBsZXRzIGJlZ2luLiAodGhpcyBpcyBhIG5pY2UgdG8gaGF2ZSwgc28gZG9uJ3QgYnJlYWsgYSBsZWcuLi4pDQoJCSAqLw0KCX0=', 'To validate code', 1, '2018-06-24 19:11:45', ''),
(3, 'uniquefield', 'CS8qKg0KCSAqIE1ldGhvZCB0byB0ZXN0IHRoZSBmaWVsZCB2YWx1ZSBmb3IgdW5pcXVlbmVzcy4NCgkgKg0KCSAqIEBwYXJhbSAgIFxTaW1wbGVYTUxFbGVtZW50ICAkZWxlbWVudCAgVGhlIFNpbXBsZVhNTEVsZW1lbnQgb2JqZWN0IHJlcHJlc2VudGluZyB0aGUgYDxmaWVsZD5gIHRhZyBmb3IgdGhlIGZvcm0gZmllbGQgb2JqZWN0Lg0KCSAqIEBwYXJhbSAgIG1peGVkICAgICAgICAgICAgICAkdmFsdWUgICAgVGhlIGZvcm0gZmllbGQgdmFsdWUgdG8gdmFsaWRhdGUuDQoJICogQHBhcmFtICAgc3RyaW5nICAgICAgICAgICAgICRncm91cCAgICBUaGUgZmllbGQgbmFtZSBncm91cCBjb250cm9sIHZhbHVlLiBUaGlzIGFjdHMgYXMgYW4gYXJyYXkgY29udGFpbmVyIGZvciB0aGUgZmllbGQuDQoJICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGb3IgZXhhbXBsZSBpZiB0aGUgZmllbGQgaGFzIG5hbWU9ImZvbyIgYW5kIHRoZSBncm91cCB2YWx1ZSBpcyBzZXQgdG8gImJhciIgdGhlbiB0aGUNCgkgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZ1bGwgZmllbGQgbmFtZSB3b3VsZCBlbmQgdXAgYmVpbmcgImJhcltmb29dIi4NCgkgKiBAcGFyYW0gICBSZWdpc3RyeSAgICAgICAgICAgJGlucHV0ICAgIEFuIG9wdGlvbmFsIFJlZ2lzdHJ5IG9iamVjdCB3aXRoIHRoZSBlbnRpcmUgZGF0YSBzZXQgdG8gdmFsaWRhdGUgYWdhaW5zdCB0aGUgZW50aXJlIGZvcm0uDQoJICogQHBhcmFtICAgRm9ybSAgICAgICAgICAgICAgICRmb3JtICAgICBUaGUgZm9ybSBvYmplY3QgZm9yIHdoaWNoIHRoZSBmaWVsZCBpcyBiZWluZyB0ZXN0ZWQuDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICBUcnVlIGlmIHRoZSB2YWx1ZSBpcyB2YWxpZCwgZmFsc2Ugb3RoZXJ3aXNlLg0KCSAqDQoJICogQHNpbmNlICAgMTEuMQ0KCSAqLw0KCXB1YmxpYyBmdW5jdGlvbiB0ZXN0KFxTaW1wbGVYTUxFbGVtZW50ICRlbGVtZW50LCAkdmFsdWUsICRncm91cCA9IG51bGwsIFJlZ2lzdHJ5ICRpbnB1dCA9IG51bGwsIEZvcm0gJGZvcm0gPSBudWxsKQ0KCXsNCgkJLy8gR2V0IHRoZSBkYXRhYmFzZSBvYmplY3QgYW5kIGEgbmV3IHF1ZXJ5IG9iamVjdC4NCgkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCSRxdWVyeSA9ICRkYi0+Z2V0UXVlcnkodHJ1ZSk7DQoNCgkJLy8gR2V0IHRoZSBleHRyYSBmaWVsZCBjaGVjayBhdHRyaWJ1dGUuDQoJCSRpZCA9ICgkaW5wdXQgaW5zdGFuY2VvZiBSZWdpc3RyeSkgPyAkaW5wdXQtPmdldCgnaWQnLCBudWxsKSA6IG51bGw7DQoNCgkJLy8gZ2V0IHRoZSBjb21wb25lbnQgJiB0YWJsZSBuYW1lDQoJCSR0YWJsZSA9ICgkZm9ybSBpbnN0YW5jZW9mIEZvcm0pID8gJGZvcm0tPmdldE5hbWUoKSA6ICcnOw0KDQoJCS8vIGdldCB0aGUgY29sdW1uIG5hbWUNCgkJJG5hbWUgPSAoYXJyYXkpICRlbGVtZW50LT5hdHRyaWJ1dGVzKCktPnsnbmFtZSd9Ow0KCQkkY29sdW1uID0gKHN0cmluZykgdHJpbSgkbmFtZVswXSk7DQoJCQ0KCQkvLyBjaGVjayB0aGF0IHdlIGhhdmUgYSB2YWx1ZQ0KCQlpZiAoc3RybGVuKCR2YWx1ZSkgJiYgc3RybGVuKCR0YWJsZSkgPiAzICYmIHN0cnBvcygkdGFibGUsICdbW1tjb21wb25lbnRdXV0uJykgIT09IGZhbHNlKQ0KCQl7DQoJCQkvLyBub3cgZ2V0IHRoZSB0YWJsZSBuYW1lDQoJCQkkdGFibGVBcnJheSA9IGV4cGxvZGUoJy4nLCAkdGFibGUpOw0KCQkJLy8gZG8gd2UgaGF2ZSB0d28gdmFsdWVzDQoJCQlpZiAoY291bnQoIChhcnJheSkgJHRhYmxlQXJyYXkpID09IDIpDQoJCQl7DQoJCQkJLy8gQnVpbGQgdGhlIHF1ZXJ5Lg0KCQkJCSRxdWVyeS0+c2VsZWN0KCdDT1VOVCgqKScpDQoJCQkJCS0+ZnJvbSgnI19fW1tbY29tcG9uZW50XV1dXycgLiAoc3RyaW5nKSAkdGFibGVBcnJheVsxXSkNCgkJCQkJLT53aGVyZSgkZGItPnF1b3RlTmFtZSgkY29sdW1uKSAuICcgPSAnIC4gJGRiLT5xdW90ZSgkdmFsdWUpKTsNCg0KCQkJCS8vIHJlbW92ZSB0aGlzIGl0ZW0gZnJvbSB0aGUgbGlzdA0KCQkJCWlmICgkaWQgPiAwKQ0KCQkJCXsNCgkJCQkJJHF1ZXJ5LT53aGVyZSgkZGItPnF1b3RlTmFtZSgnaWQnKSAuICcgPD4gJyAuIChpbnQpICRpZCk7DQoJCQkJfQ0KDQoJCQkJLy8gU2V0IGFuZCBxdWVyeSB0aGUgZGF0YWJhc2UuDQoJCQkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkJCSRkdXBsaWNhdGUgPSAoYm9vbCkgJGRiLT5sb2FkUmVzdWx0KCk7DQoNCgkJCQlpZiAoJGR1cGxpY2F0ZSkNCgkJCQl7DQoJCQkJCXJldHVybiBmYWxzZTsNCgkJCQl9DQoJCQl9DQoJCX0NCg0KCQlyZXR1cm4gdHJ1ZTsNCgl9', 'unique field value', 1, '2018-07-21 06:06:42', ''),
(4, 'memberloginname', 'CS8qKg0KCSAqIE1ldGhvZCB0byB0ZXN0IHRoZSB1c2VybmFtZSBmb3IgdW5pcXVlbmVzcy4NCgkgKg0KCSAqIEBwYXJhbSAgIFxTaW1wbGVYTUxFbGVtZW50ICAkZWxlbWVudCAgVGhlIFNpbXBsZVhNTEVsZW1lbnQgb2JqZWN0IHJlcHJlc2VudGluZyB0aGUgYDxmaWVsZD5gIHRhZyBmb3IgdGhlIGZvcm0gZmllbGQgb2JqZWN0Lg0KCSAqIEBwYXJhbSAgIG1peGVkICAgICAgICAgICAgICAkdmFsdWUgICAgVGhlIGZvcm0gZmllbGQgdmFsdWUgdG8gdmFsaWRhdGUuDQoJICogQHBhcmFtICAgc3RyaW5nICAgICAgICAgICAgICRncm91cCAgICBUaGUgZmllbGQgbmFtZSBncm91cCBjb250cm9sIHZhbHVlLiBUaGlzIGFjdHMgYXMgYW4gYXJyYXkgY29udGFpbmVyIGZvciB0aGUgZmllbGQuDQoJICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGb3IgZXhhbXBsZSBpZiB0aGUgZmllbGQgaGFzIG5hbWU9ImZvbyIgYW5kIHRoZSBncm91cCB2YWx1ZSBpcyBzZXQgdG8gImJhciIgdGhlbiB0aGUNCgkgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZ1bGwgZmllbGQgbmFtZSB3b3VsZCBlbmQgdXAgYmVpbmcgImJhcltmb29dIi4NCgkgKiBAcGFyYW0gICBSZWdpc3RyeSAgICAgICAgICAgJGlucHV0ICAgIEFuIG9wdGlvbmFsIFJlZ2lzdHJ5IG9iamVjdCB3aXRoIHRoZSBlbnRpcmUgZGF0YSBzZXQgdG8gdmFsaWRhdGUgYWdhaW5zdCB0aGUgZW50aXJlIGZvcm0uDQoJICogQHBhcmFtICAgRm9ybSAgICAgICAgICAgICAgICRmb3JtICAgICBUaGUgZm9ybSBvYmplY3QgZm9yIHdoaWNoIHRoZSBmaWVsZCBpcyBiZWluZyB0ZXN0ZWQuDQoJICoNCgkgKiBAcmV0dXJuICBib29sZWFuICBUcnVlIGlmIHRoZSB2YWx1ZSBpcyB2YWxpZCwgZmFsc2Ugb3RoZXJ3aXNlLg0KCSAqDQoJICogQHNpbmNlICAgMTEuMQ0KCSAqLw0KCXB1YmxpYyBmdW5jdGlvbiB0ZXN0KFxTaW1wbGVYTUxFbGVtZW50ICRlbGVtZW50LCAkdmFsdWUsICRncm91cCA9IG51bGwsIFJlZ2lzdHJ5ICRpbnB1dCA9IG51bGwsIEZvcm0gJGZvcm0gPSBudWxsKQ0KCXsNCgkJLy8gR2V0IHRoZSBkYXRhYmFzZSBvYmplY3QgYW5kIGEgbmV3IHF1ZXJ5IG9iamVjdC4NCgkJJGRiID0gRmFjdG9yeTo6Z2V0RGJvKCk7DQoJCSRxdWVyeSA9ICRkYi0+Z2V0UXVlcnkodHJ1ZSk7DQoNCgkJLy8gQnVpbGQgdGhlIHF1ZXJ5Lg0KCQkkcXVlcnktPnNlbGVjdCgnQ09VTlQoKiknKQ0KCQkJLT5mcm9tKCcjX191c2VycycpDQoJCQktPndoZXJlKCd1c2VybmFtZSA9ICcgLiAkZGItPnF1b3RlKCR2YWx1ZSkpOw0KDQoJCS8vIEdldCB0aGUgdXNlciBJRCBpZiBzZXQuDQoJCSR1c2VySWQgPSAoJGZvcm0gaW5zdGFuY2VvZiBGb3JtICYmICgkdXNlcklkID0gJGZvcm0tPmdldFZhbHVlKCd1c2VyJykpKSA/ICR1c2VySWQgOiAoKCRpbnB1dCBpbnN0YW5jZW9mIFJlZ2lzdHJ5ICYmICgkdXNlcklkID0gJGlucHV0LT5nZXQoJ3VzZXInKSkpID8gJHVzZXJJZCA6IDApOw0KCQkvLyBpZiBzdGlsbCBub3QgdXNlciBpcyBmb3VuZCBnZXQgbWVtYmVyIGlkDQoJCWlmICgkdXNlcklkID09IDApDQoJCXsNCgkJCSRtZW1iZXJJZCA9ICgkZm9ybSBpbnN0YW5jZW9mIEZvcm0gJiYgKCRtZW1iZXJJZCA9ICRmb3JtLT5nZXRWYWx1ZSgnaWQnKSkpID8gJG1lbWJlcklkIDogKCgkaW5wdXQgaW5zdGFuY2VvZiBSZWdpc3RyeSAmJiAoJG1lbWJlcklkID0gJGlucHV0LT5nZXQoJ2lkJykpKSA/ICRtZW1iZXJJZCA6IDApOw0KCQl9DQoJCS8vIGdldCBhY2NvdW50IHR5cGUgaWYgbmVlZGVkDQoJCWlmICgkdXNlcklkID09IDAgJiYgJG1lbWJlcklkID4gMCkNCgkJew0KCQkJJGFjY291bnRJZCA9ICgkZm9ybSBpbnN0YW5jZW9mIEZvcm0gJiYgKCRhY2NvdW50SWQgPSAkZm9ybS0+Z2V0VmFsdWUoJ2FjY291bnQnKSkpID8gJGFjY291bnRJZCA6ICgoJGlucHV0IGluc3RhbmNlb2YgUmVnaXN0cnkgJiYgKCRhY2NvdW50SWQgPSAkaW5wdXQtPmdldCgnYWNjb3VudCcpKSkgPyAkYWNjb3VudElkIDogMCk7DQoJCQkvLyBtYWtlIHN1cmUgdGhlc2UgYWNjb3VudCBpcyBzZXQNCgkJCWlmICgkYWNjb3VudElkID09IDApDQoJCQl7DQoJCQkJJGFjY291bnRJZCA9IFN1cGVyX19fZGI4N2MzMzlfNWJiNl80MjkxX2E3ZWZfMmM0OGVhMWIwNmJjX19fUG93ZXI6OnZhcignbWVtYmVyJywgJG1lbWJlcklkLCAnaWQnLCAnYWNjb3VudCcpOw0KCQkJfQ0KCQl9DQoJCS8vIGdldCB1c2VyIHZhbHVlIGlmIG5vdCBzZXQgKGR1ZSB0byBwZXJtaXNzaW9ucykNCgkJaWYgKCR1c2VySWQgPT0gMCAmJiAkbWVtYmVySWQgPiAwICYmICRhY2NvdW50SWQgPiAwICYmICgxID09ICRhY2NvdW50SWQgfHwgNCA9PSAkYWNjb3VudElkKSkNCgkJew0KCQkJJHVzZXJJZCA9IFN1cGVyX19fZGI4N2MzMzlfNWJiNl80MjkxX2E3ZWZfMmM0OGVhMWIwNmJjX19fUG93ZXI6OnZhcignbWVtYmVyJywgJG1lbWJlcklkLCAnaWQnLCAndXNlcicpOw0KCQl9DQoJCSRxdWVyeS0+d2hlcmUoJGRiLT5xdW90ZU5hbWUoJ2lkJykgLiAnIDw+ICcgLiAoaW50KSAkdXNlcklkKTsNCg0KCQkvLyBTZXQgYW5kIHF1ZXJ5IHRoZSBkYXRhYmFzZS4NCgkJJGRiLT5zZXRRdWVyeSgkcXVlcnkpOw0KCQkkZHVwbGljYXRlID0gKGJvb2wpICRkYi0+bG9hZFJlc3VsdCgpOw0KDQoJCWlmICgkZHVwbGljYXRlKQ0KCQl7DQoJCQlyZXR1cm4gZmFsc2U7DQoJCX0NCg0KCQlyZXR1cm4gdHJ1ZTsNCgl9', 'Validate the member username', 1, '2018-09-16 00:42:59', ''),
(5, 'memberuseremail', 'CS8qKg0KCSAqIFRoZSByZWd1bGFyIGV4cHJlc3Npb24gdG8gdXNlIGluIHRlc3RpbmcgYSBmb3JtIGZpZWxkIHZhbHVlLg0KCSAqDQoJICogQHZhciAgICBzdHJpbmcNCgkgKiBAc2luY2UgIDExLjENCgkgKiBAbGluayAgIGh0dHA6Ly93d3cudzMub3JnL1RSL2h0bWwtbWFya3VwL2lucHV0LmVtYWlsLmh0bWwNCgkgKi8NCglwcm90ZWN0ZWQgJHJlZ2V4ID0gIl5bYS16QS1aMC05LiEjJCUmJyorLz0/Xl9ge3x9fi1dK0BbYS16QS1aMC05LV0rKD86XC5bYS16QS1aMC05LV0rKSokIjsNCg0KCS8qKg0KCSAqIE1ldGhvZCB0byB0ZXN0IHRoZSBlbWFpbCBhZGRyZXNzIGFuZCBvcHRpb25hbGx5IGNoZWNrIGZvciB1bmlxdWVuZXNzLg0KCSAqDQoJICogQHBhcmFtICAgXFNpbXBsZVhNTEVsZW1lbnQgICRlbGVtZW50ICBUaGUgU2ltcGxlWE1MRWxlbWVudCBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBgPGZpZWxkPmAgdGFnIGZvciB0aGUgZm9ybSBmaWVsZCBvYmplY3QuDQoJICogQHBhcmFtICAgbWl4ZWQgICAgICAgICAgICAgICR2YWx1ZSAgICBUaGUgZm9ybSBmaWVsZCB2YWx1ZSB0byB2YWxpZGF0ZS4NCgkgKiBAcGFyYW0gICBzdHJpbmcgICAgICAgICAgICAgJGdyb3VwICAgIFRoZSBmaWVsZCBuYW1lIGdyb3VwIGNvbnRyb2wgdmFsdWUuIFRoaXMgYWN0cyBhcyBhbiBhcnJheSBjb250YWluZXIgZm9yIHRoZSBmaWVsZC4NCgkgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZvciBleGFtcGxlIGlmIHRoZSBmaWVsZCBoYXMgbmFtZT0iZm9vIiBhbmQgdGhlIGdyb3VwIHZhbHVlIGlzIHNldCB0byAiYmFyIiB0aGVuIHRoZQ0KCSAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZnVsbCBmaWVsZCBuYW1lIHdvdWxkIGVuZCB1cCBiZWluZyAiYmFyW2Zvb10iLg0KCSAqIEBwYXJhbSAgIFJlZ2lzdHJ5ICAgICAgICAgICAkaW5wdXQgICAgQW4gb3B0aW9uYWwgUmVnaXN0cnkgb2JqZWN0IHdpdGggdGhlIGVudGlyZSBkYXRhIHNldCB0byB2YWxpZGF0ZSBhZ2FpbnN0IHRoZSBlbnRpcmUgZm9ybS4NCgkgKiBAcGFyYW0gICBGb3JtICAgICAgICAgICAgICAgJGZvcm0gICAgIFRoZSBmb3JtIG9iamVjdCBmb3Igd2hpY2ggdGhlIGZpZWxkIGlzIGJlaW5nIHRlc3RlZC4NCgkgKg0KCSAqIEByZXR1cm4gIGJvb2xlYW4gIFRydWUgaWYgdGhlIHZhbHVlIGlzIHZhbGlkLCBmYWxzZSBvdGhlcndpc2UuDQoJICoNCgkgKiBAc2luY2UgICAxMS4xDQoJICovDQoJcHVibGljIGZ1bmN0aW9uIHRlc3QoXFNpbXBsZVhNTEVsZW1lbnQgJGVsZW1lbnQsICR2YWx1ZSwgJGdyb3VwID0gbnVsbCwgUmVnaXN0cnkgJGlucHV0ID0gbnVsbCwgRm9ybSAkZm9ybSA9IG51bGwpDQoJew0KCQkvLyBJZiB0aGUgZmllbGQgaXMgZW1wdHkgYW5kIG5vdCByZXF1aXJlZCwgdGhlIGZpZWxkIGlzIHZhbGlkLg0KCQkkcmVxdWlyZWQgPSAoKHN0cmluZykgJGVsZW1lbnRbJ3JlcXVpcmVkJ10gPT0gJ3RydWUnIHx8IChzdHJpbmcpICRlbGVtZW50WydyZXF1aXJlZCddID09ICdyZXF1aXJlZCcpOw0KDQoJCWlmICghJHJlcXVpcmVkICYmIGVtcHR5KCR2YWx1ZSkpDQoJCXsNCgkJCXJldHVybiB0cnVlOw0KCQl9DQoNCgkJLy8gSWYgdGhlIHRsZCBhdHRyaWJ1dGUgaXMgcHJlc2VudCwgY2hhbmdlIHRoZSByZWd1bGFyIGV4cHJlc3Npb24gdG8gcmVxdWlyZSBhdCBsZWFzdCAyIGNoYXJhY3RlcnMgZm9yIGl0Lg0KCQkkdGxkID0gKChzdHJpbmcpICRlbGVtZW50Wyd0bGQnXSA9PSAndGxkJyB8fCAoc3RyaW5nKSAkZWxlbWVudFsndGxkJ10gPT0gJ3JlcXVpcmVkJyk7DQoNCgkJaWYgKCR0bGQpDQoJCXsNCgkJCSR0aGlzLT5yZWdleCA9ICJeW2EtekEtWjAtOS4hIyQlJicqKy89P15fYHt8fX4tXStAW2EtekEtWjAtOV0oPzpbYS16QS1aMC05LV17MCw2MX1bYS16QS1aMC05XSkiDQoJCQkJLiAnPyg/OlwuW2EtekEtWjAtOV0oPzpbYS16QS1aMC05LV17MCw2MX1bYS16QS1aMC05XSk/KSskJzsNCgkJfQ0KDQoJCS8vIERldGVybWluZSBpZiB0aGUgbXVsdGlwbGUgYXR0cmlidXRlIGlzIHByZXNlbnQNCgkJJG11bHRpcGxlID0gKChzdHJpbmcpICRlbGVtZW50WydtdWx0aXBsZSddID09ICd0cnVlJyB8fCAoc3RyaW5nKSAkZWxlbWVudFsnbXVsdGlwbGUnXSA9PSAnbXVsdGlwbGUnKTsNCg0KCQlpZiAoISRtdWx0aXBsZSkNCgkJew0KCQkJLy8gSGFuZGxlIGlkbiBlbWFpbCBhZGRyZXNzZXMgYnkgY29udmVydGluZyB0byBwdW55Y29kZS4NCgkJCSR2YWx1ZSA9IFxKU3RyaW5nUHVueWNvZGU6OmVtYWlsVG9QdW55Y29kZSgkdmFsdWUpOw0KDQoJCQkvLyBUZXN0IHRoZSB2YWx1ZSBhZ2FpbnN0IHRoZSByZWd1bGFyIGV4cHJlc3Npb24uDQoJCQlpZiAoIXBhcmVudDo6dGVzdCgkZWxlbWVudCwgJHZhbHVlLCAkZ3JvdXAsICRpbnB1dCwgJGZvcm0pKQ0KCQkJew0KCQkJCXJldHVybiBmYWxzZTsNCgkJCX0NCgkJfQ0KCQllbHNlDQoJCXsNCgkJCSR2YWx1ZXMgPSBleHBsb2RlKCcsJywgJHZhbHVlKTsNCg0KCQkJZm9yZWFjaCAoJHZhbHVlcyBhcyAkdmFsdWUpDQoJCQl7DQoJCQkJLy8gSGFuZGxlIGlkbiBlbWFpbCBhZGRyZXNzZXMgYnkgY29udmVydGluZyB0byBwdW55Y29kZS4NCgkJCQkkdmFsdWUgPSBcSlN0cmluZ1B1bnljb2RlOjplbWFpbFRvUHVueWNvZGUoJHZhbHVlKTsNCg0KCQkJCS8vIFRlc3QgdGhlIHZhbHVlIGFnYWluc3QgdGhlIHJlZ3VsYXIgZXhwcmVzc2lvbi4NCgkJCQlpZiAoIXBhcmVudDo6dGVzdCgkZWxlbWVudCwgJHZhbHVlLCAkZ3JvdXAsICRpbnB1dCwgJGZvcm0pKQ0KCQkJCXsNCgkJCQkJcmV0dXJuIGZhbHNlOw0KCQkJCX0NCgkJCX0NCgkJfQ0KDQoJCS8vIENoZWNrIGlmIHdlIHNob3VsZCB0ZXN0IGZvciB1bmlxdWVuZXNzLiBUaGlzIG9ubHkgY2FuIGJlIHVzZWQgaWYgbXVsdGlwbGUgaXMgbm90IHRydWUNCgkJJHVuaXF1ZSA9ICgoc3RyaW5nKSAkZWxlbWVudFsndW5pcXVlJ10gPT0gJ3RydWUnIHx8IChzdHJpbmcpICRlbGVtZW50Wyd1bmlxdWUnXSA9PSAndW5pcXVlJyk7DQoNCgkJaWYgKCR1bmlxdWUgJiYgISRtdWx0aXBsZSkNCgkJew0KCQkJLy8gR2V0IHRoZSBkYXRhYmFzZSBvYmplY3QgYW5kIGEgbmV3IHF1ZXJ5IG9iamVjdC4NCgkJCSRkYiA9IEZhY3Rvcnk6OmdldERibygpOw0KCQkJJHF1ZXJ5ID0gJGRiLT5nZXRRdWVyeSh0cnVlKTsNCg0KCQkJLy8gQnVpbGQgdGhlIHF1ZXJ5Lg0KCQkJJHF1ZXJ5LT5zZWxlY3QoJ0NPVU5UKCopJykNCgkJCQktPmZyb20oJyNfX3VzZXJzJykNCgkJCQktPndoZXJlKCdlbWFpbCA9ICcgLiAkZGItPnF1b3RlKCR2YWx1ZSkpOw0KDQoJCQkvLyBHZXQgdGhlIHVzZXIgSUQgaWYgc2V0Lg0KCQkJJHVzZXJJZCA9ICgkZm9ybSBpbnN0YW5jZW9mIEZvcm0gJiYgKCR1c2VySWQgPSAkZm9ybS0+Z2V0VmFsdWUoJ3VzZXInKSkpID8gJHVzZXJJZCA6ICgoJGlucHV0IGluc3RhbmNlb2YgUmVnaXN0cnkgJiYgKCR1c2VySWQgPSAkaW5wdXQtPmdldCgndXNlcicpKSkgPyAkdXNlcklkIDogMCk7DQoJCQkvLyBpZiBzdGlsbCBub3QgdXNlciBpcyBmb3VuZCBnZXQgbWVtYmVyIGlkDQoJCQlpZiAoJHVzZXJJZCA9PSAwKQ0KCQkJew0KCQkJCSRtZW1iZXJJZCA9ICgkZm9ybSBpbnN0YW5jZW9mIEZvcm0gJiYgKCRtZW1iZXJJZCA9ICRmb3JtLT5nZXRWYWx1ZSgnaWQnKSkpID8gJG1lbWJlcklkIDogKCgkaW5wdXQgaW5zdGFuY2VvZiBSZWdpc3RyeSAmJiAoJG1lbWJlcklkID0gJGlucHV0LT5nZXQoJ2lkJykpKSA/ICRtZW1iZXJJZCA6IDApOw0KCQkJfQ0KCQkJLy8gZ2V0IGFjY291bnQgdHlwZSBpZiBuZWVkZWQNCgkJCWlmICgkdXNlcklkID09IDAgJiYgJG1lbWJlcklkID4gMCkNCgkJCXsNCgkJCQkkYWNjb3VudElkID0gKCRmb3JtIGluc3RhbmNlb2YgRm9ybSAmJiAoJGFjY291bnRJZCA9ICRmb3JtLT5nZXRWYWx1ZSgnYWNjb3VudCcpKSkgPyAkYWNjb3VudElkIDogKCgkaW5wdXQgaW5zdGFuY2VvZiBSZWdpc3RyeSAmJiAoJGFjY291bnRJZCA9ICRpbnB1dC0+Z2V0KCdhY2NvdW50JykpKSA/ICRhY2NvdW50SWQgOiAwKTsNCgkJCQkvLyBtYWtlIHN1cmUgdGhlc2UgYWNjb3VudCBpcyBzZXQNCgkJCQlpZiAoJGFjY291bnRJZCA9PSAwKQ0KCQkJCXsNCgkJCQkJJGFjY291bnRJZCA9IFN1cGVyX19fZGI4N2MzMzlfNWJiNl80MjkxX2E3ZWZfMmM0OGVhMWIwNmJjX19fUG93ZXI6OnZhcignbWVtYmVyJywgJG1lbWJlcklkLCAnaWQnLCAnYWNjb3VudCcpOw0KCQkJCX0NCgkJCX0NCgkJCS8vIGdldCB1c2VyIHZhbHVlIGlmIG5vdCBzZXQgKGR1ZSB0byBwZXJtaXNzaW9ucykNCgkJCWlmICgkdXNlcklkID09IDAgJiYgJG1lbWJlcklkID4gMCAmJiAkYWNjb3VudElkID4gMCAmJiAoMSA9PSAkYWNjb3VudElkIHx8IDQgPT0gJGFjY291bnRJZCkpDQoJCQl7DQoJCQkJJHVzZXJJZCA9IFN1cGVyX19fZGI4N2MzMzlfNWJiNl80MjkxX2E3ZWZfMmM0OGVhMWIwNmJjX19fUG93ZXI6OnZhcignbWVtYmVyJywgJG1lbWJlcklkLCAnaWQnLCAndXNlcicpOw0KCQkJfQ0KCQkJJHF1ZXJ5LT53aGVyZSgkZGItPnF1b3RlTmFtZSgnaWQnKSAuICcgPD4gJyAuIChpbnQpICR1c2VySWQpOw0KDQoJCQkvLyBTZXQgYW5kIHF1ZXJ5IHRoZSBkYXRhYmFzZS4NCgkJCSRkYi0+c2V0UXVlcnkoJHF1ZXJ5KTsNCgkJCSRkdXBsaWNhdGUgPSAoYm9vbCkgJGRiLT5sb2FkUmVzdWx0KCk7DQoNCgkJCWlmICgkZHVwbGljYXRlKQ0KCQkJew0KCQkJCXJldHVybiBmYWxzZTsNCgkJCX0NCgkJfQ0KDQoJCXJldHVybiB0cnVlOw0KCX0=', 'Validate the member useremail', 1, '2018-09-16 00:43:44', ''),
(6, 'iban', '	/**
	* Method to check if IBAN is valid.
	*
	* @param   \SimpleXMLElement  $element  The SimpleXMLElement object representing the `<field>` tag for the form field object.
	* @param   mixed              $value    The form field value to validate.
	* @param   string             $group    The field name group control value. This acts as an array container for the field.
	*                                       For example if the field has name="foo" and the group value is set to "bar" then the
	*                                       full field name would end up being "bar[foo]".
	* @param   Registry           $input    An optional Registry object with the entire data set to validate against the entire form.
	* @param   Form               $form     The form object for which the field is being tested.
	*
	* @return  boolean  True if the value is valid, false otherwise.
	*
	* @since   3.9.0
	*/
	public function test(\SimpleXMLElement $element, $value, $group = null, Registry $input = null, Form $form = null)
	{
		$countryCodeOffset = 0; // COUNTRY_CODE_OFFSET
		$countryCodeLength = 2; //COUNTRY_CODE_LENGTH
		$checksumOffset = 2; //CHECKSUM_OFFSET
		$checksumLength = 2; //CHECKSUM_LENGTH
		$instituteIdentificationOffset = 4; //INSTITUTE_IDENTIFICATION_OFFSET

		/**
		* @var array Country code to size, regex format for each country that supports IBAN
		*/
		$ibanFormatMap = array(
			'AA' => array(12, '^[A-Z0-9]{12}$'),
			'AD' => array(20, '^[0-9]{4}[0-9]{4}[A-Z0-9]{12}$'),
			'AE' => array(19, '^[0-9]{3}[0-9]{16}$'),
			'AL' => array(24, '^[0-9]{8}[A-Z0-9]{16}$'),
			'AO' => array(21, '^[0-9]{21}$'),
			'AT' => array(16, '^[0-9]{5}[0-9]{11}$'),
			'AX' => array(14, '^[0-9]{6}[0-9]{7}[0-9]{1}$'),
			'AZ' => array(24, '^[A-Z]{4}[A-Z0-9]{20}$'),
			'BA' => array(16, '^[0-9]{3}[0-9]{3}[0-9]{8}[0-9]{2}$'),
			'BE' => array(12, '^[0-9]{3}[0-9]{7}[0-9]{2}$'),
			'BF' => array(23, '^[0-9]{23}$'),
			'BG' => array(18, '^[A-Z]{4}[0-9]{4}[0-9]{2}[A-Z0-9]{8}$'),
			'BH' => array(18, '^[A-Z]{4}[A-Z0-9]{14}$'),
			'BI' => array(12, '^[0-9]{12}$'),
			'BJ' => array(24, '^[A-Z]{1}[0-9]{23}$'),
			'BL' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'BR' => array(25, '^[0-9]{8}[0-9]{5}[0-9]{10}[A-Z]{1}[A-Z0-9]{1}$'),
			'CH' => array(17, '^[0-9]{5}[A-Z0-9]{12}$'),
			'CI' => array(24, '^[A-Z]{1}[0-9]{23}$'),
			'CM' => array(23, '^[0-9]{23}$'),
			'CR' => array(17, '^[0-9]{4}[0-9]{13}$'),
			'CV' => array(21, '^[0-9]{21}$'),
			'CY' => array(24, '^[0-9]{3}[0-9]{5}[A-Z0-9]{16}$'),
			'CZ' => array(20, '^[0-9]{4}[0-9]{6}[0-9]{10}$'),
			'DE' => array(18, '^[0-9]{8}[0-9]{10}$'),
			'DK' => array(14, '^[0-9]{4}[0-9]{9}[0-9]{1}$'),
			'DO' => array(24, '^[A-Z0-9]{4}[0-9]{20}$'),
			'DZ' => array(20, '^[0-9]{20}$'),
			'EE' => array(16, '^[0-9]{2}[0-9]{2}[0-9]{11}[0-9]{1}$'),
			'ES' => array(20, '^[0-9]{4}[0-9]{4}[0-9]{1}[0-9]{1}[0-9]{10}$'),
			'FI' => array(14, '^[0-9]{6}[0-9]{7}[0-9]{1}$'),
			'FO' => array(14, '^[0-9]{4}[0-9]{9}[0-9]{1}$'),
			'FR' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'GB' => array(18, '^[A-Z]{4}[0-9]{6}[0-9]{8}$'),
			'GE' => array(18, '^[A-Z]{2}[0-9]{16}$'),
			'GF' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'GI' => array(19, '^[A-Z]{4}[A-Z0-9]{15}$'),
			'GL' => array(14, '^[0-9]{4}[0-9]{9}[0-9]{1}$'),
			'GP' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'GR' => array(23, '^[0-9]{3}[0-9]{4}[A-Z0-9]{16}$'),
			'GT' => array(24, '^[A-Z0-9]{4}[A-Z0-9]{20}$'),
			'HR' => array(17, '^[0-9]{7}[0-9]{10}$'),
			'HU' => array(24, '^[0-9]{3}[0-9]{4}[0-9]{1}[0-9]{15}[0-9]{1}$'),
			'IE' => array(18, '^[A-Z]{4}[0-9]{6}[0-9]{8}$'),
			'IL' => array(19, '^[0-9]{3}[0-9]{3}[0-9]{13}$'),
			'IR' => array(22, '^[0-9]{22}$'),
			'IS' => array(22, '^[0-9]{4}[0-9]{2}[0-9]{6}[0-9]{10}$'),
			'IT' => array(23, '^[A-Z]{1}[0-9]{5}[0-9]{5}[A-Z0-9]{12}$'),
			'JO' => array(26, '^[A-Z]{4}[0-9]{4}[A-Z0-9]{18}$'),
			'KW' => array(26, '^[A-Z]{4}[A-Z0-9]{22}$'),
			'KZ' => array(16, '^[0-9]{3}[A-Z0-9]{13}$'),
			'LB' => array(24, '^[0-9]{4}[A-Z0-9]{20}$'),
			'LC' => array(28, '^[A-Z]{4}[A-Z0-9]{24}$'),
			'LI' => array(17, '^[0-9]{5}[A-Z0-9]{12}$'),
			'LT' => array(16, '^[0-9]{5}[0-9]{11}$'),
			'LU' => array(16, '^[0-9]{3}[A-Z0-9]{13}$'),
			'LV' => array(17, '^[A-Z]{4}[A-Z0-9]{13}$'),
			'MC' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'MD' => array(20, '^[A-Z0-9]{2}[A-Z0-9]{18}$'),
			'ME' => array(18, '^[0-9]{3}[0-9]{13}[0-9]{2}$'),
			'MF' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'MG' => array(23, '^[0-9]{23}$'),
			'MK' => array(15, '^[0-9]{3}[A-Z0-9]{10}[0-9]{2}$'),
			'ML' => array(24, '^[A-Z]{1}[0-9]{23}$'),
			'MQ' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'MR' => array(23, '^[0-9]{5}[0-9]{5}[0-9]{11}[0-9]{2}$'),
			'MT' => array(27, '^[A-Z]{4}[0-9]{5}[A-Z0-9]{18}$'),
			'MU' => array(26, '^[A-Z]{4}[0-9]{2}[0-9]{2}[0-9]{12}[0-9]{3}[A-Z]{3}$'),
			'MZ' => array(21, '^[0-9]{21}$'),
			'NC' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'NL' => array(14, '^[A-Z]{4}[0-9]{10}$'),
			'NO' => array(11, '^[0-9]{4}[0-9]{6}[0-9]{1}$'),
			'PF' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'PK' => array(20, '^[A-Z]{4}[A-Z0-9]{16}$'),
			'PL' => array(24, '^[0-9]{8}[0-9]{16}$'),
			'PM' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'PS' => array(25, '^[A-Z]{4}[A-Z0-9]{21}$'),
			'PT' => array(21, '^[0-9]{4}[0-9]{4}[0-9]{11}[0-9]{2}$'),
			'QA' => array(25, '^[A-Z]{4}[0-9]{4}[A-Z0-9]{17}$'),
			'RE' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'RO' => array(20, '^[A-Z]{4}[A-Z0-9]{16}$'),
			'RS' => array(18, '^[0-9]{3}[0-9]{13}[0-9]{2}$'),
			'SA' => array(20, '^[0-9]{2}[A-Z0-9]{18}$'),
			'SC' => array(27, '^[A-Z]{4}[0-9]{4}[0-9]{16}[A-Z]{3}$'),
			'SE' => array(20, '^[0-9]{3}[0-9]{16}[0-9]{1}$'),
			'SI' => array(15, '^[0-9]{5}[0-9]{8}[0-9]{2}$'),
			'SK' => array(20, '^[0-9]{4}[0-9]{6}[0-9]{10}$'),
			'SM' => array(23, '^[A-Z]{1}[0-9]{5}[0-9]{5}[A-Z0-9]{12}$'),
			'SN' => array(24, '^[A-Z]{1}[0-9]{23}$'),
			'ST' => array(21, '^[0-9]{8}[0-9]{11}[0-9]{2}$'),
			'TF' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'TL' => array(19, '^[0-9]{3}[0-9]{14}[0-9]{2}$'),
			'TN' => array(20, '^[0-9]{2}[0-9]{3}[0-9]{13}[0-9]{2}$'),
			'TR' => array(22, '^[0-9]{5}[0-9]{1}[A-Z0-9]{16}$'),
			'UA' => array(25, '^[0-9]{6}[A-Z0-9]{19}$'),
			'VG' => array(20, '^[A-Z]{4}[0-9]{16}$'),
			'WF' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$'),
			'XK' => array(16, '^[0-9]{4}[0-9]{10}[0-9]{2}$'),
			'YT' => array(23, '^[0-9]{5}[0-9]{5}[A-Z0-9]{11}[0-9]{2}$')
		);

		// CLEAN UP IBAN
		$iban = preg_replace('/[^a-z0-9]+/i', '', trim(strtoupper($value)));

		// CHECK Country Code
		$countryCode = substr($iban, $countryCodeOffset, $countryCodeLength);
		$isCountryCodeValid = !(isset($ibanFormatMap[$countryCode]) === false);

		$validLength = $countryCodeLength + $checksumLength + $ibanFormatMap[$countryCode][0];
		$isLengthValid = strlen($iban) === $validLength;

		$accountIdentification = substr($iban, $instituteIdentificationOffset);
		$isFormatValid = !(preg_match('/' . $ibanFormatMap[$countryCode][1] . '/', $accountIdentification) !== 1);

		$checksum = substr($iban, $checksumOffset, $checksumLength);
		$accountIdentification = substr($iban, $instituteIdentificationOffset);

		// GET NUMERIC COUNTRY CODE
		$numericRepresentation = '';
		$letterRepresentation = $countryCode;
		foreach (str_split($letterRepresentation) as $char)
		{
			$ord = ord($char);
			if ($ord >= 65 && $ord <= 90)
			{
				$numericRepresentation .= (string) ($ord - 55);
			}
			elseif ($ord >= 48 && $ord <= 57)
			{
				$numericRepresentation .= (string) ($ord - 48);
			}
		}
		$numericCountryCode = $numericRepresentation;

		$numericRepresentation = '';
		$letterRepresentation = $accountIdentification;
		foreach (str_split($letterRepresentation) as $char)
		{
			$ord = ord($char);
			if ($ord >= 65 && $ord <= 90)
			{
				$numericRepresentation .= (string) ($ord - 55);
			}
			elseif ($ord >= 48 && $ord <= 57)
			{
				$numericRepresentation .= (string) ($ord - 48);
			}
		}
		$numericAccountIdentification = $numericRepresentation;
		$invertedIban = $numericAccountIdentification . $numericCountryCode . $checksum;

		// CHECKSUM BCMOD
		$x = $invertedIban;
		$y = 97;
		if (!function_exists('bcmod'))
		{
			$take = 5;
			$mod = '';
			do {
				$a = (int)$mod . substr($x, 0, $take);
				$x = substr($x, $take);
				$mod = $a % $y;
			} while (strlen($x));
			$bcmod = (string)$mod;
		}
		else
		{
			$bcmod = bcmod($x, $y);
		}

		$isChecksumValid = $bcmod === '1';

		if (!$isCountryCodeValid || !$isLengthValid || !$isFormatValid || !$isChecksumValid)
		{
			return false;
		}
		else
		{
		    return true;
		}
	}', 'IBAN validation', 1, '2019-02-12 23:14:43', '');
--
-- Dumping data for table `#__componentbuilder_field`
--
INSERT INTO `#__componentbuilder_field` (`id`, `add_css_view`, `add_css_views`, `add_javascript_view_footer`, `add_javascript_views_footer`, `css_view`, `css_views`, `datadefault`, `datadefault_other`, `datalenght`, `datalenght_other`, `datatype`, `indexes`, `javascript_view_footer`, `javascript_views_footer`, `name`, `null_switch`, `store`, `fieldtype`, `xml`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `guid`, `on_get_model_field`, `on_save_model_field`, `initiator_on_get_model`, `initiator_on_save_model`, `params`) VALUES
(23, '', '', '', '', '', '', '', '', 64, '', 'CHAR', 2, '', '', 'Alias', 'NOT NULL', '', 24, '\"<field\\n\\ttype=\\\"text\\\"\\n\\tname=\\\"alias\\\"\\n\\tlabel=\\\"Alias\\\"\\n\\tfilter=\\\"STRING\\\"\\n\\thint=\\\"Auto-generated from name\\\"\\n\\/>\"', 1, '2015-04-09 13:46:04', '2023-06-27 23:46:54', 3, '', 216, '335866ce-b81b-4329-901d-c20254135c9c', '', '', '', '', ''),
(84, '', '', '', '', '', '', '', '', '', '', 'TEXT', '', '', '', 'Description (full width)', 'NULL', '', 25, '\"<field\\n\\ttype=\\\"textarea\\\"\\n\\tname=\\\"description\\\"\\n\\tlabel=\\\"Description\\\"\\n\\trows=\\\"11\\\"\\n\\tcols=\\\"10\\\"\\n\\tdescription=\\\"Add Description Here\\\"\\n\\tclass=\\\"text_area span12\\\"\\n\\tfilter=\\\"HTML\\\"\\n\\thint=\\\"Add Description Here\\\"\\n\\/>\"', 1, '2015-03-19 18:20:49', '2024-03-06 15:53:48', 5, '', 265, '749a9917-90c3-49c4-9e72-aa33b0683a87', '', '', '', '', ''),
(100, '', '', '', '', '', '', '', '', 255, '', 'VARCHAR', '', '', '', 'Email (required)', 'NOT NULL', '', 24, '\"<field \\r\\n\\ttype=\\\"text\\\" \\r\\n\\tname=\\\"email\\\" \\r\\n\\tlabel=\\\"Email\\\" \\r\\n\\tsize=\\\"10\\\" \\r\\n\\tmaxlength=\\\"50\\\" \\r\\n\\tdescription=\\\"Enter Email\\\" \\r\\n\\tclass=\\\"text_area\\\"\\r\\n\\tfilter=\\\"STRING\\\" \\r\\n\\tvalidate=\\\"email\\\" \\r\\n\\trequired=\\\"true\\\"\\r\\n\\tmessage=\\\"Error! Please add email address here.\\\" \\r\\n\\thint=\\\"demo@example.com\\\" \\r\\n\\/>\"', 1, '2015-05-05 23:44:32', '2016-02-07 22:43:18', 4, '', 285, '10c1eccb-b3c3-4325-a056-45a72d116fd8', '', '', '', '', ''),
(158, '', '', '', '', '', '', '', '', 255, '', 'VARCHAR', '', '', '', 'Image', 'NOT NULL', '', 12, '\"<field\\n\\ttype=\\\"media\\\"\\n\\tname=\\\"image\\\"\\n\\tlabel=\\\"Image\\\"\\n\\/>\"', 1, '2015-04-29 14:00:56', '2020-06-07 02:17:46', 2, '', 45, '0d6970af-b361-4f65-84f6-0eb0c5f09bad', '', '', '', '', ''),
(196, '', '', '', '', '', '', '', '', 64, '', 'VARCHAR', '', '', '', 'Mobile Phone', 'NOT NULL', '', 23, '\"<field type=\\\"text\\\" \\r\\nname=\\\"mobile_phone\\\" \\r\\nlabel=\\\"Mobile Phone\\\" \\r\\nsize=\\\"10\\\" \\r\\nmaxlength=\\\"50\\\" \\r\\ndefault=\\\"\\\" \\r\\ndescription=\\\"Enter Mobile Phone Number\\\" \\r\\nclass=\\\"text_area\\\" \\r\\nfilter=\\\"STRING\\\" \\r\\nvalidated=\\\"tel\\\" \\r\\nrequired=\\\"true\\\" \\r\\nmessage=\\\"Error! Please add mobile phone number here.\\\" \\r\\nhint=\\\"Mobile Phone Here\\\" \\/>\"', 1, '2015-04-07 22:12:58', '2016-03-28 14:00:02', 2, '', 7, '65933a19-243a-48b2-aae9-34e2da710051', '', '', '', '', ''),
(199, '', '', '', '', '', '', '', '', 255, '', 'VARCHAR', 2, '', '', 'Name (Key - Required)', 'NOT NULL', '', 24, '\"<field\\n\\ttype=\\\"text\\\"\\n\\tname=\\\"name\\\"\\n\\tlabel=\\\"Name\\\"\\n\\tsize=\\\"40\\\"\\n\\tmaxlength=\\\"150\\\"\\n\\tdescription=\\\"Enter Name Here\\\"\\n\\tclass=\\\"text_area\\\"\\n\\treadonly=\\\"false\\\"\\n\\tdisabled=\\\"false\\\"\\n\\trequired=\\\"true\\\"\\n\\tfilter=\\\"STRING\\\"\\n\\tmessage=\\\"Error! Please add name here.\\\"\\n\\thint=\\\"Name Here\\\"\\n\\/>\"', 1, '2015-03-19 17:30:59', '2023-06-19 22:38:40', 10, '', 4, '5d3d34dd-4876-4c6a-86ab-b4e162f22c08', '', '', '', '', ''),
(203, '', '', '', '', '', '', '', '', 1, '', 'INT', '', '', '', 'Not Required', 'NOT NULL', '', 9, '\"<field\\n\\ttype=\\\"hidden\\\"\\n\\tname=\\\"not_required\\\"\\n\\tdefault=\\\"\\u4e00_\\u4e00\\\"\\n\\/>\"', 1, '2015-05-08 16:19:16', '2023-09-27 07:57:19', 16, '', 19, 'da5e6901-6958-40e5-a4f5-6822d6fe57ac', '', '', '', '', ''),
(280, '', '', '', '', '', '', '', '', 255, '', 'VARCHAR', '', '', '', 'Website', 'NOT NULL', '', 27, '\"<field\\n\\ttype=\\\"url\\\"\\n\\tname=\\\"website\\\"\\n\\tlabel=\\\"Website\\\"\\n\\tsize=\\\"60\\\"\\n\\tmaxlength=\\\"150\\\"\\n\\tdescription=\\\"Enter website address\\\"\\n\\tclass=\\\"text_area\\\"\\n\\tfilter=\\\"url\\\"\\n\\tvalidated=\\\"url\\\"\\n\\tmessage=\\\"Error! Please add website here.\\\"\\n\\thint=\\\"http:\\/\\/www.example.com\\\"\\n\\tscheme=\\\"http,https\\\"\\n\\/>\"', 1, '2015-04-08 00:36:16', '2018-07-08 00:11:05', 2, '', 105, '6c3a6983-d1bf-4e5e-9e99-deea00b0cefd', '', '', '', '', ''),
(682, '', '', '', '', '', '', '', '', 1, '', 'TINYINT', 2, '', '', 'Add More', 'NOT NULL', '', 17, '\"<field\\n\\ttype=\\\"radio\\\"\\n\\tname=\\\"add\\\"\\n\\tlabel=\\\"Add More\\\"\\n\\tdescription=\\\"\\\"\\n\\tclass=\\\"btn-group btn-group-yesno\\\"\\n\\toption=\\\"1|Yes,0|No\\\"\\n\\tdefault=\\\"0\\\"\\n\\trequired=\\\"true\\\"\\n\\/>\"', 1, '2015-08-05 01:18:20', '2023-01-20 11:15:45', 7, '', 196, 'a66389aa-2323-4f44-8c23-ff44969639be', '', '', '', '', ''),
(1011, '', '', '', '', '', '', 'Other', '0000-00-00', '', '', 'DATE', '', '', '', 'Date of Birth', 'NOT NULL', '', 1, '\"<field\\n\\ttype=\\\"calendar\\\"\\n\\tname=\\\"dateofbirth\\\"\\n\\tlabel=\\\"Date of Birth\\\"\\n\\tdefault=\\\"1970-01-01\\\"\\n\\tdescription=\\\"Your date of birth\\\"\\n\\tformat=\\\"%Y-%m-%d\\\"\\n\\tminyear=\\\"-120\\\"\\n\\tmaxyear=\\\"-1\\\"\\n\\tfilter=\\\"STRING\\\"\\n\\ttodaybutton=\\\"false\\\"\\n\\trequired=\\\"true\\\"\\n\\/>\"', 1, '2015-12-07 01:47:32', '2018-08-03 09:56:07', 4, '', 649, 'cb2bdf20-8800-407b-a4f6-250152a0bdfb', '', '', '', '', '');
--
-- Dumping data for table `#__componentbuilder_fieldtype`
--
INSERT INTO `#__componentbuilder_fieldtype` (`id`, `description`, `name`, `properties`, `short_description`, `params`, `published`, `version`, `hits`, `ordering`, `guid`) VALUES
(1, 'The calendar form field type provides a text box for entry of a date. An icon next to the text box provides a link to a pop-up calendar, which can also be used to enter the date value. If the field has a saved value this is shown in the text box. Otherwis', 'Calendar', '{\"properties0\":{\"name\":\"type\",\"example\":\"calendar\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be calendar.\"},\"properties1\":{\"name\":\"name\",\"example\":\"date\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select a date\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"NOW\",\"adjustable\":\"1\",\"description\":\"(optional) is the default date. This must be given in the same format as specified by the format argument. You can put \\\"NOW\\\" to have current time.\"},\"properties4\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the text box.\"},\"properties5\":{\"name\":\"readonly\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is whether the text box is read-only (true or false). If the text box is read-only, the date cannot be changed, but can be selected and copied. No calendar icon will be shown.\"},\"properties6\":{\"name\":\"disabled\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is whether the text box is disabled (true or false). If the text box is disabled, the date cannot be changed, selected or copied.\"},\"properties7\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field.\"},\"properties8\":{\"name\":\"format\",\"example\":\"%d-%m-%Y\",\"adjustable\":\"1\",\"description\":\"(optional) is the date format to be used. This is in the format used by PHP to specify date string formats (see below). If no format argument is given, \'%Y-%m-%d\' is assumed (giving dates like \'2008-04-16\').\"},\"properties9\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is time zone to be used. There are two values; server_utc and user_utc. The first one is server time zone and the later is user time zone as configured in global configuration and user information respectively.\"},\"properties10\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties23\":{\"name\":\"message\",\"example\":\"Error! Please add some text here.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The error message that will be displayed instead of the default message.\"},\"properties11\":{\"name\":\"size\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional)\"},\"properties12\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties13\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties14\":{\"name\":\"translateformat\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): If set to true, the calendar will use a language string to determine the format. The `format` attribute is ignored. If false, the `format` attribute is used (same behaviour as today). (starting with 3.7.0)\"},\"properties15\":{\"name\":\"showtime\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): If set to true and translateformat is true, the language key DATE_FORMAT_CALENDAR_DATETIME is used, otherwise DATE_FORMAT_CALENDAR_DATE. (starting with 3.7.0)\"},\"properties16\":{\"name\":\"timeformat\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): can be set to 12 (and specify AM or PM) or 24 (starting with 3.7.0)\"},\"properties17\":{\"name\":\"singleheader\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): if set to false, the year and the month selection will be set on two separates lines, with independant selection (starting with 3.7.0)\"},\"properties18\":{\"name\":\"todaybutton\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): if set to true, a button is added at the bottom of the datePicker to select the date of the current day (starting with 3.7.0)\"},\"properties19\":{\"name\":\"weeknumbers\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): if set to true, a column is added at the left of the datePicker to display the number of the week in the current year (starting with 3.7.0)\"},\"properties20\":{\"name\":\"filltable\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): if set to true, dates of the previous and next month is added at the top and the bottom of the current month to fill the grid (starting with 3.7.0)\"},\"properties21\":{\"name\":\"minyear\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): set a signed integer for a number of years (-10, -2, 0, 7, 12, ...) to define the relative lower limit for the year selection. The user could not select a year before your limit (starting with 3.7.0)\"},\"properties22\":{\"name\":\"maxyear\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional): set a signed integer for a number of years (-10, -2, 0, 7, 12, ...) to define the relative upper limit for the year selection. The user could not select a year after your limit (starting with 3.7.0)\"}}', 'provides a text box for entry of a date. An icon next to the text box provides a link to a pop-up calendar, which can also be used to enter the date value.', '', 1, 9, '', '', '6cf5a33f-cb25-4a58-bfec-7e1511896402'),
(2, 'The category form field type provides a drop down list of all published categories for a certain extension. If the parameter has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected. If the show_root', 'Category', '{\"properties0\":{\"name\":\"type\",\"example\":\"category\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be category.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mycategory\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select a category\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"extension\",\"example\":\"com_content\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the name of the extension for which the categories will be retrieved. For example, to list content categories, use the value \'com_content\'. You can add also target one view, use the value \'com_component.view\'.\"},\"properties4\":{\"name\":\"scope\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is an alias for extension.\"},\"properties5\":{\"name\":\"required\",\"example\":\"true\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties6\":{\"name\":\"show_root\",\"example\":\"true\",\"adjustable\":\"1\",\"description\":\"(optional) is whether a choice representing the root category will be shown. Remove completely if it is not to be shown.\"},\"properties7\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default category ID number.\"},\"properties8\":{\"name\":\"description\",\"example\":\"select one of the following categories\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties9\":{\"name\":\"class\",\"example\":\"inputbox\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties10\":{\"name\":\"published\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(optional) (1\\/0\\/2\\/-2) is whether the drop down will show only published (1), unpublished (0), archived (2) or trashed (-2) categories. It is possible to combine different publishing status by entering the list of the corresponding numbers separated by comma (e.g. \\\"0,2,-2\\\" will display only unpublished, archived and trashed categories in the drop-down).\"},\"properties11\":{\"name\":\"multiple\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) is whether multiple items can be selected at the same time (true or false).\"},\"properties12\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a drop down list of categories for an extension.', '', 1, 13, '', '', 'f70346b3-2096-4f44-8b26-01ab87da7d1e'),
(3, 'The checkbox form field type provides a single checkbox. If the parameter has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.', 'Checkbox', '{\"properties0\":{\"name\":\"type\",\"example\":\"checkbox\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be checkbox\"},\"properties1\":{\"name\":\"name\",\"example\":\"show_title\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Show title\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"value\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(optional) is the value of the parameter if this checkbox is set (usually 1).\"},\"properties4\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default value (usually 0 or 1).\"},\"properties5\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties6\":{\"name\":\"description\",\"example\":\"Show the title of the item\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the label.\"},\"properties7\":{\"name\":\"class\",\"example\":\"inputbox\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties8\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties9\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (JavaScript use)\"}}', 'provides a single checkbox to be checked or unchecked', '', 1, 7, '', '', '10066262-b6e3-4f82-941e-cbe4f61ddd6c'),
(4, 'The checkboxes form field type provides a set of checkboxes. Note: unlike most standard form field types, such as textfield or checkbox, this field is not an \"out of the box\" solution. It will create checkboxes for you, and submit their values in form of ', 'Checkboxes', '{\"properties0\":{\"name\":\"type\",\"example\":\"checkboxes\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be checkboxs\"},\"properties1\":{\"name\":\"name\",\"example\":\"toppings\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select Toppings\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"option\",\"example\":\"anch|Anchovies,chor|Chorizo,on|Onions,mush|Mushrooms\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) set the options of this radio. Separate options with commas and use the pipe symbol to separate value from text.\"},\"properties4\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default value.\"},\"properties5\":{\"name\":\"description\",\"example\":\"Select the topping of your choice\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the label.\"},\"properties6\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties7\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties8\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides unlimited checkboxes that can be used for multi-select.', '', 1, 4, '', '', 'ac10859b-58da-4584-9682-36a6c2c8d04d'),
(5, 'Provides a color picker. Enter the color as #ff00ff or pick it from the palet.', 'Color', '{\"properties0\":{\"name\":\"type\",\"example\":\"color\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be color.\"},\"properties1\":{\"name\":\"name\",\"example\":\"backgroundcolor\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"default\",\"example\":\"#FFFFFF\",\"adjustable\":\"1\",\"description\":\"(optional) provides a color when not set.\"},\"properties3\":{\"name\":\"label\",\"example\":\"Background\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties4\":{\"name\":\"description\",\"example\":\"Select the background color here.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) tooltip for the form field.\"},\"properties5\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties6\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a color picker when clicking the input box.', '', 1, 5, '', '', '7f60f198-53e7-4fe9-813f-d1b6c553680e'),
(6, 'The list form field type provides a drop down list or a list box of other current component table entries. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.', 'Custom', '{\"properties0\":{\"name\":\"type\",\"example\":\"subjects\",\"mandatory\":\"1\",\"description\":\"(mandatory) can be anything, just not the same as any other default Joomla field type. You can also not use the \\\"_\\\" (underscore) or \\\"-\\\" (hyphen) in the type name, and no spaces.\"},\"properties1\":{\"name\":\"name\",\"example\":\"subject\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select a Subject\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties5\":{\"name\":\"class\",\"example\":\"list_class\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties24\":{\"name\":\"layout\",\"example\":\"joomla.form.field.list-fancy-select\",\"adjustable\":\"1\",\"description\":\"(optional) New layout field added in Joomla 4\"},\"properties6\":{\"name\":\"multiple\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) is whether multiple items can be selected at the same time (true or false).\"},\"properties7\":{\"name\":\"default\",\"example\":\"0\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties8\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties9\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties10\":{\"name\":\"readonly\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties11\":{\"name\":\"disabled\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties12\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties13\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"},\"properties14\":{\"name\":\"extends\",\"example\":\"list\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"The JFormField sub class that should be extended. The options are (\'list\',\'radio\',\'checkboxes\')\"},\"properties15\":{\"name\":\"button\",\"example\":\"true\",\"adjustable\":\"1\",\"description\":\"(optional) to add new button next to field in edit view\"},\"properties16\":{\"name\":\"table\",\"example\":\"#__###component###_subject\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The table being linked to. The ###TABLE### placeholder holds the table in the php.\"},\"properties17\":{\"name\":\"component\",\"example\":\"com_###component###\",\"mandatory\":\"1\",\"description\":\"(mandatory) The name of the component where this table is found. Must be com_users\"},\"properties18\":{\"name\":\"view\",\"example\":\"subject\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The single view name if the place this field is added.\"},\"properties19\":{\"name\":\"views\",\"example\":\"subjects\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The list view name if the place this field is added.\"},\"properties20\":{\"name\":\"value_field\",\"example\":\"name\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The name of the text field in table linked to. The ###TEXT### placeholder holds the value_field in the php.\"},\"properties21\":{\"name\":\"key_field\",\"example\":\"id\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The field from the linked table to save in this table as the unique key. The ###ID### placeholder holds the key_field in the php.\"},\"properties22\":{\"name\":\"prime_php\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"This field makes sure that the PHP used here is used to build the field type, and other are custom fields with the same field type are ignored. So to avoid that they over write the PHP added here. You should only have one prime per\\/type. To disable remove the field or set to 0\"},\"properties23\":{\"name\":\"type_php_1\",\"example\":\"\\/\\/ Get the user object.\\r\\n\\t\\t$user = Factory::getUser();\\r\\n\\t\\t\\/\\/ Get the databse object.\\r\\n\\t\\t$db = Factory::getDBO();\\r\\n\\t\\t$query = $db->getQuery(true);\\r\\n\\t\\t$query->select($db->quoteName(array(\'a.###ID###\',\'a.###TEXT###\'),array(\'###ID###\',\'###CODE_TEXT###\')));\\r\\n\\t\\t$query->from($db->quoteName(\'###TABLE###\', \'a\'));\\r\\n\\t\\t$query->where($db->quoteName(\'a.published\') . \' = 1\');\\r\\n\\t\\t$query->order(\'a.###TEXT### ASC\');\\r\\n\\t\\t\\/\\/ Implement View Level Access (if set in table)\\r\\n\\t\\tif (!$user->authorise(\'core.options\', \'[[[com_component]]]\'))\\r\\n\\t\\t{\\r\\n\\t\\t\\t$columns = $db->getTableColumns(\'###TABLE###\');\\r\\n\\t\\t\\tif(isset($columns[\'access\']))\\r\\n\\t\\t\\t{\\r\\n\\t\\t\\t\\t$groups = implode(\',\', $user->getAuthorisedViewLevels());\\r\\n\\t\\t\\t\\t$query->where(\'a.access IN (\' . $groups . \')\');\\r\\n\\t\\t\\t}\\r\\n\\t\\t}\\r\\n\\t\\t$db->setQuery((string)$query);\\r\\n\\t\\t$items = $db->loadObjectList();\\r\\n\\t\\t$options = [];\\r\\n\\t\\tif ($items)\\r\\n\\t\\t{\\r\\n\\t\\t\\tif ($this->multiple === false)\\r\\n\\t\\t\\t{\\r\\n\\t\\t\\t\\t$options[] = Html::_(\'select.option\', \'\', Text::_(\'Select an option\'));\\r\\n\\t\\t\\t}\\r\\n\\t\\t\\tforeach($items as $item)\\r\\n\\t\\t\\t{\\r\\n\\t\\t\\t\\t$options[] = Html::_(\'select.option\', $item->###ID###, $item->###CODE_TEXT###);\\r\\n\\t\\t\\t}\\r\\n\\t\\t}\\r\\n\\t\\treturn $options;\",\"adjustable\":\"1\",\"description\":\"The php for the getOptions method.\"}}', 'provides a drop down list of items entries.', '', 1, 30, '', '', 'dd2e1f4b-f5db-45e8-85fa-efd27bae7b6a'),
(7, 'The a list of users that can be targeting one or more groups and excluded users that already belongs to an item in a view.', 'CustomUser', '{\"properties0\":{\"name\":\"type\",\"example\":\"staffusers\",\"mandatory\":\"1\",\"description\":\"(mandatory) can be anything, just not the same as any other default Joomla field type.\"},\"properties1\":{\"name\":\"name\",\"example\":\"staff\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Staff\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties5\":{\"name\":\"multiple\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) is whether multiple items can be selected at the same time (true or false).\"},\"properties6\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties7\":{\"name\":\"readonly\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties8\":{\"name\":\"disabled\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties9\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"\"},\"properties10\":{\"name\":\"hint\",\"example\":\"select a user\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"\"},\"properties11\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties12\":{\"name\":\"extends\",\"example\":\"user\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"The JFormField sub class that should be extended. The options are (\'list\',\'radio\',\'checkboxes\')\"},\"properties13\":{\"name\":\"table\",\"example\":\"#__users\",\"mandatory\":\"1\",\"description\":\"(mandatory) The table being linked to. Must be #__users\"},\"properties14\":{\"name\":\"component\",\"example\":\"com_users\",\"mandatory\":\"1\",\"description\":\"(mandatory) The name of the component where this table is found. Must be com_users\"},\"properties15\":{\"name\":\"view\",\"example\":\"###view###\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The single view name if the place this field is added.\"},\"properties16\":{\"name\":\"views\",\"example\":\"###views###\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The list view name if the place this field is added.\"},\"properties17\":{\"name\":\"value_field\",\"example\":\"name\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The name of the text field in table linked to.\"},\"properties18\":{\"name\":\"key_field\",\"example\":\"id\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The field from the linked table to save in this table as the unique key.\"},\"properties19\":{\"name\":\"type_php_1\",\"example\":\"\\t\\t\\/\\/ set the groups array\\r\\n\\t\\treturn ComponentHelper::getParams(\'com_###component###\')->get(\'###type###\');\",\"adjustable\":\"1\",\"description\":\"The php for the getGroups method.\"},\"properties22\":{\"name\":\"type_phpx_1\",\"example\":\"\\t\\t\\/\\/ To ensure that there is only one record per user\\r\\n\\t\\t\\/\\/ Get a db connection.\\r\\n\\t\\t$db = Factory::getDbo();\\r\\n\\t\\t\\/\\/ Create a new query object.\\r\\n\\t\\t$query = $db->getQuery(true);\\r\\n\\t\\t\\/\\/ Select all records from the #__###component###_###view### table from ###CODE### column\\\".\\r\\n\\t\\t$query->select($db->quoteName(\'###CODE###\'));\\r\\n\\t\\t$query->from($db->quoteName(\'#__###component###_###view###\'));\\r\\n\\t\\t$db->setQuery($query);\\r\\n\\t\\t$db->execute();\\r\\n\\t\\t$found = $db->getNumRows();\\r\\n\\t\\tif ($found)\\r\\n\\t\\t{\\r\\n\\t\\t\\t\\/\\/ return all users already used\\r\\n\\t\\t\\treturn array_unique($db->loadColumn());\\r\\n\\t\\t}\\r\\n\\t\\treturn null;\",\"adjustable\":\"1\",\"description\":\"The php for the getExcluded method.\"}}', 'Provides list of users.', '', 1, 6, '', '', 'a4a39f70-070f-459c-be4b-0ac103a29b9a'),
(8, 'The Editor field type provides a WYSIWYG editor.', 'Editor', '{\"properties0\":{\"name\":\"type\",\"example\":\"editor\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be editor.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mytextblock\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Test Field\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"Some text\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties4\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the label.\"},\"properties5\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties6\":{\"name\":\"width\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) defines the width (in pixels) of the wysiwyg editor and defaults to 100%.\"},\"properties7\":{\"name\":\"height\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) defines the height (in pixels) of the wysiwyg editor and defaults to 250px.\"},\"properties8\":{\"name\":\"cols\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) defines the width of the editor (in columns).\"},\"properties9\":{\"name\":\"rows\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) defines the height of the editor (in rows).\"},\"properties10\":{\"name\":\"buttons\",\"example\":\"no\",\"adjustable\":\"1\",\"description\":\"(optional) can be an array of plugin buttons to be excluded or set to false. The default editors-xtd are: article, image, pagebreak and readmore.\"},\"properties11\":{\"name\":\"syntax\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) can be used to set the code syntax matching for this field.\"},\"properties12\":{\"name\":\"hide\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) array of plugin buttons to be hidden. eg... set buttons=\\\"true\\\" hide=\\\"readmore,pagebreak\\\"\"},\"properties13\":{\"name\":\"editor\",\"example\":\"codemirror|none\",\"adjustable\":\"1\",\"description\":\"specifies the editor to be used and can include two options (editor=\\\"desired|alternative\\\")\"},\"properties14\":{\"name\":\"filter\",\"example\":\"safehtml\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties15\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties16\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties17\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides an editor area field.', '', 1, 11, '', '', '51f288d2-6eaa-42bc-a182-a6f69b3032b8'),
(9, 'The hidden form field type provides a hidden field for saving a field whose value cannot be altered directly by a user in the Administrator (it can be altered in code or by editing the params.ini file). If the parameter has a saved value this is entered i', 'Hidden', '{\"properties0\":{\"name\":\"type\",\"example\":\"hidden\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be hidden.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mysecretvariable\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"default\",\"example\":\"1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the data which needs to be collected.\"},\"properties5\":{\"name\":\"filter\",\"example\":\"STRING\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties4\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"}}', 'provides a hidden field for saving a form field whose value cannot be altered directly by a user.', '', 1, 2, '', '', '82f1b5ca-bb9b-44d7-9a7a-9a03fb2a31dd'),
(10, 'The integer form field type provides a select box with a range of integer values. If the field has a value saved, this value is displayed when the page is first loaded. If not, the default value (if any) is selected.', 'Integer', '{\"properties0\":{\"name\":\"type\",\"example\":\"integer\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be integer.\"},\"properties1\":{\"name\":\"name\",\"example\":\"size\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Size\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default value.\"},\"properties4\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties5\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties6\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties7\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties8\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties9\":{\"name\":\"first\",\"example\":\"1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) this value is the lowest on the list.\"},\"properties10\":{\"name\":\"last\",\"example\":\"20\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) this value is the highest on the list.\"},\"properties11\":{\"name\":\"step\",\"example\":\"5\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) each option will be the previous option incremented by this integer, starting with the first value until the last value is reached.\"},\"properties12\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties13\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a drop down list of integers between a minimum and maximum.', '', 1, 6, '', '', 'fdbb50ea-35d2-45b2-a0bc-076fdf1544b8'),
(11, 'The list form field type provides a drop down list or a list box of custom-defined entries. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.', 'List', '{\"properties0\":{\"name\":\"type\",\"example\":\"list\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be list.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mylist\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select an option\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties5\":{\"name\":\"class\",\"example\":\"list_class\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties6\":{\"name\":\"layout\",\"example\":\"joomla.form.field.list-fancy-select\",\"adjustable\":\"1\",\"description\":\"(optional) New layout field added in Joomla 4\"},\"properties7\":{\"name\":\"multiple\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) is whether multiple items can be selected at the same time (true or false).\"},\"properties8\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) filter options\"},\"properties9\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties10\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties11\":{\"name\":\"option\",\"example\":\"0|Option 1,1|Option 2,2|Option 1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) set the options of this radio. Separate options with commas and use the pipe symbol to separate value from text.\"},\"properties12\":{\"name\":\"useglobal\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) if set to true, it will show the value that is set in the global configuration if found in the database.\"},\"properties13\":{\"name\":\"default\",\"example\":\"0\",\"adjustable\":\"1\",\"description\":\"(optional) is the default list item value.\"},\"properties14\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties15\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a drop down list of custom-defined entries.', '', 1, 12, '', '', 'a51dfc06-1b9b-4d0a-86ba-f705bcd40d4d'),
(12, 'The media form field type provides modal access to the media manager for the choice of an image. Users with appropriate permissions will be able to upload files.', 'Media', '{\"properties0\":{\"name\":\"type\",\"example\":\"media\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be media.\"},\"properties1\":{\"name\":\"name\",\"example\":\"media\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Media\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"directory\",\"example\":\"\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the directory from which the user will be able to choose a file. This attribute should be relative to the top level \\/images\\/ folder.\"},\"properties5\":{\"name\":\"preview\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) shows or hides the preview of the currently chosen image. (\\\"true\\\": Show always, \\\"tooltip\\\": Show as tooltip, \\\"false\\\": Show never) (since Joomla! 2.5.5)\"},\"properties6\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties7\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides modal access to the media manager for insertion of images with upload for users with appropriate permissions.', '', 1, 5, '', '', '69957007-e3d4-4976-a32b-611d02dbad71'),
(13, 'Provides a meter to show value in a range, updated with jQuery if needed or simply a fixed value.', 'Meter', '{\"properties0\":{\"name\":\"type\",\"example\":\"meter\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be meter.\"},\"properties1\":{\"name\":\"name\",\"example\":\"meter\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Meter\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"width\",\"example\":\"330px\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of meter box\"},\"properties4\":{\"name\":\"color\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The background color\"},\"properties5\":{\"name\":\"default\",\"example\":\"9\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties6\":{\"name\":\"animated\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(optional) lets the bar have strips\"},\"properties7\":{\"name\":\"active\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(optional) lets the strips on the bar move\"},\"properties8\":{\"name\":\"description\",\"example\":\"Enter some description\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties9\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties10\":{\"name\":\"min\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(mandatory) this value is the min on the meter.\"},\"properties11\":{\"name\":\"max\",\"example\":\"20\",\"adjustable\":\"1\",\"description\":\"(mandatory) this value is the max on meter.\"},\"properties12\":{\"name\":\"step\",\"example\":\"1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) each option will be the previous option incremented by this integer, starting with the first value until the last value is reached.\"},\"properties13\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a meter to show value in a range.', '', 1, 3, '', '', '81668284-e572-4e17-927b-ba697fc64bd0'),
(14, 'This form field makes it possible to create titles, texts, descriptions and even alert boxes. It also allows you to bring order in the settings for extensions, by separating them with useful titles. Or adding descriptions for certain settings (without having to rely on the tooltips). Or adding any other text you want.', 'Note', '{\"properties0\":{\"name\":\"type\",\"example\":\"note\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be note\"},\"properties1\":{\"name\":\"name\",\"example\":\"note_one\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"The notice\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory or optional if using description) (translatable) is the descriptive title of the note \"},\"properties3\":{\"name\":\"description\",\"example\":\"The notice description\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional if using label)(translatable) the description\\/text of the note \"},\"properties4\":{\"name\":\"heading\",\"example\":\"h4\",\"adjustable\":\"1\",\"description\":\"(optional) the type of heading element to use for the label (default: h4)\"},\"properties5\":{\"name\":\"class\",\"example\":\"alert\",\"adjustable\":\"1\",\"description\":\"(optional) a class name (or class names), like these examples ( alert, alert alert-info, alert alert-success, alert alert-error )\"},\"properties6\":{\"name\":\"close\",\"example\":\"true\",\"adjustable\":\"1\",\"description\":\"(optional) a value of \'true\' (for alerts) or the value for the data-dismiss of the bootstrap close icon\"},\"properties7\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'supports a one line text field.', '', 1, 5, '', '', 'f9ecacd0-8481-4157-8c71-d7aaefc2b7c3'),
(15, 'Provides a one line text box with up-down handles to set a number in the field.', 'Number', '{\"properties0\":{\"name\":\"type\",\"example\":\"number\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be number.\"},\"properties1\":{\"name\":\"name\",\"example\":\"number\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Number\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default value.\"},\"properties4\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties5\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties6\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties7\":{\"name\":\"min\",\"example\":\"1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) this value is the lowest on the list.\"},\"properties8\":{\"name\":\"max\",\"example\":\"40\",\"mandatory\":\"1\",\"description\":\"(mandatory) this value is the highest on the list.\"},\"properties9\":{\"name\":\"step\",\"example\":\"5\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) each option will be the previous option incremented by this integer, starting with the first value until the last value is reached.\"},\"properties10\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Javascript that should run on changing of the value.\"},\"properties11\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a one line text box with up-down handles to set a number in the field.', '', 1, 4, '', '', '5abd2b73-643b-4273-841a-787991aad968'),
(16, 'The password form field type provides a text box for entry of a password. The password characters will be obscured as they are entered. If the field has a saved value this is entered (in obscured form) into the text box. If not, the default value (if any)', 'Password', '{\"properties0\":{\"name\":\"type\",\"example\":\"password\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be password.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mypassword\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Enter A Password\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"size\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties4\":{\"name\":\"default\",\"example\":\"secret\",\"adjustable\":\"1\",\"description\":\"(optional) is the default password.\"},\"properties5\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties6\":{\"name\":\"message\",\"example\":\"Error! Please add password here.\",\"adjustable\":\"1\",\"description\":\"(optional) The error message that will be displayed instead of the default message.\"},\"properties7\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties8\":{\"name\":\"readonly\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties9\":{\"name\":\"disabled\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties10\":{\"name\":\"required\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties11\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties12\":{\"name\":\"field\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) used in validation of \\\"equals\\\" to link the field to match.\"},\"properties13\":{\"name\":\"filter\",\"example\":\"raw\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties14\":{\"name\":\"hint\",\"example\":\"Password Here\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The placeholder to display inside the text box.\"},\"properties15\":{\"name\":\"autocomplete\",\"example\":\"off\",\"adjustable\":\"1\",\"description\":\"(optional) The autocomplete state for the form field. If \'off\' element will not be automatically completed by browser.\"},\"properties16\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties17\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a text box for entry of a password. The password characters will be obscured as they are entered.', '', 1, 10, '', '', '0022598d-0ee1-44f2-aa94-c2eb47595f73'),
(17, 'The radio form field type provides radio buttons to select different options. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.', 'Radio', '{\"properties0\":{\"name\":\"type\",\"example\":\"radio\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be radio.\"},\"properties1\":{\"name\":\"name\",\"example\":\"myradiovalue\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select an option\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"class\",\"example\":\"btn-group btn-group-yesno\",\"adjustable\":\"1\",\"description\":\"(optional) New in Joomla 3, if set to class=\\\"btn-group btn-group-yesno\\\" will show the nice coloured buttons\"},\"properties5\":{\"name\":\"option\",\"example\":\"1|Yes,0|No\",\"adjustable\":\"1\",\"description\":\"(mandatory) set the options of this radio. Separate options with commas and use the pipe symbol to separate value from text.\"},\"properties6\":{\"name\":\"default\",\"example\":\"0\",\"adjustable\":\"1\",\"description\":\"(optional) is the default radio button item value.\"},\"properties7\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties8\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties9\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties10\":{\"name\":\"readonly\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties11\":{\"name\":\"disabled\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties12\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties13\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides radio buttons to select different options.', '', 1, 18, '', '', 'b868ed59-4208-4206-8504-95a35a74a11c'),
(18, 'Provides a horizontal scroll bar to specify a value in a range.', 'Range', '{\"properties0\":{\"name\":\"type\",\"example\":\"range\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be range.\"},\"properties1\":{\"name\":\"name\",\"example\":\"range\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Range\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"9\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties4\":{\"name\":\"description\",\"example\":\"Enter some description\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties5\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties6\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties7\":{\"name\":\"min\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(mandatory) this value is the min on the meter.\"},\"properties8\":{\"name\":\"max\",\"example\":\"20\",\"adjustable\":\"1\",\"description\":\"(mandatory) this value is the max on meter.\"},\"properties9\":{\"name\":\"step\",\"example\":\"1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) each option will be the previous option incremented by this integer, starting with the first value until the last value is reached.\"},\"properties10\":{\"name\":\"required\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties11\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties12\":{\"name\":\"onchange\",\"example\":\"jQuery(\'#jform_range\').closest(\'.controls\').find(\'span\').remove(); var value = jQuery(\'#jform_range\').val();jQuery(\'#jform_range\').closest(\'.controls\').append(\' \'+value+\'\');\",\"adjustable\":\"1\",\"description\":\"(optional) javascript to run when the range is changed\"},\"properties13\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a horizontal scroll bar to specify a value in a range.', '', 1, 5, '', '', '627d3845-7273-4f75-8e63-7b3a319a42c8'),
(19, 'Provides a modal with rows of formfields that you specify. As many options can be added as desired. Note this form field has a jQuery based javascript file as a dependency.', 'Repeatable', '{\"properties0\":{\"name\":\"type\",\"example\":\"repeatable\",\"adjustable\":\"1\",\"description\":\"(mandatory) must be repeatable.\"},\"properties1\":{\"name\":\"name\",\"example\":\"repeatable_list\",\"adjustable\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter\"},\"properties2\":{\"name\":\"label\",\"example\":\"The Repeatable List\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) description text for the form field. Displays at the top of the modal with the name as well as in the usual position in the form\"},\"properties4\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The default value for the form field if the field is left empty. Note this has to be a json string compatible with the contents of the form field.\"},\"properties5\":{\"name\":\"id\",\"example\":\"aid\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) id of the hidden from field. (the modal will have this id with an added suffix of \\\"_modal\\\" and the table within the modal will have this id with a suffix of _modal_table\\\")\"},\"properties6\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) class of the table.\"},\"properties7\":{\"name\":\"select\",\"example\":\"Click here\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) The text to show on the modal button.\"},\"properties8\":{\"name\":\"icon\",\"example\":\"list\",\"adjustable\":\"1\",\"description\":\"(optional) The icon to show on the select button (is prefixed with \\\"icon-\\\").\"},\"properties9\":{\"name\":\"maximum\",\"example\":\"50\",\"adjustable\":\"1\",\"description\":\"(optional) The maximum number of rows of fields allowed (by default 999 to be effectively infinite)\"},\"properties10\":{\"name\":\"fields\",\"example\":\"1,2,3\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The fields to add to the modal. All fields must first be created in component builder as a field before you can add them here, since you must use the id of the field. Separate the field ids with commas. Do not add custom fields that are not also used in this component.\"},\"properties11\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Use only if you would like to save raw data, since the default is best.\"},\"properties12\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Allows form fields which can have as many options as the user desires.', '', 1, 5, '', '', '05bf68d4-52f9-4705-8ae7-cba137fce0ad'),
(20, 'The spacer form field type provides a visual separator between parameter field elements. It is purely a visual aid and no field value is stored.', 'Spacer', '{\"properties0\":{\"name\":\"type\",\"example\":\"spacer\",\"adjustable\":\"0\",\"mandatory\":\"1\",\"translatable\":\"0\",\"description\":\"(mandatory) must be spacer.\"},\"properties1\":{\"name\":\"name\",\"example\":\"myspacer\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"0\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"The notice\",\"adjustable\":\"1\",\"mandatory\":\"0\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is the text to use as a spacer.\"},\"properties3\":{\"name\":\"description\",\"example\":\"The notice description\",\"adjustable\":\"1\",\"mandatory\":\"0\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"hr\",\"example\":\"\",\"adjustable\":\"1\",\"mandatory\":\"0\",\"translatable\":\"0\",\"description\":\"(optional) is whether to display a horizontal rule (\'true\' or \'false\'). If this attribute is \'true\', the label attribute will be ignored.\"},\"properties5\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"mandatory\":\"0\",\"translatable\":\"0\",\"description\":\"(optional) is a CSS class name for the HTML form field.\"}}', 'provides a visual separator between form fields. It is purely a visual aid and no value is stored.', '', 1, 1, '', '', '626d0cba-a908-4a4f-a447-96d781aeaa0b'),
(21, 'Using this generic form field type forces you to write SQL in an XML file and is rather limited. For more flexibility, consider using Custom FieldType.\r\n\r\nThe sql form field type provides a drop down list of entries obtained by running a query on the Joom', 'SQL', '{\"properties0\":{\"name\":\"type\",\"example\":\"sql\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be sql.\"},\"properties1\":{\"name\":\"name\",\"example\":\"title\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field. This must match the name of the query results column that contains the values that will be shown to the user in the drop-down list, unless a different name is specified in the value_field attribute.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select an article\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"query\",\"example\":\"SELECT id, concat( title, \' (\', created, \')\') AS title FROM #__content\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the SQL query which will provide the data for the drop-down list. The query must return two columns; one called \'value\' (unless overridden by the key_field attribute) which will hold the values of the list items; the other called the same as the value of the name attribute (unless overridden by the value_field attribute) containing the text to be shown in the drop-down list.\"},\"properties4\":{\"name\":\"default\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the default value. This is the value of the \'value\' field, unless overridden by the key_field attribute.\"},\"properties5\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties6\":{\"name\":\"readonly\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties7\":{\"name\":\"disabled\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties8\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties9\":{\"name\":\"key_field\",\"example\":\"id\",\"adjustable\":\"1\",\"description\":\"(optional) is the name of the column that will contain values for the parameter. If omitted then the column called \'value\' will be used, if it exists.\"},\"properties10\":{\"name\":\"value_field\",\"example\":\"title\",\"adjustable\":\"1\",\"description\":\"(optional) is the name of the column that will contain values to be shown to the user in the drop-down list. If omitted then the column with the same name as the name attribute will be used, if it exists.\"},\"properties11\":{\"name\":\"translate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) will translate the output of the value_field if set to true. It defaults to false.\"},\"properties12\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a drop down list of entries obtained by running a query on the Joomla Database. The first results column returned by the query provides the values for the drop down box.', '', 1, 3, '', '', 'd4c16f1e-fd6e-4714-90eb-f9d97edd9c32'),
(22, 'The Tag field type provides a point where you can enter tags - this is either AJAX or nested.', 'Tag', '{\"properties0\":{\"name\":\"type\",\"example\":\"tag\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be tag.\"},\"properties1\":{\"name\":\"name\",\"example\":\"tags\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"mode\",\"example\":\"ajax\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the way the tags will be loaded, the options are ( ajax or nested )\"},\"properties3\":{\"name\":\"label\",\"example\":\"Tags\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties4\":{\"name\":\"description\",\"example\":\"Assign tags to ###VIEW### items. Tag names must be unique.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is the description of the field.\"},\"properties5\":{\"name\":\"id\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the id to add to the field. Note if none is set this will be the name of the field.\"},\"properties6\":{\"name\":\"class\",\"example\":\"inputbox small\",\"adjustable\":\"1\",\"description\":\"(optional) is the class to add to the field.\"},\"properties7\":{\"name\":\"published\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) determines if non published tags should be allowed.\"},\"properties8\":{\"name\":\"language\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is language to filter the existing tags by.\"},\"properties9\":{\"name\":\"multiple\",\"example\":\"true\",\"adjustable\":\"1\",\"description\":\"(optional) is the ability to add more than 1 tag to the form field.\"},\"properties10\":{\"name\":\"custom\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) if the ajax mode is chosen setting this to [deny] will prevent users from adding in new tags.\"},\"properties11\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides an entry point for tags (either AJAX or Nested).', '', 1, 3, '', '', '48cba89e-8fcb-481e-a7d3-2e41773e452d'),
(23, 'The tel field type is an alias for a text field. Telephone numbers can be validated using the tel rule and filtered using the tel input filter.', 'Tel', '{\"properties0\":{\"name\":\"type\",\"example\":\"text\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be text.\"},\"properties1\":{\"name\":\"name\",\"example\":\"phone\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Phone\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"size\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties4\":{\"name\":\"maxlength\",\"example\":\"50\",\"adjustable\":\"1\",\"description\":\"(optional) limits the number of characters that may be entered.\"},\"properties5\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties6\":{\"name\":\"description\",\"example\":\"Enter phone number\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties7\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties8\":{\"name\":\"readonly\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties9\":{\"name\":\"disabled\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties10\":{\"name\":\"required\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties11\":{\"name\":\"filter\",\"example\":\"tel\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties12\":{\"name\":\"validated\",\"example\":\"tel\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to validated the input data.\"},\"properties13\":{\"name\":\"message\",\"example\":\"Error! Please add phone number here.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The error message that will be displayed instead of the default message.\"},\"properties14\":{\"name\":\"hint\",\"example\":\"Your Phone Number\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The placeholder to display inside the text box.\"},\"properties15\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties16\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides an input field for a telephone number.', '', 1, 6, '', '', '1c6c519c-3bc8-4914-8940-3e9591b0bce6'),
(24, 'The text form field type provides a text box for data entry. If the field has a value saved, this value is displayed when the page is first loaded. If not, the default value (if any) is selected.', 'Text', '{\"properties0\":{\"name\":\"type\",\"example\":\"text\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be text.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mytextvalue\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Enter some text\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"size\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties4\":{\"name\":\"maxlength\",\"example\":\"50\",\"adjustable\":\"1\",\"description\":\"(optional) limits the number of characters that may be entered.\"},\"properties5\":{\"name\":\"default\",\"example\":\"Some text\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties6\":{\"name\":\"description\",\"example\":\"Enter some description\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties7\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties8\":{\"name\":\"readonly\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties9\":{\"name\":\"disabled\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties10\":{\"name\":\"required\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties11\":{\"name\":\"filter\",\"example\":\"STRING\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties12\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties13\":{\"name\":\"field\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) used in validation of \\\"equals\\\" to link the field to match.\"},\"properties14\":{\"name\":\"message\",\"example\":\"Error! Please add some text here.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The error message that will be displayed instead of the default message.\"},\"properties15\":{\"name\":\"hint\",\"example\":\"Your Name Here\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The placeholder to display inside the text box.\"},\"properties16\":{\"name\":\"autocomplete\",\"example\":\"on\",\"adjustable\":\"1\",\"description\":\"(optional) The autocomplete state for the form field. If \'off\' element will not be automatically completed by browser.\"},\"properties17\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties18\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a text box for data entry.', '', 1, 10, '', '', '201327fe-3067-4316-a155-3fe2a52e05c0'),
(25, 'The textarea form field type provides a text area for entry of multi-line text. If the field has a value saved, this value is displayed when the page is first loaded. If not, the default value (if any) is selected.', 'Textarea', '{\"properties0\":{\"name\":\"type\",\"example\":\"textarea\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be textarea.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mytextarea\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Enter some text\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"rows\",\"example\":\"10\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the height of the visible text area in lines. If omitted the width is determined by the browser. The value of rows does not limit the number of lines that may be entered.\"},\"properties4\":{\"name\":\"cols\",\"example\":\"5\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the width of the visible text area in characters. If omitted the width is determined by the browser. The value of cols does not limit the number of characters that may be entered.\"},\"properties5\":{\"name\":\"default\",\"example\":\"default text\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties6\":{\"name\":\"description\",\"example\":\"Text Area\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the label.\"},\"properties7\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties8\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties9\":{\"name\":\"filter\",\"example\":\"raw\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties10\":{\"name\":\"hint\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The placeholder to display inside the textarea.\"},\"properties11\":{\"name\":\"required\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties12\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties13\":{\"name\":\"readonly\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties14\":{\"name\":\"disabled\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties15\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties16\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a text area for entry of multi-line text.', '', 1, 9, '', '', '76fe1250-6fa7-49e5-a0ee-f06d8d4c9f99'),
(26, 'The timezones form field type provides a drop down list of time zones. If the field has a value saved, this value is displayed when the page is first loaded. If not, the default value (if any) is selected.', 'Timezone', '{\"properties0\":{\"name\":\"type\",\"example\":\"timezone\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be timezone.\"},\"properties1\":{\"name\":\"name\",\"example\":\"timezone\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Timezone\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default time zone. For example, use \'-10\' for \'(UTC -10:00) Hawaii\'.\"},\"properties4\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties5\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a drop down list of time zones.', '', 1, 3, '', '', 'ed8d8cf4-cb05-49cc-95ef-4ef275f539f9'),
(27, 'This field essentially is a text field with the type of url. If a fully qualified url (that is one with a scheme and domain such as http://example.com) is entered and it uses idn (that is uses characters that are non ascii such as ê or Ψ) it will translat', 'URL', '{\"properties0\":{\"name\":\"type\",\"example\":\"url\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be url.\"},\"properties1\":{\"name\":\"name\",\"example\":\"website\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Website\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"size\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties4\":{\"name\":\"maxlength\",\"example\":\"50\",\"adjustable\":\"1\",\"description\":\"(optional) limits the number of characters that may be entered.\"},\"properties5\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties6\":{\"name\":\"description\",\"example\":\"Enter website address\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties7\":{\"name\":\"class\",\"example\":\"text_area\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties8\":{\"name\":\"readonly\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties9\":{\"name\":\"disabled\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties10\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties11\":{\"name\":\"relative\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) set to true for relative URLs\"},\"properties12\":{\"name\":\"filter\",\"example\":\"url\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties13\":{\"name\":\"validated\",\"example\":\"url\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties14\":{\"name\":\"scheme\",\"example\":\"http,https,mailto\",\"adjustable\":\"1\",\"description\":\"(optional) Validates that the value is a URL with a valid scheme (which can be restricted by the optional comma-separated field \'scheme\'), and passes a basic syntax check.\"},\"properties15\":{\"name\":\"message\",\"example\":\"Error! Please add website here.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties16\":{\"name\":\"hint\",\"example\":\"Your Website Here\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The placeholder to display inside the text box.\"},\"properties19\":{\"name\":\"autocomplete\",\"example\":\"on\",\"adjustable\":\"1\",\"description\":\"(optional) The autocomplete state for the form field. If \'off\' element will not be automatically completed by browser.\"},\"properties17\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties18\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a URL text input field.', '', 1, 10, '', '', '8df6e07e-2b16-43ed-a18d-2059fa44cdf1'),
(28, 'The user form field type provides a modal select box of users.', 'User', '{\"properties0\":{\"name\":\"type\",\"example\":\"user\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be user.\"},\"properties1\":{\"name\":\"name\",\"example\":\"user\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field. This must match the name of the query results column that contains the values that will be shown to the user in the drop-down list, unless a different name is specified in the value_field attribute.\"},\"properties2\":{\"name\":\"label\",\"example\":\"User\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field.\"},\"properties5\":{\"name\":\"size\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties6\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties7\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a modal list of users.', '', 1, 4, '', '', 'b0641980-5e78-42f6-972f-86aa607db23e'),
(29, 'The usergroup form field type provides a modal select box of user groups.', 'Usergrouplist', '{\"properties0\":{\"name\":\"type\",\"example\":\"usergrouplist\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be usergroup.\"},\"properties1\":{\"name\":\"name\",\"example\":\"usergroup\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field. This must match the name of the query results column that contains the values that will be shown to the user in the drop-down list, unless a different name is specified in the value_field attribute.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Group\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"Select a group\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field.\"},\"properties9\":{\"name\":\"layout\",\"example\":\"joomla.form.field.list-fancy-select\",\"adjustable\":\"1\",\"description\":\"(optional) (translatable) is the layout, for example joomla.form.field.list-fancy-select.\"},\"properties5\":{\"name\":\"size\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties6\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the field required true if yes.\"},\"properties10\":{\"name\":\"checksuperusergroup\",\"example\":\"1\",\"adjustable\":\"1\",\"description\":\"(optional) is boolean to omit Super User groups. Values 1 or 0.\"},\"properties7\":{\"name\":\"multiple\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) If set to multiple then allows more than one usergroup to be selected.\"},\"properties8\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a drop down list of user groups.', '', 1, 5, '', '', 'e2f31181-fbb3-4c3a-859d-72b6b0cff308'),
(30, 'The filelist form field type provides a drop down list of files from a specified directory. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.\r\n\r\nBy default, the first item on the', 'Filelist', '{\"properties0\":{\"name\":\"type\",\"example\":\"filelist\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be filelist.\"},\"properties1\":{\"name\":\"name\",\"example\":\"myfile\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select a file\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"directory\",\"example\":\"images\\/stories\",\"adjustable\":\"1\",\"description\":\"(optional) is the filesystem path to the directory containing the files to be listed. If omitted the directory given by JPATH_ROOT is assumed.\"},\"properties4\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default file name.\"},\"properties5\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties6\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a regular expression string which is used to filter the list of files selected for inclusion in the drop-down list. If omitted, all files in the directory are included. The filter argument expression is applied before the exclude argument expression. For information on constructing regular expressions see Regular expressions in parameter arguments.\"},\"properties7\":{\"name\":\"exclude\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a regular expression string which is used to exclude files from the list. The exclude argument expression is applied after the filter argument expression. For information on constructing regular expressions see Regular expressions in parameter arguments.\"},\"properties8\":{\"name\":\"stripext\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true then file name extensions will be stripped from the file names listed. Also note that the file name will be saved without the extension too.\"},\"properties9\":{\"name\":\"hide_none\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true, the \'- Do not use -\' item is omitted from the drop-down list.\"},\"properties10\":{\"name\":\"hide_default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true, the \'- Use default -\' item is omitted from the drop-down list.\"},\"properties11\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a drop down list of files from a specified directory.', '', 1, 4, '', 1, '0c80df15-52c6-4647-983b-4bb4888a2edf'),
(31, 'The folderlist form field type provides a drop down list of folders from a specfied directory. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.\r\n\r\nBy default, the first item on ', 'Folderlist', '{\"properties0\":{\"name\":\"type\",\"example\":\"folderlist\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be folderlist.\"},\"properties1\":{\"name\":\"name\",\"example\":\"myfolder\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select a folder\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"directory\",\"example\":\"images\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the filesystem path to the directory containing the folders to be listed.\"},\"properties4\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default folder name.\"},\"properties5\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties6\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a regular expression string which is used to filter the list of folders selected for inclusion in the drop-down list. If omitted, all folders in the directory are included. The filter argument expression is applied before the exclude argument expression. For information on constructing regular expressions see Regular expressions in parameter arguments.\"},\"properties7\":{\"name\":\"exclude\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a regular expression string which is used to exclude folders from the list. The exclude argument expression is applied after the filter argument expression. For information on constructing regular expressions see Regular expressions in parameter arguments.\"},\"properties8\":{\"name\":\"hide_none\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true, the \'- Do not use -\' item is omitted from the drop-down list.\"},\"properties9\":{\"name\":\"hide_default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true, the \'- Use default -\' item is omitted from the drop-down list.\"},\"properties10\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a drop down list of folders from a specified directory.', '', 1, 4, '', 2, 'd3ab2ae4-9370-4497-ae6d-dee2e0b74b7a'),
(32, 'Note: When using the file input type you should always add the attribute enctype=\"multipart/form-data\" to your form tag. Otherwise, the uploaded files will not be attached correctly.\r\n\r\nNote 2: You can put a soft limit file size by adding a hidden field with name=\"MAX_FILE_SIZE\" and value the maximum allowed bytes which is handled by php, but you must also handle it in your code with or without it.', 'File', '{\"properties0\":{\"name\":\"type\",\"example\":\"file\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be file.\"},\"properties1\":{\"name\":\"name\",\"example\":\"myfilevalue\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Enter some text\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"Choose an image from your computer with maximum 100KB\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value, but doesn\'t mean much for a file.\"},\"properties5\":{\"name\":\"size\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the file box in characters.\"},\"properties6\":{\"name\":\"accept\",\"example\":\"image\\/*\",\"adjustable\":\"1\",\"description\":\"(optional) Tells the browser what MIME types your form will allow to be uploaded.\"},\"properties7\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field.\"},\"properties8\":{\"name\":\"labelclass\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) adds a CSS class for form field\'s label; for Joomla 2.5.4+\"},\"properties9\":{\"name\":\"disabled\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute\"},\"properties10\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"},\"properties11\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) For Joomla form validating it to be filled in\"},\"properties12\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Whether to Joomla validate the field according to rules\"},\"properties13\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides an input field for files', '', 1, 9, '', 3, '6da71c1e-119c-4e0d-a309-f3e52ecfa1d1'),
(33, 'The menuitem form field type provides a drop down grouped list of the available menu items from your Joomla site.', 'menuitem', '{\"properties0\":{\"name\":\"type\",\"example\":\"menuitem\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be menuitem.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mymenuitem\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select a menu item\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default menu item. Note that this is the ItemID number of the menu item.\"},\"properties4\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties5\":{\"name\":\"published\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) determines whether all menu items are listed or only published menu items. If state is \'0\' then all menu items will be listed. If state is \'1\' then only published menu items will be listed.\"},\"properties6\":{\"name\":\"filter\",\"example\":\"int\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties7\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'provides a drop down list of the available menu items from your Joomla site.', '', 1, 5, '', 4, 'f183b0e2-017f-48bd-8dba-d332ce1b8d9e'),
(34, 'Remember all views already have [accesslevel] added by default, only add this if you need more custom access selection! Provides a dropdown list of accesslevel options with the current option selected.', 'Accesslevel', '{\"properties0\":{\"name\":\"type\",\"example\":\"accesslevel\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be accesslevel\"},\"properties1\":{\"name\":\"name\",\"example\":\"accesstwo\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field. This must match the name of the query results column that contains the values that will be shown to the user in the drop-down list, unless a different name is specified in the value_field attribute. \"},\"properties2\":{\"name\":\"label\",\"example\":\"Access Two\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"Select an access level to this concept.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"class\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field.\"},\"properties5\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the field required true if yes.\"},\"properties6\":{\"name\":\"multiple\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) If set to multiple then allows more than one usergroup to be selected.\"},\"properties7\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'List of accesslevels', '', 1, 4, '', 5, '913ed2ce-836c-48e8-97af-e482441f47df'),
(35, 'Provides a form with rows of fields that you specify. As many options can be added as desired. Note this form field has a jQuery based javascript file as a dependency.', 'Subform', '{\"properties0\":{\"name\":\"type\",\"example\":\"subform\",\"description\":\"(mandatory) must be subform.\"},\"properties1\":{\"name\":\"name\",\"example\":\"options\",\"adjustable\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter\"},\"properties2\":{\"name\":\"label\",\"example\":\"The Option List\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"layout\",\"example\":\"joomla.form.field.subform.repeatable-table\",\"adjustable\":\"1\",\"description\":\"(mandatory) The layout for the repeatable table.\"},\"properties4\":{\"name\":\"component\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) To change the component where it should search for layout\"},\"properties5\":{\"name\":\"client\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Function to initialise the application clientFrontend: site or 0Backend: admin or 1\"},\"properties6\":{\"name\":\"multiple\",\"example\":\"true\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) The rows to be multiple.\"},\"properties7\":{\"name\":\"buttons\",\"example\":\"add,remove,move\",\"adjustable\":\"1\",\"description\":\"(optional) Which buttons to show if multiple mode is true.Options: add,remove,move\"},\"properties8\":{\"name\":\"fields\",\"example\":\"1,2,3\",\"adjustable\":\"1\",\"description\":\"(mandatory) The fields to add to the modal. All fields must first be created in component builder as a field before you can add them here, since you must use the id of the field. Separate the field ids with commas. Do not add custom fields that are not also used in this component.\"},\"properties9\":{\"name\":\"formsource\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) you can add a path to a xml file containing the fields.\"},\"properties10\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) description text for the form field. Displays at the top of the modal with the name as well as in the usual position in the form\"},\"properties11\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The default value for the form field if the field is left empty. Note this has to be a json string compatible with the contents of the form field.\"},\"properties12\":{\"name\":\"icon\",\"example\":\"list\",\"adjustable\":\"1\",\"description\":\"(optional) The icon to show on the select button (is prefixed with \\\"icon-\\\").\"},\"properties13\":{\"name\":\"max\",\"example\":\"50\",\"adjustable\":\"1\",\"description\":\"(optional) The maximum number of rows of fields allowed (by default 999 to be effectively infinite)\"},\"properties14\":{\"name\":\"min\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The minimum number of rows of fields required\"},\"properties15\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Use only if you would like to save raw data, since the default is best.\"},\"properties16\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Allows form fields which can have as many options as the user desires.', '', 1, 14, '', 6, '7139f2c8-a70a-46a6-bbe3-4eefe54ca515'),
(36, 'Provides an input field for an email address.', 'Email', '{\"properties0\":{\"name\":\"type\",\"example\":\"email\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be email.\"},\"properties1\":{\"name\":\"name\",\"example\":\"email\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Email Address\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"size\",\"example\":\"10\",\"adjustable\":\"1\",\"description\":\"(optional) is the width of the text box in characters. If omitted the width is determined by the browser. The value of size does not limit the number of characters that may be entered.\"},\"properties4\":{\"name\":\"maxlength\",\"example\":\"50\",\"adjustable\":\"1\",\"description\":\"(optional) limits the number of characters that may be entered.\"},\"properties5\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties6\":{\"name\":\"description\",\"example\":\"Enter some description\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties7\":{\"name\":\"class\",\"example\":\"inputbox\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'text_area\'.\"},\"properties8\":{\"name\":\"readonly\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value\"},\"properties9\":{\"name\":\"disabled\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field cannot be changed and will automatically inherit the default value - it will also not submit\"},\"properties10\":{\"name\":\"required\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties11\":{\"name\":\"filter\",\"example\":\"STRING\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties12\":{\"name\":\"validate\",\"example\":\"email\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties13\":{\"name\":\"unique\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) Used in validation, to check if we should test for uniqueness, to insure that this email does not already belong to another user. Check line 99 in \\/libraries\\/src\\/Form\\/Rule\\/EmailRule.php\"},\"properties14\":{\"name\":\"field\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) used in validation of \\\"equals\\\" to link the field to match.\"},\"properties15\":{\"name\":\"message\",\"example\":\"Error! Please add some text here.\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The error message that will be displayed instead of the default message.\"},\"properties16\":{\"name\":\"hint\",\"example\":\"your@email.com\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) The placeholder to display inside the text box.\"},\"properties17\":{\"name\":\"autocomplete\",\"example\":\"on\",\"adjustable\":\"1\",\"description\":\"(optional) The autocomplete state for the form field. If \'off\' element will not be automatically completed by browser.\"},\"properties18\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties19\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'Email form field type', '', 1, 7, '', 7, '35948af5-9e79-4454-8dfa-682ee4fdf650'),
(37, 'Provides a dropdown list of plugin options from the folder.', 'Plugins', '{\"properties0\":{\"name\":\"type\",\"example\":\"plugins\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be editors.\"},\"properties1\":{\"name\":\"name\",\"example\":\"editor\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select an editor\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) (not translatable) is the default value.\"},\"properties4\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the label.\"},\"properties5\":{\"name\":\"multiple\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) is whether multiple items can be selected at the same time (true or false).\"},\"properties6\":{\"name\":\"folder\",\"example\":\"editors\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) editors or captcha.\"},\"properties7\":{\"name\":\"filter\",\"example\":\"cmd\",\"adjustable\":\"1\",\"description\":\"(optional) allow the system to save certain html tags or raw data.\"},\"properties8\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a dropdown list of plugin options from the folder.', '', 1, 8, '', 8, '37fa4e1d-b7ca-4a8f-aa4b-d8085c135233'),
(38, 'Provides the use of a captcha plugin.', 'Captcha', '{\"properties0\":{\"name\":\"type\",\"example\":\"captcha\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be captcha.\"},\"properties3\":{\"name\":\"name\",\"example\":\"captcha\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"validate\",\"example\":\"captcha\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be captcha.\"},\"properties1\":{\"name\":\"label\",\"example\":\"Captcha\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties4\":{\"name\":\"description\",\"example\":\"We do not like spam, please show us you are human\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties5\":{\"name\":\"namespace\",\"example\":\"componentbuilder\",\"description\":\"(optional) the component name seems to work\"}}', 'Captcha robot check.', '', 1, 2, '', 9, '206fdad4-14d0-45f1-9c84-3d09abf48a39'),
(39, 'The list form field type provides a drop down list or a list box of custom-defined entries. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.', 'Groupedlist', '{\"properties0\":{\"name\":\"type\",\"example\":\"groupedlist\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be groupedlist.\"},\"properties1\":{\"name\":\"name\",\"example\":\"mygrouplist\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Select an option\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties5\":{\"name\":\"class\",\"example\":\"list_class\",\"adjustable\":\"1\",\"description\":\"(optional) is a CSS class name for the HTML form field. If omitted this will default to \'inputbox\'.\"},\"properties6\":{\"name\":\"multiple\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) is whether multiple items can be selected at the same time (true or false).\"},\"properties7\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) filter options\"},\"properties8\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties9\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties10\":{\"name\":\"option\",\"example\":\"Group Name@@1,1|Option 1|1,2|Option 2|1,Group Name 2@@2,3|Option 3|2\",\"adjustable\":\"1\",\"description\":\"(mandatory) set the options of this radio. Separate options with commas and use the pipe symbol to separate value from text.\"},\"properties11\":{\"name\":\"useglobal\",\"example\":\"false\",\"adjustable\":\"1\",\"description\":\"(optional) if set to true, it will show the value that is set in the global configuration if found in the database.\"},\"properties12\":{\"name\":\"default\",\"example\":\"0\",\"adjustable\":\"1\",\"description\":\"(optional) is the default list item value.\"},\"properties13\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties14\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'provides a drop down list of custom-defined entries.', '', 1, 2, '', 10, '088d47c0-b058-4894-b92e-dcf1b9d5a722'),
(40, 'The modulelayout form field type provides a drop down list of all available layouts for a module, grouped by core and template. If the parameter has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.', 'Modulelayout', '{\"properties0\":{\"name\":\"type\",\"example\":\"modulelayout\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be modulelayout.\"},\"properties1\":{\"name\":\"name\",\"example\":\"layout\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Layout\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"Module layout\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties4\":{\"name\":\"module\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a specific module name (e.g. mod_articles_category).\"},\"properties5\":{\"name\":\"client_id\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional). If 0 (site): Forces searching for layouts only in directories \\/modules\\/[MODULENAME]\\/tmpl\\/ and all \\/templates\\/[TEMPLATENAME]\\/html\\/[MODULENAME]\\/. If 1 (administrator): Forces searching for layouts only in directories \\/administrator\\/modules\\/[MODULENAME]\\/tmpl\\/ and all \\/administrator\\/templates\\/[TEMPLATENAME]\\/html\\/[MODULENAME]\\/.\\r\\n\"},\"properties6\":{\"name\":\"template\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a template name (e.g. protostar or isis). If set forces searching for module template overrides only in this template.\"}}', 'modulelayout', '', 1, 1, '', 11, '7520c8f4-543d-4c7a-8e4f-e2da71c3b1cd'),
(43, 'Provides a combobox field, which offers a list like the List Form Field Type, but additionally allows free text.', 'Combo', '{\"properties0\":{\"name\":\"type\",\"example\":\"combo\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be combo.\"},\"properties1\":{\"name\":\"name\",\"example\":\"type\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the parameter.\"},\"properties2\":{\"name\":\"label\",\"example\":\"Type\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties3\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) tooltip for the form field.\"},\"properties4\":{\"name\":\"message\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as error on validation.\"},\"properties5\":{\"name\":\"class\",\"example\":\"combobox\",\"adjustable\":\"1\",\"description\":\"(optional) specify your own classes for additonal markup, defaults to \\\"combobox\\\".\"},\"properties6\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) filter options\"},\"properties7\":{\"name\":\"required\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The field must be filled before submitting the form.\"},\"properties8\":{\"name\":\"validate\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) The validation method for the form field. This value will determine which method is used to validate the value for a field.\"},\"properties9\":{\"name\":\"option\",\"example\":\"0|Option 1,1|Option 2,2|Option 1\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) set the options of this radio. Separate options with commas and use the pipe symbol to separate value from text.\"},\"properties10\":{\"name\":\"default\",\"example\":\"0\",\"adjustable\":\"1\",\"description\":\"(optional) is the default list item value.\"},\"properties11\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) Allows you to hide the field based on the value(s) of another field; for Joomla 3.2.4+ https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"},\"properties12\":{\"name\":\"onchange\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) HTML equivalent attribute (javascript use)\"}}', 'Provides a combobox list field, allows free text.', '', 1, 2, '', 13, '2c8b128f-7da2-4f55-b1d7-3613f902f590'),
(44, 'The imagelist form field type provides a drop down list of image files in a specified directory. Only files with .png, .gif, .jpg, .bmp, .ico extensions are listed. If the field has a saved value this is selected when the page is first loaded. If not, the default value (if any) is selected.\r\n\r\nBy default, the first item on the list is \'- Do not use -\' (which is translatable) and is given the value \'-1\' and this is followed by \'- Use default -\' (also translatable) given the value \'0\'.', 'Imagelist', '{\"properties0\":{\"name\":\"type\",\"example\":\"imagelist\",\"mandatory\":\"1\",\"description\":\"(mandatory) must be imagelist.\"},\"properties6\":{\"name\":\"name\",\"example\":\"myimagelist\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"description\":\"(mandatory) is the unique name of the field.\"},\"properties5\":{\"name\":\"label\",\"example\":\"Select an image\",\"adjustable\":\"1\",\"mandatory\":\"1\",\"translatable\":\"1\",\"description\":\"(mandatory) (translatable) is the descriptive title of the field.\"},\"properties4\":{\"name\":\"directory\",\"example\":\"images\\/stories\",\"adjustable\":\"1\",\"description\":\"(optional) is the filesystem path to the directory containing the image files to be listed. If omitted the directory given by JPATH_ROOT is assumed.\"},\"properties3\":{\"name\":\"default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is the default image file name.\"},\"properties2\":{\"name\":\"description\",\"example\":\"\",\"adjustable\":\"1\",\"translatable\":\"1\",\"description\":\"(optional) (translatable) is text that will be shown as a tooltip when the user moves the mouse over the drop-down box.\"},\"properties1\":{\"name\":\"filter\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a regular expression string which is used to filter the list of image files selected for inclusion in the drop-down list. If omitted, all image files in the directory are included. The filter argument expression is applied before the exclude argument expression. For information on constructing regular expressions see Regular expressions in parameter arguments.\"},\"properties9\":{\"name\":\"exclude\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a regular expression string which is used to exclude image files from the list. The exclude argument expression is applied after the filter argument expression. For information on constructing regular expressions see Regular expressions in parameter arguments.\"},\"properties8\":{\"name\":\"stripext\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true then file name extensions will be stripped from the image file names listed. Also note that the file name will be saved without the extension too.\"},\"properties7\":{\"name\":\"hide_none\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true, the \'- Do not use -\' item is omitted from the drop-down list.\"},\"properties10\":{\"name\":\"hide_default\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) is a Boolean argument. If true, the \'- Use default -\' item is omitted from the drop-down list.\"},\"properties11\":{\"name\":\"showon\",\"example\":\"\",\"adjustable\":\"1\",\"description\":\"(optional) show this field on the bases of the value in another field. https:\\/\\/joomla.stackexchange.com\\/a\\/17682\\/2166\"}}', 'Provides a drop down list of image files from a specified directory.', '', 1, 1, '', 14, '72680e92-2859-49c6-ad92-c2329c52f9f8');
--
-- Dumping data for table `#__componentbuilder_language`
--
INSERT INTO `#__componentbuilder_language` (`id`, `langtag`, `name`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`) VALUES
(1, 'af-ZA', 'Afrikaans', '', 1, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(2, 'sq-AL', 'Albanian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(3, 'ar-AA', 'Arabic Unitag', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(4, 'hy-AM', 'Armenian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(5, 'id-ID', 'Indonesian, Bahasa Indonesia', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(6, 'eu-ES', 'Basque', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(7, 'be-BY', 'Belarusian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(8, 'bn-BD', 'Bengali, Bangladesh', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(9, 'bs-BA', 'Bosnian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(10, 'bg-BG', 'Bulgarian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(11, 'ca-ES', 'Catalan', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(12, 'zh-CN', 'Chinese, Simplified', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(13, 'zh-TW', 'Chinese, Traditional', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(14, 'hr-HR', 'Croatian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(15, 'cs-CZ', 'Czech', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(16, 'da-DK', 'Danish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(17, 'prs-AF', 'Dari Persian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(18, 'nl-NL', 'Dutch', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(19, 'dz-BT', 'Dzongkha', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(20, 'en-AU', 'English, Australia', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(21, 'en-CA', 'English, Canada', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(22, 'en-GB', 'English GB', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(23, 'en-NZ', 'English, New Zealand', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(24, 'en-US', 'English, USA', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(25, 'eo-XX', 'Esperanto', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(26, 'et-EE', 'Estonian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(27, 'fi-FI', 'Finnish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(28, 'nl-BE', 'Flemish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(29, 'fr-FR', 'French', '', 1, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(30, 'fr-CA', 'French, Canada', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(31, 'gl-ES', 'Galician', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(32, 'ka-GE', 'Georgian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(33, 'de-AT', 'German, Austria', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(34, 'de-CH', 'German, Switzerland', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(35, 'de-DE', 'German', '', 1, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(36, 'de-LI', 'German, Liechtenstein', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(37, 'de-LU', 'German, Luxembourg', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(38, 'el-GR', 'Greek', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(39, 'he-IL', 'Hebrew', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(40, 'hi-IN', 'Hindi, India', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(41, 'hu-HU', 'Hungarian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(42, 'ga-IE', 'Irish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(43, 'it-IT', 'Italian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(44, 'ja-JP', 'Japanese', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(45, 'km-KH', 'Khmer', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(46, 'ko-KR', 'Korean', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(47, 'lv-LV', 'Latvian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(48, 'mk-MK', 'Macedonian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(49, 'ms-MY', 'Malay', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(50, 'srp-ME', 'Montenegrin', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(51, 'nb-NO', 'Norwegian Bokmål', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(52, 'nn-NO', 'Norwegian Nynorsk', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(53, 'fa-IR', 'Persian Farsi', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(54, 'pl-PL', 'Polish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(55, 'pt-PT', 'Portuguese, Portugal', '', 1, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(56, 'pt-BR', 'Portuguese, Brazil', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(57, 'ro-RO', 'Romanian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(58, 'ru-RU', 'Russian', '', 1, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 6, '', 1),
(59, 'sr-RS', 'Serbian, Cyrillic', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(60, 'sr-YU', 'Serbian, Latin', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(61, 'si-LK', 'Sinhala', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(62, 'sk-SK', 'Slovak', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(63, 'sl-SI', 'Slovenian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(64, 'es-ES', 'Spanish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(65, 'es-CO', 'Spanish, Colombia', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(66, 'sw-KE', 'Swahili', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(67, 'sv-SE', 'Swedish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(68, 'sy-IQ', 'Syriac, East', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(69, 'ta-IN', 'Tamil, India', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(70, 'th-TH', 'Thai', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(71, 'tr-TR', 'Turkish', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(72, 'tk-TM', 'Turkmen', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(73, 'uk-UA', 'Ukrainian', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(74, 'ug-CN', 'Uyghur', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(75, 'vi-VN', 'Vietnamese', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(76, 'cy-GB', 'Welsh', '', 2, '2018-04-19 13:43:44', '2023-12-26 07:40:20', 5, '', 1),
(77, 'lt-LT', 'Lithuanian', '', 2, '2018-09-14 10:39:11', '2023-12-26 07:40:20', 4, '', 2),
(78, 'kk-KZ', 'Kazakh', '', 2, '2020-03-19 13:41:00', '2023-12-26 07:40:20', 3, '', 3);
--
-- Dumping data for table `#__componentbuilder_help_document`
--
INSERT INTO `#__componentbuilder_help_document` (`id`, `admin_view`, `alias`, `article`, `content`, `groups`, `location`, `site_view`, `target`, `title`, `type`, `url`, `params`, `published`, `version`, `hits`, `ordering`) VALUES
(1, 'components', '2016-03-04-02-31-55', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p>\r\n<h3>Create</h3>\r\n<p>You can create a component by clicking on the\r\n <button>New</button>button in the toolbar, this will open a window where you can add all the needed values to create a new component.</p>\r\n<h3>Edit</h3>\r\n<p>You can edit components in two ways.</p>\r\n<ul>\r\n <li>You can click on the box next to the component name and then click on the\r\n <button>Edit</button>button in the toolbar; this will open the component and if you have permission it will give you access to edit the values of a component.</li>\r\n <li>You can simply click on the component name; this will open the component and if you have permission it will give you access to edit the values of a component.</li>\r\n</ul>\r\n<h3>Edit State</h3>\r\n<p>You can publish, unpublish, archive, and trash any component by clicking in the boxes next the component names and then click on the corresponding button of the task you want to perform. This will change the state of all the components youve selected.</p>\r\n<p>If you have trashed a component it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed components. To completely remove these components from your system do the following: first select all the components you want to permanently delete by clicking in the boxes next to the component names and then click on the\r\n <button>Empty trash</button>button in the toolbar. This will permanently delete the components from the database. On the other hand if you would like to change the status of the component to publish, unpublish or archive, click in the boxes next to the component names and then click on the corresponding button of the task you want to perform. This will change the state of all the components youve selected.</p>\r\n<h3>Check-in</h3>\r\n<p>When another user on your Joomla website opens a component the system checks the component out to that user. A little lock will show up next to the component name. When you hover over the lock it will show to you who checked it out and when.</p>\r\n<p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p>\r\n<p>If this feature has not yet checked-in any of the components that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the component names and then click on the\r\n <button>Check-in</button>button in the toolbar, or simply click on the little lock. This will then check in the component, which will mean that it removes the component from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p>\r\n<h3>Batch Feature</h3>\r\n<p>You can use the Batch feature to update or copy many components at once by clicking in the boxes next the component names and then click on the\r\n <button>Batch</button>button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the\r\n <button>Process</button>button. Once completed this batch feature will have either copied or updated all the components according to the task you selected.</p>\r\n<h3>Export & Import</h3>\r\n<p>The export and import feature is some of the most exciting features to the list view of components. With them you can update and create many components at once.</p>\r\n<h3>Export</h3>\r\n<p>The export option only exports the components selected. So to export all components you must change the limited number of components that are being loaded to \"All\". The box that limits the number of components being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the component records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the components. Next click on the\r\n <button>Export Date</button>button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p>\r\n<h3>Import</h3>\r\n<p>The import option can be used to create components or update existing components. The way to update existing components is to use the same id as the component you want to update. Best way to do this is to first export the components you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new components via an import, simple leave the id field empty.</p>\r\n<p>So once you have your excel document ready you will again open the list view of components and click on the\r\n <button>Import Data</button>button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p>\r\n<p>Once you have the file selected you can click on the\r\n <button>Upload File</button> or\r\n <button>Get File</button>button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p>\r\n<p>When the field to column relationship has correctly been mapped you can click on the\r\n <button>continue</button>button at the bottom of the page. This should return you to the list view of components with a success message.</p>\r\n<h3>Debug</h3>\r\n<p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Components', 2, '', '', 1, 12, '', 1),
(2, 'admin_views', 'welcome-to-the-list-view-of-admin-views', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create an admin view by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new admin view.</p> <h3>Edit</h3> <p>You can edit admin views in two ways.</p> <ul> <li>You can click on the box next to the admin view name and then click on the <button>Edit</button> button in the toolbar; this will open the admin view and if you have permission it will give you access to edit the values of an admin view.</li> <li>You can simply click on the admin view name; this will open the admin view and if you have permission it will give you access to edit the values of an admin view.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any admin view by clicking in the boxes next the admin view names and then click on the corresponding button of the task you want to perform. This will change the state of all the admin views youve selected.</p> <p>If you have trashed an admin view it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed admin views. To completely remove these admin views from your system do the following: first select all the admin views you want to permanently delete by clicking in the boxes next to the admin view names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the admin views from the database. On the other hand if you would like to change the status of the admin view to publish, unpublish or archive, click in the boxes next to the admin view names and then click on the corresponding button of the task you want to perform. This will change the state of all the admin views youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens an admin view the system checks the admin view out to that user. A little lock will show up next to the admin view name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the admin views that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the admin view names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the admin view, which will mean that it removes the admin view from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many admin views at once by clicking in the boxes next the admin view names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the admin views according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of admin views. With them you can update and create many admin views at once.</p> <h3>Export</h3> <p>The export option only exports the admin views selected. So to export all admin views you must change the limited number of admin views that are being loaded to \"All\". The box that limits the number of admin views being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the admin view records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the admin views. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create admin views or update existing admin views. The way to update existing admin views is to use the same id as the admin view you want to update. Best way to do this is to first export the admin views you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new admin views via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of admin views and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of admin views with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Admin Views', 2, '', '', 1, 5, '', 2),
(3, 'custom_admin_views', 'welcome-to-the-list-view-of-custom-admin-views', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a custom admin view by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new custom admin view.</p> <h3>Edit</h3> <p>You can edit custom admin views in two ways.</p> <ul> <li>You can click on the box next to the custom admin view name and then click on the <button>Edit</button> button in the toolbar; this will open the custom admin view and if you have permission it will give you access to edit the values of a custom admin view.</li> <li>You can simply click on the custom admin view name; this will open the custom admin view and if you have permission it will give you access to edit the values of a custom admin view.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any custom admin view by clicking in the boxes next the custom admin view names and then click on the corresponding button of the task you want to perform. This will change the state of all the custom admin views youve selected.</p> <p>If you have trashed a custom admin view it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed custom admin views. To completely remove these custom admin views from your system do the following: first select all the custom admin views you want to permanently delete by clicking in the boxes next to the custom admin view names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the custom admin views from the database. On the other hand if you would like to change the status of the custom admin view to publish, unpublish or archive, click in the boxes next to the custom admin view names and then click on the corresponding button of the task you want to perform. This will change the state of all the custom admin views youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a custom admin view the system checks the custom admin view out to that user. A little lock will show up next to the custom admin view name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the custom admin views that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the custom admin view names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the custom admin view, which will mean that it removes the custom admin view from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many custom admin views at once by clicking in the boxes next the custom admin view names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the custom admin views according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of custom admin views. With them you can update and create many custom admin views at once.</p> <h3>Export</h3> <p>The export option only exports the custom admin views selected. So to export all custom admin views you must change the limited number of custom admin views that are being loaded to \"All\". The box that limits the number of custom admin views being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the custom admin view records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the custom admin views. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create custom admin views or update existing custom admin views. The way to update existing custom admin views is to use the same id as the custom admin view you want to update. Best way to do this is to first export the custom admin views you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new custom admin views via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of custom admin views and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of custom admin views with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Custom Admin Views', 2, '', '', 1, 4, '', 3),
(4, 'site_views', 'welcome-to-the-list-view-of-site-views', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a site view by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new site view.</p> <h3>Edit</h3> <p>You can edit site views in two ways.</p> <ul> <li>You can click on the box next to the site view name and then click on the <button>Edit</button> button in the toolbar; this will open the site view and if you have permission it will give you access to edit the values of a site view.</li> <li>You can simply click on the site view name; this will open the site view and if you have permission it will give you access to edit the values of a site view.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any site view by clicking in the boxes next the site view names and then click on the corresponding button of the task you want to perform. This will change the state of all the site views youve selected.</p> <p>If you have trashed a site view it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed site views. To completely remove these site views from your system do the following: first select all the site views you want to permanently delete by clicking in the boxes next to the site view names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the site views from the database. On the other hand if you would like to change the status of the site view to publish, unpublish or archive, click in the boxes next to the site view names and then click on the corresponding button of the task you want to perform. This will change the state of all the site views youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a site view the system checks the site view out to that user. A little lock will show up next to the site view name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the site views that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the site view names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the site view, which will mean that it removes the site view from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many site views at once by clicking in the boxes next the site view names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the site views according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of site views. With them you can update and create many site views at once.</p> <h3>Export</h3> <p>The export option only exports the site views selected. So to export all site views you must change the limited number of site views that are being loaded to \"All\". The box that limits the number of site views being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the site view records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the site views. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create site views or update existing site views. The way to update existing site views is to use the same id as the site view you want to update. Best way to do this is to first export the site views you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new site views via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of site views and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of site views with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Site Views', 2, '', '', 1, 3, '', 4),
(5, 'templates', 'welcome-to-the-list-view-of-templates', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a template by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new template.</p> <h3>Edit</h3> <p>You can edit templates in two ways.</p> <ul> <li>You can click on the box next to the template name and then click on the <button>Edit</button> button in the toolbar; this will open the template and if you have permission it will give you access to edit the values of a template.</li> <li>You can simply click on the template name; this will open the template and if you have permission it will give you access to edit the values of a template.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any template by clicking in the boxes next the template names and then click on the corresponding button of the task you want to perform. This will change the state of all the templates youve selected.</p> <p>If you have trashed a template it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed templates. To completely remove these templates from your system do the following: first select all the templates you want to permanently delete by clicking in the boxes next to the template names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the templates from the database. On the other hand if you would like to change the status of the template to publish, unpublish or archive, click in the boxes next to the template names and then click on the corresponding button of the task you want to perform. This will change the state of all the templates youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a template the system checks the template out to that user. A little lock will show up next to the template name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the templates that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the template names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the template, which will mean that it removes the template from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many templates at once by clicking in the boxes next the template names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the templates according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of templates. With them you can update and create many templates at once.</p> <h3>Export</h3> <p>The export option only exports the templates selected. So to export all templates you must change the limited number of templates that are being loaded to \"All\". The box that limits the number of templates being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the template records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the templates. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create templates or update existing templates. The way to update existing templates is to use the same id as the template you want to update. Best way to do this is to first export the templates you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new templates via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of templates and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of templates with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Templates', 2, '', '', 1, 4, '', 5),
(6, 'layouts', 'welcome-to-the-list-view-of-layouts', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a layout by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new layout.</p> <h3>Edit</h3> <p>You can edit layouts in two ways.</p> <ul> <li>You can click on the box next to the layout name and then click on the <button>Edit</button> button in the toolbar; this will open the layout and if you have permission it will give you access to edit the values of a layout.</li> <li>You can simply click on the layout name; this will open the layout and if you have permission it will give you access to edit the values of a layout.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any layout by clicking in the boxes next the layout names and then click on the corresponding button of the task you want to perform. This will change the state of all the layouts youve selected.</p> <p>If you have trashed a layout it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed layouts. To completely remove these layouts from your system do the following: first select all the layouts you want to permanently delete by clicking in the boxes next to the layout names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the layouts from the database. On the other hand if you would like to change the status of the layout to publish, unpublish or archive, click in the boxes next to the layout names and then click on the corresponding button of the task you want to perform. This will change the state of all the layouts youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a layout the system checks the layout out to that user. A little lock will show up next to the layout name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the layouts that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the layout names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the layout, which will mean that it removes the layout from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many layouts at once by clicking in the boxes next the layout names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the layouts according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of layouts. With them you can update and create many layouts at once.</p> <h3>Export</h3> <p>The export option only exports the layouts selected. So to export all layouts you must change the limited number of layouts that are being loaded to \"All\". The box that limits the number of layouts being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the layout records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the layouts. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create layouts or update existing layouts. The way to update existing layouts is to use the same id as the layout you want to update. Best way to do this is to first export the layouts you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new layouts via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of layouts and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of layouts with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Layouts', 2, '', '', 1, 3, '', 6),
(7, 'dynamic_gets', 'welcome-to-the-list-view-of-dynamic-gets', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a dynamic get by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new dynamic get.</p> <h3>Edit</h3> <p>You can edit dynamic gets in two ways.</p> <ul> <li>You can click on the box next to the dynamic get name and then click on the <button>Edit</button> button in the toolbar; this will open the dynamic get and if you have permission it will give you access to edit the values of a dynamic get.</li> <li>You can simply click on the dynamic get name; this will open the dynamic get and if you have permission it will give you access to edit the values of a dynamic get.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any dynamic get by clicking in the boxes next the dynamic get names and then click on the corresponding button of the task you want to perform. This will change the state of all the dynamic gets youve selected.</p> <p>If you have trashed a dynamic get it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed dynamic gets. To completely remove these dynamic gets from your system do the following: first select all the dynamic gets you want to permanently delete by clicking in the boxes next to the dynamic get names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the dynamic gets from the database. On the other hand if you would like to change the status of the dynamic get to publish, unpublish or archive, click in the boxes next to the dynamic get names and then click on the corresponding button of the task you want to perform. This will change the state of all the dynamic gets youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a dynamic get the system checks the dynamic get out to that user. A little lock will show up next to the dynamic get name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the dynamic gets that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the dynamic get names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the dynamic get, which will mean that it removes the dynamic get from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many dynamic gets at once by clicking in the boxes next the dynamic get names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the dynamic gets according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of dynamic gets. With them you can update and create many dynamic gets at once.</p> <h3>Export</h3> <p>The export option only exports the dynamic gets selected. So to export all dynamic gets you must change the limited number of dynamic gets that are being loaded to \"All\". The box that limits the number of dynamic gets being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the dynamic get records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the dynamic gets. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create dynamic gets or update existing dynamic gets. The way to update existing dynamic gets is to use the same id as the dynamic get you want to update. Best way to do this is to first export the dynamic gets you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new dynamic gets via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of dynamic gets and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of dynamic gets with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Dynamic Gets', 2, '', '', 1, 3, '', 7),
(8, 'snippets', 'welcome-to-the-list-view-of-snippets', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a snippet by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new snippet.</p> <h3>Edit</h3> <p>You can edit snippets in two ways.</p> <ul> <li>You can click on the box next to the snippet name and then click on the <button>Edit</button> button in the toolbar; this will open the snippet and if you have permission it will give you access to edit the values of a snippet.</li> <li>You can simply click on the snippet name; this will open the snippet and if you have permission it will give you access to edit the values of a snippet.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any snippet by clicking in the boxes next the snippet names and then click on the corresponding button of the task you want to perform. This will change the state of all the snippets youve selected.</p> <p>If you have trashed a snippet it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed snippets. To completely remove these snippets from your system do the following: first select all the snippets you want to permanently delete by clicking in the boxes next to the snippet names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the snippets from the database. On the other hand if you would like to change the status of the snippet to publish, unpublish or archive, click in the boxes next to the snippet names and then click on the corresponding button of the task you want to perform. This will change the state of all the snippets youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a snippet the system checks the snippet out to that user. A little lock will show up next to the snippet name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the snippets that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the snippet names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the snippet, which will mean that it removes the snippet from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many snippets at once by clicking in the boxes next the snippet names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the snippets according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of snippets. With them you can update and create many snippets at once.</p> <h3>Export</h3> <p>The export option only exports the snippets selected. So to export all snippets you must change the limited number of snippets that are being loaded to \"All\". The box that limits the number of snippets being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the snippet records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the snippets. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create snippets or update existing snippets. The way to update existing snippets is to use the same id as the snippet you want to update. Best way to do this is to first export the snippets you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new snippets via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of snippets and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of snippets with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Snippets', 2, '', '', 1, 3, '', 8),
(9, 'fields', 'welcome-to-the-list-view-of-fields', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a field by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new field.</p> <h3>Edit</h3> <p>You can edit fields in two ways.</p> <ul> <li>You can click on the box next to the field name and then click on the <button>Edit</button> button in the toolbar; this will open the field and if you have permission it will give you access to edit the values of a field.</li> <li>You can simply click on the field name; this will open the field and if you have permission it will give you access to edit the values of a field.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any field by clicking in the boxes next the field names and then click on the corresponding button of the task you want to perform. This will change the state of all the fields youve selected.</p> <p>If you have trashed a field it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed fields. To completely remove these fields from your system do the following: first select all the fields you want to permanently delete by clicking in the boxes next to the field names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the fields from the database. On the other hand if you would like to change the status of the field to publish, unpublish or archive, click in the boxes next to the field names and then click on the corresponding button of the task you want to perform. This will change the state of all the fields youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a field the system checks the field out to that user. A little lock will show up next to the field name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the fields that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the field names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the field, which will mean that it removes the field from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many fields at once by clicking in the boxes next the field names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the fields according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of fields. With them you can update and create many fields at once.</p> <h3>Export</h3> <p>The export option only exports the fields selected. So to export all fields you must change the limited number of fields that are being loaded to \"All\". The box that limits the number of fields being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the field records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the fields. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create fields or update existing fields. The way to update existing fields is to use the same id as the field you want to update. Best way to do this is to first export the fields you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new fields via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of fields and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of fields with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Fields', 2, '', '', 1, 3, '', 9),
(10, 'fieldtypes', 'welcome-to-the-list-view-of-fieldtypes', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a fieldtype by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new fieldtype.</p> <h3>Edit</h3> <p>You can edit fieldtypes in two ways.</p> <ul> <li>You can click on the box next to the fieldtype name and then click on the <button>Edit</button> button in the toolbar; this will open the fieldtype and if you have permission it will give you access to edit the values of a fieldtype.</li> <li>You can simply click on the fieldtype name; this will open the fieldtype and if you have permission it will give you access to edit the values of a fieldtype.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any fieldtype by clicking in the boxes next the fieldtype names and then click on the corresponding button of the task you want to perform. This will change the state of all the fieldtypes youve selected.</p> <p>If you have trashed a fieldtype it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed fieldtypes. To completely remove these fieldtypes from your system do the following: first select all the fieldtypes you want to permanently delete by clicking in the boxes next to the fieldtype names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the fieldtypes from the database. On the other hand if you would like to change the status of the fieldtype to publish, unpublish or archive, click in the boxes next to the fieldtype names and then click on the corresponding button of the task you want to perform. This will change the state of all the fieldtypes youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a fieldtype the system checks the fieldtype out to that user. A little lock will show up next to the fieldtype name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the fieldtypes that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the fieldtype names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the fieldtype, which will mean that it removes the fieldtype from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many fieldtypes at once by clicking in the boxes next the fieldtype names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the fieldtypes according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of fieldtypes. With them you can update and create many fieldtypes at once.</p> <h3>Export</h3> <p>The export option only exports the fieldtypes selected. So to export all fieldtypes you must change the limited number of fieldtypes that are being loaded to \"All\". The box that limits the number of fieldtypes being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the fieldtype records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the fieldtypes. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create fieldtypes or update existing fieldtypes. The way to update existing fieldtypes is to use the same id as the fieldtype you want to update. Best way to do this is to first export the fieldtypes you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new fieldtypes via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of fieldtypes and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of fieldtypes with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Fieldtypes', 2, '', '', 1, 3, '', 10),
(11, 'help_documents', 'welcome-to-the-list-view-of-help-documents', '', '<p>Here as in all Joomla backend list views you can perform all the common tasks, and more.</p> <h3>Create</h3> <p>You can create a help document by clicking on the <button>New</button> button in the toolbar, this will open a window where you can add all the needed values to create a new help document.</p> <h3>Edit</h3> <p>You can edit help documents in two ways.</p> <ul> <li>You can click on the box next to the help document name and then click on the <button>Edit</button> button in the toolbar; this will open the help document and if you have permission it will give you access to edit the values of a help document.</li> <li>You can simply click on the help document name; this will open the help document and if you have permission it will give you access to edit the values of a help document.</li> </ul> <h3>Edit State</h3> <p>You can publish, unpublish, archive, and trash any help document by clicking in the boxes next the help document names and then click on the corresponding button of the task you want to perform. This will change the state of all the help documents youve selected.</p> <p>If you have trashed a help document it is in the trash and can still be found in the database. To view items that are still in the trash change the “- Select Status –“ filter to Trashed. Here you will see the list of trashed help documents. To completely remove these help documents from your system do the following: first select all the help documents you want to permanently delete by clicking in the boxes next to the help document names and then click on the <button>Empty trash</button> button in the toolbar. This will permanently delete the help documents from the database. On the other hand if you would like to change the status of the help document to publish, unpublish or archive, click in the boxes next to the help document names and then click on the corresponding button of the task you want to perform. This will change the state of all the help documents youve selected.</p> <h3>Check-in</h3> <p>When another user on your Joomla website opens a help document the system checks the help document out to that user. A little lock will show up next to the help document name. When you hover over the lock it will show to you who checked it out and when.</p> <p>Component builder adds a nice feature to all its components that is called the auto check-in feature. This feature has a time setting that you can update in the component\'s global settings.</p> <p>If this feature has not yet checked-in any of the help documents that you as the administrator wants to open you can force a check-in by clicking in the boxes next to the help document names and then click on the <button>Check-in</button> button in the toolbar, or simply click on the little lock. This will then check in the help document, which will mean that it removes the help document from the user who checked it out before you. Remember that they will lose all changes they have made if they have not yet clicked save. This can cause very unpleasant circumstances, so only use this feature if you are absolutely sure you know what you are doing.</p> <h3>Batch Feature</h3> <p>You can use the Batch feature to update or copy many help documents at once by clicking in the boxes next the help document names and then click on the <button>Batch</button> button in the toolbar. This will open a popup window with multiple dropdown options of fields you can change with the batch feature. You can then select update or copy depending of your desired task and finally click on the <button>Process</button> button. Once completed this batch feature will have either copied or updated all the help documents according to the task you selected.</p> <h3>Export & Import</h3> <p>The export and import feature is some of the most exciting features to the list view of help documents. With them you can update and create many help documents at once.</p> <h3>Export</h3> <p>The export option only exports the help documents selected. So to export all help documents you must change the limited number of help documents that are being loaded to \"All\". The box that limits the number of help documents being loaded is found on the right top corner of the page. Simply change it from the number to “All” and the page should now reload with all the help document records from the database, excluding those in trash. If you want those also to load you must change the “- Select Status –“ filter to “All” as well. Now you can click on the tick box at the very top of the table. This should select all the help documents. Next click on the <button>Export Date</button> button in the toolbar. This should open a download window and you can select to save the excel file to your computer.</p> <h3>Import</h3> <p>The import option can be used to create help documents or update existing help documents. The way to update existing help documents is to use the same id as the help document you want to update. Best way to do this is to first export the help documents you want to update and then make the changes you have in mind in the excel document without removing or changing the id. To instead create new help documents via an import, simple leave the id field empty.</p> <p>So once you have your excel document ready you will again open the list view of help documents and click on the <button>Import Data</button> button in the toolbar. This will open a page where you can select the excel file on your computer as an upload, or on the server in a directory, or at any direct url to the excel document.</p> <p>Once you have the file selected you can click on the <button>Upload File</button> or <button>Get File</button> button depending on the method you have chosen. When file has successfully been uploaded or retrieved a new window will open where you can map the excel document headers of each column to the field names used in the database. Usually if youre using an exported version of the excel document this mapping will be done for you, yet if you have changed any of the header names you may need to set these field relationships manually. There is an option to ignore a column in the case when you want to leave a field totally unchanged.</p> <p>When the field to column relationship has correctly been mapped you can click on the <button>continue</button> button at the bottom of the page. This should return you to the list view of help documents with a success message.</p> <h3>Debug</h3> <p>In the event that any of the above features did not work as expected, please read the error message carefully since it should usually give you enough information to why your request could not be processed. Subsequently if you are still not able to perform the request after making all needed corrections according to the error messages, then please contact your system administrator.</p>', '\"\"', 1, '', 2, 'Welcome to the List view of Help Documents', 2, '', '', 1, 3, '', 11);
--
-- Dumping data for table `#__componentbuilder_admin_fields`
--
INSERT INTO `#__componentbuilder_admin_fields` (`id`, `addfields`, `admin_view`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(111, '{\"0\":{\"field\":\"84\",\"list\":\"1\",\"order_list\":\"2\",\"sort\":\"1\",\"search\":\"1\",\"tab\":\"1\",\"alignment\":\"3\",\"order_edit\":\"1\"},\"1\":{\"field\":\"199\",\"list\":\"1\",\"order_list\":\"1\",\"title\":\"1\",\"sort\":\"1\",\"search\":\"1\",\"link\":\"1\",\"tab\":\"1\",\"alignment\":\"4\",\"order_edit\":\"1\"},\"2\":{\"field\":\"23\",\"list\":\"\",\"order_list\":\"0\",\"alias\":\"1\",\"search\":\"1\",\"tab\":\"1\",\"alignment\":\"4\",\"order_edit\":\"2\"},\"3\":{\"field\":\"203\",\"list\":\"2\",\"order_list\":\"0\",\"tab\":\"1\",\"alignment\":\"5\",\"order_edit\":\"1\"},\"4\":{\"field\":\"682\",\"list\":\"\",\"order_list\":\"0\",\"sort\":\"1\",\"search\":\"1\",\"filter\":\"1\",\"tab\":\"2\",\"alignment\":\"1\",\"order_edit\":\"1\"},\"5\":{\"field\":\"100\",\"list\":\"\",\"order_list\":\"0\",\"tab\":\"2\",\"alignment\":\"2\",\"order_edit\":\"1\"},\"6\":{\"field\":\"196\",\"list\":\"\",\"order_list\":\"0\",\"tab\":\"2\",\"alignment\":\"2\",\"order_edit\":\"2\"},\"7\":{\"field\":\"1011\",\"list\":\"\",\"order_list\":\"0\",\"tab\":\"2\",\"alignment\":\"2\",\"order_edit\":\"3\"},\"8\":{\"field\":\"158\",\"list\":\"\",\"order_list\":\"0\",\"tab\":\"2\",\"alignment\":\"2\",\"order_edit\":\"4\"},\"9\":{\"field\":\"280\",\"list\":\"\",\"order_list\":\"0\",\"tab\":\"2\",\"alignment\":\"2\",\"order_edit\":\"5\"}}', 109, 1, '2017-10-12 19:52:03', '2019-01-28 16:27:19', 7, '', '', '');
--
-- Dumping data for table `#__componentbuilder_admin_fields_conditions`
--
INSERT INTO `#__componentbuilder_admin_fields_conditions` (`id`, `addconditions`, `admin_view`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(111, '{\"addconditions0\":{\"target_field\":[\"1011\",\"100\",\"158\",\"196\",\"280\"],\"target_behavior\":\"1\",\"target_relation\":\"0\",\"match_field\":\"682\",\"match_behavior\":\"1\",\"match_options\":\"1|Yes\"}}', 109, 1, '2017-10-12 21:36:00', '0000-00-00 00:00:00', 2, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_admin_views`
--
INSERT INTO `#__componentbuilder_component_admin_views` (`id`, `addadmin_views`, `joomla_component`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, '{\"addadmin_views0\":{\"adminview\":\"109\",\"icomoon\":\"eye-open\",\"mainmenu\":\"1\",\"dashboard_add\":\"1\",\"dashboard_list\":\"1\",\"submenu\":\"1\",\"checkin\":\"1\",\"history\":\"1\",\"joomla_fields\":\"1\",\"metadata\":\"1\",\"access\":\"1\",\"port\":\"1\",\"filter\":\"2\",\"edit_create_site_view\":\"1\",\"order\":\"1\"}}', 25, 1, '2017-10-28 03:56:26', '2021-02-08 10:32:04', 7, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_site_views`
--
INSERT INTO `#__componentbuilder_component_site_views` (`id`, `addsite_views`, `joomla_component`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, '{\"addsite_views0\":{\"siteview\":\"23\",\"menu\":\"1\",\"metadata\":\"1\",\"default_view\":\"1\",\"access\":\"1\",\"public_access\":\"1\"},\"addsite_views1\":{\"siteview\":\"25\",\"metadata\":\"1\",\"access\":\"1\"}}', 25, 1, '2017-10-28 03:56:26', '2020-02-27 21:32:04', 4, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_custom_admin_views`
--
INSERT INTO `#__componentbuilder_component_custom_admin_views` (`id`, `addcustom_admin_views`, `joomla_component`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, '', 25, 1, '2017-10-28 03:56:26', '0000-00-00 00:00:00', 2, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_updates`
--
INSERT INTO `#__componentbuilder_component_updates` (`id`, `joomla_component`, `version_update`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, 25, '{\"version_update0\":{\"version\":\"2.0.0\",\"mysql\":\"ALTER TABLE `#__demo_look` ENGINE = InnoDB;\\r\\n\\r\\nALTER TABLE `#__demo_look` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;\",\"url\":\"https:\\/\\/git.vdm.dev\\/joomla\\/Demo-Component\\/archive\\/v2.0.0.zip\",\"update_server_adv\":\"0\",\"update_server_type\":\"component\",\"update_element\":\"\",\"update_state\":\"stable\",\"update_target_version\":\"3.*\",\"change_log\":\"\",\"update_client\":\"site\"},\"version_update1\":{\"version\":\"2.0.2\",\"mysql\":\"ALTER TABLE `#__demo_look` CHANGE `image` `image` VARCHAR(255) NOT NULL DEFAULT \'\';\",\"url\":\"https:\\/\\/git.vdm.dev\\/joomla\\/Demo-Component\\/archive\\/v2.0.2.zip\",\"update_server_adv\":\"0\",\"update_server_type\":\"component\",\"update_element\":\"\",\"update_state\":\"stable\",\"update_target_version\":\"3.*\",\"change_log\":\"\",\"update_client\":\"site\"},\"version_update2\":{\"version\":\"2.0.3\",\"mysql\":\"\",\"url\":\"https:\\/\\/git.vdm.dev\\/joomla\\/Demo-Component\\/archive\\/v2.0.3.zip\",\"update_server_adv\":\"0\",\"update_server_type\":\"component\",\"update_element\":\"\",\"update_state\":\"stable\",\"update_target_version\":\"3.*\",\"change_log\":\"\",\"update_client\":\"site\"},\"version_update3\":{\"version\":\"2.1.0\",\"mysql\":\"\",\"url\":\"https:\\/\\/git.vdm.dev\\/joomla\\/Demo-Component\\/archive\\/v2.1.0.zip\",\"update_server_adv\":\"0\",\"update_server_type\":\"component\",\"update_element\":\"\",\"update_state\":\"stable\",\"update_target_version\":\"3.*\",\"change_log\":\"\",\"update_client\":\"site\"}}', 1, '2017-10-28 03:56:26', '2022-05-27 05:23:46', 9, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_mysql_tweaks`
--
INSERT INTO `#__componentbuilder_component_mysql_tweaks` (`id`, `joomla_component`, `sql_tweak`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, 25, '', 1, '2017-10-28 03:56:26', '0000-00-00 00:00:00', 2, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_custom_admin_menus`
--
INSERT INTO `#__componentbuilder_component_custom_admin_menus` (`id`, `addcustommenus`, `joomla_component`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, '', 25, 1, '2017-10-28 03:56:26', '0000-00-00 00:00:00', 2, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_config`
--
INSERT INTO `#__componentbuilder_component_config` (`id`, `addconfig`, `joomla_component`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, '', 25, 1, '2017-10-28 03:56:26', '0000-00-00 00:00:00', 2, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_dashboard`
--
INSERT INTO `#__componentbuilder_component_dashboard` (`id`, `dashboard_tab`, `joomla_component`, `php_dashboard_methods`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `params`) VALUES
(27, '', 25, '', 1, '2017-10-28 03:56:26', '0000-00-00 00:00:00', 2, '', '', '');
--
-- Dumping data for table `#__componentbuilder_component_files_folders`
--
INSERT INTO `#__componentbuilder_component_files_folders` (`id`, `addfiles`, `addfolders`, `joomla_component`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`, `addfilesfullpath`, `addfoldersfullpath`) VALUES
(27, '', '', 25, '', 1, '2017-10-28 03:56:26', '0000-00-00 00:00:00', 2, '', '', '', '');
--
-- Dumping data for table `#__componentbuilder_snippet_type`
--
INSERT INTO `#__componentbuilder_snippet_type` (`id`, `name`, `description`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`) VALUES
(1, 'Layout', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 1),
(2, 'Navigations', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 2),
(3, 'Elements', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 3),
(4, 'Common', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 4),
(5, 'JavaScript', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 5),
(6, 'Charts', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 6),
(7, 'Alerts', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 7),
(8, 'Badges', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 8),
(9, 'Breadcrumbs', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 9),
(10, 'Buttons', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 10),
(11, 'Button Groups', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 11),
(12, 'Button Modifiers', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 12),
(13, 'Cards', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 13),
(14, 'Carousel', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 14),
(15, 'Collapse', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 15),
(16, 'Dropdowns', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 16),
(17, 'Forms', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 17),
(18, 'Form Input Groups', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 18),
(19, 'Custom Forms', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 19),
(20, 'Grid', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 20),
(21, 'Images', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 21),
(22, 'Jumbotron', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 22),
(23, 'List Group', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 23),
(24, 'Media Objects', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 24),
(25, 'Modal', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 25),
(26, 'Navs', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 26),
(27, 'Navbar', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 27),
(28, 'Pagination', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 28),
(29, 'Popover', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 29),
(30, 'Progress', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 30),
(31, 'Scrollspy', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 31),
(32, 'Tables', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 32),
(33, 'Tooltips', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 33),
(34, 'Typography', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 34),
(35, 'Utility: Borders', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 35),
(36, 'Utility: Colors', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 36),
(37, 'Utility: Display', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 37),
(38, 'Utility: Flexbox', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 38),
(39, 'Utility: Misc', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 39),
(40, 'Utility: Positioning', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 40),
(41, 'Utility: Sizing', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 41),
(42, 'Utility: Spacing', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 42),
(43, 'Utility: Text', '', '', 1, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 1, '', 43);
--
-- Dumping data for table `#__componentbuilder_library_config`
--
INSERT INTO `#__componentbuilder_library_config` (`id`, `addconfig`, `library`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`) VALUES
(1, '{\"addconfig0\":{\"field\":\"2635\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig1\":{\"field\":\"2636\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig2\":{\"field\":\"2639\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig3\":{\"field\":\"2637\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig4\":{\"field\":\"2638\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig7\":{\"field\":\"2640\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig6\":{\"field\":\"2641\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"},\"addconfig5\":{\"field\":\"2642\",\"custom_value\":\"\",\"tabname\":\"Icon Settings\"}}', 7, '', 1, '2019-10-03 09:55:37', '2019-10-03 16:41:01', 2, '', 1);
--
-- Dumping data for table `#__componentbuilder_library_files_folders_urls`
--
INSERT INTO `#__componentbuilder_library_files_folders_urls` (`id`, `addfiles`, `addfolders`, `addurls`, `library`, `params`, `published`, `created`, `modified`, `version`, `hits`, `ordering`) VALUES
(2, '', '', '{\"addurls0\":{\"url\":\"https:\\/\\/maxcdn.bootstrapcdn.com\\/bootstrap\\/4.0.0-alpha.6\\/js\\/bootstrap.min.js\",\"type\":\"2\"},\"addurls1\":{\"url\":\"https:\\/\\/maxcdn.bootstrapcdn.com\\/bootstrap\\/4.0.0-alpha.6\\/css\\/bootstrap.min.css\",\"type\":\"2\"}}', 2, '', 1, '2017-11-25 16:17:36', '2018-05-02 23:29:05', 11, '', 2),
(3, '{}', '{}', '{\"addurls2\":{\"url\":\"https:\\/\\/cdn.jsdelivr.net\\/npm\\/uikit@3.6.22\\/dist\\/css\\/uikit.min.css\",\"type\":2},\"addurls0\":{\"url\":\"https:\\/\\/cdn.jsdelivr.net\\/npm\\/uikit@3.6.22\\/dist\\/js\\/uikit.min.js\",\"type\":2},\"addurls1\":{\"url\":\"https:\\/\\/cdn.jsdelivr.net\\/npm\\/uikit@3.6.22\\/dist\\/js\\/uikit-icons.min.js\",\"type\":2}}', 3, '', 1, '2017-11-25 21:47:40', '2021-05-27 00:16:34', 11, '', 3),
(4, '{}', '{\"addfolders0\":{\"folder\":\"file_icon_vectors\",\"path\":\"\\/media\\/vector\",\"rename\":\"1\"}}', '{}', 7, '', 1, '2019-10-03 09:24:30', '2019-10-03 09:25:39', 2, '', 4),
(5, '{}', '{}', '{\"addurls0\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/grapesjs\\/0.14.15\\/css\\/grapes.min.css\",\"type\":2},\"addurls2\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/grapesjs\\/0.14.15\\/grapes.min.js\",\"type\":2}}', 8, '', 1, '2020-02-10 21:34:33', '2020-02-18 21:12:35', 5, '', 5),
(6, '{}', '{}', '{\"addurls0\":{\"url\":\"https:\\/\\/raw.githubusercontent.com\\/artf\\/grapesjs-preset-webpage\\/master\\/dist\\/grapesjs-preset-webpage.min.css\",\"type\":2},\"addurls1\":{\"url\":\"https:\\/\\/raw.githubusercontent.com\\/artf\\/grapesjs-preset-webpage\\/master\\/dist\\/grapesjs-preset-webpage.min.js\",\"type\":2},\"addurls2\":{\"url\":\"https:\\/\\/static.filestackapi.com\\/v3\\/filestack-0.1.10.js\",\"type\":2}}', 9, '', 1, '2020-02-18 21:13:16', '2020-02-18 21:14:11', 2, '', 5),
(7, '{}', '{}', '{\"addurls0\":{\"url\":\"https:\\/\\/cdn.jsdelivr.net\\/npm\\/vue\",\"type\":3}}', 10, '', 1, '2020-06-05 13:11:54', '0000-00-00 00:00:00', 1, '', 6),
(8, '{}', '{}', '{\"addurls2\":{\"url\":\"https:\\/\\/cdn.datatables.net\\/1.10.21\\/js\\/jquery.dataTables.min.js\",\"type\":2},\"addurls1\":{\"url\":\"https:\\/\\/cdn.datatables.net\\/1.10.21\\/css\\/dataTables.uikit.min.css\",\"type\":2}}', 11, '', 1, '2020-06-27 21:34:44', '0000-00-00 00:00:00', 1, '', 7),
(9, '{}', '{}', '{\"addurls3\":{\"url\":\"http:\\/\\/code.jquery.com\\/ui\\/1.11.1\\/themes\\/smoothness\\/jquery-ui.css\",\"type\":2},\"addurls0\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/jquery-ui-timepicker-addon\\/1.6.3\\/jquery-ui-timepicker-addon.min.css\",\"type\":2},\"addurls1\":{\"url\":\"http:\\/\\/code.jquery.com\\/ui\\/1.11.1\\/jquery-ui.min.js\",\"type\":2},\"addurls2\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/jquery-ui-timepicker-addon\\/1.6.3\\/jquery-ui-timepicker-addon.min.js\",\"type\":2}}', 12, '', 1, '2020-06-29 00:00:44', '2020-06-29 04:32:57', 4, '', 8),
(10, '{}', '{}', '{\"addurls0\":{\"url\":\"https:\\/\\/cdn.datatables.net\\/v\\/dt\\/jszip-2.5.0\\/dt-1.11.5\\/b-2.2.2\\/b-colvis-2.2.2\\/b-html5-2.2.2\\/b-print-2.2.2\\/cr-1.5.5\\/date-1.1.2\\/fc-4.0.2\\/fh-3.2.2\\/kt-2.6.4\\/r-2.2.9\\/rg-1.1.4\\/rr-1.2.8\\/sc-2.0.5\\/sb-1.3.2\\/sp-2.0.0\\/sl-1.3.4\\/sr-1.1.0\\/datatables.min.css\",\"type\":3},\"addurls1\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/pdfmake\\/0.1.36\\/pdfmake.min.js\",\"type\":3},\"addurls2\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/pdfmake\\/0.1.36\\/vfs_fonts.js\",\"type\":3},\"addurls3\":{\"url\":\"https:\\/\\/cdn.datatables.net\\/v\\/dt\\/jszip-2.5.0\\/dt-1.11.5\\/b-2.2.2\\/b-colvis-2.2.2\\/b-html5-2.2.2\\/b-print-2.2.2\\/cr-1.5.5\\/date-1.1.2\\/fc-4.0.2\\/fh-3.2.2\\/kt-2.6.4\\/r-2.2.9\\/rg-1.1.4\\/rr-1.2.8\\/sc-2.0.5\\/sb-1.3.2\\/sp-2.0.0\\/sl-1.3.4\\/sr-1.1.0\\/datatables.min.js\",\"type\":3}}', 13, '', 1, '2022-10-17 20:56:24', '0000-00-00 00:00:00', 1, '', 9),
(11, '{}', '{}', '{\"addurls0\":{\"url\":\"https:\\/\\/cdn.jsdelivr.net\\/npm\\/nouislider\\/dist\\/nouislider.min.css\",\"type\":2},\"addurls1\":{\"url\":\"https:\\/\\/cdn.jsdelivr.net\\/npm\\/nouislider\\/dist\\/nouislider.min.js\",\"type\":2}}', 14, '', 1, '2023-06-26 15:02:42', '2023-07-24 18:11:41', 3, '', 10),
(12, '{}', '{}', '{\"addurls4\":{\"url\":\"https:\\/\\/cdn.datatables.net\\/v\\/bs5\\/jszip-3.10.1\\/dt-2.0.2\\/b-3.0.1\\/b-colvis-3.0.1\\/b-html5-3.0.1\\/b-print-3.0.1\\/cr-2.0.0\\/date-1.5.2\\/fc-5.0.0\\/fh-4.0.1\\/kt-2.12.0\\/r-3.0.0\\/rg-1.5.0\\/rr-1.5.0\\/sc-2.4.1\\/sb-1.7.0\\/sp-2.3.0\\/sl-2.0.0\\/sr-1.4.0\\/datatables.min.css\",\"type\":3},\"addurls1\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/pdfmake\\/0.2.7\\/pdfmake.min.js\",\"type\":3},\"addurls2\":{\"url\":\"https:\\/\\/cdnjs.cloudflare.com\\/ajax\\/libs\\/pdfmake\\/0.2.7\\/vfs_fonts.js\",\"type\":3},\"addurls3\":{\"url\":\"https:\\/\\/cdn.datatables.net\\/v\\/bs5\\/jszip-3.10.1\\/dt-2.0.2\\/b-3.0.1\\/b-colvis-3.0.1\\/b-html5-3.0.1\\/b-print-3.0.1\\/cr-2.0.0\\/date-1.5.2\\/fc-5.0.0\\/fh-4.0.1\\/kt-2.12.0\\/r-3.0.0\\/rg-1.5.0\\/rr-1.5.0\\/sc-2.4.1\\/sb-1.7.0\\/sp-2.3.0\\/sl-2.0.0\\/sr-1.4.0\\/datatables.min.js\",\"type\":3}}', 15, '', 1, '2024-03-09 16:27:28', '2024-03-09 16:29:30', 2, '', 9);
CREATE TABLE IF NOT EXISTS `#__componentbuilder_external_code` (
`target` VARCHAR(255) NOT NULL DEFAULT '',
`hash` VARCHAR(64) NOT NULL DEFAULT '',
PRIMARY KEY (`target`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 DEFAULT COLLATE=utf8mb4_general_ci ROW_FORMAT=DYNAMIC;
--
-- Always insure this column name is large enough for long component and view names.
--
ALTER TABLE `#__assets` CHANGE `name` `name` VARCHAR(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'The unique name for the asset.';