mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-08 09:38:26 -05:00
SQL Operations Studio Public Preview 1 (0.23) release source code
This commit is contained in:
145
src/vs/platform/theme/common/themeService.ts
Normal file
145
src/vs/platform/theme/common/themeService.ts
Normal file
@@ -0,0 +1,145 @@
|
||||
/*---------------------------------------------------------------------------------------------
|
||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
'use strict';
|
||||
|
||||
import { createDecorator } from 'vs/platform/instantiation/common/instantiation';
|
||||
import { Color } from 'vs/base/common/color';
|
||||
import { IDisposable } from 'vs/base/common/lifecycle';
|
||||
import platform = require('vs/platform/registry/common/platform');
|
||||
import { ColorIdentifier } from 'vs/platform/theme/common/colorRegistry';
|
||||
import Event, { Emitter } from 'vs/base/common/event';
|
||||
|
||||
export const IThemeService = createDecorator<IThemeService>('themeService');
|
||||
|
||||
export interface ThemeColor {
|
||||
id: string;
|
||||
}
|
||||
|
||||
export function themeColorFromId(id: ColorIdentifier) {
|
||||
return { id };
|
||||
}
|
||||
|
||||
// base themes
|
||||
export const DARK: ThemeType = 'dark';
|
||||
export const LIGHT: ThemeType = 'light';
|
||||
export const HIGH_CONTRAST: ThemeType = 'hc';
|
||||
export type ThemeType = 'light' | 'dark' | 'hc';
|
||||
|
||||
export function getThemeTypeSelector(type: ThemeType): string {
|
||||
switch (type) {
|
||||
case DARK: return 'vs-dark';
|
||||
case HIGH_CONTRAST: return 'hc-black';
|
||||
default: return 'vs';
|
||||
}
|
||||
}
|
||||
|
||||
export interface ITheme {
|
||||
readonly type: ThemeType;
|
||||
|
||||
/**
|
||||
* Resolves the color of the given color identifer. If the theme does not
|
||||
* specify the color, the default color is returned unless <code>useDefault</code> is set to false.
|
||||
* @param color the id of the color
|
||||
* @param useDefault specifies if the default color should be used. If not set, the default is used.
|
||||
*/
|
||||
getColor(color: ColorIdentifier, useDefault?: boolean): Color;
|
||||
|
||||
/**
|
||||
* Returns wheter the theme defines a value for the color. If not, that means the
|
||||
* default color will be used.
|
||||
*/
|
||||
defines(color: ColorIdentifier): boolean;
|
||||
}
|
||||
|
||||
export interface ICssStyleCollector {
|
||||
addRule(rule: string): void;
|
||||
}
|
||||
|
||||
export interface IThemingParticipant {
|
||||
(theme: ITheme, collector: ICssStyleCollector): void;
|
||||
}
|
||||
|
||||
export interface IThemeService {
|
||||
_serviceBrand: any;
|
||||
|
||||
getTheme(): ITheme;
|
||||
|
||||
/**
|
||||
* Register a theming participant that is invoked after every theme change.
|
||||
*/
|
||||
onThemeChange: Event<ITheme>;
|
||||
|
||||
}
|
||||
|
||||
// static theming participant
|
||||
export const Extensions = {
|
||||
ThemingContribution: 'base.contributions.theming'
|
||||
};
|
||||
|
||||
export interface IThemingRegistry {
|
||||
|
||||
/**
|
||||
* Register a theming participant that is invoked on every theme change.
|
||||
*/
|
||||
onThemeChange(participant: IThemingParticipant): IDisposable;
|
||||
|
||||
getThemingParticipants(): IThemingParticipant[];
|
||||
|
||||
readonly onThemingParticipantAdded: Event<IThemingParticipant>;
|
||||
}
|
||||
|
||||
class ThemingRegistry implements IThemingRegistry {
|
||||
private themingParticipants: IThemingParticipant[] = [];
|
||||
private onThemingParticipantAddedEmitter: Emitter<IThemingParticipant>;
|
||||
|
||||
constructor() {
|
||||
this.themingParticipants = [];
|
||||
this.onThemingParticipantAddedEmitter = new Emitter<IThemingParticipant>();
|
||||
}
|
||||
|
||||
public onThemeChange(participant: IThemingParticipant): IDisposable {
|
||||
this.themingParticipants.push(participant);
|
||||
this.onThemingParticipantAddedEmitter.fire(participant);
|
||||
return {
|
||||
dispose: () => {
|
||||
const idx = this.themingParticipants.indexOf(participant);
|
||||
this.themingParticipants.splice(idx, 1);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
public get onThemingParticipantAdded(): Event<IThemingParticipant> {
|
||||
return this.onThemingParticipantAddedEmitter.event;
|
||||
}
|
||||
|
||||
public getThemingParticipants(): IThemingParticipant[] {
|
||||
return this.themingParticipants;
|
||||
}
|
||||
}
|
||||
|
||||
let themingRegistry = new ThemingRegistry();
|
||||
platform.Registry.add(Extensions.ThemingContribution, themingRegistry);
|
||||
|
||||
export function registerThemingParticipant(participant: IThemingParticipant): IDisposable {
|
||||
return themingRegistry.onThemeChange(participant);
|
||||
}
|
||||
|
||||
/**
|
||||
* Tag function for strings containing css rules
|
||||
*/
|
||||
export function cssRule(literals, ...placeholders) {
|
||||
let result = '';
|
||||
for (let i = 0; i < placeholders.length; i++) {
|
||||
result += literals[i];
|
||||
let placeholder = placeholders[i];
|
||||
if (placeholder === null) {
|
||||
result += 'transparent';
|
||||
} else {
|
||||
result += placeholder.toString();
|
||||
}
|
||||
}
|
||||
result += literals[literals.length - 1];
|
||||
return result;
|
||||
}
|
||||
Reference in New Issue
Block a user