RequestsModal class

Requests modal displaying participant permission requests (screenshare/video/audio) with grant/deny actions (host-only).

  • Displays scrollable list of Request objects from requestList.
  • Header shows "Requests" title with counter badge (requestCounter).
  • Search input filters list by participant name via onRequestFilterChange.
  • Each request row shows participant name, icon (FontAwesome icon from request.icon like 'fa-microphone', 'fa-video', 'fa-desktop'), and "Accept" (green checkmark) / "Reject" (red X) icon buttons.
  • "Accept" calls onRequestItemPress with action: 'accepted', which emits updateRequestAction socket event with {requestId, action: 'accepted', roomName}, then removes request from requestList via updateRequestList.
  • "Reject" calls onRequestItemPress with action: 'rejected', emitting updateRequestAction event with action: 'rejected', then removes from queue.
  • Empty state shows "No requests" when list is empty.
  • Positions via getModalPosition using options.position.
  • Request items rendered via renderRequestComponent (defaults to RenderRequestComponent widget); can be overridden for custom rendering.

Override via MediasfuUICustomOverrides.requestsModal to inject custom approval workflows, analytics tracking, or automated policies.

Workflow:

  1. Visibility: The isRequestsModalVisible controls whether the modal is shown.
  2. Filtering: Text input filters requests via onRequestFilterChange.
  3. Request List: Each request is rendered using renderRequestComponent, which supports custom UI.
Inheritance

Constructors

RequestsModal({Key? key, required RequestsModalOptions options})
const

Properties

hashCode int
The hash code for this object.
no setterinherited
key Key?
Controls how one widget replaces another widget in the tree.
finalinherited
options RequestsModalOptions
final
runtimeType Type
A representation of the runtime type of the object.
no setterinherited

Methods

build(BuildContext context) Widget
Describes the part of the user interface represented by this widget.
override
createElement() StatelessElement
Creates a StatelessElement to manage this widget's location in the tree.
inherited
debugDescribeChildren() List<DiagnosticsNode>
Returns a list of DiagnosticsNode objects describing this node's children.
inherited
debugFillProperties(DiagnosticPropertiesBuilder properties) → void
Add additional properties associated with the node.
inherited
noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
toDiagnosticsNode({String? name, DiagnosticsTreeStyle? style}) DiagnosticsNode
Returns a debug representation of the object that is used by debugging tools and by DiagnosticsNode.toStringDeep.
inherited
toString({DiagnosticLevel minLevel = DiagnosticLevel.info}) String
A string representation of this object.
inherited
toStringDeep({String prefixLineOne = '', String? prefixOtherLines, DiagnosticLevel minLevel = DiagnosticLevel.debug, int wrapWidth = 65}) String
Returns a string representation of this node and its descendants.
inherited
toStringShallow({String joiner = ', ', DiagnosticLevel minLevel = DiagnosticLevel.debug}) String
Returns a one-line detailed description of the object.
inherited
toStringShort() String
A short, textual description of this widget.
inherited

Operators

operator ==(Object other) bool
The equality operator.
inherited