Refactored clips into chapters.
|  | @ -0,0 +1,161 @@ | ||||||
|  | <template> | ||||||
|  | 	<ul class="chapters nolist"> | ||||||
|  | 		<li | ||||||
|  | 			v-for="chapter in chapters" | ||||||
|  | 			:key="`chapter-${chapter.id}`" | ||||||
|  | 			class="chapter" | ||||||
|  | 		> | ||||||
|  | 			<a | ||||||
|  | 				v-if="chapter.poster" | ||||||
|  | 				:href="getPath(chapter.poster)" | ||||||
|  | 				target="_blank" | ||||||
|  | 				rel="noopener noreferrer" | ||||||
|  | 			> | ||||||
|  | 				<img | ||||||
|  | 					:src="getPath(chapter.poster, 'thumbnail')" | ||||||
|  | 					class="chapter-poster" | ||||||
|  | 				> | ||||||
|  | 			</a> | ||||||
|  | 
 | ||||||
|  | 			<span class="chapter-details"> | ||||||
|  | 				<span | ||||||
|  | 					v-if="chapter.time" | ||||||
|  | 					v-tooltip="'Time in video'" | ||||||
|  | 					class="chapter-time" | ||||||
|  | 				><Icon icon="film3" /> {{ formatDuration(chapter.time) }}</span> | ||||||
|  | 
 | ||||||
|  | 				<span | ||||||
|  | 					v-if="chapter.duration" | ||||||
|  | 					v-tooltip="'Duration'" | ||||||
|  | 					class="chapter-duration" | ||||||
|  | 				><Icon icon="stopwatch" />{{ formatDuration(chapter.duration) }}</span> | ||||||
|  | 			</span> | ||||||
|  | 
 | ||||||
|  | 			<div class="chapter-info"> | ||||||
|  | 				<h3 | ||||||
|  | 					v-if="chapter.title" | ||||||
|  | 					class="chapter-row chapter-title" | ||||||
|  | 					:title="chapter.title" | ||||||
|  | 				>{{ chapter.title }}</h3> | ||||||
|  | 
 | ||||||
|  | 				<p | ||||||
|  | 					v-if="chapter.description" | ||||||
|  | 					class="chapter-row chapter-description" | ||||||
|  | 				>{{ chapter.description }}</p> | ||||||
|  | 
 | ||||||
