108 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| <p align="center">
 | |
|   <a href="https://gulpjs.com">
 | |
|     <img height="257" width="114" src="https://raw.githubusercontent.com/gulpjs/artwork/master/gulp-2x.png">
 | |
|   </a>
 | |
| </p>
 | |
| 
 | |
| # resolve-options
 | |
| 
 | |
| [![NPM version][npm-image]][npm-url] [![Downloads][downloads-image]][npm-url] [![Build Status][ci-image]][ci-url] [![Coveralls Status][coveralls-image]][coveralls-url]
 | |
| 
 | |
| Resolve an options object based on configuration.
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| ```js
 | |
| // This example assumes a Vinyl file
 | |
| 
 | |
| var createResolver = require('resolve-options');
 | |
| 
 | |
| var config = {
 | |
|   cwd: {
 | |
|     type: 'string',
 | |
|     default: process.cwd,
 | |
|   },
 | |
|   sourcemaps: {
 | |
|     type: 'boolean',
 | |
|     default: false,
 | |
|   },
 | |
|   since: {
 | |
|     type: ['date', 'number'],
 | |
|   },
 | |
|   read: {
 | |
|     type: 'boolean',
 | |
|   },
 | |
| };
 | |
| 
 | |
| var options = {
 | |
|   sourcemaps: true,
 | |
|   since: Date.now(),
 | |
|   read: function (file) {
 | |
|     return file.extname !== '.mp4';
 | |
|   },
 | |
| };
 | |
| 
 | |
| var resolver = createResolver(config, options);
 | |
| 
 | |
| var cwd = resolver.resolve('cwd', file);
 | |
| // cwd === process.cwd()
 | |
| 
 | |
| var sourcemaps = resolver.resolve('sourcemaps', file);
 | |
| // sourcemaps === true
 | |
| 
 | |
| var read = resolver.resolve('read', file);
 | |
| // Given .mp4, read === false
 | |
| // Given .txt, read === true
 | |
| ```
 | |
| 
 | |
| ## API
 | |
| 
 | |
| ### `createResolver([config,] [options])`
 | |
| 
 | |
| Takes a `config` object that describes the options to accept/resolve and an `options` object (usually passed by a user) to resolve against the `config`. Returns a `resolver` that contains a `resolve` method for realtime resolution of options.
 | |
| 
 | |
| The `config` object takes the following structure:
 | |
| 
 | |
| ```graphql
 | |
| config {
 | |
|   [optionKey] {
 | |
|     type // string, array or function
 | |
|     default // any value or function
 | |
|   }
 | |
| }
 | |
| ```
 | |
| 
 | |
| Each option is represented by its `optionKey` in the `config` object. It must be an object with a `type` property.
 | |
| 
 | |
| The `type` property must be a string, array or function which will be passed to the [`value-or-function`][value-or-function] module (functions will be bound to the resolver to allow for dependent options).
 | |
| 
 | |
| A `default` property may also be specified as a fallback if the option isn't available or is invalid. The `default` value can be any value or a function (functions will be bound to the resolver to allow for dependent defaults). **Note:** `default` values are not type-validated by the `value-or-function` module.
 | |
| 
 | |
| ### `resolver.resolve(optionKey, [...arguments])`
 | |
| 
 | |
| Takes an `optionKey` string and any number of `arguments` to apply if an option is a function. Returns the resolved value for the `optionKey`.
 | |
| 
 | |
| ### `resolver.resolveConstant(optionKey)`
 | |
| 
 | |
| Like `resolve`, but only returns a value if the option is constant (not a function).
 | |
| 
 | |
| ## License
 | |
| 
 | |
| MIT
 | |
| 
 | |
| <!-- prettier-ignore-start -->
 | |
| [downloads-image]: https://img.shields.io/npm/dm/resolve-options.svg?style=flat-square
 | |
| [npm-url]: https://npmjs.com/package/resolve-options
 | |
| [npm-image]: https://img.shields.io/npm/v/resolve-options.svg?style=flat-square
 | |
| 
 | |
| [ci-url]: https://github.com/gulpjs/resolve-options/actions?query=workflow:dev
 | |
| [ci-image]: https://img.shields.io/github/workflow/status/gulpjs/resolve-options/dev?style=flat-square
 | |
| 
 | |
| [coveralls-url]: https://coveralls.io/r/gulpjs/resolve-options
 | |
| [coveralls-image]: https://img.shields.io/coveralls/gulpjs/resolve-options/master.svg?style=flat-square
 | |
| <!-- prettier-ignore-end -->
 | |
| 
 | |
| <!-- prettier-ignore-start -->
 | |
| [value-or-function]: https://github.com/gulpjs/value-or-function
 | |
| <!-- prettier-ignore-end -->
 |