Skip to content

planttheidea/isit.js

Repository files navigation

isit.js

JS.ORG

This is a general-purpose check library.

  • No dependencies
  • AMD, Node & browser ready
  • Supports all ES5 and above environments (IE8 and below with es5-shim)

Note

The origin of this project was the wonderful work done by arasatasaygin at is.js, and should be a drop-in replacement for it (outside renaming of is to isit). I noticed there has hasn't been work on it in months, and the issues are growing, so I originally just did a fork of the work. From there I rearchitected the library to be a modular setup that is ES2015-driven and has complete test coverage. I have also made minor tweaks and bugfixes based on the backlog in is.js, but mainly I hope to grow it from here.

Install:

Node.js:

npm i isitjs --save

Usage:

// ES2015
import isit from "isitjs";

// CommonJS
var isit = require("isitjs");

// if you just want specific categories
import isitType from "isit/lib/type";
// or
var isitType from require("isit/lib/type").default;

// if you just want specific modules
import {
    isitBoolean // all functions are named the same, just with "isit" in front and made camelCase
} from "isitjs/lib/type";
// or
var isitBoolean = require("isitjs/lib/type").isitBoolean;

Custom build:

TBD ... this feature was janky from the beginning and may no longer be needed with the modular setup. To do it right will take some time, so I'll wait to hear from the community before I invest the time to build it.

Type checks

isit.arguments(value:any)

Checks if the given value type is arguments.

interfaces: not, all, any

var getArguments = function() {
    return arguments;
};
var arguments = getArguments();

isit.arguments(arguments);
=> true

isit.not.arguments({foo: 'bar'});
=> true

isit.all.arguments(arguments, 'bar');
=> false

isit.any.arguments(['foo'], arguments);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.arguments([arguments, 'foo', 'bar']);
=> false

isit.array(value:any)

Checks if the given value type is array.

interfaces: not, all, any

isit.array(['foo', 'bar', 'baz']);
=> true

isit.not.array({foo: 'bar'});
=> true

isit.all.array(['foo'], 'bar');
=> false

