2018-04-20 20:07:36 +02:00
|
|
|
import * as vscode from 'vscode';
|
|
|
|
|
2018-06-28 23:26:07 +02:00
|
|
|
import {updateAccent} from './../../helpers/settings';
|
|
|
|
import {getDefaultValues, getAccentsProperties} from './../../helpers/fs';
|
2018-04-20 20:07:36 +02:00
|
|
|
|
|
|
|
const REGEXP_HEX: RegExp = /^#([0-9A-F]{6}|[0-9A-F]{8})$/i;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assigns colours
|
|
|
|
*/
|
2018-05-03 11:39:51 +02:00
|
|
|
const assignColorCustomizations = (colour: string, config: any): void => {
|
2018-06-28 23:26:07 +02:00
|
|
|
const accentsProperties = getAccentsProperties();
|
2018-05-03 11:39:51 +02:00
|
|
|
const newColour = isValidColour(colour) ? colour : undefined;
|
2018-04-20 20:07:36 +02:00
|
|
|
|
|
|
|
Object.keys(accentsProperties).forEach(propertyName => {
|
2018-06-28 23:26:07 +02:00
|
|
|
const accent = accentsProperties[propertyName];
|
2018-05-03 11:39:51 +02:00
|
|
|
let colorProp = newColour;
|
2018-04-20 20:07:36 +02:00
|
|
|
|
|
|
|
if (colour && accent.alpha < 100) {
|
2018-05-03 11:39:51 +02:00
|
|
|
colorProp = `${ colour }${ accent.alpha > 10 ? accent.alpha : `0${ accent.alpha }` }`;
|
2018-04-20 20:07:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (accent) {
|
2018-05-03 11:39:51 +02:00
|
|
|
config[propertyName] = colorProp;
|
2018-04-20 20:07:36 +02:00
|
|
|
}
|
|
|
|
});
|
2018-05-03 11:39:51 +02:00
|
|
|
};
|
2018-04-20 20:07:36 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines if a string is a valid colour
|
|
|
|
*/
|
2018-05-03 11:39:51 +02:00
|
|
|
const isValidColour = (colour: string | null | undefined): boolean =>
|
|
|
|
typeof colour === 'string' && REGEXP_HEX.test(colour);
|
2018-04-20 20:07:36 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets workbench options
|
|
|
|
*/
|
2018-08-20 22:19:10 +02:00
|
|
|
const setWorkbenchOptions = (config: any): Thenable<boolean> =>
|
2018-05-18 13:47:22 +02:00
|
|
|
vscode.workspace.getConfiguration().update('workbench.colorCustomizations', config, true)
|
2018-08-20 22:19:10 +02:00
|
|
|
.then(() => true, reason => vscode.window.showErrorMessage(reason));
|
2018-04-20 20:07:36 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* VSCode command
|
|
|
|
*/
|
2018-08-20 22:19:10 +02:00
|
|
|
export default async (accent?: string): Promise<boolean> => {
|
2018-05-03 11:39:51 +02:00
|
|
|
const themeConfigCommon = getDefaultValues();
|
|
|
|
const purgeColourKey: string = 'Remove accents';
|
2018-08-20 22:19:10 +02:00
|
|
|
const shouldUpdateAccent = Boolean(!accent);
|
|
|
|
let accentToSelect = accent;
|
2018-04-20 20:07:36 +02:00
|
|
|
|
2018-08-20 22:19:10 +02:00
|
|
|
// If called without accent shows the quick pick dropdown and wait response
|
|
|
|
if (!accentToSelect) {
|
|
|
|
const options: string[] = Object.keys(themeConfigCommon.accents).concat(purgeColourKey);
|
|
|
|
const accentSelected = await vscode.window.showQuickPick(options);
|
2018-04-20 20:07:36 +02:00
|
|
|
|
2018-08-20 22:19:10 +02:00
|
|
|
if (accentSelected === null || accentSelected === undefined) {
|
|
|
|
return Promise.resolve(null);
|
|
|
|
}
|
|
|
|
|
|
|
|
accentToSelect = accentSelected;
|
2018-05-18 13:47:22 +02:00
|
|
|
}
|
2018-04-20 20:07:36 +02:00
|
|
|
|
2018-05-18 13:47:22 +02:00
|
|
|
const config: any = vscode.workspace.getConfiguration().get('workbench.colorCustomizations');
|
|
|
|
|
2018-08-20 22:19:10 +02:00
|
|
|
switch (accentToSelect) {
|
2018-05-18 13:47:22 +02:00
|
|
|
case purgeColourKey:
|
|
|
|
assignColorCustomizations(undefined, config);
|
2018-08-20 22:19:10 +02:00
|
|
|
return setWorkbenchOptions(config)
|
|
|
|
.then(() => updateAccent(undefined))
|
|
|
|
.then(() => Promise.resolve(true));
|
2018-05-18 13:47:22 +02:00
|
|
|
default:
|
2018-08-20 22:19:10 +02:00
|
|
|
assignColorCustomizations(themeConfigCommon.accents[accentToSelect], config);
|
|
|
|
return setWorkbenchOptions(config)
|
|
|
|
.then(() =>
|
|
|
|
shouldUpdateAccent ? updateAccent(accentToSelect) : Promise.resolve(accentToSelect)
|
|
|
|
)
|
|
|
|
.then(() => Promise.resolve(true));
|
2018-05-18 13:47:22 +02:00
|
|
|
}
|
2018-04-20 20:07:36 +02:00
|
|
|
|
2018-05-03 11:39:51 +02:00
|
|
|
};
|