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
87107494
Commit
87107494
authored
Sep 23, 2015
by
Adam Barth
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Port DragTarget to fn3
parent
ec92aca8
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
147 additions
and
1 deletion
+147
-1
basic.dart
packages/flutter/lib/src/fn3/basic.dart
+13
-0
drag_target.dart
packages/flutter/lib/src/fn3/drag_target.dart
+125
-0
proxy_box.dart
packages/flutter/lib/src/rendering/proxy_box.dart
+9
-1
No files found.
packages/flutter/lib/src/fn3/basic.dart
View file @
87107494
...
...
@@ -870,3 +870,16 @@ class IgnorePointer extends OneChildRenderObjectWidget {
renderObject
.
ignoring
=
ignoring
;
}
}
class
MetaData
extends
OneChildRenderObjectWidget
{
MetaData
({
Key
key
,
Widget
child
,
this
.
metaData
})
:
super
(
key:
key
,
child:
child
);
final
dynamic
metaData
;
RenderMetaData
createRenderObject
()
=>
new
RenderMetaData
(
metaData:
metaData
);
void
updateRenderObject
(
RenderMetaData
renderObject
,
MetaData
oldWidget
)
{
renderObject
.
metaData
=
metaData
;
}
}
packages/flutter/lib/src/fn3/drag_target.dart
0 → 100644
View file @
87107494
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import
'dart:collection'
;
import
'package:sky/rendering.dart'
;
import
'package:sky/src/fn3/basic.dart'
;
import
'package:sky/src/fn3/binding.dart'
;
import
'package:sky/src/fn3/framework.dart'
;
typedef
bool
DragTargetWillAccept
<
T
>(
T
data
);
typedef
void
DragTargetAccept
<
T
>(
T
data
);
typedef
Widget
DragTargetBuilder
<
T
>(
BuildContext
context
,
List
<
T
>
candidateData
,
List
<
dynamic
>
rejectedData
);
class
DragTarget
<
T
>
extends
StatefulComponent
{
const
DragTarget
({
Key
key
,
this
.
builder
,
this
.
onWillAccept
,
this
.
onAccept
})
:
super
(
key:
key
);
final
DragTargetBuilder
<
T
>
builder
;
final
DragTargetWillAccept
<
T
>
onWillAccept
;
final
DragTargetAccept
<
T
>
onAccept
;
DragTargetState
<
T
>
createState
()
=>
new
DragTargetState
<
T
>(
this
);
}
class
DragTargetState
<
T
>
extends
ComponentState
<
DragTarget
<
T
>>
{
DragTargetState
(
DragTarget
<
T
>
config
)
:
super
(
config
);
final
List
<
T
>
_candidateData
=
new
List
<
T
>();
final
List
<
dynamic
>
_rejectedData
=
new
List
<
dynamic
>();
bool
didEnter
(
dynamic
data
)
{
assert
(!
_candidateData
.
contains
(
data
));
assert
(!
_rejectedData
.
contains
(
data
));
if
(
data
is
T
&&
(
config
.
onWillAccept
==
null
||
config
.
onWillAccept
(
data
)))
{
setState
(()
{
_candidateData
.
add
(
data
);
});
return
true
;
}
_rejectedData
.
add
(
data
);
return
false
;
}
void
didLeave
(
dynamic
data
)
{
assert
(
_candidateData
.
contains
(
data
)
||
_rejectedData
.
contains
(
data
));
setState
(()
{
_candidateData
.
remove
(
data
);
_rejectedData
.
remove
(
data
);
});
}
void
didDrop
(
dynamic
data
)
{
assert
(
_candidateData
.
contains
(
data
));
setState
(()
{
_candidateData
.
remove
(
data
);
});
if
(
config
.
onAccept
!=
null
)
config
.
onAccept
(
data
);
}
Widget
build
(
BuildContext
context
)
{
return
new
MetaData
(
metaData:
this
,
child:
config
.
builder
(
context
,
new
UnmodifiableListView
<
T
>(
_candidateData
),
new
UnmodifiableListView
<
dynamic
>(
_rejectedData
))
);
}
}
class
DragController
{
DragController
(
this
.
data
);
final
dynamic
data
;
DragTargetState
_activeTarget
;
bool
_activeTargetWillAcceptDrop
=
false
;
DragTargetState
_getDragTarget
(
List
<
HitTestEntry
>
path
)
{
// TODO(abarth): Why to we reverse the path here?
for
(
HitTestEntry
entry
in
path
.
reversed
)
{
if
(
entry
.
target
is
RenderMetaData
)
{
RenderMetaData
renderMetaData
=
entry
.
target
;
if
(
renderMetaData
.
metaData
is
DragTargetState
)
return
renderMetaData
.
metaData
;
}
}
return
null
;
}
void
update
(
Point
globalPosition
)
{
HitTestResult
result
=
WidgetFlutterBinding
.
instance
.
hitTest
(
globalPosition
);
DragTargetState
target
=
_getDragTarget
(
result
.
path
);
if
(
target
==
_activeTarget
)
return
;
if
(
_activeTarget
!=
null
)
_activeTarget
.
didLeave
(
data
);
_activeTarget
=
target
;
_activeTargetWillAcceptDrop
=
_activeTarget
!=
null
&&
_activeTarget
.
didEnter
(
data
);
}
void
cancel
()
{
if
(
_activeTarget
!=
null
)
_activeTarget
.
didLeave
(
data
);
_activeTarget
=
null
;
_activeTargetWillAcceptDrop
=
false
;
}
void
drop
()
{
if
(
_activeTarget
==
null
)
return
;
if
(
_activeTargetWillAcceptDrop
)
_activeTarget
.
didDrop
(
data
);
else
_activeTarget
.
didLeave
(
data
);
_activeTarget
=
null
;
_activeTargetWillAcceptDrop
=
false
;
}
}
packages/flutter/lib/src/rendering/proxy_box.dart
View file @
87107494
...
...
@@ -850,7 +850,7 @@ class RenderPointerListener extends RenderProxyBox {
/// as usual. It just cannot be the target of located events because it returns
/// false from [hitTest].
class
RenderIgnorePointer
extends
RenderProxyBox
{
RenderIgnorePointer
({
RenderBox
child
,
bool
ignoring:
true
})
:
super
(
child
);
RenderIgnorePointer
({
RenderBox
child
,
this
.
ignoring
:
true
})
:
super
(
child
);
bool
ignoring
;
...
...
@@ -858,3 +858,11 @@ class RenderIgnorePointer extends RenderProxyBox {
return
ignoring
?
false
:
super
.
hitTest
(
result
,
position:
position
);
}
}
/// Holds opaque meta data in the render tree
class
RenderMetaData
extends
RenderProxyBox
{
RenderMetaData
({
RenderBox
child
,
this
.
metaData
})
:
super
(
child
);
/// Opaque meta data ignored by the render tree
dynamic
metaData
;
}
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