-
Notifications
You must be signed in to change notification settings - Fork 0
/
commerce-config.js
105 lines (91 loc) · 3.13 KB
/
commerce-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
100
101
102
103
104
105
/**
* This file is expected to be used in next.config.js only
*/
const path = require('path')
const fs = require('fs')
const merge = require('deepmerge')
const prettier = require('prettier')
const core = require('@vercel/commerce/config')
const PROVIDERS = [
'@vercel/commerce-local',
'@vercel/commerce-bigcommerce',
'@vercel/commerce-saleor',
'@vercel/commerce-shopify',
'@vercel/commerce-swell',
'@vercel/commerce-vendure',
'@vercel/commerce-ordercloud',
'@vercel/commerce-kibocommerce',
'@vercel/commerce-spree',
'@vercel/commerce-commercejs',
]
function getProviderName() {
return (
process.env.COMMERCE_PROVIDER ||
(process.env.BIGCOMMERCE_STOREFRONT_API_URL
? '@vercel/commerce-bigcommerce'
: process.env.NEXT_PUBLIC_SHOPIFY_STORE_DOMAIN
? '@vercel/commerce-shopify'
: process.env.NEXT_PUBLIC_SWELL_STORE_ID
? '@vercel/commerce-swell'
: '@vercel/commerce-local')
)
}
function withCommerceConfig(nextConfig = {}) {
const config = merge(
{ commerce: { provider: getProviderName() } },
nextConfig
)
const { commerce } = config
const { provider } = commerce
if (!provider) {
throw new Error(
`The commerce provider is missing, please add a valid provider name or its environment variables`
)
}
if (!PROVIDERS.includes(provider)) {
throw new Error(
`The commerce provider "${provider}" can't be found, please use one of "${PROVIDERS.join(
', '
)}"`
)
}
// Update paths in `tsconfig.json` to point to the selected provider
if (commerce.updateTSConfig !== false) {
const tsconfigPath = path.join(
process.cwd(),
commerce.tsconfigPath || 'tsconfig.json'
)
const tsconfig = require(tsconfigPath)
// The module path is a symlink in node_modules
// -> /node_modules/[name]/dist/index.js
const absolutePath = require.resolve(provider)
// but we want references to go to the real path in /packages instead
// -> packages/[name]/dist
const distPath = path.join(path.relative(process.cwd(), absolutePath), '..')
// -> /packages/[name]/src
const modulePath = path.join(distPath, '../src')
tsconfig.compilerOptions.paths['@framework'] = [`${modulePath}`]
tsconfig.compilerOptions.paths['@framework/*'] = [`${modulePath}/*`]
fs.writeFileSync(
tsconfigPath,
prettier.format(JSON.stringify(tsconfig), { parser: 'json' })
)
const webpack = config.webpack
// To improve the DX of using references, we'll switch from `src` to `dist`
// only for webpack so imports resolve correctly but typechecking goes to `src`
config.webpack = (cfg, options) => {
if (Array.isArray(cfg.resolve.plugins)) {
const jsconfigPaths = cfg.resolve.plugins.find(
(plugin) => plugin.constructor.name === 'JsConfigPathsPlugin'
)
if (jsconfigPaths) {
jsconfigPaths.paths['@framework'] = [distPath]
jsconfigPaths.paths['@framework/*'] = [`${distPath}/*`]
}
}
return webpack ? webpack(cfg, options) : cfg
}
}
return core.withCommerceConfig(config)
}
module.exports = { withCommerceConfig, getProviderName }