2021-09-06 16:57:07 +01:00
|
|
|
import { Theme } from '../../themes/type';
|
|
|
|
const { camelCaseToDash, formatCssSize } = require('../../string-utils');
|
|
|
|
|
2023-07-16 17:42:42 +01:00
|
|
|
const isColor = (v: any) => {
|
|
|
|
return v && typeof v === 'object' && ('color' in v) && ('model' in v) && ('valpha' in v);
|
|
|
|
};
|
2021-09-06 16:57:07 +01:00
|
|
|
|
|
|
|
export default function(theme: Theme) {
|
|
|
|
const lines = [];
|
|
|
|
lines.push(':root {');
|
|
|
|
|
2023-07-16 17:42:42 +01:00
|
|
|
const names = Object.keys(theme).sort();
|
|
|
|
|
|
|
|
for (const name of names) {
|
2021-09-06 16:57:07 +01:00
|
|
|
const value = (theme as any)[name];
|
2023-07-16 17:42:42 +01:00
|
|
|
|
|
|
|
if (typeof value === 'object' && !isColor(value)) continue;
|
|
|
|
if (value === undefined || value === null) continue;
|
|
|
|
if (typeof value === 'number' && isNaN(value)) continue;
|
|
|
|
|
2021-09-06 16:57:07 +01:00
|
|
|
const newName = `--joplin-${camelCaseToDash(name)}`;
|
|
|
|
const formattedValue = typeof value === 'number' && newName.indexOf('opacity') < 0 ? formatCssSize(value) : value;
|
|
|
|
lines.push(`\t${newName}: ${formattedValue};`);
|
|
|
|
}
|
|
|
|
|
|
|
|
lines.push('}');
|
|
|
|
|
|
|
|
return lines.join('\n');
|
|
|
|
}
|