* @copyright 2007-2016 Apollotheme * @description: ApPageBuilder is module help you can build content for your shop */ if (!class_exists("ApPageSetup")) { class ApPageSetup { public static function getTabs() { return array( array( 'class_name' => 'AdminApPageBuilderProfiles', 'name' => 'Ap Profiles Manage', ), array( 'class_name' => 'AdminApPageBuilderPositions', 'name' => 'Ap Positions Manage', ), array( 'class_name' => 'AdminApPageBuilderShortcode', 'name' => 'Ap ShortCode Manage', ), array( 'class_name' => 'AdminApPageBuilderHome', 'name' => 'Ap Hook Builder', 'id_parent' => -1, ), array( 'class_name' => 'AdminApPageBuilderProducts', 'name' => 'Ap Products List Builder', ), array( 'class_name' => 'AdminApPageBuilderDetails', 'name' => 'Ap Products Details Builder', ), array( 'class_name' => 'AdminApPageBuilderHook', 'name' => 'Ap Hook Control Panel', ), array( 'class_name' => 'AdminApPageBuilderThemeEditor', 'name' => 'Ap Live Theme Editor', ), array( 'class_name' => 'AdminApPageBuilderModule', 'name' => 'Ap Module Configuration', ), array( 'class_name' => 'AdminApPageBuilderThemeConfiguration', 'name' => 'Ap Theme Configuration', ), array( 'class_name' => 'AdminApPageBuilderImages', 'name' => 'Ap Image Manage', 'id_parent' => -1, ), array( 'class_name' => 'AdminApPageBuilderShortcodes', 'name' => 'Ap Shortcodes Builder', 'id_parent' => -1, ), ); } public static function createTables($reset = 0) { if ($reset == 0 && file_exists(_PS_MODULE_DIR_.'appagebuilder')) { require_once(_PS_MODULE_DIR_.'appagebuilder/libs/LeoDataSample.php'); $sample = new Datasample(); if ($sample->processImport('appagebuilder')) { return true; } } $drop = ''; if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_profiles`;'; } //each shop will have one or more profile $res = (bool)Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_profiles` ( `id_appagebuilder_profiles` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255), `group_box` varchar(255), `profile_key` varchar(255), `page` varchar(255), `params` text, `header` int(11) unsigned NOT NULL, `content` int(11) unsigned NOT NULL, `footer` int(11) unsigned NOT NULL, `product` int(11) unsigned NOT NULL, `active` TINYINT(1), `active_mobile` TINYINT(1), `active_tablet` TINYINT(1), PRIMARY KEY (`id_appagebuilder_profiles`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_profiles_lang`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_profiles_lang` ( `id_appagebuilder_profiles` int(11) NOT NULL AUTO_INCREMENT, `id_lang` int(10) unsigned NOT NULL, `friendly_url` varchar(255), `meta_title` varchar(255), `meta_description` varchar(255), `meta_keywords` varchar(255), PRIMARY KEY (`id_appagebuilder_profiles`, `id_lang`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_profiles_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_profiles_shop` ( `id_appagebuilder_profiles` int(11) NOT NULL AUTO_INCREMENT, `id_shop` int(10) unsigned NOT NULL, `active` TINYINT(1), `active_mobile` TINYINT(1), `active_tablet` TINYINT(1), PRIMARY KEY (`id_appagebuilder_profiles`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_products`;'; } //we can create product item for each shop $res &= (bool)Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_products` ( `id_appagebuilder_products` int(11) NOT NULL AUTO_INCREMENT, `plist_key` varchar(255), `name` varchar(255), `class` varchar(255), `params` text, `type` TINYINT(1), `active` TINYINT(1), `active_mobile` TINYINT(1), `active_tablet` TINYINT(1), PRIMARY KEY (`id_appagebuilder_products`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_products_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_products_shop` ( `id_appagebuilder_products` int(11) NOT NULL AUTO_INCREMENT, `id_shop` int(10) unsigned NOT NULL, `active` TINYINT(1), `active_mobile` TINYINT(1), `active_tablet` TINYINT(1), PRIMARY KEY (`id_appagebuilder_products`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); $res &= (bool)Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_details` ( `id_appagebuilder_details` int(11) NOT NULL AUTO_INCREMENT, `plist_key` varchar(255), `name` varchar(255), `class_detail` varchar(255), `url_img_preview` varchar(255), `params` text, `type` TINYINT(1), `active` TINYINT(1), `active_mobile` TINYINT(1), `active_tablet` TINYINT(1), PRIMARY KEY (`id_appagebuilder_details`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_details_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_details_shop` ( `id_appagebuilder_details` int(11) NOT NULL AUTO_INCREMENT, `id_shop` int(10) unsigned NOT NULL, `active` TINYINT(1), `active_mobile` TINYINT(1), `active_tablet` TINYINT(1), PRIMARY KEY (`id_appagebuilder_details`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder`;'; } $res &= (bool)Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder` ( `id_appagebuilder` int(11) NOT NULL AUTO_INCREMENT, `id_appagebuilder_positions` int(11) NOT NULL, `hook_name` varchar(255), `id_appagebuilder_shortcode` int(11) NOT NULL, PRIMARY KEY (`id_appagebuilder`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_shop` ( `id_appagebuilder` int(11) NOT NULL AUTO_INCREMENT, `id_shop` int(10) unsigned NOT NULL, PRIMARY KEY (`id_appagebuilder`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_lang`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_lang` ( `id_appagebuilder` int(11) NOT NULL AUTO_INCREMENT, `id_lang` int(10) unsigned NOT NULL, `params` MEDIUMTEXT, PRIMARY KEY (`id_appagebuilder`, `id_lang`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_positions`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_positions` ( `id_appagebuilder_positions` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `position` varchar(255) NOT NULL, `position_key` varchar(255) NOT NULL, `params` text, PRIMARY KEY (`id_appagebuilder_positions`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_positions_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_positions_shop` ( `id_appagebuilder_positions` int(11) NOT NULL AUTO_INCREMENT, `id_shop` int(10) unsigned NOT NULL, PRIMARY KEY (`id_appagebuilder_positions`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_page_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_page` ( `id_product` int(11) unsigned NOT NULL, `id_category` int(11) unsigned NOT NULL, `page` varchar(255) NOT NULL, `id_shop` int(10) unsigned NOT NULL, PRIMARY KEY (`id_product`, `id_category`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); //DONGND:: create table for ap shortcode if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_shortcode`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_shortcode` ( `id_appagebuilder_shortcode` int(11) NOT NULL AUTO_INCREMENT, `shortcode_key` varchar(255) NOT NULL, `active` TINYINT(1), PRIMARY KEY (`id_appagebuilder_shortcode`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); //DONGND:: create table for ap shortcode (lang) if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_shortcode_lang`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_shortcode_lang` ( `id_appagebuilder_shortcode` int(11) unsigned NOT NULL, `id_lang` int(10) unsigned NOT NULL, `shortcode_name` text NOT NULL, PRIMARY KEY (`id_appagebuilder_shortcode`, `id_lang`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); //DONGND:: create table for ap shortcode (shop) if ($reset == 1) { $drop = 'DROP TABLE IF EXISTS `'._DB_PREFIX_.'appagebuilder_shortcode_shop`;'; } $res &= Db::getInstance()->execute($drop.' CREATE TABLE IF NOT EXISTS `'._DB_PREFIX_.'appagebuilder_shortcode_shop` ( `id_appagebuilder_shortcode` int(11) unsigned NOT NULL, `id_shop` int(10) unsigned NOT NULL, `active` TINYINT(1), PRIMARY KEY (`id_appagebuilder_shortcode`, `id_shop`) ) ENGINE='._MYSQL_ENGINE_.' DEFAULT CHARSET=UTF8; '); return $res; } public static function installSample() { $id_shop = Context::getContext()->shop->id; //table appagebuilder_profiles Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_profiles`'); $sql = 'INSERT INTO `'._DB_PREFIX_.'appagebuilder_profiles` (`id_appagebuilder_profiles`, `name`, `profile_key`, `page`, `params`, `header`, `content`, `footer`, `product`, `active`) VALUES (1, \'Home page\', \'profile1426561433\', \'index\', \'{"displayTopColumn":{"exception":[""]},"displayHome":{"exception":[""]},"fullwidth_index_hook":{"displayBanner":0,"displayNav":0,"displayTop":"1","displayTopColumn":"1","displayHome":0,"displayFooter":0},"fullwidth_other_hook":{"displayBanner":0,"displayNav":0,"displayTop":0,"displayTopColumn":0,"displayFooter":0}}\', 1, 2, 27, 4, NULL), (2, \'Detail demo\', \'profile1426579529\', \'index\', \'{"displayTopColumn":{"exception":[""]},"displayHome":{"exception":[""]},"fullwidth_index_hook":{"displayBanner":0,"displayNav":0,"displayTop":"1","displayTopColumn":"1","displayHome":0,"displayFooter":0},"fullwidth_other_hook":{"displayBanner":0,"displayNav":0,"displayTop":0,"displayTopColumn":0,"displayFooter":0}}\', 5, 6, 28, 8, NULL), (3, \'Home page 1\', \'profile1427119013\', \'index\', \'{"displayHome":{"exception":[""]}}\', 9, 10, 25, 12, NULL), (4, \'Home page 2\', \'profile1427116699\', \'index\', \'{"displayTopColumn":{"exception":[""]},"displayHome":{"exception":[""]}}\', 13, 14, 26, 16, NULL), (5, \'Home page 3\', \'profile1427805353\', \'index\', \'{"displayTopColumn":{"exception":[""]},"displayHome":{"exception":[""]},"fullwidth_index_hook":{"displayBanner":0,"displayNav":0,"displayTop":"1","displayTopColumn":"1","displayHome":0,"displayFooter":0},"fullwidth_other_hook":{"displayBanner":0,"displayNav":0,"displayTop":0,"displayTopColumn":0,"displayHome":0,"displayFooter":0}}\', 21, 22, 29, 24, NULL);'; Db::getInstance()->execute($sql); //table appagebuilder_profiles_shop Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_profiles_shop`'); $sql = 'INSERT INTO `'._DB_PREFIX_.'appagebuilder_profiles_shop` (`id_appagebuilder_profiles`, `id_shop`, `active`) VALUES (1, ID_SHOP, 0), (2, ID_SHOP, 0), (3, ID_SHOP, 1), (4, ID_SHOP, 0), (5, ID_SHOP, 0);'; $sql = str_replace('ID_SHOP', (int)$id_shop, $sql); Db::getInstance()->execute($sql); //table appagebuilder_positions Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_positions`'); $sql = "INSERT INTO `"._DB_PREFIX_."appagebuilder_positions` (`id_appagebuilder_positions`, `name`, `position`, `position_key`, `params`) VALUES (1, 'header1426579629', 'header', 'position1426579629', NULL), (2, 'content1426564879', 'content', 'position1426564879', NULL), (3, 'footer1426566238', 'footer', 'position1426566238', NULL), (4, 'product1426580519', 'product', 'position1426580519', NULL), (5, 'header1426564187', 'header', 'position1426564187', NULL), (6, 'content1426564490', 'content', 'position1426564490', NULL), (7, 'footer1426578355', 'footer', 'position1426578355', NULL), (8, 'product1426581801', 'product', 'position1426581801', NULL), (9, 'header1427111294', 'header', 'position1427111294', NULL), (10, 'content1427129695', 'content', 'position1427129695', NULL), (11, 'footer1427107373', 'footer', 'position1427107373', NULL), (12, 'product1427129206', 'product', 'position1427129206', NULL), (13, 'header1427138535', 'header', 'position1427138535', NULL), (14, 'content1427116604', 'content', 'position1427116604', NULL), (15, 'footer1427111534', 'footer', 'position1427111534', NULL), (16, 'product1427111243', 'product', 'position1427111243', NULL), (17, 'header1427806687', 'header', 'position1427806687', NULL), (18, 'content1427819338', 'content', 'position1427819338', NULL), (19, 'footer1427821311', 'footer', 'position1427821311', NULL), (20, 'product1427816721', 'product', 'position1427816721', NULL), (21, 'header1434016210', 'header', 'position1434016210', NULL), (22, 'content1434021220', 'content', 'position1434021220', NULL), (23, 'footer1434021922', 'footer', 'position1434021922', NULL), (24, 'product1434038427', 'product', 'position1434038427', NULL), (25, 'footer1435143282', 'footer', 'position1435143282', NULL), (26, 'footer1435158937', 'footer', 'position1435158937', NULL), (27, 'footer1435144169', 'footer', 'position1435144169', NULL), (28, 'footer1435153254', 'footer', 'position1435153254', NULL), (29, 'footer1435237119', 'footer', 'position1435237119', NULL);"; Db::getInstance()->execute($sql); //table appagebuilder_positions_shop Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_positions_shop`'); $sql = "INSERT INTO `"._DB_PREFIX_."appagebuilder_positions_shop` (`id_appagebuilder_positions`, `id_shop`) VALUES (1, ID_SHOP), (2, ID_SHOP), (4, ID_SHOP), (5, ID_SHOP), (6, ID_SHOP), (8, ID_SHOP), (9, ID_SHOP), (10, ID_SHOP), (12, ID_SHOP), (13, ID_SHOP), (14, ID_SHOP), (16, ID_SHOP), (21, ID_SHOP), (22, ID_SHOP), (24, ID_SHOP), (25, ID_SHOP), (26, ID_SHOP), (27, ID_SHOP), (28, ID_SHOP), (29, ID_SHOP), (30, ID_SHOP);"; $sql = str_replace('ID_SHOP', (int)$id_shop, $sql); Db::getInstance()->execute($sql); //table appagebuilder Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder`'); $sql = "INSERT INTO `"._DB_PREFIX_."appagebuilder` (`id_appagebuilder`, `id_appagebuilder_positions`, `hook_name`) VALUES (1, 1, 'displayBanner'), (2, 1, 'displayNav'), (3, 1, 'displayTop'), (4, 2, 'displayTopColumn'), (5, 2, 'displayLeftColumn'), (6, 2, 'displayHome'), (7, 2, 'displayRightColumn'), (8, 3, 'displayFooter'), (9, 4, 'displayFooterProduct'), (10, 4, 'displayRightColumnProduct'), (11, 5, 'displayBanner'), (12, 5, 'displayNav'), (13, 5, 'displayTop'), (14, 6, 'displayTopColumn'), (15, 6, 'displayLeftColumn'), (16, 6, 'displayHome'), (17, 6, 'displayRightColumn'), (18, 7, 'displayFooter'), (19, 8, 'displayFooterProduct'), (20, 8, 'displayRightColumnProduct'), (21, 9, 'displayBanner'), (22, 9, 'displayNav'), (23, 9, 'displayTop'), (24, 10, 'displayTopColumn'), (25, 10, 'displayLeftColumn'), (26, 10, 'displayHome'), (27, 10, 'displayRightColumn'), (28, 11, 'displayFooter'), (29, 12, 'displayFooterProduct'), (30, 12, 'displayRightColumnProduct'), (31, 13, 'displayBanner'), (32, 13, 'displayNav'), (33, 13, 'displayTop'), (34, 14, 'displayTopColumn'), (35, 14, 'displayLeftColumn'), (36, 14, 'displayHome'), (37, 14, 'displayRightColumn'), (38, 15, 'displayFooter'), (39, 16, 'displayFooterProduct'), (40, 16, 'displayRightColumnProduct'), (41, 17, 'displayBanner'), (42, 17, 'displayNav'), (43, 17, 'displayTop'), (44, 18, 'displayTopColumn'), (45, 18, 'displayLeftColumn'), (46, 18, 'displayHome'), (47, 18, 'displayRightColumn'), (48, 19, 'displayFooter'), (49, 20, 'displayFooterProduct'), (50, 20, 'displayRightColumnProduct'), (51, 21, 'displayBanner'), (52, 21, 'displayNav'), (53, 21, 'displayTop'), (54, 22, 'displayTopColumn'), (55, 22, 'displayLeftColumn'), (56, 22, 'displayHome'), (57, 22, 'displayRightColumn'), (58, 23, 'displayFooter'), (59, 24, 'displayFooterProduct'), (60, 24, 'displayRightColumnProduct'), (61, 25, 'displayFooter'), (62, 26, 'displayFooter'), (63, 27, 'displayFooter'), (64, 28, 'displayFooter'), (65, 29, 'displayFooter');"; Db::getInstance()->execute($sql); //table appagebuilder_lang Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_lang`'); $sqlArray[] = Tools::file_get_contents( apPageHelper::getShortcodeTemplatePath('setup.txt')); $languages = Language::getLanguages(false); foreach ($sqlArray as $sql) { foreach ($languages as $lang) { $sqlRun = str_replace('ID_LANG', (int)$lang["id_lang"], $sql); $sqlRun = str_replace('_DB_PREFIX_', _DB_PREFIX_, $sqlRun); Db::getInstance()->execute($sqlRun); } } //table appagebuilder_shop Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_shop`'); $sql = 'INSERT INTO `'._DB_PREFIX_.'appagebuilder_shop` (`id_appagebuilder`, `id_shop`) VALUES (1, ID_SHOP), (2, ID_SHOP), (3, ID_SHOP), (4, ID_SHOP), (5, ID_SHOP), (6, ID_SHOP), (7, ID_SHOP), (8, ID_SHOP), (9, ID_SHOP), (10, ID_SHOP), (11, ID_SHOP), (12, ID_SHOP), (13, ID_SHOP), (14, ID_SHOP), (15, ID_SHOP), (16, ID_SHOP), (17, ID_SHOP), (18, ID_SHOP), (19, ID_SHOP), (20, ID_SHOP), (21, ID_SHOP), (22, ID_SHOP), (23, ID_SHOP), (24, ID_SHOP), (25, ID_SHOP), (26, ID_SHOP), (27, ID_SHOP), (28, ID_SHOP), (29, ID_SHOP), (30, ID_SHOP), (31, ID_SHOP), (32, ID_SHOP), (33, ID_SHOP), (34, ID_SHOP), (35, ID_SHOP), (36, ID_SHOP), (37, ID_SHOP), (38, ID_SHOP), (39, ID_SHOP), (40, ID_SHOP), (41, ID_SHOP), (42, ID_SHOP), (43, ID_SHOP), (44, ID_SHOP), (45, ID_SHOP), (46, ID_SHOP), (47, ID_SHOP), (48, ID_SHOP), (49, ID_SHOP), (50, ID_SHOP), (51, ID_SHOP), (52, ID_SHOP), (53, ID_SHOP), (54, ID_SHOP), (55, ID_SHOP), (56, ID_SHOP), (57, ID_SHOP), (58, ID_SHOP), (59, ID_SHOP), (60, ID_SHOP), (61, ID_SHOP), (62, ID_SHOP), (63, ID_SHOP), (64, ID_SHOP), (65, ID_SHOP);'; $sql = str_replace('ID_SHOP', (int)$id_shop, $sql); Db::getInstance()->execute($sql); //table appagebuilder_products Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_products`'); $sql = 'INSERT INTO `'._DB_PREFIX_.'appagebuilder_products` (`id_appagebuilder_products`, `plist_key`, `name`, `params`, `type`, `class`, `active`) VALUES (1, \'plist1427203522\', \'plist1427203522\', \'{"gridLeft":{"0":{"name":"image_container"},"1":{"name":"quick_view"}},"gridRight":{"0":{"name":"price"},"1":{"name":"reviews"},"2":{"name":"name"},"3":{"name":"functional_buttons","element":{"0":{"name":"wishlist"},"1":{"name":"add_to_cart"},"2":{"name":"compare"}}}}}\', 0, \'\', NULL);'; Db::getInstance()->execute($sql); //table appagebuilder_products_shop Db::getInstance()->execute('TRUNCATE TABLE `'._DB_PREFIX_.'appagebuilder_products_shop`'); $sql = 'INSERT INTO `'._DB_PREFIX_.'appagebuilder_products_shop` (`id_appagebuilder_products`, `id_shop`, `active`) VALUES (1, ID_SHOP, 1)'; $sql = str_replace('ID_SHOP', (int)$id_shop, $sql); Db::getInstance()->execute($sql); //copy product profile $folder = apPageHelper::getConfigDir('theme_profiles'); if (!is_dir($folder)) { mkdir($folder, 0755, true); } $tpl_grid = Tools::file_get_contents(_PS_MODULE_DIR_.'appagebuilder/views/templates/front/product-item/plist1427203522.tpl'); ApPageSetting::writeFile($folder, 'plist1427203522.tpl', $tpl_grid); } public static function installModuleTab() { $id_parent = Tab::getIdFromClassName('IMPROVE'); //create parent tab $newtab = new Tab(); $newtab->class_name = 'AdminApPageBuilder'; $newtab->id_parent = $id_parent; $newtab->module = 'appagebuilder'; foreach (Language::getLanguages(false) as $l) { $newtab->name[$l['id_lang']] = Context::getContext()->getTranslator()->trans('Ap PageBuilder', array(), 'Modules.Appagebuilder.Admin'); } if ($newtab->save()) { $id_parent = $newtab->id; # insert icon for tab Db::getInstance()->execute(' UPDATE `'._DB_PREFIX_.'tab` SET `icon` = "tab" WHERE `id_tab` = "'.(int)$newtab->id.'"'); foreach (self::getTabs() as $tab) { $newtab = new Tab(); $newtab->class_name = $tab['class_name']; $newtab->id_parent = isset($tab['id_parent']) ? $tab['id_parent'] : $id_parent; $newtab->module = 'appagebuilder'; foreach (Language::getLanguages(false) as $l) { $newtab->name[$l['id_lang']] = Context::getContext()->getTranslator()->trans($tab['name'], array(), 'Modules.Appagebuilder.Admin'); } $newtab->save(); } return true; } return false; } public static function installConfiguration() { $res = true; $res &= Configuration::updateValue('APPAGEBUILDER_PRODUCT_MAX_RANDOM', 2); $res &= Configuration::updateValue('APPAGEBUILDER_GUIDE', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_OWL', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_STELLAR', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_WAYPOINTS', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_INSTAFEED', 0); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_HTML5VIDEO', 0); $res &= Configuration::updateValue('APPAGEBUILDER_SAVE_MULTITHREARING', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_FULLPAGEJS', 0); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_IMAGE360', 0); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_IMAGEHOTPOT', 0); $res &= Configuration::updateValue('APPAGEBUILDER_SAVE_SUBMIT', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_PRODUCTZOOM', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_TABCOLLAPSE', 0); // $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_AJAX', 1); // $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_PN', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_TRAN', 1); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_IMG', 0); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_COUNT', 1); // $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_COLOR', 1); // $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_ACOLOR', 1); $res &= Configuration::updateValue('APPAGEBUILDER_COLOR', ''); $res &= Configuration::updateValue('APPAGEBUILDER_COOKIE_PROFILE', 0); $res &= Configuration::updateValue('APPAGEBUILDER_SLIDE_IMAGE', 1); $res &= Configuration::updateValue('APPAGEBUILDER_HEADER_HOOK', implode(',', ApPageSetting::getHook('header'))); $res &= Configuration::updateValue('APPAGEBUILDER_CONTENT_HOOK', implode(',', ApPageSetting::getHook('content'))); $res &= Configuration::updateValue('APPAGEBUILDER_FOOTER_HOOK', implode(',', ApPageSetting::getHook('footer'))); $res &= Configuration::updateValue('APPAGEBUILDER_PRODUCT_HOOK', implode(',', ApPageSetting::getHook('product'))); $res &= Configuration::updateValue('APPAGEBUILDER_GLOBAL_HEADER_ID', 0); $res &= Configuration::updateValue('APPAGEBUILDER_GLOBAL_CONTENT_ID', 0); $res &= Configuration::updateValue('APPAGEBUILDER_GLOBAL_FOOTER_ID', 0); $res &= Configuration::updateValue('APPAGEBUILDER_GLOBAL_PRODUCT_ID', 0); $res &= Configuration::updateValue('APPAGEBUILDER_GLOBAL_PROFILE_PARAM', ''); $res &= Configuration::updateValue('APPAGEBUILDER_LOAD_COOKIE', 0); $res &= Configuration::updateValue('APPAGEBUILDER_REGISTER', 0); return $res; } public static function deleteTables() { return Db::getInstance()->execute('DROP TABLE IF EXISTS `'. _DB_PREFIX_.'appagebuilder_profiles`, `'. _DB_PREFIX_.'appagebuilder_profiles_lang`, `'. _DB_PREFIX_.'appagebuilder_profiles_shop`, `'. _DB_PREFIX_.'appagebuilder_products`, `'. _DB_PREFIX_.'appagebuilder_products_shop` , `'. _DB_PREFIX_.'appagebuilder`, `'. _DB_PREFIX_.'appagebuilder_shop`, `'. _DB_PREFIX_.'appagebuilder_lang`, `'. _DB_PREFIX_.'appagebuilder_extracat`, `'. _DB_PREFIX_.'appagebuilder_extrapro`, `'. _DB_PREFIX_.'appagebuilder_page`, `'. _DB_PREFIX_.'appagebuilder_details`, `'. _DB_PREFIX_.'appagebuilder_details_shop`, `'. _DB_PREFIX_.'appagebuilder_positions`, `'. _DB_PREFIX_.'appagebuilder_shortcode`, `'. _DB_PREFIX_.'appagebuilder_shortcode_lang`, `'. _DB_PREFIX_.'appagebuilder_shortcode_shop`, `'. _DB_PREFIX_.'appagebuilder_positions_shop`; '); } public static function uninstallModuleTab() { $id = Tab::getIdFromClassName('AdminApPageBuilder'); if ($id) { $tab = new Tab($id); $tab->delete(); } foreach (self::getTabs() as $tab) { $id = Tab::getIdFromClassName($tab['class_name']); if ($id) { $tab = new Tab($id); $tab->delete(); } } return true; } public static function uninstallConfiguration() { $res = true; $res &= Configuration::deleteByName('APPAGEBUILDER_PRODUCT_MAX_RANDOM'); $res &= Configuration::deleteByName('APPAGEBUILDER_GUIDE'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_OWL'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_STELLAR'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_WAYPOINTS'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_INSTAFEED'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_HTML5VIDEO'); $res &= Configuration::deleteByName('APPAGEBUILDER_SAVE_MULTITHREARING'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_FULLPAGEJS'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_IMAGE360'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_IMAGEHOTPOT'); $res &= Configuration::deleteByName('APPAGEBUILDER_SAVE_SUBMIT'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_PRODUCTZOOM'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_TABCOLLAPSE'); // $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_AJAX'); // $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_PN'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_TRAN'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_IMG'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_COUNT'); // $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_COLOR'); // $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_ACOLOR'); $res &= Configuration::deleteByName('APPAGEBUILDER_COLOR'); $res &= Configuration::deleteByName('APPAGEBUILDER_COOKIE_PROFILE'); $res &= Configuration::deleteByName('APPAGEBUILDER_SLIDE_IMAGE'); $res &= Configuration::deleteByName('APPAGEBUILDER_HEADER_HOOK'); $res &= Configuration::deleteByName('APPAGEBUILDER_CONTENT_HOOK'); $res &= Configuration::deleteByName('APPAGEBUILDER_FOOTER_HOOK'); $res &= Configuration::deleteByName('APPAGEBUILDER_PRODUCT_HOOK'); $res &= Configuration::deleteByName('APPAGEBUILDER_GLOBAL_HEADER_ID'); $res &= Configuration::deleteByName('APPAGEBUILDER_GLOBAL_CONTENT_ID'); $res &= Configuration::deleteByName('APPAGEBUILDER_GLOBAL_FOOTER_ID'); $res &= Configuration::deleteByName('APPAGEBUILDER_GLOBAL_PRODUCT_ID'); $res &= Configuration::deleteByName('APPAGEBUILDER_GLOBAL_PROFILE_PARAM'); $res &= Configuration::deleteByName('APPAGEBUILDER_LOAD_COOKIE'); //DONGND:: remove config check override for shortcode $res &= Configuration::deleteByName('APPAGEBUILDER_OVERRIDED'); return $res; } /** * Remove file index.php in sub folder theme/translations folder when install theme */ public static function processTranslateTheme() { $theme_name = apPageHelper::getInstallationThemeName(); if (file_exists(_PS_ALL_THEMES_DIR_.$theme_name.'/config.xml')) { $directories = glob(_PS_ALL_THEMES_DIR_.$theme_name.'/translations/*', GLOB_ONLYDIR); if (count($directories) > 0) { foreach ($directories as $directories_val) { if (file_exists($directories_val.'/index.php')) { unlink($directories_val.'/index.php'); } } } } } /** * Remove file index.php for translate in Quickstart version */ public static function processTranslateQSTheme() { # GET ARRAY THEME_NAME $arr_theme_name = array(); $themes = glob(_PS_ROOT_DIR_.'/themes/*/config/theme.yml'); if (count($themes) > 1) { foreach ($themes as $key => $value) { $temp_name = basename(Tools::substr($value, 0, -strlen('/config/theme.yml'))); if ($temp_name == 'classic') { continue; } else { $arr_theme_name[] = $temp_name; } } } foreach ($arr_theme_name as $key => $theme_name) { //DONGND:: remove index.php in sub folder theme/translations folder when install theme if (file_exists(_PS_ALL_THEMES_DIR_.$theme_name.'/config.xml')) { $directories = glob(_PS_ALL_THEMES_DIR_.$theme_name.'/translations/*', GLOB_ONLYDIR); if (count($directories) > 0) { foreach ($directories as $directories_val) { if (file_exists($directories_val.'/index.php')) { unlink($directories_val.'/index.php'); } } } } } } } }