mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-24 08:57:03 -05:00
7ec7c733c7
Backport #27267 by @silverwind 1. Dropzone attachment removal, pretty simple replacement 2. Image diff: The previous code fetched every image twice, once via `img[src]` and once via `$.ajax`. Now it's only fetched once and a second time only when necessary. The image diff code was partially rewritten. Co-authored-by: silverwind <me@silverwind.io>
83 lines
3.4 KiB
Handlebars
83 lines
3.4 KiB
Handlebars
{{if or .blobBase .blobHead}}
|
|
<tr>
|
|
<td colspan="2">
|
|
<div class="image-diff"
|
|
data-path-before="{{.root.BeforeRawPath}}/{{PathEscapeSegments .file.OldName}}"
|
|
data-path-after="{{.root.RawPath}}/{{PathEscapeSegments .file.Name}}"
|
|
data-mime-before="{{.sniffedTypeBase.GetMimeType}}"
|
|
data-mime-after="{{.sniffedTypeHead.GetMimeType}}"
|
|
>
|
|
<div class="ui secondary pointing tabular top attached borderless menu new-menu">
|
|
<div class="new-menu-inner">
|
|
<a class="item active" data-tab="diff-side-by-side-{{.file.Index}}">{{ctx.Locale.Tr "repo.diff.image.side_by_side"}}</a>
|
|
{{if and .blobBase .blobHead}}
|
|
<a class="item" data-tab="diff-swipe-{{.file.Index}}">{{ctx.Locale.Tr "repo.diff.image.swipe"}}</a>
|
|
<a class="item" data-tab="diff-overlay-{{.file.Index}}">{{ctx.Locale.Tr "repo.diff.image.overlay"}}</a>
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
<div class="image-diff-tabs is-loading">
|
|
<div class="ui bottom attached tab image-diff-container active" data-tab="diff-side-by-side-{{.file.Index}}">
|
|
<div class="diff-side-by-side">
|
|
{{if .blobBase}}
|
|
<span class="side">
|
|
<p class="side-header">{{ctx.Locale.Tr "repo.diff.file_before"}}</p>
|
|
<span class="before-container"><img class="image-before"></span>
|
|
<p>
|
|
<span class="bounds-info-before">
|
|
{{ctx.Locale.Tr "repo.diff.file_image_width"}}: <span class="text bounds-info-width"></span>
|
|
|
|
|
{{ctx.Locale.Tr "repo.diff.file_image_height"}}: <span class="text bounds-info-height"></span>
|
|
|
|
|
</span>
|
|
{{ctx.Locale.Tr "repo.diff.file_byte_size"}}: <span class="text">{{FileSize .blobBase.Size}}</span>
|
|
</p>
|
|
</span>
|
|
{{end}}
|
|
{{if .blobHead}}
|
|
<span class="side">
|
|
<p class="side-header">{{ctx.Locale.Tr "repo.diff.file_after"}}</p>
|
|
<span class="after-container"><img class="image-after"></span>
|
|
<p>
|
|
<span class="bounds-info-after">
|
|
{{ctx.Locale.Tr "repo.diff.file_image_width"}}: <span class="text bounds-info-width"></span>
|
|
|
|
|
{{ctx.Locale.Tr "repo.diff.file_image_height"}}: <span class="text bounds-info-height"></span>
|
|
|
|
|
</span>
|
|
{{ctx.Locale.Tr "repo.diff.file_byte_size"}}: <span class="text">{{FileSize .blobHead.Size}}</span>
|
|
</p>
|
|
</span>
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
{{if and .blobBase .blobHead}}
|
|
<div class="ui bottom attached tab image-diff-container" data-tab="diff-swipe-{{.file.Index}}">
|
|
<div class="diff-swipe">
|
|
<div class="swipe-frame">
|
|
<span class="before-container"><img class="image-before"></span>
|
|
<span class="swipe-container">
|
|
<span class="after-container"><img class="image-after"></span>
|
|
</span>
|
|
<span class="swipe-bar">
|
|
<span class="handle top-handle"></span>
|
|
<span class="handle bottom-handle"></span>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="ui bottom attached tab image-diff-container" data-tab="diff-overlay-{{.file.Index}}">
|
|
<div class="diff-overlay">
|
|
<input type="range" min="0" max="100" value="50">
|
|
<div class="overlay-frame">
|
|
<span class="before-container"><img class="image-before"></span>
|
|
<span class="after-container"><img class="image-after"></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
{{end}}
|