New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

itemsholdr

Package Overview
Dependencies
Maintainers
1
Versions
38
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

itemsholdr - npm Package Compare versions

Comparing version 0.6.1 to 0.7.0

.vscode/settings.json

85

package.json
{
"name": "itemsholdr",
"description": "Cache-based wrapper around localStorage.",
"version": "0.6.1",
"author": {
"name": "Josh Goldberg",
"email": "joshuakgoldberg@outlook.com"
},
"repository": {
"type": "git",
"url": "ssh://git@github.com:FullScreenShenanigans/ItemsHoldr.git"
},
"bugs": {
"url": "https://github.com/FullScreenShenanigans/ItemsHoldr/issues"
},
"license": "MIT",
"devDependencies": {
"gulp-shenanigans": "0.6.X"
}
"author": {
"email": "joshuakgoldberg@outlook.com",
"name": "Josh Goldberg"
},
"bugs": {
"url": "https://github.com/FullScreenShenanigans/ItemsHoldr/issues"
},
"dependencies": {},
"description": "Cache-based wrapper around localStorage.",
"devDependencies": {
"@types/chai": "^4.0.4",
"@types/lolex": "^1.5.32",
"@types/mocha": "^2.2.44",
"@types/sinon": "^4.0.0",
"@types/sinon-chai": "^2.7.29",
"chai": "^4.1.2",
"glob": "^7.1.2",
"gulp": "^3.9.1",
"gulp-shenanigans": "^0.6.17",
"lolex": "^2.3.0",
"mocha": "^4.0.1",
"mocha-headless-chrome": "^1.7.1",
"requirejs": "^2.3.5",
"run-for-every-file": "^1.0.4",
"shenanigans-manager": "^0.2.1",
"sinon": "^4.1.2",
"sinon-chai": "^2.14.0",
"tslint": "5.8.0",
"typedoc": "^0.9.0",
"typescript": "^2.6.2",
"webpack": "^3.10.0"
},
"license": "MIT",
"name": "itemsholdr",
"repository": {
"type": "git",
"url": "ssh://git@github.com:FullScreenShenanigans/ItemsHoldr.git"
},
"scripts": {
"dist": "npm run dist:webpack",
"dist:webpack": "webpack --config webpack.config.js",
"docs": "npm run docs:typedoc",
"docs:typedoc": "typedoc src/ --out docs/generated",
"gulp": "gulp",
"init": "npm install && npm run setup && npm run verify",
"setup": "npm run setup:copy && npm run setup:package",
"setup:copy": "npm run setup:copy:default",
"setup:copy:default": "run-for-every-file --dot --src \"node_modules/shenanigans-manager/setup/default/\" --file \"**/*\" --run \"mustache package.json {{src-file}} {{file}}\" --dest \".\"",
"setup:package": "shenanigans-manager hydrate-package-json",
"src": "npm run src:tsc && npm run src:tslint",
"src:tsc": "tsc -p .",
"src:tslint": "tslint -c tslint.json -p tsconfig.json -t stylish",
"test": "npm run test:setup && npm run test:run",
"test:run": "mocha-headless-chrome --file test/index.html",
"test:setup": "npm run test:setup:copy && npm run test:setup:html && npm run test:setup:tsc",
"test:setup:copy": "npm run test:setup:copy:default",
"test:setup:copy:default": "run-for-every-file --dot --src \"node_modules/shenanigans-manager/setup/test/\" --file \"**/*\" --run \"mustache package.json {{src-file}} ./test/{{file}}\" --dest \".\"",
"test:setup:html": "shenanigans-manager generate-test-html",
"test:setup:tsc": "tsc -p test",
"verify": "npm run src && npm run test && npm run dist && npm run docs",
"watch": "tsc -p . -w"
},
"shenanigans": {
"name": "ItemsHoldr"
},
"types": "./src/index.d.ts",
"version": "0.7.0"
}

@@ -0,1 +1,2 @@

<!-- {{Top}} -->
# ItemsHoldr

