MOTOSHARE ๐Ÿš—๐Ÿ๏ธ
Turning Idle Vehicles into Shared Rides & Earnings

From Idle to Income. From Parked to Purpose.
Earn by Sharing, Ride by Renting.
Where Owners Earn, Riders Move.
Owners Earn. Riders Move. Motoshare Connects.

With Motoshare, every parked vehicle finds a purpose. Owners earn. Renters ride.
๐Ÿš€ Everyone wins.

Start Your Journey with Motoshare

Building Elegant Multiple Select Dropdown Lists in Flutter

Selecting multiple options from a dropdown list is a common requirement in Flutter app development. While plugins like flutter_custom_selector can simplify the process, let’s explore how to create a beautiful multiple select dropdown list without relying on external plugins. In your Flutter project, you might need a dropdown list that allows users to select multiple languages. Let’s enhance your existing code and provide a more elegant solution.

import 'package:flutter/material.dart';

class MultipleSelectDropdown extends StatefulWidget {
  const MultipleSelectDropdown({Key? key}) : super(key: key);

  @override
  State<MultipleSelectDropdown> createState() => _MultipleSelectDropdownState();
}

class _MultipleSelectDropdownState extends State<MultipleSelectDropdown> {
  List<String> availableLanguages = [
    "Chinese",
    "Spanish",
    "Hindi",
    "Arabic",
    "Bengali",
    "Portuguese",
    "Russian",
    "Japanese",
    "Indonesian",
    "Sinhala",
    "Tamil",
    "Mandarin",
    "Thai",
  ];

  List<String> selectedLanguages = [];

  @override
  Widget build(BuildContext context) {
    double width = MediaQuery.of(context).size.width;
    return Container(
      width: width * 0.8,
      child: Column(
        crossAxisAlignment: CrossAxisAlignment.start,
        children: [
          Text(
            'Select Your Languages',
            style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold),
          ),
          SizedBox(height: 10),
          Container(
            padding: EdgeInsets.all(10),
            decoration: BoxDecoration(
              border: Border.all(color: Colors.grey),
              borderRadius: BorderRadius.circular(8),
            ),
            child: DropdownButtonHideUnderline(
              child: DropdownButton<String>(
                isExpanded: true,
                value: selectedLanguages.isEmpty
                    ? null
                    : selectedLanguages.join(', '),
                hint: Text('Choose Languages'),
                items: availableLanguages.map((String language) {
                  return DropdownMenuItem<String>(
                    value: language,
                    child: Text(language),
                  );
                }).toList(),
                onChanged: (String? value) {
                  setState(() {
                    if (value != null) {
                      if (selectedLanguages.contains(value)) {
                        selectedLanguages.remove(value);
                      } else {
                        selectedLanguages.add(value);
                      }
                    }
                  });
                },
              ),
            ),
          ),
          SizedBox(height: 10),
          Text(
            'Selected Languages: ${selectedLanguages.join(', ')}',
            style: TextStyle(fontSize: 16),
          ),
        ],
      ),
    );
  }
}

Dropdown UI Enhancement:

We’ve wrapped the dropdown in a container for a cleaner look.

Added styling to the dropdown container for better aesthetics.

Multi-Select Functionality:

Modified the dropdown to allow multiple selections.

Display selected languages dynamically below the dropdown.

Improved User Experience:

Included a hint in the dropdown for better user guidance.

Removed the unnecessary Padding and Column in the original code.

Related Posts

DevOps Real-World Examples for Beginners and Cloud Aspirants

Introduction Learning DevOps often feels abstract to beginners. When you start your learning journey, you are frequently bombarded with complex terms, architectural diagrams, and an endless list…

Read More

DevOps Career Roadmap for Beginners A Complete Guide

Introduction Entering the world of DevOps is one of the most rewarding decisions you can make in the modern technology landscape. However, the sheer volume of tools,…

Read More

DevOps vs Traditional IT Operations: A Practical Comparison

Introduction The way we build, ship, and manage software has undergone a fundamental transformation over the last two decades. In the early 2000s, IT infrastructure was a…

Read More

DevOps Salary and Career Growth: The Master Report

DevOps has cemented its position as one of the most critical and highest-paying domains in the IT landscape. As organizations shift toward cloud-native architectures, the reliance on…

Read More

DevOps Certification Roadmap for Building a Strong Engineering Career

Introduction Navigating the world of DevOps certifications can feel completely overwhelming. With hundreds of badges, certificates, and tool-based credentials available, engineering professionals often struggle to figure out…

Read More

The Essential Guide to Building Robust Continuous Delivery Pipelines

Introduction In the early days of software development, releasing a new feature was often a high-stakes, stressful event. Teams would spend weeks writing code, followed by days…

Read More
0 0 votes
Article Rating
Subscribe
Notify of
guest
9 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter Android development issues, Android […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter API Requests, Error Handling, […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter Backup and Restore, Configuration […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter Automation, Compliance, continuous […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter Automation, Business Growth, CI/CD, […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter Agile Development, Automated […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter Agile IT, Automation, Business […]

trackback

[…] ‘type ‘Null’ is not a subtype of type ‘String’ Errors Building Elegant Multiple Select Dropdown Lists in Flutter PlatformException: read_external_storage_denied in Flutter automation in SRE, DevOps, DevOps […]

9
0
Would love your thoughts, please comment.x
()
x