|  | 				<Tags | ||||||
|  | 					:tags="chapter.tags" | ||||||
|  | 					class="chapter-row chapter-tags" | ||||||
|  | 				/> | ||||||
|  | 			</div> | ||||||
|  | 		</li> | ||||||
|  | 	</ul> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import Tags from './tags.vue'; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	components: { | ||||||
|  | 		Tags, | ||||||
|  | 	}, | ||||||
|  | 	props: { | ||||||
|  | 		chapters: { | ||||||
|  | 			type: Array, | ||||||
|  | 			default: () => [], | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style lang="scss"> | ||||||
|  | .chapter-tags.tags-container { | ||||||
|  | 	margin: 0 0 .5rem 0; | ||||||
|  | 
 | ||||||
|  | 	.tags { | ||||||
|  | 		padding: 2px 0 0 2px; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  | 
 | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | @import 'breakpoints'; | ||||||
|  | 
 | ||||||
|  | .chapters { | ||||||
|  | 	display: grid; | ||||||
|  | 	grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr)); | ||||||
|  | 	grid-gap: 1rem; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter { | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | 	background: var(--background); | ||||||
|  | 	box-shadow: 0 0 3px var(--shadow-weak); | ||||||
|  | 	margin: 0 0 .5rem 0; | ||||||
|  | 	font-size: 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-poster { | ||||||
|  | 	width: 100%; | ||||||
|  | 	height: 10rem; | ||||||
|  | 	object-fit: cover; | ||||||
|  | 	object-position: center; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-details { | ||||||
|  | 	height: 1.75rem; | ||||||
|  | 	display: flex; | ||||||
|  | 	justify-content: space-between; | ||||||
|  | 	align-items: center; | ||||||
|  | 	padding: 0 .5rem; | ||||||
|  | 	margin: 0 0 .75rem 0; | ||||||
|  | 	color: var(--text-light); | ||||||
|  | 	background: var(--profile); | ||||||
|  | 	font-size: .9rem; | ||||||
|  | 	font-weight: bold; | ||||||
|  | 
 | ||||||
|  | 	.icon { | ||||||
|  | 		fill: var(--text-light); | ||||||
|  | 		margin: -.1rem .5rem 0 0; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-duration, | ||||||
|  | .chapter-time { | ||||||
|  | 	display: flex; | ||||||
|  | 	align-items: center; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-duration .icon { | ||||||
|  | 	/* narrower icon */ | ||||||
|  | 	margin: -.1rem .3rem 0 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-info { | ||||||
|  | 	padding: 0 .5rem; | ||||||
|  | 	font-size: 1rem; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-row { | ||||||
|  | 	margin: 0 0 .5rem 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-title { | ||||||
|  | 	padding: 0; | ||||||
|  | 	font-size: 1rem; | ||||||
|  | 	white-space: nowrap; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	text-overflow: ellipsis; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .chapter-description { | ||||||
|  | 	line-height: 1.5; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | @media(max-width: $breakpoint-micro) { | ||||||
|  | 	.chapters { | ||||||
|  | 		grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr)); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  | @ -1,126 +0,0 @@ | ||||||
| <template> |  | ||||||
| 	<ul class="clips nolist"> |  | ||||||
| 		<li |  | ||||||
| 			v-for="clip in clips" |  | ||||||
| 			:key="`clip-${clip.id}`" |  | ||||||
| 			class="clip" |  | ||||||
| 		> |  | ||||||
| 			<div class="clip-poster-container"> |  | ||||||
| 				<a |  | ||||||
| 					v-if="clip.poster" |  | ||||||
| 					:href="`/media/${clip.poster.path}`" |  | ||||||
| 					target="_blank" |  | ||||||
| 					rel="noopener noreferrer" |  | ||||||
| 				> |  | ||||||
| 					<img |  | ||||||
| 						:src="`/media/${clip.poster.thumbnail}`" |  | ||||||
| 						class="clip-poster" |  | ||||||
| 					> |  | ||||||
| 				</a> |  | ||||||
| 
 |  | ||||||
| 				<span |  | ||||||
| 					v-if="clip.duration" |  | ||||||
| 					class="clip-duration" |  | ||||||
| 				>{{ formatDuration(clip.duration) }}</span> |  | ||||||
| 			</div> |  | ||||||
| 
 |  | ||||||
| 			<div class="clip-info"> |  | ||||||
| 				<h3 |  | ||||||
| 					v-if="clip.title" |  | ||||||
| 					class="clip-row clip-title" |  | ||||||
| 					:title="clip.title" |  | ||||||
| 				>{{ clip.title }}</h3> |  | ||||||
| 
 |  | ||||||
| 				<p class="clip-row clip-description">{{ clip.description }}</p> |  | ||||||
| 
 |  | ||||||
| 				<Tags |  | ||||||
| 					:tags="clip.tags" |  | ||||||
| 					class="clip-row clip-tags" |  | ||||||
| 				/> |  | ||||||
| 			</div> |  | ||||||
| 		</li> |  | ||||||
| 	</ul> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import Tags from './tags.vue'; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
| 	components: { |  | ||||||
| 		Tags, |  | ||||||
| 	}, |  | ||||||
| 	props: { |  | ||||||
| 		clips: { |  | ||||||
| 			type: Array, |  | ||||||
| 			default: () => [], |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style lang="scss" scoped> |  | ||||||
| @import 'breakpoints'; |  | ||||||
| 
 |  | ||||||
| .clips { |  | ||||||
| 	display: grid; |  | ||||||
| 	grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr)); |  | ||||||
| 	grid-gap: 1rem; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip { |  | ||||||
| 	background: var(--background); |  | ||||||
| 	box-shadow: 0 0 3px var(--shadow-weak); |  | ||||||
| 	margin: 0 0 .5rem 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-poster-container { |  | ||||||
| 	position: relative; |  | ||||||
| 	margin: 0 0 1rem 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-poster { |  | ||||||
| 	width: 100%; |  | ||||||
| 	height: 10rem; |  | ||||||
| 	object-fit: cover; |  | ||||||
| 	object-position: center; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-duration { |  | ||||||
| 	background: var(--darken); |  | ||||||
| 	color: var(--text-light); |  | ||||||
| 	display: block; |  | ||||||
| 	position: absolute; |  | ||||||
| 	top: 0; |  | ||||||
| 	right: 0; |  | ||||||
| 	padding: .25rem .5rem; |  | ||||||
| 	font-size: .9rem; |  | ||||||
| 	font-weight: bold; |  | ||||||
| 	text-shadow: 0 0 2px var(--darken-strong); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-info { |  | ||||||
| 	padding: 0 1rem; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-row { |  | ||||||
| 	margin: 0 0 .75rem 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-title { |  | ||||||
| 	padding: 0; |  | ||||||
| 	font-size: 1rem; |  | ||||||
| 	white-space: nowrap; |  | ||||||
| 	overflow: hidden; |  | ||||||
| 	text-overflow: ellipsis; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .clip-description { |  | ||||||
| 	line-height: 1.5; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| @media(max-width: $breakpoint-micro) { |  | ||||||
| 	.clips { |  | ||||||
| 		grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr)); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
|  | @ -104,6 +104,15 @@ | ||||||
| 				<p class="description">{{ release.description }}</p> | 				<p class="description">{{ release.description }}</p> | ||||||
| 			</div> | 			</div> | ||||||
| 
 | 
 | ||||||
|  | 			<div | ||||||
|  | 				v-if="release.chapters?.length > 0" | ||||||
|  | 				class="row nolist" | ||||||
|  | 			> | ||||||
|  | 				<span class="row-label">Chapters</span> | ||||||
|  | 
 | ||||||
|  | 				<Chapters :chapters="release.chapters" /> | ||||||
|  | 			</div> | ||||||
|  | 
 | ||||||
| 			<div class="row row-tidbits"> | 			<div class="row row-tidbits"> | ||||||
| 				<div | 				<div | ||||||
| 					v-if="release.duration" | 					v-if="release.duration" | ||||||
|  | @ -169,15 +178,6 @@ | ||||||
| 				</div> | 				</div> | ||||||
| 			</div> | 			</div> | ||||||
| 
 | 
 | ||||||
| 			<div |  | ||||||
| 				v-if="release.clips && release.clips.length > 0" |  | ||||||
| 				class="row nolist" |  | ||||||
| 			> |  | ||||||
| 				<span class="row-label">Clips</span> |  | ||||||
| 
 |  | ||||||
| 				<Clips :clips="release.clips" /> |  | ||||||
| 			</div> |  | ||||||
| 
 |  | ||||||
| 			<div | 			<div | ||||||
| 				v-if="release.comment" | 				v-if="release.comment" | ||||||
| 				class="row" | 				class="row" | ||||||
|  | @ -204,7 +204,7 @@ import Details from './details.vue'; | ||||||
| import Banner from './banner.vue'; | import Banner from './banner.vue'; | ||||||
| import Album from '../album/album.vue'; | import Album from '../album/album.vue'; | ||||||
| import Tags from './tags.vue'; | import Tags from './tags.vue'; | ||||||
| import Clips from './clips.vue'; | import Chapters from './chapters.vue'; | ||||||
| import Actor from '../actors/tile.vue'; | import Actor from '../actors/tile.vue'; | ||||||
| import Releases from './releases.vue'; | import Releases from './releases.vue'; | ||||||
| import Scroll from '../scroll/scroll.vue'; | import Scroll from '../scroll/scroll.vue'; | ||||||
|  | @ -244,7 +244,7 @@ export default { | ||||||
| 		Banner, | 		Banner, | ||||||
| 		Scroll, | 		Scroll, | ||||||
| 		Releases, | 		Releases, | ||||||
| 		Clips, | 		Chapters, | ||||||
| 		Tags, | 		Tags, | ||||||
| 	}, | 	}, | ||||||
| 	data() { | 	data() { | ||||||
|  |  | ||||||
|  | @ -0,0 +1,5 @@ | ||||||
|  | <!-- Generated by IcoMoon.io --> | ||||||
|  | <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> | ||||||
|  | <title>clock</title> | ||||||
|  | <path d="M10.293 11.707l-3.293-3.293v-4.414h2v3.586l2.707 2.707zM8 0c-4.418 0-8 3.582-8 8s3.582 8 8 8 8-3.582 8-8-3.582-8-8-8zM8 14c-3.314 0-6-2.686-6-6s2.686-6 6-6c3.314 0 6 2.686 6 6s-2.686 6-6 6z"></path> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 367 B | 
|  | @ -0,0 +1,5 @@ | ||||||
|  | <!-- Generated by IcoMoon.io --> | ||||||
|  | <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> | ||||||
|  | <title>clock3</title> | ||||||
|  | <path d="M12 7v2h-5v-6h2v4zM8 0c-4.418 0-8 3.582-8 8s3.582 8 8 8 8-3.582 8-8-3.582-8-8-8zM8 14c-3.314 0-6-2.686-6-6s2.686-6 6-6c3.314 0 6 2.686 6 6s-2.686 6-6 6z"></path> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 331 B | 
|  | @ -0,0 +1,5 @@ | ||||||
|  | <!-- Generated by IcoMoon.io --> | ||||||
|  | <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> | ||||||
|  | <title>clock4</title> | ||||||
|  | <path d="M8 0c-4.418 0-8 3.582-8 8s3.582 8 8 8 8-3.582 8-8-3.582-8-8-8zM12 9h-5v-6h2v4h3v2z"></path> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 261 B | 
|  | @ -0,0 +1,5 @@ | ||||||
|  | <!-- Generated by IcoMoon.io --> | ||||||
|  | <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> | ||||||
|  | <title>pagebreak</title> | ||||||
|  | <path d="M4 6v-6h12v6h-1v-5h-10v5zM16 9v7h-12v-7h1v6h10v-6zM8 7h2v1h-2zM5 7h2v1h-2zM11 7h2v1h-2zM14 7h2v1h-2zM0 4.5l3 3-3 3z"></path> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 297 B | 
|  | @ -0,0 +1,5 @@ | ||||||
|  | <!-- Generated by IcoMoon.io --> | ||||||
|  | <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> | ||||||
|  | <title>stack4</title> | ||||||
|  | <path d="M5 1v1.155l-2.619 0.368 0.17 1.211-2.551 0.732 3.308 11.535 10.189-2.921 0.558-0.079h1.945v-12h-11zM3.929 14.879l-2.808-9.793 1.558-0.447 1.373 9.766 2.997-0.421-3.119 0.894zM4.822 13.382l-1.418-10.088 1.595-0.224v9.93h2.543l-2.721 0.382zM15 12h-9v-10h9v10zM7 7.125h7v0.25h-7zM7 7.625h7v0.25h-7zM7 8.625h7v0.25h-7zM7 8.125h7v0.25h-7zM7 9.125h7v0.25h-7zM7 10.625h7v0.25h-7zM7 9.625h7v0.25h-7zM7 10.125h7v0.25h-7zM7 4.625h7v0.25h-7zM7 3.625h7v0.25h-7zM7 4.125h7v0.25h-7zM7 3.125h7v0.25h-7zM7 6.625h7v0.25h-7zM7 6.125h7v0.25h-7zM7 5.125h7v0.25h-7zM7 5.625h7v0.25h-7z"></path> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 742 B | 
|  | @ -0,0 +1,6 @@ | ||||||
|  | <!-- Generated by IcoMoon.io --> | ||||||
|  | <svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"> | ||||||
|  | <title>watch2</title> | ||||||
|  | <path d="M9.5 8h-1.5v-2.5c0-0.276-0.224-0.5-0.5-0.5s-0.5 0.224-0.5 0.5v3c0 0.276 0.224 0.5 0.5 0.5h2c0.276 0 0.5-0.224 0.5-0.5s-0.224-0.5-0.5-0.5z"></path> | ||||||
|  | <path d="M14 8c0-2.422-1.435-4.508-3.501-5.455h0.001l-0.5-2.545h-4l-0.5 2.545h0.001c-2.066 0.948-3.501 3.034-3.501 5.455s1.435 4.507 3.5 5.455l-0 0 0.5 2.545h4l0.5-2.545h-0.001c2.066-0.948 3.501-3.034 3.501-5.455zM8 12.5c-2.485 0-4.5-2.015-4.5-4.5s2.015-4.5 4.5-4.5c2.485 0 4.5 2.015 4.5 4.5s-2.015 4.5-4.5 4.5z"></path> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 637 B | 
|  | @ -69,7 +69,7 @@ function curateRelease(release) { | ||||||
| 
 | 
 | ||||||
| 	if (release.scenes) curatedRelease.scenes = release.scenes.filter(Boolean).map(({ scene }) => curateRelease(scene)); | 	if (release.scenes) curatedRelease.scenes = release.scenes.filter(Boolean).map(({ scene }) => curateRelease(scene)); | ||||||
| 	if (release.movies) curatedRelease.movies = release.movies.filter(Boolean).map(({ movie }) => curateRelease(movie)); | 	if (release.movies) curatedRelease.movies = release.movies.filter(Boolean).map(({ movie }) => curateRelease(movie)); | ||||||
| 	if (release.clips) curatedRelease.clips = release.clips.filter(Boolean).map(clip => curateRelease(clip)); | 	if (release.chapters) curatedRelease.chapters = release.chapters.filter(Boolean).map(chapter => curateRelease(chapter)); | ||||||
| 	if (release.photos) curatedRelease.photos = release.photos.filter(Boolean).map(photo => photo.media || photo); | 	if (release.photos) curatedRelease.photos = release.photos.filter(Boolean).map(photo => photo.media || photo); | ||||||
| 	if (release.covers) curatedRelease.covers = release.covers.filter(Boolean).map(({ media }) => media); | 	if (release.covers) curatedRelease.covers = release.covers.filter(Boolean).map(({ media }) => media); | ||||||
| 	if (release.trailer) curatedRelease.trailer = release.trailer.media; | 	if (release.trailer) curatedRelease.trailer = release.trailer.media; | ||||||
|  |  | ||||||
|  | @ -268,19 +268,21 @@ const releaseFragment = ` | ||||||
|     ${releaseTrailerFragment} |     ${releaseTrailerFragment} | ||||||
|     ${releaseTeaserFragment} |     ${releaseTeaserFragment} | ||||||
|     ${siteFragment} |     ${siteFragment} | ||||||
| 	clips { | 	chapters { | ||||||
| 		id | 		id | ||||||
|  | 		index | ||||||
|  | 		time | ||||||
|  | 		duration | ||||||
| 		title | 		title | ||||||
| 		description | 		description | ||||||
| 		duration | 		tags: chaptersTags { | ||||||
| 		tags: clipsTags { |  | ||||||
| 			tag { | 			tag { | ||||||
| 				id | 				id | ||||||
| 				name | 				name | ||||||
| 				slug | 				slug | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		poster: clipsPosterByClipId { | 		poster: chaptersPosterByChapterId { | ||||||
| 			media { | 			media { | ||||||
| 				id | 				id | ||||||
| 				index | 				index | ||||||
|  |  | ||||||
|  | @ -903,7 +903,7 @@ exports.up = knex => Promise.resolve() | ||||||
| 
 | 
 | ||||||
| 		table.unique('movie_id'); | 		table.unique('movie_id'); | ||||||
| 	})) | 	})) | ||||||
| 	.then(() => knex.schema.createTable('clips', (table) => { | 	.then(() => knex.schema.createTable('chapters', (table) => { | ||||||
| 		table.increments('id', 16); | 		table.increments('id', 16); | ||||||
| 
 | 
 | ||||||
| 		table.integer('release_id', 12) | 		table.integer('release_id', 12) | ||||||
|  | @ -912,16 +912,18 @@ exports.up = knex => Promise.resolve() | ||||||
| 			.notNullable() | 			.notNullable() | ||||||
| 			.onDelete('cascade'); | 			.onDelete('cascade'); | ||||||
| 
 | 
 | ||||||
| 		table.integer('clip', 6); | 		table.integer('index'); | ||||||
|  | 		table.unique(['release_id', 'index']); | ||||||
| 
 | 
 | ||||||
| 		table.unique(['release_id', 'clip']); | 		table.integer('time') | ||||||
| 
 | 			.unsigned(); | ||||||
| 		table.text('title'); |  | ||||||
| 		table.text('description'); |  | ||||||
| 
 | 
 | ||||||
| 		table.integer('duration') | 		table.integer('duration') | ||||||
| 			.unsigned(); | 			.unsigned(); | ||||||
| 
 | 
 | ||||||
|  | 		table.text('title'); | ||||||
|  | 		table.text('description'); | ||||||
|  | 
 | ||||||
| 		table.integer('created_batch_id', 12) | 		table.integer('created_batch_id', 12) | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('batches') | 			.inTable('batches') | ||||||
|  | @ -935,11 +937,11 @@ exports.up = knex => Promise.resolve() | ||||||
| 		table.datetime('created_at') | 		table.datetime('created_at') | ||||||
| 			.defaultTo(knex.fn.now()); | 			.defaultTo(knex.fn.now()); | ||||||
| 	})) | 	})) | ||||||
| 	.then(() => knex.schema.createTable('clips_posters', (table) => { | 	.then(() => knex.schema.createTable('chapters_posters', (table) => { | ||||||
| 		table.integer('clip_id', 16) | 		table.integer('chapter_id', 16) | ||||||
| 			.notNullable() | 			.notNullable() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('clips') | 			.inTable('chapters') | ||||||
| 			.onDelete('cascade'); | 			.onDelete('cascade'); | ||||||
| 
 | 
 | ||||||
| 		table.text('media_id', 21) | 		table.text('media_id', 21) | ||||||
|  | @ -947,13 +949,13 @@ exports.up = knex => Promise.resolve() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('media'); | 			.inTable('media'); | ||||||
| 
 | 
 | ||||||
| 		table.unique('clip_id'); | 		table.unique('chapter_id'); | ||||||
| 	})) | 	})) | ||||||
| 	.then(() => knex.schema.createTable('clips_photos', (table) => { | 	.then(() => knex.schema.createTable('chapters_photos', (table) => { | ||||||
| 		table.integer('clip_id', 16) | 		table.integer('chapter_id', 16) | ||||||
| 			.notNullable() | 			.notNullable() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('clips') | 			.inTable('chapters') | ||||||
| 			.onDelete('cascade'); | 			.onDelete('cascade'); | ||||||
| 
 | 
 | ||||||
| 		table.text('media_id', 21) | 		table.text('media_id', 21) | ||||||
|  | @ -961,21 +963,22 @@ exports.up = knex => Promise.resolve() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('media'); | 			.inTable('media'); | ||||||
| 
 | 
 | ||||||
| 		table.unique(['clip_id', 'media_id']); | 		table.unique(['chapter_id', 'media_id']); | ||||||
| 	})) | 	})) | ||||||
| 	.then(() => knex.schema.createTable('clips_tags', (table) => { | 	.then(() => knex.schema.createTable('chapters_tags', (table) => { | ||||||
| 		table.integer('tag_id', 12) | 		table.integer('tag_id', 12) | ||||||
| 			.notNullable() | 			.notNullable() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('tags') | 			.inTable('tags') | ||||||
| 			.onDelete('cascade'); | 			.onDelete('cascade'); | ||||||
| 
 | 
 | ||||||
| 		table.integer('clip_id', 16) | 		table.integer('chapter_id', 16) | ||||||
| 			.notNullable() | 			.notNullable() | ||||||
| 			.references('id') | 			.references('id') | ||||||
| 			.inTable('clips'); | 			.inTable('chapters') | ||||||
|  | 			.onDelete('cascade'); | ||||||
| 
 | 
 | ||||||
| 		table.unique(['tag_id', 'clip_id']); | 		table.unique(['tag_id', 'chapter_id']); | ||||||
| 	})) | 	})) | ||||||
| 	// SEARCH
 | 	// SEARCH
 | ||||||
| 	.then(() => { // eslint-disable-line arrow-body-style
 | 	.then(() => { // eslint-disable-line arrow-body-style
 | ||||||
|  | @ -1207,6 +1210,10 @@ exports.down = (knex) => { // eslint-disable-line arrow-body-style | ||||||
| 		DROP TABLE IF EXISTS clips_posters CASCADE; | 		DROP TABLE IF EXISTS clips_posters CASCADE; | ||||||
| 		DROP TABLE IF EXISTS clips_photos CASCADE; | 		DROP TABLE IF EXISTS clips_photos CASCADE; | ||||||
| 
 | 
 | ||||||
|  | 		DROP TABLE IF EXISTS chapters_tags CASCADE; | ||||||
|  | 		DROP TABLE IF EXISTS chapters_posters CASCADE; | ||||||
|  | 		DROP TABLE IF EXISTS chapters_photos CASCADE; | ||||||
|  | 
 | ||||||
| 		DROP TABLE IF EXISTS batches CASCADE; | 		DROP TABLE IF EXISTS batches CASCADE; | ||||||
| 
 | 
 | ||||||
| 		DROP TABLE IF EXISTS actors_avatars CASCADE; | 		DROP TABLE IF EXISTS actors_avatars CASCADE; | ||||||
|  | @ -1226,6 +1233,7 @@ exports.down = (knex) => { // eslint-disable-line arrow-body-style | ||||||
| 		DROP TABLE IF EXISTS tags_photos CASCADE; | 		DROP TABLE IF EXISTS tags_photos CASCADE; | ||||||
| 		DROP TABLE IF EXISTS movies CASCADE; | 		DROP TABLE IF EXISTS movies CASCADE; | ||||||
| 		DROP TABLE IF EXISTS clips CASCADE; | 		DROP TABLE IF EXISTS clips CASCADE; | ||||||
|  | 		DROP TABLE IF EXISTS chapters CASCADE; | ||||||
| 		DROP TABLE IF EXISTS releases CASCADE; | 		DROP TABLE IF EXISTS releases CASCADE; | ||||||
| 		DROP TABLE IF EXISTS actors CASCADE; | 		DROP TABLE IF EXISTS actors CASCADE; | ||||||
| 		DROP TABLE IF EXISTS directors CASCADE; | 		DROP TABLE IF EXISTS directors CASCADE; | ||||||
|  |  | ||||||
|  | @ -12,6 +12,7 @@ | ||||||
|                 "@graphile-contrib/pg-simplify-inflector": "^5.0.0-beta.1", |                 "@graphile-contrib/pg-simplify-inflector": "^5.0.0-beta.1", | ||||||
|                 "@thependulum/bhttp": "^1.2.6", |                 "@thependulum/bhttp": "^1.2.6", | ||||||
|                 "acorn": "^8.0.4", |                 "acorn": "^8.0.4", | ||||||
|  |                 "array-equal": "^1.0.0", | ||||||
|                 "aws-sdk": "^2.847.0", |                 "aws-sdk": "^2.847.0", | ||||||
|                 "babel-polyfill": "^6.26.0", |                 "babel-polyfill": "^6.26.0", | ||||||
|                 "bhttp": "^1.2.6", |                 "bhttp": "^1.2.6", | ||||||
|  | @ -23,6 +24,7 @@ | ||||||
|                 "casual": "^1.6.2", |                 "casual": "^1.6.2", | ||||||
|                 "cheerio": "^1.0.0-rc.3", |                 "cheerio": "^1.0.0-rc.3", | ||||||
|                 "cli-confirm": "^1.0.1", |                 "cli-confirm": "^1.0.1", | ||||||
|  |                 "cloudscraper": "^4.6.0", | ||||||
|                 "config": "^3.2.5", |                 "config": "^3.2.5", | ||||||
|                 "connect-session-knex": "^2.0.0", |                 "connect-session-knex": "^2.0.0", | ||||||
|                 "convert": "^1.6.2", |                 "convert": "^1.6.2", | ||||||
|  | @ -2210,6 +2212,11 @@ | ||||||
|                 "node": ">=0.10.0" |                 "node": ">=0.10.0" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "node_modules/array-equal": { | ||||||
|  |             "version": "1.0.0", | ||||||
|  |             "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", | ||||||
|  |             "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=" | ||||||
|  |         }, | ||||||
|         "node_modules/array-find-index": { |         "node_modules/array-find-index": { | ||||||
|             "version": "1.0.2", |             "version": "1.0.2", | ||||||
|             "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", |             "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", | ||||||
|  | @ -2879,6 +2886,15 @@ | ||||||
|                 "wcwidth": "^1.0.1" |                 "wcwidth": "^1.0.1" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "node_modules/brotli": { | ||||||
|  |             "version": "1.3.2", | ||||||
|  |             "resolved": "https://registry.npmjs.org/brotli/-/brotli-1.3.2.tgz", | ||||||
|  |             "integrity": "sha1-UlqcrU/LqWR119OI9q7LE+7VL0Y=", | ||||||
|  |             "peer": true, | ||||||
|  |             "dependencies": { | ||||||
|  |                 "base64-js": "^1.1.2" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "node_modules/browser-process-hrtime": { |         "node_modules/browser-process-hrtime": { | ||||||
|             "version": "1.0.0", |             "version": "1.0.0", | ||||||
|             "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", |             "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", | ||||||
|  | @ -3259,6 +3275,21 @@ | ||||||
|                 "node": ">=0.8" |                 "node": ">=0.8" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "node_modules/cloudscraper": { | ||||||
|  |             "version": "4.6.0", | ||||||
|  |             "resolved": "https://registry.npmjs.org/cloudscraper/-/cloudscraper-4.6.0.tgz", | ||||||
|  |             "integrity": "sha512-42g6atOAQwhoMlzCYsB1238RYEQa3ibcxhjVeYuZQDLGSZjBNAKOlF/2kcPwZUhlRKA9LDwuYQ7/0LCoMui2ww==", | ||||||
|  |             "dependencies": { | ||||||
|  |                 "request-promise": "^4.2.4" | ||||||
|  |             }, | ||||||
|  |             "engines": { | ||||||
|  |                 "node": ">=8" | ||||||
|  |             }, | ||||||
|  |             "peerDependencies": { | ||||||
|  |                 "brotli": "^1.3.2", | ||||||
|  |                 "request": "^2.88.0" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "node_modules/code-point-at": { |         "node_modules/code-point-at": { | ||||||
|             "version": "1.1.0", |             "version": "1.1.0", | ||||||
|             "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", |             "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", | ||||||
|  | @ -11816,6 +11847,24 @@ | ||||||
|                 "node": ">= 6" |                 "node": ">= 6" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "node_modules/request-promise": { | ||||||
|  |             "version": "4.2.6", | ||||||
|  |             "resolved": "https://registry.npmjs.org/request-promise/-/request-promise-4.2.6.tgz", | ||||||
|  |             "integrity": "sha512-HCHI3DJJUakkOr8fNoCc73E5nU5bqITjOYFMDrKHYOXWXrgD/SBaC7LjwuPymUprRyuF06UK7hd/lMHkmUXglQ==", | ||||||
|  |             "deprecated": "request-promise has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142", | ||||||
|  |             "dependencies": { | ||||||
|  |                 "bluebird": "^3.5.0", | ||||||
|  |                 "request-promise-core": "1.1.4", | ||||||
|  |                 "stealthy-require": "^1.1.1", | ||||||
|  |                 "tough-cookie": "^2.3.3" | ||||||
|  |             }, | ||||||
|  |             "engines": { | ||||||
|  |                 "node": ">=0.10.0" | ||||||
|  |             }, | ||||||
|  |             "peerDependencies": { | ||||||
|  |                 "request": "^2.34" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "node_modules/request-promise-core": { |         "node_modules/request-promise-core": { | ||||||
|             "version": "1.1.3", |             "version": "1.1.3", | ||||||
|             "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz", |             "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz", | ||||||
|  | @ -11852,6 +11901,32 @@ | ||||||
|                 "node": ">=0.8" |                 "node": ">=0.8" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "node_modules/request-promise/node_modules/request-promise-core": { | ||||||
|  |             "version": "1.1.4", | ||||||
|  |             "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.4.tgz", | ||||||
|  |             "integrity": "sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw==", | ||||||
|  |             "dependencies": { | ||||||
|  |                 "lodash": "^4.17.19" | ||||||
|  |             }, | ||||||
|  |             "engines": { | ||||||
|  |                 "node": ">=0.10.0" | ||||||
|  |             }, | ||||||
|  |             "peerDependencies": { | ||||||
|  |                 "request": "^2.34" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         "node_modules/request-promise/node_modules/tough-cookie": { | ||||||
|  |             "version": "2.5.0", | ||||||
|  |             "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", | ||||||
|  |             "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", | ||||||
|  |             "dependencies": { | ||||||
|  |                 "psl": "^1.1.28", | ||||||
|  |                 "punycode": "^2.1.1" | ||||||
|  |             }, | ||||||
|  |             "engines": { | ||||||
|  |                 "node": ">=0.8" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "node_modules/request/node_modules/extend": { |         "node_modules/request/node_modules/extend": { | ||||||
|             "version": "3.0.2", |             "version": "3.0.2", | ||||||
|             "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", |             "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", | ||||||
|  | @ -17400,6 +17475,11 @@ | ||||||
|             "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", |             "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", | ||||||
|             "integrity": "sha1-p5SvDAWrF1KEbudTofIRoFugxE8=" |             "integrity": "sha1-p5SvDAWrF1KEbudTofIRoFugxE8=" | ||||||
|         }, |         }, | ||||||
|  |         "array-equal": { | ||||||
|  |             "version": "1.0.0", | ||||||
|  |             "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", | ||||||
|  |             "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=" | ||||||
|  |         }, | ||||||
|         "array-find-index": { |         "array-find-index": { | ||||||
|             "version": "1.0.2", |             "version": "1.0.2", | ||||||
|             "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", |             "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", | ||||||
|  | @ -17967,6 +18047,15 @@ | ||||||
|                 "wcwidth": "^1.0.1" |                 "wcwidth": "^1.0.1" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "brotli": { | ||||||
|  |             "version": "1.3.2", | ||||||
|  |             "resolved": "https://registry.npmjs.org/brotli/-/brotli-1.3.2.tgz", | ||||||
|  |             "integrity": "sha1-UlqcrU/LqWR119OI9q7LE+7VL0Y=", | ||||||
|  |             "peer": true, | ||||||
|  |             "requires": { | ||||||
|  |                 "base64-js": "^1.1.2" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "browser-process-hrtime": { |         "browser-process-hrtime": { | ||||||
|             "version": "1.0.0", |             "version": "1.0.0", | ||||||
|             "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", |             "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", | ||||||
|  | @ -18277,6 +18366,14 @@ | ||||||
|             "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", |             "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", | ||||||
|             "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=" |             "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=" | ||||||
|         }, |         }, | ||||||
|  |         "cloudscraper": { | ||||||
|  |             "version": "4.6.0", | ||||||
|  |             "resolved": "https://registry.npmjs.org/cloudscraper/-/cloudscraper-4.6.0.tgz", | ||||||
|  |             "integrity": "sha512-42g6atOAQwhoMlzCYsB1238RYEQa3ibcxhjVeYuZQDLGSZjBNAKOlF/2kcPwZUhlRKA9LDwuYQ7/0LCoMui2ww==", | ||||||
|  |             "requires": { | ||||||
|  |                 "request-promise": "^4.2.4" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "code-point-at": { |         "code-point-at": { | ||||||
|             "version": "1.1.0", |             "version": "1.1.0", | ||||||
|             "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", |             "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", | ||||||
|  | @ -25165,6 +25262,36 @@ | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "request-promise": { | ||||||
|  |             "version": "4.2.6", | ||||||
|  |             "resolved": "https://registry.npmjs.org/request-promise/-/request-promise-4.2.6.tgz", | ||||||
|  |             "integrity": "sha512-HCHI3DJJUakkOr8fNoCc73E5nU5bqITjOYFMDrKHYOXWXrgD/SBaC7LjwuPymUprRyuF06UK7hd/lMHkmUXglQ==", | ||||||
|  |             "requires": { | ||||||
|  |                 "bluebird": "^3.5.0", | ||||||
|  |                 "request-promise-core": "1.1.4", | ||||||
|  |                 "stealthy-require": "^1.1.1", | ||||||
|  |                 "tough-cookie": "^2.3.3" | ||||||
|  |             }, | ||||||
|  |             "dependencies": { | ||||||
|  |                 "request-promise-core": { | ||||||
|  |                     "version": "1.1.4", | ||||||
|  |                     "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.4.tgz", | ||||||
|  |                     "integrity": "sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw==", | ||||||
|  |                     "requires": { | ||||||
|  |                         "lodash": "^4.17.19" | ||||||
|  |                     } | ||||||
|  |                 }, | ||||||
|  |                 "tough-cookie": { | ||||||
|  |                     "version": "2.5.0", | ||||||
|  |                     "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", | ||||||
|  |                     "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", | ||||||
|  |                     "requires": { | ||||||
|  |                         "psl": "^1.1.28", | ||||||
|  |                         "punycode": "^2.1.1" | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "request-promise-core": { |         "request-promise-core": { | ||||||
|             "version": "1.1.3", |             "version": "1.1.3", | ||||||
|             "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz", |             "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz", | ||||||
|  |  | ||||||
|  | @ -73,6 +73,7 @@ | ||||||
|         "@graphile-contrib/pg-simplify-inflector": "^5.0.0-beta.1", |         "@graphile-contrib/pg-simplify-inflector": "^5.0.0-beta.1", | ||||||
|         "@thependulum/bhttp": "^1.2.6", |         "@thependulum/bhttp": "^1.2.6", | ||||||
|         "acorn": "^8.0.4", |         "acorn": "^8.0.4", | ||||||
|  |         "array-equal": "^1.0.0", | ||||||
|         "aws-sdk": "^2.847.0", |         "aws-sdk": "^2.847.0", | ||||||
|         "babel-polyfill": "^6.26.0", |         "babel-polyfill": "^6.26.0", | ||||||
|         "bhttp": "^1.2.6", |         "bhttp": "^1.2.6", | ||||||
|  | @ -84,6 +85,7 @@ | ||||||
|         "casual": "^1.6.2", |         "casual": "^1.6.2", | ||||||
|         "cheerio": "^1.0.0-rc.3", |         "cheerio": "^1.0.0-rc.3", | ||||||
|         "cli-confirm": "^1.0.1", |         "cli-confirm": "^1.0.1", | ||||||
|  |         "cloudscraper": "^4.6.0", | ||||||
|         "config": "^3.2.5", |         "config": "^3.2.5", | ||||||
|         "connect-session-knex": "^2.0.0", |         "connect-session-knex": "^2.0.0", | ||||||
|         "convert": "^1.6.2", |         "convert": "^1.6.2", | ||||||
|  |  | ||||||
| After Width: | Height: | Size: 22 KiB | 
| Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1008 B | 
| Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1008 B | 
| Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1008 B | 
| Before Width: | Height: | Size: 2.9 KiB After Width: | Height: | Size: 2.9 KiB | 
| Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 3.7 KiB | 
| Before Width: | Height: | Size: 3.5 KiB After Width: | Height: | Size: 3.5 KiB | 
| Before Width: | Height: | Size: 2.1 KiB After Width: | Height: | Size: 2.1 KiB | 
| Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.9 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB | 
| Before Width: | Height: | Size: 6.7 KiB After Width: | Height: | Size: 6.7 KiB | 
| Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 5.1 KiB | 
| After Width: | Height: | Size: 6.1 KiB | 
| Before Width: | Height: | Size: 3.0 KiB After Width: | Height: | Size: 3.0 KiB | 
| Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.9 KiB | 
| Before Width: | Height: | Size: 2.6 KiB After Width: | Height: | Size: 2.6 KiB | 
| Before Width: | Height: | Size: 4.8 KiB After Width: | Height: | Size: 4.8 KiB | 
| Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 5.2 KiB After Width: | Height: | Size: 5.2 KiB | 
| Before Width: | Height: | Size: 3.4 KiB After Width: | Height: | Size: 3.4 KiB | 
| Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 2.5 KiB | 
| Before Width: | Height: | Size: 3.6 KiB After Width: | Height: | Size: 3.6 KiB | 
| Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 3.7 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 3.1 KiB After Width: | Height: | Size: 3.1 KiB | 
| Before Width: | Height: | Size: 3.3 KiB After Width: | Height: | Size: 3.3 KiB | 
| Before Width: | Height: | Size: 5.4 KiB After Width: | Height: | Size: 5.4 KiB | 
| Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.9 KiB | 
| Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB | 
| Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 2.0 KiB | 
| Before Width: | Height: | Size: 4.2 KiB After Width: | Height: | Size: 4.2 KiB | 
| Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 6.1 KiB | 
| Before Width: | Height: | Size: 5.7 KiB After Width: | Height: | Size: 5.7 KiB | 
| Before Width: | Height: | Size: 3.1 KiB After Width: | Height: | Size: 3.1 KiB | 
| Before Width: | Height: | Size: 5.1 KiB After Width: | Height: | Size: 5.1 KiB | 
| Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 2.2 KiB | 
| Before Width: | Height: | Size: 2.0 KiB After Width: | Height: | Size: 2.0 KiB | 
| Before Width: | Height: | Size: 1.9 KiB After Width: | Height: | Size: 1.9 KiB | 
| Before Width: | Height: | Size: 2.6 KiB After Width: | Height: | Size: 2.6 KiB | 
| Before Width: | Height: | Size: 4.6 KiB After Width: | Height: | Size: 4.6 KiB | 
| Before Width: | Height: | Size: 2.8 KiB After Width: | Height: | Size: 2.8 KiB | 
| After Width: | Height: | Size: 13 KiB | 
| After Width: | Height: | Size: 11 KiB | 
| After Width: | Height: | Size: 22 KiB | 
| After Width: | Height: | Size: 14 KiB | 
| After Width: | Height: | Size: 46 KiB | 
| After Width: | Height: | Size: 1008 B | 
| After Width: | Height: | Size: 1.0 KiB | 
| Before Width: | Height: | Size: 46 KiB After Width: | Height: | Size: 22 KiB | 
| Before Width: | Height: | Size: 28 KiB After Width: | Height: | Size: 28 KiB | 
| Before Width: | Height: | Size: 36 KiB After Width: | Height: | Size: 36 KiB | 
| Before Width: | Height: | Size: 45 KiB After Width: | Height: | Size: 45 KiB | 
| Before Width: | Height: | Size: 15 KiB After Width: | Height: | Size: 15 KiB | 
| Before Width: | Height: | Size: 14 KiB After Width: | Height: | Size: 14 KiB | 
| Before Width: | Height: | Size: 9.7 KiB After Width: | Height: | Size: 9.7 KiB | 
| Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 55 KiB | 
| Before Width: | Height: | Size: 66 KiB After Width: | Height: | Size: 66 KiB | 
| After Width: | Height: | Size: 10 KiB | 
| Before Width: | Height: | Size: 17 KiB After Width: | Height: | Size: 17 KiB | 
| Before Width: | Height: | Size: 16 KiB After Width: | Height: | Size: 16 KiB | 
| Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB | 
| Before Width: | Height: | Size: 60 KiB After Width: | Height: | Size: 60 KiB | 
| Before Width: | Height: | Size: 9.2 KiB After Width: | Height: | Size: 9.2 KiB | 
| Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB | 
| Before Width: | Height: | Size: 71 KiB After Width: | Height: | Size: 71 KiB | 
| Before Width: | Height: | Size: 25 KiB After Width: | Height: | Size: 25 KiB | 
| Before Width: | Height: | Size: 21 KiB After Width: | Height: | Size: 21 KiB | 
| Before Width: | Height: | Size: 44 KiB After Width: | Height: | Size: 44 KiB | 
| Before Width: | Height: | Size: 37 KiB After Width: | Height: | Size: 37 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.8 KiB | 
| Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 12 KiB | 
| Before Width: | Height: | Size: 28 KiB After Width: | Height: | Size: 28 KiB | 
| Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 11 KiB | 
| Before Width: | Height: | Size: 4.8 KiB After Width: | Height: | Size: 4.8 KiB | 
| Before Width: | Height: | Size: 25 KiB After Width: | Height: | Size: 25 KiB | 
| Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 12 KiB | 
| Before Width: | Height: | Size: 17 KiB After Width: | Height: | Size: 17 KiB | 
| Before Width: | Height: | Size: 45 KiB After Width: | Height: | Size: 45 KiB | 
| Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 10 KiB | 
| Before Width: | Height: | Size: 61 KiB After Width: | Height: | Size: 61 KiB |