README
ts-options-defaults
Options-defaults design pattern implementation for reliable configuration. It merges objects deeply, overrides arrays and classes (different than Object) and the result remains strongly typed.
Table of contents
Getting Started
npm i ts-options-defaults
Usage
Design pattern
import { defaults } from 'ts-options-defaults';
export interface ISomeOptions {
logger?: Partial<Console>;
}
export class Something {
static defaults = {
logger: console,
};
options: ISomeOptions & typeof Something.defaults;
constructor(options?: ISomeOptions) {
this.options = defaults(Rat.defaults, options);
}
}
Behavior
import { defaults } from 'ts-options-defaults';
class TestLogger {
constructor(public name = `TestLogger`) {}
log() {
console.log(`Call from ${this.name}`);
}
}
const someDefaults = {
console,
nested: {
property: 'default',
shouldBeDefault: 'default',
array: ['default1', 'default2'],
},
};
const someOptions = {
nested: {
property: 'overriden',
array: ['overriden1'],
},
array: ['overriden'],
};
const options = defaults(
someDefaults,
someOptions,
{
console: {
log: () => {
console.log(`TEST`);
},
},
},
{
console: new TestLogger(),
},
);
options.console.log(`log`); // "Call from TestLogger"
options.console.debug(`debug`); // "debug"
// options will be:
{
"nested": {
"property": "overriden",
"shouldBeDefault": "default",
"array": [
"overriden1"
]
},
"array": [
"overriden"
]
}
// someDefaults will not be mutated!
Features
Beats alternatives - better alternative to {...defaults, ...options}
destructing and lodash _.defaults
or _.merge
Secure - immune to prototype pollution attack
Simple - just 40 lines of clean TypeScript code
Strongly typed - result remains strongly typed