You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

cloudbrains.tmpl 35 kB

3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. {{template "base/head" .}}
  2. <!-- 提示框 -->
  3. <script src="{{StaticUrlPrefix}}/js/specsuse.js?v={{MD5 AppVer}}" type="text/javascript"></script>
  4. <div class="alert"></div>
  5. <div class="explore users">
  6. <div class="cloudbrain_debug" style="display: none;" data-debug="{{$.i18n.Tr "repo.debug"}}"
  7. data-debug-again="{{$.i18n.Tr "repo.debug_again"}}" data-debug-task="{{$.i18n.Tr "cloudbrain.DEBUG"}}"
  8. data-train-task="{{$.i18n.Tr "cloudbrain.TRAIN"}}" data-inference-task="{{$.i18n.Tr "cloudbrain.INFERENCE"}}"
  9. data-benchmark-task="{{$.i18n.Tr "cloudbrain.BENCHMARK"}}"
  10. data-all-cluster="{{.i18n.Tr "cloudbrain.all_resource_cluster"}}"
  11. data-all-aiCenter="{{.i18n.Tr "cloudbrain.all_ai_center"}}"
  12. data-cluster-c2net="{{.i18n.Tr "cloudbrain.resource_cluster_c2net"}}"
  13. data-cluster-openi="{{.i18n.Tr "cloudbrain.resource_cluster_openi"}}"
  14. data-all-task="{{.i18n.Tr "admin.cloudbrain.all_task_types"}}"
  15. data-all-compute="{{.i18n.Tr "admin.cloudbrain.all_computing_resources"}}"
  16. data-all-status="{{.i18n.Tr "admin.cloudbrain.all_status"}}"></div>
  17. {{template "admin/cloudbrain/search_dashboard" .}}
  18. <div class="ui container" style="width:90%;overflow-x:auto;overflow-y:hidden">
  19. {{template "base/alert" .}}
  20. <div class="ui grid" style="min-width:1700px;">
  21. <div class="row">
  22. <div class="ui sixteen wide column" style="margin-bottom:15px;">
  23. <!-- 任务展示 -->
  24. <div class="dataset list">
  25. <!-- 表头 -->
  26. <div class="ui grid stackable" style="background: #f0f0f0;;">
  27. <div class="row">
  28. <div class="three wide column nowrap" style="width:12%!important">
  29. <span>{{$.i18n.Tr "repo.cloudbrain_task"}}</span>
  30. </div>
  31. <!-- 集群 -->
  32. <div class="one wide column text center nowrap" style="width:8% !important;">
  33. <span>{{$.i18n.Tr "repo.modelarts.cluster"}}</span>
  34. </div>
  35. <div class="two wide column text center nowrap" style="width: 8% !important;">
  36. <span>{{$.i18n.Tr "repo.modelarts.status"}}</span>
  37. </div>
  38. <div class="one wide column text center nowrap" style="width:8% !important">
  39. <span>{{$.i18n.Tr "repo.cloudbrain_task_type"}}</span>
  40. </div>
  41. <div class="two wide column text center nowrap" style="width: 8% !important;">
  42. <span>{{$.i18n.Tr "repo.modelarts.createtime"}}</span>
  43. </div>
  44. <div class="one wide column text center nowrap" style="width:6% !important;">
  45. <span>{{$.i18n.Tr "repo.cloudbrain_status_runtime"}}</span>
  46. </div>
  47. <div class="one wide column text center nowrap" style="width:6% !important;">
  48. <span>{{$.i18n.Tr "repo.modelarts.computing_resources"}}</span>
  49. </div>
  50. <!-- 智算中心 -->
  51. <div class="one wide column text center nowrap" style="width:8% !important;">
  52. <span>{{$.i18n.Tr "repo.modelarts.ai_center"}}</span>
  53. </div>
  54. <!-- XPU类型 -->
  55. <div class="one wide column text center nowrap" style="width:10% !important;">
  56. <span>{{$.i18n.Tr "repo.modelarts.card_type"}}</span>
  57. </div>
  58. <div class="two wide column text center nowrap" style="width: 11%!important;">
  59. <span>{{$.i18n.Tr "repository"}}</span>
  60. </div>
  61. <div class="three wide column text center nowrap" style="width: 15%!important;">
  62. <span>{{$.i18n.Tr "repo.cloudbrain_operate"}}</span>
  63. </div>
  64. </div>
  65. </div>
  66. {{range .Tasks}}
  67. {{if .Repo}}
  68. <div class="ui grid stackable item">
  69. <div class="row">
  70. <!-- 任务名 -->
  71. {{$JobID := '0'}}
  72. {{if eq .JobType "DEBUG" "SNN4IMAGENET" "BRAINSCORE" "BENCHMARK" "MODELSAFETY"}}
  73. {{$JobID = .Cloudbrain.ID}}
  74. {{else}}
  75. {{$JobID = .JobID}}
  76. {{end}}
  77. <!-- {{$JobID}} -->
  78. <div class="three wide column nowrap" style="width:12% !important">
  79. {{if eq .JobType "DEBUG"}}
  80. <a class="title"
  81. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain/{{$JobID}}{{else}}/modelarts/notebook/{{$JobID}}{{end}}"
  82. title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  83. <span class="fitted"
  84. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  85. </a>
  86. {{else if or (eq .JobType "SNN4IMAGENET") (eq .JobType "BRAINSCORE")}}
  87. <a class="title"
  88. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/cloudbrain/benchmark/{{$JobID}}"
  89. title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  90. <span class="fitted"
  91. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  92. </a>
  93. {{else if eq .JobType "MODELSAFETY"}}
  94. <a class="title"
  95. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/modelsafety/{{$JobID}}/show"
  96. title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  97. <span class="fitted"
  98. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  99. </a>
  100. {{else if eq .JobType "INFERENCE"}}
  101. <a class="title"
  102. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/{{if eq .Cloudbrain.Type 1}}modelarts{{else if eq .Cloudbrain.Type 0}}cloudbrain{{end}}/inference-job/{{$JobID}}"
  103. title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  104. <span class="fitted"
  105. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  106. </a>
  107. {{else if eq .JobType "TRAIN"}}
  108. <a class="title"
  109. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/{{if eq .Cloudbrain.Type 1}}modelarts{{else if eq .Cloudbrain.Type 0}}cloudbrain{{else if eq .Cloudbrain.Type 2}}grampus{{end}}/train-job/{{$JobID}}"
  110. title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  111. <span class="fitted"
  112. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  113. </a>
  114. {{else if eq .JobType "BENCHMARK"}}
  115. <a class="title"
  116. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/cloudbrain/benchmark/{{$JobID}}"
  117. title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  118. <span class="fitted"
  119. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  120. </a>
  121. {{end}}
  122. </div>
  123. <!-- 集群 -->
  124. <div class="one wide column text center nowrap" style="width:8% !important;">
  125. <span style="font-size: 12px;" class="cluster_{{.DisplayJobName}}_{{$JobID}}">{{if .Cluster}}{{.Cluster}}{{else}}--{{end}}</span>
  126. </div>
  127. <!-- 任务状态 -->
  128. <div class="two wide column text center nowrap"
  129. style="width: 8% !important;">
  130. <span class="job-status" id="{{$JobID}}"
  131. data-repopath='{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .JobType "DEBUG"}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain{{else}}/modelarts/notebook{{end}}{{else if eq .JobType "INFERENCE"}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain{{else}}/modelarts{{end}}/inference-job{{else if eq .JobType "TRAIN"}}{{if eq .ComputeResource "NPU"}}/modelarts/train-job{{else}}/cloudbrain/train-job{{end}}{{else if eq .JobType "BENCHMARK"}}/cloudbrain{{end}}'
  132. data-jobid="{{$JobID}}" data-version="{{.VersionName}}">
  133. <span><i id="{{$JobID}}-icon" style="vertical-align: middle;"
  134. class="{{.Status}}"></i><span id="{{$JobID}}-text"
  135. style="margin-left: 0.4em;font-size: 12px;">{{.Status}}</span></span>
  136. </span>
  137. </div>
  138. <!-- 任务类型 -->
  139. {{$JobType := $.i18n.Tr (printf "cloudbrain.%s" .JobType)}}
  140. <div class="one wide column text center nowrap" style="width:8% !important">
  141. <span style="font-size: 12px;" title="{{.JobType}}">{{$JobType}}</span>
  142. </div>
  143. <!-- 任务创建时间 -->
  144. <div class="two wide column text center nowrap" style="width: 8% !important;">
  145. <span style="font-size: 12px;"
  146. class="">{{TimeSinceUnix1 .Cloudbrain.CreatedUnix}}</span>
  147. </div>
  148. <!-- 任务运行时间 -->
  149. <div class="one wide column text center nowrap" style="width:6% !important;">
  150. <span style="font-size: 12px;"
  151. id="duration-{{$JobID}}">{{if .TrainJobDuration}}{{.TrainJobDuration}}{{else}}--{{end}}</span>
  152. </div>
  153. <!-- 计算资源 -->
  154. <div class="one wide column text center nowrap" style="width:6% !important;">
  155. <span
  156. style="font-size: 12px;">{{if .ComputeResource}}{{.ComputeResource}}{{else}}--{{end}}</span>
  157. </div>
  158. <!-- 智算中心 -->
  159. <div class="one wide column text center nowrap" style="width:8% !important;">
  160. <span style="font-size: 12px;" class="aicenter_{{.DisplayJobName}}_{{$JobID}}">{{if .AiCenter}}{{.AiCenter}}{{else}}--{{end}}</span>
  161. </div>
  162. <!-- XPU类型 -->
  163. <div class="one wide column text center nowrap" style="width:10% !important;">
  164. <span style="font-size: 12px;" title="" class="card_type_{{.DisplayJobName}}_{{$JobID}}"></span>
  165. </div>
  166. <script>
  167. (function(){
  168. var spec = {{.Spec}} || {};
  169. var cardType = getListValueWithKey(ACC_CARD_TYPE, spec.AccCardType) || '--';
  170. var spanEl = document.querySelector('.card_type_{{.DisplayJobName}}_{{$JobID}}');
  171. spanEl.setAttribute('title', cardType);
  172. spanEl.innerText = cardType;
  173. var cluster = spec.Cluster || '--';
  174. var clusterName = document.querySelector('.cloudbrain_debug').dataset['cluster' + cluster[0] + cluster.toLocaleLowerCase().slice(1)] || '--';
  175. spanEl = document.querySelector('.cluster_{{.DisplayJobName}}_{{$JobID}}');
  176. spanEl.setAttribute('title', cluster);
  177. spanEl.innerText = clusterName;
  178. var aiCenter = spec.AiCenterName || '--';
  179. spanEl = document.querySelector('.aicenter_{{.DisplayJobName}}_{{$JobID}}');
  180. spanEl.setAttribute('title', aiCenter);
  181. spanEl.innerText = aiCenter;
  182. })();
  183. </script>
  184. <!-- 项目 -->
  185. <div class="two wide column text center nowrap" style="width: 11%!important;">
  186. <a href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}"
  187. title="{{.Repo.OwnerName}}/{{.Repo.Alias}}">{{.Repo.OwnerName}}/{{.Repo.Alias}}</a>
  188. </div>
  189. <div class="three wide column text center nowrap" style="width: 15%!important;">
  190. {{if eq .JobType "DEBUG"}}
  191. <div class="ui compact buttons">
  192. <form id="debugAgainForm-{{$JobID}}">
  193. {{$.CsrfTokenHtml}}
  194. {{if eq .Status "RUNNING" "WAITING" "CREATING" "STARTING"}}
  195. <a style="margin: 0 1rem;" id="ai-debug-{{$JobID}}"
  196. class='ui basic ai_debug {{if eq .Status "CREATING" "STOPPING" "WAITING" "STARTING"}}disabled {{else}}blue {{end}}button'
  197. data-jobid="{{$JobID}}"
  198. data-repopath='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain{{else}}/modelarts/notebook{{end}}/{{$JobID}}/'>
  199. {{$.i18n.Tr "repo.debug"}}
  200. </a>
  201. {{else}}
  202. <a id="ai-debug-{{$JobID}}"
  203. class='ui basic ai_debug {{if eq .Status "CREATING" "STOPPING" "WAITING" "STARTING"}} disabled {{else}}blue {{end}}button'
  204. data-jobid="{{$JobID}}"
  205. data-repopath='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain{{else}}/modelarts/notebook{{end}}/{{$JobID}}/'>
  206. {{$.i18n.Tr "repo.debug_again"}}
  207. </a>
  208. {{end}}
  209. </form>
  210. </div>
  211. {{end}}
  212. <!-- 停止任务 -->
  213. <div class="ui compact buttons">
  214. {{if eq .JobType "MODELSAFETY"}}
  215. <form id="stopForm-{{$JobID}}" style="margin-left:-1px;">
  216. {{$.CsrfTokenHtml}}
  217. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  218. class='ui basic ai_stop {{if eq .Status "KILLED" "FAILED" "START_FAILED" "KILLING" "COMPLETED" "SUCCEEDED" "STOPPED" "STOPPING" "CREATE_FAILED"}}disabled {{else}} blue {{end}}button'
  219. data-repopath='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/modelsafety/{{$JobID}}/stop'
  220. data-jobid="{{$JobID}}">
  221. {{$.i18n.Tr "repo.stop"}}
  222. </a>
  223. </form>
  224. {{else}}
  225. {{if eq .JobType "DEBUG" "BENCHMARK" "SNN4IMAGENET" "BRAINSCORE"}}
  226. <form id="stopForm-{{$JobID}}" style="margin-left:-1px;">
  227. {{$.CsrfTokenHtml}}
  228. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  229. class='ui basic ai_stop {{if eq .Status "KILLED" "FAILED" "START_FAILED" "KILLING" "COMPLETED" "SUCCEEDED" "STOPPED" "STOPPING" "CREATE_FAILED"}}disabled {{else}} blue {{end}}button'
  230. data-repopath='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain{{else if eq .JobType "BENCHMARK" }}/cloudbrain/benchmark{{else if eq .ComputeResource "NPU" }}/modelarts/notebook{{end}}/{{$JobID}}/stop'
  231. data-jobid="{{$JobID}}">
  232. {{$.i18n.Tr "repo.stop"}}
  233. </a>
  234. </form>
  235. {{else}}
  236. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  237. class='ui basic ai_stop_version {{if eq .Status "KILLED" "FAILED" "START_FAILED" "KILLING" "COMPLETED" "STOPPED" "SUCCEEDED" "CREATE_FAILED"}}disabled {{else}} blue {{end}}button'
  238. data-repopath='{{.Repo.OwnerName}}/{{.Repo.Name}}/{{if eq .JobType "INFERENCE"}}{{if eq .Cloudbrain.Type 1}}modelarts/inference-job{{else}}cloudbrain/train-job{{end}}{{else if eq .JobType "TRAIN"}}{{if eq .Cloudbrain.Type 1}}modelarts/train-job{{else if eq .Cloudbrain.Type 0}}cloudbrain/train-job{{else if eq .Cloudbrain.Type 2}}grampus/train-job{{end}}{{end}}'
  239. data-jobid="{{$JobID}}" data-version="{{.VersionName}}">
  240. {{$.i18n.Tr "repo.stop"}}
  241. </a>
  242. {{end}}
  243. {{end}}
  244. </div>
  245. {{if eq .JobType "BENCHMARK"}}
  246. <div class="ui compact buttons">
  247. <a class="ui basic button {{if $.IsSigned}} blue{{else}} disabled{{end}}"
  248. href="{{$.RepoLink}}/cloudbrain/{{.Cloudbrain.ID}}/rate" target="_blank">
  249. {{$.i18n.Tr "repo.score"}}
  250. </a>
  251. </div>
  252. {{end}}
  253. <!-- 修改任务 -->
  254. {{if eq .JobType "TRAIN"}}
  255. <div class="ui compact buttons">
  256. <a style="padding: 0.5rem 1rem;" class="ui basic blue button" href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .Cloudbrain.Type 1}}/modelarts/train-job/{{.JobID}}{{else if eq .Cloudbrain.Type 0}}/cloudbrain/train-job/{{.JobID}}{{else if eq .Cloudbrain.Type 2}}/grampus/train-job/{{.JobID}}{{end}}/create_version{{if .VersionName}}?version_name={{.VersionName}}{{end}}">
  257. {{$.i18n.Tr "repo.modelarts.modify"}}
  258. </a>
  259. </div>
  260. {{end}}
  261. <!-- 删除任务 -->
  262. {{if eq .JobType "MODELSAFETY"}}
  263. <form class="ui compact buttons" id="delForm-{{$JobID}}"
  264. action='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/modelsafety/{{$JobID}}/del?ishomepage=true'
  265. method="post">
  266. {{$.CsrfTokenHtml}}
  267. <a style="padding: 0.5rem 1rem;margin-left:0.2rem" id="ai-delete-{{$JobID}}"
  268. class="ui basic ai_delete blue button"
  269. style="border-radius: .28571429rem;">
  270. {{$.i18n.Tr "repo.delete"}}
  271. </a>
  272. </form>
  273. {{else}}
  274. <form class="ui compact buttons" id="delForm-{{$JobID}}"
  275. action='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .JobType "BENCHMARK"}}/cloudbrain/benchmark{{else if or (eq .JobType "SNN4IMAGENET") (eq .JobType "BRAINSCORE")}}/cloudbrain{{else if eq .JobType "DEBUG"}}{{if eq .ComputeResource "NPU"}}/modelarts/notebook{{else}}/cloudbrain{{end}}{{else if eq .JobType "TRAIN"}}{{if eq .Cloudbrain.Type 1}}/modelarts/train-job{{else if eq .Cloudbrain.Type 0}}/cloudbrain/train-job{{else if eq .Cloudbrain.Type 2}}/grampus/train-job{{end}}{{else if eq .JobType "INFERENCE"}}{{if eq .Cloudbrain.Type 0}}/cloudbrain/train-job{{end}}{{end}}/{{$JobID}}/del?ishomepage=true'
  276. method="post">
  277. {{$.CsrfTokenHtml}}
  278. <a style="padding: 0.5rem 1rem;margin-left:0.2rem" id="ai-delete-{{$JobID}}"
  279. data-repopath="{{.Repo.OwnerName}}/{{.Repo.Name}}/modelarts/inference-job/{{$JobID}}/del_version?ishomepage=true"
  280. data-version="" class="ui basic ai_delete blue button"
  281. style="border-radius: .28571429rem;">
  282. {{$.i18n.Tr "repo.delete"}}
  283. </a>
  284. </form>
  285. {{end}}
  286. </div>
  287. </div>
  288. </div>
  289. {{else}}
  290. {{$JobID := '0'}}
  291. {{if eq .JobType "DEBUG" "SNN4IMAGENET" "BRAINSCORE" "BENCHMARK"}}
  292. {{$JobID = .Cloudbrain.ID}}
  293. {{else}}
  294. {{$JobID = .JobID}}
  295. {{end}}
  296. <div class="ui grid stackable item">
  297. <div class="row">
  298. <!-- 任务名 -->
  299. <div class="three wide column nowrap" style="width:12% !important">
  300. {{if eq .JobType "DEBUG"}}
  301. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  302. <span class="fitted"
  303. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  304. </a>
  305. {{else if eq .JobType "INFERENCE"}}
  306. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  307. <span class="fitted"
  308. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  309. </a>
  310. {{else if eq .JobType "TRAIN"}}
  311. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  312. <span class="fitted"
  313. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  314. </a>
  315. {{else if eq .JobType "BENCHMARK"}}
  316. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  317. <span class="fitted"
  318. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  319. </a>
  320. {{end}}
  321. </div>
  322. <!-- 集群 -->
  323. <div class="one wide column text center nowrap" style="width:8% !important;">
  324. <span
  325. style="font-size: 12px;">{{if .Cluster}}{{.Cluster}}{{else}}--{{end}}</span>
  326. </div>
  327. <!-- 任务状态 -->
  328. <div class="two wide column text center nowrap"
  329. style="padding-left: 2.2rem !important; width: 8% !important;">
  330. <span class="job-status" id="{{$JobID}}" data-jobid="{{$JobID}}"
  331. data-version="{{.VersionName}}">
  332. <span><i id="{{$JobID}}-icon" style="vertical-align: middle;"
  333. class="{{.Status}}"></i><span id="{{$JobID}}-text"
  334. style="margin-left: 0.4em;font-size: 12px;">{{.Status}}</span></span>
  335. </span>
  336. </div>
  337. <!-- 任务类型 -->
  338. {{$JobType := $.i18n.Tr (printf "cloudbrain.%s" .JobType)}}
  339. <div class="one wide column text center nowrap" style="width:8%">
  340. <span style="font-size: 12px;" title="{{.JobType}}">{{$JobType}}</span>
  341. </div>
  342. <!-- 任务创建时间 -->
  343. <div class="two wide column text center nowrap" style="width: 8% !important;">
  344. <span style="font-size: 12px;"
  345. class="">{{TimeSinceUnix1 .Cloudbrain.CreatedUnix}}</span>
  346. </div>
  347. <!-- 任务运行时间 -->
  348. <div class="one wide column text center nowrap" style="width:6% !important;">
  349. <span style="font-size: 12px;"
  350. id="duration-{{$JobID}}">{{if .TrainJobDuration}}{{.TrainJobDuration}}{{else}}--{{end}}</span>
  351. </div>
  352. <!-- 计算资源 -->
  353. <div class="one wide column text center nowrap" style="width:6% !important;">
  354. <span
  355. style="font-size: 12px;">{{if .ComputeResource}}{{.ComputeResource}}{{else}}--{{end}}</span>
  356. </div>
  357. <!-- 智算中心 -->
  358. <div class="one wide column text center nowrap" style="width:8% !important;">
  359. <span
  360. style="font-size: 12px;">{{if .AiCenter}}{{.AiCenter}}{{else}}--{{end}}</span>
  361. </div>
  362. <!-- XPU类型 -->
  363. <div class="one wide column text center nowrap" style="width:10% !important;">
  364. <span style="font-size: 12px;" title="{{.CardType}}">
  365. {{if .CardType}}{{.CardType}}{{else}}--{{end}}
  366. </span>
  367. </div>
  368. <!-- 项目 -->
  369. <div class="two wide column text center nowrap" style="width: 11%!important;">
  370. <a href="" title="">--</a>
  371. </div>
  372. <div class="three wide column text center nowrap" style="width: 15%!important;">
  373. {{if eq .JobType "DEBUG"}}
  374. <div class="ui compact buttons">
  375. <form id="debugAgainForm-{{$JobID}}">
  376. {{$.CsrfTokenHtml}}
  377. {{if eq .Status "RUNNING" "WAITING" "CREATING" "STARTING"}}
  378. <a style="margin: 0 1rem;" id="ai-debug-{{$JobID}}"
  379. class='ui basic disabled button'>
  380. {{$.i18n.Tr "repo.debug"}}
  381. </a>
  382. {{else}}
  383. <a id="ai-debug-{{$JobID}}" class='ui basic disabled button'>
  384. {{$.i18n.Tr "repo.debug_again"}}
  385. </a>
  386. {{end}}
  387. </form>
  388. </div>
  389. {{end}}
  390. <!-- 停止任务 -->
  391. <div class="ui compact buttons">
  392. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  393. class="ui basic disabled button" data-jobid="{{$JobID}}"
  394. data-version="{{.VersionName}}">
  395. {{$.i18n.Tr "repo.stop"}}
  396. </a>
  397. </div>
  398. <!-- 删除任务 -->
  399. <form class="ui compact buttons" id="delForm-{{$JobID}}" action='' method="post">
  400. {{$.CsrfTokenHtml}}
  401. <a style="padding: 0.5rem 1rem;margin-left:0.2rem" id="ai-delete-{{$JobID}}"
  402. class="ui basic disabled button" style="border-radius: .28571429rem;">
  403. {{$.i18n.Tr "repo.delete"}}
  404. </a>
  405. </form>
  406. </div>
  407. </div>
  408. </div>
  409. {{end}}
  410. {{end}}
  411. </div>
  412. </div>
  413. </div>
  414. </div>
  415. </div>
  416. <div id="app" style="margin-top: 2rem;margin-bottom: 2rem;">
  417. <div class="center">
  418. <el-pagination background @current-change="handleCurrentChange" :current-page="page"
  419. :page-sizes="[10]" :page-size="10" layout="total, sizes, prev, pager, next, jumper"
  420. :total="{{.Page.Paginater.Total}}">
  421. </el-pagination>
  422. </div>
  423. </div>
  424. <!-- 确认模态框 -->
  425. <div id="deletemodel">
  426. <div class="ui basic modal">
  427. <div class="ui icon header">
  428. <i class="trash icon"></i> {{.i18n.Tr "cloudbrain.delete_task"}}
  429. </div>
  430. <div class="content">
  431. <p>{{.i18n.Tr "cloudbrain.task_delete_confirm"}}</p>
  432. </div>
  433. <div class="actions">
  434. <div class="ui red basic inverted cancel button">
  435. <i class="remove icon"></i> {{.i18n.Tr "cloudbrain.operate_cancel"}}
  436. </div>
  437. <div class="ui green basic inverted ok button">
  438. <i class="checkmark icon"></i> {{.i18n.Tr "cloudbrain.operate_confirm"}}
  439. </div>
  440. </div>
  441. </div>
  442. </div>
  443. </div>
  444. {{template "base/footer" .}}