Mailspring/internal_packages/composer/stylesheets/composer.less
Evan Morikawa e7868df1ad feat(contenteditable): a React compatible contenteditable
Summary:
toolbar popup displays

restore caret protection on contenteditable

BAD - can't use cursor saving and restoring with react :(

_findNode works

saves and restores cursor state

contenteditable fixes to support cursor

comments on cursor

initial undo manager

extract undo manager and move up in stack

make undo manager a mixin

adding selection snapshots in composer

fixes in undo manager

selection saves selection states properly

move UndoManager and fix draft

selection state can now select backwards

selection works backwards and click not overridden

change bold class to allow for bolding and unbolding

styling of hover component

can set links in composer

bold and italic clicking works. text seleciton works

show link modal on hover

selection fixes

Test Plan: TODO

Reviewers: bengotow

Reviewed By: bengotow

Differential Revision: https://review.inboxapp.com/D1249
2015-03-02 15:33:58 -08:00

273 lines
5.5 KiB
Plaintext

// The ui-variables file is provided by base themes provided by Atom.
//
// See https://github.com/atom/atom-dark-ui/blob/master/stylesheets/ui-variables.less
// for a full listing of what's available.
@import "ui-variables";
@import "ui-mixins";
@import "buttons";
.composer-full-window {
width: 100%;
height: 100%;
.composer-outer-wrap {
width: 100%;
height: 100%;
}
.composer-inner-wrap {
.compose-body {
margin-bottom: 0;
position: relative;
.contenteditable-container {
position: absolute;
width: 100%;
min-height: 100%;
div[contenteditable] {
// Ensure that the contentEditable always fills the window,
// but leaves room for the quoted text marker at the bottom.
min-height: calc(~"100% - 30px");
}
}
}
}
}
.toolbar {
@padding: 0.5em;
.btn {
background: transparent;
font-size: 16px;
height: auto;
border-radius: 0;
padding: @padding*0.75 @padding;
margin: 0;
color: rgba(255,255,255, 0.6);
box-shadow: none;
&:first-child {
padding-left: 1.5*@padding;
}
&:last-child {
padding-right: 1.5*@padding;
}
&:hover, &:active {
color: rgba(255,255,255, 1);
background: transparent;
}
}
.preview-btn-icon {
position: relative;
top: 1px;
padding: 0 @padding;
}
}
.composer-inner-wrap {
height: 100%;
display: flex;
flex-flow: column;
padding-bottom: 57px;
position: relative;
a:hover {
cursor: pointer;
}
.floating-toolbar {
z-index: 10;
position: absolute;
background: @background-color-accent;
border-radius: 2px;
color: @text-color-inverse;
.toolbar-pointer {
content: " ";
position: absolute;
width: 0;
height: 0;
top: -13px;
left: 50%;
margin-left: -6px;
border: 7px solid transparent;
border-bottom-color: @background-color-accent;
border-bottom-width: 6px;
}
.floating-toolbar-input {
display: inline;
width: auto;
color: @text-color-inverse;
position: relative;
top: 1px;
}
}
.composer-header {
padding: 11px 15px 5px 15px;
.composer-title {
display: inline-block;
.bold;
}
.composer-header-actions {
float: right;
color: @text-color-subtle;
font-size: @minor-font-size;
}
.header-action {
padding-left: 1em;
&:hover {
color: @text-color-link;
cursor: pointer;
}
}
}
input, textarea, div[contenteditable] {
position: relative;
z-index: 1;
display: block;
background: inherit;
width: 100%;
resize: none;
border: none;
}
.compose-toolbar-wrap {
display: inline-block;
> button {
margin-left: 5px;
}
}
.compose-toolbar {
display: none;
box-shadow: @standard-shadow;
padding: 1px 1px 2px 1px;
position: absolute;
background: white;
z-index: 2;
bottom: 48px;
margin-left: -37.5px;
}
[disabled] {
background: rgba(0, 0, 0, 0.2);
}
.btn-send {
.btn-variant(@action-color);
margin-right: 15px;
}
.compose-participants-wrap {
padding: 5px 15px 0 15px;
}
.compose-subject-wrap {
margin: 9px 15px 0 15px;
input {
font-size: @major-font-size;
height:30px;
}
}
.compose-body {
flex: 1;
display: flex;
cursor: text;
overflow: auto;
position: relative;
.quoted-text-control {
position: absolute;
bottom: 10px;
left: 15px;
margin: 0;
}
div[contenteditable] {
min-height: 150px;
padding: 0.7em 15px 0 15px;
margin-bottom: 37px;
}
.contenteditable-container {
width: 100%;
}
}
.compose-field {
border-bottom: 1px solid @border-color-divider;
}
.compose-footer {
padding: 10px 15px;
background: @background-color-accent;
position: absolute;
width: 100%;
bottom: 0;
text-align: left;
.btn-icon {
position: relative;
top: 2px;
margin-right:0;
color:rgba(255,255,255, 0.6);
box-shadow:none;
&:hover,&:active {
background-color:transparent;
color:rgba(255,255,255, 1);
}
}
}
// TODO FIXME DRY From stylesheets/message-list.less
.attachments-area {
padding: 0px 15px 0px 15px;
border-top: 1px solid @border-color-divider;
.attachment-file-wrap {
padding-top: 5px;
&.pending, &.started, &.progress {
color: @text-color-subtle;
.attachment-file-actions { visibility: visible; }
.attachment-file-and-name:hover { cursor: default; color: @text-color-subtle; }
}
&.completed, &.success {
color: @text-color-success; // Success state
.attachment-file-actions { visibility: hidden; }
.attachment-file-and-name:hover { cursor: default; color: @text-color-success; }
.attachment-upload-progress { background: @background-color-success; }
}
&.aborted, &.failed {
color: @text-color-error;
.attachment-file-actions { visibility: hidden; }
.attachment-file-and-name:hover { cursor: default; color: @text-color-error; }
.attachment-upload-progress { background: @background-color-error; }
}
}
.attachment-file-actions {
margin-left: 0.4em;
}
}
}
#new-compose-button {
order: 1;
background: @background-color-accent;
padding: 10px 15px 13px 15px;
text-align: center;
.btn-compose {
.btn-variant(@action-color);
}
}