2023-10-24 22:09:18 -05:00
{{ $showFileTree := ( and ( not .DiffNotAvailable ) ( gt .Diff.NumFiles 1 )) }}
2023-07-06 10:33:04 -05:00
< div >
2023-09-28 05:00:26 -05:00
< div class = "diff-detail-box diff-box" >
2024-03-24 09:31:35 -05:00
< div class = "tw-flex tw-items-center tw-flex-wrap tw-gap-2 gt-ml-1" >
2023-10-24 22:09:18 -05:00
{{ if $showFileTree }}
2023-11-17 13:35:51 -05:00
< button class = "diff-toggle-file-tree-button not-mobile btn interact-fg" data-show-text = " {{ ctx .Locale.Tr "repo.diff.show_file_tree" }} " data-hide-text = " {{ ctx .Locale.Tr "repo.diff.hide_file_tree" }} " >
2022-10-14 04:43:25 -05:00
{{/* the icon meaning is reversed here, "octicon-sidebar-collapse" means show the file tree */}}
2023-03-30 07:06:10 -05:00
{{ svg "octicon-sidebar-collapse" 20 "icon gt-hidden" }}
{{ svg "octicon-sidebar-expand" 20 "icon gt-hidden" }}
< / button >
< script >
2023-06-02 10:39:01 -05:00
// Default to true if unset
const diffTreeVisible = localStorage?.getItem('diff_file_tree_visible') !== 'false';
2023-03-30 07:06:10 -05:00
const diffTreeBtn = document.querySelector('.diff-toggle-file-tree-button');
const diffTreeIcon = `.octicon-sidebar-${diffTreeVisible ? 'expand' : 'collapse'}`;
diffTreeBtn.querySelector(diffTreeIcon).classList.remove('gt-hidden');
diffTreeBtn.setAttribute('data-tooltip-content', diffTreeBtn.getAttribute(diffTreeVisible ? 'data-hide-text' : 'data-show-text'));
< / script >
2023-10-24 22:09:18 -05:00
{{ end }}
{{ if not .DiffNotAvailable }}
2024-03-22 14:51:29 -05:00
< div class = "diff-detail-stats tw-flex tw-items-center tw-flex-wrap" >
2024-03-10 03:51:19 -05:00
{{ svg "octicon-diff" 16 "gt-mr-2" }}{{ ctx .Locale.Tr "repo.diff.stats_desc" .Diff.NumFiles .Diff.TotalAddition .Diff.TotalDeletion }}
2022-10-14 04:43:25 -05:00
< / div >
2023-07-06 10:33:04 -05:00
{{ end }}
2015-12-07 17:30:52 -05:00
< / div >
2023-08-24 10:46:30 -05:00
< div class = "diff-detail-actions" >
2023-07-06 10:33:04 -05:00
{{ if and .PageIsPullFiles $.SignedUserID ( not .IsArchived ) ( not .DiffNotAvailable ) }}
2024-03-22 14:51:29 -05:00
< div class = "not-mobile tw-flex tw-items-center tw-flex-col tw-whitespace-nowrap gt-mr-2" >
2023-09-25 03:56:50 -05:00
< label for = "viewed-files-summary" id = "viewed-files-summary-label" data-text-changed-template = " {{ ctx .Locale.Tr "repo.pulls.viewed_files_label" }} " >
{{ ctx .Locale.Tr "repo.pulls.viewed_files_label" .Diff.NumViewedFiles .Diff.NumFiles }}
2023-07-06 10:33:04 -05:00
< / label >
< progress id = "viewed-files-summary" value = " {{ .Diff.NumViewedFiles }} " max = " {{ .Diff.NumFiles }} " ></ progress >
< / div >
{{ end }}
{{ template "repo/diff/whitespace_dropdown" . }}
{{ template "repo/diff/options_dropdown" . }}
2023-07-28 14:18:12 -05:00
{{ if .PageIsPullFiles }}
2023-09-25 03:56:50 -05:00
< div id = "diff-commit-select" data-issuelink = " {{ $.Issue.Link }} " data-queryparams = "?style= {{ if $.IsSplitStyle }} split {{ else }} unified {{ end }} &whitespace= {{ $.WhitespaceBehavior }} &show-outdated= {{ $.ShowOutdatedComments }} " data-filter_changes_by_commit = " {{ ctx .Locale.Tr "repo.pulls.filter_changes_by_commit" }} " >
2023-07-28 14:18:12 -05:00
{{ /*
the following will be replaced by vue component
but this avoids any loading artifacts till the vue component is initialized
*/}}
< div class = "ui jump dropdown basic button custom" >
{{ svg "octicon-git-commit" }}
< / div >
< / div >
{{ end }}
2023-07-06 10:33:04 -05:00
{{ if and .PageIsPullFiles $.SignedUserID ( not .IsArchived ) }}
{{ template "repo/diff/new_review" . }}
{{ end }}
< / div >
< / div >
{{ if not .DiffNotAvailable }}
2023-07-28 14:18:12 -05:00
{{ if and .IsShowingOnlySingleCommit .PageIsPullFiles }}
< div class = "ui info message" >
2023-11-05 18:39:32 -05:00
< div > {{ ctx .Locale.Tr "repo.pulls.showing_only_single_commit" ( ShortSha .AfterCommitID ) }} - < a href = " {{ $.Issue.Link }} /files?style= {{ if $.IsSplitStyle }} split {{ else }} unified {{ end }} &whitespace= {{ $.WhitespaceBehavior }} &show-outdated= {{ $.ShowOutdatedComments }} " > {{ ctx .Locale.Tr "repo.pulls.show_all_commits" }} </ a ></ div >
2023-07-28 14:18:12 -05:00
< / div >
{{ else if and ( not .IsShowingAllCommits ) .PageIsPullFiles }}
< div class = "ui info message" >
2023-09-25 07:42:40 -05:00
< div > {{ ctx .Locale.Tr "repo.pulls.showing_specified_commit_range" ( ShortSha .BeforeCommitID ) ( ShortSha .AfterCommitID ) }} - < a href = " {{ $.Issue.Link }} /files?style= {{ if $.IsSplitStyle }} split {{ else }} unified {{ end }} &whitespace= {{ $.WhitespaceBehavior }} &show-outdated= {{ $.ShowOutdatedComments }} " > {{ ctx .Locale.Tr "repo.pulls.show_all_commits" }} </ a ></ div >
2023-07-28 14:18:12 -05:00
< / div >
{{ end }}
2023-05-30 05:53:15 -05:00
< script id = "diff-data-script" type = "module" >
2023-06-24 19:46:30 -05:00
const diffDataFiles = [{{ range $i , $file := .Diff.Files }} {Name:"{{ $file .Name }} ",NameHash:"{{ $file .NameHash }} ",Type:{{ $file .Type }} ,IsBin:{{ $file .IsBin }} ,Addition:{{ $file .Addition }} ,Deletion:{{ $file .Deletion }} ,IsViewed:{{ $file .IsViewed }} },{{ end }} ];
2023-05-30 05:53:15 -05:00
const diffData = {
isIncomplete: {{ .Diff.IsIncomplete }} ,
2023-09-25 03:56:50 -05:00
tooManyFilesMessage: "{{ ctx .Locale.Tr "repo.diff.too_many_files" }} ",
binaryFileMessage: "{{ ctx .Locale.Tr "repo.diff.bin" }} ",
showMoreMessage: "{{ ctx .Locale.Tr "repo.diff.show_more" }} ",
statisticsMessage: "{{ ctx .Locale.Tr "repo.diff.stats_desc_file" }} ",
2024-03-20 00:56:42 -05:00
linkLoadMore: "?skip-to={{ .Diff.End }} & file-only=true",
2023-05-30 05:53:15 -05:00
};
// for first time loading, the diffFileInfo is a plain object
// after the Vue component is mounted, the diffFileInfo is a reactive object
// keep in mind that this script block would be executed many times when loading more files, by "loadMoreFiles"
let diffFileInfo = window.config.pageData.diffFileInfo || {
files:[],
fileTreeIsVisible: false,
fileListIsVisible: false,
isLoadingNewData: false,
selectedItem: '',
};
diffFileInfo = Object.assign(diffFileInfo, diffData);
diffFileInfo.files.push(...diffDataFiles);
window.config.pageData.diffFileInfo = diffFileInfo;
< / script >
2022-10-01 09:26:38 -05:00
< div id = "diff-file-list" > < / div >
2023-07-06 10:33:04 -05:00
{{ end }}
< div id = "diff-container" >
2023-10-24 22:09:18 -05:00
{{ if $showFileTree }}
2023-11-17 13:35:51 -05:00
< div id = "diff-file-tree" class = "gt-hidden not-mobile" > < / div >
2023-07-06 10:33:04 -05:00
< script >
if (diffTreeVisible) document.getElementById('diff-file-tree').classList.remove('gt-hidden');
< / script >
2023-10-24 22:09:18 -05:00
{{ end }}
{{ if .DiffNotAvailable }}
< h4 > {{ ctx .Locale.Tr "repo.diff.data_not_available" }} </ h4 >
{{ else }}
2023-07-06 10:33:04 -05:00
< div id = "diff-file-boxes" class = "sixteen wide column" >
{{ range $i , $file := .Diff.Files }}
{{/*notice: the index of Diff.Files should not be used for element ID, because the index will be restarted from 0 when doing load-more for PRs with a lot of files*/}}
{{ $blobBase := call $.GetBlobByPathForCommit $.BeforeCommit $file .OldName }}
{{ $blobHead := call $.GetBlobByPathForCommit $.HeadCommit $file .Name }}
2023-10-11 07:34:21 -05:00
{{ $sniffedTypeBase := call $.GetSniffedTypeForBlob $blobBase }}
{{ $sniffedTypeHead := call $.GetSniffedTypeForBlob $blobHead }}
{{ $isImage := or ( call $.IsSniffedTypeAnImage $sniffedTypeBase ) ( call $.IsSniffedTypeAnImage $sniffedTypeHead ) }}
2023-07-06 10:33:04 -05:00
{{ $isCsv := ( call $.IsCsvFile $file ) }}
{{ $showFileViewToggle := or $isImage ( and ( not $file .IsIncomplete ) $isCsv ) }}
{{ $isExpandable := or ( gt $file .Addition 0 ) ( gt $file .Deletion 0 ) $file .IsBin }}
2023-07-28 14:18:12 -05:00
{{ $isReviewFile := and $.IsSigned $.PageIsPullFiles ( not $.IsArchived ) $.IsShowingAllCommits }}
2023-07-28 12:12:44 -05:00
< div class = "diff-file-box diff-box file-content {{ TabSizeClass $.Editorconfig $file .Name }} gt-mt-0" id = "diff- {{ $file .NameHash }} " data-old-filename = " {{ $file .OldName }} " data-new-filename = " {{ $file .Name }} " {{ if or ( $file .ShouldBeHidden ) ( not $isExpandable ) }} data-folded = "true" {{ end }} >
2024-03-24 08:32:19 -05:00
< h4 class = "diff-file-header sticky-2nd-row ui top attached header tw-font-normal tw-flex tw-items-center tw-justify-between tw-flex-wrap" >
< div class = "diff-file-name tw-flex tw-items-center gt-gap-2 tw-flex-wrap" >
2024-03-05 00:29:32 -05:00
< button class = "fold-file btn interact-bg gt-p-2 {{ if not $isExpandable }} tw-invisible {{ end }} " >
2023-07-06 10:33:04 -05:00
{{ if $file .ShouldBeHidden }}
{{ svg "octicon-chevron-right" 18 }}
{{ else }}
{{ svg "octicon-chevron-down" 18 }}
2022-09-27 00:22:19 -05:00
{{ end }}
2023-07-06 10:33:04 -05:00
< / button >
2024-03-23 13:45:11 -05:00
< div class = "tw-font-semibold tw-flex tw-items-center gt-mono" >
2023-07-06 10:33:04 -05:00
{{ if $file .IsBin }}
< span class = "gt-ml-1 gt-mr-3" >
2023-09-25 03:56:50 -05:00
{{ ctx .Locale.Tr "repo.diff.bin" }}
2023-07-06 10:33:04 -05:00
< / span >
2021-06-05 07:32:19 -05:00
{{ else }}
2023-07-06 10:33:04 -05:00
{{ template "repo/diff/stats" dict "file" . "root" $ }}
2021-06-05 07:32:19 -05:00
{{ end }}
2022-09-27 00:22:19 -05:00
< / div >
2023-09-25 03:56:50 -05:00
< span class = "file gt-mono" >< a class = "muted file-link" title = " {{ if $file .IsRenamed }}{{ $file .OldName }} → {{ end }}{{ $file .Name }} " href = "#diff- {{ $file .NameHash }} " > {{ if $file .IsRenamed }}{{ $file .OldName }} → {{ end }}{{ $file .Name }} </ a > {{ if .IsLFSFile }} ({{ ctx .Locale.Tr "repo.stored_lfs" }} ){{ end }} </ span >
2023-07-06 10:33:04 -05:00
< button class = "btn interact-fg gt-p-3" data-clipboard-text = " {{ $file .Name }} " > {{ svg "octicon-copy" 14 }} </ button >
{{ if $file .IsGenerated }}
2023-09-25 03:56:50 -05:00
< span class = "ui label" > {{ ctx .Locale.Tr "repo.diff.generated" }} </ span >
2023-07-06 10:33:04 -05:00
{{ end }}
{{ if $file .IsVendored }}
2023-09-25 03:56:50 -05:00
< span class = "ui label" > {{ ctx .Locale.Tr "repo.diff.vendored" }} </ span >
2023-07-06 10:33:04 -05:00
{{ end }}
{{ if and $file .Mode $file .OldMode }}
2023-09-25 03:56:50 -05:00
{{ $old := ctx .Locale.Tr ( $file .ModeTranslationKey $file .OldMode ) }}
{{ $new := ctx .Locale.Tr ( $file .ModeTranslationKey $file .Mode ) }}
< span class = "gt-ml-4 gt-mono" > {{ ctx .Locale.Tr "git.filemode.changed_filemode" $old $new }} </ span >
2023-07-06 10:33:04 -05:00
{{ else if $file .Mode }}
2023-09-25 03:56:50 -05:00
< span class = "gt-ml-4 gt-mono" > {{ ctx .Locale.Tr ( $file .ModeTranslationKey $file .Mode ) }} </ span >
2023-07-06 10:33:04 -05:00
{{ end }}
< / div >
2024-03-24 09:31:35 -05:00
< div class = "diff-file-header-actions tw-flex tw-items-center tw-gap-1 tw-flex-wrap" >
2022-09-27 00:22:19 -05:00
{{ if $showFileViewToggle }}
2023-07-06 10:33:04 -05:00
< div class = "ui compact icon buttons" >
2023-09-25 03:56:50 -05:00
< button class = "ui tiny basic button file-view-toggle" data-toggle-selector = "#diff-source- {{ $file .NameHash }} " data-tooltip-content = " {{ ctx .Locale.Tr "repo.file_view_source" }} " > {{ svg "octicon-code" }} </ button >
< button class = "ui tiny basic button file-view-toggle active" data-toggle-selector = "#diff-rendered- {{ $file .NameHash }} " data-tooltip-content = " {{ ctx .Locale.Tr "repo.file_view_rendered" }} " > {{ svg "octicon-file" }} </ button >
2023-07-06 10:33:04 -05:00
< / div >
{{ end }}
{{ if $file .IsProtected }}
2023-09-25 03:56:50 -05:00
< span class = "ui basic label" > {{ ctx .Locale.Tr "repo.diff.protected" }} </ span >
2023-07-06 10:33:04 -05:00
{{ end }}
{{ if and $isReviewFile $file .HasChangedSinceLastReview }}
2023-09-25 03:56:50 -05:00
< span class = "changed-since-last-review unselectable not-mobile" > {{ ctx .Locale.Tr "repo.pulls.has_changed_since_last_review" }} </ span >
2023-07-06 10:33:04 -05:00
{{ end }}
{{ if not ( or $file .IsIncomplete $file .IsBin $file .IsSubmodule ) }}
2023-09-25 03:56:50 -05:00
< button class = "ui basic tiny button unescape-button not-mobile" > {{ ctx .Locale.Tr "repo.unescape_control_characters" }} </ button >
< button class = "ui basic tiny button escape-button gt-hidden" > {{ ctx .Locale.Tr "repo.escape_control_characters" }} </ button >
2023-07-06 10:33:04 -05:00
{{ end }}
{{ if and ( not $file .IsSubmodule ) ( not $.PageIsWiki ) }}
{{ if $file .IsDeleted }}
2023-09-25 03:56:50 -05:00
< a class = "ui basic tiny button" rel = "nofollow" href = " {{ $.BeforeSourcePath }} / {{ PathEscapeSegments .Name }} " > {{ ctx .Locale.Tr "repo.diff.view_file" }} </ a >
2023-07-06 10:33:04 -05:00
{{ else }}
2023-09-25 03:56:50 -05:00
< a class = "ui basic tiny button" rel = "nofollow" href = " {{ $.SourcePath }} / {{ PathEscapeSegments .Name }} " > {{ ctx .Locale.Tr "repo.diff.view_file" }} </ a >
2023-12-19 16:18:07 -05:00
{{ if and $.HeadBranchIsEditable ( not $file .IsLFSFile ) }}
< a class = "ui basic tiny button" rel = "nofollow" href = " {{ $.SourceRepoLink }} /_edit/ {{ PathEscapeSegments $.HeadBranch }} / {{ PathEscapeSegments .Name }} " > {{ ctx .Locale.Tr "repo.editor.edit_this_file" }} </ a >
{{ end }}
2023-07-06 10:33:04 -05:00
{{ end }}
{{ end }}
{{ if $isReviewFile }}
< label data-link = " {{ $.Issue.Link }} /viewed-files" data-headcommit = " {{ $.AfterCommitID }} " class = "viewed-file-form unselectable {{ if $file .IsViewed }} viewed-file-checked-form {{ end }} " >
2023-09-25 03:56:50 -05:00
< input type = "checkbox" name = " {{ $file .GetDiffFileName }} " autocomplete = "off" {{ if $file .IsViewed }} checked {{ end }} > {{ ctx .Locale.Tr "repo.pulls.has_viewed_file" }}
2023-07-06 10:33:04 -05:00
< / label >
{{ end }}
< / div >
< / h4 >
2023-07-28 14:18:12 -05:00
< div class = "diff-file-body ui attached unstackable table segment" {{ if and $file .IsViewed $.IsShowingAllCommits }} data-folded = "true" {{ end }} >
2023-07-06 10:33:04 -05:00
< div id = "diff-source- {{ $file .NameHash }} " class = "file-body file-code unicode-escaped code-diff {{ if $.IsSplitStyle }} code-diff-split {{ else }} code-diff-unified {{ end }}{{ if $showFileViewToggle }} gt-hidden {{ end }} " >
{{ if or $file .IsIncomplete $file .IsBin }}
2024-03-23 15:11:15 -05:00
< div class = "diff-file-body binary" >
2023-07-06 10:33:04 -05:00
{{ if $file .IsIncomplete }}
{{ if $file .IsIncompleteLineTooLong }}
2023-09-25 03:56:50 -05:00
{{ ctx .Locale.Tr "repo.diff.file_suppressed_line_too_long" }}
2022-09-27 00:22:19 -05:00
{{ else }}
2023-09-25 03:56:50 -05:00
{{ ctx .Locale.Tr "repo.diff.file_suppressed" }}
2024-03-20 00:56:42 -05:00
< a class = "ui basic tiny button diff-load-button" data-href = "?file-only=true&files= {{ $file .Name }} &files= {{ $file .OldName }} " > {{ ctx .Locale.Tr "repo.diff.load" }} </ a >
2022-09-27 00:22:19 -05:00
{{ end }}
2023-07-06 10:33:04 -05:00
{{ else }}
2023-09-25 03:56:50 -05:00
{{ ctx .Locale.Tr "repo.diff.bin_not_shown" }}
2023-07-06 10:33:04 -05:00
{{ end }}
2022-09-27 00:22:19 -05:00
< / div >
2023-07-06 10:33:04 -05:00
{{ else }}
< table class = "chroma" data-new-comment-url = " {{ $.Issue.Link }} /files/reviews/new_comment" data-path = " {{ $file .Name }} " >
{{ if $.IsSplitStyle }}
{{ template "repo/diff/section_split" dict "file" . "root" $ }}
{{ else }}
{{ template "repo/diff/section_unified" dict "file" . "root" $ }}
{{ end }}
< / table >
2022-09-27 00:22:19 -05:00
{{ end }}
2020-10-31 17:15:11 -05:00
< / div >
2023-07-06 10:33:04 -05:00
{{ if $showFileViewToggle }}
{{/* for image or CSV, it can have a horizontal scroll bar, there won't be review comment context menu (position absolute) which would be clipped by "overflow" */}}
2024-03-03 22:33:20 -05:00
< div id = "diff-rendered- {{ $file .NameHash }} " class = "file-body file-code {{ if $.IsSplitStyle }} code-diff-split {{ else }} code-diff-unified {{ end }} tw-overflow-x-scroll" >
2024-02-27 09:31:41 -05:00
< table class = "chroma tw-w-full" >
2023-07-06 10:33:04 -05:00
{{ if $isImage }}
2023-10-11 07:34:21 -05:00
{{ template "repo/diff/image_diff" dict "file" . "root" $ "blobBase" $blobBase "blobHead" $blobHead "sniffedTypeBase" $sniffedTypeBase "sniffedTypeHead" $sniffedTypeHead }}
2023-07-06 10:33:04 -05:00
{{ else }}
2023-10-11 07:34:21 -05:00
{{ template "repo/diff/csv_diff" dict "file" . "root" $ "blobBase" $blobBase "blobHead" $blobHead "sniffedTypeBase" $sniffedTypeBase "sniffedTypeHead" $sniffedTypeHead }}
2023-07-06 10:33:04 -05:00
{{ end }}
< / table >
< / div >
{{ end }}
2022-09-27 00:22:19 -05:00
< / div >
2023-07-06 10:33:04 -05:00
< / div >
{{ end }}
2016-06-29 10:11:00 -05:00
2023-07-06 10:33:04 -05:00
{{ if .Diff.IsIncomplete }}
< div class = "diff-file-box diff-box file-content gt-mt-3" id = "diff-incomplete" >
2024-03-24 08:32:19 -05:00
< h4 class = "ui top attached header tw-font-normal tw-flex tw-items-center tw-justify-between" >
2023-09-25 03:56:50 -05:00
{{ ctx .Locale.Tr "repo.diff.too_many_files" }}
2024-03-20 00:56:42 -05:00
< a class = "ui basic tiny button" id = "diff-show-more-files" data-href = "?skip-to= {{ .Diff.End }} &file-only=true" > {{ ctx .Locale.Tr "repo.diff.show_more" }} </ a >
2023-07-06 10:33:04 -05:00
< / h4 >
2019-10-21 02:51:24 -05:00
< / div >
2023-07-06 10:33:04 -05:00
{{ end }}
< / div >
2021-01-08 16:49:55 -05:00
{{ end }}
2023-07-06 10:33:04 -05:00
< / div >
2018-08-05 23:43:22 -05:00
2023-07-06 10:33:04 -05:00
{{ if and ( not $.Repository.IsArchived ) ( not .DiffNotAvailable ) }}
< template id = "issue-comment-editor-template" >
< div class = "ui comment form" >
{{ template "shared/combomarkdowneditor" ( dict
"MarkdownPreviewUrl" (print $.Repository.Link "/markup")
"MarkdownPreviewContext" $.RepoLink
"TextareaName" "content"
"DropzoneParentContainer" ".ui.form"
)}}
2024-02-25 01:00:55 -05:00
{{ if .IsAttachmentEnabled }}
< div class = "field" >
{{ template "repo/upload" . }}
< / div >
{{ end }}
2023-07-06 10:33:04 -05:00
< div class = "text right edit buttons" >
2023-11-03 09:40:48 -05:00
< button class = "ui cancel button" > {{ ctx .Locale.Tr "repo.issues.cancel" }} </ button >
< button class = "ui primary save button" > {{ ctx .Locale.Tr "repo.issues.save" }} </ button >
2023-07-06 10:33:04 -05:00
< / div >
< / div >
< / template >
{{ end }}
{{ if ( not .DiffNotAvailable ) }}
2021-01-21 08:51:17 -05:00
{{ template "repo/issue/view_content/reference_issue_dialog" . }}
2023-07-06 10:33:04 -05:00
{{ end }}
< / div >