aboutsummaryrefslogtreecommitdiff
path: root/viewer/src/assets/scss/global.scss
blob: 5d2e6dc3f8af27583314cb3652a56d87a41c62a8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* ldgallery - A static generator which turns a collection of tagged
--             pictures into a searchable web gallery.
--
-- Copyright (C) 2019-2020  Guillaume FOUET
--
-- This program is free software: you can redistribute it and/or modify
-- it under the terms of the GNU Affero General Public License as
-- published by the Free Software Foundation, either version 3 of the
-- License, or (at your option) any later version.
--
-- This program is distributed in the hope that it will be useful,
-- but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-- GNU Affero General Public License for more details.
--
-- You should have received a copy of the GNU Affero General Public License
-- along with this program.  If not, see <https://www.gnu.org/licenses/>.
*/

// Global CSS
@import "~@/assets/scss/theme.scss";

// === Forms

.required label::after {
  content: "*";
  color: red;
}

button svg + span {
  margin-left: 7px;
}

// === Tools

.nowrap {
  white-space: nowrap;
}
.no-scroll-x {
  overflow-x: hidden;
}

.flex {
  display: flex;
}
.flex-column {
  display: flex;
  flex-direction: column;
}
.flex-center {
  align-items: center;
}

/**
 * Class for containers that centers its content vertically and horizontally,
 * preferably sticking to the container start if the container is smaller than the content.
 */
.container-vh-centering {
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

// === Links

.link {
  color: $link;
  cursor: pointer;
  text-decoration: none;
  &:hover {
    color: $link-hover;
  }
}

.disabled {
  color: $disabled-color !important;
  cursor: initial;
}

// Disable sticky hover styling on touch devices,
// on which the virtual cursor doesn't leave the element after being tapped.
// The fix can be applied to `a` elements by using the .link class.
@media (hover: none), (hover: on-demand) {
  .link:hover {
    color: $link !important;
  }
  .disabled:hover {
    color: $disabled-color !important;
  }
}

// === Scrollbar styling

.scrollbar {
  overflow: auto;
}
.scrollbar::-webkit-scrollbar {
  width: $scrollbar-width;
  height: $scrollbar-width;
}
.scrollbar::-webkit-scrollbar-corner {
  background-color: transparent;
}
.scrollbar::-webkit-scrollbar-thumb {
  box-shadow: inset 0 0 1px black;
  background-color: $scrollbar-color;
}

// === Effect to apply on lazy-image loading

img {
  display: block;
  image-orientation: from-image;
  &.v-lazy-image {
    opacity: 0;
    transition: opacity 0.4s;
  }
  &.v-lazy-image-loaded {
    opacity: 1;
  }
}