зеркало из https://github.com/mozilla/snowl.git
168 строки
4.4 KiB
CSS
168 строки
4.4 KiB
CSS
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/MPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
* for the specific language governing rights and limitations under the
|
|
* License.
|
|
*
|
|
* The Original Code is Snowl.
|
|
*
|
|
* The Initial Developer of the Original Code is Mozilla.
|
|
* Portions created by the Initial Developer are Copyright (C) 2008
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
* Myk Melez <myk@mozilla.org>
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
* the provisions above, a recipient may use your version of this file under
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
/* BEGIN RULES WE UPDATE DYNAMICALLY BY INDEX */
|
|
|
|
/* Put nothing above this comment without updating the hardcoded indexes
|
|
* referencing these rules in stream.js. */
|
|
|
|
/* This box must be flexible or have an explicit width or maximum width
|
|
* in order for its content to wrap. In theory, the best option would be
|
|
* a flexible width, but Mozilla doesn't wrap URLs in text until the path
|
|
* portion of the URL, which makes the middle column too wide when we use
|
|
* a flexible width and one of the messages contains a URL with a long hostname,
|
|
* so instead we specify an explicit width that we update dynamically
|
|
* as the width of the sidebar changes. */
|
|
.body {}
|
|
|
|
/* This box must be the same width as its container or it'll remain as wide
|
|
* as the width of its widest word, creating uneven widths between messages
|
|
* once the sidebar becomes narrower than the width of any word. */
|
|
.body > div {}
|
|
|
|
/* We don't have to update this box's width dynamically, but if we don't,
|
|
* then it might be a pixel or so off depending on the width of its content. */
|
|
.centerColumn {}
|
|
|
|
/* END RULES WE UPDATE DYNAMICALLY BY INDEX */
|
|
|
|
|
|
#contentBox {
|
|
-moz-user-focus: normal;
|
|
-moz-user-select: -moz-all;
|
|
|
|
/* Make it look like content rather than the chrome in which it is embedded. */
|
|
color: black;
|
|
background-color: white;
|
|
|
|
/* Use all available vertical space in the sidebar and scroll vertically. */
|
|
-moz-box-flex: 1;
|
|
overflow-y: auto;
|
|
|
|
/* Don't scroll horizontally even if content overflows (the user can expand
|
|
* the sidebar to see the overflowed content). */
|
|
overflow-x: hidden;
|
|
}
|
|
|
|
/* Separate each adjacent message from the one before it. */
|
|
.message + .message {
|
|
margin-top: 6px;
|
|
border-top: 1px solid lightgrey;
|
|
padding-top: 3px;
|
|
}
|
|
|
|
.leftColumn {
|
|
width: 24px;
|
|
-moz-box-align: center;
|
|
margin-right: 4px;
|
|
}
|
|
|
|
/* The content in the center column shouldn't have its own margins,
|
|
* as that'll mess up the spacing between the center column and the nodes
|
|
* around it. */
|
|
.centerColumn > description {
|
|
margin: 0;
|
|
}
|
|
|
|
.rightColumn {
|
|
width: 16px;
|
|
margin-left: 2px;
|
|
}
|
|
|
|
.author {
|
|
font-weight: bold;
|
|
}
|
|
|
|
.timestamp {
|
|
font-weight: lighter;
|
|
font-size: smaller;
|
|
}
|
|
|
|
.icon {
|
|
max-width: 24px;
|
|
max-height: 24px;
|
|
}
|
|
|
|
|
|
/******************************************************************************/
|
|
/* Border styles to clarify the structure for debugging purposes. */
|
|
|
|
/*
|
|
.leftColumn {
|
|
border: 1px solid red;
|
|
}
|
|
|
|
.centerColumn {
|
|
border: 1px solid green;
|
|
}
|
|
|
|
.rightColumn {
|
|
border: 1px solid blue;
|
|
}
|
|
*/
|
|
|
|
/*
|
|
#contentBox {
|
|
outline: 1px solid yellow;
|
|
}
|
|
|
|
.message {
|
|
outline: 1px solid purple;
|
|
}
|
|
|
|
.leftColumn {
|
|
outline: 1px solid red;
|
|
}
|
|
|
|
.centerColumn {
|
|
outline: 1px solid green;
|
|
}
|
|
|
|
.rightColumn {
|
|
outline: 1px solid blue;
|
|
}
|
|
|
|
.author,
|
|
.timestamp {
|
|
outline: 1px solid orange;
|
|
}
|
|
|
|
.body {
|
|
outline: 1px solid blue;
|
|
}
|
|
*/
|