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
1ba3f99b
Unverified
Commit
1ba3f99b
authored
Mar 21, 2023
by
Mitchell Goodwin
Committed by
GitHub
Mar 21, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Create cupertino checkbox (#122244)
Create cupertino checkbox
parent
8de2433a
Changes
4
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
1058 additions
and
0 deletions
+1058
-0
cupertino.dart
packages/flutter/lib/cupertino.dart
+1
-0
checkbox.dart
packages/flutter/lib/src/cupertino/checkbox.dart
+396
-0
toggleable.dart
packages/flutter/lib/src/cupertino/toggleable.dart
+247
-0
checkbox_test.dart
packages/flutter/test/cupertino/checkbox_test.dart
+414
-0
No files found.
packages/flutter/lib/cupertino.dart
View file @
1ba3f99b
...
@@ -27,6 +27,7 @@ export 'src/cupertino/adaptive_text_selection_toolbar.dart';
...
@@ -27,6 +27,7 @@ export 'src/cupertino/adaptive_text_selection_toolbar.dart';
export
'src/cupertino/app.dart'
;
export
'src/cupertino/app.dart'
;
export
'src/cupertino/bottom_tab_bar.dart'
;
export
'src/cupertino/bottom_tab_bar.dart'
;
export
'src/cupertino/button.dart'
;
export
'src/cupertino/button.dart'
;
export
'src/cupertino/checkbox.dart'
;
export
'src/cupertino/colors.dart'
;
export
'src/cupertino/colors.dart'
;
export
'src/cupertino/constants.dart'
;
export
'src/cupertino/constants.dart'
;
export
'src/cupertino/context_menu.dart'
;
export
'src/cupertino/context_menu.dart'
;
...
...
packages/flutter/lib/src/cupertino/checkbox.dart
0 → 100644
View file @
1ba3f99b
This diff is collapsed.
Click to expand it.
packages/flutter/lib/src/cupertino/toggleable.dart
0 → 100644
View file @
1ba3f99b
// Copyright 2014 The Flutter 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
'package:flutter/foundation.dart'
;
import
'package:flutter/rendering.dart'
;
import
'package:flutter/widgets.dart'
;
/// A mixin for [StatefulWidget]s that implements iOS-themed toggleable
/// controls (e.g.[CupertinoCheckbox]es).
///
/// This mixin implements the logic for toggling the control when tapped.
/// It does not have any opinion about the visual representation of the
/// toggleable widget. The visuals are defined by a [CustomPainter] passed to
/// the [buildToggleable]. [State] objects using this mixin should call that
/// method from their [build] method.
///
/// This mixin is used to implement the Cupertino components for
/// [CupertinoCheckbox] controls.
@optionalTypeArgs
mixin
ToggleableStateMixin
<
S
extends
StatefulWidget
>
on
TickerProviderStateMixin
<
S
>
{
/// Whether the [value] of this control can be changed by user interaction.
///
/// The control is considered interactive if the [onChanged] callback is
/// non-null. If the callback is null, then the control is disabled and
/// non-interactive. A disabled checkbox, for example, is displayed using a
/// grey color and its value cannot be changed.
bool
get
isInteractive
=>
onChanged
!=
null
;
/// Called when the control changes value.
///
/// If the control is tapped, [onChanged] is called immediately with the new
/// value.
///
/// The control is considered interactive (see [isInteractive]) if this
/// callback is non-null. If the callback is null, then the control is
/// disabled and non-interactive. A disabled checkbox, for example, is
/// displayed using a grey color and its value cannot be changed.
ValueChanged
<
bool
?>?
get
onChanged
;
/// The [value] accessor returns false if this control is "inactive" (not
/// checked, off, or unselected).
///
/// If [value] is true then the control "active" (checked, on, or selected). If
/// tristate is true and value is null, then the control is considered to be
/// in its third or "indeterminate" state..
bool
?
get
value
;
/// If true, [value] can be true, false, or null, otherwise [value] must
/// be true or false.
///
/// When [tristate] is true and [value] is null, then the control is
/// considered to be in its third or "indeterminate" state.
bool
get
tristate
;
/// The most recent [Offset] at which a pointer touched the Toggleable.
///
/// This is null if currently no pointer is touching the Toggleable or if
/// [isInteractive] is false.
Offset
?
get
downPosition
=>
_downPosition
;
Offset
?
_downPosition
;
void
_handleTapDown
(
TapDownDetails
details
)
{
if
(
isInteractive
)
{
setState
(()
{
_downPosition
=
details
.
localPosition
;
});
}
}
void
_handleTap
([
Intent
?
_
])
{
if
(!
isInteractive
)
{
return
;
}
switch
(
value
)
{
case
false
:
onChanged
!(
true
);
break
;
case
true
:
onChanged
!(
tristate
?
null
:
false
);
break
;
case
null
:
onChanged
!(
false
);
break
;
}
context
.
findRenderObject
()!.
sendSemanticsEvent
(
const
TapSemanticEvent
());
}
void
_handleTapEnd
([
TapUpDetails
?
_
])
{
if
(
_downPosition
!=
null
)
{
setState
(()
{
_downPosition
=
null
;
});
}
}
bool
_focused
=
false
;
void
_handleFocusHighlightChanged
(
bool
focused
)
{
if
(
focused
!=
_focused
)
{
setState
(()
{
_focused
=
focused
;
});
}
}
late
final
Map
<
Type
,
Action
<
Intent
>>
_actionMap
=
<
Type
,
Action
<
Intent
>>{
ActivateIntent:
CallbackAction
<
ActivateIntent
>(
onInvoke:
_handleTap
),
};
/// Typically wraps a `painter` that draws the actual visuals of the
/// Toggleable with logic to toggle it.
///
/// Consider providing a subclass of [ToggleablePainter] as a `painter`.
///
/// This method must be called from the [build] method of the [State] class
/// that uses this mixin. The returned [Widget] must be returned from the
/// build method - potentially after wrapping it in other widgets.
Widget
buildToggleable
({
FocusNode
?
focusNode
,
Function
(
bool
)?
onFocusChange
,
bool
autofocus
=
false
,
required
Size
size
,
required
CustomPainter
painter
,
})
{
return
FocusableActionDetector
(
focusNode:
focusNode
,
autofocus:
autofocus
,
onFocusChange:
onFocusChange
,
enabled:
isInteractive
,
actions:
_actionMap
,
onShowFocusHighlight:
_handleFocusHighlightChanged
,
child:
GestureDetector
(
excludeFromSemantics:
!
isInteractive
,
onTapDown:
isInteractive
?
_handleTapDown
:
null
,
onTap:
isInteractive
?
_handleTap
:
null
,
onTapUp:
isInteractive
?
_handleTapEnd
:
null
,
onTapCancel:
isInteractive
?
_handleTapEnd
:
null
,
child:
Semantics
(
enabled:
isInteractive
,
child:
CustomPaint
(
size:
size
,
painter:
painter
,
),
),
),
);
}
}
/// A base class for a [CustomPainter] that may be passed to
/// [ToggleableStateMixin.buildToggleable] to draw the visual representation of
/// a Toggleable.
///
/// Subclasses must implement the [paint] method to draw the actual visuals of
/// the Toggleable.
abstract
class
ToggleablePainter
extends
ChangeNotifier
implements
CustomPainter
{
/// The color that should be used in the active state (i.e., when
/// [ToggleableStateMixin.value] is true).
///
/// For example, a checkbox should use this color when checked.
Color
get
activeColor
=>
_activeColor
!;
Color
?
_activeColor
;
set
activeColor
(
Color
value
)
{
if
(
_activeColor
==
value
)
{
return
;
}
_activeColor
=
value
;
notifyListeners
();
}
/// The color that should be used in the inactive state (i.e., when
/// [ToggleableStateMixin.value] is false).
///
/// For example, a checkbox should use this color when unchecked.
Color
get
inactiveColor
=>
_inactiveColor
!;
Color
?
_inactiveColor
;
set
inactiveColor
(
Color
value
)
{
if
(
_inactiveColor
==
value
)
{
return
;
}
_inactiveColor
=
value
;
notifyListeners
();
}
/// The color that should be used for the reaction when [isFocused] is true.
///
/// Used when the toggleable needs to change the reaction color/transparency,
/// when it has focus.
Color
get
focusColor
=>
_focusColor
!;
Color
?
_focusColor
;
set
focusColor
(
Color
value
)
{
if
(
value
==
_focusColor
)
{
return
;
}
_focusColor
=
value
;
notifyListeners
();
}
/// The [Offset] within the Toggleable at which a pointer touched the Toggleable.
///
/// This is null if currently no pointer is touching the Toggleable.
///
/// Usually set to [ToggleableStateMixin.downPosition].
Offset
?
get
downPosition
=>
_downPosition
;
Offset
?
_downPosition
;
set
downPosition
(
Offset
?
value
)
{
if
(
value
==
_downPosition
)
{
return
;
}
_downPosition
=
value
;
notifyListeners
();
}
/// True if this toggleable has the input focus.
bool
get
isFocused
=>
_isFocused
!;
bool
?
_isFocused
;
set
isFocused
(
bool
?
value
)
{
if
(
value
==
_isFocused
)
{
return
;
}
_isFocused
=
value
;
notifyListeners
();
}
/// Determines whether the toggleable shows as active.
bool
get
isActive
=>
_isActive
!;
bool
?
_isActive
;
set
isActive
(
bool
?
value
)
{
if
(
value
==
_isActive
)
{
return
;
}
_isActive
=
value
;
notifyListeners
();
}
@override
bool
shouldRepaint
(
covariant
CustomPainter
oldDelegate
)
=>
true
;
@override
bool
?
hitTest
(
Offset
position
)
=>
null
;
@override
SemanticsBuilderCallback
?
get
semanticsBuilder
=>
null
;
@override
bool
shouldRebuildSemantics
(
covariant
CustomPainter
oldDelegate
)
=>
false
;
@override
String
toString
()
=>
describeIdentity
(
this
);
}
packages/flutter/test/cupertino/checkbox_test.dart
0 → 100644
View file @
1ba3f99b
This diff is collapsed.
Click to expand it.
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