Skip to content

Commit

Permalink
Merge pull request #4 from hckrnews/feature/first-draft
Browse files Browse the repository at this point in the history
Add is and in methods
w3nl authored Oct 5, 2021
2 parents ecec2aa + b700487 commit 5f8e199
Showing 5 changed files with 18 additions and 3 deletions.
3 changes: 3 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -36,6 +36,9 @@ encoding.keys // [ 'test' ]
encoding.test // TEXT
encoding.length // 1

encoding.is('TEXT') // true
encoding.in(['TEXT']) // true


const encoding = Encoding.fromValue('TEXT')
encoding.key // test
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@hckrnews/enum",
"description": "Create vanilla JavaScript enums",
"version": "1.1.1",
"version": "1.2.0",
"author": {
"name": "Pieter Wigboldus",
"url": "https://hckr.news/"
4 changes: 4 additions & 0 deletions src/__tests__/enum.spec.js
Original file line number Diff line number Diff line change
@@ -26,6 +26,10 @@ describe('Test the encoding enum', () => {
expect(encoding.keys).toEqual(['utf-8'])
expect(encoding['utf-8']).toEqual('UTF-8')
expect(encoding.length).toEqual(1)
expect(encoding.is(Encoding.options['utf-8'])).toEqual(true)
expect(encoding.is('something')).toEqual(false)
expect(encoding.in([Encoding.options['utf-8']])).toEqual(true)
expect(encoding.in(['something'])).toEqual(false)
})

it('It should create from an value', () => {
8 changes: 8 additions & 0 deletions src/enum.js
Original file line number Diff line number Diff line change
@@ -62,6 +62,14 @@ export default class Enum {
return this.values.includes(value)
}

is (value) {
return this.value === value
}

in (values) {
return values.includes(this.value)
}

static hasKey (key) {
const newEnum = new this()

0 comments on commit 5f8e199

Please sign in to comment.