fromJson static method

BillingPriceResponse? fromJson(
  1. dynamic value
)

Returns a new BillingPriceResponse instance and imports its values from value if it's a Map, null otherwise.

Implementation

// ignore: prefer_constructors_over_static_methods
static BillingPriceResponse? fromJson(dynamic value) {
  if (value is Map) {
    final json = value.cast<String, dynamic>();

    // Ensure that the map contains the required keys.
    // Note 1: the values aren't checked for validity beyond being non-null.
    // Note 2: this code is stripped in release mode!
    assert(() {
      requiredKeys.forEach((key) {
        assert(json.containsKey(key),
            'Required key "BillingPriceResponse[$key]" is missing from JSON.');
        assert(json[key] != null,
            'Required key "BillingPriceResponse[$key]" has a null value in JSON.');
      });
      return true;
    }());

    return BillingPriceResponse(
      object: BillingPriceResponseObjectEnum.fromJson(json[r'object'])!,
      id: mapValueOfType<String>(json, r'id')!,
      planId: mapValueOfType<String>(json, r'plan_id')!,
      instanceId: mapValueOfType<String>(json, r'instance_id')!,
      currency: mapValueOfType<String>(json, r'currency')!,
      currencySymbol: mapValueOfType<String>(json, r'currency_symbol')!,
      amount: mapValueOfType<int>(json, r'amount')!,
      annualMonthlyAmount:
          mapValueOfType<int>(json, r'annual_monthly_amount')!,
      fee: CommerceMoneyResponse.fromJson(json[r'fee'])!,
      annualMonthlyFee:
          CommerceMoneyResponse.fromJson(json[r'annual_monthly_fee'])!,
      description: mapValueOfType<String>(json, r'description'),
      createdAt: mapValueOfType<int>(json, r'created_at')!,
    );
  }
  return null;
}