Source code
Revision control
Copy as Markdown
Other Tools
/* 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
: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;
}
:root[subdialog] {
/* Ensure we don't crop stuff */
width: min-content;
/* use flexbox instead of grid: */
dialog,
#dialogGrid,
#infoContainer,
.dialogRow:not([hidden]) {
display: flex;
flex-direction: column;
align-items: stretch;
}
#iconContainer {
display: none;
}
/* Fix padding/spacing */
dialog {
--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);
&::part(dialog-button) {
/* Adjust vertical margins for buttons in subdialogs. */
margin: 0 4px;
min-width: auto;
}
}
description,
checkbox {
margin: 0 4px;
}
label {
margin: 4px; /* Labels for input boxes should get block as well as the regular inline margin. */
}
.checkbox-label {
/* The checkbox already has the horizontal margin, so override the rule
* above. */
margin: 0;
}
input {
margin: 0 4px 4px;
}
/* Add vertical spaces between rows: */
.dialogRow {
margin-block: 0 var(--grid-padding);
}
/* Fix spacing in the `prompt()` case: */
#loginLabel[value=""] {
display: none;
}
}