Skip to content

[google_adsense] (Experimental) AdSense plugin for Flutter Web #6871

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 113 commits into from
Dec 4, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
113 commits
Select commit Hold shift + click to select a range
ddb2de6
Initial version of AdSense plugin for Flutter Web
sokoloff06 Jun 5, 2024
968dcdb
Merge branch 'flutter:main' into main
sokoloff06 Jun 5, 2024
3c99bae
Merge branch 'flutter:main' into main
sokoloff06 Jul 21, 2024
c37d644
WIP: apply flutter_packages analysis_options.yaml and fixing warnings
sokoloff06 Jul 21, 2024
dfae8ee
Merge remote-tracking branch 'origin/main'
sokoloff06 Jul 21, 2024
15826c0
remove local analysis_options.yaml
sokoloff06 Jul 21, 2024
6050087
Update README.md, pubspec.yaml, work on example and linter warnings
sokoloff06 Jul 25, 2024
25158d3
Update public API, add example, update README.md, add more docs and s…
sokoloff06 Jul 27, 2024
91ae43f
Update public API, add example, update README.md, add more docs and s…
sokoloff06 Jul 27, 2024
4308c93
Merge remote-tracking branch 'origin/main'
sokoloff06 Jul 27, 2024
52fb128
Merge remote-tracking branch 'origin/main'
sokoloff06 Jul 27, 2024
a562233
Merge remote-tracking branch 'origin/main'
sokoloff06 Jul 27, 2024
500483d
Fix analyzer warnings
sokoloff06 Jul 27, 2024
65c61ab
Updated README.md
sokoloff06 Jul 27, 2024
065e6fe
Add documentation, copyright, initial tests, update README.md
sokoloff06 Aug 4, 2024
b99f4f7
Fix linter error
sokoloff06 Aug 4, 2024
2c7db93
Make plugin closer to publishable state: update copyright, commit mis…
sokoloff06 Aug 4, 2024
1697032
Rename adView to adUnit, fix deps and update README.md
sokoloff06 Aug 4, 2024
875f621
Merge branch 'main' into main
sokoloff06 Aug 4, 2024
5773e5d
Refactoring + unit tests
sokoloff06 Aug 11, 2024
537d611
Merge remote-tracking branch 'origin/main'
sokoloff06 Aug 11, 2024
f105166
Refactoring + unit tests
sokoloff06 Aug 11, 2024
7d3b9c2
Upgrade dart SDK
sokoloff06 Aug 11, 2024
de1fe7c
Upgrade package:web and dart
sokoloff06 Aug 11, 2024
458cb4e
Add integration test
sokoloff06 Sep 15, 2024
ffab481
Clarify 403 error in README.md
sokoloff06 Sep 15, 2024
257007f
Rename ad_unit_widget.dart and solve dart analysis errors
sokoloff06 Sep 27, 2024
7701a7c
Merge branch 'main' into main
sokoloff06 Sep 27, 2024
172dd00
Add styling property for adUnit CSS customization
sokoloff06 Oct 12, 2024
c427a8a
Merge remote-tracking branch 'origin/main'
sokoloff06 Oct 12, 2024
689b1a6
Merge branch 'main' into main
sokoloff06 Oct 12, 2024
215da90
Code format
sokoloff06 Oct 12, 2024
3232f0e
Fix repo rules
sokoloff06 Oct 12, 2024
d59f7b7
Fix repo rules
sokoloff06 Oct 12, 2024
98b0845
Update min Dart version and readme links
sokoloff06 Oct 12, 2024
0232565
Update min SDK versions for dependencies compatibility
sokoloff06 Oct 12, 2024
f2b9c06
Fix typo
sokoloff06 Oct 16, 2024
db13a98
Revert README.md
sokoloff06 Oct 28, 2024
51e2042
Update README.md
sokoloff06 Oct 28, 2024
c57e03f
Merge branch 'main' into main
sokoloff06 Oct 28, 2024
e6842f2
Update README.md, rename class Adsense into AdSense
sokoloff06 Oct 28, 2024
913f347
Update packages/google_adsense/example/pubspec.yaml
sokoloff06 Oct 28, 2024
9ba0ba5
Use instance property to access AdSense singleton instance
sokoloff06 Oct 28, 2024
eb20328
Merge remote-tracking branch 'sokoloff06/main' into fork/sokoloff06/main
sokoloff06 Oct 28, 2024
2a8a998
Add explanation about local DNS records for testing environment
sokoloff06 Oct 29, 2024
1c29983
Use strong String type for additionalParams argument values
sokoloff06 Oct 29, 2024
d07ea36
Remove as JS* casts, change isAdTest default value, improve some docs…
sokoloff06 Oct 29, 2024
d48aa16
Remove as JS* casts, change isAdTest default value, improve some docs…
sokoloff06 Oct 29, 2024
094460b
Add screenshots to pubspec.yaml
sokoloff06 Oct 30, 2024
3f58513
Simplify ResizeObserver, define adsbygoogle JS variable
sokoloff06 Nov 3, 2024
988d3f7
Code cleanup
sokoloff06 Nov 3, 2024
6c244fd
Merge tests
sokoloff06 Nov 3, 2024
410a7eb
Tests cleanup
sokoloff06 Nov 3, 2024
dc78f2e
Provide adSense global variable for convenience
sokoloff06 Nov 3, 2024
12e657d
Remove adClient override logic,
sokoloff06 Nov 11, 2024
3a820bc
Update adUnit API with AdUnitConfiguration and named constructors for…
sokoloff06 Nov 12, 2024
1d288db
Remove test_ad.html, format code
sokoloff06 Nov 12, 2024
d214fc0
Merge branch 'main' into main
sokoloff06 Nov 12, 2024
3fda3da
Ignore avoid_print in test, remove redundant arguments
sokoloff06 Nov 12, 2024
0258b86
use testWidgets in integration tests
sokoloff06 Nov 12, 2024
b9f61b8
Fix adUnit returns Widget type test
sokoloff06 Nov 12, 2024
c509169
Update README.md and add LICENSE
sokoloff06 Nov 12, 2024
4096469
Tweak JS-interop.
ditman Nov 13, 2024
fbde1c2
Tweak ad unit param enums.
ditman Nov 13, 2024
bbaa9db
Use new js-interop init. Remove array fallback from addMasterScript.
ditman Nov 13, 2024
9742dcf
Use new types in ad_unit_configuration
ditman Nov 13, 2024
3acd43c
Use Size for ad unit widget. Some tweaks.
ditman Nov 13, 2024
bc140f4
dart format .
ditman Nov 13, 2024
bd7f839
Fix HTMLDivElement cast
ditman Nov 13, 2024
604b87b
Use offsetWidth/height
ditman Nov 13, 2024
4175da6
Fix tests
ditman Nov 13, 2024
36d2550
Merge pull request #1 from ditman/adsense-js-interop
sokoloff06 Nov 17, 2024
875f72c
Remove width and height css rules, fix test app
sokoloff06 Nov 17, 2024
41edb56
TO_REVIEW: Optimize? - Reuse single static ResizeObserver as per [thi…
sokoloff06 Nov 17, 2024
39dfc97
Hide logs from release, add AdStatus enum,
sokoloff06 Nov 17, 2024
1bbaeee
Fix AdStatus
sokoloff06 Nov 17, 2024
7a31b8e
Fix unit tests CI
sokoloff06 Nov 17, 2024
aeab558
Add TrustedTypes support
sokoloff06 Nov 17, 2024
3235d27
Remove stub tests
sokoloff06 Nov 17, 2024
5a7abad
Fix missing type annotation
sokoloff06 Nov 17, 2024
9dca5d1
Update README.md excerpts
sokoloff06 Nov 17, 2024
7d828cf
Update example to more complex layout
sokoloff06 Nov 17, 2024
d9dbc79
Merge branch 'main' into main
sokoloff06 Nov 17, 2024
308a325
Simplify API: remove cssText and add docs to use Flutter instruments,…
sokoloff06 Nov 19, 2024
baac6ba
Tweak initialization. Support prior initialization in HTML.
ditman Nov 21, 2024
2d9e5bd
Add integration tests mocking window.adsbygoogle. Tweaks.
ditman Nov 21, 2024
456da08
Ensure package compiles in Wasm.
ditman Nov 21, 2024
5f2b324
Tweak the API of AdSense. Rename internal adClient to adClientId. Mak…
ditman Nov 21, 2024
ffd8c4a
Remove adClient from AdUnitParams object, because it's always passed …
ditman Nov 21, 2024
7e4ddc9
Pass clientId when creating ad units from AdSense instance.
ditman Nov 21, 2024
d2b42f1
Simplify some more code.
ditman Nov 21, 2024
e5da3bf
Make isAdTest a normal member of the config. Remove unused getters.
ditman Nov 21, 2024
9ce3347
Remove AdUnitWidget._internal constructor.
ditman Nov 21, 2024
8bda3fd
Make as much API private as possible.
ditman Nov 21, 2024
500337e
Use new constructor instead of the removed factory.
ditman Nov 21, 2024
06886dd
Allow limiting ads by height, update example
sokoloff06 Nov 24, 2024
a36f9f8
Allow limiting ads by height, update example
sokoloff06 Nov 24, 2024
7f55807
Merge pull request #2 from ditman/add-mock-adsense-tests
sokoloff06 Nov 24, 2024
ba38273
Fix CI analyzer fails
sokoloff06 Nov 24, 2024
1914f6b
Fix CI analyzer fails
sokoloff06 Nov 24, 2024
c5e46a6
Fix CI analyzer fails
sokoloff06 Nov 24, 2024
3bb56b9
Make sure <ins> initial size is equal to wrapping div
sokoloff06 Nov 25, 2024
d7abe89
dart format
sokoloff06 Nov 25, 2024
a92864f
Add docs on using BoxConstraints
sokoloff06 Nov 25, 2024
4e52e92
Update tests to match AdSense behavior, and our code.
ditman Nov 28, 2024
44fc9e6
Update README.md and comments
sokoloff06 Dec 1, 2024
49a7a75
Merge pull request #3 from ditman/fix-ins-in-integration-test
sokoloff06 Dec 1, 2024
683fe65
Update README.md
sokoloff06 Dec 2, 2024
06803b8
Update README.md
sokoloff06 Dec 4, 2024
c0d9ec3
Merge remote-tracking branch 'sokoloff06/main' into fork/sokoloff06/main
sokoloff06 Dec 4, 2024
6dbecd7
Merge branch 'main' into main
sokoloff06 Dec 4, 2024
53f47e4
Move exports to experimental folder, update README.md
sokoloff06 Dec 4, 2024
9735ba0
Fix CI
sokoloff06 Dec 4, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CODEOWNERS
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ packages/flutter_migrate/** @stuartmorgan
packages/flutter_template_images/** @stuartmorgan
packages/go_router/** @chunhtai
packages/go_router_builder/** @chunhtai
packages/google_adsense/** @sokoloff06
packages/google_identity_services_web/** @ditman
packages/google_maps_flutter/** @stuartmorgan
packages/google_sign_in/** @stuartmorgan
Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ These are the packages hosted in this repository:
| [flutter\_template\_images](./packages/flutter_template_images/) | [![pub package](https://img.shields.io/pub/v/flutter_template_images.svg)](https://pub.dev/packages/flutter_template_images) | [![pub points](https://img.shields.io/pub/points/flutter_template_images)](https://pub.dev/packages/flutter_template_images/score) | [![popularity](https://img.shields.io/pub/popularity/flutter_template_images)](https://pub.dev/packages/flutter_template_images/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20flutter_template_images?label=)](https://github.com/flutter/flutter/labels/p%3A%20flutter_template_images) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20flutter_template_images?label=)](https://github.com/flutter/packages/labels/p%3A%20flutter_template_images) |
| [go\_router](./packages/go_router/) | [![pub package](https://img.shields.io/pub/v/go_router.svg)](https://pub.dev/packages/go_router) | [![pub points](https://img.shields.io/pub/points/go_router)](https://pub.dev/packages/go_router/score) | [![popularity](https://img.shields.io/pub/popularity/go_router)](https://pub.dev/packages/go_router/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20go_router?label=)](https://github.com/flutter/flutter/labels/p%3A%20go_router) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20go_router?label=)](https://github.com/flutter/packages/labels/p%3A%20go_router) |
| [go\_router\_builder](./packages/go_router_builder/) | [![pub package](https://img.shields.io/pub/v/go_router_builder.svg)](https://pub.dev/packages/go_router_builder) | [![pub points](https://img.shields.io/pub/points/go_router_builder)](https://pub.dev/packages/go_router_builder/score) | [![popularity](https://img.shields.io/pub/popularity/go_router_builder)](https://pub.dev/packages/go_router_builder/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20go_router_builder?label=)](https://github.com/flutter/flutter/labels/p%3A%20go_router_builder) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20go_router_builder?label=)](https://github.com/flutter/packages/labels/p%3A%20go_router_builder) |
| [google\_adsense](./packages/google_adsense/)| [![pub package](https://img.shields.io/pub/v/google_adsense.svg)](https://pub.dev/packages/google_adsense) | [![pub points](https://img.shields.io/pub/points/google_adsense)](https://pub.dev/packages/google_adsense/score) | [![popularity](https://img.shields.io/pub/popularity/google_adsense)](https://pub.dev/packages/google_adsense/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20google_adsense?label=)](https://github.com/flutter/flutter/labels/p%3A%20google_adsense) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20google_adsense?label=)](https://github.com/flutter/packages/labels/p%3A%20google_adsense) |
| [google\_maps\_flutter](./packages/google_maps_flutter/) | [![pub package](https://img.shields.io/pub/v/google_maps_flutter.svg)](https://pub.dev/packages/google_maps_flutter) | [![pub points](https://img.shields.io/pub/points/google_maps_flutter)](https://pub.dev/packages/google_maps_flutter/score) | [![popularity](https://img.shields.io/pub/popularity/google_maps_flutter)](https://pub.dev/packages/google_maps_flutter/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20maps?label=)](https://github.com/flutter/flutter/labels/p%3A%20maps) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20google_maps_flutter?label=)](https://github.com/flutter/packages/labels/p%3A%20google_maps_flutter) |
| [google\_sign\_in](./packages/google_sign_in/) | [![pub package](https://img.shields.io/pub/v/google_sign_in.svg)](https://pub.dev/packages/google_sign_in) | [![pub points](https://img.shields.io/pub/points/google_sign_in)](https://pub.dev/packages/google_sign_in/score) | [![popularity](https://img.shields.io/pub/popularity/google_sign_in)](https://pub.dev/packages/google_sign_in/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20google_sign_in?label=)](https://github.com/flutter/flutter/labels/p%3A%20google_sign_in) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20google_sign_in?label=)](https://github.com/flutter/packages/labels/p%3A%20google_sign_in) |
| [image\_picker](./packages/image_picker/) | [![pub package](https://img.shields.io/pub/v/image_picker.svg)](https://pub.dev/packages/image_picker) | [![pub points](https://img.shields.io/pub/points/image_picker)](https://pub.dev/packages/image_picker/score) | [![popularity](https://img.shields.io/pub/popularity/image_picker)](https://pub.dev/packages/image_picker/score) | [![GitHub issues by-label](https://img.shields.io/github/issues/flutter/flutter/p%3A%20image_picker?label=)](https://github.com/flutter/flutter/labels/p%3A%20image_picker) | [![GitHub pull requests by-label](https://img.shields.io/github/issues-pr/flutter/packages/p%3A%20image_picker?label=)](https://github.com/flutter/packages/labels/p%3A%20image_picker) |
Expand Down
7 changes: 7 additions & 0 deletions packages/google_adsense/AUTHORS
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# Below is a list of people and organizations that have contributed
# to the Flutter project. Names should be added to the list like so:
#
# Name/Organization <email address>

Google Inc.
The Chromium Authors
3 changes: 3 additions & 0 deletions packages/google_adsense/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
## 0.0.1

* Initial release.
25 changes: 25 additions & 0 deletions packages/google_adsense/LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
Copyright 2013 The Flutter Authors. All rights reserved.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above
copyright notice, this list of conditions and the following
disclaimer in the documentation and/or other materials provided
with the distribution.
* Neither the name of Google Inc. nor the names of its
contributors may be used to endorse or promote products derived
from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
120 changes: 120 additions & 0 deletions packages/google_adsense/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
# google_adsense
[Google AdSense](https://adsense.google.com/intl/en_us/start/) plugin for Flutter Web

This package initializes AdSense on your website and provides an ad unit `Widget` that can be configured and placed in the desired location in your Flutter web app UI, without having to directly modify the HTML markup of the app directly.

## Disclaimer: Early Access ⚠️
This package is currently in early access and is provided as-is. While it's open source and publicly available, it's likely that you'll need to make additional customizations and configurations to fully integrate it with your Flutter Web App.
Please express interest joining Early Access program using [this form](https://docs.google.com/forms/d/e/1FAIpQLSdN6aOwVkaxGdxbVQFVZ_N4_UCBkuWYa-cS4_rbU_f1jK10Tw/viewform)

## Usage

### Setup your AdSense account
1. [Make sure your site's pages are ready for AdSense](https://support.google.com/adsense/answer/7299563?hl=en&sjid=5790642343077592212-EU&visit_id=638657100661171978-1373860041&ref_topic=1319756&rd=1)
2. [Create your AdSense account](https://support.google.com/adsense/answer/10162?hl=en&sjid=5790642343077592212-EU&visit_id=638657100661171978-1373860041&ref_topic=1250103&rd=1)

### Initialize AdSense
To start displaying ads, initialize the AdSense with your [client/publisher ID](https://support.google.com/adsense/answer/105516?hl=en&sjid=5790642343077592212-EU) (only use numbers).
<?code-excerpt "example/lib/main.dart (init)"?>
```dart
import 'package:google_adsense/experimental/google_adsense.dart';

void main() {
adSense.initialize(
'0123456789012345'); // TODO: Replace with your Publisher ID (pub-0123456789012345) - https://support.google.com/adsense/answer/105516?hl=en&sjid=5790642343077592212-EU
runApp(const MyApp());
}

```

### Enable Auto Ads
In order to start displaying [Auto ads](https://support.google.com/adsense/answer/9261805?hl=en) make sure to configure this feature in your AdSense Console. If you want to display ad units within your app content, continue to the next step

### Display ad unit Widget

1. Create [ad units](https://support.google.com/adsense/answer/9183549?hl=en&ref_topic=9183242&sjid=5790642343077592212-EU) in your AdSense account
2. Use relevant `AdUnitConfiguration` constructor as per table below

| Ad Unit Type | `AdUnitConfiguration` constructor method |
|----------------|--------------------------------------------|
| Display Ads | `AdUnitConfiguration.displayAdUnit(...)` |
| In-feed Ads | `AdUnitConfiguration.inFeedAdUnit(...)` |
| In-article Ads | `AdUnitConfiguration.inArticleAdUnit(...)` |
| Multiplex Ads | `AdUnitConfiguration.multiplexAdUnit(...)` |

3. Translate data-attributes from snippet generated in AdSense Console into constructor arguments as described below:
- drop `data-` prefix
- translate kebab-case to camelCase
- no need to translate `data-ad-client` as it the value was already passed at initialization

For example snippet below
```html
<ins class="adsbygoogle"
style="display:block"
data-ad-client="ca-pub-0123456789012345"
data-ad-slot="1234567890"
data-ad-format="auto"
data-full-width-responsive="true"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
```
translates into
<?code-excerpt "example/lib/main.dart (init-min)"?>
```dart
adSense.initialize(
'0123456789012345'); // TODO: Replace with your Publisher ID (pub-0123456789012345) - https://support.google.com/adsense/answer/105516?hl=en&sjid=5790642343077592212-EU
```
and
<?code-excerpt "example/lib/main.dart (adUnit)"?>
```dart
adSense.adUnit(AdUnitConfiguration.displayAdUnit(
adSlot: '1234567890', // TODO: Replace with your Ad Unit ID
adFormat: AdFormat
.AUTO, // Remove AdFormat to make ads limited by height
))
```

#### Customize ad unit Widget
To [modify your responsive ad code](https://support.google.com/adsense/answer/9183363?hl=en&ref_topic=9183242&sjid=11551379421978541034-EU):
1. Make sure to follow [AdSense policies](https://support.google.com/adsense/answer/1346295?hl=en&sjid=18331098933308334645-EU&visit_id=638689380593964621-4184295127&ref_topic=1271508&rd=1)
2. Use Flutter instruments for [adaptive and responsive design](https://docs.flutter.dev/ui/adaptive-responsive)

For example, when not using responsive `AdFormat` it is recommended to wrap adUnit widget in the `Container` with width and/or height constraints.
Note some [policies and restrictions](https://support.google.com/adsense/answer/9185043?hl=en#:~:text=Policies%20and%20restrictions) related to ad unit sizing:

<?code-excerpt "example/lib/main.dart (constraints)"?>
```dart
Container(
constraints:
const BoxConstraints(maxHeight: 100, maxWidth: 1200),
padding: const EdgeInsets.only(bottom: 10),
child: adSense.adUnit(AdUnitConfiguration.displayAdUnit(
adSlot: '1234567890', // TODO: Replace with your Ad Unit ID
adFormat: AdFormat
.AUTO, // Not using AdFormat to make ad unit respect height constraint
)),
),
```
## Testing and common errors

### Failed to load resource: the server responded with a status of 400
Make sure to set correct values to adSlot and adClient arguments

### Failed to load resource: the server responded with a status of 403
1. When happening in **testing/staging** environment it is likely related to the fact that ads are only filled when requested from an authorized domain. If you are testing locally and running your web app on `localhost`, you need to:
1. Set custom domain name on localhost by creating a local DNS record that would point `127.0.0.1` and/or `localhost` to `your-domain.com`. On mac/linux machines this can be achieved by adding the following records to you /etc/hosts file:
`127.0.0.1 your-domain.com`
`localhost your-domain.com`
2. Specify additional run arguments in IDE by editing `Run/Debug Configuration` or by passing them directly to `flutter run` command:
`--web-port=8080`
`--web-hostname=your-domain.com`
2. When happening in **production** it might be that your domain was not yet approved or was disapproved. Login to your AdSense account to check your domain approval status

### Ad unfilled

There is no deterministic way to make sure your ads are 100% filled even when testing. Some of the way to increase the fill rate:
- Try setting `adTest` parameter to `true`
- Try setting AD_FORMAT to `auto` (default setting)
- Try setting FULL_WIDTH_RESPONSIVE to `true` (default setting)
- Try resizing the window or making sure that ad unit Widget width is less than ~1200px
6 changes: 6 additions & 0 deletions packages/google_adsense/dart_test.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
## See https://github.com/dart-lang/test/blob/master/pkgs/test/doc/configuration.md#arguments
#override_platforms:
# chrome:
# settings:
# executable: /Applications/Google Chrome.app/Contents/MacOS/Google Chrome
# arguments: --no-sandbox
21 changes: 21 additions & 0 deletions packages/google_adsense/example/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# google_adsense_example

An example demonstrating google_adsense Flutter plugin usage

## Screenshots

![Screenshot of the test app showing an ad on mobile](../example/images/mobile_screenshot.png)
![Screenshot of the test app showing an ad on desktop](../example/images/desktop_screenshot.jpg)



## Testing

This package uses `package:integration_test` to run its tests in a web browser.

See [Plugin Tests > Web Tests](https://github.com/flutter/flutter/blob/master/docs/ecosystem/testing/Plugin-Tests.md#web-tests)
in the Flutter documentation for instructions to set up and run the tests in this package.

Check [flutter.dev > Integration testing](https://docs.flutter.dev/testing/integration-tests)
for more info.

Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Loading