@schukai/monster 1.31.0 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG +11 -0
- package/README.md +55 -58
- package/example/constraints/andoperator.mjs +17 -0
- package/example/constraints/invalid.mjs +6 -0
- package/example/constraints/isarray.mjs +11 -0
- package/example/constraints/isobject.mjs +12 -0
- package/example/constraints/oroperator.mjs +15 -0
- package/example/constraints/valid.mjs +6 -0
- package/example/data/buildmap.mjs +67 -0
- package/example/data/datasource.mjs +7 -0
- package/example/data/diff.mjs +39 -0
- package/example/data/pathfinder-1.mjs +23 -0
- package/example/data/pathfinder-2.mjs +19 -0
- package/example/data/pipe.mjs +14 -0
- package/example/data/storage/restapi.mjs +11 -0
- package/example/data/transformer.mjs +9 -0
- package/example/dom/customelement.mjs +13 -0
- package/example/dom/theme.mjs +5 -0
- package/example/dom/updater.mjs +23 -0
- package/example/i18n/formatter.mjs +10 -0
- package/example/i18n/providers/fetch.mjs +5 -0
- package/example/i18n/translations.mjs +20 -0
- package/example/types/basewithoptions.mjs +10 -0
- package/example/types/is-1.mjs +5 -0
- package/example/types/is-10.mjs +6 -0
- package/example/types/is-2.mjs +4 -0
- package/example/types/is-3.mjs +4 -0
- package/example/types/is-4.mjs +5 -0
- package/example/types/is-5.mjs +4 -0
- package/example/types/is-6.mjs +4 -0
- package/example/types/is-7.mjs +4 -0
- package/example/types/is-8.mjs +4 -0
- package/example/types/is-9.mjs +6 -0
- package/example/types/noderecursiveiterator.mjs +32 -0
- package/example/types/observer.mjs +9 -0
- package/example/types/proxyobserver.mjs +25 -0
- package/example/types/queue.mjs +20 -0
- package/example/types/tokenlist-1.mjs +4 -0
- package/example/types/tokenlist-2.mjs +7 -0
- package/example/types/tokenlist-3.mjs +5 -0
- package/example/types/tokenlist-4.mjs +5 -0
- package/example/types/tokenlist-5.mjs +5 -0
- package/example/types/typeof.mjs +9 -0
- package/example/types/version-1.mjs +6 -0
- package/example/types/version-2.mjs +3 -0
- package/example/util/comparator.mjs +10 -0
- package/example/util/deadmansswitch.mjs +9 -0
- package/example/util/processing.mjs +17 -0
- package/package.json +5 -59
- package/source/{constants.js → constants.mjs} +7 -10
- package/source/constraints/{abstract.js → abstract.mjs} +8 -9
- package/source/constraints/{abstractoperator.js → abstractoperator.mjs} +11 -8
- package/source/constraints/andoperator.mjs +38 -0
- package/source/constraints/invalid.mjs +38 -0
- package/source/constraints/isarray.mjs +41 -0
- package/source/constraints/isobject.mjs +41 -0
- package/source/constraints/{namespace.js → namespace.mjs} +3 -8
- package/source/constraints/{oroperator.js → oroperator.mjs} +10 -42
- package/source/constraints/valid.mjs +38 -0
- package/source/data/{buildmap.js → buildmap.mjs} +18 -104
- package/source/data/{buildtree.js → buildtree.mjs} +11 -31
- package/source/data/datasource/{namespace.js → namespace.mjs} +1 -9
- package/source/data/datasource/restapi/namespace.mjs +8 -0
- package/source/data/datasource/restapi/{writeerror.js → writeerror.mjs} +8 -9
- package/source/data/datasource/{restapi.js → restapi.mjs} +15 -45
- package/source/data/datasource/storage/localstorage.mjs +45 -0
- package/source/data/datasource/storage/{namespace.js → namespace.mjs} +1 -9
- package/source/data/datasource/storage/sessionstorage.mjs +45 -0
- package/source/data/datasource/{storage.js → storage.mjs} +12 -35
- package/source/data/{datasource.js → datasource.mjs} +17 -45
- package/source/data/{diff.js → diff.mjs} +10 -69
- package/source/data/{extend.js → extend.mjs} +10 -28
- package/source/data/{namespace.js → namespace.mjs} +2 -8
- package/source/data/{pathfinder.js → pathfinder.mjs} +18 -77
- package/source/data/{pipe.js → pipe.mjs} +14 -46
- package/source/data/{transformer.js → transformer.mjs} +18 -43
- package/source/dom/{assembler.js → assembler.mjs} +12 -28
- package/source/dom/{attributes.js → attributes.mjs} +42 -253
- package/source/dom/{constants.js → constants.mjs} +110 -61
- package/source/dom/{customcontrol.js → customcontrol.mjs} +10 -17
- package/source/dom/{customelement.js → customelement.mjs} +28 -52
- package/source/dom/{events.js → events.mjs} +15 -64
- package/source/dom/{focusmanager.js → focusmanager.mjs} +13 -34
- package/source/dom/{locale.js → locale.mjs} +11 -26
- package/source/dom/{namespace.js → namespace.mjs} +1 -8
- package/source/dom/{ready.js → ready.mjs} +12 -30
- package/source/dom/resource/{data.js → data.mjs} +11 -31
- package/source/dom/resource/link/namespace.mjs +10 -0
- package/source/dom/resource/link/stylesheet.mjs +35 -0
- package/source/dom/resource/{link.js → link.mjs} +9 -29
- package/source/dom/resource/namespace.mjs +8 -0
- package/source/dom/resource/{script.js → script.mjs} +9 -29
- package/source/dom/{resource.js → resource.mjs} +19 -39
- package/source/dom/{resourcemanager.js → resourcemanager.mjs} +17 -35
- package/source/dom/{template.js → template.mjs} +18 -43
- package/source/dom/{theme.js → theme.mjs} +14 -36
- package/source/dom/{updater.js → updater.mjs} +34 -68
- package/source/dom/{util.js → util.mjs} +17 -66
- package/source/dom/worker/{factory.js → factory.mjs} +13 -34
- package/source/dom/worker/namespace.mjs +8 -0
- package/source/i18n/{formatter.js → formatter.mjs} +14 -45
- package/source/i18n/{locale.js → locale.mjs} +15 -30
- package/source/i18n/{namespace.js → namespace.mjs} +1 -9
- package/source/i18n/provider.mjs +40 -0
- package/source/i18n/providers/{fetch.js → fetch.mjs} +18 -43
- package/source/i18n/providers/namespace.mjs +8 -0
- package/source/i18n/{translations.js → translations.mjs} +12 -52
- package/source/logging/handler/console.mjs +50 -0
- package/source/logging/handler/namespace.mjs +6 -0
- package/source/logging/{handler.js → handler.mjs} +13 -30
- package/source/logging/logentry.mjs +51 -0
- package/source/logging/{logger.js → logger.mjs} +12 -28
- package/source/logging/{namespace.js → namespace.mjs} +1 -9
- package/source/math/{namespace.js → namespace.mjs} +1 -9
- package/source/math/{random.js → random.mjs} +8 -34
- package/source/monster.mjs +114 -0
- package/source/text/{formatter.js → formatter.mjs} +17 -33
- package/source/text/{namespace.js → namespace.mjs} +1 -9
- package/source/types/base.mjs +31 -0
- package/source/types/{basewithoptions.js → basewithoptions.mjs} +17 -46
- package/source/types/{binary.js → binary.mjs} +10 -42
- package/source/types/{dataurl.js → dataurl.mjs} +12 -46
- package/source/types/{global.js → global.mjs} +20 -12
- package/source/types/{id.js → id.mjs} +10 -27
- package/source/types/is.mjs +225 -0
- package/source/types/{mediatype.js → mediatype.mjs} +13 -29
- package/source/types/{namespace.js → namespace.mjs} +1 -8
- package/source/types/{node.js → node.mjs} +11 -28
- package/source/types/{nodelist.js → nodelist.mjs} +17 -32
- package/source/types/{noderecursiveiterator.js → noderecursiveiterator.mjs} +14 -65
- package/source/types/{observer.js → observer.mjs} +15 -42
- package/source/types/{observerlist.js → observerlist.mjs} +12 -29
- package/source/types/{proxyobserver.js → proxyobserver.mjs} +19 -62
- package/source/types/{queue.js → queue.mjs} +10 -47
- package/source/types/randomid.mjs +45 -0
- package/source/types/regex.mjs +27 -0
- package/source/types/{stack.js → stack.mjs} +8 -24
- package/source/types/{tokenlist.js → tokenlist.mjs} +20 -64
- package/source/types/typeof.mjs +37 -0
- package/source/types/{uniquequeue.js → uniquequeue.mjs} +11 -27
- package/source/types/{uuid.js → uuid.mjs} +15 -33
- package/source/types/{validate.js → validate.mjs} +38 -155
- package/source/types/{version.js → version.mjs} +19 -62
- package/source/util/{clone.js → clone.mjs} +10 -28
- package/source/util/{comparator.js → comparator.mjs} +13 -43
- package/source/util/{deadmansswitch.js → deadmansswitch.mjs} +15 -40
- package/source/util/freeze.mjs +39 -0
- package/source/util/{namespace.js → namespace.mjs} +1 -9
- package/source/util/{processing.js → processing.mjs} +13 -51
- package/source/util/{trimspaces.js → trimspaces.mjs} +14 -21
- package/test/cases/constraint/{andoperator.js → andoperator.mjs} +3 -3
- package/test/cases/constraint/{invalid.js → invalid.mjs} +1 -1
- package/test/cases/constraint/{isarray.js → isarray.mjs} +1 -1
- package/test/cases/constraint/{isobject.js → isobject.mjs} +1 -1
- package/test/cases/constraint/{oroperator.js → oroperator.mjs} +3 -3
- package/test/cases/constraint/{valid.js → valid.mjs} +1 -1
- package/test/cases/data/{buildmap.js → buildmap.mjs} +1 -1
- package/test/cases/data/{buildtree.js → buildtree.mjs} +2 -2
- package/test/cases/data/datasource/{restapi.js → restapi.mjs} +5 -5
- package/test/cases/data/datasource/storage/{localstorage.js → localstorage.mjs} +5 -5
- package/test/cases/data/datasource/storage/{sessionstorage.js → sessionstorage.mjs} +5 -5
- package/test/cases/data/{datasource.js → datasource.mjs} +1 -1
- package/test/cases/data/{diff.js → diff.mjs} +2 -2
- package/test/cases/data/{extend.js → extend.mjs} +1 -1
- package/test/cases/data/{pathfinder.js → pathfinder.mjs} +1 -1
- package/test/cases/data/{pipe.js → pipe.mjs} +19 -5
- package/test/cases/data/{transformer.js → transformer.mjs} +14 -10
- package/test/cases/dom/{assembler.js → assembler.mjs} +2 -2
- package/test/cases/dom/{attributes.js → attributes.mjs} +2 -2
- package/test/cases/dom/{customcontrol.js → customcontrol.mjs} +6 -6
- package/test/cases/dom/{customelement.js → customelement.mjs} +6 -6
- package/test/cases/dom/{events.js → events.mjs} +2 -2
- package/test/cases/dom/{focusmanager.js → focusmanager.mjs} +3 -3
- package/test/cases/dom/{locale.js → locale.mjs} +2 -2
- package/test/cases/dom/{ready.js → ready.mjs} +2 -2
- package/test/cases/dom/resource/{data.js → data.mjs} +9 -9
- package/test/cases/dom/resource/link/{stylesheet.js → stylesheet.mjs} +6 -6
- package/test/cases/dom/resource/{link.js → link.mjs} +6 -6
- package/test/cases/dom/resource/{script.js → script.mjs} +6 -6
- package/test/cases/dom/{resourcemanager.js → resourcemanager.mjs} +6 -6
- package/test/cases/dom/{template.js → template.mjs} +3 -3
- package/test/cases/dom/{theme.js → theme.mjs} +3 -3
- package/test/cases/dom/{updater.js → updater.mjs} +6 -6
- package/test/cases/dom/{util.js → util.mjs} +2 -2
- package/test/cases/dom/worker/{factory.js → factory.mjs} +4 -4
- package/test/cases/i18n/{formatter.js → formatter.mjs} +2 -2
- package/test/cases/i18n/{locale.js → locale.mjs} +1 -1
- package/test/cases/i18n/{provider.js → provider.mjs} +1 -1
- package/test/cases/i18n/providers/{fetch.js → fetch.mjs} +3 -3
- package/test/cases/i18n/{translations.js → translations.mjs} +2 -2
- package/test/cases/logging/handler/{console.js → console.mjs} +3 -3
- package/test/cases/logging/{handler.js → handler.mjs} +3 -3
- package/test/cases/logging/{logentry.js → logentry.mjs} +1 -1
- package/test/cases/logging/{logger.js → logger.mjs} +1 -1
- package/test/cases/math/random.mjs +101 -0
- package/test/cases/monster.mjs +20 -0
- package/test/cases/text/{formatter.js → formatter.mjs} +1 -1
- package/test/cases/types/{base.js → base.mjs} +1 -1
- package/test/cases/types/{basewithoptions.js → basewithoptions.mjs} +1 -1
- package/test/cases/types/{binary.js → binary.mjs} +1 -1
- package/test/cases/types/{dataurl.js → dataurl.mjs} +1 -1
- package/test/cases/types/{global.js → global.mjs} +1 -1
- package/test/cases/types/{id.js → id.mjs} +17 -6
- package/test/cases/types/{is.js → is.mjs} +20 -8
- package/test/cases/types/{mediatype.js → mediatype.mjs} +1 -1
- package/test/cases/types/{node.js → node.mjs} +3 -3
- package/test/cases/types/{nodelist.js → nodelist.mjs} +2 -2
- package/test/cases/types/{noderecursiveiterator.js → noderecursiveiterator.mjs} +3 -3
- package/test/cases/types/{observer.js → observer.mjs} +1 -1
- package/test/cases/types/{observerlist.js → observerlist.mjs} +2 -2
- package/test/cases/types/{proxyobserver.js → proxyobserver.mjs} +4 -4
- package/test/cases/types/{queue.js → queue.mjs} +1 -1
- package/test/cases/types/randomid.mjs +39 -0
- package/test/cases/types/regex.mjs +46 -0
- package/test/cases/types/{stack.js → stack.mjs} +1 -1
- package/test/cases/types/{tokenlist.js → tokenlist.mjs} +1 -1
- package/test/cases/types/{typeof.js → typeof.mjs} +3 -4
- package/test/cases/types/{uniquequeue.js → uniquequeue.mjs} +1 -1
- package/test/cases/types/{uuid.js → uuid.mjs} +30 -10
- package/test/cases/types/{validate.js → validate.mjs} +3 -4
- package/test/cases/types/{version.js → version.mjs} +1 -2
- package/test/cases/util/{clone.js → clone.mjs} +1 -1
- package/test/cases/util/{comparator.js → comparator.mjs} +1 -1
- package/test/cases/util/{deadmansswitch.js → deadmansswitch.mjs} +1 -1
- package/test/cases/util/{freeze.js → freeze.mjs} +1 -1
- package/test/cases/util/{processing.js → processing.mjs} +1 -1
- package/test/cases/util/{trimspaces.js → trimspaces.mjs} +1 -1
- package/test/util/{chai-dom.js → chai-dom.mjs} +0 -0
- package/test/util/{cleanupdom.js → cleanupdom.mjs} +0 -0
- package/test/util/{jsdom.js → jsdom.mjs} +2 -2
- package/test/util/{localstorage.js → localstorage.mjs} +0 -0
- package/test/web/import.js +77 -78
- package/test/web/prepare.js +0 -8
- package/test/web/test.html +5 -4
- package/test/web/tests.js +25731 -587
- package/dist/modules/constants.js +0 -2
- package/dist/modules/constraints/abstract.js +0 -2
- package/dist/modules/constraints/abstractoperator.js +0 -2
- package/dist/modules/constraints/andoperator.js +0 -2
- package/dist/modules/constraints/invalid.js +0 -2
- package/dist/modules/constraints/isarray.js +0 -2
- package/dist/modules/constraints/isobject.js +0 -2
- package/dist/modules/constraints/namespace.js +0 -2
- package/dist/modules/constraints/oroperator.js +0 -2
- package/dist/modules/constraints/valid.js +0 -2
- package/dist/modules/data/buildmap.js +0 -2
- package/dist/modules/data/buildtree.js +0 -2
- package/dist/modules/data/datasource/namespace.js +0 -2
- package/dist/modules/data/datasource/restapi/writeerror.js +0 -2
- package/dist/modules/data/datasource/restapi.js +0 -2
- package/dist/modules/data/datasource/storage/localstorage.js +0 -2
- package/dist/modules/data/datasource/storage/namespace.js +0 -2
- package/dist/modules/data/datasource/storage/sessionstorage.js +0 -2
- package/dist/modules/data/datasource/storage.js +0 -2
- package/dist/modules/data/datasource.js +0 -2
- package/dist/modules/data/diff.js +0 -2
- package/dist/modules/data/extend.js +0 -2
- package/dist/modules/data/namespace.js +0 -2
- package/dist/modules/data/pathfinder.js +0 -2
- package/dist/modules/data/pipe.js +0 -2
- package/dist/modules/data/transformer.js +0 -2
- package/dist/modules/dom/assembler.js +0 -2
- package/dist/modules/dom/attributes.js +0 -2
- package/dist/modules/dom/constants.js +0 -2
- package/dist/modules/dom/customcontrol.js +0 -2
- package/dist/modules/dom/customelement.js +0 -2
- package/dist/modules/dom/events.js +0 -2
- package/dist/modules/dom/focusmanager.js +0 -2
- package/dist/modules/dom/locale.js +0 -2
- package/dist/modules/dom/namespace.js +0 -2
- package/dist/modules/dom/ready.js +0 -2
- package/dist/modules/dom/resource/data.js +0 -2
- package/dist/modules/dom/resource/link/stylesheet.js +0 -2
- package/dist/modules/dom/resource/link.js +0 -2
- package/dist/modules/dom/resource/script.js +0 -2
- package/dist/modules/dom/resource.js +0 -2
- package/dist/modules/dom/resourcemanager.js +0 -2
- package/dist/modules/dom/template.js +0 -2
- package/dist/modules/dom/theme.js +0 -2
- package/dist/modules/dom/updater.js +0 -2
- package/dist/modules/dom/util.js +0 -2
- package/dist/modules/dom/worker/factory.js +0 -2
- package/dist/modules/i18n/formatter.js +0 -2
- package/dist/modules/i18n/locale.js +0 -2
- package/dist/modules/i18n/namespace.js +0 -2
- package/dist/modules/i18n/provider.js +0 -2
- package/dist/modules/i18n/providers/fetch.js +0 -2
- package/dist/modules/i18n/providers/namespace.js +0 -2
- package/dist/modules/i18n/translations.js +0 -2
- package/dist/modules/logging/handler/console.js +0 -2
- package/dist/modules/logging/handler/namespace.js +0 -2
- package/dist/modules/logging/handler.js +0 -2
- package/dist/modules/logging/logentry.js +0 -2
- package/dist/modules/logging/logger.js +0 -2
- package/dist/modules/logging/namespace.js +0 -2
- package/dist/modules/math/namespace.js +0 -2
- package/dist/modules/math/random.js +0 -2
- package/dist/modules/monster.js +0 -2
- package/dist/modules/namespace.js +0 -2
- package/dist/modules/text/formatter.js +0 -2
- package/dist/modules/text/namespace.js +0 -2
- package/dist/modules/types/base.js +0 -2
- package/dist/modules/types/basewithoptions.js +0 -2
- package/dist/modules/types/binary.js +0 -2
- package/dist/modules/types/dataurl.js +0 -2
- package/dist/modules/types/global.js +0 -2
- package/dist/modules/types/id.js +0 -2
- package/dist/modules/types/is.js +0 -2
- package/dist/modules/types/mediatype.js +0 -2
- package/dist/modules/types/namespace.js +0 -2
- package/dist/modules/types/node.js +0 -2
- package/dist/modules/types/nodelist.js +0 -2
- package/dist/modules/types/noderecursiveiterator.js +0 -2
- package/dist/modules/types/observer.js +0 -2
- package/dist/modules/types/observerlist.js +0 -2
- package/dist/modules/types/proxyobserver.js +0 -2
- package/dist/modules/types/queue.js +0 -2
- package/dist/modules/types/randomid.js +0 -2
- package/dist/modules/types/regex.js +0 -2
- package/dist/modules/types/stack.js +0 -2
- package/dist/modules/types/tokenlist.js +0 -2
- package/dist/modules/types/typeof.js +0 -2
- package/dist/modules/types/uniquequeue.js +0 -2
- package/dist/modules/types/uuid.js +0 -2
- package/dist/modules/types/validate.js +0 -2
- package/dist/modules/types/version.js +0 -2
- package/dist/modules/util/clone.js +0 -2
- package/dist/modules/util/comparator.js +0 -2
- package/dist/modules/util/deadmansswitch.js +0 -2
- package/dist/modules/util/freeze.js +0 -2
- package/dist/modules/util/namespace.js +0 -2
- package/dist/modules/util/processing.js +0 -2
- package/dist/modules/util/trimspaces.js +0 -2
- package/dist/monster.dev.js +0 -15490
- package/dist/monster.dev.js.map +0 -1
- package/dist/monster.js +0 -2
- package/source/constraints/andoperator.js +0 -71
- package/source/constraints/invalid.js +0 -63
- package/source/constraints/isarray.js +0 -71
- package/source/constraints/isobject.js +0 -72
- package/source/constraints/valid.js +0 -63
- package/source/data/datasource/storage/localstorage.js +0 -64
- package/source/data/datasource/storage/sessionstorage.js +0 -61
- package/source/dom/resource/link/stylesheet.js +0 -54
- package/source/i18n/provider.js +0 -58
- package/source/i18n/providers/namespace.js +0 -16
- package/source/logging/handler/console.js +0 -66
- package/source/logging/handler/namespace.js +0 -14
- package/source/logging/logentry.js +0 -68
- package/source/monster.js +0 -80
- package/source/namespace.js +0 -171
- package/source/types/base.js +0 -50
- package/source/types/is.js +0 -429
- package/source/types/package.d.ts +0 -1
- package/source/types/randomid.js +0 -60
- package/source/types/regex.js +0 -49
- package/source/types/typeof.js +0 -63
- package/source/util/freeze.js +0 -57
- package/test/cases/math/random.js +0 -82
- package/test/cases/monster.js +0 -23
- package/test/cases/namespace.js +0 -93
- package/test/cases/types/randomid.js +0 -24
- package/test/cases/types/regex.js +0 -32
- package/test/web/monster-dev.html +0 -22
- package/test/web/monster.html +0 -21
@@ -1,43 +1,28 @@
|
|
1
|
-
'use strict';
|
2
|
-
|
3
1
|
/**
|
4
|
-
*
|
2
|
+
* Copyright schukai GmbH and contributors 2022. All Rights Reserved.
|
3
|
+
* Node module: @schukai/monster
|
4
|
+
* This file is licensed under the AGPLv3 License.
|
5
|
+
* License text available at https://www.gnu.org/licenses/agpl-3.0.en.html
|
5
6
|
*/
|
6
7
|
|
7
|
-
import {internalSymbol} from "../constants.
|
8
|
-
import {random} from "../math/random.
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {
|
12
|
-
|
8
|
+
import {internalSymbol} from "../constants.mjs";
|
9
|
+
import {random} from "../math/random.mjs";
|
10
|
+
import {isObject} from '../types/is.mjs';
|
11
|
+
import {Base} from "./base.mjs";
|
12
|
+
import {getGlobalObject} from "./global.mjs";
|
13
|
+
|
14
|
+
export {UUID}
|
13
15
|
|
14
16
|
/**
|
15
|
-
*
|
16
|
-
*
|
17
|
-
*
|
18
|
-
*
|
19
|
-
* ```
|
20
|
-
* <script type="module">
|
21
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
22
|
-
* new Monster.Types.UUID()
|
23
|
-
* </script>
|
24
|
-
* ```
|
25
|
-
*
|
26
|
-
* Or directly via the class:
|
27
|
-
*
|
28
|
-
* ```
|
29
|
-
* <script type="module">
|
30
|
-
* import {Base} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/uuid.js';
|
31
|
-
* new UUID()
|
32
|
-
* </script>
|
33
|
-
* ```
|
34
|
-
*
|
17
|
+
* The UUID class makes it possible to get a unique UUID for an object.
|
18
|
+
*
|
19
|
+
* @license AGPLv3
|
35
20
|
* @since 1.25.0
|
36
21
|
* @copyright schukai GmbH
|
37
22
|
* @memberOf Monster.Types
|
38
23
|
* @throws {Error} unsupported
|
39
24
|
*/
|
40
|
-
class UUID extends Base {
|
25
|
+
class UUID extends Base {
|
41
26
|
|
42
27
|
/**
|
43
28
|
*
|
@@ -97,6 +82,3 @@ function createWithCrypto() {
|
|
97
82
|
return crypt.randomUUID();
|
98
83
|
}
|
99
84
|
|
100
|
-
|
101
|
-
assignToNamespace('Monster.Types', UUID);
|
102
|
-
export {Monster, UUID}
|
@@ -1,10 +1,10 @@
|
|
1
|
-
'use strict';
|
2
|
-
|
3
1
|
/**
|
4
|
-
*
|
2
|
+
* Copyright schukai GmbH and contributors 2022. All Rights Reserved.
|
3
|
+
* Node module: @schukai/monster
|
4
|
+
* This file is licensed under the AGPLv3 License.
|
5
|
+
* License text available at https://www.gnu.org/licenses/agpl-3.0.en.html
|
5
6
|
*/
|
6
7
|
|
7
|
-
import {assignToNamespace, Monster} from '../namespace.js';
|
8
8
|
import {
|
9
9
|
isArray,
|
10
10
|
isBoolean,
|
@@ -16,26 +16,27 @@ import {
|
|
16
16
|
isPrimitive,
|
17
17
|
isString,
|
18
18
|
isSymbol
|
19
|
-
} from './is.
|
19
|
+
} from './is.mjs';
|
20
|
+
|
21
|
+
export {
|
22
|
+
validateIterable,
|
23
|
+
validatePrimitive,
|
24
|
+
validateBoolean,
|
25
|
+
validateString,
|
26
|
+
validateObject,
|
27
|
+
validateInstance,
|
28
|
+
validateArray,
|
29
|
+
validateSymbol,
|
30
|
+
validateFunction,
|
31
|
+
validateInteger
|
32
|
+
}
|
20
33
|
|
21
34
|
/**
|
22
35
|
* This method checks if the type matches the primitive type. this function is identical to isPrimitive() except that a TypeError is thrown.
|
23
36
|
*
|
24
|
-
* You can call the method via the monster namespace `Monster.Types.validatePrimitive()`.
|
25
|
-
*
|
26
|
-
* ```
|
27
|
-
* <script type="module">
|
28
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
29
|
-
* console.log(Monster.Types.validateIterable('2')) // ↦ TypeError
|
30
|
-
* console.log(Monster.Types.validateIterable([])) // ↦ value
|
31
|
-
* </script>
|
32
|
-
* ```
|
33
|
-
*
|
34
|
-
* Alternatively, you can also integrate this function individually.
|
35
|
-
*
|
36
37
|
* ```
|
37
38
|
* <script type="module">
|
38
|
-
* import {validateIterable} from '
|
39
|
+
* import {validateIterable} from '@schukai/monster/source/types/validate.mjs';
|
39
40
|
* console.log(validateIterable('2')) // ↦ TypeError
|
40
41
|
* console.log(validateIterable([])) // ↦ value
|
41
42
|
* </script>
|
@@ -43,6 +44,7 @@ import {
|
|
43
44
|
*
|
44
45
|
* @param {*} value
|
45
46
|
* @return {*}
|
47
|
+
* @license AGPLv3
|
46
48
|
* @since 1.2.0
|
47
49
|
* @copyright schukai GmbH
|
48
50
|
* @memberOf Monster.Types
|
@@ -61,21 +63,9 @@ function validateIterable(value) {
|
|
61
63
|
/**
|
62
64
|
* This method checks if the type matches the primitive type. this function is identical to isPrimitive() except that a TypeError is thrown.
|
63
65
|
*
|
64
|
-
* You can call the method via the monster namespace `Monster.Types.validatePrimitive()`.
|
65
|
-
*
|
66
66
|
* ```
|
67
67
|
* <script type="module">
|
68
|
-
* import {
|
69
|
-
* console.log(Monster.Types.validatePrimitive('2')) // ↦ value
|
70
|
-
* console.log(Monster.Types.validatePrimitive([])) // ↦ TypeError
|
71
|
-
* </script>
|
72
|
-
* ```
|
73
|
-
*
|
74
|
-
* Alternatively, you can also integrate this function individually.
|
75
|
-
*
|
76
|
-
* ```
|
77
|
-
* <script type="module">
|
78
|
-
* import {validatePrimitive} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/validate.js';
|
68
|
+
* import {validatePrimitive} from '@schukai/monster/source/types/validate.mjs';
|
79
69
|
* console.log(validatePrimitive('2')) // ↦ value
|
80
70
|
* console.log(validatePrimitive([])) // ↦ TypeError
|
81
71
|
* </script>
|
@@ -83,6 +73,7 @@ function validateIterable(value) {
|
|
83
73
|
*
|
84
74
|
* @param {*} value
|
85
75
|
* @return {*}
|
76
|
+
* @license AGPLv3
|
86
77
|
* @since 1.0.0
|
87
78
|
* @copyright schukai GmbH
|
88
79
|
* @memberOf Monster.Types
|
@@ -101,22 +92,9 @@ function validatePrimitive(value) {
|
|
101
92
|
/**
|
102
93
|
* This method checks if the type matches the boolean type. this function is identical to isBoolean() except that a TypeError is thrown.
|
103
94
|
*
|
104
|
-
* You can call the method via the monster namespace `Monster.Types.validateBoolean()`.
|
105
|
-
*
|
106
|
-
* ```
|
107
|
-
* <script type="module">
|
108
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
109
|
-
* console.log(Monster.Types.validateBoolean(true)) // ↦ value
|
110
|
-
* console.log(Monster.Types.validateBoolean('2')) // ↦ TypeError
|
111
|
-
* console.log(Monster.Types.validateBoolean([])) // ↦ TypeError
|
112
|
-
* </script>
|
113
|
-
* ```
|
114
|
-
*
|
115
|
-
* Alternatively, you can also integrate this function individually.
|
116
|
-
*
|
117
95
|
* ```
|
118
96
|
* <script type="module">
|
119
|
-
* import {validateBoolean} from '
|
97
|
+
* import {validateBoolean} from '@schukai/monster/source/types/validate.mjs';
|
120
98
|
* console.log(validateBoolean(false)) // ↦ value
|
121
99
|
* console.log(validateBoolean('2')) // ↦ TypeError
|
122
100
|
* console.log(validateBoolean([])) // ↦ TypeError
|
@@ -125,6 +103,7 @@ function validatePrimitive(value) {
|
|
125
103
|
*
|
126
104
|
* @param {*} value
|
127
105
|
* @return {*}
|
106
|
+
* @license AGPLv3
|
128
107
|
* @since 1.0.0
|
129
108
|
* @copyright schukai GmbH
|
130
109
|
* @memberOf Monster.Types
|
@@ -141,21 +120,9 @@ function validateBoolean(value) {
|
|
141
120
|
/**
|
142
121
|
* This method checks if the type matches the string type. this function is identical to isString() except that a TypeError is thrown.
|
143
122
|
*
|
144
|
-
* You can call the method via the monster namespace `Monster.Types.validateString()`.
|
145
|
-
*
|
146
123
|
* ```
|
147
124
|
* <script type="module">
|
148
|
-
* import {
|
149
|
-
* console.log(Monster.Types.validateString('2')) // ↦ value
|
150
|
-
* console.log(Monster.Types.validateString([])) // ↦ TypeError
|
151
|
-
* </script>
|
152
|
-
* ```
|
153
|
-
*
|
154
|
-
* Alternatively, you can also integrate this function individually.
|
155
|
-
*
|
156
|
-
* ```
|
157
|
-
* <script type="module">
|
158
|
-
* import {validateString} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/validate.js';
|
125
|
+
* import {validateString} from '@schukai/monster/source/types/validate.mjs';
|
159
126
|
* console.log(validateString('2')) // ↦ value
|
160
127
|
* console.log(validateString([])) // ↦ TypeError
|
161
128
|
* </script>
|
@@ -163,6 +130,7 @@ function validateBoolean(value) {
|
|
163
130
|
*
|
164
131
|
* @param {*} value
|
165
132
|
* @return {*}
|
133
|
+
* @license AGPLv3
|
166
134
|
* @since 1.0.0
|
167
135
|
* @copyright schukai GmbH
|
168
136
|
* @memberOf Monster.Types
|
@@ -179,22 +147,9 @@ function validateString(value) {
|
|
179
147
|
/**
|
180
148
|
* This method checks if the type matches the object type. this function is identical to isObject() except that a TypeError is thrown.
|
181
149
|
*
|
182
|
-
* You can call the method via the monster namespace `Monster.Types.validateObject()`.
|
183
|
-
*
|
184
|
-
* ```
|
185
|
-
* <script type="module">
|
186
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
187
|
-
* console.log(Monster.Types.validateObject({})) // ↦ value
|
188
|
-
* console.log(Monster.Types.validateObject('2')) // ↦ TypeError
|
189
|
-
* console.log(Monster.Types.validateObject([])) // ↦ TypeError
|
190
|
-
* </script>
|
191
|
-
* ```
|
192
|
-
*
|
193
|
-
* Alternatively, you can also integrate this function individually.
|
194
|
-
*
|
195
150
|
* ```
|
196
151
|
* <script type="module">
|
197
|
-
* import {validateObject} from '
|
152
|
+
* import {validateObject} from '@schukai/monster/source/types/validate.mjs';
|
198
153
|
* console.log(validateObject({})) // ↦ value
|
199
154
|
* console.log(validateObject('2')) // ↦ TypeError
|
200
155
|
* console.log(validateObject([])) // ↦ TypeError
|
@@ -203,6 +158,7 @@ function validateString(value) {
|
|
203
158
|
*
|
204
159
|
* @param {*} value
|
205
160
|
* @return {*}
|
161
|
+
* @license AGPLv3
|
206
162
|
* @since 1.0.0
|
207
163
|
* @copyright schukai GmbH
|
208
164
|
* @memberOf Monster.Types
|
@@ -218,22 +174,9 @@ function validateObject(value) {
|
|
218
174
|
/**
|
219
175
|
* This method checks if the type matches the object instance.
|
220
176
|
*
|
221
|
-
* You can call the method via the monster namespace `Monster.Types.validateInstance()`.
|
222
|
-
*
|
223
|
-
* ```
|
224
|
-
* <script type="module">
|
225
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
226
|
-
* console.log(Monster.Types.validateInstance({}, Object)) // ↦ value
|
227
|
-
* console.log(Monster.Types.validateInstance('2', Object)) // ↦ TypeError
|
228
|
-
* console.log(Monster.Types.validateInstance([], Object)) // ↦ TypeError
|
229
|
-
* </script>
|
230
|
-
* ```
|
231
|
-
*
|
232
|
-
* Alternatively, you can also integrate this function individually.
|
233
|
-
*
|
234
177
|
* ```
|
235
178
|
* <script type="module">
|
236
|
-
* import {validateInstance} from '
|
179
|
+
* import {validateInstance} from '@schukai/monster/source/types/validate.mjs';
|
237
180
|
* console.log(validateInstance({}, Object)) // ↦ value
|
238
181
|
* console.log(validateInstance('2', Object)) // ↦ TypeError
|
239
182
|
* console.log(validateInstance([], Object)) // ↦ TypeError
|
@@ -242,6 +185,7 @@ function validateObject(value) {
|
|
242
185
|
*
|
243
186
|
* @param {*} value
|
244
187
|
* @return {*}
|
188
|
+
* @license AGPLv3
|
245
189
|
* @since 1.5.0
|
246
190
|
* @copyright schukai GmbH
|
247
191
|
* @memberOf Monster.Types
|
@@ -266,21 +210,9 @@ function validateInstance(value, instance) {
|
|
266
210
|
/**
|
267
211
|
* This method checks if the type matches the array type. this function is identical to isArray() except that a TypeError is thrown.
|
268
212
|
*
|
269
|
-
* You can call the method via the monster namespace `Monster.Types.validateArray()`.
|
270
|
-
*
|
271
213
|
* ```
|
272
214
|
* <script type="module">
|
273
|
-
* import {
|
274
|
-
* console.log(Monster.Types.validateArray('2')) // ↦ TypeError
|
275
|
-
* console.log(Monster.Types.validateArray([])) // ↦ value
|
276
|
-
* </script>
|
277
|
-
* ```
|
278
|
-
*
|
279
|
-
* Alternatively, you can also integrate this function individually.
|
280
|
-
*
|
281
|
-
* ```
|
282
|
-
* <script type="module">
|
283
|
-
* import {validateArray} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/validate.js';
|
215
|
+
* import {validateArray} from '@schukai/monster/source/types/validate.mjs';
|
284
216
|
* console.log(validateArray('2')) // ↦ TypeError
|
285
217
|
* console.log(validateArray([])) // ↦ value
|
286
218
|
* </script>
|
@@ -288,6 +220,7 @@ function validateInstance(value, instance) {
|
|
288
220
|
*
|
289
221
|
* @param {*} value
|
290
222
|
* @return {*}
|
223
|
+
* @license AGPLv3
|
291
224
|
* @since 1.0.0
|
292
225
|
* @copyright schukai GmbH
|
293
226
|
* @memberOf Monster.Types
|
@@ -303,21 +236,9 @@ function validateArray(value) {
|
|
303
236
|
/**
|
304
237
|
* This method checks if the type matches the symbol type. this function is identical to isSymbol() except that a TypeError is thrown.
|
305
238
|
*
|
306
|
-
* You can call the method via the monster namespace `Monster.Types.validateSymbol()`.
|
307
|
-
*
|
308
239
|
* ```
|
309
240
|
* <script type="module">
|
310
|
-
* import {
|
311
|
-
* console.log(Monster.Types.validateSymbol('2')) // ↦ TypeError
|
312
|
-
* console.log(Monster.Types.validateSymbol([])) // ↦ value
|
313
|
-
* </script>
|
314
|
-
* ```
|
315
|
-
*
|
316
|
-
* Alternatively, you can also integrate this function individually.
|
317
|
-
*
|
318
|
-
* ```
|
319
|
-
* <script type="module">
|
320
|
-
* import {validateSymbol} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/validate.js';
|
241
|
+
* import {validateSymbol} from '@schukai/monster/source/types/validate.mjs';
|
321
242
|
* console.log(validateSymbol('2')) // ↦ TypeError
|
322
243
|
* console.log(validateSymbol()) // ↦ value
|
323
244
|
* </script>
|
@@ -325,6 +246,7 @@ function validateArray(value) {
|
|
325
246
|
*
|
326
247
|
* @param {*} value
|
327
248
|
* @return {*}
|
249
|
+
* @license AGPLv3
|
328
250
|
* @since 1.9.0
|
329
251
|
* @copyright schukai GmbH
|
330
252
|
* @memberOf Monster.Types
|
@@ -340,22 +262,9 @@ function validateSymbol(value) {
|
|
340
262
|
/**
|
341
263
|
* This method checks if the type matches the function type. this function is identical to isFunction() except that a TypeError is thrown.
|
342
264
|
*
|
343
|
-
* You can call the method via the monster namespace `Monster.Types.validateFunction()`.
|
344
|
-
*
|
345
|
-
* ```
|
346
|
-
* <script type="module">
|
347
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
348
|
-
* console.log(Monster.Types.validateFunction(()=>{})) // ↦ value
|
349
|
-
* console.log(Monster.Types.validateFunction('2')) // ↦ TypeError
|
350
|
-
* console.log(Monster.Types.validateFunction([])) // ↦ TypeError
|
351
|
-
* </script>
|
352
|
-
* ```
|
353
|
-
*
|
354
|
-
* Alternatively, you can also integrate this function individually.
|
355
|
-
*
|
356
265
|
* ```
|
357
266
|
* <script type="module">
|
358
|
-
* import {validateFunction} from '
|
267
|
+
* import {validateFunction} from '@schukai/monster/source/types/validate.mjs';
|
359
268
|
* console.log(validateFunction(()=>{})) // ↦ value
|
360
269
|
* console.log(validateFunction('2')) // ↦ TypeError
|
361
270
|
* console.log(validateFunction([])) // ↦ TypeError
|
@@ -364,6 +273,7 @@ function validateSymbol(value) {
|
|
364
273
|
*
|
365
274
|
* @param {*} value
|
366
275
|
* @return {*}
|
276
|
+
* @license AGPLv3
|
367
277
|
* @since 1.0.0
|
368
278
|
* @copyright schukai GmbH
|
369
279
|
* @memberOf Monster.Types
|
@@ -379,22 +289,9 @@ function validateFunction(value) {
|
|
379
289
|
/**
|
380
290
|
* This method checks if the type is an integer. this function is identical to isInteger() except that a TypeError is thrown.
|
381
291
|
*
|
382
|
-
* You can call the method via the monster namespace `Monster.Types.validateInteger()`.
|
383
|
-
*
|
384
|
-
* ```
|
385
|
-
* <script type="module">
|
386
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
387
|
-
* console.log(Monster.Types.validateInteger(true)) // ↦ TypeError
|
388
|
-
* console.log(Monster.Types.validateInteger('2')) // ↦ TypeError
|
389
|
-
* console.log(Monster.Types.validateInteger(2)) // ↦ value
|
390
|
-
* </script>
|
391
|
-
* ```
|
392
|
-
*
|
393
|
-
* Alternatively, you can also integrate this function individually.
|
394
|
-
*
|
395
292
|
* ```
|
396
293
|
* <script type="module">
|
397
|
-
* import {validateFunction} from '
|
294
|
+
* import {validateFunction} from '@schukai/monster/source/types/validate.mjs';
|
398
295
|
* console.log(validateInteger(true)) // ↦ TypeError
|
399
296
|
* console.log(validateInteger('2')) // ↦ TypeError
|
400
297
|
* console.log(validateInteger(2)) // ↦ value
|
@@ -403,6 +300,7 @@ function validateFunction(value) {
|
|
403
300
|
*
|
404
301
|
* @param {*} value
|
405
302
|
* @return {*}
|
303
|
+
* @license AGPLv3
|
406
304
|
* @since 1.4.0
|
407
305
|
* @copyright schukai GmbH
|
408
306
|
* @memberOf Monster.Types
|
@@ -414,18 +312,3 @@ function validateInteger(value) {
|
|
414
312
|
}
|
415
313
|
return value
|
416
314
|
}
|
417
|
-
|
418
|
-
assignToNamespace('Monster.Types', validatePrimitive, validateBoolean, validateString, validateObject, validateArray, validateFunction, validateIterable, validateInteger);
|
419
|
-
export {
|
420
|
-
Monster,
|
421
|
-
validatePrimitive,
|
422
|
-
validateBoolean,
|
423
|
-
validateString,
|
424
|
-
validateObject,
|
425
|
-
validateInstance,
|
426
|
-
validateArray,
|
427
|
-
validateFunction,
|
428
|
-
validateIterable,
|
429
|
-
validateInteger,
|
430
|
-
validateSymbol
|
431
|
-
}
|
@@ -1,40 +1,19 @@
|
|
1
|
-
|
1
|
+
/**
|
2
|
+
* Copyright schukai GmbH and contributors 2022. All Rights Reserved.
|
3
|
+
* Node module: @schukai/monster
|
4
|
+
* This file is licensed under the AGPLv3 License.
|
5
|
+
* License text available at https://www.gnu.org/licenses/agpl-3.0.en.html
|
6
|
+
*/
|
7
|
+
|
8
|
+
import {Base} from './base.mjs';
|
2
9
|
|
3
|
-
|
4
|
-
import {Base} from './base.js';
|
10
|
+
export {Version, getMonsterVersion}
|
5
11
|
|
6
12
|
/**
|
7
|
-
* The version object contains a
|
8
|
-
*
|
9
|
-
* You can create the object via the monster namespace `new Monster.Types.Version()`.
|
10
|
-
*
|
11
|
-
* ```
|
12
|
-
* <script type="module">
|
13
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
14
|
-
* console.log(new Monster.Types.Version('1.2.3')) // ↦ 1.2.3
|
15
|
-
* console.log(new Monster.Types.Version('1')) // ↦ 1.0.0
|
16
|
-
* </script>
|
17
|
-
* ```
|
18
|
-
*
|
19
|
-
* Alternatively, you can also integrate this class individually.
|
20
|
-
*
|
21
|
-
* ```
|
22
|
-
* <script type="module">
|
23
|
-
* import {Version} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/version.js';
|
24
|
-
* console.log(new Version('1.2.3')) // ↦ 1.2.3
|
25
|
-
* console.log(new Version('1')) // ↦ 1.0.0
|
26
|
-
* </script>
|
27
|
-
* ```
|
28
|
-
*
|
29
|
-
* @example
|
30
|
-
*
|
31
|
-
* import {Version} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/version.js';
|
32
|
-
*
|
33
|
-
* new Version('1.0.0') // ↦ 1.0.0
|
34
|
-
* new Version(1) // ↦ 1.0.0
|
35
|
-
* new Version(1, 0, 0) // ↦ 1.0.0
|
36
|
-
* new Version('1.2.3', 4, 5) // ↦ 1.4.5
|
13
|
+
* The version object contains a semantic version number
|
37
14
|
*
|
15
|
+
* @externalExample ../../example/types/version-1.mjs
|
16
|
+
* @license AGPLv3
|
38
17
|
* @since 1.0.0
|
39
18
|
* @author schukai GmbH
|
40
19
|
* @copyright schukai GmbH
|
@@ -103,7 +82,7 @@ class Version extends Base {
|
|
103
82
|
|
104
83
|
/**
|
105
84
|
* returns 0 if equal, -1 if the object version is less and 1 if greater
|
106
|
-
*
|
85
|
+
* than the compared version
|
107
86
|
*
|
108
87
|
* @param {string|Version} version Version to compare
|
109
88
|
* @returns {number}
|
@@ -139,49 +118,27 @@ class Version extends Base {
|
|
139
118
|
|
140
119
|
}
|
141
120
|
|
142
|
-
assignToNamespace('Monster.Types', Version);
|
143
|
-
|
144
|
-
|
145
121
|
let monsterVersion;
|
146
122
|
|
147
123
|
/**
|
148
124
|
* Version of monster
|
149
125
|
*
|
150
|
-
*
|
151
|
-
*
|
152
|
-
* ```
|
153
|
-
* <script type="module">
|
154
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
155
|
-
* console.log(Monster.getVersion())
|
156
|
-
* </script>
|
157
|
-
* ```
|
158
|
-
*
|
159
|
-
* Alternatively, you can also integrate this function individually.
|
160
|
-
*
|
161
|
-
* ```
|
162
|
-
* <script type="module">
|
163
|
-
* import {getVersion} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/types/version.js';
|
164
|
-
* console.log(getVersion())
|
165
|
-
* </script>
|
166
|
-
* ```
|
167
|
-
*
|
126
|
+
* @externalExample ../../example/types/version-2.mjs
|
168
127
|
* @returns {Monster.Types.Version}
|
128
|
+
* @license AGPLv3
|
169
129
|
* @since 1.0.0
|
170
130
|
* @copyright schukai GmbH
|
171
131
|
* @author schukai GmbH
|
172
132
|
* @memberOf Monster
|
173
133
|
*/
|
174
|
-
function
|
134
|
+
function getMonsterVersion() {
|
175
135
|
if (monsterVersion instanceof Version) {
|
176
136
|
return monsterVersion;
|
177
137
|
}
|
178
|
-
|
179
|
-
|
180
|
-
|
138
|
+
|
139
|
+
/** don't touch, replaced by make with package.json version */
|
140
|
+
monsterVersion = new Version('2.0.0')
|
181
141
|
|
182
142
|
return monsterVersion;
|
183
143
|
|
184
144
|
}
|
185
|
-
|
186
|
-
assignToNamespace('Monster', getVersion);
|
187
|
-
export {Monster, Version, getVersion}
|
@@ -1,15 +1,16 @@
|
|
1
|
-
'use strict';
|
2
|
-
|
3
1
|
/**
|
4
|
-
*
|
2
|
+
* Copyright schukai GmbH and contributors 2022. All Rights Reserved.
|
3
|
+
* Node module: @schukai/monster
|
4
|
+
* This file is licensed under the AGPLv3 License.
|
5
|
+
* License text available at https://www.gnu.org/licenses/agpl-3.0.en.html
|
5
6
|
*/
|
6
7
|
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {validateObject} from "../types/validate.js";
|
8
|
+
import {getGlobal} from '../types/global.mjs';
|
9
|
+
import {isArray, isFunction, isObject, isPrimitive} from '../types/is.mjs';
|
10
|
+
import {typeOf} from "../types/typeof.mjs";
|
11
|
+
import {validateObject} from "../types/validate.mjs";
|
12
12
|
|
13
|
+
export {clone}
|
13
14
|
|
14
15
|
/**
|
15
16
|
* With this function, objects can be cloned.
|
@@ -20,26 +21,9 @@ import {validateObject} from "../types/validate.js";
|
|
20
21
|
*
|
21
22
|
* If an object has a method `getClone()`, this method is used to create the clone.
|
22
23
|
*
|
23
|
-
* You can call the method via the monster namespace `Monster.Util.clone()`.
|
24
|
-
*
|
25
|
-
* ```
|
26
|
-
* <script type="module">
|
27
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
28
|
-
* Monster.Util.clone({})
|
29
|
-
* </script>
|
30
|
-
* ```
|
31
|
-
*
|
32
|
-
* Alternatively, you can also integrate this function individually.
|
33
|
-
*
|
34
|
-
* ```
|
35
|
-
* <script type="module">
|
36
|
-
* import {clone} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/util/clone.js';
|
37
|
-
* clone({})
|
38
|
-
* </script>
|
39
|
-
* ```
|
40
|
-
*
|
41
24
|
* @param {*} obj object to be cloned
|
42
25
|
* @returns {*}
|
26
|
+
* @license AGPLv3
|
43
27
|
* @since 1.0.0
|
44
28
|
* @memberOf Monster.Util
|
45
29
|
* @copyright schukai GmbH
|
@@ -156,5 +140,3 @@ function cloneObject(obj) {
|
|
156
140
|
return copy;
|
157
141
|
}
|
158
142
|
|
159
|
-
assignToNamespace('Monster.Util', clone);
|
160
|
-
export {Monster, clone}
|
@@ -1,31 +1,18 @@
|
|
1
|
-
'use strict';
|
2
|
-
|
3
1
|
/**
|
4
|
-
*
|
2
|
+
* Copyright schukai GmbH and contributors 2022. All Rights Reserved.
|
3
|
+
* Node module: @schukai/monster
|
4
|
+
* This file is licensed under the AGPLv3 License.
|
5
|
+
* License text available at https://www.gnu.org/licenses/agpl-3.0.en.html
|
5
6
|
*/
|
6
|
-
|
7
|
-
import {Base} from '../types/base.
|
8
|
-
import {isFunction} from '../types/is.
|
7
|
+
|
8
|
+
import {Base} from '../types/base.mjs';
|
9
|
+
import {isFunction} from '../types/is.mjs';
|
10
|
+
|
11
|
+
export {Comparator}
|
9
12
|
|
10
13
|
/**
|
11
14
|
* The comparator allows a comparison function to be abstracted.
|
12
|
-
*
|
13
|
-
* ```
|
14
|
-
* <script type="module">
|
15
|
-
* import {Monster} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/monster.js';
|
16
|
-
* new Monster.Util.Comparator()
|
17
|
-
* </script>
|
18
|
-
* ```
|
19
|
-
*
|
20
|
-
* Alternatively, you can also integrate this function individually.
|
21
|
-
*
|
22
|
-
* ```
|
23
|
-
* <script type="module">
|
24
|
-
* import {Comparator} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/util/comparator.js';
|
25
|
-
* console.log(new Comparator())
|
26
|
-
* </script>
|
27
|
-
* ```
|
28
|
-
*
|
15
|
+
*
|
29
16
|
* The following are some examples of the application of the class.
|
30
17
|
*
|
31
18
|
* ```
|
@@ -44,19 +31,8 @@ import {isFunction} from '../types/is.js';
|
|
44
31
|
* }).equal({v: 2}, {v: 2}); // ↦ true
|
45
32
|
* ```
|
46
33
|
*
|
47
|
-
* @example
|
48
|
-
*
|
49
|
-
* import {Comparator} from 'https://cdn.jsdelivr.net/npm/@schukai/monster@1.31.0/dist/modules/util/comparator.js';
|
50
|
-
*
|
51
|
-
* console.log(new Comparator().lessThanOrEqual(2, 5))
|
52
|
-
* // ↦ true
|
53
|
-
* console.log(new Comparator().greaterThan(4, 2))
|
54
|
-
* // ↦ true
|
55
|
-
* console.log(new Comparator().equal(4, 4))
|
56
|
-
* // ↦ true
|
57
|
-
* console.log(new Comparator().equal(4, 5))
|
58
|
-
* // ↦ false
|
59
|
-
*
|
34
|
+
* @externalExample ../../example/util/comparator.mjs
|
35
|
+
* @license AGPLv3
|
60
36
|
* @since 1.3.0
|
61
37
|
* @memberOf Monster.Util
|
62
38
|
*/
|
@@ -88,7 +64,7 @@ class Comparator extends Base {
|
|
88
64
|
this.compare = function (a, b) {
|
89
65
|
|
90
66
|
if (typeof a !== typeof b) {
|
91
|
-
throw new TypeError("impractical comparison", "types/comparator.
|
67
|
+
throw new TypeError("impractical comparison", "types/comparator.mjs")
|
92
68
|
}
|
93
69
|
|
94
70
|
if (a === b) {
|
@@ -194,9 +170,3 @@ class Comparator extends Base {
|
|
194
170
|
* @see Monster.Util.Comparator
|
195
171
|
*/
|
196
172
|
|
197
|
-
|
198
|
-
/**
|
199
|
-
*
|
200
|
-
*/
|
201
|
-
assignToNamespace('Monster.Util', Comparator);
|
202
|
-
export {Monster, Comparator}
|