Skip to main content

LMPostWidgetCell

In our framework, we've implemented a modular design featuring six distinct Post Widget cells:

  1. LMFeedPostTopicCell: Designed for displaying the topics associated with a post

  2. LMFeedPostTextCell: Displays the post text content

  3. LMFeedPostMediaCell: Designed for showcasing posts containing photo or video content.

  4. LMFeedPostLinkCell: Tailored to display posts featuring link previews.

  5. LMFeedPostDocumentCell: Specifically crafted for presenting posts containing documents.

  6. LMFeedPostPollCell: View designed for posts containing a Poll.

LMFeedPostMediaCellLMFeedPostDocumentCellLMFeedPostLinkCell
LMFeedPostMediaCellLMFeedPostDocumentCellLMFeedPostLinkCell
LMFeedPostTopicCellLMFeedPostTextCell
LMFeedPostTopicCellLMFeedPostTextCell

All these cells share a common parent component LMPostWidgetTableViewCell, which serves as the base class. This shared foundation streamlines the user interface by incorporating consistent UI elements and actions across all three widgets. This approach ensures a unified and standardized experience for users interacting with various post formats within our framework.

The image below shows a cell breakdown of a Post Widget using MediaCell as an example: Screenshot showing Link Cell{caption=some caption}

LMPostWidgetTableViewCell

LMPostWidgetTableViewCell is the base class that is used by LMFeedPostTopicCell, LMFeedPostTextCell, LMFeedPostPollCell, LMFeedPostMediaCell, LMFeedPostLinkCell, LMFeedPostDocumentCell designed for displaying a post widget. This cell includes various UI components such as a content stack, topic feed, post text. It conforms to LMTableViewCell and is designed to be customizable and reusable across the application.

Functionality

Protocols

LMFeedPostTableCellProtocol

Defines the properties required for a table cell to display post information, including identifiers, header data, post text, topics, footer data, and the total comment count.

LMPostWidgetTableViewCellProtocol

A protocol for handling user interaction with the cell, such as tapping on the post, a URL, a route.

UI Elements

  • contentStack: A vertical stack view for organizing the cell's content.
  • topicFeed: A custom view for displaying the topic of the post.
  • postText: A text view for displaying the post's text.

Data Variables

  • actionDelegate: An optional delegate conforming to LMPostWidgetTableViewCellProtocol for handling cell actions.
  • userUUID: An optional string representing the UUID of the user who made the post.
  • postID: An optional string representing the unique identifier of the post.

Action Handlers

  • tappedTextView(): Handles taps within the postText view, triggering actions based on the content tapped.

  • didTapURL(): Invokes the delegate's didTapURL(url:) method.

  • didTapRoute(): Invokes the delegate's didTapRoute(route:) method.

  • didTapPost(): Invokes the delegate's didTapPost(postID:) method when the cell itself is tapped.