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 11 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  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 {{if ne $.MODEL_COUNT 0}}active loader {{end}}" id="loadContainer">
  20. {{template "base/alert" .}}
  21. <div class="ui two column stackable grid">
  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. {{if eq $.MODEL_COUNT 0}}
  29. <div class="ui placeholder segment bgtask-none">
  30. <div class="ui icon header bgtask-header-pic"></div>
  31. <div class="bgtask-content-header">未创建过模型</div>
  32. <div class="bgtask-content">
  33. {{if $.RepoIsEmpty}}
  34. <div class="bgtask-content-txt">代码版本:您还没有初始化代码仓库,请先<a href="{{.RepoLink}}">创建代码版本;</a></div>
  35. {{end}}
  36. {{if eq $.TRAIN_COUNT 0}}
  37. <div class="bgtask-content-txt">训练任务:你还没创建过训练任务,请先创建训练任务。</div>
  38. {{end}}
  39. <div class="bgtask-content-txt">使用说明:可以参考启智AI协作平台<a href="https://git.openi.org.cn/zeizei/OpenI_Learning">小白训练营课程。</a></div>
  40. </div>
  41. </div>
  42. {{else}}
  43. <!-- 中下列表展示区 -->
  44. <div class="ui grid" style="display: none;">
  45. <div class="row" style="padding-top: 0;">
  46. <div class="ui sixteen wide column">
  47. <!-- 任务展示 -->
  48. <div class="dataset list" id="model_list">
  49. <!-- 表头 -->
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. {{end}}
  55. </div>
  56. </div>
  57. <!-- div full height-->
  58. </div>
  59. <!-- 确认模态框 -->
  60. <div id="deletemodel">
  61. <div class="ui basic modal first">
  62. <div class="ui icon header">
  63. <i class="trash icon"></i> 删除模型
  64. </div>
  65. <div class="content">
  66. <p>你确认删除该模型么?此模型一旦删除不可恢复。</p>
  67. </div>
  68. <div class="actions">
  69. <div class="ui red basic inverted cancel button">
  70. <i class="remove icon"></i> 取消操作
  71. </div>
  72. <div class="ui green basic inverted ok button">
  73. <i class="checkmark icon"></i> 确定操作
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. <div id="newmodel">
  79. <div class="ui modal second">
  80. <div class="header" style="padding: 1rem;background-color: rgba(240, 240, 240, 100);">
  81. <h4 id="model_header"></h4>
  82. </div>
  83. <div class="content content-padding">
  84. <form id="formId" method="POST" class="ui form">
  85. <div class="ui error message">
  86. <!-- <p>asdasdasd</p> -->
  87. </div>
  88. <input type="hidden" name="_csrf" value="">
  89. <div class="two inline fields ">
  90. <div class="required ten wide field">
  91. <label style="margin-left: -23px;">选择训练任务</label>
  92. <div class="ui dropdown selection search width83 loading" id="choice_model">
  93. <input type="hidden" id="JobId" name="JobId" required>
  94. <div class="default text">选择训练任务</div>
  95. <i class="dropdown icon"></i>
  96. <div class="menu" id="job-name">
  97. </div>
  98. </div>
  99. </div>
  100. <div class="required six widde field">
  101. <label>版本</label>
  102. <div class="ui dropdown selection search width70" id="choice_version">
  103. <input type="hidden" id="VersionName" name="VersionName" required>
  104. <div class="default text">选择版本</div>
  105. <i class="dropdown icon"></i>
  106. <div class="menu" id="job-version">
  107. </div>
  108. </div>
  109. </div>
  110. </div>
  111. <div class="required inline field" id="modelname">
  112. <label>模型名称</label>
  113. <input style="width: 45%;" id="name" name="Name" required maxlength="25" onkeyup="this.value=this.value.replace(/[, ]/g,'')">
  114. </div>
  115. <div class="required inline field" id="verionname">
  116. <label>模型版本</label>
  117. <input style="width: 45%;" id="version" name="Version" value="" readonly required maxlength="255">
  118. </div>
  119. <div class="inline field">
  120. <label>模型标签</label>
  121. <input style="width: 83%;margin-left: 7px;" id="label" name="Label" maxlength="255" placeholder='{{.i18n.Tr "repo.modelarts.train_job.label_place"}}'>
  122. </div>
  123. <div class="inline field">
  124. <label for="description">模型描述</label>
  125. <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>
  126. </div>
  127. <div class="inline field" style="margin-left: 75px;">
  128. <button id="submitId" type="button" class="ui create_train_job green button" style="position: absolute;">
  129. {{.i18n.Tr "repo.model.manage.sava_model"}}
  130. </button>
  131. </div>
  132. </form>
  133. <div class="actions" style="display: inline-block;margin-left: 180px;">
  134. <button class="ui button cancel" >{{.i18n.Tr "repo.cloudbrain.cancel"}}</button>
  135. </div>
  136. </div>
  137. </div>
  138. {{template "base/footer" .}}
  139. <script>
  140. let repolink = {{.RepoLink}}
  141. let repoId = {{$repository}}
  142. const {_AppSubUrl, _StaticUrlPrefix, csrf} = window.config;
  143. $('input[name="_csrf"]').val(csrf)
  144. function createModelName(){
  145. let repoName = location.pathname.split('/')[2]
  146. let modelName = repoName + '_model_' + Math.random().toString(36).substr(2, 4)
  147. $('#name').val(modelName)
  148. $('#version').val("0.0.1")
  149. }
  150. function showcreate(obj){
  151. $('.ui.modal.second')
  152. .modal({
  153. centered: false,
  154. onShow:function(){
  155. $('#model_header').text("导入新模型")
  156. $('input[name="Version"]').addClass('model_disabled')
  157. $('.ui.dimmer').css({"background-color":"rgb(136, 136, 136,0.7)"})
  158. $("#job-name").empty()
  159. createModelName()
  160. loadTrainList()
  161. },
  162. onHide:function(){
  163. document.getElementById("formId").reset();
  164. $('#choice_model').dropdown('clear')
  165. $('#choice_version').dropdown('clear')
  166. $('.ui.dimmer').css({"background-color":""})
  167. $('.ui.error.message').text()
  168. $('.ui.error.message').css('display','none')
  169. }
  170. })
  171. .modal('show')
  172. }
  173. $(function(){
  174. $('#choice_model').dropdown({
  175. onChange:function(value){
  176. $(".ui.dropdown.selection.search.width70").addClass("loading")
  177. $('#choice_version').dropdown('clear')
  178. $("#job-version").empty()
  179. loadTrainVersion(value)
  180. }
  181. })
  182. })
  183. function versionAdd(version){
  184. let versionArray = version.split('.')
  185. if(versionArray[2]=='9'){
  186. if(versionArray[1]=='9'){
  187. versionArray[0] = String(Number(versionArray[1])+1)
  188. versionArray[1] = '0'
  189. }else{
  190. versionArray[1]=String(Number(versionArray[1])+1)
  191. }
  192. versionArray[2]='0'
  193. }else{
  194. versionArray[2]=String(Number(versionArray[2])+1)
  195. }
  196. return versionArray.join('.')
  197. }
  198. function loadTrainList(){
  199. $.get(`${repolink}/modelmanage/query_train_job?repoId=${repoId}`, (data) => {
  200. const n_length = data.length
  201. let train_html=''
  202. for (let i=0;i<n_length;i++){
  203. train_html += `<div class="item" data-value="${data[i].JobID}">${data[i].JobName}</div>`
  204. train_html += '</div>'
  205. }
  206. $("#job-name").append(train_html)
  207. $(".ui.dropdown.selection.search.width83").removeClass("loading")
  208. $('#choice_model .default.text').text(data[0].JobName)
  209. $('#choice_model input[name="JobId"]').val(data[0].JobID)
  210. loadTrainVersion()
  211. })
  212. }
  213. function loadTrainVersion(value){
  214. let JobID = !value ?$('#choice_model input[name="JobId"]').val(): value
  215. $.get(`${repolink}/modelmanage/query_train_job_version?JobID=${JobID}`, (data) => {
  216. const n_length = data.length
  217. let train_html=''
  218. for (let i=0;i<n_length;i++){
  219. train_html += `<div class="item" data-value="${data[i].VersionName}">${data[i].VersionName}</div>`
  220. train_html += '</div>'
  221. }
  222. if(data.length){
  223. $("#job-version").append(train_html)
  224. $(".ui.dropdown.selection.search.width70").removeClass("loading")
  225. $('#choice_version .default.text').text(data[0].VersionName)
  226. $('#choice_version input[name="VersionName"]').val(data[0].VersionName)
  227. }
  228. })
  229. }
  230. </script>