Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alenaksu/secchiojs
Enhanced Web Storage API
https://github.com/alenaksu/secchiojs
localstorage sessionstorage storage store webstorage
Last synced: 8 days ago
JSON representation
Enhanced Web Storage API
- Host: GitHub
- URL: https://github.com/alenaksu/secchiojs
- Owner: alenaksu
- Created: 2019-11-08T14:36:02.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-09T03:19:41.000Z (about 2 years ago)
- Last Synced: 2025-02-03T13:08:11.589Z (18 days ago)
- Topics: localstorage, sessionstorage, storage, store, webstorage
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/secchiojs
- Size: 450 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# secchiojs
[data:image/s3,"s3://crabby-images/acae6/acae6aa0f86bcac4c1691a4560ae64d50bbfe555" alt="GitHub release"](https://github.com/alenaksu/secchiojs/releases)
[data:image/s3,"s3://crabby-images/fcd34/fcd341fd9cf04e39429b1216d762be28374cf283" alt="npm"](https://www.npmjs.com/package/secchiojs)
[data:image/s3,"s3://crabby-images/e5969/e5969c29858f149145154a8e0a31c2c2a9a7bfb9" alt="downloads"](https://www.npmjs.com/package/secchiojs)
[data:image/s3,"s3://crabby-images/5db9b/5db9b146af528eeb6dc537356c4eee71e46fdfa8" alt="Known Vulnerabilities"](https://snyk.io/test/npm/secchiojs)
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="MIT licensed"](https://raw.githubusercontent.com/secchiojs/master/LICENSE)Enhanced Web Storage API
## Install
you can install the package through [npm](https://npmjs.com/) runnig:
```bash
npm install secchiojs
```## Usage
### Typescript
```ts
import { getBucket } from 'secchiojs';type UserPrefs = {
name: string;
email: string;
mode: number;
};const [getPrefs, updatePrefs, deletePrefs] = getBucket(
'user-prefs',
{
version: 1,
defaultValue: {},
storage: localStorage,
expire: 3600,
}
);const userPrefs = getPrefs();
updatePrefs({
...userPrefs,
mode: 2,
});deletePrefs();
```### Javascript
```js
import { getBucket } from 'secchiojs';const [getPrefs, updatePrefs, deletePrefs] = getBucket('user-prefs', {
version: 1,
defaultValue: {},
storage: localStorage,
expire: 3600,
});const userPrefs = getPrefs();
updatePrefs({
...userPrefs,
mode: 2,
});deletePrefs();
```## API
### getBucket
#### Parameters
- `name` **string** The name of the bucket. It will be used as key when saving into the storage.
- `options` **BucketOptions** The bucket options.#### Returns
The function returns an array containing get, set and remove methods.
```ts
export type Bucket = [
// get
() => T,// set
(value: T) => void,// remove
() => void
];
```### BucketOptions
- `storage?` **Storage** An instance of a storage implementing the Web Storage interface (eg. localStorage, sessionStorage).
- `version?` **number** The version of the bucket.
- `expire?` **number** A number that indicates the expiration of the data. Default is 0, which means no expiration.
- `defaultValue?` **any** The default value returned if the data doesn't exist, or is expired or is from a different verision.