7.10.93 • Published 10 months ago

@erboladaiorg/ducimus-incidunt v7.10.93

Weekly downloads
-
License
MIT
Repository
github
Last release
10 months ago

@erboladaiorg/ducimus-incidunt Version Badge

github actions coverage License Downloads

npm badge

Returns true if a value has the characteristics of a valid JavaScript descriptor. Works for fully completed data descriptors and accessor descriptors.

Usage

const isDescriptor = require('@erboladaiorg/ducimus-incidunt');
const assert = require('assert');

const defaults = { configurable: false, enumerable: false };
const dataDefaults = { ...defaults, writable: false};

assert.ok(isDescriptor({ ...dataDefaults, value: 'foo' }));
assert.ok(isDescriptor({ ...defaults, get() {}, set() {} }));
assert.ok(!isDescriptor({ ...defaults, get: 'foo', set() {} }));

You may also check for a descriptor by passing an object as the first argument and property name (string) as the second argument.

const obj = { foo: 'abc' };

Object.defineProperty(obj, 'bar', { value: 'xyz' });
Reflect.defineProperty(obj, 'baz', { value: 'xyz' });

assert.equal(isDescriptor(obj, 'foo'), true);
assert.equal(isDescriptor(obj, 'bar'), true);
assert.equal(isDescriptor(obj, 'baz'), true);

Examples

value type

Returns false when not an object

assert.equal(isDescriptor('a'), false);
assert.equal(isDescriptor(null), false);
assert.equal(isDescriptor([]), false);

data descriptor

Returns true when the object has valid properties with valid values.

assert.equal(isDescriptor({ ...dataDefaults, value: 'foo' }), true);
assert.equal(isDescriptor({ ...dataDefaults, value() {} }), true);

Returns false when the object has invalid properties

assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', bar: 'baz' }), false);
assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', bar: 'baz' }), false);
assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', enumerable: 'baz' }), false);
assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', configurable: 'baz' }), false);
assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', get() {} }), false);
assert.equal(isDescriptor({ ...dataDefaults, get() {}, value() {} }), false);

false when a value is not the correct type

assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', enumerable: 'foo' }), false);
assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', configurable: 'foo' }), false);
assert.equal(isDescriptor({ ...dataDefaults, value: 'foo', writable: 'foo' }), false);

accessor descriptor

true when the object has valid properties with valid values.

assert.equal(isDescriptor({ ...defaults, get() {}, set() {} }), true);
assert.equal(isDescriptor({ ...defaults, get() {} }), true);
assert.equal(isDescriptor({ ...defaults, set() {} }), true);

false when the object has invalid properties

assert.equal(isDescriptor({ ...defaults, get() {}, set() {}, bar: 'baz' }), false);
assert.equal(isDescriptor({ ...defaults, get() {}, set() {}, enumerable: 'baz' }), false);
assert.equal(isDescriptor({ ...defaults, get() {}, writable: true }), false);
assert.equal(isDescriptor({ ...defaults, get() {}, value: true }), false);

Returns false when an accessor is not a function

assert.equal(isDescriptor({ ...defaults, get() {}, set: 'baz' }), false);
assert.equal(isDescriptor({ ...defaults, get: 'foo', set() {} }), false);
assert.equal(isDescriptor({ ...defaults, get: 'foo', bar: 'baz' }), false);
assert.equal(isDescriptor({ ...defaults, get: 'foo', set: 'baz' }), false);

Returns false when a value is not the correct type

assert.equal(isDescriptor({ ...defaults, get() {}, set() {}, enumerable: 'foo' }), false);
assert.equal(isDescriptor({ ...defaults, set() {}, configurable: 'foo' }), false);
assert.equal(isDescriptor({ ...defaults, get() {}, configurable: 'foo' }), false);

Related projects

