mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-22 17:42:45 +02:00
[Spaces] M10.6 Space preview bottom sheet #4497
This commit is contained in:
@@ -59,16 +59,21 @@ final class SpaceListViewModel: SpaceListViewModelType {
|
||||
switch viewAction {
|
||||
case .loadData:
|
||||
self.loadData()
|
||||
case .selectRow(at: let indexPath):
|
||||
case .selectRow(at: let indexPath, from: let sourceView):
|
||||
let section = self.sections[indexPath.section]
|
||||
switch section {
|
||||
case .home:
|
||||
self.selectHome()
|
||||
self.viewDelegate?.spaceListViewModel(self, didSelectSpaceAt: indexPath)
|
||||
case .spaces(let viewDataList):
|
||||
let spaceViewData = viewDataList[indexPath.row]
|
||||
self.selectSpace(with: spaceViewData.spaceId)
|
||||
if spaceViewData.isInvite {
|
||||
self.selectInvite(with: spaceViewData.spaceId, from: sourceView)
|
||||
} else {
|
||||
self.selectSpace(with: spaceViewData.spaceId)
|
||||
self.viewDelegate?.spaceListViewModel(self, didSelectSpaceAt: indexPath)
|
||||
}
|
||||
}
|
||||
self.viewDelegate?.spaceListViewModel(self, didSelectSpaceAt: indexPath)
|
||||
case .moreAction(at: let indexPath, from: let sourceView):
|
||||
let section = self.sections[indexPath.section]
|
||||
switch section {
|
||||
@@ -80,6 +85,10 @@ final class SpaceListViewModel: SpaceListViewModelType {
|
||||
}
|
||||
}
|
||||
|
||||
func revertItemSelection() {
|
||||
self.viewDelegate?.spaceListViewModelRevertSelection(self)
|
||||
}
|
||||
|
||||
// MARK: - Private
|
||||
|
||||
@objc private func sessionDidSync(notification: Notification) {
|
||||
@@ -94,17 +103,22 @@ final class SpaceListViewModel: SpaceListViewModelType {
|
||||
self.update(viewState: .loading)
|
||||
|
||||
let homeViewData = self.createHomeViewData()
|
||||
|
||||
let spacesViewDataList = getSpacesViewData()
|
||||
|
||||
let sections: [SpaceListSection] = [
|
||||
.home(homeViewData),
|
||||
.spaces(spacesViewDataList)
|
||||
]
|
||||
let viewDataList = getSpacesViewData()
|
||||
|
||||
let sections: [SpaceListSection] = viewDataList.invites.isEmpty ? [
|
||||
.home(homeViewData),
|
||||
.spaces(viewDataList.spaces)
|
||||
]
|
||||
:
|
||||
[
|
||||
.spaces(viewDataList.invites),
|
||||
.home(homeViewData),
|
||||
.spaces(viewDataList.spaces)
|
||||
]
|
||||
|
||||
self.sections = sections
|
||||
|
||||
self.update(viewState: .loaded(sections))
|
||||
let homeIndexPath = viewDataList.invites.isEmpty ? IndexPath(row: 0, section: 0) : IndexPath(row: 0, section: 1)
|
||||
self.update(viewState: .loaded(sections, homeIndexPath))
|
||||
}
|
||||
|
||||
private func selectHome() {
|
||||
@@ -115,19 +129,32 @@ final class SpaceListViewModel: SpaceListViewModelType {
|
||||
self.coordinatorDelegate?.spaceListViewModel(self, didSelectSpaceWithId: spaceId)
|
||||
}
|
||||
|
||||
private func selectInvite(with spaceId: String, from sourceView: UIView?) {
|
||||
self.coordinatorDelegate?.spaceListViewModel(self, didSelectInviteWithId: spaceId, from: sourceView)
|
||||
}
|
||||
|
||||
private func createHomeViewData() -> SpaceListItemViewData {
|
||||
let avatarViewData = AvatarViewData(avatarUrl: nil, mediaManager: self.session.mediaManager, fallbackImage: .image(Asset.Images.spaceHomeIcon.image, .center))
|
||||
|
||||
let homeViewData = SpaceListItemViewData(spaceId: Constants.homeSpaceId,
|
||||
title: VectorL10n.spacesHomeSpaceTitle, avatarViewData: avatarViewData)
|
||||
title: VectorL10n.spacesHomeSpaceTitle, avatarViewData: avatarViewData, isInvite: false)
|
||||
return homeViewData
|
||||
}
|
||||
|
||||
private func getSpacesViewData() -> [SpaceListItemViewData] {
|
||||
return session.spaceService.rootSpaceSummaries.map { summary in
|
||||
private func getSpacesViewData() -> (invites: [SpaceListItemViewData], spaces: [SpaceListItemViewData]) {
|
||||
var invites: [SpaceListItemViewData] = []
|
||||
var spaces: [SpaceListItemViewData] = []
|
||||
session.spaceService.rootSpaceSummaries.forEach { summary in
|
||||
let avatarViewData = AvatarViewData(avatarUrl: summary.avatar, mediaManager: self.session.mediaManager, fallbackImage: .matrixItem(summary.roomId, summary.displayname))
|
||||
return SpaceListItemViewData(spaceId: summary.roomId, title: summary.displayname, avatarViewData: avatarViewData)
|
||||
let viewData = SpaceListItemViewData(spaceId: summary.roomId, title: summary.displayname, avatarViewData: avatarViewData, isInvite: summary.membership == .invite)
|
||||
if viewData.isInvite {
|
||||
invites.append(viewData)
|
||||
} else {
|
||||
spaces.append(viewData)
|
||||
}
|
||||
}
|
||||
|
||||
return (invites, spaces)
|
||||
}
|
||||
|
||||
private func update(viewState: SpaceListViewState) {
|
||||
|
||||
Reference in New Issue
Block a user