mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* create rule to find instances of theme variables * emit theme token usage metrics * move awking into script * make sure theme usage is covering ts and tsx files, remove commented lines
52 lines
1.4 KiB
JavaScript
52 lines
1.4 KiB
JavaScript
// @ts-check
|
|
const { ESLintUtils, AST_NODE_TYPES } = require('@typescript-eslint/utils');
|
|
|
|
const createRule = ESLintUtils.RuleCreator((name) => `https://github.com/grafana/grafana#${name}`);
|
|
|
|
const themeTokenUsage = createRule({
|
|
create(context) {
|
|
return {
|
|
Identifier: function (node) {
|
|
if (node.name === 'theme') {
|
|
const ancestors = context.getAncestors().reverse();
|
|
const paths = [];
|
|
let lastAncestor = null;
|
|
for (const ancestor of ancestors) {
|
|
if (ancestor.type === AST_NODE_TYPES.MemberExpression && ancestor.property.type === AST_NODE_TYPES.Identifier) {
|
|
paths.push(ancestor.property.name)
|
|
lastAncestor = ancestor;
|
|
} else {
|
|
break;
|
|
}
|
|
}
|
|
if (paths.length > 0 && lastAncestor) {
|
|
paths.unshift('theme');
|
|
context.report({
|
|
node: lastAncestor,
|
|
messageId: "themeTokenUsed",
|
|
data: {
|
|
identifier: paths.join('.')
|
|
}
|
|
})
|
|
}
|
|
}
|
|
}
|
|
};
|
|
},
|
|
name: 'theme-token-usage',
|
|
meta: {
|
|
type: 'problem',
|
|
docs: {
|
|
description: 'Check for theme token usage',
|
|
recommended: false,
|
|
},
|
|
messages: {
|
|
themeTokenUsed: '{{ identifier }}',
|
|
},
|
|
schema: [],
|
|
},
|
|
defaultOptions: [],
|
|
});
|
|
|
|
module.exports = themeTokenUsage;
|