2023-06-02 15:55:08 +02:00
|
|
|
import type { AssetResponseDto } from '@api';
|
2022-09-04 15:34:39 +02:00
|
|
|
|
2023-06-08 17:22:45 +02:00
|
|
|
export enum BucketPosition {
|
2023-07-01 06:50:47 +02:00
|
|
|
Above = 'above',
|
|
|
|
Below = 'below',
|
|
|
|
Visible = 'visible',
|
|
|
|
Unknown = 'unknown',
|
2023-06-08 17:22:45 +02:00
|
|
|
}
|
|
|
|
|
2022-09-04 15:34:39 +02:00
|
|
|
export class AssetBucket {
|
2023-07-01 06:50:47 +02:00
|
|
|
/**
|
|
|
|
* The DOM height of the bucket in pixel
|
|
|
|
* This value is first estimated by the number of asset and later is corrected as the user scroll
|
|
|
|
*/
|
|
|
|
bucketHeight!: number;
|
|
|
|
bucketDate!: string;
|
|
|
|
assets!: AssetResponseDto[];
|
|
|
|
cancelToken!: AbortController;
|
|
|
|
position!: BucketPosition;
|
2022-09-04 15:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export class AssetGridState {
|
2023-07-01 06:50:47 +02:00
|
|
|
/**
|
|
|
|
* The total height of the timeline in pixel
|
|
|
|
* This value is first estimated by the number of asset and later is corrected as the user scroll
|
|
|
|
*/
|
|
|
|
timelineHeight = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The fixed viewport height in pixel
|
|
|
|
*/
|
|
|
|
viewportHeight = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The fixed viewport width in pixel
|
|
|
|
*/
|
|
|
|
viewportWidth = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List of bucket information
|
|
|
|
*/
|
|
|
|
buckets: AssetBucket[] = [];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Total assets that have been loaded
|
|
|
|
*/
|
|
|
|
assets: AssetResponseDto[] = [];
|
|
|
|
|
2023-07-05 22:24:23 +02:00
|
|
|
/**
|
|
|
|
* Total assets that have been loaded along with additional data
|
|
|
|
*/
|
|
|
|
loadedAssets: Record<string, number> = {};
|
|
|
|
|
2023-07-01 06:50:47 +02:00
|
|
|
/**
|
|
|
|
* User that owns assets
|
|
|
|
*/
|
|
|
|
userId: string | undefined;
|
2022-09-04 15:34:39 +02:00
|
|
|
}
|