Skip to content

Commit

Permalink
Merge pull request #168 from clevelandcs/urlfilter
Browse files Browse the repository at this point in the history
Add support for sharing table views via link
  • Loading branch information
Donkie committed Oct 24, 2023
2 parents 4c38557 + cf518b1 commit 2bd6722
Showing 1 changed file with 56 additions and 10 deletions.
66 changes: 56 additions & 10 deletions client/src/utils/saveload.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import React from "react";
import { CrudFilter, CrudSort } from "@refinedev/core";
import { isLocalStorageAvailable } from "./support";

interface Pagination {
current: number;
pageSize: number;
Expand All @@ -16,9 +15,9 @@ export interface TableState {

export function useInitialTableState(tableId: string): TableState {
const [initialState] = React.useState(() => {
const savedSorters = isLocalStorageAvailable ? localStorage.getItem(`${tableId}-sorters`) : null;
const savedFilters = isLocalStorageAvailable ? localStorage.getItem(`${tableId}-filters`) : null;
const savedPagination = isLocalStorageAvailable ? localStorage.getItem(`${tableId}-pagination`) : 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" }];
Expand All @@ -32,21 +31,41 @@ 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 (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));
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 })) {
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]);

React.useEffect(() => {
Expand All @@ -57,6 +76,7 @@ export function useStoreInitialState(tableId: string, state: TableState) {
localStorage.setItem(`${tableId}-showColumns`, JSON.stringify(state.showColumns));
}
}

}, [tableId, state.showColumns]);
}

Expand All @@ -74,3 +94,29 @@ export function useSavedState<T>(id: string, defaultValue: T) {

return [state, setState] as const;
}

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));
return hash.get(Id);
}

function hasHashProperty(property: string): boolean {
const hash = new URLSearchParams(window.location.hash.substring(1));
return hash.has(property);
}

0 comments on commit 2bd6722

Please sign in to comment.