Basics of Module
This page explains the basic concepts and common classes that apply to all key functions and their modules in UIKit for iOS.
Global SBUModuleSet
In Sendbird UIKit, there is a SBUModuleSet global class that manages all modules. As shown in the image below, SBUModuleSet owns all modules in the key functions and each module is composed of various components. The global SBUModuleSet provides the corresponding module and its components to every view controller.
Customization
If you don't want to use the default module and component provided by the UIKit, you can set a custom module and component in SBUModuleSet so the customized objects become the default setting throughout the entire client app.
When using a customized module or its component, the view controller follows the order below:
- A component that's been customized in the view controller.
- A custom module or component that's been customized in SBUModuleSet.
- A non-customized, default module and component provided by Sendbird UIKit.
If you didn't set a custom module or component in the view controller, then a custom module or component that's been set in SBUModuleSet is used across the UIKit. If there are no custom modules or components, the default objects provided by Sendbird UIKit in SBUModuleSet is used.
Refer to the code below to see how to customize GroupChannelListModule as an example.
Note: You can customize other modules using the same code.
Refer to the code below to see how to customize the header component of GroupChannelListModule as an example.
Note: You can customize other components using the same code.
Theme
Every component has a customizable theme property and each component uses the theme object as a parameter in the configure method to build the UI.
Corresponding themes for modules and components
Refer to the table below to see which theme class is used in each module.
| Module | Component | Theme | 
|---|---|---|
| SBUGroupChannelListModule | HeaderComponent | |
| SBUGroupChannelModule | HeaderComponent | |
| SBUOpenChannelModule | HeaderComponent | |
| SBUInviteUserModule | HeaderComponent | |
| SBURegisterOperatorModule | HeaderComponent | |
| SBUUserListModule | HeaderComponent | |
| SBUCreateChannelModule | HeaderComponent | |
| SBUGroupChannelSettingsModule | HeaderComponent | |
| SBUOpenChannelSettingsModule | HeaderComponent | |
| SBUModerationsModule | HeaderComponent | |
| SBUMessageSearchModule | HeaderComponent | 
Customization
To see how to customize the theme of a component, refer to the following codes below.
There are three ways to use a custom theme in a custom component:
- Set a custom component that uses a customized theme in the view controller.
- Set a custom component that uses a customized theme in the global SBUModuleSet.
- Change the global theme class. Go to the Themes page to learn more.
Note: You can apply the same codes above to all modules.