1 /* This Source Code Form is subject to the terms of the Mozilla Public
2 * License, v. 2.0. If a copy of the MPL was not distributed with this
3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
5 @import url("chrome://global/skin/in-content/common.css");
13 background-color: #9999CC;
16 .view-pane > .list > scrollbox {
21 /*** global warnings ***/
23 .global-warning-container {
28 -moz-box-align: center;
34 #addons-page[warning] .global-warning-container {
35 background-color: #FFFFCC;
38 #detail-view .global-warning {
40 border-bottom: 1px solid #9999CC;
43 @media (max-width: 600px) {
44 .global-warning-text {
48 .global-warning .warning-icon {
49 /* background-color: #FFF;
50 box-shadow: 0px 0px 2px 5px #FFF;
51 border-radius: 10px; */
55 /*** global informations ***/
57 /* Plugins aren't yet disabled by safemode (bug 342333),
58 so don't show that warning when viewing plugins. */
59 #addons-page[warning="safemode"] .view-pane[type="plugin"] .global-warning-container,
60 #addons-page[warning="safemode"] #detail-view[loading="true"] .global-warning-container {
61 background-color: inherit;
62 background-image: none;
65 /*** notification icons ***/
77 list-style-image: url("chrome://mozapps/skin/extensions/alerticon-warning.svg");
81 list-style-image: url("chrome://mozapps/skin/extensions/alerticon-error.svg");
86 list-style-image: url("chrome://mozapps/skin/extensions/alerticon-info-positive.svg");
89 .addon-view[pending="disable"] .pending-icon,
90 .addon-view[pending="uninstall"] .pending-icon {
91 list-style-image: url("chrome://mozapps/skin/extensions/alerticon-info-negative.svg");
94 /*** view alert boxes ***/
97 -moz-box-align: center;
102 .alert-spacer-before {
106 .alert-spacer-after {
111 -moz-box-align: center;
114 border: 1px inset #CCD0DD;
116 background-color: #CCD0DD;
117 background-clip: padding-box;
120 .alert .alert-title {
131 list-style-image: url("chrome://global/skin/icons/loading.gif");
137 list-style-image: url("chrome://mozapps/skin/extensions/alerticon-warning.svg");
140 /*** category selector ***/
146 .category[disabled] {
151 transition-property: min-height, opacity;
152 transition-duration: 1s, 0.8s;
155 .category:not([disabled]) {
157 transition-property: min-height, opacity;
158 transition-duration: 1s, 0.8s;
161 /* Maximize the size of the viewport when the window is small */
162 @media (max-width: 800px) {
169 background-color: #666699;
172 margin-inline-start: 6px;
179 .category-badge[value="0"] {
183 #category-search > .category-icon {
184 list-style-image: url("chrome://mozapps/skin/extensions/category-search.png");
186 #category-discover > .category-icon {
187 list-style-image: url("chrome://mozapps/skin/extensions/category-discover.png");
189 #category-locale > .category-icon {
190 list-style-image: url("chrome://mozapps/skin/extensions/category-languages.png");
192 #category-extension > .category-icon {
193 list-style-image: url("chrome://mozapps/skin/extensions/category-extensions.png");
195 #category-service > .category-icon {
196 list-style-image: url("chrome://mozapps/skin/extensions/category-service.png");
198 #category-theme > .category-icon {
199 list-style-image: url("chrome://mozapps/skin/extensions/category-themes.png");
201 #category-plugin > .category-icon {
202 list-style-image: url("chrome://mozapps/skin/extensions/category-plugins.png");
204 #category-dictionary > .category-icon {
205 list-style-image: url("chrome://mozapps/skin/extensions/category-dictionaries.png");
207 #category-experiment > .category-icon {
208 list-style-image: url("chrome://mozapps/skin/extensions/category-experiments.png");
210 #category-legacy > .category-icon {
211 list-style-image: url("chrome://mozapps/skin/extensions/category-legacy.svg");
213 #category-availableUpdates > .category-icon {
214 list-style-image: url("chrome://mozapps/skin/extensions/category-available.png");
216 #category-recentUpdates > .category-icon {
217 list-style-image: url("chrome://mozapps/skin/extensions/category-recent.png");
226 margin-inline-end: 48px;
229 @media (max-width: 600px) {
237 border-bottom: 1px solid #666699;
241 list-style-image: url("chrome://mozapps/skin/extensions/utilities.svg");
242 -moz-context-properties: fill;
244 margin-inline-end: 16px;
250 .header-button[disabled="true"] > .toolbarbutton-icon {
253 .header-button:not([disabled="true"]):hover,
254 #header-utils-btn:not([disabled="true"]):hover {
258 .header-button > .toolbarbutton-text {
263 list-style-image: url("chrome://communicator/skin/icons/communicatoricons.png");
267 border-inline-start: none;
270 #back-btn:-moz-locale-dir(ltr),
271 #forward-btn:-moz-locale-dir(rtl) {
272 -moz-image-region: rect(42px 25px 63px 0px);
275 #back-btn[disabled="true"]:-moz-locale-dir(ltr),
276 #forward-btn[disabled="true"]:-moz-locale-dir(rtl) {
277 -moz-image-region: rect(42px 50px 63px 25px);
280 #back-btn:-moz-locale-dir(rtl),
281 #forward-btn:-moz-locale-dir(ltr) {
282 -moz-image-region: rect(63px 25px 84px 0px);
285 #back-btn[disabled="true"]:-moz-locale-dir(rtl),
286 #forward-btn[disabled="true"]:-moz-locale-dir(ltr) {
287 -moz-image-region: rect(63px 50px 84px 25px);
293 -moz-appearance: none;
297 -moz-appearance: none;
298 border: 1px solid transparent;
299 background-color: transparent;
303 min-width: 12px !important;
304 -moz-box-direction: reverse;
307 .sorter .button-box {
313 border: 1px outset #666699;
316 .sorter[checkState="1"],
317 .sorter[checkState="2"] {
318 background-color: #666699;
320 border: 1px inset #666699;
323 .sorter[checkState="1"] {
324 list-style-image: url("chrome://global/skin/arrow/arrow-down.gif");
327 .sorter[checkState="2"] {
328 list-style-image: url("chrome://global/skin/arrow/arrow-up.gif");
331 .sorter .button-icon {
332 margin-inline-start: 4px;
336 /*** discover view ***/
338 .discover-spacer-before,
339 .discover-spacer-after {
343 #discover-error .alert {
349 list-style-image: url("chrome://mozapps/skin/extensions/discover-logo.png");
350 margin-inline-end: 15px;
356 /* font-family: MetaWebPro-Book, "Trebuchet MS", sans-serif; */
360 .discover-description {
374 border-width: 0 !important;
375 background-color: transparent;
378 .list > scrollbox > .scrollbox-innerbox {
379 border: 1px dotted transparent;
382 .list:-moz-focusring > scrollbox > .scrollbox-innerbox {
383 border-color: #9999CC;
387 border-bottom: 1px solid #9999CC;
389 background-origin: border-box;
392 .addon:not(:only-child):last-child {
393 border-bottom-width: 0;
399 margin-inline-start: 10px;
406 -moz-box-align: center;
407 -moz-box-pack: center;
411 list-style-image: url("chrome://mozapps/skin/extensions/extensionGeneric.svg");
416 .content-inner-container {
417 margin-inline-end: 5px;
420 .addon[active="false"] .icon {
421 filter: grayscale(1);
424 .addon-view[type="theme"] .icon {
425 list-style-image: url("chrome://mozapps/skin/extensions/themeGeneric.png");
428 .addon-view[type="locale"] .icon {
429 list-style-image: url("chrome://mozapps/skin/extensions/localeGeneric.png");
432 .addon-view[type="plugin"] .icon {
433 list-style-image: url("chrome://mozapps/skin/plugins/pluginGeneric.png");
436 .addon-view[type="dictionary"] .icon {
437 list-style-image: url("chrome://mozapps/skin/extensions/dictionaryGeneric.png");
440 .addon-view[type="experiment"] .icon {
441 list-style-image: url("chrome://mozapps/skin/extensions/experimentGeneric.png");
452 background-color: #FFFFCC;
454 padding: 4px 5px 3px;
457 -moz-user-focus: ignore;
460 .legacy-warning:hover {
461 background-color: #FFD0DD;
463 text-decoration: none;
466 #detail-view .legacy-warning {
474 .description-container {
475 margin-inline-start: 6px;
476 -moz-box-align: center;
487 margin-inline-start: 48px;
489 -moz-box-align: center;
493 .basicinfo-container {
494 -moz-box-align: start;
497 .addon[status="installing"] > .content-container {
498 -moz-box-align: stretch;
501 .update-info-container {
502 -moz-box-align: center;
509 .install-status-container {
514 .name-outer-container {
515 -moz-box-pack: center;
518 .relnotes-toggle-container,
519 .icon-outer-container {
520 -moz-box-pack: start;
528 .addon-view .warning {
536 .addon-view .pending {
540 .addon-view[pending="disable"] .pending,
541 .addon-view[pending="uninstall"] .pending {
545 .addon .relnotes-container {
546 -moz-box-align: start;
547 margin-inline-start: 6px;
551 transition-property: height, opacity;
552 transition-duration: 0.5s, 0.5s;
555 .addon[show-relnotes] .relnotes-container {
557 transition-property: height, opacity;
558 transition-duration: 0.5s, 0.5s;
561 .addon .relnotes-header {
566 .addon .relnotes-toggle {
568 background: transparent;
570 -moz-box-direction: reverse;
572 list-style-image: url("chrome://global/skin/arrow/arrow-down.gif");
575 .addon .relnotes-toggle > .button-box > .button-icon {
576 padding-inline-start: 4px;
579 .addon[show-relnotes] .relnotes-toggle {
580 list-style-image: url("chrome://global/skin/arrow/arrow-up.gif");
583 .addon-view[notification],
584 .addon-view[pending] {
585 --view-highlight-color: transparent;
587 background-image: radial-gradient(at 50% 0%,
588 var(--view-highlight-color) 0%,
591 background-color: var(--view-highlight-color);
594 .addon-view[notification="warning"] {
595 --view-highlight-color: #FFFFCC;
598 .addon-view[notification="error"] {
599 --view-highlight-color: #FFD0DD;
602 .addon-view[notification="info"] {
603 --view-highlight-color: #9999CC;
606 .addon-view[pending="enable"],
607 .addon-view[pending="upgrade"],
608 .addon-view[pending="install"] {
609 background-color: #CCFFDD;
612 .addon-view[pending="enable"] .pending,
613 .addon-view[pending="upgrade"] .pending,
614 .addon-view[pending="install"] .pending {
618 .addon-view[pending="disable"],
619 .addon-view[pending="uninstall"] {
620 --view-highlight-color: #808080;
624 background-color: #336699;
628 .addon[selected] .name-container {
632 #addon-list .addon[active="false"] > .content-container > .content-inner-container {
636 #addon-list .addon[active="false"][selected] > .content-container > .content-inner-container {
641 /*** item - uninstalled ***/
643 .addon[status="uninstalled"] {
647 .addon[status="uninstalled"] > .container {
648 -moz-box-align: center;
650 background-color: #808080;
655 .addon[status="uninstalled"][selected] {
656 background-color: transparent;
660 /*** search view ***/
667 border-bottom: 1px solid #666699;
671 #search-filter-label {
674 margin-inline-end: 10px;
677 #search-allresults-link {
683 /*** detail view ***/
685 #detail-view > .box-inherit {
690 #detail-view .loading {
694 #detail-view[loading-extended] .loading {
696 transition-property: opacity;
697 transition-duration: 1s;
700 .detail-view-container {
701 padding-inline-end: 2em;
707 #detail-notifications {
712 #detail-notifications .warning,
713 #detail-notifications .pending,
714 #detail-notifications .error {
715 margin-inline-start: 0;
718 #detail-icon-container {
720 margin-inline-end: 10px;
733 #detail-name-container {
738 #detail-screenshot-box {
739 margin-inline-end: 2em;
745 background-color: #FFFFFF;
748 #detail-screenshot[loading] {
749 background-image: url("chrome://communicator/skin/brand/throbber-anim.gif");
750 background-position: 50% 50%;
751 background-repeat: no-repeat;
754 #detail-screenshot[loading="error"] {
755 background-image: url("chrome://global/skin/icons/alert-error.gif");
758 #detail-desc-container {
762 #detail-desc, #detail-fulldesc {
763 margin-inline-start: 6px;
764 white-space: pre-wrap;
765 /* This is necessary to fix layout issues with multi-line descriptions, see
767 outline: solid transparent;
775 #detail-contributions {
777 border: 1px solid #666699;
780 background-color: #FFFFCC;
783 #detail-contrib-description {
789 #detail-contrib-suggested {
794 #detail-contrib-btn {
795 list-style-image: url("chrome://mozapps/skin/extensions/heart.png");
798 #detail-contrib-btn .button-icon {
799 margin-inline-end: 3px;
806 #detail-grid > columns > column:first-child {
811 .detail-row[first-row="true"],
812 .detail-row-complex[first-row="true"],
813 setting[first-row="true"] {
820 border-top: 1px solid #808080;
821 -moz-box-align: center;
829 #detail-view[active="false"]:not([pending]):not([notification]) {
830 /* background-color: foo; */
833 .inline-options-browser,
834 setting[first-row="true"] {
839 -moz-box-align: start;
842 .preferences-alignment {
844 -moz-box-align: center;
847 .preferences-description {
851 margin-inline-start: 2em;
852 white-space: pre-wrap;
855 .preferences-description:empty {
859 setting[type="radio"] > radiogroup {
860 -moz-box-orient: horizontal;
867 margin-inline-start: 0;
868 margin-inline-end: 0;
871 .creator > .text-link {
880 margin-inline-end: 0;
884 .meta-rating > .star {
885 list-style-image: url("chrome://mozapps/skin/extensions/rating-not-won.png");
889 .meta-rating > .star[on="true"] {
890 list-style-image: url("chrome://mozapps/skin/extensions/rating-won.png");
894 /*** download progress ***/
897 border: 1px solid #808080;
899 background-color: #CCD0DD;
905 .download-progress[mode="undetermined"] {
906 border-color: #666699;
909 .download-progress .start-cap,
910 .download-progress[complete] .end-cap,
911 .download-progress[mode="undetermined"] .end-cap,
912 .download-progress .progress .progress-bar {
913 background-color: #336699;
916 .download-progress .progress .progress-bar {
920 .download-progress .progress {
921 background-color: transparent;
927 .download-progress .start-cap,
928 .download-progress .end-cap {
932 .download-progress .start-cap:-moz-locale-dir(ltr),
933 .download-progress .end-cap:-moz-locale-dir(rtl) {
934 border-radius: 1px 0 0 1px;
937 .download-progress .end-cap:-moz-locale-dir(ltr),
938 .download-progress .start-cap:-moz-locale-dir(rtl) {
939 border-radius: 0 1px 1px 0;
942 .download-progress .cancel {
943 -moz-appearance: none;
951 .download-progress .cancel .button-box {
956 .download-progress .cancel .button-text {
960 .download-progress .cancel .button-icon {
961 margin-inline-start: 0;
964 .download-progress .cancel {
965 list-style-image: url('chrome://mozapps/skin/extensions/cancel.png');
968 .download-progress .status-container {
969 -moz-box-align: center;
972 .download-progress .status {
973 /* text-shadow: #FFF 0 0 2px; */
976 /*** install status ***/
979 -moz-box-align: center;
983 /*** check for updates ***/
986 -moz-box-align: center;
989 #updates-container .button-link {
994 #updates-downloaded {
1006 .addon-control[disabled="true"]:not(.no-auto-hide) {
1010 .no-auto-hide .addon-control {
1011 display: block !important;
1014 button.button-link {
1015 background: transparent;
1025 button.button-link:hover {
1026 background-color: transparent;
1028 text-decoration: underline;
1031 /* Needed to override normal button style from inContent.css */
1032 button.button-link:not([disabled="true"]):active:hover {
1035 .addon-control.replacement {
1036 background-color: #008484;
1040 /*** telemetry experiments ***/
1042 #detail-experiment-container {
1047 #detail-experiment-bullet-container,
1048 #detail-experiment-state,
1049 #detail-experiment-time,
1050 .experiment-bullet-container,
1053 vertical-align: middle;
1054 display: inline-block;
1057 .addon .experiment-bullet,
1058 #detail-experiment-bullet {
1062 .addon[active="true"] .experiment-bullet,
1063 #detail-view[active="true"] #detail-experiment-bullet {
1067 /*** info UI for add-ons that have been disabled for being unsigned ***/
1069 #show-disabled-unsigned-extensions:not(:hover) {
1070 background-color: #FFFFCC;
1073 #disabled-unsigned-addons-info {
1079 #disabled-unsigned-addons-heading,
1080 #legacy-extensions-heading {
1083 margin-bottom: .5em;
1090 #detail-findUpdates-btn[hidden] {