Merge pull request #15272 from Budibase/typing/stores-grid-resize

Typing grid resize store
This commit is contained in:
Adria Navarro 2024-12-31 12:36:20 +01:00 committed by GitHub
commit 2bc5b720dc
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 35 additions and 11 deletions

View File

@ -85,7 +85,8 @@ export type Store = BaseStore &
bounds: Readable<any>
height: Readable<number>
} & Rows.Store &
Reorder.Store
Reorder.Store &
Resize.Store
export const attachStores = (context: Store): Store => {
// Atomic store creation

View File

@ -1,8 +1,19 @@
import { writable, get, derived } from "svelte/store"
import { writable, get, derived, Writable, Readable } from "svelte/store"
import { MinColumnWidth, DefaultColumnWidth } from "../lib/constants"
import { parseEventLocation } from "../lib/utils"
import { Store as StoreContext } from "."
import { UIColumn } from "@budibase/types"
const initialState = {
interface ResizeInitialStoreData {
initialMouseX: number | null
initialWidth: number | null
column: string | null
width: number
left: number
related?: UIColumn["related"]
}
const initialState: ResizeInitialStoreData = {
initialMouseX: null,
initialWidth: null,
column: null,
@ -10,7 +21,14 @@ const initialState = {
left: 0,
}
export const createStores = () => {
interface ResizeInitialStore {
resize: Writable<ResizeInitialStoreData>
isResizing: Readable<boolean>
}
export type Store = ResizeInitialStore
export const createStores = (): ResizeInitialStore => {
const resize = writable(initialState)
const isResizing = derived(resize, $resize => $resize.column != null, false)
return {
@ -19,11 +37,11 @@ export const createStores = () => {
}
}
export const createActions = context => {
export const createActions = (context: StoreContext) => {
const { resize, ui, datasource } = context
// Starts resizing a certain column
const startResizing = (column, e) => {
const startResizing = (column: UIColumn, e: MouseEvent | TouchEvent) => {
const { x } = parseEventLocation(e)
// Prevent propagation to stop reordering triggering
@ -50,11 +68,11 @@ export const createActions = context => {
}
// Handler for moving the mouse to resize columns
const onResizeMouseMove = e => {
const onResizeMouseMove = (e: MouseEvent | TouchEvent) => {
const { initialMouseX, initialWidth, width, column, related } = get(resize)
const { x } = parseEventLocation(e)
const dx = x - initialMouseX
const newWidth = Math.round(Math.max(MinColumnWidth, initialWidth + dx))
const dx = x - initialMouseX!
const newWidth = Math.round(Math.max(MinColumnWidth, initialWidth! + dx))
// Ignore small changes
if (Math.abs(width - newWidth) < 5) {
@ -63,7 +81,7 @@ export const createActions = context => {
// Update column state
if (!related) {
datasource.actions.addSchemaMutation(column, { width })
datasource.actions.addSchemaMutation(column!, { width })
} else {
datasource.actions.addSubSchemaMutation(related.subField, related.field, {
width,
@ -95,7 +113,7 @@ export const createActions = context => {
}
// Resets a column size back to default
const resetSize = async column => {
const resetSize = async (column: { name: string }) => {
datasource.actions.addSchemaMutation(column.name, {
width: DefaultColumnWidth,
})

View File

@ -52,6 +52,11 @@ interface UIActionStore {
selectRange: (source: string | null, target: string | null) => void
}
}
ui: {
actions: {
blur: () => void
}
}
}
export type Store = UIStore & UIDerivedStore & UIActionStore