summaryrefslogtreecommitdiffstats
path: root/toolkit/components/prompts/content/commonDialog.css
blob: 3521af13c6ed7bc1c0d337f5943f4d4b85f774fd (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
123
124
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

:root {
  min-width: 29em;
}

dialog[insecureauth] {
  --icon-url: url("chrome://global/skin/icons/security-broken.svg");
}

#dialogGrid {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  max-height: 100%;
}

.dialogRow:not([hidden]) {
  display: contents;
}

#iconContainer {
  align-self: start;
}

#infoContainer {
  max-width: 45em;
}

#infoTitle {
  margin-bottom: 1em;
}

#infoBody {
  -moz-user-focus: normal;
  user-select: text;
  cursor: text !important;
  white-space: pre-wrap;
  word-break: break-word;
  unicode-bidi: plaintext;
  overflow-y: auto;
}

.sizeDetermined,
.sizeDetermined::part(content-box),
.sizeDetermined #infoBody,
.sizeDetermined #infoRow,
.sizeDetermined #infoContainer {
  /* Allow stuff to shrink */
  min-height: 0;
}

.sizeDetermined #infoRow {
  /* Make the info row take all the available space, potentially shrinking,
   * since it's what contains the infoBody, which is scrollable */
  flex: 1;
}

#loginLabel, #password1Label {
  text-align: start;
}

#loginTextbox,
#password1Textbox {
  text-align: match-parent;
}

/* use flexbox instead of grid: */
dialog[subdialog],
dialog[subdialog] #dialogGrid,
dialog[subdialog] #infoContainer,
dialog[subdialog] .dialogRow:not([hidden]) {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

dialog[subdialog] #iconContainer {
  display: none;
}

/* Fix padding/spacing */
dialog[subdialog] {
  --grid-padding: 16px;
  /* All the inner items should have 4px inline margin, leading to 1.16em spacing
   * between the dialog and its contents, and 8px horizontal spacing between items. */
  padding: var(--grid-padding) calc(var(--grid-padding) - 4px);
}

/* Use an ID selector for the dialog to win on specificity... */
#commonDialog[subdialog] description,
#commonDialog[subdialog] checkbox {
  margin: 0 4px;
}

#commonDialog[subdialog] label {
  margin: 4px; /* Labels for input boxes should get block as well as the regular inline margin. */
}

#commonDialog[subdialog] .checkbox-label {
  /* The checkbox already has the horizontal margin, so override the rule
   * above. */
  margin: 0;
}

#commonDialog[subdialog] input {
  margin: 0 4px 4px;
}

/* Add vertical spaces between rows: */
dialog[subdialog] .dialogRow {
  margin-block: 0 var(--grid-padding);
}

/* Fix spacing in the `prompt()` case: */
dialog[subdialog] #loginLabel[value=""] {
  display: none;
}

dialog[subdialog][windowtype="prompt:prompt"] #infoRow {
  margin-bottom: 4px;
}