]> code.citadel.org Git - citadel.git/blob - webcit-ng/static/css/webcit.css
9031087f54dad55965f2615fd52976b106c9ffe1
[citadel.git] / webcit-ng / static / css / webcit.css
1 /*
2         Copyright (c) 1996-2023 by Art Cancro and the citadel.org team.
3         This program is open source software.  Use, duplication, or disclosure
4         are subject to the terms of the GNU General Public License, version 3.
5 */
6
7 * {                                             /* This makes grids consume exactly 100% of their parent containers */
8         box-sizing: border-box;
9         padding: 0;
10         margin: 0;
11 }
12
13 [contenteditable]:focus {
14         outline: 0px solid transparent;
15
16
17 .ctdl-main-grid-container {                     /* This grid implements the "holy grail layout" of the screen */
18         display: grid;
19         grid-template-rows: 5vh auto;
20         grid-template-columns: 12vw auto;
21         grid-template-areas:
22                 'ctdl-mg-banner ctdl-mg-banner'
23                 'ctdl-mg-menu ctdl-mg-main';
24         gap: 1px;                               /* This is the thickness of the lines between the boxes */
25         background-color: DarkSlateGrey;        /* This is the color of the lines between the boxes */
26         padding: 0;                             /* This is the border around the edges of the screen (0 for no border) */
27         width: 100vw;
28         height: 100vh;
29 }
30
31 .ctdl-grid-banner-item {                        /* Top banner, referenced by the grid container */
32         grid-area: ctdl-mg-banner;
33         background-color: DarkSlateGrey;
34 }
35
36 .ctdl-grid-sidebar-item {                       /* Side bar, referenced by the grid container */
37         grid-area: ctdl-mg-menu;
38         background-color: GhostWhite;
39 }
40
41 .ctdl-grid-main-item {                          /* Main content area of the screen, referenced by the grid container */
42         grid-area: ctdl-mg-main;
43         overflow-x: hidden;
44         overflow-y: auto;
45         background-color: GhostWhite;
46 }
47
48 .ctdl-main-grid-container > div {
49         text-align: left;
50 }
51
52 .ctdl-banner-buttons {                          /* Flexbox container for everything we stick into the banner */
53         display: flex;
54         flex-direction: row;
55         flex-wrap: nowrap;
56         justify-content: space-between;
57         align-items: center;
58         margin: 0;
59         width: 100%;
60         height: 100%;
61         overflow: hidden;
62 }
63
64 .ctdl-banner-left {                             /* Items which should be grouped to the LEFT side of the banner */
65         display: flex;
66         flex-direction: row;
67         flex-wrap: nowrap;
68         align-items: center;
69 }
70
71 .ctdl-banner-center {                           /* Items which should be grouped to the MIDDLE of the banner */
72         display: flex;
73         flex-direction: row;
74         flex-wrap: nowrap;
75         align-items: center;
76 }
77
78 .ctdl-banner-right {                            /* Items which should be grouped to the RIGHT side of the banner */
79         display: flex;
80         flex-direction: row;
81         flex-wrap: nowrap;
82         align-items: center;
83 }
84
85 .ctdl-banner-buttons li, .ctdl-banner-buttons li button {
86         float: left;
87         display: block;
88         background-color: DarkSlateGrey;
89         color: White;
90         font-size: 1.7vh;
91         border: none;
92         padding: 1vh;
93 }
94
95 .ctdl-banner-buttons li button:hover {
96         background-color: Black;
97 }
98
99 .ctdl-banner-buttons a {                        /* For example, the Login / Log Off button */
100         color: White;
101 }
102
103 .ctdl-banner-buttons span {                     /* For example, the name of the logged in user */
104         color: White;
105 }
106
107 .ctdl-logo-img {
108         background-color: White;
109         border-radius: 5px;
110         padding-bottom: 3px;
111         padding-left: 3px;
112         padding-right: 3px;
113 }
114
115 html,body,h1,h2,h3,h4,h5 {
116         font-family: sans-serif
117 }
118
119 .ctdl-modal {
120         display: none;                          /* set to "block" to make the modal appear */
121         z-index: 9;
122         position: fixed;
123         top: 50%;
124         left: 50%;
125         transform: translate(-50%, -50%);
126         border-style: outset;
127         border-width: 3px;
128         border-color: Black;
129         justify-content: center;
130         align-items: center;
131         padding: 10px;
132         background-color: GhostWhite;
133 }
134
135 .ctdl-modal-header {
136         background-color: GhostWhite;
137         padding: 10px;
138 }
139
140 .ctdl-modal-main {
141         padding: 10px;
142 }
143
144 .ctdl-modal-footer {
145         background-color: GhostWhite;
146         padding: 10px;
147 }
148
149 .ctdl-sidebar-button {
150         width: 100%;
151         padding: 10px;
152         text-align: left;
153         border: 1px solid GhostWhite;
154         background-color: GhostWhite;
155         color: Black;
156         font-size: 1.5vh;
157         border-radius: 5px;
158 }
159
160 .ctdl-sidebar-button:hover {
161         border-color: Blue;
162 }
163
164 .ctdl-sidebar-button-selected {
165         font-weight: bold;
166         background-color: Gainsboro;
167 }
168
169 .ctdl-grid-banner-item button {
170         background-color: #888888;
171         color: #FFFFFF;
172 }
173
174 .ctdl-forum-reading-pane {
175         background-color: White;        /* Background behind the message boxes */
176 }
177
178 .ctdl-fmsg-wrapper {                            /* message wrapper for forum view */
179         overflow: hidden;
180         border-radius: 10px;
181         background-color: White;
182         margin: 1vw;
183         padding: 5px;                           /* inside the box */
184         border-radius: 10px;
185         border-style: outset;
186         border-width: thin;
187 }
188
189 .ctdl-mmsg-wrapper {                            /* message wrapper for mailbox view */
190         overflow: hidden;
191         background-color: White;
192         padding: 5px;                           /* inside the box */
193 }
194
195 .ctdl-msg-reply {
196         margin-left: 5vw;
197 }
198
199 .ctdl-msg-header {
200         overflow: hidden;
201         padding: 4px;
202         min-height: 35px;
203         background-color: GhostWhite;
204         margin-bottom: 10px;                    /* this is the vertical space between the header and the message text */
205 }
206
207 .ctdl-msg-header-info {
208         float: left;
209 }
210
211 .ctdl-msg-header-buttons {
212         float: right;
213 }
214
215 .ctdl-msg-button {
216         margin-left: 2px;
217         border-radius: 5px;
218         background-color: Blue;
219         color: Black;
220         padding: 2px;
221         background-color: GhostWhite;
222         border-style: solid;
223         border-width: thin;
224         border-color: Black;
225         cursor: default;
226 }
227
228 .ctdl-msg-button:hover {
229         background-color: #123456;
230         color: GhostWhite;
231         transition: .3s;
232         border-color: #123456;
233         cursor: default;
234 }
235
236 .ctdl-msg-button a {
237         color: Black;
238         text-decoration: none;
239         cursor: default;
240 }
241
242 .ctdl-msg-button a:hover {
243         color: White;
244         cursor: default;
245 }
246
247 .ctdl-avatar {
248         width: 32px;
249 }
250
251 .ctdl-avatar img {
252         clip-path: circle(50%);
253 }
254
255 .ctdl-username {
256         font-weight: bold;
257         color: #000055;
258 }
259
260 .ctdl-username a {
261         text-decoration: none;
262         padding-right: 4px;
263 }
264
265 .ctdl-msgdate {
266         padding-left: 4px;
267 }
268
269 .ctdl-msgsubject {
270         font-weight: bold;
271 }
272
273 .ctdl-fmsg-content {                            /* message text, when in forum view */
274         margin-left: 32px;
275 }
276
277 .ctdl-mmsg-content {                            /* message text, when in mailbox view */
278         margin-left: 0;
279 }
280
281 .ctdl_mail_folders li {
282         color: Black;
283         padding-left: 10px;
284 }
285
286 .ctdl_mail_folders li:hover {
287         color: DarkSlateGrey;
288 }
289
290 .ctdl-avatar {
291         float: left;
292         padding-right: 2px;
293 }
294
295 .ctdl-forum-nav {
296         text-align: center;
297         color: Black;
298         background-color: Gainsboro;
299         padding-top: 5px;
300         padding-bottom: 5px;
301 }
302
303 .ctdl-forum-nav a {
304         text-decoration: none;
305 }
306
307 .ctdl-msg-body {
308 }
309
310 .ctdl-forum-editor-body {
311         padding-left: 5px;
312         padding-right: 5px;
313         padding-top: 1px black;
314         padding-bottom: 1px black;
315 }
316
317 blockquote {
318         background-color: #f5f5f5 !important;
319         color: Navy !important;
320         border-left: 2px solid Navy;
321         margin-bottom: 0px;
322         padding-bottom: 0px;
323         margin-left: 1em;
324         padding-left: 1em;
325 }
326
327 blockquote blockquote {
328         background-color: #ebebeb !important;
329         color: Maroon !important;
330         border-left: 2px solid Maroon;
331 }
332
333 blockquote blockquote blockquote {
334         background-color: #e1e1e1 !important;
335         color: Green !important;
336         border-left: 2px solid Green;
337 }
338
339 blockquote blockquote blockquote blockquote {
340         background-color: #d7d7d7 !important;
341         color: Purple !important;
342         border-left: 2px solid Purple;
343 }
344
345 blockquote blockquote blockquote blockquote blockquote {
346         background-color: #cdcdcd !important;
347         color: Teal !important;
348         border-left: 2px solid Teal;
349 }
350
351 blockquote pre {
352         margin-left: 1%;
353         margin-right: 1%;
354 }
355
356 .ctdl-forum-urlmodal {
357         width: 75%;
358 }
359
360 /* use this class for any small item that needs to be centered on the screen in the main div */
361 .ctdl-middle {
362         display: flex;
363         flex-direction: column;
364         justify-content: center;
365         align-items: center;
366         text-align: center;
367         min-height: 100vh;
368         background-color: GhostWhite;
369         overflow: none;
370         border: none;
371 }
372
373 .ctdl-roomlist-top {
374         background-color: GhostWhite;
375         width: 100%;
376         height: 100%;
377         overflow: auto;
378         border: none;
379 }
380
381 .ctdl-roomlist-floor {
382 }
383
384 .ctdl-roomlist-floor-label {
385         font-size: x-large;
386         margin: 1vw;
387         margin-bottom: 0;
388 }
389
390 .ctdl-roomlist-floor-rooms {
391 }
392
393 .ctdl-roomlist-room {
394         display: flex;
395         flex-direction: row;
396         flex-wrap: nowrap;
397         justify-content: space-around;
398         align-items: center;
399         overflow: hidden;
400         border-radius: 10px;
401         border-style: outset;
402         border-width: thin;
403         background-color: White;
404         padding: 0.3vw;
405         margin-top: 0;
406         margin-bottom: 0.1vw;
407         margin-left: 1vw;
408         margin-right: 1vw;
409 }
410
411 .ctdl-roomlist-roomicon {
412         overflow: hidden;
413         font-size: large;
414         margin-right: auto;
415 }
416
417 .ctdl-roomlist-roomname {
418         font-size: large;
419         margin-right: auto;
420         padding-left: 1vw;
421         padding-right: 1vw;
422 }
423
424 .ctdl-roomlist-roomname-hasnewmsgs {
425         font-weight: bold;
426         margin-right: auto;
427 }
428
429 .ctdl-roomlist-mtime {
430         margin-left: auto;
431 }
432
433 .ctdl-mailbox-grid-container {
434         display: grid;
435         position: relative;
436         overflow: hidden;
437         width: 100%;
438         height: 100%;
439         background-color: GhostWhite;
440         grid-template-rows: 15vw 1fr;           /* "1fr" means "all of the remaining space" */
441 }
442
443 .ctdl-mailbox-pane {                            /* list of messages when in mailbox view */
444         overflow-x: hidden;
445         overflow-y: scroll;
446         background-color: #DDDDDD;
447         border-bottom: solid 3px SlateGrey;     /* We can probably turn this into a drag handle */
448 }
449
450 .ctdl-mailbox-table {
451         width: 100%;
452         background-color: GhostWhite;
453         border-collapse: collapse;
454 }
455
456 .ctdl-mailbox-table td {
457         padding: 5px;
458 }
459
460 .ctdl-mailbox-table tr {
461         cursor: pointer;
462         border-top: solid 1px LightGrey;
463 }
464
465 .ctdl-mailbox-table tr:hover {
466         border-top: solid 1px Blue;
467         border-bottom: solid 1px Blue;
468         background-color: LightGrey;
469 }
470
471 .ctdl-mailbox-table th {
472         position: sticky;
473         top: 0;
474         z-index: 6;
475         background-color: SlateGrey;
476         color: White;
477         padding-top: 5px;
478         padding-bottom: 5px;
479 }
480
481 .ctdl-mailbox-table th:hover {                  /* Suppress highlighting the header bar */
482         background-color: SlateGrey;
483         color: White;
484         cursor: default;
485 }
486
487 .ctdl-mail-selected {
488         background-color: Blue;
489         color: White;
490 }
491
492 .ctdl-mail-subject {                            /* Subject column in mailbox message list */
493 }
494
495 .ctdl-mail-sender {                             /* Sender column in mailbox message list */
496 }
497
498 .ctdl-mail-date {                               /* Date column in mailbox message list */
499         white-space: nowrap;
500 }
501
502 .ctdl-mail-msgnum {                             /* # column in mailbox message list */
503         white-space: nowrap;
504 }
505
506 .ctdl-mailbox-reading-pane {                    /* message reading pane when in mailbox view */
507         overflow: auto;
508         background-color: GhostWhite;
509         padding: 5px;
510         overflow: auto;
511         border: none;
512 }
513
514 .ctdl-compose-mail {                            /* mail composition window */
515         width: 100%;
516         height: 100%;
517         overflow: none;
518         border: none;
519         padding: 0;
520         background-color: GhostWhite;
521         display: grid;
522         grid-template-rows: auto auto auto auto 1fr auto;
523         grid-template-columns: auto 1fr;
524         grid-template-areas:
525                 'ctdl-compose-to-label ctdl-compose-to-line'
526                 'ctdl-compose-cc-label ctdl-compose-cc-field'
527                 'ctdl-compose-bcc-label ctdl-compose-bcc-field'
528                 'ctdl-compose-subject-label ctdl-compose-subject-field'
529                 'ctdl-compose-message-box ctdl-compose-message-box'
530                 'ctdl-compose-toolbar ctdl-compose-toolbar';
531         gap: 3px;
532 }
533
534 .ctdl-compose-to-label {
535         grid-area: ctdl-compose-to-label;
536         padding: 0.5vw;
537 }
538
539 .ctdl-compose-to-line {
540         grid-area: ctdl-compose-to-line;
541         padding-left: 0;
542         padding-right: 0.5vw;
543         padding-top: 0.5vw;
544         padding-bottom: 1px;
545         border-bottom: 1px solid Grey;
546         margin-right: 0.5vw;
547         display: flex;
548         flex-direction: row;
549         flex-wrap: nowrap;
550         margin: 0;
551         width: 100%;
552         height: 100%;
553         overflow: hidden;
554 }
555
556 .ctdl-compose-to-field {
557         flex-grow: 1;
558
559 }
560
561 .ctdl-compose-cc-label {
562         grid-area: ctdl-compose-cc-label;
563         padding: 0.5vw;
564         display: none;
565 }
566
567 .ctdl-compose-cc-field {
568         grid-area: ctdl-compose-cc-field;
569         border-bottom: 1px solid Grey;
570         margin-right: 0.5vw;
571         display: none;
572         padding-left: 0;
573         padding-right: 0.5vw;
574         padding-top: 0.5vw;
575         padding-bottom: 0;
576 }
577
578 .ctdl-compose-bcc-label {
579         grid-area: ctdl-compose-bcc-label;
580         padding: 0.5vw;
581         display: none;
582 }
583
584 .ctdl-compose-bcc-field {
585         grid-area: ctdl-compose-bcc-field;
586         padding-left: 0;
587         padding-right: 0.5vw;
588         padding-top: 0.5vw;
589         padding-bottom: 0;
590         border-bottom: 1px solid Grey;
591         margin-right: 0.5vw;
592         display: none;
593 }
594
595 .ctdl-compose-subject-label {
596         grid-area: ctdl-compose-subject-label;
597         padding: 0.5vw;
598 }
599
600 .ctdl-compose-subject-field {
601         grid-area: ctdl-compose-subject-field;
602         padding-left: 0;
603         padding-right: 0.5vw;
604         padding-top: 0.5vw;
605         padding-bottom: 0;
606         border-bottom: 1px solid Grey;
607         margin-right: 0.5vw;
608 }
609
610 .ctdl-compose-message-box {
611         grid-area: ctdl-compose-message-box;
612         overflow-x: wrap;
613         overflow-y: auto;
614         padding: 0.5vw;
615         border-bottom: 1px solid Grey;
616         margin-left: 0.5vw;
617         margin-right: 0.5vw;
618 }
619
620 .ctdl-compose-toolbar {
621         grid-area: ctdl-compose-toolbar;
622         overflow: none;
623         padding: 0.5vw;
624         display: flex;
625         flex-direction: row;
626         flex-wrap: nowrap;
627         justify-content: space-between;
628         align-items: center;
629         margin: 0:
630         width: 100%;
631         height: 100%;
632         overflow: hidden;
633 }
634
635 .ctdl-login-screen-grid-container {
636         display: grid;
637         grid-template-columns: auto auto;
638 }
639
640 .ctdl-login-screen-grid-item {
641         padding: 20px;
642         font-size: 1.25em;
643         vertical-align: middle;
644 }
645
646 .ctdl-login-screen-grid-item input {
647         height: 100%;
648         border: none;
649         font-size: 1.25em;
650 }
651
652 .ctdl-fatal-error {
653         background-color: DarkRed;
654         margin-left: 1em;
655         margin-right: 1em;
656         padding: 1em;
657         font-size: 2em;
658         color: White;
659 }