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.

index.tmpl 9.8 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. <!-- 头部导航栏 -->
  2. {{template "base/head" .}}
  3. <!-- 弹窗 -->
  4. <div id="mask">
  5. <div id="loadingPage">
  6. <div class="rect1"></div>
  7. <div class="rect2"></div>
  8. <div class="rect3"></div>
  9. <div class="rect4"></div>
  10. <div class="rect5"></div>
  11. </div>
  12. </div>
  13. {{$repository := .Repository.ID}}
  14. <!-- 提示框 -->
  15. <div class="alert"></div>
  16. <div class="repository release dataset-list view">
  17. {{template "repo/header" .}}
  18. <!-- 列表容器 -->
  19. <div class="ui container active loader" id="loadContainer">
  20. {{template "base/alert" .}}
  21. <div class="ui two column stackable grid" style="display: none;">
  22. <div class="column"></div>
  23. <div class="column right aligned">
  24. <!-- -->
  25. <a class="ui button {{if .Permission.CanWrite $.UnitTypeCloudBrain}} green {{else}} disabled {{end}}" onclick="showcreate(this)">{{$.i18n.Tr "repo.model.manage.import_new_model"}}</a>
  26. </div>
  27. </div>
  28. <!-- 中下列表展示区 -->
  29. <div class="ui grid" style="display: none;">
  30. <div class="row" style="padding-top: 0;">
  31. <div class="ui sixteen wide column">
  32. <!-- 任务展示 -->
  33. <div class="dataset list" id="model_list">
  34. <!-- 表头 -->
  35. </div>
  36. </div>
  37. </div>
  38. </div>
  39. </div>
  40. </div>
  41. <!-- div full height-->
  42. </div>
  43. <!-- 确认模态框 -->
  44. <div id="deletemodel">
  45. <div class="ui basic modal first">
  46. <div class="ui icon header">
  47. <i class="trash icon"></i> 删除模型
  48. </div>
  49. <div class="content">
  50. <p>你确认删除该模型么?此模型一旦删除不可恢复。</p>
  51. </div>
  52. <div class="actions">
  53. <div class="ui red basic inverted cancel button">
  54. <i class="remove icon"></i> 取消操作
  55. </div>
  56. <div class="ui green basic inverted ok button">
  57. <i class="checkmark icon"></i> 确定操作
  58. </div>
  59. </div>
  60. </div>
  61. </div>
  62. <div id="newmodel">
  63. <div class="ui modal second">
  64. <div class="header" style="padding: 1rem;background-color: rgba(240, 240, 240, 100);">
  65. <h4 id="model_header"></h4>
  66. </div>
  67. <div class="content content-padding">
  68. <form id="formId" method="POST" class="ui form">
  69. <div class="ui error message">
  70. <!-- <p>asdasdasd</p> -->
  71. </div>
  72. <input type="hidden" name="_csrf" value="">
  73. <div class="two inline fields ">
  74. <div class="required ten wide field">
  75. <label style="margin-left: -23px;">选择训练任务</label>
  76. <div class="ui dropdown selection search width83 loading" id="choice_model">
  77. <input type="hidden" id="JobId" name="JobId" required>
  78. <div class="default text">选择训练任务</div>
  79. <i class="dropdown icon"></i>
  80. <div class="menu" id="job-name">
  81. </div>
  82. </div>
  83. </div>
  84. <div class="required six widde field">
  85. <label>版本</label>
  86. <div class="ui dropdown selection search width70" id="choice_version">
  87. <input type="hidden" id="VersionName" name="VersionName" required>
  88. <div class="default text">选择版本</div>
  89. <i class="dropdown icon"></i>
  90. <div class="menu" id="job-version">
  91. </div>
  92. </div>
  93. </div>
  94. </div>
  95. <div class="required inline field" id="modelname">
  96. <label>模型名称</label>
  97. <input style="width: 45%;" id="name" name="Name" required maxlength="25" onkeyup="this.value=this.value.replace(/[, ]/g,'')">
  98. </div>
  99. <div class="required inline field" id="verionname">
  100. <label>模型版本</label>
  101. <input style="width: 45%;" id="version" name="Version" value="" readonly required maxlength="255">
  102. </div>
  103. <div class="inline field">
  104. <label>模型标签</label>
  105. <input style="width: 83%;margin-left: 7px;" id="label" name="Label" maxlength="255" placeholder='{{.i18n.Tr "repo.modelarts.train_job.label_place"}}'>
  106. </div>
  107. <div class="inline field">
  108. <label for="description">模型描述</label>
  109. <textarea style="width: 83%;margin-left: 7px;" id="Description" name="Description" rows="3" maxlength="255" placeholder='{{.i18n.Tr "repo.modelarts.train_job.new_place"}}' onchange="this.value=this.value.substring(0, 255)" onkeydown="this.value=this.value.substring(0, 255)" onkeyup="this.value=this.value.substring(0, 256)"></textarea>
  110. </div>
  111. <div class="inline field" style="margin-left: 75px;">
  112. <button id="submitId" type="button" class="ui create_train_job green button" style="position: absolute;">
  113. {{.i18n.Tr "repo.model.manage.sava_model"}}
  114. </button>
  115. </div>
  116. </form>
  117. <div class="actions" style="display: inline-block;margin-left: 180px;">
  118. <button class="ui button cancel" >{{.i18n.Tr "repo.cloudbrain.cancel"}}</button>
  119. </div>
  120. </div>
  121. </div>
  122. {{template "base/footer" .}}
  123. <script>
  124. let repolink = {{.RepoLink}}
  125. let repoId = {{$repository}}
  126. let url_href = window.location.pathname.split('show_model')[0] + 'create_model'
  127. const {_AppSubUrl, _StaticUrlPrefix, csrf} = window.config;
  128. $('input[name="_csrf"]').val(csrf)
  129. function createModelName(){
  130. let repoName = location.pathname.split('/')[2]
  131. let modelName = repoName + '_model_' + Math.random().toString(36).substr(2, 4)
  132. $('#name').val(modelName)
  133. $('#version').val("0.0.1")
  134. }
  135. function showcreate(obj){
  136. $('.ui.modal.second')
  137. .modal({
  138. centered: false,
  139. onShow:function(){
  140. $('#model_header').text("导入新模型")
  141. $('input[name="Version"]').addClass('model_disabled')
  142. $('.ui.dimmer').css({"background-color":"rgb(136, 136, 136,0.7)"})
  143. $("#job-name").empty()
  144. createModelName()
  145. loadTrainList()
  146. },
  147. onHide:function(){
  148. document.getElementById("formId").reset();
  149. $('#choice_model').dropdown('clear')
  150. $('#choice_version').dropdown('clear')
  151. $('.ui.dimmer').css({"background-color":""})
  152. $('.ui.error.message').text()
  153. $('.ui.error.message').css('display','none')
  154. }
  155. })
  156. .modal('show')
  157. }
  158. $(function(){
  159. $('#choice_model').dropdown({
  160. onChange:function(value){
  161. $(".ui.dropdown.selection.search.width70").addClass("loading")
  162. $('#choice_version').dropdown('clear')
  163. $("#job-version").empty()
  164. loadTrainVersion(value)
  165. }
  166. })
  167. })
  168. function versionAdd(version){
  169. let versionArray = version.split('.')
  170. if(versionArray[2]=='9'){
  171. if(versionArray[1]=='9'){
  172. versionArray[0] = String(Number(versionArray[1])+1)
  173. versionArray[1] = '0'
  174. }else{
  175. versionArray[1]=String(Number(versionArray[1])+1)
  176. }
  177. versionArray[2]='0'
  178. }else{
  179. versionArray[2]=String(Number(versionArray[2])+1)
  180. }
  181. return versionArray.join('.')
  182. }
  183. function loadTrainList(){
  184. $.get(`${repolink}/modelmanage/query_train_job?repoId=${repoId}`, (data) => {
  185. const n_length = data.length
  186. let train_html=''
  187. for (let i=0;i<n_length;i++){
  188. train_html += `<div class="item" data-value="${data[i].JobID}">${data[i].JobName}</div>`
  189. train_html += '</div>'
  190. }
  191. $("#job-name").append(train_html)
  192. $(".ui.dropdown.selection.search.width83").removeClass("loading")
  193. $('#choice_model .default.text').text(data[0].JobName)
  194. $('#choice_model input[name="JobId"]').val(data[0].JobID)
  195. loadTrainVersion()
  196. })
  197. }
  198. function loadTrainVersion(value){
  199. let JobID = !value ?$('#choice_model input[name="JobId"]').val(): value
  200. $.get(`${repolink}/modelmanage/query_train_job_version?JobID=${JobID}`, (data) => {
  201. const n_length = data.length
  202. let train_html=''
  203. for (let i=0;i<n_length;i++){
  204. train_html += `<div class="item" data-value="${data[i].VersionName}">${data[i].VersionName}</div>`
  205. train_html += '</div>'
  206. }
  207. if(data.length){
  208. $("#job-version").append(train_html)
  209. $(".ui.dropdown.selection.search.width70").removeClass("loading")
  210. $('#choice_version .default.text').text(data[0].VersionName)
  211. $('#choice_version input[name="VersionName"]').val(data[0].VersionName)
  212. }
  213. })
  214. }
  215. </script>