Наверное каждый хоть раз смотрел фильм "День сурка", в котором показали офигенные перекидные часы-радио, игравшие каждое утро одну и ту же музыку. Такие часы довольно просто добавить в систему MajorDoMo на сцену или в меню управления. Ниже приведена подробная инструкция и приложены необходимые скрипты.
Добавлять будем в меню управления (размещение на сцене аналогично). Заходим в Панель управления/Объекты/Меню управления. В открывшемся окне заполняем необходимые поля:
- Название - придумываем название или называем как у меня "flip clock";
- Тип - выбираем "HTML-блок";
- Жмём кнопку "Добавить".
- В поле "Данные" вставляем ниже приведённый код
Показать
Скрыть
<style> @import url("https://fonts.googleapis.com/css?family=Droid+Sans+Mono"); * { box-sizing: border-box; } body { margin: 0; } #root { display: -webkit-box; display: -ms-flexbox; display: flex; /*position: relative;*/ width: 100%; min-height: 5vh; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; background-color: #2a2a2a; /*Фон*/ /* background-image: -webkit-linear-gradient(28deg, #FBAB7E 0%, #F7CE68 100%); background-image: linear-gradient(62deg, #FBAB7E 0%, #F7CE68 100%);*/ } header { display: -webkit-box; display: -ms-flexbox; display: flex; position: relative; } header h1 { font-family: "Droid Sans Mono", monospace; font-weight: lighter; text-transform: uppercase; letter-spacing: 0.1em; color: white; } .flipClock { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; width: 260px; /*Ширина часов*/ } .flipUnitContainer { display: block; position: relative; width: 76px; /*Ширина плитки*/ height: 76px; /*Высота плитки*/ -webkit-perspective-origin: 50% 50%; perspective-origin: 50% 50%; -webkit-perspective: 150px; perspective: 150px; background-color: white; border-radius: 3px; box-shadow: 0px 10px 10px -10px grey; } .upperCard, .lowerCard { display: -webkit-box; display: -ms-flexbox; display: flex; position: relative; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; width: 100%; height: 50%; overflow: hidden; border: 1px solid whitesmoke; } .upperCard span, .lowerCard span { font-size: 3em; /*Размер шрифта*/ font-family: "Droid Sans Mono", monospace; font-weight: lighter; color: #333333; } .upperCard { -webkit-box-align: end; -ms-flex-align: end; align-items: flex-end; border-bottom: 0.5px solid whitesmoke; border-top-left-radius: 3px; border-top-right-radius: 3px; } .upperCard span { -webkit-transform: translateY(50%); transform: translateY(50%); } .lowerCard { -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; border-top: 0.5px solid whitesmoke; border-bottom-left-radius: 3px; border-bottom-right-radius: 3px; } .lowerCard span { -webkit-transform: translateY(-50%); transform: translateY(-50%); } .flipCard { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; position: absolute; left: 0; width: 76px; height: 38px; overflow: hidden; -webkit-backface-visibility: hidden; backface-visibility: hidden; } .flipCard span { font-family: "Droid Sans Mono", monospace; font-size: 3em; /*Размер шрифта*/ font-weight: lighter; color: #333333; } .flipCard.unfold { top: 50%; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; -webkit-transform-origin: 50% 0%; transform-origin: 50% 0%; -webkit-transform: rotateX(180deg); transform: rotateX(180deg); background-color: white; border-bottom-left-radius: 3px; border-bottom-right-radius: 3px; border: 1px solid whitesmoke; border-top: 0.5px solid whitesmoke; } .flipCard.unfold span { -webkit-transform: translateY(-50%); transform: translateY(-50%); } .flipCard.fold { top: 0%; -webkit-box-align: end; -ms-flex-align: end; align-items: flex-end; -webkit-transform-origin: 50% 100%; transform-origin: 50% 100%; -webkit-transform: rotateX(0deg); transform: rotateX(0deg); background-color: white; border-top-left-radius: 3px; border-top-right-radius: 3px; border: 0.5px solid whitesmoke; border-bottom: 0.5px solid whitesmoke; } .flipCard.fold span { -webkit-transform: translateY(50%); transform: translateY(50%); } .fold { -webkit-animation: fold 0.6s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s 1 normal forwards; animation: fold 0.6s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s 1 normal forwards; -webkit-transform-style: preserve-3d; transform-style: preserve-3d; } .unfold { -webkit-animation: unfold 0.6s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s 1 normal forwards; animation: unfold 0.6s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s 1 normal forwards; -webkit-transform-style: preserve-3d; transform-style: preserve-3d; } @-webkit-keyframes fold { 0% { -webkit-transform: rotateX(0deg); transform: rotateX(0deg); } 100% { -webkit-transform: rotateX(-180deg); transform: rotateX(-180deg); } } @keyframes fold { 0% { -webkit-transform: rotateX(0deg); transform: rotateX(0deg); } 100% { -webkit-transform: rotateX(-180deg); transform: rotateX(-180deg); } } @-webkit-keyframes unfold { 0% { -webkit-transform: rotateX(180deg); transform: rotateX(180deg); } 100% { -webkit-transform: rotateX(0deg); transform: rotateX(0deg); } } @keyframes unfold { 0% { -webkit-transform: rotateX(180deg); transform: rotateX(180deg); } 100% { -webkit-transform: rotateX(0deg); transform: rotateX(0deg); } } </style> <div id="root"></div> <script src='js/react.min.js'></script> <script src='js/react-dom.min.js'></script> <script src="/js/flipclock.js"></script>
Должно получиться так
Жмём кнопку сохранить и выходим в раздела.
Раздел с часами появился в самом низу меню управления. Кнопками вверх/вниз устанавливаем раздел в нужную позицию. Я поднял часы в самый верх меню управления.
Если обновить веб страничку Majordomo, то мы увидим новый раздел в меню, но он будет пустым. Для работы часов нехватает java скриптов.
Скачиваем внизу статьи архив js.zip и распаковываем его в папку. В архиве находятся три скрипта. Эти скрипты необходимо скопировать в папку js сервера любым удобным способом. На raspberry (в ОС Linux) папка js находиться тут /var/www/html/js/
Для копирования файлов на сервер, можно подключиться к нему удалённо по SAMBA протоколу (в винде в сетевом окружении).
Можно в сервер вставить флэшку с файлами, подключиться к малинке по SSH и перекинуть их с помощью Midnight Commander (mc).
Как вариант, к малинке можно удалённо подключиться по протоколу SFTP.
В общем с закидыванием файлов проблем возникнуть не должно.
После этого достаточно обновить страницу MajorDoMo, и в меню управления появятся крутые винтажные перекидные часы.