-
Notifications
You must be signed in to change notification settings - Fork 28
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'supabase-integration' into supabase-queue
- Loading branch information
Showing
17 changed files
with
987 additions
and
19 deletions.
There are no files selected for viewing
4 changes: 0 additions & 4 deletions
4
packages/brick_offline_first_with_supabase_build/analysis_options.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1 @@ | ||
include: ../../analysis_options.yaml | ||
|
||
linter: | ||
rules: | ||
library_prefixes: false |
112 changes: 112 additions & 0 deletions
112
..._offline_first_with_supabase_build/test/offline_first_generator/test_default_to_null.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
import 'package:brick_offline_first/brick_offline_first.dart'; | ||
import 'package:brick_offline_first_with_supabase/brick_offline_first_with_supabase.dart'; | ||
import 'package:brick_supabase/brick_supabase.dart'; | ||
|
||
final output = r''' | ||
// GENERATED CODE DO NOT EDIT | ||
part of '../brick.g.dart'; | ||
Future<SupabaseDefined> _$SupabaseDefinedFromSupabase(Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseDefined(someLongField: data['some_long_field'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseDefinedToSupabase( | ||
SupabaseDefined instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseDefined> _$SupabaseDefinedFromSqlite(Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseDefined(someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseDefinedToSqlite(SupabaseDefined instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
/// Construct a [SupabaseDefined] | ||
class SupabaseDefinedAdapter extends OfflineFirstAdapter<SupabaseDefined> { | ||
SupabaseDefinedAdapter(); | ||
@override | ||
final tableName = 'supabase_defineds'; | ||
@override | ||
final defaultToNull = false; | ||
@override | ||
final Map<String, RuntimeSqliteColumnDefinition> fieldsToSqliteColumns = { | ||
'someLongField': const RuntimeSupabaseColumnDefinition( | ||
association: false, | ||
associationForeignKey: 'null', | ||
associationType: int, | ||
columnName: 'some_long_field', | ||
) | ||
}; | ||
@override | ||
final ignoreDuplicates = false; | ||
@override | ||
final uniqueFields = {}; | ||
@override | ||
final Map<String, RuntimeSqliteColumnDefinition> fieldsToSqliteColumns = { | ||
'primaryKey': const RuntimeSqliteColumnDefinition( | ||
association: false, | ||
columnName: '_brick_id', | ||
iterable: false, | ||
type: int, | ||
), | ||
'someLongField': const RuntimeSqliteColumnDefinition( | ||
association: false, | ||
columnName: 'some_long_field', | ||
iterable: false, | ||
type: int, | ||
) | ||
}; | ||
@override | ||
Future<int?> primaryKeyByUniqueColumns( | ||
SupabaseDefined instance, DatabaseExecutor executor) async => | ||
instance.primaryKey; | ||
@override | ||
final String tableName = 'SupabaseDefined'; | ||
@override | ||
Future<SupabaseDefined> fromSupabase(Map<String, dynamic> input, | ||
{required provider, | ||
covariant OfflineFirstRepository? repository}) async => | ||
await _$SupabaseDefinedFromSupabase(input, | ||
provider: provider, repository: repository); | ||
@override | ||
Future<Map<String, dynamic>> toSupabase(SupabaseDefined input, | ||
{required provider, | ||
covariant OfflineFirstRepository? repository}) async => | ||
await _$SupabaseDefinedToSupabase(input, | ||
provider: provider, repository: repository); | ||
@override | ||
Future<SupabaseDefined> fromSqlite(Map<String, dynamic> input, | ||
{required provider, | ||
covariant OfflineFirstRepository? repository}) async => | ||
await _$SupabaseDefinedFromSqlite(input, | ||
provider: provider, repository: repository); | ||
@override | ||
Future<Map<String, dynamic>> toSqlite(SupabaseDefined input, | ||
{required provider, | ||
covariant OfflineFirstRepository? repository}) async => | ||
await _$SupabaseDefinedToSqlite(input, | ||
provider: provider, repository: repository); | ||
} | ||
'''; | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(defaultToNull: false), | ||
) | ||
class SupabaseDefined extends OfflineFirstModel { | ||
final int someLongField; | ||
|
||
SupabaseDefined(this.someLongField); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
231 changes: 231 additions & 0 deletions
231
...ick_offline_first_with_supabase_build/test/offline_first_generator/test_field_rename.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,231 @@ | ||
import 'package:brick_offline_first/brick_offline_first.dart'; | ||
import 'package:brick_offline_first_with_supabase/brick_offline_first_with_supabase.dart'; | ||
import 'package:brick_supabase/brick_supabase.dart'; | ||
|
||
final output = r''' | ||
Future<SupabaseDefault> _$SupabaseDefaultFromSupabase(Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseDefault(someLongField: data['some_long_field'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseDefaultToSupabase( | ||
SupabaseDefault instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseDefault> _$SupabaseDefaultFromSqlite(Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseDefault(someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseDefaultToSqlite(SupabaseDefault instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseNoRename> _$SupabaseNoRenameFromSupabase( | ||
Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseNoRename(someLongField: data['someLongField'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseNoRenameToSupabase( | ||
SupabaseNoRename instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'someLongField': instance.someLongField}; | ||
} | ||
Future<SupabaseNoRename> _$SupabaseNoRenameFromSqlite(Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseNoRename(someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseNoRenameToSqlite( | ||
SupabaseNoRename instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseSnakeRename> _$SupabaseSnakeRenameFromSupabase( | ||
Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseSnakeRename(someLongField: data['some_long_field'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseSnakeRenameToSupabase( | ||
SupabaseSnakeRename instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseSnakeRename> _$SupabaseSnakeRenameFromSqlite( | ||
Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseSnakeRename(someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseSnakeRenameToSqlite( | ||
SupabaseSnakeRename instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseKebabRename> _$SupabaseKebabRenameFromSupabase( | ||
Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseKebabRename(someLongField: data['some-long-field'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseKebabRenameToSupabase( | ||
SupabaseKebabRename instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some-long-field': instance.someLongField}; | ||
} | ||
Future<SupabaseKebabRename> _$SupabaseKebabRenameFromSqlite( | ||
Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseKebabRename(someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseKebabRenameToSqlite( | ||
SupabaseKebabRename instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabasePascalRename> _$SupabasePascalRenameFromSupabase( | ||
Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabasePascalRename(someLongField: data['SomeLongField'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabasePascalRenameToSupabase( | ||
SupabasePascalRename instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'SomeLongField': instance.someLongField}; | ||
} | ||
Future<SupabasePascalRename> _$SupabasePascalRenameFromSqlite( | ||
Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabasePascalRename(someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabasePascalRenameToSqlite( | ||
SupabasePascalRename instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
Future<SupabaseRenameWithOverride> _$SupabaseRenameWithOverrideFromSupabase( | ||
Map<String, dynamic> data, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseRenameWithOverride(someLongField: data['some_field'] as int); | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseRenameWithOverrideToSupabase( | ||
SupabaseRenameWithOverride instance, | ||
{required SupabaseProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_field': instance.someLongField}; | ||
} | ||
Future<SupabaseRenameWithOverride> _$SupabaseRenameWithOverrideFromSqlite( | ||
Map<String, dynamic> data, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return SupabaseRenameWithOverride( | ||
someLongField: data['some_long_field'] as int) | ||
..primaryKey = data['_brick_id'] as int; | ||
} | ||
Future<Map<String, dynamic>> _$SupabaseRenameWithOverrideToSqlite( | ||
SupabaseRenameWithOverride instance, | ||
{required SqliteProvider provider, | ||
OfflineFirstRepository? repository}) async { | ||
return {'some_long_field': instance.someLongField}; | ||
} | ||
'''; | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(), | ||
) | ||
class SupabaseDefault extends OfflineFirstModel { | ||
final int someLongField; | ||
|
||
SupabaseDefault(this.someLongField); | ||
} | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(fieldRename: FieldRename.none), | ||
) | ||
class SupabaseNoRename extends OfflineFirstModel { | ||
final int someLongField; | ||
|
||
SupabaseNoRename(this.someLongField); | ||
} | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(fieldRename: FieldRename.snake), | ||
) | ||
class SupabaseSnakeRename extends OfflineFirstModel { | ||
final int someLongField; | ||
|
||
SupabaseSnakeRename(this.someLongField); | ||
} | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(fieldRename: FieldRename.kebab), | ||
) | ||
class SupabaseKebabRename extends OfflineFirstModel { | ||
final int someLongField; | ||
|
||
SupabaseKebabRename(this.someLongField); | ||
} | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(fieldRename: FieldRename.pascal), | ||
) | ||
class SupabasePascalRename extends OfflineFirstModel { | ||
final int someLongField; | ||
|
||
SupabasePascalRename(this.someLongField); | ||
} | ||
|
||
@ConnectOfflineFirstWithSupabase( | ||
supabaseConfig: SupabaseSerializable(fieldRename: FieldRename.pascal), | ||
) | ||
class SupabaseRenameWithOverride extends OfflineFirstModel { | ||
@Supabase(name: 'some_field') | ||
final int someLongField; | ||
|
||
SupabaseRenameWithOverride(this.someLongField); | ||
} |
Oops, something went wrong.