-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGalleryNode.ts
64 lines (52 loc) · 1.79 KB
/
GalleryNode.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import { type UploadedImage, isUploadedImage } from '@prezly/uploads';
import { Element } from '../Element';
import { isArrayOf, isEnum, isObject, isUuid } from '../validation';
export interface GalleryNode extends Element<typeof GalleryNode.TYPE> {
uuid: string;
images: GalleryNode.GalleryImage[];
layout: `${GalleryNode.Layout}`;
padding: `${GalleryNode.Padding}`;
thumbnail_size: `${GalleryNode.ImageSize}`;
}
export namespace GalleryNode {
export const TYPE = 'gallery';
export enum Layout {
CONTAINED = 'contained',
EXPANDED = 'expanded',
FULL_WIDTH = 'full-width',
}
export enum ImageSize {
XSMALL = 'XS',
SMALL = 'S',
MEDIUM = 'M',
LARGE = 'L',
XLARGE = 'XL',
}
export enum Padding {
LARGE = 'L',
MEDIUM = 'M',
SMALL = 'S',
}
export interface GalleryImage {
file: File;
caption: string;
}
export type File = UploadedImage;
export function isGalleryNode(value: any): value is GalleryNode {
return Element.isElement(value, TYPE);
}
export function validateGalleryNode(value: any): GalleryNode | null {
const isValid =
isGalleryNode(value) &&
isUuid(value.uuid) &&
isEnum(value.layout, Layout) &&
isEnum(value.padding, Padding) &&
isEnum(value.thumbnail_size, ImageSize) &&
isArrayOf(value.images, (image) => Boolean(validateGalleryImage(image)));
return isValid ? value : null;
}
export function validateGalleryImage(value: any): GalleryImage | null {
const isValid = isObject(value) && typeof value.caption === 'string' && isUploadedImage(value.file);
return isValid ? (value as unknown as GalleryImage) : null;
}
}