From e0cb8d46f4e21dafff334f464359a49c88aabcbe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Paul=20Nicou=C3=A9?= Date: Thu, 28 Jul 2022 18:59:14 +0200 Subject: [PATCH] Add logo and edit general design --- public/assets/build/app.js | 64 +++++++--- public/assets/build/main.css | 136 ++++++++++++++++++--- public/assets/css/main.scss | 81 +++++++++--- public/assets/css/partials/animations.scss | 35 +++++- public/assets/css/partials/variables.scss | 6 +- public/assets/js/app.js | 62 +++++++--- site/controllers/exhibitions.php | 6 +- site/templates/exhibitions.twig | 13 +- 8 files changed, 330 insertions(+), 73 deletions(-) diff --git a/public/assets/build/app.js b/public/assets/build/app.js index 909d94d..e9132fb 100644 --- a/public/assets/build/app.js +++ b/public/assets/build/app.js @@ -8,42 +8,74 @@ var __webpack_exports__ = {}; // ---------------------------------------------------------------------------- // SIDEBAR ANIMATION const sidebar = document.querySelector('.sidebar'); -const sidebarNav = document.querySelector('.sidebar__nav'); -const sidebarNavLinks = sidebarNav.querySelectorAll('.sidebar__nav-link--internal'); // ---------------------------------------------------------------------------- -// UTILS +const sidebarNavLinks = document.querySelectorAll('.sidebar__nav-link--internal'); +const logoIcon = document.querySelector('.logo__icon'); +const exhibitionIframe = document.querySelector('.exhibition'); // ---------------------------------------------------------------------------- +// LOGIC // ---------------------------------------------------------------------------- -// Convert rem to pixels by getting font-size CSS property +// UTILS +// Enable CSS :active pseudo-class in Safari Mobile + +function enableActivePseudoClass() { + document.addEventListener("touchstart", function () {}, false); +} // Convert rem to pixels by getting font-size CSS property + function convertRemToPixels(rem) { let fontSize = parseFloat(window.getComputedStyle(document.body).getPropertyValue('font-size')); return rem * fontSize; -} // ---------------------------------------------------------------------------- -// LOGIC -// ---------------------------------------------------------------------------- -// SIDEBAR ANIMATION +} // SIDEBAR ANIMATION function slimDownSidebar() { - if (sidebar) { + if (sidebar && !sidebar.classList.contains('sidebar--slimmed')) { sidebar.classList.add('sidebar--slimmed'); } } -function slimDownSidebarOnClick() { - if (sidebarNavLinks.length > 0) { +function enableLogoIconRotation() { + if (logoIcon) { + if (logoIcon.classList.contains('logo__icon--vertical')) { + logoIcon.classList.add('logo__icon--rotate-vertical-left'); + } else { + logoIcon.classList.add('logo__icon--rotate-horizontal-bottom'); + } + } +} + +function disableLogoIconRotation() { + if (logoIcon) { + if (logoIcon.classList.contains('logo__icon--vertical')) { + logoIcon.classList.remove('logo__icon--rotate-vertical-left'); + } else { + logoIcon.classList.remove('logo__icon--rotate-horizontal-bottom'); + } + } +} + +function loadExhibitionIframe() { + if (sidebarNavLinks.length > 0 && exhibitionIframe) { for (let i = 0; i < sidebarNavLinks.length; i++) { - sidebarNavLinks[i].addEventListener('click', slimDownSidebar); + sidebarNavLinks[i].addEventListener('click', function (e) { + enableLogoIconRotation(); + exhibitionIframe.classList.remove('exhibition--visible'); + exhibitionIframe.addEventListener('load', function (e) { + slimDownSidebar(); + disableLogoIconRotation(); + exhibitionIframe.classList.add('exhibition--visible'); + }); + }); } } } // ---------------------------------------------------------------------------- // PROGRAM // ---------------------------------------------------------------------------- -// Enable CSS :active pseudo-class in Safari Mobile +// UTILS -document.addEventListener("touchstart", function () {}, false); // SIDEBAR ANIMATION +enableActivePseudoClass(); // SIDEBAR ANIMATION -slimDownSidebarOnClick(); +loadExhibitionIframe(); /******/ })() ; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBRUE7QUFFQSxNQUFNQSxPQUFPLEdBQUdDLFFBQVEsQ0FBQ0MsYUFBVCxDQUF1QixVQUF2QixDQUFoQjtBQUNBLE1BQU1DLFVBQVUsR0FBR0YsUUFBUSxDQUFDQyxhQUFULENBQXVCLGVBQXZCLENBQW5CO0FBQ0EsTUFBTUUsZUFBZSxHQUFHRCxVQUFVLENBQUNFLGdCQUFYLENBQTRCLDhCQUE1QixDQUF4QixFQUVBO0FBQ0E7QUFDQTtBQUVBOztBQUNBLFNBQVNDLGtCQUFULENBQTRCQyxHQUE1QixFQUFpQztFQUNoQyxJQUFJQyxRQUFRLEdBQUdDLFVBQVUsQ0FBQ0MsTUFBTSxDQUFDQyxnQkFBUCxDQUF3QlYsUUFBUSxDQUFDVyxJQUFqQyxFQUF1Q0MsZ0JBQXZDLENBQXdELFdBQXhELENBQUQsQ0FBekI7RUFDQSxPQUFPTixHQUFHLEdBQUdDLFFBQWI7QUFDQSxFQUVEO0FBQ0E7QUFDQTtBQUVBOzs7QUFFQSxTQUFTTSxlQUFULEdBQTJCO0VBQzFCLElBQUlkLE9BQUosRUFBYTtJQUNaQSxPQUFPLENBQUNlLFNBQVIsQ0FBa0JDLEdBQWxCLENBQXNCLGtCQUF0QjtFQUNBO0FBQ0Q7O0FBRUQsU0FBU0Msc0JBQVQsR0FBa0M7RUFDakMsSUFBSWIsZUFBZSxDQUFDYyxNQUFoQixHQUF5QixDQUE3QixFQUFnQztJQUMvQixLQUFLLElBQUlDLENBQUMsR0FBRyxDQUFiLEVBQWdCQSxDQUFDLEdBQUdmLGVBQWUsQ0FBQ2MsTUFBcEMsRUFBNENDLENBQUMsRUFBN0MsRUFBaUQ7TUFDaERmLGVBQWUsQ0FBQ2UsQ0FBRCxDQUFmLENBQW1CQyxnQkFBbkIsQ0FBb0MsT0FBcEMsRUFBNkNOLGVBQTdDO0lBQ0E7RUFDRDtBQUNELEVBRUQ7QUFDQTtBQUNBO0FBRUE7OztBQUNBYixRQUFRLENBQUNtQixnQkFBVCxDQUEwQixZQUExQixFQUF3QyxZQUFXLENBQUUsQ0FBckQsRUFBc0QsS0FBdEQsR0FFQTs7QUFFQUgsc0JBQXNCLEciLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9wdWJsaWMvYXNzZXRzL2pzL2FwcC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4vLyBEQVRBXG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5cbi8vIFNJREVCQVIgQU5JTUFUSU9OXG5cbmNvbnN0IHNpZGViYXIgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKCcuc2lkZWJhcicpO1xuY29uc3Qgc2lkZWJhck5hdiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJy5zaWRlYmFyX19uYXYnKTtcbmNvbnN0IHNpZGViYXJOYXZMaW5rcyA9IHNpZGViYXJOYXYucXVlcnlTZWxlY3RvckFsbCgnLnNpZGViYXJfX25hdi1saW5rLS1pbnRlcm5hbCcpO1xuXG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4vLyBVVElMU1xuLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuXG4vLyBDb252ZXJ0IHJlbSB0byBwaXhlbHMgYnkgZ2V0dGluZyBmb250LXNpemUgQ1NTIHByb3BlcnR5XG5mdW5jdGlvbiBjb252ZXJ0UmVtVG9QaXhlbHMocmVtKSB7XG5cdGxldCBmb250U2l6ZSA9IHBhcnNlRmxvYXQod2luZG93LmdldENvbXB1dGVkU3R5bGUoZG9jdW1lbnQuYm9keSkuZ2V0UHJvcGVydHlWYWx1ZSgnZm9udC1zaXplJykpO1xuXHRyZXR1cm4gcmVtICogZm9udFNpemU7XG59XG5cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbi8vIExPR0lDXG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5cbi8vIFNJREVCQVIgQU5JTUFUSU9OXG5cbmZ1bmN0aW9uIHNsaW1Eb3duU2lkZWJhcigpIHtcblx0aWYgKHNpZGViYXIpIHtcblx0XHRzaWRlYmFyLmNsYXNzTGlzdC5hZGQoJ3NpZGViYXItLXNsaW1tZWQnKTtcblx0fVxufVxuXG5mdW5jdGlvbiBzbGltRG93blNpZGViYXJPbkNsaWNrKCkge1xuXHRpZiAoc2lkZWJhck5hdkxpbmtzLmxlbmd0aCA+IDApIHtcblx0XHRmb3IgKGxldCBpID0gMDsgaSA8IHNpZGViYXJOYXZMaW5rcy5sZW5ndGg7IGkrKykge1xuXHRcdFx0c2lkZWJhck5hdkxpbmtzW2ldLmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgc2xpbURvd25TaWRlYmFyKTtcblx0XHR9XG5cdH1cbn1cblxuLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuLy8gUFJPR1JBTVxuLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuXG4vLyBFbmFibGUgQ1NTIDphY3RpdmUgcHNldWRvLWNsYXNzIGluIFNhZmFyaSBNb2JpbGVcbmRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoXCJ0b3VjaHN0YXJ0XCIsIGZ1bmN0aW9uKCkge30sZmFsc2UpO1xuXG4vLyBTSURFQkFSIEFOSU1BVElPTlxuXG5zbGltRG93blNpZGViYXJPbkNsaWNrKCk7XG4iXSwibmFtZXMiOlsic2lkZWJhciIsImRvY3VtZW50IiwicXVlcnlTZWxlY3RvciIsInNpZGViYXJOYXYiLCJzaWRlYmFyTmF2TGlua3MiLCJxdWVyeVNlbGVjdG9yQWxsIiwiY29udmVydFJlbVRvUGl4ZWxzIiwicmVtIiwiZm9udFNpemUiLCJwYXJzZUZsb2F0Iiwid2luZG93IiwiZ2V0Q29tcHV0ZWRTdHlsZSIsImJvZHkiLCJnZXRQcm9wZXJ0eVZhbHVlIiwic2xpbURvd25TaWRlYmFyIiwiY2xhc3NMaXN0IiwiYWRkIiwic2xpbURvd25TaWRlYmFyT25DbGljayIsImxlbmd0aCIsImkiLCJhZGRFdmVudExpc3RlbmVyIl0sInNvdXJjZVJvb3QiOiIifQ== \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBRUE7QUFFQSxNQUFNQSxPQUFPLEdBQUdDLFFBQVEsQ0FBQ0MsYUFBVCxDQUF1QixVQUF2QixDQUFoQjtBQUNBLE1BQU1DLGVBQWUsR0FBR0YsUUFBUSxDQUFDRyxnQkFBVCxDQUEwQiw4QkFBMUIsQ0FBeEI7QUFDQSxNQUFNQyxRQUFRLEdBQUdKLFFBQVEsQ0FBQ0MsYUFBVCxDQUF1QixhQUF2QixDQUFqQjtBQUNBLE1BQU1JLGdCQUFnQixHQUFHTCxRQUFRLENBQUNDLGFBQVQsQ0FBdUIsYUFBdkIsQ0FBekIsRUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUVBOztBQUNBLFNBQVNLLHVCQUFULEdBQW1DO0VBQ2xDTixRQUFRLENBQUNPLGdCQUFULENBQTBCLFlBQTFCLEVBQXdDLFlBQVcsQ0FBRSxDQUFyRCxFQUFzRCxLQUF0RDtBQUNBLEVBRUQ7OztBQUNBLFNBQVNDLGtCQUFULENBQTRCQyxHQUE1QixFQUFpQztFQUNoQyxJQUFJQyxRQUFRLEdBQUdDLFVBQVUsQ0FBQ0MsTUFBTSxDQUFDQyxnQkFBUCxDQUF3QmIsUUFBUSxDQUFDYyxJQUFqQyxFQUF1Q0MsZ0JBQXZDLENBQXdELFdBQXhELENBQUQsQ0FBekI7RUFDQSxPQUFPTixHQUFHLEdBQUdDLFFBQWI7QUFDQSxFQUVEOzs7QUFFQSxTQUFTTSxlQUFULEdBQTJCO0VBQzFCLElBQUlqQixPQUFPLElBQUksQ0FBQ0EsT0FBTyxDQUFDa0IsU0FBUixDQUFrQkMsUUFBbEIsQ0FBMkIsa0JBQTNCLENBQWhCLEVBQWdFO0lBQy9EbkIsT0FBTyxDQUFDa0IsU0FBUixDQUFrQkUsR0FBbEIsQ0FBc0Isa0JBQXRCO0VBQ0E7QUFDRDs7QUFHRCxTQUFTQyxzQkFBVCxHQUFrQztFQUNqQyxJQUFJaEIsUUFBSixFQUFjO0lBQ2IsSUFBSUEsUUFBUSxDQUFDYSxTQUFULENBQW1CQyxRQUFuQixDQUE0QixzQkFBNUIsQ0FBSixFQUF5RDtNQUN4RGQsUUFBUSxDQUFDYSxTQUFULENBQW1CRSxHQUFuQixDQUF1QixrQ0FBdkI7SUFDQSxDQUZELE1BRU87TUFDTmYsUUFBUSxDQUFDYSxTQUFULENBQW1CRSxHQUFuQixDQUF1QixzQ0FBdkI7SUFDQTtFQUNEO0FBQ0Q7O0FBRUQsU0FBU0UsdUJBQVQsR0FBbUM7RUFDbEMsSUFBSWpCLFFBQUosRUFBYztJQUNiLElBQUlBLFFBQVEsQ0FBQ2EsU0FBVCxDQUFtQkMsUUFBbkIsQ0FBNEIsc0JBQTVCLENBQUosRUFBeUQ7TUFDeERkLFFBQVEsQ0FBQ2EsU0FBVCxDQUFtQkssTUFBbkIsQ0FBMEIsa0NBQTFCO0lBQ0EsQ0FGRCxNQUVPO01BQ05sQixRQUFRLENBQUNhLFNBQVQsQ0FBbUJLLE1BQW5CLENBQTBCLHNDQUExQjtJQUNBO0VBQ0Q7QUFDRDs7QUFFRCxTQUFTQyxvQkFBVCxHQUFnQztFQUMvQixJQUFJckIsZUFBZSxDQUFDc0IsTUFBaEIsR0FBeUIsQ0FBekIsSUFBOEJuQixnQkFBbEMsRUFBb0Q7SUFDbkQsS0FBSyxJQUFJb0IsQ0FBQyxHQUFHLENBQWIsRUFBZ0JBLENBQUMsR0FBR3ZCLGVBQWUsQ0FBQ3NCLE1BQXBDLEVBQTRDQyxDQUFDLEVBQTdDLEVBQWlEO01BQ2hEdkIsZUFBZSxDQUFDdUIsQ0FBRCxDQUFmLENBQW1CbEIsZ0JBQW5CLENBQW9DLE9BQXBDLEVBQTZDLFVBQVNtQixDQUFULEVBQVk7UUFDeEROLHNCQUFzQjtRQUN0QmYsZ0JBQWdCLENBQUNZLFNBQWpCLENBQTJCSyxNQUEzQixDQUFrQyxxQkFBbEM7UUFDQWpCLGdCQUFnQixDQUFDRSxnQkFBakIsQ0FBa0MsTUFBbEMsRUFBMEMsVUFBU21CLENBQVQsRUFBWTtVQUNyRFYsZUFBZTtVQUNmSyx1QkFBdUI7VUFDdkJoQixnQkFBZ0IsQ0FBQ1ksU0FBakIsQ0FBMkJFLEdBQTNCLENBQStCLHFCQUEvQjtRQUNBLENBSkQ7TUFLQSxDQVJEO0lBU0E7RUFDRDtBQUNELEVBRUQ7QUFDQTtBQUNBO0FBRUE7OztBQUVBYix1QkFBdUIsSUFFdkI7O0FBRUFpQixvQkFBb0IsRyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3B1YmxpYy9hc3NldHMvanMvYXBwLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbi8vIERBVEFcbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuLy8gU0lERUJBUiBBTklNQVRJT05cblxuY29uc3Qgc2lkZWJhciA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJy5zaWRlYmFyJyk7XG5jb25zdCBzaWRlYmFyTmF2TGlua3MgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKCcuc2lkZWJhcl9fbmF2LWxpbmstLWludGVybmFsJyk7XG5jb25zdCBsb2dvSWNvbiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoJy5sb2dvX19pY29uJyk7XG5jb25zdCBleGhpYml0aW9uSWZyYW1lID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcignLmV4aGliaXRpb24nKTtcblxuLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuLy8gTE9HSUNcbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuLy8gVVRJTFNcblxuLy8gRW5hYmxlIENTUyA6YWN0aXZlIHBzZXVkby1jbGFzcyBpbiBTYWZhcmkgTW9iaWxlXG5mdW5jdGlvbiBlbmFibGVBY3RpdmVQc2V1ZG9DbGFzcygpIHtcblx0ZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihcInRvdWNoc3RhcnRcIiwgZnVuY3Rpb24oKSB7fSxmYWxzZSk7XG59XG5cbi8vIENvbnZlcnQgcmVtIHRvIHBpeGVscyBieSBnZXR0aW5nIGZvbnQtc2l6ZSBDU1MgcHJvcGVydHlcbmZ1bmN0aW9uIGNvbnZlcnRSZW1Ub1BpeGVscyhyZW0pIHtcblx0bGV0IGZvbnRTaXplID0gcGFyc2VGbG9hdCh3aW5kb3cuZ2V0Q29tcHV0ZWRTdHlsZShkb2N1bWVudC5ib2R5KS5nZXRQcm9wZXJ0eVZhbHVlKCdmb250LXNpemUnKSk7XG5cdHJldHVybiByZW0gKiBmb250U2l6ZTtcbn1cblxuLy8gU0lERUJBUiBBTklNQVRJT05cblxuZnVuY3Rpb24gc2xpbURvd25TaWRlYmFyKCkge1xuXHRpZiAoc2lkZWJhciAmJiAhc2lkZWJhci5jbGFzc0xpc3QuY29udGFpbnMoJ3NpZGViYXItLXNsaW1tZWQnKSkge1xuXHRcdHNpZGViYXIuY2xhc3NMaXN0LmFkZCgnc2lkZWJhci0tc2xpbW1lZCcpO1xuXHR9XG59XG5cblxuZnVuY3Rpb24gZW5hYmxlTG9nb0ljb25Sb3RhdGlvbigpIHtcblx0aWYgKGxvZ29JY29uKSB7XG5cdFx0aWYgKGxvZ29JY29uLmNsYXNzTGlzdC5jb250YWlucygnbG9nb19faWNvbi0tdmVydGljYWwnKSkge1xuXHRcdFx0bG9nb0ljb24uY2xhc3NMaXN0LmFkZCgnbG9nb19faWNvbi0tcm90YXRlLXZlcnRpY2FsLWxlZnQnKTtcblx0XHR9IGVsc2Uge1xuXHRcdFx0bG9nb0ljb24uY2xhc3NMaXN0LmFkZCgnbG9nb19faWNvbi0tcm90YXRlLWhvcml6b250YWwtYm90dG9tJyk7XG5cdFx0fVxuXHR9XG59XG5cbmZ1bmN0aW9uIGRpc2FibGVMb2dvSWNvblJvdGF0aW9uKCkge1xuXHRpZiAobG9nb0ljb24pIHtcblx0XHRpZiAobG9nb0ljb24uY2xhc3NMaXN0LmNvbnRhaW5zKCdsb2dvX19pY29uLS12ZXJ0aWNhbCcpKSB7XG5cdFx0XHRsb2dvSWNvbi5jbGFzc0xpc3QucmVtb3ZlKCdsb2dvX19pY29uLS1yb3RhdGUtdmVydGljYWwtbGVmdCcpO1xuXHRcdH0gZWxzZSB7XG5cdFx0XHRsb2dvSWNvbi5jbGFzc0xpc3QucmVtb3ZlKCdsb2dvX19pY29uLS1yb3RhdGUtaG9yaXpvbnRhbC1ib3R0b20nKTtcblx0XHR9XG5cdH1cbn1cblxuZnVuY3Rpb24gbG9hZEV4aGliaXRpb25JZnJhbWUoKSB7XG5cdGlmIChzaWRlYmFyTmF2TGlua3MubGVuZ3RoID4gMCAmJiBleGhpYml0aW9uSWZyYW1lKSB7XG5cdFx0Zm9yIChsZXQgaSA9IDA7IGkgPCBzaWRlYmFyTmF2TGlua3MubGVuZ3RoOyBpKyspIHtcblx0XHRcdHNpZGViYXJOYXZMaW5rc1tpXS5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsIGZ1bmN0aW9uKGUpIHtcblx0XHRcdFx0ZW5hYmxlTG9nb0ljb25Sb3RhdGlvbigpO1xuXHRcdFx0XHRleGhpYml0aW9uSWZyYW1lLmNsYXNzTGlzdC5yZW1vdmUoJ2V4aGliaXRpb24tLXZpc2libGUnKTtcblx0XHRcdFx0ZXhoaWJpdGlvbklmcmFtZS5hZGRFdmVudExpc3RlbmVyKCdsb2FkJywgZnVuY3Rpb24oZSkge1xuXHRcdFx0XHRcdHNsaW1Eb3duU2lkZWJhcigpO1xuXHRcdFx0XHRcdGRpc2FibGVMb2dvSWNvblJvdGF0aW9uKCk7XG5cdFx0XHRcdFx0ZXhoaWJpdGlvbklmcmFtZS5jbGFzc0xpc3QuYWRkKCdleGhpYml0aW9uLS12aXNpYmxlJyk7XG5cdFx0XHRcdH0pO1xuXHRcdFx0fSk7XG5cdFx0fVxuXHR9XG59XG5cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbi8vIFBST0dSQU1cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuLy8gVVRJTFNcblxuZW5hYmxlQWN0aXZlUHNldWRvQ2xhc3MoKTtcblxuLy8gU0lERUJBUiBBTklNQVRJT05cblxubG9hZEV4aGliaXRpb25JZnJhbWUoKTtcbiJdLCJuYW1lcyI6WyJzaWRlYmFyIiwiZG9jdW1lbnQiLCJxdWVyeVNlbGVjdG9yIiwic2lkZWJhck5hdkxpbmtzIiwicXVlcnlTZWxlY3RvckFsbCIsImxvZ29JY29uIiwiZXhoaWJpdGlvbklmcmFtZSIsImVuYWJsZUFjdGl2ZVBzZXVkb0NsYXNzIiwiYWRkRXZlbnRMaXN0ZW5lciIsImNvbnZlcnRSZW1Ub1BpeGVscyIsInJlbSIsImZvbnRTaXplIiwicGFyc2VGbG9hdCIsIndpbmRvdyIsImdldENvbXB1dGVkU3R5bGUiLCJib2R5IiwiZ2V0UHJvcGVydHlWYWx1ZSIsInNsaW1Eb3duU2lkZWJhciIsImNsYXNzTGlzdCIsImNvbnRhaW5zIiwiYWRkIiwiZW5hYmxlTG9nb0ljb25Sb3RhdGlvbiIsImRpc2FibGVMb2dvSWNvblJvdGF0aW9uIiwicmVtb3ZlIiwibG9hZEV4aGliaXRpb25JZnJhbWUiLCJsZW5ndGgiLCJpIiwiZSJdLCJzb3VyY2VSb290IjoiIn0= \ No newline at end of file diff --git a/public/assets/build/main.css b/public/assets/build/main.css index 28c10f9..b16e6af 100644 --- a/public/assets/build/main.css +++ b/public/assets/build/main.css @@ -144,11 +144,13 @@ th { --h2-line-height: calc(var(--h2-font-size) * 1.2); --h3-font-size: 1rem; --h3-line-height: calc(var(--h3-font-size) * 1.2); + --logo-width: 2rem; + --logo-height: 4rem; --icon-size: 1.75rem; --sidebar-vertical-padding: 1rem; --sidebar-horizontal-padding: 1rem; --black: #000; - --transparent-black: rgba(0, 0, 0, 0.4); + --transparent-black: rgba(0, 0, 0, 0.3); --white: #fff; --transparent-white: rgba(255, 255, 255, 0.9); --feldgrau: #4B6259; @@ -161,25 +163,83 @@ th { --h1-font-size: 1.8rem; --h2-font-size: 1.4rem; --h3-font-size: 1.2rem; + --logo-width: 6rem; + --logo-height: 3rem; --icon-size: 2.25rem; } } @-webkit-keyframes expand-outline { - from { + 0% { outline-offset: 0; } - to { + 100% { outline-offset: 2px; } } @keyframes expand-outline { - from { + 0% { outline-offset: 0; } - to { + 100% { outline-offset: 2px; } } +@-webkit-keyframes rotate-vertical-left { + 0% { + transform: rotateY(0); + transform-origin: left; + } + 50% { + transform: rotateY(180deg); + transform-origin: left; + } + 100% { + transform: rotateY(0); + transform-origin: left; + } +} +@keyframes rotate-vertical-left { + 0% { + transform: rotateY(0); + transform-origin: left; + } + 50% { + transform: rotateY(180deg); + transform-origin: left; + } + 100% { + transform: rotateY(0); + transform-origin: left; + } +} +@-webkit-keyframes rotate-horizontal-bottom { + 0% { + transform: rotateX(0); + transform-origin: bottom; + } + 50% { + transform: rotateX(180deg); + transform-origin: bottom; + } + 100% { + transform: rotateX(0); + transform-origin: bottom; + } +} +@keyframes rotate-horizontal-bottom { + 0% { + transform: rotateX(0); + transform-origin: bottom; + } + 50% { + transform: rotateX(180deg); + transform-origin: bottom; + } + 100% { + transform: rotateX(0); + transform-origin: bottom; + } +} body { font-family: var(--text-font-family); font-size: var(--text-font-size); @@ -242,31 +302,68 @@ body { overflow: hidden; } +.logo { + z-index: 2; + position: fixed; + top: 1rem; + right: 1.5rem; +} +.logo .logo__link { + width: var(--logo-width); + height: var(--logo-height); + display: flex; + justify-content: center; + align-items: center; +} +.logo .logo__icon { + width: 100%; + height: 100%; +} +.logo .logo__icon path:nth-child(1) { + stroke: var(--black); +} +.logo .logo__icon path:nth-child(2) { + stroke: var(--white); +} +.logo .logo__icon--rotate-vertical-left { + -webkit-animation: rotate-vertical-left 800ms ease-in-out infinite; + animation: rotate-vertical-left 800ms ease-in-out infinite; +} +.logo .logo__icon--rotate-horizontal-bottom { + -webkit-animation: rotate-horizontal-bottom 800ms ease-in-out infinite; + animation: rotate-horizontal-bottom 800ms ease-in-out infinite; +} + .sidebar { + z-index: 1; + overflow-y: auto; position: fixed; top: 0; bottom: 0; left: 0; + width: 100%; padding: var(--sidebar-vertical-padding) var(--sidebar-horizontal-padding); - overflow-y: auto; - background-color: var(--transparent-white); + display: flex; + flex-direction: column; + justify-content: space-between; + align-items: flex-start; + background-color: var(--white); transition: background-color 400ms ease-in-out; } -.sidebar .sidebar__nav-item { - width: 97vw; - transition: width 400ms ease-in-out; +.sidebar .sidebar__nav { + max-width: 100%; } .sidebar .sidebar__nav-item + .sidebar__nav-item { - margin: 0.75rem 0 0 0; + margin: 0.5rem 0 0 0; } .sidebar .sidebar__nav-link { display: inline-block; - max-width: 100vw; + max-width: 100%; overflow-x: hidden; white-space: nowrap; text-overflow: ellipsis; color: var(--black); - transition: max-width 400ms ease-in-out, color 400ms ease-in-out; + transition: color 400ms ease-in-out; } .sidebar .sidebar__social { display: flex; @@ -291,13 +388,10 @@ body { transition: fill 400ms ease-in-out; } .sidebar--slimmed { + width: 15%; background-color: transparent; } -.sidebar--slimmed .sidebar__nav-item { - width: 15vw; -} .sidebar--slimmed .sidebar__nav-link { - max-width: 15vw; color: var(--transparent-black); } .sidebar--slimmed .sidebar__instagram-icon, @@ -321,8 +415,14 @@ body { } .exhibition { + opacity: 0; width: 100%; height: 100%; + padding: 0 0 0 15%; + transition: opacity 400ms ease-in-out; +} +.exhibition--visible { + opacity: 1; } -/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.css","mappings":";;;AAAA;;8EAAA;AAIA;;;;;;;;;;;;;;;;;;;;;;;EAuBC;EACA;ACAD;;ADGA;;;;;;EAMC;EACA;ACAD;;ADGA;EACC;ACAD;;ADGA;;;EAGC;ACAD;;ADGA;EACC;ACAD;;ADGA;EACC;ACAD;;ADGA;;EAEC;EACA;ACAD;;ADGA;EACC;ACAD;;ADGA;EACC;EACA;ACAD;;ADGA;;EAEC;ACAD;;ACtEA;EACC;EACA;EACA;EACA;ADyED;ACtEA;EACC;EACA;EACA;EACA;ADwED;ACrEA;EACC;EACA;EACA;EACA;ADuED;ACpEA;EACC;EACA;EACA;EACA;ADsED;ACnEA;EACC;EACA;EACA;EACA;ADqED;AClEA;EACC;EACA;EACA;EACA;ADoED;ACjEA;EACC;EACA;EACA;EACA;ADmED;AChEA;EACC;EACA;EACA;EACA;ADkED;AEzHA;EAIC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAIA;EACA;EACA;EAIA;EACA;EACA;EACA;EACA;AFkHD;;AE1GA;EAEC;IAIC;IACA;IACA;IACA;IACA;IAIA;EFsGA;AACF;AG9JA;EACC;IACC;EHgKA;EG9JD;IACC;EHgKA;AACF;AGtKA;EACC;IACC;EHgKA;EG9JD;IACC;EHgKA;AACF;AI/JA;EACC;EACA;EACA;EACA;EACA;AJiKD;;AI9JA;EACC;EACA;EACA;AJiKD;;AI9JA;EACC;EACA;EACA;EACA;AJiKD;;AI9JA;EACC;EACA;EACA;EACA;AJiKD;;AI9JA;EACC;AJiKD;;AI9JA;EACC;AJiKD;;AI9JA;EACC;AJiKD;;AI5JA;EACC;EACA;EACA;EAAA;EAAA;AJ+JD;AI7JC;EAGC;AJ6JF;AI1JC;EACC;EACA;EACA;UAAA;AJ4JF;;AItJA;EACC;EACA;AJyJD;;AIhJA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AJmJD;AIjJC;EACC;EACA;AJmJF;AIjJE;EACC;AJmJH;AI/IC;EACC;EACA;EACA;EACA;EACA;EACA;EACA,gEACC;AJgJH;AI5IC;EACC;EACA;EACA;AJ8IF;AI3IC;EACC;EACA;EACA;EACA;EACA;AJ6IF;AI3IE;EACC;AJ6IH;AIzIC;;EAEC;EACA;EACA;EACA;AJ2IF;AIxIC;EACC;AJ0IF;AIxIE;EACC;AJ0IH;AIvIE;EACC;EACA;AJyIH;AItIE;;EAEC;AJwIH;AIrIE;EACC;AJuIH;AIpIG;EACC;AJsIJ;AInIG;;EAEC;AJqIJ;;AIxHA;EACC;EACA;AJ2HD;;AIxHA;EACC;EACA;AJ2HD,C","sources":["webpack:///./public/assets/css/utils/minireset.css","webpack:///../../../../Donn%C3%A9es/Programmation/Projets/julienmonnerie/public/assets/css/main.scss","webpack:///./public/assets/css/partials/fonts.scss","webpack:///./public/assets/css/partials/variables.scss","webpack:///./public/assets/css/partials/animations.scss","webpack:///./public/assets/css/main.scss"],"sourcesContent":["/* ----------------------------------------------------------------------------\nMINIRESET V0.0.6\n---------------------------------------------------------------------------- */\n\nhtml,\nbody,\np,\nol,\nul,\nli,\ndl,\ndt,\ndd,\nblockquote,\nfigure,\nfieldset,\nlegend,\ntextarea,\npre,\niframe,\nhr,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n\tmargin: 0;\n\tpadding: 0;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n\tfont-size: 100%;\n\tfont-weight: normal;\n}\n\nul {\n\tlist-style: none;\n}\n\nbutton,\ninput,\nselect {\n\tmargin: 0;\n}\n\nhtml {\n\tbox-sizing: border-box;\n}\n\n*, *::before, *::after {\n\tbox-sizing: inherit;\n}\n\nimg,\nvideo {\n\theight: auto;\n\tmax-width: 100%;\n}\n\niframe {\n\tborder: 0;\n}\n\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}\n\ntd,\nth {\n\tpadding: 0;\n}\n","/* ----------------------------------------------------------------------------\nMINIRESET V0.0.6\n---------------------------------------------------------------------------- */\nhtml,\nbody,\np,\nol,\nul,\nli,\ndl,\ndt,\ndd,\nblockquote,\nfigure,\nfieldset,\nlegend,\ntextarea,\npre,\niframe,\nhr,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n  margin: 0;\n  padding: 0;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n  font-size: 100%;\n  font-weight: normal;\n}\n\nul {\n  list-style: none;\n}\n\nbutton,\ninput,\nselect {\n  margin: 0;\n}\n\nhtml {\n  box-sizing: border-box;\n}\n\n*, *::before, *::after {\n  box-sizing: inherit;\n}\n\nimg,\nvideo {\n  height: auto;\n  max-width: 100%;\n}\n\niframe {\n  border: 0;\n}\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\ntd,\nth {\n  padding: 0;\n}\n\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Regular.ttf) format(\"truetype\");\n  font-weight: 400;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Italic.ttf) format(\"truetype\");\n  font-weight: 400;\n  font-style: italic;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Medium.ttf) format(\"truetype\");\n  font-weight: 500;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-MediumItalic.ttf) format(\"truetype\");\n  font-weight: 500;\n  font-style: italic;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-SemiBold.ttf) format(\"truetype\");\n  font-weight: 600;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-SemiBoldItalic.ttf) format(\"truetype\");\n  font-weight: 600;\n  font-style: italic;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Bold.ttf) format(\"truetype\");\n  font-weight: 700;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-BoldItalic.ttf) format(\"truetype\");\n  font-weight: 700;\n  font-style: italic;\n}\n:root {\n  --text-font-family: Helvetica, sans-serif;\n  --title-font-family: Helvetica, sans-serif;\n  --regular-font-weight: 400;\n  --medium-font-weight: 500;\n  --semi-bold-font-weight: 600;\n  --bold-font-weight: 700;\n  --text-font-size: 0.8rem;\n  --text-line-height: calc(var(--text-font-size) * 1.2);\n  --footnote-font-size: 0.6rem;\n  --footnote-line-height: calc(var(--footnote-font-size) * 1.2);\n  --h1-font-size: 1.6rem;\n  --h1-line-height: calc(var(--h1-font-size) * 1.2);\n  --h2-font-size: 1.2rem;\n  --h2-line-height: calc(var(--h2-font-size) * 1.2);\n  --h3-font-size: 1rem;\n  --h3-line-height: calc(var(--h3-font-size) * 1.2);\n  --icon-size: 1.75rem;\n  --sidebar-vertical-padding: 1rem;\n  --sidebar-horizontal-padding: 1rem;\n  --black: #000;\n  --transparent-black: rgba(0, 0, 0, 0.4);\n  --white: #fff;\n  --transparent-white: rgba(255, 255, 255, 0.9);\n  --feldgrau: #4B6259;\n}\n\n@media screen and (min-width: 48rem) {\n  :root {\n    --text-font-size: 1rem;\n    --footnote-font-size: 0.8rem;\n    --h1-font-size: 1.8rem;\n    --h2-font-size: 1.4rem;\n    --h3-font-size: 1.2rem;\n    --icon-size: 2.25rem;\n  }\n}\n@keyframes expand-outline {\n  from {\n    outline-offset: 0;\n  }\n  to {\n    outline-offset: 2px;\n  }\n}\nbody {\n  font-family: var(--text-font-family);\n  font-size: var(--text-font-size);\n  line-height: var(--text-line-height);\n  color: var(--black);\n  background-color: var(--white);\n}\n\nh1 {\n  font-family: var(--title-font-family);\n  font-size: var(--h1-font-size);\n  line-height: var(--h1-line-height);\n}\n\nh2 {\n  font-family: var(--text-font-family);\n  font-size: var(--h2-font-size);\n  line-height: var(--h2-line-height);\n  margin: 0 0 4rem 0;\n}\n\nh3 {\n  font-family: var(--text-font-family);\n  font-size: var(--h3-font-size);\n  line-height: var(--h3-line-height);\n  margin: 2rem 0 1rem 0;\n}\n\np {\n  text-align: justify;\n}\n\nstrong {\n  font-weight: var(--bold-font-weight);\n}\n\nem {\n  font-style: italic;\n}\n\na {\n  color: var(--black);\n  text-decoration: none;\n  transition: text-decoration 200ms ease-in-out;\n}\na:hover, a:focus, a:active {\n  text-decoration: underline;\n}\na:focus-visible {\n  outline: 1px dashed var(--black);\n  outline-offset: 2px;\n  animation: expand-outline 200ms ease-in-out;\n}\n\nbody {\n  min-height: 100vh;\n  overflow: hidden;\n}\n\n.sidebar {\n  position: fixed;\n  top: 0;\n  bottom: 0;\n  left: 0;\n  padding: var(--sidebar-vertical-padding) var(--sidebar-horizontal-padding);\n  overflow-y: auto;\n  background-color: var(--transparent-white);\n  transition: background-color 400ms ease-in-out;\n}\n.sidebar .sidebar__nav-item {\n  width: 97vw;\n  transition: width 400ms ease-in-out;\n}\n.sidebar .sidebar__nav-item + .sidebar__nav-item {\n  margin: 0.75rem 0 0 0;\n}\n.sidebar .sidebar__nav-link {\n  display: inline-block;\n  max-width: 100vw;\n  overflow-x: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  color: var(--black);\n  transition: max-width 400ms ease-in-out, color 400ms ease-in-out;\n}\n.sidebar .sidebar__social {\n  display: flex;\n  align-items: center;\n  margin: 1rem 0 0 0;\n}\n.sidebar .sidebar__social-link {\n  width: var(--icon-size);\n  height: var(--icon-size);\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n.sidebar .sidebar__social-link + .sidebar__social-link {\n  margin: 0 0 0 1rem;\n}\n.sidebar .sidebar__instagram-icon,\n.sidebar .sidebar__email-icon {\n  width: 100%;\n  height: 100%;\n  fill: var(--black);\n  transition: fill 400ms ease-in-out;\n}\n.sidebar--slimmed {\n  background-color: transparent;\n}\n.sidebar--slimmed .sidebar__nav-item {\n  width: 15vw;\n}\n.sidebar--slimmed .sidebar__nav-link {\n  max-width: 15vw;\n  color: var(--transparent-black);\n}\n.sidebar--slimmed .sidebar__instagram-icon,\n.sidebar--slimmed .sidebar__email-icon {\n  fill: var(--transparent-black);\n}\n.sidebar--slimmed:hover {\n  background-color: var(--transparent-white);\n}\n.sidebar--slimmed:hover .sidebar__nav-link {\n  color: var(--black);\n}\n.sidebar--slimmed:hover .sidebar__instagram-icon,\n.sidebar--slimmed:hover .sidebar__email-icon {\n  fill: var(--black);\n}\n\n.exhibition-section {\n  width: 100vw;\n  height: 100vh;\n}\n\n.exhibition {\n  width: 100%;\n  height: 100%;\n}","// ----------------------------------------------------------------------------\n// FONTS\n// ----------------------------------------------------------------------------\n\n// Open Sans\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Regular.ttf) format('truetype');\n\tfont-weight: 400;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Italic.ttf) format('truetype');\n\tfont-weight: 400;\n\tfont-style: italic;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Medium.ttf) format('truetype');\n\tfont-weight: 500;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-MediumItalic.ttf) format('truetype');\n\tfont-weight: 500;\n\tfont-style: italic;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-SemiBold.ttf) format('truetype');\n\tfont-weight: 600;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-SemiBoldItalic.ttf) format('truetype');\n\tfont-weight: 600;\n\tfont-style: italic;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Bold.ttf) format('truetype');\n\tfont-weight: 700;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-BoldItalic.ttf) format('truetype');\n\tfont-weight: 700;\n\tfont-style: italic;\n}\n","// ----------------------------------------------------------------------------\n// VARIABLES\n// ----------------------------------------------------------------------------\n\n:root {\n\n\t// Fonts\n\n\t--text-font-family: Helvetica, sans-serif;\n\t--title-font-family: Helvetica, sans-serif;\n\t--regular-font-weight: 400;\n\t--medium-font-weight: 500;\n\t--semi-bold-font-weight: 600;\n\t--bold-font-weight: 700;\n\t--text-font-size: 0.8rem;\n\t--text-line-height: calc(var(--text-font-size) * 1.2);\n\t--footnote-font-size: 0.6rem;\n\t--footnote-line-height: calc(var(--footnote-font-size) * 1.2);\n\t--h1-font-size: 1.6rem;\n\t--h1-line-height: calc(var(--h1-font-size) * 1.2);\n\t--h2-font-size: 1.2rem;\n\t--h2-line-height: calc(var(--h2-font-size) * 1.2);\n\t--h3-font-size: 1rem;\n\t--h3-line-height: calc(var(--h3-font-size) * 1.2);\n\n\t// Dimensions\n\n\t--icon-size: 1.75rem;\n\t--sidebar-vertical-padding: 1rem;\n\t--sidebar-horizontal-padding: 1rem;\n\n\t// Colors\n\n\t--black: #000;\n\t--transparent-black: rgba(0, 0, 0, 0.4);\n\t--white: #fff;\n\t--transparent-white: rgba(255, 255, 255, 0.9);\n\t--feldgrau: #4B6259;\n}\n\n// Media queries\n\n$tablet-media-query: 48rem;\n$desktop-media-query: 62rem;\n\n@media screen and (min-width: $tablet-media-query) {\n\n\t:root {\n\n\t\t// Fonts\n\n\t\t--text-font-size: 1rem;\n\t\t--footnote-font-size: 0.8rem;\n\t\t--h1-font-size: 1.8rem;\n\t\t--h2-font-size: 1.4rem;\n\t\t--h3-font-size: 1.2rem;\n\n\t\t// Dimensions\n\n\t\t--icon-size: 2.25rem;\n\t}\n}\n","// ----------------------------------------------------------------------------\n// ANIMATIONS\n// ----------------------------------------------------------------------------\n\n@keyframes expand-outline {\n\tfrom {\n\t\toutline-offset: 0;\n\t}\n\tto {\n\t\toutline-offset: 2px;\n\t}\n}\n","@use 'utils/minireset';\n@use 'partials/fonts';\n@use 'partials/variables' as *;\n@use 'partials/animations';\n\n// ----------------------------------------------------------------------------\n// GENERALITIES\n// ----------------------------------------------------------------------------\n\n// Fonts and colors\n\nbody {\n\tfont-family: var(--text-font-family);\n\tfont-size: var(--text-font-size);\n\tline-height: var(--text-line-height);\n\tcolor: var(--black);\n\tbackground-color: var(--white);\n}\n\nh1 {\n\tfont-family: var(--title-font-family);\n\tfont-size: var(--h1-font-size);\n\tline-height: var(--h1-line-height);\n}\n\nh2 {\n\tfont-family: var(--text-font-family);\n\tfont-size: var(--h2-font-size);\n\tline-height: var(--h2-line-height);\n\tmargin: 0 0 4rem 0;\n}\n\nh3 {\n\tfont-family: var(--text-font-family);\n\tfont-size: var(--h3-font-size);\n\tline-height: var(--h3-line-height);\n\tmargin: 2rem 0 1rem 0;\n}\n\np {\n\ttext-align: justify;\n}\n\nstrong {\n\tfont-weight: var(--bold-font-weight);\n}\n\nem {\n\tfont-style: italic;\n}\n\n// Link style\n\na {\n\tcolor: var(--black);\n\ttext-decoration: none;\n\ttransition: text-decoration 200ms ease-in-out;\n\n\t&:hover,\n\t&:focus,\n\t&:active {\n\t\ttext-decoration: underline;\n\t}\n\n\t&:focus-visible {\n\t\toutline: 1px dashed var(--black);\n\t\toutline-offset: 2px;\n\t\tanimation: expand-outline 200ms ease-in-out;\n\t}\n}\n\n// General layout\n\nbody {\n\tmin-height: 100vh;\n\toverflow: hidden;\n}\n\n// ----------------------------------------------------------------------------\n// HEADER\n// ----------------------------------------------------------------------------\n\n// Sidebar\n\n.sidebar {\n\tposition: fixed;\n\ttop: 0;\n\tbottom: 0;\n\tleft: 0;\n\tpadding: var(--sidebar-vertical-padding) var(--sidebar-horizontal-padding);\n\toverflow-y: auto;\n\tbackground-color: var(--transparent-white);\n\ttransition: background-color 400ms ease-in-out;\n\n\t.sidebar__nav-item {\n\t\twidth: 97vw;\n\t\ttransition: width 400ms ease-in-out;\n\n\t\t+ .sidebar__nav-item {\n\t\t\tmargin: 0.75rem 0 0 0;\n\t\t}\n\t}\n\n\t.sidebar__nav-link {\n\t\tdisplay: inline-block;\n\t\tmax-width: 100vw;\n\t\toverflow-x: hidden;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\tcolor: var(--black);\n\t\ttransition:\n\t\t\tmax-width 400ms ease-in-out,\n\t\t\tcolor 400ms ease-in-out;\n\t}\n\n\t.sidebar__social {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tmargin: 1rem 0 0 0;\n\t}\n\n\t.sidebar__social-link {\n\t\twidth: var(--icon-size);\n\t\theight: var(--icon-size);\n\t\tdisplay: flex;\n\t\tjustify-content: center;\n\t\talign-items: center;\n\n\t\t+ .sidebar__social-link {\n\t\t\tmargin: 0 0 0 1rem;\n\t\t}\n\t}\n\n\t.sidebar__instagram-icon,\n\t.sidebar__email-icon {\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\tfill: var(--black);\n\t\ttransition: fill 400ms ease-in-out;\n\t}\n\n\t&--slimmed {\n\t\tbackground-color: transparent;\n\n\t\t.sidebar__nav-item {\n\t\t\twidth: 15vw;\n\t\t}\n\n\t\t.sidebar__nav-link {\n\t\t\tmax-width: 15vw;\n\t\t\tcolor: var(--transparent-black);\n\t\t}\n\n\t\t.sidebar__instagram-icon,\n\t\t.sidebar__email-icon {\n\t\t\tfill: var(--transparent-black);\n\t\t}\n\n\t\t&:hover {\n\t\t\tbackground-color: var(--transparent-white);\n\n\t\t\t\t\n\t\t\t.sidebar__nav-link {\n\t\t\t\tcolor: var(--black);\n\t\t\t}\n\n\t\t\t.sidebar__instagram-icon,\n\t\t\t.sidebar__email-icon {\n\t\t\t\tfill: var(--black);\n\t\t\t}\n\t\t}\n\n\t}\n}\n\n// ----------------------------------------------------------------------------\n// MAIN\n// ----------------------------------------------------------------------------\n\n// Exhibition section\n\n.exhibition-section {\n\twidth: 100vw;\n\theight: 100vh;\n}\n\n.exhibition {\n\twidth: 100%;\n\theight: 100%;\n}\n\n// ----------------------------------------------------------------------------\n// FOOTER\n// ----------------------------------------------------------------------------\n\n// Footer bar\n"],"names":[],"sourceRoot":""}*/ \ No newline at end of file +/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.css","mappings":";;;AAAA;;8EAAA;AAIA;;;;;;;;;;;;;;;;;;;;;;;EAuBC;EACA;ACAD;;ADGA;;;;;;EAMC;EACA;ACAD;;ADGA;EACC;ACAD;;ADGA;;;EAGC;ACAD;;ADGA;EACC;ACAD;;ADGA;EACC;ACAD;;ADGA;;EAEC;EACA;ACAD;;ADGA;EACC;ACAD;;ADGA;EACC;EACA;ACAD;;ADGA;;EAEC;ACAD;;ACtEA;EACC;EACA;EACA;EACA;ADyED;ACtEA;EACC;EACA;EACA;EACA;ADwED;ACrEA;EACC;EACA;EACA;EACA;ADuED;ACpEA;EACC;EACA;EACA;EACA;ADsED;ACnEA;EACC;EACA;EACA;EACA;ADqED;AClEA;EACC;EACA;EACA;EACA;ADoED;ACjEA;EACC;EACA;EACA;EACA;ADmED;AChEA;EACC;EACA;EACA;EACA;ADkED;AEzHA;EAIC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAIA;EACA;EACA;EACA;EACA;EAIA;EACA;EACA;EACA;EACA;AFkHD;;AE1GA;EAEC;IAIC;IACA;IACA;IACA;IACA;IAIA;IACA;IACA;EFsGA;AACF;AGlKA;EACC;IACC;EHoKA;EGlKD;IACC;EHoKA;AACF;AG1KA;EACC;IACC;EHoKA;EGlKD;IACC;EHoKA;AACF;AGjKA;EACC;IACC;IACA;EHmKA;EGjKD;IACC;IACA;EHmKA;EGjKD;IACC;IACA;EHmKA;AACF;AG/KA;EACC;IACC;IACA;EHmKA;EGjKD;IACC;IACA;EHmKA;EGjKD;IACC;IACA;EHmKA;AACF;AGhKA;EACC;IACC;IACA;EHkKA;EGhKD;IACC;IACA;EHkKA;EGhKD;IACC;IACA;EHkKA;AACF;AG9KA;EACC;IACC;IACA;EHkKA;EGhKD;IACC;IACA;EHkKA;EGhKD;IACC;IACA;EHkKA;AACF;AI/LA;EACC;EACA;EACA;EACA;EACA;AJiMD;;AI9LA;EACC;EACA;EACA;AJiMD;;AI9LA;EACC;EACA;EACA;EACA;AJiMD;;AI9LA;EACC;EACA;EACA;EACA;AJiMD;;AI9LA;EACC;AJiMD;;AI9LA;EACC;AJiMD;;AI9LA;EACC;AJiMD;;AI5LA;EACC;EACA;EACA;EAAA;EAAA;AJ+LD;AI7LC;EAGC;AJ6LF;AI1LC;EACC;EACA;EACA;UAAA;AJ4LF;;AItLA;EACC;EACA;AJyLD;;AIhLA;EACC;EACA;EACA;EACA;AJmLD;AIjLC;EACC;EACA;EACA;EACA;EACA;AJmLF;AIhLC;EACC;EACA;AJkLF;AIhLE;EACC;AJkLH;AI/KE;EACC;AJiLH;AI9KE;EACC;UAAA;AJgLH;AI7KE;EACC;UAAA;AJ+KH;;AIxKA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AJ2KD;AIzKC;EACC;AJ2KF;AItKE;EACC;AJwKH;AIpKC;EACC;EACA;EACA;EACA;EACA;EACA;EACA;AJsKF;AInKC;EACC;EACA;EACA;AJqKF;AIlKC;EACC;EACA;EACA;EACA;EACA;AJoKF;AIlKE;EACC;AJoKH;AIhKC;;EAEC;EACA;EACA;EACA;AJkKF;AI/JC;EACC;EACA;AJiKF;AI/JE;EACC;AJiKH;AI9JE;;EAEC;AJgKH;AI7JE;EACC;AJ+JH;AI5JG;EACC;AJ8JJ;AI3JG;;EAEC;AJ6JJ;;AIhJA;EACC;EACA;AJmJD;;AIhJA;EACC;EACA;EACA;EACA;EACA;AJmJD;AIjJC;EACC;AJmJF,C","sources":["webpack:///./public/assets/css/utils/minireset.css","webpack:///../../../../Donn%C3%A9es/Programmation/Projets/julienmonnerie/public/assets/css/main.scss","webpack:///./public/assets/css/partials/fonts.scss","webpack:///./public/assets/css/partials/variables.scss","webpack:///./public/assets/css/partials/animations.scss","webpack:///./public/assets/css/main.scss"],"sourcesContent":["/* ----------------------------------------------------------------------------\nMINIRESET V0.0.6\n---------------------------------------------------------------------------- */\n\nhtml,\nbody,\np,\nol,\nul,\nli,\ndl,\ndt,\ndd,\nblockquote,\nfigure,\nfieldset,\nlegend,\ntextarea,\npre,\niframe,\nhr,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n\tmargin: 0;\n\tpadding: 0;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n\tfont-size: 100%;\n\tfont-weight: normal;\n}\n\nul {\n\tlist-style: none;\n}\n\nbutton,\ninput,\nselect {\n\tmargin: 0;\n}\n\nhtml {\n\tbox-sizing: border-box;\n}\n\n*, *::before, *::after {\n\tbox-sizing: inherit;\n}\n\nimg,\nvideo {\n\theight: auto;\n\tmax-width: 100%;\n}\n\niframe {\n\tborder: 0;\n}\n\ntable {\n\tborder-collapse: collapse;\n\tborder-spacing: 0;\n}\n\ntd,\nth {\n\tpadding: 0;\n}\n","/* ----------------------------------------------------------------------------\nMINIRESET V0.0.6\n---------------------------------------------------------------------------- */\nhtml,\nbody,\np,\nol,\nul,\nli,\ndl,\ndt,\ndd,\nblockquote,\nfigure,\nfieldset,\nlegend,\ntextarea,\npre,\niframe,\nhr,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n  margin: 0;\n  padding: 0;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\n  font-size: 100%;\n  font-weight: normal;\n}\n\nul {\n  list-style: none;\n}\n\nbutton,\ninput,\nselect {\n  margin: 0;\n}\n\nhtml {\n  box-sizing: border-box;\n}\n\n*, *::before, *::after {\n  box-sizing: inherit;\n}\n\nimg,\nvideo {\n  height: auto;\n  max-width: 100%;\n}\n\niframe {\n  border: 0;\n}\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\ntd,\nth {\n  padding: 0;\n}\n\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Regular.ttf) format(\"truetype\");\n  font-weight: 400;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Italic.ttf) format(\"truetype\");\n  font-weight: 400;\n  font-style: italic;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Medium.ttf) format(\"truetype\");\n  font-weight: 500;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-MediumItalic.ttf) format(\"truetype\");\n  font-weight: 500;\n  font-style: italic;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-SemiBold.ttf) format(\"truetype\");\n  font-weight: 600;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-SemiBoldItalic.ttf) format(\"truetype\");\n  font-weight: 600;\n  font-style: italic;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-Bold.ttf) format(\"truetype\");\n  font-weight: 700;\n  font-style: normal;\n}\n@font-face {\n  font-family: \"Open Sans\";\n  src: url(../../fonts/open-sans/OpenSans-BoldItalic.ttf) format(\"truetype\");\n  font-weight: 700;\n  font-style: italic;\n}\n:root {\n  --text-font-family: Helvetica, sans-serif;\n  --title-font-family: Helvetica, sans-serif;\n  --regular-font-weight: 400;\n  --medium-font-weight: 500;\n  --semi-bold-font-weight: 600;\n  --bold-font-weight: 700;\n  --text-font-size: 0.8rem;\n  --text-line-height: calc(var(--text-font-size) * 1.2);\n  --footnote-font-size: 0.6rem;\n  --footnote-line-height: calc(var(--footnote-font-size) * 1.2);\n  --h1-font-size: 1.6rem;\n  --h1-line-height: calc(var(--h1-font-size) * 1.2);\n  --h2-font-size: 1.2rem;\n  --h2-line-height: calc(var(--h2-font-size) * 1.2);\n  --h3-font-size: 1rem;\n  --h3-line-height: calc(var(--h3-font-size) * 1.2);\n  --logo-width: 2rem;\n  --logo-height: 4rem;\n  --icon-size: 1.75rem;\n  --sidebar-vertical-padding: 1rem;\n  --sidebar-horizontal-padding: 1rem;\n  --black: #000;\n  --transparent-black: rgba(0, 0, 0, 0.3);\n  --white: #fff;\n  --transparent-white: rgba(255, 255, 255, 0.9);\n  --feldgrau: #4B6259;\n}\n\n@media screen and (min-width: 48rem) {\n  :root {\n    --text-font-size: 1rem;\n    --footnote-font-size: 0.8rem;\n    --h1-font-size: 1.8rem;\n    --h2-font-size: 1.4rem;\n    --h3-font-size: 1.2rem;\n    --logo-width: 6rem;\n    --logo-height: 3rem;\n    --icon-size: 2.25rem;\n  }\n}\n@keyframes expand-outline {\n  0% {\n    outline-offset: 0;\n  }\n  100% {\n    outline-offset: 2px;\n  }\n}\n@keyframes rotate-vertical-left {\n  0% {\n    transform: rotateY(0);\n    transform-origin: left;\n  }\n  50% {\n    transform: rotateY(180deg);\n    transform-origin: left;\n  }\n  100% {\n    transform: rotateY(0);\n    transform-origin: left;\n  }\n}\n@keyframes rotate-horizontal-bottom {\n  0% {\n    transform: rotateX(0);\n    transform-origin: bottom;\n  }\n  50% {\n    transform: rotateX(180deg);\n    transform-origin: bottom;\n  }\n  100% {\n    transform: rotateX(0);\n    transform-origin: bottom;\n  }\n}\nbody {\n  font-family: var(--text-font-family);\n  font-size: var(--text-font-size);\n  line-height: var(--text-line-height);\n  color: var(--black);\n  background-color: var(--white);\n}\n\nh1 {\n  font-family: var(--title-font-family);\n  font-size: var(--h1-font-size);\n  line-height: var(--h1-line-height);\n}\n\nh2 {\n  font-family: var(--text-font-family);\n  font-size: var(--h2-font-size);\n  line-height: var(--h2-line-height);\n  margin: 0 0 4rem 0;\n}\n\nh3 {\n  font-family: var(--text-font-family);\n  font-size: var(--h3-font-size);\n  line-height: var(--h3-line-height);\n  margin: 2rem 0 1rem 0;\n}\n\np {\n  text-align: justify;\n}\n\nstrong {\n  font-weight: var(--bold-font-weight);\n}\n\nem {\n  font-style: italic;\n}\n\na {\n  color: var(--black);\n  text-decoration: none;\n  transition: text-decoration 200ms ease-in-out;\n}\na:hover, a:focus, a:active {\n  text-decoration: underline;\n}\na:focus-visible {\n  outline: 1px dashed var(--black);\n  outline-offset: 2px;\n  animation: expand-outline 200ms ease-in-out;\n}\n\nbody {\n  min-height: 100vh;\n  overflow: hidden;\n}\n\n.logo {\n  z-index: 2;\n  position: fixed;\n  top: 1rem;\n  right: 1.5rem;\n}\n.logo .logo__link {\n  width: var(--logo-width);\n  height: var(--logo-height);\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n.logo .logo__icon {\n  width: 100%;\n  height: 100%;\n}\n.logo .logo__icon path:nth-child(1) {\n  stroke: var(--black);\n}\n.logo .logo__icon path:nth-child(2) {\n  stroke: var(--white);\n}\n.logo .logo__icon--rotate-vertical-left {\n  animation: rotate-vertical-left 800ms ease-in-out infinite;\n}\n.logo .logo__icon--rotate-horizontal-bottom {\n  animation: rotate-horizontal-bottom 800ms ease-in-out infinite;\n}\n\n.sidebar {\n  z-index: 1;\n  overflow-y: auto;\n  position: fixed;\n  top: 0;\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  padding: var(--sidebar-vertical-padding) var(--sidebar-horizontal-padding);\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  align-items: flex-start;\n  background-color: var(--white);\n  transition: background-color 400ms ease-in-out;\n}\n.sidebar .sidebar__nav {\n  max-width: 100%;\n}\n.sidebar .sidebar__nav-item + .sidebar__nav-item {\n  margin: 0.5rem 0 0 0;\n}\n.sidebar .sidebar__nav-link {\n  display: inline-block;\n  max-width: 100%;\n  overflow-x: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  color: var(--black);\n  transition: color 400ms ease-in-out;\n}\n.sidebar .sidebar__social {\n  display: flex;\n  align-items: center;\n  margin: 1rem 0 0 0;\n}\n.sidebar .sidebar__social-link {\n  width: var(--icon-size);\n  height: var(--icon-size);\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n.sidebar .sidebar__social-link + .sidebar__social-link {\n  margin: 0 0 0 1rem;\n}\n.sidebar .sidebar__instagram-icon,\n.sidebar .sidebar__email-icon {\n  width: 100%;\n  height: 100%;\n  fill: var(--black);\n  transition: fill 400ms ease-in-out;\n}\n.sidebar--slimmed {\n  width: 15%;\n  background-color: transparent;\n}\n.sidebar--slimmed .sidebar__nav-link {\n  color: var(--transparent-black);\n}\n.sidebar--slimmed .sidebar__instagram-icon,\n.sidebar--slimmed .sidebar__email-icon {\n  fill: var(--transparent-black);\n}\n.sidebar--slimmed:hover {\n  background-color: var(--transparent-white);\n}\n.sidebar--slimmed:hover .sidebar__nav-link {\n  color: var(--black);\n}\n.sidebar--slimmed:hover .sidebar__instagram-icon,\n.sidebar--slimmed:hover .sidebar__email-icon {\n  fill: var(--black);\n}\n\n.exhibition-section {\n  width: 100vw;\n  height: 100vh;\n}\n\n.exhibition {\n  opacity: 0;\n  width: 100%;\n  height: 100%;\n  padding: 0 0 0 15%;\n  transition: opacity 400ms ease-in-out;\n}\n.exhibition--visible {\n  opacity: 1;\n}","// ----------------------------------------------------------------------------\n// FONTS\n// ----------------------------------------------------------------------------\n\n// Open Sans\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Regular.ttf) format('truetype');\n\tfont-weight: 400;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Italic.ttf) format('truetype');\n\tfont-weight: 400;\n\tfont-style: italic;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Medium.ttf) format('truetype');\n\tfont-weight: 500;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-MediumItalic.ttf) format('truetype');\n\tfont-weight: 500;\n\tfont-style: italic;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-SemiBold.ttf) format('truetype');\n\tfont-weight: 600;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-SemiBoldItalic.ttf) format('truetype');\n\tfont-weight: 600;\n\tfont-style: italic;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-Bold.ttf) format('truetype');\n\tfont-weight: 700;\n\tfont-style: normal;\n}\n\n@font-face {\n\tfont-family: 'Open Sans';\n\tsrc: url(../../fonts/open-sans/OpenSans-BoldItalic.ttf) format('truetype');\n\tfont-weight: 700;\n\tfont-style: italic;\n}\n","// ----------------------------------------------------------------------------\n// VARIABLES\n// ----------------------------------------------------------------------------\n\n:root {\n\n\t// Fonts\n\n\t--text-font-family: Helvetica, sans-serif;\n\t--title-font-family: Helvetica, sans-serif;\n\t--regular-font-weight: 400;\n\t--medium-font-weight: 500;\n\t--semi-bold-font-weight: 600;\n\t--bold-font-weight: 700;\n\t--text-font-size: 0.8rem;\n\t--text-line-height: calc(var(--text-font-size) * 1.2);\n\t--footnote-font-size: 0.6rem;\n\t--footnote-line-height: calc(var(--footnote-font-size) * 1.2);\n\t--h1-font-size: 1.6rem;\n\t--h1-line-height: calc(var(--h1-font-size) * 1.2);\n\t--h2-font-size: 1.2rem;\n\t--h2-line-height: calc(var(--h2-font-size) * 1.2);\n\t--h3-font-size: 1rem;\n\t--h3-line-height: calc(var(--h3-font-size) * 1.2);\n\n\t// Dimensions\n\n\t--logo-width: 2rem;\n\t--logo-height: 4rem;\n\t--icon-size: 1.75rem;\n\t--sidebar-vertical-padding: 1rem;\n\t--sidebar-horizontal-padding: 1rem;\n\n\t// Colors\n\n\t--black: #000;\n\t--transparent-black: rgba(0, 0, 0, 0.3);\n\t--white: #fff;\n\t--transparent-white: rgba(255, 255, 255, 0.9);\n\t--feldgrau: #4B6259;\n}\n\n// Media queries\n\n$tablet-media-query: 48rem;\n$desktop-media-query: 62rem;\n\n@media screen and (min-width: $tablet-media-query) {\n\n\t:root {\n\n\t\t// Fonts\n\n\t\t--text-font-size: 1rem;\n\t\t--footnote-font-size: 0.8rem;\n\t\t--h1-font-size: 1.8rem;\n\t\t--h2-font-size: 1.4rem;\n\t\t--h3-font-size: 1.2rem;\n\n\t\t// Dimensions\n\n\t\t--logo-width: 6rem;\n\t\t--logo-height: 3rem;\n\t\t--icon-size: 2.25rem;\n\t}\n}\n","// ----------------------------------------------------------------------------\n// ANIMATIONS\n// ----------------------------------------------------------------------------\n\n@keyframes expand-outline {\n\t0% {\n\t\toutline-offset: 0;\n\t}\n\t100% {\n\t\toutline-offset: 2px;\n\t}\n}\n\n@keyframes rotate-vertical-left {\n\t0% {\n\t\ttransform: rotateY(0);\n\t\ttransform-origin: left;\n\t}\n\t50% {\n\t\ttransform: rotateY(180deg);\n\t\ttransform-origin: left;\n\t}\n\t100% {\n\t\ttransform: rotateY(0);\n\t\ttransform-origin: left;\n\t}\n}\n\n@keyframes rotate-horizontal-bottom {\n\t0% {\n\t\ttransform: rotateX(0);\n\t\ttransform-origin: bottom;\n\t}\n\t50% {\n\t\ttransform: rotateX(180deg);\n\t\ttransform-origin: bottom;\n\t}\n\t100% {\n\t\ttransform: rotateX(0);\n\t\ttransform-origin: bottom;\n\t}\n}\n\n","@use 'utils/minireset';\n@use 'partials/fonts';\n@use 'partials/variables' as *;\n@use 'partials/animations';\n\n// ----------------------------------------------------------------------------\n// GENERALITIES\n// ----------------------------------------------------------------------------\n\n// Fonts and colors\n\nbody {\n\tfont-family: var(--text-font-family);\n\tfont-size: var(--text-font-size);\n\tline-height: var(--text-line-height);\n\tcolor: var(--black);\n\tbackground-color: var(--white);\n}\n\nh1 {\n\tfont-family: var(--title-font-family);\n\tfont-size: var(--h1-font-size);\n\tline-height: var(--h1-line-height);\n}\n\nh2 {\n\tfont-family: var(--text-font-family);\n\tfont-size: var(--h2-font-size);\n\tline-height: var(--h2-line-height);\n\tmargin: 0 0 4rem 0;\n}\n\nh3 {\n\tfont-family: var(--text-font-family);\n\tfont-size: var(--h3-font-size);\n\tline-height: var(--h3-line-height);\n\tmargin: 2rem 0 1rem 0;\n}\n\np {\n\ttext-align: justify;\n}\n\nstrong {\n\tfont-weight: var(--bold-font-weight);\n}\n\nem {\n\tfont-style: italic;\n}\n\n// Link style\n\na {\n\tcolor: var(--black);\n\ttext-decoration: none;\n\ttransition: text-decoration 200ms ease-in-out;\n\n\t&:hover,\n\t&:focus,\n\t&:active {\n\t\ttext-decoration: underline;\n\t}\n\n\t&:focus-visible {\n\t\toutline: 1px dashed var(--black);\n\t\toutline-offset: 2px;\n\t\tanimation: expand-outline 200ms ease-in-out;\n\t}\n}\n\n// General layout\n\nbody {\n\tmin-height: 100vh;\n\toverflow: hidden;\n}\n\n// ----------------------------------------------------------------------------\n// HEADER\n// ----------------------------------------------------------------------------\n\n// Logo\n\n.logo {\n\tz-index: 2;\n\tposition: fixed;\n\ttop: 1rem;\n\tright: 1.5rem;\n\n\t.logo__link {\n\t\twidth: var(--logo-width);\n\t\theight: var(--logo-height);\n\t\tdisplay: flex;\n\t\tjustify-content: center;\n\t\talign-items: center;\n\t}\n\n\t.logo__icon {\n\t\twidth: 100%;\n\t\theight: 100%;\n\n\t\tpath:nth-child(1) {\n\t\t\tstroke: var(--black);\n\t\t}\n\n\t\tpath:nth-child(2) {\n\t\t\tstroke: var(--white);\n\t\t}\n\n\t\t&--rotate-vertical-left {\n\t\t\tanimation: rotate-vertical-left 800ms ease-in-out infinite;\n\t\t}\n\n\t\t&--rotate-horizontal-bottom {\n\t\t\tanimation: rotate-horizontal-bottom 800ms ease-in-out infinite;\n\t\t}\n\t}\n}\n\n// Sidebar\n\n.sidebar {\n\tz-index: 1;\n\toverflow-y: auto;\n\tposition: fixed;\n\ttop: 0;\n\tbottom: 0;\n\tleft: 0;\n\twidth: 100%;\n\tpadding: var(--sidebar-vertical-padding) var(--sidebar-horizontal-padding);\n\tdisplay: flex;\n\tflex-direction: column;\n\tjustify-content: space-between;\n\talign-items: flex-start;\n\tbackground-color: var(--white);\n\ttransition: background-color 400ms ease-in-out;\n\n\t.sidebar__nav {\n\t\tmax-width: 100%;\n\t}\n\n\t.sidebar__nav-item {\n\n\t\t+ .sidebar__nav-item {\n\t\t\tmargin: 0.5rem 0 0 0;\n\t\t}\n\t}\n\n\t.sidebar__nav-link {\n\t\tdisplay: inline-block;\n\t\tmax-width: 100%;\n\t\toverflow-x: hidden;\n\t\twhite-space: nowrap;\n\t\ttext-overflow: ellipsis;\n\t\tcolor: var(--black);\n\t\ttransition: color 400ms ease-in-out;\n\t}\n\n\t.sidebar__social {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tmargin: 1rem 0 0 0;\n\t}\n\n\t.sidebar__social-link {\n\t\twidth: var(--icon-size);\n\t\theight: var(--icon-size);\n\t\tdisplay: flex;\n\t\tjustify-content: center;\n\t\talign-items: center;\n\n\t\t+ .sidebar__social-link {\n\t\t\tmargin: 0 0 0 1rem;\n\t\t}\n\t}\n\n\t.sidebar__instagram-icon,\n\t.sidebar__email-icon {\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\tfill: var(--black);\n\t\ttransition: fill 400ms ease-in-out;\n\t}\n\n\t&--slimmed {\n\t\twidth: 15%;\n\t\tbackground-color: transparent;\n\n\t\t.sidebar__nav-link {\n\t\t\tcolor: var(--transparent-black);\n\t\t}\n\n\t\t.sidebar__instagram-icon,\n\t\t.sidebar__email-icon {\n\t\t\tfill: var(--transparent-black);\n\t\t}\n\n\t\t&:hover {\n\t\t\tbackground-color: var(--transparent-white);\n\n\t\t\t\t\n\t\t\t.sidebar__nav-link {\n\t\t\t\tcolor: var(--black);\n\t\t\t}\n\n\t\t\t.sidebar__instagram-icon,\n\t\t\t.sidebar__email-icon {\n\t\t\t\tfill: var(--black);\n\t\t\t}\n\t\t}\n\n\t}\n}\n\n// ----------------------------------------------------------------------------\n// MAIN\n// ----------------------------------------------------------------------------\n\n// Exhibition section\n\n.exhibition-section {\n\twidth: 100vw;\n\theight: 100vh;\n}\n\n.exhibition {\n\topacity: 0;\n\twidth: 100%;\n\theight: 100%;\n\tpadding: 0 0 0 15%;\n\ttransition: opacity 400ms ease-in-out;\n\n\t&--visible {\n\t\topacity: 1;\n\t}\n}\n"],"names":[],"sourceRoot":""}*/ \ No newline at end of file diff --git a/public/assets/css/main.scss b/public/assets/css/main.scss index afa1206..834f9e0 100644 --- a/public/assets/css/main.scss +++ b/public/assets/css/main.scss @@ -80,37 +80,81 @@ body { // HEADER // ---------------------------------------------------------------------------- +// Logo + +.logo { + z-index: 2; + position: fixed; + top: 1rem; + right: 1.5rem; + + .logo__link { + width: var(--logo-width); + height: var(--logo-height); + display: flex; + justify-content: center; + align-items: center; + } + + .logo__icon { + width: 100%; + height: 100%; + + path:nth-child(1) { + stroke: var(--black); + } + + path:nth-child(2) { + stroke: var(--white); + } + + &--rotate-vertical-left { + animation: rotate-vertical-left 800ms ease-in-out infinite; + } + + &--rotate-horizontal-bottom { + animation: rotate-horizontal-bottom 800ms ease-in-out infinite; + } + } +} + // Sidebar .sidebar { + z-index: 1; + overflow-y: auto; position: fixed; top: 0; bottom: 0; left: 0; + width: 100%; padding: var(--sidebar-vertical-padding) var(--sidebar-horizontal-padding); - overflow-y: auto; - background-color: var(--transparent-white); + display: flex; + flex-direction: column; + justify-content: space-between; + align-items: flex-start; + background-color: var(--white); transition: background-color 400ms ease-in-out; + .sidebar__nav { + max-width: 100%; + } + .sidebar__nav-item { - width: 97vw; - transition: width 400ms ease-in-out; + .sidebar__nav-item { - margin: 0.75rem 0 0 0; + margin: 0.5rem 0 0 0; } } .sidebar__nav-link { display: inline-block; - max-width: 100vw; + max-width: 100%; overflow-x: hidden; white-space: nowrap; text-overflow: ellipsis; color: var(--black); - transition: - max-width 400ms ease-in-out, - color 400ms ease-in-out; + transition: color 400ms ease-in-out; } .sidebar__social { @@ -140,14 +184,10 @@ body { } &--slimmed { + width: 15%; background-color: transparent; - .sidebar__nav-item { - width: 15vw; - } - .sidebar__nav-link { - max-width: 15vw; color: var(--transparent-black); } @@ -185,12 +225,13 @@ body { } .exhibition { + opacity: 0; width: 100%; height: 100%; + padding: 0 0 0 15%; + transition: opacity 400ms ease-in-out; + + &--visible { + opacity: 1; + } } - -// ---------------------------------------------------------------------------- -// FOOTER -// ---------------------------------------------------------------------------- - -// Footer bar diff --git a/public/assets/css/partials/animations.scss b/public/assets/css/partials/animations.scss index 6e2bd45..7f167c5 100644 --- a/public/assets/css/partials/animations.scss +++ b/public/assets/css/partials/animations.scss @@ -3,10 +3,41 @@ // ---------------------------------------------------------------------------- @keyframes expand-outline { - from { + 0% { outline-offset: 0; } - to { + 100% { outline-offset: 2px; } } + +@keyframes rotate-vertical-left { + 0% { + transform: rotateY(0); + transform-origin: left; + } + 50% { + transform: rotateY(180deg); + transform-origin: left; + } + 100% { + transform: rotateY(0); + transform-origin: left; + } +} + +@keyframes rotate-horizontal-bottom { + 0% { + transform: rotateX(0); + transform-origin: bottom; + } + 50% { + transform: rotateX(180deg); + transform-origin: bottom; + } + 100% { + transform: rotateX(0); + transform-origin: bottom; + } +} + diff --git a/public/assets/css/partials/variables.scss b/public/assets/css/partials/variables.scss index 3f49695..47a0e46 100644 --- a/public/assets/css/partials/variables.scss +++ b/public/assets/css/partials/variables.scss @@ -25,6 +25,8 @@ // Dimensions + --logo-width: 2rem; + --logo-height: 4rem; --icon-size: 1.75rem; --sidebar-vertical-padding: 1rem; --sidebar-horizontal-padding: 1rem; @@ -32,7 +34,7 @@ // Colors --black: #000; - --transparent-black: rgba(0, 0, 0, 0.4); + --transparent-black: rgba(0, 0, 0, 0.3); --white: #fff; --transparent-white: rgba(255, 255, 255, 0.9); --feldgrau: #4B6259; @@ -57,6 +59,8 @@ $desktop-media-query: 62rem; // Dimensions + --logo-width: 6rem; + --logo-height: 3rem; --icon-size: 2.25rem; } } diff --git a/public/assets/js/app.js b/public/assets/js/app.js index 95d2c06..173a4f6 100644 --- a/public/assets/js/app.js +++ b/public/assets/js/app.js @@ -5,35 +5,68 @@ // SIDEBAR ANIMATION const sidebar = document.querySelector('.sidebar'); -const sidebarNav = document.querySelector('.sidebar__nav'); -const sidebarNavLinks = sidebarNav.querySelectorAll('.sidebar__nav-link--internal'); +const sidebarNavLinks = document.querySelectorAll('.sidebar__nav-link--internal'); +const logoIcon = document.querySelector('.logo__icon'); +const exhibitionIframe = document.querySelector('.exhibition'); // ---------------------------------------------------------------------------- -// UTILS +// LOGIC // ---------------------------------------------------------------------------- +// UTILS + +// Enable CSS :active pseudo-class in Safari Mobile +function enableActivePseudoClass() { + document.addEventListener("touchstart", function() {},false); +} + // Convert rem to pixels by getting font-size CSS property function convertRemToPixels(rem) { let fontSize = parseFloat(window.getComputedStyle(document.body).getPropertyValue('font-size')); return rem * fontSize; } -// ---------------------------------------------------------------------------- -// LOGIC -// ---------------------------------------------------------------------------- - // SIDEBAR ANIMATION function slimDownSidebar() { - if (sidebar) { + if (sidebar && !sidebar.classList.contains('sidebar--slimmed')) { sidebar.classList.add('sidebar--slimmed'); } } -function slimDownSidebarOnClick() { - if (sidebarNavLinks.length > 0) { + +function enableLogoIconRotation() { + if (logoIcon) { + if (logoIcon.classList.contains('logo__icon--vertical')) { + logoIcon.classList.add('logo__icon--rotate-vertical-left'); + } else { + logoIcon.classList.add('logo__icon--rotate-horizontal-bottom'); + } + } +} + +function disableLogoIconRotation() { + if (logoIcon) { + if (logoIcon.classList.contains('logo__icon--vertical')) { + logoIcon.classList.remove('logo__icon--rotate-vertical-left'); + } else { + logoIcon.classList.remove('logo__icon--rotate-horizontal-bottom'); + } + } +} + +function loadExhibitionIframe() { + if (sidebarNavLinks.length > 0 && exhibitionIframe) { for (let i = 0; i < sidebarNavLinks.length; i++) { - sidebarNavLinks[i].addEventListener('click', slimDownSidebar); + sidebarNavLinks[i].addEventListener('click', function(e) { + enableLogoIconRotation(); + exhibitionIframe.classList.remove('exhibition--visible'); + exhibitionIframe.addEventListener('load', function(e) { + slimDownSidebar(); + disableLogoIconRotation(); + exhibitionIframe.classList.add('exhibition--visible'); + }); + }); } } } @@ -42,9 +75,10 @@ function slimDownSidebarOnClick() { // PROGRAM // ---------------------------------------------------------------------------- -// Enable CSS :active pseudo-class in Safari Mobile -document.addEventListener("touchstart", function() {},false); +// UTILS + +enableActivePseudoClass(); // SIDEBAR ANIMATION -slimDownSidebarOnClick(); +loadExhibitionIframe(); diff --git a/site/controllers/exhibitions.php b/site/controllers/exhibitions.php index c772809..e716781 100644 --- a/site/controllers/exhibitions.php +++ b/site/controllers/exhibitions.php @@ -1,6 +1,9 @@ homePage(); // Get exhibitions field content (stored as yaml) and parse it to return an array $exhibitions = $page->exhibitions()->yaml(); @@ -15,6 +18,7 @@ return function ($page) { $instagram = $page->instagram(); return [ + 'homePage' => $homePage, 'exhibitions' => $exhibitions, 'email' => $email, 'instagram' => $instagram diff --git a/site/templates/exhibitions.twig b/site/templates/exhibitions.twig index ac1ebf4..0d161be 100644 --- a/site/templates/exhibitions.twig +++ b/site/templates/exhibitions.twig @@ -3,6 +3,17 @@ {% block header %}
+ +