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.1 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  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;" 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.cloudbrain.new"}}
  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').css('display','none')
  153. }
  154. })
  155. .modal('show')
  156. }
  157. $(function(){
  158. $('#choice_model').dropdown({
  159. onChange:function(value){
  160. $(".ui.dropdown.selection.search.width70").addClass("loading")
  161. $("#job-version").empty()
  162. loadTrainVersion(value)
  163. }
  164. })
  165. })
  166. function versionAdd(version){
  167. let versionArray = version.split('.')
  168. if(versionArray[2]=='9'){
  169. if(versionArray[1]=='9'){
  170. versionArray[0] = String(Number(versionArray[1])+1)
  171. versionArray[1] = '0'
  172. }else{
  173. versionArray[1]=String(Number(versionArray[1])+1)
  174. }
  175. versionArray[2]='0'
  176. }else{
  177. versionArray[2]=String(Number(versionArray[2])+1)
  178. }
  179. return versionArray.join('.')
  180. }
  181. function loadTrainList(){
  182. $.get(`${repolink}/modelmanage/query_train_job?repoId=${repoId}`, (data) => {
  183. const n_length = data.length
  184. let train_html=''
  185. for (let i=0;i<n_length;i++){
  186. train_html += `<div class="item" data-value="${data[i].JobID}">${data[i].JobName}</div>`
  187. train_html += '</div>'
  188. }
  189. $("#job-name").append(train_html)
  190. $(".ui.dropdown.selection.search.width83").removeClass("loading")
  191. })
  192. }
  193. function loadTrainVersion(value){
  194. $.get(`${repolink}/modelmanage/query_train_job_version?JobID=${value}`, (data) => {
  195. const n_length = data.length
  196. let train_html=''
  197. for (let i=0;i<n_length;i++){
  198. train_html += `<div class="item" data-value="${data[i].VersionName}">${data[i].VersionName}</div>`
  199. train_html += '</div>'
  200. }
  201. $("#job-version").append(train_html)
  202. $(".ui.dropdown.selection.search.width70").removeClass("loading")
  203. })
  204. }
  205. </script>