Skip to content
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
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
3 changes: 3 additions & 0 deletions packages/google_identity_services_web/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
## NEXT
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
## NEXT
## 0.3.1+5


* Updates minimum supported SDK version to Flutter 3.22/Dart 3.4.
* Clean up documentation of callbacks in `CodeClientConfig`,
`TokenClientConfig`, `onGoogleLibraryLoad`, and `revoke` to indicate they only
accept Dart functions and not JS functions.

## 0.3.1+4

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,15 +26,15 @@ void main() async {
testWidgets('TokenClientConfig', (_) async {
final TokenClientConfig config = TokenClientConfig(
client_id: 'testing_1-2-3',
callback: (_) {},
callback: (TokenResponse _) {},
scope: <String>['one', 'two', 'three'],
include_granted_scopes: true,
prompt: 'some-prompt',
enable_granular_consent: true,
login_hint: '[email protected]',
hd: 'hd_value',
state: 'some-state',
error_callback: (_) {},
error_callback: (GoogleIdentityServicesError? _) {},
);

final utils.ExpectConfigValueFn expectConfigValue =
Expand Down Expand Up @@ -79,14 +79,14 @@ void main() async {
scope: <String>['one', 'two', 'three'],
include_granted_scopes: true,
redirect_uri: Uri.parse('https://www.example.com/login'),
callback: (_) {},
callback: (CodeResponse _) {},
state: 'some-state',
enable_granular_consent: true,
login_hint: '[email protected]',
hd: 'hd_value',
ux_mode: UxMode.popup,
select_account: true,
error_callback: (_) {},
error_callback: (GoogleIdentityServicesError? _) {},
);

final utils.ExpectConfigValueFn expectConfigValue =
Expand All @@ -110,7 +110,7 @@ void main() async {
testWidgets('returns a tokenClient', (_) async {
final TokenClient client = oauth2.initTokenClient(TokenClientConfig(
client_id: 'for-tests',
callback: (_) {},
callback: (TokenResponse _) {},
scope: <String>['some_scope', 'for_tests', 'not_real'],
));

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,8 @@ extension GoogleAccountsIdExtension on GoogleAccountsId {
/// ID is the `sub` property of the [CredentialResponse.credential] payload.
///
/// The optional [callback] is a function that gets called to report on the
/// success of the revocation call.
/// success of the revocation call. It must be a Dart function and not a JS
/// function.
///
/// Method: google.accounts.id.revoke
/// https://developers.google.com/identity/gsi/web/reference/js-reference#google.accounts.id.revoke
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ extension GoogleAccountsOauth2Extension on GoogleAccountsOauth2 {
/// A valid [accessToken] is required to revoke permissions.
///
/// The [done] callback is called once the revoke action is done. It must be
/// manually wrapped in [allowInterop] before being passed to this method.
/// a Dart function and not a JS function.
///
/// Method: google.accounts.oauth2.revoke
/// https://developers.google.com/identity/oauth2/web/reference/js-reference#google.accounts.oauth2.revoke
Expand Down Expand Up @@ -103,8 +103,7 @@ extension GoogleAccountsOauth2Extension on GoogleAccountsOauth2 {
abstract class CodeClientConfig {
/// Constructs a CodeClientConfig object in JavaScript.
///
/// The [callback] property must be wrapped in [allowInterop] before it's
/// passed to this constructor.
/// The [callback] property must be a Dart function and not a JS function.
factory CodeClientConfig({
required String client_id,
required List<String> scope,
Expand Down Expand Up @@ -230,8 +229,7 @@ typedef CodeClientCallbackFn = void Function(CodeResponse response);
abstract class TokenClientConfig {
/// Constructs a TokenClientConfig object in JavaScript.
///
/// The [callback] property must be wrapped in [allowInterop] before it's
/// passed to this constructor.
/// The [callback] property must be a Dart function and not a JS function.
factory TokenClientConfig({
required String client_id,
required TokenClientCallbackFn callback,
Expand Down Expand Up @@ -315,9 +313,6 @@ extension TokenClientExtension on TokenClient {
@staticInterop
abstract class OverridableTokenClientConfig {
/// Constructs an OverridableTokenClientConfig object in JavaScript.
///
/// The [callback] property must be wrapped in [allowInterop] before it's
/// passed to this constructor.
factory OverridableTokenClientConfig({
/// A list of scopes that identify the resources that your application could
/// access on the user's behalf. These values inform the consent screen that
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,7 @@ external set _onGoogleLibraryLoad(JSFunction callback);

/// Method called after the Sign In With Google JavaScript library is loaded.
///
/// The [callback] parameter must be manually wrapped in [allowInterop]
/// before being set to the [onGoogleLibraryLoad] property.
/// The [function] parameter must be a Dart function and not a JS function.
set onGoogleLibraryLoad(VoidFn function) {
_onGoogleLibraryLoad = function.toJS;
}
Original file line number Diff line number Diff line change
Expand Up @@ -188,9 +188,9 @@ class GisSdkClient {
//
// Token clients have an additional `error_callback` for miscellaneous
// errors, like "popup couldn't open" or "popup closed by user".
void _onTokenError(Object? error) {
void _onTokenError(GoogleIdentityServicesError? error) {
if (error != null) {
_tokenResponses.addError((error as GoogleIdentityServicesError).type);
_tokenResponses.addError(error.type);
}
}

Expand Down Expand Up @@ -223,9 +223,9 @@ class GisSdkClient {
}
}

void _onCodeError(Object? error) {
void _onCodeError(GoogleIdentityServicesError? error) {
if (error != null) {
_codeResponses.addError((error as GoogleIdentityServicesError).type);
_codeResponses.addError(error.type);
}
}

Expand Down