isit.any.array(['foo'], 'bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.array([[1, 2], 'foo', 'bar']);
=> false

isit.boolean(value:any)

Checks if the given value type is boolean.

interfaces: not, all, any

isit.boolean(true);
=> true

isit.not.boolean({foo: 'bar'});
=> true

isit.all.boolean(true, 'bar');
=> false

isit.any.boolean(true, 'bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.boolean([true, 'foo', 'bar']);
=> false

isit.date(value:any)

Checks if the given value type is date.

interfaces: not, all, any

isit.date(new Date());
=> true

isit.not.date({foo: 'bar'});
=> true

isit.all.date(new Date(), 'bar');
=> false

isit.any.date(new Date(), 'bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.date([new Date(), 'foo', 'bar']);
=> false

isit.error(value:any)

Checks if the given value type is error.

interfaces: not, all, any

isit.error(new Error());
=> true

isit.not.error({foo: 'bar'});
=> true

isit.all.error(new Error(), 'bar');
=> false

isit.any.error(new Error(), 'bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.error([new Error(), 'foo', 'bar']);
=> false

isit.function(value:any)

Checks if the given value type is function.

interfaces: not, all, any

isit.function(toString);
=> true

isit.not.function({foo: 'bar'});
=> true

isit.all.function(toString, 'bar');
=> false

isit.any.function(toString, 'bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.function([toString, 'foo', 'bar']);
=> false

isit.nan(value:any)

Checks if the given value type is NaN.

interfaces: not, all, any

isit.nan(NaN);
=> true

isit.not.nan(42);
=> true

isit.all.nan(NaN, 1);
=> false

isit.any.nan(NaN, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.nan([NaN, 'foo', 1]);
=> false

isit.null(value:any)

Checks if the given value type is null.

interfaces: not, all, any

isit.null(null);
=> true

isit.not.null(42);
=> true

isit.all.null(null, 1);
=> false

isit.any.null(null, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.null([null, 'foo', 1]);
=> false

isit.number(value:any)

Checks if the given value type is number.

interfaces: not, all, any

isit.number(42);
=> true

isit.number(NaN);
=> false

isit.not.number('42');
=> true

isit.all.number('foo', 1);
=> false

isit.any.number({}, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.number([42, 'foo', 1]);
=> false

isit.object(value:any)

Checks if the given value type is object.

interfaces: not, all, any

isit.object({foo: 'bar'});
=> true

// functions are also returning as true
isit.object(toString);
=> true

isit.not.object('foo');
=> true

isit.all.object({}, 1);
=> false

isit.any.object({}, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.object([{}, new Object()]);
=> true

isit.json(value:any)

Checks if the given value type is pure json object.

interfaces: not, all, any

isit.json({foo: 'bar'});
=> true

// functions are returning as false
isit.json(toString);
=> false

isit.not.json([]);
=> true

isit.all.json({}, 1);
=> false

isit.any.json({}, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.json([{}, {foo: 'bar'}]);
=> true

isit.regexp(value:any)

Checks if the given value type is RegExp.

interfaces: not, all, any

isit.regexp(/test/);
=> true

isit.not.regexp(['foo']);
=> true

isit.all.regexp(/test/, 1);
=> false

isit.any.regexp(new RegExp('ab+c'), 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.regexp([{}, /test/]);
=> false

isit.string(value:any)

Checks if the given value type is string.

interfaces: not, all, any

isit.string('foo');
=> true

isit.not.string(['foo']);
=> true

isit.all.string('foo', 1);
=> false

isit.any.string('foo', 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.string([{}, 'foo']);
=> false

isit.char(value:any)

Checks if the given value type is char.

interfaces: not, all, any

isit.char('f');
=> true

isit.not.char(['foo']);
=> true

isit.all.char('f', 1);
=> false

isit.any.char('f', 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.char(['f', 'o', 'o']);
=> true

isit.undefined(value:any)

Checks if the given value type is undefined.

interfaces: not, all, any

isit.undefined(undefined);
=> true

isit.not.undefined(null);
=> true

isit.all.undefined(undefined, 1);
=> false

isit.any.undefined(undefined, 2);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.undefined([{}, undefined]);
=> false

isit.sameType(value:any, value:any)

Checks if the given value types are same type.

interface: not

isit.sameType(42, 7);
=> true

isit.sameType(42, '7');
=> false

isit.not.sameType(42, 7);
=> false

isit.typedArray(value:any)

Checks if the given value is a typed array.

interfaces: not, all, any

isit.typedArray(new Float32Array());
=> true

isit.typedArray([]);
=> false

isit.not.typedArray(new Uint16Array());
=> false

isit.all.typedArray(undefined, new Int8Array());
=> false

isit.any.typedArray(undefined, new Int8Array());
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.typedArray([new Float64Array(), undefined]);
=> false

Presence checks

isit.empty(value:object|array|string)

Checks if the given value is empty.

interfaces: not, all, any

isit.empty({});
=> true

isit.empty([]);
=> true

isit.empty('');
=> true

isit.not.empty(['foo']);
=> true

isit.all.empty('', {}, ['foo']);
=> false

isit.any.empty([], 42);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.empty([{}, 'foo']);
=> false

isit.existy(value:any)

Checks if the given value is existy. (not null or undefined)

interfaces: not, all, any

isit.existy({});
=> true

isit.existy(null);
=> false

isit.not.existy(undefined);
=> true

isit.all.existy(null, ['foo']);
=> false

isit.any.existy(undefined, 42);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.existy([{}, 'foo']);
=> true

isit.truthy(value:any)

Checks if the given value is truthy. (existy and not false)

interfaces: not, all, any

isit.truthy(true);
=> true

isit.truthy(null);
=> false

isit.not.truthy(false);
=> true

isit.all.truthy(null, true);
=> false

isit.any.truthy(undefined, true);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.truthy([{}, true]);
=> true

isit.falsy(value:any)

Checks if the given value is falsy.

interfaces: not, all, any

isit.falsy(false);
=> true

isit.falsy(null);
=> true

isit.not.falsy(true);
=> true

isit.all.falsy(null, false);
=> true

isit.any.falsy(undefined, true);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.falsy([false, true, undefined]);
=> false

isit.space(value:string)

Checks if the given value is space.

interfaces: not, all, any

isit.space(' ');
=> true

isit.space('foo');
=> false

isit.not.space(true);
=> true

isit.all.space(' ', 'foo');
=> false

isit.any.space(' ', true);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.space([' ', 'foo', undefined]);
=> false

isit.whitespace(value:string)

Checks if the given value is whitespace.

interfaces: not, all, any

isit.whitespace(' ');
=> true

isit.whitespace('foo');
=> false

isit.not.whitespace(true);
=> true

isit.all.whitespace('          ', ' ');
=> true

isit.any.whitespace(' ', true);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.whitespace([' ', 'foo', undefined]);
=> false

RegExp checks

isit.url(value:any)

Checks if the given value matches url regexp.

interfaces: not, all, any

isit.url('http://www.test.com');
=> true

isit.url('foo');
=> false

isit.not.url(true);
=> true

isit.all.url('http://www.test.com', 'foo');
=> false

isit.any.url('http://www.test.com', true);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.url(['http://www.test.com', 'foo', undefined]);
=> false

isit.email(value:any)

Checks if the given value matches email regexp.

interfaces: not, all, any

isit.email('test@test.com');
=> true

isit.email('foo');
=> false

isit.not.email('foo');
=> true

isit.all.email('test@test.com', 'foo');
=> false

isit.any.email('test@test.com', 'foo');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.email(['test@test.com', 'foo', undefined]);
=> false

isit.creditCard(value:any)

Checks if the given value matches credit card regexp.

interfaces: not, all, any

isit.creditCard(378282246310005);
=> true

isit.creditCard(123);
=> false

isit.not.creditCard(123);
=> true

isit.all.creditCard(378282246310005, 123);
=> false

isit.any.creditCard(378282246310005, 123);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.creditCard([378282246310005, 123, undefined]);
=> false

isit.alphaNumeric(value:any)

Checks if the given value matches alpha numeric regexp.

interfaces: not, all, any

isit.alphaNumeric('alphaNu3er1k');
=> true

isit.alphaNumeric('*?');
=> false

isit.not.alphaNumeric('*?');
=> true

isit.all.alphaNumeric('alphaNu3er1k', '*?');
=> false

isit.any.alphaNumeric('alphaNu3er1k', '*?');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.alphaNumeric(['alphaNu3er1k', '*?']);
=> false

isit.timeString(value:any)

Checks if the given value matches time string regexp.

interfaces: not, all, any

isit.timeString('13:45:30');
=> true

isit.timeString('90:90:90');
=> false

isit.not.timeString('90:90:90');
=> true

isit.all.timeString('13:45:30', '90:90:90');
=> false

isit.any.timeString('13:45:30', '90:90:90');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.timeString(['13:45:30', '90:90:90']);
=> false

isit.dateString(value:any)

Checks if the given value matches date string regexp.

interfaces: not, all, any

isit.dateString('11/11/2011');
=> true

isit.dateString('90/11/2011');
=> false

isit.not.dateString('90/11/2011');
=> true

isit.all.dateString('11/11/2011', '90/11/2011');
=> false

isit.any.dateString('11/11/2011', '90/11/2011');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.dateString(['11/11/2011', '90/11/2011']);
=> false

isit.usZipCode(value:any)

Checks if the given value matches US zip code regexp.

interfaces: not, all, any

isit.usZipCode('02201-1020');
=> true

isit.usZipCode('123');
=> false

isit.not.usZipCode('123');
=> true

isit.all.usZipCode('02201-1020', '123');
=> false

isit.any.usZipCode('02201-1020', '123');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.usZipCode(['02201-1020', '123']);
=> false

isit.caPostalCode(value:any)

Checks if the given value matches Canada postal code regexp.

interfaces: not, all, any

isit.caPostalCode('L8V3Y1');
=> true

isit.caPostalCode('L8V 3Y1');
=> true

isit.caPostalCode('123');
=> false

isit.not.caPostalCode('123');
=> true

isit.all.caPostalCode('L8V3Y1', '123');
=> false

isit.any.caPostalCode('L8V3Y1', '123');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.caPostalCode(['L8V3Y1', '123']);
=> false

isit.ukPostCode(value:any)

Checks if the given value matches UK post code regexp.

interfaces: not, all, any

isit.ukPostCode('B184BJ');
=> true

isit.ukPostCode('123');
=> false

isit.not.ukPostCode('123');
=> true

isit.all.ukPostCode('B184BJ', '123');
=> false

isit.any.ukPostCode('B184BJ', '123');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.ukPostCode(['B184BJ', '123']);
=> false

isit.nanpPhone(value:any)

Checks if the given value matches North American numbering plan phone regexp.

interfaces: not, all, any

isit.nanpPhone('609-555-0175');
=> true

isit.nanpPhone('123');
=> false

isit.not.nanpPhone('123');
=> true

isit.all.nanpPhone('609-555-0175', '123');
=> false

isit.any.nanpPhone('609-555-0175', '123');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.nanpPhone(['609-555-0175', '123']);
=> false

isit.eppPhone(value:any)

Checks if the given value matches extensible provisioning protocol phone regexp.

interfaces: not, all, any

isit.eppPhone('+90.2322456789');
=> true

isit.eppPhone('123');
=> false

isit.not.eppPhone('123');
=> true

isit.all.eppPhone('+90.2322456789', '123');
=> false

isit.any.eppPhone('+90.2322456789', '123');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.eppPhone(['+90.2322456789', '123']);
=> false

isit.socialSecurityNumber(value:any)

Checks if the given value matches social security number regexp.

interfaces: not, all, any

isit.socialSecurityNumber('017-90-7890');
=> true

isit.socialSecurityNumber('123');
=> false

isit.not.socialSecurityNumber('123');
=> true

isit.all.socialSecurityNumber('017-90-7890', '123');
=> false

isit.any.socialSecurityNumber('017-90-7890', '123');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.socialSecurityNumber(['017-90-7890', '123']);
=> false

isit.affirmative(value:any)

Checks if the given value matches affirmative regexp.

interfaces: not, all, any

isit.affirmative('yes');
=> true

isit.affirmative('no');
=> false

isit.not.affirmative('no');
=> true

isit.all.affirmative('yes', 'no');
=> false

isit.any.affirmative('yes', 'no');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.affirmative(['yes', 'y', 'true', 't', 'ok', 'okay']);
=> true

isit.hexadecimal(value:any)

Checks if the given value matches hexadecimal regexp.

interfaces: not, all, any

isit.hexadecimal('f0f0f0');
=> true

isit.hexadecimal(2.5);
=> false

isit.not.hexadecimal('string');
=> true

isit.all.hexadecimal('ff', 'f50');
=> true

isit.any.hexadecimal('ff5500', true);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.hexadecimal(['fff', '333', 'f50']);
=> true

isit.hexColor(value:any)

Checks if the given value matches hexcolor regexp.

interfaces: not, all, any

isit.hexColor('#333');
=> true

isit.hexColor('#3333');
=> false

isit.not.hexColor(0.5);
=> true

isit.all.hexColor('fff', 'f50');
=> true

isit.any.hexColor('ff5500', 0.5);
=> false

// 'all' and 'any' interfaces can also take array parameter
isit.all.hexColor(['fff', '333', 'f50']);
=> true

isit.ip(value:string)

Checks if the given value matches ip regexp

interfaces: not, all, any

isit.ip('198.156.23.5');
=> true

isit.ip('1.2..5');
=> false

isit.not.ip('8:::::::7');
=> true

isit.all.ip('0:1::4:ff5:54:987:C', '123.123.123.123');
=> true

isit.any.ip('123.8.4.3', '0.0.0.0');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.ip(['123.123.23.12', 'A:B:C:D:E:F:0:0']);
=> true

isit.ipv4(value:string)

Checks if the given value matches ipv4 regexp

interfaces: not, all, any

isit.ipv4('198.12.3.142');
=> true

isit.ipv4('1.2..5');
=> false

isit.not.ipv4('8:::::::7');
=> true

isit.all.ipv4('198.12.3.142', '123.123.123.123');
=> true

isit.any.ipv4('255.255.255.255', '850..1.4');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.ipv4(['198.12.3.142', '1.2.3']);
=> false

isit.ipv6(value:string)

Checks if the given value matches ipv6 regexp

interfaces: not, all, any

isit.ipv6('2001:DB8:0:0:1::1');
=> true

isit.ipv6('985.12.3.4');
=> true

isit.not.ipv6('8:::::::7');
=> true

isit.all.ipv6('2001:DB8:0:0:1::1', '1:50:198:2::1:2:8');
=> true

isit.any.ipv6('255.255.255.255', '2001:DB8:0:0:1::1');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.ipv6(['2001:DB8:0:0:1::1', '1.2.3']);
=> false

isit.isoDateString(value:any)

Checks if the given value matches valid ISO strings (full ISO compliance).

interfaces: not, all, any

isit.isoDateString('2010-01-15');
=> true

isit.isoDateString('1/15/2010');
=> false

isit.not.isoDateString('1/15/2010');
=> true

isit.all.isoDateString('2010-01T12:34', '1/15/2010');
=> false

isit.any.isoDateString('2007-04-05T24:00', '1/15/2010');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.isoDateString(['2010-222', '2010-W21-2']);
=> true

String checks

isit.include(value:string, value:substring)

Checks if the given string contains a substring.

interfaces: not

isit.include('Some text goes here', 'text');
=> true

isit.include('test', 'text');
=> false

isit.not.include('test', 'text');
=> true

isit.includes(value:string, value:substring)

alias for isit.include

isit.upperCase(value:string)

Checks if the given string is UPPERCASE.

interfaces: not, all, any

isit.upperCase('YEAP');
=> true

isit.upperCase('nope');
=> false

isit.not.upperCase('Nope');
=> true

isit.all.upperCase('YEAP', 'nope');
=> false

isit.any.upperCase('YEAP', 'nope');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.upperCase(['YEAP', 'ALL UPPERCASE']);
=> true

isit.lowerCase(value:string)

Checks if the given string is lowercase.

interfaces: not, all, any

isit.lowerCase('yeap');
=> true

isit.lowerCase('NOPE');
=> false

isit.not.lowerCase('Nope');
=> true

isit.all.lowerCase('yeap', 'NOPE');
=> false

isit.any.lowerCase('yeap', 'NOPE');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.lowerCase(['yeap', 'all lowercase']);
=> true

isit.startWith(value:string, value:substring)

Checks if the given string starts with substring.

interface: not

isit.startWith('yeap', 'ye');
=> true

isit.startWith('nope', 'ye');
=> false

isit.not.startWith('nope not that', 'not');
=> true

isit.startsWith(value:string, value:substring)

alias for isit.startWith

isit.endWith(value:string, value:substring)

Checks if the given string ends with substring.

interfaces: not

isit.endWith('yeap', 'ap');
=> true

isit.endWith('nope', 'no');
=> false

isit.not.endWith('nope not that', 'not');
=> true

isit.endWith('yeap that one', 'one');
=> true

isit.endsWith(value:string, value:substring)

alias for isit.endWith

isit.capitalized(value:string)

Checks if the given string is capitalized.

interfaces: not, all, any

isit.capitalized('Yeap');
=> true

isit.capitalized('nope');
=> false

isit.not.capitalized('nope not capitalized');
=> true

isit.all.capitalized('Yeap', 'All', 'Capitalized');
=> true

isit.any.capitalized('Yeap', 'some', 'Capitalized');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.capitalized(['Nope', 'not']);
=> false

isit.palindrome(value:string, value:substring)

Checks if the given string is palindrome.

interfaces: not, all, any

isit.palindrome('testset');
=> true

isit.palindrome('nope');
=> false

isit.not.palindrome('nope not palindrome');
=> true

isit.all.palindrome('testset', 'tt');
=> true

isit.any.palindrome('Yeap', 'some', 'testset');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.palindrome(['Nope', 'testset']);
=> false

isit.camelCase(value:string)

Checks if the given string is camelCase.

interfaces: not, all, any

isit.camelCase('fooBar');
=> true

isit.camelCase('Foo Bar');
=> false

isit.not.camelCase('nope not camel case');
=> true

isit.all.camelCase('fooBar', 'tastyCakes', 'iThinkYouGetIt');
=> true

isit.any.camelCase('Yeap', 'some', 'fooBar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.camelCase(['Nope', 'fooBar']);
=> false

isit.kebabCase(value:string)

Checks if the given string is -kebab-case.

interfaces: not, all, any

isit.kebabCase('-foo-bar');
=> true

isit.kebabCase('Foo Bar');
=> false

isit.not.kebabCase('nope not kebab case');
=> true

isit.all.kebabCase('-foo-bar', '-tasty-cakes', '-i-think-you-get-it');
=> true

isit.any.kebabCase('Yeap', 'some', '-foo-bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.kebabCase(['Nope', '-foo-bar']);
=> false

isit.snakeCase(value:string)

Checks if the given string is snake_case.

interfaces: not, all, any

isit.snakeCase('foo_bar');
=> true

isit.snakeCase('Foo Bar');
=> false

isit.not.snakeCase('nope not snake case');
=> true

isit.all.snakeCase('foo_bar', 'tasty_cakes', 'i_think_yoU_get_it');
=> true

isit.any.snakeCase('Yeap', 'some', 'foo_bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.snakeCase(['Nope', 'foo_bar']);
=> false

isit.startCase(value:string)

Checks if the given string is Start Case.

interfaces: not, all, any

isit.startCase('Foo Bar');
=> true

isit.startCase('fooBar');
=> false

isit.not.startCase('-nope-not-start-case');
=> true

isit.all.startCase('Foo Bar', 'Tasty Cakes', 'I Think You Get It');
=> true

isit.any.startCase('Yeap', 'some', '-foo-bar');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.startCase(['Nope', '-foo-bar']);
=> false

isit.doubleByte(value:string)

Checks if the given string contains two-byte (or non-Latin) characters.

interfaces: not, all, any

isit.doubleByte('は123');
=> true

isit.doubleByte('foo');
=> false

isit.not.doubleByte('foo');
=> true

isit.all.doubleByte('は123', 'はtest');
=> true

isit.any.doubleByte('は123', 'some', '');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.doubleByte(['Nope', 'は123']);
=> false

isit.html(value:string)

Checks if the given string contains HTML tags.

interfaces: not, all, any

isit.html('<div></div>');
=> true

isit.html('div');
=> false

isit.not.html('foo');
=> true

isit.all.html('<input type="text">', '<br/>');
=> true

isit.any.html('<img src="happyKittens.jpg">', 'foo', '');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.html(['Nope', '<div/>']);
=> false

isit.dataUrl(value:string)

Checks if the given string is a data URL.

interfaces: not, all, any

isit.dataUrl('');
=> true

isit.dataUrl('data:empty');
=> false

isit.not.dataUrl('data:empty');
=> true

isit.all.dataUrl('data:text/html;charset=US-ASCII,%3Ch1%3EHello!%3C%2Fh1%3E', 'data:,A%20brief%20note');
=> true

isit.any.dataUrl('data:text/html;charset=US-ASCII,%3Ch1%3EHello!%3C%2Fh1%3E', 'foo');
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.dataUrl(['Nope', 'data:text/html;charset=US-ASCII,%3Ch1%3EHello!%3C%2Fh1%3E']);
=> false

Arithmetic checks

isit.equal(value:any, value:any)

Checks if the given values are equal. For objects and arrays, deep equality checks occur.

interfaces: not

isit.equal(42, 40 + 2);
=> true

isit.equal('yeap', 'yeap');
=> true

isit.equal(true, true);
=> true

isit.equal({foo:"bar"}, {foo:"bar"});
=> true

isit.equal(["foo", "bar"], ["foo", "bar"]);
=> true

isit.not.equal('yeap', 'nope');
=> true

isit.not.equal(["foo", "bar"], ["bar", "foo"]); // for arrays, order matters for equality
=> true

isit.even(value:number)

Checks if the given value is even.

interfaces: not, all, any

isit.even(42);
=> true

isit.not.even(41);
=> true

isit.all.even(40, 42, 44);
=> true

isit.any.even(39, 42, 43);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.even([40, 42, 43]);
=> false

isit.odd(value:number)

Checks if the given value is odd.

interfaces: not, all, any

isit.odd(41);
=> true

isit.not.odd(42);
=> true

isit.all.odd(39, 41, 43);
=> true

isit.any.odd(39, 42, 44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.odd([40, 42, 43]);
=> false

isit.positive(value:number)

Checks if the given value is positive.

interfaces: not, all, any

isit.positive(41);
=> true

isit.not.positive(-42);
=> true

isit.all.positive(39, 41, 43);
=> true

isit.any.positive(-39, 42, -44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.positive([40, 42, -43]);
=> false

isit.negative(value:number)

Checks if the given value is negative.

interfaces: not, all, any

isit.negative(-41);
=> true

isit.not.negative(42);
=> true

isit.all.negative(-39, -41, -43);
=> true

isit.any.negative(-39, 42, 44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.negative([40, 42, -43]);
=> false

isit.above(value:number, min)

Checks if the given value is above minimum value.

interface: not

isit.above(41, 30);
=> true

isit.not.above(42, 50);
=> true

isit.over(value:number, min)

alias for isit.above

isit.under(value:number, min)

Checks if the given value is under maximum value.

interface: not

isit.under(30, 35);
=> true

isit.not.under(42, 30);
=> true

isit.below(value:number, min)

alias for isit.under

isit.within(value:number, min, max)

Checks if the given value is within minimum and maximum values.

interface: not

isit.within(30, 20, 40);
=> true

isit.not.within(40, 30, 35);
=> true

isit.decimal(value:number)

Checks if the given value is decimal.

interfaces: not, all, any

isit.decimal(41.5);
=> true

isit.not.decimal(42);
=> true

isit.all.decimal(39.5, 41.5, -43.5);
=> true

isit.any.decimal(-39, 42.5, 44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.decimal([40, 42.5, -43]);
=> false

isit.integer(value:number)

Checks if the given value is integer.

interfaces: not, all, any

isit.integer(41);
=> true

isit.not.integer(42.5);
=> true

isit.all.integer(39, 41, -43);
=> true

isit.any.integer(-39, 42.5, 44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.integer([40, 42.5, -43]);
=> false

isit.finite(value:number)

Checks if the given value is finite.

interfaces: not, all, any

isit.finite(41);
=> true

isit.not.finite(42 / 0);
=> true

isit.all.finite(39, 41, -43);
=> true

isit.any.finite(-39, Infinity, 44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.finite([Infinity, -Infinity, 42.5]);
=> false

isit.infinite(value:number)

Checks if the given value is infinite.

interfaces: not, all, any

isit.infinite(Infinity);
=> true

isit.not.infinite(42);
=> true

isit.all.infinite(Infinity, -Infinity, -43 / 0);
=> true

isit.any.infinite(-39, Infinity, 44);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.infinite([Infinity, -Infinity, 42.5]);
=> false

Object checks

isit.propertyCount(value:object, count)

Checks if objects' property count is equal to given count.

interface: not

isit.propertyCount({this: 'is', 'sample': object}, 2);
=> true

isit.propertyCount({this: 'is', 'sample': object}, 3);
=> false

isit.not.propertyCount({}, 2);
=> true

isit.propertyDefined(value:object, property)

Checks if the given property is defined on object.

interface: not

isit.propertyDefined({yeap: 'yeap'}, 'yeap');
=> true

isit.propertyDefined({yeap: 'yeap'}, 'nope');
=> false

isit.not.propertyDefined({}, 'nope');
=> true

isit.windowObject(value:window)

Checks if the given object is window object.

interfaces: not, all, any

isit.windowObject(window);
=> true

isit.windowObject({nope: 'nope'});
=> false

isit.not.windowObject({});
=> true

isit.all.windowObject(window, {nope: 'nope'});
=> false

isit.any.windowObject(window, {nope: 'nope'});
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.windowObject([window, {nope: 'nope'}]);
=> false

isit.domNode(value:object)

Checks if the given object is a dom node.

interfaces: not, all, any

var obj = document.createElement('div');
isit.domNode(obj);
=> true

isit.domNode({nope: 'nope'});
=> false

isit.not.domNode({});
=> true

isit.all.domNode(obj, obj);
=> true

isit.any.domNode(obj, {nope: 'nope'});
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.domNode([obj, {nope: 'nope'}]);
=> false

isit.jquery(value:object)

Checks if the given object is a jQuery object or jQuery itself.

interfaces: not, all, any

isit.jquery($("#test-div"));
=> true

isit.jquery({});
=> false

isit.not.jquery({});
=> true

isit.all.jquery($, $("#test-div"));
=> true

isit.any.jquery($, {nope: 'nope'});
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.jquery([$, {nope: 'nope'}]);
=> false

isit.domNodeList(value:object)

Checks if the given object is a dom NodeList.

interfaces: not, all, any

var obj = document.querySelectorAll('div');
isit.domNodeList(obj);
=> true

isit.domNodeList({nope: 'nope'});
=> false

isit.not.domNodeList({});
=> true

isit.all.domNodeList(obj, document.querySelectorAll('span'));
=> true

isit.any.domNodeList(obj, {nope: 'nope'});
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.domNodeList([obj, {nope: 'nope'}]);
=> false

isit.plainObject(value:object)

Checks if the given object is a plain JavaScript object.

interfaces: not, all, any

isit.plainObject({});
=> true

isit.plainObject(new SomeConstructor());
=> false

isit.not.plainObject(new SomeConstructor());
=> true

isit.all.plainObject({some:"object"}, document.querySelector('#dom-node'));
=> false

isit.all.plainObject({some:"object"}, document.querySelector('#dom-node'));
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.plainObject([{some:"object"}, document.querySelector('#dom-node')]);
=> false

Array checks

isit.inArray(value:any, array)

Checks if the given item is in array?

interface: not

isit.inArray(2, [1, 2, 3]);
=> true

isit.inArray(4, [1, 2, 3]);
=> false

isit.not.inArray(4, [1, 2, 3]);
=> true

isit.sorted(value:array)

Checks if the given array is sorted.

interfaces: not, all, any

isit.sorted([1, 2, 3]);
=> true

isit.sorted([1, 2, 4, 3]);
=> false

isit.not.sorted([5, 3, 4]);
=> true

isit.all.sorted([1, 2, 3], [4, 3, 2]); // sort checks either ascending or descending
=> true

isit.any.sorted([1, 2], [5, 4, 7]);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.sorted([[1, 2], [5, 4, 7]]);
=> false

Environment checks

##Environment checks are not available as node module.

isit.browser()

Checks if current environment is browser.

interface: not

isit.browser()
=> true if in browser

isit.node()

Checks if current environment is nodejs.

interface: not

isit.node()
=> true if in nodejs

isit.ie(value:number)

Checks if current browser is ie. Parameter is optional version number of browser.

interface: not

isit.ie();
=> true if current browser is ie

isit.ie(6);
=> hopefully false

isit.not.ie();
=> false if current browser is ie

isit.chrome()

Checks if current browser is chrome.

interface: not

isit.chrome();
=> true if current browser is chrome

isit.not.chrome();
=> false if current browser is chrome

isit.firefox()

Checks if current browser is firefox.

interface: not

isit.firefox();
=> true if current browser is firefox

isit.not.firefox();
=> false if current browser is firefox

isit.opera()

Checks if current browser is opera.

interface: not

isit.opera();
=> true if current browser is opera

isit.not.opera();
=> false if current browser is opera

isit.safari()

Checks if current browser is safari.

interface: not

isit.safari();
=> true if current browser is safari

isit.not.safari();
=> false if current browser is safari

isit.ios()

Checks if current device has ios.

interface: not

isit.ios();
=> true if current device is iPhone, iPad or iPod

isit.not.ios();
=> true if current device is not iPhone, iPad or iPod

isit.iphone()

Checks if current device is iPhone.

interface: not

isit.iphone();
=> true if current device is iPhone

isit.not.iphone();
=> true if current device is not iPhone

isit.ipad()

Checks if current device is iPad.

interface: not

isit.ipad();
=> true if current device is iPad

isit.not.ipad();
=> true if current device is not iPad

isit.ipod()

Checks if current device is iPod.

interface: not

isit.ipod();
=> true if current device is iPod

isit.not.ipod();
=> true if current device is not iPod

isit.android()

Checks if current device has Android.

interface: not

isit.android();
=> true if current device has Android OS

isit.not.android();
=> true if current device has not Android OS

isit.androidPhone()

Checks if current device is Android phone.

interface: not

isit.androidPhone();
=> true if current device is Android phone

isit.not.androidPhone();
=> true if current device is not Android phone

isit.androidTablet()

Checks if current device is Android tablet.

interface: not

isit.androidTablet();
=> true if current device is Android tablet

isit.not.androidTablet();
=> true if current device is not Android tablet

isit.blackberry()

Checks if current device is Blackberry.

interface: not

isit.blackberry();
=> true if current device is Blackberry

isit.not.blackberry();
=> true if current device is not Blackberry

isit.windowsPhone()

Checks if current device is Windows phone.

interface: not

isit.windowsPhone();
=> true if current device is Windows phone

isit.not.windowsPhone();
=> true if current device is not Windows Phone

isit.windowsTablet()

Checks if current device is Windows tablet.

interface: not

isit.windowsTablet();
=> true if current device is Windows tablet

isit.not.windowsTablet();
=> true if current device is not Windows tablet

isit.windows()

Checks if current OS is Windows.

interface: not

isit.windows();
=> true if current OS is Windows

isit.not.windows();
=> true if current OS is not Windows

isit.mac()

Checks if current OS is Mac OS X.

interface: not

isit.mac();
=> true if current OS is Mac OS X

isit.not.mac();
=> true if current OS is not Mac OS X

isit.linux()

Checks if current OS is linux.

interface: not

isit.linux();
=> true if current OS is linux

isit.not.linux();
=> true if current OS is not linux

isit.desktop()

Checks if current device is desktop.

interface: not

isit.desktop();
=> true if current device is desktop

isit.not.desktop();
=> true if current device is not desktop

isit.mobile()

Checks if current device is mobile.

interface: not iPhone, iPod, Android Phone, Windows Phone, Blackberry.

isit.mobile();
=> true if current device is mobile

isit.not.mobile();
=> true if current device is not mobile

isit.tablet()

Checks if current device is tablet.

interface: not iPad, Android Tablet, Windows Tablet

isit.tablet();
=> true if current device is tablet

isit.not.tablet();
=> true if current device is not tablet

isit.online()

Checks if current device is online.

interface: not

isit.online();
=> true if current device is online

isit.not.online();
=> true if current device is not online

isit.offline()

Checks if current device is offline.

interface: not

isit.offline();
=> true if current device is offline

isit.not.offline();
=> true if current device is not offline

isit.touchDevice()

Checks if current device supports touch.

interface: not

isit.touchDevice();
=> true if current device supports touch

isit.not.touchDevice();
=> true if current device does not support touch

isit.blink()

Checks if browser rendering engine is Blink.

interface: not

isit.blink();
=> true if browser render with  Blink

isit.not.blink();
=> true if browser does not render with Blink

isit.gecko()

Checks if browser rendering engine is Gecko.

interface: not

isit.gecko();
=> true if browser render with  Gecko

isit.not.gecko();
=> true if browser does not render with Gecko

isit.presto()

Checks if browser rendering engine is Presto.

interface: not

isit.presto();
=> true if browser render with Presto

isit.not.presto();
=> true if browser does not render with Presto

isit.trident()

Checks if browser rendering engine is Trident.

interface: not

isit.trident();
=> true if browser render with Trident

isit.not.trident();
=> true if browser does not render with Trident

isit.webkit()

Checks if browser rendering engine is WebKit.

interface: not

isit.webkit();
=> true if browser render with WebKit

isit.not.webkit();
=> true if browser does not render with WebKit

Time checks

isit.today(value:object)

Checks if the given date object indicate today.

interfaces: not, all, any

var today = new Date();
isit.today(today);
=> true

var yesterday = new Date(new Date().setDate(new Date().getDate() - 1));
isit.today(yesterday);
=> false

isit.not.today(yesterday);
=> true

isit.all.today(today, today);
=> true

isit.any.today(today, yesterday);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.today([today, yesterday]);
=> false

isit.yesterday(value:object)

Checks if the given date object indicate yesterday.

interfaces: not, all, any

var today = new Date();
isit.yesterday(today);
=> false

var yesterday = new Date(new Date().setDate(new Date().getDate() - 1));
isit.yesterday(yesterday);
=> true

isit.not.yesterday(today);
=> true

isit.all.yesterday(yesterday, today);
=> false

isit.any.yesterday(today, yesterday);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.yesterday([today, yesterday]);
=> false

isit.tomorrow(value:object)

Checks if the given date object indicate tomorrow.

interfaces: not, all, any

var today = new Date();
isit.tomorrow(today);
=> false

var tomorrow = new Date(new Date().setDate(new Date().getDate() + 1));
isit.tomorrow(tomorrow);
=> true

isit.not.tomorrow(today);
=> true

isit.all.tomorrow(tomorrow, today);
=> false

isit.any.tomorrow(today, tomorrow);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.tomorrow([today, tomorrow]);
=> false

isit.past(value:object)

Checks if the given date object indicate past.

interfaces: not, all, any

var yesterday = new Date(new Date().setDate(new Date().getDate() - 1));
var tomorrow = new Date(new Date().setDate(new Date().getDate() + 1));

isit.past(yesterday);
=> true

isit.past(tomorrow);
=> false

isit.not.past(tomorrow);
=> true

isit.all.past(tomorrow, yesterday);
=> false

isit.any.past(yesterday, tomorrow);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.past([yesterday, tomorrow]);
=> false

isit.future(value:object)

Checks if the given date object indicate future.

interfaces: not, all, any

var yesterday = new Date(new Date().setDate(new Date().getDate() - 1));
var tomorrow = new Date(new Date().setDate(new Date().getDate() + 1));

isit.future(yesterday);
=> false

isit.future(tomorrow);
=> true

isit.not.future(yesterday);
=> true

isit.all.future(tomorrow, yesterday);
=> false

isit.any.future(yesterday, tomorrow);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.future([yesterday, tomorrow]);
=> false

isit.day(value:object, dayString)

Checks if the given date objects' day equal given dayString parameter. If not given, dayString defaults to current day.

interface: not

var mondayObj = new Date('01/26/2015');
var tuesdayObj = new Date('01/27/2015');
isit.day(mondayObj, 'monday');
=> true

isit.day(mondayObj, 'tuesday');
=> false

isit.not.day(mondayObj, 'tuesday');
=> true

isit.month(value:object, monthString)

Checks if the given date objects' month equal given monthString parameter. If not given, monthString defaults to current month.

interface: not

var januaryObj = new Date('01/26/2015');
var februaryObj = new Date('02/26/2015');
isit.month(januaryObj, 'january');
=> true

isit.month(februaryObj, 'january');
=> false

isit.not.month(februaryObj, 'january');
=> true

isit.year(value:object, yearNumber)

Checks if the given date objects' year equal given yearNumber parameter. If not given, yearNumber defaults to current year.

interface: not

var year2015 = new Date('01/26/2015');
var year2016 = new Date('01/26/2016');
isit.year(year2015, 2015);
=> true

isit.year(year2016, 2015);
=> false

isit.not.year(year2016, 2015);
=> true

isit.leapYear(value:number)

Checks if the given year number is a leap year

interfaces: not, all, any

isit.leapYear(2016);
=> true

isit.leapYear(2015);
=> false

isit.not.leapYear(2015);
=> true

isit.all.leapYear(2015, 2016);
=> false

isit.any.leapYear(2015, 2016);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.leapYear([2016, 2080]);
=> true

isit.weekend(value:object)

Checks if the given date objects' day is weekend.

interfaces: not, all, any

var monday = new Date('01/26/2015');
var sunday = new Date('01/25/2015');
var saturday = new Date('01/24/2015');
isit.weekend(sunday);
=> true

isit.weekend(monday);
=> false

isit.not.weekend(monday);
=> true

isit.all.weekend(sunday, saturday);
=> true

isit.any.weekend(sunday, saturday, monday);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.weekend([sunday, saturday, monday]);
=> false

isit.weekday(value:object)

Checks if the given date objects' day is weekday.

interfaces: not, all, any

var monday = new Date('01/26/2015');
var sunday = new Date('01/25/2015');
var saturday = new Date('01/24/2015');
isit.weekday(monday);
=> true

isit.weekday(sunday);
=> false

isit.not.weekday(sunday);
=> true

isit.all.weekday(monday, saturday);
=> false

isit.any.weekday(sunday, saturday, monday);
=> true

// 'all' and 'any' interfaces can also take array parameter
isit.all.weekday([sunday, saturday, monday]);
=> false

isit.inDateRange(value:object, startObject, endObject)

Checks if date is within given range.

interface: not

var saturday = new Date('01/24/2015');
var sunday = new Date('01/25/2015');
var monday = new Date('01/26/2015');
isit.inDateRange(sunday, saturday, monday);
=> true

isit.inDateRange(saturday, sunday, monday);
=> false

isit.not.inDateRange(saturday, sunday, monday);
=> true

isit.inLastWeek(value:object)

Checks if the given date is between now and 7 days ago.

interface: not

var twoDaysAgo = new Date(new Date().setDate(new Date().getDate() - 2));
var nineDaysAgo = new Date(new Date().setDate(new Date().getDate() - 9));
isit.inLastWeek(twoDaysAgo);
=> true

isit.inLastWeek(nineDaysAgo);
=> false

isit.not.inLastWeek(nineDaysAgo);
=> true

isit.inLastMonth(value:object)

Checks if the given date is between now and a month ago.

interface: not

var tenDaysAgo = new Date(new Date().setDate(new Date().getDate() - 10));
var fortyDaysAgo = new Date(new Date().setDate(new Date().getDate() - 40));
isit.inLastMonth(tenDaysAgo);
=> true

isit.inLastMonth(fortyDaysAgo);
=> false

isit.not.inLastMonth(fortyDaysAgo);
=> true

isit.inLastYear(value:object)

Checks if the given date is between now and a year ago.

interface: not

var twoMonthsAgo = new Date(new Date().setMonth(new Date().getMonth() - 2));
var thirteenMonthsAgo = new Date(new Date().setMonth(new Date().getMonth() - 13));
isit.inLastYear(twoMonthsAgo);
=> true

isit.inLastYear(thirteenMonthsAgo);
=> false

isit.not.inLastYear(thirteenMonthsAgo);
=> true

isit.inNextWeek(value:object)

Checks if the given date is between now and 7 days later.

interface: not

var twoDaysLater = new Date(new Date().setDate(new Date().getDate() + 2));
var nineDaysLater = new Date(new Date().setDate(new Date().getDate() + 9));
isit.inNextWeek(twoDaysLater);
=> true

isit.inNextWeek(nineDaysLater);
=> false

isit.not.inNextWeek(nineDaysLater);
=> true

isit.inNextMonth(value:object)

Checks if the given date is between now and a month later.

interface: not

var tenDaysLater = new Date(new Date().setDate(new Date().getDate() + 10));
var fortyDaysLater = new Date(new Date().setDate(new Date().getDate() + 40));
isit.inNextMonth(tenDaysLater);
=> true

isit.inNextMonth(fortyDaysLater);
=> false

isit.not.inNextMonth(fortyDaysLater);
=> true

isit.inNextYear(value:object)

Checks if the given date is between now and a year later.

interface: not

var twoMonthsLater = new Date(new Date().setMonth(new Date().getMonth() + 2));
var thirteenMonthsLater = new Date(new Date().setMonth(new Date().getMonth() + 13));
isit.inNextYear(twoMonthsLater);
=> true

isit.inNextYear(thirteenMonthsLater);
=> false

isit.not.inNextYear(thirteenMonthsLater);
=> true

isit.quarterOfYear(value:object, quarterNumber)

Checks if the given date is in the parameter quarter.

interface: not

var firstQuarter = new Date('01/26/2015');
var secondQuarter = new Date('05/26/2015');
isit.quarterOfYear(firstQuarter, 1);
=> true

isit.quarterOfYear(secondQuarter, 1);
=> false

isit.not.quarterOfYear(secondQuarter, 1);
=> true

isit.daylightSavingTime(value:object, quarterNumber)

Checks if the given date is in daylight saving time.

interface: not

// For Turkey Time Zone
var january1 = new Date('01/01/2015');
var june1 = new Date('06/01/2015');

isit.daylightSavingTime(june1);
=> true

isit.daylightSavingTime(january1);
=> false

isit.not.daylightSavingTime(january1);
=> true

isit.daylightSavingsTime(value:object, quarterNumber)

alias for isit.daylightSavingTime

Configuration methods

isit.setRegexp(value:RegExp, regexpString)

Override RegExps if you think they suck.

isit.url('https://www.duckduckgo.com');
=> true

isit.setRegexp(/quack/, 'url');
isit.url('quack');
=> true