From edea0511dd902c3ae41030a645b356e67b8cd560 Mon Sep 17 00:00:00 2001 From: distiller Date: Wed, 4 Dec 2024 07:38:22 +0000 Subject: [PATCH] Release - swiftui/1.0.0 --- CHANGELOG.md | 337 +- Package.swift | 6 +- .../project.pbxproj | 8686 ++++++++--------- .../CustomSampleSubViewModel.swift | 3 + .../CustomCreateGroupChannel.swift | 3 + ...GroupChannel.SwiftUI.View.CustomMain.swift | 3 + ...CreateGroupChannel.SwiftUI.View.Main.swift | 3 + ...hannel.ViewConverter.Header.leftView.swift | 3 + ...annel.ViewConverter.Header.rightView.swift | 3 + ...annel.ViewConverter.Header.titleView.swift | 3 + ...hannel.ViewConverter.List.entireView.swift | 22 +- ...nnel.ViewConverter.List.profileImage.swift | 3 + ...upChannel.ViewConverter.List.rowView.swift | 3 + ...l.ViewConverter.List.selectionButton.swift | 3 + ...nel.ViewConverter.List.userNameLabel.swift | 3 + .../CustomCreateOpenChannel.swift | 3 + ...eOpenChannel.SwiftUI.View.CustomMain.swift | 3 + ...mCreateOpenChannel.SwiftUI.View.Main.swift | 3 + ...hannel.ViewConverter.Header.leftView.swift | 3 + ...annel.ViewConverter.Header.rightView.swift | 3 + ...annel.ViewConverter.Header.titleView.swift | 3 + ...hannel.ViewConverter.List.entireView.swift | 3 + ...nnel.ViewConverter.List.profileImage.swift | 3 + ...enChannel.ViewConverter.List.rowView.swift | 3 + ...l.ViewConverter.List.selectionButton.swift | 3 + ...nel.ViewConverter.List.userNameLabel.swift | 3 + .../CustomGroupBannedUserList.swift | 10 +- ...nnedUserList.SwiftUI.View.CustomMain.swift | 5 +- ...roupBannedUserList.SwiftUI.View.Main.swift | 7 +- ...erList.ViewConverter.Header.leftView.swift | 5 +- ...rList.ViewConverter.Header.rightView.swift | 5 +- ...rList.ViewConverter.Header.titleView.swift | 5 +- ...erList.ViewConverter.List.entireView.swift | 17 +- ...erList.ViewConverter.List.moreButton.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...dUserList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../GroupChannel/CustomGroupChannel.swift | 7 +- ...nnel.SubView.Builder.channelSettings.swift | 9 +- ...hannel.SubView.Builder.messageThread.swift | 12 +- ...GroupChannel.SwiftUI.View.CustomMain.swift | 5 +- ...CustomGroupChannel.SwiftUI.View.Main.swift | 16 +- ...nnel.ViewConverter.Header.coverImage.swift | 5 +- ...hannel.ViewConverter.Header.leftView.swift | 5 +- ...annel.ViewConverter.Header.rightView.swift | 5 +- ...nnel.ViewConverter.Header.titleLabel.swift | 5 +- ...annel.ViewConverter.Header.titleView.swift | 5 +- ...iewConverter.Header.typingStatusView.swift | 5 +- ...hannel.ViewConverter.Input.addButton.swift | 5 +- ...annel.ViewConverter.Input.entireView.swift | 3 + ...Channel.ViewConverter.Input.leftView.swift | 5 +- ...hannel.ViewConverter.Input.rightView.swift | 5 +- ...annel.ViewConverter.Input.sendButton.swift | 5 +- ...nnel.ViewConverter.Input.voiceButton.swift | 5 +- ....ViewConverter.List.adminMessageView.swift | 5 +- ...iewConverter.List.channelStateBanner.swift | 5 +- ...hannel.ViewConverter.List.entireView.swift | 15 +- ...l.ViewConverter.List.fileMessageView.swift | 5 +- ...verter.List.multipleFilesMessageView.swift | 5 +- ...iewConverter.List.newMessageInfoView.swift | 5 +- ...upChannel.ViewConverter.List.rowView.swift | 5 +- ....ViewConverter.List.scrollBottomView.swift | 5 +- ...iewConverter.List.senderProfileImage.swift | 5 +- ...ewConverter.List.typingIndicatorView.swift | 5 +- ...l.ViewConverter.List.userMessageView.swift | 5 +- ...oupChannel.SwiftUI.View.ViewProvider.swift | 83 + .../CustomGroupChannelList.swift | 3 + ...elList.SubView.Builder.createChannel.swift | 9 +- ...nelList.SubView.Builder.groupChannel.swift | 11 +- ...pChannelList.SwiftUI.View.CustomMain.swift | 3 + ...omGroupChannelList.SwiftUI.View.Main.swift | 3 + ...elList.ViewConverter.Header.leftView.swift | 3 + ...lList.ViewConverter.Header.rightView.swift | 3 + ...lList.ViewConverter.Header.titleView.swift | 3 + ...lList.ViewConverter.List.channelName.swift | 3 + ...st.ViewConverter.List.channelPreview.swift | 3 + ...elList.ViewConverter.List.coverImage.swift | 3 + ...elList.ViewConverter.List.entireView.swift | 17 +- ...annelList.ViewConverter.List.rowView.swift | 3 + ...lList.ViewConverter.List.unreadCount.swift | 3 + ...hannelList.SwiftUI.View.ViewProvider.swift | 58 + .../CustomGroupChannelPushSettings.swift | 7 +- ...PushSettings.SwiftUI.View.CustomMain.swift | 5 +- ...hannelPushSettings.SwiftUI.View.Main.swift | 7 +- ...ttings.ViewConverter.Header.leftView.swift | 5 +- ...tings.ViewConverter.Header.rightView.swift | 5 +- ...tings.ViewConverter.Header.titleView.swift | 5 +- ...ttings.ViewConverter.List.entireView.swift | 7 +- .../CustomGroupChannelRegisterOperator.swift | 5 +- ...sterOperator.SwiftUI.View.CustomMain.swift | 5 +- ...elRegisterOperator.SwiftUI.View.Main.swift | 5 +- ...erator.ViewConverter.Header.leftView.swift | 5 +- ...rator.ViewConverter.Header.rightView.swift | 5 +- ...rator.ViewConverter.Header.titleView.swift | 5 +- ...erator.ViewConverter.List.entireView.swift | 5 +- .../CustomGroupChannelSettings.swift | 5 +- ...Settings.SubView.Builder.moderations.swift | 9 +- ...ettings.SubView.Builder.pushSettings.swift | 11 +- ...nelSettings.SubView.Builder.userList.swift | 9 +- ...nnelSettings.SwiftUI.View.CustomMain.swift | 6 +- ...oupChannelSettings.SwiftUI.View.Main.swift | 5 +- ...ttings.ViewConverter.Header.leftView.swift | 5 +- ...tings.ViewConverter.Header.rightView.swift | 5 +- ...tings.ViewConverter.Header.titleView.swift | 5 +- ...tings.ViewConverter.List.channelInfo.swift | 5 +- ...ttings.ViewConverter.List.entireView.swift | 12 +- ...ings.ViewConverter.List.leaveChannel.swift | 5 +- ...elSettings.ViewConverter.List.member.swift | 5 +- ...ttings.ViewConverter.List.moderation.swift | 5 +- ...ings.ViewConverter.List.notification.swift | 5 +- ...ttings.ViewConverter.List.searchItem.swift | 5 +- .../CustomGroupMemberList.swift | 7 +- ...emberList.SubView.Builder.inviteUser.swift | 9 +- ...upMemberList.SwiftUI.View.CustomMain.swift | 5 +- ...tomGroupMemberList.SwiftUI.View.Main.swift | 7 +- ...erList.ViewConverter.Header.leftView.swift | 5 +- ...rList.ViewConverter.Header.rightView.swift | 5 +- ...rList.ViewConverter.Header.titleView.swift | 5 +- ...erList.ViewConverter.List.entireView.swift | 69 +- ...erList.ViewConverter.List.moreButton.swift | 5 +- ...ViewConverter.List.operatorStateView.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...emberList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../CustomGroupModerations.swift | 5 +- ...pModerations.SwiftUI.View.CustomMain.swift | 5 +- ...omGroupModerations.SwiftUI.View.Main.swift | 5 +- ...ations.ViewConverter.Header.leftView.swift | 5 +- ...tions.ViewConverter.Header.rightView.swift | 5 +- ...tions.ViewConverter.Header.titleView.swift | 5 +- ...ations.ViewConverter.List.entireView.swift | 5 +- .../CustomGroupMutedMemberList.swift | 7 +- ...edMemberList.SwiftUI.View.CustomMain.swift | 5 +- ...oupMutedMemberList.SwiftUI.View.Main.swift | 7 +- ...erList.ViewConverter.Header.leftView.swift | 5 +- ...rList.ViewConverter.Header.rightView.swift | 5 +- ...rList.ViewConverter.Header.titleView.swift | 5 +- ...erList.ViewConverter.List.entireView.swift | 17 +- ...erList.ViewConverter.List.moreButton.swift | 5 +- ...ViewConverter.List.operatorStateView.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...emberList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../CustomGroupOperatorList.swift | 7 +- ...ist.SubView.Builder.registerOperator.swift | 7 +- ...OperatorList.SwiftUI.View.CustomMain.swift | 5 +- ...mGroupOperatorList.SwiftUI.View.Main.swift | 5 +- ...orList.ViewConverter.Header.leftView.swift | 5 +- ...rList.ViewConverter.Header.rightView.swift | 5 +- ...rList.ViewConverter.Header.titleView.swift | 5 +- ...orList.ViewConverter.List.entireView.swift | 17 +- ...orList.ViewConverter.List.moreButton.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...ratorList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../InviteUser/CustomInviteUser.swift | 5 +- ...omInviteUser.SwiftUI.View.CustomMain.swift | 5 +- .../CustomInviteUser.SwiftUI.View.Main.swift | 5 +- ...teUser.ViewConverter.Header.leftView.swift | 5 +- ...eUser.ViewConverter.Header.rightView.swift | 5 +- ...eUser.ViewConverter.Header.titleView.swift | 5 +- ...teUser.ViewConverter.List.entireView.swift | 21 +- ...User.ViewConverter.List.profileImage.swift | 5 +- ...nviteUser.ViewConverter.List.rowView.swift | 5 +- ...r.ViewConverter.List.selectionButton.swift | 5 +- ...ser.ViewConverter.List.userNameLabel.swift | 5 +- .../MessageSearch/CustomMessageSearch.swift | 7 +- ...eSearch.SubView.Builder.groupChannel.swift | 19 +- ...essageSearch.SwiftUI.View.CustomMain.swift | 3 + ...ustomMessageSearch.SwiftUI.View.Main.swift | 7 +- ...Search.ViewConverter.Header.leftView.swift | 3 + ...earch.ViewConverter.Header.rightView.swift | 3 + ...earch.ViewConverter.Header.titleView.swift | 3 + ...Search.ViewConverter.List.entireView.swift | 5 +- .../MessageThread/CustomMessageThread.swift | 10 +- ...essageThread.SwiftUI.View.CustomMain.swift | 8 +- ...ustomMessageThread.SwiftUI.View.Main.swift | 9 +- ...Thread.ViewConverter.Header.leftView.swift | 9 +- ...hread.ViewConverter.Header.rightView.swift | 9 +- ...d.ViewConverter.Header.subtitleLabel.swift | 9 +- ...read.ViewConverter.Header.titleLabel.swift | 9 +- ...hread.ViewConverter.Header.titleView.swift | 9 +- ...Thread.ViewConverter.Input.addButton.swift | 9 +- ...hread.ViewConverter.Input.entireView.swift | 3 + ...eThread.ViewConverter.Input.leftView.swift | 9 +- ...Thread.ViewConverter.Input.rightView.swift | 9 +- ...hread.ViewConverter.Input.sendButton.swift | 9 +- ...read.ViewConverter.Input.voiceButton.swift | 9 +- ...iewConverter.List.channelStateBanner.swift | 9 +- ...Thread.ViewConverter.List.entireView.swift | 19 +- ...d.ViewConverter.List.fileMessageView.swift | 9 +- ...verter.List.multipleFilesMessageView.swift | 9 +- ...ageThread.ViewConverter.List.rowView.swift | 9 +- ...iewConverter.List.senderProfileImage.swift | 9 +- ...d.ViewConverter.List.userMessageView.swift | 9 +- ...d.ViewConverter.ParentInfo.dateLabel.swift | 9 +- ...ewConverter.ParentInfo.entireContent.swift | 9 +- ...Converter.ParentInfo.fileContentView.swift | 9 +- ...Converter.ParentInfo.messageTextView.swift | 9 +- ....ViewConverter.ParentInfo.moreButton.swift | 9 +- ...r.ParentInfo.multipleFileContentView.swift | 9 +- ...ViewConverter.ParentInfo.profileView.swift | 9 +- ...iewConverter.ParentInfo.reactionView.swift | 9 +- ....ViewConverter.ParentInfo.replyLabel.swift | 9 +- ...ewConverter.ParentInfo.userNameLabel.swift | 9 +- ...ead.ViewConverter.ParentInfo.webView.swift | 9 +- .../CustomOpenBannedUserList.swift | 5 +- ...nnedUserList.SwiftUI.View.CustomMain.swift | 5 +- ...OpenBannedUserList.SwiftUI.View.Main.swift | 5 +- ...erList.ViewConverter.Header.leftView.swift | 5 +- ...rList.ViewConverter.Header.rightView.swift | 5 +- ...rList.ViewConverter.Header.titleView.swift | 5 +- ...erList.ViewConverter.List.entireView.swift | 17 +- ...erList.ViewConverter.List.moreButton.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...dUserList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../OpenChannel/CustomOpenChannel.swift | 5 +- ...nnel.SubView.Builder.channelSettings.swift | 9 +- ...OpenChannel.SubView.Builder.userList.swift | 7 +- ...mOpenChannel.SwiftUI.View.CustomMain.swift | 5 +- .../CustomOpenChannel.SwiftUI.View.Main.swift | 5 +- ...nnel.ViewConverter.Header.coverImage.swift | 5 +- ...hannel.ViewConverter.Header.leftView.swift | 5 +- ...annel.ViewConverter.Header.rightView.swift | 5 +- ...l.ViewConverter.Header.subtitleLabel.swift | 5 +- ...nnel.ViewConverter.Header.titleLabel.swift | 5 +- ...annel.ViewConverter.Header.titleView.swift | 5 +- ...hannel.ViewConverter.Input.addButton.swift | 5 +- ...annel.ViewConverter.Input.entireView.swift | 3 + ...Channel.ViewConverter.Input.leftView.swift | 5 +- ...hannel.ViewConverter.Input.rightView.swift | 5 +- ...annel.ViewConverter.Input.sendButton.swift | 5 +- ....ViewConverter.List.adminMessageView.swift | 5 +- ...hannel.ViewConverter.List.entireView.swift | 15 +- ...l.ViewConverter.List.fileMessageView.swift | 5 +- ...enChannel.ViewConverter.List.rowView.swift | 5 +- ....ViewConverter.List.scrollBottomView.swift | 5 +- ...iewConverter.List.senderProfileImage.swift | 5 +- ...l.ViewConverter.List.userMessageView.swift | 5 +- ...annel.ViewConverter.Media.entireView.swift | 5 +- .../CustomOpenChannelList.swift | 3 + ...elList.SubView.Builder.createChannel.swift | 3 + ...nnelList.SubView.Builder.openChannel.swift | 10 +- ...nChannelList.SwiftUI.View.CustomMain.swift | 3 + ...tomOpenChannelList.SwiftUI.View.Main.swift | 3 + ...elList.ViewConverter.Header.leftView.swift | 3 + ...lList.ViewConverter.Header.rightView.swift | 3 + ...lList.ViewConverter.Header.titleView.swift | 3 + ...lList.ViewConverter.List.channelName.swift | 3 + ...st.ViewConverter.List.channelPreview.swift | 3 + ...elList.ViewConverter.List.coverImage.swift | 3 + ...elList.ViewConverter.List.entireView.swift | 20 +- ...annelList.ViewConverter.List.rowView.swift | 3 + .../CustomOpenChannelRegisterOperator.swift | 5 +- ...sterOperator.SwiftUI.View.CustomMain.swift | 5 +- ...elRegisterOperator.SwiftUI.View.Main.swift | 5 +- ...erator.ViewConverter.Header.leftView.swift | 5 +- ...rator.ViewConverter.Header.rightView.swift | 5 +- ...rator.ViewConverter.Header.titleView.swift | 5 +- ...erator.ViewConverter.List.entireView.swift | 5 +- .../CustomOpenChannelSettings.swift | 7 +- ...Settings.SubView.Builder.moderations.swift | 9 +- ...nelSettings.SubView.Builder.userList.swift | 11 +- ...nnelSettings.SwiftUI.View.CustomMain.swift | 5 +- ...penChannelSettings.SwiftUI.View.Main.swift | 7 +- ...ttings.ViewConverter.Header.leftView.swift | 5 +- ...tings.ViewConverter.Header.rightView.swift | 5 +- ...tings.ViewConverter.Header.titleView.swift | 5 +- ...ttings.ViewConverter.List.entireView.swift | 7 +- .../CustomOpenModerations.swift | 5 +- ...nModerations.SwiftUI.View.CustomMain.swift | 5 +- ...tomOpenModerations.SwiftUI.View.Main.swift | 5 +- ...ations.ViewConverter.Header.leftView.swift | 5 +- ...tions.ViewConverter.Header.rightView.swift | 5 +- ...tions.ViewConverter.Header.titleView.swift | 5 +- ...ations.ViewConverter.List.entireView.swift | 5 +- .../CustomOpenMutedParticipantList.swift | 7 +- ...ticipantList.SwiftUI.View.CustomMain.swift | 5 +- ...tedParticipantList.SwiftUI.View.Main.swift | 7 +- ...ntList.ViewConverter.Header.leftView.swift | 5 +- ...tList.ViewConverter.Header.rightView.swift | 5 +- ...tList.ViewConverter.Header.titleView.swift | 5 +- ...ntList.ViewConverter.List.entireView.swift | 17 +- ...ntList.ViewConverter.List.moreButton.swift | 5 +- ...ViewConverter.List.operatorStateView.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...ipantList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../CustomOpenOperatorList.swift | 7 +- ...ist.SubView.Builder.registerOperator.swift | 5 +- ...OperatorList.SwiftUI.View.CustomMain.swift | 5 +- ...omOpenOperatorList.SwiftUI.View.Main.swift | 7 +- ...orList.ViewConverter.Header.leftView.swift | 5 +- ...rList.ViewConverter.Header.rightView.swift | 5 +- ...rList.ViewConverter.Header.titleView.swift | 5 +- ...orList.ViewConverter.List.entireView.swift | 17 +- ...orList.ViewConverter.List.moreButton.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...ratorList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../CustomOpenParticipantList.swift | 7 +- ...ticipantList.SwiftUI.View.CustomMain.swift | 5 +- ...penParticipantList.SwiftUI.View.Main.swift | 7 +- ...ntList.ViewConverter.Header.leftView.swift | 5 +- ...tList.ViewConverter.Header.rightView.swift | 5 +- ...tList.ViewConverter.Header.titleView.swift | 5 +- ...ntList.ViewConverter.List.entireView.swift | 17 +- ...ntList.ViewConverter.List.moreButton.swift | 5 +- ...ViewConverter.List.operatorStateView.swift | 5 +- ...List.ViewConverter.List.profileImage.swift | 5 +- ...ipantList.ViewConverter.List.rowView.swift | 5 +- ...ist.ViewConverter.List.userNameLabel.swift | 5 +- .../CustomTheme.ColorSet.Custom.Main.swift | 3 + .../CustomViews/Theme/CustomTheme.swift | 3 + .../CustomTheme.FontSet.Custom.Main.swift | 3 + .../CustomTheme.IconSet.Custom.Main.swift | 3 + .../CustomTheme.Theme.Custom.Main.swift | 3 + .../CustomSampleManager+SwiftUI.swift | 116 +- .../CustomSampleManager.swift | 15 +- .../SampleListSwiftUI.json | 180 +- .../Views/GroupChannelsView.swift | 45 +- .../Views/OpenChannelsView.swift | 23 +- Sample/README.md | 34 - Sample/project.yml | 4 +- Sample/screenshots/run_sample.png | Bin 52619 -> 0 bytes Sample/screenshots/sample_screenshot.png | Bin 147055 -> 0 bytes Sample/screenshots/screenshots.png | Bin 516271 -> 0 bytes SendbirdSwiftUI.podspec | 6 +- Sources/Info.plist | 24 - .../SwiftUI/Common/Sendbird+Typealias.swift | 12 + .../Protocol/SendbirdUIProvider.swift | 20 + .../CreateGroupChannelView.swift | 64 +- .../CreateGroupChannelViewProvider.swift | 159 + .../CreateOpenChannelView.swift | 44 +- .../CreateOpenChannelViewProvider.swift | 75 + ...eateOpenChannelModule.Header+SwiftUI.swift | 1 + .../GroupBannedUserListView.swift | 74 +- .../GroupBannedUserListViewProvider.swift | 150 + .../GroupChannel/GroupChannelProvider.swift | 297 + .../GroupChannel/GroupChannelView.swift | 116 +- .../SBUBaseMessageCell+SwiftUI.swift | 2 +- .../GroupChannelListView.swift | 86 +- .../GroupChannelListViewProvider.swift | 158 + .../GroupChannelPushSettingsView.swift | 42 +- ...GroupChannelPushSettingsViewProvider.swift | 67 + .../GroupChannelRegisterOperatorView.swift | 62 +- ...pChannelRegisterOperatorViewProvider.swift | 117 + .../GroupChannelSettingsView.swift | 45 +- .../GroupChannelSettingsViewProvider.swift | 73 + .../GroupMemberList/GroupMemberListView.swift | 84 +- .../GroupMemberListViewProvider.swift | 169 + .../GroupMemberListViewConverter.List.swift | 4 +- .../SBUGroupUserListModule.List+SwiftUI.swift | 20 +- .../GroupModerationsView.swift | 47 +- .../GroupModerationsViewProvider.swift | 97 + .../GroupMutedMemberListView.swift | 78 +- .../GroupMutedMemberListViewProvider.swift | 149 + .../GroupOperatorListView.swift | 78 +- .../GroupOperatorListViewProvider.swift | 149 + .../InviteUser/InviteUserView.swift | 61 +- .../InviteUser/InviteUserViewProvider.swift | 74 + .../MessageSearch/MessageSearchView.swift | 41 +- .../MessageSearchViewProvider.swift | 66 + .../MessageThread/MessageThreadView.swift | 147 +- .../MessageThreadViewProvider.swift | 203 + ...aseMessageCell.MessageThread+SwiftUI.swift | 2 +- .../OpenBannedUserListView.swift | 78 +- .../OpenBannedUserListViewProvider.swift | 149 + .../OpenChannel/OpenChannelView.swift | 101 +- .../OpenChannel/OpenChannelViewProvider.swift | 184 + .../OpenChannelList/OpenChannelListView.swift | 68 +- .../OpenChannelListViewProvider.swift | 126 + ...BUOpenChannelListModule.List+SwiftUI.swift | 2 +- .../OpenChannelRegisterOperatorView.swift | 60 +- ...nChannelRegisterOperatorViewProvider.swift | 117 + .../OpenChannelSettingsView.swift | 41 +- .../OpenChannelSettingsViewProvider.swift | 67 + .../OpenModerations/OpenModerationsView.swift | 47 +- .../OpenModerationsViewProvider.swift | 98 + .../OpenMutedParticipantListView.swift | 78 +- ...OpenMutedParticipantListViewProvider.swift | 149 + .../OpenOperatorListView.swift | 78 +- .../OpenOperatorListViewProvider.swift | 149 + .../OpenParticipantListView.swift | 78 +- .../OpenParticipantListViewProvider.swift | 169 + .../SBUOpenUserListModule.List+SwiftUI.swift | 5 +- ...ViewControllerTypeProtocol + swiftUI.swift | 4 +- Sources/SwiftUI/SendbirdSwiftUI-Info.plist | 2 +- .../Util/ProviderWrappedHostingView.swift | 61 + Sources/SwiftUI/Util/StateImpactManager.swift | 17 + .../SwiftUI/Util/SwiftUIViewController.swift | 14 +- .../Mention/SBUMentionConfiguration.swift | 0 .../Mention/SBUUserMentionConfiguration.swift | 0 .../SBUMessageCellConfiguration.swift | 0 .../Replies/SBUReplyConfiguration.swift | 0 .../Configuration/SBUConfig.Base.swift | 0 .../Configuration/SBUConfig.CodingKeys.swift | 0 .../Configuration/SBUConfig.Common.swift | 0 .../SBUConfig.GroupChannel.swift | 0 .../Configuration/SBUConfig.OpenChannel.swift | 0 .../{ => uikit}/Configuration/SBUConfig.swift | 0 .../Configuration/SBUConfigManager.swift | 0 .../Configuration/SBUDashboardConfig.swift | 0 .../SBUScrollPostionConfiguration.swift | 0 .../SBUVoiceMessageConfiguration.swift | 0 .../{ => uikit}/Constant/SBUConstant.swift | 0 .../Constant/SBUDateFormatSet.swift | 0 .../Constant/SBUStringSet.Deprecated.swift | 0 .../{ => uikit}/Constant/SBUStringSet.swift | 0 .../BaseMesssage+SBUIKit.Deprecated.swift | 0 .../SBUBaseMessageCellParams.Deprecated.swift | 0 ...otedBaseMessageViewParams.Deprecated.swift | 0 ...SBUContentBaseMessageCell.Deprecated.swift | 0 ...BaseChannelViewController.Deprecated.swift | 0 ...aseChannelViewController.Unavailable.swift | 0 ...roupChannelViewController.Deprecated.swift | 0 ...oupChannelViewController.Unavailable.swift | 0 ...OpenChannelViewController.Deprecated.swift | 0 ...penChannelViewController.Unavailable.swift | 0 ...ChannelListViewController.Deprecated.swift | 0 ...nelSettingsViewController.Deprecated.swift | 0 ...eateChannelViewController.Deprecated.swift | 0 ...UMemberListViewController.Deprecated.swift | 0 ...ssageSearchViewController.Deprecated.swift | 0 ...ModerationsViewController.Deprecated.swift | 0 .../SBUModerationsViewModel.Deprecated.swift | 0 ...NotificationChannelModule.Deprecated.swift | 0 ...NotificationChannelModule.Deprecated.swift | 0 .../SBUBaseChannelModule.Deprecated.swift | 0 .../SBUGroupChannelModule.Deprecated.swift | 0 .../SBUOpenChannelModule.Deprecated.swift | 0 ...SBUGroupChannelListModule.Deprecated.swift | 0 .../SBUOpenChannelListModule.Deprecated.swift | 0 ...roupChannelSettingsModule.Deprecated.swift | 0 ...OpenChannelSettingsModule.Deprecated.swift | 0 .../SBUMessageSearchModule.Deprecated.swift | 0 .../SBUMessageThreadModule.Deprecated.swift | 0 .../SBUModerationsModule.Deprecated.swift | 0 ...ChannelPushSettingsModule.Deprecated.swift | 0 .../Module/SBUModuleSet.Deprecated.swift | 0 .../SBUCreateChannelModule.Deprecated.swift | 0 ...BUCreateOpenChannelModule.Deprecated.swift | 0 .../SBUInviteUserModule.Deprecated.swift | 0 ...SBURegisterOperatorModule.Deprecated.swift | 0 .../SBUUserListModule.Deprecated.swift | 0 .../SBUBaseViewController.Unavailable.swift | 0 .../SBUCoverImageView.Deprecated.swift | 0 .../Deprecated/SBUEnums.Deprecated.swift | 0 .../Deprecated/SBUForm.Deprecated.swift | 0 .../SBUFormFieldView.Deprecated.swift | 0 .../Deprecated/SBUFormView.Deprecated.swift | 0 .../SBUFormViewParams.Deprecated.swift | 0 .../Deprecated/SBUGlobals.Deprecated.swift | 0 .../SBUTableViewCell.Unavailable.swift | 0 .../Deprecated/SBUTheme.Deprecated.swift | 0 .../Deprecated/SBUView.Unavaliable.swift | 0 .../Deprecated/SendbirdUI.Deprecated.swift | 0 ...eSelectUserViewController.Deprecated.swift | 0 Sources/{ => uikit}/Enums/SBUEnums.swift | 2 +- .../{ => uikit}/Enums/SBUIconSetType.swift | 0 .../Enums/VoiceMessageStatus.swift | 0 .../{ => uikit}/Extension/Array+SBUIKit.swift | 0 .../Extension/CGSize+SBUIKit.swift | 0 .../BaseMessage+SBUIKit.MessageTemplate.swift | 0 .../ChatSDK/BaseMessage+SBUIKit.swift | 2 +- .../ChatSDK/MessageForm+SBUIKit.swift | 0 .../MultipleFilesMessage+SBUIKit.swift | 0 .../ChatSDK/SendbirdChat+SBUIKit.swift | 14 + .../Extension/Collection+SBUIKit.swift | 0 .../{ => uikit}/Extension/Data+SBUIKit.swift | 0 .../{ => uikit}/Extension/Date+SBUIKit.swift | 0 .../{ => uikit}/Extension/Float+SBUIKit.swift | 0 .../Extension/Formatter+SBUIKit.swift | 0 .../NSLayoutConstraint+SBUIKit.swift | 0 .../Extension/NSObject+SBUIKit.swift | 0 .../Extension/Sequence+SBUIKit.swift | 0 .../Extension/String+SBUIKit.swift | 9 + .../Extension/StringProtocol+SBUIKit.swift | 0 .../Extension/Thread+SBUIKit.swift | 0 .../Extension/UIApplication+SBUIKit.swift | 0 .../Extension/UIButton+SBUIKit.swift | 0 .../Extension/UICollectionView+SBUIKit.swift | 0 .../Extension/UIColor+SBUIKit.swift | 0 .../Extension/UIImage+SBUIKit.swift | 0 .../Extension/UIImageView+SBUIKit.swift | 0 .../UINavigationController+SBUIKit.swift | 2 +- .../Extension/UIScrollView+SBUIKit.swift | 0 .../Extension/UIStackView.SBUIKit.swift | 0 .../Extension/UITableView+SBUIKit.swift | 0 .../Extension/UITextField+SBUIKit.swift | 0 .../Extension/UIView+SBUIKit.swift | 0 .../Extension/UIViewController+SBUIKit.swift | 0 .../{ => uikit}/Extension/URL+SBUIKit.swift | 0 .../CacheManager/SBUCacheManager.Config.swift | 0 .../CacheManager/SBUCacheManager.File.swift | 0 .../CacheManager/SBUCacheManager.Image.swift | 0 .../SBUCacheManager.NotificationSetting.swift | 0 .../SBUCacheManager.Template.swift | 0 .../SBUCacheManager.Version.swift | 0 .../CacheManager/SBUCacheManager.swift | 0 .../Manager/SBUDownloadManager.swift | 0 .../{ => uikit}/Manager/SBUEmojiManager.swift | 0 .../Manager/SBUMessageTemplateManager.swift | 60 +- .../SBUNotificationChannelManager.swift | 0 .../Manager/SBUPendingMessageManager.swift | 0 .../Manager/SBUPermissionManager.swift | 0 .../{ => uikit}/Manager/SBUTemplateType.swift | 0 .../SBUTypingIndicatorMessageManager.swift | 0 .../{ => uikit}/Manager/SBUVoicePlayer.swift | 0 .../Manager/SBUVoiceRecorder.swift | 0 .../Processor/SBUMessageTemplate.Binder.swift | 0 .../SBUMessageTemplate.Container.swift | 0 .../SBUMessageTemplate.Coordinator.swift | 0 .../SBUMessageTemplate.Payload.swift | 0 .../SBUMessageTemplate.PayloadType.swift | 0 .../SBUMessageTemplate.TemplateList.swift | 0 .../SBUMessageTemplate.Renderer+Events.swift | 0 ...MessageTemplate.Renderer+RenderItems.swift | 0 ...essageTemplate.Renderer+RenderStyles.swift | 0 .../SBUMessageTemplate.Renderer+Utils.swift | 0 .../SBUMessageTemplate.Renderer.Image.swift | 0 ...essageTemplate.Renderer.RendererType.swift | 0 .../SBUMessageTemplate.Renderer.Views.swift | 0 .../SBUMessageTemplate.Renderer.swift | 0 .../MessageTemplate/SBUMessageTemplate.swift | 0 .../Syntax/SBUMessageTemplate.Action.swift | 0 .../Syntax/SBUMessageTemplate.Decoders.swift | 0 .../SBUMessageTemplate.ErrorMessages.swift | 0 .../SBUMessageTemplate.ImageRatioType.swift | 0 .../SBUMessageTemplate.Syntax.Aligns.swift | 0 ...SBUMessageTemplate.Syntax.Identifier.swift | 0 .../SBUMessageTemplate.Syntax.Item.swift | 0 .../SBUMessageTemplate.Syntax.Sizes.swift | 0 .../SBUMessageTemplate.Syntax.Styles.swift | 0 .../SBUMessageTemplate.Syntax.Types.swift | 0 .../SBUMessageTemplate.Syntax.Views.swift | 0 .../Tester/MessageTemplateParserTest.swift | 0 .../MessageTemplateTestViewController.swift | 0 Sources/{ => uikit}/Model/SBUError.swift | 0 .../Model/SBUExtendedMessagePayload.swift | 0 .../SBUExtendedMessagePayloadForUI.swift | 0 .../{ => uikit}/Model/SBUFeedbackAction.swift | 0 .../Model/SBUHighlightMessageInfo.swift | 0 Sources/{ => uikit}/Model/SBUMention.swift | 0 .../{ => uikit}/Model/SBUMessageCache.swift | 0 .../{ => uikit}/Model/SBUScrollOptions.swift | 0 .../Model/SBUTypingIndicatorInfo.swift | 0 .../Model/SBUTypingIndicatorMessage.swift | 0 Sources/{ => uikit}/Model/SBUUser.swift | 0 .../{ => uikit}/Model/SBUVoiceFileInfo.swift | 0 .../SBUGroupChannelModule.Header.swift | 0 .../SBUGroupChannelModule.Input.swift | 0 .../SBUGroupChannelModule.List.swift | 0 .../GroupChannel/SBUGroupChannelModule.swift | 34 +- ...ChatNotificationChannelModule.Header.swift | 0 ...BUChatNotificationChannelModule.List.swift | 0 .../SBUChatNotificationChannelModule.swift | 0 ...SBUFeedNotificationChannelViewParams.swift | 0 ...ficationChannelModule.CategoryFilter.swift | 0 ...FeedNotificationChannelModule.Header.swift | 0 ...BUFeedNotificationChannelModule.List.swift | 0 .../SBUFeedNotificationChannelModule.swift | 0 .../SBUOpenChannelModule.Header.swift | 2 +- .../SBUOpenChannelModule.Input.swift | 0 .../SBUOpenChannelModule.List.swift | 0 .../SBUOpenChannelModule.Media.swift | 0 .../OpenChannel/SBUOpenChannelModule.swift | 28 +- .../Channel/SBUBaseChannelModule.Header.swift | 8 +- .../Channel/SBUBaseChannelModule.Input.swift | 0 .../Channel/SBUBaseChannelModule.List.swift | 0 .../Module/Channel/SBUBaseChannelModule.swift | 0 .../SBUGroupChannelListModule.Common.swift | 0 .../SBUGroupChannelListModule.Header.swift | 0 .../SBUGroupChannelListModule.List.swift | 0 .../SBUGroupChannelListModule.swift | 22 +- .../SBUOpenChannelListModule.Header.swift | 0 .../SBUOpenChannelListModule.List.swift | 0 .../SBUOpenChannelListModule.swift | 10 +- .../SBUBaseChannelListModule.Header.swift | 8 +- .../SBUBaseChannelListModule.List.swift | 0 .../SBUBaseChannelListModule.swift | 0 .../SBUChannelSettingItem.swift | 0 ...SBUGroupChannelSettingsModule.Header.swift | 4 +- .../SBUGroupChannelSettingsModule.List.swift | 0 .../SBUGroupChannelSettingsModule.swift | 10 +- .../SBUOpenChannelSettingsModule.Header.swift | 4 +- .../SBUOpenChannelSettingsModule.List.swift | 0 .../SBUOpenChannelSettingsModule.swift | 10 +- .../SBUBaseChannelSettingsModule.Header.swift | 4 +- .../SBUBaseChannelSettingsModule.List.swift | 0 .../SBUBaseChannelSettingsModule.swift | 0 .../Module/Common/SBUCommonModule.swift | 8 +- .../SBUMessageSearchModule.Header.swift | 2 +- .../SBUMessageSearchModule.List.swift | 0 .../SBUMessageSearchModule.swift | 10 +- .../SBUMessageThreadModule.Header.swift | 0 .../SBUMessageThreadModule.Input.swift | 0 .../SBUMessageThreadModule.List.swift | 0 .../SBUMessageThreadModule.swift | 30 +- .../SBUModerationsModule.Header.swift | 8 +- .../SBUModerationsModule.List.swift | 0 .../Moderations/SBUModerationsModule.swift | 6 +- ...roupChannelPushSettingsModule.Header.swift | 8 +- ...UGroupChannelPushSettingsModule.List.swift | 0 .../SBUGroupChannelPushSettingsModule.swift | 8 +- Sources/{ => uikit}/Module/SBUModuleSet.swift | 2 +- .../SBUCreateChannelModule.Header.swift | 4 +- .../SBUCreateChannelModule.List.swift | 0 .../SBUCreateChannelModule.swift | 10 +- .../SBUCreateOpenChannelModule.Header.swift | 8 +- ...CreateOpenChannelModule.ProfileInput.swift | 0 .../SBUCreateOpenChannelModule.swift | 10 +- .../SBUInviteUserModule.Header.swift | 4 +- .../InviteUser/SBUInviteUserModule.List.swift | 0 .../InviteUser/SBUInviteUserModule.swift | 10 +- .../SBURegisterOperatorModule.Header.swift | 4 +- .../SBURegisterOperatorModule.List.swift | 0 .../SBURegisterOperatorModule.swift | 10 +- .../SBUBaseSelectUserModule.Header.swift | 4 +- .../SBUBaseSelectUserModule.List.swift | 0 .../SelectUser/SBUBaseSelectUserModule.swift | 0 .../UserList/SBUUserListModule.Header.swift | 8 +- .../UserList/SBUUserListModule.List.swift | 0 .../Module/UserList/SBUUserListModule.swift | 10 +- Sources/{ => uikit}/PrivacyInfo.xcprivacy | 0 .../Protocol/CommonProtocols.swift | 0 .../Resource/Assets.xcassets/Contents.json | 0 .../iconAdd.imageset/Contents.json | 0 .../iconAdd.imageset/iconAdd.png | Bin .../iconAdd.imageset/iconAdd@2x.png | Bin .../iconAdd.imageset/iconAdd@3x.png | Bin .../iconBack.imageset/Contents.json | 0 .../iconBack.imageset/iconBack.png | Bin .../iconBack.imageset/iconBack@2x.png | Bin .../iconBack.imageset/iconBack@3x.png | Bin .../iconBack.imageset/iconBackRTL.png | Bin .../iconBack.imageset/iconBackRTL@2x.png | Bin .../iconBack.imageset/iconBackRTL@3x.png | Bin .../iconBad.imageset/Contents.json | 0 .../iconBad.imageset/icon-bad.png | Bin .../iconBad.imageset/icon-bad@2x.png | Bin .../iconBad.imageset/icon-bad@3x.png | Bin .../iconBan.imageset/Contents.json | 0 .../iconBan.imageset/iconBan.png | Bin .../iconBan.imageset/iconBan@2x.png | Bin .../iconBan.imageset/iconBan@3x.png | Bin .../iconBroadcast.imageset/Contents.json | 0 .../iconBroadcast.imageset/iconBroadcast.png | Bin .../iconBroadcast@2x.png | Bin .../iconBroadcast@3x.png | Bin .../iconBroadcastRTL.png | Bin .../iconBroadcastRTL@2x.png | Bin .../iconBroadcastRTL@3x.png | Bin .../iconCamera.imageset/Contents.json | 0 .../iconCamera.imageset/iconCamera.png | Bin .../iconCamera.imageset/iconCamera@2x.png | Bin .../iconCamera.imageset/iconCamera@3x.png | Bin .../iconChannels.imageset/Contents.json | 0 .../iconChannels.imageset/iconChannels.png | Bin .../iconChannels.imageset/iconChannels@2x.png | Bin .../iconChannels.imageset/iconChannels@3x.png | Bin .../iconChat.imageset/Contents.json | 0 .../iconChat.imageset/iconChat.png | Bin .../iconChat.imageset/iconChat@2x.png | Bin .../iconChat.imageset/iconChat@3x.png | Bin .../iconChat.imageset/iconChatRTL.png | Bin .../iconChat.imageset/iconChatRTL@2x.png | Bin .../iconChat.imageset/iconChatRTL@3x.png | Bin .../Contents.json | 0 .../iconCheckboxChecked.png | Bin .../iconCheckboxChecked@2x.png | Bin .../iconCheckboxChecked@3x.png | Bin .../Contents.json | 0 .../iconCheckboxUnchecked.png | Bin .../iconCheckboxUnchecked@2x.png | Bin .../iconCheckboxUnchecked@3x.png | Bin .../iconChevronDown.imageset/Contents.json | 0 .../iconChevronDown.png | Bin .../iconChevronDown@2x.png | Bin .../iconChevronDown@3x.png | Bin .../iconChevronRight.imageset/Contents.json | 0 .../iconChevronRight.png | Bin .../iconChevronRight@2x.png | Bin .../iconChevronRight@3x.png | Bin .../iconChevronRightRTL.png | Bin .../iconChevronRightRTL@2x.png | Bin .../iconChevronRightRTL@3x.png | Bin .../iconClose.imageset/Contents.json | 0 .../iconClose.imageset/iconClose.png | Bin .../iconClose.imageset/iconClose@2x.png | Bin .../iconClose.imageset/iconClose@3x.png | Bin .../iconCopy.imageset/Contents.json | 0 .../iconCopy.imageset/iconCopy.png | Bin .../iconCopy.imageset/iconCopy@2x.png | Bin .../iconCopy.imageset/iconCopy@3x.png | Bin .../iconCreate.imageset/Contents.json | 0 .../iconCreate.imageset/iconCreate.png | Bin .../iconCreate.imageset/iconCreate@2x.png | Bin .../iconCreate.imageset/iconCreate@3x.png | Bin .../iconCreate.imageset/iconCreateRTL.png | Bin .../iconCreate.imageset/iconCreateRTL@2x.png | Bin .../iconCreate.imageset/iconCreateRTL@3x.png | Bin .../iconDelete.imageset/Contents.json | 0 .../iconDelete.imageset/iconDelete.png | Bin .../iconDelete.imageset/iconDelete@2x.png | Bin .../iconDelete.imageset/iconDelete@3x.png | Bin .../iconDocument.imageset/Contents.json | 0 .../iconDocument.imageset/iconDocument.png | Bin .../iconDocument.imageset/iconDocument@2x.png | Bin .../iconDocument.imageset/iconDocument@3x.png | Bin .../iconDone.imageset/Contents.json | 0 .../iconDone.imageset/iconDone.png | Bin .../iconDone.imageset/iconDone@2x.png | Bin .../iconDone.imageset/iconDone@3x.png | Bin .../iconDoneAll.imageset/Contents.json | 0 .../iconDoneAll.imageset/iconDoneAll.png | Bin .../iconDoneAll.imageset/iconDoneAll@2x.png | Bin .../iconDoneAll.imageset/iconDoneAll@3x.png | Bin .../iconDownload.imageset/Contents.json | 0 .../iconDownload.imageset/iconDownload.png | Bin .../iconDownload.imageset/iconDownload@2x.png | Bin .../iconDownload.imageset/iconDownload@3x.png | Bin .../iconEdit.imageset/Contents.json | 0 .../iconEdit.imageset/iconEdit.png | Bin .../iconEdit.imageset/iconEdit@2x.png | Bin .../iconEdit.imageset/iconEdit@3x.png | Bin .../iconEmojiMore.imageset/Contents.json | 0 .../iconEmojiMore.imageset/iconEmojiMore.png | Bin .../iconEmojiMore@2x.png | Bin .../iconEmojiMore@3x.png | Bin .../iconEmpty.imageset/Contents.json | 0 .../iconEmpty.imageset/iconEmpty.png | Bin .../iconEmpty.imageset/iconEmpty@2x.png | Bin .../iconEmpty.imageset/iconEmpty@3x.png | Bin .../iconError.imageset/Contents.json | 0 .../iconError.imageset/iconError.png | Bin .../iconError.imageset/iconError@2x.png | Bin .../iconError.imageset/iconError@3x.png | Bin .../iconFileAudio.imageset/Contents.json | 0 .../iconFileAudio.imageset/iconFileAudio.png | Bin .../iconFileAudio@2x.png | Bin .../iconFileAudio@3x.png | Bin .../iconFileAudioRTL.png | Bin .../iconFileAudioRTL@2x.png | Bin .../iconFileAudioRTL@3x.png | Bin .../iconFileDocument.imageset/Contents.json | 0 .../iconFileDocument.png | Bin .../iconFileDocument@2x.png | Bin .../iconFileDocument@3x.png | Bin .../iconFreeze.imageset/Contents.json | 0 .../iconFreeze.imageset/iconFreeze.png | Bin .../iconFreeze.imageset/iconFreeze@2x.png | Bin .../iconFreeze.imageset/iconFreeze@3x.png | Bin .../iconGif.imageset/Contents.json | 0 .../iconGif.imageset/iconGif.png | Bin .../iconGif.imageset/iconGif@2x.png | Bin .../iconGif.imageset/iconGif@3x.png | Bin .../iconGood.imageset/Contents.json | 0 .../iconGood.imageset/icon-good.png | Bin .../iconGood.imageset/icon-good@2x.png | Bin .../iconGood.imageset/icon-good@3x.png | Bin .../iconInfo.imageset/Contents.json | 0 .../iconInfo.imageset/iconInfo.png | Bin .../iconInfo.imageset/iconInfo@2x.png | Bin .../iconInfo.imageset/iconInfo@3x.png | Bin .../iconLeave.imageset/Contents.json | 0 .../iconLeave.imageset/iconLeave.png | Bin .../iconLeave.imageset/iconLeave@2x.png | Bin .../iconLeave.imageset/iconLeave@3x.png | Bin .../iconLeave.imageset/iconLeaveRTL.png | Bin .../iconLeave.imageset/iconLeaveRTL@2x.png | Bin .../iconLeave.imageset/iconLeaveRTL@3x.png | Bin .../iconMembers.imageset/Contents.json | 0 .../iconMembers.imageset/iconMembers.png | Bin .../iconMembers.imageset/iconMembers@2x.png | Bin .../iconMembers.imageset/iconMembers@3x.png | Bin .../iconMessage.imageset/Contents.json | 0 .../iconMessage.imageset/iconMessage.png | Bin .../iconMessage.imageset/iconMessage@2x.png | Bin .../iconMessage.imageset/iconMessage@3x.png | Bin .../iconMessage.imageset/iconMessageRTL.png | Bin .../iconMessageRTL@2x.png | Bin .../iconMessageRTL@3x.png | Bin .../iconModerations.imageset/Contents.json | 0 .../iconModerations.png | Bin .../iconModerations@2x.png | Bin .../iconModerations@3x.png | Bin .../iconMore.imageset/Contents.json | 0 .../iconMore.imageset/iconMore.png | Bin .../iconMore.imageset/iconMore@2x.png | Bin .../iconMore.imageset/iconMore@3x.png | Bin .../iconMute.imageset/Contents.json | 0 .../iconMute.imageset/iconMute.png | Bin .../iconMute.imageset/iconMute@2x.png | Bin .../iconMute.imageset/iconMute@3x.png | Bin .../Contents.json | 0 .../iconNotificationsFilled.png | Bin .../iconNotificationsFilled@2x.png | Bin .../iconNotificationsFilled@3x.png | Bin .../Contents.json | 0 .../iconNotificationsOffFilled.png | Bin .../iconNotificationsOffFilled@2x.png | Bin .../iconNotificationsOffFilled@3x.png | Bin .../iconNotifications.imageset/Contents.json | 0 .../iconNotifications.png | Bin .../iconNotifications@2x.png | Bin .../iconNotifications@3x.png | Bin .../iconOperator.imageset/Contents.json | 0 .../iconOperator.imageset/iconOperator.png | Bin .../iconOperator.imageset/iconOperator@2x.png | Bin .../iconOperator.imageset/iconOperator@3x.png | Bin .../iconPause.imageset/Contents.json | 0 .../iconPause.imageset/iconPause.png | Bin .../iconPause.imageset/iconPause@2x.png | Bin .../iconPause.imageset/iconPause@3x.png | Bin .../iconPhoto.imageset/Contents.json | 0 .../iconPhoto.imageset/iconPhoto.png | Bin .../iconPhoto.imageset/iconPhoto@2x.png | Bin .../iconPhoto.imageset/iconPhoto@3x.png | Bin .../iconPlay.imageset/Contents.json | 0 .../iconPlay.imageset/iconPlay.png | Bin .../iconPlay.imageset/iconPlay@2x.png | Bin .../iconPlay.imageset/iconPlay@3x.png | Bin .../iconPlus.imageset/Contents.json | 0 .../iconPlus.imageset/iconPlus.png | Bin .../iconPlus.imageset/iconPlus@2x.png | Bin .../iconPlus.imageset/iconPlus@3x.png | Bin .../iconQuestion.imageset/Contents.json | 0 .../iconQuestion.imageset/iconQuestion.png | Bin .../iconQuestion.imageset/iconQuestion@2x.png | Bin .../iconQuestion.imageset/iconQuestion@3x.png | Bin .../iconRadioButtonOff.imageset/Contents.json | 0 .../iconRadioButtonOff.png | Bin .../iconRadioButtonOff@2x.png | Bin .../iconRadioButtonOff@3x.png | Bin .../iconRadioButtonOn.imageset/Contents.json | 0 .../iconRadioButtonOn.png | Bin .../iconRadioButtonOn@2x.png | Bin .../iconRadioButtonOn@3x.png | Bin .../iconRecording.imageset/Contents.json | 0 .../iconRecording.imageset/iconRecording.png | Bin .../iconRecording@2x.png | Bin .../iconRecording@3x.png | Bin .../iconRefresh.imageset/Contents.json | 0 .../iconRefresh.imageset/iconRefresh.png | Bin .../iconRefresh.imageset/iconRefresh@2x.png | Bin .../iconRefresh.imageset/iconRefresh@3x.png | Bin .../iconRemove.imageset/Contents.json | 0 .../iconRemove.imageset/iconRemove.png | Bin .../iconRemove.imageset/iconRemove@2x.png | Bin .../iconRemove.imageset/iconRemove@3x.png | Bin .../iconReplied.imageset/Contents.json | 0 .../iconReplied.imageset/iconReplied.png | Bin .../iconReplied.imageset/iconReplied@2x.png | Bin .../iconReplied.imageset/iconReplied@3x.png | Bin .../iconReplyFilledRTL.png | Bin .../iconReplyFilledRTL@2x.png | Bin .../iconReplyFilledRTL@3x.png | Bin .../iconReply.imageset/Contents.json | 0 .../iconReply.imageset/iconReply.png | Bin .../iconReply.imageset/iconReply@2x.png | Bin .../iconReply.imageset/iconReply@3x.png | Bin .../iconReplyFilledRTL@2x.png | Bin .../iconReply.imageset/iconReplyRTL.png | Bin .../iconReply.imageset/iconReplyRTL@2x.png | Bin .../iconSearch.imageset/Contents.json | 0 .../iconSearch.imageset/iconSearch.png | Bin .../iconSearch.imageset/iconSearch@2x.png | Bin .../iconSearch.imageset/iconSearch@3x.png | Bin .../iconSend.imageset/Contents.json | 0 .../iconSend.imageset/iconSend.png | Bin .../iconSend.imageset/iconSend@2x.png | Bin .../iconSend.imageset/iconSend@3x.png | Bin .../iconSend.imageset/iconSendRTL.png | Bin .../iconSend.imageset/iconSendRTL@2x.png | Bin .../iconSend.imageset/iconSendRTL@3x.png | Bin .../iconSpinner.imageset/Contents.json | 0 .../iconSpinner.imageset/iconSpinner.png | Bin .../iconSpinner.imageset/iconSpinner@2x.png | Bin .../iconSpinner.imageset/iconSpinner@3x.png | Bin .../iconStop.imageset/Contents.json | 0 .../iconStop.imageset/iconStop.png | Bin .../iconStop.imageset/iconStop@2x.png | Bin .../iconStop.imageset/iconStop@3x.png | Bin .../iconSupergroup.imageset/Contents.json | 0 .../iconSupergroup.png | Bin .../iconSupergroup@2x.png | Bin .../iconSupergroup@3x.png | Bin .../iconThread.imageset/Contents.json | 0 .../iconThread.imageset/iconThread.png | Bin .../iconThread.imageset/iconThread@2x.png | Bin .../iconThread.imageset/iconThread@3x.png | Bin .../iconThread.imageset/iconThreadRTL.png | Bin .../iconThread.imageset/iconThreadRTL@2x.png | Bin .../iconThread.imageset/iconThreadRTL@3x.png | Bin .../iconThumbnailNone.imageset/Contents.json | 0 .../iconThumbnailNone.png | Bin .../iconThumbnailNone@2x-1.png | Bin .../iconThumbnailNone@3x.png | Bin .../iconUser.imageset/Contents.json | 0 .../iconUser.imageset/iconUser.png | Bin .../iconUser.imageset/iconUser@2x.png | Bin .../iconUser.imageset/iconUser@3x.png | Bin .../iconVoiceMessageOn.imageset/Contents.json | 0 .../iconAudioOn.png | Bin .../iconAudioOn@2x.png | Bin .../iconAudioOn@3x.png | Bin Sources/{ => uikit}/SBUAvailable.swift | 0 .../{ => uikit}/SBUGlobalCustomParams.swift | 0 Sources/{ => uikit}/SBUGlobals.swift | 44 +- Sources/{ => uikit}/SendbirdUI.swift | 18 +- Sources/{ => uikit}/SendbirdUIKit.h | 0 Sources/{ => uikit}/Theme/SBUColorSet.swift | 2 +- Sources/{ => uikit}/Theme/SBUFontSet.swift | 2 +- Sources/{ => uikit}/Theme/SBUIconSet.swift | 0 Sources/{ => uikit}/Theme/SBUTheme+Type.swift | 0 Sources/{ => uikit}/Theme/SBUTheme.swift | 0 .../{ => uikit}/Util/BlockingOperation.swift | 0 Sources/{ => uikit}/Util/SBUDebouncer.swift | 0 Sources/{ => uikit}/Util/SBULogger.swift | 0 .../{ => uikit}/Util/SBUMentionManager.swift | 0 .../{ => uikit}/Util/SBUPropertyWrapper.swift | 0 Sources/{ => uikit}/Util/SBUUtils.swift | 2 +- Sources/uikit/Util/WeakDelegateStorage.swift | 57 + .../SBUCategoryFilterCell.swift | 0 .../CellView/SBULinkClickableTextView.swift | 0 .../CellView/SBUMarkdownTransfer.swift | 2 +- .../Channel/CellView/SBUMessageDateView.swift | 0 .../CellView/SBUMessageProfileView.swift | 0 .../CellView/SBUMessageStateView.swift | 0 .../Channel/CellView/SBUMessageWebView.swift | 0 .../SBUNotificationTimelineView.swift | 0 .../SBUOpenChannelMessageWebView.swift | 0 .../CellView/SBUSelectableStackView.swift | 0 .../CellView/SBUUserMessageTextView.swift | 0 .../Channel/CellView/SBUUserNameView.swift | 0 .../SBUChannelStateBanner.swift | 2 +- .../FileViewer/SBUFileViewController.swift | 0 .../Header/SBUChannelInfoHeaderView.swift | 0 .../Channel/Header/SBUChannelTitleView.swift | 0 .../View/Channel/Media/SBUMediaView.swift | 2 +- .../CarouselView/SBUBaseCarouselView.swift | 0 ...endedMessagePayloadCustomViewFactory.swift | 0 .../Feedback/SBUFeedbackView.swift | 0 .../Feedback/SBUFeedbackViewParams.swift | 0 .../SBUBaseFileContentView.swift | 0 .../SBUCommonContentView.swift | 0 .../SBUImageContentView.swift | 0 .../SBUOpenChannelCommonContentView.swift | 0 .../SBUOpenChannelImageContentView.swift | 0 .../SBUVoiceContentView.swift | 0 .../SBUAdminMessageCellParams.swift | 0 .../SBUBaseMessageCellParams.swift | 2 +- .../SBUFeedNotificationCellParams.swift | 0 .../SBUFileMessageCellParams.swift | 0 .../SBUMessageTemplateCellParams.swift | 0 .../SBUMultipleFilesMessageCellParams.swift | 0 .../SBUTypingMessageCellParams.swift | 0 .../SBUUnknownMessageCellParams.swift | 0 .../SBUUserMessageCellParams.swift | 0 .../ViewParams/SBUMessageFormViewParams.swift | 0 .../Views/SBUMessageFormChipsItemView.swift | 0 .../Views/SBUMessageFormFallbackView.swift | 0 .../Views/SBUMessageFormItemView.swift | 0 .../SBUMessageFormMultiTextItemView.swift | 0 .../SBUMessageFormSingleTextItemView.swift | 0 .../Views/SBUMessageFormView.swift | 0 .../SubViews/SBUMessageFormChipView.swift | 0 .../SBUMultipleFilesMessageCell.swift | 0 ...BUMultipleFilesMessageCollectionView.swift | 0 ...ltipleFilesMessageCollectionViewCell.swift | 0 .../SBUChatNotificationCell.swift | 0 .../SBUFeedNotificationCell.swift | 0 .../SBUNotificationCell.swift | 0 .../SBUOpenChannelAdminMessageCell.swift | 0 .../SBUOpenChannelBaseMessageCell.swift | 0 ...SBUOpenChannelContentBaseMessageCell.swift | 0 .../SBUOpenChannelFileMessageCell.swift | 0 .../SBUOpenChannelUnknownMessageCell.swift | 0 .../SBUOpenChannelUserMessageCell.swift | 0 .../QuotedFileCommonContentView.swift | 0 .../QuotedFileImageContentView.swift | 0 .../SBUQuotedBaseMessageView.swift | 0 .../SBUQuotedFileMessageView.swift | 0 .../SBUQuotedUserMessageView.swift | 0 .../MessageView/SBUThreadInfoView.swift | 0 .../SBUQuotedBaseMessageViewParams.swift | 0 .../MessageCell/SBUAdminMessageCell.swift | 0 .../SBUBaseMessageCell.Feedback.swift | 0 .../MessageCell/SBUBaseMessageCell.swift | 0 .../SBUContentBaseMessageCell.swift | 0 .../MessageCell/SBUFileMessageCell.swift | 0 ...ageTemplateCell.MessageTemplateLayer.swift | 0 .../MessageCell/SBUMessageTemplateCell.swift | 0 .../SBUMessageTemplateCellLayout.swift | 0 .../SBUTypingIndicatorMessageCell.swift | 0 .../MessageCell/SBUUnknownMessageCell.swift | 0 .../MessageCell/SBUUserMessageCell.swift | 0 .../SBUSuggestedReplyViewParams.swift | 0 ...BUHorizontalSuggestedReplyOptionView.swift | 0 .../SBUHorizontalSuggestedReplyView.swift | 0 .../SBUSimpleSuggestedReplyOptionView.swift | 0 .../Views/SBUSuggestedReplyOptionView.swift | 0 .../Views/SBUSuggestedReplyView.swift | 0 .../Views/SBUVerticalSuggestedReplyView.swift | 0 .../SBUMentionLimitGuideCell.swift | 0 .../MessageInput/SBUMessageInputMode.swift | 0 .../MessageInput/SBUMessageInputView.swift | 44 +- .../SBUQuoteMessageInputView.swift | 0 .../SBUSuggestedMentionList.swift | 0 .../SBUQuoteMessageInputViewParams.swift | 0 .../NewMessageInfo/SBUNewMessageInfo.swift | 0 .../SBUNewNotificationInfo.swift | 0 .../Reaction/SBUEmojiListViewController.swift | 8 +- .../Reaction/SBUMessageReactionView.swift | 0 .../SBUParentMessageInfoReactionView.swift | 0 .../SBUReactionCollectionViewCell.swift | 0 .../Reaction/SBUReactionsViewController.swift | 8 +- ...BUBaseChannelViewController.Keyboard.swift | 0 .../SBUBaseChannelViewController.swift | 4 +- ...hatNotificationChannelViewController.swift | 2 +- ...eedNotificationChannelViewController.swift | 10 +- .../SBUGroupChannelViewController.swift | 31 +- .../SBUOpenChannelViewController.swift | 14 +- .../SBUScrollBottomView.swift | 2 +- .../ViewModel/SBUMessageWebViewModel.swift | 0 .../SBUUserMessageTextViewModel.swift | 0 .../ChannelCell/SBUBaseChannelCell.swift | 0 .../ChannelCell/SBUGroupChannelCell.swift | 0 .../ChannelCell/SBUOpenChannelCell.swift | 0 .../SBUBaseChannelListViewController.swift | 0 .../SBUGroupChannelListViewController.swift | 35 +- .../SBUOpenChannelListViewController.swift | 20 +- .../Cell/SBUBaseChannelSettingCell.swift | 0 .../Cell/SBUGroupChannelSettingCell.swift | 0 .../Cell/SBUModerationCell.swift | 2 +- .../Cell/SBUOpenChannelSettingCell.swift | 0 ...SBUBaseChannelSettingsViewController.swift | 0 ...BUGroupChannelSettingsViewController.swift | 12 + ...SBUOpenChannelSettingsViewController.swift | 12 + .../SBUChannelSettingsChannelInfoView.swift | 2 +- .../ActionSheet/SBUActionSheet.Item.swift | 4 +- .../Common/ActionSheet/SBUActionSheet.swift | 0 .../Common/AlertView/SBUAlertView.Item.swift | 6 +- .../View/Common/AlertView/SBUAlertView.swift | 18 +- .../Menu/SBUBottomSheetController.swift | 4 +- .../View/Common/Menu/SBUMenuCell.swift | 2 +- .../Menu/SBUMenuSheetViewController.swift | 0 .../View/Common/Menu/SBUMenuView.swift | 0 .../Common/PhotoLibrary/SBUPhotoAccess.swift | 0 .../SBUPhotoCollectionViewCell.swift | 0 .../SBUSelectablePhotoViewController.swift | 0 .../View/Common/SBUAnimation.swift | 0 .../View/Common/SBUBarButtonItem.swift | 2 +- .../Common/SBUCollectionViewFlowLayout.swift | 0 .../View/Common/SBUCommonItem.swift | 0 .../Common/SBUCommonViewControllerSet.swift | 8 +- .../View/Common/SBUCoverImageView.swift | 0 .../View/Common/SBUEmptyView.swift | 0 .../View/Common/SBULayoutableButton.swift | 0 .../{ => uikit}/View/Common/SBULoading.swift | 0 .../View/Common/SBUMarginView.swift | 0 .../View/Common/SBUNavigationTitleView.swift | 0 .../Common/SBUNotificationEmptyView.swift | 0 .../SBUNotificationNavigationTitleView.swift | 0 .../View/Common/SBUPaddingLabel.swift | 0 .../View/Common/SBUSearchBar.swift | 2 +- .../View/Common/SBUStackView.swift | 0 .../View/Common/SBUTemplateLabel.swift | 0 .../Common/SBUTypingIndicatorBubbleView.swift | 0 .../View/Common/SBUUnderLineTextField.swift | 2 +- .../View/Common/Toast/SBUToastType.swift | 0 .../Common/Toast/SBUToastView.Internal.swift | 0 .../View/Common/Toast/SBUToastView.Item.swift | 6 +- .../View/Common/Toast/SBUToastView.swift | 0 .../View/Common/User/SBUUserProfileView.swift | 2 +- .../View/Common/UserCell/SBUUserCell.swift | 0 .../Life cycles/SBUCollectionViewCell.swift | 0 .../View/Life cycles/SBULabel.swift | 2 +- .../Life cycles/SBUMessageCellProtocol.swift | 0 .../SBUQuoteMessageInputViewProtocol.swift | 0 .../SBUQuotedMessageViewProtocol.swift | 0 .../View/Life cycles/SBUTableViewCell.swift | 0 .../View/Life cycles/SBUTextView.swift | 0 .../View/Life cycles/SBUView.swift | 0 .../View/Life cycles/SBUViewLifeCycle.swift | 0 .../Cell/SBUMessageSearchResultCell.swift | 0 .../SBUMessageSearchViewController.swift | 15 +- .../SBUMessageThreadTitleView.swift | 0 .../SBUMessageThreadViewController.swift | 15 +- .../SBUParentMessageInfoView.swift | 2 +- .../SBUModerationsViewController.swift | 26 +- .../Cell/SBUChannelPushSettingCell.swift | 2 +- ...oupChannelPushSettingsViewController.swift | 15 + .../View/SBUBaseViewController.swift | 15 + .../View/SBUViewControllerSet.swift | 0 .../SBUCreateChannelViewController.swift | 27 +- .../SBUCreateOpenChannelViewController.swift | 15 + .../View/SBUCreateChannelTypeSelector.swift | 0 .../SBUBaseSelectUserViewController.swift | 0 .../SBUInviteUserViewController.swift | 15 + .../SBURegisterOperatorViewController.swift | 19 + .../UserList/SBUUserListViewController.swift | 180 +- .../VoiceNote/SBUVoiceMessageInputView.swift | 0 .../Channel/SBUBaseChannelViewModel.swift | 76 +- .../SBUChatNotificationChannelViewModel.swift | 0 .../SBUFeedNotificationChannelViewModel.swift | 0 .../Channel/SBUGroupChannelViewModel.swift | 271 +- .../Channel/SBUOpenChannelViewModel.swift | 183 +- .../SBUBaseChannelListViewModel.swift | 19 +- .../SBUGroupChannelListViewModel.swift | 110 +- .../SBUOpenChannelListViewModel.swift | 51 +- .../SBUBaseChannelSettingsViewModel.swift | 25 +- .../SBUGroupChannelSettingsViewModel.swift | 89 +- .../SBUModerationsViewModel.swift | 52 +- .../SBUOpenChannelSettingsViewModel.swift | 82 +- .../ViewModel/Common/SBUCommonDelegate.swift | 0 .../SBUMessageSearchViewModel.swift | 75 +- .../SBUMessageThreadViewModel.swift | 394 +- ...SBUGroupChannelPushSettingsViewModel.swift | 51 +- .../ViewModel/SBUViewModelDelegate.swift | 0 .../ViewModel/SBUViewModelSet.swift | 2 +- .../SBUCreateChannelViewModel.swift | 68 +- .../SBUCreateOpenChannelViewModel.swift | 12 +- .../SBUBaseSelectUserViewModel.swift | 102 +- .../SelectUser/SBUInviteUserViewModel.swift | 20 +- .../SBURegisterOperatorViewModel.swift | 20 +- .../UserList/SBUUserListViewModel.swift | 144 +- 1129 files changed, 12633 insertions(+), 7002 deletions(-) create mode 100644 Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewProvider/CustomGroupChannel.SwiftUI.View.ViewProvider.swift create mode 100644 Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewProvider/CustomGroupChannelList.SwiftUI.View.ViewProvider.swift delete mode 100644 Sample/README.md delete mode 100644 Sample/screenshots/run_sample.png delete mode 100644 Sample/screenshots/sample_screenshot.png delete mode 100644 Sample/screenshots/screenshots.png delete mode 100644 Sources/Info.plist create mode 100644 Sources/SwiftUI/Common/Sendbird+Typealias.swift create mode 100644 Sources/SwiftUI/Internal/Protocol/SendbirdUIProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListViewProvider.swift create mode 100644 Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListViewProvider.swift create mode 100644 Sources/SwiftUI/Util/ProviderWrappedHostingView.swift create mode 100644 Sources/SwiftUI/Util/StateImpactManager.swift rename Sources/{ => uikit}/Configuration/Mention/SBUMentionConfiguration.swift (100%) rename Sources/{ => uikit}/Configuration/Mention/SBUUserMentionConfiguration.swift (100%) rename Sources/{ => uikit}/Configuration/MessageCell/SBUMessageCellConfiguration.swift (100%) rename Sources/{ => uikit}/Configuration/Replies/SBUReplyConfiguration.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfig.Base.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfig.CodingKeys.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfig.Common.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfig.GroupChannel.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfig.OpenChannel.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfig.swift (100%) rename Sources/{ => uikit}/Configuration/SBUConfigManager.swift (100%) rename Sources/{ => uikit}/Configuration/SBUDashboardConfig.swift (100%) rename Sources/{ => uikit}/Configuration/ScrollPostion/SBUScrollPostionConfiguration.swift (100%) rename Sources/{ => uikit}/Configuration/VoiceMessage/SBUVoiceMessageConfiguration.swift (100%) rename Sources/{ => uikit}/Constant/SBUConstant.swift (100%) rename Sources/{ => uikit}/Constant/SBUDateFormatSet.swift (100%) rename Sources/{ => uikit}/Constant/SBUStringSet.Deprecated.swift (100%) rename Sources/{ => uikit}/Constant/SBUStringSet.swift (100%) rename Sources/{ => uikit}/Deprecated/BaseMesssage+SBUIKit.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/MessageCell/Replies/SBUQuotedBaseMessageViewParams.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/MessageCell/SBUContentBaseMessageCell.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/SBUBaseChannelViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/SBUBaseChannelViewController.Unavailable.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/SBUGroupChannelViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/SBUGroupChannelViewController.Unavailable.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/SBUOpenChannelViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Channel/SBUOpenChannelViewController.Unavailable.swift (100%) rename Sources/{ => uikit}/Deprecated/ChannelList/SBUChannelListViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/ChannelSettings/SBUBaseChannelSettingsViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/CreateChannel/SBUCreateChannelViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/MemberList/SBUMemberListViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/MessageSearch/SBUMessageSearchViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Moderations/SBUModerationsViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Moderations/SBUModerationsViewModel.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/Channel/Notifications/SBUChatNotificationChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/Channel/Notifications/SBUFeedNotificationChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/Channel/SBUBaseChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/Channel/SBUGroupChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/Channel/SBUOpenChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/ChannelList/SBUGroupChannelListModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/ChannelList/SBUOpenChannelListModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/ChannelSettings/SBUGroupChannelSettingsModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/ChannelSettings/SBUOpenChannelSettingsModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/MessageSearch/SBUMessageSearchModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/MessageThread/SBUMessageThreadModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/Moderations/SBUModerationsModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/SBUModuleSet.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/SelectUser/SBUCreateChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/SelectUser/SBUCreateOpenChannelModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/SelectUser/SBUInviteUserModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/SelectUser/SBURegisterOperatorModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/Module/UserList/SBUUserListModule.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUBaseViewController.Unavailable.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUCoverImageView.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUEnums.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUForm.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUFormFieldView.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUFormView.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUFormViewParams.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUGlobals.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUTableViewCell.Unavailable.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUTheme.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/SBUView.Unavaliable.swift (100%) rename Sources/{ => uikit}/Deprecated/SendbirdUI.Deprecated.swift (100%) rename Sources/{ => uikit}/Deprecated/UserList/SBUBaseSelectUserViewController.Deprecated.swift (100%) rename Sources/{ => uikit}/Enums/SBUEnums.swift (99%) rename Sources/{ => uikit}/Enums/SBUIconSetType.swift (100%) rename Sources/{ => uikit}/Enums/VoiceMessageStatus.swift (100%) rename Sources/{ => uikit}/Extension/Array+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/CGSize+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/ChatSDK/BaseMessage+SBUIKit.MessageTemplate.swift (100%) rename Sources/{ => uikit}/Extension/ChatSDK/BaseMessage+SBUIKit.swift (99%) rename Sources/{ => uikit}/Extension/ChatSDK/MessageForm+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/ChatSDK/MultipleFilesMessage+SBUIKit.swift (100%) create mode 100644 Sources/uikit/Extension/ChatSDK/SendbirdChat+SBUIKit.swift rename Sources/{ => uikit}/Extension/Collection+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/Data+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/Date+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/Float+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/Formatter+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/NSLayoutConstraint+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/NSObject+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/Sequence+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/String+SBUIKit.swift (89%) rename Sources/{ => uikit}/Extension/StringProtocol+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/Thread+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIApplication+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIButton+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UICollectionView+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIColor+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIImage+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIImageView+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UINavigationController+SBUIKit.swift (98%) rename Sources/{ => uikit}/Extension/UIScrollView+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIStackView.SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UITableView+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UITextField+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIView+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/UIViewController+SBUIKit.swift (100%) rename Sources/{ => uikit}/Extension/URL+SBUIKit.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.Config.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.File.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.Image.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.NotificationSetting.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.Template.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.Version.swift (100%) rename Sources/{ => uikit}/Manager/CacheManager/SBUCacheManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUDownloadManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUEmojiManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUMessageTemplateManager.swift (82%) rename Sources/{ => uikit}/Manager/SBUNotificationChannelManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUPendingMessageManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUPermissionManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUTemplateType.swift (100%) rename Sources/{ => uikit}/Manager/SBUTypingIndicatorMessageManager.swift (100%) rename Sources/{ => uikit}/Manager/SBUVoicePlayer.swift (100%) rename Sources/{ => uikit}/Manager/SBUVoiceRecorder.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Processor/SBUMessageTemplate.Binder.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Processor/SBUMessageTemplate.Container.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Processor/SBUMessageTemplate.Coordinator.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Processor/SBUMessageTemplate.Payload.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Processor/SBUMessageTemplate.PayloadType.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Processor/SBUMessageTemplate.TemplateList.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Events.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderItems.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderStyles.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Utils.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Image.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.RendererType.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Views.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.swift (100%) rename Sources/{ => uikit}/MessageTemplate/SBUMessageTemplate.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Action.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Decoders.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.ErrorMessages.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.ImageRatioType.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Aligns.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Identifier.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Item.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Sizes.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Styles.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Types.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Views.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Tester/MessageTemplateParserTest.swift (100%) rename Sources/{ => uikit}/MessageTemplate/Tester/MessageTemplateTestViewController.swift (100%) rename Sources/{ => uikit}/Model/SBUError.swift (100%) rename Sources/{ => uikit}/Model/SBUExtendedMessagePayload.swift (100%) rename Sources/{ => uikit}/Model/SBUExtendedMessagePayloadForUI.swift (100%) rename Sources/{ => uikit}/Model/SBUFeedbackAction.swift (100%) rename Sources/{ => uikit}/Model/SBUHighlightMessageInfo.swift (100%) rename Sources/{ => uikit}/Model/SBUMention.swift (100%) rename Sources/{ => uikit}/Model/SBUMessageCache.swift (100%) rename Sources/{ => uikit}/Model/SBUScrollOptions.swift (100%) rename Sources/{ => uikit}/Model/SBUTypingIndicatorInfo.swift (100%) rename Sources/{ => uikit}/Model/SBUTypingIndicatorMessage.swift (100%) rename Sources/{ => uikit}/Model/SBUUser.swift (100%) rename Sources/{ => uikit}/Model/SBUVoiceFileInfo.swift (100%) rename Sources/{ => uikit}/Module/Channel/GroupChannel/SBUGroupChannelModule.Header.swift (100%) rename Sources/{ => uikit}/Module/Channel/GroupChannel/SBUGroupChannelModule.Input.swift (100%) rename Sources/{ => uikit}/Module/Channel/GroupChannel/SBUGroupChannelModule.List.swift (100%) rename Sources/{ => uikit}/Module/Channel/GroupChannel/SBUGroupChannelModule.swift (90%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.Header.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.List.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Feed/Params/SBUFeedNotificationChannelViewParams.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.CategoryFilter.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.Header.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.List.swift (100%) rename Sources/{ => uikit}/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.swift (100%) rename Sources/{ => uikit}/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift (99%) rename Sources/{ => uikit}/Module/Channel/OpenChannel/SBUOpenChannelModule.Input.swift (100%) rename Sources/{ => uikit}/Module/Channel/OpenChannel/SBUOpenChannelModule.List.swift (100%) rename Sources/{ => uikit}/Module/Channel/OpenChannel/SBUOpenChannelModule.Media.swift (100%) rename Sources/{ => uikit}/Module/Channel/OpenChannel/SBUOpenChannelModule.swift (91%) rename Sources/{ => uikit}/Module/Channel/SBUBaseChannelModule.Header.swift (99%) rename Sources/{ => uikit}/Module/Channel/SBUBaseChannelModule.Input.swift (100%) rename Sources/{ => uikit}/Module/Channel/SBUBaseChannelModule.List.swift (100%) rename Sources/{ => uikit}/Module/Channel/SBUBaseChannelModule.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Common.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Header.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.List.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift (92%) rename Sources/{ => uikit}/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.Header.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.List.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift (93%) rename Sources/{ => uikit}/Module/ChannelList/SBUBaseChannelListModule.Header.swift (98%) rename Sources/{ => uikit}/Module/ChannelList/SBUBaseChannelListModule.List.swift (100%) rename Sources/{ => uikit}/Module/ChannelList/SBUBaseChannelListModule.swift (100%) rename Sources/{ => uikit}/Module/ChannelSettings/ChannelSettingItem/SBUChannelSettingItem.swift (100%) rename Sources/{ => uikit}/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift (99%) rename Sources/{ => uikit}/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.List.swift (100%) rename Sources/{ => uikit}/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift (94%) rename Sources/{ => uikit}/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift (99%) rename Sources/{ => uikit}/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.List.swift (100%) rename Sources/{ => uikit}/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift (94%) rename Sources/{ => uikit}/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift (99%) rename Sources/{ => uikit}/Module/ChannelSettings/SBUBaseChannelSettingsModule.List.swift (100%) rename Sources/{ => uikit}/Module/ChannelSettings/SBUBaseChannelSettingsModule.swift (100%) rename Sources/{ => uikit}/Module/Common/SBUCommonModule.swift (94%) rename Sources/{ => uikit}/Module/MessageSearch/SBUMessageSearchModule.Header.swift (99%) rename Sources/{ => uikit}/Module/MessageSearch/SBUMessageSearchModule.List.swift (100%) rename Sources/{ => uikit}/Module/MessageSearch/SBUMessageSearchModule.swift (93%) rename Sources/{ => uikit}/Module/MessageThread/SBUMessageThreadModule.Header.swift (100%) rename Sources/{ => uikit}/Module/MessageThread/SBUMessageThreadModule.Input.swift (100%) rename Sources/{ => uikit}/Module/MessageThread/SBUMessageThreadModule.List.swift (100%) rename Sources/{ => uikit}/Module/MessageThread/SBUMessageThreadModule.swift (91%) rename Sources/{ => uikit}/Module/Moderations/SBUModerationsModule.Header.swift (99%) rename Sources/{ => uikit}/Module/Moderations/SBUModerationsModule.List.swift (100%) rename Sources/{ => uikit}/Module/Moderations/SBUModerationsModule.swift (95%) rename Sources/{ => uikit}/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift (99%) rename Sources/{ => uikit}/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.List.swift (100%) rename Sources/{ => uikit}/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift (94%) rename Sources/{ => uikit}/Module/SBUModuleSet.swift (99%) rename Sources/{ => uikit}/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift (99%) rename Sources/{ => uikit}/Module/SelectUser/CreateChannel/SBUCreateChannelModule.List.swift (100%) rename Sources/{ => uikit}/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift (93%) rename Sources/{ => uikit}/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift (99%) rename Sources/{ => uikit}/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.ProfileInput.swift (100%) rename Sources/{ => uikit}/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift (94%) rename Sources/{ => uikit}/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift (99%) rename Sources/{ => uikit}/Module/SelectUser/InviteUser/SBUInviteUserModule.List.swift (100%) rename Sources/{ => uikit}/Module/SelectUser/InviteUser/SBUInviteUserModule.swift (93%) rename Sources/{ => uikit}/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift (99%) rename Sources/{ => uikit}/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.List.swift (100%) rename Sources/{ => uikit}/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift (93%) rename Sources/{ => uikit}/Module/SelectUser/SBUBaseSelectUserModule.Header.swift (99%) rename Sources/{ => uikit}/Module/SelectUser/SBUBaseSelectUserModule.List.swift (100%) rename Sources/{ => uikit}/Module/SelectUser/SBUBaseSelectUserModule.swift (100%) rename Sources/{ => uikit}/Module/UserList/SBUUserListModule.Header.swift (99%) rename Sources/{ => uikit}/Module/UserList/SBUUserListModule.List.swift (100%) rename Sources/{ => uikit}/Module/UserList/SBUUserListModule.swift (93%) rename Sources/{ => uikit}/PrivacyInfo.xcprivacy (100%) rename Sources/{ => uikit}/Protocol/CommonProtocols.swift (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconAdd.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconAdd.imageset/iconAdd.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/iconBack.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/iconBack@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/iconBack@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBad.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBad.imageset/icon-bad.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBad.imageset/icon-bad@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBad.imageset/icon-bad@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBan.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBan.imageset/iconBan.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBan.imageset/iconBan@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBan.imageset/iconBan@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCamera.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCamera.imageset/iconCamera.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChannels.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChannels.imageset/iconChannels.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/iconChat.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/iconChat@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/iconChat@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxChecked.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronDown.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconClose.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconClose.imageset/iconClose.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconClose.imageset/iconClose@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconClose.imageset/iconClose@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCopy.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCopy.imageset/iconCopy.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/iconCreate.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDelete.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDelete.imageset/iconDelete.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDocument.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDocument.imageset/iconDocument.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDone.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDone.imageset/iconDone.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDone.imageset/iconDone@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDone.imageset/iconDone@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDoneAll.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDownload.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDownload.imageset/iconDownload.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEdit.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEdit.imageset/iconEdit.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmojiMore.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmpty.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconError.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconError.imageset/iconError.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconError.imageset/iconError@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconError.imageset/iconError@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileDocument.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFreeze.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGif.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGif.imageset/iconGif.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGif.imageset/iconGif@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGif.imageset/iconGif@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGood.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGood.imageset/icon-good.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGood.imageset/icon-good@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconGood.imageset/icon-good@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconInfo.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconInfo.imageset/iconInfo.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/iconLeave.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMembers.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMembers.imageset/iconMembers.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/iconMessage.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconModerations.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconModerations.imageset/iconModerations.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMore.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMore.imageset/iconMore.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMore.imageset/iconMore@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMore.imageset/iconMore@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMute.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMute.imageset/iconMute.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMute.imageset/iconMute@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconMute.imageset/iconMute@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationFilled.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotifications.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconOperator.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconOperator.imageset/iconOperator.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPause.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPause.imageset/iconPause.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPause.imageset/iconPause@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPause.imageset/iconPause@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPhoto.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlay.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlay.imageset/iconPlay.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlus.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlus.imageset/iconPlus.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconQuestion.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOff.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOn.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRecording.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRecording.imageset/iconRecording.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRefresh.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRemove.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRemove.imageset/iconRemove.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/iconReplied.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/iconReply.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/iconReply@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/iconReply@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/iconReplyFilledRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSearch.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSearch.imageset/iconSearch.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/iconSend.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/iconSend@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/iconSend@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSpinner.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconStop.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconStop.imageset/iconStop.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconStop.imageset/iconStop@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconStop.imageset/iconStop@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSupergroup.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/iconThread.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/iconThread@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/iconThread@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThumbnailNone.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@2x-1.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconUser.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconUser.imageset/iconUser.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconUser.imageset/iconUser@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconUser.imageset/iconUser@3x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/Contents.json (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@2x.png (100%) rename Sources/{ => uikit}/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@3x.png (100%) rename Sources/{ => uikit}/SBUAvailable.swift (100%) rename Sources/{ => uikit}/SBUGlobalCustomParams.swift (100%) rename Sources/{ => uikit}/SBUGlobals.swift (85%) rename Sources/{ => uikit}/SendbirdUI.swift (98%) rename Sources/{ => uikit}/SendbirdUIKit.h (100%) rename Sources/{ => uikit}/Theme/SBUColorSet.swift (99%) rename Sources/{ => uikit}/Theme/SBUFontSet.swift (99%) rename Sources/{ => uikit}/Theme/SBUIconSet.swift (100%) rename Sources/{ => uikit}/Theme/SBUTheme+Type.swift (100%) rename Sources/{ => uikit}/Theme/SBUTheme.swift (100%) rename Sources/{ => uikit}/Util/BlockingOperation.swift (100%) rename Sources/{ => uikit}/Util/SBUDebouncer.swift (100%) rename Sources/{ => uikit}/Util/SBULogger.swift (100%) rename Sources/{ => uikit}/Util/SBUMentionManager.swift (100%) rename Sources/{ => uikit}/Util/SBUPropertyWrapper.swift (100%) rename Sources/{ => uikit}/Util/SBUUtils.swift (99%) create mode 100644 Sources/uikit/Util/WeakDelegateStorage.swift rename Sources/{ => uikit}/View/Channel/CategoryFilterCell/SBUCategoryFilterCell.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBULinkClickableTextView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUMarkdownTransfer.swift (97%) rename Sources/{ => uikit}/View/Channel/CellView/SBUMessageDateView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUMessageProfileView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUMessageStateView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUMessageWebView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUNotificationTimelineView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUOpenChannelMessageWebView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUSelectableStackView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUUserMessageTextView.swift (100%) rename Sources/{ => uikit}/View/Channel/CellView/SBUUserNameView.swift (100%) rename Sources/{ => uikit}/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift (99%) rename Sources/{ => uikit}/View/Channel/FileViewer/SBUFileViewController.swift (100%) rename Sources/{ => uikit}/View/Channel/Header/SBUChannelInfoHeaderView.swift (100%) rename Sources/{ => uikit}/View/Channel/Header/SBUChannelTitleView.swift (100%) rename Sources/{ => uikit}/View/Channel/Media/SBUMediaView.swift (94%) rename Sources/{ => uikit}/View/Channel/MessageCell/CarouselView/SBUBaseCarouselView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/CustomView/SBUExtendedMessagePayloadCustomViewFactory.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Feedback/SBUFeedbackView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Feedback/SBUFeedbackViewParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/FileMessageContentView/SBUBaseFileContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/FileMessageContentView/SBUCommonContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/FileMessageContentView/SBUImageContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelCommonContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelImageContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/FileMessageContentView/SBUVoiceContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUAdminMessageCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift (99%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUFeedNotificationCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUFileMessageCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUMessageTemplateCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUMultipleFilesMessageCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUTypingMessageCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUUnknownMessageCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageCellParams/SBUUserMessageCellParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/ViewParams/SBUMessageFormViewParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormChipsItemView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormFallbackView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormItemView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormMultiTextItemView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormSingleTextItemView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MessageForm/Views/SubViews/SBUMessageFormChipView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionViewCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/NotificationChannel/SBUChatNotificationCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/NotificationChannel/SBUFeedNotificationCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/NotificationChannel/SBUNotificationCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/OpenChannel/SBUOpenChannelAdminMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/OpenChannel/SBUOpenChannelBaseMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/OpenChannel/SBUOpenChannelContentBaseMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/OpenChannel/SBUOpenChannelFileMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUnknownMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUserMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/MessageView/QuotedFileCommonContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/MessageView/QuotedFileImageContentView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/MessageView/SBUQuotedBaseMessageView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/MessageView/SBUQuotedFileMessageView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/MessageView/SBUQuotedUserMessageView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/MessageView/SBUThreadInfoView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/Replies/ViewParams/SBUQuotedBaseMessageViewParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUAdminMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUBaseMessageCell.Feedback.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUBaseMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUContentBaseMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUFileMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUMessageTemplateCell.MessageTemplateLayer.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUMessageTemplateCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUMessageTemplateCellLayout.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUTypingIndicatorMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUUnknownMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SBUUserMessageCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/ViewParams/SBUSuggestedReplyViewParams.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyOptionView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/Views/SBUSimpleSuggestedReplyOptionView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyOptionView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageCell/SuggestedReply/Views/SBUVerticalSuggestedReplyView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageInput/SBUMentionLimitGuideCell.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageInput/SBUMessageInputMode.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageInput/SBUMessageInputView.swift (98%) rename Sources/{ => uikit}/View/Channel/MessageInput/SBUQuoteMessageInputView.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageInput/SBUSuggestedMentionList.swift (100%) rename Sources/{ => uikit}/View/Channel/MessageInput/ViewParams/SBUQuoteMessageInputViewParams.swift (100%) rename Sources/{ => uikit}/View/Channel/NewMessageInfo/SBUNewMessageInfo.swift (100%) rename Sources/{ => uikit}/View/Channel/NewMessageInfo/SBUNewNotificationInfo.swift (100%) rename Sources/{ => uikit}/View/Channel/Reaction/SBUEmojiListViewController.swift (98%) rename Sources/{ => uikit}/View/Channel/Reaction/SBUMessageReactionView.swift (100%) rename Sources/{ => uikit}/View/Channel/Reaction/SBUParentMessageInfoReactionView.swift (100%) rename Sources/{ => uikit}/View/Channel/Reaction/SBUReactionCollectionViewCell.swift (100%) rename Sources/{ => uikit}/View/Channel/Reaction/SBUReactionsViewController.swift (99%) rename Sources/{ => uikit}/View/Channel/SBUBaseChannelViewController.Keyboard.swift (100%) rename Sources/{ => uikit}/View/Channel/SBUBaseChannelViewController.swift (99%) rename Sources/{ => uikit}/View/Channel/SBUChatNotificationChannelViewController.swift (99%) rename Sources/{ => uikit}/View/Channel/SBUFeedNotificationChannelViewController.swift (99%) rename Sources/{ => uikit}/View/Channel/SBUGroupChannelViewController.swift (98%) rename Sources/{ => uikit}/View/Channel/SBUOpenChannelViewController.swift (99%) rename Sources/{ => uikit}/View/Channel/ScrollBottomView/SBUScrollBottomView.swift (99%) rename Sources/{ => uikit}/View/Channel/ViewModel/SBUMessageWebViewModel.swift (100%) rename Sources/{ => uikit}/View/Channel/ViewModel/SBUUserMessageTextViewModel.swift (100%) rename Sources/{ => uikit}/View/ChannelList/ChannelCell/SBUBaseChannelCell.swift (100%) rename Sources/{ => uikit}/View/ChannelList/ChannelCell/SBUGroupChannelCell.swift (100%) rename Sources/{ => uikit}/View/ChannelList/ChannelCell/SBUOpenChannelCell.swift (100%) rename Sources/{ => uikit}/View/ChannelList/SBUBaseChannelListViewController.swift (100%) rename Sources/{ => uikit}/View/ChannelList/SBUGroupChannelListViewController.swift (93%) rename Sources/{ => uikit}/View/ChannelList/SBUOpenChannelListViewController.swift (95%) rename Sources/{ => uikit}/View/ChannelSettings/Cell/SBUBaseChannelSettingCell.swift (100%) rename Sources/{ => uikit}/View/ChannelSettings/Cell/SBUGroupChannelSettingCell.swift (100%) rename Sources/{ => uikit}/View/ChannelSettings/Cell/SBUModerationCell.swift (99%) rename Sources/{ => uikit}/View/ChannelSettings/Cell/SBUOpenChannelSettingCell.swift (100%) rename Sources/{ => uikit}/View/ChannelSettings/SBUBaseChannelSettingsViewController.swift (100%) rename Sources/{ => uikit}/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift (97%) rename Sources/{ => uikit}/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift (97%) rename Sources/{ => uikit}/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift (99%) rename Sources/{ => uikit}/View/Common/ActionSheet/SBUActionSheet.Item.swift (97%) rename Sources/{ => uikit}/View/Common/ActionSheet/SBUActionSheet.swift (100%) rename Sources/{ => uikit}/View/Common/AlertView/SBUAlertView.Item.swift (93%) rename Sources/{ => uikit}/View/Common/AlertView/SBUAlertView.swift (99%) rename Sources/{ => uikit}/View/Common/Menu/SBUBottomSheetController.swift (99%) rename Sources/{ => uikit}/View/Common/Menu/SBUMenuCell.swift (99%) rename Sources/{ => uikit}/View/Common/Menu/SBUMenuSheetViewController.swift (100%) rename Sources/{ => uikit}/View/Common/Menu/SBUMenuView.swift (100%) rename Sources/{ => uikit}/View/Common/PhotoLibrary/SBUPhotoAccess.swift (100%) rename Sources/{ => uikit}/View/Common/PhotoLibrary/SBUPhotoCollectionViewCell.swift (100%) rename Sources/{ => uikit}/View/Common/PhotoLibrary/SBUSelectablePhotoViewController.swift (100%) rename Sources/{ => uikit}/View/Common/SBUAnimation.swift (100%) rename Sources/{ => uikit}/View/Common/SBUBarButtonItem.swift (98%) rename Sources/{ => uikit}/View/Common/SBUCollectionViewFlowLayout.swift (100%) rename Sources/{ => uikit}/View/Common/SBUCommonItem.swift (100%) rename Sources/{ => uikit}/View/Common/SBUCommonViewControllerSet.swift (93%) rename Sources/{ => uikit}/View/Common/SBUCoverImageView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUEmptyView.swift (100%) rename Sources/{ => uikit}/View/Common/SBULayoutableButton.swift (100%) rename Sources/{ => uikit}/View/Common/SBULoading.swift (100%) rename Sources/{ => uikit}/View/Common/SBUMarginView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUNavigationTitleView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUNotificationEmptyView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUNotificationNavigationTitleView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUPaddingLabel.swift (100%) rename Sources/{ => uikit}/View/Common/SBUSearchBar.swift (99%) rename Sources/{ => uikit}/View/Common/SBUStackView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUTemplateLabel.swift (100%) rename Sources/{ => uikit}/View/Common/SBUTypingIndicatorBubbleView.swift (100%) rename Sources/{ => uikit}/View/Common/SBUUnderLineTextField.swift (98%) rename Sources/{ => uikit}/View/Common/Toast/SBUToastType.swift (100%) rename Sources/{ => uikit}/View/Common/Toast/SBUToastView.Internal.swift (100%) rename Sources/{ => uikit}/View/Common/Toast/SBUToastView.Item.swift (96%) rename Sources/{ => uikit}/View/Common/Toast/SBUToastView.swift (100%) rename Sources/{ => uikit}/View/Common/User/SBUUserProfileView.swift (99%) rename Sources/{ => uikit}/View/Common/UserCell/SBUUserCell.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUCollectionViewCell.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBULabel.swift (98%) rename Sources/{ => uikit}/View/Life cycles/SBUMessageCellProtocol.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUQuoteMessageInputViewProtocol.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUQuotedMessageViewProtocol.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUTableViewCell.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUTextView.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUView.swift (100%) rename Sources/{ => uikit}/View/Life cycles/SBUViewLifeCycle.swift (100%) rename Sources/{ => uikit}/View/MessageSearch/Cell/SBUMessageSearchResultCell.swift (100%) rename Sources/{ => uikit}/View/MessageSearch/SBUMessageSearchViewController.swift (97%) rename Sources/{ => uikit}/View/MessageThread/SBUMessageThreadTitleView.swift (100%) rename Sources/{ => uikit}/View/MessageThread/SBUMessageThreadViewController.swift (99%) rename Sources/{ => uikit}/View/MessageThread/SBUParentMessageInfoView.swift (99%) rename Sources/{ => uikit}/View/Moderations/SBUModerationsViewController.swift (94%) rename Sources/{ => uikit}/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift (99%) rename Sources/{ => uikit}/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift (95%) rename Sources/{ => uikit}/View/SBUBaseViewController.swift (93%) rename Sources/{ => uikit}/View/SBUViewControllerSet.swift (100%) rename Sources/{ => uikit}/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift (94%) rename Sources/{ => uikit}/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift (97%) rename Sources/{ => uikit}/View/SelectUser/CreateChannel/View/SBUCreateChannelTypeSelector.swift (100%) rename Sources/{ => uikit}/View/SelectUser/SBUBaseSelectUserViewController.swift (100%) rename Sources/{ => uikit}/View/SelectUser/SBUInviteUserViewController.swift (95%) rename Sources/{ => uikit}/View/SelectUser/SBURegisterOperatorViewController.swift (94%) rename Sources/{ => uikit}/View/UserList/SBUUserListViewController.swift (96%) rename Sources/{ => uikit}/View/VoiceNote/SBUVoiceMessageInputView.swift (100%) rename Sources/{ => uikit}/ViewModel/Channel/SBUBaseChannelViewModel.swift (95%) rename Sources/{ => uikit}/ViewModel/Channel/SBUChatNotificationChannelViewModel.swift (100%) rename Sources/{ => uikit}/ViewModel/Channel/SBUFeedNotificationChannelViewModel.swift (100%) rename Sources/{ => uikit}/ViewModel/Channel/SBUGroupChannelViewModel.swift (85%) rename Sources/{ => uikit}/ViewModel/Channel/SBUOpenChannelViewModel.swift (86%) rename Sources/{ => uikit}/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift (82%) rename Sources/{ => uikit}/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift (77%) rename Sources/{ => uikit}/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift (86%) rename Sources/{ => uikit}/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift (81%) rename Sources/{ => uikit}/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift (70%) rename Sources/{ => uikit}/ViewModel/ChannelSettings/SBUModerationsViewModel.swift (79%) rename Sources/{ => uikit}/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift (65%) rename Sources/{ => uikit}/ViewModel/Common/SBUCommonDelegate.swift (100%) rename Sources/{ => uikit}/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift (78%) rename Sources/{ => uikit}/ViewModel/MessageThread/SBUMessageThreadViewModel.swift (84%) rename Sources/{ => uikit}/ViewModel/NotificationSettings/SBUGroupChannelPushSettingsViewModel.swift (66%) rename Sources/{ => uikit}/ViewModel/SBUViewModelDelegate.swift (100%) rename Sources/{ => uikit}/ViewModel/SBUViewModelSet.swift (99%) rename Sources/{ => uikit}/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift (83%) rename Sources/{ => uikit}/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift (84%) rename Sources/{ => uikit}/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift (81%) rename Sources/{ => uikit}/ViewModel/SelectUser/SBUInviteUserViewModel.swift (77%) rename Sources/{ => uikit}/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift (77%) rename Sources/{ => uikit}/ViewModel/UserList/SBUUserListViewModel.swift (80%) diff --git a/CHANGELOG.md b/CHANGELOG.md index b58a311..2f218d9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,2 +1,335 @@ -### v1.0.0-beta.3 (Oct 07, 2024) -- Fixed an issue that was not available SDK in xcode 15 +# **SwiftUI GA** +:tada: Exciting Announcement: SendbirdSwiftUI now goes GA :tada: +Previously launched as beta, SendbirdSwiftUI is now official. +SendbirdSwiftUI 1.0.0 includes new interfaces that enable even further and wider customization upon out-of-the-box SwiftUI Views with live chat data. The new interfaces mainly include View Providers for each View, and events methods of SendbirdSwiftUI Views. +For detailed information and documentation, please visit our [docs homepage](https://sendbird.com/docs/chat/uikit/v3/swiftui/overview). + + +# **Changes: Beta → GA** + +## **New Interfaces** +New functionalities and interfaces have been added + +### **CreateGroupChannelView** +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `CreateGroupChannelViewProvider` + - `CreateGroupChannelEventHandlers` + +### **CreateOpenChannelView** +- `init(provider:headerItem:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `CreateOpenChannelViewProvider` + - `CreateOpenChannelEventHandlers` + +### **GroupBannedUserListView** +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `GroupBannedUserListViewProvider` + - `GroupBannedUserListViewEventHandlers` + +### **GroupChannelView** +- `init(provider:)` +- `init(provider:headerItem:listItem:inputItem:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `GroupChannelViewProvider` + - `GroupChannelViewEventHandlers` + +### **GroupChannelListView** +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdSelectLeaveChannel(_:)` +- `onSendbirdChangePushTriggerOption(_:)` +- `onSendbirdConnectionStateChange(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `GroupChannelListViewProvider` + - `GroupChannelListEventHandlers` + +### **GroupChannelPushSettingsView** +- `init(provider:)` +- `init(provider:headerItem:)` +- **Provider and EventHandlers**: + - `GroupChannelPushSettingsViewProvider` + +### **GroupChannelRegisterOperatorView** +- `init(provider:)` +- `init(provider:headerItem:)` +- **Provider and EventHandlers**: + - `GroupChannelRegisterOperatorViewProvider` + - `GroupChannelRegisterOperatorViewEventHandlers` + +### **GroupChannelSettingsView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- **Provider and EventHandlers**: + - `GroupChannelSettingsViewProvider` + +### **GroupMemberListView** +- `init(provider:)` +- `init(provider:userListType:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `GroupMemberListViewProvider` + - `GroupMemberListViewEventHandlers` + +### **GroupModerationsView** +- `init(provider:)` +- `init(provider:headerItem:)` +- **Provider and EventHandlers**: + - `GroupModerationsViewProvider` + - `GroupModerationsViewEventHandlers` + +### **GroupMutedMemberListView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `GroupMutedMemberListViewProvider` + - `GroupMutedMemberListViewEventHandlers` + +### **GroupOperatorListView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `GroupOperatorListViewProvider` + - `GroupOperatorListViewEventHandlers` + +### **InviteUserView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- **Provider and EventHandlers**: + - `InviteUserViewProvider` + +### **MessageSearchView** +- `init(provider:)` +- **Provider and EventHandlers**: + - `MessageSearchViewProvider` + +### **MessageThreadView** +- `init(provider:)` +- `init(provider:headerItem:parentInfoItem:listItem:inputItem:)` +- **Provider and EventHandlers**: + - `MessageThreadViewProvider` + - `MessageThreadViewEventHandlers` + +### **OpenBannedUserListView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `OpenBannedUserListViewProvider` + - `OpenBannedUserListViewEventHandlers` + +### **OpenChannelView** +- `init(provider:)` +- `init(provider:headerItem:listItem:inputItem:)` +- **Provider and EventHandlers**: + - `OpenChannelViewProvider` + - `OpenChannelEventHandlers` + +### **OpenChannelListView** +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdConnectionStateChange(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `OpenChannelListViewProvider` + - `OpenChannelListEventHandlers` + +### **OpenChannelRegisterOperatorView** +- `init(provider:)` +- `init(provider:headerItem:)` +- **Provider and EventHandlers**: + - `OpenChannelRegisterOperatorViewProvider` + - `OpenChannelRegisterOperatorViewEventHandlers` + +### **OpenChannelSettingsView** +- `init(provider:)` +- `init(provider:headerItem:)` +- **Provider and EventHandlers**: + - `OpenChannelSettingsViewProvider` + - `OpenChannelSettingsEventHandlers` + +### **OpenModerationsView** +- `init(provider:)` +- `init(provider:headerItem:)` +- **Provider and EventHandlers**: + - `OpenModerationsViewProvider` + - `OpenModerationsViewEventHandlers` + +### **OpenMutedParticipantListView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `OpenMutedParticipantListViewProvider` + - `OpenMutedParticipantListViewEventHandlers` + +### **OpenOperatorListView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `OpenOperatorListViewProvider` + - `OpenOperatorListViewEventHandlers` + +### **OpenParticipantListView** +- `init(provider:)` +- `init(provider:headerItem:listItem:)` +- `onSendbirdSelectRow(_:)` +- `onSendbirdError(_:)` +- **Provider and EventHandlers**: + - `OpenParticipantListViewProvider` + - `OpenParticipantListViewEventHandlers` + + +--- + +## **Unavailbale Interfaces** +The following interfaces that were available in the Beta version have been removed in the GA release: + +### **CreateGroupChannelView** +- **Constructor Changes**: + - `init(users:type:headerItem:listItem:)` + - `init(users:type:headerItem:list:)` + +### **CreateOpenChannelView** +- **Constructor Changes**: + - `init()` + - `init(headerItem:)` + +### **GroupBannedUserListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + +### **GroupChannelView** +- **Constructor Changes**: + - `init()` + - `init(users:type:headerItem:listItem:)` + - `init(users:type:headerItem:list:)` + +### **GroupChannelListView** +- **Constructor Changes**: + - `init(channelListQuery:headerItem:listItem:)` + - `init(channelListQuery:headerItem:list:)` + +### **GroupChannelPushSettingsView** +- **Constructor Changes**: + - `init(channelURL:)` + - `init(channelURL:headerItem:)` + +### **GroupChannelRegisterOperatorView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:)` + +### **GroupChannelSettingsView** +- **Constructor Changes**: + - `init(channelURL:headerItem:listItem:)` + - `init(channelURL:headerItem:list:)` + +### **GroupMemberListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:userListType:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **GroupModerationsView** +- **Constructor Changes**: + - `init(channelURL:)` + +### **GroupMutedMemberListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **GroupOperatorListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **InviteUserView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **MessageSearchView** +- **Constructor Changes**: + - `init(channelURL:)` + - `init(channelURL:headerItem:listItem:)` + +### **MessageThreadView** +- **Constructor Changes**: + - `init(channelURL:parentMessageId:delegate:threadedMessageListParams:startingPoint:voiceFileInfos:)` + - `init(channelURL:parentMessageId:delegate:threadedMessageListParams:startingPoint:voiceFileInfos:headerItem:parentInfoItem:listItem:inputItem:)` + - `init(channelURL:parentMessageId:delegate:threadedMessageListParams:startingPoint:voiceFileInfos:headerItem:list:inputItem:)` + +### **OpenBannedUserListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **OpenChannelView** +- **Constructor Changes**: + - `init(channelURL:startingPoint:messageListParams:)` + - `init(channelURL:startingPoint:messageListParams:headerItem:listItem:inputItem:)` + - `init(channelURL:startingPoint:messageListParams:headerItem:list:inputItem:)` + +### **OpenChannelListView** +- **Constructor Changes**: + - `init(channelListQuery:)` + - `init(channelListQuery:headerItem:listItem:)` + - `init(channelListQuery:headerItem:list:)` + +### **OpenChannelRegisterOperatorView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **OpenChannelSettingsView** +- **Constructor Changes**: + - `init(channelURL:)` + - `init(channelURL:headerItem:)` + +### **OpenModerationsView** +- **Constructor Changes**: + - `init(channelURL:)` + - `init(channelURL:headerItem:)` + +### **OpenMutedParticipantListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **OpenOperatorListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` + +### **OpenParticipantListView** +- **Constructor Changes**: + - `init(channelURL:users:)` + - `init(channelURL:users:headerItem:listItem:)` + - `init(channelURL:users:headerItem:list:)` diff --git a/Package.swift b/Package.swift index 257550d..cddc0c9 100644 --- a/Package.swift +++ b/Package.swift @@ -17,14 +17,14 @@ let package = Package( .package( name: "SendbirdChatSDK", url: "https://github.com/sendbird/sendbird-chat-sdk-ios", - from: "4.21.1" + from: "4.23.1" ), ], targets: [ .binaryTarget( name: "SendbirdSwiftUI", - url: "https://github.com/sendbird/sendbird-swiftui-ios/releases/download/1.0.0-beta.3/SendbirdSwiftUI.xcframework.zip", - checksum: "4aad0185e8ebf1b305cfbf984e29312faf4084925c40e774d77b8328477fc4a4" + url: "https://github.com/sendbird/sendbird-swiftui-ios/releases/download/1.0.0/SendbirdSwiftUI.xcframework.zip", + checksum: "bed700df14354830f874c5cda1a20bb785ab7924274e05c45418fc97655591c4" ), .target( diff --git a/Sample/QuickStartSwiftUI.xcodeproj/project.pbxproj b/Sample/QuickStartSwiftUI.xcodeproj/project.pbxproj index c146650..5bfc614 100644 --- a/Sample/QuickStartSwiftUI.xcodeproj/project.pbxproj +++ b/Sample/QuickStartSwiftUI.xcodeproj/project.pbxproj @@ -7,1068 +7,1100 @@ objects = { /* Begin PBXBuildFile section */ - 0065D6AA9D787B828A0880B6 /* SBUViewControllerSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 960030BBD4843C4DD078C35C /* SBUViewControllerSet.swift */; }; + 00C488A81560EF0A64874F47 /* SBUBaseMessageCell.Feedback.swift in Sources */ = {isa = PBXBuildFile; fileRef = 246C6675D850EA56F58871FC /* SBUBaseMessageCell.Feedback.swift */; }; + 00C85B54DEAAFA517FA0D50B /* GroupMutedMemberListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2769D3BC0129E975B6946A2C /* GroupMutedMemberListView+SubViewBuilder.swift */; }; 00ED5EE1868FFCCBA2C7AD8D /* CustomOpenOperatorList.swift in Sources */ = {isa = PBXBuildFile; fileRef = F66A9356D0027AF606372658 /* CustomOpenOperatorList.swift */; }; 00EF5904E2CC8C1CA8E7CDC7 /* CustomOpenOperatorList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = BA429B863A8ED037889380A4 /* CustomOpenOperatorList.ViewConverter.List.moreButton.swift */; }; - 01198926DBBD9D8D39D76595 /* SBUUserListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = BBE02207F2AC34710E9F2A41 /* SBUUserListViewController.swift */; }; - 0141C203B309D94FE9BC96F0 /* SBUMessageThreadTitleView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1CE8943E2D24A159FAE8A666 /* SBUMessageThreadTitleView+SwiftUI.swift */; }; 0152DA39617EFC76210E6B13 /* CustomGroupChannelList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9EA9A722A74690B1FE0DA8E9 /* CustomGroupChannelList.SwiftUI.View.CustomMain.swift */; }; - 01C10C34A07F581EAD1CD350 /* SBUBaseChannelSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 869EAD18504324BF7D9CF724 /* SBUBaseChannelSettingsModule.List.swift */; }; - 02485528E666F206B7C18F89 /* SBUColorSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = FD3B3C58D3785437EE1411F1 /* SBUColorSet.swift */; }; - 027F85F8D05965EA72E35649 /* SBUEmptyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E8C797DF2665B67DB664FD80 /* SBUEmptyView.swift */; }; - 02D7FB791629405E7B868FB5 /* InviteUserViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = BB0D3EA32D2293C49B99240F /* InviteUserViewConverter.swift */; }; - 03102A48C0986F20C8F64749 /* SBUOpenScrollBottomView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 60C8EC1B23B48AE94DF6F3A7 /* SBUOpenScrollBottomView+SwiftUI.swift */; }; - 03C5991A0F934387C4886CF7 /* CreateGroupChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 20F4251E92AEC8A7056D747A /* CreateGroupChannelViewConverter.swift */; }; + 016DE4771424BCB5E36BD8A0 /* GroupBannedUserListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = D2AECC85EB8D47720009CB4A /* GroupBannedUserListViewConverter.Header.swift */; }; + 01A64DE1989F69381E0E3B02 /* SBUScrollBottomView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A5D3AAD48890B67F36BEE43 /* SBUScrollBottomView+SwiftUI.swift */; }; + 02B33E2B9E007EC37070C22D /* SBULoading.swift in Sources */ = {isa = PBXBuildFile; fileRef = 70D5F2E2B3D151693F21C0A6 /* SBULoading.swift */; }; + 03E2C98D4F2EE59B3B9C92C7 /* SBUUserProfileView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 59C00249475970C2ACE48F80 /* SBUUserProfileView.swift */; }; 03E2F3F10A51A43A3454A3D7 /* CustomMessageThread.ViewConverter.List.fileMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB69F30738244FD2FBE1C222 /* CustomMessageThread.ViewConverter.List.fileMessageView.swift */; }; 04107BD5F6320D39F3CD004A /* CustomInviteUser.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3453123508BA0620302C5095 /* CustomInviteUser.SwiftUI.View.CustomMain.swift */; }; 042735E10390D121E284C98C /* CustomGroupOperatorList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C877EE241E9DBF85CC0AEAEC /* CustomGroupOperatorList.ViewConverter.Header.titleView.swift */; }; 0461AACD27520C00D39871A8 /* CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A3A24FE5B77BFB32E7FC600B /* CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift */; }; - 0488280C607E8C782DA5371C /* SBUOpenChannelModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B23F126897E287420089CCD2 /* SBUOpenChannelModule.List+SwiftUI.swift */; }; + 047F814076A05A3CD98A99EB /* MessageThreadViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5B197912A53CB3854FF990B4 /* MessageThreadViewConverter.swift */; }; + 04900E9B717C7CED5A30AC94 /* SendbirdUI+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F5ABD9526E2BC97012171C4A /* SendbirdUI+SwiftUI.swift */; }; 04C96B7EDDA3BD7ACBB84DC7 /* CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 37AAC2A470701025FC17A63C /* CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift */; }; + 04C9C81C378C25E41DD22BB2 /* SBUGlobals.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = C88F606D9A7BFD1287285E78 /* SBUGlobals.Deprecated.swift */; }; + 04ED8F61F94545D52646FD4E /* MessageSearchView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6EB65FAB29A17019E54AFA24 /* MessageSearchView.swift */; }; 05068630525C542EE173A581 /* CustomGroupChannelSettings.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 83E21DEE99C27C67B4374E32 /* CustomGroupChannelSettings.ViewConverter.Header.rightView.swift */; }; - 051DF9B1FD6387F77A69ED61 /* SBUCacheManager.Config.swift in Sources */ = {isa = PBXBuildFile; fileRef = E24BD1FBA414D2FCC2A2825F /* SBUCacheManager.Config.swift */; }; - 05381E02BBF59AF2D639E9A7 /* SBUTypingIndicatorMessageManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2BCED6324E56293CB6D4F266 /* SBUTypingIndicatorMessageManager.swift */; }; - 0596682EC3456B6FF4EBE4B7 /* SBUOpenChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = C4B4928DCE8DCBA7C80D26C0 /* SBUOpenChannelModule.Deprecated.swift */; }; 05A1B3315920CA3172EE4BF3 /* CustomGroupChannelSettings.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B8DD94130F1FCA4BC88AC734 /* CustomGroupChannelSettings.ViewConverter.List.entireView.swift */; }; + 061D761670DD3846F2EB4B20 /* ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = CFC414657A88A22B041B0248 /* ViewConverter.swift */; }; 069DD6E38C6AE8FC0ACE95BC /* CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C3FE16B863E8BBB398CBE7A9 /* CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift */; }; - 06C25FEA3135A0BD3CB28F97 /* SBUCreateGroupChannelUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 210AF12A14FCE17C47355C30 /* SBUCreateGroupChannelUserCell+SwiftUI.swift */; }; - 06D249E19B196DEDEE19BF55 /* GroupChannelViewConverter.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 118B3013D694187D3BA0B6CC /* GroupChannelViewConverter.Input.swift */; }; + 06A5DAADFEA005FE07E2E082 /* MessageSearchViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2998E5B0A2F8028DC20D9D04 /* MessageSearchViewConverter.swift */; }; + 06C16919548225224D687E8A /* GroupChannelSettingsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 54D753A8D0469BADE7B3A79C /* GroupChannelSettingsView+Item.swift */; }; + 06E145EC829658D24E39F9B2 /* OpenOperatorListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 116A35DCB844940ACC55AFA0 /* OpenOperatorListView+Item.swift */; }; 06FE33B7004273A41FF23E05 /* CustomMessageSearch.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 22F8DAE624B591D4CFCCAA01 /* CustomMessageSearch.ViewConverter.Header.rightView.swift */; }; - 071AB6CFBDA5D6FC64611157 /* OpenChannelViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9CEA691367E3A7EA0CC719D0 /* OpenChannelViewConverter.List.swift */; }; - 0771F7BF876B9940D2D51DFF /* SBUOpenOperatorListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F363B8C0EDA127F26AAFA8CD /* SBUOpenOperatorListModule.List+SwiftUI.swift */; }; + 071994DBFEE33E4945CF375E /* UICollectionView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = D00605CF296075CBED52EF08 /* UICollectionView+SBUIKit.swift */; }; + 077EE5F13FBD2FFB7DE74086 /* SBUUserListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E62CC4F6BA3B54579233BFE /* SBUUserListModule.swift */; }; 07D545A0AC4DC7F924C8C1B0 /* CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 964B5747079764A20DD6EF7B /* CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift */; }; - 07F0326A4479D48FA595591B /* SBULinkClickableTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF99A51ED217C33B971A26F9 /* SBULinkClickableTextView.swift */; }; + 07F84CEA484DCBB1F948AAD8 /* SBUMessageThreadModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2BCB5EB5A43E374C6E5D2743 /* SBUMessageThreadModule.Deprecated.swift */; }; + 082F4BBEC7BE29EB4A6703B0 /* OpenChannelRegisterOperatorViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 589B1E8E2A00B25B20ECD24A /* OpenChannelRegisterOperatorViewConverter.swift */; }; 083BD45F9A57249547B8E11A /* CustomCreateGroupChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = CCAC3124A832A9847294D2F8 /* CustomCreateGroupChannel.swift */; }; - 0887D93782BB853729387857 /* SBUFeedbackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D7FF76C892053B1F2B2D112 /* SBUFeedbackView.swift */; }; - 0889CA23C29B6C4DD37AC8E1 /* OpenModerationsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5439E224FB62720B74EAC103 /* OpenModerationsView.swift */; }; + 08931227D365B7E2FC9630A9 /* SBUBaseChannelListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 31220D4260D422D89BA59FD3 /* SBUBaseChannelListViewModel.swift */; }; 0966366273A343F558FE0872 /* CustomOpenChannel.ViewConverter.Input.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A42767E94B44B0D92A7A4D5F /* CustomOpenChannel.ViewConverter.Input.leftView.swift */; }; - 09CEBEB51450909EA7A3482D /* SBUCommonContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 16C4D273B7FFFD441AC2D664 /* SBUCommonContentView.swift */; }; - 0A230327F67B275C554C0AA3 /* Sendbird.swift in Sources */ = {isa = PBXBuildFile; fileRef = ECA3A3BB1C8BE8DD7400F28B /* Sendbird.swift */; }; - 0A50103E6135D93A5EDEEF51 /* SBUGroupBannedUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8CE73800C5625E411855E0D3 /* SBUGroupBannedUserListUserCell+SwiftUI.swift */; }; - 0A82663EF8D84D235CA65F81 /* SBUFeedbackViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 60EC3C29705F473B8FD02D2A /* SBUFeedbackViewParams.swift */; }; - 0A96B6FBD0FA827EE12AE507 /* GroupChannelListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = E03D59600F0C64AE7B9745E8 /* GroupChannelListView+ViewConverter.swift */; }; + 097DC8B40B2D870D5AA19E33 /* SBUMention.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8B69E3E68D1C6DF2B3B4CCE5 /* SBUMention.swift */; }; + 09825CD9E70677F734FFE2CA /* SBUOpenChannelModule.Media.swift in Sources */ = {isa = PBXBuildFile; fileRef = F4D4EB006F53EF06F2BA27A2 /* SBUOpenChannelModule.Media.swift */; }; + 099A2EDAE7CA9DFE548C0143 /* SBUEmojiListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 44C879D1FFF9A02FD6EC7826 /* SBUEmojiListViewController.swift */; }; + 0AB54DCF8BD1B1B4E1DA5092 /* OpenMutedParticipantListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = C480862D8A2D16A98B766589 /* OpenMutedParticipantListView+ViewConverter.swift */; }; + 0AD790EBDAC85B76E056AF87 /* SBUMessageThreadViewController.SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = D7E1ACADA48174C1998A7B11 /* SBUMessageThreadViewController.SwiftUI.swift */; }; 0AF18B8C73BB11FBABC3688D /* CustomGroupMemberList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 29C09A758F4B4E167933E832 /* CustomGroupMemberList.swift */; }; - 0AF54942AA36849D498811A3 /* CreateGroupChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BA7D637DA3F016BB278AC0E /* CreateGroupChannelView.swift */; }; 0B206B68339562497D2F44A3 /* CustomGroupChannelSettings.SubView.Builder.moderations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3300D14C142B4740F0438811 /* CustomGroupChannelSettings.SubView.Builder.moderations.swift */; }; - 0B3121A9A5C7036C3181007E /* SBUQuotedMessageViewProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = F680D037CDE9E80938B09CC6 /* SBUQuotedMessageViewProtocol.swift */; }; - 0B34A5551E2DED6ADDE63CFF /* GroupChannelRegisterOperatorView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3580081863865A49C61883FE /* GroupChannelRegisterOperatorView+ViewConverter.swift */; }; - 0B873482FEFADB21E16A6EEE /* SBUMessageTemplateCellLayout.swift in Sources */ = {isa = PBXBuildFile; fileRef = 374258FE63226944670893DB /* SBUMessageTemplateCellLayout.swift */; }; 0B8D422DA84270DAC09CF0C7 /* CustomInviteUser.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = CA1DD2E5AE504E97921165C8 /* CustomInviteUser.ViewConverter.List.userNameLabel.swift */; }; - 0BA7595DAD97702571BA7916 /* SBUBaseChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 304A09ECDE1B9834CD9A4E19 /* SBUBaseChannelViewModel.swift */; }; 0BB8F37564A4E3DCF2F276EE /* CustomOpenChannel.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = CF631CBCF396FA6414917B91 /* CustomOpenChannel.SwiftUI.View.CustomMain.swift */; }; - 0BFB374169F7A70227B32B68 /* SendbirdUI+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6BCFF1A7BD3C2D592E67391A /* SendbirdUI+SwiftUI.swift */; }; - 0C7BA48C658CE0ED4CAB7A7A /* SBUReactionCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3846C23C9BCC45CA38A719FE /* SBUReactionCollectionViewCell.swift */; }; + 0BD22A6449BD8262CE3756EC /* SBUScrollOptions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 07C8D193A2E09030747F8FF6 /* SBUScrollOptions.swift */; }; + 0C27C90307067551A9A637D2 /* SBUOpenChannelFileMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9894EDC6924A66DE7D950197 /* SBUOpenChannelFileMessageCell.swift */; }; + 0C57985D8FE67FC87D94687F /* SBUOpenChannelListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F8BD3B6A480001E40AE01F3 /* SBUOpenChannelListModule.Header+SwiftUI.swift */; }; + 0C747AC29AABEC0933228BB5 /* SBUMessageTemplate.Payload.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF2B1200556A2038713B5612 /* SBUMessageTemplate.Payload.swift */; }; 0CA6872674A929B565DFF27D /* CustomOpenParticipantList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7FEEA8F347B582521FCD6832 /* CustomOpenParticipantList.swift */; }; 0CA699D4EAA347284F24539F /* CustomGroupChannel.ViewConverter.Header.typingStatusView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CF06ED3F6955863BF89D804C /* CustomGroupChannel.ViewConverter.Header.typingStatusView.swift */; }; 0CB0065C93DC8FFF6A4679D8 /* CustomMessageThread.ViewConverter.Input.sendButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = A03292F2BC70DF952DE00861 /* CustomMessageThread.ViewConverter.Input.sendButton.swift */; }; - 0CB77FFE192888B064D9AE52 /* GroupOperatorListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 647093ADCCD6A67EC419903A /* GroupOperatorListViewConverter.List.swift */; }; - 0CFF3C908E611F9CEA4ABE96 /* SBUInviteUserModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = E85ED75EA5E22BAA62EBFB36 /* SBUInviteUserModule.Deprecated.swift */; }; - 0D2CAA45B1EF5E2E2E6D647A /* SBUModerationsViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8579E772B5F950377C00E855 /* SBUModerationsViewController.Deprecated.swift */; }; - 0D4DC17049C1CDC466A2A9D3 /* SBUConfig.OpenChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = EFE82704B02948EF4CB57B1C /* SBUConfig.OpenChannel.swift */; }; + 0CF3C73661223534635C9658 /* SBUMessageTemplateCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A5845DA1C7AF582A65422E50 /* SBUMessageTemplateCell.swift */; }; + 0D115603E813723F8194405A /* SBUModerationsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C6B64F40A2CCC515B0EC030 /* SBUModerationsModule.Deprecated.swift */; }; + 0D1AAB233E88F9E3B385B1DE /* SBUInviteUserModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = DD44488053095D7122FB760C /* SBUInviteUserModule.swift */; }; 0D8D8D404B58E881DD31CFFB /* CustomOpenChannelList.ViewConverter.List.channelName.swift in Sources */ = {isa = PBXBuildFile; fileRef = D858342C8951A91AE5FA7F29 /* CustomOpenChannelList.ViewConverter.List.channelName.swift */; }; - 0DE339B2E17A3D2FD1AB150F /* SBUInviteUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0FB5A38900DB0EB791444A96 /* SBUInviteUserCell+SwiftUI.swift */; }; - 0DEF56F6757B109D7FA7BEE2 /* OpenOperatorListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F30867017D52BC55BF8A8F2 /* OpenOperatorListViewConverter.List.swift */; }; + 0E2967410CDFB920C4FF8E50 /* GroupOperatorListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = FFA78758B8276DAA3B4E9BEE /* GroupOperatorListView+Item.swift */; }; 0E7A3B6DF858A0709B6BD286 /* CustomInviteUser.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 859105D58C941EB14073F9F1 /* CustomInviteUser.ViewConverter.List.entireView.swift */; }; - 0E7BF9CB04DF1C6EE821C217 /* GroupChannelPushSettingsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 574826B35D2867EBF562685B /* GroupChannelPushSettingsView+Item.swift */; }; - 0E7EF6182788D615A13C630C /* UIView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 026199A2CE3A7D4DBA022604 /* UIView+SBUIKit.swift */; }; - 0E9ECC8C2374A387DAEA92AF /* SBUInviteUserModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D8C03E266B5DC64D27B8F44 /* SBUInviteUserModule.List.swift */; }; - 0E9EDEA535577EA289FF08B2 /* SBUBaseChannelListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F4C42BBF3DAEC2178B976E9 /* SBUBaseChannelListModule.Header.swift */; }; + 0E80D604138939D542FFA19D /* GroupBannedUserListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = ECDE3327C779F78C5CA0DC65 /* GroupBannedUserListViewConverter.List.swift */; }; 0EAE49464F79FC90733B292C /* CustomOpenChannel.ViewConverter.Input.addButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = A9D88030BE14DF71F88DC365 /* CustomOpenChannel.ViewConverter.Input.addButton.swift */; }; 0F18CC3D902A44D0364C0742 /* CustomInviteUser.swift in Sources */ = {isa = PBXBuildFile; fileRef = C550DBA483C82B34FA1CAEB2 /* CustomInviteUser.swift */; }; + 0F74F4016F18E2A99B5A8FF3 /* SBUCreateChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = C14904CE37235FCDF0FF6ACD /* SBUCreateChannelViewController.Deprecated.swift */; }; 0F7C39925BFE250526EC893D /* CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = D6830E84616231F70E92CB43 /* CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift */; }; + 0FA3ED5FF3C7A82A72DB865C /* SBUGroupChannelViewController+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3FFC8EB13F480E8BEAFC5E6A /* SBUGroupChannelViewController+SwiftUI.swift */; }; 0FD962C85A0124D671EEFD5A /* CustomGroupChannelList.ViewConverter.List.coverImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A85FE7A6759FC81DC272274 /* CustomGroupChannelList.ViewConverter.List.coverImage.swift */; }; - 112188B1E80592B02E43ECE9 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = DD198E6C9A69D0C4810F6C0F /* SBUGroupMutedMemberListUserCell+SwiftUI.swift */; }; + 0FF0CC8E45E4CB7DCD8923BC /* SBUOpenChannelSettingsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD331F75C4062F3566D75108 /* SBUOpenChannelSettingsModule.Deprecated.swift */; }; + 101A2310CFCEA9A19AF991F8 /* SBURegisterOperatorModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = FD8219759D395864DBC89499 /* SBURegisterOperatorModule.List.swift */; }; + 101B541C74D71CA5C4890A81 /* SBUOpenChannelSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = F6255269EEFB1064CBD9ED02 /* SBUOpenChannelSettingsViewController.swift */; }; + 103F4D7BE202A4F1F1307B84 /* SBUMessageInputView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 887FB1AF021C77AE2658CF59 /* SBUMessageInputView+SwiftUI.swift */; }; + 10B2ABFE9DBB9C42A0575A2B /* SBUMessageTemplateCellLayout.swift in Sources */ = {isa = PBXBuildFile; fileRef = 559F4134A4DA519D83ECCEED /* SBUMessageTemplateCellLayout.swift */; }; + 10D645939926994E2369D679 /* SBUConfig.Common.swift in Sources */ = {isa = PBXBuildFile; fileRef = F94CBE179EC28528B6D75C20 /* SBUConfig.Common.swift */; }; + 112E01B82F75D4D02921299E /* SBUMessageSearchModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2409918FAB1E81ADAE21623 /* SBUMessageSearchModule.Header.swift */; }; + 11545F37072B247002058199 /* SBUTypingIndicatorMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 90DCABD83770A8345AEC3919 /* SBUTypingIndicatorMessageCell.swift */; }; + 11659F092A8E2355A455E687 /* SBUNotificationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8C72EA12FBDBE0429DB866B0 /* SBUNotificationCell.swift */; }; + 12484B91A36082E1D7B3981A /* SBUMessageThreadModule.Input+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 34127F637D9BA4589A5E73CB /* SBUMessageThreadModule.Input+SwiftUI.swift */; }; + 1277097C86BAE76CC54A6EE5 /* SBUTemplateType.swift in Sources */ = {isa = PBXBuildFile; fileRef = CF2784E3ECE293C035C957A6 /* SBUTemplateType.swift */; }; + 12A9851DC436E5947835D61B /* SBUView.Unavaliable.swift in Sources */ = {isa = PBXBuildFile; fileRef = E0F389D1E864F9A48260D9C7 /* SBUView.Unavaliable.swift */; }; 12B028BC8329A1786FD812A4 /* CustomMessageThread.ViewConverter.List.senderProfileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1D2EAD5AE3B031549D4E8E9D /* CustomMessageThread.ViewConverter.List.senderProfileImage.swift */; }; 12E1DA02C0029F18799584FF /* CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3063FC91B4A7751B29DC80B1 /* CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift */; }; - 130CB58D0AE566A514B6C60A /* SBUMarkdownTransfer.swift in Sources */ = {isa = PBXBuildFile; fileRef = D2F9885440D0492C8904699E /* SBUMarkdownTransfer.swift */; }; + 133B357AACE5246AB58946DB /* GroupMutedMemberListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 074C60BDD434834C451516D4 /* GroupMutedMemberListView+ViewConverter.swift */; }; 1355FAAE4ACFCE5DB8B84779 /* CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 274069D20D2F3B5E40ADC2D2 /* CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift */; }; + 135C6711638D6C75602E9A10 /* OpenMutedParticipantListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = D5E60FEA77508AA565B02B9B /* OpenMutedParticipantListView+Item.swift */; }; + 13716072DD23C523DE7173CE /* SBUCreateChannelTypeSelector.swift in Sources */ = {isa = PBXBuildFile; fileRef = 71CDC288E01D00AB7B00DBCE /* SBUCreateChannelTypeSelector.swift */; }; 13AF8585B34B9C4B06D2F764 /* CustomGroupChannel.ViewConverter.Input.voiceButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 18AA52A71ED80E2FE000C626 /* CustomGroupChannel.ViewConverter.Input.voiceButton.swift */; }; - 13B7E99F054FD7EDA9AC835D /* SBUGroupBannedUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CCF3DD6DAEDA6404D3F9EDFB /* SBUGroupBannedUserListModule.Header+SwiftUI.swift */; }; - 13EF136B8AF94AD0C8811ABC /* SBUStringSet.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 599E3037238837AC8467C033 /* SBUStringSet.Deprecated.swift */; }; - 142C04F278D263E09B627C49 /* CommonProtocols.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD039AD94BFA1191FFFA3149 /* CommonProtocols.swift */; }; + 13C6CA31E98C268D30A31DD2 /* GroupChannelListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F8BCC1FD155F0E5F9AC2C3D /* GroupChannelListViewProvider.swift */; }; + 13E4E6078E5CD48C96B09D21 /* SBUContentBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85648A3B41D27C36B032B178 /* SBUContentBaseMessageCell.swift */; }; + 13F17B7FDD4E9FF8A933C8FD /* SBUAlertView.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 59A09DB977466D219BBC36EA /* SBUAlertView.Item.swift */; }; + 140FB25B85486638A0BE4C4D /* SBUMessageFormView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 29FE8D858AD7C69E3B2FF2EE /* SBUMessageFormView.swift */; }; + 142C0C8E5E796A5227AF79FD /* SBUOpenOperatorListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = DFAF3C2261ECEBCC158D13CD /* SBUOpenOperatorListModule.List+SwiftUI.swift */; }; 1446EF3B283113B18A535B24 /* CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7BC19298E51750C9D0D610A1 /* CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift */; }; + 147B46CF860FB32B3C32D97E /* GroupMemberListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = F624E4320147A947036A7DE1 /* GroupMemberListView+SubViewBuilder.swift */; }; + 14AF8B85B474D29FEA3E2E61 /* SBUOpenChannelImageContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D2FFCD9112A92A33B800F41A /* SBUOpenChannelImageContentView.swift */; }; 14BC70FEA69651C6EE494CC4 /* CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F9BC7BDE74485AE5C8C934A4 /* CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift */; }; - 15015802991AFE1E136071A2 /* SBUQuotedUserMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 86CD79484A29B4EA66EC4B0C /* SBUQuotedUserMessageView.swift */; }; - 150C54165E25735C227560B4 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 367715EF02DB7B56C38D52A8 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift */; }; - 152F55CC6AE8166A23EC83D3 /* SBUNewMessageInfo+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D75B2A23956659470CD7213 /* SBUNewMessageInfo+SwiftUI.swift */; }; - 153D98B039DCF5F5084D88F9 /* SBUVoicePlayer.swift in Sources */ = {isa = PBXBuildFile; fileRef = 092C81FE6CB8C115FFB896E6 /* SBUVoicePlayer.swift */; }; - 154F02373DE0C18BD9E6A507 /* GroupChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1C19B6EF4242A39ED9990598 /* GroupChannelViewConverter.Header.swift */; }; - 155034F91E88C596503B400F /* SBUFeedNotificationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 78DC43005F3DE461ADE2DEAA /* SBUFeedNotificationCell.swift */; }; - 158F0AE32FEAAEF95C59788E /* SBULogger.swift in Sources */ = {isa = PBXBuildFile; fileRef = D677AA356C4DC935016C176E /* SBULogger.swift */; }; - 15AEC541D37A66CA53872261 /* SBUTypingMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = A2B05FBDB7E619A9A48FA28F /* SBUTypingMessageCellParams.swift */; }; + 151604A8951C75CA8B6470F6 /* SBUOpenChannelSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2A62CCCCB59301329BD70E3D /* SBUOpenChannelSettingsViewModel.swift */; }; + 1520194D5810C4B569FE815B /* OpenParticipantListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE8F91080D5B149513B0FF6A /* OpenParticipantListViewConverter.swift */; }; + 15666B586ABBE148301CF2CE /* SBUToastView.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = DD82DA89A3CA5C66A6996786 /* SBUToastView.Item.swift */; }; + 159EFF704D530D3BB7954F9A /* GroupModerationsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 70474C82754DA2A006251C40 /* GroupModerationsViewConverter.Header.swift */; }; + 15BD2E6ABE5303E3D71DEAEC /* Data+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = D38E6015D6853331994CD11F /* Data+SBUIKit.swift */; }; + 15D335EDBF557813CF0B7DE9 /* SBUMessageTemplate.ErrorMessages.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1F2F32D7E4883A0DAA8DB902 /* SBUMessageTemplate.ErrorMessages.swift */; }; 15DE6C53B8E98DECB8662181 /* CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 254B1E417C819DCD58A83742 /* CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift */; }; - 1623C20672C40F24BECBD4B0 /* SBUMessageTemplate.Decoders.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2938701A69B6EA5F371B33A0 /* SBUMessageTemplate.Decoders.swift */; }; - 165275B7994606FCA5389DAD /* OpenOperatorListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 08AE1C3D2DAF93702E8C3E6B /* OpenOperatorListView+SubViewBuilder.swift */; }; - 16E9FF91ED8E29009296D913 /* GroupMutedMemberListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0965E8B16F9D4C0559C110F /* GroupMutedMemberListView+ViewConverter.swift */; }; - 17588F67A5F570D5DBB9C5F6 /* GroupChannelViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = E89F994B7B6B705FD09B4921 /* GroupChannelViewConverter.List.swift */; }; + 166F9E7A0021FDD057EFF4DE /* GroupMemberListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 26A32BBCC22F6F9C43CE2299 /* GroupMemberListView+ViewConverter.swift */; }; + 168321D0F7F44797E10226F0 /* SBUBaseMessageCellParams.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3478D6F58D07B41B64C21B46 /* SBUBaseMessageCellParams.Deprecated.swift */; }; + 16A2639ABADF02310D7681F0 /* SBUMessageTemplate.Renderer+RenderStyles.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6643E3E65786C6485BDDA545 /* SBUMessageTemplate.Renderer+RenderStyles.swift */; }; 1762C9DBC8F590B0D0686725 /* CustomOpenBannedUserList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7FB951B495F7482D3DFCF6FF /* CustomOpenBannedUserList.ViewConverter.List.entireView.swift */; }; 17763381B043EC1352EA5A58 /* CustomMessageSearch.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BB10FC3F72D7FCC938FCA63 /* CustomMessageSearch.ViewConverter.Header.titleView.swift */; }; 177F1C7DF47A440C6A333C0C /* CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift in Sources */ = {isa = PBXBuildFile; fileRef = 62590526052269EA23C6E769 /* CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift */; }; - 17CB908AC8EE4178560C893D /* CreateOpenChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7FB320B188CFD4C01CCEF5A /* CreateOpenChannelView.swift */; }; - 18157D39446334925AAAAF9B /* SBUUserMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69FA8142D379C935F954206C /* SBUUserMessageCell.swift */; }; - 181DCED5C5544A3F86180085 /* SBUCreateChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = C2CC930353E9AF952D5C1E72 /* SBUCreateChannelViewController.swift */; }; - 1885480A55126999F1DE6E8A /* SBUQuoteMessageInputView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F4E0A861082E4DD96C4AF034 /* SBUQuoteMessageInputView.swift */; }; - 188A4D6E24B8CF4AF46670BC /* GroupOperatorListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = A4E6B3FBFE02752B58883E4B /* GroupOperatorListView+Item.swift */; }; - 188D2F501E622F6B61F66DDA /* InviteUserView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = FD96D51055C0724028FBB802 /* InviteUserView+ViewConverter.swift */; }; + 17903F522658CE0BB9EC6A72 /* SBURegisterOperatorViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = EF30301466491271F0E3512D /* SBURegisterOperatorViewController.swift */; }; + 17F67B46A6B3EF856DDE32F6 /* SBUMessageTemplate.Renderer.Views.swift in Sources */ = {isa = PBXBuildFile; fileRef = E593C2078945818E573F8A66 /* SBUMessageTemplate.Renderer.Views.swift */; }; + 180AC254F1DDA0DEBC3E45D3 /* SBUMessageReactionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8B5C96EC8862AA9CA0719BE8 /* SBUMessageReactionView.swift */; }; + 1820475945938BFF7FE245C4 /* SBUGroupChannelListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1729EF71A43A28ABF375F9A0 /* SBUGroupChannelListViewController.swift */; }; 18D95CCBB16ECA34423D3A89 /* CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = C05AA4A4BD31F43C7ABE474F /* CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift */; }; + 18E68A1318906554CFD9F758 /* SBUMessageTemplate.Renderer.RendererType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 87FA2058A4863E17BF50A632 /* SBUMessageTemplate.Renderer.RendererType.swift */; }; 18F341F0BE21B31F6F11DAF6 /* CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = D60BB10FA597EA02D980A94F /* CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift */; }; + 19048A9532E6C9ADC902F0A8 /* SBUThreadInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A172ECA24F1EED3C916C4B10 /* SBUThreadInfoView.swift */; }; + 19094B7F7BADCE19F493BE65 /* BaseMessage+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68610F5D31C4E9913A09CCD4 /* BaseMessage+SBUIKit.swift */; }; 19322CA3DC0AFD2F7D8B1094 /* CustomOpenChannelList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 98DACE2F878024BB6383C53F /* CustomOpenChannelList.ViewConverter.Header.rightView.swift */; }; - 19DD09C33C5BA282969E440D /* SBUMessageTemplate.TemplateList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2CC3E6F72DBC8FEE5B5FF69A /* SBUMessageTemplate.TemplateList.swift */; }; - 1A2C611176CCF3F1064D4306 /* SBUToastType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6F685142DBEC56397DF49B04 /* SBUToastType.swift */; }; + 193FF15E70578558727AB9AA /* SBUFeedNotificationCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = E68C5044109960435BBDBF86 /* SBUFeedNotificationCellParams.swift */; }; + 1985015BBDC92D9FFFCDCC12 /* GroupChannelViewConverter.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 42FB13DE92ED80900AD05054 /* GroupChannelViewConverter.Input.swift */; }; + 19B611A4548CFA8C5102D78C /* SBUBaseChannelListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = E60ABCC74B32B1B8BD7232BD /* SBUBaseChannelListModule.Header.swift */; }; + 1A4D92E04F069A9308EBDEBC /* SBUMultipleFilesMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3046107CAA8EAABF90DD8218 /* SBUMultipleFilesMessageCellParams.swift */; }; 1A64C2B2F4DE4F40EB6D4143 /* CustomOpenModerations.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 031A3770C7F979E10B2F46B2 /* CustomOpenModerations.SwiftUI.View.CustomMain.swift */; }; 1A83A9D1452EB3E5A9746056 /* CustomOpenChannel.ViewConverter.Input.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9C2CA31E5B4CC3F3DAE26D97 /* CustomOpenChannel.ViewConverter.Input.entireView.swift */; }; - 1AEBA5EA1D4CA925242B4B95 /* SBUGroupChannelViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 46FF82F5B4555A400669ADA2 /* SBUGroupChannelViewController.Unavailable.swift */; }; 1AF74139D349D14CBE248478 /* CustomSampleSubView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6C01527DA7DC24CAFBDFD28D /* CustomSampleSubView.swift */; }; 1AFA2E014D93F4C3A236094B /* CustomOpenBannedUserList.swift in Sources */ = {isa = PBXBuildFile; fileRef = E166ED5498A74640EC21B366 /* CustomOpenBannedUserList.swift */; }; - 1B1DEF5A353560183FD461ED /* OpenBannedUserListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6099C0F4584A7A7822DF81D6 /* OpenBannedUserListViewConverter.Header.swift */; }; - 1B6A2888CA898D3252A92F6F /* GroupOperatorListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = CC3F606B79E0EAB2E982DC39 /* GroupOperatorListView+SubViewBuilder.swift */; }; - 1BBAA717CCB2197403FE4B48 /* SBUUserProfileView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 24001A687A99EDBCB633CFD9 /* SBUUserProfileView.swift */; }; - 1BD0F8B3D9A84B0192BFB452 /* CreateOpenChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = E3242DE074C1AA33D5C85D4B /* CreateOpenChannelViewConverter.Header.swift */; }; - 1BE5FC9A8C2FD5B5C3D3D9AC /* SBUOpenOperatorListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0A85529A02737F4F20AFDCA2 /* SBUOpenOperatorListModule.Header+SwiftUI.swift */; }; + 1BD2FDDBCF28B325ED23743F /* SBUInviteUserViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D843E5D2908EB56EFDC2E4E /* SBUInviteUserViewController.swift */; }; + 1BE0CD8344B6CF2AD61E502C /* SBURegisterOperatorModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = D95DA4F7F43B4408328A06B2 /* SBURegisterOperatorModule.Deprecated.swift */; }; + 1BE244E44E2C84BB2724B395 /* CreateGroupChannelViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = BE55BC5056EEB299BC27EF13 /* CreateGroupChannelViewProvider.swift */; }; 1BF954C4BA7EC179AEB8761A /* CustomCreateGroupChannel.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = BB3D6D98B9661B747DCF6AA5 /* CustomCreateGroupChannel.SwiftUI.View.Main.swift */; }; + 1C4F3D64825F74BC8E9C43BC /* SBUScrollBottomView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B8D4F66B16058506BB43940F /* SBUScrollBottomView.swift */; }; + 1C5E24DDCDEA510D196A9A5F /* SendbirdUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8EBCAEA988BE8EE57CD4DE26 /* SendbirdUI.swift */; }; + 1C974CABBD0DE21CE565B2A0 /* SBUMessageSearchResultCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 627DBB55B063137DA9273A8A /* SBUMessageSearchResultCell.swift */; }; 1C9989C572D67426DC03599E /* CustomOpenOperatorList.SubView.Builder.registerOperator.swift in Sources */ = {isa = PBXBuildFile; fileRef = 90D8DE1D14DD3A1D25ED47F3 /* CustomOpenOperatorList.SubView.Builder.registerOperator.swift */; }; - 1CB1CCD3DB5A40FBD5128383 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 66DCC726041A9BF5D118CCE1 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift */; }; + 1CB2BEA9D7D6D449E421FDAF /* GroupBannedUserListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81EFDEE298AB85013EA1761F /* GroupBannedUserListView.swift */; }; 1CCC15F9D135ABB7F92046C0 /* CustomCreateGroupChannel.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DEE6B3475E267184B7C0921 /* CustomCreateGroupChannel.ViewConverter.List.entireView.swift */; }; 1CD2122F20210ADFEBF694E5 /* CustomGroupChannelRegisterOperator.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4E59F203B7488D4BC92B8103 /* CustomGroupChannelRegisterOperator.swift */; }; - 1CD7213BF7AE6B3C5FD68BCA /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4891397AAB5DCBD36AAE7D51 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift */; }; - 1CDB503F30FC2AB8FF73576F /* SBUMessageFormView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 384A0D8AB5B526308F89634E /* SBUMessageFormView.swift */; }; - 1CF6CC40EECB4EC563E19158 /* SBUVoiceMessageConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33A19DC31A19B9871C014844 /* SBUVoiceMessageConfiguration.swift */; }; - 1D2B28D0D92973CF4081216C /* GroupModerationsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 472483201FA056ED9A255321 /* GroupModerationsViewConverter.swift */; }; - 1D318FFF730CD58BF3E3D03C /* BaseMessage+SBUIKit.MessageTemplate.swift in Sources */ = {isa = PBXBuildFile; fileRef = F566B012103F8EEBE03AECA3 /* BaseMessage+SBUIKit.MessageTemplate.swift */; }; - 1D41D6C1454CC82937DEC230 /* SBUMessageTemplate.Syntax.Identifier.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D90AA83494B7F9C031B6DD2 /* SBUMessageTemplate.Syntax.Identifier.swift */; }; - 1D75C1E950BC28D2C4B55BC4 /* SBUMessageTemplate.ImageRatioType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69ADDDE3739EDAA8933BAF4C /* SBUMessageTemplate.ImageRatioType.swift */; }; - 1D83365CA99CC195113CC2DA /* WrapperUIViews.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BB8896A51AC9A129CED3AA1 /* WrapperUIViews.swift */; }; + 1D04320552FDEE949ABE2CC6 /* UIView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9CFDA621D7A6EB6427288A6 /* UIView+SBUIKit.swift */; }; + 1D0FD5DBEE14840FE2B9E4ED /* SBUConfig.CodingKeys.swift in Sources */ = {isa = PBXBuildFile; fileRef = CE5CDE3DA748B162A1898531 /* SBUConfig.CodingKeys.swift */; }; + 1DA87FEB8D2DA780F94968BC /* SBUSuggestedReplyOptionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 83D46A1142AC3CC4D1396719 /* SBUSuggestedReplyOptionView.swift */; }; 1DB92650D9A059FA92939341 /* CustomGroupModerations.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55EAE96A85D7F046159B3D87 /* CustomGroupModerations.ViewConverter.Header.leftView.swift */; }; - 1DD67D8C0A184CFB3622746B /* SBUOpenChannelUserMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = B78C4CB73E4DC57DEC979D99 /* SBUOpenChannelUserMessageCell.swift */; }; - 1DDE92BE762570E25EDA42FE /* MultipleFilesMessage+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5CB7111297AFFD4F44521579 /* MultipleFilesMessage+SBUIKit.swift */; }; + 1DDE050C3CD80D80788F2DB5 /* SBUGroupChannelSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 18FD3B37FC9DE267350E60D6 /* SBUGroupChannelSettingsViewModel.swift */; }; 1DE630C30971DB7682BC188D /* CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D892CA4FD6B2597BFF04D24F /* CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift */; }; - 1DF4725BF5B522C48426DC88 /* SBUNotificationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 13DE0F9AF0C8495874233F35 /* SBUNotificationCell.swift */; }; - 1DFFD08112E02DBE0274D54E /* SBUMessageSearchViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B76D4B10BDE52AD3E7C6B136 /* SBUMessageSearchViewController.swift */; }; - 1E40B251A39274B0DDA89157 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4CC6408E970D9582343C2F67 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift */; }; - 1E435408BA84F9E42973B50A /* SBUInviteUserViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 16A073C3C063FECB43EE3886 /* SBUInviteUserViewController.swift */; }; + 1E1CF9B8D095F6C875D049CE /* OpenChannelRegisterOperatorViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF34A3B458887980810747D2 /* OpenChannelRegisterOperatorViewConverter.Header.swift */; }; + 1E2F3C901891AE37BA3DE884 /* OpenMutedParticipantListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1CE8E0AE7AC6EA86FDF2BB5 /* OpenMutedParticipantListView.swift */; }; 1E4E18D92843E192F76648F7 /* CustomGroupMutedMemberList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C5266F61E9850A492752AF7 /* CustomGroupMutedMemberList.ViewConverter.List.entireView.swift */; }; - 1E9CFDDE19604AF05970F40E /* SBURegisterOperatorModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = B461281DDE306B84C3893B7F /* SBURegisterOperatorModule.Header.swift */; }; - 1EB0F0FB0921F42151B381F8 /* SBUMessageFormChipView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 904618EB6B0A591FC15D1542 /* SBUMessageFormChipView.swift */; }; + 1E75BE962CC544B3DBE71148 /* SBUBaseChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB3E0B3AF5888509BFD2E7D5 /* SBUBaseChannelModule.swift */; }; + 1EA1B94BD1DE798DBC92E0F3 /* SBUMessageTemplate.Decoders.swift in Sources */ = {isa = PBXBuildFile; fileRef = FBB443922F23428075A25054 /* SBUMessageTemplate.Decoders.swift */; }; + 1EB613FE017F0721F3EB6808 /* OpenChannelListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 86B0D9E7E2F38DE9B72E811D /* OpenChannelListViewConverter.swift */; }; 1EBD15B2C5E7487E46E4E43A /* CustomOpenChannelList.SubView.Builder.createChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3689A9086F74AAAEAB2FC8F7 /* CustomOpenChannelList.SubView.Builder.createChannel.swift */; }; - 1EF752D3E3CA604EB7052956 /* SBUMessageCache.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1C082271530831A0A97BA43 /* SBUMessageCache.swift */; }; + 1ED181995790C6173895BFA4 /* SBUCacheManager.Template.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB20C7C8D91A4FB6BE5BB00A /* SBUCacheManager.Template.swift */; }; + 1EDF91717F258127078B8C74 /* SBUGroupChannelPushSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 51564EBFCB24F043472D1D55 /* SBUGroupChannelPushSettingsModule.List.swift */; }; + 1F145397F88D546FD032E326 /* GroupMutedMemberListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4BDBA5011291E3E322F0660F /* GroupMutedMemberListView.swift */; }; + 1F4086119B5C13A0F6D5E418 /* SBUScrollPostionConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = F953887FA77606336B478451 /* SBUScrollPostionConfiguration.swift */; }; 1F51C756D745C5DE1758F91A /* CustomTheme.ColorSet.Custom.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 44AC2120ADDF0EB8ED8D341E /* CustomTheme.ColorSet.Custom.Main.swift */; }; 1F816F12112DFC4D2DF55764 /* CustomGroupMemberList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FD7B856C7B2765E3C158DCE /* CustomGroupMemberList.ViewConverter.Header.rightView.swift */; }; - 1FFA61368D52D367BDBEFC5A /* InviteUserView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3BCF8D7F6481CF9321250DF9 /* InviteUserView+SubViewBuilder.swift */; }; + 1FD06B124BE1EC29BDA99E07 /* SBUExtendedMessagePayloadForUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 61EFB9AFE83364174EFF7E68 /* SBUExtendedMessagePayloadForUI.swift */; }; 200064B087980A103CE23DDC /* CustomMessageThread.ViewConverter.Input.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F4F269E21BC1771EA562A1E /* CustomMessageThread.ViewConverter.Input.entireView.swift */; }; - 201120B35CFB5D19CCF88E89 /* MessageForm+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 86D998504A47DE9BAAC543C1 /* MessageForm+SBUIKit.swift */; }; 2024C4E99883B72EF605CE2B /* CustomGroupChannelSettings.ViewConverter.List.moderation.swift in Sources */ = {isa = PBXBuildFile; fileRef = FE3455B16C9555F970F4D601 /* CustomGroupChannelSettings.ViewConverter.List.moderation.swift */; }; - 2057B0454F27A7A20B1373C5 /* SBUCommonViewControllerSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 93C6EE37AC969FB9BBAF7B8E /* SBUCommonViewControllerSet.swift */; }; + 2034AC28EDE34FCFC1C6CBF9 /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3002316F9F925813729C3DE0 /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift */; }; 209CA9D4547B30990757AAFD /* CustomGroupChannel.ViewConverter.Input.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 18DAC3A6A235AF92E38CC492 /* CustomGroupChannel.ViewConverter.Input.leftView.swift */; }; + 20A39FBACE4A33889DE64B91 /* SBUMessageProfileView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C3AD5EEF2606A62F9F0CD9E2 /* SBUMessageProfileView.swift */; }; 20CD5894BD6AE6A7E5C0BE2D /* CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = EB41910E2789F6B96EF2934E /* CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift */; }; 2110D34263FD04A20ACF8B33 /* CustomGroupChannelList.ViewConverter.List.channelName.swift in Sources */ = {isa = PBXBuildFile; fileRef = 72E615EBA26684FF934C2D41 /* CustomGroupChannelList.ViewConverter.List.channelName.swift */; }; - 21A67DAEA05E61BC99F5D0CB /* SBUUserMentionConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3DDDA8624C4543555B800D2C /* SBUUserMentionConfiguration.swift */; }; - 21B715602294D016F17A2457 /* SBUBaseMessageCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F974D6F1E53ED5AB2C2C84C /* SBUBaseMessageCell+SwiftUI.swift */; }; - 21F84F844BADB840E84D553E /* SBUChannelTitleView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = AE4CCA39B22DF2E106943CE0 /* SBUChannelTitleView+SwiftUI.swift */; }; + 2137E2A26E2DF0841EC114C2 /* SBUOpenChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 953E1A70757DE741732BA909 /* SBUOpenChannelModule.swift */; }; + 21A7991F06297EBACD3D1B0C /* SBUQuotedFileMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE88D3E3ECD3A7A231EA8AA7 /* SBUQuotedFileMessageView.swift */; }; 21FCE8C55C612C7D01C26264 /* CustomGroupChannelSettings.SubView.Builder.userList.swift in Sources */ = {isa = PBXBuildFile; fileRef = BDE26BC1BAF5CEC2C2C5135F /* CustomGroupChannelSettings.SubView.Builder.userList.swift */; }; - 224D5B1C3DBD8C960E1276B5 /* OpenChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 30394872D50BA64B985DA1FF /* OpenChannelView.swift */; }; - 226FF5F3F53C7972E4EA780D /* SBUMessageThreadModule.Input+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 05328E6371DCAEDAEF7BB16A /* SBUMessageThreadModule.Input+SwiftUI.swift */; }; - 228088466D9334448D949249 /* InviteUserViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = AE33606F2063A12272D6CCB7 /* InviteUserViewConverter.List.swift */; }; - 2319983E0726011906AC7FD4 /* SBUInviteUserViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D2D48D4D2A4206F1DDE7CD7 /* SBUInviteUserViewModel.swift */; }; - 2320A12AD4A24FD50A506784 /* GroupChannelListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = F37A3C0CAC8D9964CABBB7D5 /* GroupChannelListViewConverter.List.swift */; }; + 2261BA068FDFDE8CCE7FF496 /* MessageThreadViewConverter.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 514BADC1204C3F13E85FAF35 /* MessageThreadViewConverter.Input.swift */; }; + 2292600E3BADD7725969DF11 /* OpenMutedParticipantListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5E7ECC0D58ECDC06EF0183F3 /* OpenMutedParticipantListViewConverter.List.swift */; }; + 22C17F40E9DD1D81F417BD2C /* SBUMessageTemplate.Syntax.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = CEFEC44A228BCC230686AC05 /* SBUMessageTemplate.Syntax.Item.swift */; }; + 22CFFC50B3702F4CC8BA9896 /* SBUMessageThreadModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D04B328AB000735BD52BE9D /* SBUMessageThreadModule.swift */; }; + 230BD6735D8A6BF1421E3637 /* SBULogger.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0176BCE61DDDBD6F0937F8E /* SBULogger.swift */; }; 2365770F3E1395793D9121BD /* CustomOpenChannel.SubView.Builder.channelSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A90A31A500C5E9AAE45A08C /* CustomOpenChannel.SubView.Builder.channelSettings.swift */; }; - 237893FFC266BAB3578B4489 /* SBUUserMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = B05DC3A2E750EC0A12CC4393 /* SBUUserMessageCellParams.swift */; }; - 2396C41E13FDB99A2EC97888 /* SBUFormViewParams.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1DB8F69105F07B296E8C63F7 /* SBUFormViewParams.Deprecated.swift */; }; - 23C626C143D5E5872BFBAC6E /* GroupMutedMemberListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9349402FEC3ACCC843C056E /* GroupMutedMemberListViewConverter.swift */; }; - 242B18DA84070DC4F609033E /* SBUUserMessageTextViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2AB52183CDCA494948E5976E /* SBUUserMessageTextViewModel.swift */; }; - 24457EA1BBCECDB69A3D7136 /* OpenBannedUserListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 051BED79FDD0D9A17F350838 /* OpenBannedUserListView+ViewConverter.swift */; }; - 24749FF29AD6A6E0C47BA551 /* SBUSuggestedReplyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = DFB6D698EDC2ED209371A6BF /* SBUSuggestedReplyView.swift */; }; - 24FAEB760F4A95577BB279F8 /* SBUGroupOperatorListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = D78D017455F58559F9F64C82 /* SBUGroupOperatorListModule.List+SwiftUI.swift */; }; - 2531B2C6B57D1CB3B95A468D /* SBUMessageThreadModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85DBC0A4BA3AD7B3625F04F4 /* SBUMessageThreadModule.Header+SwiftUI.swift */; }; + 237CE7996FB3C050EC4A7275 /* VoiceMessageStatus.swift in Sources */ = {isa = PBXBuildFile; fileRef = 06CE16BE3276D48C2D2E44D4 /* VoiceMessageStatus.swift */; }; + 238FF11DD9F3E063E74F3586 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF5228FB7BBC9672AE3637C5 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift */; }; + 23E9F69D382332605608196E /* MultipleFilesMessage+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 82679D287A3368E9008A1CAC /* MultipleFilesMessage+SBUIKit.swift */; }; + 24028A8B4C6A5D907E061EC8 /* UITableView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 167486D0234433BF424AD399 /* UITableView+SBUIKit.swift */; }; + 24161F49E2F822912347966A /* SBUViewControllerSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9A92CD9FA0255F503C2D351E /* SBUViewControllerSet.swift */; }; + 241CBAEBCA730A0DA87DCA71 /* OpenBannedUserListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52D32A54B554A339D5661CD4 /* OpenBannedUserListView+ViewConverter.swift */; }; + 246F35E088992AB75BBEDAE1 /* SBUOpenChannelViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 51345B6EB0708B353BE6D39D /* SBUOpenChannelViewController.Unavailable.swift */; }; + 248335178A5D2248F1CA75F5 /* SBUCreateOpenChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = FAD037E71A163BD4A3A0BA79 /* SBUCreateOpenChannelModule.Header.swift */; }; + 248F30AE152079810432DB60 /* SBUBaseChannelSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6C8A4D2AB78B5DD00E13566E /* SBUBaseChannelSettingsModule.List.swift */; }; + 24BF8CFD883CDAA204765E8D /* SBUMessageSearchModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F5A9EC87E51CE11529D2B28C /* SBUMessageSearchModule.List+SwiftUI.swift */; }; + 24C047AAFDBA0AB98A880EEB /* SBUCoverImageView.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 76C3E5ACC74FD4BB8F224A67 /* SBUCoverImageView.Deprecated.swift */; }; + 2525EC086630E66A03B5DC26 /* SBUMentionLimitGuideCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 764BFC79756B1BCCE4ACB207 /* SBUMentionLimitGuideCell.swift */; }; 2539FA017B90153078106241 /* CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = BF7C18BECF6A013F82FB18B3 /* CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift */; }; - 2558BB2B7FBB80024FFA9D84 /* Sequence+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 691908423FD3C5E45C4BF41A /* Sequence+SBUIKit.swift */; }; - 256896373CACC223A4F9D297 /* SBUCreateChannelTypeSelector.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D1A9C9D267ADD34ABADC14A /* SBUCreateChannelTypeSelector.swift */; }; - 2598789B240EB34C5FCE28A2 /* SBUBaseMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB0B81E6414A56CEC58EB58E /* SBUBaseMessageCellParams.swift */; }; - 25B7BDF88C9F8F4473A01931 /* SBUOpenChannelModule.Media.swift in Sources */ = {isa = PBXBuildFile; fileRef = 25858342E4D2B978B8BAD861 /* SBUOpenChannelModule.Media.swift */; }; - 25C520E41FC4936B075752F8 /* SBUUnknownMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1CD45E3398D54B7995E3867F /* SBUUnknownMessageCell.swift */; }; - 2637DC0A0C8F965A37AE303E /* SBUFormView.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 515A6FCA6E34F58EB62146AD /* SBUFormView.Deprecated.swift */; }; - 265BA70DB6A018F1AE1D2ECE /* UIFont+Sendbird.swift in Sources */ = {isa = PBXBuildFile; fileRef = 42FDCEFB59A8DBF122F0523E /* UIFont+Sendbird.swift */; }; + 25A83ADAC036FA0729E05948 /* SBUFontSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 08656A9709E292E482DFCDD3 /* SBUFontSet.swift */; }; 2687C154EC3EEBF0580FB234 /* CustomMessageSearch.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F9FF61E04422CDF019FC8A14 /* CustomMessageSearch.ViewConverter.Header.leftView.swift */; }; - 2730E7FEBE4EEE5FD355C129 /* BaseMesssage+SBUIKit.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 002B39B769D0499CC67311F8 /* BaseMesssage+SBUIKit.Deprecated.swift */; }; + 270D763396586533C461C05F /* SBUReplyConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5CFC8E13C50AAE8AFF471AC /* SBUReplyConfiguration.swift */; }; 274ED45E7CD81CCB535C1063 /* CustomGroupChannelList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 310897972F208CD1051FDB43 /* CustomGroupChannelList.ViewConverter.Header.titleView.swift */; }; - 277D34A3FAE8C92339162228 /* GroupChannelPushSettingsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5F3FD4AA9DAA78710AED644D /* GroupChannelPushSettingsViewConverter.List.swift */; }; 2795ECC1A3AABF16AC60ED43 /* CustomInviteUser.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 506B49D35067C017A092EB8C /* CustomInviteUser.ViewConverter.List.profileImage.swift */; }; + 27C36972AE1DF0F51E293527 /* SBUOpenChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 803819597504B510729CE67A /* SBUOpenChannelViewController.swift */; }; 27C3D6EDF94EED97D41E5970 /* CustomMessageThread.ViewConverter.Input.addButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5E7AF0A36D04D33BA1B28E46 /* CustomMessageThread.ViewConverter.Input.addButton.swift */; }; - 27E11C4D9F40C6AB46EF4852 /* SBUCreateOpenChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2E0ABB6DADF9727A38ACB20 /* SBUCreateOpenChannelModule.Deprecated.swift */; }; + 27E39608589E3AD66A2440B7 /* SBUMessageTemplateCell.MessageTemplateLayer.swift in Sources */ = {isa = PBXBuildFile; fileRef = E7513D0A46E6B0D3B734E065 /* SBUMessageTemplateCell.MessageTemplateLayer.swift */; }; + 285FF707C19A9BEFC6DB19DC /* SBUCreateOpenChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = DC897D28420AE8B2454DCA7A /* SBUCreateOpenChannelViewController.swift */; }; 28804398C405B03DECA5B7F6 /* CustomGroupMemberList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0350825D0583AEE1CDC40A22 /* CustomGroupMemberList.ViewConverter.List.userNameLabel.swift */; }; - 2935EDC7B2624F7A96E8A053 /* GroupChannelPushSettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19D36786FC47C674BC286A36 /* GroupChannelPushSettingsView.swift */; }; - 295EB6A6B8612129FEDC7379 /* SBUMessageWebView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 519230E62500F1040802B744 /* SBUMessageWebView.swift */; }; - 2974135DF76DB03A6D24D1FF /* SBUMessageTemplate.Binder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 563DF68B8CFC74728183C069 /* SBUMessageTemplate.Binder.swift */; }; - 29BE03D00D366B85209BD197 /* SBUUserListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1332D36686F1F249E74B711C /* SBUUserListViewModel.swift */; }; - 2A7F6FBA98B39948502492C3 /* SBUHorizontalSuggestedReplyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A95E354523AE09616B1BD80 /* SBUHorizontalSuggestedReplyView.swift */; }; - 2A8E932076887CCD5B8BEF77 /* SBUCacheManager.Image.swift in Sources */ = {isa = PBXBuildFile; fileRef = B7D26F2838B7D12D15885978 /* SBUCacheManager.Image.swift */; }; - 2ACA2532E8EECB79E25C8C5D /* SBUMessageSearchModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 693AAFF0FF413BA5086E1B0C /* SBUMessageSearchModule.List+SwiftUI.swift */; }; - 2AF12799601EBC9F368DCE25 /* SBUMessageTemplate.ErrorMessages.swift in Sources */ = {isa = PBXBuildFile; fileRef = E88D2D612D550B0EA07F62CD /* SBUMessageTemplate.ErrorMessages.swift */; }; - 2B6EFBCAEB8119F31FA639AE /* SBUMessageWebViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 926322E643B26A93BE240616 /* SBUMessageWebViewModel.swift */; }; - 2B9AA1BE5AC49494F02B5FF6 /* SBUOpenChannelModule.Input+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3D4529D5F3329C4BC3B98A17 /* SBUOpenChannelModule.Input+SwiftUI.swift */; }; - 2BD4D741D3EA96633FA5929D /* SBUOpenChannelSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = A417F007B9CB1963D0EEAF4D /* SBUOpenChannelSettingsModule.Header.swift */; }; - 2BEBD502CF647A043F824505 /* SBUOpenChannelViewController+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6585ED152504C2FFC5DA1AB2 /* SBUOpenChannelViewController+SwiftUI.swift */; }; - 2D36FF0502F15350CB9CDE3A /* SBUChatNotificationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F411E990FA74EB4C7BD7027 /* SBUChatNotificationCell.swift */; }; + 28B038F489F6B33DF70C5A30 /* Formatter+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 882B165AD9E00AD0671DD185 /* Formatter+SBUIKit.swift */; }; + 28F0FCB98DAAB95E4B0372F1 /* ViewControllerTypeProtocol + swiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CE6D4B74FB8A576A0ED92AB0 /* ViewControllerTypeProtocol + swiftUI.swift */; }; + 296174744FF16CE681B9B598 /* ViewItemInitialize.swift in Sources */ = {isa = PBXBuildFile; fileRef = 94BC67B1D4514E0EF9894966 /* ViewItemInitialize.swift */; }; + 29F018998FA0D33982DF2898 /* GroupChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 213BF3497B6FD30B17654CF0 /* GroupChannelViewConverter.Header.swift */; }; + 29F300152C1075AB758D7DF6 /* View + ViewModifier.swift in Sources */ = {isa = PBXBuildFile; fileRef = 584CEE89C822E1D1BD59E44F /* View + ViewModifier.swift */; }; + 2A20717EAEA0FC6226AFC67C /* SBUMessageCellConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BFA16874C98B8F5046EC5D6 /* SBUMessageCellConfiguration.swift */; }; + 2AF34F3C2EB1558503DD6C94 /* SBUVoicePlayer.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0A5B0CFDF41FCE53A58D53DB /* SBUVoicePlayer.swift */; }; + 2B524BCC88FFE8180C10DCA7 /* SBUMediaView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B2D1684E7E56CD1DC90FA733 /* SBUMediaView.swift */; }; + 2BCA6E8FABBD51F391AB236E /* CreateGroupChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 87A0FA711ABE3E5605B1307B /* CreateGroupChannelView+ViewConverter.swift */; }; + 2BE7CBBB357759A3872E5C0C /* SBUChatNotificationChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = DD29661D82CBA8D0E3513C8D /* SBUChatNotificationChannelModule.List.swift */; }; + 2C2C30195CDFBB187131408E /* SBUGroupChannelCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 062F7B69185282C3ADAAEFA9 /* SBUGroupChannelCell+SwiftUI.swift */; }; + 2C2D7B352437FC0FE1C3BD2E /* SBUMessageTemplate.Renderer+Events.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7FD3DBE85BDBF98CBE0F758E /* SBUMessageTemplate.Renderer+Events.swift */; }; + 2CCB577D34A9FFFD7F35E985 /* DefaultViewConfigSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1AAE5D94748BD4BAC705164 /* DefaultViewConfigSet.swift */; }; + 2D1855925DC14BAB78327DFE /* SBUAdminMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EC0EAFDCFB570D5C83FAD1 /* SBUAdminMessageCell.swift */; }; + 2D53DA1CB3608B2DC8C8B7AC /* GroupChannelRegisterOperatorViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 644EEE0E3AB230AD9CC782FE /* GroupChannelRegisterOperatorViewConverter.swift */; }; 2D58A6EA545608CAECEE4E45 /* CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D123A133B83CA3E4C6A55CB3 /* CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift */; }; - 2D820F3F8E24448320ACF52E /* SBUModerationsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = B23C27311B45D3C9124E9EC8 /* SBUModerationsModule.Deprecated.swift */; }; - 2DB6CA0CC0BB531B7E073BFE /* SBUFileViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = E6541DB78921410A46EA2506 /* SBUFileViewController.swift */; }; - 2E12E61AB649FB4551D2B8A6 /* MessageSearchViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2A07D10F3965FA8EFDD720D6 /* MessageSearchViewConverter.Header.swift */; }; - 2E3C7D635CD0FA4006D59F09 /* GroupChannelListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 492BC0AAB8CE6B4CDE3E4AF5 /* GroupChannelListView.swift */; }; + 2D7593F1A9223B56895C03E3 /* SBUTableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = CF02A0C341CEE4D97DF115CD /* SBUTableViewCell.swift */; }; + 2D9479B222339C927A220AD9 /* SBUOpenModerationsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 746FFA5F3A512F4DDD996282 /* SBUOpenModerationsModule.List+SwiftUI.swift */; }; + 2DD96D0591F2FEBEC2E6E867 /* SBUGroupChannelListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9B2C00F284587D8677219F4A /* SBUGroupChannelListViewModel.swift */; }; + 2DE08BC7EAC8EEB8770030C8 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F21197AC02DB3794FF1A73B9 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift */; }; 2E4F727A0F4A5FB4AEA31B98 /* CustomOpenChannelSettings.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 850E1D213D3EC098A580B835 /* CustomOpenChannelSettings.ViewConverter.List.entireView.swift */; }; - 2E745A54C2C179EF675EEEE0 /* SBUOpenChannelSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DC1B024DDFE6E63F14713E79 /* SBUOpenChannelSettingCell.swift */; }; - 2EAA52382A0E8C5B2E941005 /* MessageSearchView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 29C37028F3734AF788C0631C /* MessageSearchView+ViewConverter.swift */; }; - 2EB545F44CE247B82B9558C2 /* SBUGroupChannelSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D19ADB444964278B6E24246 /* SBUGroupChannelSettingsModule.swift */; }; - 2EEA84E8D1E33A744A816989 /* ViewItemProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = C5CB3C5D62F094A20945FC45 /* ViewItemProtocol.swift */; }; + 2EB7C68A6075B356709326C4 /* OpenParticipantListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3564A850E6E29401E0BE3E5A /* OpenParticipantListViewConverter.List.swift */; }; + 2ED2E470F7DC8ED1CF2315F0 /* SBUImageContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1F414EE8A18D12F1A90F406E /* SBUImageContentView.swift */; }; 2F2410D5C0F0A896C48C2873 /* CustomGroupMutedMemberList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2C7FC20BFBCA4BB020D0A532 /* CustomGroupMutedMemberList.swift */; }; 2F2D3E90ADA787E578E8E451 /* CustomGroupChannelList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 014618B2C4618338C8BF4AA6 /* CustomGroupChannelList.ViewConverter.Header.leftView.swift */; }; - 2F7984DB4A3D3ED837F85766 /* CreateGroupChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = CBDE8C489CF491949336BA54 /* CreateGroupChannelView+ViewConverter.swift */; }; - 306FA7E3CAD8D059B3232C12 /* SBUMessageSearchModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 27093994AF106EAB97B7F24D /* SBUMessageSearchModule.Deprecated.swift */; }; - 308B09C70FAF3AED15D8DA3B /* SBUChannelInfoHeaderView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 05FF389F9A723B77312A0D51 /* SBUChannelInfoHeaderView.swift */; }; + 2F30ACF2D7846817D4F6B8C3 /* SBURegisterOperatorViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = AE682F654DF8EC3C5B5D3996 /* SBURegisterOperatorViewModel.swift */; }; + 2F5B011BD22FFA86602E290A /* SBUFileMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 77694BFE0E0E11F21133E27D /* SBUFileMessageCell.swift */; }; + 2F5D5F7A299CB763FD570E71 /* SBUToastType.swift in Sources */ = {isa = PBXBuildFile; fileRef = FD18A49461FC8A53036E3A08 /* SBUToastType.swift */; }; + 2F5E500F640760FDCA36B51F /* SBUMessageSearchModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 32A81BB37AE3190F7AD09F77 /* SBUMessageSearchModule.Deprecated.swift */; }; + 2F6552E42111CF1071C53AE7 /* PrivacyInfo.xcprivacy in Resources */ = {isa = PBXBuildFile; fileRef = 434AF506C04A1A095C70A126 /* PrivacyInfo.xcprivacy */; }; + 2F9F8DB1DED4A17E46EB786F /* SBUMenuCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = F8C4831068F0F117DDA51E76 /* SBUMenuCell.swift */; }; + 2FBFE7BDFD8B85473A6F568C /* OpenBannedUserListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5B0C556D74C6973EC9D079ED /* OpenBannedUserListViewProvider.swift */; }; + 2FD0CE6A1C02AB2E54028CD9 /* SBUContentBaseMessageCell.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9AC164247B4ADF8D79CF790 /* SBUContentBaseMessageCell.Deprecated.swift */; }; + 301B9D704F37E9977999EF97 /* OpenChannelListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52C77023C4D2F1DB0CBC34D0 /* OpenChannelListViewConverter.Header.swift */; }; + 301D93C99855A2A6858965C8 /* UINavigationController+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5E85D3B450A2E0B91A8E3E3C /* UINavigationController+SBUIKit.swift */; }; + 301FA916AB35E6A7C7E8E383 /* GroupChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 525FAF5D7C1814A0634AA10A /* GroupChannelView+SubViewBuilder.swift */; }; + 3032B6EB19E62C7DB57903ED /* SBUCacheManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5053C3F54CF82D69A26CC37B /* SBUCacheManager.swift */; }; + 308D1E6825184AFCF7FB30F3 /* OpenChannelViewConverter.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = B780F445346B319D875EBB26 /* OpenChannelViewConverter.Input.swift */; }; 31439159D0C7F3957B51A069 /* CustomGroupChannel.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A0B13F6CFE78B660DE0001C3 /* CustomGroupChannel.ViewConverter.Header.titleView.swift */; }; - 31488BBD3C2421112A77A970 /* SBUViewModelDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = A901B98DBD349F8A5CBDB977 /* SBUViewModelDelegate.swift */; }; + 314E67B382A2A0129E41DE99 /* SBUBaseSelectUserModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6E3EB599E75E9A534192C97C /* SBUBaseSelectUserModule.Header.swift */; }; 3196B627E124FAE32FDF4DA1 /* CustomOpenBannedUserList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 59199C2D5B1AAF71E4BD38D0 /* CustomOpenBannedUserList.ViewConverter.List.rowView.swift */; }; - 322C065074646D69A67ACB53 /* GroupChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6C9F033A5ACB73B595F79862 /* GroupChannelView+Item.swift */; }; - 3247A8C9C728645C9F0A65DC /* SBUModerationsViewModel.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 86392DB847368C4FDA9AEB72 /* SBUModerationsViewModel.Deprecated.swift */; }; + 31DC3DBD4670E7AE72C005AE /* SBUMessageTemplate.Syntax.Types.swift in Sources */ = {isa = PBXBuildFile; fileRef = 02C01C65740D25BBD3D9DD72 /* SBUMessageTemplate.Syntax.Types.swift */; }; + 326B0ECA1C45B979A3A438AB /* SBUBaseChannelModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA2F3BFBE980CBE8A343DE43 /* SBUBaseChannelModule.Input.swift */; }; + 328D8DAD258C15EFD986FBE1 /* SBUMessageTemplate.Syntax.Identifier.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D538AAC9F0B43C86FCCF6FB /* SBUMessageTemplate.Syntax.Identifier.swift */; }; 32BC25347884DF68E5195B63 /* CustomCreateGroupChannel.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 96A2372978263A7131ECE94F /* CustomCreateGroupChannel.ViewConverter.List.profileImage.swift */; }; 3312D1908DF7F512FBB8A6C7 /* CustomGroupChannelList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9587E1B40C8128A76DCAF7A8 /* CustomGroupChannelList.ViewConverter.List.entireView.swift */; }; - 3352E799FEA119A35F28E0ED /* SBUMessageTemplateCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4E542BCE47135E2CF12B69A8 /* SBUMessageTemplateCellParams.swift */; }; - 33ECE34C057447D26C83E6CA /* SBUVoiceMessageInputView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C73D7E5C13B65599FAE5D2E3 /* SBUVoiceMessageInputView.swift */; }; - 341397411E718FA1877632CE /* SBUMessageThreadModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = D8573A563BC2E14A69A49B2C /* SBUMessageThreadModule.Deprecated.swift */; }; - 34E3C948C64092A0AAABB60A /* InviteUserViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 72AADB71AB3EE728FC6C0993 /* InviteUserViewConverter.Header.swift */; }; - 3513E41C4A69F8983B75B7C1 /* SBUError.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2C15ED108FD8018112C6E8B7 /* SBUError.swift */; }; - 35541402EA0341E6AC422FDC /* OpenChannelRegisterOperatorView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = AE5AE7AE8AFB0332BF6B91B9 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift */; }; + 338BE5281B09CD9862D8B40F /* SBUUserMessageTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 608274ACB42DDAE6A5976FC6 /* SBUUserMessageTextView.swift */; }; + 33F211B7F47CC6FC91C639AF /* SBUCreateGroupChannelUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9A63BAEF80ECC309FA1E7669 /* SBUCreateGroupChannelUserCell+SwiftUI.swift */; }; + 3407C53E67355F05BD5568CC /* SBUCoverImageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E0C6B3B15A2C99291A025E96 /* SBUCoverImageView.swift */; }; + 3412D19373A8ACC77B9277AA /* OpenOperatorListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F32A69B02CCE4166DE09F9D /* OpenOperatorListView+SubViewBuilder.swift */; }; + 3416FD182734700D48191237 /* SBUOpenBannedUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 934D088DA1735729346CE8C0 /* SBUOpenBannedUserListUserCell+SwiftUI.swift */; }; + 34C3EFDD816902E6ABBD97A4 /* SBUMessageFormChipsItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F7C5297FA101765F9784775 /* SBUMessageFormChipsItemView.swift */; }; 356B573E33FFBF70AE484926 /* CustomOpenBannedUserList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1F40D34A8DAA0338D60BCC95 /* CustomOpenBannedUserList.ViewConverter.List.profileImage.swift */; }; - 35A042C34CB866EFBF4ADA98 /* SBUCreateChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9AA2862AB56710CEAAEB6A77 /* SBUCreateChannelViewController.Deprecated.swift */; }; - 35BC84D42A11723C39FC4147 /* SBUMenuCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45FA71D8C8152131EDE22583 /* SBUMenuCell.swift */; }; - 35E89032995E54FCEE345D2D /* SBUGroupChannelPushSettingsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D80E95EF57DDC3B50934217 /* SBUGroupChannelPushSettingsModule.Deprecated.swift */; }; + 357D0348F28A8ACFE47FB2D6 /* GroupOperatorListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = C0C346D6EED1C20C50D275E9 /* GroupOperatorListViewConverter.List.swift */; }; 36149A5A5AF7E946701AF01A /* CustomOpenChannelRegisterOperator.swift in Sources */ = {isa = PBXBuildFile; fileRef = E5645C24C2297EC9DBE73B7F /* CustomOpenChannelRegisterOperator.swift */; }; 3621393E3C94934922A82CB1 /* CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = E292093376A1435753C8717C /* CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift */; }; 365BF21AE71ADD004BB3E90C /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 8B3DB3B902EE642A320204FC /* Assets.xcassets */; }; - 36A3637008B84DDD9559D115 /* GroupBannedUserListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E4DA64D4218AE42BAC6C567 /* GroupBannedUserListViewConverter.Header.swift */; }; - 36DE27B3673937512D65607B /* SBUHorizontalSuggestedReplyOptionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6005865475CC09912381B378 /* SBUHorizontalSuggestedReplyOptionView.swift */; }; - 36FD3D8985661691E4C856BE /* SBUOpenModerationsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B882F1528ECBB76E2777E7FF /* SBUOpenModerationsModule.Header+SwiftUI.swift */; }; + 36DD391A8F890A0561D682D3 /* GroupMemberListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = E9C129A8E7F7F62801B604ED /* GroupMemberListViewConverter.Header.swift */; }; 373D6252F5129B2CBE072A1B /* CustomOpenBannedUserList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1594F63CF9E5FDE4E1A20E4E /* CustomOpenBannedUserList.ViewConverter.Header.titleView.swift */; }; - 374873069DFF6964CED424C4 /* GroupOperatorListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9F3EE35D2B6C4B0FCC42CB8E /* GroupOperatorListViewConverter.Header.swift */; }; + 3773BD698DE731408C45CF84 /* SBUSelectableStackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B07065B5EEFA8858ADAD76CA /* SBUSelectableStackView.swift */; }; + 3775E1F124A1E5B53F9C542E /* SBUDashboardConfig.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2AFB3ABEC66B7B5DF2B1C6C1 /* SBUDashboardConfig.swift */; }; 378E3792F5E8833C562570E5 /* CustomGroupChannelList.ViewConverter.List.channelPreview.swift in Sources */ = {isa = PBXBuildFile; fileRef = E28678781153AEB5AD838205 /* CustomGroupChannelList.ViewConverter.List.channelPreview.swift */; }; - 380277562989E6254E9D5B04 /* SBUVoiceFileInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9FC2858F11E00B30B3C6B844 /* SBUVoiceFileInfo.swift */; }; - 380D86806369B8B85ACCC8F7 /* GroupModerationsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = F35DAFB453749AFE67CD58EE /* GroupModerationsView+SubViewBuilder.swift */; }; - 387E3D9349C182157C0EDBD0 /* SBUGroupChannelSettingsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E9F07C7C0780B668356ECFF /* SBUGroupChannelSettingsModule.Deprecated.swift */; }; - 390A27535C034C93B8F7EBCE /* SBUOpenUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CDF5A13CCF666CC7179C7878 /* SBUOpenUserListModule.Header+SwiftUI.swift */; }; - 391D34782F1606CF69FD1B50 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 98037A186B2F6815C6BC45CD /* SBUGroupChannelSettingsModule.List+SwiftUI.swift */; }; + 38116DEE4FA5BA7D124AF0C9 /* SBUOpenChannelAdminMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 62CC0CF4B851582B239AE1FF /* SBUOpenChannelAdminMessageCell.swift */; }; 39317C43889562789CD98BB3 /* CustomMessageThread.ViewConverter.List.channelStateBanner.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB09B1B15A5D99B56FCABE91 /* CustomMessageThread.ViewConverter.List.channelStateBanner.swift */; }; + 3937A8958F386B56217275B4 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E3A3342AEA6256BC66D30A3 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift */; }; + 3995D511AD5734E72ED66070 /* SBUBaseViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 60990AE9096DF6FA54EC29BF /* SBUBaseViewController.Unavailable.swift */; }; 39A7CF45DAD21A2F7381828C /* CustomGroupModerations.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 377FEABC82180302EA83C74A /* CustomGroupModerations.SwiftUI.View.CustomMain.swift */; }; 39E1B131F5D0BD13F40A5D55 /* CustomSampleViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8DE8486ECC131F76C82AD08D /* CustomSampleViewModel.swift */; }; - 39FEDD7154D8A830F6CF419B /* SwiftUIMessageInputInterface.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52E4D495AFCFF546A54C3B24 /* SwiftUIMessageInputInterface.swift */; }; - 3AD5FCFB46A6704D379A40AA /* SBUMenuSheetViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = AFF25F8EC9716847344276B0 /* SBUMenuSheetViewController.swift */; }; - 3C38D2CD22DE4C08D0D8648B /* Collection+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1DDB1C8B0B6F4041F5B74E5F /* Collection+SBUIKit.swift */; }; - 3C4C6B12FB4F6177E417D857 /* SBUConfig.GroupChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = DDDF7743ADEF95903798D261 /* SBUConfig.GroupChannel.swift */; }; + 3A1AD29BAA5DAE35CC9FE3CA /* SBUChannelTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9AC6D3C982FEB244190F2493 /* SBUChannelTitleView.swift */; }; + 3AAD3C2119E27C0E9622066A /* SBUMessageThreadTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9C12F2848C78BBE9E222E5A8 /* SBUMessageThreadTitleView.swift */; }; + 3C664C9410C90EDC17B9F397 /* SBUMessageSearchViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81F7060AFCA22AF15E3122CD /* SBUMessageSearchViewModel.swift */; }; 3C9DB1FEDCEE1CF8E00F444D /* CustomMessageThread.ViewConverter.Header.titleLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = DED9CED6E144447EA5AF3CFE /* CustomMessageThread.ViewConverter.Header.titleLabel.swift */; }; - 3CB5A9CD871BEA948248DE21 /* SBUGroupChannelPushSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 53CDCB30A1F06A5DE1531A88 /* SBUGroupChannelPushSettingsModule.swift */; }; - 3CE30A717F80695A7424BE14 /* SBUMultipleFilesMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 229772D9190CF57D0E32B7D2 /* SBUMultipleFilesMessageCell.swift */; }; - 3D1719AAFB70F1E31F4EC696 /* SBUUserCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = C8BA1B8C93D3C73902AD9BD4 /* SBUUserCell.swift */; }; + 3CE19B8299750EF64E7041EC /* SBUVoiceFileInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 83337608204FE94776C542A4 /* SBUVoiceFileInfo.swift */; }; + 3D30144647F6B79A5397CFB4 /* SBUMessageThreadModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8BA4724E320BF5BEB01C0511 /* SBUMessageThreadModule.Input.swift */; }; + 3D77F2AC974F8337F6442134 /* InviteUserViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = BCDE756FB020AB19ECBB9189 /* InviteUserViewConverter.Header.swift */; }; + 3D9A6996BE88C59EB045C07F /* SBUBaseChannelListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E730A218995750A20EC764A /* SBUBaseChannelListModule.swift */; }; + 3DC67644E3563B914CC5A8E6 /* SBUMessageTemplate.Syntax.Aligns.swift in Sources */ = {isa = PBXBuildFile; fileRef = CBB1CE2457846204624418C0 /* SBUMessageTemplate.Syntax.Aligns.swift */; }; + 3DD80CFCD55FBB553006697D /* GroupChannelListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = C9B2E0BAC9866D25FE5F8F5F /* GroupChannelListViewConverter.Header.swift */; }; 3E5BA63D6422E754C1FF34A1 /* CustomInviteUser.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = BF9C7D0187A83D8621B5B6E9 /* CustomInviteUser.ViewConverter.Header.leftView.swift */; }; + 3EAB7553CB0F367BBF523B43 /* GroupChannelPushSettingsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = B2381F491D07215E71A1C179 /* GroupChannelPushSettingsViewConverter.Header.swift */; }; + 3ED50515BC8E8E8AA26CDBF1 /* SBUMessageTemplate.Renderer.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3168D719E8C0DBF32138DBD9 /* SBUMessageTemplate.Renderer.swift */; }; + 3EF2255B820FCBF48B60ACF4 /* SBUParentMessageInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F6D788FD7849625F5F58CEDE /* SBUParentMessageInfoView.swift */; }; + 3EF27929DDF5A9C7DF3B3A35 /* OpenModerationsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = ADDA48DA43F534CAF86DA08A /* OpenModerationsViewConverter.Header.swift */; }; 3F9FC0E14D747175B256E45F /* CustomGroupChannel.ViewConverter.Header.titleLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6B9D1393478C09E0807164E4 /* CustomGroupChannel.ViewConverter.Header.titleLabel.swift */; }; - 3FD42D94801F8F60933203C4 /* SBURegisterOperatorModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD1D2FF674AE425302A71903 /* SBURegisterOperatorModule.swift */; }; - 3FDDF95834D426171021D60F /* OpenMutedParticipantListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0ADAA8130275C2A217DA88C8 /* OpenMutedParticipantListView+ViewConverter.swift */; }; - 3FE398357361E82A822D14FC /* SBUMessageTemplate.Renderer+RenderStyles.swift in Sources */ = {isa = PBXBuildFile; fileRef = B7E0D4FD8746F209DFE99AF3 /* SBUMessageTemplate.Renderer+RenderStyles.swift */; }; - 3FF42830178D1DC8CD3D6F04 /* SBUOpenChannelCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 07CDB82417CCB1815F880C95 /* SBUOpenChannelCell+SwiftUI.swift */; }; - 406BD21F5FC64E934F53B164 /* SBUOpenChannelSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D5FA8F827F8A99D242C01C7 /* SBUOpenChannelSettingsViewModel.swift */; }; + 408FB60AFA6FF6716A2FF2F6 /* BaseMessage+SBUIKit.MessageTemplate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5A6472958F4CF3447377BD4A /* BaseMessage+SBUIKit.MessageTemplate.swift */; }; + 4092C8C02C9D014C95965819 /* SBUBaseFileContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9479ECE36C683AB4CF1BE683 /* SBUBaseFileContentView.swift */; }; + 4096F9B85946CE4F57E4BB21 /* SBUCreateChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = A265FA0F4182C5F6FB327DC1 /* SBUCreateChannelModule.Header.swift */; }; 40ACBEA98893FBB384F82ACC /* CustomGroupChannel.ViewConverter.Input.sendButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7CA64549D32F469A58888692 /* CustomGroupChannel.ViewConverter.Input.sendButton.swift */; }; 40C24C2FF88B68584A4E69C3 /* CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0F49DB6B8C7DF57E5377F0D /* CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift */; }; - 413DA6431A1DF4B2285ACC61 /* SBUMessageTemplate.Action.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9F55FA2519DCC099F23C4F0 /* SBUMessageTemplate.Action.swift */; }; - 4196947C633EFEBC5DD78DB0 /* SBUCreateOpenChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 538BF9253A4990D0C05713F5 /* SBUCreateOpenChannelModule.Header.swift */; }; - 41ABB2DCC040058AF9D3233A /* SBUGroupChannelSettingCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4CF215E5C5EAE38BCDB732CD /* SBUGroupChannelSettingCell+SwiftUI.swift */; }; - 42004339E11B8CD30011DDD0 /* SBUGroupUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E787BE5CA17742F73854520 /* SBUGroupUserListModule.Header+SwiftUI.swift */; }; - 429674A28CCB9F7E17F25B95 /* SBUBaseViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6E58BDD6097554E5AA391B25 /* SBUBaseViewController.Unavailable.swift */; }; - 4342550D395EEBBF39CEBD4A /* OpenParticipantListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = AAAF55460E9B55A08425A596 /* OpenParticipantListView+SubViewBuilder.swift */; }; - 435D7C9F386025A5B35CD9F0 /* SBUChatNotificationChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2F88656EDE7A31FD01B7ED7D /* SBUChatNotificationChannelModule.Deprecated.swift */; }; + 413ECDBB1EC03F9A27E7EFD5 /* OpenBannedUserListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = B79650F5C408244AF34B5DA1 /* OpenBannedUserListViewConverter.swift */; }; + 41BACBFFB4567EAB3B95C50E /* SBUFeedbackAction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0635067B6F0880D18DE4C6D5 /* SBUFeedbackAction.swift */; }; + 41CD9DDB6951A3AA52432650 /* CreateGroupChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7AF732FDF59475FF7693846E /* CreateGroupChannelViewConverter.swift */; }; + 4228E8E7699D05B036C5319F /* SBUUserListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7301F42637EF67DDD07821CF /* SBUUserListViewController.swift */; }; + 4248888996DDC01CE0F9C829 /* SBUGroupModerationsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9693AE7B405435E81AFB70DB /* SBUGroupModerationsModule.List+SwiftUI.swift */; }; + 42A575D8819B486F049C33DF /* SBUChannelStateBanner+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1758AEB45338E3698851ED34 /* SBUChannelStateBanner+SwiftUI.swift */; }; + 43312196721B790BA15E6022 /* String+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7ECA3675E4F44DFB6586D04 /* String+SBUIKit.swift */; }; + 439D98329817EA406BB74B3E /* SBUMessageInputMode.swift in Sources */ = {isa = PBXBuildFile; fileRef = B4A0BB7D655128684E76A5B2 /* SBUMessageInputMode.swift */; }; 43C47B11E060AFA3EB438B62 /* CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 39347C5622B095E111628DAE /* CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift */; }; - 43D00C568BEC5D4CEB0BDA98 /* SBUOpenChannelListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = D26E0EABCE381C370B68E9A8 /* SBUOpenChannelListModule.Header+SwiftUI.swift */; }; - 43F0BBFFC51A2D49F330F817 /* SBUGroupChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19CEBE4C850E10CB4FDA7B68 /* SBUGroupChannelModule.List.swift */; }; - 43F1C242C467554BE94E81DE /* OpenModerationsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0A26F750C0BD5F985CE0488F /* OpenModerationsView+SubViewBuilder.swift */; }; - 442D06E6B5F2E1C8EE70FB5A /* SBUBottomSheetController.swift in Sources */ = {isa = PBXBuildFile; fileRef = E05180B4571B1F3B9A4BA50C /* SBUBottomSheetController.swift */; }; - 444B563CE4133A9F78848657 /* GroupModerationsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A6912CC46BA4AFE74AABDB6E /* GroupModerationsView.swift */; }; + 4432A7F44ED30FE6566FBC11 /* OpenChannelSettingsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1D26DE3887547F356A14F016 /* OpenChannelSettingsViewConverter.List.swift */; }; + 445BB4AD178FA8285B5DBE6E /* GroupModerationsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 349C18C1DC887172FCB29311 /* GroupModerationsView+ViewConverter.swift */; }; + 4469F5B26AF4AE47320EFD2F /* SBUMessageThreadTitleView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 11507F4DAA42980635F9C12E /* SBUMessageThreadTitleView+SwiftUI.swift */; }; + 44F4C460574D81E299679162 /* SBUGroupChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B0ED60E6DBA9AF470E3DB48B /* SBUGroupChannelViewController.swift */; }; 45183D63A319B55D9610D12A /* CustomOpenChannelList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F4562E0FF6115855EA43DEB3 /* CustomOpenChannelList.ViewConverter.Header.leftView.swift */; }; 45201D0F9177690FB3963C77 /* CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = B683D8C9E07D1EFD01133041 /* CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift */; }; 4554AA4AD82307F6B48CDB34 /* CustomGroupChannelList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0906752602F6996C99B03220 /* CustomGroupChannelList.ViewConverter.Header.rightView.swift */; }; - 455AB5F789FF5433C815713A /* GroupChannelPushSettingsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 015DF3CD2805DA3FED653BA8 /* GroupChannelPushSettingsView+ViewConverter.swift */; }; - 45B3AB9192A0133C98968DDD /* SBUOpenChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B823235003718792C817309 /* SBUOpenChannelModule.swift */; }; - 45D1330B868348CFC9332587 /* SBUModerationsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 41D90092595D82EE02099124 /* SBUModerationsModule.List.swift */; }; + 4564699A876DFD2A314226E7 /* SBUFeedNotificationChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 35900F9772C3BD6331D81176 /* SBUFeedNotificationChannelModule.List.swift */; }; + 45A202A38205D388F6F09959 /* SBUAlertView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3898C32C492215F4562791CD /* SBUAlertView.swift */; }; 45E53C19F9C8C06ED1EEEA5F /* CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = D575F4B28A9776FA1080738B /* CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift */; }; - 46AC73962DEFD970AD80F6AC /* SBUToastView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9B434F3BB648812D03FFFB9 /* SBUToastView.swift */; }; - 46DE4A719ED6C0ECF60AB64A /* SBUOpenChannelListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = A4E9A824E45E051EC112A416 /* SBUOpenChannelListViewController.swift */; }; + 45FBA23F645EC16087F4BD28 /* SBUNotificationNavigationTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4609C23D48140B46A11D9077 /* SBUNotificationNavigationTitleView.swift */; }; + 460031BC6C7688929FF5BEB9 /* SBUGroupChannelPushSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = A0D6D1EDAD29575916B5BE29 /* SBUGroupChannelPushSettingsViewModel.swift */; }; + 4605B12AAF79EFE43B741F51 /* CreateOpenChannelViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4501508FDCD8E6900C33668C /* CreateOpenChannelViewProvider.swift */; }; + 467ADACA3CEE437F94B398EE /* GroupChannelRegisterOperatorViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 411F9A231E8707D76F0B05FA /* GroupChannelRegisterOperatorViewConverter.List.swift */; }; + 46ABE1851FE5770BE79DCB89 /* GroupMutedMemberListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = BFD44E420AECC052E968D1D2 /* GroupMutedMemberListViewConverter.List.swift */; }; 471183715BC28FBB2AEFE080 /* CustomGroupChannel.ViewConverter.Input.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E17D9CC93AAD8E92C3BB7587 /* CustomGroupChannel.ViewConverter.Input.entireView.swift */; }; - 4734B91D1D1600B3CE68021E /* SBUModuleSet.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = E700A49675E9D9B07C018C41 /* SBUModuleSet.Deprecated.swift */; }; 475E9ED72413154DBBE99F31 /* CustomGroupChannel.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F6E4F2C3A2A114F1699BCBA /* CustomGroupChannel.SwiftUI.View.CustomMain.swift */; }; 4782FB9B86E7DEE15C6F45E5 /* CustomGroupChannelSettings.SubView.Builder.pushSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81401E7343AA611CD5BC481B /* CustomGroupChannelSettings.SubView.Builder.pushSettings.swift */; }; - 47FFB70AFD0AF40C1B722977 /* SBUMemberListViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 562B1654E59E7FBB80E3FDFB /* SBUMemberListViewController.Deprecated.swift */; }; - 480343725830814ADFB93582 /* SBUThreadInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1D0C5587D78DE4FF38CD361A /* SBUThreadInfoView.swift */; }; - 48441C5EAE63AF462E9F521E /* SBUGroupChannelCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0FA34F6AA2F8B23B93236BF1 /* SBUGroupChannelCell+SwiftUI.swift */; }; + 48061E8A6A2CCB8E3B410263 /* GroupBannedUserListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2307E41DDDA61CF29EB83335 /* GroupBannedUserListView+ViewConverter.swift */; }; + 4821DC2603A9E1E93C7EDCF3 /* SBUModerationsViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 682435685BFDA58E30D915B8 /* SBUModerationsViewController.Deprecated.swift */; }; + 483073E502ACDC6B0B97071D /* SBUOpenChannelModule.Input+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CE4DFFF0E46FAB0FDF0048EF /* SBUOpenChannelModule.Input+SwiftUI.swift */; }; 48559EA9AD772DD6FDCC45A5 /* CustomGroupMutedMemberList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = BA526C8D0DF18295F76898BD /* CustomGroupMutedMemberList.SwiftUI.View.Main.swift */; }; - 4947E732EF44B9AA93B21B99 /* SBUGroupChannelModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B96A9441D86C9B70E7B8FC1 /* SBUGroupChannelModule.Input.swift */; }; + 489DF91B622A88716BD787D4 /* GroupChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CC43AC31B6D1017FAD879CC6 /* GroupChannelView.swift */; }; + 48F24D873C5E14C5463F7218 /* SBUCreateOpenChannelModule.ProfileInput.swift in Sources */ = {isa = PBXBuildFile; fileRef = C1DE532D5BE137069E46610F /* SBUCreateOpenChannelModule.ProfileInput.swift */; }; + 492DA4A12B29161F5F214F2E /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 96D00F1925C38316F7B14F6F /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift */; }; + 49326461344F3ACBA5189DA8 /* UIButton+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 361730BCE391F1EC0B386A82 /* UIButton+SBUIKit.swift */; }; 495FE0B773BFAD972995862A /* CustomSampleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B7E908DFF59E617F26B85F1 /* CustomSampleView.swift */; }; 496684990013E94B88EDFB04 /* CustomOpenChannel.ViewConverter.List.senderProfileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 034B7E97A85668F9BF8AE75A /* CustomOpenChannel.ViewConverter.List.senderProfileImage.swift */; }; 49B25CC0221278E75D48088C /* CustomGroupOperatorList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 519AF0B13E4AD698AEFB0303 /* CustomGroupOperatorList.ViewConverter.List.profileImage.swift */; }; 49B49B5F828F7DED52B3F23C /* CustomGroupOperatorList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7FDEEDB706412FC601CCF624 /* CustomGroupOperatorList.ViewConverter.Header.leftView.swift */; }; - 49D022117EB3895DD034F970 /* GroupChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1223F79CC60D5AB916A3204B /* GroupChannelView.swift */; }; 49DB94E503AEE63D63803184 /* CustomGroupBannedUserList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3225F148DEE17564551340F3 /* CustomGroupBannedUserList.swift */; }; - 49F5234FBCF7AE93EED0596C /* SBUMessageTemplate.Renderer+RenderItems.swift in Sources */ = {isa = PBXBuildFile; fileRef = 248481420F458F58CA0D9E6F /* SBUMessageTemplate.Renderer+RenderItems.swift */; }; - 4A973AFD762FD1B7F89623BE /* Closure.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19CC6B675B71533BB7EFA604 /* Closure.swift */; }; - 4AE354251F110B0258232F40 /* OpenMutedParticipantListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E4836735A03C7E6A5A5E1C0 /* OpenMutedParticipantListViewConverter.swift */; }; - 4B12AC423B1E57AFD2800C84 /* SBUMessageInputMode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 97C853C1F7E530CFD4D3C666 /* SBUMessageInputMode.swift */; }; - 4B2A2232C234A7B00F985A56 /* SBUMarginView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 48F076274C9FA374B6BD0708 /* SBUMarginView.swift */; }; - 4BF7588B345B441B33943F13 /* CreateOpenChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8E8801C8B570BA053A2B2FEA /* CreateOpenChannelView+ViewConverter.swift */; }; - 4C1887A9486E5139B141C3C8 /* ColorSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = A64F81096C2DBE9610059AA9 /* ColorSet.swift */; }; - 4C323B8C0D64565A5C31F777 /* SBUMessageTemplate.Renderer.RendererType.swift in Sources */ = {isa = PBXBuildFile; fileRef = EECE2AC717C2FBAC7D59465F /* SBUMessageTemplate.Renderer.RendererType.swift */; }; + 4BD60C8A8E90705C2B3C1830 /* SBUPermissionManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = A37035DF62B792FA791F53D5 /* SBUPermissionManager.swift */; }; + 4C0FC99E2A2DEB35CAAD19D4 /* SBUGroupBannedUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 58DC541DD17CED0D33F79128 /* SBUGroupBannedUserListModule.List+SwiftUI.swift */; }; 4CD06E51CEB6D2E30263C96C /* NotificationService.swift in Sources */ = {isa = PBXBuildFile; fileRef = 29A8E469FDC1391368051BBF /* NotificationService.swift */; }; - 4CE62412DE9C4DDEA553A108 /* GroupChannelListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = F3B37A003211506172A34CE4 /* GroupChannelListViewConverter.Header.swift */; }; + 4CDB3A59EC5F79228A388A76 /* OpenChannelViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = C777B171EAF9592EA52F9707 /* OpenChannelViewProvider.swift */; }; 4CF3A935E350C75329E77678 /* CustomCreateOpenChannel.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2B41B61973E52E8F8B861399 /* CustomCreateOpenChannel.ViewConverter.List.profileImage.swift */; }; - 4CF8D5FA139905816CB42DDA /* SBUCategoryFilterCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = D2CCFB76C36D83C085F65E5C /* SBUCategoryFilterCell.swift */; }; - 4D6BAE73205FD92DF2EAA72D /* SBUParentMessageInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 789CAB6C3FE329C8F7C13530 /* SBUParentMessageInfoView.swift */; }; + 4D2E42308F42E09855A1CD9B /* SBUFeedNotificationChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = A8B2153FEAAF7C92B3DBE27F /* SBUFeedNotificationChannelModule.swift */; }; 4D70B4A588CCC51A794C9F40 /* CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = B50AAD81BE674A45CFD5AEB5 /* CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift */; }; + 4D7368028A8AE3B04C606302 /* SBUOpenChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = C155DD4B518BAA95DA93098F /* SBUOpenChannelModule.Deprecated.swift */; }; 4D740DC1206DE044AF5E5D17 /* CustomOpenOperatorList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7AFDDC578AF7C0F3D0461335 /* CustomOpenOperatorList.SwiftUI.View.CustomMain.swift */; }; - 4DC0350ED1D2833CA946B8C3 /* SBUBaseChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7B361C809A4825F96490CCAA /* SBUBaseChannelModule.Deprecated.swift */; }; - 4E27A2AD62CFD82641C2120C /* GroupChannelPushSettingsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 57D9985EEF88343041C1BE51 /* GroupChannelPushSettingsViewConverter.Header.swift */; }; - 4E49B57D46AC815181DFB452 /* SBUConfig.swift in Sources */ = {isa = PBXBuildFile; fileRef = 899CCE6BB9CD3EDE4F60D06D /* SBUConfig.swift */; }; - 4EB9EFB39E2E14B9D5AE08AC /* SBUFeedNotificationChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = B34779DFF03F17E12EF14F8B /* SBUFeedNotificationChannelModule.Header.swift */; }; - 4ED158577D05DD6E73651698 /* ViewControllerTypeProtocol + swiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 326E8DC6D22782968571F3EC /* ViewControllerTypeProtocol + swiftUI.swift */; }; + 4DEAB3D627359FFF30497182 /* CreateGroupChannelViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 48342C2B2D314AB84A41048F /* CreateGroupChannelViewConverter.List.swift */; }; + 4DEBBC6C537F17808B683CE0 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B7EBE9547D711DC04841C63 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift */; }; + 4E007D3C096B3D2701B98E02 /* GroupChannelRegisterOperatorViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4DF8E970CDDD209431757EE9 /* GroupChannelRegisterOperatorViewConverter.Header.swift */; }; + 4E2A62BFF5497BBDA4C1FFAE /* GroupChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2F02C24F1081B38C6BBB9B3A /* GroupChannelView+ViewConverter.swift */; }; + 4EAFF36AA2B114BDBFD37BCC /* SBUOpenChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 666D5EED292A8388ADBD01E3 /* SBUOpenChannelModule.List.swift */; }; + 4EBCCC1431AE117C813D1BED /* UIApplication+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = F200CA4F5373C5A264BE312A /* UIApplication+SBUIKit.swift */; }; + 4EF20EB7151A235007A8811F /* SBUOpenChannelSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4355FC0431F98C7660BB7AAB /* SBUOpenChannelSettingCell.swift */; }; + 4F42716E2D6DCE99C0BE8662 /* OpenOperatorListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 77A22D8FCAD422A90844DC4C /* OpenOperatorListView.swift */; }; + 4F9103454D8BD03741CB1A70 /* OpenBannedUserListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 198642EB3A0DA4073E11FBBE /* OpenBannedUserListView+Item.swift */; }; 4FC44C8EC4739231237AC5BF /* CustomCreateOpenChannel.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 49C02D1B4060B034D7BC9A08 /* CustomCreateOpenChannel.ViewConverter.Header.leftView.swift */; }; 4FDFFE9D3905CDC25D3DD05B /* CustomOpenChannel.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 64A60006EDE83A992CE4899A /* CustomOpenChannel.SwiftUI.View.Main.swift */; }; + 4FF5FAFB147DBC0064CE8991 /* SBUMessageTemplate.Renderer+RenderItems.swift in Sources */ = {isa = PBXBuildFile; fileRef = 01FFB98B8DBF2797338BCE5A /* SBUMessageTemplate.Renderer+RenderItems.swift */; }; + 502CB752FABA82E71D64B640 /* SBUView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 62AF0E697857ED2994B84E0C /* SBUView.swift */; }; + 504AE9E9D6FBB8E1F61C5B5E /* GroupChannelRegisterOperatorView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D90B73B8AC8C71F9C1C431A /* GroupChannelRegisterOperatorView+Item.swift */; }; 506BAF06879E75C508747F5F /* CustomGroupMemberList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55D3470BAC153580068FAA95 /* CustomGroupMemberList.SwiftUI.View.Main.swift */; }; + 50AA08F67C08BA3F453717F1 /* SBUModerationsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = A280E51C52241837A38F05CB /* SBUModerationsViewModel.swift */; }; 50DC7EA496CB2F004CC18C08 /* CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 22F1260D9E0F6882210913EA /* CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift */; }; 5128416924F60A8B7B824AAF /* CustomGroupChannel.ViewConverter.List.scrollBottomView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E325565C4F113CEBD8DBA04 /* CustomGroupChannel.ViewConverter.List.scrollBottomView.swift */; }; 5152DC8281635E61B570DB42 /* CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 620712A21432C3E2D4B76DCD /* CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift */; }; - 5157F8160F3474FECCF5B546 /* SBUBarButtonItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 166A655BEA90071D890FE83F /* SBUBarButtonItem.swift */; }; - 5255221FF6079D13240B56B2 /* GroupMemberListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C5F3807ECAAB76E19DBFE2D1 /* GroupMemberListView.swift */; }; - 529D6A32B137AAE957062140 /* MessageThreadView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 803F50E6244F87861D865AE5 /* MessageThreadView+Item.swift */; }; - 52D3B526742AA7D54E53DE7F /* OpenChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 677AE6C278482C5D34FEE924 /* OpenChannelViewConverter.swift */; }; - 52EF8EF7DA1AD41FEF178541 /* SBUModerationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33B515D9E7A6C9C304D30F5F /* SBUModerationCell.swift */; }; + 515776BA921831318D7C5366 /* SBUBaseChannelViewController.Keyboard.swift in Sources */ = {isa = PBXBuildFile; fileRef = 446D630F304F4592542988D1 /* SBUBaseChannelViewController.Keyboard.swift */; }; + 519717F281CEB36BCBED4BE7 /* SBUGroupChannelCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A59A6D2DE07C732BD16DB8CB /* SBUGroupChannelCell.swift */; }; + 51CEBEBE26D74913FBFCE2EF /* GroupChannelRegisterOperatorView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E412F92FD80B99ACFE30AF7 /* GroupChannelRegisterOperatorView+ViewConverter.swift */; }; + 51F13CFECE1B517D54F20C30 /* OpenBannedUserListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1DC014816EBFF2C90B439FEF /* OpenBannedUserListViewConverter.Header.swift */; }; + 5221A095983EA246ED6DE32A /* MethodOverridable.swift in Sources */ = {isa = PBXBuildFile; fileRef = D96FF4DECC16108247C2B05F /* MethodOverridable.swift */; }; + 52362755FDE9CE2BE269332A /* OpenBannedUserListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5E136559F51500BE7524DCA9 /* OpenBannedUserListViewConverter.List.swift */; }; + 52E94ED9DC2EBD6DDCCBC2FA /* MessageSearchViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = D1C0385D2634A8150F5B7765 /* MessageSearchViewConverter.List.swift */; }; + 533FDED6A7724E8193950C67 /* GroupChannelSettingsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5A1D7523528A21181034C649 /* GroupChannelSettingsViewConverter.swift */; }; 535317BFCB43A3FAA08E5689 /* CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4A4630B2B926C70C941FD547 /* CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift */; }; - 5372A5C055FC1B99AD2F064F /* SBUNotificationEmptyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 54733AC26F3E88F21EC1750E /* SBUNotificationEmptyView.swift */; }; - 539A540807A678A26A1E8926 /* SBUGroupChannelSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81EE50EA8221195EAE1F0290 /* SBUGroupChannelSettingsViewController.swift */; }; - 53E719A697BF0C7C0634477C /* UITableView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = B08F254ED73A65FF24CE813B /* UITableView+SBUIKit.swift */; }; - 53EED1261A469B47B8E5AF5E /* SBUCacheManager.Version.swift in Sources */ = {isa = PBXBuildFile; fileRef = 027F5B8FFDDCA7C6C28E4BD7 /* SBUCacheManager.Version.swift */; }; + 53E5046D24EFD425EE0B8F01 /* FontSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 14A5CBF9A05A44B87429CDCC /* FontSet.swift */; }; + 53E72628745B9E63E1C95C43 /* SBUGlobalCustomParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DAE1563042355B438870C6A /* SBUGlobalCustomParams.swift */; }; 5408252EE3B93696F1810D93 /* CustomMessageThread.ViewConverter.List.userMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3D141E8C8C15AEBA43FA67F5 /* CustomMessageThread.ViewConverter.List.userMessageView.swift */; }; - 5409EB47DEE45963E96D8093 /* SBUCreateOpenChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1C984E50160373E12FA0438E /* SBUCreateOpenChannelViewModel.swift */; }; 543C990E170FD44CD9302297 /* CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD052ED37E7CB964936B4AF8 /* CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift */; }; 544DA2A9E98C15FBCAB5A98F /* CustomOpenOperatorList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 97387173C72E68A8BA13C25A /* CustomOpenOperatorList.ViewConverter.List.profileImage.swift */; }; + 544EEA8C932F1096A5F2C3B4 /* SBUUnknownMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D217125A2F37CCE38F58948 /* SBUUnknownMessageCell.swift */; }; + 5498D2DB8A283178433BCCE0 /* SBUChatNotificationChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = D8EA593C614B0BDD8E1FA2C8 /* SBUChatNotificationChannelModule.swift */; }; 54BF3613204026805EC81AFC /* CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4F19E0129A6247FB94372E4C /* CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift */; }; - 54E06FDDB15A6C4FF928C1A0 /* OpenOperatorListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 66DC68119CAB88E61C94C90B /* OpenOperatorListViewConverter.swift */; }; - 54FC2D3C252EA9514A8C426E /* SBUParentMessageInfoView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1B4A8280119033D9FB86B458 /* SBUParentMessageInfoView+SwiftUI.swift */; }; - 550B147EF5CC390139390EB7 /* GroupMemberListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55CB97C4415AE0168B1EAEE4 /* GroupMemberListViewConverter.Header.swift */; }; + 54F9C3EF451880E03DD9C14D /* SBUFeedNotificationChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 02844CACFD763E4FA4A29F09 /* SBUFeedNotificationChannelModule.Deprecated.swift */; }; 554ED5B82DA98001C30E0AEA /* CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09FB473379288E2643AFD21B /* CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift */; }; - 55A068C70117611B644BEE9E /* SBUGroupChannelModule.Input+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9EA80A9DB07BD04E1A717C23 /* SBUGroupChannelModule.Input+SwiftUI.swift */; }; + 559125F39CD9442DB4EF2647 /* CustomGroupChannel.SwiftUI.View.ViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 20B52D131C6D75296798238F /* CustomGroupChannel.SwiftUI.View.ViewProvider.swift */; }; + 559579090B163B8A9BA33EB7 /* SBUBaseSelectUserModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6B9F8515A20FA64F26C16D46 /* SBUBaseSelectUserModule.List.swift */; }; 55C890422065C23BA50C14E3 /* CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F3D5ADC9FA4617F866CEFED1 /* CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift */; }; + 55E263152DBC2B5C6AFB2264 /* GroupChannelPushSettingsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = B037A4E8EC8A7B9131F03A16 /* GroupChannelPushSettingsView+Item.swift */; }; 56142E1CF032B0C70476A32E /* CustomMessageThread.ViewConverter.Input.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A31F5BA3D3B2F335B1FA8A5F /* CustomMessageThread.ViewConverter.Input.leftView.swift */; }; - 5654B18C61BCA6414031A585 /* SBURegisterOperatorViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 08612EE13528E627A17FC38D /* SBURegisterOperatorViewModel.swift */; }; + 5629DC4559C08AAFA338A316 /* SBUOpenChannelViewController+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD92AAE15AFE138AA4C1EEB6 /* SBUOpenChannelViewController+SwiftUI.swift */; }; + 564F1B6B7AE4402631180FD2 /* SBUChatNotificationChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D4B7768EB6324A2952EF8E3 /* SBUChatNotificationChannelViewController.swift */; }; 56688DB9C0C396C4EC301C10 /* CustomOpenOperatorList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB3A3CD06C2DEF6907171B46 /* CustomOpenOperatorList.ViewConverter.List.rowView.swift */; }; - 5688556E00B70FAFC8B1F1D1 /* GroupBannedUserListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6681789D0A58D7A83BE74A27 /* GroupBannedUserListView+SubViewBuilder.swift */; }; - 568B75AEBE3555EAEDC32C64 /* SBUGroupChannelSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3705CC5FA738AA9FAB298E7D /* SBUGroupChannelSettingCell.swift */; }; - 56A4448631C5FBAD4A47BA51 /* SBUEnums.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2FF459520D3ED7BBC083BB7E /* SBUEnums.swift */; }; - 56A50FC7E092ABF8AC3A1B4C /* OpenChannelSettingsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = E473AE77FEB63622BA2CE73E /* OpenChannelSettingsViewConverter.List.swift */; }; - 56A9415B712A6BE6D0604B03 /* SBUMessageThreadModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A47631C573A77043D1C5F868 /* SBUMessageThreadModule.List+SwiftUI.swift */; }; + 5673DF20BB7DA1E7011C473D /* SBUGroupChannelListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8EBBC3D69755C1B4A69C7721 /* SBUGroupChannelListModule.swift */; }; 56B918ABAC3906E308F65D92 /* CustomInviteUser.ViewConverter.List.selectionButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3ED66AF6F0BEFF49609F06E1 /* CustomInviteUser.ViewConverter.List.selectionButton.swift */; }; + 574CF37D9D0E030B282D0054 /* SBUBaseMessageCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CA4BAF0DBCE4A96D3835303E /* SBUBaseMessageCell+SwiftUI.swift */; }; + 57572A87BE7D9E250158BA0B /* OpenChannelViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B037D3D503D49A7A34573F5 /* OpenChannelViewConverter.List.swift */; }; 57802138B78B56D2D45E1EEA /* CustomOpenChannelList.SubView.Builder.openChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 413FEC589EA4606EDB81E531 /* CustomOpenChannelList.SubView.Builder.openChannel.swift */; }; - 5782823871DC186373F23AA2 /* SBUCreateChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = F1906ACF63D4B5C27FB224F3 /* SBUCreateChannelViewModel.swift */; }; - 57B80623B0F8BA760F61302F /* OpenMutedParticipantListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2DA6787A21BBB0988131D241 /* OpenMutedParticipantListView+SubViewBuilder.swift */; }; - 57C940DFAFBFE228BDFB7E06 /* SBUAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = C17AFFFF84626265B8C333A6 /* SBUAnimation.swift */; }; - 57EA7C8E6F3F39CC432A85BA /* SBUChatNotificationChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = B130A2EAD2252178E5063E37 /* SBUChatNotificationChannelModule.swift */; }; - 57EEDEB10C783FE7A3A12CAB /* SBUFeedNotificationCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8220E4F1F2BE2C124ED8B73A /* SBUFeedNotificationCellParams.swift */; }; - 582BB9DE1DBC628778B3CDEE /* SBUOpenChannelListModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = BFB2AC204CC38945E7CD7DCC /* SBUOpenChannelListModule.Deprecated.swift */; }; - 589705AA739674BBFC622D85 /* SBUChannelPushSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 53E511BD6CE441242E39D368 /* SBUChannelPushSettingCell.swift */; }; + 57B6A48AC3DBB236593DAB15 /* SBUMessageTemplate.Syntax.Sizes.swift in Sources */ = {isa = PBXBuildFile; fileRef = 56F950DBB5A54AEC88D2E539 /* SBUMessageTemplate.Syntax.Sizes.swift */; }; + 583651736657E4B62F1A6B83 /* SBUGroupChannelSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 82D516D15DFAD9E9EEC5AA3D /* SBUGroupChannelSettingCell.swift */; }; + 587AFAFDC3D405F9F6C20853 /* MessageThreadView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A9FEEEABEADA3B3140A5F0B /* MessageThreadView+Item.swift */; }; + 588FE97552B595B6ECD21889 /* SBUTypingMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 02B0799921F368AB9F43E812 /* SBUTypingMessageCellParams.swift */; }; 58A4E06F7E98AA1A3017ED4E /* CustomCreateGroupChannel.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D3437E424B7438108BB128B1 /* CustomCreateGroupChannel.ViewConverter.Header.leftView.swift */; }; - 5916E62E09E939455B5C079B /* SBUCreateChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 65DF771A802E179051B74F2F /* SBUCreateChannelModule.Header.swift */; }; - 5938A517DB245EE5AFB54C2A /* SBUUserNameView.swift in Sources */ = {isa = PBXBuildFile; fileRef = DEE36BE9DDD0FCF4E77E17DA /* SBUUserNameView.swift */; }; - 59B34C003B81BC5252BCB1F5 /* SBUInviteUserModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8082548DA6A2D4226E6D4B0B /* SBUInviteUserModule.List+SwiftUI.swift */; }; - 59E177326077BCC04E09A381 /* SBUOpenChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE2E49B4FC91D817366079ED /* SBUOpenChannelViewController.Deprecated.swift */; }; - 5B336F13C49D1543C2A84BD2 /* SBUMessageThreadViewController.SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1956667B2BEFE9115DC6BDAE /* SBUMessageThreadViewController.SwiftUI.swift */; }; + 58CB7486FBB7A50F7AF4EE52 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15FB5DC297BFAC6381342D85 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift */; }; + 5B0B8EC873E13E8913D7985F /* SBUSimpleSuggestedReplyOptionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4AFA1BE5F8584D2F119CE1E3 /* SBUSimpleSuggestedReplyOptionView.swift */; }; + 5B12F44A574D88AA56F9E1CF /* SBUModerationsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 12DF34E19AD9277AABB197A4 /* SBUModerationsModule.swift */; }; + 5B3CFCA797E9C2516F5C75C1 /* SBUTypingIndicatorMessage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7BA35D433C66A5CAEADA49E0 /* SBUTypingIndicatorMessage.swift */; }; 5B77482B76D8FFE69BFDB7E5 /* NotificationService.appex in Embed Foundation Extensions */ = {isa = PBXBuildFile; fileRef = 47B6987458B0278D08119327 /* NotificationService.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; }; - 5C39A59836B3CAB59744DFE5 /* SBUVerticalSuggestedReplyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 60F1CC4E90D3A4D2A8070599 /* SBUVerticalSuggestedReplyView.swift */; }; + 5C4CE59950719F465A158543 /* UIViewController+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85CCC0022AAE55FB91296FE5 /* UIViewController+SBUIKit.swift */; }; 5C7477124FC81D0CEAF1F760 /* CustomMessageThread.swift in Sources */ = {isa = PBXBuildFile; fileRef = 328595E958E75E652E64F839 /* CustomMessageThread.swift */; }; - 5C826B25A6BCB1399506A22D /* Date+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1DEBA9D64BDD959D8117D5C8 /* Date+SBUIKit.swift */; }; - 5C9880E54330BFDECBC0C02E /* SBUUserListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9083FB6B72A4A282A2389B1 /* SBUUserListModule.List.swift */; }; - 5CA01106404E246DF785F231 /* OpenChannelRegisterOperatorViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9AF49CD344907510F8C32C0F /* OpenChannelRegisterOperatorViewConverter.List.swift */; }; - 5CC915DBD67E6C0749F53DF2 /* DefaultViewConfigSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 58D18F28C0BA2FC86077F964 /* DefaultViewConfigSet.swift */; }; - 5D49E88AFAF971B4F1DB58FD /* SBUGroupChannelListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68FEB348E153995E6D9A609C /* SBUGroupChannelListModule.Header.swift */; }; - 5D829EE1E565973BA1F52793 /* SBUFeedNotificationChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9456BE61985B9DAB0E0D12CE /* SBUFeedNotificationChannelViewController.swift */; }; + 5D83A1050763CDE1B713425A /* SBUOpenOperatorListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = ECA54CBEF188987F7469149B /* SBUOpenOperatorListUserCell+SwiftUI.swift */; }; + 5D96DDBE4A3EA76F3055399F /* SBUMenuView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 31EBBEC705350486B5A9DBC6 /* SBUMenuView.swift */; }; + 5DABF30A10C7F8FCF51F8CF3 /* SBUDebouncer.swift in Sources */ = {isa = PBXBuildFile; fileRef = CF745C20CDD40C35ACDA3A76 /* SBUDebouncer.swift */; }; 5DC50FA6EED3F8A3D4F966AF /* CustomOpenChannel.ViewConverter.Media.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 60E74E559F411EA5C8C39980 /* CustomOpenChannel.ViewConverter.Media.entireView.swift */; }; - 5DE0EF61A1BBC2FFCE61911D /* SBUBaseSelectUserViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4C2633C1C6CBACCB2EA60472 /* SBUBaseSelectUserViewController.Deprecated.swift */; }; - 5E6AF1F62A480310EAE344BE /* SBUTemplateType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E36DF9938BFB246705DDF39 /* SBUTemplateType.swift */; }; - 5E70C58C2056996F5402894C /* Color+Sendbird.swift in Sources */ = {isa = PBXBuildFile; fileRef = C056C5CCBC515F1ABAA627C1 /* Color+Sendbird.swift */; }; - 5EB26A7581C2E9847325754B /* SBUOpenChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = BF61B959A003633F9C9EB07D /* SBUOpenChannelModule.Header+SwiftUI.swift */; }; - 5EDE9CF7F5BE0C5CA87EB470 /* SBUEmojiListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 35595546721F0FD423B8D80F /* SBUEmojiListViewController.swift */; }; - 5EE36A58EE1A10E1437C0966 /* OpenChannelSettingsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE2A90E5736F2795003DC13E /* OpenChannelSettingsViewConverter.swift */; }; - 5F0565A4139305CDA21FB273 /* SBUAdminMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 256F0FE776E5E6572F47D96A /* SBUAdminMessageCell.swift */; }; - 5F0CD15B81AEF734A6BB58B2 /* PrivacyInfo.xcprivacy in Resources */ = {isa = PBXBuildFile; fileRef = 06417874288D6FAD8D6C61E1 /* PrivacyInfo.xcprivacy */; }; + 5DD906309C96D3E67B1CCBDA /* GroupModerationsViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = EAC33A1D45B726CE0C5F2810 /* GroupModerationsViewProvider.swift */; }; + 5E508188D0EA7735586C71F9 /* SBUOpenChannelContentBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 207182002E1CFAE44F7484F7 /* SBUOpenChannelContentBaseMessageCell.swift */; }; + 5EB2291F44643B8AB2324A7F /* SBUGroupUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 386477BCFB3C3B92E9854484 /* SBUGroupUserListModule.Header+SwiftUI.swift */; }; + 5EC3E529BD5BCC9C89219F3F /* SBUCacheManager.NotificationSetting.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2D275616CF2FFE31313FF15B /* SBUCacheManager.NotificationSetting.swift */; }; + 5F02D23CA3FE3A01E2F78B37 /* SBUInviteUserViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0076945EEAFADBBF46EFFA28 /* SBUInviteUserViewModel.swift */; }; + 5F926A23178986BB02118BC9 /* ViewItemProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4C8F2F5AE4133CDF039D4FDC /* ViewItemProtocol.swift */; }; + 5F93369C8DC21FC1FBFF14EC /* SBUMessageCellProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E46BB57B23AA2CB9528366B /* SBUMessageCellProtocol.swift */; }; 5F9AF33ECDEB0847CAC89CC2 /* CustomGroupChannelSettings.ViewConverter.List.notification.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4CE700B571BDF60CF3AB5576 /* CustomGroupChannelSettings.ViewConverter.List.notification.swift */; }; 5FA3ED209BFA1FE414F53E66 /* CustomOpenBannedUserList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 07696C2C76138E6C1277A6A4 /* CustomOpenBannedUserList.ViewConverter.List.moreButton.swift */; }; - 5FA6862B351607948BEAE4C0 /* GroupChannelPushSettingsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0B4A24D18198AD3FC6A6896 /* GroupChannelPushSettingsView+SubViewBuilder.swift */; }; - 602D59F11EFE41978C1901E7 /* SBUMessageThreadInputView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 61C267590CEE26C18694C591 /* SBUMessageThreadInputView+SwiftUI.swift */; }; - 60DD35FDC14A3235FB83066B /* SBUOpenChannelCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB4BEBA0FDEDCCE9A5804BB9 /* SBUOpenChannelCell.swift */; }; + 5FBD60398F5F13D4D11DBFC6 /* OpenChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = EA2A1DDA7731802AB5994AB5 /* OpenChannelViewConverter.Header.swift */; }; + 5FF3A92D6837E755F277A62D /* SBUModerationsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FB83E6465C9943C30CD9C11 /* SBUModerationsModule.Header.swift */; }; + 6081F52FD872DF19BCCD56D0 /* SBUBaseChannelListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 60581B37CF51AAEFCECE77CD /* SBUBaseChannelListViewController.swift */; }; + 60BB44F946CED611E9035E0C /* SBUError.swift in Sources */ = {isa = PBXBuildFile; fileRef = 035C3F64FE7AAB645C853985 /* SBUError.swift */; }; 60EF40371E0D2FAAAEDBE67F /* Preview Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = F1E04EDD53838E84619F3E17 /* Preview Assets.xcassets */; }; - 610D3FC412C949B9E0E454C0 /* SBUMessageSearchModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = B37E21BC8F9E14B7F17F08BB /* SBUMessageSearchModule.List.swift */; }; - 618A9F92401F9F3D7B9FE3A1 /* SBUBaseChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 26570397B1DC53048CF4E0D0 /* SBUBaseChannelModule.Header.swift */; }; + 6100303B05C35D95DA524E2D /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A88C3ED343AF03A46C782863 /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift */; }; + 614F8544FFEC4EBD7933D8AD /* OpenParticipantListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = EAF986AD73EAB8ADBC900800 /* OpenParticipantListView+ViewConverter.swift */; }; + 6167F0361080F777AEE83744 /* ProviderWrappedHostingView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E787481C1D3394BE0D6A6CBB /* ProviderWrappedHostingView.swift */; }; + 6188D295CBFECFABC98C9C70 /* SBUModerationsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 456A19C5809209F185A044ED /* SBUModerationsModule.List.swift */; }; + 61929D39E1A432B862767F07 /* SBUFeedbackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE0E3266C8A26B645EE82DB8 /* SBUFeedbackView.swift */; }; 61D3957A6057BE642F009B53 /* CustomOpenBannedUserList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E55454E2280EFAAEE0F18863 /* CustomOpenBannedUserList.ViewConverter.Header.leftView.swift */; }; - 6235200FC11DFE84A4E4B8FE /* Data+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 61C01A500D446EBDA6C34A88 /* Data+SBUIKit.swift */; }; + 62415E72995182D94B8FF86A /* SBUBaseChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = A5D1AC09BD03089D2639594A /* SBUBaseChannelModule.Header.swift */; }; 62549845C75B3DAD2D9D3812 /* CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = B2D0EFADDF5CB6BDF60CD7A2 /* CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift */; }; - 629055AEB92A061CA912F275 /* UIApplication+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 463AAB7723F705DF887E76BE /* UIApplication+SBUIKit.swift */; }; - 6328B0D463A87352055ED09F /* SBUSimpleSuggestedReplyOptionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45DD7E41B743695FA21FC378 /* SBUSimpleSuggestedReplyOptionView.swift */; }; - 636070B74D240BFCDF26E2AB /* OpenBannedUserListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = E62E37A0B85E8D8C1DD0BE42 /* OpenBannedUserListViewConverter.List.swift */; }; - 64FAAC91380DD6A0E3D0EA92 /* SBUGroupChannelModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19E5681F3154A4F68F3F2C2E /* SBUGroupChannelModule.List+SwiftUI.swift */; }; - 654ADA1832E52D1D4E90DBCA /* Formatter+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3407D92E992D53C7D02B7CB3 /* Formatter+SBUIKit.swift */; }; - 65958603D664C13D2AB935BB /* SBUOpenChannelBaseMessageCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 10245F542657CABD9F636A3D /* SBUOpenChannelBaseMessageCell+SwiftUI.swift */; }; - 6632A6391C5F963979F17FFD /* OpenChannelRegisterOperatorViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB82FCDC07B9737FF5237466 /* OpenChannelRegisterOperatorViewConverter.swift */; }; - 66ADA4F8CFC6EB6A77D60B1B /* SBUFontSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74FEA7AFCAA577BB7A5935A5 /* SBUFontSet.swift */; }; - 66E3D318F724C2DD14BB3995 /* SBUPaddingLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 722A8173CBC9E33AB320794E /* SBUPaddingLabel.swift */; }; - 66FA5B6120E41120D04DDC2C /* SBUBaseChannelViewController.Keyboard.swift in Sources */ = {isa = PBXBuildFile; fileRef = B85160213149D7C96CF3D470 /* SBUBaseChannelViewController.Keyboard.swift */; }; + 626FB4EB33334F39BAA9C645 /* SBUHorizontalSuggestedReplyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB6DB1D4C127ED23F83429E9 /* SBUHorizontalSuggestedReplyView.swift */; }; + 62D54992B9A2BDDED8FEBB6E /* SBUCreateOpenChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = F1CA0FD406EF14F103F993F1 /* SBUCreateOpenChannelViewModel.swift */; }; + 6315B53F26C8043E49F161CD /* BlockingOperation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68A5BCD230041D9FBB14D808 /* BlockingOperation.swift */; }; + 63D334E69BFDBB0EEDD979C0 /* SBUBaseChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8806A58516400503B5D7EAA4 /* SBUBaseChannelModule.Deprecated.swift */; }; + 6559B87C185467A5E089AF9C /* SBUOpenChannelSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7BF8B7BD5D3182A7B49D05D5 /* SBUOpenChannelSettingsModule.List.swift */; }; + 6588D766BBF57986CC992752 /* SBUMessageCache.swift in Sources */ = {isa = PBXBuildFile; fileRef = DDD86011BD9689522AFEA443 /* SBUMessageCache.swift */; }; + 65C9B673F78F3B0749FA4EAE /* Sendbird+Typealias.swift in Sources */ = {isa = PBXBuildFile; fileRef = EB9EAE40ED4B2267D13C0B8C /* Sendbird+Typealias.swift */; }; + 65EAF94B4113A56875B4A326 /* SBUTableViewCell.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = CE2F4109190C0315167EAF1C /* SBUTableViewCell.Unavailable.swift */; }; 672150262FA671D385144B6F /* CustomInviteUser.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 388F6BF164AE95A69B80EB39 /* CustomInviteUser.ViewConverter.Header.rightView.swift */; }; + 6782E83014B4D1666796CEB3 /* SBUNotificationEmptyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E396AAA7E062869842D0067C /* SBUNotificationEmptyView.swift */; }; 67AD8C8B89D721170E6DA7BB /* CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55C42C46994988A224886728 /* CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift */; }; - 67C6683A660CF0ABFD12862E /* SBUVoiceRecorder.swift in Sources */ = {isa = PBXBuildFile; fileRef = E009E7101E09810AB0B2A2BA /* SBUVoiceRecorder.swift */; }; + 67B7D760B2FCC36C0010911B /* SBUOpenChannelUnknownMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2B9F8C9272B19A196F85B9F1 /* SBUOpenChannelUnknownMessageCell.swift */; }; 67D3743443F891F15D6B8E62 /* CustomGroupMemberList.SubView.Builder.inviteUser.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FBED55AA88DBE899ACF3025 /* CustomGroupMemberList.SubView.Builder.inviteUser.swift */; }; 67E42162BC60FCE8C48FCC25 /* CustomGroupOperatorList.swift in Sources */ = {isa = PBXBuildFile; fileRef = C48F413351CBA7170C9961DF /* CustomGroupOperatorList.swift */; }; - 68157C9AB11657EA24F5905E /* Array+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6B306A81F7C4F4B82605F38B /* Array+SBUIKit.swift */; }; 682280F22C20205432C6D1E6 /* CustomCreateGroupChannel.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D120C68DAE432A9F5C175D1 /* CustomCreateGroupChannel.ViewConverter.List.rowView.swift */; }; + 6839E4960F91236C191BACB5 /* SBUQuotedUserMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7BA58675E43486760EBE4B9B /* SBUQuotedUserMessageView.swift */; }; + 6849F15D4D7D0DDB13B7CCF6 /* SBUMessageTemplate.Binder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 862BAEECB41748FB96C9778F /* SBUMessageTemplate.Binder.swift */; }; + 684CB45E068CC0C34F58F06F /* SBUMultipleFilesMessageCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB28FF204E44C2979312FED6 /* SBUMultipleFilesMessageCollectionViewCell.swift */; }; 689EED9FFA07D7801C8EE0B7 /* CustomOpenChannel.ViewConverter.Input.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 93846E36D0CA7BD5C19CE6F3 /* CustomOpenChannel.ViewConverter.Input.rightView.swift */; }; 68D90A52B6C2C9D42608FC0C /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE135331D28927031AA660D6 /* AppDelegate.swift */; }; + 68EC60B5E312225B96E17C7F /* OpenModerationsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 40F84492490C7710F5A1A242 /* OpenModerationsViewConverter.swift */; }; 693EC70B553C954FFB109B05 /* CustomOpenChannelList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = CAF2F3B78EE368AFF2C5AAFC /* CustomOpenChannelList.SwiftUI.View.Main.swift */; }; - 69BE5266FE4B5A3819986798 /* SBUMessageTemplate.Renderer+Utils.swift in Sources */ = {isa = PBXBuildFile; fileRef = B4634E8F326FA5E9E408A111 /* SBUMessageTemplate.Renderer+Utils.swift */; }; - 6A06C04DE0DE920B35519A29 /* SBUMessageCellConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 61852897DAE0358AD6BBDCA4 /* SBUMessageCellConfiguration.swift */; }; + 69BF779A7D4711A8036D259E /* CGSize+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8B14D993DFD2D52F88F9CEBE /* CGSize+SBUIKit.swift */; }; 6A1B98026C37FB65B07A05A7 /* CustomGroupChannelList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4E7A992C1BA6BBD9F68F735A /* CustomGroupChannelList.ViewConverter.List.rowView.swift */; }; 6A42A7E636253623FACE16B9 /* CustomGroupMemberList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 078067AB981B56743EF32D42 /* CustomGroupMemberList.ViewConverter.Header.leftView.swift */; }; - 6A48C8A3A8B8BC5CAE595936 /* SBUBaseChannelSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5CEEA40256503D52DA8301A7 /* SBUBaseChannelSettingCell.swift */; }; + 6A5C8EC38128BDB746EE2DC4 /* SBUOpenBannedUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CEAD608897F9DE73D59EB1C9 /* SBUOpenBannedUserListModule.List+SwiftUI.swift */; }; + 6A9B427E41716EC0F1A36A54 /* SBUMarkdownTransfer.swift in Sources */ = {isa = PBXBuildFile; fileRef = A57520D9A1D02AE25101EACD /* SBUMarkdownTransfer.swift */; }; + 6AE289C164DD701E3973260B /* SBUChannelStateBanner.MessageThread+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = E77ABB425ACC1813E35023C6 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift */; }; 6AE814F7B2EFCECE248B93F3 /* CustomOpenParticipantList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = DD06A568617A957C0B077EE4 /* CustomOpenParticipantList.SwiftUI.View.CustomMain.swift */; }; - 6B73694B6281E401BDDF6A86 /* SBUUserListModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 05FFB56CB1A9AF2AA9EB60A5 /* SBUUserListModule.Deprecated.swift */; }; - 6BFE5FA80E4C34342365A81D /* SBUCoverImageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 76987E34E766FE932E3CD06A /* SBUCoverImageView.swift */; }; - 6C610264B527BD88F7FDBBE4 /* OpenChannelSettingsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8B900E0B514EC1D42837B8FF /* OpenChannelSettingsView+SubViewBuilder.swift */; }; + 6B04459F796AFCDB1D50D3F9 /* SBUCommonItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9DB600E69AA30D66B6F3D9D7 /* SBUCommonItem.swift */; }; + 6B557999AEF72BE97F4E11EC /* SBUCreateChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = C5B096932C37180E655EB9A6 /* SBUCreateChannelViewController.swift */; }; + 6B6AB05353E77AEB88C44A67 /* OpenParticipantListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E9F239FA17E47DB3C61C92B /* OpenParticipantListView+SubViewBuilder.swift */; }; + 6BB3C117ACD1A65B9A4C7510 /* SBUBaseSelectUserModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B333F8593FEB4991E9648B1 /* SBUBaseSelectUserModule.swift */; }; + 6C5856F01FCFF1D761309379 /* SBUInviteUserModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8E6740EC9EC809010A5628C7 /* SBUInviteUserModule.Deprecated.swift */; }; 6C7FDEFA3F2621C8470B0E42 /* CustomOpenMutedParticipantList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9ABD4B8E0F4F737904494C70 /* CustomOpenMutedParticipantList.swift */; }; + 6CA904E0C8A1B010E9B5159E /* SBUColorSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = E77E32C1CCB09ED19ED82DC8 /* SBUColorSet.swift */; }; 6CC5658F17F99E60195279B8 /* CustomCreateOpenChannel.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33DDBE877B5BABC51BD08FE9 /* CustomCreateOpenChannel.ViewConverter.Header.titleView.swift */; }; - 6CD3C4DAB2E40DDA68C4FB83 /* OpenModerationsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = CD163025FD5F2FDEBE9F839A /* OpenModerationsViewConverter.List.swift */; }; - 6CD3D20A691DEE226074B79C /* SBUOpenUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = D60D97979BB0D61C336877D6 /* SBUOpenUserListUserCell+SwiftUI.swift */; }; - 6CDDFC3D3C6D3B35682BBB66 /* SBUGroupChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = C6401EB0744D3234CC09B212 /* SBUGroupChannelViewController.swift */; }; - 6CF60D9B84F4C8F2CDBDC94E /* SBUBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 66E8A3A8B613A74979FB0FD2 /* SBUBaseMessageCell.swift */; }; + 6CC5FCB02E843FEC5A95FFCF /* GroupMemberListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = BAEB95B332FE15206BBC2DFE /* GroupMemberListViewConverter.swift */; }; + 6D057AE3EF02D6F431F77D7D /* SBUOpenChannelSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F0D567C1B8A60E173F80D95 /* SBUOpenChannelSettingsModule.Header.swift */; }; 6D3AB85EAF69007A452A9355 /* CustomGroupBannedUserList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 29996001A7AE321A2AF1FDE8 /* CustomGroupBannedUserList.SwiftUI.View.Main.swift */; }; - 6E32FBA7FEF4B1DF15CBA365 /* OpenChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB5A989D9069803A11632F6A /* OpenChannelView+SubViewBuilder.swift */; }; - 6E56A4C38E8FB2A9ABFE5100 /* SBUMessageFormViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09E6606143A887F262F79FA9 /* SBUMessageFormViewParams.swift */; }; - 6E87F95D609F2E99C85A2155 /* InviteUserView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 16D3BFEEF9AF232331AE1BDC /* InviteUserView.swift */; }; + 6D6AA6F4E34153A606CD4AAB /* SBUOpenChannelCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9F54E316B3315A516516C65E /* SBUOpenChannelCell+SwiftUI.swift */; }; + 6D9FB62D7282668250312C63 /* Sequence+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 167B8A4B458413D2B4C5F591 /* Sequence+SBUIKit.swift */; }; + 6E32203FC329E9CCF2DF8625 /* OpenParticipantListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 21ECDE889CE936449AE9DBFD /* OpenParticipantListView.swift */; }; + 6E349189BE6D0342A5ED49C0 /* SBUBaseChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 35ACD3293ECBD4E4344CB186 /* SBUBaseChannelViewController.Deprecated.swift */; }; + 6EA99118081FB889DA5DC1FE /* SBUChatNotificationChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = BDEE4A85341548A38E5EB50C /* SBUChatNotificationChannelModule.Header.swift */; }; + 6EB56EDEC523643DC9C2B3C2 /* SBUCommonDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 43029E52C382D59F27DB2770 /* SBUCommonDelegate.swift */; }; 6EB8AE7FE569D606693E7E34 /* CustomOpenOperatorList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8E194EB59871973C28A282B5 /* CustomOpenOperatorList.ViewConverter.Header.leftView.swift */; }; - 6F337F85F1EC26FB5747C0B0 /* SBUMessageFormMultiTextItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52F1328AE03EAAF1AD426D08 /* SBUMessageFormMultiTextItemView.swift */; }; - 6F35423AB5238BD924BF8EB1 /* SwiftUIViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B43C3575A86FB54C7F46C0C /* SwiftUIViewController.swift */; }; + 6EE24A100E14C610574F361E /* SBUBaseMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 53AC6ADF9CA7559D22B20EFD /* SBUBaseMessageCellParams.swift */; }; 6F5EDDDB302028D0FE8790D7 /* CustomGroupChannel.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E90127DF72AC51AA2AE0001 /* CustomGroupChannel.ViewConverter.List.rowView.swift */; }; 6FEB53022DA164CA48ED8F6E /* LoginView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF17E587AFF1B661A648930B /* LoginView.swift */; }; - 6FEBC24199B9349BCD5E410A /* SBUMessageProfileView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F06A8792B7A5667225B0B139 /* SBUMessageProfileView.swift */; }; - 6FEDBF1FAC71B202202A6CFC /* SBUEmojiManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 88134BA06CADFAE21FFFC2D0 /* SBUEmojiManager.swift */; }; - 6FFB9F61D3B5DE9F3270D6BF /* URL+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = E91ABFFD5B2067D560F73E17 /* URL+SBUIKit.swift */; }; - 7007C1FB6C2AB76F1EFBBFA7 /* OpenChannelListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8731B4E84E8F9AFDB3DCCF5D /* OpenChannelListView+Item.swift */; }; + 6FFCCD3AE31B1E858F6A6EAD /* SBUFileMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 062E500577E9F9C767A60C97 /* SBUFileMessageCellParams.swift */; }; 700B4F07EB5DD013D0315FDD /* CustomOpenChannel.ViewConverter.Header.titleLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = A570D54C533C1A8E4328595F /* CustomOpenChannel.ViewConverter.Header.titleLabel.swift */; }; - 7033BAC3383409BDBC1F277C /* OpenBannedUserListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = CA33454C78840807B7841838 /* OpenBannedUserListViewConverter.swift */; }; - 7042EA106C890E247EAA7889 /* SBUGroupChannelListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 501B2DCFD9D5FAD15D5CB709 /* SBUGroupChannelListModule.swift */; }; - 7047759F78D053CCE131A8D2 /* SBUMessageReactionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = DBC22FB20B9809BA2B7123A3 /* SBUMessageReactionView.swift */; }; 704983A70DEF05A3FC317B83 /* CustomMessageSearch.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = C3D8C639BF0842F457D02910 /* CustomMessageSearch.SwiftUI.View.Main.swift */; }; - 70D3891EF8F0F4988D1F82A6 /* SBUMessageInputView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 03B00117DFCCB2FF23A6F102 /* SBUMessageInputView+SwiftUI.swift */; }; - 71B0487C7FB64F8DBFF58DF1 /* SBUTypingIndicatorBubbleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 539CBC600DBA91F212F97009 /* SBUTypingIndicatorBubbleView.swift */; }; + 708AC741FBF6A69E783E2479 /* GroupChannelListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = F124AB50E137D73C24E2B83D /* GroupChannelListViewConverter.List.swift */; }; + 70AE7E0A4E026CBAF47C493A /* GroupOperatorListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A7C45E94E88F6254D996F23 /* GroupOperatorListView+ViewConverter.swift */; }; + 70C4A4792E2BFE63A18A9954 /* SBUTypingIndicatorBubbleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00742C0D576C475B69BDD384 /* SBUTypingIndicatorBubbleView.swift */; }; + 710FAF2DBD1923BFF837E29E /* SBUMessageFormViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 409DBFC7D0F907CC4CC919AD /* SBUMessageFormViewParams.swift */; }; + 71125C3760C161FC8222D8C4 /* SBUMessageThreadModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45C48A775332637B50383C44 /* SBUMessageThreadModule.List.swift */; }; + 71EF4733AFDB66CC2E0590F3 /* SBUTheme+Type.swift in Sources */ = {isa = PBXBuildFile; fileRef = D4348E39A20D96D16960C445 /* SBUTheme+Type.swift */; }; + 71FB67C036D0A5DDEC24A1F6 /* SBUMessageWebView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D6E8137AEC2C6412832EEF1E /* SBUMessageWebView.swift */; }; 71FF59B331DF8D63F7BCD75E /* CustomGroupChannelList.swift in Sources */ = {isa = PBXBuildFile; fileRef = C311C0B887E424C930D2D503 /* CustomGroupChannelList.swift */; }; - 726BE6009C1C3F4B6E224B6F /* SBUBaseSelectUserViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 49B69FE2DEFAAFCBEBC9A1FC /* SBUBaseSelectUserViewController.swift */; }; - 7279E86712E7C3022EA5E7D3 /* SBUMessageTemplate.PayloadType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 54C28728C9C8AC31A2BFBAD1 /* SBUMessageTemplate.PayloadType.swift */; }; - 727B43431066B2BE55A3736B /* SBUReactionsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = DAD0A5FC842160B00A941361 /* SBUReactionsViewController.swift */; }; - 728AF90B616A19E97D31CBD6 /* SBUOpenChannelAdminMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2312B56E1998FE3473D42757 /* SBUOpenChannelAdminMessageCell.swift */; }; - 72E1942B6F0714E5C5E3FD0E /* SBUGroupChannelListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = DF0E4D61160B2C4D056ABF96 /* SBUGroupChannelListModule.List.swift */; }; - 7305337E0F61C0623B07C64A /* OpenMutedParticipantListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1243D603EB01314B012C1D6E /* OpenMutedParticipantListViewConverter.List.swift */; }; - 7397E736C9B53B71C241F874 /* GroupMutedMemberListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = BC85F62E529A705813ED5671 /* GroupMutedMemberListViewConverter.Header.swift */; }; - 73A07126956A34CDDF79C72B /* SBUMessageTemplateCell.MessageTemplateLayer.swift in Sources */ = {isa = PBXBuildFile; fileRef = E7F4A5C2DE942F918F081586 /* SBUMessageTemplateCell.MessageTemplateLayer.swift */; }; - 73B5E951B0FB998EDACC8BB4 /* OpenOperatorListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 76799FA15AA5786517BEF343 /* OpenOperatorListView+Item.swift */; }; + 720FE9F17A79B4B6532208C3 /* GroupChannelListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4F73FDBC49B98B821FAD9E09 /* GroupChannelListView.swift */; }; + 726FCE518B1E92A6064461D6 /* SBUOpenChannelListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6E75FECD8466345F80889285 /* SBUOpenChannelListModule.Header.swift */; }; + 72C5014A5F3EF9F3C54EE23C /* SBUQuotedBaseMessageViewParams.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 05EAE6B5A040463C2BCC6878 /* SBUQuotedBaseMessageViewParams.Deprecated.swift */; }; + 72F31B50B2B889E2E945E8A3 /* OpenModerationsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D2A3BE2336B9819BFB36AD1E /* OpenModerationsView.swift */; }; + 732DB302FC8B4962E92BA430 /* SBUChannelInfoHeaderView.swift in Sources */ = {isa = PBXBuildFile; fileRef = BE88DD79EB597B50591F3AE4 /* SBUChannelInfoHeaderView.swift */; }; + 732DC716016B3A65E12A6F35 /* CustomGroupChannelList.SwiftUI.View.ViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 98A67C9D3AF0E073941124E5 /* CustomGroupChannelList.SwiftUI.View.ViewProvider.swift */; }; + 733E5B71D657B2031C69DFF0 /* SBUChannelSettingsChannelInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D7C327FC68584CFA626021FF /* SBUChannelSettingsChannelInfoView.swift */; }; + 735542E7E87B6C11A55336E5 /* SBUMessageTemplate.Renderer+Utils.swift in Sources */ = {isa = PBXBuildFile; fileRef = AA9023EA669DDE89840B17F0 /* SBUMessageTemplate.Renderer+Utils.swift */; }; + 73A87006FCAEFD7C0359D93E /* SBUGroupBannedUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6E96A78E503C25F929F51F29 /* SBUGroupBannedUserListModule.Header+SwiftUI.swift */; }; 73B6B5337FF2FC877DBDB6B5 /* CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5CC7C6EE71D9C0203FB5FB1A /* CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift */; }; - 73CDF9A5384577E92EACC44C /* SBUCreateGroupChannelModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2E6F8EEF508DA948CDEA60A /* SBUCreateGroupChannelModule.List+SwiftUI.swift */; }; - 73CE000A9B2FA50F39AC6B1B /* SBUMessageTemplateManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = F7159308B1615AF89E0C5848 /* SBUMessageTemplateManager.swift */; }; - 73DD3712A77AED801C29013C /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7DB8540E24BA4EAD377A29F7 /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift */; }; 73EA7261CCF151971AF20878 /* CustomOpenChannel.SubView.Builder.userList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EF0CBE3236AA5C29F96124D /* CustomOpenChannel.SubView.Builder.userList.swift */; }; 73EC1909319017A4B8CDC78A /* CustomGroupChannelList.ViewConverter.List.unreadCount.swift in Sources */ = {isa = PBXBuildFile; fileRef = B62DDB5AEADE552713948729 /* CustomGroupChannelList.ViewConverter.List.unreadCount.swift */; }; - 73F5820D874BD63ECFE0B5CB /* SBUViewLifeCycle.swift in Sources */ = {isa = PBXBuildFile; fileRef = 13C1A9FF2EF8EC07A88DF01C /* SBUViewLifeCycle.swift */; }; 741EDEF887C5D26B6EC6A07F /* CustomOpenModerations.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 04561764A6EDAA5F1B379364 /* CustomOpenModerations.ViewConverter.List.entireView.swift */; }; - 743C7FE64559E35EA4B3DFB8 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1613A81DAF0386D295401F59 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift */; }; - 75117163F51C9A2BBDDC7E5A /* GroupChannelListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6B072AC7DDABF32DA278BBA6 /* GroupChannelListView+SubViewBuilder.swift */; }; + 749F372DA7755F9B0CD00F9F /* SBUUserCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1D79AE410C0225BF9B73BD23 /* SBUUserCell.swift */; }; + 74F6E4EEE99721439E3FCC0A /* SBUMessageInputView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 830DF49F679C52EADB4D45B6 /* SBUMessageInputView.swift */; }; + 75298996C8301E78AC5B781F /* SBUBaseChannelSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5550B3E5AB07ED184E5C3A84 /* SBUBaseChannelSettingsViewController.swift */; }; 752F5BF3BA55D2996394B5D5 /* CustomOpenChannel.ViewConverter.List.scrollBottomView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A506ABBB4475B2B23B51459C /* CustomOpenChannel.ViewConverter.List.scrollBottomView.swift */; }; - 755389B615893549894B2F2D /* SBUBaseChannelModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = C322F14245229C7D8D078D67 /* SBUBaseChannelModule.Input.swift */; }; - 755AFEC6F6C99EED386CD93D /* OpenParticipantListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = FD91A7FA49003653EAC40E13 /* OpenParticipantListViewConverter.swift */; }; - 75F8DF16D7722B362B5BCF2E /* SBUChatNotificationChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FC7056D923557465B002170 /* SBUChatNotificationChannelViewModel.swift */; }; - 760DB6940C51374972580B90 /* SBUBaseSelectUserModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = FDF95535882D104149DE19C4 /* SBUBaseSelectUserModule.Header.swift */; }; + 75410ED22270B7B5BB199AD4 /* SBUGroupChannelSettingCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3D593110E31DC45E924E2D9B /* SBUGroupChannelSettingCell+SwiftUI.swift */; }; + 755884802F1253F871FAEC4C /* SBUGroupChannelPushSettingsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = FF19DEF5C6B07A8E32A6919B /* SBUGroupChannelPushSettingsModule.Deprecated.swift */; }; + 7571C94F245C2E7E74AD6187 /* SBUMentionManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0CC6CC5766E9A4E51E951E69 /* SBUMentionManager.swift */; }; + 75771AD4432A3C7F634CF7AE /* MessageSearchView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = DECFF1D9649B3B654288217B /* MessageSearchView+Item.swift */; }; + 75FE26AA4B907C484F2A9483 /* SBUGroupModerationsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CE82953971F0DF674CF5F599 /* SBUGroupModerationsModule.Header+SwiftUI.swift */; }; + 76020C9F983CDCF54A5015B9 /* SendbirdUI.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 525286C859F82074D24680B2 /* SendbirdUI.Deprecated.swift */; }; + 767D097425B4B3AAC824CD77 /* Thread+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9ED6D075080214039048A95D /* Thread+SBUIKit.swift */; }; 768E695C92E91E4D08F7ED2C /* CustomGroupMemberList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 279B0E88887FD0F09FD5290E /* CustomGroupMemberList.ViewConverter.List.rowView.swift */; }; - 76A52219FACE19DDD99554CD /* SBUGroupChannelSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 16B94B84000BF8542CAE6747 /* SBUGroupChannelSettingsViewModel.swift */; }; - 76AFE05AB31FFE1CC4F96941 /* SBUMessageSearchViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = DE4692268960D6FB3AD51F3A /* SBUMessageSearchViewController.Deprecated.swift */; }; - 76CF2A78B301A445C3DD58B2 /* SBUMessageThreadModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E35F2241D8BFF297E9C7880 /* SBUMessageThreadModule.Input.swift */; }; + 76B4CFCFBBE6B97081FF81BE /* SBUGroupBannedUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3CA1FC5D1795A64974F5421A /* SBUGroupBannedUserListUserCell+SwiftUI.swift */; }; 76EDABA453D0957F41C42684 /* CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 14EA076EB6C73BA4290914FE /* CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift */; }; - 7705D4416461633D988BF2D4 /* SBUCreateOpenChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 633ED5B1F7A4CAB56DE1F5BB /* SBUCreateOpenChannelViewController.swift */; }; - 770D93EADA297635BA603621 /* SBUInviteUserModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = B4EB1DE72843F9F2E4E067BC /* SBUInviteUserModule.Header.swift */; }; - 77391D78564F848F57EE1E46 /* OpenModerationsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AACD96B9376174CFA06D9E9 /* OpenModerationsViewConverter.swift */; }; - 777246F426A612F593C2D69F /* SBUBaseMessageCell.MessageThread+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A039F4C3599EE466CF9B9233 /* SBUBaseMessageCell.MessageThread+SwiftUI.swift */; }; - 77A67C1F5A44AB3E5AEC5E14 /* SBUMessageTemplate.Renderer.Image.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BDF021DB7EDAA493F908BB5 /* SBUMessageTemplate.Renderer.Image.swift */; }; + 771BEBCA97EBA8B31AAF95C2 /* SBUToastView.Internal.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68559B08315B254984DBA950 /* SBUToastView.Internal.swift */; }; + 771C5437EECAA571DF8C9B8F /* SBUCreateGroupChannelModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = C1C275129547FD119EC8DC0A /* SBUCreateGroupChannelModule.List+SwiftUI.swift */; }; + 772E4D392B5550DD3FDAD535 /* InviteUserViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = EA23C8AD569D84167F4DD526 /* InviteUserViewConverter.swift */; }; + 773421C3BDBEAAA97B75EA80 /* CreateGroupChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2B719C1C7BCA50103B2FD33F /* CreateGroupChannelView+SubViewBuilder.swift */; }; + 77804AA5E6072297F429A920 /* SBUMessageFormChipView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4295DC2364062B88F929D80E /* SBUMessageFormChipView.swift */; }; 77AA724DB557C412388E3750 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C9C266B8A2DF6EB7F1504782 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift */; }; - 783A7828C7E3288A7480F126 /* SBUGroupChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6FD12CE289932C017AACEFC8 /* SBUGroupChannelModule.Header+SwiftUI.swift */; }; + 77AA82E38B8808BC31CF1A33 /* SBUMessageThreadModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F41FB77D91238CE800D9F43 /* SBUMessageThreadModule.Header+SwiftUI.swift */; }; + 77F45EB93F523CDDECF16107 /* UIStackView.SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = FD34FF666C940B94555A93F5 /* UIStackView.SBUIKit.swift */; }; + 7812F26A7A0A2D570C741C6A /* GroupOperatorListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = BDFE3D65FB2D6207335EFEF0 /* GroupOperatorListViewConverter.swift */; }; 784374EC48F1FF3B98BB80CB /* CustomOpenChannel.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C7600AD2C584F0101C89CBAB /* CustomOpenChannel.ViewConverter.Header.leftView.swift */; }; - 785FE7080A6BB20F6FC9117F /* SendbirdUI.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = D4DBC0F7C21761BD70C04903 /* SendbirdUI.Deprecated.swift */; }; 786261EBAF78615F8AFEAF41 /* MainView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 940843643FFA366733C4118D /* MainView.swift */; }; + 7872E67C27C3D19415B44720 /* SBUMessageSearchModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2C4D064E91A746BEA570EA54 /* SBUMessageSearchModule.List.swift */; }; + 78BA0849D102494B2D0B66C2 /* SBUOpenChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 030585AC870531AD9465859D /* SBUOpenChannelModule.Header+SwiftUI.swift */; }; + 78BD0BE51D5CEFCB92A30AE1 /* SBUNotificationChannelManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = F9AD7543D82F147890DDA8EC /* SBUNotificationChannelManager.swift */; }; 78C2FBC31DD3F2C8A6160AC8 /* CustomInviteUser.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 11EC6E379AF8CC994489450D /* CustomInviteUser.ViewConverter.List.rowView.swift */; }; - 790BDF268EE5BE9FF7D4C985 /* SBUMessageTemplate.Container.swift in Sources */ = {isa = PBXBuildFile; fileRef = 130BDF243558344563BDD04F /* SBUMessageTemplate.Container.swift */; }; - 7912D438DD630BA7680173B5 /* SBUDateFormatSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = A0A6460B6ABA537A9DF9E077 /* SBUDateFormatSet.swift */; }; + 78FFE2C752BD028D33D288DF /* SBUGroupChannelModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB98E8EF9F62A00D52D15264 /* SBUGroupChannelModule.Input.swift */; }; 791745E57EDBDDC81EDDEFDB /* CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 34DF51D99B16E5DE6AF5DE56 /* CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift */; }; - 791E5F692866B1DC5DB07A79 /* SBUPhotoCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = D98EB11025EC91C28DF16EA2 /* SBUPhotoCollectionViewCell.swift */; }; - 7924A57DC1B97A73957ECF12 /* SBUChannelSettingItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = AA730E10316B59EC0D80449F /* SBUChannelSettingItem.swift */; }; - 792582B380251061DC474C41 /* Float+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 920FC92C3C10DFB71BEA1069 /* Float+SBUIKit.swift */; }; - 798F12C2585CAABC8B101321 /* SBUOpenBannedUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9A6F00C0095D4A373AC6FD93 /* SBUOpenBannedUserListUserCell+SwiftUI.swift */; }; - 799B8CA047558F53292A298F /* SBUSelectableStackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9791A3C99477F1AA70CB5338 /* SBUSelectableStackView.swift */; }; - 79D6BB20F171C134F9110FBF /* GroupChannelSettingsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = AFB7053B5FEC84E058F598BF /* GroupChannelSettingsView+Item.swift */; }; + 797ED487D628A88BD5F11558 /* SBUGroupOperatorListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = BC87A02119141F2A3B9F2390 /* SBUGroupOperatorListModule.List+SwiftUI.swift */; }; + 79C59527FC4913F85249703F /* OpenChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 947446DE112FAC2320D1EF22 /* OpenChannelView+Item.swift */; }; + 79DE6B64A5192F1E49A12E4B /* SBUNewMessageInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = EF67B852DBB45B4929297E29 /* SBUNewMessageInfo.swift */; }; + 79EE6C6C3317C68081075891 /* SBUGroupMutedMemberListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CBC80E25FFD78206A507757A /* SBUGroupMutedMemberListModule.List+SwiftUI.swift */; }; + 7A471BD88BF39C4392D0640B /* OpenMutedParticipantListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 89193DB4600A4F222C0F5524 /* OpenMutedParticipantListView+SubViewBuilder.swift */; }; + 7A55A24D142F4DE901440E9D /* SBUMessageTemplate.Action.swift in Sources */ = {isa = PBXBuildFile; fileRef = 50E19A3A71169937AB5A03B8 /* SBUMessageTemplate.Action.swift */; }; + 7A9A43692C612EA3BEE35FBB /* SBUForm.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0259861A8497D04AEA7CE0C9 /* SBUForm.Deprecated.swift */; }; + 7AC62B383D145110B5C9D25B /* SBUOpenChannelListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = E6C77D06D3443161CF556779 /* SBUOpenChannelListViewModel.swift */; }; 7B4CC35E4C7C82E83A235DBA /* CustomGroupChannel.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2535A08EF2BFD8F5B95990E8 /* CustomGroupChannel.SwiftUI.View.Main.swift */; }; - 7BACA8DB6DD90759116A2EC0 /* OpenOperatorListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4C33D8246AFE1AE05351D8CA /* OpenOperatorListView.swift */; }; - 7BF6212FB2FC5CFCE3D636D9 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6F89A8E5D6B54674EDAD0090 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift */; }; - 7C068B2032F4D86F52C73E1E /* GroupBannedUserListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B70536649E7147BA12EAED3 /* GroupBannedUserListView+Item.swift */; }; - 7C0C0ED9C2E62A88775A257B /* SBUMessageThreadTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69FF9A1D6E3096D844452179 /* SBUMessageThreadTitleView.swift */; }; - 7C22CFA5895EDA53C558CD83 /* GroupChannelPushSettingsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5AA91AC88677D130F49744F1 /* GroupChannelPushSettingsViewConverter.swift */; }; - 7C6D71CF99DA0C31028AC39D /* SBUContentBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9FF73F1AC1586488A59B9BB9 /* SBUContentBaseMessageCell.swift */; }; - 7CFF409B8A3C97FA854261F3 /* SBUGroupChannelListModule.Common.swift in Sources */ = {isa = PBXBuildFile; fileRef = F6D93377303A480B6512DD30 /* SBUGroupChannelListModule.Common.swift */; }; - 7D124911960DBA1BF9E54E49 /* SBUBaseChannelListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 27C26C3082D49E50ADAB0561 /* SBUBaseChannelListViewModel.swift */; }; + 7BA56FCC53B4ACEF17667EBA /* GroupMemberListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68884CEA1F889062B9AE92D9 /* GroupMemberListViewProvider.swift */; }; + 7BA58ABB58DC96653CFE0EAF /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = AFE3D03358D333FDDEA9BB20 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift */; }; + 7BDD74C91C71E41176358809 /* SBUOpenChannelMessageWebView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6B424207542E1A82DAC82A0D /* SBUOpenChannelMessageWebView.swift */; }; + 7C930D4C75E7342EEADE9AF6 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 421321AB71FAF7684718DD97 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift */; }; + 7C99078737FB1A94FE3E2CC4 /* SBUConfig.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2949F2DE8EFDD9154DC2E2E9 /* SBUConfig.swift */; }; + 7D162B369BE3198C867A5662 /* SBUVoiceRecorder.swift in Sources */ = {isa = PBXBuildFile; fileRef = D5A8512A3DE8E4E3C4FD944C /* SBUVoiceRecorder.swift */; }; + 7D29700D11022FFE16975E59 /* GroupChannelSettingsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EC4CB40DFDCDAA8D8D03164 /* GroupChannelSettingsView+SubViewBuilder.swift */; }; + 7D43A4DDC699B50998184A85 /* SBUGroupChannelListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8E77729D950B20F81EC79C63 /* SBUGroupChannelListModule.List+SwiftUI.swift */; }; + 7D8DB25B63042F2D7F505632 /* SBUCacheManager.Config.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0BDD72D5B40E66A00F22358F /* SBUCacheManager.Config.swift */; }; + 7DF5788443E1C3CE035241CE /* SBUPropertyWrapper.swift in Sources */ = {isa = PBXBuildFile; fileRef = 401B66CDBC80C118564B5045 /* SBUPropertyWrapper.swift */; }; 7E0B5C6DC3666509BB969752 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 792EED2FB05603227B76613B /* CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift */; }; - 7E5E45E47693761072E48293 /* SBUPhotoAccess.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6192BAE26601C4A3B4CE787C /* SBUPhotoAccess.swift */; }; - 7E764BE12CFEB2DC1EC00B68 /* GroupMemberListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4C58C8CFC4FB879A749E7447 /* GroupMemberListView+ViewConverter.swift */; }; + 7E503FBB0F614CE6D6C58B74 /* GroupChannelRegisterOperatorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E0914DD583685C5CC8D2419 /* GroupChannelRegisterOperatorView.swift */; }; 7E78ADE9F16A5B3A0D758349 /* CustomGroupChannelSettings.ViewConverter.List.member.swift in Sources */ = {isa = PBXBuildFile; fileRef = 138034D59666A1D306B840DA /* CustomGroupChannelSettings.ViewConverter.List.member.swift */; }; - 7F315F24B4D8C1F258FCA8C1 /* SBUMessageCellProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = ADE7D91A32DE35288413F142 /* SBUMessageCellProtocol.swift */; }; - 7F595FC290A932EA77CC113C /* SBUMessageTemplate.Syntax.Types.swift in Sources */ = {isa = PBXBuildFile; fileRef = 67309FAB43DB15811EE0FAC5 /* SBUMessageTemplate.Syntax.Types.swift */; }; - 7F82F1A1E5C62A71724B5366 /* SBUUnderLineTextField.swift in Sources */ = {isa = PBXBuildFile; fileRef = 30D114A3FEC7A9B2EC46E9EE /* SBUUnderLineTextField.swift */; }; - 7F83A3EFDCBEE6F0F0399F36 /* GroupChannelSettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 29F879C5B05E8718BA713CED /* GroupChannelSettingsView.swift */; }; - 7F9CFA9CEC0DD25A3822642F /* SBUMessageThreadModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C02B4F623BAF706728A67A3 /* SBUMessageThreadModule.List.swift */; }; - 7FA8937FB07369062A7EBAFE /* SBUTheme.swift in Sources */ = {isa = PBXBuildFile; fileRef = EC3CBE8DD286C9ED98CC73C0 /* SBUTheme.swift */; }; - 8020914212378DB0CB861084 /* SendbirdUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2A72C6155A43F6C1095DF84B /* SendbirdUI.swift */; }; - 803B30E799E043691CED267A /* SBUGroupChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 49B0CF645FE9CBB0F17FAB36 /* SBUGroupChannelModule.swift */; }; - 807BB72D1A285BC3389B5DE1 /* SBUFeedNotificationChannelModule.CategoryFilter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 71A416E658CCC1E1163229BB /* SBUFeedNotificationChannelModule.CategoryFilter.swift */; }; - 80A2E031698ACA7E9CB82974 /* SBUQuotedBaseMessageViewParams.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15F63FC3018647E421EC68B1 /* SBUQuotedBaseMessageViewParams.Deprecated.swift */; }; - 80DBE36AEE07BA173E746B76 /* MessageThreadViewConverter.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD56A02381EBFBDFB56FF9D7 /* MessageThreadViewConverter.Input.swift */; }; - 80EAE88EFE5AA50D8F9D6040 /* OpenModerationsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = B27F2C1ED575A382398E6677 /* OpenModerationsView+ViewConverter.swift */; }; - 811751B155EA0C0797AC521E /* SBUQuotedFileMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 39177B76E752035056578234 /* SBUQuotedFileMessageView.swift */; }; - 817653C94409F8B5986A4475 /* ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15CFF068B647DF41C757A688 /* ViewConverter.swift */; }; + 7EF26B31198C8B771AC6A8ED /* SBURegisterOperatorModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69AD8CF8B82DA7E28C4E1E29 /* SBURegisterOperatorModule.Header.swift */; }; + 7EFDEBEAAF1DBDED177EE139 /* SBUMessageTemplate.Container.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB5A3230F6C3473FCC54FE72 /* SBUMessageTemplate.Container.swift */; }; + 7F098AABCC2D5C845C95607A /* OpenChannelRegisterOperatorViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = BE11E602679B94F815434977 /* OpenChannelRegisterOperatorViewProvider.swift */; }; + 8027CA105DCC384F42A15034 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1FA72B8958F28537FDA7ACFE /* SBUCreateGroupChannelModule.Header+SwiftUI.swift */; }; + 8102C5375DF8738D2B414429 /* SBUOpenChannelUserMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = C9DED4E5BC49F741DD5BAE12 /* SBUOpenChannelUserMessageCell.swift */; }; + 81477334E91657BE68CCB150 /* SBUSearchBar.swift in Sources */ = {isa = PBXBuildFile; fileRef = F7EDA70EF7D626DD23ABD4C8 /* SBUSearchBar.swift */; }; 81A887EE3048DF2384FDD57D /* CustomGroupChannel.ViewConverter.Input.addButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 51454BECF0ACB34F18848A01 /* CustomGroupChannel.ViewConverter.Input.addButton.swift */; }; - 81B92E41ACBED0F2622CBA04 /* OpenChannelListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 64D0F70137FEF5F25AD7A9DC /* OpenChannelListViewConverter.Header.swift */; }; 81C012522C17232D664E250B /* CustomGroupOperatorList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1A44E48D1D24AA8A93786370 /* CustomGroupOperatorList.SwiftUI.View.CustomMain.swift */; }; - 81D347E7506E34DD45A54827 /* SBUGroupChannelPushSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 433031D3C682345C94D28FDF /* SBUGroupChannelPushSettingsModule.List.swift */; }; - 81DFA07BDEC020933EB801D5 /* OpenChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 798CA844E4DAA6C1574314BE /* OpenChannelView+Item.swift */; }; - 81F04D83B2BCE531EEF9C983 /* OpenChannelListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5FC3D28B7EC4E416E6936B47 /* OpenChannelListView+SubViewBuilder.swift */; }; - 8205BE1C5CF85CF34FE8672D /* SBUDashboardConfig.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4655846FE0CADF225229E917 /* SBUDashboardConfig.swift */; }; - 82080F4FA9B0396AAE547CA4 /* SBUBaseChannelSettingsViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = FE58C6471BF7E86158214650 /* SBUBaseChannelSettingsViewController.Deprecated.swift */; }; - 8216EBEE01536786B41EF6A1 /* SBUChatNotificationChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B217E1EA093625A1F18F9245 /* SBUChatNotificationChannelViewController.swift */; }; - 821A4BDD3AD4494A14303F9C /* SBUChannelListViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = C8892CCB312BD353673997C2 /* SBUChannelListViewController.Deprecated.swift */; }; - 8241C83EE1198310FA21F73D /* SBUInviteUserModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 567FF37C00B81850DBD328D4 /* SBUInviteUserModule.Header+SwiftUI.swift */; }; + 827226E24E8063114A293903 /* GroupMemberListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F519A11E20B608D84165E59 /* GroupMemberListView+Item.swift */; }; 829A3F7C608D620160A0347D /* CustomOpenChannelSettings.SubView.Builder.moderations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 279B677541AB48613E5A2EA8 /* CustomOpenChannelSettings.SubView.Builder.moderations.swift */; }; 829A7D34DAD00E6309387CEF /* CustomGroupMemberList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = E5BF064E0D3608B442A23FF6 /* CustomGroupMemberList.SwiftUI.View.CustomMain.swift */; }; - 82A13655F33C7B331CADEC26 /* UIViewController+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = E51D27858754EDD555AF4BD5 /* UIViewController+SBUIKit.swift */; }; - 83184B6DE831773CD38D3F4F /* OpenChannelSettingsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9794223D75D07919015D20B /* OpenChannelSettingsViewConverter.Header.swift */; }; - 8384A67651EFEE2F2AB8E67D /* SBUChatNotificationChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 482ABAD59BE7C16F21111FAC /* SBUChatNotificationChannelModule.List.swift */; }; - 8398BB53C2C6D3D33C5DA505 /* SBUBaseChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5F1E6CC210604D9FFC1F3234 /* SBUBaseChannelModule.swift */; }; - 842DC78E8C3D568A732AE597 /* SBUBaseChannelListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6830AB2E6492132B6DCF3BE4 /* SBUBaseChannelListModule.List.swift */; }; + 82A898BACC6F2F1FD574F8F0 /* SBUMentionConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6869E075C9311C1F762F78B6 /* SBUMentionConfiguration.swift */; }; + 82CEECFAA499AA52533DAC0B /* SBUCacheManager.File.swift in Sources */ = {isa = PBXBuildFile; fileRef = 183C845EEBFBD4DF24DBFAF5 /* SBUCacheManager.File.swift */; }; + 82CF1DEDA7BCF6604A4F71EA /* GroupChannelListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 918EA2EEE13EC608EE6A9692 /* GroupChannelListView+ViewConverter.swift */; }; + 82D77D77451DFA4A47284ECF /* OpenChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7D0E7D82632BC43A4434560 /* OpenChannelView+SubViewBuilder.swift */; }; + 83519CD9F2682049CAC10AAE /* OpenChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A907EC372E1A2032BF4721C /* OpenChannelViewConverter.swift */; }; + 836605B9CC401A3A75EEABBF /* SBUConstant.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3DD2F8C9F7503629C66F2EEE /* SBUConstant.swift */; }; + 83B3AE01FB5693BEEFF17D1B /* SBUOpenUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A3D23ECF381EA3D28AAD871 /* SBUOpenUserListModule.List+SwiftUI.swift */; }; + 83ED3B750DFFD0857F6AFA29 /* SBUMessageSearchViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 736D000D5C7D45CA1F4D9F3B /* SBUMessageSearchViewController.swift */; }; 8442EB4D112739755CFA3AE9 /* CustomGroupOperatorList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = E8F1CE3F5598712CA3C279EB /* CustomGroupOperatorList.SwiftUI.View.Main.swift */; }; - 84F293336B8C6AC202AF045D /* SBUTypingIndicatorMessage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 934D7469181C103EE1ACAF1B /* SBUTypingIndicatorMessage.swift */; }; + 849267C24B79D5262E20A32A /* SBUGroupChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1A01964E8998FC11F82F7F27 /* SBUGroupChannelModule.Deprecated.swift */; }; + 85080FE10A399FFEC8482641 /* SBUFeedbackViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9D0CE5D19096B1C1D8766F21 /* SBUFeedbackViewParams.swift */; }; 85144A9DC5DEB1BB192CF75D /* CustomOpenParticipantList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0600F135F1741E465B05B84E /* CustomOpenParticipantList.ViewConverter.List.moreButton.swift */; }; - 8573108EB9817D925B933311 /* SBUUserListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8668B5EFC9B9C3CBB72B925D /* SBUUserListModule.Header.swift */; }; + 8523FEA7BC6EF599A443BD80 /* MessageThreadView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 21050C5DF391743F4A7D9825 /* MessageThreadView+ViewConverter.swift */; }; + 8588EA58929A46E1C917B41B /* SBUConfig.GroupChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5FBA19E717B0FDA9B35A2D5F /* SBUConfig.GroupChannel.swift */; }; 859A8A47DCFF9F035A2622C9 /* CustomGroupBannedUserList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = B9E1014ACA765E3598F06F71 /* CustomGroupBannedUserList.ViewConverter.List.profileImage.swift */; }; 85A78B84F1D2B6A018CF6C2F /* CustomMessageSearch.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F8E8BBB7F3386838673ACE44 /* CustomMessageSearch.ViewConverter.List.entireView.swift */; }; 85D95745D7937272E7D954C4 /* CustomOpenChannel.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3180CCA4DF7E2B5F60580C79 /* CustomOpenChannel.ViewConverter.List.rowView.swift */; }; - 864CB4627554453FCC734983 /* OpenBannedUserListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = BF2C918C951707F9AC84EA4F /* OpenBannedUserListView+Item.swift */; }; - 8657C3AEF83AD7A2D1068902 /* SBUPermissionManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 79787649F52DE9A28FB275CE /* SBUPermissionManager.swift */; }; - 869AF52E0D0163E959C3D1E8 /* SBUOpenChannelModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 630659BAAC01FBD1371A29F5 /* SBUOpenChannelModule.Input.swift */; }; + 85EE91F0746CAACE767F5E0D /* SBUTypingIndicatorInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = F02236D8926A5EE794CBBE3F /* SBUTypingIndicatorInfo.swift */; }; + 868FFE104D525ACE8BAA05F3 /* SBUIconSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F787E65B4187FC92E0391AF /* SBUIconSet.swift */; }; + 86ACE990277910A684185982 /* UITextField+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 54BFF6A6EF79427A10DA19C5 /* UITextField+SBUIKit.swift */; }; 86BFEEEA13989BBA81C59EAD /* CustomOpenChannel.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 060356821F9B1712D880A550 /* CustomOpenChannel.ViewConverter.Header.rightView.swift */; }; - 86F226822B1451C19965B7E4 /* SBUNotificationNavigationTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A27F27248F7F70BEB6F6468 /* SBUNotificationNavigationTitleView.swift */; }; + 86CD5796D4AAE048134ADF51 /* SBUCreateOpenChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 40F43C0CB687B4B7C5E4B3C6 /* SBUCreateOpenChannelModule.Deprecated.swift */; }; + 86E6148CBF2BFD02FDA80732 /* SBUExtendedMessagePayload.swift in Sources */ = {isa = PBXBuildFile; fileRef = 37ABB14A977C9D99DFF4CA6A /* SBUExtendedMessagePayload.swift */; }; + 8742DC47B4E3EE28F65FDE70 /* SBUTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9EA130B566F3BFCA65E9A262 /* SBUTextView.swift */; }; 8756E150D07A8EA750EFA1A0 /* QuickStartSwiftUIApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = D7B7852719332CFD27879AB8 /* QuickStartSwiftUIApp.swift */; }; - 879224620E046F928842B9F9 /* SBUCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = CCAD3EB06242ACBE685CAC9A /* SBUCollectionViewCell.swift */; }; + 87882C0D0FB63C03157D9E1D /* InviteUserView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B041F9C56CD7C0C012E98950 /* InviteUserView.swift */; }; 881BC0F0352997561DF8377E /* CustomGroupChannel.SubView.Builder.channelSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5ACEF102F36443266AED5359 /* CustomGroupChannel.SubView.Builder.channelSettings.swift */; }; - 882E1B6DFF06F1074F8157D2 /* SBUMultipleFilesMessageCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 37C11167BE05D634FB689838 /* SBUMultipleFilesMessageCollectionViewCell.swift */; }; - 88757C1BAED695420CD841F4 /* SBUScrollPostionConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = E209E92758FCC408F49DB85A /* SBUScrollPostionConfiguration.swift */; }; - 887745C06130F7437448530E /* SBUGroupModerationsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F7307101AAA00FA1558AF980 /* SBUGroupModerationsModule.Header+SwiftUI.swift */; }; - 888008287DE75A2749595294 /* SBUOpenChannelInputView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F92B219D2E3A203BB7E9F3EB /* SBUOpenChannelInputView+SwiftUI.swift */; }; - 88D1F877842116D504E90183 /* GroupChannelSettingsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9642EB6B731C9449EF95384D /* GroupChannelSettingsViewConverter.swift */; }; - 89223DB915FC1ED34B37E820 /* SBUHighlightMessageInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = F11CCC27B98DC10813651863 /* SBUHighlightMessageInfo.swift */; }; - 892CE8238EDBCDE6C19CC926 /* SBUCacheManager.Template.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3AD9EB3F40F9E5D40F9B5FAC /* SBUCacheManager.Template.swift */; }; + 881BC3027B2BD7BA53C02685 /* SBULabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E9DA3E806D49F987C40355A /* SBULabel.swift */; }; + 882F0C559D38825AB12B87CC /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 621F589E5F0ED5BEE52864D0 /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift */; }; + 88FAAC0E19331859E9F0A86F /* SBUBaseMessageCell.MessageThread+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = C539EDA44801E5FA137C9F14 /* SBUBaseMessageCell.MessageThread+SwiftUI.swift */; }; + 897709A55B9AD396E995FA94 /* GroupChannelListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = D6DA1D0A44C99A7052978AB9 /* GroupChannelListViewConverter.swift */; }; 89C974859E19E0F059CE0C9F /* CustomOpenBannedUserList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9AF661DCF63857A167FA1552 /* CustomOpenBannedUserList.SwiftUI.View.Main.swift */; }; - 89DD1EC1DD502D00EC350B39 /* SBURegisterOperatorModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2C29B6EED1FE32956FF834A8 /* SBURegisterOperatorModule.Deprecated.swift */; }; - 8A0605B18C11E2482DFBBFBE /* SBUReplyConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = ED4992F14BC1A4369B0FE99F /* SBUReplyConfiguration.swift */; }; - 8B16B9513C3414DDEBB144E9 /* MessageTemplateTestViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1BD8C3C6E22B76ECEA6DC1DB /* MessageTemplateTestViewController.swift */; }; - 8B3A95B7E9A2926DB86EB5BA /* SBUToastView.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = BCB0F215A1630FCF1A088CCA /* SBUToastView.Item.swift */; }; - 8B3D296ED71AA9DEE683DD1E /* SBUAvailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9FAB9A2A0323D5A01103F169 /* SBUAvailable.swift */; }; - 8BC2D01CC28ADEC9F3AF8F07 /* SBUActionSheet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9A57EF97E3AB541373FFE03F /* SBUActionSheet.swift */; }; - 8BD19388485B644E8C55B428 /* CreateGroupChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7941531B02292F6773399CBE /* CreateGroupChannelViewConverter.Header.swift */; }; - 8C010F344DF737F686118EEA /* SBUGroupChannelPushSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = EC000D6306DDB9315E2125AC /* SBUGroupChannelPushSettingsModule.Header.swift */; }; - 8C05C14DCABBADAD4001D1B4 /* GroupChannelSettingsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 053C0919C7CAED665251B6BA /* GroupChannelSettingsViewConverter.Header.swift */; }; - 8C0A5E28547E0446FFCD7681 /* SBUGroupChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0C58F296D9B6516563598F5 /* SBUGroupChannelViewController.Deprecated.swift */; }; + 8A407D2C3CFE9FC0EE63C2B1 /* SBUBaseChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B01828BC5F31C8FA805FB0AA /* SBUBaseChannelViewController.swift */; }; + 8A51E94D0A5A62638CC6DB94 /* OpenChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 67CA15DE5967D27E5ABC4233 /* OpenChannelView.swift */; }; + 8A729DD853E751CB489D6635 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 37116E5191BE696685FA5A75 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift */; }; + 8BD2A4C9AE40F902D4812AF5 /* SBUBaseChannelSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D856B5EFE6D3EF8B75FCF7F /* SBUBaseChannelSettingsModule.Header.swift */; }; + 8BD60D420559CB35EAFE12B8 /* SBUOpenChannelCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B2C1A70B8458205689EC309 /* SBUOpenChannelCell.swift */; }; + 8C4B9C8E408560BE1835D299 /* SBUOpenChannelCommonContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9735294E73DAE6D3E1FDB33 /* SBUOpenChannelCommonContentView.swift */; }; 8C5D51E16A4E5713FAB8184F /* CustomOpenChannelList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5CAA1A308767FA316ADF24DB /* CustomOpenChannelList.swift */; }; 8C7A16CB5734964F17BE5D01 /* CustomOpenChannelSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2998E5D033EA7F13FC35ECFF /* CustomOpenChannelSettings.swift */; }; - 8C7AA1F7FF6DB74850968478 /* SBUBaseChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74A2D25905D7CC24CCE2D72C /* SBUBaseChannelModule.List.swift */; }; - 8CE94EBFC14835E4D80BC0DA /* SBUMultipleFilesMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 63888E8140CC9FF7B2967F6E /* SBUMultipleFilesMessageCellParams.swift */; }; - 8CF5347EA161D4F37A2EE09A /* SBURegisterOperatorViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45F57E43CFC459BC0A9D2E5C /* SBURegisterOperatorViewController.swift */; }; - 8D334DE25D7D824B45FE9EF1 /* SBUGroupChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74CAA3A0343417CBC00C9A2D /* SBUGroupChannelModule.Deprecated.swift */; }; 8D5D7A00B6854099056721BB /* CustomGroupBannedUserList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C0BD9DADEBEC69A7F8E52285 /* CustomGroupBannedUserList.ViewConverter.List.entireView.swift */; }; - 8DAC02831AB61867EE26A452 /* GroupBannedUserListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1A947D09517B73A703E1A7F0 /* GroupBannedUserListViewConverter.swift */; }; - 8DC4457FD2D80B376928A1B6 /* SBUGroupChannelListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 070A17548A8DF7AF1500579B /* SBUGroupChannelListViewModel.swift */; }; - 8DC71A5EBE84A03C5DC366ED /* UITextField+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 43AAC279DE5780A073B1E21F /* UITextField+SBUIKit.swift */; }; 8DD37B72CEC3828D58E0CD30 /* CustomOpenOperatorList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F248FC8980FA08DAAF78C58 /* CustomOpenOperatorList.ViewConverter.Header.titleView.swift */; }; - 8EF27574E3E0662A41B6A116 /* SBUNotificationChannelManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 677F49AF45920CCFBEB5C009 /* SBUNotificationChannelManager.swift */; }; + 8E43876AFEA9D4B2C4CAC14C /* SBUCacheManager.Image.swift in Sources */ = {isa = PBXBuildFile; fileRef = 07C310E48146C5577ED9FBCA /* SBUCacheManager.Image.swift */; }; + 8E5A8B1632342C3624224529 /* SBUViewLifeCycle.swift in Sources */ = {isa = PBXBuildFile; fileRef = C13060009BC2B7A91C44C6AA /* SBUViewLifeCycle.swift */; }; + 8EE4F68584BB80FA0BBE0126 /* SBUUserListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6EB71BF0445525ACB58EB67D /* SBUUserListModule.Header.swift */; }; + 8F046AB06FDE6D8784E4F615 /* SBUFeedNotificationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = E27105B44C5F51755341A1CF /* SBUFeedNotificationCell.swift */; }; + 8F3CD21218E4FA2DDD4C339C /* GroupModerationsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = A5DD11EC90E6DD9335006B66 /* GroupModerationsView+SubViewBuilder.swift */; }; + 8F3D67420D52E5E004D0F0E9 /* WeakDelegateStorage.swift in Sources */ = {isa = PBXBuildFile; fileRef = DB95C0B594B7B03CE1B623A2 /* WeakDelegateStorage.swift */; }; 8F8C964F6A6C34290DED691E /* CustomCreateOpenChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 757B053477A4E021A04CA877 /* CustomCreateOpenChannel.swift */; }; 903DBFB0B613666FBA5EF8CE /* CustomGroupChannel.SubView.Builder.messageThread.swift in Sources */ = {isa = PBXBuildFile; fileRef = A347D7A83335A9169B69374F /* CustomGroupChannel.SubView.Builder.messageThread.swift */; }; 905947251EB8FEA1FB8D4B1E /* CustomOpenOperatorList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 06BDE87D5391FDB1CC73C1EB /* CustomOpenOperatorList.SwiftUI.View.Main.swift */; }; - 90B2C66740CD90D19674DB52 /* SBUOpenChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5B17D11ADD035FDE1271DBAA /* SBUOpenChannelViewController.swift */; }; + 907FE25370A7D68DB6F0209B /* GroupChannelSettingsViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7244A2B65E75811F309743EC /* GroupChannelSettingsViewProvider.swift */; }; + 9081981B8E347C8838FE1FD6 /* GroupChannelPushSettingsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3BD19FB097E2A1F6DAAE9E96 /* GroupChannelPushSettingsViewConverter.swift */; }; + 908E1F51B723B0F07F4F9CF4 /* OpenChannelRegisterOperatorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F5B10A1CDEC20024D2B59210 /* OpenChannelRegisterOperatorView.swift */; }; 90D18F306C187A47301633AA /* CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A80640594D370683DEF63B03 /* CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift */; }; - 915A00A1A61FEC4D37490114 /* SBUDownloadManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4135695B4B2A78F728C56842 /* SBUDownloadManager.swift */; }; - 921EFBA21BE951E3863281E8 /* SBUUserMessageTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A29D69A7375F3F7BDFEE2D4C /* SBUUserMessageTextView.swift */; }; - 9273A262FCFFEB5BFED22EF6 /* SBUChannelStateBanner.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6D0823820ED006AB5C158A68 /* SBUChannelStateBanner.swift */; }; + 911E9D8A47AA491F63A0C5A4 /* MessageSearchViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 89CAF8C853F289E0DFFD3AE8 /* MessageSearchViewProvider.swift */; }; + 91E5FF686988D3FAC2203152 /* MessageThreadView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2BAFD80BA871EC59725EC7AC /* MessageThreadView+SubViewBuilder.swift */; }; + 925AA726A5F8F8C54F11A033 /* SBUMarginView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A4F262DB37A37F85B936D28B /* SBUMarginView.swift */; }; + 925FD15C21DE8E0DDB025125 /* SBUViewModelDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45DB087B50F9492F21F8C258 /* SBUViewModelDelegate.swift */; }; + 9271A1EE9E96EDC2A9B3D3B8 /* MessageTemplateParserTest.swift in Sources */ = {isa = PBXBuildFile; fileRef = B58B9C60DFDDBFB10FF2737C /* MessageTemplateParserTest.swift */; }; + 92CE5BC278D9D9658BC0880A /* GroupChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1A8DD774054C5168961DF04B /* GroupChannelViewConverter.swift */; }; + 92D37CEF2CC26FE26165A1B2 /* SBUTheme.swift in Sources */ = {isa = PBXBuildFile; fileRef = FCB7E275124DF45ADB981B0E /* SBUTheme.swift */; }; 92E99BC4AAA7EB7B68340E71 /* CustomOpenChannel.ViewConverter.Header.coverImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 787AF9B8933205C26AFCA2CB /* CustomOpenChannel.ViewConverter.Header.coverImage.swift */; }; - 930F1FD0E06245D81E40DCB6 /* MessageSearchView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 074F5995F2755F87CAA18440 /* MessageSearchView+SubViewBuilder.swift */; }; 9341AA9405919C00A939BECD /* CustomGroupChannelList.SubView.Builder.createChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E76196CD8391DE9B46E02A8 /* CustomGroupChannelList.SubView.Builder.createChannel.swift */; }; 935F09EF33F70EB0C4E8B06B /* CustomGroupChannel.ViewConverter.Input.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = BEFE3796A35F972AC95F9705 /* CustomGroupChannel.ViewConverter.Input.rightView.swift */; }; - 9364802D9C9786A05231FF7B /* SBUCacheManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EC18DF4ECCF42C69B1DE4E3 /* SBUCacheManager.swift */; }; + 93A5253A6300B53E76CB790C /* GroupBannedUserListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 485E1BC7A3AB0C82AAE3145D /* GroupBannedUserListView+SubViewBuilder.swift */; }; 93AE4DF8AC715B0D8BB066FE /* CustomGroupModerations.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F4FB5E4998023A160CBFE588 /* CustomGroupModerations.ViewConverter.Header.titleView.swift */; }; - 93BF2059C2DF0F1EC0060562 /* GroupChannelRegisterOperatorViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5A5BD051A6556D060FB89677 /* GroupChannelRegisterOperatorViewConverter.List.swift */; }; - 9451864888CCCDA64A869927 /* GroupChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E08E04B398544D900FCDB10 /* GroupChannelView+ViewConverter.swift */; }; - 9471433D59A65637F27987E9 /* SBUGroupModerationsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 345A88D14A3A5E57A00414FA /* SBUGroupModerationsModule.List+SwiftUI.swift */; }; - 9486242E728DD97805F031C6 /* SBUBaseChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = BC4E1242DCFF67A780DD080B /* SBUBaseChannelViewController.swift */; }; - 949FB57CD1485C0A2C24090C /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = AEB9F6769BE111DFA1D6A0D1 /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift */; }; + 93B9E05C601FD4F43BD9B29E /* SBUModuleSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = CBF25F56D448A252479D1AA3 /* SBUModuleSet.swift */; }; + 93C4C51D9DF7C31CA4AFDD6F /* SBUModerationsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33552F4E4E45108163CF3CAC /* SBUModerationsViewController.swift */; }; + 93D434C8E8B82070B9DFC1FA /* SBUGroupChannelModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 149EF5C6D56F66FA509EA283 /* SBUGroupChannelModule.List+SwiftUI.swift */; }; + 93E4D4F9EA6FA7DA8BBCEB48 /* SBUOpenChannelListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = C6F654B64098E41716C2FE00 /* SBUOpenChannelListModule.List+SwiftUI.swift */; }; + 93F095A77A7496E51241E3AF /* HierarchyScannable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6BBFE7AA481DE52BC6E05814 /* HierarchyScannable.swift */; }; + 945C1C41A6F6A93DE84B5416 /* SBUBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 65443F1247D65F9688EBC933 /* SBUBaseMessageCell.swift */; }; + 945F6D5FA19FAFDF9E93BDB6 /* GroupChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 93D381BEB63BA319C071D9DB /* GroupChannelView+Item.swift */; }; 94A8D20DDDED0E7AC674DC91 /* CustomMessageThread.ViewConverter.Input.voiceButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD9CB8CE7BC4EF75FC02D89F /* CustomMessageThread.ViewConverter.Input.voiceButton.swift */; }; - 950445FB87883797963FFF5D /* MessageThreadViewConverter.ParentInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = EA9A5B0A5DE2C459A65410DC /* MessageThreadViewConverter.ParentInfo.swift */; }; + 94AF8B67250A5FD896285106 /* SBUOpenUserListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2FEFD91414F95FB42FCF2FB1 /* SBUOpenUserListModule.Header+SwiftUI.swift */; }; 951EB3F69A3B963027B88EDB /* CustomMessageThread.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5B80CF8942A9B524589380BF /* CustomMessageThread.ViewConverter.List.entireView.swift */; }; - 95CD32CC30E8BC8C3D47D173 /* SBUConstant.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4C0A2D80C7306781D308DF50 /* SBUConstant.swift */; }; - 960074B411FE7255869C7B94 /* SBUMessageThreadViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 075C4E9CEE0C27B851CD533C /* SBUMessageThreadViewController.swift */; }; - 96542D691531332A9DBA8126 /* SBUPropertyWrapper.swift in Sources */ = {isa = PBXBuildFile; fileRef = D53DD5D59B4099FF2491FD4E /* SBUPropertyWrapper.swift */; }; + 9531B7E14F7278CDB070E582 /* MessageThreadViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 703C05B3B91F19E011CA92B7 /* MessageThreadViewProvider.swift */; }; + 95A7CC65BD2CA6A377D9AA95 /* SBUCreateChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 58158C5B57BBB1219A1A7907 /* SBUCreateChannelModule.swift */; }; + 95C89A9B083F3CE10C6A6E33 /* GroupModerationsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CF9B3D01A792D6AB23816E47 /* GroupModerationsView.swift */; }; + 95CAB95868E0CF0BF12E4BEC /* SBUOpenChannelListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 56DB67FD35B6DC6ABDA4E639 /* SBUOpenChannelListModule.List.swift */; }; + 964F856C0DDD16171FC6858D /* OpenChannelListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2303751640029A1195FA8663 /* OpenChannelListView+SubViewBuilder.swift */; }; 9705E72ED1723E182B038BA7 /* CustomOpenChannelSettings.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9AD7AABB1BA8EA4D43105BD4 /* CustomOpenChannelSettings.ViewConverter.Header.leftView.swift */; }; 972F86B5517BE88F359765E3 /* CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69AA5A484CD6F75C2FB63B42 /* CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift */; }; - 9753354376AA464C7686A373 /* OpenChannelRegisterOperatorView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 868865ED19B43E30C0DCE6BF /* OpenChannelRegisterOperatorView+Item.swift */; }; - 978C78CD1448E70538A47AB8 /* SBUMessageTemplateCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2F7CFF8FDC3CA84CA743B250 /* SBUMessageTemplateCell.swift */; }; + 9748FC4A7522DB0195A108A2 /* SBUQuotedMessageViewProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = 891A4F16527B1283ADACE452 /* SBUQuotedMessageViewProtocol.swift */; }; + 9751FBDD99F592CB96B99D9C /* SBUNavigationTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CA7760618CB22098FFAA5180 /* SBUNavigationTitleView.swift */; }; + 97522EEDE55AD9E175A983EE /* GroupChannelViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF2301F651B24A4E16EFAEA8 /* GroupChannelViewConverter.List.swift */; }; + 975C77F875B47855AA8CD09D /* SBUInviteUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 040FD7FC4D1B4A8EC959975A /* SBUInviteUserCell+SwiftUI.swift */; }; + 97742067DEAA094F37E34920 /* OpenChannelSettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A88F464BAAD90AB84BB13317 /* OpenChannelSettingsView.swift */; }; 978FED43298D0E7AC78726A2 /* CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 315F7B885B880AEE8C60AC67 /* CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift */; }; + 97999D8F0976ACBE224DECDB /* SBUChatNotificationChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = A2A6496F9496B70C0C5DC32C /* SBUChatNotificationChannelViewModel.swift */; }; 97A63E76BDCB65E0EE19C5E4 /* CustomGroupMemberList.ViewConverter.List.operatorStateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1DA1AD0747C09319189DDF68 /* CustomGroupMemberList.ViewConverter.List.operatorStateView.swift */; }; - 97B0D361A9BC7A26A22021FD /* SBUUnknownMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3D5EA770115CE527CEF39044 /* SBUUnknownMessageCellParams.swift */; }; + 97B232653308AF1CE34273F0 /* SBUActionSheet.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5912802D62DB001F7D04659 /* SBUActionSheet.swift */; }; 97CFCF714688D285C159FE9A /* ImagePicker.swift in Sources */ = {isa = PBXBuildFile; fileRef = D42CAF359351D6DB452CD96F /* ImagePicker.swift */; }; - 97D9739924A2824A1BC2A348 /* SBUNewMessageInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 14EB76F7DCFDA115FA759567 /* SBUNewMessageInfo.swift */; }; 97D9CEE9D953652400A9EDEC /* CustomInviteUser.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 61A71254E7A66A77BC11ECA9 /* CustomInviteUser.SwiftUI.View.Main.swift */; }; - 97E17BF2026429BA82CD76C1 /* SBUMentionLimitGuideCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 194EB3991201611697330E0D /* SBUMentionLimitGuideCell.swift */; }; - 97EDD5B5BB072A17441EDD61 /* SBUCommonModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5FB98D6D00677001841E2CD1 /* SBUCommonModule.swift */; }; - 9864666F137B4E39C81300D8 /* SBUMessageTemplate.Coordinator.swift in Sources */ = {isa = PBXBuildFile; fileRef = 01554179DBF097DA7646B2AE /* SBUMessageTemplate.Coordinator.swift */; }; - 988B779C6CFD4268F45260E3 /* GroupChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = FE6750636605238BA0E244C8 /* GroupChannelViewConverter.swift */; }; + 981CDDC9AE02CB03306BA22B /* OpenModerationsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 17D4DB776814E712BA3D522E /* OpenModerationsView+Item.swift */; }; + 985DC2B0D76F7C2DA401706C /* SBUGroupUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = DAA4591A42376EF2D300B7CE /* SBUGroupUserListUserCell+SwiftUI.swift */; }; + 985DC6B75BF2E4950B007E7D /* MessageThreadView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 80277CCA8CD14E420F5CE34B /* MessageThreadView.swift */; }; + 989798AC7122EDCF7DA308BF /* SBUBarButtonItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2AF37FB8A55745647820E475 /* SBUBarButtonItem.swift */; }; + 98B9324E525A1611FD031F15 /* GroupChannelSettingsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E86E99F56BC13D21BFEBE68 /* GroupChannelSettingsViewConverter.List.swift */; }; 98BF33D0A2D0375BE3519482 /* CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1CB771DC92339EE331D47DBD /* CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift */; }; - 9909715615D788746045692B /* GroupOperatorListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 64E89D9B931EADFB789516A6 /* GroupOperatorListViewConverter.swift */; }; - 9924714A0BD418EE3C24A082 /* GroupChannelListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15D0C93348560E6639D9887F /* GroupChannelListViewConverter.swift */; }; - 99390EC5AC1E4BEA3E0B4D20 /* SBUChannelTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F7BC78603E390AB17CF9BE14 /* SBUChannelTitleView.swift */; }; + 98C21D5C393D3BE562A0297A /* SBUFormViewParams.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7955E39023C81688202CE6AE /* SBUFormViewParams.Deprecated.swift */; }; + 98CCA32E71C6724A69DFD8BA /* SBUMessageSearchModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 602FB0E64CCDD3B8406812D1 /* SBUMessageSearchModule.Header+SwiftUI.swift */; }; + 9918FE4EEE6E752361D552C2 /* QuotedFileCommonContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 82266B325AF8EC3539D27C56 /* QuotedFileCommonContentView.swift */; }; + 999ABD0598A4E41292F8F7F8 /* MessageSearchViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0FD1533E6A37B61095F3D3F8 /* MessageSearchViewConverter.Header.swift */; }; + 99B3B251DA5CE47373F11D55 /* SBUConfig.OpenChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15BCA0CEA4BD6AC0AF9F5E93 /* SBUConfig.OpenChannel.swift */; }; 9A02F5F85B2DBF76CB370FCD /* CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 83402211DD8882C43D58382D /* CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift */; }; + 9A2D8C01B76AB936691B443F /* SBUTypingIndicatorMessageManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 58AB877B3077DBE7EC520DBE /* SBUTypingIndicatorMessageManager.swift */; }; 9AA20681A925727F2780D495 /* CustomMessageThread.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E9388E235D8F81710908610F /* CustomMessageThread.ViewConverter.Header.titleView.swift */; }; - 9AD10F667C4A981B820D2B44 /* SBUGroupChannelSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = CB21C648253FAC1AE4DF7C2A /* SBUGroupChannelSettingsModule.List.swift */; }; + 9AAD286A1633798C510D70C4 /* UIColor+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8016144176E0D68BC050E151 /* UIColor+SBUIKit.swift */; }; 9AD9034FB564A881750D9345 /* CustomOpenChannel.ViewConverter.List.adminMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 172802894396063C49F84236 /* CustomOpenChannel.ViewConverter.List.adminMessageView.swift */; }; - 9B6807A3F5EEFB63B8B64837 /* SBUGroupChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C83ED8F2CAA20B762F4F5B6 /* SBUGroupChannelViewModel.swift */; }; + 9AFC2DF88D531002F954E169 /* Date+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 24F167651C8FE9886C4D02D6 /* Date+SBUIKit.swift */; }; 9B9EBFB4BB3907CAD661AA00 /* CustomGroupMemberList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C4E395239704CB0253A0C036 /* CustomGroupMemberList.ViewConverter.List.entireView.swift */; }; 9BD4E711B9989AB357319E9A /* CustomGroupChannelPushSettings.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9C9D481CEACE14D2726C302D /* CustomGroupChannelPushSettings.SwiftUI.View.Main.swift */; }; - 9CCDE637E3E78AEB62D9527F /* SBUBaseCarouselView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7697BCB63E99D1CDCF94905 /* SBUBaseCarouselView.swift */; }; - 9CF1526115B690E80FF83442 /* SBUGroupChannelSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 459A13CFDD327E9181AE2F5F /* SBUGroupChannelSettingsModule.Header.swift */; }; - 9D06928EE947D643BD788DD1 /* SBUMessageSearchViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = A6CD877BF4F75C3CE545D26F /* SBUMessageSearchViewModel.swift */; }; - 9D393C3437FF919AA8AE763C /* SBUVoiceContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0B78A78B3EEDCE40DFDFD34 /* SBUVoiceContentView.swift */; }; - 9D3D7D814993C8AC7B7D5E04 /* MessageThreadViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 487AD77A600D4D0BAC851314 /* MessageThreadViewConverter.List.swift */; }; - 9D56300DA705AA133E877DE1 /* OpenParticipantListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2051F6EC7AA67803BA3D91FC /* OpenParticipantListView.swift */; }; + 9C747C5E2F5C360322DADF09 /* CreateOpenChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0409D70B90128508F58134CF /* CreateOpenChannelView+Item.swift */; }; + 9CEE3F03D7428180C46396FF /* SBUUser.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A7FF2619B41D30553554AC0 /* SBUUser.swift */; }; + 9D24AFA3A8ACB3620B2A858C /* SBUNewNotificationInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 058F7755FCA9CC99DBB5B468 /* SBUNewNotificationInfo.swift */; }; 9DBFEAA8AE68EC9DE4208BB6 /* CustomGroupModerations.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7546B04F2B673FBE23B4578B /* CustomGroupModerations.SwiftUI.View.Main.swift */; }; - 9DCBC61C17B73DBD921AE8BA /* UINavigationController+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0B58422C8C6BDC4A3B19315 /* UINavigationController+SBUIKit.swift */; }; - 9DE8D8FDC524B09710FD7C27 /* OpenMutedParticipantListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 78E601DC9E72E49D4C69FCA1 /* OpenMutedParticipantListViewConverter.Header.swift */; }; + 9E32572DAC5785DCC6616732 /* SBUInviteUserModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B53F3FCA6C01FAB50776850 /* SBUInviteUserModule.Header+SwiftUI.swift */; }; 9E391034B1E23D2D48382F88 /* CustomCreateGroupChannel.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 371A733CC45A9696DEBF8F79 /* CustomCreateGroupChannel.ViewConverter.Header.rightView.swift */; }; 9E43AF5A8D46E8D0E8C4C683 /* CustomMessageSearch.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5BED13B61170536763801B04 /* CustomMessageSearch.swift */; }; - 9E4D6F9813E0F1F9C55182D5 /* OpenChannelRegisterOperatorViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = DF1E9EBB5C80F9BC517456A1 /* OpenChannelRegisterOperatorViewConverter.Header.swift */; }; - 9E599AC42738008C9653577A /* GroupModerationsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 534BB97DAD333885A76085C0 /* GroupModerationsViewConverter.List.swift */; }; 9E5C1DA2D08A2926305DD189 /* CustomSampleManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = C09C8C6CEC68C15036518EF9 /* CustomSampleManager.swift */; }; - 9EC3D1808000E0D1BDE892B4 /* SBUBaseChannelSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 43CA6787E4A3A782EE75B313 /* SBUBaseChannelSettingsViewController.swift */; }; - 9F09F0918B8855435C8201F8 /* SBUFeedbackAction.swift in Sources */ = {isa = PBXBuildFile; fileRef = 89F0ABB7E53466D01AC02983 /* SBUFeedbackAction.swift */; }; + 9E8FC63E9DA69207A233C5CF /* SBUStringSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0C3FA638C505A1130D29CB79 /* SBUStringSet.swift */; }; + 9EB93409B98FF75A35D29D02 /* SBUFeedNotificationChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = F3B52DE1481E7DCF5E9A0B11 /* SBUFeedNotificationChannelViewModel.swift */; }; + 9F77C728DC49F47B631A8C81 /* CreateOpenChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4E179F88E8C865DA3B3C80BD /* CreateOpenChannelView+SubViewBuilder.swift */; }; 9F8A055BCA334A858540EDF6 /* SendbirdChatSDK in Frameworks */ = {isa = PBXBuildFile; productRef = 3802DE3DF80A82DD3E77A925 /* SendbirdChatSDK */; }; 9F963EC1FB888312F704D8EF /* CustomOpenChannelList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AA7E85539CE0E5423736D18E /* CustomOpenChannelList.ViewConverter.Header.titleView.swift */; }; - 9F9BDDC6E6384E06A8BE2D71 /* SBUGroupUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 887F4EC72B8FC7D81D7886DB /* SBUGroupUserListUserCell+SwiftUI.swift */; }; - 9FCDF683381D89D80DB2F4B4 /* GroupMutedMemberListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5B7E3DDD69211B9214A0A24D /* GroupMutedMemberListView+Item.swift */; }; - A0329DB9194171E53643D399 /* SBUMessageThreadViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = B90AEFF358A26F1593707117 /* SBUMessageThreadViewModel.swift */; }; + 9FB795B410EFF663AA5AAAE0 /* SBUHighlightMessageInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = B1E9D76A5720F7B7C9B6AA55 /* SBUHighlightMessageInfo.swift */; }; + 9FBDD5BF5BA4586B3C97114C /* OpenChannelSettingsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AB39B9F7C19B2CB08F1D83F /* OpenChannelSettingsView+SubViewBuilder.swift */; }; + 9FCAD0A25F06AC7DE1FB8E08 /* SBUModerationsViewModel.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1CAA39A852B107E285CE001B /* SBUModerationsViewModel.Deprecated.swift */; }; + 9FF53CDF8DA213BC1591FD03 /* SBUMessageFormSingleTextItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 48BB97FD2509104396ED0E43 /* SBUMessageFormSingleTextItemView.swift */; }; + A01A69C6219122DAF5402109 /* SBUMessageThreadModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6BF5A66B08808CCFBEC2C60A /* SBUMessageThreadModule.List+SwiftUI.swift */; }; A0442BD86F36659653E0E50F /* OpenChannelsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2402CB59A675E428278E27B6 /* OpenChannelsView.swift */; }; - A17A9E7D5853718EBC0D6896 /* OpenOperatorListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1FDD8BBDA06606723A4BD18E /* OpenOperatorListViewConverter.Header.swift */; }; - A1DD53553857C3F92780C556 /* MethodOverridable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3B10E73347B487AE2FBA2806 /* MethodOverridable.swift */; }; - A22A1FD41E8191F4B8DB7B7E /* SBUOpenChannelSettingsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 88E58F4FBC5A015D68518FC5 /* SBUOpenChannelSettingsModule.Deprecated.swift */; }; + A0472607F46D2B12C431E318 /* SBUOpenChannelModule.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = 92074159434417ECFA4275EE /* SBUOpenChannelModule.Input.swift */; }; + A18151C9932C6695D180A853 /* SBUCommonModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 41F67E3AB37F20407F559B51 /* SBUCommonModule.swift */; }; + A1A17DC4B0D017AAC7967C36 /* SBUCreateChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 37343538D25A799C84E3BAE4 /* SBUCreateChannelModule.List.swift */; }; A2401A29EA167C199C27E028 /* CustomMessageThread.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = EC5D44A320DBE9B8DB580423 /* CustomMessageThread.SwiftUI.View.CustomMain.swift */; }; A24911C84E3D1EF28D6BA00B /* CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 02C174E7957338B3F8329B36 /* CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift */; }; - A24923CE6B533A8BF0480F8E /* SBUTheme+Type.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE7B5B27FFA176D18D23171C /* SBUTheme+Type.swift */; }; - A27C3C995A735C4EC8F17B54 /* SBUCreateChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 06A44B20FC2EFB44267D2F6F /* SBUCreateChannelModule.swift */; }; - A305A9100DCB76480046B0E1 /* SBUFileMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7AD2BD448D02C9A9B551AA86 /* SBUFileMessageCellParams.swift */; }; - A31F753F8F96C521381AEA67 /* OpenModerationsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = E672677E26CA7ADF545827E4 /* OpenModerationsViewConverter.Header.swift */; }; - A33BF99AFD866E7F77E633DC /* SBUGroupMutedMemberListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = F996C7F4D29C1645E1465E33 /* SBUGroupMutedMemberListModule.List+SwiftUI.swift */; }; - A44CD72AB2BE7F02D8EFEB89 /* SBUOpenChannelMessageWebView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F8581D84EDC1F269B235F2B2 /* SBUOpenChannelMessageWebView.swift */; }; + A2FFDF9BF98C367994572B63 /* GroupChannelProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = CD3F95DAB17E94241A3A1355 /* GroupChannelProvider.swift */; }; + A306E8898D0C3999C52E3676 /* SBUGroupChannelListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 151589C04C2127E51ABCF91D /* SBUGroupChannelListModule.Header.swift */; }; + A32E16AF72CAE96B107D470C /* SBUChatNotificationChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5C733994D9E30A3D2126469E /* SBUChatNotificationChannelModule.Deprecated.swift */; }; + A388AC432F87F16EDA9D7A89 /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 068D92AC2E455E1FB045B5EE /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift */; }; + A3939070EE33F6952B446FA6 /* MessageThreadViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 13DE9BE7EA1E8EA4077C9689 /* MessageThreadViewConverter.List.swift */; }; + A3A26CCE760C24CD75C5E071 /* SBUBaseChannelListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4ABAFA861BDEB0E2B5E08C64 /* SBUBaseChannelListModule.List.swift */; }; + A42F4EB37662F040D1951E75 /* SBUFeedNotificationChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7592610FC6E821A878F88582 /* SBUFeedNotificationChannelModule.Header.swift */; }; A465F00A70A21F02A988B7F5 /* CustomGroupChannel.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4CB4F955DE8A98683A194DEE /* CustomGroupChannel.ViewConverter.Header.rightView.swift */; }; - A4666E9905B5691E1F2AFD98 /* SBUOpenChannelListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = F35CD8BA9042B97652CACABA /* SBUOpenChannelListViewModel.swift */; }; - A4677726C13987128860A646 /* UIScrollView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = CC6D68CE2E93880EB54D12ED /* UIScrollView+SBUIKit.swift */; }; - A4718FA92012A938757A27D0 /* GroupChannelRegisterOperatorView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 735AEA7FB06A451F8F5B3226 /* GroupChannelRegisterOperatorView+Item.swift */; }; - A489FD72ADA4FEC1F14C4A4D /* SBUParentMessageInfoReactionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 39A7437156C34F88C39E223D /* SBUParentMessageInfoReactionView.swift */; }; - A49918C6E3E8144F5F9CEF44 /* SBUPendingMessageManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E39C7F475F05E20458F1D7C /* SBUPendingMessageManager.swift */; }; - A4A0F3C22D0BC90F05BEB267 /* OpenBannedUserListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 57F7C0D861D9733D927D60AB /* OpenBannedUserListView+SubViewBuilder.swift */; }; + A47B683FB720EE947E60AEB0 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = ACE0161330623767B0B22AEA /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift */; }; + A4B9AAE7FC00153957A17A93 /* CreateOpenChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5C1F0FC94BD67FFF13DCA583 /* CreateOpenChannelViewConverter.Header.swift */; }; A4F42AA1B1B8308AC052A2FA /* CustomCreateOpenChannel.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A908A59131B410EF958EC4F5 /* CustomCreateOpenChannel.ViewConverter.Header.rightView.swift */; }; - A5007E989C75C7974CF99B13 /* OpenBannedUserListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = FDE68F5000CAD06B280FC70C /* OpenBannedUserListView.swift */; }; - A51EF1957CD733EDC8655511 /* SBUOpenChannelTitleView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 997DCDD73BE218FE6620854B /* SBUOpenChannelTitleView+SwiftUI.swift */; }; + A4FA58B4BD13E6AC259878AC /* SBUEnums.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 36DB7771E34A27FE3507F0DE /* SBUEnums.Deprecated.swift */; }; + A506D73584E27E0A8FF1E953 /* SBUReactionsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3D65D7A80A375918D8B0EB9F /* SBUReactionsViewController.swift */; }; + A51C40101CBE93E05BF95481 /* GroupModerationsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5F7BEBBF660496309A703D82 /* GroupModerationsViewConverter.List.swift */; }; A5321F7776FAB918814A637F /* CustomCreateOpenChannel.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB93B3DEC8E153D6A8BFC160 /* CustomCreateOpenChannel.SwiftUI.View.Main.swift */; }; + A57649F9E4A8974F1A374329 /* SBUStringSet.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D7F84D65D12CFD5BD192CE8 /* SBUStringSet.Deprecated.swift */; }; + A5766120AA2BC59813883C58 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B2BC4EA3D8CE0C395D945CF8 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift */; }; A5852413BF1411566CD19A01 /* CustomTheme.IconSet.Custom.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = C8B010F0771DB55B89DB52D6 /* CustomTheme.IconSet.Custom.Main.swift */; }; + A59074FB7F583D580D028A92 /* SBUMessageTemplate.Syntax.Views.swift in Sources */ = {isa = PBXBuildFile; fileRef = 63C9E6ECE987D0D1AAE72330 /* SBUMessageTemplate.Syntax.Views.swift */; }; + A59B5B7C75731CCA2E7667B0 /* SBUQuoteMessageInputViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 195059F9729364314EB88550 /* SBUQuoteMessageInputViewParams.swift */; }; A5A1421B2D3848529C8C3EF0 /* CustomOpenChannel.ViewConverter.Input.sendButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0FC471844F62DAC68F852859 /* CustomOpenChannel.ViewConverter.Input.sendButton.swift */; }; - A5AF0DBD410F34451E7816A2 /* SBUFeedNotificationChannelViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = D7863D6531C9EAA4341984F9 /* SBUFeedNotificationChannelViewParams.swift */; }; A5D30D1E9252794B2110F7D5 /* CustomGroupMemberList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = ADDB752428A84A635510D867 /* CustomGroupMemberList.ViewConverter.List.profileImage.swift */; }; - A5E62E8AF5FDF66ECCD728EA /* SBViewConverterSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8AF20B71046B6D5FF0174268 /* SBViewConverterSet.swift */; }; - A5F5BCC030E063972F5048C0 /* SBUOpenOperatorListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4966B4B124FA577795A56523 /* SBUOpenOperatorListUserCell+SwiftUI.swift */; }; + A5ECD7407BE4BC3F516F1E84 /* SBUExtendedMessagePayloadCustomViewFactory.swift in Sources */ = {isa = PBXBuildFile; fileRef = BDD4EB3C929D559F5D0D624E /* SBUExtendedMessagePayloadCustomViewFactory.swift */; }; + A612018F4F6F6812C42F980A /* Closure.swift in Sources */ = {isa = PBXBuildFile; fileRef = F28B6B09EF78A29A92725BD6 /* Closure.swift */; }; A61A5C740501AB32A8BAB423 /* CustomGroupChannelSettings.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FC9ADF39DE854D50970224F /* CustomGroupChannelSettings.ViewConverter.Header.titleView.swift */; }; A672916EDFB4A22782306946 /* CustomGroupChannelSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 62CC4972B032D9F6EE874436 /* CustomGroupChannelSettings.swift */; }; - A6A41AE98F1073A58BE69B8F /* SBUMultipleFilesMessageCollectionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C70D83A51D1811A88B0C140E /* SBUMultipleFilesMessageCollectionView.swift */; }; - A6BABA616C94F2318FCBB6F0 /* VoiceMessageStatus.swift in Sources */ = {isa = PBXBuildFile; fileRef = 37663F0868F7387F231EF23F /* VoiceMessageStatus.swift */; }; + A6C3683CC473BEB177D53449 /* OpenChannelSettingsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C33B727B28009C968BDF9B6 /* OpenChannelSettingsViewConverter.swift */; }; A6CEF242B3095406389A8D7D /* CustomOpenChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0CC325811E3058B01772942 /* CustomOpenChannel.swift */; }; - A6F20177C90E39CE5A5C7962 /* SBUUser.swift in Sources */ = {isa = PBXBuildFile; fileRef = 739741AE05C182B289832616 /* SBUUser.swift */; }; + A6DD3777FCBE43236A2D2C47 /* SBUDownloadManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ADEBE78ECAF2FB8B6CD1A96 /* SBUDownloadManager.swift */; }; A6F4398621EC964E5B7A32A6 /* CustomGroupBannedUserList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2232894B6B82C593EACB9AF8 /* CustomGroupBannedUserList.ViewConverter.List.rowView.swift */; }; - A7880ED8BBF33F205C224AA2 /* SBUGroupChannelViewController+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7BB35A201ABF5E46615916B /* SBUGroupChannelViewController+SwiftUI.swift */; }; - A7E5E3820B1BCA5799F39EA4 /* SBUOpenChannelListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0DA777F44C7DE5F2768375B6 /* SBUOpenChannelListModule.swift */; }; - A80D13A1BEBDC0D06CE6E3E3 /* SBUView.Unavaliable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7F311E6823137533AF24741B /* SBUView.Unavaliable.swift */; }; + A7EEBF3F64F0F8A74752E505 /* OpenOperatorListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 88D5604351DFC4004002856A /* OpenOperatorListViewConverter.swift */; }; A80D1CA9116C8DD5CDC3F564 /* CustomGroupChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = C35485398319DEEEC3845442 /* CustomGroupChannel.swift */; }; - A8442E5704D1B8751F61D7E6 /* SBUFeedNotificationChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 70A996C0178CC5216BCB2EBE /* SBUFeedNotificationChannelModule.Deprecated.swift */; }; - A84C5278F00A995B3E357AEC /* SBUMessageTemplate.Syntax.Aligns.swift in Sources */ = {isa = PBXBuildFile; fileRef = CBD4AF9A5A39CD6EB954C272 /* SBUMessageTemplate.Syntax.Aligns.swift */; }; - A8B6751568500B27EFEE7A4D /* GroupOperatorListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D8F39143F890265770E857F8 /* GroupOperatorListView.swift */; }; + A813DE7327B146C9A9A5676C /* SBUUserListModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4A8338A02D18FC23E595C05A /* SBUUserListModule.Deprecated.swift */; }; + A88E7548C11E04317EE9D855 /* GroupChannelRegisterOperatorViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = ECE0E78C0DE00AD12F25AC49 /* GroupChannelRegisterOperatorViewProvider.swift */; }; + A89FFCEE168C76530C9E6502 /* SBUSuggestedMentionList.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF68890BEBB702CC9ED09C98 /* SBUSuggestedMentionList.swift */; }; + A8AF3B5E826BEFF5A71245A8 /* SBUSuggestedReplyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9E78C28530EB42B33B68C3C6 /* SBUSuggestedReplyView.swift */; }; A8BA2BA3DE72F4C375AAA8C4 /* CustomGroupChannel.ViewConverter.List.channelStateBanner.swift in Sources */ = {isa = PBXBuildFile; fileRef = 26EECBA4BF71E97955C63A32 /* CustomGroupChannel.ViewConverter.List.channelStateBanner.swift */; }; A8D0975BB10FF02B9AA77C44 /* CustomSampleManager+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0243B0EFB1BAEE1DD4F5B8FB /* CustomSampleManager+SwiftUI.swift */; }; - A9629CEFC1BE5FB0C453702B /* SBUMenuView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 838C450577B1005585D4F38E /* SBUMenuView.swift */; }; - A9908A0A0107340580C68CBA /* SBUCreateChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 79E91C43DF36F6D0CADBE2D3 /* SBUCreateChannelModule.Deprecated.swift */; }; - A9956F5640BBEACF104D1F0F /* StringProtocol+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2C593374BB12107EC560C715 /* StringProtocol+SBUIKit.swift */; }; - A9C0F58134C8FA628F88BAA0 /* GroupModerationsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 486F991ADBCD134649F89781 /* GroupModerationsView+ViewConverter.swift */; }; - A9DFF415083CC11BFE3AB50F /* SBUMessageSearchModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 49511A48940E5542A4C0F5FD /* SBUMessageSearchModule.swift */; }; - AA28E77662FB06CD946F95C2 /* SBUMessageTemplate.Payload.swift in Sources */ = {isa = PBXBuildFile; fileRef = 26E081F853537DD71E0BC25F /* SBUMessageTemplate.Payload.swift */; }; - AA9DEF50B43F0317117EE784 /* OpenChannelListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 24B1972F020FD19FB7A7E8D8 /* OpenChannelListViewConverter.swift */; }; - AACEEB29943236CFDCD0C4C8 /* OpenChannelListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 361AEE3CF32E940D61DDCF69 /* OpenChannelListView.swift */; }; - AB245877579C021A382803F8 /* SBUMentionConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9774EC4FF0EB6B296E4A2731 /* SBUMentionConfiguration.swift */; }; - ABE339EB7B283F5586A58AD1 /* GroupChannelSettingsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = C00284E6199B018EE7B11AC7 /* GroupChannelSettingsView+SubViewBuilder.swift */; }; - AC2F3589344FEEBC2A540BD7 /* SBUUserListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85C17FF5923CE7EA65775A6E /* SBUUserListModule.swift */; }; + A8D5F71FEA78EC29BABCF451 /* SBUChannelPushSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4CDA371C83E2F67518C3A760 /* SBUChannelPushSettingCell.swift */; }; + A956D8EBFB89FF3310507B02 /* SBUAdminMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 73D6FC69CD89388D9ACC5B71 /* SBUAdminMessageCellParams.swift */; }; + A97BA713BA19DB9E55E30B18 /* SBUCreateChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74FC80676ADF1E7D30B25C8E /* SBUCreateChannelViewModel.swift */; }; + A9B2A574729B61CCBA4A6908 /* SBUNewMessageInfo+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C1EBEBB49DB9D9129545F68 /* SBUNewMessageInfo+SwiftUI.swift */; }; + A9CD60BC674C032FF02F6D95 /* GroupChannelPushSettingsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = D2A9680190548D628D0D71B0 /* GroupChannelPushSettingsView+ViewConverter.swift */; }; + AA2CE74FA3344DC91B5F0046 /* CreateOpenChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4AF0897805380BAF7AD8859C /* CreateOpenChannelView.swift */; }; + AB38B7A496B8637A29331FF3 /* SBUMessageTemplate.PayloadType.swift in Sources */ = {isa = PBXBuildFile; fileRef = DDFD71AA835A87908EFEEAF0 /* SBUMessageTemplate.PayloadType.swift */; }; + AB84A187B143A2965E92D9DA /* SBUGroupChannelSettingsModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85DF9F68E38AE6BBA2DE35BE /* SBUGroupChannelSettingsModule.Deprecated.swift */; }; + ABCA7C46182351476744F40C /* GroupChannelPushSettingsViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2282B01F493BF02C9708B2F8 /* GroupChannelPushSettingsViewProvider.swift */; }; + ABCE864F5372FCC8C609C77B /* SBUOpenChannelListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D1138C0CF644F604A4DB6BEA /* SBUOpenChannelListViewController.swift */; }; + ABF3FE1455979C3B736DDC1A /* SBULazyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7F737D0DF3D80BAE69165E99 /* SBULazyView.swift */; }; + AC4F13963A037B90CBD034FC /* OpenChannelRegisterOperatorView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A7B7E1E88F1115AD78191C3 /* OpenChannelRegisterOperatorView+Item.swift */; }; AC50BE096ECD36CDDEBB194D /* CustomGroupModerations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4510D73D64979A14389411B5 /* CustomGroupModerations.swift */; }; - AC7DEE4A7DB6C68B1859C8E7 /* UIImageView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD7AC31657ED213E32ECBD42 /* UIImageView+SBUIKit.swift */; }; - ACB2B91137FA560631B8E21C /* UIImage+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1286E9C8A5FDC69006356104 /* UIImage+SBUIKit.swift */; }; - AD6DFEFE2891B862C59ADE1B /* SBUNavigationTitleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B882C20E663ED48B5ED6D4A7 /* SBUNavigationTitleView.swift */; }; - ADA3CB1273F6228F305040A1 /* View + ViewModifier.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2D485B6D4BF580481E4D1D72 /* View + ViewModifier.swift */; }; + AC523E807AE951B214E773DB /* SBUBaseChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4792A2ADDCEE5FE657BA8AC7 /* SBUBaseChannelViewModel.swift */; }; + AC6DA27873A79F456DDB2C92 /* SBUGroupOperatorListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B2F84327611A02AD862FBF50 /* SBUGroupOperatorListModule.Header+SwiftUI.swift */; }; + ACA20BE3B7ECBF135B0D3BE8 /* SBUInviteUserModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D84CAF6C762506B85F584E6 /* SBUInviteUserModule.List.swift */; }; + AD5A82348CABF8286ADA4387 /* SBUMessageFormMultiTextItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A94FC79DD966BE57D3D864FE /* SBUMessageFormMultiTextItemView.swift */; }; ADE9EBB541FC71F1F25E5C3D /* CustomOpenChannelSettings.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D627C22FA33DADBCD007F40D /* CustomOpenChannelSettings.ViewConverter.Header.rightView.swift */; }; - AE015039EA61BB1F24C79EDA /* MessageThreadView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45F6A63D5390117FA882CE43 /* MessageThreadView+SubViewBuilder.swift */; }; - AE1845C068922DF20545BB70 /* MessageThreadViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9C2574D3E04FB26DBF76ED58 /* MessageThreadViewConverter.swift */; }; - AE6CC1744A48FB93D24F8544 /* SBUOpenUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 03998A9F377AFFC6FB0E69BA /* SBUOpenUserListModule.List+SwiftUI.swift */; }; - AE74C43D92832880B75FEC9B /* SBUGroupBannedUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 95DB32CF54500BF7F04B6482 /* SBUGroupBannedUserListModule.List+SwiftUI.swift */; }; + ADEDFD3D4867535940B03384 /* SBUIconSetType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 66D12454623DEC0547534C5F /* SBUIconSetType.swift */; }; + ADF43FD9D04373D6A9AD61AE /* OpenChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 418C7FD54C888F55739A45F5 /* OpenChannelView+ViewConverter.swift */; }; + AE59386CBB3F7D8B9C0D502F /* SBUOpenModerationsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0C51254CEED3C799BECECBBA /* SBUOpenModerationsModule.Header+SwiftUI.swift */; }; + AE7E327DE6B29650FDBC9FB2 /* OpenParticipantListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68438B681D10DDC232C3D9B4 /* OpenParticipantListViewConverter.Header.swift */; }; AEA5D95F169E48B4D7D89411 /* CustomGroupChannelList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52351ED09B63E5E5FE1EE827 /* CustomGroupChannelList.SwiftUI.View.Main.swift */; }; - AEF46BD164C362CD5EBF9465 /* SendbirdSwiftUI-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = 377CB683EA76DA82E16E556A /* SendbirdSwiftUI-Info.plist */; }; + AEF0C3B8FA3F9DFB7A4D7D98 /* SBUUnknownMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 65327F0DFF20C899672B90BB /* SBUUnknownMessageCellParams.swift */; }; AEFFDC8D114E5D8840877C81 /* CustomGroupMemberList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F34DA7D7D4B2985E294981E7 /* CustomGroupMemberList.ViewConverter.Header.titleView.swift */; }; - AF20C220160DCC107926F516 /* SBUGlobals.swift in Sources */ = {isa = PBXBuildFile; fileRef = A8B980032E44E8D2CD11B79A /* SBUGlobals.swift */; }; - AF83514E03BDB74C06340303 /* SBUFormFieldView.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = FCD53856699176A2A465111B /* SBUFormFieldView.Deprecated.swift */; }; - AFB7CB7B79CF3807A64F52E3 /* SBUDebouncer.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4A95670973E944B4C3A95416 /* SBUDebouncer.swift */; }; + AF0BC7C82BB194D6588FC701 /* Color+Sendbird.swift in Sources */ = {isa = PBXBuildFile; fileRef = 40DBB14AD71744BD8B995B4F /* Color+Sendbird.swift */; }; + AF0D44D6DEB7F76342B76230 /* SBUVoiceMessageInputView.swift in Sources */ = {isa = PBXBuildFile; fileRef = FC3E876887601735308273D9 /* SBUVoiceMessageInputView.swift */; }; + AF2DF5A3F86C80F4CED1ADE0 /* OpenChannelListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = C7A7A445786CDA239FC3A495 /* OpenChannelListView+Item.swift */; }; + AF6961C39F74BAFE2562893A /* SBUOpenChannelTitleView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B490A5163E0F31829523A88C /* SBUOpenChannelTitleView+SwiftUI.swift */; }; + AF6A17136172808D92BF29E7 /* GroupOperatorListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A5B8F101D680AC30270B59D /* GroupOperatorListViewConverter.Header.swift */; }; + AF87064353739448B4371C09 /* SBUUserMentionConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 581E25EA40DF49EBAA0142FE /* SBUUserMentionConfiguration.swift */; }; + AFAAEB57805DBE7DC88EA690 /* OpenParticipantListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = F9287770F82C83D551563531 /* OpenParticipantListViewProvider.swift */; }; AFBC68E1B521FEA3FE3C5891 /* CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = F60F28A03D242FFB2D615190 /* CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift */; }; - AFD355B4DADBB95C7411FC98 /* SBUMessageThreadModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 07B875B23CC937172B1A0557 /* SBUMessageThreadModule.swift */; }; - AFD48BD36352900AF6B964D5 /* MessageThreadView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB042AC39230E43C6B58A32E /* MessageThreadView+ViewConverter.swift */; }; - AFEF62DD6CD4464AA4687B82 /* SBUScrollOptions.swift in Sources */ = {isa = PBXBuildFile; fileRef = B3AEA60115A8DACD156EFE14 /* SBUScrollOptions.swift */; }; - B0B3EADA0ACFE07ACAD2A89A /* SBUQuotedBaseMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6BFEDEA0282EC80B5682BC6B /* SBUQuotedBaseMessageView.swift */; }; + AFD0135CCA41FEAA88B08D2F /* MessageForm+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2F648AC1BF4B63CC9EDF30CF /* MessageForm+SBUIKit.swift */; }; + AFE884D58BBBA0E0DDA0318D /* InviteUserView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = F1211AAEFCC66ABDC646D834 /* InviteUserView+SubViewBuilder.swift */; }; + B0C25591651A78C1816F9893 /* SBUGroupChannelModule.Input+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = CBFB50A8249F3AF8106E3D7E /* SBUGroupChannelModule.Input+SwiftUI.swift */; }; B11DFF996C8B40C236E5167A /* CustomOpenModerations.swift in Sources */ = {isa = PBXBuildFile; fileRef = 02676C1FF2C5DD89C779D257 /* CustomOpenModerations.swift */; }; - B172261CD25AC117AEC18668 /* SBUGroupChannelCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE2A55A25B370F6C8ED56E24 /* SBUGroupChannelCell.swift */; }; - B21B643C3844046E8C438632 /* CGSize+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = D9C0E0D304969F74F95F6857 /* CGSize+SBUIKit.swift */; }; + B1341030A8607D803824FF7A /* SBUGroupChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 34ED39256240C5DA35BDC807 /* SBUGroupChannelModule.Header+SwiftUI.swift */; }; + B134DD826C7E0B90F2585736 /* SBUOpenChannelModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = EBF7F15698BF3AB2B7C0B92A /* SBUOpenChannelModule.List+SwiftUI.swift */; }; + B17DC93AB903620508167E1F /* SBUMessageFormItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 928D1849A1BC6DB24E431C92 /* SBUMessageFormItemView.swift */; }; + B1C294C82A0ED7345B0DECF8 /* GroupMemberListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 02860979E56EFC1AF779C802 /* GroupMemberListView.swift */; }; + B1DA5D4CF8DBEFE857E7A7C3 /* SBUOpenChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6956509D6C57F140F2A819D9 /* SBUOpenChannelViewModel.swift */; }; + B1EA03591DEFF9EDAAE593E3 /* GroupOperatorListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5CFCDF4354C150EB6E4EC7E9 /* GroupOperatorListView.swift */; }; + B1F6791421A548C309C24103 /* SBUBaseCarouselView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 661B774DC02837911A7CDA4C /* SBUBaseCarouselView.swift */; }; B23A3526D56637FE944C44B5 /* CustomGroupMutedMemberList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 025010882A64A7618C401C16 /* CustomGroupMutedMemberList.ViewConverter.List.rowView.swift */; }; - B279902A41FCE05DA0D03EFF /* GroupMemberListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2F5596CBB3FB434BE59F8BBA /* GroupMemberListView+Item.swift */; }; B27BA50D96C21A0BB77AFEAC /* CustomGroupChannelList.SubView.Builder.groupChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2443ED212D4BF7E2A647104F /* CustomGroupChannelList.SubView.Builder.groupChannel.swift */; }; - B29DA0496FF6163137BB240A /* CreateGroupChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3CC0923742309FAE95E55C98 /* CreateGroupChannelView+Item.swift */; }; - B30F51F42C6CF85C18B52825 /* SBUCommonItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = A2195C8048CCBEB921EA8954 /* SBUCommonItem.swift */; }; - B32A953FFB19CD707CFE455B /* SBUMessageTemplate.Renderer.swift in Sources */ = {isa = PBXBuildFile; fileRef = C096565785A1E150A95D7572 /* SBUMessageTemplate.Renderer.swift */; }; + B2ABAE2CFC3FC3ACE24E784B /* SBULayoutableButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 517DCACCA8CAB496DAE1FE65 /* SBULayoutableButton.swift */; }; + B2C3F62C2CD9741A4D00D8D6 /* SBUGroupChannelListModule.Common.swift in Sources */ = {isa = PBXBuildFile; fileRef = AED99943C6CCB04E8DB46AE5 /* SBUGroupChannelListModule.Common.swift */; }; + B2DE7C0B76B706DF4898A6F7 /* SBUViewModelSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 948D0930539618E949CE2D4C /* SBUViewModelSet.swift */; }; + B39B1F447C795BB4874DB28F /* SBUChannelStateBanner.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3EBF8DBA8CDA504642F81845 /* SBUChannelStateBanner.swift */; }; B3A2F65A58B64BD8A8906B37 /* CustomGroupOperatorList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5DBA3FA486B355A6F23DFD00 /* CustomGroupOperatorList.ViewConverter.List.rowView.swift */; }; - B3B97510A6BF0998BDA9F2AE /* MessageSearchView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C32AC3ABF480C0D62322AE3B /* MessageSearchView.swift */; }; - B41BEC11C0A54A6D241D2404 /* HierarchyScannable.swift in Sources */ = {isa = PBXBuildFile; fileRef = BA4A079F4D61BE349D534EDE /* HierarchyScannable.swift */; }; - B46C80C656E74A6DF282DF8F /* OpenChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F0E3B57CD4297BB82C8C616 /* OpenChannelView+ViewConverter.swift */; }; - B4761F82F3CED19B2045303B /* GroupChannelRegisterOperatorViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6F5B7BEEA70A8811267E7236 /* GroupChannelRegisterOperatorViewConverter.Header.swift */; }; - B49340B1138D31ACA4902A70 /* GroupModerationsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5697F9AAD564890A973256A /* GroupModerationsViewConverter.Header.swift */; }; - B52A1894069B72DED9E05620 /* SBUOpenChannelListModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D6849B7606ADDACDDF87569 /* SBUOpenChannelListModule.Header.swift */; }; - B52FBFE95A63654DC0E0771A /* SBUQuoteMessageInputViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = FF616B484BF9E87795017EA1 /* SBUQuoteMessageInputViewParams.swift */; }; + B4114B6E30FB7F2A58AC3928 /* SBUBaseChannelSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0FD503C5B7F8CDFB80C1888F /* SBUBaseChannelSettingsModule.swift */; }; + B444015B4802605B95FC0DA9 /* SBUStackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AEA53AA4E09C4C797BD87EE /* SBUStackView.swift */; }; + B4C210205F10E991AD9075E3 /* SBUBaseChannelSettingCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = C5A04F4ED104E23B61B85318 /* SBUBaseChannelSettingCell.swift */; }; + B50A83F7E4EA51F580069745 /* OpenChannelRegisterOperatorViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = FFFBB3032630028580441A41 /* OpenChannelRegisterOperatorViewConverter.List.swift */; }; + B52788A2901F6128B2076AC3 /* SBUFormFieldView.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 424A582E4E59F6FC3F368ABB /* SBUFormFieldView.Deprecated.swift */; }; B5EB3735F2726ACB5E388378 /* CustomMessageThread.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 537F956A3C96A94FB5F01B34 /* CustomMessageThread.ViewConverter.List.rowView.swift */; }; - B602F92B8400E475E0DAAEB5 /* SBUGroupChannelListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 81C92F68E1188BB0A7CB863C /* SBUGroupChannelListModule.List+SwiftUI.swift */; }; + B5F14B579862C764BC790C3A /* SBUBaseSelectUserViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = FDA3D3D02D5E297D699CD2C2 /* SBUBaseSelectUserViewController.Deprecated.swift */; }; + B5FC50AEDDA9828762003305 /* OpenChannelSettingsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = C5DDEFBCE4985FC09EB4B6D2 /* OpenChannelSettingsView+Item.swift */; }; B60AB9B4EDB4F19205BE4B58 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 905A88DC20838A94B21B3544 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift */; }; - B60EF43F2157D33F313C8D70 /* SBUOpenChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = EFF7F3AFE50A393A18343E1D /* SBUOpenChannelModule.Header.swift */; }; - B658DE87280EDB22AD2ED2CC /* String+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9816C55DCB0A7ED877604B1F /* String+SBUIKit.swift */; }; - B67D370DFEDBCEAD82A46151 /* SBUIconSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = B51FC07C5EB09E0C69628EA0 /* SBUIconSet.swift */; }; - B6F73763A07267A4DAE5E2A4 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B1A85D27D8C3E08D0B4BF1C9 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift */; }; - B703E602A7AAA0A75B12C829 /* SBUBaseSelectUserModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9DBA21B0C820B120DABD7BF3 /* SBUBaseSelectUserModule.swift */; }; - B7166941961D1B94400DE836 /* CreateOpenChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 28404C050D7E597FB4DF7837 /* CreateOpenChannelView+SubViewBuilder.swift */; }; + B65F35ECA4F3F6A7A7F68E69 /* GroupChannelPushSettingsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 76BBE5BEB476721101C05579 /* GroupChannelPushSettingsView+SubViewBuilder.swift */; }; + B6776383DE9AAA81EA0BD868 /* SBUOpenChannelBaseMessageCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = FF107290F4EB7C3FAD727570 /* SBUOpenChannelBaseMessageCell+SwiftUI.swift */; }; + B694EC442D0171B5EE6E3B02 /* SBUMessageTemplate.ImageRatioType.swift in Sources */ = {isa = PBXBuildFile; fileRef = F00384B1EF32956E18353B90 /* SBUMessageTemplate.ImageRatioType.swift */; }; + B6AB46E57719FD3967ACFB7A /* SBUConfigManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3B7B872CDDEDEEA89964760E /* SBUConfigManager.swift */; }; + B78E2FBB68188E9E662E6049 /* BaseMesssage+SBUIKit.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AD34F85878574D07C59C493 /* BaseMesssage+SBUIKit.Deprecated.swift */; }; + B7A67CF17A2BC21DD001D094 /* UIImageView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3FEA7B7C415546F22E63FEFE /* UIImageView+SBUIKit.swift */; }; + B7DB4D2480F0217ED10A74E5 /* SBUGroupChannelSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9FD0291F032A293A68F16270 /* SBUGroupChannelSettingsModule.swift */; }; B7FE1F59DB85F9C20723079B /* CustomMessageThread.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3E8E19A98FD114729EFA3A9E /* CustomMessageThread.SwiftUI.View.Main.swift */; }; - B8993551EFC15564A51C3F79 /* SBUGroupChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A07FD82926848554C43ABB5 /* SBUGroupChannelModule.Header.swift */; }; - B8B4BF3CECA35D68ADF7A315 /* SBUOpenChannelBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = E0A690A691FBFFFB1EA46385 /* SBUOpenChannelBaseMessageCell.swift */; }; - B8D722C5D220AE5E67987F60 /* OpenChannelRegisterOperatorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 57E9486AE7A3DA69D14C2B1F /* OpenChannelRegisterOperatorView.swift */; }; - B90B393ED6F9C556DC4ADE50 /* SBUGlobals.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 505C2553E67C0C1CDDE626B2 /* SBUGlobals.Deprecated.swift */; }; B9252B353B5561297E7DB544 /* CustomSampleSubViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 534F2E4ED993A0EB9AE192C4 /* CustomSampleSubViewModel.swift */; }; B935796C35E88B4B78ECDB96 /* MySettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = DAD98D54B19D973D5419D595 /* MySettingsView.swift */; }; - B98A0058F9918F9157C03A68 /* SBUBaseChannelListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B82B55E310D26E3DD9E67834 /* SBUBaseChannelListViewController.swift */; }; - B992CEB2B4C62A6A3FC62385 /* SBUTheme.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = F3D7ECABBD13ECA6EDB56017 /* SBUTheme.Deprecated.swift */; }; - BAB3E05D8911CB8AD0EFA300 /* CreateOpenChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = CEC51145218937994CD7E226 /* CreateOpenChannelViewConverter.swift */; }; + B95CDAA702A32D053DEE96B4 /* OpenChannelListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = DBE77CA1AA32061F0B89F310 /* OpenChannelListView.swift */; }; + BA4D55F28A21CED586FC2142 /* SBUBaseChannelSettingsViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0B305731A8CE51649B82676 /* SBUBaseChannelSettingsViewController.Deprecated.swift */; }; + BA52BAF30C192E824DF2680E /* SBUInviteUserModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15269264474C5B46CF1910BE /* SBUInviteUserModule.List+SwiftUI.swift */; }; BAD47705CBB51CAB0DD635B7 /* CustomMessageSearch.SubView.Builder.groupChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4F5A3BE9830FFE3F5AD5F422 /* CustomMessageSearch.SubView.Builder.groupChannel.swift */; }; - BB0749D100B16A2E27D771EF /* SBUCoverImageView.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B26FE8DE186569C5BEFC548 /* SBUCoverImageView.Deprecated.swift */; }; - BB0F042568FEF1D71417AC9F /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D75561E0F23994F2D54F02A /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift */; }; - BB28F057F39AF3F0542A9A37 /* GroupMemberListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 72BDBA680E4964489D1BCDB5 /* GroupMemberListView+SubViewBuilder.swift */; }; - BB84A1C1CD85F146B5D46626 /* SBUToastView.Internal.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F45FA38BF21FE277B770348 /* SBUToastView.Internal.swift */; }; + BB253B4C99A3EF6539011459 /* SBUMessageTemplate.Syntax.Styles.swift in Sources */ = {isa = PBXBuildFile; fileRef = 58251BF056C682C010BEDD4D /* SBUMessageTemplate.Syntax.Styles.swift */; }; + BB6A4D1F004CF64D3FF5BDD8 /* GroupOperatorListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = CCF1C1BAB1FCE4DA3FADC95C /* GroupOperatorListView+SubViewBuilder.swift */; }; + BB7683674F03AE5F9A3784B5 /* SBUUserListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 44C1DB413EA8CE674D33B63E /* SBUUserListModule.List.swift */; }; BB88C92EDDF3082699F39EF2 /* CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0B8430A4C57FC0EDD8A68A3F /* CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift */; }; - BBDA611B8615DB9582B73AC2 /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5ECC1263CB743FBD32569570 /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift */; }; + BBBA781D851EB6290446E909 /* OpenModerationsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = C61C960E362565B1258C1530 /* OpenModerationsView+ViewConverter.swift */; }; + BC7B461A310DEE879E224D85 /* SBUQuotedBaseMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0C7DB64BF6C562A80283A7E6 /* SBUQuotedBaseMessageView.swift */; }; BCAF0F5BD7716DC7ED5476A0 /* CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 94FCA597D446778ABB141E6D /* CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift */; }; + BCBBAD59C9D31BE03EA7CC63 /* SBULinkClickableTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB2CBA09DA24007F0E5C877F /* SBULinkClickableTextView.swift */; }; + BCE8437AE06CB19FEDD03501 /* CreateOpenChannelViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2881A84C01CB255EE1976829 /* CreateOpenChannelViewConverter.swift */; }; BCF57D1F1A3B07D44AD7AD24 /* CustomCreateOpenChannel.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8B87B3AF55303D34FB171AF6 /* CustomCreateOpenChannel.ViewConverter.List.rowView.swift */; }; - BD2F982C9CA605F747407620 /* GroupChannelSettingsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = D47B80C8F70B7B35CB44832C /* GroupChannelSettingsView+ViewConverter.swift */; }; - BD6080969BB3E78B1ED0C952 /* SBUMessageInputView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AEAE4D3A35CB4AE694FB592 /* SBUMessageInputView.swift */; }; - BDE73C3C5B5901C89B7749B2 /* SBUStackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CC66BFE52B21FA2B30AE8E30 /* SBUStackView.swift */; }; - BDF9A8DE063A5D26AD903A5A /* SBUMessageFormFallbackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D23CE29CE2785C1F89E0FE88 /* SBUMessageFormFallbackView.swift */; }; - BEA54478E13DAC0FB099126F /* SBUTypingIndicatorMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A0B27BB4D8B2F159844A77BF /* SBUTypingIndicatorMessageCell.swift */; }; + BD1447DFAE8EC51F287CDBF0 /* InviteUserViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = F406B0CC701411F859F4934A /* InviteUserViewProvider.swift */; }; + BD4FCEF79F02239658DDE0F1 /* CreateGroupChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB3EA7BE88661E3E98BC2085 /* CreateGroupChannelViewConverter.Header.swift */; }; + BD78CDDE8476EBD510911D70 /* GroupModerationsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = C08C818F7E03C3CC838DCED3 /* GroupModerationsView+Item.swift */; }; + BDA937E14112A6694081A51A /* Collection+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 10D4FAE80AC3E74AA8159C06 /* Collection+SBUIKit.swift */; }; + BE40DE4B5FA2E30C80A00064 /* SBUOpenChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F05697C440446392E577719 /* SBUOpenChannelModule.Header.swift */; }; + BE805271B9F890151B99CD01 /* SBUFeedNotificationChannelModule.CategoryFilter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D2D5DF994BB70E9CCF42022 /* SBUFeedNotificationChannelModule.CategoryFilter.swift */; }; + BE9CD4E2054189F5833D98C3 /* OpenOperatorListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = A37A5AFCDE39921B45147472 /* OpenOperatorListViewConverter.List.swift */; }; + BE9EB03BCE0271ABE232AE7B /* SendbirdUIProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9D66F6F4842608E7545438C6 /* SendbirdUIProvider.swift */; }; BEA61A98C3197318CB54E1F3 /* CustomOpenOperatorList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D6086A2472531DE282E4A98 /* CustomOpenOperatorList.ViewConverter.Header.rightView.swift */; }; BECC583E161FDC7F9FB35264 /* CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = D1BE7FE947E6F68414C95978 /* CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift */; }; BEDD418913F7CB0A3E26AD8C /* CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 266967BFCE2D21AC989E71CD /* CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift */; }; BF0ABB57B96304CA62FC7B86 /* CustomOpenChannelList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C19B7801E10F35318619EB84 /* CustomOpenChannelList.ViewConverter.List.entireView.swift */; }; + BF0FA5920391E0C76F500286 /* SBUCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DC2A8DE6A8BFEB20D40A60BB /* SBUCollectionViewCell.swift */; }; BF2B7CAC42EA0639130BC60E /* CustomGroupChannel.ViewConverter.List.adminMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7B792924F253C665E1B57733 /* CustomGroupChannel.ViewConverter.List.adminMessageView.swift */; }; + BF44B13C27389915301FAC9E /* GroupChannelListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4E2B56441DCC9C595481F9EE /* GroupChannelListView+Item.swift */; }; BF66786E33466193FFDD4F48 /* ViewModifiers.swift in Sources */ = {isa = PBXBuildFile; fileRef = 670879B256200596D8546552 /* ViewModifiers.swift */; }; - BF6BC0EFDA8F015F66A42EAC /* GroupMutedMemberListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55B4B36852330960D9BC5260 /* GroupMutedMemberListView.swift */; }; - BF7A9954C040ECF3504A060C /* SBUGroupChannelListViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = F5787B281C37A19736CD8A8A /* SBUGroupChannelListViewController.swift */; }; - BF842E30D9F0A7E0DC16AC4C /* OpenChannelRegisterOperatorView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2B3BA29A37C81D499E354EB4 /* OpenChannelRegisterOperatorView+ViewConverter.swift */; }; BFB1739811A45EB3CD06AD35 /* CustomOpenModerations.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D1728A93ADAD5C8498316FD /* CustomOpenModerations.SwiftUI.View.Main.swift */; }; + BFBB9B2EDB48DD75A4C3614A /* GroupChannelSettingsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 28A2E22DD48A106F4586D002 /* GroupChannelSettingsView+ViewConverter.swift */; }; BFBEB5C01D06BDC341012E40 /* CustomOpenParticipantList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E4D74430CD9A8CE3A3F23515 /* CustomOpenParticipantList.ViewConverter.Header.leftView.swift */; }; - C09141874B287303763DDA1E /* SBUBaseChannelCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DE2C77128576368219B73147 /* SBUBaseChannelCell.swift */; }; + BFC78F2763ED79A041F3728E /* SBUFileViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 604F608DA839B7F04E684A40 /* SBUFileViewController.swift */; }; + BFE819978A355FCE61AB1FD8 /* MessageTemplateTestViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 40F3DF712CD31E46942D4A03 /* MessageTemplateTestViewController.swift */; }; + C008B5E6FD93235F644F336F /* GroupOperatorListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4A3FA47B606D666AD9E97938 /* GroupOperatorListViewProvider.swift */; }; + C00C9CAB781ACDABF47D4BC3 /* Float+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 73F0DFB46EDBD5F62F209CC9 /* Float+SBUIKit.swift */; }; C09B955DC76B823375844240 /* CustomOpenChannelList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 71C09802CE6CAD970683DDF3 /* CustomOpenChannelList.SwiftUI.View.CustomMain.swift */; }; - C0AA20C06FD343A6F73718A4 /* OpenChannelListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 47DF5589BE90ED973DB7F67A /* OpenChannelListViewConverter.List.swift */; }; C0AFA77C70AE4B2E550904EA /* CustomOpenOperatorList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 92B86E09449B7AC165C14297 /* CustomOpenOperatorList.ViewConverter.List.entireView.swift */; }; C0CB3CC019AF2745925B2130 /* CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD83A8BF2B08D10F438C21C0 /* CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift */; }; C0E13908AD7C621E12937715 /* CustomGroupOperatorList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 78F2D06B939DB1E99B1DFFFF /* CustomGroupOperatorList.ViewConverter.List.entireView.swift */; }; - C0F5E06887431A6BCCAA41B7 /* SBUCacheManager.NotificationSetting.swift in Sources */ = {isa = PBXBuildFile; fileRef = C0DDF27516D888B54EA2559D /* SBUCacheManager.NotificationSetting.swift */; }; - C13B2A363F14DFD04FE0B172 /* SBUConfigManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F27A78EE60A93797E010244 /* SBUConfigManager.swift */; }; + C13105058293FDCEFE9C18F8 /* SBUGroupChannelListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = BA937CAFFBDC2CAC0FE00664 /* SBUGroupChannelListModule.Header+SwiftUI.swift */; }; C1AD677B18E5AAA391EDE7B1 /* CustomGroupOperatorList.SubView.Builder.registerOperator.swift in Sources */ = {isa = PBXBuildFile; fileRef = DF7D3CD441496E8922807E30 /* CustomGroupOperatorList.SubView.Builder.registerOperator.swift */; }; - C207DC73361FA2B44E7B1870 /* GroupChannelRegisterOperatorViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8063BA0912F07F52734489F8 /* GroupChannelRegisterOperatorViewConverter.swift */; }; - C20B2977DDD5BF1DACBC39CE /* SBUGroupOperatorListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3F45F78119195BA9C15B4B18 /* SBUGroupOperatorListUserCell+SwiftUI.swift */; }; - C293FDB62B3980DDAEDF4C79 /* HandlerSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = A43C491A5F4F3DC54D841EB5 /* HandlerSet.swift */; }; - C311F7EF246404831952FCDF /* SBUTemplateLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2667B362F8DD00A36E0A5C00 /* SBUTemplateLabel.swift */; }; - C31DBF49FA64FCC89FA68D67 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5612F8CEF1CBD9C4CD18E21A /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift */; }; - C36FB367C9654AC67A3FAECF /* SBUMessageSearchModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = B3B7DF2B3CBE003069677711 /* SBUMessageSearchModule.Header+SwiftUI.swift */; }; + C1E25E9625B7832E644A6B61 /* HandlerSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 775497373156080C786EFFA9 /* HandlerSet.swift */; }; + C1E6CD32A54E001AD7A32C1B /* SBUHorizontalSuggestedReplyOptionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2D8E1428454BAB2823888AD1 /* SBUHorizontalSuggestedReplyOptionView.swift */; }; + C256F24886A7C814FCE83A6C /* OpenChannelSettingsViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 18C1C60E4B404A088689D1E8 /* OpenChannelSettingsViewProvider.swift */; }; + C2F8461748B49BA4C211BB2F /* OpenChannelRegisterOperatorView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 278A681D06BDAF42A5A4A6D6 /* OpenChannelRegisterOperatorView+ViewConverter.swift */; }; + C315D49E7D1B47CFE7AF9E92 /* SBUBaseSelectUserViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2689FD4A0398FE01DD24BCF2 /* SBUBaseSelectUserViewController.swift */; }; C3A9A271E2516F49D9239AEC /* CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3A9945722AA9B595F601541C /* CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift */; }; C3DC02272E0D7812CCD7478D /* CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 21CB4AD0ED1AB4BA1550A685 /* CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift */; }; + C40D2C394689B54254702D99 /* SBUTheme.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = E42AB4882426DF1FBE40A612 /* SBUTheme.Deprecated.swift */; }; C41BCB8D6BE5A18F7C8A6772 /* UserNotifications.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1AF8CB593FE2D4951A3ED114 /* UserNotifications.framework */; }; - C42B4656DE7E6CDA051816B7 /* SBUInviteUserModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = C09A08CA49DDC01557C7D096 /* SBUInviteUserModule.swift */; }; - C4C05BC8629DD4511D1985CB /* BaseMessage+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = C589684819C0917EE5FC82DE /* BaseMessage+SBUIKit.swift */; }; - C513788D72B5B3755E77C999 /* SBUConfig.Common.swift in Sources */ = {isa = PBXBuildFile; fileRef = 56C6B35A7D7A8F45805DE891 /* SBUConfig.Common.swift */; }; - C5286BDA534892079A304057 /* SBUScrollBottomView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 740FE6FE5E6D2566C92D0CD8 /* SBUScrollBottomView.swift */; }; - C5732121655B28735339013C /* SBUTableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D3679B4B2C92ABF5A1CF56 /* SBUTableViewCell.swift */; }; - C6EE61C38C7751AC1FE367E5 /* SBUMessageTemplate.Syntax.Views.swift in Sources */ = {isa = PBXBuildFile; fileRef = FAC8E79C1FEAE3685E293243 /* SBUMessageTemplate.Syntax.Views.swift */; }; - C737EE6B654D97918352E7C1 /* SBUMessageTemplate.Renderer+Events.swift in Sources */ = {isa = PBXBuildFile; fileRef = 344AF01876274CF324237E4D /* SBUMessageTemplate.Renderer+Events.swift */; }; - C7410A1AC1A83ED4777BB93B /* QuotedFileCommonContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8403312D3345AA5154DF81D1 /* QuotedFileCommonContentView.swift */; }; - C77A7F907D674791B6263F68 /* GroupChannelRegisterOperatorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5A01B459C79535912AC488C /* GroupChannelRegisterOperatorView.swift */; }; - C7B4A469263B7A3EF08E68C3 /* SBUOpenChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = A9E52D0CF1A2746B74AE93F2 /* SBUOpenChannelModule.List.swift */; }; - C7BD726B7EEB46493DD1B96A /* SBUOpenModerationsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 14693ACB733109628B1E5244 /* SBUOpenModerationsModule.List+SwiftUI.swift */; }; - C8554510A3ADE4D044956D14 /* OpenModerationsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = C2DC6AC36C13CF9CE994D450 /* OpenModerationsView+Item.swift */; }; - C85E092257EAF0E31F3205AD /* SBUCacheManager.File.swift in Sources */ = {isa = PBXBuildFile; fileRef = 88E0D73102E23DDE1DAEDDF0 /* SBUCacheManager.File.swift */; }; - C8A06DF4347E630C56F1C374 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = AF66DF02B81CE8EF19BF9BF0 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift */; }; - C8D6966D1D8C1D504F2D6FA9 /* OpenParticipantListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0669C29C318DE47185F6859E /* OpenParticipantListViewConverter.List.swift */; }; + C477AACF553B28BEF3426651 /* SBUEmojiManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 464ADCD317DBEB46993B86DD /* SBUEmojiManager.swift */; }; + C502F906CDCA0EBE28686637 /* SBUParentMessageInfoView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 05EDD8753FC63FAB2F6E8EA5 /* SBUParentMessageInfoView+SwiftUI.swift */; }; + C50643A3484C62BDF5EC2CDB /* CreateOpenChannelView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 92F8C302415A0DA76BAE7815 /* CreateOpenChannelView+ViewConverter.swift */; }; + C513A8D06ED083B5C6F8526A /* SBUOpenChannelInputView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 35B171FF6F71B428F421E126 /* SBUOpenChannelInputView+SwiftUI.swift */; }; + C52BD4EBC048E6A9FDC781AE /* SBUGroupUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 746CB9D65D9BE7AEACEE55C9 /* SBUGroupUserListModule.List+SwiftUI.swift */; }; + C58B40F708F225481E6B9D17 /* MessageThreadViewConverter.ParentInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = B966D1C78F8A4D306FD0172A /* MessageThreadViewConverter.ParentInfo.swift */; }; + C58CC900E4D3FC4ACA86E071 /* GroupChannelSettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 62364A595D53A0543706D2F9 /* GroupChannelSettingsView.swift */; }; + C5FBDF91DA19A26BC978B002 /* URL+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7DF47B235A5C5712180E6232 /* URL+SBUIKit.swift */; }; + C60D583881525033B4E97782 /* GroupMutedMemberListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = A17C46E3441DE12806ABD160 /* GroupMutedMemberListViewProvider.swift */; }; + C61EF824B8C0026A3FFB1BED /* OpenBannedUserListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 54077061A5C0CB8EE8DA4AB7 /* OpenBannedUserListView.swift */; }; + C71CBE14ED22A9E5854DFE8D /* SBUOpenUserListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6CAACF7915BF5F47DF2D444E /* SBUOpenUserListUserCell+SwiftUI.swift */; }; + C7AE89F613479689E310F254 /* SBUMessageThreadModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = DC5F4EF470234F308512D764 /* SBUMessageThreadModule.Header.swift */; }; + C82C113F59D0BB346ADE62B6 /* SBUVoiceContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F49E6F0696729061F88BAF0C /* SBUVoiceContentView.swift */; }; + C880AB65922F91959C306FF2 /* SBUMessageStateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F52098C95DFA4A3CBB23C61B /* SBUMessageStateView.swift */; }; + C8A3717E5A8103BFB79EE99F /* SBUMessageWebViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0CC15B4BBE65B13E5DCABD99 /* SBUMessageWebViewModel.swift */; }; + C8D1518D38A52164CEE1CEDF /* UIImage+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = D3A937118732EBE90BC48E80 /* UIImage+SBUIKit.swift */; }; + C91278C982153C5CB9EAD826 /* OpenMutedParticipantListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E24797172C62D7225E0F118 /* OpenMutedParticipantListViewConverter.swift */; }; C920BB4E0790D12BD899A222 /* CustomCreateGroupChannel.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9B6511EB77591FAA9ECA0604 /* CustomCreateGroupChannel.ViewConverter.Header.titleView.swift */; }; - C92800E91681A1906102B807 /* SBUExtendedMessagePayload.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19A3BDA35036947D712CB9E1 /* SBUExtendedMessagePayload.swift */; }; - C99EB14D4264EB0C586ECE12 /* SBUOpenChannelViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B0C7AD67D264A3CACBF0A24 /* SBUOpenChannelViewController.Unavailable.swift */; }; - C9DE77AA383EB03A89B52F34 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9B6A113CC7CEC6C224ED5D07 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift */; }; + C9CE8F6CD847D0BC2C574D10 /* SBUMessageFormFallbackView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5AB54402454B883CCD6CBD01 /* SBUMessageFormFallbackView.swift */; }; C9EAE6D0611296C0D346EAB3 /* CustomGroupChannelSettings.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = B7434B1BB34EE7822565BE8A /* CustomGroupChannelSettings.SwiftUI.View.Main.swift */; }; - CA3C67CF1BAB3F8FCB7A1F84 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 41DF87515C28078D54D8ED88 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift */; }; - CA4C607C9E77CF3E9C9CEE5F /* SBUOpenChannelImageContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 61007D0CB510FD7CDC121AC9 /* SBUOpenChannelImageContentView.swift */; }; - CB0FF3446B81180AB9C2E198 /* SBUGroupChannelPushSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 076B76458F2B9617C69FB28E /* SBUGroupChannelPushSettingsViewModel.swift */; }; + C9EDCF465087330DE28357F8 /* OpenOperatorListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5C466E8AD49DF599AB343FA3 /* OpenOperatorListView+ViewConverter.swift */; }; + CA2CBB4AFC5EDE22ED94C2F9 /* NSObject+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5B8D919D29518C330D50223 /* NSObject+SBUIKit.swift */; }; + CA6C733C11200AB1BFC3F227 /* SBUGroupOperatorListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 97AA2A602830838B5F8BFF85 /* SBUGroupOperatorListUserCell+SwiftUI.swift */; }; + CAD5634D9186CE5B8CE63350 /* SendbirdSwiftUI-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = E2ADEA87D2CD1937FE761A55 /* SendbirdSwiftUI-Info.plist */; }; CB14EB0FDE990BE026C021E8 /* CustomInviteUser.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5A7879949AFA1239627B000A /* CustomInviteUser.ViewConverter.Header.titleView.swift */; }; - CB605F99D4F0E4569359BEE3 /* SBUOpenChannelSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4558C00951E40E0BFB0ADB26 /* SBUOpenChannelSettingsModule.List.swift */; }; - CB67A3634CE05B28F746BA2B /* CreateOpenChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = A8F1B86B8E65954C7AA1988C /* CreateOpenChannelView+Item.swift */; }; - CB73E4A2F4AF7F919F17C6F2 /* OpenParticipantListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 844456744940B60FACF05B17 /* OpenParticipantListViewConverter.Header.swift */; }; - CB79774F4E6C31EDA48E7E8A /* SBUMediaView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 94B6B99EE4914E2736C8042C /* SBUMediaView.swift */; }; + CB7D95A81730FC2FA35B99AD /* SBUMenuSheetViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6869251780957A520939FB48 /* SBUMenuSheetViewController.swift */; }; + CB9F986AD0DA4AEB83EC304A /* SBUCreateChannelModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7C7E57B3E69531C17273C791 /* SBUCreateChannelModule.Deprecated.swift */; }; + CBEC8D8DCCF1A458603C7671 /* SBUQuoteMessageInputView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C26C7227DB3F3D547F68EFB0 /* SBUQuoteMessageInputView.swift */; }; + CBF3472829482C53F2FF07C4 /* OpenMutedParticipantListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = E073AA8CC1B9D07D58D24E07 /* OpenMutedParticipantListViewProvider.swift */; }; CC83BD52CB82859C6A303EAA /* CustomOpenParticipantList.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D1ADCD8B486C3D101AA4CBF8 /* CustomOpenParticipantList.ViewConverter.List.entireView.swift */; }; - CD8EAA5E713598B43E0B0126 /* SBUBaseFileContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 32F2AF6630757800DFF08628 /* SBUBaseFileContentView.swift */; }; + CCC5B6680B47D013BD6F289B /* OpenBannedUserListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8FEB3D3A0A4B95348451722F /* OpenBannedUserListView+SubViewBuilder.swift */; }; + CCE9F1723767764548D89129 /* SBUChannelSettingItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 587C70B610EC30D8522A8304 /* SBUChannelSettingItem.swift */; }; + CD2A900FCA92FC6EDBA0924A /* SBViewConverterSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2664B443F513C3E12BD8C350 /* SBViewConverterSet.swift */; }; + CD3E56FA953A20E2F612942F /* InviteUserViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 94086D052C1DD45734B45C9B /* InviteUserViewConverter.List.swift */; }; CDA9D1D2585C9A748C9A6271 /* CustomMessageThread.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1FB96424E98E120EA6E8856A /* CustomMessageThread.ViewConverter.Header.leftView.swift */; }; - CDCDABD02719862BE557A3C2 /* SBUOpenChannelFileMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 016BAC75334B9EECCCDCC68B /* SBUOpenChannelFileMessageCell.swift */; }; - CDD1D698BE1522649678E640 /* SBUMessageThreadModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = A9F80A10E0E12E6B550927F7 /* SBUMessageThreadModule.Header.swift */; }; - CE8A540833324BF9FB4A3906 /* OpenOperatorListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = E3BB215085699F6E89FF3F5D /* OpenOperatorListView+ViewConverter.swift */; }; + CDE670D72972D89F6135D56D /* GroupMutedMemberListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = B48E2BC784CAFA265679C530 /* GroupMutedMemberListView+Item.swift */; }; + CEB27644D5A809454035EEF4 /* SBUBottomSheetController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 77572D02FFF2252D6380AA76 /* SBUBottomSheetController.swift */; }; CEFDCBCD63215345E8693249 /* CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = ABF9555C752DF6B69AC2BB56 /* CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift */; }; + CF200F52BBCED2E61A620142 /* UIFont+Sendbird.swift in Sources */ = {isa = PBXBuildFile; fileRef = 11DF0BD15A442817BB746609 /* UIFont+Sendbird.swift */; }; CF2EA89ED0B299A06FA94095 /* CustomOpenParticipantList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 533FBEB0CF02D20487819307 /* CustomOpenParticipantList.ViewConverter.Header.titleView.swift */; }; - CF664360605D0FBD20E77476 /* SBUCreateOpenChannelModule.ProfileInput.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15E7A0A982529296BD896B07 /* SBUCreateOpenChannelModule.ProfileInput.swift */; }; CFE96F351CAA858F355089DB /* CustomOpenParticipantList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2BD3F92049FFA549EE2A62ED /* CustomOpenParticipantList.ViewConverter.List.rowView.swift */; }; CFF408133CDD3D4F8217D2B7 /* CustomTheme.Theme.Custom.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3AE47348615AD3C64FA1FDAA /* CustomTheme.Theme.Custom.Main.swift */; }; D00BDA4DD7B17A84D49EFD95 /* CustomOpenChannelList.ViewConverter.List.channelPreview.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D7977F8BBB275731E11BE34 /* CustomOpenChannelList.ViewConverter.List.channelPreview.swift */; }; D00EBD058B6290476424286D /* CustomGroupChannel.ViewConverter.Header.coverImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1D38AA27BCCE944F35F787E7 /* CustomGroupChannel.ViewConverter.Header.coverImage.swift */; }; - D0161EAD1D4B16A02139A84D /* MessageThreadViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3575D8324F8DCEC741A02E9C /* MessageThreadViewConverter.Header.swift */; }; - D01F0F1DD3A5CD13D0460014 /* SBULazyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6FDEE72ED520123188DB93FF /* SBULazyView.swift */; }; - D0B9BCABF4D8E0174A29C3C7 /* SBUMessageFormSingleTextItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = BE7259CA31206A469BB51C25 /* SBUMessageFormSingleTextItemView.swift */; }; + D0547F6D251988A8EA4C079B /* SBUMessageTemplate.Coordinator.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0BCBB1C66BF4FFB629BFCDF1 /* SBUMessageTemplate.Coordinator.swift */; }; D105B90AD27E4A1D177141B2 /* CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D44ADE8F289364F71D86202A /* CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift */; }; + D108B194A79177A0E5886692 /* GroupMutedMemberListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8D48DFD3FF62BE218F62CA2C /* GroupMutedMemberListViewConverter.swift */; }; D130BC83D31456C9DADF559F /* CustomGroupModerations.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EDE250657479E5DFC57BEF3 /* CustomGroupModerations.ViewConverter.Header.rightView.swift */; }; D15448A2AFC32086A87FD72D /* UserDefaults+Ext.swift in Sources */ = {isa = PBXBuildFile; fileRef = BB75D9350081AF38A4FAA594 /* UserDefaults+Ext.swift */; }; - D160881E23EA2CE56DD3056A /* SBUOpenChannelListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6B76B6E8F8E888984DE91EAA /* SBUOpenChannelListModule.List.swift */; }; + D1A3D8B42F5939F1619D5A36 /* SBUGroupChannelViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 00E512AA6538A2C054A5F952 /* SBUGroupChannelViewController.Unavailable.swift */; }; + D1CB8CA45AFBC1AB83DE141E /* SBUFeedNotificationChannelViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45AE9457F2764E673A9408D9 /* SBUFeedNotificationChannelViewController.swift */; }; + D1E55CD604D66C28A09F5F21 /* SBUToastView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 198F31B87E693C7FA29E1A38 /* SBUToastView.swift */; }; D1ECE51EB97035BAAF2ED355 /* CustomGroupChannel.ViewConverter.List.senderProfileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 21145BF3F3E645DAC712F358 /* CustomGroupChannel.ViewConverter.List.senderProfileImage.swift */; }; - D288D1FD498B6FA01921482A /* SBUModerationsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = D36259D49FBF122E1CC92591 /* SBUModerationsModule.swift */; }; + D24D1F87034D4265CBDEC307 /* SBUGroupChannelPushSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 42D37B68DDC774BB034CEE3E /* SBUGroupChannelPushSettingsModule.swift */; }; D2C7DD22F0C1B312E36071F2 /* CustomGroupModerations.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = FE35056CA598654CAD9BD7FF /* CustomGroupModerations.ViewConverter.List.entireView.swift */; }; D2D1239E774F22EE5DDD222A /* CustomOpenParticipantList.ViewConverter.List.profileImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 563EB54A9E2574042EE0CE84 /* CustomOpenParticipantList.ViewConverter.List.profileImage.swift */; }; - D2D3898FA489DEC8B003670B /* SBUEnums.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A8F43AB90915B61D475F48A /* SBUEnums.Deprecated.swift */; }; - D31105D429573D105CF51B4D /* SBUMessageTemplate.Syntax.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5EDD7A1F27B543A5A2CC0C50 /* SBUMessageTemplate.Syntax.Item.swift */; }; D34CD68115E828A821DCED91 /* CustomOpenModerations.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F89671E15060D30405A5A9B7 /* CustomOpenModerations.ViewConverter.Header.rightView.swift */; }; - D3775D72291D8243C42B000E /* Thread+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6AEF8D4FF705BB662A4BDC7A /* Thread+SBUIKit.swift */; }; - D3868E3A2F8D661563025087 /* SBUAlertView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68804DE6D7F73CEA7FEEA335 /* SBUAlertView.swift */; }; - D3B5643C1E822D974328D4BB /* GroupModerationsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = CD8F9ED1B50DBD995EEF594B /* GroupModerationsView+Item.swift */; }; - D4297F02CDEFB90DD1C01C0B /* OpenParticipantListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1992BFA4DDDB1636ACFF4A97 /* OpenParticipantListView+Item.swift */; }; - D4500C33046BB2D60EA64C66 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2D62381A39883A6AF9749655 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift */; }; - D50E407E80A53447FF9B3F83 /* SBUOpenChannelSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0862BAC5CCDFC6641C3B97C3 /* SBUOpenChannelSettingsViewController.swift */; }; + D3693F5B3C5BDA0970AE976C /* GroupChannelSettingsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1AE76A1AE751AA26FFB13901 /* GroupChannelSettingsViewConverter.Header.swift */; }; + D3F9C1EA89B6F0CD309F1661 /* GroupChannelListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9B51CE14A8194C970B0D40F3 /* GroupChannelListView+SubViewBuilder.swift */; }; + D451110E7911228D3FAD2107 /* SBUEmptyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C3B03F7CD7C1C6606A5BA43F /* SBUEmptyView.swift */; }; D51031FEFC9399DD2BB8301C /* CustomOpenChannel.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CE41B8A5727684B5E30295B4 /* CustomOpenChannel.ViewConverter.List.entireView.swift */; }; D57118BC69FAEA9F2DA17FDA /* CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F0F5806465F7C6A9458CFA95 /* CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift */; }; D57E556013E63C09FFF5F11B /* CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D7E0033519CF0DFDBF445DBF /* CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift */; }; - D5A1C9DC1298E12DEF491352 /* SBUModerationsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = C8CA206B4B29BAF26852CB29 /* SBUModerationsViewModel.swift */; }; - D64166FCA5096FD3CEE19E6F /* SBUModerationsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9DEB237E4B180100712E7618 /* SBUModerationsModule.Header.swift */; }; - D6C387C6445C17C4D2E4B928 /* SBUStringSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 91658F3FA5C4F2E9DB896DEB /* SBUStringSet.swift */; }; - D6F64CCAC890DE60919658F3 /* CreateGroupChannelViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 41BBFE0A1ECE6E97671C152C /* CreateGroupChannelViewConverter.List.swift */; }; + D589D27B764BEBC102F05794 /* SBURegisterOperatorModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 42DCD70A6B86E1C1113518A4 /* SBURegisterOperatorModule.swift */; }; + D58C121ACCB1F20C95BA23B3 /* OpenChannelSettingsViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = DBC40F923C1D6C6FC592B67A /* OpenChannelSettingsViewConverter.Header.swift */; }; + D5A6F0567923769FA2398C7E /* SBUGroupChannelSettingsModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5FEC8CAB95357120546DFA62 /* SBUGroupChannelSettingsModule.List.swift */; }; + D658DC3A36C27319A7B922ED /* SBUEnums.swift in Sources */ = {isa = PBXBuildFile; fileRef = 244EE344C8E75A091EAECD86 /* SBUEnums.swift */; }; + D66D65F95BCC0BE6B11E7D75 /* SBUGroupChannelPushSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2A29132CC8E88EB608B11887 /* SBUGroupChannelPushSettingsViewController.swift */; }; + D6EB199C43B90E162A2F20B3 /* SBUGroupChannelListModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4798C26A881FB43F032AC24D /* SBUGroupChannelListModule.List.swift */; }; D700D51CF1431F165C099FA1 /* CustomMessageThread.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = FBC4A6592CF9264B9334EC0C /* CustomMessageThread.ViewConverter.Header.rightView.swift */; }; - D7531BC55DDC2FD53CFCF70A /* UIColor+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = A3CF699C92A450F181836CD9 /* UIColor+SBUIKit.swift */; }; + D71AE9F8940934FD27BA0934 /* SBUGroupChannelSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = F9D3B79BEAF2D1C7C3D484D0 /* SBUGroupChannelSettingsModule.Header.swift */; }; + D71DDB5B256AADEC51B8CA51 /* SBUQuotedBaseMessageViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6C2A652B4CE7406954BBF464 /* SBUQuotedBaseMessageViewParams.swift */; }; + D73131BD56BB892C8FCA7ABC /* SBUFormView.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = ABEE9C98A1E6CDDEA7001F6A /* SBUFormView.Deprecated.swift */; }; D76D94A74969D557C5D8E414 /* CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 344A9753F8B782EDD9E411B6 /* CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift */; }; - D78B56FF68EC5CAF2F39F522 /* SBUMessageFormChipsItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5E7E39A804B558F66F7EB947 /* SBUMessageFormChipsItemView.swift */; }; - D7A6DA898753003B05ECC100 /* GroupChannelSettingsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A4F7A4428AA6840190A27E2 /* GroupChannelSettingsViewConverter.List.swift */; }; - D7C3BCFB400E6BA692406943 /* SBUMentionManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9854C9F75B1B5DF2C5C09594 /* SBUMentionManager.swift */; }; - D7DE86DB66F59C1D32492FE0 /* SBUOpenChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 41CE55F82D74BE766CC40BC8 /* SBUOpenChannelViewModel.swift */; }; + D79DA58655048691F33C1324 /* SBUBaseViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 657F6F2027D3DE4F87DDBDA6 /* SBUBaseViewController.swift */; }; + D7C7A88AFF4A08EF7105823E /* SBUBaseSelectUserViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = A16049189F9B0C7ABC022076 /* SBUBaseSelectUserViewModel.swift */; }; + D821D3F623937C7A515003E5 /* CreateGroupChannelView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3442BED25FDD54492980D099 /* CreateGroupChannelView+Item.swift */; }; D8522E3EDB9703003A8FF525 /* CustomGroupBannedUserList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 45A81732697B3F45963DDC20 /* CustomGroupBannedUserList.ViewConverter.List.moreButton.swift */; }; - D8A595CFD9892DAB66088428 /* FontSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD0FAD1E018EEBC665ACD0B6 /* FontSet.swift */; }; - D97F7E736F1CBA332E72BE2B /* SBUBaseChannelSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = DEFC8D070D3FD13797007DD2 /* SBUBaseChannelSettingsViewModel.swift */; }; + D88C96CEB93A889B58FB26B2 /* SBUCategoryFilterCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = B545224CE456DD6FC076E267 /* SBUCategoryFilterCell.swift */; }; + D890BDF7EA7E8F299CB771C6 /* SBUBaseChannelViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = B51E1CE18BE4F3FDC6244D83 /* SBUBaseChannelViewController.Unavailable.swift */; }; + D8DB4EC1517D600A7BAB3E6B /* SBUTemplateLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = C14D33CD97DDAE9959DB7FAB /* SBUTemplateLabel.swift */; }; + D95D59BCCD0E4ED0672E423F /* SBUAvailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = C11CD6DE01963046D4167D31 /* SBUAvailable.swift */; }; + D9741519F48A5C56A4E31758 /* OpenChannelListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = F88ED0A9054B24C63657907F /* OpenChannelListView+ViewConverter.swift */; }; D9971217DD7E669C3AB8EFF5 /* CustomGroupOperatorList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 73BAF54B7AED8872A6418ED8 /* CustomGroupOperatorList.ViewConverter.List.moreButton.swift */; }; D9EFC08AA12B5BA2CB490B02 /* CustomCreateOpenChannel.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 832AD74C612CBA95BB6080A9 /* CustomCreateOpenChannel.ViewConverter.List.entireView.swift */; }; - DA6759309CEB090B5736ADEA /* SBUMessageTemplate.Syntax.Sizes.swift in Sources */ = {isa = PBXBuildFile; fileRef = 889E65EF815ECC664FAAABE2 /* SBUMessageTemplate.Syntax.Sizes.swift */; }; - DA6E618B26EF3A66E44CFE4B /* SBUExtendedMessagePayloadCustomViewFactory.swift in Sources */ = {isa = PBXBuildFile; fileRef = B180E9D8480EE10DE31B9FE1 /* SBUExtendedMessagePayloadCustomViewFactory.swift */; }; + DA21E2E8D4568E10184C5829 /* SBUCommonViewControllerSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7725F441E1811150851949AB /* SBUCommonViewControllerSet.swift */; }; DA7F04516E8BD61F84BF1CCF /* CustomGroupChannelSettings.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9087883EC823CC5667850BE6 /* CustomGroupChannelSettings.ViewConverter.Header.leftView.swift */; }; - DACBC67120261B903F277917 /* SBUChannelSettingsChannelInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2D33147A10A17DE06274D98B /* SBUChannelSettingsChannelInfoView.swift */; }; DAD48567A2CD30ED5AA7DBD6 /* GroupChannelsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 44E9086D8B5595BDE5E88340 /* GroupChannelsView.swift */; }; DAE23D983347E184AB62CE6A /* CustomGroupChannel.ViewConverter.List.fileMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 53346E81604409C68486DBB2 /* CustomGroupChannel.ViewConverter.List.fileMessageView.swift */; }; - DB784512EF2721F525CCC5AF /* SBUTableViewCell.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = B48EFC9732F79D6C644ABE86 /* SBUTableViewCell.Unavailable.swift */; }; - DC7D77404C0685CAA873B466 /* MessageSearchViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1C31CF4BCC3BBFC1D19D9A3 /* MessageSearchViewConverter.swift */; }; - DC9D16332ACB8881A320B8BC /* SBUGroupChannelListModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = EBDD55B35D81B408381A6074 /* SBUGroupChannelListModule.Deprecated.swift */; }; - DD26AE269E8F0A33504775F6 /* SBUOpenBannedUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7D019D737385153F291693BF /* SBUOpenBannedUserListModule.List+SwiftUI.swift */; }; + DB14CAEEDA9EDCCCEC048DC1 /* SBUOpenChannelListModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 93C5F784B2DBFAB6E6C9F1B8 /* SBUOpenChannelListModule.Deprecated.swift */; }; + DB356896BCA044665B242399 /* GroupBannedUserListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 045EF0FD06337FF5EA81F035 /* GroupBannedUserListViewProvider.swift */; }; + DB401DA57593F4ADF0D3ED84 /* SBUOpenOperatorListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = C7291EB72F5BC939C93ACD43 /* SBUOpenOperatorListModule.Header+SwiftUI.swift */; }; + DBD660C7A6B7B0CF3BB88609 /* SBUUserNameView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 08C31448CE461810A569DE1E /* SBUUserNameView.swift */; }; + DC1FD939B69B7412F5D4B7A8 /* SBUUserMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = E8444BA33EBECD12A5B3278F /* SBUUserMessageCellParams.swift */; }; + DD425D8E4996A6C3CCADDD5F /* OpenModerationsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F59F85ADF99A208A9C082B0 /* OpenModerationsViewConverter.List.swift */; }; DD849A24C5F4B19F1610D4BE /* CustomOpenChannelSettings.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3C026B187F72078CFCDC5BBE /* CustomOpenChannelSettings.SwiftUI.View.Main.swift */; }; DDADA81EA1FD0E980F60FCD2 /* CustomOpenParticipantList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 69F40C5D515D21F5E4F11F89 /* CustomOpenParticipantList.ViewConverter.Header.rightView.swift */; }; - DDBEC50FB891AC49AE114611 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1C1C132A58903724C8A1FA14 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift */; }; + DDDC2FB959B3E2B39EA8EACC /* SBUGroupChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = C9DE89D8E1BB400650B44CF8 /* SBUGroupChannelModule.List.swift */; }; + DDE9EC09148983597313BEE8 /* SBUCreateOpenChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 510A0B30736E46E0278FC9A9 /* SBUCreateOpenChannelModule.swift */; }; DDEBAC0217F9BC12F921A9DA /* SampleListSwiftUI.json in Resources */ = {isa = PBXBuildFile; fileRef = 0283CFAD93FEE4DA37292045 /* SampleListSwiftUI.json */; }; - DDFFDDFFB3DA8F867B6ADF7D /* SBUModuleSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4DEF0B14DE38EB619FD6405B /* SBUModuleSet.swift */; }; - DE29C57028910EFACF8BC21B /* SBUBaseChannelListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 766287661E5CEC1E2D67A87D /* SBUBaseChannelListModule.swift */; }; + DDFAB659A3347A66423269EA /* SBUOpenChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7B12B08BDE49DDA8CEF1081 /* SBUOpenChannelViewController.Deprecated.swift */; }; + DE198D029D3134AFD5B3EAE3 /* SBUOpenChannelBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0C45A13A56647ADEE8B57C17 /* SBUOpenChannelBaseMessageCell.swift */; }; + DE26AED838AFFF841E2700B8 /* OpenChannelSettingsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = BB8E79F86C80CC2DD59FCC04 /* OpenChannelSettingsView+ViewConverter.swift */; }; DE2DC3ABFD4619E3BAAB065E /* CustomGroupChannel.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = ABE556FD97646142D0B60B2E /* CustomGroupChannel.ViewConverter.List.entireView.swift */; }; + DE582665CC81FE860DB5BDD6 /* SBUVoiceMessageConfiguration.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4DDE8745066E0EC425DD0C85 /* SBUVoiceMessageConfiguration.swift */; }; + DE77932BB62B6C6ABB50E6C5 /* SBUActionSheet.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6A8FE68282C9D1E38107C371 /* SBUActionSheet.Item.swift */; }; DE92BC068203145AD72AA823 /* CustomGroupChannel.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E7FA5ACCAFC350D479002755 /* CustomGroupChannel.ViewConverter.Header.leftView.swift */; }; - DEBF3392C7142EFC15547445 /* SBUChannelStateBanner+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 758ABFEF69EB1E64F10BBD08 /* SBUChannelStateBanner+SwiftUI.swift */; }; - DEC1A145B129CCED3F001421 /* SBUMessageSearchModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6BBFC36107564B847F7FE03B /* SBUMessageSearchModule.Header.swift */; }; - DEC8EF3C4040E0CA0F4C1238 /* SBULayoutableButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = E6AB5AF4E86499D0DFEE881B /* SBULayoutableButton.swift */; }; DF353BFE84BA086EE7F3E766 /* CustomOpenModerations.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A026D51D238CBB4236E62120 /* CustomOpenModerations.ViewConverter.Header.titleView.swift */; }; DF46001C4A194EBC28E03B80 /* CustomMessageThread.ViewConverter.ParentInfo.webView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 89C262A82447A1864301C8A1 /* CustomMessageThread.ViewConverter.ParentInfo.webView.swift */; }; DF85556C819C09D991FB01C4 /* CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = AE502119AE1D2DF2A3A00516 /* CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift */; }; - DF8E37A2811986DDD4084B36 /* GroupOperatorListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4E03A57B44CC6B14D4C4031B /* GroupOperatorListView+ViewConverter.swift */; }; DF9B51B8867AD57311C581BF /* CustomOpenChannelSettings.SubView.Builder.userList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2EE881D701BE62C2C5A1297C /* CustomOpenChannelSettings.SubView.Builder.userList.swift */; }; - DFA9966EF652CADE6D96ED0A /* MessageSearchViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = A14365C43B23A4185F8DDCA5 /* MessageSearchViewConverter.List.swift */; }; - DFAC18234423C9FE06C61020 /* SBUCollectionViewFlowLayout.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2DAAF41FC4C94DDFA9DB7794 /* SBUCollectionViewFlowLayout.swift */; }; - DFED0A12C20374C2E59D2188 /* OpenChannelViewConverter.Input.swift in Sources */ = {isa = PBXBuildFile; fileRef = B02DAC06AC58179B3149D2C3 /* OpenChannelViewConverter.Input.swift */; }; - DFFE1B9DC17CB3F9EAD4C46F /* SBUBaseSelectUserViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 020B96FF3BCFE616CFDD5DBC /* SBUBaseSelectUserViewModel.swift */; }; - E00E02F894E103B52A787CFA /* SBUActionSheet.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5BBE80E7FA22943BBC1F7C9 /* SBUActionSheet.Item.swift */; }; + E007334B519593C1204810F1 /* SBUMessageTemplate.Renderer.Image.swift in Sources */ = {isa = PBXBuildFile; fileRef = 96A238FF98AFC58A20C0202D /* SBUMessageTemplate.Renderer.Image.swift */; }; E020B870C47927BCF407D8D6 /* CustomOpenChannel.ViewConverter.List.userMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = CAC0DD1043216CB7D20D5D0C /* CustomOpenChannel.ViewConverter.List.userMessageView.swift */; }; - E041ED0754A7003638FE32FB /* NSObject+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 285695471DE00B5F03AF5665 /* NSObject+SBUIKit.swift */; }; - E0BABA0802B060E1E05A0619 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = A70B8E791E1AA6A605F15277 /* Assets.xcassets */; }; - E15DCBFAC901D6AA6A70AD18 /* NSLayoutConstraint+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 57110DEFE797090CB0D36499 /* NSLayoutConstraint+SBUIKit.swift */; }; - E17930904D0C67EF43A9937A /* SBUViewModelSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 666C50E90307271C07649F2A /* SBUViewModelSet.swift */; }; - E1B1B58491BBB92494FA178D /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A71DA9519A09B9E6CBC9D375 /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift */; }; - E1DCD33CFE1FAB9CFA589E1D /* SBUMessageSearchResultCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E15C3CDDBC6D533E0C64E57 /* SBUMessageSearchResultCell.swift */; }; + E03341A314BE9FDCC51455EA /* SBUModerationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5BE9CE19D2E6FB9CC0276345 /* SBUModerationCell.swift */; }; + E0AA86C26729A692797C8666 /* Sendbird.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2B50481174F97B1EE25DA725 /* Sendbird.swift */; }; + E16734D498A71A626E474116 /* OpenParticipantListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 883A64B2835D7B6C1D60452E /* OpenParticipantListView+Item.swift */; }; + E17F0E9586DB80A76D8386A2 /* SendbirdChat+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = E567F385A20BDC53C3078CC6 /* SendbirdChat+SBUIKit.swift */; }; + E19EB21CBB56FE2CB7DCC23D /* GroupMutedMemberListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = FA5E060A224E457A70D2C17C /* GroupMutedMemberListViewConverter.Header.swift */; }; + E1A131376C16EFFC6BA88B13 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = D250660811AF42D876E15FA9 /* Assets.xcassets */; }; + E1AE7A7067D6B8B6970F08DA /* SBUUnderLineTextField.swift in Sources */ = {isa = PBXBuildFile; fileRef = BE00B6FCA3245B5D40FCB38C /* SBUUnderLineTextField.swift */; }; + E1B65F461DFA5E4D0515F4A1 /* SBUModuleSet.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1BB7510F2315F0AA6E215A4B /* SBUModuleSet.Deprecated.swift */; }; E1EE9FE3F98093588B22702D /* CustomOpenChannelSettings.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 587133C64EC3FDA6A0E78472 /* CustomOpenChannelSettings.ViewConverter.Header.titleView.swift */; }; + E1FE698F09E5426EA2BF4220 /* OpenChannelListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = AEA66943CFCCE47F35FFB80F /* OpenChannelListViewProvider.swift */; }; + E20140053EFB0D38E7583F38 /* SBUMessageThreadInputView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7A0D57F36F2D8B1100D6FE49 /* SBUMessageThreadInputView+SwiftUI.swift */; }; + E20593ED3CDE0767A2BB81EB /* SBUMessageTemplateManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = C6D06846C4514870E7373463 /* SBUMessageTemplateManager.swift */; }; + E233ECD670D245502190617D /* SBUCollectionViewFlowLayout.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6893750A21CEBD75C830B03A /* SBUCollectionViewFlowLayout.swift */; }; E249AE4E269D6F929AFC0F87 /* CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5C7865CE65D851F196960978 /* CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift */; }; - E24DD39228128306D43F5F95 /* SBUBaseSelectUserModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = DC3DF1FA4AFE90DC6FA8AC20 /* SBUBaseSelectUserModule.List.swift */; }; - E262658E5596CA5B8A9800CE /* OpenChannelListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = A4CAF7382CC2469BBF87E329 /* OpenChannelListView+ViewConverter.swift */; }; - E275EA3302EB2EA9443D0A29 /* ViewItemInitialize.swift in Sources */ = {isa = PBXBuildFile; fileRef = C881A0739A99CFC25E5779FE /* ViewItemInitialize.swift */; }; - E2A5C652B7FB5E678480D382 /* SBUMessageTemplate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 823177EB22F1375CF161441D /* SBUMessageTemplate.swift */; }; - E2E5FCFAAAF8D4E28A8C9AE8 /* OpenMutedParticipantListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = F2B377E7421E1FDDFB61C7DA /* OpenMutedParticipantListView+Item.swift */; }; - E2F52C7E7ADB0B8114C5CDD3 /* SBUForm.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 055A3B07C1A7654608413474 /* SBUForm.Deprecated.swift */; }; - E37868000C956EFAB18F0F98 /* SBUSelectablePhotoViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B3815A0BB9F670F9F21DB0F0 /* SBUSelectablePhotoViewController.swift */; }; - E38F83998295EB297029D87A /* SBUModerationsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1500B8E9713683B07753569C /* SBUModerationsViewController.swift */; }; + E2726D4CC2CAC501CFAE7E15 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = DEFD2C9C3755450DB4FB300D /* SBUOpenChannelSettingsModule.List+SwiftUI.swift */; }; + E30D824F9AD83B1AFE419A74 /* OpenModerationsView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2ECACCFCA2492AB6CF181E9B /* OpenModerationsView+SubViewBuilder.swift */; }; + E310C6E67AD22482CD33FEEA /* SBUOpenChannelSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 59D6F159B1AF097FA42F0795 /* SBUOpenChannelSettingsModule.swift */; }; + E324F27541808F977BEB3461 /* SBUBaseChannelCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB654419A3218B0E3A4093D5 /* SBUBaseChannelCell.swift */; }; + E333B1FF65287CD42D3DCA7F /* OpenMutedParticipantListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = B26D20DFC631D5EDC2CF8D54 /* OpenMutedParticipantListViewConverter.Header.swift */; }; E3C5EDB58BDFEF79C9D2EDE4 /* CustomGroupBannedUserList.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = B07D3A391488B12E092C1164 /* CustomGroupBannedUserList.ViewConverter.Header.leftView.swift */; }; E3D626BF7B1BE125274C72DA /* CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 24823518A52E6BB53C899607 /* CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift */; }; - E3ECA6E25F4FE009310D1E30 /* SBUView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3A9D4CF5A5EE6E8646E37865 /* SBUView.swift */; }; - E53E0BEDB6DBD11B9DBD4249 /* SBUQuotedBaseMessageViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = A4D6A060025AC392A913D587 /* SBUQuotedBaseMessageViewParams.swift */; }; - E54606D64412F6BAB1886758 /* SBUImageContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 86D37B65E1EF649577EA0D37 /* SBUImageContentView.swift */; }; - E5C7D45DC9E90EA6957A1A7F /* SBUBaseMessageCell.Feedback.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E8A575294393A1D7BC34487 /* SBUBaseMessageCell.Feedback.swift */; }; - E6225EB93A8FD067A26CBDF2 /* SBUOpenChannelListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A3AEBCB0B26EC13B2CA266E8 /* SBUOpenChannelListModule.List+SwiftUI.swift */; }; - E68926AA4D9CE89804D96380 /* SBUFeedNotificationChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0E29F2ED3AC2E2D139EF1814 /* SBUFeedNotificationChannelModule.swift */; }; + E41876A47FC63195B2042B16 /* SBUChannelListViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = A724FC169EF60661FE55A578 /* SBUChannelListViewController.Deprecated.swift */; }; + E41B3AD45A7869B7EB6D7B83 /* SBUGroupChannelPushSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = A5AAEF8465A482135D31EB44 /* SBUGroupChannelPushSettingsModule.Header.swift */; }; + E44C5E8E735A88195F730DDC /* QuotedFileImageContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6EB22BF73F4DB239A34F6792 /* QuotedFileImageContentView.swift */; }; + E4957040F6F16C052D03A09A /* SBUReactionCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 717BB61F0D034A789B0F3470 /* SBUReactionCollectionViewCell.swift */; }; + E53E112114ED4F9AB72E7599 /* SBUPhotoCollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 54A86D1EE72BB0B915C95571 /* SBUPhotoCollectionViewCell.swift */; }; + E5F26019AAED4891982FAACF /* GroupChannelPushSettingsViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AA30971729AB912E9FC2BB9 /* GroupChannelPushSettingsViewConverter.List.swift */; }; + E622A4BD0B6A149DDED179E2 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9268BE22DBE8DBD50C37CB32 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift */; }; + E633602EE668031243BF1195 /* SBUUtils.swift in Sources */ = {isa = PBXBuildFile; fileRef = 228FA3A4F2C3475CD28C3D23 /* SBUUtils.swift */; }; + E6365D7C7EE4F62FC962FCD3 /* WrapperUIViews.swift in Sources */ = {isa = PBXBuildFile; fileRef = B166932E45875505EE1E64DB /* WrapperUIViews.swift */; }; + E646BD797B5C1865C71C1A03 /* SBUChannelTitleView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1CF9D34BCB427438C4E21B0B /* SBUChannelTitleView+SwiftUI.swift */; }; + E6AFA3E291CBDBB8F0A2A561 /* SBUUserMessageTextViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D1009E6F8479AF70D7433D /* SBUUserMessageTextViewModel.swift */; }; + E6B3E04DF4709FF6C31AAA7B /* SBUVerticalSuggestedReplyView.swift in Sources */ = {isa = PBXBuildFile; fileRef = ADD3FAB38AE4AB7059250476 /* SBUVerticalSuggestedReplyView.swift */; }; + E6B641254065AC40061E7852 /* SBUPaddingLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = B1CEACEDCDA122F53B6F9048 /* SBUPaddingLabel.swift */; }; E6BAD099DE9924FFCCC0A92D /* CustomGroupMemberList.ViewConverter.List.moreButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0AB62A723B63530224C5977F /* CustomGroupMemberList.ViewConverter.List.moreButton.swift */; }; E6F39C44CD982968992B1ADB /* CustomOpenParticipantList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 76D679FC213569853E5A02DE /* CustomOpenParticipantList.SwiftUI.View.Main.swift */; }; - E6FD95E728A65284B04676F4 /* SBUBaseChannelViewController.Unavailable.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1D0F53258EBF6406A01FBE22 /* SBUBaseChannelViewController.Unavailable.swift */; }; - E6FDBB24F606883B8D3A7757 /* SBUOpenChannelContentBaseMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 78EA6D0B65FF927D2CE1805D /* SBUOpenChannelContentBaseMessageCell.swift */; }; - E72068F330B18B111C25BEA5 /* SBUCreateChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0FD98E815C023134E9123D4 /* SBUCreateChannelModule.List.swift */; }; + E72FE839E56753325B2354B0 /* SwiftUIMessageInputInterface.swift in Sources */ = {isa = PBXBuildFile; fileRef = 52CE2A507E7A42C725CCBE15 /* SwiftUIMessageInputInterface.swift */; }; E765C943402870DD877CC596 /* CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A10A557D8CFE5451AC04DD3 /* CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift */; }; - E78569906B225E8EFFDAF522 /* OpenParticipantListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 12DC37AE9F9A2EAAB346B524 /* OpenParticipantListView+ViewConverter.swift */; }; - E7AD63843F241D0D0CD6EF42 /* SBUBaseViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 84E9EDEFC79A50C05C8D5C31 /* SBUBaseViewController.swift */; }; + E7BED5E5EB91E0764A60C357 /* SBUCacheManager.Version.swift in Sources */ = {isa = PBXBuildFile; fileRef = D7E4393E73BAF35A4ECF1541 /* SBUCacheManager.Version.swift */; }; E7D929F429799D010607395A /* CustomOpenBannedUserList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9D9E9FD91120A87FB6AF0AAA /* CustomOpenBannedUserList.ViewConverter.Header.rightView.swift */; }; + E7E14B28363015575DABE0B5 /* OpenModerationsViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19B6DCAB9B843572847D9FA6 /* OpenModerationsViewProvider.swift */; }; E7E244725A5FCC93651A169F /* CustomGroupOperatorList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4BD45E788E57BFD2326E26A4 /* CustomGroupOperatorList.ViewConverter.Header.rightView.swift */; }; - E82B73F45E1B261798A3C1D9 /* SBUOpenChannelSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = C11906C6C1DC0D52EC28F0D0 /* SBUOpenChannelSettingsModule.swift */; }; - E8307AA123548D284537B16A /* SBUAdminMessageCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 224DFC32A8DFF7FCAE9B3585 /* SBUAdminMessageCellParams.swift */; }; - E87DE39B2D383FAE60F00257 /* SBUMessageTemplate.Syntax.Styles.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2C6C9F8F3C88F07B39F5C385 /* SBUMessageTemplate.Syntax.Styles.swift */; }; E8D8D2762701DF06A53AC3E3 /* CustomMessageThread.ViewConverter.Input.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = EF14FECB8F18A1D036D7C324 /* CustomMessageThread.ViewConverter.Input.rightView.swift */; }; - E91CF381A3962D99614DD552 /* GroupChannelListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD6134279DE72ADE5816F2F0 /* GroupChannelListView+Item.swift */; }; - E96F05F8443C46A75441A5F0 /* OpenChannelSettingsView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 526ED0C01EE8EF2AC7D76E68 /* OpenChannelSettingsView+ViewConverter.swift */; }; - E9B907682BD46AAB30DE9A90 /* GroupMemberListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = E643BD503D1B0287D115F459 /* GroupMemberListViewConverter.List.swift */; }; - E9CD4A495C8815F8B47C1FD1 /* SBUSuggestedReplyOptionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0F25A2D259E9D51AC9C71562 /* SBUSuggestedReplyOptionView.swift */; }; + E8F988401EB92C4C0B30EA9F /* ColorSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8FF453D51A63DD5EAC2A29B3 /* ColorSet.swift */; }; + E91364FF0B3A7683F5EB70ED /* SBUAnimation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 50ED882EE429BC0546752DE2 /* SBUAnimation.swift */; }; + E9670E0623792580346E32D9 /* SBUChatNotificationCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 15FB7D893238C88344868AD0 /* SBUChatNotificationCell.swift */; }; EA2C6888338A473B8B030AA8 /* CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3518C56DA60C12F9CEB9E407 /* CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift */; }; - EA33B6D96C33382B69680DBA /* SBUBaseMessageCellParams.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = CADB3058FF6F4B079FB37BB8 /* SBUBaseMessageCellParams.Deprecated.swift */; }; - EA3976663914B3C1572AE2ED /* SBUCreateOpenChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = B16C1FB87FE416A9AACF8977 /* SBUCreateOpenChannelModule.swift */; }; - EA6EFEB0C07B15E26377DD92 /* SBUBaseChannelSettingsModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = C7EFCE231326D9CFCB928363 /* SBUBaseChannelSettingsModule.swift */; }; - EAC99BC05AF6076D4BA9F514 /* SBUSearchBar.swift in Sources */ = {isa = PBXBuildFile; fileRef = E27A6013DA5EDC1AE77B2577 /* SBUSearchBar.swift */; }; - EB37271035E9D01B69E5249C /* CreateGroupChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 93368E728F88CC318E978EEA /* CreateGroupChannelView+SubViewBuilder.swift */; }; + EA8AA3192A5F5D990B6ACB17 /* SBUMemberListViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = FA08839B2698DC9512850391 /* SBUMemberListViewController.Deprecated.swift */; }; + EAB3A741FAB9074738198031 /* SBUInviteUserModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9CA37BC0C06812BB951EC82F /* SBUInviteUserModule.Header.swift */; }; + EAD958A3EDEB446671C89C8E /* SBUMessageTemplateCellParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EA5BBCE668287248E3E5863 /* SBUMessageTemplateCellParams.swift */; }; EB3D9203A0DF4F4A395A413D /* CustomGroupBannedUserList.ViewConverter.Header.rightView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F6823DFB6EB45E555D00876D /* CustomGroupBannedUserList.ViewConverter.Header.rightView.swift */; }; - EB7249112A888F49EC8BB3DA /* InviteUserView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 94C077267D8FDD493CDAF330 /* InviteUserView+Item.swift */; }; - EBC78746894BA6E4E47AEB1A /* SBUGroupChannelListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 01014154A6F2DDA514E9AEE6 /* SBUGroupChannelListModule.Header+SwiftUI.swift */; }; + EB5A669D541805381D676CB9 /* GroupChannelPushSettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 95CE7A7C3AD04AA4DC13DECB /* GroupChannelPushSettingsView.swift */; }; EBCC65232ADE6ABE115E3BC5 /* CustomOpenChannelList.ViewConverter.List.coverImage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 77429209B80CB959FD5662A1 /* CustomOpenChannelList.ViewConverter.List.coverImage.swift */; }; - EC1E8177EA612D6400938100 /* SBUMessageTemplate.Renderer.Views.swift in Sources */ = {isa = PBXBuildFile; fileRef = 66214E35809045C5464EF919 /* SBUMessageTemplate.Renderer.Views.swift */; }; - EC29897D6C48E4070A5F2709 /* SBUOpenChannelCommonContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AD07773AFAC8EDB0C5804E32 /* SBUOpenChannelCommonContentView.swift */; }; + EC1FD23F4261BCDC439DCE79 /* SBUGroupChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3AC6115AB54C4F0DE018F8EE /* SBUGroupChannelViewModel.swift */; }; + EC5E164049C5223D55316F1F /* CreateGroupChannelView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 644566F6C95C0AE1075D4E82 /* CreateGroupChannelView.swift */; }; + ECAB32E977EF5EA1BBAFAA71 /* SBUMessageThreadViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B6FD670D57FB0A2380422154 /* SBUMessageThreadViewController.swift */; }; ECB9EAACE63575385978E9C1 /* CustomOpenChannel.ViewConverter.List.fileMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = EA651403B226D24C7BDC99E8 /* CustomOpenChannel.ViewConverter.List.fileMessageView.swift */; }; - ED4ADF7E3FC9D86805EFD907 /* SBUIconSetType.swift in Sources */ = {isa = PBXBuildFile; fileRef = AE671E84CB2E1BF4227408D7 /* SBUIconSetType.swift */; }; - EDBFC9051041DEB903DEF868 /* UIStackView.SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = DCEAE022E08885F8F8991889 /* UIStackView.SBUIKit.swift */; }; - EDE2669DCC64990790660E85 /* SBUFeedNotificationChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 57EAE7739E3BD2E813597301 /* SBUFeedNotificationChannelModule.List.swift */; }; - EE18744AE360DAACB19FFA47 /* SBUSuggestedMentionList.swift in Sources */ = {isa = PBXBuildFile; fileRef = A35787A00958FD8404D93082 /* SBUSuggestedMentionList.swift */; }; - EE6F7874CA43EF4B1374DC47 /* SBUMessageStateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 46A56A7F8B030C1F016B4CED /* SBUMessageStateView.swift */; }; - EF2DDFC6BA4286E5C6976A10 /* SBUGlobalCustomParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0A4B1C1EC52CFF027D65EFA5 /* SBUGlobalCustomParams.swift */; }; - EF31A9F67E151504D2D61273 /* OpenChannelSettingsView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = F4CCF79AABF76CC5A2F14629 /* OpenChannelSettingsView+Item.swift */; }; - EF7226964F4E87543F7FB55C /* OpenMutedParticipantListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = F69D522AF28DCC02E3639775 /* OpenMutedParticipantListView.swift */; }; + ECBBEA5F25E528664C41EDEC /* SBUNotificationTimelineView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E9AABB7CE646ADCDF873887 /* SBUNotificationTimelineView.swift */; }; + ED24A05588C5B781AAD3088F /* SBUDateFormatSet.swift in Sources */ = {isa = PBXBuildFile; fileRef = E9758CC43DB1F420CFD323D8 /* SBUDateFormatSet.swift */; }; + ED4F9C80A93E0E3F0A41B2F0 /* MessageThreadViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0ACCCEA9CFD52750859279FF /* MessageThreadViewConverter.Header.swift */; }; + EDB0D9B0073CB1F92449087A /* SBUParentMessageInfoReactionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4F9DB1C8A4D25102F05E3EF6 /* SBUParentMessageInfoReactionView.swift */; }; + EE140AFBFF2F5E99F19ED036 /* SBUUserListViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 36069F6F9F98006B014805FE /* SBUUserListViewModel.swift */; }; + EE8E041FF3DF7D3016ACFCCB /* SBUOpenChannelListModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55A777BF3329A828082C419E /* SBUOpenChannelListModule.swift */; }; + EF70D41EB10E7E3D84A91257 /* InviteUserView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1CED8D3880DEF2156A3DB5CC /* InviteUserView+ViewConverter.swift */; }; + EF83143AFC931162448332F8 /* SBUUserMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 927503842DC84814D6A78230 /* SBUUserMessageCell.swift */; }; EFA13760A6A85B45A6FBE921 /* CustomGroupBannedUserList.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1072BE53AA3569B9742E724E /* CustomGroupBannedUserList.ViewConverter.Header.titleView.swift */; }; - EFA5CFF27B028DF351B54DE1 /* SBUBaseChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 51C56CFE8E82E6E482183B7D /* SBUBaseChannelViewController.Deprecated.swift */; }; - EFB6D9EBA3D6FE450C063CFC /* SBUMessageDateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D5497D090BBDCC67C4F8CBF8 /* SBUMessageDateView.swift */; }; EFC9EB8F40449BEF90B1F745 /* CustomGroupChannelSettings.ViewConverter.List.searchItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E2404EBE71135A247419F81 /* CustomGroupChannelSettings.ViewConverter.List.searchItem.swift */; }; - F09AD512141C60DD538627BE /* SBUFileMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 27F66C34721B8052037668EF /* SBUFileMessageCell.swift */; }; - F09CF2430BE102203A4AEBB9 /* SBUSuggestedReplyViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = D86D4D360EBE5B44F0D0606D /* SBUSuggestedReplyViewParams.swift */; }; + F0907749B923ACA12384ACDF /* SBUMultipleFilesMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = C11C0F93FE87E0C4F72A5027 /* SBUMultipleFilesMessageCell.swift */; }; F0A38A8E7B664D62CDE9CDDB /* CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = C0AE3AA13449F68E87D7DD3D /* CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift */; }; - F0D502B07BE7FF2D8FDE7967 /* SBUMessageFormItemView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A4FE9D61A27CDE2A743D3CFE /* SBUMessageFormItemView.swift */; }; - F16A0166E2F1F0B4B596C82A /* MessageSearchView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 735C35C7BF5726DE097A6252 /* MessageSearchView+Item.swift */; }; - F1A6CCACDA3EDC4EB8401ACD /* GroupBannedUserListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = EAB28CD649CAB03111FF852B /* GroupBannedUserListViewConverter.List.swift */; }; + F0EAFEE7FE642C5160D47F47 /* SBUOpenScrollBottomView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 68AE2F17C4A25E2EA1BC7A63 /* SBUOpenScrollBottomView+SwiftUI.swift */; }; + F10A8905E2E771AD3163C17F /* SBUMessageTemplate.swift in Sources */ = {isa = PBXBuildFile; fileRef = B97D86AD63DE6E5D1AF2F631 /* SBUMessageTemplate.swift */; }; + F185B2B69ED9A710B7B78EC7 /* MessageSearchView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1177BB4E92D600EED17C2C8 /* MessageSearchView+SubViewBuilder.swift */; }; + F1A8E19D9E8F85F92DFE32FD /* SBUGlobals.swift in Sources */ = {isa = PBXBuildFile; fileRef = 654B422A3B857A5B120E4528 /* SBUGlobals.swift */; }; F1C659C2EC12CAB1DF3BE706 /* CustomOpenMutedParticipantList.SwiftUI.View.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5C4C185DFE1CA6B5583DB42A /* CustomOpenMutedParticipantList.SwiftUI.View.Main.swift */; }; - F20DF8AC3F5E34ED6E8B7D79 /* SBUExtendedMessagePayloadForUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 80EA4D44B6C5B0BF0C7543E6 /* SBUExtendedMessagePayloadForUI.swift */; }; + F1D93E30B153BDDC5DA67761 /* Array+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4B7D92C1C33EB7B70A4DD7CB /* Array+SBUIKit.swift */; }; + F1DB1E3587B55F0EFED1E5DB /* SBUGroupChannelListModule.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = AA6DD0EF41EBA11F612CAE67 /* SBUGroupChannelListModule.Deprecated.swift */; }; + F1DFE101D21127610F28F400 /* SBUPhotoAccess.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6E971C1577893A6B0FE234FD /* SBUPhotoAccess.swift */; }; + F2280B6FF8D8F42DF09DF068 /* StateImpactManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = 377597543169F94AFF543475 /* StateImpactManager.swift */; }; + F23AE46531423592266716C2 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = DAED2EACDE1CAAA7CC8688DE /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift */; }; F2726B162593EA04E7C860A8 /* CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1236AC76A91CA191083672C5 /* CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift */; }; - F2A5904C3A514379ED495E33 /* UIButton+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2435FE6370AF68E18F345DD8 /* UIButton+SBUIKit.swift */; }; - F2A5E5FDD3BB6B18D1EF6835 /* SBUQuoteMessageInputViewProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = 55425279F87879EA393619E1 /* SBUQuoteMessageInputViewProtocol.swift */; }; - F2FB23E7859DAB234B777DE5 /* SBUCommonDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5BFCC249BB471DB592E5A3C3 /* SBUCommonDelegate.swift */; }; - F3303D08123203E067529621 /* SBUAlertView.Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5C9F9A798C62C33692A93813 /* SBUAlertView.Item.swift */; }; - F3C36FE0F7455A39DF419614 /* SBUBaseChannelSettingsModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5AE183BFE40D7C1AE34EF4C5 /* SBUBaseChannelSettingsModule.Header.swift */; }; - F42EE4548C70DA5B326BAA56 /* SBUGroupOperatorListModule.Header+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = A7147B21E40C241888B079A1 /* SBUGroupOperatorListModule.Header+SwiftUI.swift */; }; - F43A6D9977E666414D8C4E58 /* SBUContentBaseMessageCell.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 595CB34BBF4416DC0AA3CB28 /* SBUContentBaseMessageCell.Deprecated.swift */; }; + F29CBAFB517D74A6C86E4B9C /* GroupModerationsViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 374A6395FA9C34EE3DA516DF /* GroupModerationsViewConverter.swift */; }; + F35FE1245327F4554EBE7BAD /* SwiftUIViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8C3638DCCB2EA6D0B1E9451A /* SwiftUIViewController.swift */; }; F45A3152E1FAA14BE8CD9D25 /* CustomGroupChannelPushSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BEDEEE112FE1EB02DDA2C0D /* CustomGroupChannelPushSettings.swift */; }; - F472FD7274CA3C542B107CA1 /* SBUGroupUserListModule.List+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D67908CBFE6F4D1590D22A3 /* SBUGroupUserListModule.List+SwiftUI.swift */; }; F49186D6B97BC1239F0B1904 /* CustomOpenModerations.ViewConverter.Header.leftView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9BCD7CD632F7F60EEDE69043 /* CustomOpenModerations.ViewConverter.Header.leftView.swift */; }; - F4A90A171E5CAFA12D1C8695 /* QuotedFileImageContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0EAB282FB441D9B3F630D3C /* QuotedFileImageContentView.swift */; }; - F53F8FC2A1793955B9D352B3 /* GroupChannelView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = A833DCE545C57E47102A070E /* GroupChannelView+SubViewBuilder.swift */; }; - F54B0584BA9C1AE5D457C7C4 /* SBUGroupChannelPushSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 13A39F0CA1ACC3DC69F56F19 /* SBUGroupChannelPushSettingsViewController.swift */; }; - F5772B2CEAEA30A1D216D7EA /* BlockingOperation.swift in Sources */ = {isa = PBXBuildFile; fileRef = E65E8C83BAC9277CA63A5421 /* BlockingOperation.swift */; }; - F58E90A2F55A3AA736C5F437 /* OpenChannelViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8AC9322A2E31BFE30E449B5F /* OpenChannelViewConverter.Header.swift */; }; - F5A166DDB3A9690E987262F3 /* SBUConfig.Base.swift in Sources */ = {isa = PBXBuildFile; fileRef = E5B646591D56E6AFE946CC45 /* SBUConfig.Base.swift */; }; - F5CF20AEACC99716A0208ADE /* GroupBannedUserListView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2D5AFECAA4BF9BA8AD3B0F71 /* GroupBannedUserListView+ViewConverter.swift */; }; + F4A8EDFDBE92371430320D7F /* SBUPendingMessageManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = BBF13F185407274DA4BAFF25 /* SBUPendingMessageManager.swift */; }; + F5628D78C4C3F85E893DC907 /* SBUFeedNotificationChannelViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 214A494A609C5A22C2BB8AA7 /* SBUFeedNotificationChannelViewParams.swift */; }; + F5A4DB321A03CCA71E6F3E78 /* SBUGroupChannelViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = 19F7CEEE95BBF13CB214CF41 /* SBUGroupChannelViewController.Deprecated.swift */; }; F5D83C1241B29B3E0F174D80 /* CustomMessageSearch.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 878A8DA40EB2448FB0724D26 /* CustomMessageSearch.SwiftUI.View.CustomMain.swift */; }; - F6141B649B6A71EA303E2C97 /* GroupMutedMemberListView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 393297B39B4586C83A5FE3D0 /* GroupMutedMemberListView+SubViewBuilder.swift */; }; - F64D48E9E16C47955FBD70F7 /* GroupMutedMemberListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 96CE24EEEC3A06E40F7874C9 /* GroupMutedMemberListViewConverter.List.swift */; }; - F65DF3951996885296957169 /* SBUNewNotificationInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = 681FCE6FE5FEC50EDECCB1BB /* SBUNewNotificationInfo.swift */; }; - F6A55FD4F939E34B974EC276 /* SBUNotificationTimelineView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C080BD93D8577C641E87E1D5 /* SBUNotificationTimelineView.swift */; }; + F61D156276F3F8107A1C9766 /* SBUGroupChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = EA746A3AC8FF541DF89D4606 /* SBUGroupChannelModule.Header.swift */; }; + F6CE4CCE9D5D5BCB95086FEB /* StringProtocol+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 85DC90D7892EF6119DE13735 /* StringProtocol+SBUIKit.swift */; }; + F6D5FC9F804C150B5E5FBB3A /* SBUBaseChannelModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 56EE3C45F358E3FF78C38FF5 /* SBUBaseChannelModule.List.swift */; }; F76A1290E87A7042FE910883 /* CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift in Sources */ = {isa = PBXBuildFile; fileRef = 434BE19EF6D070299A1BBB96 /* CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift */; }; - F78D508B82FF6AF8575ECC04 /* UICollectionView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3064CE17D9A94272F21E223E /* UICollectionView+SBUIKit.swift */; }; - F79FCC71D80ECA4481F1B234 /* MessageTemplateParserTest.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7FD3CDCCBBB8FB5E0C3164B8 /* MessageTemplateParserTest.swift */; }; F7AA58AB82F4C495E5284CA0 /* CustomGroupChannel.ViewConverter.List.userMessageView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 27D1D6BA515FD2C31FF5DF98 /* CustomGroupChannel.ViewConverter.List.userMessageView.swift */; }; - F7CBD1BF0C0DA146850E183B /* GroupMemberListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = EAD9C78B13DA1261EFA4A175 /* GroupMemberListViewConverter.swift */; }; - F7DA65269E357E13A99E5DF9 /* OpenChannelSettingsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 274DE7206A600067D64B8AF8 /* OpenChannelSettingsView.swift */; }; - F876788358C112410ECAB4E8 /* MessageThreadView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 482F356F3F2D59068AF4D959 /* MessageThreadView.swift */; }; - F8BA54072955D783FCD276AB /* SBULabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 089EFCFAB4CC0905D70E98F7 /* SBULabel.swift */; }; + F7B48FD0D8901203FBD4F72E /* CommonProtocols.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33FAB263E1745861F9AD0B26 /* CommonProtocols.swift */; }; + F7F5896DD491728C5E9CBBB6 /* GroupBannedUserListView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = C6B832789F70E71F8D7572D9 /* GroupBannedUserListView+Item.swift */; }; + F813C6C440C80E0BB2E3308D /* GroupBannedUserListViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3193B2D263F3D9CA56150766 /* GroupBannedUserListViewConverter.swift */; }; + F82E518CE6E0946B168BAA18 /* UIScrollView+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5B75F4EBD4914A4295678613 /* UIScrollView+SBUIKit.swift */; }; + F877982811AC508943632CCE /* SBUSelectablePhotoViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = A936C2B0F4BEFCCE17689484 /* SBUSelectablePhotoViewController.swift */; }; F8C970D71462EFD8D116E260 /* CustomOpenChannel.ViewConverter.Header.titleView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 6D5AFF1C0FFAF7FB44385303 /* CustomOpenChannel.ViewConverter.Header.titleView.swift */; }; - F8F0B40DE98424420598D32A /* SBUTextView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2752645C33797142AEE30A20 /* SBUTextView.swift */; }; + F9463E2CA150EF9329E14BDF /* SBUMessageTemplate.TemplateList.swift in Sources */ = {isa = PBXBuildFile; fileRef = 49D0BEED240F49CC5889EBF6 /* SBUMessageTemplate.TemplateList.swift */; }; + F9C2912608CC5EAA33B09C3C /* SBUMessageDateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 744D3897AF413516BB6A02CB /* SBUMessageDateView.swift */; }; F9CF4B42BDC33490C9BB589C /* CustomTheme.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5251C5F71C7B463C54D6474C /* CustomTheme.swift */; }; - F9F2D651B0D67D56FB3387DA /* SBULoading.swift in Sources */ = {isa = PBXBuildFile; fileRef = 24FA1C9F270095F0BBE68991 /* SBULoading.swift */; }; - FA7025F697F842992DE3DB75 /* SBUScrollBottomView+SwiftUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = C74FF03A1BD9590647429D9E /* SBUScrollBottomView+SwiftUI.swift */; }; + F9E8A5C906219EB9DA3F6453 /* SBUGroupChannelModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = D91401F0CEDB5A733BE00C20 /* SBUGroupChannelModule.swift */; }; + F9FF79906A372FD1B14EA51A /* OpenChannelListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = A761A9195C9F62DD9A739A19 /* OpenChannelListViewConverter.List.swift */; }; + FA3E54416512FA88DD8E159E /* SBUMessageSearchModule.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA8B78F1D3A60872891EB8E5 /* SBUMessageSearchModule.swift */; }; FA718EAEA31FC1DC79D8AAC5 /* CustomOpenChannelList.ViewConverter.List.rowView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 896D3D907E9EBAB45C5FD383 /* CustomOpenChannelList.ViewConverter.List.rowView.swift */; }; - FAC187F0CAC75721B1667848 /* SBUChatNotificationChannelModule.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = E2C6311A1B53F43110C9BC88 /* SBUChatNotificationChannelModule.Header.swift */; }; - FB20D2C791C5A003F5CBA107 /* SBUConfig.CodingKeys.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA4BD8DEDFBA0A910449DB84 /* SBUConfig.CodingKeys.swift */; }; - FB92FA1E16F8B401FBF22295 /* SBURegisterOperatorModule.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0358D88C77E677DC51C6F4F9 /* SBURegisterOperatorModule.List.swift */; }; - FC23DBF0D512EDD00027EF9A /* SBUFeedNotificationChannelViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = CC744E2B758AC433553ABEBB /* SBUFeedNotificationChannelViewModel.swift */; }; + FA9FA573FEDB0E7119C5254D /* SBUQuoteMessageInputViewProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = E4FB9CBC6163B1B65BACBE4F /* SBUQuoteMessageInputViewProtocol.swift */; }; + FAF4A573C684B274DE8851CC /* NSLayoutConstraint+SBUIKit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 915CB4B356E8EE48F40EAF87 /* NSLayoutConstraint+SBUIKit.swift */; }; + FAFE9BFE99991B273091412B /* OpenOperatorListViewProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = C7FE5E5ECE83C43C1C690C3C /* OpenOperatorListViewProvider.swift */; }; + FB0B9C2C8A82B5CFAA6F75DF /* SBUGroupChannelSettingsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0D2EF85B58A833AF96960622 /* SBUGroupChannelSettingsViewController.swift */; }; + FB112E3809457E31C1582C1D /* MessageSearchView+ViewConverter.swift in Sources */ = {isa = PBXBuildFile; fileRef = 210E248F9D2CF51D4B837AE2 /* MessageSearchView+ViewConverter.swift */; }; + FB737408C0CE15ACCA67B4B1 /* OpenOperatorListViewConverter.Header.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2E2769B561909503AB35C646 /* OpenOperatorListViewConverter.Header.swift */; }; + FC1C8336C2A542C53995CC20 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9C974D5E01D2D8CB8E15B8CD /* GroupChannelRegisterOperatorView+SubViewBuilder.swift */; }; + FC274050B793974FA5B3B325 /* SBUCommonContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0A957CCD31F05C1FE9E652E2 /* SBUCommonContentView.swift */; }; FC35B52EB66250F9EE111CF6 /* CustomMessageThread.ViewConverter.Header.subtitleLabel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0C0B447017B39B7A4378C2C6 /* CustomMessageThread.ViewConverter.Header.subtitleLabel.swift */; }; + FCD03C34AE2221900E9F9C82 /* SBUConfig.Base.swift in Sources */ = {isa = PBXBuildFile; fileRef = B7F704A16BB10D77C631E19A /* SBUConfig.Base.swift */; }; FCD5A4890CC32F6FBD716D64 /* CustomTheme.FontSet.Custom.Main.swift in Sources */ = {isa = PBXBuildFile; fileRef = A6B05764304DFF28CA5393AA /* CustomTheme.FontSet.Custom.Main.swift */; }; + FCE76CEE7EEBEF09DACF1FF1 /* GroupMemberListViewConverter.List.swift in Sources */ = {isa = PBXBuildFile; fileRef = 20731A3A1048D4D869625C6F /* GroupMemberListViewConverter.List.swift */; }; + FD05FBC1738DADC60A104DF4 /* SBUMultipleFilesMessageCollectionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2BA1A976DF480A02EAAA44B9 /* SBUMultipleFilesMessageCollectionView.swift */; }; + FD16D0D63728B50FE6B1620D /* SBUSuggestedReplyViewParams.swift in Sources */ = {isa = PBXBuildFile; fileRef = 108B741FE9BECCEB02800C52 /* SBUSuggestedReplyViewParams.swift */; }; FD4C096561CBB1EB9CD36F60 /* CustomMessageThread.ViewConverter.ParentInfo.profileView.swift in Sources */ = {isa = PBXBuildFile; fileRef = AEF35963ABD21040E7D4883A /* CustomMessageThread.ViewConverter.ParentInfo.profileView.swift */; }; - FD643C90E52BD127AD895ECF /* SBUTypingIndicatorInfo.swift in Sources */ = {isa = PBXBuildFile; fileRef = F878EF1542E0FD36E8ED1D96 /* SBUTypingIndicatorInfo.swift */; }; - FE18C179BAA225E16EC12B94 /* SBUMention.swift in Sources */ = {isa = PBXBuildFile; fileRef = 75EBF0BF01347F6F918EF810 /* SBUMention.swift */; }; - FE6BAEB044A9DD64228E97CB /* SBUOpenChannelUnknownMessageCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3716519FE7F6D63C6FE4A48A /* SBUOpenChannelUnknownMessageCell.swift */; }; - FEED40940CB9F74F00756D9B /* GroupBannedUserListView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 36D398420F97BA15C888FA6E /* GroupBannedUserListView.swift */; }; + FE34B74BEB4902E0A23BDD64 /* SBUBaseChannelSettingsViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = BE130EF4A36F3ADFE7007505 /* SBUBaseChannelSettingsViewModel.swift */; }; + FEBF7D15E840B97A00EB1FB0 /* SBUMessageThreadViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8F6C581AF86F0FDF7EE97402 /* SBUMessageThreadViewModel.swift */; }; FF353AE4AE2C914789828416 /* CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 8A6B0FBE56B4CC9248A62E08 /* CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift */; }; - FF50672171E8A155132A92B6 /* SBUUtils.swift in Sources */ = {isa = PBXBuildFile; fileRef = 5D61ED359FBDCFE0760CF024 /* SBUUtils.swift */; }; + FF927D3C7D095E9AFE594C3A /* InviteUserView+Item.swift in Sources */ = {isa = PBXBuildFile; fileRef = 9D511342232983FBBE03516A /* InviteUserView+Item.swift */; }; + FFB32DABB639C49C4755DD6F /* SBUMessageSearchViewController.Deprecated.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB4D0C9E36B253F255269B77 /* SBUMessageSearchViewController.Deprecated.swift */; }; FFBFCF90AB4BE89F60BD6C9D /* CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 894840A4B8B0CA19FE1F8552 /* CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift */; }; /* End PBXBuildFile section */ @@ -1097,1074 +1129,1106 @@ /* End PBXCopyFilesBuildPhase section */ /* Begin PBXFileReference section */ - 002B39B769D0499CC67311F8 /* BaseMesssage+SBUIKit.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "BaseMesssage+SBUIKit.Deprecated.swift"; sourceTree = ""; }; - 01014154A6F2DDA514E9AEE6 /* SBUGroupChannelListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 00742C0D576C475B69BDD384 /* SBUTypingIndicatorBubbleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorBubbleView.swift; sourceTree = ""; }; + 0076945EEAFADBBF46EFFA28 /* SBUInviteUserViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserViewModel.swift; sourceTree = ""; }; + 00E512AA6538A2C054A5F952 /* SBUGroupChannelViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewController.Unavailable.swift; sourceTree = ""; }; 014618B2C4618338C8BF4AA6 /* CustomGroupChannelList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 01554179DBF097DA7646B2AE /* SBUMessageTemplate.Coordinator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Coordinator.swift; sourceTree = ""; }; - 015DF3CD2805DA3FED653BA8 /* GroupChannelPushSettingsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelPushSettingsView+ViewConverter.swift"; sourceTree = ""; }; - 016BAC75334B9EECCCDCC68B /* SBUOpenChannelFileMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelFileMessageCell.swift; sourceTree = ""; }; - 020B96FF3BCFE616CFDD5DBC /* SBUBaseSelectUserViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserViewModel.swift; sourceTree = ""; }; + 0198B27F0E6EB85860123E5A /* SendbirdUIKit.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SendbirdUIKit.h; sourceTree = ""; }; + 01FFB98B8DBF2797338BCE5A /* SBUMessageTemplate.Renderer+RenderItems.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+RenderItems.swift"; sourceTree = ""; }; 0243B0EFB1BAEE1DD4F5B8FB /* CustomSampleManager+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CustomSampleManager+SwiftUI.swift"; sourceTree = ""; }; 025010882A64A7618C401C16 /* CustomGroupMutedMemberList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 026199A2CE3A7D4DBA022604 /* UIView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIView+SBUIKit.swift"; sourceTree = ""; }; + 0259861A8497D04AEA7CE0C9 /* SBUForm.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUForm.Deprecated.swift; sourceTree = ""; }; 02676C1FF2C5DD89C779D257 /* CustomOpenModerations.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.swift; sourceTree = ""; }; - 027F5B8FFDDCA7C6C28E4BD7 /* SBUCacheManager.Version.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Version.swift; sourceTree = ""; }; 0283CFAD93FEE4DA37292045 /* SampleListSwiftUI.json */ = {isa = PBXFileReference; lastKnownFileType = text.json; path = SampleListSwiftUI.json; sourceTree = ""; }; + 02844CACFD763E4FA4A29F09 /* SBUFeedNotificationChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.Deprecated.swift; sourceTree = ""; }; + 02860979E56EFC1AF779C802 /* GroupMemberListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListView.swift; sourceTree = ""; }; + 02B0799921F368AB9F43E812 /* SBUTypingMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingMessageCellParams.swift; sourceTree = ""; }; + 02C01C65740D25BBD3D9DD72 /* SBUMessageTemplate.Syntax.Types.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Types.swift; sourceTree = ""; }; 02C174E7957338B3F8329B36 /* CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift; sourceTree = ""; }; + 030585AC870531AD9465859D /* SBUOpenChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; 031A3770C7F979E10B2F46B2 /* CustomOpenModerations.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; 034B7E97A85668F9BF8AE75A /* CustomOpenChannel.ViewConverter.List.senderProfileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.senderProfileImage.swift; sourceTree = ""; }; 0350825D0583AEE1CDC40A22 /* CustomGroupMemberList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; - 0358D88C77E677DC51C6F4F9 /* SBURegisterOperatorModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.List.swift; sourceTree = ""; }; - 03998A9F377AFFC6FB0E69BA /* SBUOpenUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; - 03B00117DFCCB2FF23A6F102 /* SBUMessageInputView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageInputView+SwiftUI.swift"; sourceTree = ""; }; + 035C3F64FE7AAB645C853985 /* SBUError.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUError.swift; sourceTree = ""; }; + 0409D70B90128508F58134CF /* CreateOpenChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateOpenChannelView+Item.swift"; sourceTree = ""; }; + 040FD7FC4D1B4A8EC959975A /* SBUInviteUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUInviteUserCell+SwiftUI.swift"; sourceTree = ""; }; 04561764A6EDAA5F1B379364 /* CustomOpenModerations.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 051BED79FDD0D9A17F350838 /* OpenBannedUserListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenBannedUserListView+ViewConverter.swift"; sourceTree = ""; }; - 05328E6371DCAEDAEF7BB16A /* SBUMessageThreadModule.Input+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadModule.Input+SwiftUI.swift"; sourceTree = ""; }; - 053C0919C7CAED665251B6BA /* GroupChannelSettingsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewConverter.Header.swift; sourceTree = ""; }; - 055A3B07C1A7654608413474 /* SBUForm.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUForm.Deprecated.swift; sourceTree = ""; }; - 05FF389F9A723B77312A0D51 /* SBUChannelInfoHeaderView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelInfoHeaderView.swift; sourceTree = ""; }; - 05FFB56CB1A9AF2AA9EB60A5 /* SBUUserListModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.Deprecated.swift; sourceTree = ""; }; + 045EF0FD06337FF5EA81F035 /* GroupBannedUserListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewProvider.swift; sourceTree = ""; }; + 058F7755FCA9CC99DBB5B468 /* SBUNewNotificationInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNewNotificationInfo.swift; sourceTree = ""; }; + 05EAE6B5A040463C2BCC6878 /* SBUQuotedBaseMessageViewParams.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedBaseMessageViewParams.Deprecated.swift; sourceTree = ""; }; + 05EDD8753FC63FAB2F6E8EA5 /* SBUParentMessageInfoView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUParentMessageInfoView+SwiftUI.swift"; sourceTree = ""; }; 0600F135F1741E465B05B84E /* CustomOpenParticipantList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; 060356821F9B1712D880A550 /* CustomOpenChannel.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 06417874288D6FAD8D6C61E1 /* PrivacyInfo.xcprivacy */ = {isa = PBXFileReference; path = PrivacyInfo.xcprivacy; sourceTree = ""; }; - 0669C29C318DE47185F6859E /* OpenParticipantListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewConverter.List.swift; sourceTree = ""; }; - 06A44B20FC2EFB44267D2F6F /* SBUCreateChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.swift; sourceTree = ""; }; + 062E500577E9F9C767A60C97 /* SBUFileMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFileMessageCellParams.swift; sourceTree = ""; }; + 062F7B69185282C3ADAAEFA9 /* SBUGroupChannelCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelCell+SwiftUI.swift"; sourceTree = ""; }; + 0635067B6F0880D18DE4C6D5 /* SBUFeedbackAction.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedbackAction.swift; sourceTree = ""; }; + 068D92AC2E455E1FB045B5EE /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift"; sourceTree = ""; }; 06BDE87D5391FDB1CC73C1EB /* CustomOpenOperatorList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.SwiftUI.View.Main.swift; sourceTree = ""; }; - 070A17548A8DF7AF1500579B /* SBUGroupChannelListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListViewModel.swift; sourceTree = ""; }; - 074F5995F2755F87CAA18440 /* MessageSearchView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageSearchView+SubViewBuilder.swift"; sourceTree = ""; }; - 075C4E9CEE0C27B851CD533C /* SBUMessageThreadViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadViewController.swift; sourceTree = ""; }; + 06CE16BE3276D48C2D2E44D4 /* VoiceMessageStatus.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = VoiceMessageStatus.swift; sourceTree = ""; }; + 074C60BDD434834C451516D4 /* GroupMutedMemberListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMutedMemberListView+ViewConverter.swift"; sourceTree = ""; }; 07696C2C76138E6C1277A6A4 /* CustomOpenBannedUserList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; - 076B76458F2B9617C69FB28E /* SBUGroupChannelPushSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsViewModel.swift; sourceTree = ""; }; 078067AB981B56743EF32D42 /* CustomGroupMemberList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 07B875B23CC937172B1A0557 /* SBUMessageThreadModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.swift; sourceTree = ""; }; - 07CDB82417CCB1815F880C95 /* SBUOpenChannelCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelCell+SwiftUI.swift"; sourceTree = ""; }; - 08612EE13528E627A17FC38D /* SBURegisterOperatorViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorViewModel.swift; sourceTree = ""; }; - 0862BAC5CCDFC6641C3B97C3 /* SBUOpenChannelSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsViewController.swift; sourceTree = ""; }; - 089EFCFAB4CC0905D70E98F7 /* SBULabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULabel.swift; sourceTree = ""; }; - 08AE1C3D2DAF93702E8C3E6B /* OpenOperatorListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenOperatorListView+SubViewBuilder.swift"; sourceTree = ""; }; + 07C310E48146C5577ED9FBCA /* SBUCacheManager.Image.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Image.swift; sourceTree = ""; }; + 07C8D193A2E09030747F8FF6 /* SBUScrollOptions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUScrollOptions.swift; sourceTree = ""; }; + 08656A9709E292E482DFCDD3 /* SBUFontSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFontSet.swift; sourceTree = ""; }; + 08C31448CE461810A569DE1E /* SBUUserNameView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserNameView.swift; sourceTree = ""; }; 0906752602F6996C99B03220 /* CustomGroupChannelList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 092C81FE6CB8C115FFB896E6 /* SBUVoicePlayer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoicePlayer.swift; sourceTree = ""; }; - 09E6606143A887F262F79FA9 /* SBUMessageFormViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormViewParams.swift; sourceTree = ""; }; 09FB473379288E2643AFD21B /* CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 0A26F750C0BD5F985CE0488F /* OpenModerationsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenModerationsView+SubViewBuilder.swift"; sourceTree = ""; }; - 0A4B1C1EC52CFF027D65EFA5 /* SBUGlobalCustomParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGlobalCustomParams.swift; sourceTree = ""; }; - 0A85529A02737F4F20AFDCA2 /* SBUOpenOperatorListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenOperatorListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 0AACD96B9376174CFA06D9E9 /* OpenModerationsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewConverter.swift; sourceTree = ""; }; + 0A5B0CFDF41FCE53A58D53DB /* SBUVoicePlayer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoicePlayer.swift; sourceTree = ""; }; + 0A957CCD31F05C1FE9E652E2 /* SBUCommonContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonContentView.swift; sourceTree = ""; }; + 0AA30971729AB912E9FC2BB9 /* GroupChannelPushSettingsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewConverter.List.swift; sourceTree = ""; }; + 0AB39B9F7C19B2CB08F1D83F /* OpenChannelSettingsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelSettingsView+SubViewBuilder.swift"; sourceTree = ""; }; 0AB62A723B63530224C5977F /* CustomGroupMemberList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; - 0ADAA8130275C2A217DA88C8 /* OpenMutedParticipantListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenMutedParticipantListView+ViewConverter.swift"; sourceTree = ""; }; - 0AEAE4D3A35CB4AE694FB592 /* SBUMessageInputView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageInputView.swift; sourceTree = ""; }; - 0B26FE8DE186569C5BEFC548 /* SBUCoverImageView.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCoverImageView.Deprecated.swift; sourceTree = ""; }; - 0B43C3575A86FB54C7F46C0C /* SwiftUIViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SwiftUIViewController.swift; sourceTree = ""; }; - 0B70536649E7147BA12EAED3 /* GroupBannedUserListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupBannedUserListView+Item.swift"; sourceTree = ""; }; + 0ACCCEA9CFD52750859279FF /* MessageThreadViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.Header.swift; sourceTree = ""; }; + 0AD34F85878574D07C59C493 /* BaseMesssage+SBUIKit.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "BaseMesssage+SBUIKit.Deprecated.swift"; sourceTree = ""; }; + 0AEA53AA4E09C4C797BD87EE /* SBUStackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUStackView.swift; sourceTree = ""; }; + 0B2C1A70B8458205689EC309 /* SBUOpenChannelCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelCell.swift; sourceTree = ""; }; + 0B333F8593FEB4991E9648B1 /* SBUBaseSelectUserModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserModule.swift; sourceTree = ""; }; 0B7E908DFF59E617F26B85F1 /* CustomSampleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomSampleView.swift; sourceTree = ""; }; 0B8430A4C57FC0EDD8A68A3F /* CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 0B96A9441D86C9B70E7B8FC1 /* SBUGroupChannelModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.Input.swift; sourceTree = ""; }; + 0BCBB1C66BF4FFB629BFCDF1 /* SBUMessageTemplate.Coordinator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Coordinator.swift; sourceTree = ""; }; + 0BDD72D5B40E66A00F22358F /* SBUCacheManager.Config.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Config.swift; sourceTree = ""; }; 0C0B447017B39B7A4378C2C6 /* CustomMessageThread.ViewConverter.Header.subtitleLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Header.subtitleLabel.swift; sourceTree = ""; }; + 0C3FA638C505A1130D29CB79 /* SBUStringSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUStringSet.swift; sourceTree = ""; }; + 0C45A13A56647ADEE8B57C17 /* SBUOpenChannelBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelBaseMessageCell.swift; sourceTree = ""; }; + 0C51254CEED3C799BECECBBA /* SBUOpenModerationsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenModerationsModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 0C7DB64BF6C562A80283A7E6 /* SBUQuotedBaseMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedBaseMessageView.swift; sourceTree = ""; }; + 0CC15B4BBE65B13E5DCABD99 /* SBUMessageWebViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageWebViewModel.swift; sourceTree = ""; }; + 0CC6CC5766E9A4E51E951E69 /* SBUMentionManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMentionManager.swift; sourceTree = ""; }; 0D1728A93ADAD5C8498316FD /* CustomOpenModerations.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.SwiftUI.View.Main.swift; sourceTree = ""; }; + 0D217125A2F37CCE38F58948 /* SBUUnknownMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUnknownMessageCell.swift; sourceTree = ""; }; + 0D2EF85B58A833AF96960622 /* SBUGroupChannelSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsViewController.swift; sourceTree = ""; }; 0D6086A2472531DE282E4A98 /* CustomOpenOperatorList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 0D67908CBFE6F4D1590D22A3 /* SBUGroupUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; - 0D75561E0F23994F2D54F02A /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 0DA777F44C7DE5F2768375B6 /* SBUOpenChannelListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.swift; sourceTree = ""; }; - 0E29F2ED3AC2E2D139EF1814 /* SBUFeedNotificationChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.swift; sourceTree = ""; }; - 0E35F2241D8BFF297E9C7880 /* SBUMessageThreadModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.Input.swift; sourceTree = ""; }; - 0E36DF9938BFB246705DDF39 /* SBUTemplateType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTemplateType.swift; sourceTree = ""; }; - 0E39C7F475F05E20458F1D7C /* SBUPendingMessageManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPendingMessageManager.swift; sourceTree = ""; }; + 0E0914DD583685C5CC8D2419 /* GroupChannelRegisterOperatorView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorView.swift; sourceTree = ""; }; 0E76196CD8391DE9B46E02A8 /* CustomGroupChannelList.SubView.Builder.createChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.SubView.Builder.createChannel.swift; sourceTree = ""; }; - 0E8A575294393A1D7BC34487 /* SBUBaseMessageCell.Feedback.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCell.Feedback.swift; sourceTree = ""; }; + 0EA5BBCE668287248E3E5863 /* SBUMessageTemplateCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCellParams.swift; sourceTree = ""; }; 0EDE250657479E5DFC57BEF3 /* CustomGroupModerations.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.ViewConverter.Header.rightView.swift; sourceTree = ""; }; 0F248FC8980FA08DAAF78C58 /* CustomOpenOperatorList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 0F25A2D259E9D51AC9C71562 /* SBUSuggestedReplyOptionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedReplyOptionView.swift; sourceTree = ""; }; - 0F4C42BBF3DAEC2178B976E9 /* SBUBaseChannelListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListModule.Header.swift; sourceTree = ""; }; + 0F32A69B02CCE4166DE09F9D /* OpenOperatorListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenOperatorListView+SubViewBuilder.swift"; sourceTree = ""; }; 0F4F269E21BC1771EA562A1E /* CustomMessageThread.ViewConverter.Input.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Input.entireView.swift; sourceTree = ""; }; - 0FA34F6AA2F8B23B93236BF1 /* SBUGroupChannelCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelCell+SwiftUI.swift"; sourceTree = ""; }; - 0FB5A38900DB0EB791444A96 /* SBUInviteUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUInviteUserCell+SwiftUI.swift"; sourceTree = ""; }; + 0F519A11E20B608D84165E59 /* GroupMemberListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMemberListView+Item.swift"; sourceTree = ""; }; + 0F8BCC1FD155F0E5F9AC2C3D /* GroupChannelListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewProvider.swift; sourceTree = ""; }; 0FC471844F62DAC68F852859 /* CustomOpenChannel.ViewConverter.Input.sendButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Input.sendButton.swift; sourceTree = ""; }; - 10245F542657CABD9F636A3D /* SBUOpenChannelBaseMessageCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelBaseMessageCell+SwiftUI.swift"; sourceTree = ""; }; + 0FD1533E6A37B61095F3D3F8 /* MessageSearchViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewConverter.Header.swift; sourceTree = ""; }; + 0FD503C5B7F8CDFB80C1888F /* SBUBaseChannelSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsModule.swift; sourceTree = ""; }; 1072BE53AA3569B9742E724E /* CustomGroupBannedUserList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 118B3013D694187D3BA0B6CC /* GroupChannelViewConverter.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.Input.swift; sourceTree = ""; }; + 108B741FE9BECCEB02800C52 /* SBUSuggestedReplyViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedReplyViewParams.swift; sourceTree = ""; }; + 10D4FAE80AC3E74AA8159C06 /* Collection+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Collection+SBUIKit.swift"; sourceTree = ""; }; + 11507F4DAA42980635F9C12E /* SBUMessageThreadTitleView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadTitleView+SwiftUI.swift"; sourceTree = ""; }; + 116A35DCB844940ACC55AFA0 /* OpenOperatorListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenOperatorListView+Item.swift"; sourceTree = ""; }; + 11DF0BD15A442817BB746609 /* UIFont+Sendbird.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIFont+Sendbird.swift"; sourceTree = ""; }; 11EC6E379AF8CC994489450D /* CustomInviteUser.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 1223F79CC60D5AB916A3204B /* GroupChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelView.swift; sourceTree = ""; }; 1236AC76A91CA191083672C5 /* CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 1243D603EB01314B012C1D6E /* OpenMutedParticipantListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewConverter.List.swift; sourceTree = ""; }; - 1286E9C8A5FDC69006356104 /* UIImage+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIImage+SBUIKit.swift"; sourceTree = ""; }; - 12DC37AE9F9A2EAAB346B524 /* OpenParticipantListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenParticipantListView+ViewConverter.swift"; sourceTree = ""; }; - 130BDF243558344563BDD04F /* SBUMessageTemplate.Container.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Container.swift; sourceTree = ""; }; - 1332D36686F1F249E74B711C /* SBUUserListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListViewModel.swift; sourceTree = ""; }; + 12DF34E19AD9277AABB197A4 /* SBUModerationsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.swift; sourceTree = ""; }; 138034D59666A1D306B840DA /* CustomGroupChannelSettings.ViewConverter.List.member.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.member.swift; sourceTree = ""; }; - 13A39F0CA1ACC3DC69F56F19 /* SBUGroupChannelPushSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsViewController.swift; sourceTree = ""; }; - 13C1A9FF2EF8EC07A88DF01C /* SBUViewLifeCycle.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewLifeCycle.swift; sourceTree = ""; }; - 13DE0F9AF0C8495874233F35 /* SBUNotificationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationCell.swift; sourceTree = ""; }; - 14693ACB733109628B1E5244 /* SBUOpenModerationsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenModerationsModule.List+SwiftUI.swift"; sourceTree = ""; }; + 13DE9BE7EA1E8EA4077C9689 /* MessageThreadViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.List.swift; sourceTree = ""; }; + 149EF5C6D56F66FA509EA283 /* SBUGroupChannelModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelModule.List+SwiftUI.swift"; sourceTree = ""; }; + 14A5CBF9A05A44B87429CDCC /* FontSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FontSet.swift; sourceTree = ""; }; 14EA076EB6C73BA4290914FE /* CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 14EB76F7DCFDA115FA759567 /* SBUNewMessageInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNewMessageInfo.swift; sourceTree = ""; }; - 1500B8E9713683B07753569C /* SBUModerationsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewController.swift; sourceTree = ""; }; + 151589C04C2127E51ABCF91D /* SBUGroupChannelListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.Header.swift; sourceTree = ""; }; + 15269264474C5B46CF1910BE /* SBUInviteUserModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUInviteUserModule.List+SwiftUI.swift"; sourceTree = ""; }; 1594F63CF9E5FDE4E1A20E4E /* CustomOpenBannedUserList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 15CFF068B647DF41C757A688 /* ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewConverter.swift; sourceTree = ""; }; - 15D0C93348560E6639D9887F /* GroupChannelListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewConverter.swift; sourceTree = ""; }; - 15E7A0A982529296BD896B07 /* SBUCreateOpenChannelModule.ProfileInput.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.ProfileInput.swift; sourceTree = ""; }; - 15F63FC3018647E421EC68B1 /* SBUQuotedBaseMessageViewParams.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedBaseMessageViewParams.Deprecated.swift; sourceTree = ""; }; - 1613A81DAF0386D295401F59 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelRegisterOperatorView+SubViewBuilder.swift"; sourceTree = ""; }; - 166A655BEA90071D890FE83F /* SBUBarButtonItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBarButtonItem.swift; sourceTree = ""; }; - 16A073C3C063FECB43EE3886 /* SBUInviteUserViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserViewController.swift; sourceTree = ""; }; - 16B94B84000BF8542CAE6747 /* SBUGroupChannelSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsViewModel.swift; sourceTree = ""; }; - 16C4D273B7FFFD441AC2D664 /* SBUCommonContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonContentView.swift; sourceTree = ""; }; - 16D3BFEEF9AF232331AE1BDC /* InviteUserView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserView.swift; sourceTree = ""; }; + 15BCA0CEA4BD6AC0AF9F5E93 /* SBUConfig.OpenChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.OpenChannel.swift; sourceTree = ""; }; + 15FB5DC297BFAC6381342D85 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelSettingsModule.List+SwiftUI.swift"; sourceTree = ""; }; + 15FB7D893238C88344868AD0 /* SBUChatNotificationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationCell.swift; sourceTree = ""; }; + 167486D0234433BF424AD399 /* UITableView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UITableView+SBUIKit.swift"; sourceTree = ""; }; + 167B8A4B458413D2B4C5F591 /* Sequence+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Sequence+SBUIKit.swift"; sourceTree = ""; }; 172802894396063C49F84236 /* CustomOpenChannel.ViewConverter.List.adminMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.adminMessageView.swift; sourceTree = ""; }; + 1729EF71A43A28ABF375F9A0 /* SBUGroupChannelListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListViewController.swift; sourceTree = ""; }; + 1758AEB45338E3698851ED34 /* SBUChannelStateBanner+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUChannelStateBanner+SwiftUI.swift"; sourceTree = ""; }; + 17D4DB776814E712BA3D522E /* OpenModerationsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenModerationsView+Item.swift"; sourceTree = ""; }; + 183C845EEBFBD4DF24DBFAF5 /* SBUCacheManager.File.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.File.swift; sourceTree = ""; }; 18AA52A71ED80E2FE000C626 /* CustomGroupChannel.ViewConverter.Input.voiceButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Input.voiceButton.swift; sourceTree = ""; }; + 18C1C60E4B404A088689D1E8 /* OpenChannelSettingsViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewProvider.swift; sourceTree = ""; }; 18DAC3A6A235AF92E38CC492 /* CustomGroupChannel.ViewConverter.Input.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Input.leftView.swift; sourceTree = ""; }; + 18FD3B37FC9DE267350E60D6 /* SBUGroupChannelSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsViewModel.swift; sourceTree = ""; }; 192CDCD51D4B579E3E82C6CF /* QuickStartSwiftUI.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = QuickStartSwiftUI.entitlements; sourceTree = ""; }; - 194EB3991201611697330E0D /* SBUMentionLimitGuideCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMentionLimitGuideCell.swift; sourceTree = ""; }; - 1956667B2BEFE9115DC6BDAE /* SBUMessageThreadViewController.SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadViewController.SwiftUI.swift; sourceTree = ""; }; - 1992BFA4DDDB1636ACFF4A97 /* OpenParticipantListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenParticipantListView+Item.swift"; sourceTree = ""; }; - 19A3BDA35036947D712CB9E1 /* SBUExtendedMessagePayload.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUExtendedMessagePayload.swift; sourceTree = ""; }; - 19CC6B675B71533BB7EFA604 /* Closure.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Closure.swift; sourceTree = ""; }; - 19CEBE4C850E10CB4FDA7B68 /* SBUGroupChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.List.swift; sourceTree = ""; }; + 195059F9729364314EB88550 /* SBUQuoteMessageInputViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuoteMessageInputViewParams.swift; sourceTree = ""; }; + 198642EB3A0DA4073E11FBBE /* OpenBannedUserListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenBannedUserListView+Item.swift"; sourceTree = ""; }; + 198F31B87E693C7FA29E1A38 /* SBUToastView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastView.swift; sourceTree = ""; }; + 19B6DCAB9B843572847D9FA6 /* OpenModerationsViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewProvider.swift; sourceTree = ""; }; 19D2EEBE03F849746DDD0E0D /* SwiftUINotificationService.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = SwiftUINotificationService.entitlements; sourceTree = ""; }; - 19D36786FC47C674BC286A36 /* GroupChannelPushSettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsView.swift; sourceTree = ""; }; - 19E5681F3154A4F68F3F2C2E /* SBUGroupChannelModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelModule.List+SwiftUI.swift"; sourceTree = ""; }; + 19F7CEEE95BBF13CB214CF41 /* SBUGroupChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewController.Deprecated.swift; sourceTree = ""; }; + 1A01964E8998FC11F82F7F27 /* SBUGroupChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.Deprecated.swift; sourceTree = ""; }; 1A44E48D1D24AA8A93786370 /* CustomGroupOperatorList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 1A947D09517B73A703E1A7F0 /* GroupBannedUserListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewConverter.swift; sourceTree = ""; }; + 1A8DD774054C5168961DF04B /* GroupChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.swift; sourceTree = ""; }; + 1AE76A1AE751AA26FFB13901 /* GroupChannelSettingsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewConverter.Header.swift; sourceTree = ""; }; 1AF8CB593FE2D4951A3ED114 /* UserNotifications.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = UserNotifications.framework; path = System/Library/Frameworks/UserNotifications.framework; sourceTree = SDKROOT; }; - 1B4A8280119033D9FB86B458 /* SBUParentMessageInfoView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUParentMessageInfoView+SwiftUI.swift"; sourceTree = ""; }; - 1BD8C3C6E22B76ECEA6DC1DB /* MessageTemplateTestViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageTemplateTestViewController.swift; sourceTree = ""; }; - 1C19B6EF4242A39ED9990598 /* GroupChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.Header.swift; sourceTree = ""; }; - 1C1C132A58903724C8A1FA14 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateGroupChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 1C984E50160373E12FA0438E /* SBUCreateOpenChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelViewModel.swift; sourceTree = ""; }; + 1BB7510F2315F0AA6E215A4B /* SBUModuleSet.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModuleSet.Deprecated.swift; sourceTree = ""; }; + 1CAA39A852B107E285CE001B /* SBUModerationsViewModel.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewModel.Deprecated.swift; sourceTree = ""; }; 1CB771DC92339EE331D47DBD /* CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; - 1CD45E3398D54B7995E3867F /* SBUUnknownMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUnknownMessageCell.swift; sourceTree = ""; }; - 1CE8943E2D24A159FAE8A666 /* SBUMessageThreadTitleView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadTitleView+SwiftUI.swift"; sourceTree = ""; }; - 1D0C5587D78DE4FF38CD361A /* SBUThreadInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUThreadInfoView.swift; sourceTree = ""; }; - 1D0F53258EBF6406A01FBE22 /* SBUBaseChannelViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.Unavailable.swift; sourceTree = ""; }; + 1CED8D3880DEF2156A3DB5CC /* InviteUserView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "InviteUserView+ViewConverter.swift"; sourceTree = ""; }; + 1CF9D34BCB427438C4E21B0B /* SBUChannelTitleView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUChannelTitleView+SwiftUI.swift"; sourceTree = ""; }; + 1D26DE3887547F356A14F016 /* OpenChannelSettingsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewConverter.List.swift; sourceTree = ""; }; 1D2EAD5AE3B031549D4E8E9D /* CustomMessageThread.ViewConverter.List.senderProfileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.senderProfileImage.swift; sourceTree = ""; }; 1D38AA27BCCE944F35F787E7 /* CustomGroupChannel.ViewConverter.Header.coverImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Header.coverImage.swift; sourceTree = ""; }; + 1D79AE410C0225BF9B73BD23 /* SBUUserCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserCell.swift; sourceTree = ""; }; 1DA1AD0747C09319189DDF68 /* CustomGroupMemberList.ViewConverter.List.operatorStateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.List.operatorStateView.swift; sourceTree = ""; }; - 1DB8F69105F07B296E8C63F7 /* SBUFormViewParams.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFormViewParams.Deprecated.swift; sourceTree = ""; }; - 1DDB1C8B0B6F4041F5B74E5F /* Collection+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Collection+SBUIKit.swift"; sourceTree = ""; }; - 1DEBA9D64BDD959D8117D5C8 /* Date+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Date+SBUIKit.swift"; sourceTree = ""; }; - 1E15C3CDDBC6D533E0C64E57 /* SBUMessageSearchResultCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchResultCell.swift; sourceTree = ""; }; - 1E4836735A03C7E6A5A5E1C0 /* OpenMutedParticipantListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewConverter.swift; sourceTree = ""; }; - 1E787BE5CA17742F73854520 /* SBUGroupUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 1E9F07C7C0780B668356ECFF /* SBUGroupChannelSettingsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.Deprecated.swift; sourceTree = ""; }; + 1DC014816EBFF2C90B439FEF /* OpenBannedUserListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewConverter.Header.swift; sourceTree = ""; }; + 1E46BB57B23AA2CB9528366B /* SBUMessageCellProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageCellProtocol.swift; sourceTree = ""; }; + 1F2F32D7E4883A0DAA8DB902 /* SBUMessageTemplate.ErrorMessages.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.ErrorMessages.swift; sourceTree = ""; }; 1F40D34A8DAA0338D60BCC95 /* CustomOpenBannedUserList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; + 1F414EE8A18D12F1A90F406E /* SBUImageContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUImageContentView.swift; sourceTree = ""; }; + 1FA72B8958F28537FDA7ACFE /* SBUCreateGroupChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateGroupChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; 1FB96424E98E120EA6E8856A /* CustomMessageThread.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 1FDD8BBDA06606723A4BD18E /* OpenOperatorListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewConverter.Header.swift; sourceTree = ""; }; - 2051F6EC7AA67803BA3D91FC /* OpenParticipantListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListView.swift; sourceTree = ""; }; - 20F4251E92AEC8A7056D747A /* CreateGroupChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewConverter.swift; sourceTree = ""; }; - 210AF12A14FCE17C47355C30 /* SBUCreateGroupChannelUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateGroupChannelUserCell+SwiftUI.swift"; sourceTree = ""; }; + 207182002E1CFAE44F7484F7 /* SBUOpenChannelContentBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelContentBaseMessageCell.swift; sourceTree = ""; }; + 20731A3A1048D4D869625C6F /* GroupMemberListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewConverter.List.swift; sourceTree = ""; }; + 20B52D131C6D75296798238F /* CustomGroupChannel.SwiftUI.View.ViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.SwiftUI.View.ViewProvider.swift; sourceTree = ""; }; + 21050C5DF391743F4A7D9825 /* MessageThreadView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageThreadView+ViewConverter.swift"; sourceTree = ""; }; + 210E248F9D2CF51D4B837AE2 /* MessageSearchView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageSearchView+ViewConverter.swift"; sourceTree = ""; }; 21145BF3F3E645DAC712F358 /* CustomGroupChannel.ViewConverter.List.senderProfileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.senderProfileImage.swift; sourceTree = ""; }; + 213BF3497B6FD30B17654CF0 /* GroupChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.Header.swift; sourceTree = ""; }; + 214A494A609C5A22C2BB8AA7 /* SBUFeedNotificationChannelViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelViewParams.swift; sourceTree = ""; }; 21CB4AD0ED1AB4BA1550A685 /* CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; + 21ECDE889CE936449AE9DBFD /* OpenParticipantListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListView.swift; sourceTree = ""; }; 2232894B6B82C593EACB9AF8 /* CustomGroupBannedUserList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 224DFC32A8DFF7FCAE9B3585 /* SBUAdminMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAdminMessageCellParams.swift; sourceTree = ""; }; - 229772D9190CF57D0E32B7D2 /* SBUMultipleFilesMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCell.swift; sourceTree = ""; }; + 2282B01F493BF02C9708B2F8 /* GroupChannelPushSettingsViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewProvider.swift; sourceTree = ""; }; + 228FA3A4F2C3475CD28C3D23 /* SBUUtils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUtils.swift; sourceTree = ""; }; 22F1260D9E0F6882210913EA /* CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; 22F8DAE624B591D4CFCCAA01 /* CustomMessageSearch.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 2312B56E1998FE3473D42757 /* SBUOpenChannelAdminMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelAdminMessageCell.swift; sourceTree = ""; }; - 24001A687A99EDBCB633CFD9 /* SBUUserProfileView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserProfileView.swift; sourceTree = ""; }; + 2303751640029A1195FA8663 /* OpenChannelListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelListView+SubViewBuilder.swift"; sourceTree = ""; }; + 2307E41DDDA61CF29EB83335 /* GroupBannedUserListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupBannedUserListView+ViewConverter.swift"; sourceTree = ""; }; 2402CB59A675E428278E27B6 /* OpenChannelsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelsView.swift; sourceTree = ""; }; - 2435FE6370AF68E18F345DD8 /* UIButton+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIButton+SBUIKit.swift"; sourceTree = ""; }; 2443ED212D4BF7E2A647104F /* CustomGroupChannelList.SubView.Builder.groupChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.SubView.Builder.groupChannel.swift; sourceTree = ""; }; + 244EE344C8E75A091EAECD86 /* SBUEnums.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEnums.swift; sourceTree = ""; }; + 246C6675D850EA56F58871FC /* SBUBaseMessageCell.Feedback.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCell.Feedback.swift; sourceTree = ""; }; 24823518A52E6BB53C899607 /* CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 248481420F458F58CA0D9E6F /* SBUMessageTemplate.Renderer+RenderItems.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+RenderItems.swift"; sourceTree = ""; }; - 24B1972F020FD19FB7A7E8D8 /* OpenChannelListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewConverter.swift; sourceTree = ""; }; - 24FA1C9F270095F0BBE68991 /* SBULoading.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULoading.swift; sourceTree = ""; }; + 24F167651C8FE9886C4D02D6 /* Date+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Date+SBUIKit.swift"; sourceTree = ""; }; 2535A08EF2BFD8F5B95990E8 /* CustomGroupChannel.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.SwiftUI.View.Main.swift; sourceTree = ""; }; 254B1E417C819DCD58A83742 /* CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift; sourceTree = ""; }; - 256F0FE776E5E6572F47D96A /* SBUAdminMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAdminMessageCell.swift; sourceTree = ""; }; - 25858342E4D2B978B8BAD861 /* SBUOpenChannelModule.Media.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Media.swift; sourceTree = ""; }; - 26570397B1DC53048CF4E0D0 /* SBUBaseChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.Header.swift; sourceTree = ""; }; - 2667B362F8DD00A36E0A5C00 /* SBUTemplateLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTemplateLabel.swift; sourceTree = ""; }; + 2664B443F513C3E12BD8C350 /* SBViewConverterSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBViewConverterSet.swift; sourceTree = ""; }; 266967BFCE2D21AC989E71CD /* CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift; sourceTree = ""; }; - 26E081F853537DD71E0BC25F /* SBUMessageTemplate.Payload.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Payload.swift; sourceTree = ""; }; + 2689FD4A0398FE01DD24BCF2 /* SBUBaseSelectUserViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserViewController.swift; sourceTree = ""; }; + 26A32BBCC22F6F9C43CE2299 /* GroupMemberListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMemberListView+ViewConverter.swift"; sourceTree = ""; }; 26EECBA4BF71E97955C63A32 /* CustomGroupChannel.ViewConverter.List.channelStateBanner.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.channelStateBanner.swift; sourceTree = ""; }; - 27093994AF106EAB97B7F24D /* SBUMessageSearchModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.Deprecated.swift; sourceTree = ""; }; 274069D20D2F3B5E40ADC2D2 /* CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 274DE7206A600067D64B8AF8 /* OpenChannelSettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsView.swift; sourceTree = ""; }; - 2752645C33797142AEE30A20 /* SBUTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTextView.swift; sourceTree = ""; }; + 2769D3BC0129E975B6946A2C /* GroupMutedMemberListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMutedMemberListView+SubViewBuilder.swift"; sourceTree = ""; }; + 278A681D06BDAF42A5A4A6D6 /* OpenChannelRegisterOperatorView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelRegisterOperatorView+ViewConverter.swift"; sourceTree = ""; }; 279B0E88887FD0F09FD5290E /* CustomGroupMemberList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.List.rowView.swift; sourceTree = ""; }; 279B677541AB48613E5A2EA8 /* CustomOpenChannelSettings.SubView.Builder.moderations.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.SubView.Builder.moderations.swift; sourceTree = ""; }; - 27C26C3082D49E50ADAB0561 /* SBUBaseChannelListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListViewModel.swift; sourceTree = ""; }; 27D1D6BA515FD2C31FF5DF98 /* CustomGroupChannel.ViewConverter.List.userMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.userMessageView.swift; sourceTree = ""; }; - 27F66C34721B8052037668EF /* SBUFileMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFileMessageCell.swift; sourceTree = ""; }; - 28404C050D7E597FB4DF7837 /* CreateOpenChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateOpenChannelView+SubViewBuilder.swift"; sourceTree = ""; }; - 285695471DE00B5F03AF5665 /* NSObject+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "NSObject+SBUIKit.swift"; sourceTree = ""; }; - 2938701A69B6EA5F371B33A0 /* SBUMessageTemplate.Decoders.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Decoders.swift; sourceTree = ""; }; + 2881A84C01CB255EE1976829 /* CreateOpenChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelViewConverter.swift; sourceTree = ""; }; + 28A2E22DD48A106F4586D002 /* GroupChannelSettingsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelSettingsView+ViewConverter.swift"; sourceTree = ""; }; + 2949F2DE8EFDD9154DC2E2E9 /* SBUConfig.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.swift; sourceTree = ""; }; + 2998E5B0A2F8028DC20D9D04 /* MessageSearchViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewConverter.swift; sourceTree = ""; }; 2998E5D033EA7F13FC35ECFF /* CustomOpenChannelSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.swift; sourceTree = ""; }; 29996001A7AE321A2AF1FDE8 /* CustomGroupBannedUserList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.SwiftUI.View.Main.swift; sourceTree = ""; }; 29A8E469FDC1391368051BBF /* NotificationService.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NotificationService.swift; sourceTree = ""; }; 29C09A758F4B4E167933E832 /* CustomGroupMemberList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.swift; sourceTree = ""; }; - 29C37028F3734AF788C0631C /* MessageSearchView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageSearchView+ViewConverter.swift"; sourceTree = ""; }; - 29F879C5B05E8718BA713CED /* GroupChannelSettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsView.swift; sourceTree = ""; }; - 2A07D10F3965FA8EFDD720D6 /* MessageSearchViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewConverter.Header.swift; sourceTree = ""; }; - 2A72C6155A43F6C1095DF84B /* SendbirdUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SendbirdUI.swift; sourceTree = ""; }; - 2AB52183CDCA494948E5976E /* SBUUserMessageTextViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageTextViewModel.swift; sourceTree = ""; }; - 2B3BA29A37C81D499E354EB4 /* OpenChannelRegisterOperatorView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelRegisterOperatorView+ViewConverter.swift"; sourceTree = ""; }; + 29FE8D858AD7C69E3B2FF2EE /* SBUMessageFormView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormView.swift; sourceTree = ""; }; + 2A29132CC8E88EB608B11887 /* SBUGroupChannelPushSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsViewController.swift; sourceTree = ""; }; + 2A62CCCCB59301329BD70E3D /* SBUOpenChannelSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsViewModel.swift; sourceTree = ""; }; + 2ADEBE78ECAF2FB8B6CD1A96 /* SBUDownloadManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDownloadManager.swift; sourceTree = ""; }; + 2AF37FB8A55745647820E475 /* SBUBarButtonItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBarButtonItem.swift; sourceTree = ""; }; + 2AFB3ABEC66B7B5DF2B1C6C1 /* SBUDashboardConfig.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDashboardConfig.swift; sourceTree = ""; }; 2B41B61973E52E8F8B861399 /* CustomCreateOpenChannel.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 2BCED6324E56293CB6D4F266 /* SBUTypingIndicatorMessageManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorMessageManager.swift; sourceTree = ""; }; + 2B50481174F97B1EE25DA725 /* Sendbird.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Sendbird.swift; sourceTree = ""; }; + 2B719C1C7BCA50103B2FD33F /* CreateGroupChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateGroupChannelView+SubViewBuilder.swift"; sourceTree = ""; }; + 2B9F8C9272B19A196F85B9F1 /* SBUOpenChannelUnknownMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelUnknownMessageCell.swift; sourceTree = ""; }; + 2BA1A976DF480A02EAAA44B9 /* SBUMultipleFilesMessageCollectionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCollectionView.swift; sourceTree = ""; }; + 2BAFD80BA871EC59725EC7AC /* MessageThreadView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageThreadView+SubViewBuilder.swift"; sourceTree = ""; }; + 2BCB5EB5A43E374C6E5D2743 /* SBUMessageThreadModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.Deprecated.swift; sourceTree = ""; }; 2BD3F92049FFA549EE2A62ED /* CustomOpenParticipantList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 2C15ED108FD8018112C6E8B7 /* SBUError.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUError.swift; sourceTree = ""; }; - 2C29B6EED1FE32956FF834A8 /* SBURegisterOperatorModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.Deprecated.swift; sourceTree = ""; }; - 2C593374BB12107EC560C715 /* StringProtocol+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "StringProtocol+SBUIKit.swift"; sourceTree = ""; }; - 2C6C9F8F3C88F07B39F5C385 /* SBUMessageTemplate.Syntax.Styles.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Styles.swift; sourceTree = ""; }; + 2C4D064E91A746BEA570EA54 /* SBUMessageSearchModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.List.swift; sourceTree = ""; }; 2C7FC20BFBCA4BB020D0A532 /* CustomGroupMutedMemberList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.swift; sourceTree = ""; }; - 2CC3E6F72DBC8FEE5B5FF69A /* SBUMessageTemplate.TemplateList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.TemplateList.swift; sourceTree = ""; }; - 2D33147A10A17DE06274D98B /* SBUChannelSettingsChannelInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelSettingsChannelInfoView.swift; sourceTree = ""; }; - 2D485B6D4BF580481E4D1D72 /* View + ViewModifier.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "View + ViewModifier.swift"; sourceTree = ""; }; - 2D5AFECAA4BF9BA8AD3B0F71 /* GroupBannedUserListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupBannedUserListView+ViewConverter.swift"; sourceTree = ""; }; - 2D62381A39883A6AF9749655 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 2DA6787A21BBB0988131D241 /* OpenMutedParticipantListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenMutedParticipantListView+SubViewBuilder.swift"; sourceTree = ""; }; - 2DAAF41FC4C94DDFA9DB7794 /* SBUCollectionViewFlowLayout.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCollectionViewFlowLayout.swift; sourceTree = ""; }; + 2D275616CF2FFE31313FF15B /* SBUCacheManager.NotificationSetting.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.NotificationSetting.swift; sourceTree = ""; }; + 2D8E1428454BAB2823888AD1 /* SBUHorizontalSuggestedReplyOptionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUHorizontalSuggestedReplyOptionView.swift; sourceTree = ""; }; 2E2404EBE71135A247419F81 /* CustomGroupChannelSettings.ViewConverter.List.searchItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.searchItem.swift; sourceTree = ""; }; - 2EC18DF4ECCF42C69B1DE4E3 /* SBUCacheManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.swift; sourceTree = ""; }; + 2E24797172C62D7225E0F118 /* OpenMutedParticipantListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewConverter.swift; sourceTree = ""; }; + 2E2769B561909503AB35C646 /* OpenOperatorListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewConverter.Header.swift; sourceTree = ""; }; + 2E3A3342AEA6256BC66D30A3 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelRegisterOperatorView+SubViewBuilder.swift"; sourceTree = ""; }; + 2E62CC4F6BA3B54579233BFE /* SBUUserListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.swift; sourceTree = ""; }; + 2E730A218995750A20EC764A /* SBUBaseChannelListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListModule.swift; sourceTree = ""; }; + 2E9AABB7CE646ADCDF873887 /* SBUNotificationTimelineView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationTimelineView.swift; sourceTree = ""; }; + 2EC4CB40DFDCDAA8D8D03164 /* GroupChannelSettingsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelSettingsView+SubViewBuilder.swift"; sourceTree = ""; }; + 2ECACCFCA2492AB6CF181E9B /* OpenModerationsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenModerationsView+SubViewBuilder.swift"; sourceTree = ""; }; 2EE881D701BE62C2C5A1297C /* CustomOpenChannelSettings.SubView.Builder.userList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.SubView.Builder.userList.swift; sourceTree = ""; }; 2EF0CBE3236AA5C29F96124D /* CustomOpenChannel.SubView.Builder.userList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.SubView.Builder.userList.swift; sourceTree = ""; }; - 2F5596CBB3FB434BE59F8BBA /* GroupMemberListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMemberListView+Item.swift"; sourceTree = ""; }; - 2F7CFF8FDC3CA84CA743B250 /* SBUMessageTemplateCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCell.swift; sourceTree = ""; }; - 2F88656EDE7A31FD01B7ED7D /* SBUChatNotificationChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.Deprecated.swift; sourceTree = ""; }; - 2FF459520D3ED7BBC083BB7E /* SBUEnums.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEnums.swift; sourceTree = ""; }; - 30394872D50BA64B985DA1FF /* OpenChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelView.swift; sourceTree = ""; }; - 304A09ECDE1B9834CD9A4E19 /* SBUBaseChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewModel.swift; sourceTree = ""; }; + 2F02C24F1081B38C6BBB9B3A /* GroupChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelView+ViewConverter.swift"; sourceTree = ""; }; + 2F648AC1BF4B63CC9EDF30CF /* MessageForm+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageForm+SBUIKit.swift"; sourceTree = ""; }; + 2FEFD91414F95FB42FCF2FB1 /* SBUOpenUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 3002316F9F925813729C3DE0 /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 3046107CAA8EAABF90DD8218 /* SBUMultipleFilesMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCellParams.swift; sourceTree = ""; }; 3063FC91B4A7751B29DC80B1 /* CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 3064CE17D9A94272F21E223E /* UICollectionView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UICollectionView+SBUIKit.swift"; sourceTree = ""; }; - 30D114A3FEC7A9B2EC46E9EE /* SBUUnderLineTextField.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUnderLineTextField.swift; sourceTree = ""; }; 310897972F208CD1051FDB43 /* CustomGroupChannelList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; + 31220D4260D422D89BA59FD3 /* SBUBaseChannelListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListViewModel.swift; sourceTree = ""; }; 315F7B885B880AEE8C60AC67 /* CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; + 3168D719E8C0DBF32138DBD9 /* SBUMessageTemplate.Renderer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.swift; sourceTree = ""; }; 3180CCA4DF7E2B5F60580C79 /* CustomOpenChannel.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.rowView.swift; sourceTree = ""; }; + 3193B2D263F3D9CA56150766 /* GroupBannedUserListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewConverter.swift; sourceTree = ""; }; + 31EBBEC705350486B5A9DBC6 /* SBUMenuView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMenuView.swift; sourceTree = ""; }; 3225F148DEE17564551340F3 /* CustomGroupBannedUserList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.swift; sourceTree = ""; }; - 326E8DC6D22782968571F3EC /* ViewControllerTypeProtocol + swiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "ViewControllerTypeProtocol + swiftUI.swift"; sourceTree = ""; }; 328595E958E75E652E64F839 /* CustomMessageThread.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.swift; sourceTree = ""; }; - 32F2AF6630757800DFF08628 /* SBUBaseFileContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseFileContentView.swift; sourceTree = ""; }; + 32A81BB37AE3190F7AD09F77 /* SBUMessageSearchModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.Deprecated.swift; sourceTree = ""; }; 3300D14C142B4740F0438811 /* CustomGroupChannelSettings.SubView.Builder.moderations.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.SubView.Builder.moderations.swift; sourceTree = ""; }; - 33A19DC31A19B9871C014844 /* SBUVoiceMessageConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceMessageConfiguration.swift; sourceTree = ""; }; - 33B515D9E7A6C9C304D30F5F /* SBUModerationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationCell.swift; sourceTree = ""; }; + 33552F4E4E45108163CF3CAC /* SBUModerationsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewController.swift; sourceTree = ""; }; 33DDBE877B5BABC51BD08FE9 /* CustomCreateOpenChannel.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 3407D92E992D53C7D02B7CB3 /* Formatter+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Formatter+SBUIKit.swift"; sourceTree = ""; }; + 33FAB263E1745861F9AD0B26 /* CommonProtocols.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CommonProtocols.swift; sourceTree = ""; }; + 34127F637D9BA4589A5E73CB /* SBUMessageThreadModule.Input+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadModule.Input+SwiftUI.swift"; sourceTree = ""; }; + 3442BED25FDD54492980D099 /* CreateGroupChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateGroupChannelView+Item.swift"; sourceTree = ""; }; 344A9753F8B782EDD9E411B6 /* CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 344AF01876274CF324237E4D /* SBUMessageTemplate.Renderer+Events.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+Events.swift"; sourceTree = ""; }; 3453123508BA0620302C5095 /* CustomInviteUser.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 345A88D14A3A5E57A00414FA /* SBUGroupModerationsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupModerationsModule.List+SwiftUI.swift"; sourceTree = ""; }; + 3478D6F58D07B41B64C21B46 /* SBUBaseMessageCellParams.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCellParams.Deprecated.swift; sourceTree = ""; }; + 349C18C1DC887172FCB29311 /* GroupModerationsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupModerationsView+ViewConverter.swift"; sourceTree = ""; }; 34DF51D99B16E5DE6AF5DE56 /* CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift; sourceTree = ""; }; + 34ED39256240C5DA35BDC807 /* SBUGroupChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; 3518C56DA60C12F9CEB9E407 /* CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; - 35595546721F0FD423B8D80F /* SBUEmojiListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEmojiListViewController.swift; sourceTree = ""; }; - 3575D8324F8DCEC741A02E9C /* MessageThreadViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.Header.swift; sourceTree = ""; }; - 3580081863865A49C61883FE /* GroupChannelRegisterOperatorView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelRegisterOperatorView+ViewConverter.swift"; sourceTree = ""; }; - 361AEE3CF32E940D61DDCF69 /* OpenChannelListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListView.swift; sourceTree = ""; }; - 367715EF02DB7B56C38D52A8 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelPushSettingsModule.List+SwiftUI.swift"; sourceTree = ""; }; + 3564A850E6E29401E0BE3E5A /* OpenParticipantListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewConverter.List.swift; sourceTree = ""; }; + 35900F9772C3BD6331D81176 /* SBUFeedNotificationChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.List.swift; sourceTree = ""; }; + 35ACD3293ECBD4E4344CB186 /* SBUBaseChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.Deprecated.swift; sourceTree = ""; }; + 35B171FF6F71B428F421E126 /* SBUOpenChannelInputView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelInputView+SwiftUI.swift"; sourceTree = ""; }; + 36069F6F9F98006B014805FE /* SBUUserListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListViewModel.swift; sourceTree = ""; }; + 361730BCE391F1EC0B386A82 /* UIButton+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIButton+SBUIKit.swift"; sourceTree = ""; }; 3689A9086F74AAAEAB2FC8F7 /* CustomOpenChannelList.SubView.Builder.createChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.SubView.Builder.createChannel.swift; sourceTree = ""; }; - 36D398420F97BA15C888FA6E /* GroupBannedUserListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListView.swift; sourceTree = ""; }; - 3705CC5FA738AA9FAB298E7D /* SBUGroupChannelSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingCell.swift; sourceTree = ""; }; - 3716519FE7F6D63C6FE4A48A /* SBUOpenChannelUnknownMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelUnknownMessageCell.swift; sourceTree = ""; }; + 36DB7771E34A27FE3507F0DE /* SBUEnums.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEnums.Deprecated.swift; sourceTree = ""; }; + 37116E5191BE696685FA5A75 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift"; sourceTree = ""; }; 371A733CC45A9696DEBF8F79 /* CustomCreateGroupChannel.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 374258FE63226944670893DB /* SBUMessageTemplateCellLayout.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCellLayout.swift; sourceTree = ""; }; - 37663F0868F7387F231EF23F /* VoiceMessageStatus.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = VoiceMessageStatus.swift; sourceTree = ""; }; - 377CB683EA76DA82E16E556A /* SendbirdSwiftUI-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist; path = "SendbirdSwiftUI-Info.plist"; sourceTree = ""; }; + 37343538D25A799C84E3BAE4 /* SBUCreateChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.List.swift; sourceTree = ""; }; + 374A6395FA9C34EE3DA516DF /* GroupModerationsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewConverter.swift; sourceTree = ""; }; + 377597543169F94AFF543475 /* StateImpactManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StateImpactManager.swift; sourceTree = ""; }; 377FEABC82180302EA83C74A /* CustomGroupModerations.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; 37AAC2A470701025FC17A63C /* CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 37C11167BE05D634FB689838 /* SBUMultipleFilesMessageCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCollectionViewCell.swift; sourceTree = ""; }; - 3846C23C9BCC45CA38A719FE /* SBUReactionCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUReactionCollectionViewCell.swift; sourceTree = ""; }; - 384A0D8AB5B526308F89634E /* SBUMessageFormView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormView.swift; sourceTree = ""; }; + 37ABB14A977C9D99DFF4CA6A /* SBUExtendedMessagePayload.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUExtendedMessagePayload.swift; sourceTree = ""; }; + 386477BCFB3C3B92E9854484 /* SBUGroupUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; 388F6BF164AE95A69B80EB39 /* CustomInviteUser.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 39177B76E752035056578234 /* SBUQuotedFileMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedFileMessageView.swift; sourceTree = ""; }; - 393297B39B4586C83A5FE3D0 /* GroupMutedMemberListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMutedMemberListView+SubViewBuilder.swift"; sourceTree = ""; }; + 3898C32C492215F4562791CD /* SBUAlertView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAlertView.swift; sourceTree = ""; }; 39347C5622B095E111628DAE /* CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift; sourceTree = ""; }; - 39A7437156C34F88C39E223D /* SBUParentMessageInfoReactionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUParentMessageInfoReactionView.swift; sourceTree = ""; }; 3A9945722AA9B595F601541C /* CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift; sourceTree = ""; }; - 3A9D4CF5A5EE6E8646E37865 /* SBUView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUView.swift; sourceTree = ""; }; - 3AD9EB3F40F9E5D40F9B5FAC /* SBUCacheManager.Template.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Template.swift; sourceTree = ""; }; + 3AC6115AB54C4F0DE018F8EE /* SBUGroupChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewModel.swift; sourceTree = ""; }; 3AE47348615AD3C64FA1FDAA /* CustomTheme.Theme.Custom.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomTheme.Theme.Custom.Main.swift; sourceTree = ""; }; - 3B10E73347B487AE2FBA2806 /* MethodOverridable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MethodOverridable.swift; sourceTree = ""; }; - 3BCF8D7F6481CF9321250DF9 /* InviteUserView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "InviteUserView+SubViewBuilder.swift"; sourceTree = ""; }; + 3B7B872CDDEDEEA89964760E /* SBUConfigManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfigManager.swift; sourceTree = ""; }; + 3BD19FB097E2A1F6DAAE9E96 /* GroupChannelPushSettingsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewConverter.swift; sourceTree = ""; }; 3C026B187F72078CFCDC5BBE /* CustomOpenChannelSettings.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.SwiftUI.View.Main.swift; sourceTree = ""; }; - 3C02B4F623BAF706728A67A3 /* SBUMessageThreadModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.List.swift; sourceTree = ""; }; + 3C1EBEBB49DB9D9129545F68 /* SBUNewMessageInfo+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUNewMessageInfo+SwiftUI.swift"; sourceTree = ""; }; + 3C33B727B28009C968BDF9B6 /* OpenChannelSettingsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewConverter.swift; sourceTree = ""; }; 3C5266F61E9850A492752AF7 /* CustomGroupMutedMemberList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 3C83ED8F2CAA20B762F4F5B6 /* SBUGroupChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewModel.swift; sourceTree = ""; }; - 3CC0923742309FAE95E55C98 /* CreateGroupChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateGroupChannelView+Item.swift"; sourceTree = ""; }; + 3C6B64F40A2CCC515B0EC030 /* SBUModerationsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.Deprecated.swift; sourceTree = ""; }; + 3CA1FC5D1795A64974F5421A /* SBUGroupBannedUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupBannedUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; 3D141E8C8C15AEBA43FA67F5 /* CustomMessageThread.ViewConverter.List.userMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.userMessageView.swift; sourceTree = ""; }; - 3D4529D5F3329C4BC3B98A17 /* SBUOpenChannelModule.Input+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelModule.Input+SwiftUI.swift"; sourceTree = ""; }; - 3D5EA770115CE527CEF39044 /* SBUUnknownMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUnknownMessageCellParams.swift; sourceTree = ""; }; - 3DDDA8624C4543555B800D2C /* SBUUserMentionConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMentionConfiguration.swift; sourceTree = ""; }; + 3D593110E31DC45E924E2D9B /* SBUGroupChannelSettingCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelSettingCell+SwiftUI.swift"; sourceTree = ""; }; + 3D65D7A80A375918D8B0EB9F /* SBUReactionsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUReactionsViewController.swift; sourceTree = ""; }; + 3DD2F8C9F7503629C66F2EEE /* SBUConstant.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConstant.swift; sourceTree = ""; }; 3E8E19A98FD114729EFA3A9E /* CustomMessageThread.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.SwiftUI.View.Main.swift; sourceTree = ""; }; + 3EBF8DBA8CDA504642F81845 /* SBUChannelStateBanner.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelStateBanner.swift; sourceTree = ""; }; 3ED66AF6F0BEFF49609F06E1 /* CustomInviteUser.ViewConverter.List.selectionButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.List.selectionButton.swift; sourceTree = ""; }; - 3F0E3B57CD4297BB82C8C616 /* OpenChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelView+ViewConverter.swift"; sourceTree = ""; }; - 3F411E990FA74EB4C7BD7027 /* SBUChatNotificationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationCell.swift; sourceTree = ""; }; - 3F45F78119195BA9C15B4B18 /* SBUGroupOperatorListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupOperatorListUserCell+SwiftUI.swift"; sourceTree = ""; }; - 3F45FA38BF21FE277B770348 /* SBUToastView.Internal.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastView.Internal.swift; sourceTree = ""; }; + 3F05697C440446392E577719 /* SBUOpenChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Header.swift; sourceTree = ""; }; + 3F41FB77D91238CE800D9F43 /* SBUMessageThreadModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadModule.Header+SwiftUI.swift"; sourceTree = ""; }; 3F6E4F2C3A2A114F1699BCBA /* CustomGroupChannel.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 3F974D6F1E53ED5AB2C2C84C /* SBUBaseMessageCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUBaseMessageCell+SwiftUI.swift"; sourceTree = ""; }; - 4135695B4B2A78F728C56842 /* SBUDownloadManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDownloadManager.swift; sourceTree = ""; }; + 3F7C5297FA101765F9784775 /* SBUMessageFormChipsItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormChipsItemView.swift; sourceTree = ""; }; + 3FEA7B7C415546F22E63FEFE /* UIImageView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIImageView+SBUIKit.swift"; sourceTree = ""; }; + 3FFC8EB13F480E8BEAFC5E6A /* SBUGroupChannelViewController+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelViewController+SwiftUI.swift"; sourceTree = ""; }; + 401B66CDBC80C118564B5045 /* SBUPropertyWrapper.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPropertyWrapper.swift; sourceTree = ""; }; + 409DBFC7D0F907CC4CC919AD /* SBUMessageFormViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormViewParams.swift; sourceTree = ""; }; + 40DBB14AD71744BD8B995B4F /* Color+Sendbird.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Color+Sendbird.swift"; sourceTree = ""; }; + 40F3DF712CD31E46942D4A03 /* MessageTemplateTestViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageTemplateTestViewController.swift; sourceTree = ""; }; + 40F43C0CB687B4B7C5E4B3C6 /* SBUCreateOpenChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.Deprecated.swift; sourceTree = ""; }; + 40F84492490C7710F5A1A242 /* OpenModerationsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewConverter.swift; sourceTree = ""; }; + 411F9A231E8707D76F0B05FA /* GroupChannelRegisterOperatorViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewConverter.List.swift; sourceTree = ""; }; 413FEC589EA4606EDB81E531 /* CustomOpenChannelList.SubView.Builder.openChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.SubView.Builder.openChannel.swift; sourceTree = ""; }; - 41BBFE0A1ECE6E97671C152C /* CreateGroupChannelViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewConverter.List.swift; sourceTree = ""; }; - 41CE55F82D74BE766CC40BC8 /* SBUOpenChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewModel.swift; sourceTree = ""; }; - 41D90092595D82EE02099124 /* SBUModerationsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.List.swift; sourceTree = ""; }; - 41DF87515C28078D54D8ED88 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelSettingsModule.List+SwiftUI.swift"; sourceTree = ""; }; - 42FDCEFB59A8DBF122F0523E /* UIFont+Sendbird.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIFont+Sendbird.swift"; sourceTree = ""; }; - 433031D3C682345C94D28FDF /* SBUGroupChannelPushSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.List.swift; sourceTree = ""; }; + 418C7FD54C888F55739A45F5 /* OpenChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelView+ViewConverter.swift"; sourceTree = ""; }; + 41F67E3AB37F20407F559B51 /* SBUCommonModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonModule.swift; sourceTree = ""; }; + 421321AB71FAF7684718DD97 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenBannedUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 424A582E4E59F6FC3F368ABB /* SBUFormFieldView.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFormFieldView.Deprecated.swift; sourceTree = ""; }; + 4295DC2364062B88F929D80E /* SBUMessageFormChipView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormChipView.swift; sourceTree = ""; }; + 42D37B68DDC774BB034CEE3E /* SBUGroupChannelPushSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.swift; sourceTree = ""; }; + 42DCD70A6B86E1C1113518A4 /* SBURegisterOperatorModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.swift; sourceTree = ""; }; + 42FB13DE92ED80900AD05054 /* GroupChannelViewConverter.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.Input.swift; sourceTree = ""; }; + 43029E52C382D59F27DB2770 /* SBUCommonDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonDelegate.swift; sourceTree = ""; }; + 434AF506C04A1A095C70A126 /* PrivacyInfo.xcprivacy */ = {isa = PBXFileReference; path = PrivacyInfo.xcprivacy; sourceTree = ""; }; 434BE19EF6D070299A1BBB96 /* CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 43AAC279DE5780A073B1E21F /* UITextField+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UITextField+SBUIKit.swift"; sourceTree = ""; }; - 43CA6787E4A3A782EE75B313 /* SBUBaseChannelSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsViewController.swift; sourceTree = ""; }; + 4355FC0431F98C7660BB7AAB /* SBUOpenChannelSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingCell.swift; sourceTree = ""; }; + 446D630F304F4592542988D1 /* SBUBaseChannelViewController.Keyboard.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.Keyboard.swift; sourceTree = ""; }; 44AC2120ADDF0EB8ED8D341E /* CustomTheme.ColorSet.Custom.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomTheme.ColorSet.Custom.Main.swift; sourceTree = ""; }; + 44C1DB413EA8CE674D33B63E /* SBUUserListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.List.swift; sourceTree = ""; }; + 44C879D1FFF9A02FD6EC7826 /* SBUEmojiListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEmojiListViewController.swift; sourceTree = ""; }; 44E9086D8B5595BDE5E88340 /* GroupChannelsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelsView.swift; sourceTree = ""; }; + 4501508FDCD8E6900C33668C /* CreateOpenChannelViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelViewProvider.swift; sourceTree = ""; }; 4510D73D64979A14389411B5 /* CustomGroupModerations.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.swift; sourceTree = ""; }; - 4558C00951E40E0BFB0ADB26 /* SBUOpenChannelSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.List.swift; sourceTree = ""; }; - 459A13CFDD327E9181AE2F5F /* SBUGroupChannelSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.Header.swift; sourceTree = ""; }; + 456A19C5809209F185A044ED /* SBUModerationsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.List.swift; sourceTree = ""; }; 45A81732697B3F45963DDC20 /* CustomGroupBannedUserList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; - 45DD7E41B743695FA21FC378 /* SBUSimpleSuggestedReplyOptionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSimpleSuggestedReplyOptionView.swift; sourceTree = ""; }; - 45F57E43CFC459BC0A9D2E5C /* SBURegisterOperatorViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorViewController.swift; sourceTree = ""; }; - 45F6A63D5390117FA882CE43 /* MessageThreadView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageThreadView+SubViewBuilder.swift"; sourceTree = ""; }; - 45FA71D8C8152131EDE22583 /* SBUMenuCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMenuCell.swift; sourceTree = ""; }; - 463AAB7723F705DF887E76BE /* UIApplication+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIApplication+SBUIKit.swift"; sourceTree = ""; }; - 4655846FE0CADF225229E917 /* SBUDashboardConfig.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDashboardConfig.swift; sourceTree = ""; }; - 46A56A7F8B030C1F016B4CED /* SBUMessageStateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageStateView.swift; sourceTree = ""; }; - 46FF82F5B4555A400669ADA2 /* SBUGroupChannelViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewController.Unavailable.swift; sourceTree = ""; }; - 472483201FA056ED9A255321 /* GroupModerationsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewConverter.swift; sourceTree = ""; }; + 45AE9457F2764E673A9408D9 /* SBUFeedNotificationChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelViewController.swift; sourceTree = ""; }; + 45C48A775332637B50383C44 /* SBUMessageThreadModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.List.swift; sourceTree = ""; }; + 45DB087B50F9492F21F8C258 /* SBUViewModelDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewModelDelegate.swift; sourceTree = ""; }; + 4609C23D48140B46A11D9077 /* SBUNotificationNavigationTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationNavigationTitleView.swift; sourceTree = ""; }; + 464ADCD317DBEB46993B86DD /* SBUEmojiManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEmojiManager.swift; sourceTree = ""; }; + 4792A2ADDCEE5FE657BA8AC7 /* SBUBaseChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewModel.swift; sourceTree = ""; }; + 4798C26A881FB43F032AC24D /* SBUGroupChannelListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.List.swift; sourceTree = ""; }; 47B6987458B0278D08119327 /* NotificationService.appex */ = {isa = PBXFileReference; includeInIndex = 0; lastKnownFileType = "wrapper.app-extension"; path = NotificationService.appex; sourceTree = BUILT_PRODUCTS_DIR; }; - 47DF5589BE90ED973DB7F67A /* OpenChannelListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewConverter.List.swift; sourceTree = ""; }; - 482ABAD59BE7C16F21111FAC /* SBUChatNotificationChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.List.swift; sourceTree = ""; }; - 482F356F3F2D59068AF4D959 /* MessageThreadView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadView.swift; sourceTree = ""; }; - 486F991ADBCD134649F89781 /* GroupModerationsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupModerationsView+ViewConverter.swift"; sourceTree = ""; }; - 487AD77A600D4D0BAC851314 /* MessageThreadViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.List.swift; sourceTree = ""; }; - 4891397AAB5DCBD36AAE7D51 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenMutedParticipantListUserCell+SwiftUI.swift"; sourceTree = ""; }; - 48F076274C9FA374B6BD0708 /* SBUMarginView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMarginView.swift; sourceTree = ""; }; - 492BC0AAB8CE6B4CDE3E4AF5 /* GroupChannelListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListView.swift; sourceTree = ""; }; - 49511A48940E5542A4C0F5FD /* SBUMessageSearchModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.swift; sourceTree = ""; }; - 4966B4B124FA577795A56523 /* SBUOpenOperatorListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenOperatorListUserCell+SwiftUI.swift"; sourceTree = ""; }; - 49B0CF645FE9CBB0F17FAB36 /* SBUGroupChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.swift; sourceTree = ""; }; - 49B69FE2DEFAAFCBEBC9A1FC /* SBUBaseSelectUserViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserViewController.swift; sourceTree = ""; }; + 48342C2B2D314AB84A41048F /* CreateGroupChannelViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewConverter.List.swift; sourceTree = ""; }; + 485E1BC7A3AB0C82AAE3145D /* GroupBannedUserListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupBannedUserListView+SubViewBuilder.swift"; sourceTree = ""; }; + 48BB97FD2509104396ED0E43 /* SBUMessageFormSingleTextItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormSingleTextItemView.swift; sourceTree = ""; }; 49C02D1B4060B034D7BC9A08 /* CustomCreateOpenChannel.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.Header.leftView.swift; sourceTree = ""; }; + 49D0BEED240F49CC5889EBF6 /* SBUMessageTemplate.TemplateList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.TemplateList.swift; sourceTree = ""; }; + 4A3FA47B606D666AD9E97938 /* GroupOperatorListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewProvider.swift; sourceTree = ""; }; 4A4630B2B926C70C941FD547 /* CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift; sourceTree = ""; }; - 4A95670973E944B4C3A95416 /* SBUDebouncer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDebouncer.swift; sourceTree = ""; }; - 4B0C7AD67D264A3CACBF0A24 /* SBUOpenChannelViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewController.Unavailable.swift; sourceTree = ""; }; - 4B823235003718792C817309 /* SBUOpenChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.swift; sourceTree = ""; }; + 4A8338A02D18FC23E595C05A /* SBUUserListModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.Deprecated.swift; sourceTree = ""; }; + 4ABAFA861BDEB0E2B5E08C64 /* SBUBaseChannelListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListModule.List.swift; sourceTree = ""; }; + 4AF0897805380BAF7AD8859C /* CreateOpenChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelView.swift; sourceTree = ""; }; + 4AFA1BE5F8584D2F119CE1E3 /* SBUSimpleSuggestedReplyOptionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSimpleSuggestedReplyOptionView.swift; sourceTree = ""; }; + 4B037D3D503D49A7A34573F5 /* OpenChannelViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.List.swift; sourceTree = ""; }; + 4B53F3FCA6C01FAB50776850 /* SBUInviteUserModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUInviteUserModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 4B7D92C1C33EB7B70A4DD7CB /* Array+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+SBUIKit.swift"; sourceTree = ""; }; + 4B7EBE9547D711DC04841C63 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateOpenChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; 4BD45E788E57BFD2326E26A4 /* CustomGroupOperatorList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 4C0A2D80C7306781D308DF50 /* SBUConstant.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConstant.swift; sourceTree = ""; }; - 4C2633C1C6CBACCB2EA60472 /* SBUBaseSelectUserViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserViewController.Deprecated.swift; sourceTree = ""; }; - 4C33D8246AFE1AE05351D8CA /* OpenOperatorListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListView.swift; sourceTree = ""; }; - 4C58C8CFC4FB879A749E7447 /* GroupMemberListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMemberListView+ViewConverter.swift"; sourceTree = ""; }; + 4BDBA5011291E3E322F0660F /* GroupMutedMemberListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListView.swift; sourceTree = ""; }; + 4C8F2F5AE4133CDF039D4FDC /* ViewItemProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewItemProtocol.swift; sourceTree = ""; }; 4CB4F955DE8A98683A194DEE /* CustomGroupChannel.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 4CC6408E970D9582343C2F67 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenMutedParticipantListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 4CDA371C83E2F67518C3A760 /* SBUChannelPushSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelPushSettingCell.swift; sourceTree = ""; }; 4CE700B571BDF60CF3AB5576 /* CustomGroupChannelSettings.ViewConverter.List.notification.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.notification.swift; sourceTree = ""; }; - 4CF215E5C5EAE38BCDB732CD /* SBUGroupChannelSettingCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelSettingCell+SwiftUI.swift"; sourceTree = ""; }; - 4DEF0B14DE38EB619FD6405B /* SBUModuleSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModuleSet.swift; sourceTree = ""; }; - 4E03A57B44CC6B14D4C4031B /* GroupOperatorListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupOperatorListView+ViewConverter.swift"; sourceTree = ""; }; - 4E542BCE47135E2CF12B69A8 /* SBUMessageTemplateCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCellParams.swift; sourceTree = ""; }; + 4DDE8745066E0EC425DD0C85 /* SBUVoiceMessageConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceMessageConfiguration.swift; sourceTree = ""; }; + 4DF8E970CDDD209431757EE9 /* GroupChannelRegisterOperatorViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewConverter.Header.swift; sourceTree = ""; }; + 4E179F88E8C865DA3B3C80BD /* CreateOpenChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateOpenChannelView+SubViewBuilder.swift"; sourceTree = ""; }; + 4E2B56441DCC9C595481F9EE /* GroupChannelListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelListView+Item.swift"; sourceTree = ""; }; 4E59F203B7488D4BC92B8103 /* CustomGroupChannelRegisterOperator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.swift; sourceTree = ""; }; 4E7A992C1BA6BBD9F68F735A /* CustomGroupChannelList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.List.rowView.swift; sourceTree = ""; }; 4F19E0129A6247FB94372E4C /* CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift; sourceTree = ""; }; 4F5A3BE9830FFE3F5AD5F422 /* CustomMessageSearch.SubView.Builder.groupChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.SubView.Builder.groupChannel.swift; sourceTree = ""; }; + 4F73FDBC49B98B821FAD9E09 /* GroupChannelListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListView.swift; sourceTree = ""; }; + 4F9DB1C8A4D25102F05E3EF6 /* SBUParentMessageInfoReactionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUParentMessageInfoReactionView.swift; sourceTree = ""; }; + 4FB83E6465C9943C30CD9C11 /* SBUModerationsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.Header.swift; sourceTree = ""; }; 4FBED55AA88DBE899ACF3025 /* CustomGroupMemberList.SubView.Builder.inviteUser.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.SubView.Builder.inviteUser.swift; sourceTree = ""; }; - 4FC7056D923557465B002170 /* SBUChatNotificationChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelViewModel.swift; sourceTree = ""; }; 4FC9ADF39DE854D50970224F /* CustomGroupChannelSettings.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.Header.titleView.swift; sourceTree = ""; }; 4FD7B856C7B2765E3C158DCE /* CustomGroupMemberList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 501B2DCFD9D5FAD15D5CB709 /* SBUGroupChannelListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.swift; sourceTree = ""; }; - 505C2553E67C0C1CDDE626B2 /* SBUGlobals.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGlobals.Deprecated.swift; sourceTree = ""; }; + 5053C3F54CF82D69A26CC37B /* SBUCacheManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.swift; sourceTree = ""; }; 506B49D35067C017A092EB8C /* CustomInviteUser.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.List.profileImage.swift; sourceTree = ""; }; + 50E19A3A71169937AB5A03B8 /* SBUMessageTemplate.Action.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Action.swift; sourceTree = ""; }; + 50ED882EE429BC0546752DE2 /* SBUAnimation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAnimation.swift; sourceTree = ""; }; + 510A0B30736E46E0278FC9A9 /* SBUCreateOpenChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.swift; sourceTree = ""; }; + 51345B6EB0708B353BE6D39D /* SBUOpenChannelViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewController.Unavailable.swift; sourceTree = ""; }; 51454BECF0ACB34F18848A01 /* CustomGroupChannel.ViewConverter.Input.addButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Input.addButton.swift; sourceTree = ""; }; - 515A6FCA6E34F58EB62146AD /* SBUFormView.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFormView.Deprecated.swift; sourceTree = ""; }; - 519230E62500F1040802B744 /* SBUMessageWebView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageWebView.swift; sourceTree = ""; }; + 514BADC1204C3F13E85FAF35 /* MessageThreadViewConverter.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.Input.swift; sourceTree = ""; }; + 51564EBFCB24F043472D1D55 /* SBUGroupChannelPushSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.List.swift; sourceTree = ""; }; + 517DCACCA8CAB496DAE1FE65 /* SBULayoutableButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULayoutableButton.swift; sourceTree = ""; }; 519AF0B13E4AD698AEFB0303 /* CustomGroupOperatorList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 51C56CFE8E82E6E482183B7D /* SBUBaseChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.Deprecated.swift; sourceTree = ""; }; 52351ED09B63E5E5FE1EE827 /* CustomGroupChannelList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.SwiftUI.View.Main.swift; sourceTree = ""; }; 5251C5F71C7B463C54D6474C /* CustomTheme.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomTheme.swift; sourceTree = ""; }; - 526ED0C01EE8EF2AC7D76E68 /* OpenChannelSettingsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelSettingsView+ViewConverter.swift"; sourceTree = ""; }; - 52E4D495AFCFF546A54C3B24 /* SwiftUIMessageInputInterface.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SwiftUIMessageInputInterface.swift; sourceTree = ""; }; - 52F1328AE03EAAF1AD426D08 /* SBUMessageFormMultiTextItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormMultiTextItemView.swift; sourceTree = ""; }; + 525286C859F82074D24680B2 /* SendbirdUI.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SendbirdUI.Deprecated.swift; sourceTree = ""; }; + 525FAF5D7C1814A0634AA10A /* GroupChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelView+SubViewBuilder.swift"; sourceTree = ""; }; + 52C77023C4D2F1DB0CBC34D0 /* OpenChannelListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewConverter.Header.swift; sourceTree = ""; }; + 52CE2A507E7A42C725CCBE15 /* SwiftUIMessageInputInterface.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SwiftUIMessageInputInterface.swift; sourceTree = ""; }; + 52D32A54B554A339D5661CD4 /* OpenBannedUserListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenBannedUserListView+ViewConverter.swift"; sourceTree = ""; }; 53346E81604409C68486DBB2 /* CustomGroupChannel.ViewConverter.List.fileMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.fileMessageView.swift; sourceTree = ""; }; 533FBEB0CF02D20487819307 /* CustomOpenParticipantList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 534BB97DAD333885A76085C0 /* GroupModerationsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewConverter.List.swift; sourceTree = ""; }; 534F2E4ED993A0EB9AE192C4 /* CustomSampleSubViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomSampleSubViewModel.swift; sourceTree = ""; }; 537F956A3C96A94FB5F01B34 /* CustomMessageThread.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 538BF9253A4990D0C05713F5 /* SBUCreateOpenChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.Header.swift; sourceTree = ""; }; - 539CBC600DBA91F212F97009 /* SBUTypingIndicatorBubbleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorBubbleView.swift; sourceTree = ""; }; - 53CDCB30A1F06A5DE1531A88 /* SBUGroupChannelPushSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.swift; sourceTree = ""; }; - 53E511BD6CE441242E39D368 /* SBUChannelPushSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelPushSettingCell.swift; sourceTree = ""; }; - 5439E224FB62720B74EAC103 /* OpenModerationsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsView.swift; sourceTree = ""; }; - 54733AC26F3E88F21EC1750E /* SBUNotificationEmptyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationEmptyView.swift; sourceTree = ""; }; - 54C28728C9C8AC31A2BFBAD1 /* SBUMessageTemplate.PayloadType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.PayloadType.swift; sourceTree = ""; }; - 55425279F87879EA393619E1 /* SBUQuoteMessageInputViewProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuoteMessageInputViewProtocol.swift; sourceTree = ""; }; - 55B4B36852330960D9BC5260 /* GroupMutedMemberListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListView.swift; sourceTree = ""; }; + 53AC6ADF9CA7559D22B20EFD /* SBUBaseMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCellParams.swift; sourceTree = ""; }; + 54077061A5C0CB8EE8DA4AB7 /* OpenBannedUserListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListView.swift; sourceTree = ""; }; + 54A86D1EE72BB0B915C95571 /* SBUPhotoCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPhotoCollectionViewCell.swift; sourceTree = ""; }; + 54BFF6A6EF79427A10DA19C5 /* UITextField+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UITextField+SBUIKit.swift"; sourceTree = ""; }; + 54D753A8D0469BADE7B3A79C /* GroupChannelSettingsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelSettingsView+Item.swift"; sourceTree = ""; }; + 5550B3E5AB07ED184E5C3A84 /* SBUBaseChannelSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsViewController.swift; sourceTree = ""; }; + 559F4134A4DA519D83ECCEED /* SBUMessageTemplateCellLayout.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCellLayout.swift; sourceTree = ""; }; + 55A777BF3329A828082C419E /* SBUOpenChannelListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.swift; sourceTree = ""; }; 55C42C46994988A224886728 /* CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 55CB97C4415AE0168B1EAEE4 /* GroupMemberListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewConverter.Header.swift; sourceTree = ""; }; 55D3470BAC153580068FAA95 /* CustomGroupMemberList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.SwiftUI.View.Main.swift; sourceTree = ""; }; 55EAE96A85D7F046159B3D87 /* CustomGroupModerations.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 5612F8CEF1CBD9C4CD18E21A /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupMutedMemberListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 562B1654E59E7FBB80E3FDFB /* SBUMemberListViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMemberListViewController.Deprecated.swift; sourceTree = ""; }; - 563DF68B8CFC74728183C069 /* SBUMessageTemplate.Binder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Binder.swift; sourceTree = ""; }; 563EB54A9E2574042EE0CE84 /* CustomOpenParticipantList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 567FF37C00B81850DBD328D4 /* SBUInviteUserModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUInviteUserModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 56C6B35A7D7A8F45805DE891 /* SBUConfig.Common.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.Common.swift; sourceTree = ""; }; - 57110DEFE797090CB0D36499 /* NSLayoutConstraint+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "NSLayoutConstraint+SBUIKit.swift"; sourceTree = ""; }; - 574826B35D2867EBF562685B /* GroupChannelPushSettingsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelPushSettingsView+Item.swift"; sourceTree = ""; }; - 57D9985EEF88343041C1BE51 /* GroupChannelPushSettingsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewConverter.Header.swift; sourceTree = ""; }; - 57E9486AE7A3DA69D14C2B1F /* OpenChannelRegisterOperatorView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorView.swift; sourceTree = ""; }; - 57EAE7739E3BD2E813597301 /* SBUFeedNotificationChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.List.swift; sourceTree = ""; }; - 57F7C0D861D9733D927D60AB /* OpenBannedUserListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenBannedUserListView+SubViewBuilder.swift"; sourceTree = ""; }; + 56DB67FD35B6DC6ABDA4E639 /* SBUOpenChannelListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.List.swift; sourceTree = ""; }; + 56EE3C45F358E3FF78C38FF5 /* SBUBaseChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.List.swift; sourceTree = ""; }; + 56F950DBB5A54AEC88D2E539 /* SBUMessageTemplate.Syntax.Sizes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Sizes.swift; sourceTree = ""; }; + 58158C5B57BBB1219A1A7907 /* SBUCreateChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.swift; sourceTree = ""; }; + 581E25EA40DF49EBAA0142FE /* SBUUserMentionConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMentionConfiguration.swift; sourceTree = ""; }; + 58251BF056C682C010BEDD4D /* SBUMessageTemplate.Syntax.Styles.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Styles.swift; sourceTree = ""; }; + 584CEE89C822E1D1BD59E44F /* View + ViewModifier.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "View + ViewModifier.swift"; sourceTree = ""; }; 587133C64EC3FDA6A0E78472 /* CustomOpenChannelSettings.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 58D18F28C0BA2FC86077F964 /* DefaultViewConfigSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DefaultViewConfigSet.swift; sourceTree = ""; }; + 587C70B610EC30D8522A8304 /* SBUChannelSettingItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelSettingItem.swift; sourceTree = ""; }; + 589B1E8E2A00B25B20ECD24A /* OpenChannelRegisterOperatorViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewConverter.swift; sourceTree = ""; }; + 58AB877B3077DBE7EC520DBE /* SBUTypingIndicatorMessageManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorMessageManager.swift; sourceTree = ""; }; + 58DC541DD17CED0D33F79128 /* SBUGroupBannedUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupBannedUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; 59199C2D5B1AAF71E4BD38D0 /* CustomOpenBannedUserList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 595CB34BBF4416DC0AA3CB28 /* SBUContentBaseMessageCell.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUContentBaseMessageCell.Deprecated.swift; sourceTree = ""; }; - 599E3037238837AC8467C033 /* SBUStringSet.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUStringSet.Deprecated.swift; sourceTree = ""; }; - 5A5BD051A6556D060FB89677 /* GroupChannelRegisterOperatorViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewConverter.List.swift; sourceTree = ""; }; + 59A09DB977466D219BBC36EA /* SBUAlertView.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAlertView.Item.swift; sourceTree = ""; }; + 59C00249475970C2ACE48F80 /* SBUUserProfileView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserProfileView.swift; sourceTree = ""; }; + 59D6F159B1AF097FA42F0795 /* SBUOpenChannelSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.swift; sourceTree = ""; }; + 5A1D7523528A21181034C649 /* GroupChannelSettingsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewConverter.swift; sourceTree = ""; }; + 5A6472958F4CF3447377BD4A /* BaseMessage+SBUIKit.MessageTemplate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "BaseMessage+SBUIKit.MessageTemplate.swift"; sourceTree = ""; }; 5A7879949AFA1239627B000A /* CustomInviteUser.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 5AA91AC88677D130F49744F1 /* GroupChannelPushSettingsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewConverter.swift; sourceTree = ""; }; + 5AB54402454B883CCD6CBD01 /* SBUMessageFormFallbackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormFallbackView.swift; sourceTree = ""; }; 5ACEF102F36443266AED5359 /* CustomGroupChannel.SubView.Builder.channelSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.SubView.Builder.channelSettings.swift; sourceTree = ""; }; - 5AE183BFE40D7C1AE34EF4C5 /* SBUBaseChannelSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsModule.Header.swift; sourceTree = ""; }; - 5B17D11ADD035FDE1271DBAA /* SBUOpenChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewController.swift; sourceTree = ""; }; - 5B7E3DDD69211B9214A0A24D /* GroupMutedMemberListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMutedMemberListView+Item.swift"; sourceTree = ""; }; + 5B0C556D74C6973EC9D079ED /* OpenBannedUserListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewProvider.swift; sourceTree = ""; }; + 5B197912A53CB3854FF990B4 /* MessageThreadViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.swift; sourceTree = ""; }; + 5B75F4EBD4914A4295678613 /* UIScrollView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIScrollView+SBUIKit.swift"; sourceTree = ""; }; 5B80CF8942A9B524589380BF /* CustomMessageThread.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.entireView.swift; sourceTree = ""; }; + 5BE9CE19D2E6FB9CC0276345 /* SBUModerationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationCell.swift; sourceTree = ""; }; 5BED13B61170536763801B04 /* CustomMessageSearch.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.swift; sourceTree = ""; }; - 5BFCC249BB471DB592E5A3C3 /* SBUCommonDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonDelegate.swift; sourceTree = ""; }; + 5C1F0FC94BD67FFF13DCA583 /* CreateOpenChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelViewConverter.Header.swift; sourceTree = ""; }; + 5C466E8AD49DF599AB343FA3 /* OpenOperatorListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenOperatorListView+ViewConverter.swift"; sourceTree = ""; }; 5C4C185DFE1CA6B5583DB42A /* CustomOpenMutedParticipantList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.SwiftUI.View.Main.swift; sourceTree = ""; }; + 5C733994D9E30A3D2126469E /* SBUChatNotificationChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.Deprecated.swift; sourceTree = ""; }; 5C7865CE65D851F196960978 /* CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift; sourceTree = ""; }; - 5C9F9A798C62C33692A93813 /* SBUAlertView.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAlertView.Item.swift; sourceTree = ""; }; 5CAA1A308767FA316ADF24DB /* CustomOpenChannelList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.swift; sourceTree = ""; }; - 5CB7111297AFFD4F44521579 /* MultipleFilesMessage+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MultipleFilesMessage+SBUIKit.swift"; sourceTree = ""; }; 5CC7C6EE71D9C0203FB5FB1A /* CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; - 5CEEA40256503D52DA8301A7 /* SBUBaseChannelSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingCell.swift; sourceTree = ""; }; - 5D61ED359FBDCFE0760CF024 /* SBUUtils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUtils.swift; sourceTree = ""; }; - 5D75B2A23956659470CD7213 /* SBUNewMessageInfo+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUNewMessageInfo+SwiftUI.swift"; sourceTree = ""; }; + 5CFCDF4354C150EB6E4EC7E9 /* GroupOperatorListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListView.swift; sourceTree = ""; }; + 5D04B328AB000735BD52BE9D /* SBUMessageThreadModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.swift; sourceTree = ""; }; + 5D2D5DF994BB70E9CCF42022 /* SBUFeedNotificationChannelModule.CategoryFilter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.CategoryFilter.swift; sourceTree = ""; }; + 5D538AAC9F0B43C86FCCF6FB /* SBUMessageTemplate.Syntax.Identifier.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Identifier.swift; sourceTree = ""; }; 5D7977F8BBB275731E11BE34 /* CustomOpenChannelList.ViewConverter.List.channelPreview.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.List.channelPreview.swift; sourceTree = ""; }; - 5D90AA83494B7F9C031B6DD2 /* SBUMessageTemplate.Syntax.Identifier.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Identifier.swift; sourceTree = ""; }; + 5DAE1563042355B438870C6A /* SBUGlobalCustomParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGlobalCustomParams.swift; sourceTree = ""; }; 5DBA3FA486B355A6F23DFD00 /* CustomGroupOperatorList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.List.rowView.swift; sourceTree = ""; }; 5DEE6B3475E267184B7C0921 /* CustomCreateGroupChannel.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.List.entireView.swift; sourceTree = ""; }; + 5E136559F51500BE7524DCA9 /* OpenBannedUserListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewConverter.List.swift; sourceTree = ""; }; 5E7AF0A36D04D33BA1B28E46 /* CustomMessageThread.ViewConverter.Input.addButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Input.addButton.swift; sourceTree = ""; }; - 5E7E39A804B558F66F7EB947 /* SBUMessageFormChipsItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormChipsItemView.swift; sourceTree = ""; }; - 5ECC1263CB743FBD32569570 /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelSettingsModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 5EDD7A1F27B543A5A2CC0C50 /* SBUMessageTemplate.Syntax.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Item.swift; sourceTree = ""; }; - 5F1E6CC210604D9FFC1F3234 /* SBUBaseChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.swift; sourceTree = ""; }; - 5F3FD4AA9DAA78710AED644D /* GroupChannelPushSettingsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewConverter.List.swift; sourceTree = ""; }; - 5FB98D6D00677001841E2CD1 /* SBUCommonModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonModule.swift; sourceTree = ""; }; - 5FC3D28B7EC4E416E6936B47 /* OpenChannelListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelListView+SubViewBuilder.swift"; sourceTree = ""; }; - 6005865475CC09912381B378 /* SBUHorizontalSuggestedReplyOptionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUHorizontalSuggestedReplyOptionView.swift; sourceTree = ""; }; - 6099C0F4584A7A7822DF81D6 /* OpenBannedUserListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewConverter.Header.swift; sourceTree = ""; }; - 60C8EC1B23B48AE94DF6F3A7 /* SBUOpenScrollBottomView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenScrollBottomView+SwiftUI.swift"; sourceTree = ""; }; + 5E7ECC0D58ECDC06EF0183F3 /* OpenMutedParticipantListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewConverter.List.swift; sourceTree = ""; }; + 5E85D3B450A2E0B91A8E3E3C /* UINavigationController+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UINavigationController+SBUIKit.swift"; sourceTree = ""; }; + 5F7BEBBF660496309A703D82 /* GroupModerationsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewConverter.List.swift; sourceTree = ""; }; + 5FBA19E717B0FDA9B35A2D5F /* SBUConfig.GroupChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.GroupChannel.swift; sourceTree = ""; }; + 5FEC8CAB95357120546DFA62 /* SBUGroupChannelSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.List.swift; sourceTree = ""; }; + 602FB0E64CCDD3B8406812D1 /* SBUMessageSearchModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageSearchModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 604F608DA839B7F04E684A40 /* SBUFileViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFileViewController.swift; sourceTree = ""; }; + 60581B37CF51AAEFCECE77CD /* SBUBaseChannelListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListViewController.swift; sourceTree = ""; }; + 608274ACB42DDAE6A5976FC6 /* SBUUserMessageTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageTextView.swift; sourceTree = ""; }; + 60990AE9096DF6FA54EC29BF /* SBUBaseViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseViewController.Unavailable.swift; sourceTree = ""; }; 60E74E559F411EA5C8C39980 /* CustomOpenChannel.ViewConverter.Media.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Media.entireView.swift; sourceTree = ""; }; - 60EC3C29705F473B8FD02D2A /* SBUFeedbackViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedbackViewParams.swift; sourceTree = ""; }; - 60F1CC4E90D3A4D2A8070599 /* SBUVerticalSuggestedReplyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVerticalSuggestedReplyView.swift; sourceTree = ""; }; - 61007D0CB510FD7CDC121AC9 /* SBUOpenChannelImageContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelImageContentView.swift; sourceTree = ""; }; - 61852897DAE0358AD6BBDCA4 /* SBUMessageCellConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageCellConfiguration.swift; sourceTree = ""; }; - 6192BAE26601C4A3B4CE787C /* SBUPhotoAccess.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPhotoAccess.swift; sourceTree = ""; }; 61A71254E7A66A77BC11ECA9 /* CustomInviteUser.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.SwiftUI.View.Main.swift; sourceTree = ""; }; - 61C01A500D446EBDA6C34A88 /* Data+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Data+SBUIKit.swift"; sourceTree = ""; }; - 61C267590CEE26C18694C591 /* SBUMessageThreadInputView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadInputView+SwiftUI.swift"; sourceTree = ""; }; + 61EFB9AFE83364174EFF7E68 /* SBUExtendedMessagePayloadForUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUExtendedMessagePayloadForUI.swift; sourceTree = ""; }; 620712A21432C3E2D4B76DCD /* CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift; sourceTree = ""; }; + 621F589E5F0ED5BEE52864D0 /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelSettingsModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 62364A595D53A0543706D2F9 /* GroupChannelSettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsView.swift; sourceTree = ""; }; 62590526052269EA23C6E769 /* CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift; sourceTree = ""; }; + 627DBB55B063137DA9273A8A /* SBUMessageSearchResultCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchResultCell.swift; sourceTree = ""; }; + 62AF0E697857ED2994B84E0C /* SBUView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUView.swift; sourceTree = ""; }; + 62CC0CF4B851582B239AE1FF /* SBUOpenChannelAdminMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelAdminMessageCell.swift; sourceTree = ""; }; 62CC4972B032D9F6EE874436 /* CustomGroupChannelSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.swift; sourceTree = ""; }; - 630659BAAC01FBD1371A29F5 /* SBUOpenChannelModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Input.swift; sourceTree = ""; }; - 633ED5B1F7A4CAB56DE1F5BB /* SBUCreateOpenChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelViewController.swift; sourceTree = ""; }; - 63888E8140CC9FF7B2967F6E /* SBUMultipleFilesMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCellParams.swift; sourceTree = ""; }; - 647093ADCCD6A67EC419903A /* GroupOperatorListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewConverter.List.swift; sourceTree = ""; }; + 63C9E6ECE987D0D1AAE72330 /* SBUMessageTemplate.Syntax.Views.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Views.swift; sourceTree = ""; }; + 644566F6C95C0AE1075D4E82 /* CreateGroupChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelView.swift; sourceTree = ""; }; + 644EEE0E3AB230AD9CC782FE /* GroupChannelRegisterOperatorViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewConverter.swift; sourceTree = ""; }; 64A60006EDE83A992CE4899A /* CustomOpenChannel.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.SwiftUI.View.Main.swift; sourceTree = ""; }; - 64D0F70137FEF5F25AD7A9DC /* OpenChannelListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewConverter.Header.swift; sourceTree = ""; }; - 64E89D9B931EADFB789516A6 /* GroupOperatorListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewConverter.swift; sourceTree = ""; }; - 6585ED152504C2FFC5DA1AB2 /* SBUOpenChannelViewController+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelViewController+SwiftUI.swift"; sourceTree = ""; }; - 65DF771A802E179051B74F2F /* SBUCreateChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.Header.swift; sourceTree = ""; }; - 66214E35809045C5464EF919 /* SBUMessageTemplate.Renderer.Views.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.Views.swift; sourceTree = ""; }; - 666C50E90307271C07649F2A /* SBUViewModelSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewModelSet.swift; sourceTree = ""; }; - 6681789D0A58D7A83BE74A27 /* GroupBannedUserListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupBannedUserListView+SubViewBuilder.swift"; sourceTree = ""; }; - 66DC68119CAB88E61C94C90B /* OpenOperatorListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewConverter.swift; sourceTree = ""; }; - 66DCC726041A9BF5D118CCE1 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenMutedParticipantListModule.List+SwiftUI.swift"; sourceTree = ""; }; - 66E8A3A8B613A74979FB0FD2 /* SBUBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCell.swift; sourceTree = ""; }; + 65327F0DFF20C899672B90BB /* SBUUnknownMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUnknownMessageCellParams.swift; sourceTree = ""; }; + 65443F1247D65F9688EBC933 /* SBUBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCell.swift; sourceTree = ""; }; + 654B422A3B857A5B120E4528 /* SBUGlobals.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGlobals.swift; sourceTree = ""; }; + 657F6F2027D3DE4F87DDBDA6 /* SBUBaseViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseViewController.swift; sourceTree = ""; }; + 661B774DC02837911A7CDA4C /* SBUBaseCarouselView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseCarouselView.swift; sourceTree = ""; }; + 6643E3E65786C6485BDDA545 /* SBUMessageTemplate.Renderer+RenderStyles.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+RenderStyles.swift"; sourceTree = ""; }; + 666D5EED292A8388ADBD01E3 /* SBUOpenChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.List.swift; sourceTree = ""; }; + 66D12454623DEC0547534C5F /* SBUIconSetType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUIconSetType.swift; sourceTree = ""; }; 670879B256200596D8546552 /* ViewModifiers.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewModifiers.swift; sourceTree = ""; }; - 67309FAB43DB15811EE0FAC5 /* SBUMessageTemplate.Syntax.Types.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Types.swift; sourceTree = ""; }; - 677AE6C278482C5D34FEE924 /* OpenChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.swift; sourceTree = ""; }; - 677F49AF45920CCFBEB5C009 /* SBUNotificationChannelManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationChannelManager.swift; sourceTree = ""; }; - 681FCE6FE5FEC50EDECCB1BB /* SBUNewNotificationInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNewNotificationInfo.swift; sourceTree = ""; }; - 6830AB2E6492132B6DCF3BE4 /* SBUBaseChannelListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListModule.List.swift; sourceTree = ""; }; - 68804DE6D7F73CEA7FEEA335 /* SBUAlertView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAlertView.swift; sourceTree = ""; }; - 68FEB348E153995E6D9A609C /* SBUGroupChannelListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.Header.swift; sourceTree = ""; }; - 691908423FD3C5E45C4BF41A /* Sequence+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Sequence+SBUIKit.swift"; sourceTree = ""; }; - 693AAFF0FF413BA5086E1B0C /* SBUMessageSearchModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageSearchModule.List+SwiftUI.swift"; sourceTree = ""; }; + 67CA15DE5967D27E5ABC4233 /* OpenChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelView.swift; sourceTree = ""; }; + 682435685BFDA58E30D915B8 /* SBUModerationsViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewController.Deprecated.swift; sourceTree = ""; }; + 68438B681D10DDC232C3D9B4 /* OpenParticipantListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewConverter.Header.swift; sourceTree = ""; }; + 68559B08315B254984DBA950 /* SBUToastView.Internal.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastView.Internal.swift; sourceTree = ""; }; + 68610F5D31C4E9913A09CCD4 /* BaseMessage+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "BaseMessage+SBUIKit.swift"; sourceTree = ""; }; + 6869251780957A520939FB48 /* SBUMenuSheetViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMenuSheetViewController.swift; sourceTree = ""; }; + 6869E075C9311C1F762F78B6 /* SBUMentionConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMentionConfiguration.swift; sourceTree = ""; }; + 68884CEA1F889062B9AE92D9 /* GroupMemberListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewProvider.swift; sourceTree = ""; }; + 6893750A21CEBD75C830B03A /* SBUCollectionViewFlowLayout.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCollectionViewFlowLayout.swift; sourceTree = ""; }; + 68A5BCD230041D9FBB14D808 /* BlockingOperation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockingOperation.swift; sourceTree = ""; }; + 68AE2F17C4A25E2EA1BC7A63 /* SBUOpenScrollBottomView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenScrollBottomView+SwiftUI.swift"; sourceTree = ""; }; + 6956509D6C57F140F2A819D9 /* SBUOpenChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewModel.swift; sourceTree = ""; }; 69AA5A484CD6F75C2FB63B42 /* CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 69ADDDE3739EDAA8933BAF4C /* SBUMessageTemplate.ImageRatioType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.ImageRatioType.swift; sourceTree = ""; }; + 69AD8CF8B82DA7E28C4E1E29 /* SBURegisterOperatorModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.Header.swift; sourceTree = ""; }; 69F40C5D515D21F5E4F11F89 /* CustomOpenParticipantList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 69FA8142D379C935F954206C /* SBUUserMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageCell.swift; sourceTree = ""; }; - 69FF9A1D6E3096D844452179 /* SBUMessageThreadTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadTitleView.swift; sourceTree = ""; }; - 6A27F27248F7F70BEB6F6468 /* SBUNotificationNavigationTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationNavigationTitleView.swift; sourceTree = ""; }; - 6A6D753D5D34A8538C6AF20D /* SendbirdUIKit.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SendbirdUIKit.h; sourceTree = ""; }; + 6A3D23ECF381EA3D28AAD871 /* SBUOpenUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; + 6A7B7E1E88F1115AD78191C3 /* OpenChannelRegisterOperatorView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelRegisterOperatorView+Item.swift"; sourceTree = ""; }; + 6A7C45E94E88F6254D996F23 /* GroupOperatorListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupOperatorListView+ViewConverter.swift"; sourceTree = ""; }; + 6A7FF2619B41D30553554AC0 /* SBUUser.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUser.swift; sourceTree = ""; }; + 6A8FE68282C9D1E38107C371 /* SBUActionSheet.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUActionSheet.Item.swift; sourceTree = ""; }; 6A90A31A500C5E9AAE45A08C /* CustomOpenChannel.SubView.Builder.channelSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.SubView.Builder.channelSettings.swift; sourceTree = ""; }; - 6A95E354523AE09616B1BD80 /* SBUHorizontalSuggestedReplyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUHorizontalSuggestedReplyView.swift; sourceTree = ""; }; - 6AEF8D4FF705BB662A4BDC7A /* Thread+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Thread+SBUIKit.swift"; sourceTree = ""; }; - 6B072AC7DDABF32DA278BBA6 /* GroupChannelListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelListView+SubViewBuilder.swift"; sourceTree = ""; }; - 6B306A81F7C4F4B82605F38B /* Array+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+SBUIKit.swift"; sourceTree = ""; }; - 6B76B6E8F8E888984DE91EAA /* SBUOpenChannelListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.List.swift; sourceTree = ""; }; + 6B424207542E1A82DAC82A0D /* SBUOpenChannelMessageWebView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelMessageWebView.swift; sourceTree = ""; }; 6B9D1393478C09E0807164E4 /* CustomGroupChannel.ViewConverter.Header.titleLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Header.titleLabel.swift; sourceTree = ""; }; - 6BBFC36107564B847F7FE03B /* SBUMessageSearchModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.Header.swift; sourceTree = ""; }; - 6BCFF1A7BD3C2D592E67391A /* SendbirdUI+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SendbirdUI+SwiftUI.swift"; sourceTree = ""; }; - 6BFEDEA0282EC80B5682BC6B /* SBUQuotedBaseMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedBaseMessageView.swift; sourceTree = ""; }; + 6B9F8515A20FA64F26C16D46 /* SBUBaseSelectUserModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserModule.List.swift; sourceTree = ""; }; + 6BBFE7AA481DE52BC6E05814 /* HierarchyScannable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HierarchyScannable.swift; sourceTree = ""; }; + 6BF5A66B08808CCFBEC2C60A /* SBUMessageThreadModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadModule.List+SwiftUI.swift"; sourceTree = ""; }; 6C01527DA7DC24CAFBDFD28D /* CustomSampleSubView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomSampleSubView.swift; sourceTree = ""; }; - 6C9F033A5ACB73B595F79862 /* GroupChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelView+Item.swift"; sourceTree = ""; }; - 6D0823820ED006AB5C158A68 /* SBUChannelStateBanner.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelStateBanner.swift; sourceTree = ""; }; + 6C2A652B4CE7406954BBF464 /* SBUQuotedBaseMessageViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedBaseMessageViewParams.swift; sourceTree = ""; }; + 6C8A4D2AB78B5DD00E13566E /* SBUBaseChannelSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsModule.List.swift; sourceTree = ""; }; + 6CAACF7915BF5F47DF2D444E /* SBUOpenUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; 6D5AFF1C0FFAF7FB44385303 /* CustomOpenChannel.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 6E58BDD6097554E5AA391B25 /* SBUBaseViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseViewController.Unavailable.swift; sourceTree = ""; }; - 6F5B7BEEA70A8811267E7236 /* GroupChannelRegisterOperatorViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewConverter.Header.swift; sourceTree = ""; }; - 6F685142DBEC56397DF49B04 /* SBUToastType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastType.swift; sourceTree = ""; }; - 6F89A8E5D6B54674EDAD0090 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenBannedUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 6FD12CE289932C017AACEFC8 /* SBUGroupChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 6FDEE72ED520123188DB93FF /* SBULazyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULazyView.swift; sourceTree = ""; }; - 70A996C0178CC5216BCB2EBE /* SBUFeedNotificationChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.Deprecated.swift; sourceTree = ""; }; - 71A416E658CCC1E1163229BB /* SBUFeedNotificationChannelModule.CategoryFilter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.CategoryFilter.swift; sourceTree = ""; }; + 6E3EB599E75E9A534192C97C /* SBUBaseSelectUserModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserModule.Header.swift; sourceTree = ""; }; + 6E75FECD8466345F80889285 /* SBUOpenChannelListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.Header.swift; sourceTree = ""; }; + 6E96A78E503C25F929F51F29 /* SBUGroupBannedUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupBannedUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 6E971C1577893A6B0FE234FD /* SBUPhotoAccess.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPhotoAccess.swift; sourceTree = ""; }; + 6EB22BF73F4DB239A34F6792 /* QuotedFileImageContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QuotedFileImageContentView.swift; sourceTree = ""; }; + 6EB65FAB29A17019E54AFA24 /* MessageSearchView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchView.swift; sourceTree = ""; }; + 6EB71BF0445525ACB58EB67D /* SBUUserListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.Header.swift; sourceTree = ""; }; + 703C05B3B91F19E011CA92B7 /* MessageThreadViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewProvider.swift; sourceTree = ""; }; + 70474C82754DA2A006251C40 /* GroupModerationsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewConverter.Header.swift; sourceTree = ""; }; + 70D5F2E2B3D151693F21C0A6 /* SBULoading.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULoading.swift; sourceTree = ""; }; + 717BB61F0D034A789B0F3470 /* SBUReactionCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUReactionCollectionViewCell.swift; sourceTree = ""; }; 71C09802CE6CAD970683DDF3 /* CustomOpenChannelList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 722A8173CBC9E33AB320794E /* SBUPaddingLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPaddingLabel.swift; sourceTree = ""; }; - 72AADB71AB3EE728FC6C0993 /* InviteUserViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewConverter.Header.swift; sourceTree = ""; }; - 72BDBA680E4964489D1BCDB5 /* GroupMemberListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMemberListView+SubViewBuilder.swift"; sourceTree = ""; }; + 71CDC288E01D00AB7B00DBCE /* SBUCreateChannelTypeSelector.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelTypeSelector.swift; sourceTree = ""; }; + 7244A2B65E75811F309743EC /* GroupChannelSettingsViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewProvider.swift; sourceTree = ""; }; 72E615EBA26684FF934C2D41 /* CustomGroupChannelList.ViewConverter.List.channelName.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.List.channelName.swift; sourceTree = ""; }; - 735AEA7FB06A451F8F5B3226 /* GroupChannelRegisterOperatorView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelRegisterOperatorView+Item.swift"; sourceTree = ""; }; - 735C35C7BF5726DE097A6252 /* MessageSearchView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageSearchView+Item.swift"; sourceTree = ""; }; - 739741AE05C182B289832616 /* SBUUser.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUser.swift; sourceTree = ""; }; + 7301F42637EF67DDD07821CF /* SBUUserListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListViewController.swift; sourceTree = ""; }; + 736D000D5C7D45CA1F4D9F3B /* SBUMessageSearchViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchViewController.swift; sourceTree = ""; }; 73BAF54B7AED8872A6418ED8 /* CustomGroupOperatorList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; - 740FE6FE5E6D2566C92D0CD8 /* SBUScrollBottomView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUScrollBottomView.swift; sourceTree = ""; }; - 74A2D25905D7CC24CCE2D72C /* SBUBaseChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.List.swift; sourceTree = ""; }; - 74CAA3A0343417CBC00C9A2D /* SBUGroupChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.Deprecated.swift; sourceTree = ""; }; - 74FEA7AFCAA577BB7A5935A5 /* SBUFontSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFontSet.swift; sourceTree = ""; }; + 73D6FC69CD89388D9ACC5B71 /* SBUAdminMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAdminMessageCellParams.swift; sourceTree = ""; }; + 73F0DFB46EDBD5F62F209CC9 /* Float+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Float+SBUIKit.swift"; sourceTree = ""; }; + 744D3897AF413516BB6A02CB /* SBUMessageDateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageDateView.swift; sourceTree = ""; }; + 746CB9D65D9BE7AEACEE55C9 /* SBUGroupUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; + 746FFA5F3A512F4DDD996282 /* SBUOpenModerationsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenModerationsModule.List+SwiftUI.swift"; sourceTree = ""; }; + 74FC80676ADF1E7D30B25C8E /* SBUCreateChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelViewModel.swift; sourceTree = ""; }; 7546B04F2B673FBE23B4578B /* CustomGroupModerations.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.SwiftUI.View.Main.swift; sourceTree = ""; }; 757B053477A4E021A04CA877 /* CustomCreateOpenChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.swift; sourceTree = ""; }; - 758ABFEF69EB1E64F10BBD08 /* SBUChannelStateBanner+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUChannelStateBanner+SwiftUI.swift"; sourceTree = ""; }; - 75EBF0BF01347F6F918EF810 /* SBUMention.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMention.swift; sourceTree = ""; }; - 766287661E5CEC1E2D67A87D /* SBUBaseChannelListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListModule.swift; sourceTree = ""; }; - 76799FA15AA5786517BEF343 /* OpenOperatorListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenOperatorListView+Item.swift"; sourceTree = ""; }; - 76987E34E766FE932E3CD06A /* SBUCoverImageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCoverImageView.swift; sourceTree = ""; }; + 7592610FC6E821A878F88582 /* SBUFeedNotificationChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.Header.swift; sourceTree = ""; }; + 764BFC79756B1BCCE4ACB207 /* SBUMentionLimitGuideCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMentionLimitGuideCell.swift; sourceTree = ""; }; + 76BBE5BEB476721101C05579 /* GroupChannelPushSettingsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelPushSettingsView+SubViewBuilder.swift"; sourceTree = ""; }; + 76C3E5ACC74FD4BB8F224A67 /* SBUCoverImageView.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCoverImageView.Deprecated.swift; sourceTree = ""; }; 76D679FC213569853E5A02DE /* CustomOpenParticipantList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.SwiftUI.View.Main.swift; sourceTree = ""; }; + 7725F441E1811150851949AB /* SBUCommonViewControllerSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonViewControllerSet.swift; sourceTree = ""; }; 77429209B80CB959FD5662A1 /* CustomOpenChannelList.ViewConverter.List.coverImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.List.coverImage.swift; sourceTree = ""; }; + 775497373156080C786EFFA9 /* HandlerSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HandlerSet.swift; sourceTree = ""; }; + 77572D02FFF2252D6380AA76 /* SBUBottomSheetController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBottomSheetController.swift; sourceTree = ""; }; + 77694BFE0E0E11F21133E27D /* SBUFileMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFileMessageCell.swift; sourceTree = ""; }; + 77A22D8FCAD422A90844DC4C /* OpenOperatorListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListView.swift; sourceTree = ""; }; 787AF9B8933205C26AFCA2CB /* CustomOpenChannel.ViewConverter.Header.coverImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Header.coverImage.swift; sourceTree = ""; }; - 789CAB6C3FE329C8F7C13530 /* SBUParentMessageInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUParentMessageInfoView.swift; sourceTree = ""; }; - 78DC43005F3DE461ADE2DEAA /* SBUFeedNotificationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationCell.swift; sourceTree = ""; }; - 78E601DC9E72E49D4C69FCA1 /* OpenMutedParticipantListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewConverter.Header.swift; sourceTree = ""; }; - 78EA6D0B65FF927D2CE1805D /* SBUOpenChannelContentBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelContentBaseMessageCell.swift; sourceTree = ""; }; 78F2D06B939DB1E99B1DFFFF /* CustomGroupOperatorList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.List.entireView.swift; sourceTree = ""; }; 792EED2FB05603227B76613B /* CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 7941531B02292F6773399CBE /* CreateGroupChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewConverter.Header.swift; sourceTree = ""; }; - 79787649F52DE9A28FB275CE /* SBUPermissionManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPermissionManager.swift; sourceTree = ""; }; - 798CA844E4DAA6C1574314BE /* OpenChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelView+Item.swift"; sourceTree = ""; }; - 79E91C43DF36F6D0CADBE2D3 /* SBUCreateChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.Deprecated.swift; sourceTree = ""; }; - 7AD2BD448D02C9A9B551AA86 /* SBUFileMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFileMessageCellParams.swift; sourceTree = ""; }; + 7955E39023C81688202CE6AE /* SBUFormViewParams.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFormViewParams.Deprecated.swift; sourceTree = ""; }; + 7A0D57F36F2D8B1100D6FE49 /* SBUMessageThreadInputView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadInputView+SwiftUI.swift"; sourceTree = ""; }; + 7AF732FDF59475FF7693846E /* CreateGroupChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewConverter.swift; sourceTree = ""; }; 7AFDDC578AF7C0F3D0461335 /* CustomOpenOperatorList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 7B361C809A4825F96490CCAA /* SBUBaseChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.Deprecated.swift; sourceTree = ""; }; 7B792924F253C665E1B57733 /* CustomGroupChannel.ViewConverter.List.adminMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.adminMessageView.swift; sourceTree = ""; }; + 7BA35D433C66A5CAEADA49E0 /* SBUTypingIndicatorMessage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorMessage.swift; sourceTree = ""; }; + 7BA58675E43486760EBE4B9B /* SBUQuotedUserMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedUserMessageView.swift; sourceTree = ""; }; 7BC19298E51750C9D0D610A1 /* CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; + 7BF8B7BD5D3182A7B49D05D5 /* SBUOpenChannelSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.List.swift; sourceTree = ""; }; + 7C7E57B3E69531C17273C791 /* SBUCreateChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.Deprecated.swift; sourceTree = ""; }; 7CA64549D32F469A58888692 /* CustomGroupChannel.ViewConverter.Input.sendButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Input.sendButton.swift; sourceTree = ""; }; - 7D019D737385153F291693BF /* SBUOpenBannedUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenBannedUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; - 7D1A9C9D267ADD34ABADC14A /* SBUCreateChannelTypeSelector.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelTypeSelector.swift; sourceTree = ""; }; - 7D2D48D4D2A4206F1DDE7CD7 /* SBUInviteUserViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserViewModel.swift; sourceTree = ""; }; - 7D6849B7606ADDACDDF87569 /* SBUOpenChannelListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.Header.swift; sourceTree = ""; }; - 7D80E95EF57DDC3B50934217 /* SBUGroupChannelPushSettingsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.Deprecated.swift; sourceTree = ""; }; - 7DB8540E24BA4EAD377A29F7 /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift"; sourceTree = ""; }; - 7E4DA64D4218AE42BAC6C567 /* GroupBannedUserListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewConverter.Header.swift; sourceTree = ""; }; - 7F311E6823137533AF24741B /* SBUView.Unavaliable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUView.Unavaliable.swift; sourceTree = ""; }; + 7D7F84D65D12CFD5BD192CE8 /* SBUStringSet.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUStringSet.Deprecated.swift; sourceTree = ""; }; + 7D843E5D2908EB56EFDC2E4E /* SBUInviteUserViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserViewController.swift; sourceTree = ""; }; + 7D856B5EFE6D3EF8B75FCF7F /* SBUBaseChannelSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsModule.Header.swift; sourceTree = ""; }; + 7D90B73B8AC8C71F9C1C431A /* GroupChannelRegisterOperatorView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelRegisterOperatorView+Item.swift"; sourceTree = ""; }; + 7DF47B235A5C5712180E6232 /* URL+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "URL+SBUIKit.swift"; sourceTree = ""; }; + 7E86E99F56BC13D21BFEBE68 /* GroupChannelSettingsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewConverter.List.swift; sourceTree = ""; }; + 7E9DA3E806D49F987C40355A /* SBULabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULabel.swift; sourceTree = ""; }; + 7F737D0DF3D80BAE69165E99 /* SBULazyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULazyView.swift; sourceTree = ""; }; 7FB951B495F7482D3DFCF6FF /* CustomOpenBannedUserList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 7FD3CDCCBBB8FB5E0C3164B8 /* MessageTemplateParserTest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageTemplateParserTest.swift; sourceTree = ""; }; + 7FD3DBE85BDBF98CBE0F758E /* SBUMessageTemplate.Renderer+Events.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+Events.swift"; sourceTree = ""; }; 7FDEEDB706412FC601CCF624 /* CustomGroupOperatorList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; 7FEEA8F347B582521FCD6832 /* CustomOpenParticipantList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.swift; sourceTree = ""; }; - 803F50E6244F87861D865AE5 /* MessageThreadView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageThreadView+Item.swift"; sourceTree = ""; }; - 8063BA0912F07F52734489F8 /* GroupChannelRegisterOperatorViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewConverter.swift; sourceTree = ""; }; - 8082548DA6A2D4226E6D4B0B /* SBUInviteUserModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUInviteUserModule.List+SwiftUI.swift"; sourceTree = ""; }; - 80EA4D44B6C5B0BF0C7543E6 /* SBUExtendedMessagePayloadForUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUExtendedMessagePayloadForUI.swift; sourceTree = ""; }; + 8016144176E0D68BC050E151 /* UIColor+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIColor+SBUIKit.swift"; sourceTree = ""; }; + 80277CCA8CD14E420F5CE34B /* MessageThreadView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadView.swift; sourceTree = ""; }; + 803819597504B510729CE67A /* SBUOpenChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewController.swift; sourceTree = ""; }; 81401E7343AA611CD5BC481B /* CustomGroupChannelSettings.SubView.Builder.pushSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.SubView.Builder.pushSettings.swift; sourceTree = ""; }; - 81C92F68E1188BB0A7CB863C /* SBUGroupChannelListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelListModule.List+SwiftUI.swift"; sourceTree = ""; }; - 81EE50EA8221195EAE1F0290 /* SBUGroupChannelSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsViewController.swift; sourceTree = ""; }; - 8220E4F1F2BE2C124ED8B73A /* SBUFeedNotificationCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationCellParams.swift; sourceTree = ""; }; - 823177EB22F1375CF161441D /* SBUMessageTemplate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.swift; sourceTree = ""; }; + 81EFDEE298AB85013EA1761F /* GroupBannedUserListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListView.swift; sourceTree = ""; }; + 81F7060AFCA22AF15E3122CD /* SBUMessageSearchViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchViewModel.swift; sourceTree = ""; }; + 82266B325AF8EC3539D27C56 /* QuotedFileCommonContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QuotedFileCommonContentView.swift; sourceTree = ""; }; + 82679D287A3368E9008A1CAC /* MultipleFilesMessage+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MultipleFilesMessage+SBUIKit.swift"; sourceTree = ""; }; + 82D516D15DFAD9E9EEC5AA3D /* SBUGroupChannelSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingCell.swift; sourceTree = ""; }; + 830DF49F679C52EADB4D45B6 /* SBUMessageInputView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageInputView.swift; sourceTree = ""; }; 832AD74C612CBA95BB6080A9 /* CustomCreateOpenChannel.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.List.entireView.swift; sourceTree = ""; }; + 83337608204FE94776C542A4 /* SBUVoiceFileInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceFileInfo.swift; sourceTree = ""; }; 83402211DD8882C43D58382D /* CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 838C450577B1005585D4F38E /* SBUMenuView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMenuView.swift; sourceTree = ""; }; + 83D46A1142AC3CC4D1396719 /* SBUSuggestedReplyOptionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedReplyOptionView.swift; sourceTree = ""; }; 83E21DEE99C27C67B4374E32 /* CustomGroupChannelSettings.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 8403312D3345AA5154DF81D1 /* QuotedFileCommonContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QuotedFileCommonContentView.swift; sourceTree = ""; }; - 844456744940B60FACF05B17 /* OpenParticipantListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewConverter.Header.swift; sourceTree = ""; }; - 84E9EDEFC79A50C05C8D5C31 /* SBUBaseViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseViewController.swift; sourceTree = ""; }; 850E1D213D3EC098A580B835 /* CustomOpenChannelSettings.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 8579E772B5F950377C00E855 /* SBUModerationsViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewController.Deprecated.swift; sourceTree = ""; }; + 85648A3B41D27C36B032B178 /* SBUContentBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUContentBaseMessageCell.swift; sourceTree = ""; }; 859105D58C941EB14073F9F1 /* CustomInviteUser.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 85C17FF5923CE7EA65775A6E /* SBUUserListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.swift; sourceTree = ""; }; - 85DBC0A4BA3AD7B3625F04F4 /* SBUMessageThreadModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 86392DB847368C4FDA9AEB72 /* SBUModerationsViewModel.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewModel.Deprecated.swift; sourceTree = ""; }; - 8668B5EFC9B9C3CBB72B925D /* SBUUserListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.Header.swift; sourceTree = ""; }; - 868865ED19B43E30C0DCE6BF /* OpenChannelRegisterOperatorView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelRegisterOperatorView+Item.swift"; sourceTree = ""; }; - 869EAD18504324BF7D9CF724 /* SBUBaseChannelSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsModule.List.swift; sourceTree = ""; }; - 86CD79484A29B4EA66EC4B0C /* SBUQuotedUserMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedUserMessageView.swift; sourceTree = ""; }; - 86D37B65E1EF649577EA0D37 /* SBUImageContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUImageContentView.swift; sourceTree = ""; }; - 86D998504A47DE9BAAC543C1 /* MessageForm+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageForm+SBUIKit.swift"; sourceTree = ""; }; - 8731B4E84E8F9AFDB3DCCF5D /* OpenChannelListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelListView+Item.swift"; sourceTree = ""; }; + 85CCC0022AAE55FB91296FE5 /* UIViewController+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIViewController+SBUIKit.swift"; sourceTree = ""; }; + 85DC90D7892EF6119DE13735 /* StringProtocol+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "StringProtocol+SBUIKit.swift"; sourceTree = ""; }; + 85DF9F68E38AE6BBA2DE35BE /* SBUGroupChannelSettingsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.Deprecated.swift; sourceTree = ""; }; + 862BAEECB41748FB96C9778F /* SBUMessageTemplate.Binder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Binder.swift; sourceTree = ""; }; + 86B0D9E7E2F38DE9B72E811D /* OpenChannelListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewConverter.swift; sourceTree = ""; }; 878A8DA40EB2448FB0724D26 /* CustomMessageSearch.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 88134BA06CADFAE21FFFC2D0 /* SBUEmojiManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEmojiManager.swift; sourceTree = ""; }; - 887F4EC72B8FC7D81D7886DB /* SBUGroupUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; - 889E65EF815ECC664FAAABE2 /* SBUMessageTemplate.Syntax.Sizes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Sizes.swift; sourceTree = ""; }; - 88E0D73102E23DDE1DAEDDF0 /* SBUCacheManager.File.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.File.swift; sourceTree = ""; }; - 88E58F4FBC5A015D68518FC5 /* SBUOpenChannelSettingsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.Deprecated.swift; sourceTree = ""; }; + 87A0FA711ABE3E5605B1307B /* CreateGroupChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateGroupChannelView+ViewConverter.swift"; sourceTree = ""; }; + 87FA2058A4863E17BF50A632 /* SBUMessageTemplate.Renderer.RendererType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.RendererType.swift; sourceTree = ""; }; + 8806A58516400503B5D7EAA4 /* SBUBaseChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.Deprecated.swift; sourceTree = ""; }; + 882B165AD9E00AD0671DD185 /* Formatter+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Formatter+SBUIKit.swift"; sourceTree = ""; }; + 883A64B2835D7B6C1D60452E /* OpenParticipantListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenParticipantListView+Item.swift"; sourceTree = ""; }; + 887FB1AF021C77AE2658CF59 /* SBUMessageInputView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageInputView+SwiftUI.swift"; sourceTree = ""; }; + 88D5604351DFC4004002856A /* OpenOperatorListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewConverter.swift; sourceTree = ""; }; + 89193DB4600A4F222C0F5524 /* OpenMutedParticipantListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenMutedParticipantListView+SubViewBuilder.swift"; sourceTree = ""; }; + 891A4F16527B1283ADACE452 /* SBUQuotedMessageViewProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedMessageViewProtocol.swift; sourceTree = ""; }; 894840A4B8B0CA19FE1F8552 /* CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift; sourceTree = ""; }; 896D3D907E9EBAB45C5FD383 /* CustomOpenChannelList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 899CCE6BB9CD3EDE4F60D06D /* SBUConfig.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.swift; sourceTree = ""; }; 89C262A82447A1864301C8A1 /* CustomMessageThread.ViewConverter.ParentInfo.webView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.webView.swift; sourceTree = ""; }; - 89F0ABB7E53466D01AC02983 /* SBUFeedbackAction.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedbackAction.swift; sourceTree = ""; }; - 8A07FD82926848554C43ABB5 /* SBUGroupChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.Header.swift; sourceTree = ""; }; + 89CAF8C853F289E0DFFD3AE8 /* MessageSearchViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewProvider.swift; sourceTree = ""; }; 8A10A557D8CFE5451AC04DD3 /* CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 8A4F7A4428AA6840190A27E2 /* GroupChannelSettingsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewConverter.List.swift; sourceTree = ""; }; + 8A5B8F101D680AC30270B59D /* GroupOperatorListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewConverter.Header.swift; sourceTree = ""; }; + 8A5D3AAD48890B67F36BEE43 /* SBUScrollBottomView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUScrollBottomView+SwiftUI.swift"; sourceTree = ""; }; 8A6B0FBE56B4CC9248A62E08 /* CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift; sourceTree = ""; }; 8A85FE7A6759FC81DC272274 /* CustomGroupChannelList.ViewConverter.List.coverImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.List.coverImage.swift; sourceTree = ""; }; - 8A8F43AB90915B61D475F48A /* SBUEnums.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEnums.Deprecated.swift; sourceTree = ""; }; - 8AC9322A2E31BFE30E449B5F /* OpenChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.Header.swift; sourceTree = ""; }; - 8AF20B71046B6D5FF0174268 /* SBViewConverterSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBViewConverterSet.swift; sourceTree = ""; }; + 8A907EC372E1A2032BF4721C /* OpenChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.swift; sourceTree = ""; }; + 8A9FEEEABEADA3B3140A5F0B /* MessageThreadView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageThreadView+Item.swift"; sourceTree = ""; }; + 8B14D993DFD2D52F88F9CEBE /* CGSize+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CGSize+SBUIKit.swift"; sourceTree = ""; }; 8B3DB3B902EE642A320204FC /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 8B5C96EC8862AA9CA0719BE8 /* SBUMessageReactionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageReactionView.swift; sourceTree = ""; }; + 8B69E3E68D1C6DF2B3B4CCE5 /* SBUMention.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMention.swift; sourceTree = ""; }; 8B87B3AF55303D34FB171AF6 /* CustomCreateOpenChannel.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 8B900E0B514EC1D42837B8FF /* OpenChannelSettingsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelSettingsView+SubViewBuilder.swift"; sourceTree = ""; }; - 8CE73800C5625E411855E0D3 /* SBUGroupBannedUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupBannedUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; + 8BA4724E320BF5BEB01C0511 /* SBUMessageThreadModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.Input.swift; sourceTree = ""; }; + 8C3638DCCB2EA6D0B1E9451A /* SwiftUIViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SwiftUIViewController.swift; sourceTree = ""; }; + 8C72EA12FBDBE0429DB866B0 /* SBUNotificationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationCell.swift; sourceTree = ""; }; 8D120C68DAE432A9F5C175D1 /* CustomCreateGroupChannel.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 8D19ADB444964278B6E24246 /* SBUGroupChannelSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.swift; sourceTree = ""; }; - 8D5FA8F827F8A99D242C01C7 /* SBUOpenChannelSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsViewModel.swift; sourceTree = ""; }; - 8D7FF76C892053B1F2B2D112 /* SBUFeedbackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedbackView.swift; sourceTree = ""; }; - 8D8C03E266B5DC64D27B8F44 /* SBUInviteUserModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.List.swift; sourceTree = ""; }; + 8D48DFD3FF62BE218F62CA2C /* GroupMutedMemberListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewConverter.swift; sourceTree = ""; }; + 8D4B7768EB6324A2952EF8E3 /* SBUChatNotificationChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelViewController.swift; sourceTree = ""; }; + 8D84CAF6C762506B85F584E6 /* SBUInviteUserModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.List.swift; sourceTree = ""; }; 8DE8486ECC131F76C82AD08D /* CustomSampleViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomSampleViewModel.swift; sourceTree = ""; }; 8E194EB59871973C28A282B5 /* CustomOpenOperatorList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 8E8801C8B570BA053A2B2FEA /* CreateOpenChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateOpenChannelView+ViewConverter.swift"; sourceTree = ""; }; - 8F27A78EE60A93797E010244 /* SBUConfigManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfigManager.swift; sourceTree = ""; }; - 8F30867017D52BC55BF8A8F2 /* OpenOperatorListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewConverter.List.swift; sourceTree = ""; }; - 904618EB6B0A591FC15D1542 /* SBUMessageFormChipView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormChipView.swift; sourceTree = ""; }; + 8E6740EC9EC809010A5628C7 /* SBUInviteUserModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.Deprecated.swift; sourceTree = ""; }; + 8E77729D950B20F81EC79C63 /* SBUGroupChannelListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelListModule.List+SwiftUI.swift"; sourceTree = ""; }; + 8EBBC3D69755C1B4A69C7721 /* SBUGroupChannelListModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.swift; sourceTree = ""; }; + 8EBCAEA988BE8EE57CD4DE26 /* SendbirdUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SendbirdUI.swift; sourceTree = ""; }; + 8F0D567C1B8A60E173F80D95 /* SBUOpenChannelSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.Header.swift; sourceTree = ""; }; + 8F59F85ADF99A208A9C082B0 /* OpenModerationsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewConverter.List.swift; sourceTree = ""; }; + 8F6C581AF86F0FDF7EE97402 /* SBUMessageThreadViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadViewModel.swift; sourceTree = ""; }; + 8F787E65B4187FC92E0391AF /* SBUIconSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUIconSet.swift; sourceTree = ""; }; + 8F8BD3B6A480001E40AE01F3 /* SBUOpenChannelListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + 8FEB3D3A0A4B95348451722F /* OpenBannedUserListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenBannedUserListView+SubViewBuilder.swift"; sourceTree = ""; }; + 8FF453D51A63DD5EAC2A29B3 /* ColorSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ColorSet.swift; sourceTree = ""; }; 905A88DC20838A94B21B3544 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift; sourceTree = ""; }; 9087883EC823CC5667850BE6 /* CustomGroupChannelSettings.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.Header.leftView.swift; sourceTree = ""; }; 90D8DE1D14DD3A1D25ED47F3 /* CustomOpenOperatorList.SubView.Builder.registerOperator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.SubView.Builder.registerOperator.swift; sourceTree = ""; }; - 91658F3FA5C4F2E9DB896DEB /* SBUStringSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUStringSet.swift; sourceTree = ""; }; - 920FC92C3C10DFB71BEA1069 /* Float+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Float+SBUIKit.swift"; sourceTree = ""; }; - 926322E643B26A93BE240616 /* SBUMessageWebViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageWebViewModel.swift; sourceTree = ""; }; + 90DCABD83770A8345AEC3919 /* SBUTypingIndicatorMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorMessageCell.swift; sourceTree = ""; }; + 915CB4B356E8EE48F40EAF87 /* NSLayoutConstraint+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "NSLayoutConstraint+SBUIKit.swift"; sourceTree = ""; }; + 918EA2EEE13EC608EE6A9692 /* GroupChannelListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelListView+ViewConverter.swift"; sourceTree = ""; }; + 92074159434417ECFA4275EE /* SBUOpenChannelModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Input.swift; sourceTree = ""; }; + 9268BE22DBE8DBD50C37CB32 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenMutedParticipantListUserCell+SwiftUI.swift"; sourceTree = ""; }; + 927503842DC84814D6A78230 /* SBUUserMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageCell.swift; sourceTree = ""; }; + 928D1849A1BC6DB24E431C92 /* SBUMessageFormItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormItemView.swift; sourceTree = ""; }; 92B86E09449B7AC165C14297 /* CustomOpenOperatorList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 93368E728F88CC318E978EEA /* CreateGroupChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateGroupChannelView+SubViewBuilder.swift"; sourceTree = ""; }; - 934D7469181C103EE1ACAF1B /* SBUTypingIndicatorMessage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorMessage.swift; sourceTree = ""; }; + 92F8C302415A0DA76BAE7815 /* CreateOpenChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateOpenChannelView+ViewConverter.swift"; sourceTree = ""; }; + 934D088DA1735729346CE8C0 /* SBUOpenBannedUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenBannedUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; 93846E36D0CA7BD5C19CE6F3 /* CustomOpenChannel.ViewConverter.Input.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Input.rightView.swift; sourceTree = ""; }; - 93C6EE37AC969FB9BBAF7B8E /* SBUCommonViewControllerSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonViewControllerSet.swift; sourceTree = ""; }; + 93C5F784B2DBFAB6E6C9F1B8 /* SBUOpenChannelListModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.Deprecated.swift; sourceTree = ""; }; + 93D381BEB63BA319C071D9DB /* GroupChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelView+Item.swift"; sourceTree = ""; }; 940843643FFA366733C4118D /* MainView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MainView.swift; sourceTree = ""; }; - 9456BE61985B9DAB0E0D12CE /* SBUFeedNotificationChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelViewController.swift; sourceTree = ""; }; - 94B6B99EE4914E2736C8042C /* SBUMediaView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMediaView.swift; sourceTree = ""; }; - 94C077267D8FDD493CDAF330 /* InviteUserView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "InviteUserView+Item.swift"; sourceTree = ""; }; + 94086D052C1DD45734B45C9B /* InviteUserViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewConverter.List.swift; sourceTree = ""; }; + 947446DE112FAC2320D1EF22 /* OpenChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelView+Item.swift"; sourceTree = ""; }; + 9479ECE36C683AB4CF1BE683 /* SBUBaseFileContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseFileContentView.swift; sourceTree = ""; }; + 948D0930539618E949CE2D4C /* SBUViewModelSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewModelSet.swift; sourceTree = ""; }; + 94BC67B1D4514E0EF9894966 /* ViewItemInitialize.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewItemInitialize.swift; sourceTree = ""; }; 94FCA597D446778ABB141E6D /* CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift; sourceTree = ""; }; + 953E1A70757DE741732BA909 /* SBUOpenChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.swift; sourceTree = ""; }; 9587E1B40C8128A76DCAF7A8 /* CustomGroupChannelList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - 95DB32CF54500BF7F04B6482 /* SBUGroupBannedUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupBannedUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; - 960030BBD4843C4DD078C35C /* SBUViewControllerSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewControllerSet.swift; sourceTree = ""; }; - 9642EB6B731C9449EF95384D /* GroupChannelSettingsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelSettingsViewConverter.swift; sourceTree = ""; }; + 95CE7A7C3AD04AA4DC13DECB /* GroupChannelPushSettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsView.swift; sourceTree = ""; }; 964B5747079764A20DD6EF7B /* CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; + 9693AE7B405435E81AFB70DB /* SBUGroupModerationsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupModerationsModule.List+SwiftUI.swift"; sourceTree = ""; }; 96A2372978263A7131ECE94F /* CustomCreateGroupChannel.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 96CE24EEEC3A06E40F7874C9 /* GroupMutedMemberListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewConverter.List.swift; sourceTree = ""; }; + 96A238FF98AFC58A20C0202D /* SBUMessageTemplate.Renderer.Image.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.Image.swift; sourceTree = ""; }; + 96D00F1925C38316F7B14F6F /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelSettingsModule.Header+SwiftUI.swift"; sourceTree = ""; }; 97387173C72E68A8BA13C25A /* CustomOpenOperatorList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - 9774EC4FF0EB6B296E4A2731 /* SBUMentionConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMentionConfiguration.swift; sourceTree = ""; }; - 9791A3C99477F1AA70CB5338 /* SBUSelectableStackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSelectableStackView.swift; sourceTree = ""; }; - 97C853C1F7E530CFD4D3C666 /* SBUMessageInputMode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageInputMode.swift; sourceTree = ""; }; - 98037A186B2F6815C6BC45CD /* SBUGroupChannelSettingsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelSettingsModule.List+SwiftUI.swift"; sourceTree = ""; }; - 9816C55DCB0A7ED877604B1F /* String+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "String+SBUIKit.swift"; sourceTree = ""; }; - 9854C9F75B1B5DF2C5C09594 /* SBUMentionManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMentionManager.swift; sourceTree = ""; }; + 97AA2A602830838B5F8BFF85 /* SBUGroupOperatorListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupOperatorListUserCell+SwiftUI.swift"; sourceTree = ""; }; + 9894EDC6924A66DE7D950197 /* SBUOpenChannelFileMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelFileMessageCell.swift; sourceTree = ""; }; + 98A67C9D3AF0E073941124E5 /* CustomGroupChannelList.SwiftUI.View.ViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.SwiftUI.View.ViewProvider.swift; sourceTree = ""; }; 98DACE2F878024BB6383C53F /* CustomOpenChannelList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; 9971DD2E8907E4153EE20CA2 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist; path = Info.plist; sourceTree = ""; }; - 997DCDD73BE218FE6620854B /* SBUOpenChannelTitleView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelTitleView+SwiftUI.swift"; sourceTree = ""; }; - 9A57EF97E3AB541373FFE03F /* SBUActionSheet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUActionSheet.swift; sourceTree = ""; }; - 9A6F00C0095D4A373AC6FD93 /* SBUOpenBannedUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenBannedUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; - 9AA2862AB56710CEAAEB6A77 /* SBUCreateChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelViewController.Deprecated.swift; sourceTree = ""; }; + 9A63BAEF80ECC309FA1E7669 /* SBUCreateGroupChannelUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateGroupChannelUserCell+SwiftUI.swift"; sourceTree = ""; }; + 9A92CD9FA0255F503C2D351E /* SBUViewControllerSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewControllerSet.swift; sourceTree = ""; }; 9ABD4B8E0F4F737904494C70 /* CustomOpenMutedParticipantList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.swift; sourceTree = ""; }; + 9AC6D3C982FEB244190F2493 /* SBUChannelTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelTitleView.swift; sourceTree = ""; }; 9AD7AABB1BA8EA4D43105BD4 /* CustomOpenChannelSettings.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 9AF49CD344907510F8C32C0F /* OpenChannelRegisterOperatorViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewConverter.List.swift; sourceTree = ""; }; 9AF661DCF63857A167FA1552 /* CustomOpenBannedUserList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.SwiftUI.View.Main.swift; sourceTree = ""; }; + 9B2C00F284587D8677219F4A /* SBUGroupChannelListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListViewModel.swift; sourceTree = ""; }; + 9B51CE14A8194C970B0D40F3 /* GroupChannelListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelListView+SubViewBuilder.swift"; sourceTree = ""; }; 9B6511EB77591FAA9ECA0604 /* CustomCreateGroupChannel.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 9B6A113CC7CEC6C224ED5D07 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateOpenChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; - 9BA7D637DA3F016BB278AC0E /* CreateGroupChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelView.swift; sourceTree = ""; }; 9BB10FC3F72D7FCC938FCA63 /* CustomMessageSearch.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - 9BB8896A51AC9A129CED3AA1 /* WrapperUIViews.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WrapperUIViews.swift; sourceTree = ""; }; 9BCD7CD632F7F60EEDE69043 /* CustomOpenModerations.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - 9BDF021DB7EDAA493F908BB5 /* SBUMessageTemplate.Renderer.Image.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.Image.swift; sourceTree = ""; }; 9BEDEEE112FE1EB02DDA2C0D /* CustomGroupChannelPushSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.swift; sourceTree = ""; }; - 9C2574D3E04FB26DBF76ED58 /* MessageThreadViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.swift; sourceTree = ""; }; + 9BFA16874C98B8F5046EC5D6 /* SBUMessageCellConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageCellConfiguration.swift; sourceTree = ""; }; + 9C12F2848C78BBE9E222E5A8 /* SBUMessageThreadTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadTitleView.swift; sourceTree = ""; }; 9C2CA31E5B4CC3F3DAE26D97 /* CustomOpenChannel.ViewConverter.Input.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Input.entireView.swift; sourceTree = ""; }; + 9C974D5E01D2D8CB8E15B8CD /* GroupChannelRegisterOperatorView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelRegisterOperatorView+SubViewBuilder.swift"; sourceTree = ""; }; 9C9D481CEACE14D2726C302D /* CustomGroupChannelPushSettings.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.SwiftUI.View.Main.swift; sourceTree = ""; }; - 9CEA691367E3A7EA0CC719D0 /* OpenChannelViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.List.swift; sourceTree = ""; }; + 9CA37BC0C06812BB951EC82F /* SBUInviteUserModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.Header.swift; sourceTree = ""; }; + 9D0CE5D19096B1C1D8766F21 /* SBUFeedbackViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedbackViewParams.swift; sourceTree = ""; }; + 9D511342232983FBBE03516A /* InviteUserView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "InviteUserView+Item.swift"; sourceTree = ""; }; + 9D66F6F4842608E7545438C6 /* SendbirdUIProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SendbirdUIProvider.swift; sourceTree = ""; }; 9D9E9FD91120A87FB6AF0AAA /* CustomOpenBannedUserList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - 9DBA21B0C820B120DABD7BF3 /* SBUBaseSelectUserModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserModule.swift; sourceTree = ""; }; - 9DEB237E4B180100712E7618 /* SBUModerationsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.Header.swift; sourceTree = ""; }; - 9E08E04B398544D900FCDB10 /* GroupChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelView+ViewConverter.swift"; sourceTree = ""; }; + 9DB600E69AA30D66B6F3D9D7 /* SBUCommonItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonItem.swift; sourceTree = ""; }; 9E325565C4F113CEBD8DBA04 /* CustomGroupChannel.ViewConverter.List.scrollBottomView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.scrollBottomView.swift; sourceTree = ""; }; + 9E412F92FD80B99ACFE30AF7 /* GroupChannelRegisterOperatorView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelRegisterOperatorView+ViewConverter.swift"; sourceTree = ""; }; + 9E78C28530EB42B33B68C3C6 /* SBUSuggestedReplyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedReplyView.swift; sourceTree = ""; }; 9E90127DF72AC51AA2AE0001 /* CustomGroupChannel.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.rowView.swift; sourceTree = ""; }; - 9EA80A9DB07BD04E1A717C23 /* SBUGroupChannelModule.Input+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelModule.Input+SwiftUI.swift"; sourceTree = ""; }; + 9E9F239FA17E47DB3C61C92B /* OpenParticipantListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenParticipantListView+SubViewBuilder.swift"; sourceTree = ""; }; + 9EA130B566F3BFCA65E9A262 /* SBUTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTextView.swift; sourceTree = ""; }; 9EA9A722A74690B1FE0DA8E9 /* CustomGroupChannelList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - 9F3EE35D2B6C4B0FCC42CB8E /* GroupOperatorListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewConverter.Header.swift; sourceTree = ""; }; - 9FAB9A2A0323D5A01103F169 /* SBUAvailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAvailable.swift; sourceTree = ""; }; - 9FC2858F11E00B30B3C6B844 /* SBUVoiceFileInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceFileInfo.swift; sourceTree = ""; }; - 9FF73F1AC1586488A59B9BB9 /* SBUContentBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUContentBaseMessageCell.swift; sourceTree = ""; }; + 9ED6D075080214039048A95D /* Thread+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Thread+SBUIKit.swift"; sourceTree = ""; }; + 9F54E316B3315A516516C65E /* SBUOpenChannelCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelCell+SwiftUI.swift"; sourceTree = ""; }; + 9FD0291F032A293A68F16270 /* SBUGroupChannelSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.swift; sourceTree = ""; }; A026D51D238CBB4236E62120 /* CustomOpenModerations.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.ViewConverter.Header.titleView.swift; sourceTree = ""; }; A03292F2BC70DF952DE00861 /* CustomMessageThread.ViewConverter.Input.sendButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Input.sendButton.swift; sourceTree = ""; }; - A039F4C3599EE466CF9B9233 /* SBUBaseMessageCell.MessageThread+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUBaseMessageCell.MessageThread+SwiftUI.swift"; sourceTree = ""; }; - A0A6460B6ABA537A9DF9E077 /* SBUDateFormatSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDateFormatSet.swift; sourceTree = ""; }; A0B13F6CFE78B660DE0001C3 /* CustomGroupChannel.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - A0B27BB4D8B2F159844A77BF /* SBUTypingIndicatorMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorMessageCell.swift; sourceTree = ""; }; - A14365C43B23A4185F8DDCA5 /* MessageSearchViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewConverter.List.swift; sourceTree = ""; }; - A2195C8048CCBEB921EA8954 /* SBUCommonItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCommonItem.swift; sourceTree = ""; }; - A29D69A7375F3F7BDFEE2D4C /* SBUUserMessageTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageTextView.swift; sourceTree = ""; }; - A2B05FBDB7E619A9A48FA28F /* SBUTypingMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingMessageCellParams.swift; sourceTree = ""; }; + A0D6D1EDAD29575916B5BE29 /* SBUGroupChannelPushSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsViewModel.swift; sourceTree = ""; }; + A16049189F9B0C7ABC022076 /* SBUBaseSelectUserViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserViewModel.swift; sourceTree = ""; }; + A172ECA24F1EED3C916C4B10 /* SBUThreadInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUThreadInfoView.swift; sourceTree = ""; }; + A17C46E3441DE12806ABD160 /* GroupMutedMemberListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewProvider.swift; sourceTree = ""; }; + A1AAE5D94748BD4BAC705164 /* DefaultViewConfigSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DefaultViewConfigSet.swift; sourceTree = ""; }; + A1EC0EAFDCFB570D5C83FAD1 /* SBUAdminMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAdminMessageCell.swift; sourceTree = ""; }; + A265FA0F4182C5F6FB327DC1 /* SBUCreateChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.Header.swift; sourceTree = ""; }; + A280E51C52241837A38F05CB /* SBUModerationsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewModel.swift; sourceTree = ""; }; + A2A6496F9496B70C0C5DC32C /* SBUChatNotificationChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelViewModel.swift; sourceTree = ""; }; A31F5BA3D3B2F335B1FA8A5F /* CustomMessageThread.ViewConverter.Input.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Input.leftView.swift; sourceTree = ""; }; A347D7A83335A9169B69374F /* CustomGroupChannel.SubView.Builder.messageThread.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.SubView.Builder.messageThread.swift; sourceTree = ""; }; - A35787A00958FD8404D93082 /* SBUSuggestedMentionList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedMentionList.swift; sourceTree = ""; }; + A37035DF62B792FA791F53D5 /* SBUPermissionManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPermissionManager.swift; sourceTree = ""; }; + A37A5AFCDE39921B45147472 /* OpenOperatorListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewConverter.List.swift; sourceTree = ""; }; A3A24FE5B77BFB32E7FC600B /* CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift; sourceTree = ""; }; - A3AEBCB0B26EC13B2CA266E8 /* SBUOpenChannelListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelListModule.List+SwiftUI.swift"; sourceTree = ""; }; - A3CF699C92A450F181836CD9 /* UIColor+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIColor+SBUIKit.swift"; sourceTree = ""; }; - A417F007B9CB1963D0EEAF4D /* SBUOpenChannelSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.Header.swift; sourceTree = ""; }; A42767E94B44B0D92A7A4D5F /* CustomOpenChannel.ViewConverter.Input.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Input.leftView.swift; sourceTree = ""; }; - A43C491A5F4F3DC54D841EB5 /* HandlerSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HandlerSet.swift; sourceTree = ""; }; - A47631C573A77043D1C5F868 /* SBUMessageThreadModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageThreadModule.List+SwiftUI.swift"; sourceTree = ""; }; - A4CAF7382CC2469BBF87E329 /* OpenChannelListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelListView+ViewConverter.swift"; sourceTree = ""; }; - A4D6A060025AC392A913D587 /* SBUQuotedBaseMessageViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedBaseMessageViewParams.swift; sourceTree = ""; }; - A4E6B3FBFE02752B58883E4B /* GroupOperatorListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupOperatorListView+Item.swift"; sourceTree = ""; }; - A4E9A824E45E051EC112A416 /* SBUOpenChannelListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListViewController.swift; sourceTree = ""; }; - A4FE9D61A27CDE2A743D3CFE /* SBUMessageFormItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormItemView.swift; sourceTree = ""; }; + A4F262DB37A37F85B936D28B /* SBUMarginView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMarginView.swift; sourceTree = ""; }; A506ABBB4475B2B23B51459C /* CustomOpenChannel.ViewConverter.List.scrollBottomView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.scrollBottomView.swift; sourceTree = ""; }; A570D54C533C1A8E4328595F /* CustomOpenChannel.ViewConverter.Header.titleLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Header.titleLabel.swift; sourceTree = ""; }; - A64F81096C2DBE9610059AA9 /* ColorSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ColorSet.swift; sourceTree = ""; }; - A6912CC46BA4AFE74AABDB6E /* GroupModerationsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsView.swift; sourceTree = ""; }; + A57520D9A1D02AE25101EACD /* SBUMarkdownTransfer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMarkdownTransfer.swift; sourceTree = ""; }; + A5845DA1C7AF582A65422E50 /* SBUMessageTemplateCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCell.swift; sourceTree = ""; }; + A59A6D2DE07C732BD16DB8CB /* SBUGroupChannelCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelCell.swift; sourceTree = ""; }; + A5AAEF8465A482135D31EB44 /* SBUGroupChannelPushSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.Header.swift; sourceTree = ""; }; + A5D1AC09BD03089D2639594A /* SBUBaseChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.Header.swift; sourceTree = ""; }; + A5DD11EC90E6DD9335006B66 /* GroupModerationsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupModerationsView+SubViewBuilder.swift"; sourceTree = ""; }; A6B05764304DFF28CA5393AA /* CustomTheme.FontSet.Custom.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomTheme.FontSet.Custom.Main.swift; sourceTree = ""; }; - A6CD877BF4F75C3CE545D26F /* SBUMessageSearchViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchViewModel.swift; sourceTree = ""; }; - A70B8E791E1AA6A605F15277 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; - A7147B21E40C241888B079A1 /* SBUGroupOperatorListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupOperatorListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - A71DA9519A09B9E6CBC9D375 /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift"; sourceTree = ""; }; - A7697BCB63E99D1CDCF94905 /* SBUBaseCarouselView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseCarouselView.swift; sourceTree = ""; }; - A7BB35A201ABF5E46615916B /* SBUGroupChannelViewController+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelViewController+SwiftUI.swift"; sourceTree = ""; }; - A7FB320B188CFD4C01CCEF5A /* CreateOpenChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelView.swift; sourceTree = ""; }; + A724FC169EF60661FE55A578 /* SBUChannelListViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelListViewController.Deprecated.swift; sourceTree = ""; }; + A761A9195C9F62DD9A739A19 /* OpenChannelListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewConverter.List.swift; sourceTree = ""; }; + A7B12B08BDE49DDA8CEF1081 /* SBUOpenChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewController.Deprecated.swift; sourceTree = ""; }; + A7D0E7D82632BC43A4434560 /* OpenChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelView+SubViewBuilder.swift"; sourceTree = ""; }; + A7ECA3675E4F44DFB6586D04 /* String+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "String+SBUIKit.swift"; sourceTree = ""; }; A80640594D370683DEF63B03 /* CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - A833DCE545C57E47102A070E /* GroupChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelView+SubViewBuilder.swift"; sourceTree = ""; }; - A8B980032E44E8D2CD11B79A /* SBUGlobals.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGlobals.swift; sourceTree = ""; }; - A8F1B86B8E65954C7AA1988C /* CreateOpenChannelView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateOpenChannelView+Item.swift"; sourceTree = ""; }; - A901B98DBD349F8A5CBDB977 /* SBUViewModelDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewModelDelegate.swift; sourceTree = ""; }; + A88C3ED343AF03A46C782863 /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift"; sourceTree = ""; }; + A88F464BAAD90AB84BB13317 /* OpenChannelSettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsView.swift; sourceTree = ""; }; + A8B2153FEAAF7C92B3DBE27F /* SBUFeedNotificationChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.swift; sourceTree = ""; }; A908A59131B410EF958EC4F5 /* CustomCreateOpenChannel.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.Header.rightView.swift; sourceTree = ""; }; + A936C2B0F4BEFCCE17689484 /* SBUSelectablePhotoViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSelectablePhotoViewController.swift; sourceTree = ""; }; + A94FC79DD966BE57D3D864FE /* SBUMessageFormMultiTextItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormMultiTextItemView.swift; sourceTree = ""; }; A9D88030BE14DF71F88DC365 /* CustomOpenChannel.ViewConverter.Input.addButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Input.addButton.swift; sourceTree = ""; }; - A9E52D0CF1A2746B74AE93F2 /* SBUOpenChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.List.swift; sourceTree = ""; }; - A9F80A10E0E12E6B550927F7 /* SBUMessageThreadModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.Header.swift; sourceTree = ""; }; - AA730E10316B59EC0D80449F /* SBUChannelSettingItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelSettingItem.swift; sourceTree = ""; }; + AA6DD0EF41EBA11F612CAE67 /* SBUGroupChannelListModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.Deprecated.swift; sourceTree = ""; }; AA7E85539CE0E5423736D18E /* CustomOpenChannelList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - AAAF55460E9B55A08425A596 /* OpenParticipantListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenParticipantListView+SubViewBuilder.swift"; sourceTree = ""; }; - AB042AC39230E43C6B58A32E /* MessageThreadView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageThreadView+ViewConverter.swift"; sourceTree = ""; }; + AA9023EA669DDE89840B17F0 /* SBUMessageTemplate.Renderer+Utils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+Utils.swift"; sourceTree = ""; }; AB09B1B15A5D99B56FCABE91 /* CustomMessageThread.ViewConverter.List.channelStateBanner.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.channelStateBanner.swift; sourceTree = ""; }; + AB2CBA09DA24007F0E5C877F /* SBULinkClickableTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULinkClickableTextView.swift; sourceTree = ""; }; AB3A3CD06C2DEF6907171B46 /* CustomOpenOperatorList.ViewConverter.List.rowView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.List.rowView.swift; sourceTree = ""; }; + AB3EA7BE88661E3E98BC2085 /* CreateGroupChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewConverter.Header.swift; sourceTree = ""; }; + AB4D0C9E36B253F255269B77 /* SBUMessageSearchViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchViewController.Deprecated.swift; sourceTree = ""; }; + AB654419A3218B0E3A4093D5 /* SBUBaseChannelCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelCell.swift; sourceTree = ""; }; AB69F30738244FD2FBE1C222 /* CustomMessageThread.ViewConverter.List.fileMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.fileMessageView.swift; sourceTree = ""; }; ABE556FD97646142D0B60B2E /* CustomGroupChannel.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.entireView.swift; sourceTree = ""; }; + ABEE9C98A1E6CDDEA7001F6A /* SBUFormView.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFormView.Deprecated.swift; sourceTree = ""; }; ABF9555C752DF6B69AC2BB56 /* CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; AC38B314105F8FD6ECB154F7 /* QuickStartSwiftUI.app */ = {isa = PBXFileReference; includeInIndex = 0; lastKnownFileType = wrapper.application; path = QuickStartSwiftUI.app; sourceTree = BUILT_PRODUCTS_DIR; }; + ACE0161330623767B0B22AEA /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenMutedParticipantListModule.Header+SwiftUI.swift"; sourceTree = ""; }; AD052ED37E7CB964936B4AF8 /* CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - AD07773AFAC8EDB0C5804E32 /* SBUOpenChannelCommonContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelCommonContentView.swift; sourceTree = ""; }; - AD56A02381EBFBDFB56FF9D7 /* MessageThreadViewConverter.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.Input.swift; sourceTree = ""; }; - AD6134279DE72ADE5816F2F0 /* GroupChannelListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelListView+Item.swift"; sourceTree = ""; }; + AD331F75C4062F3566D75108 /* SBUOpenChannelSettingsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.Deprecated.swift; sourceTree = ""; }; AD83A8BF2B08D10F438C21C0 /* CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift; sourceTree = ""; }; AD9CB8CE7BC4EF75FC02D89F /* CustomMessageThread.ViewConverter.Input.voiceButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Input.voiceButton.swift; sourceTree = ""; }; + ADD3FAB38AE4AB7059250476 /* SBUVerticalSuggestedReplyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVerticalSuggestedReplyView.swift; sourceTree = ""; }; + ADDA48DA43F534CAF86DA08A /* OpenModerationsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewConverter.Header.swift; sourceTree = ""; }; ADDB752428A84A635510D867 /* CustomGroupMemberList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; - ADE7D91A32DE35288413F142 /* SBUMessageCellProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageCellProtocol.swift; sourceTree = ""; }; - AE33606F2063A12272D6CCB7 /* InviteUserViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewConverter.List.swift; sourceTree = ""; }; - AE4CCA39B22DF2E106943CE0 /* SBUChannelTitleView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUChannelTitleView+SwiftUI.swift"; sourceTree = ""; }; AE502119AE1D2DF2A3A00516 /* CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift; sourceTree = ""; }; - AE5AE7AE8AFB0332BF6B91B9 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelRegisterOperatorView+SubViewBuilder.swift"; sourceTree = ""; }; - AE671E84CB2E1BF4227408D7 /* SBUIconSetType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUIconSetType.swift; sourceTree = ""; }; - AEB9F6769BE111DFA1D6A0D1 /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelSettingsModule.Header+SwiftUI.swift"; sourceTree = ""; }; + AE682F654DF8EC3C5B5D3996 /* SBURegisterOperatorViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorViewModel.swift; sourceTree = ""; }; + AEA66943CFCCE47F35FFB80F /* OpenChannelListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListViewProvider.swift; sourceTree = ""; }; + AED99943C6CCB04E8DB46AE5 /* SBUGroupChannelListModule.Common.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.Common.swift; sourceTree = ""; }; AEF35963ABD21040E7D4883A /* CustomMessageThread.ViewConverter.ParentInfo.profileView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.profileView.swift; sourceTree = ""; }; AF17E587AFF1B661A648930B /* LoginView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LoginView.swift; sourceTree = ""; }; - AF66DF02B81CE8EF19BF9BF0 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift"; sourceTree = ""; }; - AF99A51ED217C33B971A26F9 /* SBULinkClickableTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULinkClickableTextView.swift; sourceTree = ""; }; - AFB7053B5FEC84E058F598BF /* GroupChannelSettingsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelSettingsView+Item.swift"; sourceTree = ""; }; - AFF25F8EC9716847344276B0 /* SBUMenuSheetViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMenuSheetViewController.swift; sourceTree = ""; }; - B02DAC06AC58179B3149D2C3 /* OpenChannelViewConverter.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.Input.swift; sourceTree = ""; }; - B05DC3A2E750EC0A12CC4393 /* SBUUserMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageCellParams.swift; sourceTree = ""; }; + AF2301F651B24A4E16EFAEA8 /* GroupChannelViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.List.swift; sourceTree = ""; }; + AF2B1200556A2038713B5612 /* SBUMessageTemplate.Payload.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Payload.swift; sourceTree = ""; }; + AF34A3B458887980810747D2 /* OpenChannelRegisterOperatorViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewConverter.Header.swift; sourceTree = ""; }; + AF5228FB7BBC9672AE3637C5 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupMutedMemberListUserCell+SwiftUI.swift"; sourceTree = ""; }; + AF68890BEBB702CC9ED09C98 /* SBUSuggestedMentionList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedMentionList.swift; sourceTree = ""; }; + AFE3D03358D333FDDEA9BB20 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift"; sourceTree = ""; }; + B01828BC5F31C8FA805FB0AA /* SBUBaseChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.swift; sourceTree = ""; }; + B037A4E8EC8A7B9131F03A16 /* GroupChannelPushSettingsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelPushSettingsView+Item.swift"; sourceTree = ""; }; + B041F9C56CD7C0C012E98950 /* InviteUserView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserView.swift; sourceTree = ""; }; + B07065B5EEFA8858ADAD76CA /* SBUSelectableStackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSelectableStackView.swift; sourceTree = ""; }; B07D3A391488B12E092C1164 /* CustomGroupBannedUserList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - B08F254ED73A65FF24CE813B /* UITableView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UITableView+SBUIKit.swift"; sourceTree = ""; }; - B130A2EAD2252178E5063E37 /* SBUChatNotificationChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.swift; sourceTree = ""; }; - B16C1FB87FE416A9AACF8977 /* SBUCreateOpenChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.swift; sourceTree = ""; }; - B180E9D8480EE10DE31B9FE1 /* SBUExtendedMessagePayloadCustomViewFactory.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUExtendedMessagePayloadCustomViewFactory.swift; sourceTree = ""; }; - B1A85D27D8C3E08D0B4BF1C9 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUChannelStateBanner.MessageThread+SwiftUI.swift"; sourceTree = ""; }; - B217E1EA093625A1F18F9245 /* SBUChatNotificationChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelViewController.swift; sourceTree = ""; }; - B23C27311B45D3C9124E9EC8 /* SBUModerationsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.Deprecated.swift; sourceTree = ""; }; - B23F126897E287420089CCD2 /* SBUOpenChannelModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelModule.List+SwiftUI.swift"; sourceTree = ""; }; - B27F2C1ED575A382398E6677 /* OpenModerationsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenModerationsView+ViewConverter.swift"; sourceTree = ""; }; + B0ED60E6DBA9AF470E3DB48B /* SBUGroupChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewController.swift; sourceTree = ""; }; + B166932E45875505EE1E64DB /* WrapperUIViews.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WrapperUIViews.swift; sourceTree = ""; }; + B1CEACEDCDA122F53B6F9048 /* SBUPaddingLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPaddingLabel.swift; sourceTree = ""; }; + B1E9D76A5720F7B7C9B6AA55 /* SBUHighlightMessageInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUHighlightMessageInfo.swift; sourceTree = ""; }; + B2381F491D07215E71A1C179 /* GroupChannelPushSettingsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelPushSettingsViewConverter.Header.swift; sourceTree = ""; }; + B26D20DFC631D5EDC2CF8D54 /* OpenMutedParticipantListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewConverter.Header.swift; sourceTree = ""; }; + B2BC4EA3D8CE0C395D945CF8 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupMutedMemberListModule.Header+SwiftUI.swift"; sourceTree = ""; }; B2D0EFADDF5CB6BDF60CD7A2 /* CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; - B34779DFF03F17E12EF14F8B /* SBUFeedNotificationChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelModule.Header.swift; sourceTree = ""; }; - B37E21BC8F9E14B7F17F08BB /* SBUMessageSearchModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.List.swift; sourceTree = ""; }; - B3815A0BB9F670F9F21DB0F0 /* SBUSelectablePhotoViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSelectablePhotoViewController.swift; sourceTree = ""; }; - B3AEA60115A8DACD156EFE14 /* SBUScrollOptions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUScrollOptions.swift; sourceTree = ""; }; - B3B7DF2B3CBE003069677711 /* SBUMessageSearchModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageSearchModule.Header+SwiftUI.swift"; sourceTree = ""; }; - B461281DDE306B84C3893B7F /* SBURegisterOperatorModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.Header.swift; sourceTree = ""; }; - B4634E8F326FA5E9E408A111 /* SBUMessageTemplate.Renderer+Utils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+Utils.swift"; sourceTree = ""; }; - B48EFC9732F79D6C644ABE86 /* SBUTableViewCell.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTableViewCell.Unavailable.swift; sourceTree = ""; }; - B4EB1DE72843F9F2E4E067BC /* SBUInviteUserModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.Header.swift; sourceTree = ""; }; + B2D1684E7E56CD1DC90FA733 /* SBUMediaView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMediaView.swift; sourceTree = ""; }; + B2F84327611A02AD862FBF50 /* SBUGroupOperatorListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupOperatorListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + B48E2BC784CAFA265679C530 /* GroupMutedMemberListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMutedMemberListView+Item.swift"; sourceTree = ""; }; + B490A5163E0F31829523A88C /* SBUOpenChannelTitleView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelTitleView+SwiftUI.swift"; sourceTree = ""; }; + B4A0BB7D655128684E76A5B2 /* SBUMessageInputMode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageInputMode.swift; sourceTree = ""; }; B50AAD81BE674A45CFD5AEB5 /* CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift; sourceTree = ""; }; - B51FC07C5EB09E0C69628EA0 /* SBUIconSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUIconSet.swift; sourceTree = ""; }; - B5697F9AAD564890A973256A /* GroupModerationsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewConverter.Header.swift; sourceTree = ""; }; - B5A01B459C79535912AC488C /* GroupChannelRegisterOperatorView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorView.swift; sourceTree = ""; }; - B5BBE80E7FA22943BBC1F7C9 /* SBUActionSheet.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUActionSheet.Item.swift; sourceTree = ""; }; + B51E1CE18BE4F3FDC6244D83 /* SBUBaseChannelViewController.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.Unavailable.swift; sourceTree = ""; }; + B545224CE456DD6FC076E267 /* SBUCategoryFilterCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCategoryFilterCell.swift; sourceTree = ""; }; + B58B9C60DFDDBFB10FF2737C /* MessageTemplateParserTest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageTemplateParserTest.swift; sourceTree = ""; }; + B5912802D62DB001F7D04659 /* SBUActionSheet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUActionSheet.swift; sourceTree = ""; }; + B5B8D919D29518C330D50223 /* NSObject+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "NSObject+SBUIKit.swift"; sourceTree = ""; }; + B5CFC8E13C50AAE8AFF471AC /* SBUReplyConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUReplyConfiguration.swift; sourceTree = ""; }; B62DDB5AEADE552713948729 /* CustomGroupChannelList.ViewConverter.List.unreadCount.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.List.unreadCount.swift; sourceTree = ""; }; B683D8C9E07D1EFD01133041 /* CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift; sourceTree = ""; }; + B6FD670D57FB0A2380422154 /* SBUMessageThreadViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadViewController.swift; sourceTree = ""; }; B7434B1BB34EE7822565BE8A /* CustomGroupChannelSettings.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.SwiftUI.View.Main.swift; sourceTree = ""; }; - B76D4B10BDE52AD3E7C6B136 /* SBUMessageSearchViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchViewController.swift; sourceTree = ""; }; - B78C4CB73E4DC57DEC979D99 /* SBUOpenChannelUserMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelUserMessageCell.swift; sourceTree = ""; }; - B7D26F2838B7D12D15885978 /* SBUCacheManager.Image.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Image.swift; sourceTree = ""; }; - B7E0D4FD8746F209DFE99AF3 /* SBUMessageTemplate.Renderer+RenderStyles.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageTemplate.Renderer+RenderStyles.swift"; sourceTree = ""; }; - B82B55E310D26E3DD9E67834 /* SBUBaseChannelListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListViewController.swift; sourceTree = ""; }; - B85160213149D7C96CF3D470 /* SBUBaseChannelViewController.Keyboard.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.Keyboard.swift; sourceTree = ""; }; - B882C20E663ED48B5ED6D4A7 /* SBUNavigationTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNavigationTitleView.swift; sourceTree = ""; }; - B882F1528ECBB76E2777E7FF /* SBUOpenModerationsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenModerationsModule.Header+SwiftUI.swift"; sourceTree = ""; }; + B780F445346B319D875EBB26 /* OpenChannelViewConverter.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.Input.swift; sourceTree = ""; }; + B79650F5C408244AF34B5DA1 /* OpenBannedUserListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewConverter.swift; sourceTree = ""; }; + B7F704A16BB10D77C631E19A /* SBUConfig.Base.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.Base.swift; sourceTree = ""; }; + B8D4F66B16058506BB43940F /* SBUScrollBottomView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUScrollBottomView.swift; sourceTree = ""; }; B8DD94130F1FCA4BC88AC734 /* CustomGroupChannelSettings.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.entireView.swift; sourceTree = ""; }; - B90AEFF358A26F1593707117 /* SBUMessageThreadViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadViewModel.swift; sourceTree = ""; }; + B966D1C78F8A4D306FD0172A /* MessageThreadViewConverter.ParentInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.ParentInfo.swift; sourceTree = ""; }; + B97D86AD63DE6E5D1AF2F631 /* SBUMessageTemplate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.swift; sourceTree = ""; }; B9E1014ACA765E3598F06F71 /* CustomGroupBannedUserList.ViewConverter.List.profileImage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.List.profileImage.swift; sourceTree = ""; }; BA429B863A8ED037889380A4 /* CustomOpenOperatorList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; - BA4A079F4D61BE349D534EDE /* HierarchyScannable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HierarchyScannable.swift; sourceTree = ""; }; BA526C8D0DF18295F76898BD /* CustomGroupMutedMemberList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.SwiftUI.View.Main.swift; sourceTree = ""; }; - BB0D3EA32D2293C49B99240F /* InviteUserViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewConverter.swift; sourceTree = ""; }; + BA937CAFFBDC2CAC0FE00664 /* SBUGroupChannelListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + BAEB95B332FE15206BBC2DFE /* GroupMemberListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewConverter.swift; sourceTree = ""; }; BB3D6D98B9661B747DCF6AA5 /* CustomCreateGroupChannel.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.SwiftUI.View.Main.swift; sourceTree = ""; }; BB75D9350081AF38A4FAA594 /* UserDefaults+Ext.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UserDefaults+Ext.swift"; sourceTree = ""; }; - BBE02207F2AC34710E9F2A41 /* SBUUserListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListViewController.swift; sourceTree = ""; }; - BC4E1242DCFF67A780DD080B /* SBUBaseChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelViewController.swift; sourceTree = ""; }; - BC85F62E529A705813ED5671 /* GroupMutedMemberListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewConverter.Header.swift; sourceTree = ""; }; - BCB0F215A1630FCF1A088CCA /* SBUToastView.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastView.Item.swift; sourceTree = ""; }; - BD039AD94BFA1191FFFA3149 /* CommonProtocols.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CommonProtocols.swift; sourceTree = ""; }; - BD0FAD1E018EEBC665ACD0B6 /* FontSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FontSet.swift; sourceTree = ""; }; - BD1D2FF674AE425302A71903 /* SBURegisterOperatorModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.swift; sourceTree = ""; }; - BD7AC31657ED213E32ECBD42 /* UIImageView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIImageView+SBUIKit.swift"; sourceTree = ""; }; + BB8E79F86C80CC2DD59FCC04 /* OpenChannelSettingsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelSettingsView+ViewConverter.swift"; sourceTree = ""; }; + BBF13F185407274DA4BAFF25 /* SBUPendingMessageManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPendingMessageManager.swift; sourceTree = ""; }; + BC87A02119141F2A3B9F2390 /* SBUGroupOperatorListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupOperatorListModule.List+SwiftUI.swift"; sourceTree = ""; }; + BCDE756FB020AB19ECBB9189 /* InviteUserViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewConverter.Header.swift; sourceTree = ""; }; + BD92AAE15AFE138AA4C1EEB6 /* SBUOpenChannelViewController+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelViewController+SwiftUI.swift"; sourceTree = ""; }; + BDD4EB3C929D559F5D0D624E /* SBUExtendedMessagePayloadCustomViewFactory.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUExtendedMessagePayloadCustomViewFactory.swift; sourceTree = ""; }; BDE26BC1BAF5CEC2C2C5135F /* CustomGroupChannelSettings.SubView.Builder.userList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.SubView.Builder.userList.swift; sourceTree = ""; }; - BE7259CA31206A469BB51C25 /* SBUMessageFormSingleTextItemView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormSingleTextItemView.swift; sourceTree = ""; }; + BDEE4A85341548A38E5EB50C /* SBUChatNotificationChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.Header.swift; sourceTree = ""; }; + BDFE3D65FB2D6207335EFEF0 /* GroupOperatorListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewConverter.swift; sourceTree = ""; }; + BE00B6FCA3245B5D40FCB38C /* SBUUnderLineTextField.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUnderLineTextField.swift; sourceTree = ""; }; + BE11E602679B94F815434977 /* OpenChannelRegisterOperatorViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewProvider.swift; sourceTree = ""; }; + BE130EF4A36F3ADFE7007505 /* SBUBaseChannelSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsViewModel.swift; sourceTree = ""; }; + BE55BC5056EEB299BC27EF13 /* CreateGroupChannelViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateGroupChannelViewProvider.swift; sourceTree = ""; }; + BE88DD79EB597B50591F3AE4 /* SBUChannelInfoHeaderView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelInfoHeaderView.swift; sourceTree = ""; }; BEFE3796A35F972AC95F9705 /* CustomGroupChannel.ViewConverter.Input.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Input.rightView.swift; sourceTree = ""; }; - BF2C918C951707F9AC84EA4F /* OpenBannedUserListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenBannedUserListView+Item.swift"; sourceTree = ""; }; - BF61B959A003633F9C9EB07D /* SBUOpenChannelModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelModule.Header+SwiftUI.swift"; sourceTree = ""; }; BF7C18BECF6A013F82FB18B3 /* CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; BF9C7D0187A83D8621B5B6E9 /* CustomInviteUser.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - BFB2AC204CC38945E7CD7DCC /* SBUOpenChannelListModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListModule.Deprecated.swift; sourceTree = ""; }; - C00284E6199B018EE7B11AC7 /* GroupChannelSettingsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelSettingsView+SubViewBuilder.swift"; sourceTree = ""; }; - C056C5CCBC515F1ABAA627C1 /* Color+Sendbird.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Color+Sendbird.swift"; sourceTree = ""; }; + BFD44E420AECC052E968D1D2 /* GroupMutedMemberListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewConverter.List.swift; sourceTree = ""; }; C05AA4A4BD31F43C7ABE474F /* CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift; sourceTree = ""; }; - C080BD93D8577C641E87E1D5 /* SBUNotificationTimelineView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationTimelineView.swift; sourceTree = ""; }; - C096565785A1E150A95D7572 /* SBUMessageTemplate.Renderer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.swift; sourceTree = ""; }; - C09A08CA49DDC01557C7D096 /* SBUInviteUserModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.swift; sourceTree = ""; }; + C08C818F7E03C3CC838DCED3 /* GroupModerationsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupModerationsView+Item.swift"; sourceTree = ""; }; C09C8C6CEC68C15036518EF9 /* CustomSampleManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomSampleManager.swift; sourceTree = ""; }; C0AE3AA13449F68E87D7DD3D /* CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; C0BD9DADEBEC69A7F8E52285 /* CustomGroupBannedUserList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - C0DDF27516D888B54EA2559D /* SBUCacheManager.NotificationSetting.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.NotificationSetting.swift; sourceTree = ""; }; - C11906C6C1DC0D52EC28F0D0 /* SBUOpenChannelSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsModule.swift; sourceTree = ""; }; - C17AFFFF84626265B8C333A6 /* SBUAnimation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAnimation.swift; sourceTree = ""; }; + C0C346D6EED1C20C50D275E9 /* GroupOperatorListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListViewConverter.List.swift; sourceTree = ""; }; + C11C0F93FE87E0C4F72A5027 /* SBUMultipleFilesMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCell.swift; sourceTree = ""; }; + C11CD6DE01963046D4167D31 /* SBUAvailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUAvailable.swift; sourceTree = ""; }; + C13060009BC2B7A91C44C6AA /* SBUViewLifeCycle.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUViewLifeCycle.swift; sourceTree = ""; }; + C14904CE37235FCDF0FF6ACD /* SBUCreateChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelViewController.Deprecated.swift; sourceTree = ""; }; + C14D33CD97DDAE9959DB7FAB /* SBUTemplateLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTemplateLabel.swift; sourceTree = ""; }; + C155DD4B518BAA95DA93098F /* SBUOpenChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Deprecated.swift; sourceTree = ""; }; C19B7801E10F35318619EB84 /* CustomOpenChannelList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.List.entireView.swift; sourceTree = ""; }; - C2CC930353E9AF952D5C1E72 /* SBUCreateChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelViewController.swift; sourceTree = ""; }; - C2DC6AC36C13CF9CE994D450 /* OpenModerationsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenModerationsView+Item.swift"; sourceTree = ""; }; + C1C275129547FD119EC8DC0A /* SBUCreateGroupChannelModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateGroupChannelModule.List+SwiftUI.swift"; sourceTree = ""; }; + C1DE532D5BE137069E46610F /* SBUCreateOpenChannelModule.ProfileInput.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.ProfileInput.swift; sourceTree = ""; }; + C26C7227DB3F3D547F68EFB0 /* SBUQuoteMessageInputView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuoteMessageInputView.swift; sourceTree = ""; }; C311C0B887E424C930D2D503 /* CustomGroupChannelList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.swift; sourceTree = ""; }; - C322F14245229C7D8D078D67 /* SBUBaseChannelModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.Input.swift; sourceTree = ""; }; - C32AC3ABF480C0D62322AE3B /* MessageSearchView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchView.swift; sourceTree = ""; }; C35485398319DEEEC3845442 /* CustomGroupChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.swift; sourceTree = ""; }; + C3AD5EEF2606A62F9F0CD9E2 /* SBUMessageProfileView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageProfileView.swift; sourceTree = ""; }; + C3B03F7CD7C1C6606A5BA43F /* SBUEmptyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEmptyView.swift; sourceTree = ""; }; C3D8C639BF0842F457D02910 /* CustomMessageSearch.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.SwiftUI.View.Main.swift; sourceTree = ""; }; C3FE16B863E8BBB398CBE7A9 /* CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift; sourceTree = ""; }; + C480862D8A2D16A98B766589 /* OpenMutedParticipantListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenMutedParticipantListView+ViewConverter.swift"; sourceTree = ""; }; C48F413351CBA7170C9961DF /* CustomGroupOperatorList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.swift; sourceTree = ""; }; - C4B4928DCE8DCBA7C80D26C0 /* SBUOpenChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Deprecated.swift; sourceTree = ""; }; C4E395239704CB0253A0C036 /* CustomGroupMemberList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.List.entireView.swift; sourceTree = ""; }; + C539EDA44801E5FA137C9F14 /* SBUBaseMessageCell.MessageThread+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUBaseMessageCell.MessageThread+SwiftUI.swift"; sourceTree = ""; }; C550DBA483C82B34FA1CAEB2 /* CustomInviteUser.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.swift; sourceTree = ""; }; - C589684819C0917EE5FC82DE /* BaseMessage+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "BaseMessage+SBUIKit.swift"; sourceTree = ""; }; - C5CB3C5D62F094A20945FC45 /* ViewItemProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewItemProtocol.swift; sourceTree = ""; }; - C5F3807ECAAB76E19DBFE2D1 /* GroupMemberListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListView.swift; sourceTree = ""; }; - C6401EB0744D3234CC09B212 /* SBUGroupChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewController.swift; sourceTree = ""; }; - C70D83A51D1811A88B0C140E /* SBUMultipleFilesMessageCollectionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCollectionView.swift; sourceTree = ""; }; - C73D7E5C13B65599FAE5D2E3 /* SBUVoiceMessageInputView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceMessageInputView.swift; sourceTree = ""; }; - C74FF03A1BD9590647429D9E /* SBUScrollBottomView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUScrollBottomView+SwiftUI.swift"; sourceTree = ""; }; + C5A04F4ED104E23B61B85318 /* SBUBaseChannelSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingCell.swift; sourceTree = ""; }; + C5B096932C37180E655EB9A6 /* SBUCreateChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelViewController.swift; sourceTree = ""; }; + C5DDEFBCE4985FC09EB4B6D2 /* OpenChannelSettingsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelSettingsView+Item.swift"; sourceTree = ""; }; + C61C960E362565B1258C1530 /* OpenModerationsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenModerationsView+ViewConverter.swift"; sourceTree = ""; }; + C6B832789F70E71F8D7572D9 /* GroupBannedUserListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupBannedUserListView+Item.swift"; sourceTree = ""; }; + C6D06846C4514870E7373463 /* SBUMessageTemplateManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateManager.swift; sourceTree = ""; }; + C6F654B64098E41716C2FE00 /* SBUOpenChannelListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelListModule.List+SwiftUI.swift"; sourceTree = ""; }; + C7291EB72F5BC939C93ACD43 /* SBUOpenOperatorListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenOperatorListModule.Header+SwiftUI.swift"; sourceTree = ""; }; C7600AD2C584F0101C89CBAB /* CustomOpenChannel.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - C7EFCE231326D9CFCB928363 /* SBUBaseChannelSettingsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsModule.swift; sourceTree = ""; }; + C777B171EAF9592EA52F9707 /* OpenChannelViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewProvider.swift; sourceTree = ""; }; + C7A7A445786CDA239FC3A495 /* OpenChannelListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelListView+Item.swift"; sourceTree = ""; }; + C7FE5E5ECE83C43C1C690C3C /* OpenOperatorListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenOperatorListViewProvider.swift; sourceTree = ""; }; C877EE241E9DBF85CC0AEAEC /* CustomGroupOperatorList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - C881A0739A99CFC25E5779FE /* ViewItemInitialize.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewItemInitialize.swift; sourceTree = ""; }; - C8892CCB312BD353673997C2 /* SBUChannelListViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelListViewController.Deprecated.swift; sourceTree = ""; }; + C88F606D9A7BFD1287285E78 /* SBUGlobals.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGlobals.Deprecated.swift; sourceTree = ""; }; C8B010F0771DB55B89DB52D6 /* CustomTheme.IconSet.Custom.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomTheme.IconSet.Custom.Main.swift; sourceTree = ""; }; - C8BA1B8C93D3C73902AD9BD4 /* SBUUserCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserCell.swift; sourceTree = ""; }; - C8CA206B4B29BAF26852CB29 /* SBUModerationsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsViewModel.swift; sourceTree = ""; }; + C9B2E0BAC9866D25FE5F8F5F /* GroupChannelListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewConverter.Header.swift; sourceTree = ""; }; C9C266B8A2DF6EB7F1504782 /* CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift; sourceTree = ""; }; + C9DE89D8E1BB400650B44CF8 /* SBUGroupChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.List.swift; sourceTree = ""; }; + C9DED4E5BC49F741DD5BAE12 /* SBUOpenChannelUserMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelUserMessageCell.swift; sourceTree = ""; }; CA1DD2E5AE504E97921165C8 /* CustomInviteUser.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomInviteUser.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; - CA33454C78840807B7841838 /* OpenBannedUserListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewConverter.swift; sourceTree = ""; }; + CA4BAF0DBCE4A96D3835303E /* SBUBaseMessageCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUBaseMessageCell+SwiftUI.swift"; sourceTree = ""; }; + CA7760618CB22098FFAA5180 /* SBUNavigationTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNavigationTitleView.swift; sourceTree = ""; }; CAC0DD1043216CB7D20D5D0C /* CustomOpenChannel.ViewConverter.List.userMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.userMessageView.swift; sourceTree = ""; }; - CADB3058FF6F4B079FB37BB8 /* SBUBaseMessageCellParams.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCellParams.Deprecated.swift; sourceTree = ""; }; CAF2F3B78EE368AFF2C5AAFC /* CustomOpenChannelList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.SwiftUI.View.Main.swift; sourceTree = ""; }; - CB0B81E6414A56CEC58EB58E /* SBUBaseMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseMessageCellParams.swift; sourceTree = ""; }; - CB21C648253FAC1AE4DF7C2A /* SBUGroupChannelSettingsModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.List.swift; sourceTree = ""; }; - CB4BEBA0FDEDCCE9A5804BB9 /* SBUOpenChannelCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelCell.swift; sourceTree = ""; }; - CBD4AF9A5A39CD6EB954C272 /* SBUMessageTemplate.Syntax.Aligns.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Aligns.swift; sourceTree = ""; }; - CBDE8C489CF491949336BA54 /* CreateGroupChannelView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CreateGroupChannelView+ViewConverter.swift"; sourceTree = ""; }; - CC3F606B79E0EAB2E982DC39 /* GroupOperatorListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupOperatorListView+SubViewBuilder.swift"; sourceTree = ""; }; - CC66BFE52B21FA2B30AE8E30 /* SBUStackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUStackView.swift; sourceTree = ""; }; - CC6D68CE2E93880EB54D12ED /* UIScrollView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIScrollView+SBUIKit.swift"; sourceTree = ""; }; - CC744E2B758AC433553ABEBB /* SBUFeedNotificationChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelViewModel.swift; sourceTree = ""; }; + CB20C7C8D91A4FB6BE5BB00A /* SBUCacheManager.Template.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Template.swift; sourceTree = ""; }; + CB98E8EF9F62A00D52D15264 /* SBUGroupChannelModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.Input.swift; sourceTree = ""; }; + CBB1CE2457846204624418C0 /* SBUMessageTemplate.Syntax.Aligns.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Aligns.swift; sourceTree = ""; }; + CBC80E25FFD78206A507757A /* SBUGroupMutedMemberListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupMutedMemberListModule.List+SwiftUI.swift"; sourceTree = ""; }; + CBF25F56D448A252479D1AA3 /* SBUModuleSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModuleSet.swift; sourceTree = ""; }; + CBFB50A8249F3AF8106E3D7E /* SBUGroupChannelModule.Input+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelModule.Input+SwiftUI.swift"; sourceTree = ""; }; + CC43AC31B6D1017FAD879CC6 /* GroupChannelView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelView.swift; sourceTree = ""; }; CCAC3124A832A9847294D2F8 /* CustomCreateGroupChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.swift; sourceTree = ""; }; - CCAD3EB06242ACBE685CAC9A /* SBUCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCollectionViewCell.swift; sourceTree = ""; }; - CCF3DD6DAEDA6404D3F9EDFB /* SBUGroupBannedUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupBannedUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - CD163025FD5F2FDEBE9F839A /* OpenModerationsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewConverter.List.swift; sourceTree = ""; }; - CD8F9ED1B50DBD995EEF594B /* GroupModerationsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupModerationsView+Item.swift"; sourceTree = ""; }; - CDF5A13CCF666CC7179C7878 /* SBUOpenUserListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenUserListModule.Header+SwiftUI.swift"; sourceTree = ""; }; + CCF1C1BAB1FCE4DA3FADC95C /* GroupOperatorListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupOperatorListView+SubViewBuilder.swift"; sourceTree = ""; }; + CD3F95DAB17E94241A3A1355 /* GroupChannelProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelProvider.swift; sourceTree = ""; }; + CE2F4109190C0315167EAF1C /* SBUTableViewCell.Unavailable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTableViewCell.Unavailable.swift; sourceTree = ""; }; CE41B8A5727684B5E30295B4 /* CustomOpenChannel.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.entireView.swift; sourceTree = ""; }; - CEC51145218937994CD7E226 /* CreateOpenChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelViewConverter.swift; sourceTree = ""; }; + CE4DFFF0E46FAB0FDF0048EF /* SBUOpenChannelModule.Input+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelModule.Input+SwiftUI.swift"; sourceTree = ""; }; + CE5CDE3DA748B162A1898531 /* SBUConfig.CodingKeys.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.CodingKeys.swift; sourceTree = ""; }; + CE6D4B74FB8A576A0ED92AB0 /* ViewControllerTypeProtocol + swiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "ViewControllerTypeProtocol + swiftUI.swift"; sourceTree = ""; }; + CE82953971F0DF674CF5F599 /* SBUGroupModerationsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupModerationsModule.Header+SwiftUI.swift"; sourceTree = ""; }; + CEAD608897F9DE73D59EB1C9 /* SBUOpenBannedUserListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenBannedUserListModule.List+SwiftUI.swift"; sourceTree = ""; }; + CEFEC44A228BCC230686AC05 /* SBUMessageTemplate.Syntax.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Item.swift; sourceTree = ""; }; + CF02A0C341CEE4D97DF115CD /* SBUTableViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTableViewCell.swift; sourceTree = ""; }; CF06ED3F6955863BF89D804C /* CustomGroupChannel.ViewConverter.Header.typingStatusView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Header.typingStatusView.swift; sourceTree = ""; }; + CF2784E3ECE293C035C957A6 /* SBUTemplateType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTemplateType.swift; sourceTree = ""; }; CF631CBCF396FA6414917B91 /* CustomOpenChannel.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - D0EAB282FB441D9B3F630D3C /* QuotedFileImageContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QuotedFileImageContentView.swift; sourceTree = ""; }; + CF745C20CDD40C35ACDA3A76 /* SBUDebouncer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDebouncer.swift; sourceTree = ""; }; + CF9B3D01A792D6AB23816E47 /* GroupModerationsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsView.swift; sourceTree = ""; }; + CFC414657A88A22B041B0248 /* ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewConverter.swift; sourceTree = ""; }; + D00605CF296075CBED52EF08 /* UICollectionView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UICollectionView+SBUIKit.swift"; sourceTree = ""; }; + D0176BCE61DDDBD6F0937F8E /* SBULogger.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULogger.swift; sourceTree = ""; }; + D0B305731A8CE51649B82676 /* SBUBaseChannelSettingsViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsViewController.Deprecated.swift; sourceTree = ""; }; D0F49DB6B8C7DF57E5377F0D /* CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift; sourceTree = ""; }; - D0FD98E815C023134E9123D4 /* SBUCreateChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelModule.List.swift; sourceTree = ""; }; + D1138C0CF644F604A4DB6BEA /* SBUOpenChannelListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListViewController.swift; sourceTree = ""; }; D123A133B83CA3E4C6A55CB3 /* CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; D1ADCD8B486C3D101AA4CBF8 /* CustomOpenParticipantList.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.List.entireView.swift; sourceTree = ""; }; D1BE7FE947E6F68414C95978 /* CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - D23CE29CE2785C1F89E0FE88 /* SBUMessageFormFallbackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageFormFallbackView.swift; sourceTree = ""; }; - D26E0EABCE381C370B68E9A8 /* SBUOpenChannelListModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelListModule.Header+SwiftUI.swift"; sourceTree = ""; }; - D2CCFB76C36D83C085F65E5C /* SBUCategoryFilterCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCategoryFilterCell.swift; sourceTree = ""; }; - D2F9885440D0492C8904699E /* SBUMarkdownTransfer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMarkdownTransfer.swift; sourceTree = ""; }; + D1C0385D2634A8150F5B7765 /* MessageSearchViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewConverter.List.swift; sourceTree = ""; }; + D250660811AF42D876E15FA9 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + D2A3BE2336B9819BFB36AD1E /* OpenModerationsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsView.swift; sourceTree = ""; }; + D2A9680190548D628D0D71B0 /* GroupChannelPushSettingsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelPushSettingsView+ViewConverter.swift"; sourceTree = ""; }; + D2AECC85EB8D47720009CB4A /* GroupBannedUserListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewConverter.Header.swift; sourceTree = ""; }; + D2FFCD9112A92A33B800F41A /* SBUOpenChannelImageContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelImageContentView.swift; sourceTree = ""; }; D3437E424B7438108BB128B1 /* CustomCreateGroupChannel.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateGroupChannel.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - D36259D49FBF122E1CC92591 /* SBUModerationsModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModerationsModule.swift; sourceTree = ""; }; + D38E6015D6853331994CD11F /* Data+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Data+SBUIKit.swift"; sourceTree = ""; }; + D3A937118732EBE90BC48E80 /* UIImage+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIImage+SBUIKit.swift"; sourceTree = ""; }; D42CAF359351D6DB452CD96F /* ImagePicker.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ImagePicker.swift; sourceTree = ""; }; + D4348E39A20D96D16960C445 /* SBUTheme+Type.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUTheme+Type.swift"; sourceTree = ""; }; D44ADE8F289364F71D86202A /* CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift; sourceTree = ""; }; - D47B80C8F70B7B35CB44832C /* GroupChannelSettingsView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelSettingsView+ViewConverter.swift"; sourceTree = ""; }; - D4DBC0F7C21761BD70C04903 /* SendbirdUI.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SendbirdUI.Deprecated.swift; sourceTree = ""; }; - D53DD5D59B4099FF2491FD4E /* SBUPropertyWrapper.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPropertyWrapper.swift; sourceTree = ""; }; - D5497D090BBDCC67C4F8CBF8 /* SBUMessageDateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageDateView.swift; sourceTree = ""; }; D575F4B28A9776FA1080738B /* CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; + D5A8512A3DE8E4E3C4FD944C /* SBUVoiceRecorder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceRecorder.swift; sourceTree = ""; }; + D5E60FEA77508AA565B02B9B /* OpenMutedParticipantListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenMutedParticipantListView+Item.swift"; sourceTree = ""; }; D60BB10FA597EA02D980A94F /* CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift; sourceTree = ""; }; - D60D97979BB0D61C336877D6 /* SBUOpenUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; D627C22FA33DADBCD007F40D /* CustomOpenChannelSettings.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelSettings.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - D677AA356C4DC935016C176E /* SBULogger.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULogger.swift; sourceTree = ""; }; D6830E84616231F70E92CB43 /* CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - D7863D6531C9EAA4341984F9 /* SBUFeedNotificationChannelViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelViewParams.swift; sourceTree = ""; }; - D78D017455F58559F9F64C82 /* SBUGroupOperatorListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupOperatorListModule.List+SwiftUI.swift"; sourceTree = ""; }; + D6DA1D0A44C99A7052978AB9 /* GroupChannelListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewConverter.swift; sourceTree = ""; }; + D6E8137AEC2C6412832EEF1E /* SBUMessageWebView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageWebView.swift; sourceTree = ""; }; D7B7852719332CFD27879AB8 /* QuickStartSwiftUIApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QuickStartSwiftUIApp.swift; sourceTree = ""; }; + D7C327FC68584CFA626021FF /* SBUChannelSettingsChannelInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelSettingsChannelInfoView.swift; sourceTree = ""; }; D7E0033519CF0DFDBF445DBF /* CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - D8573A563BC2E14A69A49B2C /* SBUMessageThreadModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.Deprecated.swift; sourceTree = ""; }; + D7E1ACADA48174C1998A7B11 /* SBUMessageThreadViewController.SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadViewController.SwiftUI.swift; sourceTree = ""; }; + D7E4393E73BAF35A4ECF1541 /* SBUCacheManager.Version.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Version.swift; sourceTree = ""; }; D858342C8951A91AE5FA7F29 /* CustomOpenChannelList.ViewConverter.List.channelName.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.List.channelName.swift; sourceTree = ""; }; - D86D4D360EBE5B44F0D0606D /* SBUSuggestedReplyViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedReplyViewParams.swift; sourceTree = ""; }; D892CA4FD6B2597BFF04D24F /* CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift; sourceTree = ""; }; - D8F39143F890265770E857F8 /* GroupOperatorListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupOperatorListView.swift; sourceTree = ""; }; - D9083FB6B72A4A282A2389B1 /* SBUUserListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserListModule.List.swift; sourceTree = ""; }; - D9349402FEC3ACCC843C056E /* GroupMutedMemberListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewConverter.swift; sourceTree = ""; }; - D9794223D75D07919015D20B /* OpenChannelSettingsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewConverter.Header.swift; sourceTree = ""; }; - D98EB11025EC91C28DF16EA2 /* SBUPhotoCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUPhotoCollectionViewCell.swift; sourceTree = ""; }; - D9B434F3BB648812D03FFFB9 /* SBUToastView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastView.swift; sourceTree = ""; }; - D9C0E0D304969F74F95F6857 /* CGSize+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "CGSize+SBUIKit.swift"; sourceTree = ""; }; - D9F55FA2519DCC099F23C4F0 /* SBUMessageTemplate.Action.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Action.swift; sourceTree = ""; }; - DA4BD8DEDFBA0A910449DB84 /* SBUConfig.CodingKeys.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.CodingKeys.swift; sourceTree = ""; }; - DAD0A5FC842160B00A941361 /* SBUReactionsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUReactionsViewController.swift; sourceTree = ""; }; + D8EA593C614B0BDD8E1FA2C8 /* SBUChatNotificationChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.swift; sourceTree = ""; }; + D91401F0CEDB5A733BE00C20 /* SBUGroupChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.swift; sourceTree = ""; }; + D95DA4F7F43B4408328A06B2 /* SBURegisterOperatorModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.Deprecated.swift; sourceTree = ""; }; + D96FF4DECC16108247C2B05F /* MethodOverridable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MethodOverridable.swift; sourceTree = ""; }; + D9735294E73DAE6D3E1FDB33 /* SBUOpenChannelCommonContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelCommonContentView.swift; sourceTree = ""; }; + D9AC164247B4ADF8D79CF790 /* SBUContentBaseMessageCell.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUContentBaseMessageCell.Deprecated.swift; sourceTree = ""; }; + D9CFDA621D7A6EB6427288A6 /* UIView+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIView+SBUIKit.swift"; sourceTree = ""; }; + DA2F3BFBE980CBE8A343DE43 /* SBUBaseChannelModule.Input.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.Input.swift; sourceTree = ""; }; + DA8B78F1D3A60872891EB8E5 /* SBUMessageSearchModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.swift; sourceTree = ""; }; + DAA4591A42376EF2D300B7CE /* SBUGroupUserListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupUserListUserCell+SwiftUI.swift"; sourceTree = ""; }; DAD98D54B19D973D5419D595 /* MySettingsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MySettingsView.swift; sourceTree = ""; }; - DB82FCDC07B9737FF5237466 /* OpenChannelRegisterOperatorViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewConverter.swift; sourceTree = ""; }; - DBC22FB20B9809BA2B7123A3 /* SBUMessageReactionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageReactionView.swift; sourceTree = ""; }; - DC1B024DDFE6E63F14713E79 /* SBUOpenChannelSettingCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingCell.swift; sourceTree = ""; }; - DC3DF1FA4AFE90DC6FA8AC20 /* SBUBaseSelectUserModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserModule.List.swift; sourceTree = ""; }; - DCEAE022E08885F8F8991889 /* UIStackView.SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIStackView.SBUIKit.swift; sourceTree = ""; }; + DAED2EACDE1CAAA7CC8688DE /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupChannelPushSettingsModule.List+SwiftUI.swift"; sourceTree = ""; }; + DB28FF204E44C2979312FED6 /* SBUMultipleFilesMessageCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMultipleFilesMessageCollectionViewCell.swift; sourceTree = ""; }; + DB3E0B3AF5888509BFD2E7D5 /* SBUBaseChannelModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelModule.swift; sourceTree = ""; }; + DB6DB1D4C127ED23F83429E9 /* SBUHorizontalSuggestedReplyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUHorizontalSuggestedReplyView.swift; sourceTree = ""; }; + DB95C0B594B7B03CE1B623A2 /* WeakDelegateStorage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WeakDelegateStorage.swift; sourceTree = ""; }; + DBC40F923C1D6C6FC592B67A /* OpenChannelSettingsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewConverter.Header.swift; sourceTree = ""; }; + DBE77CA1AA32061F0B89F310 /* OpenChannelListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelListView.swift; sourceTree = ""; }; + DC2A8DE6A8BFEB20D40A60BB /* SBUCollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCollectionViewCell.swift; sourceTree = ""; }; + DC5F4EF470234F308512D764 /* SBUMessageThreadModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageThreadModule.Header.swift; sourceTree = ""; }; + DC897D28420AE8B2454DCA7A /* SBUCreateOpenChannelViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelViewController.swift; sourceTree = ""; }; DD06A568617A957C0B077EE4 /* CustomOpenParticipantList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - DD198E6C9A69D0C4810F6C0F /* SBUGroupMutedMemberListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupMutedMemberListUserCell+SwiftUI.swift"; sourceTree = ""; }; - DDDF7743ADEF95903798D261 /* SBUConfig.GroupChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.GroupChannel.swift; sourceTree = ""; }; + DD29661D82CBA8D0E3513C8D /* SBUChatNotificationChannelModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.List.swift; sourceTree = ""; }; + DD44488053095D7122FB760C /* SBUInviteUserModule.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.swift; sourceTree = ""; }; + DD82DA89A3CA5C66A6996786 /* SBUToastView.Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastView.Item.swift; sourceTree = ""; }; + DDD86011BD9689522AFEA443 /* SBUMessageCache.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageCache.swift; sourceTree = ""; }; + DDFD71AA835A87908EFEEAF0 /* SBUMessageTemplate.PayloadType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.PayloadType.swift; sourceTree = ""; }; DE1FBB912E6B266BF075DA58 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist; path = Info.plist; sourceTree = ""; }; - DE2C77128576368219B73147 /* SBUBaseChannelCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelCell.swift; sourceTree = ""; }; - DE4692268960D6FB3AD51F3A /* SBUMessageSearchViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchViewController.Deprecated.swift; sourceTree = ""; }; + DECFF1D9649B3B654288217B /* MessageSearchView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageSearchView+Item.swift"; sourceTree = ""; }; DED9CED6E144447EA5AF3CFE /* CustomMessageThread.ViewConverter.Header.titleLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Header.titleLabel.swift; sourceTree = ""; }; - DEE36BE9DDD0FCF4E77E17DA /* SBUUserNameView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserNameView.swift; sourceTree = ""; }; - DEFC8D070D3FD13797007DD2 /* SBUBaseChannelSettingsViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsViewModel.swift; sourceTree = ""; }; - DF0E4D61160B2C4D056ABF96 /* SBUGroupChannelListModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.List.swift; sourceTree = ""; }; - DF1E9EBB5C80F9BC517456A1 /* OpenChannelRegisterOperatorViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewConverter.Header.swift; sourceTree = ""; }; + DEFD2C9C3755450DB4FB300D /* SBUOpenChannelSettingsModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelSettingsModule.List+SwiftUI.swift"; sourceTree = ""; }; DF7D3CD441496E8922807E30 /* CustomGroupOperatorList.SubView.Builder.registerOperator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.SubView.Builder.registerOperator.swift; sourceTree = ""; }; - DFB6D698EDC2ED209371A6BF /* SBUSuggestedReplyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSuggestedReplyView.swift; sourceTree = ""; }; - E009E7101E09810AB0B2A2BA /* SBUVoiceRecorder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceRecorder.swift; sourceTree = ""; }; - E03D59600F0C64AE7B9745E8 /* GroupChannelListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelListView+ViewConverter.swift"; sourceTree = ""; }; - E05180B4571B1F3B9A4BA50C /* SBUBottomSheetController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBottomSheetController.swift; sourceTree = ""; }; - E0A690A691FBFFFB1EA46385 /* SBUOpenChannelBaseMessageCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelBaseMessageCell.swift; sourceTree = ""; }; + DFAF3C2261ECEBCC158D13CD /* SBUOpenOperatorListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenOperatorListModule.List+SwiftUI.swift"; sourceTree = ""; }; + E073AA8CC1B9D07D58D24E07 /* OpenMutedParticipantListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListViewProvider.swift; sourceTree = ""; }; + E0C6B3B15A2C99291A025E96 /* SBUCoverImageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCoverImageView.swift; sourceTree = ""; }; + E0F389D1E864F9A48260D9C7 /* SBUView.Unavaliable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUView.Unavaliable.swift; sourceTree = ""; }; + E1177BB4E92D600EED17C2C8 /* MessageSearchView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "MessageSearchView+SubViewBuilder.swift"; sourceTree = ""; }; E166ED5498A74640EC21B366 /* CustomOpenBannedUserList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.swift; sourceTree = ""; }; E17D9CC93AAD8E92C3BB7587 /* CustomGroupChannel.ViewConverter.Input.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Input.entireView.swift; sourceTree = ""; }; - E1C082271530831A0A97BA43 /* SBUMessageCache.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageCache.swift; sourceTree = ""; }; - E1C31CF4BCC3BBFC1D19D9A3 /* MessageSearchViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageSearchViewConverter.swift; sourceTree = ""; }; - E1D3679B4B2C92ABF5A1CF56 /* SBUTableViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTableViewCell.swift; sourceTree = ""; }; - E209E92758FCC408F49DB85A /* SBUScrollPostionConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUScrollPostionConfiguration.swift; sourceTree = ""; }; - E24BD1FBA414D2FCC2A2825F /* SBUCacheManager.Config.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCacheManager.Config.swift; sourceTree = ""; }; - E27A6013DA5EDC1AE77B2577 /* SBUSearchBar.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSearchBar.swift; sourceTree = ""; }; + E1CE8E0AE7AC6EA86FDF2BB5 /* OpenMutedParticipantListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListView.swift; sourceTree = ""; }; + E1D1009E6F8479AF70D7433D /* SBUUserMessageTextViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageTextViewModel.swift; sourceTree = ""; }; + E2409918FAB1E81ADAE21623 /* SBUMessageSearchModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageSearchModule.Header.swift; sourceTree = ""; }; + E27105B44C5F51755341A1CF /* SBUFeedNotificationCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationCell.swift; sourceTree = ""; }; E28678781153AEB5AD838205 /* CustomGroupChannelList.ViewConverter.List.channelPreview.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelList.ViewConverter.List.channelPreview.swift; sourceTree = ""; }; E292093376A1435753C8717C /* CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift; sourceTree = ""; }; - E2C6311A1B53F43110C9BC88 /* SBUChatNotificationChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChatNotificationChannelModule.Header.swift; sourceTree = ""; }; - E2E0ABB6DADF9727A38ACB20 /* SBUCreateOpenChannelModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.Deprecated.swift; sourceTree = ""; }; - E2E6F8EEF508DA948CDEA60A /* SBUCreateGroupChannelModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUCreateGroupChannelModule.List+SwiftUI.swift"; sourceTree = ""; }; - E3242DE074C1AA33D5C85D4B /* CreateOpenChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CreateOpenChannelViewConverter.Header.swift; sourceTree = ""; }; - E3BB215085699F6E89FF3F5D /* OpenOperatorListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenOperatorListView+ViewConverter.swift"; sourceTree = ""; }; - E473AE77FEB63622BA2CE73E /* OpenChannelSettingsViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewConverter.List.swift; sourceTree = ""; }; + E2ADEA87D2CD1937FE761A55 /* SendbirdSwiftUI-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist; path = "SendbirdSwiftUI-Info.plist"; sourceTree = ""; }; + E396AAA7E062869842D0067C /* SBUNotificationEmptyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationEmptyView.swift; sourceTree = ""; }; + E42AB4882426DF1FBE40A612 /* SBUTheme.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTheme.Deprecated.swift; sourceTree = ""; }; E4D74430CD9A8CE3A3F23515 /* CustomOpenParticipantList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenParticipantList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - E51D27858754EDD555AF4BD5 /* UIViewController+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIViewController+SBUIKit.swift"; sourceTree = ""; }; + E4FB9CBC6163B1B65BACBE4F /* SBUQuoteMessageInputViewProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuoteMessageInputViewProtocol.swift; sourceTree = ""; }; E55454E2280EFAAEE0F18863 /* CustomOpenBannedUserList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenBannedUserList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; E5645C24C2297EC9DBE73B7F /* CustomOpenChannelRegisterOperator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.swift; sourceTree = ""; }; - E5B646591D56E6AFE946CC45 /* SBUConfig.Base.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.Base.swift; sourceTree = ""; }; + E567F385A20BDC53C3078CC6 /* SendbirdChat+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SendbirdChat+SBUIKit.swift"; sourceTree = ""; }; + E593C2078945818E573F8A66 /* SBUMessageTemplate.Renderer.Views.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.Views.swift; sourceTree = ""; }; E5BF064E0D3608B442A23FF6 /* CustomGroupMemberList.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - E62E37A0B85E8D8C1DD0BE42 /* OpenBannedUserListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListViewConverter.List.swift; sourceTree = ""; }; - E643BD503D1B0287D115F459 /* GroupMemberListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewConverter.List.swift; sourceTree = ""; }; - E6541DB78921410A46EA2506 /* SBUFileViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFileViewController.swift; sourceTree = ""; }; - E65E8C83BAC9277CA63A5421 /* BlockingOperation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockingOperation.swift; sourceTree = ""; }; - E672677E26CA7ADF545827E4 /* OpenModerationsViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenModerationsViewConverter.Header.swift; sourceTree = ""; }; - E6AB5AF4E86499D0DFEE881B /* SBULayoutableButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBULayoutableButton.swift; sourceTree = ""; }; - E700A49675E9D9B07C018C41 /* SBUModuleSet.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUModuleSet.Deprecated.swift; sourceTree = ""; }; - E7F4A5C2DE942F918F081586 /* SBUMessageTemplateCell.MessageTemplateLayer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCell.MessageTemplateLayer.swift; sourceTree = ""; }; + E60ABCC74B32B1B8BD7232BD /* SBUBaseChannelListModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelListModule.Header.swift; sourceTree = ""; }; + E68C5044109960435BBDBF86 /* SBUFeedNotificationCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationCellParams.swift; sourceTree = ""; }; + E6C77D06D3443161CF556779 /* SBUOpenChannelListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListViewModel.swift; sourceTree = ""; }; + E7513D0A46E6B0D3B734E065 /* SBUMessageTemplateCell.MessageTemplateLayer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateCell.MessageTemplateLayer.swift; sourceTree = ""; }; + E77ABB425ACC1813E35023C6 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUChannelStateBanner.MessageThread+SwiftUI.swift"; sourceTree = ""; }; + E77E32C1CCB09ED19ED82DC8 /* SBUColorSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUColorSet.swift; sourceTree = ""; }; + E787481C1D3394BE0D6A6CBB /* ProviderWrappedHostingView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ProviderWrappedHostingView.swift; sourceTree = ""; }; E7FA5ACCAFC350D479002755 /* CustomGroupChannel.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - E85ED75EA5E22BAA62EBFB36 /* SBUInviteUserModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUInviteUserModule.Deprecated.swift; sourceTree = ""; }; - E88D2D612D550B0EA07F62CD /* SBUMessageTemplate.ErrorMessages.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.ErrorMessages.swift; sourceTree = ""; }; - E89F994B7B6B705FD09B4921 /* GroupChannelViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.List.swift; sourceTree = ""; }; - E8C797DF2665B67DB664FD80 /* SBUEmptyView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUEmptyView.swift; sourceTree = ""; }; + E8444BA33EBECD12A5B3278F /* SBUUserMessageCellParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUUserMessageCellParams.swift; sourceTree = ""; }; E8F1CE3F5598712CA3C279EB /* CustomGroupOperatorList.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.SwiftUI.View.Main.swift; sourceTree = ""; }; - E91ABFFD5B2067D560F73E17 /* URL+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "URL+SBUIKit.swift"; sourceTree = ""; }; E9388E235D8F81710908610F /* CustomMessageThread.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Header.titleView.swift; sourceTree = ""; }; + E9758CC43DB1F420CFD323D8 /* SBUDateFormatSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUDateFormatSet.swift; sourceTree = ""; }; + E9C129A8E7F7F62801B604ED /* GroupMemberListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewConverter.Header.swift; sourceTree = ""; }; + EA23C8AD569D84167F4DD526 /* InviteUserViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewConverter.swift; sourceTree = ""; }; + EA2A1DDA7731802AB5994AB5 /* OpenChannelViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelViewConverter.Header.swift; sourceTree = ""; }; EA651403B226D24C7BDC99E8 /* CustomOpenChannel.ViewConverter.List.fileMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.ViewConverter.List.fileMessageView.swift; sourceTree = ""; }; - EA9A5B0A5DE2C459A65410DC /* MessageThreadViewConverter.ParentInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MessageThreadViewConverter.ParentInfo.swift; sourceTree = ""; }; - EAB28CD649CAB03111FF852B /* GroupBannedUserListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewConverter.List.swift; sourceTree = ""; }; - EAD9C78B13DA1261EFA4A175 /* GroupMemberListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMemberListViewConverter.swift; sourceTree = ""; }; + EA746A3AC8FF541DF89D4606 /* SBUGroupChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelModule.Header.swift; sourceTree = ""; }; + EAC33A1D45B726CE0C5F2810 /* GroupModerationsViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupModerationsViewProvider.swift; sourceTree = ""; }; + EAF986AD73EAB8ADBC900800 /* OpenParticipantListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenParticipantListView+ViewConverter.swift"; sourceTree = ""; }; EB41910E2789F6B96EF2934E /* CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - EBDD55B35D81B408381A6074 /* SBUGroupChannelListModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.Deprecated.swift; sourceTree = ""; }; - EC000D6306DDB9315E2125AC /* SBUGroupChannelPushSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.Header.swift; sourceTree = ""; }; - EC3CBE8DD286C9ED98CC73C0 /* SBUTheme.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTheme.swift; sourceTree = ""; }; + EB9EAE40ED4B2267D13C0B8C /* Sendbird+Typealias.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Sendbird+Typealias.swift"; sourceTree = ""; }; + EBF7F15698BF3AB2B7C0B92A /* SBUOpenChannelModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelModule.List+SwiftUI.swift"; sourceTree = ""; }; EC5D44A320DBE9B8DB580423 /* CustomMessageThread.SwiftUI.View.CustomMain.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.SwiftUI.View.CustomMain.swift; sourceTree = ""; }; - ECA3A3BB1C8BE8DD7400F28B /* Sendbird.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Sendbird.swift; sourceTree = ""; }; - ED4992F14BC1A4369B0FE99F /* SBUReplyConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUReplyConfiguration.swift; sourceTree = ""; }; + ECA54CBEF188987F7469149B /* SBUOpenOperatorListUserCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenOperatorListUserCell+SwiftUI.swift"; sourceTree = ""; }; + ECDE3327C779F78C5CA0DC65 /* GroupBannedUserListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupBannedUserListViewConverter.List.swift; sourceTree = ""; }; + ECE0E78C0DE00AD12F25AC49 /* GroupChannelRegisterOperatorViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelRegisterOperatorViewProvider.swift; sourceTree = ""; }; + EE0E3266C8A26B645EE82DB8 /* SBUFeedbackView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedbackView.swift; sourceTree = ""; }; EE135331D28927031AA660D6 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; - EE2A55A25B370F6C8ED56E24 /* SBUGroupChannelCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelCell.swift; sourceTree = ""; }; - EE2A90E5736F2795003DC13E /* OpenChannelSettingsViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelSettingsViewConverter.swift; sourceTree = ""; }; - EE2E49B4FC91D817366079ED /* SBUOpenChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelViewController.Deprecated.swift; sourceTree = ""; }; - EE7B5B27FFA176D18D23171C /* SBUTheme+Type.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUTheme+Type.swift"; sourceTree = ""; }; - EECE2AC717C2FBAC7D59465F /* SBUMessageTemplate.Renderer.RendererType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Renderer.RendererType.swift; sourceTree = ""; }; + EE88D3E3ECD3A7A231EA8AA7 /* SBUQuotedFileMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedFileMessageView.swift; sourceTree = ""; }; + EE8F91080D5B149513B0FF6A /* OpenParticipantListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewConverter.swift; sourceTree = ""; }; EF14FECB8F18A1D036D7C324 /* CustomMessageThread.ViewConverter.Input.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Input.rightView.swift; sourceTree = ""; }; - EFE82704B02948EF4CB57B1C /* SBUConfig.OpenChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.OpenChannel.swift; sourceTree = ""; }; - EFF7F3AFE50A393A18343E1D /* SBUOpenChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Header.swift; sourceTree = ""; }; - F06A8792B7A5667225B0B139 /* SBUMessageProfileView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageProfileView.swift; sourceTree = ""; }; - F0965E8B16F9D4C0559C110F /* GroupMutedMemberListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMutedMemberListView+ViewConverter.swift"; sourceTree = ""; }; - F0B4A24D18198AD3FC6A6896 /* GroupChannelPushSettingsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupChannelPushSettingsView+SubViewBuilder.swift"; sourceTree = ""; }; - F0B58422C8C6BDC4A3B19315 /* UINavigationController+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UINavigationController+SBUIKit.swift"; sourceTree = ""; }; - F0B78A78B3EEDCE40DFDFD34 /* SBUVoiceContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceContentView.swift; sourceTree = ""; }; - F0C58F296D9B6516563598F5 /* SBUGroupChannelViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelViewController.Deprecated.swift; sourceTree = ""; }; + EF30301466491271F0E3512D /* SBURegisterOperatorViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorViewController.swift; sourceTree = ""; }; + EF67B852DBB45B4929297E29 /* SBUNewMessageInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNewMessageInfo.swift; sourceTree = ""; }; + F00384B1EF32956E18353B90 /* SBUMessageTemplate.ImageRatioType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.ImageRatioType.swift; sourceTree = ""; }; + F02236D8926A5EE794CBBE3F /* SBUTypingIndicatorInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorInfo.swift; sourceTree = ""; }; F0CC325811E3058B01772942 /* CustomOpenChannel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannel.swift; sourceTree = ""; }; F0F5806465F7C6A9458CFA95 /* CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift; sourceTree = ""; }; - F11CCC27B98DC10813651863 /* SBUHighlightMessageInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUHighlightMessageInfo.swift; sourceTree = ""; }; - F1906ACF63D4B5C27FB224F3 /* SBUCreateChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateChannelViewModel.swift; sourceTree = ""; }; + F1211AAEFCC66ABDC646D834 /* InviteUserView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "InviteUserView+SubViewBuilder.swift"; sourceTree = ""; }; + F124AB50E137D73C24E2B83D /* GroupChannelListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewConverter.List.swift; sourceTree = ""; }; + F1CA0FD406EF14F103F993F1 /* SBUCreateOpenChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelViewModel.swift; sourceTree = ""; }; F1E04EDD53838E84619F3E17 /* Preview Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = "Preview Assets.xcassets"; sourceTree = ""; }; - F2B377E7421E1FDDFB61C7DA /* OpenMutedParticipantListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenMutedParticipantListView+Item.swift"; sourceTree = ""; }; + F200CA4F5373C5A264BE312A /* UIApplication+SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UIApplication+SBUIKit.swift"; sourceTree = ""; }; + F21197AC02DB3794FF1A73B9 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenMutedParticipantListModule.List+SwiftUI.swift"; sourceTree = ""; }; + F28B6B09EF78A29A92725BD6 /* Closure.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Closure.swift; sourceTree = ""; }; F34DA7D7D4B2985E294981E7 /* CustomGroupMemberList.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupMemberList.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - F35CD8BA9042B97652CACABA /* SBUOpenChannelListViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelListViewModel.swift; sourceTree = ""; }; - F35DAFB453749AFE67CD58EE /* GroupModerationsView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupModerationsView+SubViewBuilder.swift"; sourceTree = ""; }; - F363B8C0EDA127F26AAFA8CD /* SBUOpenOperatorListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenOperatorListModule.List+SwiftUI.swift"; sourceTree = ""; }; - F37A3C0CAC8D9964CABBB7D5 /* GroupChannelListViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewConverter.List.swift; sourceTree = ""; }; - F3B37A003211506172A34CE4 /* GroupChannelListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelListViewConverter.Header.swift; sourceTree = ""; }; + F3B52DE1481E7DCF5E9A0B11 /* SBUFeedNotificationChannelViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFeedNotificationChannelViewModel.swift; sourceTree = ""; }; F3D5ADC9FA4617F866CEFED1 /* CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift; sourceTree = ""; }; - F3D7ECABBD13ECA6EDB56017 /* SBUTheme.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTheme.Deprecated.swift; sourceTree = ""; }; + F406B0CC701411F859F4934A /* InviteUserViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InviteUserViewProvider.swift; sourceTree = ""; }; F4562E0FF6115855EA43DEB3 /* CustomOpenChannelList.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenChannelList.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - F4CCF79AABF76CC5A2F14629 /* OpenChannelSettingsView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelSettingsView+Item.swift"; sourceTree = ""; }; - F4E0A861082E4DD96C4AF034 /* SBUQuoteMessageInputView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuoteMessageInputView.swift; sourceTree = ""; }; + F49E6F0696729061F88BAF0C /* SBUVoiceContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceContentView.swift; sourceTree = ""; }; + F4D4EB006F53EF06F2BA27A2 /* SBUOpenChannelModule.Media.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelModule.Media.swift; sourceTree = ""; }; F4FB5E4998023A160CBFE588 /* CustomGroupModerations.ViewConverter.Header.titleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.ViewConverter.Header.titleView.swift; sourceTree = ""; }; - F566B012103F8EEBE03AECA3 /* BaseMessage+SBUIKit.MessageTemplate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "BaseMessage+SBUIKit.MessageTemplate.swift"; sourceTree = ""; }; - F5787B281C37A19736CD8A8A /* SBUGroupChannelListViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListViewController.swift; sourceTree = ""; }; + F52098C95DFA4A3CBB23C61B /* SBUMessageStateView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageStateView.swift; sourceTree = ""; }; + F5A9EC87E51CE11529D2B28C /* SBUMessageSearchModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUMessageSearchModule.List+SwiftUI.swift"; sourceTree = ""; }; + F5ABD9526E2BC97012171C4A /* SendbirdUI+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SendbirdUI+SwiftUI.swift"; sourceTree = ""; }; + F5B10A1CDEC20024D2B59210 /* OpenChannelRegisterOperatorView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorView.swift; sourceTree = ""; }; F60F28A03D242FFB2D615190 /* CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift; sourceTree = ""; }; + F624E4320147A947036A7DE1 /* GroupMemberListView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupMemberListView+SubViewBuilder.swift"; sourceTree = ""; }; + F6255269EEFB1064CBD9ED02 /* SBUOpenChannelSettingsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelSettingsViewController.swift; sourceTree = ""; }; F66A9356D0027AF606372658 /* CustomOpenOperatorList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenOperatorList.swift; sourceTree = ""; }; - F680D037CDE9E80938B09CC6 /* SBUQuotedMessageViewProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuotedMessageViewProtocol.swift; sourceTree = ""; }; F6823DFB6EB45E555D00876D /* CustomGroupBannedUserList.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupBannedUserList.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - F69D522AF28DCC02E3639775 /* OpenMutedParticipantListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenMutedParticipantListView.swift; sourceTree = ""; }; - F6D93377303A480B6512DD30 /* SBUGroupChannelListModule.Common.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelListModule.Common.swift; sourceTree = ""; }; - F7159308B1615AF89E0C5848 /* SBUMessageTemplateManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplateManager.swift; sourceTree = ""; }; - F7307101AAA00FA1558AF980 /* SBUGroupModerationsModule.Header+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupModerationsModule.Header+SwiftUI.swift"; sourceTree = ""; }; - F7BC78603E390AB17CF9BE14 /* SBUChannelTitleView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUChannelTitleView.swift; sourceTree = ""; }; - F8581D84EDC1F269B235F2B2 /* SBUOpenChannelMessageWebView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUOpenChannelMessageWebView.swift; sourceTree = ""; }; - F878EF1542E0FD36E8ED1D96 /* SBUTypingIndicatorInfo.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTypingIndicatorInfo.swift; sourceTree = ""; }; + F6D788FD7849625F5F58CEDE /* SBUParentMessageInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUParentMessageInfoView.swift; sourceTree = ""; }; + F7EDA70EF7D626DD23ABD4C8 /* SBUSearchBar.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUSearchBar.swift; sourceTree = ""; }; + F88ED0A9054B24C63657907F /* OpenChannelListView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelListView+ViewConverter.swift"; sourceTree = ""; }; F89671E15060D30405A5A9B7 /* CustomOpenModerations.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomOpenModerations.ViewConverter.Header.rightView.swift; sourceTree = ""; }; + F8C4831068F0F117DDA51E76 /* SBUMenuCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMenuCell.swift; sourceTree = ""; }; F8E8BBB7F3386838673ACE44 /* CustomMessageSearch.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.ViewConverter.List.entireView.swift; sourceTree = ""; }; - F92B219D2E3A203BB7E9F3EB /* SBUOpenChannelInputView+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelInputView+SwiftUI.swift"; sourceTree = ""; }; - F996C7F4D29C1645E1465E33 /* SBUGroupMutedMemberListModule.List+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUGroupMutedMemberListModule.List+SwiftUI.swift"; sourceTree = ""; }; + F9287770F82C83D551563531 /* OpenParticipantListViewProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewProvider.swift; sourceTree = ""; }; + F94CBE179EC28528B6D75C20 /* SBUConfig.Common.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUConfig.Common.swift; sourceTree = ""; }; + F953887FA77606336B478451 /* SBUScrollPostionConfiguration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUScrollPostionConfiguration.swift; sourceTree = ""; }; + F9AD7543D82F147890DDA8EC /* SBUNotificationChannelManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUNotificationChannelManager.swift; sourceTree = ""; }; F9BC7BDE74485AE5C8C934A4 /* CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift; sourceTree = ""; }; + F9D3B79BEAF2D1C7C3D484D0 /* SBUGroupChannelSettingsModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelSettingsModule.Header.swift; sourceTree = ""; }; F9FF61E04422CDF019FC8A14 /* CustomMessageSearch.ViewConverter.Header.leftView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageSearch.ViewConverter.Header.leftView.swift; sourceTree = ""; }; - FAC8E79C1FEAE3685E293243 /* SBUMessageTemplate.Syntax.Views.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Syntax.Views.swift; sourceTree = ""; }; - FB5A989D9069803A11632F6A /* OpenChannelView+SubViewBuilder.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "OpenChannelView+SubViewBuilder.swift"; sourceTree = ""; }; + FA08839B2698DC9512850391 /* SBUMemberListViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMemberListViewController.Deprecated.swift; sourceTree = ""; }; + FA5E060A224E457A70D2C17C /* GroupMutedMemberListViewConverter.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupMutedMemberListViewConverter.Header.swift; sourceTree = ""; }; + FAD037E71A163BD4A3A0BA79 /* SBUCreateOpenChannelModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUCreateOpenChannelModule.Header.swift; sourceTree = ""; }; + FB5A3230F6C3473FCC54FE72 /* SBUMessageTemplate.Container.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Container.swift; sourceTree = ""; }; FB93B3DEC8E153D6A8BFC160 /* CustomCreateOpenChannel.SwiftUI.View.Main.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomCreateOpenChannel.SwiftUI.View.Main.swift; sourceTree = ""; }; + FBB443922F23428075A25054 /* SBUMessageTemplate.Decoders.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUMessageTemplate.Decoders.swift; sourceTree = ""; }; FBC4A6592CF9264B9334EC0C /* CustomMessageThread.ViewConverter.Header.rightView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomMessageThread.ViewConverter.Header.rightView.swift; sourceTree = ""; }; - FCD53856699176A2A465111B /* SBUFormFieldView.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUFormFieldView.Deprecated.swift; sourceTree = ""; }; - FD3B3C58D3785437EE1411F1 /* SBUColorSet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUColorSet.swift; sourceTree = ""; }; - FD91A7FA49003653EAC40E13 /* OpenParticipantListViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenParticipantListViewConverter.swift; sourceTree = ""; }; - FD96D51055C0724028FBB802 /* InviteUserView+ViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "InviteUserView+ViewConverter.swift"; sourceTree = ""; }; - FDE68F5000CAD06B280FC70C /* OpenBannedUserListView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenBannedUserListView.swift; sourceTree = ""; }; - FDF95535882D104149DE19C4 /* SBUBaseSelectUserModule.Header.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserModule.Header.swift; sourceTree = ""; }; + FC3E876887601735308273D9 /* SBUVoiceMessageInputView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUVoiceMessageInputView.swift; sourceTree = ""; }; + FCB7E275124DF45ADB981B0E /* SBUTheme.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUTheme.swift; sourceTree = ""; }; + FD18A49461FC8A53036E3A08 /* SBUToastType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUToastType.swift; sourceTree = ""; }; + FD34FF666C940B94555A93F5 /* UIStackView.SBUIKit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIStackView.SBUIKit.swift; sourceTree = ""; }; + FD8219759D395864DBC89499 /* SBURegisterOperatorModule.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBURegisterOperatorModule.List.swift; sourceTree = ""; }; + FDA3D3D02D5E297D699CD2C2 /* SBUBaseSelectUserViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseSelectUserViewController.Deprecated.swift; sourceTree = ""; }; FE3455B16C9555F970F4D601 /* CustomGroupChannelSettings.ViewConverter.List.moderation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupChannelSettings.ViewConverter.List.moderation.swift; sourceTree = ""; }; FE35056CA598654CAD9BD7FF /* CustomGroupModerations.ViewConverter.List.entireView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CustomGroupModerations.ViewConverter.List.entireView.swift; sourceTree = ""; }; - FE58C6471BF7E86158214650 /* SBUBaseChannelSettingsViewController.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUBaseChannelSettingsViewController.Deprecated.swift; sourceTree = ""; }; - FE6750636605238BA0E244C8 /* GroupChannelViewConverter.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GroupChannelViewConverter.swift; sourceTree = ""; }; - FF616B484BF9E87795017EA1 /* SBUQuoteMessageInputViewParams.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUQuoteMessageInputViewParams.swift; sourceTree = ""; }; + FF107290F4EB7C3FAD727570 /* SBUOpenChannelBaseMessageCell+SwiftUI.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "SBUOpenChannelBaseMessageCell+SwiftUI.swift"; sourceTree = ""; }; + FF19DEF5C6B07A8E32A6919B /* SBUGroupChannelPushSettingsModule.Deprecated.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SBUGroupChannelPushSettingsModule.Deprecated.swift; sourceTree = ""; }; + FFA78758B8276DAA3B4E9BEE /* GroupOperatorListView+Item.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "GroupOperatorListView+Item.swift"; sourceTree = ""; }; + FFFBB3032630028580441A41 /* OpenChannelRegisterOperatorViewConverter.List.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChannelRegisterOperatorViewConverter.List.swift; sourceTree = ""; }; /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ @@ -2206,32 +2270,25 @@ path = ViewConverter; sourceTree = ""; }; - 01B62348032FAB2E1AC5E0E7 /* ChannelCell */ = { + 026452E92E8AB7038308C3DB /* NotificationSettings */ = { isa = PBXGroup; children = ( - DE2C77128576368219B73147 /* SBUBaseChannelCell.swift */, - EE2A55A25B370F6C8ED56E24 /* SBUGroupChannelCell.swift */, - CB4BEBA0FDEDCCE9A5804BB9 /* SBUOpenChannelCell.swift */, + FF19DEF5C6B07A8E32A6919B /* SBUGroupChannelPushSettingsModule.Deprecated.swift */, ); - path = ChannelCell; + path = NotificationSettings; sourceTree = ""; }; - 01F8391BCE93736ECA1D82AC /* Module */ = { + 027354120503B8D3C12E122A /* OpenChannel */ = { isa = PBXGroup; children = ( - 4DEF0B14DE38EB619FD6405B /* SBUModuleSet.swift */, - 80E3BBF58866133C23FF50E4 /* Channel */, - D859E8FC7B0A675E24E0D390 /* ChannelList */, - 47FAD00AAFE8623AFD97BD89 /* ChannelSettings */, - A049765FA220EB5BEC7401EF /* Common */, - 81B8DE36E827F506EFC715F8 /* MessageSearch */, - EA340001A6210A4483B2BF7E /* MessageThread */, - BF5F86BFE985AE40DAA3EFB2 /* Moderations */, - 304051113C2E40C5032D3D85 /* NotificationSettings */, - D607D3E218BDA7375DF73D24 /* SelectUser */, - EF4BA4306BDA1CB72D7F5E25 /* UserList */, + 67CA15DE5967D27E5ABC4233 /* OpenChannelView.swift */, + 947446DE112FAC2320D1EF22 /* OpenChannelView+Item.swift */, + A7D0E7D82632BC43A4434560 /* OpenChannelView+SubViewBuilder.swift */, + 418C7FD54C888F55739A45F5 /* OpenChannelView+ViewConverter.swift */, + C777B171EAF9592EA52F9707 /* OpenChannelViewProvider.swift */, + AE1445AC9B0B6A053DE08E1C /* ViewConverters */, ); - path = Module; + path = OpenChannel; sourceTree = ""; }; 027A352775B7380B368DC51B /* SwiftUI */ = { @@ -2242,39 +2299,34 @@ path = SwiftUI; sourceTree = ""; }; - 02A9E596573FDE7CB8B282E8 /* ViewConverters */ = { + 02D6CAFA1B7C951E40A2C975 /* ViewParams */ = { isa = PBXGroup; children = ( - E3242DE074C1AA33D5C85D4B /* CreateOpenChannelViewConverter.Header.swift */, - CEC51145218937994CD7E226 /* CreateOpenChannelViewConverter.swift */, - 9B6A113CC7CEC6C224ED5D07 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift */, + 409DBFC7D0F907CC4CC919AD /* SBUMessageFormViewParams.swift */, ); - path = ViewConverters; + path = ViewParams; sourceTree = ""; }; - 05432D8DAD7613CA6439B4E1 /* MessageView */ = { + 0384CE725B2C73E3E0C1678D /* ChannelList */ = { isa = PBXGroup; children = ( - 8403312D3345AA5154DF81D1 /* QuotedFileCommonContentView.swift */, - D0EAB282FB441D9B3F630D3C /* QuotedFileImageContentView.swift */, - 6BFEDEA0282EC80B5682BC6B /* SBUQuotedBaseMessageView.swift */, - 39177B76E752035056578234 /* SBUQuotedFileMessageView.swift */, - 86CD79484A29B4EA66EC4B0C /* SBUQuotedUserMessageView.swift */, - 1D0C5587D78DE4FF38CD361A /* SBUThreadInfoView.swift */, + AA6DD0EF41EBA11F612CAE67 /* SBUGroupChannelListModule.Deprecated.swift */, + 93C5F784B2DBFAB6E6C9F1B8 /* SBUOpenChannelListModule.Deprecated.swift */, ); - path = MessageView; + path = ChannelList; sourceTree = ""; }; - 05CF9587ACD9216080559FB2 /* InviteUser */ = { + 0427D1F31F23FD611A340269 /* ViewConverters */ = { isa = PBXGroup; children = ( - 16D3BFEEF9AF232331AE1BDC /* InviteUserView.swift */, - 94C077267D8FDD493CDAF330 /* InviteUserView+Item.swift */, - 3BCF8D7F6481CF9321250DF9 /* InviteUserView+SubViewBuilder.swift */, - FD96D51055C0724028FBB802 /* InviteUserView+ViewConverter.swift */, - 74D5488505700B0A641DF167 /* ViewConverters */, + B26D20DFC631D5EDC2CF8D54 /* OpenMutedParticipantListViewConverter.Header.swift */, + 5E7ECC0D58ECDC06EF0183F3 /* OpenMutedParticipantListViewConverter.List.swift */, + 2E24797172C62D7225E0F118 /* OpenMutedParticipantListViewConverter.swift */, + ACE0161330623767B0B22AEA /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift */, + F21197AC02DB3794FF1A73B9 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift */, + 9268BE22DBE8DBD50C37CB32 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift */, ); - path = InviteUser; + path = ViewConverters; sourceTree = ""; }; 05F98A8A0938B321388714B8 /* ViewConverter */ = { @@ -2288,45 +2340,41 @@ path = ViewConverter; sourceTree = ""; }; - 06BA19501C8B082AE6526FD4 /* ViewParams */ = { + 0664259FBD1A656D40A93936 /* View */ = { isa = PBXGroup; children = ( - 09E6606143A887F262F79FA9 /* SBUMessageFormViewParams.swift */, + D7C327FC68584CFA626021FF /* SBUChannelSettingsChannelInfoView.swift */, ); - path = ViewParams; + path = View; sourceTree = ""; }; - 09C770197FC73C6111FF9983 /* ViewConverters */ = { + 067FD04BDDE8A1BF361AF200 /* Cell */ = { isa = PBXGroup; children = ( - 55CB97C4415AE0168B1EAEE4 /* GroupMemberListViewConverter.Header.swift */, - E643BD503D1B0287D115F459 /* GroupMemberListViewConverter.List.swift */, - EAD9C78B13DA1261EFA4A175 /* GroupMemberListViewConverter.swift */, - 1E787BE5CA17742F73854520 /* SBUGroupUserListModule.Header+SwiftUI.swift */, - 0D67908CBFE6F4D1590D22A3 /* SBUGroupUserListModule.List+SwiftUI.swift */, - 887F4EC72B8FC7D81D7886DB /* SBUGroupUserListUserCell+SwiftUI.swift */, + 627DBB55B063137DA9273A8A /* SBUMessageSearchResultCell.swift */, ); - path = ViewConverters; + path = Cell; sourceTree = ""; }; - 0A2E65842DA5F60662B41275 /* ChannelSettings */ = { + 0717F782F27BCB508547FC16 /* ViewConverters */ = { isa = PBXGroup; children = ( - FE58C6471BF7E86158214650 /* SBUBaseChannelSettingsViewController.Deprecated.swift */, + 0FD1533E6A37B61095F3D3F8 /* MessageSearchViewConverter.Header.swift */, + D1C0385D2634A8150F5B7765 /* MessageSearchViewConverter.List.swift */, + 2998E5B0A2F8028DC20D9D04 /* MessageSearchViewConverter.swift */, + 602FB0E64CCDD3B8406812D1 /* SBUMessageSearchModule.Header+SwiftUI.swift */, + F5A9EC87E51CE11529D2B28C /* SBUMessageSearchModule.List+SwiftUI.swift */, ); - path = ChannelSettings; + path = ViewConverters; sourceTree = ""; }; - 0A82322859368BEFE15C56D9 /* OpenChannelRegisterOperator */ = { + 082EA3EECA5D715BCA2A03F3 /* Theme */ = { isa = PBXGroup; children = ( - 57E9486AE7A3DA69D14C2B1F /* OpenChannelRegisterOperatorView.swift */, - 868865ED19B43E30C0DCE6BF /* OpenChannelRegisterOperatorView+Item.swift */, - AE5AE7AE8AFB0332BF6B91B9 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift */, - 2B3BA29A37C81D499E354EB4 /* OpenChannelRegisterOperatorView+ViewConverter.swift */, - C71454E0D75032C572E83141 /* ViewConverters */, + 8FF453D51A63DD5EAC2A29B3 /* ColorSet.swift */, + 14A5CBF9A05A44B87429CDCC /* FontSet.swift */, ); - path = OpenChannelRegisterOperator; + path = Theme; sourceTree = ""; }; 0A8E7DA082500F5A841266A7 /* Input */ = { @@ -2362,18 +2410,17 @@ path = SwiftUI; sourceTree = ""; }; - 0C009F1683DDEEE24F25E166 /* Channel */ = { + 0E37B9749605FD3BD9136D57 /* ViewConverters */ = { isa = PBXGroup; children = ( - 51C56CFE8E82E6E482183B7D /* SBUBaseChannelViewController.Deprecated.swift */, - 1D0F53258EBF6406A01FBE22 /* SBUBaseChannelViewController.Unavailable.swift */, - F0C58F296D9B6516563598F5 /* SBUGroupChannelViewController.Deprecated.swift */, - 46FF82F5B4555A400669ADA2 /* SBUGroupChannelViewController.Unavailable.swift */, - EE2E49B4FC91D817366079ED /* SBUOpenChannelViewController.Deprecated.swift */, - 4B0C7AD67D264A3CACBF0A24 /* SBUOpenChannelViewController.Unavailable.swift */, - BBAF05FDD28ED6C97F7FE066 /* MessageCell */, + 52C77023C4D2F1DB0CBC34D0 /* OpenChannelListViewConverter.Header.swift */, + A761A9195C9F62DD9A739A19 /* OpenChannelListViewConverter.List.swift */, + 86B0D9E7E2F38DE9B72E811D /* OpenChannelListViewConverter.swift */, + 9F54E316B3315A516516C65E /* SBUOpenChannelCell+SwiftUI.swift */, + 8F8BD3B6A480001E40AE01F3 /* SBUOpenChannelListModule.Header+SwiftUI.swift */, + C6F654B64098E41716C2FE00 /* SBUOpenChannelListModule.List+SwiftUI.swift */, ); - path = Channel; + path = ViewConverters; sourceTree = ""; }; 0ECDE8B8E9031D5FDB5BA892 /* SwiftUI */ = { @@ -2446,44 +2493,48 @@ path = ViewConverter; sourceTree = ""; }; - 11521464DEE2F7AC0E6F747A /* CreateChannel */ = { + 0FA13A4661E69E9115D0596E /* NotificationSettings */ = { isa = PBXGroup; children = ( - F1906ACF63D4B5C27FB224F3 /* SBUCreateChannelViewModel.swift */, - 1C984E50160373E12FA0438E /* SBUCreateOpenChannelViewModel.swift */, + 2A29132CC8E88EB608B11887 /* SBUGroupChannelPushSettingsViewController.swift */, + D266795CB20D0BC9F32F6620 /* Cell */, ); - path = CreateChannel; + path = NotificationSettings; sourceTree = ""; }; - 1228F805FE97ECE563467D22 /* RegisterOperator */ = { + 115DD1E49CB4A60C09E572DF /* Common */ = { isa = PBXGroup; children = ( - B461281DDE306B84C3893B7F /* SBURegisterOperatorModule.Header.swift */, - 0358D88C77E677DC51C6F4F9 /* SBURegisterOperatorModule.List.swift */, - BD1D2FF674AE425302A71903 /* SBURegisterOperatorModule.swift */, + 43029E52C382D59F27DB2770 /* SBUCommonDelegate.swift */, ); - path = RegisterOperator; + path = Common; sourceTree = ""; }; - 1277D6AC1D429087F6E4A528 /* ViewConverters */ = { + 11E583AA76DC9F12CBD78C2B /* ViewConverters */ = { isa = PBXGroup; children = ( - 8AC9322A2E31BFE30E449B5F /* OpenChannelViewConverter.Header.swift */, - B02DAC06AC58179B3149D2C3 /* OpenChannelViewConverter.Input.swift */, - 9CEA691367E3A7EA0CC719D0 /* OpenChannelViewConverter.List.swift */, - 677AE6C278482C5D34FEE924 /* OpenChannelViewConverter.swift */, - 10245F542657CABD9F636A3D /* SBUOpenChannelBaseMessageCell+SwiftUI.swift */, - F92B219D2E3A203BB7E9F3EB /* SBUOpenChannelInputView+SwiftUI.swift */, - BF61B959A003633F9C9EB07D /* SBUOpenChannelModule.Header+SwiftUI.swift */, - 3D4529D5F3329C4BC3B98A17 /* SBUOpenChannelModule.Input+SwiftUI.swift */, - B23F126897E287420089CCD2 /* SBUOpenChannelModule.List+SwiftUI.swift */, - 997DCDD73BE218FE6620854B /* SBUOpenChannelTitleView+SwiftUI.swift */, - 6585ED152504C2FFC5DA1AB2 /* SBUOpenChannelViewController+SwiftUI.swift */, - 60C8EC1B23B48AE94DF6F3A7 /* SBUOpenScrollBottomView+SwiftUI.swift */, + B2381F491D07215E71A1C179 /* GroupChannelPushSettingsViewConverter.Header.swift */, + 0AA30971729AB912E9FC2BB9 /* GroupChannelPushSettingsViewConverter.List.swift */, + 3BD19FB097E2A1F6DAAE9E96 /* GroupChannelPushSettingsViewConverter.swift */, + 37116E5191BE696685FA5A75 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift */, + DAED2EACDE1CAAA7CC8688DE /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift */, ); path = ViewConverters; sourceTree = ""; }; + 125D8C7674FBD9A611DED5FF /* FileMessageContentView */ = { + isa = PBXGroup; + children = ( + 9479ECE36C683AB4CF1BE683 /* SBUBaseFileContentView.swift */, + 0A957CCD31F05C1FE9E652E2 /* SBUCommonContentView.swift */, + 1F414EE8A18D12F1A90F406E /* SBUImageContentView.swift */, + D9735294E73DAE6D3E1FDB33 /* SBUOpenChannelCommonContentView.swift */, + D2FFCD9112A92A33B800F41A /* SBUOpenChannelImageContentView.swift */, + F49E6F0696729061F88BAF0C /* SBUVoiceContentView.swift */, + ); + path = FileMessageContentView; + sourceTree = ""; + }; 127F0510669556AE71E9CF27 /* List */ = { isa = PBXGroup; children = ( @@ -2502,22 +2553,30 @@ path = CustomSampleManager; sourceTree = ""; }; - 136E50E3B3EACB38F9022250 /* OpenChannel */ = { + 135615028119E48474B428F8 /* OpenChannelSettings */ = { isa = PBXGroup; children = ( - 7D6849B7606ADDACDDF87569 /* SBUOpenChannelListModule.Header.swift */, - 6B76B6E8F8E888984DE91EAA /* SBUOpenChannelListModule.List.swift */, - 0DA777F44C7DE5F2768375B6 /* SBUOpenChannelListModule.swift */, + A88F464BAAD90AB84BB13317 /* OpenChannelSettingsView.swift */, + C5DDEFBCE4985FC09EB4B6D2 /* OpenChannelSettingsView+Item.swift */, + 0AB39B9F7C19B2CB08F1D83F /* OpenChannelSettingsView+SubViewBuilder.swift */, + BB8E79F86C80CC2DD59FCC04 /* OpenChannelSettingsView+ViewConverter.swift */, + 18C1C60E4B404A088689D1E8 /* OpenChannelSettingsViewProvider.swift */, + EDFF1AE15C256E0442521CFD /* ViewConverters */, ); - path = OpenChannel; + path = OpenChannelSettings; sourceTree = ""; }; - 13B0332D64DE00281D5D0CDA /* View */ = { + 144C41F1981091BBD0DB86D7 /* MessageThread */ = { isa = PBXGroup; children = ( - 7D1A9C9D267ADD34ABADC14A /* SBUCreateChannelTypeSelector.swift */, + 80277CCA8CD14E420F5CE34B /* MessageThreadView.swift */, + 8A9FEEEABEADA3B3140A5F0B /* MessageThreadView+Item.swift */, + 2BAFD80BA871EC59725EC7AC /* MessageThreadView+SubViewBuilder.swift */, + 21050C5DF391743F4A7D9825 /* MessageThreadView+ViewConverter.swift */, + 703C05B3B91F19E011CA92B7 /* MessageThreadViewProvider.swift */, + 78A50C0EE65F7C2B8CFAEE5A /* ViewConverters */, ); - path = View; + path = MessageThread; sourceTree = ""; }; 1494C3FA0EDFE5A8835F849A /* SwiftUI */ = { @@ -2528,6 +2587,94 @@ path = SwiftUI; sourceTree = ""; }; + 14BC1FAA825087220F1B5928 /* GroupOperatorList */ = { + isa = PBXGroup; + children = ( + 5CFCDF4354C150EB6E4EC7E9 /* GroupOperatorListView.swift */, + FFA78758B8276DAA3B4E9BEE /* GroupOperatorListView+Item.swift */, + CCF1C1BAB1FCE4DA3FADC95C /* GroupOperatorListView+SubViewBuilder.swift */, + 6A7C45E94E88F6254D996F23 /* GroupOperatorListView+ViewConverter.swift */, + 4A3FA47B606D666AD9E97938 /* GroupOperatorListViewProvider.swift */, + D6C5A955DC2742FB58996175 /* ViewConverters */, + ); + path = GroupOperatorList; + sourceTree = ""; + }; + 14E5F439516ECB3C089C811B /* swiftui */ = { + isa = PBXGroup; + children = ( + E2ADEA87D2CD1937FE761A55 /* SendbirdSwiftUI-Info.plist */, + F5ABD9526E2BC97012171C4A /* SendbirdUI+SwiftUI.swift */, + A9779DBC3ABC5BEFFBF2DC74 /* Common */, + E60710C816DBFE5CA297D37D /* Extension */, + 76CD9D5102D4F4437A17BD5B /* Internal */, + 95393EDEEFC1610D96766953 /* KeyFunctions */, + C1680B664A04153DD205501D /* Protocol */, + 082EA3EECA5D715BCA2A03F3 /* Theme */, + 27CC4ED6EFB148B643C47B37 /* Util */, + ); + path = swiftui; + sourceTree = ""; + }; + 15464239D1FEC5DEBFFFB817 /* ViewConverters */ = { + isa = PBXGroup; + children = ( + 4DF8E970CDDD209431757EE9 /* GroupChannelRegisterOperatorViewConverter.Header.swift */, + 411F9A231E8707D76F0B05FA /* GroupChannelRegisterOperatorViewConverter.List.swift */, + 644EEE0E3AB230AD9CC782FE /* GroupChannelRegisterOperatorViewConverter.swift */, + 3002316F9F925813729C3DE0 /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift */, + A88C3ED343AF03A46C782863 /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift */, + ); + path = ViewConverters; + sourceTree = ""; + }; + 154C2C20E9797E01603142CF /* View */ = { + isa = PBXGroup; + children = ( + 657F6F2027D3DE4F87DDBDA6 /* SBUBaseViewController.swift */, + 9A92CD9FA0255F503C2D351E /* SBUViewControllerSet.swift */, + 978E87D5925265AF43371E1B /* Channel */, + 3F4AC65878DC63DBA6CAF956 /* ChannelList */, + F42CC250A593FB030B0EFC79 /* ChannelSettings */, + CAFA27DC744775FA7727B38B /* Common */, + 3C2C14D38837866FBC082590 /* Life cycles */, + B01CACD5DF8F0CB5D28C5C9D /* MessageSearch */, + F67C53BBB445DA2F5501F5DB /* MessageThread */, + 916AB2A9BA3612FB51A82BD0 /* Moderations */, + 0FA13A4661E69E9115D0596E /* NotificationSettings */, + E43330EA426DD1B85555EF6F /* SelectUser */, + 8FF8630283EF0AB6256E5C57 /* UserList */, + 35A3B851E0BF1CA71F85EB56 /* VoiceNote */, + ); + path = View; + sourceTree = ""; + }; + 15A92824C795311E850F25F3 /* Protocol */ = { + isa = PBXGroup; + children = ( + 33FAB263E1745861F9AD0B26 /* CommonProtocols.swift */, + ); + path = Protocol; + sourceTree = ""; + }; + 15B37BD12AF037BDA28D5A33 /* ChannelSettings */ = { + isa = PBXGroup; + children = ( + 85DF9F68E38AE6BBA2DE35BE /* SBUGroupChannelSettingsModule.Deprecated.swift */, + AD331F75C4062F3566D75108 /* SBUOpenChannelSettingsModule.Deprecated.swift */, + ); + path = ChannelSettings; + sourceTree = ""; + }; + 161A42B1A88C581C50538C1C /* ActionSheet */ = { + isa = PBXGroup; + children = ( + 6A8FE68282C9D1E38107C371 /* SBUActionSheet.Item.swift */, + B5912802D62DB001F7D04659 /* SBUActionSheet.swift */, + ); + path = ActionSheet; + sourceTree = ""; + }; 16846B5E9F8BCDE4ADA15DD8 /* ViewConverter */ = { isa = PBXGroup; children = ( @@ -2568,6 +2715,24 @@ path = List; sourceTree = ""; }; + 190E50121242BD1451CA5858 /* ViewModel */ = { + isa = PBXGroup; + children = ( + 45DB087B50F9492F21F8C258 /* SBUViewModelDelegate.swift */, + 948D0930539618E949CE2D4C /* SBUViewModelSet.swift */, + DD394436761B7AB4D860DAC4 /* Channel */, + 8F1839CB3BAB86C1229C08BD /* ChannelList */, + 7DF35F273E07DAE1D557E556 /* ChannelSettings */, + 115DD1E49CB4A60C09E572DF /* Common */, + 644A0FCD1CC229A232C6BCD5 /* MessageSearch */, + FE4800EFEF9571AE5D9FE997 /* MessageThread */, + 8E05E0BE99114C53CE4B5E55 /* NotificationSettings */, + 4F50BE2F1FB881CDF8B27B53 /* SelectUser */, + EA810D7D207D79C140836E61 /* UserList */, + ); + path = ViewModel; + sourceTree = ""; + }; 197A8F8FEB79CAC85C65BFE6 /* SwiftUI */ = { isa = PBXGroup; children = ( @@ -2576,16 +2741,14 @@ path = SwiftUI; sourceTree = ""; }; - 19A25BB7CFE3710B8A2D998E /* ViewConverters */ = { + 1998BBD27C3AC7DC97F8017B /* GroupChannel */ = { isa = PBXGroup; children = ( - E672677E26CA7ADF545827E4 /* OpenModerationsViewConverter.Header.swift */, - CD163025FD5F2FDEBE9F839A /* OpenModerationsViewConverter.List.swift */, - 0AACD96B9376174CFA06D9E9 /* OpenModerationsViewConverter.swift */, - B882F1528ECBB76E2777E7FF /* SBUOpenModerationsModule.Header+SwiftUI.swift */, - 14693ACB733109628B1E5244 /* SBUOpenModerationsModule.List+SwiftUI.swift */, + F9D3B79BEAF2D1C7C3D484D0 /* SBUGroupChannelSettingsModule.Header.swift */, + 5FEC8CAB95357120546DFA62 /* SBUGroupChannelSettingsModule.List.swift */, + 9FD0291F032A293A68F16270 /* SBUGroupChannelSettingsModule.swift */, ); - path = ViewConverters; + path = GroupChannel; sourceTree = ""; }; 19E7E55D44E9DE7798275361 /* List */ = { @@ -2616,15 +2779,33 @@ path = Header; sourceTree = ""; }; - 1B09309885C4F0D28B2AA0A9 /* ChatSDK */ = { - isa = PBXGroup; - children = ( - F566B012103F8EEBE03AECA3 /* BaseMessage+SBUIKit.MessageTemplate.swift */, - C589684819C0917EE5FC82DE /* BaseMessage+SBUIKit.swift */, - 86D998504A47DE9BAAC543C1 /* MessageForm+SBUIKit.swift */, - 5CB7111297AFFD4F44521579 /* MultipleFilesMessage+SBUIKit.swift */, + 1AEFB90DEAD838E24EBFB5B4 /* MessageCell */ = { + isa = PBXGroup; + children = ( + A1EC0EAFDCFB570D5C83FAD1 /* SBUAdminMessageCell.swift */, + 246C6675D850EA56F58871FC /* SBUBaseMessageCell.Feedback.swift */, + 65443F1247D65F9688EBC933 /* SBUBaseMessageCell.swift */, + 85648A3B41D27C36B032B178 /* SBUContentBaseMessageCell.swift */, + 77694BFE0E0E11F21133E27D /* SBUFileMessageCell.swift */, + E7513D0A46E6B0D3B734E065 /* SBUMessageTemplateCell.MessageTemplateLayer.swift */, + A5845DA1C7AF582A65422E50 /* SBUMessageTemplateCell.swift */, + 559F4134A4DA519D83ECCEED /* SBUMessageTemplateCellLayout.swift */, + 90DCABD83770A8345AEC3919 /* SBUTypingIndicatorMessageCell.swift */, + 0D217125A2F37CCE38F58948 /* SBUUnknownMessageCell.swift */, + 927503842DC84814D6A78230 /* SBUUserMessageCell.swift */, + 349F88571DEFC620177B3DD9 /* CarouselView */, + 98CB950F6FCBE52F0FA80B16 /* CustomView */, + 83DD2714A97C13F047E625B3 /* Feedback */, + 125D8C7674FBD9A611DED5FF /* FileMessageContentView */, + 69E2E529708E491C19C7A463 /* MessageCellParams */, + BE5C85731B14C8EC4219ADEF /* MessageForm */, + C4456DA7C0BAB540901CD61F /* MultipleFilesMessage */, + 516D2ACE0F38FC7F166FBF64 /* NotificationChannel */, + 6FCD0BA2E90BBC37B90AE63E /* OpenChannel */, + 40F308661D4D155076B792BA /* Replies */, + 659F002C6BD4539C3C746F9E /* SuggestedReply */, ); - path = ChatSDK; + path = MessageCell; sourceTree = ""; }; 1B1008557781940B67BE286C /* Theme */ = { @@ -2648,162 +2829,120 @@ path = View; sourceTree = ""; }; - 1BF7C91CE977A51EC03623CB /* Header */ = { - isa = PBXGroup; - children = ( - 014618B2C4618338C8BF4AA6 /* CustomGroupChannelList.ViewConverter.Header.leftView.swift */, - 0906752602F6996C99B03220 /* CustomGroupChannelList.ViewConverter.Header.rightView.swift */, - 310897972F208CD1051FDB43 /* CustomGroupChannelList.ViewConverter.Header.titleView.swift */, - ); - path = Header; - sourceTree = ""; - }; - 1C7A063F8BE080086BAB4F8D /* Common */ = { - isa = PBXGroup; - children = ( - C17AFFFF84626265B8C333A6 /* SBUAnimation.swift */, - 166A655BEA90071D890FE83F /* SBUBarButtonItem.swift */, - 2DAAF41FC4C94DDFA9DB7794 /* SBUCollectionViewFlowLayout.swift */, - A2195C8048CCBEB921EA8954 /* SBUCommonItem.swift */, - 93C6EE37AC969FB9BBAF7B8E /* SBUCommonViewControllerSet.swift */, - 76987E34E766FE932E3CD06A /* SBUCoverImageView.swift */, - E8C797DF2665B67DB664FD80 /* SBUEmptyView.swift */, - E6AB5AF4E86499D0DFEE881B /* SBULayoutableButton.swift */, - 24FA1C9F270095F0BBE68991 /* SBULoading.swift */, - 48F076274C9FA374B6BD0708 /* SBUMarginView.swift */, - B882C20E663ED48B5ED6D4A7 /* SBUNavigationTitleView.swift */, - 54733AC26F3E88F21EC1750E /* SBUNotificationEmptyView.swift */, - 6A27F27248F7F70BEB6F6468 /* SBUNotificationNavigationTitleView.swift */, - 722A8173CBC9E33AB320794E /* SBUPaddingLabel.swift */, - E27A6013DA5EDC1AE77B2577 /* SBUSearchBar.swift */, - CC66BFE52B21FA2B30AE8E30 /* SBUStackView.swift */, - 2667B362F8DD00A36E0A5C00 /* SBUTemplateLabel.swift */, - 539CBC600DBA91F212F97009 /* SBUTypingIndicatorBubbleView.swift */, - 30D114A3FEC7A9B2EC46E9EE /* SBUUnderLineTextField.swift */, - 1F9ABD18D2E21C2819286743 /* ActionSheet */, - E94A6926CD0E900AC5BEECBA /* AlertView */, - 946BFD2742D5674FA8CEEF28 /* Menu */, - EF5A0ADBC771A193A0A17933 /* PhotoLibrary */, - 5B77CFAF53AAB86BE2EF3123 /* Toast */, - 64A994A926EE96A22347C8C3 /* User */, - F17B8DA0264AD4191385BC0B /* UserCell */, - ); - path = Common; - sourceTree = ""; - }; - 1CC533D44BA273811028A012 /* Syntax */ = { + 1BD6603624266543FC29960A /* OpenParticipantList */ = { isa = PBXGroup; children = ( - D9F55FA2519DCC099F23C4F0 /* SBUMessageTemplate.Action.swift */, - 2938701A69B6EA5F371B33A0 /* SBUMessageTemplate.Decoders.swift */, - E88D2D612D550B0EA07F62CD /* SBUMessageTemplate.ErrorMessages.swift */, - 69ADDDE3739EDAA8933BAF4C /* SBUMessageTemplate.ImageRatioType.swift */, - CBD4AF9A5A39CD6EB954C272 /* SBUMessageTemplate.Syntax.Aligns.swift */, - 5D90AA83494B7F9C031B6DD2 /* SBUMessageTemplate.Syntax.Identifier.swift */, - 5EDD7A1F27B543A5A2CC0C50 /* SBUMessageTemplate.Syntax.Item.swift */, - 889E65EF815ECC664FAAABE2 /* SBUMessageTemplate.Syntax.Sizes.swift */, - 2C6C9F8F3C88F07B39F5C385 /* SBUMessageTemplate.Syntax.Styles.swift */, - 67309FAB43DB15811EE0FAC5 /* SBUMessageTemplate.Syntax.Types.swift */, - FAC8E79C1FEAE3685E293243 /* SBUMessageTemplate.Syntax.Views.swift */, + 21ECDE889CE936449AE9DBFD /* OpenParticipantListView.swift */, + 883A64B2835D7B6C1D60452E /* OpenParticipantListView+Item.swift */, + 9E9F239FA17E47DB3C61C92B /* OpenParticipantListView+SubViewBuilder.swift */, + EAF986AD73EAB8ADBC900800 /* OpenParticipantListView+ViewConverter.swift */, + F9287770F82C83D551563531 /* OpenParticipantListViewProvider.swift */, + 82019BCC3DB69FA856E34E3E /* ViewConverters */, ); - path = Syntax; + path = OpenParticipantList; sourceTree = ""; }; - 1DB640D00845527888B91E08 /* Params */ = { + 1BF7C91CE977A51EC03623CB /* Header */ = { isa = PBXGroup; children = ( - D7863D6531C9EAA4341984F9 /* SBUFeedNotificationChannelViewParams.swift */, + 014618B2C4618338C8BF4AA6 /* CustomGroupChannelList.ViewConverter.Header.leftView.swift */, + 0906752602F6996C99B03220 /* CustomGroupChannelList.ViewConverter.Header.rightView.swift */, + 310897972F208CD1051FDB43 /* CustomGroupChannelList.ViewConverter.Header.titleView.swift */, ); - path = Params; + path = Header; sourceTree = ""; }; - 1DCD5EDAE4B648BFCCA97FA9 /* ScrollPostion */ = { + 1EDC0049FD083D38C5C9BFCC /* CreateChannel */ = { isa = PBXGroup; children = ( - E209E92758FCC408F49DB85A /* SBUScrollPostionConfiguration.swift */, + 74FC80676ADF1E7D30B25C8E /* SBUCreateChannelViewModel.swift */, + F1CA0FD406EF14F103F993F1 /* SBUCreateOpenChannelViewModel.swift */, ); - path = ScrollPostion; + path = CreateChannel; sourceTree = ""; }; - 1EA70CD99921CBFDA33B44F8 /* MessageThread */ = { + 1FA3FEAD48FB114CD4C6A800 /* Tester */ = { isa = PBXGroup; children = ( - 482F356F3F2D59068AF4D959 /* MessageThreadView.swift */, - 803F50E6244F87861D865AE5 /* MessageThreadView+Item.swift */, - 45F6A63D5390117FA882CE43 /* MessageThreadView+SubViewBuilder.swift */, - AB042AC39230E43C6B58A32E /* MessageThreadView+ViewConverter.swift */, - 823917E40696BCECAD41B1E4 /* ViewConverters */, + B58B9C60DFDDBFB10FF2737C /* MessageTemplateParserTest.swift */, + 40F3DF712CD31E46942D4A03 /* MessageTemplateTestViewController.swift */, ); - path = MessageThread; + path = Tester; sourceTree = ""; }; - 1F9ABD18D2E21C2819286743 /* ActionSheet */ = { + 1FF84F5DF9C75C48DCADE03D /* SwiftUI */ = { isa = PBXGroup; children = ( - B5BBE80E7FA22943BBC1F7C9 /* SBUActionSheet.Item.swift */, - 9A57EF97E3AB541373FFE03F /* SBUActionSheet.swift */, + 0F21F5473A0A04D28A7C0BD7 /* View */, ); - path = ActionSheet; + path = SwiftUI; sourceTree = ""; }; - 1FF84F5DF9C75C48DCADE03D /* SwiftUI */ = { + 20B70BDEB3053CC5CD50C1C8 /* OpenOperatorList */ = { isa = PBXGroup; children = ( - 0F21F5473A0A04D28A7C0BD7 /* View */, + 77A22D8FCAD422A90844DC4C /* OpenOperatorListView.swift */, + 116A35DCB844940ACC55AFA0 /* OpenOperatorListView+Item.swift */, + 0F32A69B02CCE4166DE09F9D /* OpenOperatorListView+SubViewBuilder.swift */, + 5C466E8AD49DF599AB343FA3 /* OpenOperatorListView+ViewConverter.swift */, + C7FE5E5ECE83C43C1C690C3C /* OpenOperatorListViewProvider.swift */, + 76A5810EC2F41277D182CF4F /* ViewConverters */, ); - path = SwiftUI; + path = OpenOperatorList; sourceTree = ""; }; - 210473DEF2745D86BBE20840 /* CreateChannel */ = { + 2146876D2BA2BCE129617778 /* Builder */ = { isa = PBXGroup; children = ( - C2CC930353E9AF952D5C1E72 /* SBUCreateChannelViewController.swift */, - 633ED5B1F7A4CAB56DE1F5BB /* SBUCreateOpenChannelViewController.swift */, - 13B0332D64DE00281D5D0CDA /* View */, + 0E76196CD8391DE9B46E02A8 /* CustomGroupChannelList.SubView.Builder.createChannel.swift */, + 2443ED212D4BF7E2A647104F /* CustomGroupChannelList.SubView.Builder.groupChannel.swift */, ); - path = CreateChannel; + path = Builder; sourceTree = ""; }; - 210944461ABABCDB6D80FD58 /* Feed */ = { + 21D2D4EB42BAC67F162DC3B9 /* ViewModel */ = { isa = PBXGroup; children = ( - 71A416E658CCC1E1163229BB /* SBUFeedNotificationChannelModule.CategoryFilter.swift */, - B34779DFF03F17E12EF14F8B /* SBUFeedNotificationChannelModule.Header.swift */, - 57EAE7739E3BD2E813597301 /* SBUFeedNotificationChannelModule.List.swift */, - 0E29F2ED3AC2E2D139EF1814 /* SBUFeedNotificationChannelModule.swift */, - 1DB640D00845527888B91E08 /* Params */, + 0CC15B4BBE65B13E5DCABD99 /* SBUMessageWebViewModel.swift */, + E1D1009E6F8479AF70D7433D /* SBUUserMessageTextViewModel.swift */, ); - path = Feed; + path = ViewModel; sourceTree = ""; }; - 2146876D2BA2BCE129617778 /* Builder */ = { + 230061178DC65F9C7044E74F /* Processor */ = { isa = PBXGroup; children = ( - 0E76196CD8391DE9B46E02A8 /* CustomGroupChannelList.SubView.Builder.createChannel.swift */, - 2443ED212D4BF7E2A647104F /* CustomGroupChannelList.SubView.Builder.groupChannel.swift */, + 862BAEECB41748FB96C9778F /* SBUMessageTemplate.Binder.swift */, + FB5A3230F6C3473FCC54FE72 /* SBUMessageTemplate.Container.swift */, + 0BCBB1C66BF4FFB629BFCDF1 /* SBUMessageTemplate.Coordinator.swift */, + AF2B1200556A2038713B5612 /* SBUMessageTemplate.Payload.swift */, + DDFD71AA835A87908EFEEAF0 /* SBUMessageTemplate.PayloadType.swift */, + 49D0BEED240F49CC5889EBF6 /* SBUMessageTemplate.TemplateList.swift */, ); - path = Builder; + path = Processor; sourceTree = ""; }; - 217328E9EFE6BC7722B65DA8 /* NewMessageInfo */ = { + 232A9BAD381710AE908B42E2 /* Notifications */ = { isa = PBXGroup; children = ( - 14EB76F7DCFDA115FA759567 /* SBUNewMessageInfo.swift */, - 681FCE6FE5FEC50EDECCB1BB /* SBUNewNotificationInfo.swift */, + 5C733994D9E30A3D2126469E /* SBUChatNotificationChannelModule.Deprecated.swift */, + 02844CACFD763E4FA4A29F09 /* SBUFeedNotificationChannelModule.Deprecated.swift */, ); - path = NewMessageInfo; + path = Notifications; sourceTree = ""; }; - 224D4FBFCC0B46FFFF365E94 /* Reaction */ = { + 23BD4F79BB64006FE21F0983 /* Channel */ = { isa = PBXGroup; children = ( - 35595546721F0FD423B8D80F /* SBUEmojiListViewController.swift */, - DBC22FB20B9809BA2B7123A3 /* SBUMessageReactionView.swift */, - 39A7437156C34F88C39E223D /* SBUParentMessageInfoReactionView.swift */, - 3846C23C9BCC45CA38A719FE /* SBUReactionCollectionViewCell.swift */, - DAD0A5FC842160B00A941361 /* SBUReactionsViewController.swift */, + A5D1AC09BD03089D2639594A /* SBUBaseChannelModule.Header.swift */, + DA2F3BFBE980CBE8A343DE43 /* SBUBaseChannelModule.Input.swift */, + 56EE3C45F358E3FF78C38FF5 /* SBUBaseChannelModule.List.swift */, + DB3E0B3AF5888509BFD2E7D5 /* SBUBaseChannelModule.swift */, + 36D4BFD1DA96C91D70EBCE8D /* GroupChannel */, + 3B95A8FEAD91892D8605EB92 /* NotificationChannel */, + 8EC4534EC2688DFEFA089DB4 /* OpenChannel */, ); - path = Reaction; + path = Channel; sourceTree = ""; }; 23C733B378E82B3FD08BFC5D /* Header */ = { @@ -2816,15 +2955,19 @@ path = Header; sourceTree = ""; }; - 23DDF9BCBA0027F87C42DF81 /* SelectUser */ = { + 24336E86E48061D6378D638F /* Renderer */ = { isa = PBXGroup; children = ( - 49B69FE2DEFAAFCBEBC9A1FC /* SBUBaseSelectUserViewController.swift */, - 16A073C3C063FECB43EE3886 /* SBUInviteUserViewController.swift */, - 45F57E43CFC459BC0A9D2E5C /* SBURegisterOperatorViewController.swift */, - 210473DEF2745D86BBE20840 /* CreateChannel */, + 96A238FF98AFC58A20C0202D /* SBUMessageTemplate.Renderer.Image.swift */, + 87FA2058A4863E17BF50A632 /* SBUMessageTemplate.Renderer.RendererType.swift */, + 3168D719E8C0DBF32138DBD9 /* SBUMessageTemplate.Renderer.swift */, + E593C2078945818E573F8A66 /* SBUMessageTemplate.Renderer.Views.swift */, + 7FD3DBE85BDBF98CBE0F758E /* SBUMessageTemplate.Renderer+Events.swift */, + 01FFB98B8DBF2797338BCE5A /* SBUMessageTemplate.Renderer+RenderItems.swift */, + 6643E3E65786C6485BDDA545 /* SBUMessageTemplate.Renderer+RenderStyles.swift */, + AA9023EA669DDE89840B17F0 /* SBUMessageTemplate.Renderer+Utils.swift */, ); - path = SelectUser; + path = Renderer; sourceTree = ""; }; 24552C4FBE71BE1D273BA22F /* SubView */ = { @@ -2835,34 +2978,6 @@ path = SubView; sourceTree = ""; }; - 26720279B76892AF626E3EF9 /* CreateGroupChannel */ = { - isa = PBXGroup; - children = ( - 9BA7D637DA3F016BB278AC0E /* CreateGroupChannelView.swift */, - 3CC0923742309FAE95E55C98 /* CreateGroupChannelView+Item.swift */, - 93368E728F88CC318E978EEA /* CreateGroupChannelView+SubViewBuilder.swift */, - CBDE8C489CF491949336BA54 /* CreateGroupChannelView+ViewConverter.swift */, - 289410C8E35A8ACF559F23DC /* ViewConverters */, - ); - path = CreateGroupChannel; - sourceTree = ""; - }; - 26A47D9B3830215D4BA69EF6 /* CustomView */ = { - isa = PBXGroup; - children = ( - B180E9D8480EE10DE31B9FE1 /* SBUExtendedMessagePayloadCustomViewFactory.swift */, - ); - path = CustomView; - sourceTree = ""; - }; - 26CE194F6189ADCC57BD8970 /* ChannelSettingItem */ = { - isa = PBXGroup; - children = ( - AA730E10316B59EC0D80449F /* SBUChannelSettingItem.swift */, - ); - path = ChannelSettingItem; - sourceTree = ""; - }; 270904B1EAB39EC04007CDF1 /* ViewConverter */ = { isa = PBXGroup; children = ( @@ -2872,29 +2987,19 @@ path = ViewConverter; sourceTree = ""; }; - 272BB6A29A107AC62CCAF485 /* GroupChannelRegisterOperator */ = { - isa = PBXGroup; - children = ( - B5A01B459C79535912AC488C /* GroupChannelRegisterOperatorView.swift */, - 735AEA7FB06A451F8F5B3226 /* GroupChannelRegisterOperatorView+Item.swift */, - 1613A81DAF0386D295401F59 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift */, - 3580081863865A49C61883FE /* GroupChannelRegisterOperatorView+ViewConverter.swift */, - 50089F087451946CA477BB9D /* ViewConverters */, - ); - path = GroupChannelRegisterOperator; - sourceTree = ""; - }; - 289410C8E35A8ACF559F23DC /* ViewConverters */ = { + 27CC4ED6EFB148B643C47B37 /* Util */ = { isa = PBXGroup; children = ( - 7941531B02292F6773399CBE /* CreateGroupChannelViewConverter.Header.swift */, - 41BBFE0A1ECE6E97671C152C /* CreateGroupChannelViewConverter.List.swift */, - 20F4251E92AEC8A7056D747A /* CreateGroupChannelViewConverter.swift */, - 1C1C132A58903724C8A1FA14 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift */, - E2E6F8EEF508DA948CDEA60A /* SBUCreateGroupChannelModule.List+SwiftUI.swift */, - 210AF12A14FCE17C47355C30 /* SBUCreateGroupChannelUserCell+SwiftUI.swift */, + A1AAE5D94748BD4BAC705164 /* DefaultViewConfigSet.swift */, + E787481C1D3394BE0D6A6CBB /* ProviderWrappedHostingView.swift */, + 2664B443F513C3E12BD8C350 /* SBViewConverterSet.swift */, + 377597543169F94AFF543475 /* StateImpactManager.swift */, + 8C3638DCCB2EA6D0B1E9451A /* SwiftUIViewController.swift */, + 584CEE89C822E1D1BD59E44F /* View + ViewModifier.swift */, + CFC414657A88A22B041B0248 /* ViewConverter.swift */, + B166932E45875505EE1E64DB /* WrapperUIViews.swift */, ); - path = ViewConverters; + path = Util; sourceTree = ""; }; 28DCE194BCE0FC8683999308 /* Header */ = { @@ -2907,6 +3012,16 @@ path = Header; sourceTree = ""; }; + 28DD317DD19073641AD30F34 /* OpenChannel */ = { + isa = PBXGroup; + children = ( + 6E75FECD8466345F80889285 /* SBUOpenChannelListModule.Header.swift */, + 56DB67FD35B6DC6ABDA4E639 /* SBUOpenChannelListModule.List.swift */, + 55A777BF3329A828082C419E /* SBUOpenChannelListModule.swift */, + ); + path = OpenChannel; + sourceTree = ""; + }; 28F6063407DB71D99C1FFE81 /* NotificationService */ = { isa = PBXGroup; children = ( @@ -2926,16 +3041,25 @@ path = ViewConverter; sourceTree = ""; }; - 2BABC3762D6B1F782AA65EED /* GroupModerations */ = { + 2A38107FF3B7D943D2ED3160 /* MemberList */ = { isa = PBXGroup; children = ( - A6912CC46BA4AFE74AABDB6E /* GroupModerationsView.swift */, - CD8F9ED1B50DBD995EEF594B /* GroupModerationsView+Item.swift */, - F35DAFB453749AFE67CD58EE /* GroupModerationsView+SubViewBuilder.swift */, - 486F991ADBCD134649F89781 /* GroupModerationsView+ViewConverter.swift */, - 3CD32B700E6BEF962C93A7B8 /* ViewConverters */, + FA08839B2698DC9512850391 /* SBUMemberListViewController.Deprecated.swift */, ); - path = GroupModerations; + path = MemberList; + sourceTree = ""; + }; + 2C00DA99B035730D0E05A29C /* CreateChannel */ = { + isa = PBXGroup; + children = ( + A265FA0F4182C5F6FB327DC1 /* SBUCreateChannelModule.Header.swift */, + 37343538D25A799C84E3BAE4 /* SBUCreateChannelModule.List.swift */, + 58158C5B57BBB1219A1A7907 /* SBUCreateChannelModule.swift */, + FAD037E71A163BD4A3A0BA79 /* SBUCreateOpenChannelModule.Header.swift */, + C1DE532D5BE137069E46610F /* SBUCreateOpenChannelModule.ProfileInput.swift */, + 510A0B30736E46E0278FC9A9 /* SBUCreateOpenChannelModule.swift */, + ); + path = CreateChannel; sourceTree = ""; }; 2CE97AD41B72794CC41AE61A /* List */ = { @@ -2950,14 +3074,17 @@ path = List; sourceTree = ""; }; - 2CF9F5283FE2A1D0DCAB7BEA /* MultipleFilesMessage */ = { + 2D2F6EF9D8D2EBB05BF3E580 /* GroupChannel */ = { isa = PBXGroup; children = ( - 229772D9190CF57D0E32B7D2 /* SBUMultipleFilesMessageCell.swift */, - C70D83A51D1811A88B0C140E /* SBUMultipleFilesMessageCollectionView.swift */, - 37C11167BE05D634FB689838 /* SBUMultipleFilesMessageCollectionViewCell.swift */, + CD3F95DAB17E94241A3A1355 /* GroupChannelProvider.swift */, + CC43AC31B6D1017FAD879CC6 /* GroupChannelView.swift */, + 93D381BEB63BA319C071D9DB /* GroupChannelView+Item.swift */, + 525FAF5D7C1814A0634AA10A /* GroupChannelView+SubViewBuilder.swift */, + 2F02C24F1081B38C6BBB9B3A /* GroupChannelView+ViewConverter.swift */, + FFEE44BE0FBAF54BD9260056 /* ViewConverters */, ); - path = MultipleFilesMessage; + path = GroupChannel; sourceTree = ""; }; 2D469B166AF4BC7FE047532C /* ViewConverter */ = { @@ -2969,42 +3096,14 @@ path = ViewConverter; sourceTree = ""; }; - 2DA1C21D72FF7C354308F85F /* VoiceMessage */ = { - isa = PBXGroup; - children = ( - 33A19DC31A19B9871C014844 /* SBUVoiceMessageConfiguration.swift */, - ); - path = VoiceMessage; - sourceTree = ""; - }; - 2DB244FB1C4C4D8C21A97AF9 /* SuggestedReply */ = { - isa = PBXGroup; - children = ( - 90C49DC8F459C3F7477CFBB8 /* ViewParams */, - E52586E736AD50CE829E9C0F /* Views */, - ); - path = SuggestedReply; - sourceTree = ""; - }; - 2EB514F5E16FF9E678AFB9C9 /* ViewConverters */ = { - isa = PBXGroup; - children = ( - 78E601DC9E72E49D4C69FCA1 /* OpenMutedParticipantListViewConverter.Header.swift */, - 1243D603EB01314B012C1D6E /* OpenMutedParticipantListViewConverter.List.swift */, - 1E4836735A03C7E6A5A5E1C0 /* OpenMutedParticipantListViewConverter.swift */, - 4CC6408E970D9582343C2F67 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift */, - 66DCC726041A9BF5D118CCE1 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift */, - 4891397AAB5DCBD36AAE7D51 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift */, - ); - path = ViewConverters; - sourceTree = ""; - }; - 2F0FC6252CF56EA4CA4E090C /* Protocol */ = { + 2F558A2F3C8985DE49006B1C /* PhotoLibrary */ = { isa = PBXGroup; children = ( - BD039AD94BFA1191FFFA3149 /* CommonProtocols.swift */, + 6E971C1577893A6B0FE234FD /* SBUPhotoAccess.swift */, + 54A86D1EE72BB0B915C95571 /* SBUPhotoCollectionViewCell.swift */, + A936C2B0F4BEFCCE17689484 /* SBUSelectablePhotoViewController.swift */, ); - path = Protocol; + path = PhotoLibrary; sourceTree = ""; }; 2F981247974691A8E78F97CC /* OpenMutedParticipantList */ = { @@ -3028,37 +3127,16 @@ path = OpenOperatorList; sourceTree = ""; }; - 304051113C2E40C5032D3D85 /* NotificationSettings */ = { - isa = PBXGroup; - children = ( - EC000D6306DDB9315E2125AC /* SBUGroupChannelPushSettingsModule.Header.swift */, - 433031D3C682345C94D28FDF /* SBUGroupChannelPushSettingsModule.List.swift */, - 53CDCB30A1F06A5DE1531A88 /* SBUGroupChannelPushSettingsModule.swift */, - ); - path = NotificationSettings; - sourceTree = ""; - }; - 30BC850E86491E7998ADAA03 /* ViewConverters */ = { - isa = PBXGroup; - children = ( - F3B37A003211506172A34CE4 /* GroupChannelListViewConverter.Header.swift */, - F37A3C0CAC8D9964CABBB7D5 /* GroupChannelListViewConverter.List.swift */, - 15D0C93348560E6639D9887F /* GroupChannelListViewConverter.swift */, - 0FA34F6AA2F8B23B93236BF1 /* SBUGroupChannelCell+SwiftUI.swift */, - 01014154A6F2DDA514E9AEE6 /* SBUGroupChannelListModule.Header+SwiftUI.swift */, - 81C92F68E1188BB0A7CB863C /* SBUGroupChannelListModule.List+SwiftUI.swift */, - ); - path = ViewConverters; - sourceTree = ""; - }; - 3262C9B3836517134F359A3E /* Protocol */ = { + 320345099B24AD59CC985496 /* Feed */ = { isa = PBXGroup; children = ( - BA4A079F4D61BE349D534EDE /* HierarchyScannable.swift */, - 3B10E73347B487AE2FBA2806 /* MethodOverridable.swift */, - C881A0739A99CFC25E5779FE /* ViewItemInitialize.swift */, + 5D2D5DF994BB70E9CCF42022 /* SBUFeedNotificationChannelModule.CategoryFilter.swift */, + 7592610FC6E821A878F88582 /* SBUFeedNotificationChannelModule.Header.swift */, + 35900F9772C3BD6331D81176 /* SBUFeedNotificationChannelModule.List.swift */, + A8B2153FEAAF7C92B3DBE27F /* SBUFeedNotificationChannelModule.swift */, + BAB718A27BAEB0EDAEA3C1F5 /* Params */, ); - path = Protocol; + path = Feed; sourceTree = ""; }; 327B05B34A37F564B9EAAD91 /* Header */ = { @@ -3080,6 +3158,14 @@ path = View; sourceTree = ""; }; + 3407B19E1179AC461AF350FC /* MessageSearch */ = { + isa = PBXGroup; + children = ( + AB4D0C9E36B253F255269B77 /* SBUMessageSearchViewController.Deprecated.swift */, + ); + path = MessageSearch; + sourceTree = ""; + }; 34613B8387BE5E6AC19A2F67 /* OpenBannedUserList */ = { isa = PBXGroup; children = ( @@ -3090,190 +3176,173 @@ path = OpenBannedUserList; sourceTree = ""; }; - 34B6FDC78C332F783E947516 /* ViewModel */ = { + 349F88571DEFC620177B3DD9 /* CarouselView */ = { isa = PBXGroup; children = ( - A901B98DBD349F8A5CBDB977 /* SBUViewModelDelegate.swift */, - 666C50E90307271C07649F2A /* SBUViewModelSet.swift */, - 49EFBFA1A41AD384C6BE2382 /* Channel */, - 7C1BA31876EA32F00CC45579 /* ChannelList */, - 88FD31BD05C911CA3401071A /* ChannelSettings */, - 6BB7F2F4A53919E8A17629B7 /* Common */, - FCC560EA042B8A46963B2A9F /* MessageSearch */, - 4F1C94EA7A89AD3936A4ADED /* MessageThread */, - 6D1EC3EC0C4846B652F8FB9E /* NotificationSettings */, - 6BE694860AC1F73A360AA868 /* SelectUser */, - FAF7DDD4CDA0585A359B632E /* UserList */, + 661B774DC02837911A7CDA4C /* SBUBaseCarouselView.swift */, ); - path = ViewModel; + path = CarouselView; sourceTree = ""; }; - 360CDE51371E635410A3C145 /* SwiftUI */ = { + 3589A259FC19999B30A989CF /* Mention */ = { isa = PBXGroup; children = ( - 177D4D43A66FA906EEE8F2AA /* View */, + 6869E075C9311C1F762F78B6 /* SBUMentionConfiguration.swift */, + 581E25EA40DF49EBAA0142FE /* SBUUserMentionConfiguration.swift */, ); - path = SwiftUI; + path = Mention; sourceTree = ""; }; - 366894BFF080E8F071C429E7 /* ViewConverters */ = { + 35A3B851E0BF1CA71F85EB56 /* VoiceNote */ = { isa = PBXGroup; children = ( - 2A07D10F3965FA8EFDD720D6 /* MessageSearchViewConverter.Header.swift */, - A14365C43B23A4185F8DDCA5 /* MessageSearchViewConverter.List.swift */, - E1C31CF4BCC3BBFC1D19D9A3 /* MessageSearchViewConverter.swift */, - B3B7DF2B3CBE003069677711 /* SBUMessageSearchModule.Header+SwiftUI.swift */, - 693AAFF0FF413BA5086E1B0C /* SBUMessageSearchModule.List+SwiftUI.swift */, + FC3E876887601735308273D9 /* SBUVoiceMessageInputView.swift */, ); - path = ViewConverters; + path = VoiceNote; sourceTree = ""; }; - 369D640A6B2265FDA9C95CC6 /* SwiftUI */ = { + 360CDE51371E635410A3C145 /* SwiftUI */ = { isa = PBXGroup; children = ( - 7E0D94CC6ACDD295DD3EF2C8 /* View */, + 177D4D43A66FA906EEE8F2AA /* View */, ); path = SwiftUI; sourceTree = ""; }; - 37726C180237B740AAF8B2EA /* Products */ = { + 369D640A6B2265FDA9C95CC6 /* SwiftUI */ = { isa = PBXGroup; children = ( - 47B6987458B0278D08119327 /* NotificationService.appex */, - AC38B314105F8FD6ECB154F7 /* QuickStartSwiftUI.app */, + 7E0D94CC6ACDD295DD3EF2C8 /* View */, ); - name = Products; + path = SwiftUI; sourceTree = ""; }; - 3787587C509E7B3ABA7A88B6 /* SwiftUI */ = { + 36D4BFD1DA96C91D70EBCE8D /* GroupChannel */ = { isa = PBXGroup; children = ( - C5D760C05858D57E567F8E7F /* View */, + EA746A3AC8FF541DF89D4606 /* SBUGroupChannelModule.Header.swift */, + CB98E8EF9F62A00D52D15264 /* SBUGroupChannelModule.Input.swift */, + C9DE89D8E1BB400650B44CF8 /* SBUGroupChannelModule.List.swift */, + D91401F0CEDB5A733BE00C20 /* SBUGroupChannelModule.swift */, ); - path = SwiftUI; + path = GroupChannel; sourceTree = ""; }; - 382704CB790510BCF55CDF3B /* OpenMutedParticipantList */ = { + 370EDAA6CB561037EA9C8675 /* SelectUser */ = { isa = PBXGroup; children = ( - F69D522AF28DCC02E3639775 /* OpenMutedParticipantListView.swift */, - F2B377E7421E1FDDFB61C7DA /* OpenMutedParticipantListView+Item.swift */, - 2DA6787A21BBB0988131D241 /* OpenMutedParticipantListView+SubViewBuilder.swift */, - 0ADAA8130275C2A217DA88C8 /* OpenMutedParticipantListView+ViewConverter.swift */, - 2EB514F5E16FF9E678AFB9C9 /* ViewConverters */, + 7C7E57B3E69531C17273C791 /* SBUCreateChannelModule.Deprecated.swift */, + 40F43C0CB687B4B7C5E4B3C6 /* SBUCreateOpenChannelModule.Deprecated.swift */, + 8E6740EC9EC809010A5628C7 /* SBUInviteUserModule.Deprecated.swift */, + D95DA4F7F43B4408328A06B2 /* SBURegisterOperatorModule.Deprecated.swift */, ); - path = OpenMutedParticipantList; + path = SelectUser; sourceTree = ""; }; - 38EE8575E4C8F0D1EA4BE500 /* Header */ = { + 373C5169F17F06D91EC69D32 /* ScrollBottomView */ = { isa = PBXGroup; children = ( - 8E194EB59871973C28A282B5 /* CustomOpenOperatorList.ViewConverter.Header.leftView.swift */, - 0D6086A2472531DE282E4A98 /* CustomOpenOperatorList.ViewConverter.Header.rightView.swift */, - 0F248FC8980FA08DAAF78C58 /* CustomOpenOperatorList.ViewConverter.Header.titleView.swift */, + B8D4F66B16058506BB43940F /* SBUScrollBottomView.swift */, ); - path = Header; + path = ScrollBottomView; sourceTree = ""; }; - 390039F1F40E3C9A3BB3BA92 /* MessageSearch */ = { + 37726C180237B740AAF8B2EA /* Products */ = { isa = PBXGroup; children = ( - C32AC3ABF480C0D62322AE3B /* MessageSearchView.swift */, - 735C35C7BF5726DE097A6252 /* MessageSearchView+Item.swift */, - 074F5995F2755F87CAA18440 /* MessageSearchView+SubViewBuilder.swift */, - 29C37028F3734AF788C0631C /* MessageSearchView+ViewConverter.swift */, - 366894BFF080E8F071C429E7 /* ViewConverters */, + 47B6987458B0278D08119327 /* NotificationService.appex */, + AC38B314105F8FD6ECB154F7 /* QuickStartSwiftUI.app */, ); - path = MessageSearch; + name = Products; sourceTree = ""; }; - 39063555F313CC6989308367 /* Processor */ = { + 3787587C509E7B3ABA7A88B6 /* SwiftUI */ = { isa = PBXGroup; children = ( - 563DF68B8CFC74728183C069 /* SBUMessageTemplate.Binder.swift */, - 130BDF243558344563BDD04F /* SBUMessageTemplate.Container.swift */, - 01554179DBF097DA7646B2AE /* SBUMessageTemplate.Coordinator.swift */, - 26E081F853537DD71E0BC25F /* SBUMessageTemplate.Payload.swift */, - 54C28728C9C8AC31A2BFBAD1 /* SBUMessageTemplate.PayloadType.swift */, - 2CC3E6F72DBC8FEE5B5FF69A /* SBUMessageTemplate.TemplateList.swift */, + C5D760C05858D57E567F8E7F /* View */, ); - path = Processor; + path = SwiftUI; sourceTree = ""; }; - 3B4804BD76F54211D6F6BCF9 /* List */ = { + 37F0F836809AA71D47801345 /* Toast */ = { isa = PBXGroup; children = ( - 7FB951B495F7482D3DFCF6FF /* CustomOpenBannedUserList.ViewConverter.List.entireView.swift */, - 07696C2C76138E6C1277A6A4 /* CustomOpenBannedUserList.ViewConverter.List.moreButton.swift */, - 1F40D34A8DAA0338D60BCC95 /* CustomOpenBannedUserList.ViewConverter.List.profileImage.swift */, - 59199C2D5B1AAF71E4BD38D0 /* CustomOpenBannedUserList.ViewConverter.List.rowView.swift */, - 5CC7C6EE71D9C0203FB5FB1A /* CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift */, + FD18A49461FC8A53036E3A08 /* SBUToastType.swift */, + 68559B08315B254984DBA950 /* SBUToastView.Internal.swift */, + DD82DA89A3CA5C66A6996786 /* SBUToastView.Item.swift */, + 198F31B87E693C7FA29E1A38 /* SBUToastView.swift */, ); - path = List; + path = Toast; sourceTree = ""; }; - 3B97E013AD6022EBE0BA3D51 /* MessageSearch */ = { + 38EE8575E4C8F0D1EA4BE500 /* Header */ = { isa = PBXGroup; children = ( - DE4692268960D6FB3AD51F3A /* SBUMessageSearchViewController.Deprecated.swift */, + 8E194EB59871973C28A282B5 /* CustomOpenOperatorList.ViewConverter.Header.leftView.swift */, + 0D6086A2472531DE282E4A98 /* CustomOpenOperatorList.ViewConverter.Header.rightView.swift */, + 0F248FC8980FA08DAAF78C58 /* CustomOpenOperatorList.ViewConverter.Header.titleView.swift */, ); - path = MessageSearch; + path = Header; sourceTree = ""; }; - 3BAED34AF2354C77A3167F4E /* MessageCellParams */ = { + 3A533ABC2F1C33DAF33FD773 /* SelectUser */ = { isa = PBXGroup; children = ( - 224DFC32A8DFF7FCAE9B3585 /* SBUAdminMessageCellParams.swift */, - CB0B81E6414A56CEC58EB58E /* SBUBaseMessageCellParams.swift */, - 8220E4F1F2BE2C124ED8B73A /* SBUFeedNotificationCellParams.swift */, - 7AD2BD448D02C9A9B551AA86 /* SBUFileMessageCellParams.swift */, - 4E542BCE47135E2CF12B69A8 /* SBUMessageTemplateCellParams.swift */, - 63888E8140CC9FF7B2967F6E /* SBUMultipleFilesMessageCellParams.swift */, - A2B05FBDB7E619A9A48FA28F /* SBUTypingMessageCellParams.swift */, - 3D5EA770115CE527CEF39044 /* SBUUnknownMessageCellParams.swift */, - B05DC3A2E750EC0A12CC4393 /* SBUUserMessageCellParams.swift */, + 6E3EB599E75E9A534192C97C /* SBUBaseSelectUserModule.Header.swift */, + 6B9F8515A20FA64F26C16D46 /* SBUBaseSelectUserModule.List.swift */, + 0B333F8593FEB4991E9648B1 /* SBUBaseSelectUserModule.swift */, + 2C00DA99B035730D0E05A29C /* CreateChannel */, + F8F32A05ADBC9FFEBB3268C9 /* InviteUser */, + F0649607576F863190C48D57 /* RegisterOperator */, ); - path = MessageCellParams; + path = SelectUser; sourceTree = ""; }; - 3C275611E82FC0C0A1A9BC2D /* Internal */ = { + 3B4804BD76F54211D6F6BCF9 /* List */ = { isa = PBXGroup; children = ( - 3262C9B3836517134F359A3E /* Protocol */, - 93EDA3B5F459BDA802AE5611 /* Util */, + 7FB951B495F7482D3DFCF6FF /* CustomOpenBannedUserList.ViewConverter.List.entireView.swift */, + 07696C2C76138E6C1277A6A4 /* CustomOpenBannedUserList.ViewConverter.List.moreButton.swift */, + 1F40D34A8DAA0338D60BCC95 /* CustomOpenBannedUserList.ViewConverter.List.profileImage.swift */, + 59199C2D5B1AAF71E4BD38D0 /* CustomOpenBannedUserList.ViewConverter.List.rowView.swift */, + 5CC7C6EE71D9C0203FB5FB1A /* CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift */, ); - path = Internal; + path = List; sourceTree = ""; }; - 3C39C8F69C0F6199DA58AACD /* Header */ = { + 3B95A8FEAD91892D8605EB92 /* NotificationChannel */ = { isa = PBXGroup; children = ( - 05FF389F9A723B77312A0D51 /* SBUChannelInfoHeaderView.swift */, - F7BC78603E390AB17CF9BE14 /* SBUChannelTitleView.swift */, + 8061A218333E238C622D0024 /* Chat */, + 320345099B24AD59CC985496 /* Feed */, ); - path = Header; + path = NotificationChannel; sourceTree = ""; }; - 3CB84247974B638019E2C2B7 /* Header */ = { + 3C2C14D38837866FBC082590 /* Life cycles */ = { isa = PBXGroup; children = ( - 22F1260D9E0F6882210913EA /* CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift */, - D123A133B83CA3E4C6A55CB3 /* CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift */, - AD052ED37E7CB964936B4AF8 /* CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift */, + DC2A8DE6A8BFEB20D40A60BB /* SBUCollectionViewCell.swift */, + 7E9DA3E806D49F987C40355A /* SBULabel.swift */, + 1E46BB57B23AA2CB9528366B /* SBUMessageCellProtocol.swift */, + 891A4F16527B1283ADACE452 /* SBUQuotedMessageViewProtocol.swift */, + E4FB9CBC6163B1B65BACBE4F /* SBUQuoteMessageInputViewProtocol.swift */, + CF02A0C341CEE4D97DF115CD /* SBUTableViewCell.swift */, + 9EA130B566F3BFCA65E9A262 /* SBUTextView.swift */, + 62AF0E697857ED2994B84E0C /* SBUView.swift */, + C13060009BC2B7A91C44C6AA /* SBUViewLifeCycle.swift */, ); - path = Header; + path = "Life cycles"; sourceTree = ""; }; - 3CD32B700E6BEF962C93A7B8 /* ViewConverters */ = { + 3CB84247974B638019E2C2B7 /* Header */ = { isa = PBXGroup; children = ( - B5697F9AAD564890A973256A /* GroupModerationsViewConverter.Header.swift */, - 534BB97DAD333885A76085C0 /* GroupModerationsViewConverter.List.swift */, - 472483201FA056ED9A255321 /* GroupModerationsViewConverter.swift */, - F7307101AAA00FA1558AF980 /* SBUGroupModerationsModule.Header+SwiftUI.swift */, - 345A88D14A3A5E57A00414FA /* SBUGroupModerationsModule.List+SwiftUI.swift */, + 22F1260D9E0F6882210913EA /* CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift */, + D123A133B83CA3E4C6A55CB3 /* CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift */, + AD052ED37E7CB964936B4AF8 /* CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift */, ); - path = ViewConverters; + path = Header; sourceTree = ""; }; 3D39D12132D2B105F3EDEE9B /* ParentInfo */ = { @@ -3294,6 +3363,20 @@ path = ParentInfo; sourceTree = ""; }; + 3D464670C858CEB6C67BA230 /* Channel */ = { + isa = PBXGroup; + children = ( + 35ACD3293ECBD4E4344CB186 /* SBUBaseChannelViewController.Deprecated.swift */, + B51E1CE18BE4F3FDC6244D83 /* SBUBaseChannelViewController.Unavailable.swift */, + 19F7CEEE95BBF13CB214CF41 /* SBUGroupChannelViewController.Deprecated.swift */, + 00E512AA6538A2C054A5F952 /* SBUGroupChannelViewController.Unavailable.swift */, + A7B12B08BDE49DDA8CEF1081 /* SBUOpenChannelViewController.Deprecated.swift */, + 51345B6EB0708B353BE6D39D /* SBUOpenChannelViewController.Unavailable.swift */, + C478BBF8363AA46333AA672F /* MessageCell */, + ); + path = Channel; + sourceTree = ""; + }; 3DF38A08F7BA12B9BA621AC7 /* GroupMutedMemberList */ = { isa = PBXGroup; children = ( @@ -3304,254 +3387,232 @@ path = GroupMutedMemberList; sourceTree = ""; }; - 3ED2A22377280FF244056B2D /* CreateChannel */ = { + 3E628D626329D903CA7D429A /* Reaction */ = { isa = PBXGroup; children = ( - 65DF771A802E179051B74F2F /* SBUCreateChannelModule.Header.swift */, - D0FD98E815C023134E9123D4 /* SBUCreateChannelModule.List.swift */, - 06A44B20FC2EFB44267D2F6F /* SBUCreateChannelModule.swift */, - 538BF9253A4990D0C05713F5 /* SBUCreateOpenChannelModule.Header.swift */, - 15E7A0A982529296BD896B07 /* SBUCreateOpenChannelModule.ProfileInput.swift */, - B16C1FB87FE416A9AACF8977 /* SBUCreateOpenChannelModule.swift */, + 44C879D1FFF9A02FD6EC7826 /* SBUEmojiListViewController.swift */, + 8B5C96EC8862AA9CA0719BE8 /* SBUMessageReactionView.swift */, + 4F9DB1C8A4D25102F05E3EF6 /* SBUParentMessageInfoReactionView.swift */, + 717BB61F0D034A789B0F3470 /* SBUReactionCollectionViewCell.swift */, + 3D65D7A80A375918D8B0EB9F /* SBUReactionsViewController.swift */, ); - path = CreateChannel; + path = Reaction; sourceTree = ""; }; - 3F5ED75AB7DEED7CC5410B37 /* Module */ = { + 3E81C51976553C11412FD61A /* Enums */ = { isa = PBXGroup; children = ( - E700A49675E9D9B07C018C41 /* SBUModuleSet.Deprecated.swift */, - A9D25F0225301983F9D56474 /* Channel */, - ECC68D0772FE38DA95177ACE /* ChannelList */, - E37B889E5DBCBC920BC56521 /* ChannelSettings */, - 90523FBD74F1C43AD6D3465F /* MessageSearch */, - 6B52B6FCCBF72533DE363063 /* MessageThread */, - 83A207899B0E5651C83134F7 /* Moderations */, - 9B6755A81901984FED695D31 /* NotificationSettings */, - 4E38C0E0730E5B9412A903DC /* SelectUser */, - 401F620639A5A13452827920 /* UserList */, + 244EE344C8E75A091EAECD86 /* SBUEnums.swift */, + 66D12454623DEC0547534C5F /* SBUIconSetType.swift */, + 06CE16BE3276D48C2D2E44D4 /* VoiceMessageStatus.swift */, ); - path = Module; + path = Enums; sourceTree = ""; }; - 401F620639A5A13452827920 /* UserList */ = { + 3F4AC65878DC63DBA6CAF956 /* ChannelList */ = { isa = PBXGroup; children = ( - 05FFB56CB1A9AF2AA9EB60A5 /* SBUUserListModule.Deprecated.swift */, + 60581B37CF51AAEFCECE77CD /* SBUBaseChannelListViewController.swift */, + 1729EF71A43A28ABF375F9A0 /* SBUGroupChannelListViewController.swift */, + D1138C0CF644F604A4DB6BEA /* SBUOpenChannelListViewController.swift */, + 65C668339606B0A41610ECFD /* ChannelCell */, ); - path = UserList; + path = ChannelList; sourceTree = ""; }; - 4288822841421C796CF81D5E /* ViewConverters */ = { + 405291E3A663F0C8D579CD7A /* GroupBannedUserList */ = { isa = PBXGroup; children = ( - 6099C0F4584A7A7822DF81D6 /* OpenBannedUserListViewConverter.Header.swift */, - E62E37A0B85E8D8C1DD0BE42 /* OpenBannedUserListViewConverter.List.swift */, - CA33454C78840807B7841838 /* OpenBannedUserListViewConverter.swift */, - 6F89A8E5D6B54674EDAD0090 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift */, - 7D019D737385153F291693BF /* SBUOpenBannedUserListModule.List+SwiftUI.swift */, - 9A6F00C0095D4A373AC6FD93 /* SBUOpenBannedUserListUserCell+SwiftUI.swift */, + 81EFDEE298AB85013EA1761F /* GroupBannedUserListView.swift */, + C6B832789F70E71F8D7572D9 /* GroupBannedUserListView+Item.swift */, + 485E1BC7A3AB0C82AAE3145D /* GroupBannedUserListView+SubViewBuilder.swift */, + 2307E41DDDA61CF29EB83335 /* GroupBannedUserListView+ViewConverter.swift */, + 045EF0FD06337FF5EA81F035 /* GroupBannedUserListViewProvider.swift */, + 835F158D36A9025D2526EFA2 /* ViewConverters */, ); - path = ViewConverters; + path = GroupBannedUserList; sourceTree = ""; }; - 4365CE58060FBBB9A5F2B732 /* CustomSample */ = { - isa = PBXGroup; - children = ( - 6C01527DA7DC24CAFBDFD28D /* CustomSampleSubView.swift */, - 534F2E4ED993A0EB9AE192C4 /* CustomSampleSubViewModel.swift */, - 0B7E908DFF59E617F26B85F1 /* CustomSampleView.swift */, - 8DE8486ECC131F76C82AD08D /* CustomSampleViewModel.swift */, - 0F414A17F02B7FBAF48B52B4 /* CustomViews */, + 406A19B584F71B1B4DB46410 /* Deprecated */ = { + isa = PBXGroup; + children = ( + 0AD34F85878574D07C59C493 /* BaseMesssage+SBUIKit.Deprecated.swift */, + 60990AE9096DF6FA54EC29BF /* SBUBaseViewController.Unavailable.swift */, + 76C3E5ACC74FD4BB8F224A67 /* SBUCoverImageView.Deprecated.swift */, + 36DB7771E34A27FE3507F0DE /* SBUEnums.Deprecated.swift */, + 0259861A8497D04AEA7CE0C9 /* SBUForm.Deprecated.swift */, + 424A582E4E59F6FC3F368ABB /* SBUFormFieldView.Deprecated.swift */, + ABEE9C98A1E6CDDEA7001F6A /* SBUFormView.Deprecated.swift */, + 7955E39023C81688202CE6AE /* SBUFormViewParams.Deprecated.swift */, + C88F606D9A7BFD1287285E78 /* SBUGlobals.Deprecated.swift */, + CE2F4109190C0315167EAF1C /* SBUTableViewCell.Unavailable.swift */, + E42AB4882426DF1FBE40A612 /* SBUTheme.Deprecated.swift */, + E0F389D1E864F9A48260D9C7 /* SBUView.Unavaliable.swift */, + 525286C859F82074D24680B2 /* SendbirdUI.Deprecated.swift */, + 3D464670C858CEB6C67BA230 /* Channel */, + 8C014842FD198022179F2AEF /* ChannelList */, + 6BAE18D887D4199693220DFC /* ChannelSettings */, + 8853BDC936388F5C4C15F784 /* CreateChannel */, + 2A38107FF3B7D943D2ED3160 /* MemberList */, + 3407B19E1179AC461AF350FC /* MessageSearch */, + D572A6F2EB9EA9CC6750F357 /* Moderations */, + 6E8EDEB5B0A885FC4CD611D8 /* Module */, + BDA65EBB7B18CE14D60E960A /* UserList */, ); - path = CustomSample; + path = Deprecated; sourceTree = ""; }; - 4384AAD690A7AFF22A028A0C /* MessageSearch */ = { + 407A280C10789557816A1AF8 /* ViewParams */ = { isa = PBXGroup; children = ( - 5BED13B61170536763801B04 /* CustomMessageSearch.swift */, - 875D2D6DA38A32E1BB865205 /* SubView */, - 1FF84F5DF9C75C48DCADE03D /* SwiftUI */, - BF7B49A1319B044D32E0BEF7 /* ViewConverter */, + 6C2A652B4CE7406954BBF464 /* SBUQuotedBaseMessageViewParams.swift */, ); - path = MessageSearch; + path = ViewParams; sourceTree = ""; }; - 4439F6557CDF210DC11B8761 /* SubView */ = { + 408876FBD39EDF3D40FB28D4 /* ViewConverters */ = { isa = PBXGroup; children = ( - 9450C3973B172BE5EE88D23C /* Builder */, + AF34A3B458887980810747D2 /* OpenChannelRegisterOperatorViewConverter.Header.swift */, + FFFBB3032630028580441A41 /* OpenChannelRegisterOperatorViewConverter.List.swift */, + 589B1E8E2A00B25B20ECD24A /* OpenChannelRegisterOperatorViewConverter.swift */, + AFE3D03358D333FDDEA9BB20 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift */, + 068D92AC2E455E1FB045B5EE /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift */, ); - path = SubView; + path = ViewConverters; sourceTree = ""; }; - 467D706D4365B148D27D7147 /* SwiftUI */ = { + 409CE668582B54DDF9AC5855 /* ViewConverters */ = { isa = PBXGroup; children = ( - 0028881F36A7654C3E9DEA9B /* View */, + C9B2E0BAC9866D25FE5F8F5F /* GroupChannelListViewConverter.Header.swift */, + F124AB50E137D73C24E2B83D /* GroupChannelListViewConverter.List.swift */, + D6DA1D0A44C99A7052978AB9 /* GroupChannelListViewConverter.swift */, + 062F7B69185282C3ADAAEFA9 /* SBUGroupChannelCell+SwiftUI.swift */, + BA937CAFFBDC2CAC0FE00664 /* SBUGroupChannelListModule.Header+SwiftUI.swift */, + 8E77729D950B20F81EC79C63 /* SBUGroupChannelListModule.List+SwiftUI.swift */, ); - path = SwiftUI; + path = ViewConverters; sourceTree = ""; }; - 468B6AE90A221C3B64D76B2E /* Deprecated */ = { - isa = PBXGroup; - children = ( - 002B39B769D0499CC67311F8 /* BaseMesssage+SBUIKit.Deprecated.swift */, - 6E58BDD6097554E5AA391B25 /* SBUBaseViewController.Unavailable.swift */, - 0B26FE8DE186569C5BEFC548 /* SBUCoverImageView.Deprecated.swift */, - 8A8F43AB90915B61D475F48A /* SBUEnums.Deprecated.swift */, - 055A3B07C1A7654608413474 /* SBUForm.Deprecated.swift */, - FCD53856699176A2A465111B /* SBUFormFieldView.Deprecated.swift */, - 515A6FCA6E34F58EB62146AD /* SBUFormView.Deprecated.swift */, - 1DB8F69105F07B296E8C63F7 /* SBUFormViewParams.Deprecated.swift */, - 505C2553E67C0C1CDDE626B2 /* SBUGlobals.Deprecated.swift */, - B48EFC9732F79D6C644ABE86 /* SBUTableViewCell.Unavailable.swift */, - F3D7ECABBD13ECA6EDB56017 /* SBUTheme.Deprecated.swift */, - 7F311E6823137533AF24741B /* SBUView.Unavaliable.swift */, - D4DBC0F7C21761BD70C04903 /* SendbirdUI.Deprecated.swift */, - 0C009F1683DDEEE24F25E166 /* Channel */, - 688FC7A8A47D29201EDF11CD /* ChannelList */, - 0A2E65842DA5F60662B41275 /* ChannelSettings */, - CCC8CB1C84A26D60CEA650E1 /* CreateChannel */, - DFAB359EC86C8260746E3638 /* MemberList */, - 3B97E013AD6022EBE0BA3D51 /* MessageSearch */, - 9B7B3C8AD13A16214ABDB40C /* Moderations */, - 3F5ED75AB7DEED7CC5410B37 /* Module */, - 9F40563D7465D26B775DF83E /* UserList */, + 40F308661D4D155076B792BA /* Replies */ = { + isa = PBXGroup; + children = ( + 73244C0BDE25C5B9302DC29B /* MessageView */, + 407A280C10789557816A1AF8 /* ViewParams */, ); - path = Deprecated; + path = Replies; sourceTree = ""; }; - 46AA50892BC29E91F92FE439 /* GroupMutedMemberList */ = { + 429E843624E052A1AFD3D4E7 /* GroupChannelList */ = { isa = PBXGroup; children = ( - 55B4B36852330960D9BC5260 /* GroupMutedMemberListView.swift */, - 5B7E3DDD69211B9214A0A24D /* GroupMutedMemberListView+Item.swift */, - 393297B39B4586C83A5FE3D0 /* GroupMutedMemberListView+SubViewBuilder.swift */, - F0965E8B16F9D4C0559C110F /* GroupMutedMemberListView+ViewConverter.swift */, - 8409CB8409688833AF1C464C /* ViewConverters */, + 4F73FDBC49B98B821FAD9E09 /* GroupChannelListView.swift */, + 4E2B56441DCC9C595481F9EE /* GroupChannelListView+Item.swift */, + 9B51CE14A8194C970B0D40F3 /* GroupChannelListView+SubViewBuilder.swift */, + 918EA2EEE13EC608EE6A9692 /* GroupChannelListView+ViewConverter.swift */, + 0F8BCC1FD155F0E5F9AC2C3D /* GroupChannelListViewProvider.swift */, + 409CE668582B54DDF9AC5855 /* ViewConverters */, ); - path = GroupMutedMemberList; + path = GroupChannelList; sourceTree = ""; }; - 46C329AA59391DC15F8F6EC0 /* SwiftUI */ = { + 435E6C3D5B8EFE4A5BEDF785 /* Syntax */ = { isa = PBXGroup; children = ( - 377CB683EA76DA82E16E556A /* SendbirdSwiftUI-Info.plist */, - 6BCFF1A7BD3C2D592E67391A /* SendbirdUI+SwiftUI.swift */, - CEBED7ED1E21D148B97F3548 /* Common */, - BF266751A0408B5F15724910 /* Extension */, - 3C275611E82FC0C0A1A9BC2D /* Internal */, - FA878FD989531295C6265A69 /* KeyFunctions */, - 47C39D2BE9C14140C12B50E5 /* Protocol */, - A7C2C17AB1DC5621537E7B4C /* Theme */, - 64AB0443DEC6C17B6F97C5F9 /* Util */, + 50E19A3A71169937AB5A03B8 /* SBUMessageTemplate.Action.swift */, + FBB443922F23428075A25054 /* SBUMessageTemplate.Decoders.swift */, + 1F2F32D7E4883A0DAA8DB902 /* SBUMessageTemplate.ErrorMessages.swift */, + F00384B1EF32956E18353B90 /* SBUMessageTemplate.ImageRatioType.swift */, + CBB1CE2457846204624418C0 /* SBUMessageTemplate.Syntax.Aligns.swift */, + 5D538AAC9F0B43C86FCCF6FB /* SBUMessageTemplate.Syntax.Identifier.swift */, + CEFEC44A228BCC230686AC05 /* SBUMessageTemplate.Syntax.Item.swift */, + 56F950DBB5A54AEC88D2E539 /* SBUMessageTemplate.Syntax.Sizes.swift */, + 58251BF056C682C010BEDD4D /* SBUMessageTemplate.Syntax.Styles.swift */, + 02C01C65740D25BBD3D9DD72 /* SBUMessageTemplate.Syntax.Types.swift */, + 63C9E6ECE987D0D1AAE72330 /* SBUMessageTemplate.Syntax.Views.swift */, ); - path = SwiftUI; + path = Syntax; sourceTree = ""; }; - 473E43FA14C87BF26F51A9FA /* Views */ = { + 4365CE58060FBBB9A5F2B732 /* CustomSample */ = { isa = PBXGroup; children = ( - 5E7E39A804B558F66F7EB947 /* SBUMessageFormChipsItemView.swift */, - D23CE29CE2785C1F89E0FE88 /* SBUMessageFormFallbackView.swift */, - A4FE9D61A27CDE2A743D3CFE /* SBUMessageFormItemView.swift */, - 52F1328AE03EAAF1AD426D08 /* SBUMessageFormMultiTextItemView.swift */, - BE7259CA31206A469BB51C25 /* SBUMessageFormSingleTextItemView.swift */, - 384A0D8AB5B526308F89634E /* SBUMessageFormView.swift */, - D743D1ED45AAA2315FDB6614 /* SubViews */, + 6C01527DA7DC24CAFBDFD28D /* CustomSampleSubView.swift */, + 534F2E4ED993A0EB9AE192C4 /* CustomSampleSubViewModel.swift */, + 0B7E908DFF59E617F26B85F1 /* CustomSampleView.swift */, + 8DE8486ECC131F76C82AD08D /* CustomSampleViewModel.swift */, + 0F414A17F02B7FBAF48B52B4 /* CustomViews */, ); - path = Views; + path = CustomSample; sourceTree = ""; }; - 47C39D2BE9C14140C12B50E5 /* Protocol */ = { + 4384AAD690A7AFF22A028A0C /* MessageSearch */ = { isa = PBXGroup; children = ( - 52E4D495AFCFF546A54C3B24 /* SwiftUIMessageInputInterface.swift */, - 326E8DC6D22782968571F3EC /* ViewControllerTypeProtocol + swiftUI.swift */, - C5CB3C5D62F094A20945FC45 /* ViewItemProtocol.swift */, + 5BED13B61170536763801B04 /* CustomMessageSearch.swift */, + 875D2D6DA38A32E1BB865205 /* SubView */, + 1FF84F5DF9C75C48DCADE03D /* SwiftUI */, + BF7B49A1319B044D32E0BEF7 /* ViewConverter */, ); - path = Protocol; + path = MessageSearch; sourceTree = ""; }; - 47FAD00AAFE8623AFD97BD89 /* ChannelSettings */ = { + 4439F6557CDF210DC11B8761 /* SubView */ = { isa = PBXGroup; children = ( - 5AE183BFE40D7C1AE34EF4C5 /* SBUBaseChannelSettingsModule.Header.swift */, - 869EAD18504324BF7D9CF724 /* SBUBaseChannelSettingsModule.List.swift */, - C7EFCE231326D9CFCB928363 /* SBUBaseChannelSettingsModule.swift */, - 26CE194F6189ADCC57BD8970 /* ChannelSettingItem */, - 86742C5016D873B75483C6E0 /* GroupChannel */, - 9004327AAC7327A6449173F1 /* OpenChannel */, + 9450C3973B172BE5EE88D23C /* Builder */, ); - path = ChannelSettings; + path = SubView; sourceTree = ""; }; - 48F39F715352BA623D592ADF /* Configuration */ = { + 44B23D89621E7E4165832ACB /* MessageThread */ = { isa = PBXGroup; children = ( - E5B646591D56E6AFE946CC45 /* SBUConfig.Base.swift */, - DA4BD8DEDFBA0A910449DB84 /* SBUConfig.CodingKeys.swift */, - 56C6B35A7D7A8F45805DE891 /* SBUConfig.Common.swift */, - DDDF7743ADEF95903798D261 /* SBUConfig.GroupChannel.swift */, - EFE82704B02948EF4CB57B1C /* SBUConfig.OpenChannel.swift */, - 899CCE6BB9CD3EDE4F60D06D /* SBUConfig.swift */, - 8F27A78EE60A93797E010244 /* SBUConfigManager.swift */, - 4655846FE0CADF225229E917 /* SBUDashboardConfig.swift */, - FC6B44BBB0BD3FC63EFE9ABD /* Mention */, - BA94FE259CBE2C0D3D1956BF /* MessageCell */, - F623ABFB8FDDAB9CDA797E12 /* Replies */, - 1DCD5EDAE4B648BFCCA97FA9 /* ScrollPostion */, - 2DA1C21D72FF7C354308F85F /* VoiceMessage */, + 2BCB5EB5A43E374C6E5D2743 /* SBUMessageThreadModule.Deprecated.swift */, ); - path = Configuration; + path = MessageThread; sourceTree = ""; }; - 493D5A21C3F422372FB6520D /* ViewConverter */ = { + 467D706D4365B148D27D7147 /* SwiftUI */ = { isa = PBXGroup; children = ( - 1A6E51CAAB3A8BF374BB048C /* Header */, - 0F170B0507B2489AC222E8EB /* List */, + 0028881F36A7654C3E9DEA9B /* View */, ); - path = ViewConverter; + path = SwiftUI; sourceTree = ""; }; - 49EFBFA1A41AD384C6BE2382 /* Channel */ = { + 48C109F35F02216E177F12E8 /* OpenChannel */ = { isa = PBXGroup; children = ( - 304A09ECDE1B9834CD9A4E19 /* SBUBaseChannelViewModel.swift */, - 4FC7056D923557465B002170 /* SBUChatNotificationChannelViewModel.swift */, - CC744E2B758AC433553ABEBB /* SBUFeedNotificationChannelViewModel.swift */, - 3C83ED8F2CAA20B762F4F5B6 /* SBUGroupChannelViewModel.swift */, - 41CE55F82D74BE766CC40BC8 /* SBUOpenChannelViewModel.swift */, + 8F0D567C1B8A60E173F80D95 /* SBUOpenChannelSettingsModule.Header.swift */, + 7BF8B7BD5D3182A7B49D05D5 /* SBUOpenChannelSettingsModule.List.swift */, + 59D6F159B1AF097FA42F0795 /* SBUOpenChannelSettingsModule.swift */, ); - path = Channel; + path = OpenChannel; sourceTree = ""; }; - 4A2A535E4636A203F0A94B55 /* OpenChannel */ = { + 491CAA9C39B6086E714B1903 /* Util */ = { isa = PBXGroup; children = ( - 30394872D50BA64B985DA1FF /* OpenChannelView.swift */, - 798CA844E4DAA6C1574314BE /* OpenChannelView+Item.swift */, - FB5A989D9069803A11632F6A /* OpenChannelView+SubViewBuilder.swift */, - 3F0E3B57CD4297BB82C8C616 /* OpenChannelView+ViewConverter.swift */, - 1277D6AC1D429087F6E4A528 /* ViewConverters */, + 68A5BCD230041D9FBB14D808 /* BlockingOperation.swift */, + CF745C20CDD40C35ACDA3A76 /* SBUDebouncer.swift */, + D0176BCE61DDDBD6F0937F8E /* SBULogger.swift */, + 0CC6CC5766E9A4E51E951E69 /* SBUMentionManager.swift */, + 401B66CDBC80C118564B5045 /* SBUPropertyWrapper.swift */, + 228FA3A4F2C3475CD28C3D23 /* SBUUtils.swift */, + DB95C0B594B7B03CE1B623A2 /* WeakDelegateStorage.swift */, ); - path = OpenChannel; + path = Util; sourceTree = ""; }; - 4A4CEA2BFA758EDB71D239B1 /* ViewConverters */ = { + 493D5A21C3F422372FB6520D /* ViewConverter */ = { isa = PBXGroup; children = ( - 7E4DA64D4218AE42BAC6C567 /* GroupBannedUserListViewConverter.Header.swift */, - EAB28CD649CAB03111FF852B /* GroupBannedUserListViewConverter.List.swift */, - 1A947D09517B73A703E1A7F0 /* GroupBannedUserListViewConverter.swift */, - CCF3DD6DAEDA6404D3F9EDFB /* SBUGroupBannedUserListModule.Header+SwiftUI.swift */, - 95DB32CF54500BF7F04B6482 /* SBUGroupBannedUserListModule.List+SwiftUI.swift */, - 8CE73800C5625E411855E0D3 /* SBUGroupBannedUserListUserCell+SwiftUI.swift */, + 1A6E51CAAB3A8BF374BB048C /* Header */, + 0F170B0507B2489AC222E8EB /* List */, ); - path = ViewConverters; + path = ViewConverter; sourceTree = ""; }; 4ABF73CB75BA3CC09EB7553F /* Builder */ = { @@ -3586,6 +3647,29 @@ path = OpenChannelList; sourceTree = ""; }; + 4C7DB99359F74A79BF6612F8 /* ViewConverters */ = { + isa = PBXGroup; + children = ( + 5C1F0FC94BD67FFF13DCA583 /* CreateOpenChannelViewConverter.Header.swift */, + 2881A84C01CB255EE1976829 /* CreateOpenChannelViewConverter.swift */, + 4B7EBE9547D711DC04841C63 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift */, + ); + path = ViewConverters; + sourceTree = ""; + }; + 4CB85E5D3E5C1E393CCE9794 /* ViewConverters */ = { + isa = PBXGroup; + children = ( + BCDE756FB020AB19ECBB9189 /* InviteUserViewConverter.Header.swift */, + 94086D052C1DD45734B45C9B /* InviteUserViewConverter.List.swift */, + EA23C8AD569D84167F4DD526 /* InviteUserViewConverter.swift */, + 040FD7FC4D1B4A8EC959975A /* SBUInviteUserCell+SwiftUI.swift */, + 4B53F3FCA6C01FAB50776850 /* SBUInviteUserModule.Header+SwiftUI.swift */, + 15269264474C5B46CF1910BE /* SBUInviteUserModule.List+SwiftUI.swift */, + ); + path = ViewConverters; + sourceTree = ""; + }; 4DBD9B53DFD7874C201FFD0E /* SwiftUI */ = { isa = PBXGroup; children = ( @@ -3604,15 +3688,17 @@ path = Header; sourceTree = ""; }; - 4E38C0E0730E5B9412A903DC /* SelectUser */ = { + 4E339E16363816705BB2918D /* OpenChannelList */ = { isa = PBXGroup; children = ( - 79E91C43DF36F6D0CADBE2D3 /* SBUCreateChannelModule.Deprecated.swift */, - E2E0ABB6DADF9727A38ACB20 /* SBUCreateOpenChannelModule.Deprecated.swift */, - E85ED75EA5E22BAA62EBFB36 /* SBUInviteUserModule.Deprecated.swift */, - 2C29B6EED1FE32956FF834A8 /* SBURegisterOperatorModule.Deprecated.swift */, + DBE77CA1AA32061F0B89F310 /* OpenChannelListView.swift */, + C7A7A445786CDA239FC3A495 /* OpenChannelListView+Item.swift */, + 2303751640029A1195FA8663 /* OpenChannelListView+SubViewBuilder.swift */, + F88ED0A9054B24C63657907F /* OpenChannelListView+ViewConverter.swift */, + AEA66943CFCCE47F35FFB80F /* OpenChannelListViewProvider.swift */, + 0E37B9749605FD3BD9136D57 /* ViewConverters */, ); - path = SelectUser; + path = OpenChannelList; sourceTree = ""; }; 4E5EF8D04A98E3F26606A967 /* ViewConverter */ = { @@ -3624,12 +3710,15 @@ path = ViewConverter; sourceTree = ""; }; - 4F1C94EA7A89AD3936A4ADED /* MessageThread */ = { + 4F50BE2F1FB881CDF8B27B53 /* SelectUser */ = { isa = PBXGroup; children = ( - B90AEFF358A26F1593707117 /* SBUMessageThreadViewModel.swift */, + A16049189F9B0C7ABC022076 /* SBUBaseSelectUserViewModel.swift */, + 0076945EEAFADBBF46EFFA28 /* SBUInviteUserViewModel.swift */, + AE682F654DF8EC3C5B5D3996 /* SBURegisterOperatorViewModel.swift */, + 1EDC0049FD083D38C5C9BFCC /* CreateChannel */, ); - path = MessageThread; + path = SelectUser; sourceTree = ""; }; 4FAD7AF898918AC264320855 /* Header */ = { @@ -3642,16 +3731,14 @@ path = Header; sourceTree = ""; }; - 50089F087451946CA477BB9D /* ViewConverters */ = { + 516D2ACE0F38FC7F166FBF64 /* NotificationChannel */ = { isa = PBXGroup; children = ( - 6F5B7BEEA70A8811267E7236 /* GroupChannelRegisterOperatorViewConverter.Header.swift */, - 5A5BD051A6556D060FB89677 /* GroupChannelRegisterOperatorViewConverter.List.swift */, - 8063BA0912F07F52734489F8 /* GroupChannelRegisterOperatorViewConverter.swift */, - 0D75561E0F23994F2D54F02A /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift */, - A71DA9519A09B9E6CBC9D375 /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift */, + 15FB7D893238C88344868AD0 /* SBUChatNotificationCell.swift */, + E27105B44C5F51755341A1CF /* SBUFeedNotificationCell.swift */, + 8C72EA12FBDBE0429DB866B0 /* SBUNotificationCell.swift */, ); - path = ViewConverters; + path = NotificationChannel; sourceTree = ""; }; 52BE5C3FE49C001B58B0FC21 /* GroupModerations */ = { @@ -3694,6 +3781,19 @@ path = List; sourceTree = ""; }; + 55D0D6829E44A11759802AC9 /* ChannelSettings */ = { + isa = PBXGroup; + children = ( + 7D856B5EFE6D3EF8B75FCF7F /* SBUBaseChannelSettingsModule.Header.swift */, + 6C8A4D2AB78B5DD00E13566E /* SBUBaseChannelSettingsModule.List.swift */, + 0FD503C5B7F8CDFB80C1888F /* SBUBaseChannelSettingsModule.swift */, + 7C3A486FA9CC087B271956F6 /* ChannelSettingItem */, + 1998BBD27C3AC7DC97F8017B /* GroupChannel */, + 48C109F35F02216E177F12E8 /* OpenChannel */, + ); + path = ChannelSettings; + sourceTree = ""; + }; 560EE283F59ADF0968936F12 /* View */ = { isa = PBXGroup; children = ( @@ -3712,52 +3812,27 @@ path = View; sourceTree = ""; }; - 59AA5667F5A450DB004A8060 /* ViewConverters */ = { + 57A401CDC2B680DFFE8092E7 /* CreateGroupChannel */ = { isa = PBXGroup; children = ( - 57D9985EEF88343041C1BE51 /* GroupChannelPushSettingsViewConverter.Header.swift */, - 5F3FD4AA9DAA78710AED644D /* GroupChannelPushSettingsViewConverter.List.swift */, - 5AA91AC88677D130F49744F1 /* GroupChannelPushSettingsViewConverter.swift */, - 2D62381A39883A6AF9749655 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift */, - 367715EF02DB7B56C38D52A8 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift */, - ); - path = ViewConverters; - sourceTree = ""; - }; - 5B71D0B9AB321FE785DF7693 /* Channel */ = { - isa = PBXGroup; - children = ( - B85160213149D7C96CF3D470 /* SBUBaseChannelViewController.Keyboard.swift */, - BC4E1242DCFF67A780DD080B /* SBUBaseChannelViewController.swift */, - B217E1EA093625A1F18F9245 /* SBUChatNotificationChannelViewController.swift */, - 9456BE61985B9DAB0E0D12CE /* SBUFeedNotificationChannelViewController.swift */, - C6401EB0744D3234CC09B212 /* SBUGroupChannelViewController.swift */, - 5B17D11ADD035FDE1271DBAA /* SBUOpenChannelViewController.swift */, - 6E8ACB69351D47AF7892259A /* CategoryFilterCell */, - 66AAD2339E7B7D75746B3100 /* CellView */, - ECBFF421037C34C3E998C6F1 /* ChannelStateBanner */, - 81AB0BD39153E969F3B9EF34 /* FileViewer */, - 3C39C8F69C0F6199DA58AACD /* Header */, - A7DEADF1750E04F4F832EADF /* Media */, - 65BF76A59DA7FBA3FD8B7381 /* MessageCell */, - E2393BBCED543B06C566031A /* MessageInput */, - 217328E9EFE6BC7722B65DA8 /* NewMessageInfo */, - 224D4FBFCC0B46FFFF365E94 /* Reaction */, - CC90673304787B93F2D1652A /* ScrollBottomView */, - 84E7F01CCA13CF781F309FA1 /* ViewModel */, + 644566F6C95C0AE1075D4E82 /* CreateGroupChannelView.swift */, + 3442BED25FDD54492980D099 /* CreateGroupChannelView+Item.swift */, + 2B719C1C7BCA50103B2FD33F /* CreateGroupChannelView+SubViewBuilder.swift */, + 87A0FA711ABE3E5605B1307B /* CreateGroupChannelView+ViewConverter.swift */, + BE55BC5056EEB299BC27EF13 /* CreateGroupChannelViewProvider.swift */, + D9714C44FD4B3BD4FF9E9BA6 /* ViewConverters */, ); - path = Channel; + path = CreateGroupChannel; sourceTree = ""; }; - 5B77CFAF53AAB86BE2EF3123 /* Toast */ = { + 59576C9425E6E7760C142619 /* Moderations */ = { isa = PBXGroup; children = ( - 6F685142DBEC56397DF49B04 /* SBUToastType.swift */, - 3F45FA38BF21FE277B770348 /* SBUToastView.Internal.swift */, - BCB0F215A1630FCF1A088CCA /* SBUToastView.Item.swift */, - D9B434F3BB648812D03FFFB9 /* SBUToastView.swift */, + 4FB83E6465C9943C30CD9C11 /* SBUModerationsModule.Header.swift */, + 456A19C5809209F185A044ED /* SBUModerationsModule.List.swift */, + 12DF34E19AD9277AABB197A4 /* SBUModerationsModule.swift */, ); - path = Toast; + path = Moderations; sourceTree = ""; }; 5CAFC9AB4BB0C0F3B00433DA /* OpenChannelRegisterOperator */ = { @@ -3779,30 +3854,20 @@ path = ViewConverter; sourceTree = ""; }; - 5FC5C1AE77DE2A38B7307021 /* Custom */ = { + 5ED8199C1A718295D452C9FE /* CategoryFilterCell */ = { isa = PBXGroup; children = ( - C8B010F0771DB55B89DB52D6 /* CustomTheme.IconSet.Custom.Main.swift */, + B545224CE456DD6FC076E267 /* SBUCategoryFilterCell.swift */, ); - path = Custom; + path = CategoryFilterCell; sourceTree = ""; }; - 5FDD009EC649193BF202EE1B /* Manager */ = { + 5FC5C1AE77DE2A38B7307021 /* Custom */ = { isa = PBXGroup; children = ( - 4135695B4B2A78F728C56842 /* SBUDownloadManager.swift */, - 88134BA06CADFAE21FFFC2D0 /* SBUEmojiManager.swift */, - F7159308B1615AF89E0C5848 /* SBUMessageTemplateManager.swift */, - 677F49AF45920CCFBEB5C009 /* SBUNotificationChannelManager.swift */, - 0E39C7F475F05E20458F1D7C /* SBUPendingMessageManager.swift */, - 79787649F52DE9A28FB275CE /* SBUPermissionManager.swift */, - 0E36DF9938BFB246705DDF39 /* SBUTemplateType.swift */, - 2BCED6324E56293CB6D4F266 /* SBUTypingIndicatorMessageManager.swift */, - 092C81FE6CB8C115FFB896E6 /* SBUVoicePlayer.swift */, - E009E7101E09810AB0B2A2BA /* SBUVoiceRecorder.swift */, - A63909874513E7398C217DD0 /* CacheManager */, + C8B010F0771DB55B89DB52D6 /* CustomTheme.IconSet.Custom.Main.swift */, ); - path = Manager; + path = Custom; sourceTree = ""; }; 5FDEB9E6E3EB85C3DA610202 /* QuickStartSwiftUI */ = { @@ -3835,15 +3900,6 @@ path = List; sourceTree = ""; }; - 603F6CCA87C123941424D100 /* MessageSearch */ = { - isa = PBXGroup; - children = ( - B76D4B10BDE52AD3E7C6B136 /* SBUMessageSearchViewController.swift */, - FD4BB759224750FDE5DF1630 /* Cell */, - ); - path = MessageSearch; - sourceTree = ""; - }; 61DBF6CA1972E6DC3F2A0F50 /* Header */ = { isa = PBXGroup; children = ( @@ -3875,83 +3931,39 @@ path = SwiftUI; sourceTree = ""; }; - 64A994A926EE96A22347C8C3 /* User */ = { + 644A0FCD1CC229A232C6BCD5 /* MessageSearch */ = { isa = PBXGroup; children = ( - 24001A687A99EDBCB633CFD9 /* SBUUserProfileView.swift */, + 81F7060AFCA22AF15E3122CD /* SBUMessageSearchViewModel.swift */, ); - path = User; + path = MessageSearch; sourceTree = ""; }; - 64AB0443DEC6C17B6F97C5F9 /* Util */ = { + 659F002C6BD4539C3C746F9E /* SuggestedReply */ = { isa = PBXGroup; children = ( - 58D18F28C0BA2FC86077F964 /* DefaultViewConfigSet.swift */, - 8AF20B71046B6D5FF0174268 /* SBViewConverterSet.swift */, - 0B43C3575A86FB54C7F46C0C /* SwiftUIViewController.swift */, - 2D485B6D4BF580481E4D1D72 /* View + ViewModifier.swift */, - 15CFF068B647DF41C757A688 /* ViewConverter.swift */, - 9BB8896A51AC9A129CED3AA1 /* WrapperUIViews.swift */, - ); - path = Util; - sourceTree = ""; - }; - 65BF76A59DA7FBA3FD8B7381 /* MessageCell */ = { - isa = PBXGroup; - children = ( - 256F0FE776E5E6572F47D96A /* SBUAdminMessageCell.swift */, - 0E8A575294393A1D7BC34487 /* SBUBaseMessageCell.Feedback.swift */, - 66E8A3A8B613A74979FB0FD2 /* SBUBaseMessageCell.swift */, - 9FF73F1AC1586488A59B9BB9 /* SBUContentBaseMessageCell.swift */, - 27F66C34721B8052037668EF /* SBUFileMessageCell.swift */, - E7F4A5C2DE942F918F081586 /* SBUMessageTemplateCell.MessageTemplateLayer.swift */, - 2F7CFF8FDC3CA84CA743B250 /* SBUMessageTemplateCell.swift */, - 374258FE63226944670893DB /* SBUMessageTemplateCellLayout.swift */, - A0B27BB4D8B2F159844A77BF /* SBUTypingIndicatorMessageCell.swift */, - 1CD45E3398D54B7995E3867F /* SBUUnknownMessageCell.swift */, - 69FA8142D379C935F954206C /* SBUUserMessageCell.swift */, - F8A9CA098992AC9A397860E6 /* CarouselView */, - 26A47D9B3830215D4BA69EF6 /* CustomView */, - C4C67B3ED5AFC52073C01656 /* Feedback */, - D85A179C310192313FBAC03D /* FileMessageContentView */, - 3BAED34AF2354C77A3167F4E /* MessageCellParams */, - C9BF1ADC893574C285E9743D /* MessageForm */, - 2CF9F5283FE2A1D0DCAB7BEA /* MultipleFilesMessage */, - 91FF8520C435D3CACA86F75A /* NotificationChannel */, - D82AB513C032DD5BF769BC9C /* OpenChannel */, - E152ED49F13F45C06864F7EF /* Replies */, - 2DB244FB1C4C4D8C21A97AF9 /* SuggestedReply */, + FEDACCDF3580E7D5971C2DCE /* ViewParams */, + A1FFAB387774DBE8C9F1376C /* Views */, ); - path = MessageCell; + path = SuggestedReply; sourceTree = ""; }; - 66841D77E1D71FFA0E35F758 /* Cell */ = { + 65C668339606B0A41610ECFD /* ChannelCell */ = { isa = PBXGroup; children = ( - 5CEEA40256503D52DA8301A7 /* SBUBaseChannelSettingCell.swift */, - 3705CC5FA738AA9FAB298E7D /* SBUGroupChannelSettingCell.swift */, - 33B515D9E7A6C9C304D30F5F /* SBUModerationCell.swift */, - DC1B024DDFE6E63F14713E79 /* SBUOpenChannelSettingCell.swift */, + AB654419A3218B0E3A4093D5 /* SBUBaseChannelCell.swift */, + A59A6D2DE07C732BD16DB8CB /* SBUGroupChannelCell.swift */, + 0B2C1A70B8458205689EC309 /* SBUOpenChannelCell.swift */, ); - path = Cell; + path = ChannelCell; sourceTree = ""; }; - 66AAD2339E7B7D75746B3100 /* CellView */ = { + 668D44DB9BA02C63B7110239 /* UserCell */ = { isa = PBXGroup; children = ( - AF99A51ED217C33B971A26F9 /* SBULinkClickableTextView.swift */, - D2F9885440D0492C8904699E /* SBUMarkdownTransfer.swift */, - D5497D090BBDCC67C4F8CBF8 /* SBUMessageDateView.swift */, - F06A8792B7A5667225B0B139 /* SBUMessageProfileView.swift */, - 46A56A7F8B030C1F016B4CED /* SBUMessageStateView.swift */, - 519230E62500F1040802B744 /* SBUMessageWebView.swift */, - C080BD93D8577C641E87E1D5 /* SBUNotificationTimelineView.swift */, - F8581D84EDC1F269B235F2B2 /* SBUOpenChannelMessageWebView.swift */, - 9791A3C99477F1AA70CB5338 /* SBUSelectableStackView.swift */, - A29D69A7375F3F7BDFEE2D4C /* SBUUserMessageTextView.swift */, - DEE36BE9DDD0FCF4E77E17DA /* SBUUserNameView.swift */, + 1D79AE410C0225BF9B73BD23 /* SBUUserCell.swift */, ); - path = CellView; + path = UserCell; sourceTree = ""; }; 66BF9252109B64921D9F42D9 /* SwiftUI */ = { @@ -3980,14 +3992,6 @@ path = SubView; sourceTree = ""; }; - 688FC7A8A47D29201EDF11CD /* ChannelList */ = { - isa = PBXGroup; - children = ( - C8892CCB312BD353673997C2 /* SBUChannelListViewController.Deprecated.swift */, - ); - path = ChannelList; - sourceTree = ""; - }; 6897C7E4B264FD458028B845 /* List */ = { isa = PBXGroup; children = ( @@ -4000,65 +4004,73 @@ path = List; sourceTree = ""; }; - 697510D454FA0C81301E8D36 /* CreateGroupChannel */ = { + 68F65643567C85C304D50C31 /* MessageTemplate */ = { isa = PBXGroup; children = ( - CCAC3124A832A9847294D2F8 /* CustomCreateGroupChannel.swift */, - D35C5ED8392BF324A99B9934 /* SwiftUI */, - 493D5A21C3F422372FB6520D /* ViewConverter */, + B97D86AD63DE6E5D1AF2F631 /* SBUMessageTemplate.swift */, + 230061178DC65F9C7044E74F /* Processor */, + 24336E86E48061D6378D638F /* Renderer */, + 435E6C3D5B8EFE4A5BEDF785 /* Syntax */, + 1FA3FEAD48FB114CD4C6A800 /* Tester */, ); - path = CreateGroupChannel; + path = MessageTemplate; sourceTree = ""; }; - 6978D272A6E8BD64E4340F40 /* GroupChannel */ = { + 697510D454FA0C81301E8D36 /* CreateGroupChannel */ = { isa = PBXGroup; children = ( - 1223F79CC60D5AB916A3204B /* GroupChannelView.swift */, - 6C9F033A5ACB73B595F79862 /* GroupChannelView+Item.swift */, - A833DCE545C57E47102A070E /* GroupChannelView+SubViewBuilder.swift */, - 9E08E04B398544D900FCDB10 /* GroupChannelView+ViewConverter.swift */, - E1CC4D09C2CA70DAE58B55B3 /* ViewConverters */, + CCAC3124A832A9847294D2F8 /* CustomCreateGroupChannel.swift */, + D35C5ED8392BF324A99B9934 /* SwiftUI */, + 493D5A21C3F422372FB6520D /* ViewConverter */, ); - path = GroupChannel; + path = CreateGroupChannel; sourceTree = ""; }; - 69B2827C8B9D19CE53BB5178 /* Theme */ = { + 698EF9C9DEF12F6FB1265602 /* ChatSDK */ = { isa = PBXGroup; children = ( - FD3B3C58D3785437EE1411F1 /* SBUColorSet.swift */, - 74FEA7AFCAA577BB7A5935A5 /* SBUFontSet.swift */, - B51FC07C5EB09E0C69628EA0 /* SBUIconSet.swift */, - EC3CBE8DD286C9ED98CC73C0 /* SBUTheme.swift */, - EE7B5B27FFA176D18D23171C /* SBUTheme+Type.swift */, + 5A6472958F4CF3447377BD4A /* BaseMessage+SBUIKit.MessageTemplate.swift */, + 68610F5D31C4E9913A09CCD4 /* BaseMessage+SBUIKit.swift */, + 2F648AC1BF4B63CC9EDF30CF /* MessageForm+SBUIKit.swift */, + 82679D287A3368E9008A1CAC /* MultipleFilesMessage+SBUIKit.swift */, + E567F385A20BDC53C3078CC6 /* SendbirdChat+SBUIKit.swift */, ); - path = Theme; + path = ChatSDK; sourceTree = ""; }; - 6B52B6FCCBF72533DE363063 /* MessageThread */ = { + 69E2E529708E491C19C7A463 /* MessageCellParams */ = { isa = PBXGroup; children = ( - D8573A563BC2E14A69A49B2C /* SBUMessageThreadModule.Deprecated.swift */, + 73D6FC69CD89388D9ACC5B71 /* SBUAdminMessageCellParams.swift */, + 53AC6ADF9CA7559D22B20EFD /* SBUBaseMessageCellParams.swift */, + E68C5044109960435BBDBF86 /* SBUFeedNotificationCellParams.swift */, + 062E500577E9F9C767A60C97 /* SBUFileMessageCellParams.swift */, + 0EA5BBCE668287248E3E5863 /* SBUMessageTemplateCellParams.swift */, + 3046107CAA8EAABF90DD8218 /* SBUMultipleFilesMessageCellParams.swift */, + 02B0799921F368AB9F43E812 /* SBUTypingMessageCellParams.swift */, + 65327F0DFF20C899672B90BB /* SBUUnknownMessageCellParams.swift */, + E8444BA33EBECD12A5B3278F /* SBUUserMessageCellParams.swift */, ); - path = MessageThread; + path = MessageCellParams; sourceTree = ""; }; - 6BB7F2F4A53919E8A17629B7 /* Common */ = { + 6BAE18D887D4199693220DFC /* ChannelSettings */ = { isa = PBXGroup; children = ( - 5BFCC249BB471DB592E5A3C3 /* SBUCommonDelegate.swift */, + D0B305731A8CE51649B82676 /* SBUBaseChannelSettingsViewController.Deprecated.swift */, ); - path = Common; + path = ChannelSettings; sourceTree = ""; }; - 6BE694860AC1F73A360AA868 /* SelectUser */ = { + 6C7BCCB8D37875E3223E86A5 /* GroupChannel */ = { isa = PBXGroup; children = ( - 020B96FF3BCFE616CFDD5DBC /* SBUBaseSelectUserViewModel.swift */, - 7D2D48D4D2A4206F1DDE7CD7 /* SBUInviteUserViewModel.swift */, - 08612EE13528E627A17FC38D /* SBURegisterOperatorViewModel.swift */, - 11521464DEE2F7AC0E6F747A /* CreateChannel */, + AED99943C6CCB04E8DB46AE5 /* SBUGroupChannelListModule.Common.swift */, + 151589C04C2127E51ABCF91D /* SBUGroupChannelListModule.Header.swift */, + 4798C26A881FB43F032AC24D /* SBUGroupChannelListModule.List.swift */, + 8EBBC3D69755C1B4A69C7721 /* SBUGroupChannelListModule.swift */, ); - path = SelectUser; + path = GroupChannel; sourceTree = ""; }; 6CB038EEC694A414B4A12D74 /* Extensions */ = { @@ -4070,14 +4082,6 @@ path = Extensions; sourceTree = ""; }; - 6D1EC3EC0C4846B652F8FB9E /* NotificationSettings */ = { - isa = PBXGroup; - children = ( - 076B76458F2B9617C69FB28E /* SBUGroupChannelPushSettingsViewModel.swift */, - ); - path = NotificationSettings; - sourceTree = ""; - }; 6D351AD64E84C927FE00ACEC /* Header */ = { isa = PBXGroup; children = ( @@ -4088,12 +4092,39 @@ path = Header; sourceTree = ""; }; - 6E8ACB69351D47AF7892259A /* CategoryFilterCell */ = { + 6D3DE8660C9CC50307788FC8 /* Manager */ = { isa = PBXGroup; children = ( - D2CCFB76C36D83C085F65E5C /* SBUCategoryFilterCell.swift */, + 2ADEBE78ECAF2FB8B6CD1A96 /* SBUDownloadManager.swift */, + 464ADCD317DBEB46993B86DD /* SBUEmojiManager.swift */, + C6D06846C4514870E7373463 /* SBUMessageTemplateManager.swift */, + F9AD7543D82F147890DDA8EC /* SBUNotificationChannelManager.swift */, + BBF13F185407274DA4BAFF25 /* SBUPendingMessageManager.swift */, + A37035DF62B792FA791F53D5 /* SBUPermissionManager.swift */, + CF2784E3ECE293C035C957A6 /* SBUTemplateType.swift */, + 58AB877B3077DBE7EC520DBE /* SBUTypingIndicatorMessageManager.swift */, + 0A5B0CFDF41FCE53A58D53DB /* SBUVoicePlayer.swift */, + D5A8512A3DE8E4E3C4FD944C /* SBUVoiceRecorder.swift */, + B1973970C79F1A7BE63EC3EE /* CacheManager */, ); - path = CategoryFilterCell; + path = Manager; + sourceTree = ""; + }; + 6E8EDEB5B0A885FC4CD611D8 /* Module */ = { + isa = PBXGroup; + children = ( + 1BB7510F2315F0AA6E215A4B /* SBUModuleSet.Deprecated.swift */, + 9F88D0726F99D7231D8FA69C /* Channel */, + 0384CE725B2C73E3E0C1678D /* ChannelList */, + 15B37BD12AF037BDA28D5A33 /* ChannelSettings */, + FD67BD40F7877CE6DFFE8FD5 /* MessageSearch */, + 44B23D89621E7E4165832ACB /* MessageThread */, + CCE414371CE628BF4F4C3A7F /* Moderations */, + 026452E92E8AB7038308C3DB /* NotificationSettings */, + 370EDAA6CB561037EA9C8675 /* SelectUser */, + C440C7EF2B5947B434178ACC /* UserList */, + ); + path = Module; sourceTree = ""; }; 6EC0745FE82A168DC70FC09B /* ViewConverter */ = { @@ -4105,6 +4136,16 @@ path = ViewConverter; sourceTree = ""; }; + 6F08556F59EAF2165D1C999F /* UserList */ = { + isa = PBXGroup; + children = ( + 6EB71BF0445525ACB58EB67D /* SBUUserListModule.Header.swift */, + 44C1DB413EA8CE674D33B63E /* SBUUserListModule.List.swift */, + 2E62CC4F6BA3B54579233BFE /* SBUUserListModule.swift */, + ); + path = UserList; + sourceTree = ""; + }; 6F3C4B5A158067FE9E092B00 /* SwiftUI */ = { isa = PBXGroup; children = ( @@ -4123,14 +4164,17 @@ path = Header; sourceTree = ""; }; - 6FD2259F7D73881DBA3DF577 /* MessageThread */ = { + 6FCD0BA2E90BBC37B90AE63E /* OpenChannel */ = { isa = PBXGroup; children = ( - 69FF9A1D6E3096D844452179 /* SBUMessageThreadTitleView.swift */, - 075C4E9CEE0C27B851CD533C /* SBUMessageThreadViewController.swift */, - 789CAB6C3FE329C8F7C13530 /* SBUParentMessageInfoView.swift */, + 62CC0CF4B851582B239AE1FF /* SBUOpenChannelAdminMessageCell.swift */, + 0C45A13A56647ADEE8B57C17 /* SBUOpenChannelBaseMessageCell.swift */, + 207182002E1CFAE44F7484F7 /* SBUOpenChannelContentBaseMessageCell.swift */, + 9894EDC6924A66DE7D950197 /* SBUOpenChannelFileMessageCell.swift */, + 2B9F8C9272B19A196F85B9F1 /* SBUOpenChannelUnknownMessageCell.swift */, + C9DED4E5BC49F741DD5BAE12 /* SBUOpenChannelUserMessageCell.swift */, ); - path = MessageThread; + path = OpenChannel; sourceTree = ""; }; 7009317050CEF06A0C984FF9 /* Builder */ = { @@ -4142,16 +4186,12 @@ path = Builder; sourceTree = ""; }; - 70739DE86441084058D5FEDF /* OpenModerations */ = { + 71D1B26875E76A58D4D372EE /* ViewProvider */ = { isa = PBXGroup; children = ( - 5439E224FB62720B74EAC103 /* OpenModerationsView.swift */, - C2DC6AC36C13CF9CE994D450 /* OpenModerationsView+Item.swift */, - 0A26F750C0BD5F985CE0488F /* OpenModerationsView+SubViewBuilder.swift */, - B27F2C1ED575A382398E6677 /* OpenModerationsView+ViewConverter.swift */, - 19A25BB7CFE3710B8A2D998E /* ViewConverters */, + 98A67C9D3AF0E073941124E5 /* CustomGroupChannelList.SwiftUI.View.ViewProvider.swift */, ); - path = OpenModerations; + path = ViewProvider; sourceTree = ""; }; 7231E6F9486A697A5DDB7126 /* Header */ = { @@ -4167,6 +4207,14 @@ path = Header; sourceTree = ""; }; + 723B758A4E64701846B6AF7A /* FileViewer */ = { + isa = PBXGroup; + children = ( + 604F608DA839B7F04E684A40 /* SBUFileViewController.swift */, + ); + path = FileViewer; + sourceTree = ""; + }; 72BC67A31924DCA5087FAE29 /* View */ = { isa = PBXGroup; children = ( @@ -4176,17 +4224,36 @@ path = View; sourceTree = ""; }; - 74D5488505700B0A641DF167 /* ViewConverters */ = { + 73244C0BDE25C5B9302DC29B /* MessageView */ = { isa = PBXGroup; children = ( - 72AADB71AB3EE728FC6C0993 /* InviteUserViewConverter.Header.swift */, - AE33606F2063A12272D6CCB7 /* InviteUserViewConverter.List.swift */, - BB0D3EA32D2293C49B99240F /* InviteUserViewConverter.swift */, - 0FB5A38900DB0EB791444A96 /* SBUInviteUserCell+SwiftUI.swift */, - 567FF37C00B81850DBD328D4 /* SBUInviteUserModule.Header+SwiftUI.swift */, - 8082548DA6A2D4226E6D4B0B /* SBUInviteUserModule.List+SwiftUI.swift */, + 82266B325AF8EC3539D27C56 /* QuotedFileCommonContentView.swift */, + 6EB22BF73F4DB239A34F6792 /* QuotedFileImageContentView.swift */, + 0C7DB64BF6C562A80283A7E6 /* SBUQuotedBaseMessageView.swift */, + EE88D3E3ECD3A7A231EA8AA7 /* SBUQuotedFileMessageView.swift */, + 7BA58675E43486760EBE4B9B /* SBUQuotedUserMessageView.swift */, + A172ECA24F1EED3C916C4B10 /* SBUThreadInfoView.swift */, ); - path = ViewConverters; + path = MessageView; + sourceTree = ""; + }; + 73AF64E05429C2D9804448FA /* Model */ = { + isa = PBXGroup; + children = ( + 035C3F64FE7AAB645C853985 /* SBUError.swift */, + 37ABB14A977C9D99DFF4CA6A /* SBUExtendedMessagePayload.swift */, + 61EFB9AFE83364174EFF7E68 /* SBUExtendedMessagePayloadForUI.swift */, + 0635067B6F0880D18DE4C6D5 /* SBUFeedbackAction.swift */, + B1E9D76A5720F7B7C9B6AA55 /* SBUHighlightMessageInfo.swift */, + 8B69E3E68D1C6DF2B3B4CCE5 /* SBUMention.swift */, + DDD86011BD9689522AFEA443 /* SBUMessageCache.swift */, + 07C8D193A2E09030747F8FF6 /* SBUScrollOptions.swift */, + F02236D8926A5EE794CBBE3F /* SBUTypingIndicatorInfo.swift */, + 7BA35D433C66A5CAEADA49E0 /* SBUTypingIndicatorMessage.swift */, + 6A7FF2619B41D30553554AC0 /* SBUUser.swift */, + 83337608204FE94776C542A4 /* SBUVoiceFileInfo.swift */, + ); + path = Model; sourceTree = ""; }; 756CC45EE8E2B2F77C5314F1 /* ViewConverter */ = { @@ -4198,24 +4265,26 @@ path = ViewConverter; sourceTree = ""; }; - 75D3C8F6310558F0DA3A8CB0 /* NotificationChannel */ = { + 76A5810EC2F41277D182CF4F /* ViewConverters */ = { isa = PBXGroup; children = ( - BF024F362C5F2B1974FFABE1 /* Chat */, - 210944461ABABCDB6D80FD58 /* Feed */, + 2E2769B561909503AB35C646 /* OpenOperatorListViewConverter.Header.swift */, + A37A5AFCDE39921B45147472 /* OpenOperatorListViewConverter.List.swift */, + 88D5604351DFC4004002856A /* OpenOperatorListViewConverter.swift */, + C7291EB72F5BC939C93ACD43 /* SBUOpenOperatorListModule.Header+SwiftUI.swift */, + DFAF3C2261ECEBCC158D13CD /* SBUOpenOperatorListModule.List+SwiftUI.swift */, + ECA54CBEF188987F7469149B /* SBUOpenOperatorListUserCell+SwiftUI.swift */, ); - path = NotificationChannel; + path = ViewConverters; sourceTree = ""; }; - 7669980D4DB087571F7E523D /* GroupChannel */ = { + 76CD9D5102D4F4437A17BD5B /* Internal */ = { isa = PBXGroup; children = ( - F6D93377303A480B6512DD30 /* SBUGroupChannelListModule.Common.swift */, - 68FEB348E153995E6D9A609C /* SBUGroupChannelListModule.Header.swift */, - DF0E4D61160B2C4D056ABF96 /* SBUGroupChannelListModule.List.swift */, - 501B2DCFD9D5FAD15D5CB709 /* SBUGroupChannelListModule.swift */, + F80235BDD41FD230B2CEBA6B /* Protocol */, + D8C81B5BE27B529B495D927A /* Util */, ); - path = GroupChannel; + path = Internal; sourceTree = ""; }; 77BA896294D8DFEA0DE5A50C /* List */ = { @@ -4265,27 +4334,35 @@ path = View; sourceTree = ""; }; - 7847A121F521C10D81CFC75C /* ViewConverters */ = { + 7874403CCD46A17ECAC7848B /* Assets */ = { isa = PBXGroup; children = ( - 64D0F70137FEF5F25AD7A9DC /* OpenChannelListViewConverter.Header.swift */, - 47DF5589BE90ED973DB7F67A /* OpenChannelListViewConverter.List.swift */, - 24B1972F020FD19FB7A7E8D8 /* OpenChannelListViewConverter.swift */, - 07CDB82417CCB1815F880C95 /* SBUOpenChannelCell+SwiftUI.swift */, - D26E0EABCE381C370B68E9A8 /* SBUOpenChannelListModule.Header+SwiftUI.swift */, - A3AEBCB0B26EC13B2CA266E8 /* SBUOpenChannelListModule.List+SwiftUI.swift */, + 8B3DB3B902EE642A320204FC /* Assets.xcassets */, + 9971DD2E8907E4153EE20CA2 /* Info.plist */, + 192CDCD51D4B579E3E82C6CF /* QuickStartSwiftUI.entitlements */, ); - path = ViewConverters; + path = Assets; sourceTree = ""; }; - 7874403CCD46A17ECAC7848B /* Assets */ = { + 78A50C0EE65F7C2B8CFAEE5A /* ViewConverters */ = { isa = PBXGroup; children = ( - 8B3DB3B902EE642A320204FC /* Assets.xcassets */, - 9971DD2E8907E4153EE20CA2 /* Info.plist */, - 192CDCD51D4B579E3E82C6CF /* QuickStartSwiftUI.entitlements */, + 0ACCCEA9CFD52750859279FF /* MessageThreadViewConverter.Header.swift */, + 514BADC1204C3F13E85FAF35 /* MessageThreadViewConverter.Input.swift */, + 13DE9BE7EA1E8EA4077C9689 /* MessageThreadViewConverter.List.swift */, + B966D1C78F8A4D306FD0172A /* MessageThreadViewConverter.ParentInfo.swift */, + 5B197912A53CB3854FF990B4 /* MessageThreadViewConverter.swift */, + C539EDA44801E5FA137C9F14 /* SBUBaseMessageCell.MessageThread+SwiftUI.swift */, + E77ABB425ACC1813E35023C6 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift */, + 7A0D57F36F2D8B1100D6FE49 /* SBUMessageThreadInputView+SwiftUI.swift */, + 3F41FB77D91238CE800D9F43 /* SBUMessageThreadModule.Header+SwiftUI.swift */, + 34127F637D9BA4589A5E73CB /* SBUMessageThreadModule.Input+SwiftUI.swift */, + 6BF5A66B08808CCFBEC2C60A /* SBUMessageThreadModule.List+SwiftUI.swift */, + 11507F4DAA42980635F9C12E /* SBUMessageThreadTitleView+SwiftUI.swift */, + D7E1ACADA48174C1998A7B11 /* SBUMessageThreadViewController.SwiftUI.swift */, + 05EDD8753FC63FAB2F6E8EA5 /* SBUParentMessageInfoView+SwiftUI.swift */, ); - path = Assets; + path = ViewConverters; sourceTree = ""; }; 79FFC3B182A4AD8B296B9CDE /* View */ = { @@ -4297,37 +4374,17 @@ path = View; sourceTree = ""; }; - 7B08421A95216EF999A46093 /* ViewConverters */ = { - isa = PBXGroup; - children = ( - 9F3EE35D2B6C4B0FCC42CB8E /* GroupOperatorListViewConverter.Header.swift */, - 647093ADCCD6A67EC419903A /* GroupOperatorListViewConverter.List.swift */, - 64E89D9B931EADFB789516A6 /* GroupOperatorListViewConverter.swift */, - A7147B21E40C241888B079A1 /* SBUGroupOperatorListModule.Header+SwiftUI.swift */, - D78D017455F58559F9F64C82 /* SBUGroupOperatorListModule.List+SwiftUI.swift */, - 3F45F78119195BA9C15B4B18 /* SBUGroupOperatorListUserCell+SwiftUI.swift */, - ); - path = ViewConverters; - sourceTree = ""; - }; - 7B216A51C6D9959F37D3C5D5 /* View */ = { - isa = PBXGroup; - children = ( - 2D33147A10A17DE06274D98B /* SBUChannelSettingsChannelInfoView.swift */, - ); - path = View; - sourceTree = ""; - }; - 7B9DEDA2978C11A7877A4AD3 /* GroupBannedUserList */ = { + 7A44DE816094758AD368638D /* MessageInput */ = { isa = PBXGroup; children = ( - 36D398420F97BA15C888FA6E /* GroupBannedUserListView.swift */, - 0B70536649E7147BA12EAED3 /* GroupBannedUserListView+Item.swift */, - 6681789D0A58D7A83BE74A27 /* GroupBannedUserListView+SubViewBuilder.swift */, - 2D5AFECAA4BF9BA8AD3B0F71 /* GroupBannedUserListView+ViewConverter.swift */, - 4A4CEA2BFA758EDB71D239B1 /* ViewConverters */, + 764BFC79756B1BCCE4ACB207 /* SBUMentionLimitGuideCell.swift */, + B4A0BB7D655128684E76A5B2 /* SBUMessageInputMode.swift */, + 830DF49F679C52EADB4D45B6 /* SBUMessageInputView.swift */, + C26C7227DB3F3D547F68EFB0 /* SBUQuoteMessageInputView.swift */, + AF68890BEBB702CC9ED09C98 /* SBUSuggestedMentionList.swift */, + A88A555CB056D67F21C4D086 /* ViewParams */, ); - path = GroupBannedUserList; + path = MessageInput; sourceTree = ""; }; 7BA3E76079F43B2CD640F5DE /* View */ = { @@ -4339,14 +4396,12 @@ path = View; sourceTree = ""; }; - 7C1BA31876EA32F00CC45579 /* ChannelList */ = { + 7C3A486FA9CC087B271956F6 /* ChannelSettingItem */ = { isa = PBXGroup; children = ( - 27C26C3082D49E50ADAB0561 /* SBUBaseChannelListViewModel.swift */, - 070A17548A8DF7AF1500579B /* SBUGroupChannelListViewModel.swift */, - F35CD8BA9042B97652CACABA /* SBUOpenChannelListViewModel.swift */, + 587C70B610EC30D8522A8304 /* SBUChannelSettingItem.swift */, ); - path = ChannelList; + path = ChannelSettingItem; sourceTree = ""; }; 7CCB543FEB976094592362A9 /* Header */ = { @@ -4361,26 +4416,35 @@ path = Header; sourceTree = ""; }; - 7CCDE7811E6BD55D179F3FD1 /* ViewConverters */ = { + 7D28589BD19D6B72C0D47546 /* Builder */ = { isa = PBXGroup; children = ( - 053C0919C7CAED665251B6BA /* GroupChannelSettingsViewConverter.Header.swift */, - 8A4F7A4428AA6840190A27E2 /* GroupChannelSettingsViewConverter.List.swift */, - 9642EB6B731C9449EF95384D /* GroupChannelSettingsViewConverter.swift */, - 4CF215E5C5EAE38BCDB732CD /* SBUGroupChannelSettingCell+SwiftUI.swift */, - AEB9F6769BE111DFA1D6A0D1 /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift */, - 98037A186B2F6815C6BC45CD /* SBUGroupChannelSettingsModule.List+SwiftUI.swift */, + 279B677541AB48613E5A2EA8 /* CustomOpenChannelSettings.SubView.Builder.moderations.swift */, + 2EE881D701BE62C2C5A1297C /* CustomOpenChannelSettings.SubView.Builder.userList.swift */, ); - path = ViewConverters; + path = Builder; sourceTree = ""; }; - 7D28589BD19D6B72C0D47546 /* Builder */ = { + 7DAB15BF254D369416D19C38 /* Cell */ = { isa = PBXGroup; children = ( - 279B677541AB48613E5A2EA8 /* CustomOpenChannelSettings.SubView.Builder.moderations.swift */, - 2EE881D701BE62C2C5A1297C /* CustomOpenChannelSettings.SubView.Builder.userList.swift */, + C5A04F4ED104E23B61B85318 /* SBUBaseChannelSettingCell.swift */, + 82D516D15DFAD9E9EEC5AA3D /* SBUGroupChannelSettingCell.swift */, + 5BE9CE19D2E6FB9CC0276345 /* SBUModerationCell.swift */, + 4355FC0431F98C7660BB7AAB /* SBUOpenChannelSettingCell.swift */, ); - path = Builder; + path = Cell; + sourceTree = ""; + }; + 7DF35F273E07DAE1D557E556 /* ChannelSettings */ = { + isa = PBXGroup; + children = ( + BE130EF4A36F3ADFE7007505 /* SBUBaseChannelSettingsViewModel.swift */, + 18FD3B37FC9DE267350E60D6 /* SBUGroupChannelSettingsViewModel.swift */, + A280E51C52241837A38F05CB /* SBUModerationsViewModel.swift */, + 2A62CCCCB59301329BD70E3D /* SBUOpenChannelSettingsViewModel.swift */, + ); + path = ChannelSettings; sourceTree = ""; }; 7E0D94CC6ACDD295DD3EF2C8 /* View */ = { @@ -4400,30 +4464,32 @@ path = List; sourceTree = ""; }; - 7F31826B26DDDD70B15B5413 /* OpenParticipantList */ = { + 7F563E19B8D94629196C3B6E /* CellView */ = { isa = PBXGroup; children = ( - 2051F6EC7AA67803BA3D91FC /* OpenParticipantListView.swift */, - 1992BFA4DDDB1636ACFF4A97 /* OpenParticipantListView+Item.swift */, - AAAF55460E9B55A08425A596 /* OpenParticipantListView+SubViewBuilder.swift */, - 12DC37AE9F9A2EAAB346B524 /* OpenParticipantListView+ViewConverter.swift */, - A01055D998BBE77966D1DA2D /* ViewConverters */, + AB2CBA09DA24007F0E5C877F /* SBULinkClickableTextView.swift */, + A57520D9A1D02AE25101EACD /* SBUMarkdownTransfer.swift */, + 744D3897AF413516BB6A02CB /* SBUMessageDateView.swift */, + C3AD5EEF2606A62F9F0CD9E2 /* SBUMessageProfileView.swift */, + F52098C95DFA4A3CBB23C61B /* SBUMessageStateView.swift */, + D6E8137AEC2C6412832EEF1E /* SBUMessageWebView.swift */, + 2E9AABB7CE646ADCDF873887 /* SBUNotificationTimelineView.swift */, + 6B424207542E1A82DAC82A0D /* SBUOpenChannelMessageWebView.swift */, + B07065B5EEFA8858ADAD76CA /* SBUSelectableStackView.swift */, + 608274ACB42DDAE6A5976FC6 /* SBUUserMessageTextView.swift */, + 08C31448CE461810A569DE1E /* SBUUserNameView.swift */, ); - path = OpenParticipantList; + path = CellView; sourceTree = ""; }; - 80E3BBF58866133C23FF50E4 /* Channel */ = { + 8061A218333E238C622D0024 /* Chat */ = { isa = PBXGroup; children = ( - 26570397B1DC53048CF4E0D0 /* SBUBaseChannelModule.Header.swift */, - C322F14245229C7D8D078D67 /* SBUBaseChannelModule.Input.swift */, - 74A2D25905D7CC24CCE2D72C /* SBUBaseChannelModule.List.swift */, - 5F1E6CC210604D9FFC1F3234 /* SBUBaseChannelModule.swift */, - D08FA5C809028E456042B770 /* GroupChannel */, - 75D3C8F6310558F0DA3A8CB0 /* NotificationChannel */, - 9728FF9451660D9B37FA0979 /* OpenChannel */, + BDEE4A85341548A38E5EB50C /* SBUChatNotificationChannelModule.Header.swift */, + DD29661D82CBA8D0E3513C8D /* SBUChatNotificationChannelModule.List.swift */, + D8EA593C614B0BDD8E1FA2C8 /* SBUChatNotificationChannelModule.swift */, ); - path = Channel; + path = Chat; sourceTree = ""; }; 816961F4F9E38BAE2471952D /* View */ = { @@ -4435,41 +4501,15 @@ path = View; sourceTree = ""; }; - 81AB0BD39153E969F3B9EF34 /* FileViewer */ = { - isa = PBXGroup; - children = ( - E6541DB78921410A46EA2506 /* SBUFileViewController.swift */, - ); - path = FileViewer; - sourceTree = ""; - }; - 81B8DE36E827F506EFC715F8 /* MessageSearch */ = { - isa = PBXGroup; - children = ( - 6BBFC36107564B847F7FE03B /* SBUMessageSearchModule.Header.swift */, - B37E21BC8F9E14B7F17F08BB /* SBUMessageSearchModule.List.swift */, - 49511A48940E5542A4C0F5FD /* SBUMessageSearchModule.swift */, - ); - path = MessageSearch; - sourceTree = ""; - }; - 823917E40696BCECAD41B1E4 /* ViewConverters */ = { + 82019BCC3DB69FA856E34E3E /* ViewConverters */ = { isa = PBXGroup; children = ( - 3575D8324F8DCEC741A02E9C /* MessageThreadViewConverter.Header.swift */, - AD56A02381EBFBDFB56FF9D7 /* MessageThreadViewConverter.Input.swift */, - 487AD77A600D4D0BAC851314 /* MessageThreadViewConverter.List.swift */, - EA9A5B0A5DE2C459A65410DC /* MessageThreadViewConverter.ParentInfo.swift */, - 9C2574D3E04FB26DBF76ED58 /* MessageThreadViewConverter.swift */, - A039F4C3599EE466CF9B9233 /* SBUBaseMessageCell.MessageThread+SwiftUI.swift */, - B1A85D27D8C3E08D0B4BF1C9 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift */, - 61C267590CEE26C18694C591 /* SBUMessageThreadInputView+SwiftUI.swift */, - 85DBC0A4BA3AD7B3625F04F4 /* SBUMessageThreadModule.Header+SwiftUI.swift */, - 05328E6371DCAEDAEF7BB16A /* SBUMessageThreadModule.Input+SwiftUI.swift */, - A47631C573A77043D1C5F868 /* SBUMessageThreadModule.List+SwiftUI.swift */, - 1CE8943E2D24A159FAE8A666 /* SBUMessageThreadTitleView+SwiftUI.swift */, - 1956667B2BEFE9115DC6BDAE /* SBUMessageThreadViewController.SwiftUI.swift */, - 1B4A8280119033D9FB86B458 /* SBUParentMessageInfoView+SwiftUI.swift */, + 68438B681D10DDC232C3D9B4 /* OpenParticipantListViewConverter.Header.swift */, + 3564A850E6E29401E0BE3E5A /* OpenParticipantListViewConverter.List.swift */, + EE8F91080D5B149513B0FF6A /* OpenParticipantListViewConverter.swift */, + 2FEFD91414F95FB42FCF2FB1 /* SBUOpenUserListModule.Header+SwiftUI.swift */, + 6A3D23ECF381EA3D28AAD871 /* SBUOpenUserListModule.List+SwiftUI.swift */, + 6CAACF7915BF5F47DF2D444E /* SBUOpenUserListUserCell+SwiftUI.swift */, ); path = ViewConverters; sourceTree = ""; @@ -4484,46 +4524,39 @@ path = CreateOpenChannel; sourceTree = ""; }; - 83A207899B0E5651C83134F7 /* Moderations */ = { + 835F158D36A9025D2526EFA2 /* ViewConverters */ = { isa = PBXGroup; children = ( - B23C27311B45D3C9124E9EC8 /* SBUModerationsModule.Deprecated.swift */, - ); - path = Moderations; - sourceTree = ""; - }; - 8409CB8409688833AF1C464C /* ViewConverters */ = { - isa = PBXGroup; - children = ( - BC85F62E529A705813ED5671 /* GroupMutedMemberListViewConverter.Header.swift */, - 96CE24EEEC3A06E40F7874C9 /* GroupMutedMemberListViewConverter.List.swift */, - D9349402FEC3ACCC843C056E /* GroupMutedMemberListViewConverter.swift */, - 5612F8CEF1CBD9C4CD18E21A /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift */, - F996C7F4D29C1645E1465E33 /* SBUGroupMutedMemberListModule.List+SwiftUI.swift */, - DD198E6C9A69D0C4810F6C0F /* SBUGroupMutedMemberListUserCell+SwiftUI.swift */, + D2AECC85EB8D47720009CB4A /* GroupBannedUserListViewConverter.Header.swift */, + ECDE3327C779F78C5CA0DC65 /* GroupBannedUserListViewConverter.List.swift */, + 3193B2D263F3D9CA56150766 /* GroupBannedUserListViewConverter.swift */, + 6E96A78E503C25F929F51F29 /* SBUGroupBannedUserListModule.Header+SwiftUI.swift */, + 58DC541DD17CED0D33F79128 /* SBUGroupBannedUserListModule.List+SwiftUI.swift */, + 3CA1FC5D1795A64974F5421A /* SBUGroupBannedUserListUserCell+SwiftUI.swift */, ); path = ViewConverters; sourceTree = ""; }; - 84E7F01CCA13CF781F309FA1 /* ViewModel */ = { + 83DD2714A97C13F047E625B3 /* Feedback */ = { isa = PBXGroup; children = ( - 926322E643B26A93BE240616 /* SBUMessageWebViewModel.swift */, - 2AB52183CDCA494948E5976E /* SBUUserMessageTextViewModel.swift */, + EE0E3266C8A26B645EE82DB8 /* SBUFeedbackView.swift */, + 9D0CE5D19096B1C1D8766F21 /* SBUFeedbackViewParams.swift */, ); - path = ViewModel; + path = Feedback; sourceTree = ""; }; - 864CF6DF200E34DE7762FA7F /* OpenBannedUserList */ = { + 83E9CFCE5DC6C100C327E7BB /* CreateOpenChannel */ = { isa = PBXGroup; children = ( - FDE68F5000CAD06B280FC70C /* OpenBannedUserListView.swift */, - BF2C918C951707F9AC84EA4F /* OpenBannedUserListView+Item.swift */, - 57F7C0D861D9733D927D60AB /* OpenBannedUserListView+SubViewBuilder.swift */, - 051BED79FDD0D9A17F350838 /* OpenBannedUserListView+ViewConverter.swift */, - 4288822841421C796CF81D5E /* ViewConverters */, + 4AF0897805380BAF7AD8859C /* CreateOpenChannelView.swift */, + 0409D70B90128508F58134CF /* CreateOpenChannelView+Item.swift */, + 4E179F88E8C865DA3B3C80BD /* CreateOpenChannelView+SubViewBuilder.swift */, + 92F8C302415A0DA76BAE7815 /* CreateOpenChannelView+ViewConverter.swift */, + 4501508FDCD8E6900C33668C /* CreateOpenChannelViewProvider.swift */, + 4C7DB99359F74A79BF6612F8 /* ViewConverters */, ); - path = OpenBannedUserList; + path = CreateOpenChannel; sourceTree = ""; }; 8662AB9DC522CFA3BF3AEB8C /* Header */ = { @@ -4539,16 +4572,6 @@ path = Header; sourceTree = ""; }; - 86742C5016D873B75483C6E0 /* GroupChannel */ = { - isa = PBXGroup; - children = ( - 459A13CFDD327E9181AE2F5F /* SBUGroupChannelSettingsModule.Header.swift */, - CB21C648253FAC1AE4DF7C2A /* SBUGroupChannelSettingsModule.List.swift */, - 8D19ADB444964278B6E24246 /* SBUGroupChannelSettingsModule.swift */, - ); - path = GroupChannel; - sourceTree = ""; - }; 873DA741B33920F495398F2D /* ViewConverter */ = { isa = PBXGroup; children = ( @@ -4566,23 +4589,28 @@ path = SubView; sourceTree = ""; }; - 88CBC51D02C7A3F792A9F95E /* Custom */ = { + 87D201D0D13A7685F1C6702C /* Resource */ = { isa = PBXGroup; children = ( - A6B05764304DFF28CA5393AA /* CustomTheme.FontSet.Custom.Main.swift */, + D250660811AF42D876E15FA9 /* Assets.xcassets */, ); - path = Custom; + path = Resource; sourceTree = ""; }; - 88FD31BD05C911CA3401071A /* ChannelSettings */ = { + 8853BDC936388F5C4C15F784 /* CreateChannel */ = { isa = PBXGroup; children = ( - DEFC8D070D3FD13797007DD2 /* SBUBaseChannelSettingsViewModel.swift */, - 16B94B84000BF8542CAE6747 /* SBUGroupChannelSettingsViewModel.swift */, - C8CA206B4B29BAF26852CB29 /* SBUModerationsViewModel.swift */, - 8D5FA8F827F8A99D242C01C7 /* SBUOpenChannelSettingsViewModel.swift */, + C14904CE37235FCDF0FF6ACD /* SBUCreateChannelViewController.Deprecated.swift */, ); - path = ChannelSettings; + path = CreateChannel; + sourceTree = ""; + }; + 88CBC51D02C7A3F792A9F95E /* Custom */ = { + isa = PBXGroup; + children = ( + A6B05764304DFF28CA5393AA /* CustomTheme.FontSet.Custom.Main.swift */, + ); + path = Custom; sourceTree = ""; }; 8AB22BA8BB01650AE69C6A0B /* List */ = { @@ -4593,20 +4621,20 @@ path = List; sourceTree = ""; }; - 8ADE6498B92A03CB8BD56443 /* UserList */ = { + 8AE51A0E28B36B20AF21C743 /* ViewProvider */ = { isa = PBXGroup; children = ( - BBE02207F2AC34710E9F2A41 /* SBUUserListViewController.swift */, + 20B52D131C6D75296798238F /* CustomGroupChannel.SwiftUI.View.ViewProvider.swift */, ); - path = UserList; + path = ViewProvider; sourceTree = ""; }; - 8AF775560DD8E3D23A9438E9 /* Cell */ = { + 8C014842FD198022179F2AEF /* ChannelList */ = { isa = PBXGroup; children = ( - 53E511BD6CE441242E39D368 /* SBUChannelPushSettingCell.swift */, + A724FC169EF60661FE55A578 /* SBUChannelListViewController.Deprecated.swift */, ); - path = Cell; + path = ChannelList; sourceTree = ""; }; 8DAB9E936D8418659534EA92 /* Header */ = { @@ -4619,6 +4647,14 @@ path = Header; sourceTree = ""; }; + 8E05E0BE99114C53CE4B5E55 /* NotificationSettings */ = { + isa = PBXGroup; + children = ( + A0D6D1EDAD29575916B5BE29 /* SBUGroupChannelPushSettingsViewModel.swift */, + ); + path = NotificationSettings; + sourceTree = ""; + }; 8EA13B6F17B06EF8FD167EB3 /* List */ = { isa = PBXGroup; children = ( @@ -4627,6 +4663,18 @@ path = List; sourceTree = ""; }; + 8EC4534EC2688DFEFA089DB4 /* OpenChannel */ = { + isa = PBXGroup; + children = ( + 3F05697C440446392E577719 /* SBUOpenChannelModule.Header.swift */, + 92074159434417ECFA4275EE /* SBUOpenChannelModule.Input.swift */, + 666D5EED292A8388ADBD01E3 /* SBUOpenChannelModule.List.swift */, + F4D4EB006F53EF06F2BA27A2 /* SBUOpenChannelModule.Media.swift */, + 953E1A70757DE741732BA909 /* SBUOpenChannelModule.swift */, + ); + path = OpenChannel; + sourceTree = ""; + }; 8EDF7A45D76D5A1442A6B7FB /* GroupChannelList */ = { isa = PBXGroup; children = ( @@ -4634,6 +4682,7 @@ F941DF8DA529D9B503FC8EE3 /* SubView */, 369D640A6B2265FDA9C95CC6 /* SwiftUI */, D7DA8666256ADB2BE36019B1 /* ViewConverter */, + 71D1B26875E76A58D4D372EE /* ViewProvider */, ); path = GroupChannelList; sourceTree = ""; @@ -4648,16 +4697,14 @@ path = Header; sourceTree = ""; }; - 8F1B537A96F975F503D2D6C2 /* ViewConverters */ = { + 8F1839CB3BAB86C1229C08BD /* ChannelList */ = { isa = PBXGroup; children = ( - D9794223D75D07919015D20B /* OpenChannelSettingsViewConverter.Header.swift */, - E473AE77FEB63622BA2CE73E /* OpenChannelSettingsViewConverter.List.swift */, - EE2A90E5736F2795003DC13E /* OpenChannelSettingsViewConverter.swift */, - 5ECC1263CB743FBD32569570 /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift */, - 41DF87515C28078D54D8ED88 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift */, + 31220D4260D422D89BA59FD3 /* SBUBaseChannelListViewModel.swift */, + 9B2C00F284587D8677219F4A /* SBUGroupChannelListViewModel.swift */, + E6C77D06D3443161CF556779 /* SBUOpenChannelListViewModel.swift */, ); - path = ViewConverters; + path = ChannelList; sourceTree = ""; }; 8F367A5BA5694A0F9BF9B107 /* Custom */ = { @@ -4668,58 +4715,60 @@ path = Custom; sourceTree = ""; }; - 9004327AAC7327A6449173F1 /* OpenChannel */ = { + 8FF8630283EF0AB6256E5C57 /* UserList */ = { isa = PBXGroup; children = ( - A417F007B9CB1963D0EEAF4D /* SBUOpenChannelSettingsModule.Header.swift */, - 4558C00951E40E0BFB0ADB26 /* SBUOpenChannelSettingsModule.List.swift */, - C11906C6C1DC0D52EC28F0D0 /* SBUOpenChannelSettingsModule.swift */, + 7301F42637EF67DDD07821CF /* SBUUserListViewController.swift */, ); - path = OpenChannel; + path = UserList; sourceTree = ""; }; - 90523FBD74F1C43AD6D3465F /* MessageSearch */ = { + 9053EA2B881128C5485F21DD /* Menu */ = { isa = PBXGroup; children = ( - 27093994AF106EAB97B7F24D /* SBUMessageSearchModule.Deprecated.swift */, + 77572D02FFF2252D6380AA76 /* SBUBottomSheetController.swift */, + F8C4831068F0F117DDA51E76 /* SBUMenuCell.swift */, + 6869251780957A520939FB48 /* SBUMenuSheetViewController.swift */, + 31EBBEC705350486B5A9DBC6 /* SBUMenuView.swift */, ); - path = MessageSearch; + path = Menu; sourceTree = ""; }; - 90C49DC8F459C3F7477CFBB8 /* ViewParams */ = { + 90589FA80DDE7E18BA6DB91F /* ViewConverters */ = { isa = PBXGroup; children = ( - D86D4D360EBE5B44F0D0606D /* SBUSuggestedReplyViewParams.swift */, + 1DC014816EBFF2C90B439FEF /* OpenBannedUserListViewConverter.Header.swift */, + 5E136559F51500BE7524DCA9 /* OpenBannedUserListViewConverter.List.swift */, + B79650F5C408244AF34B5DA1 /* OpenBannedUserListViewConverter.swift */, + 421321AB71FAF7684718DD97 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift */, + CEAD608897F9DE73D59EB1C9 /* SBUOpenBannedUserListModule.List+SwiftUI.swift */, + 934D088DA1735729346CE8C0 /* SBUOpenBannedUserListUserCell+SwiftUI.swift */, ); - path = ViewParams; + path = ViewConverters; sourceTree = ""; }; - 91FF8520C435D3CACA86F75A /* NotificationChannel */ = { + 90873467F74670B85A783466 /* User */ = { isa = PBXGroup; children = ( - 3F411E990FA74EB4C7BD7027 /* SBUChatNotificationCell.swift */, - 78DC43005F3DE461ADE2DEAA /* SBUFeedNotificationCell.swift */, - 13DE0F9AF0C8495874233F35 /* SBUNotificationCell.swift */, + 59C00249475970C2ACE48F80 /* SBUUserProfileView.swift */, ); - path = NotificationChannel; + path = User; sourceTree = ""; }; - 9346A9F29540461E547CD87B /* SwiftUI */ = { + 916AB2A9BA3612FB51A82BD0 /* Moderations */ = { isa = PBXGroup; children = ( - C0839A62D5F8AFCAA3D0694C /* View */, + 33552F4E4E45108163CF3CAC /* SBUModerationsViewController.swift */, ); - path = SwiftUI; + path = Moderations; sourceTree = ""; }; - 93EDA3B5F459BDA802AE5611 /* Util */ = { + 9346A9F29540461E547CD87B /* SwiftUI */ = { isa = PBXGroup; children = ( - 19CC6B675B71533BB7EFA604 /* Closure.swift */, - A43C491A5F4F3DC54D841EB5 /* HandlerSet.swift */, - 6FDEE72ED520123188DB93FF /* SBULazyView.swift */, + C0839A62D5F8AFCAA3D0694C /* View */, ); - path = Util; + path = SwiftUI; sourceTree = ""; }; 9450C3973B172BE5EE88D23C /* Builder */ = { @@ -4731,17 +4780,6 @@ path = Builder; sourceTree = ""; }; - 946BFD2742D5674FA8CEEF28 /* Menu */ = { - isa = PBXGroup; - children = ( - E05180B4571B1F3B9A4BA50C /* SBUBottomSheetController.swift */, - 45FA71D8C8152131EDE22583 /* SBUMenuCell.swift */, - AFF25F8EC9716847344276B0 /* SBUMenuSheetViewController.swift */, - 838C450577B1005585D4F38E /* SBUMenuView.swift */, - ); - path = Menu; - sourceTree = ""; - }; 946CB3FBE0747EB6E5729C46 /* Header */ = { isa = PBXGroup; children = ( @@ -4760,6 +4798,45 @@ path = SubView; sourceTree = ""; }; + 950EAAA7218B686254793360 /* SubViews */ = { + isa = PBXGroup; + children = ( + 4295DC2364062B88F929D80E /* SBUMessageFormChipView.swift */, + ); + path = SubViews; + sourceTree = ""; + }; + 95393EDEEFC1610D96766953 /* KeyFunctions */ = { + isa = PBXGroup; + children = ( + 57A401CDC2B680DFFE8092E7 /* CreateGroupChannel */, + 83E9CFCE5DC6C100C327E7BB /* CreateOpenChannel */, + 405291E3A663F0C8D579CD7A /* GroupBannedUserList */, + 2D2F6EF9D8D2EBB05BF3E580 /* GroupChannel */, + 429E843624E052A1AFD3D4E7 /* GroupChannelList */, + 98B4F77BA173917314374897 /* GroupChannelPushSettings */, + D1A4ED7F0D44F0E5A0C29A3A /* GroupChannelRegisterOperator */, + D1B95A327BC7751095E44886 /* GroupChannelSettings */, + CE5AC02368FDB474F92E9F9B /* GroupMemberList */, + DB970A3EAF5F100E597AF721 /* GroupModerations */, + D23A41D38C239063E793BD4B /* GroupMutedMemberList */, + 14BC1FAA825087220F1B5928 /* GroupOperatorList */, + AFC02CA5C54A45335C20074D /* InviteUser */, + BF494D350F4BD27492ECB1F0 /* MessageSearch */, + 144C41F1981091BBD0DB86D7 /* MessageThread */, + EF23550B53A6A76D4649E8B0 /* OpenBannedUserList */, + 027354120503B8D3C12E122A /* OpenChannel */, + 4E339E16363816705BB2918D /* OpenChannelList */, + B2557C545E2870869FC5AA80 /* OpenChannelRegisterOperator */, + 135615028119E48474B428F8 /* OpenChannelSettings */, + C323011F5F0CE8FE47061817 /* OpenModerations */, + F090EFE733C66414AFC3EA77 /* OpenMutedParticipantList */, + 20B70BDEB3053CC5CD50C1C8 /* OpenOperatorList */, + 1BD6603624266543FC29960A /* OpenParticipantList */, + ); + path = KeyFunctions; + sourceTree = ""; + }; 96AF012DEF99BE2533533E62 /* Header */ = { isa = PBXGroup; children = ( @@ -4770,51 +4847,50 @@ path = Header; sourceTree = ""; }; - 9728FF9451660D9B37FA0979 /* OpenChannel */ = { - isa = PBXGroup; - children = ( - EFF7F3AFE50A393A18343E1D /* SBUOpenChannelModule.Header.swift */, - 630659BAAC01FBD1371A29F5 /* SBUOpenChannelModule.Input.swift */, - A9E52D0CF1A2746B74AE93F2 /* SBUOpenChannelModule.List.swift */, - 25858342E4D2B978B8BAD861 /* SBUOpenChannelModule.Media.swift */, - 4B823235003718792C817309 /* SBUOpenChannelModule.swift */, + 978E87D5925265AF43371E1B /* Channel */ = { + isa = PBXGroup; + children = ( + 446D630F304F4592542988D1 /* SBUBaseChannelViewController.Keyboard.swift */, + B01828BC5F31C8FA805FB0AA /* SBUBaseChannelViewController.swift */, + 8D4B7768EB6324A2952EF8E3 /* SBUChatNotificationChannelViewController.swift */, + 45AE9457F2764E673A9408D9 /* SBUFeedNotificationChannelViewController.swift */, + B0ED60E6DBA9AF470E3DB48B /* SBUGroupChannelViewController.swift */, + 803819597504B510729CE67A /* SBUOpenChannelViewController.swift */, + 5ED8199C1A718295D452C9FE /* CategoryFilterCell */, + 7F563E19B8D94629196C3B6E /* CellView */, + A00F1531A744306E9CF9FD1D /* ChannelStateBanner */, + 723B758A4E64701846B6AF7A /* FileViewer */, + A1A1A01A0D4F2347CEE59B86 /* Header */, + B327C0E7FDE9796632AB7A6F /* Media */, + 1AEFB90DEAD838E24EBFB5B4 /* MessageCell */, + 7A44DE816094758AD368638D /* MessageInput */, + E35EDEE8E4D9C33C42E8BB13 /* NewMessageInfo */, + 3E628D626329D903CA7D429A /* Reaction */, + 373C5169F17F06D91EC69D32 /* ScrollBottomView */, + 21D2D4EB42BAC67F162DC3B9 /* ViewModel */, ); - path = OpenChannel; + path = Channel; sourceTree = ""; }; - 9746CAC1E63BA22614AC01A4 /* GroupChannelPushSettings */ = { + 98B4F77BA173917314374897 /* GroupChannelPushSettings */ = { isa = PBXGroup; children = ( - 19D36786FC47C674BC286A36 /* GroupChannelPushSettingsView.swift */, - 574826B35D2867EBF562685B /* GroupChannelPushSettingsView+Item.swift */, - F0B4A24D18198AD3FC6A6896 /* GroupChannelPushSettingsView+SubViewBuilder.swift */, - 015DF3CD2805DA3FED653BA8 /* GroupChannelPushSettingsView+ViewConverter.swift */, - 59AA5667F5A450DB004A8060 /* ViewConverters */, + 95CE7A7C3AD04AA4DC13DECB /* GroupChannelPushSettingsView.swift */, + B037A4E8EC8A7B9131F03A16 /* GroupChannelPushSettingsView+Item.swift */, + 76BBE5BEB476721101C05579 /* GroupChannelPushSettingsView+SubViewBuilder.swift */, + D2A9680190548D628D0D71B0 /* GroupChannelPushSettingsView+ViewConverter.swift */, + 2282B01F493BF02C9708B2F8 /* GroupChannelPushSettingsViewProvider.swift */, + 11E583AA76DC9F12CBD78C2B /* ViewConverters */, ); path = GroupChannelPushSettings; sourceTree = ""; }; - 97A2D784B3585E5384C05B11 /* Constant */ = { - isa = PBXGroup; - children = ( - 4C0A2D80C7306781D308DF50 /* SBUConstant.swift */, - A0A6460B6ABA537A9DF9E077 /* SBUDateFormatSet.swift */, - 599E3037238837AC8467C033 /* SBUStringSet.Deprecated.swift */, - 91658F3FA5C4F2E9DB896DEB /* SBUStringSet.swift */, - ); - path = Constant; - sourceTree = ""; - }; - 9A48CD3DAE53A3FE3194E7D6 /* OpenOperatorList */ = { + 98CB950F6FCBE52F0FA80B16 /* CustomView */ = { isa = PBXGroup; children = ( - 4C33D8246AFE1AE05351D8CA /* OpenOperatorListView.swift */, - 76799FA15AA5786517BEF343 /* OpenOperatorListView+Item.swift */, - 08AE1C3D2DAF93702E8C3E6B /* OpenOperatorListView+SubViewBuilder.swift */, - E3BB215085699F6E89FF3F5D /* OpenOperatorListView+ViewConverter.swift */, - F4CFE4801B95A1CF73BCA630 /* ViewConverters */, + BDD4EB3C929D559F5D0D624E /* SBUExtendedMessagePayloadCustomViewFactory.swift */, ); - path = OpenOperatorList; + path = CustomView; sourceTree = ""; }; 9A6762AC2F4D5F208BF58D87 /* View */ = { @@ -4834,6 +4910,14 @@ path = Builder; sourceTree = ""; }; + 9B36B7073FBAB5677FA5A146 /* View */ = { + isa = PBXGroup; + children = ( + 71CDC288E01D00AB7B00DBCE /* SBUCreateChannelTypeSelector.swift */, + ); + path = View; + sourceTree = ""; + }; 9B629A88EDA8C1C392FFBEA6 /* ViewConverter */ = { isa = PBXGroup; children = ( @@ -4845,23 +4929,6 @@ path = ViewConverter; sourceTree = ""; }; - 9B6755A81901984FED695D31 /* NotificationSettings */ = { - isa = PBXGroup; - children = ( - 7D80E95EF57DDC3B50934217 /* SBUGroupChannelPushSettingsModule.Deprecated.swift */, - ); - path = NotificationSettings; - sourceTree = ""; - }; - 9B7B3C8AD13A16214ABDB40C /* Moderations */ = { - isa = PBXGroup; - children = ( - 8579E772B5F950377C00E855 /* SBUModerationsViewController.Deprecated.swift */, - 86392DB847368C4FDA9AEB72 /* SBUModerationsViewModel.Deprecated.swift */, - ); - path = Moderations; - sourceTree = ""; - }; 9B848886D5F352ADEF9F717D /* SwiftUI */ = { isa = PBXGroup; children = ( @@ -4870,24 +4937,24 @@ path = SwiftUI; sourceTree = ""; }; - 9BA7750F168C87FE3EC5A012 /* MessageTemplate */ = { + 9BE5F49D7E2466A0879FC00B /* SwiftUI */ = { isa = PBXGroup; children = ( - 823177EB22F1375CF161441D /* SBUMessageTemplate.swift */, - 39063555F313CC6989308367 /* Processor */, - D84BA29D057F15497864FB20 /* Renderer */, - 1CC533D44BA273811028A012 /* Syntax */, - A98C388E63EFC28F005FA585 /* Tester */, + A62C05581B9CEC968FDBE1B7 /* View */, ); - path = MessageTemplate; + path = SwiftUI; sourceTree = ""; }; - 9BE5F49D7E2466A0879FC00B /* SwiftUI */ = { + 9D521DAAB08CB0004CB3ADDE /* ViewConverters */ = { isa = PBXGroup; children = ( - A62C05581B9CEC968FDBE1B7 /* View */, + ADDA48DA43F534CAF86DA08A /* OpenModerationsViewConverter.Header.swift */, + 8F59F85ADF99A208A9C082B0 /* OpenModerationsViewConverter.List.swift */, + 40F84492490C7710F5A1A242 /* OpenModerationsViewConverter.swift */, + 0C51254CEED3C799BECECBBA /* SBUOpenModerationsModule.Header+SwiftUI.swift */, + 746FFA5F3A512F4DDD996282 /* SBUOpenModerationsModule.List+SwiftUI.swift */, ); - path = SwiftUI; + path = ViewConverters; sourceTree = ""; }; 9D6DE9CB44AB3DA4749D6CBA /* List */ = { @@ -4902,41 +4969,66 @@ path = List; sourceTree = ""; }; - 9F40563D7465D26B775DF83E /* UserList */ = { + 9F88D0726F99D7231D8FA69C /* Channel */ = { isa = PBXGroup; children = ( - 4C2633C1C6CBACCB2EA60472 /* SBUBaseSelectUserViewController.Deprecated.swift */, + 8806A58516400503B5D7EAA4 /* SBUBaseChannelModule.Deprecated.swift */, + 1A01964E8998FC11F82F7F27 /* SBUGroupChannelModule.Deprecated.swift */, + C155DD4B518BAA95DA93098F /* SBUOpenChannelModule.Deprecated.swift */, + 232A9BAD381710AE908B42E2 /* Notifications */, ); - path = UserList; + path = Channel; sourceTree = ""; }; - A01055D998BBE77966D1DA2D /* ViewConverters */ = { + A00F1531A744306E9CF9FD1D /* ChannelStateBanner */ = { isa = PBXGroup; children = ( - 844456744940B60FACF05B17 /* OpenParticipantListViewConverter.Header.swift */, - 0669C29C318DE47185F6859E /* OpenParticipantListViewConverter.List.swift */, - FD91A7FA49003653EAC40E13 /* OpenParticipantListViewConverter.swift */, - CDF5A13CCF666CC7179C7878 /* SBUOpenUserListModule.Header+SwiftUI.swift */, - 03998A9F377AFFC6FB0E69BA /* SBUOpenUserListModule.List+SwiftUI.swift */, - D60D97979BB0D61C336877D6 /* SBUOpenUserListUserCell+SwiftUI.swift */, + 3EBF8DBA8CDA504642F81845 /* SBUChannelStateBanner.swift */, ); - path = ViewConverters; + path = ChannelStateBanner; sourceTree = ""; }; - A049765FA220EB5BEC7401EF /* Common */ = { + A05A17C408DD714FD0697368 /* Media */ = { isa = PBXGroup; children = ( - 5FB98D6D00677001841E2CD1 /* SBUCommonModule.swift */, + 60E74E559F411EA5C8C39980 /* CustomOpenChannel.ViewConverter.Media.entireView.swift */, ); - path = Common; + path = Media; sourceTree = ""; }; - A05A17C408DD714FD0697368 /* Media */ = { + A1A1A01A0D4F2347CEE59B86 /* Header */ = { isa = PBXGroup; children = ( - 60E74E559F411EA5C8C39980 /* CustomOpenChannel.ViewConverter.Media.entireView.swift */, + BE88DD79EB597B50591F3AE4 /* SBUChannelInfoHeaderView.swift */, + 9AC6D3C982FEB244190F2493 /* SBUChannelTitleView.swift */, ); - path = Media; + path = Header; + sourceTree = ""; + }; + A1FFAB387774DBE8C9F1376C /* Views */ = { + isa = PBXGroup; + children = ( + 2D8E1428454BAB2823888AD1 /* SBUHorizontalSuggestedReplyOptionView.swift */, + DB6DB1D4C127ED23F83429E9 /* SBUHorizontalSuggestedReplyView.swift */, + 4AFA1BE5F8584D2F119CE1E3 /* SBUSimpleSuggestedReplyOptionView.swift */, + 83D46A1142AC3CC4D1396719 /* SBUSuggestedReplyOptionView.swift */, + 9E78C28530EB42B33B68C3C6 /* SBUSuggestedReplyView.swift */, + ADD3FAB38AE4AB7059250476 /* SBUVerticalSuggestedReplyView.swift */, + ); + path = Views; + sourceTree = ""; + }; + A218B79F9913B68CEACD222A /* ViewConverters */ = { + isa = PBXGroup; + children = ( + FA5E060A224E457A70D2C17C /* GroupMutedMemberListViewConverter.Header.swift */, + BFD44E420AECC052E968D1D2 /* GroupMutedMemberListViewConverter.List.swift */, + 8D48DFD3FF62BE218F62CA2C /* GroupMutedMemberListViewConverter.swift */, + B2BC4EA3D8CE0C395D945CF8 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift */, + CBC80E25FFD78206A507757A /* SBUGroupMutedMemberListModule.List+SwiftUI.swift */, + AF5228FB7BBC9672AE3637C5 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift */, + ); + path = ViewConverters; sourceTree = ""; }; A4A786F04DADB13E88C79109 /* ColorSet */ = { @@ -4947,27 +5039,21 @@ path = ColorSet; sourceTree = ""; }; - A62C05581B9CEC968FDBE1B7 /* View */ = { + A5B2F0823C0D1ACDCBBD09F2 /* Replies */ = { isa = PBXGroup; children = ( - 434BE19EF6D070299A1BBB96 /* CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift */, - FB93B3DEC8E153D6A8BFC160 /* CustomCreateOpenChannel.SwiftUI.View.Main.swift */, + 05EAE6B5A040463C2BCC6878 /* SBUQuotedBaseMessageViewParams.Deprecated.swift */, ); - path = View; + path = Replies; sourceTree = ""; }; - A63909874513E7398C217DD0 /* CacheManager */ = { + A62C05581B9CEC968FDBE1B7 /* View */ = { isa = PBXGroup; children = ( - E24BD1FBA414D2FCC2A2825F /* SBUCacheManager.Config.swift */, - 88E0D73102E23DDE1DAEDDF0 /* SBUCacheManager.File.swift */, - B7D26F2838B7D12D15885978 /* SBUCacheManager.Image.swift */, - C0DDF27516D888B54EA2559D /* SBUCacheManager.NotificationSetting.swift */, - 2EC18DF4ECCF42C69B1DE4E3 /* SBUCacheManager.swift */, - 3AD9EB3F40F9E5D40F9B5FAC /* SBUCacheManager.Template.swift */, - 027F5B8FFDDCA7C6C28E4BD7 /* SBUCacheManager.Version.swift */, + 434BE19EF6D070299A1BBB96 /* CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift */, + FB93B3DEC8E153D6A8BFC160 /* CustomCreateOpenChannel.SwiftUI.View.Main.swift */, ); - path = CacheManager; + path = View; sourceTree = ""; }; A6AD7E1A146A47A0F33AC445 /* Views */ = { @@ -4981,77 +5067,35 @@ path = Views; sourceTree = ""; }; - A7143A6C13B550E27EF4EB7F /* FontSet */ = { - isa = PBXGroup; - children = ( - 88CBC51D02C7A3F792A9F95E /* Custom */, - ); - path = FontSet; - sourceTree = ""; - }; - A7C2C17AB1DC5621537E7B4C /* Theme */ = { + A6DDAA4ED6FFED159D0F665A /* MessageCell */ = { isa = PBXGroup; children = ( - A64F81096C2DBE9610059AA9 /* ColorSet.swift */, - BD0FAD1E018EEBC665ACD0B6 /* FontSet.swift */, + 9BFA16874C98B8F5046EC5D6 /* SBUMessageCellConfiguration.swift */, ); - path = Theme; + path = MessageCell; sourceTree = ""; }; - A7DEADF1750E04F4F832EADF /* Media */ = { + A7143A6C13B550E27EF4EB7F /* FontSet */ = { isa = PBXGroup; children = ( - 94B6B99EE4914E2736C8042C /* SBUMediaView.swift */, + 88CBC51D02C7A3F792A9F95E /* Custom */, ); - path = Media; + path = FontSet; sourceTree = ""; }; - A85448583EEA5A14E01A509C /* View */ = { + A88A555CB056D67F21C4D086 /* ViewParams */ = { isa = PBXGroup; children = ( - 84E9EDEFC79A50C05C8D5C31 /* SBUBaseViewController.swift */, - 960030BBD4843C4DD078C35C /* SBUViewControllerSet.swift */, - 5B71D0B9AB321FE785DF7693 /* Channel */, - C5936CE7D4BE596342EB1F5B /* ChannelList */, - DBDF91D107548D777A8C3598 /* ChannelSettings */, - 1C7A063F8BE080086BAB4F8D /* Common */, - F7E86A7C3516F5EE0712A8B2 /* Life cycles */, - 603F6CCA87C123941424D100 /* MessageSearch */, - 6FD2259F7D73881DBA3DF577 /* MessageThread */, - BF70418839DF92C32009B432 /* Moderations */, - F62697598C554FC5507864B7 /* NotificationSettings */, - 23DDF9BCBA0027F87C42DF81 /* SelectUser */, - 8ADE6498B92A03CB8BD56443 /* UserList */, - D109A7E6AAEBDA73C95E5E5C /* VoiceNote */, + 195059F9729364314EB88550 /* SBUQuoteMessageInputViewParams.swift */, ); - path = View; + path = ViewParams; sourceTree = ""; }; A8C330E55A90BC3CCE209DC7 /* Sources */ = { isa = PBXGroup; children = ( - 06417874288D6FAD8D6C61E1 /* PrivacyInfo.xcprivacy */, - 9FAB9A2A0323D5A01103F169 /* SBUAvailable.swift */, - 0A4B1C1EC52CFF027D65EFA5 /* SBUGlobalCustomParams.swift */, - A8B980032E44E8D2CD11B79A /* SBUGlobals.swift */, - 2A72C6155A43F6C1095DF84B /* SendbirdUI.swift */, - 6A6D753D5D34A8538C6AF20D /* SendbirdUIKit.h */, - 48F39F715352BA623D592ADF /* Configuration */, - 97A2D784B3585E5384C05B11 /* Constant */, - 468B6AE90A221C3B64D76B2E /* Deprecated */, - D2651C38116DD90645B2DA17 /* Enums */, - D8E778BF58081A5D0C9E4DA2 /* Extension */, - 5FDD009EC649193BF202EE1B /* Manager */, - 9BA7750F168C87FE3EC5A012 /* MessageTemplate */, - E6C3AAB9BFE9E35C5F63F819 /* Model */, - 01F8391BCE93736ECA1D82AC /* Module */, - 2F0FC6252CF56EA4CA4E090C /* Protocol */, - F30ACDDDD345549DB8FEB9AE /* Resource */, - 46C329AA59391DC15F8F6EC0 /* SwiftUI */, - 69B2827C8B9D19CE53BB5178 /* Theme */, - AA24E2702ECE5B42050C7956 /* Util */, - A85448583EEA5A14E01A509C /* View */, - 34B6FDC78C332F783E947516 /* ViewModel */, + 14E5F439516ECB3C089C811B /* swiftui */, + CB6A8BC786C3454BFCEB281D /* uikit */, ); name = Sources; path = ../Sources; @@ -5065,37 +5109,52 @@ path = Builder; sourceTree = ""; }; - A98C388E63EFC28F005FA585 /* Tester */ = { + A9779DBC3ABC5BEFFBF2DC74 /* Common */ = { isa = PBXGroup; children = ( - 7FD3CDCCBBB8FB5E0C3164B8 /* MessageTemplateParserTest.swift */, - 1BD8C3C6E22B76ECEA6DC1DB /* MessageTemplateTestViewController.swift */, + 2B50481174F97B1EE25DA725 /* Sendbird.swift */, + EB9EAE40ED4B2267D13C0B8C /* Sendbird+Typealias.swift */, ); - path = Tester; + path = Common; sourceTree = ""; }; - A9D25F0225301983F9D56474 /* Channel */ = { + AA7E35C4FCBBC0B26CF2FD79 /* Theme */ = { isa = PBXGroup; children = ( - 7B361C809A4825F96490CCAA /* SBUBaseChannelModule.Deprecated.swift */, - 74CAA3A0343417CBC00C9A2D /* SBUGroupChannelModule.Deprecated.swift */, - C4B4928DCE8DCBA7C80D26C0 /* SBUOpenChannelModule.Deprecated.swift */, - DA9990DB8A90F6735EA3108E /* Notifications */, + E77E32C1CCB09ED19ED82DC8 /* SBUColorSet.swift */, + 08656A9709E292E482DFCDD3 /* SBUFontSet.swift */, + 8F787E65B4187FC92E0391AF /* SBUIconSet.swift */, + FCB7E275124DF45ADB981B0E /* SBUTheme.swift */, + D4348E39A20D96D16960C445 /* SBUTheme+Type.swift */, ); - path = Channel; + path = Theme; sourceTree = ""; }; - AA24E2702ECE5B42050C7956 /* Util */ = { + ACAF70995350920244D99BDD /* ScrollPostion */ = { isa = PBXGroup; children = ( - E65E8C83BAC9277CA63A5421 /* BlockingOperation.swift */, - 4A95670973E944B4C3A95416 /* SBUDebouncer.swift */, - D677AA356C4DC935016C176E /* SBULogger.swift */, - 9854C9F75B1B5DF2C5C09594 /* SBUMentionManager.swift */, - D53DD5D59B4099FF2491FD4E /* SBUPropertyWrapper.swift */, - 5D61ED359FBDCFE0760CF024 /* SBUUtils.swift */, + F953887FA77606336B478451 /* SBUScrollPostionConfiguration.swift */, ); - path = Util; + path = ScrollPostion; + sourceTree = ""; + }; + AE1445AC9B0B6A053DE08E1C /* ViewConverters */ = { + isa = PBXGroup; + children = ( + EA2A1DDA7731802AB5994AB5 /* OpenChannelViewConverter.Header.swift */, + B780F445346B319D875EBB26 /* OpenChannelViewConverter.Input.swift */, + 4B037D3D503D49A7A34573F5 /* OpenChannelViewConverter.List.swift */, + 8A907EC372E1A2032BF4721C /* OpenChannelViewConverter.swift */, + FF107290F4EB7C3FAD727570 /* SBUOpenChannelBaseMessageCell+SwiftUI.swift */, + 35B171FF6F71B428F421E126 /* SBUOpenChannelInputView+SwiftUI.swift */, + 030585AC870531AD9465859D /* SBUOpenChannelModule.Header+SwiftUI.swift */, + CE4DFFF0E46FAB0FDF0048EF /* SBUOpenChannelModule.Input+SwiftUI.swift */, + EBF7F15698BF3AB2B7C0B92A /* SBUOpenChannelModule.List+SwiftUI.swift */, + B490A5163E0F31829523A88C /* SBUOpenChannelTitleView+SwiftUI.swift */, + BD92AAE15AFE138AA4C1EEB6 /* SBUOpenChannelViewController+SwiftUI.swift */, + 68AE2F17C4A25E2EA1BC7A63 /* SBUOpenScrollBottomView+SwiftUI.swift */, + ); + path = ViewConverters; sourceTree = ""; }; AECDCD3D27CE7934847E7067 /* ViewConverter */ = { @@ -5107,6 +5166,14 @@ path = ViewConverter; sourceTree = ""; }; + AF27AFA54782A22874F2DCCC /* MessageCellParams */ = { + isa = PBXGroup; + children = ( + 3478D6F58D07B41B64C21B46 /* SBUBaseMessageCellParams.Deprecated.swift */, + ); + path = MessageCellParams; + sourceTree = ""; + }; AFB1696E764DC7827B085B5F /* Header */ = { isa = PBXGroup; children = ( @@ -5117,6 +5184,28 @@ path = Header; sourceTree = ""; }; + AFC02CA5C54A45335C20074D /* InviteUser */ = { + isa = PBXGroup; + children = ( + B041F9C56CD7C0C012E98950 /* InviteUserView.swift */, + 9D511342232983FBBE03516A /* InviteUserView+Item.swift */, + F1211AAEFCC66ABDC646D834 /* InviteUserView+SubViewBuilder.swift */, + 1CED8D3880DEF2156A3DB5CC /* InviteUserView+ViewConverter.swift */, + F406B0CC701411F859F4934A /* InviteUserViewProvider.swift */, + 4CB85E5D3E5C1E393CCE9794 /* ViewConverters */, + ); + path = InviteUser; + sourceTree = ""; + }; + B01CACD5DF8F0CB5D28C5C9D /* MessageSearch */ = { + isa = PBXGroup; + children = ( + 736D000D5C7D45CA1F4D9F3B /* SBUMessageSearchViewController.swift */, + 067FD04BDDE8A1BF361AF200 /* Cell */, + ); + path = MessageSearch; + sourceTree = ""; + }; B143B45FA5421E6CDF0C369A /* OpenModerations */ = { isa = PBXGroup; children = ( @@ -5127,118 +5216,128 @@ path = OpenModerations; sourceTree = ""; }; - B69C7B8396DEB232F2208CDD /* ViewConverter */ = { + B1973970C79F1A7BE63EC3EE /* CacheManager */ = { isa = PBXGroup; children = ( - 3CB84247974B638019E2C2B7 /* Header */, - FD8C122F8C1B40968801B60C /* List */, + 0BDD72D5B40E66A00F22358F /* SBUCacheManager.Config.swift */, + 183C845EEBFBD4DF24DBFAF5 /* SBUCacheManager.File.swift */, + 07C310E48146C5577ED9FBCA /* SBUCacheManager.Image.swift */, + 2D275616CF2FFE31313FF15B /* SBUCacheManager.NotificationSetting.swift */, + 5053C3F54CF82D69A26CC37B /* SBUCacheManager.swift */, + CB20C7C8D91A4FB6BE5BB00A /* SBUCacheManager.Template.swift */, + D7E4393E73BAF35A4ECF1541 /* SBUCacheManager.Version.swift */, ); - path = ViewConverter; + path = CacheManager; sourceTree = ""; }; - B7A5F4D6F64CBDB55E35CCD7 /* IconSet */ = { + B2557C545E2870869FC5AA80 /* OpenChannelRegisterOperator */ = { isa = PBXGroup; children = ( - 5FC5C1AE77DE2A38B7307021 /* Custom */, + F5B10A1CDEC20024D2B59210 /* OpenChannelRegisterOperatorView.swift */, + 6A7B7E1E88F1115AD78191C3 /* OpenChannelRegisterOperatorView+Item.swift */, + 2E3A3342AEA6256BC66D30A3 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift */, + 278A681D06BDAF42A5A4A6D6 /* OpenChannelRegisterOperatorView+ViewConverter.swift */, + BE11E602679B94F815434977 /* OpenChannelRegisterOperatorViewProvider.swift */, + 408876FBD39EDF3D40FB28D4 /* ViewConverters */, ); - path = IconSet; + path = OpenChannelRegisterOperator; sourceTree = ""; }; - B87FDDD8F7D0E6C17076FA2B /* ViewParams */ = { + B327C0E7FDE9796632AB7A6F /* Media */ = { isa = PBXGroup; children = ( - A4D6A060025AC392A913D587 /* SBUQuotedBaseMessageViewParams.swift */, + B2D1684E7E56CD1DC90FA733 /* SBUMediaView.swift */, ); - path = ViewParams; + path = Media; sourceTree = ""; }; - BA94FE259CBE2C0D3D1956BF /* MessageCell */ = { + B37C29E657BD494983A96819 /* Replies */ = { isa = PBXGroup; children = ( - 61852897DAE0358AD6BBDCA4 /* SBUMessageCellConfiguration.swift */, + B5CFC8E13C50AAE8AFF471AC /* SBUReplyConfiguration.swift */, ); - path = MessageCell; + path = Replies; sourceTree = ""; }; - BACCCD34F85E3A2919AC3DC5 /* SwiftUI */ = { + B69C7B8396DEB232F2208CDD /* ViewConverter */ = { isa = PBXGroup; children = ( - 79FFC3B182A4AD8B296B9CDE /* View */, + 3CB84247974B638019E2C2B7 /* Header */, + FD8C122F8C1B40968801B60C /* List */, ); - path = SwiftUI; + path = ViewConverter; sourceTree = ""; }; - BBA522B858545A851732FE37 /* ViewConverter */ = { + B7A5F4D6F64CBDB55E35CCD7 /* IconSet */ = { isa = PBXGroup; children = ( - 7231E6F9486A697A5DDB7126 /* Header */, - 4AEE6974976A38328574DEE4 /* Input */, - 77BA896294D8DFEA0DE5A50C /* List */, + 5FC5C1AE77DE2A38B7307021 /* Custom */, ); - path = ViewConverter; + path = IconSet; sourceTree = ""; }; - BBAF05FDD28ED6C97F7FE066 /* MessageCell */ = { + BAB718A27BAEB0EDAEA3C1F5 /* Params */ = { isa = PBXGroup; children = ( - 595CB34BBF4416DC0AA3CB28 /* SBUContentBaseMessageCell.Deprecated.swift */, - DEFBDFA49A46AA313952B13F /* MessageCellParams */, - BD706E2B81F6A802C0F0F85E /* Replies */, + 214A494A609C5A22C2BB8AA7 /* SBUFeedNotificationChannelViewParams.swift */, ); - path = MessageCell; + path = Params; sourceTree = ""; }; - BD1E90359B405024071FF19C /* Preview Content */ = { + BACCCD34F85E3A2919AC3DC5 /* SwiftUI */ = { isa = PBXGroup; children = ( - F1E04EDD53838E84619F3E17 /* Preview Assets.xcassets */, + 79FFC3B182A4AD8B296B9CDE /* View */, ); - path = "Preview Content"; + path = SwiftUI; sourceTree = ""; }; - BD706E2B81F6A802C0F0F85E /* Replies */ = { + BBA522B858545A851732FE37 /* ViewConverter */ = { isa = PBXGroup; children = ( - 15F63FC3018647E421EC68B1 /* SBUQuotedBaseMessageViewParams.Deprecated.swift */, + 7231E6F9486A697A5DDB7126 /* Header */, + 4AEE6974976A38328574DEE4 /* Input */, + 77BA896294D8DFEA0DE5A50C /* List */, ); - path = Replies; + path = ViewConverter; sourceTree = ""; }; - BF024F362C5F2B1974FFABE1 /* Chat */ = { + BD1E90359B405024071FF19C /* Preview Content */ = { isa = PBXGroup; children = ( - E2C6311A1B53F43110C9BC88 /* SBUChatNotificationChannelModule.Header.swift */, - 482ABAD59BE7C16F21111FAC /* SBUChatNotificationChannelModule.List.swift */, - B130A2EAD2252178E5063E37 /* SBUChatNotificationChannelModule.swift */, + F1E04EDD53838E84619F3E17 /* Preview Assets.xcassets */, ); - path = Chat; + path = "Preview Content"; sourceTree = ""; }; - BF266751A0408B5F15724910 /* Extension */ = { + BDA65EBB7B18CE14D60E960A /* UserList */ = { isa = PBXGroup; children = ( - C056C5CCBC515F1ABAA627C1 /* Color+Sendbird.swift */, - 42FDCEFB59A8DBF122F0523E /* UIFont+Sendbird.swift */, + FDA3D3D02D5E297D699CD2C2 /* SBUBaseSelectUserViewController.Deprecated.swift */, ); - path = Extension; + path = UserList; sourceTree = ""; }; - BF5F86BFE985AE40DAA3EFB2 /* Moderations */ = { + BE5C85731B14C8EC4219ADEF /* MessageForm */ = { isa = PBXGroup; children = ( - 9DEB237E4B180100712E7618 /* SBUModerationsModule.Header.swift */, - 41D90092595D82EE02099124 /* SBUModerationsModule.List.swift */, - D36259D49FBF122E1CC92591 /* SBUModerationsModule.swift */, + 02D6CAFA1B7C951E40A2C975 /* ViewParams */, + E335EDCB09D39F6F4B210D2D /* Views */, ); - path = Moderations; + path = MessageForm; sourceTree = ""; }; - BF70418839DF92C32009B432 /* Moderations */ = { + BF494D350F4BD27492ECB1F0 /* MessageSearch */ = { isa = PBXGroup; children = ( - 1500B8E9713683B07753569C /* SBUModerationsViewController.swift */, + 6EB65FAB29A17019E54AFA24 /* MessageSearchView.swift */, + DECFF1D9649B3B654288217B /* MessageSearchView+Item.swift */, + E1177BB4E92D600EED17C2C8 /* MessageSearchView+SubViewBuilder.swift */, + 210E248F9D2CF51D4B837AE2 /* MessageSearchView+ViewConverter.swift */, + 89CAF8C853F289E0DFFD3AE8 /* MessageSearchViewProvider.swift */, + 0717F782F27BCB508547FC16 /* ViewConverters */, ); - path = Moderations; + path = MessageSearch; sourceTree = ""; }; BF7B49A1319B044D32E0BEF7 /* ViewConverter */ = { @@ -5259,6 +5358,16 @@ path = ViewConverter; sourceTree = ""; }; + C0495D9451BF91562C688AB8 /* MessageSearch */ = { + isa = PBXGroup; + children = ( + E2409918FAB1E81ADAE21623 /* SBUMessageSearchModule.Header.swift */, + 2C4D064E91A746BEA570EA54 /* SBUMessageSearchModule.List.swift */, + DA8B78F1D3A60872891EB8E5 /* SBUMessageSearchModule.swift */, + ); + path = MessageSearch; + sourceTree = ""; + }; C05EE955396739FDA9C48C82 /* SwiftUI */ = { isa = PBXGroup; children = ( @@ -5287,6 +5396,49 @@ path = OpenChannel; sourceTree = ""; }; + C1680B664A04153DD205501D /* Protocol */ = { + isa = PBXGroup; + children = ( + 52CE2A507E7A42C725CCBE15 /* SwiftUIMessageInputInterface.swift */, + CE6D4B74FB8A576A0ED92AB0 /* ViewControllerTypeProtocol + swiftUI.swift */, + 4C8F2F5AE4133CDF039D4FDC /* ViewItemProtocol.swift */, + ); + path = Protocol; + sourceTree = ""; + }; + C3141836907B1D9097369FD1 /* Configuration */ = { + isa = PBXGroup; + children = ( + B7F704A16BB10D77C631E19A /* SBUConfig.Base.swift */, + CE5CDE3DA748B162A1898531 /* SBUConfig.CodingKeys.swift */, + F94CBE179EC28528B6D75C20 /* SBUConfig.Common.swift */, + 5FBA19E717B0FDA9B35A2D5F /* SBUConfig.GroupChannel.swift */, + 15BCA0CEA4BD6AC0AF9F5E93 /* SBUConfig.OpenChannel.swift */, + 2949F2DE8EFDD9154DC2E2E9 /* SBUConfig.swift */, + 3B7B872CDDEDEEA89964760E /* SBUConfigManager.swift */, + 2AFB3ABEC66B7B5DF2B1C6C1 /* SBUDashboardConfig.swift */, + 3589A259FC19999B30A989CF /* Mention */, + A6DDAA4ED6FFED159D0F665A /* MessageCell */, + B37C29E657BD494983A96819 /* Replies */, + ACAF70995350920244D99BDD /* ScrollPostion */, + E3AE60267A15D95E48BC9246 /* VoiceMessage */, + ); + path = Configuration; + sourceTree = ""; + }; + C323011F5F0CE8FE47061817 /* OpenModerations */ = { + isa = PBXGroup; + children = ( + D2A3BE2336B9819BFB36AD1E /* OpenModerationsView.swift */, + 17D4DB776814E712BA3D522E /* OpenModerationsView+Item.swift */, + 2ECACCFCA2492AB6CF181E9B /* OpenModerationsView+SubViewBuilder.swift */, + C61C960E362565B1258C1530 /* OpenModerationsView+ViewConverter.swift */, + 19B6DCAB9B843572847D9FA6 /* OpenModerationsViewProvider.swift */, + 9D521DAAB08CB0004CB3ADDE /* ViewConverters */, + ); + path = OpenModerations; + sourceTree = ""; + }; C3C3D6F9AE5A65BFBB66FFE2 /* View */ = { isa = PBXGroup; children = ( @@ -5306,53 +5458,50 @@ path = MessageThread; sourceTree = ""; }; - C4C67B3ED5AFC52073C01656 /* Feedback */ = { + C440C7EF2B5947B434178ACC /* UserList */ = { isa = PBXGroup; children = ( - 8D7FF76C892053B1F2B2D112 /* SBUFeedbackView.swift */, - 60EC3C29705F473B8FD02D2A /* SBUFeedbackViewParams.swift */, + 4A8338A02D18FC23E595C05A /* SBUUserListModule.Deprecated.swift */, ); - path = Feedback; + path = UserList; sourceTree = ""; }; - C5936CE7D4BE596342EB1F5B /* ChannelList */ = { + C4456DA7C0BAB540901CD61F /* MultipleFilesMessage */ = { isa = PBXGroup; children = ( - B82B55E310D26E3DD9E67834 /* SBUBaseChannelListViewController.swift */, - F5787B281C37A19736CD8A8A /* SBUGroupChannelListViewController.swift */, - A4E9A824E45E051EC112A416 /* SBUOpenChannelListViewController.swift */, - 01B62348032FAB2E1AC5E0E7 /* ChannelCell */, + C11C0F93FE87E0C4F72A5027 /* SBUMultipleFilesMessageCell.swift */, + 2BA1A976DF480A02EAAA44B9 /* SBUMultipleFilesMessageCollectionView.swift */, + DB28FF204E44C2979312FED6 /* SBUMultipleFilesMessageCollectionViewCell.swift */, ); - path = ChannelList; + path = MultipleFilesMessage; sourceTree = ""; }; - C5D760C05858D57E567F8E7F /* View */ = { + C478BBF8363AA46333AA672F /* MessageCell */ = { isa = PBXGroup; children = ( - DD06A568617A957C0B077EE4 /* CustomOpenParticipantList.SwiftUI.View.CustomMain.swift */, - 76D679FC213569853E5A02DE /* CustomOpenParticipantList.SwiftUI.View.Main.swift */, + D9AC164247B4ADF8D79CF790 /* SBUContentBaseMessageCell.Deprecated.swift */, + AF27AFA54782A22874F2DCCC /* MessageCellParams */, + A5B2F0823C0D1ACDCBBD09F2 /* Replies */, ); - path = View; + path = MessageCell; sourceTree = ""; }; - C6C4EF4818DC97CF5FD87C78 /* ViewParams */ = { + C5D760C05858D57E567F8E7F /* View */ = { isa = PBXGroup; children = ( - FF616B484BF9E87795017EA1 /* SBUQuoteMessageInputViewParams.swift */, + DD06A568617A957C0B077EE4 /* CustomOpenParticipantList.SwiftUI.View.CustomMain.swift */, + 76D679FC213569853E5A02DE /* CustomOpenParticipantList.SwiftUI.View.Main.swift */, ); - path = ViewParams; + path = View; sourceTree = ""; }; - C71454E0D75032C572E83141 /* ViewConverters */ = { + C6B00485933E488C38625DD7 /* AlertView */ = { isa = PBXGroup; children = ( - DF1E9EBB5C80F9BC517456A1 /* OpenChannelRegisterOperatorViewConverter.Header.swift */, - 9AF49CD344907510F8C32C0F /* OpenChannelRegisterOperatorViewConverter.List.swift */, - DB82FCDC07B9737FF5237466 /* OpenChannelRegisterOperatorViewConverter.swift */, - AF66DF02B81CE8EF19BF9BF0 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift */, - 7DB8540E24BA4EAD377A29F7 /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift */, + 59A09DB977466D219BBC36EA /* SBUAlertView.Item.swift */, + 3898C32C492215F4562791CD /* SBUAlertView.swift */, ); - path = ViewConverters; + path = AlertView; sourceTree = ""; }; C79C5F3E2CE7EA3A16623A55 /* SubView */ = { @@ -5380,41 +5529,73 @@ path = SwiftUI; sourceTree = ""; }; - C98573E3FAE96141E5E47D88 /* OpenChannelList */ = { - isa = PBXGroup; - children = ( - 361AEE3CF32E940D61DDCF69 /* OpenChannelListView.swift */, - 8731B4E84E8F9AFDB3DCCF5D /* OpenChannelListView+Item.swift */, - 5FC3D28B7EC4E416E6936B47 /* OpenChannelListView+SubViewBuilder.swift */, - A4CAF7382CC2469BBF87E329 /* OpenChannelListView+ViewConverter.swift */, - 7847A121F521C10D81CFC75C /* ViewConverters */, - ); - path = OpenChannelList; - sourceTree = ""; - }; - C9BF1ADC893574C285E9743D /* MessageForm */ = { - isa = PBXGroup; - children = ( - 06BA19501C8B082AE6526FD4 /* ViewParams */, - 473E43FA14C87BF26F51A9FA /* Views */, + CAFA27DC744775FA7727B38B /* Common */ = { + isa = PBXGroup; + children = ( + 50ED882EE429BC0546752DE2 /* SBUAnimation.swift */, + 2AF37FB8A55745647820E475 /* SBUBarButtonItem.swift */, + 6893750A21CEBD75C830B03A /* SBUCollectionViewFlowLayout.swift */, + 9DB600E69AA30D66B6F3D9D7 /* SBUCommonItem.swift */, + 7725F441E1811150851949AB /* SBUCommonViewControllerSet.swift */, + E0C6B3B15A2C99291A025E96 /* SBUCoverImageView.swift */, + C3B03F7CD7C1C6606A5BA43F /* SBUEmptyView.swift */, + 517DCACCA8CAB496DAE1FE65 /* SBULayoutableButton.swift */, + 70D5F2E2B3D151693F21C0A6 /* SBULoading.swift */, + A4F262DB37A37F85B936D28B /* SBUMarginView.swift */, + CA7760618CB22098FFAA5180 /* SBUNavigationTitleView.swift */, + E396AAA7E062869842D0067C /* SBUNotificationEmptyView.swift */, + 4609C23D48140B46A11D9077 /* SBUNotificationNavigationTitleView.swift */, + B1CEACEDCDA122F53B6F9048 /* SBUPaddingLabel.swift */, + F7EDA70EF7D626DD23ABD4C8 /* SBUSearchBar.swift */, + 0AEA53AA4E09C4C797BD87EE /* SBUStackView.swift */, + C14D33CD97DDAE9959DB7FAB /* SBUTemplateLabel.swift */, + 00742C0D576C475B69BDD384 /* SBUTypingIndicatorBubbleView.swift */, + BE00B6FCA3245B5D40FCB38C /* SBUUnderLineTextField.swift */, + 161A42B1A88C581C50538C1C /* ActionSheet */, + C6B00485933E488C38625DD7 /* AlertView */, + 9053EA2B881128C5485F21DD /* Menu */, + 2F558A2F3C8985DE49006B1C /* PhotoLibrary */, + 37F0F836809AA71D47801345 /* Toast */, + 90873467F74670B85A783466 /* User */, + 668D44DB9BA02C63B7110239 /* UserCell */, ); - path = MessageForm; + path = Common; sourceTree = ""; }; - CC90673304787B93F2D1652A /* ScrollBottomView */ = { + CB6A8BC786C3454BFCEB281D /* uikit */ = { isa = PBXGroup; children = ( - 740FE6FE5E6D2566C92D0CD8 /* SBUScrollBottomView.swift */, + 434AF506C04A1A095C70A126 /* PrivacyInfo.xcprivacy */, + C11CD6DE01963046D4167D31 /* SBUAvailable.swift */, + 5DAE1563042355B438870C6A /* SBUGlobalCustomParams.swift */, + 654B422A3B857A5B120E4528 /* SBUGlobals.swift */, + 8EBCAEA988BE8EE57CD4DE26 /* SendbirdUI.swift */, + 0198B27F0E6EB85860123E5A /* SendbirdUIKit.h */, + C3141836907B1D9097369FD1 /* Configuration */, + FF179ECBE873626BCACFED35 /* Constant */, + 406A19B584F71B1B4DB46410 /* Deprecated */, + 3E81C51976553C11412FD61A /* Enums */, + E2A7F915FB9D78CFCCBDB116 /* Extension */, + 6D3DE8660C9CC50307788FC8 /* Manager */, + 68F65643567C85C304D50C31 /* MessageTemplate */, + 73AF64E05429C2D9804448FA /* Model */, + E4AE61E1E94A7C50716BD4D4 /* Module */, + 15A92824C795311E850F25F3 /* Protocol */, + 87D201D0D13A7685F1C6702C /* Resource */, + AA7E35C4FCBBC0B26CF2FD79 /* Theme */, + 491CAA9C39B6086E714B1903 /* Util */, + 154C2C20E9797E01603142CF /* View */, + 190E50121242BD1451CA5858 /* ViewModel */, ); - path = ScrollBottomView; + path = uikit; sourceTree = ""; }; - CCC8CB1C84A26D60CEA650E1 /* CreateChannel */ = { + CCE414371CE628BF4F4C3A7F /* Moderations */ = { isa = PBXGroup; children = ( - 9AA2862AB56710CEAAEB6A77 /* SBUCreateChannelViewController.Deprecated.swift */, + 3C6B64F40A2CCC515B0EC030 /* SBUModerationsModule.Deprecated.swift */, ); - path = CreateChannel; + path = Moderations; sourceTree = ""; }; CD428B5D0920D0756466C44D /* SwiftUI */ = { @@ -5433,21 +5614,26 @@ path = Builder; sourceTree = ""; }; - CE8305968BFE7AD16C3D731C /* View */ = { + CE5AC02368FDB474F92E9F9B /* GroupMemberList */ = { isa = PBXGroup; children = ( - 24823518A52E6BB53C899607 /* CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift */, - 39347C5622B095E111628DAE /* CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift */, + 02860979E56EFC1AF779C802 /* GroupMemberListView.swift */, + 0F519A11E20B608D84165E59 /* GroupMemberListView+Item.swift */, + F624E4320147A947036A7DE1 /* GroupMemberListView+SubViewBuilder.swift */, + 26A32BBCC22F6F9C43CE2299 /* GroupMemberListView+ViewConverter.swift */, + 68884CEA1F889062B9AE92D9 /* GroupMemberListViewProvider.swift */, + E95E3C9D30E7497F062FCA59 /* ViewConverters */, ); - path = View; + path = GroupMemberList; sourceTree = ""; }; - CEBED7ED1E21D148B97F3548 /* Common */ = { + CE8305968BFE7AD16C3D731C /* View */ = { isa = PBXGroup; children = ( - ECA3A3BB1C8BE8DD7400F28B /* Sendbird.swift */, + 24823518A52E6BB53C899607 /* CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift */, + 39347C5622B095E111628DAE /* CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift */, ); - path = Common; + path = View; sourceTree = ""; }; CEE8DF4794BAB3CF3639C1BB /* GroupChannelPushSettings */ = { @@ -5470,61 +5656,87 @@ path = GroupChannelRegisterOperator; sourceTree = ""; }; - D08FA5C809028E456042B770 /* GroupChannel */ = { + CF86EDCD8D07DB3014CAFCAE /* CreateChannel */ = { isa = PBXGroup; children = ( - 8A07FD82926848554C43ABB5 /* SBUGroupChannelModule.Header.swift */, - 0B96A9441D86C9B70E7B8FC1 /* SBUGroupChannelModule.Input.swift */, - 19CEBE4C850E10CB4FDA7B68 /* SBUGroupChannelModule.List.swift */, - 49B0CF645FE9CBB0F17FAB36 /* SBUGroupChannelModule.swift */, + C5B096932C37180E655EB9A6 /* SBUCreateChannelViewController.swift */, + DC897D28420AE8B2454DCA7A /* SBUCreateOpenChannelViewController.swift */, + 9B36B7073FBAB5677FA5A146 /* View */, ); - path = GroupChannel; + path = CreateChannel; sourceTree = ""; }; - D109A7E6AAEBDA73C95E5E5C /* VoiceNote */ = { + D12645C5E467ABB7A22D577C /* Theme */ = { isa = PBXGroup; children = ( - C73D7E5C13B65599FAE5D2E3 /* SBUVoiceMessageInputView.swift */, + 8F367A5BA5694A0F9BF9B107 /* Custom */, ); - path = VoiceNote; + path = Theme; sourceTree = ""; }; - D12645C5E467ABB7A22D577C /* Theme */ = { + D1A4ED7F0D44F0E5A0C29A3A /* GroupChannelRegisterOperator */ = { isa = PBXGroup; children = ( - 8F367A5BA5694A0F9BF9B107 /* Custom */, + 0E0914DD583685C5CC8D2419 /* GroupChannelRegisterOperatorView.swift */, + 7D90B73B8AC8C71F9C1C431A /* GroupChannelRegisterOperatorView+Item.swift */, + 9C974D5E01D2D8CB8E15B8CD /* GroupChannelRegisterOperatorView+SubViewBuilder.swift */, + 9E412F92FD80B99ACFE30AF7 /* GroupChannelRegisterOperatorView+ViewConverter.swift */, + ECE0E78C0DE00AD12F25AC49 /* GroupChannelRegisterOperatorViewProvider.swift */, + 15464239D1FEC5DEBFFFB817 /* ViewConverters */, ); - path = Theme; + path = GroupChannelRegisterOperator; sourceTree = ""; }; - D2651C38116DD90645B2DA17 /* Enums */ = { + D1B95A327BC7751095E44886 /* GroupChannelSettings */ = { isa = PBXGroup; children = ( - 2FF459520D3ED7BBC083BB7E /* SBUEnums.swift */, - AE671E84CB2E1BF4227408D7 /* SBUIconSetType.swift */, - 37663F0868F7387F231EF23F /* VoiceMessageStatus.swift */, + 62364A595D53A0543706D2F9 /* GroupChannelSettingsView.swift */, + 54D753A8D0469BADE7B3A79C /* GroupChannelSettingsView+Item.swift */, + 2EC4CB40DFDCDAA8D8D03164 /* GroupChannelSettingsView+SubViewBuilder.swift */, + 28A2E22DD48A106F4586D002 /* GroupChannelSettingsView+ViewConverter.swift */, + 7244A2B65E75811F309743EC /* GroupChannelSettingsViewProvider.swift */, + EA95D31131AD14EAAA9DD7C8 /* ViewConverters */, ); - path = Enums; + path = GroupChannelSettings; sourceTree = ""; }; - D2850CFF3EA6FE66D395E1E5 /* List */ = { + D23A41D38C239063E793BD4B /* GroupMutedMemberList */ = { isa = PBXGroup; children = ( - F8E8BBB7F3386838673ACE44 /* CustomMessageSearch.ViewConverter.List.entireView.swift */, + 4BDBA5011291E3E322F0660F /* GroupMutedMemberListView.swift */, + B48E2BC784CAFA265679C530 /* GroupMutedMemberListView+Item.swift */, + 2769D3BC0129E975B6946A2C /* GroupMutedMemberListView+SubViewBuilder.swift */, + 074C60BDD434834C451516D4 /* GroupMutedMemberListView+ViewConverter.swift */, + A17C46E3441DE12806ABD160 /* GroupMutedMemberListViewProvider.swift */, + A218B79F9913B68CEACD222A /* ViewConverters */, ); - path = List; + path = GroupMutedMemberList; sourceTree = ""; }; - D31515481660F2A112791202 /* GroupOperatorList */ = { + D248ADA3A6C7D22A3036CF0F /* NotificationSettings */ = { isa = PBXGroup; children = ( - D8F39143F890265770E857F8 /* GroupOperatorListView.swift */, - A4E6B3FBFE02752B58883E4B /* GroupOperatorListView+Item.swift */, - CC3F606B79E0EAB2E982DC39 /* GroupOperatorListView+SubViewBuilder.swift */, - 4E03A57B44CC6B14D4C4031B /* GroupOperatorListView+ViewConverter.swift */, - 7B08421A95216EF999A46093 /* ViewConverters */, + A5AAEF8465A482135D31EB44 /* SBUGroupChannelPushSettingsModule.Header.swift */, + 51564EBFCB24F043472D1D55 /* SBUGroupChannelPushSettingsModule.List.swift */, + 42D37B68DDC774BB034CEE3E /* SBUGroupChannelPushSettingsModule.swift */, ); - path = GroupOperatorList; + path = NotificationSettings; + sourceTree = ""; + }; + D266795CB20D0BC9F32F6620 /* Cell */ = { + isa = PBXGroup; + children = ( + 4CDA371C83E2F67518C3A760 /* SBUChannelPushSettingCell.swift */, + ); + path = Cell; + sourceTree = ""; + }; + D2850CFF3EA6FE66D395E1E5 /* List */ = { + isa = PBXGroup; + children = ( + F8E8BBB7F3386838673ACE44 /* CustomMessageSearch.ViewConverter.List.entireView.swift */, + ); + path = List; sourceTree = ""; }; D35C5ED8392BF324A99B9934 /* SwiftUI */ = { @@ -5567,16 +5779,13 @@ path = List; sourceTree = ""; }; - D5C140713185B141540B5471 /* CreateOpenChannel */ = { + D572A6F2EB9EA9CC6750F357 /* Moderations */ = { isa = PBXGroup; children = ( - A7FB320B188CFD4C01CCEF5A /* CreateOpenChannelView.swift */, - A8F1B86B8E65954C7AA1988C /* CreateOpenChannelView+Item.swift */, - 28404C050D7E597FB4DF7837 /* CreateOpenChannelView+SubViewBuilder.swift */, - 8E8801C8B570BA053A2B2FEA /* CreateOpenChannelView+ViewConverter.swift */, - 02A9E596573FDE7CB8B282E8 /* ViewConverters */, + 682435685BFDA58E30D915B8 /* SBUModerationsViewController.Deprecated.swift */, + 1CAA39A852B107E285CE001B /* SBUModerationsViewModel.Deprecated.swift */, ); - path = CreateOpenChannel; + path = Moderations; sourceTree = ""; }; D5CE390AD8B69B93EEF79D04 /* GroupBannedUserList */ = { @@ -5589,19 +5798,6 @@ path = GroupBannedUserList; sourceTree = ""; }; - D607D3E218BDA7375DF73D24 /* SelectUser */ = { - isa = PBXGroup; - children = ( - FDF95535882D104149DE19C4 /* SBUBaseSelectUserModule.Header.swift */, - DC3DF1FA4AFE90DC6FA8AC20 /* SBUBaseSelectUserModule.List.swift */, - 9DBA21B0C820B120DABD7BF3 /* SBUBaseSelectUserModule.swift */, - 3ED2A22377280FF244056B2D /* CreateChannel */, - FAE5FF0B1CD329933C60A9CA /* InviteUser */, - 1228F805FE97ECE563467D22 /* RegisterOperator */, - ); - path = SelectUser; - sourceTree = ""; - }; D62779920ABE6B8A1E688FD4 /* GroupOperatorList */ = { isa = PBXGroup; children = ( @@ -5623,12 +5819,17 @@ path = OpenParticipantList; sourceTree = ""; }; - D743D1ED45AAA2315FDB6614 /* SubViews */ = { + D6C5A955DC2742FB58996175 /* ViewConverters */ = { isa = PBXGroup; children = ( - 904618EB6B0A591FC15D1542 /* SBUMessageFormChipView.swift */, + 8A5B8F101D680AC30270B59D /* GroupOperatorListViewConverter.Header.swift */, + C0C346D6EED1C20C50D275E9 /* GroupOperatorListViewConverter.List.swift */, + BDFE3D65FB2D6207335EFEF0 /* GroupOperatorListViewConverter.swift */, + B2F84327611A02AD862FBF50 /* SBUGroupOperatorListModule.Header+SwiftUI.swift */, + BC87A02119141F2A3B9F2390 /* SBUGroupOperatorListModule.List+SwiftUI.swift */, + 97AA2A602830838B5F8BFF85 /* SBUGroupOperatorListUserCell+SwiftUI.swift */, ); - path = SubViews; + path = ViewConverters; sourceTree = ""; }; D7DA8666256ADB2BE36019B1 /* ViewConverter */ = { @@ -5640,59 +5841,6 @@ path = ViewConverter; sourceTree = ""; }; - D82AB513C032DD5BF769BC9C /* OpenChannel */ = { - isa = PBXGroup; - children = ( - 2312B56E1998FE3473D42757 /* SBUOpenChannelAdminMessageCell.swift */, - E0A690A691FBFFFB1EA46385 /* SBUOpenChannelBaseMessageCell.swift */, - 78EA6D0B65FF927D2CE1805D /* SBUOpenChannelContentBaseMessageCell.swift */, - 016BAC75334B9EECCCDCC68B /* SBUOpenChannelFileMessageCell.swift */, - 3716519FE7F6D63C6FE4A48A /* SBUOpenChannelUnknownMessageCell.swift */, - B78C4CB73E4DC57DEC979D99 /* SBUOpenChannelUserMessageCell.swift */, - ); - path = OpenChannel; - sourceTree = ""; - }; - D84BA29D057F15497864FB20 /* Renderer */ = { - isa = PBXGroup; - children = ( - 9BDF021DB7EDAA493F908BB5 /* SBUMessageTemplate.Renderer.Image.swift */, - EECE2AC717C2FBAC7D59465F /* SBUMessageTemplate.Renderer.RendererType.swift */, - C096565785A1E150A95D7572 /* SBUMessageTemplate.Renderer.swift */, - 66214E35809045C5464EF919 /* SBUMessageTemplate.Renderer.Views.swift */, - 344AF01876274CF324237E4D /* SBUMessageTemplate.Renderer+Events.swift */, - 248481420F458F58CA0D9E6F /* SBUMessageTemplate.Renderer+RenderItems.swift */, - B7E0D4FD8746F209DFE99AF3 /* SBUMessageTemplate.Renderer+RenderStyles.swift */, - B4634E8F326FA5E9E408A111 /* SBUMessageTemplate.Renderer+Utils.swift */, - ); - path = Renderer; - sourceTree = ""; - }; - D859E8FC7B0A675E24E0D390 /* ChannelList */ = { - isa = PBXGroup; - children = ( - 0F4C42BBF3DAEC2178B976E9 /* SBUBaseChannelListModule.Header.swift */, - 6830AB2E6492132B6DCF3BE4 /* SBUBaseChannelListModule.List.swift */, - 766287661E5CEC1E2D67A87D /* SBUBaseChannelListModule.swift */, - 7669980D4DB087571F7E523D /* GroupChannel */, - 136E50E3B3EACB38F9022250 /* OpenChannel */, - ); - path = ChannelList; - sourceTree = ""; - }; - D85A179C310192313FBAC03D /* FileMessageContentView */ = { - isa = PBXGroup; - children = ( - 32F2AF6630757800DFF08628 /* SBUBaseFileContentView.swift */, - 16C4D273B7FFFD441AC2D664 /* SBUCommonContentView.swift */, - 86D37B65E1EF649577EA0D37 /* SBUImageContentView.swift */, - AD07773AFAC8EDB0C5804E32 /* SBUOpenChannelCommonContentView.swift */, - 61007D0CB510FD7CDC121AC9 /* SBUOpenChannelImageContentView.swift */, - F0B78A78B3EEDCE40DFDFD34 /* SBUVoiceContentView.swift */, - ); - path = FileMessageContentView; - sourceTree = ""; - }; D89A004173153CA1E6D71081 /* Header */ = { isa = PBXGroup; children = ( @@ -5703,56 +5851,35 @@ path = Header; sourceTree = ""; }; - D8E778BF58081A5D0C9E4DA2 /* Extension */ = { - isa = PBXGroup; - children = ( - 6B306A81F7C4F4B82605F38B /* Array+SBUIKit.swift */, - D9C0E0D304969F74F95F6857 /* CGSize+SBUIKit.swift */, - 1DDB1C8B0B6F4041F5B74E5F /* Collection+SBUIKit.swift */, - 61C01A500D446EBDA6C34A88 /* Data+SBUIKit.swift */, - 1DEBA9D64BDD959D8117D5C8 /* Date+SBUIKit.swift */, - 920FC92C3C10DFB71BEA1069 /* Float+SBUIKit.swift */, - 3407D92E992D53C7D02B7CB3 /* Formatter+SBUIKit.swift */, - 57110DEFE797090CB0D36499 /* NSLayoutConstraint+SBUIKit.swift */, - 285695471DE00B5F03AF5665 /* NSObject+SBUIKit.swift */, - 691908423FD3C5E45C4BF41A /* Sequence+SBUIKit.swift */, - 9816C55DCB0A7ED877604B1F /* String+SBUIKit.swift */, - 2C593374BB12107EC560C715 /* StringProtocol+SBUIKit.swift */, - 6AEF8D4FF705BB662A4BDC7A /* Thread+SBUIKit.swift */, - 463AAB7723F705DF887E76BE /* UIApplication+SBUIKit.swift */, - 2435FE6370AF68E18F345DD8 /* UIButton+SBUIKit.swift */, - 3064CE17D9A94272F21E223E /* UICollectionView+SBUIKit.swift */, - A3CF699C92A450F181836CD9 /* UIColor+SBUIKit.swift */, - 1286E9C8A5FDC69006356104 /* UIImage+SBUIKit.swift */, - BD7AC31657ED213E32ECBD42 /* UIImageView+SBUIKit.swift */, - F0B58422C8C6BDC4A3B19315 /* UINavigationController+SBUIKit.swift */, - CC6D68CE2E93880EB54D12ED /* UIScrollView+SBUIKit.swift */, - DCEAE022E08885F8F8991889 /* UIStackView.SBUIKit.swift */, - B08F254ED73A65FF24CE813B /* UITableView+SBUIKit.swift */, - 43AAC279DE5780A073B1E21F /* UITextField+SBUIKit.swift */, - 026199A2CE3A7D4DBA022604 /* UIView+SBUIKit.swift */, - E51D27858754EDD555AF4BD5 /* UIViewController+SBUIKit.swift */, - E91ABFFD5B2067D560F73E17 /* URL+SBUIKit.swift */, - 1B09309885C4F0D28B2AA0A9 /* ChatSDK */, + D8C81B5BE27B529B495D927A /* Util */ = { + isa = PBXGroup; + children = ( + F28B6B09EF78A29A92725BD6 /* Closure.swift */, + 775497373156080C786EFFA9 /* HandlerSet.swift */, + 7F737D0DF3D80BAE69165E99 /* SBULazyView.swift */, ); - path = Extension; + path = Util; sourceTree = ""; }; - DA18B5219946B9E2E23125ED /* Frameworks */ = { + D9714C44FD4B3BD4FF9E9BA6 /* ViewConverters */ = { isa = PBXGroup; children = ( - 1AF8CB593FE2D4951A3ED114 /* UserNotifications.framework */, + AB3EA7BE88661E3E98BC2085 /* CreateGroupChannelViewConverter.Header.swift */, + 48342C2B2D314AB84A41048F /* CreateGroupChannelViewConverter.List.swift */, + 7AF732FDF59475FF7693846E /* CreateGroupChannelViewConverter.swift */, + 1FA72B8958F28537FDA7ACFE /* SBUCreateGroupChannelModule.Header+SwiftUI.swift */, + C1C275129547FD119EC8DC0A /* SBUCreateGroupChannelModule.List+SwiftUI.swift */, + 9A63BAEF80ECC309FA1E7669 /* SBUCreateGroupChannelUserCell+SwiftUI.swift */, ); - name = Frameworks; + path = ViewConverters; sourceTree = ""; }; - DA9990DB8A90F6735EA3108E /* Notifications */ = { + DA18B5219946B9E2E23125ED /* Frameworks */ = { isa = PBXGroup; children = ( - 2F88656EDE7A31FD01B7ED7D /* SBUChatNotificationChannelModule.Deprecated.swift */, - 70A996C0178CC5216BCB2EBE /* SBUFeedNotificationChannelModule.Deprecated.swift */, + 1AF8CB593FE2D4951A3ED114 /* UserNotifications.framework */, ); - path = Notifications; + name = Frameworks; sourceTree = ""; }; DB4B5089F63C98ADCA99956E = { @@ -5766,24 +5893,41 @@ ); sourceTree = ""; }; - DBDF91D107548D777A8C3598 /* ChannelSettings */ = { + DB970A3EAF5F100E597AF721 /* GroupModerations */ = { isa = PBXGroup; children = ( - 43CA6787E4A3A782EE75B313 /* SBUBaseChannelSettingsViewController.swift */, - 81EE50EA8221195EAE1F0290 /* SBUGroupChannelSettingsViewController.swift */, - 0862BAC5CCDFC6641C3B97C3 /* SBUOpenChannelSettingsViewController.swift */, - 66841D77E1D71FFA0E35F758 /* Cell */, - 7B216A51C6D9959F37D3C5D5 /* View */, + CF9B3D01A792D6AB23816E47 /* GroupModerationsView.swift */, + C08C818F7E03C3CC838DCED3 /* GroupModerationsView+Item.swift */, + A5DD11EC90E6DD9335006B66 /* GroupModerationsView+SubViewBuilder.swift */, + 349C18C1DC887172FCB29311 /* GroupModerationsView+ViewConverter.swift */, + EAC33A1D45B726CE0C5F2810 /* GroupModerationsViewProvider.swift */, + E443B7BFC239179E615480CF /* ViewConverters */, ); - path = ChannelSettings; + path = GroupModerations; sourceTree = ""; }; - DEFBDFA49A46AA313952B13F /* MessageCellParams */ = { + DBB37BC1D540B3FB7CBD0E82 /* ChannelList */ = { isa = PBXGroup; children = ( - CADB3058FF6F4B079FB37BB8 /* SBUBaseMessageCellParams.Deprecated.swift */, + E60ABCC74B32B1B8BD7232BD /* SBUBaseChannelListModule.Header.swift */, + 4ABAFA861BDEB0E2B5E08C64 /* SBUBaseChannelListModule.List.swift */, + 2E730A218995750A20EC764A /* SBUBaseChannelListModule.swift */, + 6C7BCCB8D37875E3223E86A5 /* GroupChannel */, + 28DD317DD19073641AD30F34 /* OpenChannel */, ); - path = MessageCellParams; + path = ChannelList; + sourceTree = ""; + }; + DD394436761B7AB4D860DAC4 /* Channel */ = { + isa = PBXGroup; + children = ( + 4792A2ADDCEE5FE657BA8AC7 /* SBUBaseChannelViewModel.swift */, + A2A6496F9496B70C0C5DC32C /* SBUChatNotificationChannelViewModel.swift */, + F3B52DE1481E7DCF5E9A0B11 /* SBUFeedNotificationChannelViewModel.swift */, + 3AC6115AB54C4F0DE018F8EE /* SBUGroupChannelViewModel.swift */, + 6956509D6C57F140F2A819D9 /* SBUOpenChannelViewModel.swift */, + ); + path = Channel; sourceTree = ""; }; DF01DBC0D404D9B5E3A2FEAE /* ViewConverter */ = { @@ -5795,72 +5939,119 @@ path = ViewConverter; sourceTree = ""; }; - DFAB359EC86C8260746E3638 /* MemberList */ = { + E136A13008F5CBAC025017AC /* SubView */ = { isa = PBXGroup; children = ( - 562B1654E59E7FBB80E3FDFB /* SBUMemberListViewController.Deprecated.swift */, + E617D85FDE318D9757CDBA3A /* Builder */, ); - path = MemberList; + path = SubView; sourceTree = ""; }; - E136A13008F5CBAC025017AC /* SubView */ = { + E2A7F915FB9D78CFCCBDB116 /* Extension */ = { + isa = PBXGroup; + children = ( + 4B7D92C1C33EB7B70A4DD7CB /* Array+SBUIKit.swift */, + 8B14D993DFD2D52F88F9CEBE /* CGSize+SBUIKit.swift */, + 10D4FAE80AC3E74AA8159C06 /* Collection+SBUIKit.swift */, + D38E6015D6853331994CD11F /* Data+SBUIKit.swift */, + 24F167651C8FE9886C4D02D6 /* Date+SBUIKit.swift */, + 73F0DFB46EDBD5F62F209CC9 /* Float+SBUIKit.swift */, + 882B165AD9E00AD0671DD185 /* Formatter+SBUIKit.swift */, + 915CB4B356E8EE48F40EAF87 /* NSLayoutConstraint+SBUIKit.swift */, + B5B8D919D29518C330D50223 /* NSObject+SBUIKit.swift */, + 167B8A4B458413D2B4C5F591 /* Sequence+SBUIKit.swift */, + A7ECA3675E4F44DFB6586D04 /* String+SBUIKit.swift */, + 85DC90D7892EF6119DE13735 /* StringProtocol+SBUIKit.swift */, + 9ED6D075080214039048A95D /* Thread+SBUIKit.swift */, + F200CA4F5373C5A264BE312A /* UIApplication+SBUIKit.swift */, + 361730BCE391F1EC0B386A82 /* UIButton+SBUIKit.swift */, + D00605CF296075CBED52EF08 /* UICollectionView+SBUIKit.swift */, + 8016144176E0D68BC050E151 /* UIColor+SBUIKit.swift */, + D3A937118732EBE90BC48E80 /* UIImage+SBUIKit.swift */, + 3FEA7B7C415546F22E63FEFE /* UIImageView+SBUIKit.swift */, + 5E85D3B450A2E0B91A8E3E3C /* UINavigationController+SBUIKit.swift */, + 5B75F4EBD4914A4295678613 /* UIScrollView+SBUIKit.swift */, + FD34FF666C940B94555A93F5 /* UIStackView.SBUIKit.swift */, + 167486D0234433BF424AD399 /* UITableView+SBUIKit.swift */, + 54BFF6A6EF79427A10DA19C5 /* UITextField+SBUIKit.swift */, + D9CFDA621D7A6EB6427288A6 /* UIView+SBUIKit.swift */, + 85CCC0022AAE55FB91296FE5 /* UIViewController+SBUIKit.swift */, + 7DF47B235A5C5712180E6232 /* URL+SBUIKit.swift */, + 698EF9C9DEF12F6FB1265602 /* ChatSDK */, + ); + path = Extension; + sourceTree = ""; + }; + E335EDCB09D39F6F4B210D2D /* Views */ = { isa = PBXGroup; children = ( - E617D85FDE318D9757CDBA3A /* Builder */, + 3F7C5297FA101765F9784775 /* SBUMessageFormChipsItemView.swift */, + 5AB54402454B883CCD6CBD01 /* SBUMessageFormFallbackView.swift */, + 928D1849A1BC6DB24E431C92 /* SBUMessageFormItemView.swift */, + A94FC79DD966BE57D3D864FE /* SBUMessageFormMultiTextItemView.swift */, + 48BB97FD2509104396ED0E43 /* SBUMessageFormSingleTextItemView.swift */, + 29FE8D858AD7C69E3B2FF2EE /* SBUMessageFormView.swift */, + 950EAAA7218B686254793360 /* SubViews */, ); - path = SubView; + path = Views; sourceTree = ""; }; - E152ED49F13F45C06864F7EF /* Replies */ = { + E35EDEE8E4D9C33C42E8BB13 /* NewMessageInfo */ = { isa = PBXGroup; children = ( - 05432D8DAD7613CA6439B4E1 /* MessageView */, - B87FDDD8F7D0E6C17076FA2B /* ViewParams */, + EF67B852DBB45B4929297E29 /* SBUNewMessageInfo.swift */, + 058F7755FCA9CC99DBB5B468 /* SBUNewNotificationInfo.swift */, ); - path = Replies; + path = NewMessageInfo; sourceTree = ""; }; - E1CC4D09C2CA70DAE58B55B3 /* ViewConverters */ = { + E3AE60267A15D95E48BC9246 /* VoiceMessage */ = { isa = PBXGroup; children = ( - 1C19B6EF4242A39ED9990598 /* GroupChannelViewConverter.Header.swift */, - 118B3013D694187D3BA0B6CC /* GroupChannelViewConverter.Input.swift */, - E89F994B7B6B705FD09B4921 /* GroupChannelViewConverter.List.swift */, - FE6750636605238BA0E244C8 /* GroupChannelViewConverter.swift */, - 3F974D6F1E53ED5AB2C2C84C /* SBUBaseMessageCell+SwiftUI.swift */, - 758ABFEF69EB1E64F10BBD08 /* SBUChannelStateBanner+SwiftUI.swift */, - AE4CCA39B22DF2E106943CE0 /* SBUChannelTitleView+SwiftUI.swift */, - 6FD12CE289932C017AACEFC8 /* SBUGroupChannelModule.Header+SwiftUI.swift */, - 9EA80A9DB07BD04E1A717C23 /* SBUGroupChannelModule.Input+SwiftUI.swift */, - 19E5681F3154A4F68F3F2C2E /* SBUGroupChannelModule.List+SwiftUI.swift */, - A7BB35A201ABF5E46615916B /* SBUGroupChannelViewController+SwiftUI.swift */, - 03B00117DFCCB2FF23A6F102 /* SBUMessageInputView+SwiftUI.swift */, - 5D75B2A23956659470CD7213 /* SBUNewMessageInfo+SwiftUI.swift */, - C74FF03A1BD9590647429D9E /* SBUScrollBottomView+SwiftUI.swift */, + 4DDE8745066E0EC425DD0C85 /* SBUVoiceMessageConfiguration.swift */, ); - path = ViewConverters; + path = VoiceMessage; sourceTree = ""; }; - E2393BBCED543B06C566031A /* MessageInput */ = { + E43330EA426DD1B85555EF6F /* SelectUser */ = { isa = PBXGroup; children = ( - 194EB3991201611697330E0D /* SBUMentionLimitGuideCell.swift */, - 97C853C1F7E530CFD4D3C666 /* SBUMessageInputMode.swift */, - 0AEAE4D3A35CB4AE694FB592 /* SBUMessageInputView.swift */, - F4E0A861082E4DD96C4AF034 /* SBUQuoteMessageInputView.swift */, - A35787A00958FD8404D93082 /* SBUSuggestedMentionList.swift */, - C6C4EF4818DC97CF5FD87C78 /* ViewParams */, + 2689FD4A0398FE01DD24BCF2 /* SBUBaseSelectUserViewController.swift */, + 7D843E5D2908EB56EFDC2E4E /* SBUInviteUserViewController.swift */, + EF30301466491271F0E3512D /* SBURegisterOperatorViewController.swift */, + CF86EDCD8D07DB3014CAFCAE /* CreateChannel */, ); - path = MessageInput; + path = SelectUser; sourceTree = ""; }; - E37B889E5DBCBC920BC56521 /* ChannelSettings */ = { + E443B7BFC239179E615480CF /* ViewConverters */ = { isa = PBXGroup; children = ( - 1E9F07C7C0780B668356ECFF /* SBUGroupChannelSettingsModule.Deprecated.swift */, - 88E58F4FBC5A015D68518FC5 /* SBUOpenChannelSettingsModule.Deprecated.swift */, + 70474C82754DA2A006251C40 /* GroupModerationsViewConverter.Header.swift */, + 5F7BEBBF660496309A703D82 /* GroupModerationsViewConverter.List.swift */, + 374A6395FA9C34EE3DA516DF /* GroupModerationsViewConverter.swift */, + CE82953971F0DF674CF5F599 /* SBUGroupModerationsModule.Header+SwiftUI.swift */, + 9693AE7B405435E81AFB70DB /* SBUGroupModerationsModule.List+SwiftUI.swift */, ); - path = ChannelSettings; + path = ViewConverters; + sourceTree = ""; + }; + E4AE61E1E94A7C50716BD4D4 /* Module */ = { + isa = PBXGroup; + children = ( + CBF25F56D448A252479D1AA3 /* SBUModuleSet.swift */, + 23BD4F79BB64006FE21F0983 /* Channel */, + DBB37BC1D540B3FB7CBD0E82 /* ChannelList */, + 55D0D6829E44A11759802AC9 /* ChannelSettings */, + FF1AFDDF70B7339933D66D0E /* Common */, + C0495D9451BF91562C688AB8 /* MessageSearch */, + FDAED4D66693708B8E061B50 /* MessageThread */, + 59576C9425E6E7760C142619 /* Moderations */, + D248ADA3A6C7D22A3036CF0F /* NotificationSettings */, + 3A533ABC2F1C33DAF33FD773 /* SelectUser */, + 6F08556F59EAF2165D1C999F /* UserList */, + ); + path = Module; sourceTree = ""; }; E4F06BA07D7E95ED73F546C8 /* SwiftUI */ = { @@ -5882,17 +6073,13 @@ path = GroupMemberList; sourceTree = ""; }; - E52586E736AD50CE829E9C0F /* Views */ = { + E60710C816DBFE5CA297D37D /* Extension */ = { isa = PBXGroup; children = ( - 6005865475CC09912381B378 /* SBUHorizontalSuggestedReplyOptionView.swift */, - 6A95E354523AE09616B1BD80 /* SBUHorizontalSuggestedReplyView.swift */, - 45DD7E41B743695FA21FC378 /* SBUSimpleSuggestedReplyOptionView.swift */, - 0F25A2D259E9D51AC9C71562 /* SBUSuggestedReplyOptionView.swift */, - DFB6D698EDC2ED209371A6BF /* SBUSuggestedReplyView.swift */, - 60F1CC4E90D3A4D2A8070599 /* SBUVerticalSuggestedReplyView.swift */, + 40DBB14AD71744BD8B995B4F /* Color+Sendbird.swift */, + 11DF0BD15A442817BB746609 /* UIFont+Sendbird.swift */, ); - path = Views; + path = Extension; sourceTree = ""; }; E617D85FDE318D9757CDBA3A /* Builder */ = { @@ -5905,37 +6092,6 @@ path = Builder; sourceTree = ""; }; - E6C3AAB9BFE9E35C5F63F819 /* Model */ = { - isa = PBXGroup; - children = ( - 2C15ED108FD8018112C6E8B7 /* SBUError.swift */, - 19A3BDA35036947D712CB9E1 /* SBUExtendedMessagePayload.swift */, - 80EA4D44B6C5B0BF0C7543E6 /* SBUExtendedMessagePayloadForUI.swift */, - 89F0ABB7E53466D01AC02983 /* SBUFeedbackAction.swift */, - F11CCC27B98DC10813651863 /* SBUHighlightMessageInfo.swift */, - 75EBF0BF01347F6F918EF810 /* SBUMention.swift */, - E1C082271530831A0A97BA43 /* SBUMessageCache.swift */, - B3AEA60115A8DACD156EFE14 /* SBUScrollOptions.swift */, - F878EF1542E0FD36E8ED1D96 /* SBUTypingIndicatorInfo.swift */, - 934D7469181C103EE1ACAF1B /* SBUTypingIndicatorMessage.swift */, - 739741AE05C182B289832616 /* SBUUser.swift */, - 9FC2858F11E00B30B3C6B844 /* SBUVoiceFileInfo.swift */, - ); - path = Model; - sourceTree = ""; - }; - E7148FD88D840EF176D44954 /* GroupMemberList */ = { - isa = PBXGroup; - children = ( - C5F3807ECAAB76E19DBFE2D1 /* GroupMemberListView.swift */, - 2F5596CBB3FB434BE59F8BBA /* GroupMemberListView+Item.swift */, - 72BDBA680E4964489D1BCDB5 /* GroupMemberListView+SubViewBuilder.swift */, - 4C58C8CFC4FB879A749E7447 /* GroupMemberListView+ViewConverter.swift */, - 09C770197FC73C6111FF9983 /* ViewConverters */, - ); - path = GroupMemberList; - sourceTree = ""; - }; E90560B58DCA58C931C0DCB3 /* List */ = { isa = PBXGroup; children = ( @@ -5962,13 +6118,17 @@ path = List; sourceTree = ""; }; - E94A6926CD0E900AC5BEECBA /* AlertView */ = { + E95E3C9D30E7497F062FCA59 /* ViewConverters */ = { isa = PBXGroup; children = ( - 5C9F9A798C62C33692A93813 /* SBUAlertView.Item.swift */, - 68804DE6D7F73CEA7FEEA335 /* SBUAlertView.swift */, + E9C129A8E7F7F62801B604ED /* GroupMemberListViewConverter.Header.swift */, + 20731A3A1048D4D869625C6F /* GroupMemberListViewConverter.List.swift */, + BAEB95B332FE15206BBC2DFE /* GroupMemberListViewConverter.swift */, + 386477BCFB3C3B92E9854484 /* SBUGroupUserListModule.Header+SwiftUI.swift */, + 746CB9D65D9BE7AEACEE55C9 /* SBUGroupUserListModule.List+SwiftUI.swift */, + DAA4591A42376EF2D300B7CE /* SBUGroupUserListUserCell+SwiftUI.swift */, ); - path = AlertView; + path = ViewConverters; sourceTree = ""; }; E9720737286F68E912320B76 /* InviteUser */ = { @@ -5981,17 +6141,6 @@ path = InviteUser; sourceTree = ""; }; - EA340001A6210A4483B2BF7E /* MessageThread */ = { - isa = PBXGroup; - children = ( - A9F80A10E0E12E6B550927F7 /* SBUMessageThreadModule.Header.swift */, - 0E35F2241D8BFF297E9C7880 /* SBUMessageThreadModule.Input.swift */, - 3C02B4F623BAF706728A67A3 /* SBUMessageThreadModule.List.swift */, - 07B875B23CC937172B1A0557 /* SBUMessageThreadModule.swift */, - ); - path = MessageThread; - sourceTree = ""; - }; EA381DD9CBDDE04B7C64B225 /* View */ = { isa = PBXGroup; children = ( @@ -6010,59 +6159,39 @@ path = View; sourceTree = ""; }; - EC25054337C540259AB68A5E /* List */ = { + EA810D7D207D79C140836E61 /* UserList */ = { isa = PBXGroup; children = ( - 3A9945722AA9B595F601541C /* CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift */, - B8DD94130F1FCA4BC88AC734 /* CustomGroupChannelSettings.ViewConverter.List.entireView.swift */, - 5C7865CE65D851F196960978 /* CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift */, - 138034D59666A1D306B840DA /* CustomGroupChannelSettings.ViewConverter.List.member.swift */, - FE3455B16C9555F970F4D601 /* CustomGroupChannelSettings.ViewConverter.List.moderation.swift */, - 4CE700B571BDF60CF3AB5576 /* CustomGroupChannelSettings.ViewConverter.List.notification.swift */, - 2E2404EBE71135A247419F81 /* CustomGroupChannelSettings.ViewConverter.List.searchItem.swift */, + 36069F6F9F98006B014805FE /* SBUUserListViewModel.swift */, ); - path = List; - sourceTree = ""; - }; - ECBFF421037C34C3E998C6F1 /* ChannelStateBanner */ = { - isa = PBXGroup; - children = ( - 6D0823820ED006AB5C158A68 /* SBUChannelStateBanner.swift */, - ); - path = ChannelStateBanner; - sourceTree = ""; - }; - ECC68D0772FE38DA95177ACE /* ChannelList */ = { - isa = PBXGroup; - children = ( - EBDD55B35D81B408381A6074 /* SBUGroupChannelListModule.Deprecated.swift */, - BFB2AC204CC38945E7CD7DCC /* SBUOpenChannelListModule.Deprecated.swift */, - ); - path = ChannelList; + path = UserList; sourceTree = ""; }; - ECD1327DDB295B2E4D3CCF6D /* GroupChannelList */ = { + EA95D31131AD14EAAA9DD7C8 /* ViewConverters */ = { isa = PBXGroup; children = ( - 492BC0AAB8CE6B4CDE3E4AF5 /* GroupChannelListView.swift */, - AD6134279DE72ADE5816F2F0 /* GroupChannelListView+Item.swift */, - 6B072AC7DDABF32DA278BBA6 /* GroupChannelListView+SubViewBuilder.swift */, - E03D59600F0C64AE7B9745E8 /* GroupChannelListView+ViewConverter.swift */, - 30BC850E86491E7998ADAA03 /* ViewConverters */, + 1AE76A1AE751AA26FFB13901 /* GroupChannelSettingsViewConverter.Header.swift */, + 7E86E99F56BC13D21BFEBE68 /* GroupChannelSettingsViewConverter.List.swift */, + 5A1D7523528A21181034C649 /* GroupChannelSettingsViewConverter.swift */, + 3D593110E31DC45E924E2D9B /* SBUGroupChannelSettingCell+SwiftUI.swift */, + 621F589E5F0ED5BEE52864D0 /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift */, + 15FB5DC297BFAC6381342D85 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift */, ); - path = GroupChannelList; + path = ViewConverters; sourceTree = ""; }; - ED317116892FC3C994B0CA90 /* GroupChannelSettings */ = { + EC25054337C540259AB68A5E /* List */ = { isa = PBXGroup; children = ( - 29F879C5B05E8718BA713CED /* GroupChannelSettingsView.swift */, - AFB7053B5FEC84E058F598BF /* GroupChannelSettingsView+Item.swift */, - C00284E6199B018EE7B11AC7 /* GroupChannelSettingsView+SubViewBuilder.swift */, - D47B80C8F70B7B35CB44832C /* GroupChannelSettingsView+ViewConverter.swift */, - 7CCDE7811E6BD55D179F3FD1 /* ViewConverters */, + 3A9945722AA9B595F601541C /* CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift */, + B8DD94130F1FCA4BC88AC734 /* CustomGroupChannelSettings.ViewConverter.List.entireView.swift */, + 5C7865CE65D851F196960978 /* CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift */, + 138034D59666A1D306B840DA /* CustomGroupChannelSettings.ViewConverter.List.member.swift */, + FE3455B16C9555F970F4D601 /* CustomGroupChannelSettings.ViewConverter.List.moderation.swift */, + 4CE700B571BDF60CF3AB5576 /* CustomGroupChannelSettings.ViewConverter.List.notification.swift */, + 2E2404EBE71135A247419F81 /* CustomGroupChannelSettings.ViewConverter.List.searchItem.swift */, ); - path = GroupChannelSettings; + path = List; sourceTree = ""; }; EDD4BAC9293DC880EA199C4F /* Custom */ = { @@ -6073,52 +6202,52 @@ path = Custom; sourceTree = ""; }; - EED8A856C16F72CA5A02BDA3 /* OpenChannelSettings */ = { - isa = PBXGroup; - children = ( - 274DE7206A600067D64B8AF8 /* OpenChannelSettingsView.swift */, - F4CCF79AABF76CC5A2F14629 /* OpenChannelSettingsView+Item.swift */, - 8B900E0B514EC1D42837B8FF /* OpenChannelSettingsView+SubViewBuilder.swift */, - 526ED0C01EE8EF2AC7D76E68 /* OpenChannelSettingsView+ViewConverter.swift */, - 8F1B537A96F975F503D2D6C2 /* ViewConverters */, - ); - path = OpenChannelSettings; - sourceTree = ""; - }; - EF4BA4306BDA1CB72D7F5E25 /* UserList */ = { + EDFF1AE15C256E0442521CFD /* ViewConverters */ = { isa = PBXGroup; children = ( - 8668B5EFC9B9C3CBB72B925D /* SBUUserListModule.Header.swift */, - D9083FB6B72A4A282A2389B1 /* SBUUserListModule.List.swift */, - 85C17FF5923CE7EA65775A6E /* SBUUserListModule.swift */, + DBC40F923C1D6C6FC592B67A /* OpenChannelSettingsViewConverter.Header.swift */, + 1D26DE3887547F356A14F016 /* OpenChannelSettingsViewConverter.List.swift */, + 3C33B727B28009C968BDF9B6 /* OpenChannelSettingsViewConverter.swift */, + 96D00F1925C38316F7B14F6F /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift */, + DEFD2C9C3755450DB4FB300D /* SBUOpenChannelSettingsModule.List+SwiftUI.swift */, ); - path = UserList; + path = ViewConverters; sourceTree = ""; }; - EF5A0ADBC771A193A0A17933 /* PhotoLibrary */ = { + EF23550B53A6A76D4649E8B0 /* OpenBannedUserList */ = { isa = PBXGroup; children = ( - 6192BAE26601C4A3B4CE787C /* SBUPhotoAccess.swift */, - D98EB11025EC91C28DF16EA2 /* SBUPhotoCollectionViewCell.swift */, - B3815A0BB9F670F9F21DB0F0 /* SBUSelectablePhotoViewController.swift */, + 54077061A5C0CB8EE8DA4AB7 /* OpenBannedUserListView.swift */, + 198642EB3A0DA4073E11FBBE /* OpenBannedUserListView+Item.swift */, + 8FEB3D3A0A4B95348451722F /* OpenBannedUserListView+SubViewBuilder.swift */, + 52D32A54B554A339D5661CD4 /* OpenBannedUserListView+ViewConverter.swift */, + 5B0C556D74C6973EC9D079ED /* OpenBannedUserListViewProvider.swift */, + 90589FA80DDE7E18BA6DB91F /* ViewConverters */, ); - path = PhotoLibrary; + path = OpenBannedUserList; sourceTree = ""; }; - F17B8DA0264AD4191385BC0B /* UserCell */ = { + F0649607576F863190C48D57 /* RegisterOperator */ = { isa = PBXGroup; children = ( - C8BA1B8C93D3C73902AD9BD4 /* SBUUserCell.swift */, + 69AD8CF8B82DA7E28C4E1E29 /* SBURegisterOperatorModule.Header.swift */, + FD8219759D395864DBC89499 /* SBURegisterOperatorModule.List.swift */, + 42DCD70A6B86E1C1113518A4 /* SBURegisterOperatorModule.swift */, ); - path = UserCell; + path = RegisterOperator; sourceTree = ""; }; - F30ACDDDD345549DB8FEB9AE /* Resource */ = { + F090EFE733C66414AFC3EA77 /* OpenMutedParticipantList */ = { isa = PBXGroup; children = ( - A70B8E791E1AA6A605F15277 /* Assets.xcassets */, + E1CE8E0AE7AC6EA86FDF2BB5 /* OpenMutedParticipantListView.swift */, + D5E60FEA77508AA565B02B9B /* OpenMutedParticipantListView+Item.swift */, + 89193DB4600A4F222C0F5524 /* OpenMutedParticipantListView+SubViewBuilder.swift */, + C480862D8A2D16A98B766589 /* OpenMutedParticipantListView+ViewConverter.swift */, + E073AA8CC1B9D07D58D24E07 /* OpenMutedParticipantListViewProvider.swift */, + 0427D1F31F23FD611A340269 /* ViewConverters */, ); - path = Resource; + path = OpenMutedParticipantList; sourceTree = ""; }; F411649E6033B50A3CA28E0A /* SubView */ = { @@ -6129,17 +6258,16 @@ path = SubView; sourceTree = ""; }; - F4CFE4801B95A1CF73BCA630 /* ViewConverters */ = { + F42CC250A593FB030B0EFC79 /* ChannelSettings */ = { isa = PBXGroup; children = ( - 1FDD8BBDA06606723A4BD18E /* OpenOperatorListViewConverter.Header.swift */, - 8F30867017D52BC55BF8A8F2 /* OpenOperatorListViewConverter.List.swift */, - 66DC68119CAB88E61C94C90B /* OpenOperatorListViewConverter.swift */, - 0A85529A02737F4F20AFDCA2 /* SBUOpenOperatorListModule.Header+SwiftUI.swift */, - F363B8C0EDA127F26AAFA8CD /* SBUOpenOperatorListModule.List+SwiftUI.swift */, - 4966B4B124FA577795A56523 /* SBUOpenOperatorListUserCell+SwiftUI.swift */, + 5550B3E5AB07ED184E5C3A84 /* SBUBaseChannelSettingsViewController.swift */, + 0D2EF85B58A833AF96960622 /* SBUGroupChannelSettingsViewController.swift */, + F6255269EEFB1064CBD9ED02 /* SBUOpenChannelSettingsViewController.swift */, + 7DAB15BF254D369416D19C38 /* Cell */, + 0664259FBD1A656D40A93936 /* View */, ); - path = ViewConverters; + path = ChannelSettings; sourceTree = ""; }; F5BE9A44A9158792EF5112DF /* List */ = { @@ -6150,21 +6278,14 @@ path = List; sourceTree = ""; }; - F623ABFB8FDDAB9CDA797E12 /* Replies */ = { - isa = PBXGroup; - children = ( - ED4992F14BC1A4369B0FE99F /* SBUReplyConfiguration.swift */, - ); - path = Replies; - sourceTree = ""; - }; - F62697598C554FC5507864B7 /* NotificationSettings */ = { + F67C53BBB445DA2F5501F5DB /* MessageThread */ = { isa = PBXGroup; children = ( - 13A39F0CA1ACC3DC69F56F19 /* SBUGroupChannelPushSettingsViewController.swift */, - 8AF775560DD8E3D23A9438E9 /* Cell */, + 9C12F2848C78BBE9E222E5A8 /* SBUMessageThreadTitleView.swift */, + B6FD670D57FB0A2380422154 /* SBUMessageThreadViewController.swift */, + F6D788FD7849625F5F58CEDE /* SBUParentMessageInfoView.swift */, ); - path = NotificationSettings; + path = MessageThread; sourceTree = ""; }; F6ED6C448E7B15525C8231F7 /* GroupChannel */ = { @@ -6174,32 +6295,30 @@ 4439F6557CDF210DC11B8761 /* SubView */, 9B848886D5F352ADEF9F717D /* SwiftUI */, BBA522B858545A851732FE37 /* ViewConverter */, + 8AE51A0E28B36B20AF21C743 /* ViewProvider */, ); path = GroupChannel; sourceTree = ""; }; - F7E86A7C3516F5EE0712A8B2 /* Life cycles */ = { + F80235BDD41FD230B2CEBA6B /* Protocol */ = { isa = PBXGroup; children = ( - CCAD3EB06242ACBE685CAC9A /* SBUCollectionViewCell.swift */, - 089EFCFAB4CC0905D70E98F7 /* SBULabel.swift */, - ADE7D91A32DE35288413F142 /* SBUMessageCellProtocol.swift */, - F680D037CDE9E80938B09CC6 /* SBUQuotedMessageViewProtocol.swift */, - 55425279F87879EA393619E1 /* SBUQuoteMessageInputViewProtocol.swift */, - E1D3679B4B2C92ABF5A1CF56 /* SBUTableViewCell.swift */, - 2752645C33797142AEE30A20 /* SBUTextView.swift */, - 3A9D4CF5A5EE6E8646E37865 /* SBUView.swift */, - 13C1A9FF2EF8EC07A88DF01C /* SBUViewLifeCycle.swift */, + 6BBFE7AA481DE52BC6E05814 /* HierarchyScannable.swift */, + D96FF4DECC16108247C2B05F /* MethodOverridable.swift */, + 9D66F6F4842608E7545438C6 /* SendbirdUIProvider.swift */, + 94BC67B1D4514E0EF9894966 /* ViewItemInitialize.swift */, ); - path = "Life cycles"; + path = Protocol; sourceTree = ""; }; - F8A9CA098992AC9A397860E6 /* CarouselView */ = { + F8F32A05ADBC9FFEBB3268C9 /* InviteUser */ = { isa = PBXGroup; children = ( - A7697BCB63E99D1CDCF94905 /* SBUBaseCarouselView.swift */, + 9CA37BC0C06812BB951EC82F /* SBUInviteUserModule.Header.swift */, + 8D84CAF6C762506B85F584E6 /* SBUInviteUserModule.List.swift */, + DD44488053095D7122FB760C /* SBUInviteUserModule.swift */, ); - path = CarouselView; + path = InviteUser; sourceTree = ""; }; F941DF8DA529D9B503FC8EE3 /* SubView */ = { @@ -6210,55 +6329,6 @@ path = SubView; sourceTree = ""; }; - FA878FD989531295C6265A69 /* KeyFunctions */ = { - isa = PBXGroup; - children = ( - 26720279B76892AF626E3EF9 /* CreateGroupChannel */, - D5C140713185B141540B5471 /* CreateOpenChannel */, - 7B9DEDA2978C11A7877A4AD3 /* GroupBannedUserList */, - 6978D272A6E8BD64E4340F40 /* GroupChannel */, - ECD1327DDB295B2E4D3CCF6D /* GroupChannelList */, - 9746CAC1E63BA22614AC01A4 /* GroupChannelPushSettings */, - 272BB6A29A107AC62CCAF485 /* GroupChannelRegisterOperator */, - ED317116892FC3C994B0CA90 /* GroupChannelSettings */, - E7148FD88D840EF176D44954 /* GroupMemberList */, - 2BABC3762D6B1F782AA65EED /* GroupModerations */, - 46AA50892BC29E91F92FE439 /* GroupMutedMemberList */, - D31515481660F2A112791202 /* GroupOperatorList */, - 05CF9587ACD9216080559FB2 /* InviteUser */, - 390039F1F40E3C9A3BB3BA92 /* MessageSearch */, - 1EA70CD99921CBFDA33B44F8 /* MessageThread */, - 864CF6DF200E34DE7762FA7F /* OpenBannedUserList */, - 4A2A535E4636A203F0A94B55 /* OpenChannel */, - C98573E3FAE96141E5E47D88 /* OpenChannelList */, - 0A82322859368BEFE15C56D9 /* OpenChannelRegisterOperator */, - EED8A856C16F72CA5A02BDA3 /* OpenChannelSettings */, - 70739DE86441084058D5FEDF /* OpenModerations */, - 382704CB790510BCF55CDF3B /* OpenMutedParticipantList */, - 9A48CD3DAE53A3FE3194E7D6 /* OpenOperatorList */, - 7F31826B26DDDD70B15B5413 /* OpenParticipantList */, - ); - path = KeyFunctions; - sourceTree = ""; - }; - FAE5FF0B1CD329933C60A9CA /* InviteUser */ = { - isa = PBXGroup; - children = ( - B4EB1DE72843F9F2E4E067BC /* SBUInviteUserModule.Header.swift */, - 8D8C03E266B5DC64D27B8F44 /* SBUInviteUserModule.List.swift */, - C09A08CA49DDC01557C7D096 /* SBUInviteUserModule.swift */, - ); - path = InviteUser; - sourceTree = ""; - }; - FAF7DDD4CDA0585A359B632E /* UserList */ = { - isa = PBXGroup; - children = ( - 1332D36686F1F249E74B711C /* SBUUserListViewModel.swift */, - ); - path = UserList; - sourceTree = ""; - }; FB3600719DCB10837F1DE5AE /* List */ = { isa = PBXGroup; children = ( @@ -6283,15 +6353,6 @@ path = GroupChannelSettings; sourceTree = ""; }; - FC6B44BBB0BD3FC63EFE9ABD /* Mention */ = { - isa = PBXGroup; - children = ( - 9774EC4FF0EB6B296E4A2731 /* SBUMentionConfiguration.swift */, - 3DDDA8624C4543555B800D2C /* SBUUserMentionConfiguration.swift */, - ); - path = Mention; - sourceTree = ""; - }; FC808072EA9185530C86139C /* ViewConverter */ = { isa = PBXGroup; children = ( @@ -6301,22 +6362,14 @@ path = ViewConverter; sourceTree = ""; }; - FCC560EA042B8A46963B2A9F /* MessageSearch */ = { + FD67BD40F7877CE6DFFE8FD5 /* MessageSearch */ = { isa = PBXGroup; children = ( - A6CD877BF4F75C3CE545D26F /* SBUMessageSearchViewModel.swift */, + 32A81BB37AE3190F7AD09F77 /* SBUMessageSearchModule.Deprecated.swift */, ); path = MessageSearch; sourceTree = ""; }; - FD4BB759224750FDE5DF1630 /* Cell */ = { - isa = PBXGroup; - children = ( - 1E15C3CDDBC6D533E0C64E57 /* SBUMessageSearchResultCell.swift */, - ); - path = Cell; - sourceTree = ""; - }; FD8C122F8C1B40968801B60C /* List */ = { isa = PBXGroup; children = ( @@ -6330,823 +6383,92 @@ path = List; sourceTree = ""; }; - FFB511ACFA17729D28F4EAA0 /* View */ = { - isa = PBXGroup; - children = ( - 1A44E48D1D24AA8A93786370 /* CustomGroupOperatorList.SwiftUI.View.CustomMain.swift */, - E8F1CE3F5598712CA3C279EB /* CustomGroupOperatorList.SwiftUI.View.Main.swift */, - ); - path = View; - sourceTree = ""; - }; - FFB666D8293FFB4C896B74B2 /* List */ = { - isa = PBXGroup; - children = ( - 859105D58C941EB14073F9F1 /* CustomInviteUser.ViewConverter.List.entireView.swift */, - 506B49D35067C017A092EB8C /* CustomInviteUser.ViewConverter.List.profileImage.swift */, - 11EC6E379AF8CC994489450D /* CustomInviteUser.ViewConverter.List.rowView.swift */, - 3ED66AF6F0BEFF49609F06E1 /* CustomInviteUser.ViewConverter.List.selectionButton.swift */, - CA1DD2E5AE504E97921165C8 /* CustomInviteUser.ViewConverter.List.userNameLabel.swift */, - ); - path = List; - sourceTree = ""; - }; - "TEMP_0199B5F1-040F-467E-9BBF-D07A22B8B4BB" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_02471739-5B3C-4EE8-9E12-720C18E60858" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_025CB36A-A91B-48FA-AE9F-46EA0F538835" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_08C46386-8870-42CC-A83B-552ECBF79B43" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_0E6F7619-AC35-491D-8953-CE585F92331D" /* GroupUserList */ = { - isa = PBXGroup; - children = ( - ); - path = GroupUserList; - sourceTree = ""; - }; - "TEMP_0E808DED-0F45-48CD-9E84-71456EB389AE" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_0EA3F4BB-5C99-41CF-BD7B-18E4E82507FE" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_1635A3B3-0010-4387-A333-2CECD376033C" /* SubView */ = { + FDAED4D66693708B8E061B50 /* MessageThread */ = { isa = PBXGroup; children = ( + DC5F4EF470234F308512D764 /* SBUMessageThreadModule.Header.swift */, + 8BA4724E320BF5BEB01C0511 /* SBUMessageThreadModule.Input.swift */, + 45C48A775332637B50383C44 /* SBUMessageThreadModule.List.swift */, + 5D04B328AB000735BD52BE9D /* SBUMessageThreadModule.swift */, ); - path = SubView; - sourceTree = ""; - }; - "TEMP_173BD294-DE94-4EE0-A484-FA8FF4A19684" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; + path = MessageThread; sourceTree = ""; }; - "TEMP_1A7D443A-C9A5-4EDA-9512-CAE6DA3F284B" /* ViewController */ = { + FE4800EFEF9571AE5D9FE997 /* MessageThread */ = { isa = PBXGroup; children = ( + 8F6C581AF86F0FDF7EE97402 /* SBUMessageThreadViewModel.swift */, ); - path = ViewController; + path = MessageThread; sourceTree = ""; }; - "TEMP_1AC9A899-BA16-4651-925D-DAA1E579F23D" /* Header */ = { + FEDACCDF3580E7D5971C2DCE /* ViewParams */ = { isa = PBXGroup; children = ( + 108B741FE9BECCEB02800C52 /* SBUSuggestedReplyViewParams.swift */, ); - path = Header; + path = ViewParams; sourceTree = ""; }; - "TEMP_20BC6BFD-0DA0-42A5-B3E0-1A34C6156F11" /* Media */ = { + FF179ECBE873626BCACFED35 /* Constant */ = { isa = PBXGroup; children = ( + 3DD2F8C9F7503629C66F2EEE /* SBUConstant.swift */, + E9758CC43DB1F420CFD323D8 /* SBUDateFormatSet.swift */, + 7D7F84D65D12CFD5BD192CE8 /* SBUStringSet.Deprecated.swift */, + 0C3FA638C505A1130D29CB79 /* SBUStringSet.swift */, ); - path = Media; + path = Constant; sourceTree = ""; }; - "TEMP_225881CC-0747-416B-8DB2-2AB9B51856AB" /* Common */ = { + FF1AFDDF70B7339933D66D0E /* Common */ = { isa = PBXGroup; children = ( + 41F67E3AB37F20407F559B51 /* SBUCommonModule.swift */, ); path = Common; sourceTree = ""; }; - "TEMP_2339DD66-3A1B-4124-B1E1-B8C9AA5B6990" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_23451FB0-253D-42AC-A699-687DB3C7B57F" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_2415A6A8-8956-41F7-9CE5-B29AA8D10BE7" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_27D39984-FAB5-4BDA-9BE2-489F32B0909C" /* Common */ = { + FFB511ACFA17729D28F4EAA0 /* View */ = { isa = PBXGroup; children = ( + 1A44E48D1D24AA8A93786370 /* CustomGroupOperatorList.SwiftUI.View.CustomMain.swift */, + E8F1CE3F5598712CA3C279EB /* CustomGroupOperatorList.SwiftUI.View.Main.swift */, ); - path = Common; + path = View; sourceTree = ""; }; - "TEMP_3143116A-FB64-4E48-8C7B-6FB2F7B6C0F5" /* List */ = { + FFB666D8293FFB4C896B74B2 /* List */ = { isa = PBXGroup; children = ( + 859105D58C941EB14073F9F1 /* CustomInviteUser.ViewConverter.List.entireView.swift */, + 506B49D35067C017A092EB8C /* CustomInviteUser.ViewConverter.List.profileImage.swift */, + 11EC6E379AF8CC994489450D /* CustomInviteUser.ViewConverter.List.rowView.swift */, + 3ED66AF6F0BEFF49609F06E1 /* CustomInviteUser.ViewConverter.List.selectionButton.swift */, + CA1DD2E5AE504E97921165C8 /* CustomInviteUser.ViewConverter.List.userNameLabel.swift */, ); path = List; sourceTree = ""; }; - "TEMP_317F1320-F30C-418A-A756-5FF374B96BFC" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_3819E504-C8F3-40E0-8387-B8F509DE722B" /* Common */ = { - isa = PBXGroup; - children = ( - ); - path = Common; - sourceTree = ""; - }; - "TEMP_3873B46D-D627-4064-B8BF-DFF8DD1D1415" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_3A5F639C-1FE5-4433-BF7B-30013C5A33B7" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_3BDF53DC-56D5-4ADF-81A4-400FF1513B21" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_3DF712FB-CD7B-48F5-8B47-95E82BA3034E" /* Common */ = { - isa = PBXGroup; - children = ( - ); - path = Common; - sourceTree = ""; - }; - "TEMP_3F7FFB37-90BF-4742-92A3-5F425BEDE932" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_409F7DDC-5808-4BB0-B0CD-446D9E956D86" /* ChannelList */ = { - isa = PBXGroup; - children = ( - ); - path = ChannelList; - sourceTree = ""; - }; - "TEMP_41072BFA-9CCD-487F-A37C-6368077922B1" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_4193D5DF-380D-4EBA-B351-8F17A3848133" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_41B9DFCC-2E02-4168-A4E4-37880B2352DB" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_44C6D2F6-F195-4E4A-BFC9-CEB560293156" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_46838470-23E6-4052-964D-67A9FD971B25" /* Module */ = { + FFEE44BE0FBAF54BD9260056 /* ViewConverters */ = { isa = PBXGroup; children = ( + 213BF3497B6FD30B17654CF0 /* GroupChannelViewConverter.Header.swift */, + 42FB13DE92ED80900AD05054 /* GroupChannelViewConverter.Input.swift */, + AF2301F651B24A4E16EFAEA8 /* GroupChannelViewConverter.List.swift */, + 1A8DD774054C5168961DF04B /* GroupChannelViewConverter.swift */, + CA4BAF0DBCE4A96D3835303E /* SBUBaseMessageCell+SwiftUI.swift */, + 1758AEB45338E3698851ED34 /* SBUChannelStateBanner+SwiftUI.swift */, + 1CF9D34BCB427438C4E21B0B /* SBUChannelTitleView+SwiftUI.swift */, + 34ED39256240C5DA35BDC807 /* SBUGroupChannelModule.Header+SwiftUI.swift */, + CBFB50A8249F3AF8106E3D7E /* SBUGroupChannelModule.Input+SwiftUI.swift */, + 149EF5C6D56F66FA509EA283 /* SBUGroupChannelModule.List+SwiftUI.swift */, + 3FFC8EB13F480E8BEAFC5E6A /* SBUGroupChannelViewController+SwiftUI.swift */, + 887FB1AF021C77AE2658CF59 /* SBUMessageInputView+SwiftUI.swift */, + 3C1EBEBB49DB9D9129545F68 /* SBUNewMessageInfo+SwiftUI.swift */, + 8A5D3AAD48890B67F36BEE43 /* SBUScrollBottomView+SwiftUI.swift */, ); - path = Module; - sourceTree = ""; - }; - "TEMP_4A97F98C-D4CA-4C22-810A-D3C8C661F022" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_4C282AB2-5EFA-45F7-B9BC-6F0E750D584D" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_55682535-79CB-4B36-9E3A-97C18594274C" /* Common */ = { - isa = PBXGroup; - children = ( - ); - path = Common; - sourceTree = ""; - }; - "TEMP_5973BC32-3460-4505-A32A-1B1D0B5F48FB" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_5F5D8D9D-A99B-4630-9102-6EF268E35078" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_5FE9C742-07F6-455A-821C-F4E832501F64" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_61098632-2EB5-41D4-AC74-C4811BAAA4CA" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_613D22F3-BAAC-4B81-A273-94838ACC3FA5" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_62812BF7-CAC2-4D5C-9351-105E1BB1B510" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_62B4B2A7-8317-4894-9407-DCF65384B1F0" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_646E2CE9-8651-46EF-8856-ACE526DCDC14" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_65DC2D1E-5E26-48D8-983A-1290BEF4DB79" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_65FFD230-27C6-4F4B-8E8E-18CE96E9E866" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_689FFFB8-ED79-4C22-B83A-E1485B296F3F" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_6B2C9AD2-30A1-4923-90EB-7DE8DC995446" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_6CA16752-E00B-479C-85EA-15533B718A8E" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_6F2B3EC9-B20A-498A-AC07-378DCC9630C3" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_70F419A9-1C40-4D0C-AF24-0EDB0776F4E8" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_74318616-CE6D-4A28-B86E-115D1D27B66F" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_74D04BEE-7157-43C8-B20F-6BF1128ED36D" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_79B5EB14-03C9-4F3C-ACB1-150B217E95AD" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_7EC57E55-73F0-4DAD-BC14-4E8B30A9BB36" /* ProfileInput */ = { - isa = PBXGroup; - children = ( - ); - path = ProfileInput; - sourceTree = ""; - }; - "TEMP_7F7AADE2-391B-4EC8-9A54-D16E81D80F94" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_81161FA1-8713-4F4A-8FBC-3848C6C62AD5" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_811BC954-4657-4F0D-BF09-58890F3F3AFD" /* Common */ = { - isa = PBXGroup; - children = ( - ); - path = Common; - sourceTree = ""; - }; - "TEMP_814AEAD3-DDDC-4955-A6AC-F71DD7372C5F" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_81CDE4E6-FFD3-4DA7-BDA9-70E709AAA2AF" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_82376388-4A67-49E4-9431-8C72A30E0B0A" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_848C092D-913D-4594-A402-7CBA82F7876E" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_870C7ADF-175E-460A-B5F1-44CAEA3D6929" /* Theme */ = { - isa = PBXGroup; - children = ( - ); - path = Theme; - sourceTree = ""; - }; - "TEMP_88670E69-660A-4F09-A7EA-8E8C4CB5B989" /* OpenUserList */ = { - isa = PBXGroup; - children = ( - ); - path = OpenUserList; - sourceTree = ""; - }; - "TEMP_8BD0971F-FE5B-42AF-B7ED-B1A2C2ADB84A" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_8CF6B64B-BA6F-406D-989A-55F7E9836569" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_91EADA65-D21F-4A8B-B042-1BEC1BAE377B" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_94ABD6DC-B3E2-4D22-8B43-44660EC50089" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_9571C300-FC8F-4242-A8CB-EA8180724E52" /* Input */ = { - isa = PBXGroup; - children = ( - ); - path = Input; - sourceTree = ""; - }; - "TEMP_9A1ECB13-443D-482C-BB54-CA2996793289" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_A0759ACE-4384-4F60-ABF6-9D9C5D872068" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_A1BB9F1A-5F94-4933-B9AD-FBA51704E77C" /* Input */ = { - isa = PBXGroup; - children = ( - ); - path = Input; - sourceTree = ""; - }; - "TEMP_A5E191D8-310A-473E-BA94-C8BC293E62AE" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_A644B64E-AF07-43A1-B5A4-57AD21B3D4C5" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_B0BE5BB2-4F31-484B-A36A-843B3DBBA68D" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_B0CB75D5-5643-4AA6-A762-52FF0E894239" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_B1AE3BE0-63F0-4023-ACB7-5FFD8ACE1584" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_B4035116-9032-4B5F-A12F-084F4B885B5B" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_B40BAED1-EABE-455C-B2E1-A96BD60CC351" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_B6783EA1-5281-4E38-86BD-8650F87D4516" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_B79DA308-D60E-468F-9ABD-3E20620233DC" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_B95FC551-0CA3-4BF5-9953-69BD94EBD154" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_BCE54956-A4EA-4CA9-AA3C-FCC3392C3679" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_BD5785B0-37EB-415D-8F3B-98F66FB02A16" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_BE362144-282E-40CF-A021-965A21688A74" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_BF3996B5-27FA-4CC6-8F3D-01219BE1DB83" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_C1446A09-9ED1-4070-BCEE-3E1C6E8B8300" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_C3F2CD73-0F3E-4475-9C63-0AB401C3BFA8" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_C5CB1645-8EA9-49BD-9804-5D9348DCE957" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_C7E365B6-F62A-4594-9C0C-48D88188CC16" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_CCA76708-002C-45B9-8F50-3493229AEF97" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_D02561DF-BF3E-4DAF-A783-9CAC1EAA6DE0" /* SubView */ = { - isa = PBXGroup; - children = ( - ); - path = SubView; - sourceTree = ""; - }; - "TEMP_D1553DF1-3694-436D-B3F6-74D060F4F762" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_D5EE2F71-F5AC-4BB7-AD9B-C0B72220A0AC" /* Input */ = { - isa = PBXGroup; - children = ( - ); - path = Input; - sourceTree = ""; - }; - "TEMP_D65C69CD-8778-4190-AB8D-AE7B3A643D13" /* Common */ = { - isa = PBXGroup; - children = ( - ); - path = Common; - sourceTree = ""; - }; - "TEMP_D82F5679-6247-42F2-A125-E009CC61CAE2" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_D9C94377-5DB5-4F30-BA1D-A6C1AC80E705" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_DD4153B7-4646-4619-8490-29D6AF720D52" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_DE818E13-A7AA-4187-9764-D82EFE4A5100" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_E3343F39-CA75-4F83-BE91-26AFA69356F4" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_E5C50754-0F13-4365-9663-7085B6CE45F6" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_E5CDBDA4-96E5-48DD-906D-D67F27668D7B" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_E6DD23CE-2223-4A2D-A2ED-FDCF36B3FD6B" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_E88BD22A-CFA5-4EA0-9DBB-8803B7F676A1" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_EA7D23C3-A3A5-4AAE-A1A4-F226B89A01FE" /* List */ = { - isa = PBXGroup; - children = ( - ); - path = List; - sourceTree = ""; - }; - "TEMP_EA8C9BA0-D7E9-4AF9-BCA0-20E952B6972D" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_EAF0CC42-EA53-456B-8A79-DBC12B7F7C90" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_EBF5A73E-9835-4D7D-B3E0-DB4CAE645342" /* ViewModel */ = { - isa = PBXGroup; - children = ( - ); - path = ViewModel; - sourceTree = ""; - }; - "TEMP_EDADB98C-8C00-4A47-AF42-476D7433A3E8" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_EE4480FF-D685-4A2A-BF63-350ECE0087A2" /* Common */ = { - isa = PBXGroup; - children = ( - ); - path = Common; - sourceTree = ""; - }; - "TEMP_F06B3F5E-9713-445B-A84F-FA7A4458C10B" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_F3D901A5-BB5B-4293-84BC-B3862C66DAF2" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_F7E86B88-BA0A-4753-B8FD-CC5EBC0A1A13" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; - sourceTree = ""; - }; - "TEMP_F82E4BAB-ECD9-4647-B0D8-801B30547DA0" /* Header */ = { - isa = PBXGroup; - children = ( - ); - path = Header; - sourceTree = ""; - }; - "TEMP_FD0B8116-03BF-4B92-A45E-B87CC957B40A" /* ViewController */ = { - isa = PBXGroup; - children = ( - ); - path = ViewController; - sourceTree = ""; - }; - "TEMP_FFE1E3EC-FD58-4BA0-9EFB-BAF17B0B75E4" /* Module */ = { - isa = PBXGroup; - children = ( - ); - path = Module; + path = ViewConverters; sourceTree = ""; }; /* End PBXGroup section */ @@ -7236,11 +6558,11 @@ buildActionMask = 2147483647; files = ( 365BF21AE71ADD004BB3E90C /* Assets.xcassets in Resources */, - E0BABA0802B060E1E05A0619 /* Assets.xcassets in Resources */, + E1A131376C16EFFC6BA88B13 /* Assets.xcassets in Resources */, 60EF40371E0D2FAAAEDBE67F /* Preview Assets.xcassets in Resources */, - 5F0CD15B81AEF734A6BB58B2 /* PrivacyInfo.xcprivacy in Resources */, + 2F6552E42111CF1071C53AE7 /* PrivacyInfo.xcprivacy in Resources */, DDEBAC0217F9BC12F921A9DA /* SampleListSwiftUI.json in Resources */, - AEF46BD164C362CD5EBF9465 /* SendbirdSwiftUI-Info.plist in Resources */, + CAD5634D9186CE5B8CE63350 /* SendbirdSwiftUI-Info.plist in Resources */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -7260,30 +6582,32 @@ buildActionMask = 2147483647; files = ( 68D90A52B6C2C9D42608FC0C /* AppDelegate.swift in Sources */, - 68157C9AB11657EA24F5905E /* Array+SBUIKit.swift in Sources */, - 1D318FFF730CD58BF3E3D03C /* BaseMessage+SBUIKit.MessageTemplate.swift in Sources */, - C4C05BC8629DD4511D1985CB /* BaseMessage+SBUIKit.swift in Sources */, - 2730E7FEBE4EEE5FD355C129 /* BaseMesssage+SBUIKit.Deprecated.swift in Sources */, - F5772B2CEAEA30A1D216D7EA /* BlockingOperation.swift in Sources */, - B21B643C3844046E8C438632 /* CGSize+SBUIKit.swift in Sources */, - 4A973AFD762FD1B7F89623BE /* Closure.swift in Sources */, - 3C38D2CD22DE4C08D0D8648B /* Collection+SBUIKit.swift in Sources */, - 5E70C58C2056996F5402894C /* Color+Sendbird.swift in Sources */, - 4C1887A9486E5139B141C3C8 /* ColorSet.swift in Sources */, - 142C04F278D263E09B627C49 /* CommonProtocols.swift in Sources */, - B29DA0496FF6163137BB240A /* CreateGroupChannelView+Item.swift in Sources */, - EB37271035E9D01B69E5249C /* CreateGroupChannelView+SubViewBuilder.swift in Sources */, - 2F7984DB4A3D3ED837F85766 /* CreateGroupChannelView+ViewConverter.swift in Sources */, - 0AF54942AA36849D498811A3 /* CreateGroupChannelView.swift in Sources */, - 8BD19388485B644E8C55B428 /* CreateGroupChannelViewConverter.Header.swift in Sources */, - D6F64CCAC890DE60919658F3 /* CreateGroupChannelViewConverter.List.swift in Sources */, - 03C5991A0F934387C4886CF7 /* CreateGroupChannelViewConverter.swift in Sources */, - CB67A3634CE05B28F746BA2B /* CreateOpenChannelView+Item.swift in Sources */, - B7166941961D1B94400DE836 /* CreateOpenChannelView+SubViewBuilder.swift in Sources */, - 4BF7588B345B441B33943F13 /* CreateOpenChannelView+ViewConverter.swift in Sources */, - 17CB908AC8EE4178560C893D /* CreateOpenChannelView.swift in Sources */, - 1BD0F8B3D9A84B0192BFB452 /* CreateOpenChannelViewConverter.Header.swift in Sources */, - BAB3E05D8911CB8AD0EFA300 /* CreateOpenChannelViewConverter.swift in Sources */, + F1D93E30B153BDDC5DA67761 /* Array+SBUIKit.swift in Sources */, + 408FB60AFA6FF6716A2FF2F6 /* BaseMessage+SBUIKit.MessageTemplate.swift in Sources */, + 19094B7F7BADCE19F493BE65 /* BaseMessage+SBUIKit.swift in Sources */, + B78E2FBB68188E9E662E6049 /* BaseMesssage+SBUIKit.Deprecated.swift in Sources */, + 6315B53F26C8043E49F161CD /* BlockingOperation.swift in Sources */, + 69BF779A7D4711A8036D259E /* CGSize+SBUIKit.swift in Sources */, + A612018F4F6F6812C42F980A /* Closure.swift in Sources */, + BDA937E14112A6694081A51A /* Collection+SBUIKit.swift in Sources */, + AF0BC7C82BB194D6588FC701 /* Color+Sendbird.swift in Sources */, + E8F988401EB92C4C0B30EA9F /* ColorSet.swift in Sources */, + F7B48FD0D8901203FBD4F72E /* CommonProtocols.swift in Sources */, + D821D3F623937C7A515003E5 /* CreateGroupChannelView+Item.swift in Sources */, + 773421C3BDBEAAA97B75EA80 /* CreateGroupChannelView+SubViewBuilder.swift in Sources */, + 2BCA6E8FABBD51F391AB236E /* CreateGroupChannelView+ViewConverter.swift in Sources */, + EC5E164049C5223D55316F1F /* CreateGroupChannelView.swift in Sources */, + BD4FCEF79F02239658DDE0F1 /* CreateGroupChannelViewConverter.Header.swift in Sources */, + 4DEAB3D627359FFF30497182 /* CreateGroupChannelViewConverter.List.swift in Sources */, + 41CD9DDB6951A3AA52432650 /* CreateGroupChannelViewConverter.swift in Sources */, + 1BE244E44E2C84BB2724B395 /* CreateGroupChannelViewProvider.swift in Sources */, + 9C747C5E2F5C360322DADF09 /* CreateOpenChannelView+Item.swift in Sources */, + 9F77C728DC49F47B631A8C81 /* CreateOpenChannelView+SubViewBuilder.swift in Sources */, + C50643A3484C62BDF5EC2CDB /* CreateOpenChannelView+ViewConverter.swift in Sources */, + AA2CE74FA3344DC91B5F0046 /* CreateOpenChannelView.swift in Sources */, + A4B9AAE7FC00153957A17A93 /* CreateOpenChannelViewConverter.Header.swift in Sources */, + BCE8437AE06CB19FEDD03501 /* CreateOpenChannelViewConverter.swift in Sources */, + 4605B12AAF79EFE43B741F51 /* CreateOpenChannelViewProvider.swift in Sources */, 04C96B7EDDA3BD7ACBB84DC7 /* CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift in Sources */, 1BF954C4BA7EC179AEB8761A /* CustomCreateGroupChannel.SwiftUI.View.Main.swift in Sources */, 58A4E06F7E98AA1A3017ED4E /* CustomCreateGroupChannel.ViewConverter.Header.leftView.swift in Sources */, @@ -7321,6 +6645,7 @@ 903DBFB0B613666FBA5EF8CE /* CustomGroupChannel.SubView.Builder.messageThread.swift in Sources */, 475E9ED72413154DBBE99F31 /* CustomGroupChannel.SwiftUI.View.CustomMain.swift in Sources */, 7B4CC35E4C7C82E83A235DBA /* CustomGroupChannel.SwiftUI.View.Main.swift in Sources */, + 559125F39CD9442DB4EF2647 /* CustomGroupChannel.SwiftUI.View.ViewProvider.swift in Sources */, D00EBD058B6290476424286D /* CustomGroupChannel.ViewConverter.Header.coverImage.swift in Sources */, DE92BC068203145AD72AA823 /* CustomGroupChannel.ViewConverter.Header.leftView.swift in Sources */, A465F00A70A21F02A988B7F5 /* CustomGroupChannel.ViewConverter.Header.rightView.swift in Sources */, @@ -7349,6 +6674,7 @@ B27BA50D96C21A0BB77AFEAC /* CustomGroupChannelList.SubView.Builder.groupChannel.swift in Sources */, 0152DA39617EFC76210E6B13 /* CustomGroupChannelList.SwiftUI.View.CustomMain.swift in Sources */, AEA5D95F169E48B4D7D89411 /* CustomGroupChannelList.SwiftUI.View.Main.swift in Sources */, + 732DC716016B3A65E12A6F35 /* CustomGroupChannelList.SwiftUI.View.ViewProvider.swift in Sources */, 2F2D3E90ADA787E578E8E451 /* CustomGroupChannelList.ViewConverter.Header.leftView.swift in Sources */, 4554AA4AD82307F6B48CDB34 /* CustomGroupChannelList.ViewConverter.Header.rightView.swift in Sources */, 274ED45E7CD81CCB535C1063 /* CustomGroupChannelList.ViewConverter.Header.titleView.swift in Sources */, @@ -7602,716 +6928,744 @@ A5852413BF1411566CD19A01 /* CustomTheme.IconSet.Custom.Main.swift in Sources */, CFF408133CDD3D4F8217D2B7 /* CustomTheme.Theme.Custom.Main.swift in Sources */, F9CF4B42BDC33490C9BB589C /* CustomTheme.swift in Sources */, - 6235200FC11DFE84A4E4B8FE /* Data+SBUIKit.swift in Sources */, - 5C826B25A6BCB1399506A22D /* Date+SBUIKit.swift in Sources */, - 5CC915DBD67E6C0749F53DF2 /* DefaultViewConfigSet.swift in Sources */, - 792582B380251061DC474C41 /* Float+SBUIKit.swift in Sources */, - D8A595CFD9892DAB66088428 /* FontSet.swift in Sources */, - 654ADA1832E52D1D4E90DBCA /* Formatter+SBUIKit.swift in Sources */, - 7C068B2032F4D86F52C73E1E /* GroupBannedUserListView+Item.swift in Sources */, - 5688556E00B70FAFC8B1F1D1 /* GroupBannedUserListView+SubViewBuilder.swift in Sources */, - F5CF20AEACC99716A0208ADE /* GroupBannedUserListView+ViewConverter.swift in Sources */, - FEED40940CB9F74F00756D9B /* GroupBannedUserListView.swift in Sources */, - 36A3637008B84DDD9559D115 /* GroupBannedUserListViewConverter.Header.swift in Sources */, - F1A6CCACDA3EDC4EB8401ACD /* GroupBannedUserListViewConverter.List.swift in Sources */, - 8DAC02831AB61867EE26A452 /* GroupBannedUserListViewConverter.swift in Sources */, - E91CF381A3962D99614DD552 /* GroupChannelListView+Item.swift in Sources */, - 75117163F51C9A2BBDDC7E5A /* GroupChannelListView+SubViewBuilder.swift in Sources */, - 0A96B6FBD0FA827EE12AE507 /* GroupChannelListView+ViewConverter.swift in Sources */, - 2E3C7D635CD0FA4006D59F09 /* GroupChannelListView.swift in Sources */, - 4CE62412DE9C4DDEA553A108 /* GroupChannelListViewConverter.Header.swift in Sources */, - 2320A12AD4A24FD50A506784 /* GroupChannelListViewConverter.List.swift in Sources */, - 9924714A0BD418EE3C24A082 /* GroupChannelListViewConverter.swift in Sources */, - 0E7BF9CB04DF1C6EE821C217 /* GroupChannelPushSettingsView+Item.swift in Sources */, - 5FA6862B351607948BEAE4C0 /* GroupChannelPushSettingsView+SubViewBuilder.swift in Sources */, - 455AB5F789FF5433C815713A /* GroupChannelPushSettingsView+ViewConverter.swift in Sources */, - 2935EDC7B2624F7A96E8A053 /* GroupChannelPushSettingsView.swift in Sources */, - 4E27A2AD62CFD82641C2120C /* GroupChannelPushSettingsViewConverter.Header.swift in Sources */, - 277D34A3FAE8C92339162228 /* GroupChannelPushSettingsViewConverter.List.swift in Sources */, - 7C22CFA5895EDA53C558CD83 /* GroupChannelPushSettingsViewConverter.swift in Sources */, - A4718FA92012A938757A27D0 /* GroupChannelRegisterOperatorView+Item.swift in Sources */, - 743C7FE64559E35EA4B3DFB8 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift in Sources */, - 0B34A5551E2DED6ADDE63CFF /* GroupChannelRegisterOperatorView+ViewConverter.swift in Sources */, - C77A7F907D674791B6263F68 /* GroupChannelRegisterOperatorView.swift in Sources */, - B4761F82F3CED19B2045303B /* GroupChannelRegisterOperatorViewConverter.Header.swift in Sources */, - 93BF2059C2DF0F1EC0060562 /* GroupChannelRegisterOperatorViewConverter.List.swift in Sources */, - C207DC73361FA2B44E7B1870 /* GroupChannelRegisterOperatorViewConverter.swift in Sources */, - 79D6BB20F171C134F9110FBF /* GroupChannelSettingsView+Item.swift in Sources */, - ABE339EB7B283F5586A58AD1 /* GroupChannelSettingsView+SubViewBuilder.swift in Sources */, - BD2F982C9CA605F747407620 /* GroupChannelSettingsView+ViewConverter.swift in Sources */, - 7F83A3EFDCBEE6F0F0399F36 /* GroupChannelSettingsView.swift in Sources */, - 8C05C14DCABBADAD4001D1B4 /* GroupChannelSettingsViewConverter.Header.swift in Sources */, - D7A6DA898753003B05ECC100 /* GroupChannelSettingsViewConverter.List.swift in Sources */, - 88D1F877842116D504E90183 /* GroupChannelSettingsViewConverter.swift in Sources */, - 322C065074646D69A67ACB53 /* GroupChannelView+Item.swift in Sources */, - F53F8FC2A1793955B9D352B3 /* GroupChannelView+SubViewBuilder.swift in Sources */, - 9451864888CCCDA64A869927 /* GroupChannelView+ViewConverter.swift in Sources */, - 49D022117EB3895DD034F970 /* GroupChannelView.swift in Sources */, - 154F02373DE0C18BD9E6A507 /* GroupChannelViewConverter.Header.swift in Sources */, - 06D249E19B196DEDEE19BF55 /* GroupChannelViewConverter.Input.swift in Sources */, - 17588F67A5F570D5DBB9C5F6 /* GroupChannelViewConverter.List.swift in Sources */, - 988B779C6CFD4268F45260E3 /* GroupChannelViewConverter.swift in Sources */, + 15BD2E6ABE5303E3D71DEAEC /* Data+SBUIKit.swift in Sources */, + 9AFC2DF88D531002F954E169 /* Date+SBUIKit.swift in Sources */, + 2CCB577D34A9FFFD7F35E985 /* DefaultViewConfigSet.swift in Sources */, + C00C9CAB781ACDABF47D4BC3 /* Float+SBUIKit.swift in Sources */, + 53E5046D24EFD425EE0B8F01 /* FontSet.swift in Sources */, + 28B038F489F6B33DF70C5A30 /* Formatter+SBUIKit.swift in Sources */, + F7F5896DD491728C5E9CBBB6 /* GroupBannedUserListView+Item.swift in Sources */, + 93A5253A6300B53E76CB790C /* GroupBannedUserListView+SubViewBuilder.swift in Sources */, + 48061E8A6A2CCB8E3B410263 /* GroupBannedUserListView+ViewConverter.swift in Sources */, + 1CB2BEA9D7D6D449E421FDAF /* GroupBannedUserListView.swift in Sources */, + 016DE4771424BCB5E36BD8A0 /* GroupBannedUserListViewConverter.Header.swift in Sources */, + 0E80D604138939D542FFA19D /* GroupBannedUserListViewConverter.List.swift in Sources */, + F813C6C440C80E0BB2E3308D /* GroupBannedUserListViewConverter.swift in Sources */, + DB356896BCA044665B242399 /* GroupBannedUserListViewProvider.swift in Sources */, + BF44B13C27389915301FAC9E /* GroupChannelListView+Item.swift in Sources */, + D3F9C1EA89B6F0CD309F1661 /* GroupChannelListView+SubViewBuilder.swift in Sources */, + 82CF1DEDA7BCF6604A4F71EA /* GroupChannelListView+ViewConverter.swift in Sources */, + 720FE9F17A79B4B6532208C3 /* GroupChannelListView.swift in Sources */, + 3DD80CFCD55FBB553006697D /* GroupChannelListViewConverter.Header.swift in Sources */, + 708AC741FBF6A69E783E2479 /* GroupChannelListViewConverter.List.swift in Sources */, + 897709A55B9AD396E995FA94 /* GroupChannelListViewConverter.swift in Sources */, + 13C6CA31E98C268D30A31DD2 /* GroupChannelListViewProvider.swift in Sources */, + A2FFDF9BF98C367994572B63 /* GroupChannelProvider.swift in Sources */, + 55E263152DBC2B5C6AFB2264 /* GroupChannelPushSettingsView+Item.swift in Sources */, + B65F35ECA4F3F6A7A7F68E69 /* GroupChannelPushSettingsView+SubViewBuilder.swift in Sources */, + A9CD60BC674C032FF02F6D95 /* GroupChannelPushSettingsView+ViewConverter.swift in Sources */, + EB5A669D541805381D676CB9 /* GroupChannelPushSettingsView.swift in Sources */, + 3EAB7553CB0F367BBF523B43 /* GroupChannelPushSettingsViewConverter.Header.swift in Sources */, + E5F26019AAED4891982FAACF /* GroupChannelPushSettingsViewConverter.List.swift in Sources */, + 9081981B8E347C8838FE1FD6 /* GroupChannelPushSettingsViewConverter.swift in Sources */, + ABCA7C46182351476744F40C /* GroupChannelPushSettingsViewProvider.swift in Sources */, + 504AE9E9D6FBB8E1F61C5B5E /* GroupChannelRegisterOperatorView+Item.swift in Sources */, + FC1C8336C2A542C53995CC20 /* GroupChannelRegisterOperatorView+SubViewBuilder.swift in Sources */, + 51CEBEBE26D74913FBFCE2EF /* GroupChannelRegisterOperatorView+ViewConverter.swift in Sources */, + 7E503FBB0F614CE6D6C58B74 /* GroupChannelRegisterOperatorView.swift in Sources */, + 4E007D3C096B3D2701B98E02 /* GroupChannelRegisterOperatorViewConverter.Header.swift in Sources */, + 467ADACA3CEE437F94B398EE /* GroupChannelRegisterOperatorViewConverter.List.swift in Sources */, + 2D53DA1CB3608B2DC8C8B7AC /* GroupChannelRegisterOperatorViewConverter.swift in Sources */, + A88E7548C11E04317EE9D855 /* GroupChannelRegisterOperatorViewProvider.swift in Sources */, + 06C16919548225224D687E8A /* GroupChannelSettingsView+Item.swift in Sources */, + 7D29700D11022FFE16975E59 /* GroupChannelSettingsView+SubViewBuilder.swift in Sources */, + BFBB9B2EDB48DD75A4C3614A /* GroupChannelSettingsView+ViewConverter.swift in Sources */, + C58CC900E4D3FC4ACA86E071 /* GroupChannelSettingsView.swift in Sources */, + D3693F5B3C5BDA0970AE976C /* GroupChannelSettingsViewConverter.Header.swift in Sources */, + 98B9324E525A1611FD031F15 /* GroupChannelSettingsViewConverter.List.swift in Sources */, + 533FDED6A7724E8193950C67 /* GroupChannelSettingsViewConverter.swift in Sources */, + 907FE25370A7D68DB6F0209B /* GroupChannelSettingsViewProvider.swift in Sources */, + 945F6D5FA19FAFDF9E93BDB6 /* GroupChannelView+Item.swift in Sources */, + 301FA916AB35E6A7C7E8E383 /* GroupChannelView+SubViewBuilder.swift in Sources */, + 4E2A62BFF5497BBDA4C1FFAE /* GroupChannelView+ViewConverter.swift in Sources */, + 489DF91B622A88716BD787D4 /* GroupChannelView.swift in Sources */, + 29F018998FA0D33982DF2898 /* GroupChannelViewConverter.Header.swift in Sources */, + 1985015BBDC92D9FFFCDCC12 /* GroupChannelViewConverter.Input.swift in Sources */, + 97522EEDE55AD9E175A983EE /* GroupChannelViewConverter.List.swift in Sources */, + 92CE5BC278D9D9658BC0880A /* GroupChannelViewConverter.swift in Sources */, DAD48567A2CD30ED5AA7DBD6 /* GroupChannelsView.swift in Sources */, - B279902A41FCE05DA0D03EFF /* GroupMemberListView+Item.swift in Sources */, - BB28F057F39AF3F0542A9A37 /* GroupMemberListView+SubViewBuilder.swift in Sources */, - 7E764BE12CFEB2DC1EC00B68 /* GroupMemberListView+ViewConverter.swift in Sources */, - 5255221FF6079D13240B56B2 /* GroupMemberListView.swift in Sources */, - 550B147EF5CC390139390EB7 /* GroupMemberListViewConverter.Header.swift in Sources */, - E9B907682BD46AAB30DE9A90 /* GroupMemberListViewConverter.List.swift in Sources */, - F7CBD1BF0C0DA146850E183B /* GroupMemberListViewConverter.swift in Sources */, - D3B5643C1E822D974328D4BB /* GroupModerationsView+Item.swift in Sources */, - 380D86806369B8B85ACCC8F7 /* GroupModerationsView+SubViewBuilder.swift in Sources */, - A9C0F58134C8FA628F88BAA0 /* GroupModerationsView+ViewConverter.swift in Sources */, - 444B563CE4133A9F78848657 /* GroupModerationsView.swift in Sources */, - B49340B1138D31ACA4902A70 /* GroupModerationsViewConverter.Header.swift in Sources */, - 9E599AC42738008C9653577A /* GroupModerationsViewConverter.List.swift in Sources */, - 1D2B28D0D92973CF4081216C /* GroupModerationsViewConverter.swift in Sources */, - 9FCDF683381D89D80DB2F4B4 /* GroupMutedMemberListView+Item.swift in Sources */, - F6141B649B6A71EA303E2C97 /* GroupMutedMemberListView+SubViewBuilder.swift in Sources */, - 16E9FF91ED8E29009296D913 /* GroupMutedMemberListView+ViewConverter.swift in Sources */, - BF6BC0EFDA8F015F66A42EAC /* GroupMutedMemberListView.swift in Sources */, - 7397E736C9B53B71C241F874 /* GroupMutedMemberListViewConverter.Header.swift in Sources */, - F64D48E9E16C47955FBD70F7 /* GroupMutedMemberListViewConverter.List.swift in Sources */, - 23C626C143D5E5872BFBAC6E /* GroupMutedMemberListViewConverter.swift in Sources */, - 188A4D6E24B8CF4AF46670BC /* GroupOperatorListView+Item.swift in Sources */, - 1B6A2888CA898D3252A92F6F /* GroupOperatorListView+SubViewBuilder.swift in Sources */, - DF8E37A2811986DDD4084B36 /* GroupOperatorListView+ViewConverter.swift in Sources */, - A8B6751568500B27EFEE7A4D /* GroupOperatorListView.swift in Sources */, - 374873069DFF6964CED424C4 /* GroupOperatorListViewConverter.Header.swift in Sources */, - 0CB77FFE192888B064D9AE52 /* GroupOperatorListViewConverter.List.swift in Sources */, - 9909715615D788746045692B /* GroupOperatorListViewConverter.swift in Sources */, - C293FDB62B3980DDAEDF4C79 /* HandlerSet.swift in Sources */, - B41BEC11C0A54A6D241D2404 /* HierarchyScannable.swift in Sources */, + 827226E24E8063114A293903 /* GroupMemberListView+Item.swift in Sources */, + 147B46CF860FB32B3C32D97E /* GroupMemberListView+SubViewBuilder.swift in Sources */, + 166F9E7A0021FDD057EFF4DE /* GroupMemberListView+ViewConverter.swift in Sources */, + B1C294C82A0ED7345B0DECF8 /* GroupMemberListView.swift in Sources */, + 36DD391A8F890A0561D682D3 /* GroupMemberListViewConverter.Header.swift in Sources */, + FCE76CEE7EEBEF09DACF1FF1 /* GroupMemberListViewConverter.List.swift in Sources */, + 6CC5FCB02E843FEC5A95FFCF /* GroupMemberListViewConverter.swift in Sources */, + 7BA56FCC53B4ACEF17667EBA /* GroupMemberListViewProvider.swift in Sources */, + BD78CDDE8476EBD510911D70 /* GroupModerationsView+Item.swift in Sources */, + 8F3CD21218E4FA2DDD4C339C /* GroupModerationsView+SubViewBuilder.swift in Sources */, + 445BB4AD178FA8285B5DBE6E /* GroupModerationsView+ViewConverter.swift in Sources */, + 95C89A9B083F3CE10C6A6E33 /* GroupModerationsView.swift in Sources */, + 159EFF704D530D3BB7954F9A /* GroupModerationsViewConverter.Header.swift in Sources */, + A51C40101CBE93E05BF95481 /* GroupModerationsViewConverter.List.swift in Sources */, + F29CBAFB517D74A6C86E4B9C /* GroupModerationsViewConverter.swift in Sources */, + 5DD906309C96D3E67B1CCBDA /* GroupModerationsViewProvider.swift in Sources */, + CDE670D72972D89F6135D56D /* GroupMutedMemberListView+Item.swift in Sources */, + 00C85B54DEAAFA517FA0D50B /* GroupMutedMemberListView+SubViewBuilder.swift in Sources */, + 133B357AACE5246AB58946DB /* GroupMutedMemberListView+ViewConverter.swift in Sources */, + 1F145397F88D546FD032E326 /* GroupMutedMemberListView.swift in Sources */, + E19EB21CBB56FE2CB7DCC23D /* GroupMutedMemberListViewConverter.Header.swift in Sources */, + 46ABE1851FE5770BE79DCB89 /* GroupMutedMemberListViewConverter.List.swift in Sources */, + D108B194A79177A0E5886692 /* GroupMutedMemberListViewConverter.swift in Sources */, + C60D583881525033B4E97782 /* GroupMutedMemberListViewProvider.swift in Sources */, + 0E2967410CDFB920C4FF8E50 /* GroupOperatorListView+Item.swift in Sources */, + BB6A4D1F004CF64D3FF5BDD8 /* GroupOperatorListView+SubViewBuilder.swift in Sources */, + 70AE7E0A4E026CBAF47C493A /* GroupOperatorListView+ViewConverter.swift in Sources */, + B1EA03591DEFF9EDAAE593E3 /* GroupOperatorListView.swift in Sources */, + AF6A17136172808D92BF29E7 /* GroupOperatorListViewConverter.Header.swift in Sources */, + 357D0348F28A8ACFE47FB2D6 /* GroupOperatorListViewConverter.List.swift in Sources */, + 7812F26A7A0A2D570C741C6A /* GroupOperatorListViewConverter.swift in Sources */, + C008B5E6FD93235F644F336F /* GroupOperatorListViewProvider.swift in Sources */, + C1E25E9625B7832E644A6B61 /* HandlerSet.swift in Sources */, + 93F095A77A7496E51241E3AF /* HierarchyScannable.swift in Sources */, 97CFCF714688D285C159FE9A /* ImagePicker.swift in Sources */, - EB7249112A888F49EC8BB3DA /* InviteUserView+Item.swift in Sources */, - 1FFA61368D52D367BDBEFC5A /* InviteUserView+SubViewBuilder.swift in Sources */, - 188D2F501E622F6B61F66DDA /* InviteUserView+ViewConverter.swift in Sources */, - 6E87F95D609F2E99C85A2155 /* InviteUserView.swift in Sources */, - 34E3C948C64092A0AAABB60A /* InviteUserViewConverter.Header.swift in Sources */, - 228088466D9334448D949249 /* InviteUserViewConverter.List.swift in Sources */, - 02D7FB791629405E7B868FB5 /* InviteUserViewConverter.swift in Sources */, + FF927D3C7D095E9AFE594C3A /* InviteUserView+Item.swift in Sources */, + AFE884D58BBBA0E0DDA0318D /* InviteUserView+SubViewBuilder.swift in Sources */, + EF70D41EB10E7E3D84A91257 /* InviteUserView+ViewConverter.swift in Sources */, + 87882C0D0FB63C03157D9E1D /* InviteUserView.swift in Sources */, + 3D77F2AC974F8337F6442134 /* InviteUserViewConverter.Header.swift in Sources */, + CD3E56FA953A20E2F612942F /* InviteUserViewConverter.List.swift in Sources */, + 772E4D392B5550DD3FDAD535 /* InviteUserViewConverter.swift in Sources */, + BD1447DFAE8EC51F287CDBF0 /* InviteUserViewProvider.swift in Sources */, 6FEB53022DA164CA48ED8F6E /* LoginView.swift in Sources */, 786261EBAF78615F8AFEAF41 /* MainView.swift in Sources */, - 201120B35CFB5D19CCF88E89 /* MessageForm+SBUIKit.swift in Sources */, - F16A0166E2F1F0B4B596C82A /* MessageSearchView+Item.swift in Sources */, - 930F1FD0E06245D81E40DCB6 /* MessageSearchView+SubViewBuilder.swift in Sources */, - 2EAA52382A0E8C5B2E941005 /* MessageSearchView+ViewConverter.swift in Sources */, - B3B97510A6BF0998BDA9F2AE /* MessageSearchView.swift in Sources */, - 2E12E61AB649FB4551D2B8A6 /* MessageSearchViewConverter.Header.swift in Sources */, - DFA9966EF652CADE6D96ED0A /* MessageSearchViewConverter.List.swift in Sources */, - DC7D77404C0685CAA873B466 /* MessageSearchViewConverter.swift in Sources */, - F79FCC71D80ECA4481F1B234 /* MessageTemplateParserTest.swift in Sources */, - 8B16B9513C3414DDEBB144E9 /* MessageTemplateTestViewController.swift in Sources */, - 529D6A32B137AAE957062140 /* MessageThreadView+Item.swift in Sources */, - AE015039EA61BB1F24C79EDA /* MessageThreadView+SubViewBuilder.swift in Sources */, - AFD48BD36352900AF6B964D5 /* MessageThreadView+ViewConverter.swift in Sources */, - F876788358C112410ECAB4E8 /* MessageThreadView.swift in Sources */, - D0161EAD1D4B16A02139A84D /* MessageThreadViewConverter.Header.swift in Sources */, - 80DBE36AEE07BA173E746B76 /* MessageThreadViewConverter.Input.swift in Sources */, - 9D3D7D814993C8AC7B7D5E04 /* MessageThreadViewConverter.List.swift in Sources */, - 950445FB87883797963FFF5D /* MessageThreadViewConverter.ParentInfo.swift in Sources */, - AE1845C068922DF20545BB70 /* MessageThreadViewConverter.swift in Sources */, - A1DD53553857C3F92780C556 /* MethodOverridable.swift in Sources */, - 1DDE92BE762570E25EDA42FE /* MultipleFilesMessage+SBUIKit.swift in Sources */, + AFD0135CCA41FEAA88B08D2F /* MessageForm+SBUIKit.swift in Sources */, + 75771AD4432A3C7F634CF7AE /* MessageSearchView+Item.swift in Sources */, + F185B2B69ED9A710B7B78EC7 /* MessageSearchView+SubViewBuilder.swift in Sources */, + FB112E3809457E31C1582C1D /* MessageSearchView+ViewConverter.swift in Sources */, + 04ED8F61F94545D52646FD4E /* MessageSearchView.swift in Sources */, + 999ABD0598A4E41292F8F7F8 /* MessageSearchViewConverter.Header.swift in Sources */, + 52E94ED9DC2EBD6DDCCBC2FA /* MessageSearchViewConverter.List.swift in Sources */, + 06A5DAADFEA005FE07E2E082 /* MessageSearchViewConverter.swift in Sources */, + 911E9D8A47AA491F63A0C5A4 /* MessageSearchViewProvider.swift in Sources */, + 9271A1EE9E96EDC2A9B3D3B8 /* MessageTemplateParserTest.swift in Sources */, + BFE819978A355FCE61AB1FD8 /* MessageTemplateTestViewController.swift in Sources */, + 587AFAFDC3D405F9F6C20853 /* MessageThreadView+Item.swift in Sources */, + 91E5FF686988D3FAC2203152 /* MessageThreadView+SubViewBuilder.swift in Sources */, + 8523FEA7BC6EF599A443BD80 /* MessageThreadView+ViewConverter.swift in Sources */, + 985DC6B75BF2E4950B007E7D /* MessageThreadView.swift in Sources */, + ED4F9C80A93E0E3F0A41B2F0 /* MessageThreadViewConverter.Header.swift in Sources */, + 2261BA068FDFDE8CCE7FF496 /* MessageThreadViewConverter.Input.swift in Sources */, + A3939070EE33F6952B446FA6 /* MessageThreadViewConverter.List.swift in Sources */, + C58B40F708F225481E6B9D17 /* MessageThreadViewConverter.ParentInfo.swift in Sources */, + 047F814076A05A3CD98A99EB /* MessageThreadViewConverter.swift in Sources */, + 9531B7E14F7278CDB070E582 /* MessageThreadViewProvider.swift in Sources */, + 5221A095983EA246ED6DE32A /* MethodOverridable.swift in Sources */, + 23E9F69D382332605608196E /* MultipleFilesMessage+SBUIKit.swift in Sources */, B935796C35E88B4B78ECDB96 /* MySettingsView.swift in Sources */, - E15DCBFAC901D6AA6A70AD18 /* NSLayoutConstraint+SBUIKit.swift in Sources */, - E041ED0754A7003638FE32FB /* NSObject+SBUIKit.swift in Sources */, - 864CB4627554453FCC734983 /* OpenBannedUserListView+Item.swift in Sources */, - A4A0F3C22D0BC90F05BEB267 /* OpenBannedUserListView+SubViewBuilder.swift in Sources */, - 24457EA1BBCECDB69A3D7136 /* OpenBannedUserListView+ViewConverter.swift in Sources */, - A5007E989C75C7974CF99B13 /* OpenBannedUserListView.swift in Sources */, - 1B1DEF5A353560183FD461ED /* OpenBannedUserListViewConverter.Header.swift in Sources */, - 636070B74D240BFCDF26E2AB /* OpenBannedUserListViewConverter.List.swift in Sources */, - 7033BAC3383409BDBC1F277C /* OpenBannedUserListViewConverter.swift in Sources */, - 7007C1FB6C2AB76F1EFBBFA7 /* OpenChannelListView+Item.swift in Sources */, - 81F04D83B2BCE531EEF9C983 /* OpenChannelListView+SubViewBuilder.swift in Sources */, - E262658E5596CA5B8A9800CE /* OpenChannelListView+ViewConverter.swift in Sources */, - AACEEB29943236CFDCD0C4C8 /* OpenChannelListView.swift in Sources */, - 81B92E41ACBED0F2622CBA04 /* OpenChannelListViewConverter.Header.swift in Sources */, - C0AA20C06FD343A6F73718A4 /* OpenChannelListViewConverter.List.swift in Sources */, - AA9DEF50B43F0317117EE784 /* OpenChannelListViewConverter.swift in Sources */, - 9753354376AA464C7686A373 /* OpenChannelRegisterOperatorView+Item.swift in Sources */, - 35541402EA0341E6AC422FDC /* OpenChannelRegisterOperatorView+SubViewBuilder.swift in Sources */, - BF842E30D9F0A7E0DC16AC4C /* OpenChannelRegisterOperatorView+ViewConverter.swift in Sources */, - B8D722C5D220AE5E67987F60 /* OpenChannelRegisterOperatorView.swift in Sources */, - 9E4D6F9813E0F1F9C55182D5 /* OpenChannelRegisterOperatorViewConverter.Header.swift in Sources */, - 5CA01106404E246DF785F231 /* OpenChannelRegisterOperatorViewConverter.List.swift in Sources */, - 6632A6391C5F963979F17FFD /* OpenChannelRegisterOperatorViewConverter.swift in Sources */, - EF31A9F67E151504D2D61273 /* OpenChannelSettingsView+Item.swift in Sources */, - 6C610264B527BD88F7FDBBE4 /* OpenChannelSettingsView+SubViewBuilder.swift in Sources */, - E96F05F8443C46A75441A5F0 /* OpenChannelSettingsView+ViewConverter.swift in Sources */, - F7DA65269E357E13A99E5DF9 /* OpenChannelSettingsView.swift in Sources */, - 83184B6DE831773CD38D3F4F /* OpenChannelSettingsViewConverter.Header.swift in Sources */, - 56A50FC7E092ABF8AC3A1B4C /* OpenChannelSettingsViewConverter.List.swift in Sources */, - 5EE36A58EE1A10E1437C0966 /* OpenChannelSettingsViewConverter.swift in Sources */, - 81DFA07BDEC020933EB801D5 /* OpenChannelView+Item.swift in Sources */, - 6E32FBA7FEF4B1DF15CBA365 /* OpenChannelView+SubViewBuilder.swift in Sources */, - B46C80C656E74A6DF282DF8F /* OpenChannelView+ViewConverter.swift in Sources */, - 224D5B1C3DBD8C960E1276B5 /* OpenChannelView.swift in Sources */, - F58E90A2F55A3AA736C5F437 /* OpenChannelViewConverter.Header.swift in Sources */, - DFED0A12C20374C2E59D2188 /* OpenChannelViewConverter.Input.swift in Sources */, - 071AB6CFBDA5D6FC64611157 /* OpenChannelViewConverter.List.swift in Sources */, - 52D3B526742AA7D54E53DE7F /* OpenChannelViewConverter.swift in Sources */, + FAF4A573C684B274DE8851CC /* NSLayoutConstraint+SBUIKit.swift in Sources */, + CA2CBB4AFC5EDE22ED94C2F9 /* NSObject+SBUIKit.swift in Sources */, + 4F9103454D8BD03741CB1A70 /* OpenBannedUserListView+Item.swift in Sources */, + CCC5B6680B47D013BD6F289B /* OpenBannedUserListView+SubViewBuilder.swift in Sources */, + 241CBAEBCA730A0DA87DCA71 /* OpenBannedUserListView+ViewConverter.swift in Sources */, + C61EF824B8C0026A3FFB1BED /* OpenBannedUserListView.swift in Sources */, + 51F13CFECE1B517D54F20C30 /* OpenBannedUserListViewConverter.Header.swift in Sources */, + 52362755FDE9CE2BE269332A /* OpenBannedUserListViewConverter.List.swift in Sources */, + 413ECDBB1EC03F9A27E7EFD5 /* OpenBannedUserListViewConverter.swift in Sources */, + 2FBFE7BDFD8B85473A6F568C /* OpenBannedUserListViewProvider.swift in Sources */, + AF2DF5A3F86C80F4CED1ADE0 /* OpenChannelListView+Item.swift in Sources */, + 964F856C0DDD16171FC6858D /* OpenChannelListView+SubViewBuilder.swift in Sources */, + D9741519F48A5C56A4E31758 /* OpenChannelListView+ViewConverter.swift in Sources */, + B95CDAA702A32D053DEE96B4 /* OpenChannelListView.swift in Sources */, + 301B9D704F37E9977999EF97 /* OpenChannelListViewConverter.Header.swift in Sources */, + F9FF79906A372FD1B14EA51A /* OpenChannelListViewConverter.List.swift in Sources */, + 1EB613FE017F0721F3EB6808 /* OpenChannelListViewConverter.swift in Sources */, + E1FE698F09E5426EA2BF4220 /* OpenChannelListViewProvider.swift in Sources */, + AC4F13963A037B90CBD034FC /* OpenChannelRegisterOperatorView+Item.swift in Sources */, + 3937A8958F386B56217275B4 /* OpenChannelRegisterOperatorView+SubViewBuilder.swift in Sources */, + C2F8461748B49BA4C211BB2F /* OpenChannelRegisterOperatorView+ViewConverter.swift in Sources */, + 908E1F51B723B0F07F4F9CF4 /* OpenChannelRegisterOperatorView.swift in Sources */, + 1E1CF9B8D095F6C875D049CE /* OpenChannelRegisterOperatorViewConverter.Header.swift in Sources */, + B50A83F7E4EA51F580069745 /* OpenChannelRegisterOperatorViewConverter.List.swift in Sources */, + 082F4BBEC7BE29EB4A6703B0 /* OpenChannelRegisterOperatorViewConverter.swift in Sources */, + 7F098AABCC2D5C845C95607A /* OpenChannelRegisterOperatorViewProvider.swift in Sources */, + B5FC50AEDDA9828762003305 /* OpenChannelSettingsView+Item.swift in Sources */, + 9FBDD5BF5BA4586B3C97114C /* OpenChannelSettingsView+SubViewBuilder.swift in Sources */, + DE26AED838AFFF841E2700B8 /* OpenChannelSettingsView+ViewConverter.swift in Sources */, + 97742067DEAA094F37E34920 /* OpenChannelSettingsView.swift in Sources */, + D58C121ACCB1F20C95BA23B3 /* OpenChannelSettingsViewConverter.Header.swift in Sources */, + 4432A7F44ED30FE6566FBC11 /* OpenChannelSettingsViewConverter.List.swift in Sources */, + A6C3683CC473BEB177D53449 /* OpenChannelSettingsViewConverter.swift in Sources */, + C256F24886A7C814FCE83A6C /* OpenChannelSettingsViewProvider.swift in Sources */, + 79C59527FC4913F85249703F /* OpenChannelView+Item.swift in Sources */, + 82D77D77451DFA4A47284ECF /* OpenChannelView+SubViewBuilder.swift in Sources */, + ADF43FD9D04373D6A9AD61AE /* OpenChannelView+ViewConverter.swift in Sources */, + 8A51E94D0A5A62638CC6DB94 /* OpenChannelView.swift in Sources */, + 5FBD60398F5F13D4D11DBFC6 /* OpenChannelViewConverter.Header.swift in Sources */, + 308D1E6825184AFCF7FB30F3 /* OpenChannelViewConverter.Input.swift in Sources */, + 57572A87BE7D9E250158BA0B /* OpenChannelViewConverter.List.swift in Sources */, + 83519CD9F2682049CAC10AAE /* OpenChannelViewConverter.swift in Sources */, + 4CDB3A59EC5F79228A388A76 /* OpenChannelViewProvider.swift in Sources */, A0442BD86F36659653E0E50F /* OpenChannelsView.swift in Sources */, - C8554510A3ADE4D044956D14 /* OpenModerationsView+Item.swift in Sources */, - 43F1C242C467554BE94E81DE /* OpenModerationsView+SubViewBuilder.swift in Sources */, - 80EAE88EFE5AA50D8F9D6040 /* OpenModerationsView+ViewConverter.swift in Sources */, - 0889CA23C29B6C4DD37AC8E1 /* OpenModerationsView.swift in Sources */, - A31F753F8F96C521381AEA67 /* OpenModerationsViewConverter.Header.swift in Sources */, - 6CD3C4DAB2E40DDA68C4FB83 /* OpenModerationsViewConverter.List.swift in Sources */, - 77391D78564F848F57EE1E46 /* OpenModerationsViewConverter.swift in Sources */, - E2E5FCFAAAF8D4E28A8C9AE8 /* OpenMutedParticipantListView+Item.swift in Sources */, - 57B80623B0F8BA760F61302F /* OpenMutedParticipantListView+SubViewBuilder.swift in Sources */, - 3FDDF95834D426171021D60F /* OpenMutedParticipantListView+ViewConverter.swift in Sources */, - EF7226964F4E87543F7FB55C /* OpenMutedParticipantListView.swift in Sources */, - 9DE8D8FDC524B09710FD7C27 /* OpenMutedParticipantListViewConverter.Header.swift in Sources */, - 7305337E0F61C0623B07C64A /* OpenMutedParticipantListViewConverter.List.swift in Sources */, - 4AE354251F110B0258232F40 /* OpenMutedParticipantListViewConverter.swift in Sources */, - 73B5E951B0FB998EDACC8BB4 /* OpenOperatorListView+Item.swift in Sources */, - 165275B7994606FCA5389DAD /* OpenOperatorListView+SubViewBuilder.swift in Sources */, - CE8A540833324BF9FB4A3906 /* OpenOperatorListView+ViewConverter.swift in Sources */, - 7BACA8DB6DD90759116A2EC0 /* OpenOperatorListView.swift in Sources */, - A17A9E7D5853718EBC0D6896 /* OpenOperatorListViewConverter.Header.swift in Sources */, - 0DEF56F6757B109D7FA7BEE2 /* OpenOperatorListViewConverter.List.swift in Sources */, - 54E06FDDB15A6C4FF928C1A0 /* OpenOperatorListViewConverter.swift in Sources */, - D4297F02CDEFB90DD1C01C0B /* OpenParticipantListView+Item.swift in Sources */, - 4342550D395EEBBF39CEBD4A /* OpenParticipantListView+SubViewBuilder.swift in Sources */, - E78569906B225E8EFFDAF522 /* OpenParticipantListView+ViewConverter.swift in Sources */, - 9D56300DA705AA133E877DE1 /* OpenParticipantListView.swift in Sources */, - CB73E4A2F4AF7F919F17C6F2 /* OpenParticipantListViewConverter.Header.swift in Sources */, - C8D6966D1D8C1D504F2D6FA9 /* OpenParticipantListViewConverter.List.swift in Sources */, - 755AFEC6F6C99EED386CD93D /* OpenParticipantListViewConverter.swift in Sources */, + 981CDDC9AE02CB03306BA22B /* OpenModerationsView+Item.swift in Sources */, + E30D824F9AD83B1AFE419A74 /* OpenModerationsView+SubViewBuilder.swift in Sources */, + BBBA781D851EB6290446E909 /* OpenModerationsView+ViewConverter.swift in Sources */, + 72F31B50B2B889E2E945E8A3 /* OpenModerationsView.swift in Sources */, + 3EF27929DDF5A9C7DF3B3A35 /* OpenModerationsViewConverter.Header.swift in Sources */, + DD425D8E4996A6C3CCADDD5F /* OpenModerationsViewConverter.List.swift in Sources */, + 68EC60B5E312225B96E17C7F /* OpenModerationsViewConverter.swift in Sources */, + E7E14B28363015575DABE0B5 /* OpenModerationsViewProvider.swift in Sources */, + 135C6711638D6C75602E9A10 /* OpenMutedParticipantListView+Item.swift in Sources */, + 7A471BD88BF39C4392D0640B /* OpenMutedParticipantListView+SubViewBuilder.swift in Sources */, + 0AB54DCF8BD1B1B4E1DA5092 /* OpenMutedParticipantListView+ViewConverter.swift in Sources */, + 1E2F3C901891AE37BA3DE884 /* OpenMutedParticipantListView.swift in Sources */, + E333B1FF65287CD42D3DCA7F /* OpenMutedParticipantListViewConverter.Header.swift in Sources */, + 2292600E3BADD7725969DF11 /* OpenMutedParticipantListViewConverter.List.swift in Sources */, + C91278C982153C5CB9EAD826 /* OpenMutedParticipantListViewConverter.swift in Sources */, + CBF3472829482C53F2FF07C4 /* OpenMutedParticipantListViewProvider.swift in Sources */, + 06E145EC829658D24E39F9B2 /* OpenOperatorListView+Item.swift in Sources */, + 3412D19373A8ACC77B9277AA /* OpenOperatorListView+SubViewBuilder.swift in Sources */, + C9EDCF465087330DE28357F8 /* OpenOperatorListView+ViewConverter.swift in Sources */, + 4F42716E2D6DCE99C0BE8662 /* OpenOperatorListView.swift in Sources */, + FB737408C0CE15ACCA67B4B1 /* OpenOperatorListViewConverter.Header.swift in Sources */, + BE9CD4E2054189F5833D98C3 /* OpenOperatorListViewConverter.List.swift in Sources */, + A7EEBF3F64F0F8A74752E505 /* OpenOperatorListViewConverter.swift in Sources */, + FAFE9BFE99991B273091412B /* OpenOperatorListViewProvider.swift in Sources */, + E16734D498A71A626E474116 /* OpenParticipantListView+Item.swift in Sources */, + 6B6AB05353E77AEB88C44A67 /* OpenParticipantListView+SubViewBuilder.swift in Sources */, + 614F8544FFEC4EBD7933D8AD /* OpenParticipantListView+ViewConverter.swift in Sources */, + 6E32203FC329E9CCF2DF8625 /* OpenParticipantListView.swift in Sources */, + AE7E327DE6B29650FDBC9FB2 /* OpenParticipantListViewConverter.Header.swift in Sources */, + 2EB7C68A6075B356709326C4 /* OpenParticipantListViewConverter.List.swift in Sources */, + 1520194D5810C4B569FE815B /* OpenParticipantListViewConverter.swift in Sources */, + AFAAEB57805DBE7DC88EA690 /* OpenParticipantListViewProvider.swift in Sources */, + 6167F0361080F777AEE83744 /* ProviderWrappedHostingView.swift in Sources */, 8756E150D07A8EA750EFA1A0 /* QuickStartSwiftUIApp.swift in Sources */, - C7410A1AC1A83ED4777BB93B /* QuotedFileCommonContentView.swift in Sources */, - F4A90A171E5CAFA12D1C8695 /* QuotedFileImageContentView.swift in Sources */, - E00E02F894E103B52A787CFA /* SBUActionSheet.Item.swift in Sources */, - 8BC2D01CC28ADEC9F3AF8F07 /* SBUActionSheet.swift in Sources */, - 5F0565A4139305CDA21FB273 /* SBUAdminMessageCell.swift in Sources */, - E8307AA123548D284537B16A /* SBUAdminMessageCellParams.swift in Sources */, - F3303D08123203E067529621 /* SBUAlertView.Item.swift in Sources */, - D3868E3A2F8D661563025087 /* SBUAlertView.swift in Sources */, - 57C940DFAFBFE228BDFB7E06 /* SBUAnimation.swift in Sources */, - 8B3D296ED71AA9DEE683DD1E /* SBUAvailable.swift in Sources */, - 5157F8160F3474FECCF5B546 /* SBUBarButtonItem.swift in Sources */, - 9CCDE637E3E78AEB62D9527F /* SBUBaseCarouselView.swift in Sources */, - C09141874B287303763DDA1E /* SBUBaseChannelCell.swift in Sources */, - 0E9EDEA535577EA289FF08B2 /* SBUBaseChannelListModule.Header.swift in Sources */, - 842DC78E8C3D568A732AE597 /* SBUBaseChannelListModule.List.swift in Sources */, - DE29C57028910EFACF8BC21B /* SBUBaseChannelListModule.swift in Sources */, - B98A0058F9918F9157C03A68 /* SBUBaseChannelListViewController.swift in Sources */, - 7D124911960DBA1BF9E54E49 /* SBUBaseChannelListViewModel.swift in Sources */, - 4DC0350ED1D2833CA946B8C3 /* SBUBaseChannelModule.Deprecated.swift in Sources */, - 618A9F92401F9F3D7B9FE3A1 /* SBUBaseChannelModule.Header.swift in Sources */, - 755389B615893549894B2F2D /* SBUBaseChannelModule.Input.swift in Sources */, - 8C7AA1F7FF6DB74850968478 /* SBUBaseChannelModule.List.swift in Sources */, - 8398BB53C2C6D3D33C5DA505 /* SBUBaseChannelModule.swift in Sources */, - 6A48C8A3A8B8BC5CAE595936 /* SBUBaseChannelSettingCell.swift in Sources */, - F3C36FE0F7455A39DF419614 /* SBUBaseChannelSettingsModule.Header.swift in Sources */, - 01C10C34A07F581EAD1CD350 /* SBUBaseChannelSettingsModule.List.swift in Sources */, - EA6EFEB0C07B15E26377DD92 /* SBUBaseChannelSettingsModule.swift in Sources */, - 82080F4FA9B0396AAE547CA4 /* SBUBaseChannelSettingsViewController.Deprecated.swift in Sources */, - 9EC3D1808000E0D1BDE892B4 /* SBUBaseChannelSettingsViewController.swift in Sources */, - D97F7E736F1CBA332E72BE2B /* SBUBaseChannelSettingsViewModel.swift in Sources */, - EFA5CFF27B028DF351B54DE1 /* SBUBaseChannelViewController.Deprecated.swift in Sources */, - 66FA5B6120E41120D04DDC2C /* SBUBaseChannelViewController.Keyboard.swift in Sources */, - E6FD95E728A65284B04676F4 /* SBUBaseChannelViewController.Unavailable.swift in Sources */, - 9486242E728DD97805F031C6 /* SBUBaseChannelViewController.swift in Sources */, - 0BA7595DAD97702571BA7916 /* SBUBaseChannelViewModel.swift in Sources */, - CD8EAA5E713598B43E0B0126 /* SBUBaseFileContentView.swift in Sources */, - 21B715602294D016F17A2457 /* SBUBaseMessageCell+SwiftUI.swift in Sources */, - E5C7D45DC9E90EA6957A1A7F /* SBUBaseMessageCell.Feedback.swift in Sources */, - 777246F426A612F593C2D69F /* SBUBaseMessageCell.MessageThread+SwiftUI.swift in Sources */, - 6CF60D9B84F4C8F2CDBDC94E /* SBUBaseMessageCell.swift in Sources */, - EA33B6D96C33382B69680DBA /* SBUBaseMessageCellParams.Deprecated.swift in Sources */, - 2598789B240EB34C5FCE28A2 /* SBUBaseMessageCellParams.swift in Sources */, - 760DB6940C51374972580B90 /* SBUBaseSelectUserModule.Header.swift in Sources */, - E24DD39228128306D43F5F95 /* SBUBaseSelectUserModule.List.swift in Sources */, - B703E602A7AAA0A75B12C829 /* SBUBaseSelectUserModule.swift in Sources */, - 5DE0EF61A1BBC2FFCE61911D /* SBUBaseSelectUserViewController.Deprecated.swift in Sources */, - 726BE6009C1C3F4B6E224B6F /* SBUBaseSelectUserViewController.swift in Sources */, - DFFE1B9DC17CB3F9EAD4C46F /* SBUBaseSelectUserViewModel.swift in Sources */, - 429674A28CCB9F7E17F25B95 /* SBUBaseViewController.Unavailable.swift in Sources */, - E7AD63843F241D0D0CD6EF42 /* SBUBaseViewController.swift in Sources */, - 442D06E6B5F2E1C8EE70FB5A /* SBUBottomSheetController.swift in Sources */, - 051DF9B1FD6387F77A69ED61 /* SBUCacheManager.Config.swift in Sources */, - C85E092257EAF0E31F3205AD /* SBUCacheManager.File.swift in Sources */, - 2A8E932076887CCD5B8BEF77 /* SBUCacheManager.Image.swift in Sources */, - C0F5E06887431A6BCCAA41B7 /* SBUCacheManager.NotificationSetting.swift in Sources */, - 892CE8238EDBCDE6C19CC926 /* SBUCacheManager.Template.swift in Sources */, - 53EED1261A469B47B8E5AF5E /* SBUCacheManager.Version.swift in Sources */, - 9364802D9C9786A05231FF7B /* SBUCacheManager.swift in Sources */, - 4CF8D5FA139905816CB42DDA /* SBUCategoryFilterCell.swift in Sources */, - 308B09C70FAF3AED15D8DA3B /* SBUChannelInfoHeaderView.swift in Sources */, - 821A4BDD3AD4494A14303F9C /* SBUChannelListViewController.Deprecated.swift in Sources */, - 589705AA739674BBFC622D85 /* SBUChannelPushSettingCell.swift in Sources */, - 7924A57DC1B97A73957ECF12 /* SBUChannelSettingItem.swift in Sources */, - DACBC67120261B903F277917 /* SBUChannelSettingsChannelInfoView.swift in Sources */, - DEBF3392C7142EFC15547445 /* SBUChannelStateBanner+SwiftUI.swift in Sources */, - B6F73763A07267A4DAE5E2A4 /* SBUChannelStateBanner.MessageThread+SwiftUI.swift in Sources */, - 9273A262FCFFEB5BFED22EF6 /* SBUChannelStateBanner.swift in Sources */, - 21F84F844BADB840E84D553E /* SBUChannelTitleView+SwiftUI.swift in Sources */, - 99390EC5AC1E4BEA3E0B4D20 /* SBUChannelTitleView.swift in Sources */, - 2D36FF0502F15350CB9CDE3A /* SBUChatNotificationCell.swift in Sources */, - 435D7C9F386025A5B35CD9F0 /* SBUChatNotificationChannelModule.Deprecated.swift in Sources */, - FAC187F0CAC75721B1667848 /* SBUChatNotificationChannelModule.Header.swift in Sources */, - 8384A67651EFEE2F2AB8E67D /* SBUChatNotificationChannelModule.List.swift in Sources */, - 57EA7C8E6F3F39CC432A85BA /* SBUChatNotificationChannelModule.swift in Sources */, - 8216EBEE01536786B41EF6A1 /* SBUChatNotificationChannelViewController.swift in Sources */, - 75F8DF16D7722B362B5BCF2E /* SBUChatNotificationChannelViewModel.swift in Sources */, - 879224620E046F928842B9F9 /* SBUCollectionViewCell.swift in Sources */, - DFAC18234423C9FE06C61020 /* SBUCollectionViewFlowLayout.swift in Sources */, - 02485528E666F206B7C18F89 /* SBUColorSet.swift in Sources */, - 09CEBEB51450909EA7A3482D /* SBUCommonContentView.swift in Sources */, - F2FB23E7859DAB234B777DE5 /* SBUCommonDelegate.swift in Sources */, - B30F51F42C6CF85C18B52825 /* SBUCommonItem.swift in Sources */, - 97EDD5B5BB072A17441EDD61 /* SBUCommonModule.swift in Sources */, - 2057B0454F27A7A20B1373C5 /* SBUCommonViewControllerSet.swift in Sources */, - F5A166DDB3A9690E987262F3 /* SBUConfig.Base.swift in Sources */, - FB20D2C791C5A003F5CBA107 /* SBUConfig.CodingKeys.swift in Sources */, - C513788D72B5B3755E77C999 /* SBUConfig.Common.swift in Sources */, - 3C4C6B12FB4F6177E417D857 /* SBUConfig.GroupChannel.swift in Sources */, - 0D4DC17049C1CDC466A2A9D3 /* SBUConfig.OpenChannel.swift in Sources */, - 4E49B57D46AC815181DFB452 /* SBUConfig.swift in Sources */, - C13B2A363F14DFD04FE0B172 /* SBUConfigManager.swift in Sources */, - 95CD32CC30E8BC8C3D47D173 /* SBUConstant.swift in Sources */, - F43A6D9977E666414D8C4E58 /* SBUContentBaseMessageCell.Deprecated.swift in Sources */, - 7C6D71CF99DA0C31028AC39D /* SBUContentBaseMessageCell.swift in Sources */, - BB0749D100B16A2E27D771EF /* SBUCoverImageView.Deprecated.swift in Sources */, - 6BFE5FA80E4C34342365A81D /* SBUCoverImageView.swift in Sources */, - A9908A0A0107340580C68CBA /* SBUCreateChannelModule.Deprecated.swift in Sources */, - 5916E62E09E939455B5C079B /* SBUCreateChannelModule.Header.swift in Sources */, - E72068F330B18B111C25BEA5 /* SBUCreateChannelModule.List.swift in Sources */, - A27C3C995A735C4EC8F17B54 /* SBUCreateChannelModule.swift in Sources */, - 256896373CACC223A4F9D297 /* SBUCreateChannelTypeSelector.swift in Sources */, - 35A042C34CB866EFBF4ADA98 /* SBUCreateChannelViewController.Deprecated.swift in Sources */, - 181DCED5C5544A3F86180085 /* SBUCreateChannelViewController.swift in Sources */, - 5782823871DC186373F23AA2 /* SBUCreateChannelViewModel.swift in Sources */, - DDBEC50FB891AC49AE114611 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift in Sources */, - 73CDF9A5384577E92EACC44C /* SBUCreateGroupChannelModule.List+SwiftUI.swift in Sources */, - 06C25FEA3135A0BD3CB28F97 /* SBUCreateGroupChannelUserCell+SwiftUI.swift in Sources */, - 27E11C4D9F40C6AB46EF4852 /* SBUCreateOpenChannelModule.Deprecated.swift in Sources */, - C9DE77AA383EB03A89B52F34 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift in Sources */, - 4196947C633EFEBC5DD78DB0 /* SBUCreateOpenChannelModule.Header.swift in Sources */, - CF664360605D0FBD20E77476 /* SBUCreateOpenChannelModule.ProfileInput.swift in Sources */, - EA3976663914B3C1572AE2ED /* SBUCreateOpenChannelModule.swift in Sources */, - 7705D4416461633D988BF2D4 /* SBUCreateOpenChannelViewController.swift in Sources */, - 5409EB47DEE45963E96D8093 /* SBUCreateOpenChannelViewModel.swift in Sources */, - 8205BE1C5CF85CF34FE8672D /* SBUDashboardConfig.swift in Sources */, - 7912D438DD630BA7680173B5 /* SBUDateFormatSet.swift in Sources */, - AFB7CB7B79CF3807A64F52E3 /* SBUDebouncer.swift in Sources */, - 915A00A1A61FEC4D37490114 /* SBUDownloadManager.swift in Sources */, - 5EDE9CF7F5BE0C5CA87EB470 /* SBUEmojiListViewController.swift in Sources */, - 6FEDBF1FAC71B202202A6CFC /* SBUEmojiManager.swift in Sources */, - 027F85F8D05965EA72E35649 /* SBUEmptyView.swift in Sources */, - D2D3898FA489DEC8B003670B /* SBUEnums.Deprecated.swift in Sources */, - 56A4448631C5FBAD4A47BA51 /* SBUEnums.swift in Sources */, - 3513E41C4A69F8983B75B7C1 /* SBUError.swift in Sources */, - C92800E91681A1906102B807 /* SBUExtendedMessagePayload.swift in Sources */, - DA6E618B26EF3A66E44CFE4B /* SBUExtendedMessagePayloadCustomViewFactory.swift in Sources */, - F20DF8AC3F5E34ED6E8B7D79 /* SBUExtendedMessagePayloadForUI.swift in Sources */, - 155034F91E88C596503B400F /* SBUFeedNotificationCell.swift in Sources */, - 57EEDEB10C783FE7A3A12CAB /* SBUFeedNotificationCellParams.swift in Sources */, - 807BB72D1A285BC3389B5DE1 /* SBUFeedNotificationChannelModule.CategoryFilter.swift in Sources */, - A8442E5704D1B8751F61D7E6 /* SBUFeedNotificationChannelModule.Deprecated.swift in Sources */, - 4EB9EFB39E2E14B9D5AE08AC /* SBUFeedNotificationChannelModule.Header.swift in Sources */, - EDE2669DCC64990790660E85 /* SBUFeedNotificationChannelModule.List.swift in Sources */, - E68926AA4D9CE89804D96380 /* SBUFeedNotificationChannelModule.swift in Sources */, - 5D829EE1E565973BA1F52793 /* SBUFeedNotificationChannelViewController.swift in Sources */, - FC23DBF0D512EDD00027EF9A /* SBUFeedNotificationChannelViewModel.swift in Sources */, - A5AF0DBD410F34451E7816A2 /* SBUFeedNotificationChannelViewParams.swift in Sources */, - 9F09F0918B8855435C8201F8 /* SBUFeedbackAction.swift in Sources */, - 0887D93782BB853729387857 /* SBUFeedbackView.swift in Sources */, - 0A82663EF8D84D235CA65F81 /* SBUFeedbackViewParams.swift in Sources */, - F09AD512141C60DD538627BE /* SBUFileMessageCell.swift in Sources */, - A305A9100DCB76480046B0E1 /* SBUFileMessageCellParams.swift in Sources */, - 2DB6CA0CC0BB531B7E073BFE /* SBUFileViewController.swift in Sources */, - 66ADA4F8CFC6EB6A77D60B1B /* SBUFontSet.swift in Sources */, - E2F52C7E7ADB0B8114C5CDD3 /* SBUForm.Deprecated.swift in Sources */, - AF83514E03BDB74C06340303 /* SBUFormFieldView.Deprecated.swift in Sources */, - 2637DC0A0C8F965A37AE303E /* SBUFormView.Deprecated.swift in Sources */, - 2396C41E13FDB99A2EC97888 /* SBUFormViewParams.Deprecated.swift in Sources */, - EF2DDFC6BA4286E5C6976A10 /* SBUGlobalCustomParams.swift in Sources */, - B90B393ED6F9C556DC4ADE50 /* SBUGlobals.Deprecated.swift in Sources */, - AF20C220160DCC107926F516 /* SBUGlobals.swift in Sources */, - 13B7E99F054FD7EDA9AC835D /* SBUGroupBannedUserListModule.Header+SwiftUI.swift in Sources */, - AE74C43D92832880B75FEC9B /* SBUGroupBannedUserListModule.List+SwiftUI.swift in Sources */, - 0A50103E6135D93A5EDEEF51 /* SBUGroupBannedUserListUserCell+SwiftUI.swift in Sources */, - 48441C5EAE63AF462E9F521E /* SBUGroupChannelCell+SwiftUI.swift in Sources */, - B172261CD25AC117AEC18668 /* SBUGroupChannelCell.swift in Sources */, - 7CFF409B8A3C97FA854261F3 /* SBUGroupChannelListModule.Common.swift in Sources */, - DC9D16332ACB8881A320B8BC /* SBUGroupChannelListModule.Deprecated.swift in Sources */, - EBC78746894BA6E4E47AEB1A /* SBUGroupChannelListModule.Header+SwiftUI.swift in Sources */, - 5D49E88AFAF971B4F1DB58FD /* SBUGroupChannelListModule.Header.swift in Sources */, - B602F92B8400E475E0DAAEB5 /* SBUGroupChannelListModule.List+SwiftUI.swift in Sources */, - 72E1942B6F0714E5C5E3FD0E /* SBUGroupChannelListModule.List.swift in Sources */, - 7042EA106C890E247EAA7889 /* SBUGroupChannelListModule.swift in Sources */, - BF7A9954C040ECF3504A060C /* SBUGroupChannelListViewController.swift in Sources */, - 8DC4457FD2D80B376928A1B6 /* SBUGroupChannelListViewModel.swift in Sources */, - 8D334DE25D7D824B45FE9EF1 /* SBUGroupChannelModule.Deprecated.swift in Sources */, - 783A7828C7E3288A7480F126 /* SBUGroupChannelModule.Header+SwiftUI.swift in Sources */, - B8993551EFC15564A51C3F79 /* SBUGroupChannelModule.Header.swift in Sources */, - 55A068C70117611B644BEE9E /* SBUGroupChannelModule.Input+SwiftUI.swift in Sources */, - 4947E732EF44B9AA93B21B99 /* SBUGroupChannelModule.Input.swift in Sources */, - 64FAAC91380DD6A0E3D0EA92 /* SBUGroupChannelModule.List+SwiftUI.swift in Sources */, - 43F0BBFFC51A2D49F330F817 /* SBUGroupChannelModule.List.swift in Sources */, - 803B30E799E043691CED267A /* SBUGroupChannelModule.swift in Sources */, - 35E89032995E54FCEE345D2D /* SBUGroupChannelPushSettingsModule.Deprecated.swift in Sources */, - D4500C33046BB2D60EA64C66 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift in Sources */, - 8C010F344DF737F686118EEA /* SBUGroupChannelPushSettingsModule.Header.swift in Sources */, - 150C54165E25735C227560B4 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift in Sources */, - 81D347E7506E34DD45A54827 /* SBUGroupChannelPushSettingsModule.List.swift in Sources */, - 3CB5A9CD871BEA948248DE21 /* SBUGroupChannelPushSettingsModule.swift in Sources */, - F54B0584BA9C1AE5D457C7C4 /* SBUGroupChannelPushSettingsViewController.swift in Sources */, - CB0FF3446B81180AB9C2E198 /* SBUGroupChannelPushSettingsViewModel.swift in Sources */, - BB0F042568FEF1D71417AC9F /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */, - E1B1B58491BBB92494FA178D /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */, - 41ABB2DCC040058AF9D3233A /* SBUGroupChannelSettingCell+SwiftUI.swift in Sources */, - 568B75AEBE3555EAEDC32C64 /* SBUGroupChannelSettingCell.swift in Sources */, - 387E3D9349C182157C0EDBD0 /* SBUGroupChannelSettingsModule.Deprecated.swift in Sources */, - 949FB57CD1485C0A2C24090C /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift in Sources */, - 9CF1526115B690E80FF83442 /* SBUGroupChannelSettingsModule.Header.swift in Sources */, - 391D34782F1606CF69FD1B50 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift in Sources */, - 9AD10F667C4A981B820D2B44 /* SBUGroupChannelSettingsModule.List.swift in Sources */, - 2EB545F44CE247B82B9558C2 /* SBUGroupChannelSettingsModule.swift in Sources */, - 539A540807A678A26A1E8926 /* SBUGroupChannelSettingsViewController.swift in Sources */, - 76A52219FACE19DDD99554CD /* SBUGroupChannelSettingsViewModel.swift in Sources */, - A7880ED8BBF33F205C224AA2 /* SBUGroupChannelViewController+SwiftUI.swift in Sources */, - 8C0A5E28547E0446FFCD7681 /* SBUGroupChannelViewController.Deprecated.swift in Sources */, - 1AEBA5EA1D4CA925242B4B95 /* SBUGroupChannelViewController.Unavailable.swift in Sources */, - 6CDDFC3D3C6D3B35682BBB66 /* SBUGroupChannelViewController.swift in Sources */, - 9B6807A3F5EEFB63B8B64837 /* SBUGroupChannelViewModel.swift in Sources */, - 887745C06130F7437448530E /* SBUGroupModerationsModule.Header+SwiftUI.swift in Sources */, - 9471433D59A65637F27987E9 /* SBUGroupModerationsModule.List+SwiftUI.swift in Sources */, - C31DBF49FA64FCC89FA68D67 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift in Sources */, - A33BF99AFD866E7F77E633DC /* SBUGroupMutedMemberListModule.List+SwiftUI.swift in Sources */, - 112188B1E80592B02E43ECE9 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift in Sources */, - F42EE4548C70DA5B326BAA56 /* SBUGroupOperatorListModule.Header+SwiftUI.swift in Sources */, - 24FAEB760F4A95577BB279F8 /* SBUGroupOperatorListModule.List+SwiftUI.swift in Sources */, - C20B2977DDD5BF1DACBC39CE /* SBUGroupOperatorListUserCell+SwiftUI.swift in Sources */, - 42004339E11B8CD30011DDD0 /* SBUGroupUserListModule.Header+SwiftUI.swift in Sources */, - F472FD7274CA3C542B107CA1 /* SBUGroupUserListModule.List+SwiftUI.swift in Sources */, - 9F9BDDC6E6384E06A8BE2D71 /* SBUGroupUserListUserCell+SwiftUI.swift in Sources */, - 89223DB915FC1ED34B37E820 /* SBUHighlightMessageInfo.swift in Sources */, - 36DE27B3673937512D65607B /* SBUHorizontalSuggestedReplyOptionView.swift in Sources */, - 2A7F6FBA98B39948502492C3 /* SBUHorizontalSuggestedReplyView.swift in Sources */, - B67D370DFEDBCEAD82A46151 /* SBUIconSet.swift in Sources */, - ED4ADF7E3FC9D86805EFD907 /* SBUIconSetType.swift in Sources */, - E54606D64412F6BAB1886758 /* SBUImageContentView.swift in Sources */, - 0DE339B2E17A3D2FD1AB150F /* SBUInviteUserCell+SwiftUI.swift in Sources */, - 0CFF3C908E611F9CEA4ABE96 /* SBUInviteUserModule.Deprecated.swift in Sources */, - 8241C83EE1198310FA21F73D /* SBUInviteUserModule.Header+SwiftUI.swift in Sources */, - 770D93EADA297635BA603621 /* SBUInviteUserModule.Header.swift in Sources */, - 59B34C003B81BC5252BCB1F5 /* SBUInviteUserModule.List+SwiftUI.swift in Sources */, - 0E9ECC8C2374A387DAEA92AF /* SBUInviteUserModule.List.swift in Sources */, - C42B4656DE7E6CDA051816B7 /* SBUInviteUserModule.swift in Sources */, - 1E435408BA84F9E42973B50A /* SBUInviteUserViewController.swift in Sources */, - 2319983E0726011906AC7FD4 /* SBUInviteUserViewModel.swift in Sources */, - F8BA54072955D783FCD276AB /* SBULabel.swift in Sources */, - DEC8EF3C4040E0CA0F4C1238 /* SBULayoutableButton.swift in Sources */, - D01F0F1DD3A5CD13D0460014 /* SBULazyView.swift in Sources */, - 07F0326A4479D48FA595591B /* SBULinkClickableTextView.swift in Sources */, - F9F2D651B0D67D56FB3387DA /* SBULoading.swift in Sources */, - 158F0AE32FEAAEF95C59788E /* SBULogger.swift in Sources */, - 4B2A2232C234A7B00F985A56 /* SBUMarginView.swift in Sources */, - 130CB58D0AE566A514B6C60A /* SBUMarkdownTransfer.swift in Sources */, - CB79774F4E6C31EDA48E7E8A /* SBUMediaView.swift in Sources */, - 47FFB70AFD0AF40C1B722977 /* SBUMemberListViewController.Deprecated.swift in Sources */, - FE18C179BAA225E16EC12B94 /* SBUMention.swift in Sources */, - AB245877579C021A382803F8 /* SBUMentionConfiguration.swift in Sources */, - 97E17BF2026429BA82CD76C1 /* SBUMentionLimitGuideCell.swift in Sources */, - D7C3BCFB400E6BA692406943 /* SBUMentionManager.swift in Sources */, - 35BC84D42A11723C39FC4147 /* SBUMenuCell.swift in Sources */, - 3AD5FCFB46A6704D379A40AA /* SBUMenuSheetViewController.swift in Sources */, - A9629CEFC1BE5FB0C453702B /* SBUMenuView.swift in Sources */, - 1EF752D3E3CA604EB7052956 /* SBUMessageCache.swift in Sources */, - 6A06C04DE0DE920B35519A29 /* SBUMessageCellConfiguration.swift in Sources */, - 7F315F24B4D8C1F258FCA8C1 /* SBUMessageCellProtocol.swift in Sources */, - EFB6D9EBA3D6FE450C063CFC /* SBUMessageDateView.swift in Sources */, - 1EB0F0FB0921F42151B381F8 /* SBUMessageFormChipView.swift in Sources */, - D78B56FF68EC5CAF2F39F522 /* SBUMessageFormChipsItemView.swift in Sources */, - BDF9A8DE063A5D26AD903A5A /* SBUMessageFormFallbackView.swift in Sources */, - F0D502B07BE7FF2D8FDE7967 /* SBUMessageFormItemView.swift in Sources */, - 6F337F85F1EC26FB5747C0B0 /* SBUMessageFormMultiTextItemView.swift in Sources */, - D0B9BCABF4D8E0174A29C3C7 /* SBUMessageFormSingleTextItemView.swift in Sources */, - 1CDB503F30FC2AB8FF73576F /* SBUMessageFormView.swift in Sources */, - 6E56A4C38E8FB2A9ABFE5100 /* SBUMessageFormViewParams.swift in Sources */, - 4B12AC423B1E57AFD2800C84 /* SBUMessageInputMode.swift in Sources */, - 70D3891EF8F0F4988D1F82A6 /* SBUMessageInputView+SwiftUI.swift in Sources */, - BD6080969BB3E78B1ED0C952 /* SBUMessageInputView.swift in Sources */, - 6FEBC24199B9349BCD5E410A /* SBUMessageProfileView.swift in Sources */, - 7047759F78D053CCE131A8D2 /* SBUMessageReactionView.swift in Sources */, - 306FA7E3CAD8D059B3232C12 /* SBUMessageSearchModule.Deprecated.swift in Sources */, - C36FB367C9654AC67A3FAECF /* SBUMessageSearchModule.Header+SwiftUI.swift in Sources */, - DEC1A145B129CCED3F001421 /* SBUMessageSearchModule.Header.swift in Sources */, - 2ACA2532E8EECB79E25C8C5D /* SBUMessageSearchModule.List+SwiftUI.swift in Sources */, - 610D3FC412C949B9E0E454C0 /* SBUMessageSearchModule.List.swift in Sources */, - A9DFF415083CC11BFE3AB50F /* SBUMessageSearchModule.swift in Sources */, - E1DCD33CFE1FAB9CFA589E1D /* SBUMessageSearchResultCell.swift in Sources */, - 76AFE05AB31FFE1CC4F96941 /* SBUMessageSearchViewController.Deprecated.swift in Sources */, - 1DFFD08112E02DBE0274D54E /* SBUMessageSearchViewController.swift in Sources */, - 9D06928EE947D643BD788DD1 /* SBUMessageSearchViewModel.swift in Sources */, - EE6F7874CA43EF4B1374DC47 /* SBUMessageStateView.swift in Sources */, - 413DA6431A1DF4B2285ACC61 /* SBUMessageTemplate.Action.swift in Sources */, - 2974135DF76DB03A6D24D1FF /* SBUMessageTemplate.Binder.swift in Sources */, - 790BDF268EE5BE9FF7D4C985 /* SBUMessageTemplate.Container.swift in Sources */, - 9864666F137B4E39C81300D8 /* SBUMessageTemplate.Coordinator.swift in Sources */, - 1623C20672C40F24BECBD4B0 /* SBUMessageTemplate.Decoders.swift in Sources */, - 2AF12799601EBC9F368DCE25 /* SBUMessageTemplate.ErrorMessages.swift in Sources */, - 1D75C1E950BC28D2C4B55BC4 /* SBUMessageTemplate.ImageRatioType.swift in Sources */, - AA28E77662FB06CD946F95C2 /* SBUMessageTemplate.Payload.swift in Sources */, - 7279E86712E7C3022EA5E7D3 /* SBUMessageTemplate.PayloadType.swift in Sources */, - C737EE6B654D97918352E7C1 /* SBUMessageTemplate.Renderer+Events.swift in Sources */, - 49F5234FBCF7AE93EED0596C /* SBUMessageTemplate.Renderer+RenderItems.swift in Sources */, - 3FE398357361E82A822D14FC /* SBUMessageTemplate.Renderer+RenderStyles.swift in Sources */, - 69BE5266FE4B5A3819986798 /* SBUMessageTemplate.Renderer+Utils.swift in Sources */, - 77A67C1F5A44AB3E5AEC5E14 /* SBUMessageTemplate.Renderer.Image.swift in Sources */, - 4C323B8C0D64565A5C31F777 /* SBUMessageTemplate.Renderer.RendererType.swift in Sources */, - EC1E8177EA612D6400938100 /* SBUMessageTemplate.Renderer.Views.swift in Sources */, - B32A953FFB19CD707CFE455B /* SBUMessageTemplate.Renderer.swift in Sources */, - A84C5278F00A995B3E357AEC /* SBUMessageTemplate.Syntax.Aligns.swift in Sources */, - 1D41D6C1454CC82937DEC230 /* SBUMessageTemplate.Syntax.Identifier.swift in Sources */, - D31105D429573D105CF51B4D /* SBUMessageTemplate.Syntax.Item.swift in Sources */, - DA6759309CEB090B5736ADEA /* SBUMessageTemplate.Syntax.Sizes.swift in Sources */, - E87DE39B2D383FAE60F00257 /* SBUMessageTemplate.Syntax.Styles.swift in Sources */, - 7F595FC290A932EA77CC113C /* SBUMessageTemplate.Syntax.Types.swift in Sources */, - C6EE61C38C7751AC1FE367E5 /* SBUMessageTemplate.Syntax.Views.swift in Sources */, - 19DD09C33C5BA282969E440D /* SBUMessageTemplate.TemplateList.swift in Sources */, - E2A5C652B7FB5E678480D382 /* SBUMessageTemplate.swift in Sources */, - 73A07126956A34CDDF79C72B /* SBUMessageTemplateCell.MessageTemplateLayer.swift in Sources */, - 978C78CD1448E70538A47AB8 /* SBUMessageTemplateCell.swift in Sources */, - 0B873482FEFADB21E16A6EEE /* SBUMessageTemplateCellLayout.swift in Sources */, - 3352E799FEA119A35F28E0ED /* SBUMessageTemplateCellParams.swift in Sources */, - 73CE000A9B2FA50F39AC6B1B /* SBUMessageTemplateManager.swift in Sources */, - 602D59F11EFE41978C1901E7 /* SBUMessageThreadInputView+SwiftUI.swift in Sources */, - 341397411E718FA1877632CE /* SBUMessageThreadModule.Deprecated.swift in Sources */, - 2531B2C6B57D1CB3B95A468D /* SBUMessageThreadModule.Header+SwiftUI.swift in Sources */, - CDD1D698BE1522649678E640 /* SBUMessageThreadModule.Header.swift in Sources */, - 226FF5F3F53C7972E4EA780D /* SBUMessageThreadModule.Input+SwiftUI.swift in Sources */, - 76CF2A78B301A445C3DD58B2 /* SBUMessageThreadModule.Input.swift in Sources */, - 56A9415B712A6BE6D0604B03 /* SBUMessageThreadModule.List+SwiftUI.swift in Sources */, - 7F9CFA9CEC0DD25A3822642F /* SBUMessageThreadModule.List.swift in Sources */, - AFD355B4DADBB95C7411FC98 /* SBUMessageThreadModule.swift in Sources */, - 0141C203B309D94FE9BC96F0 /* SBUMessageThreadTitleView+SwiftUI.swift in Sources */, - 7C0C0ED9C2E62A88775A257B /* SBUMessageThreadTitleView.swift in Sources */, - 5B336F13C49D1543C2A84BD2 /* SBUMessageThreadViewController.SwiftUI.swift in Sources */, - 960074B411FE7255869C7B94 /* SBUMessageThreadViewController.swift in Sources */, - A0329DB9194171E53643D399 /* SBUMessageThreadViewModel.swift in Sources */, - 295EB6A6B8612129FEDC7379 /* SBUMessageWebView.swift in Sources */, - 2B6EFBCAEB8119F31FA639AE /* SBUMessageWebViewModel.swift in Sources */, - 52EF8EF7DA1AD41FEF178541 /* SBUModerationCell.swift in Sources */, - 2D820F3F8E24448320ACF52E /* SBUModerationsModule.Deprecated.swift in Sources */, - D64166FCA5096FD3CEE19E6F /* SBUModerationsModule.Header.swift in Sources */, - 45D1330B868348CFC9332587 /* SBUModerationsModule.List.swift in Sources */, - D288D1FD498B6FA01921482A /* SBUModerationsModule.swift in Sources */, - 0D2CAA45B1EF5E2E2E6D647A /* SBUModerationsViewController.Deprecated.swift in Sources */, - E38F83998295EB297029D87A /* SBUModerationsViewController.swift in Sources */, - 3247A8C9C728645C9F0A65DC /* SBUModerationsViewModel.Deprecated.swift in Sources */, - D5A1C9DC1298E12DEF491352 /* SBUModerationsViewModel.swift in Sources */, - 4734B91D1D1600B3CE68021E /* SBUModuleSet.Deprecated.swift in Sources */, - DDFFDDFFB3DA8F867B6ADF7D /* SBUModuleSet.swift in Sources */, - 3CE30A717F80695A7424BE14 /* SBUMultipleFilesMessageCell.swift in Sources */, - 8CE94EBFC14835E4D80BC0DA /* SBUMultipleFilesMessageCellParams.swift in Sources */, - A6A41AE98F1073A58BE69B8F /* SBUMultipleFilesMessageCollectionView.swift in Sources */, - 882E1B6DFF06F1074F8157D2 /* SBUMultipleFilesMessageCollectionViewCell.swift in Sources */, - AD6DFEFE2891B862C59ADE1B /* SBUNavigationTitleView.swift in Sources */, - 152F55CC6AE8166A23EC83D3 /* SBUNewMessageInfo+SwiftUI.swift in Sources */, - 97D9739924A2824A1BC2A348 /* SBUNewMessageInfo.swift in Sources */, - F65DF3951996885296957169 /* SBUNewNotificationInfo.swift in Sources */, - 1DF4725BF5B522C48426DC88 /* SBUNotificationCell.swift in Sources */, - 8EF27574E3E0662A41B6A116 /* SBUNotificationChannelManager.swift in Sources */, - 5372A5C055FC1B99AD2F064F /* SBUNotificationEmptyView.swift in Sources */, - 86F226822B1451C19965B7E4 /* SBUNotificationNavigationTitleView.swift in Sources */, - F6A55FD4F939E34B974EC276 /* SBUNotificationTimelineView.swift in Sources */, - 7BF6212FB2FC5CFCE3D636D9 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift in Sources */, - DD26AE269E8F0A33504775F6 /* SBUOpenBannedUserListModule.List+SwiftUI.swift in Sources */, - 798F12C2585CAABC8B101321 /* SBUOpenBannedUserListUserCell+SwiftUI.swift in Sources */, - 728AF90B616A19E97D31CBD6 /* SBUOpenChannelAdminMessageCell.swift in Sources */, - 65958603D664C13D2AB935BB /* SBUOpenChannelBaseMessageCell+SwiftUI.swift in Sources */, - B8B4BF3CECA35D68ADF7A315 /* SBUOpenChannelBaseMessageCell.swift in Sources */, - 3FF42830178D1DC8CD3D6F04 /* SBUOpenChannelCell+SwiftUI.swift in Sources */, - 60DD35FDC14A3235FB83066B /* SBUOpenChannelCell.swift in Sources */, - EC29897D6C48E4070A5F2709 /* SBUOpenChannelCommonContentView.swift in Sources */, - E6FDBB24F606883B8D3A7757 /* SBUOpenChannelContentBaseMessageCell.swift in Sources */, - CDCDABD02719862BE557A3C2 /* SBUOpenChannelFileMessageCell.swift in Sources */, - CA4C607C9E77CF3E9C9CEE5F /* SBUOpenChannelImageContentView.swift in Sources */, - 888008287DE75A2749595294 /* SBUOpenChannelInputView+SwiftUI.swift in Sources */, - 582BB9DE1DBC628778B3CDEE /* SBUOpenChannelListModule.Deprecated.swift in Sources */, - 43D00C568BEC5D4CEB0BDA98 /* SBUOpenChannelListModule.Header+SwiftUI.swift in Sources */, - B52A1894069B72DED9E05620 /* SBUOpenChannelListModule.Header.swift in Sources */, - E6225EB93A8FD067A26CBDF2 /* SBUOpenChannelListModule.List+SwiftUI.swift in Sources */, - D160881E23EA2CE56DD3056A /* SBUOpenChannelListModule.List.swift in Sources */, - A7E5E3820B1BCA5799F39EA4 /* SBUOpenChannelListModule.swift in Sources */, - 46DE4A719ED6C0ECF60AB64A /* SBUOpenChannelListViewController.swift in Sources */, - A4666E9905B5691E1F2AFD98 /* SBUOpenChannelListViewModel.swift in Sources */, - A44CD72AB2BE7F02D8EFEB89 /* SBUOpenChannelMessageWebView.swift in Sources */, - 0596682EC3456B6FF4EBE4B7 /* SBUOpenChannelModule.Deprecated.swift in Sources */, - 5EB26A7581C2E9847325754B /* SBUOpenChannelModule.Header+SwiftUI.swift in Sources */, - B60EF43F2157D33F313C8D70 /* SBUOpenChannelModule.Header.swift in Sources */, - 2B9AA1BE5AC49494F02B5FF6 /* SBUOpenChannelModule.Input+SwiftUI.swift in Sources */, - 869AF52E0D0163E959C3D1E8 /* SBUOpenChannelModule.Input.swift in Sources */, - 0488280C607E8C782DA5371C /* SBUOpenChannelModule.List+SwiftUI.swift in Sources */, - C7B4A469263B7A3EF08E68C3 /* SBUOpenChannelModule.List.swift in Sources */, - 25B7BDF88C9F8F4473A01931 /* SBUOpenChannelModule.Media.swift in Sources */, - 45B3AB9192A0133C98968DDD /* SBUOpenChannelModule.swift in Sources */, - C8A06DF4347E630C56F1C374 /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */, - 73DD3712A77AED801C29013C /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */, - 2E745A54C2C179EF675EEEE0 /* SBUOpenChannelSettingCell.swift in Sources */, - A22A1FD41E8191F4B8DB7B7E /* SBUOpenChannelSettingsModule.Deprecated.swift in Sources */, - BBDA611B8615DB9582B73AC2 /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift in Sources */, - 2BD4D741D3EA96633FA5929D /* SBUOpenChannelSettingsModule.Header.swift in Sources */, - CA3C67CF1BAB3F8FCB7A1F84 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift in Sources */, - CB605F99D4F0E4569359BEE3 /* SBUOpenChannelSettingsModule.List.swift in Sources */, - E82B73F45E1B261798A3C1D9 /* SBUOpenChannelSettingsModule.swift in Sources */, - D50E407E80A53447FF9B3F83 /* SBUOpenChannelSettingsViewController.swift in Sources */, - 406BD21F5FC64E934F53B164 /* SBUOpenChannelSettingsViewModel.swift in Sources */, - A51EF1957CD733EDC8655511 /* SBUOpenChannelTitleView+SwiftUI.swift in Sources */, - FE6BAEB044A9DD64228E97CB /* SBUOpenChannelUnknownMessageCell.swift in Sources */, - 1DD67D8C0A184CFB3622746B /* SBUOpenChannelUserMessageCell.swift in Sources */, - 2BEBD502CF647A043F824505 /* SBUOpenChannelViewController+SwiftUI.swift in Sources */, - 59E177326077BCC04E09A381 /* SBUOpenChannelViewController.Deprecated.swift in Sources */, - C99EB14D4264EB0C586ECE12 /* SBUOpenChannelViewController.Unavailable.swift in Sources */, - 90B2C66740CD90D19674DB52 /* SBUOpenChannelViewController.swift in Sources */, - D7DE86DB66F59C1D32492FE0 /* SBUOpenChannelViewModel.swift in Sources */, - 36FD3D8985661691E4C856BE /* SBUOpenModerationsModule.Header+SwiftUI.swift in Sources */, - C7BD726B7EEB46493DD1B96A /* SBUOpenModerationsModule.List+SwiftUI.swift in Sources */, - 1E40B251A39274B0DDA89157 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift in Sources */, - 1CB1CCD3DB5A40FBD5128383 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift in Sources */, - 1CD7213BF7AE6B3C5FD68BCA /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift in Sources */, - 1BE5FC9A8C2FD5B5C3D3D9AC /* SBUOpenOperatorListModule.Header+SwiftUI.swift in Sources */, - 0771F7BF876B9940D2D51DFF /* SBUOpenOperatorListModule.List+SwiftUI.swift in Sources */, - A5F5BCC030E063972F5048C0 /* SBUOpenOperatorListUserCell+SwiftUI.swift in Sources */, - 03102A48C0986F20C8F64749 /* SBUOpenScrollBottomView+SwiftUI.swift in Sources */, - 390A27535C034C93B8F7EBCE /* SBUOpenUserListModule.Header+SwiftUI.swift in Sources */, - AE6CC1744A48FB93D24F8544 /* SBUOpenUserListModule.List+SwiftUI.swift in Sources */, - 6CD3D20A691DEE226074B79C /* SBUOpenUserListUserCell+SwiftUI.swift in Sources */, - 66E3D318F724C2DD14BB3995 /* SBUPaddingLabel.swift in Sources */, - A489FD72ADA4FEC1F14C4A4D /* SBUParentMessageInfoReactionView.swift in Sources */, - 54FC2D3C252EA9514A8C426E /* SBUParentMessageInfoView+SwiftUI.swift in Sources */, - 4D6BAE73205FD92DF2EAA72D /* SBUParentMessageInfoView.swift in Sources */, - A49918C6E3E8144F5F9CEF44 /* SBUPendingMessageManager.swift in Sources */, - 8657C3AEF83AD7A2D1068902 /* SBUPermissionManager.swift in Sources */, - 7E5E45E47693761072E48293 /* SBUPhotoAccess.swift in Sources */, - 791E5F692866B1DC5DB07A79 /* SBUPhotoCollectionViewCell.swift in Sources */, - 96542D691531332A9DBA8126 /* SBUPropertyWrapper.swift in Sources */, - 1885480A55126999F1DE6E8A /* SBUQuoteMessageInputView.swift in Sources */, - B52FBFE95A63654DC0E0771A /* SBUQuoteMessageInputViewParams.swift in Sources */, - F2A5E5FDD3BB6B18D1EF6835 /* SBUQuoteMessageInputViewProtocol.swift in Sources */, - B0B3EADA0ACFE07ACAD2A89A /* SBUQuotedBaseMessageView.swift in Sources */, - 80A2E031698ACA7E9CB82974 /* SBUQuotedBaseMessageViewParams.Deprecated.swift in Sources */, - E53E0BEDB6DBD11B9DBD4249 /* SBUQuotedBaseMessageViewParams.swift in Sources */, - 811751B155EA0C0797AC521E /* SBUQuotedFileMessageView.swift in Sources */, - 0B3121A9A5C7036C3181007E /* SBUQuotedMessageViewProtocol.swift in Sources */, - 15015802991AFE1E136071A2 /* SBUQuotedUserMessageView.swift in Sources */, - 0C7BA48C658CE0ED4CAB7A7A /* SBUReactionCollectionViewCell.swift in Sources */, - 727B43431066B2BE55A3736B /* SBUReactionsViewController.swift in Sources */, - 89DD1EC1DD502D00EC350B39 /* SBURegisterOperatorModule.Deprecated.swift in Sources */, - 1E9CFDDE19604AF05970F40E /* SBURegisterOperatorModule.Header.swift in Sources */, - FB92FA1E16F8B401FBF22295 /* SBURegisterOperatorModule.List.swift in Sources */, - 3FD42D94801F8F60933203C4 /* SBURegisterOperatorModule.swift in Sources */, - 8CF5347EA161D4F37A2EE09A /* SBURegisterOperatorViewController.swift in Sources */, - 5654B18C61BCA6414031A585 /* SBURegisterOperatorViewModel.swift in Sources */, - 8A0605B18C11E2482DFBBFBE /* SBUReplyConfiguration.swift in Sources */, - FA7025F697F842992DE3DB75 /* SBUScrollBottomView+SwiftUI.swift in Sources */, - C5286BDA534892079A304057 /* SBUScrollBottomView.swift in Sources */, - AFEF62DD6CD4464AA4687B82 /* SBUScrollOptions.swift in Sources */, - 88757C1BAED695420CD841F4 /* SBUScrollPostionConfiguration.swift in Sources */, - EAC99BC05AF6076D4BA9F514 /* SBUSearchBar.swift in Sources */, - E37868000C956EFAB18F0F98 /* SBUSelectablePhotoViewController.swift in Sources */, - 799B8CA047558F53292A298F /* SBUSelectableStackView.swift in Sources */, - 6328B0D463A87352055ED09F /* SBUSimpleSuggestedReplyOptionView.swift in Sources */, - BDE73C3C5B5901C89B7749B2 /* SBUStackView.swift in Sources */, - 13EF136B8AF94AD0C8811ABC /* SBUStringSet.Deprecated.swift in Sources */, - D6C387C6445C17C4D2E4B928 /* SBUStringSet.swift in Sources */, - EE18744AE360DAACB19FFA47 /* SBUSuggestedMentionList.swift in Sources */, - E9CD4A495C8815F8B47C1FD1 /* SBUSuggestedReplyOptionView.swift in Sources */, - 24749FF29AD6A6E0C47BA551 /* SBUSuggestedReplyView.swift in Sources */, - F09CF2430BE102203A4AEBB9 /* SBUSuggestedReplyViewParams.swift in Sources */, - DB784512EF2721F525CCC5AF /* SBUTableViewCell.Unavailable.swift in Sources */, - C5732121655B28735339013C /* SBUTableViewCell.swift in Sources */, - C311F7EF246404831952FCDF /* SBUTemplateLabel.swift in Sources */, - 5E6AF1F62A480310EAE344BE /* SBUTemplateType.swift in Sources */, - F8F0B40DE98424420598D32A /* SBUTextView.swift in Sources */, - A24923CE6B533A8BF0480F8E /* SBUTheme+Type.swift in Sources */, - B992CEB2B4C62A6A3FC62385 /* SBUTheme.Deprecated.swift in Sources */, - 7FA8937FB07369062A7EBAFE /* SBUTheme.swift in Sources */, - 480343725830814ADFB93582 /* SBUThreadInfoView.swift in Sources */, - 1A2C611176CCF3F1064D4306 /* SBUToastType.swift in Sources */, - BB84A1C1CD85F146B5D46626 /* SBUToastView.Internal.swift in Sources */, - 8B3A95B7E9A2926DB86EB5BA /* SBUToastView.Item.swift in Sources */, - 46AC73962DEFD970AD80F6AC /* SBUToastView.swift in Sources */, - 71B0487C7FB64F8DBFF58DF1 /* SBUTypingIndicatorBubbleView.swift in Sources */, - FD643C90E52BD127AD895ECF /* SBUTypingIndicatorInfo.swift in Sources */, - 84F293336B8C6AC202AF045D /* SBUTypingIndicatorMessage.swift in Sources */, - BEA54478E13DAC0FB099126F /* SBUTypingIndicatorMessageCell.swift in Sources */, - 05381E02BBF59AF2D639E9A7 /* SBUTypingIndicatorMessageManager.swift in Sources */, - 15AEC541D37A66CA53872261 /* SBUTypingMessageCellParams.swift in Sources */, - 7F82F1A1E5C62A71724B5366 /* SBUUnderLineTextField.swift in Sources */, - 25C520E41FC4936B075752F8 /* SBUUnknownMessageCell.swift in Sources */, - 97B0D361A9BC7A26A22021FD /* SBUUnknownMessageCellParams.swift in Sources */, - A6F20177C90E39CE5A5C7962 /* SBUUser.swift in Sources */, - 3D1719AAFB70F1E31F4EC696 /* SBUUserCell.swift in Sources */, - 6B73694B6281E401BDDF6A86 /* SBUUserListModule.Deprecated.swift in Sources */, - 8573108EB9817D925B933311 /* SBUUserListModule.Header.swift in Sources */, - 5C9880E54330BFDECBC0C02E /* SBUUserListModule.List.swift in Sources */, - AC2F3589344FEEBC2A540BD7 /* SBUUserListModule.swift in Sources */, - 01198926DBBD9D8D39D76595 /* SBUUserListViewController.swift in Sources */, - 29BE03D00D366B85209BD197 /* SBUUserListViewModel.swift in Sources */, - 21A67DAEA05E61BC99F5D0CB /* SBUUserMentionConfiguration.swift in Sources */, - 18157D39446334925AAAAF9B /* SBUUserMessageCell.swift in Sources */, - 237893FFC266BAB3578B4489 /* SBUUserMessageCellParams.swift in Sources */, - 921EFBA21BE951E3863281E8 /* SBUUserMessageTextView.swift in Sources */, - 242B18DA84070DC4F609033E /* SBUUserMessageTextViewModel.swift in Sources */, - 5938A517DB245EE5AFB54C2A /* SBUUserNameView.swift in Sources */, - 1BBAA717CCB2197403FE4B48 /* SBUUserProfileView.swift in Sources */, - FF50672171E8A155132A92B6 /* SBUUtils.swift in Sources */, - 5C39A59836B3CAB59744DFE5 /* SBUVerticalSuggestedReplyView.swift in Sources */, - A80D13A1BEBDC0D06CE6E3E3 /* SBUView.Unavaliable.swift in Sources */, - E3ECA6E25F4FE009310D1E30 /* SBUView.swift in Sources */, - 0065D6AA9D787B828A0880B6 /* SBUViewControllerSet.swift in Sources */, - 73F5820D874BD63ECFE0B5CB /* SBUViewLifeCycle.swift in Sources */, - 31488BBD3C2421112A77A970 /* SBUViewModelDelegate.swift in Sources */, - E17930904D0C67EF43A9937A /* SBUViewModelSet.swift in Sources */, - 9D393C3437FF919AA8AE763C /* SBUVoiceContentView.swift in Sources */, - 380277562989E6254E9D5B04 /* SBUVoiceFileInfo.swift in Sources */, - 1CF6CC40EECB4EC563E19158 /* SBUVoiceMessageConfiguration.swift in Sources */, - 33ECE34C057447D26C83E6CA /* SBUVoiceMessageInputView.swift in Sources */, - 153D98B039DCF5F5084D88F9 /* SBUVoicePlayer.swift in Sources */, - 67C6683A660CF0ABFD12862E /* SBUVoiceRecorder.swift in Sources */, - A5E62E8AF5FDF66ECCD728EA /* SBViewConverterSet.swift in Sources */, - 0A230327F67B275C554C0AA3 /* Sendbird.swift in Sources */, - 0BFB374169F7A70227B32B68 /* SendbirdUI+SwiftUI.swift in Sources */, - 785FE7080A6BB20F6FC9117F /* SendbirdUI.Deprecated.swift in Sources */, - 8020914212378DB0CB861084 /* SendbirdUI.swift in Sources */, - 2558BB2B7FBB80024FFA9D84 /* Sequence+SBUIKit.swift in Sources */, - B658DE87280EDB22AD2ED2CC /* String+SBUIKit.swift in Sources */, - A9956F5640BBEACF104D1F0F /* StringProtocol+SBUIKit.swift in Sources */, - 39FEDD7154D8A830F6CF419B /* SwiftUIMessageInputInterface.swift in Sources */, - 6F35423AB5238BD924BF8EB1 /* SwiftUIViewController.swift in Sources */, - D3775D72291D8243C42B000E /* Thread+SBUIKit.swift in Sources */, - 629055AEB92A061CA912F275 /* UIApplication+SBUIKit.swift in Sources */, - F2A5904C3A514379ED495E33 /* UIButton+SBUIKit.swift in Sources */, - F78D508B82FF6AF8575ECC04 /* UICollectionView+SBUIKit.swift in Sources */, - D7531BC55DDC2FD53CFCF70A /* UIColor+SBUIKit.swift in Sources */, - 265BA70DB6A018F1AE1D2ECE /* UIFont+Sendbird.swift in Sources */, - ACB2B91137FA560631B8E21C /* UIImage+SBUIKit.swift in Sources */, - AC7DEE4A7DB6C68B1859C8E7 /* UIImageView+SBUIKit.swift in Sources */, - 9DCBC61C17B73DBD921AE8BA /* UINavigationController+SBUIKit.swift in Sources */, - A4677726C13987128860A646 /* UIScrollView+SBUIKit.swift in Sources */, - EDBFC9051041DEB903DEF868 /* UIStackView.SBUIKit.swift in Sources */, - 53E719A697BF0C7C0634477C /* UITableView+SBUIKit.swift in Sources */, - 8DC71A5EBE84A03C5DC366ED /* UITextField+SBUIKit.swift in Sources */, - 0E7EF6182788D615A13C630C /* UIView+SBUIKit.swift in Sources */, - 82A13655F33C7B331CADEC26 /* UIViewController+SBUIKit.swift in Sources */, - 6FFB9F61D3B5DE9F3270D6BF /* URL+SBUIKit.swift in Sources */, + 9918FE4EEE6E752361D552C2 /* QuotedFileCommonContentView.swift in Sources */, + E44C5E8E735A88195F730DDC /* QuotedFileImageContentView.swift in Sources */, + DE77932BB62B6C6ABB50E6C5 /* SBUActionSheet.Item.swift in Sources */, + 97B232653308AF1CE34273F0 /* SBUActionSheet.swift in Sources */, + 2D1855925DC14BAB78327DFE /* SBUAdminMessageCell.swift in Sources */, + A956D8EBFB89FF3310507B02 /* SBUAdminMessageCellParams.swift in Sources */, + 13F17B7FDD4E9FF8A933C8FD /* SBUAlertView.Item.swift in Sources */, + 45A202A38205D388F6F09959 /* SBUAlertView.swift in Sources */, + E91364FF0B3A7683F5EB70ED /* SBUAnimation.swift in Sources */, + D95D59BCCD0E4ED0672E423F /* SBUAvailable.swift in Sources */, + 989798AC7122EDCF7DA308BF /* SBUBarButtonItem.swift in Sources */, + B1F6791421A548C309C24103 /* SBUBaseCarouselView.swift in Sources */, + E324F27541808F977BEB3461 /* SBUBaseChannelCell.swift in Sources */, + 19B611A4548CFA8C5102D78C /* SBUBaseChannelListModule.Header.swift in Sources */, + A3A26CCE760C24CD75C5E071 /* SBUBaseChannelListModule.List.swift in Sources */, + 3D9A6996BE88C59EB045C07F /* SBUBaseChannelListModule.swift in Sources */, + 6081F52FD872DF19BCCD56D0 /* SBUBaseChannelListViewController.swift in Sources */, + 08931227D365B7E2FC9630A9 /* SBUBaseChannelListViewModel.swift in Sources */, + 63D334E69BFDBB0EEDD979C0 /* SBUBaseChannelModule.Deprecated.swift in Sources */, + 62415E72995182D94B8FF86A /* SBUBaseChannelModule.Header.swift in Sources */, + 326B0ECA1C45B979A3A438AB /* SBUBaseChannelModule.Input.swift in Sources */, + F6D5FC9F804C150B5E5FBB3A /* SBUBaseChannelModule.List.swift in Sources */, + 1E75BE962CC544B3DBE71148 /* SBUBaseChannelModule.swift in Sources */, + B4C210205F10E991AD9075E3 /* SBUBaseChannelSettingCell.swift in Sources */, + 8BD2A4C9AE40F902D4812AF5 /* SBUBaseChannelSettingsModule.Header.swift in Sources */, + 248F30AE152079810432DB60 /* SBUBaseChannelSettingsModule.List.swift in Sources */, + B4114B6E30FB7F2A58AC3928 /* SBUBaseChannelSettingsModule.swift in Sources */, + BA4D55F28A21CED586FC2142 /* SBUBaseChannelSettingsViewController.Deprecated.swift in Sources */, + 75298996C8301E78AC5B781F /* SBUBaseChannelSettingsViewController.swift in Sources */, + FE34B74BEB4902E0A23BDD64 /* SBUBaseChannelSettingsViewModel.swift in Sources */, + 6E349189BE6D0342A5ED49C0 /* SBUBaseChannelViewController.Deprecated.swift in Sources */, + 515776BA921831318D7C5366 /* SBUBaseChannelViewController.Keyboard.swift in Sources */, + D890BDF7EA7E8F299CB771C6 /* SBUBaseChannelViewController.Unavailable.swift in Sources */, + 8A407D2C3CFE9FC0EE63C2B1 /* SBUBaseChannelViewController.swift in Sources */, + AC523E807AE951B214E773DB /* SBUBaseChannelViewModel.swift in Sources */, + 4092C8C02C9D014C95965819 /* SBUBaseFileContentView.swift in Sources */, + 574CF37D9D0E030B282D0054 /* SBUBaseMessageCell+SwiftUI.swift in Sources */, + 00C488A81560EF0A64874F47 /* SBUBaseMessageCell.Feedback.swift in Sources */, + 88FAAC0E19331859E9F0A86F /* SBUBaseMessageCell.MessageThread+SwiftUI.swift in Sources */, + 945C1C41A6F6A93DE84B5416 /* SBUBaseMessageCell.swift in Sources */, + 168321D0F7F44797E10226F0 /* SBUBaseMessageCellParams.Deprecated.swift in Sources */, + 6EE24A100E14C610574F361E /* SBUBaseMessageCellParams.swift in Sources */, + 314E67B382A2A0129E41DE99 /* SBUBaseSelectUserModule.Header.swift in Sources */, + 559579090B163B8A9BA33EB7 /* SBUBaseSelectUserModule.List.swift in Sources */, + 6BB3C117ACD1A65B9A4C7510 /* SBUBaseSelectUserModule.swift in Sources */, + B5F14B579862C764BC790C3A /* SBUBaseSelectUserViewController.Deprecated.swift in Sources */, + C315D49E7D1B47CFE7AF9E92 /* SBUBaseSelectUserViewController.swift in Sources */, + D7C7A88AFF4A08EF7105823E /* SBUBaseSelectUserViewModel.swift in Sources */, + 3995D511AD5734E72ED66070 /* SBUBaseViewController.Unavailable.swift in Sources */, + D79DA58655048691F33C1324 /* SBUBaseViewController.swift in Sources */, + CEB27644D5A809454035EEF4 /* SBUBottomSheetController.swift in Sources */, + 7D8DB25B63042F2D7F505632 /* SBUCacheManager.Config.swift in Sources */, + 82CEECFAA499AA52533DAC0B /* SBUCacheManager.File.swift in Sources */, + 8E43876AFEA9D4B2C4CAC14C /* SBUCacheManager.Image.swift in Sources */, + 5EC3E529BD5BCC9C89219F3F /* SBUCacheManager.NotificationSetting.swift in Sources */, + 1ED181995790C6173895BFA4 /* SBUCacheManager.Template.swift in Sources */, + E7BED5E5EB91E0764A60C357 /* SBUCacheManager.Version.swift in Sources */, + 3032B6EB19E62C7DB57903ED /* SBUCacheManager.swift in Sources */, + D88C96CEB93A889B58FB26B2 /* SBUCategoryFilterCell.swift in Sources */, + 732DB302FC8B4962E92BA430 /* SBUChannelInfoHeaderView.swift in Sources */, + E41876A47FC63195B2042B16 /* SBUChannelListViewController.Deprecated.swift in Sources */, + A8D5F71FEA78EC29BABCF451 /* SBUChannelPushSettingCell.swift in Sources */, + CCE9F1723767764548D89129 /* SBUChannelSettingItem.swift in Sources */, + 733E5B71D657B2031C69DFF0 /* SBUChannelSettingsChannelInfoView.swift in Sources */, + 42A575D8819B486F049C33DF /* SBUChannelStateBanner+SwiftUI.swift in Sources */, + 6AE289C164DD701E3973260B /* SBUChannelStateBanner.MessageThread+SwiftUI.swift in Sources */, + B39B1F447C795BB4874DB28F /* SBUChannelStateBanner.swift in Sources */, + E646BD797B5C1865C71C1A03 /* SBUChannelTitleView+SwiftUI.swift in Sources */, + 3A1AD29BAA5DAE35CC9FE3CA /* SBUChannelTitleView.swift in Sources */, + E9670E0623792580346E32D9 /* SBUChatNotificationCell.swift in Sources */, + A32E16AF72CAE96B107D470C /* SBUChatNotificationChannelModule.Deprecated.swift in Sources */, + 6EA99118081FB889DA5DC1FE /* SBUChatNotificationChannelModule.Header.swift in Sources */, + 2BE7CBBB357759A3872E5C0C /* SBUChatNotificationChannelModule.List.swift in Sources */, + 5498D2DB8A283178433BCCE0 /* SBUChatNotificationChannelModule.swift in Sources */, + 564F1B6B7AE4402631180FD2 /* SBUChatNotificationChannelViewController.swift in Sources */, + 97999D8F0976ACBE224DECDB /* SBUChatNotificationChannelViewModel.swift in Sources */, + BF0FA5920391E0C76F500286 /* SBUCollectionViewCell.swift in Sources */, + E233ECD670D245502190617D /* SBUCollectionViewFlowLayout.swift in Sources */, + 6CA904E0C8A1B010E9B5159E /* SBUColorSet.swift in Sources */, + FC274050B793974FA5B3B325 /* SBUCommonContentView.swift in Sources */, + 6EB56EDEC523643DC9C2B3C2 /* SBUCommonDelegate.swift in Sources */, + 6B04459F796AFCDB1D50D3F9 /* SBUCommonItem.swift in Sources */, + A18151C9932C6695D180A853 /* SBUCommonModule.swift in Sources */, + DA21E2E8D4568E10184C5829 /* SBUCommonViewControllerSet.swift in Sources */, + FCD03C34AE2221900E9F9C82 /* SBUConfig.Base.swift in Sources */, + 1D0FD5DBEE14840FE2B9E4ED /* SBUConfig.CodingKeys.swift in Sources */, + 10D645939926994E2369D679 /* SBUConfig.Common.swift in Sources */, + 8588EA58929A46E1C917B41B /* SBUConfig.GroupChannel.swift in Sources */, + 99B3B251DA5CE47373F11D55 /* SBUConfig.OpenChannel.swift in Sources */, + 7C99078737FB1A94FE3E2CC4 /* SBUConfig.swift in Sources */, + B6AB46E57719FD3967ACFB7A /* SBUConfigManager.swift in Sources */, + 836605B9CC401A3A75EEABBF /* SBUConstant.swift in Sources */, + 2FD0CE6A1C02AB2E54028CD9 /* SBUContentBaseMessageCell.Deprecated.swift in Sources */, + 13E4E6078E5CD48C96B09D21 /* SBUContentBaseMessageCell.swift in Sources */, + 24C047AAFDBA0AB98A880EEB /* SBUCoverImageView.Deprecated.swift in Sources */, + 3407C53E67355F05BD5568CC /* SBUCoverImageView.swift in Sources */, + CB9F986AD0DA4AEB83EC304A /* SBUCreateChannelModule.Deprecated.swift in Sources */, + 4096F9B85946CE4F57E4BB21 /* SBUCreateChannelModule.Header.swift in Sources */, + A1A17DC4B0D017AAC7967C36 /* SBUCreateChannelModule.List.swift in Sources */, + 95A7CC65BD2CA6A377D9AA95 /* SBUCreateChannelModule.swift in Sources */, + 13716072DD23C523DE7173CE /* SBUCreateChannelTypeSelector.swift in Sources */, + 0F74F4016F18E2A99B5A8FF3 /* SBUCreateChannelViewController.Deprecated.swift in Sources */, + 6B557999AEF72BE97F4E11EC /* SBUCreateChannelViewController.swift in Sources */, + A97BA713BA19DB9E55E30B18 /* SBUCreateChannelViewModel.swift in Sources */, + 8027CA105DCC384F42A15034 /* SBUCreateGroupChannelModule.Header+SwiftUI.swift in Sources */, + 771C5437EECAA571DF8C9B8F /* SBUCreateGroupChannelModule.List+SwiftUI.swift in Sources */, + 33F211B7F47CC6FC91C639AF /* SBUCreateGroupChannelUserCell+SwiftUI.swift in Sources */, + 86CD5796D4AAE048134ADF51 /* SBUCreateOpenChannelModule.Deprecated.swift in Sources */, + 4DEBBC6C537F17808B683CE0 /* SBUCreateOpenChannelModule.Header+SwiftUI.swift in Sources */, + 248335178A5D2248F1CA75F5 /* SBUCreateOpenChannelModule.Header.swift in Sources */, + 48F24D873C5E14C5463F7218 /* SBUCreateOpenChannelModule.ProfileInput.swift in Sources */, + DDE9EC09148983597313BEE8 /* SBUCreateOpenChannelModule.swift in Sources */, + 285FF707C19A9BEFC6DB19DC /* SBUCreateOpenChannelViewController.swift in Sources */, + 62D54992B9A2BDDED8FEBB6E /* SBUCreateOpenChannelViewModel.swift in Sources */, + 3775E1F124A1E5B53F9C542E /* SBUDashboardConfig.swift in Sources */, + ED24A05588C5B781AAD3088F /* SBUDateFormatSet.swift in Sources */, + 5DABF30A10C7F8FCF51F8CF3 /* SBUDebouncer.swift in Sources */, + A6DD3777FCBE43236A2D2C47 /* SBUDownloadManager.swift in Sources */, + 099A2EDAE7CA9DFE548C0143 /* SBUEmojiListViewController.swift in Sources */, + C477AACF553B28BEF3426651 /* SBUEmojiManager.swift in Sources */, + D451110E7911228D3FAD2107 /* SBUEmptyView.swift in Sources */, + A4FA58B4BD13E6AC259878AC /* SBUEnums.Deprecated.swift in Sources */, + D658DC3A36C27319A7B922ED /* SBUEnums.swift in Sources */, + 60BB44F946CED611E9035E0C /* SBUError.swift in Sources */, + 86E6148CBF2BFD02FDA80732 /* SBUExtendedMessagePayload.swift in Sources */, + A5ECD7407BE4BC3F516F1E84 /* SBUExtendedMessagePayloadCustomViewFactory.swift in Sources */, + 1FD06B124BE1EC29BDA99E07 /* SBUExtendedMessagePayloadForUI.swift in Sources */, + 8F046AB06FDE6D8784E4F615 /* SBUFeedNotificationCell.swift in Sources */, + 193FF15E70578558727AB9AA /* SBUFeedNotificationCellParams.swift in Sources */, + BE805271B9F890151B99CD01 /* SBUFeedNotificationChannelModule.CategoryFilter.swift in Sources */, + 54F9C3EF451880E03DD9C14D /* SBUFeedNotificationChannelModule.Deprecated.swift in Sources */, + A42F4EB37662F040D1951E75 /* SBUFeedNotificationChannelModule.Header.swift in Sources */, + 4564699A876DFD2A314226E7 /* SBUFeedNotificationChannelModule.List.swift in Sources */, + 4D2E42308F42E09855A1CD9B /* SBUFeedNotificationChannelModule.swift in Sources */, + D1CB8CA45AFBC1AB83DE141E /* SBUFeedNotificationChannelViewController.swift in Sources */, + 9EB93409B98FF75A35D29D02 /* SBUFeedNotificationChannelViewModel.swift in Sources */, + F5628D78C4C3F85E893DC907 /* SBUFeedNotificationChannelViewParams.swift in Sources */, + 41BACBFFB4567EAB3B95C50E /* SBUFeedbackAction.swift in Sources */, + 61929D39E1A432B862767F07 /* SBUFeedbackView.swift in Sources */, + 85080FE10A399FFEC8482641 /* SBUFeedbackViewParams.swift in Sources */, + 2F5B011BD22FFA86602E290A /* SBUFileMessageCell.swift in Sources */, + 6FFCCD3AE31B1E858F6A6EAD /* SBUFileMessageCellParams.swift in Sources */, + BFC78F2763ED79A041F3728E /* SBUFileViewController.swift in Sources */, + 25A83ADAC036FA0729E05948 /* SBUFontSet.swift in Sources */, + 7A9A43692C612EA3BEE35FBB /* SBUForm.Deprecated.swift in Sources */, + B52788A2901F6128B2076AC3 /* SBUFormFieldView.Deprecated.swift in Sources */, + D73131BD56BB892C8FCA7ABC /* SBUFormView.Deprecated.swift in Sources */, + 98C21D5C393D3BE562A0297A /* SBUFormViewParams.Deprecated.swift in Sources */, + 53E72628745B9E63E1C95C43 /* SBUGlobalCustomParams.swift in Sources */, + 04C9C81C378C25E41DD22BB2 /* SBUGlobals.Deprecated.swift in Sources */, + F1A8E19D9E8F85F92DFE32FD /* SBUGlobals.swift in Sources */, + 73A87006FCAEFD7C0359D93E /* SBUGroupBannedUserListModule.Header+SwiftUI.swift in Sources */, + 4C0FC99E2A2DEB35CAAD19D4 /* SBUGroupBannedUserListModule.List+SwiftUI.swift in Sources */, + 76B4CFCFBBE6B97081FF81BE /* SBUGroupBannedUserListUserCell+SwiftUI.swift in Sources */, + 2C2C30195CDFBB187131408E /* SBUGroupChannelCell+SwiftUI.swift in Sources */, + 519717F281CEB36BCBED4BE7 /* SBUGroupChannelCell.swift in Sources */, + B2C3F62C2CD9741A4D00D8D6 /* SBUGroupChannelListModule.Common.swift in Sources */, + F1DB1E3587B55F0EFED1E5DB /* SBUGroupChannelListModule.Deprecated.swift in Sources */, + C13105058293FDCEFE9C18F8 /* SBUGroupChannelListModule.Header+SwiftUI.swift in Sources */, + A306E8898D0C3999C52E3676 /* SBUGroupChannelListModule.Header.swift in Sources */, + 7D43A4DDC699B50998184A85 /* SBUGroupChannelListModule.List+SwiftUI.swift in Sources */, + D6EB199C43B90E162A2F20B3 /* SBUGroupChannelListModule.List.swift in Sources */, + 5673DF20BB7DA1E7011C473D /* SBUGroupChannelListModule.swift in Sources */, + 1820475945938BFF7FE245C4 /* SBUGroupChannelListViewController.swift in Sources */, + 2DD96D0591F2FEBEC2E6E867 /* SBUGroupChannelListViewModel.swift in Sources */, + 849267C24B79D5262E20A32A /* SBUGroupChannelModule.Deprecated.swift in Sources */, + B1341030A8607D803824FF7A /* SBUGroupChannelModule.Header+SwiftUI.swift in Sources */, + F61D156276F3F8107A1C9766 /* SBUGroupChannelModule.Header.swift in Sources */, + B0C25591651A78C1816F9893 /* SBUGroupChannelModule.Input+SwiftUI.swift in Sources */, + 78FFE2C752BD028D33D288DF /* SBUGroupChannelModule.Input.swift in Sources */, + 93D434C8E8B82070B9DFC1FA /* SBUGroupChannelModule.List+SwiftUI.swift in Sources */, + DDDC2FB959B3E2B39EA8EACC /* SBUGroupChannelModule.List.swift in Sources */, + F9E8A5C906219EB9DA3F6453 /* SBUGroupChannelModule.swift in Sources */, + 755884802F1253F871FAEC4C /* SBUGroupChannelPushSettingsModule.Deprecated.swift in Sources */, + 8A729DD853E751CB489D6635 /* SBUGroupChannelPushSettingsModule.Header+SwiftUI.swift in Sources */, + E41B3AD45A7869B7EB6D7B83 /* SBUGroupChannelPushSettingsModule.Header.swift in Sources */, + F23AE46531423592266716C2 /* SBUGroupChannelPushSettingsModule.List+SwiftUI.swift in Sources */, + 1EDF91717F258127078B8C74 /* SBUGroupChannelPushSettingsModule.List.swift in Sources */, + D24D1F87034D4265CBDEC307 /* SBUGroupChannelPushSettingsModule.swift in Sources */, + D66D65F95BCC0BE6B11E7D75 /* SBUGroupChannelPushSettingsViewController.swift in Sources */, + 460031BC6C7688929FF5BEB9 /* SBUGroupChannelPushSettingsViewModel.swift in Sources */, + 2034AC28EDE34FCFC1C6CBF9 /* SBUGroupChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */, + 6100303B05C35D95DA524E2D /* SBUGroupChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */, + 75410ED22270B7B5BB199AD4 /* SBUGroupChannelSettingCell+SwiftUI.swift in Sources */, + 583651736657E4B62F1A6B83 /* SBUGroupChannelSettingCell.swift in Sources */, + AB84A187B143A2965E92D9DA /* SBUGroupChannelSettingsModule.Deprecated.swift in Sources */, + 882F0C559D38825AB12B87CC /* SBUGroupChannelSettingsModule.Header+SwiftUI.swift in Sources */, + D71AE9F8940934FD27BA0934 /* SBUGroupChannelSettingsModule.Header.swift in Sources */, + 58CB7486FBB7A50F7AF4EE52 /* SBUGroupChannelSettingsModule.List+SwiftUI.swift in Sources */, + D5A6F0567923769FA2398C7E /* SBUGroupChannelSettingsModule.List.swift in Sources */, + B7DB4D2480F0217ED10A74E5 /* SBUGroupChannelSettingsModule.swift in Sources */, + FB0B9C2C8A82B5CFAA6F75DF /* SBUGroupChannelSettingsViewController.swift in Sources */, + 1DDE050C3CD80D80788F2DB5 /* SBUGroupChannelSettingsViewModel.swift in Sources */, + 0FA3ED5FF3C7A82A72DB865C /* SBUGroupChannelViewController+SwiftUI.swift in Sources */, + F5A4DB321A03CCA71E6F3E78 /* SBUGroupChannelViewController.Deprecated.swift in Sources */, + D1A3D8B42F5939F1619D5A36 /* SBUGroupChannelViewController.Unavailable.swift in Sources */, + 44F4C460574D81E299679162 /* SBUGroupChannelViewController.swift in Sources */, + EC1FD23F4261BCDC439DCE79 /* SBUGroupChannelViewModel.swift in Sources */, + 75FE26AA4B907C484F2A9483 /* SBUGroupModerationsModule.Header+SwiftUI.swift in Sources */, + 4248888996DDC01CE0F9C829 /* SBUGroupModerationsModule.List+SwiftUI.swift in Sources */, + A5766120AA2BC59813883C58 /* SBUGroupMutedMemberListModule.Header+SwiftUI.swift in Sources */, + 79EE6C6C3317C68081075891 /* SBUGroupMutedMemberListModule.List+SwiftUI.swift in Sources */, + 238FF11DD9F3E063E74F3586 /* SBUGroupMutedMemberListUserCell+SwiftUI.swift in Sources */, + AC6DA27873A79F456DDB2C92 /* SBUGroupOperatorListModule.Header+SwiftUI.swift in Sources */, + 797ED487D628A88BD5F11558 /* SBUGroupOperatorListModule.List+SwiftUI.swift in Sources */, + CA6C733C11200AB1BFC3F227 /* SBUGroupOperatorListUserCell+SwiftUI.swift in Sources */, + 5EB2291F44643B8AB2324A7F /* SBUGroupUserListModule.Header+SwiftUI.swift in Sources */, + C52BD4EBC048E6A9FDC781AE /* SBUGroupUserListModule.List+SwiftUI.swift in Sources */, + 985DC2B0D76F7C2DA401706C /* SBUGroupUserListUserCell+SwiftUI.swift in Sources */, + 9FB795B410EFF663AA5AAAE0 /* SBUHighlightMessageInfo.swift in Sources */, + C1E6CD32A54E001AD7A32C1B /* SBUHorizontalSuggestedReplyOptionView.swift in Sources */, + 626FB4EB33334F39BAA9C645 /* SBUHorizontalSuggestedReplyView.swift in Sources */, + 868FFE104D525ACE8BAA05F3 /* SBUIconSet.swift in Sources */, + ADEDFD3D4867535940B03384 /* SBUIconSetType.swift in Sources */, + 2ED2E470F7DC8ED1CF2315F0 /* SBUImageContentView.swift in Sources */, + 975C77F875B47855AA8CD09D /* SBUInviteUserCell+SwiftUI.swift in Sources */, + 6C5856F01FCFF1D761309379 /* SBUInviteUserModule.Deprecated.swift in Sources */, + 9E32572DAC5785DCC6616732 /* SBUInviteUserModule.Header+SwiftUI.swift in Sources */, + EAB3A741FAB9074738198031 /* SBUInviteUserModule.Header.swift in Sources */, + BA52BAF30C192E824DF2680E /* SBUInviteUserModule.List+SwiftUI.swift in Sources */, + ACA20BE3B7ECBF135B0D3BE8 /* SBUInviteUserModule.List.swift in Sources */, + 0D1AAB233E88F9E3B385B1DE /* SBUInviteUserModule.swift in Sources */, + 1BD2FDDBCF28B325ED23743F /* SBUInviteUserViewController.swift in Sources */, + 5F02D23CA3FE3A01E2F78B37 /* SBUInviteUserViewModel.swift in Sources */, + 881BC3027B2BD7BA53C02685 /* SBULabel.swift in Sources */, + B2ABAE2CFC3FC3ACE24E784B /* SBULayoutableButton.swift in Sources */, + ABF3FE1455979C3B736DDC1A /* SBULazyView.swift in Sources */, + BCBBAD59C9D31BE03EA7CC63 /* SBULinkClickableTextView.swift in Sources */, + 02B33E2B9E007EC37070C22D /* SBULoading.swift in Sources */, + 230BD6735D8A6BF1421E3637 /* SBULogger.swift in Sources */, + 925AA726A5F8F8C54F11A033 /* SBUMarginView.swift in Sources */, + 6A9B427E41716EC0F1A36A54 /* SBUMarkdownTransfer.swift in Sources */, + 2B524BCC88FFE8180C10DCA7 /* SBUMediaView.swift in Sources */, + EA8AA3192A5F5D990B6ACB17 /* SBUMemberListViewController.Deprecated.swift in Sources */, + 097DC8B40B2D870D5AA19E33 /* SBUMention.swift in Sources */, + 82A898BACC6F2F1FD574F8F0 /* SBUMentionConfiguration.swift in Sources */, + 2525EC086630E66A03B5DC26 /* SBUMentionLimitGuideCell.swift in Sources */, + 7571C94F245C2E7E74AD6187 /* SBUMentionManager.swift in Sources */, + 2F9F8DB1DED4A17E46EB786F /* SBUMenuCell.swift in Sources */, + CB7D95A81730FC2FA35B99AD /* SBUMenuSheetViewController.swift in Sources */, + 5D96DDBE4A3EA76F3055399F /* SBUMenuView.swift in Sources */, + 6588D766BBF57986CC992752 /* SBUMessageCache.swift in Sources */, + 2A20717EAEA0FC6226AFC67C /* SBUMessageCellConfiguration.swift in Sources */, + 5F93369C8DC21FC1FBFF14EC /* SBUMessageCellProtocol.swift in Sources */, + F9C2912608CC5EAA33B09C3C /* SBUMessageDateView.swift in Sources */, + 77804AA5E6072297F429A920 /* SBUMessageFormChipView.swift in Sources */, + 34C3EFDD816902E6ABBD97A4 /* SBUMessageFormChipsItemView.swift in Sources */, + C9CE8F6CD847D0BC2C574D10 /* SBUMessageFormFallbackView.swift in Sources */, + B17DC93AB903620508167E1F /* SBUMessageFormItemView.swift in Sources */, + AD5A82348CABF8286ADA4387 /* SBUMessageFormMultiTextItemView.swift in Sources */, + 9FF53CDF8DA213BC1591FD03 /* SBUMessageFormSingleTextItemView.swift in Sources */, + 140FB25B85486638A0BE4C4D /* SBUMessageFormView.swift in Sources */, + 710FAF2DBD1923BFF837E29E /* SBUMessageFormViewParams.swift in Sources */, + 439D98329817EA406BB74B3E /* SBUMessageInputMode.swift in Sources */, + 103F4D7BE202A4F1F1307B84 /* SBUMessageInputView+SwiftUI.swift in Sources */, + 74F6E4EEE99721439E3FCC0A /* SBUMessageInputView.swift in Sources */, + 20A39FBACE4A33889DE64B91 /* SBUMessageProfileView.swift in Sources */, + 180AC254F1DDA0DEBC3E45D3 /* SBUMessageReactionView.swift in Sources */, + 2F5E500F640760FDCA36B51F /* SBUMessageSearchModule.Deprecated.swift in Sources */, + 98CCA32E71C6724A69DFD8BA /* SBUMessageSearchModule.Header+SwiftUI.swift in Sources */, + 112E01B82F75D4D02921299E /* SBUMessageSearchModule.Header.swift in Sources */, + 24BF8CFD883CDAA204765E8D /* SBUMessageSearchModule.List+SwiftUI.swift in Sources */, + 7872E67C27C3D19415B44720 /* SBUMessageSearchModule.List.swift in Sources */, + FA3E54416512FA88DD8E159E /* SBUMessageSearchModule.swift in Sources */, + 1C974CABBD0DE21CE565B2A0 /* SBUMessageSearchResultCell.swift in Sources */, + FFB32DABB639C49C4755DD6F /* SBUMessageSearchViewController.Deprecated.swift in Sources */, + 83ED3B750DFFD0857F6AFA29 /* SBUMessageSearchViewController.swift in Sources */, + 3C664C9410C90EDC17B9F397 /* SBUMessageSearchViewModel.swift in Sources */, + C880AB65922F91959C306FF2 /* SBUMessageStateView.swift in Sources */, + 7A55A24D142F4DE901440E9D /* SBUMessageTemplate.Action.swift in Sources */, + 6849F15D4D7D0DDB13B7CCF6 /* SBUMessageTemplate.Binder.swift in Sources */, + 7EFDEBEAAF1DBDED177EE139 /* SBUMessageTemplate.Container.swift in Sources */, + D0547F6D251988A8EA4C079B /* SBUMessageTemplate.Coordinator.swift in Sources */, + 1EA1B94BD1DE798DBC92E0F3 /* SBUMessageTemplate.Decoders.swift in Sources */, + 15D335EDBF557813CF0B7DE9 /* SBUMessageTemplate.ErrorMessages.swift in Sources */, + B694EC442D0171B5EE6E3B02 /* SBUMessageTemplate.ImageRatioType.swift in Sources */, + 0C747AC29AABEC0933228BB5 /* SBUMessageTemplate.Payload.swift in Sources */, + AB38B7A496B8637A29331FF3 /* SBUMessageTemplate.PayloadType.swift in Sources */, + 2C2D7B352437FC0FE1C3BD2E /* SBUMessageTemplate.Renderer+Events.swift in Sources */, + 4FF5FAFB147DBC0064CE8991 /* SBUMessageTemplate.Renderer+RenderItems.swift in Sources */, + 16A2639ABADF02310D7681F0 /* SBUMessageTemplate.Renderer+RenderStyles.swift in Sources */, + 735542E7E87B6C11A55336E5 /* SBUMessageTemplate.Renderer+Utils.swift in Sources */, + E007334B519593C1204810F1 /* SBUMessageTemplate.Renderer.Image.swift in Sources */, + 18E68A1318906554CFD9F758 /* SBUMessageTemplate.Renderer.RendererType.swift in Sources */, + 17F67B46A6B3EF856DDE32F6 /* SBUMessageTemplate.Renderer.Views.swift in Sources */, + 3ED50515BC8E8E8AA26CDBF1 /* SBUMessageTemplate.Renderer.swift in Sources */, + 3DC67644E3563B914CC5A8E6 /* SBUMessageTemplate.Syntax.Aligns.swift in Sources */, + 328D8DAD258C15EFD986FBE1 /* SBUMessageTemplate.Syntax.Identifier.swift in Sources */, + 22C17F40E9DD1D81F417BD2C /* SBUMessageTemplate.Syntax.Item.swift in Sources */, + 57B6A48AC3DBB236593DAB15 /* SBUMessageTemplate.Syntax.Sizes.swift in Sources */, + BB253B4C99A3EF6539011459 /* SBUMessageTemplate.Syntax.Styles.swift in Sources */, + 31DC3DBD4670E7AE72C005AE /* SBUMessageTemplate.Syntax.Types.swift in Sources */, + A59074FB7F583D580D028A92 /* SBUMessageTemplate.Syntax.Views.swift in Sources */, + F9463E2CA150EF9329E14BDF /* SBUMessageTemplate.TemplateList.swift in Sources */, + F10A8905E2E771AD3163C17F /* SBUMessageTemplate.swift in Sources */, + 27E39608589E3AD66A2440B7 /* SBUMessageTemplateCell.MessageTemplateLayer.swift in Sources */, + 0CF3C73661223534635C9658 /* SBUMessageTemplateCell.swift in Sources */, + 10B2ABFE9DBB9C42A0575A2B /* SBUMessageTemplateCellLayout.swift in Sources */, + EAD958A3EDEB446671C89C8E /* SBUMessageTemplateCellParams.swift in Sources */, + E20593ED3CDE0767A2BB81EB /* SBUMessageTemplateManager.swift in Sources */, + E20140053EFB0D38E7583F38 /* SBUMessageThreadInputView+SwiftUI.swift in Sources */, + 07F84CEA484DCBB1F948AAD8 /* SBUMessageThreadModule.Deprecated.swift in Sources */, + 77AA82E38B8808BC31CF1A33 /* SBUMessageThreadModule.Header+SwiftUI.swift in Sources */, + C7AE89F613479689E310F254 /* SBUMessageThreadModule.Header.swift in Sources */, + 12484B91A36082E1D7B3981A /* SBUMessageThreadModule.Input+SwiftUI.swift in Sources */, + 3D30144647F6B79A5397CFB4 /* SBUMessageThreadModule.Input.swift in Sources */, + A01A69C6219122DAF5402109 /* SBUMessageThreadModule.List+SwiftUI.swift in Sources */, + 71125C3760C161FC8222D8C4 /* SBUMessageThreadModule.List.swift in Sources */, + 22CFFC50B3702F4CC8BA9896 /* SBUMessageThreadModule.swift in Sources */, + 4469F5B26AF4AE47320EFD2F /* SBUMessageThreadTitleView+SwiftUI.swift in Sources */, + 3AAD3C2119E27C0E9622066A /* SBUMessageThreadTitleView.swift in Sources */, + 0AD790EBDAC85B76E056AF87 /* SBUMessageThreadViewController.SwiftUI.swift in Sources */, + ECAB32E977EF5EA1BBAFAA71 /* SBUMessageThreadViewController.swift in Sources */, + FEBF7D15E840B97A00EB1FB0 /* SBUMessageThreadViewModel.swift in Sources */, + 71FB67C036D0A5DDEC24A1F6 /* SBUMessageWebView.swift in Sources */, + C8A3717E5A8103BFB79EE99F /* SBUMessageWebViewModel.swift in Sources */, + E03341A314BE9FDCC51455EA /* SBUModerationCell.swift in Sources */, + 0D115603E813723F8194405A /* SBUModerationsModule.Deprecated.swift in Sources */, + 5FF3A92D6837E755F277A62D /* SBUModerationsModule.Header.swift in Sources */, + 6188D295CBFECFABC98C9C70 /* SBUModerationsModule.List.swift in Sources */, + 5B12F44A574D88AA56F9E1CF /* SBUModerationsModule.swift in Sources */, + 4821DC2603A9E1E93C7EDCF3 /* SBUModerationsViewController.Deprecated.swift in Sources */, + 93C4C51D9DF7C31CA4AFDD6F /* SBUModerationsViewController.swift in Sources */, + 9FCAD0A25F06AC7DE1FB8E08 /* SBUModerationsViewModel.Deprecated.swift in Sources */, + 50AA08F67C08BA3F453717F1 /* SBUModerationsViewModel.swift in Sources */, + E1B65F461DFA5E4D0515F4A1 /* SBUModuleSet.Deprecated.swift in Sources */, + 93B9E05C601FD4F43BD9B29E /* SBUModuleSet.swift in Sources */, + F0907749B923ACA12384ACDF /* SBUMultipleFilesMessageCell.swift in Sources */, + 1A4D92E04F069A9308EBDEBC /* SBUMultipleFilesMessageCellParams.swift in Sources */, + FD05FBC1738DADC60A104DF4 /* SBUMultipleFilesMessageCollectionView.swift in Sources */, + 684CB45E068CC0C34F58F06F /* SBUMultipleFilesMessageCollectionViewCell.swift in Sources */, + 9751FBDD99F592CB96B99D9C /* SBUNavigationTitleView.swift in Sources */, + A9B2A574729B61CCBA4A6908 /* SBUNewMessageInfo+SwiftUI.swift in Sources */, + 79DE6B64A5192F1E49A12E4B /* SBUNewMessageInfo.swift in Sources */, + 9D24AFA3A8ACB3620B2A858C /* SBUNewNotificationInfo.swift in Sources */, + 11659F092A8E2355A455E687 /* SBUNotificationCell.swift in Sources */, + 78BD0BE51D5CEFCB92A30AE1 /* SBUNotificationChannelManager.swift in Sources */, + 6782E83014B4D1666796CEB3 /* SBUNotificationEmptyView.swift in Sources */, + 45FBA23F645EC16087F4BD28 /* SBUNotificationNavigationTitleView.swift in Sources */, + ECBBEA5F25E528664C41EDEC /* SBUNotificationTimelineView.swift in Sources */, + 7C930D4C75E7342EEADE9AF6 /* SBUOpenBannedUserListModule.Header+SwiftUI.swift in Sources */, + 6A5C8EC38128BDB746EE2DC4 /* SBUOpenBannedUserListModule.List+SwiftUI.swift in Sources */, + 3416FD182734700D48191237 /* SBUOpenBannedUserListUserCell+SwiftUI.swift in Sources */, + 38116DEE4FA5BA7D124AF0C9 /* SBUOpenChannelAdminMessageCell.swift in Sources */, + B6776383DE9AAA81EA0BD868 /* SBUOpenChannelBaseMessageCell+SwiftUI.swift in Sources */, + DE198D029D3134AFD5B3EAE3 /* SBUOpenChannelBaseMessageCell.swift in Sources */, + 6D6AA6F4E34153A606CD4AAB /* SBUOpenChannelCell+SwiftUI.swift in Sources */, + 8BD60D420559CB35EAFE12B8 /* SBUOpenChannelCell.swift in Sources */, + 8C4B9C8E408560BE1835D299 /* SBUOpenChannelCommonContentView.swift in Sources */, + 5E508188D0EA7735586C71F9 /* SBUOpenChannelContentBaseMessageCell.swift in Sources */, + 0C27C90307067551A9A637D2 /* SBUOpenChannelFileMessageCell.swift in Sources */, + 14AF8B85B474D29FEA3E2E61 /* SBUOpenChannelImageContentView.swift in Sources */, + C513A8D06ED083B5C6F8526A /* SBUOpenChannelInputView+SwiftUI.swift in Sources */, + DB14CAEEDA9EDCCCEC048DC1 /* SBUOpenChannelListModule.Deprecated.swift in Sources */, + 0C57985D8FE67FC87D94687F /* SBUOpenChannelListModule.Header+SwiftUI.swift in Sources */, + 726FCE518B1E92A6064461D6 /* SBUOpenChannelListModule.Header.swift in Sources */, + 93E4D4F9EA6FA7DA8BBCEB48 /* SBUOpenChannelListModule.List+SwiftUI.swift in Sources */, + 95CAB95868E0CF0BF12E4BEC /* SBUOpenChannelListModule.List.swift in Sources */, + EE8E041FF3DF7D3016ACFCCB /* SBUOpenChannelListModule.swift in Sources */, + ABCE864F5372FCC8C609C77B /* SBUOpenChannelListViewController.swift in Sources */, + 7AC62B383D145110B5C9D25B /* SBUOpenChannelListViewModel.swift in Sources */, + 7BDD74C91C71E41176358809 /* SBUOpenChannelMessageWebView.swift in Sources */, + 4D7368028A8AE3B04C606302 /* SBUOpenChannelModule.Deprecated.swift in Sources */, + 78BA0849D102494B2D0B66C2 /* SBUOpenChannelModule.Header+SwiftUI.swift in Sources */, + BE40DE4B5FA2E30C80A00064 /* SBUOpenChannelModule.Header.swift in Sources */, + 483073E502ACDC6B0B97071D /* SBUOpenChannelModule.Input+SwiftUI.swift in Sources */, + A0472607F46D2B12C431E318 /* SBUOpenChannelModule.Input.swift in Sources */, + B134DD826C7E0B90F2585736 /* SBUOpenChannelModule.List+SwiftUI.swift in Sources */, + 4EAFF36AA2B114BDBFD37BCC /* SBUOpenChannelModule.List.swift in Sources */, + 09825CD9E70677F734FFE2CA /* SBUOpenChannelModule.Media.swift in Sources */, + 2137E2A26E2DF0841EC114C2 /* SBUOpenChannelModule.swift in Sources */, + 7BA58ABB58DC96653CFE0EAF /* SBUOpenChannelRegisterOperatorModule.Header+SwiftUI.swift in Sources */, + A388AC432F87F16EDA9D7A89 /* SBUOpenChannelRegisterOperatorModule.List+SwiftUI.swift in Sources */, + 4EF20EB7151A235007A8811F /* SBUOpenChannelSettingCell.swift in Sources */, + 0FF0CC8E45E4CB7DCD8923BC /* SBUOpenChannelSettingsModule.Deprecated.swift in Sources */, + 492DA4A12B29161F5F214F2E /* SBUOpenChannelSettingsModule.Header+SwiftUI.swift in Sources */, + 6D057AE3EF02D6F431F77D7D /* SBUOpenChannelSettingsModule.Header.swift in Sources */, + E2726D4CC2CAC501CFAE7E15 /* SBUOpenChannelSettingsModule.List+SwiftUI.swift in Sources */, + 6559B87C185467A5E089AF9C /* SBUOpenChannelSettingsModule.List.swift in Sources */, + E310C6E67AD22482CD33FEEA /* SBUOpenChannelSettingsModule.swift in Sources */, + 101B541C74D71CA5C4890A81 /* SBUOpenChannelSettingsViewController.swift in Sources */, + 151604A8951C75CA8B6470F6 /* SBUOpenChannelSettingsViewModel.swift in Sources */, + AF6961C39F74BAFE2562893A /* SBUOpenChannelTitleView+SwiftUI.swift in Sources */, + 67B7D760B2FCC36C0010911B /* SBUOpenChannelUnknownMessageCell.swift in Sources */, + 8102C5375DF8738D2B414429 /* SBUOpenChannelUserMessageCell.swift in Sources */, + 5629DC4559C08AAFA338A316 /* SBUOpenChannelViewController+SwiftUI.swift in Sources */, + DDFAB659A3347A66423269EA /* SBUOpenChannelViewController.Deprecated.swift in Sources */, + 246F35E088992AB75BBEDAE1 /* SBUOpenChannelViewController.Unavailable.swift in Sources */, + 27C36972AE1DF0F51E293527 /* SBUOpenChannelViewController.swift in Sources */, + B1DA5D4CF8DBEFE857E7A7C3 /* SBUOpenChannelViewModel.swift in Sources */, + AE59386CBB3F7D8B9C0D502F /* SBUOpenModerationsModule.Header+SwiftUI.swift in Sources */, + 2D9479B222339C927A220AD9 /* SBUOpenModerationsModule.List+SwiftUI.swift in Sources */, + A47B683FB720EE947E60AEB0 /* SBUOpenMutedParticipantListModule.Header+SwiftUI.swift in Sources */, + 2DE08BC7EAC8EEB8770030C8 /* SBUOpenMutedParticipantListModule.List+SwiftUI.swift in Sources */, + E622A4BD0B6A149DDED179E2 /* SBUOpenMutedParticipantListUserCell+SwiftUI.swift in Sources */, + DB401DA57593F4ADF0D3ED84 /* SBUOpenOperatorListModule.Header+SwiftUI.swift in Sources */, + 142C0C8E5E796A5227AF79FD /* SBUOpenOperatorListModule.List+SwiftUI.swift in Sources */, + 5D83A1050763CDE1B713425A /* SBUOpenOperatorListUserCell+SwiftUI.swift in Sources */, + F0EAFEE7FE642C5160D47F47 /* SBUOpenScrollBottomView+SwiftUI.swift in Sources */, + 94AF8B67250A5FD896285106 /* SBUOpenUserListModule.Header+SwiftUI.swift in Sources */, + 83B3AE01FB5693BEEFF17D1B /* SBUOpenUserListModule.List+SwiftUI.swift in Sources */, + C71CBE14ED22A9E5854DFE8D /* SBUOpenUserListUserCell+SwiftUI.swift in Sources */, + E6B641254065AC40061E7852 /* SBUPaddingLabel.swift in Sources */, + EDB0D9B0073CB1F92449087A /* SBUParentMessageInfoReactionView.swift in Sources */, + C502F906CDCA0EBE28686637 /* SBUParentMessageInfoView+SwiftUI.swift in Sources */, + 3EF2255B820FCBF48B60ACF4 /* SBUParentMessageInfoView.swift in Sources */, + F4A8EDFDBE92371430320D7F /* SBUPendingMessageManager.swift in Sources */, + 4BD60C8A8E90705C2B3C1830 /* SBUPermissionManager.swift in Sources */, + F1DFE101D21127610F28F400 /* SBUPhotoAccess.swift in Sources */, + E53E112114ED4F9AB72E7599 /* SBUPhotoCollectionViewCell.swift in Sources */, + 7DF5788443E1C3CE035241CE /* SBUPropertyWrapper.swift in Sources */, + CBEC8D8DCCF1A458603C7671 /* SBUQuoteMessageInputView.swift in Sources */, + A59B5B7C75731CCA2E7667B0 /* SBUQuoteMessageInputViewParams.swift in Sources */, + FA9FA573FEDB0E7119C5254D /* SBUQuoteMessageInputViewProtocol.swift in Sources */, + BC7B461A310DEE879E224D85 /* SBUQuotedBaseMessageView.swift in Sources */, + 72C5014A5F3EF9F3C54EE23C /* SBUQuotedBaseMessageViewParams.Deprecated.swift in Sources */, + D71DDB5B256AADEC51B8CA51 /* SBUQuotedBaseMessageViewParams.swift in Sources */, + 21A7991F06297EBACD3D1B0C /* SBUQuotedFileMessageView.swift in Sources */, + 9748FC4A7522DB0195A108A2 /* SBUQuotedMessageViewProtocol.swift in Sources */, + 6839E4960F91236C191BACB5 /* SBUQuotedUserMessageView.swift in Sources */, + E4957040F6F16C052D03A09A /* SBUReactionCollectionViewCell.swift in Sources */, + A506D73584E27E0A8FF1E953 /* SBUReactionsViewController.swift in Sources */, + 1BE0CD8344B6CF2AD61E502C /* SBURegisterOperatorModule.Deprecated.swift in Sources */, + 7EF26B31198C8B771AC6A8ED /* SBURegisterOperatorModule.Header.swift in Sources */, + 101A2310CFCEA9A19AF991F8 /* SBURegisterOperatorModule.List.swift in Sources */, + D589D27B764BEBC102F05794 /* SBURegisterOperatorModule.swift in Sources */, + 17903F522658CE0BB9EC6A72 /* SBURegisterOperatorViewController.swift in Sources */, + 2F30ACF2D7846817D4F6B8C3 /* SBURegisterOperatorViewModel.swift in Sources */, + 270D763396586533C461C05F /* SBUReplyConfiguration.swift in Sources */, + 01A64DE1989F69381E0E3B02 /* SBUScrollBottomView+SwiftUI.swift in Sources */, + 1C4F3D64825F74BC8E9C43BC /* SBUScrollBottomView.swift in Sources */, + 0BD22A6449BD8262CE3756EC /* SBUScrollOptions.swift in Sources */, + 1F4086119B5C13A0F6D5E418 /* SBUScrollPostionConfiguration.swift in Sources */, + 81477334E91657BE68CCB150 /* SBUSearchBar.swift in Sources */, + F877982811AC508943632CCE /* SBUSelectablePhotoViewController.swift in Sources */, + 3773BD698DE731408C45CF84 /* SBUSelectableStackView.swift in Sources */, + 5B0B8EC873E13E8913D7985F /* SBUSimpleSuggestedReplyOptionView.swift in Sources */, + B444015B4802605B95FC0DA9 /* SBUStackView.swift in Sources */, + A57649F9E4A8974F1A374329 /* SBUStringSet.Deprecated.swift in Sources */, + 9E8FC63E9DA69207A233C5CF /* SBUStringSet.swift in Sources */, + A89FFCEE168C76530C9E6502 /* SBUSuggestedMentionList.swift in Sources */, + 1DA87FEB8D2DA780F94968BC /* SBUSuggestedReplyOptionView.swift in Sources */, + A8AF3B5E826BEFF5A71245A8 /* SBUSuggestedReplyView.swift in Sources */, + FD16D0D63728B50FE6B1620D /* SBUSuggestedReplyViewParams.swift in Sources */, + 65EAF94B4113A56875B4A326 /* SBUTableViewCell.Unavailable.swift in Sources */, + 2D7593F1A9223B56895C03E3 /* SBUTableViewCell.swift in Sources */, + D8DB4EC1517D600A7BAB3E6B /* SBUTemplateLabel.swift in Sources */, + 1277097C86BAE76CC54A6EE5 /* SBUTemplateType.swift in Sources */, + 8742DC47B4E3EE28F65FDE70 /* SBUTextView.swift in Sources */, + 71EF4733AFDB66CC2E0590F3 /* SBUTheme+Type.swift in Sources */, + C40D2C394689B54254702D99 /* SBUTheme.Deprecated.swift in Sources */, + 92D37CEF2CC26FE26165A1B2 /* SBUTheme.swift in Sources */, + 19048A9532E6C9ADC902F0A8 /* SBUThreadInfoView.swift in Sources */, + 2F5D5F7A299CB763FD570E71 /* SBUToastType.swift in Sources */, + 771BEBCA97EBA8B31AAF95C2 /* SBUToastView.Internal.swift in Sources */, + 15666B586ABBE148301CF2CE /* SBUToastView.Item.swift in Sources */, + D1E55CD604D66C28A09F5F21 /* SBUToastView.swift in Sources */, + 70C4A4792E2BFE63A18A9954 /* SBUTypingIndicatorBubbleView.swift in Sources */, + 85EE91F0746CAACE767F5E0D /* SBUTypingIndicatorInfo.swift in Sources */, + 5B3CFCA797E9C2516F5C75C1 /* SBUTypingIndicatorMessage.swift in Sources */, + 11545F37072B247002058199 /* SBUTypingIndicatorMessageCell.swift in Sources */, + 9A2D8C01B76AB936691B443F /* SBUTypingIndicatorMessageManager.swift in Sources */, + 588FE97552B595B6ECD21889 /* SBUTypingMessageCellParams.swift in Sources */, + E1AE7A7067D6B8B6970F08DA /* SBUUnderLineTextField.swift in Sources */, + 544EEA8C932F1096A5F2C3B4 /* SBUUnknownMessageCell.swift in Sources */, + AEF0C3B8FA3F9DFB7A4D7D98 /* SBUUnknownMessageCellParams.swift in Sources */, + 9CEE3F03D7428180C46396FF /* SBUUser.swift in Sources */, + 749F372DA7755F9B0CD00F9F /* SBUUserCell.swift in Sources */, + A813DE7327B146C9A9A5676C /* SBUUserListModule.Deprecated.swift in Sources */, + 8EE4F68584BB80FA0BBE0126 /* SBUUserListModule.Header.swift in Sources */, + BB7683674F03AE5F9A3784B5 /* SBUUserListModule.List.swift in Sources */, + 077EE5F13FBD2FFB7DE74086 /* SBUUserListModule.swift in Sources */, + 4228E8E7699D05B036C5319F /* SBUUserListViewController.swift in Sources */, + EE140AFBFF2F5E99F19ED036 /* SBUUserListViewModel.swift in Sources */, + AF87064353739448B4371C09 /* SBUUserMentionConfiguration.swift in Sources */, + EF83143AFC931162448332F8 /* SBUUserMessageCell.swift in Sources */, + DC1FD939B69B7412F5D4B7A8 /* SBUUserMessageCellParams.swift in Sources */, + 338BE5281B09CD9862D8B40F /* SBUUserMessageTextView.swift in Sources */, + E6AFA3E291CBDBB8F0A2A561 /* SBUUserMessageTextViewModel.swift in Sources */, + DBD660C7A6B7B0CF3BB88609 /* SBUUserNameView.swift in Sources */, + 03E2C98D4F2EE59B3B9C92C7 /* SBUUserProfileView.swift in Sources */, + E633602EE668031243BF1195 /* SBUUtils.swift in Sources */, + E6B3E04DF4709FF6C31AAA7B /* SBUVerticalSuggestedReplyView.swift in Sources */, + 12A9851DC436E5947835D61B /* SBUView.Unavaliable.swift in Sources */, + 502CB752FABA82E71D64B640 /* SBUView.swift in Sources */, + 24161F49E2F822912347966A /* SBUViewControllerSet.swift in Sources */, + 8E5A8B1632342C3624224529 /* SBUViewLifeCycle.swift in Sources */, + 925FD15C21DE8E0DDB025125 /* SBUViewModelDelegate.swift in Sources */, + B2DE7C0B76B706DF4898A6F7 /* SBUViewModelSet.swift in Sources */, + C82C113F59D0BB346ADE62B6 /* SBUVoiceContentView.swift in Sources */, + 3CE19B8299750EF64E7041EC /* SBUVoiceFileInfo.swift in Sources */, + DE582665CC81FE860DB5BDD6 /* SBUVoiceMessageConfiguration.swift in Sources */, + AF0D44D6DEB7F76342B76230 /* SBUVoiceMessageInputView.swift in Sources */, + 2AF34F3C2EB1558503DD6C94 /* SBUVoicePlayer.swift in Sources */, + 7D162B369BE3198C867A5662 /* SBUVoiceRecorder.swift in Sources */, + CD2A900FCA92FC6EDBA0924A /* SBViewConverterSet.swift in Sources */, + 65C9B673F78F3B0749FA4EAE /* Sendbird+Typealias.swift in Sources */, + E0AA86C26729A692797C8666 /* Sendbird.swift in Sources */, + E17F0E9586DB80A76D8386A2 /* SendbirdChat+SBUIKit.swift in Sources */, + 04900E9B717C7CED5A30AC94 /* SendbirdUI+SwiftUI.swift in Sources */, + 76020C9F983CDCF54A5015B9 /* SendbirdUI.Deprecated.swift in Sources */, + 1C5E24DDCDEA510D196A9A5F /* SendbirdUI.swift in Sources */, + BE9EB03BCE0271ABE232AE7B /* SendbirdUIProvider.swift in Sources */, + 6D9FB62D7282668250312C63 /* Sequence+SBUIKit.swift in Sources */, + F2280B6FF8D8F42DF09DF068 /* StateImpactManager.swift in Sources */, + 43312196721B790BA15E6022 /* String+SBUIKit.swift in Sources */, + F6CE4CCE9D5D5BCB95086FEB /* StringProtocol+SBUIKit.swift in Sources */, + E72FE839E56753325B2354B0 /* SwiftUIMessageInputInterface.swift in Sources */, + F35FE1245327F4554EBE7BAD /* SwiftUIViewController.swift in Sources */, + 767D097425B4B3AAC824CD77 /* Thread+SBUIKit.swift in Sources */, + 4EBCCC1431AE117C813D1BED /* UIApplication+SBUIKit.swift in Sources */, + 49326461344F3ACBA5189DA8 /* UIButton+SBUIKit.swift in Sources */, + 071994DBFEE33E4945CF375E /* UICollectionView+SBUIKit.swift in Sources */, + 9AAD286A1633798C510D70C4 /* UIColor+SBUIKit.swift in Sources */, + CF200F52BBCED2E61A620142 /* UIFont+Sendbird.swift in Sources */, + C8D1518D38A52164CEE1CEDF /* UIImage+SBUIKit.swift in Sources */, + B7A67CF17A2BC21DD001D094 /* UIImageView+SBUIKit.swift in Sources */, + 301D93C99855A2A6858965C8 /* UINavigationController+SBUIKit.swift in Sources */, + F82E518CE6E0946B168BAA18 /* UIScrollView+SBUIKit.swift in Sources */, + 77F45EB93F523CDDECF16107 /* UIStackView.SBUIKit.swift in Sources */, + 24028A8B4C6A5D907E061EC8 /* UITableView+SBUIKit.swift in Sources */, + 86ACE990277910A684185982 /* UITextField+SBUIKit.swift in Sources */, + 1D04320552FDEE949ABE2CC6 /* UIView+SBUIKit.swift in Sources */, + 5C4CE59950719F465A158543 /* UIViewController+SBUIKit.swift in Sources */, + C5FBDF91DA19A26BC978B002 /* URL+SBUIKit.swift in Sources */, D15448A2AFC32086A87FD72D /* UserDefaults+Ext.swift in Sources */, - ADA3CB1273F6228F305040A1 /* View + ViewModifier.swift in Sources */, - 4ED158577D05DD6E73651698 /* ViewControllerTypeProtocol + swiftUI.swift in Sources */, - 817653C94409F8B5986A4475 /* ViewConverter.swift in Sources */, - E275EA3302EB2EA9443D0A29 /* ViewItemInitialize.swift in Sources */, - 2EEA84E8D1E33A744A816989 /* ViewItemProtocol.swift in Sources */, + 29F300152C1075AB758D7DF6 /* View + ViewModifier.swift in Sources */, + 28F0FCB98DAAB95E4B0372F1 /* ViewControllerTypeProtocol + swiftUI.swift in Sources */, + 061D761670DD3846F2EB4B20 /* ViewConverter.swift in Sources */, + 296174744FF16CE681B9B598 /* ViewItemInitialize.swift in Sources */, + 5F926A23178986BB02118BC9 /* ViewItemProtocol.swift in Sources */, BF66786E33466193FFDD4F48 /* ViewModifiers.swift in Sources */, - A6BABA616C94F2318FCBB6F0 /* VoiceMessageStatus.swift in Sources */, - 1D83365CA99CC195113CC2DA /* WrapperUIViews.swift in Sources */, + 237CE7996FB3C050EC4A7275 /* VoiceMessageStatus.swift in Sources */, + 8F3D67420D52E5E004D0F0E9 /* WeakDelegateStorage.swift in Sources */, + E6365D7C7EE4F62FC962FCD3 /* WrapperUIViews.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -8344,7 +7698,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = "1.0.0-beta.3"; + MARKETING_VERSION = 1.0.0; PRODUCT_BUNDLE_IDENTIFIER = com.sendbird.swiftui.sample; PRODUCT_NAME = "$(TARGET_NAME)"; SDKROOT = iphoneos; @@ -8377,7 +7731,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = "1.0.0-beta.3"; + MARKETING_VERSION = 1.0.0; PRODUCT_BUNDLE_IDENTIFIER = com.sendbird.swiftui.sample.SwiftUINotificationService; PRODUCT_NAME = "$(TARGET_NAME)"; SDKROOT = iphoneos; @@ -8468,7 +7822,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = "1.0.0-beta.3"; + MARKETING_VERSION = 1.0.0; PRODUCT_BUNDLE_IDENTIFIER = com.sendbird.swiftui.sample; PRODUCT_NAME = "$(TARGET_NAME)"; SDKROOT = iphoneos; @@ -8556,7 +7910,7 @@ "@executable_path/Frameworks", "@loader_path/Frameworks", ); - MARKETING_VERSION = "1.0.0-beta.3"; + MARKETING_VERSION = 1.0.0; PRODUCT_BUNDLE_IDENTIFIER = com.sendbird.swiftui.sample.SwiftUINotificationService; PRODUCT_NAME = "$(TARGET_NAME)"; SDKROOT = iphoneos; @@ -8605,7 +7959,7 @@ repositoryURL = "https://github.com/sendbird/sendbird-chat-sdk-ios"; requirement = { kind = upToNextMajorVersion; - minimumVersion = 4.21.1; + minimumVersion = 4.23.1; }; }; /* End XCRemoteSwiftPackageReference section */ diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomSampleSubViewModel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomSampleSubViewModel.swift index 05b57bd..87231e7 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomSampleSubViewModel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomSampleSubViewModel.swift @@ -8,6 +8,9 @@ import SwiftUI import SendbirdChatSDK +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif class CustomSampleSubViewModel: ObservableObject { @Published var groupChannel: GroupChannel? diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/CustomCreateGroupChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/CustomCreateGroupChannel.swift index c2c8d9c..91a73df 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/CustomCreateGroupChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/CustomCreateGroupChannel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomCreateGroupChannel: View { var body: some View { CreateGroupChannelView() diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift index ec110ac..ebbae01 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.SwiftUI.View { struct CustomMain: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.Main.swift index bf46f75..4919cd6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/SwiftUI/View/CustomCreateGroupChannel.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.SwiftUI.View { struct Main: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.leftView.swift index 1aa0d0f..fce3dab 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.Header { struct leftView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.rightView.swift index c394722..da34673 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.Header { struct rightView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.titleView.swift index da463e4..16281d1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/Header/CustomCreateGroupChannel.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.Header { struct titleView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.entireView.swift index c89c65e..83e6924 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.List { struct entireView: View { @@ -16,24 +19,7 @@ extension CustomCreateGroupChannel.ViewConverter.List { } var body: some View { - CreateGroupChannelView( - list: { config in - List(config.users, id: \.self) { user in - Button { - config.parentView.onSelectUser(user) - } label: { - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(config.selectedUsers.contains(user) ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } - } - ) + CreateGroupChannelView() CustomButton() } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.profileImage.swift index 784a1dd..134f760 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.List { struct profileImage: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.rowView.swift index dcf70d8..c94678c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.List { struct rowView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift index 7a7dd9c..2725d0e 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.selectionButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.List { struct selectionButton: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift index eb5013d..a9a6520 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateGroupChannel/ViewConverter/List/CustomCreateGroupChannel.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateGroupChannel.ViewConverter.List { struct userNameLabel: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/CustomCreateOpenChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/CustomCreateOpenChannel.swift index c197ab6..3aeeee8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/CustomCreateOpenChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/CustomCreateOpenChannel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomCreateOpenChannel: View { var body: some View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift index 94fbdb8..474c770 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.SwiftUI.View { struct CustomMain: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.Main.swift index c2f5cfb..f644446 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/SwiftUI/View/CustomCreateOpenChannel.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.SwiftUI.View { struct Main: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.leftView.swift index b4774d1..ad5b9b2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.Header { struct leftView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.rightView.swift index 083a2f0..4b06d15 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.Header { struct rightView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.titleView.swift index 24ef51d..ba6b362 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/Header/CustomCreateOpenChannel.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.Header { struct titleView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.entireView.swift index 8fefb29..cf8d65c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.List { struct entireView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.profileImage.swift index 885f8c9..432ee79 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.List { struct profileImage: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.rowView.swift index 86c94c4..08bd117 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.List { struct rowView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift index 74f5b17..f7280f6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.selectionButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.List { struct selectionButton: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift index f17a668..fd0a277 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/CreateOpenChannel/ViewConverter/List/CustomCreateOpenChannel.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomCreateOpenChannel.ViewConverter.List { struct userNameLabel: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/CustomGroupBannedUserList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/CustomGroupBannedUserList.swift index 09e3277..b7bb7ca 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/CustomGroupBannedUserList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/CustomGroupBannedUserList.swift @@ -1,11 +1,19 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupBannedUserList: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupBannedUserListView(channelURL: channelURL) + + GroupBannedUserListView( + provider: GroupBannedUserListViewProvider( + channelURL: channelURL + ) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift index ea715c1..e5e822c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.SwiftUI.View { struct CustomMain: View { @@ -20,7 +23,7 @@ extension CustomGroupBannedUserList.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL { // Currently only header is tested GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.Main.swift index 2ba594a..f160d32 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/SwiftUI/View/CustomGroupBannedUserList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomGroupBannedUserList.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupBannedUserListView(channelURL: channelURL) + GroupBannedUserListView( + provider: GroupBannedUserListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.leftView.swift index 3eead32..48c42c4 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.rightView.swift index c1cde76..b298fca 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.titleView.swift index 25ce26c..0a4de3f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/Header/CustomGroupBannedUserList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.entireView.swift index 7efe7ed..dac0d6d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.List { struct entireView: View { @@ -19,19 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: GroupBannedUserListViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.moreButton.swift index 87aada6..bf07856 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.List { struct moreButton: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.profileImage.swift index 828127b..af62035 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.rowView.swift index bcfbc3b..27ad885 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift index 0cdb497..26290c0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupBannedUserList/ViewConverter/List/CustomGroupBannedUserList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupBannedUserList.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomGroupBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupBannedUserListView( - channelURL: channelURL, + provider: GroupBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/CustomGroupChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/CustomGroupChannel.swift index 5be3e1e..9ef3fdb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/CustomGroupChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/CustomGroupChannel.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupChannel: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelView(channelURL: channelURL) + GroupChannelView( + provider: GroupChannelViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.channelSettings.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.channelSettings.swift index c9ca372..5668b2f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.channelSettings.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.channelSettings.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.SubView.Builder { struct channelSettings: View { @@ -6,9 +9,11 @@ extension CustomGroupChannel.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelView(channelURL: channelURL) + GroupChannelView(provider: GroupChannelViewProvider(channelURL: channelURL)) .channelSettingsView { channelURL in - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView( + provider: GroupChannelSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.messageThread.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.messageThread.swift index 8f406fe..51adc01 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.messageThread.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SubView/Builder/CustomGroupChannel.SubView.Builder.messageThread.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.SubView.Builder { struct messageThread: View { @@ -6,9 +9,14 @@ extension CustomGroupChannel.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelView(channelURL: channelURL) + GroupChannelView(provider: GroupChannelViewProvider(channelURL: channelURL)) .messageThreadView { channelURL, parentMessageId in - MessageThreadView(channelURL: channelURL, parentMessageId: parentMessageId) + MessageThreadView( + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.CustomMain.swift index b886c9a..fdb9c85 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.SwiftUI.View { struct CustomMain: View { @@ -7,7 +10,7 @@ extension CustomGroupChannel.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.Main.swift index 1420885..da609dc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/SwiftUI/View/CustomGroupChannel.SwiftUI.View.Main.swift @@ -1,17 +1,25 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.SwiftUI.View { struct Main: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel - + @StateObject var provider = GroupChannelViewProvider(channelURL: "") + var body: some View { - if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelView(channelURL: channelURL) - } + GroupChannelView(provider: provider) + .onAppear { + if let channelURL = viewModel.groupChannel?.channelURL { + provider.setup(channelURL: channelURL) + } + } } } } + #Preview { CustomGroupChannel.SwiftUI.View.Main() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.coverImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.coverImage.swift index 1568b27..c3836b5 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.coverImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.coverImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Header { struct coverImage: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .coverImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.leftView.swift index d2114b8..8ce69e0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.rightView.swift index ec785c0..0a6d754 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleLabel.swift index 9d4e7f6..07dbc89 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Header { struct titleLabel: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .titleLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleView.swift index cca3320..794b415 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.typingStatusView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.typingStatusView.swift index ad91092..774561d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.typingStatusView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Header/CustomGroupChannel.ViewConverter.Header.typingStatusView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Header { struct typingStatusView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), headerItem: { .init() .typingStatusView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.addButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.addButton.swift index c8fc1fb..4eec9f3 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.addButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.addButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Input { struct addButton: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), inputItem: { .init() .addButton { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.entireView.swift index e6fcbf9..15cd5f0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Input { struct entireView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.leftView.swift index a5cf792..fceb75d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Input { struct leftView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomGroupChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), inputItem: { .init() .leftView { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.rightView.swift index 4fbbf66..19cda04 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Input { struct rightView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomGroupChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), inputItem: { .init() .rightView(content: { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.sendButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.sendButton.swift index 47a6ed9..f8c0604 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.sendButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.sendButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Input { struct sendButton: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomGroupChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), inputItem: { .init() .sendButton { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.voiceButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.voiceButton.swift index dadfced..d9e8030 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.voiceButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/Input/CustomGroupChannel.ViewConverter.Input.voiceButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.Input { struct voiceButton: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomGroupChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), inputItem: { .init() .voiceButton(content: { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.adminMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.adminMessageView.swift index 085a1d9..1d92c84 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.adminMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.adminMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct adminMessageView: View { @@ -20,7 +23,7 @@ extension CustomGroupChannel.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL { VStack { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .adminMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.channelStateBanner.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.channelStateBanner.swift index 3c541b8..7c2b86c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.channelStateBanner.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.channelStateBanner.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct channelStateBanner: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .channelStateBanner { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.entireView.swift index 5740083..cc5a80c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct entireView: View { @@ -19,17 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, - list: { config in - List(config.messages) { message in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(customFlag ? .green : .red) - Text(message.message) - } - } - } + provider: GroupChannelViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.fileMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.fileMessageView.swift index 2279120..0abc3e3 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.fileMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.fileMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct fileMessageView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .fileMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift index e806019..883d998 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.multipleFilesMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct multipleFilesMessageView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .multipleFilesMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift index 19d953c..5c9e73d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.newMessageInfoView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct newMessageInfoView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .newMessageInfoView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.rowView.swift index 67aa82b..38b8222 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif import SendbirdChatSDK extension CustomGroupChannel.ViewConverter.List { @@ -20,7 +23,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.scrollBottomView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.scrollBottomView.swift index e301de1..374bb0f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.scrollBottomView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.scrollBottomView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct scrollBottomView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .scrollBottomView { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.senderProfileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.senderProfileImage.swift index 367362c..a3ce5cc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.senderProfileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.senderProfileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct senderProfileImage: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .senderProfileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift index cd80f33..ed02172 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.typingIndicatorView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct typingIndicatorView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .typingIndicatorView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.userMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.userMessageView.swift index e88bf37..c71a086 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.userMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewConverter/List/CustomGroupChannel.ViewConverter.List.userMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannel.ViewConverter.List { struct userMessageView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelView( - channelURL: channelURL, + provider: GroupChannelViewProvider(channelURL: channelURL), listItem: { .init() .userMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewProvider/CustomGroupChannel.SwiftUI.View.ViewProvider.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewProvider/CustomGroupChannel.SwiftUI.View.ViewProvider.swift new file mode 100644 index 0000000..3365580 --- /dev/null +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannel/ViewProvider/CustomGroupChannel.SwiftUI.View.ViewProvider.swift @@ -0,0 +1,83 @@ +// +// CustomGroupChannel.SwiftUI.View.ViewProvider.swift +// +// Created by Celine Moon on 11/14/24. +// + +import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif +import SendbirdChatSDK + +extension CustomGroupChannel.SwiftUI.View { + struct ViewProvider: View { + @EnvironmentObject var viewModel: CustomSampleSubViewModel + @StateObject var provider = GroupChannelViewProvider(channelURL: "") + @State private var showingMessageTextAlert = false + + var body: some View { + VStack { + GroupChannelView(provider: provider) + .onAppear { + if let channelURL = viewModel.groupChannel?.channelURL { + provider.setup(channelURL: channelURL) + } + } + + VStack { + // Demo of @Published properties + Text("Number of loaded messages: \(provider.fullMessages.count)") + .padding() + .background(Color.blue.opacity(0.5)) + .foregroundColor(.black) + .cornerRadius(10) + .font(.system(size: 13)) + + + // Demo of provider methods. + Button { + if let messageText = provider.messageInputText { + let trimmedText = messageText.trimmingCharacters(in: .whitespacesAndNewlines) + guard trimmedText.isEmpty == false else { + showingMessageTextAlert = true + return + } + let messageParam = UserMessageCreateParams(message: trimmedText) + provider.sendUserMessage(messageParams: messageParam) + provider.endTypingMode() + provider.messageInputText = nil + } else { + showingMessageTextAlert = true + } + } label: { + Text("Send User Message") + .padding() + .background(Color.yellow.opacity(0.5)) + .foregroundColor(.black) + .cornerRadius(10) + .font(.system(size: 13)) + } + .alert(isPresented: $showingMessageTextAlert) { + Alert( + title: Text("Empty message"), + message: Text("Type in message text to send a User Message"), + dismissButton: .default(Text("Dismiss")) + ) + } + + Button { + provider.showPhotosLibrary() + } label: { + Text("Show Photos and Send File Message") + .padding() + .background(Color.yellow.opacity(0.5)) + .foregroundColor(.black) + .cornerRadius(10) + .font(.system(size: 13)) + } + } + } + } + } +} diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/CustomGroupChannelList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/CustomGroupChannelList.swift index b608c6a..af2c8b0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/CustomGroupChannelList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/CustomGroupChannelList.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupChannelList: View { var body: some View { GroupChannelListView() diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.createChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.createChannel.swift index 8c744b3..d3764af 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.createChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.createChannel.swift @@ -1,11 +1,18 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.SubView.Builder { struct createChannel: View { var body: some View { GroupChannelListView() .createChannelView { users, type in - CreateGroupChannelView(users: users, type: type) + CreateGroupChannelView( + provider: CreateGroupChannelViewProvider( + customUsers: users + ) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.groupChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.groupChannel.swift index cdb8193..e133050 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.groupChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SubView/Builder/CustomGroupChannelList.SubView.Builder.groupChannel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.SubView.Builder { struct groupChannel: View { @@ -6,9 +9,11 @@ extension CustomGroupChannelList.SubView.Builder { GroupChannelListView() .groupChannelView { channelURL, startingPoint, messageListParams in GroupChannelView( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams + provider: GroupChannelViewProvider( + channelURL: channelURL, + startingPoint: startingPoint, + messageListParams: messageListParams + ) ) } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.CustomMain.swift index 883fe33..9288316 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.SwiftUI.View { struct CustomMain: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.Main.swift index cd6303b..689c451 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/SwiftUI/View/CustomGroupChannelList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.SwiftUI.View { struct Main: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.leftView.swift index 0d3a0e0..5709307 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.Header { struct leftView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.rightView.swift index b4c5f39..7b579cc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.Header { struct rightView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.titleView.swift index 03900e4..eaa137b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/Header/CustomGroupChannelList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.Header { struct titleView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelName.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelName.swift index 361949b..4130a3d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelName.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelName.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.List { struct channelName: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelPreview.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelPreview.swift index a321b03..ed6ff38 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelPreview.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.channelPreview.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.List { struct channelPreview: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.coverImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.coverImage.swift index f676149..f1c8064 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.coverImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.coverImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.List { struct coverImage: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.entireView.swift index 54354e6..02ba0d0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.List { struct entireView: View { @@ -16,19 +19,7 @@ extension CustomGroupChannelList.ViewConverter.List { } var body: some View { - GroupChannelListView( - list: { config in - ScrollView { - ForEach(config.channels) { channel in - VStack { - Text("Channel entire view: \(customFlag ? "ON" : "OFF")") - Text("\(channel.name)") - } - } - } - } - ) - + GroupChannelListView() CustomButton() } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.rowView.swift index 3cd013e..4497085 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.List { struct rowView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.unreadCount.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.unreadCount.swift index ab092b6..f33ad84 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.unreadCount.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewConverter/List/CustomGroupChannelList.ViewConverter.List.unreadCount.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelList.ViewConverter.List { struct unreadCount: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewProvider/CustomGroupChannelList.SwiftUI.View.ViewProvider.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewProvider/CustomGroupChannelList.SwiftUI.View.ViewProvider.swift new file mode 100644 index 0000000..d7a5942 --- /dev/null +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelList/ViewProvider/CustomGroupChannelList.SwiftUI.View.ViewProvider.swift @@ -0,0 +1,58 @@ +// +// CustomGroupChannelList.SwiftUI.View.ViewProvider.swift +// +// Created by Celine Moon on 11/14/24. +// + +import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif + +extension CustomGroupChannelList.SwiftUI.View { + struct ViewProvider: View { + @EnvironmentObject var viewModel: CustomSampleSubViewModel + @StateObject var provider = GroupChannelListViewProvider() + + var body: some View { + VStack { + GroupChannelListView(provider: provider) + // Demo of event methods. + .onSendbirdSelectRow { indexPath in + print("Tapped on \(indexPath.row)!") + // do actions here. + } + + VStack { + // Demo of @Published properties. + Text("Last message of latest channel: \(provider.channels.first?.lastMessage?.message ?? "nil")") + .padding() + .background(Color.pink.opacity(0.7)) + .foregroundColor(.white) + .cornerRadius(10) + .font(.system(size: 13)) + Text("Channel list is \(provider.isLoading ? "Loading..." : "Loaded!")") + .padding() + .background(Color.pink.opacity(0.7)) + .foregroundColor(.white) + .cornerRadius(10) + .font(.system(size: 13)) + + // Demo of function call. + Button { + provider.showCreateChannel() + } label: { + Text("Create Channel Button") + .padding() + .background(Color.blue.opacity(0.7)) + .foregroundColor(.white) + .cornerRadius(10) + .font(.system(size: 13)) + } + } + .onAppear() + } + } + + } +} diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/CustomGroupChannelPushSettings.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/CustomGroupChannelPushSettings.swift index 7aafcd5..8986f1d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/CustomGroupChannelPushSettings.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/CustomGroupChannelPushSettings.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupChannelPushSettings: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelPushSettingsView(channelURL: channelURL) + GroupChannelPushSettingsView( + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift index 11bd5b7..d6b80ab 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelPushSettings.SwiftUI.View { struct CustomMain: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -19,7 +22,7 @@ extension CustomGroupChannelPushSettings.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL { // Currently only header is tested GroupChannelPushSettingsView( - channelURL: channelURL, + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.Main.swift index 82ee392..756029b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/SwiftUI/View/CustomGroupChannelPushSettings.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelPushSettings.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomGroupChannelPushSettings.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelPushSettingsView(channelURL: channelURL) + GroupChannelPushSettingsView( + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift index 39d317c..706f2a0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelPushSettings.ViewConverter.Header { struct leftView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomGroupChannelPushSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelPushSettingsView( - channelURL: channelURL, + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift index 56cc8b7..98797ec 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelPushSettings.ViewConverter.Header { struct rightView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomGroupChannelPushSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelPushSettingsView( - channelURL: channelURL, + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift index cf42959..4d4962b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/Header/CustomGroupChannelPushSettings.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelPushSettings.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelPushSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelPushSettingsView( - channelURL: channelURL, + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/List/CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/List/CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift index ccde6a3..77f2a50 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/List/CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelPushSettings/ViewConverter/List/CustomGroupChannelPushSettings.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelPushSettings.ViewConverter.List { struct entireView: View { @@ -6,7 +9,9 @@ extension CustomGroupChannelPushSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelPushSettingsView(channelURL: channelURL) + GroupChannelPushSettingsView( + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/CustomGroupChannelRegisterOperator.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/CustomGroupChannelRegisterOperator.swift index 90a8fad..62f4449 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/CustomGroupChannelRegisterOperator.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/CustomGroupChannelRegisterOperator.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupChannelRegisterOperator: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelRegisterOperatorView(channelURL: channelURL) + GroupChannelRegisterOperatorView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift index 7168a9b..cdc2fe6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif import SendbirdChatSDK extension CustomGroupChannelRegisterOperator.SwiftUI.View { @@ -21,7 +24,7 @@ extension CustomGroupChannelRegisterOperator.SwiftUI.View { // Currently only header is tested if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelRegisterOperatorView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift index d402f20..c856a5f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/SwiftUI/View/CustomGroupChannelRegisterOperator.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelRegisterOperator.SwiftUI.View { struct Main: View { @@ -7,7 +10,7 @@ extension CustomGroupChannelRegisterOperator.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelRegisterOperatorView( - channelURL: channelURL + provider: .init(channelURL: channelURL) ) } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift index 90542b7..e6a8e27 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelRegisterOperator.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelRegisterOperator.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelRegisterOperatorView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift index 2cb71d1..14f1883 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelRegisterOperator.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelRegisterOperator.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelRegisterOperatorView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift index a84c38f..986788b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/Header/CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelRegisterOperator.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelRegisterOperator.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelRegisterOperatorView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/List/CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/List/CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift index e6b33b1..3f0aef6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/List/CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelRegisterOperator/ViewConverter/List/CustomGroupChannelRegisterOperator.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelRegisterOperator.ViewConverter.List { struct entireView: View { @@ -6,7 +9,7 @@ extension CustomGroupChannelRegisterOperator.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelRegisterOperatorView(channelURL: channelURL) + GroupChannelRegisterOperatorView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/CustomGroupChannelSettings.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/CustomGroupChannelSettings.swift index c7f47d4..16c0488 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/CustomGroupChannelSettings.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/CustomGroupChannelSettings.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupChannelSettings: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView(provider: GroupChannelSettingsViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.moderations.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.moderations.swift index 0b6dc2b..3d9c75a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.moderations.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.moderations.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.SubView.Builder { struct moderations: View { @@ -6,9 +9,11 @@ extension CustomGroupChannelSettings.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView( + provider: GroupChannelSettingsViewProvider(channelURL: channelURL) + ) .moderationsView { channelURL in - GroupModerationsView(channelURL: channelURL) + GroupModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.pushSettings.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.pushSettings.swift index fb1d96a..b6b4c05 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.pushSettings.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.pushSettings.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.SubView.Builder { struct pushSettings: View { @@ -6,9 +9,13 @@ extension CustomGroupChannelSettings.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView( + provider: GroupChannelSettingsViewProvider(channelURL: channelURL) + ) .pushSettingsView { channelURL in - GroupChannelPushSettingsView(channelURL: channelURL) + GroupChannelPushSettingsView( + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.userList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.userList.swift index 24eaf51..966b84c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.userList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SubView/Builder/CustomGroupChannelSettings.SubView.Builder.userList.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.SubView.Builder { struct userList: View { @@ -6,9 +9,11 @@ extension CustomGroupChannelSettings.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView( + provider: GroupChannelSettingsViewProvider(channelURL: channelURL) + ) .memberListView { channelURL in - GroupMemberListView(channelURL: channelURL) + GroupMemberListView(provider: GroupMemberListViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift index 43bcb55..12d6f37 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.SwiftUI.View { struct CustomMain: View { @@ -19,7 +22,8 @@ extension CustomGroupChannelSettings.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL) { + provider: GroupChannelSettingsViewProvider(channelURL: channelURL) + ) { .init() .leftView { viewConfig in Image(systemName: "arrowshape.backward.circle") diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.Main.swift index 678a6bf..f2cad8d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/SwiftUI/View/CustomGroupChannelSettings.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomGroupChannelSettings.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView(provider: GroupChannelSettingsViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.leftView.swift index 536991a..0668cf2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.rightView.swift index 0e9fd5d..cffe0da 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.titleView.swift index ecd4ba0..64b32f4 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/Header/CustomGroupChannelSettings.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift index 6199ee9..8c4ab6b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.channelInfo.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct channelInfo: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), listItem: { .init() .channelInfo { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.entireView.swift index e26fcae..de4919b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct entireView: View { @@ -19,14 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, - list: { config in - VStack { - Text(config.channel.name.replaceWhenIsEmpty()) - Text("\(config.channel.memberCount)") - Text("Flag: \(customFlag ? "ON" : "OFF")") - } - } + provider: GroupChannelSettingsViewProvider(channelURL: channelURL) ) CustomButton() diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift index bbf7e38..9c521c4 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.leaveChannel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct leaveChannel: View { @@ -17,7 +20,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { GroupChannelSettingsView( - channelURL: TestURL.leaveGroupChannel, + provider: GroupChannelSettingsViewProvider(channelURL: TestURL.leaveGroupChannel), listItem: { .init() .leaveChannelRow { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.member.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.member.swift index 360c10e..5bea7cc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.member.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.member.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct member: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), listItem: { .init() .memberRow { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.moderation.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.moderation.swift index 1138c92..7b6160e 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.moderation.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.moderation.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct moderation: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), listItem: { .init() .moderationRow { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.notification.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.notification.swift index 9f92e32..03a10b6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.notification.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.notification.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct notification: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), listItem: { .init() .notificationRow { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.searchItem.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.searchItem.swift index e7d0863..3501be3 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.searchItem.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupChannelSettings/ViewConverter/List/CustomGroupChannelSettings.ViewConverter.List.searchItem.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupChannelSettings.ViewConverter.List { struct searchItem: View { @@ -19,7 +22,7 @@ extension CustomGroupChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupChannelSettingsView( - channelURL: channelURL, + provider: GroupChannelSettingsViewProvider(channelURL: channelURL), listItem: { .init() .searchRow { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/CustomGroupMemberList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/CustomGroupMemberList.swift index 1c10049..e8f8517 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/CustomGroupMemberList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/CustomGroupMemberList.swift @@ -1,11 +1,16 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupMemberList: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupMemberListView(channelURL: channelURL) + GroupMemberListView( + provider: GroupMemberListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SubView/Builder/CustomGroupMemberList.SubView.Builder.inviteUser.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SubView/Builder/CustomGroupMemberList.SubView.Builder.inviteUser.swift index 08f023e..5bf4778 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SubView/Builder/CustomGroupMemberList.SubView.Builder.inviteUser.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SubView/Builder/CustomGroupMemberList.SubView.Builder.inviteUser.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.SubView.Builder { struct inviteUser: View { @@ -6,9 +9,11 @@ extension CustomGroupMemberList.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupMemberListView(channelURL: channelURL) + GroupMemberListView( + provider: GroupMemberListViewProvider(channelURL: channelURL) + ) .inviteUserView { channelURL in - InviteUserView(channelURL: channelURL) + InviteUserView(provider: InviteUserViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.CustomMain.swift index b98eca8..bf86529 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.SwiftUI.View { struct CustomMain: View { @@ -20,7 +23,7 @@ extension CustomGroupMemberList.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL { // Currently only header is tested GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.Main.swift index bd8927e..4d989d2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/SwiftUI/View/CustomGroupMemberList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomGroupMemberList.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupMemberListView(channelURL: channelURL) + GroupMemberListView( + provider: GroupMemberListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.leftView.swift index 3d7f574..bd6a524 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.rightView.swift index ce2adf4..58a0523 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.titleView.swift index 61edc13..d2c499f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/Header/CustomGroupMemberList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.entireView.swift index 83bfa9e..39d02b1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.entireView.swift @@ -1,13 +1,45 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.List { struct entireView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel + @StateObject var provider: GroupMemberListViewProvider @State var customFlag: Bool = false + // case 1: view init timing + var body: some View { + VStack { + if let channelURL = viewModel.groupChannel?.channelURL { + GroupMemberListView( + provider: provider.setup(channelURL: channelURL, customUsers: nil) + ) + CustomButton() + } + } + } + + // case 2: onAppear timing + var body1: some View { + VStack { + GroupMemberListView( + provider: provider + ) + .onAppear { + if let channelURL = viewModel.groupChannel?.channelURL { + provider.setup(channelURL: channelURL, customUsers: nil) + } + } + CustomButton() + } + } + + // MARK: - Minor views func CustomButton() -> Button { return Button { - self.customFlag.toggle() + customFlag.toggle() } label: { Text("Toggle") .padding() @@ -16,29 +48,26 @@ extension CustomGroupMemberList.ViewConverter.List { } } - var body: some View { - if let channelURL = viewModel.groupChannel?.channelURL { - GroupMemberListView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } + fileprivate func MemberList( + viewConfig: GroupMemberListViewConverter.List.TableView.ViewConfig + ) -> List> { + return List(provider.members, id: \.userId) { user in + HStack { + Circle() + .frame(width: 12, height: 12) + .foregroundStyle(user.isOperator ? .green : .red) + Text("\(user.refinedNickname())") + } + .onAppear { + if user.userId == provider.members.last?.userId { + provider.loadNextMemberList() } - ) - CustomButton() + } } } } } - + #Preview { - CustomGroupMemberList.ViewConverter.List.entireView() + CustomGroupMemberList.ViewConverter.List.entireView(provider: .init(channelURL: "")) } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.moreButton.swift index 438111e..53ff77c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.List { struct moreButton: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.operatorStateView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.operatorStateView.swift index 4bb581e..62b072c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.operatorStateView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.operatorStateView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.List { struct operatorStateView: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), listItem: { .init() .operatorStateView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.profileImage.swift index 0b3be63..5549b23 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.rowView.swift index 4ad5ecb..70daee3 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.userNameLabel.swift index e5bf3e5..a05afcb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMemberList/ViewConverter/List/CustomGroupMemberList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMemberList.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomGroupMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMemberListView( - channelURL: channelURL, + provider: GroupMemberListViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/CustomGroupModerations.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/CustomGroupModerations.swift index 9f267ec..f125fab 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/CustomGroupModerations.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/CustomGroupModerations.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupModerations: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupModerationsView(channelURL: channelURL) + GroupModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.CustomMain.swift index d5ca16c..d1cb3e7 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupModerations.SwiftUI.View { struct CustomMain: View { @@ -19,7 +22,7 @@ extension CustomGroupModerations.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.Main.swift index f611ec1..ca0073a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/SwiftUI/View/CustomGroupModerations.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupModerations.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomGroupModerations.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupModerationsView(channelURL: channelURL) + GroupModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.leftView.swift index 27745a7..d0f84a2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupModerations.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupModerations.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.rightView.swift index ce4d3bf..4584bd2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupModerations.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupModerations.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.titleView.swift index 137a2b0..306d869 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/Header/CustomGroupModerations.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupModerations.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupModerations.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/List/CustomGroupModerations.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/List/CustomGroupModerations.ViewConverter.List.entireView.swift index a6c178b..0d38530 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/List/CustomGroupModerations.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupModerations/ViewConverter/List/CustomGroupModerations.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupModerations.ViewConverter.List { struct entireView: View { @@ -6,7 +9,7 @@ extension CustomGroupModerations.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupModerationsView(channelURL: channelURL) + GroupModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/CustomGroupMutedMemberList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/CustomGroupMutedMemberList.swift index e993cc3..18328c9 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/CustomGroupMutedMemberList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/CustomGroupMutedMemberList.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupMutedMemberList: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupMutedMemberListView(channelURL: channelURL) + GroupMutedMemberListView( + provider: GroupMutedMemberListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift index 9fa395b..b617295 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.SwiftUI.View { struct CustomMain: View { @@ -20,7 +23,7 @@ extension CustomGroupMutedMemberList.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL { // Currently only header is tested GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.Main.swift index 7963c24..0671ad2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/SwiftUI/View/CustomGroupMutedMemberList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomGroupMutedMemberList.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupMutedMemberListView(channelURL: channelURL) + GroupMutedMemberListView( + provider: GroupMutedMemberListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift index 789afb7..38f3df7 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift index 64bbea2..03d505d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift index 9982939..62fe121 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/Header/CustomGroupMutedMemberList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.entireView.swift index b7d0a09..6da580c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.List { struct entireView: View { @@ -19,19 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: GroupMutedMemberListViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift index 4d4a343..74283f2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.List { struct moreButton: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift index 5d1f489..0144b46 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.operatorStateView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.List { struct operatorStateView: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), listItem: { .init() .operatorStateView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift index 156b911..4585fc0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.rowView.swift index df0cf0a..990acc9 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift index a51a950..2500556 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupMutedMemberList/ViewConverter/List/CustomGroupMutedMemberList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupMutedMemberList.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomGroupMutedMemberList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupMutedMemberListView( - channelURL: channelURL, + provider: GroupMutedMemberListViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/CustomGroupOperatorList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/CustomGroupOperatorList.swift index c73e7dd..29d933a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/CustomGroupOperatorList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/CustomGroupOperatorList.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomGroupOperatorList: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupOperatorListView(channelURL: channelURL) + GroupOperatorListView( + provider: GroupOperatorListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SubView/Builder/CustomGroupOperatorList.SubView.Builder.registerOperator.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SubView/Builder/CustomGroupOperatorList.SubView.Builder.registerOperator.swift index 84b52fc..5acf77b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SubView/Builder/CustomGroupOperatorList.SubView.Builder.registerOperator.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SubView/Builder/CustomGroupOperatorList.SubView.Builder.registerOperator.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.SubView.Builder { struct registerOperator: View { @@ -6,9 +9,9 @@ extension CustomGroupOperatorList.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupOperatorListView(channelURL: channelURL) + GroupOperatorListView(provider: .init(channelURL: channelURL)) .registerOperatorView { channelURL in - GroupChannelRegisterOperatorView(channelURL: channelURL) + GroupChannelRegisterOperatorView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.CustomMain.swift index a7c6357..e477ab1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.SwiftUI.View { struct CustomMain: View { @@ -20,7 +23,7 @@ extension CustomGroupOperatorList.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL { // Currently only header is tested GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.Main.swift index ca92871..268dd3d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/SwiftUI/View/CustomGroupOperatorList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomGroupOperatorList.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - GroupOperatorListView(channelURL: channelURL) + GroupOperatorListView(provider: GroupOperatorListViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.leftView.swift index 8b9fc59..6042ee6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.rightView.swift index c931666..ec8bc4d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.titleView.swift index 7496134..6f30b5b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/Header/CustomGroupOperatorList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.Header { struct titleView: View { @@ -17,7 +20,7 @@ extension CustomGroupOperatorList.ViewConverter.Header { var body: some View { GroupOperatorListView( - channelURL: TestURL.openChannel, + provider: GroupOperatorListViewProvider(channelURL: TestURL.groupChannel), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.entireView.swift index 6935553..c60c35a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.List { struct entireView: View { @@ -19,19 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: GroupOperatorListViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.moreButton.swift index a030929..4cc9288 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.List { struct moreButton: View { @@ -19,7 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.profileImage.swift index 1fef324..235adbe 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.rowView.swift index 3b03b5f..4979193 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift index 7535247..252b704 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/GroupOperatorList/ViewConverter/List/CustomGroupOperatorList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomGroupOperatorList.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomGroupOperatorList.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { GroupOperatorListView( - channelURL: channelURL, + provider: GroupOperatorListViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/CustomInviteUser.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/CustomInviteUser.swift index 5dc4ca5..17adb92 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/CustomInviteUser.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/CustomInviteUser.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomInviteUser: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - InviteUserView(channelURL: channelURL) + InviteUserView(provider: InviteUserViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.CustomMain.swift index 17ada15..dc1eeb8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.SwiftUI.View { struct CustomMain: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomInviteUser.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.Main.swift index c8eb6f8..b6bd9ba 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/SwiftUI/View/CustomInviteUser.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomInviteUser.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - InviteUserView(channelURL: channelURL) + InviteUserView(provider: InviteUserViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.leftView.swift index 57346a6..035d2a4 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.Header { struct leftView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomInviteUser.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.rightView.swift index 48d3044..534ca24 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.Header { struct rightView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomInviteUser.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.titleView.swift index 26cf2d5..d661b09 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/Header/CustomInviteUser.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomInviteUser.ViewConverter.Header { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.entireView.swift index 5f22587..fec0121 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.List { struct entireView: View { @@ -19,23 +22,7 @@ extension CustomInviteUser.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - Button { - config.parentView.onSelectUser(user) - } label: { - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(config.selectedUsers.contains(user) ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } - } + provider: InviteUserViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.profileImage.swift index a888141..b86ce64 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomInviteUser.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.rowView.swift index 8e276a7..527792d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomInviteUser.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.selectionButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.selectionButton.swift index 83effc2..6c7fa57 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.selectionButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.selectionButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.List { struct selectionButton: View { @@ -19,7 +22,7 @@ extension CustomInviteUser.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), listItem: { .init() .selectionButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.userNameLabel.swift index e7063b9..865c644 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/InviteUser/ViewConverter/List/CustomInviteUser.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomInviteUser.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomInviteUser.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { InviteUserView( - channelURL: channelURL, + provider: InviteUserViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/CustomMessageSearch.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/CustomMessageSearch.swift index bd65d2c..ae9ff46 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/CustomMessageSearch.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/CustomMessageSearch.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomMessageSearch: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - MessageSearchView(channelURL: channelURL) + MessageSearchView( + provider: MessageSearchViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SubView/Builder/CustomMessageSearch.SubView.Builder.groupChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SubView/Builder/CustomMessageSearch.SubView.Builder.groupChannel.swift index 45f97cc..f1b1260 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SubView/Builder/CustomMessageSearch.SubView.Builder.groupChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SubView/Builder/CustomMessageSearch.SubView.Builder.groupChannel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.SubView.Builder { struct groupChannel: View { @@ -6,13 +9,17 @@ extension CustomMessageSearch.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - MessageSearchView(channelURL: channelURL) + MessageSearchView( + provider: MessageSearchViewProvider(channelURL: channelURL) + ) .groupChannelView { channelURL, startingPoint, messageListParams in - GroupChannelView( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams) - } + GroupChannelView(provider: GroupChannelViewProvider( + channelURL: channelURL, + startingPoint: startingPoint, + messageListParams: messageListParams + ) + ) + } } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.CustomMain.swift index b8d511a..7fe559a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.SwiftUI.View { struct CustomMain: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.Main.swift index cd59ec8..90e4f25 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/SwiftUI/View/CustomMessageSearch.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomMessageSearch.SwiftUI.View { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - MessageSearchView(channelURL: channelURL) + MessageSearchView( + provider: MessageSearchViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.leftView.swift index 9462d54..5f95aa8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.ViewConverter.Header { struct leftView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.rightView.swift index fca424d..b269134 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.ViewConverter.Header { struct rightView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.titleView.swift index d857d4b..a40e2fb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/Header/CustomMessageSearch.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.ViewConverter.Header { struct titleView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/List/CustomMessageSearch.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/List/CustomMessageSearch.ViewConverter.List.entireView.swift index 25a564b..0a10903 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/List/CustomMessageSearch.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageSearch/ViewConverter/List/CustomMessageSearch.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageSearch.ViewConverter.List { struct entireView: View { @@ -6,7 +9,7 @@ extension CustomMessageSearch.ViewConverter.List { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { - MessageSearchView(channelURL: channelURL) + MessageSearchView(provider: MessageSearchViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/CustomMessageThread.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/CustomMessageThread.swift index 4baac7a..dee05f7 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/CustomMessageThread.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/CustomMessageThread.swift @@ -1,11 +1,19 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomMessageThread: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { - MessageThreadView(channelURL: channelURL, parentMessageId: parentMessageId) + MessageThreadView( + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.CustomMain.swift index f2eeca6..4f647ac 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.SwiftUI.View { struct CustomMain: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -19,7 +22,10 @@ extension CustomMessageThread.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.Main.swift index 90a1143..b177f0f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/SwiftUI/View/CustomMessageThread.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.SwiftUI.View { struct Main: View { @@ -8,8 +11,10 @@ extension CustomMessageThread.SwiftUI.View { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ) ) } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.leftView.swift index fbfda96..00a72ce 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Header { struct leftView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Header { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.rightView.swift index c12ec04..f147b62 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Header { struct rightView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Header { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.subtitleLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.subtitleLabel.swift index cd1729d..1103038 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.subtitleLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.subtitleLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Header { struct subtitleLabel: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Header { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), headerItem: { .init() .subtitleLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleLabel.swift index 3436d61..3968739 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Header { struct titleLabel: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Header { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), headerItem: { .init() .titleLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleView.swift index e4d797b..9eb37cb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Header/CustomMessageThread.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Header { struct titleView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Header { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.addButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.addButton.swift index 36babe0..7001316 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.addButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.addButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Input { struct addButton: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Input { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), inputItem: { .init() .addButton { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.entireView.swift index 6749e17..22f43fb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Input { struct entireView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.leftView.swift index 04dfff8..9b9238d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Input { struct leftView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Input { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), inputItem: { .init() .leftView { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.rightView.swift index b89fe27..ac87447 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Input { struct rightView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Input { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), inputItem: { .init() .rightView(content: { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.sendButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.sendButton.swift index 0f1300b..27146c9 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.sendButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.sendButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Input { struct sendButton: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Input { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), inputItem: { .init() .sendButton { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.voiceButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.voiceButton.swift index 48c37bd..c80b7b6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.voiceButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/Input/CustomMessageThread.ViewConverter.Input.voiceButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.Input { struct voiceButton: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.Input { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), inputItem: { .init() .voiceButton(content: { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.channelStateBanner.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.channelStateBanner.swift index 31f024d..49db852 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.channelStateBanner.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.channelStateBanner.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.List { struct channelStateBanner: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), listItem: { .init() .channelStateBanner { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.entireView.swift index 65e81f7..ca74497 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.List { struct entireView: View { @@ -18,18 +21,10 @@ extension CustomMessageThread.ViewConverter.List { var body: some View { MessageThreadView( - channelURL: TestURL.threadMessageChannel, - parentMessageId: TestMessageId.threadMessageId, - list: { config in - List(config.messages) { message in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(customFlag ? .green : .red) - Text(message.message) - } - } - } + provider: MessageThreadViewProvider( + channelURL: TestURL.threadMessageChannel, + parentMessageId: TestMessageId.threadMessageId + ) ) CustomButton() diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.fileMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.fileMessageView.swift index e0edf84..fda06f8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.fileMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.fileMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.List { struct fileMessageView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), listItem: { .init() .fileMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift index fc7c734..f8156ce 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.multipleFilesMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.List { struct multipleFilesMessageView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), listItem: { .init() .multipleFilesMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.rowView.swift index e03e59c..62e22f1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif import SendbirdChatSDK extension CustomMessageThread.ViewConverter.List { @@ -21,8 +24,10 @@ extension CustomMessageThread.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.senderProfileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.senderProfileImage.swift index 800c61c..e1ffe81 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.senderProfileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.senderProfileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.List { struct senderProfileImage: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), listItem: { .init() .senderProfileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.userMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.userMessageView.swift index 02cfa81..f822f13 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.userMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/List/CustomMessageThread.ViewConverter.List.userMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.List { struct userMessageView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.List { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), listItem: { .init() .userMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift index 6b0ab82..b3187dc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.dateLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct dateLabel: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .dateLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift index f92f24a..c1fe430 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.entireContent.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct entireContent: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .parentInfoView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift index d511f08..e348e16 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.fileContentView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct fileContentView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .fileContentView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift index d25710d..082e963 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.messageTextView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct messageTextView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .messageTextView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift index 6fe030c..a0ced5e 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct moreButton: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift index 715ea6f..5f50310 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.multipleFileContentView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct multipleFileContentView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .multipleFilesContentView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.profileView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.profileView.swift index 70754db..72b7f96 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.profileView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.profileView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct profileView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .profileView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift index 58d4e7d..6bdfcb8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.reactionView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct reactionView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .reactionView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift index a354992..a09016e 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.replyLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct replyLabel: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .replyLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift index cd5927f..1b17ecf 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct userNameLabel: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .userNameLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.webView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.webView.swift index dffea96..26a2c1a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.webView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/MessageThread/ViewConverter/ParentInfo/CustomMessageThread.ViewConverter.ParentInfo.webView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomMessageThread.ViewConverter.ParentInfo { struct webView: View { @@ -20,8 +23,10 @@ extension CustomMessageThread.ViewConverter.ParentInfo { if let channelURL = viewModel.groupChannel?.channelURL, let parentMessageId = viewModel.parentMessage?.messageId { MessageThreadView( - channelURL: channelURL, - parentMessageId: parentMessageId, + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ), parentInfoItem: { .init() .messageTextView(content: { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/CustomOpenBannedUserList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/CustomOpenBannedUserList.swift index b35fd6e..20706fb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/CustomOpenBannedUserList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/CustomOpenBannedUserList.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenBannedUserList: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenBannedUserListView(channelURL: channelURL) + OpenBannedUserListView(provider: OpenBannedUserListViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift index 4ad91dd..d14cf74 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.SwiftUI.View { struct CustomMain: View { @@ -20,7 +23,7 @@ extension CustomOpenBannedUserList.SwiftUI.View { if let channelURL = viewModel.openChannel?.channelURL { // Currently only header is tested OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.Main.swift index 76baa4a..3491cea 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/SwiftUI/View/CustomOpenBannedUserList.SwiftUI.View.Main.swift @@ -1,11 +1,14 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.SwiftUI.View { struct Main: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenBannedUserListView(channelURL: channelURL) + OpenBannedUserListView(provider: OpenBannedUserListViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.leftView.swift index d7ab7ab..1097528 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.rightView.swift index 85ffcee..93a9485 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.titleView.swift index 40af5fe..7493e71 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/Header/CustomOpenBannedUserList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.entireView.swift index f42d267..12f81cb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.List { struct entireView: View { @@ -19,19 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: OpenBannedUserListViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.moreButton.swift index e8c508c..6529140 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.List { struct moreButton: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.profileImage.swift index 9bddc83..c54041f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.rowView.swift index 672dd4d..883e827 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift index e507497..6f28678 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenBannedUserList/ViewConverter/List/CustomOpenBannedUserList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenBannedUserList.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomOpenBannedUserList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenBannedUserListView( - channelURL: channelURL, + provider: OpenBannedUserListViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/CustomOpenChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/CustomOpenChannel.swift index f307530..e5d093c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/CustomOpenChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/CustomOpenChannel.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenChannel: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelView(channelURL: channelURL) + OpenChannelView(provider: OpenChannelViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.channelSettings.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.channelSettings.swift index ba1c011..37c8f00 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.channelSettings.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.channelSettings.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.SubView.Builder { struct channelSettings: View { @@ -6,9 +9,11 @@ extension CustomOpenChannel.SubView.Builder { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelView(channelURL: channelURL) + OpenChannelView(provider: OpenChannelViewProvider(channelURL: channelURL)) .channelSettingsView { channelURL in - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.userList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.userList.swift index 332be64..c6412c8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.userList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SubView/Builder/CustomOpenChannel.SubView.Builder.userList.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.SubView.Builder { struct userList: View { @@ -6,9 +9,9 @@ extension CustomOpenChannel.SubView.Builder { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelView(channelURL: channelURL) + OpenChannelView(provider: OpenChannelViewProvider(channelURL: channelURL)) .participantListView { channelURL in - OpenParticipantListView(channelURL: channelURL) + OpenParticipantListView(provider: OpenParticipantListViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.CustomMain.swift index 3c79d83..0081f7a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.SwiftUI.View { struct CustomMain: View { @@ -7,7 +10,7 @@ extension CustomOpenChannel.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .coverImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.Main.swift index 0233d35..180c12a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/SwiftUI/View/CustomOpenChannel.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomOpenChannel.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelView(channelURL: channelURL) + OpenChannelView(provider: OpenChannelViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.coverImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.coverImage.swift index f4e7fb5..afee0be 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.coverImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.coverImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Header { struct coverImage: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .coverImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.leftView.swift index 12d94ad..3c6bcfc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.rightView.swift index 6ecde8c..d11a56d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift index 4670850..7dedfaf 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.subtitleLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Header { struct subtitleLabel: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .subtitleLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleLabel.swift index 1c61026..cea9638 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Header { struct titleLabel: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .titleLabel { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleView.swift index a1de67a..79fdbcc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Header/CustomOpenChannel.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.addButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.addButton.swift index 14ae524..5363d36 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.addButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.addButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Input { struct addButton: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), inputItem: { .init() .addButton { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.entireView.swift index 681398a..3fb05f7 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Input { struct entireView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.leftView.swift index e06dfe4..90f61d0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Input { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), inputItem: { .init() .leftView { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.rightView.swift index 67883d0..2b786bc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Input { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), inputItem: { .init() .rightView(content: { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.sendButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.sendButton.swift index a6597c9..99a3dc2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.sendButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Input/CustomOpenChannel.ViewConverter.Input.sendButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Input { struct sendButton: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.Input { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), inputItem: { .init() .sendButton { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.adminMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.adminMessageView.swift index 480e686..098c386 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.adminMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.adminMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.List { struct adminMessageView: View { @@ -20,7 +23,7 @@ extension CustomOpenChannel.ViewConverter.List { if let channelURL = viewModel.openChannel?.channelURL { VStack { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), listItem: { .init() .adminMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.entireView.swift index 99d1c69..a665ee1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.List { struct entireView: View { @@ -19,17 +22,7 @@ extension CustomOpenChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, - list: { config in - List(config.messages) { message in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(customFlag ? .green : .red) - Text(message.message) - } - } - } + provider: OpenChannelViewProvider(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.fileMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.fileMessageView.swift index aec4cf6..8d4be22 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.fileMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.fileMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.List { struct fileMessageView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), listItem: { .init() .fileMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.rowView.swift index f709d2b..b20f48a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif import SendbirdChatSDK extension CustomOpenChannel.ViewConverter.List { @@ -20,7 +23,7 @@ extension CustomOpenChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.scrollBottomView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.scrollBottomView.swift index 0a0f272..7d2453d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.scrollBottomView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.scrollBottomView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.List { struct scrollBottomView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), listItem: { .init() .scrollBottomView { viewConfig in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.senderProfileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.senderProfileImage.swift index 449b903..b067e6a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.senderProfileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.senderProfileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.List { struct senderProfileImage: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), listItem: { .init() .senderProfileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.userMessageView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.userMessageView.swift index d89d56c..93e3f66 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.userMessageView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/List/CustomOpenChannel.ViewConverter.List.userMessageView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.List { struct userMessageView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannel.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelView( - channelURL: channelURL, + provider: OpenChannelViewProvider(channelURL: channelURL), listItem: { .init() .userMessageView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Media/CustomOpenChannel.ViewConverter.Media.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Media/CustomOpenChannel.ViewConverter.Media.entireView.swift index fe50c0a..ea7bf92 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Media/CustomOpenChannel.ViewConverter.Media.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannel/ViewConverter/Media/CustomOpenChannel.ViewConverter.Media.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannel.ViewConverter.Media { struct entireView: View { @@ -6,7 +9,7 @@ extension CustomOpenChannel.ViewConverter.Media { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelView(channelURL: channelURL) + OpenChannelView(provider: OpenChannelViewProvider(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/CustomOpenChannelList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/CustomOpenChannelList.swift index 98bc19f..b339afa 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/CustomOpenChannelList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/CustomOpenChannelList.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenChannelList: View { var body: some View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.createChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.createChannel.swift index cb063be..ecce320 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.createChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.createChannel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.SubView.Builder { struct createChannel: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.openChannel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.openChannel.swift index 6b75f95..2cf7f03 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.openChannel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SubView/Builder/CustomOpenChannelList.SubView.Builder.openChannel.swift @@ -1,11 +1,19 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.SubView.Builder { struct openChannel: View { var body: some View { OpenChannelListView() .openChannelView { channelURL, messageListParams in - OpenChannelView(channelURL: channelURL, messageListParams: messageListParams) + OpenChannelView( + provider: OpenChannelViewProvider( + channelURL: channelURL, + messageListParams: messageListParams + ) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.CustomMain.swift index 0a6c382..49a41fd 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.SwiftUI.View { struct CustomMain: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.Main.swift index d6c4deb..6d39128 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/SwiftUI/View/CustomOpenChannelList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.SwiftUI.View { struct Main: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.leftView.swift index 504f6ba..9bf673b 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.Header { struct leftView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.rightView.swift index 438679e..8842f30 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.Header { struct rightView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.titleView.swift index 0b2a3ea..6fcc3dc 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/Header/CustomOpenChannelList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.Header { struct titleView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelName.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelName.swift index 5041763..bb6db41 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelName.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelName.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.List { struct channelName: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelPreview.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelPreview.swift index 66e46e7..56f65d5 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelPreview.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.channelPreview.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.List { struct channelPreview: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.coverImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.coverImage.swift index a489779..25e70b4 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.coverImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.coverImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.List { struct coverImage: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.entireView.swift index 99af4bc..5c2b752 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.List { struct entireView: View { @@ -16,22 +19,7 @@ extension CustomOpenChannelList.ViewConverter.List { } var body: some View { - OpenChannelListView( - list: { config in - if config.channels.isEmpty { - Text("No channels") - } else { - ScrollView { - ForEach(config.channels) { channel in - VStack { - Text("Channel entire view: \(customFlag ? "ON" : "OFF")") - Text("\(channel.name)") - } - } - } - } - } - ) + OpenChannelListView() CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.rowView.swift index de88450..30d5bf6 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelList/ViewConverter/List/CustomOpenChannelList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelList.ViewConverter.List { struct rowView: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/CustomOpenChannelRegisterOperator.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/CustomOpenChannelRegisterOperator.swift index 166b3c0..a0c64e3 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/CustomOpenChannelRegisterOperator.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/CustomOpenChannelRegisterOperator.swift @@ -1,7 +1,10 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenChannelRegisterOperator: View { var body: some View { - OpenChannelRegisterOperatorView(channelURL: TestURL.openChannel) + OpenChannelRegisterOperatorView(provider: .init(channelURL: TestURL.openChannel)) } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift index 775deb4..086a830 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelRegisterOperator.SwiftUI.View { struct CustomMain: View { @@ -18,7 +21,7 @@ extension CustomOpenChannelRegisterOperator.SwiftUI.View { var body: some View { // Currently only header is tested OpenChannelRegisterOperatorView( - channelURL: TestURL.openChannelOperator, + provider: .init(channelURL: TestURL.openChannelOperator), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift index b95e6d4..2d0039d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/SwiftUI/View/CustomOpenChannelRegisterOperator.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelRegisterOperator.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomOpenChannelRegisterOperator.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelRegisterOperatorView(channelURL: channelURL) + OpenChannelRegisterOperatorView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift index 1eb36e3..64cd93a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelRegisterOperator.ViewConverter.Header { struct leftView: View { @@ -17,7 +20,7 @@ extension CustomOpenChannelRegisterOperator.ViewConverter.Header { var body: some View { OpenChannelRegisterOperatorView( - channelURL: TestURL.openChannelOperator, + provider: .init(channelURL: TestURL.openChannelOperator), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift index d5f2ff0..07b128c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelRegisterOperator.ViewConverter.Header { struct rightView: View { @@ -17,7 +20,7 @@ extension CustomOpenChannelRegisterOperator.ViewConverter.Header { var body: some View { OpenChannelRegisterOperatorView( - channelURL: TestURL.openChannelOperator, + provider: .init(channelURL: TestURL.openChannelOperator), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift index dfe22cf..71c4391 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/Header/CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelRegisterOperator.ViewConverter.Header { struct titleView: View { @@ -17,7 +20,7 @@ extension CustomOpenChannelRegisterOperator.ViewConverter.Header { var body: some View { OpenChannelRegisterOperatorView( - channelURL: TestURL.openChannelOperator, + provider: .init(channelURL: TestURL.openChannelOperator), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/List/CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/List/CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift index aa05650..a47593a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/List/CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelRegisterOperator/ViewConverter/List/CustomOpenChannelRegisterOperator.ViewConverter.List.entireView.swift @@ -1,9 +1,12 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelRegisterOperator.ViewConverter.List { struct entireView: View { var body: some View { - OpenChannelRegisterOperatorView(channelURL: TestURL.openChannelOperator) + OpenChannelRegisterOperatorView(provider: .init(channelURL: TestURL.openChannelOperator)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/CustomOpenChannelSettings.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/CustomOpenChannelSettings.swift index 3269181..bcb7102 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/CustomOpenChannelSettings.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/CustomOpenChannelSettings.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenChannelSettings: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.moderations.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.moderations.swift index e2353b8..a11cfa5 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.moderations.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.moderations.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.SubView.Builder { struct moderations: View { @@ -6,9 +9,11 @@ extension CustomOpenChannelSettings.SubView.Builder { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) .moderationsView { channelURL in - OpenModerationsView(channelURL: channelURL) + OpenModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.userList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.userList.swift index 62193f2..ffe088d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.userList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SubView/Builder/CustomOpenChannelSettings.SubView.Builder.userList.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.SubView.Builder { struct userList: View { @@ -6,9 +9,13 @@ extension CustomOpenChannelSettings.SubView.Builder { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) .participantListView { channelURL in - OpenParticipantListView(channelURL: channelURL) + OpenParticipantListView( + provider: OpenParticipantListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift index 621e159..695ec41 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.SwiftUI.View { struct CustomMain: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -7,7 +10,7 @@ extension CustomOpenChannelSettings.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelSettingsView( - channelURL: channelURL, + provider: OpenChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.Main.swift index 57d8574..d8ab0be 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/SwiftUI/View/CustomOpenChannelSettings.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomOpenChannelSettings.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.leftView.swift index 48036cd..4f1dc87 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.ViewConverter.Header { struct leftView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomOpenChannelSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelSettingsView( - channelURL: channelURL, + provider: OpenChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.rightView.swift index abd2574..acfe769 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.ViewConverter.Header { struct rightView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomOpenChannelSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelSettingsView( - channelURL: channelURL, + provider: OpenChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.titleView.swift index e85e9be..9eccb75 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/Header/CustomOpenChannelSettings.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomOpenChannelSettings.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenChannelSettingsView( - channelURL: channelURL, + provider: OpenChannelSettingsViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/List/CustomOpenChannelSettings.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/List/CustomOpenChannelSettings.ViewConverter.List.entireView.swift index 36c35fe..a7b3086 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/List/CustomOpenChannelSettings.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenChannelSettings/ViewConverter/List/CustomOpenChannelSettings.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenChannelSettings.ViewConverter.List { struct entireView: View { @@ -6,7 +9,9 @@ extension CustomOpenChannelSettings.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/CustomOpenModerations.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/CustomOpenModerations.swift index a4e8298..5820bdd 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/CustomOpenModerations.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/CustomOpenModerations.swift @@ -1,10 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenModerations: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenModerationsView(channelURL: channelURL) + OpenModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.CustomMain.swift index e5b100e..0b87648 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenModerations.SwiftUI.View { struct CustomMain: View { @@ -19,7 +22,7 @@ extension CustomOpenModerations.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.Main.swift index a9dcfe4..2f17783 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/SwiftUI/View/CustomOpenModerations.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenModerations.SwiftUI.View { struct Main: View { @@ -6,7 +9,7 @@ extension CustomOpenModerations.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenModerationsView(channelURL: channelURL) + OpenModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.leftView.swift index ec61345..e644421 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenModerations.ViewConverter.Header { struct leftView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomOpenModerations.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.rightView.swift index 1f35ebf..f53b7d8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenModerations.ViewConverter.Header { struct rightView: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel @@ -18,7 +21,7 @@ extension CustomOpenModerations.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.titleView.swift index 9512437..4ca9af1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/Header/CustomOpenModerations.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenModerations.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomOpenModerations.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenModerationsView( - channelURL: channelURL, + provider: .init(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/List/CustomOpenModerations.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/List/CustomOpenModerations.ViewConverter.List.entireView.swift index 0ae33ba..bdba01c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/List/CustomOpenModerations.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenModerations/ViewConverter/List/CustomOpenModerations.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenModerations.ViewConverter.List { struct entireView: View { @@ -6,7 +9,7 @@ extension CustomOpenModerations.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenModerationsView(channelURL: channelURL) + OpenModerationsView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/CustomOpenMutedParticipantList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/CustomOpenMutedParticipantList.swift index 282175a..8b79b15 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/CustomOpenMutedParticipantList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/CustomOpenMutedParticipantList.swift @@ -1,10 +1,15 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenMutedParticipantList: View { @EnvironmentObject var viewModel: CustomSampleSubViewModel var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenMutedParticipantListView(channelURL: channelURL) + OpenMutedParticipantListView( + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift index 7108a4b..9831dd0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.SwiftUI.View { struct CustomMain: View { @@ -20,7 +23,7 @@ extension CustomOpenMutedParticipantList.SwiftUI.View { if let channelURL = viewModel.openChannel?.channelURL { // Currently only header is tested OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.Main.swift index 989f45b..4b008d0 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/SwiftUI/View/CustomOpenMutedParticipantList.SwiftUI.View.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.SwiftUI.View { struct Main: View { @@ -6,7 +9,9 @@ extension CustomOpenMutedParticipantList.SwiftUI.View { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { - OpenMutedParticipantListView(channelURL: channelURL) + OpenMutedParticipantListView( + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift index 98f95c8..3b83446 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.Header { struct leftView: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift index 2085f63..f158c1c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.Header { struct rightView: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift index 1d19bb3..b4630be 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/Header/CustomOpenMutedParticipantList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.Header { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.Header { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift index 493da35..0eb6241 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.List { struct entireView: View { @@ -19,19 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: .init(channelURL: channelURL) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift index 04bbe9d..e90544f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.List { struct moreButton: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift index 4d4697f..d1e0626 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.operatorStateView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.List { struct operatorStateView: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), listItem: { .init() .operatorStateView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift index 57c22f0..f647612 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.List { struct profileImage: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift index ae07e55..c4f61fb 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.List { struct rowView: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift index d384bb3..e6c3daa 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenMutedParticipantList/ViewConverter/List/CustomOpenMutedParticipantList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenMutedParticipantList.ViewConverter.List { struct userNameLabel: View { @@ -19,7 +22,7 @@ extension CustomOpenMutedParticipantList.ViewConverter.List { var body: some View { if let channelURL = viewModel.openChannel?.channelURL { OpenMutedParticipantListView( - channelURL: channelURL, + provider: OpenMutedParticipantListViewProvider(channelURL: channelURL), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/CustomOpenOperatorList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/CustomOpenOperatorList.swift index 930ebf7..fdd8a24 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/CustomOpenOperatorList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/CustomOpenOperatorList.swift @@ -1,7 +1,12 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenOperatorList: View { var body: some View { - OpenOperatorListView(channelURL: TestURL.openChannel) + OpenOperatorListView( + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel) + ) } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SubView/Builder/CustomOpenOperatorList.SubView.Builder.registerOperator.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SubView/Builder/CustomOpenOperatorList.SubView.Builder.registerOperator.swift index 2bd34c8..782e3ee 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SubView/Builder/CustomOpenOperatorList.SubView.Builder.registerOperator.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SubView/Builder/CustomOpenOperatorList.SubView.Builder.registerOperator.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.SubView.Builder { struct titleView: View { @@ -19,7 +22,7 @@ extension CustomOpenOperatorList.SubView.Builder { var body: some View { if let channelURL = viewModel.groupChannel?.channelURL { OpenOperatorListView( - channelURL: channelURL, + provider: OpenOperatorListViewProvider(channelURL: channelURL), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.CustomMain.swift index 41fea9e..16c9167 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.SwiftUI.View { struct CustomMain: View { @@ -18,7 +21,7 @@ extension CustomOpenOperatorList.SwiftUI.View { var body: some View { // Currently only header is tested OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.Main.swift index d5fa539..2afb081 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/SwiftUI/View/CustomOpenOperatorList.SwiftUI.View.Main.swift @@ -1,9 +1,14 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.SwiftUI.View { struct Main: View { var body: some View { - OpenOperatorListView(channelURL: TestURL.openChannel) + OpenOperatorListView( + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.leftView.swift index 8a1b587..379758c 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.Header { struct leftView: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.Header { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.rightView.swift index 2aaf1c4..6453ee4 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.Header { struct rightView: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.Header { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.titleView.swift index 30e263e..393f796 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/Header/CustomOpenOperatorList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.Header { struct titleView: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.Header { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.entireView.swift index 873409d..d3780c5 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.List { struct entireView: View { @@ -17,19 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.List { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.moreButton.swift index 106fb98..a26d62a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.List { struct moreButton: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.List { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.profileImage.swift index 42b5a28..ee5dd40 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.List { struct profileImage: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.List { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.rowView.swift index b5f804c..c62b805 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.List { struct rowView: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.List { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift index a3ab1e9..2ccd44f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenOperatorList/ViewConverter/List/CustomOpenOperatorList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenOperatorList.ViewConverter.List { struct userNameLabel: View { @@ -17,7 +20,7 @@ extension CustomOpenOperatorList.ViewConverter.List { var body: some View { OpenOperatorListView( - channelURL: TestURL.openChannel, + provider: OpenOperatorListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/CustomOpenParticipantList.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/CustomOpenParticipantList.swift index 91f63bb..7ac4abf 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/CustomOpenParticipantList.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/CustomOpenParticipantList.swift @@ -1,8 +1,13 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomOpenParticipantList: View { var body: some View { - OpenParticipantListView(channelURL: TestURL.openChannel) + OpenParticipantListView( + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel) + ) } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.CustomMain.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.CustomMain.swift index ef21f1c..e5d2064 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.CustomMain.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.CustomMain.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.SwiftUI.View { struct CustomMain: View { @@ -18,7 +21,7 @@ extension CustomOpenParticipantList.SwiftUI.View { var body: some View { // Currently only header is tested OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.Main.swift index fc2ac72..c02558a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/SwiftUI/View/CustomOpenParticipantList.SwiftUI.View.Main.swift @@ -1,9 +1,14 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.SwiftUI.View { struct Main: View { var body: some View { - OpenParticipantListView(channelURL: TestURL.openChannel) + OpenParticipantListView( + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel) + ) } } } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.leftView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.leftView.swift index a180909..2dc13de 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.leftView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.leftView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.Header { struct leftView: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.Header { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .leftView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.rightView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.rightView.swift index e1fd341..b60fc1d 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.rightView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.rightView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.Header { struct rightView: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.Header { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .rightView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.titleView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.titleView.swift index a109fc5..452340f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.titleView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/Header/CustomOpenParticipantList.ViewConverter.Header.titleView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.Header { struct titleView: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.Header { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), headerItem: { .init() .titleView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.entireView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.entireView.swift index 9f776cd..8d9c02f 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.entireView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.entireView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.List { struct entireView: View { @@ -17,19 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.List { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, - list: { config in - List(config.users, id: \.self) { user in - HStack { - Circle() - .frame(width: 12, height: 12) - .foregroundStyle(user.isOperator ? .green : .red) - Text("\(user.refinedNickname()) - \(customFlag ? "ON" : "OFF")") - .foregroundStyle(.black) - } - .contentShape(Rectangle()) // HStack 전체를 터치 가능한 영역으로 확장 - } - } + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel) ) CustomButton() } diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.moreButton.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.moreButton.swift index dc97958..c87581a 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.moreButton.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.moreButton.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.List { struct moreButton: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.List { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .moreButton { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift index a2efcfc..29dc7e8 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.operatorStateView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.List { struct operatorStateView: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.List { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .operatorStateView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.profileImage.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.profileImage.swift index 9bbe452..8ac8daf 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.profileImage.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.profileImage.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.List { struct profileImage: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.List { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .profileImage { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.rowView.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.rowView.swift index e00524b..cb7cc51 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.rowView.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.rowView.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.List { struct rowView: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.List { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .rowView { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift index a733010..a7aa7b2 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/OpenParticipantList/ViewConverter/List/CustomOpenParticipantList.ViewConverter.List.userNameLabel.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomOpenParticipantList.ViewConverter.List { struct userNameLabel: View { @@ -17,7 +20,7 @@ extension CustomOpenParticipantList.ViewConverter.List { var body: some View { OpenParticipantListView( - channelURL: TestURL.openChannel, + provider: OpenParticipantListViewProvider(channelURL: TestURL.openChannel), listItem: { .init() .userName { config in diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/ColorSet/Custom/CustomTheme.ColorSet.Custom.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/ColorSet/Custom/CustomTheme.ColorSet.Custom.Main.swift index cc91534..0d6c988 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/ColorSet/Custom/CustomTheme.ColorSet.Custom.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/ColorSet/Custom/CustomTheme.ColorSet.Custom.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif /// WARNING: `FontSet`, `ColorSet` must be set before `SendbirdSwiftUI` initialization, and if you change them at runtime, you must call `SBUTheme.set(theme:)'` to reflect them in the generated theme. extension CustomTheme.ColorSet.Custom { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/CustomTheme.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/CustomTheme.swift index 84ef58f..0d5be53 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/CustomTheme.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/CustomTheme.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif struct CustomTheme: View { var body: some View { GroupChannelListView() diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/FontSet/Custom/CustomTheme.FontSet.Custom.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/FontSet/Custom/CustomTheme.FontSet.Custom.Main.swift index ed3c05e..b33a6a1 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/FontSet/Custom/CustomTheme.FontSet.Custom.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/FontSet/Custom/CustomTheme.FontSet.Custom.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif /// WARNING: `FontSet`, `ColorSet` must be set before `SendbirdSwiftUI` initialization, and if you change them at runtime, you must call `SBUTheme.set(theme:)'` to reflect them in the generated theme. extension CustomTheme.FontSet.Custom { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/IconSet/Custom/CustomTheme.IconSet.Custom.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/IconSet/Custom/CustomTheme.IconSet.Custom.Main.swift index c481d90..ffd2a23 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/IconSet/Custom/CustomTheme.IconSet.Custom.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/IconSet/Custom/CustomTheme.IconSet.Custom.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomTheme.IconSet.Custom { struct Main: View { diff --git a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/Theme/Custom/CustomTheme.Theme.Custom.Main.swift b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/Theme/Custom/CustomTheme.Theme.Custom.Main.swift index 48dffce..f959a8e 100644 --- a/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/Theme/Custom/CustomTheme.Theme.Custom.Main.swift +++ b/Sample/QuickStartSwiftUI/CustomSample/CustomViews/Theme/Theme/Custom/CustomTheme.Theme.Custom.Main.swift @@ -1,4 +1,7 @@ import SwiftUI +#if canImport(SendbirdSwiftUI) +import SendbirdSwiftUI +#endif extension CustomTheme.Theme.Custom { struct Main: View { diff --git a/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager+SwiftUI.swift b/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager+SwiftUI.swift index bc00b66..7b6b288 100644 --- a/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager+SwiftUI.swift +++ b/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager+SwiftUI.swift @@ -20,6 +20,8 @@ extension CustomSampleManager { CustomGroupChannelList.SwiftUI.View.Main() case "CustomGroupChannelList.SwiftUI.View.CustomMain": CustomGroupChannelList.SwiftUI.View.CustomMain() + case "CustomGroupChannelList.SwiftUI.View.ViewProvider": + CustomGroupChannelList.SwiftUI.View.ViewProvider() case "CustomGroupChannelList.SubView.Builder.groupChannel": CustomGroupChannelList.SubView.Builder.groupChannel() case "CustomGroupChannelList.SubView.Builder.createChannel": @@ -30,8 +32,8 @@ extension CustomSampleManager { CustomGroupChannelList.ViewConverter.Header.rightView() case "CustomGroupChannelList.ViewConverter.Header.titleView": CustomGroupChannelList.ViewConverter.Header.titleView() - case "CustomGroupChannelList.ViewConverter.List.entireView": - CustomGroupChannelList.ViewConverter.List.entireView() +// case "CustomGroupChannelList.ViewConverter.List.entireView": +// CustomGroupChannelList.ViewConverter.List.entireView() case "CustomGroupChannelList.ViewConverter.List.rowView": CustomGroupChannelList.ViewConverter.List.rowView() case "CustomGroupChannelList.ViewConverter.List.coverImage": @@ -56,8 +58,8 @@ extension CustomSampleManager { CustomOpenChannelList.ViewConverter.Header.rightView() case "CustomOpenChannelList.ViewConverter.Header.titleView": CustomOpenChannelList.ViewConverter.Header.titleView() - case "CustomOpenChannelList.ViewConverter.List.entireView": - CustomOpenChannelList.ViewConverter.List.entireView() +// case "CustomOpenChannelList.ViewConverter.List.entireView": +// CustomOpenChannelList.ViewConverter.List.entireView() case "CustomOpenChannelList.ViewConverter.List.rowView": CustomOpenChannelList.ViewConverter.List.rowView() case "CustomOpenChannelList.ViewConverter.List.coverImage": @@ -70,6 +72,8 @@ extension CustomSampleManager { CustomGroupChannel.SwiftUI.View.Main() case "CustomGroupChannel.SwiftUI.View.CustomMain": CustomGroupChannel.SwiftUI.View.CustomMain() + case "CustomGroupChannel.SwiftUI.View.ViewProvider": + CustomGroupChannel.SwiftUI.View.ViewProvider() case "CustomGroupChannel.SubView.Builder.channelSettings": CustomGroupChannel.SubView.Builder.channelSettings() case "CustomGroupChannel.SubView.Builder.messageThread": @@ -86,8 +90,8 @@ extension CustomSampleManager { CustomGroupChannel.ViewConverter.Header.titleLabel() case "CustomGroupChannel.ViewConverter.Header.typingStatusView": CustomGroupChannel.ViewConverter.Header.typingStatusView() - case "CustomGroupChannel.ViewConverter.List.entireView": - CustomGroupChannel.ViewConverter.List.entireView() +// case "CustomGroupChannel.ViewConverter.List.entireView": +// CustomGroupChannel.ViewConverter.List.entireView() case "CustomGroupChannel.ViewConverter.List.rowView": CustomGroupChannel.ViewConverter.List.rowView() case "CustomGroupChannel.ViewConverter.List.senderProfileImage": @@ -109,8 +113,8 @@ extension CustomSampleManager { case "CustomGroupChannel.ViewConverter.List.channelStateBanner": CustomGroupChannel.ViewConverter.List.channelStateBanner() case "CustomGroupChannel.ViewConverter.Input.entireView": - CustomGroupChannel.ViewConverter.Input.entireView() - case "CustomGroupChannel.ViewConverter.Input.leftView": +// CustomGroupChannel.ViewConverter.Input.entireView() +// case "CustomGroupChannel.ViewConverter.Input.leftView": CustomGroupChannel.ViewConverter.Input.leftView() case "CustomGroupChannel.ViewConverter.Input.addButton": CustomGroupChannel.ViewConverter.Input.addButton() @@ -140,8 +144,8 @@ extension CustomSampleManager { CustomOpenChannel.ViewConverter.Header.titleLabel() case "CustomOpenChannel.ViewConverter.Header.subtitleLabel": CustomOpenChannel.ViewConverter.Header.subtitleLabel() - case "CustomOpenChannel.ViewConverter.List.entireView": - CustomOpenChannel.ViewConverter.List.entireView() +// case "CustomOpenChannel.ViewConverter.List.entireView": +// CustomOpenChannel.ViewConverter.List.entireView() case "CustomOpenChannel.ViewConverter.List.rowView": CustomOpenChannel.ViewConverter.List.rowView() case "CustomOpenChannel.ViewConverter.List.senderProfileImage": @@ -155,10 +159,10 @@ extension CustomSampleManager { case "CustomOpenChannel.ViewConverter.List.scrollBottomView": CustomOpenChannel.ViewConverter.List.scrollBottomView() case "CustomOpenChannel.ViewConverter.Media.entireView": - CustomOpenChannel.ViewConverter.Media.entireView() - case "CustomOpenChannel.ViewConverter.Input.entireView": - CustomOpenChannel.ViewConverter.Input.entireView() - case "CustomOpenChannel.ViewConverter.Input.leftView": +// CustomOpenChannel.ViewConverter.Media.entireView() +// case "CustomOpenChannel.ViewConverter.Input.entireView": +// CustomOpenChannel.ViewConverter.Input.entireView() +// case "CustomOpenChannel.ViewConverter.Input.leftView": CustomOpenChannel.ViewConverter.Input.leftView() case "CustomOpenChannel.ViewConverter.Input.addButton": CustomOpenChannel.ViewConverter.Input.addButton() @@ -176,8 +180,8 @@ extension CustomSampleManager { CustomCreateGroupChannel.ViewConverter.Header.rightView() case "CustomCreateGroupChannel.ViewConverter.Header.titleView": CustomCreateGroupChannel.ViewConverter.Header.titleView() - case "CustomCreateGroupChannel.ViewConverter.List.entireView": - CustomCreateGroupChannel.ViewConverter.List.entireView() +// case "CustomCreateGroupChannel.ViewConverter.List.entireView": +// CustomCreateGroupChannel.ViewConverter.List.entireView() case "CustomCreateGroupChannel.ViewConverter.List.rowView": CustomCreateGroupChannel.ViewConverter.List.rowView() case "CustomCreateGroupChannel.ViewConverter.List.profileImage": @@ -196,8 +200,8 @@ extension CustomSampleManager { CustomCreateOpenChannel.ViewConverter.Header.rightView() case "CustomCreateOpenChannel.ViewConverter.Header.titleView": CustomCreateOpenChannel.ViewConverter.Header.titleView() - case "CustomCreateOpenChannel.ViewConverter.List.entireView": - CustomCreateOpenChannel.ViewConverter.List.entireView() +// case "CustomCreateOpenChannel.ViewConverter.List.entireView": +// CustomCreateOpenChannel.ViewConverter.List.entireView() case "CustomCreateOpenChannel.ViewConverter.List.rowView": CustomCreateOpenChannel.ViewConverter.List.rowView() case "CustomCreateOpenChannel.ViewConverter.List.profileImage": @@ -216,8 +220,8 @@ extension CustomSampleManager { CustomInviteUser.ViewConverter.Header.rightView() case "CustomInviteUser.ViewConverter.Header.titleView": CustomInviteUser.ViewConverter.Header.titleView() - case "CustomInviteUser.ViewConverter.List.entireView": - CustomInviteUser.ViewConverter.List.entireView() +// case "CustomInviteUser.ViewConverter.List.entireView": +// CustomInviteUser.ViewConverter.List.entireView() case "CustomInviteUser.ViewConverter.List.rowView": CustomInviteUser.ViewConverter.List.rowView() case "CustomInviteUser.ViewConverter.List.profileImage": @@ -236,8 +240,8 @@ extension CustomSampleManager { CustomGroupChannelRegisterOperator.ViewConverter.Header.rightView() case "CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView": CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView() - case "CustomGroupChannelRegisterOperator.ViewConverter.List.entireView": - CustomGroupChannelRegisterOperator.ViewConverter.List.entireView() +// case "CustomGroupChannelRegisterOperator.ViewConverter.List.entireView": +// CustomGroupChannelRegisterOperator.ViewConverter.List.entireView() case "CustomOpenChannelRegisterOperator.SwiftUI.View.Main": CustomOpenChannelRegisterOperator.SwiftUI.View.Main() case "CustomOpenChannelRegisterOperator.SwiftUI.View.CustomMain": @@ -248,8 +252,8 @@ extension CustomSampleManager { CustomOpenChannelRegisterOperator.ViewConverter.Header.rightView() case "CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView": CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView() - case "CustomOpenChannelRegisterOperator.ViewConverter.List.entireView": - CustomOpenChannelRegisterOperator.ViewConverter.List.entireView() +// case "CustomOpenChannelRegisterOperator.ViewConverter.List.entireView": +// CustomOpenChannelRegisterOperator.ViewConverter.List.entireView() case "CustomGroupMemberList.SwiftUI.View.Main": CustomGroupMemberList.SwiftUI.View.Main() case "CustomGroupMemberList.SwiftUI.View.CustomMain": @@ -262,8 +266,8 @@ extension CustomSampleManager { CustomGroupMemberList.ViewConverter.Header.rightView() case "CustomGroupMemberList.ViewConverter.Header.titleView": CustomGroupMemberList.ViewConverter.Header.titleView() - case "CustomGroupMemberList.ViewConverter.List.entireView": - CustomGroupMemberList.ViewConverter.List.entireView() +// case "CustomGroupMemberList.ViewConverter.List.entireView": +// CustomGroupMemberList.ViewConverter.List.entireView(provider: .init(channelURL: "")) case "CustomGroupMemberList.ViewConverter.List.rowView": CustomGroupMemberList.ViewConverter.List.rowView() case "CustomGroupMemberList.ViewConverter.List.profileImage": @@ -284,8 +288,8 @@ extension CustomSampleManager { CustomOpenParticipantList.ViewConverter.Header.rightView() case "CustomOpenParticipantList.ViewConverter.Header.titleView": CustomOpenParticipantList.ViewConverter.Header.titleView() - case "CustomOpenParticipantList.ViewConverter.List.entireView": - CustomOpenParticipantList.ViewConverter.List.entireView() +// case "CustomOpenParticipantList.ViewConverter.List.entireView": +// CustomOpenParticipantList.ViewConverter.List.entireView() case "CustomOpenParticipantList.ViewConverter.List.rowView": CustomOpenParticipantList.ViewConverter.List.rowView() case "CustomOpenParticipantList.ViewConverter.List.profileImage": @@ -306,8 +310,8 @@ extension CustomSampleManager { CustomGroupChannelPushSettings.ViewConverter.Header.rightView() case "CustomGroupChannelPushSettings.ViewConverter.Header.titleView": CustomGroupChannelPushSettings.ViewConverter.Header.titleView() - case "CustomGroupChannelPushSettings.ViewConverter.List.entireView": - CustomGroupChannelPushSettings.ViewConverter.List.entireView() +// case "CustomGroupChannelPushSettings.ViewConverter.List.entireView": +// CustomGroupChannelPushSettings.ViewConverter.List.entireView() case "CustomGroupChannelSettings.SwiftUI.View.Main": CustomGroupChannelSettings.SwiftUI.View.Main() case "CustomGroupChannelSettings.SwiftUI.View.CustomMain": @@ -324,8 +328,8 @@ extension CustomSampleManager { CustomGroupChannelSettings.ViewConverter.Header.rightView() case "CustomGroupChannelSettings.ViewConverter.Header.titleView": CustomGroupChannelSettings.ViewConverter.Header.titleView() - case "CustomGroupChannelSettings.ViewConverter.List.entireView": - CustomGroupChannelSettings.ViewConverter.List.entireView() +// case "CustomGroupChannelSettings.ViewConverter.List.entireView": +// CustomGroupChannelSettings.ViewConverter.List.entireView() case "CustomGroupChannelSettings.ViewConverter.List.channelInfo": CustomGroupChannelSettings.ViewConverter.List.channelInfo() case "CustomGroupChannelSettings.ViewConverter.List.moderation": @@ -352,8 +356,8 @@ extension CustomSampleManager { CustomOpenChannelSettings.ViewConverter.Header.rightView() case "CustomOpenChannelSettings.ViewConverter.Header.titleView": CustomOpenChannelSettings.ViewConverter.Header.titleView() - case "CustomOpenChannelSettings.ViewConverter.List.entireView": - CustomOpenChannelSettings.ViewConverter.List.entireView() +// case "CustomOpenChannelSettings.ViewConverter.List.entireView": +// CustomOpenChannelSettings.ViewConverter.List.entireView() case "CustomGroupModerations.SwiftUI.View.Main": CustomGroupModerations.SwiftUI.View.Main() case "CustomGroupModerations.SwiftUI.View.CustomMain": @@ -364,8 +368,8 @@ extension CustomSampleManager { CustomGroupModerations.ViewConverter.Header.rightView() case "CustomGroupModerations.ViewConverter.Header.titleView": CustomGroupModerations.ViewConverter.Header.titleView() - case "CustomGroupModerations.ViewConverter.List.entireView": - CustomGroupModerations.ViewConverter.List.entireView() +// case "CustomGroupModerations.ViewConverter.List.entireView": +// CustomGroupModerations.ViewConverter.List.entireView() case "CustomOpenModerations.SwiftUI.View.Main": CustomOpenModerations.SwiftUI.View.Main() case "CustomOpenModerations.SwiftUI.View.CustomMain": @@ -376,8 +380,8 @@ extension CustomSampleManager { CustomOpenModerations.ViewConverter.Header.rightView() case "CustomOpenModerations.ViewConverter.Header.titleView": CustomOpenModerations.ViewConverter.Header.titleView() - case "CustomOpenModerations.ViewConverter.List.entireView": - CustomOpenModerations.ViewConverter.List.entireView() +// case "CustomOpenModerations.ViewConverter.List.entireView": +// CustomOpenModerations.ViewConverter.List.entireView() case "CustomMessageSearch.SwiftUI.View.Main": CustomMessageSearch.SwiftUI.View.Main() case "CustomMessageSearch.SwiftUI.View.CustomMain": @@ -390,8 +394,8 @@ extension CustomSampleManager { CustomMessageSearch.ViewConverter.Header.rightView() case "CustomMessageSearch.ViewConverter.Header.titleView": CustomMessageSearch.ViewConverter.Header.titleView() - case "CustomMessageSearch.ViewConverter.List.entireView": - CustomMessageSearch.ViewConverter.List.entireView() +// case "CustomMessageSearch.ViewConverter.List.entireView": +// CustomMessageSearch.ViewConverter.List.entireView() case "CustomMessageThread.SwiftUI.View.Main": CustomMessageThread.SwiftUI.View.Main() case "CustomMessageThread.SwiftUI.View.CustomMain": @@ -406,8 +410,8 @@ extension CustomSampleManager { CustomMessageThread.ViewConverter.Header.titleLabel() case "CustomMessageThread.ViewConverter.Header.subtitleLabel": CustomMessageThread.ViewConverter.Header.subtitleLabel() - case "CustomMessageThread.ViewConverter.List.entireView": - CustomMessageThread.ViewConverter.List.entireView() +// case "CustomMessageThread.ViewConverter.List.entireView": +// CustomMessageThread.ViewConverter.List.entireView() case "CustomMessageThread.ViewConverter.List.rowView": CustomMessageThread.ViewConverter.List.rowView() case "CustomMessageThread.ViewConverter.List.senderProfileImage": @@ -443,8 +447,8 @@ extension CustomSampleManager { case "CustomMessageThread.ViewConverter.ParentInfo.reactionView": CustomMessageThread.ViewConverter.ParentInfo.reactionView() case "CustomMessageThread.ViewConverter.Input.entireView": - CustomMessageThread.ViewConverter.Input.entireView() - case "CustomMessageThread.ViewConverter.Input.leftView": +// CustomMessageThread.ViewConverter.Input.entireView() +// case "CustomMessageThread.ViewConverter.Input.leftView": CustomMessageThread.ViewConverter.Input.leftView() case "CustomMessageThread.ViewConverter.Input.addButton": CustomMessageThread.ViewConverter.Input.addButton() @@ -464,8 +468,8 @@ extension CustomSampleManager { CustomGroupMutedMemberList.ViewConverter.Header.rightView() case "CustomGroupMutedMemberList.ViewConverter.Header.titleView": CustomGroupMutedMemberList.ViewConverter.Header.titleView() - case "CustomGroupMutedMemberList.ViewConverter.List.entireView": - CustomGroupMutedMemberList.ViewConverter.List.entireView() +// case "CustomGroupMutedMemberList.ViewConverter.List.entireView": +// CustomGroupMutedMemberList.ViewConverter.List.entireView() case "CustomGroupMutedMemberList.ViewConverter.List.rowView": CustomGroupMutedMemberList.ViewConverter.List.rowView() case "CustomGroupMutedMemberList.ViewConverter.List.profileImage": @@ -486,8 +490,8 @@ extension CustomSampleManager { CustomGroupBannedUserList.ViewConverter.Header.rightView() case "CustomGroupBannedUserList.ViewConverter.Header.titleView": CustomGroupBannedUserList.ViewConverter.Header.titleView() - case "CustomGroupBannedUserList.ViewConverter.List.entireView": - CustomGroupBannedUserList.ViewConverter.List.entireView() +// case "CustomGroupBannedUserList.ViewConverter.List.entireView": +// CustomGroupBannedUserList.ViewConverter.List.entireView() case "CustomGroupBannedUserList.ViewConverter.List.rowView": CustomGroupBannedUserList.ViewConverter.List.rowView() case "CustomGroupBannedUserList.ViewConverter.List.profileImage": @@ -508,8 +512,8 @@ extension CustomSampleManager { CustomGroupOperatorList.ViewConverter.Header.rightView() case "CustomGroupOperatorList.ViewConverter.Header.titleView": CustomGroupOperatorList.ViewConverter.Header.titleView() - case "CustomGroupOperatorList.ViewConverter.List.entireView": - CustomGroupOperatorList.ViewConverter.List.entireView() +// case "CustomGroupOperatorList.ViewConverter.List.entireView": +// CustomGroupOperatorList.ViewConverter.List.entireView() case "CustomGroupOperatorList.ViewConverter.List.rowView": CustomGroupOperatorList.ViewConverter.List.rowView() case "CustomGroupOperatorList.ViewConverter.List.profileImage": @@ -528,8 +532,8 @@ extension CustomSampleManager { CustomOpenMutedParticipantList.ViewConverter.Header.rightView() case "CustomOpenMutedParticipantList.ViewConverter.Header.titleView": CustomOpenMutedParticipantList.ViewConverter.Header.titleView() - case "CustomOpenMutedParticipantList.ViewConverter.List.entireView": - CustomOpenMutedParticipantList.ViewConverter.List.entireView() +// case "CustomOpenMutedParticipantList.ViewConverter.List.entireView": +// CustomOpenMutedParticipantList.ViewConverter.List.entireView() case "CustomOpenMutedParticipantList.ViewConverter.List.rowView": CustomOpenMutedParticipantList.ViewConverter.List.rowView() case "CustomOpenMutedParticipantList.ViewConverter.List.profileImage": @@ -550,8 +554,8 @@ extension CustomSampleManager { CustomOpenBannedUserList.ViewConverter.Header.rightView() case "CustomOpenBannedUserList.ViewConverter.Header.titleView": CustomOpenBannedUserList.ViewConverter.Header.titleView() - case "CustomOpenBannedUserList.ViewConverter.List.entireView": - CustomOpenBannedUserList.ViewConverter.List.entireView() +// case "CustomOpenBannedUserList.ViewConverter.List.entireView": +// CustomOpenBannedUserList.ViewConverter.List.entireView() case "CustomOpenBannedUserList.ViewConverter.List.rowView": CustomOpenBannedUserList.ViewConverter.List.rowView() case "CustomOpenBannedUserList.ViewConverter.List.profileImage": @@ -570,8 +574,8 @@ extension CustomSampleManager { CustomOpenOperatorList.ViewConverter.Header.rightView() case "CustomOpenOperatorList.ViewConverter.Header.titleView": CustomOpenOperatorList.ViewConverter.Header.titleView() - case "CustomOpenOperatorList.ViewConverter.List.entireView": - CustomOpenOperatorList.ViewConverter.List.entireView() +// case "CustomOpenOperatorList.ViewConverter.List.entireView": +// CustomOpenOperatorList.ViewConverter.List.entireView() case "CustomOpenOperatorList.ViewConverter.List.rowView": CustomOpenOperatorList.ViewConverter.List.rowView() case "CustomOpenOperatorList.ViewConverter.List.profileImage": diff --git a/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager.swift b/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager.swift index 21c549b..89bd696 100644 --- a/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager.swift +++ b/Sample/QuickStartSwiftUI/CustomSampleManager/CustomSampleManager.swift @@ -7,13 +7,18 @@ // import UIKit -#if !SWIFTUI +#if !SWIFTUI && canImport(SendbirdUIKit) import SendbirdUIKit +#elseif canImport(SendbirdSwiftUI) +import SendbirdSwiftUI #endif import SendbirdChatSDK // MARK: Common class CustomSampleManager { + private static var groupChannelListQuery: GroupChannelListQuery? + private static var openChannelListQuery: OpenChannelListQuery? + /// (async) Gets the current user's latest group channel. @available(iOS 13.0, *) static func connectIfNeeded() async throws -> User { @@ -45,8 +50,8 @@ class CustomSampleManager { params.limit = 10 params.includeEmptyChannel = true - let channelListQuery = GroupChannel.createMyGroupChannelListQuery(params: params) - channelListQuery.loadNextPage { channels, error in + groupChannelListQuery = GroupChannel.createMyGroupChannelListQuery(params: params) + groupChannelListQuery?.loadNextPage { channels, error in guard error == nil else { print("Group channel list query error. \(error!.localizedDescription)") return @@ -132,8 +137,8 @@ class CustomSampleManager { let params = OpenChannelListQueryParams() params.limit = 10 - let channelListQuery = OpenChannel.createOpenChannelListQuery(params: params) - channelListQuery.loadNextPage { channels, error in + openChannelListQuery = OpenChannel.createOpenChannelListQuery(params: params) + openChannelListQuery?.loadNextPage { channels, error in guard error == nil else { print("Open channel list query error. \(error!.localizedDescription)") return diff --git a/Sample/QuickStartSwiftUI/CustomSampleManager/SampleListSwiftUI.json b/Sample/QuickStartSwiftUI/CustomSampleManager/SampleListSwiftUI.json index 4e70cce..9839275 100644 --- a/Sample/QuickStartSwiftUI/CustomSampleManager/SampleListSwiftUI.json +++ b/Sample/QuickStartSwiftUI/CustomSampleManager/SampleListSwiftUI.json @@ -44,6 +44,12 @@ "viewDesc": "SwiftUI", "viewFullPath": "CustomGroupChannelList.SwiftUI.View.CustomMain" }, + { + "viewTitle": "Provider Examples", + "viewType": "[View]", + "viewDesc": "ViewProvider", + "viewFullPath": "CustomGroupChannelList.SwiftUI.View.ViewProvider" + }, { "viewTitle": "groupChannel", "viewType": "[Builder]", @@ -74,12 +80,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupChannelList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupChannelList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -157,12 +157,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenChannelList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenChannelList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -204,6 +198,12 @@ "viewDesc": "SwiftUI", "viewFullPath": "CustomGroupChannel.SwiftUI.View.CustomMain" }, + { + "viewTitle": "Provider Examples", + "viewType": "[View]", + "viewDesc": "ViewProvider", + "viewFullPath": "CustomGroupChannel.SwiftUI.View.ViewProvider" + }, { "viewTitle": "channelSettings", "viewType": "[Builder]", @@ -252,12 +252,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupChannel.ViewConverter.Header.typingStatusView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupChannel.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -318,12 +312,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupChannel.ViewConverter.List.channelStateBanner" }, - { - "viewTitle": "entireView", - "viewType": "[Input]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupChannel.ViewConverter.Input.entireView" - }, { "viewTitle": "leftView", "viewType": "[Input]", @@ -419,12 +407,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenChannel.ViewConverter.Header.subtitleLabel" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenChannel.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -461,18 +443,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenChannel.ViewConverter.List.scrollBottomView" }, - { - "viewTitle": "entireView", - "viewType": "[Media]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenChannel.ViewConverter.Media.entireView" - }, - { - "viewTitle": "entireView", - "viewType": "[Input]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenChannel.ViewConverter.Input.entireView" - }, { "viewTitle": "leftView", "viewType": "[Input]", @@ -532,12 +502,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomCreateGroupChannel.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomCreateGroupChannel.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -597,12 +561,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomCreateOpenChannel.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomCreateOpenChannel.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -662,12 +620,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomInviteUser.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomInviteUser.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -727,12 +679,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupChannelRegisterOperator.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupChannelRegisterOperator.ViewConverter.List.entireView" - } ] }, { @@ -767,12 +713,6 @@ "viewType": "[Header]", "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenChannelRegisterOperator.ViewConverter.Header.titleView" - }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenChannelRegisterOperator.ViewConverter.List.entireView" } ] }, @@ -815,12 +755,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupMemberList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupMemberList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -886,12 +820,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenParticipantList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenParticipantList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -956,12 +884,6 @@ "viewType": "[Header]", "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupChannelPushSettings.ViewConverter.Header.titleView" - }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupChannelPushSettings.ViewConverter.List.entireView" } ] }, @@ -1016,12 +938,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupChannelSettings.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupChannelSettings.ViewConverter.List.entireView" - }, { "viewTitle": "channelInfo", "viewType": "[List]", @@ -1104,12 +1020,6 @@ "viewType": "[Header]", "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenChannelSettings.ViewConverter.Header.titleView" - }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenChannelSettings.ViewConverter.List.entireView" } ] }, @@ -1145,12 +1055,6 @@ "viewType": "[Header]", "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupModerations.ViewConverter.Header.titleView" - }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupModerations.ViewConverter.List.entireView" } ] }, @@ -1186,12 +1090,6 @@ "viewType": "[Header]", "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenModerations.ViewConverter.Header.titleView" - }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenModerations.ViewConverter.List.entireView" } ] }, @@ -1233,12 +1131,6 @@ "viewType": "[Header]", "viewDesc": "ViewConverter", "viewFullPath": "CustomMessageSearch.ViewConverter.Header.titleView" - }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomMessageSearch.ViewConverter.List.entireView" } ] }, @@ -1287,12 +1179,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomMessageThread.ViewConverter.Header.subtitleLabel" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomMessageThread.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -1395,12 +1281,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomMessageThread.ViewConverter.ParentInfo.reactionView" }, - { - "viewTitle": "entireView", - "viewType": "[Input]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomMessageThread.ViewConverter.Input.entireView" - }, { "viewTitle": "leftView", "viewType": "[Input]", @@ -1466,12 +1346,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupMutedMemberList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupMutedMemberList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -1537,12 +1411,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupBannedUserList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupBannedUserList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -1608,12 +1476,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomGroupOperatorList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomGroupOperatorList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -1673,12 +1535,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenMutedParticipantList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenMutedParticipantList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -1744,12 +1600,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenBannedUserList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenBannedUserList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", @@ -1809,12 +1659,6 @@ "viewDesc": "ViewConverter", "viewFullPath": "CustomOpenOperatorList.ViewConverter.Header.titleView" }, - { - "viewTitle": "entireView", - "viewType": "[List]", - "viewDesc": "ViewConverter", - "viewFullPath": "CustomOpenOperatorList.ViewConverter.List.entireView" - }, { "viewTitle": "rowView", "viewType": "[List]", diff --git a/Sample/QuickStartSwiftUI/Views/GroupChannelsView.swift b/Sample/QuickStartSwiftUI/Views/GroupChannelsView.swift index ef22ce8..199735b 100644 --- a/Sample/QuickStartSwiftUI/Views/GroupChannelsView.swift +++ b/Sample/QuickStartSwiftUI/Views/GroupChannelsView.swift @@ -12,46 +12,61 @@ struct GroupChannelsView: View { GroupChannelListView() .groupChannelView { channelURL, startingPoint, messageListParams in GroupChannelView( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams + provider: GroupChannelViewProvider( + channelURL: channelURL, + startingPoint: startingPoint, + messageListParams: messageListParams + ) ) .messageThreadView { channelURL, parentMessageId in - MessageThreadView(channelURL: channelURL, parentMessageId: parentMessageId) + MessageThreadView( + provider: MessageThreadViewProvider( + channelURL: channelURL, + parentMessageId: parentMessageId + ) + ) } .channelSettingsView { channelURL in - GroupChannelSettingsView(channelURL: channelURL) + GroupChannelSettingsView(provider: GroupChannelSettingsViewProvider(channelURL: channelURL)) .moderationsView { channelURL in - GroupModerationsView(channelURL: channelURL) + GroupModerationsView(provider: GroupModerationsViewProvider(channelURL: channelURL)) .bannedUserListView { channelURL in - GroupBannedUserListView(channelURL: channelURL) + GroupBannedUserListView(provider: GroupBannedUserListViewProvider(channelURL: channelURL)) } .mutedMemberListView { channelURL in - GroupMutedMemberListView(channelURL: channelURL) + GroupMutedMemberListView(provider: GroupMutedMemberListViewProvider(channelURL: channelURL)) } .operatorListView { channelURL in - GroupOperatorListView(channelURL: channelURL) + GroupOperatorListView(provider: GroupOperatorListViewProvider(channelURL: channelURL)) .registerOperatorView { channelURL in - GroupChannelRegisterOperatorView(channelURL: channelURL) + GroupChannelRegisterOperatorView( + provider: GroupChannelRegisterOperatorViewProvider(channelURL: channelURL) + ) } } } .pushSettingsView { channelURL in - GroupChannelPushSettingsView(channelURL: channelURL) + GroupChannelPushSettingsView( + provider: GroupChannelPushSettingsViewProvider(channelURL: channelURL) + ) } .memberListView { channelURL in - GroupMemberListView(channelURL: channelURL) + GroupMemberListView(provider: GroupMemberListViewProvider(channelURL: channelURL)) .inviteUserView { channelURL in - InviteUserView(channelURL: channelURL) + InviteUserView(provider: InviteUserViewProvider(channelURL: channelURL)) } } .messageSearchView { channelURL in - MessageSearchView(channelURL: channelURL) + MessageSearchView( + provider: MessageSearchViewProvider(channelURL: channelURL) + ) } } } .createChannelView { users, type in - CreateGroupChannelView(users: users, type: type) + CreateGroupChannelView( + provider: CreateGroupChannelViewProvider(customUsers: users, type: type) + ) } } } diff --git a/Sample/QuickStartSwiftUI/Views/OpenChannelsView.swift b/Sample/QuickStartSwiftUI/Views/OpenChannelsView.swift index d1aa825..8c7913d 100644 --- a/Sample/QuickStartSwiftUI/Views/OpenChannelsView.swift +++ b/Sample/QuickStartSwiftUI/Views/OpenChannelsView.swift @@ -11,27 +11,34 @@ struct OpenChannelsView: View { var body: some View { OpenChannelListView() .openChannelView { channelURL, messageListParams in - OpenChannelView(channelURL: channelURL, messageListParams: messageListParams) + OpenChannelView( + provider: OpenChannelViewProvider( + channelURL: channelURL, + messageListParams: messageListParams + ) + ) .channelSettingsView { channelURL in - OpenChannelSettingsView(channelURL: channelURL) + OpenChannelSettingsView( + provider: OpenChannelSettingsViewProvider(channelURL: channelURL) + ) .moderationsView { channelURL in - OpenModerationsView(channelURL: channelURL) + OpenModerationsView(provider: OpenModerationsViewProvider(channelURL: channelURL)) .bannedUserListView { channelURL in - OpenBannedUserListView(channelURL: channelURL) + OpenBannedUserListView(provider: OpenBannedUserListViewProvider(channelURL: channelURL)) } .mutedParticipantListView { channelURL in - OpenMutedParticipantListView(channelURL: channelURL) + OpenMutedParticipantListView(provider: OpenMutedParticipantListViewProvider(channelURL: channelURL)) } .operatorListView { channelURL in - OpenOperatorListView(channelURL: channelURL) + OpenOperatorListView(provider: OpenOperatorListViewProvider(channelURL: channelURL)) } } .participantListView { channelURL in - OpenParticipantListView(channelURL: channelURL) + OpenParticipantListView(provider: OpenParticipantListViewProvider(channelURL: channelURL)) } } .participantListView { channelURL in - OpenParticipantListView(channelURL: channelURL) + OpenParticipantListView(provider: OpenParticipantListViewProvider(channelURL: channelURL)) } } .createChannelView { diff --git a/Sample/README.md b/Sample/README.md deleted file mode 100644 index 4a31965..0000000 --- a/Sample/README.md +++ /dev/null @@ -1,34 +0,0 @@ -# Sendbird Chat SwiftUI Sample -Sendbird Chat SwiftUI is a development kit with a declarative user interface, enabling easy and fast integration of standard chat features into new or existing client apps. This repository contains a sample app demonstrating the use of Sendbird Chat SwiftUI. -Learn more about Sendbird Chat SwiftUI in the [documentation](https://sendbird.com/docs/chat/uikit/v3/swiftui/overview). For assistance or questions, visit [our community](https://community.sendbird.com). - -## Screenshots -![Screenshot](screenshots/screenshots.png) - -## How to Use the Sample App - -### 1. Clone the Repository - -```bash -git clone git@github.com:sendbird/sendbird-swiftui-ios.git -``` - -### 2. Open in Xcode - -Navigate to the sendbird-swiftui-ios/Sample directory and open it in Xcode. Make sure to open the sendbird-swiftui-ios/Sample/Sample.xcodeproj file. - -### 3. Run the Sample App -Run the sample app on your simulator or device. - -![Sample Screenshot](screenshots/run_sample.png) - -### 4. Test with Your Data -Sample Screenshot - -For user ID and nickname, you can enter any values you like. The app will run in guest mode. - -> Note: Avoid using guest mode in production. - -## Customize with Your Data - -To tailor the sample app to your needs, replace the default app ID with your own. You can obtain this by [creating a Sendbird application from the dashboard](https://dashboard.sendbird.com). You can also add your own data on the dashboard to test, allowing you to experience the app with data from your Sendbird application. \ No newline at end of file diff --git a/Sample/project.yml b/Sample/project.yml index 032ed60..f009505 100644 --- a/Sample/project.yml +++ b/Sample/project.yml @@ -12,7 +12,7 @@ options: packages: SendbirdChatSDK: url: https://github.com/sendbird/sendbird-chat-sdk-ios - from: 4.21.1 + from: 4.23.1 schemes: QuickStartSwiftUI: @@ -41,7 +41,7 @@ settingGroups: FRAMEWORK_SEARCH_PATHS: '' IPHONEOS_DEPLOYMENT_TARGET: '15.0' LD_RUNPATH_SEARCH_PATHS: ["$(inherited)", "@executable_path/Frameworks", "@loader_path/Frameworks"] - MARKETING_VERSION: '1.0.0-beta.3' + MARKETING_VERSION: '1.0.0' PRODUCT_NAME: "$(TARGET_NAME)" SDKROOT: iphoneos SWIFT_VERSION: '5.0' diff --git a/Sample/screenshots/run_sample.png b/Sample/screenshots/run_sample.png deleted file mode 100644 index 55f78befae597ce2b21a563357e1eb54d8c25d76..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 52619 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%0DT$dy7}nK0VNr^&mfz8(tKOC3syvl_h3-j?K5%0 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 diff --git a/Sample/screenshots/screenshots.png b/Sample/screenshots/screenshots.png deleted file mode 100644 index 620e3d6cdff159f08ff85ef59de0db7e79d968f3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 516271 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: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 z z=qq$ zUbwPOqD@~=)?j?+{L4IQkdoj2!}fb(Qf>G9a{8;%HMWA|t>$kAa;UZZ9xj*T?MyXd zeZB~ttlV@hC(?ItAJUyeU^O+pWL1($InEImn~g7jm^tq3&Yr5HPN?of9D5L;=JYLV z8Sw67aI@ks5IaD@E-;E>oE;F&;u!DNg&#^_na{%BJ?Hv3AgiSK8d3y6a)EBqpcmL= zIiRjy8oIWr+Q8LdF!F;@ytQzI+3u&=PcxcV=qWK>mrM39m<1w~kgCAMAhJw#otB3d zPoPFyotz1moPM;5QEu>)7g6RzHZ@a6YLPU-_5z&?AI8B<&R*=!3MaTi7i13uKsln_BcJQm2Tx*dB2|hU>m!tm*?9L$c4- zl6iX-WrNVNfbnR_ouyr2wAh9m%(RS4&P8fpDFF3wE- z%iyMF98F9iR)m<+i{GDG>HhN52~HIBF$Bg8QbpZ)Umux>X>J!fFL6g$sA)hwr_)88 zV1siPXNO`$ux}(mLk1*nt}4T2xUQ~i$Fbd>JkShg2B(|P<(%_*kPGU2NeZSRru<|i z02~|}6ykKZQaAc5?$Nulz%{!6* z>vqE@FA>)lcgvZTAdandRzkB!VRuKIr4bJVI!?qi#h9|}B7Ha^UzYUaic1!_ME1Q zcJf1oY$WEPOWWv016-H#(m9L69j1bBB;QW*+Z#6%9cyTegMbv)z1t|xMhe( zbg1VGQZSdiw_7`4cN8NpXs1i)ta+)F-NXTp&=eHQyxYq}_Rq1$P#&6}}u$ zFuZBPi!`4b3fW{@c}SnP8YPS}?81;ZjhZJ8ZYvOZxJ{rl54DJXu}{XFj;TRwrS+hL z_3f}h|5l!t|5tf7QLB?Z)2TiwCpf{jrcOMesFN=a{mXYH)=26u6=N;#qJ2CeL$){F zLX3R-mFB>M!k~u(E*FP0>L)WZguM45hvl!ZJYf~&e(Bz9{47eOBWlf0+|-c8k40$B zR^{Lq->YpM9~ho`Uni$Ko}+_<_1 zIJaFzs4*$$UuZxXM`-Ra4L} zWwioLU?bwXUFHk64`AX6xQuNK+|l>gNNKMXFbvQX+v;aZT7;{c&NZmxr_W^xUaR+1 zeO8X2)kg0{rLfFNm3~mAQfk>enDyzsChc?3k!LR)Cb2CvHuk^ML2H43r-KLhffO-7 z?aug_k}c*GPeGJSboEP~_0;9#%VQ={p8lB};we>V3F;lA4PyAz!3{wH1e^~!x!bwo z8(Ob;HOdy-KV{sJBy66>@#JdT9~r|;;f+wxAOcrNnYjFIL9y$%?zgY^vT`5Wn=cq0 z9d+Q57C(6({kUXhM51yA!!o$`d-nc7*>PXRj~^|EvNej#tDVD=BInoyot~<6QWTlK zoZ?Fp(7|P74jj37KOyq-AEwWg{^r_~tJMTTXI{sL`GEs3caiPT&EB_fOMYY?`z0b; zdIaW2SH>tO6Cr~KuhUCzAz%Ad?Xp0S?PY$>lHb4IOc-ghb0%OUx7vv7c@GXl( zQp$<5zwQTF)yuYiX)%G9olKid;Ci`8UdPX1y3v4R>{`q#(=EBxjbyd{qCV%}OJFgsNnEQ7z4}`1$7Ln@Q*%vpsq|pN6W&h4WY&e6{@|Us5?bn! zbwzPjD64<@T-hgb9|ZX|Jn$Yi*sjx)k{KY@YydsZ4!09C`-wAWh1Xe!P(sc?`!xBH zZ%;aslW9Ze%`4XOBBx@%cW`>>@2yh#9UKZm&YL-eecw&Gr*s@W1-*Fj?81EAa<`OA z##Y5oQ?&V^>$$Seea?zIvP>;rD8tXj8&HyjDlf2+s+WF{IN&IfL#=-NF(488@pVf{ z)`Vn>b&iMVsj~EaGJSA)CqvNWwUtkxAS=007h8S_4o6J9(kwU0J<`v=K0 zgO?`m#{>p-MtDchs6qQ0fOe>p;Yz4+cmb1~T_%|=jQ4}Ox}yD=0x7|5giZw}V&*ZX zLigrXw;J?Q(UI*9x`I#0`){V^|D6RJIf-hD-l7 zgPECwZYKpe=5ByamJfNboc1Eq%-eebfo)%-BrA8uZoWBOu*R~#fAZw!-LqUchB>rK z{s!{tPxsEJ?QW>eny<7Y21c_7`$NivpbB6mJ>kNS%)nLgMae?V9!2d(I+A$+%sO`0 z4-QaMK74l=*$8^8kHtv)rwWsIWjDp7ecW_heNKbRXObwUu)@T_w{s<~Y+llqOE;4T zm2qlvNfs5Levx%zGP)t_ZKV{ZowF|`Tm!InodB6c|Jx*)gLFjcN9IR86uc2B z$^j2lLHYDNETo;I$(}lbx%u-hd*3MzxH$MJ!1eT$THEUscUibG>v@)|7S}Xiu!+Gr zNa4Bz_+0ToxpYnzbPKMwVT$UTPPpG}kuTrT_*B1HD`*YI@R%|mZTyJ-gz0Zv0T3ns zZ7U7|2Nti8S$U7GS3JS>rdV9H4s29Hv%TR}iX~icJWV%Hl%$T=21hcwB=w%v;Q`cKY>ISynl%&SkuvfMxwj*l$KCL4< zJA0T@H0hYl&w-^U7ceN3UH*}CS$JTUUhkvqn0rKDU{6*!R{4`Cs-rM9)_QkC9^}_+CWh!%3t(hW~D2z&kZ)qWI2Q`9FxNV~f8kx|;02c1ePC5c4 zd*RMFku$u=FtZwR%M>n_WU=z_{e?RXl*5oc{qM{ZDK;MbSZX$z$xqwf(sTT(b{4+ zw8d6mzlpvlg=teM+V~;2H)Tn&Tfh^XAlOvw(sLOls8)`OJf^L$Z8R(l(Yg2QV`PES z2{3Jmz7Qql!HZ1T-+kv1)9sO9HtAw0Y99HtC3k=8gCgaoGaLNQ)jZ_Sa9}p+k+(-; z65UL7ldV+F2vR7aLUa0yS}m`Or_HxF-$A5pY*5@@P9vF1VmpdLnIH zM+T#I4^w~K*Ou7~#M=DKlqPuH9~^XV#cNfn07)}5i{upvoG-KYOkTp zArV+;-_2=_o8)?{r*!A$WpF7MRneS%b5gBR-sqJ~?KF_CdFPh>md8=-iYl)?;BD-R z#?fp>LvJkcSvtaXDUEf4s7dU+%8JlQQ@u`#1ky4C#|0;uLO~Hn8Y7#>y!H7Bdu3-x zq<+V=hzSuJ4&TGjK=grQaQ%g7s$Cep*XXd#qLx4hLG3sqf~I5AIqSB~bomhp_~XoAAd$dMy28s&VvZkUr>qT| z@gQM2w1a0EzM%{0A{ZM=()|`{APRHs8;An9mMc2~P*jixZq`pdrg&)>MU|DZHoDT8 zu>C*|(-kIOT}Wd{2n$iCsB*L0DFzpO_gw@9l$UDh`5cb^xkoQz)jDIIv|Cb=z=L!c z-KvZyxI>O+g@6^hX#=+th+(pc6hOZ9&5b7zD=lzKJ0}$Lt-Gh4sC{Wfb+}8dBs1`m!GookRsGjUciOW~N(2kvBWF0H*X_ z7`6_UcQC)$DGn3 zar9$#e=w2l@dqoa;}N4Tx= z z|Mtx&Ne&c z`k+vLzE-{@X1(|_p@4kS@GQr;QbEE`*m-$Y5xAdxsOW8twPoQt>7{pcf}_7$ka<1W zv@+*&km3}ADV#r?tE8%)j&KM*B`vK?Pw?Gh%CjHzF_Q;&pe1}q$5{nOI|`VB69P`; zM-T*2BD{y+=sCTBkQQP3eclyos5Ttfy-PZr+kN5t%2QJ)agpu180khjwBCfGj=Us@ zPlKKDQe_K1(@^lbK4dKp=eWaF-ka)7R+0W`_3t4^{_l_>j|O<`|)7 zqS4-uGu8#z;K<pmseJb=I{g~uC*_dHTc!zFHNp77mBouj37 z6C#pRDC4dBgaX$(v(ayTyNH8 zjGDJob}ir&Yl4u7q?yEzT}gd%0D?8^m6=ZKs+cx#J%JQN@PD}m2}fbPR0ruBVDROk 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 diff --git a/SendbirdSwiftUI.podspec b/SendbirdSwiftUI.podspec index 45bad60..94df393 100644 --- a/SendbirdSwiftUI.podspec +++ b/SendbirdSwiftUI.podspec @@ -1,6 +1,6 @@ Pod::Spec.new do |s| s.name = "SendbirdSwiftUI" - s.version = "1.0.0-beta.3" + s.version = "1.0.0" s.summary = "Sendbird SwiftUI SDK based on SendbirdChatSDK" s.description = "SendbirdSwiftUI is a framework composed of basic UI components based on SwiftUI and SendbirdChatSDK." s.homepage = "https://sendbird.com" @@ -16,10 +16,10 @@ Pod::Spec.new do |s| "Kai" => "kai.lee@sendbird.com" } s.platform = :ios, "15.0" - s.source = { :http => "https://github.com/sendbird/sendbird-swiftui-ios/releases/download/#{s.version}/SendbirdSwiftUI.zip", :sha1 => "3e47dcb7216206c266a4e23b310a8a48334b7483" } + s.source = { :http => "https://github.com/sendbird/sendbird-swiftui-ios/releases/download/#{s.version}/SendbirdSwiftUI.zip", :sha1 => "00608fa56dfb8735ab2f98a39780fc3b0bdfa665" } s.ios.vendored_frameworks = 'SendbirdSwiftUI/SendbirdSwiftUI.xcframework' s.ios.frameworks = ["UIKit", "SwiftUI", "Foundation", "CoreData", "SendbirdChatSDK"] s.requires_arc = true - s.dependency "SendbirdChatSDK", ">= 4.21.1" + s.dependency "SendbirdChatSDK", ">= 4.23.1" s.ios.library = "icucore" end diff --git a/Sources/Info.plist b/Sources/Info.plist deleted file mode 100644 index 08ce33c..0000000 --- a/Sources/Info.plist +++ /dev/null @@ -1,24 +0,0 @@ - - - - - CFBundleDevelopmentRegion - $(DEVELOPMENT_LANGUAGE) - CFBundleExecutable - $(EXECUTABLE_NAME) - CFBundleIdentifier - $(PRODUCT_BUNDLE_IDENTIFIER) - CFBundleInfoDictionaryVersion - 6.0 - CFBundleName - $(PRODUCT_NAME) - CFBundlePackageType - $(PRODUCT_BUNDLE_PACKAGE_TYPE) - CFBundleShortVersionString - $(MARKETING_VERSION) - CFBundleVersion - $(CURRENT_PROJECT_VERSION) - SBUAppVersion - $(SBU_APP_VERSION) - - diff --git a/Sources/SwiftUI/Common/Sendbird+Typealias.swift b/Sources/SwiftUI/Common/Sendbird+Typealias.swift new file mode 100644 index 0000000..f9d8499 --- /dev/null +++ b/Sources/SwiftUI/Common/Sendbird+Typealias.swift @@ -0,0 +1,12 @@ +// +// Sendbird+Typealias.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/21/24. +// + +import Foundation +import SendbirdChatSDK + +public typealias SendbirdConnectionStateChangeHandler = (_ isConnected: Bool) -> Void +public typealias SendbirdErrorHandler = (_ error: SBError?) -> Void diff --git a/Sources/SwiftUI/Internal/Protocol/SendbirdUIProvider.swift b/Sources/SwiftUI/Internal/Protocol/SendbirdUIProvider.swift new file mode 100644 index 0000000..4a95991 --- /dev/null +++ b/Sources/SwiftUI/Internal/Protocol/SendbirdUIProvider.swift @@ -0,0 +1,20 @@ +// +// SendbirdUIProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/21/24. +// + +import Foundation +import UIKit +import SwiftUI + +protocol SendbirdUIProvider: ObservableObject { + associatedtype ViewController: UIViewController + associatedtype EventHandlers + var eventHandlers: EventHandlers { get set } + var viewController: ViewController? { get set } + + /// Binds the provider with its corresponding view controller & view model. + func bind(viewController: ViewController) +} diff --git a/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelView.swift b/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelView.swift index 5624c43..7ec8252 100644 --- a/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelView.swift +++ b/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelView.swift @@ -16,17 +16,25 @@ public struct CreateGroupChannelView: View { var configurations: [(SBUCreateChannelViewController) -> Void] = [] - private var users: [SBUUser]? - private var type: ChannelCreationType = .group + @ObservedObject private var provider: CreateGroupChannelViewProvider - // MARK: - Methods - public init() {} + public init() { + self.provider = CreateGroupChannelViewProvider() + } public var body: some View { SBUViewControllerSet.CreateChannelViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + users: self.provider.customUsers + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -41,15 +49,25 @@ public struct CreateGroupChannelView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.CreateGroupChannel = CreateGroupChannelViewConverter() + } } - + + // MARK: - Methods private func createViewController() -> SBUCreateChannelViewController { let viewController = SBUViewControllerSet.CreateChannelViewController.init( - users: self.users, - type: self.type + users: self.provider.customUsers, + type: self.provider.type ) + self.provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUCreateChannelViewController) -> Bool { + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,13 +77,11 @@ public extension CreateGroupChannelView { typealias ListContent = CreateGroupChannelViewConverter.List init( - users: [SBUUser]? = nil, - type: ChannelCreationType = .group, + provider: CreateGroupChannelViewProvider? = nil, headerItem: (() -> CreateGroupChannelType.HeaderItem)? = nil, listItem: (() -> CreateGroupChannelType.ListItem)? = nil ) { - self.users = users - self.type = type + self.provider = provider ?? CreateGroupChannelViewProvider() if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -74,14 +90,13 @@ public extension CreateGroupChannelView { self.applyViewConverterSet() } - init( - users: [SBUUser]? = nil, - type: ChannelCreationType = .group, + // TODO: After entire content is implemented + internal init( + provider: CreateGroupChannelViewProvider? = nil, headerItem: (() -> CreateGroupChannelType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content - ) { - self.users = users - self.type = type + ) { + self.provider = provider ?? CreateGroupChannelViewProvider() typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -98,6 +113,21 @@ public extension CreateGroupChannelView { } } +// MARK: Event handler interfaces +public extension CreateGroupChannelView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { CreateGroupChannelView() diff --git a/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelViewProvider.swift b/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelViewProvider.swift new file mode 100644 index 0000000..2e7eacf --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/CreateGroupChannel/CreateGroupChannelViewProvider.swift @@ -0,0 +1,159 @@ +// +// CreateGroupChannelViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: - ViewEventHandlers +public struct CreateGroupChannelEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - CreateGroupChannelViewProvider +public class CreateGroupChannelViewProvider: SendbirdUIProvider { + // init properties + var customUsers: [SBUUser]? + var type: ChannelCreationType = .group + + // SendbirdUIProvider properties + weak var viewController: SBUCreateChannelViewController? + var eventHandlers = CreateGroupChannelEventHandlers() + + // MARK: Public Data Properties + /// User list + @Published public var users: [SBUUser] = [] + + /// Selected users + @Published public var selectedUsers: [SBUUser] = [] + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + customUsers: [SBUUser]? = nil, + type: ChannelCreationType = .group + ) { + self.type = type + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + customUsers: [SBUUser]? = nil, + type: ChannelCreationType? = nil + ) -> Self { + if let customUsers { self.customUsers = customUsers } + if let type { self.type = type } + return self + } + + func bind(viewController: SBUCreateChannelViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// Create a channel with selected users. + public func createChannelWithSelectedUsers() { + self.viewController?.createChannelWithSelectedUsers() + } + + /// Creates the channel with channelParams. + /// + /// You can create a channel by setting various properties of ChannelParams. + /// - Parameters: + /// - params: `GroupChannelCreateParams` class object + /// - messageListParams: If there is a messageListParams set directly for use in Channel, set it up here + public func createChannel( + params: GroupChannelCreateParams, + messageListParams: MessageListParams? = nil + ) { + self.viewController?.viewModel?.createChannel( + params: params, + messageListParams: messageListParams + ) + } + + /// Load the user list. + /// - Parameters: + /// - customUsers: Custom user list to load (optional) + public func loadNextUserList(customUsers: [SBUUser]?) { + self.viewController?.viewModel?.loadNextUserList( + reset: false, + users: customUsers + ) + } + + /// Resets the user list. + public func resetUserList() { + self.viewController?.viewModel?.resetUserList() + } +} + +// MARK: - ViewEventDelegate +extension CreateGroupChannelViewProvider: SBUCreateChannelViewModelDelegate { + public func createChannelViewModel( + _ viewModel: SBUCreateChannelViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.users = users + } + } + + /// Called when it has created channel with `MessageListParams` object. + public func createChannelViewModel( + _ viewModel: SBUCreateChannelViewModel, + didCreateChannel channel: BaseChannel?, + withMessageListParams messageListParams: MessageListParams? + ) { } + + /// Called when the selected users has been updated. + public func createChannelViewModel( + _ viewModel: SBUCreateChannelViewModel, + didUpdateSelectedUsers selectedUsers: [SBUUser] + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.selectedUsers = selectedUsers + } + } +} + +// MARK: - ViewModelDelegate +extension CreateGroupChannelViewProvider: CreateGroupChannelViewEventDelegate { + func createGroupChannelView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +extension CreateGroupChannelViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +// MARK: - ViewModelDelegate (default implementation) +extension SBUCreateChannelViewModelDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelView.swift b/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelView.swift index 547bc76..9025d53 100644 --- a/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelView.swift +++ b/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelView.swift @@ -16,14 +16,23 @@ public struct CreateOpenChannelView: View { var configurations: [(SBUCreateOpenChannelViewController) -> Void] = [] - // MARK: - Methods - public init() {} + @ObservedObject private var provider: CreateOpenChannelViewProvider + + public init() { + self.provider = CreateOpenChannelViewProvider() // Default provider + } public var body: some View { SBUViewControllerSet.CreateOpenChannelViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + // Nothing to load + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,13 +47,22 @@ public struct CreateOpenChannelView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.CreateOpenChannel = CreateOpenChannelViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUCreateOpenChannelViewController { - let viewController = SBUViewControllerSet.CreateOpenChannelViewController.init( - ) + let viewController = SBUViewControllerSet.CreateOpenChannelViewController.init() + // Connect provider <-> VC, VM + self.provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUCreateOpenChannelViewController) -> Bool { + return true + } } // MARK: - Initializers @@ -56,16 +74,20 @@ public extension CreateOpenChannelView { // (↓↓ example ↓↓) init( + provider: CreateOpenChannelViewProvider? = nil, headerItem: (() -> CreateOpenChannelType.HeaderItem)? = nil ) { + self.provider = provider ?? CreateOpenChannelViewProvider() // Default provider + if let headerItem { _ = headerItem() } // TODO: SwiftUI - header 외 요소 추가 필요 // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -87,6 +109,16 @@ public extension CreateOpenChannelView { // } } +// MARK: Event handler interfaces +public extension CreateOpenChannelView { + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + + #Preview { NavigationView { CreateOpenChannelView() diff --git a/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelViewProvider.swift b/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelViewProvider.swift new file mode 100644 index 0000000..5e9f8c4 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/CreateOpenChannelViewProvider.swift @@ -0,0 +1,75 @@ +// +// CreateOpenChannelViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: - ViewEventHandlers +public struct CreateOpenChannelEventHandlers { + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - CreateOpenChannelViewProvider +public class CreateOpenChannelViewProvider: SendbirdUIProvider { + // init properties + + // SendbirdUIProvider properties + weak var viewController: SBUCreateOpenChannelViewController? + var eventHandlers = CreateOpenChannelEventHandlers() + + // MARK: Public Data Properties + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init() {} + + /// This function sets up the provider. + @discardableResult + internal func setup() -> Self { + return self + } + + func bind(viewController: SBUCreateOpenChannelViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + public func createChannel(params: OpenChannelCreateParams) { + self.viewController?.viewModel?.createChannel(params: params) + } +} + +// MARK: - ViewEventDelegate +extension CreateOpenChannelViewProvider: CreateOpenChannelViewEventDelegate { +} + +// MARK: - ViewModelDelegate +extension CreateOpenChannelViewProvider: SBUCreateOpenChannelViewModelDelegate { +} + +extension CreateOpenChannelViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +// MARK: - ViewModelDelegate (default implementation) +extension SBUCreateOpenChannelViewModelDelegate { + public func createOpenChannelViewModel(_ viewModel: SBUCreateOpenChannelViewModel, didCreateChannel channel: SendbirdChatSDK.BaseChannel?) { } +} diff --git a/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/ViewConverters/SBUCreateOpenChannelModule.Header+SwiftUI.swift b/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/ViewConverters/SBUCreateOpenChannelModule.Header+SwiftUI.swift index 0e904ca..75145b7 100644 --- a/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/ViewConverters/SBUCreateOpenChannelModule.Header+SwiftUI.swift +++ b/Sources/SwiftUI/KeyFunctions/CreateOpenChannel/ViewConverters/SBUCreateOpenChannelModule.Header+SwiftUI.swift @@ -46,6 +46,7 @@ extension SBUCreateOpenChannelModule.Header { return true } else { self.rightBarButton = self.defaultRightBarButton + self.rightBarButton?.isEnabled = false return false } case .titleView: diff --git a/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListView.swift b/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListView.swift index 5d8c389..16f9113 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListView.swift @@ -15,16 +15,30 @@ public struct GroupBannedUserListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupBannedUserListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: GroupBannedUserListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .group, + users: self.provider.customUsers, + userListType: .banned + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,27 @@ public struct GroupBannedUserListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupBannedUserList = GroupBannedUserListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.GroupUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .group, - users: self.users, + users: self.provider.customUsers, userListType: .banned ) return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,21 +83,11 @@ public extension GroupBannedUserListView { typealias ListContent = GroupBannedUserListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: GroupBannedUserListViewProvider, headerItem: (() -> GroupBannedUserListType.HeaderItem)? = nil, listItem: (() -> GroupBannedUserListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +96,13 @@ public extension GroupBannedUserListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: GroupBannedUserListViewProvider, headerItem: (() -> GroupBannedUserListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +119,23 @@ public extension GroupBannedUserListView { } } +// MARK: Event handler interfaces +public extension GroupBannedUserListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - GroupBannedUserListView(channelURL: "") + GroupBannedUserListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListViewProvider.swift new file mode 100644 index 0000000..647e526 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupBannedUserList/GroupBannedUserListViewProvider.swift @@ -0,0 +1,150 @@ +// +// GroupBannedUserListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct GroupBannedUserListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - GroupBannedUserListViewProvider +public class GroupBannedUserListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = GroupBannedUserListViewEventHandlers() + + // MARK: Public Data Properties + /// Banned user list + @Published public var bannedUsers: [SBUUser] = [] + + /// Channel object + @Published public var channel: GroupChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the banned user list. + public func loadNextBannedUserList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the user list. + public func resetBannedUserList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function bans the user. + public func ban(user: SBUUser) { + self.viewController?.viewModel?.ban(user: user) + } + + /// This function unbans the user. + public func unban(user: SBUUser) { + self.viewController?.viewModel?.unban(user: user) + } +} + +// MARK: - ViewEventDelegate +extension GroupBannedUserListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension GroupBannedUserListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.bannedUsers = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? GroupChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension GroupBannedUserListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelProvider.swift new file mode 100644 index 0000000..f1c5032 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelProvider.swift @@ -0,0 +1,297 @@ +// +// GroupChannelViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/21/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct GroupChannelViewEventHandlers { + // Internal state event handlers. + var errorHandler: SendbirdErrorHandler? + var connectionStateChangeHandler: SendbirdConnectionStateChangeHandler? +} + +public class GroupChannelViewProvider: SendbirdUIProvider { + public private(set) var channelURL: String + public private(set) var startingPoint: Int64? + var messageListParams: MessageListParams? + + weak var viewController: SBUGroupChannelViewController? + var eventHandlers = GroupChannelViewEventHandlers() + + // MARK: Published properties + @Published public var channel: GroupChannel? + @Published public var fullMessages: [BaseMessage] = [] + @Published public var isLoading: Bool = false + @Published public var newMessagesCount: Int = 0 + @Published public var messageInputText: String? + + // MARK: Computed properties + public var hasNext: Bool { + self.viewController?.viewModel?.hasNext() ?? false + } + + public var hasPrevious: Bool { + self.viewController?.viewModel?.hasPrevious() ?? false + } + + public var highlightInfo: SBUHighlightMessageInfo? { + self.viewController?.highlightInfo + } + + // MARK: Private properties + fileprivate var messageInputView: SBUMessageInputView? { self.viewController?.inputComponent?.messageInputView as? SBUMessageInputView + } + + fileprivate var viewModel: SBUGroupChannelViewModel? { + self.viewController?.viewModel + } + + public init( + channelURL: String, + startingPoint: Int64? = nil, + messageListParams: MessageListParams? = nil + ) { + self.channelURL = channelURL + self.startingPoint = startingPoint + self.messageListParams = messageListParams + } + + public func setup( + channelURL: String, + startingPoint: Int64? = nil, + messageListParams: MessageListParams? = nil + ) { + self.channelURL = channelURL + if let startingPoint { self.startingPoint = startingPoint } + if let messageListParams { self.messageListParams = messageListParams } + } + + func bind(viewController: SBUGroupChannelViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +// MARK: - Method Wrappers +public extension GroupChannelViewProvider { + // View Controller Methods + func showChannelSettings() { + self.viewController?.showChannelSettings() + } + + func showMessageThread( + parentMessageId: Int64, + parentMessageCreatedAt: Int64, // 기존 인터페이스는 default 0인데, 그러면 작동X. default 없는게 사용할때 더 명확한듯. + startingPoint: Int64? = 0 + ) { + self.viewController?.showMessageThread( + channelURL: self.channelURL, + parentMessageId: parentMessageId, + parentMessageCreatedAt: parentMessageCreatedAt, + startingPoint: startingPoint + ) + } + + /// Ends the typing mode of the Input View. + func endTypingMode() { + messageInputView?.endTypingMode() + } + + func showResourcePicker() { + messageInputView?.onTapAddButton() + } + + func showCamera() { + messageInputView?.showCamera() + } + + func showPhotosLibrary() { + messageInputView?.showPhotosLibrary() + } + + func showDocumentsPicker() { + messageInputView?.showDocumentsPicker() + } + + // View Model Methods + func sendUserMessage( + messageParams: UserMessageCreateParams, + parentMessage: BaseMessage? = nil + ) { + self.viewController?.viewModel?.sendUserMessage( + messageParams: messageParams, + parentMessage: parentMessage + ) + } + + func sendFileMessage( + messageParams: FileMessageCreateParams, + parentMessage: BaseMessage? = nil + ) { + self.viewController?.viewModel?.sendFileMessage( + messageParams: messageParams, + parentMessage: parentMessage + ) + } + + func resendMessage(failedMessage: BaseMessage) { + viewModel?.resendMessage(failedMessage: failedMessage) + } + + func deleteMessage(message: BaseMessage) { + viewModel?.deleteMessage(message: message) + } + + func clearMessageList() { + viewModel?.clearMessageList() + } + + func setReaction(message: BaseMessage, emojiKey: String, didSelect: Bool) { + viewModel?.setReaction(message: message, emojiKey: emojiKey, didSelect: didSelect) + } + + func loadPrevMessages() { + viewModel?.loadPrevMessages() + } + + func loadNextMessages() { + viewModel?.loadNextMessages() + } + + func reloadMessageList() { + viewModel?.reloadMessageList() + } +} + +// MARK: - SBUGroupChannelViewModelDelegate +extension GroupChannelViewProvider: SBUGroupChannelViewModelDelegate { + public func groupChannelViewModel( + _ viewModel: SBUGroupChannelViewModel, + didReceiveSuggestedMentions members: [SBUUser]? + ) { + + } + + public func groupChannelViewModel( + _ viewModel: SBUGroupChannelViewModel, + didFinishUploadingFileAt index: Int, + multipleFilesMessageRequestId requestId: String + ) { + + } + + public func groupChannelViewModel( + _ viewModel: SBUGroupChannelViewModel, + didReceiveStreamMessage message: BaseMessage, + forChannel channel: GroupChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didChangeChannel channel: BaseChannel?, + withContext context: MessageContext + ) { + if let groupChannel = channel as? GroupChannel { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = groupChannel + } + } + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didReceiveNewMessage message: BaseMessage, + forChannel channel: BaseChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldFinishEditModeForChannel channel: BaseChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldDismissForChannel channel: BaseChannel? + ) { + + } + + // changes fullMessageList + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didChangeMessageList messages: [BaseMessage], + needsToReload: Bool, + initialLoad: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.fullMessages = messages + } + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + deletedMessages messages: [BaseMessage] + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldUpdateScrollInMessageList messages: [BaseMessage], + forContext context: MessageContext?, + keepsScroll: Bool + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didUpdateReaction reaction: ReactionEvent, + forMessage message: BaseMessage + ) { + + } +} + +// MARK: - SBUCommonViewModelDelegate +extension GroupChannelViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } + + public func connectionStateDidChange(_ isConnected: Bool) { + self.eventHandlers.connectionStateChangeHandler?(isConnected) + } +} + +// MARK: - GroupChannelViewEventDelegate +extension GroupChannelViewProvider: GroupChannelViewEventDelegate { + func groupChannelViewDidUpdateNewMessagesCount(_ count: Int) { + StateImpactHandler.safeExecute { [weak self] in + self?.newMessagesCount = count + } + } + + func groupChannelViewDidChangeMessageText(_ text: String) { + StateImpactHandler.safeExecute { [weak self] in + self?.messageInputText = text + } + } +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelView.swift b/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelView.swift index 11ff00c..f1074f7 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupChannel/GroupChannelView.swift @@ -15,21 +15,34 @@ public struct GroupChannelView: View { private var dismiss var configurations: [(SBUGroupChannelViewController) -> Void] = [] - - private var channelURL: String - private var startingPoint: Int64? - private var messageListParams: MessageListParams? // for message search var highlightInfo: SBUHighlightMessageInfo? var useRightBarButtonItem: Bool = true - // MARK: - Methods + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupChannelViewProvider + + init(provider: GroupChannelViewProvider) { + self.provider = provider // Default + } + public var body: some View { SBUViewControllerSet.GroupChannelViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + messageListParams: self.provider.messageListParams, + startingPoint: self.provider.startingPoint, + displaysLocalCachedListFirst: true + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -44,19 +57,43 @@ public struct GroupChannelView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupChannel = GroupChannelViewConverter() + } } private func createViewController() -> SBUGroupChannelViewController { + SBULog.info( + """ + [\(Self.self).\(#function)] provider + channelURL = \(provider.channelURL) + startingPoint = \(String(describing: provider.startingPoint)) + messageListParams = \(String(describing: provider.messageListParams)) + """ + ) + let viewController = SBUViewControllerSet.GroupChannelViewController.init( - channelURL: self.channelURL, - startingPoint: self.startingPoint, - messageListParams: self.messageListParams + channelURL: self.provider.channelURL, + startingPoint: self.provider.startingPoint, + messageListParams: self.provider.messageListParams ) viewController.highlightInfo = self.highlightInfo viewController.useRightBarButtonItem = self.useRightBarButtonItem + // connect VC, VM <-> provider + self.provider.bind(viewController: viewController) + return viewController } + + // MARK: - Methods + // TODO: 이후에 필요하다면, 값 변화에 대해서 새로 그릴 수 있도록 처리 + private func shouldUpdateData(viewController: SBUGroupChannelViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateMessageListParams = viewController.viewModel?.customizedMessageListParams == nil && self.provider.messageListParams != nil + let shouldUpdateStartingPoint = viewController.viewModel?.startingPoint == nil && self.provider.startingPoint != nil + return shouldUpdateChannelURL || shouldUpdateMessageListParams || shouldUpdateStartingPoint + } } // MARK: - Initializers @@ -65,33 +102,14 @@ public extension GroupChannelView { // MARK: - typealias typealias ListContent = GroupChannelViewConverter.List typealias InputContent = GroupChannelViewConverter.Input - - init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil - ) { - self.channelURL = channelURL - self.startingPoint = startingPoint - self.messageListParams = messageListParams - // Apply view converter in viewConverterSet. - self.applyViewConverterSet() - } - init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + provider: GroupChannelViewProvider, headerItem: (() -> GroupChannelType.HeaderItem)? = nil, listItem: (() -> GroupChannelType.ListItem)? = nil, inputItem: (() -> GroupChannelType.InputItem)? = nil ) { - self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams - ) + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -100,18 +118,15 @@ public extension GroupChannelView { self.applyViewConverterSet() } - init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + // TODO: After entire content is implemented + internal init( + provider: GroupChannelViewProvider, headerItem: (() -> GroupChannelType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content, inputItem: (() -> GroupChannelType.InputItem)? = nil ) { self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams, + provider: provider, headerItem: headerItem, inputItem: inputItem ) @@ -129,17 +144,13 @@ public extension GroupChannelView { // NOTE: This interface has been temporarily closed. private init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + provider: GroupChannelViewProvider, headerItem: (() -> GroupChannelType.HeaderItem)? = nil, listItem: (() -> GroupChannelType.ListItem)? = nil, input: @escaping (InputContent.ViewConfig) -> Content ) { self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams, + provider: provider, headerItem: headerItem, listItem: listItem ) @@ -158,18 +169,14 @@ public extension GroupChannelView { } // NOTE: This interface has been temporarily closed. - private init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + internal init( + provider: GroupChannelViewProvider, headerItem: (() -> GroupChannelType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content, input: @escaping (InputContent.ViewConfig) -> Content ) { self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams, + provider: provider, headerItem: headerItem ) @@ -194,8 +201,17 @@ public extension GroupChannelView { } } +// MARK: Event handler interfaces +public extension GroupChannelView { + func onSendbirdError(_ errorHandler: @escaping SendbirdErrorHandler) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - GroupChannelView(channelURL: "") + GroupChannelView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannel/ViewConverters/SBUBaseMessageCell+SwiftUI.swift b/Sources/SwiftUI/KeyFunctions/GroupChannel/ViewConverters/SBUBaseMessageCell+SwiftUI.swift index 06dfa32..664835f 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupChannel/ViewConverters/SBUBaseMessageCell+SwiftUI.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupChannel/ViewConverters/SBUBaseMessageCell+SwiftUI.swift @@ -114,7 +114,7 @@ extension SBUBaseMessageCell { userMessageCell.mainContainerView.layer.cornerRadius = 0 userMessageCell.mainContainerView.setTransparentBackgroundColor() - userMessageCell.mainContainerView.insertArrangedSubview(hostingView, at: 1) + userMessageCell.mainContainerView.insertArrangedSubview(hostingView, at: 0) return true case .fileMessage: diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListView.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListView.swift index 8f3215c..b2b830f 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListView.swift @@ -19,12 +19,25 @@ public struct GroupChannelListView: View { var configurations: [(SBUGroupChannelListViewController) -> Void] = [] private var channelListQuery: GroupChannelListQuery? - // MARK: - Methods + @ObservedObject private var provider: GroupChannelListViewProvider + + public init() { + self.provider = GroupChannelListViewProvider() // Default + } + public var body: some View { SBUViewControllerSet.GroupChannelListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelListQuery: self.provider.channelListQuery + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -41,15 +54,28 @@ public struct GroupChannelListView: View { moveToChannelIfNeeded(payloadManager.channelURL) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupChannelList = GroupChannelListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUGroupChannelListViewController { let viewController = SBUViewControllerSet.GroupChannelListViewController.init( channelListQuery: self.channelListQuery ) + + // connect VC, VM <-> provider + self.provider.bind(viewController: viewController) + return viewController } + private func shouldUpdateData(viewController: SBUGroupChannelListViewController) -> Bool { + let shouldUpdateChannelListQuery = viewController.viewModel?.channelListQuery == nil && self.provider.channelListQuery != nil + return shouldUpdateChannelListQuery + } + private func moveToChannelIfNeeded(_ channelURL: String?) { DispatchQueue.main.async { if let channelURL = payloadManager.channelURL { @@ -67,11 +93,12 @@ public extension GroupChannelListView { typealias ListContent = GroupChannelListViewConverter.List init( - channelListQuery: GroupChannelListQuery? = nil, + provider: GroupChannelListViewProvider? = nil, headerItem: (() -> GroupChannelListType.HeaderItem)? = nil, listItem: (() -> GroupChannelListType.ListItem)? = nil ) { - self.channelListQuery = channelListQuery + self.provider = provider ?? GroupChannelListViewProvider() + self.channelListQuery = self.provider.channelListQuery if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -80,12 +107,17 @@ public extension GroupChannelListView { self.applyViewConverterSet() } - init( - channelListQuery: GroupChannelListQuery? = nil, + // TODO: After entire content is implemented + internal init( + provider: GroupChannelListViewProvider? = nil, headerItem: (() -> GroupChannelListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.init(channelListQuery: channelListQuery, headerItem: headerItem, listItem: nil) + self.init( + provider: provider, + headerItem: headerItem, + listItem: nil + ) typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -102,11 +134,51 @@ public extension GroupChannelListView { } } +// MARK: Event handler interfaces +public extension GroupChannelListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping (_ indexPath: IndexPath) -> Void) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdSelectLeaveChannel(_ selectLeaveChannelHandler: @escaping (_ channel: GroupChannel) -> Void) -> Self { + let copy = self + copy.provider.eventHandlers.selectLeaveChannelHandler = selectLeaveChannelHandler + return copy + } + + func onSendbirdChangePushTriggerOption(_ changePushTriggerOptionHandler: @escaping (_ channel: GroupChannel) -> Void) -> Self { + let copy = self + copy.provider.eventHandlers.changePushTriggerOptionHandler = changePushTriggerOptionHandler + return copy + } + + func onSendbirdConnectionStateChange(_ connectionStateChangeHandler: @escaping SendbirdConnectionStateChangeHandler) -> Self { + let copy = self + copy.provider.eventHandlers.connectionStateChangeHandler = connectionStateChangeHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping SendbirdErrorHandler) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } + + // Note: Events from Chat SDK are not be available in SendbirdSwiftUI. +// func onUpdatedChannels(_ handler: @escaping GroupChannelListUpdatedChannelsHandler) -> Self { +// let copy = self +// copy.manager?.eventHandlers.updatedChannelsHandler = handler +// return copy +// } +} + #Preview { NavigationView { GroupChannelListView() .groupChannelView { channelURL, _, _ in - GroupChannelView(channelURL: channelURL) + GroupChannelView(provider: .init(channelURL: channelURL)) } } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListViewProvider.swift new file mode 100644 index 0000000..e5d190a --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelList/GroupChannelListViewProvider.swift @@ -0,0 +1,158 @@ +// +// GroupChannelListViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/28/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: GroupChannelListEventHandlers +public struct GroupChannelListEventHandlers { + // View related event handlers. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + var selectLeaveChannelHandler: ((_ channel: GroupChannel) -> Void)? + var changePushTriggerOptionHandler: ((_ channel: GroupChannel) -> Void)? + + // Internal state event handlers. + var connectionStateChangeHandler: SendbirdConnectionStateChangeHandler? + var errorHandler: SendbirdErrorHandler? + + + // Note: Events from Chat SDK are not be available in SendbirdSwiftUI. +} + +// MARK: - GroupChannelListViewProvider +public class GroupChannelListViewProvider: SendbirdUIProvider { + // Init properties + var channelListQuery: GroupChannelListQuery? + + // SendbirdProvider protocol + weak var viewController: SBUGroupChannelListViewController? + var eventHandlers = GroupChannelListEventHandlers() + + // MARK: Public Data Properties + // Note: @Published properties can't be computed properties. + @Published public var channels: [GroupChannel] = [] + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties (??) + // public var theme: SBUGroupChannelListTheme + + public init(channelListQuery: GroupChannelListQuery? = nil) { + self.channelListQuery = channelListQuery + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelListQuery: GroupChannelListQuery? = nil + ) -> Self { + if let channelListQuery { self.channelListQuery = channelListQuery } + return self + } + + func bind(viewController: SBUGroupChannelListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +// MARK: - ViewController method wrappers +extension GroupChannelListViewProvider { + public func showChannel( + channelURL: String, + messageListParams: MessageListParams? = nil + ) { + self.viewController?.showChannel( + channelURL: channelURL, + messageListParams: messageListParams + ) + } + + public func showCreateChannelOrTypeSelector () { + self.viewController?.showCreateChannelOrTypeSelector() + } + + public func showCreateChannelTypeSelector() { + self.viewController?.showCreateChannelTypeSelector() + } + + public func showCreateChannel(type: ChannelCreationType = .group) { + self.viewController?.showCreateChannel(type: type) + } + + public func showCreateChannel() { + self.viewController?.showCreateChannel() + } +} + +// MARK: - ViewModel method wrappers +extension GroupChannelListViewProvider { + // MARK: - List handling + func loadNextChannelList() { + self.viewController?.viewModel?.loadNextChannelList(reset: true) + } +} + +// MARK: - GroupChannelListViewModelDelegate +extension GroupChannelListViewProvider: SBUGroupChannelListViewModelDelegate { + public func groupChannelListViewModel( + _ viewModel: SBUGroupChannelListViewModel, + didUpdateChannel channel: GroupChannel + ) { + StateImpactHandler.safeExecute { [weak self] in + if let index = self?.channels.firstIndex(where: { $0.channelURL == channel.channelURL }) { + self?.channels[index] = channel + } + } + } + + public func groupChannelListViewModel( + _ viewModel: SBUGroupChannelListViewModel, + didLeaveChannel channel: GroupChannel + ) { + + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func groupChannelListViewModel(_ viewModel: SBUGroupChannelListViewModel, didChangeChannelList channels: [GroupChannel]?, needsToReload: Bool) { + guard let channels = channels else { return } + StateImpactHandler.safeExecute { [weak self] in + self?.channels = channels + } + } +} + +// MARK: - CommonViewModelDelegate +extension GroupChannelListViewProvider: SBUCommonViewModelDelegate { + public func connectionStateDidChange(_ isConnected: Bool) { + self.eventHandlers.connectionStateChangeHandler?(isConnected) + } + + public func didReceiveError(_ error: SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +// MARK: - GroupChannelListViewEventDelegate +extension GroupChannelListViewProvider: GroupChannelListViewEventDelegate { + func groupChannelListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } + + func groupChannelListView(didSelectLeaveFrom channel: GroupChannel) { + self.eventHandlers.selectLeaveChannelHandler?(channel) + } + + func groupChannelListView(didChangePushTriggerOption channel: GroupChannel) { + self.eventHandlers.changePushTriggerOptionHandler?(channel) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsView.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsView.swift index a0b85a0..5585e7c 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsView.swift @@ -16,14 +16,25 @@ public struct GroupChannelPushSettingsView: View { var configurations: [(SBUGroupChannelPushSettingsViewController) -> Void] = [] - private var channelURL: String + @ObservedObject var provider: GroupChannelPushSettingsViewProvider + + public init(provider: GroupChannelPushSettingsViewProvider) { + self.provider = provider // Default provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupChannelPushSettingsViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,14 +49,24 @@ public struct GroupChannelPushSettingsView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupChannelPushSettings = GroupChannelPushSettingsViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUGroupChannelPushSettingsViewController { let viewController = SBUViewControllerSet.GroupChannelPushSettingsViewController.init( - channelURL: channelURL + channelURL: self.provider.channelURL ) + self.provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUGroupChannelPushSettingsViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + return shouldUpdateChannelURL + } } // MARK: - Initializers @@ -55,16 +76,12 @@ public extension GroupChannelPushSettingsView { // TODO: Initializer 에서 필요하면 구현 // typealias ListContent = GroupChannelPushSettingsViewConverter.List - init(channelURL: String) { - self.channelURL = channelURL - } - // (↓↓ example ↓↓) init( - channelURL: String, + provider: GroupChannelPushSettingsViewProvider, headerItem: (() -> GroupChannelPushSettingsType.HeaderItem)? = nil ) { - self.channelURL = channelURL + self.provider = provider if let headerItem { _ = headerItem() } // if let listItem { _ = listItem() } @@ -72,8 +89,9 @@ public extension GroupChannelPushSettingsView { // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -97,6 +115,6 @@ public extension GroupChannelPushSettingsView { #Preview { NavigationView { - GroupChannelPushSettingsView(channelURL: "") + GroupChannelPushSettingsView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsViewProvider.swift new file mode 100644 index 0000000..5d7a392 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelPushSettings/GroupChannelPushSettingsViewProvider.swift @@ -0,0 +1,67 @@ +// +// GroupChannelPushSettingsViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct GroupChannelPushSettingsEventHandlers { + +} + +public class GroupChannelPushSettingsViewProvider: SendbirdUIProvider { + // init properties + var channelURL: String + + // SendbirdProvider protocol + weak var viewController: SBUGroupChannelPushSettingsViewController? + var eventHandlers = GroupChannelPushSettingsEventHandlers() + + public init(channelURL: String) { + self.channelURL = channelURL + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String + ) -> Self { + self.channelURL = channelURL + return self + } + + func bind(viewController: SBUGroupChannelPushSettingsViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +extension GroupChannelPushSettingsViewProvider: SBUGroupChannelPushSettingsViewModelDelegate { + public func groupChannelPushSettingsViewModel(_ viewModel: SBUGroupChannelPushSettingsViewModel, didChangeNotification pushTriggerOption: SendbirdChatSDK.GroupChannelPushTriggerOption) { + + } + + public func baseChannelSettingsViewModel(_ viewModel: SBUBaseChannelSettingsViewModel, didChangeChannel channel: SendbirdChatSDK.BaseChannel?, withContext context: SendbirdChatSDK.MessageContext) { + + } + + public func baseChannelSettingsViewModel(_ viewModel: SBUBaseChannelSettingsViewModel, shouldDismissForChannelSettings channel: SendbirdChatSDK.BaseChannel?) { + + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + + } +} + +extension GroupChannelPushSettingsViewProvider: GroupChannelPushSettingsViewEventDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorView.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorView.swift index 771b881..9d567f0 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorView.swift @@ -16,15 +16,29 @@ public struct GroupChannelRegisterOperatorView: View { var configurations: [(SBURegisterOperatorViewController) -> Void] = [] - private var channelURL: String - private var users: [SBUUser]? + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupChannelRegisterOperatorViewProvider + + init(provider: GroupChannelRegisterOperatorViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupChannelRegisterOperatorViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .group, + users: self.provider.customUsers, + inviteListType: .operators + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,39 +53,42 @@ public struct GroupChannelRegisterOperatorView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupChannelRegisterOperator = GroupChannelRegisterOperatorViewConverter() + } } - + + // MARK: - Methods private func createViewController() -> SBURegisterOperatorViewController { let viewController = SBUViewControllerSet.GroupChannelRegisterOperatorViewController.init( - channelURL: self.channelURL, - users: self.users + channelURL: self.provider.channelURL, + users: self.provider.customUsers ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBURegisterOperatorViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers /// GroupChannelRegisterOperatorView initializers public extension GroupChannelRegisterOperatorView { // MARK: - typealias - // TODO: Initializer 에서 필요하면 구현 // typealias ListContent = GroupChannelRegisterOperatorViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } -// (↓↓ example ↓↓) - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: GroupChannelRegisterOperatorViewProvider, headerItem: (() -> GroupChannelRegisterOperatorType.HeaderItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } // if let listItem { _ = listItem() } @@ -79,8 +96,9 @@ public extension GroupChannelRegisterOperatorView { // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -104,6 +122,6 @@ public extension GroupChannelRegisterOperatorView { #Preview { NavigationView { - GroupChannelRegisterOperatorView(channelURL: "") + GroupChannelRegisterOperatorView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorViewProvider.swift new file mode 100644 index 0000000..c1fae41 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelRegisterOperator/GroupChannelRegisterOperatorViewProvider.swift @@ -0,0 +1,117 @@ +// +// GroupChannelRegisterOperatorViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// swiftlint:disable type_name +// MARK: ViewEventHandlers +public struct GroupChannelRegisterOperatorViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + var didRegisterOperatorsHandler: ((_ operatorIds: [String]) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} +// swiftlint:enable type_name + +// MARK: - GroupChannelRegisterOperatorViewProvider +public class GroupChannelRegisterOperatorViewProvider: SendbirdUIProvider { + // Init properties + var channelURL: String + var customUsers: [SBUUser]? + + // SendbirdProvider protocol + weak var viewController: SBURegisterOperatorViewController? + var eventHandlers = GroupChannelRegisterOperatorViewEventHandlers() + + // MARK: Public Data Properties + // Note: @Published properties can't be computed properties. + @Published public var members: [SBUUser] = [] + @Published public var selectedMembers: [SBUUser] = [] + @Published public var isLoading: Bool = false + + // MARK: Public Data Properties + public var channel: GroupChannel? + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBURegisterOperatorViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: ViewController method wrappers + public func registerOperatorWithSelectedMembers() { + self.viewController?.registerSelectedUsers() + } + + // MARK: ViewModel method wrappers + public func registerOperator(with userIds: [String]) { + self.viewController?.viewModel?.registerAsOperators(userIds: userIds) + } +} + +extension GroupChannelRegisterOperatorViewProvider: SBURegisterOperatorViewModelDelegate { + public func registerOperatorViewModel(_ viewModel: SBURegisterOperatorViewModel, didRegisterOperatorIds operatorIds: [String]) { + self.eventHandlers.didRegisterOperatorsHandler?(operatorIds) + } + + public func baseSelectedUserViewModel(_ viewModel: SBUBaseSelectUserViewModel, didChangeUserList users: [SBUUser]?, needsToReload: Bool) { + guard let users = users else { return } + StateImpactHandler.safeExecute { [weak self] in + self?.members = users + } + } + + public func baseSelectedUserViewModel(_ viewModel: SBUBaseSelectUserViewModel, didUpdateSelectedUsers selectedUsers: [SBUUser]?) { + guard let selectedUsers = selectedUsers else { return } + StateImpactHandler.safeExecute { [weak self] in + self?.selectedMembers = selectedUsers + } + } +} + +extension GroupChannelRegisterOperatorViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +extension GroupChannelRegisterOperatorViewProvider: RegisterOperatorViewEventDelegate { + func registerOperatorView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsView.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsView.swift index 4962f5b..fbae003 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsView.swift @@ -15,15 +15,26 @@ public struct GroupChannelSettingsView: View { private var dismiss var configurations: [(SBUGroupChannelSettingsViewController) -> Void] = [] + + @ObservedObject var provider: GroupChannelSettingsViewProvider - private var channelURL: String + init(provider: GroupChannelSettingsViewProvider) { + self.provider = provider // Default + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupChannelSettingsViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,10 +49,21 @@ public struct GroupChannelSettingsView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupChannelSettings = GroupChannelSettingsViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUGroupChannelSettingsViewController { - SBUViewControllerSet.GroupChannelSettingsViewController.init(channelURL: channelURL) + let viewController = SBUViewControllerSet.GroupChannelSettingsViewController.init(channelURL: self.provider.channelURL) + self.provider.bind(viewController: viewController) + return viewController + } + + private func shouldUpdateData(viewController: SBUGroupChannelSettingsViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + return shouldUpdateChannelURL } } @@ -52,11 +74,11 @@ public extension GroupChannelSettingsView { typealias ListContent = GroupChannelSettingsViewConverter.List init( - channelURL: String, + provider: GroupChannelSettingsViewProvider, headerItem: (() -> GroupChannelSettingsType.HeaderItem)? = nil, listItem: (() -> GroupChannelSettingsType.ListItem)? = nil ) { - self.channelURL = channelURL + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -65,12 +87,13 @@ public extension GroupChannelSettingsView { self.applyViewConverterSet() } - init( - channelURL: String, + // TODO: After entire content is implemented + internal init( + provider: GroupChannelSettingsViewProvider, headerItem: (() -> GroupChannelSettingsType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.init(channelURL: channelURL, headerItem: headerItem, listItem: nil) + self.init(provider: provider, headerItem: headerItem, listItem: nil) typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -89,6 +112,10 @@ public extension GroupChannelSettingsView { #Preview { NavigationView { - GroupChannelSettingsView(channelURL: DefaultViewConfigSet.groupChannel.channelURL) + GroupChannelSettingsView( + provider: .init( + channelURL: DefaultViewConfigSet.groupChannel.channelURL + ) + ) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsViewProvider.swift new file mode 100644 index 0000000..c5e8c27 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupChannelSettings/GroupChannelSettingsViewProvider.swift @@ -0,0 +1,73 @@ +// +// GroupChannelSettingsViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct GroupChannelSettingsEventHandlers { + +} + +public class GroupChannelSettingsViewProvider: SendbirdUIProvider { + // Init properties + var channelURL: String + + // SendbirdProvider protocol + weak var viewController: SBUGroupChannelSettingsViewController? + var eventHandlers = GroupChannelSettingsEventHandlers() + + // MARK: Public Data Properties + // Note: @Published properties can't be computed properties. + + // MARK: Public UI Properties (??) + // public var theme: SBUGroupChannelListTheme + + public init(channelURL: String) { + self.channelURL = channelURL + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String + ) -> Self { + self.channelURL = channelURL + return self + } + + func bind(viewController: SBUGroupChannelSettingsViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +extension GroupChannelSettingsViewProvider: SBUGroupChannelSettingsViewModelDelegate { + public func groupChannelSettingsViewModel(_ viewModel: SBUGroupChannelSettingsViewModel, didLeaveChannel channel: SendbirdChatSDK.GroupChannel) { + + } + + public func baseChannelSettingsViewModel(_ viewModel: SBUBaseChannelSettingsViewModel, didChangeChannel channel: SendbirdChatSDK.BaseChannel?, withContext context: SendbirdChatSDK.MessageContext) { + + } + + public func baseChannelSettingsViewModel(_ viewModel: SBUBaseChannelSettingsViewModel, shouldDismissForChannelSettings channel: SendbirdChatSDK.BaseChannel?) { + + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + + } +} + +extension GroupChannelSettingsViewProvider: GroupChannelSettingsViewEventDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListView.swift b/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListView.swift index fb783fd..1ea1db9 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListView.swift @@ -15,16 +15,30 @@ public struct GroupMemberListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupMemberListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: GroupMemberListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .group, + users: self.provider.customUsers, + userListType: .members + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct GroupMemberListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupMemberList = GroupMemberListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.GroupUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .group, - users: self.users, + users: self.provider.customUsers, userListType: .members ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,22 +87,12 @@ public extension GroupMemberListView { typealias ListContent = GroupMemberListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: GroupMemberListViewProvider, userListType: ChannelUserListType = .members, headerItem: (() -> GroupMemberListType.HeaderItem)? = nil, listItem: (() -> GroupMemberListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -83,18 +101,21 @@ public extension GroupMemberListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: GroupMemberListViewProvider, headerItem: (() -> GroupMemberListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.init(provider: provider, headerItem: headerItem, listItem: nil) typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in - UIHostingController(rootView: list(listConfig)).view + ProviderAndConfigWrappedHostingView( + provider: provider, + config: listConfig, + content: list + ).createHostingView() } self.viewConverter.list.tableView.entireContent = listViewConverter @@ -107,8 +128,23 @@ public extension GroupMemberListView { } } +// MARK: Event handler interfaces +public extension GroupMemberListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - GroupMemberListView(channelURL: "") + GroupMemberListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListViewProvider.swift new file mode 100644 index 0000000..1cb4fca --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupMemberList/GroupMemberListViewProvider.swift @@ -0,0 +1,169 @@ +// +// GroupMemberListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct GroupMemberListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - GroupMemberListViewProvider +public class GroupMemberListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = GroupMemberListViewEventHandlers() + + // MARK: Public Data Properties + /// Member list + @Published public var members: [SBUUser] = [] + + /// Channel object + @Published public var channel: GroupChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the operator list. + public func loadNextMemberList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the operator list. + public func resetMemberList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function registers the user as an operator. + public func registerAsOperator(user: SBUUser) { + self.viewController?.viewModel?.registerAsOperator(user: user) + } + + /// This function unregisters the user as an operator. + public func unregisterOperator(user: SBUUser) { + self.viewController?.viewModel?.unregisterOperator(user: user) + } + + /// This function bans the user. + public func ban(user: SBUUser) { + self.viewController?.viewModel?.ban(user: user) + } + + /// This function unbans the user. + public func unban(user: SBUUser) { + self.viewController?.viewModel?.unban(user: user) + } + + /// This function mutes the user. + public func mute(user: SBUUser) { + self.viewController?.viewModel?.mute(user: user) + } + + /// This function unmutes the user. + public func unmute(user: SBUUser) { + self.viewController?.viewModel?.unmute(user: user) + } +} + +// MARK: - ViewEventDelegate +extension GroupMemberListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension GroupMemberListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.members = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? GroupChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension GroupMemberListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/GroupMemberListViewConverter.List.swift b/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/GroupMemberListViewConverter.List.swift index b480989..dd68d26 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/GroupMemberListViewConverter.List.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/GroupMemberListViewConverter.List.swift @@ -56,8 +56,8 @@ extension GroupMemberListViewConverter.List { // MARK: ViewConfigurations public struct ViewConfig: ViewConfigurations { - public var parentView: ContentBaseArg - public var users: [SBUUser] = [] +// public var parentView: ContentBaseArg +// public var users: [SBUUser] = [] } // MARK: View updater diff --git a/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/SBUGroupUserListModule.List+SwiftUI.swift b/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/SBUGroupUserListModule.List+SwiftUI.swift index 2f21b68..ed7c3ff 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/SBUGroupUserListModule.List+SwiftUI.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupMemberList/ViewConverters/SBUGroupUserListModule.List+SwiftUI.swift @@ -19,20 +19,20 @@ extension SBUUserListModule.List { extension SBUUserListModule.List { func applyViewConverter(_ viewType: ViewConverter.ViewType) -> Bool { let tag = viewType.tag - switch viewType { case .entireContent: - let users = self.userList + // TODO: EntireContent + if self.viewWithTag(tag) != nil { + return true + } + if let tableViewConverter = self.viewConverter.tableView.entireContent, - let hostingView = tableViewConverter( - .init( - parentView: self, - users: users - ) - ) { + let hostingView = tableViewConverter(.init()) { + hostingView.backgroundColor = .blue // remove UITableView self.tableView.removeFromSuperview() + self.viewWithTag(tag)?.removeFromSuperview() // add hostingView as subview of List hostingView.tag = tag @@ -47,4 +47,8 @@ extension SBUUserListModule.List { return false } } + + private func updateHostingViewData(users: [SBUUser]) { + // 여기서 hostingView 내부의 SwiftUI view에 userList와 관련된 데이터를 업데이트합니다. + } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsView.swift b/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsView.swift index cdb2e90..9615e65 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsView.swift @@ -16,14 +16,26 @@ public struct GroupModerationsView: View { var configurations: [(SBUModerationsViewController) -> Void] = [] - private var channelURL: String + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupModerationsViewProvider + + init(provider: GroupModerationsViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupModerationsViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,33 +50,41 @@ public struct GroupModerationsView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupModerations = GroupModerationsViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUModerationsViewController { let viewController = SBUViewControllerSet.GroupModerationsViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .group ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUModerationsViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + return shouldUpdateChannelURL + } } // MARK: - Initializers /// GroupModerationsView initializers public extension GroupModerationsView { // MARK: - typealias - // TODO: Initializer 에서 필요하면 구현 // typealias ListContent = GroupModerationsViewConverter.List - init(channelURL: String) { - self.channelURL = channelURL - } -// (↓↓ example ↓↓) init( - channelURL: String, + provider: GroupModerationsViewProvider, headerItem: (() -> GroupModerationsType.HeaderItem)? = nil ) { - self.channelURL = channelURL + self.provider = provider if let headerItem { _ = headerItem() } // if let listItem { _ = listItem() } @@ -72,8 +92,9 @@ public extension GroupModerationsView { // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -97,6 +118,6 @@ public extension GroupModerationsView { #Preview { NavigationView { - GroupModerationsView(channelURL: "") + GroupModerationsView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsViewProvider.swift new file mode 100644 index 0000000..bf0791e --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupModerations/GroupModerationsViewProvider.swift @@ -0,0 +1,97 @@ +// +// GroupModerationsViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// swiftlint:disable type_name +// MARK: ViewEventHandlers +public struct GroupModerationsViewEventHandlers { + // Blocks for handling for user inputs. + var didChangeFrozenStateHandler: ((_ isFrozen: Bool) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} +// swiftlint:enable type_name + +// MARK: - GroupModerationsViewProvider +public class GroupModerationsViewProvider: SendbirdUIProvider { + // Init properties + var channelURL: String + + // SendbirdProvider protocol + weak var viewController: SBUModerationsViewController? + var eventHandlers = GroupModerationsViewEventHandlers() + + // MARK: Public Data Properties + // Note: @Published properties can't be computed properties. + @Published public var participants: [SBUUser] = [] + @Published public var selectedParticipants: [SBUUser] = [] + @Published public var isLoading: Bool = false + + // MARK: Public Data Properties + public var channel: OpenChannel? + + // MARK: Public UI Properties + + // MARK: Methods + public init(channelURL: String) { + self.channelURL = channelURL + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String + ) -> Self { + self.channelURL = channelURL + return self + } + + func bind(viewController: SBUModerationsViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: ViewController method wrappers + public func changeFreeze(_ freeze: Bool) { + self.viewController?.changeFreeze(freeze) + } + + // MARK: ViewModel method wrappers + // nothing +} + +extension GroupModerationsViewProvider: SBUModerationsViewModelDelegate { + public func moderationsViewModel( + _ viewModel: SBUModerationsViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + // + } +} + +extension GroupModerationsViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +extension GroupModerationsViewProvider: ModerationsViewEventDelegate { + func moderationsView(didChangeFrozenState isFrozen: Bool) { + self.eventHandlers.didChangeFrozenStateHandler?(isFrozen) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListView.swift b/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListView.swift index a664727..4150886 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListView.swift @@ -15,16 +15,30 @@ public struct GroupMutedMemberListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupMutedMemberListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: GroupMutedMemberListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .group, + users: self.provider.customUsers, + userListType: .muted + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct GroupMutedMemberListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupMutedMemberList = GroupMutedMemberListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.GroupUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .group, - users: self.users, + users: self.provider.customUsers, userListType: .muted ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,21 +87,11 @@ public extension GroupMutedMemberListView { typealias ListContent = GroupMutedMemberListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: GroupMutedMemberListViewProvider, headerItem: (() -> GroupMutedMemberListType.HeaderItem)? = nil, listItem: (() -> GroupMutedMemberListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +100,13 @@ public extension GroupMutedMemberListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: GroupMutedMemberListViewProvider, headerItem: (() -> GroupMutedMemberListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +123,23 @@ public extension GroupMutedMemberListView { } } +// MARK: Event handler interfaces +public extension GroupMutedMemberListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - GroupMutedMemberListView(channelURL: "") + GroupMutedMemberListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListViewProvider.swift new file mode 100644 index 0000000..8378624 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupMutedMemberList/GroupMutedMemberListViewProvider.swift @@ -0,0 +1,149 @@ +// +// GroupMutedMemberListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct GroupMutedMemberListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - GroupMutedMemberListViewProvider +public class GroupMutedMemberListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = GroupMutedMemberListViewEventHandlers() + + // MARK: Public Data Properties + /// Muted member list + @Published public var mutedMembers: [SBUUser] = [] + + /// Channel object + @Published public var channel: GroupChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the muted member list. + public func loadNextMutedMemberList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the muted member list. + public func resetMutedMemberList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function mutes the user. + public func mute(user: SBUUser) { + self.viewController?.viewModel?.mute(user: user) + } + + /// This function unmutes the user. + public func unmute(user: SBUUser) { + self.viewController?.viewModel?.unmute(user: user) + } +} + +// MARK: - ViewEventDelegate +extension GroupMutedMemberListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension GroupMutedMemberListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.mutedMembers = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? GroupChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension GroupMutedMemberListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListView.swift b/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListView.swift index 9be985f..6c74d82 100644 --- a/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListView.swift +++ b/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListView.swift @@ -15,16 +15,30 @@ public struct GroupOperatorListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: GroupOperatorListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: GroupOperatorListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.GroupUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .group, + users: self.provider.customUsers, + userListType: .operators + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct GroupOperatorListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.GroupOperatorList = GroupOperatorListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.GroupUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .group, - users: self.users, + users: self.provider.customUsers, userListType: .operators ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,21 +87,11 @@ public extension GroupOperatorListView { typealias ListContent = GroupOperatorListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: GroupOperatorListViewProvider, headerItem: (() -> GroupOperatorListType.HeaderItem)? = nil, listItem: (() -> GroupOperatorListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +100,13 @@ public extension GroupOperatorListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: GroupOperatorListViewProvider, headerItem: (() -> GroupOperatorListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +123,23 @@ public extension GroupOperatorListView { } } +// MARK: Event handler interfaces +public extension GroupOperatorListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - GroupOperatorListView(channelURL: "") + GroupOperatorListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListViewProvider.swift new file mode 100644 index 0000000..2f991f7 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/GroupOperatorList/GroupOperatorListViewProvider.swift @@ -0,0 +1,149 @@ +// +// GroupOperatorListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct GroupOperatorListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - GroupOperatorListViewProvider +public class GroupOperatorListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = GroupOperatorListViewEventHandlers() + + // MARK: Public Data Properties + /// Operator list + @Published public var operators: [SBUUser] = [] + + /// Channel object + @Published public var channel: GroupChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the operator list. + public func loadNextOperatorList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the operator list. + public func resetOperatorList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function registers the user as an operator. + public func registerAsOperator(user: SBUUser) { + self.viewController?.viewModel?.registerAsOperator(user: user) + } + + /// This function unregisters the user as an operator. + public func unregisterOperator(user: SBUUser) { + self.viewController?.viewModel?.unregisterOperator(user: user) + } +} + +// MARK: - ViewEventDelegate +extension GroupOperatorListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension GroupOperatorListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.operators = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? GroupChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension GroupOperatorListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserView.swift b/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserView.swift index 76f222f..9f300a5 100644 --- a/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserView.swift +++ b/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserView.swift @@ -16,15 +16,28 @@ public struct InviteUserView: View { var configurations: [(SBUInviteUserViewController) -> Void] = [] - private var channelURL: String - private var users: [SBUUser]? + @ObservedObject private var provider: InviteUserViewProvider + + init(provider: InviteUserViewProvider) { + self.provider = provider // Default + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.InviteUserViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .group, + users: self.provider.customUsers, + inviteListType: .users + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,15 +52,26 @@ public struct InviteUserView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.InviteUser = InviteUserViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUInviteUserViewController { let viewController = SBUViewControllerSet.InviteUserViewController.init( - channelURL: self.channelURL, - users: self.users + channelURL: self.provider.channelURL, + users: self.provider.customUsers ) + self.provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUInviteUserViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -55,24 +79,14 @@ public struct InviteUserView: View { public extension InviteUserView { // MARK: - typealias typealias ListContent = InviteUserViewConverter.List - - init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } init( - channelURL: String, - users: [SBUUser]? = nil, + provider: InviteUserViewProvider, headerItem: (() -> InviteUserType.HeaderItem)? = nil, listItem: (() -> InviteUserType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users - + self.provider = provider + if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -80,14 +94,13 @@ public extension InviteUserView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: InviteUserViewProvider, headerItem: (() -> InviteUserType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,6 +119,6 @@ public extension InviteUserView { #Preview { NavigationView { - InviteUserView(channelURL: "") + InviteUserView(provider: .init(channelURL:"")) } } diff --git a/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserViewProvider.swift b/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserViewProvider.swift new file mode 100644 index 0000000..6bac545 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/InviteUser/InviteUserViewProvider.swift @@ -0,0 +1,74 @@ +// +// InviteUserViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public class InviteUserViewProvider: SendbirdUIProvider { + // init properties + var channelURL: String + var customUsers: [SBUUser]? + + // SendbirdProvider protocol + weak var viewController: SBUInviteUserViewController? + var eventHandlers = InviteUserEventHandlers() + + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUInviteUserViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +extension InviteUserViewProvider: SBUInviteUserViewModelDelegate { + public func inviteUserViewModel(_ viewModel: SBUInviteUserViewModel, didInviteUserIds userIds: [String]) { + + } + + public func baseSelectedUserViewModel(_ viewModel: SBUBaseSelectUserViewModel, didChangeUserList users: [SBUUser]?, needsToReload: Bool) { + + } + + public func baseSelectedUserViewModel(_ viewModel: SBUBaseSelectUserViewModel, didUpdateSelectedUsers selectedUsers: [SBUUser]?) { + + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + + } +} + +extension InviteUserViewProvider: InviteUserViewEventDelegate { + +} + +public struct InviteUserEventHandlers { + +} diff --git a/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchView.swift b/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchView.swift index e460fed..a4264cb 100644 --- a/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchView.swift +++ b/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchView.swift @@ -16,14 +16,26 @@ public struct MessageSearchView: View { var configurations: [(SBUMessageSearchViewController) -> Void] = [] - private var channelURL: String + var provider: MessageSearchViewProvider + + public init(provider: MessageSearchViewProvider) { + self.provider = provider // Default provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.MessageSearchViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + params: self.provider.messageSearchQueryParams + ) + } + } .configure { viewController in // viewController.dismissAction = { // dismiss() @@ -38,14 +50,25 @@ public struct MessageSearchView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.MessageSearch = MessageSearchViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUMessageSearchViewController { let viewController = SBUViewControllerSet.MessageSearchViewController.init( - channelURL: self.channelURL + channelURL: self.provider.channelURL ) + self.provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUMessageSearchViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateMessageSearchQueryParams = viewController.viewModel?.messageSearchQuery == nil && self.provider.messageSearchQueryParams != nil + return shouldUpdateChannelURL || shouldUpdateMessageSearchQueryParams + } } // MARK: - Initializers @@ -53,18 +76,14 @@ public struct MessageSearchView: View { public extension MessageSearchView { // MARK: - typealias // typealias ListContent = MessageSearchViewConverter.List - - init(channelURL: String) { - self.channelURL = channelURL - } - + // TODO: public after beta private init( - channelURL: String, + provider: MessageSearchViewProvider, headerItem: (() -> MessageSearchType.HeaderItem)? = nil, listItem: (() -> MessageSearchType.ListItem)? = nil ) { - self.channelURL = channelURL + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -76,6 +95,6 @@ public extension MessageSearchView { #Preview { NavigationView { - MessageSearchView(channelURL: "") + MessageSearchView(provider: MessageSearchViewProvider(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchViewProvider.swift b/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchViewProvider.swift new file mode 100644 index 0000000..d39824a --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/MessageSearch/MessageSearchViewProvider.swift @@ -0,0 +1,66 @@ +// +// MessageSearchViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct MessageSearchEventHandlers { + +} + +public class MessageSearchViewProvider: SendbirdUIProvider { + // init params + var channelURL: String + var messageSearchQueryParams: MessageSearchQueryParams? + + // SendbirdUIProvider protocol + weak var viewController: SBUMessageSearchViewController? + var eventHandlers = MessageSearchEventHandlers() + + public init( + channelURL: String, + messageSearchQueryParams: MessageSearchQueryParams? = nil + ) { + self.channelURL = channelURL + self.messageSearchQueryParams = messageSearchQueryParams + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + messageSearchQueryParams: MessageSearchQueryParams? = nil + ) -> Self { + self.channelURL = channelURL + if let messageSearchQueryParams { self.messageSearchQueryParams = messageSearchQueryParams } + return self + } + + func bind(viewController: SBUMessageSearchViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +extension MessageSearchViewProvider: SBUMessageSearchViewModelDelegate { + public func searchViewModel(_ viewModel: SBUMessageSearchViewModel, didChangeSearchResults results: [SendbirdChatSDK.BaseMessage], needsToReload: Bool) { + + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + + } +} + +extension MessageSearchViewProvider: MessageSearchViewEventDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadView.swift b/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadView.swift index fc6e655..7e6cc59 100644 --- a/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadView.swift +++ b/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadView.swift @@ -16,19 +16,33 @@ public struct MessageThreadView: View { var configurations: [(SBUMessageThreadViewController) -> Void] = [] - private var channelURL: String - private var parentMessageId: Int64 - private var delegate: SBUMessageThreadViewControllerDelegate? - private var threadedMessageListParams: ThreadedMessageListParams? - private var startingPoint: Int64? = .max - private var voiceFileInfos: [String: SBUVoiceFileInfo]? = nil + // Non-optional since `channelURL`, `parentMessageId` are required. + @ObservedObject private var provider: MessageThreadViewProvider + + init(provider: MessageThreadViewProvider) { + self.provider = provider // Default + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.MessageThreadViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + if let voiceFileInfos = provider.voiceFileInfos { + viewController.voiceFileInfos = voiceFileInfos + } + + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + parentMessageId: self.provider.parentMessageId, + threadedMessageListParams: self.provider.threadedMessageListParams, + startingPoint: self.provider.startingPoint + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -43,19 +57,35 @@ public struct MessageThreadView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.MessageThread = MessageThreadViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUMessageThreadViewController { let viewController = SBUViewControllerSet.MessageThreadViewController.init( - channelURL: self.channelURL, - parentMessageId: self.parentMessageId, - delegate: self.delegate, - threadedMessageListParams: self.threadedMessageListParams, - startingPoint: self.startingPoint, - voiceFileInfos: self.voiceFileInfos + channelURL: self.provider.channelURL, + parentMessageId: self.provider.parentMessageId, + threadedMessageListParams: self.provider.threadedMessageListParams, + startingPoint: self.provider.startingPoint, + voiceFileInfos: self.provider.voiceFileInfos ) + + // connect VC, VM <-> provider + self.provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUMessageThreadViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateParentMessageId = viewController.viewModel?.parentMessageId == nil && self.provider.parentMessageId != 0 + let shouldUpdateStartingPoint = viewController.viewModel?.startingPoint == nil && self.provider.startingPoint != 0 + let shouldUpdateVoiceFileInfos = viewController.voiceFileInfos == nil && self.provider.voiceFileInfos != nil + let shouldUpdateThreadMessageParams = viewController.viewModel?.threadedMessageListParams == nil && self.provider.threadedMessageListParams != nil + + return shouldUpdateChannelURL || shouldUpdateParentMessageId || shouldUpdateStartingPoint || shouldUpdateVoiceFileInfos || shouldUpdateThreadMessageParams + } } // MARK: - Initializers @@ -66,44 +96,13 @@ public extension MessageThreadView { typealias InputContent = MessageThreadViewConverter.Input init( - channelURL: String, - parentMessageId: Int64, - delegate: SBUMessageThreadViewControllerDelegate? = nil, - threadedMessageListParams: ThreadedMessageListParams? = nil, - startingPoint: Int64? = .max, - voiceFileInfos: [String: SBUVoiceFileInfo]? = nil - ) { - self.channelURL = channelURL - self.parentMessageId = parentMessageId - self.delegate = delegate - self.threadedMessageListParams = threadedMessageListParams - self.startingPoint = startingPoint - self.voiceFileInfos = voiceFileInfos - - // Apply view converter in viewConverterSet. - self.applyViewConverterSet() - } - - init( - channelURL: String, - parentMessageId: Int64, - delegate: SBUMessageThreadViewControllerDelegate? = nil, - threadedMessageListParams: ThreadedMessageListParams? = nil, - startingPoint: Int64? = .max, - voiceFileInfos: [String: SBUVoiceFileInfo]? = nil, + provider: MessageThreadViewProvider, headerItem: (() -> MessageThreadType.HeaderItem)? = nil, parentInfoItem: (() -> MessageThreadType.ParentInfoItem)? = nil, listItem: (() -> MessageThreadType.ListItem)? = nil, inputItem: (() -> MessageThreadType.InputItem)? = nil ) { - self.init( - channelURL: channelURL, - parentMessageId: parentMessageId, - delegate: delegate, - threadedMessageListParams: threadedMessageListParams, - startingPoint: startingPoint, - voiceFileInfos: voiceFileInfos - ) + self.init(provider: provider) if let headerItem { _ = headerItem() } if let parentInfoItem { _ = parentInfoItem() } @@ -114,27 +113,14 @@ public extension MessageThreadView { self.applyViewConverterSet() } - init( - channelURL: String, - parentMessageId: Int64, - delegate: SBUMessageThreadViewControllerDelegate? = nil, - threadedMessageListParams: ThreadedMessageListParams? = nil, - startingPoint: Int64? = .max, - voiceFileInfos: [String: SBUVoiceFileInfo]? = nil, + // TODO: After entire content is implemented + internal init( + provider: MessageThreadViewProvider, headerItem: (() -> MessageThreadType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content, inputItem: (() -> MessageThreadType.InputItem)? = nil ) { - self.init( - channelURL: channelURL, - parentMessageId: parentMessageId, - delegate: delegate, - threadedMessageListParams: threadedMessageListParams, - startingPoint: startingPoint, - voiceFileInfos: voiceFileInfos, - headerItem: headerItem, - inputItem: inputItem - ) + self.init(provider: provider) self.viewConverter.list.tableView.entireContent = ViewConverter { tableViewConfig in UIHostingController(rootView: list(tableViewConfig)).view @@ -148,24 +134,14 @@ public extension MessageThreadView { // NOTE: This interface has been temporarily closed. private init( - channelURL: String, - parentMessageId: Int64, - delegate: SBUMessageThreadViewControllerDelegate? = nil, - threadedMessageListParams: ThreadedMessageListParams? = nil, - startingPoint: Int64? = .max, - voiceFileInfos: [String: SBUVoiceFileInfo]? = nil, + provider: MessageThreadViewProvider, headerItem: (() -> MessageThreadType.HeaderItem)? = nil, parentInfoItem: (() -> MessageThreadType.ParentInfoItem)? = nil, listItem: (() -> MessageThreadType.ListItem)? = nil, input: @escaping (InputContent.ViewConfig) -> Content ) { self.init( - channelURL: channelURL, - parentMessageId: parentMessageId, - delegate: delegate, - threadedMessageListParams: threadedMessageListParams, - startingPoint: startingPoint, - voiceFileInfos: voiceFileInfos, + provider: provider, headerItem: headerItem, parentInfoItem: parentInfoItem, listItem: listItem @@ -186,23 +162,13 @@ public extension MessageThreadView { // NOTE: This interface has been temporarily closed. private init( - channelURL: String, - parentMessageId: Int64, - delegate: SBUMessageThreadViewControllerDelegate? = nil, - threadedMessageListParams: ThreadedMessageListParams? = nil, - startingPoint: Int64? = .max, - voiceFileInfos: [String: SBUVoiceFileInfo]? = nil, + provider: MessageThreadViewProvider, headerItem: (() -> MessageThreadType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content, input: @escaping (InputContent.ViewConfig) -> Content ) { self.init( - channelURL: channelURL, - parentMessageId: parentMessageId, - delegate: delegate, - threadedMessageListParams: threadedMessageListParams, - startingPoint: startingPoint, - voiceFileInfos: voiceFileInfos, + provider: provider, headerItem: headerItem ) @@ -229,6 +195,11 @@ public extension MessageThreadView { #Preview { NavigationView { - MessageThreadView(channelURL: "", parentMessageId: -1) + MessageThreadView( + provider: .init( + channelURL: "", + parentMessageId: -1 + ) + ) } } diff --git a/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadViewProvider.swift b/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadViewProvider.swift new file mode 100644 index 0000000..06f498e --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/MessageThread/MessageThreadViewProvider.swift @@ -0,0 +1,203 @@ +// +// MessageThreadViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/21/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct MessageThreadViewEventHandlers { + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +public class MessageThreadViewProvider: SendbirdUIProvider { + // SendbirdUIProvider protocol + weak var viewController: SBUMessageThreadViewController? + var eventHandlers = MessageThreadViewEventHandlers() + + // + public private(set) var channelURL: String + public private(set) var parentMessageId: Int64 + public private(set) var threadedMessageListParams: ThreadedMessageListParams? + public private(set) var startingPoint: Int64? = .max + public private(set) var voiceFileInfos: [String: SBUVoiceFileInfo]? + + // MARK: Published properties + @Published public var channel: BaseChannel? + @Published public var parentMessage: BaseMessage? + @Published public var fullMessages: [BaseMessage] = [] + @Published public var isLoading: Bool = false + + public init( + channelURL: String, + parentMessageId: Int64, + threadedMessageListParams: ThreadedMessageListParams? = nil, + startingPoint: Int64? = .max, + voiceFileInfos: [String: SBUVoiceFileInfo]? = nil + ) { + self.channelURL = channelURL + self.parentMessageId = parentMessageId + self.threadedMessageListParams = threadedMessageListParams + self.startingPoint = startingPoint + self.voiceFileInfos = voiceFileInfos + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + parentMessageId: Int64, + threadedMessageListParams: ThreadedMessageListParams? = nil, + startingPoint: Int64? = .max, + voiceFileInfos: [String: SBUVoiceFileInfo]? = nil + ) -> Self { + self.channelURL = channelURL + self.parentMessageId = parentMessageId + if let threadedMessageListParams {self.threadedMessageListParams = threadedMessageListParams } + if let startingPoint {self.startingPoint = startingPoint } + if let voiceFileInfos {self.voiceFileInfos = voiceFileInfos } + return self + } + + func bind(viewController: SBUMessageThreadViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +// MARK: - SBUMessageThreadViewModelDelegate +extension MessageThreadViewProvider: SBUMessageThreadViewModelDelegate { + public func messageThreadViewModel( + _ viewModel: SBUMessageThreadViewModel, + didReceiveSuggestedMentions members: [SBUUser]? + ) { + + } + + public func messageThreadViewModel( + _ viewModel: SBUMessageThreadViewModel, + didLoadParentMessage parentMessage: BaseMessage? + ) { + if let parentMessage = parentMessage { + StateImpactHandler.safeExecute { [weak self] in + self?.parentMessage = parentMessage + } + } + } + + public func messageThreadViewModel( + _ viewModel: SBUMessageThreadViewModel, + didUpdateParentMessage parentMessage: BaseMessage? + ) { + if let parentMessage = parentMessage { + StateImpactHandler.safeExecute { [weak self] in + self?.parentMessage = parentMessage + } + } + } + + public func messageThreadViewModelShouldDismissMessageThread( + _ viewModel: SBUMessageThreadViewModel + ) { + + } + + public func messageThreadViewModel( + _ viewModel: SBUMessageThreadViewModel, + didFinishUploadingFileAt index: Int, + multipleFilesMessageRequestId requestId: String + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didChangeChannel channel: BaseChannel?, + withContext context: MessageContext + ) { + if let channel { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel + } + } + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didReceiveNewMessage message: BaseMessage, + forChannel channel: BaseChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldFinishEditModeForChannel channel: BaseChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldDismissForChannel channel: BaseChannel? + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didChangeMessageList messages: [BaseMessage], + needsToReload: Bool, + initialLoad: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.fullMessages = messages + } + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + deletedMessages messages: [BaseMessage] + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldUpdateScrollInMessageList messages: [BaseMessage], + forContext context: MessageContext?, + keepsScroll: Bool + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didUpdateReaction reaction: ReactionEvent, + forMessage message: BaseMessage + ) { + + } +} + +// MARK: - SBUCommonViewModelDelegate +extension MessageThreadViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +// MARK: - MessageThreadViewEventDelegate +extension MessageThreadViewProvider: MessageThreadViewEventDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/MessageThread/ViewConverters/SBUBaseMessageCell.MessageThread+SwiftUI.swift b/Sources/SwiftUI/KeyFunctions/MessageThread/ViewConverters/SBUBaseMessageCell.MessageThread+SwiftUI.swift index ec334fe..f469098 100644 --- a/Sources/SwiftUI/KeyFunctions/MessageThread/ViewConverters/SBUBaseMessageCell.MessageThread+SwiftUI.swift +++ b/Sources/SwiftUI/KeyFunctions/MessageThread/ViewConverters/SBUBaseMessageCell.MessageThread+SwiftUI.swift @@ -90,7 +90,7 @@ extension SBUBaseMessageCell { hostingView.addGestureRecognizer(userMessageCell.contentLongPressRecognizer) hostingView.addGestureRecognizer(userMessageCell.contentTapRecognizer) - userMessageCell.mainContainerView.insertArrangedSubview(hostingView, at: 1) + userMessageCell.mainContainerView.insertArrangedSubview(hostingView, at: 0) return true case .fileMessage: diff --git a/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListView.swift b/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListView.swift index 28269fc..102fc43 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListView.swift @@ -15,16 +15,30 @@ public struct OpenBannedUserListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: OpenBannedUserListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: OpenBannedUserListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .open, + users: self.provider.customUsers, + userListType: .banned + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct OpenBannedUserListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenBannedUserList = OpenBannedUserListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.OpenUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .open, - users: self.users, + users: self.provider.customUsers, userListType: .banned ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,21 +87,11 @@ public extension OpenBannedUserListView { typealias ListContent = OpenBannedUserListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: OpenBannedUserListViewProvider, headerItem: (() -> OpenBannedUserListType.HeaderItem)? = nil, listItem: (() -> OpenBannedUserListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +100,13 @@ public extension OpenBannedUserListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: OpenBannedUserListViewProvider, headerItem: (() -> OpenBannedUserListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +123,23 @@ public extension OpenBannedUserListView { } } +// MARK: Event handler interfaces +public extension OpenBannedUserListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - OpenBannedUserListView(channelURL: "") + OpenBannedUserListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListViewProvider.swift new file mode 100644 index 0000000..c48a27f --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenBannedUserList/OpenBannedUserListViewProvider.swift @@ -0,0 +1,149 @@ +// +// OpenBannedUserListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct OpenBannedUserListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - OpenBannedUserListViewProvider +public class OpenBannedUserListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = OpenBannedUserListViewEventHandlers() + + // MARK: Public Data Properties + /// Banned user list + @Published public var bannedUsers: [SBUUser] = [] + + /// Channel object + @Published public var channel: OpenChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the banned user list. + public func loadNextBannedUserList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the user list. + public func resetBannedUserList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function bans the user. + public func ban(user: SBUUser) { + self.viewController?.viewModel?.ban(user: user) + } + + /// This function unbans the user. + public func unban(user: SBUUser) { + self.viewController?.viewModel?.unban(user: user) + } +} + +// MARK: - ViewEventDelegate +extension OpenBannedUserListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension OpenBannedUserListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.bannedUsers = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? OpenChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension OpenBannedUserListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelView.swift b/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelView.swift index f34eea8..8bb7482 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelView.swift @@ -16,16 +16,28 @@ public struct OpenChannelView: View { var configurations: [(SBUOpenChannelViewController) -> Void] = [] - private var channelURL: String - private var startingPoint: Int64? - private var messageListParams: MessageListParams? + // Non-optional since `channelURL` is required. + @ObservedObject var provider: OpenChannelViewProvider + + init(provider: OpenChannelViewProvider) { + self.provider = provider // Default + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenChannelViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + messageListParams: self.provider.messageListParams, + startingPoint: self.provider.startingPoint + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -40,16 +52,39 @@ public struct OpenChannelView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenChannel = OpenChannelViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUOpenChannelViewController { + SBULog.info( + """ + [\(Self.self).\(#function)] provider + channelURL = \(provider.channelURL) + startingPoint = \(String(describing: provider.startingPoint)) + messageListParams = \(String(describing: provider.messageListParams)) + """ + ) + let viewController = SBUViewControllerSet.OpenChannelViewController.init( - channelURL: self.channelURL, - startingPoint: self.startingPoint, - messageListParams: self.messageListParams + channelURL: self.provider.channelURL, + startingPoint: self.provider.startingPoint, + messageListParams: self.provider.messageListParams ) + + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUOpenChannelViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateMessageListParams = viewController.viewModel?.customizedMessageListParams == nil && self.provider.messageListParams != nil + let shouldUpdateStartingPoint = viewController.viewModel?.startingPoint == nil && self.provider.startingPoint != nil + return shouldUpdateChannelURL || shouldUpdateMessageListParams || shouldUpdateStartingPoint + } } // MARK: - Initializers @@ -60,31 +95,12 @@ public extension OpenChannelView { typealias InputContent = OpenChannelViewConverter.Input init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil - ) { - self.channelURL = channelURL - self.startingPoint = startingPoint - self.messageListParams = messageListParams - - // Apply view converter in viewConverterSet. - self.applyViewConverterSet() - } - - init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + provider: OpenChannelViewProvider, headerItem: (() -> OpenChannelType.HeaderItem)? = nil, listItem: (() -> OpenChannelType.ListItem)? = nil, inputItem: (() -> OpenChannelType.InputItem)? = nil ) { - self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams - ) + self.init(provider: provider) if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -93,18 +109,15 @@ public extension OpenChannelView { self.applyViewConverterSet() } - init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + // TODO: After entire content is implemented + internal init( + provider: OpenChannelViewProvider, headerItem: (() -> OpenChannelType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content, inputItem: (() -> OpenChannelType.InputItem)? = nil ) { self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams, + provider: provider, headerItem: headerItem, inputItem: inputItem ) @@ -122,17 +135,13 @@ public extension OpenChannelView { // NOTE: This interface has been temporarily closed. private init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + provider: OpenChannelViewProvider, headerItem: (() -> OpenChannelType.HeaderItem)? = nil, listItem: (() -> OpenChannelType.ListItem)? = nil, input: @escaping (InputContent.ViewConfig) -> Content ) { self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams, + provider: provider, headerItem: headerItem, listItem: listItem ) @@ -152,17 +161,13 @@ public extension OpenChannelView { // NOTE: This interface has been temporarily closed. private init( - channelURL: String, - startingPoint: Int64? = nil, - messageListParams: MessageListParams? = nil, + provider: OpenChannelViewProvider, headerItem: (() -> OpenChannelType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content, input: @escaping (InputContent.ViewConfig) -> Content ) { self.init( - channelURL: channelURL, - startingPoint: startingPoint, - messageListParams: messageListParams, + provider: provider, headerItem: headerItem ) @@ -189,6 +194,6 @@ public extension OpenChannelView { #Preview { NavigationView { - OpenChannelView(channelURL: "") + OpenChannelView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelViewProvider.swift new file mode 100644 index 0000000..8926231 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenChannel/OpenChannelViewProvider.swift @@ -0,0 +1,184 @@ +// +// OpenChannelViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct OpenChannelEventHandlers { + var errorHandler: SendbirdErrorHandler? + var connectionStateChangeHandler: SendbirdConnectionStateChangeHandler? +} + +public class OpenChannelViewProvider: SendbirdUIProvider { + // SendbirdProvider protocol + weak var viewController: SBUOpenChannelViewController? + var eventHandlers = OpenChannelEventHandlers() + + // init properties + public private(set) var channelURL: String + public private(set) var startingPoint: Int64? + public private(set) var messageListParams: MessageListParams? + + // MARK: Published properties + @Published public var channel: OpenChannel? + @Published public var fullMessages: [BaseMessage] = [] + @Published public var isLoading: Bool = false + + // MARK: Private properties + fileprivate var viewModel: SBUOpenChannelViewModel? { + self.viewController?.viewModel + } + + public init( + channelURL: String, + startingPoint: Int64? = nil, + messageListParams: MessageListParams? = nil + ) { + self.channelURL = channelURL + self.startingPoint = startingPoint + self.messageListParams = messageListParams + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + startingPoint: Int64? = nil, + messageListParams: MessageListParams? = nil + ) -> Self { + self.channelURL = channelURL + if let startingPoint { self.startingPoint = startingPoint } + if let messageListParams { self.messageListParams = messageListParams } + return self + } + + func bind(viewController: SBUOpenChannelViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +// MARK: - ViewController method wrappers +public extension OpenChannelViewProvider { + func onClickBack() { + self.viewController?.onClickBack() + } + + func showChannelSettings() { + self.viewController?.showChannelSettings() + } + + func showParticipantsList() { + self.viewController?.showParticipantsList() + } +} + +// MARK: - ViewModel method wrappers +public extension OpenChannelViewProvider { + func loadPreviousMessages() { + viewModel?.loadPrevMessages(timestamp: .max) + } + + func loadNextMessages() { + viewModel?.loadNextMessages() + } +} + +// MARK: - SBUOpenChannelViewModelDelegate +extension OpenChannelViewProvider: SBUOpenChannelViewModelDelegate { + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didChangeChannel channel: BaseChannel?, + withContext context: MessageContext + ) { + if let openChannel = channel as? OpenChannel { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = openChannel + } + } + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didReceiveNewMessage message: BaseMessage, + forChannel channel: BaseChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldFinishEditModeForChannel channel: BaseChannel + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldDismissForChannel channel: BaseChannel? + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didChangeMessageList messages: [BaseMessage], + needsToReload: Bool, + initialLoad: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.fullMessages = messages + } + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + deletedMessages messages: [SendbirdChatSDK.BaseMessage] + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + shouldUpdateScrollInMessageList messages: [SendbirdChatSDK.BaseMessage], + forContext context: SendbirdChatSDK.MessageContext?, + keepsScroll: Bool + ) { + + } + + public func baseChannelViewModel( + _ viewModel: SBUBaseChannelViewModel, + didUpdateReaction reaction: SendbirdChatSDK.ReactionEvent, + forMessage message: SendbirdChatSDK.BaseMessage + ) { + + } +} + +// MARK: SBUCommonViewModelDelegate +extension OpenChannelViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } + + public func connectionStateDidChange(_ isConnected: Bool) { + self.eventHandlers.connectionStateChangeHandler?(isConnected) + } +} + +// MARK: - OpenChannelViewEventDelegate +extension OpenChannelViewProvider: OpenChannelViewEventDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListView.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListView.swift index 07dffe0..0c6890f 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListView.swift @@ -16,14 +16,25 @@ public struct OpenChannelListView: View { var configurations: [(SBUOpenChannelListViewController) -> Void] = [] - private var channelListQuery: OpenChannelListQuery? + @ObservedObject var provider: OpenChannelListViewProvider + + public init() { + self.provider = OpenChannelListViewProvider() // Default provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenChannelListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelListQuery: self.provider.channelListQuery + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,14 +49,27 @@ public struct OpenChannelListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenChannelList = OpenChannelListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUOpenChannelListViewController { let viewController = SBUViewControllerSet.OpenChannelListViewController.init( - channelListQuery: self.channelListQuery + channelListQuery: self.provider.channelListQuery ) + + // connect VC, VM <-> provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUOpenChannelListViewController) -> Bool { + let shouldUpdateChannelListQuery = viewController.viewModel?.channelListQuery == nil && self.provider.channelListQuery != nil + return shouldUpdateChannelListQuery + } } // MARK: - Initializers @@ -54,16 +78,12 @@ public extension OpenChannelListView { // MARK: - typealias typealias ListContent = OpenChannelListViewConverter.List - init(channelListQuery: OpenChannelListQuery? = nil) { - self.channelListQuery = channelListQuery - } - init( - channelListQuery: OpenChannelListQuery? = nil, + provider: OpenChannelListViewProvider? = nil, headerItem: (() -> OpenChannelListType.HeaderItem)? = nil, listItem: (() -> OpenChannelListType.ListItem)? = nil ) { - self.channelListQuery = channelListQuery + self.provider = provider ?? OpenChannelListViewProvider() // Default provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -72,12 +92,13 @@ public extension OpenChannelListView { self.applyViewConverterSet() } - init( - channelListQuery: OpenChannelListQuery? = nil, + // TODO: After entire content is implemented + internal init( + provider: OpenChannelListViewProvider? = nil, headerItem: (() -> OpenChannelListType.HeaderItem)? = nil, @ViewBuilder list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.init(channelListQuery: channelListQuery, headerItem: headerItem, listItem: nil) + self.init(provider: provider, headerItem: headerItem, listItem: nil) typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -94,6 +115,29 @@ public extension OpenChannelListView { } } +// MARK: Event handler interfaces +public extension OpenChannelListView { + func onSendbirdSelectRow( + _ selectRowHandler: @escaping (_ indexPath: IndexPath) -> Void + ) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdConnectionStateChange(_ connectionStateChangeHandler: @escaping SendbirdConnectionStateChangeHandler) -> Self { + let copy = self + copy.provider.eventHandlers.connectionStateChangeHandler = connectionStateChangeHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping SendbirdErrorHandler) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { OpenChannelListView() diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListViewProvider.swift new file mode 100644 index 0000000..8f9fbf0 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelList/OpenChannelListViewProvider.swift @@ -0,0 +1,126 @@ +// +// OpenChannelListViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct OpenChannelListEventHandlers { + // View related event handlers. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Internal state event handerls. + var connectionStateChangeHandler: SendbirdConnectionStateChangeHandler? + var errorHandler: SendbirdErrorHandler? +} + +public class OpenChannelListViewProvider: SendbirdUIProvider { + // SendbirdProvider protocol + weak var viewController: SBUOpenChannelListViewController? + var eventHandlers = OpenChannelListEventHandlers() + + // init properties + var channelListQuery: OpenChannelListQuery? + + // Published properties + @Published public var channels: [OpenChannel] = [] + @Published public var isLoading: Bool = false + + public init(channelListQuery: OpenChannelListQuery? = nil) { + self.channelListQuery = channelListQuery + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelListQuery: OpenChannelListQuery? = nil + ) -> Self { + if let channelListQuery { self.channelListQuery = channelListQuery } + return self + } + + func bind(viewController: SBUOpenChannelListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +// MARK: ViewController method wrappers +public extension OpenChannelListViewProvider { + func reloadChannelList() { + self.viewController?.reloadChannelList() + } + + func showChannel(channelURL: String, messageListParams: MessageListParams? = nil) { + self.viewController?.showChannel(channelURL: channelURL, messageListParams: messageListParams) + } + + func showCreateChannel() { + self.viewController?.showCreateChannel() + } +} + +// MARK: ViewModel method wrappers +public extension OpenChannelListViewProvider { + // MARK: - List handling + func loadNextChannelList() { + self.viewController?.viewModel?.loadNextChannelList(reset: true) + } +} + +// MARK: SBUOpenChannelListViewModelDelegate +extension OpenChannelListViewProvider: SBUOpenChannelListViewModelDelegate { + public func openChannelListViewModel( + _ viewModel: SBUOpenChannelListViewModel, + didChangeChannelList channels: [OpenChannel]?, + needsToReload: Bool + ) { + if let channels { + StateImpactHandler.safeExecute { [weak self] in + self?.channels = channels + } + } + } + + public func openChannelListViewModel( + _ viewModel: SBUOpenChannelListViewModel, + didUpdateChannel channel: OpenChannel + ) { + if let index = self.channels.firstIndex(where: { $0.channelURL == channel.channelURL }) { + StateImpactHandler.safeExecute { [weak self] in + self?.channels[index] = channel + } + } + } + + public func didReceiveError(_ error: SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +extension OpenChannelListViewProvider: SBUCommonViewModelDelegate { + public func connectionStateDidChange(_ isConnected: Bool) { + self.eventHandlers.connectionStateChangeHandler?(isConnected) + } + + public func didreceiveError(_ error: SBError?) { + self.eventHandlers.errorHandler?(error) + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } +} + +// MARK: OpenChannelListViewEventDelegate +extension OpenChannelListViewProvider: OpenChannelListViewEventDelegate { + func openChannelListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelList/ViewConverters/SBUOpenChannelListModule.List+SwiftUI.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelList/ViewConverters/SBUOpenChannelListModule.List+SwiftUI.swift index d4b22ed..63d03bd 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenChannelList/ViewConverters/SBUOpenChannelListModule.List+SwiftUI.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelList/ViewConverters/SBUOpenChannelListModule.List+SwiftUI.swift @@ -35,7 +35,7 @@ extension SBUOpenChannelListModule.List { // add hostingView as subview of List hostingView.tag = tag self.addSubview(hostingView) - + hostingView .sbu_constraint_fill(equalTo: self) .sbu_constraint(height: self.frame.height) diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorView.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorView.swift index e53b6af..ca5bfe6 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorView.swift @@ -16,15 +16,29 @@ public struct OpenChannelRegisterOperatorView: View { var configurations: [(SBURegisterOperatorViewController) -> Void] = [] - private var channelURL: String - private var users: [SBUUser]? + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: OpenChannelRegisterOperatorViewProvider + + init(provider: OpenChannelRegisterOperatorViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenChannelRegisterOperatorViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .open, + users: self.provider.customUsers, + inviteListType: .operators + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,40 +53,43 @@ public struct OpenChannelRegisterOperatorView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenChannelRegisterOperator = OpenChannelRegisterOperatorViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBURegisterOperatorViewController { let viewController = SBUViewControllerSet.OpenChannelRegisterOperatorViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .open, - users: self.users + users: self.provider.customUsers ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBURegisterOperatorViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers /// OpenChannelRegisterOperatorView initializers public extension OpenChannelRegisterOperatorView { // MARK: - typealias - // TODO: Initializer 에서 필요하면 구현 // typealias ListContent = OpenChannelRegisterOperatorViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } -// (↓↓ example ↓↓) - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: OpenChannelRegisterOperatorViewProvider, headerItem: (() -> OpenChannelRegisterOperatorType.HeaderItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } // if let listItem { _ = listItem() } @@ -80,8 +97,9 @@ public extension OpenChannelRegisterOperatorView { // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -105,6 +123,6 @@ public extension OpenChannelRegisterOperatorView { #Preview { NavigationView { - OpenChannelRegisterOperatorView(channelURL: "") + OpenChannelRegisterOperatorView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorViewProvider.swift new file mode 100644 index 0000000..63a149d --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelRegisterOperator/OpenChannelRegisterOperatorViewProvider.swift @@ -0,0 +1,117 @@ +// +// OpenChannelRegisterOperatorViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// swiftlint:disable type_name +// MARK: ViewEventHandlers +public struct OpenChannelRegisterOperatorViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + var didRegisterOperatorsHandler: ((_ operatorIds: [String]) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} +// swiftlint:enable type_name + +// MARK: - OpenChannelRegisterOperatorViewProvider +public class OpenChannelRegisterOperatorViewProvider: SendbirdUIProvider { + // Init properties + var channelURL: String + var customUsers: [SBUUser]? + + // SendbirdProvider protocol + weak var viewController: SBURegisterOperatorViewController? + var eventHandlers = OpenChannelRegisterOperatorViewEventHandlers() + + // MARK: Public Data Properties + // Note: @Published properties can't be computed properties. + @Published public var participants: [SBUUser] = [] + @Published public var selectedParticipants: [SBUUser] = [] + @Published public var isLoading: Bool = false + + // MARK: Public Data Properties + public var channel: OpenChannel? + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBURegisterOperatorViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: ViewController method wrappers + public func registerOperatorWithSelectedParticipants() { + self.viewController?.registerSelectedUsers() + } + + // MARK: ViewModel method wrappers + public func registerOperator(with userIds: [String]) { + self.viewController?.viewModel?.registerAsOperators(userIds: userIds) + } +} + +extension OpenChannelRegisterOperatorViewProvider: SBURegisterOperatorViewModelDelegate { + public func registerOperatorViewModel(_ viewModel: SBURegisterOperatorViewModel, didRegisterOperatorIds operatorIds: [String]) { + self.eventHandlers.didRegisterOperatorsHandler?(operatorIds) + } + + public func baseSelectedUserViewModel(_ viewModel: SBUBaseSelectUserViewModel, didChangeUserList users: [SBUUser]?, needsToReload: Bool) { + guard let users = users else { return } + StateImpactHandler.safeExecute { [weak self] in + self?.participants = users + } + } + + public func baseSelectedUserViewModel(_ viewModel: SBUBaseSelectUserViewModel, didUpdateSelectedUsers selectedUsers: [SBUUser]?) { + guard let selectedUsers = selectedUsers else { return } + StateImpactHandler.safeExecute { [weak self] in + self?.selectedParticipants = selectedUsers + } + } +} + +extension OpenChannelRegisterOperatorViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +extension OpenChannelRegisterOperatorViewProvider: RegisterOperatorViewEventDelegate { + func registerOperatorView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsView.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsView.swift index 5b8f7df..0b60a20 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsView.swift @@ -16,14 +16,26 @@ public struct OpenChannelSettingsView: View { var configurations: [(SBUOpenChannelSettingsViewController) -> Void] = [] - private var channelURL: String + @ObservedObject var provider: OpenChannelSettingsViewProvider + init(provider: OpenChannelSettingsViewProvider) { + self.provider = provider + } + // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenChannelSettingsViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,14 +50,25 @@ public struct OpenChannelSettingsView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenChannelSettings = OpenChannelSettingsViewConverter() + } + } + // MARK: - Methods private func createViewController() -> SBUOpenChannelSettingsViewController { let viewController = SBUViewControllerSet.OpenChannelSettingsViewController.init( - channelURL: self.channelURL + channelURL: self.provider.channelURL ) + provider.bind(viewController: viewController) return viewController } + + private func shouldUpdateData(viewController: SBUOpenChannelSettingsViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + return shouldUpdateChannelURL + } } // MARK: - Initializers @@ -55,15 +78,12 @@ public extension OpenChannelSettingsView { // TODO: Initializer 에서 필요하면 구현 // typealias ListContent = OpenChannelSettingsViewConverter.List - init(channelURL: String) { - self.channelURL = channelURL - } // (↓↓ example ↓↓) init( - channelURL: String, + provider: OpenChannelSettingsViewProvider, headerItem: (() -> OpenChannelSettingsType.HeaderItem)? = nil ) { - self.channelURL = channelURL + self.provider = provider if let headerItem { _ = headerItem() } // if let listItem { _ = listItem() } @@ -71,8 +91,9 @@ public extension OpenChannelSettingsView { // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -96,6 +117,6 @@ public extension OpenChannelSettingsView { #Preview { NavigationView { - OpenChannelSettingsView(channelURL: "") + OpenChannelSettingsView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsViewProvider.swift new file mode 100644 index 0000000..5a3039c --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenChannelSettings/OpenChannelSettingsViewProvider.swift @@ -0,0 +1,67 @@ +// +// OpenChannelSettingsViewProvider.swift +// SendbirdUIKit +// +// Created by Celine Moon on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +public struct OpenChannelSettingsEventHandlers { + +} + +public class OpenChannelSettingsViewProvider: SendbirdUIProvider { + // init properties + var channelURL: String + + // SendbirdUIProvider protocol + weak var viewController: SBUOpenChannelSettingsViewController? + var eventHandlers = OpenChannelSettingsEventHandlers() + + public init(channelURL: String) { + self.channelURL = channelURL + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String + ) -> Self { + self.channelURL = channelURL + return self + } + + func bind(viewController: SBUOpenChannelSettingsViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } +} + +extension OpenChannelSettingsViewProvider: SBUOpenChannelSettingsViewModelDelegate { + public func baseChannelSettingsViewModel(_ viewModel: SBUBaseChannelSettingsViewModel, didChangeChannel channel: SendbirdChatSDK.BaseChannel?, withContext context: SendbirdChatSDK.MessageContext) { + + } + + public func baseChannelSettingsViewModel(_ viewModel: SBUBaseChannelSettingsViewModel, shouldDismissForChannelSettings channel: SendbirdChatSDK.BaseChannel?) { + + } + + public func shouldUpdateLoadingState(_ isLoading: Bool) { + + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + + } + + public func openChannelSettingsViewModel(_ viewModel: SBUOpenChannelSettingsViewModel, didDeleteChannel channel: SendbirdChatSDK.OpenChannel) { + + } +} + +extension OpenChannelSettingsViewProvider: OpenChannelSettingsViewEventDelegate { + +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsView.swift b/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsView.swift index fd2df9e..d756a60 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsView.swift @@ -16,14 +16,26 @@ public struct OpenModerationsView: View { var configurations: [(SBUModerationsViewController) -> Void] = [] - private var channelURL: String + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: OpenModerationsViewProvider + + init(provider: OpenModerationsViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenModerationsViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -38,33 +50,41 @@ public struct OpenModerationsView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenModerations = OpenModerationsViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUModerationsViewController { let viewController = SBUViewControllerSet.OpenModerationsViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .open ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUModerationsViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + return shouldUpdateChannelURL + } } // MARK: - Initializers /// OpenModerationsView initializers public extension OpenModerationsView { // MARK: - typealias - // TODO: Initializer 에서 필요하면 구현 // typealias ListContent = OpenModerationsViewConverter.List - init(channelURL: String) { - self.channelURL = channelURL - } -// (↓↓ example ↓↓) init( - channelURL: String, + provider: OpenModerationsViewProvider, headerItem: (() -> OpenModerationsType.HeaderItem)? = nil ) { - self.channelURL = channelURL + self.provider = provider if let headerItem { _ = headerItem() } // if let listItem { _ = listItem() } @@ -72,8 +92,9 @@ public extension OpenModerationsView { // Apply view converter in viewConverterSet. self.applyViewConverterSet() } -// -// init( + + // TODO: After entire content is implemented +// internal init( // channelListQuery: GroupChannelListQuery? = nil, // headerItem: (() -> Sendbird.View.GroupChannel.ChannelList.HeaderItem)? = nil, // list: @escaping (ListContent.ViewConfig) -> Content @@ -97,6 +118,6 @@ public extension OpenModerationsView { #Preview { NavigationView { - OpenModerationsView(channelURL: "") + OpenModerationsView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsViewProvider.swift new file mode 100644 index 0000000..712f93a --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenModerations/OpenModerationsViewProvider.swift @@ -0,0 +1,98 @@ +// +// OpenModerationsViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// swiftlint:disable type_name +// MARK: ViewEventHandlers +public struct OpenModerationsViewEventHandlers { + // Blocks for handling for user inputs. + var didChangeFrozenStateHandler: ((_ isFrozen: Bool) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} +// swiftlint:enable type_name + +// MARK: - OpenModerationsViewProvider +public class OpenModerationsViewProvider: SendbirdUIProvider { + // Init properties + var channelURL: String + + // SendbirdProvider protocol + weak var viewController: SBUModerationsViewController? + var eventHandlers = OpenModerationsViewEventHandlers() + + // MARK: Public Data Properties + // Note: @Published properties can't be computed properties. + @Published public var participants: [SBUUser] = [] + @Published public var selectedParticipants: [SBUUser] = [] + @Published public var isLoading: Bool = false + + // MARK: Public Data Properties + public var channel: OpenChannel? + + // MARK: Public UI Properties + + // MARK: Methods + public init(channelURL: String) { + self.channelURL = channelURL + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String + ) -> Self { + self.channelURL = channelURL + return self + } + + func bind(viewController: SBUModerationsViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: ViewController method wrappers + public func changeFreeze(_ freeze: Bool) { + self.viewController?.changeFreeze(freeze) + } + + // MARK: ViewModel method wrappers + // nothing +} + +extension OpenModerationsViewProvider: SBUModerationsViewModelDelegate { + public func moderationsViewModel( + _ viewModel: SBUModerationsViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + // + } +} + +extension OpenModerationsViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} + +extension OpenModerationsViewProvider: ModerationsViewEventDelegate { + func moderationsView(didChangeFrozenState isFrozen: Bool) { + self.eventHandlers.didChangeFrozenStateHandler?(isFrozen) + } +} + diff --git a/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListView.swift b/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListView.swift index 489c9a2..9a9883d 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListView.swift @@ -15,16 +15,30 @@ public struct OpenMutedParticipantListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: OpenMutedParticipantListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: OpenMutedParticipantListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .open, + users: self.provider.customUsers, + userListType: .muted + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct OpenMutedParticipantListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenMutedParticipantList = OpenMutedParticipantListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.OpenUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .open, - users: self.users, + users: self.provider.customUsers, userListType: .muted ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,21 +87,11 @@ public extension OpenMutedParticipantListView { typealias ListContent = OpenMutedParticipantListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: OpenMutedParticipantListViewProvider, headerItem: (() -> OpenMutedParticipantType.HeaderItem)? = nil, listItem: (() -> OpenMutedParticipantType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +100,13 @@ public extension OpenMutedParticipantListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: OpenMutedParticipantListViewProvider, headerItem: (() -> OpenMutedParticipantType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +123,23 @@ public extension OpenMutedParticipantListView { } } +// MARK: Event handler interfaces +public extension OpenMutedParticipantListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - OpenMutedParticipantListView(channelURL: "") + OpenMutedParticipantListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListViewProvider.swift new file mode 100644 index 0000000..75575ed --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenMutedParticipantList/OpenMutedParticipantListViewProvider.swift @@ -0,0 +1,149 @@ +// +// OpenMutedParticipantListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct OpenMutedParticipantListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - OpenMutedParticipantListViewProvider +public class OpenMutedParticipantListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // SendbirdProvider protocol + weak var viewController: SBUUserListViewController? + var eventHandlers = OpenMutedParticipantListViewEventHandlers() + + // MARK: Public Data Properties + /// Muted participant list + @Published public var mutedParticipants: [SBUUser] = [] + + /// Channel object + @Published public var channel: OpenChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the muted participant list. + public func loadNextMutedParticipantList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the muted participant list. + public func resetMutedParticipantList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function mutes the user. + public func mute(user: SBUUser) { + self.viewController?.viewModel?.mute(user: user) + } + + /// This function unmutes the user. + public func unmute(user: SBUUser) { + self.viewController?.viewModel?.unmute(user: user) + } +} + +// MARK: - ViewEventDelegate +extension OpenMutedParticipantListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension OpenMutedParticipantListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.mutedParticipants = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? OpenChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension OpenMutedParticipantListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListView.swift b/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListView.swift index 7231622..1078367 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListView.swift @@ -15,16 +15,30 @@ public struct OpenOperatorListView: View { private var dismiss var configurations: [(SBUUserListViewController) -> Void] = [] + + // Non-optional since `channelURL` is required. + @ObservedObject private var provider: OpenOperatorListViewProvider - private var channelURL: String - private var users: [SBUUser]? + init(provider: OpenOperatorListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .open, + users: self.provider.customUsers, + userListType: .operators + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct OpenOperatorListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenOperatorList = OpenOperatorListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.OpenUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .open, - users: self.users, + users: self.provider.customUsers, userListType: .operators ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -59,21 +87,11 @@ public extension OpenOperatorListView { typealias ListContent = OpenOperatorListViewConverter.List init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } - - init( - channelURL: String, - users: [SBUUser]? = nil, + provider: OpenOperatorListViewProvider, headerItem: (() -> OpenOperatorListType.HeaderItem)? = nil, listItem: (() -> OpenOperatorListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +100,13 @@ public extension OpenOperatorListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: OpenOperatorListViewProvider, headerItem: (() -> OpenOperatorListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +123,23 @@ public extension OpenOperatorListView { } } +// MARK: Event handler interfaces +public extension OpenOperatorListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - OpenOperatorListView(channelURL: "") + OpenOperatorListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListViewProvider.swift new file mode 100644 index 0000000..4a33826 --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenOperatorList/OpenOperatorListViewProvider.swift @@ -0,0 +1,149 @@ +// +// OpenOperatorListViewProvider.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/22/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct OpenOperatorListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - OpenOperatorListViewProvider +public class OpenOperatorListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = OpenOperatorListViewEventHandlers() + + // MARK: Public Data Properties + /// Operator list + @Published public var operators: [SBUUser] = [] + + /// Channel object + @Published public var channel: OpenChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the operator list. + public func loadNextOperatorList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the operator list. + public func resetOperatorList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function registers the user as an operator. + public func registerAsOperator(user: SBUUser) { + self.viewController?.viewModel?.registerAsOperator(user: user) + } + + /// This function unregisters the user as an operator. + public func unregisterOperator(user: SBUUser) { + self.viewController?.viewModel?.unregisterOperator(user: user) + } +} + +// MARK: - ViewEventDelegate +extension OpenOperatorListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension OpenOperatorListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.operators = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? OpenChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension OpenOperatorListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListView.swift b/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListView.swift index f7864ae..07e413b 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListView.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListView.swift @@ -16,15 +16,29 @@ public struct OpenParticipantListView: View { var configurations: [(SBUUserListViewController) -> Void] = [] - private var channelURL: String - private var users: [SBUUser]? + // Non-optional since `channelURL` is required. + private var provider: OpenParticipantListViewProvider + + init(provider: OpenParticipantListViewProvider) { + self.provider = provider + } - // MARK: - Methods public var body: some View { SBUViewControllerSet.OpenUserListViewController .swiftUI { createViewController() } + .injectData { viewController in + if self.shouldUpdateData(viewController: viewController) { + // Inject data into view model and load + viewController.viewModel?.initializeAndLoad( + channelURL: self.provider.channelURL, + channelType: .open, + users: self.provider.customUsers, + userListType: .participants + ) + } + } .configure { viewController in viewController.dismissAction = { dismiss() @@ -39,17 +53,31 @@ public struct OpenParticipantListView: View { viewConverter.applyViewUpdates(to: viewController) } .switchUIKitNavigationBar() + .onDisappear { + SBViewConverterSet.OpenParticipantList = OpenParticipantListViewConverter() + } } + // MARK: - Methods private func createViewController() -> SBUUserListViewController { let viewController = SBUViewControllerSet.OpenUserListViewController.init( - channelURL: self.channelURL, + channelURL: self.provider.channelURL, channelType: .open, - users: self.users, + users: self.provider.customUsers, userListType: .participants ) + + // hook up VC, VM into provider + self.provider.bind(viewController: viewController) + return viewController } + + private func shouldUpdateData(viewController: SBUUserListViewController) -> Bool { + let shouldUpdateChannelURL = viewController.viewModel?.channelURL == "" && self.provider.channelURL != "" + let shouldUpdateCustomUsers = viewController.viewModel?.customizedUsers == nil && self.provider.customUsers != nil + return shouldUpdateChannelURL || shouldUpdateCustomUsers + } } // MARK: - Initializers @@ -57,23 +85,13 @@ public struct OpenParticipantListView: View { public extension OpenParticipantListView { // MARK: - typealias typealias ListContent = OpenParticipantListViewConverter.List - - init( - channelURL: String, - users: [SBUUser]? = nil - ) { - self.channelURL = channelURL - self.users = users - } init( - channelURL: String, - users: [SBUUser]? = nil, + provider: OpenParticipantListViewProvider, headerItem: (() -> OpenMemberListType.HeaderItem)? = nil, listItem: (() -> OpenMemberListType.ListItem)? = nil ) { - self.channelURL = channelURL - self.users = users + self.provider = provider if let headerItem { _ = headerItem() } if let listItem { _ = listItem() } @@ -82,14 +100,13 @@ public extension OpenParticipantListView { self.applyViewConverterSet() } - init( - channelURL: String, - users: [SBUUser]? = nil, + // TODO: After entire content is implemented + internal init( + provider: OpenParticipantListViewProvider, headerItem: (() -> OpenMemberListType.HeaderItem)? = nil, list: @escaping (ListContent.TableView.ViewConfig) -> Content ) { - self.channelURL = channelURL - self.users = users + self.provider = provider typealias ViewConverterType = ViewConverter let listViewConverter: ViewConverterType = ViewConverter { listConfig in @@ -106,8 +123,23 @@ public extension OpenParticipantListView { } } +// MARK: Event handler interfaces +public extension OpenParticipantListView { + func onSendbirdSelectRow(_ selectRowHandler: @escaping ((_ indexPath: IndexPath) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.selectRowHandler = selectRowHandler + return copy + } + + func onSendbirdError(_ errorHandler: @escaping ((_ error: SBError?) -> Void)) -> Self { + let copy = self + copy.provider.eventHandlers.errorHandler = errorHandler + return copy + } +} + #Preview { NavigationView { - OpenParticipantListView(channelURL: "") + OpenParticipantListView(provider: .init(channelURL: "")) } } diff --git a/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListViewProvider.swift b/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListViewProvider.swift new file mode 100644 index 0000000..8b85aab --- /dev/null +++ b/Sources/SwiftUI/KeyFunctions/OpenParticipantList/OpenParticipantListViewProvider.swift @@ -0,0 +1,169 @@ +// +// OpenParticipantListViewProvider.swift +// SendbirdSwiftUI +// +// Created by Tez Park on 10/21/24. +// + +import Foundation +import SwiftUI +import SendbirdChatSDK + +// MARK: ViewEventHandlers +public struct OpenParticipantListViewEventHandlers { + // Blocks for handling for user inputs. + var selectRowHandler: ((_ indexPath: IndexPath) -> Void)? + + // Blocks for handling for internal events. + var errorHandler: ((_ error: SBError?) -> Void)? +} + +// MARK: - OpenParticipantListViewProvider +public class OpenParticipantListViewProvider: SendbirdUIProvider { + // MARK: - Init properties + public var channelURL: String + var customUsers: [SBUUser]? + + // MARK: - Internal properties + weak var viewController: SBUUserListViewController? + var eventHandlers = OpenParticipantListViewEventHandlers() + + // MARK: Public Data Properties + /// Member list + @Published public var participants: [SBUUser] = [] + + /// Channel object + @Published public var channel: OpenChannel? + + /// Loading state + @Published public var isLoading: Bool = false + + // MARK: Public UI Properties + + // MARK: Methods + public init( + channelURL: String, + customUsers: [SBUUser]? = nil + ) { + self.channelURL = channelURL + self.customUsers = customUsers + } + + /// This function sets up the provider. + @discardableResult + public func setup( + channelURL: String, + customUsers: [SBUUser]? = nil + ) -> Self { + self.channelURL = channelURL + if let customUsers { self.customUsers = customUsers } + return self + } + + func bind(viewController: SBUUserListViewController) { + viewController.swiftUIDelegate = self + self.viewController = viewController + } + + // MARK: UIKit method wrappers + + /// This function shows the user profile + /// - Parameter user: `SBUUser` object used for user profile configuration + public func showUserProfile(user: SBUUser) { + self.viewController?.showUserProfile(with: user) + } + + /// This function shows the more menu + public func showMoreMenu(user: SBUUser) { + self.viewController?.showMoreMenu(with: user) + } + + /// This function loads the operator list. + public func loadNextOperatorList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: false, users: customUsers) + } + + /// This function resets the operator list. + public func resetOperatorList(customUsers: [SBUUser]? = nil) { + self.viewController?.viewModel?.loadNextUserList(reset: true, users: customUsers) + } + + /// This function registers the user as an operator. + public func registerAsOperator(user: SBUUser) { + self.viewController?.viewModel?.registerAsOperator(user: user) + } + + /// This function unregisters the user as an operator. + public func unregisterOperator(user: SBUUser) { + self.viewController?.viewModel?.unregisterOperator(user: user) + } + + /// This function bans the user. + public func ban(user: SBUUser) { + self.viewController?.viewModel?.ban(user: user) + } + + /// This function unbans the user. + public func unban(user: SBUUser) { + self.viewController?.viewModel?.unban(user: user) + } + + /// This function mutes the user. + public func mute(user: SBUUser) { + self.viewController?.viewModel?.mute(user: user) + } + + /// This function unmutes the user. + public func unmute(user: SBUUser) { + self.viewController?.viewModel?.unmute(user: user) + } +} + +// MARK: - ViewEventDelegate +extension OpenParticipantListViewProvider: UserListViewEventDelegate { + func userListView(didSelectRowAt indexPath: IndexPath) { + self.eventHandlers.selectRowHandler?(indexPath) + } +} + +// MARK: - ViewModelDelegate +extension OpenParticipantListViewProvider: SBUUserListViewModelDelegate { + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.participants = users + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + didChangeChannel channel: SendbirdChatSDK.BaseChannel?, + withContext context: SendbirdChatSDK.MessageContext + ) { + StateImpactHandler.safeExecute { [weak self] in + self?.channel = channel as? OpenChannel + } + } + + public func userListViewModel( + _ viewModel: SBUUserListViewModel, + shouldDismissForUserList channel: SendbirdChatSDK.BaseChannel? + ) { + // TODO: + } +} + +extension OpenParticipantListViewProvider: SBUCommonViewModelDelegate { + public func shouldUpdateLoadingState(_ isLoading: Bool) { + StateImpactHandler.safeExecute { [weak self] in + self?.isLoading = isLoading + } + } + + public func didReceiveError(_ error: SendbirdChatSDK.SBError?, isBlocker: Bool) { + self.eventHandlers.errorHandler?(error) + } +} diff --git a/Sources/SwiftUI/KeyFunctions/OpenParticipantList/ViewConverters/SBUOpenUserListModule.List+SwiftUI.swift b/Sources/SwiftUI/KeyFunctions/OpenParticipantList/ViewConverters/SBUOpenUserListModule.List+SwiftUI.swift index a38e30e..eb1b993 100644 --- a/Sources/SwiftUI/KeyFunctions/OpenParticipantList/ViewConverters/SBUOpenUserListModule.List+SwiftUI.swift +++ b/Sources/SwiftUI/KeyFunctions/OpenParticipantList/ViewConverters/SBUOpenUserListModule.List+SwiftUI.swift @@ -26,10 +26,7 @@ extension SBUUserListModule.List { let users = self.userList if let tableViewConverter = self.viewConverter.tableView.entireContent, let hostingView = tableViewConverter( - .init( - parentView: self, - users: users - ) + .init() ) { // remove UITableView diff --git a/Sources/SwiftUI/Protocol/ViewControllerTypeProtocol + swiftUI.swift b/Sources/SwiftUI/Protocol/ViewControllerTypeProtocol + swiftUI.swift index 3771d03..44430a4 100644 --- a/Sources/SwiftUI/Protocol/ViewControllerTypeProtocol + swiftUI.swift +++ b/Sources/SwiftUI/Protocol/ViewControllerTypeProtocol + swiftUI.swift @@ -9,7 +9,7 @@ import SwiftUI // MARK: - ViewControllerType -/// A protocol that all `UIView`s conform to, enabling extensions that have a `Self` reference. +/// A protocol that all `UIViewController`s conform to, enabling extensions that have a `Self` reference. protocol ViewControllerType: UIViewController {} // MARK: - ViewType + ViewTypeProtocol @@ -30,5 +30,5 @@ extension ViewControllerType { /// ``` static func swiftUI(makeView: @escaping () -> Self) -> SwiftUIViewController { SwiftUIViewController(makeContent: makeView) - } + } } diff --git a/Sources/SwiftUI/SendbirdSwiftUI-Info.plist b/Sources/SwiftUI/SendbirdSwiftUI-Info.plist index 25a40b0..3b10eb3 100644 --- a/Sources/SwiftUI/SendbirdSwiftUI-Info.plist +++ b/Sources/SwiftUI/SendbirdSwiftUI-Info.plist @@ -15,7 +15,7 @@ CFBundlePackageType $(PRODUCT_BUNDLE_PACKAGE_TYPE) CFBundleShortVersionString - $(SWIFTUI_SHORT_VERSION_STRING) + $(MARKETING_VERSION) CFBundleVersion $(CURRENT_PROJECT_VERSION) SBSwiftUIAppVersion diff --git a/Sources/SwiftUI/Util/ProviderWrappedHostingView.swift b/Sources/SwiftUI/Util/ProviderWrappedHostingView.swift new file mode 100644 index 0000000..7cd939c --- /dev/null +++ b/Sources/SwiftUI/Util/ProviderWrappedHostingView.swift @@ -0,0 +1,61 @@ +// +// ProviderWrappedHostingView.swift +// SendbirdUIKit +// +// Created by Tez Park on 11/8/24. +// + +import SwiftUI + +struct ProviderWrappedHostingView: View { + @ObservedObject var provider: Provider + let content: () -> Content + + init( + provider: Provider, + @ViewBuilder content: @escaping () -> Content + ) { + self.provider = provider + self.content = content + } + + func createHostingView() -> UIView { + let hostingController = UIHostingController(rootView: self) + return hostingController.view + } + + var body: some View { + content() + } +} + +struct ProviderAndConfigWrappedHostingView: View { + @ObservedObject var provider: Provider + let content: () -> Content + + init( + provider: Provider, + @ViewBuilder content: @escaping () -> Content + ) { + self.provider = provider + self.content = content + } + + init( + provider: Provider, + config: Config, + @ViewBuilder content: @escaping (Config) -> Content + ) { + self.provider = provider + self.content = { content(config) } + } + + func createHostingView() -> UIView { + let hostingController = UIHostingController(rootView: self) + return hostingController.view + } + + var body: some View { + return content() + } +} diff --git a/Sources/SwiftUI/Util/StateImpactManager.swift b/Sources/SwiftUI/Util/StateImpactManager.swift new file mode 100644 index 0000000..810c0ce --- /dev/null +++ b/Sources/SwiftUI/Util/StateImpactManager.swift @@ -0,0 +1,17 @@ +// +// StateImpactManager.swift +// SendbirdUIKit +// +// Created by Tez Park on 11/14/24. +// + +import Foundation + +struct StateImpactHandler { + /// This function helps avoid the `publishing changes from within view updates is not allowed, this will cause undefined behavior` error + static func safeExecute(_ work: @escaping () -> Void) { + DispatchQueue.main.async { + work() + } + } +} diff --git a/Sources/SwiftUI/Util/SwiftUIViewController.swift b/Sources/SwiftUI/Util/SwiftUIViewController.swift index 653784f..823c61c 100644 --- a/Sources/SwiftUI/Util/SwiftUIViewController.swift +++ b/Sources/SwiftUI/Util/SwiftUIViewController.swift @@ -22,6 +22,7 @@ struct SwiftUIViewController { /// A closure that's invoked to construct the represented content view. var makeContent: () -> Content var configuration: Configuration? + private var injectionHandler: ((Content) -> Void)? } // MARK: - UIViewControllerRepresentable @@ -45,6 +46,7 @@ extension SwiftUIViewController: UIViewControllerRepresentable { func updateUIViewController(_ viewController: UIViewController, context: Context) { if let navigationController = viewController as? UINavigationController, let uiViewController = navigationController.viewControllers.first as? Content { + injectionHandler?(uiViewController) configuration?(uiViewController) } else { context.coordinator.parentObserver = viewController.observe(\.parent, changeHandler: { viewController, _ in @@ -58,6 +60,7 @@ extension SwiftUIViewController: UIViewControllerRepresentable { }) if let viewController = viewController as? Content { + injectionHandler?(viewController) configuration?(viewController) } } @@ -161,8 +164,15 @@ extension UIResponder { } extension SwiftUIViewController { - /// Returns a copy of this view updated to have the given closure applied to its represented view - /// whenever it is updated via the `updateUIView(…)` method. + /// Injects data into view controller or view model with data provided after the view controller init was finished. + func injectData(injectionHandler: @escaping (Content) -> Void) -> Self { + var copy = self + copy.injectionHandler = injectionHandler + return copy + } + + /// Returns a copy of this view controller updated to have the given closure applied to its represented view controller + /// whenever it is updated via the `updateUIViewController(…)` method. func configure(_ configure: @escaping Configuration) -> Self { var copy = self copy.configuration = configure diff --git a/Sources/Configuration/Mention/SBUMentionConfiguration.swift b/Sources/uikit/Configuration/Mention/SBUMentionConfiguration.swift similarity index 100% rename from Sources/Configuration/Mention/SBUMentionConfiguration.swift rename to Sources/uikit/Configuration/Mention/SBUMentionConfiguration.swift diff --git a/Sources/Configuration/Mention/SBUUserMentionConfiguration.swift b/Sources/uikit/Configuration/Mention/SBUUserMentionConfiguration.swift similarity index 100% rename from Sources/Configuration/Mention/SBUUserMentionConfiguration.swift rename to Sources/uikit/Configuration/Mention/SBUUserMentionConfiguration.swift diff --git a/Sources/Configuration/MessageCell/SBUMessageCellConfiguration.swift b/Sources/uikit/Configuration/MessageCell/SBUMessageCellConfiguration.swift similarity index 100% rename from Sources/Configuration/MessageCell/SBUMessageCellConfiguration.swift rename to Sources/uikit/Configuration/MessageCell/SBUMessageCellConfiguration.swift diff --git a/Sources/Configuration/Replies/SBUReplyConfiguration.swift b/Sources/uikit/Configuration/Replies/SBUReplyConfiguration.swift similarity index 100% rename from Sources/Configuration/Replies/SBUReplyConfiguration.swift rename to Sources/uikit/Configuration/Replies/SBUReplyConfiguration.swift diff --git a/Sources/Configuration/SBUConfig.Base.swift b/Sources/uikit/Configuration/SBUConfig.Base.swift similarity index 100% rename from Sources/Configuration/SBUConfig.Base.swift rename to Sources/uikit/Configuration/SBUConfig.Base.swift diff --git a/Sources/Configuration/SBUConfig.CodingKeys.swift b/Sources/uikit/Configuration/SBUConfig.CodingKeys.swift similarity index 100% rename from Sources/Configuration/SBUConfig.CodingKeys.swift rename to Sources/uikit/Configuration/SBUConfig.CodingKeys.swift diff --git a/Sources/Configuration/SBUConfig.Common.swift b/Sources/uikit/Configuration/SBUConfig.Common.swift similarity index 100% rename from Sources/Configuration/SBUConfig.Common.swift rename to Sources/uikit/Configuration/SBUConfig.Common.swift diff --git a/Sources/Configuration/SBUConfig.GroupChannel.swift b/Sources/uikit/Configuration/SBUConfig.GroupChannel.swift similarity index 100% rename from Sources/Configuration/SBUConfig.GroupChannel.swift rename to Sources/uikit/Configuration/SBUConfig.GroupChannel.swift diff --git a/Sources/Configuration/SBUConfig.OpenChannel.swift b/Sources/uikit/Configuration/SBUConfig.OpenChannel.swift similarity index 100% rename from Sources/Configuration/SBUConfig.OpenChannel.swift rename to Sources/uikit/Configuration/SBUConfig.OpenChannel.swift diff --git a/Sources/Configuration/SBUConfig.swift b/Sources/uikit/Configuration/SBUConfig.swift similarity index 100% rename from Sources/Configuration/SBUConfig.swift rename to Sources/uikit/Configuration/SBUConfig.swift diff --git a/Sources/Configuration/SBUConfigManager.swift b/Sources/uikit/Configuration/SBUConfigManager.swift similarity index 100% rename from Sources/Configuration/SBUConfigManager.swift rename to Sources/uikit/Configuration/SBUConfigManager.swift diff --git a/Sources/Configuration/SBUDashboardConfig.swift b/Sources/uikit/Configuration/SBUDashboardConfig.swift similarity index 100% rename from Sources/Configuration/SBUDashboardConfig.swift rename to Sources/uikit/Configuration/SBUDashboardConfig.swift diff --git a/Sources/Configuration/ScrollPostion/SBUScrollPostionConfiguration.swift b/Sources/uikit/Configuration/ScrollPostion/SBUScrollPostionConfiguration.swift similarity index 100% rename from Sources/Configuration/ScrollPostion/SBUScrollPostionConfiguration.swift rename to Sources/uikit/Configuration/ScrollPostion/SBUScrollPostionConfiguration.swift diff --git a/Sources/Configuration/VoiceMessage/SBUVoiceMessageConfiguration.swift b/Sources/uikit/Configuration/VoiceMessage/SBUVoiceMessageConfiguration.swift similarity index 100% rename from Sources/Configuration/VoiceMessage/SBUVoiceMessageConfiguration.swift rename to Sources/uikit/Configuration/VoiceMessage/SBUVoiceMessageConfiguration.swift diff --git a/Sources/Constant/SBUConstant.swift b/Sources/uikit/Constant/SBUConstant.swift similarity index 100% rename from Sources/Constant/SBUConstant.swift rename to Sources/uikit/Constant/SBUConstant.swift diff --git a/Sources/Constant/SBUDateFormatSet.swift b/Sources/uikit/Constant/SBUDateFormatSet.swift similarity index 100% rename from Sources/Constant/SBUDateFormatSet.swift rename to Sources/uikit/Constant/SBUDateFormatSet.swift diff --git a/Sources/Constant/SBUStringSet.Deprecated.swift b/Sources/uikit/Constant/SBUStringSet.Deprecated.swift similarity index 100% rename from Sources/Constant/SBUStringSet.Deprecated.swift rename to Sources/uikit/Constant/SBUStringSet.Deprecated.swift diff --git a/Sources/Constant/SBUStringSet.swift b/Sources/uikit/Constant/SBUStringSet.swift similarity index 100% rename from Sources/Constant/SBUStringSet.swift rename to Sources/uikit/Constant/SBUStringSet.swift diff --git a/Sources/Deprecated/BaseMesssage+SBUIKit.Deprecated.swift b/Sources/uikit/Deprecated/BaseMesssage+SBUIKit.Deprecated.swift similarity index 100% rename from Sources/Deprecated/BaseMesssage+SBUIKit.Deprecated.swift rename to Sources/uikit/Deprecated/BaseMesssage+SBUIKit.Deprecated.swift diff --git a/Sources/Deprecated/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.Deprecated.swift b/Sources/uikit/Deprecated/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.Deprecated.swift rename to Sources/uikit/Deprecated/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.Deprecated.swift diff --git a/Sources/Deprecated/Channel/MessageCell/Replies/SBUQuotedBaseMessageViewParams.Deprecated.swift b/Sources/uikit/Deprecated/Channel/MessageCell/Replies/SBUQuotedBaseMessageViewParams.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Channel/MessageCell/Replies/SBUQuotedBaseMessageViewParams.Deprecated.swift rename to Sources/uikit/Deprecated/Channel/MessageCell/Replies/SBUQuotedBaseMessageViewParams.Deprecated.swift diff --git a/Sources/Deprecated/Channel/MessageCell/SBUContentBaseMessageCell.Deprecated.swift b/Sources/uikit/Deprecated/Channel/MessageCell/SBUContentBaseMessageCell.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Channel/MessageCell/SBUContentBaseMessageCell.Deprecated.swift rename to Sources/uikit/Deprecated/Channel/MessageCell/SBUContentBaseMessageCell.Deprecated.swift diff --git a/Sources/Deprecated/Channel/SBUBaseChannelViewController.Deprecated.swift b/Sources/uikit/Deprecated/Channel/SBUBaseChannelViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Channel/SBUBaseChannelViewController.Deprecated.swift rename to Sources/uikit/Deprecated/Channel/SBUBaseChannelViewController.Deprecated.swift diff --git a/Sources/Deprecated/Channel/SBUBaseChannelViewController.Unavailable.swift b/Sources/uikit/Deprecated/Channel/SBUBaseChannelViewController.Unavailable.swift similarity index 100% rename from Sources/Deprecated/Channel/SBUBaseChannelViewController.Unavailable.swift rename to Sources/uikit/Deprecated/Channel/SBUBaseChannelViewController.Unavailable.swift diff --git a/Sources/Deprecated/Channel/SBUGroupChannelViewController.Deprecated.swift b/Sources/uikit/Deprecated/Channel/SBUGroupChannelViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Channel/SBUGroupChannelViewController.Deprecated.swift rename to Sources/uikit/Deprecated/Channel/SBUGroupChannelViewController.Deprecated.swift diff --git a/Sources/Deprecated/Channel/SBUGroupChannelViewController.Unavailable.swift b/Sources/uikit/Deprecated/Channel/SBUGroupChannelViewController.Unavailable.swift similarity index 100% rename from Sources/Deprecated/Channel/SBUGroupChannelViewController.Unavailable.swift rename to Sources/uikit/Deprecated/Channel/SBUGroupChannelViewController.Unavailable.swift diff --git a/Sources/Deprecated/Channel/SBUOpenChannelViewController.Deprecated.swift b/Sources/uikit/Deprecated/Channel/SBUOpenChannelViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Channel/SBUOpenChannelViewController.Deprecated.swift rename to Sources/uikit/Deprecated/Channel/SBUOpenChannelViewController.Deprecated.swift diff --git a/Sources/Deprecated/Channel/SBUOpenChannelViewController.Unavailable.swift b/Sources/uikit/Deprecated/Channel/SBUOpenChannelViewController.Unavailable.swift similarity index 100% rename from Sources/Deprecated/Channel/SBUOpenChannelViewController.Unavailable.swift rename to Sources/uikit/Deprecated/Channel/SBUOpenChannelViewController.Unavailable.swift diff --git a/Sources/Deprecated/ChannelList/SBUChannelListViewController.Deprecated.swift b/Sources/uikit/Deprecated/ChannelList/SBUChannelListViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/ChannelList/SBUChannelListViewController.Deprecated.swift rename to Sources/uikit/Deprecated/ChannelList/SBUChannelListViewController.Deprecated.swift diff --git a/Sources/Deprecated/ChannelSettings/SBUBaseChannelSettingsViewController.Deprecated.swift b/Sources/uikit/Deprecated/ChannelSettings/SBUBaseChannelSettingsViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/ChannelSettings/SBUBaseChannelSettingsViewController.Deprecated.swift rename to Sources/uikit/Deprecated/ChannelSettings/SBUBaseChannelSettingsViewController.Deprecated.swift diff --git a/Sources/Deprecated/CreateChannel/SBUCreateChannelViewController.Deprecated.swift b/Sources/uikit/Deprecated/CreateChannel/SBUCreateChannelViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/CreateChannel/SBUCreateChannelViewController.Deprecated.swift rename to Sources/uikit/Deprecated/CreateChannel/SBUCreateChannelViewController.Deprecated.swift diff --git a/Sources/Deprecated/MemberList/SBUMemberListViewController.Deprecated.swift b/Sources/uikit/Deprecated/MemberList/SBUMemberListViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/MemberList/SBUMemberListViewController.Deprecated.swift rename to Sources/uikit/Deprecated/MemberList/SBUMemberListViewController.Deprecated.swift diff --git a/Sources/Deprecated/MessageSearch/SBUMessageSearchViewController.Deprecated.swift b/Sources/uikit/Deprecated/MessageSearch/SBUMessageSearchViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/MessageSearch/SBUMessageSearchViewController.Deprecated.swift rename to Sources/uikit/Deprecated/MessageSearch/SBUMessageSearchViewController.Deprecated.swift diff --git a/Sources/Deprecated/Moderations/SBUModerationsViewController.Deprecated.swift b/Sources/uikit/Deprecated/Moderations/SBUModerationsViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Moderations/SBUModerationsViewController.Deprecated.swift rename to Sources/uikit/Deprecated/Moderations/SBUModerationsViewController.Deprecated.swift diff --git a/Sources/Deprecated/Moderations/SBUModerationsViewModel.Deprecated.swift b/Sources/uikit/Deprecated/Moderations/SBUModerationsViewModel.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Moderations/SBUModerationsViewModel.Deprecated.swift rename to Sources/uikit/Deprecated/Moderations/SBUModerationsViewModel.Deprecated.swift diff --git a/Sources/Deprecated/Module/Channel/Notifications/SBUChatNotificationChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/Channel/Notifications/SBUChatNotificationChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/Channel/Notifications/SBUChatNotificationChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/Channel/Notifications/SBUChatNotificationChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/Channel/Notifications/SBUFeedNotificationChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/Channel/Notifications/SBUFeedNotificationChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/Channel/Notifications/SBUFeedNotificationChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/Channel/Notifications/SBUFeedNotificationChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/Channel/SBUBaseChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/Channel/SBUBaseChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/Channel/SBUBaseChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/Channel/SBUBaseChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/Channel/SBUGroupChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/Channel/SBUGroupChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/Channel/SBUGroupChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/Channel/SBUGroupChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/Channel/SBUOpenChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/Channel/SBUOpenChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/Channel/SBUOpenChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/Channel/SBUOpenChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/ChannelList/SBUGroupChannelListModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/ChannelList/SBUGroupChannelListModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/ChannelList/SBUGroupChannelListModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/ChannelList/SBUGroupChannelListModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/ChannelList/SBUOpenChannelListModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/ChannelList/SBUOpenChannelListModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/ChannelList/SBUOpenChannelListModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/ChannelList/SBUOpenChannelListModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/ChannelSettings/SBUGroupChannelSettingsModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/ChannelSettings/SBUGroupChannelSettingsModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/ChannelSettings/SBUGroupChannelSettingsModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/ChannelSettings/SBUGroupChannelSettingsModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/ChannelSettings/SBUOpenChannelSettingsModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/ChannelSettings/SBUOpenChannelSettingsModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/ChannelSettings/SBUOpenChannelSettingsModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/ChannelSettings/SBUOpenChannelSettingsModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/MessageSearch/SBUMessageSearchModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/MessageSearch/SBUMessageSearchModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/MessageSearch/SBUMessageSearchModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/MessageSearch/SBUMessageSearchModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/MessageThread/SBUMessageThreadModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/MessageThread/SBUMessageThreadModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/MessageThread/SBUMessageThreadModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/MessageThread/SBUMessageThreadModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/Moderations/SBUModerationsModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/Moderations/SBUModerationsModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/Moderations/SBUModerationsModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/Moderations/SBUModerationsModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/SBUModuleSet.Deprecated.swift b/Sources/uikit/Deprecated/Module/SBUModuleSet.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/SBUModuleSet.Deprecated.swift rename to Sources/uikit/Deprecated/Module/SBUModuleSet.Deprecated.swift diff --git a/Sources/Deprecated/Module/SelectUser/SBUCreateChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/SelectUser/SBUCreateChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/SelectUser/SBUCreateChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/SelectUser/SBUCreateChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/SelectUser/SBUCreateOpenChannelModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/SelectUser/SBUCreateOpenChannelModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/SelectUser/SBUCreateOpenChannelModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/SelectUser/SBUCreateOpenChannelModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/SelectUser/SBUInviteUserModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/SelectUser/SBUInviteUserModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/SelectUser/SBUInviteUserModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/SelectUser/SBUInviteUserModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/SelectUser/SBURegisterOperatorModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/SelectUser/SBURegisterOperatorModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/SelectUser/SBURegisterOperatorModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/SelectUser/SBURegisterOperatorModule.Deprecated.swift diff --git a/Sources/Deprecated/Module/UserList/SBUUserListModule.Deprecated.swift b/Sources/uikit/Deprecated/Module/UserList/SBUUserListModule.Deprecated.swift similarity index 100% rename from Sources/Deprecated/Module/UserList/SBUUserListModule.Deprecated.swift rename to Sources/uikit/Deprecated/Module/UserList/SBUUserListModule.Deprecated.swift diff --git a/Sources/Deprecated/SBUBaseViewController.Unavailable.swift b/Sources/uikit/Deprecated/SBUBaseViewController.Unavailable.swift similarity index 100% rename from Sources/Deprecated/SBUBaseViewController.Unavailable.swift rename to Sources/uikit/Deprecated/SBUBaseViewController.Unavailable.swift diff --git a/Sources/Deprecated/SBUCoverImageView.Deprecated.swift b/Sources/uikit/Deprecated/SBUCoverImageView.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUCoverImageView.Deprecated.swift rename to Sources/uikit/Deprecated/SBUCoverImageView.Deprecated.swift diff --git a/Sources/Deprecated/SBUEnums.Deprecated.swift b/Sources/uikit/Deprecated/SBUEnums.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUEnums.Deprecated.swift rename to Sources/uikit/Deprecated/SBUEnums.Deprecated.swift diff --git a/Sources/Deprecated/SBUForm.Deprecated.swift b/Sources/uikit/Deprecated/SBUForm.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUForm.Deprecated.swift rename to Sources/uikit/Deprecated/SBUForm.Deprecated.swift diff --git a/Sources/Deprecated/SBUFormFieldView.Deprecated.swift b/Sources/uikit/Deprecated/SBUFormFieldView.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUFormFieldView.Deprecated.swift rename to Sources/uikit/Deprecated/SBUFormFieldView.Deprecated.swift diff --git a/Sources/Deprecated/SBUFormView.Deprecated.swift b/Sources/uikit/Deprecated/SBUFormView.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUFormView.Deprecated.swift rename to Sources/uikit/Deprecated/SBUFormView.Deprecated.swift diff --git a/Sources/Deprecated/SBUFormViewParams.Deprecated.swift b/Sources/uikit/Deprecated/SBUFormViewParams.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUFormViewParams.Deprecated.swift rename to Sources/uikit/Deprecated/SBUFormViewParams.Deprecated.swift diff --git a/Sources/Deprecated/SBUGlobals.Deprecated.swift b/Sources/uikit/Deprecated/SBUGlobals.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUGlobals.Deprecated.swift rename to Sources/uikit/Deprecated/SBUGlobals.Deprecated.swift diff --git a/Sources/Deprecated/SBUTableViewCell.Unavailable.swift b/Sources/uikit/Deprecated/SBUTableViewCell.Unavailable.swift similarity index 100% rename from Sources/Deprecated/SBUTableViewCell.Unavailable.swift rename to Sources/uikit/Deprecated/SBUTableViewCell.Unavailable.swift diff --git a/Sources/Deprecated/SBUTheme.Deprecated.swift b/Sources/uikit/Deprecated/SBUTheme.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SBUTheme.Deprecated.swift rename to Sources/uikit/Deprecated/SBUTheme.Deprecated.swift diff --git a/Sources/Deprecated/SBUView.Unavaliable.swift b/Sources/uikit/Deprecated/SBUView.Unavaliable.swift similarity index 100% rename from Sources/Deprecated/SBUView.Unavaliable.swift rename to Sources/uikit/Deprecated/SBUView.Unavaliable.swift diff --git a/Sources/Deprecated/SendbirdUI.Deprecated.swift b/Sources/uikit/Deprecated/SendbirdUI.Deprecated.swift similarity index 100% rename from Sources/Deprecated/SendbirdUI.Deprecated.swift rename to Sources/uikit/Deprecated/SendbirdUI.Deprecated.swift diff --git a/Sources/Deprecated/UserList/SBUBaseSelectUserViewController.Deprecated.swift b/Sources/uikit/Deprecated/UserList/SBUBaseSelectUserViewController.Deprecated.swift similarity index 100% rename from Sources/Deprecated/UserList/SBUBaseSelectUserViewController.Deprecated.swift rename to Sources/uikit/Deprecated/UserList/SBUBaseSelectUserViewController.Deprecated.swift diff --git a/Sources/Enums/SBUEnums.swift b/Sources/uikit/Enums/SBUEnums.swift similarity index 99% rename from Sources/Enums/SBUEnums.swift rename to Sources/uikit/Enums/SBUEnums.swift index 0d5bf4f..7439379 100644 --- a/Sources/Enums/SBUEnums.swift +++ b/Sources/uikit/Enums/SBUEnums.swift @@ -439,7 +439,7 @@ public enum SBUChannelType { // - MARK: Internal -/// - Since: 3.26.0 +/// - Since: 3.28.0 enum SBUItemUsageState { case unused case usingDefault(Item) diff --git a/Sources/Enums/SBUIconSetType.swift b/Sources/uikit/Enums/SBUIconSetType.swift similarity index 100% rename from Sources/Enums/SBUIconSetType.swift rename to Sources/uikit/Enums/SBUIconSetType.swift diff --git a/Sources/Enums/VoiceMessageStatus.swift b/Sources/uikit/Enums/VoiceMessageStatus.swift similarity index 100% rename from Sources/Enums/VoiceMessageStatus.swift rename to Sources/uikit/Enums/VoiceMessageStatus.swift diff --git a/Sources/Extension/Array+SBUIKit.swift b/Sources/uikit/Extension/Array+SBUIKit.swift similarity index 100% rename from Sources/Extension/Array+SBUIKit.swift rename to Sources/uikit/Extension/Array+SBUIKit.swift diff --git a/Sources/Extension/CGSize+SBUIKit.swift b/Sources/uikit/Extension/CGSize+SBUIKit.swift similarity index 100% rename from Sources/Extension/CGSize+SBUIKit.swift rename to Sources/uikit/Extension/CGSize+SBUIKit.swift diff --git a/Sources/Extension/ChatSDK/BaseMessage+SBUIKit.MessageTemplate.swift b/Sources/uikit/Extension/ChatSDK/BaseMessage+SBUIKit.MessageTemplate.swift similarity index 100% rename from Sources/Extension/ChatSDK/BaseMessage+SBUIKit.MessageTemplate.swift rename to Sources/uikit/Extension/ChatSDK/BaseMessage+SBUIKit.MessageTemplate.swift diff --git a/Sources/Extension/ChatSDK/BaseMessage+SBUIKit.swift b/Sources/uikit/Extension/ChatSDK/BaseMessage+SBUIKit.swift similarity index 99% rename from Sources/Extension/ChatSDK/BaseMessage+SBUIKit.swift rename to Sources/uikit/Extension/ChatSDK/BaseMessage+SBUIKit.swift index aa0aa4a..09a5815 100644 --- a/Sources/Extension/ChatSDK/BaseMessage+SBUIKit.swift +++ b/Sources/uikit/Extension/ChatSDK/BaseMessage+SBUIKit.swift @@ -60,7 +60,7 @@ extension BaseMessage { } /// Indicates if the message is a stream (being updated) message. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var isStreamMessage: Bool { StreamData.make(self).stream == true } diff --git a/Sources/Extension/ChatSDK/MessageForm+SBUIKit.swift b/Sources/uikit/Extension/ChatSDK/MessageForm+SBUIKit.swift similarity index 100% rename from Sources/Extension/ChatSDK/MessageForm+SBUIKit.swift rename to Sources/uikit/Extension/ChatSDK/MessageForm+SBUIKit.swift diff --git a/Sources/Extension/ChatSDK/MultipleFilesMessage+SBUIKit.swift b/Sources/uikit/Extension/ChatSDK/MultipleFilesMessage+SBUIKit.swift similarity index 100% rename from Sources/Extension/ChatSDK/MultipleFilesMessage+SBUIKit.swift rename to Sources/uikit/Extension/ChatSDK/MultipleFilesMessage+SBUIKit.swift diff --git a/Sources/uikit/Extension/ChatSDK/SendbirdChat+SBUIKit.swift b/Sources/uikit/Extension/ChatSDK/SendbirdChat+SBUIKit.swift new file mode 100644 index 0000000..7e1456f --- /dev/null +++ b/Sources/uikit/Extension/ChatSDK/SendbirdChat+SBUIKit.swift @@ -0,0 +1,14 @@ +// +// SendbirdChat+SBUIKit.swift +// InspectionQuickStart +// +// Created by Jed Gyeong on 9/26/24. +// + +import SendbirdChatSDK + +extension SendbirdChat { + static func isAuthenticated() -> Bool { + return SendbirdChat.getCurrentUser() != nil + } +} diff --git a/Sources/Extension/Collection+SBUIKit.swift b/Sources/uikit/Extension/Collection+SBUIKit.swift similarity index 100% rename from Sources/Extension/Collection+SBUIKit.swift rename to Sources/uikit/Extension/Collection+SBUIKit.swift diff --git a/Sources/Extension/Data+SBUIKit.swift b/Sources/uikit/Extension/Data+SBUIKit.swift similarity index 100% rename from Sources/Extension/Data+SBUIKit.swift rename to Sources/uikit/Extension/Data+SBUIKit.swift diff --git a/Sources/Extension/Date+SBUIKit.swift b/Sources/uikit/Extension/Date+SBUIKit.swift similarity index 100% rename from Sources/Extension/Date+SBUIKit.swift rename to Sources/uikit/Extension/Date+SBUIKit.swift diff --git a/Sources/Extension/Float+SBUIKit.swift b/Sources/uikit/Extension/Float+SBUIKit.swift similarity index 100% rename from Sources/Extension/Float+SBUIKit.swift rename to Sources/uikit/Extension/Float+SBUIKit.swift diff --git a/Sources/Extension/Formatter+SBUIKit.swift b/Sources/uikit/Extension/Formatter+SBUIKit.swift similarity index 100% rename from Sources/Extension/Formatter+SBUIKit.swift rename to Sources/uikit/Extension/Formatter+SBUIKit.swift diff --git a/Sources/Extension/NSLayoutConstraint+SBUIKit.swift b/Sources/uikit/Extension/NSLayoutConstraint+SBUIKit.swift similarity index 100% rename from Sources/Extension/NSLayoutConstraint+SBUIKit.swift rename to Sources/uikit/Extension/NSLayoutConstraint+SBUIKit.swift diff --git a/Sources/Extension/NSObject+SBUIKit.swift b/Sources/uikit/Extension/NSObject+SBUIKit.swift similarity index 100% rename from Sources/Extension/NSObject+SBUIKit.swift rename to Sources/uikit/Extension/NSObject+SBUIKit.swift diff --git a/Sources/Extension/Sequence+SBUIKit.swift b/Sources/uikit/Extension/Sequence+SBUIKit.swift similarity index 100% rename from Sources/Extension/Sequence+SBUIKit.swift rename to Sources/uikit/Extension/Sequence+SBUIKit.swift diff --git a/Sources/Extension/String+SBUIKit.swift b/Sources/uikit/Extension/String+SBUIKit.swift similarity index 89% rename from Sources/Extension/String+SBUIKit.swift rename to Sources/uikit/Extension/String+SBUIKit.swift index cecaa46..b9ccdbe 100644 --- a/Sources/Extension/String+SBUIKit.swift +++ b/Sources/uikit/Extension/String+SBUIKit.swift @@ -78,6 +78,15 @@ extension String { } extension String { + var asURLEncoded: String { + if let components = URLComponents(string: self), + let validURL = components.url { + return validURL.absoluteString + } else { + return self.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) ?? self + } + } + var removedNewLineEscape: String { self.replacingOccurrences(of: "\\n", with: "\n") } diff --git a/Sources/Extension/StringProtocol+SBUIKit.swift b/Sources/uikit/Extension/StringProtocol+SBUIKit.swift similarity index 100% rename from Sources/Extension/StringProtocol+SBUIKit.swift rename to Sources/uikit/Extension/StringProtocol+SBUIKit.swift diff --git a/Sources/Extension/Thread+SBUIKit.swift b/Sources/uikit/Extension/Thread+SBUIKit.swift similarity index 100% rename from Sources/Extension/Thread+SBUIKit.swift rename to Sources/uikit/Extension/Thread+SBUIKit.swift diff --git a/Sources/Extension/UIApplication+SBUIKit.swift b/Sources/uikit/Extension/UIApplication+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIApplication+SBUIKit.swift rename to Sources/uikit/Extension/UIApplication+SBUIKit.swift diff --git a/Sources/Extension/UIButton+SBUIKit.swift b/Sources/uikit/Extension/UIButton+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIButton+SBUIKit.swift rename to Sources/uikit/Extension/UIButton+SBUIKit.swift diff --git a/Sources/Extension/UICollectionView+SBUIKit.swift b/Sources/uikit/Extension/UICollectionView+SBUIKit.swift similarity index 100% rename from Sources/Extension/UICollectionView+SBUIKit.swift rename to Sources/uikit/Extension/UICollectionView+SBUIKit.swift diff --git a/Sources/Extension/UIColor+SBUIKit.swift b/Sources/uikit/Extension/UIColor+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIColor+SBUIKit.swift rename to Sources/uikit/Extension/UIColor+SBUIKit.swift diff --git a/Sources/Extension/UIImage+SBUIKit.swift b/Sources/uikit/Extension/UIImage+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIImage+SBUIKit.swift rename to Sources/uikit/Extension/UIImage+SBUIKit.swift diff --git a/Sources/Extension/UIImageView+SBUIKit.swift b/Sources/uikit/Extension/UIImageView+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIImageView+SBUIKit.swift rename to Sources/uikit/Extension/UIImageView+SBUIKit.swift diff --git a/Sources/Extension/UINavigationController+SBUIKit.swift b/Sources/uikit/Extension/UINavigationController+SBUIKit.swift similarity index 98% rename from Sources/Extension/UINavigationController+SBUIKit.swift rename to Sources/uikit/Extension/UINavigationController+SBUIKit.swift index 1663150..511e785 100644 --- a/Sources/Extension/UINavigationController+SBUIKit.swift +++ b/Sources/uikit/Extension/UINavigationController+SBUIKit.swift @@ -34,7 +34,7 @@ extension UINavigationController { #if SWIFTUI /// Push view controller with hiding navigation bar. Method to hide and show navigationBar in swiftui (ui timing issue) - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func pushViewControllerNonFlickering( _ viewController: UIHostingController, animated: Bool diff --git a/Sources/Extension/UIScrollView+SBUIKit.swift b/Sources/uikit/Extension/UIScrollView+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIScrollView+SBUIKit.swift rename to Sources/uikit/Extension/UIScrollView+SBUIKit.swift diff --git a/Sources/Extension/UIStackView.SBUIKit.swift b/Sources/uikit/Extension/UIStackView.SBUIKit.swift similarity index 100% rename from Sources/Extension/UIStackView.SBUIKit.swift rename to Sources/uikit/Extension/UIStackView.SBUIKit.swift diff --git a/Sources/Extension/UITableView+SBUIKit.swift b/Sources/uikit/Extension/UITableView+SBUIKit.swift similarity index 100% rename from Sources/Extension/UITableView+SBUIKit.swift rename to Sources/uikit/Extension/UITableView+SBUIKit.swift diff --git a/Sources/Extension/UITextField+SBUIKit.swift b/Sources/uikit/Extension/UITextField+SBUIKit.swift similarity index 100% rename from Sources/Extension/UITextField+SBUIKit.swift rename to Sources/uikit/Extension/UITextField+SBUIKit.swift diff --git a/Sources/Extension/UIView+SBUIKit.swift b/Sources/uikit/Extension/UIView+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIView+SBUIKit.swift rename to Sources/uikit/Extension/UIView+SBUIKit.swift diff --git a/Sources/Extension/UIViewController+SBUIKit.swift b/Sources/uikit/Extension/UIViewController+SBUIKit.swift similarity index 100% rename from Sources/Extension/UIViewController+SBUIKit.swift rename to Sources/uikit/Extension/UIViewController+SBUIKit.swift diff --git a/Sources/Extension/URL+SBUIKit.swift b/Sources/uikit/Extension/URL+SBUIKit.swift similarity index 100% rename from Sources/Extension/URL+SBUIKit.swift rename to Sources/uikit/Extension/URL+SBUIKit.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.Config.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.Config.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.Config.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.Config.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.File.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.File.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.File.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.File.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.Image.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.Image.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.Image.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.Image.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.NotificationSetting.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.NotificationSetting.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.NotificationSetting.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.NotificationSetting.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.Template.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.Template.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.Template.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.Template.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.Version.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.Version.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.Version.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.Version.swift diff --git a/Sources/Manager/CacheManager/SBUCacheManager.swift b/Sources/uikit/Manager/CacheManager/SBUCacheManager.swift similarity index 100% rename from Sources/Manager/CacheManager/SBUCacheManager.swift rename to Sources/uikit/Manager/CacheManager/SBUCacheManager.swift diff --git a/Sources/Manager/SBUDownloadManager.swift b/Sources/uikit/Manager/SBUDownloadManager.swift similarity index 100% rename from Sources/Manager/SBUDownloadManager.swift rename to Sources/uikit/Manager/SBUDownloadManager.swift diff --git a/Sources/Manager/SBUEmojiManager.swift b/Sources/uikit/Manager/SBUEmojiManager.swift similarity index 100% rename from Sources/Manager/SBUEmojiManager.swift rename to Sources/uikit/Manager/SBUEmojiManager.swift diff --git a/Sources/Manager/SBUMessageTemplateManager.swift b/Sources/uikit/Manager/SBUMessageTemplateManager.swift similarity index 82% rename from Sources/Manager/SBUMessageTemplateManager.swift rename to Sources/uikit/Manager/SBUMessageTemplateManager.swift index 6124f1c..75bf95b 100644 --- a/Sources/Manager/SBUMessageTemplateManager.swift +++ b/Sources/uikit/Manager/SBUMessageTemplateManager.swift @@ -10,6 +10,9 @@ import UIKit import SendbirdChatSDK public class SBUMessageTemplateManager: NSObject { + static var templateDownloadRetryCount: [String: Int] = [:] + + static let retryCountQueue = DispatchQueue(label: "com.sendbird.message_template.retry_count.queue") /// Resets notification template cache /// - Since: 3.21.0 @@ -24,6 +27,23 @@ public class SBUMessageTemplateManager: NSObject { } static let exeucuteQueue = DispatchQueue(label: "com.sendbird.message_template.images") + + static func increaseTemplateDownloadRetryCount(templateKey: String) { + retryCountQueue.sync { + let retryCount = templateDownloadRetryCount[templateKey] ?? 0 + templateDownloadRetryCount[templateKey] = retryCount + 1 + + SBULog.info("Template download retry count for \(templateKey) increased to: \(templateDownloadRetryCount[templateKey]!)") + } + } + + static func isTemplateDownloadRetryAvailable(templateKey: String) -> Bool { + retryCountQueue.sync { + let retryCount = templateDownloadRetryCount[templateKey] ?? 0 + SBULog.info("Template download retry count for \(templateKey): \(retryCount)") + return retryCount < 10 + } + } } // MARK: - Template list @@ -142,28 +162,34 @@ extension SBUMessageTemplateManager { let cache = SBUCacheManager.template(with: type) if let template = cache.getTemplate(forKey: templateKey) { + SBULog.info("\(templateKey) is in cache") return template - } else { - type.loadTemplate(key: templateKey) { jsonPayload, error in - guard let jsonPayload = jsonPayload, let jsonData = jsonPayload.data(using: .utf8) else { - newTemplateResponseHandler?(false) - return - } + } + + guard isTemplateDownloadRetryAvailable(templateKey: templateKey) else { return nil } + + type.loadTemplate(key: templateKey) { jsonPayload, error in + guard let jsonPayload = jsonPayload, let jsonData = jsonPayload.data(using: .utf8) else { + increaseTemplateDownloadRetryCount(templateKey: templateKey) + newTemplateResponseHandler?(false) + return + } - do { - if let templateDic = try JSONSerialization.jsonObject(with: jsonData, options: []) as? [String: Any], - let template = try SBUMessageTemplate.TemplateModel.createTemplate(with: templateDic) { - cache.save(templates: [template]) - _ = cache.loadAllTemplates() - newTemplateResponseHandler?(true) - } - } catch { - newTemplateResponseHandler?(false) - SBULog.error(error.localizedDescription) + do { + if let templateDic = try JSONSerialization.jsonObject(with: jsonData, options: []) as? [String: Any], + let template = try SBUMessageTemplate.TemplateModel.createTemplate(with: templateDic) { + cache.save(templates: [template]) + _ = cache.loadAllTemplates() + newTemplateResponseHandler?(true) } + } catch { + increaseTemplateDownloadRetryCount(templateKey: templateKey) + newTemplateResponseHandler?(false) + SBULog.error(error.localizedDescription) } - return nil } + + return nil } // original diff --git a/Sources/Manager/SBUNotificationChannelManager.swift b/Sources/uikit/Manager/SBUNotificationChannelManager.swift similarity index 100% rename from Sources/Manager/SBUNotificationChannelManager.swift rename to Sources/uikit/Manager/SBUNotificationChannelManager.swift diff --git a/Sources/Manager/SBUPendingMessageManager.swift b/Sources/uikit/Manager/SBUPendingMessageManager.swift similarity index 100% rename from Sources/Manager/SBUPendingMessageManager.swift rename to Sources/uikit/Manager/SBUPendingMessageManager.swift diff --git a/Sources/Manager/SBUPermissionManager.swift b/Sources/uikit/Manager/SBUPermissionManager.swift similarity index 100% rename from Sources/Manager/SBUPermissionManager.swift rename to Sources/uikit/Manager/SBUPermissionManager.swift diff --git a/Sources/Manager/SBUTemplateType.swift b/Sources/uikit/Manager/SBUTemplateType.swift similarity index 100% rename from Sources/Manager/SBUTemplateType.swift rename to Sources/uikit/Manager/SBUTemplateType.swift diff --git a/Sources/Manager/SBUTypingIndicatorMessageManager.swift b/Sources/uikit/Manager/SBUTypingIndicatorMessageManager.swift similarity index 100% rename from Sources/Manager/SBUTypingIndicatorMessageManager.swift rename to Sources/uikit/Manager/SBUTypingIndicatorMessageManager.swift diff --git a/Sources/Manager/SBUVoicePlayer.swift b/Sources/uikit/Manager/SBUVoicePlayer.swift similarity index 100% rename from Sources/Manager/SBUVoicePlayer.swift rename to Sources/uikit/Manager/SBUVoicePlayer.swift diff --git a/Sources/Manager/SBUVoiceRecorder.swift b/Sources/uikit/Manager/SBUVoiceRecorder.swift similarity index 100% rename from Sources/Manager/SBUVoiceRecorder.swift rename to Sources/uikit/Manager/SBUVoiceRecorder.swift diff --git a/Sources/MessageTemplate/Processor/SBUMessageTemplate.Binder.swift b/Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Binder.swift similarity index 100% rename from Sources/MessageTemplate/Processor/SBUMessageTemplate.Binder.swift rename to Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Binder.swift diff --git a/Sources/MessageTemplate/Processor/SBUMessageTemplate.Container.swift b/Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Container.swift similarity index 100% rename from Sources/MessageTemplate/Processor/SBUMessageTemplate.Container.swift rename to Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Container.swift diff --git a/Sources/MessageTemplate/Processor/SBUMessageTemplate.Coordinator.swift b/Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Coordinator.swift similarity index 100% rename from Sources/MessageTemplate/Processor/SBUMessageTemplate.Coordinator.swift rename to Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Coordinator.swift diff --git a/Sources/MessageTemplate/Processor/SBUMessageTemplate.Payload.swift b/Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Payload.swift similarity index 100% rename from Sources/MessageTemplate/Processor/SBUMessageTemplate.Payload.swift rename to Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.Payload.swift diff --git a/Sources/MessageTemplate/Processor/SBUMessageTemplate.PayloadType.swift b/Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.PayloadType.swift similarity index 100% rename from Sources/MessageTemplate/Processor/SBUMessageTemplate.PayloadType.swift rename to Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.PayloadType.swift diff --git a/Sources/MessageTemplate/Processor/SBUMessageTemplate.TemplateList.swift b/Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.TemplateList.swift similarity index 100% rename from Sources/MessageTemplate/Processor/SBUMessageTemplate.TemplateList.swift rename to Sources/uikit/MessageTemplate/Processor/SBUMessageTemplate.TemplateList.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Events.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Events.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Events.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Events.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderItems.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderItems.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderItems.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderItems.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderStyles.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderStyles.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderStyles.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+RenderStyles.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Utils.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Utils.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Utils.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer+Utils.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Image.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Image.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Image.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Image.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.RendererType.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.RendererType.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.RendererType.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.RendererType.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Views.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Views.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Views.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.Views.swift diff --git a/Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.swift b/Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.swift similarity index 100% rename from Sources/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.swift rename to Sources/uikit/MessageTemplate/Renderer/SBUMessageTemplate.Renderer.swift diff --git a/Sources/MessageTemplate/SBUMessageTemplate.swift b/Sources/uikit/MessageTemplate/SBUMessageTemplate.swift similarity index 100% rename from Sources/MessageTemplate/SBUMessageTemplate.swift rename to Sources/uikit/MessageTemplate/SBUMessageTemplate.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Action.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Action.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Action.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Action.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Decoders.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Decoders.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Decoders.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Decoders.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.ErrorMessages.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.ErrorMessages.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.ErrorMessages.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.ErrorMessages.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.ImageRatioType.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.ImageRatioType.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.ImageRatioType.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.ImageRatioType.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Aligns.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Aligns.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Aligns.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Aligns.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Identifier.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Identifier.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Identifier.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Identifier.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Item.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Item.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Item.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Item.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Sizes.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Sizes.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Sizes.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Sizes.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Styles.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Styles.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Styles.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Styles.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Types.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Types.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Types.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Types.swift diff --git a/Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Views.swift b/Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Views.swift similarity index 100% rename from Sources/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Views.swift rename to Sources/uikit/MessageTemplate/Syntax/SBUMessageTemplate.Syntax.Views.swift diff --git a/Sources/MessageTemplate/Tester/MessageTemplateParserTest.swift b/Sources/uikit/MessageTemplate/Tester/MessageTemplateParserTest.swift similarity index 100% rename from Sources/MessageTemplate/Tester/MessageTemplateParserTest.swift rename to Sources/uikit/MessageTemplate/Tester/MessageTemplateParserTest.swift diff --git a/Sources/MessageTemplate/Tester/MessageTemplateTestViewController.swift b/Sources/uikit/MessageTemplate/Tester/MessageTemplateTestViewController.swift similarity index 100% rename from Sources/MessageTemplate/Tester/MessageTemplateTestViewController.swift rename to Sources/uikit/MessageTemplate/Tester/MessageTemplateTestViewController.swift diff --git a/Sources/Model/SBUError.swift b/Sources/uikit/Model/SBUError.swift similarity index 100% rename from Sources/Model/SBUError.swift rename to Sources/uikit/Model/SBUError.swift diff --git a/Sources/Model/SBUExtendedMessagePayload.swift b/Sources/uikit/Model/SBUExtendedMessagePayload.swift similarity index 100% rename from Sources/Model/SBUExtendedMessagePayload.swift rename to Sources/uikit/Model/SBUExtendedMessagePayload.swift diff --git a/Sources/Model/SBUExtendedMessagePayloadForUI.swift b/Sources/uikit/Model/SBUExtendedMessagePayloadForUI.swift similarity index 100% rename from Sources/Model/SBUExtendedMessagePayloadForUI.swift rename to Sources/uikit/Model/SBUExtendedMessagePayloadForUI.swift diff --git a/Sources/Model/SBUFeedbackAction.swift b/Sources/uikit/Model/SBUFeedbackAction.swift similarity index 100% rename from Sources/Model/SBUFeedbackAction.swift rename to Sources/uikit/Model/SBUFeedbackAction.swift diff --git a/Sources/Model/SBUHighlightMessageInfo.swift b/Sources/uikit/Model/SBUHighlightMessageInfo.swift similarity index 100% rename from Sources/Model/SBUHighlightMessageInfo.swift rename to Sources/uikit/Model/SBUHighlightMessageInfo.swift diff --git a/Sources/Model/SBUMention.swift b/Sources/uikit/Model/SBUMention.swift similarity index 100% rename from Sources/Model/SBUMention.swift rename to Sources/uikit/Model/SBUMention.swift diff --git a/Sources/Model/SBUMessageCache.swift b/Sources/uikit/Model/SBUMessageCache.swift similarity index 100% rename from Sources/Model/SBUMessageCache.swift rename to Sources/uikit/Model/SBUMessageCache.swift diff --git a/Sources/Model/SBUScrollOptions.swift b/Sources/uikit/Model/SBUScrollOptions.swift similarity index 100% rename from Sources/Model/SBUScrollOptions.swift rename to Sources/uikit/Model/SBUScrollOptions.swift diff --git a/Sources/Model/SBUTypingIndicatorInfo.swift b/Sources/uikit/Model/SBUTypingIndicatorInfo.swift similarity index 100% rename from Sources/Model/SBUTypingIndicatorInfo.swift rename to Sources/uikit/Model/SBUTypingIndicatorInfo.swift diff --git a/Sources/Model/SBUTypingIndicatorMessage.swift b/Sources/uikit/Model/SBUTypingIndicatorMessage.swift similarity index 100% rename from Sources/Model/SBUTypingIndicatorMessage.swift rename to Sources/uikit/Model/SBUTypingIndicatorMessage.swift diff --git a/Sources/Model/SBUUser.swift b/Sources/uikit/Model/SBUUser.swift similarity index 100% rename from Sources/Model/SBUUser.swift rename to Sources/uikit/Model/SBUUser.swift diff --git a/Sources/Model/SBUVoiceFileInfo.swift b/Sources/uikit/Model/SBUVoiceFileInfo.swift similarity index 100% rename from Sources/Model/SBUVoiceFileInfo.swift rename to Sources/uikit/Model/SBUVoiceFileInfo.swift diff --git a/Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.Header.swift b/Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.Header.swift similarity index 100% rename from Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.Header.swift rename to Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.Header.swift diff --git a/Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.Input.swift b/Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.Input.swift similarity index 100% rename from Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.Input.swift rename to Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.Input.swift diff --git a/Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.List.swift b/Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.List.swift similarity index 100% rename from Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.List.swift rename to Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.List.swift diff --git a/Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.swift b/Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.swift similarity index 90% rename from Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.swift rename to Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.swift index 6dc9c49..da0ab6a 100644 --- a/Sources/Module/Channel/GroupChannel/SBUGroupChannelModule.swift +++ b/Sources/uikit/Module/Channel/GroupChannel/SBUGroupChannelModule.swift @@ -26,76 +26,76 @@ extension SBUGroupChannelModule { // MARK: Header extension SBUGroupChannelModule.Header { /// Represents the type of left bar button on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of right bar button on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of title view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUChannelTitleView.Type = SBUChannelTitleView.self } // MARK: List extension SBUGroupChannelModule.List { /// Represents the type of empty view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of admin message cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var AdminMessageCell: SBUBaseMessageCell.Type = SBUAdminMessageCell.self /// Represents the type of user message cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserMessageCell: SBUBaseMessageCell.Type = SBUUserMessageCell.self /// Represents the type of file message cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var FileMessageCell: SBUBaseMessageCell.Type = SBUFileMessageCell.self /// Represents the type of multiple files message cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MultipleFilesMessageCell: SBUBaseMessageCell.Type = SBUMultipleFilesMessageCell.self /// Represents the type of typing indicator cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TypingIndicatorMessageCell: SBUBaseMessageCell.Type = SBUTypingIndicatorMessageCell.self /// Represents the type of unknown cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UnknownMessageCell: SBUBaseMessageCell.Type = SBUUnknownMessageCell.self /// Represents the type of custom cell on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var CustomMessageCell: SBUBaseMessageCell.Type? /// Represents the type of channel state banner view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelStateBanner: SBUChannelStateBanner.Type = SBUChannelStateBanner.self /// Represents the type of scroll bottom view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ScrollBottomView: SBUScrollBottomView.Type = SBUScrollBottomView.self /// Represents the type of message info view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var NewMessageInfo: SBUNewMessageInfo.Type = SBUNewMessageInfo.self /// Represents the type of profile view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserProfileView: SBUUserProfileView.Type = SBUUserProfileView.self } // MARK: Input extension SBUGroupChannelModule.Input { /// The component property that the message input view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MessageInputView: SBUMessageInputView.Type = SBUMessageInputView.self /// The component property that the voice message input view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var VoiceMessageInputView: SBUVoiceMessageInputView.Type = SBUVoiceMessageInputView.self } diff --git a/Sources/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.Header.swift b/Sources/uikit/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.Header.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.Header.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.Header.swift diff --git a/Sources/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.List.swift b/Sources/uikit/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.List.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.List.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.List.swift diff --git a/Sources/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.swift b/Sources/uikit/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Chat/SBUChatNotificationChannelModule.swift diff --git a/Sources/Module/Channel/NotificationChannel/Feed/Params/SBUFeedNotificationChannelViewParams.swift b/Sources/uikit/Module/Channel/NotificationChannel/Feed/Params/SBUFeedNotificationChannelViewParams.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Feed/Params/SBUFeedNotificationChannelViewParams.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Feed/Params/SBUFeedNotificationChannelViewParams.swift diff --git a/Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.CategoryFilter.swift b/Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.CategoryFilter.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.CategoryFilter.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.CategoryFilter.swift diff --git a/Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.Header.swift b/Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.Header.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.Header.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.Header.swift diff --git a/Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.List.swift b/Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.List.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.List.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.List.swift diff --git a/Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.swift b/Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.swift similarity index 100% rename from Sources/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.swift rename to Sources/uikit/Module/Channel/NotificationChannel/Feed/SBUFeedNotificationChannelModule.swift diff --git a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift similarity index 99% rename from Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift rename to Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift index e0d822e..ce0c813 100644 --- a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift +++ b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Header.swift @@ -62,7 +62,7 @@ extension SBUOpenChannelModule { } /// A view that represents right bar items in navigation bar. - /// - Since: 3.26.0 + /// - Since: 3.28.0 /// - NOTE: When the value is updated, `baseChannelModule(_:didUpdateRightItems:)` delegate function is called. override public var rightBarButtons: [UIBarButtonItem]? { get { self.internalRightBarButtons.item ?? nil } diff --git a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Input.swift b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Input.swift similarity index 100% rename from Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Input.swift rename to Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Input.swift diff --git a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.List.swift b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.List.swift similarity index 100% rename from Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.List.swift rename to Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.List.swift diff --git a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Media.swift b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Media.swift similarity index 100% rename from Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.Media.swift rename to Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.Media.swift diff --git a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.swift b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.swift similarity index 91% rename from Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.swift rename to Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.swift index a135c3a..3c339ed 100644 --- a/Sources/Module/Channel/OpenChannel/SBUOpenChannelModule.swift +++ b/Sources/uikit/Module/Channel/OpenChannel/SBUOpenChannelModule.swift @@ -29,68 +29,68 @@ extension SBUOpenChannelModule { // MARK: Header extension SBUOpenChannelModule.Header { /// Represents the type of left bar button on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of right bar button on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of title view on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUChannelTitleView.Type = SBUChannelTitleView.self } // MARK: List extension SBUOpenChannelModule.List { /// Represents the type of empty view on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of admin message cell on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var AdminMessageCell: SBUOpenChannelBaseMessageCell.Type = SBUOpenChannelAdminMessageCell.self /// Represents the type of user message cell on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserMessageCell: SBUOpenChannelBaseMessageCell.Type = SBUOpenChannelUserMessageCell.self /// Represents the type of file message cell on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var FileMessageCell: SBUOpenChannelBaseMessageCell.Type = SBUOpenChannelFileMessageCell.self /// Represents the type of unknown message cell on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UnknownMessageCell: SBUOpenChannelBaseMessageCell.Type = SBUOpenChannelUnknownMessageCell.self /// Represents the type of custom message cell on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var CustomMessageCell: SBUOpenChannelBaseMessageCell.Type? /// Represents the type of channel state banner on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelStateBanner: SBUChannelStateBanner.Type = SBUChannelStateBanner.self /// Represents the type of scroll bottom view on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ScrollBottomView: SBUScrollBottomView.Type = SBUScrollBottomView.self /// Represents the type of user profile view on the open channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserProfileView: SBUUserProfileView.Type = SBUUserProfileView.self } // MARK: Input extension SBUOpenChannelModule.Input { /// The component property that the message input view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MessageInputView: SBUMessageInputView.Type = SBUMessageInputView.self } // MARK: Media extension SBUOpenChannelModule.Media { /// A view to shows media or other contents in the open channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MediaView: SBUMediaView.Type = SBUMediaView.self } diff --git a/Sources/Module/Channel/SBUBaseChannelModule.Header.swift b/Sources/uikit/Module/Channel/SBUBaseChannelModule.Header.swift similarity index 99% rename from Sources/Module/Channel/SBUBaseChannelModule.Header.swift rename to Sources/uikit/Module/Channel/SBUBaseChannelModule.Header.swift index ca715d8..8b6f07d 100644 --- a/Sources/Module/Channel/SBUBaseChannelModule.Header.swift +++ b/Sources/uikit/Module/Channel/SBUBaseChannelModule.Header.swift @@ -33,14 +33,14 @@ public protocol SBUBaseChannelModuleHeaderDelegate: SBUCommonDelegate { /// - Parameters: /// - headerComponent: `SBUBaseChannelModule.Header` object /// - rightItem: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func baseChannelModule(_ headerComponent: SBUBaseChannelModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` value has been updated. /// - Parameters: /// - headerComponent: `SBUBaseChannelModule.Header` object /// - rightItem: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func baseChannelModule(_ headerComponent: SBUBaseChannelModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `titleView` was selected. @@ -116,7 +116,7 @@ extension SBUBaseChannelModule { var internalRightBarButton: SBUItemUsageState = .unused /// A view that represents left bar items in navigation bar. - /// - Since: 3.26.0 + /// - Since: 3.28.0 /// - NOTE: When the value is updated, `baseChannelModule(_:didUpdateLeftItems:)` delegate function is called. public var leftBarButtons: [UIBarButtonItem]? { didSet { @@ -125,7 +125,7 @@ extension SBUBaseChannelModule { } /// A view that represents right bar items in navigation bar. - /// - Since: 3.26.0 + /// - Since: 3.28.0 /// - NOTE: When the value is updated, `baseChannelModule(_:didUpdateRightItems:)` delegate function is called. public var rightBarButtons: [UIBarButtonItem]? { didSet { diff --git a/Sources/Module/Channel/SBUBaseChannelModule.Input.swift b/Sources/uikit/Module/Channel/SBUBaseChannelModule.Input.swift similarity index 100% rename from Sources/Module/Channel/SBUBaseChannelModule.Input.swift rename to Sources/uikit/Module/Channel/SBUBaseChannelModule.Input.swift diff --git a/Sources/Module/Channel/SBUBaseChannelModule.List.swift b/Sources/uikit/Module/Channel/SBUBaseChannelModule.List.swift similarity index 100% rename from Sources/Module/Channel/SBUBaseChannelModule.List.swift rename to Sources/uikit/Module/Channel/SBUBaseChannelModule.List.swift diff --git a/Sources/Module/Channel/SBUBaseChannelModule.swift b/Sources/uikit/Module/Channel/SBUBaseChannelModule.swift similarity index 100% rename from Sources/Module/Channel/SBUBaseChannelModule.swift rename to Sources/uikit/Module/Channel/SBUBaseChannelModule.swift diff --git a/Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Common.swift b/Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Common.swift similarity index 100% rename from Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Common.swift rename to Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Common.swift diff --git a/Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Header.swift b/Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Header.swift similarity index 100% rename from Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Header.swift rename to Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.Header.swift diff --git a/Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.List.swift b/Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.List.swift similarity index 100% rename from Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.List.swift rename to Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.List.swift diff --git a/Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift b/Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift similarity index 92% rename from Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift rename to Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift index d102ba9..1353e6b 100644 --- a/Sources/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift +++ b/Sources/uikit/Module/ChannelList/GroupChannel/SBUGroupChannelListModule.swift @@ -19,33 +19,33 @@ extension SBUGroupChannelListModule { public static var ListComponent: SBUGroupChannelListModule.List.Type = SBUGroupChannelListModule.List.self /// The module component that shows the common of message in the channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var CommonComponent: SBUGroupChannelListModule.Common.Type = SBUGroupChannelListModule.Common.self } // MARK: Header extension SBUGroupChannelListModule.Header { /// Represents the type of left bar button on the group channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of right bar button on the group channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of title view on the group channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self } // MARK: List extension SBUGroupChannelListModule.List { /// Represents the type of empty view on the group channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of channel cell on the group channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelCell: SBUBaseChannelCell.Type = SBUGroupChannelCell.self } @@ -59,7 +59,7 @@ extension SBUGroupChannelListModule.Common { /// SBUModuleSet.GroupChannelList.Common.CreateChannelTypeSelector = CustomTypeSelector.self /// ``` /// - Note: To apply the custom type selector, assign your subclass of ``SBUCreateChannelTypeSelector`` to this property. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var CreateChannelTypeSelector: SBUCreateChannelTypeSelector.Type = SBUCreateChannelTypeSelector.self } @@ -67,19 +67,19 @@ extension SBUGroupChannelListModule.Common { extension SBUModuleSet { // Module /// The class that represents the list of the group channel module - /// - Since: 3.26.0 + /// - Since: 3.28.0 public typealias GroupChannelList = SBUGroupChannelListModule // Components /// The module component that shows the header in the channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public typealias Header = SBUGroupChannelListModule.Header /// The module component that shows the list of message in the channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public typealias List = SBUGroupChannelListModule.List /// The module component that shows the common view in the channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public typealias Common = SBUGroupChannelListModule.Common } diff --git a/Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.Header.swift b/Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.Header.swift similarity index 100% rename from Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.Header.swift rename to Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.Header.swift diff --git a/Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.List.swift b/Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.List.swift similarity index 100% rename from Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.List.swift rename to Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.List.swift diff --git a/Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift b/Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift similarity index 93% rename from Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift rename to Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift index cac1728..9e58bee 100644 --- a/Sources/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift +++ b/Sources/uikit/Module/ChannelList/OpenChannel/SBUOpenChannelListModule.swift @@ -24,25 +24,25 @@ extension SBUOpenChannelListModule { // MARK: Header extension SBUOpenChannelListModule.Header { /// Represents the type of left bar button on the open channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of right bar button on the open channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of title view on the open channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self } // MARK: List extension SBUOpenChannelListModule.List { /// Represents the type of empty view on the open channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of channel cell on the open channel list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelCell: SBUBaseChannelCell.Type = SBUOpenChannelCell.self } diff --git a/Sources/Module/ChannelList/SBUBaseChannelListModule.Header.swift b/Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.Header.swift similarity index 98% rename from Sources/Module/ChannelList/SBUBaseChannelListModule.Header.swift rename to Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.Header.swift index 4a993d4..fe4b3c6 100644 --- a/Sources/Module/ChannelList/SBUBaseChannelListModule.Header.swift +++ b/Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.Header.swift @@ -33,14 +33,14 @@ public protocol SBUBaseChannelListModuleHeaderDelegate: SBUCommonDelegate { /// - Parameters: /// - headerComponent: `SBUBaseChannelListModule.Header` object /// - leftItems: The updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func baseChannelListModule(_ headerComponent: SBUBaseChannelListModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was updated. /// - Parameters: /// - headerComponent: `SBUBaseChannelListModule.Header` object /// - rightItems: The updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func baseChannelListModule(_ headerComponent: SBUBaseChannelListModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. @@ -106,14 +106,14 @@ extension SBUBaseChannelListModule { /// A view that represents the left `[UIBarButtonItem]` in the navigation bar. /// - NOTE: When the value is updated, `channelListModule(_:didUpdateLeftItems:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var leftBarButtons: [UIBarButtonItem]? { didSet { self.didUpdateLeftItems() } } /// A view that represents the right `[UIBarButtonItem]` in the navigation bar. /// - NOTE: When the value is updated, `channelListModule(_:didUpdateRightItems:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var rightBarButtons: [UIBarButtonItem]? { didSet { self.didUpdateRightItems() } } diff --git a/Sources/Module/ChannelList/SBUBaseChannelListModule.List.swift b/Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.List.swift similarity index 100% rename from Sources/Module/ChannelList/SBUBaseChannelListModule.List.swift rename to Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.List.swift diff --git a/Sources/Module/ChannelList/SBUBaseChannelListModule.swift b/Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.swift similarity index 100% rename from Sources/Module/ChannelList/SBUBaseChannelListModule.swift rename to Sources/uikit/Module/ChannelList/SBUBaseChannelListModule.swift diff --git a/Sources/Module/ChannelSettings/ChannelSettingItem/SBUChannelSettingItem.swift b/Sources/uikit/Module/ChannelSettings/ChannelSettingItem/SBUChannelSettingItem.swift similarity index 100% rename from Sources/Module/ChannelSettings/ChannelSettingItem/SBUChannelSettingItem.swift rename to Sources/uikit/Module/ChannelSettings/ChannelSettingItem/SBUChannelSettingItem.swift diff --git a/Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift b/Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift similarity index 99% rename from Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift rename to Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift index 77f0dbe..9df9a7e 100644 --- a/Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift +++ b/Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.Header.swift @@ -34,14 +34,14 @@ public protocol SBUGroupChannelSettingsModuleHeaderDelegate: SBUBaseChannelSetti /// - Parameters: /// - headerComponent: `SBUGroupChannelSettingsModule.Header` object /// - leftItem: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func groupChannelSettingsModule(_ headerComponent: SBUGroupChannelSettingsModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was selected. /// - Parameters: /// - headerComponent: `SBUGroupChannelSettingsModule.Header` object /// - rightItem: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func groupChannelSettingsModule(_ headerComponent: SBUGroupChannelSettingsModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. diff --git a/Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.List.swift b/Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.List.swift similarity index 100% rename from Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.List.swift rename to Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.List.swift diff --git a/Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift b/Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift similarity index 94% rename from Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift rename to Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift index 24e172d..9a99e2a 100644 --- a/Sources/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift +++ b/Sources/uikit/Module/ChannelSettings/GroupChannel/SBUGroupChannelSettingsModule.swift @@ -23,15 +23,15 @@ extension SBUGroupChannelSettingsModule { // MARK: Header extension SBUGroupChannelSettingsModule.Header { /// Represents the metatype of left bar button on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of right bar button on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self } @@ -39,10 +39,10 @@ extension SBUGroupChannelSettingsModule.Header { extension SBUGroupChannelSettingsModule.List { /// Represents the metatype of channel info view on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelInfoView: SBUChannelSettingsChannelInfoView.Type = SBUChannelSettingsChannelInfoView.self /// Represents the metatype of setting cell on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var SettingCell: SBUGroupChannelSettingCell.Type = SBUGroupChannelSettingCell.self } diff --git a/Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift b/Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift similarity index 99% rename from Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift rename to Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift index 9016fa0..64f8e63 100644 --- a/Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift +++ b/Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.Header.swift @@ -46,14 +46,14 @@ public protocol SBUOpenChannelSettingsModuleHeaderDelegate: SBUBaseChannelSettin /// - Parameters: /// - headerComponent: `SBUOpenChannelSettingsModule.Header` object /// - leftItems: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func openChannelSettingsModule(_ headerComponent: SBUOpenChannelSettingsModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was updated. /// - Parameters: /// - headerComponent: `SBUOpenChannelSettingsModule.Header` object /// - rightItems: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func openChannelSettingsModule(_ headerComponent: SBUOpenChannelSettingsModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) } diff --git a/Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.List.swift b/Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.List.swift similarity index 100% rename from Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.List.swift rename to Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.List.swift diff --git a/Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift b/Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift similarity index 94% rename from Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift rename to Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift index 13a4d0d..8bbed18 100644 --- a/Sources/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift +++ b/Sources/uikit/Module/ChannelSettings/OpenChannel/SBUOpenChannelSettingsModule.swift @@ -23,25 +23,25 @@ extension SBUOpenChannelSettingsModule { // MARK: Header extension SBUOpenChannelSettingsModule.Header { /// Represents the type of left bar button on the open channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of right bar button on the open channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of title view on the open channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self } // MARK: List extension SBUOpenChannelSettingsModule.List { /// Represents the type of channel info view on the open channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelInfoView: SBUChannelSettingsChannelInfoView.Type = SBUChannelSettingsChannelInfoView.self /// Represents the type of setting cell on the open channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var SettingCell: SBUOpenChannelSettingCell.Type = SBUOpenChannelSettingCell.self } diff --git a/Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift b/Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift similarity index 99% rename from Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift rename to Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift index cedf18d..393f927 100644 --- a/Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift +++ b/Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.Header.swift @@ -61,14 +61,14 @@ extension SBUBaseChannelSettingsModule { /// A view that represents a left `UIBarButtonItem` in navigation bar. /// - NOTE: When the value is updated, `didUpdateRightItem`is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var leftBarButtons: [UIBarButtonItem]? { didSet { self.didUpdateLeftItems() } } /// A view that represents a right `UIBarButtonItem` in navigation bar. /// - NOTE: When the value is updated, `didUpdateRightItem`is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var rightBarButtons: [UIBarButtonItem]? { didSet { self.didUpdateRightItems() } } diff --git a/Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.List.swift b/Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.List.swift similarity index 100% rename from Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.List.swift rename to Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.List.swift diff --git a/Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.swift b/Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.swift similarity index 100% rename from Sources/Module/ChannelSettings/SBUBaseChannelSettingsModule.swift rename to Sources/uikit/Module/ChannelSettings/SBUBaseChannelSettingsModule.swift diff --git a/Sources/Module/Common/SBUCommonModule.swift b/Sources/uikit/Module/Common/SBUCommonModule.swift similarity index 94% rename from Sources/Module/Common/SBUCommonModule.swift rename to Sources/uikit/Module/Common/SBUCommonModule.swift index 0890b85..9fa1c17 100644 --- a/Sources/Module/Common/SBUCommonModule.swift +++ b/Sources/uikit/Module/Common/SBUCommonModule.swift @@ -15,7 +15,7 @@ open class SBUCommonModule { /// ```swift /// SBUModuleSet.CommonModule.ToastView = SBUToastView.self /// ``` - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ToastView: SBUToastView.Type = SBUToastView.self { didSet { SBUModuleSet.CommonModule.ToastView.resetInstance() } } @@ -24,7 +24,7 @@ open class SBUCommonModule { /// ```swift /// SBUModuleSet.CommonModule.ActionSheet = SBUActionSheet.self /// ``` - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ActionSheet: SBUActionSheet.Type = SBUActionSheet.self { didSet { SBUModuleSet.CommonModule.ActionSheet.resetInstance() } } @@ -33,7 +33,7 @@ open class SBUCommonModule { /// ```swift /// SBUModuleSet.CommonModule.AlertView = SBUAlertView.self /// ``` - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var AlertView: SBUAlertView.Type = SBUAlertView.self { didSet { SBUModuleSet.CommonModule.AlertView.resetInstance() } } @@ -42,7 +42,7 @@ open class SBUCommonModule { /// ```swift /// SBUModuleSet.CommonModule.Loading = SBULoading.self /// ``` - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var Loading: SBULoading.Type = SBULoading.self { didSet { SBUModuleSet.CommonModule.Loading.resetInstance() } } diff --git a/Sources/Module/MessageSearch/SBUMessageSearchModule.Header.swift b/Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.Header.swift similarity index 99% rename from Sources/Module/MessageSearch/SBUMessageSearchModule.Header.swift rename to Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.Header.swift index 086c587..c23b0a8 100644 --- a/Sources/Module/MessageSearch/SBUMessageSearchModule.Header.swift +++ b/Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.Header.swift @@ -237,7 +237,7 @@ extension SBUMessageSearchModule { } /// Cancels the search. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func cancelSearch() { self.delegate?.messageSearchModuleDidTapCancel(self) } diff --git a/Sources/Module/MessageSearch/SBUMessageSearchModule.List.swift b/Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.List.swift similarity index 100% rename from Sources/Module/MessageSearch/SBUMessageSearchModule.List.swift rename to Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.List.swift diff --git a/Sources/Module/MessageSearch/SBUMessageSearchModule.swift b/Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.swift similarity index 93% rename from Sources/Module/MessageSearch/SBUMessageSearchModule.swift rename to Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.swift index 6163cf6..c500fcf 100644 --- a/Sources/Module/MessageSearch/SBUMessageSearchModule.swift +++ b/Sources/uikit/Module/MessageSearch/SBUMessageSearchModule.swift @@ -23,25 +23,25 @@ extension SBUMessageSearchModule { // MARK: Header extension SBUMessageSearchModule.Header { /// Represents the metatype of left bar button in ``SBUMessageSearchModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type? /// Represents the metatype of title view in ``SBUMessageSearchModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUSearchBar.Type = SBUSearchBar.self /// Represents the metatype of right bar button in ``SBUMessageSearchModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self } // MARK: List extension SBUMessageSearchModule.List { /// Represents the type of empty view on the message search module module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of message search result cell on the message search module module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MessageSearchResultCell: SBUMessageSearchResultCell.Type = SBUMessageSearchResultCell.self } diff --git a/Sources/Module/MessageThread/SBUMessageThreadModule.Header.swift b/Sources/uikit/Module/MessageThread/SBUMessageThreadModule.Header.swift similarity index 100% rename from Sources/Module/MessageThread/SBUMessageThreadModule.Header.swift rename to Sources/uikit/Module/MessageThread/SBUMessageThreadModule.Header.swift diff --git a/Sources/Module/MessageThread/SBUMessageThreadModule.Input.swift b/Sources/uikit/Module/MessageThread/SBUMessageThreadModule.Input.swift similarity index 100% rename from Sources/Module/MessageThread/SBUMessageThreadModule.Input.swift rename to Sources/uikit/Module/MessageThread/SBUMessageThreadModule.Input.swift diff --git a/Sources/Module/MessageThread/SBUMessageThreadModule.List.swift b/Sources/uikit/Module/MessageThread/SBUMessageThreadModule.List.swift similarity index 100% rename from Sources/Module/MessageThread/SBUMessageThreadModule.List.swift rename to Sources/uikit/Module/MessageThread/SBUMessageThreadModule.List.swift diff --git a/Sources/Module/MessageThread/SBUMessageThreadModule.swift b/Sources/uikit/Module/MessageThread/SBUMessageThreadModule.swift similarity index 91% rename from Sources/Module/MessageThread/SBUMessageThreadModule.swift rename to Sources/uikit/Module/MessageThread/SBUMessageThreadModule.swift index 9877570..f930103 100644 --- a/Sources/Module/MessageThread/SBUMessageThreadModule.swift +++ b/Sources/uikit/Module/MessageThread/SBUMessageThreadModule.swift @@ -27,68 +27,68 @@ extension SBUMessageThreadModule { // MARK: Header extension SBUMessageThreadModule.Header { /// Represents the type of left bar button on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of right bar button on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the type of title view on the group channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUMessageThreadTitleView.Type = SBUMessageThreadTitleView.self } // MARK: List extension SBUMessageThreadModule.List { /// Represents the type of empty view on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of admin message cell on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var AdminMessageCell: SBUBaseMessageCell.Type = SBUAdminMessageCell.self /// Represents the type of user message cell on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserMessageCell: SBUBaseMessageCell.Type = SBUUserMessageCell.self /// Represents the type of file message cell on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var FileMessageCell: SBUBaseMessageCell.Type = SBUFileMessageCell.self /// Represents the type of multiple files message cell on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MultipleFilesMessageCell: SBUBaseMessageCell.Type = SBUMultipleFilesMessageCell.self /// Represents the type of unknown message cell on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UnknownMessageCell: SBUBaseMessageCell.Type = SBUUnknownMessageCell.self /// Represents the type of custom message cell on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var CustomMessageCell: SBUBaseMessageCell.Type? /// Represents the type of channel state banner on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelStateBanner: SBUChannelStateBanner.Type = SBUChannelStateBanner.self /// Represents the type of user profile view on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserProfileView: SBUUserProfileView.Type = SBUUserProfileView.self /// Represents the type of parent messag info view on the message thread module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ParentMessageInfoView: SBUParentMessageInfoView.Type = SBUParentMessageInfoView.self } // MARK: Input extension SBUMessageThreadModule.Input { /// The component property that the message input view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MessageInputView: SBUMessageInputView.Type = SBUMessageInputView.self /// The component property that the voice message input view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var VoiceMessageInputView: SBUVoiceMessageInputView.Type = SBUVoiceMessageInputView.self } diff --git a/Sources/Module/Moderations/SBUModerationsModule.Header.swift b/Sources/uikit/Module/Moderations/SBUModerationsModule.Header.swift similarity index 99% rename from Sources/Module/Moderations/SBUModerationsModule.Header.swift rename to Sources/uikit/Module/Moderations/SBUModerationsModule.Header.swift index f74c21a..253dbb8 100644 --- a/Sources/Module/Moderations/SBUModerationsModule.Header.swift +++ b/Sources/uikit/Module/Moderations/SBUModerationsModule.Header.swift @@ -33,14 +33,14 @@ public protocol SBUModerationsModuleHeaderDelegate: SBUCommonDelegate { /// - Parameters: /// - headerComponent: `SBUModerationsModule.Header` object /// - leftItems: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func moderationsModule(_ headerComponent: SBUModerationsModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` value is updated. /// - Parameters: /// - headerComponent: `SBUModerationsModule.Header` object /// - rightItems: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func moderationsModule(_ headerComponent: SBUModerationsModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. @@ -101,14 +101,14 @@ extension SBUModerationsModule { /// A view that represents the left `UIBarButtonItem`s in navigation bar. /// - NOTE: When the value is updated, `moderationsModule(_:didUpdateLeftItem:)` delegate function is called. /// and when the value is tapped, `moderationsModule(_:didTapLeftItems:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var leftBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.moderationsModule(self, didUpdateLeftItems: self.leftBarButtons) } } /// A view that represents the right `UIBarButtonItem`s in navigation bar. /// - NOTE: When the value is updated, `moderationsModule(_:didUpdateRightItems:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var rightBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.moderationsModule(self, didUpdateRightItems: self.rightBarButtons) } } diff --git a/Sources/Module/Moderations/SBUModerationsModule.List.swift b/Sources/uikit/Module/Moderations/SBUModerationsModule.List.swift similarity index 100% rename from Sources/Module/Moderations/SBUModerationsModule.List.swift rename to Sources/uikit/Module/Moderations/SBUModerationsModule.List.swift diff --git a/Sources/Module/Moderations/SBUModerationsModule.swift b/Sources/uikit/Module/Moderations/SBUModerationsModule.swift similarity index 95% rename from Sources/Module/Moderations/SBUModerationsModule.swift rename to Sources/uikit/Module/Moderations/SBUModerationsModule.swift index 70a4f05..bb7bf5a 100644 --- a/Sources/Module/Moderations/SBUModerationsModule.swift +++ b/Sources/uikit/Module/Moderations/SBUModerationsModule.swift @@ -23,17 +23,17 @@ extension SBUModerationsModule { // MARK: Header extension SBUModerationsModule.Header { /// Represents the metatype of left bar button in ``SBUModerationsModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view in ``SBUModerationsModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self } // MARK: List extension SBUModerationsModule.List { /// Represents the metatype of moderation cell in moderation module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ModerationCell: SBUModerationCell.Type = SBUModerationCell.self } diff --git a/Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift b/Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift similarity index 99% rename from Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift rename to Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift index 6eeeefa..88bdc7a 100644 --- a/Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift +++ b/Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.Header.swift @@ -44,7 +44,7 @@ public protocol SBUGroupChannelPushSettingsModuleHeaderDelegate: SBUCommonDelega /// - Parameters: /// - headerComponent: `SBUGroupChannelPushSettingsModule.Header` object /// - leftItems: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func groupChannelPushSettingsModule( _ headerComponent: SBUGroupChannelPushSettingsModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]? @@ -54,7 +54,7 @@ public protocol SBUGroupChannelPushSettingsModuleHeaderDelegate: SBUCommonDelega /// - Parameters: /// - headerComponent: `SBUGroupChannelPushSettingsModule.Header` object /// - rightItems: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func groupChannelPushSettingsModule( _ headerComponent: SBUGroupChannelPushSettingsModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]? @@ -152,7 +152,7 @@ extension SBUGroupChannelPushSettingsModule { /// The default view type is ``[UIBarButtonItem]``. /// - NOTE: When the value is updated, `groupChannelPushSettingsModule(_:didUpdateLeftItems:)` delegate function is called. /// and when the default `leftBarButtons` is tapped, `groupChannelPushSettingsModule(_:didTapLeftItem:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var leftBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.groupChannelPushSettingsModule( @@ -165,7 +165,7 @@ extension SBUGroupChannelPushSettingsModule { /// A view that represents the right `[UIBarButtonItem]` in navigation bar. /// - NOTE: When the value is updated, `groupChannelPushSettingsModule(_:didUpdateRightItems:)` delegate function is called. /// and when the default `rightBarButtons` is tapped, `groupChannelPushSettingsModule(_:didTapRightItem:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var rightBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.groupChannelPushSettingsModule( diff --git a/Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.List.swift b/Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.List.swift similarity index 100% rename from Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.List.swift rename to Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.List.swift diff --git a/Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift b/Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift similarity index 94% rename from Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift rename to Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift index 3704793..2dfab11 100644 --- a/Sources/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift +++ b/Sources/uikit/Module/NotificationSettings/SBUGroupChannelPushSettingsModule.swift @@ -23,15 +23,15 @@ extension SBUGroupChannelPushSettingsModule { // MARK: Header extension SBUGroupChannelPushSettingsModule.Header { /// Represents the metatype of left bar button on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of right bar button on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self } @@ -39,6 +39,6 @@ extension SBUGroupChannelPushSettingsModule.Header { extension SBUGroupChannelPushSettingsModule.List { /// Represents the metatype of setting cell on the group channel settings module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelPushSettingCell: SBUChannelPushSettingCell.Type = SBUChannelPushSettingCell.self } diff --git a/Sources/Module/SBUModuleSet.swift b/Sources/uikit/Module/SBUModuleSet.swift similarity index 99% rename from Sources/Module/SBUModuleSet.swift rename to Sources/uikit/Module/SBUModuleSet.swift index 2a90130..01c4a22 100644 --- a/Sources/Module/SBUModuleSet.swift +++ b/Sources/uikit/Module/SBUModuleSet.swift @@ -188,6 +188,6 @@ extension SBUModuleSet { /// ```swift /// SBUModuleSet.CommonModule = SBUCommonModule.self /// ``` - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var CommonModule: SBUCommonModule.Type = SBUCommonModule.self } diff --git a/Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift similarity index 99% rename from Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift rename to Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift index 086b6af..a7f6a2d 100644 --- a/Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift +++ b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.Header.swift @@ -33,14 +33,14 @@ public protocol SBUCreateChannelModuleHeaderDelegate: SBUBaseSelectUserModuleHea /// - Parameters: /// - headerComponent: `SBUCreateChannelModule.Header` object /// - leftItem: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func createChannelModule(_ headerComponent: SBUCreateChannelModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was selected. /// - Parameters: /// - headerComponent: `SBUCreateChannelModule.Header` object /// - rightItem: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func createChannelModule(_ headerComponent: SBUCreateChannelModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. diff --git a/Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.List.swift b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.List.swift similarity index 100% rename from Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.List.swift rename to Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.List.swift diff --git a/Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift similarity index 93% rename from Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift rename to Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift index 26277f8..30c49a6 100644 --- a/Sources/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift +++ b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateChannelModule.swift @@ -23,25 +23,25 @@ extension SBUCreateChannelModule { // MARK: Header extension SBUCreateChannelModule.Header { /// Represents the metatype of left bar button in ``SBUCreateChannelModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view in ``SBUCreateChannelModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self /// Represents the metatype of right bar button in ``SBUCreateChannelModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self } // MARK: List extension SBUCreateChannelModule.List { /// Represents the type of empty view on the create channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of user cell on the create channel module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserCell: SBUUserCell.Type = SBUUserCell.self } diff --git a/Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift similarity index 99% rename from Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift rename to Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift index 8d7a5ff..df613be 100644 --- a/Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift +++ b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.Header.swift @@ -33,14 +33,14 @@ public protocol SBUCreateOpenChannelModuleHeaderDelegate: SBUCommonDelegate { /// - Parameters: /// - headerComponent: `SBUCreateOpenChannelModule.Header` object /// - leftItems: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func createOpenChannelModule(_ headerComponent: SBUCreateOpenChannelModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButton` was selected. /// - Parameters: /// - headerComponent: `SBUCreateOpenChannelModule.Header` object /// - rightItems: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func createOpenChannelModule(_ headerComponent: SBUCreateOpenChannelModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. @@ -107,14 +107,14 @@ extension SBUCreateOpenChannelModule { /// A view that represents the left `UIBarButtonItem`s in navigation bar. /// - NOTE: When the value is updated, `createOpenChannelModule(_:didUpdateLeftItems:)` delegate function is called. /// and when the value is tapped, `createOpenChannelModule(_:didTapLeftItems:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var leftBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.createOpenChannelModule(self, didUpdateLeftItems: self.leftBarButtons) } } /// A view that represents the right `UIBarButtonItem`s in navigation bar. /// - NOTE: When the value is updated, `createOpenChannelModule(_:didUpdateRightItems:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var rightBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.createOpenChannelModule(self, didUpdateRightItems: self.rightBarButtons) } } diff --git a/Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.ProfileInput.swift b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.ProfileInput.swift similarity index 100% rename from Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.ProfileInput.swift rename to Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.ProfileInput.swift diff --git a/Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift similarity index 94% rename from Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift rename to Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift index 7c5be6d..42b6f7e 100644 --- a/Sources/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift +++ b/Sources/uikit/Module/SelectUser/CreateChannel/SBUCreateOpenChannelModule.swift @@ -23,25 +23,25 @@ extension SBUCreateOpenChannelModule { // MARK: Header extension SBUCreateOpenChannelModule.Header { /// Represents the metatype of left bar button in ``SBUCreateOpenChannelModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view in ``SBUCreateOpenChannelModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self /// Represents the metatype of right bar button in ``SBUCreateOpenChannelModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self } // MARK: List extension SBUCreateOpenChannelModule.ProfileInput { /// The view that displays the channel image in Create channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelImageView: SBUCoverImageView.Type = SBUCoverImageView.self /// The view that displays the channel name inputField in Create channel. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ChannelNameInputField: SBUUnderLineTextField.Type = SBUUnderLineTextField.self } diff --git a/Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift b/Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift similarity index 99% rename from Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift rename to Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift index e7d3930..70dd14b 100644 --- a/Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift +++ b/Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.Header.swift @@ -32,14 +32,14 @@ public protocol SBUInviteUserModuleHeaderDelegate: SBUBaseSelectUserModuleHeader /// - Parameters: /// - headerComponent: `SBUInviteUserModule.Header` object /// - leftItem: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func inviteUserModule(_ headerComponent: SBUInviteUserModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was selected. /// - Parameters: /// - headerComponent: `SBUInviteUserModule.Header` object /// - rightItem: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func inviteUserModule(_ headerComponent: SBUInviteUserModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. diff --git a/Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.List.swift b/Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.List.swift similarity index 100% rename from Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.List.swift rename to Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.List.swift diff --git a/Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.swift b/Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.swift similarity index 93% rename from Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.swift rename to Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.swift index 10434b3..a456c74 100644 --- a/Sources/Module/SelectUser/InviteUser/SBUInviteUserModule.swift +++ b/Sources/uikit/Module/SelectUser/InviteUser/SBUInviteUserModule.swift @@ -23,15 +23,15 @@ extension SBUInviteUserModule { // MARK: Header extension SBUInviteUserModule.Header { /// Represents the metatype of left bar button in ``SBUInviteUserModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view in ``SBUInviteUserModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self /// Represents the metatype of right bar button in ``SBUInviteUserModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self } @@ -39,10 +39,10 @@ extension SBUInviteUserModule.Header { extension SBUInviteUserModule.List { /// Represents the type of empty view on the invite user module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of user cell on the invite user module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserCell: SBUUserCell.Type = SBUUserCell.self } diff --git a/Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift b/Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift similarity index 99% rename from Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift rename to Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift index d7a4123..1d0bab5 100644 --- a/Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift +++ b/Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.Header.swift @@ -32,14 +32,14 @@ public protocol SBURegisterOperatorModuleHeaderDelegate: SBUBaseSelectUserModule /// - Parameters: /// - headerComponent: `SBURegisterOperatorModule.Header` object /// - leftItems: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func registerOperatorModule(_ headerComponent: SBURegisterOperatorModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was selected. /// - Parameters: /// - headerComponent: `SBURegisterOperatorModule.Header` object /// - rightItems: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func registerOperatorModule(_ headerComponent: SBURegisterOperatorModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. diff --git a/Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.List.swift b/Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.List.swift similarity index 100% rename from Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.List.swift rename to Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.List.swift diff --git a/Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift b/Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift similarity index 93% rename from Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift rename to Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift index 4048e81..79bf181 100644 --- a/Sources/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift +++ b/Sources/uikit/Module/SelectUser/RegisterOperator/SBURegisterOperatorModule.swift @@ -23,25 +23,25 @@ extension SBURegisterOperatorModule { // MARK: Header extension SBURegisterOperatorModule.Header { /// Represents the metatype of left bar button in ``SBURegisterOperatorModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view in ``SBURegisterOperatorModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self /// Represents the metatype of right bar button in ``SBURegisterOperatorModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self } // MARK: List extension SBURegisterOperatorModule.List { /// Represents the type of empty view on the register operator module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of user cell on the register operator module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserCell: SBUUserCell.Type = SBUUserCell.self } diff --git a/Sources/Module/SelectUser/SBUBaseSelectUserModule.Header.swift b/Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.Header.swift similarity index 99% rename from Sources/Module/SelectUser/SBUBaseSelectUserModule.Header.swift rename to Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.Header.swift index 5367de8..31452da 100644 --- a/Sources/Module/SelectUser/SBUBaseSelectUserModule.Header.swift +++ b/Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.Header.swift @@ -173,10 +173,10 @@ extension SBUBaseSelectUserModule { /// Called when the `rightBarButton` was updated. func didUpdateRightItem() { } /// Called when the `leftBarButtons` was updated. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func didUpdateLeftItems() { } /// Called when the `rightBarButtons` was updated. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func didUpdateRightItems() { } // MARK: - Actions diff --git a/Sources/Module/SelectUser/SBUBaseSelectUserModule.List.swift b/Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.List.swift similarity index 100% rename from Sources/Module/SelectUser/SBUBaseSelectUserModule.List.swift rename to Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.List.swift diff --git a/Sources/Module/SelectUser/SBUBaseSelectUserModule.swift b/Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.swift similarity index 100% rename from Sources/Module/SelectUser/SBUBaseSelectUserModule.swift rename to Sources/uikit/Module/SelectUser/SBUBaseSelectUserModule.swift diff --git a/Sources/Module/UserList/SBUUserListModule.Header.swift b/Sources/uikit/Module/UserList/SBUUserListModule.Header.swift similarity index 99% rename from Sources/Module/UserList/SBUUserListModule.Header.swift rename to Sources/uikit/Module/UserList/SBUUserListModule.Header.swift index 48b6b35..a3423e1 100644 --- a/Sources/Module/UserList/SBUUserListModule.Header.swift +++ b/Sources/uikit/Module/UserList/SBUUserListModule.Header.swift @@ -33,14 +33,14 @@ public protocol SBUUserListModuleHeaderDelegate: SBUCommonDelegate { /// - Parameters: /// - headerComponent: `SBUUserListModule.Header` object /// - leftItems: Updated `leftBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func userListModule(_ headerComponent: SBUUserListModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) /// Called when `rightBarButtons` was updated. /// - Parameters: /// - headerComponent: `SBUUserListModule.Header` object /// - rightItems: Updated `rightBarButtons` object. - /// - Since: 3.26.0 + /// - Since: 3.28.0 func userListModule(_ headerComponent: SBUUserListModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) /// Called when `leftBarButton` was selected. @@ -109,7 +109,7 @@ extension SBUUserListModule { /// A view that represents a left `UIBarButtonItem` in navigation bar. /// - NOTE: When the value is updated, `userListModule(_:didUpdateLeftItems:)` delegate function is called. /// and when the value is tapped, `userListModule(_:didTapLeftItem:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var leftBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.userListModule(self, didUpdateLeftItems: self.leftBarButtons) } } @@ -117,7 +117,7 @@ extension SBUUserListModule { /// A view that represents a right `UIBarButtonItem` in navigation bar. /// - NOTE: When the value is updated, `userListModule(_:didUpdateRightItems:)` delegate function is called. /// and when the value is tapped, `userListModule(_:didTapRightItem:)` delegate function is called. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var rightBarButtons: [UIBarButtonItem]? { didSet { self.delegate?.userListModule(self, didUpdateRightItems: self.rightBarButtons) } } diff --git a/Sources/Module/UserList/SBUUserListModule.List.swift b/Sources/uikit/Module/UserList/SBUUserListModule.List.swift similarity index 100% rename from Sources/Module/UserList/SBUUserListModule.List.swift rename to Sources/uikit/Module/UserList/SBUUserListModule.List.swift diff --git a/Sources/Module/UserList/SBUUserListModule.swift b/Sources/uikit/Module/UserList/SBUUserListModule.swift similarity index 93% rename from Sources/Module/UserList/SBUUserListModule.swift rename to Sources/uikit/Module/UserList/SBUUserListModule.swift index 09bc2e9..8e2a560 100644 --- a/Sources/Module/UserList/SBUUserListModule.swift +++ b/Sources/uikit/Module/UserList/SBUUserListModule.swift @@ -23,25 +23,25 @@ extension SBUUserListModule { // MARK: Header extension SBUUserListModule.Header { /// Represents the metatype of left bar button in ``SBUUserListModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var LeftBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self /// Represents the metatype of title view in ``SBUUserListModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var TitleView: SBUNavigationTitleView.Type = SBUNavigationTitleView.self /// Represents the metatype of right bar button in ``SBUUserListModule.Header``. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var RightBarButton: SBUBarButtonItem.Type = SBUBarButtonItem.self } // MARK: List extension SBUUserListModule.List { /// Represents the type of empty view on the user list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmptyView: SBUEmptyView.Type = SBUEmptyView.self /// Represents the type of user cell on the user list module. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var UserCell: SBUUserCell.Type = SBUUserCell.self } diff --git a/Sources/PrivacyInfo.xcprivacy b/Sources/uikit/PrivacyInfo.xcprivacy similarity index 100% rename from Sources/PrivacyInfo.xcprivacy rename to Sources/uikit/PrivacyInfo.xcprivacy diff --git a/Sources/Protocol/CommonProtocols.swift b/Sources/uikit/Protocol/CommonProtocols.swift similarity index 100% rename from Sources/Protocol/CommonProtocols.swift rename to Sources/uikit/Protocol/CommonProtocols.swift diff --git a/Sources/Resource/Assets.xcassets/Contents.json b/Sources/uikit/Resource/Assets.xcassets/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconAdd.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconAdd.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconAdd.imageset/iconAdd.png b/Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/iconAdd.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconAdd.imageset/iconAdd.png rename to Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/iconAdd.png diff --git a/Sources/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconAdd.imageset/iconAdd@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/iconBack.png b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBack.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/iconBack.png rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBack.png diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/iconBack@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBack@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/iconBack@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBack@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/iconBack@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBack@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/iconBack@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBack@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBack.imageset/iconBackRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconBad.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBad.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconBad.imageset/icon-bad.png b/Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/icon-bad.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBad.imageset/icon-bad.png rename to Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/icon-bad.png diff --git a/Sources/Resource/Assets.xcassets/iconBad.imageset/icon-bad@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/icon-bad@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBad.imageset/icon-bad@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/icon-bad@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconBad.imageset/icon-bad@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/icon-bad@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBad.imageset/icon-bad@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBad.imageset/icon-bad@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconBan.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBan.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconBan.imageset/iconBan.png b/Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/iconBan.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBan.imageset/iconBan.png rename to Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/iconBan.png diff --git a/Sources/Resource/Assets.xcassets/iconBan.imageset/iconBan@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/iconBan@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBan.imageset/iconBan@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/iconBan@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconBan.imageset/iconBan@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/iconBan@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBan.imageset/iconBan@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBan.imageset/iconBan@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast.png b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast.png rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast.png diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcast@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconBroadcast.imageset/iconBroadcastRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconCamera.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCamera.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconCamera.imageset/iconCamera.png b/Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/iconCamera.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCamera.imageset/iconCamera.png rename to Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/iconCamera.png diff --git a/Sources/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCamera.imageset/iconCamera@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconChannels.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChannels.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconChannels.imageset/iconChannels.png b/Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/iconChannels.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChannels.imageset/iconChannels.png rename to Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/iconChannels.png diff --git a/Sources/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChannels.imageset/iconChannels@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/iconChat.png b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChat.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/iconChat.png rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChat.png diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/iconChat@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChat@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/iconChat@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChat@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/iconChat@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChat@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/iconChat@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChat@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChat.imageset/iconChatRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked.png b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked.png rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked.png diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxChecked.imageset/iconCheckboxChecked@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked.png b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked.png rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked.png diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCheckboxUnchecked.imageset/iconCheckboxUnchecked@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronDown.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronDown.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronDown.imageset/iconChevronDown@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRight@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconChevronRight.imageset/iconChevronRightRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconClose.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconClose.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconClose.imageset/iconClose.png b/Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/iconClose.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconClose.imageset/iconClose.png rename to Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/iconClose.png diff --git a/Sources/Resource/Assets.xcassets/iconClose.imageset/iconClose@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/iconClose@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconClose.imageset/iconClose@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/iconClose@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconClose.imageset/iconClose@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/iconClose@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconClose.imageset/iconClose@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconClose.imageset/iconClose@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconCopy.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCopy.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconCopy.imageset/iconCopy.png b/Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/iconCopy.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCopy.imageset/iconCopy.png rename to Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/iconCopy.png diff --git a/Sources/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCopy.imageset/iconCopy@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreate.png b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreate.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreate.png rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreate.png diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreate@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconCreate.imageset/iconCreateRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconDelete.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDelete.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconDelete.imageset/iconDelete.png b/Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/iconDelete.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDelete.imageset/iconDelete.png rename to Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/iconDelete.png diff --git a/Sources/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDelete.imageset/iconDelete@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconDocument.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDocument.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconDocument.imageset/iconDocument.png b/Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/iconDocument.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDocument.imageset/iconDocument.png rename to Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/iconDocument.png diff --git a/Sources/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDocument.imageset/iconDocument@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconDone.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDone.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconDone.imageset/iconDone.png b/Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/iconDone.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDone.imageset/iconDone.png rename to Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/iconDone.png diff --git a/Sources/Resource/Assets.xcassets/iconDone.imageset/iconDone@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/iconDone@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDone.imageset/iconDone@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/iconDone@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconDone.imageset/iconDone@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/iconDone@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDone.imageset/iconDone@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDone.imageset/iconDone@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconDoneAll.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDoneAll.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll.png b/Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll.png rename to Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll.png diff --git a/Sources/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDoneAll.imageset/iconDoneAll@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconDownload.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDownload.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconDownload.imageset/iconDownload.png b/Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/iconDownload.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDownload.imageset/iconDownload.png rename to Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/iconDownload.png diff --git a/Sources/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconDownload.imageset/iconDownload@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconEdit.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEdit.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconEdit.imageset/iconEdit.png b/Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/iconEdit.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEdit.imageset/iconEdit.png rename to Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/iconEdit.png diff --git a/Sources/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconEdit.imageset/iconEdit@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore.png b/Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore.png rename to Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore.png diff --git a/Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconEmojiMore.imageset/iconEmojiMore@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconEmpty.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmpty.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty.png b/Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty.png rename to Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty.png diff --git a/Sources/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconEmpty.imageset/iconEmpty@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconError.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconError.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconError.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconError.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconError.imageset/iconError.png b/Sources/uikit/Resource/Assets.xcassets/iconError.imageset/iconError.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconError.imageset/iconError.png rename to Sources/uikit/Resource/Assets.xcassets/iconError.imageset/iconError.png diff --git a/Sources/Resource/Assets.xcassets/iconError.imageset/iconError@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconError.imageset/iconError@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconError.imageset/iconError@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconError.imageset/iconError@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconError.imageset/iconError@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconError.imageset/iconError@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconError.imageset/iconError@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconError.imageset/iconError@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio.png b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio.png diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudio@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileAudio.imageset/iconFileAudioRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconFileDocument.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileDocument.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument.png b/Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument.png diff --git a/Sources/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFileDocument.imageset/iconFileDocument@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconFreeze.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFreeze.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze.png b/Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze.png rename to Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze.png diff --git a/Sources/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconFreeze.imageset/iconFreeze@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconGif.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGif.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconGif.imageset/iconGif.png b/Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/iconGif.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGif.imageset/iconGif.png rename to Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/iconGif.png diff --git a/Sources/Resource/Assets.xcassets/iconGif.imageset/iconGif@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/iconGif@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGif.imageset/iconGif@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/iconGif@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconGif.imageset/iconGif@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/iconGif@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGif.imageset/iconGif@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconGif.imageset/iconGif@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconGood.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGood.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconGood.imageset/icon-good.png b/Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/icon-good.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGood.imageset/icon-good.png rename to Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/icon-good.png diff --git a/Sources/Resource/Assets.xcassets/iconGood.imageset/icon-good@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/icon-good@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGood.imageset/icon-good@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/icon-good@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconGood.imageset/icon-good@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/icon-good@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconGood.imageset/icon-good@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconGood.imageset/icon-good@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconInfo.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconInfo.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconInfo.imageset/iconInfo.png b/Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/iconInfo.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconInfo.imageset/iconInfo.png rename to Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/iconInfo.png diff --git a/Sources/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconInfo.imageset/iconInfo@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeave.png b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeave.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeave.png rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeave.png diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeave@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconLeave.imageset/iconLeaveRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconMembers.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMembers.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconMembers.imageset/iconMembers.png b/Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/iconMembers.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMembers.imageset/iconMembers.png rename to Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/iconMembers.png diff --git a/Sources/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMembers.imageset/iconMembers@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessage.png b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessage.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessage.png rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessage.png diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessage@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMessage.imageset/iconMessageRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconModerations.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconModerations.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconModerations.imageset/iconModerations.png b/Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/iconModerations.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconModerations.imageset/iconModerations.png rename to Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/iconModerations.png diff --git a/Sources/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconModerations.imageset/iconModerations@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconMore.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMore.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconMore.imageset/iconMore.png b/Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/iconMore.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMore.imageset/iconMore.png rename to Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/iconMore.png diff --git a/Sources/Resource/Assets.xcassets/iconMore.imageset/iconMore@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/iconMore@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMore.imageset/iconMore@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/iconMore@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconMore.imageset/iconMore@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/iconMore@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMore.imageset/iconMore@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMore.imageset/iconMore@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconMute.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMute.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconMute.imageset/iconMute.png b/Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/iconMute.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMute.imageset/iconMute.png rename to Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/iconMute.png diff --git a/Sources/Resource/Assets.xcassets/iconMute.imageset/iconMute@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/iconMute@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMute.imageset/iconMute@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/iconMute@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconMute.imageset/iconMute@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/iconMute@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconMute.imageset/iconMute@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconMute.imageset/iconMute@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled.png b/Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled.png diff --git a/Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationFilled.imageset/iconNotificationsFilled@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled.png b/Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled.png diff --git a/Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotificationOffFilled.imageset/iconNotificationsOffFilled@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconNotifications.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotifications.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications.png b/Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications.png diff --git a/Sources/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconNotifications.imageset/iconNotifications@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconOperator.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconOperator.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconOperator.imageset/iconOperator.png b/Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/iconOperator.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconOperator.imageset/iconOperator.png rename to Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/iconOperator.png diff --git a/Sources/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconOperator.imageset/iconOperator@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconPause.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPause.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconPause.imageset/iconPause.png b/Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/iconPause.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPause.imageset/iconPause.png rename to Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/iconPause.png diff --git a/Sources/Resource/Assets.xcassets/iconPause.imageset/iconPause@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/iconPause@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPause.imageset/iconPause@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/iconPause@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconPause.imageset/iconPause@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/iconPause@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPause.imageset/iconPause@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPause.imageset/iconPause@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconPhoto.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPhoto.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto.png b/Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto.png rename to Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto.png diff --git a/Sources/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPhoto.imageset/iconPhoto@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconPlay.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlay.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconPlay.imageset/iconPlay.png b/Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/iconPlay.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlay.imageset/iconPlay.png rename to Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/iconPlay.png diff --git a/Sources/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPlay.imageset/iconPlay@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconPlus.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlus.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconPlus.imageset/iconPlus.png b/Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/iconPlus.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlus.imageset/iconPlus.png rename to Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/iconPlus.png diff --git a/Sources/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconPlus.imageset/iconPlus@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconQuestion.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconQuestion.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion.png b/Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion.png rename to Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion.png diff --git a/Sources/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconQuestion.imageset/iconQuestion@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff.png b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff.png rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff.png diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOff.imageset/iconRadioButtonOff@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn.png b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn.png rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn.png diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRadioButtonOn.imageset/iconRadioButtonOn@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconRecording.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRecording.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconRecording.imageset/iconRecording.png b/Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/iconRecording.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRecording.imageset/iconRecording.png rename to Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/iconRecording.png diff --git a/Sources/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRecording.imageset/iconRecording@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconRefresh.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRefresh.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh.png b/Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh.png rename to Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh.png diff --git a/Sources/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRefresh.imageset/iconRefresh@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconRemove.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRemove.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconRemove.imageset/iconRemove.png b/Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/iconRemove.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRemove.imageset/iconRemove.png rename to Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/iconRemove.png diff --git a/Sources/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconRemove.imageset/iconRemove@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplied.png b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplied.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplied.png rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplied.png diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplied@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReplied.imageset/iconReplyFilledRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/iconReply.png b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReply.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/iconReply.png rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReply.png diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/iconReply@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReply@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/iconReply@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReply@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/iconReply@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReply@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/iconReply@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReply@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/iconReplyFilledRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReplyFilledRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/iconReplyFilledRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReplyFilledRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconReply.imageset/iconReplyRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconSearch.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSearch.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconSearch.imageset/iconSearch.png b/Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/iconSearch.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSearch.imageset/iconSearch.png rename to Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/iconSearch.png diff --git a/Sources/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSearch.imageset/iconSearch@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/iconSend.png b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSend.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/iconSend.png rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSend.png diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/iconSend@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSend@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/iconSend@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSend@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/iconSend@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSend@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/iconSend@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSend@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSend.imageset/iconSendRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconSpinner.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSpinner.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner.png b/Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner.png rename to Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner.png diff --git a/Sources/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSpinner.imageset/iconSpinner@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconStop.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconStop.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconStop.imageset/iconStop.png b/Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/iconStop.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconStop.imageset/iconStop.png rename to Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/iconStop.png diff --git a/Sources/Resource/Assets.xcassets/iconStop.imageset/iconStop@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/iconStop@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconStop.imageset/iconStop@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/iconStop@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconStop.imageset/iconStop@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/iconStop@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconStop.imageset/iconStop@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconStop.imageset/iconStop@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconSupergroup.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSupergroup.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup.png b/Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup.png rename to Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup.png diff --git a/Sources/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconSupergroup.imageset/iconSupergroup@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/iconThread.png b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThread.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/iconThread.png rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThread.png diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/iconThread@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThread@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/iconThread@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThread@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/iconThread@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThread@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/iconThread@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThread@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL.png b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL.png rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL.png diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconThread.imageset/iconThreadRTL@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone.png b/Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone.png rename to Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone.png diff --git a/Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@2x-1.png b/Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@2x-1.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@2x-1.png rename to Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@2x-1.png diff --git a/Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconThumbnailNone.imageset/iconThumbnailNone@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconUser.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconUser.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconUser.imageset/iconUser.png b/Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/iconUser.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconUser.imageset/iconUser.png rename to Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/iconUser.png diff --git a/Sources/Resource/Assets.xcassets/iconUser.imageset/iconUser@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/iconUser@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconUser.imageset/iconUser@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/iconUser@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconUser.imageset/iconUser@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/iconUser@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconUser.imageset/iconUser@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconUser.imageset/iconUser@3x.png diff --git a/Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/Contents.json b/Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/Contents.json similarity index 100% rename from Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/Contents.json rename to Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/Contents.json diff --git a/Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn.png b/Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn.png rename to Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn.png diff --git a/Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@2x.png b/Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@2x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@2x.png rename to Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@2x.png diff --git a/Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@3x.png b/Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@3x.png similarity index 100% rename from Sources/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@3x.png rename to Sources/uikit/Resource/Assets.xcassets/iconVoiceMessageOn.imageset/iconAudioOn@3x.png diff --git a/Sources/SBUAvailable.swift b/Sources/uikit/SBUAvailable.swift similarity index 100% rename from Sources/SBUAvailable.swift rename to Sources/uikit/SBUAvailable.swift diff --git a/Sources/SBUGlobalCustomParams.swift b/Sources/uikit/SBUGlobalCustomParams.swift similarity index 100% rename from Sources/SBUGlobalCustomParams.swift rename to Sources/uikit/SBUGlobalCustomParams.swift diff --git a/Sources/SBUGlobals.swift b/Sources/uikit/SBUGlobals.swift similarity index 85% rename from Sources/SBUGlobals.swift rename to Sources/uikit/SBUGlobals.swift index 5ee4bdc..7895e90 100644 --- a/Sources/SBUGlobals.swift +++ b/Sources/uikit/SBUGlobals.swift @@ -198,7 +198,7 @@ public class SBUGlobals { /// See the example below. /// ```swift /// // Define your custom filter logic before the emojis are shown. - /// + /// /// SBUGlobals.emojiCategoryFilter = { message in /// switch message { /// case is UserMessage: @@ -215,4 +215,46 @@ public class SBUGlobals { public static var emojiCategoryFilter: (BaseMessage) -> [Int64]? = { message in return nil } + + /// The configuration for loading indicator. + /// In certain scenarios, loading indicators are not displayed by default, such as when loading cached channels in Group Channel List. + /// You can choose to display them by modifying this property. + /// + /// See the example below. + /// ```swift + /// // Show loading indicator when loading cached channels in Group Channel List. + /// SBUGlobals.loadingIndicator.groupChannelList.cachedChannels = true + /// ``` + /// + /// - Since: 3.27.5 + public static var loadingIndicator = LoadingIndicator() +} + +extension SBUGlobals { + /// The configuration for loading indicators. + public class LoadingIndicator { + /// The configuration for loading indicator in a Group Channel. + /// - Since: 3.27.5 + public var groupChannel = GroupChannel() + + /// The configuration for loading indicator in a Group Channel List. + /// - Since: 3.27.5 + public var groupChannelList = GroupChannelList() + + // The configuration for loading indicators in a Group ChannelList. + public class GroupChannelList { + /// Decides whether to show a loading indicator when loading **cached** channels in a Group Channel List. + /// Default is false. + /// - Since: 3.27.5 + public var cachedChannels: Bool = false + } + + // The configuration for loading indicators in a Group Channel. + public class GroupChannel { + /// Decides whether to show a loading indicator when loading **cached** messages in a Group Channel. + /// Default is false. + /// - Since: 3.27.5 + public var cachedMessages: Bool = false + } + } } diff --git a/Sources/SendbirdUI.swift b/Sources/uikit/SendbirdUI.swift similarity index 98% rename from Sources/SendbirdUI.swift rename to Sources/uikit/SendbirdUI.swift index a39d1fb..d6d021d 100644 --- a/Sources/SendbirdUI.swift +++ b/Sources/uikit/SendbirdUI.swift @@ -318,18 +318,10 @@ public class SendbirdUI { completionHandler: @escaping (_ user: User?, _ error: SBError?) -> Void ) { SendbirdChat.executeOrWaitForInitialization { - if SendbirdChat.getConnectState() == .open { - completionHandler(SendbirdChat.getCurrentUser(), nil) - } else { - SBULog.info("currentUser: \(String(describing: SendbirdChat.getCurrentUser()?.userId))") - if SendbirdChat.isLocalCachingEnabled, - let currentUSer = SendbirdChat.getCurrentUser() { - completionHandler(currentUSer, nil) - SendbirdUI.authenticateFeedAndUpdates(needToUpdateExtraData: needToUpdateExtraData) { _, _ in } - } else { - SendbirdUI.authenticateFeedAndUpdates(needToUpdateExtraData: needToUpdateExtraData, completionHandler: completionHandler) - } - } + SendbirdUI.authenticateFeedAndUpdates( + needToUpdateExtraData: needToUpdateExtraData, + completionHandler: completionHandler + ) } } @@ -349,7 +341,7 @@ public class SendbirdUI { let userId = currentUser.userId.trimmingCharacters(in: .whitespacesAndNewlines) let nickname = currentUser.nickname?.trimmingCharacters(in: .whitespacesAndNewlines) - SendbirdChat.authenticateFeed(userId: userId, authToken: SBUGlobals.accessToken, apiHost: SBUGlobals.apiHost) { [userId, nickname] user, error in + SendbirdChat.authenticate(userId: userId, authToken: SBUGlobals.accessToken, apiHost: SBUGlobals.apiHost) { [userId, nickname] user, error in guard let user = user else { SBULog.error("[Failed] Authentication to Sendbird: \(error?.localizedDescription ?? "")") completionHandler(nil, error) diff --git a/Sources/SendbirdUIKit.h b/Sources/uikit/SendbirdUIKit.h similarity index 100% rename from Sources/SendbirdUIKit.h rename to Sources/uikit/SendbirdUIKit.h diff --git a/Sources/Theme/SBUColorSet.swift b/Sources/uikit/Theme/SBUColorSet.swift similarity index 99% rename from Sources/Theme/SBUColorSet.swift rename to Sources/uikit/Theme/SBUColorSet.swift index 5773eed..eae5411 100644 --- a/Sources/Theme/SBUColorSet.swift +++ b/Sources/uikit/Theme/SBUColorSet.swift @@ -72,7 +72,7 @@ public class SBUColorSet { extension SBUColorSet { /// Restore the default colors. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static func restoreDefaultColors() { SBUColorSet.primaryExtraLight = UIColor(red: 219.0 / 255.0, green: 209.0 / 255.0, blue: 1.0, alpha: 1.0) SBUColorSet.primaryLight = UIColor(red: 194.0 / 255.0, green: 169.0 / 255.0, blue: 250.0 / 255.0, alpha: 1.0) diff --git a/Sources/Theme/SBUFontSet.swift b/Sources/uikit/Theme/SBUFontSet.swift similarity index 99% rename from Sources/Theme/SBUFontSet.swift rename to Sources/uikit/Theme/SBUFontSet.swift index 7e5b83a..92b2c93 100644 --- a/Sources/Theme/SBUFontSet.swift +++ b/Sources/uikit/Theme/SBUFontSet.swift @@ -291,7 +291,7 @@ extension SBUFontSet { extension SBUFontSet { /// Restore default fonts - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static func restoreDefaultFonts() { SBUFontSet.h1 = UIFont.systemFont(ofSize: 18.0, weight: .bold) SBUFontSet.h2 = UIFont.systemFont(ofSize: 18.0, weight: .medium) diff --git a/Sources/Theme/SBUIconSet.swift b/Sources/uikit/Theme/SBUIconSet.swift similarity index 100% rename from Sources/Theme/SBUIconSet.swift rename to Sources/uikit/Theme/SBUIconSet.swift diff --git a/Sources/Theme/SBUTheme+Type.swift b/Sources/uikit/Theme/SBUTheme+Type.swift similarity index 100% rename from Sources/Theme/SBUTheme+Type.swift rename to Sources/uikit/Theme/SBUTheme+Type.swift diff --git a/Sources/Theme/SBUTheme.swift b/Sources/uikit/Theme/SBUTheme.swift similarity index 100% rename from Sources/Theme/SBUTheme.swift rename to Sources/uikit/Theme/SBUTheme.swift diff --git a/Sources/Util/BlockingOperation.swift b/Sources/uikit/Util/BlockingOperation.swift similarity index 100% rename from Sources/Util/BlockingOperation.swift rename to Sources/uikit/Util/BlockingOperation.swift diff --git a/Sources/Util/SBUDebouncer.swift b/Sources/uikit/Util/SBUDebouncer.swift similarity index 100% rename from Sources/Util/SBUDebouncer.swift rename to Sources/uikit/Util/SBUDebouncer.swift diff --git a/Sources/Util/SBULogger.swift b/Sources/uikit/Util/SBULogger.swift similarity index 100% rename from Sources/Util/SBULogger.swift rename to Sources/uikit/Util/SBULogger.swift diff --git a/Sources/Util/SBUMentionManager.swift b/Sources/uikit/Util/SBUMentionManager.swift similarity index 100% rename from Sources/Util/SBUMentionManager.swift rename to Sources/uikit/Util/SBUMentionManager.swift diff --git a/Sources/Util/SBUPropertyWrapper.swift b/Sources/uikit/Util/SBUPropertyWrapper.swift similarity index 100% rename from Sources/Util/SBUPropertyWrapper.swift rename to Sources/uikit/Util/SBUPropertyWrapper.swift diff --git a/Sources/Util/SBUUtils.swift b/Sources/uikit/Util/SBUUtils.swift similarity index 99% rename from Sources/Util/SBUUtils.swift rename to Sources/uikit/Util/SBUUtils.swift index c332e60..f161e60 100644 --- a/Sources/Util/SBUUtils.swift +++ b/Sources/uikit/Util/SBUUtils.swift @@ -292,7 +292,7 @@ extension SBUUtils { extension SBUUtils { /// Methods for determining if the first character of a string is an RTL language - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static func isRTLCharacter(with string: String?) -> Bool { guard let scalar = string?.unicodeScalars.first else { return false } return Self.rtlCharacterSet.contains(scalar) diff --git a/Sources/uikit/Util/WeakDelegateStorage.swift b/Sources/uikit/Util/WeakDelegateStorage.swift new file mode 100644 index 0000000..318320e --- /dev/null +++ b/Sources/uikit/Util/WeakDelegateStorage.swift @@ -0,0 +1,57 @@ +// +// WeakDelegateStorage.swift +// SendbirdUIKit +// +// Created by Tez Park on 10/31/24. +// + +import Foundation + +enum WeakDelegateType: String { + case uikit = "UIKitDelegate" + case swiftui = "SwiftUIDelegate" +} + +class WeakDelegate { + weak var value: AnyObject? + + init(value: AnyObject? = nil) { + self.value = value + } +} + +class WeakDelegateStorage { + var delegates = [String: Any]() +} + +extension WeakDelegateStorage { + func addDelegate(_ delegate: T?, type: WeakDelegateType) { + delegates[type.rawValue] = WeakDelegate(value: delegate as? AnyObject) + } + + func forEach(_ closure: (T) -> Void) { + delegates + .values + .compactMap { $0 as? WeakDelegate } + .forEach { + if let value = $0.value as? T { + closure(value) + } + } + } + + func allKeys() -> [WeakDelegateType] { + delegates.keys.compactMap { WeakDelegateType(rawValue: $0) } + } + + func allKeyValuePairs() -> [(WeakDelegateType, T)] { + delegates.compactMap { delegate in + if let key = WeakDelegateType(rawValue: delegate.key), + let value = (delegate.value as? WeakDelegate)?.value as? T { + return (key, value) + } else { + return nil + } + } + } +} diff --git a/Sources/View/Channel/CategoryFilterCell/SBUCategoryFilterCell.swift b/Sources/uikit/View/Channel/CategoryFilterCell/SBUCategoryFilterCell.swift similarity index 100% rename from Sources/View/Channel/CategoryFilterCell/SBUCategoryFilterCell.swift rename to Sources/uikit/View/Channel/CategoryFilterCell/SBUCategoryFilterCell.swift diff --git a/Sources/View/Channel/CellView/SBULinkClickableTextView.swift b/Sources/uikit/View/Channel/CellView/SBULinkClickableTextView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBULinkClickableTextView.swift rename to Sources/uikit/View/Channel/CellView/SBULinkClickableTextView.swift diff --git a/Sources/View/Channel/CellView/SBUMarkdownTransfer.swift b/Sources/uikit/View/Channel/CellView/SBUMarkdownTransfer.swift similarity index 97% rename from Sources/View/Channel/CellView/SBUMarkdownTransfer.swift rename to Sources/uikit/View/Channel/CellView/SBUMarkdownTransfer.swift index 8053f73..024ff95 100644 --- a/Sources/View/Channel/CellView/SBUMarkdownTransfer.swift +++ b/Sources/uikit/View/Channel/CellView/SBUMarkdownTransfer.swift @@ -91,7 +91,7 @@ extension SBUMarkdownTransfer.Markdown { result.replaceCharacters(in: match.range, with: linkText) let newRange = NSRange(location: match.range.location, length: linkText.utf16.count) - result.addAttribute(.link, value: urlString, range: newRange) + result.addAttribute(.link, value: urlString.asURLEncoded, range: newRange) result.addBoldAttribute(at: newRange) result.addAttribute(.underlineStyle, value: NSUnderlineStyle.single.rawValue, range: newRange) } diff --git a/Sources/View/Channel/CellView/SBUMessageDateView.swift b/Sources/uikit/View/Channel/CellView/SBUMessageDateView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUMessageDateView.swift rename to Sources/uikit/View/Channel/CellView/SBUMessageDateView.swift diff --git a/Sources/View/Channel/CellView/SBUMessageProfileView.swift b/Sources/uikit/View/Channel/CellView/SBUMessageProfileView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUMessageProfileView.swift rename to Sources/uikit/View/Channel/CellView/SBUMessageProfileView.swift diff --git a/Sources/View/Channel/CellView/SBUMessageStateView.swift b/Sources/uikit/View/Channel/CellView/SBUMessageStateView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUMessageStateView.swift rename to Sources/uikit/View/Channel/CellView/SBUMessageStateView.swift diff --git a/Sources/View/Channel/CellView/SBUMessageWebView.swift b/Sources/uikit/View/Channel/CellView/SBUMessageWebView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUMessageWebView.swift rename to Sources/uikit/View/Channel/CellView/SBUMessageWebView.swift diff --git a/Sources/View/Channel/CellView/SBUNotificationTimelineView.swift b/Sources/uikit/View/Channel/CellView/SBUNotificationTimelineView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUNotificationTimelineView.swift rename to Sources/uikit/View/Channel/CellView/SBUNotificationTimelineView.swift diff --git a/Sources/View/Channel/CellView/SBUOpenChannelMessageWebView.swift b/Sources/uikit/View/Channel/CellView/SBUOpenChannelMessageWebView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUOpenChannelMessageWebView.swift rename to Sources/uikit/View/Channel/CellView/SBUOpenChannelMessageWebView.swift diff --git a/Sources/View/Channel/CellView/SBUSelectableStackView.swift b/Sources/uikit/View/Channel/CellView/SBUSelectableStackView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUSelectableStackView.swift rename to Sources/uikit/View/Channel/CellView/SBUSelectableStackView.swift diff --git a/Sources/View/Channel/CellView/SBUUserMessageTextView.swift b/Sources/uikit/View/Channel/CellView/SBUUserMessageTextView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUUserMessageTextView.swift rename to Sources/uikit/View/Channel/CellView/SBUUserMessageTextView.swift diff --git a/Sources/View/Channel/CellView/SBUUserNameView.swift b/Sources/uikit/View/Channel/CellView/SBUUserNameView.swift similarity index 100% rename from Sources/View/Channel/CellView/SBUUserNameView.swift rename to Sources/uikit/View/Channel/CellView/SBUUserNameView.swift diff --git a/Sources/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift b/Sources/uikit/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift similarity index 99% rename from Sources/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift rename to Sources/uikit/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift index f82cc39..dc5e23f 100644 --- a/Sources/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift +++ b/Sources/uikit/View/Channel/ChannelStateBanner/SBUChannelStateBanner.swift @@ -10,7 +10,7 @@ import UIKit import SwiftUI /// Banner to show channel state -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUChannelStateBanner: SBULabel { var isThreadMessage: Bool = false diff --git a/Sources/View/Channel/FileViewer/SBUFileViewController.swift b/Sources/uikit/View/Channel/FileViewer/SBUFileViewController.swift similarity index 100% rename from Sources/View/Channel/FileViewer/SBUFileViewController.swift rename to Sources/uikit/View/Channel/FileViewer/SBUFileViewController.swift diff --git a/Sources/View/Channel/Header/SBUChannelInfoHeaderView.swift b/Sources/uikit/View/Channel/Header/SBUChannelInfoHeaderView.swift similarity index 100% rename from Sources/View/Channel/Header/SBUChannelInfoHeaderView.swift rename to Sources/uikit/View/Channel/Header/SBUChannelInfoHeaderView.swift diff --git a/Sources/View/Channel/Header/SBUChannelTitleView.swift b/Sources/uikit/View/Channel/Header/SBUChannelTitleView.swift similarity index 100% rename from Sources/View/Channel/Header/SBUChannelTitleView.swift rename to Sources/uikit/View/Channel/Header/SBUChannelTitleView.swift diff --git a/Sources/View/Channel/Media/SBUMediaView.swift b/Sources/uikit/View/Channel/Media/SBUMediaView.swift similarity index 94% rename from Sources/View/Channel/Media/SBUMediaView.swift rename to Sources/uikit/View/Channel/Media/SBUMediaView.swift index f5a3fed..444aa50 100644 --- a/Sources/View/Channel/Media/SBUMediaView.swift +++ b/Sources/uikit/View/Channel/Media/SBUMediaView.swift @@ -9,7 +9,7 @@ import UIKit /// A view to shows media or other contents in the open channel. -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUMediaView: SBUView { public required override init() { super.init(frame: .zero) diff --git a/Sources/View/Channel/MessageCell/CarouselView/SBUBaseCarouselView.swift b/Sources/uikit/View/Channel/MessageCell/CarouselView/SBUBaseCarouselView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/CarouselView/SBUBaseCarouselView.swift rename to Sources/uikit/View/Channel/MessageCell/CarouselView/SBUBaseCarouselView.swift diff --git a/Sources/View/Channel/MessageCell/CustomView/SBUExtendedMessagePayloadCustomViewFactory.swift b/Sources/uikit/View/Channel/MessageCell/CustomView/SBUExtendedMessagePayloadCustomViewFactory.swift similarity index 100% rename from Sources/View/Channel/MessageCell/CustomView/SBUExtendedMessagePayloadCustomViewFactory.swift rename to Sources/uikit/View/Channel/MessageCell/CustomView/SBUExtendedMessagePayloadCustomViewFactory.swift diff --git a/Sources/View/Channel/MessageCell/Feedback/SBUFeedbackView.swift b/Sources/uikit/View/Channel/MessageCell/Feedback/SBUFeedbackView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Feedback/SBUFeedbackView.swift rename to Sources/uikit/View/Channel/MessageCell/Feedback/SBUFeedbackView.swift diff --git a/Sources/View/Channel/MessageCell/Feedback/SBUFeedbackViewParams.swift b/Sources/uikit/View/Channel/MessageCell/Feedback/SBUFeedbackViewParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Feedback/SBUFeedbackViewParams.swift rename to Sources/uikit/View/Channel/MessageCell/Feedback/SBUFeedbackViewParams.swift diff --git a/Sources/View/Channel/MessageCell/FileMessageContentView/SBUBaseFileContentView.swift b/Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUBaseFileContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/FileMessageContentView/SBUBaseFileContentView.swift rename to Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUBaseFileContentView.swift diff --git a/Sources/View/Channel/MessageCell/FileMessageContentView/SBUCommonContentView.swift b/Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUCommonContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/FileMessageContentView/SBUCommonContentView.swift rename to Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUCommonContentView.swift diff --git a/Sources/View/Channel/MessageCell/FileMessageContentView/SBUImageContentView.swift b/Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUImageContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/FileMessageContentView/SBUImageContentView.swift rename to Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUImageContentView.swift diff --git a/Sources/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelCommonContentView.swift b/Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelCommonContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelCommonContentView.swift rename to Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelCommonContentView.swift diff --git a/Sources/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelImageContentView.swift b/Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelImageContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelImageContentView.swift rename to Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUOpenChannelImageContentView.swift diff --git a/Sources/View/Channel/MessageCell/FileMessageContentView/SBUVoiceContentView.swift b/Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUVoiceContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/FileMessageContentView/SBUVoiceContentView.swift rename to Sources/uikit/View/Channel/MessageCell/FileMessageContentView/SBUVoiceContentView.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUAdminMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUAdminMessageCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUAdminMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUAdminMessageCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift similarity index 99% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift index ec35019..e617e68 100644 --- a/Sources/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift +++ b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUBaseMessageCellParams.swift @@ -50,7 +50,7 @@ public class SBUBaseMessageCellParams { /// - Since: 3.15.0 public var shouldHideFeedback: Bool = true - /// - Since: 3.26.0 + /// - Since: 3.28.0 var isThreadMessage: Bool = false /** diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUFeedNotificationCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUFeedNotificationCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUFeedNotificationCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUFeedNotificationCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUFileMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUFileMessageCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUFileMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUFileMessageCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUMessageTemplateCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUMessageTemplateCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUMessageTemplateCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUMessageTemplateCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUMultipleFilesMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUMultipleFilesMessageCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUMultipleFilesMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUMultipleFilesMessageCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUTypingMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUTypingMessageCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUTypingMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUTypingMessageCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUUnknownMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUUnknownMessageCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUUnknownMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUUnknownMessageCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageCellParams/SBUUserMessageCellParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUUserMessageCellParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageCellParams/SBUUserMessageCellParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageCellParams/SBUUserMessageCellParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/ViewParams/SBUMessageFormViewParams.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/ViewParams/SBUMessageFormViewParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/ViewParams/SBUMessageFormViewParams.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/ViewParams/SBUMessageFormViewParams.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormChipsItemView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormChipsItemView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormChipsItemView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormChipsItemView.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormFallbackView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormFallbackView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormFallbackView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormFallbackView.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormItemView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormItemView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormItemView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormItemView.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormMultiTextItemView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormMultiTextItemView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormMultiTextItemView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormMultiTextItemView.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormSingleTextItemView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormSingleTextItemView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormSingleTextItemView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormSingleTextItemView.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SBUMessageFormView.swift diff --git a/Sources/View/Channel/MessageCell/MessageForm/Views/SubViews/SBUMessageFormChipView.swift b/Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SubViews/SBUMessageFormChipView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MessageForm/Views/SubViews/SBUMessageFormChipView.swift rename to Sources/uikit/View/Channel/MessageCell/MessageForm/Views/SubViews/SBUMessageFormChipView.swift diff --git a/Sources/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionView.swift b/Sources/uikit/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionView.swift rename to Sources/uikit/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionView.swift diff --git a/Sources/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionViewCell.swift b/Sources/uikit/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionViewCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionViewCell.swift rename to Sources/uikit/View/Channel/MessageCell/MultipleFilesMessage/SBUMultipleFilesMessageCollectionViewCell.swift diff --git a/Sources/View/Channel/MessageCell/NotificationChannel/SBUChatNotificationCell.swift b/Sources/uikit/View/Channel/MessageCell/NotificationChannel/SBUChatNotificationCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/NotificationChannel/SBUChatNotificationCell.swift rename to Sources/uikit/View/Channel/MessageCell/NotificationChannel/SBUChatNotificationCell.swift diff --git a/Sources/View/Channel/MessageCell/NotificationChannel/SBUFeedNotificationCell.swift b/Sources/uikit/View/Channel/MessageCell/NotificationChannel/SBUFeedNotificationCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/NotificationChannel/SBUFeedNotificationCell.swift rename to Sources/uikit/View/Channel/MessageCell/NotificationChannel/SBUFeedNotificationCell.swift diff --git a/Sources/View/Channel/MessageCell/NotificationChannel/SBUNotificationCell.swift b/Sources/uikit/View/Channel/MessageCell/NotificationChannel/SBUNotificationCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/NotificationChannel/SBUNotificationCell.swift rename to Sources/uikit/View/Channel/MessageCell/NotificationChannel/SBUNotificationCell.swift diff --git a/Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelAdminMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelAdminMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelAdminMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelAdminMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelBaseMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelBaseMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelBaseMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelBaseMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelContentBaseMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelContentBaseMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelContentBaseMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelContentBaseMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelFileMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelFileMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelFileMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelFileMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUnknownMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUnknownMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUnknownMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUnknownMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUserMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUserMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUserMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/OpenChannel/SBUOpenChannelUserMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/Replies/MessageView/QuotedFileCommonContentView.swift b/Sources/uikit/View/Channel/MessageCell/Replies/MessageView/QuotedFileCommonContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/MessageView/QuotedFileCommonContentView.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/MessageView/QuotedFileCommonContentView.swift diff --git a/Sources/View/Channel/MessageCell/Replies/MessageView/QuotedFileImageContentView.swift b/Sources/uikit/View/Channel/MessageCell/Replies/MessageView/QuotedFileImageContentView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/MessageView/QuotedFileImageContentView.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/MessageView/QuotedFileImageContentView.swift diff --git a/Sources/View/Channel/MessageCell/Replies/MessageView/SBUQuotedBaseMessageView.swift b/Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUQuotedBaseMessageView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/MessageView/SBUQuotedBaseMessageView.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUQuotedBaseMessageView.swift diff --git a/Sources/View/Channel/MessageCell/Replies/MessageView/SBUQuotedFileMessageView.swift b/Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUQuotedFileMessageView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/MessageView/SBUQuotedFileMessageView.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUQuotedFileMessageView.swift diff --git a/Sources/View/Channel/MessageCell/Replies/MessageView/SBUQuotedUserMessageView.swift b/Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUQuotedUserMessageView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/MessageView/SBUQuotedUserMessageView.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUQuotedUserMessageView.swift diff --git a/Sources/View/Channel/MessageCell/Replies/MessageView/SBUThreadInfoView.swift b/Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUThreadInfoView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/MessageView/SBUThreadInfoView.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/MessageView/SBUThreadInfoView.swift diff --git a/Sources/View/Channel/MessageCell/Replies/ViewParams/SBUQuotedBaseMessageViewParams.swift b/Sources/uikit/View/Channel/MessageCell/Replies/ViewParams/SBUQuotedBaseMessageViewParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/Replies/ViewParams/SBUQuotedBaseMessageViewParams.swift rename to Sources/uikit/View/Channel/MessageCell/Replies/ViewParams/SBUQuotedBaseMessageViewParams.swift diff --git a/Sources/View/Channel/MessageCell/SBUAdminMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUAdminMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUAdminMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUAdminMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUBaseMessageCell.Feedback.swift b/Sources/uikit/View/Channel/MessageCell/SBUBaseMessageCell.Feedback.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUBaseMessageCell.Feedback.swift rename to Sources/uikit/View/Channel/MessageCell/SBUBaseMessageCell.Feedback.swift diff --git a/Sources/View/Channel/MessageCell/SBUBaseMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUBaseMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUBaseMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUBaseMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUContentBaseMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUContentBaseMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUContentBaseMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUContentBaseMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUFileMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUFileMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUFileMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUFileMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUMessageTemplateCell.MessageTemplateLayer.swift b/Sources/uikit/View/Channel/MessageCell/SBUMessageTemplateCell.MessageTemplateLayer.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUMessageTemplateCell.MessageTemplateLayer.swift rename to Sources/uikit/View/Channel/MessageCell/SBUMessageTemplateCell.MessageTemplateLayer.swift diff --git a/Sources/View/Channel/MessageCell/SBUMessageTemplateCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUMessageTemplateCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUMessageTemplateCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUMessageTemplateCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUMessageTemplateCellLayout.swift b/Sources/uikit/View/Channel/MessageCell/SBUMessageTemplateCellLayout.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUMessageTemplateCellLayout.swift rename to Sources/uikit/View/Channel/MessageCell/SBUMessageTemplateCellLayout.swift diff --git a/Sources/View/Channel/MessageCell/SBUTypingIndicatorMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUTypingIndicatorMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUTypingIndicatorMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUTypingIndicatorMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUUnknownMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUUnknownMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUUnknownMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUUnknownMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SBUUserMessageCell.swift b/Sources/uikit/View/Channel/MessageCell/SBUUserMessageCell.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SBUUserMessageCell.swift rename to Sources/uikit/View/Channel/MessageCell/SBUUserMessageCell.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/ViewParams/SBUSuggestedReplyViewParams.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/ViewParams/SBUSuggestedReplyViewParams.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/ViewParams/SBUSuggestedReplyViewParams.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/ViewParams/SBUSuggestedReplyViewParams.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyOptionView.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyOptionView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyOptionView.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyOptionView.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyView.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyView.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUHorizontalSuggestedReplyView.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUSimpleSuggestedReplyOptionView.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUSimpleSuggestedReplyOptionView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUSimpleSuggestedReplyOptionView.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUSimpleSuggestedReplyOptionView.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyOptionView.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyOptionView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyOptionView.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyOptionView.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyView.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyView.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUSuggestedReplyView.swift diff --git a/Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUVerticalSuggestedReplyView.swift b/Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUVerticalSuggestedReplyView.swift similarity index 100% rename from Sources/View/Channel/MessageCell/SuggestedReply/Views/SBUVerticalSuggestedReplyView.swift rename to Sources/uikit/View/Channel/MessageCell/SuggestedReply/Views/SBUVerticalSuggestedReplyView.swift diff --git a/Sources/View/Channel/MessageInput/SBUMentionLimitGuideCell.swift b/Sources/uikit/View/Channel/MessageInput/SBUMentionLimitGuideCell.swift similarity index 100% rename from Sources/View/Channel/MessageInput/SBUMentionLimitGuideCell.swift rename to Sources/uikit/View/Channel/MessageInput/SBUMentionLimitGuideCell.swift diff --git a/Sources/View/Channel/MessageInput/SBUMessageInputMode.swift b/Sources/uikit/View/Channel/MessageInput/SBUMessageInputMode.swift similarity index 100% rename from Sources/View/Channel/MessageInput/SBUMessageInputMode.swift rename to Sources/uikit/View/Channel/MessageInput/SBUMessageInputMode.swift diff --git a/Sources/View/Channel/MessageInput/SBUMessageInputView.swift b/Sources/uikit/View/Channel/MessageInput/SBUMessageInputView.swift similarity index 98% rename from Sources/View/Channel/MessageInput/SBUMessageInputView.swift rename to Sources/uikit/View/Channel/MessageInput/SBUMessageInputView.swift index 526f1a2..b2bf865 100644 --- a/Sources/View/Channel/MessageInput/SBUMessageInputView.swift +++ b/Sources/uikit/View/Channel/MessageInput/SBUMessageInputView.swift @@ -1042,7 +1042,7 @@ open class SBUMessageInputView: SBUView, SBUActionSheetDelegate, UITextViewDeleg return Self.generateResourceItems(channelType: self.channelType) } - /// - Since: 3.26.0 + /// - Since: 3.28.0 static func generateResourceItems(channelType: ChannelType) -> [SBUActionSheetItem] { var items: [SBUActionSheetItem] = [] var inputConfig: SBUConfig.BaseInput? @@ -1106,6 +1106,33 @@ open class SBUMessageInputView: SBUView, SBUActionSheetDelegate, UITextViewDeleg didSelectEdit: self.textView?.text.trimmingCharacters(in: .whitespacesAndNewlines) ?? "" ) } + + // MARK: - Internal methods + func showCamera() { + SBUPermissionManager.shared.requestCameraAccess(for: .video) { [weak self] in + guard let self = self else { return } + self.delegate?.messageInputView(self, didSelectResource: .camera) + } onDenied: { [weak self] in + guard let self = self else { return } + self.delegate?.messageInputView(self, didSelectResource: .camera) + } + } + + func showPhotosLibrary() { + SBUPermissionManager.shared.requestPhotoAccessIfNeeded { _ in + DispatchQueue.main.async { [weak self] in + guard let self = self else { return } + self.delegate?.messageInputView(self, didSelectResource: .library) + } + } + } + + func showDocumentsPicker() { + DispatchQueue.main.async { [weak self] in + guard let self = self else { return } + self.delegate?.messageInputView(self, didSelectResource: .document) + } + } // MARK: - UITextViewDelegate public func textViewDidChange(_ textView: UITextView) { @@ -1176,20 +1203,9 @@ open class SBUMessageInputView: SBUView, SBUActionSheetDelegate, UITextViewDeleg let type = MediaResourceType.init(rawValue: index) ?? .unknown switch type { case .camera: - SBUPermissionManager.shared.requestCameraAccess(for: .video) { [weak self] in - guard let self = self else { return } - self.delegate?.messageInputView(self, didSelectResource: type) - } onDenied: { [weak self] in - guard let self = self else { return } - self.delegate?.messageInputView(self, didSelectResource: type) - } + self.showCamera() case .library: - SBUPermissionManager.shared.requestPhotoAccessIfNeeded { _ in - DispatchQueue.main.async { [weak self] in - guard let self = self else { return } - self.delegate?.messageInputView(self, didSelectResource: type) - } - } + self.showPhotosLibrary() default: DispatchQueue.main.async { [weak self] in guard let self = self else { return } diff --git a/Sources/View/Channel/MessageInput/SBUQuoteMessageInputView.swift b/Sources/uikit/View/Channel/MessageInput/SBUQuoteMessageInputView.swift similarity index 100% rename from Sources/View/Channel/MessageInput/SBUQuoteMessageInputView.swift rename to Sources/uikit/View/Channel/MessageInput/SBUQuoteMessageInputView.swift diff --git a/Sources/View/Channel/MessageInput/SBUSuggestedMentionList.swift b/Sources/uikit/View/Channel/MessageInput/SBUSuggestedMentionList.swift similarity index 100% rename from Sources/View/Channel/MessageInput/SBUSuggestedMentionList.swift rename to Sources/uikit/View/Channel/MessageInput/SBUSuggestedMentionList.swift diff --git a/Sources/View/Channel/MessageInput/ViewParams/SBUQuoteMessageInputViewParams.swift b/Sources/uikit/View/Channel/MessageInput/ViewParams/SBUQuoteMessageInputViewParams.swift similarity index 100% rename from Sources/View/Channel/MessageInput/ViewParams/SBUQuoteMessageInputViewParams.swift rename to Sources/uikit/View/Channel/MessageInput/ViewParams/SBUQuoteMessageInputViewParams.swift diff --git a/Sources/View/Channel/NewMessageInfo/SBUNewMessageInfo.swift b/Sources/uikit/View/Channel/NewMessageInfo/SBUNewMessageInfo.swift similarity index 100% rename from Sources/View/Channel/NewMessageInfo/SBUNewMessageInfo.swift rename to Sources/uikit/View/Channel/NewMessageInfo/SBUNewMessageInfo.swift diff --git a/Sources/View/Channel/NewMessageInfo/SBUNewNotificationInfo.swift b/Sources/uikit/View/Channel/NewMessageInfo/SBUNewNotificationInfo.swift similarity index 100% rename from Sources/View/Channel/NewMessageInfo/SBUNewNotificationInfo.swift rename to Sources/uikit/View/Channel/NewMessageInfo/SBUNewNotificationInfo.swift diff --git a/Sources/View/Channel/Reaction/SBUEmojiListViewController.swift b/Sources/uikit/View/Channel/Reaction/SBUEmojiListViewController.swift similarity index 98% rename from Sources/View/Channel/Reaction/SBUEmojiListViewController.swift rename to Sources/uikit/View/Channel/Reaction/SBUEmojiListViewController.swift index a43db3f..4128cb5 100644 --- a/Sources/View/Channel/Reaction/SBUEmojiListViewController.swift +++ b/Sources/uikit/View/Channel/Reaction/SBUEmojiListViewController.swift @@ -13,7 +13,7 @@ import SendbirdChatSDK /// /// This class is responsible for managing and displaying a collection of emojis. It handles user interactions with the emojis and communicates with the bottom sheet controller. /// -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUEmojiListViewController: SBUBaseViewController, UICollectionViewDelegate, UICollectionViewDataSource, UICollectionViewDelegateFlowLayout, SBUBottomSheetControllerDelegate, UIGestureRecognizerDelegate { public private(set) lazy var collectionView = UICollectionView(frame: self.view.bounds, collectionViewLayout: layout) @@ -41,7 +41,7 @@ open class SBUEmojiListViewController: SBUBaseViewController, UICollectionViewDe /// - Parameters: /// - emojiKey: The key of the tapped emoji. /// - setSelect: A boolean indicating whether the emoji should be selected. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var emojiTapHandler: ((_ emojiKey: String, _ setSelect: Bool) -> Void)? // MARK: - Lifecycle @@ -158,7 +158,7 @@ open class SBUEmojiListViewController: SBUBaseViewController, UICollectionViewDe /// Calculates the height of the collection view content based on the number of emojis. /// /// - Returns: The total height required to display all emojis in the collection view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 open func calculateCollectionViewContentHeight() -> CGFloat { let lineCount = CGFloat((emojiList.count + maxEmojiOneLine - 1) / maxEmojiOneLine) return lineCount * layout.itemSize.height @@ -242,7 +242,7 @@ open class SBUEmojiListViewController: SBUBaseViewController, UICollectionViewDe // MARK: - SBUBottomSheetControllerDelegate /// This function is called when the bottom sheet moves to a specific position. - /// - Since: 3.26.0 + /// - Since: 3.28.0 open func bottomSheet(moveTo position: SBUBottomSheetSnapPoint) { switch position { case .top: diff --git a/Sources/View/Channel/Reaction/SBUMessageReactionView.swift b/Sources/uikit/View/Channel/Reaction/SBUMessageReactionView.swift similarity index 100% rename from Sources/View/Channel/Reaction/SBUMessageReactionView.swift rename to Sources/uikit/View/Channel/Reaction/SBUMessageReactionView.swift diff --git a/Sources/View/Channel/Reaction/SBUParentMessageInfoReactionView.swift b/Sources/uikit/View/Channel/Reaction/SBUParentMessageInfoReactionView.swift similarity index 100% rename from Sources/View/Channel/Reaction/SBUParentMessageInfoReactionView.swift rename to Sources/uikit/View/Channel/Reaction/SBUParentMessageInfoReactionView.swift diff --git a/Sources/View/Channel/Reaction/SBUReactionCollectionViewCell.swift b/Sources/uikit/View/Channel/Reaction/SBUReactionCollectionViewCell.swift similarity index 100% rename from Sources/View/Channel/Reaction/SBUReactionCollectionViewCell.swift rename to Sources/uikit/View/Channel/Reaction/SBUReactionCollectionViewCell.swift diff --git a/Sources/View/Channel/Reaction/SBUReactionsViewController.swift b/Sources/uikit/View/Channel/Reaction/SBUReactionsViewController.swift similarity index 99% rename from Sources/View/Channel/Reaction/SBUReactionsViewController.swift rename to Sources/uikit/View/Channel/Reaction/SBUReactionsViewController.swift index 2e34e03..c2659a3 100644 --- a/Sources/View/Channel/Reaction/SBUReactionsViewController.swift +++ b/Sources/uikit/View/Channel/Reaction/SBUReactionsViewController.swift @@ -215,7 +215,7 @@ open class SBUReactionsViewController: SBUBaseViewController, UITableViewDelegat // MARK: - Common /// Retrieves the index path for the currently selected reaction, if any. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func getSelectedIndexPath() -> IndexPath? { guard let selectedReaction = self.selectedReaction else { return nil } @@ -227,7 +227,7 @@ open class SBUReactionsViewController: SBUBaseViewController, UITableViewDelegat } /// This function retrieves the size of the cell based on the number of reactions. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func getCellSize(count: Int) -> CGSize { switch count { case 0...9: @@ -240,7 +240,7 @@ open class SBUReactionsViewController: SBUBaseViewController, UITableViewDelegat } /// This function retrieves the user for the specified index path. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func getUser(with indexPath: IndexPath) -> SBUUser? { guard let selectedReaction = self.selectedReaction, indexPath.row < selectedReaction.userIds.count else { return nil } @@ -351,7 +351,7 @@ open class SBUReactionsViewController: SBUBaseViewController, UITableViewDelegat // MARK: - SBUBottomSheetControllerDelegate /// This function is called when the bottom sheet moves to a specific position. - /// - Since: 3.26.0 + /// - Since: 3.28.0 open func bottomSheet(moveTo position: SBUBottomSheetSnapPoint) { switch position { case .top: diff --git a/Sources/View/Channel/SBUBaseChannelViewController.Keyboard.swift b/Sources/uikit/View/Channel/SBUBaseChannelViewController.Keyboard.swift similarity index 100% rename from Sources/View/Channel/SBUBaseChannelViewController.Keyboard.swift rename to Sources/uikit/View/Channel/SBUBaseChannelViewController.Keyboard.swift diff --git a/Sources/View/Channel/SBUBaseChannelViewController.swift b/Sources/uikit/View/Channel/SBUBaseChannelViewController.swift similarity index 99% rename from Sources/View/Channel/SBUBaseChannelViewController.swift rename to Sources/uikit/View/Channel/SBUBaseChannelViewController.swift index 613b301..f402c4d 100644 --- a/Sources/View/Channel/SBUBaseChannelViewController.swift +++ b/Sources/uikit/View/Channel/SBUBaseChannelViewController.swift @@ -782,12 +782,12 @@ open class SBUBaseChannelViewController: SBUBaseViewController, SBUBaseChannelVi } } - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func baseChannelModule(_ headerComponent: SBUBaseChannelModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]?) { self.navigationItem.leftBarButtonItems = leftItems } - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func baseChannelModule(_ headerComponent: SBUBaseChannelModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]?) { if useRightBarButtonItem { self.navigationItem.rightBarButtonItems = rightItems diff --git a/Sources/View/Channel/SBUChatNotificationChannelViewController.swift b/Sources/uikit/View/Channel/SBUChatNotificationChannelViewController.swift similarity index 99% rename from Sources/View/Channel/SBUChatNotificationChannelViewController.swift rename to Sources/uikit/View/Channel/SBUChatNotificationChannelViewController.swift index 529d37f..6d6bdaf 100644 --- a/Sources/View/Channel/SBUChatNotificationChannelViewController.swift +++ b/Sources/uikit/View/Channel/SBUChatNotificationChannelViewController.swift @@ -400,7 +400,7 @@ open class SBUChatNotificationChannelViewController: SBUBaseViewController, ) { guard channel != nil else { // channel deleted - if self.navigationController?.viewControllers.last == self { + if self.isLastInNavigationStack() { // If leave is called in the ChannelSettingsViewController, this logic needs to be prevented. self.onClickBack() } diff --git a/Sources/View/Channel/SBUFeedNotificationChannelViewController.swift b/Sources/uikit/View/Channel/SBUFeedNotificationChannelViewController.swift similarity index 99% rename from Sources/View/Channel/SBUFeedNotificationChannelViewController.swift rename to Sources/uikit/View/Channel/SBUFeedNotificationChannelViewController.swift index 90f425a..f109a18 100644 --- a/Sources/View/Channel/SBUFeedNotificationChannelViewController.swift +++ b/Sources/uikit/View/Channel/SBUFeedNotificationChannelViewController.swift @@ -299,8 +299,12 @@ open class SBUFeedNotificationChannelViewController: SBUBaseViewController, .sbu_constraint( equalTo: self.view, left: 0, - right: 0, - top: 0 + right: 0 + ) + .sbu_constraint( + equalTo: self.view, + top: 0, + useSafeArea: true ) .sbu_constraint(height: Constants.categoryFilterHeight) @@ -474,7 +478,7 @@ open class SBUFeedNotificationChannelViewController: SBUBaseViewController, ) { guard channel != nil else { // channel deleted - if self.navigationController?.viewControllers.last == self { + if self.isLastInNavigationStack() { // If leave is called in the ChannelSettingsViewController, this logic needs to be prevented. self.onClickBack() } diff --git a/Sources/View/Channel/SBUGroupChannelViewController.swift b/Sources/uikit/View/Channel/SBUGroupChannelViewController.swift similarity index 98% rename from Sources/View/Channel/SBUGroupChannelViewController.swift rename to Sources/uikit/View/Channel/SBUGroupChannelViewController.swift index 2298139..d19eee6 100644 --- a/Sources/View/Channel/SBUGroupChannelViewController.swift +++ b/Sources/uikit/View/Channel/SBUGroupChannelViewController.swift @@ -17,6 +17,13 @@ import MobileCoreServices import SwiftUI #endif +#if SWIFTUI +protocol GroupChannelViewEventDelegate: AnyObject { + func groupChannelViewDidUpdateNewMessagesCount(_ count: Int) + func groupChannelViewDidChangeMessageText(_ text: String) +} +#endif + @objcMembers open class SBUGroupChannelViewController: SBUBaseChannelViewController, SBUGroupChannelViewModelDelegate, SBUGroupChannelModuleHeaderDelegate, SBUGroupChannelModuleListDelegate, SBUGroupChannelModuleListDataSource, SBUGroupChannelModuleInputDelegate, SBUGroupChannelModuleInputDataSource, SBUGroupChannelViewModelDataSource, SBUMentionManagerDataSource, SBUMessageThreadViewControllerDelegate, SBUVoiceMessageInputViewDelegate, SBUReactionsViewControllerDelegate { @@ -46,7 +53,13 @@ open class SBUGroupChannelViewController: SBUBaseChannelViewController, SBUGroup public override var channel: GroupChannel? { self.viewModel?.channel as? GroupChannel } - public private(set) var newMessagesCount: Int = 0 + public private(set) var newMessagesCount: Int = 0 { + didSet { + #if SWIFTUI + self.swiftUIDelegate?.groupChannelViewDidUpdateNewMessagesCount(self.newMessagesCount) + #endif + } + } override var isChatInputDisabled: Bool { didSet { @@ -58,6 +71,12 @@ open class SBUGroupChannelViewController: SBUBaseChannelViewController, SBUGroup #if SWIFTUI var channelSettingsViewBuilder: GroupChannelSettingsViewBuilder? var messageThreadViewBuilder: MessageThreadViewBuilder? + + weak var swiftUIDelegate: (SBUGroupChannelViewModelDelegate & GroupChannelViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif /// An error handler that is called when any one of the files size in multiple files message exceeds the file size limit. @@ -773,7 +792,7 @@ open class SBUGroupChannelViewController: SBUBaseChannelViewController, SBUGroup ) { guard channel != nil else { // channel deleted - if self.navigationController?.viewControllers.last == self { + if self.isLastInNavigationStack() { // If leave is called in the ChannelSettingsViewController, this logic needs to be prevented. self.onClickBack() } @@ -1259,6 +1278,14 @@ open class SBUGroupChannelViewController: SBUBaseChannelViewController, SBUGroup self.inputComponent?.dismissSuggestedMentionList() } + open override func baseChannelModule(_ inputComponent: SBUBaseChannelModule.Input, didChangeText text: String) { + super.baseChannelModule(inputComponent, didChangeText: text) + + #if SWIFTUI + self.swiftUIDelegate?.groupChannelViewDidChangeMessageText(text) + #endif + } + // MARK: - SBUGroupChannelViewModelDataSource open func groupChannelViewModel(_ viewModel: SBUGroupChannelViewModel, startingPointIndexPathsForChannel channel: GroupChannel?) -> [IndexPath]? { diff --git a/Sources/View/Channel/SBUOpenChannelViewController.swift b/Sources/uikit/View/Channel/SBUOpenChannelViewController.swift similarity index 99% rename from Sources/View/Channel/SBUOpenChannelViewController.swift rename to Sources/uikit/View/Channel/SBUOpenChannelViewController.swift index 2363178..ba70adb 100644 --- a/Sources/View/Channel/SBUOpenChannelViewController.swift +++ b/Sources/uikit/View/Channel/SBUOpenChannelViewController.swift @@ -13,6 +13,12 @@ import Photos import SwiftUI #endif +#if SWIFTUI +protocol OpenChannelViewEventDelegate: AnyObject { + +} +#endif + @objcMembers open class SBUOpenChannelViewController: SBUBaseChannelViewController, SBUOpenChannelViewModelDelegate, SBUOpenChannelModuleHeaderDelegate, SBUOpenChannelModuleListDelegate, SBUOpenChannelModuleInputDelegate, SBUOpenChannelModuleMediaDelegate, SBUOpenChannelModuleListDataSource, SBUOpenChannelModuleInputDataSource, SBUOpenChannelViewModelDataSource { @@ -128,6 +134,12 @@ open class SBUOpenChannelViewController: SBUBaseChannelViewController, SBUOpenCh #if SWIFTUI var channelSettingsViewBuilder: OpenChannelSettingsViewBuilder? var participantListViewBuilder: OpenParticipantListViewBuilder? + + weak var swiftUIDelegate: (SBUOpenChannelViewModelDelegate & OpenChannelViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle @@ -874,7 +886,7 @@ open class SBUOpenChannelViewController: SBUBaseChannelViewController, SBUOpenCh withContext context: MessageContext ) { guard channel != nil else { - if self.navigationController?.viewControllers.last == self { + if self.isLastInNavigationStack() { // If leave is called in the ChannelSettingsViewController, this logic needs to be prevented. self.onClickBack() } diff --git a/Sources/View/Channel/ScrollBottomView/SBUScrollBottomView.swift b/Sources/uikit/View/Channel/ScrollBottomView/SBUScrollBottomView.swift similarity index 99% rename from Sources/View/Channel/ScrollBottomView/SBUScrollBottomView.swift rename to Sources/uikit/View/Channel/ScrollBottomView/SBUScrollBottomView.swift index 01505c7..c0aa3ca 100644 --- a/Sources/View/Channel/ScrollBottomView/SBUScrollBottomView.swift +++ b/Sources/uikit/View/Channel/ScrollBottomView/SBUScrollBottomView.swift @@ -10,7 +10,7 @@ import UIKit import SendbirdChatSDK /// ScrollBottomView used in the channel -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUScrollBottomView: SBUView { var channelType: ChannelType = .group diff --git a/Sources/View/Channel/ViewModel/SBUMessageWebViewModel.swift b/Sources/uikit/View/Channel/ViewModel/SBUMessageWebViewModel.swift similarity index 100% rename from Sources/View/Channel/ViewModel/SBUMessageWebViewModel.swift rename to Sources/uikit/View/Channel/ViewModel/SBUMessageWebViewModel.swift diff --git a/Sources/View/Channel/ViewModel/SBUUserMessageTextViewModel.swift b/Sources/uikit/View/Channel/ViewModel/SBUUserMessageTextViewModel.swift similarity index 100% rename from Sources/View/Channel/ViewModel/SBUUserMessageTextViewModel.swift rename to Sources/uikit/View/Channel/ViewModel/SBUUserMessageTextViewModel.swift diff --git a/Sources/View/ChannelList/ChannelCell/SBUBaseChannelCell.swift b/Sources/uikit/View/ChannelList/ChannelCell/SBUBaseChannelCell.swift similarity index 100% rename from Sources/View/ChannelList/ChannelCell/SBUBaseChannelCell.swift rename to Sources/uikit/View/ChannelList/ChannelCell/SBUBaseChannelCell.swift diff --git a/Sources/View/ChannelList/ChannelCell/SBUGroupChannelCell.swift b/Sources/uikit/View/ChannelList/ChannelCell/SBUGroupChannelCell.swift similarity index 100% rename from Sources/View/ChannelList/ChannelCell/SBUGroupChannelCell.swift rename to Sources/uikit/View/ChannelList/ChannelCell/SBUGroupChannelCell.swift diff --git a/Sources/View/ChannelList/ChannelCell/SBUOpenChannelCell.swift b/Sources/uikit/View/ChannelList/ChannelCell/SBUOpenChannelCell.swift similarity index 100% rename from Sources/View/ChannelList/ChannelCell/SBUOpenChannelCell.swift rename to Sources/uikit/View/ChannelList/ChannelCell/SBUOpenChannelCell.swift diff --git a/Sources/View/ChannelList/SBUBaseChannelListViewController.swift b/Sources/uikit/View/ChannelList/SBUBaseChannelListViewController.swift similarity index 100% rename from Sources/View/ChannelList/SBUBaseChannelListViewController.swift rename to Sources/uikit/View/ChannelList/SBUBaseChannelListViewController.swift diff --git a/Sources/View/ChannelList/SBUGroupChannelListViewController.swift b/Sources/uikit/View/ChannelList/SBUGroupChannelListViewController.swift similarity index 93% rename from Sources/View/ChannelList/SBUGroupChannelListViewController.swift rename to Sources/uikit/View/ChannelList/SBUGroupChannelListViewController.swift index 359be87..65c7330 100644 --- a/Sources/View/ChannelList/SBUGroupChannelListViewController.swift +++ b/Sources/uikit/View/ChannelList/SBUGroupChannelListViewController.swift @@ -12,6 +12,16 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +// MARK: GroupChannelListViewEventDelegate +/// A delegate that propagates events from ``SBUGroupChannelListViewController`` to ``GroupChannelListView``. +protocol GroupChannelListViewEventDelegate: AnyObject { + func groupChannelListView(didSelectRowAt indexPath: IndexPath) + func groupChannelListView(didSelectLeaveFrom channel: GroupChannel) + func groupChannelListView(didChangePushTriggerOption channel: GroupChannel) +} +#endif + @objcMembers open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, SBUGroupChannelListModuleHeaderDelegate, SBUGroupChannelListModuleListDelegate, SBUGroupChannelListModuleListDataSource, SBUCreateChannelTypeSelectorDelegate, SBUCommonViewModelDelegate, SBUGroupChannelListViewModelDelegate { @@ -55,6 +65,12 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, #if SWIFTUI var groupChannelViewBuilder: GroupChannelViewBuilder? var createChannelViewBuilder: CreateGroupChannelViewBuilder? + + weak var swiftUIDelegate: (SBUGroupChannelListViewModelDelegate & GroupChannelListViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle @@ -277,7 +293,8 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, open func showCreateChannel(type: ChannelCreationType = .group) { #if SWIFTUI if let createChannelViewBuilder = self.createChannelViewBuilder { - let view = createChannelViewBuilder(nil, type) + let customUsers = (self.swiftUIDelegate as? CreateGroupChannelViewProvider)?.customUsers + let view = createChannelViewBuilder(customUsers, type) let createChannelVC = UIHostingController(rootView: view) self.navigationController?.pushViewControllerNonFlickering(createChannelVC, animated: true) return @@ -318,7 +335,7 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, self.navigationItem.rightBarButtonItem = rightItem } - /// 3.26.0 + /// 3.28.0 open func baseChannelListModule( _ headerComponent: SBUBaseChannelListModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]? @@ -326,7 +343,7 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, self.navigationItem.leftBarButtonItems = leftItems } - /// 3.26.0 + /// 3.28.0 open func baseChannelListModule( _ headerComponent: SBUBaseChannelListModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]? @@ -356,6 +373,10 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, guard self.channelList.count > indexPath.row else { return } let channel = self.channelList[indexPath.row] self.showChannel(channelURL: channel.channelURL) + + #if SWIFTUI + self.swiftUIDelegate?.groupChannelListView(didSelectRowAt: indexPath) + #endif } open func baseChannelListModule( @@ -378,6 +399,10 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, didSelectLeave channel: GroupChannel ) { self.viewModel?.leaveChannel(channel) + + #if SWIFTUI + self.swiftUIDelegate?.groupChannelListView(didSelectLeaveFrom: channel) + #endif } open func groupChannelListModule( @@ -386,6 +411,10 @@ open class SBUGroupChannelListViewController: SBUBaseChannelListViewController, channel: GroupChannel ) { self.viewModel?.changePushTriggerOption(option: option, channel: channel) + + #if SWIFTUI + self.swiftUIDelegate?.groupChannelListView(didChangePushTriggerOption: channel) + #endif } // MARK: - SBUGroupChannelListModuleListDataSource diff --git a/Sources/View/ChannelList/SBUOpenChannelListViewController.swift b/Sources/uikit/View/ChannelList/SBUOpenChannelListViewController.swift similarity index 95% rename from Sources/View/ChannelList/SBUOpenChannelListViewController.swift rename to Sources/uikit/View/ChannelList/SBUOpenChannelListViewController.swift index 979d809..de4e549 100644 --- a/Sources/View/ChannelList/SBUOpenChannelListViewController.swift +++ b/Sources/uikit/View/ChannelList/SBUOpenChannelListViewController.swift @@ -12,6 +12,12 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +protocol OpenChannelListViewEventDelegate: AnyObject { + func openChannelListView(didSelectRowAt indexPath: IndexPath) +} +#endif + open class SBUOpenChannelListViewController: SBUBaseChannelListViewController, SBUOpenChannelListModuleHeaderDelegate, SBUOpenChannelListModuleListDelegate, SBUOpenChannelListModuleListDataSource, SBUCommonViewModelDelegate, SBUOpenChannelListViewModelDelegate { // MARK: - UI Properties (Public) @@ -40,6 +46,12 @@ open class SBUOpenChannelListViewController: SBUBaseChannelListViewController, S #if SWIFTUI var openChannelViewBuilder: OpenChannelViewBuilder? var createChannelViewBuilder: CreateOpenChannelViewBuilder? + + weak var swiftUIDelegate: (SBUOpenChannelListViewModelDelegate & OpenChannelListViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle @@ -229,7 +241,7 @@ open class SBUOpenChannelListViewController: SBUBaseChannelListViewController, S self.navigationItem.rightBarButtonItem = rightItem } - /// 3.26.0 + /// 3.28.0 open func baseChannelListModule( _ headerComponent: SBUBaseChannelListModule.Header, didUpdateLeftItems leftItems: [UIBarButtonItem]? @@ -237,7 +249,7 @@ open class SBUOpenChannelListViewController: SBUBaseChannelListViewController, S self.navigationItem.leftBarButtonItems = leftItems } - /// 3.26.0 + /// 3.28.0 open func baseChannelListModule( _ headerComponent: SBUBaseChannelListModule.Header, didUpdateRightItems rightItems: [UIBarButtonItem]? @@ -266,6 +278,10 @@ open class SBUOpenChannelListViewController: SBUBaseChannelListViewController, S ) { guard let channel = self.viewModel?.channelList[indexPath.row] else { return } self.showChannel(channelURL: channel.channelURL) + + #if SWIFTUI + self.swiftUIDelegate?.openChannelListView(didSelectRowAt: indexPath) + #endif } open func baseChannelListModule( diff --git a/Sources/View/ChannelSettings/Cell/SBUBaseChannelSettingCell.swift b/Sources/uikit/View/ChannelSettings/Cell/SBUBaseChannelSettingCell.swift similarity index 100% rename from Sources/View/ChannelSettings/Cell/SBUBaseChannelSettingCell.swift rename to Sources/uikit/View/ChannelSettings/Cell/SBUBaseChannelSettingCell.swift diff --git a/Sources/View/ChannelSettings/Cell/SBUGroupChannelSettingCell.swift b/Sources/uikit/View/ChannelSettings/Cell/SBUGroupChannelSettingCell.swift similarity index 100% rename from Sources/View/ChannelSettings/Cell/SBUGroupChannelSettingCell.swift rename to Sources/uikit/View/ChannelSettings/Cell/SBUGroupChannelSettingCell.swift diff --git a/Sources/View/ChannelSettings/Cell/SBUModerationCell.swift b/Sources/uikit/View/ChannelSettings/Cell/SBUModerationCell.swift similarity index 99% rename from Sources/View/ChannelSettings/Cell/SBUModerationCell.swift rename to Sources/uikit/View/ChannelSettings/Cell/SBUModerationCell.swift index f1ef730..f0d0ef9 100644 --- a/Sources/View/ChannelSettings/Cell/SBUModerationCell.swift +++ b/Sources/uikit/View/ChannelSettings/Cell/SBUModerationCell.swift @@ -10,7 +10,7 @@ import UIKit import SendbirdChatSDK /// ModerationCell class that inherits from BaseChannelSettingCell -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUModerationCell: SBUBaseChannelSettingCell { /// This function configure a cell using moderation list information. /// - Parameter channel: channel object diff --git a/Sources/View/ChannelSettings/Cell/SBUOpenChannelSettingCell.swift b/Sources/uikit/View/ChannelSettings/Cell/SBUOpenChannelSettingCell.swift similarity index 100% rename from Sources/View/ChannelSettings/Cell/SBUOpenChannelSettingCell.swift rename to Sources/uikit/View/ChannelSettings/Cell/SBUOpenChannelSettingCell.swift diff --git a/Sources/View/ChannelSettings/SBUBaseChannelSettingsViewController.swift b/Sources/uikit/View/ChannelSettings/SBUBaseChannelSettingsViewController.swift similarity index 100% rename from Sources/View/ChannelSettings/SBUBaseChannelSettingsViewController.swift rename to Sources/uikit/View/ChannelSettings/SBUBaseChannelSettingsViewController.swift diff --git a/Sources/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift b/Sources/uikit/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift similarity index 97% rename from Sources/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift rename to Sources/uikit/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift index 6c4c626..1e934ef 100644 --- a/Sources/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift +++ b/Sources/uikit/View/ChannelSettings/SBUGroupChannelSettingsViewController.swift @@ -12,6 +12,12 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +protocol GroupChannelSettingsViewEventDelegate: AnyObject { + +} +#endif + open class SBUGroupChannelSettingsViewController: SBUBaseChannelSettingsViewController, SBUGroupChannelSettingsModuleHeaderDelegate, SBUGroupChannelSettingsModuleHeaderDataSource, SBUGroupChannelSettingsModuleListDelegate, SBUGroupChannelSettingsModuleListDataSource, SBUGroupChannelSettingsViewModelDelegate { // MARK: - UI Properties (Public) @@ -38,6 +44,12 @@ open class SBUGroupChannelSettingsViewController: SBUBaseChannelSettingsViewCont var moderationsViewBuilder: GroupModerationsViewBuilder? var pushSettingsViewBuilder: GroupChannelPushSettingsViewBuilder? var messageSearchViewBuilder: MessageSearchViewBuilder? + + weak var swiftUIDelegate: (SBUGroupChannelSettingsViewModelDelegate & GroupChannelSettingsViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle diff --git a/Sources/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift b/Sources/uikit/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift similarity index 97% rename from Sources/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift rename to Sources/uikit/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift index a99a669..9eb0a8c 100644 --- a/Sources/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift +++ b/Sources/uikit/View/ChannelSettings/SBUOpenChannelSettingsViewController.swift @@ -12,6 +12,12 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +protocol OpenChannelSettingsViewEventDelegate: AnyObject { + +} +#endif + open class SBUOpenChannelSettingsViewController: SBUBaseChannelSettingsViewController, SBUOpenChannelSettingsModuleHeaderDelegate, SBUOpenChannelSettingsModuleListDelegate, SBUOpenChannelSettingsModuleListDataSource, SBUOpenChannelSettingsViewModelDelegate { // MARK: - UI Properties (Public) @@ -36,6 +42,12 @@ open class SBUOpenChannelSettingsViewController: SBUBaseChannelSettingsViewContr #if SWIFTUI var participantListViewBuilder: OpenParticipantListViewBuilder? var moderationsViewBuilder: OpenModerationsViewBuilder? + + weak var swiftUIDelegate: (SBUOpenChannelSettingsViewModelDelegate & OpenChannelSettingsViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle diff --git a/Sources/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift b/Sources/uikit/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift similarity index 99% rename from Sources/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift rename to Sources/uikit/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift index dd5de99..227fe68 100644 --- a/Sources/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift +++ b/Sources/uikit/View/ChannelSettings/View/SBUChannelSettingsChannelInfoView.swift @@ -10,7 +10,7 @@ import UIKit import SendbirdChatSDK /// Info view used in channel setting -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUChannelSettingsChannelInfoView: SBUView { public lazy var stackView = UIStackView() public lazy var coverImage = SBUCoverImageView() diff --git a/Sources/View/Common/ActionSheet/SBUActionSheet.Item.swift b/Sources/uikit/View/Common/ActionSheet/SBUActionSheet.Item.swift similarity index 97% rename from Sources/View/Common/ActionSheet/SBUActionSheet.Item.swift rename to Sources/uikit/View/Common/ActionSheet/SBUActionSheet.Item.swift index 3434394..efa3d4e 100644 --- a/Sources/View/Common/ActionSheet/SBUActionSheet.Item.swift +++ b/Sources/uikit/View/Common/ActionSheet/SBUActionSheet.Item.swift @@ -11,11 +11,11 @@ import UIKit /// This class represents an item in an action sheet. public class SBUActionSheetItem: SBUCommonItem { /// The completion handler of the action sheet item. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var completionHandler: SBUActionSheetHandler? /// This property indicates whether the text alignment is set. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var isTextAlignmentSet = false /// initializer diff --git a/Sources/View/Common/ActionSheet/SBUActionSheet.swift b/Sources/uikit/View/Common/ActionSheet/SBUActionSheet.swift similarity index 100% rename from Sources/View/Common/ActionSheet/SBUActionSheet.swift rename to Sources/uikit/View/Common/ActionSheet/SBUActionSheet.swift diff --git a/Sources/View/Common/AlertView/SBUAlertView.Item.swift b/Sources/uikit/View/Common/AlertView/SBUAlertView.Item.swift similarity index 93% rename from Sources/View/Common/AlertView/SBUAlertView.Item.swift rename to Sources/uikit/View/Common/AlertView/SBUAlertView.Item.swift index c422a46..1c27c90 100644 --- a/Sources/View/Common/AlertView/SBUAlertView.Item.swift +++ b/Sources/uikit/View/Common/AlertView/SBUAlertView.Item.swift @@ -11,15 +11,15 @@ import UIKit /// `SBUAlertButtonItem` is a class that represents an alert button item. public class SBUAlertButtonItem { /// The completion handler type for the alert button. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var title: String /// The title color of the alert button. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var color: UIColor? /// The completion handler of the alert button. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var completionHandler: SBUAlertButtonHandler? /// This function initializes alert button item. diff --git a/Sources/View/Common/AlertView/SBUAlertView.swift b/Sources/uikit/View/Common/AlertView/SBUAlertView.swift similarity index 99% rename from Sources/View/Common/AlertView/SBUAlertView.swift rename to Sources/uikit/View/Common/AlertView/SBUAlertView.swift index 658809d..7e88a06 100644 --- a/Sources/View/Common/AlertView/SBUAlertView.swift +++ b/Sources/uikit/View/Common/AlertView/SBUAlertView.swift @@ -9,11 +9,11 @@ import UIKit /// This typealias is used for handling alert button actions. It takes an optional parameter of type `Any`. -/// - Since: 3.26.0 +/// - Since: 3.28.0 public typealias SBUAlertButtonHandler = (_ info: Any?) -> Void /// This typealias is used for handling alert button actions. It takes an optional parameter of type `Any`. -@available(*, deprecated, renamed: "SBUAlertButtonHandler") // 3.26.0 +@available(*, deprecated, renamed: "SBUAlertButtonHandler") // 3.28.0 public typealias AlertButtonHandler = SBUAlertButtonHandler /// SBUAlertViewDelegate is a delegate that defines methods for handling alert view events. @@ -353,7 +353,7 @@ extension SBUAlertView { // MARK: Button action /// This function is called when the button is clicked. - /// - Since: 3.26.0 + /// - Since: 3.28.0 @objc public func onClickAlertButton(sender: UIButton) { let index = sender.tag @@ -604,7 +604,7 @@ extension SBUAlertView { // MARK: Create items /// This function creates a title label. - /// - Since: 3.26.0 + /// - Since: 3.28.0 private func createTitleLabel() -> UILabel { let label = UILabel(frame: CGRect( origin: CGPoint( @@ -618,7 +618,7 @@ extension SBUAlertView { } /// This function creates a message label. - /// - Since: 3.26.0 + /// - Since: 3.28.0 private func createMessageLabel(originY: CGFloat) -> UILabel? { guard self.message != nil else { return nil } @@ -634,7 +634,7 @@ extension SBUAlertView { } /// This function creates a inputFiled. - /// - Since: 3.26.0 + /// - Since: 3.28.0 private func createInputField(originY: CGFloat) -> UITextField? { if self.needInputField { let textField = UITextField() @@ -658,7 +658,7 @@ extension SBUAlertView { } /// This function creates a separator. - /// - Since: 3.26.0 + /// - Since: 3.28.0 private func createSeparator(originY: CGFloat) -> UIView { let view = UIView(frame: CGRect( origin: CGPoint(x: 0, y: originY-0.5), @@ -668,7 +668,7 @@ extension SBUAlertView { } /// This function creates a cancel button. - /// - Since: 3.26.0 + /// - Since: 3.28.0 private func createCancelButton( originY: CGFloat, buttonOriginX: CGFloat = 0.0 @@ -700,7 +700,7 @@ extension SBUAlertView { } /// This function creates a confirm button. - /// - Since: 3.26.0 + /// - Since: 3.28.0 private func createConfirmButton( originY: CGFloat, buttonOriginX: CGFloat = 0.0 diff --git a/Sources/View/Common/Menu/SBUBottomSheetController.swift b/Sources/uikit/View/Common/Menu/SBUBottomSheetController.swift similarity index 99% rename from Sources/View/Common/Menu/SBUBottomSheetController.swift rename to Sources/uikit/View/Common/Menu/SBUBottomSheetController.swift index c71c903..55a7778 100644 --- a/Sources/View/Common/Menu/SBUBottomSheetController.swift +++ b/Sources/uikit/View/Common/Menu/SBUBottomSheetController.swift @@ -9,7 +9,7 @@ import UIKit /// Represents the snap points for the bottom sheet. -/// - Since: 3.26.0 +/// - Since: 3.28.0 public enum SBUBottomSheetSnapPoint { /// The top position of the bottom sheet. case top @@ -24,7 +24,7 @@ public protocol SBUBottomSheetControllerDelegate: AnyObject { } /// A controller that manages the presentation of a bottom sheet. -/// - Since: 3.26.0 +/// - Since: 3.28.0 public class SBUBottomSheetController: UIPresentationController { /// The delegate that receives updates on the bottom sheet's position. diff --git a/Sources/View/Common/Menu/SBUMenuCell.swift b/Sources/uikit/View/Common/Menu/SBUMenuCell.swift similarity index 99% rename from Sources/View/Common/Menu/SBUMenuCell.swift rename to Sources/uikit/View/Common/Menu/SBUMenuCell.swift index d04fdf1..cf5e75c 100644 --- a/Sources/View/Common/Menu/SBUMenuCell.swift +++ b/Sources/uikit/View/Common/Menu/SBUMenuCell.swift @@ -9,7 +9,7 @@ import UIKit /// This menu cell used in the MenuSheetViewController is the menu cell -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUMenuCell: SBUTableViewCell { public lazy var containerView = { SBUStackView.init(axis: .horizontal, alignment: .fill, spacing: 30) diff --git a/Sources/View/Common/Menu/SBUMenuSheetViewController.swift b/Sources/uikit/View/Common/Menu/SBUMenuSheetViewController.swift similarity index 100% rename from Sources/View/Common/Menu/SBUMenuSheetViewController.swift rename to Sources/uikit/View/Common/Menu/SBUMenuSheetViewController.swift diff --git a/Sources/View/Common/Menu/SBUMenuView.swift b/Sources/uikit/View/Common/Menu/SBUMenuView.swift similarity index 100% rename from Sources/View/Common/Menu/SBUMenuView.swift rename to Sources/uikit/View/Common/Menu/SBUMenuView.swift diff --git a/Sources/View/Common/PhotoLibrary/SBUPhotoAccess.swift b/Sources/uikit/View/Common/PhotoLibrary/SBUPhotoAccess.swift similarity index 100% rename from Sources/View/Common/PhotoLibrary/SBUPhotoAccess.swift rename to Sources/uikit/View/Common/PhotoLibrary/SBUPhotoAccess.swift diff --git a/Sources/View/Common/PhotoLibrary/SBUPhotoCollectionViewCell.swift b/Sources/uikit/View/Common/PhotoLibrary/SBUPhotoCollectionViewCell.swift similarity index 100% rename from Sources/View/Common/PhotoLibrary/SBUPhotoCollectionViewCell.swift rename to Sources/uikit/View/Common/PhotoLibrary/SBUPhotoCollectionViewCell.swift diff --git a/Sources/View/Common/PhotoLibrary/SBUSelectablePhotoViewController.swift b/Sources/uikit/View/Common/PhotoLibrary/SBUSelectablePhotoViewController.swift similarity index 100% rename from Sources/View/Common/PhotoLibrary/SBUSelectablePhotoViewController.swift rename to Sources/uikit/View/Common/PhotoLibrary/SBUSelectablePhotoViewController.swift diff --git a/Sources/View/Common/SBUAnimation.swift b/Sources/uikit/View/Common/SBUAnimation.swift similarity index 100% rename from Sources/View/Common/SBUAnimation.swift rename to Sources/uikit/View/Common/SBUAnimation.swift diff --git a/Sources/View/Common/SBUBarButtonItem.swift b/Sources/uikit/View/Common/SBUBarButtonItem.swift similarity index 98% rename from Sources/View/Common/SBUBarButtonItem.swift rename to Sources/uikit/View/Common/SBUBarButtonItem.swift index f6f602b..14110a3 100644 --- a/Sources/View/Common/SBUBarButtonItem.swift +++ b/Sources/uikit/View/Common/SBUBarButtonItem.swift @@ -9,7 +9,7 @@ import UIKit /// A class that displays an bar button item in SendbirdUIKit. -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUBarButtonItem: UIBarButtonItem { required public init?(coder: NSCoder) { super.init(coder: coder) diff --git a/Sources/View/Common/SBUCollectionViewFlowLayout.swift b/Sources/uikit/View/Common/SBUCollectionViewFlowLayout.swift similarity index 100% rename from Sources/View/Common/SBUCollectionViewFlowLayout.swift rename to Sources/uikit/View/Common/SBUCollectionViewFlowLayout.swift diff --git a/Sources/View/Common/SBUCommonItem.swift b/Sources/uikit/View/Common/SBUCommonItem.swift similarity index 100% rename from Sources/View/Common/SBUCommonItem.swift rename to Sources/uikit/View/Common/SBUCommonItem.swift diff --git a/Sources/View/Common/SBUCommonViewControllerSet.swift b/Sources/uikit/View/Common/SBUCommonViewControllerSet.swift similarity index 93% rename from Sources/View/Common/SBUCommonViewControllerSet.swift rename to Sources/uikit/View/Common/SBUCommonViewControllerSet.swift index 3241b52..c9246d7 100644 --- a/Sources/View/Common/SBUCommonViewControllerSet.swift +++ b/Sources/uikit/View/Common/SBUCommonViewControllerSet.swift @@ -21,18 +21,18 @@ public class SBUCommonViewControllerSet { // MOD TODO: Need to add CustomViewController sample /// The view controller that shows the selected accessible photos and videos. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var SelectablePhotoViewController: SBUSelectablePhotoViewController.Type = SBUSelectablePhotoViewController.self /// The view controller that shows the message menu sheet. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var MenuSheetViewController: SBUMenuSheetViewController.Type = SBUMenuSheetViewController.self /// The view controller that shows the reactions. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var ReactionsViewController: SBUReactionsViewController.Type = SBUReactionsViewController.self /// The view controller that shows the emojis. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public static var EmojiListViewController: SBUEmojiListViewController.Type = SBUEmojiListViewController.self } diff --git a/Sources/View/Common/SBUCoverImageView.swift b/Sources/uikit/View/Common/SBUCoverImageView.swift similarity index 100% rename from Sources/View/Common/SBUCoverImageView.swift rename to Sources/uikit/View/Common/SBUCoverImageView.swift diff --git a/Sources/View/Common/SBUEmptyView.swift b/Sources/uikit/View/Common/SBUEmptyView.swift similarity index 100% rename from Sources/View/Common/SBUEmptyView.swift rename to Sources/uikit/View/Common/SBUEmptyView.swift diff --git a/Sources/View/Common/SBULayoutableButton.swift b/Sources/uikit/View/Common/SBULayoutableButton.swift similarity index 100% rename from Sources/View/Common/SBULayoutableButton.swift rename to Sources/uikit/View/Common/SBULayoutableButton.swift diff --git a/Sources/View/Common/SBULoading.swift b/Sources/uikit/View/Common/SBULoading.swift similarity index 100% rename from Sources/View/Common/SBULoading.swift rename to Sources/uikit/View/Common/SBULoading.swift diff --git a/Sources/View/Common/SBUMarginView.swift b/Sources/uikit/View/Common/SBUMarginView.swift similarity index 100% rename from Sources/View/Common/SBUMarginView.swift rename to Sources/uikit/View/Common/SBUMarginView.swift diff --git a/Sources/View/Common/SBUNavigationTitleView.swift b/Sources/uikit/View/Common/SBUNavigationTitleView.swift similarity index 100% rename from Sources/View/Common/SBUNavigationTitleView.swift rename to Sources/uikit/View/Common/SBUNavigationTitleView.swift diff --git a/Sources/View/Common/SBUNotificationEmptyView.swift b/Sources/uikit/View/Common/SBUNotificationEmptyView.swift similarity index 100% rename from Sources/View/Common/SBUNotificationEmptyView.swift rename to Sources/uikit/View/Common/SBUNotificationEmptyView.swift diff --git a/Sources/View/Common/SBUNotificationNavigationTitleView.swift b/Sources/uikit/View/Common/SBUNotificationNavigationTitleView.swift similarity index 100% rename from Sources/View/Common/SBUNotificationNavigationTitleView.swift rename to Sources/uikit/View/Common/SBUNotificationNavigationTitleView.swift diff --git a/Sources/View/Common/SBUPaddingLabel.swift b/Sources/uikit/View/Common/SBUPaddingLabel.swift similarity index 100% rename from Sources/View/Common/SBUPaddingLabel.swift rename to Sources/uikit/View/Common/SBUPaddingLabel.swift diff --git a/Sources/View/Common/SBUSearchBar.swift b/Sources/uikit/View/Common/SBUSearchBar.swift similarity index 99% rename from Sources/View/Common/SBUSearchBar.swift rename to Sources/uikit/View/Common/SBUSearchBar.swift index fdb0f8a..6163c44 100644 --- a/Sources/View/Common/SBUSearchBar.swift +++ b/Sources/uikit/View/Common/SBUSearchBar.swift @@ -9,7 +9,7 @@ import UIKit /// A class that displays a search bar in SendbirdUIKit. -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUSearchBar: UISearchBar, SBUViewLifeCycle { var theme: SBUMessageSearchTheme? diff --git a/Sources/View/Common/SBUStackView.swift b/Sources/uikit/View/Common/SBUStackView.swift similarity index 100% rename from Sources/View/Common/SBUStackView.swift rename to Sources/uikit/View/Common/SBUStackView.swift diff --git a/Sources/View/Common/SBUTemplateLabel.swift b/Sources/uikit/View/Common/SBUTemplateLabel.swift similarity index 100% rename from Sources/View/Common/SBUTemplateLabel.swift rename to Sources/uikit/View/Common/SBUTemplateLabel.swift diff --git a/Sources/View/Common/SBUTypingIndicatorBubbleView.swift b/Sources/uikit/View/Common/SBUTypingIndicatorBubbleView.swift similarity index 100% rename from Sources/View/Common/SBUTypingIndicatorBubbleView.swift rename to Sources/uikit/View/Common/SBUTypingIndicatorBubbleView.swift diff --git a/Sources/View/Common/SBUUnderLineTextField.swift b/Sources/uikit/View/Common/SBUUnderLineTextField.swift similarity index 98% rename from Sources/View/Common/SBUUnderLineTextField.swift rename to Sources/uikit/View/Common/SBUUnderLineTextField.swift index 3bfd4b0..9ec3aa8 100644 --- a/Sources/View/Common/SBUUnderLineTextField.swift +++ b/Sources/uikit/View/Common/SBUUnderLineTextField.swift @@ -12,7 +12,7 @@ open class SBUUnderLineTextField: UITextField { // MARK: - UI (Public) /// A layer that represents the border of the text field. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public let border = CALayer() // MARK: - Life cycle diff --git a/Sources/View/Common/Toast/SBUToastType.swift b/Sources/uikit/View/Common/Toast/SBUToastType.swift similarity index 100% rename from Sources/View/Common/Toast/SBUToastType.swift rename to Sources/uikit/View/Common/Toast/SBUToastType.swift diff --git a/Sources/View/Common/Toast/SBUToastView.Internal.swift b/Sources/uikit/View/Common/Toast/SBUToastView.Internal.swift similarity index 100% rename from Sources/View/Common/Toast/SBUToastView.Internal.swift rename to Sources/uikit/View/Common/Toast/SBUToastView.Internal.swift diff --git a/Sources/View/Common/Toast/SBUToastView.Item.swift b/Sources/uikit/View/Common/Toast/SBUToastView.Item.swift similarity index 96% rename from Sources/View/Common/Toast/SBUToastView.Item.swift rename to Sources/uikit/View/Common/Toast/SBUToastView.Item.swift index 8a89521..0f5b6fe 100644 --- a/Sources/View/Common/Toast/SBUToastView.Item.swift +++ b/Sources/uikit/View/Common/Toast/SBUToastView.Item.swift @@ -12,15 +12,15 @@ import UIKit /// - Since: 3.15.0 public class SBUToastViewItem: SBUCommonItem { /// The position of the toast view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var position: Position /// The duration of the toast view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var duration: Double /// The completion handler of the toast view. - /// - Since: 3.26.0 + /// - Since: 3.28.0 public var completionHandler: SBUToastViewHandler? /// This function initializes toast view item. diff --git a/Sources/View/Common/Toast/SBUToastView.swift b/Sources/uikit/View/Common/Toast/SBUToastView.swift similarity index 100% rename from Sources/View/Common/Toast/SBUToastView.swift rename to Sources/uikit/View/Common/Toast/SBUToastView.swift diff --git a/Sources/View/Common/User/SBUUserProfileView.swift b/Sources/uikit/View/Common/User/SBUUserProfileView.swift similarity index 99% rename from Sources/View/Common/User/SBUUserProfileView.swift rename to Sources/uikit/View/Common/User/SBUUserProfileView.swift index c15e5b0..0d9e313 100644 --- a/Sources/View/Common/User/SBUUserProfileView.swift +++ b/Sources/uikit/View/Common/User/SBUUserProfileView.swift @@ -41,7 +41,7 @@ public protocol SBUUserProfileViewProtocol { } /// Default user profile view -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUUserProfileView: UIView, SBUUserProfileViewProtocol { // MARK: - Property diff --git a/Sources/View/Common/UserCell/SBUUserCell.swift b/Sources/uikit/View/Common/UserCell/SBUUserCell.swift similarity index 100% rename from Sources/View/Common/UserCell/SBUUserCell.swift rename to Sources/uikit/View/Common/UserCell/SBUUserCell.swift diff --git a/Sources/View/Life cycles/SBUCollectionViewCell.swift b/Sources/uikit/View/Life cycles/SBUCollectionViewCell.swift similarity index 100% rename from Sources/View/Life cycles/SBUCollectionViewCell.swift rename to Sources/uikit/View/Life cycles/SBUCollectionViewCell.swift diff --git a/Sources/View/Life cycles/SBULabel.swift b/Sources/uikit/View/Life cycles/SBULabel.swift similarity index 98% rename from Sources/View/Life cycles/SBULabel.swift rename to Sources/uikit/View/Life cycles/SBULabel.swift index 8c397df..89d0c5f 100644 --- a/Sources/View/Life cycles/SBULabel.swift +++ b/Sources/uikit/View/Life cycles/SBULabel.swift @@ -9,7 +9,7 @@ import UIKit /// The `UILabel` conforming to `SBUViewLifeCycle` -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBULabel: UILabel { /// Initializes `UILabel` and set up subviews, auto layouts and actions for SendbirdUIKit. diff --git a/Sources/View/Life cycles/SBUMessageCellProtocol.swift b/Sources/uikit/View/Life cycles/SBUMessageCellProtocol.swift similarity index 100% rename from Sources/View/Life cycles/SBUMessageCellProtocol.swift rename to Sources/uikit/View/Life cycles/SBUMessageCellProtocol.swift diff --git a/Sources/View/Life cycles/SBUQuoteMessageInputViewProtocol.swift b/Sources/uikit/View/Life cycles/SBUQuoteMessageInputViewProtocol.swift similarity index 100% rename from Sources/View/Life cycles/SBUQuoteMessageInputViewProtocol.swift rename to Sources/uikit/View/Life cycles/SBUQuoteMessageInputViewProtocol.swift diff --git a/Sources/View/Life cycles/SBUQuotedMessageViewProtocol.swift b/Sources/uikit/View/Life cycles/SBUQuotedMessageViewProtocol.swift similarity index 100% rename from Sources/View/Life cycles/SBUQuotedMessageViewProtocol.swift rename to Sources/uikit/View/Life cycles/SBUQuotedMessageViewProtocol.swift diff --git a/Sources/View/Life cycles/SBUTableViewCell.swift b/Sources/uikit/View/Life cycles/SBUTableViewCell.swift similarity index 100% rename from Sources/View/Life cycles/SBUTableViewCell.swift rename to Sources/uikit/View/Life cycles/SBUTableViewCell.swift diff --git a/Sources/View/Life cycles/SBUTextView.swift b/Sources/uikit/View/Life cycles/SBUTextView.swift similarity index 100% rename from Sources/View/Life cycles/SBUTextView.swift rename to Sources/uikit/View/Life cycles/SBUTextView.swift diff --git a/Sources/View/Life cycles/SBUView.swift b/Sources/uikit/View/Life cycles/SBUView.swift similarity index 100% rename from Sources/View/Life cycles/SBUView.swift rename to Sources/uikit/View/Life cycles/SBUView.swift diff --git a/Sources/View/Life cycles/SBUViewLifeCycle.swift b/Sources/uikit/View/Life cycles/SBUViewLifeCycle.swift similarity index 100% rename from Sources/View/Life cycles/SBUViewLifeCycle.swift rename to Sources/uikit/View/Life cycles/SBUViewLifeCycle.swift diff --git a/Sources/View/MessageSearch/Cell/SBUMessageSearchResultCell.swift b/Sources/uikit/View/MessageSearch/Cell/SBUMessageSearchResultCell.swift similarity index 100% rename from Sources/View/MessageSearch/Cell/SBUMessageSearchResultCell.swift rename to Sources/uikit/View/MessageSearch/Cell/SBUMessageSearchResultCell.swift diff --git a/Sources/View/MessageSearch/SBUMessageSearchViewController.swift b/Sources/uikit/View/MessageSearch/SBUMessageSearchViewController.swift similarity index 97% rename from Sources/View/MessageSearch/SBUMessageSearchViewController.swift rename to Sources/uikit/View/MessageSearch/SBUMessageSearchViewController.swift index 75b4aa9..365903f 100644 --- a/Sources/View/MessageSearch/SBUMessageSearchViewController.swift +++ b/Sources/uikit/View/MessageSearch/SBUMessageSearchViewController.swift @@ -12,6 +12,12 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +protocol MessageSearchViewEventDelegate: AnyObject { + +} +#endif + /// ViewController handling a message search. /// /// - Since: 2.1.0 @@ -34,8 +40,15 @@ open class SBUMessageSearchViewController: SBUBaseViewController, SBUMessageSear /// You can set custom query params for message search. public var customMessageSearchQueryParams: MessageSearchQueryParams? + // MARK: - SwiftUI #if SWIFTUI var groupChannelViewBuilder: GroupChannelViewBuilder? + + weak var swiftUIDelegate: (SBUMessageSearchViewModelDelegate & MessageSearchViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle @@ -115,7 +128,7 @@ open class SBUMessageSearchViewController: SBUBaseViewController, SBUMessageSear } /// Create view model with channelURL - /// - Since: 3.26.0 + /// - Since: 3.28.0 open func createViewModel(channelURL: String) { self.viewModel = SBUViewModelSet.MessageSearchViewModel.init( channelURL: channelURL, diff --git a/Sources/View/MessageThread/SBUMessageThreadTitleView.swift b/Sources/uikit/View/MessageThread/SBUMessageThreadTitleView.swift similarity index 100% rename from Sources/View/MessageThread/SBUMessageThreadTitleView.swift rename to Sources/uikit/View/MessageThread/SBUMessageThreadTitleView.swift diff --git a/Sources/View/MessageThread/SBUMessageThreadViewController.swift b/Sources/uikit/View/MessageThread/SBUMessageThreadViewController.swift similarity index 99% rename from Sources/View/MessageThread/SBUMessageThreadViewController.swift rename to Sources/uikit/View/MessageThread/SBUMessageThreadViewController.swift index e4fbe1e..62951e4 100644 --- a/Sources/View/MessageThread/SBUMessageThreadViewController.swift +++ b/Sources/uikit/View/MessageThread/SBUMessageThreadViewController.swift @@ -16,6 +16,12 @@ import PhotosUI import SwiftUI #endif +#if SWIFTUI +protocol MessageThreadViewEventDelegate: AnyObject { + +} +#endif + public protocol SBUMessageThreadViewControllerDelegate: AnyObject { /// Called when `SBUThreadInfoView` was tapped. /// - Parameter threadInfoView: The tapped thread info view. @@ -73,6 +79,13 @@ open class SBUMessageThreadViewController: SBUBaseChannelViewController, SBUMess // MARK: - Logic properties (Private) var voiceFileInfos: [String: SBUVoiceFileInfo]? + #if SWIFTUI + weak var swiftUIDelegate: (SBUMessageThreadViewModelDelegate & MessageThreadViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } + #endif // MARK: - Lifecycle @available(*, unavailable) required public init(channelURL: String, startingPoint: Int64? = nil, messageListParams: MessageListParams? = nil) { @@ -834,7 +847,7 @@ open class SBUMessageThreadViewController: SBUBaseChannelViewController, SBUMess ) { guard channel != nil else { // channel deleted - if self.navigationController?.viewControllers.last == self { + if self.isLastInNavigationStack() { // If leave is called in the ChannelSettingsViewController, this logic needs to be prevented. self.onClickBack() } diff --git a/Sources/View/MessageThread/SBUParentMessageInfoView.swift b/Sources/uikit/View/MessageThread/SBUParentMessageInfoView.swift similarity index 99% rename from Sources/View/MessageThread/SBUParentMessageInfoView.swift rename to Sources/uikit/View/MessageThread/SBUParentMessageInfoView.swift index 2d529b7..1cbce97 100644 --- a/Sources/View/MessageThread/SBUParentMessageInfoView.swift +++ b/Sources/uikit/View/MessageThread/SBUParentMessageInfoView.swift @@ -720,7 +720,7 @@ open class SBUParentMessageInfoView: SBUView, SBUUserMessageTextViewDelegate { } } - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func onTapSelectFile(_ fileInfo: UploadedFileInfo, index: Int) { self.fileSelectHandler?(fileInfo, index) } diff --git a/Sources/View/Moderations/SBUModerationsViewController.swift b/Sources/uikit/View/Moderations/SBUModerationsViewController.swift similarity index 94% rename from Sources/View/Moderations/SBUModerationsViewController.swift rename to Sources/uikit/View/Moderations/SBUModerationsViewController.swift index f6308e2..7fd58f0 100644 --- a/Sources/View/Moderations/SBUModerationsViewController.swift +++ b/Sources/uikit/View/Moderations/SBUModerationsViewController.swift @@ -12,6 +12,12 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +protocol ModerationsViewEventDelegate: AnyObject { + func moderationsView(didChangeFrozenState isFrozen: Bool) +} +#endif + open class SBUModerationsViewController: SBUBaseViewController, SBUModerationsModuleHeaderDelegate, SBUModerationsModuleListDelegate, SBUModerationsModuleListDataSource, SBUCommonViewModelDelegate, SBUModerationsViewModelDelegate { // MARK: - UI properties (Public) @@ -31,6 +37,12 @@ open class SBUModerationsViewController: SBUBaseViewController, SBUModerationsMo // MARK: - SwiftUI #if SWIFTUI + weak var swiftUIDelegate: (SBUModerationsViewModelDelegate & ModerationsViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } + var groupMemberListViewBuilder: GroupMemberListViewBuilder? var openParticipantListViewBuilder: OpenParticipantListViewBuilder? @@ -205,9 +217,19 @@ open class SBUModerationsViewController: SBUBaseViewController, SBUModerationsMo /// - Parameter completionHandler: completion handler of freeze status change public func changeFreeze(_ freeze: Bool, _ completionHandler: ((Bool) -> Void)? = nil) { if freeze { - self.viewModel?.freezeChannel(completionHandler) + self.viewModel?.freezeChannel({ isFrozen in + #if SWIFTUI + self.swiftUIDelegate?.moderationsView(didChangeFrozenState: isFrozen) + #endif + completionHandler?(isFrozen) + }) } else { - self.viewModel?.unfreezeChannel(completionHandler) + self.viewModel?.unfreezeChannel({ isUnfrozen in + #if SWIFTUI + self.swiftUIDelegate?.moderationsView(didChangeFrozenState: !isUnfrozen) + #endif + completionHandler?(isUnfrozen) + }) } } diff --git a/Sources/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift b/Sources/uikit/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift similarity index 99% rename from Sources/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift rename to Sources/uikit/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift index 835cc3a..ddc1f0d 100644 --- a/Sources/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift +++ b/Sources/uikit/View/NotificationSettings/Cell/SBUChannelPushSettingCell.swift @@ -10,7 +10,7 @@ import UIKit import SendbirdChatSDK /// Channel Push Setting cell class -/// - Since: 3.26.0 +/// - Since: 3.28.0 open class SBUChannelPushSettingCell: SBUTableViewCell { /// base vertical stack view public lazy var baseStackView = SBUStackView(axis: .vertical, alignment: .fill, spacing: 16) diff --git a/Sources/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift b/Sources/uikit/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift similarity index 95% rename from Sources/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift rename to Sources/uikit/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift index 303996b..9942f65 100644 --- a/Sources/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift +++ b/Sources/uikit/View/NotificationSettings/SBUGroupChannelPushSettingsViewController.swift @@ -9,6 +9,12 @@ import UIKit import SendbirdChatSDK +#if SWIFTUI +protocol GroupChannelPushSettingsViewEventDelegate: AnyObject { + +} +#endif + // swiftlint:disable type_name open class SBUGroupChannelPushSettingsViewController: SBUBaseViewController, SBUGroupChannelPushSettingsViewModelDelegate, SBUGroupChannelPushSettingsModuleHeaderDelegate, SBUGroupChannelPushSettingsModuleListDelegate, SBUGroupChannelPushSettingsModuleListDataSource { // swiftlint:enable type_name @@ -30,6 +36,15 @@ open class SBUGroupChannelPushSettingsViewController: SBUBaseViewController, SBU public var channel: BaseChannel? { viewModel?.channel } public var channelURL: String? { viewModel?.channelURL } + // MARK: - SwiftUI + #if SWIFTUI + weak var swiftUIDelegate: (SBUGroupChannelPushSettingsViewModelDelegate & GroupChannelPushSettingsViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } + #endif + // MARK: - Lifecycle @available(*, unavailable, renamed: "SBUGroupChannelPushSettingsViewController(channelURL:type:)") required public init?(coder: NSCoder) { diff --git a/Sources/View/SBUBaseViewController.swift b/Sources/uikit/View/SBUBaseViewController.swift similarity index 93% rename from Sources/View/SBUBaseViewController.swift rename to Sources/uikit/View/SBUBaseViewController.swift index de19baf..7bf14ca 100644 --- a/Sources/View/SBUBaseViewController.swift +++ b/Sources/uikit/View/SBUBaseViewController.swift @@ -133,6 +133,21 @@ open class SBUBaseViewController: UIViewController, UINavigationControllerDelega SBULog.error("Did receive error: \(message ?? "")") } + // MARK: UINavigationController + func isLastInNavigationStack() -> Bool { + if self.navigationController?.viewControllers.last == self { + return true + } + #if SWIFTUI + // In SwiftUI, a UIViewController is wrapped inside a UIHostingController. + // The navigationController has access to the UIHostingController and not the UIViewController. + if self.navigationController?.viewControllers.last == self.parent { + return true + } + #endif + return false + } + // MARK: - UINavigationControllerDelegate open func navigationController(_ navigationController: UINavigationController, didShow viewController: UIViewController, animated: Bool) { // prevent swipe to pop if current vc is the first one. App freezes (https://sendbird.atlassian.net/browse/QU-234) diff --git a/Sources/View/SBUViewControllerSet.swift b/Sources/uikit/View/SBUViewControllerSet.swift similarity index 100% rename from Sources/View/SBUViewControllerSet.swift rename to Sources/uikit/View/SBUViewControllerSet.swift diff --git a/Sources/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift b/Sources/uikit/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift similarity index 94% rename from Sources/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift rename to Sources/uikit/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift index ad4bce3..244adcc 100644 --- a/Sources/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift +++ b/Sources/uikit/View/SelectUser/CreateChannel/SBUCreateChannelViewController.swift @@ -9,6 +9,12 @@ import UIKit import SendbirdChatSDK +#if SWIFTUI +protocol CreateGroupChannelViewEventDelegate: AnyObject { + func createGroupChannelView(didSelectRowAt indexPath: IndexPath) +} +#endif + open class SBUCreateChannelViewController: SBUBaseViewController, SBUCreateChannelModuleHeaderDelegate, SBUCreateChannelModuleHeaderDataSource, SBUCreateChannelModuleListDataSource, SBUCreateChannelModuleListDelegate, SBUCommonViewModelDelegate, SBUCreateChannelViewModelDataSource, SBUCreateChannelViewModelDelegate { // MARK: - UI properties (Public) @@ -30,6 +36,15 @@ open class SBUCreateChannelViewController: SBUBaseViewController, SBUCreateChann private var users: [SBUUser]? = nil private var type: ChannelCreationType = .group + // MARK: - SwiftUI + #if SWIFTUI + weak var swiftUIDelegate: (SBUCreateChannelViewModelDelegate & CreateGroupChannelViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } + #endif + // MARK: - Lifecycle @available(*, unavailable, renamed: "SBUCreateChannelViewController(type:)") required public init?(coder: NSCoder) { @@ -240,6 +255,10 @@ open class SBUCreateChannelViewController: SBUBaseViewController, SBUCreateChann didSelectRowAt indexPath: IndexPath) { guard let user = self.viewModel?.userList[indexPath.row] else { return } self.viewModel?.selectUser(user: user) + + #if SWIFTUI + self.swiftUIDelegate?.createGroupChannelView(didSelectRowAt: indexPath) + #endif } open func createChannelModule(_ listComponent: SBUCreateChannelModule.List, didDetectPreloadingPosition indexPath: IndexPath) { @@ -271,7 +290,11 @@ open class SBUCreateChannelViewController: SBUBaseViewController, SBUCreateChann } // MARK: - SBUCreateChannelViewModelDelegate - open func createChannelViewModel(_ viewModel: SBUCreateChannelViewModel, didChangeUsers users: [SBUUser], needsToReload: Bool) { + open func createChannelViewModel( + _ viewModel: SBUCreateChannelViewModel, + didChangeUsers users: [SBUUser], + needsToReload: Bool + ) { let emptyType: EmptyViewType = users.count == 0 ? .noMembers : .none self.listComponent?.updateEmptyView(type: emptyType) @@ -300,10 +323,12 @@ open class SBUCreateChannelViewController: SBUBaseViewController, SBUCreateChann didUpdateSelectedUsers selectedUsers: [SBUUser] ) { var didApplyRightBarButtonViewConverter = false + #if SWIFTUI didApplyRightBarButtonViewConverter = self.headerComponent?.applyViewConverter(.rightView) ?? false self.listComponent?.applyViewConverter(.entireContent) #endif + if !didApplyRightBarButtonViewConverter { self.headerComponent?.updateRightBarButton() } diff --git a/Sources/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift b/Sources/uikit/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift similarity index 97% rename from Sources/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift rename to Sources/uikit/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift index 0c2b1da..d6e48e7 100644 --- a/Sources/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift +++ b/Sources/uikit/View/SelectUser/CreateChannel/SBUCreateOpenChannelViewController.swift @@ -11,6 +11,12 @@ import SendbirdChatSDK import PhotosUI import MobileCoreServices +#if SWIFTUI +protocol CreateOpenChannelViewEventDelegate: AnyObject { + +} +#endif + open class SBUCreateOpenChannelViewController: SBUBaseViewController, SBUActionSheetDelegate, PHPickerViewControllerDelegate, UIImagePickerControllerDelegate, SBUSelectablePhotoViewDelegate, SBUCreateOpenChannelModuleHeaderDelegate, SBUCreateOpenChannelModuleProfileInputDelegate, SBUCommonViewModelDelegate, SBUCreateOpenChannelViewModelDelegate, SBUAlertViewDelegate { // MARK: - UI properties (Public) @@ -27,6 +33,15 @@ open class SBUCreateOpenChannelViewController: SBUBaseViewController, SBUActionS // MARK: - Constant private let actionSheetIdPicker = 2 + // MARK: - SwiftUI (Internal) + #if SWIFTUI + weak var swiftUIDelegate: (SBUCreateOpenChannelViewModelDelegate & CreateOpenChannelViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } + #endif + // MARK: - Lifecycle @available(*, unavailable, renamed: "SBUCreateOpenChannelViewController()") required public init?(coder: NSCoder) { diff --git a/Sources/View/SelectUser/CreateChannel/View/SBUCreateChannelTypeSelector.swift b/Sources/uikit/View/SelectUser/CreateChannel/View/SBUCreateChannelTypeSelector.swift similarity index 100% rename from Sources/View/SelectUser/CreateChannel/View/SBUCreateChannelTypeSelector.swift rename to Sources/uikit/View/SelectUser/CreateChannel/View/SBUCreateChannelTypeSelector.swift diff --git a/Sources/View/SelectUser/SBUBaseSelectUserViewController.swift b/Sources/uikit/View/SelectUser/SBUBaseSelectUserViewController.swift similarity index 100% rename from Sources/View/SelectUser/SBUBaseSelectUserViewController.swift rename to Sources/uikit/View/SelectUser/SBUBaseSelectUserViewController.swift diff --git a/Sources/View/SelectUser/SBUInviteUserViewController.swift b/Sources/uikit/View/SelectUser/SBUInviteUserViewController.swift similarity index 95% rename from Sources/View/SelectUser/SBUInviteUserViewController.swift rename to Sources/uikit/View/SelectUser/SBUInviteUserViewController.swift index f2f09eb..b686660 100644 --- a/Sources/View/SelectUser/SBUInviteUserViewController.swift +++ b/Sources/uikit/View/SelectUser/SBUInviteUserViewController.swift @@ -9,6 +9,12 @@ import UIKit import SendbirdChatSDK +#if SWIFTUI +protocol InviteUserViewEventDelegate: AnyObject { + +} +#endif + open class SBUInviteUserViewController: SBUBaseSelectUserViewController, SBUInviteUserViewModelDataSource, SBUInviteUserModuleListDataSource, SBUInviteUserModuleHeaderDataSource, SBUInviteUserModuleHeaderDelegate, SBUInviteUserModuleListDelegate, SBUInviteUserViewModelDelegate { // MARK: - UI Properties (Public) @@ -27,6 +33,15 @@ open class SBUInviteUserViewController: SBUBaseSelectUserViewController, SBUInvi set { self.baseViewModel = newValue } } + // MARK: - SwiftUI + #if SWIFTUI + weak var swiftUIDelegate: (SBUInviteUserViewModelDelegate & InviteUserViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(self.swiftUIDelegate, type: .swiftui) + } + } + #endif + // MARK: - Lifecycle @available(*, unavailable, renamed: "SBUInviteUserViewController(channel:)") required public init?(coder: NSCoder) { diff --git a/Sources/View/SelectUser/SBURegisterOperatorViewController.swift b/Sources/uikit/View/SelectUser/SBURegisterOperatorViewController.swift similarity index 94% rename from Sources/View/SelectUser/SBURegisterOperatorViewController.swift rename to Sources/uikit/View/SelectUser/SBURegisterOperatorViewController.swift index 1f596ea..3bf12bb 100644 --- a/Sources/View/SelectUser/SBURegisterOperatorViewController.swift +++ b/Sources/uikit/View/SelectUser/SBURegisterOperatorViewController.swift @@ -9,6 +9,12 @@ import UIKit import SendbirdChatSDK +#if SWIFTUI +protocol RegisterOperatorViewEventDelegate: AnyObject { + func registerOperatorView(didSelectRowAt indexPath: IndexPath) +} +#endif + open class SBURegisterOperatorViewController: SBUBaseSelectUserViewController, SBURegisterOperatorViewModelDataSource, SBURegisterOperatorModuleListDataSource, SBURegisterOperatorModuleHeaderDataSource, SBURegisterOperatorModuleHeaderDelegate, SBURegisterOperatorModuleListDelegate, SBURegisterOperatorViewModelDelegate { // MARK: - UI Properties (Public) @@ -27,6 +33,15 @@ open class SBURegisterOperatorViewController: SBUBaseSelectUserViewController, S set { self.baseViewModel = newValue } } + // MARK: - SwiftUI + #if SWIFTUI + weak var swiftUIDelegate: (SBURegisterOperatorViewModelDelegate & RegisterOperatorViewEventDelegate)? { + didSet { + self.viewModel?.baseDelegates.addDelegate(swiftUIDelegate, type: .swiftui) + } + } + #endif + // MARK: - Lifecycle @available(*, unavailable, renamed: "SBURegisterOperatorViewController(channel:)") required public init?(coder: NSCoder) { @@ -212,6 +227,10 @@ open class SBURegisterOperatorViewController: SBUBaseSelectUserViewController, S ) { guard let user = self.viewModel?.userList[indexPath.row] else { return } self.viewModel?.selectUser(user: user) + + #if SWIFTUI + self.swiftUIDelegate?.registerOperatorView(didSelectRowAt: indexPath) + #endif } open func registerOperatorModule( diff --git a/Sources/View/UserList/SBUUserListViewController.swift b/Sources/uikit/View/UserList/SBUUserListViewController.swift similarity index 96% rename from Sources/View/UserList/SBUUserListViewController.swift rename to Sources/uikit/View/UserList/SBUUserListViewController.swift index 92bc4fe..1307a95 100644 --- a/Sources/View/UserList/SBUUserListViewController.swift +++ b/Sources/uikit/View/UserList/SBUUserListViewController.swift @@ -12,6 +12,12 @@ import SendbirdChatSDK import SwiftUI #endif +#if SWIFTUI +protocol UserListViewEventDelegate: AnyObject { + func userListView(didSelectRowAt indexPath: IndexPath) +} +#endif + /// This class handling members, operators, muted/Participants, banned, participants, open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHeaderDelegate, SBUUserListModuleListDelegate, SBUUserListModuleListDataSource, SBUCommonViewModelDelegate, SBUUserProfileViewDelegate, SBUUserListViewModelDelegate, SBUUserListViewModelDataSource { @@ -46,6 +52,12 @@ open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHe var inviteUserViewBuilder: InviteUserViewBuilder? var groupChannelRegisterOperatorViewBuilder: GroupChannelRegisterOperatorViewBuilder? var openChannelRegisterOperatorViewBuilder: OpenChannelRegisterOperatorViewBuilder? + + weak var swiftUIDelegate: (SBUUserListViewModelDelegate & UserListViewEventDelegate)? { + didSet { + self.viewModel?.delegates.addDelegate(swiftUIDelegate, type: .swiftui) + } + } #endif // MARK: - Lifecycle @@ -258,14 +270,14 @@ open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHe switch type { case .users: if let inviteUserViewBuilder = self.inviteUserViewBuilder { - var view = inviteUserViewBuilder(groupChannel.channelURL) + let view = inviteUserViewBuilder(groupChannel.channelURL) let inviteUserVC = UIHostingController(rootView: view) self.navigationController?.pushViewControllerNonFlickering(inviteUserVC, animated: true) return } case .operators: if let groupChannelRegisterOperatorViewBuilder = self.groupChannelRegisterOperatorViewBuilder { - var view = groupChannelRegisterOperatorViewBuilder(groupChannel.channelURL) + let view = groupChannelRegisterOperatorViewBuilder(groupChannel.channelURL) let registerOperatorVC = UIHostingController(rootView: view) self.navigationController?.pushViewControllerNonFlickering(registerOperatorVC, animated: true) return @@ -277,7 +289,7 @@ open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHe switch type { case .operators: if let openChannelRegisterOperatorViewBuilder = self.openChannelRegisterOperatorViewBuilder { - var view = openChannelRegisterOperatorViewBuilder(openChannel.channelURL) + let view = openChannelRegisterOperatorViewBuilder(openChannel.channelURL) let registerOperatorVC = UIHostingController(rootView: view) self.navigationController?.pushViewControllerNonFlickering(registerOperatorVC, animated: true) return @@ -310,7 +322,7 @@ open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHe } } - /// This func tion shows the user profile + /// This function shows the user profile /// /// If you do not want to use the user profile function, override this function and leave it empty. /// - Parameter user: `SBUUser` object used for user profile configuration @@ -331,82 +343,7 @@ open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHe } } - // MARK: - Error handling - private func errorHandler(_ error: SBError) { - self.errorHandler(error.localizedDescription, error.code) - } - - open override func errorHandler(_ message: String?, _ code: NSInteger? = nil) { - SBULog.error("Did receive error: \(message ?? "")") - } - - // MARK: - SBUUserListModuleHeaderDelegate - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didUpdateTitleView titleView: UIView? - ) { - self.navigationItem.titleView = titleView - } - - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didUpdateLeftItem leftItem: UIBarButtonItem? - ) { - self.navigationItem.leftBarButtonItem = leftItem - } - - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didUpdateRightItem rightItem: UIBarButtonItem? - ) { - self.navigationItem.rightBarButtonItem = rightItem - } - - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didUpdateLeftItems leftItems: [UIBarButtonItem]? - ) { - self.navigationItem.leftBarButtonItems = leftItems - } - - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didUpdateRightItems rightItems: [UIBarButtonItem]? - ) { - self.navigationItem.rightBarButtonItems = rightItems - } - - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didTapLeftItem leftItem: UIBarButtonItem - ) { - self.onClickBack() - } - - open func userListModule( - _ headerComponent: SBUUserListModule.Header, - didTapRightItem rightItem: UIBarButtonItem - ) { - self.showInviteUser() - } - - // MARK: - SBUUserListModuleListDelegate - open func userListModule( - _ listComponent: SBUUserListModule.List, - didSelectRowAt indexPath: IndexPath - ) { } - - open func userListModule( - _ listComponent: SBUUserListModule.List, - didDetectPreloadingPosition indexPath: IndexPath - ) { - self.viewModel?.preLoadNextUserList(indexPath: indexPath) - } - - open func userListModule( - _ listComponent: SBUUserListModule.List, - didTapMoreMenuFor user: SBUUser - ) { + func showMoreMenu(with user: SBUUser) { let userNameItem = SBUActionSheetItem( title: user.nickname ?? user.userId, color: self.componentTheme.actionSheetSubTextColor, @@ -495,6 +432,89 @@ open class SBUUserListViewController: SBUBaseViewController, SBUUserListModuleHe SBUActionSheet.show(items: items, cancelItem: cancelItem, oneTimetheme: componentTheme) } + // MARK: - Error handling + private func errorHandler(_ error: SBError) { + self.errorHandler(error.localizedDescription, error.code) + } + + open override func errorHandler(_ message: String?, _ code: NSInteger? = nil) { + SBULog.error("Did receive error: \(message ?? "")") + } + + // MARK: - SBUUserListModuleHeaderDelegate + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didUpdateTitleView titleView: UIView? + ) { + self.navigationItem.titleView = titleView + } + + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didUpdateLeftItem leftItem: UIBarButtonItem? + ) { + self.navigationItem.leftBarButtonItem = leftItem + } + + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didUpdateRightItem rightItem: UIBarButtonItem? + ) { + self.navigationItem.rightBarButtonItem = rightItem + } + + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didUpdateLeftItems leftItems: [UIBarButtonItem]? + ) { + self.navigationItem.leftBarButtonItems = leftItems + } + + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didUpdateRightItems rightItems: [UIBarButtonItem]? + ) { + self.navigationItem.rightBarButtonItems = rightItems + } + + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didTapLeftItem leftItem: UIBarButtonItem + ) { + self.onClickBack() + } + + open func userListModule( + _ headerComponent: SBUUserListModule.Header, + didTapRightItem rightItem: UIBarButtonItem + ) { + self.showInviteUser() + } + + // MARK: - SBUUserListModuleListDelegate + open func userListModule( + _ listComponent: SBUUserListModule.List, + didSelectRowAt indexPath: IndexPath + ) { + #if SWIFTUI + self.swiftUIDelegate?.userListView(didSelectRowAt: indexPath) + #endif + } + + open func userListModule( + _ listComponent: SBUUserListModule.List, + didDetectPreloadingPosition indexPath: IndexPath + ) { + self.viewModel?.preLoadNextUserList(indexPath: indexPath) + } + + open func userListModule( + _ listComponent: SBUUserListModule.List, + didTapMoreMenuFor user: SBUUser + ) { + self.showMoreMenu(with: user) + } + open func userListModule( _ listComponent: SBUUserListModule.List, didTapUserProfileFor user: SBUUser diff --git a/Sources/View/VoiceNote/SBUVoiceMessageInputView.swift b/Sources/uikit/View/VoiceNote/SBUVoiceMessageInputView.swift similarity index 100% rename from Sources/View/VoiceNote/SBUVoiceMessageInputView.swift rename to Sources/uikit/View/VoiceNote/SBUVoiceMessageInputView.swift diff --git a/Sources/ViewModel/Channel/SBUBaseChannelViewModel.swift b/Sources/uikit/ViewModel/Channel/SBUBaseChannelViewModel.swift similarity index 95% rename from Sources/ViewModel/Channel/SBUBaseChannelViewModel.swift rename to Sources/uikit/ViewModel/Channel/SBUBaseChannelViewModel.swift index 3e96835..77b54f2 100644 --- a/Sources/ViewModel/Channel/SBUBaseChannelViewModel.swift +++ b/Sources/uikit/ViewModel/Channel/SBUBaseChannelViewModel.swift @@ -131,6 +131,9 @@ open class SBUBaseChannelViewModel: NSObject { weak var baseDataSource: SBUBaseChannelViewModelDataSource? weak var baseDelegate: SBUBaseChannelViewModelDelegate? + // MARK: SwiftUI (Internal) + var baseDelegates = WeakDelegateStorage() + let prevLock = NSLock() let nextLock = NSLock() let initialLock = NSLock() @@ -297,12 +300,15 @@ open class SBUBaseChannelViewModel: NSObject { } let context = MessageContext(source: .eventMessageSent, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: self.fullMessageList, - forContext: context, - keepsScroll: false - ) + self.baseDelegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: self.fullMessageList, + forContext: context, + keepsScroll: false + ) + } + } /// Sends a file message with file data, file name, mime type. @@ -457,12 +463,14 @@ open class SBUBaseChannelViewModel: NSObject { self.sortAllMessageList(needReload: true) let context = MessageContext(source: .eventMessageSent, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: self.fullMessageList, - forContext: context, - keepsScroll: false - ) + self.baseDelegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: self.fullMessageList, + forContext: context, + keepsScroll: false + ) + } } /// Updates a user message with message object. @@ -517,7 +525,9 @@ open class SBUBaseChannelViewModel: NSObject { ) { [weak self] _, _ in guard let self = self else { return } guard let channel = self.channel else { return } - self.baseDelegate?.baseChannelViewModel(self, shouldFinishEditModeForChannel: channel) + self.baseDelegates.forEach { + $0.baseChannelViewModel(self, shouldFinishEditModeForChannel: channel) + } } } @@ -683,7 +693,9 @@ open class SBUBaseChannelViewModel: NSObject { if needUpdateNewMessage { guard let channel = self.channel else { return } - self.baseDelegate?.baseChannelViewModel(self, didReceiveNewMessage: message, forChannel: channel) + self.baseDelegates.forEach { + $0.baseChannelViewModel(self, didReceiveNewMessage: message, forChannel: channel) + } } if message.sendingStatus == .succeeded { @@ -754,7 +766,9 @@ open class SBUBaseChannelViewModel: NSObject { if let editMessage = inEditingMessage, messageIds.contains(editMessage.messageId), let channel = self.channel { - self.baseDelegate?.baseChannelViewModel(self, shouldFinishEditModeForChannel: channel) + self.baseDelegates.forEach { + $0.baseChannelViewModel(self, shouldFinishEditModeForChannel: channel) + } } var toBeDeleteIndexes: [Int] = [] @@ -861,13 +875,15 @@ open class SBUBaseChannelViewModel: NSObject { + typingMessageArray } - self.baseDelegate?.shouldUpdateLoadingState(false) - self.baseDelegate?.baseChannelViewModel( - self, - didChangeMessageList: self.fullMessageList, - needsToReload: needReload, - initialLoad: self.isInitialLoading - ) + self.baseDelegates.forEach { + $0.shouldUpdateLoadingState(false) + $0.baseChannelViewModel( + self, + didChangeMessageList: self.fullMessageList, + needsToReload: needReload, + initialLoad: self.isInitialLoading + ) + } } /// This functions clears current message lists @@ -919,7 +935,9 @@ open class SBUBaseChannelViewModel: NSObject { // If currentUser reacts to an already reacted emoji, the request succeeds, but Chat SDK returns a decoding error (80000). // (the response doesn't contain "updated_at" field, but Chat SDK tries to decode this as a non-optional property) if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } SBULog.info("[Response] \(reactionEvent?.key ?? "") reaction") @@ -927,13 +945,17 @@ open class SBUBaseChannelViewModel: NSObject { if reactionEvent.messageId == message.messageId { message.apply(reactionEvent) } - self.baseDelegate?.baseChannelViewModel(self, didUpdateReaction: reactionEvent, forMessage: message) + self.baseDelegates.forEach { + $0.baseChannelViewModel(self, didUpdateReaction: reactionEvent, forMessage: message) + } } } else { SBULog.info("[Request] Delete Reaction") self.channel?.deleteReaction(with: message, key: emojiKey) { reactionEvent, error in if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } SBULog.info("[Response] \(reactionEvent?.key ?? "") reaction") @@ -941,7 +963,9 @@ open class SBUBaseChannelViewModel: NSObject { if reactionEvent.messageId == message.messageId { message.apply(reactionEvent) } - self.baseDelegate?.baseChannelViewModel(self, didUpdateReaction: reactionEvent, forMessage: message) + self.baseDelegates.forEach { + $0.baseChannelViewModel(self, didUpdateReaction: reactionEvent, forMessage: message) + } } } } diff --git a/Sources/ViewModel/Channel/SBUChatNotificationChannelViewModel.swift b/Sources/uikit/ViewModel/Channel/SBUChatNotificationChannelViewModel.swift similarity index 100% rename from Sources/ViewModel/Channel/SBUChatNotificationChannelViewModel.swift rename to Sources/uikit/ViewModel/Channel/SBUChatNotificationChannelViewModel.swift diff --git a/Sources/ViewModel/Channel/SBUFeedNotificationChannelViewModel.swift b/Sources/uikit/ViewModel/Channel/SBUFeedNotificationChannelViewModel.swift similarity index 100% rename from Sources/ViewModel/Channel/SBUFeedNotificationChannelViewModel.swift rename to Sources/uikit/ViewModel/Channel/SBUFeedNotificationChannelViewModel.swift diff --git a/Sources/ViewModel/Channel/SBUGroupChannelViewModel.swift b/Sources/uikit/ViewModel/Channel/SBUGroupChannelViewModel.swift similarity index 85% rename from Sources/ViewModel/Channel/SBUGroupChannelViewModel.swift rename to Sources/uikit/ViewModel/Channel/SBUGroupChannelViewModel.swift index abeafa7..be0eb93 100644 --- a/Sources/ViewModel/Channel/SBUGroupChannelViewModel.swift +++ b/Sources/uikit/ViewModel/Channel/SBUGroupChannelViewModel.swift @@ -63,6 +63,17 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { set { self.baseDataSource = newValue } } + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUGroupChannelViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // swiftlint:disable identifier_name /// A completion handler that is called after sending a multiple files message is completed. /// - Since: 3.10.0 @@ -104,13 +115,17 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { self.delegate = delegate self.dataSource = dataSource - self.displaysLocalCachedListFirst = displaysLocalCachedListFirst + self.baseDelegates.addDelegate(self.delegate, type: .uikit) SendbirdChat.addChannelDelegate( self, identifier: "\(SBUConstant.groupChannelDelegateIdentifier).\(self.description)" ) + self.debouncer = SBUDebouncer( + debounceTime: SBUGlobals.userMentionConfig?.debounceTime ?? SBUDebouncer.defaultTime + ) + if let channel = channel { self.channel = channel self.channelURL = channel.channelURL @@ -118,14 +133,25 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { self.channelURL = channelURL } - self.customizedMessageListParams = messageListParams - self.startingPoint = startingPoint - - self.debouncer = SBUDebouncer( - debounceTime: SBUGlobals.userMentionConfig?.debounceTime ?? SBUDebouncer.defaultTime + guard let channelURL = self.channelURL else { return } + self.initializeAndLoad( + channelURL: channelURL, + messageListParams: messageListParams, + startingPoint: startingPoint, + displaysLocalCachedListFirst: displaysLocalCachedListFirst ) + } + + func initializeAndLoad( + channelURL: String, + messageListParams: MessageListParams? = nil, + startingPoint: Int64? = nil, + displaysLocalCachedListFirst: Bool? = nil + ) { + if let messageListParams { self.customizedMessageListParams = messageListParams } + if let startingPoint { self.startingPoint = startingPoint } + if let displaysLocalCachedListFirst { self.displaysLocalCachedListFirst = displaysLocalCachedListFirst } - guard let channelURL = self.channelURL else { return } self.loadChannel( channelURL: channelURL, messageListParams: self.customizedMessageListParams @@ -153,11 +179,14 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { } // TODO: loading -// self.delegate?.shouldUpdateLoadingState(true) + let showIndicator = SBUGlobals.loadingIndicator.groupChannel.cachedMessages + self.delegate?.shouldUpdateLoadingState(showIndicator) SendbirdUI.connectIfNeeded { [weak self] _, error in if let error = error { - self?.delegate?.didReceiveError(error, isBlocker: true) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } completionHandler?(nil, error) return } @@ -184,11 +213,13 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { // for updating channel information when the connection state is closed at the time of initial load. if SendbirdChat.getConnectState() == .closed { let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } completionHandler?(channel, nil) } @@ -208,12 +239,16 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { guard let self = self else { return } guard self.canProceed(with: channel, error: error) == true else { let context = MessageContext(source: .eventChannelChanged, sendingStatus: .failed) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { + $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + } return } let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { + $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + } } } else if let channelURL = self.channelURL { self.loadChannel(channelURL: channelURL) @@ -225,14 +260,18 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { SBULog.error("[Failed] Load channel request: \(error.localizedDescription)") if error.code == ChatError.nonAuthorized.rawValue { - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: nil) + self.delegates.forEach { + $0.baseChannelViewModel(self, shouldDismissForChannel: nil) + } } else { if SendbirdChat.isLocalCachingEnabled && error.code == ChatError.networkError.rawValue && channel != nil { return true } else { - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } } } return false @@ -241,7 +280,9 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { guard let channel = channel, channel.myMemberState != .none else { - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: channel) + self.delegates.forEach { + $0.baseChannelViewModel(self, shouldDismissForChannel: channel) + } return false } @@ -307,12 +348,14 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { self.sortAllMessageList(needReload: true) let context = MessageContext(source: .eventMessageSent, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: self.fullMessageList, - forContext: context, - keepsScroll: false - ) + self.baseDelegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: self.fullMessageList, + forContext: context, + keepsScroll: false + ) + } } } @@ -322,11 +365,13 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { /// - index: the index of the cell of a multiple files message to update. /// - Since: 3.10.0 open func updateMultipleFilesMessageCell(requestId: String, index: Int) { - self.delegate?.groupChannelViewModel( - self, - didFinishUploadingFileAt: index, - multipleFilesMessageRequestId: requestId - ) + self.delegates.forEach { + $0.groupChannelViewModel( + self, + didFinishUploadingFileAt: index, + multipleFilesMessageRequestId: requestId + ) + } } // MARK: - Load Messages @@ -352,7 +397,9 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { setupCache() } - self.delegate?.shouldUpdateLoadingState(showIndicator) + self.delegates.forEach { + $0.shouldUpdateLoadingState(showIndicator) + } self.messageCollection?.startCollection( initPolicy: initPolicy, @@ -362,7 +409,9 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { defer { self.displaysLocalCachedListFirst = false } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } return } @@ -382,11 +431,15 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { self.loadInitialPendingMessages() if let error = error { - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } // ignore error if using local caching if !SendbirdChat.isLocalCachingEnabled { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } else { self.isInitialLoading = false self.upsertMessagesInList(messages: nil, needReload: true) @@ -439,19 +492,23 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } return } guard let messages = messages, !messages.isEmpty else { return } SBULog.info("[Prev message response] \(messages.count) messages") - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: messages, - forContext: nil, - keepsScroll: false - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: messages, + forContext: nil, + keepsScroll: false + ) + } self.upsertMessagesInList(messages: messages, needReload: true) } } @@ -474,19 +531,23 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } return } guard let messages = messages else { return } SBULog.info("[Next message Response] \(messages.count) messages") - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: messages, - forContext: nil, - keepsScroll: true - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: messages, + forContext: nil, + keepsScroll: true + ) + } self.upsertMessagesInList(messages: messages, needReload: true) } } @@ -590,15 +651,19 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { self.query?.loadNextPage { [weak self] members, _ in guard let self = self else { return } self.suggestedMemberList = SBUUser.convertUsers(members) - self.delegate?.groupChannelViewModel( - self, - didReceiveSuggestedMentions: self.suggestedMemberList - ) + self.delegates.forEach { + $0.groupChannelViewModel( + self, + didReceiveSuggestedMentions: self.suggestedMemberList + ) + } } } else { guard channel.members.count > 0 else { self.suggestedMemberList = nil - self.delegate?.groupChannelViewModel(self, didReceiveSuggestedMentions: nil) + self.delegates.forEach { + $0.groupChannelViewModel(self, didReceiveSuggestedMentions: nil) + } return } @@ -613,10 +678,12 @@ open class SBUGroupChannelViewModel: SBUBaseChannelViewModel { let resultMembers = Array(matchedMembers[0.. { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUOpenChannelViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // MARK: - Logic properties (Private) @SBUAtomic private var hasMorePrevious: Bool = true @@ -94,6 +105,8 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.delegate = delegate self.dataSource = dataSource + self.baseDelegates.addDelegate(self.delegate, type: .uikit) + SendbirdChat.addChannelDelegate( self, identifier: "\(SBUConstant.openChannelDelegateIdentifier).\(self.description)" @@ -106,10 +119,25 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.channelURL = channelURL } - self.customizedMessageListParams = messageListParams - self.startingPoint = startingPoint - guard let channelURL = self.channelURL else { return } + + self.initializeAndLoad( + channelURL: channelURL, + messageListParams: messageListParams, + startingPoint: startingPoint + ) + } + + func initializeAndLoad( + channelURL: String, + messageListParams: MessageListParams? = nil, + startingPoint: Int64? = nil + ) { + self.channelURL = channelURL + + if let messageListParams { self.customizedMessageListParams = messageListParams } + if let startingPoint { self.startingPoint = startingPoint } + self.loadChannel( channelURL: channelURL, messageListParams: self.customizedMessageListParams @@ -119,6 +147,7 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.setupSendFileMessageCompletionHandlers() } + deinit { SBULog.info("") @@ -145,7 +174,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { SendbirdUI.connectIfNeeded { _, error in if let error = error { - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } completionHandler?(nil, error) return } @@ -158,7 +189,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { } if let error = error { SBULog.error("[Failed] Load channel request: \(error.localizedDescription)") - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } completionHandler?(nil, error) return } @@ -170,7 +203,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { } if let error = error { SBULog.error("[Failed] Enter channel request: \(error.localizedDescription)") - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: nil) + self.delegates.forEach { + $0.baseChannelViewModel(self, shouldDismissForChannel: nil) + } completionHandler?(nil, error) return } @@ -201,15 +236,21 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { SBULog.error("[Failed] Load channel request: \(error.localizedDescription)") if error.code != CoreError.networkError.rawValue { - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: nil) + self.delegates.forEach { + $0.baseChannelViewModel(self, shouldDismissForChannel: nil) + } } else { - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } } } SBULog.info("[Succeed] Refresh channel request") let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { + $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + } self.loadMessageChangeLogs() } @@ -279,7 +320,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } return } @@ -293,12 +336,14 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.hasMorePrevious = messages.count >= params.previousResultSize - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: messages, - forContext: nil, - keepsScroll: false - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: messages, + forContext: nil, + keepsScroll: false + ) + } self.updateLastUpdatedTimestamp(messages: messages) @@ -351,12 +396,14 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { SBULog.info("[Next message Response] \(messages.count) messages") - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: mergedList ?? messages, - forContext: nil, - keepsScroll: true - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: mergedList ?? messages, + forContext: nil, + keepsScroll: true + ) + } self.upsertMessagesInList(messages: mergedList ?? messages, needReload: true) } } @@ -370,7 +417,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { SBULog.info("[Request] Both message list from : \(String(describing: timestamp))") guard self.initialLock.try() else { return } - self.delegate?.shouldUpdateLoadingState(showIndicator) + self.delegates.forEach { + $0.shouldUpdateLoadingState(showIndicator) + } let params = self.messageListParams.copy() as? MessageListParams ?? MessageListParams() params.isInclusive = true @@ -412,8 +461,10 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { defer { self.initialLock.unlock() } if let error = error { - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + $0.didReceiveError(error, isBlocker: false) + } return } @@ -440,7 +491,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { guard self.isValidResponse(messages: messages, error: error), let messages = messages else { SBULog.warning("Initial message list request is not valid") - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } return } @@ -487,7 +540,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.sortAllMessageList(needReload: true) - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } SBULog.error("[Failed] Resend failed user message request: \(error.localizedDescription)") return @@ -624,7 +679,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { """) self.nextLock.unlock() - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } return } @@ -672,12 +729,14 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { private func handleChangelogResponse(updatedMessages: [BaseMessage]?, deletedMessageIds: [Int64]?) { if let updatedMessages = updatedMessages, !updatedMessages.isEmpty { - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: updatedMessages, - forContext: nil, - keepsScroll: false - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: updatedMessages, + forContext: nil, + keepsScroll: false + ) + } self.upsertMessagesInList(messages: updatedMessages, needReload: true) } @@ -702,12 +761,14 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { mergedList = self.flushCache(with: addedMessages) } - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: mergedList ?? addedMessages, - forContext: nil, - keepsScroll: true - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: mergedList ?? addedMessages, + forContext: nil, + keepsScroll: true + ) + } self.upsertMessagesInList(messages: mergedList ?? addedMessages, needReload: true) SBULog.info("Loaded added messages : \(addedMessages.count), hasNext : \(String(describing: self.hasNext))") @@ -729,7 +790,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.sortAllMessageList(needReload: true) - self.baseDelegate?.didReceiveError(error) + self.baseDelegates.forEach { + $0.didReceiveError(error) + } SBULog.error("[Failed] Send user message request: \(error.localizedDescription)") return } @@ -761,7 +824,9 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { self.sortAllMessageList(needReload: true) - self.baseDelegate?.didReceiveError(error) + self.baseDelegates.forEach { + $0.didReceiveError(error) + } SBULog.error( """ [Failed] Send file message request: @@ -795,7 +860,7 @@ open class SBUOpenChannelViewModel: SBUBaseChannelViewModel { if let error = error { SBULog.error("[Failed] Message list request: \(error)") self.isLoadingNext = false - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: true) } return false } @@ -853,17 +918,17 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { guard message is UserMessage || message is FileMessage else { return } if let channel = self.channel { - self.delegate?.baseChannelViewModel(self, didReceiveNewMessage: message, forChannel: channel) + self.delegates.forEach { $0.baseChannelViewModel(self, didReceiveNewMessage: message, forChannel: channel) } } } if self.hasNext() == false { - self.delegate?.baseChannelViewModel( + self.delegates.forEach { $0.baseChannelViewModel( self, shouldUpdateScrollInMessageList: [message], forContext: nil, keepsScroll: !isScrollNearBottom - ) + ) } self.upsertMessagesInList(messages: [message], needReload: true) } @@ -891,7 +956,7 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { SBULog.info("Channel was changed, ChannelURL:\(channel.channelURL)") let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } open override func channelWasFrozen(_ channel: BaseChannel) { @@ -900,7 +965,7 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { SBULog.info("Channel was frozen, ChannelURL:\(channel.channelURL)") let context = MessageContext(source: .eventChannelFrozen, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } open override func channelWasUnfrozen(_ channel: BaseChannel) { @@ -909,7 +974,7 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { SBULog.info("Channel was unfrozen, ChannelURL:\(channel.channelURL)") let context = MessageContext(source: .eventChannelUnfrozen, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } open override func channel(_ channel: BaseChannel, userWasMuted user: RestrictedUser) { @@ -918,7 +983,7 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { if user.userId == SBUGlobals.currentUser?.userId { SBULog.info("You are muted.") let context = MessageContext(source: .eventUserMuted, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } } @@ -928,7 +993,7 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { if user.userId == SBUGlobals.currentUser?.userId { SBULog.info("You are unmuted.") let context = MessageContext(source: .eventUserUnmuted, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } } @@ -936,7 +1001,7 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { guard self.channel?.channelURL == channel.channelURL else { return } let context = MessageContext(source: .eventOperatorUpdated, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } open override func channel(_ channel: BaseChannel, userWasBanned user: RestrictedUser) { @@ -944,10 +1009,10 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { if user.userId == SBUGlobals.currentUser?.userId { SBULog.info("You are banned.") - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: channel) + self.delegates.forEach { $0.baseChannelViewModel(self, shouldDismissForChannel: channel) } } else { let context = MessageContext(source: .eventUserBanned, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } } } @@ -955,22 +1020,22 @@ extension SBUOpenChannelViewModel: OpenChannelDelegate { guard self.channel?.channelURL == channel.channelURL else { return } let context = MessageContext(source: .eventChannelMemberCountChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) - self.delegate?.openChannelViewModel(self, userDidEnter: user, forChannel: channel) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } + self.delegates.forEach { $0.openChannelViewModel(self, userDidEnter: user, forChannel: channel) } } open func channel(_ channel: OpenChannel, userDidExit user: User) { guard self.channel?.channelURL == channel.channelURL else { return } let context = MessageContext(source: .eventChannelMemberCountChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) - self.delegate?.openChannelViewModel(self, userDidExit: user, forChannel: channel) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) } + self.delegates.forEach { $0.openChannelViewModel(self, userDidExit: user, forChannel: channel) } } open override func channelWasDeleted(_ channelURL: String, channelType: ChannelType) { guard self.channel?.channelURL == channelURL else { return } let context = MessageContext(source: .eventChannelDeleted, sendingStatus: .succeeded) - self.delegate?.baseChannelViewModel(self, didChangeChannel: nil, withContext: context) + self.delegates.forEach { $0.baseChannelViewModel(self, didChangeChannel: nil, withContext: context) } } } diff --git a/Sources/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift b/Sources/uikit/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift similarity index 82% rename from Sources/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift rename to Sources/uikit/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift index 5bf1822..2c36239 100644 --- a/Sources/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelList/SBUBaseChannelListViewModel.swift @@ -15,6 +15,10 @@ open class SBUBaseChannelListViewModel: NSObject { // MARK: - Property (private) weak var baseDelegate: SBUBaseChannelListViewModelDelegate? + + // MARK: SwiftUI (Internal) + var baseDelegates = WeakDelegateStorage() + var isLoading = false // MARK: - Life Cycle @@ -27,6 +31,7 @@ open class SBUBaseChannelListViewModel: NSObject { delegate: SBUBaseChannelListViewModelDelegate? ) { self.baseDelegate = delegate + self.baseDelegates.addDelegate(delegate, type: .uikit) super.init() @@ -50,11 +55,15 @@ open class SBUBaseChannelListViewModel: NSObject { SBULog.info("[Request] Next channel List") SendbirdUI.connectIfNeeded { [weak self] _, error in if let error = error { - self?.baseDelegate?.didReceiveError(error, isBlocker: true) + self?.baseDelegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } return } - self?.baseDelegate?.connectionStateDidChange(true) + self?.baseDelegates.forEach { + $0.connectionStateDidChange(true) + } self?.loadNextChannelList(reset: true) } @@ -80,7 +89,7 @@ open class SBUBaseChannelListViewModel: NSObject { private func setLoading(_ loadingState: Bool, _ showIndicator: Bool) { self.isLoading = loadingState - self.baseDelegate?.shouldUpdateLoadingState(showIndicator) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(showIndicator) } } } @@ -95,6 +104,8 @@ extension SBUBaseChannelListViewModel: ConnectionDelegate { } } - self.baseDelegate?.connectionStateDidChange(true) + self.baseDelegates.forEach { + $0.connectionStateDidChange(true) + } } } diff --git a/Sources/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift b/Sources/uikit/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift similarity index 77% rename from Sources/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift rename to Sources/uikit/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift index b8e46b7..1db0f83 100644 --- a/Sources/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelList/SBUGroupChannelListViewModel.swift @@ -60,6 +60,18 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { get { self.baseDelegate as? SBUGroupChannelListViewModelDelegate } set { self.baseDelegate = newValue } } + + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUGroupChannelListViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + private var customizedChannelListQuery: GroupChannelListQuery? // MARK: - Life Cycle @@ -73,9 +85,13 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { channelListQuery: GroupChannelListQuery? = nil ) { super.init(delegate: delegate) - - self.customizedChannelListQuery = channelListQuery + self.baseDelegates.addDelegate(delegate, type: .uikit) + self.initializeAndLoad(channelListQuery: channelListQuery) + } + + func initializeAndLoad(channelListQuery: GroupChannelListQuery? = nil) { + if let channelListQuery { self.customizedChannelListQuery = channelListQuery } self.initChannelList() } @@ -135,7 +151,8 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { return } - self.setLoading(true, false) + let showIndicator = SBUGlobals.loadingIndicator.groupChannelList.cachedChannels + self.setLoading(true, showIndicator) self.channelCollection?.loadMore { [weak self] channels, error in guard let self = self else { return } @@ -143,18 +160,22 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { if let error = error { DispatchQueue.main.async { [weak self] in - self?.delegate?.didReceiveError(error, isBlocker: true) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } } return } SBULog.info("[Response] \(channels?.count ?? 0) channels") - self.delegate?.groupChannelListViewModel( - self, - didChangeChannelList: self.channelList, - needsToReload: true - ) + self.delegates.forEach { + $0.groupChannelListViewModel( + self, + didChangeChannelList: self.channelList, + needsToReload: true + ) + } } } @@ -184,7 +205,9 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { if let error = error { DispatchQueue.main.async { [weak self] in - self?.delegate?.didReceiveError(error, isBlocker: false) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } return } @@ -192,7 +215,9 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { // Final handling in `GroupChannelCollectionDelegate` SBULog.info("[Succeed] Leave channel request, ChannelURL: \(channel.channelURL)") - self.delegate?.groupChannelListViewModel(self, didLeaveChannel: channel) + self.delegates.forEach { + $0.groupChannelListViewModel(self, didLeaveChannel: channel) + } } } @@ -215,7 +240,9 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { if let error = error { DispatchQueue.main.async { [weak self] in - self?.delegate?.didReceiveError(error, isBlocker: false) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } return } @@ -223,7 +250,9 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { // Final handling in `GroupChannelCollectionDelegate` SBULog.info("[Succeed] Channel push status, ChannelURL: \(channel.channelURL)") - self.delegate?.groupChannelListViewModel(self, didUpdateChannel: channel) + self.delegates.forEach { + $0.groupChannelListViewModel(self, didUpdateChannel: channel) + } } } @@ -235,8 +264,9 @@ open class SBUGroupChannelListViewModel: SBUBaseChannelListViewModel { /// - showIndicator: If true, the loading indicator is started, and if false, the indicator is stopped. private func setLoading(_ loadingState: Bool, _ showIndicator: Bool) { self.isLoading = loadingState - - self.delegate?.shouldUpdateLoadingState(showIndicator) + self.delegates.forEach { + $0.shouldUpdateLoadingState(loadingState) + } } } @@ -251,11 +281,13 @@ extension SBUGroupChannelListViewModel: GroupChannelCollectionDelegate { delete size : \(deletedChannelURLs.count) """) - self.delegate?.groupChannelListViewModel( - self, - didChangeChannelList: self.channelList, - needsToReload: true - ) + self.delegates.forEach { + $0.groupChannelListViewModel( + self, + didChangeChannelList: self.channelList, + needsToReload: true + ) + } } open func channelCollection(_ collection: GroupChannelCollection, @@ -266,11 +298,13 @@ extension SBUGroupChannelListViewModel: GroupChannelCollectionDelegate { fromEvent: \(context.fromEvent), channel size : \(channels.count) """) - self.delegate?.groupChannelListViewModel( - self, - didChangeChannelList: self.channelList, - needsToReload: true - ) + self.delegates.forEach { + $0.groupChannelListViewModel( + self, + didChangeChannelList: self.channelList, + needsToReload: true + ) + } } open func channelCollection(_ collection: GroupChannelCollection, @@ -281,11 +315,27 @@ extension SBUGroupChannelListViewModel: GroupChannelCollectionDelegate { fromEvent: \(context.fromEvent), channel size : \(channels.count) """) - self.delegate?.groupChannelListViewModel( - self, - didChangeChannelList: self.channelList, - needsToReload: true - ) + + // Propagate updated `channelList`. + self.delegates.forEach { + $0.groupChannelListViewModel( + self, + didChangeChannelList: self.channelList, + needsToReload: true + )} + +// self.delegate?.groupChannelListViewModel( +// self, +// didChangeChannelList: self.channelList, +// needsToReload: true +// ) + +// +// self.swiftUIDelegate?.groupChannelListViewModel( +// self, +// didChangeChannelList: self.channelList, +// needsToReload: true +// ) } } diff --git a/Sources/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift b/Sources/uikit/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift similarity index 86% rename from Sources/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift rename to Sources/uikit/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift index 4bca69f..2b9f447 100644 --- a/Sources/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelList/SBUOpenChannelListViewModel.swift @@ -50,6 +50,17 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { } private var customizedChannelListQuery: OpenChannelListQuery? + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUOpenChannelListViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // MARK: - Life Cycle /// This function initializes the ViewModel. @@ -61,7 +72,8 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { channelListQuery: OpenChannelListQuery? ) { super.init(delegate: delegate) - + self.baseDelegates.addDelegate(delegate, type: .uikit) + self.customizedChannelListQuery = channelListQuery SendbirdChat.addChannelDelegate( @@ -72,6 +84,11 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { self.initChannelList() } + func initializeAndLoad(channelListQuery: OpenChannelListQuery?) { + if let channelListQuery { self.customizedChannelListQuery = channelListQuery } + self.initChannelList() + } + deinit { self.reset() @@ -119,7 +136,9 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { if let error = error { DispatchQueue.main.async { [weak self] in - self?.delegate?.didReceiveError(error, isBlocker: true) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } } return } @@ -205,11 +224,13 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { self.channelList = sortedChannelList.sbu_unique() - self.delegate?.openChannelListViewModel( - self, - didChangeChannelList: self.channelList, - needsToReload: needReload - ) + self.delegates.forEach { + $0.openChannelListViewModel( + self, + didChangeChannelList: self.channelList, + needsToReload: needReload + ) + } } /// This function resets channelList @@ -218,6 +239,18 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { self.channelList = [] self.channelListQuery = nil + + // Celine TODO: do we need reset() at all? + #if SWIFTUI + // Celine TODO: need to call this method only for swiftUIDelegate. + self.delegates.forEach { + $0.openChannelListViewModel( + self, + didChangeChannelList: self.channelList, + needsToReload: false + ) + } + #endif } // MARK: - Common @@ -229,7 +262,9 @@ open class SBUOpenChannelListViewModel: SBUBaseChannelListViewModel { private func setLoading(_ loadingState: Bool, _ showIndicator: Bool) { self.isLoading = loadingState - self.delegate?.shouldUpdateLoadingState(showIndicator) + self.delegates.forEach { + $0.shouldUpdateLoadingState(isLoading) + } } } diff --git a/Sources/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift b/Sources/uikit/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift similarity index 81% rename from Sources/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift rename to Sources/uikit/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift index 1e9b0af..f165c15 100644 --- a/Sources/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelSettings/SBUBaseChannelSettingsViewModel.swift @@ -45,6 +45,7 @@ open class SBUBaseChannelSettingsViewModel: NSObject { // MARK: - Logic properties (Private) weak var baseDelegate: SBUBaseChannelSettingsViewModelDelegate? + var baseDelegates = WeakDelegateStorage() // MARK: - LifeCycle public override init() { @@ -66,30 +67,30 @@ open class SBUBaseChannelSettingsViewModel: NSObject { /// - channelURL: channel url /// - type: channel type public func loadChannel(channelURL: String, type: ChannelType) { - self.baseDelegate?.shouldUpdateLoadingState(true) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(true) } SendbirdUI.connectIfNeeded { [weak self] _, error in guard let self = self else { return } - defer { self.baseDelegate?.shouldUpdateLoadingState(false) } + defer { self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else { let completionHandler: ((BaseChannel?, SBError?) -> Void) = { [weak self] channel, error in guard let self = self else { return } if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else if let channel = channel { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelSettingsViewModel( + self.baseDelegates.forEach { $0.baseChannelSettingsViewModel( self, didChangeChannel: channel, withContext: context - ) + ) } } } @@ -118,22 +119,22 @@ extension SBUBaseChannelSettingsViewModel: BaseChannelDelegate { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelSettingsViewModel( + self.baseDelegates.forEach { $0.baseChannelSettingsViewModel( self, didChangeChannel: channel, withContext: context - ) + ) } } open func channelDidUpdateOperators(_ channel: BaseChannel) { if let channel = self.channel as? GroupChannel { if channel.myRole != .operator { - self.baseDelegate?.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: channel) + self.baseDelegates.forEach { $0.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: channel) } return } } else if let channel = self.channel as? OpenChannel { let userId = SBUGlobals.currentUser?.userId ?? "" if !channel.isOperator(userId: userId) { - self.baseDelegate?.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: channel) + self.baseDelegates.forEach { $0.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: channel) } return } } @@ -143,10 +144,10 @@ extension SBUBaseChannelSettingsViewModel: BaseChannelDelegate { guard let userId = SBUGlobals.currentUser?.userId, user.userId == userId else { return } - self.baseDelegate?.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: nil) + self.baseDelegates.forEach { $0.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: nil) } } public func channelWasDeleted(_ channelURL: String, channelType: ChannelType) { - self.baseDelegate?.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: nil) + self.baseDelegates.forEach { $0.baseChannelSettingsViewModel(self, shouldDismissForChannelSettings: nil) } } } diff --git a/Sources/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift b/Sources/uikit/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift similarity index 70% rename from Sources/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift rename to Sources/uikit/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift index a80cfb8..6589648 100644 --- a/Sources/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelSettings/SBUGroupChannelSettingsViewModel.swift @@ -33,6 +33,17 @@ open class SBUGroupChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { set { self.baseDelegate = newValue } } + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUGroupChannelSettingsViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // MARK: - LifeCycle /// Initializes a new instance of the `SBUGroupChannelSettingsViewModel` class. /// @@ -48,6 +59,7 @@ open class SBUGroupChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { super.init() self.delegate = delegate + self.baseDelegates.addDelegate(delegate, type: .uikit) SendbirdChat.addChannelDelegate( self, @@ -61,9 +73,16 @@ open class SBUGroupChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { self.channelURL = channelURL } - self.loadChannel(channelURL: self.channelURL) + guard let channelURL = self.channelURL else { return } + self.initializeAndLoad(channelURL: channelURL) } + func initializeAndLoad(channelURL: String) { + self.channelURL = channelURL + self.loadChannel(channelURL: channelURL) + } + + deinit { SendbirdChat.removeChannelDelegate( forIdentifier: "\(SBUConstant.groupChannelDelegateIdentifier).\(self.description)" @@ -101,24 +120,30 @@ open class SBUGroupChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { guard let groupChannel = self.channel as? GroupChannel else { return } SBULog.info("[Request] Channel update") - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } groupChannel.update(params: params) { [weak self] channel, error in - defer { self?.delegate?.shouldUpdateLoadingState(false) } + defer { self?.delegates.forEach { $0.shouldUpdateLoadingState(false) } } guard let self = self else { return } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } return } else if let channel = channel { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.delegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } } } @@ -127,24 +152,32 @@ open class SBUGroupChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { public func leaveChannel() { guard let groupChannel = self.channel as? GroupChannel else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } groupChannel.leave { [weak self] error in guard let self = self else { return } - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { + $0.didReceiveError(error) + } return } self.channel = nil - self.delegate?.groupChannelSettingsViewModel( - self, - didLeaveChannel: groupChannel - ) + self.delegates.forEach { + $0.groupChannelSettingsViewModel( + self, + didLeaveChannel: groupChannel + ) + } } } } @@ -153,19 +186,23 @@ open class SBUGroupChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { extension SBUGroupChannelSettingsViewModel: GroupChannelDelegate { open func channel(_ channel: GroupChannel, userDidJoin user: User) { let context = MessageContext(source: .eventUserJoined, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.baseDelegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } open func channel(_ channel: GroupChannel, userDidLeave user: User) { let context = MessageContext(source: .eventUserLeft, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.baseDelegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } } diff --git a/Sources/ViewModel/ChannelSettings/SBUModerationsViewModel.swift b/Sources/uikit/ViewModel/ChannelSettings/SBUModerationsViewModel.swift similarity index 79% rename from Sources/ViewModel/ChannelSettings/SBUModerationsViewModel.swift rename to Sources/uikit/ViewModel/ChannelSettings/SBUModerationsViewModel.swift index 9297955..39064c8 100644 --- a/Sources/ViewModel/ChannelSettings/SBUModerationsViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelSettings/SBUModerationsViewModel.swift @@ -34,6 +34,9 @@ open class SBUModerationsViewModel { // MARK: - Property (Private) weak var delegate: SBUModerationsViewModelDelegate? + // MARK: SwiftUI (Internal) + var delegates = WeakDelegateStorage() + // MARK: - Lifecycle /// Initializes a new `SBUModerationsViewModel` instance. /// @@ -44,12 +47,18 @@ open class SBUModerationsViewModel { /// - delegate: An optional `SBUModerationsViewModelDelegate` to handle events. Default is `nil`. required public init(channel: BaseChannel, delegate: SBUModerationsViewModelDelegate? = nil) { self.delegate = delegate + self.delegates.addDelegate(delegate, type: .uikit) self.channelType = (channel is GroupChannel) ? .group : .open self.channel = channel self.channelURL = channel.channelURL guard let channelURL = self.channelURL else { return } + self.initializeAndLoad(channelURL: channelURL) + } + + func initializeAndLoad(channelURL: String) { + self.channelURL = channelURL self.loadChannel(channelURL: channelURL) } @@ -65,6 +74,7 @@ open class SBUModerationsViewModel { delegate: SBUModerationsViewModelDelegate? = nil ) { self.delegate = delegate + self.delegates.addDelegate(delegate, type: .uikit) self.channelType = channelType self.channelURL = channelURL @@ -78,14 +88,14 @@ open class SBUModerationsViewModel { /// - Parameters: /// - channelURL: channel url public func loadChannel(channelURL: String) { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SendbirdUI.connectIfNeeded { [weak self] _, error in guard let self = self else { return } if let error = error { - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else { if self.channelType == .group { self.loadGroupChannel(channelURL: channelURL) @@ -100,19 +110,19 @@ open class SBUModerationsViewModel { let completionHandler: ((GroupChannel?, SBError?) -> Void) = { [weak self] channel, error in guard let self = self else { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else if let channel = channel { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.moderationsViewModel( + self.delegates.forEach { $0.moderationsViewModel( self, didChangeChannel: channel, withContext: context - ) + ) } } } @@ -123,19 +133,19 @@ open class SBUModerationsViewModel { let completionHandler: ((OpenChannel?, SBError?) -> Void) = { [weak self] channel, error in guard let self = self else { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else if let channel = channel { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.moderationsViewModel( + self.delegates.forEach { $0.moderationsViewModel( self, didChangeChannel: channel, withContext: context - ) + ) } } } @@ -148,7 +158,7 @@ open class SBUModerationsViewModel { public func freezeChannel(_ completionHandler: ((Bool) -> Void)? = nil) { guard let groupChannel = self.channel as? GroupChannel else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } groupChannel.freeze { [weak self] error in guard let self = self else { @@ -156,20 +166,20 @@ open class SBUModerationsViewModel { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } if let channel = self.channel { let context = MessageContext(source: .eventChannelFrozen, sendingStatus: .succeeded) - self.delegate?.moderationsViewModel( + self.delegates.forEach { $0.moderationsViewModel( self, didChangeChannel: channel, withContext: context - ) + ) } } completionHandler?(true) } @@ -180,7 +190,7 @@ open class SBUModerationsViewModel { public func unfreezeChannel(_ completionHandler: ((Bool) -> Void)? = nil) { guard let groupChannel = self.channel as? GroupChannel else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } groupChannel.unfreeze { [weak self] error in guard let self = self else { @@ -188,20 +198,20 @@ open class SBUModerationsViewModel { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } if let channel = self.channel { let context = MessageContext(source: .eventChannelUnfrozen, sendingStatus: .succeeded) - self.delegate?.moderationsViewModel( + self.delegates.forEach { $0.moderationsViewModel( self, didChangeChannel: channel, withContext: context - ) + ) } } completionHandler?(true) } diff --git a/Sources/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift b/Sources/uikit/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift similarity index 65% rename from Sources/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift rename to Sources/uikit/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift index 0bcb40a..dc60858 100644 --- a/Sources/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift +++ b/Sources/uikit/ViewModel/ChannelSettings/SBUOpenChannelSettingsViewModel.swift @@ -25,6 +25,17 @@ open class SBUOpenChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { set { self.baseDelegate = newValue } } + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUOpenChannelSettingsViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // MARK: - LifeCycle required public init( channel: BaseChannel? = nil, @@ -34,6 +45,7 @@ open class SBUOpenChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { super.init() self.delegate = delegate + self.baseDelegates.addDelegate(delegate, type: .uikit) SendbirdChat.addChannelDelegate( self, @@ -47,7 +59,13 @@ open class SBUOpenChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { self.channelURL = channelURL } - self.loadChannel(channelURL: self.channelURL) + guard let channelURL = self.channelURL else { return } + self.initializeAndLoad(channelURL: channelURL) + } + + func initializeAndLoad(channelURL: String) { + self.channelURL = channelURL + self.loadChannel(channelURL: channelURL) } deinit { @@ -87,24 +105,30 @@ open class SBUOpenChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { guard let openChannel = self.channel as? OpenChannel else { return } SBULog.info("[Request] Channel update") - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } openChannel.update(params: params) { [weak self] channel, error in - defer { self?.delegate?.shouldUpdateLoadingState(false) } + defer { self?.delegates.forEach { $0.shouldUpdateLoadingState(false) } } guard let self = self else { return } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } return } else if let channel = channel { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.delegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } } } @@ -113,21 +137,29 @@ open class SBUOpenChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { public func deleteChannel() { guard let openChannel = self.channel as? OpenChannel else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } openChannel.delete { [weak self] error in guard let self = self else { return } - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { + $0.didReceiveError(error) + } return } self.channel = nil - self.delegate?.openChannelSettingsViewModel(self, didDeleteChannel: openChannel) + self.delegates.forEach { + $0.openChannelSettingsViewModel(self, didDeleteChannel: openChannel) + } } } } @@ -136,19 +168,23 @@ open class SBUOpenChannelSettingsViewModel: SBUBaseChannelSettingsViewModel { extension SBUOpenChannelSettingsViewModel: OpenChannelDelegate { open func channel(_ channel: OpenChannel, userDidEnter user: User) { let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.baseDelegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } open func channel(_ channel: OpenChannel, userDidExit user: User) { let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.baseDelegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } } diff --git a/Sources/ViewModel/Common/SBUCommonDelegate.swift b/Sources/uikit/ViewModel/Common/SBUCommonDelegate.swift similarity index 100% rename from Sources/ViewModel/Common/SBUCommonDelegate.swift rename to Sources/uikit/ViewModel/Common/SBUCommonDelegate.swift diff --git a/Sources/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift b/Sources/uikit/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift similarity index 78% rename from Sources/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift rename to Sources/uikit/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift index 21d4b82..2499e7e 100644 --- a/Sources/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift +++ b/Sources/uikit/ViewModel/MessageSearch/SBUMessageSearchViewModel.swift @@ -28,7 +28,7 @@ open class SBUMessageSearchViewModel { // MARK: - Property (Public) /// The channel that the search will be performed on. public private(set) var channel: BaseChannel? - /// The URL of the current channel. // 3.26.0 + /// The URL of the current channel. // 3.28.0 public private(set) var channelURL: String? /// The list of search results. @@ -47,6 +47,9 @@ open class SBUMessageSearchViewModel { var keyword: String? + // MARK: SwiftUI (Internal) + var delegates = WeakDelegateStorage() + // MARK: - Lifecycle /// Initializes a new `SBUMessageSearchViewModel` instance. /// @@ -60,8 +63,11 @@ open class SBUMessageSearchViewModel { delegate: SBUMessageSearchViewModelDelegate? = nil ) { self.delegate = delegate - self.customMessageSearchQueryParams = params - self.channel = channel + self.delegates.addDelegate(delegate, type: .uikit) + + self.channelURL = channel.channelURL + + self.initializeAndLoad(channelURL: channel.channelURL, params: params) } /// Initializes a new `SBUMessageSearchViewModel` instance. @@ -70,15 +76,26 @@ open class SBUMessageSearchViewModel { /// - channelURL: The URL of the channel. /// - params: The `MessageSearchQueryParams` object that will be used for the search. Default is `nil`. /// - delegate: The `SBUMessageSearchViewModelDelegate` object that will handle delegate methods. Default is `nil`. - /// - Since: 3.26.0 + /// - Since: 3.28.0 required public init( channelURL: String, params: MessageSearchQueryParams? = nil, delegate: SBUMessageSearchViewModelDelegate? = nil ) { self.delegate = delegate - self.customMessageSearchQueryParams = params + self.delegates.addDelegate(delegate, type: .uikit) + + self.channelURL = channelURL + + self.initializeAndLoad(channelURL: channelURL, params: params) + } + + func initializeAndLoad( + channelURL: String, + params: MessageSearchQueryParams? = nil + ) { self.channelURL = channelURL + if let params { self.customMessageSearchQueryParams = params } self.loadChannel(channelURL: channelURL) } @@ -87,22 +104,28 @@ open class SBUMessageSearchViewModel { /// - Parameters: /// - channelURL: channel url /// - type: channel type - /// - Since: 3.26.0 + /// - Since: 3.28.0 public func loadChannel(channelURL: String) { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } SendbirdUI.connectIfNeeded { [weak self] _, error in guard let self = self else { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } else { let completionHandler: ((BaseChannel?, SBError?) -> Void) = { [weak self] channel, error in guard let self = self else { return } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } } else if let channel = channel { self.channel = channel } @@ -121,7 +144,9 @@ open class SBUMessageSearchViewModel { open func search(keyword: String) { guard let channel = self.channel else { let error = SBError(domain: "Requires a channel object for message search", code: -1, userInfo: nil) - self.delegate?.didReceiveError(error) + self.delegates.forEach { + $0.didReceiveError(error) + } return } @@ -182,7 +207,9 @@ open class SBUMessageSearchViewModel { self.keyword = trimmedKeyword self.messageSearchQuery = query - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } self.loadMore() } @@ -193,7 +220,9 @@ open class SBUMessageSearchViewModel { messageSearchQuery.hasNext && !messageSearchQuery.isLoading else { - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } return } @@ -201,10 +230,14 @@ open class SBUMessageSearchViewModel { messageSearchQuery.loadNextPage { [weak self] messageList, error in guard let self = self else { return } - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } } else { guard let messageList = messageList else { return } @@ -213,11 +246,13 @@ open class SBUMessageSearchViewModel { } self.searchResultList.append(contentsOf: filteredList) - self.delegate?.searchViewModel( - self, - didChangeSearchResults: self.searchResultList, - needsToReload: true - ) + self.delegates.forEach { + $0.searchViewModel( + self, + didChangeSearchResults: self.searchResultList, + needsToReload: true + ) + } } } } diff --git a/Sources/ViewModel/MessageThread/SBUMessageThreadViewModel.swift b/Sources/uikit/ViewModel/MessageThread/SBUMessageThreadViewModel.swift similarity index 84% rename from Sources/ViewModel/MessageThread/SBUMessageThreadViewModel.swift rename to Sources/uikit/ViewModel/MessageThread/SBUMessageThreadViewModel.swift index 9292079..7830499 100644 --- a/Sources/ViewModel/MessageThread/SBUMessageThreadViewModel.swift +++ b/Sources/uikit/ViewModel/MessageThread/SBUMessageThreadViewModel.swift @@ -72,6 +72,17 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { set { self.baseDataSource = newValue } } + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUMessageThreadViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + public internal(set) var customizedThreadedMessageListParams: ThreadedMessageListParams? public internal(set) var threadedMessageListParams = ThreadedMessageListParams() @@ -118,6 +129,7 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { super.init() self.delegate = delegate + self.baseDelegates.addDelegate(self.delegate, type: .uikit) self.dataSource = dataSource self.isTransformedList = false self.isThreadMessageMode = true @@ -129,6 +141,10 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { identifier: "\(SBUConstant.groupChannelDelegateIdentifier).\(self.description)" ) + self.debouncer = SBUDebouncer( + debounceTime: SBUGlobals.userMentionConfig?.debounceTime ?? SBUDebouncer.defaultTime + ) + if let channel = channel { self.channel = channel self.channelURL = channel.channelURL @@ -143,12 +159,28 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.parentMessageId = parentMessageId } - self.customizedThreadedMessageListParams = threadedMessageListParams - self.startingPoint = startingPoint + guard let channelURL = self.channelURL, + let parentMessageId = self.parentMessageId else { return } - self.debouncer = SBUDebouncer( - debounceTime: SBUGlobals.userMentionConfig?.debounceTime ?? SBUDebouncer.defaultTime + self.initializeAndLoad( + channelURL: channelURL, + parentMessageId: parentMessageId, + threadedMessageListParams: threadedMessageListParams, + startingPoint: startingPoint ) + } + + func initializeAndLoad( + channelURL: String, + parentMessageId: Int64, + threadedMessageListParams: ThreadedMessageListParams? = nil, + startingPoint: Int64? = nil + ) { + self.channelURL = channelURL + self.parentMessageId = parentMessageId + + if let threadedMessageListParams { self.customizedThreadedMessageListParams = threadedMessageListParams } + if let startingPoint { self.startingPoint = startingPoint } self.loadChannelAndMessages(channelURL: channelURL) @@ -181,7 +213,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { // 1. Connect SendbirdUI.connectIfNeeded { [weak self] _, error in if let error = error { - self?.delegate?.didReceiveError(error, isBlocker: true) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } return } @@ -192,7 +226,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { guard error == nil, let parentMessageId = self?.parentMessageId, let channel = channel else { - self?.delegate?.didReceiveError(error, isBlocker: true) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } return } @@ -205,16 +241,20 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { isInitilize: true, completionHandler: { parentMessage, error in guard error == nil, let parentMessage = parentMessage else { - self?.delegate?.didReceiveError(error, isBlocker: true) + self?.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } return } self?.parentMessage = parentMessage if let self = self { - self.delegate?.messageThreadViewModel( - self, - didLoadParentMessage: parentMessage - ) + self.delegates.forEach { + $0.messageThreadViewModel( + self, + didLoadParentMessage: parentMessage + ) + } } // 4. loadThreadedMessage @@ -267,11 +307,13 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { source: .eventChannelChanged, sendingStatus: .succeeded ) - self.delegate?.baseChannelViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } completionHandler?(channel, nil) } @@ -285,7 +327,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { guard let self = self else { return } guard self.canProceed(with: channel, error: error) == true else { let context = MessageContext(source: .eventChannelChanged, sendingStatus: .failed) - self.delegate?.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { + $0.baseChannelViewModel(self, didChangeChannel: channel, withContext: context) + } return } @@ -293,11 +337,13 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { source: .eventChannelChanged, sendingStatus: .succeeded ) - self.delegate?.baseChannelViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } } } else if let channelURL = self.channelURL { self.loadChannel(channelURL: channelURL) @@ -309,11 +355,15 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { SBULog.error("[Failed] Load channel request: \(error.localizedDescription)") if error.code == ChatError.nonAuthorized.rawValue { - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: nil) + self.delegates.forEach { + $0.baseChannelViewModel(self, shouldDismissForChannel: nil) + } } else { // Currently thread messages do not support local caching. // if SendbirdChat.isLocalCachingEnabled { return true } - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } } return false } @@ -321,7 +371,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { guard let channel = channel, channel.myMemberState != .none else { - self.delegate?.baseChannelViewModel(self, shouldDismissForChannel: channel) + self.delegates.forEach { + $0.baseChannelViewModel(self, shouldDismissForChannel: channel) + } return false } @@ -376,7 +428,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { return } self.parentMessage = parentMessage - self.delegate?.messageThreadViewModel(self, didUpdateParentMessage: self.parentMessage) + self.delegates.forEach { + $0.messageThreadViewModel(self, didUpdateParentMessage: self.parentMessage) + } } } @@ -439,7 +493,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } self.isLoadingPrev = false return } @@ -455,12 +511,14 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.hasMorePrevious = messages.count >= params.previousResultSize - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: messages, - forContext: nil, - keepsScroll: false - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: messages, + forContext: nil, + keepsScroll: false + ) + } self.updateLastUpdatedTimestamp(messages: messages) @@ -509,12 +567,14 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.hasMoreNext = messages.count >= params.nextResultSize - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: messages, - forContext: nil, - keepsScroll: true - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: messages, + forContext: nil, + keepsScroll: true + ) + } self.updateLastUpdatedTimestamp(messages: messages) self.upsertMessagesInList(messages: messages, needReload: true) @@ -530,7 +590,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { public func loadBothMessages(timestamp: Int64?, showIndicator: Bool) { SBULog.info("[Request] Both message list from : \(String(describing: timestamp))") guard self.initialLock.try() else { return } - self.delegate?.shouldUpdateLoadingState(showIndicator) + self.delegates.forEach { + $0.shouldUpdateLoadingState(showIndicator) + } let params = (self.threadedMessageListParams.copy() as? ThreadedMessageListParams) ?? ThreadedMessageListParams() params.isInclusive = true @@ -577,8 +639,10 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { defer { self.initialLock.unlock() } if let error = error { - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + $0.didReceiveError(error, isBlocker: false) + } return } @@ -606,7 +670,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { guard self.isValidResponse(messages: messages, error: error), let messages = messages else { SBULog.warning("Initial message list request is not valid") - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } return } @@ -710,23 +776,27 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.sortAllMessageList(needReload: true) let context = MessageContext(source: .eventMessageSent, sendingStatus: .succeeded) - self.baseDelegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: self.fullMessageList, - forContext: context, - keepsScroll: false - ) + self.baseDelegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: self.fullMessageList, + forContext: context, + keepsScroll: false + ) + } } } /// - Note: This interface is beta. We do not gaurantee this interface to work properly yet. /// - Since: [NEXT_VERSION_MFM_THREAD] public func updateMultipleFilesMessageCell(requestId: String, index: Int) { - self.delegate?.messageThreadViewModel( - self, - didFinishUploadingFileAt: index, - multipleFilesMessageRequestId: requestId - ) + self.delegates.forEach { + $0.messageThreadViewModel( + self, + didFinishUploadingFileAt: index, + multipleFilesMessageRequestId: requestId + ) + } } /// Sets up completion handlers of send user message. @@ -735,7 +805,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { guard let self = self else { return } if let error = error { - self.baseDelegate?.didReceiveError(error) + self.baseDelegates.forEach { + $0.didReceiveError(error) + } SBULog.error("[Failed] Send user message request: \(error.localizedDescription)") return } @@ -759,7 +831,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { guard let self = self else { return } if let error = error { - self.baseDelegate?.didReceiveError(error) + self.baseDelegates.forEach { + $0.didReceiveError(error) + } SBULog.error( """ [Failed] Send file message request: @@ -794,7 +868,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.sortAllMessageList(needReload: true) - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { + $0.didReceiveError(error, isBlocker: false) + } SBULog.error("[Failed] Resend failed user message request: \(error.localizedDescription)") return @@ -828,13 +904,15 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.fullMessageList = self.messageList + pendingMessages.sorted { $0.createdAt < $1.createdAt } - self.baseDelegate?.shouldUpdateLoadingState(false) - self.baseDelegate?.baseChannelViewModel( - self, - didChangeMessageList: self.fullMessageList, - needsToReload: needReload, - initialLoad: self.isInitialLoading - ) + self.baseDelegates.forEach { + $0.shouldUpdateLoadingState(false) + $0.baseChannelViewModel( + self, + didChangeMessageList: self.fullMessageList, + needsToReload: needReload, + initialLoad: self.isInitialLoading + ) + } } // MARK: - Last Updated timestamp @@ -975,7 +1053,9 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { """) self.nextLock.unlock() - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { + $0.didReceiveError(error, isBlocker: true) + } return } @@ -1023,12 +1103,14 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { private func handleChangelogResponse(updatedMessages: [BaseMessage]?, deletedMessageIds: [Int64]?) { if let updatedMessages = updatedMessages, !updatedMessages.isEmpty { - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: updatedMessages, - forContext: nil, - keepsScroll: false - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: updatedMessages, + forContext: nil, + keepsScroll: false + ) + } self.upsertMessagesInList(messages: updatedMessages, needReload: true) } @@ -1044,12 +1126,14 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { private func handleChangelogResponse(addedMessages: [BaseMessage]) -> Bool { let hasMore = addedMessages.count >= self.changelogFetchLimit - self.delegate?.baseChannelViewModel( - self, - shouldUpdateScrollInMessageList: addedMessages, - forContext: nil, - keepsScroll: true - ) + self.delegates.forEach { + $0.baseChannelViewModel( + self, + shouldUpdateScrollInMessageList: addedMessages, + forContext: nil, + keepsScroll: true + ) + } self.upsertMessagesInList(messages: addedMessages, needReload: true) SBULog.info("Loaded added messages : \(addedMessages.count), hasNext : \(String(describing: self.hasNext))") @@ -1103,15 +1187,19 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { self.query?.loadNextPage { [weak self] members, _ in guard let self = self else { return } self.suggestedMemberList = SBUUser.convertUsers(members) - self.delegate?.messageThreadViewModel( - self, - didReceiveSuggestedMentions: self.suggestedMemberList - ) + self.delegates.forEach { + $0.messageThreadViewModel( + self, + didReceiveSuggestedMentions: self.suggestedMemberList + ) + } } } else { guard channel.members.count > 0 else { self.suggestedMemberList = nil - self.delegate?.messageThreadViewModel(self, didReceiveSuggestedMentions: nil) + self.delegates.forEach { + $0.messageThreadViewModel(self, didReceiveSuggestedMentions: nil) + } return } @@ -1128,10 +1216,12 @@ open class SBUMessageThreadViewModel: SBUBaseChannelViewModel { let resultMembers = Array(matchedMembers[0.. { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUGroupChannelPushSettingsViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + required public init( channel: BaseChannel? = nil, channelURL: String? = nil, @@ -38,6 +49,7 @@ open class SBUGroupChannelPushSettingsViewModel: SBUBaseChannelSettingsViewModel super.init() self.delegate = delegate + self.baseDelegates.addDelegate(delegate, type: .uikit) if let channel = channel { self.channel = channel @@ -47,6 +59,11 @@ open class SBUGroupChannelPushSettingsViewModel: SBUBaseChannelSettingsViewModel } guard let channelURL = self.channelURL else { return } + self.initializeAndLoad(channelURL: channelURL) + } + + func initializeAndLoad(channelURL: String) { + self.channelURL = channelURL self.loadChannel(channelURL: channelURL) } @@ -60,23 +77,31 @@ open class SBUGroupChannelPushSettingsViewModel: SBUBaseChannelSettingsViewModel guard let groupChannel = self.channel as? GroupChannel else { return } guard self.currentTriggerOption != pushTriggerOption else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { + $0.shouldUpdateLoadingState(true) + } groupChannel.setMyPushTriggerOption(pushTriggerOption) { [weak self] error in guard let self = self else { return } - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { + $0.shouldUpdateLoadingState(false) + } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { + $0.didReceiveError(error) + } return } if let channel = self.channel { let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.baseChannelSettingsViewModel( - self, - didChangeChannel: channel, - withContext: context - ) + self.delegates.forEach { + $0.baseChannelSettingsViewModel( + self, + didChangeChannel: channel, + withContext: context + ) + } self.updateChannelPushTriggerOption() } } @@ -85,9 +110,11 @@ open class SBUGroupChannelPushSettingsViewModel: SBUBaseChannelSettingsViewModel public func updateChannelPushTriggerOption() { guard let channel = self.channel as? GroupChannel else { return } self.currentTriggerOption = channel.myPushTriggerOption - self.delegate?.groupChannelPushSettingsViewModel( - self, - didChangeNotification: self.currentTriggerOption - ) + self.delegates.forEach { + $0.groupChannelPushSettingsViewModel( + self, + didChangeNotification: self.currentTriggerOption + ) + } } } diff --git a/Sources/ViewModel/SBUViewModelDelegate.swift b/Sources/uikit/ViewModel/SBUViewModelDelegate.swift similarity index 100% rename from Sources/ViewModel/SBUViewModelDelegate.swift rename to Sources/uikit/ViewModel/SBUViewModelDelegate.swift diff --git a/Sources/ViewModel/SBUViewModelSet.swift b/Sources/uikit/ViewModel/SBUViewModelSet.swift similarity index 99% rename from Sources/ViewModel/SBUViewModelSet.swift rename to Sources/uikit/ViewModel/SBUViewModelSet.swift index a90393e..63a9c81 100644 --- a/Sources/ViewModel/SBUViewModelSet.swift +++ b/Sources/uikit/ViewModel/SBUViewModelSet.swift @@ -9,7 +9,7 @@ import UIKit /// A class that holds references to various view model types used in the Sendbird UIKit. -/// - Since: 3.26.0 +/// - Since: 3.28.0 public class SBUViewModelSet { /// The view model for the group channel list. public static var GroupChannelListViewModel: SBUGroupChannelListViewModel.Type = SBUGroupChannelListViewModel.self diff --git a/Sources/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift b/Sources/uikit/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift similarity index 83% rename from Sources/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift rename to Sources/uikit/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift index bad4603..9fdce6e 100644 --- a/Sources/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift +++ b/Sources/uikit/ViewModel/SelectUser/CreateChannel/SBUCreateChannelViewModel.swift @@ -51,6 +51,9 @@ open class SBUCreateChannelViewModel { public weak var delegate: SBUCreateChannelViewModelDelegate? /// The data source for `SBUCreateChannelViewModel`. This is used to provide the next member list for the channel type. public weak var dataSource: SBUCreateChannelViewModelDataSource? + + // MARK: SwiftUI (Internal) + var delegates = WeakDelegateStorage() /// The type of channel to be created. Default is `.group`. public private(set) var channelType: ChannelCreationType = .group @@ -85,15 +88,24 @@ open class SBUCreateChannelViewModel { ) { self.delegate = delegate self.dataSource = dataSource + self.delegates.addDelegate(delegate, type: .uikit) self.channelType = channelType self.customizedUsers = users self.useCustomizedUsers = (users?.count ?? 0) > 0 + self.initializeAndLoad(users: users) + } + + func initializeAndLoad( + users: [SBUUser]? = nil + ) { + if let users { self.customizedUsers = users } + self.useCustomizedUsers = (users?.count ?? 0) > 0 + // If want using your custom user list, filled users with your custom user list. self.loadNextUserList(reset: true, users: self.customizedUsers ?? nil) - } // MARK: - List handling @@ -107,7 +119,7 @@ open class SBUCreateChannelViewModel { /// - users: customized `SBUUser` array for add to user list public func loadNextUserList(reset: Bool, users: [SBUUser]? = nil) { guard !self.isLoading else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } if reset { self.userListQuery = nil @@ -123,15 +135,17 @@ open class SBUCreateChannelViewModel { SBULog.info("\(users.count) customized users have been added.") self.userList += users - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.createChannelViewModel( - self, - didChangeUsers: self.userList, - needsToReload: true - ) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } + self.delegates.forEach { + $0.createChannelViewModel( + self, + didChangeUsers: self.userList, + needsToReload: true + ) + } } else { guard !self.useCustomizedUsers else { - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } return } @@ -143,17 +157,17 @@ open class SBUCreateChannelViewModel { } guard self.userListQuery?.hasNext == true else { - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All users have been loaded.") return } self.userListQuery?.loadNextPage { [weak self] users, error in guard let self = self else { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: true) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: true) } return } @@ -166,7 +180,7 @@ open class SBUCreateChannelViewModel { guard !users.isEmpty else { return } self.userList += users - self.delegate?.createChannelViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.createChannelViewModel(self, didChangeUsers: self.userList, needsToReload: true) } } } } @@ -234,10 +248,10 @@ open class SBUCreateChannelViewModel { [Request] Create channel with users, Users: \(Array(self.selectedUserList)) """) - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } GroupChannel.createChannel(params: params) { [weak self] channel, error in - defer { self?.delegate?.shouldUpdateLoadingState(false) } + defer { self?.delegates.forEach { $0.shouldUpdateLoadingState(false) } } guard let self = self else { return } if let error = error { @@ -245,16 +259,18 @@ open class SBUCreateChannelViewModel { [Failed] Create channel request: \(String(error.localizedDescription)) """) - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } SBULog.info("[Succeed] Create channel: \(channel?.description ?? "")") - self.delegate?.createChannelViewModel( - self, - didCreateChannel: channel, - withMessageListParams: messageListParams - ) + self.delegates.forEach { + $0.createChannelViewModel( + self, + didCreateChannel: channel, + withMessageListParams: messageListParams + ) + } } } @@ -272,9 +288,11 @@ open class SBUCreateChannelViewModel { SBULog.info("Selected user: \(user)") - self.delegate?.createChannelViewModel( - self, - didUpdateSelectedUsers: Array(self.selectedUserList) - ) + self.delegates.forEach { + $0.createChannelViewModel( + self, + didUpdateSelectedUsers: Array(self.selectedUserList) + ) + } } } diff --git a/Sources/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift b/Sources/uikit/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift similarity index 84% rename from Sources/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift rename to Sources/uikit/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift index 1abb2ae..931ed1e 100644 --- a/Sources/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift +++ b/Sources/uikit/ViewModel/SelectUser/CreateChannel/SBUCreateOpenChannelViewModel.swift @@ -24,11 +24,15 @@ open class SBUCreateOpenChannelViewModel { weak var delegate: SBUCreateOpenChannelViewModelDelegate? @SBUAtomic private var isLoading = false + // MARK: SwiftUI (Internal) + var delegates = WeakDelegateStorage() + // MARK: - Life Cycle /// Initializes a new instance of `SBUCreateOpenChannelViewModel`. /// - Parameter delegate: An optional delegate that conforms to `SBUCreateOpenChannelViewModelDelegate`. required public init(delegate: SBUCreateOpenChannelViewModelDelegate?) { self.delegate = delegate + self.delegates.addDelegate(delegate, type: .uikit) } // MARK: - Create Channel @@ -57,10 +61,10 @@ open class SBUCreateOpenChannelViewModel { open func createChannel(params: OpenChannelCreateParams) { SBULog.info("[Request] Create open channel") - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach {$0.shouldUpdateLoadingState(true) } OpenChannel.createChannel(params: params) { [weak self] channel, error in - defer { self?.delegate?.shouldUpdateLoadingState(false) } + defer { self?.delegates.forEach {$0.shouldUpdateLoadingState(false) } } guard let self = self else { return } if let error = error { @@ -68,12 +72,12 @@ open class SBUCreateOpenChannelViewModel { [Failed] Create open channel request: \(String(error.localizedDescription)) """) - self.delegate?.didReceiveError(error) + self.delegates.forEach {$0.didReceiveError(error) } return } SBULog.info("[Succeed] Create open channel: \(channel?.description ?? "")") - self.delegate?.createOpenChannelViewModel(self, didCreateChannel: channel) + self.delegates.forEach {$0.createOpenChannelViewModel(self, didCreateChannel: channel) } } } diff --git a/Sources/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift b/Sources/uikit/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift similarity index 81% rename from Sources/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift rename to Sources/uikit/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift index eb23ee3..63fce90 100644 --- a/Sources/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift +++ b/Sources/uikit/ViewModel/SelectUser/SBUBaseSelectUserViewModel.swift @@ -55,6 +55,8 @@ open class SBUBaseSelectUserViewModel: NSObject { weak var baseDelegate: SBUBaseSelectUserViewModelDelegate? weak var baseDataSource: SBUBaseSelectUserViewModelDataSource? + var baseDelegates = WeakDelegateStorage() + internal var customUserListQuery: ApplicationUserListQuery? internal var customMemberListQuery: MemberListQuery? internal var customParticipantListQuery: ParticipantListQuery? @@ -77,10 +79,11 @@ open class SBUBaseSelectUserViewModel: NSObject { delegate: SBUBaseSelectUserViewModelDelegate? = nil, dataSource: SBUBaseSelectUserViewModelDataSource? = nil ) { - self.baseDelegate = delegate self.baseDataSource = dataSource + self.baseDelegates.addDelegate(delegate, type: .uikit) + super.init() if let channel = channel { @@ -89,38 +92,60 @@ open class SBUBaseSelectUserViewModel: NSObject { } else if let channelURL = channelURL { self.channelURL = channelURL } + + guard let channelURL = self.channelURL else { return } + self.initializeAndLoad( + channelURL: channelURL, + channelType: channelType, + users: users, + inviteListType: inviteListType, + userListQuery: userListQuery, + memberListQuery: memberListQuery, + participantListQuery: participantListQuery + ) + } + + func initializeAndLoad( + channelURL: String, + channelType: ChannelType = .group, + users: [SBUUser]? = nil, + inviteListType: ChannelInviteListType, + userListQuery: ApplicationUserListQuery? = nil, + memberListQuery: MemberListQuery? = nil, + participantListQuery: ParticipantListQuery? = nil + ) { + self.channelURL = channelURL self.channelType = channelType self.inviteListType = inviteListType - self.customUserListQuery = userListQuery - self.customMemberListQuery = memberListQuery - self.customParticipantListQuery = participantListQuery + if let userListQuery { self.userListQuery = userListQuery } + if let memberListQuery { self.memberListQuery = memberListQuery } + if let participantListQuery { self.participantListQuery = participantListQuery } - self.customizedUsers = users + if let users { self.customizedUsers = users } self.useCustomizedUsers = (users?.count ?? 0) > 0 - - guard let channelURL = self.channelURL else { return } + self.loadChannel(channelURL: channelURL, type: channelType) } // MARK: - Channel related public func loadChannel(channelURL: String, type: ChannelType) { - self.baseDelegate?.shouldUpdateLoadingState(true) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(true) } SendbirdUI.connectIfNeeded { [weak self] _, error in guard let self = self else { return } if let error = error { - self.baseDelegate?.shouldUpdateLoadingState(false) - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else { let completionHandler: ((BaseChannel?, SBError?) -> Void) = { [weak self] channel, error in guard let self = self else { return } if let error = error { - self.baseDelegate?.shouldUpdateLoadingState(false) - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else if let channel = channel { self.channel = channel self.loadNextUserList(reset: true, users: self.customizedUsers) @@ -219,7 +244,7 @@ open class SBUBaseSelectUserViewModel: NSObject { guard self.userListQuery?.hasNext == true else { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All users have been loaded.") return } @@ -228,11 +253,11 @@ open class SBUBaseSelectUserViewModel: NSObject { guard let self = self else { return } defer { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } return } guard let users = users?.sbu_convertUserList() else { return } @@ -246,28 +271,28 @@ open class SBUBaseSelectUserViewModel: NSObject { private func appendUsersWithFiltering(users: [SBUUser]) { defer { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } } // Super,Broadcast channel does not contain all information in joined members. if let channel = channel as? GroupChannel, (channel.isBroadcast || channel.isSuper) { self.userList += users - self.baseDelegate?.baseSelectedUserViewModel( + self.baseDelegates.forEach { $0.baseSelectedUserViewModel( self, didChangeUserList: self.userList, needsToReload: true - ) + ) } return } guard !self.joinedUserIds.isEmpty else { self.userList += users - self.baseDelegate?.baseSelectedUserViewModel( + self.baseDelegates.forEach { $0.baseSelectedUserViewModel( self, didChangeUserList: self.userList, needsToReload: true - ) + ) } return } @@ -276,17 +301,18 @@ open class SBUBaseSelectUserViewModel: NSObject { let nextUserList = (self.baseDataSource?.nextUserList()?.count ?? 0) > 0 ? self.baseDataSource?.nextUserList() : nil + // FIXME: member list 다음 목록을 제대로 못가져옴. 우선 loading 상태 해제가 되야하고, 해제가되면, 리스트 받아오는게 이미 가져온 목록이 있어도 limit 만큼 가져와야함 self.loadNextUserList( reset: false, users: self.useCustomizedUsers ? nextUserList : nil ) } else { self.userList += filteredUsers - self.baseDelegate?.baseSelectedUserViewModel( + self.baseDelegates.forEach { $0.baseSelectedUserViewModel( self, didChangeUserList: self.userList, needsToReload: true - ) + ) } } } @@ -306,8 +332,8 @@ open class SBUBaseSelectUserViewModel: NSObject { self.memberListQuery = channel.createMemberListQuery(params: params) } else { let error = SBError(domain: "Cannot create the memberListQuery.", code: -1, userInfo: nil) - self.baseDelegate?.shouldUpdateLoadingState(false) - self.baseDelegate?.didReceiveError(error) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } + self.baseDelegates.forEach { $0.didReceiveError(error) } return } } @@ -315,7 +341,7 @@ open class SBUBaseSelectUserViewModel: NSObject { guard self.memberListQuery?.hasNext == true else { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All members have been loaded.") return } @@ -324,11 +350,11 @@ open class SBUBaseSelectUserViewModel: NSObject { guard let self = self else { return } defer { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } return } @@ -337,11 +363,11 @@ open class SBUBaseSelectUserViewModel: NSObject { guard !members.isEmpty else { return } self.userList += members - self.baseDelegate?.baseSelectedUserViewModel( + self.baseDelegates.forEach { $0.baseSelectedUserViewModel( self, didChangeUserList: self.userList, needsToReload: true - ) + ) } }) } @@ -360,8 +386,8 @@ open class SBUBaseSelectUserViewModel: NSObject { self.participantListQuery = channel.createParticipantListQuery(params: params) } else { let error = SBError(domain: "Cannot create the participantListQuery.", code: -1, userInfo: nil) - self.baseDelegate?.shouldUpdateLoadingState(false) - self.baseDelegate?.didReceiveError(error) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } + self.baseDelegates.forEach { $0.didReceiveError(error) } return } } @@ -369,7 +395,7 @@ open class SBUBaseSelectUserViewModel: NSObject { guard self.participantListQuery?.hasNext == true else { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All participants have been loaded.") return } @@ -378,11 +404,11 @@ open class SBUBaseSelectUserViewModel: NSObject { guard let self = self, let channel = channel else { return } defer { self.isLoading = false - self.baseDelegate?.shouldUpdateLoadingState(false) + self.baseDelegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.baseDelegate?.didReceiveError(error, isBlocker: false) + self.baseDelegates.forEach { $0.didReceiveError(error, isBlocker: false) } return } @@ -391,11 +417,11 @@ open class SBUBaseSelectUserViewModel: NSObject { guard !users.isEmpty else { return } self.userList += users.sbu_updateOperatorStatus(channel: channel) - self.baseDelegate?.baseSelectedUserViewModel( + self.baseDelegates.forEach { $0.baseSelectedUserViewModel( self, didChangeUserList: self.userList, needsToReload: true - ) + ) } }) } @@ -449,9 +475,9 @@ open class SBUBaseSelectUserViewModel: NSObject { SBULog.info("Selected user: \(user)") - self.baseDelegate?.baseSelectedUserViewModel( + self.baseDelegates.forEach { $0.baseSelectedUserViewModel( self, didUpdateSelectedUsers: Array(self.selectedUserList) - ) + ) } } } diff --git a/Sources/ViewModel/SelectUser/SBUInviteUserViewModel.swift b/Sources/uikit/ViewModel/SelectUser/SBUInviteUserViewModel.swift similarity index 77% rename from Sources/ViewModel/SelectUser/SBUInviteUserViewModel.swift rename to Sources/uikit/ViewModel/SelectUser/SBUInviteUserViewModel.swift index 4bb8e15..a3b4361 100644 --- a/Sources/ViewModel/SelectUser/SBUInviteUserViewModel.swift +++ b/Sources/uikit/ViewModel/SelectUser/SBUInviteUserViewModel.swift @@ -32,6 +32,17 @@ open class SBUInviteUserViewModel: SBUBaseSelectUserViewModel { set { self.baseDataSource = newValue } } + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBUInviteUserViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // MARK: - Life Cycle required public init( channel: BaseChannel? = nil, @@ -55,6 +66,7 @@ open class SBUInviteUserViewModel: SBUBaseSelectUserViewModel { delegate: delegate, dataSource: dataSource ) + self.baseDelegates.addDelegate(delegate, type: .uikit) } // MARK: - Channel actions @@ -76,20 +88,20 @@ open class SBUInviteUserViewModel: SBUBaseSelectUserViewModel { public func invite(userIds: [String]) { guard let channel = self.channel as? GroupChannel else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SBULog.info("Request invite users: \(userIds)") channel.inviteUserIds(userIds, completionHandler: { [weak self] error in guard let self = self else { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } return } SBULog.info("[Succeed] Invite users request success") - self.delegate?.inviteUserViewModel(self, didInviteUserIds: userIds) + self.delegates.forEach { $0.inviteUserViewModel(self, didInviteUserIds: userIds) } }) } } diff --git a/Sources/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift b/Sources/uikit/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift similarity index 77% rename from Sources/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift rename to Sources/uikit/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift index a7b9c06..b75afab 100644 --- a/Sources/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift +++ b/Sources/uikit/ViewModel/SelectUser/SBURegisterOperatorViewModel.swift @@ -31,6 +31,17 @@ open class SBURegisterOperatorViewModel: SBUBaseSelectUserViewModel { set { self.baseDataSource = newValue } } + // MARK: SwiftUI (Internal) + var delegates: WeakDelegateStorage { + let computedDelegates = WeakDelegateStorage() + self.baseDelegates.allKeyValuePairs().forEach { key, value in + if let delegate = value as? SBURegisterOperatorViewModelDelegate { + computedDelegates.addDelegate(delegate, type: key) + } + } + return computedDelegates + } + // MARK: - Life Cycle required public init( channel: BaseChannel? = nil, @@ -53,6 +64,7 @@ open class SBURegisterOperatorViewModel: SBUBaseSelectUserViewModel { delegate: delegate, dataSource: dataSource ) + self.baseDelegates.addDelegate(delegate, type: .uikit) } // MARK: - Channel actions @@ -73,20 +85,20 @@ open class SBURegisterOperatorViewModel: SBUBaseSelectUserViewModel { public func registerAsOperators(userIds: [String]) { guard let channel = self.channel else { return } - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SBULog.info("[Request] Register users: \(userIds)") channel.addOperators(userIds: userIds) { [weak self] error in guard let self = self else { return } - defer { self.delegate?.shouldUpdateLoadingState(false) } + defer { self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } return } SBULog.info("[Succeed] Register users request success") - self.delegate?.registerOperatorViewModel(self, didRegisterOperatorIds: userIds) + self.delegates.forEach { $0.registerOperatorViewModel(self, didRegisterOperatorIds: userIds) } } } } diff --git a/Sources/ViewModel/UserList/SBUUserListViewModel.swift b/Sources/uikit/ViewModel/UserList/SBUUserListViewModel.swift similarity index 80% rename from Sources/ViewModel/UserList/SBUUserListViewModel.swift rename to Sources/uikit/ViewModel/UserList/SBUUserListViewModel.swift index ba017f7..4ba6292 100644 --- a/Sources/ViewModel/UserList/SBUUserListViewModel.swift +++ b/Sources/uikit/ViewModel/UserList/SBUUserListViewModel.swift @@ -51,9 +51,12 @@ open class SBUUserListViewModel: NSObject { // MARK: - Property (Public) public weak var delegate: SBUUserListViewModelDelegate? public weak var dataSource: SBUUserListViewModelDataSource? + + // MARK: SwiftUI (Internal) + var delegates = WeakDelegateStorage() public private(set) var channel: BaseChannel? - public private(set) var channelURL: String? + public internal(set) var channelURL: String? public private(set) var channelType: ChannelType = .group @SBUAtomic public private(set) var userList: [SBUUser] = [] @@ -68,7 +71,7 @@ open class SBUUserListViewModel: NSObject { public private(set) var userListType: ChannelUserListType = .none // MARK: - Property (Private) - @SBUAtomic private var customizedUsers: [SBUUser]? + @SBUAtomic var customizedUsers: [SBUUser]? private var useCustomizedUsers = false @SBUAtomic private var isLoading = false @@ -94,6 +97,8 @@ open class SBUUserListViewModel: NSObject { self.delegate = delegate self.dataSource = dataSource + self.delegates.addDelegate(delegate, type: .uikit) + super.init() if let channel = channel { @@ -102,26 +107,55 @@ open class SBUUserListViewModel: NSObject { } else if let channelURL = channelURL { self.channelURL = channelURL } + + guard let channelURL = self.channelURL else { return } + self.initializeAndLoad( + channelURL: channelURL, + channelType: channelType, + users: users, + userListType: userListType, + memberListQuery: memberListQuery, + operatorListQuery: operatorListQuery, + mutedMemberListQuery: mutedMemberListQuery, + mutedParticipantListQuery: mutedParticipantListQuery, + bannedUserListQuery: bannedUserListQuery, + participantListQuery: participantListQuery + ) + } + + func initializeAndLoad( + channelURL: String, + channelType: ChannelType = .group, + users: [SBUUser]? = nil, + userListType: ChannelUserListType, + memberListQuery: MemberListQuery? = nil, + operatorListQuery: OperatorListQuery? = nil, + mutedMemberListQuery: MemberListQuery? = nil, + mutedParticipantListQuery: MutedUserListQuery? = nil, + bannedUserListQuery: BannedUserListQuery? = nil, + participantListQuery: ParticipantListQuery? = nil + ) { + self.channelURL = channelURL self.channelType = channelType self.userListType = userListType - self.memberListQuery = memberListQuery - self.operatorListQuery = operatorListQuery - self.mutedMemberListQuery = mutedMemberListQuery - self.mutedParticipantListQuery = mutedParticipantListQuery - self.bannedUserListQuery = bannedUserListQuery - self.participantListQuery = participantListQuery + if let memberListQuery { self.memberListQuery = memberListQuery } + if let operatorListQuery { self.operatorListQuery = operatorListQuery } + if let mutedMemberListQuery { self.mutedMemberListQuery = mutedMemberListQuery } + if let mutedParticipantListQuery { self.mutedParticipantListQuery = mutedParticipantListQuery } + if let bannedUserListQuery { self.bannedUserListQuery = bannedUserListQuery } + if let participantListQuery { self.participantListQuery = participantListQuery } - self.customizedUsers = users + if let users { self.customizedUsers = users } self.useCustomizedUsers = (users?.count ?? 0) > 0 self.userStateChangedHandler = { [weak self] error in - defer { self?.delegate?.shouldUpdateLoadingState(false) } + defer { self?.delegates.forEach { $0.shouldUpdateLoadingState(false) } } guard let self = self else { return } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } return } @@ -157,25 +191,25 @@ open class SBUUserListViewModel: NSObject { // MARK: - Channel related public func loadChannel(channelURL: String, type: ChannelType) { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SendbirdUI.connectIfNeeded { [weak self] _, error in guard let self = self else { return } if let error = error { - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else { let completionHandler: ((BaseChannel?, SBError?) -> Void) = { [weak self] channel, error in guard let self = self else { return } if let error = error { - self.delegate?.didReceiveError(error, isBlocker: false) + self.delegates.forEach { $0.didReceiveError(error, isBlocker: false) } } else if let channel = channel { self.channel = channel let context = MessageContext(source: .eventChannelChanged, sendingStatus: .succeeded) - self.delegate?.userListViewModel(self, didChangeChannel: channel, withContext: context) + self.delegates.forEach { $0.userListViewModel(self, didChangeChannel: channel, withContext: context) } // If want using your custom user list, filled users with your custom user list. self.loadNextUserList(reset: true, users: self.customizedUsers ?? nil) @@ -209,7 +243,7 @@ open class SBUUserListViewModel: NSObject { guard !self.isLoading else { return } self.isLoading = true - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SBULog.info("[Request] Next user List") @@ -219,13 +253,13 @@ open class SBUUserListViewModel: NSObject { self.userList += users self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } } else if self.useCustomizedUsers, let customizedUsers = self.customizedUsers { self.userList += customizedUsers self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } } else if !self.useCustomizedUsers { switch userListType { case .members: @@ -261,7 +295,7 @@ open class SBUUserListViewModel: NSObject { guard self.memberListQuery?.hasNext == true else { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All members have been loaded.") return } @@ -270,18 +304,18 @@ open class SBUUserListViewModel: NSObject { guard let self = self else { return } defer { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } guard let members = members?.sbu_convertUserList() else { return } SBULog.info("[Response] \(members.count) members") self.userList += members - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } }) } @@ -299,7 +333,7 @@ open class SBUUserListViewModel: NSObject { guard self.operatorListQuery?.hasNext == true else { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All operators have been loaded.") return } @@ -308,18 +342,18 @@ open class SBUUserListViewModel: NSObject { guard let self = self else { return } defer { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } guard let operators = operators?.sbu_convertUserList() else { return } SBULog.info("[Response] \(operators.count) operators") self.userList += operators - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } }) } @@ -337,7 +371,7 @@ open class SBUUserListViewModel: NSObject { guard self.mutedMemberListQuery?.hasNext == true else { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All muted members have been loaded.") return } @@ -346,18 +380,18 @@ open class SBUUserListViewModel: NSObject { guard let self = self else { return } defer { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } guard let members = members?.sbu_convertUserList() else { return } SBULog.info("[Response] \(members.count) members") self.userList += members - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } }) } @@ -376,7 +410,7 @@ open class SBUUserListViewModel: NSObject { guard self.mutedParticipantListQuery?.hasNext == true else { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All muted participants have been loaded.") return } @@ -385,18 +419,18 @@ open class SBUUserListViewModel: NSObject { guard let self = self, let channel = channel else { return } defer { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } guard let members = members?.sbu_convertUserList() else { return } SBULog.info("[Response] \(members.count) members") self.userList += members.sbu_updateOperatorStatus(channel: channel) - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } }) } @@ -413,7 +447,7 @@ open class SBUUserListViewModel: NSObject { guard self.bannedUserListQuery?.hasNext == true else { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All banned users have been loaded.") return } @@ -423,18 +457,18 @@ open class SBUUserListViewModel: NSObject { guard let self = self else { return } defer { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } guard let users = users?.sbu_convertUserList() else { return } SBULog.info("[Response] \(users.count) users") self.userList += users - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } }) } @@ -452,7 +486,7 @@ open class SBUUserListViewModel: NSObject { guard self.participantListQuery?.hasNext == true else { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } SBULog.info("All participants have been loaded.") return } @@ -461,18 +495,18 @@ open class SBUUserListViewModel: NSObject { guard let self = self, let channel = channel else { return } defer { self.isLoading = false - self.delegate?.shouldUpdateLoadingState(false) + self.delegates.forEach { $0.shouldUpdateLoadingState(false) } } if let error = error { - self.delegate?.didReceiveError(error) + self.delegates.forEach { $0.didReceiveError(error) } return } guard let participants = participants?.sbu_convertUserList() else { return } SBULog.info("[Response] \(participants.count) participants") self.userList += participants.sbu_updateOperatorStatus(channel: channel) - self.delegate?.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) + self.delegates.forEach { $0.userListViewModel(self, didChangeUsers: self.userList, needsToReload: true) } }) } @@ -551,7 +585,7 @@ open class SBUUserListViewModel: NSObject { guard let channel = self.channel else { return } let userId = user.userId - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SBULog.info("[Request] Register user: \(userId)") channel.addOperators(userIds: [userId], completionHandler: self.userStateChangedHandler) @@ -563,7 +597,7 @@ open class SBUUserListViewModel: NSObject { guard let channel = self.channel else { return } let userId = user.userId - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } SBULog.info("[Request] Unregister operator: \(userId)") channel.removeOperators(userIds: [userId], completionHandler: self.userStateChangedHandler) @@ -575,7 +609,7 @@ open class SBUUserListViewModel: NSObject { if let groupChannel = self.channel as? GroupChannel { groupChannel.muteUser(userId: user.userId, seconds: -1, description: nil, completionHandler: self.userStateChangedHandler) } else if let openChannel = self.channel as? OpenChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } openChannel.muteUser(userId: user.userId, seconds: -1, description: nil, completionHandler: self.userStateChangedHandler) } } @@ -584,10 +618,10 @@ open class SBUUserListViewModel: NSObject { /// - Parameter user: A member/participant to be unmuted public func unmute(user: SBUUser) { if let groupChannel = self.channel as? GroupChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } groupChannel.unmuteUser(userId: user.userId, completionHandler: self.userStateChangedHandler) } else if let openChannel = self.channel as? OpenChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } openChannel.unmuteUser(userId: user.userId, completionHandler: self.userStateChangedHandler) } } @@ -596,7 +630,7 @@ open class SBUUserListViewModel: NSObject { /// - Parameter user: A user to be banned public func ban(user: SBUUser) { if let groupChannel = self.channel as? GroupChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } groupChannel.banUser( userId: user.userId, seconds: -1, @@ -604,7 +638,7 @@ open class SBUUserListViewModel: NSObject { completionHandler: self.userStateChangedHandler ) } else if let openChannel = self.channel as? OpenChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } openChannel.banUser( userId: user.userId, seconds: -1, @@ -618,13 +652,13 @@ open class SBUUserListViewModel: NSObject { /// - Parameter user: A user to be unbanned public func unban(user: SBUUser) { if let groupChannel = self.channel as? GroupChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } groupChannel.unbanUser( userId: user.userId, completionHandler: self.userStateChangedHandler ) } else if let openChannel = self.channel as? OpenChannel { - self.delegate?.shouldUpdateLoadingState(true) + self.delegates.forEach { $0.shouldUpdateLoadingState(true) } openChannel.unbanUser( userId: user.userId, completionHandler: self.userStateChangedHandler @@ -662,7 +696,7 @@ extension SBUUserListViewModel: BaseChannelDelegate { } public func channelWasDeleted(_ channelURL: String, channelType: ChannelType) { - self.delegate?.userListViewModel(self, shouldDismissForUserList: nil) + self.delegates.forEach { $0.userListViewModel(self, shouldDismissForUserList: nil) } } }