decodeSwitchThemeData static method

SwitchThemeData? decodeSwitchThemeData(
  1. dynamic value, {
  2. bool validate = true,
})

Decodes the given value to an SwitchThemeData. This expects the given value to follow the structure below:

{
  "materialTapTargetSize": <MaterialTapTargetSize>,
  "mouseCursor": <MaterialStateProperty<MouseCursor>>,
  "overlayColor": <MaterialStateProperty<Color>>,
  "splashRadius": <double>,
  "thumbColor": <MaterialStateProperty<Color>>,
  "trackColor": <MaterialStateProperty<Color>>
}

See also:

Implementation

static SwitchThemeData? decodeSwitchThemeData(
  dynamic value, {
  bool validate = true,
}) {
  SwitchThemeData? result;

  if (value is SwitchThemeData) {
    result = value;
  } else if (value != null) {
    assert(SchemaValidator.validate(
      schemaId: '$_baseSchemaUrl/switch_theme_data',
      value: value,
      validate: validate,
    ));

    result = SwitchThemeData(
      materialTapTargetSize: decodeMaterialTapTargetSize(
        value['materialTapTargetSize'],
        validate: false,
      ),
      mouseCursor: decodeMaterialStatePropertyMouseCursor(
        value['mouseCursor'],
        validate: false,
      ),
      overlayColor: decodeMaterialStatePropertyColor(
        value['overlayColor'],
        validate: false,
      ),
      splashRadius: JsonClass.parseDouble(value['splashRadius']),
      thumbColor: decodeMaterialStatePropertyColor(
        value['thumbColor'],
        validate: false,
      ),
      trackColor: decodeMaterialStatePropertyColor(
        value['trackColor'],
        validate: false,
      ),
    );
  }

  return result;
}