-
Notifications
You must be signed in to change notification settings - Fork 498
/
Copy pathcheck-css-import.ts
52 lines (46 loc) · 1.46 KB
/
check-css-import.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
// Copyright 2021 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
/**
* @fileoverview Prevent usage of customElements.define() and use the helper
* function instead
*/
import * as fs from 'fs';
import * as path from 'path';
import {createRule} from './utils/ruleCreator.ts';
export default createRule({
name: 'check-css-import',
meta: {
type: 'problem',
docs: {
description: 'check CSS file imports',
category: 'Possible Errors',
},
fixable: 'code',
messages: {
fileDoesNotExist: 'File {{filename}} does not exist. Check you are importing the correct file.',
},
schema: [], // no options
},
defaultOptions: [],
create: function(context) {
const filename = context.getFilename();
return {
ImportDeclaration(node) {
const importPath = path.normalize(`${node.source.value}`);
if (importPath.endsWith('.css.js')) {
const importingFileName = path.resolve(filename);
const exportingFileName = path.resolve(path.dirname(importingFileName), importPath);
const importedCSS = exportingFileName.replace(/\.js$/, '');
if (!fs.existsSync(importedCSS)) {
context.report({
node,
messageId: 'fileDoesNotExist',
data: {filename: path.basename(importedCSS)},
});
}
}
},
};
},
});