-
Notifications
You must be signed in to change notification settings - Fork 40
/
babel.config.js
99 lines (91 loc) · 3 KB
/
babel.config.js
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/**
* @license
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
* SPDX-FileCopyrightText: The Apache Software Foundation
* SPDX-License-Identifier: Apache-2.0
*/
const path = require('path');
const { resolvePath } = require('babel-plugin-module-resolver');
const packagePath = path.join(__dirname, 'packages');
module.exports = (api) => {
const ENV = api.env();
const DEV = ENV === 'development';
const TEST = ENV === 'test';
// Options for the @babel/env preset.
const envOptions = {
// Use minimal syntax fixes where possible
// Note: This setting may become the default in Babel 8.
bugfixes: true,
// Do not transform module syntax.
modules: false,
};
// Options for the @babel/typescript preset.
const typescriptOptions = {
// Opt in to a Babel 8 default.
allowDeclareFields: true,
// Be explicit about type-only imports.
onlyRemoveTypeImports: true,
};
// Options for the module-resolver plugin.
// Used for resolving source files during development.
const resolverOptions = {
...(DEV || TEST
? {
alias: {
'^@apache-annotator/([^/]+)$': ([, name]) =>
path.join(packagePath, name, 'src', 'index.ts'),
},
resolvePath(sourcePath, currentFile, opts) {
if (
currentFile.startsWith(packagePath) &&
currentFile.endsWith('.ts') &&
sourcePath.startsWith('.') &&
sourcePath.endsWith('.js')
) {
return sourcePath.replace(/\.js$/, '.ts');
}
return resolvePath(sourcePath, currentFile, opts);
},
}
: null),
};
// Options for the @babel/transform-runtime plugin.
const runtimeOptions = {
// Use corejs version 3.
corejs: { version: 3, proposals: true },
};
return {
plugins: [
'@babel/plugin-proposal-class-properties',
['@babel/transform-runtime', runtimeOptions],
['module-resolver', resolverOptions],
'preserve-comment-header',
...(TEST ? ['istanbul'] : []),
],
presets: [
['@babel/env', envOptions],
['@babel/typescript', typescriptOptions],
],
targets: {
browsers: 'defaults',
esmodules: true,
node: TEST ? 'current' : '14.15',
},
};
};