decodeMaterialStatePropertyIconThemeData static method

MaterialStateProperty<IconThemeData?>? decodeMaterialStatePropertyIconThemeData(
  1. dynamic value, {
  2. bool validate = true,
})

Decodes a value into a IconThemeData based MaterialStateProperty. This accepts a IconThemeData or a String which will be resolved for all states.

Alternatively, if the value is a Map then this expects the following format:

{
  "disabled": <IconThemeData>,
  "dragged": <IconThemeData>,
  "empty": <IconThemeData>,
  "error": <IconThemeData>,
  "focused": <IconThemeData>,
  "hovered": <IconThemeData>,
  "pressed": <IconThemeData>,
  "scrolledUnder": <IconThemeData>,
  "selected": <IconThemeData>
}

See also:

Implementation

static MaterialStateProperty<IconThemeData?>?
    decodeMaterialStatePropertyIconThemeData(
  dynamic value, {
  bool validate = true,
}) {
  MaterialStateProperty<IconThemeData?>? result;

  if (value is MaterialStateProperty<IconThemeData?>) {
    result = value;
  } else if (value != null) {
    if (value is IconThemeData) {
      result = MaterialStateProperty.all<IconThemeData?>(value);
    } else if (value is String) {
      result = MaterialStateProperty.all<IconThemeData?>(
        decodeIconThemeData(value),
      );
    } else if (value is Map) {
      var testValues = [
        'disabled',
        'dragged',
        'empty',
        'error',
        'focused',
        'hovered',
        'pressed',
        'scrolledUnder',
        'selected',
      ];

      var isMsp = false;
      for (var key in value.keys) {
        if (testValues.contains(key)) {
          isMsp = true;
          break;
        }
      }

      if (isMsp != true) {
        result = MaterialStateProperty.all<IconThemeData?>(
          decodeIconThemeData(value),
        );
      } else {
        assert(SchemaValidator.validate(
          schemaId: '$_baseSchemaUrl/material_state_property_icon_theme_data',
          value: value,
          validate: validate,
        ));

        result = MaterialStateProperty.resolveWith((states) {
          IconThemeData? result;
          if (states.contains(MaterialState.disabled)) {
            result = decodeIconThemeData(value['disabled']);
          } else if (states.contains(MaterialState.dragged)) {
            result = decodeIconThemeData(value['dragged']);
          } else if (states.contains(MaterialState.error)) {
            result = decodeIconThemeData(value['error']);
          } else if (states.contains(MaterialState.focused)) {
            result = decodeIconThemeData(value['focused']);
          } else if (states.contains(MaterialState.hovered)) {
            result = decodeIconThemeData(value['hovered']);
          } else if (states.contains(MaterialState.pressed)) {
            result = decodeIconThemeData(value['pressed']);
          } else if (states.contains(MaterialState.scrolledUnder)) {
            result = decodeIconThemeData(value['scrolledUnder']);
          } else if (states.contains(MaterialState.selected)) {
            result = decodeIconThemeData(value['selected']);
          } else {
            result = decodeIconThemeData(value['empty']);
          }

          return result;
        });
      }
    } else {
      result = MaterialStateProperty.all<IconThemeData?>(value);
    }
  }
  return result;
}