@@ -6,17 +7,10 @@ [![Build Status](https://travis-ci.org/FullScreenShenanigans/ItemsHoldr.svg?branch=master)](https://travis-ci.org/FullScreenShenanigans/ItemsHoldr)

Cache-based wrapper around localStorage.
<!-- {{/Top}} -->
<!-- {{Development}} -->
## Development
See [Documentation/Development](https://github.com/FullScreenShenanigans/Documentation).
## Build Process
ItemsHoldr uses [Gulp](http://gulpjs.com/) to automate building, which requires [Node.js](http://node.js.org).
To build from scratch, install NodeJS and run the following commands:
```
npm install -g gulp
npm install
gulp
```
See [Build Details](https://github.com/FullScreenShenanigans/Documentation/blob/master/Build%20Details.md) for detailed Gulp usage.
<!-- {{/Development}} -->

@@ -25,6 +25,2 @@ import { IItemValue, IItemValueDefaults } from "./IItemValue";

/**
* Arguments to pass to triggered callback Functions.
*/
callbackArgs?: any[];
/**
* A localStorage object to use instead of the global localStorage.

@@ -41,20 +37,5 @@ */

defaults?: IItemValueDefaults;
/**
* Any hardcoded changes to element content.
*/
displayChanges?: {
[i: string]: string;
};
/**
* Whether an HTML container should be created to house the IItemValue elements.
*/
doMakeContainer?: boolean;
/**
* Arguments to pass to create the container, if not the default div and className.
*/
containersArguments?: [string, any][];
}
/**
* A versatile container to store and manipulate values in localStorage, and
* optionally keep an updated HTML container showing these values.
* A versatile container to store and manipulate values in localStorage.
*/

@@ -85,20 +66,2 @@ export interface IItemsHoldr {

/**
* @returns The container HTML element, if it exists.
*/
getContainer(): HTMLElement;
/**
* @returns createElement arguments for HTML containers, outside-to-inside.
*/
getContainersArguments(): [string, any][];
/**
* @returns Any hard-coded changes to element content.
*/
getDisplayChanges(): {
[i: string]: string;
};
/**
* @returns Arguments to be passed to triggered event callbacks.
*/
getCallbackArgs(): any[];
/**
* @returns String keys for each of the stored IItemValues.

@@ -139,16 +102,13 @@ */

/**
* Clears a value from the listing, and removes its element from the
* container (if they both exist).
* Clears a value from the listing.
*
* @param key The key of the element to remove.
* @param key The key of the value to remove.
*/
removeItem(key: string): void;
/**
* Completely clears all values from the ItemsHoldr, removing their
* elements from the container (if they both exist) as well.
* Completely clears all values from the ItemsHoldr.
*/
clear(): void;
/**
* Sets the value for the ItemValue under the given key, then updates the ItemValue
* (including the ItemValue's element and localStorage, if needed).
* Sets the value for the ItemValue under the given key.
*

@@ -185,3 +145,3 @@ * @param key The key of the ItemValue.

*
* @param key
* @param key Key of an ItemValue.
*/

@@ -199,63 +159,2 @@ checkExistence(key: string): void;

saveAll(): void;
/**
* Hides the container Element by setting its visibility to hidden.
*/
hideContainer(): void;
/**
* Shows the container Element by setting its visibility to visible.
*/
displayContainer(): void;
/**
* Creates the container Element, which contains a child for each ItemValue that
* specifies hasElement to be true.
*
* @param containers An Array representing the Element to be created and the
* children between it and the contained ItemValues.
* Each contained Object has a String tag name as its
* first member, followed by any number of Objects to apply
* via createElement.
* @returns A newly created Element that can be used as a container.
*/
makeContainer(containers: [string, any][]): HTMLElement;
/**
* @returns Whether displayChanges has an entry for a particular value.
*/
hasDisplayChange(value: string): boolean;
/**
* @returns The displayChanges entry for a particular value.
*/
getDisplayChange(value: string): string;
/**
* Creates a new HTMLElement of the given type. For each Object given as
* arguments after, each member is proliferated onto the element.
*
* @param tag The type of the HTMLElement (by default, "div").
* @param args Any number of Objects to be proliferated onto the
* new HTMLElement.
* @returns A newly created HTMLElement of the given tag.
*/
createElement(tag?: string, ...args: any[]): HTMLElement;
/**
* Proliferates all members of the donor to the recipient recursively, as
* a deep copy.
*
* @param recipient An object receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
proliferate(recipient: any, donor: any, noOverride?: boolean): any;
/**
* Identical to proliferate, but tailored for HTML elements because many
* element attributes don't play nicely with JavaScript Array standards.
* Looking at you, HTMLCollection!
*
* @param recipient An HTMLElement receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
proliferateElement(recipient: any, donor: any, noOverride?: boolean): any;
}
define(["require", "exports"], function (require, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJJSXRlbXNIb2xkci5qcyIsInNvdXJjZXNDb250ZW50IjpbXX0=

@@ -30,7 +30,2 @@ import { IItemValue, IItemValueDefaults } from "./IItemValue";

/**
* Arguments to pass to triggered callback Functions.
*/
callbackArgs?: any[];
/**
* A localStorage object to use instead of the global localStorage.

@@ -49,22 +44,6 @@ */

defaults?: IItemValueDefaults;
/**
* Any hardcoded changes to element content.
*/
displayChanges?: { [i: string]: string };
/**
* Whether an HTML container should be created to house the IItemValue elements.
*/
doMakeContainer?: boolean;
/**
* Arguments to pass to create the container, if not the default div and className.
*/
containersArguments?: [string, any][];
}
/**
* A versatile container to store and manipulate values in localStorage, and
* optionally keep an updated HTML container showing these values.
* A versatile container to store and manipulate values in localStorage.
*/

@@ -98,22 +77,2 @@ export interface IItemsHoldr {

/**
* @returns The container HTML element, if it exists.
*/
getContainer(): HTMLElement;
/**
* @returns createElement arguments for HTML containers, outside-to-inside.
*/
getContainersArguments(): [string, any][];
/**
* @returns Any hard-coded changes to element content.
*/
getDisplayChanges(): { [i: string]: string };
/**
* @returns Arguments to be passed to triggered event callbacks.
*/
getCallbackArgs(): any[];
/**
* @returns String keys for each of the stored IItemValues.

@@ -153,3 +112,3 @@ */

* Adds a new key & value pair to by linking to a newly created ItemValue.
*
*
* @param key The key to reference by new ItemValue by.

@@ -162,6 +121,5 @@ * @param settings The settings for the new ItemValue.

/**
* Clears a value from the listing, and removes its element from the
* container (if they both exist).
*
* @param key The key of the element to remove.
* Clears a value from the listing.
*
* @param key The key of the value to remove.
*/

@@ -171,4 +129,3 @@ removeItem(key: string): void;

/**
* Completely clears all values from the ItemsHoldr, removing their
* elements from the container (if they both exist) as well.
* Completely clears all values from the ItemsHoldr.
*/

@@ -178,5 +135,4 @@ clear(): void;

/**
* Sets the value for the ItemValue under the given key, then updates the ItemValue
* (including the ItemValue's element and localStorage, if needed).
*
* Sets the value for the ItemValue under the given key.
*
* @param key The key of the ItemValue.

@@ -190,3 +146,3 @@ * @param value The new value for the ItemValue.

* Numbers or concatenation for Strings.
*
*
* @param key The key of the ItemValue.

@@ -200,3 +156,3 @@ * @param amount The amount to increase by (by default, 1).

* Numbers or concatenation for Strings.
*
*
* @param key The key of the ItemValue.

@@ -209,3 +165,3 @@ * @param amount The amount to increase by (by default, 1).

* Toggles whether a value is true or false.
*
*
* @param key The key of the ItemValue.

@@ -218,4 +174,4 @@ */

* allowed, it creates it; otherwise, it throws an Error.
*
* @param key
*
* @param key Key of an ItemValue.
*/

@@ -226,3 +182,3 @@ checkExistence(key: string): void;

* Manually saves an item's value to localStorage, ignoring the autoSave flag.
*
*
* @param key The key of the item to save.

@@ -233,74 +189,5 @@ */

/**
* Manually saves all values to localStorage, ignoring the autoSave flag.
* Manually saves all values to localStorage, ignoring the autoSave flag.
*/
saveAll(): void;
/**
* Hides the container Element by setting its visibility to hidden.
*/
hideContainer(): void;
/**
* Shows the container Element by setting its visibility to visible.
*/
displayContainer(): void;
/**
* Creates the container Element, which contains a child for each ItemValue that
* specifies hasElement to be true.
*
* @param containers An Array representing the Element to be created and the
* children between it and the contained ItemValues.
* Each contained Object has a String tag name as its
* first member, followed by any number of Objects to apply
* via createElement.
* @returns A newly created Element that can be used as a container.
*/
makeContainer(containers: [string, any][]): HTMLElement;
/**
* @returns Whether displayChanges has an entry for a particular value.
*/
hasDisplayChange(value: string): boolean;
/**
* @returns The displayChanges entry for a particular value.
*/
getDisplayChange(value: string): string;
/**
* Creates a new HTMLElement of the given type. For each Object given as
* arguments after, each member is proliferated onto the element.
*
* @param tag The type of the HTMLElement (by default, "div").
* @param args Any number of Objects to be proliferated onto the
* new HTMLElement.
* @returns A newly created HTMLElement of the given tag.
*/
createElement(tag?: string, ...args: any[]): HTMLElement;
/**
* Proliferates all members of the donor to the recipient recursively, as
* a deep copy.
*
* @param recipient An object receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
proliferate(recipient: any, donor: any, noOverride?: boolean): any;
/**
* Identical to proliferate, but tailored for HTML elements because many
* element attributes don't play nicely with JavaScript Array standards.
* Looking at you, HTMLCollection!
*
* @param recipient An HTMLElement receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
proliferateElement(recipient: any, donor: any, noOverride?: boolean): any;
}

@@ -37,10 +37,2 @@ /**

/**
* Whether an Element should be created and synced to the value.
*/
hasElement?: boolean;
/**
* An Element tag to use in creating the element, if hasElement is true.
*/
elementTag?: string;
/**
* A minimum value for the value to equal, if value is a number.

@@ -79,4 +71,3 @@ */

/**
* Storage container for a single IItemsHoldr value. The value may have triggers
* assigned to value, modularity, and other triggers, as well as an HTML element.
* Storage container for a single IItemsHoldr value.
*/

@@ -96,9 +87,3 @@ export interface IItemValue {

/**
* @returns The stored HTML element, if it exists.
*/
getElement(): HTMLElement;
/**
* General update Function to be run whenever the internal value is changed.
* It runs all the trigger, modular, etc. checks, updates the HTML element
* if there is one, and updates localStorage if needed.
*/

@@ -105,0 +90,0 @@ update(): void;

define(["require", "exports"], function (require, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJJSXRlbVZhbHVlLmpzIiwic291cmNlc0NvbnRlbnQiOltdfQ==

@@ -43,12 +43,2 @@ /**

/**
* Whether an Element should be created and synced to the value.
*/
hasElement?: boolean;
/**
* An Element tag to use in creating the element, if hasElement is true.
*/
elementTag?: string;
/**
* A minimum value for the value to equal, if value is a number.

@@ -95,4 +85,3 @@ */

/**
* Storage container for a single IItemsHoldr value. The value may have triggers
* assigned to value, modularity, and other triggers, as well as an HTML element.
* Storage container for a single IItemsHoldr value.
*/

@@ -114,10 +103,3 @@ export interface IItemValue {

/**
* @returns The stored HTML element, if it exists.
*/
getElement(): HTMLElement;
/**
* General update Function to be run whenever the internal value is changed.
* It runs all the trigger, modular, etc. checks, updates the HTML element
* if there is one, and updates localStorage if needed.
*/

@@ -128,3 +110,3 @@ update(): void;

* Stores a ItemValue's value in localStorage under the prefix plus its key.
*
*
* @param overrideAutoSave Whether the policy on saving should be ignored

@@ -131,0 +113,0 @@ * so saving happens regardless. By default, false.

@@ -11,48 +11,32 @@ import { IItemsHoldr, IItemsHoldrSettings } from "./IItemsHoldr";

*/
private settings;
private readonly settings;
/**
* The ItemValues being stored, keyed by name.
*/
private items;
/**
* A listing of all the String keys for the stored items.
*/
private itemKeys;
/**
* Default attributes for ItemValues.
*/
private defaults;
private readonly defaults;
/**
* A reference to localStorage or a replacement object.
*/
private localStorage;
private readonly localStorage;
/**
* A prefix to store things under in localStorage.
*/
private prefix;
private readonly prefix;
/**
* Whether new items are allowed to be created using setItem.
*/
private allowNewItems;
private readonly allowNewItems;
/**
* Whether this should save changes to localStorage automatically.
* The ItemValues being stored, keyed by name.
*/
private autoSave;
private items;
/**
* A container element containing children for each value's element.
* A listing of all the String keys for the stored items.
*/
private container;
private itemKeys;
/**
* An Array of elements as createElement arguments, outside-to-inside.
* Whether this should save changes to localStorage automatically.
*/
private containersArguments;
private autoSave;
/**
* Any hardcoded changes to element content, such as "INF" for Infinity.
*/
private displayChanges;
/**
* Arguments to be passed to triggered callback Functions.
*/
private callbackArgs;
/**
* Initializes a new instance of the ItemsHoldr class.

@@ -64,2 +48,4 @@ *

/**
* Gets the key at an index.
*
* @param index An index for a key.

@@ -70,2 +56,4 @@ * @returns The indexed key.

/**
* Gets the contained values.
*
* @returns The values contained within, keyed by their keys.

@@ -77,10 +65,16 @@ */

/**
* @returns {Mixed} Default attributes for values.
* Gets the default attributes for values.
*
* @returns Default attributes for values.
*/
getDefaults(): any;
/**
* @returns A reference to localStorage or a replacment object.
* Gets the reference to localStorage or its placeholder.
*
* @returns A reference to localStorage or its placeholder.
*/
getLocalStorage(): Storage;
/**
* Gets whether this should save changes to localStorage automatically.
*
* @returns Whether this should save changes to localStorage automatically.

@@ -90,24 +84,10 @@ */

/**
* @returns The prefix to store thigns under in localStorage.
* Gets the prefix for localStorage keys.
*
* @returns The prefix to store keys under in localStorage.
*/
getPrefix(): string;
/**
* @returns The container HTML element, if it exists.
*/
getContainer(): HTMLElement;
/**
* @returns createElement arguments for HTML containers, outside-to-inside.
*/
getContainersArguments(): [string, any][];
/**
* @returns Any hard-coded changes to element content.
*/
getDisplayChanges(): {
[i: string]: string;
};
/**
* @returns Arguments to be passed to triggered event callbacks.
*/
getCallbackArgs(): any[];
/**
* Gets all keys for all items.
*
* @returns String keys for each of the stored ItemValues.

@@ -117,6 +97,10 @@ */

/**
* @returns All String keys of items.
* Gets all stored keys of items.
*
* @returns All keys of items.
*/
getItemKeys(): string[];
/**
* Gets the value for a known key.
*
* @param key The key for a known value.

@@ -127,3 +111,5 @@ * @returns The known value of a key, assuming that key exists.

/**
* @param key The key for a known value.
* Gets the value for a potentially unknown key.
*
* @param key The key for a potentially unknown value.
* @returns The settings for that particular key.

@@ -133,2 +119,4 @@ */

/**
* Checks whether a key exists.
*
* @param key The key for a potentially known value.

@@ -139,2 +127,4 @@ * @returns Whether there is a value under that key.

/**
* Maps key names to their values.
*
* @returns A mapping of key names to the actual values of all objects being stored.

@@ -214,74 +204,2 @@ */

saveAll(): void;
/**
* Hides the container Element by setting its visibility to hidden.
*/
hideContainer(): void;
/**
* Shows the container Element by setting its visibility to visible.
*/
displayContainer(): void;
/**
* Creates the container Element, which contains a child for each ItemValue that
* specifies hasElement to be true.
*
* @param containers An Array representing the Element to be created and the
* children between it and the contained ItemValues.
* Each contained Object has a String tag name as its
* first member, followed by any number of Objects to apply
* via createElement.
* @returns A newly created Element that can be used as a container.
*/
makeContainer(containers: [string, any][]): HTMLElement;
/**
* @returns Whether displayChanges has an entry for a particular value.
*/
hasDisplayChange(value: string): boolean;
/**
* @returns The displayChanges entry for a particular value.
*/
getDisplayChange(value: string): string;
/**
* Creates a new HTMLElement of the given type. For each Object given as
* arguments after, each member is proliferated onto the element.
*
* @param tag The type of the HTMLElement (by default, "div").
* @param args Any number of Objects to be proliferated onto the
* new HTMLElement.
* @returns A newly created HTMLElement of the given tag.
*/
createElement(tag?: string, ...args: any[]): HTMLElement;
/**
* Proliferates all members of the donor to the recipient recursively, as
* a deep copy.
*
* @param recipient An object receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
proliferate(recipient: any, donor: any, noOverride?: boolean): any;
/**
* Identical to proliferate, but tailored for HTML elements because many
* element attributes don't play nicely with JavaScript Array standards.
* Looking at you, HTMLCollection!
*
* @param recipient An HTMLElement receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
proliferateElement(recipient: any, donor: any, noOverride?: boolean): HTMLElement;
/**
* Creates an Object that can be used to create a new LocalStorage
* replacement, if the JavaScript environment doesn't have one.
*
* @returns {Object}
*/
private createPlaceholderStorage();
/**
* Resets this.items to their default values and resets this.itemKeys.
*/
private resetItemsToDefaults();
}

@@ -1,3 +0,4 @@

define(["require", "exports", "./ItemValue"], function (require, exports, ItemValue_1) {
define(["require", "exports", "./createPlaceholderStorage", "./ItemValue"], function (require, exports, createPlaceholderStorage_1, ItemValue_1) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**

@@ -7,3 +8,3 @@ * A versatile container to store and manipulate values in localStorage, and

*/
var ItemsHoldr = (function () {
var ItemsHoldr = /** @class */ (function () {
/**

@@ -18,3 +19,2 @@ * Initializes a new instance of the ItemsHoldr class.

this.autoSave = !!settings.autoSave;
this.callbackArgs = settings.callbackArgs || [];
this.prefix = settings.prefix || "";

@@ -27,3 +27,3 @@ this.allowNewItems = settings.allowNewItems === undefined

else if (typeof localStorage === "undefined") {
this.localStorage = this.createPlaceholderStorage();
this.localStorage = createPlaceholderStorage_1.createPlaceholderStorage();
}

@@ -34,14 +34,7 @@ else {

this.defaults = settings.defaults || {};
this.displayChanges = settings.displayChanges || {};
this.resetItemsToDefaults();
if (settings.doMakeContainer) {
this.containersArguments = settings.containersArguments || [
["div", {
"className": this.prefix + "_container"
}]
];
this.container = this.makeContainer(this.containersArguments);
}
this.clear();
}
/**
* Gets the key at an index.
*
* @param index An index for a key.

@@ -54,2 +47,4 @@ * @returns The indexed key.

/**
* Gets the contained values.
*
* @returns The values contained within, keyed by their keys.

@@ -61,3 +56,5 @@ */

/**
* @returns {Mixed} Default attributes for values.
* Gets the default attributes for values.
*
* @returns Default attributes for values.
*/

@@ -68,3 +65,5 @@ ItemsHoldr.prototype.getDefaults = function () {

/**
* @returns A reference to localStorage or a replacment object.
* Gets the reference to localStorage or its placeholder.
*
* @returns A reference to localStorage or its placeholder.
*/

@@ -75,2 +74,4 @@ ItemsHoldr.prototype.getLocalStorage = function () {

/**
* Gets whether this should save changes to localStorage automatically.
*
* @returns Whether this should save changes to localStorage automatically.

@@ -82,3 +83,5 @@ */

/**
* @returns The prefix to store thigns under in localStorage.
* Gets the prefix for localStorage keys.
*
* @returns The prefix to store keys under in localStorage.
*/

@@ -89,26 +92,4 @@ ItemsHoldr.prototype.getPrefix = function () {

/**
* @returns The container HTML element, if it exists.
*/
ItemsHoldr.prototype.getContainer = function () {
return this.container;
};
/**
* @returns createElement arguments for HTML containers, outside-to-inside.
*/
ItemsHoldr.prototype.getContainersArguments = function () {
return this.containersArguments;
};
/**
* @returns Any hard-coded changes to element content.
*/
ItemsHoldr.prototype.getDisplayChanges = function () {
return this.displayChanges;
};
/**
* @returns Arguments to be passed to triggered event callbacks.
*/
ItemsHoldr.prototype.getCallbackArgs = function () {
return this.callbackArgs;
};
/**
* Gets all keys for all items.
*
* @returns String keys for each of the stored ItemValues.

@@ -120,3 +101,5 @@ */

/**
* @returns All String keys of items.
* Gets all stored keys of items.
*
* @returns All keys of items.
*/

@@ -127,2 +110,4 @@ ItemsHoldr.prototype.getItemKeys = function () {

/**
* Gets the value for a known key.
*
* @param key The key for a known value.

@@ -136,3 +121,5 @@ * @returns The known value of a key, assuming that key exists.

/**
* @param key The key for a known value.
* Gets the value for a potentially unknown key.
*
* @param key The key for a potentially unknown value.
* @returns The settings for that particular key.

@@ -144,2 +131,4 @@ */

/**
* Checks whether a key exists.
*
* @param key The key for a potentially known value.

@@ -152,2 +141,4 @@ * @returns Whether there is a value under that key.

/**
* Maps key names to their values.
*
* @returns A mapping of key names to the actual values of all objects being stored.

@@ -158,5 +149,3 @@ */

for (var i in this.items) {
if (this.items.hasOwnProperty(i)) {
output[i] = this.items[i].getValue();
}
output[i] = this.items[i].getValue();
}

@@ -188,5 +177,2 @@ return output;

}
if (this.container && this.items[key].getElement() !== undefined) {
this.container.removeChild(this.items[key].getElement());
}
this.itemKeys.splice(this.itemKeys.indexOf(key), 1);

@@ -201,10 +187,12 @@ delete this.items[key];

ItemsHoldr.prototype.clear = function () {
if (this.container) {
for (var i in this.items) {
if (this.items[i].getElement() !== undefined) {
this.container.removeChild(this.items[i].getElement());
}
this.items = {};
this.itemKeys = [];
if (!this.settings.values) {
return;
}
for (var key in this.settings.values) {
if (this.settings.values.hasOwnProperty(key)) {
this.addItem(key, this.settings.values[key]);
}
}
this.resetItemsToDefaults();
};

@@ -232,2 +220,3 @@ /**

this.checkExistence(key);
// tslint:disable-next-line restrict-plus-operands
var value = this.items[key].getValue() + amount;

@@ -296,226 +285,5 @@ this.items[key].setValue(value);

for (var key in this.items) {
if (this.items.hasOwnProperty(key)) {
this.items[key].updateLocalStorage(true);
}
this.items[key].updateLocalStorage(true);
}
};
/**
* Hides the container Element by setting its visibility to hidden.
*/
ItemsHoldr.prototype.hideContainer = function () {
this.container.style.visibility = "hidden";
};
/**
* Shows the container Element by setting its visibility to visible.
*/
ItemsHoldr.prototype.displayContainer = function () {
this.container.style.visibility = "visible";
};
/**
* Creates the container Element, which contains a child for each ItemValue that
* specifies hasElement to be true.
*
* @param containers An Array representing the Element to be created and the
* children between it and the contained ItemValues.
* Each contained Object has a String tag name as its
* first member, followed by any number of Objects to apply
* via createElement.
* @returns A newly created Element that can be used as a container.
*/
ItemsHoldr.prototype.makeContainer = function (containers) {
var output = this.createElement.apply(this, containers[0]);
var lastElement = output;
for (var i = 1; i < containers.length; i += 1) {
var child = this.createElement.apply(this, containers[i]);
lastElement.appendChild(child);
lastElement = child;
}
for (var key in this.items) {
if (this.items[key].getElement() !== undefined) {
lastElement.appendChild(this.items[key].getElement());
}
}
return output;
};
/**
* @returns Whether displayChanges has an entry for a particular value.
*/
ItemsHoldr.prototype.hasDisplayChange = function (value) {
return this.displayChanges.hasOwnProperty(value);
};
/**
* @returns The displayChanges entry for a particular value.
*/
ItemsHoldr.prototype.getDisplayChange = function (value) {
return this.displayChanges[value];
};
/**
* Creates a new HTMLElement of the given type. For each Object given as
* arguments after, each member is proliferated onto the element.
*
* @param tag The type of the HTMLElement (by default, "div").
* @param args Any number of Objects to be proliferated onto the
* new HTMLElement.
* @returns A newly created HTMLElement of the given tag.
*/
ItemsHoldr.prototype.createElement = function (tag) {
if (tag === void 0) { tag = "div"; }
var args = [];
for (var _i = 1; _i < arguments.length; _i++) {
args[_i - 1] = arguments[_i];
}
var element = document.createElement(tag);
// For each provided object, add those settings to the element
for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {
var arg = args_1[_a];
this.proliferateElement(element, arg);
}
return element;
};
/**
* Proliferates all members of the donor to the recipient recursively, as
* a deep copy.
*
* @param recipient An object receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
ItemsHoldr.prototype.proliferate = function (recipient, donor, noOverride) {
// For each attribute of the donor:
for (var i in donor) {
if (!donor.hasOwnProperty(i)) {
continue;
}
// If noOverride, don't override already existing properties
if (noOverride && recipient.hasOwnProperty(i)) {
continue;
}
// If it's an object, recurse on a new version of it
var setting = donor[i];
if (typeof setting === "object") {
if (!recipient.hasOwnProperty(i)) {
recipient[i] = new setting.constructor();
}
this.proliferate(recipient[i], setting, noOverride);
}
else {
// Regular primitives are easy to copy otherwise
recipient[i] = setting;
}
}
return recipient;
};
/**
* Identical to proliferate, but tailored for HTML elements because many
* element attributes don't play nicely with JavaScript Array standards.
* Looking at you, HTMLCollection!
*
* @param recipient An HTMLElement receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
ItemsHoldr.prototype.proliferateElement = function (recipient, donor, noOverride) {
// For each attribute of the donor:
for (var i in donor) {
if (!donor.hasOwnProperty(i)) {
continue;
}
// If noOverride, don't override already existing properties
if (noOverride && recipient.hasOwnProperty(i)) {
continue;
}
var setting = donor[i];
// Special cases for HTML elements
switch (i) {
// Children and options: just append all of them directly
case "children":
case "options":
if (typeof setting !== "undefined") {
for (var _i = 0, setting_1 = setting; _i < setting_1.length; _i++) {
var member = setting_1[_i];
recipient.appendChild(member);
}
}
break;
// Style: proliferate (instead of making a new Object)
case "style":
this.proliferate(recipient[i], setting);
break;
// By default, use the normal proliferate logic
default:
// If it's an object, recurse on a new version of it
if (typeof setting === "object") {
if (!recipient.hasOwnProperty(i)) {
recipient[i] = new setting.constructor();
}
this.proliferate(recipient[i], setting, noOverride);
}
else {
// Regular primitives are easy to copy otherwise
recipient[i] = setting;
}
break;
}
}
return recipient;
};
/**
* Creates an Object that can be used to create a new LocalStorage
* replacement, if the JavaScript environment doesn't have one.
*
* @returns {Object}
*/
ItemsHoldr.prototype.createPlaceholderStorage = function () {
var _this = this;
var output = {
keys: [],
getItem: function (key) {
return _this.localStorage[key];
},
setItem: function (key, value) {
_this.localStorage[key] = value;
},
clear: function () {
for (var i in _this) {
if (_this.hasOwnProperty(i)) {
delete _this[i];
}
}
},
removeItem: function (key) {
delete _this[key];
},
key: function (index) {
return this.keys[index];
}
};
Object.defineProperties(output, {
length: {
get: function () { return output.keys.length; }
},
remainingSpace: {
get: function () { return 9001; }
}
});
return output;
};
/**
* Resets this.items to their default values and resets this.itemKeys.
*/
ItemsHoldr.prototype.resetItemsToDefaults = function () {
this.items = {};
this.itemKeys = [];
if (!this.settings.values) {
return;
}
for (var key in this.settings.values) {
if (this.settings.values.hasOwnProperty(key)) {
this.addItem(key, this.settings.values[key]);
}
}
};
return ItemsHoldr;

@@ -525,3 +293,1 @@ }());

});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["ItemsHoldr.ts"],"names":[],"mappings":"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","file":"ItemsHoldr.js","sourcesContent":["import { IItems, IItemsHoldr, IItemsHoldrSettings } from \"./IItemsHoldr\";\r\nimport { IItemValue, IItemValueDefaults } from \"./IItemValue\";\r\nimport { ItemValue } from \"./ItemValue\";\r\n\r\n/**\r\n * A versatile container to store and manipulate values in localStorage, and\r\n * optionally keep an updated HTML container showing these values. \r\n */\r\nexport class ItemsHoldr implements IItemsHoldr {\r\n    /**\r\n     * Settings used to construct this ItemsHoldr.\r\n     */\r\n    private settings: IItemsHoldrSettings;\r\n\r\n    /**\r\n     * The ItemValues being stored, keyed by name.\r\n     */\r\n    private items: IItems;\r\n\r\n    /**\r\n     * A listing of all the String keys for the stored items.\r\n     */\r\n    private itemKeys: string[];\r\n\r\n    /**\r\n     * Default attributes for ItemValues.\r\n     */\r\n    private defaults: IItemValueDefaults;\r\n\r\n    /**\r\n     * A reference to localStorage or a replacement object.\r\n     */\r\n    private localStorage: Storage;\r\n\r\n    /**\r\n     * A prefix to store things under in localStorage.\r\n     */\r\n    private prefix: string;\r\n\r\n    /**\r\n     * Whether new items are allowed to be created using setItem.\r\n     */\r\n    private allowNewItems: boolean;\r\n\r\n    /**\r\n     * Whether this should save changes to localStorage automatically.\r\n     */\r\n    private autoSave: boolean;\r\n\r\n    /**\r\n     * A container element containing children for each value's element.\r\n     */\r\n    private container: HTMLElement;\r\n\r\n    /**\r\n     * An Array of elements as createElement arguments, outside-to-inside.\r\n     */\r\n    private containersArguments: [string, any][];\r\n\r\n    /**\r\n     * Any hardcoded changes to element content, such as \"INF\" for Infinity.\r\n     */\r\n    private displayChanges: { [i: string]: string };\r\n\r\n    /**\r\n     * Arguments to be passed to triggered callback Functions.\r\n     */\r\n    private callbackArgs: any[];\r\n\r\n    /**\r\n     * Initializes a new instance of the ItemsHoldr class.\r\n     * \r\n     * @param settings   Any optional custom settings.\r\n     */\r\n    constructor(settings: IItemsHoldrSettings = {}) {\r\n        this.settings = settings;\r\n        this.autoSave = !!settings.autoSave;\r\n        this.callbackArgs = settings.callbackArgs || [];\r\n        this.prefix = settings.prefix || \"\";\r\n\r\n        this.allowNewItems = settings.allowNewItems === undefined\r\n            ? true : settings.allowNewItems;\r\n\r\n        if (settings.localStorage) {\r\n            this.localStorage = settings.localStorage;\r\n        } else if (typeof localStorage === \"undefined\") {\r\n            this.localStorage = this.createPlaceholderStorage();\r\n        } else {\r\n            this.localStorage = localStorage;\r\n        }\r\n\r\n        this.defaults = settings.defaults || {};\r\n        this.displayChanges = settings.displayChanges || {};\r\n\r\n        this.resetItemsToDefaults();\r\n\r\n        if (settings.doMakeContainer) {\r\n            this.containersArguments = settings.containersArguments || [\r\n                [\"div\", {\r\n                    \"className\": this.prefix + \"_container\"\r\n                }]\r\n            ];\r\n            this.container = this.makeContainer(this.containersArguments);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @param index   An index for a key.\r\n     * @returns The indexed key.\r\n     */\r\n    public key(index: number): string {\r\n        return this.itemKeys[index];\r\n    }\r\n\r\n    /**\r\n     * @returns The values contained within, keyed by their keys.\r\n     */\r\n    public getValues(): { [i: string]: IItemValue } {\r\n        return this.items;\r\n    }\r\n\r\n    /**\r\n     * @returns {Mixed} Default attributes for values.\r\n     */\r\n    public getDefaults(): any {\r\n        return this.defaults;\r\n    }\r\n\r\n    /**\r\n     * @returns A reference to localStorage or a replacment object.\r\n     */\r\n    public getLocalStorage(): Storage {\r\n        return this.localStorage;\r\n    }\r\n\r\n    /**\r\n     * @returns Whether this should save changes to localStorage automatically.\r\n     */\r\n    public getAutoSave(): boolean {\r\n        return this.autoSave;\r\n    }\r\n\r\n    /**\r\n     * @returns The prefix to store thigns under in localStorage.\r\n     */\r\n    public getPrefix(): string {\r\n        return this.prefix;\r\n    }\r\n\r\n    /**\r\n     * @returns The container HTML element, if it exists.\r\n     */\r\n    public getContainer(): HTMLElement {\r\n        return this.container;\r\n    }\r\n\r\n    /**\r\n     * @returns createElement arguments for HTML containers, outside-to-inside.\r\n     */\r\n    public getContainersArguments(): [string, any][] {\r\n        return this.containersArguments;\r\n    }\r\n\r\n    /**\r\n     * @returns Any hard-coded changes to element content.\r\n     */\r\n    public getDisplayChanges(): { [i: string]: string } {\r\n        return this.displayChanges;\r\n    }\r\n\r\n    /**\r\n     * @returns Arguments to be passed to triggered event callbacks.\r\n     */\r\n    public getCallbackArgs(): any[] {\r\n        return this.callbackArgs;\r\n    }\r\n\r\n    /**\r\n     * @returns String keys for each of the stored ItemValues.\r\n     */\r\n    public getKeys(): string[] {\r\n        return Object.keys(this.items);\r\n    }\r\n\r\n    /**\r\n     * @returns All String keys of items.\r\n     */\r\n    public getItemKeys(): string[] {\r\n        return this.itemKeys;\r\n    }\r\n\r\n    /**\r\n     * @param key   The key for a known value.\r\n     * @returns The known value of a key, assuming that key exists.\r\n     */\r\n    public getItem(key: string): any {\r\n        this.checkExistence(key);\r\n\r\n        return this.items[key].getValue();\r\n    }\r\n\r\n    /**\r\n     * @param key   The key for a known value.\r\n     * @returns The settings for that particular key.\r\n     */\r\n    public getObject(key: string): any {\r\n        return this.items[key];\r\n    }\r\n\r\n    /**\r\n     * @param key   The key for a potentially known value.\r\n     * @returns Whether there is a value under that key.\r\n     */\r\n    public hasKey(key: string): boolean {\r\n        return this.items.hasOwnProperty(key);\r\n    }\r\n\r\n    /**\r\n     * @returns A mapping of key names to the actual values of all objects being stored.\r\n     */\r\n    public exportItems(): any {\r\n        const output: any = {};\r\n\r\n        for (let i in this.items) {\r\n            if (this.items.hasOwnProperty(i)) {\r\n                output[i] = this.items[i].getValue();\r\n            }\r\n        }\r\n\r\n        return output;\r\n    }\r\n\r\n    /**\r\n     * Adds a new key & value pair to by linking to a newly created ItemValue.\r\n     * \r\n     * @param key   The key to reference by new ItemValue by.\r\n     * @param settings   The settings for the new ItemValue.\r\n     * @returns The newly created ItemValue.\r\n     */\r\n    public addItem(key: string, settings: any = {}): IItemValue {\r\n        this.items[key] = new ItemValue(this, key, settings);\r\n        this.itemKeys.push(key);\r\n        return this.items[key];\r\n    }\r\n\r\n    /**\r\n     * Clears a value from the listing, and removes its element from the\r\n     * container (if they both exist).\r\n     * \r\n     * @param key   The key of the element to remove.\r\n     */\r\n    public removeItem(key: string): void {\r\n        if (!this.items.hasOwnProperty(key)) {\r\n            return;\r\n        }\r\n\r\n        if (this.container && this.items[key].getElement() !== undefined) {\r\n            this.container.removeChild(this.items[key].getElement());\r\n        }\r\n\r\n        this.itemKeys.splice(this.itemKeys.indexOf(key), 1);\r\n\r\n        delete this.items[key];\r\n        delete this.localStorage[this.prefix + key];\r\n    }\r\n\r\n    /**\r\n     * Completely clears all values from the ItemsHoldr, removing their\r\n     * elements from the container (if they both exist) as well.\r\n     */\r\n    public clear(): void {\r\n        if (this.container) {\r\n            for (let i in this.items) {\r\n                if (this.items[i].getElement() !== undefined) {\r\n                    this.container.removeChild(this.items[i].getElement());\r\n                }\r\n            }\r\n        }\r\n\r\n        this.resetItemsToDefaults();\r\n    }\r\n\r\n    /**\r\n     * Sets the value for the ItemValue under the given key, then updates the ItemValue\r\n     * (including the ItemValue's element and localStorage, if needed).\r\n     * \r\n     * @param key   The key of the ItemValue.\r\n     * @param value   The new value for the ItemValue.\r\n     */\r\n    public setItem(key: string, value: any): void {\r\n        this.checkExistence(key);\r\n\r\n        this.items[key].setValue(value);\r\n    }\r\n\r\n    /**\r\n     * Increases the value for the ItemValue under the given key, via addition for\r\n     * Numbers or concatenation for Strings.\r\n     * \r\n     * @param key   The key of the ItemValue.\r\n     * @param amount   The amount to increase by (by default, 1).\r\n     */\r\n    public increase(key: string, amount: number | string = 1): void {\r\n        this.checkExistence(key);\r\n\r\n        const value: number | string = this.items[key].getValue() + amount;\r\n\r\n        this.items[key].setValue(value);\r\n    }\r\n\r\n    /**\r\n     * Decreases the value for the ItemValue under the given key, via addition for\r\n     * Numbers or concatenation for Strings.\r\n     * \r\n     * @param key   The key of the ItemValue.\r\n     * @param amount   The amount to decrease by (by default, 1).\r\n     */\r\n    public decrease(key: string, amount: number = 1): void {\r\n        this.checkExistence(key);\r\n\r\n        let value: number = this.items[key].getValue() - amount;\r\n\r\n        this.items[key].setValue(value);\r\n    }\r\n\r\n    /**\r\n     * Toggles whether a value is true or false.\r\n     * \r\n     * @param key   The key of the ItemValue.\r\n     */\r\n    public toggle(key: string): void {\r\n        this.checkExistence(key);\r\n\r\n        const value: any = this.items[key].getValue() ? false : true;\r\n\r\n        this.items[key].setValue(value);\r\n    }\r\n\r\n    /**\r\n     * Toggles this.autoSave.\r\n     */\r\n    public toggleAutoSave(): void {\r\n        this.autoSave = !this.autoSave;\r\n    }\r\n\r\n    /**\r\n     * Ensures a key exists in values. If it doesn't, and new values are\r\n     * allowed, it creates it; otherwise, it throws an Error.\r\n     * \r\n     * @param key\r\n     */\r\n    public checkExistence(key: string): void {\r\n        if (this.items.hasOwnProperty(key)) {\r\n            return;\r\n        }\r\n\r\n        if (!this.allowNewItems) {\r\n            throw new Error(\"Unknown key given to ItemsHoldr: '\" + key + \"'.\");\r\n        }\r\n\r\n        this.addItem(key);\r\n    }\r\n\r\n    /**\r\n     * Manually saves an item's value to localStorage, ignoring the autoSave flag.\r\n     * \r\n     * @param key   The key of the item to save.\r\n     */\r\n    public saveItem(key: string): void {\r\n        if (!this.items.hasOwnProperty(key)) {\r\n            throw new Error(\"Unknown key given to ItemsHoldr: '\" + key + \"'.\");\r\n        }\r\n\r\n        this.items[key].updateLocalStorage(true);\r\n    }\r\n\r\n    /**\r\n     * Manually saves all values to localStorage, ignoring the autoSave flag. \r\n     */\r\n    public saveAll(): void {\r\n        for (let key in this.items) {\r\n            if (this.items.hasOwnProperty(key)) {\r\n                this.items[key].updateLocalStorage(true);\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Hides the container Element by setting its visibility to hidden.\r\n     */\r\n    public hideContainer(): void {\r\n        this.container.style.visibility = \"hidden\";\r\n    }\r\n\r\n    /**\r\n     * Shows the container Element by setting its visibility to visible.\r\n     */\r\n    public displayContainer(): void {\r\n        this.container.style.visibility = \"visible\";\r\n    }\r\n\r\n    /**\r\n     * Creates the container Element, which contains a child for each ItemValue that\r\n     * specifies hasElement to be true.\r\n     * \r\n     * @param containers   An Array representing the Element to be created and the\r\n     *                     children between it and the contained ItemValues. \r\n     *                     Each contained Object has a String tag name as its \r\n     *                     first member, followed by any number of Objects to apply \r\n     *                     via createElement.\r\n     * @returns A newly created Element that can be used as a container.\r\n     */\r\n    public makeContainer(containers: [string, any][]): HTMLElement {\r\n        const output: HTMLElement = this.createElement.apply(this, containers[0]);\r\n        let lastElement: HTMLElement = output;\r\n\r\n        for (let i: number = 1; i < containers.length; i += 1) {\r\n            const child: HTMLElement = this.createElement.apply(this, containers[i]);\r\n            lastElement.appendChild(child);\r\n            lastElement = child;\r\n        }\r\n\r\n        for (let key in this.items) {\r\n            if (this.items[key].getElement() !== undefined) {\r\n                lastElement.appendChild(this.items[key].getElement());\r\n            }\r\n        }\r\n\r\n        return output;\r\n    }\r\n\r\n    /**\r\n     * @returns Whether displayChanges has an entry for a particular value.\r\n     */\r\n    public hasDisplayChange(value: string): boolean {\r\n        return this.displayChanges.hasOwnProperty(value);\r\n    }\r\n\r\n    /**\r\n     * @returns The displayChanges entry for a particular value.\r\n     */\r\n    public getDisplayChange(value: string): string {\r\n        return this.displayChanges[value];\r\n    }\r\n\r\n    /**\r\n     * Creates a new HTMLElement of the given type. For each Object given as\r\n     * arguments after, each member is proliferated onto the element.\r\n     * \r\n     * @param tag   The type of the HTMLElement (by default, \"div\").\r\n     * @param args   Any number of Objects to be proliferated onto the \r\n     *               new HTMLElement.\r\n     * @returns A newly created HTMLElement of the given tag.\r\n     */\r\n    public createElement(tag: string = \"div\", ...args: any[]): HTMLElement {\r\n        const element: HTMLElement = document.createElement(tag);\r\n\r\n        // For each provided object, add those settings to the element\r\n        for (const arg of args) {\r\n            this.proliferateElement(element, arg);\r\n        }\r\n\r\n        return element;\r\n    }\r\n\r\n    /**\r\n     * Proliferates all members of the donor to the recipient recursively, as\r\n     * a deep copy.\r\n     * \r\n     * @param recipient   An object receiving the donor's members.\r\n     * @param donor   An object whose members are copied to recipient.\r\n     * @param noOverride   If recipient properties may be overriden (by \r\n     *                     default, false).\r\n     * @returns The recipient, which should have the donor proliferated onto it.\r\n     */\r\n    public proliferate(recipient: any, donor: any, noOverride?: boolean): any {\r\n        // For each attribute of the donor:\r\n        for (let i in donor) {\r\n            if (!donor.hasOwnProperty(i)) {\r\n                continue;\r\n            }\r\n\r\n            // If noOverride, don't override already existing properties\r\n            if (noOverride && recipient.hasOwnProperty(i)) {\r\n                continue;\r\n            }\r\n\r\n            // If it's an object, recurse on a new version of it\r\n            const setting: any = donor[i];\r\n            if (typeof setting === \"object\") {\r\n                if (!recipient.hasOwnProperty(i)) {\r\n                    recipient[i] = new setting.constructor();\r\n                }\r\n                this.proliferate(recipient[i], setting, noOverride);\r\n            } else {\r\n                // Regular primitives are easy to copy otherwise\r\n                recipient[i] = setting;\r\n            }\r\n        }\r\n\r\n        return recipient;\r\n    }\r\n\r\n    /**\r\n     * Identical to proliferate, but tailored for HTML elements because many\r\n     * element attributes don't play nicely with JavaScript Array standards. \r\n     * Looking at you, HTMLCollection!\r\n     * \r\n     * @param recipient   An HTMLElement receiving the donor's members.\r\n     * @param donor   An object whose members are copied to recipient.\r\n     * @param noOverride   If recipient properties may be overriden (by \r\n     *                     default, false).\r\n     * @returns The recipient, which should have the donor proliferated onto it.\r\n     */\r\n    public proliferateElement(recipient: any, donor: any, noOverride?: boolean): HTMLElement {\r\n        // For each attribute of the donor:\r\n        for (let i in donor) {\r\n            if (!donor.hasOwnProperty(i)) {\r\n                continue;\r\n            }\r\n\r\n            // If noOverride, don't override already existing properties\r\n            if (noOverride && recipient.hasOwnProperty(i)) {\r\n                continue;\r\n            }\r\n\r\n            const setting: any = donor[i];\r\n\r\n            // Special cases for HTML elements\r\n            switch (i) {\r\n                // Children and options: just append all of them directly\r\n                case \"children\":\r\n                case \"options\":\r\n                    if (typeof setting !== \"undefined\") {\r\n                        for (const member of setting) {\r\n                            recipient.appendChild(member);\r\n                        }\r\n                    }\r\n                    break;\r\n\r\n                // Style: proliferate (instead of making a new Object)\r\n                case \"style\":\r\n                    this.proliferate(recipient[i], setting);\r\n                    break;\r\n\r\n                // By default, use the normal proliferate logic\r\n                default:\r\n                    // If it's an object, recurse on a new version of it\r\n                    if (typeof setting === \"object\") {\r\n                        if (!recipient.hasOwnProperty(i)) {\r\n                            recipient[i] = new setting.constructor();\r\n                        }\r\n                        this.proliferate(recipient[i], setting, noOverride);\r\n                    } else {\r\n                        // Regular primitives are easy to copy otherwise\r\n                        recipient[i] = setting;\r\n                    }\r\n                    break;\r\n            }\r\n        }\r\n\r\n        return recipient;\r\n    }\r\n\r\n    /**\r\n     * Creates an Object that can be used to create a new LocalStorage\r\n     * replacement, if the JavaScript environment doesn't have one.\r\n     * \r\n     * @returns {Object}\r\n     */\r\n    private createPlaceholderStorage(): Storage {\r\n        const output: any = {\r\n            keys: [],\r\n            getItem: (key: string): any => {\r\n                return this.localStorage[key];\r\n            },\r\n            setItem: (key: string, value: string): void => {\r\n                this.localStorage[key] = value;\r\n            },\r\n            clear: (): void => {\r\n                for (let i in this) {\r\n                    if (this.hasOwnProperty(i)) {\r\n                        delete (this as any)[i];\r\n                    }\r\n                }\r\n            },\r\n            removeItem: (key: string): void => {\r\n                delete (this as any)[key];\r\n            },\r\n            key: function (this: any, index: number): string {\r\n                return this.keys[index];\r\n            }\r\n        };\r\n\r\n        Object.defineProperties(output, {\r\n            length: {\r\n                get: (): number => output.keys.length\r\n            },\r\n            remainingSpace: {\r\n                get: (): number => 9001\r\n            }\r\n        });\r\n\r\n        return output;\r\n    }\r\n\r\n    /**\r\n     * Resets this.items to their default values and resets this.itemKeys.\r\n     */\r\n    private resetItemsToDefaults(): void {\r\n        this.items = {};\r\n        this.itemKeys = [];\r\n\r\n        if (!this.settings.values) {\r\n            return;\r\n        }\r\n\r\n        for (let key in this.settings.values) {\r\n            if (this.settings.values.hasOwnProperty(key)) {\r\n                this.addItem(key, this.settings.values[key]);\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}

@@ -0,1 +1,2 @@

import { createPlaceholderStorage } from "./createPlaceholderStorage";
import { IItems, IItemsHoldr, IItemsHoldrSettings } from "./IItemsHoldr";

@@ -7,3 +8,3 @@ import { IItemValue, IItemValueDefaults } from "./IItemValue";

* A versatile container to store and manipulate values in localStorage, and
* optionally keep an updated HTML container showing these values.
* optionally keep an updated HTML container showing these values.
*/

@@ -14,18 +15,8 @@ export class ItemsHoldr implements IItemsHoldr {

*/
private settings: IItemsHoldrSettings;
private readonly settings: IItemsHoldrSettings;
/**
* The ItemValues being stored, keyed by name.
*/
private items: IItems;
/**
* A listing of all the String keys for the stored items.
*/
private itemKeys: string[];
/**
* Default attributes for ItemValues.
*/
private defaults: IItemValueDefaults;
private readonly defaults: IItemValueDefaults;

@@ -35,3 +26,3 @@ /**

*/
private localStorage: Storage;
private readonly localStorage: Storage;

@@ -41,3 +32,3 @@ /**

*/
private prefix: string;
private readonly prefix: string;

@@ -47,38 +38,27 @@ /**

*/
private allowNewItems: boolean;
private readonly allowNewItems: boolean;
/**
* Whether this should save changes to localStorage automatically.
* The ItemValues being stored, keyed by name.
*/
private autoSave: boolean;
private items: IItems;
/**
* A container element containing children for each value's element.
* A listing of all the String keys for the stored items.
*/
private container: HTMLElement;
private itemKeys: string[];
/**
* An Array of elements as createElement arguments, outside-to-inside.
* Whether this should save changes to localStorage automatically.
*/
private containersArguments: [string, any][];
private autoSave: boolean;
/**
* Any hardcoded changes to element content, such as "INF" for Infinity.
*/
private displayChanges: { [i: string]: string };
/**
* Arguments to be passed to triggered callback Functions.
*/
private callbackArgs: any[];
/**
* Initializes a new instance of the ItemsHoldr class.
*
*
* @param settings Any optional custom settings.
*/
constructor(settings: IItemsHoldrSettings = {}) {
public constructor(settings: IItemsHoldrSettings = {}) {
this.settings = settings;
this.autoSave = !!settings.autoSave;
this.callbackArgs = settings.callbackArgs || [];
this.prefix = settings.prefix || "";

@@ -91,4 +71,4 @@

this.localStorage = settings.localStorage;
} else if (typeof localStorage === "undefined") {
this.localStorage = this.createPlaceholderStorage();
} else if (typeof localStorage === "undefined") { // tslint:disable-line strict-type-predicates
this.localStorage = createPlaceholderStorage();
} else {

@@ -99,17 +79,9 @@ this.localStorage = localStorage;

this.defaults = settings.defaults || {};
this.displayChanges = settings.displayChanges || {};
this.resetItemsToDefaults();
if (settings.doMakeContainer) {
this.containersArguments = settings.containersArguments || [
["div", {
"className": this.prefix + "_container"
}]
];
this.container = this.makeContainer(this.containersArguments);
}
this.clear();
}
/**
* Gets the key at an index.
*
* @param index An index for a key.

@@ -123,2 +95,4 @@ * @returns The indexed key.

/**
* Gets the contained values.
*
* @returns The values contained within, keyed by their keys.

@@ -131,3 +105,5 @@ */

/**
* @returns {Mixed} Default attributes for values.
* Gets the default attributes for values.
*
* @returns Default attributes for values.
*/

@@ -139,3 +115,5 @@ public getDefaults(): any {

/**
* @returns A reference to localStorage or a replacment object.
* Gets the reference to localStorage or its placeholder.
*
* @returns A reference to localStorage or its placeholder.
*/

@@ -147,2 +125,4 @@ public getLocalStorage(): Storage {

/**
* Gets whether this should save changes to localStorage automatically.
*
* @returns Whether this should save changes to localStorage automatically.

@@ -155,3 +135,5 @@ */

/**
* @returns The prefix to store thigns under in localStorage.
* Gets the prefix for localStorage keys.
*
* @returns The prefix to store keys under in localStorage.
*/

@@ -163,30 +145,4 @@ public getPrefix(): string {

/**
* @returns The container HTML element, if it exists.
*/
public getContainer(): HTMLElement {
return this.container;
}
/**
* @returns createElement arguments for HTML containers, outside-to-inside.
*/
public getContainersArguments(): [string, any][] {
return this.containersArguments;
}
/**
* @returns Any hard-coded changes to element content.
*/
public getDisplayChanges(): { [i: string]: string } {
return this.displayChanges;
}
/**
* @returns Arguments to be passed to triggered event callbacks.
*/
public getCallbackArgs(): any[] {
return this.callbackArgs;
}
/**
* Gets all keys for all items.
*
* @returns String keys for each of the stored ItemValues.

@@ -199,3 +155,5 @@ */

/**
* @returns All String keys of items.
* Gets all stored keys of items.
*
* @returns All keys of items.
*/

@@ -207,2 +165,4 @@ public getItemKeys(): string[] {

/**
* Gets the value for a known key.
*
* @param key The key for a known value.

@@ -218,3 +178,5 @@ * @returns The known value of a key, assuming that key exists.

/**
* @param key The key for a known value.
* Gets the value for a potentially unknown key.
*
* @param key The key for a potentially unknown value.
* @returns The settings for that particular key.

@@ -227,2 +189,4 @@ */

/**
* Checks whether a key exists.
*
* @param key The key for a potentially known value.

@@ -236,2 +200,4 @@ * @returns Whether there is a value under that key.

/**
* Maps key names to their values.
*
* @returns A mapping of key names to the actual values of all objects being stored.

@@ -242,6 +208,4 @@ */

for (let i in this.items) {
if (this.items.hasOwnProperty(i)) {
output[i] = this.items[i].getValue();
}
for (const i in this.items) {
output[i] = this.items[i].getValue();
}

@@ -254,3 +218,3 @@

* Adds a new key & value pair to by linking to a newly created ItemValue.
*
*
* @param key The key to reference by new ItemValue by.

@@ -269,3 +233,3 @@ * @param settings The settings for the new ItemValue.

* container (if they both exist).
*
*
* @param key The key of the element to remove.

@@ -278,6 +242,2 @@ */

if (this.container && this.items[key].getElement() !== undefined) {
this.container.removeChild(this.items[key].getElement());
}
this.itemKeys.splice(this.itemKeys.indexOf(key), 1);

@@ -294,11 +254,14 @@

public clear(): void {
if (this.container) {
for (let i in this.items) {
if (this.items[i].getElement() !== undefined) {
this.container.removeChild(this.items[i].getElement());
}
this.items = {};
this.itemKeys = [];
if (!this.settings.values) {
return;
}
for (const key in this.settings.values) {
if (this.settings.values.hasOwnProperty(key)) {
this.addItem(key, this.settings.values[key]);
}
}
this.resetItemsToDefaults();
}

@@ -309,3 +272,3 @@

* (including the ItemValue's element and localStorage, if needed).
*
*
* @param key The key of the ItemValue.

@@ -323,3 +286,3 @@ * @param value The new value for the ItemValue.

* Numbers or concatenation for Strings.
*
*
* @param key The key of the ItemValue.

@@ -331,2 +294,3 @@ * @param amount The amount to increase by (by default, 1).

// tslint:disable-next-line restrict-plus-operands
const value: number | string = this.items[key].getValue() + amount;

@@ -340,3 +304,3 @@

* Numbers or concatenation for Strings.
*
*
* @param key The key of the ItemValue.

@@ -348,3 +312,3 @@ * @param amount The amount to decrease by (by default, 1).

let value: number = this.items[key].getValue() - amount;
const value: number = this.items[key].getValue() - amount;

@@ -356,3 +320,3 @@ this.items[key].setValue(value);

* Toggles whether a value is true or false.
*
*
* @param key The key of the ItemValue.

@@ -378,3 +342,3 @@ */

* allowed, it creates it; otherwise, it throws an Error.
*
*
* @param key

@@ -388,3 +352,3 @@ */

if (!this.allowNewItems) {
throw new Error("Unknown key given to ItemsHoldr: '" + key + "'.");
throw new Error(`Unknown key given to ItemsHoldr: '${key}'.`);
}

@@ -397,3 +361,3 @@

* Manually saves an item's value to localStorage, ignoring the autoSave flag.
*
*
* @param key The key of the item to save.

@@ -403,3 +367,3 @@ */

if (!this.items.hasOwnProperty(key)) {
throw new Error("Unknown key given to ItemsHoldr: '" + key + "'.");
throw new Error(`Unknown key given to ItemsHoldr: '${key}'.`);
}

@@ -411,248 +375,9 @@

/**
* Manually saves all values to localStorage, ignoring the autoSave flag.
* Manually saves all values to localStorage, ignoring the autoSave flag.
*/
public saveAll(): void {
for (let key in this.items) {
if (this.items.hasOwnProperty(key)) {
this.items[key].updateLocalStorage(true);
}
for (const key in this.items) {
this.items[key].updateLocalStorage(true);
}
}
/**
* Hides the container Element by setting its visibility to hidden.
*/
public hideContainer(): void {
this.container.style.visibility = "hidden";
}
/**
* Shows the container Element by setting its visibility to visible.
*/
public displayContainer(): void {
this.container.style.visibility = "visible";
}
/**
* Creates the container Element, which contains a child for each ItemValue that
* specifies hasElement to be true.
*
* @param containers An Array representing the Element to be created and the
* children between it and the contained ItemValues.
* Each contained Object has a String tag name as its
* first member, followed by any number of Objects to apply
* via createElement.
* @returns A newly created Element that can be used as a container.
*/
public makeContainer(containers: [string, any][]): HTMLElement {
const output: HTMLElement = this.createElement.apply(this, containers[0]);
let lastElement: HTMLElement = output;
for (let i: number = 1; i < containers.length; i += 1) {
const child: HTMLElement = this.createElement.apply(this, containers[i]);
lastElement.appendChild(child);
lastElement = child;
}
for (let key in this.items) {
if (this.items[key].getElement() !== undefined) {
lastElement.appendChild(this.items[key].getElement());
}
}
return output;
}
/**
* @returns Whether displayChanges has an entry for a particular value.
*/
public hasDisplayChange(value: string): boolean {
return this.displayChanges.hasOwnProperty(value);
}
/**
* @returns The displayChanges entry for a particular value.
*/
public getDisplayChange(value: string): string {
return this.displayChanges[value];
}
/**
* Creates a new HTMLElement of the given type. For each Object given as
* arguments after, each member is proliferated onto the element.
*
* @param tag The type of the HTMLElement (by default, "div").
* @param args Any number of Objects to be proliferated onto the
* new HTMLElement.
* @returns A newly created HTMLElement of the given tag.
*/
public createElement(tag: string = "div", ...args: any[]): HTMLElement {
const element: HTMLElement = document.createElement(tag);
// For each provided object, add those settings to the element
for (const arg of args) {
this.proliferateElement(element, arg);
}
return element;
}
/**
* Proliferates all members of the donor to the recipient recursively, as
* a deep copy.
*
* @param recipient An object receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
public proliferate(recipient: any, donor: any, noOverride?: boolean): any {
// For each attribute of the donor:
for (let i in donor) {
if (!donor.hasOwnProperty(i)) {
continue;
}
// If noOverride, don't override already existing properties
if (noOverride && recipient.hasOwnProperty(i)) {
continue;
}
// If it's an object, recurse on a new version of it
const setting: any = donor[i];
if (typeof setting === "object") {
if (!recipient.hasOwnProperty(i)) {
recipient[i] = new setting.constructor();
}
this.proliferate(recipient[i], setting, noOverride);
} else {
// Regular primitives are easy to copy otherwise
recipient[i] = setting;
}
}
return recipient;
}
/**
* Identical to proliferate, but tailored for HTML elements because many
* element attributes don't play nicely with JavaScript Array standards.
* Looking at you, HTMLCollection!
*
* @param recipient An HTMLElement receiving the donor's members.
* @param donor An object whose members are copied to recipient.
* @param noOverride If recipient properties may be overriden (by
* default, false).
* @returns The recipient, which should have the donor proliferated onto it.
*/
public proliferateElement(recipient: any, donor: any, noOverride?: boolean): HTMLElement {
// For each attribute of the donor:
for (let i in donor) {
if (!donor.hasOwnProperty(i)) {
continue;
}
// If noOverride, don't override already existing properties
if (noOverride && recipient.hasOwnProperty(i)) {
continue;
}
const setting: any = donor[i];
// Special cases for HTML elements
switch (i) {
// Children and options: just append all of them directly
case "children":
case "options":
if (typeof setting !== "undefined") {
for (const member of setting) {
recipient.appendChild(member);
}
}
break;
// Style: proliferate (instead of making a new Object)
case "style":
this.proliferate(recipient[i], setting);
break;
// By default, use the normal proliferate logic
default:
// If it's an object, recurse on a new version of it
if (typeof setting === "object") {
if (!recipient.hasOwnProperty(i)) {
recipient[i] = new setting.constructor();
}
this.proliferate(recipient[i], setting, noOverride);
} else {
// Regular primitives are easy to copy otherwise
recipient[i] = setting;
}
break;
}
}
return recipient;
}
/**
* Creates an Object that can be used to create a new LocalStorage
* replacement, if the JavaScript environment doesn't have one.
*
* @returns {Object}
*/
private createPlaceholderStorage(): Storage {
const output: any = {
keys: [],
getItem: (key: string): any => {
return this.localStorage[key];
},
setItem: (key: string, value: string): void => {
this.localStorage[key] = value;
},
clear: (): void => {
for (let i in this) {
if (this.hasOwnProperty(i)) {
delete (this as any)[i];
}
}
},
removeItem: (key: string): void => {
delete (this as any)[key];
},
key: function (this: any, index: number): string {
return this.keys[index];
}
};
Object.defineProperties(output, {
length: {
get: (): number => output.keys.length
},
remainingSpace: {
get: (): number => 9001
}
});
return output;
}
/**
* Resets this.items to their default values and resets this.itemKeys.
*/
private resetItemsToDefaults(): void {
this.items = {};
this.itemKeys = [];
if (!this.settings.values) {
return;
}
for (let key in this.settings.values) {
if (this.settings.values.hasOwnProperty(key)) {
this.addItem(key, this.settings.values[key]);
}
}
}
}
import { IItemsHoldr } from "./IItemsHoldr";
import { IItemValue } from "./IItemValue";
/**
* Storage container for a single ItemsHoldr value. The value may have triggers
* assigned to value, modularity, and other triggers, as well as an HTML element.
* Storage container for a single ItemsHoldr value.
*/

@@ -11,3 +10,3 @@ export declare class ItemValue implements IItemValue {

*/
private ItemsHolder;
private itemsHolder;
/**

@@ -31,14 +30,2 @@ * The unique key identifying this ItemValue in the ItemsHoldr.

/**
* An HTML element whose second child's textContent is always set to that of the element.
*/
private element;
/**
* Whether an Element should be created and synced to the value.
*/
private hasElement;
/**
* An Element tag to use in creating the element, if hasElement is true.
*/
private elementTag;
/**
* A minimum value for the value to equal, if value is a number.

@@ -70,7 +57,7 @@ */

*/
private transformGet;
private transformGet?;
/**
* A Function to transform the value when it's being retrieved.
*/
private transformSet;
private transformSet?;
/**

@@ -84,10 +71,11 @@ * The value being stored.

*
* @constructor
* @param ItemsHolder The container for this value.
* @param itemsHolder The container for this value.
* @param key The key to reference this new ItemValue by.
* @param settings Any optional custom settings.
*/
constructor(ItemsHolder: IItemsHoldr, key: string, settings?: any);
constructor(itemsHolder: IItemsHoldr, key: string, settings?: any);
/**
* @returns The value being stored, with a transformGet applied if one exists.
* Gets a stored value, with a transformGet applied if one exists.
*
* @returns The value being stored.
*/

@@ -103,9 +91,3 @@ getValue(): any;

/**
* @returns The stored HTML element, if it exists.
*/
getElement(): HTMLElement;
/**
* General update Function to be run whenever the internal value is changed.
* It runs all the trigger, modular, etc. checks, updates the HTML element
* if there is one, and updates localStorage if needed.
*/

@@ -132,12 +114,6 @@ update(): void;

/**
* Updates the ItemValue's element's second child to be the ItemValue's value.
*/
private updateElement();
/**
* Retrieves a ItemValue's value from localStorage, making sure not to try to
* JSON.parse an undefined or null value.
*
* @returns {Mixed}
*/
private retrieveLocalStorage();
}

@@ -1,8 +0,8 @@

define(["require", "exports"], function (require, exports) {
define(["require", "exports", "./proliferate"], function (require, exports, proliferate_1) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* Storage container for a single ItemsHoldr value. The value may have triggers
* assigned to value, modularity, and other triggers, as well as an HTML element.
* Storage container for a single ItemsHoldr value.
*/
var ItemValue = (function () {
var ItemValue = /** @class */ (function () {
/**

@@ -12,12 +12,11 @@ * Creates a new ItemValue with the given key and settings. Defaults are given

*
* @constructor
* @param ItemsHolder The container for this value.
* @param itemsHolder The container for this value.
* @param key The key to reference this new ItemValue by.
* @param settings Any optional custom settings.
*/
function ItemValue(ItemsHolder, key, settings) {
function ItemValue(itemsHolder, key, settings) {
if (settings === void 0) { settings = {}; }
this.ItemsHolder = ItemsHolder;
ItemsHolder.proliferate(this, ItemsHolder.getDefaults());
ItemsHolder.proliferate(this, settings);
this.itemsHolder = itemsHolder;
proliferate_1.proliferate(this, itemsHolder.getDefaults());
proliferate_1.proliferate(this, settings);
this.key = key;

@@ -27,16 +26,5 @@ if (!this.hasOwnProperty("value")) {

}
if (this.hasElement) {
this.element = ItemsHolder.createElement(this.elementTag || "div", {
className: ItemsHolder.getPrefix() + "_value " + key
});
this.element.appendChild(ItemsHolder.createElement("div", {
"textContent": key
}));
this.element.appendChild(ItemsHolder.createElement("div", {
"textContent": this.value
}));
}
if (this.storeLocally) {
// If there exists an old version of this property, get it
if (ItemsHolder.getLocalStorage().hasOwnProperty(ItemsHolder.getPrefix() + key)) {
// If there exists an old version of this property, get it
if (itemsHolder.getLocalStorage().hasOwnProperty(itemsHolder.getPrefix() + key)) {
this.value = this.retrieveLocalStorage();

@@ -52,3 +40,5 @@ this.update();

/**
* @returns The value being stored, with a transformGet applied if one exists.
* Gets a stored value, with a transformGet applied if one exists.
*
* @returns The value being stored.
*/

@@ -68,20 +58,9 @@ ItemValue.prototype.getValue = function () {

ItemValue.prototype.setValue = function (value) {
if (this.transformSet) {
this.value = this.transformSet(value);
}
else {
this.value = value;
}
this.value = this.transformSet === undefined
? value
: this.transformSet(value);
this.update();
};
/**
* @returns The stored HTML element, if it exists.
*/
ItemValue.prototype.getElement = function () {
return this.element;
};
/**
* General update Function to be run whenever the internal value is changed.
* It runs all the trigger, modular, etc. checks, updates the HTML element
* if there is one, and updates localStorage if needed.
*/

@@ -92,4 +71,4 @@ ItemValue.prototype.update = function () {

this.value = this.minimum;
if (this.onMinimum) {
this.onMinimum.apply(this, this.ItemsHolder.getCallbackArgs());
if (this.onMinimum !== undefined) {
this.onMinimum();
}

@@ -99,4 +78,4 @@ }

this.value = this.maximum;
if (this.onMaximum) {
this.onMaximum.apply(this, this.ItemsHolder.getCallbackArgs());
if (this.onMaximum !== undefined) {
this.onMaximum();
}

@@ -110,5 +89,2 @@ }

}
if (this.hasElement) {
this.updateElement();
}
if (this.storeLocally) {

@@ -126,4 +102,4 @@ this.updateLocalStorage();

ItemValue.prototype.updateLocalStorage = function (overrideAutoSave) {
if (overrideAutoSave || this.ItemsHolder.getAutoSave()) {
this.ItemsHolder.getLocalStorage()[this.ItemsHolder.getPrefix() + this.key] = JSON.stringify(this.value);
if (overrideAutoSave || this.itemsHolder.getAutoSave()) {
this.itemsHolder.getLocalStorage()[this.itemsHolder.getPrefix() + this.key] = JSON.stringify(this.value);
}

@@ -136,3 +112,3 @@ };

if (this.triggers.hasOwnProperty(this.value)) {
this.triggers[this.value].apply(this, this.ItemsHolder.getCallbackArgs());
this.triggers[this.value]();
}

@@ -152,3 +128,3 @@ };

if (this.onModular) {
this.onModular.apply(this, this.ItemsHolder.getCallbackArgs());
this.onModular();
}

@@ -158,20 +134,7 @@ }

/**
* Updates the ItemValue's element's second child to be the ItemValue's value.
*/
ItemValue.prototype.updateElement = function () {
if (this.ItemsHolder.hasDisplayChange(this.value)) {
this.element.children[1].textContent = this.ItemsHolder.getDisplayChange(this.value);
}
else {
this.element.children[1].textContent = this.value;
}
};
/**
* Retrieves a ItemValue's value from localStorage, making sure not to try to
* JSON.parse an undefined or null value.
*
* @returns {Mixed}
*/
ItemValue.prototype.retrieveLocalStorage = function () {
var value = this.ItemsHolder.getLocalStorage()[this.ItemsHolder.getPrefix() + this.key];
var value = this.itemsHolder.getLocalStorage()[this.itemsHolder.getPrefix() + this.key];
if (typeof value === "undefined" || value === "undefined") {

@@ -189,3 +152,1 @@ return undefined;

});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["ItemValue.ts"],"names":[],"mappings":"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","file":"ItemValue.js","sourcesContent":["import { IItemsHoldr } from \"./IItemsHoldr\";\r\nimport { IItemValue, ITriggers } from \"./IItemValue\";\r\n\r\n/**\r\n * Storage container for a single ItemsHoldr value. The value may have triggers\r\n * assigned to value, modularity, and other triggers, as well as an HTML element.\r\n */\r\nexport class ItemValue implements IItemValue {\r\n    /**\r\n     * The container ItemsHoldr governing usage of this ItemsValue.\r\n     */\r\n    private ItemsHolder: IItemsHoldr;\r\n\r\n    /**\r\n     * The unique key identifying this ItemValue in the ItemsHoldr.\r\n     */\r\n    private key: string;\r\n\r\n    /**\r\n     * A default initial value to store, if value isn't provided.\r\n     */\r\n    private valueDefault: any;\r\n\r\n    /**\r\n     * Whether the value should be stored in the ItemHoldr's localStorage.\r\n     */\r\n    private storeLocally: boolean;\r\n\r\n    /**\r\n     * A mapping of values to callbacks that should be triggered when value\r\n     * is equal to them.\r\n     */\r\n    private triggers: ITriggers;\r\n\r\n    /**\r\n     * An HTML element whose second child's textContent is always set to that of the element.\r\n     */\r\n    private element: HTMLElement;\r\n\r\n    /**\r\n     * Whether an Element should be created and synced to the value.\r\n     */\r\n    private hasElement: boolean;\r\n\r\n    /**\r\n     * An Element tag to use in creating the element, if hasElement is true.\r\n     */\r\n    private elementTag: string;\r\n\r\n    /**\r\n     * A minimum value for the value to equal, if value is a number.\r\n     */\r\n    private minimum: number;\r\n\r\n    /**\r\n     * A callback to call when the value reaches the minimum value.\r\n     */\r\n    private onMinimum: Function;\r\n\r\n    /**\r\n     * A maximum value for the value to equal, if value is a number.\r\n     */\r\n    private maximum: number;\r\n\r\n    /**\r\n     * A callback to call when the value reaches the maximum value.\r\n     */\r\n    private onMaximum: Function;\r\n\r\n    /**\r\n     * A maximum number to modulo the value against, if value is a number.\r\n     */\r\n    private modularity: number;\r\n\r\n    /**\r\n     * A callback to call when the value reaches modularity.\r\n     */\r\n    private onModular: Function;\r\n\r\n    /**\r\n     * A Function to transform the value when it's being set.\r\n     */\r\n    private transformGet: Function;\r\n\r\n    /**\r\n     * A Function to transform the value when it's being retrieved.\r\n     */\r\n    private transformSet: Function;\r\n\r\n    /**\r\n     * The value being stored.\r\n     */\r\n    private value: any;\r\n\r\n    /**\r\n     * Creates a new ItemValue with the given key and settings. Defaults are given\r\n     * to the value via proliferate before the settings.\r\n     * \r\n     * @constructor\r\n     * @param ItemsHolder   The container for this value.\r\n     * @param key   The key to reference this new ItemValue by.\r\n     * @param settings   Any optional custom settings.\r\n     */\r\n    constructor(ItemsHolder: IItemsHoldr, key: string, settings: any = {}) {\r\n        this.ItemsHolder = ItemsHolder;\r\n\r\n        ItemsHolder.proliferate(this, ItemsHolder.getDefaults());\r\n        ItemsHolder.proliferate(this, settings);\r\n\r\n        this.key = key;\r\n\r\n        if (!this.hasOwnProperty(\"value\")) {\r\n            this.value = this.valueDefault;\r\n        }\r\n\r\n        if (this.hasElement) {\r\n            this.element = ItemsHolder.createElement(this.elementTag || \"div\", {\r\n                className: ItemsHolder.getPrefix() + \"_value \" + key\r\n            });\r\n            this.element.appendChild(ItemsHolder.createElement(\"div\", {\r\n                \"textContent\": key\r\n            }));\r\n            this.element.appendChild(ItemsHolder.createElement(\"div\", {\r\n                \"textContent\": this.value\r\n            }));\r\n        }\r\n\r\n        if (this.storeLocally) {\r\n            // If there exists an old version of this property, get it \r\n            if (ItemsHolder.getLocalStorage().hasOwnProperty(ItemsHolder.getPrefix() + key)) {\r\n                this.value = this.retrieveLocalStorage();\r\n                this.update();\r\n            } else {\r\n                // Otherwise save the new version to memory\r\n                this.updateLocalStorage();\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @returns The value being stored, with a transformGet applied if one exists.\r\n     */\r\n    public getValue(): any {\r\n        if (this.transformGet) {\r\n            return this.transformGet(this.value);\r\n        }\r\n\r\n        return this.value;\r\n    }\r\n\r\n    /**\r\n     * Sets the value being stored, with a is a transformSet applied if one exists.\r\n     * Any attached triggers to the new value will be called.\r\n     *\r\n     * @param value   The desired value to now store.\r\n     */\r\n    public setValue(value: any): void {\r\n        if (this.transformSet) {\r\n            this.value = this.transformSet(value);\r\n        } else {\r\n            this.value = value;\r\n        }\r\n\r\n        this.update();\r\n    }\r\n\r\n    /**\r\n     * @returns The stored HTML element, if it exists.\r\n     */\r\n    public getElement(): HTMLElement {\r\n        return this.element;\r\n    }\r\n\r\n    /**\r\n     * General update Function to be run whenever the internal value is changed.\r\n     * It runs all the trigger, modular, etc. checks, updates the HTML element\r\n     * if there is one, and updates localStorage if needed.\r\n     */\r\n    public update(): void {\r\n        // Mins and maxes must be obeyed before any other considerations\r\n        if (this.hasOwnProperty(\"minimum\") && Number(this.value) <= Number(this.minimum)) {\r\n            this.value = this.minimum;\r\n            if (this.onMinimum) {\r\n                this.onMinimum.apply(this, this.ItemsHolder.getCallbackArgs());\r\n            }\r\n        } else if (this.hasOwnProperty(\"maximum\") && Number(this.value) <= Number(this.maximum)) {\r\n            this.value = this.maximum;\r\n            if (this.onMaximum) {\r\n                this.onMaximum.apply(this, this.ItemsHolder.getCallbackArgs());\r\n            }\r\n        }\r\n\r\n        if (this.modularity) {\r\n            this.checkModularity();\r\n        }\r\n\r\n        if (this.triggers) {\r\n            this.checkTriggers();\r\n        }\r\n\r\n        if (this.hasElement) {\r\n            this.updateElement();\r\n        }\r\n\r\n        if (this.storeLocally) {\r\n            this.updateLocalStorage();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Stores a ItemValue's value in localStorage under the prefix plus its key.\r\n     * \r\n     * @param [overrideAutoSave]   Whether the policy on saving should be\r\n     *                             ignored (so saving happens regardless). By \r\n     *                             default, false.\r\n     */\r\n    public updateLocalStorage(overrideAutoSave?: boolean): void {\r\n        if (overrideAutoSave || this.ItemsHolder.getAutoSave()) {\r\n            this.ItemsHolder.getLocalStorage()[this.ItemsHolder.getPrefix() + this.key] = JSON.stringify(this.value);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Checks if the current value should trigger a callback, and if so calls it.\r\n     */\r\n    private checkTriggers(): void {\r\n        if (this.triggers.hasOwnProperty(this.value)) {\r\n            this.triggers[this.value].apply(this, this.ItemsHolder.getCallbackArgs());\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Checks if the current value is greater than the modularity (assuming\r\n     * modular is a non-zero Numbers), and if so, continuously reduces value and \r\n     * calls this.onModular.\r\n     */\r\n    private checkModularity(): void {\r\n        if (this.value.constructor !== Number || !this.modularity) {\r\n            return;\r\n        }\r\n\r\n        while (this.value >= this.modularity) {\r\n            this.value = Math.max(0, this.value - this.modularity);\r\n            if (this.onModular) {\r\n                this.onModular.apply(this, this.ItemsHolder.getCallbackArgs());\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Updates the ItemValue's element's second child to be the ItemValue's value.\r\n     */\r\n    private updateElement(): void {\r\n        if (this.ItemsHolder.hasDisplayChange(this.value)) {\r\n            this.element.children[1].textContent = this.ItemsHolder.getDisplayChange(this.value);\r\n        } else {\r\n            this.element.children[1].textContent = this.value;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Retrieves a ItemValue's value from localStorage, making sure not to try to\r\n     * JSON.parse an undefined or null value.\r\n     * \r\n     * @returns {Mixed}\r\n     */\r\n    private retrieveLocalStorage(): any {\r\n        const value: any = this.ItemsHolder.getLocalStorage()[this.ItemsHolder.getPrefix() + this.key];\r\n\r\n        if (typeof value === \"undefined\" || value === \"undefined\") {\r\n            return undefined;\r\n        }\r\n\r\n        if (value.constructor !== String) {\r\n            return value;\r\n        }\r\n\r\n        return JSON.parse(value);\r\n    }\r\n}\r\n"]}
import { IItemsHoldr } from "./IItemsHoldr";
import { IItemValue, ITriggers } from "./IItemValue";
import { proliferate } from "./proliferate";
/**
* Storage container for a single ItemsHoldr value. The value may have triggers
* assigned to value, modularity, and other triggers, as well as an HTML element.
* Storage container for a single ItemsHoldr value.
*/

@@ -12,3 +12,3 @@ export class ItemValue implements IItemValue {

*/
private ItemsHolder: IItemsHoldr;
private itemsHolder: IItemsHoldr;

@@ -37,17 +37,2 @@ /**

/**
* An HTML element whose second child's textContent is always set to that of the element.
*/
private element: HTMLElement;
/**
* Whether an Element should be created and synced to the value.
*/
private hasElement: boolean;
/**
* An Element tag to use in creating the element, if hasElement is true.
*/
private elementTag: string;
/**
* A minimum value for the value to equal, if value is a number.

@@ -60,3 +45,3 @@ */

*/
private onMinimum: Function;
private onMinimum: Function | undefined;

@@ -71,3 +56,3 @@ /**

*/
private onMaximum: Function;
private onMaximum: Function | undefined;

@@ -87,3 +72,3 @@ /**

*/
private transformGet: Function;
private transformGet?: Function;

@@ -93,3 +78,3 @@ /**

*/
private transformSet: Function;
private transformSet?: Function;

@@ -104,13 +89,12 @@ /**

* to the value via proliferate before the settings.
*
* @constructor
* @param ItemsHolder The container for this value.
*
* @param itemsHolder The container for this value.
* @param key The key to reference this new ItemValue by.
* @param settings Any optional custom settings.
*/
constructor(ItemsHolder: IItemsHoldr, key: string, settings: any = {}) {
this.ItemsHolder = ItemsHolder;
public constructor(itemsHolder: IItemsHoldr, key: string, settings: any = {}) {
this.itemsHolder = itemsHolder;
ItemsHolder.proliferate(this, ItemsHolder.getDefaults());
ItemsHolder.proliferate(this, settings);
proliferate(this, itemsHolder.getDefaults());
proliferate(this, settings);

@@ -123,17 +107,5 @@ this.key = key;

if (this.hasElement) {
this.element = ItemsHolder.createElement(this.elementTag || "div", {
className: ItemsHolder.getPrefix() + "_value " + key
});
this.element.appendChild(ItemsHolder.createElement("div", {
"textContent": key
}));
this.element.appendChild(ItemsHolder.createElement("div", {
"textContent": this.value
}));
}
if (this.storeLocally) {
// If there exists an old version of this property, get it
if (ItemsHolder.getLocalStorage().hasOwnProperty(ItemsHolder.getPrefix() + key)) {
// If there exists an old version of this property, get it
if (itemsHolder.getLocalStorage().hasOwnProperty(itemsHolder.getPrefix() + key)) {
this.value = this.retrieveLocalStorage();

@@ -149,3 +121,5 @@ this.update();

/**
* @returns The value being stored, with a transformGet applied if one exists.
* Gets a stored value, with a transformGet applied if one exists.
*
* @returns The value being stored.
*/

@@ -167,7 +141,5 @@ public getValue(): any {

public setValue(value: any): void {
if (this.transformSet) {
this.value = this.transformSet(value);
} else {
this.value = value;
}
this.value = this.transformSet === undefined
? value
: this.transformSet(value);

@@ -178,12 +150,3 @@ this.update();

/**
* @returns The stored HTML element, if it exists.
*/
public getElement(): HTMLElement {
return this.element;
}
/**
* General update Function to be run whenever the internal value is changed.
* It runs all the trigger, modular, etc. checks, updates the HTML element
* if there is one, and updates localStorage if needed.
*/

@@ -194,9 +157,9 @@ public update(): void {

this.value = this.minimum;
if (this.onMinimum) {
this.onMinimum.apply(this, this.ItemsHolder.getCallbackArgs());
if (this.onMinimum !== undefined) {
this.onMinimum();
}
} else if (this.hasOwnProperty("maximum") && Number(this.value) <= Number(this.maximum)) {
this.value = this.maximum;
if (this.onMaximum) {
this.onMaximum.apply(this, this.ItemsHolder.getCallbackArgs());
if (this.onMaximum !== undefined) {
this.onMaximum();
}

@@ -213,6 +176,2 @@ }

if (this.hasElement) {
this.updateElement();
}
if (this.storeLocally) {

@@ -225,10 +184,10 @@ this.updateLocalStorage();

* Stores a ItemValue's value in localStorage under the prefix plus its key.
*
*
* @param [overrideAutoSave] Whether the policy on saving should be
* ignored (so saving happens regardless). By
* ignored (so saving happens regardless). By
* default, false.
*/
public updateLocalStorage(overrideAutoSave?: boolean): void {
if (overrideAutoSave || this.ItemsHolder.getAutoSave()) {
this.ItemsHolder.getLocalStorage()[this.ItemsHolder.getPrefix() + this.key] = JSON.stringify(this.value);
if (overrideAutoSave || this.itemsHolder.getAutoSave()) {
this.itemsHolder.getLocalStorage()[this.itemsHolder.getPrefix() + this.key] = JSON.stringify(this.value);
}

@@ -242,3 +201,3 @@ }

if (this.triggers.hasOwnProperty(this.value)) {
this.triggers[this.value].apply(this, this.ItemsHolder.getCallbackArgs());
this.triggers[this.value]();
}

@@ -249,3 +208,3 @@ }

* Checks if the current value is greater than the modularity (assuming
* modular is a non-zero Numbers), and if so, continuously reduces value and
* modular is a non-zero Numbers), and if so, continuously reduces value and
* calls this.onModular.

@@ -261,3 +220,3 @@ */

if (this.onModular) {
this.onModular.apply(this, this.ItemsHolder.getCallbackArgs());
this.onModular();
}

@@ -268,20 +227,7 @@ }

/**
* Updates the ItemValue's element's second child to be the ItemValue's value.
*/
private updateElement(): void {
if (this.ItemsHolder.hasDisplayChange(this.value)) {
this.element.children[1].textContent = this.ItemsHolder.getDisplayChange(this.value);
} else {
this.element.children[1].textContent = this.value;
}
}
/**
* Retrieves a ItemValue's value from localStorage, making sure not to try to
* JSON.parse an undefined or null value.
*
* @returns {Mixed}
*/
private retrieveLocalStorage(): any {
const value: any = this.ItemsHolder.getLocalStorage()[this.ItemsHolder.getPrefix() + this.key];
const value: any = this.itemsHolder.getLocalStorage()[this.itemsHolder.getPrefix() + this.key];

@@ -288,0 +234,0 @@ if (typeof value === "undefined" || value === "undefined") {

{
"compilerOptions": {
"declaration": true,
"experimentalDecorators": true,
"jsx": "react",
"lib": ["dom", "es2015.collection", "es2015.promise", "es5"],
"module": "amd",

@@ -10,10 +13,14 @@ "moduleResolution": "node",

"noFallthroughCasesInSwitch": true,
"noUnusedLocals": true,
"noUnusedParameters": true,
"pretty": true,
"strictNullChecks": true,
"target": "es3"
"target": "es5"
},
"exclude": [
"dist",
"node_modules"
],
"include": [
"./src/**/*.ts"
"./src/**/*.ts",
"./src/**/*.tsx"
]
}
{
"extends": "./node_modules/shenanigans-manager/setup/tslint.json",
"rules": {
"align": [
true,
"parameters",
"arguments",
"statements"
],
"class-name": true,
"comment-format": [true, "check-space"],
"curly": true,
"eofline": true,
"forin": true,
"indent": [true, 4],
"interface-name": [true, "always-prefix"],
"jsdoc-format": true,
"label-position": true,
"max-line-length": [true, 140],
"member-access": true,
"member-ordering": [
true,
"public-before-private",
"static-before-instance",
"variables-before-functions"
],
"new-parens": true,
"no-angle-bracket-type-assertion": true,
"no-arg": true,
"no-conditional-assignment": true,
"no-consecutive-blank-lines": true,
"no-console": [
true,
"debug",
"info",
"time",
"timeEnd",
"trace"
],
"no-construct": true,
"no-debugger": true,
"no-duplicate-variable": true,
"no-empty": true,
"no-eval": true,
"no-internal-module": true,
"no-null-keyword": true,
"no-shadowed-variable": true,
"no-string-literal": true,
"no-switch-case-fall-through": true,
"no-trailing-whitespace": true,
"no-unsafe-finally": true,
"no-unused-expression": true,
"no-unused-new": true,
"no-use-before-declare": true,
"no-var-keyword": true,
"one-line": [
true,
"check-catch",
"check-else",
"check-finally",
"check-open-brace",
"check-whitespace"
],
"one-variable-per-declaration": true,
"ordered-imports": true,
"quotemark": [true, "double"],
"semicolon": [true, "always"],
"switch-default": true,
"trailing-comma": true,
"triple-equals": [true, "allow-null-check"],
"typedef": [
true,
"call-signature",
"parameter",
"property-declaration",
"variable-declaration",
"member-variable-declaration"
],
"typedef-whitespace": [
true,
{
"call-signature": "nospace",
"index-signature": "nospace",
"parameter": "nospace",
"property-declaration": "nospace",
"variable-declaration": "nospace"
}
],
"use-isnan": true,
"whitespace": [
true,
"check-branch",
"check-decl",
"check-operator",
"check-separator",
"check-type"
]
"ban-types": false,
"no-any": false,
"no-unsafe-any": false,
"strict-boolean-expressions": false
}
}
}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc