forked from flutter/plugins
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Switch
: Add an interactive example (#103045)
* `Switch`: Add an interactive examples * Update docs * Update doc
- Loading branch information
1 parent
680a819
commit 97452d1
Showing
5 changed files
with
197 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
// 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. | ||
|
||
// Flutter code sample for Switch | ||
|
||
import 'package:flutter/material.dart'; | ||
|
||
void main() => runApp(const SwitchApp()); | ||
|
||
class SwitchApp extends StatelessWidget { | ||
const SwitchApp({super.key}); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return MaterialApp( | ||
home: Scaffold( | ||
appBar: AppBar(title: const Text('Switch Sample')), | ||
body: const Center( | ||
child: SwitchExample(), | ||
), | ||
), | ||
); | ||
} | ||
} | ||
|
||
class SwitchExample extends StatefulWidget { | ||
const SwitchExample({super.key}); | ||
|
||
@override | ||
State<SwitchExample> createState() => _SwitchExampleState(); | ||
} | ||
|
||
class _SwitchExampleState extends State<SwitchExample> { | ||
bool light = true; | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return Switch( | ||
// This bool value toggles the switch. | ||
value: light, | ||
activeColor: Colors.red, | ||
onChanged: (bool value) { | ||
// This is called when the user toggles the switch. | ||
setState(() { | ||
light = value; | ||
}); | ||
}, | ||
); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
// 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. | ||
|
||
// Flutter code sample for Switch | ||
|
||
import 'package:flutter/material.dart'; | ||
|
||
void main() => runApp(const SwitchApp()); | ||
|
||
class SwitchApp extends StatelessWidget { | ||
const SwitchApp({super.key}); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return MaterialApp( | ||
home: Scaffold( | ||
appBar: AppBar(title: const Text('Switch Sample')), | ||
body: const Center( | ||
child: SwitchExample(), | ||
), | ||
), | ||
); | ||
} | ||
} | ||
|
||
class SwitchExample extends StatefulWidget { | ||
const SwitchExample({super.key}); | ||
|
||
@override | ||
State<SwitchExample> createState() => _SwitchExampleState(); | ||
} | ||
|
||
class _SwitchExampleState extends State<SwitchExample> { | ||
bool light = true; | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
final MaterialStateProperty<Color?> trackColor = MaterialStateProperty.resolveWith<Color?>( | ||
(Set<MaterialState> states) { | ||
// Track color when the switch is selected. | ||
if (states.contains(MaterialState.selected)) { | ||
return Colors.amber; | ||
} | ||
// Otherwise return null to set default track color | ||
// for remaining states such as when the switch is | ||
// hovered, focused, or disabled. | ||
return null; | ||
}, | ||
); | ||
final MaterialStateProperty<Color?> overlayColor = MaterialStateProperty.resolveWith<Color?>( | ||
(Set<MaterialState> states) { | ||
// Material color when switch is selected. | ||
if (states.contains(MaterialState.selected)) { | ||
return Colors.amber.withOpacity(0.54); | ||
} | ||
// Material color when switch is disabled. | ||
if (states.contains(MaterialState.disabled)) { | ||
return Colors.grey.shade400; | ||
} | ||
// Otherwise return null to set default material color | ||
// for remaining states such as when the switch is | ||
// hovered, or focused. | ||
return null; | ||
}, | ||
); | ||
|
||
return Switch( | ||
// This bool value toggles the switch. | ||
value: light, | ||
overlayColor: overlayColor, | ||
trackColor: trackColor, | ||
thumbColor: MaterialStateProperty.all<Color>(Colors.black), | ||
onChanged: (bool value) { | ||
// This is called when the user toggles the switch. | ||
setState(() { | ||
light = value; | ||
}); | ||
}, | ||
); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
// 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/material.dart'; | ||
import 'package:flutter_api_samples/material/switch/switch.0.dart' as example; | ||
import 'package:flutter_test/flutter_test.dart'; | ||
|
||
void main() { | ||
testWidgets('Can toggle switch', (WidgetTester tester) async { | ||
await tester.pumpWidget( | ||
const example.SwitchApp(), | ||
); | ||
|
||
final Finder switchFinder = find.byType(Switch); | ||
Switch materialSwitch = tester.widget<Switch>(switchFinder); | ||
expect(materialSwitch.value, true); | ||
|
||
await tester.tap(switchFinder); | ||
await tester.pumpAndSettle(); | ||
materialSwitch = tester.widget<Switch>(switchFinder); | ||
expect(materialSwitch.value, false); | ||
}); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
// 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/material.dart'; | ||
import 'package:flutter_api_samples/material/switch/switch.0.dart' as example; | ||
import 'package:flutter_test/flutter_test.dart'; | ||
|
||
void main() { | ||
testWidgets('Can toggle switch', (WidgetTester tester) async { | ||
await tester.pumpWidget( | ||
const example.SwitchApp(), | ||
); | ||
|
||
final Finder switchFinder = find.byType(Switch); | ||
Switch materialSwitch = tester.widget<Switch>(switchFinder); | ||
expect(materialSwitch.value, true); | ||
|
||
await tester.tap(switchFinder); | ||
await tester.pumpAndSettle(); | ||
materialSwitch = tester.widget<Switch>(switchFinder); | ||
expect(materialSwitch.value, false); | ||
}); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters