@ecodev/natural-gallery-js
Version:
A lazy load, infinite scroll, natural and masonry layout gallery
1 lines • 26.6 kB
Source Map (JSON)
{"version":3,"sources":["../src/styles/_figure.scss","../src/styles/natural-gallery.scss","../node_modules/photoswipe/dist/photoswipe.css"],"sourcesContent":["$defaultBorderRadius: 8px;\n\n.natural-gallery-js {\n .root {\n transform: scale(1) translateY(0);\n transform-origin: top center;\n opacity: 1;\n\n &:is(a) {\n border: none;\n }\n\n &,\n .figure,\n img {\n border-radius: var(--ngjs-figure-radius, $defaultBorderRadius);\n overflow: hidden;\n }\n\n &,\n .figure {\n left: 0;\n position: relative;\n display: flex;\n flex-direction: column;\n float: left;\n margin: 0;\n transition: 1s background-color;\n border: none;\n background: none;\n }\n\n &:focus-within,\n &:focus,\n &:hover {\n .title.hover,\n .select-btn {\n transform: translateY(0%);\n }\n }\n\n &:focus-visible,\n *:focus-visible {\n outline: var(--ngjs-focus-outline, 1px solid orange);\n }\n\n &.zoomable,\n .zoomable {\n cursor: zoom-in;\n }\n\n &.activable,\n .activable {\n cursor: pointer;\n }\n\n &.loaded .image {\n opacity: 1;\n }\n\n .image.zoomable:hover,\n .image.zoomable:focus,\n &.zoomable:focus .image,\n &.zoomable:hover .image {\n transform: rotate(1deg) scale(1.2);\n }\n\n .image {\n display: block;\n position: relative;\n margin: 0;\n width: 100%;\n height: 100%;\n z-index: 100;\n opacity: 0;\n transition: 1s ease-out all;\n min-height: 0;\n }\n\n .select-btn:focus,\n &.selected .select-btn {\n transform: translateY(0%);\n top: 0;\n left: 0;\n }\n\n .select-btn {\n position: absolute;\n z-index: 991;\n top: 0;\n left: 0;\n padding: 10px;\n width: 36px;\n height: 36px;\n transition: 0.2s ease all;\n transform: translateY(calc(-100% - 15px));\n color: rgba(255, 255, 255, 0.9);\n fill: currentColor;\n cursor: pointer;\n background: rgba(0, 0, 0, 0.6);\n border-top-left-radius: var(--ngjs-figure-radius, $defaultBorderRadius);\n border-bottom-right-radius: 5px;\n border: none;\n\n .marker {\n position: relative;\n width: 18px;\n height: 18px;\n border-width: 2px;\n border-style: solid;\n border-color: var(--ngjs-marker-border-color, currentColor);\n box-sizing: border-box;\n border-radius: 2px;\n\n &::before,\n &::after {\n content: ' ';\n position: absolute;\n display: block;\n background: var(--ngjs-marker-check-color, transparent);\n width: 2px;\n }\n\n &::before {\n left: 5px;\n top: 5px;\n height: 7px;\n transform: rotateZ(-45deg);\n transform-origin: 0 100%;\n }\n\n &::after {\n left: 4px;\n top: 0px;\n height: 11px;\n transform: rotateZ(45deg);\n transform-origin: 100% 100%;\n }\n }\n }\n\n &.selected {\n .select-btn {\n color: var(--ngjs-selected-marker-color, orange);\n\n .marker {\n background: currentColor;\n\n &::before,\n &::after {\n background: var(--ngjs-selected-marker-check, black);\n }\n }\n }\n }\n\n .title {\n position: absolute;\n bottom: 0;\n left: 0;\n right: 0;\n z-index: 1100;\n text-align: center;\n color: white;\n font-size: 14px;\n line-height: 1.4em;\n font-weight: normal;\n transition: 0.2s ease all;\n overflow: hidden;\n white-space: normal;\n\n &,\n button,\n a {\n padding: 8px 8px;\n }\n\n &:not(.link),\n &.link button,\n &.link a {\n background: var(--ngjs-link-bg, rgb(0, 0, 0, 0.7));\n color: var(--ngjs-link-color, white);\n }\n\n &:not(.link) {\n border-radius: 0 0 var(--ngjs-figure-radius, $defaultBorderRadius)\n var(--ngjs-figure-radius, $defaultBorderRadius);\n }\n\n &.link {\n button,\n a {\n display: block;\n box-shadow:\n inset 0 1px 1px rgba(255, 255, 255, 0.25),\n 0 2px 5px rgba(0, 0, 0, 0.5);\n border-radius: var(--ngjs-link-radius, 4px);\n border: none;\n text-decoration: none;\n cursor: pointer;\n\n &:hover {\n background: var(--ngjs-link-hover-bg, rgb(0, 0, 0));\n color: var(--ngjs-link-hover-color, white);\n }\n }\n }\n\n // Status : Mouse out\n &.hover {\n // + the margin of &[href]\n transform: translateY(calc(100% + 12px));\n }\n }\n }\n}\n","// CSS Custom Properties (--ngjs variables) used in this file:\n// --ngjs-figure-radius: Border radius for figure elements (default: $defaultBorderRadius)\n// --ngjs-link-radius: Border radius for link buttons/anchors (default: 4px)\n// --ngjs-focus-outline: Focus outline style (default: 1px solid orange)\n// --ngjs-marker-border-color: Border color for selection marker (default: currentColor)\n// --ngjs-marker-check-color: Background color for marker check (default: transparent)\n// --ngjs-selected-marker-color: Color for selected marker (default: orange)\n// --ngjs-selected-marker-check: Color for selected marker check (default: black)\n// --ngjs-link-bg: Background color for non-link titles (default: rgb(0, 0, 0, 0.7))\n// --ngjs-link-color: Text color for non-link titles (default: white)\n// --ngjs-link-hover-bg: Background color for link hover state (default: rgb(0, 0, 0))\n// --ngjs-link-hover-color: Text color for link hover state (default: white)\n\n@use 'figure';\n\n.pswp {\n z-index: 9999999;\n\n .pswp__caption__center {\n text-align: center;\n }\n}\n\n.natural-gallery-js {\n position: relative;\n\n *,\n *::after,\n *::before {\n box-sizing: border-box;\n margin: 0;\n padding: 0;\n font-family: inherit;\n font-size: inherit;\n line-height: inherit;\n }\n\n iframe {\n position: absolute;\n width: 100%;\n height: 0;\n top: 0;\n left: 0;\n background-color: transparent;\n border: 0;\n }\n\n &.scrolling {\n &,\n & * {\n pointer-events: none !important;\n }\n }\n\n /**\n * Columns\n * ===================================================\n */\n\n .column {\n float: left;\n }\n\n /**\n * Pictures\n * ===================================================\n */\n\n &.format-square,\n &.format-natural {\n .natural-gallery-body {\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n }\n }\n\n &.format-masonry {\n .natural-gallery-body {\n display: flex;\n align-items: flex-start;\n justify-content: space-between;\n\n .column {\n display: flex;\n flex-direction: column;\n }\n }\n }\n\n .natural-gallery-body {\n padding: 0;\n margin: 0;\n\n .figure {\n background-color: var(--ngjs-figure-bg, rgba(0, 137, 224, 0.1));\n }\n\n &.resizing {\n .figure,\n .column {\n transition: none;\n opacity: 0;\n }\n }\n }\n\n /**\n * Next\n * ===================================================\n */\n .natural-gallery-next {\n display: block;\n margin: 10px auto;\n text-align: center;\n height: 50px;\n padding-block: 10px;\n background: none;\n border: none;\n width: 100%;\n cursor: pointer;\n border-radius: var(--ngjs-figure-radius, figure.$defaultBorderRadius);\n\n svg {\n cursor: pointer;\n font-size: 16px;\n height: 30px;\n color: var(--ngjs-next-color, rgb(0, 137, 224));\n fill: currentColor;\n }\n\n &:hover {\n background-color: var(--ngjs-next-hover-bg, rgba(0, 0, 0, 0.2));\n }\n\n &::after {\n content: '';\n display: block;\n clear: both;\n }\n }\n}\n","/*! PhotoSwipe main CSS by Dmytro Semenov | photoswipe.com */\r\n\r\n.pswp {\r\n --pswp-bg: #000;\r\n --pswp-placeholder-bg: #222;\r\n \r\n\r\n --pswp-root-z-index: 100000;\r\n \r\n --pswp-preloader-color: rgba(79, 79, 79, 0.4);\r\n --pswp-preloader-color-secondary: rgba(255, 255, 255, 0.9);\r\n \r\n /* defined via js:\r\n --pswp-transition-duration: 333ms; */\r\n \r\n --pswp-icon-color: #fff;\r\n --pswp-icon-color-secondary: #4f4f4f;\r\n --pswp-icon-stroke-color: #4f4f4f;\r\n --pswp-icon-stroke-width: 2px;\r\n\r\n --pswp-error-text-color: var(--pswp-icon-color);\r\n}\r\n\r\n\r\n/*\r\n\tStyles for basic PhotoSwipe (pswp) functionality (sliding area, open/close transitions)\r\n*/\r\n\r\n.pswp {\r\n\tposition: fixed;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\twidth: 100%;\r\n\theight: 100%;\r\n\tz-index: var(--pswp-root-z-index);\r\n\tdisplay: none;\r\n\ttouch-action: none;\r\n\toutline: 0;\r\n\topacity: 0.003;\r\n\tcontain: layout style size;\r\n\t-webkit-tap-highlight-color: rgba(0, 0, 0, 0);\r\n}\r\n\r\n/* Prevents focus outline on the root element,\r\n (it may be focused initially) */\r\n.pswp:focus {\r\n outline: 0;\r\n}\r\n\r\n.pswp * {\r\n box-sizing: border-box;\r\n}\r\n\r\n.pswp img {\r\n max-width: none;\r\n}\r\n\r\n.pswp--open {\r\n\tdisplay: block;\r\n}\r\n\r\n.pswp,\r\n.pswp__bg {\r\n\ttransform: translateZ(0);\r\n\twill-change: opacity;\r\n}\r\n\r\n.pswp__bg {\r\n opacity: 0.005;\r\n\tbackground: var(--pswp-bg);\r\n}\r\n\r\n.pswp,\r\n.pswp__scroll-wrap {\r\n\toverflow: hidden;\r\n}\r\n\r\n.pswp__scroll-wrap,\r\n.pswp__bg,\r\n.pswp__container,\r\n.pswp__item,\r\n.pswp__content,\r\n.pswp__img,\r\n.pswp__zoom-wrap {\r\n\tposition: absolute;\r\n\ttop: 0;\r\n\tleft: 0;\r\n\twidth: 100%;\r\n\theight: 100%;\r\n}\r\n\r\n.pswp__img,\r\n.pswp__zoom-wrap {\r\n\twidth: auto;\r\n\theight: auto;\r\n}\r\n\r\n.pswp--click-to-zoom.pswp--zoom-allowed .pswp__img {\r\n\tcursor: -webkit-zoom-in;\r\n\tcursor: -moz-zoom-in;\r\n\tcursor: zoom-in;\r\n}\r\n\r\n.pswp--click-to-zoom.pswp--zoomed-in .pswp__img {\r\n\tcursor: move;\r\n\tcursor: -webkit-grab;\r\n\tcursor: -moz-grab;\r\n\tcursor: grab;\r\n}\r\n\r\n.pswp--click-to-zoom.pswp--zoomed-in .pswp__img:active {\r\n cursor: -webkit-grabbing;\r\n cursor: -moz-grabbing;\r\n cursor: grabbing;\r\n}\r\n\r\n/* :active to override grabbing cursor */\r\n.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img,\r\n.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img:active,\r\n.pswp__img {\r\n\tcursor: -webkit-zoom-out;\r\n\tcursor: -moz-zoom-out;\r\n\tcursor: zoom-out;\r\n}\r\n\r\n\r\n/* Prevent selection and tap highlights */\r\n.pswp__container,\r\n.pswp__img,\r\n.pswp__button,\r\n.pswp__counter {\r\n\t-webkit-user-select: none;\r\n\t-moz-user-select: none;\r\n\t-ms-user-select: none;\r\n\tuser-select: none;\r\n}\r\n\r\n.pswp__item {\r\n\t/* z-index for fade transition */\r\n\tz-index: 1;\r\n\toverflow: hidden;\r\n}\r\n\r\n.pswp__hidden {\r\n\tdisplay: none !important;\r\n}\r\n\r\n/* Allow to click through pswp__content element, but not its children */\r\n.pswp__content {\r\n pointer-events: none;\r\n}\r\n.pswp__content > * {\r\n pointer-events: auto;\r\n}\r\n\r\n\r\n/*\r\n\r\n PhotoSwipe UI\r\n\r\n*/\r\n\r\n/*\r\n\tError message appears when image is not loaded\r\n\t(JS option errorMsg controls markup)\r\n*/\r\n.pswp__error-msg-container {\r\n display: grid;\r\n}\r\n.pswp__error-msg {\r\n\tmargin: auto;\r\n\tfont-size: 1em;\r\n\tline-height: 1;\r\n\tcolor: var(--pswp-error-text-color);\r\n}\r\n\r\n/*\r\nclass pswp__hide-on-close is applied to elements that\r\nshould hide (for example fade out) when PhotoSwipe is closed\r\nand show (for example fade in) when PhotoSwipe is opened\r\n */\r\n.pswp .pswp__hide-on-close {\r\n\topacity: 0.005;\r\n\twill-change: opacity;\r\n\ttransition: opacity var(--pswp-transition-duration) cubic-bezier(0.4, 0, 0.22, 1);\r\n\tz-index: 10; /* always overlap slide content */\r\n\tpointer-events: none; /* hidden elements should not be clickable */\r\n}\r\n\r\n/* class pswp--ui-visible is added when opening or closing transition starts */\r\n.pswp--ui-visible .pswp__hide-on-close {\r\n\topacity: 1;\r\n\tpointer-events: auto;\r\n}\r\n\r\n/* <button> styles, including css reset */\r\n.pswp__button {\r\n\tposition: relative;\r\n\tdisplay: block;\r\n\twidth: 50px;\r\n\theight: 60px;\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n\toverflow: hidden;\r\n\tcursor: pointer;\r\n\tbackground: none;\r\n\tborder: 0;\r\n\tbox-shadow: none;\r\n\topacity: 0.85;\r\n\t-webkit-appearance: none;\r\n\t-webkit-touch-callout: none;\r\n}\r\n\r\n.pswp__button:hover,\r\n.pswp__button:active,\r\n.pswp__button:focus {\r\n transition: none;\r\n padding: 0;\r\n background: none;\r\n border: 0;\r\n box-shadow: none;\r\n opacity: 1;\r\n}\r\n\r\n.pswp__button:disabled {\r\n opacity: 0.3;\r\n cursor: auto;\r\n}\r\n\r\n.pswp__icn {\r\n fill: var(--pswp-icon-color);\r\n color: var(--pswp-icon-color-secondary);\r\n}\r\n\r\n.pswp__icn {\r\n position: absolute;\r\n top: 14px;\r\n left: 9px;\r\n width: 32px;\r\n height: 32px;\r\n overflow: hidden;\r\n pointer-events: none;\r\n}\r\n\r\n.pswp__icn-shadow {\r\n stroke: var(--pswp-icon-stroke-color);\r\n stroke-width: var(--pswp-icon-stroke-width);\r\n fill: none;\r\n}\r\n\r\n.pswp__icn:focus {\r\n\toutline: 0;\r\n}\r\n\r\n/*\r\n\tdiv element that matches size of large image,\r\n\tlarge image loads on top of it,\r\n\tused when msrc is not provided\r\n*/\r\ndiv.pswp__img--placeholder,\r\n.pswp__img--with-bg {\r\n\tbackground: var(--pswp-placeholder-bg);\r\n}\r\n\r\n.pswp__top-bar {\r\n\tposition: absolute;\r\n\tleft: 0;\r\n\ttop: 0;\r\n\twidth: 100%;\r\n\theight: 60px;\r\n\tdisplay: flex;\r\n flex-direction: row;\r\n justify-content: flex-end;\r\n\tz-index: 10;\r\n\r\n\t/* allow events to pass through top bar itself */\r\n\tpointer-events: none !important;\r\n}\r\n.pswp__top-bar > * {\r\n pointer-events: auto;\r\n /* this makes transition significantly more smooth,\r\n even though inner elements are not animated */\r\n will-change: opacity;\r\n}\r\n\r\n\r\n/*\r\n\r\n Close button\r\n\r\n*/\r\n.pswp__button--close {\r\n margin-right: 6px;\r\n}\r\n\r\n\r\n/*\r\n\r\n Arrow buttons\r\n\r\n*/\r\n.pswp__button--arrow {\r\n position: absolute;\r\n top: 0;\r\n width: 75px;\r\n height: 100px;\r\n top: 50%;\r\n margin-top: -50px;\r\n}\r\n\r\n.pswp__button--arrow:disabled {\r\n display: none;\r\n cursor: default;\r\n}\r\n\r\n.pswp__button--arrow .pswp__icn {\r\n top: 50%;\r\n margin-top: -30px;\r\n width: 60px;\r\n height: 60px;\r\n background: none;\r\n border-radius: 0;\r\n}\r\n\r\n.pswp--one-slide .pswp__button--arrow {\r\n display: none;\r\n}\r\n\r\n/* hide arrows on touch screens */\r\n.pswp--touch .pswp__button--arrow {\r\n visibility: hidden;\r\n}\r\n\r\n/* show arrows only after mouse was used */\r\n.pswp--has_mouse .pswp__button--arrow {\r\n visibility: visible;\r\n}\r\n\r\n.pswp__button--arrow--prev {\r\n right: auto;\r\n left: 0px;\r\n}\r\n\r\n.pswp__button--arrow--next {\r\n right: 0px;\r\n}\r\n.pswp__button--arrow--next .pswp__icn {\r\n left: auto;\r\n right: 14px;\r\n /* flip horizontally */\r\n transform: scale(-1, 1);\r\n}\r\n\r\n/*\r\n\r\n Zoom button\r\n\r\n*/\r\n.pswp__button--zoom {\r\n display: none;\r\n}\r\n\r\n.pswp--zoom-allowed .pswp__button--zoom {\r\n display: block;\r\n}\r\n\r\n/* \"+\" => \"-\" */\r\n.pswp--zoomed-in .pswp__zoom-icn-bar-v {\r\n display: none;\r\n}\r\n\r\n\r\n/*\r\n\r\n Loading indicator\r\n\r\n*/\r\n.pswp__preloader {\r\n position: relative;\r\n overflow: hidden;\r\n width: 50px;\r\n height: 60px;\r\n margin-right: auto;\r\n}\r\n\r\n.pswp__preloader .pswp__icn {\r\n opacity: 0;\r\n transition: opacity 0.2s linear;\r\n animation: pswp-clockwise 600ms linear infinite;\r\n}\r\n\r\n.pswp__preloader--active .pswp__icn {\r\n opacity: 0.85;\r\n}\r\n\r\n@keyframes pswp-clockwise {\r\n 0% { transform: rotate(0deg); }\r\n 100% { transform: rotate(360deg); }\r\n}\r\n\r\n\r\n/*\r\n\r\n \"1 of 10\" counter\r\n\r\n*/\r\n.pswp__counter {\r\n height: 30px;\r\n margin-top: 15px;\r\n margin-inline-start: 20px;\r\n font-size: 14px;\r\n line-height: 30px;\r\n color: var(--pswp-icon-color);\r\n text-shadow: 1px 1px 3px var(--pswp-icon-color-secondary);\r\n opacity: 0.85;\r\n}\r\n\r\n.pswp--one-slide .pswp__counter {\r\n display: none;\r\n}\r\n"],"mappings":"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","names":[]}