mirror of
https://github.com/immich-app/immich.git
synced 2025-12-17 17:23:20 +03:00
feat: db insertions for edits feat: get asset edits endpoint feat: wip apply edits feat: finish asset files changes feat: wip feat: wip fix: openapi fix: tests the failing tests were so scuffed. Simply solved by adding [] to the param list feat: more wip feat: more wip feat: some more tests and fixes chore: fix default for getting thumbnail and add todo for tests feat: LRTB validation chore: code cleanup chore: more test checks for cleanup feat: show edit pane fix: state issues chore: restructure web editor feat: restructure edit manager feat: refactor cropManager chore: combine all editing chore: web editing improvements fix: handling when no crops fix: openapi enum chore: more edit refactoring fix: make image decoding more efficient chore: more refactoring fix: getCrop LRTB algorithm fix: missing await chore: use relative coordinates for edit chore: update sql fix: use resize observer instead of svelte:doc resize hook chore: simplify quad box generation fix: light mode styling chore: refactor to not be a recursive job call this simplifies the logic and the job only completes once thumbhash and others are properly updated chore: more refactoring feat: use affine transforms for most operations feat: bounding box edit transformation feat: tests chore: sql and openapi sync fix: medium tests fix: rotated OCR chore: cleanup transform test fix: remove rebase issue fix(server): block edits for live photos, gifs, panoramic photos fix: openapi enum validation chore: rename edit endpoint chore: remove public modifiers feat: delete endpoint chore: use === and !== explicitly fix: require 1 edit for the editAsset endpoint fix: remove thumbnail edit notification and use on_upload_success instead fix: primary key on asset edit table chore: refactor to isPanorama chore: rename editRepository to assetEditRepository fix: missing toLowerCase fix: db migrations chore: update sql files
136 lines
3.4 KiB
Dart
Generated
136 lines
3.4 KiB
Dart
Generated
//
|
|
// AUTO-GENERATED FILE, DO NOT MODIFY!
|
|
//
|
|
// @dart=2.18
|
|
|
|
// 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 CropParameters {
|
|
/// Returns a new [CropParameters] instance.
|
|
CropParameters({
|
|
required this.height,
|
|
required this.width,
|
|
required this.x,
|
|
required this.y,
|
|
});
|
|
|
|
/// Height of the crop
|
|
///
|
|
/// Minimum value: 1
|
|
num height;
|
|
|
|
/// Width of the crop
|
|
///
|
|
/// Minimum value: 1
|
|
num width;
|
|
|
|
/// Top-Left X coordinate of crop
|
|
///
|
|
/// Minimum value: 0
|
|
num x;
|
|
|
|
/// Top-Left Y coordinate of crop
|
|
///
|
|
/// Minimum value: 0
|
|
num y;
|
|
|
|
@override
|
|
bool operator ==(Object other) => identical(this, other) || other is CropParameters &&
|
|
other.height == height &&
|
|
other.width == width &&
|
|
other.x == x &&
|
|
other.y == y;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
// ignore: unnecessary_parenthesis
|
|
(height.hashCode) +
|
|
(width.hashCode) +
|
|
(x.hashCode) +
|
|
(y.hashCode);
|
|
|
|
@override
|
|
String toString() => 'CropParameters[height=$height, width=$width, x=$x, y=$y]';
|
|
|
|
Map<String, dynamic> toJson() {
|
|
final json = <String, dynamic>{};
|
|
json[r'height'] = this.height;
|
|
json[r'width'] = this.width;
|
|
json[r'x'] = this.x;
|
|
json[r'y'] = this.y;
|
|
return json;
|
|
}
|
|
|
|
/// Returns a new [CropParameters] instance and imports its values from
|
|
/// [value] if it's a [Map], null otherwise.
|
|
// ignore: prefer_constructors_over_static_methods
|
|
static CropParameters? fromJson(dynamic value) {
|
|
upgradeDto(value, "CropParameters");
|
|
if (value is Map) {
|
|
final json = value.cast<String, dynamic>();
|
|
|
|
return CropParameters(
|
|
height: num.parse('${json[r'height']}'),
|
|
width: num.parse('${json[r'width']}'),
|
|
x: num.parse('${json[r'x']}'),
|
|
y: num.parse('${json[r'y']}'),
|
|
);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
static List<CropParameters> listFromJson(dynamic json, {bool growable = false,}) {
|
|
final result = <CropParameters>[];
|
|
if (json is List && json.isNotEmpty) {
|
|
for (final row in json) {
|
|
final value = CropParameters.fromJson(row);
|
|
if (value != null) {
|
|
result.add(value);
|
|
}
|
|
}
|
|
}
|
|
return result.toList(growable: growable);
|
|
}
|
|
|
|
static Map<String, CropParameters> mapFromJson(dynamic json) {
|
|
final map = <String, CropParameters>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = CropParameters.fromJson(entry.value);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
// maps a json object with a list of CropParameters-objects as value to a dart map
|
|
static Map<String, List<CropParameters>> mapListFromJson(dynamic json, {bool growable = false,}) {
|
|
final map = <String, List<CropParameters>>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
// ignore: parameter_assignments
|
|
json = json.cast<String, dynamic>();
|
|
for (final entry in json.entries) {
|
|
map[entry.key] = CropParameters.listFromJson(entry.value, growable: growable,);
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
/// The list of required keys that must be present in a JSON.
|
|
static const requiredKeys = <String>{
|
|
'height',
|
|
'width',
|
|
'x',
|
|
'y',
|
|
};
|
|
}
|
|
|