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.

new.tmpl 16 kB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
4 years ago
5 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
4 years ago
4 years ago
5 years ago
4 years ago
4 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
5 years ago
4 years ago
5 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. {{template "base/head" .}}
  2. <style>
  3. /* 遮罩层css效果图 */
  4. #mask {
  5. position: fixed;
  6. top: 0px;
  7. left: 0px;
  8. right: 0px;
  9. bottom: 0px;
  10. filter: alpha(opacity=60);
  11. background-color: #777;
  12. z-index: 1000;
  13. display: none;
  14. opacity: 0.8;
  15. -moz-opacity: 0.5;
  16. padding-top: 100px;
  17. color: #000000
  18. }
  19. /* 加载圈css效果图 */
  20. #loadingPage {
  21. margin: 200px auto;
  22. width: 50px;
  23. height: 40px;
  24. text-align: center;
  25. font-size: 10px;
  26. display: block;
  27. }
  28. #loadingPage>div {
  29. background-color: green;
  30. height: 100%;
  31. width: 6px;
  32. display: inline-block;
  33. -webkit-animation: sk-stretchdelay 1.2s infinite ease-in-out;
  34. animation: sk-stretchdelay 1.2s infinite ease-in-out;
  35. }
  36. #loadingPage .rect2 {
  37. -webkit-animation-delay: -1.1s;
  38. animation-delay: -1.1s;
  39. }
  40. #loadingPage .rect3 {
  41. -webkit-animation-delay: -1.0s;
  42. animation-delay: -1.0s;
  43. }
  44. #loadingPage .rect4 {
  45. -webkit-animation-delay: -0.9s;
  46. animation-delay: -0.9s;
  47. }
  48. #loadingPage .rect5 {
  49. -webkit-animation-delay: -0.8s;
  50. animation-delay: -0.8s;
  51. }
  52. @-webkit-keyframes sk-stretchdelay {
  53. 0%,
  54. 40%,
  55. 100% {
  56. -webkit-transform: scaleY(0.4)
  57. }
  58. 20% {
  59. -webkit-transform: scaleY(1.0)
  60. }
  61. }
  62. @keyframes sk-stretchdelay {
  63. 0%,
  64. 40%,
  65. 100% {
  66. transform: scaleY(0.4);
  67. -webkit-transform: scaleY(0.4);
  68. }
  69. 20% {
  70. transform: scaleY(1.0);
  71. -webkit-transform: scaleY(1.0);
  72. }
  73. }
  74. .inline.required.field.cloudbrain_benchmark {
  75. display: none;
  76. }
  77. .inline.required.field.cloudbrain_snn4imagenet {
  78. display: none;
  79. }
  80. .inline.required.field.cloudbrain_brainscore {
  81. display: none;
  82. }
  83. .icons{
  84. /* position: absolute !important;
  85. right: 150px;
  86. top: 14px;
  87. z-index: 2; */
  88. }
  89. </style>
  90. <div id="mask">
  91. <div id="loadingPage">
  92. <div class="rect1"></div>
  93. <div class="rect2"></div>
  94. <div class="rect3"></div>
  95. <div class="rect4"></div>
  96. <div class="rect5"></div>
  97. </div>
  98. </div>
  99. <div class="repository">
  100. {{template "repo/header" .}}
  101. <div class="repository new repo ui middle very relaxed page grid">
  102. <div class="column">
  103. {{template "base/alert" .}}
  104. <div class="ui negative message" id="messageInfo">
  105. <p></p>
  106. </div>
  107. <form id="form_id" class="ui form" action="{{.Link}}" method="post">
  108. {{.CsrfTokenHtml}}
  109. <h3 class="ui top attached header">
  110. {{.i18n.Tr "repo.cloudbrain.new"}}
  111. </h3>
  112. <div class="ui attached segment">
  113. <div class="inline required field">
  114. <label>{{.i18n.Tr "cloudbrain.compute_resource"}}</label>
  115. <div class="ui blue small menu compact selectcloudbrain">
  116. <a class="active item" href="{{.RepoLink}}/cloudbrain/create">
  117. <svg class="svg" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="16" height="16">
  118. <path fill="none" d="M0 0h24v24H0z"/>
  119. <path d="M3 2.992C3 2.444 3.445 2 3.993 2h16.014a1 1 0 0 1 .993.992v18.016a.993.993 0 0 1-.993.992H3.993A1 1 0 0 1 3 21.008V2.992zM19 11V4H5v7h14zm0 2H5v7h14v-7zM9 6h6v2H9V6zm0 9h6v2H9v-2z"/>
  120. </svg>
  121. CPU/GPU
  122. </a>
  123. <a class="item" href="{{.RepoLink}}/modelarts/notebook/create">
  124. <svg class="svg" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="16" height="16">
  125. <path fill="none" d="M0 0h24v24H0z"/>
  126. <path d="M3 2.992C3 2.444 3.445 2 3.993 2h16.014a1 1 0 0 1 .993.992v18.016a.993.993 0 0 1-.993.992H3.993A1 1 0 0 1 3 21.008V2.992zM19 11V4H5v7h14zm0 2H5v7h14v-7zM9 6h6v2H9V6zm0 9h6v2H9v-2z"/>
  127. </svg>
  128. Ascend NPU</a>
  129. </div>
  130. </div>
  131. <div class="inline required field">
  132. <label>{{.i18n.Tr "cloudbrain.task_name"}}</label>
  133. <input name="display_job_name" id="cloudbrain_job_name" placeholder="input {{.i18n.Tr "cloudbrain.task_name"}}" value="{{.display_job_name}}" tabindex="3" autofocus required maxlength="255" onkeyup="this.value=this.value.replace(/[, ]/g,'')">
  134. </div>
  135. <div class="inline required field">
  136. <label>{{.i18n.Tr "cloudbrain.task_type"}}</label>
  137. <select id="cloudbrain_job_type" class="ui search dropdown" placeholder="select {{.i18n.Tr "cloudbrain.task_type"}}" style='width:385px' name="job_type">
  138. <option name="job_type" value="DEBUG">DEBUG</option>
  139. {{if .is_snn4imagenet_enabled}}
  140. <option name="job_type" value="SNN4IMAGENET">SNN4IMAGENET</option>
  141. {{end}}
  142. {{if .is_brainscore_enabled}}
  143. <option name="job_type" value="BRAINSCORE">BRAINSCORE</option>
  144. {{end}}
  145. </select>
  146. </div>
  147. <div class="inline required field cloudbrain_benchmark">
  148. <label style="vertical-align: top; margin-top:9px">数据集类别</label>
  149. <select class="ui search dropdown" multiple="multiple" id="cloudbrain_benchmark_category" style='width:385px'>
  150. {{range .benchmark_categories}}
  151. <option value="{{.Value}}">{{.Value}}</option>
  152. {{end}}
  153. </select>
  154. <div class="mini ui buttons" style="vertical-align: top; margin-top:9px">
  155. <button class="ui button reset">重置</button>
  156. <div class="or"></div>
  157. <button class="ui positive button active all_selected">全选</button>
  158. </div>
  159. </div>
  160. <input id="store_category" type="hidden" name="get_benchmark_category">
  161. <div class="inline required field">
  162. <label>{{.i18n.Tr "repo.modelarts.code_version"}}</label>
  163. <select class="ui dropdown width80 left2" id="code_version" name="branch_name">
  164. {{if .branch_name}}
  165. <option name="branch_name" value="{{.branch_name}}">{{.branch_name}}</option>
  166. {{range $k, $v :=.Branches}}
  167. {{ if ne $v $.branch_name }}
  168. <option name="branch_name" value="{{$v}}">{{$v}}</option>
  169. {{end}}
  170. {{end}}
  171. {{else}}
  172. <option name="branch_name" value="{{.branchName}}">{{.branchName}}</option>
  173. {{range $k, $v :=.Branches}}
  174. {{ if ne $v $.branchName }}
  175. <option name="branch_name" value="{{$v}}">{{$v}}</option>
  176. {{end}}
  177. {{end}}
  178. {{end}}
  179. </select>
  180. </div>
  181. <div class="inline required field">
  182. <label>{{.i18n.Tr "cloudbrain.gpu_type"}}</label>
  183. <select id="cloudbrain_gpu_type" class="ui search dropdown" placeholder="选择GPU类型" style='width:385px' name="gpu_type">
  184. {{range .gpu_types}}
  185. <option value="{{.Queue}}">{{.Value}}</option>
  186. {{end}}
  187. </select>
  188. </div>
  189. <!-- <div class="inline required field" style="position: relative;">
  190. <label>{{.i18n.Tr "cloudbrain.mirror"}}</label>
  191. <input type="text" list="cloudbrain_image" placeholder="{{.i18n.Tr "cloudbrain.choose_mirror"}}" name="image" required autofocus maxlength="255">
  192. <i class="times circle outline icon icons" style="visibility: hidden;" onclick="clearValue()"></i>
  193. <datalist class="ui search" id="cloudbrain_image" style='width:385px;' name="image">
  194. {{range .images}}
  195. <option name="image" value="{{.Place}}">{{.PlaceView}}</option>
  196. {{end}}
  197. {{range .public_images}}
  198. <option name="image" value="{{.Place}}">{{.PlaceView}}</option>
  199. {{end}}
  200. </datalist>
  201. </div> -->
  202. <div id="images-new-cb">
  203. </div>
  204. {{template "custom/select_dataset" .}}
  205. <div class="inline required field">
  206. <label>{{.i18n.Tr "cloudbrain.resource_specification"}}</label>
  207. <select id="cloudbrain_resource_spec" class="ui search dropdown" placeholder="{{.i18n.Tr "cloudbrain.select_specification"}}" style='width:385px' name="resource_spec_id">
  208. {{range .resource_specs}}
  209. <option name="resource_spec_id" value="{{.Id}}">{{$.i18n.Tr "cloudbrain.gpu_num"}}:{{.GpuNum}},{{$.i18n.Tr "cloudbrain.cpu_num"}}:{{.CpuNum}},{{$.i18n.Tr "cloudbrain.memory"}}(MB):{{.MemMiB}},{{$.i18n.Tr "cloudbrain.shared_memory"}}(MB):{{.ShareMemMiB}}</option>
  210. {{end}}
  211. </select>
  212. </div>
  213. <div class="inline required field">
  214. <label>{{.i18n.Tr "cloudbrain.dataset_storage_path"}}</label>
  215. <input name="dataset_path" id="cloudbrain_dataset_path" value="{{.dataset_path}}" tabindex="3" disabled autofocus required maxlength="255" readonly="readonly">
  216. </div>
  217. <div class="inline required field">
  218. <label>{{.i18n.Tr "cloudbrain.model_storage_path"}}</label>
  219. <input name="model_path" id="cloudbrain_model_path" value="{{.model_path}}" tabindex="3" disabled autofocus required maxlength="255" readonly="readonly">
  220. </div>
  221. <div class="inline required field">
  222. <label>{{.i18n.Tr "cloudbrain.code_storage_path"}}</label>
  223. <input name="code_path" id="cloudbrain_code_path" value="{{.code_path}}" tabindex="3" disabled autofocus required maxlength="255" readonly="readonly">
  224. </div>
  225. <div class="inline required field cloudbrain_benchmark">
  226. <label>{{.i18n.Tr "cloudbrain.benchmark_path"}}</label>
  227. <input name="benchmark_path" id="cloudbrain_benchmark_path" value="{{.benchmark_path}}" tabindex="3" disabled autofocus required maxlength="255" readonly="readonly">
  228. </div>
  229. <div class="inline required field cloudbrain_snn4imagenet">
  230. <label>{{.i18n.Tr "cloudbrain.snn4imagenet_path"}}</label>
  231. <input name="snn4imagenet_path" id="cloudbrain_snn4imagenet_path" value="{{.snn4imagenet_path}}" tabindex="3" disabled autofocus required maxlength="255" readonly="readonly">
  232. </div>
  233. <div class="inline required field cloudbrain_brainscore">
  234. <label>{{.i18n.Tr "cloudbrain.brainscore_path"}}</label>
  235. <input name="brainscore_path" id="cloudbrain_brainscore_path" value="{{.brainscore_path}}" tabindex="3" disabled autofocus required maxlength="255" readonly="readonly">
  236. </div>
  237. <div class="inline required field" hidden>
  238. <label>{{.i18n.Tr "cloudbrain.start_command"}}</label>
  239. <textarea name="command" rows="10" readonly="readonly">{{.command}}</textarea>
  240. </div>
  241. <div class="inline field">
  242. <label></label>
  243. <button class="ui green button" >
  244. {{.i18n.Tr "repo.cloudbrain.new"}}
  245. </button>
  246. <a class="ui button cancel" href="{{.RepoLink}}/debugjob?debugListType=all">{{.i18n.Tr "repo.cloudbrain.cancel"}}</a>
  247. </div>
  248. </div>
  249. </form>
  250. </div>
  251. </div>
  252. </div>
  253. {{template "base/footer" .}}
  254. <script>
  255. let form = document.getElementById('form_id');
  256. // let inputs = document.querySelectorAll('input[list]');
  257. // inputs[0].addEventListener('change', function() {
  258. // $(".icon.icons").css("visibility","visible")
  259. // });
  260. $('#messageInfo').css('display','none')
  261. function clearValue(){
  262. context=inputs[0]
  263. context.value=''
  264. $(".icon.icons").css("visibility","hidden")
  265. }
  266. form.onsubmit = function(e){
  267. let value_task = $("input[name='display_job_name']").val()
  268. let value_image = $("input[name='image']").val()
  269. let value_data = $("input[name='attachment']").val()
  270. let re = /^[a-z0-9][a-z0-9-_]{1,34}[a-z0-9-]$/
  271. let flag = re.test(value_task)
  272. if(!flag){
  273. $('#messageInfo').css('display','block')
  274. let str = '只能以小写字母或数字开头且只包含小写字母、数字、_和-,不能以_结尾,最长36个字符。'
  275. $('#messageInfo p').text(str)
  276. return false
  277. }
  278. let min_value_task = value_task.toLowerCase()
  279. $("input[name='display_job_name']").attr("value",min_value_task)
  280. document.getElementById("mask").style.display = "block"
  281. }
  282. // 页面加载完毕后遮罩层隐藏
  283. document.onreadystatechange = function() {
  284. if (document.readyState === "complete") {
  285. document.getElementById("mask").style.display = "none"
  286. }
  287. }
  288. $('#cloudbrain_benchmark_category')
  289. .dropdown({
  290. placeholder: "选择数据集类别",
  291. })
  292. $('select.dropdown')
  293. .dropdown();
  294. // $('#cloudbrain_image').select2({
  295. // placeholder: "选择镜像"
  296. // });
  297. $(".ui.button.reset").click(function(e){
  298. e.preventDefault()
  299. $('#cloudbrain_benchmark_category')
  300. .dropdown("clear", true)
  301. })
  302. $(".ui.positive.button.active.all_selected").click(function(e){
  303. e.preventDefault()
  304. var selected_value = new Array()
  305. $("#cloudbrain_benchmark_category option").each(function(){
  306. selected_value.push($(this).val())
  307. });
  308. $('#cloudbrain_benchmark_category')
  309. .dropdown("set exactly", selected_value)
  310. })
  311. $(function() {
  312. $("#cloudbrain_job_type").change(function() {
  313. if ($(this).val() == 'BENCHMARK') {
  314. $(".cloudbrain_benchmark").show();
  315. } else if ($(this).val() == 'SNN4IMAGENET') {
  316. $(".cloudbrain_snn4imagenet").show();
  317. } else if ($(this).val() == 'BRAINSCORE') {
  318. $(".cloudbrain_brainscore").show();
  319. } else {
  320. $(".cloudbrain_benchmark").hide();
  321. $(".cloudbrain_snn4imagenet").hide();
  322. $(".cloudbrain_brainscore").hide();
  323. }
  324. })
  325. })
  326. $('.ui.green.button').click(function() {
  327. selected_value = $("#cloudbrain_benchmark_category").val()
  328. $('#store_category').attr("value", selected_value)
  329. })
  330. </script>