You might also be interested in these projects:

  • is-accessor-descriptor: Returns true if a value has the characteristics of a valid JavaScript accessor descriptor.
  • is-data-descriptor: Returns true if a value has the characteristics of a valid JavaScript data descriptor.
  • is-object: Returns true if the value is an object and not an array or null.

Tests

Simply clone the repo, npm install, and run npm test

cloudfrontlastdataviewdotenvBigInt64ArrayoptiontesttoSortedcreateES8fulloncenpmnegativedayjsObject.fromEntries@@toStringTagreduxtransportshimslotargsreact-testing-librarytakenopelruArray.prototype.findLastwritableaccessor6to5URLSearchParamswhichcode pointscircularchromefastifyeslintdebuggerregexstringifyjsxeventEmitterpathhtmli18ntoolsWeakMapparentseast-asian-widthtslibperformancelibphonenumberec2typedarraysguidArrayBufferphoneyamlequal0npmignorereadqueueMicrotaskECMAScript 2023managerarraysprunewalkingfantasy-landincludescloudformationelectronawesomesaucepoint-freeES2017maptyperssArray.prototype.includesgroupBycopy3dbabel-coreES2020entriesbabelremoveObservablevalidateformatmkdirinstallerl10ntelephonehasOwnhashgetinECMAScript 5user-streamspreprocessorflatMapregularastregular-expressionES3waitfixed-widthUint8ArrayArray.prototype.findLastIndexdomdeletewriteinternal slotmapreducebundlingemrshellposeurlhasrmdebughasOwnPropertystreamobjectuuides-abstractsometdddeep-copykeysymbolreact animationIteratorfunctionsprotocol-buffersdescriptionUint16ArrayisConcatSpreadablesource mapregular expressionsPromisefast-copybeanstalkmakeeslintplugindircloudtraillocalfpstoolkitcoerciblefromwidthconsoleObject.getPrototypeOfpatchuninstalls3fast-deep-clone-0framerform-validationcurriedSymbol.toStringTagfigletkoreanworkspace:*artassigntextdefineglobal objectFunction.prototype.namewarningpropertiesutilitygroupcollection.es6pluginhttptypescriptpropertycommandInt32ArraydeterministicarraybufferworkflowworkerutilsECMAScript 2021styled-componentschildmkdirsshrinkwraphelperprivate datashamreact-hooksserializerUint32Arraysetterreact-hook-formhardlinksstarterObject.definePropertycurlespreetypedarrayparsescheme-validationsideresolvesnsECMAScript 2019ES2015ECMAScript 2022jestclientstylingvalidationclassesObservableseverymodulesconcatquoteArrayBuffer.prototype.sliceestreeclass-validator$.extendsharedbrowsertransformmoduleutilexpress_.extendenumerableefficientjsdiffclonedynamodbfindLastIndexthreeES2021requirefnmatchoffsetimmutableES2022varspnpm9.gitignorelogserializefull-widthpusheslint-pluginvariablesspecRxJSreversepositiveECMAScript 6linkapolloavaeventDispatcheridentifiersECMAScript 2017atomchaispawnrouteWebSocketsargves6whatwgoptimisttoArraysubprocessinstallformattingArrayqseslintconfigprogressignoretrimEndvalidatorharmonyArray.prototype.flattenSystem.globalsortedES7spinnersrm -freventsweaksetargumentString.prototype.trimJSONpromisefastlanguagesymbolsttyerrorECMAScript 2020URLReactiveXjsonYAMLconfiganimationMicrosoftlookhas-ownrestfulunicodedragmochamonorepoSymbolfolderslicestringifierzeroes2016cloudwatchairbnbtrimRightjapaneseformsschemaglobwgetomita11ysearchobjcommand-lineES2019fskinesiscliidinspectredux-toolkitparseristanbulnumberBigUint64Arraypackagestrimtacittranspileupasterisksjsdomtc39testerArray.prototype.flatflattenmovematchloadingcolourdeep-clonetapecallsafestringgdprstoragegatewaydatepipepostcss-pluginSetes2017StyleSheetecmascriptObject.assigndeepclonequeuerfc4122readablestreamnamesgenericsexecfilermdirendpointramdasetImmediatedependenciesrandomparentappimportexportrequestfiltersyntaxerrorfunctionlook-upcolumnstypanionlintReactiveExtensionsbyteOffsetfastcopyTypeBoxhelpersvesteffect-tscodestoobjectPushjson-schema-validatorieexecuterm -rfcharacterassertionreuseregexpruntimedataViewcallboundString.prototype.matchAllnativeprocessiteratorhigher-orderrulesindicatortoReversedjoifile systemletFloat64ArrayObject.keysimportwebreversed
7.10.93

