mirror of
https://github.com/flutter/samples.git
synced 2025-11-09 22:38:42 +00:00
Dart 3.9 / Flutter 3.35 [first LLM release] (#2714)
I got carried away with Gemini and basically rewrote CI and the release process for the new LLM reality. This work was largely completed by Gemini. - Bump all SDK versions to the current beta (3.9.0-0) - Run `flutter channel beta` - Wrote `ci_script.dart` to replace the bash scripts - Converted repository to pub workspace #2499 - Added llm.md and release.md - Added redirect for deprecated Samples Index ## Pre-launch Checklist - [x] I read the [Flutter Style Guide] _recently_, and have followed its advice. - [x] I signed the [CLA]. - [x] I read the [Contributors Guide]. - [x] I have added sample code updates to the [changelog]. - [x] I updated/added relevant documentation (doc comments with `///`).
This commit is contained in:
@@ -244,18 +244,19 @@ class _ExampleState extends State<Example> {
|
||||
actions.add(FunctionResponse(fn.name, task.toJson()));
|
||||
break;
|
||||
case 'get_completed_tasks':
|
||||
var filter =
|
||||
current.toList().where((e) => e.completed == true).toList();
|
||||
var filter = current
|
||||
.toList()
|
||||
.where((e) => e.completed == true)
|
||||
.toList();
|
||||
final name = args['name'] as String?;
|
||||
final description = args['description'] as String?;
|
||||
if (name != null) {
|
||||
filter = filter.where((e) => e.name.contains(name)).toList();
|
||||
}
|
||||
if (description != null) {
|
||||
filter =
|
||||
filter
|
||||
.where((e) => e.description?.contains(description) ?? false)
|
||||
.toList();
|
||||
filter = filter
|
||||
.where((e) => e.description?.contains(description) ?? false)
|
||||
.toList();
|
||||
}
|
||||
actions.add(
|
||||
FunctionResponse(fn.name, {
|
||||
@@ -264,18 +265,19 @@ class _ExampleState extends State<Example> {
|
||||
);
|
||||
break;
|
||||
case 'get_active_tasks':
|
||||
var filter =
|
||||
current.toList().where((e) => e.completed == false).toList();
|
||||
var filter = current
|
||||
.toList()
|
||||
.where((e) => e.completed == false)
|
||||
.toList();
|
||||
final name = args['name'] as String?;
|
||||
final description = args['description'] as String?;
|
||||
if (name != null) {
|
||||
filter = filter.where((e) => e.name.contains(name)).toList();
|
||||
}
|
||||
if (description != null) {
|
||||
filter =
|
||||
filter
|
||||
.where((e) => e.description?.contains(description) ?? false)
|
||||
.toList();
|
||||
filter = filter
|
||||
.where((e) => e.description?.contains(description) ?? false)
|
||||
.toList();
|
||||
}
|
||||
actions.add(
|
||||
FunctionResponse(fn.name, {
|
||||
@@ -336,21 +338,20 @@ class _ExampleState extends State<Example> {
|
||||
final reversed = messages.value.reversed;
|
||||
return Scaffold(
|
||||
appBar: AppBar(title: Text(widget.title)),
|
||||
body:
|
||||
messages.value.isEmpty
|
||||
? const Center(child: Text('No tasks found'))
|
||||
: ListView.builder(
|
||||
padding: const EdgeInsets.all(8),
|
||||
reverse: true,
|
||||
itemCount: reversed.length,
|
||||
itemBuilder: (context, index) {
|
||||
final (sender, message) = reversed.elementAt(index);
|
||||
return MessageWidget(
|
||||
isFromUser: sender == Sender.user,
|
||||
text: message,
|
||||
);
|
||||
},
|
||||
),
|
||||
body: messages.value.isEmpty
|
||||
? const Center(child: Text('No tasks found'))
|
||||
: ListView.builder(
|
||||
padding: const EdgeInsets.all(8),
|
||||
reverse: true,
|
||||
itemCount: reversed.length,
|
||||
itemBuilder: (context, index) {
|
||||
final (sender, message) = reversed.elementAt(index);
|
||||
return MessageWidget(
|
||||
isFromUser: sender == Sender.user,
|
||||
text: message,
|
||||
);
|
||||
},
|
||||
),
|
||||
bottomNavigationBar: BottomAppBar(
|
||||
padding: const EdgeInsets.all(8),
|
||||
child: Row(
|
||||
|
||||
Reference in New Issue
Block a user