This repository has been archived by the owner on Mar 17, 2021. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 158
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: fallback options behaviour (#145)
- Loading branch information
1 parent
e4d10a2
commit 03e631f
Showing
18 changed files
with
288 additions
and
233 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,46 +1,27 @@ | ||
function normalizeFallbackString(fallbackString, originalOptions) { | ||
const index = fallbackString.indexOf('?'); | ||
if (index >= 0) { | ||
return { | ||
loader: fallbackString.substr(0, index), | ||
query: fallbackString.substr(index), | ||
}; | ||
} | ||
import loaderUtils from 'loader-utils'; | ||
|
||
// To remain consistent with version 1.0.1, pass any other options which were provided to url-loader to the fallback loader. | ||
const { fallback, limit, mimetype, ...otherOptions } = originalOptions; | ||
export default function normalizeFallback(fallback, originalOptions) { | ||
let loader = 'file-loader'; | ||
let options = {}; | ||
|
||
return { | ||
loader: fallbackString, | ||
query: otherOptions, | ||
}; | ||
} | ||
if (typeof fallback === 'string') { | ||
loader = fallback; | ||
|
||
function normalizeFallbackObject(fallbackObject) { | ||
return { | ||
loader: fallbackObject.loader, | ||
query: fallbackObject.options, | ||
}; | ||
} | ||
const index = fallback.indexOf('?'); | ||
|
||
/** | ||
* Converts the fallback option, which can be a string or an object, to an object with a loader and a query. The result | ||
* has this form: | ||
* { | ||
* loader: 'file-loader', | ||
* query: '?name=[name].[ext]' | ||
* } | ||
* Note that the returned query can be either a string or an object. | ||
*/ | ||
export default function normalizeFallback(fallback, originalOptions) { | ||
// If no fallback was provided, use file-loader. | ||
if (!fallback) { | ||
return normalizeFallbackString('file-loader', originalOptions); | ||
if (index >= 0) { | ||
loader = fallback.substr(0, index); | ||
options = loaderUtils.parseQuery(fallback.substr(index)); | ||
} | ||
} | ||
|
||
if (typeof fallback === 'string') { | ||
return normalizeFallbackString(fallback, originalOptions); | ||
if (fallback !== null && typeof fallback === 'object') { | ||
({ loader, options } = fallback); | ||
} | ||
|
||
return normalizeFallbackObject(fallback); | ||
options = Object.assign({}, originalOptions, options); | ||
|
||
delete options.fallback; | ||
|
||
return { loader, options }; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
// Jest Snapshot v1, https://goo.gl/fbAQLP | ||
|
||
exports[`fallback option {Object} 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"fallback-[hash].[ext]\\",\\"unknown\\":\\"fallback-other-value\\"}"`; | ||
|
||
exports[`fallback option {String} (with query) 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"fallback-[hash].[ext]\\",\\"unknown\\":\\"fallback-value\\"}"`; | ||
|
||
exports[`fallback option {String} 1`] = `"module.exports={\\"limit\\":-9007199254740991,\\"name\\":\\"[name].[hash].[ext]\\",\\"unknown\\":\\"value\\"}"`; | ||
|
||
exports[`fallback option {undefined} 1`] = `"module.exports = \\"\\""`; |
Oops, something went wrong.