Skip to content

Commit

Permalink
Merge pull request #249 from logisky/jh/sheet
Browse files Browse the repository at this point in the history
fix: sheet tab
  • Loading branch information
ImJeremyHe authored Dec 29, 2024
2 parents 9ae7268 + c262061 commit 498f993
Show file tree
Hide file tree
Showing 6 changed files with 97 additions and 29 deletions.
13 changes: 11 additions & 2 deletions src/components/canvas/component.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,8 @@ const canvasHost = () => {
export interface CanvasProps {
selectedCell: SelectedCell
selectedCell$: (e: SelectedCell) => void
activeSheet: number
activeSheet$: (s: number) => void
}
export const CanvasComponent = (props: CanvasProps) => {
const DATA_SERVICE = useInjection<DataServiceImpl>(TYPES.Data)
Expand All @@ -47,7 +49,8 @@ export const CanvasComponent = (props: CanvasProps) => {
)
}

const Internal: FC<CanvasProps> = observer(({selectedCell, selectedCell$}) => {
const Internal: FC<CanvasProps> = observer((props: CanvasProps) => {
const {selectedCell, selectedCell$, activeSheet, activeSheet$} = props
const store = useContext(CanvasStoreContext)
const [contextmenuOpen, setContextMenuOpen] = useState(false)
const [invalidFormulaWarning, setInvalidFormulaWarning] = useState(false)
Expand Down Expand Up @@ -77,6 +80,12 @@ const Internal: FC<CanvasProps> = observer(({selectedCell, selectedCell$}) => {
store.textarea.reset()
}, [selectedCell])

useEffect(() => {
store.render.canvas.focus()
store.dataSvc.setCurrentSheetIdx(activeSheet)
store.render.render()
}, [activeSheet])

useEffect(() => {
const sub = on(window, EventType.MOUSE_MOVE).subscribe((mme) => {
mme.preventDefault()
Expand Down Expand Up @@ -129,7 +138,7 @@ const Internal: FC<CanvasProps> = observer(({selectedCell, selectedCell$}) => {
const onMouseWheel = (e: WheelEvent) => {
// only support y scrollbar currently
if (store.anchorY + e.deltaY < 0) return
store.anchorY += e.deltaY
store.setAnchor(store.anchorX, store.anchorY + e.deltaY)

const now = Date.now()
if (now - lastScrollTime < 50) return
Expand Down
15 changes: 6 additions & 9 deletions src/components/canvas/store/render.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,8 @@
import {makeObservable} from 'mobx'
import {CanvasStore} from './store'
import {Box, CanvasAttr, PainterService, TextAttr} from '@/core/painter'
import {pxToPt, simpleUuid, toA1notation} from '@/core'
import {
CellViewData,
CellViewRespType,
RenderCell,
toCanvasPosition,
} from '@/core/data2'
import {simpleUuid, toA1notation} from '@/core'
import {CellViewData, RenderCell, toCanvasPosition} from '@/core/data2'
import {LeftTop, SETTINGS} from '@/core/settings'
import {StandardColor, Range, StandardCell} from '@/core/standable'
import {StandardStyle} from '@/core/standable/style'
Expand Down Expand Up @@ -71,8 +66,10 @@ export class Render {
if (!data) return
const firstRow = data.rows[0]
const firstCol = data.cols[0]
this.store.anchorY = firstRow.position.startRow
this.store.anchorX = firstCol.position.startCol
this.store.setAnchor(
firstRow.position.startRow,
firstCol.position.startCol
)
this.render()
})
}
Expand Down
30 changes: 27 additions & 3 deletions src/components/canvas/store/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,7 @@ export class CanvasStore {
* left mousedown the same cell
*/
same = false
currSheetIdx = 0

anchorX = 0
anchorY = 0
render: Render
resizer: Resizer
highlights: Highlights
Expand All @@ -43,6 +40,28 @@ export class CanvasStore {
scrollbar: ScrollBar
textarea: Textarea

get currSheetIdx() {
return this.dataSvc.getCurrentSheetIdx()
}

get anchorX() {
return this._sheetAnchorData.get(this.currSheetIdx)?.anchorX ?? 0
}

get anchorY() {
return this._sheetAnchorData.get(this.currSheetIdx)?.anchorY ?? 0
}

setAnchor(x: number, y: number) {
const data = this._sheetAnchorData.get(this.currSheetIdx) ?? {
anchorX: 0,
anchorY: 0,
}
data.anchorX = x
data.anchorY = y
this._sheetAnchorData.set(this.currSheetIdx, data)
}

getCurrentCellView(): readonly CellViewData[] {
return this.dataSvc.getCurrentCellView(this.currSheetIdx)
}
Expand Down Expand Up @@ -129,6 +148,11 @@ export class CanvasStore {
this.same = true
this.selector.onScroll(newStartCell)
}

private _sheetAnchorData = new Map<
number,
{anchorX: number; anchorY: number}
>()
}

// @ts-expect-error init data when use
Expand Down
10 changes: 8 additions & 2 deletions src/components/content/index.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import {SelectedCell, CanvasComponent} from '@/components/canvas'
import {FC} from 'react'
import {FC, useState} from 'react'
import styles from './content.module.scss'
import {EditBarComponent} from './edit-bar'
import {SheetsTabComponent} from '@/components/sheets-tab'
Expand All @@ -13,6 +13,7 @@ export const ContentComponent: FC<ContentProps> = ({
selectedCell$,
selectedCell,
}) => {
const [activeSheet, activeSheet$] = useState<number>(0)
return (
<div className={styles.host}>
<EditBarComponent
Expand All @@ -24,10 +25,15 @@ export const ContentComponent: FC<ContentProps> = ({
<CanvasComponent
selectedCell={selectedCell}
selectedCell$={selectedCell$}
activeSheet={activeSheet}
activeSheet$={activeSheet$}
/>
</div>
</div>
<SheetsTabComponent />
<SheetsTabComponent
activeSheet={activeSheet}
activeSheet$={activeSheet$}
/>
</div>
)
}
54 changes: 43 additions & 11 deletions src/components/sheets-tab/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,15 @@ import {Tabs} from 'antd'
import {Subscription} from 'rxjs'
import {DataService} from '@/core/data2'

export type SheetsTabprops = Record<string, unknown>
export interface SheetTabProps {
activeSheet: number
activeSheet$: (s: number) => void
}

export const SheetsTabComponent: FC<SheetsTabprops> = () => {
export const SheetsTabComponent: FC<SheetTabProps> = ({
activeSheet,
activeSheet$,
}) => {
const DATA_SERVICE = useInjection<DataService>(TYPES.Data)
const getSheets = () => {
const sheetInfo = DATA_SERVICE.getAllSheetInfo().then((info) => {
Expand All @@ -24,9 +30,14 @@ export const SheetsTabComponent: FC<SheetsTabprops> = () => {
return sheetInfo
}
const [sheets, setSheets] = useState([] as string[])
const [active, setActive] = useState(0)
const [isOpen, setIsOpen] = useState(false)

useEffect(() => {
getSheets().then((v) => {
if (v) setSheets(v)
})
}, [])

useEffect(() => {
const subs = new Subscription()
subs.add(
Expand All @@ -43,12 +54,12 @@ export const SheetsTabComponent: FC<SheetsTabprops> = () => {

const onTabChange = (key: string) => {
const i = sheets.findIndex((s) => s === key)
setActive(i)
DATA_SERVICE.setCurrentSheetIDx(i)
activeSheet$(i)
DATA_SERVICE.setCurrentSheetIdx(i)
}

const add = () => {
const payload = new InsertSheetBuilder().sheetIdx(active).build()
const payload = new InsertSheetBuilder().sheetIdx(activeSheet).build()
DATA_SERVICE.handleTransaction(new Transaction([payload], true))
}

Expand All @@ -69,7 +80,7 @@ export const SheetsTabComponent: FC<SheetsTabprops> = () => {
onContextMenu={(e) => {
e.preventDefault()
e.stopPropagation()
setActive(i)
activeSheet$(i)
setIsOpen(true)
}}
>
Expand All @@ -81,26 +92,47 @@ export const SheetsTabComponent: FC<SheetsTabprops> = () => {
onChange={onTabChange}
onEdit={(e, action) => {
if (action === 'add') {
const newSheetName = findNewSheetName(sheets)
const newIdx = sheets.length
const payload = new InsertSheetBuilder()
.sheetIdx(sheets.length)
.name(newSheetName)
.sheetIdx(newIdx)
.build()
DATA_SERVICE.handleTransaction(
new Transaction([payload], true)
)
).then((v) => {
if (isErrorMessage(v)) return
activeSheet$(newIdx)
})
} else if (action === 'remove') {
if (typeof e !== 'string') return
const i = sheets.findIndex((s) => s === e)
onDelete(i)
}
}}
activeKey={sheets[active]}
activeKey={sheets[activeSheet]}
/>
<ContextMenuComponent
isOpen={isOpen}
setIsOpen={setIsOpen}
index={active}
index={activeSheet}
sheetnames={sheets}
/>
</div>
)
}

function findNewSheetName(sheetNames: readonly string[]): string {
const sheetPattern = /^Sheet(\d+)$/

const numbers = sheetNames
.map((name) => {
const match = name.match(sheetPattern)
return match ? parseInt(match[1], 10) : null
})
.filter((num): num is number => num !== null)

const nextNumber = numbers.length > 0 ? Math.max(...numbers) + 1 : 1

return `Sheet${nextNumber}`
}
4 changes: 2 additions & 2 deletions src/core/data2/service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ export interface DataService {
getCurrentCellView(sheetIdx: number): readonly CellViewData[]

getCurrentSheetIdx(): number
setCurrentSheetIDx(idx: number): void
setCurrentSheetIdx(idx: number): void

getAllSheetInfo(): Resp<readonly SheetInfo[]>
getCellInfo(sheetIdx: number, row: number, col: number): Resp<Cell>
Expand Down Expand Up @@ -104,7 +104,7 @@ export class DataServiceImpl implements DataService {
return this._sheetIdx
}

public setCurrentSheetIDx(idx: number): void {
public setCurrentSheetIdx(idx: number): void {
this._sheetIdx = idx
}

Expand Down

0 comments on commit 498f993

Please sign in to comment.