forked from DefinitelyTyped/DefinitelyTyped
-
Notifications
You must be signed in to change notification settings - Fork 0
/
simplestorage.js.d.ts
118 lines (101 loc) · 5.58 KB
/
simplestorage.js.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
// Type definitions for simplestorage.js v0.2.1
// Project: https://github.com/andris9/simpleStorage
// Definitions by: Áxel Costas Pena <https://github.com/axelcostaspena>, Michael Ledin <https://github.com/mxl>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
declare namespace simplestoragejs {
/**
* {@link simpleStorage} API is a subset of {@link http://www.jstorage.info/|jStorage} with slight modifications, so for most cases it should work out of the box if you are converting from {@link http://www.jstorage.info/|jStorage}. Main difference is between return values - if an action failed because of an error (storage full, storage not available, invalid data used etc.), you get the error object as the return value. {@link http://www.jstorage.info/|jStorage} never indicated anything if an error occurred.
* @see https://github.com/andris9/simpleStorage#usage
*/
export interface SimpleStorage {
version: string;
/**
* Check if local storage can be used.
* Returns <code>true</code> if storage is available.
* @see https://github.com/andris9/simpleStorage#canuse
*/
canUse(): boolean;
/**
* Store or update a value in local storage.
* Returns <code>true</code> if value was stored, <code>false</code> if value was not stored or <code>{@link Error}</code> object if value was not stored because of an error.
* @param key The key for the value.
* @param value Value to be stored (can be any JSONeable value).
* @param [options] Optional options object.
* @see https://github.com/andris9/simpleStorage#setkey-value-options
*/
set(key: string, value: any, options?: SetOptions): boolean|Error;
/**
* Retrieve a value from local storage.
* Returns the value for a key or undefined if the key was not found.
* @param key The key to be retrieved.
* @see https://github.com/andris9/simpleStorage#getkey
*/
get(key: string): any;
/**
* Checks if there's a value with the given key in the local storage.
* Returns <code>true</code> if the given key exists, <code>false</code> otherwise.
* @param key The key to be checked.
* @see https://github.com/andris9/simpleStorage#haskeykey
*/
hasKey(key: string): boolean;
/**
* Removes a value from local storage.
* Returns <code>true</code> if the value was deleted, <code>false</code> if the value was not found or <code>{@link Error}</code> object if value was not deleted because of an error.
* @param key The key to be deleted.
* @see https://github.com/andris9/simpleStorage#deletekeykey
*/
deleteKey(key: string): boolean|Error;
/**
* Set a millisecond timeout. When the timeout is reached, the key is removed automatically from local storage.
* Returns <code>true</code> if ttl was set, <code>false</code> if value was not found or <code>{@link Error}</code> object if ttl was not set because of an error.
* @param key The key to be updated.
* @param ttl Timeout in milliseconds. If the value is 0, timeout is cleared from the key.
* @see https://github.com/andris9/simpleStorage#setttlkey-ttl
*/
setTTL(key: string, ttl: number): boolean|Error;
/**
* Retrieve remaining milliseconds for a key with TTL.
* Returns the finite number of remaining milliseconds, <code>Infinity</code> if TTL is not set for the selected key or <code>false</code> if the selected key does not exist or is expired.
* @param key The key to be checked.
* @see https://github.com/andris9/simpleStorage#getttlkey
*/
getTTL(key: string): number|boolean;
/**
* Clear all values.
* Returns <code>true</code> if storage was flushed or <code>{@link Error}</code> object if storage was not flushed because of an error.
* @see https://github.com/andris9/simpleStorage#flush
*/
flush(): boolean|Error;
/**
* Retrieve all used keys as an array.
* Returns an array of keys.
* @see https://github.com/andris9/simpleStorage#index
*/
index(): [string]|boolean;
/**
* Get used storage in symbol count.
* @see https://github.com/andris9/simpleStorage#storagesize
*/
storageSize(): number;
}
/**
* @see https://github.com/andris9/simpleStorage#setkey-value-options
*/
export interface SetOptions {
/**
* Sets the time-to-live (TTL) value in milliseconds for the given key/value.
*/
TTL?: number;
}
}
declare module "simplestorage.js" {
export = simpleStorage;
}
/**
* Cross-browser key-value store database to store data locally in the browser.
* {@link simpleStorage} is a fork of {@link http://www.jstorage.info/|jStorage} that only includes the minimal set of features. Basically it is a wrapper for native <code>{@link JSON}</code> + <code>{@link WindowLocalStorage.localStorage|localStorage}</code> with some TTL magic mixed in.
* The module has no dependencies, you can use it as a standalone script (introduces {@link simpleStorage} global) or as an AMD module. All modern browsers (including mobile) are supported, older browsers (IE7, Firefox 3) are not.
* {@link simpleStorage} is very small - about 1kB in size when minimized and gzipped.
* @see https://github.com/andris9/simpleStorage#simplestorage
*/
declare var simpleStorage: simplestoragejs.SimpleStorage;