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 36 kB

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
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
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
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
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
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
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
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
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
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
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
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
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
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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474
  1. {{template "base/head" .}}
  2. <!-- 提示框 -->
  3. <div class="alert"></div>
  4. <script src="{{StaticUrlPrefix}}/js/specsuse.js?v={{MD5 AppVer}}" type="text/javascript"></script>
  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 (eq .JobType "SNN4IMAGENET" "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 "INFERENCE"}}
  94. <a class="title"
  95. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/{{if eq .Cloudbrain.Type 1}}modelarts{{else if eq .Cloudbrain.Type 0}}cloudbrain{{end}}/inference-job/{{$JobID}}"
  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 "TRAIN"}}
  101. <a class="title"
  102. 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}}"
  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 "BENCHMARK" "MODELSAFETY"}}
  108. <a class="title"
  109. href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/cloudbrain/benchmark/{{$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. {{end}}
  115. </div>
  116. <!-- 集群 -->
  117. <div class="one wide column text center nowrap" style="width:8% !important;">
  118. <span style="font-size: 12px;" class="cluster_{{.DisplayJobName}}_{{$JobID}}">{{if .Cluster}}{{.Cluster}}{{else}}--{{end}}</span>
  119. </div>
  120. <!-- 任务状态 -->
  121. <div class="two wide column text center nowrap"
  122. style="width: 8% !important;">
  123. <span class="job-status" id="{{$JobID}}"
  124. 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" "MODELSAFETY"}}/cloudbrain{{end}}'
  125. data-jobid="{{$JobID}}" data-version="{{.VersionName}}">
  126. <span><i id="{{$JobID}}-icon" style="vertical-align: middle;"
  127. class="{{.Status}}"></i><span id="{{$JobID}}-text"
  128. style="margin-left: 0.4em;font-size: 12px;">{{.Status}}</span></span>
  129. </span>
  130. </div>
  131. <!-- 任务类型 -->
  132. {{$JobType := $.i18n.Tr (printf "cloudbrain.%s" .JobType)}}
  133. <div class="one wide column text center nowrap" style="width:8% !important">
  134. <span style="font-size: 12px;" title="{{.JobType}}">{{$JobType}}</span>
  135. </div>
  136. <!-- 任务创建时间 -->
  137. <div class="two wide column text center nowrap" style="width: 8% !important;">
  138. <span style="font-size: 12px;"
  139. class="">{{TimeSinceUnix1 .Cloudbrain.CreatedUnix}}</span>
  140. </div>
  141. <!-- 任务运行时间 -->
  142. <div class="one wide column text center nowrap" style="width:6% !important;">
  143. <span style="font-size: 12px;"
  144. id="duration-{{$JobID}}">{{if .TrainJobDuration}}{{.TrainJobDuration}}{{else}}--{{end}}</span>
  145. </div>
  146. <!-- 计算资源 -->
  147. <div class="one wide column text center nowrap" style="width:6% !important;">
  148. <span
  149. style="font-size: 12px;">{{if .ComputeResource}}{{.ComputeResource}}{{else}}--{{end}}</span>
  150. </div>
  151. <!-- 智算中心 -->
  152. <div class="one wide column text center nowrap" style="width:8% !important;">
  153. <span style="font-size: 12px;" class="aicenter_{{.DisplayJobName}}_{{$JobID}}" title="{{if .AiCenter}}{{.AiCenter}}{{else}}--{{end}}">{{if .AiCenter}}{{.AiCenter}}{{else}}--{{end}}</span>
  154. </div>
  155. <!-- XPU类型 -->
  156. <div class="one wide column text center nowrap" style="width:10% !important;">
  157. <span style="font-size: 12px;" title="" class="card_type_{{.DisplayJobName}}_{{$JobID}}"></span>
  158. </div>
  159. <script>
  160. (function(){
  161. var spec = {{.Spec}} || {};
  162. var cardType = getListValueWithKey(ACC_CARD_TYPE, spec.AccCardType) || '--';
  163. var spanEl = document.querySelector('.card_type_{{.DisplayJobName}}_{{$JobID}}');
  164. spanEl.setAttribute('title', cardType);
  165. spanEl.innerText = cardType;
  166. var cluster = {{.Cluster}} || '--';
  167. var clusterName = document.querySelector('.cloudbrain_debug').dataset['cluster' + cluster[0] + cluster.toLocaleLowerCase().slice(1)] || '--';
  168. spanEl = document.querySelector('.cluster_{{.DisplayJobName}}_{{$JobID}}');
  169. spanEl.setAttribute('title', cluster);
  170. spanEl.innerText = clusterName;
  171. // var aiCenter = spec.AiCenterName || '--';
  172. // spanEl = document.querySelector('.aicenter_{{.DisplayJobName}}_{{$JobID}}');
  173. // spanEl.setAttribute('title', aiCenter);
  174. // spanEl.innerText = aiCenter;
  175. })();
  176. </script>
  177. <!-- 项目 -->
  178. <div class="two wide column text center nowrap" style="width: 11%!important;">
  179. <a href="{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}"
  180. title="{{.Repo.OwnerName}}/{{.Repo.Alias}}">{{.Repo.OwnerName}}/{{.Repo.Alias}}</a>
  181. </div>
  182. <div class="three wide column text center nowrap" style="width: 15%!important;">
  183. {{if eq .JobType "DEBUG"}}
  184. <div class="ui compact buttons">
  185. <form id="debugAgainForm-{{$JobID}}">
  186. {{$.CsrfTokenHtml}}
  187. {{if eq .Status "RUNNING" "WAITING" "CREATING" "STARTING"}}
  188. <a style="margin: 0 1rem;" id="ai-debug-{{$JobID}}"
  189. class='ui basic ai_debug {{if eq .Status "CREATING" "STOPPING" "WAITING" "STARTING"}}disabled {{else}}blue {{end}}button'
  190. data-jobid="{{$JobID}}"
  191. data-repopath='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}{{if eq .ComputeResource "CPU/GPU"}}/cloudbrain{{else}}/modelarts/notebook{{end}}/{{$JobID}}/'>
  192. {{$.i18n.Tr "repo.debug"}}
  193. </a>
  194. {{else}}
  195. <a 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_again"}}
  200. </a>
  201. {{end}}
  202. </form>
  203. </div>
  204. {{end}}
  205. <!-- 停止任务 -->
  206. <div class="ui compact buttons">
  207. {{if eq .JobType "MODELSAFETY"}}
  208. <form id="stopForm-{{$JobID}}" style="margin-left:-1px;">
  209. {{$.CsrfTokenHtml}}
  210. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  211. class='ui basic ai_stop {{if eq .Status "KILLED" "FAILED" "START_FAILED" "KILLING" "COMPLETED" "SUCCEEDED" "STOPPED" "STOPPING" "CREATE_FAILED"}}disabled {{else}} blue {{end}}button'
  212. data-repopath='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/modelsafety/{{$JobID}}/stop'
  213. data-jobid="{{$JobID}}">
  214. {{$.i18n.Tr "repo.stop"}}
  215. </a>
  216. </form>
  217. {{else}}
  218. {{if eq .JobType "DEBUG" "BENCHMARK" "SNN4IMAGENET" "BRAINSCORE"}}
  219. <form id="stopForm-{{$JobID}}" style="margin-left:-1px;">
  220. {{$.CsrfTokenHtml}}
  221. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  222. class='ui basic ai_stop {{if eq .Status "KILLED" "FAILED" "START_FAILED" "KILLING" "COMPLETED" "SUCCEEDED" "STOPPED" "STOPPING" "CREATE_FAILED"}}disabled {{else}} blue {{end}}button'
  223. 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'
  224. data-jobid="{{$JobID}}">
  225. {{$.i18n.Tr "repo.stop"}}
  226. </a>
  227. </form>
  228. {{else}}
  229. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  230. class='ui basic ai_stop_version {{if eq .Status "KILLED" "FAILED" "START_FAILED" "KILLING" "COMPLETED" "STOPPED" "SUCCEEDED" "CREATE_FAILED"}}disabled {{else}} blue {{end}}button'
  231. 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}}'
  232. data-jobid="{{$JobID}}" data-version="{{.VersionName}}">
  233. {{$.i18n.Tr "repo.stop"}}
  234. </a>
  235. {{end}}
  236. {{end}}
  237. </div>
  238. {{if eq .JobType "BENCHMARK"}}
  239. <div class="ui compact buttons">
  240. <a class="ui basic button {{if $.IsSigned}} blue{{else}} disabled{{end}}"
  241. href="{{$.RepoLink}}/cloudbrain/{{.Cloudbrain.ID}}/rate" target="_blank">
  242. {{$.i18n.Tr "repo.score"}}
  243. </a>
  244. </div>
  245. {{end}}
  246. <!-- 修改任务 -->
  247. {{if eq .JobType "TRAIN"}}
  248. <div class="ui compact buttons __btn_edit__">
  249. <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}}">
  250. {{$.i18n.Tr "repo.modelarts.modify"}}
  251. </a>
  252. </div>
  253. {{end}}
  254. <!-- 删除任务 -->
  255. {{if eq .JobType "MODELSAFETY"}}
  256. <form class="ui compact buttons" id="delForm-{{$JobID}}"
  257. action='{{AppSubUrl}}/{{.Repo.OwnerName}}/{{.Repo.Name}}/modelsafety/{{$JobID}}/del?ishomepage=true'
  258. method="post">
  259. {{$.CsrfTokenHtml}}
  260. <a style="padding: 0.5rem 1rem;margin-left:0.2rem" id="ai-delete-{{$JobID}}"
  261. class="ui basic ai_delete blue button"
  262. style="border-radius: .28571429rem;">
  263. {{$.i18n.Tr "repo.delete"}}
  264. </a>
  265. </form>
  266. {{else}}
  267. <form class="ui compact buttons" id="delForm-{{$JobID}}"
  268. 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'
  269. method="post">
  270. {{$.CsrfTokenHtml}}
  271. <a style="padding: 0.5rem 1rem;margin-left:0.2rem" id="ai-delete-{{$JobID}}"
  272. data-repopath="{{.Repo.OwnerName}}/{{.Repo.Name}}/modelarts/inference-job/{{$JobID}}/del_version?ishomepage=true"
  273. data-version="" class="ui basic ai_delete blue button"
  274. style="border-radius: .28571429rem;">
  275. {{$.i18n.Tr "repo.delete"}}
  276. </a>
  277. </form>
  278. {{end}}
  279. </div>
  280. </div>
  281. </div>
  282. {{else}}
  283. {{$JobID := '0'}}
  284. {{if eq .JobType "DEBUG" "SNN4IMAGENET" "BRAINSCORE" "BENCHMARK"}}
  285. {{$JobID = .Cloudbrain.ID}}
  286. {{else}}
  287. {{$JobID = .JobID}}
  288. {{end}}
  289. <div class="ui grid stackable item">
  290. <div class="row">
  291. <!-- 任务名 -->
  292. <div class="three wide column nowrap" style="width:12% !important">
  293. {{if eq .JobType "DEBUG"}}
  294. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  295. <span class="fitted"
  296. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  297. </a>
  298. {{else if eq .JobType "INFERENCE"}}
  299. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  300. <span class="fitted"
  301. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  302. </a>
  303. {{else if eq .JobType "TRAIN"}}
  304. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  305. <span class="fitted"
  306. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  307. </a>
  308. {{else if eq .JobType "BENCHMARK"}}
  309. <a class="title" href="" title="{{.DisplayJobName}}" style="font-size: 14px;padding-right:0px">
  310. <span class="fitted"
  311. style="width: 90%;vertical-align: middle;">{{.DisplayJobName}}</span>
  312. </a>
  313. {{end}}
  314. </div>
  315. <!-- 集群 -->
  316. <div class="one wide column text center nowrap" style="width:8% !important;">
  317. <span
  318. style="font-size: 12px;">{{if .Cluster}}{{.Cluster}}{{else}}--{{end}}</span>
  319. </div>
  320. <!-- 任务状态 -->
  321. <div class="two wide column text center nowrap"
  322. style="padding-left: 2.2rem !important; width: 8% !important;">
  323. <span class="job-status" id="{{$JobID}}" data-jobid="{{$JobID}}"
  324. data-version="{{.VersionName}}">
  325. <span><i id="{{$JobID}}-icon" style="vertical-align: middle;"
  326. class="{{.Status}}"></i><span id="{{$JobID}}-text"
  327. style="margin-left: 0.4em;font-size: 12px;">{{.Status}}</span></span>
  328. </span>
  329. </div>
  330. <!-- 任务类型 -->
  331. {{$JobType := $.i18n.Tr (printf "cloudbrain.%s" .JobType)}}
  332. <div class="one wide column text center nowrap" style="width:8%">
  333. <span style="font-size: 12px;" title="{{.JobType}}">{{$JobType}}</span>
  334. </div>
  335. <!-- 任务创建时间 -->
  336. <div class="two wide column text center nowrap" style="width: 8% !important;">
  337. <span style="font-size: 12px;"
  338. class="">{{TimeSinceUnix1 .Cloudbrain.CreatedUnix}}</span>
  339. </div>
  340. <!-- 任务运行时间 -->
  341. <div class="one wide column text center nowrap" style="width:6% !important;">
  342. <span style="font-size: 12px;"
  343. id="duration-{{$JobID}}">{{if .TrainJobDuration}}{{.TrainJobDuration}}{{else}}--{{end}}</span>
  344. </div>
  345. <!-- 计算资源 -->
  346. <div class="one wide column text center nowrap" style="width:6% !important;">
  347. <span
  348. style="font-size: 12px;">{{if .ComputeResource}}{{.ComputeResource}}{{else}}--{{end}}</span>
  349. </div>
  350. <!-- 智算中心 -->
  351. <div class="one wide column text center nowrap" style="width:8% !important;">
  352. <span
  353. style="font-size: 12px;">{{if .AiCenter}}{{.AiCenter}}{{else}}--{{end}}</span>
  354. </div>
  355. <!-- XPU类型 -->
  356. <div class="one wide column text center nowrap" style="width:10% !important;">
  357. <span style="font-size: 12px;" title="{{.CardType}}">
  358. {{if .CardType}}{{.CardType}}{{else}}--{{end}}
  359. </span>
  360. </div>
  361. <!-- 项目 -->
  362. <div class="two wide column text center nowrap" style="width: 11%!important;">
  363. <a href="" title="">--</a>
  364. </div>
  365. <div class="three wide column text center nowrap" style="width: 15%!important;">
  366. {{if eq .JobType "DEBUG"}}
  367. <div class="ui compact buttons">
  368. <form id="debugAgainForm-{{$JobID}}">
  369. {{$.CsrfTokenHtml}}
  370. {{if eq .Status "RUNNING" "WAITING" "CREATING" "STARTING"}}
  371. <a style="margin: 0 1rem;" id="ai-debug-{{$JobID}}"
  372. class='ui basic disabled button'>
  373. {{$.i18n.Tr "repo.debug"}}
  374. </a>
  375. {{else}}
  376. <a id="ai-debug-{{$JobID}}" class='ui basic disabled button'>
  377. {{$.i18n.Tr "repo.debug_again"}}
  378. </a>
  379. {{end}}
  380. </form>
  381. </div>
  382. {{end}}
  383. <!-- 停止任务 -->
  384. <div class="ui compact buttons">
  385. <a style="padding: 0.5rem 1rem;" id="ai-stop-{{$JobID}}"
  386. class="ui basic disabled button" data-jobid="{{$JobID}}"
  387. data-version="{{.VersionName}}">
  388. {{$.i18n.Tr "repo.stop"}}
  389. </a>
  390. </div>
  391. <!-- 删除任务 -->
  392. <form class="ui compact buttons" id="delForm-{{$JobID}}" action='' method="post">
  393. {{$.CsrfTokenHtml}}
  394. <a style="padding: 0.5rem 1rem;margin-left:0.2rem" id="ai-delete-{{$JobID}}"
  395. class="ui basic disabled button" style="border-radius: .28571429rem;">
  396. {{$.i18n.Tr "repo.delete"}}
  397. </a>
  398. </form>
  399. </div>
  400. </div>
  401. </div>
  402. {{end}}
  403. {{end}}
  404. </div>
  405. </div>
  406. </div>
  407. </div>
  408. </div>
  409. <div id="app" style="margin-top: 2rem;margin-bottom: 2rem;">
  410. <div class="center">
  411. <el-pagination background @current-change="handleCurrentChange" :current-page="page"
  412. :page-sizes="[10]" :page-size="10" layout="total, sizes, prev, pager, next, jumper"
  413. :total="{{.Page.Paginater.Total}}">
  414. </el-pagination>
  415. </div>
  416. </div>
  417. <!-- 确认模态框 -->
  418. <div id="deletemodel">
  419. <div class="ui basic modal">
  420. <div class="ui icon header">
  421. <i class="trash icon"></i> {{.i18n.Tr "cloudbrain.delete_task"}}
  422. </div>
  423. <div class="content">
  424. <p>{{.i18n.Tr "cloudbrain.task_delete_confirm"}}</p>
  425. </div>
  426. <div class="actions">
  427. <div class="ui red basic inverted cancel button">
  428. <i class="remove icon"></i> {{.i18n.Tr "cloudbrain.operate_cancel"}}
  429. </div>
  430. <div class="ui green basic inverted ok button">
  431. <i class="checkmark icon"></i> {{.i18n.Tr "cloudbrain.operate_confirm"}}
  432. </div>
  433. </div>
  434. </div>
  435. </div>
  436. <div class="ui modal debug-again-alert">
  437. <div class="ui message" style="background-color: rgba(242, 113, 28, 0.05);border: 1px solid rgba(242, 113, 28, 1);border-radius: 5px;">
  438. <div style="display: flex;align-items: center;">
  439. <i class="ri-information-line" style="font-size: 35px;color: rgba(242, 113, 28, 1);;"></i>
  440. <div style="text-align: left;margin-left: 1rem;">
  441. <div style="font-weight: 600;line-height: 2;">{{.i18n.Tr "repo.cloudbrain.morethanonejob1" | Safe }}</div>
  442. <div style="color:#939393">{{.i18n.Tr "repo.cloudbrain.morethanonejob2" | Safe}}</div>
  443. </div>
  444. </div>
  445. </div>
  446. </div>
  447. </div>
  448. <script>
  449. document.addEventListener('DOMContentLoaded', function() {
  450. var editbtns = $('.__btn_edit__');
  451. var curHref = window.location.href;
  452. for (var i = 0, iLen = editbtns.length; i < iLen; i++) {
  453. var buttonEl = editbtns.eq(i).find('a');
  454. var oHref = buttonEl.attr('href');
  455. var hasSearch = oHref.split('?').length > 1;
  456. buttonEl.attr('href', oHref + (hasSearch ? '&' : '?') + 'backurl=' + encodeURIComponent(curHref));
  457. }
  458. });
  459. </script>
  460. {{template "base/footer" .}}