fromJson static method

InvoicesBatch? fromJson(
  1. dynamic value
)

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

Implementation

// ignore: prefer_constructors_over_static_methods
static InvoicesBatch? fromJson(dynamic value) {
  if (value is InvoicesBatch) {
    return 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 "InvoicesBatch[$key]" is missing from JSON.');
        assert(json[key] != null, 'Required key "InvoicesBatch[$key]" has a null value in JSON.');
      });
      return true;
    }());

    return InvoicesBatch(
      invoicingYear: mapValueOfType<int>(json, r'invoicingYear')!,
      invoicingMonth: mapValueOfType<int>(json, r'invoicingMonth')!,
      fileRef: mapValueOfType<String>(json, r'fileRef'),
      batchRef: mapValueOfType<String>(json, r'batchRef'),
      ioFederationCode: mapValueOfType<String>(json, r'ioFederationCode'),
      uniqueSendNumber: mapValueOfType<int>(json, r'uniqueSendNumber'),
      sender: InvoiceSender.fromJson(json[r'sender']),
      numericalRef: mapValueOfType<int>(json, r'numericalRef'),
      invoices: EfactInvoice.listFromJson(json[r'invoices'])!,
    );
  }
  return null;
}