gallery/css/grid-n-view.css

176 lines
3.6 KiB
CSS
Raw Normal View History

/**********************************************************************
*
*
*
**********************************************************************/
/********************************************************* 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;
}
/******************************************************* 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 : */