zenity 1.0.1

zenity #

Desktop UI library to show simple dialog boxes and forms. Uses Zenity under-the-hood.

The following dialogs are supported:

  • Message
    • Info
    • Error
    • Question
    • Warning
  • Form with following fields
    • Text
    • Int
    • Double
    • Num
    • Password
    • DateTime
  • File selection
  • Password
  • Username:Password

Examples #

Forms #

main() async {
  final FormResult result =
  await new Form(title: 'Form example', name: 'User info', fields: [
    new TextField('First name:'),
    new TextField('Last name:'),
    new PasswordField('Password'),
    new CalendarField('DoB')
  ]).read;
  print(result);
}

Returns the form values are result:

{First name:: Teja, Last name:: Gudapati, Password: 1234as, DoB: 2017-12-11 00:00:00.000}

Form dialog

Message #

Info #

main() async {
  await Zenity.showInfoMessage(
      title: 'Information',
      text: 'Dialogs for Dart!');
}

Info message dialog

Question #

main() async {
  final bool reply = await Zenity.showQuestionMessage(
      title: 'Question', text: 'Dialogs for Dart!');
  print(reply);
}

Question message dialog

Warning #

main() async {
  await Zenity.showWarningMessage(title: 'Warning', text: 'Dialogs for Dart!');
}

Error #

main() async {
  await Zenity.showErrorMessage(title: 'Error', text: 'Dialogs for Dart!');
}

Progress #

import 'dart:async';
import 'package:zenity/zenity.dart';

Stream<int> get progress async* {
  for (int i = 0; i < 5; i++) {
    await new Future.delayed(new Duration(seconds: 2));
    yield await (i + 1) * (100 ~/ 5);
  }
}

main() async {
  await Zenity.showProgress(
      title: 'Progress', text: 'Loading...', progress: progress);
}

Progress dialog

Password #

import 'package:zenity/zenity.dart';

main() async {
  print(await Zenity.readPassword());
}

Password dialog

Select file #

import 'package:zenity/zenity.dart';

main() async {
  final List<String> files = await Zenity.selectFiles();
  print(files);
}

Select file dialog

Changelog #

0.0.1 #

Support for

  • Message
    • Info
    • Error
    • Question
    • Warning
  • Form with following fields
    • Text
    • Int
    • Double
    • Num
    • Password
    • DateTime
  • File selection
  • Password
  • Username:Password

Use this package as a library

1. Depend on it

Add this to your package's pubspec.yaml file:


dependencies:
  zenity: ^1.0.1

2. Install it

You can install packages from the command line:

with pub:


$ pub get

Alternatively, your editor might support pub get. Check the docs for your editor to learn more.

3. Import it

Now in your Dart code, you can use:


import 'package:zenity/zenity.dart';
  
Popularity:
Describes how popular the package is relative to other packages. [more]
0
Health:
Code health derived from static analysis. [more]
--
Maintenance:
Reflects how tidy and up-to-date the package is. [more]
--
Overall:
Weighted score of the above. [more]
0
Learn more about scoring.

The package version is not analyzed, because it does not support Dart 2. Until this is resolved, the package will receive a health and maintenance score of 0.

Analysis issues and suggestions

Support Dart 2 in pubspec.yaml.

The SDK constraint in pubspec.yaml doesn't allow the Dart 2.0.0 release. For information about upgrading it to be Dart 2 compatible, please see https://dart.dev/dart-2#migration.

Maintenance issues and suggestions

Make sure dartdoc successfully runs on your package's source files. (-10 points)

Dependencies were not resolved.

Dependencies

Package Constraint Resolved Available
Direct dependencies
Dart SDK >=1.20.1 <2.0.0