You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

79 lines
2.0 KiB
JavaScript

'use strict';
const SchemaTypeOptions = require('./SchemaTypeOptions');
/**
* The options defined on an Array schematype.
*
* #### Example:
*
* const schema = new Schema({ tags: [String] });
* schema.path('tags').options; // SchemaArrayOptions instance
*
* @api public
* @inherits SchemaTypeOptions
* @constructor SchemaArrayOptions
*/
class SchemaArrayOptions extends SchemaTypeOptions {}
const opts = require('./propertyOptions');
/**
* If this is an array of strings, an array of allowed values for this path.
* Throws an error if this array isn't an array of strings.
*
* @api public
* @property enum
* @memberOf SchemaArrayOptions
* @type {Array}
* @instance
*/
Object.defineProperty(SchemaArrayOptions.prototype, 'enum', opts);
/**
* If set, specifies the type of this array's values. Equivalent to setting
* `type` to an array whose first element is `of`.
*
* #### Example:
*
* // `arr` is an array of numbers.
* new Schema({ arr: [Number] });
* // Equivalent way to define `arr` as an array of numbers
* new Schema({ arr: { type: Array, of: Number } });
*
* @api public
* @property of
* @memberOf SchemaArrayOptions
* @type {Function|String}
* @instance
*/
Object.defineProperty(SchemaArrayOptions.prototype, 'of', opts);
/**
* If set to `false`, will always deactivate casting non-array values to arrays.
* If set to `true`, will cast non-array values to arrays if `init` and `SchemaArray.options.castNonArrays` are also `true`
*
* #### Example:
*
* const Model = db.model('Test', new Schema({ x1: { castNonArrays: false, type: [String] } }));
* const doc = new Model({ x1: "some non-array value" });
* await doc.validate(); // Errors with "CastError"
*
* @api public
* @property castNonArrays
* @memberOf SchemaArrayOptions
* @type {Boolean}
* @instance
*/
Object.defineProperty(SchemaArrayOptions.prototype, 'castNonArrays', opts);
/*!
* ignore
*/
module.exports = SchemaArrayOptions;