Compare commits
No commits in common. "356b7bf01ace18d82122fb39fc3a35148552105c" and "f04285848fef08cf0f80c0010d9e1a38fc840210" have entirely different histories.
356b7bf01a
...
f04285848f
@ -631,24 +631,5 @@
|
|||||||
"realmJoinSuccess": "Successfully joined the realm.",
|
"realmJoinSuccess": "Successfully joined the realm.",
|
||||||
"discoverRealms": "Discover Realms",
|
"discoverRealms": "Discover Realms",
|
||||||
"discoverPublishers": "Discover Publishers",
|
"discoverPublishers": "Discover Publishers",
|
||||||
"search": "Search",
|
"search": "Search"
|
||||||
"publisherMembers": "Collaborators",
|
|
||||||
"developerHub": "Developer Hub",
|
|
||||||
"developerHubUnselectedHint": "Select a developer to see stats or enroll a new one.",
|
|
||||||
"enrollDeveloper": "Enroll as a Developer",
|
|
||||||
"enrollDeveloperHint": "Enroll one of your publishers to become a developer.",
|
|
||||||
"noPublishersToEnroll": "You don't have any publishers that can be enrolled as a developer.",
|
|
||||||
"totalCustomApps": "Total Custom Apps",
|
|
||||||
"customApps": "Custom Apps",
|
|
||||||
"noCustomApps": "No custom apps yet.",
|
|
||||||
"createCustomApp": "Create Custom App",
|
|
||||||
"editCustomApp": "Edit Custom App",
|
|
||||||
"publicRealm": "Public Realm",
|
|
||||||
"publicRealmDescription": "Anyone can preview the content of this realm.",
|
|
||||||
"communityRealm": "Community Realm",
|
|
||||||
"communityRealmDescription": "Anyone can join this realm and participate in discussions. And will show in the discover page & feed.",
|
|
||||||
"publicChat": "Public Chat",
|
|
||||||
"publicChatDescription": "Anyone can preview the content of this chat. Including unjoined bots.",
|
|
||||||
"communityChat": "Community Chat",
|
|
||||||
"communityChatDescription": "Anyone can join this chat and participate in discussions."
|
|
||||||
}
|
}
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
import 'package:freezed_annotation/freezed_annotation.dart';
|
|
||||||
import 'package:island/models/file.dart';
|
|
||||||
import 'package:island/models/user.dart';
|
|
||||||
|
|
||||||
part 'custom_app.freezed.dart';
|
|
||||||
part 'custom_app.g.dart';
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
sealed class CustomApp with _$CustomApp {
|
|
||||||
const factory CustomApp({
|
|
||||||
@Default('') String id,
|
|
||||||
@Default('') String slug,
|
|
||||||
@Default('') String name,
|
|
||||||
String? description,
|
|
||||||
@Default(0) int status,
|
|
||||||
SnCloudFile? picture,
|
|
||||||
SnCloudFile? background,
|
|
||||||
SnVerificationMark? verification,
|
|
||||||
CustomAppOauthConfig? oauthConfig,
|
|
||||||
CustomAppLinks? links,
|
|
||||||
@Default([]) List<CustomAppSecret> secrets,
|
|
||||||
@Default('') String publisherId,
|
|
||||||
}) = _CustomApp;
|
|
||||||
|
|
||||||
factory CustomApp.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$CustomAppFromJson(json);
|
|
||||||
}
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
sealed class CustomAppLinks with _$CustomAppLinks {
|
|
||||||
const factory CustomAppLinks({
|
|
||||||
String? homePage,
|
|
||||||
String? privacyPolicy,
|
|
||||||
String? termsOfService,
|
|
||||||
}) = _CustomAppLinks;
|
|
||||||
|
|
||||||
factory CustomAppLinks.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$CustomAppLinksFromJson(json);
|
|
||||||
}
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
sealed class CustomAppOauthConfig with _$CustomAppOauthConfig {
|
|
||||||
const factory CustomAppOauthConfig({
|
|
||||||
String? clientUri,
|
|
||||||
@Default([]) List<String> redirectUris,
|
|
||||||
List<String>? postLogoutRedirectUris,
|
|
||||||
@Default(['openid', 'profile', 'email']) List<String> allowedScopes,
|
|
||||||
@Default(['authorization_code', 'refresh_token'])
|
|
||||||
List<String> allowedGrantTypes,
|
|
||||||
@Default(true) bool requirePkce,
|
|
||||||
@Default(false) bool allowOfflineAccess,
|
|
||||||
}) = _CustomAppOauthConfig;
|
|
||||||
|
|
||||||
factory CustomAppOauthConfig.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$CustomAppOauthConfigFromJson(json);
|
|
||||||
}
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
sealed class CustomAppSecret with _$CustomAppSecret {
|
|
||||||
const factory CustomAppSecret({
|
|
||||||
@Default('') String id,
|
|
||||||
@Default('') String secret,
|
|
||||||
String? description,
|
|
||||||
DateTime? expiredAt,
|
|
||||||
@Default(false) bool isOidc,
|
|
||||||
@Default('') String appId,
|
|
||||||
}) = _CustomAppSecret;
|
|
||||||
|
|
||||||
factory CustomAppSecret.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$CustomAppSecretFromJson(json);
|
|
||||||
}
|
|
@ -1,771 +0,0 @@
|
|||||||
// dart format width=80
|
|
||||||
// coverage:ignore-file
|
|
||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
// ignore_for_file: type=lint
|
|
||||||
// ignore_for_file: unused_element, deprecated_member_use, deprecated_member_use_from_same_package, use_function_type_syntax_for_parameters, unnecessary_const, avoid_init_to_null, invalid_override_different_default_values_named, prefer_expression_function_bodies, annotate_overrides, invalid_annotation_target, unnecessary_question_mark
|
|
||||||
|
|
||||||
part of 'custom_app.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// FreezedGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
// dart format off
|
|
||||||
T _$identity<T>(T value) => value;
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
mixin _$CustomApp {
|
|
||||||
|
|
||||||
String get id; String get slug; String get name; String? get description; int get status; SnCloudFile? get picture; SnCloudFile? get background; SnVerificationMark? get verification; CustomAppOauthConfig? get oauthConfig; CustomAppLinks? get links; List<CustomAppSecret> get secrets; String get publisherId;
|
|
||||||
/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppCopyWith<CustomApp> get copyWith => _$CustomAppCopyWithImpl<CustomApp>(this as CustomApp, _$identity);
|
|
||||||
|
|
||||||
/// Serializes this CustomApp to a JSON map.
|
|
||||||
Map<String, dynamic> toJson();
|
|
||||||
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is CustomApp&&(identical(other.id, id) || other.id == id)&&(identical(other.slug, slug) || other.slug == slug)&&(identical(other.name, name) || other.name == name)&&(identical(other.description, description) || other.description == description)&&(identical(other.status, status) || other.status == status)&&(identical(other.picture, picture) || other.picture == picture)&&(identical(other.background, background) || other.background == background)&&(identical(other.verification, verification) || other.verification == verification)&&(identical(other.oauthConfig, oauthConfig) || other.oauthConfig == oauthConfig)&&(identical(other.links, links) || other.links == links)&&const DeepCollectionEquality().equals(other.secrets, secrets)&&(identical(other.publisherId, publisherId) || other.publisherId == publisherId));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,id,slug,name,description,status,picture,background,verification,oauthConfig,links,const DeepCollectionEquality().hash(secrets),publisherId);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomApp(id: $id, slug: $slug, name: $name, description: $description, status: $status, picture: $picture, background: $background, verification: $verification, oauthConfig: $oauthConfig, links: $links, secrets: $secrets, publisherId: $publisherId)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class $CustomAppCopyWith<$Res> {
|
|
||||||
factory $CustomAppCopyWith(CustomApp value, $Res Function(CustomApp) _then) = _$CustomAppCopyWithImpl;
|
|
||||||
@useResult
|
|
||||||
$Res call({
|
|
||||||
String id, String slug, String name, String? description, int status, SnCloudFile? picture, SnCloudFile? background, SnVerificationMark? verification, CustomAppOauthConfig? oauthConfig, CustomAppLinks? links, List<CustomAppSecret> secrets, String publisherId
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
$SnCloudFileCopyWith<$Res>? get picture;$SnCloudFileCopyWith<$Res>? get background;$SnVerificationMarkCopyWith<$Res>? get verification;$CustomAppOauthConfigCopyWith<$Res>? get oauthConfig;$CustomAppLinksCopyWith<$Res>? get links;
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class _$CustomAppCopyWithImpl<$Res>
|
|
||||||
implements $CustomAppCopyWith<$Res> {
|
|
||||||
_$CustomAppCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final CustomApp _self;
|
|
||||||
final $Res Function(CustomApp) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@pragma('vm:prefer-inline') @override $Res call({Object? id = null,Object? slug = null,Object? name = null,Object? description = freezed,Object? status = null,Object? picture = freezed,Object? background = freezed,Object? verification = freezed,Object? oauthConfig = freezed,Object? links = freezed,Object? secrets = null,Object? publisherId = null,}) {
|
|
||||||
return _then(_self.copyWith(
|
|
||||||
id: null == id ? _self.id : id // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,slug: null == slug ? _self.slug : slug // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,name: null == name ? _self.name : name // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,description: freezed == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,status: null == status ? _self.status : status // ignore: cast_nullable_to_non_nullable
|
|
||||||
as int,picture: freezed == picture ? _self.picture : picture // ignore: cast_nullable_to_non_nullable
|
|
||||||
as SnCloudFile?,background: freezed == background ? _self.background : background // ignore: cast_nullable_to_non_nullable
|
|
||||||
as SnCloudFile?,verification: freezed == verification ? _self.verification : verification // ignore: cast_nullable_to_non_nullable
|
|
||||||
as SnVerificationMark?,oauthConfig: freezed == oauthConfig ? _self.oauthConfig : oauthConfig // ignore: cast_nullable_to_non_nullable
|
|
||||||
as CustomAppOauthConfig?,links: freezed == links ? _self.links : links // ignore: cast_nullable_to_non_nullable
|
|
||||||
as CustomAppLinks?,secrets: null == secrets ? _self.secrets : secrets // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<CustomAppSecret>,publisherId: null == publisherId ? _self.publisherId : publisherId // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$SnCloudFileCopyWith<$Res>? get picture {
|
|
||||||
if (_self.picture == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $SnCloudFileCopyWith<$Res>(_self.picture!, (value) {
|
|
||||||
return _then(_self.copyWith(picture: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$SnCloudFileCopyWith<$Res>? get background {
|
|
||||||
if (_self.background == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $SnCloudFileCopyWith<$Res>(_self.background!, (value) {
|
|
||||||
return _then(_self.copyWith(background: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$SnVerificationMarkCopyWith<$Res>? get verification {
|
|
||||||
if (_self.verification == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $SnVerificationMarkCopyWith<$Res>(_self.verification!, (value) {
|
|
||||||
return _then(_self.copyWith(verification: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppOauthConfigCopyWith<$Res>? get oauthConfig {
|
|
||||||
if (_self.oauthConfig == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $CustomAppOauthConfigCopyWith<$Res>(_self.oauthConfig!, (value) {
|
|
||||||
return _then(_self.copyWith(oauthConfig: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppLinksCopyWith<$Res>? get links {
|
|
||||||
if (_self.links == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $CustomAppLinksCopyWith<$Res>(_self.links!, (value) {
|
|
||||||
return _then(_self.copyWith(links: value));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
@JsonSerializable()
|
|
||||||
|
|
||||||
class _CustomApp implements CustomApp {
|
|
||||||
const _CustomApp({this.id = '', this.slug = '', this.name = '', this.description, this.status = 0, this.picture, this.background, this.verification, this.oauthConfig, this.links, final List<CustomAppSecret> secrets = const [], this.publisherId = ''}): _secrets = secrets;
|
|
||||||
factory _CustomApp.fromJson(Map<String, dynamic> json) => _$CustomAppFromJson(json);
|
|
||||||
|
|
||||||
@override@JsonKey() final String id;
|
|
||||||
@override@JsonKey() final String slug;
|
|
||||||
@override@JsonKey() final String name;
|
|
||||||
@override final String? description;
|
|
||||||
@override@JsonKey() final int status;
|
|
||||||
@override final SnCloudFile? picture;
|
|
||||||
@override final SnCloudFile? background;
|
|
||||||
@override final SnVerificationMark? verification;
|
|
||||||
@override final CustomAppOauthConfig? oauthConfig;
|
|
||||||
@override final CustomAppLinks? links;
|
|
||||||
final List<CustomAppSecret> _secrets;
|
|
||||||
@override@JsonKey() List<CustomAppSecret> get secrets {
|
|
||||||
if (_secrets is EqualUnmodifiableListView) return _secrets;
|
|
||||||
// ignore: implicit_dynamic_type
|
|
||||||
return EqualUnmodifiableListView(_secrets);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override@JsonKey() final String publisherId;
|
|
||||||
|
|
||||||
/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
_$CustomAppCopyWith<_CustomApp> get copyWith => __$CustomAppCopyWithImpl<_CustomApp>(this, _$identity);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
return _$CustomAppToJson(this, );
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _CustomApp&&(identical(other.id, id) || other.id == id)&&(identical(other.slug, slug) || other.slug == slug)&&(identical(other.name, name) || other.name == name)&&(identical(other.description, description) || other.description == description)&&(identical(other.status, status) || other.status == status)&&(identical(other.picture, picture) || other.picture == picture)&&(identical(other.background, background) || other.background == background)&&(identical(other.verification, verification) || other.verification == verification)&&(identical(other.oauthConfig, oauthConfig) || other.oauthConfig == oauthConfig)&&(identical(other.links, links) || other.links == links)&&const DeepCollectionEquality().equals(other._secrets, _secrets)&&(identical(other.publisherId, publisherId) || other.publisherId == publisherId));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,id,slug,name,description,status,picture,background,verification,oauthConfig,links,const DeepCollectionEquality().hash(_secrets),publisherId);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomApp(id: $id, slug: $slug, name: $name, description: $description, status: $status, picture: $picture, background: $background, verification: $verification, oauthConfig: $oauthConfig, links: $links, secrets: $secrets, publisherId: $publisherId)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class _$CustomAppCopyWith<$Res> implements $CustomAppCopyWith<$Res> {
|
|
||||||
factory _$CustomAppCopyWith(_CustomApp value, $Res Function(_CustomApp) _then) = __$CustomAppCopyWithImpl;
|
|
||||||
@override @useResult
|
|
||||||
$Res call({
|
|
||||||
String id, String slug, String name, String? description, int status, SnCloudFile? picture, SnCloudFile? background, SnVerificationMark? verification, CustomAppOauthConfig? oauthConfig, CustomAppLinks? links, List<CustomAppSecret> secrets, String publisherId
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
@override $SnCloudFileCopyWith<$Res>? get picture;@override $SnCloudFileCopyWith<$Res>? get background;@override $SnVerificationMarkCopyWith<$Res>? get verification;@override $CustomAppOauthConfigCopyWith<$Res>? get oauthConfig;@override $CustomAppLinksCopyWith<$Res>? get links;
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class __$CustomAppCopyWithImpl<$Res>
|
|
||||||
implements _$CustomAppCopyWith<$Res> {
|
|
||||||
__$CustomAppCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final _CustomApp _self;
|
|
||||||
final $Res Function(_CustomApp) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @pragma('vm:prefer-inline') $Res call({Object? id = null,Object? slug = null,Object? name = null,Object? description = freezed,Object? status = null,Object? picture = freezed,Object? background = freezed,Object? verification = freezed,Object? oauthConfig = freezed,Object? links = freezed,Object? secrets = null,Object? publisherId = null,}) {
|
|
||||||
return _then(_CustomApp(
|
|
||||||
id: null == id ? _self.id : id // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,slug: null == slug ? _self.slug : slug // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,name: null == name ? _self.name : name // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,description: freezed == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,status: null == status ? _self.status : status // ignore: cast_nullable_to_non_nullable
|
|
||||||
as int,picture: freezed == picture ? _self.picture : picture // ignore: cast_nullable_to_non_nullable
|
|
||||||
as SnCloudFile?,background: freezed == background ? _self.background : background // ignore: cast_nullable_to_non_nullable
|
|
||||||
as SnCloudFile?,verification: freezed == verification ? _self.verification : verification // ignore: cast_nullable_to_non_nullable
|
|
||||||
as SnVerificationMark?,oauthConfig: freezed == oauthConfig ? _self.oauthConfig : oauthConfig // ignore: cast_nullable_to_non_nullable
|
|
||||||
as CustomAppOauthConfig?,links: freezed == links ? _self.links : links // ignore: cast_nullable_to_non_nullable
|
|
||||||
as CustomAppLinks?,secrets: null == secrets ? _self._secrets : secrets // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<CustomAppSecret>,publisherId: null == publisherId ? _self.publisherId : publisherId // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$SnCloudFileCopyWith<$Res>? get picture {
|
|
||||||
if (_self.picture == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $SnCloudFileCopyWith<$Res>(_self.picture!, (value) {
|
|
||||||
return _then(_self.copyWith(picture: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$SnCloudFileCopyWith<$Res>? get background {
|
|
||||||
if (_self.background == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $SnCloudFileCopyWith<$Res>(_self.background!, (value) {
|
|
||||||
return _then(_self.copyWith(background: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$SnVerificationMarkCopyWith<$Res>? get verification {
|
|
||||||
if (_self.verification == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $SnVerificationMarkCopyWith<$Res>(_self.verification!, (value) {
|
|
||||||
return _then(_self.copyWith(verification: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppOauthConfigCopyWith<$Res>? get oauthConfig {
|
|
||||||
if (_self.oauthConfig == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $CustomAppOauthConfigCopyWith<$Res>(_self.oauthConfig!, (value) {
|
|
||||||
return _then(_self.copyWith(oauthConfig: value));
|
|
||||||
});
|
|
||||||
}/// Create a copy of CustomApp
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppLinksCopyWith<$Res>? get links {
|
|
||||||
if (_self.links == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $CustomAppLinksCopyWith<$Res>(_self.links!, (value) {
|
|
||||||
return _then(_self.copyWith(links: value));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
mixin _$CustomAppLinks {
|
|
||||||
|
|
||||||
String? get homePage; String? get privacyPolicy; String? get termsOfService;
|
|
||||||
/// Create a copy of CustomAppLinks
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppLinksCopyWith<CustomAppLinks> get copyWith => _$CustomAppLinksCopyWithImpl<CustomAppLinks>(this as CustomAppLinks, _$identity);
|
|
||||||
|
|
||||||
/// Serializes this CustomAppLinks to a JSON map.
|
|
||||||
Map<String, dynamic> toJson();
|
|
||||||
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is CustomAppLinks&&(identical(other.homePage, homePage) || other.homePage == homePage)&&(identical(other.privacyPolicy, privacyPolicy) || other.privacyPolicy == privacyPolicy)&&(identical(other.termsOfService, termsOfService) || other.termsOfService == termsOfService));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,homePage,privacyPolicy,termsOfService);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomAppLinks(homePage: $homePage, privacyPolicy: $privacyPolicy, termsOfService: $termsOfService)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class $CustomAppLinksCopyWith<$Res> {
|
|
||||||
factory $CustomAppLinksCopyWith(CustomAppLinks value, $Res Function(CustomAppLinks) _then) = _$CustomAppLinksCopyWithImpl;
|
|
||||||
@useResult
|
|
||||||
$Res call({
|
|
||||||
String? homePage, String? privacyPolicy, String? termsOfService
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class _$CustomAppLinksCopyWithImpl<$Res>
|
|
||||||
implements $CustomAppLinksCopyWith<$Res> {
|
|
||||||
_$CustomAppLinksCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final CustomAppLinks _self;
|
|
||||||
final $Res Function(CustomAppLinks) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppLinks
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@pragma('vm:prefer-inline') @override $Res call({Object? homePage = freezed,Object? privacyPolicy = freezed,Object? termsOfService = freezed,}) {
|
|
||||||
return _then(_self.copyWith(
|
|
||||||
homePage: freezed == homePage ? _self.homePage : homePage // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,privacyPolicy: freezed == privacyPolicy ? _self.privacyPolicy : privacyPolicy // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,termsOfService: freezed == termsOfService ? _self.termsOfService : termsOfService // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
@JsonSerializable()
|
|
||||||
|
|
||||||
class _CustomAppLinks implements CustomAppLinks {
|
|
||||||
const _CustomAppLinks({this.homePage, this.privacyPolicy, this.termsOfService});
|
|
||||||
factory _CustomAppLinks.fromJson(Map<String, dynamic> json) => _$CustomAppLinksFromJson(json);
|
|
||||||
|
|
||||||
@override final String? homePage;
|
|
||||||
@override final String? privacyPolicy;
|
|
||||||
@override final String? termsOfService;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppLinks
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
_$CustomAppLinksCopyWith<_CustomAppLinks> get copyWith => __$CustomAppLinksCopyWithImpl<_CustomAppLinks>(this, _$identity);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
return _$CustomAppLinksToJson(this, );
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _CustomAppLinks&&(identical(other.homePage, homePage) || other.homePage == homePage)&&(identical(other.privacyPolicy, privacyPolicy) || other.privacyPolicy == privacyPolicy)&&(identical(other.termsOfService, termsOfService) || other.termsOfService == termsOfService));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,homePage,privacyPolicy,termsOfService);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomAppLinks(homePage: $homePage, privacyPolicy: $privacyPolicy, termsOfService: $termsOfService)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class _$CustomAppLinksCopyWith<$Res> implements $CustomAppLinksCopyWith<$Res> {
|
|
||||||
factory _$CustomAppLinksCopyWith(_CustomAppLinks value, $Res Function(_CustomAppLinks) _then) = __$CustomAppLinksCopyWithImpl;
|
|
||||||
@override @useResult
|
|
||||||
$Res call({
|
|
||||||
String? homePage, String? privacyPolicy, String? termsOfService
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class __$CustomAppLinksCopyWithImpl<$Res>
|
|
||||||
implements _$CustomAppLinksCopyWith<$Res> {
|
|
||||||
__$CustomAppLinksCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final _CustomAppLinks _self;
|
|
||||||
final $Res Function(_CustomAppLinks) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppLinks
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @pragma('vm:prefer-inline') $Res call({Object? homePage = freezed,Object? privacyPolicy = freezed,Object? termsOfService = freezed,}) {
|
|
||||||
return _then(_CustomAppLinks(
|
|
||||||
homePage: freezed == homePage ? _self.homePage : homePage // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,privacyPolicy: freezed == privacyPolicy ? _self.privacyPolicy : privacyPolicy // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,termsOfService: freezed == termsOfService ? _self.termsOfService : termsOfService // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
mixin _$CustomAppOauthConfig {
|
|
||||||
|
|
||||||
String? get clientUri; List<String> get redirectUris; List<String>? get postLogoutRedirectUris; List<String> get allowedScopes; List<String> get allowedGrantTypes; bool get requirePkce; bool get allowOfflineAccess;
|
|
||||||
/// Create a copy of CustomAppOauthConfig
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppOauthConfigCopyWith<CustomAppOauthConfig> get copyWith => _$CustomAppOauthConfigCopyWithImpl<CustomAppOauthConfig>(this as CustomAppOauthConfig, _$identity);
|
|
||||||
|
|
||||||
/// Serializes this CustomAppOauthConfig to a JSON map.
|
|
||||||
Map<String, dynamic> toJson();
|
|
||||||
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is CustomAppOauthConfig&&(identical(other.clientUri, clientUri) || other.clientUri == clientUri)&&const DeepCollectionEquality().equals(other.redirectUris, redirectUris)&&const DeepCollectionEquality().equals(other.postLogoutRedirectUris, postLogoutRedirectUris)&&const DeepCollectionEquality().equals(other.allowedScopes, allowedScopes)&&const DeepCollectionEquality().equals(other.allowedGrantTypes, allowedGrantTypes)&&(identical(other.requirePkce, requirePkce) || other.requirePkce == requirePkce)&&(identical(other.allowOfflineAccess, allowOfflineAccess) || other.allowOfflineAccess == allowOfflineAccess));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,clientUri,const DeepCollectionEquality().hash(redirectUris),const DeepCollectionEquality().hash(postLogoutRedirectUris),const DeepCollectionEquality().hash(allowedScopes),const DeepCollectionEquality().hash(allowedGrantTypes),requirePkce,allowOfflineAccess);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomAppOauthConfig(clientUri: $clientUri, redirectUris: $redirectUris, postLogoutRedirectUris: $postLogoutRedirectUris, allowedScopes: $allowedScopes, allowedGrantTypes: $allowedGrantTypes, requirePkce: $requirePkce, allowOfflineAccess: $allowOfflineAccess)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class $CustomAppOauthConfigCopyWith<$Res> {
|
|
||||||
factory $CustomAppOauthConfigCopyWith(CustomAppOauthConfig value, $Res Function(CustomAppOauthConfig) _then) = _$CustomAppOauthConfigCopyWithImpl;
|
|
||||||
@useResult
|
|
||||||
$Res call({
|
|
||||||
String? clientUri, List<String> redirectUris, List<String>? postLogoutRedirectUris, List<String> allowedScopes, List<String> allowedGrantTypes, bool requirePkce, bool allowOfflineAccess
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class _$CustomAppOauthConfigCopyWithImpl<$Res>
|
|
||||||
implements $CustomAppOauthConfigCopyWith<$Res> {
|
|
||||||
_$CustomAppOauthConfigCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final CustomAppOauthConfig _self;
|
|
||||||
final $Res Function(CustomAppOauthConfig) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppOauthConfig
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@pragma('vm:prefer-inline') @override $Res call({Object? clientUri = freezed,Object? redirectUris = null,Object? postLogoutRedirectUris = freezed,Object? allowedScopes = null,Object? allowedGrantTypes = null,Object? requirePkce = null,Object? allowOfflineAccess = null,}) {
|
|
||||||
return _then(_self.copyWith(
|
|
||||||
clientUri: freezed == clientUri ? _self.clientUri : clientUri // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,redirectUris: null == redirectUris ? _self.redirectUris : redirectUris // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>,postLogoutRedirectUris: freezed == postLogoutRedirectUris ? _self.postLogoutRedirectUris : postLogoutRedirectUris // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>?,allowedScopes: null == allowedScopes ? _self.allowedScopes : allowedScopes // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>,allowedGrantTypes: null == allowedGrantTypes ? _self.allowedGrantTypes : allowedGrantTypes // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>,requirePkce: null == requirePkce ? _self.requirePkce : requirePkce // ignore: cast_nullable_to_non_nullable
|
|
||||||
as bool,allowOfflineAccess: null == allowOfflineAccess ? _self.allowOfflineAccess : allowOfflineAccess // ignore: cast_nullable_to_non_nullable
|
|
||||||
as bool,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
@JsonSerializable()
|
|
||||||
|
|
||||||
class _CustomAppOauthConfig implements CustomAppOauthConfig {
|
|
||||||
const _CustomAppOauthConfig({this.clientUri, final List<String> redirectUris = const [], final List<String>? postLogoutRedirectUris, final List<String> allowedScopes = const ['openid', 'profile', 'email'], final List<String> allowedGrantTypes = const ['authorization_code', 'refresh_token'], this.requirePkce = true, this.allowOfflineAccess = false}): _redirectUris = redirectUris,_postLogoutRedirectUris = postLogoutRedirectUris,_allowedScopes = allowedScopes,_allowedGrantTypes = allowedGrantTypes;
|
|
||||||
factory _CustomAppOauthConfig.fromJson(Map<String, dynamic> json) => _$CustomAppOauthConfigFromJson(json);
|
|
||||||
|
|
||||||
@override final String? clientUri;
|
|
||||||
final List<String> _redirectUris;
|
|
||||||
@override@JsonKey() List<String> get redirectUris {
|
|
||||||
if (_redirectUris is EqualUnmodifiableListView) return _redirectUris;
|
|
||||||
// ignore: implicit_dynamic_type
|
|
||||||
return EqualUnmodifiableListView(_redirectUris);
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<String>? _postLogoutRedirectUris;
|
|
||||||
@override List<String>? get postLogoutRedirectUris {
|
|
||||||
final value = _postLogoutRedirectUris;
|
|
||||||
if (value == null) return null;
|
|
||||||
if (_postLogoutRedirectUris is EqualUnmodifiableListView) return _postLogoutRedirectUris;
|
|
||||||
// ignore: implicit_dynamic_type
|
|
||||||
return EqualUnmodifiableListView(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<String> _allowedScopes;
|
|
||||||
@override@JsonKey() List<String> get allowedScopes {
|
|
||||||
if (_allowedScopes is EqualUnmodifiableListView) return _allowedScopes;
|
|
||||||
// ignore: implicit_dynamic_type
|
|
||||||
return EqualUnmodifiableListView(_allowedScopes);
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<String> _allowedGrantTypes;
|
|
||||||
@override@JsonKey() List<String> get allowedGrantTypes {
|
|
||||||
if (_allowedGrantTypes is EqualUnmodifiableListView) return _allowedGrantTypes;
|
|
||||||
// ignore: implicit_dynamic_type
|
|
||||||
return EqualUnmodifiableListView(_allowedGrantTypes);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override@JsonKey() final bool requirePkce;
|
|
||||||
@override@JsonKey() final bool allowOfflineAccess;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppOauthConfig
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
_$CustomAppOauthConfigCopyWith<_CustomAppOauthConfig> get copyWith => __$CustomAppOauthConfigCopyWithImpl<_CustomAppOauthConfig>(this, _$identity);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
return _$CustomAppOauthConfigToJson(this, );
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _CustomAppOauthConfig&&(identical(other.clientUri, clientUri) || other.clientUri == clientUri)&&const DeepCollectionEquality().equals(other._redirectUris, _redirectUris)&&const DeepCollectionEquality().equals(other._postLogoutRedirectUris, _postLogoutRedirectUris)&&const DeepCollectionEquality().equals(other._allowedScopes, _allowedScopes)&&const DeepCollectionEquality().equals(other._allowedGrantTypes, _allowedGrantTypes)&&(identical(other.requirePkce, requirePkce) || other.requirePkce == requirePkce)&&(identical(other.allowOfflineAccess, allowOfflineAccess) || other.allowOfflineAccess == allowOfflineAccess));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,clientUri,const DeepCollectionEquality().hash(_redirectUris),const DeepCollectionEquality().hash(_postLogoutRedirectUris),const DeepCollectionEquality().hash(_allowedScopes),const DeepCollectionEquality().hash(_allowedGrantTypes),requirePkce,allowOfflineAccess);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomAppOauthConfig(clientUri: $clientUri, redirectUris: $redirectUris, postLogoutRedirectUris: $postLogoutRedirectUris, allowedScopes: $allowedScopes, allowedGrantTypes: $allowedGrantTypes, requirePkce: $requirePkce, allowOfflineAccess: $allowOfflineAccess)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class _$CustomAppOauthConfigCopyWith<$Res> implements $CustomAppOauthConfigCopyWith<$Res> {
|
|
||||||
factory _$CustomAppOauthConfigCopyWith(_CustomAppOauthConfig value, $Res Function(_CustomAppOauthConfig) _then) = __$CustomAppOauthConfigCopyWithImpl;
|
|
||||||
@override @useResult
|
|
||||||
$Res call({
|
|
||||||
String? clientUri, List<String> redirectUris, List<String>? postLogoutRedirectUris, List<String> allowedScopes, List<String> allowedGrantTypes, bool requirePkce, bool allowOfflineAccess
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class __$CustomAppOauthConfigCopyWithImpl<$Res>
|
|
||||||
implements _$CustomAppOauthConfigCopyWith<$Res> {
|
|
||||||
__$CustomAppOauthConfigCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final _CustomAppOauthConfig _self;
|
|
||||||
final $Res Function(_CustomAppOauthConfig) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppOauthConfig
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @pragma('vm:prefer-inline') $Res call({Object? clientUri = freezed,Object? redirectUris = null,Object? postLogoutRedirectUris = freezed,Object? allowedScopes = null,Object? allowedGrantTypes = null,Object? requirePkce = null,Object? allowOfflineAccess = null,}) {
|
|
||||||
return _then(_CustomAppOauthConfig(
|
|
||||||
clientUri: freezed == clientUri ? _self.clientUri : clientUri // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,redirectUris: null == redirectUris ? _self._redirectUris : redirectUris // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>,postLogoutRedirectUris: freezed == postLogoutRedirectUris ? _self._postLogoutRedirectUris : postLogoutRedirectUris // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>?,allowedScopes: null == allowedScopes ? _self._allowedScopes : allowedScopes // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>,allowedGrantTypes: null == allowedGrantTypes ? _self._allowedGrantTypes : allowedGrantTypes // ignore: cast_nullable_to_non_nullable
|
|
||||||
as List<String>,requirePkce: null == requirePkce ? _self.requirePkce : requirePkce // ignore: cast_nullable_to_non_nullable
|
|
||||||
as bool,allowOfflineAccess: null == allowOfflineAccess ? _self.allowOfflineAccess : allowOfflineAccess // ignore: cast_nullable_to_non_nullable
|
|
||||||
as bool,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
mixin _$CustomAppSecret {
|
|
||||||
|
|
||||||
String get id; String get secret; String? get description; DateTime? get expiredAt; bool get isOidc; String get appId;
|
|
||||||
/// Create a copy of CustomAppSecret
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$CustomAppSecretCopyWith<CustomAppSecret> get copyWith => _$CustomAppSecretCopyWithImpl<CustomAppSecret>(this as CustomAppSecret, _$identity);
|
|
||||||
|
|
||||||
/// Serializes this CustomAppSecret to a JSON map.
|
|
||||||
Map<String, dynamic> toJson();
|
|
||||||
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is CustomAppSecret&&(identical(other.id, id) || other.id == id)&&(identical(other.secret, secret) || other.secret == secret)&&(identical(other.description, description) || other.description == description)&&(identical(other.expiredAt, expiredAt) || other.expiredAt == expiredAt)&&(identical(other.isOidc, isOidc) || other.isOidc == isOidc)&&(identical(other.appId, appId) || other.appId == appId));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,id,secret,description,expiredAt,isOidc,appId);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomAppSecret(id: $id, secret: $secret, description: $description, expiredAt: $expiredAt, isOidc: $isOidc, appId: $appId)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class $CustomAppSecretCopyWith<$Res> {
|
|
||||||
factory $CustomAppSecretCopyWith(CustomAppSecret value, $Res Function(CustomAppSecret) _then) = _$CustomAppSecretCopyWithImpl;
|
|
||||||
@useResult
|
|
||||||
$Res call({
|
|
||||||
String id, String secret, String? description, DateTime? expiredAt, bool isOidc, String appId
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class _$CustomAppSecretCopyWithImpl<$Res>
|
|
||||||
implements $CustomAppSecretCopyWith<$Res> {
|
|
||||||
_$CustomAppSecretCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final CustomAppSecret _self;
|
|
||||||
final $Res Function(CustomAppSecret) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppSecret
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@pragma('vm:prefer-inline') @override $Res call({Object? id = null,Object? secret = null,Object? description = freezed,Object? expiredAt = freezed,Object? isOidc = null,Object? appId = null,}) {
|
|
||||||
return _then(_self.copyWith(
|
|
||||||
id: null == id ? _self.id : id // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,secret: null == secret ? _self.secret : secret // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,description: freezed == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,expiredAt: freezed == expiredAt ? _self.expiredAt : expiredAt // ignore: cast_nullable_to_non_nullable
|
|
||||||
as DateTime?,isOidc: null == isOidc ? _self.isOidc : isOidc // ignore: cast_nullable_to_non_nullable
|
|
||||||
as bool,appId: null == appId ? _self.appId : appId // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
@JsonSerializable()
|
|
||||||
|
|
||||||
class _CustomAppSecret implements CustomAppSecret {
|
|
||||||
const _CustomAppSecret({this.id = '', this.secret = '', this.description, this.expiredAt, this.isOidc = false, this.appId = ''});
|
|
||||||
factory _CustomAppSecret.fromJson(Map<String, dynamic> json) => _$CustomAppSecretFromJson(json);
|
|
||||||
|
|
||||||
@override@JsonKey() final String id;
|
|
||||||
@override@JsonKey() final String secret;
|
|
||||||
@override final String? description;
|
|
||||||
@override final DateTime? expiredAt;
|
|
||||||
@override@JsonKey() final bool isOidc;
|
|
||||||
@override@JsonKey() final String appId;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppSecret
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
_$CustomAppSecretCopyWith<_CustomAppSecret> get copyWith => __$CustomAppSecretCopyWithImpl<_CustomAppSecret>(this, _$identity);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
return _$CustomAppSecretToJson(this, );
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _CustomAppSecret&&(identical(other.id, id) || other.id == id)&&(identical(other.secret, secret) || other.secret == secret)&&(identical(other.description, description) || other.description == description)&&(identical(other.expiredAt, expiredAt) || other.expiredAt == expiredAt)&&(identical(other.isOidc, isOidc) || other.isOidc == isOidc)&&(identical(other.appId, appId) || other.appId == appId));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,id,secret,description,expiredAt,isOidc,appId);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'CustomAppSecret(id: $id, secret: $secret, description: $description, expiredAt: $expiredAt, isOidc: $isOidc, appId: $appId)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class _$CustomAppSecretCopyWith<$Res> implements $CustomAppSecretCopyWith<$Res> {
|
|
||||||
factory _$CustomAppSecretCopyWith(_CustomAppSecret value, $Res Function(_CustomAppSecret) _then) = __$CustomAppSecretCopyWithImpl;
|
|
||||||
@override @useResult
|
|
||||||
$Res call({
|
|
||||||
String id, String secret, String? description, DateTime? expiredAt, bool isOidc, String appId
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class __$CustomAppSecretCopyWithImpl<$Res>
|
|
||||||
implements _$CustomAppSecretCopyWith<$Res> {
|
|
||||||
__$CustomAppSecretCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final _CustomAppSecret _self;
|
|
||||||
final $Res Function(_CustomAppSecret) _then;
|
|
||||||
|
|
||||||
/// Create a copy of CustomAppSecret
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @pragma('vm:prefer-inline') $Res call({Object? id = null,Object? secret = null,Object? description = freezed,Object? expiredAt = freezed,Object? isOidc = null,Object? appId = null,}) {
|
|
||||||
return _then(_CustomAppSecret(
|
|
||||||
id: null == id ? _self.id : id // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,secret: null == secret ? _self.secret : secret // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,description: freezed == description ? _self.description : description // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String?,expiredAt: freezed == expiredAt ? _self.expiredAt : expiredAt // ignore: cast_nullable_to_non_nullable
|
|
||||||
as DateTime?,isOidc: null == isOidc ? _self.isOidc : isOidc // ignore: cast_nullable_to_non_nullable
|
|
||||||
as bool,appId: null == appId ? _self.appId : appId // ignore: cast_nullable_to_non_nullable
|
|
||||||
as String,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// dart format on
|
|
@ -1,137 +0,0 @@
|
|||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
|
|
||||||
part of 'custom_app.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// JsonSerializableGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
_CustomApp _$CustomAppFromJson(Map<String, dynamic> json) => _CustomApp(
|
|
||||||
id: json['id'] as String? ?? '',
|
|
||||||
slug: json['slug'] as String? ?? '',
|
|
||||||
name: json['name'] as String? ?? '',
|
|
||||||
description: json['description'] as String?,
|
|
||||||
status: (json['status'] as num?)?.toInt() ?? 0,
|
|
||||||
picture:
|
|
||||||
json['picture'] == null
|
|
||||||
? null
|
|
||||||
: SnCloudFile.fromJson(json['picture'] as Map<String, dynamic>),
|
|
||||||
background:
|
|
||||||
json['background'] == null
|
|
||||||
? null
|
|
||||||
: SnCloudFile.fromJson(json['background'] as Map<String, dynamic>),
|
|
||||||
verification:
|
|
||||||
json['verification'] == null
|
|
||||||
? null
|
|
||||||
: SnVerificationMark.fromJson(
|
|
||||||
json['verification'] as Map<String, dynamic>,
|
|
||||||
),
|
|
||||||
oauthConfig:
|
|
||||||
json['oauth_config'] == null
|
|
||||||
? null
|
|
||||||
: CustomAppOauthConfig.fromJson(
|
|
||||||
json['oauth_config'] as Map<String, dynamic>,
|
|
||||||
),
|
|
||||||
links:
|
|
||||||
json['links'] == null
|
|
||||||
? null
|
|
||||||
: CustomAppLinks.fromJson(json['links'] as Map<String, dynamic>),
|
|
||||||
secrets:
|
|
||||||
(json['secrets'] as List<dynamic>?)
|
|
||||||
?.map((e) => CustomAppSecret.fromJson(e as Map<String, dynamic>))
|
|
||||||
.toList() ??
|
|
||||||
const [],
|
|
||||||
publisherId: json['publisher_id'] as String? ?? '',
|
|
||||||
);
|
|
||||||
|
|
||||||
Map<String, dynamic> _$CustomAppToJson(_CustomApp instance) =>
|
|
||||||
<String, dynamic>{
|
|
||||||
'id': instance.id,
|
|
||||||
'slug': instance.slug,
|
|
||||||
'name': instance.name,
|
|
||||||
'description': instance.description,
|
|
||||||
'status': instance.status,
|
|
||||||
'picture': instance.picture?.toJson(),
|
|
||||||
'background': instance.background?.toJson(),
|
|
||||||
'verification': instance.verification?.toJson(),
|
|
||||||
'oauth_config': instance.oauthConfig?.toJson(),
|
|
||||||
'links': instance.links?.toJson(),
|
|
||||||
'secrets': instance.secrets.map((e) => e.toJson()).toList(),
|
|
||||||
'publisher_id': instance.publisherId,
|
|
||||||
};
|
|
||||||
|
|
||||||
_CustomAppLinks _$CustomAppLinksFromJson(Map<String, dynamic> json) =>
|
|
||||||
_CustomAppLinks(
|
|
||||||
homePage: json['home_page'] as String?,
|
|
||||||
privacyPolicy: json['privacy_policy'] as String?,
|
|
||||||
termsOfService: json['terms_of_service'] as String?,
|
|
||||||
);
|
|
||||||
|
|
||||||
Map<String, dynamic> _$CustomAppLinksToJson(_CustomAppLinks instance) =>
|
|
||||||
<String, dynamic>{
|
|
||||||
'home_page': instance.homePage,
|
|
||||||
'privacy_policy': instance.privacyPolicy,
|
|
||||||
'terms_of_service': instance.termsOfService,
|
|
||||||
};
|
|
||||||
|
|
||||||
_CustomAppOauthConfig _$CustomAppOauthConfigFromJson(
|
|
||||||
Map<String, dynamic> json,
|
|
||||||
) => _CustomAppOauthConfig(
|
|
||||||
clientUri: json['client_uri'] as String?,
|
|
||||||
redirectUris:
|
|
||||||
(json['redirect_uris'] as List<dynamic>?)
|
|
||||||
?.map((e) => e as String)
|
|
||||||
.toList() ??
|
|
||||||
const [],
|
|
||||||
postLogoutRedirectUris:
|
|
||||||
(json['post_logout_redirect_uris'] as List<dynamic>?)
|
|
||||||
?.map((e) => e as String)
|
|
||||||
.toList(),
|
|
||||||
allowedScopes:
|
|
||||||
(json['allowed_scopes'] as List<dynamic>?)
|
|
||||||
?.map((e) => e as String)
|
|
||||||
.toList() ??
|
|
||||||
const ['openid', 'profile', 'email'],
|
|
||||||
allowedGrantTypes:
|
|
||||||
(json['allowed_grant_types'] as List<dynamic>?)
|
|
||||||
?.map((e) => e as String)
|
|
||||||
.toList() ??
|
|
||||||
const ['authorization_code', 'refresh_token'],
|
|
||||||
requirePkce: json['require_pkce'] as bool? ?? true,
|
|
||||||
allowOfflineAccess: json['allow_offline_access'] as bool? ?? false,
|
|
||||||
);
|
|
||||||
|
|
||||||
Map<String, dynamic> _$CustomAppOauthConfigToJson(
|
|
||||||
_CustomAppOauthConfig instance,
|
|
||||||
) => <String, dynamic>{
|
|
||||||
'client_uri': instance.clientUri,
|
|
||||||
'redirect_uris': instance.redirectUris,
|
|
||||||
'post_logout_redirect_uris': instance.postLogoutRedirectUris,
|
|
||||||
'allowed_scopes': instance.allowedScopes,
|
|
||||||
'allowed_grant_types': instance.allowedGrantTypes,
|
|
||||||
'require_pkce': instance.requirePkce,
|
|
||||||
'allow_offline_access': instance.allowOfflineAccess,
|
|
||||||
};
|
|
||||||
|
|
||||||
_CustomAppSecret _$CustomAppSecretFromJson(Map<String, dynamic> json) =>
|
|
||||||
_CustomAppSecret(
|
|
||||||
id: json['id'] as String? ?? '',
|
|
||||||
secret: json['secret'] as String? ?? '',
|
|
||||||
description: json['description'] as String?,
|
|
||||||
expiredAt:
|
|
||||||
json['expired_at'] == null
|
|
||||||
? null
|
|
||||||
: DateTime.parse(json['expired_at'] as String),
|
|
||||||
isOidc: json['is_oidc'] as bool? ?? false,
|
|
||||||
appId: json['app_id'] as String? ?? '',
|
|
||||||
);
|
|
||||||
|
|
||||||
Map<String, dynamic> _$CustomAppSecretToJson(_CustomAppSecret instance) =>
|
|
||||||
<String, dynamic>{
|
|
||||||
'id': instance.id,
|
|
||||||
'secret': instance.secret,
|
|
||||||
'description': instance.description,
|
|
||||||
'expired_at': instance.expiredAt?.toIso8601String(),
|
|
||||||
'is_oidc': instance.isOidc,
|
|
||||||
'app_id': instance.appId,
|
|
||||||
};
|
|
@ -1,14 +0,0 @@
|
|||||||
import 'package:freezed_annotation/freezed_annotation.dart';
|
|
||||||
|
|
||||||
part 'developer.freezed.dart';
|
|
||||||
part 'developer.g.dart';
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
sealed class DeveloperStats with _$DeveloperStats {
|
|
||||||
const factory DeveloperStats({
|
|
||||||
@Default(0) int totalCustomApps,
|
|
||||||
}) = _DeveloperStats;
|
|
||||||
|
|
||||||
factory DeveloperStats.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$DeveloperStatsFromJson(json);
|
|
||||||
}
|
|
@ -1,148 +0,0 @@
|
|||||||
// dart format width=80
|
|
||||||
// coverage:ignore-file
|
|
||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
// ignore_for_file: type=lint
|
|
||||||
// ignore_for_file: unused_element, deprecated_member_use, deprecated_member_use_from_same_package, use_function_type_syntax_for_parameters, unnecessary_const, avoid_init_to_null, invalid_override_different_default_values_named, prefer_expression_function_bodies, annotate_overrides, invalid_annotation_target, unnecessary_question_mark
|
|
||||||
|
|
||||||
part of 'developer.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// FreezedGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
// dart format off
|
|
||||||
T _$identity<T>(T value) => value;
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
mixin _$DeveloperStats {
|
|
||||||
|
|
||||||
int get totalCustomApps;
|
|
||||||
/// Create a copy of DeveloperStats
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
$DeveloperStatsCopyWith<DeveloperStats> get copyWith => _$DeveloperStatsCopyWithImpl<DeveloperStats>(this as DeveloperStats, _$identity);
|
|
||||||
|
|
||||||
/// Serializes this DeveloperStats to a JSON map.
|
|
||||||
Map<String, dynamic> toJson();
|
|
||||||
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is DeveloperStats&&(identical(other.totalCustomApps, totalCustomApps) || other.totalCustomApps == totalCustomApps));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,totalCustomApps);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'DeveloperStats(totalCustomApps: $totalCustomApps)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class $DeveloperStatsCopyWith<$Res> {
|
|
||||||
factory $DeveloperStatsCopyWith(DeveloperStats value, $Res Function(DeveloperStats) _then) = _$DeveloperStatsCopyWithImpl;
|
|
||||||
@useResult
|
|
||||||
$Res call({
|
|
||||||
int totalCustomApps
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class _$DeveloperStatsCopyWithImpl<$Res>
|
|
||||||
implements $DeveloperStatsCopyWith<$Res> {
|
|
||||||
_$DeveloperStatsCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final DeveloperStats _self;
|
|
||||||
final $Res Function(DeveloperStats) _then;
|
|
||||||
|
|
||||||
/// Create a copy of DeveloperStats
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@pragma('vm:prefer-inline') @override $Res call({Object? totalCustomApps = null,}) {
|
|
||||||
return _then(_self.copyWith(
|
|
||||||
totalCustomApps: null == totalCustomApps ? _self.totalCustomApps : totalCustomApps // ignore: cast_nullable_to_non_nullable
|
|
||||||
as int,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
@JsonSerializable()
|
|
||||||
|
|
||||||
class _DeveloperStats implements DeveloperStats {
|
|
||||||
const _DeveloperStats({this.totalCustomApps = 0});
|
|
||||||
factory _DeveloperStats.fromJson(Map<String, dynamic> json) => _$DeveloperStatsFromJson(json);
|
|
||||||
|
|
||||||
@override@JsonKey() final int totalCustomApps;
|
|
||||||
|
|
||||||
/// Create a copy of DeveloperStats
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@pragma('vm:prefer-inline')
|
|
||||||
_$DeveloperStatsCopyWith<_DeveloperStats> get copyWith => __$DeveloperStatsCopyWithImpl<_DeveloperStats>(this, _$identity);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
return _$DeveloperStatsToJson(this, );
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return identical(this, other) || (other.runtimeType == runtimeType&&other is _DeveloperStats&&(identical(other.totalCustomApps, totalCustomApps) || other.totalCustomApps == totalCustomApps));
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
||||||
@override
|
|
||||||
int get hashCode => Object.hash(runtimeType,totalCustomApps);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'DeveloperStats(totalCustomApps: $totalCustomApps)';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @nodoc
|
|
||||||
abstract mixin class _$DeveloperStatsCopyWith<$Res> implements $DeveloperStatsCopyWith<$Res> {
|
|
||||||
factory _$DeveloperStatsCopyWith(_DeveloperStats value, $Res Function(_DeveloperStats) _then) = __$DeveloperStatsCopyWithImpl;
|
|
||||||
@override @useResult
|
|
||||||
$Res call({
|
|
||||||
int totalCustomApps
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
/// @nodoc
|
|
||||||
class __$DeveloperStatsCopyWithImpl<$Res>
|
|
||||||
implements _$DeveloperStatsCopyWith<$Res> {
|
|
||||||
__$DeveloperStatsCopyWithImpl(this._self, this._then);
|
|
||||||
|
|
||||||
final _DeveloperStats _self;
|
|
||||||
final $Res Function(_DeveloperStats) _then;
|
|
||||||
|
|
||||||
/// Create a copy of DeveloperStats
|
|
||||||
/// with the given fields replaced by the non-null parameter values.
|
|
||||||
@override @pragma('vm:prefer-inline') $Res call({Object? totalCustomApps = null,}) {
|
|
||||||
return _then(_DeveloperStats(
|
|
||||||
totalCustomApps: null == totalCustomApps ? _self.totalCustomApps : totalCustomApps // ignore: cast_nullable_to_non_nullable
|
|
||||||
as int,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// dart format on
|
|
@ -1,15 +0,0 @@
|
|||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
|
|
||||||
part of 'developer.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// JsonSerializableGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
_DeveloperStats _$DeveloperStatsFromJson(Map<String, dynamic> json) =>
|
|
||||||
_DeveloperStats(
|
|
||||||
totalCustomApps: (json['total_custom_apps'] as num?)?.toInt() ?? 0,
|
|
||||||
);
|
|
||||||
|
|
||||||
Map<String, dynamic> _$DeveloperStatsToJson(_DeveloperStats instance) =>
|
|
||||||
<String, dynamic>{'total_custom_apps': instance.totalCustomApps};
|
|
@ -1,10 +1,6 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:go_router/go_router.dart';
|
import 'package:go_router/go_router.dart';
|
||||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||||
import 'package:island/screens/developers/apps.dart';
|
|
||||||
import 'package:island/screens/developers/edit_app.dart';
|
|
||||||
import 'package:island/screens/developers/new_app.dart';
|
|
||||||
import 'package:island/screens/developers/hub.dart';
|
|
||||||
import 'package:island/widgets/app_wrapper.dart';
|
import 'package:island/widgets/app_wrapper.dart';
|
||||||
import 'package:island/screens/tabs.dart';
|
import 'package:island/screens/tabs.dart';
|
||||||
|
|
||||||
@ -156,36 +152,6 @@ final routerProvider = Provider<GoRouter>((ref) {
|
|||||||
),
|
),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
ShellRoute(
|
|
||||||
builder:
|
|
||||||
(context, state, child) =>
|
|
||||||
DeveloperHubShellScreen(child: child),
|
|
||||||
routes: [
|
|
||||||
GoRoute(
|
|
||||||
path: '/developers',
|
|
||||||
builder: (context, state) => const DeveloperHubScreen(),
|
|
||||||
),
|
|
||||||
GoRoute(
|
|
||||||
path: '/developers/:name/apps',
|
|
||||||
builder: (context, state) => CustomAppsScreen(
|
|
||||||
publisherName: state.pathParameters['name']!,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
GoRoute(
|
|
||||||
path: '/developers/:name/apps/new',
|
|
||||||
builder: (context, state) => NewCustomAppScreen(
|
|
||||||
publisherName: state.pathParameters['name']!,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
GoRoute(
|
|
||||||
path: '/developers/:name/apps/:id',
|
|
||||||
builder: (context, state) => EditAppScreen(
|
|
||||||
publisherName: state.pathParameters['name']!,
|
|
||||||
id: state.pathParameters['id']!,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
|
|
||||||
// Auth routes
|
// Auth routes
|
||||||
GoRoute(
|
GoRoute(
|
||||||
|
@ -178,9 +178,7 @@ class AccountScreen extends HookConsumerWidget {
|
|||||||
Text('developerPortalDescription').tr(),
|
Text('developerPortalDescription').tr(),
|
||||||
],
|
],
|
||||||
).padding(horizontal: 16, vertical: 12),
|
).padding(horizontal: 16, vertical: 12),
|
||||||
onTap: () {
|
onTap: () {},
|
||||||
context.push('/developers');
|
|
||||||
},
|
|
||||||
),
|
),
|
||||||
).height(140),
|
).height(140),
|
||||||
),
|
),
|
||||||
|
@ -676,36 +676,17 @@ class EditChatScreen extends HookConsumerWidget {
|
|||||||
(_) => FocusManager.instance.primaryFocus?.unfocus(),
|
(_) => FocusManager.instance.primaryFocus?.unfocus(),
|
||||||
),
|
),
|
||||||
const SizedBox(height: 16),
|
const SizedBox(height: 16),
|
||||||
Card(
|
|
||||||
margin: EdgeInsets.zero,
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
CheckboxListTile(
|
CheckboxListTile(
|
||||||
secondary: const Icon(Symbols.public),
|
title: const Text('isPublic').tr(),
|
||||||
title: Text('publicChat').tr(),
|
subtitle: const Text('isPublicHint').tr(),
|
||||||
subtitle: Text('publicChatDescription').tr(),
|
|
||||||
value: isPublic.value,
|
value: isPublic.value,
|
||||||
onChanged: (value) {
|
onChanged: (value) => isPublic.value = value ?? false,
|
||||||
isPublic.value = value ?? true;
|
|
||||||
},
|
|
||||||
shape: RoundedRectangleBorder(
|
|
||||||
borderRadius: BorderRadius.circular(8),
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
CheckboxListTile(
|
CheckboxListTile(
|
||||||
secondary: const Icon(Symbols.travel_explore),
|
title: const Text('isCommunity').tr(),
|
||||||
title: Text('communityChat').tr(),
|
subtitle: const Text('isCommunityHint').tr(),
|
||||||
subtitle: Text('communityChatDescription').tr(),
|
|
||||||
value: isCommunity.value,
|
value: isCommunity.value,
|
||||||
onChanged: (value) {
|
onChanged: (value) => isCommunity.value = value ?? false,
|
||||||
isCommunity.value = value ?? false;
|
|
||||||
},
|
|
||||||
shape: RoundedRectangleBorder(
|
|
||||||
borderRadius: BorderRadius.circular(8),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
const SizedBox(height: 16),
|
const SizedBox(height: 16),
|
||||||
Align(
|
Align(
|
||||||
|
@ -356,7 +356,13 @@ class CreatorHubScreen extends HookConsumerWidget {
|
|||||||
),
|
),
|
||||||
ListTile(
|
ListTile(
|
||||||
minTileHeight: 48,
|
minTileHeight: 48,
|
||||||
title: Text('publisherMembers').tr(),
|
title: Text('members').plural(
|
||||||
|
ref
|
||||||
|
.watch(publisherMemberStateProvider(
|
||||||
|
currentPublisher.value!.name,
|
||||||
|
))
|
||||||
|
.total,
|
||||||
|
),
|
||||||
trailing: Icon(Symbols.chevron_right),
|
trailing: Icon(Symbols.chevron_right),
|
||||||
leading: const Icon(Symbols.group),
|
leading: const Icon(Symbols.group),
|
||||||
contentPadding: EdgeInsets.symmetric(
|
contentPadding: EdgeInsets.symmetric(
|
||||||
@ -531,22 +537,23 @@ class PublisherMemberState {
|
|||||||
}
|
}
|
||||||
|
|
||||||
final publisherMemberStateProvider = StateNotifierProvider.family<
|
final publisherMemberStateProvider = StateNotifierProvider.family<
|
||||||
PublisherMemberNotifier,
|
PublisherMemberNotifier, PublisherMemberState, String>(
|
||||||
PublisherMemberState,
|
(ref, publisherUname) {
|
||||||
String
|
|
||||||
>((ref, publisherUname) {
|
|
||||||
final apiClient = ref.watch(apiClientProvider);
|
final apiClient = ref.watch(apiClientProvider);
|
||||||
return PublisherMemberNotifier(apiClient, publisherUname);
|
return PublisherMemberNotifier(apiClient, publisherUname);
|
||||||
});
|
},
|
||||||
|
);
|
||||||
|
|
||||||
class PublisherMemberNotifier extends StateNotifier<PublisherMemberState> {
|
class PublisherMemberNotifier extends StateNotifier<PublisherMemberState> {
|
||||||
final String publisherUname;
|
final String publisherUname;
|
||||||
final Dio _apiClient;
|
final Dio _apiClient;
|
||||||
|
|
||||||
PublisherMemberNotifier(this._apiClient, this.publisherUname)
|
PublisherMemberNotifier(this._apiClient, this.publisherUname)
|
||||||
: super(
|
: super(const PublisherMemberState(
|
||||||
const PublisherMemberState(members: [], isLoading: false, total: 0),
|
members: [],
|
||||||
);
|
isLoading: false,
|
||||||
|
total: 0,
|
||||||
|
));
|
||||||
|
|
||||||
Future<void> loadMore({int offset = 0, int take = 20}) async {
|
Future<void> loadMore({int offset = 0, int take = 20}) async {
|
||||||
if (state.isLoading) return;
|
if (state.isLoading) return;
|
||||||
@ -562,7 +569,8 @@ class PublisherMemberNotifier extends StateNotifier<PublisherMemberState> {
|
|||||||
|
|
||||||
final total = int.parse(response.headers.value('X-Total') ?? '0');
|
final total = int.parse(response.headers.value('X-Total') ?? '0');
|
||||||
final List<dynamic> data = response.data;
|
final List<dynamic> data = response.data;
|
||||||
final members = data.map((e) => SnPublisherMember.fromJson(e)).toList();
|
final members =
|
||||||
|
data.map((e) => SnPublisherMember.fromJson(e)).toList();
|
||||||
|
|
||||||
state = state.copyWith(
|
state = state.copyWith(
|
||||||
members: [...state.members, ...members],
|
members: [...state.members, ...members],
|
||||||
@ -588,9 +596,8 @@ class _PublisherMemberListSheet extends HookConsumerWidget {
|
|||||||
final publisherIdentity = ref.watch(
|
final publisherIdentity = ref.watch(
|
||||||
publisherIdentityProvider(publisherUname),
|
publisherIdentityProvider(publisherUname),
|
||||||
);
|
);
|
||||||
final memberListProvider = publisherMemberListNotifierProvider(
|
final memberListProvider =
|
||||||
publisherUname,
|
publisherMemberListNotifierProvider(publisherUname);
|
||||||
);
|
|
||||||
final memberState = ref.watch(publisherMemberStateProvider(publisherUname));
|
final memberState = ref.watch(publisherMemberStateProvider(publisherUname));
|
||||||
final memberNotifier = ref.read(
|
final memberNotifier = ref.read(
|
||||||
publisherMemberStateProvider(publisherUname).notifier,
|
publisherMemberStateProvider(publisherUname).notifier,
|
||||||
|
@ -1,65 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:easy_localization/easy_localization.dart';
|
|
||||||
import 'package:go_router/go_router.dart';
|
|
||||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
||||||
import 'package:island/models/custom_app.dart';
|
|
||||||
import 'package:island/pods/network.dart';
|
|
||||||
import 'package:island/widgets/app_scaffold.dart';
|
|
||||||
import 'package:island/widgets/response.dart';
|
|
||||||
import 'package:material_symbols_icons/symbols.dart';
|
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
||||||
|
|
||||||
part 'apps.g.dart';
|
|
||||||
|
|
||||||
@riverpod
|
|
||||||
Future<List<CustomApp>> customApps(Ref ref, String publisherName) async {
|
|
||||||
final client = ref.watch(apiClientProvider);
|
|
||||||
final resp = await client.get('/developers/$publisherName/apps');
|
|
||||||
return resp.data.map((e) => CustomApp.fromJson(e)).cast<CustomApp>().toList();
|
|
||||||
}
|
|
||||||
|
|
||||||
class CustomAppsScreen extends HookConsumerWidget {
|
|
||||||
final String publisherName;
|
|
||||||
const CustomAppsScreen({super.key, required this.publisherName});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context, WidgetRef ref) {
|
|
||||||
final apps = ref.watch(customAppsProvider(publisherName));
|
|
||||||
|
|
||||||
return AppScaffold(
|
|
||||||
appBar: AppBar(title: Text('customApps').tr()),
|
|
||||||
floatingActionButton: FloatingActionButton(
|
|
||||||
child: const Icon(Symbols.add),
|
|
||||||
onPressed: () {
|
|
||||||
context.push('/developers/$publisherName/apps/new');
|
|
||||||
},
|
|
||||||
),
|
|
||||||
body: apps.when(
|
|
||||||
data: (data) {
|
|
||||||
if (data.isEmpty) {
|
|
||||||
return Center(child: Text('noCustomApps').tr());
|
|
||||||
}
|
|
||||||
return ListView.builder(
|
|
||||||
itemCount: data.length,
|
|
||||||
itemBuilder: (context, index) {
|
|
||||||
final app = data[index];
|
|
||||||
return ListTile(
|
|
||||||
title: Text(app.name),
|
|
||||||
subtitle: Text(app.slug),
|
|
||||||
onTap: () {
|
|
||||||
context.push('/developers/$publisherName/apps/${app.id}');
|
|
||||||
},
|
|
||||||
);
|
|
||||||
},
|
|
||||||
);
|
|
||||||
},
|
|
||||||
loading: () => const Center(child: CircularProgressIndicator()),
|
|
||||||
error:
|
|
||||||
(err, stack) => ResponseErrorWidget(
|
|
||||||
error: err,
|
|
||||||
onRetry: () => ref.invalidate(customAppsProvider(publisherName)),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,151 +0,0 @@
|
|||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
|
|
||||||
part of 'apps.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// RiverpodGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
String _$customAppsHash() => r'1dec11573b9d987c3adbdf4732b3781a6f40172a';
|
|
||||||
|
|
||||||
/// Copied from Dart SDK
|
|
||||||
class _SystemHash {
|
|
||||||
_SystemHash._();
|
|
||||||
|
|
||||||
static int combine(int hash, int value) {
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + value);
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + ((0x0007ffff & hash) << 10));
|
|
||||||
return hash ^ (hash >> 6);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int finish(int hash) {
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + ((0x03ffffff & hash) << 3));
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = hash ^ (hash >> 11);
|
|
||||||
return 0x1fffffff & (hash + ((0x00003fff & hash) << 15));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// See also [customApps].
|
|
||||||
@ProviderFor(customApps)
|
|
||||||
const customAppsProvider = CustomAppsFamily();
|
|
||||||
|
|
||||||
/// See also [customApps].
|
|
||||||
class CustomAppsFamily extends Family<AsyncValue<List<CustomApp>>> {
|
|
||||||
/// See also [customApps].
|
|
||||||
const CustomAppsFamily();
|
|
||||||
|
|
||||||
/// See also [customApps].
|
|
||||||
CustomAppsProvider call(String publisherName) {
|
|
||||||
return CustomAppsProvider(publisherName);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
CustomAppsProvider getProviderOverride(
|
|
||||||
covariant CustomAppsProvider provider,
|
|
||||||
) {
|
|
||||||
return call(provider.publisherName);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const Iterable<ProviderOrFamily>? _dependencies = null;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Iterable<ProviderOrFamily>? get dependencies => _dependencies;
|
|
||||||
|
|
||||||
static const Iterable<ProviderOrFamily>? _allTransitiveDependencies = null;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Iterable<ProviderOrFamily>? get allTransitiveDependencies =>
|
|
||||||
_allTransitiveDependencies;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String? get name => r'customAppsProvider';
|
|
||||||
}
|
|
||||||
|
|
||||||
/// See also [customApps].
|
|
||||||
class CustomAppsProvider extends AutoDisposeFutureProvider<List<CustomApp>> {
|
|
||||||
/// See also [customApps].
|
|
||||||
CustomAppsProvider(String publisherName)
|
|
||||||
: this._internal(
|
|
||||||
(ref) => customApps(ref as CustomAppsRef, publisherName),
|
|
||||||
from: customAppsProvider,
|
|
||||||
name: r'customAppsProvider',
|
|
||||||
debugGetCreateSourceHash:
|
|
||||||
const bool.fromEnvironment('dart.vm.product')
|
|
||||||
? null
|
|
||||||
: _$customAppsHash,
|
|
||||||
dependencies: CustomAppsFamily._dependencies,
|
|
||||||
allTransitiveDependencies: CustomAppsFamily._allTransitiveDependencies,
|
|
||||||
publisherName: publisherName,
|
|
||||||
);
|
|
||||||
|
|
||||||
CustomAppsProvider._internal(
|
|
||||||
super._createNotifier, {
|
|
||||||
required super.name,
|
|
||||||
required super.dependencies,
|
|
||||||
required super.allTransitiveDependencies,
|
|
||||||
required super.debugGetCreateSourceHash,
|
|
||||||
required super.from,
|
|
||||||
required this.publisherName,
|
|
||||||
}) : super.internal();
|
|
||||||
|
|
||||||
final String publisherName;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Override overrideWith(
|
|
||||||
FutureOr<List<CustomApp>> Function(CustomAppsRef provider) create,
|
|
||||||
) {
|
|
||||||
return ProviderOverride(
|
|
||||||
origin: this,
|
|
||||||
override: CustomAppsProvider._internal(
|
|
||||||
(ref) => create(ref as CustomAppsRef),
|
|
||||||
from: from,
|
|
||||||
name: null,
|
|
||||||
dependencies: null,
|
|
||||||
allTransitiveDependencies: null,
|
|
||||||
debugGetCreateSourceHash: null,
|
|
||||||
publisherName: publisherName,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
AutoDisposeFutureProviderElement<List<CustomApp>> createElement() {
|
|
||||||
return _CustomAppsProviderElement(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return other is CustomAppsProvider && other.publisherName == publisherName;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
int get hashCode {
|
|
||||||
var hash = _SystemHash.combine(0, runtimeType.hashCode);
|
|
||||||
hash = _SystemHash.combine(hash, publisherName.hashCode);
|
|
||||||
|
|
||||||
return _SystemHash.finish(hash);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated('Will be removed in 3.0. Use Ref instead')
|
|
||||||
// ignore: unused_element
|
|
||||||
mixin CustomAppsRef on AutoDisposeFutureProviderRef<List<CustomApp>> {
|
|
||||||
/// The parameter `publisherName` of this provider.
|
|
||||||
String get publisherName;
|
|
||||||
}
|
|
||||||
|
|
||||||
class _CustomAppsProviderElement
|
|
||||||
extends AutoDisposeFutureProviderElement<List<CustomApp>>
|
|
||||||
with CustomAppsRef {
|
|
||||||
_CustomAppsProviderElement(super.provider);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String get publisherName => (origin as CustomAppsProvider).publisherName;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ignore_for_file: type=lint
|
|
||||||
// ignore_for_file: subtype_of_sealed_class, invalid_use_of_internal_member, invalid_use_of_visible_for_testing_member, deprecated_member_use_from_same_package
|
|
@ -1,253 +0,0 @@
|
|||||||
import 'package:croppy/croppy.dart' hide cropImage;
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:easy_localization/easy_localization.dart';
|
|
||||||
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
||||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
||||||
import 'package:image_picker/image_picker.dart';
|
|
||||||
import 'package:island/models/custom_app.dart';
|
|
||||||
import 'package:island/models/file.dart';
|
|
||||||
import 'package:island/pods/config.dart';
|
|
||||||
import 'package:island/pods/network.dart';
|
|
||||||
import 'package:island/screens/developers/apps.dart';
|
|
||||||
import 'package:island/services/file.dart';
|
|
||||||
import 'package:island/widgets/alert.dart';
|
|
||||||
import 'package:island/widgets/app_scaffold.dart';
|
|
||||||
import 'package:island/widgets/content/cloud_files.dart';
|
|
||||||
import 'package:island/widgets/response.dart';
|
|
||||||
import 'package:material_symbols_icons/symbols.dart';
|
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
||||||
import 'package:styled_widget/styled_widget.dart';
|
|
||||||
|
|
||||||
part 'edit_app.g.dart';
|
|
||||||
|
|
||||||
@riverpod
|
|
||||||
Future<CustomApp?> customApp(Ref ref, String publisherName, String id) async {
|
|
||||||
final client = ref.watch(apiClientProvider);
|
|
||||||
final resp = await client.get('/developers/$publisherName/apps/$id');
|
|
||||||
return CustomApp.fromJson(resp.data);
|
|
||||||
}
|
|
||||||
|
|
||||||
class EditAppScreen extends HookConsumerWidget {
|
|
||||||
final String publisherName;
|
|
||||||
final String? id;
|
|
||||||
const EditAppScreen({super.key, required this.publisherName, this.id});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context, WidgetRef ref) {
|
|
||||||
final isNew = id == null;
|
|
||||||
final app = isNew ? null : ref.watch(customAppProvider(publisherName, id!));
|
|
||||||
|
|
||||||
final formKey = useMemoized(() => GlobalKey<FormState>());
|
|
||||||
|
|
||||||
final nameController = useTextEditingController();
|
|
||||||
final slugController = useTextEditingController();
|
|
||||||
final descriptionController = useTextEditingController();
|
|
||||||
final picture = useState<SnCloudFile?>(null);
|
|
||||||
final background = useState<SnCloudFile?>(null);
|
|
||||||
|
|
||||||
final submitting = useState(false);
|
|
||||||
|
|
||||||
useEffect(() {
|
|
||||||
if (app?.value != null) {
|
|
||||||
nameController.text = app!.value!.name;
|
|
||||||
slugController.text = app.value!.slug;
|
|
||||||
descriptionController.text = app.value!.description ?? '';
|
|
||||||
picture.value = app.value!.picture;
|
|
||||||
background.value = app.value!.background;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}, [app]);
|
|
||||||
|
|
||||||
void setPicture(String position) async {
|
|
||||||
showLoadingModal(context);
|
|
||||||
var result = await ref
|
|
||||||
.read(imagePickerProvider)
|
|
||||||
.pickImage(source: ImageSource.gallery);
|
|
||||||
if (result == null) {
|
|
||||||
if (context.mounted) hideLoadingModal(context);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!context.mounted) return;
|
|
||||||
hideLoadingModal(context);
|
|
||||||
result = await cropImage(
|
|
||||||
context,
|
|
||||||
image: result,
|
|
||||||
allowedAspectRatios: [
|
|
||||||
if (position == 'background')
|
|
||||||
const CropAspectRatio(height: 7, width: 16)
|
|
||||||
else
|
|
||||||
const CropAspectRatio(height: 1, width: 1),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
if (result == null) {
|
|
||||||
if (context.mounted) hideLoadingModal(context);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!context.mounted) return;
|
|
||||||
showLoadingModal(context);
|
|
||||||
|
|
||||||
submitting.value = true;
|
|
||||||
try {
|
|
||||||
final baseUrl = ref.watch(serverUrlProvider);
|
|
||||||
final token = await getToken(ref.watch(tokenProvider));
|
|
||||||
if (token == null) throw ArgumentError('Token is null');
|
|
||||||
final cloudFile =
|
|
||||||
await putMediaToCloud(
|
|
||||||
fileData: UniversalFile(
|
|
||||||
data: result,
|
|
||||||
type: UniversalFileType.image,
|
|
||||||
),
|
|
||||||
atk: token,
|
|
||||||
baseUrl: baseUrl,
|
|
||||||
filename: result.name,
|
|
||||||
mimetype: result.mimeType ?? 'image/jpeg',
|
|
||||||
).future;
|
|
||||||
if (cloudFile == null) {
|
|
||||||
throw ArgumentError('Failed to upload the file...');
|
|
||||||
}
|
|
||||||
switch (position) {
|
|
||||||
case 'picture':
|
|
||||||
picture.value = cloudFile;
|
|
||||||
case 'background':
|
|
||||||
background.value = cloudFile;
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
showErrorAlert(err);
|
|
||||||
} finally {
|
|
||||||
if (context.mounted) hideLoadingModal(context);
|
|
||||||
submitting.value = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void performAction() async {
|
|
||||||
final client = ref.read(apiClientProvider);
|
|
||||||
final data = {
|
|
||||||
'name': nameController.text,
|
|
||||||
'slug': slugController.text,
|
|
||||||
'description': descriptionController.text,
|
|
||||||
'picture_id': picture.value?.id,
|
|
||||||
'background_id': background.value?.id,
|
|
||||||
};
|
|
||||||
if (isNew) {
|
|
||||||
await client.post('/developers/$publisherName/apps', data: data);
|
|
||||||
} else {
|
|
||||||
await client.patch('/developers/$publisherName/apps/$id', data: data);
|
|
||||||
}
|
|
||||||
ref.invalidate(customAppsProvider(publisherName));
|
|
||||||
if (context.mounted) {
|
|
||||||
Navigator.pop(context);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return AppScaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
title: Text(isNew ? 'createCustomApp'.tr() : 'editCustomApp'.tr()),
|
|
||||||
),
|
|
||||||
body:
|
|
||||||
app == null && !isNew
|
|
||||||
? const Center(child: CircularProgressIndicator())
|
|
||||||
: app?.hasError == true && !isNew
|
|
||||||
? ResponseErrorWidget(
|
|
||||||
error: app!.error,
|
|
||||||
onRetry:
|
|
||||||
() => ref.invalidate(customAppProvider(publisherName, id!)),
|
|
||||||
)
|
|
||||||
: SingleChildScrollView(
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
AspectRatio(
|
|
||||||
aspectRatio: 16 / 7,
|
|
||||||
child: Stack(
|
|
||||||
clipBehavior: Clip.none,
|
|
||||||
fit: StackFit.expand,
|
|
||||||
children: [
|
|
||||||
GestureDetector(
|
|
||||||
child: Container(
|
|
||||||
color:
|
|
||||||
Theme.of(
|
|
||||||
context,
|
|
||||||
).colorScheme.surfaceContainerHigh,
|
|
||||||
child:
|
|
||||||
background.value != null
|
|
||||||
? CloudFileWidget(
|
|
||||||
item: background.value!,
|
|
||||||
fit: BoxFit.cover,
|
|
||||||
)
|
|
||||||
: const SizedBox.shrink(),
|
|
||||||
),
|
|
||||||
onTap: () {
|
|
||||||
setPicture('background');
|
|
||||||
},
|
|
||||||
),
|
|
||||||
Positioned(
|
|
||||||
left: 20,
|
|
||||||
bottom: -32,
|
|
||||||
child: GestureDetector(
|
|
||||||
child: ProfilePictureWidget(
|
|
||||||
fileId: picture.value?.id,
|
|
||||||
radius: 40,
|
|
||||||
fallbackIcon: Symbols.apps,
|
|
||||||
),
|
|
||||||
onTap: () {
|
|
||||||
setPicture('picture');
|
|
||||||
},
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
).padding(bottom: 32),
|
|
||||||
Form(
|
|
||||||
key: formKey,
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
TextFormField(
|
|
||||||
controller: nameController,
|
|
||||||
decoration: InputDecoration(labelText: 'name'.tr()),
|
|
||||||
onTapOutside:
|
|
||||||
(_) =>
|
|
||||||
FocusManager.instance.primaryFocus
|
|
||||||
?.unfocus(),
|
|
||||||
),
|
|
||||||
const SizedBox(height: 16),
|
|
||||||
TextFormField(
|
|
||||||
controller: slugController,
|
|
||||||
decoration: InputDecoration(
|
|
||||||
labelText: 'slug'.tr(),
|
|
||||||
helperText: 'slugHint'.tr(),
|
|
||||||
),
|
|
||||||
onTapOutside:
|
|
||||||
(_) =>
|
|
||||||
FocusManager.instance.primaryFocus
|
|
||||||
?.unfocus(),
|
|
||||||
),
|
|
||||||
const SizedBox(height: 16),
|
|
||||||
TextFormField(
|
|
||||||
controller: descriptionController,
|
|
||||||
decoration: InputDecoration(
|
|
||||||
labelText: 'description'.tr(),
|
|
||||||
),
|
|
||||||
maxLines: 3,
|
|
||||||
onTapOutside:
|
|
||||||
(_) =>
|
|
||||||
FocusManager.instance.primaryFocus
|
|
||||||
?.unfocus(),
|
|
||||||
),
|
|
||||||
const SizedBox(height: 16),
|
|
||||||
Align(
|
|
||||||
alignment: Alignment.centerRight,
|
|
||||||
child: TextButton.icon(
|
|
||||||
onPressed:
|
|
||||||
submitting.value ? null : performAction,
|
|
||||||
label: Text('saveChanges'.tr()),
|
|
||||||
icon: const Icon(Symbols.save),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
).padding(all: 24),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,161 +0,0 @@
|
|||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
|
|
||||||
part of 'edit_app.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// RiverpodGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
String _$customAppHash() => r'aa4d1fb803c47a99cbacf6d91481f4fce3fda457';
|
|
||||||
|
|
||||||
/// Copied from Dart SDK
|
|
||||||
class _SystemHash {
|
|
||||||
_SystemHash._();
|
|
||||||
|
|
||||||
static int combine(int hash, int value) {
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + value);
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + ((0x0007ffff & hash) << 10));
|
|
||||||
return hash ^ (hash >> 6);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int finish(int hash) {
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + ((0x03ffffff & hash) << 3));
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = hash ^ (hash >> 11);
|
|
||||||
return 0x1fffffff & (hash + ((0x00003fff & hash) << 15));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// See also [customApp].
|
|
||||||
@ProviderFor(customApp)
|
|
||||||
const customAppProvider = CustomAppFamily();
|
|
||||||
|
|
||||||
/// See also [customApp].
|
|
||||||
class CustomAppFamily extends Family<AsyncValue<CustomApp?>> {
|
|
||||||
/// See also [customApp].
|
|
||||||
const CustomAppFamily();
|
|
||||||
|
|
||||||
/// See also [customApp].
|
|
||||||
CustomAppProvider call(String publisherName, String id) {
|
|
||||||
return CustomAppProvider(publisherName, id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
CustomAppProvider getProviderOverride(covariant CustomAppProvider provider) {
|
|
||||||
return call(provider.publisherName, provider.id);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const Iterable<ProviderOrFamily>? _dependencies = null;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Iterable<ProviderOrFamily>? get dependencies => _dependencies;
|
|
||||||
|
|
||||||
static const Iterable<ProviderOrFamily>? _allTransitiveDependencies = null;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Iterable<ProviderOrFamily>? get allTransitiveDependencies =>
|
|
||||||
_allTransitiveDependencies;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String? get name => r'customAppProvider';
|
|
||||||
}
|
|
||||||
|
|
||||||
/// See also [customApp].
|
|
||||||
class CustomAppProvider extends AutoDisposeFutureProvider<CustomApp?> {
|
|
||||||
/// See also [customApp].
|
|
||||||
CustomAppProvider(String publisherName, String id)
|
|
||||||
: this._internal(
|
|
||||||
(ref) => customApp(ref as CustomAppRef, publisherName, id),
|
|
||||||
from: customAppProvider,
|
|
||||||
name: r'customAppProvider',
|
|
||||||
debugGetCreateSourceHash:
|
|
||||||
const bool.fromEnvironment('dart.vm.product')
|
|
||||||
? null
|
|
||||||
: _$customAppHash,
|
|
||||||
dependencies: CustomAppFamily._dependencies,
|
|
||||||
allTransitiveDependencies: CustomAppFamily._allTransitiveDependencies,
|
|
||||||
publisherName: publisherName,
|
|
||||||
id: id,
|
|
||||||
);
|
|
||||||
|
|
||||||
CustomAppProvider._internal(
|
|
||||||
super._createNotifier, {
|
|
||||||
required super.name,
|
|
||||||
required super.dependencies,
|
|
||||||
required super.allTransitiveDependencies,
|
|
||||||
required super.debugGetCreateSourceHash,
|
|
||||||
required super.from,
|
|
||||||
required this.publisherName,
|
|
||||||
required this.id,
|
|
||||||
}) : super.internal();
|
|
||||||
|
|
||||||
final String publisherName;
|
|
||||||
final String id;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Override overrideWith(
|
|
||||||
FutureOr<CustomApp?> Function(CustomAppRef provider) create,
|
|
||||||
) {
|
|
||||||
return ProviderOverride(
|
|
||||||
origin: this,
|
|
||||||
override: CustomAppProvider._internal(
|
|
||||||
(ref) => create(ref as CustomAppRef),
|
|
||||||
from: from,
|
|
||||||
name: null,
|
|
||||||
dependencies: null,
|
|
||||||
allTransitiveDependencies: null,
|
|
||||||
debugGetCreateSourceHash: null,
|
|
||||||
publisherName: publisherName,
|
|
||||||
id: id,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
AutoDisposeFutureProviderElement<CustomApp?> createElement() {
|
|
||||||
return _CustomAppProviderElement(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return other is CustomAppProvider &&
|
|
||||||
other.publisherName == publisherName &&
|
|
||||||
other.id == id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
int get hashCode {
|
|
||||||
var hash = _SystemHash.combine(0, runtimeType.hashCode);
|
|
||||||
hash = _SystemHash.combine(hash, publisherName.hashCode);
|
|
||||||
hash = _SystemHash.combine(hash, id.hashCode);
|
|
||||||
|
|
||||||
return _SystemHash.finish(hash);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated('Will be removed in 3.0. Use Ref instead')
|
|
||||||
// ignore: unused_element
|
|
||||||
mixin CustomAppRef on AutoDisposeFutureProviderRef<CustomApp?> {
|
|
||||||
/// The parameter `publisherName` of this provider.
|
|
||||||
String get publisherName;
|
|
||||||
|
|
||||||
/// The parameter `id` of this provider.
|
|
||||||
String get id;
|
|
||||||
}
|
|
||||||
|
|
||||||
class _CustomAppProviderElement
|
|
||||||
extends AutoDisposeFutureProviderElement<CustomApp?>
|
|
||||||
with CustomAppRef {
|
|
||||||
_CustomAppProviderElement(super.provider);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String get publisherName => (origin as CustomAppProvider).publisherName;
|
|
||||||
@override
|
|
||||||
String get id => (origin as CustomAppProvider).id;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ignore_for_file: type=lint
|
|
||||||
// ignore_for_file: subtype_of_sealed_class, invalid_use_of_internal_member, invalid_use_of_visible_for_testing_member, deprecated_member_use_from_same_package
|
|
@ -1,380 +0,0 @@
|
|||||||
import 'package:dropdown_button2/dropdown_button2.dart';
|
|
||||||
import 'package:easy_localization/easy_localization.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
||||||
import 'package:gap/gap.dart';
|
|
||||||
import 'package:go_router/go_router.dart';
|
|
||||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
||||||
import 'package:island/models/developer.dart';
|
|
||||||
import 'package:island/models/publisher.dart';
|
|
||||||
import 'package:island/pods/network.dart';
|
|
||||||
import 'package:island/screens/creators/publishers.dart';
|
|
||||||
import 'package:island/services/responsive.dart';
|
|
||||||
import 'package:island/widgets/alert.dart';
|
|
||||||
import 'package:island/widgets/app_scaffold.dart';
|
|
||||||
import 'package:island/widgets/content/cloud_files.dart';
|
|
||||||
import 'package:island/widgets/content/sheet.dart';
|
|
||||||
import 'package:island/widgets/response.dart';
|
|
||||||
import 'package:material_symbols_icons/symbols.dart';
|
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
||||||
import 'package:styled_widget/styled_widget.dart';
|
|
||||||
|
|
||||||
part 'hub.g.dart';
|
|
||||||
|
|
||||||
@riverpod
|
|
||||||
Future<DeveloperStats?> developerStats(Ref ref, String? uname) async {
|
|
||||||
if (uname == null) return null;
|
|
||||||
final apiClient = ref.watch(apiClientProvider);
|
|
||||||
final resp = await apiClient.get('/developers/$uname/stats');
|
|
||||||
return DeveloperStats.fromJson(resp.data);
|
|
||||||
}
|
|
||||||
|
|
||||||
@riverpod
|
|
||||||
Future<List<SnPublisher>> developers(Ref ref) async {
|
|
||||||
final client = ref.watch(apiClientProvider);
|
|
||||||
final resp = await client.get('/developers');
|
|
||||||
return resp.data
|
|
||||||
.map((e) => SnPublisher.fromJson(e))
|
|
||||||
.cast<SnPublisher>()
|
|
||||||
.toList();
|
|
||||||
}
|
|
||||||
|
|
||||||
class DeveloperHubShellScreen extends StatelessWidget {
|
|
||||||
final Widget child;
|
|
||||||
const DeveloperHubShellScreen({super.key, required this.child});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final isWide = isWideScreen(context);
|
|
||||||
if (isWide) {
|
|
||||||
return Row(
|
|
||||||
children: [
|
|
||||||
SizedBox(width: 360, child: const DeveloperHubScreen(isAside: true)),
|
|
||||||
const VerticalDivider(width: 1),
|
|
||||||
Expanded(child: child),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return child;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class DeveloperHubScreen extends HookConsumerWidget {
|
|
||||||
final bool isAside;
|
|
||||||
const DeveloperHubScreen({super.key, this.isAside = false});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context, WidgetRef ref) {
|
|
||||||
final isWide = isWideScreen(context);
|
|
||||||
if (isWide && !isAside) {
|
|
||||||
return Container(color: Theme.of(context).colorScheme.surface);
|
|
||||||
}
|
|
||||||
|
|
||||||
final developers = ref.watch(developersProvider);
|
|
||||||
final currentDeveloper = useState<SnPublisher?>(
|
|
||||||
developers.value?.firstOrNull,
|
|
||||||
);
|
|
||||||
|
|
||||||
final List<DropdownMenuItem<SnPublisher>> developersMenu = developers.when(
|
|
||||||
data:
|
|
||||||
(data) =>
|
|
||||||
data
|
|
||||||
.map(
|
|
||||||
(item) => DropdownMenuItem<SnPublisher>(
|
|
||||||
value: item,
|
|
||||||
child: ListTile(
|
|
||||||
minTileHeight: 48,
|
|
||||||
leading: ProfilePictureWidget(
|
|
||||||
radius: 16,
|
|
||||||
fileId: item.picture?.id,
|
|
||||||
),
|
|
||||||
title: Text(item.nick),
|
|
||||||
subtitle: Text('@${item.name}'),
|
|
||||||
trailing:
|
|
||||||
currentDeveloper.value?.id == item.id
|
|
||||||
? const Icon(Icons.check)
|
|
||||||
: null,
|
|
||||||
contentPadding: EdgeInsets.symmetric(horizontal: 8),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
.toList(),
|
|
||||||
loading: () => [],
|
|
||||||
error: (_, _) => [],
|
|
||||||
);
|
|
||||||
|
|
||||||
final developerStats = ref.watch(
|
|
||||||
developerStatsProvider(currentDeveloper.value?.name),
|
|
||||||
);
|
|
||||||
|
|
||||||
return AppScaffold(
|
|
||||||
noBackground: false,
|
|
||||||
appBar: AppBar(
|
|
||||||
leading: !isWide ? const PageBackButton() : null,
|
|
||||||
title: Text('developerHub').tr(),
|
|
||||||
actions: [
|
|
||||||
DropdownButtonHideUnderline(
|
|
||||||
child: DropdownButton2<SnPublisher>(
|
|
||||||
alignment: Alignment.centerRight,
|
|
||||||
value: currentDeveloper.value,
|
|
||||||
hint: CircleAvatar(
|
|
||||||
radius: 16,
|
|
||||||
child: Icon(
|
|
||||||
Symbols.person,
|
|
||||||
color: Theme.of(
|
|
||||||
context,
|
|
||||||
).colorScheme.onSecondaryContainer.withOpacity(0.9),
|
|
||||||
fill: 1,
|
|
||||||
),
|
|
||||||
).center().padding(right: 8),
|
|
||||||
items: [...developersMenu],
|
|
||||||
onChanged: (value) {
|
|
||||||
currentDeveloper.value = value;
|
|
||||||
},
|
|
||||||
selectedItemBuilder: (context) {
|
|
||||||
return [
|
|
||||||
...developersMenu.map(
|
|
||||||
(e) => ProfilePictureWidget(
|
|
||||||
radius: 16,
|
|
||||||
fileId: e.value?.picture?.id,
|
|
||||||
).center().padding(right: 8),
|
|
||||||
),
|
|
||||||
];
|
|
||||||
},
|
|
||||||
buttonStyleData: ButtonStyleData(
|
|
||||||
height: 40,
|
|
||||||
padding: const EdgeInsets.only(left: 14, right: 8),
|
|
||||||
decoration: BoxDecoration(
|
|
||||||
borderRadius: BorderRadius.circular(20),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
dropdownStyleData: DropdownStyleData(
|
|
||||||
width: 320,
|
|
||||||
padding: const EdgeInsets.symmetric(vertical: 6),
|
|
||||||
decoration: BoxDecoration(
|
|
||||||
borderRadius: BorderRadius.circular(4),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
menuItemStyleData: const MenuItemStyleData(
|
|
||||||
height: 64,
|
|
||||||
padding: EdgeInsets.only(left: 14, right: 14),
|
|
||||||
),
|
|
||||||
iconStyleData: IconStyleData(
|
|
||||||
icon: Icon(Icons.arrow_drop_down),
|
|
||||||
iconSize: 19,
|
|
||||||
iconEnabledColor:
|
|
||||||
Theme.of(context).appBarTheme.foregroundColor!,
|
|
||||||
iconDisabledColor:
|
|
||||||
Theme.of(context).appBarTheme.foregroundColor!,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
const Gap(8),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
body: developerStats.when(
|
|
||||||
data:
|
|
||||||
(stats) => SingleChildScrollView(
|
|
||||||
child:
|
|
||||||
currentDeveloper.value == null
|
|
||||||
? Column(
|
|
||||||
children: [
|
|
||||||
const Gap(24),
|
|
||||||
const Icon(Symbols.info, size: 32).padding(bottom: 4),
|
|
||||||
Text(
|
|
||||||
'developerHubUnselectedHint',
|
|
||||||
textAlign: TextAlign.center,
|
|
||||||
).tr(),
|
|
||||||
const Gap(24),
|
|
||||||
const Divider(height: 1),
|
|
||||||
...(developers.value?.map(
|
|
||||||
(developer) => ListTile(
|
|
||||||
leading: ProfilePictureWidget(
|
|
||||||
file: developer.picture,
|
|
||||||
),
|
|
||||||
title: Text(developer.nick),
|
|
||||||
subtitle: Text('@${developer.name}'),
|
|
||||||
onTap: () {
|
|
||||||
currentDeveloper.value = developer;
|
|
||||||
},
|
|
||||||
),
|
|
||||||
) ??
|
|
||||||
[]),
|
|
||||||
ListTile(
|
|
||||||
leading: const CircleAvatar(
|
|
||||||
child: Icon(Symbols.add),
|
|
||||||
),
|
|
||||||
title: Text('enrollDeveloper').tr(),
|
|
||||||
subtitle: Text('enrollDeveloperHint').tr(),
|
|
||||||
trailing: const Icon(Symbols.chevron_right),
|
|
||||||
onTap: () {
|
|
||||||
showModalBottomSheet(
|
|
||||||
context: context,
|
|
||||||
isScrollControlled: true,
|
|
||||||
builder:
|
|
||||||
(_) => const _DeveloperEnrollmentSheet(),
|
|
||||||
).then((value) {
|
|
||||||
if (value == true) {
|
|
||||||
ref.invalidate(developersProvider);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
: Column(
|
|
||||||
children: [
|
|
||||||
if (stats != null)
|
|
||||||
_DeveloperStatsWidget(
|
|
||||||
stats: stats,
|
|
||||||
).padding(vertical: 12, horizontal: 12),
|
|
||||||
ListTile(
|
|
||||||
minTileHeight: 48,
|
|
||||||
title: Text('customApps').tr(),
|
|
||||||
trailing: Icon(Symbols.chevron_right),
|
|
||||||
leading: const Icon(Symbols.apps),
|
|
||||||
contentPadding: EdgeInsets.symmetric(
|
|
||||||
horizontal: 24,
|
|
||||||
),
|
|
||||||
onTap: () {
|
|
||||||
context.push(
|
|
||||||
'/developers/${currentDeveloper.value!.name}/apps',
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
loading: () => const Center(child: CircularProgressIndicator()),
|
|
||||||
error:
|
|
||||||
(err, stack) => ResponseErrorWidget(
|
|
||||||
error: err,
|
|
||||||
onRetry: () {
|
|
||||||
ref.invalidate(
|
|
||||||
developerStatsProvider(currentDeveloper.value?.name),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _DeveloperStatsWidget extends StatelessWidget {
|
|
||||||
final DeveloperStats stats;
|
|
||||||
const _DeveloperStatsWidget({required this.stats});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return SingleChildScrollView(
|
|
||||||
child: Column(
|
|
||||||
spacing: 8,
|
|
||||||
children: [
|
|
||||||
Row(
|
|
||||||
spacing: 8,
|
|
||||||
children: [
|
|
||||||
Expanded(
|
|
||||||
child: _buildStatsCard(
|
|
||||||
context,
|
|
||||||
stats.totalCustomApps.toString(),
|
|
||||||
'totalCustomApps',
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
Widget _buildStatsCard(
|
|
||||||
BuildContext context,
|
|
||||||
String statValue,
|
|
||||||
String statLabel,
|
|
||||||
) {
|
|
||||||
return Card(
|
|
||||||
margin: EdgeInsets.zero,
|
|
||||||
child: SizedBox(
|
|
||||||
height: 100,
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 8),
|
|
||||||
child: Column(
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
children: [
|
|
||||||
Text(
|
|
||||||
statValue,
|
|
||||||
style: Theme.of(context).textTheme.headlineMedium,
|
|
||||||
),
|
|
||||||
const Gap(4),
|
|
||||||
Text(
|
|
||||||
statLabel,
|
|
||||||
maxLines: 1,
|
|
||||||
overflow: TextOverflow.ellipsis,
|
|
||||||
).tr(),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _DeveloperEnrollmentSheet extends HookConsumerWidget {
|
|
||||||
const _DeveloperEnrollmentSheet();
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context, WidgetRef ref) {
|
|
||||||
final publishers = ref.watch(publishersManagedProvider);
|
|
||||||
|
|
||||||
Future<void> enroll(SnPublisher publisher) async {
|
|
||||||
try {
|
|
||||||
final client = ref.read(apiClientProvider);
|
|
||||||
await client.post('/developers/${publisher.name}/enroll');
|
|
||||||
if (context.mounted) {
|
|
||||||
Navigator.pop(context, true);
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
showErrorAlert(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return SheetScaffold(
|
|
||||||
titleText: 'enrollDeveloper'.tr(),
|
|
||||||
child: publishers.when(
|
|
||||||
data:
|
|
||||||
(items) =>
|
|
||||||
items.isEmpty
|
|
||||||
? Center(
|
|
||||||
child:
|
|
||||||
Text(
|
|
||||||
'noPublishersToEnroll',
|
|
||||||
textAlign: TextAlign.center,
|
|
||||||
).tr(),
|
|
||||||
)
|
|
||||||
: ListView.builder(
|
|
||||||
shrinkWrap: true,
|
|
||||||
itemCount: items.length,
|
|
||||||
itemBuilder: (context, index) {
|
|
||||||
final publisher = items[index];
|
|
||||||
return ListTile(
|
|
||||||
leading: ProfilePictureWidget(
|
|
||||||
fileId: publisher.picture?.id,
|
|
||||||
fallbackIcon: Symbols.group,
|
|
||||||
),
|
|
||||||
title: Text(publisher.nick),
|
|
||||||
subtitle: Text('@${publisher.name}'),
|
|
||||||
onTap: () => enroll(publisher),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
loading: () => const Center(child: CircularProgressIndicator()),
|
|
||||||
error:
|
|
||||||
(error, _) => ResponseErrorWidget(
|
|
||||||
error: error,
|
|
||||||
onRetry: () => ref.invalidate(publishersManagedProvider),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,172 +0,0 @@
|
|||||||
// GENERATED CODE - DO NOT MODIFY BY HAND
|
|
||||||
|
|
||||||
part of 'hub.dart';
|
|
||||||
|
|
||||||
// **************************************************************************
|
|
||||||
// RiverpodGenerator
|
|
||||||
// **************************************************************************
|
|
||||||
|
|
||||||
String _$developerStatsHash() => r'783398cbde09c3d956c3e20b02a1cebd1f8ab748';
|
|
||||||
|
|
||||||
/// Copied from Dart SDK
|
|
||||||
class _SystemHash {
|
|
||||||
_SystemHash._();
|
|
||||||
|
|
||||||
static int combine(int hash, int value) {
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + value);
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + ((0x0007ffff & hash) << 10));
|
|
||||||
return hash ^ (hash >> 6);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int finish(int hash) {
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = 0x1fffffff & (hash + ((0x03ffffff & hash) << 3));
|
|
||||||
// ignore: parameter_assignments
|
|
||||||
hash = hash ^ (hash >> 11);
|
|
||||||
return 0x1fffffff & (hash + ((0x00003fff & hash) << 15));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// See also [developerStats].
|
|
||||||
@ProviderFor(developerStats)
|
|
||||||
const developerStatsProvider = DeveloperStatsFamily();
|
|
||||||
|
|
||||||
/// See also [developerStats].
|
|
||||||
class DeveloperStatsFamily extends Family<AsyncValue<DeveloperStats?>> {
|
|
||||||
/// See also [developerStats].
|
|
||||||
const DeveloperStatsFamily();
|
|
||||||
|
|
||||||
/// See also [developerStats].
|
|
||||||
DeveloperStatsProvider call(String? uname) {
|
|
||||||
return DeveloperStatsProvider(uname);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
DeveloperStatsProvider getProviderOverride(
|
|
||||||
covariant DeveloperStatsProvider provider,
|
|
||||||
) {
|
|
||||||
return call(provider.uname);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const Iterable<ProviderOrFamily>? _dependencies = null;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Iterable<ProviderOrFamily>? get dependencies => _dependencies;
|
|
||||||
|
|
||||||
static const Iterable<ProviderOrFamily>? _allTransitiveDependencies = null;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Iterable<ProviderOrFamily>? get allTransitiveDependencies =>
|
|
||||||
_allTransitiveDependencies;
|
|
||||||
|
|
||||||
@override
|
|
||||||
String? get name => r'developerStatsProvider';
|
|
||||||
}
|
|
||||||
|
|
||||||
/// See also [developerStats].
|
|
||||||
class DeveloperStatsProvider
|
|
||||||
extends AutoDisposeFutureProvider<DeveloperStats?> {
|
|
||||||
/// See also [developerStats].
|
|
||||||
DeveloperStatsProvider(String? uname)
|
|
||||||
: this._internal(
|
|
||||||
(ref) => developerStats(ref as DeveloperStatsRef, uname),
|
|
||||||
from: developerStatsProvider,
|
|
||||||
name: r'developerStatsProvider',
|
|
||||||
debugGetCreateSourceHash:
|
|
||||||
const bool.fromEnvironment('dart.vm.product')
|
|
||||||
? null
|
|
||||||
: _$developerStatsHash,
|
|
||||||
dependencies: DeveloperStatsFamily._dependencies,
|
|
||||||
allTransitiveDependencies:
|
|
||||||
DeveloperStatsFamily._allTransitiveDependencies,
|
|
||||||
uname: uname,
|
|
||||||
);
|
|
||||||
|
|
||||||
DeveloperStatsProvider._internal(
|
|
||||||
super._createNotifier, {
|
|
||||||
required super.name,
|
|
||||||
required super.dependencies,
|
|
||||||
required super.allTransitiveDependencies,
|
|
||||||
required super.debugGetCreateSourceHash,
|
|
||||||
required super.from,
|
|
||||||
required this.uname,
|
|
||||||
}) : super.internal();
|
|
||||||
|
|
||||||
final String? uname;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Override overrideWith(
|
|
||||||
FutureOr<DeveloperStats?> Function(DeveloperStatsRef provider) create,
|
|
||||||
) {
|
|
||||||
return ProviderOverride(
|
|
||||||
origin: this,
|
|
||||||
override: DeveloperStatsProvider._internal(
|
|
||||||
(ref) => create(ref as DeveloperStatsRef),
|
|
||||||
from: from,
|
|
||||||
name: null,
|
|
||||||
dependencies: null,
|
|
||||||
allTransitiveDependencies: null,
|
|
||||||
debugGetCreateSourceHash: null,
|
|
||||||
uname: uname,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
AutoDisposeFutureProviderElement<DeveloperStats?> createElement() {
|
|
||||||
return _DeveloperStatsProviderElement(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) {
|
|
||||||
return other is DeveloperStatsProvider && other.uname == uname;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
int get hashCode {
|
|
||||||
var hash = _SystemHash.combine(0, runtimeType.hashCode);
|
|
||||||
hash = _SystemHash.combine(hash, uname.hashCode);
|
|
||||||
|
|
||||||
return _SystemHash.finish(hash);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated('Will be removed in 3.0. Use Ref instead')
|
|
||||||
// ignore: unused_element
|
|
||||||
mixin DeveloperStatsRef on AutoDisposeFutureProviderRef<DeveloperStats?> {
|
|
||||||
/// The parameter `uname` of this provider.
|
|
||||||
String? get uname;
|
|
||||||
}
|
|
||||||
|
|
||||||
class _DeveloperStatsProviderElement
|
|
||||||
extends AutoDisposeFutureProviderElement<DeveloperStats?>
|
|
||||||
with DeveloperStatsRef {
|
|
||||||
_DeveloperStatsProviderElement(super.provider);
|
|
||||||
|
|
||||||
@override
|
|
||||||
String? get uname => (origin as DeveloperStatsProvider).uname;
|
|
||||||
}
|
|
||||||
|
|
||||||
String _$developersHash() => r'f52639d3c21aafbf235c8ae33f35448baf2989a1';
|
|
||||||
|
|
||||||
/// See also [developers].
|
|
||||||
@ProviderFor(developers)
|
|
||||||
final developersProvider =
|
|
||||||
AutoDisposeFutureProvider<List<SnPublisher>>.internal(
|
|
||||||
developers,
|
|
||||||
name: r'developersProvider',
|
|
||||||
debugGetCreateSourceHash:
|
|
||||||
const bool.fromEnvironment('dart.vm.product')
|
|
||||||
? null
|
|
||||||
: _$developersHash,
|
|
||||||
dependencies: null,
|
|
||||||
allTransitiveDependencies: null,
|
|
||||||
);
|
|
||||||
|
|
||||||
@Deprecated('Will be removed in 3.0. Use Ref instead')
|
|
||||||
// ignore: unused_element
|
|
||||||
typedef DevelopersRef = AutoDisposeFutureProviderRef<List<SnPublisher>>;
|
|
||||||
// ignore_for_file: type=lint
|
|
||||||
// ignore_for_file: subtype_of_sealed_class, invalid_use_of_internal_member, invalid_use_of_visible_for_testing_member, deprecated_member_use_from_same_package
|
|
@ -1,12 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:island/screens/developers/edit_app.dart';
|
|
||||||
|
|
||||||
class NewCustomAppScreen extends StatelessWidget {
|
|
||||||
final String publisherName;
|
|
||||||
const NewCustomAppScreen({super.key, required this.publisherName});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return EditAppScreen(publisherName: publisherName);
|
|
||||||
}
|
|
||||||
}
|
|
@ -351,36 +351,17 @@ class EditRealmScreen extends HookConsumerWidget {
|
|||||||
(_) => FocusManager.instance.primaryFocus?.unfocus(),
|
(_) => FocusManager.instance.primaryFocus?.unfocus(),
|
||||||
),
|
),
|
||||||
const SizedBox(height: 16),
|
const SizedBox(height: 16),
|
||||||
Card(
|
|
||||||
margin: EdgeInsets.zero,
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
CheckboxListTile(
|
CheckboxListTile(
|
||||||
secondary: const Icon(Symbols.public),
|
title: const Text('isPublic').tr(),
|
||||||
title: Text('publicRealm').tr(),
|
subtitle: const Text('isPublicHint').tr(),
|
||||||
subtitle: Text('publicRealmDescription').tr(),
|
|
||||||
value: isPublic.value,
|
value: isPublic.value,
|
||||||
onChanged: (value) {
|
onChanged: (value) => isPublic.value = value ?? false,
|
||||||
isPublic.value = value ?? true;
|
|
||||||
},
|
|
||||||
shape: RoundedRectangleBorder(
|
|
||||||
borderRadius: BorderRadius.circular(8),
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
CheckboxListTile(
|
CheckboxListTile(
|
||||||
secondary: const Icon(Symbols.travel_explore),
|
title: const Text('isCommunity').tr(),
|
||||||
title: Text('communityRealm').tr(),
|
subtitle: const Text('isCommunityHint').tr(),
|
||||||
subtitle: Text('communityRealmDescription').tr(),
|
|
||||||
value: isCommunity.value,
|
value: isCommunity.value,
|
||||||
onChanged: (value) {
|
onChanged: (value) => isCommunity.value = value ?? false,
|
||||||
isCommunity.value = value ?? false;
|
|
||||||
},
|
|
||||||
shape: RoundedRectangleBorder(
|
|
||||||
borderRadius: BorderRadius.circular(8),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
const SizedBox(height: 16),
|
const SizedBox(height: 16),
|
||||||
Align(
|
Align(
|
||||||
|
@ -341,25 +341,6 @@ class SettingsScreen extends HookConsumerWidget {
|
|||||||
];
|
];
|
||||||
|
|
||||||
final behaviorSettings = [
|
final behaviorSettings = [
|
||||||
ListTile(
|
|
||||||
minLeadingWidth: 48,
|
|
||||||
title: Text('creatorHub').tr(),
|
|
||||||
contentPadding: const EdgeInsets.only(left: 24, right: 17),
|
|
||||||
leading: const Icon(Symbols.rocket_launch),
|
|
||||||
trailing: const Icon(Symbols.chevron_right),
|
|
||||||
onTap: () => context.push('/creators'),
|
|
||||||
),
|
|
||||||
|
|
||||||
// Developer Hub
|
|
||||||
ListTile(
|
|
||||||
minLeadingWidth: 48,
|
|
||||||
title: Text('developerHub').tr(),
|
|
||||||
contentPadding: const EdgeInsets.only(left: 24, right: 17),
|
|
||||||
leading: const Icon(Symbols.hub),
|
|
||||||
trailing: const Icon(Symbols.chevron_right),
|
|
||||||
onTap: () => context.push('/developers'),
|
|
||||||
),
|
|
||||||
|
|
||||||
// Auto translate settings
|
// Auto translate settings
|
||||||
ListTile(
|
ListTile(
|
||||||
minLeadingWidth: 48,
|
minLeadingWidth: 48,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user