forked from mirzaev/ff
		
	оптимизация генерация страниц и шутника
This commit is contained in:
		| @@ -15,57 +15,23 @@ use mirzaev\site\rules\controllers\core; | ||||
|  */ | ||||
| final class index_controller extends core | ||||
| { | ||||
|     /** | ||||
|      * Главная страница | ||||
|      * | ||||
|      * @param array $parameters Параметры запроса | ||||
|      */ | ||||
|     public function index(array $parameters = []): ?string | ||||
|     { | ||||
|         // Инициализация загружаемых категорий | ||||
|         $this->variables['include'] = [ | ||||
|             'head' => ['self'], | ||||
|             'body' => ['self'] | ||||
|         ]; | ||||
|   /** | ||||
|    * Главная страница | ||||
|    * | ||||
|    * @param array $parameters Параметры запроса | ||||
|    */ | ||||
|   public function index(array $parameters = []): ?string | ||||
|   { | ||||
|     // Инициализация шутника | ||||
|     $this->variables['troller'] = [ | ||||
|       'instasamka' => rand(1, 11), | ||||
|       'vk' => (bool) rand(0, 1), | ||||
|       'whatsapp' => (bool) rand(0, 1), | ||||
|       'iphone' => (bool) rand(0, 1), | ||||
|     ]; | ||||
|  | ||||
|         // Инициализация бегущей строки | ||||
|         $this->variables['hotline'] = [ | ||||
|             'id' => $this->variables['request']['id'] ?? 'hotline' | ||||
|         ]; | ||||
|  | ||||
|         // Инициализация параметров бегущей строки | ||||
|         $this->variables['hotline']['parameters'] = [ | ||||
|             // 'step' => 2 | ||||
|         ]; | ||||
|  | ||||
|         // Инициализация аттрибутов бегущей строки | ||||
|         $this->variables['hotline']['attributes'] = [ | ||||
|  | ||||
|         ]; | ||||
|  | ||||
|         // Инициализация элементов бегущей строки | ||||
|         $this->variables['hotline']['elements'] = [ | ||||
|             ['content' => '1'], | ||||
|             [ | ||||
|                 'tag' => 'article', | ||||
|                 'content' => '2' | ||||
|             ], | ||||
|             ['content' => '3'], | ||||
|             ['content' => '4'], | ||||
|             ['content' => '5'], | ||||
|             ['content' => '6'], | ||||
|             ['content' => '7'], | ||||
|             ['content' => '8'], | ||||
|             ['content' => '9'], | ||||
|             ['content' => '10'], | ||||
|             ['content' => '11'], | ||||
|             ['content' => '12'], | ||||
|             ['content' => '13'], | ||||
|             ['content' => '14'], | ||||
|             ['content' => '15'] | ||||
|         ]; | ||||
|  | ||||
|         // Генерация представления | ||||
|         return $this->view->render(DIRECTORY_SEPARATOR . 'index.html', $this->variables); | ||||
|     } | ||||
|     // Генерация представления | ||||
|     return $this->view->render(DIRECTORY_SEPARATOR . 'index.html', $this->variables); | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -20,24 +20,24 @@ class troller { | ||||
|     }, | ||||
|     start() { | ||||
|       // Отображение изображения
 | ||||
|       document.getElementById("what_image").classList.add("active"); | ||||
|       document.getElementById("troller_image_what").classList.add("active"); | ||||
| 
 | ||||
|         // Проигрывание звука
 | ||||
|         troller.what.play();  | ||||
|     }, | ||||
|     end() { | ||||
|       // Сокрытие изображения
 | ||||
|       document.getElementById("what_image").classList.remove("active"); | ||||
|       document.getElementById("troller_image_what").classList.remove("active"); | ||||
| 
 | ||||
|       // Остановка звука
 | ||||
|       document.getElementById("what_sound").pause(); | ||||
|       document.getElementById("troller_sound_what").pause(); | ||||
|     }, | ||||
|     single(event = "onmouseleave") { | ||||
|       if (typeof event === "string") { | ||||
|         // Получены обязательные входные параметры
 | ||||
| 
 | ||||
|         // Отображение изображения
 | ||||
|         document.getElementById("what_image").classList.add("active"); | ||||
|         document.getElementById("troller_image_what").classList.add("active"); | ||||
| 
 | ||||
|         // Проигрывание звука
 | ||||
|         troller.what.play();  | ||||
| @@ -51,7 +51,7 @@ class troller { | ||||
|     }, | ||||
|     play() { | ||||
|       // Инициализация элемента со звуком
 | ||||
|       const what_sound = document.getElementById("what_sound"); | ||||
|       const what_sound = document.getElementById("troller_sound_what"); | ||||
| 
 | ||||
|       // Воспроизведение звука
 | ||||
|       what_sound.currentTime = 0; | ||||
| @@ -61,7 +61,7 @@ class troller { | ||||
| 
 | ||||
|   static vk() { | ||||
|     setInterval(function () { | ||||
|       const sound = document.getElementById("sound_vk"); | ||||
|       const sound = document.getElementById("troller_sound_vk"); | ||||
| 
 | ||||
|       if (Math.random() > 0.95) { | ||||
|         // 5%
 | ||||
| @@ -75,7 +75,7 @@ class troller { | ||||
| 
 | ||||
|   static whatsapp() { | ||||
|     setInterval(function () { | ||||
|       const sound = document.getElementById("sound_whatsup"); | ||||
|       const sound = document.getElementById("troller_sound_whatsup"); | ||||
| 
 | ||||
|       if (Math.random() > 0.97) { | ||||
|         // 3%
 | ||||
| @@ -89,7 +89,7 @@ class troller { | ||||
| 
 | ||||
|   static iphone() { | ||||
|     setInterval(function () { | ||||
|       const sound = document.getElementById("sound_iphone"); | ||||
|       const sound = document.getElementById("troller_sound_iphone"); | ||||
| 
 | ||||
|       if (Math.random() > 0.98) { | ||||
|         // 2%
 | ||||
| @@ -102,9 +102,9 @@ class troller { | ||||
|   } | ||||
| 
 | ||||
|   static instasamka = { | ||||
|     play(track, time) { | ||||
|     play(time) { | ||||
|       // Инициализация элемента со звуком
 | ||||
|       const sound = document.querySelectorAll('[data-instasamka]')[track]; | ||||
|       const sound = document.getElementById("troller_sound_instasamka"); | ||||
| 
 | ||||
|       if (sound instanceof HTMLElement) { | ||||
|         // Найден звук
 | ||||
| @@ -112,34 +112,17 @@ class troller { | ||||
|         // Воспроизведение звука
 | ||||
|         sound.currentTime = time ?? Math.random() * 100; | ||||
|         sound.play(); | ||||
|       } else { | ||||
|         // Не найден звук (подразумевается)
 | ||||
|          | ||||
|         return; | ||||
|         console.log('[mirzaev] [troller] Не удалось найти песню инстасамки'); | ||||
|       } | ||||
| 
 | ||||
|       console.log('[mirzaev] [troller] Не удалось найти песню инстасамки под идентификатором ' + track); | ||||
| 
 | ||||
|       // Не найден звук (подразумевается)
 | ||||
|       troller.instasamka.play(1, time); | ||||
|     }, | ||||
|   }; | ||||
| } | ||||
| 
 | ||||
| troller.what.enable(); | ||||
| 
 | ||||
| if (Math.random() > 0.60) { | ||||
|   // 40%
 | ||||
| 
 | ||||
|   troller.vk(); | ||||
| } | ||||
| 
 | ||||
| if (Math.random() > 0.60) { | ||||
|   // 40%
 | ||||
| 
 | ||||
|   troller.whatsapp(); | ||||
| } | ||||
| 
 | ||||
| if (Math.random() > 0.60) { | ||||
|   // 40%
 | ||||
| 
 | ||||
|   troller.iphone(); | ||||
| } | ||||
| document.dispatchEvent( | ||||
|   new CustomEvent("troller.loaded", { | ||||
|     detail: { troller }, | ||||
|   }), | ||||
| ); | ||||
| @@ -1,20 +1,20 @@ | ||||
| {% extends "core.html" %} | ||||
|  | ||||
| {% use "core.html" with css as core_css, body as core_body, js as core_js, js_init as core_js_init %} | ||||
| {% use "trolling.html" with css as trolling_css, body as trolling_body, js as trolling_js %} | ||||
| {% use "troller.html" with css as troller_css, body as troller_body, js as troller_js, js_init as troller_js_init  %} | ||||
| {% use "popups/rules.html" with css as popup_rules_css, body as popup_rules_body %} | ||||
| {% use "header.html" with css as header_css, body as header_body, js as header_js, js_init as header_js_init %} | ||||
|  | ||||
| {% block css %} | ||||
| {{ block('core_css') }} | ||||
| {{ block('trolling_css') }} | ||||
| {{ block('troller_css') }} | ||||
| {{ block('popup_rules_css') }} | ||||
| {{ block('header_css') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block body %} | ||||
| {{ block('core_body') }} | ||||
| {{ block('trolling_body') }} | ||||
| {{ block('troller_body') }} | ||||
| {{ block('popup_rules_body') }} | ||||
| {{ block('header_body') }} | ||||
|  | ||||
| @@ -30,11 +30,12 @@ | ||||
|  | ||||
| {% block js %} | ||||
| {{ block('core_js') }} | ||||
| {{ block('trolling_js') }} | ||||
| {{ block('troller_js') }} | ||||
| {{ block('header_js') }} | ||||
| {% endblock %} | ||||
|  | ||||
| {% block js_init %} | ||||
| {{ block('core_js_init') }} | ||||
| {{ block('header_js_init') }} | ||||
| {{ block('troller_js_init') }} | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -14,7 +14,7 @@ | ||||
|     </ol> | ||||
|     <div class="row separated"> | ||||
|       <button | ||||
|         onclick="troller.instasamka.play(Math.round(Math.random() * 10)); this.parentElement.parentElement.parentElement.remove();">Прочитал</button> | ||||
|         onclick="troller.instasamka.play(); this.parentElement.parentElement.parentElement.remove();">Прочитал</button> | ||||
|       <button onclick="troller.what.play(); alert('ты идиот?'); this.disabled = true">Не прочитал</button> | ||||
|     </div> | ||||
|   </div> | ||||
|   | ||||
							
								
								
									
										57
									
								
								mirzaev/site/rules/system/views/troller.html
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										57
									
								
								mirzaev/site/rules/system/views/troller.html
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| {% block css %} | ||||
| <link rel="stylesheet" type="text/css" href="/css/troller.css" /> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block body %} | ||||
| <img id="troller_image_what" class="hide" src="/images/what.png" /> | ||||
| <audio id="troller_sound_what" class="hide" src="/sounds/what.mp3" controls></audio> | ||||
| {% if troller.vk %} | ||||
| <audio id="troller_sound_vk" class="hide" src="/sounds/vk.mp3" controls></audio> | ||||
| <script> | ||||
|   document.addEventListener('troller.loaded', function (e) { | ||||
|     // Загружен документ с классом шутника | ||||
|  | ||||
|     // Активация интервального воспроизведения звука сообщения ВКонтакте | ||||
|     e.detail.troller.vk(); | ||||
|   }); | ||||
| </script> | ||||
| {% endif %} | ||||
| {% if troller.whatsapp %} | ||||
| <audio id="troller_sound_whatsup" class="hide" src="/sounds/whatsup.mp3" controls></audio> | ||||
| <script> | ||||
|   document.addEventListener('troller.loaded', function (e) { | ||||
|     // Загружен документ с классом шутника | ||||
|  | ||||
|     // Активация интервального воспроизведения звука сообщения WhatsApp | ||||
|     e.detail.troller.whatsapp(); | ||||
|   }); | ||||
| </script> | ||||
| {% endif %} | ||||
| {% if troller.iphone %} | ||||
| <audio id="troller_sound_iphone" class="hide" src="/sounds/iphone.mp3" controls></audio> | ||||
| <script> | ||||
|   document.addEventListener('troller.loaded', function (e) { | ||||
|     // Загружен документ с классом шутника | ||||
|  | ||||
|     // Активация интервального воспроизведения звука сообщения iPhone | ||||
|     e.detail.troller.iphone(); | ||||
|   }); | ||||
| </script> | ||||
| {% endif %} | ||||
| <audio id="troller_sound_instasamka" class="hide" src="/sounds/instasamka/{{ troller.instasamka ?? 1 }}.mp3" preload="auto" loop="true"></audio> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block js %} | ||||
| <script src="/js/troller.js" defer></script> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block js_init %} | ||||
| <script> | ||||
|   document.addEventListener('troller.loaded', function (e) { | ||||
|     // Загружен документ с классом шутника | ||||
|  | ||||
|     // Активация изображения при потере фокуса с окна | ||||
|     e.detail.troller.what.enable(); | ||||
|   }); | ||||
| </script> | ||||
| {% endblock %} | ||||
| @@ -1,26 +0,0 @@ | ||||
| {% block css %} | ||||
| <link rel="stylesheet" type="text/css" href="/css/trolling.css" /> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block body %} | ||||
| <img id="what_image" class="hide" src="/images/what.png" /> | ||||
| <audio id="what_sound" class="hide" src="/sounds/what.mp3" controls></audio> | ||||
| <audio id="sound_vk" class="hide" src="/sounds/vk.mp3" controls></audio> | ||||
| <audio id="sound_whatsup" class="hide" src="/sounds/whatsup.mp3" controls></audio> | ||||
| <audio id="sound_iphone" class="hide" src="/sounds/iphone.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/1.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/2.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/3.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/4.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/5.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/6.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/7.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/8.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/9.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/10.mp3" controls></audio> | ||||
| <audio data-instasamka class="hide" src="/sounds/instasamka/11.mp3" controls></audio> | ||||
| {% endblock %} | ||||
|  | ||||
| {% block js %} | ||||
| <script src="/js/trolling.js" defer></script> | ||||
| {% endblock %} | ||||
		Reference in New Issue
	
	Block a user