Перекидные ретро часы для MajorDoMo

Наверное каждый хоть раз смотрел фильм "День сурка", в котором показали офигенные перекидные часы-радио, игравшие каждое утро одну и ту же музыку. Такие часы довольно просто добавить в систему MajorDoMo на сцену или в меню управления. Ниже приведена подробная инструкция и приложены необходимые скрипты.

Добавлять будем в меню управления (размещение на сцене аналогично). Заходим в Панель управления/Объекты/Меню управления. В открывшемся окне заполняем необходимые поля:

  1. Название - придумываем название или называем как у меня "flip clock";
  2. Тип - выбираем "HTML-блок";
  3. Жмём кнопку "Добавить".

Перекидные ретро часы для MajorDoMo

  1. В поле "Данные" вставляем ниже приведённый код

Показать

Скрыть

<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

Жмём кнопку сохранить и выходим в раздела.

Раздел с часами появился в самом низу меню управления. Кнопками вверх/вниз устанавливаем раздел в нужную позицию. Я поднял часы в самый верх меню управления.

Перекидные ретро часы для MajorDoMo

Если обновить веб страничку Majordomo, то мы увидим новый раздел в меню, но он будет пустым. Для работы часов нехватает java скриптов.

Скачиваем внизу статьи архив js.zip и распаковываем его в папку. В архиве находятся три скрипта. Эти скрипты необходимо скопировать в папку js сервера любым удобным способом. На raspberry (в ОС Linux) папка js находиться тут /var/www/html/js/

Для копирования файлов на сервер, можно подключиться к нему удалённо по SAMBA протоколу (в винде в сетевом окружении).

Перекидные ретро часы для MajorDoMo

Можно в сервер вставить флэшку с файлами, подключиться к малинке по SSH и перекинуть их с помощью Midnight Commander (mc).

Перекидные ретро часы для MajorDoMo

Как вариант, к малинке можно удалённо подключиться по протоколу SFTP.

Перекидные ретро часы для MajorDoMo

В общем с закидыванием файлов проблем возникнуть не должно.

После этого достаточно обновить страницу MajorDoMo, и в меню управления появятся крутые винтажные перекидные часы.

mt_ignore Перекидные ретро часы для MajorDoMo

Необходимые java скрипты