blob: fff8dfd706968ffd5ac0b7ddee6abed481fea27c [file] [log] [blame] [raw]
// Copyright (c) 2016, Compiler Explorer Authors
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
import * as monaco from 'monaco-editor';
import {Themes} from './themes.js';
export type ColourScheme = 'rainbow' | 'rainbow2' | 'earth' | 'green-blue' | 'gray-shade' | 'rainbow-dark';
export type AppTheme = Themes | 'all';
export interface ColourSchemeInfo {
name: ColourScheme;
desc: string;
count: number;
themes: AppTheme[];
}
// If you want to use a scheme in every theme, set `theme: ['all']`
export const schemes: ColourSchemeInfo[] = [
{name: 'rainbow', desc: 'Rainbow 1', count: 12, themes: ['default']},
{name: 'rainbow2', desc: 'Rainbow 2', count: 12, themes: ['default']},
{
name: 'earth',
desc: 'Earth tones (colourblind safe)',
count: 9,
themes: ['default'],
},
{
name: 'green-blue',
desc: 'Greens and blues (colourblind safe)',
count: 4,
themes: ['default'],
},
{
name: 'gray-shade',
desc: 'Gray shades',
count: 4,
themes: ['dark', 'darkplus'],
},
{
name: 'rainbow-dark',
desc: 'Dark Rainbow',
count: 12,
themes: ['dark', 'darkplus'],
},
];
export function applyColours(
editor: monaco.editor.ICodeEditor,
colours: Record<number, number>,
schemeName: string,
previousDecorations: string[],
): string[] {
const scheme = schemes.find(scheme => scheme.name === schemeName) ?? schemes[0];
const newDecorations: monaco.editor.IModelDeltaDecoration[] = Object.entries(colours).map(([line, index]) => {
const realLineNumber = parseInt(line) + 1;
return {
range: new monaco.Range(realLineNumber, 1, realLineNumber, 1),
options: {
isWholeLine: true,
className: 'line-linkage ' + scheme.name + '-' + (index % scheme.count),
},
};
});
return editor.deltaDecorations(previousDecorations, newDecorations);
}