mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 13:14:29 +02:00
a147dee4b6
* maplibre on web, custom styles from server Actually use new vector tile server, custom style.json support multiple style files, light/dark mode cleanup, use new map everywhere send file directly instead of loading first better light/dark mode switching remove leaflet fix mapstyles dto, first draft of map settings delete and add styles fix delete default styles fix tests only allow one light and one dark style url revert config core changes fix server config store fix tests move axios fetches to repo fix package-lock fix tests * open api * add assets to docker container * web: use mapSettings color for style * style: add unique ids to map styles * mobile: use style json for vector / raster * do not use svelte-material-icons * add click events to markers, simplify asset detail map * improve map performance by using asset thumbnails for markers instead of original file * Remove custom attribution (by request) * mobile: update map attribution * style: map dark mode * style: map light mode * zoom level for state * styling * overflow gradient * Limit maxZoom to 14 * mobile: listen for mapStyle changes in MapThumbnail * mobile: update concurrency --------- Co-authored-by: shalong-tanwen <139912620+shalong-tanwen@users.noreply.github.com> Co-authored-by: bo0tzz <git@bo0tzz.me> Co-authored-by: Alex <alex.tran1502@gmail.com>
123 lines
3.7 KiB
Dart
Generated
123 lines
3.7 KiB
Dart
Generated
//
|
|
// AUTO-GENERATED FILE, DO NOT MODIFY!
|
|
//
|
|
// @dart=2.12
|
|
|
|
// ignore_for_file: unused_element, unused_import
|
|
// ignore_for_file: always_put_required_named_parameters_first
|
|
// ignore_for_file: constant_identifier_names
|
|
// ignore_for_file: lines_longer_than_80_chars
|
|
|
|
part of openapi.api;
|
|
|
|
class ServerConfigDto {
|
|
/// Returns a new [ServerConfigDto] instance.
|
|
ServerConfigDto({
|
|
required this.isInitialized,
|
|
required this.loginPageMessage,
|
|
required this.oauthButtonText,
|
|
required this.trashDays,
|
|
});
|
|
|
|
bool isInitialized;
|
|
|
|
String loginPageMessage;
|
|
|
|
String oauthButtonText;
|
|
|
|
int trashDays;
|
|
|
|
@override
|
|
bool operator ==(Object other) => identical(this, other) || other is ServerConfigDto &&
|
|
other.isInitialized == isInitialized &&
|
|
other.loginPageMessage == loginPageMessage &&
|
|
other.oauthButtonText == oauthButtonText &&
|
|
other.trashDays == trashDays;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
// ignore: unnecessary_parenthesis
|
|
(isInitialized.hashCode) +
|
|
(loginPageMessage.hashCode) +
|
|
(oauthButtonText.hashCode) +
|
|
(trashDays.hashCode);
|
|
|
|
@override
|
|
String toString() => 'ServerConfigDto[isInitialized=$isInitialized, loginPageMessage=$loginPageMessage, oauthButtonText=$oauthButtonText, trashDays=$trashDays]';
|
|
|
|
Map<String, dynamic> toJson() {
|
|
final json = <String, dynamic>{};
|
|
json[r'isInitialized'] = this.isInitialized;
|
|
json[r'loginPageMessage'] = this.loginPageMessage;
|
|
json[r'oauthButtonText'] = this.oauthButtonText;
|
|
json[r'trashDays'] = this.trashDays;
|
|
return json;
|
|
}
|
|
|
|
/// Returns a new [ServerConfigDto] instance and imports its values from
|
|
/// [value] if it's a [Map], null otherwise.
|
|
// ignore: prefer_constructors_over_static_methods
|
|
static ServerConfigDto? fromJson(dynamic value) {
|
|
if (value is Map) {
|
|
final json = value.cast<String, dynamic>();
|
|
|
|
return ServerConfigDto(
|
|
isInitialized: mapValueOfType<bool>(json, r'isInitialized')!,
|
|
loginPageMessage: mapValueOfType<String>(json, r'loginPageMessage')!,
|
|
oauthButtonText: mapValueOfType<String>(json, r'oauthButtonText')!,
|
|
trashDays: mapValueOfType<int>(json, r'trashDays')!,
|
|
);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
static List<ServerConfigDto> listFromJson(dynamic json, {bool growable = false,}) {
|
|
final result = <ServerConfigDto>[];
|
|
if (json is List && json.isNotEmpty) {
|
|
for (final row in json) {
|
|
final value = ServerConfigDto.fromJson(row);
|
|
if (value != null) {
|
|
result.add(value);
|
|
}
|
|
}
|
|
}
|
|
return result.toList(growable: growable);
|
|
}
|
|
|
|
static Map<String, ServerConfigDto> mapFromJson(dynamic json) {
|
|
final map = <String, ServerConfigDto>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = ServerConfigDto.fromJson(entry.value);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
// maps a json object with a list of ServerConfigDto-objects as value to a dart map
|
|
static Map<String, List<ServerConfigDto>> mapListFromJson(dynamic json, {bool growable = false,}) {
|
|
final map = <String, List<ServerConfigDto>>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
// ignore: parameter_assignments
|
|
json = json.cast<String, dynamic>();
|
|
for (final entry in json.entries) {
|
|
map[entry.key] = ServerConfigDto.listFromJson(entry.value, growable: growable,);
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
/// The list of required keys that must be present in a JSON.
|
|
static const requiredKeys = <String>{
|
|
'isInitialized',
|
|
'loginPageMessage',
|
|
'oauthButtonText',
|
|
'trashDays',
|
|
};
|
|
}
|
|
|