Skip to main content

How to perform Post Creation without using LikeMinds UI?

Introduction

This guide will walk you through the process of implementing a custom post creation flow using the LikeMinds Feed Flutter SDK. You'll learn how to use the LMFeedPostBloc to create posts and handle attachments using the LMAttachmentViewData class.

Prerequisites

Before you begin, ensure the following:

  • LikeMinds Feed Flutter SDK: The SDK must be properly installed and initialized in your Flutter project. Refer to the installation guide if needed.
  • Feed Enabled: Ensure that Feed is enabled on the dashboard for your project.
  • Basic Understanding of Flutter Widgets: Familiarity with Flutter widgets and layout concepts.
  • Knowledge of Builder Pattern: Understanding of the builder pattern in Dart, as it is used to customize and create widgets dynamically.

Steps

Step 1: Understanding the LMFeedPostBloc

The LMFeedPostBloc is responsible for managing the state of post-related operations in the Feed SDK. It gives access to a number of different events and states that can be used to build your entire Post handling UI without worrying about the business logic.

To create a post, you'll need to add an event to the BLoC called LMFeedCreateNewPostEvent, which we will discuss further.

Step 2: Understanding LMAttachmentViewData

The LMAttachmentViewData class represents media attachments for a post. It's has multiple factory constructors for different scenarios.

Here's a brief overview:

enum LMMediaType { none, video, image, document, link, widget, repost, poll }

class LMAttachmentViewData {
final LMMediaType attachmentType;
final LMAttachmentMetaViewData attachmentMeta;

// Factory constructors
factory LMAttachmentViewData.fromAttachmentMeta({...});
factory LMAttachmentViewData.fromMediaUrl({...});
factory LMAttachmentViewData.fromMediaBytes({...});
factory LMAttachmentViewData.fromMediaPath({...});

// Method to map media type to integer
int mapMediaTypeToInt() {...}
}

The class uses different factory constructors based on how you want to create the attachment:

  • fromAttachmentMeta: When you already have an LMAttachmentMetaViewData object.
  • fromMediaUrl: When you have a URL for the media.
  • fromMediaBytes: When you have the media as bytes (Uint8List).
  • fromMediaPath: When you have a local file path for the media.

The LMMediaType enum provides various media types you can use.

When creating an attachment, make sure to specify the correct media type. To do this you can also use, but always prefer using the LMMediaType enum.

LMAttachmentViewData attachment; //image type attachment

/// Function to map the LMMediaType enum to its int value
int attachmentType = attachment.mapMediaTypeToInt(); // 1

/// Function to map the attachment int value to its LMMediaType enum
LMMediaType type = mapIntToMediaType(attachmentType); // LMMediaType.image

Step 3: Creating Attachments

To create an attachment for your post, use one of the factory constructors of LMAttachmentViewData. Here's an example using fromMediaPath:

LMAttachmentViewData attachment = LMAttachmentViewData.fromMediaPath(
path: "path/to/your/file",
attachmentType: LMMediaType.image,
// Add other parameters as needed
);

Step 4: Preparing Post Data

Before creating a post, you need to prepare the necessary data. Here's a breakdown of the required information:

  1. LMUserViewData user: The current user object.
  2. String? postText: The main content of the post (optional).
  3. String? heading: The post heading (optional).
  4. int? feedroomId: The ID of the feedroom where the post will be created (if applicable).
  5. List<LMUserTagViewData>? userTagged: Any users tagged in the post (optional).
  6. List<LMTopicViewData> selectedTopics: Any topics associated with the post.
  7. List<LMAttachmentViewData>? postMedia: An array of LMAttachmentViewData objects representing attachments (optional).
note
  • Either one of postText, heading, or postMedia should be not null.
  • The parameter selectedTopics can be an empty list, but should not be null.
  • You can get the instance of the current logged-in user anytime using the helper function of the local preference utility - LMFeedLocalPreference.instance.fetchUserData();.

Step 5: Creating a Post

To create a post, use the following code snippet:

LMFeedPostBloc.instance.add(
LMFeedCreateNewPostEvent(
user: user, // Current user object
postText: postContent, // The main content of the post
selectedTopics: selectedTopics, // List of selected topics
postMedia: [attachment], // List of LMAttachmentViewData objects
heading: postHeading, // Optional heading
feedroomId: feedroomId, // ID of the feedroom (if applicable)
userTagged: taggedUsers, // List of tagged users
),
);

Step 6: Listening for Post Creation Result

The LMFeedPostBloc automatically handles all the state changes, and the built-in UI responds to it accordingly. Additionally, to listen to the result of the post creation:

Listen to the LMFeedPostBloc state changes:

LMFeedPostBloc.instance.stream.listen((state) {
if (state is LMFeedNewPostUploadedState) {
// Post created successfully
// Handle success (e.g., show a success message, navigate to feed)
} else if (state is LMFeedNewPostErrorState) {
// Error occurred while creating post
// Handle error (e.g., show error message)
}
});

Steps to Implement Post Creation with Custom Widget

Step 1: Build an Attachment

Using the steps above as reference, now build an attachment object of type LMAttachmentViewData and add it into your list of attachments. Here's how:

List<LMAttachmentViewData> attachments = [];
final attachment = LMAttachmentViewData.fromAttachmentMeta(
attachmentType: LMMediaType.widget,
attachmentMeta: (LMAttachmentMetaViewDataBuilder()
..meta({
// Map<String, dynamic>
}))
.build(),
);
attachments.add(attachment);

Step 2: Create Post with Attachment

Use your list of attachments to send alongside your post data, in the LMFeedCreateNewPostEvent event, and then add the event to an instance of LMFeedPostBloc.

Additional Information

  • The LMAttachmentViewData class uses a builder pattern. If you need more control over the creation process, you can use LMAttachmentViewDataBuilder.
  • Handle attachment uploads separately before creating the post, and use the returned URLs or file paths to create LMAttachmentViewData objects.
  • Be mindful of the different media types and use the appropriate factory constructor for each type.
  • Implement proper error handling and user feedback in your UI.
  • For polls, widgets, or other complex media types, refer to the SDK documentation for specific parameters and usage.
  • For more details on post creation features or specific media types, please reach out to us.