Merge pull request #34 from asaadmahmood/ui-updates

Updating Application UI
This commit is contained in:
Chen-I Lim 2021-01-27 10:14:09 -08:00 committed by GitHub
commit c812b5dc98
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
61 changed files with 300 additions and 187 deletions

View file

@ -121,7 +121,7 @@
"ViewHeader.export-board-archive": "Export board archive", "ViewHeader.export-board-archive": "Export board archive",
"ViewHeader.export-csv": "Export to CSV", "ViewHeader.export-csv": "Export to CSV",
"ViewHeader.filter": "Filter", "ViewHeader.filter": "Filter",
"ViewHeader.group-by": "Group by {property}", "ViewHeader.group-by": "Group by: {property}",
"ViewHeader.new": "New", "ViewHeader.new": "New",
"ViewHeader.properties": "Properties", "ViewHeader.properties": "Properties",
"ViewHeader.search": "Search", "ViewHeader.search": "Search",

View file

@ -57,7 +57,7 @@
"ViewHeader.export-board-archive": "Exportar Archivo del Panel", "ViewHeader.export-board-archive": "Exportar Archivo del Panel",
"ViewHeader.export-csv": "Exportar a CSV", "ViewHeader.export-csv": "Exportar a CSV",
"ViewHeader.filter": "Filtrar", "ViewHeader.filter": "Filtrar",
"ViewHeader.group-by": "Agrupar por {property}", "ViewHeader.group-by": "Agrupar por: {property}",
"ViewHeader.new": "Nueva", "ViewHeader.new": "Nueva",
"ViewHeader.properties": "Propiedades", "ViewHeader.properties": "Propiedades",
"ViewHeader.search": "Buscar", "ViewHeader.search": "Buscar",

View file

@ -8,7 +8,7 @@
align-items: center; align-items: center;
justify-content: center; justify-content: center;
&:not(.readonly):hover { &:not(.readonly):hover {
background-color: rgba(var(--main-fg), 0.1); background-color: rgba(var(--body-color), 0.1);
} }
&.size-s { &.size-s {
height: 24px; height: 24px;

View file

@ -7,16 +7,16 @@
border-radius: 3px; border-radius: 3px;
margin-bottom: 10px; margin-bottom: 10px;
padding: 7px 10px; padding: 8px 16px;
box-shadow: rgba(var(--main-fg), 0.1) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 2px 4px; box-shadow: rgba(var(--body-color), 0.1) 0px 0px 0px 1px, rgba(var(--body-color), 0.1) 0px 2px 4px;
cursor: pointer; cursor: pointer;
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
transition: background 100ms ease-out 0s; transition: background 100ms ease-out 0s;
&:hover { &:hover {
background-color: rgba(var(--main-fg), 0.1); background-color: rgba(var(--body-color), 0.1);
.optionsMenu { .optionsMenu {
display: block; display: block;
} }
@ -32,13 +32,14 @@
right: 0; right: 0;
} }
> div {
margin-bottom: 3px;
}
> .octo-propertyvalue { > .octo-propertyvalue {
margin: 4px 0 0;
font-size: 12px; font-size: 12px;
line-height: 18px; line-height: 18px;
&:empty {
display: none;
}
} }
.octo-icontitle { .octo-icontitle {
@ -54,8 +55,8 @@
border-radius: 3px; border-radius: 3px;
margin-right: 6px; margin-right: 6px;
padding: 0; padding: 0;
background: rgb(var(--main-fg), 0.1); background: rgb(var(--body-color), 0.1);
box-shadow: rgba(var(--main-fg), 0.1) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 2px 4px; box-shadow: rgba(var(--body-color), 0.1) 0px 0px 0px 1px, rgba(var(--body-color), 0.1) 0px 2px 4px;
height: 24px; height: 24px;
width: 24px; width: 24px;
} }

View file

@ -11,8 +11,7 @@
flex-direction: row; flex-direction: row;
min-height: 30px; min-height: 30px;
margin-bottom: 10px; margin-bottom: 16px;
padding: 0px 10px;
color: #909090; color: #909090;
} }
@ -30,13 +29,17 @@
} }
> div { > div {
margin-right: 5px; margin-right: 8px;
&:last-child {
margin: 0;
}
} }
.IconButton{ .IconButton{
background-color: unset; background-color: unset;
&:hover { &:hover {
background-color: rgba(var(--main-fg), 0.1); background-color: rgba(var(--body-color), 0.1);
} }
} }
} }
@ -45,7 +48,6 @@
.octo-board-body { .octo-board-body {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
padding: 0 10px;
flex: 0 1 auto; flex: 0 1 auto;
} }

View file

