flutter_modalselection 0.0.1-pre flutter_modalselection: ^0.0.1-pre copied to clipboard
Crea un modal con callback di selezione
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';
import 'package:flutter_modalselection/flutter_modalselection.dart';
import 'package:flutter_modalselection/modalSelectionElement.dart';
import 'package:flutter_modalselection/modalSelectionModal.dart';
void main() {
runApp(const MainApp());
}
/// Define the UI for the element in selection
class SimpleElement extends StatelessWidget {
String text;
Function(String)? onTapCallback;
SimpleElement({super.key, required this.text, this.onTapCallback});
void _processOnTap() {
if(onTapCallback != null) onTapCallback!(text);
}
@override
Widget build(BuildContext context) {
if(onTapCallback != null) return GestureDetector(
onTap: _processOnTap,
child: _SimpleElement(text: text)
);
return _SimpleElement(text: text);
}
}
class _SimpleElement extends StatelessWidget {
String text;
_SimpleElement({required this.text});
@override
Widget build(BuildContext context) {
return Card(
child: Padding(
padding: const EdgeInsets.all(20),
child: Row(children: [Expanded(child: Text(text))]
,),
),
);
}
}
/// Define the modal UI it must extends ModalSelection
class SelecteStringModal extends ModalSelectionModal<String> {
SelecteStringModal({required super.availableEntitis, required super.selectedCallback, super.selectedEntity});
/// Define the build method like this
@override
Widget build(BuildContext context) {
void manageCallback(String? s) {
selectedCallback(s);
Navigator.of(context).pop();
}
return Container(
padding: const EdgeInsets.all(25),
height: MediaQuery.of(context).copyWith().size.height,
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.start,
children: [
/// Definisce il titolo del modal
Text("Seleziona elemento")
],
),
const SizedBox(height: 10),
Expanded(
child: ListView.builder(
itemCount: availableEntitis.length,
itemBuilder: (context, index) => SimpleElement(
onTapCallback: manageCallback,
/// Access the possibile entities using the property of ModalSelectionWidget
text: availableEntitis[index],
)
),
),
],
)
);
}
}
class MainAppUI extends StatefulWidget {
const MainAppUI({super.key});
@override
State<MainAppUI> createState() => _MainAppUIState();
}
class _MainAppUIState extends State<MainAppUI> {
/// Current element selected
String selectedText = "Seleziona un elemento";
/// List of selection
List<String> avbTexts = ["Testo 1", "Testo2", "Testo3"];
/// On selection callback
void onSelection(String? s) {
setState(() {
selectedText = s ?? "";
});
}
@override
Widget build(BuildContext context) {
return SafeArea(child: Padding(padding: const EdgeInsets.all(20),
child: ModalSelection<String>(
availableEntitis: avbTexts,
selectionCallback: onSelection,
selectedEntity: selectedText,
modalContent: SelecteStringModal(availableEntitis: avbTexts, selectedCallback: onSelection, selectedEntity: selectedText),
selectElement: ModalSelectionElement<String>(entity: selectedText, displayElement: SimpleElement(text: selectedText)),
),
));
}
}
class MainApp extends StatelessWidget {
const MainApp({super.key});
@override
Widget build(BuildContext context) {
return const MaterialApp(
home: Scaffold(
body: MainAppUI()
),
);
}
}