Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
36767d01
Unverified
Commit
36767d01
authored
Apr 21, 2020
by
Greg Spencer
Committed by
GitHub
Apr 21, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make Action.enabled be isEnabled(Intent intent) instead. (#55230)
parent
8ee26efb
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
31 additions
and
49 deletions
+31
-49
actions.dart
dev/manual_tests/lib/actions.dart
+2
-2
actions.dart
packages/flutter/lib/src/widgets/actions.dart
+22
-42
scrollable.dart
packages/flutter/lib/src/widgets/scrollable.dart
+1
-1
actions_test.dart
packages/flutter/test/widgets/actions_test.dart
+6
-4
No files found.
dev/manual_tests/lib/actions.dart
View file @
36767d01
...
...
@@ -193,7 +193,7 @@ class UndoIntent extends Intent {
class
UndoAction
extends
Action
<
UndoIntent
>
{
@override
bool
get
enabled
{
bool
isEnabled
(
UndoIntent
intent
)
{
final
UndoableActionDispatcher
manager
=
Actions
.
of
(
primaryFocus
?.
context
??
FocusDemo
.
appKey
.
currentContext
,
nullOk:
true
)
as
UndoableActionDispatcher
;
return
manager
.
canUndo
;
}
...
...
@@ -211,7 +211,7 @@ class RedoIntent extends Intent {
class
RedoAction
extends
Action
<
RedoIntent
>
{
@override
bool
get
enabled
{
bool
isEnabled
(
RedoIntent
intent
)
{
final
UndoableActionDispatcher
manager
=
Actions
.
of
(
primaryFocus
.
context
,
nullOk:
true
)
as
UndoableActionDispatcher
;
return
manager
.
canRedo
;
}
...
...
packages/flutter/lib/src/widgets/actions.dart
View file @
36767d01
...
...
@@ -82,7 +82,7 @@ abstract class Action<T extends Intent> with Diagnosticable {
///
/// If the enabled state changes, overriding subclasses must call
/// [notifyActionListeners] to notify any listeners of the change.
bool
get
enabled
=>
true
;
bool
isEnabled
(
covariant
T
intent
)
=>
true
;
/// Called when the action is to be performed.
///
...
...
@@ -379,7 +379,7 @@ class ActionDispatcher with Diagnosticable {
assert
(
action
!=
null
);
assert
(
intent
!=
null
);
context
??=
primaryFocus
?.
context
;
if
(
action
.
enabled
)
{
if
(
action
.
isEnabled
(
intent
)
)
{
if
(
action
is
ContextAction
)
{
return
action
.
invoke
(
intent
,
context
);
}
else
{
...
...
@@ -486,7 +486,7 @@ class Actions extends StatefulWidget {
/// updated action.
static
VoidCallback
handler
<
T
extends
Intent
>(
BuildContext
context
,
T
intent
,
{
bool
nullOk
=
false
})
{
final
Action
<
T
>
action
=
Actions
.
find
<
T
>(
context
,
nullOk:
nullOk
);
if
(
action
!=
null
&&
action
.
enabled
)
{
if
(
action
!=
null
&&
action
.
isEnabled
(
intent
)
)
{
return
()
{
Actions
.
of
(
context
).
invokeAction
(
action
,
intent
,
context
);
};
...
...
@@ -635,12 +635,10 @@ class Actions extends StatefulWidget {
}
class
_ActionsState
extends
State
<
Actions
>
{
// Keeps the last-known enabled state of each action in the action map in
// order to be able to appropriately notify dependents that the state has
// changed.
Map
<
Action
<
Intent
>,
bool
>
enabledState
=
<
Action
<
Intent
>,
bool
>{};
// Used to tell the marker to rebuild when the enabled state of an action in
// the map changes.
// The set of actions that this Actions widget is current listening to.
Set
<
Action
<
Intent
>>
listenedActions
=
<
Action
<
Intent
>>{};
// Used to tell the marker to rebuild its dependencies when the state of an
// action in the map changes.
Object
rebuildKey
=
Object
();
@override
...
...
@@ -650,42 +648,24 @@ class _ActionsState extends State<Actions> {
}
void
_handleActionChanged
(
Action
<
Intent
>
action
)
{
assert
(
enabledState
.
containsKey
(
action
));
final
bool
actionEnabled
=
action
.
enabled
;
if
(
enabledState
[
action
]
==
null
||
enabledState
[
action
]
!=
actionEnabled
)
{
setState
(()
{
enabledState
[
action
]
=
actionEnabled
;
// Generate a new key so that the marker notifies dependents.
setState
(()
{
rebuildKey
=
Object
();
});
}
}
void
_updateActionListeners
()
{
final
Map
<
Action
<
Intent
>,
bool
>
newState
=
<
Action
<
Intent
>,
bool
>{};
final
Set
<
Action
<
Intent
>>
foundActions
=
<
Action
<
Intent
>>{};
for
(
final
Action
<
Intent
>
action
in
widget
.
actions
.
values
)
{
if
(
enabledState
.
containsKey
(
action
))
{
// Already subscribed to this action, just copy over the current enabled state.
newState
[
action
]
=
enabledState
[
action
];
foundActions
.
add
(
action
);
}
else
{
// New action to subscribe to.
// Don't set the new state to action.enabled, since that can cause
// problems when the enabled accessor looks up other widgets (which may
// have already been removed from the tree).
newState
[
action
]
=
null
;
action
.
addActionListener
(
_handleActionChanged
);
}
}
// Unregister from any actions in the previous enabledState map that aren't
// going to be transferred to the new one.
for
(
final
Action
<
Intent
>
action
in
enabledState
.
keys
)
{
if
(!
foundActions
.
contains
(
action
))
{
final
Set
<
Action
<
Intent
>>
widgetActions
=
widget
.
actions
.
values
.
toSet
();
final
Set
<
Action
<
Intent
>>
removedActions
=
listenedActions
.
difference
(
widgetActions
);
final
Set
<
Action
<
Intent
>>
addedActions
=
widgetActions
.
difference
(
listenedActions
);
for
(
final
Action
<
Intent
>
action
in
removedActions
)
{
action
.
removeActionListener
(
_handleActionChanged
);
}
for
(
final
Action
<
Intent
>
action
in
addedActions
)
{
action
.
addActionListener
(
_handleActionChanged
);
}
enabledState
=
newState
;
listenedActions
=
widgetActions
;
}
@override
...
...
@@ -697,10 +677,10 @@ class _ActionsState extends State<Actions> {
@override
void
dispose
()
{
super
.
dispose
();
for
(
final
Action
<
Intent
>
action
in
enabledState
.
key
s
)
{
for
(
final
Action
<
Intent
>
action
in
listenedAction
s
)
{
action
.
removeActionListener
(
_handleActionChanged
);
}
enabledState
=
null
;
listenedActions
=
null
;
}
@override
...
...
packages/flutter/lib/src/widgets/scrollable.dart
View file @
36767d01
...
...
@@ -911,7 +911,7 @@ class ScrollAction extends Action<ScrollIntent> {
static
const
LocalKey
key
=
ValueKey
<
Type
>(
ScrollAction
);
@override
bool
get
enabled
{
bool
isEnabled
(
ScrollIntent
intent
)
{
final
FocusNode
focus
=
primaryFocus
;
return
focus
!=
null
&&
focus
.
context
!=
null
&&
Scrollable
.
of
(
focus
.
context
)
!=
null
;
}
...
...
packages/flutter/test/widgets/actions_test.dart
View file @
36767d01
...
...
@@ -30,6 +30,8 @@ class TestAction extends CallbackAction<TestIntent> {
super
(
onInvoke:
onInvoke
);
@override
bool
isEnabled
(
TestIntent
intent
)
=>
enabled
;
bool
get
enabled
=>
_enabled
;
bool
_enabled
=
true
;
set
enabled
(
bool
value
)
{
...
...
@@ -412,17 +414,17 @@ void main() {
},
);
bool
enabled1
=
true
;
action1
.
addActionListener
((
Action
<
Intent
>
action
)
=>
enabled1
=
action
.
enabled
);
action1
.
addActionListener
((
Action
<
Intent
>
action
)
=>
enabled1
=
action
.
isEnabled
(
const
TestIntent
())
);
action1
.
enabled
=
false
;
expect
(
enabled1
,
isFalse
);
bool
enabled2
=
true
;
action2
.
addActionListener
((
Action
<
Intent
>
action
)
=>
enabled2
=
action
.
enabled
);
action2
.
addActionListener
((
Action
<
Intent
>
action
)
=>
enabled2
=
action
.
isEnabled
(
const
SecondTestIntent
())
);
action2
.
enabled
=
false
;
expect
(
enabled2
,
isFalse
);
bool
enabled3
=
true
;
action3
.
addActionListener
((
Action
<
Intent
>
action
)
=>
enabled3
=
action
.
enabled
);
action3
.
addActionListener
((
Action
<
Intent
>
action
)
=>
enabled3
=
action
.
isEnabled
(
const
ThirdTestIntent
())
);
action3
.
enabled
=
false
;
expect
(
enabled3
,
isFalse
);
...
...
@@ -466,7 +468,7 @@ void main() {
SecondTestIntent:
action2
,
},
child:
ActionListener
(
listener:
(
Action
<
Intent
>
action
)
=>
enabledChanged
=
action
.
enabled
,
listener:
(
Action
<
Intent
>
action
)
=>
enabledChanged
=
action
.
isEnabled
(
const
ThirdTestIntent
())
,
action:
action2
,
child:
Actions
(
actions:
<
Type
,
Action
<
Intent
>>{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment