[Spaces] M10.6 Space preview bottom sheet #4497

This commit is contained in:
Gil Eluard
2021-09-06 07:46:43 +03:00
parent 7dd4af28b6
commit fd5d96aff9
25 changed files with 978 additions and 27 deletions
@@ -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) {