diff.tmpl 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. {{template "base/head" .}}
  2. <div class="repository diff">
  3. {{template "repo/header" .}}
  4. <div class="ui container">
  5. {{if .IsDiffCompare }}
  6. {{template "repo/commits_table" .}}
  7. {{else}}
  8. <h4 class="ui top attached info header">
  9. {{RenderCommitMessage .Commit.Message $.RepoLink}}
  10. <div class="ui right">
  11. <a class="ui blue tiny button" href="{{EscapePound .SourcePath}}">
  12. {{.i18n.Tr "repo.diff.browse_source"}}
  13. </a>
  14. </div>
  15. </h4>
  16. <div class="ui attached info segment">
  17. {{if .Author}}
  18. <img class="ui avatar image" src="{{.Author.AvatarLink}}" />
  19. <a href="{{.Author.HomeLink}}"><strong>{{.Commit.Author.Name}}</strong></a>
  20. {{else}}
  21. <img class="ui avatar image" src="{{AvatarLink .Commit.Author.Email}}" />
  22. <strong>{{.Commit.Author.Name}}</strong>
  23. {{end}}
  24. <span class="text grey" id="authored-time">{{TimeSince .Commit.Author.When $.Lang}}</span>
  25. <div class="ui right">
  26. <div class="ui horizontal list">
  27. {{if .Parents}}
  28. <div class="item">
  29. {{.i18n.Tr "repo.diff.parent"}}
  30. </div>
  31. <div class="item">
  32. {{range .Parents}}
  33. <a class="ui blue sha label" href="{{$.RepoLink}}/commit/{{.}}">{{ShortSha .}}</a>
  34. {{end}}
  35. </div>
  36. {{end}}
  37. <div class="item">{{.i18n.Tr "repo.diff.commit"}}</div>
  38. <div class="item"><span class="ui blue sha label">{{ShortSha .CommitID}}</span></div>
  39. </div>
  40. </div>
  41. </div>
  42. {{end}}
  43. {{if .DiffNotAvailable}}
  44. <h4>{{.i18n.Tr "repo.diff.data_not_available"}}</h4>
  45. {{else}}
  46. <div class="diff-detail-box diff-box">
  47. <div>
  48. <i class="fa fa-retweet"></i>
  49. {{.i18n.Tr "repo.diff.stats_desc" .Diff.NumFiles .Diff.TotalAddition .Diff.TotalDeletion | Str2html}}
  50. <div class="ui right">
  51. <a class="ui tiny basic black toggle button" data-target="#diff-files">{{.i18n.Tr "repo.diff.show_diff_stats"}}</a>
  52. </div>
  53. </div>
  54. <ol class="detail-files hide" id="diff-files">
  55. {{range .Diff.Files}}
  56. <li>
  57. <div class="diff-counter count pull-right">
  58. {{if not .IsBin}}
  59. <span class="add" data-line="{{.Addition}}">{{.Addition}}</span>
  60. <span class="bar">
  61. <span class="pull-left add"></span>
  62. <span class="pull-left del"></span>
  63. </span>
  64. <span class="del" data-line="{{.Deletion}}">{{.Deletion}}</span>
  65. {{else}}
  66. <span>{{$.i18n.Tr "repo.diff.bin"}}</span>
  67. {{end}}
  68. </div>
  69. <!-- todo finish all file status, now modify, add, delete and rename -->
  70. <span class="status {{DiffTypeToStr .Type}} poping up" data-content="{{DiffTypeToStr .Type}}" data-variation="inverted tiny" data-position="right center">&nbsp;</span>
  71. <a class="file" href="#diff-{{.Index}}">{{.Name}}</a>
  72. </li>
  73. {{end}}
  74. </ol>
  75. </div>
  76. {{range $i, $file := .Diff.Files}}
  77. <div class="diff-file-box diff-box file-content" id="diff-{{.Index}}">
  78. <h4 class="ui top attached normal header">
  79. <div class="diff-counter count ui left">
  80. {{if not $file.IsBin}}
  81. <span class="add" data-line="{{.Addition}}">+ {{.Addition}}</span>
  82. <span class="bar">
  83. <span class="pull-left add"></span>
  84. <span class="pull-left del"></span>
  85. </span>
  86. <span class="del" data-line="{{.Deletion}}">- {{.Deletion}}</span>
  87. {{else}}
  88. {{$.i18n.Tr "repo.diff.bin"}}
  89. {{end}}
  90. </div>
  91. <span class="file">{{$file.Name}}</span>
  92. <div class="ui right">
  93. {{if $file.IsDeleted}}
  94. <a class="ui basic tiny button" rel="nofollow" href="{{EscapePound $.BeforeSourcePath}}/{{EscapePound .Name}}">{{$.i18n.Tr "repo.diff.view_file"}}</a>
  95. {{else}}
  96. <a class="ui basic tiny button" rel="nofollow" href="{{EscapePound $.SourcePath}}/{{EscapePound .Name}}">{{$.i18n.Tr "repo.diff.view_file"}}</a>
  97. {{end}}
  98. </div>
  99. </h4>
  100. <div class="ui attached table segment">
  101. {{$isImage := (call $.IsImageFile $file.Name)}}
  102. {{if $isImage}}
  103. <div class="center">
  104. <img src="{{$.RawPath}}/{{EscapePound .Name}}">
  105. </div>
  106. {{else}}
  107. <div class="file-body file-code code-view code-diff">
  108. <table>
  109. <tbody>
  110. {{range .Sections}}
  111. {{range $k, $line := .Lines}}
  112. <tr class="{{DiffLineTypeToStr .Type}}-code nl-{{$k}} ol-{{$k}}">
  113. <td class="lines-num lines-num-old">
  114. <span rel="{{if $line.LeftIdx}}diff-{{Sha1 $file.Name}}L{{$line.LeftIdx}}{{end}}">{{if $line.LeftIdx}}{{$line.LeftIdx}}{{end}}</span>
  115. </td>
  116. <td class="lines-num lines-num-new">
  117. <span rel="{{if $line.RightIdx}}diff-{{Sha1 $file.Name}}R{{$line.RightIdx}}{{end}}">{{if $line.RightIdx}}{{$line.RightIdx}}{{end}}</span>
  118. </td>
  119. <td class="lines-code">
  120. <pre>{{$line.Content}}</pre>
  121. </td>
  122. </tr>
  123. {{end}}
  124. {{end}}
  125. </tbody>
  126. </table>
  127. </div>
  128. {{end}}
  129. </div>
  130. </div>
  131. <br>
  132. {{end}}
  133. {{end}}
  134. </div>
  135. </div>
  136. {{template "base/footer" .}}