flutter_modalselection 0.0.1-pre copy "flutter_modalselection: ^0.0.1-pre" to clipboard
flutter_modalselection: ^0.0.1-pre copied to clipboard

Crea un modal con callback di selezione

example/lib/main.dart

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()
      ),
    );
  }
}
1
likes
130
points
17
downloads

Publisher

unverified uploader

Weekly Downloads

Crea un modal con callback di selezione

Homepage
Repository (GitHub)
View/report issues

Documentation

API reference

License

unknown (license)

Dependencies

flutter, modal_bottom_sheet

More

Packages that depend on flutter_modalselection