itemsholdr
Advanced tools
Comparing version 0.6.1 to 0.7.0
{ | ||
"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" | ||
] | ||
} |
101
tslint.json
{ | ||
"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
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
0
773708
21
59
3813
16
4