mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-20 18:48:28 +02:00
117 lines
3.4 KiB
TypeScript
117 lines
3.4 KiB
TypeScript
import { Theme, ThemeAppearance } from '../../themes/type';
|
|
import themeToCss from './themeToCss';
|
|
|
|
const input: Theme = {
|
|
appearance: ThemeAppearance.Light,
|
|
|
|
// Color scheme "1" is the basic one, like used to display the note
|
|
// content. It's basically dark gray text on white background
|
|
backgroundColor: '#ffffff',
|
|
backgroundColorTransparent: 'rgba(255,255,255,0.9)',
|
|
oddBackgroundColor: '#eeeeee',
|
|
color: '#32373F', // For regular text
|
|
colorError: 'red',
|
|
colorCorrect: 'green',
|
|
colorWarn: 'rgb(228,86,0)',
|
|
colorWarnUrl: '#155BDA',
|
|
colorFaded: '#7C8B9E', // For less important text
|
|
dividerColor: '#dddddd',
|
|
selectedColor: '#e5e5e5',
|
|
urlColor: '#155BDA',
|
|
|
|
// Color scheme "2" is used for the sidebar. It's white text over
|
|
// dark blue background.
|
|
backgroundColor2: '#313640',
|
|
color2: '#ffffff',
|
|
selectedColor2: '#131313',
|
|
colorError2: '#ff6c6c',
|
|
colorWarn2: '#ffcb81',
|
|
colorWarn3: '#ff7626',
|
|
|
|
// Color scheme "3" is used for the config screens for example/
|
|
// It's dark text over gray background.
|
|
backgroundColor3: '#F4F5F6',
|
|
backgroundColorHover3: '#CBDAF1',
|
|
color3: '#738598',
|
|
|
|
// Color scheme "4" is used for secondary-style buttons. It makes a white
|
|
// button with blue text.
|
|
backgroundColor4: '#ffffff',
|
|
color4: '#2D6BDC',
|
|
|
|
raisedBackgroundColor: '#e5e5e5',
|
|
raisedColor: '#222222',
|
|
searchMarkerBackgroundColor: '#F7D26E',
|
|
searchMarkerColor: 'black',
|
|
|
|
warningBackgroundColor: '#FFD08D',
|
|
destructiveColor: '#F00000',
|
|
|
|
tableBackgroundColor: 'rgb(247, 247, 247)',
|
|
codeBackgroundColor: 'rgb(243, 243, 243)',
|
|
codeBorderColor: 'rgb(220, 220, 220)',
|
|
codeColor: 'rgb(0,0,0)',
|
|
|
|
blockQuoteOpacity: 0.7,
|
|
|
|
codeMirrorTheme: 'default',
|
|
codeThemeCss: 'atom-one-light.css',
|
|
|
|
headerBackgroundColor: '#ffffff',
|
|
textSelectionColor: '#a0a0ff',
|
|
colorBright2: '#ffffff',
|
|
};
|
|
|
|
const expected = `
|
|
:root {
|
|
--joplin-appearance: light;
|
|
--joplin-background-color: #ffffff;
|
|
--joplin-background-color2: #313640;
|
|
--joplin-background-color3: #F4F5F6;
|
|
--joplin-background-color4: #ffffff;
|
|
--joplin-background-color-hover3: #CBDAF1;
|
|
--joplin-background-color-transparent: rgba(255,255,255,0.9);
|
|
--joplin-block-quote-opacity: 0.7;
|
|
--joplin-code-background-color: rgb(243, 243, 243);
|
|
--joplin-code-border-color: rgb(220, 220, 220);
|
|
--joplin-code-color: rgb(0,0,0);
|
|
--joplin-code-mirror-theme: default;
|
|
--joplin-code-theme-css: atom-one-light.css;
|
|
--joplin-color: #32373F;
|
|
--joplin-color2: #ffffff;
|
|
--joplin-color3: #738598;
|
|
--joplin-color4: #2D6BDC;
|
|
--joplin-color-bright2: #ffffff;
|
|
--joplin-color-correct: green;
|
|
--joplin-color-error: red;
|
|
--joplin-color-error2: #ff6c6c;
|
|
--joplin-color-faded: #7C8B9E;
|
|
--joplin-color-warn: rgb(228,86,0);
|
|
--joplin-color-warn2: #ffcb81;
|
|
--joplin-color-warn3: #ff7626;
|
|
--joplin-color-warn-url: #155BDA;
|
|
--joplin-destructive-color: #F00000;
|
|
--joplin-divider-color: #dddddd;
|
|
--joplin-header-background-color: #ffffff;
|
|
--joplin-odd-background-color: #eeeeee;
|
|
--joplin-raised-background-color: #e5e5e5;
|
|
--joplin-raised-color: #222222;
|
|
--joplin-search-marker-background-color: #F7D26E;
|
|
--joplin-search-marker-color: black;
|
|
--joplin-selected-color: #e5e5e5;
|
|
--joplin-selected-color2: #131313;
|
|
--joplin-table-background-color: rgb(247, 247, 247);
|
|
--joplin-text-selection-color: #a0a0ff;
|
|
--joplin-url-color: #155BDA;
|
|
--joplin-warning-background-color: #FFD08D;
|
|
}`;
|
|
|
|
describe('themeToCss', () => {
|
|
|
|
it('should a theme to a CSS string', async () => {
|
|
const actual = themeToCss(input);
|
|
expect(actual.trim()).toBe(expected.trim());
|
|
});
|
|
|
|
});
|