1
0
mirror of https://github.com/mattermost/focalboard.git synced 2025-01-17 18:26:17 +02:00

Fix some strictNullChecks

This commit is contained in:
Chen-I Lim 2020-11-12 11:29:48 -08:00
parent 44f0a2e65b
commit 3504dff72e
4 changed files with 25 additions and 23 deletions

View File

@ -10,7 +10,7 @@ type ISortOption = { propertyId: '__title' | string, reversed: boolean }
interface BoardView extends IBlock {
readonly viewType: IViewType
readonly groupById: string
readonly groupById?: string
readonly sortOptions: readonly ISortOption[]
readonly visiblePropertyIds: readonly string[]
readonly visibleOptionIds: readonly string[]
@ -20,7 +20,7 @@ interface BoardView extends IBlock {
readonly columnWidths: Readonly<Record<string, number>>
}
class MutableBoardView extends MutableBlock {
class MutableBoardView extends MutableBlock implements BoardView {
get viewType(): IViewType {
return this.fields.viewType
}

View File

@ -11,6 +11,7 @@ import {OctoListener} from '../octoListener'
import {Utils} from '../utils'
import {MutableWorkspaceTree, WorkspaceTree} from '../viewModel/workspaceTree'
import {IBlock} from '../blocks/block'
import { isReturnStatement } from 'typescript'
type Props = {
setLanguage: (lang: string) => void
@ -24,18 +25,13 @@ type State = {
}
export default class BoardPage extends React.Component<Props, State> {
view: BoardView
updateTitleTimeout: number
updatePropertyLabelTimeout: number
private workspaceListener = new OctoListener()
constructor(props: Props) {
super(props)
const queryString = new URLSearchParams(window.location.search)
const boardId = queryString.get('id')
const viewId = queryString.get('v')
const boardId = queryString.get('id') || ''
const viewId = queryString.get('v') || ''
this.state = {
boardId,
@ -180,7 +176,7 @@ export default class BoardPage extends React.Component<Props, State> {
this.setState({
boardTree,
boardId,
viewId: boardTree.activeView.id,
viewId: boardTree.activeView!.id,
})
Utils.log(`sync complete: ${boardTree.board.id} (${boardTree.board.title})`)
}
@ -220,7 +216,7 @@ export default class BoardPage extends React.Component<Props, State> {
}
showView(viewId: string, boardId: string = this.state.boardId): void {
if (this.state.boardId === boardId) {
if (this.state.boardTree && this.state.boardId === boardId) {
const newBoardTree = this.state.boardTree.mutableCopy()
newBoardTree.setActiveView(viewId)
this.setState({boardTree: newBoardTree, viewId})
@ -233,6 +229,11 @@ export default class BoardPage extends React.Component<Props, State> {
}
setSearchText(text?: string): void {
if (!this.state.boardTree) {
Utils.assertFailure('setSearchText: boardTree')
return
}
const newBoardTree = this.state.boardTree.mutableCopy()
newBoardTree.setSearchText(text)
this.setState({boardTree: newBoardTree})

View File

@ -146,10 +146,10 @@ class MutableBoardTree implements BoardTree {
this.cards = this.sortCards(this.cards) as MutableCard[]
Utils.assert(this.cards !== undefined)
if (this.activeView.groupById) {
if (this.activeView?.groupById) {
this.setGroupByProperty(this.activeView.groupById)
} else {
Utils.assert(this.activeView.viewType !== 'board')
Utils.assert(this.activeView?.viewType !== 'board')
}
Utils.assert(this.cards !== undefined)
@ -186,6 +186,10 @@ class MutableBoardTree implements BoardTree {
private groupCards() {
const {activeView, groupByProperty} = this
if (!activeView || !groupByProperty) {
Utils.assertFailure('groupCards')
return
}
const unassignedOptionIds = groupByProperty.options.
filter((o) => !activeView.visibleOptionIds.includes(o.id) && !activeView.hiddenOptionIds.includes(o.id)).
@ -221,7 +225,7 @@ class MutableBoardTree implements BoardTree {
// Empty group
const emptyGroupCards = this.cards.filter((o) => {
const optionId = o.properties[groupByProperty.id]
return !optionId || !this.groupByProperty.options.find((option) => option.id === optionId)
return !optionId || !groupByProperty.options.find((option) => option.id === optionId)
})
const group: Group = {
option: {id: '', value: `No ${groupByProperty.name}`, color: ''},
@ -264,9 +268,7 @@ class MutableBoardTree implements BoardTree {
return cardA.createAt - cardB.createAt
}
private manualOrder(cardA: Card, cardB: Card) {
const {activeView} = this
private manualOrder(activeView: BoardView, cardA: Card, cardB: Card) {
const indexA = activeView.cardOrder.indexOf(cardA.id)
const indexB = activeView.cardOrder.indexOf(cardB.id)
@ -280,17 +282,17 @@ class MutableBoardTree implements BoardTree {
}
private sortCards(cards: Card[]): Card[] {
if (!this.activeView) {
const {board, activeView} = this
if (!activeView) {
Utils.assertFailure()
return cards
}
const {board} = this
const {sortOptions} = this.activeView
const {sortOptions} = activeView
let sortedCards: Card[] = []
if (sortOptions.length < 1) {
Utils.log('Manual sort')
sortedCards = cards.sort((a, b) => this.manualOrder(a, b))
sortedCards = cards.sort((a, b) => this.manualOrder(activeView, a, b))
} else {
sortOptions.forEach((sortOption) => {
if (sortOption.propertyId === Constants.titleColumnId) {

View File

@ -5,7 +5,6 @@ import {IOrderedBlock} from '../blocks/orderedBlock'
import octoClient from '../octoClient'
import {IBlock, MutableBlock} from '../blocks/block'
import {OctoUtils} from '../octoUtils'
import {Utils} from '../utils'
interface CardTree {
readonly card: Card
@ -17,7 +16,7 @@ interface CardTree {
}
class MutableCardTree implements CardTree {
card: MutableCard
card!: MutableCard
comments: IBlock[] = []
contents: IOrderedBlock[] = []