@ -7,7 +7,7 @@
display: flex; display: flex;
flex-direction: column; flex-direction: column;
min-height: 30px; min-height: 30px;
color:rgba(var(--main-fg), 0.4); color:rgba(var(--body-color), 0.4);
width: 100%; width: 100%;
align-items: flex-start; align-items: flex-start;
.Button { .Button {
@ -44,20 +44,20 @@
.octo-propertyname { .octo-propertyname {
width: 150px; width: 150px;
margin-right: 5px; margin-right: 5px;
color: rgba(var(--main-fg), 0.6); color: rgba(var(--body-color), 0.6);
.Button { .Button {
text-align: left; text-align: left;
justify-content: unset; justify-content: unset;
} }
&.add-property { &.add-property {
color: rgba(var(--main-fg), 0.4); color: rgba(var(--body-color), 0.4);
} }
} }
&.add-content { &.add-content {
.Button { .Button {
opacity: 0; opacity: 0;
color: rgba(var(--main-fg), 0.6); color: rgba(var(--body-color), 0.6);
} }
&:hover { &:hover {
.Button { .Button {

View file

@ -40,7 +40,7 @@
} }
.comment-text { .comment-text {
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
width: 100%; width: 100%;
padding-left: 25px; padding-left: 25px;
} }

View file

@ -18,7 +18,7 @@
} }
.newcomment { .newcomment {
color: rgba(var(--main-fg), 0.8); color: rgba(var(--body-color), 0.8);
flex-grow: 1; flex-grow: 1;
margin-left: 5px; margin-left: 5px;
} }

View file

@ -9,7 +9,7 @@
} }
.divider { .divider {
padding-top: 16px; padding-top: 16px;
border-bottom: 1px solid rgba(var(--main-fg), 0.09); border-bottom: 1px solid rgba(var(--body-color), 0.09);
margin-bottom: 17px; margin-bottom: 17px;
flex-grow: 1; flex-grow: 1;
} }

View file

@ -7,16 +7,15 @@
bottom: 0; bottom: 0;
z-index: 10; z-index: 10;
background-color: rgba(var(--main-fg), 0.5); background-color: rgba(var(--body-color), 0.5);
} }
.dialog { .dialog {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
background-color: rgb(var(--main-bg)); background-color: rgb(var(--main-bg));
border-radius: 3px; box-shadow: rgba(var(--body-color), 0.1) 0px 0px 0px 1px, rgba(var(--body-color), 0.1) 0px 2px 4px;
box-shadow: rgba(var(--main-fg), 0.1) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 2px 4px; border-radius: var(--modal-rad);
padding: 0; padding: 0;
overflow-x: hidden; overflow-x: hidden;
@ -54,8 +53,7 @@
> .toolbar { > .toolbar {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
height: 30px; padding: 16px;
margin: 10px;
} }
> .content { > .content {
display: flex; display: flex;

View file

@ -54,11 +54,14 @@ export default class Dialog extends React.PureComponent<Props> {
onClick={this.closeClicked} onClick={this.closeClicked}
icon={<CloseIcon/>} icon={<CloseIcon/>}
title={'Close dialog'} title={'Close dialog'}
className='hideOnWidescreen' className='hideOnWidescreen IconButton--large'
/> />
<div className='octo-spacer'/> <div className='octo-spacer'/>
<MenuWrapper> <MenuWrapper>
<IconButton icon={<OptionsIcon/>}/> <IconButton
className='IconButton--large'
icon={<OptionsIcon/>}
/>
{toolsMenu} {toolsMenu}
</MenuWrapper> </MenuWrapper>
</> </>

View file

@ -1,12 +1,12 @@
.Modal { .Modal {
position: absolute; position: absolute;
top: 25px; top: 25px;
left: -230px; left: -240px;
z-index: 10; z-index: 10;
background-color: rgb(var(--main-bg)); background-color: rgb(var(--main-bg));
padding: 10px; padding: 10px;
border-radius: 3px; border-radius: 3px;
box-shadow: rgba(var(--main-fg), 0.05) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 3px 6px, rgba(var(--main-fg), 0.2) 0px 9px 24px; box-shadow: var(--elevation-4);
@media screen and (max-width: 430px) { @media screen and (max-width: 430px) {
position: fixed; position: fixed;

View file

@ -2,7 +2,7 @@
display: flex; display: flex;
flex-direction: column; flex-direction: column;
padding: 5px; padding: 5px;
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
font-weight: normal; font-weight: normal;
line-height: normal; line-height: normal;

View file

@ -2,7 +2,7 @@
display: flex; display: flex;
flex-direction: column; flex-direction: column;
padding: 5px; padding: 5px;
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
max-width: 400px; max-width: 400px;
> .row { > .row {

View file

@ -1,5 +1,5 @@
.Sidebar { .Sidebar {
flex: 0 0 230px; flex: 0 0 240px;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@ -7,7 +7,7 @@
min-height: 100%; min-height: 100%;
color: rgb(var(--sidebar-fg)); color: rgb(var(--sidebar-fg));
background-color: rgb(var(--sidebar-bg)); background-color: rgb(var(--sidebar-bg));
padding-top: 10px; padding: 12px 0;
&.hidden { &.hidden {
position: absolute; position: absolute;
@ -19,6 +19,7 @@
width: 50px; width: 50px;
background: none; background: none;
padding: 0; padding: 0;
>div { >div {
padding: 0; padding: 0;
margin: auto; margin: auto;
@ -34,6 +35,10 @@
flex: 1 1 auto; flex: 1 1 auto;
overflow-y: auto; overflow-y: auto;
max-width: 250px; max-width: 250px;
>div {
margin-bottom: 16px;
}
} }
.octo-sidebar-header { .octo-sidebar-header {
@ -42,7 +47,14 @@
font-weight: 600; font-weight: 600;
padding: 3px 20px; padding: 3px 20px;
margin-bottom: 5px; margin-bottom: 16px;
height: 48px;
align-items: center;
button {
font-size: 16px;
font-weight: 600;
}
>.heading { >.heading {
line-height: 30px; line-height: 30px;
@ -51,6 +63,7 @@
>.IconButton { >.IconButton {
background-color: var(--sidebar-bg); background-color: var(--sidebar-bg);
&:hover { &:hover {
background-color: rgba(var(--sidebar-fg), 0.1); background-color: rgba(var(--sidebar-fg), 0.1);
} }
@ -60,13 +73,16 @@
.hamburger-icon { .hamburger-icon {
display: block; display: block;
} }
.show-icon { .show-icon {
display: none; display: none;
} }
&:hover { &:hover {
.hamburger-icon { .hamburger-icon {
display: none; display: none;
} }
.show-icon { .show-icon {
display: block; display: block;
} }
@ -77,19 +93,24 @@
.octo-sidebar-item { .octo-sidebar-item {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
font-weight: 500; font-weight: 500;
padding: 3px 20px; padding: 0 16px 0 8px;
height: 36px;
align-items: center;
&:hover { &:hover {
background-color: rgba(var(--sidebar-fg), 0.05); background-color: rgba(var(--sidebar-fg), 0.08);
} }
&.subitem { &.subitem {
color: rgba(var(--sidebar-fg), 0.6); padding-left: 20px;
color: rgba(var(--sidebar-fg), 0.64);
font-weight: 400; font-weight: 400;
margin-left: 20px;
} }
&.no-views { &.no-views {
color: rgba(var(--sidebar-fg), 0.4); color: rgba(var(--sidebar-fg), 0.4);
&:hover { &:hover {
background-color: rgba(var(--sidebar-bg)); background-color: rgba(var(--sidebar-bg));
} }
@ -97,15 +118,19 @@
>.IconButton { >.IconButton {
background-color: var(--sidebar-bg); background-color: var(--sidebar-bg);
&:hover { &:hover {
background-color: rgba(var(--sidebar-fg), 0.1); background-color: rgba(var(--sidebar-fg), 0.1);
} }
} }
.MenuWrapper { .MenuWrapper {
display: none; display: none;
} }
&:hover { &:hover {
display: flex; display: flex;
.MenuWrapper { .MenuWrapper {
display: block; display: block;
} }
@ -116,6 +141,7 @@
transform: rotate(90deg); transform: rotate(90deg);
} }
} }
.DisclosureTriangleIcon { .DisclosureTriangleIcon {
transition: 200ms ease-in-out; transition: 200ms ease-in-out;
transform: rotate(0deg); transform: rotate(0deg);
@ -123,6 +149,7 @@
} }
.octo-sidebar-title { .octo-sidebar-title {
font-weight: 600;
cursor: pointer; cursor: pointer;
flex-grow: 1; flex-grow: 1;
white-space: nowrap; white-space: nowrap;
@ -130,7 +157,9 @@
text-overflow: ellipsis; text-overflow: ellipsis;
} }
.OptionsIcon, .DisclosureTriangleIcon, .DotIcon { .OptionsIcon,
.DisclosureTriangleIcon,
.DotIcon {
fill: rgba(var(--sidebar-fg), 0.5); fill: rgba(var(--sidebar-fg), 0.5);
flex-shrink: 0; flex-shrink: 0;
} }

View file

@ -285,12 +285,12 @@ class Sidebar extends React.Component<Props, State> {
</MenuWrapper> </MenuWrapper>
<MenuWrapper> <MenuWrapper>
<Button> <div className='octo-sidebar-item subitem'>
<FormattedMessage <FormattedMessage
id='Sidebar.settings' id='Sidebar.settings'
defaultMessage='Settings' defaultMessage='Settings'
/> />
</Button> </div>
<Menu position='top'> <Menu position='top'>
<Menu.Text <Menu.Text
id='import' id='import'

View file

@ -2,22 +2,24 @@
.octo-table-cell { .octo-table-cell {
flex: 0 0 auto; flex: 0 0 auto;
display: flex; display: flex;
align-items: center;
flex-direction: row; flex-direction: row;
color: rgb(var(--body-color));
color: rgb(var(--main-fg)); border-right: solid 1px rgba(var(--body-color), 0.09);
border-right: solid 1px rgba(var(--main-fg), 0.09);
box-sizing: border-box; box-sizing: border-box;
padding: 5px 8px 6px 8px; padding: 8px;
min-height: 32px; min-height: 32px;
font-size: 14px; font-size: 14px;
line-height: 21px; line-height: 20px;
position: relative; position: relative;
&.title-cell {
padding-left: 16px;
}
.octo-icontitle { .octo-icontitle {
flex: 1 1 auto; flex: 1 1 auto;
.octo-icon { .octo-icon {
min-width: 20px; min-width: 20px;
} }
@ -60,8 +62,7 @@
} }
.octo-editable, .octo-editable,
.octo-propertyvalue .octo-propertyvalue {
{
text-align: left; text-align: left;
white-space: nowrap; white-space: nowrap;
} }
@ -70,7 +71,6 @@
.octo-table-body { .octo-table-body {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
padding: 0 10px;
} }
.octo-table-header, .octo-table-header,
@ -79,28 +79,30 @@
display: flex; display: flex;
flex-direction: row; flex-direction: row;
border-bottom: solid 1px rgba(var(--main-fg), 0.09); border-bottom: solid 1px rgba(var(--body-color), 0.09);
} }
.octo-table-header { .octo-table-header {
.octo-table-cell { .octo-table-cell {
color: rgba(var(--main-fg), 0.6); color: rgba(var(--body-color), 0.6);
.octo-label { .octo-label {
color: rgba(var(--main-fg), 0.6); color: rgba(var(--body-color), 0.6);
} }
} }
} }
.octo-table-footer { .octo-table-footer {
.octo-table-cell { .octo-table-cell {
color: rgba(var(--main-fg), 0.6); color: rgba(var(--body-color), 0.6);
cursor: pointer; cursor: pointer;
width: 100%; width: 100%;
border-right: none; border-right: none;
padding-left: 15px; padding-left: 15px;
&:hover { &:hover {
background-color: rgba(var(--main-fg), 0.08); background-color: rgba(var(--body-color), 0.08);
} }
} }
} }

View file

@ -116,7 +116,7 @@ class TableComponent extends React.Component<Props, State> {
<div <div
id='mainBoardHeader' id='mainBoardHeader'
ref={titleRef} ref={titleRef}
className='octo-table-cell title-cell header-cell' className='octo-table-cell header-cell'
style={{overflow: 'unset', width: this.columnWidth(Constants.titleColumnId)}} style={{overflow: 'unset', width: this.columnWidth(Constants.titleColumnId)}}
> >
<MenuWrapper <MenuWrapper

View file

@ -1,11 +1,18 @@
.TableRow { .TableRow {
.open-button { .open-button {
display: none; display: none;
.Button { .Button {
background-color: rgba(var(--main-fg), 0.1); padding: 2px 4px;
box-shadow: rgba(var(--main-fg), 0.1) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 2px 4px; font-size: 11px;
text-transform: uppercase;
font-weight: 600;
color: rgba(var(--body-color), .64);
background-color: rgba(var(--body-color), 0.1);
box-shadow: rgba(var(--body-color), 0.1) 0px 0px 0px 1px, rgba(var(--body-color), 0.1) 0px 2px 4px;
} }
} }
&:hover { &:hover {
.open-button { .open-button {
display: block; display: block;

View file

@ -3,15 +3,19 @@
display: flex; display: flex;
flex-direction: row; flex-direction: row;
border-bottom: solid 1px rgba(var(--main-fg), 0.16); border-bottom: solid 1px rgba(var(--body-color), 0.16);
margin-bottom: 10px; margin: 16px 0;
padding: 10px 10px; padding: 12px 8px;
color: rgba(var(--main-fg), 0.5); color: rgba(var(--body-color), 0.64);
align-items: center; align-items: center;
> div { > div {
margin-right: 5px; margin-right: 16px;
white-space: nowrap white-space: nowrap;
&:last-child {
margin: 0;
}
} }
#groupByLabel { #groupByLabel {
@ -21,7 +25,7 @@
.IconButton { .IconButton {
background: none; background: none;
&:hover { &:hover {
background: rgba(var(--main-fg), 0.1); background: rgba(var(--body-color), 0.1);
} }
} }

View file

@ -137,7 +137,7 @@ class ViewHeader extends React.Component<Props, State> {
<Button> <Button>
<FormattedMessage <FormattedMessage
id='ViewHeader.group-by' id='ViewHeader.group-by'
defaultMessage='Group by {property}' defaultMessage='Group by: {property}'
values={{ values={{
property: ( property: (
<span <span

View file

@ -8,7 +8,7 @@
&.add-buttons { &.add-buttons {
flex-direction: row; flex-direction: row;
min-height: 30px; min-height: 30px;
color:rgba(var(--main-fg), 0.4); color:rgba(var(--body-color), 0.4);
width: 100%; width: 100%;
align-items: flex-start; align-items: flex-start;
.Button { .Button {

View file

@ -6,8 +6,9 @@ import ReactDOM from 'react-dom'
import App from './app' import App from './app'
import {loadTheme} from './theme' import {loadTheme} from './theme'
import './styles/variables.scss'
import './styles/main.scss' import './styles/main.scss'
import './styles/colors.scss' import './styles/labels.scss'
loadTheme() loadTheme()
ReactDOM.render(<App/>, document.getElementById('octo-tasks-app')) ReactDOM.render(<App/>, document.getElementById('octo-tasks-app'))

View file

@ -9,7 +9,7 @@
align-items: center; align-items: center;
justify-content: flex-start; justify-content: flex-start;
flex-direction: column; flex-direction: column;
box-shadow: rgba(var(--main-fg), 0.1) 0px 0px 0px 1px, rgba(var(--main-fg), 0.3) 0px 4px 8px; box-shadow: rgba(var(--body-color), 0.1) 0px 0px 0px 1px, rgba(var(--body-color), 0.3) 0px 4px 8px;
@media screen and (max-width: 430px) { @media screen and (max-width: 430px) {
position: fixed; position: fixed;

View file

@ -9,7 +9,7 @@
align-items: center; align-items: center;
justify-content: flex-start; justify-content: flex-start;
flex-direction: column; flex-direction: column;
box-shadow: rgba(var(--main-fg), 0.1) 0px 0px 0px 1px, rgba(var(--main-fg), 0.3) 0px 4px 8px; box-shadow: rgba(var(--body-color), 0.1) 0px 0px 0px 1px, rgba(var(--body-color), 0.3) 0px 4px 8px;
@media screen and (max-width: 430px) { @media screen and (max-width: 430px) {
position: fixed; position: fixed;

View file

@ -1,49 +1,49 @@
.propColor0, .propColor0,
.propColorDefault { .propColorDefault {
background-color: rgba(206, 205, 202, 0.5); background-color: var(--prop-default);
} }
.propColor1, .propColor1:hover, .propColor1, .propColor1:hover,
.propColorGray, .propColorGray:hover { .propColorGray, .propColorGray:hover {
background-color: rgba(155, 154, 151, 0.4); background-color: var(--prop-gray);
} }
.propColor2, .propColor2:hover, .propColor2, .propColor2:hover,
.propColorBrown, .propColorBrown:hover { .propColorBrown, .propColorBrown:hover {
background-color: rgba(140, 46, 0, 0.2); background-color: var(--prop-brown);
} }
.propColor3, .propColor3:hover, .propColor3, .propColor3:hover,
.propColorOrange, .propColorOrange:hover { .propColorOrange, .propColorOrange:hover {
background-color: rgba(245, 93, 0, 0.2); background-color: var(--prop-orange);
} }
.propColor4, .propColor4:hover, .propColor4, .propColor4:hover,
.propColorYellow, .propColorYellow:hover { .propColorYellow, .propColorYellow:hover {
background-color: rgba(233, 168, 0, 0.2); background-color: var(--prop-yellow);
} }
.propColor5, .propColor5:hover, .propColor5, .propColor5:hover,
.propColorGreen, .propColorGreen:hover { .propColorGreen, .propColorGreen:hover {
background-color: rgba(0, 135, 107, 0.2); background-color: var(--prop-green);
} }
.propColor6, .propColor6:hover, .propColor6, .propColor6:hover,
.propColorBlue, .propColorBlue:hover { .propColorBlue, .propColorBlue:hover {
background-color: rgba(0, 120, 233, 0.2); background-color: var(--prop-blue);
} }
.propColor7, .propColor7:hover, .propColor7, .propColor7:hover,
.propColorPurple, .propColorPurple:hover { .propColorPurple, .propColorPurple:hover {
background-color: rgba(103, 36, 222, 0.2); background-color: var(--prop-purple);
} }
.propColor8, .propColor8:hover, .propColor8, .propColor8:hover,
.propColorPink, .propColorPink:hover { .propColorPink, .propColorPink:hover {
background-color: rgba(221, 0, 129, 0.2); background-color: var(--prop-pink);
} }
.propColor9, .propColor9:hover, .propColor9, .propColor9:hover,
.propColorRed, .propColorRed:hover { .propColorRed, .propColorRed:hover {
background-color: rgba(255, 0, 26, 0.2); background-color: var(--prop-red);
} }

View file

@ -1,12 +1,3 @@
:root {
--main-bg: 255, 255, 255;
--main-fg: 55, 53, 47;
--button-bg: 80, 170, 221;
--button-fg: 255, 255, 255;
--sidebar-bg: '247, 246, 243';
--sidebar-fg: '55, 53, 47';
}
* { * {
box-sizing: border-box; box-sizing: border-box;
outline: 0; outline: 0;
@ -14,6 +5,7 @@
-moz-user-select: none; /* Firefox all */ -moz-user-select: none; /* Firefox all */
-ms-user-select: none; /* IE 10+ */ -ms-user-select: none; /* IE 10+ */
user-select: none; /* Likely future */ user-select: none; /* Likely future */
font-family: 'Open Sans', sans-serif;
} }
html, body { html, body {
@ -22,13 +14,13 @@ html, body {
width: 100%; width: 100%;
height: 100%; height: 100%;
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
background: rgb(var(--main-bg)); background: rgb(var(--main-bg));
} }
input, textarea { input, textarea {
background: rgb(var(--main-bg)); background: rgb(var(--main-bg));
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
-webkit-user-select: auto; /* Chrome all / Safari all */ -webkit-user-select: auto; /* Chrome all / Safari all */
-moz-user-select: auto; /* Firefox all */ -moz-user-select: auto; /* Firefox all */
@ -39,11 +31,11 @@ input, textarea {
body { body {
padding: 0; padding: 0;
margin: 0; margin: 0;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, "Apple Color Emoji", Arial, sans-serif, "Segoe UI Emoji", "Segoe UI Symbol"; font-family: 'Open Sans', sans-serif;
/* -webkit-font-smoothing: auto; */ /* -webkit-font-smoothing: auto; */
font-size: 14px; font-size: 14px;
line-height: 24px; line-height: 24px;
--cursor-color: rgb(var(--main-fg)); --cursor-color: rgb(var(--body-color));
} }
a { a {
@ -57,11 +49,19 @@ hr {
width: 100%; width: 100%;
height: 1px; height: 1px;
border: none; border: none;
color: rgba(var(--main-fg), 0.09); color: rgba(var(--body-color), 0.09);
background-color: rgba(var(--main-fg), 0.09); background-color: rgba(var(--body-color), 0.09);
margin-bottom: 8px; margin-bottom: 8px;
} }
button {
&.style--none {
background: transparent;
border: none;
padding: 0;
}
}
.page-loading { .page-loading {
margin: 50px auto; margin: 50px auto;
} }
@ -107,10 +107,10 @@ hr {
flex-direction: column; flex-direction: column;
overflow: scroll; overflow: scroll;
padding: 10px 95px 50px 95px; padding: 24px 80px 8px;
@media screen and (max-width: 768px) { @media screen and (max-width: 768px) {
padding: 10px 10px 50px 10px; padding: 8px 40px;
} }
} }
@ -119,12 +119,17 @@ hr {
} }
.octo-label { .octo-label {
display: inline-block; display: inline-flex;
padding: 0 5px; align-items: center;
padding: 2px 8px;
border-radius: 3px; border-radius: 3px;
line-height: 20px; line-height: 20px;
color: rgb(var(--main-fg)); color: rgba(var(--body-color), .8);
white-space: nowrap white-space: nowrap;
text-transform: uppercase;
font-weight: 600;
font-size: 13px;
} }
.octo-spacer { .octo-spacer {
@ -150,10 +155,10 @@ hr {
/*-- Property list --*/ /*-- Property list --*/
.octo-propertyvalue { .octo-propertyvalue {
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
padding: 0 5px; padding: 0 5px;
&.empty { &.empty {
color: rgba(var(--main-fg), 0.4); color: rgba(var(--body-color), 0.4);
} }
} }
@ -168,7 +173,7 @@ hr {
} }
.octo-placeholder { .octo-placeholder {
color: rgba(var(--main-fg), 0.4); color: rgba(var(--body-color), 0.4);
} }
[contentEditable=true] { [contentEditable=true] {
@ -181,7 +186,7 @@ hr {
[contentEditable=true]:empty:before{ [contentEditable=true]:empty:before{
content: attr(placeholder); content: attr(placeholder);
display: block; display: block;
color: rgba(var(--main-fg), 0.4); color: rgba(var(--body-color), 0.4);
} }

View file

@ -0,0 +1,34 @@
:root {
--body-color: 38, 38, 38;
--main-bg: 255, 255, 255;
--button-bg: 80, 170, 221;
--button-fg: 255, 255, 255;
--sidebar-bg: 20, 93, 191;
--sidebar-fg: 55, 53, 47;
--button-bg: 22, 109, 204;
--link-color: 35, 137, 215;
// Label Colors
--prop-default: #fff;
--prop-gray: #EDEDED;
--prop-brown: #F7DDC3;
--prop-orange: #ffd3c1;
--prop-yellow: #f7f0b6;
--prop-green: #c7eac3;
--prop-blue: #B1D1F6;
--prop-purple: #e6d0ff;
--prop-pink: #ffd6e9;
--prop-red: #ffa9a9;
// Elevations
--elevation-1: 0 2px 3px 0 rgba(0, 0, 0, .8);
--elevation-2: 0 4px 6px 0 rgba(0, 0, 0, .12);
--elevation-3: 0 6px 14px 0 rgba(0, 0, 0, .12);
--elevation-4: 0 8px 24px 0 rgba(0, 0, 0, .12);
--elevation-5: 0 12px 32px 0 rgba(0, 0, 0, .12);
--elevation-6: 0 20px 32px 0 rgba(0, 0, 0, .12);
// Radius
--default-rad: 4px;
--modal-rad: 8px;
}

View file

@ -4,16 +4,18 @@
align-items: center; align-items: center;
text-align: center; text-align: center;
justify-content: center; justify-content: center;
border-radius: 5px; border-radius: var(--default-rad);
padding: 0 5px; padding: 4px 8px;
min-width: 20px; min-width: 20px;
cursor: pointer; cursor: pointer;
overflow: hidden; overflow: hidden;
background: transparent;
border: none;
transition: background 100ms ease-out 0s; transition: background 100ms ease-out 0s;
color: inherit;
&:hover { &:hover {
background-color: rgba(var(--main-fg), 0.1); background-color: rgba(var(--body-color), 0.1);
} }
&.filled { &.filled {
@ -27,8 +29,8 @@
} }
&.active { &.active {
color: rgb(45, 170, 220); color: rgb(var(--link-color));
font-weight: 500; font-weight: 600;
} }
.Icon { .Icon {

View file

@ -5,7 +5,7 @@ import React from 'react'
import './button.scss' import './button.scss'
type Props = { type Props = {
onClick?: (e: React.MouseEvent<HTMLDivElement>) => void onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void
children?: React.ReactNode children?: React.ReactNode
title?: string title?: string
icon?: React.ReactNode icon?: React.ReactNode
@ -16,13 +16,14 @@ type Props = {
export default class Button extends React.PureComponent<Props> { export default class Button extends React.PureComponent<Props> {
render(): JSX.Element { render(): JSX.Element {
return ( return (
<div <button
type='button'
onClick={this.props.onClick} onClick={this.props.onClick}
className={`Button ${this.props.active ? 'active' : ''} ${this.props.filled ? 'filled' : ''}`} className={`Button ${this.props.active ? 'active' : ''} ${this.props.filled ? 'filled' : ''}`}
title={this.props.title} title={this.props.title}
> >
{this.props.icon} {this.props.icon}
{this.props.children} {this.props.children}
</div>) </button>)
} }
} }

View file

@ -3,10 +3,21 @@
width: 24px; width: 24px;
padding: 0; padding: 0;
margin: 0; margin: 0;
.Icon { .Icon {
height: 24px; height: 24px;
width: 24px; width: 24px;
padding: 0; padding: 0;
margin: 0; margin: 0;
} }
&--large {
width: 40px;
height: 40px;
.Icon {
width: 32px;
height: 32px;
}
}
} }

View file

@ -11,7 +11,7 @@ type Props = {
className?: string className?: string
} }
export default class IconButton extends React.PureComponent<Props> { export default class cIconButton extends React.PureComponent<Props> {
render(): JSX.Element { render(): JSX.Element {
let className = 'Button IconButton' let className = 'Button IconButton'
if (this.props.className) { if (this.props.className) {

View file

@ -7,7 +7,7 @@
min-width: 100px; min-width: 100px;
} }
&::placeholder{ &::placeholder{
color: rgba(var(--main-fg), 0.4); color: rgba(var(--body-color), 0.4);
opacity: 1; opacity: 1;
} }
} }

View file

@ -1,20 +1,20 @@
.EmojiPicker { .EmojiPicker {
.emoji-mart { .emoji-mart {
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
background: rgb(var(--main-bg)); background: rgb(var(--main-bg));
border-color: rgba(var(--main-fg), 0.16); border-color: rgba(var(--body-color), 0.16);
.emoji-mart-bar { .emoji-mart-bar {
border: 0 solid rgba(var(--main-fg), 0.16); border: 0 solid rgba(var(--body-color), 0.16);
border-bottom-width: 1px border-bottom-width: 1px
} }
.emoji-mart-search input { .emoji-mart-search input {
border: 1px solid rgba(var(--main-fg), 0.16); border: 1px solid rgba(var(--body-color), 0.16);
} }
.emoji-mart-category-label span { .emoji-mart-category-label span {
background: rgb(var(--main-bg)); background: rgb(var(--main-bg));
} }
.emoji-mart-search-icon svg { .emoji-mart-search-icon svg {
fill: rgb(var(--main-fg)); fill: rgb(var(--body-color));
} }
} }
} }

View file

@ -1,5 +1,5 @@
.AddIcon { .AddIcon {
stroke: rgb(var(--main-fg), 0.5); stroke: rgb(var(--body-color), 0.5);
stroke-width: 4px; stroke-width: 4px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.CheckIcon { .CheckIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 8px; stroke-width: 8px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.CloseIcon { .CloseIcon {
stroke: rgb(var(--main-fg), 0.5); stroke: rgb(var(--body-color), 0.5);
stroke-width: 4px; stroke-width: 4px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.DeleteIcon { .DeleteIcon {
fill: rgba(var(--main-fg), 0.5); fill: rgba(var(--body-color), 0.5);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.DisclosureTriangleIcon { .DisclosureTriangleIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.DividerIcon { .DividerIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.DotIcon { .DotIcon {
fill: rgba(var(--main-fg), 0.5); fill: rgba(var(--body-color), 0.5);
width: 24px; width: 24px;
height: 24px; height: 24px;
} }

View file

@ -1,6 +1,6 @@
.DropdownIcon { .DropdownIcon {
fill: none; fill: none;
stroke: rgb(var(--main-fg)); stroke: rgb(var(--body-color));
stroke-width: 4px; stroke-width: 4px;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.DuplicateIcon { .DuplicateIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.EmojiIcon { .EmojiIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.HamburgerIcon { .HamburgerIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 6px; stroke-width: 6px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.HideIcon { .HideIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.HideSidebarIcon { .HideSidebarIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 6px; stroke-width: 6px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.ImageIcon { .ImageIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.OptionsIcon { .OptionsIcon {
fill: rgba(var(--main-fg), 0.5); fill: rgba(var(--body-color), 0.5);
width: 24px; width: 24px;
height: 24px; height: 24px;
} }

View file

@ -1,5 +1,5 @@
.ShowIcon { .ShowIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.ShowSidebarIcon { .ShowSidebarIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 6px; stroke-width: 6px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.SortDownIcon { .SortDownIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 8px; stroke-width: 8px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.SortUpIcon { .SortUpIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 8px; stroke-width: 8px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.StandardIcon { .StandardIcon {
stroke: rgba(var(--main-fg), 0.5); stroke: rgba(var(--body-color), 0.5);
stroke-width: 4px; stroke-width: 4px;
fill: none; fill: none;
width: 24px; width: 24px;

View file

@ -1,5 +1,5 @@
.SubmenuTriangleIcon { .SubmenuTriangleIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -1,5 +1,5 @@
.TextIcon { .TextIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
stroke: none; stroke: none;
width: 24px; width: 24px;
height: 24px; height: 24px;

View file

@ -5,14 +5,15 @@
z-index: 15; z-index: 15;
min-width: 180px; min-width: 180px;
background-color: rgb(var(--main-bg)); background-color: rgb(var(--main-bg));
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
border-radius: var(--default-rad);
border-radius: 3px; box-shadow: var(--elevation-4);
box-shadow: rgba(var(--main-fg), 0.05) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 3px 6px, rgba(var(--main-fg), 0.2) 0px 9px 24px;
.menu-contents { .menu-contents {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
padding: 8px 0;
min-width: 240px;
} }
.menu-options { .menu-options {
@ -26,7 +27,7 @@
padding: 0; padding: 0;
margin: 0; margin: 0;
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
>.menu-option { >.menu-option {
display: flex; display: flex;
@ -34,15 +35,18 @@
align-items: center; align-items: center;
font-weight: 400; font-weight: 400;
padding: 2px 10px; height: 32px;
padding: 4px 20px;
cursor: pointer; cursor: pointer;
&:hover { &:hover {
background: rgba(90, 90, 90, 0.1); background: rgba(var(--button-bg), 0.08);
} }
>* { >* {
margin-left: 5px; margin-left: 16px;
} }
>*:first-child { >*:first-child {
margin-left: 0; margin-left: 0;
} }
@ -54,14 +58,16 @@
} }
>.SubmenuTriangleIcon { >.SubmenuTriangleIcon {
fill: rgba(var(--main-fg), 0.7); fill: rgba(var(--body-color), 0.7);
} }
>.Icon { >.Icon {
opacity: 0.56;
width: 16px; width: 16px;
height: 16px; height: 16px;
line-height: 16px; line-height: 16px;
} }
>.IconButton .Icon { >.IconButton .Icon {
margin-right: 0; margin-right: 0;
} }
@ -78,13 +84,15 @@
&.top { &.top {
bottom: 100%; bottom: 100%;
} }
&.left { &.left {
right: 0; right: 0;
} }
} }
} }
.Menu, .SubMenuOption .SubMenu { .Menu,
.SubMenuOption .SubMenu {
@media screen and (max-width: 430px) { @media screen and (max-width: 430px) {
position: fixed; position: fixed;
top: 0; top: 0;
@ -92,7 +100,7 @@
right: 0; right: 0;
bottom: 0; bottom: 0;
min-width: 0; min-width: 0;
background-color: rgba(var(--main-fg), 0.5); background-color: rgba(var(--body-color), 0.5);
border-radius: 0; border-radius: 0;
padding: 10px; padding: 10px;
@ -120,10 +128,12 @@
>* { >* {
flex: 0 0 auto; flex: 0 0 auto;
} }
>.noicon { >.noicon {
width: 16px; width: 16px;
height: 16px; height: 16px;
} }
>.menu-name { >.menu-name {
font-size: 16px; font-size: 16px;
justify-content: center; justify-content: center;
@ -131,6 +141,7 @@
} }
} }
} }
@media not screen and (max-width: 430px) { @media not screen and (max-width: 430px) {
.hideOnWidescreen { .hideOnWidescreen {
/* Hide controls (e.g. close button) on larger screens */ /* Hide controls (e.g. close button) on larger screens */

View file

@ -1,3 +1,4 @@
.MenuSeparator { .MenuSeparator {
border-bottom: solid 1px rgba(var(--main-fg), 0.16); border-bottom: solid 1px rgba(var(--body-color), 0.16);
margin: 8px 0;
} }

View file

@ -6,11 +6,11 @@
z-index: 16; z-index: 16;
min-width: 180px; min-width: 180px;
background-color: rgb(var(--main-bg)); background-color: rgb(var(--main-bg));
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
margin: 0 !important; margin: 0 !important;
border-radius: 3px; border-radius: 3px;
box-shadow: rgba(var(--main-fg), 0.05) 0px 0px 0px 1px, rgba(var(--main-fg), 0.1) 0px 3px 6px, rgba(var(--main-fg), 0.2) 0px 9px 24px; box-shadow: rgba(var(--body-color), 0.05) 0px 0px 0px 1px, rgba(var(--body-color), 0.1) 0px 3px 6px, rgba(var(--body-color), 0.2) 0px 9px 24px;
left: 100%; left: 100%;
&.top { &.top {
bottom: 0; bottom: 0;
@ -22,7 +22,7 @@
@media screen and (max-width: 430px) { @media screen and (max-width: 430px) {
.SubMenu { .SubMenu {
background-color: rgba(var(--main-fg), 0.8) !important; background-color: rgba(var(--body-color), 0.8) !important;
} }
} }
} }

View file

@ -7,11 +7,11 @@
width: 26px; width: 26px;
border-radius: 44px; border-radius: 44px;
padding: 2px; padding: 2px;
background-color: rgba(135, 131, 120, 0.3); background-color: rgba(var(--body-color), 0.24);
transition: background 200ms ease 0s, box-shadow 200ms ease 0s; transition: background 200ms ease 0s, box-shadow 200ms ease 0s;
&.on { &.on {
background-color: rgba(46, 170, 220); background-color: rgb(var(--button-bg));
.octo-switch-inner { .octo-switch-inner {
transform: translateX(12px) translateY(0px); transform: translateX(12px) translateY(0px);
} }

View file

@ -1,15 +1,16 @@
.ValueSelector { .ValueSelector {
width: 100%; width: 100%;
border-radius: 5px; border-radius: var(--default-rad);
color: rgb(var(--main-fg)); color: rgb(var(--body-color));
&:hover { &:hover {
background-color: rgba(var(--main-fg), 0.1), background-color: rgba(var(--body-color), 0.1),
} }
> .octo-label { > .octo-label {
margin: 0 10px; margin: 0 10px;
&.empty { &.empty {
color: rgba(var(--main-fg), 0.6); color: rgba(var(--body-color), 0.6);
} }
} }
@ -25,7 +26,7 @@
.IconButton { .IconButton {
background-color: unset; background-color: unset;
&:hover { &:hover {
background-color: rgba(var(--main-fg), 0.1); background-color: rgba(var(--body-color), 0.1);
} }
} }
} }