@helpwave/hightide
Version:
helpwave's component and theming library
85 lines (81 loc) • 2.72 kB
JavaScript
"use client";
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/hooks/useLocalStorage.ts
var useLocalStorage_exports = {};
__export(useLocalStorage_exports, {
useLocalStorage: () => useLocalStorage
});
module.exports = __toCommonJS(useLocalStorage_exports);
var import_react = require("react");
// src/util/storage.ts
var StorageService = class {
// this seems to be a bug in eslint as 'paramter-properties' is a special syntax of typescript
constructor(storage) {
this.storage = storage;
}
get(key) {
const value = this.storage.getItem(key);
if (value === null) {
return null;
}
return JSON.parse(value);
}
set(key, value) {
this.storage.setItem(key, JSON.stringify(value));
}
delete(key) {
this.storage.removeItem(key);
}
deleteAll() {
this.storage.clear();
}
};
var LocalStorageService = class extends StorageService {
constructor() {
super(window.localStorage);
}
};
// src/util/resolveSetState.ts
function resolveSetState(action, prev) {
return typeof action === "function" ? action(prev) : action;
}
// src/hooks/useLocalStorage.ts
var useLocalStorage = (key, initValue) => {
const get = (0, import_react.useCallback)(() => {
if (typeof window === "undefined") {
return initValue;
}
const storageService = new LocalStorageService();
const value = storageService.get(key);
return value || initValue;
}, [initValue, key]);
const [storedValue, setStoredValue] = (0, import_react.useState)(get);
const setValue = (0, import_react.useCallback)((action) => {
const newValue = resolveSetState(action, storedValue);
const storageService = new LocalStorageService();
storageService.set(key, newValue);
setStoredValue(newValue);
}, [storedValue, setStoredValue, key]);
return [storedValue, setValue];
};
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
useLocalStorage
});
//# sourceMappingURL=useLocalStorage.js.map