PermissionGate class

Shows child only when the current user holds permission; otherwise renders fallback (an empty box by default).

Requires a PermissionScope ancestor.

PermissionGate(
  permission: AppPermission.todoAdd,
  child: ElevatedButton(onPressed: ..., child: const Text('Add')),
);

🔒 This is a UI convenience, not a security boundary. Always keep your repository-level @Access guards — they are the real enforcement.

Inheritance

Constructors

PermissionGate({Key? key, required PermissionKey permission, required Widget child, Widget fallback = const SizedBox.shrink()})
const

Properties

child → Widget
The widget shown when the permission is granted.
final
fallback → Widget
The widget shown when the permission is missing. Defaults to an empty (zero-size) widget, effectively hiding child.
final
hashCode → int
The hash code for this object.
no setterinherited
key → Key?
Controls how one widget replaces another widget in the tree.
finalinherited
permission → PermissionKey
The permission required to render child.
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