reusable_editor 1.2.9 copy "reusable_editor: ^1.2.9" to clipboard
reusable_editor: ^1.2.9 copied to clipboard

A modular form and file editor package for Flutter with support for Form widgets. Includes Cubit-based state management, form field validation, and UI input widgets.

reusable_editor #

A flexible and modular file management and form handling package for Flutter, supporting both Firestore and REST API-based storage systems along with comprehensive form field management. This package includes file operations, form state management using Cubits, and a collection of reusable form field widgets.

Features #

  • Abstract interfaces for clean architecture
  • Cubits for managing form states (e.g., image, switch, dropdown, text field)
  • Complete set of reusable form field widgets
  • Extensions for asset loading as File and Uint8List
  • Enum-based dropdown with icon and label support

Getting Started #

Installation #

Add the following to your pubspec.yaml:

dependencies:
  reusable_editor: <latest_version>

Import #

import 'package:reusable_editor/reusable_editor.dart';

📘 Documentation #

Full usage guides available at: 👉 https://geniecodersrc.github.io/reusable_editor

Usage #

Form Field Management #

// Create cubit for a field
final textFieldCubit = TextFieldCubit(
  initialValue: 'Default',
  validator: RequiredValidator(),
);

// Use with AppTextField
AppTextField(cubit: textFieldCubit, label: 'Name');

// Toggle field example
final toggleCubit = ToggleCubit(initialValue: false);
AppSwitch(cubit: toggleCubit);

Available Form Widgets #

  • AppCheckbox - Checkbox with label and validation
  • AppDatePicker - Date selection field
  • AppDropdown - Custom dropdown field
  • AppFilePicker - File selection widget
  • AppRadioGroup - Radio button group
  • AppRangeSlider - Range slider input
  • AppSlider - Slider input
  • AppSwitch - Toggle switch
  • AppTimePicker - Time selection field
  • AppTextField - Text input field
enum FileSourceType { firebase, server }

final dropdown = EnumOptionDropDownMenuFormField<FileSourceType>(
  selectedValue: selectedOption,
  onChanged: (value) => print(value?.type),
  hint: 'Select file source',
  dropdownItems: [
    EnumOptionEntity(type: FileSourceType.firebase, icon: Icons.cloud, label: 'Firebase'),
    EnumOptionEntity(type: FileSourceType.server, icon: Icons.storage, label: 'Server'),
  ],
);

Load Asset as File #

final file = await 'assets/image.png'.loadAsFile();

Load Asset as Bytes #

final bytes = await 'assets/image.png'.loadAssetImage();

State Management Cubits #

  • FieldCubit<T> - Generic form field management with validation
  • ToggleCubit - Specialized cubit for boolean toggle fields
  • DateTimeCubit - Manages date selection
  • ImageCrudCubit - Handles image pick logic and validation
  • EnumOptionCubit<T> - Dropdown Selection with Generic enum
  • SwitchCubit - Toggle logic
  • TextFieldCubit - Text field validation

Contributions #

Feel free to open issues or pull requests.

License #

© MIT License. Developed with ❤️ by Shohidul Islam

0
likes
150
points
165
downloads

Publisher

unverified uploader

Weekly Downloads

A modular form and file editor package for Flutter with support for Form widgets. Includes Cubit-based state management, form field validation, and UI input widgets.

Homepage
Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

bloc, cross_file, dartz, equatable, file_picker, flutter, flutter_bloc, get_it_di_global_variable, i_validator, intl, path_provider, provider

More

Packages that depend on reusable_editor