mirror of
https://github.com/supabase/supabase.git
synced 2026-07-03 22:54:19 +08:00
* Replace all usage of useProjectContext with useSelectedProjectQuery * Replace all usage of useSelectedProject with useSelectedProjectQuery * Replace all usage of useProjectByRef with useProjectByRefQuery * Replace all usage of useSelectedOrganization with useSelectedOrganizationQuery * Deprecate useSelectedProject, useSelectedOrganization, and useProjectByRef hooks * Deprecate ProjecContext
59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
import { useCallback } from 'react'
|
|
|
|
import { saveTableEditorStateToLocalStorage } from 'components/grid/SupabaseGrid.utils'
|
|
import { useSelectedProjectQuery } from 'hooks/misc/useSelectedProject'
|
|
import { useTableEditorTableStateSnapshot } from 'state/table-editor-table'
|
|
|
|
/**
|
|
* Hook for saving state and triggering side effects.
|
|
*/
|
|
export function useSaveTableEditorState() {
|
|
const { data: project } = useSelectedProjectQuery()
|
|
const snap = useTableEditorTableStateSnapshot()
|
|
|
|
const saveDataAndTriggerSideEffects = useCallback(
|
|
(dataToSave: { filters?: string[]; sorts?: string[] }) => {
|
|
const projectRef = project?.ref
|
|
|
|
if (!projectRef) {
|
|
return console.warn(
|
|
'[useSaveTableEditorState] ProjectRef missing, cannot save or trigger side effects.'
|
|
)
|
|
}
|
|
|
|
try {
|
|
snap.setPage(1)
|
|
snap.setEnforceExactCount(false)
|
|
|
|
const tableName = snap.table?.name
|
|
const schema = snap.table?.schema
|
|
|
|
if (tableName) {
|
|
saveTableEditorStateToLocalStorage({
|
|
projectRef,
|
|
tableName,
|
|
schema,
|
|
...dataToSave,
|
|
})
|
|
} else {
|
|
console.warn('[useSaveTableEditorState] Table name missing, skipping localStorage save.')
|
|
}
|
|
} catch (error) {
|
|
console.error('[useSaveTableEditorState] Error during interaction with snapshot:', error)
|
|
}
|
|
},
|
|
[snap, project]
|
|
)
|
|
|
|
const saveFiltersAndTriggerSideEffects = useCallback(
|
|
(urlFilters: string[]) => saveDataAndTriggerSideEffects({ filters: urlFilters }),
|
|
[saveDataAndTriggerSideEffects]
|
|
)
|
|
const saveSortsAndTriggerSideEffects = useCallback(
|
|
(urlSorts: string[]) => saveDataAndTriggerSideEffects({ sorts: urlSorts }),
|
|
[saveDataAndTriggerSideEffects]
|
|
)
|
|
|
|
return { saveFiltersAndTriggerSideEffects, saveSortsAndTriggerSideEffects }
|
|
}
|