X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Fextensions%2Fext-theme.php;h=39d54a85ccfe5098a82d372d1b4c0179142569cb;hp=d5cc37660b0a70af5bba838491abdb78c8b00510;hb=6d08952d672c5a5de7d8522f894a5665599a2a4a;hpb=e3701377bd1dcae6ac39265f8c1bdd8d0fed7911 diff --git a/inc/extensions/ext-theme.php b/inc/extensions/ext-theme.php index d5cc37660b..39d54a85cc 100644 --- a/inc/extensions/ext-theme.php +++ b/inc/extensions/ext-theme.php @@ -1,7 +1,7 @@ set_session() mit @-Zeichen gegen ungewollte Ausgaben abgesichert."); + // Unregister filters + unregisterFilter(__FILE__, __LINE__, 'init', 'HANDLE_THEME_CHANGE', TRUE, isExtensionDryRun()); + unregisterFilter(__FILE__, __LINE__, 'member_login_check', 'SET_USERS_THEME', TRUE, isExtensionDryRun()); + unregisterFilter(__FILE__, __LINE__, 'pre_user_registration', 'THEME_USER_REGISTRATION_ADD_SQL_COLUMNS', TRUE, isExtensionDryRun()); break; - case "0.0.6": // SQL queries for v0.0.6 - // Update notes (these will be set as task text!) - EXT_SET_UPDATE_NOTES("Variablen-Handling skriptglobal geändert."); + case 'activate': // Do stuff when admin activates this extension + // SQL commands to run + addExtensionSql("UPDATE `{?_MYSQL_PREFIX?}_guest_menu` SET `visible`='Y',`locked`='N' WHERE `action`='theme' LIMIT 1"); + addExtensionSql("UPDATE `{?_MYSQL_PREFIX?}_member_menu` SET `visible`='Y',`locked`='N' WHERE `action`='themes' OR `what`='themes' LIMIT 2"); break; - case "0.0.7": // SQL queries for v0.0.7 - // Update notes (these will be set as task text!) - EXT_SET_UPDATE_NOTES("Ungültiges Update."); + case 'deactivate': // Do stuff when admin deactivates this extension + // SQL commands to run + addExtensionSql("UPDATE `{?_MYSQL_PREFIX?}_guest_menu` SET `visible`='N',`locked`='Y' WHERE `action`='theme' LIMIT 1"); + addExtensionSql("UPDATE `{?_MYSQL_PREFIX?}_member_menu` SET `visible`='N',`locked`='Y' WHERE `action`='themes' OR `what`='themes' LIMIT 2"); break; - case "0.0.8": // SQL queries for v0.0.8 - // Theme table - ADD_SQL("DROP TABLE IF EXISTS `{!_MYSQL_PREFIX!}_themes`"); - ADD_SQL("CREATE TABLE `{!_MYSQL_PREFIX!}_themes` ( -id BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT, -theme_path VARCHAR(255) NOT NULL DEFAULT '', -theme_name VARCHAR(255) NOT NULL DEFAULT '', -theme_active ENUM('Y','N') NOT NULL DEFAULT 'N', -theme_ver VARCHAR(255) NOT NULL DEFAULT '0.0', + case 'update': // Update an extension + switch (getCurrentExtensionVersion()) { + case '0.0.1': // SQL queries for v0.0.1 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("HTML-Code für ein Zeilen-Template ausgelagert."); + break; + + case '0.0.2': // SQL queries for v0.0.2 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Abspeichern von Einstellungen repariert."); + break; + + case '0.0.3': // SQL queries for v0.0.3 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Im Menüpunkt "Prüfen" wurden die bereits installierten und auch aktuellen Themes nicht ausgeblendet."); + break; + + case '0.0.4': // SQL queries for v0.0.4 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Sicherheitsupdate für die Include-Befehle."); + break; + + case '0.0.5': // SQL queries for v0.0.5 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("setSession() mit @-Zeichen gegen ungewollte Ausgaben abgesichert."); + break; + + case '0.0.6': // SQL queries for v0.0.6 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Variablen-Handling scripteweit geändert."); + break; + + case '0.0.7': // SQL queries for v0.0.7 + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Ungültiges Update."); + break; + + case '0.0.8': // SQL queries for v0.0.8 + // Theme table + addDropTableSql('themes'); + addCreateTableSql('themes', " +`id` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT, +`theme_path` VARCHAR(255) NOT NULL DEFAULT '', +`theme_name` VARCHAR(255) NOT NULL DEFAULT '', +`theme_active` ENUM('Y','N') NOT NULL DEFAULT 'N', +`theme_ver` VARCHAR(255) NOT NULL DEFAULT '0.0.0', PRIMARY KEY (`id`), -UNIQUE KEY (`theme_path`), -INDEX (`theme_active`) -) TYPE={!_TABLE_TYPE!} COMMENT='Themes'"); - - // Admin menu - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_admin_menu` (`action`,`what`,`title`,`descr`,`sort`) VALUES ('theme', NULL, 'Themes','Verwalten Sie hier alle Designs (Themes) Ihres Mailtausch-Scriptes.', 8)"); - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_admin_menu` (`action`,`what`,`title`,`descr`,`sort`) VALUES ('theme','theme_import','Importieren','Es wird das Verzeichnis "theme" nach neuen Ordnern durchsucht und anschliessend in die Datenbank gesperrt aufgenommen.', 1)"); - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_admin_menu` (`action`,`what`,`title`,`descr`,`sort`) VALUES ('theme','theme_edit','Modifizieren','Ändern Sie Titel, Freigaben usw. an den Themes. Sie können bis auf das Standart-Theme "default" auch Themes aus der Datenbank entfernen. Vorher sollten Sie es jedoch vom Server löschen, damit es niht erneut importiert werden kann.', 2)"); - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_admin_menu` (`action`,`what`,`title`,`descr`,`sort`) VALUES ('theme','theme_check','Prüfen','Nach neuen Themes suchen bzw. nach Updates zu den Themes suchen.', 3)"); - - // Guest menu - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_guest_menu` (`action`,`what`,`title`,`sort`,`visible`,`locked`) VALUES ('themes',NULL,'Design-Auswahl',4,'Y','N')"); - - // Memember menu - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_member_menu` (`action`,`what`,`title`,`sort`,`visible`,`locked`) VALUES ('themes',NULL,'Design-Auswahl',3,'Y','N')"); - ADD_SQL("INSERT INTO `{!_MYSQL_PREFIX!}_member_menu` (`action`,`what`,`title`,`sort`,`visible`,`locked`) VALUES ('main','themes','Designs', 6,'Y','N')"); - ADD_SQL("UPDATE `{!_MYSQL_PREFIX!}_member_menu` SET `sort`='8' WHERE `action`='themes' LIMIT 1"); - ADD_SQL("UPDATE `{!_MYSQL_PREFIX!}_member_menu` SET `action`='account', `sort`='1', `title`='Designs' WHERE `what`='themes' LIMIT 1"); - - // User data - ADD_SQL("ALTER TABLE `{!_MYSQL_PREFIX!}_user_data` ADD curr_theme VARCHAR(255) NOT NULL DEFAULT 'default'"); - - // Update notes (these will be set as task text!) - EXT_SET_UPDATE_NOTES("Update von sql_patches übertragen. (Kann Fehlermeldungen verursacht haben!)"); +UNIQUE INDEX (`theme_path`), +INDEX (`theme_active`)", 'Themes'); + + // Admin menu + addAdminMenuSql('theme', NULL, 'Themes', 'Verwalten Sie hier alle Designs (Themes) Ihres {OPEN_CONFIG}mt_word2{CLOSE_CONFIG}.', 8); + addAdminMenuSql('theme', 'theme_import', 'Importieren', 'Es wird das Verzeichnis "theme" nach neuen Ordnern durchsucht und anschliessend in die Datenbank gesperrt aufgenommen.', 1); + addAdminMenuSql('theme', 'theme_edit', 'Modifizieren', 'Ändern Sie Titel, Freigaben usw. an den Themes. Sie können bis auf das Standard-Theme "default" auch Themes aus der Datenbank entfernen. Vorher sollten Sie es jedoch vom Server löschen, damit es niht erneut importiert werden kann.', 2); + + // Guest menu + addGuestMenuSql('themes', NULL, 'Design-Auswahl', 4); + + // Memember menu + addMemberMenuSql('themes', NULL, 'Design-Auswahl', 3); + addMemberMenuSql('main', 'themes', 'Designs', 6); + addExtensionSql("UPDATE `{?_MYSQL_PREFIX?}_member_menu` SET `sort`=8 WHERE `action`='themes' LIMIT 1"); + addExtensionSql("UPDATE `{?_MYSQL_PREFIX?}_member_menu` SET `action`='account',`sort`=1,`title`='Designs' WHERE `what`='themes' LIMIT 1"); + + // User data + addExtensionAddTableColumnSql('user_data', 'curr_theme', "VARCHAR(255) NOT NULL DEFAULT 'default'"); + + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Update von sql_patches übertragen. (Kann Fehlermeldungen verursacht haben!)"); + break; + + case '0.0.9': // SQL queries for v0.0.9 + // Config SQL + addConfigAddSql('default_theme', "VARCHAR(255) NOT NULL DEFAULT 'default'"); + + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Fehlende Konfiguration hinzugefügt."); + break; + + case '0.1.0': // SQL queries for v0.1.0 + // Register filter + registerFilter(__FILE__, __LINE__, 'init', 'HANDLE_THEME_CHANGE', FALSE, TRUE, isExtensionDryRun()); + + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Ändern des Designs nun im Filter (internes TODO)."); + break; + + case '0.1.1': // SQL queries for v0.1.1 + // Register filter + registerFilter(__FILE__, __LINE__, 'member_login_check', 'SET_USERS_THEME', FALSE, TRUE, isExtensionDryRun()); + + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Setzen des Mitgliedes' eigener Design-Auswahl per Filter (internes TODO)."); + break; + + case '0.1.2': // SQL queries for v0.1.2 + // Remove deprecated menu + addExtensionSql("DELETE LOW_PRIORITY FROM `{?_MYSQL_PREFIX?}_admin_menu` WHERE `what`='theme_check' LIMIT 1"); + + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Nicht mehr benötigtes Menü zum Prüfen von Theme-Versionen entfernt."); + break; + + case '0.1.3': // SQL queries for v0.1.3 + // Register filter + registerFilter(__FILE__, __LINE__, 'pre_user_registration', 'THEME_USER_REGISTRATION_ADD_SQL_COLUMNS', FALSE, TRUE, isExtensionDryRun()); + + // This depends on ext-register + addExtensionDependency('register'); + + // Update notes (these will be set as task text!) + setExtensionUpdateNotes("Filter für Mitgliederanmeldung hinzugefügt."); + break; + } // END - switch break; - } - break; -case "modify": // When the extension got modified - break; + case 'modify': // When the extension got modified + break; -case "test": // For testing purposes. For details see file inc/modules/admin/what-extensions.php, arround line 305. - break; + case 'test': // For testing purposes + break; -default: // Do stuff when extension is loaded - break; -} + case 'init': // Do stuff when extension is initialized + break; + + default: // Unknown extension mode + reportBug(__FILE__, __LINE__, sprintf("Unknown extension mode %s in extension %s detected.", getExtensionMode(), getCurrentExtensionName())); + break; +} // END - switch -// +// [EOF] ?>