gallery/css/grid-n-view.css
Alex A. Naanou 209202945a cleanup and tweaks...
Signed-off-by: Alex A. Naanou <alex.nanou@gmail.com>
2023-07-20 22:06:51 +03:00

178 lines
3.6 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/**********************************************************************
*
*
*
**********************************************************************/
/********************************************************* Config ****/
:root {
/* dimensions */
--gallery-scrollbar-width: 0.5em;
--lightbox-frame-size: 5vmin;
--lightbox-image-margin-top: 0.75;
--lightbox-button-size: 4em;
/* theme */
--gallery-text-color: black;
--gallery-secondary-color: silver;
--gallery-background-color: white;
--lightbox-text-color: black;
--lightbox-background-color: white;
}
.gallery-dark {
--gallery-text-color: silver;
--gallery-secondary-color: gray;
--gallery-background-color: black;
}
.lightbox-dark {
--lightbox-text-color: silver;
--lightbox-background-color: black;
}
/****************************************************** Scrolling ****/
::-webkit-scrollbar {
width: var(--gallery-scrollbar-width);
}
::-webkit-scrollbar-track {
background-color: transparent;
border-radius: 100px;
}
::-webkit-scrollbar-thumb {
background-color: var(--gallery-secondary-color);
border-radius: 100px;
}
body {
overflow-y: scroll;
color: var(--gallery-text-color);
background: var(--gallery-background-color);
}
/******************************************************** Gallery ****/
/* XXX need to account for scrollbar popping in and out */
.gallery {
margin-left: var(--gallery-scrollbar-width);
margin-right: 0;
color: var(--gallery-text-color);
background: var(--gallery-background-color);
}
.gallery .images {
position: relative;
display: flex;
justify-content: flex-start;
align-content: flex-start;
flex-flow: row wrap;
}
.gallery .images img {
height: 300px;
width: auto;
image-rendering: crisp-edges;
box-sizing: border-box;
}
.gallery .images img {
cursor: hand;
}
.gallery .images img.current {
border: solid 2px red;
}
/*************************************************** Image markers ***/
.gallery .images img+.mark {
position: relative;
}
/* marker: selected */
.gallery .images img+.mark.selected:after {
content: "";
position: absolute;
display: block;
width: 1em;
height: 1em;
right: 0.5em;
bottom: 0.5em;
border-radius: 50%;
background: blue;
border: solid 1px white;
}
/******************************************************* Lightbox ****/
.gallery .lightbox {
display: none;
position: fixed;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
text-align: center;
color: var(--lightbox-text-color);
background: var(--lightbox-background-color);
}
.gallery .lightbox.show-caption:after {
content: attr(caption);
position: absolute;
bottom: 0.5em;
left: 0.5em;
}
.gallery .lightbox.clickable {
cursor: hand;
}
/* XXX add metadata display... */
.gallery .lightbox img {
object-fit: contain;
width: calc(
100vw
- var(--lightbox-frame-size) * 2);
height: calc(
100vh
- var(--lightbox-frame-size) * 2);
margin-top: calc(
var(--lightbox-frame-size)
* var(--lightbox-image-margin-top));
}
/* controls: next/prev... */
.lightbox .button {
cursor: hand;
font-size: var(--lightbox-button-size);
padding: 0 0.25em;
filter: saturate(0);
opacity: 0.1;
}
.lightbox .button:hover {
opacity: 1;
filter: saturate(1);
}
/* controls: close... */
.gallery .lightbox .button.close {
position: absolute;
top: 0px;
right: 0px;
}
.gallery .lightbox .button.close:after {
content: "×";
color: red;
}
/**********************************************************************
* vim:set ts=4 sw=4 : */