mirror of
https://github.com/Eugeny/tabby
synced 2025-01-21 09:34:57 +00:00
.
This commit is contained in:
parent
c3cc57f897
commit
fa02eb38e9
17 changed files with 468 additions and 132 deletions
7
Makefile
7
Makefile
|
@ -14,13 +14,6 @@ lint:
|
||||||
build:
|
build:
|
||||||
DEV=1 ./node_modules/.bin/webpack --progress --display-modules
|
DEV=1 ./node_modules/.bin/webpack --progress --display-modules
|
||||||
|
|
||||||
build-plugins:
|
|
||||||
cd terminus-core; npm run build
|
|
||||||
cd terminus-settings; npm run build
|
|
||||||
cd terminus-terminal; npm run build
|
|
||||||
cd terminus-community-color-schemes; npm run build
|
|
||||||
cd terminus-clickable-links; npm run build
|
|
||||||
|
|
||||||
watch:
|
watch:
|
||||||
DEV=1 ./node_modules/.bin/webpack --progress -w
|
DEV=1 ./node_modules/.bin/webpack --progress -w
|
||||||
|
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
app > toaster-container > #toast-container {
|
|
||||||
width: 100% !important;
|
|
||||||
left: 0 !important;
|
|
||||||
right: 0 !important;
|
|
||||||
top: 50px !important;
|
|
||||||
|
|
||||||
.toast {
|
|
||||||
box-shadow: none !important;
|
|
||||||
text-shadow: none !important;
|
|
||||||
opacity: 1 !important;
|
|
||||||
border-radius: 0 !important;
|
|
||||||
width: 100% !important;
|
|
||||||
padding: 10px !important;
|
|
||||||
|
|
||||||
.toaster-icon {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.toast-title {
|
|
||||||
font-weight: normal !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -12,6 +12,7 @@ let plugins = [
|
||||||
(<any>global).require(projectRoot + 'terminus-terminal').default,
|
(<any>global).require(projectRoot + 'terminus-terminal').default,
|
||||||
(<any>global).require(projectRoot + 'terminus-clickable-links').default,
|
(<any>global).require(projectRoot + 'terminus-clickable-links').default,
|
||||||
(<any>global).require(projectRoot + 'terminus-community-color-schemes').default,
|
(<any>global).require(projectRoot + 'terminus-community-color-schemes').default,
|
||||||
|
(<any>global).require(projectRoot + 'terminus-theme-hype').default,
|
||||||
]
|
]
|
||||||
|
|
||||||
const core = (<any>global).require(projectRoot + 'terminus-core')
|
const core = (<any>global).require(projectRoot + 'terminus-core')
|
||||||
|
|
|
@ -1,3 +1,2 @@
|
||||||
import 'source-sans-pro'
|
import 'source-sans-pro'
|
||||||
import 'font-awesome/css/font-awesome.css'
|
import 'font-awesome/css/font-awesome.css'
|
||||||
import '../assets/toaster-custom.scss'
|
|
||||||
|
|
|
@ -3,7 +3,7 @@ title-bar(*ngIf='!config.full().appearance.useNativeFrame && config.full().appea
|
||||||
.content(
|
.content(
|
||||||
[class.tabs-on-top]='config.full().appearance.tabsOnTop'
|
[class.tabs-on-top]='config.full().appearance.tabsOnTop'
|
||||||
)
|
)
|
||||||
.tabs
|
.tab-bar
|
||||||
button.btn.btn-secondary(
|
button.btn.btn-secondary(
|
||||||
*ngFor='let button of getLeftToolbarButtons()',
|
*ngFor='let button of getLeftToolbarButtons()',
|
||||||
[title]='button.title',
|
[title]='button.title',
|
||||||
|
@ -11,7 +11,7 @@ title-bar(*ngIf='!config.full().appearance.useNativeFrame && config.full().appea
|
||||||
)
|
)
|
||||||
i.fa([class]='"fa fa-" + button.icon')
|
i.fa([class]='"fa fa-" + button.icon')
|
||||||
|
|
||||||
.tabs-container
|
.tabs
|
||||||
tab-header(
|
tab-header(
|
||||||
*ngFor='let tab of app.tabs; let idx = index',
|
*ngFor='let tab of app.tabs; let idx = index',
|
||||||
[class.pre-selected]='idx == app.tabs.indexOf(app.activeTab) - 1',
|
[class.pre-selected]='idx == app.tabs.indexOf(app.activeTab) - 1',
|
||||||
|
@ -32,15 +32,12 @@ title-bar(*ngIf='!config.full().appearance.useNativeFrame && config.full().appea
|
||||||
)
|
)
|
||||||
i.fa([class]='"fa fa-" + button.icon')
|
i.fa([class]='"fa fa-" + button.icon')
|
||||||
|
|
||||||
.tabs-content
|
tab-body(
|
||||||
tab-body(
|
*ngFor='let tab of app.tabs; trackBy: tab?.id',
|
||||||
*ngFor='let tab of app.tabs; trackBy: tab?.id',
|
[active]='tab == app.activeTab',
|
||||||
[active]='tab == app.activeTab',
|
[tab]='tab',
|
||||||
[tab]='tab',
|
[class.scrollable]='tab.scrollable',
|
||||||
[class.scrollable]='tab.scrollable',
|
)
|
||||||
)
|
|
||||||
|
|
||||||
toaster-container([toasterconfig]="toasterconfig")
|
toaster-container([toasterconfig]="toasterconfig")
|
||||||
ng-template(ngbModalContainer)
|
ng-template(ngbModalContainer)
|
||||||
|
|
||||||
div.window-resizer.window-resizer-tl
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
:host {
|
:host {
|
||||||
display: flex;
|
display: flex;
|
||||||
width: calc(100vw - 2px);
|
width: 100vw;
|
||||||
height: calc(100vh - 2px);
|
height: 100vh;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
-webkit-user-select: none;
|
-webkit-user-select: none;
|
||||||
|
@ -23,7 +23,7 @@ $tab-border-radius: 4px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.tabs {
|
.tab-bar {
|
||||||
flex: none;
|
flex: none;
|
||||||
height: $tabs-height;
|
height: $tabs-height;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
@ -45,7 +45,7 @@ $tab-border-radius: 4px;
|
||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
&>.tabs-container {
|
&>.tabs {
|
||||||
flex: auto;
|
flex: auto;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
.content-wrapper
|
.wrapper
|
||||||
.index {{index + 1}}
|
.index {{index + 1}}
|
||||||
.name {{(tab.title$ || "Terminal") | async}}
|
.name {{(tab.title$ || "Terminal") | async}}
|
||||||
button((click)='closeClicked.emit()') ×
|
button((click)='closeClicked.emit()') ×
|
||||||
|
|
|
@ -13,9 +13,8 @@ $tabs-height: 40px;
|
||||||
|
|
||||||
min-width: 0;
|
min-width: 0;
|
||||||
transition: 0.25s all;
|
transition: 0.25s all;
|
||||||
//.button-states();
|
|
||||||
|
|
||||||
.content-wrapper {
|
.wrapper {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
flex: auto;
|
flex: auto;
|
||||||
|
@ -47,11 +46,9 @@ $tabs-height: 40px;
|
||||||
}
|
}
|
||||||
|
|
||||||
button {
|
button {
|
||||||
flex: none;
|
|
||||||
|
|
||||||
background: transparent;
|
|
||||||
|
|
||||||
display: block;
|
display: block;
|
||||||
|
flex: none;
|
||||||
|
background: transparent;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
|
|
||||||
$button-size: $tabs-height * 0.6;
|
$button-size: $tabs-height * 0.6;
|
||||||
|
@ -64,8 +61,6 @@ $tabs-height: 40px;
|
||||||
|
|
||||||
text-align: center;
|
text-align: center;
|
||||||
font-size: 20px;
|
font-size: 20px;
|
||||||
|
|
||||||
//.button-states();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover button {
|
&:hover button {
|
||||||
|
@ -74,7 +69,4 @@ $tabs-height: 40px;
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//border-bottom: 2px solid transparent;
|
|
||||||
transition: 0.25s all;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,7 +94,7 @@ app-root {
|
||||||
&> .content {
|
&> .content {
|
||||||
background: $body-bg2;
|
background: $body-bg2;
|
||||||
|
|
||||||
.tabs {
|
.tab-bar {
|
||||||
background: $body-bg;
|
background: $body-bg;
|
||||||
|
|
||||||
&>button {
|
&>button {
|
||||||
|
@ -103,105 +103,103 @@ app-root {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tab-header {
|
&>.tabs {
|
||||||
background: $body-bg;
|
&:empty {
|
||||||
|
|
||||||
.content-wrapper {
|
|
||||||
background: $body-bg2;
|
background: $body-bg2;
|
||||||
|
|
||||||
.index {
|
|
||||||
color: #555;
|
|
||||||
}
|
|
||||||
|
|
||||||
button {
|
|
||||||
color: $body-color;
|
|
||||||
border: none;
|
|
||||||
transition: 0.25s all;
|
|
||||||
|
|
||||||
&:hover { background: $button-hover-bg !important; }
|
|
||||||
&:active { background: $button-active-bg !important; }
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&.active {
|
tab-header {
|
||||||
background: $body-bg2;
|
background: $body-bg;
|
||||||
|
|
||||||
.content-wrapper {
|
.wrapper {
|
||||||
background: $body-bg;
|
background: $body-bg2;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.has-activity:not(.active) {
|
.index {
|
||||||
/*
|
color: #555;
|
||||||
.content-wrapper .index {
|
}
|
||||||
background: $blue;
|
|
||||||
color: white;
|
button {
|
||||||
text-shadow: 0 1px 1px rgba(0,0,0,.95);
|
color: $body-color;
|
||||||
|
border: none;
|
||||||
|
transition: 0.25s all;
|
||||||
|
|
||||||
|
&:hover { background: $button-hover-bg !important; }
|
||||||
|
&:active { background: $button-active-bg !important; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.active {
|
||||||
|
background: $body-bg2;
|
||||||
|
|
||||||
|
.wrapper {
|
||||||
|
background: $body-bg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.has-activity:not(.active) {
|
||||||
|
/*
|
||||||
|
.wrapper .index {
|
||||||
|
background: $blue;
|
||||||
|
color: white;
|
||||||
|
text-shadow: 0 1px 1px rgba(0,0,0,.95);
|
||||||
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&.tabs-on-top .tabs {
|
&.tabs-on-top .tab-bar {
|
||||||
margin-top: 3px;
|
margin-top: 3px;
|
||||||
|
|
||||||
tab-header {
|
tab-header {
|
||||||
&.pre-selected {
|
.wrapper {
|
||||||
.content-wrapper {
|
|
||||||
border-bottom-right-radius: $tab-border-radius;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.post-selected {
|
|
||||||
.content-wrapper {
|
|
||||||
border-bottom-left-radius: $tab-border-radius;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.content-wrapper {
|
|
||||||
border-top: 1px solid transparent;
|
border-top: 1px solid transparent;
|
||||||
}
|
|
||||||
|
|
||||||
&.active .content-wrapper {
|
|
||||||
border-top: 1px solid $teal;
|
|
||||||
border-top-left-radius: $tab-border-radius;
|
border-top-left-radius: $tab-border-radius;
|
||||||
border-top-right-radius: $tab-border-radius;
|
border-top-right-radius: $tab-border-radius;
|
||||||
}
|
}
|
||||||
|
|
||||||
&.has-activity:not(.active) .content-wrapper {
|
&.pre-selected .wrapper {
|
||||||
|
border-bottom-right-radius: $tab-border-radius;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.post-selected .wrapper {
|
||||||
|
border-bottom-left-radius: $tab-border-radius;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.active .wrapper {
|
||||||
|
border-top: 1px solid $teal;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.has-activity:not(.active) .wrapper {
|
||||||
border-top: 1px solid $green;
|
border-top: 1px solid $green;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:not(.tabs-on-top) .tabs {
|
&:not(.tabs-on-top) .tab-bar {
|
||||||
margin-bottom: 3px;
|
margin-bottom: 3px;
|
||||||
|
|
||||||
tab-header {
|
tab-header {
|
||||||
&.pre-selected {
|
.wrapper {
|
||||||
.content-wrapper {
|
|
||||||
border-top-right-radius: $tab-border-radius;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.post-selected {
|
|
||||||
.content-wrapper {
|
|
||||||
border-top-left-radius: $tab-border-radius;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.content-wrapper {
|
|
||||||
border-bottom: 1px solid transparent;
|
border-bottom: 1px solid transparent;
|
||||||
}
|
|
||||||
|
|
||||||
&.active .content-wrapper {
|
|
||||||
border-bottom: 1px solid $teal;
|
|
||||||
border-bottom-left-radius: $tab-border-radius;
|
border-bottom-left-radius: $tab-border-radius;
|
||||||
border-bottom-right-radius: $tab-border-radius;
|
border-bottom-right-radius: $tab-border-radius;
|
||||||
}
|
}
|
||||||
|
|
||||||
&.has-activity:not(.active) .content-wrapper {
|
&.pre-selected .wrapper {
|
||||||
|
border-top-right-radius: $tab-border-radius;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.post-selected .wrapper {
|
||||||
|
border-top-left-radius: $tab-border-radius;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.active .wrapper {
|
||||||
|
border-bottom: 1px solid $teal;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.has-activity:not(.active) .wrapper {
|
||||||
border-bottom: 1px solid $green;
|
border-bottom: 1px solid $green;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,11 +9,11 @@ ngb-tabset.vertical(type='tabs')
|
||||||
.col.col-lg-6
|
.col.col-lg-6
|
||||||
.form-group
|
.form-group
|
||||||
label Theme
|
label Theme
|
||||||
select.form-control(
|
select.form-control(
|
||||||
'[(ngModel)]'='config.store.appearance.theme',
|
'[(ngModel)]'='config.store.appearance.theme',
|
||||||
(ngModelChange)='config.save()',
|
(ngModelChange)='config.save()',
|
||||||
)
|
)
|
||||||
option(*ngFor='let theme of themes', [ngValue]='theme.name') {{theme.name}}
|
option(*ngFor='let theme of themes', [ngValue]='theme.name') {{theme.name}}
|
||||||
|
|
||||||
.form-group
|
.form-group
|
||||||
label Show tabs
|
label Show tabs
|
||||||
|
|
1
terminus-theme-hype/.gitignore
vendored
Normal file
1
terminus-theme-hype/.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
dist
|
28
terminus-theme-hype/package.json
Normal file
28
terminus-theme-hype/package.json
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
{
|
||||||
|
"name": "terminus-theme-hype",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"description": "Hyper inspired theme for Terminus",
|
||||||
|
"main": "dist/index.js",
|
||||||
|
"scripts": {
|
||||||
|
"build": "webpack --progress --color",
|
||||||
|
"watch": "webpack --progress --color --watch"
|
||||||
|
},
|
||||||
|
"author": "Eugene Pankov",
|
||||||
|
"license": "MIT",
|
||||||
|
"peerDependencies": {
|
||||||
|
"@angular/core": "4.0.1",
|
||||||
|
"terminus-core": "*"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@types/webpack-env": "1.13.0",
|
||||||
|
"node-sass": "^4.5.0",
|
||||||
|
"bootstrap": "4.0.0-alpha.6",
|
||||||
|
"sass-loader": "^6.0.3",
|
||||||
|
"css-loader": "0.26.1",
|
||||||
|
"typescript": "~2.1.0",
|
||||||
|
"to-string-loader": "^1.1.5",
|
||||||
|
"awesome-typescript-loader": "3.1.2",
|
||||||
|
"raw-loader": "0.5.1",
|
||||||
|
"webpack": "2.3.3"
|
||||||
|
}
|
||||||
|
}
|
18
terminus-theme-hype/src/index.ts
Normal file
18
terminus-theme-hype/src/index.ts
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import { NgModule, Injectable } from '@angular/core'
|
||||||
|
import { Theme } from 'terminus-core'
|
||||||
|
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
class HypeTheme extends Theme {
|
||||||
|
name = 'Hype'
|
||||||
|
css = require('./theme.scss')
|
||||||
|
terminalBackground = '#1D272D'
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
providers: [
|
||||||
|
{ provide: Theme, useClass: HypeTheme, multi: true },
|
||||||
|
],
|
||||||
|
})
|
||||||
|
export default class HypeThemeModule { }
|
269
terminus-theme-hype/src/theme.scss
Normal file
269
terminus-theme-hype/src/theme.scss
Normal file
|
@ -0,0 +1,269 @@
|
||||||
|
$window-border: #313131;
|
||||||
|
$body-bg: #010101;
|
||||||
|
$body-bg2: #010101;
|
||||||
|
$body-bg3: #111;
|
||||||
|
|
||||||
|
|
||||||
|
$tab-border-radius: 3px;
|
||||||
|
$button-hover-bg: rgba(255, 255, 255, .05);
|
||||||
|
$button-active-bg: rgba(255, 255, 255, .1);
|
||||||
|
|
||||||
|
|
||||||
|
$white: #fff !default;
|
||||||
|
$black: #000 !default;
|
||||||
|
$red: #d9534f !default;
|
||||||
|
$orange: #f0ad4e !default;
|
||||||
|
$yellow: #ffd500 !default;
|
||||||
|
$green: #5cb85c !default;
|
||||||
|
$blue: #0275d8 !default;
|
||||||
|
$teal: #5bc0de !default;
|
||||||
|
$pink: #ff5b77 !default;
|
||||||
|
$purple: #613d7c !default;
|
||||||
|
|
||||||
|
|
||||||
|
$body-color: #aaa;
|
||||||
|
$font-family-sans-serif: "Source Sans Pro";
|
||||||
|
$font-size-base: 14rem / 16;
|
||||||
|
|
||||||
|
$btn-secondary-color: #ccc;
|
||||||
|
$btn-secondary-bg: #222;
|
||||||
|
$btn-secondary-border: #444;
|
||||||
|
|
||||||
|
//$btn-warning-bg: rgba($orange, .5);
|
||||||
|
|
||||||
|
|
||||||
|
$nav-tabs-border-color: $body-bg2;
|
||||||
|
$nav-tabs-border-width: 1px;
|
||||||
|
$nav-tabs-border-radius: 0;
|
||||||
|
$nav-tabs-link-hover-border-color: $body-bg2;
|
||||||
|
$nav-tabs-active-link-hover-color: $white;
|
||||||
|
$nav-tabs-active-link-hover-bg: $blue;
|
||||||
|
$nav-tabs-active-link-hover-border-color: darken($blue, 30%);
|
||||||
|
|
||||||
|
$input-bg: #111;
|
||||||
|
$input-bg-disabled: #333;
|
||||||
|
|
||||||
|
$input-color: $body-color;
|
||||||
|
//$input-border-color: rgba($black,.15);
|
||||||
|
//$input-box-shadow: inset 0 1px 1px rgba($black,.075);
|
||||||
|
|
||||||
|
$input-border-radius: 0;
|
||||||
|
|
||||||
|
$input-bg-focus: $input-bg;
|
||||||
|
//$input-border-focus: lighten($brand-primary, 25%);
|
||||||
|
//$input-box-shadow-focus: $input-box-shadow, rgba($input-border-focus, .6);
|
||||||
|
$input-color-focus: $input-color;
|
||||||
|
|
||||||
|
$modal-content-bg: $body-bg;
|
||||||
|
$modal-content-border-color: $body-bg2;
|
||||||
|
$modal-header-border-color: $body-bg2;
|
||||||
|
$modal-footer-border-color: $body-bg2;
|
||||||
|
|
||||||
|
$popover-bg: $body-bg2;
|
||||||
|
|
||||||
|
|
||||||
|
@import '~bootstrap/scss/bootstrap.scss';
|
||||||
|
|
||||||
|
.nav-tabs {
|
||||||
|
background: $btn-secondary-bg;
|
||||||
|
.nav-link {
|
||||||
|
transition: 0.25s all;
|
||||||
|
border-bottom-color: $nav-tabs-border-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ngb-tabset .tab-content {
|
||||||
|
padding-top: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
[ngbradiogroup] > label.active {
|
||||||
|
background: $blue;
|
||||||
|
}
|
||||||
|
|
||||||
|
title-bar {
|
||||||
|
background: $body-bg2;
|
||||||
|
|
||||||
|
button {
|
||||||
|
&:hover { background: $button-hover-bg !important; }
|
||||||
|
&:active { background: $button-active-bg !important; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
app-root {
|
||||||
|
background: $body-bg;
|
||||||
|
border: 1px solid $window-border;
|
||||||
|
|
||||||
|
&> .content {
|
||||||
|
.tab-bar {
|
||||||
|
&>button {
|
||||||
|
&:hover { background: $button-hover-bg !important; }
|
||||||
|
&:active { background: $button-active-bg !important; }
|
||||||
|
|
||||||
|
&:not(:hover):not(:active) {
|
||||||
|
background: $body-bg2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&>.tabs {
|
||||||
|
tab-header {
|
||||||
|
.wrapper {
|
||||||
|
.index {
|
||||||
|
color: #555;
|
||||||
|
}
|
||||||
|
|
||||||
|
.name {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
button {
|
||||||
|
color: $body-color;
|
||||||
|
border: none;
|
||||||
|
transition: 0.25s all;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.tabs-on-top .tab-bar {
|
||||||
|
margin-top: 3px;
|
||||||
|
|
||||||
|
&>button {
|
||||||
|
border-bottom: 1px solid $window-border;
|
||||||
|
}
|
||||||
|
|
||||||
|
tab-header {
|
||||||
|
.wrapper {
|
||||||
|
border: 1px solid transparent;
|
||||||
|
border-bottom: 1px solid $window-border;
|
||||||
|
border-top-left-radius: $tab-border-radius;
|
||||||
|
border-top-right-radius: $tab-border-radius;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.active .wrapper {
|
||||||
|
border: 1px solid $window-border;
|
||||||
|
border-bottom: 1px solid transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.has-activity:not(.active) .wrapper {
|
||||||
|
border-top: 1px solid $green;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&:not(.tabs-on-top) .tab-bar {
|
||||||
|
margin-bottom: 3px;
|
||||||
|
|
||||||
|
&>button {
|
||||||
|
border-top: 1px solid $window-border;
|
||||||
|
}
|
||||||
|
|
||||||
|
tab-header {
|
||||||
|
.wrapper {
|
||||||
|
border: 1px solid transparent;
|
||||||
|
border-top: 1px solid $window-border;
|
||||||
|
border-bottom-left-radius: $tab-border-radius;
|
||||||
|
border-bottom-right-radius: $tab-border-radius;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.active .wrapper {
|
||||||
|
border: 1px solid $window-border;
|
||||||
|
border-top: 1px solid transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.has-activity:not(.active) .wrapper {
|
||||||
|
border-bottom: 1px solid $green;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tab-body {
|
||||||
|
background: $body-bg;
|
||||||
|
}
|
||||||
|
|
||||||
|
settings-tab > ngb-tabset {
|
||||||
|
border-right: 1px solid $body-bg2;
|
||||||
|
|
||||||
|
& > .nav {
|
||||||
|
background: $body-bg3;
|
||||||
|
|
||||||
|
& > .nav-item > .nav-link {
|
||||||
|
border-left: none;
|
||||||
|
border-right: none;
|
||||||
|
border-top: 1px solid transparent;
|
||||||
|
border-bottom: 1px solid transparent;
|
||||||
|
padding: 10px 50px 10px 20px;
|
||||||
|
font-size: 14px;
|
||||||
|
|
||||||
|
&.active {
|
||||||
|
border-top-color: $nav-tabs-active-link-hover-border-color;
|
||||||
|
border-bottom-color: $nav-tabs-active-link-hover-border-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
multi-hotkey-input {
|
||||||
|
.item {
|
||||||
|
background: $body-bg3;
|
||||||
|
border: 1px solid $blue;
|
||||||
|
border-radius: 3px;
|
||||||
|
margin-right: 5px;
|
||||||
|
|
||||||
|
.body {
|
||||||
|
padding: 3px 0 2px;
|
||||||
|
|
||||||
|
.stroke {
|
||||||
|
padding: 0 6px;
|
||||||
|
border-right: 1px solid $body-bg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.remove {
|
||||||
|
padding: 3px 8px 2px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.add {
|
||||||
|
color: #777;
|
||||||
|
padding: 4px 10px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.add, .item .body, .item .remove {
|
||||||
|
&:hover { background: darken($body-bg3, 5%); }
|
||||||
|
&:active { background: darken($body-bg3, 15%); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
hotkey-input-modal {
|
||||||
|
.input {
|
||||||
|
background: $input-bg;
|
||||||
|
padding: 10px;
|
||||||
|
font-size: 24px;
|
||||||
|
line-height: 27px;
|
||||||
|
height: 55px;
|
||||||
|
|
||||||
|
.stroke {
|
||||||
|
background: $body-bg3;
|
||||||
|
border: 1px solid $blue;
|
||||||
|
border-radius: 3px;
|
||||||
|
margin-right: 10px;
|
||||||
|
padding: 3px 10px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.timeout {
|
||||||
|
background: $input-bg;
|
||||||
|
|
||||||
|
div {
|
||||||
|
background: $blue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-group label {
|
||||||
|
margin-bottom: 2px;
|
||||||
|
}
|
24
terminus-theme-hype/tsconfig.json
Normal file
24
terminus-theme-hype/tsconfig.json
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"baseUrl": "src",
|
||||||
|
"module": "commonjs",
|
||||||
|
"target": "es5",
|
||||||
|
"declaration": false,
|
||||||
|
"noImplicitAny": false,
|
||||||
|
"removeComments": false,
|
||||||
|
"emitDecoratorMetadata": true,
|
||||||
|
"experimentalDecorators": true,
|
||||||
|
"lib": [
|
||||||
|
"dom",
|
||||||
|
"es2015",
|
||||||
|
"es7"
|
||||||
|
],
|
||||||
|
"paths": {
|
||||||
|
"*": ["../../app/node_modules/*"],
|
||||||
|
"terminus-*": ["../../terminus-*"]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"exclude": [
|
||||||
|
"node_modules"
|
||||||
|
]
|
||||||
|
}
|
38
terminus-theme-hype/webpack.config.js
Normal file
38
terminus-theme-hype/webpack.config.js
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
const path = require('path')
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
target: 'node',
|
||||||
|
entry: 'src/index.ts',
|
||||||
|
devtool: 'source-map',
|
||||||
|
context: __dirname,
|
||||||
|
output: {
|
||||||
|
path: path.resolve(__dirname, 'dist'),
|
||||||
|
filename: 'index.js',
|
||||||
|
pathinfo: true,
|
||||||
|
libraryTarget: 'umd',
|
||||||
|
},
|
||||||
|
resolve: {
|
||||||
|
modules: ['.', 'src', 'node_modules', '../app/node_modules'].map(x => path.join(__dirname, x)),
|
||||||
|
extensions: ['.ts', '.js'],
|
||||||
|
},
|
||||||
|
module: {
|
||||||
|
loaders: [
|
||||||
|
{
|
||||||
|
test: /\.ts$/,
|
||||||
|
loader: 'awesome-typescript-loader',
|
||||||
|
options: {
|
||||||
|
paths: {
|
||||||
|
"terminus-*": [path.resolve(__dirname, '../terminus-*')],
|
||||||
|
"*": [path.resolve(__dirname, '../app/node_modules/*')],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ test: /\.scss$/, use: ['to-string-loader', 'css-loader', 'sass-loader'] },
|
||||||
|
]
|
||||||
|
},
|
||||||
|
externals: [
|
||||||
|
/^@angular/,
|
||||||
|
/^@ng-bootstrap/,
|
||||||
|
/^terminus-/,
|
||||||
|
]
|
||||||
|
}
|
|
@ -5,4 +5,5 @@ module.exports = [
|
||||||
require('./terminus-terminal/webpack.config.js'),
|
require('./terminus-terminal/webpack.config.js'),
|
||||||
require('./terminus-clickable-links/webpack.config.js'),
|
require('./terminus-clickable-links/webpack.config.js'),
|
||||||
require('./terminus-community-color-schemes/webpack.config.js'),
|
require('./terminus-community-color-schemes/webpack.config.js'),
|
||||||
|
require('./terminus-theme-hype/webpack.config.js'),
|
||||||
]
|
]
|
||||||
|
|
Loading…
Reference in a new issue