10 months ago

7.10.92

10 months ago

7.10.91

10 months ago

7.10.90

10 months ago

7.10.89

11 months ago

7.10.88

11 months ago

7.10.87

11 months ago

6.10.87

11 months ago

6.10.86

11 months ago

6.10.85

11 months ago

6.10.84

11 months ago

6.10.83

11 months ago

6.10.82

11 months ago

6.10.81

11 months ago

5.10.81

11 months ago

5.10.80

11 months ago

5.10.79

11 months ago

5.10.78

11 months ago

5.10.77

11 months ago

5.10.76

11 months ago

5.9.76

11 months ago

5.8.76

11 months ago

5.8.75

11 months ago

5.8.74

11 months ago

5.7.74

11 months ago

5.7.73

11 months ago

5.7.72

11 months ago

5.6.72

11 months ago

5.6.71

11 months ago

5.5.71

11 months ago

5.5.70

11 months ago

5.4.70

11 months ago

5.4.69

11 months ago

5.4.68

11 months ago

5.4.67

12 months ago

5.4.66

12 months ago

5.3.66

12 months ago

4.3.66

12 months ago

4.3.65

12 months ago

4.3.64

12 months ago

4.3.63

12 months ago

3.3.63

12 months ago

3.3.62

12 months ago

3.3.61

12 months ago

3.3.60

12 months ago

3.3.59

12 months ago

3.3.58

12 months ago

3.3.57

12 months ago

3.3.56

12 months ago

3.3.55

12 months ago

3.3.54

12 months ago

3.3.53

12 months ago

3.3.52

12 months ago

2.3.52

12 months ago

2.3.51

1 year ago

2.3.50

1 year ago

2.3.49

1 year ago

2.3.48

1 year ago

2.3.47

1 year ago

2.3.46

1 year ago

2.3.45

1 year ago

2.3.44

1 year ago

2.3.43

1 year ago

2.3.42

1 year ago

2.3.41

1 year ago

2.2.41

1 year ago

2.2.40

1 year ago

2.2.39

1 year ago

2.2.38

1 year ago

2.2.37

1 year ago

2.2.36

1 year ago

2.2.35

1 year ago

2.2.34

1 year ago

2.2.33

1 year ago

2.2.32

1 year ago

2.2.31

1 year ago

2.2.30

1 year ago

2.1.30

1 year ago

2.1.29

1 year ago

2.1.28

1 year ago

2.1.27

1 year ago

2.1.26

1 year ago

2.1.25

1 year ago

2.1.24

1 year ago

1.1.24

1 year ago

1.1.23

1 year ago

1.1.22

1 year ago

1.1.21

1 year ago

1.1.20

1 year ago

1.1.19

1 year ago

1.1.18

1 year ago

1.1.17

1 year ago

1.1.16

1 year ago

1.1.15

1 year ago

1.1.14

1 year ago

1.1.13

1 year ago

1.1.12

1 year ago

1.1.11

1 year ago

1.1.10

1 year ago

1.1.9

1 year ago

1.1.8

1 year ago

1.1.7

1 year ago

1.1.6

1 year ago

1.0.6

1 year ago

1.0.5

1 year ago

1.0.4

1 year ago

1.0.3

1 year ago

1.0.2

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago