Skip to content

Commit

Permalink
only update localStorage and hash if table setting differs from default
Browse files Browse the repository at this point in the history
  • Loading branch information
clevelandcs committed Oct 24, 2023
1 parent 201665d commit cf518b1
Showing 1 changed file with 36 additions and 24 deletions.
60 changes: 36 additions & 24 deletions client/src/utils/saveload.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,10 @@ export interface TableState {

export function useInitialTableState(tableId: string): TableState {
const [initialState] = React.useState(() => {
const savedSorters = hasHashProperty(`${tableId}-sorters`) ? getHashProperty(`${tableId}-sorters`) : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-sorters`) : null;
const savedFilters = hasHashProperty(`${tableId}-filters`) ? getHashProperty(`${tableId}-filters`) : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-filters`) : null;
const savedPagination = hasHashProperty(`${tableId}-pagination`) ? getHashProperty(`${tableId}-pagination`) : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-pagination`) : null;
const savedShowColumns = hasHashProperty(`${tableId}-showColumns`) ? getHashProperty(`${tableId}-showColumns`) : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-showColumns`) : null;
const savedSorters = hasHashProperty('sorters') ? getHashProperty('sorters') : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-sorters`) : null;
const savedFilters = hasHashProperty('filters') ? getHashProperty('filters') : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-filters`) : null;
const savedPagination = hasHashProperty('pagination') ? getHashProperty('pagination') : isLocalStorageAvailable ? localStorage.getItem(`${tableId}-pagination`) : null;
const savedShowColumns = isLocalStorageAvailable ? localStorage.getItem(`${tableId}-showColumns`) : null;

const sorters = savedSorters ? JSON.parse(savedSorters) : [{ field: "id", order: "asc" }];
const filters = savedFilters ? JSON.parse(savedFilters) : [];
Expand All @@ -31,29 +31,39 @@ export function useInitialTableState(tableId: string): TableState {

export function useStoreInitialState(tableId: string, state: TableState) {
React.useEffect(() => {
if (isLocalStorageAvailable) {
localStorage.setItem(`${tableId}-sorters`, JSON.stringify(state.sorters));
}
if (JSON.stringify(state.sorters) != JSON.stringify([{ field: "id", order: "asc" }])) {
updateURLHash(`${tableId}-sorters`, JSON.stringify(state.sorters));
if (state.sorters.length > 0 && JSON.stringify(state.sorters) != JSON.stringify([{ field: "id", order: "asc" }])) {
if (isLocalStorageAvailable) {
localStorage.setItem(`${tableId}-sorters`, JSON.stringify(state.sorters));
}
setURLHash(`sorters`, JSON.stringify(state.sorters));
} else {
localStorage.removeItem(`${tableId}-sorters`)
removeURLHash('sorters');
}
}, [tableId, state.sorters]);

React.useEffect(() => {
if (isLocalStorageAvailable) {
localStorage.setItem(`${tableId}-filters`, JSON.stringify(state.filters));
}
if (JSON.stringify(state.filters) != JSON.stringify([])) {
updateURLHash(`${tableId}-filters`, JSON.stringify(state.filters));
let filters = state.filters.filter(f => f.value.length != 0);
if (filters.length > 0) {
if (isLocalStorageAvailable) {
localStorage.setItem(`${tableId}-filters`, JSON.stringify(filters));
setURLHash('filters', JSON.stringify(state.filters));
}
} else {
localStorage.removeItem(`${tableId}-filters`)
removeURLHash(`filters`);
}
}, [tableId, state.filters]);

React.useEffect(() => {
if (isLocalStorageAvailable) {
localStorage.setItem(`${tableId}-pagination`, JSON.stringify(state.pagination));
}
if (JSON.stringify(state.pagination) != JSON.stringify({ current: 1, pageSize: 20 })) {
updateURLHash(`${tableId}-pagination`, JSON.stringify(state.pagination));
if (isLocalStorageAvailable) {
localStorage.setItem(`${tableId}-pagination`, JSON.stringify(state.pagination));
}
setURLHash(`pagination`, JSON.stringify(state.pagination));
} else {
localStorage.removeItem(`${tableId}-pagination`)
removeURLHash(`pagination`);
}

}, [tableId, state.pagination]);
Expand All @@ -62,11 +72,6 @@ export function useStoreInitialState(tableId: string, state: TableState) {
if (isLocalStorageAvailable) {
if (state.showColumns === undefined) {
localStorage.removeItem(`${tableId}-showColumns`);
const params = new URLSearchParams(window.location.hash.substring(1));
if (params.has(`${tableId}-showColumns`)) {
params.delete(`${tableId}-showColumns`)
}
window.location.hash = params.toString();
} else {
localStorage.setItem(`${tableId}-showColumns`, JSON.stringify(state.showColumns));
}
Expand All @@ -90,14 +95,21 @@ export function useSavedState<T>(id: string, defaultValue: T) {
return [state, setState] as const;
}

export function updateURLHash(Id: string, value: string) {
function setURLHash(Id: string, value: string) {
const params = new URLSearchParams(window.location.hash.substring(1));
if (!params.has(Id)) {
params.append(Id, value)
}
params.set(Id, value);
window.location.hash = params.toString();
}
function removeURLHash(Id: string) {
const params = new URLSearchParams(window.location.hash.substring(1));
if (params.has(Id)) {
params.delete(Id)
}
window.location.hash = params.toString();
}

function getHashProperty(Id: string) {
const hash = new URLSearchParams(window.location.hash.substring(1));
Expand Down

0 comments on commit cf518b1

Please sign in to comment.