is_dart_empty_or_not 0.2.3 copy "is_dart_empty_or_not: ^0.2.3" to clipboard
is_dart_empty_or_not: ^0.2.3 copied to clipboard

A Dart package that provides extensions for checking empty or zero values

example/main.dart

// ignore_for_file: dead_code, lines_longer_than_80_chars, avoid_print

import 'package:is_dart_empty_or_not/is_dart_empty_or_not.dart';

void main() {
  // String examples
  print('--- String Examples ---');
  String? nullString; // Example of a nullable string that is null
  const String emptyString = ''; // Example of a non-nullable empty string
  const String nonEmptyString = 'Hello Dart!';

  // Demonstrating onEmpty with a nullable string that is null
  // Note: onEmpty will not be called because the string itself is null, not just empty.
  // The ?. operator ensures that onEmpty is only called if nullString is not null.
  print('Demonstrating onEmpty with a nullable string that is null:');
  nullString?.onEmpty(() {
    print('  nullString is empty.'); // This will not be loged
  });
  print(
    '  nullString is null, so onEmpty was not called on it via ?. operator.',
  );

  // Demonstrating onEmpty with a non-nullable empty string
  print('Demonstrating onEmpty with a non-nullable empty string:');
  emptyString.onEmpty(() {
    print('  emptyString is empty.'); // This will be loged
  });

  // Demonstrating onNotEmpty with a non-empty string
  print('Demonstrating onNotEmpty with a non-empty string:');
  nonEmptyString.onNotEmpty((final value) {
    print('  Non-empty string: $value'); // This will be loged
  });

  // Demonstrating whenEmptyUse with a nullable string that is null
  // Using ?. as suggested by analyzer. If nullString is null, this will log null.
  print('Demonstrating whenEmptyUse with a nullable string that is null:');
  print(
    '  Using whenEmptyUse for nullString: ${nullString?.whenEmptyUse('Default String')}',
  ); // logs: null

  // Demonstrating whenEmptyUse with a non-nullable empty string
  print('Demonstrating whenEmptyUse with a non-nullable empty string:');
  print(
    '  Using whenEmptyUse for emptyString: ${emptyString.whenEmptyUse('Default String')}',
  ); // logs: Default String

  // Demonstrating whenEmptyUse with a non-empty string
  print('Demonstrating whenEmptyUse with a non-empty string:');
  print(
    '  Using whenEmptyUse for nonEmptyString: ${nonEmptyString.whenEmptyUse('Default String')}',
  ); // logs: Hello Dart!
  print('');

  // List examples
  print('--- List Examples ---');
  final List<int> emptyList = [];
  final List<int> nonEmptyList = [1, 2, 3];
  final List<int> defaultList = [4, 5, 6];

  print(
    'Using whenEmptyUse for empty list: ${emptyList.whenEmptyUse(defaultList)}',
  );
  print(
    'Using whenEmptyUse for non-empty list: ${nonEmptyList.whenEmptyUse(defaultList)}',
  );
  print('');

  // Map examples
  print('--- Map Examples ---');
  final Map<String, int> emptyMap = {};
  final Map<String, int> nonEmptyMap = {'a': 1, 'b': 2};
  final Map<String, int> defaultMap = {'c': 3, 'd': 4};

  print(
    'Using whenEmptyUse for empty map: ${emptyMap.whenEmptyUse(defaultMap)}',
  );
  print(
    'Using whenEmptyUse for non-empty map: ${nonEmptyMap.whenEmptyUse(defaultMap)}',
  );
  print('');

  // Set examples
  print('--- Set Examples ---');
  final Set<String> emptySet = {};
  final Set<String> nonEmptySet = {'apple', 'banana'};
  final Set<String> defaultSet = {'orange', 'grape'};

  print(
    'Using whenEmptyUse for empty set: ${emptySet.whenEmptyUse(defaultSet)}',
  );
  print(
    'Using whenEmptyUse for non-empty set: ${nonEmptySet.whenEmptyUse(defaultSet)}',
  );
  print('');

  // Num examples (int and double)
  print('--- Num Examples ---');
  const int zeroInt = 0;
  const int nonZeroInt = 5;
  const double zeroDouble = 0;
  const double nonZeroDouble = 3.14;
  const num negativeNum = -10;
  const num positiveNum = 10;

  print('zeroInt.isZero: ${zeroInt.isZero}');
  print('nonZeroInt.isZero: ${nonZeroInt.isZero}');
  print('zeroInt.whenZeroUse(10): ${zeroInt.whenZeroUse(10)}');
  print('nonZeroInt.whenZeroUse(10): ${nonZeroInt.whenZeroUse(10)}');

  print('zeroDouble.isZero: ${zeroDouble.isZero}');
  print('nonZeroDouble.isZero: ${nonZeroDouble.isZero}');
  print('zeroDouble.whenZeroUse(1.0): ${zeroDouble.whenZeroUse(1)}');
  print('nonZeroDouble.whenZeroUse(1.0): ${nonZeroDouble.whenZeroUse(1)}');

  print('positiveNum.isPositive: ${positiveNum.isPositive}');
  print(
    'zeroInt.isPositive: ${zeroInt.isPositive}',
  ); // As per library, 0 is positive
  print('negativeNum.isPositive: ${negativeNum.isPositive}');
  print('');

  // Duration examples
  print('--- Duration Examples ---');
  const Duration zeroDuration = Duration.zero;
  const Duration nonZeroPositiveDuration = Duration(seconds: 5);
  const Duration negativeDuration = Duration(seconds: -5);
  const Duration defaultDuration = Duration(minutes: 1);

  print('zeroDuration.isZero: ${zeroDuration.isZero}');
  print('nonZeroPositiveDuration.isZero: ${nonZeroPositiveDuration.isZero}');

  print(
    'zeroDuration.whenZeroUse(defaultDuration): ${zeroDuration.whenZeroUse(defaultDuration)}',
  );
  print(
    'nonZeroPositiveDuration.whenZeroUse(defaultDuration): ${nonZeroPositiveDuration.whenZeroUse(defaultDuration)}',
  );

  print(
    'zeroDuration.isPositive: ${zeroDuration.isPositive}',
  ); // Duration.zero is considered positive
  print(
    'nonZeroPositiveDuration.isPositive: ${nonZeroPositiveDuration.isPositive}',
  );
  print('negativeDuration.isPositive: ${negativeDuration.isPositive}');

  print('zeroDuration.isNegative: ${zeroDuration.isNegative}');
  print(
    'nonZeroPositiveDuration.isNegative: ${nonZeroPositiveDuration.isNegative}',
  );
  print('negativeDuration.isNegative: ${negativeDuration.isNegative}');

  print(
    'zeroDuration.whenNegativeUse(defaultDuration): ${zeroDuration.whenNegativeUse(defaultDuration)}',
  );
  print(
    'nonZeroPositiveDuration.whenNegativeUse(defaultDuration): ${nonZeroPositiveDuration.whenNegativeUse(defaultDuration)}',
  );
  print(
    'negativeDuration.whenNegativeUse(defaultDuration): ${negativeDuration.whenNegativeUse(defaultDuration)}',
  );
}
1
likes
160
points
2.88k
downloads

Publisher

unverified uploader

Weekly Downloads

A Dart package that provides extensions for checking empty or zero values

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

More

Packages that depend on is_dart_empty_or_not