mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-22 13:45:18 +00:00
feat: support targer functions to consume nuxtOptions
This commit is contained in:
parent
5647d2dad0
commit
91caf2c470
@ -1,12 +1,13 @@
|
|||||||
import { resolve } from 'path'
|
import { resolve } from 'path'
|
||||||
import defu from 'defu'
|
import defu from 'defu'
|
||||||
import { NuxtOptions } from '@nuxt/types'
|
import type { NuxtOptions } from '@nuxt/types'
|
||||||
import { tryImport, resolvePath, detectTarget } from './utils'
|
import { tryImport, resolvePath, detectTarget } from './utils'
|
||||||
import * as TARGETS from './targets'
|
import * as TARGETS from './targets'
|
||||||
|
|
||||||
export type UnresolvedPath = string | ((SLSOptions) => string)
|
export type UnresolvedPath = string | ((SLSOptions) => string)
|
||||||
|
|
||||||
export interface SLSOptions {
|
export interface SLSOptions {
|
||||||
|
nuxtOptions: NuxtOptions
|
||||||
node: false
|
node: false
|
||||||
target: string
|
target: string
|
||||||
entry: UnresolvedPath
|
entry: UnresolvedPath
|
||||||
@ -42,7 +43,7 @@ export interface SLSConfig extends Omit<Partial<SLSOptions>, 'targetDir'> {
|
|||||||
targetDir: UnresolvedPath
|
targetDir: UnresolvedPath
|
||||||
}
|
}
|
||||||
|
|
||||||
export type SLSTarget = Partial<SLSConfig>
|
export type SLSTarget = Partial<SLSConfig> | ((NuxtOptions) => Partial<SLSConfig>)
|
||||||
|
|
||||||
export function getoptions (nuxtOptions: NuxtOptions): SLSOptions {
|
export function getoptions (nuxtOptions: NuxtOptions): SLSOptions {
|
||||||
const defaults: SLSConfig = {
|
const defaults: SLSConfig = {
|
||||||
@ -55,6 +56,7 @@ export function getoptions (nuxtOptions: NuxtOptions): SLSOptions {
|
|||||||
outName: '_nuxt.js',
|
outName: '_nuxt.js',
|
||||||
runtimeDir: resolve(__dirname, '../runtime'),
|
runtimeDir: resolve(__dirname, '../runtime'),
|
||||||
static: [],
|
static: [],
|
||||||
|
generateIgnore: [],
|
||||||
nuxt: 2,
|
nuxt: 2,
|
||||||
logStartup: true,
|
logStartup: true,
|
||||||
inlineChunks: true,
|
inlineChunks: true,
|
||||||
@ -65,11 +67,15 @@ export function getoptions (nuxtOptions: NuxtOptions): SLSOptions {
|
|||||||
if (typeof target === 'function') {
|
if (typeof target === 'function') {
|
||||||
target = target(nuxtOptions)
|
target = target(nuxtOptions)
|
||||||
}
|
}
|
||||||
|
|
||||||
let targetDefaults = TARGETS[target] || tryImport(nuxtOptions.rootDir, target)
|
let targetDefaults = TARGETS[target] || tryImport(nuxtOptions.rootDir, target)
|
||||||
if (!targetDefaults) {
|
if (!targetDefaults) {
|
||||||
throw new Error('Cannot resolve target: ' + target)
|
throw new Error('Cannot resolve target: ' + target)
|
||||||
}
|
}
|
||||||
targetDefaults = targetDefaults.default || targetDefaults
|
targetDefaults = targetDefaults.default || targetDefaults
|
||||||
|
if (typeof targetDefaults === 'function') {
|
||||||
|
targetDefaults = targetDefaults(nuxtOptions)
|
||||||
|
}
|
||||||
|
|
||||||
const options: SLSOptions = defu(nuxtOptions.serverless, targetDefaults, defaults, { target })
|
const options: SLSOptions = defu(nuxtOptions.serverless, targetDefaults, defaults, { target })
|
||||||
|
|
||||||
|
@ -2,6 +2,8 @@ import { relative, dirname, resolve } from 'path'
|
|||||||
import { writeFile, mkdirp } from 'fs-extra'
|
import { writeFile, mkdirp } from 'fs-extra'
|
||||||
import jiti from 'jiti'
|
import jiti from 'jiti'
|
||||||
import defu from 'defu'
|
import defu from 'defu'
|
||||||
|
import Hookable from 'hookable'
|
||||||
|
import type { NuxtOptions } from '@nuxt/types'
|
||||||
import { SLSOptions, UnresolvedPath, SLSTarget } from './config'
|
import { SLSOptions, UnresolvedPath, SLSTarget } from './config'
|
||||||
|
|
||||||
export function hl (str: string) {
|
export function hl (str: string) {
|
||||||
@ -60,6 +62,18 @@ export function detectTarget () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function extendTarget (base: SLSTarget, target: SLSTarget): SLSTarget {
|
export function extendTarget (base: SLSTarget, target: SLSTarget): SLSTarget {
|
||||||
// TODO: merge hooks
|
return (nuxtOptions: NuxtOptions) => {
|
||||||
return defu(target, base)
|
if (typeof target === 'function') {
|
||||||
|
target = target(nuxtOptions)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof base === 'function') {
|
||||||
|
base = base(base)
|
||||||
|
}
|
||||||
|
|
||||||
|
return defu({
|
||||||
|
hooks: Hookable.mergeHooks(base.hooks, target.hooks),
|
||||||
|
nuxtHooks: Hookable.mergeHooks(base.nuxtHooks as any, target.nuxtHooks as any)
|
||||||
|
}, target, base)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user