mirror of
https://github.com/immich-app/immich.git
synced 2026-03-07 10:37:22 +03:00
* faces * add openapi descriptions * remove dto descriptions * gen openapi * dtos * fix dtos * fix more * fix build * more * complete dtos * descriptions on rebase * gen rebase * revert correct integer type conversion * gen after revert * revert correct nullables * regen after revert * actually incorrect adding default here * revert correct number type conversion * regen after revert * revert nullable usage * regen fully * readd some comments * one more * one more * use enum * add missing * add missing controllers * add missing dtos * complete it * more * describe global key and slug * add remaining body and param descriptions * lint and format * cleanup * response and schema descriptions * test patch according to suggestion * revert added api response objects * revert added api body objects * revert added api param object * revert added api query objects * revert reorganized http code objects * revert reorganize ApiOkResponse objects * revert added api response objects (2) * revert added api tag object * revert added api schema objects * migrate missing asset.dto.ts * regenerate openapi builds * delete generated mustache files * remove descriptions from properties that are schemas * lint * revert nullable type changes * revert int/num type changes * remove explicit default * readd comment * lint * pr fixes * last bits and pieces * lint and format * chore: remove rejected patches * fix: deleting asset from asset-viewer on search results (#25596) * fix: escape handling in search asset viewer (#25621) * fix: correctly show owner in album options modal (#25618) * fix: validation issues * fix: validation issues --------- Co-authored-by: Jason Rasmussen <jason@rasm.me> Co-authored-by: Min Idzelis <min123@gmail.com> Co-authored-by: Daniel Dietzler <36593685+danieldietzler@users.noreply.github.com> Co-authored-by: Paul Makles <me@insrt.uk>
131 lines
3.8 KiB
TypeScript
131 lines
3.8 KiB
TypeScript
import { ApiExtraModels, ApiProperty, getSchemaPath } from '@nestjs/swagger';
|
|
import { ClassConstructor, plainToInstance, Transform, Type } from 'class-transformer';
|
|
import { ArrayMinSize, IsEnum, IsInt, Min, ValidateNested } from 'class-validator';
|
|
import { IsAxisAlignedRotation, IsUniqueEditActions, ValidateUUID } from 'src/validation';
|
|
|
|
export enum AssetEditAction {
|
|
Crop = 'crop',
|
|
Rotate = 'rotate',
|
|
Mirror = 'mirror',
|
|
}
|
|
|
|
export enum MirrorAxis {
|
|
Horizontal = 'horizontal',
|
|
Vertical = 'vertical',
|
|
}
|
|
|
|
export class CropParameters {
|
|
@IsInt()
|
|
@Min(0)
|
|
@ApiProperty({ description: 'Top-Left X coordinate of crop' })
|
|
x!: number;
|
|
|
|
@IsInt()
|
|
@Min(0)
|
|
@ApiProperty({ description: 'Top-Left Y coordinate of crop' })
|
|
y!: number;
|
|
|
|
@IsInt()
|
|
@Min(1)
|
|
@ApiProperty({ description: 'Width of the crop' })
|
|
width!: number;
|
|
|
|
@IsInt()
|
|
@Min(1)
|
|
@ApiProperty({ description: 'Height of the crop' })
|
|
height!: number;
|
|
}
|
|
|
|
export class RotateParameters {
|
|
@IsAxisAlignedRotation()
|
|
@ApiProperty({ description: 'Rotation angle in degrees' })
|
|
angle!: number;
|
|
}
|
|
|
|
export class MirrorParameters {
|
|
@IsEnum(MirrorAxis)
|
|
@ApiProperty({ enum: MirrorAxis, enumName: 'MirrorAxis', description: 'Axis to mirror along' })
|
|
axis!: MirrorAxis;
|
|
}
|
|
|
|
class AssetEditActionBase {
|
|
@IsEnum(AssetEditAction)
|
|
@ApiProperty({ enum: AssetEditAction, enumName: 'AssetEditAction', description: 'Type of edit action to perform' })
|
|
action!: AssetEditAction;
|
|
}
|
|
|
|
export class AssetEditActionCrop extends AssetEditActionBase {
|
|
@ValidateNested()
|
|
@Type(() => CropParameters)
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
parameters!: CropParameters;
|
|
}
|
|
|
|
export class AssetEditActionRotate extends AssetEditActionBase {
|
|
@ValidateNested()
|
|
@Type(() => RotateParameters)
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
parameters!: RotateParameters;
|
|
}
|
|
|
|
export class AssetEditActionMirror extends AssetEditActionBase {
|
|
@ValidateNested()
|
|
@Type(() => MirrorParameters)
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
parameters!: MirrorParameters;
|
|
}
|
|
|
|
export type AssetEditActionItem =
|
|
| {
|
|
action: AssetEditAction.Crop;
|
|
parameters: CropParameters;
|
|
}
|
|
| {
|
|
action: AssetEditAction.Rotate;
|
|
parameters: RotateParameters;
|
|
}
|
|
| {
|
|
action: AssetEditAction.Mirror;
|
|
parameters: MirrorParameters;
|
|
};
|
|
|
|
export type AssetEditActionParameter = {
|
|
[AssetEditAction.Crop]: CropParameters;
|
|
[AssetEditAction.Rotate]: RotateParameters;
|
|
[AssetEditAction.Mirror]: MirrorParameters;
|
|
};
|
|
|
|
type AssetEditActions = AssetEditActionCrop | AssetEditActionRotate | AssetEditActionMirror;
|
|
const actionToClass: Record<AssetEditAction, ClassConstructor<AssetEditActions>> = {
|
|
[AssetEditAction.Crop]: AssetEditActionCrop,
|
|
[AssetEditAction.Rotate]: AssetEditActionRotate,
|
|
[AssetEditAction.Mirror]: AssetEditActionMirror,
|
|
} as const;
|
|
|
|
const getActionClass = (item: { action: AssetEditAction }): ClassConstructor<AssetEditActions> =>
|
|
actionToClass[item.action];
|
|
|
|
@ApiExtraModels(AssetEditActionRotate, AssetEditActionMirror, AssetEditActionCrop)
|
|
export class AssetEditActionListDto {
|
|
/** list of edits */
|
|
@ArrayMinSize(1)
|
|
@IsUniqueEditActions()
|
|
@ValidateNested({ each: true })
|
|
@Transform(({ value: edits }) =>
|
|
Array.isArray(edits) ? edits.map((item) => plainToInstance(getActionClass(item), item)) : edits,
|
|
)
|
|
@ApiProperty({
|
|
anyOf: Object.values(actionToClass).map((target) => ({ $ref: getSchemaPath(target) })),
|
|
description: 'List of edit actions to apply (crop, rotate, or mirror)',
|
|
})
|
|
edits!: AssetEditActionItem[];
|
|
}
|
|
|
|
export class AssetEditsDto extends AssetEditActionListDto {
|
|
@ValidateUUID({ description: 'Asset ID to apply edits to' })
|
|
assetId!: string;
|
|
}
|