# Reporte de ingresos

## Implementación

Desde la versión **1.7.0**, las apps pueden recibir un reporte estimado del ingreso que previsiblemente ha sido generado por un anuncio.

Para ello, simplemente hay que implementar el listener correspondiente para cada formato de anuncio, como se muestra en el ejemplo a continuación:

```dart
BannerAd(
  ...
  listener: (event, args) {
    if (event == BannerAdEvent.REVENUE_PAID) {
      // El anuncio ha sido generado un ingreso
    }
  },
)
```

El listener recibe como argumento un objeto que contiene los siguientes campos:

<table><thead><tr><th width="139.62109375">Campo</th><th width="175.3203125">Tipo</th><th>Descripción</th></tr></thead><tbody><tr><td><code>revenue</code></td><td><code>Map</code></td><td>El ingreso generado por el anuncio</td></tr><tr><td><code>source</code></td><td><code>String</code></td><td>La fuente del ingreso</td></tr></tbody></table>

Además, el objeto `revenue` contiene los siguientes campos que representan al ingreso:

<table><thead><tr><th width="140.49609375">Campo</th><th width="174.91796875">Tipo</th><th>Descripción</th></tr></thead><tbody><tr><td><code>currency</code></td><td><code>String</code></td><td>La divisa correspondiente al ingreso </td></tr><tr><td><code>precision</code></td><td><code>String</code></td><td>La precisión de la información. Puede ser <code>ESTIMATED</code>, <code>PRECISE</code> o <code>PUBLISHER_DEFINED</code></td></tr><tr><td><code>value</code></td><td><code>double</code></td><td>El valor del ingreso</td></tr></tbody></table>

## Integración con Firebase

A continuación, se muestra un ejemplo básico para reportar la información de los ingresos a Firebase:

```dart
final analytics = FirebaseAnalytics();

BannerAd(
  ...
  listener: (event, args) {
    if (event == BannerAdEvent.REVENUE_PAID) {
      analytics.logEvent(
        name: 'ad_revenue',
        parameters: {
          'currency':  args['revenue']['currency'],
          'precision': args['revenue']['precision'],
          'source':    args['source'],
          'value':     args['revenue']['value'],
        },
      );
    }
  },
)
```
