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

Your Complete Guide to CISM Certification Training

The CISM Certification Training prepares professionals to manage, design, and oversee enterprise information security programs. Offered by ISACA, this leadership-focused credential covers governance, risk management, program development, and incident…

Complete Guide to CISA Certification Training Courses

The CISA Certification Training Course equips professionals with skills to audit, control, and secure enterprise IT systems. Offered by ISACA, this globally recognized credential covers information systems auditing from…

Your Guide to Certified Kubernetes Security Specialist Success

The Certified Kubernetes Security Specialist (CKS) Certification Training Course prepares IT pros to protect Kubernetes environments from threats. This advanced credential from CNCF and the Linux Foundation proves hands-on…

Your Guide to Certified Kubernetes Application Developer Success

The Certified Kubernetes Application Developer (CKAD) certification equips developers with hands-on skills to build and deploy cloud-native apps on Kubernetes. This credential stands out in today’s job market by…

Your Complete Guide to Becoming a Certified Kubernetes Administrator

The Certified Kubernetes Administrator (CKA) Certification Training Course teaches you to manage Kubernetes clusters like a pro. Kubernetes handles containers across many servers. It keeps apps running smoothly at…

Your Complete Guide to Becoming a Certified Jenkins Engineer

The Certified Jenkins Engineer program gives you hands-on skills to build and manage CI/CD pipelines. Jenkins, the popular open-source tool, automates testing and deployment, helping teams deliver code faster…

0 0 votes
Article Rating
Subscribe
Notify of
guest
0 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
0
Would love your thoughts, please comment.x
()
x