core/features/content
2022-01-22 20:19:50 +06:00
..
binary add integration with posts creating 2022-01-22 13:30:49 +06:00
client add content 2021-11-24 20:25:05 +06:00
common include compose 2022-01-22 20:19:50 +06:00
server include compose 2022-01-22 20:19:50 +06:00
text temporal progress 2022-01-19 17:22:04 +06:00
README.md fix Readme.md 2022-01-07 20:26:32 +06:00

How to create content?

For example, you want to create content named MyFormat. To do this, you must perform the following actions:

  1. Copy template folder from core/features in core/features/content
  2. Rename this folder in myformat
  3. Inside the myformat folder rename all the template on content.myformat
  4. In the settings.gradle file in the includes array add the following code:
        String[] includes = [
            ...
            ":features:content:myformat:common",
            ":features:content:myformat:client",
            ":features:content:myformat:server",
            ...
        ]
    
  5. In the core/features/content/myformat/common/src folder create folders with appropriate subfolders commonMain/kotlin/dev/inmo/postssystem/features/content/myformat/common:
  6. In the last folder сommon, create a data class and the configurator as shown below:
       // MyFormatContent.kt
       @Serializable
       data class MyFormatContent(
           // Your code
       ) : Content
    
       // MyFormatContentSerializerModuleConfigurator.kt
       object MyFormatContentSerializerModuleConfigurator : ContentSerializersModuleConfigurator.Element {
           override fun PolymorphicModuleBuilder<Content>.invoke() {
               subclass(MyFormatContent::class, MyFormatContent.serializer())
           }
       }
    
  7. In two di.kt file located in core/client/src/commonMain/kotlin/dev/inmo/postsystem/client and core/server/src/main/java/dev/inmo/postsystem/client respectively add the following string:
    singleWithRandomQualifier<ContentSerializersModuleConfigurator.Element> { MyFormatContentSerializerModuleConfigurator }